/* ============================================================
   CENTRAL JURÍDICA DIGITAL — Site (identidade formal, execução moderna)
   ============================================================ */
:root{
  --navy-900:#0A1F38; --navy-800:#0E2A47; --navy-700:#16395E; --navy-50:#F1F4F8;
  --gold-600:#A98A4E; --gold-500:#CBB079; --gold-300:#DEC893;
  --ink:#1A2332; --slate:#5B6472; --muted:#9AA1AC; --border:#E5E0D5;
  --cream:#FBF9F4; --white:#FFFFFF; --danger:#9B2C2C; --success:#2E6B4F;
  --font-display:"Playfair Display",Georgia,serif;
  --font-body:"EB Garamond",Georgia,serif;
  --font-ui:"Inter","Segoe UI",system-ui,sans-serif;
  --radius:8px; --radius-lg:14px;
  --shadow:0 6px 24px rgba(14,42,71,.10);
  --shadow-lg:0 24px 60px rgba(14,42,71,.20);
  --gold-grad:linear-gradient(135deg,var(--gold-300),var(--gold-600));
  --maxw:1180px;
  --ease:cubic-bezier(.16,.84,.44,1);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-ui);color:var(--ink);background:var(--cream);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.ui{font-family:var(--font-ui);}

/* ---------- Animações ---------- */
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.reveal{opacity:0;}
.reveal.in{animation:fadeUp .7s var(--ease) forwards;}
.reveal.d1{animation-delay:.08s}.reveal.d2{animation-delay:.16s}.reveal.d3{animation-delay:.24s}.reveal.d4{animation-delay:.32s}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;animation:none!important}.hero-doc{animation:none!important}}

/* ---------- Botões ---------- */
.btn{font-family:var(--font-ui);font-weight:600;font-size:13px;letter-spacing:.6px;text-transform:uppercase;
  border:none;border-radius:var(--radius);padding:15px 30px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;
  transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .18s ease,color .18s ease;line-height:1;}
.btn:hover{transform:translateY(-2px);}
.btn-primary{background:var(--navy-800);color:#fff;box-shadow:0 8px 20px rgba(14,42,71,.18);}
.btn-primary:hover{background:var(--navy-700);box-shadow:0 14px 30px rgba(14,42,71,.28);}
.btn-gold{background:var(--gold-grad);color:var(--navy-900);box-shadow:0 8px 22px rgba(169,138,78,.32);}
.btn-gold:hover{box-shadow:0 14px 34px rgba(169,138,78,.42);}
.btn-ghost{background:transparent;border:1.5px solid var(--navy-800);color:var(--navy-800);}
.btn-ghost:hover{background:var(--navy-800);color:#fff;}
.btn-ghost-light{background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.45);color:#fff;backdrop-filter:blur(4px);}
.btn-ghost-light:hover{background:#fff;color:var(--navy-800);}
.btn-sm{padding:11px 18px;font-size:11px;}
.btn-lg{padding:17px 36px;font-size:14px;}
.btn-block{width:100%;justify-content:center;}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(251,249,244,.82);backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .25s ease,box-shadow .25s ease,background .25s ease;}
.site-header.scrolled{border-bottom-color:var(--border);box-shadow:0 4px 24px rgba(14,42,71,.06);background:rgba(251,249,244,.94);}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:74px;}
.site-header .logo img{height:46px;}
.site-nav{display:flex;align-items:center;gap:30px;}
.site-nav a{font-family:var(--font-ui);font-size:14px;font-weight:500;letter-spacing:.2px;color:var(--slate);position:relative;}
.site-nav a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-5px;width:0;height:2px;background:var(--gold-500);transition:width .25s var(--ease);}
.site-nav a:not(.btn):hover{color:var(--navy-800);}
.site-nav a:not(.btn):hover::after{width:100%;}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;font-size:24px;color:var(--navy-800);}

/* ---------- Hero ---------- */
.hero{background:radial-gradient(120% 120% at 85% 0%,var(--navy-700) 0%,var(--navy-800) 40%,var(--navy-900) 100%);
  color:#fff;position:relative;overflow:hidden;}
.hero::after{content:"";position:absolute;right:-160px;top:-160px;width:520px;height:520px;border-radius:50%;
  border:1px solid rgba(203,176,121,.16);pointer-events:none;}
.hero::before{content:"";position:absolute;left:-120px;bottom:-220px;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(203,176,121,.10),transparent 70%);pointer-events:none;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
  padding-top:60px;padding-bottom:64px;position:relative;z-index:1;}
.hero .eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-ui);font-size:12px;font-weight:600;
  letter-spacing:2.5px;text-transform:uppercase;color:var(--gold-300);}
.hero .eyebrow::before{content:"";width:26px;height:1px;background:var(--gold-500);}
.hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(2.1rem,4vw,3.1rem);line-height:1.1;margin:18px 0 0;}
.hero h1 em{color:var(--gold-300);font-style:italic;}
.hero p.sub{font-family:var(--font-ui);font-size:1.12rem;color:#C9D2DF;margin:22px 0 0;max-width:540px;line-height:1.6;}
.hero .cta-row{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap;}
.hero-stats{display:flex;gap:34px;margin-top:42px;padding-top:30px;border-top:1px solid rgba(255,255,255,.12);}
.hero-stats div{display:flex;flex-direction:column;}
.hero-stats b{font-family:var(--font-display);font-size:1.9rem;font-weight:700;color:#fff;line-height:1;}
.hero-stats span{font-family:var(--font-ui);font-size:11.5px;letter-spacing:.6px;color:#8C9AB0;margin-top:6px;text-transform:uppercase;}

/* documento flutuante */
.hero-visual{position:relative;display:flex;justify-content:center;}
.hero-doc{width:330px;background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);overflow:hidden;
  animation:floaty 6s ease-in-out infinite;transform-origin:center;}
.hero-doc .hd{background:var(--navy-800);padding:16px 20px;display:flex;align-items:center;justify-content:space-between;}
.hero-doc .hd .nm{font-family:var(--font-display);color:#fff;font-size:13px;font-weight:700;line-height:1;}
.hero-doc .hd .nm span{display:block;font-family:var(--font-ui);font-size:6px;letter-spacing:4px;color:var(--gold-500);margin-top:3px;}
.hero-doc .hd .code{font-family:var(--font-ui);font-size:8px;color:var(--gold-300);letter-spacing:1px;}
.hero-doc .gr{height:3px;background:var(--gold-grad);}
.hero-doc .bd{padding:24px 22px 30px;}
.hero-doc .bd .t{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--navy-800);text-align:center;}
.hero-doc .bd .tr{width:40px;height:2px;background:var(--gold-500);margin:8px auto 18px;}
.hero-doc .bd .ln{height:7px;border-radius:3px;background:#EEF1F5;margin:9px 0;}
.hero-doc .bd .ln.s{width:60%;}.hero-doc .bd .ln.m{width:85%;}
.hero-doc .bd .ln.g{background:linear-gradient(90deg,#EEF1F5 25%,#F6F2E8 50%,#EEF1F5 75%);background-size:200% 100%;animation:shimmer 2.4s linear infinite;}
.hero-doc .seal{position:absolute;right:18px;bottom:18px;width:72px;height:72px;filter:drop-shadow(0 6px 14px rgba(14,42,71,.25));}
.hero-badge{position:absolute;top:18px;left:-18px;background:#fff;border-radius:999px;padding:9px 16px 9px 12px;
  display:flex;align-items:center;gap:8px;box-shadow:var(--shadow);font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--navy-800);}
.hero-badge .dot{width:22px;height:22px;border-radius:50%;background:var(--gold-grad);display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;}
.hero-badge--cob .dot{font-size:9px;}

/* ---------- Alternador de serviços (hero dinâmico) ---------- */
.hero-switch{display:flex;flex-direction:column;gap:8px;margin-top:30px;}
.hs-pill{display:flex;align-items:center;gap:14px;text-align:left;width:100%;cursor:pointer;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);border-radius:14px;
  padding:12px 16px;color:#fff;font-family:var(--font-ui);transition:background .25s,border-color .25s,transform .25s;}
.hs-pill:hover{background:rgba(255,255,255,.09);transform:translateX(2px);}
.hs-pill.active{background:rgba(203,176,121,.14);border-color:rgba(203,176,121,.55);}
.hs-ic{flex:0 0 auto;width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.07);color:var(--gold-300);transition:background .25s,color .25s;}
.hs-ic svg{width:21px;height:21px;}
.hs-pill.active .hs-ic{background:var(--gold-grad);color:#fff;}
.hs-tx{display:flex;flex-direction:column;line-height:1.25;}
.hs-tx b{font-size:14.5px;font-weight:600;color:#fff;}
.hs-tx small{font-size:11.5px;color:#9FB0C6;}
.hs-pill.active .hs-tx small{color:var(--gold-300);}

/* ---------- Palco dinâmico (slides do hero) ---------- */
.hero-stage{position:relative;width:330px;max-width:100%;min-height:340px;}
.hero-slide{position:absolute;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;pointer-events:none;transform:translateY(14px) scale(.97);
  transition:opacity .5s var(--ease),transform .5s var(--ease),visibility .5s;}
.hero-slide.active{opacity:1;visibility:visible;pointer-events:auto;transform:none;position:relative;z-index:2;}
.hero-slide .hero-doc,.hero-slide .hero-card{width:330px;}

/* card genérico dos slides */
.hero-card{background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;
  animation:floaty 6s ease-in-out infinite;}
/* slide advogado */
.hero-card--law{padding:22px 22px 20px;}
.hcl-top{display:flex;align-items:center;gap:13px;position:relative;}
.hcl-av{width:52px;height:52px;border-radius:50%;flex:0 0 auto;background:var(--navy-700);color:#fff;
  display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-weight:700;font-size:18px;}
.hcl-id{display:flex;flex-direction:column;line-height:1.3;}
.hcl-id b{font-family:var(--font-display);font-size:16px;color:var(--navy-800);}
.hcl-oab{font-family:var(--font-ui);font-size:11px;font-weight:600;color:var(--gold-600,#9C7C3C);letter-spacing:.4px;}
.hcl-seal{width:40px;height:40px;margin-left:auto;}
.hcl-rows{margin-top:18px;display:flex;flex-direction:column;gap:11px;}
.hcl-row{display:flex;align-items:center;gap:10px;font-family:var(--font-ui);font-size:13px;color:var(--navy-700);}
.hcl-ck{width:20px;height:20px;border-radius:50%;flex:0 0 auto;background:#1f9d57;color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:11px;}
.hcl-foot{margin-top:18px;padding-top:13px;border-top:1px solid var(--border);
  font-family:var(--font-ui);font-size:11.5px;color:var(--slate);text-align:center;}
/* slide cobrança */
.hero-card--cob{padding:22px;}
.hcc-amount{background:linear-gradient(120deg,var(--navy-700),var(--navy-800));border-radius:11px;
  padding:16px 18px;color:#fff;margin-bottom:18px;}
.hcc-amount small{font-family:var(--font-ui);font-size:11px;letter-spacing:.5px;color:#AEBED4;text-transform:uppercase;}
.hcc-amount b{display:block;font-family:var(--font-display);font-size:27px;margin-top:4px;color:#fff;}
.hcc-track{display:flex;flex-direction:column;gap:13px;position:relative;}
.hcc-step{display:flex;align-items:center;gap:11px;font-family:var(--font-ui);font-size:13px;color:#9AA4B2;}
.hcc-dot{width:18px;height:18px;border-radius:50%;flex:0 0 auto;border:2px solid #D8DEE6;background:#fff;
  display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;}
.hcc-step.done{color:var(--navy-700);}
.hcc-step.done .hcc-dot{background:#1f9d57;border-color:#1f9d57;}
.hcc-step.now{color:var(--navy-800);font-weight:600;}
.hcc-step.now .hcc-dot{border-color:var(--gold-500);box-shadow:0 0 0 4px rgba(203,176,121,.18);
  animation:cobPulse 1.6s ease-in-out infinite;}
@keyframes cobPulse{0%,100%{box-shadow:0 0 0 3px rgba(203,176,121,.20);}50%{box-shadow:0 0 0 7px rgba(203,176,121,.05);}}

/* ---------- Seções ---------- */
.section{padding:88px 0;}
.section-head{text-align:center;max-width:680px;margin:0 auto 52px;}
.section-head .kicker{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold-600);}
.section-head h2{font-family:var(--font-display);font-weight:700;font-size:2.4rem;color:var(--navy-800);margin:10px 0 0;line-height:1.12;}
.section-head .rule{width:54px;height:3px;background:var(--gold-grad);border-radius:3px;margin:18px auto 0;}
.section-head p{color:var(--slate);margin-top:16px;font-size:1.05rem;}

/* ---------- Como funciona ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.step{position:relative;padding:30px 24px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);overflow:hidden;}
.step::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:var(--gold-grad);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.step:hover::before{transform:scaleX(1);}
.step .num{font-family:var(--font-display);font-size:2.6rem;font-weight:700;line-height:1;
  background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.step h3{font-family:var(--font-ui);font-size:13px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--navy-800);margin:14px 0 8px;}
.step p{font-size:.96rem;color:var(--slate);}

/* ---------- Catálogo ---------- */
.catalog-tools{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-bottom:26px;}
.search-box{flex:1;min-width:240px;max-width:480px;position:relative;}
.search-box input{width:100%;font-family:var(--font-ui);font-size:15px;padding:15px 16px 15px 46px;
  border:1px solid var(--border);border-radius:999px;background:#fff;color:var(--ink);transition:.2s;box-shadow:0 2px 10px rgba(14,42,71,.04);}
.search-box input:focus{outline:none;border-color:var(--gold-500);box-shadow:0 0 0 4px rgba(203,176,121,.15);}
.search-box svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);}
.filters{display:flex;gap:9px;flex-wrap:wrap;justify-content:center;}
.chip{font-family:var(--font-ui);font-size:12.5px;font-weight:500;letter-spacing:.2px;padding:9px 17px;border-radius:999px;
  border:1px solid var(--border);background:#fff;color:var(--slate);cursor:pointer;transition:.18s var(--ease);}
.chip:hover{border-color:var(--gold-500);color:var(--navy-800);transform:translateY(-1px);}
.chip.active{background:var(--navy-800);color:#fff;border-color:var(--navy-800);box-shadow:0 6px 16px rgba(14,42,71,.18);}

.cat-group{margin-bottom:44px;}
.cat-group > h3{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-600);
  display:flex;align-items:center;gap:14px;margin-bottom:22px;}
.cat-group > h3::after{content:"";flex:1;height:1px;background:var(--border);}
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;}
.doc-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px;
  display:flex;flex-direction:column;transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s ease;
  position:relative;overflow:hidden;}
.doc-card::before{content:"";position:absolute;left:0;top:0;width:100%;height:3px;background:var(--gold-grad);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease);}
.doc-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px);border-color:transparent;}
.doc-card:hover::before{transform:scaleX(1);}
.doc-card .doc-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--navy-50),#E7EDF5);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;transition:.25s var(--ease);}
.doc-card:hover .doc-icon{background:var(--gold-grad);transform:rotate(-4deg) scale(1.05);}
.doc-card:hover .doc-icon svg{stroke:#fff;}
.doc-card .doc-icon svg{transition:stroke .25s ease;}
.doc-card h4{font-family:var(--font-display);font-size:1.32rem;font-weight:700;color:var(--navy-800);line-height:1.2;}
.doc-card p{font-size:.95rem;color:var(--slate);margin:10px 0 18px;flex:1;line-height:1.55;}
.doc-card .doc-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:16px;border-top:1px solid var(--border);}
.doc-card .price{font-family:var(--font-ui);font-size:11.5px;color:var(--muted);}
.doc-card .price b{font-family:var(--font-display);font-size:1.18rem;color:var(--navy-800);display:block;margin-top:2px;}
.doc-card .btn-ghost.btn-sm{transition:.2s var(--ease);}
.doc-card:hover .btn-ghost.btn-sm{background:var(--navy-800);color:#fff;}
.doc-card .btn-ghost.btn-sm::after{content:"→";transition:transform .2s var(--ease);}
.doc-card:hover .btn-ghost.btn-sm::after{transform:translateX(4px);}
.tag-free{position:absolute;top:20px;right:20px;font-family:var(--font-ui);font-size:10px;font-weight:600;letter-spacing:.8px;
  text-transform:uppercase;background:rgba(46,107,79,.1);color:var(--success);padding:5px 11px;border-radius:999px;border:1px solid rgba(46,107,79,.25);z-index:1;}

/* ---------- Faixa de valor / preços ---------- */
.pricing{background:linear-gradient(165deg,var(--navy-800),var(--navy-900));color:#fff;position:relative;overflow:hidden;}
.pricing::before{content:"";position:absolute;left:-120px;top:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(203,176,121,.10),transparent 70%);}
.pricing .section-head h2{color:#fff;}
.pricing .section-head p{color:#C9D2DF;}
.price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:780px;margin:0 auto;position:relative;z-index:1;}
.price-card{background:rgba(255,255,255,.04);border:1px solid rgba(203,176,121,.28);border-radius:var(--radius-lg);padding:36px;
  transition:transform .25s var(--ease);}
.price-card:hover{transform:translateY(-4px);}
.price-card.featured{background:rgba(203,176,121,.1);border-color:var(--gold-500);position:relative;box-shadow:0 20px 50px rgba(0,0,0,.25);}
.price-card.featured::after{content:"Mais escolhido";position:absolute;top:-12px;right:24px;background:var(--gold-grad);color:var(--navy-900);
  font-family:var(--font-ui);font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:6px 14px;border-radius:999px;}
.price-card .ptitle{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-300);}
.price-card .pval{font-family:var(--font-display);font-size:2.7rem;font-weight:700;margin:10px 0 4px;}
.price-card .pval small{font-size:1rem;color:#AEBBCC;font-family:var(--font-ui);}
.price-card ul{list-style:none;margin:22px 0 0;}
.price-card li{padding:10px 0 10px 28px;position:relative;color:#D7DEE8;font-size:1rem;border-top:1px solid rgba(255,255,255,.07);}
.price-card li::before{content:"";position:absolute;left:0;top:14px;width:16px;height:16px;border-radius:50%;background:var(--gold-grad);
  background-image:var(--gold-grad);}
.price-card li::after{content:"✓";position:absolute;left:3px;top:10px;color:var(--navy-900);font-size:10px;font-weight:800;font-family:var(--font-ui);}

/* ---------- Faixa OAB / confiança ---------- */
.assurance{background:var(--cream);}
.assurance .container{max-width:800px;text-align:center;}
.assurance .seal{height:118px;margin:0 auto 24px;animation:floaty 7s ease-in-out infinite;}
.assurance blockquote{font-family:var(--font-display);font-style:italic;font-size:1.6rem;color:var(--navy-800);line-height:1.45;}
.assurance cite{display:block;font-family:var(--font-ui);font-style:normal;font-size:12px;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--gold-600);margin-top:20px;}

/* ---------- CTA final ---------- */
.cta-final{padding:84px 0;}
.cta-final .container{max-width:860px;text-align:center;background:linear-gradient(135deg,var(--navy-800),var(--navy-900));
  border-radius:24px;padding:64px 40px;position:relative;overflow:hidden;box-shadow:var(--shadow-lg);}
.cta-final .container::after{content:"";position:absolute;right:-80px;top:-80px;width:280px;height:280px;border-radius:50%;border:1px solid rgba(203,176,121,.2);}
.cta-final h2{font-family:var(--font-display);font-size:2.3rem;color:#fff;position:relative;}
.cta-final p{color:#C9D2DF;margin:14px 0 30px;position:relative;}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-900);color:#AEBBCC;padding:60px 0 30px;font-family:var(--font-ui);font-size:13px;}
.site-footer .cols{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:32px;margin-bottom:38px;}
.site-footer h5{color:#fff;font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:16px;}
.site-footer a{display:block;color:#AEBBCC;padding:6px 0;transition:color .18s,transform .18s var(--ease);}
.site-footer a:hover{color:var(--gold-300);transform:translateX(3px);}
.site-footer .brand-col img{height:42px;margin-bottom:16px;}
.site-footer .brand-col p{line-height:1.65;}
.site-footer .disclaimer{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;font-size:11px;color:#7C8AA0;line-height:1.65;}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(10,31,56,.6);backdrop-filter:blur(4px);z-index:100;
  display:none;align-items:center;justify-content:center;padding:24px;}
.modal-overlay.open{display:flex;animation:fadeUp .3s var(--ease);}
.modal{background:#fff;border-radius:var(--radius-lg);max-width:480px;width:100%;padding:38px;box-shadow:var(--shadow-lg);position:relative;}
.modal h3{font-family:var(--font-display);font-size:1.7rem;color:var(--navy-800);}
.modal .close{position:absolute;top:16px;right:18px;background:none;border:none;font-size:26px;color:var(--muted);cursor:pointer;line-height:1;transition:.18s;}
.modal .close:hover{color:var(--navy-800);transform:rotate(90deg);}
.modal label{display:block;font-family:var(--font-ui);font-size:12px;font-weight:500;letter-spacing:.3px;color:var(--slate);margin:16px 0 6px;}
.modal input,.modal select{width:100%;font-family:var(--font-ui);font-size:1rem;padding:13px 14px;border:1px solid var(--border);border-radius:var(--radius);transition:.2s;}
.modal input:focus{outline:none;border-color:var(--gold-500);box-shadow:0 0 0 3px rgba(203,176,121,.15);}
.pay-summary{background:var(--cream);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin:20px 0;
  display:flex;justify-content:space-between;align-items:center;}
.pay-summary .lbl{font-family:var(--font-ui);font-size:13px;color:var(--slate);}
.pay-summary .val{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--navy-800);}

/* ---------- Responsivo ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:36px;text-align:left;padding-top:52px;padding-bottom:60px;}
  .hero p.sub{max-width:none;}
  .hero-visual{order:-1;}
  .hero-doc{width:290px;}
  .hero-stage{width:100%;max-width:300px;margin:0 auto;min-height:300px;}
}
@media(max-width:480px){
  .hero-stage{max-width:280px;min-height:280px;}
  .hero-slide .hero-doc,.hero-slide .hero-card{width:280px;}
  .hs-pill{padding:10px 13px;gap:11px;}
  .hs-ic{width:34px;height:34px;border-radius:9px;}
  .hs-ic svg{width:18px;height:18px;}
}
@media(max-width:900px){
  .steps{grid-template-columns:repeat(2,1fr);gap:18px;}
  .site-footer .cols{grid-template-columns:1fr 1fr;}
}
@media(max-width:680px){
  body{font-size:16px;}
  .site-nav{position:absolute;top:74px;left:0;right:0;background:rgba(251,249,244,.98);backdrop-filter:blur(10px);flex-direction:column;gap:0;
    border-bottom:1px solid var(--border);display:none;padding:8px 0;}
  .site-nav.open{display:flex;}
  .site-nav a{padding:14px 24px;width:100%;}
  .site-nav a:not(.btn)::after{display:none;}
  .nav-toggle{display:block;}
  .price-grid{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr;}
  .section{padding:60px 0;}
  .hero-switch{margin-top:24px;}
  .hs-tx small{display:none;}
  .cta-final .container{padding:48px 24px;}
}
