/* ==========================================================================
   Vítor Zimermann · Advocacia e Consultoria — estilos
   Paleta: tinta (quase preto azulado) + papel + acento dourado sóbrio
   ========================================================================== */
:root{
  --ink:#12294D;          /* azul-marinho quase preto (base) */
  --ink-2:#193558;
  --ink-3:#21406E;
  --paper:#F6F5F2;
  --paper-2:#ECEAE3;
  /* --gold / --gold-2 = ACENTO da marca (agora VERMELHO). Nome mantido p/ não
     alterar dezenas de usos; representa a cor de ação/urgência. */
  --gold:#C1121F;
  --gold-2:#E23140;
  --navy:#1B3A66;         /* azul-marinho institucional (confiança) */
  --white:#FFFFFF;
  --muted:#8A93A1;
  --muted-d:#5C6572;
  --line:rgba(255,255,255,.12);
  --line-d:rgba(16,36,66,.12);
  --maxw:1180px;
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  --radius:14px;
  --shadow:0 24px 60px -20px rgba(0,0,0,.45);
}

*{box-sizing:border-box}
/* evita overflow horizontal: filhos de grid/flex podem encolher */
.hero-grid>*,.two-col>*,.sobre-grid>*,.contato-grid>*,.urgencia-inner>*{min-width:0}
h1,h2,h3,p,li,a{overflow-wrap:break-word}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- Tipografia utilitária ---------- */
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.1;margin:0 0 .4em;letter-spacing:.2px}
.eyebrow{
  font-family:var(--sans);text-transform:uppercase;letter-spacing:.28em;
  font-size:.72rem;font-weight:600;color:var(--gold);margin:0 0 1rem
}
em{font-style:italic;color:var(--gold-2)}

/* ---------- Botões ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:600;font-size:.94rem;letter-spacing:.02em;
  padding:.9rem 1.5rem;border-radius:999px;cursor:pointer;border:1px solid transparent;
  transition:transform .18s ease,background .2s ease,color .2s ease,border-color .2s;white-space:nowrap
}
.btn:hover{transform:translateY(-2px)}
/* CTA principal "falar com advogado" = VERDE (WhatsApp). Vermelho fica só como acento de marca. */
.btn-gold{background:linear-gradient(120deg,#1FAB53,#25D366);color:#fff;box-shadow:0 12px 30px -12px rgba(31,157,85,.55)}
.btn-gold:hover{filter:brightness(1.04)}
.btn-ghost{background:transparent;border-color:currentColor;color:inherit}
.btn-ghost:hover{background:rgba(183,150,90,.12)}
.btn-wpp{background:linear-gradient(120deg,#1FAB53,#25D366);color:#fff}
.btn-wpp:hover{filter:brightness(1.04)}
.btn-block{width:100%}
.ico{width:18px;height:18px;fill:currentColor}

/* ==========================================================================
   HEADER
   ========================================================================== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .3s ease,box-shadow .3s ease,padding .3s ease;
  padding:14px 0
}
.site-header.scrolled{background:rgba(16,36,66,.92);backdrop-filter:blur(10px);box-shadow:0 1px 0 var(--line)}
.header-inner{display:flex;align-items:center;gap:24px}
.brand-logo{height:44px;width:auto}
.nav{display:flex;gap:30px;margin-left:auto}
.nav a{color:rgba(255,255,255,.82);font-size:.92rem;font-weight:500;letter-spacing:.02em;position:relative;padding:4px 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold);transition:width .25s}
.nav a:hover{color:#fff}
.nav a:hover::after{width:100%}
.header-cta{padding:.62rem 1.1rem;font-size:.88rem}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;margin-left:auto}
.nav-toggle span{width:26px;height:2px;background:#fff;transition:.3s}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{
  display:none;flex-direction:column;gap:2px;background:rgba(16,36,66,.98);
  padding:10px 24px 22px;border-top:1px solid var(--line)
}
.mobile-nav.open{display:flex}
.mobile-nav a{color:#fff;padding:14px 4px;border-bottom:1px solid var(--line);font-size:1rem}
.mobile-nav .btn{margin-top:14px;border-bottom:0}

/* ==========================================================================
   HERO
   ========================================================================== */
.hero{
  position:relative;background:
    radial-gradient(1200px 600px at 75% -10%,rgba(183,150,90,.14),transparent 60%),
    linear-gradient(180deg,#0E2447 0%,var(--ink) 55%,var(--ink-2) 100%);
  color:#fff;padding:150px 0 90px;overflow:hidden
}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(90deg,transparent 60%,rgba(0,0,0,.35));
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center;position:relative}
.hero-copy h1{font-size:clamp(2.4rem,5vw,4rem);margin-bottom:.5em;font-weight:600}
.hero-copy .lede{font-size:1.16rem;color:rgba(255,255,255,.78);max-width:34ch;margin:0 0 2rem}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:2.4rem}
.hero-trust{list-style:none;margin:0;padding:1.5rem 0 0;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:8px 28px}
.hero-trust li{font-size:.92rem;color:rgba(255,255,255,.62)}
.hero-trust strong{color:#fff;font-weight:600}
.hero-media{position:relative}
.hero-media img{
  width:100%;max-width:460px;margin-left:auto;border-radius:18px;
  border:1px solid var(--line);box-shadow:var(--shadow);
  object-fit:cover;object-position:center top;aspect-ratio:1/1
}
.hero-badge{
  position:absolute;left:8px;bottom:22px;background:var(--gold);color:#fff;
  font-weight:600;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;
  padding:.5rem 1rem;border-radius:999px;box-shadow:0 10px 24px -8px rgba(0,0,0,.5)
}

/* ==========================================================================
   FAIXA URGÊNCIA
   ========================================================================== */
.urgencia{background:var(--ink-3);color:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.urgencia-inner{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:34px 0}
.urgencia h2{font-size:1.7rem;margin:0 0 .2em}
.urgencia p{margin:0;color:rgba(255,255,255,.72);max-width:60ch}

/* ==========================================================================
   SECTIONS (base)
   ========================================================================== */
.section{padding:96px 0}
.section-head{max-width:640px;margin:0 0 54px}
.section-head h2{font-size:clamp(2rem,3.6vw,2.9rem)}
.section-sub{color:var(--muted-d);font-size:1.06rem;margin:0}

/* ---------- Áreas de atuação ---------- */
.atuacao{background:var(--paper)}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{
  background:var(--white);border:1px solid var(--line-d);border-radius:var(--radius);
  padding:30px 26px 32px;position:relative;transition:transform .2s,box-shadow .2s,border-color .2s
}
.card:hover{transform:translateY(-6px);box-shadow:0 26px 50px -28px rgba(16,36,66,.4);border-color:rgba(183,150,90,.5)}
.card-num{font-family:var(--serif);font-size:1.1rem;color:var(--gold);font-weight:700}
.card h3{font-size:1.4rem;margin:.5rem 0 .5rem}
.card p{color:var(--muted-d);font-size:.96rem;margin:0}
/* Especialidades agrupadas */
.cards-lead{font-size:.78rem;text-transform:uppercase;letter-spacing:.22em;color:var(--gold);font-weight:600;margin:0 0 18px}
.especialidades{margin-top:64px}
.esp-head{max-width:640px;margin:0 0 28px}
.esp-head h3{font-size:clamp(1.7rem,3vw,2.2rem);margin:0 0 .25em}
.esp-head p{color:var(--muted-d);margin:0;font-size:1.02rem}
.esp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.esp-card{background:var(--white);border:1px solid var(--line-d);border-radius:14px;padding:24px 24px 18px;transition:.2s}
.esp-card:hover{border-color:rgba(183,150,90,.5);box-shadow:0 20px 44px -28px rgba(16,36,66,.35)}
.esp-card h4{font-family:var(--serif);font-size:1.28rem;margin:0 0 12px;color:var(--ink);display:flex;align-items:center;gap:10px;line-height:1.2}
.esp-card h4::before{content:"";width:22px;height:2px;background:var(--gold);flex:none}
.esp-list{list-style:none;margin:0;padding:0;display:grid}
.esp-list li{border-top:1px solid var(--line-d)}
.esp-list li:first-child{border-top:0}
.esp-list a,.esp-list span{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 0;color:#3a424d;font-size:.95rem}
.esp-list a{transition:.15s}
.esp-list a:hover{color:var(--gold);padding-left:4px}
.esp-list a::after{content:"→";color:var(--gold);opacity:.75;font-size:.9rem;flex:none}
.esp-nota{margin-top:24px;font-size:.9rem;color:var(--muted-d)}
.esp-nota a{color:#12335F;text-decoration:underline;text-underline-offset:2px}
@media (max-width:900px){.esp-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.esp-grid{grid-template-columns:1fr}}

/* ---------- Compromisso / assistência ---------- */
.compromisso{background:var(--paper-2)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:56px}
.col-block h2{font-size:1.8rem;max-width:20ch}
.check-list{list-style:none;margin:1.4rem 0 0;padding:0;display:grid;gap:12px}
.check-list li{position:relative;padding-left:34px;color:#333b46}
.check-list li::before{
  content:"";position:absolute;left:0;top:2px;width:20px;height:20px;border-radius:50%;
  background:var(--gold);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/13px no-repeat;
          mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/></svg>") center/13px no-repeat
}

/* ---------- Sobre ---------- */
.sobre{background:var(--ink);color:#fff}
.sobre-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center}
.sobre-media img{border-radius:18px;border:1px solid var(--line);box-shadow:var(--shadow)}
.sobre-copy h2{font-size:clamp(2rem,3.4vw,2.8rem);color:#fff;margin-bottom:.15em}
.sobre-cargo{color:var(--gold);font-weight:600;letter-spacing:.04em;margin:0 0 1.4rem}
.sobre-copy p{color:rgba(255,255,255,.8)}
.sobre-facts{list-style:none;margin:2rem 0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:20px}
.sobre-facts li{border-left:2px solid var(--gold);padding-left:16px}
.sobre-facts strong{display:block;font-family:var(--serif);font-size:1.5rem;color:#fff}
.sobre-facts span{font-size:.9rem;color:rgba(255,255,255,.6)}

/* ---------- Atendimento (passos) ---------- */
.atendimento{background:var(--paper)}
.passos{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:p}
.passos li{position:relative;padding-top:14px}
.passo-n{
  display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;
  border:1px solid rgba(183,150,90,.4);color:var(--gold);font-family:var(--serif);font-size:1.5rem;font-weight:700;margin-bottom:16px
}
.passos h3{font-size:1.3rem;margin:0 0 .3em}
.passos p{color:var(--muted-d);font-size:.96rem;margin:0}

/* ---------- FAQ ---------- */
.faq{background:var(--paper-2)}
.faq-wrap{max-width:820px;margin:0 auto}
.accordion{display:grid;gap:12px}
.acc-item{background:var(--white);border:1px solid var(--line-d);border-radius:12px;overflow:hidden}
.acc-head{
  width:100%;text-align:left;background:none;border:0;cursor:pointer;
  font-family:var(--serif);font-size:1.22rem;font-weight:600;color:var(--ink);
  padding:20px 24px;display:flex;justify-content:space-between;align-items:center;gap:16px
}
.acc-ico{position:relative;width:16px;height:16px;flex:none}
.acc-ico::before,.acc-ico::after{content:"";position:absolute;background:var(--gold);transition:.3s}
.acc-ico::before{top:7px;left:0;width:16px;height:2px}
.acc-ico::after{left:7px;top:0;width:2px;height:16px}
.acc-item.open .acc-ico::after{transform:scaleY(0)}
.acc-body{max-height:0;overflow:hidden;transition:max-height .32s ease}
.acc-body p{margin:0;padding:0 24px 22px;color:var(--muted-d)}

/* ---------- Contato ---------- */
.contato{background:var(--ink);color:#fff}
.contato-grid{display:grid;grid-template-columns:1fr .9fr;gap:56px;align-items:start}
.contato-info h2{font-size:clamp(2rem,3.4vw,2.8rem);color:#fff}
.contato-lede{color:rgba(255,255,255,.75);max-width:46ch}
.contato-list{list-style:none;margin:2rem 0;padding:0;display:grid;gap:20px}
.contato-list li{display:flex;flex-direction:column;gap:3px;border-top:1px solid var(--line);padding-top:16px}
.ci-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.22em;color:var(--gold)}
.contato-list a{font-size:1.3rem;font-family:var(--serif);color:#fff;width:max-content}
.contato-list a:hover{color:var(--gold-2)}
.contato-cta{display:flex;gap:14px;flex-wrap:wrap}
.contato-form{background:var(--white);color:var(--ink);border-radius:18px;padding:34px;box-shadow:var(--shadow)}
.contato-form h3{font-size:1.7rem;margin:0 0 .2em}
.form-sub{color:var(--muted-d);margin:0 0 1.4rem;font-size:.95rem}
.contato-form label{display:block;font-size:.85rem;font-weight:600;color:#333b46;margin-bottom:14px}
.contato-form input,.contato-form textarea{
  width:100%;margin-top:6px;padding:.85rem 1rem;border:1px solid #d6d3ca;border-radius:10px;
  font-family:var(--sans);font-size:1rem;background:#fbfaf7;color:var(--ink);transition:border-color .2s
}
.contato-form input:focus,.contato-form textarea:focus{outline:none;border-color:var(--gold)}
.form-nota{font-size:.78rem;color:var(--muted-d);margin:14px 0 0;line-height:1.5}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.site-footer{background:#0D2245;color:#fff;padding:70px 0 30px}
.footer-inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.footer-logo{height:52px;width:auto;margin-bottom:18px}
.footer-brand p{color:rgba(255,255,255,.6);max-width:34ch;font-size:.95rem}
.footer-col h4{font-family:var(--sans);text-transform:uppercase;letter-spacing:.18em;font-size:.75rem;color:var(--gold);margin:0 0 16px}
.footer-col p{margin:0 0 12px;color:rgba(255,255,255,.7);font-size:.92rem;line-height:1.5}
.footer-col a:hover{color:var(--gold-2)}
.footer-legal{margin-top:50px;padding-top:24px;border-top:1px solid var(--line)}
.footer-legal p{margin:0 0 8px;font-size:.82rem;color:rgba(255,255,255,.6)}
.footer-legal .disclaimer{font-size:.76rem;max-width:80ch;line-height:1.6}

/* ==========================================================================
   FAB WhatsApp
   ========================================================================== */
.fab-wpp{
  position:fixed;right:22px;bottom:22px;z-index:90;width:60px;height:60px;border-radius:50%;
  background:#1f9d55;display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 30px -8px rgba(31,157,85,.6);transition:transform .2s;animation:pulse 2.6s infinite
}
.fab-wpp:hover{transform:scale(1.08)}
.fab-wpp svg{width:32px;height:32px;fill:#fff}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(31,157,85,.5)}70%{box-shadow:0 0 0 16px rgba(31,157,85,0)}100%{box-shadow:0 0 0 0 rgba(31,157,85,0)}}

/* ==========================================================================
   REVEAL on scroll
   ========================================================================== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ==========================================================================
   RESPONSIVO
   ========================================================================== */
@media (max-width:960px){
  .nav,.header-cta{display:none}
  .nav-toggle{display:flex}
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .hero-media{order:-1}
  .hero-media img{max-width:340px;margin:0 auto}
  .hero{padding:120px 0 70px}
  .cards{grid-template-columns:1fr 1fr}
  .passos{grid-template-columns:1fr 1fr}
  .two-col,.sobre-grid,.contato-grid{grid-template-columns:1fr;gap:40px}
  .sobre-media{max-width:420px;margin:0 auto}
  .footer-inner{grid-template-columns:1fr 1fr}
  .urgencia-inner{flex-direction:column;align-items:flex-start;text-align:left}
}
@media (max-width:560px){
  .wrap{padding:0 18px}
  .section{padding:70px 0}
  .cards,.passos,.sobre-facts,.footer-inner{grid-template-columns:1fr}
  .atuacao-lista{padding:30px 22px}
  .contato-form,.contato-cta .btn{width:100%}
  .eyebrow{letter-spacing:.16em;font-size:.66rem}
  .hero{padding:110px 0 60px}
  .hero-copy h1{font-size:2.05rem}
  .hero-copy .lede{font-size:1.05rem;max-width:100%}
  .hero-media{max-width:320px;margin:0 auto}
  .hero-media img{max-width:100%;margin:0}
  .sobre-facts{gap:16px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* ==========================================================================
   REFINO UX (tráfego pago) — tipografia forte, contraste, toque, CTA fixo
   ========================================================================== */
:root{ --ui:"Plus Jakarta Sans","Inter",-apple-system,Arial,sans-serif }
body{font-size:1rem;line-height:1.65;letter-spacing:.005em}
h1,h2,h3{letter-spacing:-.01em;line-height:1.1}

.hero-copy h1{font-family:var(--serif);font-weight:700;font-size:clamp(2.5rem,5.2vw,4.25rem);line-height:1.04;letter-spacing:-.5px;margin-bottom:.45em}
.hero-copy h1 em,.area-hero h1 em{font-style:italic;color:var(--gold-2)}
.hero-copy .lede,.area-hero .lede{font-family:var(--sans);font-weight:400;font-size:clamp(1.1rem,1.5vw,1.28rem);line-height:1.55;color:rgba(255,255,255,.86);max-width:44ch}
.section-head h2,.urgencia h2,.sobre-copy h2,.contato-info h2,.area-intro h2,.area-why h2{font-family:var(--serif);font-weight:700;font-size:clamp(2.05rem,3.8vw,3rem);line-height:1.08;letter-spacing:-.4px}
.card h3,.passos h3,.svc h3,.esp-card h4,.acc-head{font-family:var(--ui);font-weight:700;letter-spacing:-.2px;line-height:1.2}
.card h3{font-size:clamp(1.2rem,1.6vw,1.4rem)}.svc h3{font-size:1.18rem}.passos h3{font-size:1.25rem}
.eyebrow,.cards-lead,.ci-label,.post-cat,.a-cat{font-family:var(--ui);font-weight:700;letter-spacing:.18em}
.eyebrow{font-size:.74rem}
.btn{font-family:var(--ui);font-weight:700;font-size:.98rem;letter-spacing:.01em;padding:1rem 1.6rem}
.header-cta{padding:.7rem 1.15rem;font-size:.9rem}

/* Contraste e largura de leitura */
.section-head{margin-bottom:clamp(32px,5vw,54px)}
.section-sub,.area-intro p{max-width:68ch}
.sobre-copy p{max-width:60ch;line-height:1.7}
.hero-trust li,.area-trust li{color:rgba(255,255,255,.72)}
.card p,.svc p{color:#4a5361}

/* Especialidades mais escaneáveis */
.esp-card h4{font-family:var(--ui);font-weight:800;font-size:1.08rem;letter-spacing:-.1px;color:var(--ink);margin:0 0 8px}
.esp-card h4::before{width:26px;height:3px;border-radius:2px}
.esp-list a,.esp-list span{font-size:.97rem;color:#2b333d;font-weight:500}
.esp-list li{border-top:1px solid rgba(16,36,66,.08)}

/* Tap targets ≥44px */
.nav-toggle{padding:10px}
.esp-list a,.esp-list span{padding:13px 2px;min-height:44px}
.mobile-nav a{padding:16px 4px}

/* Barra CTA fixa (mobile) — sempre visível */
.cta-bar{display:none}
@media (max-width:720px){
  .cta-bar{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:95;align-items:center;justify-content:center;gap:.5rem;background:linear-gradient(120deg,#1FAB53,#25D366);color:#fff;font-family:var(--ui);font-weight:800;font-size:1.02rem;padding:15px 18px;min-height:56px;text-align:center;box-shadow:0 -8px 24px -10px rgba(0,0,0,.4);cursor:pointer}
  body{padding-bottom:64px}
  .fab-wpp{bottom:74px}
}

/* Tablet */
@media (max-width:1024px) and (min-width:769px){
  .cards{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:1fr 1fr}
}
/* Padrão de advogado: texto justificado com hifenização nos blocos de leitura */
.article-body p,.area-intro p,.sobre-copy p,.section-sub,.contato-lede,.compromisso .col-block p{
  text-align:justify;-webkit-hyphens:auto;hyphens:auto;text-justify:inter-word
}
/* Mobile fino */
@media (max-width:480px){
  /* em telas estreitas, justificar cria "rios" — volta a alinhar à esquerda */
  .article-body p,.area-intro p,.sobre-copy p,.section-sub,.contato-lede{text-align:left;hyphens:none}
  .hero-copy h1{font-size:clamp(2.15rem,8.5vw,2.5rem);line-height:1.06}
  .area-hero h1{font-size:clamp(2rem,8vw,2.4rem);max-width:100%}
  .hero-copy .lede,.area-hero .lede{font-size:1.06rem;max-width:100%}
  .eyebrow{letter-spacing:.14em;font-size:.68rem}
  .section-head h2{font-size:clamp(1.8rem,7vw,2.1rem)}
  .hero-cta .btn,.area-hero-cta .btn,.contato-cta .btn{width:100%}
  .hero-cta,.area-hero-cta,.contato-cta{gap:12px}
}

/* ==========================================================================
   HERO MOBILE — copy e CTA PRIMEIRO, foto contida (não estourar a tela)
   ========================================================================== */
@media (max-width:768px){
  .hero{padding:100px 0 42px}
  .hero-grid{grid-template-columns:1fr;gap:22px}
  .hero-copy{order:1}
  .hero-media{order:2;max-width:100%;margin:0;position:relative}
  .hero-media img{
    width:74%;max-width:290px;margin:4px auto 0;display:block;border-radius:16px;
    aspect-ratio:3/4;max-height:360px;object-fit:cover;object-position:center 10%
  }
  .hero-badge{display:none}
  .hero-copy h1{margin-bottom:.35em}
  .hero-trust{padding-top:1rem;gap:6px 20px}
  /* qualquer foto de retrato não pode dominar a tela no mobile */
  .sobre-media img{max-height:480px;object-fit:cover;object-position:center 8%}
}
@media (max-width:480px){
  .hero-media img{width:82%;max-width:260px;max-height:320px}
}

/* Polimento mobile (QA): esconde o FAB quando a barra fixa aparece e dá folga */
@media (max-width:720px){
  .fab-wpp{display:none}
  body{padding-bottom:78px}
}

/* ==========================================================================
   Ajustes mobile: passos centralizados (texto justificado) + urgência centrada
   ========================================================================== */
@media (max-width:768px){
  /* "Como atendo" — etapa centralizada, texto justificado */
  .passos{gap:34px}
  .passos li{text-align:center;display:flex;flex-direction:column;align-items:center}
  .passo-n{margin:0 auto 16px}
  .passos h3{text-align:center}
  .passos p{text-align:justify;-webkit-hyphens:auto;hyphens:auto;max-width:34ch}
  /* Faixa de urgência centralizada + CTA full width */
  .urgencia-inner{align-items:center;text-align:center;gap:20px}
  .urgencia p{text-align:justify;-webkit-hyphens:auto;hyphens:auto;margin-left:auto;margin-right:auto}
  .urgencia .btn{width:100%}
}
@media (max-width:480px){
  .passos p,.urgencia p{text-align:center;hyphens:none}
}

/* Lede do herói maior no mobile + credenciais das guias empilhadas */
@media (max-width:768px){
  .hero-copy .lede{font-size:1.2rem;line-height:1.6}
  .area-trust{flex-direction:column;gap:10px;align-items:flex-start}
}
@media (max-width:480px){
  .hero-copy .lede,.area-hero .lede{font-size:1.16rem;line-height:1.6}
}

/* Destaque de "Advogado criminalista" na lede do herói */
.hero-copy .lede strong,.area-hero .lede strong{color:#fff;font-weight:700}
/* Botão flutuante do WhatsApp: pill com rótulo (mais convidativo) */
.fab-wpp{width:auto;height:56px;border-radius:999px;padding:0 20px 0 14px;gap:9px;background:linear-gradient(120deg,#1FAB53,#25D366)}
.fab-wpp svg{width:27px;height:27px}
.fab-wpp::after{content:"Fale no WhatsApp";color:#fff;font-family:var(--ui,"Plus Jakarta Sans",sans-serif);font-weight:700;font-size:.94rem;white-space:nowrap}

/* Navegação/leitura: base um pouco maior */
html{font-size:16.5px}
.card p,.svc p,.esp-list a,.esp-list span{font-size:1rem}
.section-sub{font-size:1.1rem}

/* Âncoras não ficam sob o header fixo ao rolar */
[id]{scroll-margin-top:92px}
/* H1 maior e mais impactante (design/UX) */
.hero-copy h1{font-size:clamp(3rem,6vw,5rem);line-height:1.02;letter-spacing:-.7px;font-weight:700}
.area-hero h1{font-size:clamp(2.5rem,4.8vw,3.8rem);line-height:1.04;font-weight:700}
@media (max-width:768px){
  .hero-copy h1{font-size:clamp(2.6rem,9.5vw,3.4rem);line-height:1.05}
}
@media (max-width:480px){
  .hero-copy h1{font-size:clamp(2.4rem,10vw,3.05rem);line-height:1.06}
  .area-hero h1{font-size:clamp(2.15rem,8.8vw,2.7rem)}
}

/* ==========================================================================
   ESPAÇAMENTO ENTRE BLOCOS — respiro adequado (toda a base)
   ========================================================================== */
.urgencia-inner{padding:48px 0}
.section{padding:104px 0}
@media (max-width:768px){
  .section{padding:66px 0}
  .urgencia-inner{padding:52px 0}
  .section-head{margin-bottom:34px}
  .especialidades{margin-top:46px}
  .two-col{gap:44px}
  .sobre-grid,.contato-grid{gap:40px}
  .area-intro{padding:56px 0}
  .area-services,.area-why{padding:60px 0}
}
@media (max-width:480px){
  .section{padding:56px 0}
  .urgencia-inner{padding:46px 0}
}

/* ==========================================================================
   Botão flutuante: círculo claramente FLUTUANTE (elevação + anel pulsante)
   ========================================================================== */
.fab-wpp{
  width:62px;height:62px;border-radius:50%;padding:0;gap:0;
  background:linear-gradient(135deg,#25D366,#1FAB53);
  box-shadow:0 16px 34px -8px rgba(0,0,0,.55), 0 6px 16px rgba(31,157,85,.5);
  border:3px solid rgba(255,255,255,.16);
  animation:none;right:24px;bottom:24px
}
.fab-wpp::after{content:none}
.fab-wpp::before{content:"";position:absolute;inset:0;border-radius:50%;pointer-events:none;animation:fabpulse 2.4s ease-out infinite}
.fab-wpp svg{width:31px;height:31px}
.fab-wpp:hover{transform:scale(1.09)}
@keyframes fabpulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* Polimento QA: divisor sutil entre contato e rodapé + hero uniforme */
.site-footer{border-top:1px solid rgba(255,255,255,.06)}
@media (max-width:560px){ .hero{padding:100px 0 56px} }

/* ==========================================================================
   Margens laterais confortáveis em todos os dispositivos (iPhone/Android)
   ========================================================================== */
@media (max-width:768px){
  .wrap{padding-left:22px;padding-right:22px}
  .article-wrap{padding-left:22px;padding-right:22px}
  .related-grid{padding-left:22px;padding-right:22px}
}
@media (max-width:390px){
  .wrap{padding-left:20px;padding-right:20px}
  .article-wrap{padding-left:20px;padding-right:20px}
}

/* ==========================================================================
   HERO CLEAN — badge, H1 elegante e âncora "advogado criminal" (YOLO revisão)
   Escopado ao herói para não afetar os eyebrows das demais seções.
   ========================================================================== */
.hero .eyebrow{
  display:inline-flex;align-items:center;gap:.62ch;
  padding:.5em 1.05em;border-radius:999px;line-height:1;
  color:#FFD9DC;font-size:.8rem;letter-spacing:.16em;
  border:1px solid rgba(226,49,64,.42);
  background:linear-gradient(180deg,rgba(226,49,64,.16),rgba(226,49,64,.05));
}
.hero .eyebrow::before{
  content:"";width:.52em;height:.52em;border-radius:50%;
  background:var(--gold-2);box-shadow:0 0 0 4px rgba(226,49,64,.22)
}
/* H1 mais clean: quebras equilibradas, linhas curtas, respiro */
.hero-copy h1{
  font-size:clamp(2.9rem,5.6vw,4.6rem);
  line-height:1.05;letter-spacing:-.6px;font-weight:700;
  text-wrap:balance;max-width:17ch;margin:.15em 0 .5em
}
.hero-copy h1 em{font-style:italic;color:var(--gold-2);white-space:nowrap}
.hero-copy .lede{max-width:40ch}
/* Linha de confiança com check vermelho */
.hero-trust li{display:inline-flex;align-items:center;gap:.5ch}
.hero-trust li::before{content:"\2713";color:var(--gold-2);font-weight:800;font-size:.95em}
@media (max-width:768px){
  .hero .eyebrow{font-size:.74rem;letter-spacing:.14em}
  .hero-copy h1{font-size:clamp(2.55rem,9vw,3.35rem);line-height:1.07;max-width:20ch;margin-bottom:.45em}
  .hero-copy h1 em{white-space:normal}
}
@media (max-width:480px){
  .hero-copy h1{font-size:clamp(2.35rem,10vw,3rem);letter-spacing:-.4px}
}

/* Acessibilidade: foco visível no teclado (contraste sobre navy) */
:focus-visible{outline:3px solid #25D366;outline-offset:2px;border-radius:6px}
.btn:focus-visible,.fab-wpp:focus-visible,.nav-toggle:focus-visible,.site-header a:focus-visible{outline:3px solid #fff;outline-offset:3px}

/* ==========================================================================
   POLIMENTO UX (revisão YOLO): hierarquia, órfãs, âncora do selo, ritmo
   ========================================================================== */
/* P1: título de .area-services caía no tamanho default do browser */
.area-services h2{
  font-family:var(--serif);font-weight:700;
  font-size:clamp(1.7rem,3vw,2.3rem);line-height:1.12;letter-spacing:-.3px
}
/* P2: selo "Plantão 24h" ancorado ao canto da foto (estava solto no vão) */
.hero-badge{left:auto;right:8px}
/* P3: evita última linha com palavra órfã nos títulos */
.section-head h2,.area-intro h2,.area-services h2,.area-why h2,
.urgencia h2,.contato-info h2,.sobre-copy h2,
.article-head h1,.article-body h2,.blog-hero h1,
.card h3,.svc h3,.esp-card h4,.related h2{text-wrap:balance}
.hero-copy .lede,.area-hero .lede,.section-sub,.contato-lede{text-wrap:pretty}
/* P5: CTA solto (fora de section) em /areas/ e sobre: respiro simétrico */
.wrap>.article-cta{margin:8px 0 56px}
