/* ============================================================
   Júlia Castellari Ribeiro — Advocacia
   Direção: editorial old-money. Marfim quente, navy profundo,
   fio dourado. Cormorant Garamond display + Inter corpo.
   ============================================================ */

/* ───── TEMA 1 · Old Money claro (padrão) ───── */
:root,
[data-theme="ivory"]{
  --ivory:      #F4EADE;   /* fundo marfim quente */
  --ivory-2:    #EFE3D4;   /* marfim levemente mais fechado */
  --navy:       #14202E;   /* quase-preto azulado, texto/escuro */
  --navy-deep:  #0E1822;   /* seção escura */
  --ink:        #1d2b38;
  --graphite:   #5b6672;   /* texto secundário */
  --gold:       #B08537;   /* acento — discreto */
  --gold-soft:  #c8a35a;
  --line:       #d9cab6;   /* fios sobre marfim */
  --line-dk:    #2a3a48;   /* fios sobre escuro */
  --grain-blend: multiply;
  --on-dark:      #F4EADE; /* texto SEMPRE claro sobre seção escura */
  --on-dark-soft: #e9dcc9;
  --on-dark-mut:  #c4cdd6;
}

/* ───── TEMA 2 · Dark premium / tech ─────
   fundo escuro elegante, texto off-white, acento gold.
   A "seção escura" (contato) fica ainda mais profunda que o fundo. */
[data-theme="dark"]{
  --ivory:      #111A24;   /* "fundo" agora é escuro */
  --ivory-2:    #16202C;
  --navy:       #F1E8DA;   /* "texto escuro" agora é claro */
  --navy-deep:  #0A1119;   /* seção contato — mais profunda */
  --ink:        #d9d2c4;
  --graphite:   #8b97a4;
  --gold:       #C9A45C;
  --gold-soft:  #e0c486;
  --line:       #2a3744;   /* fios sobre o escuro */
  --line-dk:    #2f3d4a;
  --grain-blend: screen;
  --on-dark:      #F1E8DA;
  --on-dark-soft: #ddd3c4;
  --on-dark-mut:  #9aa6b3;
}

/* ───── TEMA 3 · Verde heritage ─────
   verde escuro profundo + marfim + taupe + gold. */
[data-theme="green"]{
  --ivory:      #F3EBDD;   /* marfim levemente mais fresco */
  --ivory-2:    #E9DEC9;
  --navy:       #123A2E;   /* verde escuro = "texto/escuro" */
  --navy-deep:  #0C2C22;   /* seção verde profunda */
  --ink:        #234c3f;
  --graphite:   #6b6256;   /* taupe acinzentado */
  --gold:       #A8893E;
  --gold-soft:  #c2a25c;
  --line:       #d3c6ad;
  --line-dk:    #2c5044;
  --grain-blend: multiply;
  --on-dark:      #F3EBDD;
  --on-dark-soft: #e2d8c4;
  --on-dark-mut:  #b9c4ad;
}

:root{
  /* tipografia */
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, sans-serif;

  /* escala fluida */
  --step--1: clamp(0.82rem, 0.79rem + 0.12vw, 0.9rem);
  --step-0:  clamp(1.02rem, 0.98rem + 0.2vw, 1.16rem);
  --step-1:  clamp(1.2rem, 1.1rem + 0.5vw, 1.5rem);
  --step-2:  clamp(1.6rem, 1.4rem + 1vw, 2.2rem);
  --step-3:  clamp(2.1rem, 1.7rem + 2vw, 3.2rem);
  --hero:    clamp(3.2rem, 2rem + 6.5vw, 8.2rem);

  --maxw: 1240px;
  --gutter: clamp(1.4rem, 5vw, 6rem);
  --section-y: clamp(5rem, 9vw, 10rem);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  background:var(--ivory);
  color:var(--navy);
  font-family:var(--sans);
  font-size:var(--step-0);
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .5s ease, color .5s ease;
}

/* ░░ seletor de tema (canto inferior) ░░ */
.theme-switch{
  position:fixed; right:clamp(1rem,3vw,2rem); bottom:clamp(1rem,3vw,2rem); z-index:40;
  display:flex; align-items:center; gap:.55rem; padding:.55rem .65rem; border-radius:100px;
  background:color-mix(in srgb, var(--navy) 92%, transparent);
  box-shadow:0 10px 30px -12px rgba(0,0,0,.5);
  backdrop-filter:blur(8px);
}
.theme-switch__label{
  font-size:.62rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--on-dark-mut); margin-right:.1rem; user-select:none;
}
.theme-switch__dot{
  width:26px; height:26px; border-radius:50%; cursor:pointer; border:2px solid transparent;
  transition:transform .25s, border-color .25s, box-shadow .25s; position:relative; padding:0;
  -webkit-tap-highlight-color:transparent; flex:0 0 auto;
}
.theme-switch__dot:hover{ transform:scale(1.12); }
.theme-switch__dot[aria-pressed="true"]{ border-color:#fff; box-shadow:0 0 0 3px color-mix(in srgb,var(--gold) 55%,transparent); }
.theme-switch__dot--ivory{ background:linear-gradient(135deg,#F4EADE 50%,#14202E 50%); }
.theme-switch__dot--dark{ background:linear-gradient(135deg,#111A24 50%,#C9A45C 50%); }
.theme-switch__dot--green{ background:linear-gradient(135deg,#123A2E 50%,#F3EBDD 50%); }

/* ── mobile: maior, mais óbvio, alvo de toque confortável ── */
@media (max-width:640px){
  .theme-switch{
    bottom:1rem; right:50%; transform:translateX(50%);   /* centralizado embaixo */
    padding:.6rem .8rem; gap:.7rem;
  }
  .theme-switch__label{ font-size:.6rem; }
  .theme-switch__dot{ width:34px; height:34px; border-width:2.5px; }
  .theme-switch__dot[aria-pressed="true"]{ box-shadow:0 0 0 3px color-mix(in srgb,var(--gold) 60%,transparent); }
}
@media print{ .theme-switch{ display:none; } }
::selection{ background:var(--navy); color:var(--ivory); }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* textura de grão muito sutil, dá vida ao marfim */
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.035; mix-blend-mode:var(--grain-blend, multiply);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ░░ utilidades de layout ░░ */
.wrap{ max-width:var(--maxw); margin-inline:auto; }
main{ position:relative; z-index:2; }

/* ░░ reveal on scroll ░░ */
.reveal{ opacity:0; transform:translateY(26px); }
.reveal.in{
  opacity:1; transform:none;
  transition:opacity .9s cubic-bezier(.2,.7,.2,1) var(--d,0s),
             transform .9s cubic-bezier(.2,.7,.2,1) var(--d,0s);
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:20;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem var(--gutter);
  background:color-mix(in srgb, var(--ivory) 80%, transparent);
  backdrop-filter:blur(10px) saturate(1.1);
  border-bottom:1px solid transparent;
  transition:border-color .4s, background .4s, padding .4s;
}
.nav.scrolled{ border-bottom-color:var(--line); padding-block:.75rem; }
.nav__brand{ display:flex; align-items:baseline; gap:.7rem; }
.nav__mark{
  font-family:var(--serif); font-weight:600; font-size:1.35rem; letter-spacing:.06em;
  color:var(--navy);
}
.nav__name{
  font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--graphite);
}
.nav__links{ display:flex; align-items:center; gap:clamp(1rem,2.4vw,2.4rem); }
.nav__links a{
  font-size:.78rem; letter-spacing:.13em; text-transform:uppercase; color:var(--graphite);
  position:relative; transition:color .3s;
}
.nav__links a:hover{ color:var(--navy); }
.nav__links a:not(.nav__cta)::after{
  content:""; position:absolute; left:0; bottom:-5px; height:1px; width:0; background:var(--gold);
  transition:width .35s ease;
}
.nav__links a:not(.nav__cta):hover::after{ width:100%; }
.nav__cta{
  border:1px solid var(--navy); padding:.55em 1.1em; border-radius:100px; color:var(--navy)!important;
  transition:background .3s, color .3s;
}
.nav__cta:hover{ background:var(--navy); color:var(--ivory)!important; }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  padding:clamp(8rem,16vh,12rem) var(--gutter) clamp(4rem,8vw,7rem);
  max-width:var(--maxw); margin-inline:auto;
}
.hero__eyebrow{
  font-size:.76rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold);
  margin-bottom:clamp(1.4rem,3vw,2.4rem);
}
.hero__title{
  font-family:var(--serif); font-weight:500;
  font-size:var(--hero); line-height:.96; letter-spacing:-.015em;
  margin:0; color:var(--navy);
}
.hero__title span{ display:block; }
.hero__title em{ font-style:italic; color:var(--gold); font-weight:500; }
.hero__amp{ position:relative; }
.hero__amp::before{
  content:""; position:absolute; left:.02em; top:-.16em; width:clamp(40px,7vw,84px); height:1px;
  background:var(--gold); opacity:.6;
}
.hero__sub{
  max-width:46ch; margin:clamp(1.6rem,3vw,2.6rem) 0 0;
  font-size:var(--step-1); line-height:1.5; color:var(--ink); font-weight:400;
}
.hero__actions{
  display:flex; flex-wrap:wrap; gap:1rem; margin-top:clamp(2rem,4vw,3rem);
}
.hero__rule{
  height:1px; background:linear-gradient(90deg,var(--line),transparent);
  margin:clamp(3rem,6vw,5rem) 0 clamp(1.6rem,3vw,2.4rem);
}
.hero__meta{
  list-style:none; margin:0; padding:0; display:grid; gap:1rem;
  grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
}
.hero__meta li{
  font-size:var(--step--1); color:var(--graphite); line-height:1.55;
}
.hero__meta strong{
  display:block; font-family:var(--serif); font-size:1.2rem; font-weight:600;
  color:var(--navy); letter-spacing:.01em; margin-bottom:.15rem;
}

/* ░░ botões ░░ */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; font-weight:500;
  padding:1em 1.7em; border-radius:100px; cursor:pointer; border:1px solid var(--navy);
  transition:transform .3s cubic-bezier(.2,.7,.2,1), background .3s, color .3s, box-shadow .3s;
}
.btn--solid{ background:var(--navy); color:var(--ivory); }
.btn--solid:hover{ background:var(--navy-deep); transform:translateY(-2px);
  box-shadow:0 14px 30px -14px rgba(20,32,46,.6); }
.btn--ghost{ background:transparent; color:var(--navy); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--navy); transform:translateY(-2px); }

/* ============================================================
   LEDE (problema)
   ============================================================ */
.lede{
  padding:clamp(3rem,7vw,7rem) var(--gutter);
  max-width:1080px; margin-inline:auto;
}
.lede__text{
  font-family:var(--serif); font-weight:400;
  font-size:var(--step-3); line-height:1.32; letter-spacing:-.01em; color:var(--navy);
  text-wrap:balance;
}
.lede__text .u{
  font-style:italic; color:var(--ink);
  background-image:linear-gradient(transparent 62%, color-mix(in srgb,var(--gold) 30%,transparent) 0);
}

/* ============================================================
   SECTION HEAD compartilhado
   ============================================================ */
.section-head{
  display:flex; align-items:baseline; gap:1rem;
  padding-bottom:clamp(2rem,4vw,3.2rem);
  border-bottom:1px solid var(--line);
  margin-bottom:clamp(2.6rem,5vw,4rem);
}
.section-head__num{
  font-family:var(--serif); font-size:1rem; color:var(--gold); letter-spacing:.1em;
}
.section-head__title{
  font-family:var(--serif); font-weight:500; font-size:var(--step-2); margin:0;
  letter-spacing:-.01em;
}
.section-head--light{ border-color:var(--line-dk); }
.section-head--light .section-head__title{ color:var(--on-dark); }

/* ============================================================
   ÁREAS
   ============================================================ */
.areas{ padding:var(--section-y) var(--gutter); max-width:var(--maxw); margin-inline:auto; }
.areas__grid{
  display:grid; gap:clamp(1.6rem,3vw,2.6rem);
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
}
.area{
  border-top:2px solid var(--navy);
  padding-top:1.6rem;
  position:relative;
}
.area__idx{
  font-family:var(--serif); font-style:italic; font-size:1.1rem; color:var(--gold);
  letter-spacing:.04em;
}
.area__title{
  font-family:var(--serif); font-weight:600; font-size:var(--step-2); margin:.4rem 0 .8rem;
  letter-spacing:-.01em; line-height:1.05;
}
.area__desc{ color:var(--ink); margin:0 0 1.4rem; max-width:34ch; }
.area__list{ list-style:none; margin:0; padding:0; }
.area__list li{
  font-size:var(--step--1); color:var(--graphite); padding:.5rem 0; padding-left:1.3rem;
  position:relative; border-top:1px solid var(--line);
}
.area__list li:first-child{ border-top:none; }
.area__list li::before{
  content:""; position:absolute; left:0; top:1.05em; width:7px; height:1px; background:var(--gold);
}

/* ============================================================
   SOBRE
   ============================================================ */
.about{ padding:var(--section-y) var(--gutter); max-width:var(--maxw); margin-inline:auto; }
.about__grid{
  display:grid; gap:clamp(2rem,5vw,5rem);
  grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);
  align-items:start;
}
.portrait{
  position:relative; aspect-ratio:4/5; border-radius:3px; margin:0;
  background:var(--ivory-2);
  border:1px solid var(--line);
  overflow:hidden;
}
.portrait img{
  width:100%; height:100%; object-fit:cover; object-position:center 22%;
  display:block;
  filter:saturate(.96) contrast(1.02);
}
/* moldura interna fina dourada por cima da foto, dá o ar editorial */
.portrait::after{
  content:""; position:absolute; inset:10px; border:1px solid color-mix(in srgb, var(--gold) 55%, transparent);
  pointer-events:none;
}
.about__lead{
  font-family:var(--serif); font-size:var(--step-2); line-height:1.28; font-weight:500;
  letter-spacing:-.01em; margin:0 0 1.4rem;
}
.about__body p{ color:var(--ink); margin:0 0 1.2rem; max-width:58ch; }
.about__facts{
  margin:2.2rem 0 0; display:grid; gap:0; grid-template-columns:1fr 1fr;
  border-top:1px solid var(--line);
}
.about__facts > div{
  padding:1.1rem .2rem; border-bottom:1px solid var(--line);
}
.about__facts > div:nth-child(odd){ border-right:1px solid var(--line); padding-right:1.4rem; }
.about__facts > div:nth-child(even){ padding-left:1.4rem; }
.about__facts dt{
  font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:.3rem;
}
.about__facts dd{ margin:0; font-family:var(--serif); font-size:1.22rem; color:var(--navy); }

/* ============================================================
   PROCESSO
   ============================================================ */
.process{ padding:var(--section-y) var(--gutter); max-width:var(--maxw); margin-inline:auto; }
.process__list{
  list-style:none; margin:0; padding:0;
  display:grid; gap:clamp(1.4rem,3vw,2.4rem);
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  counter-reset:step;
}
.step{ position:relative; padding-top:2.2rem; }
.step__num{
  font-family:var(--serif); font-size:2.6rem; color:var(--gold); opacity:.85; line-height:1;
  display:block; margin-bottom:.6rem;
}
.step__title{
  font-family:var(--serif); font-weight:600; font-size:1.5rem; margin:0 0 .5rem; letter-spacing:-.01em;
}
.step p{ color:var(--graphite); font-size:var(--step--1); margin:0; max-width:30ch; }

/* ============================================================
   CONTATO (seção escura)
   ============================================================ */
.contact{
  background:var(--navy-deep); color:var(--on-dark);
  margin-top:clamp(2rem,5vw,5rem);
  position:relative; overflow:hidden;
}
.contact::before{
  /* leve brilho dourado no canto */
  content:""; position:absolute; top:-20%; right:-10%; width:50vw; height:50vw;
  background:radial-gradient(circle, color-mix(in srgb,var(--gold) 14%,transparent), transparent 60%);
  pointer-events:none;
}
.contact__inner{
  position:relative; max-width:920px; margin-inline:auto;
  padding:var(--section-y) var(--gutter);
}
.contact__lead{
  font-family:var(--serif); font-size:var(--step-2); line-height:1.32; max-width:34ch;
  color:var(--on-dark-soft); margin:0 0 clamp(2.4rem,5vw,3.6rem); font-weight:500;
}
.form{
  display:grid; grid-template-columns:1fr 1fr; gap:1.4rem 1.6rem;
}
.field{ display:flex; flex-direction:column; gap:.5rem; }
.field--full{ grid-column:1 / -1; }
.field label{
  font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-soft);
}
.field input, .field select, .field textarea{
  font-family:var(--sans); font-size:1rem; color:var(--on-dark);
  background:transparent; border:none; border-bottom:1px solid var(--line-dk);
  padding:.7rem 0; outline:none; transition:border-color .3s; border-radius:0;
}
.field textarea{ resize:vertical; }
.field select{ appearance:none; cursor:pointer;
  background-image:linear-gradient(45deg,transparent 50%,var(--gold-soft) 50%),
                   linear-gradient(135deg,var(--gold-soft) 50%,transparent 50%);
  background-position:right 2px center, right 7px center; background-size:5px 5px, 5px 5px;
  background-repeat:no-repeat; padding-right:1.5rem; }
.field select option{ background:var(--navy-deep); color:var(--on-dark); }
.field input:focus, .field select:focus, .field textarea:focus{ border-color:var(--gold); }
.field input::placeholder, .field textarea::placeholder{ color:#6b7785; }
.form__actions{ display:flex; align-items:center; gap:1.6rem; flex-wrap:wrap; margin-top:.6rem; }
.form .btn--solid{ background:var(--gold); border-color:var(--gold); color:var(--navy-deep); }
.form .btn--solid:hover{ background:var(--gold-soft); border-color:var(--gold-soft); }
.contact__alt{
  font-size:.84rem; letter-spacing:.04em; color:#cdbfa9; border-bottom:1px solid transparent;
  transition:border-color .3s, color .3s;
}
.contact__alt:hover{ color:var(--on-dark); border-color:var(--gold); }
.form__note{ font-size:.9rem; color:var(--gold-soft); margin:.4rem 0 0; }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{
  background:var(--navy-deep); color:var(--on-dark);
  padding:clamp(3rem,6vw,5rem) var(--gutter) 2rem;
  display:grid; gap:2.4rem;
  grid-template-columns:1.4fr 1fr; align-items:start;
  position:relative; z-index:2;
  border-top:1px solid var(--line-dk);
}
.foot__mark{ font-family:var(--serif); font-size:1.6rem; display:block; letter-spacing:.01em; }
.foot__role{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:#8a96a3; margin-top:.5rem; display:block; }
.foot__cols{ display:flex; gap:clamp(2rem,5vw,4rem); justify-content:flex-end; }
.foot__h{ font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-soft); display:block; margin-bottom:.9rem; }
.foot__cols a{ display:block; font-size:.92rem; color:var(--on-dark-mut); padding:.25rem 0; transition:color .3s; }
.foot__cols a:hover{ color:var(--on-dark); }
.foot__legal{
  grid-column:1 / -1; border-top:1px solid var(--line-dk); padding-top:1.6rem; margin:0;
  font-size:.74rem; line-height:1.6; color:#7c8893; max-width:80ch;
}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media (max-width:860px){
  .nav__name{ display:none; }
  .about__grid{ grid-template-columns:1fr; }
  .about__portrait{ max-width:360px; }
  .form{ grid-template-columns:1fr; }
  .foot{ grid-template-columns:1fr; }
  .foot__cols{ justify-content:flex-start; }
}
@media (max-width:520px){
  .nav__links a:not(.nav__cta){ display:none; }
  .about__facts{ grid-template-columns:1fr; }
  .about__facts > div:nth-child(odd){ border-right:none; padding-right:.2rem; }
  .about__facts > div:nth-child(even){ padding-left:.2rem; }
}

/* ============================================================
   ACESSIBILIDADE — reduzir movimento
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1!important; transform:none!important; transition:none!important; }
  html{ scroll-behavior:auto; }
  *{ animation:none!important; }
}

/* ============================================================
   BLOG  ·  índice (insights.html) + artigo (artigo.html)
   ============================================================ */

/* hero curto das páginas internas */
.page-hero{
  padding:clamp(8rem,16vh,11rem) var(--gutter) clamp(2rem,4vw,3.5rem);
  max-width:var(--maxw); margin-inline:auto;
}
.page-hero__eyebrow{
  font-size:.76rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold);
  margin-bottom:1.2rem;
}
.page-hero__title{
  font-family:var(--serif); font-weight:500; font-size:var(--step-3); line-height:1.02;
  letter-spacing:-.015em; margin:0; color:var(--navy); max-width:18ch;
}
.page-hero__sub{
  margin:1.4rem 0 0; font-size:var(--step-1); color:var(--ink); max-width:52ch; line-height:1.5;
}

/* índice de artigos */
.posts{ max-width:var(--maxw); margin:0 auto clamp(4rem,8vw,7rem); padding-inline:var(--gutter); }
.posts__list{ list-style:none; margin:0; padding:0; }
.post-row{
  display:grid; grid-template-columns:auto 1fr auto; gap:clamp(1rem,3vw,3rem); align-items:baseline;
  padding:clamp(1.6rem,3vw,2.4rem) 0; border-top:1px solid var(--line);
  text-decoration:none; color:inherit; position:relative; transition:padding-left .4s cubic-bezier(.2,.7,.2,1);
}
.posts__list li:last-child .post-row{ border-bottom:1px solid var(--line); }
.post-row:hover{ padding-left:.8rem; }
.post-row__idx{ font-family:var(--serif); font-style:italic; color:var(--gold); font-size:1.05rem; }
.post-row__main{ min-width:0; }
.post-row__title{
  font-family:var(--serif); font-weight:600; font-size:clamp(1.4rem,2.6vw,2rem); line-height:1.1;
  letter-spacing:-.01em; margin:0 0 .4rem; color:var(--navy);
  transition:color .3s;
}
.post-row:hover .post-row__title{ color:var(--gold); }
.post-row__dek{ color:var(--graphite); font-size:var(--step--1); margin:0; max-width:60ch; }
.post-row__tags{ margin-top:.7rem; display:flex; gap:.5rem; flex-wrap:wrap; }
.tag{
  font-size:.68rem; letter-spacing:.1em; text-transform:uppercase; color:var(--graphite);
  border:1px solid var(--line); border-radius:100px; padding:.25em .8em;
}
.post-row__meta{ font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color:var(--graphite); white-space:nowrap; }
.post-row__arrow{ font-family:var(--serif); color:var(--gold); font-size:1.3rem; opacity:0; transform:translateX(-6px); transition:.35s; }
.post-row:hover .post-row__arrow{ opacity:1; transform:none; }

/* ── artigo ── */
.article{ max-width:760px; margin:0 auto; padding:clamp(8rem,15vh,10rem) var(--gutter) 0; }
.article__back{
  font-size:.76rem; letter-spacing:.14em; text-transform:uppercase; color:var(--graphite);
  display:inline-block; margin-bottom:2.4rem; transition:color .3s;
}
.article__back:hover{ color:var(--gold); }
.article__eyebrow{ font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); margin-bottom:1.1rem; }
.article__title{
  font-family:var(--serif); font-weight:500; font-size:var(--step-3); line-height:1.05;
  letter-spacing:-.015em; margin:0 0 1rem; color:var(--navy);
}
.article__sub{ font-family:var(--serif); font-style:italic; font-size:var(--step-1); color:var(--ink); margin:0 0 1.6rem; }
.article__meta{
  display:flex; gap:1.2rem; align-items:center; flex-wrap:wrap;
  font-size:.76rem; letter-spacing:.08em; text-transform:uppercase; color:var(--graphite);
  padding-bottom:2.2rem; border-bottom:1px solid var(--line); margin-bottom:2.6rem;
}
.article__body{ font-size:1.12rem; line-height:1.75; color:var(--ink); }
.article__body h2{
  font-family:var(--serif); font-weight:600; font-size:clamp(1.5rem,3vw,2rem); line-height:1.12;
  letter-spacing:-.01em; color:var(--navy); margin:2.6rem 0 .9rem;
}
.article__body h3{
  font-family:var(--serif); font-weight:600; font-size:1.3rem; color:var(--navy); margin:1.8rem 0 .6rem;
}
.article__body p{ margin:0 0 1.2rem; }
.article__body ul, .article__body ol{ margin:0 0 1.4rem; padding-left:0; list-style:none; }
.article__body li{ position:relative; padding-left:1.5rem; margin-bottom:.6rem; }
.article__body ul li::before{ content:""; position:absolute; left:0; top:.7em; width:8px; height:1px; background:var(--gold); }
.article__body ol{ counter-reset:li; }
.article__body ol li{ counter-increment:li; }
.article__body ol li::before{
  content:counter(li); position:absolute; left:0; top:0; font-family:var(--serif);
  color:var(--gold); font-size:.95rem; font-style:italic;
}
.article__body blockquote{
  margin:2rem 0; padding:1.4rem 0 1.4rem 1.8rem; border-left:2px solid var(--gold);
  font-family:var(--serif); font-style:italic; font-size:1.35rem; line-height:1.4; color:var(--navy);
}
.article__body strong{ color:var(--navy); font-weight:600; }
.article__body a{ color:var(--gold); text-decoration:underline; text-underline-offset:3px; text-decoration-thickness:1px; }

/* CTA institucional no fim do artigo */
.article__cta{
  margin:3.5rem 0 0; padding:2.4rem; border-radius:4px;
  background:var(--ivory-2); border:1px solid var(--line);
  display:flex; flex-direction:column; gap:1.2rem; align-items:flex-start;
}
.article__cta p{ font-family:var(--serif); font-size:1.25rem; line-height:1.4; color:var(--navy); margin:0; max-width:46ch; }

/* tags do artigo + navegação entre posts */
.article__foot{ max-width:760px; margin:3rem auto 0; padding:0 var(--gutter); }
.article__tags{ display:flex; gap:.5rem; flex-wrap:wrap; padding-bottom:2.4rem; }
.article__disclaimer{
  border-top:1px solid var(--line); padding:1.8rem 0 0; margin-top:0;
  font-size:.78rem; line-height:1.6; color:var(--graphite);
}

@media (max-width:640px){
  .post-row{ grid-template-columns:auto 1fr; }
  .post-row__meta{ display:none; }
  .article__body{ font-size:1.05rem; }
}

/* ============================================================
   INSIGHTS na HOME (seção de destaque)
   ============================================================ */
.section-head__link{
  margin-left:auto; font-size:.74rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--gold); white-space:nowrap; transition:opacity .3s; align-self:center;
}
.section-head__link:hover{ opacity:.7; }

.home-insights{ padding:var(--section-y) var(--gutter); max-width:var(--maxw); margin-inline:auto; }
.home-insights__lede{
  font-family:var(--serif); font-size:var(--step-1); color:var(--ink); max-width:54ch;
  margin:0 0 clamp(2.4rem,4vw,3.4rem); line-height:1.4;
}
.home-insights__grid{
  display:grid; gap:clamp(1.2rem,2.5vw,2rem);
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}
.post-card{
  display:flex; flex-direction:column; gap:.7rem; text-decoration:none; color:inherit;
  border-top:2px solid var(--navy); padding:1.4rem .2rem 1.6rem;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), border-color .3s;
}
.post-card:hover{ transform:translateY(-4px); border-color:var(--gold); }
.post-card__tag{
  font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold);
}
.post-card__title{
  font-family:var(--serif); font-weight:600; font-size:1.45rem; line-height:1.14;
  letter-spacing:-.01em; margin:0; color:var(--navy); transition:color .3s;
}
.post-card:hover .post-card__title{ color:var(--gold); }
.post-card__dek{ color:var(--graphite); font-size:var(--step--1); margin:0; flex:1; }
.post-card__meta{
  font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--graphite);
  margin-top:.3rem;
}
@media (max-width:520px){
  .section-head__link{ font-size:.68rem; }
}

/* ============================================================
   FUNIL: bloco autora, CTA inline, leia também, tag clicável
   ============================================================ */

/* tag clicável (vira link, mantém visual) */
a.tag{ transition:border-color .25s, color .25s; }
a.tag:hover{ border-color:var(--gold); color:var(--gold); }

/* CTA inline no meio do artigo */
.cta-inline{
  margin:2.4rem 0; padding:1.3rem 1.6rem; border-radius:4px;
  border-left:2px solid var(--gold); background:var(--ivory-2);
  display:flex; align-items:center; justify-content:space-between; gap:1.2rem; flex-wrap:wrap;
}
.cta-inline p{ margin:0; font-family:var(--serif); font-size:1.18rem; color:var(--navy); line-height:1.3; }
.cta-inline a{
  white-space:nowrap; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase; font-weight:500;
  color:var(--gold); border-bottom:1px solid var(--gold); padding-bottom:2px; transition:opacity .3s;
}
.cta-inline a:hover{ opacity:.7; }

/* bloco "Sobre a autora" */
.author-box{
  max-width:760px; margin:3rem auto 0; padding:1.8rem var(--gutter);
  display:flex; gap:1.6rem; align-items:flex-start;
}
.author-box__photo{
  width:96px; height:96px; border-radius:50%; object-fit:cover; object-position:center 20%;
  border:1px solid var(--line); flex:0 0 auto;
}
.author-box__eyebrow{ font-size:.66rem; letter-spacing:.2em; text-transform:uppercase; color:var(--gold); }
.author-box__name{ font-family:var(--serif); font-weight:600; font-size:1.4rem; margin:.2rem 0 .5rem; color:var(--navy); }
.author-box__bio{ font-size:.92rem; line-height:1.6; color:var(--graphite); margin:0 0 .7rem; }
.author-box__link{ font-size:.8rem; letter-spacing:.06em; color:var(--gold); border-bottom:1px solid transparent; transition:border-color .3s; }
.author-box__link:hover{ border-color:var(--gold); }

/* "Leia também" */
.related{ max-width:760px; margin:2.6rem auto 0; padding:2rem var(--gutter) 0; border-top:1px solid var(--line); }
.related__head{ font-family:var(--serif); font-weight:600; font-size:1.5rem; margin:0 0 1.4rem; color:var(--navy); }
.related__grid{ display:grid; gap:1rem; grid-template-columns:repeat(auto-fit,minmax(210px,1fr)); }
.related__item{
  display:flex; flex-direction:column; gap:.5rem; padding:1.1rem 1.2rem; border:1px solid var(--line);
  border-radius:4px; transition:transform .35s cubic-bezier(.2,.7,.2,1), border-color .3s; background:var(--ivory-2);
}
.related__item:hover{ transform:translateY(-3px); border-color:var(--gold); }
.related__tag{ font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); }
.related__title{ font-family:var(--serif); font-weight:600; font-size:1.08rem; line-height:1.2; color:var(--navy); }

@media (max-width:560px){
  .author-box{ flex-direction:column; gap:1rem; }
  .cta-inline{ flex-direction:column; align-items:flex-start; }
}

/* ============================================================
   FAQ + lede do processo + posicionamento
   ============================================================ */
.process__lede{
  font-family:var(--serif); font-size:var(--step-1); line-height:1.45; color:var(--ink);
  max-width:60ch; margin:0 0 clamp(2.4rem,4vw,3.4rem);
}
.faq{ padding:var(--section-y) var(--gutter); max-width:880px; margin-inline:auto; }
.faq__list{ display:flex; flex-direction:column; }
.faq__item{
  border-top:1px solid var(--line); padding:.2rem 0;
}
.faq__item:last-child{ border-bottom:1px solid var(--line); }
.faq__q{
  font-family:var(--serif); font-size:clamp(1.2rem,2.2vw,1.5rem); font-weight:500; color:var(--navy);
  cursor:pointer; list-style:none; padding:1.3rem 2.5rem 1.3rem 0; position:relative; line-height:1.25;
  transition:color .3s;
}
.faq__q::-webkit-details-marker{ display:none; }
.faq__q::after{
  content:"+"; position:absolute; right:.2rem; top:1.2rem; font-family:var(--serif); font-size:1.6rem;
  color:var(--gold); transition:transform .35s; line-height:1;
}
.faq__item[open] .faq__q::after{ transform:rotate(45deg); }
.faq__item[open] .faq__q{ color:var(--gold); }
.faq__a{ padding:0 2.5rem 1.4rem 0; }
.faq__a p{ margin:0; color:var(--graphite); font-size:1.02rem; line-height:1.65; max-width:68ch; }
