/* ===========================================================
   CV · Assessoria Previdenciária — Design System
   Marca: teal #0E4F4B + ouro gradiente · Fonte Fredoka
   =========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&display=swap');

:root{
  --teal:#0E4F4B; --teal-2:#15756B; --teal-deep:#07332f; --teal-deeper:#03130f;
  --cream:#F5EFE3; --cream-2:#EFE7D6; --line:#e3dcca;
  --gold:#C99A3A; --gold-l:#E8C877; --gold-d:#A2742A;
  --ink:#1a2422; --body:#34433f; --muted:#5d6b67; --muted-l:#8aa39d;
  --wa:#25D366; --wa-d:#1ebe5a;
  --gold-grad:linear-gradient(180deg,#5C3E14,#F7E6A8 46%,#E8C877 56%,#A2742A);
  --gold-grad-btn:linear-gradient(135deg,#E8C877,#C99A3A 55%,#A2742A);
  --teal-grad:radial-gradient(120% 100% at 50% 0%,#0d514c,#07332f 55%,#03130f 120%);
  --radius:18px; --radius-s:12px; --shadow:0 18px 50px -22px rgba(7,51,47,.45);
  --maxw:1080px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Fredoka',system-ui,sans-serif;font-weight:400;color:var(--body);
  background:var(--cream);line-height:1.6;-webkit-font-smoothing:antialiased}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-weight:600;line-height:1.14;color:var(--teal);letter-spacing:-.01em}
strong,b{font-weight:600}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.gold{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.center{text-align:center}

/* ---------- Header ---------- */
.hd{position:sticky;top:0;z-index:50;background:rgba(245,239,227,.86);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.hd .wrap{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mk{width:50px;height:50px;flex:none}
.brand .nm{display:flex;flex-direction:column;line-height:1}
.brand .nm .cv{font-weight:700;font-size:21px;letter-spacing:3px;color:var(--teal)}
.brand .nm .sg{font-size:9.5px;letter-spacing:2.2px;text-transform:uppercase;color:var(--muted);margin-top:3px}
.hd .nav{display:flex;align-items:center;gap:26px}
.hd .nav a.lnk{font-size:14.5px;font-weight:500;color:var(--teal);opacity:.82}
.hd .nav a.lnk:hover{opacity:1}
@media(max-width:860px){.hd .nav a.lnk{display:none}}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:inherit;font-weight:600;font-size:16px;border:0;cursor:pointer;
  padding:15px 26px;border-radius:50px;transition:transform .15s ease,box-shadow .15s ease;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-wa{background:var(--wa);color:#063d1c;box-shadow:0 12px 26px -10px rgba(37,211,102,.7)}
.btn-wa:hover{background:var(--wa-d)}
.btn-gold{background:var(--gold-grad-btn);color:#2a1d05;box-shadow:0 12px 28px -12px rgba(201,154,58,.8)}
.btn-ghost{background:transparent;border:1.5px solid rgba(232,200,119,.5);color:var(--gold-l)}
.btn-sm{padding:11px 18px;font-size:14.5px}
.btn .ic{width:20px;height:20px;flex:none}
.btn-block{display:flex;width:100%}

/* ---------- Hero ---------- */
.hero{background:var(--teal-grad);color:var(--cream);position:relative;overflow:hidden;
  padding:54px 0 64px}
.hero:before{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 50% at 88% 10%,rgba(201,154,58,.16),transparent 60%);pointer-events:none}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center}
.hero .eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;
  letter-spacing:1px;text-transform:uppercase;color:var(--gold-l);
  border:1px solid rgba(232,200,119,.3);border-radius:40px;padding:7px 16px;margin-bottom:18px}
.hero h1{color:#fff;font-size:43px;font-weight:600;line-height:1.08;margin-bottom:16px}
.hero h1 .gold{font-weight:700}
.hero .sub{font-size:18.5px;color:#d4e0dd;max-width:540px;margin-bottom:26px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero .micro{margin-top:18px;font-size:13.5px;color:var(--muted-l);display:flex;gap:18px;flex-wrap:wrap}
.hero .micro span{display:inline-flex;align-items:center;gap:7px}
.hero-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  border-radius:22px;padding:26px;backdrop-filter:blur(4px)}
.hero-card .hk{font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--gold-l);font-weight:600;margin-bottom:14px}
.hero-card ul{list-style:none}
.hero-card li{display:flex;gap:12px;align-items:flex-start;padding:10px 0;color:#e7efed;font-size:15.5px;border-top:1px solid rgba(255,255,255,.08)}
.hero-card li:first-child{border-top:0}
.hero-card li .ck{width:24px;height:24px;flex:none;border-radius:50%;background:rgba(37,211,102,.18);
  display:flex;align-items:center;justify-content:center;color:var(--wa);font-weight:700;font-size:13px;margin-top:1px}
.hero .mk-bg{position:absolute;right:-90px;bottom:-90px;width:360px;opacity:.06;pointer-events:none}
@media(max-width:860px){
  .hero{padding:38px 0 46px}
  .hero .wrap{grid-template-columns:1fr;gap:26px}
  .hero h1{font-size:33px}.hero .sub{font-size:17px}
  .hero .cta-row .btn{flex:1}
}

/* ---------- Trust strip ---------- */
.trust{background:var(--teal-deeper);color:#cdd9d6}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:22px 22px}
.trust .t{display:flex;align-items:center;gap:11px;font-size:14px}
.trust .t .ic{width:26px;height:26px;flex:none;color:var(--gold-l)}
.trust .t b{color:#fff;font-weight:600}
@media(max-width:860px){.trust .wrap{grid-template-columns:1fr 1fr;gap:14px}}

/* ---------- Sections ---------- */
section{padding:64px 0}
.sec-alt{background:#fff}
.sec-cream{background:var(--cream)}
.sec-dark{background:var(--teal-deep);color:var(--cream)}
.sec-dark h2,.sec-dark h3{color:#fff}
.sec-dark p{color:#cdd9d6}
.kick{font-size:12.5px;letter-spacing:3px;text-transform:uppercase;font-weight:600;color:var(--gold);margin-bottom:11px}
.sec-dark .kick{color:var(--gold-l)}
.h2{font-size:30px;margin-bottom:14px}
.lead{font-size:17.5px;color:var(--muted);max-width:680px;margin-bottom:8px}
.sec-dark .lead{color:#b9c8c4}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:18px;margin-top:30px}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.g-3,.g-4{grid-template-columns:1fr}.g-2{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;transition:transform .18s,box-shadow .18s}
.sec-alt .card{background:var(--cream)}
.card.hov:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card .emo{font-size:32px;line-height:1;margin-bottom:14px}
.card h3{font-size:19px;margin-bottom:8px}
.card p{font-size:15px;color:var(--body)}
.card .go{display:inline-flex;align-items:center;gap:7px;margin-top:14px;color:var(--gold-d);font-weight:600;font-size:14.5px}

/* nicho cards (home) */
a.nicho{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:24px;transition:transform .18s,box-shadow .18s,border-color .18s}
a.nicho:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--gold-l)}
a.nicho .emo{font-size:34px;margin-bottom:12px}
a.nicho h3{font-size:18px;margin-bottom:6px}
a.nicho p{font-size:14px;color:var(--muted);flex:1}
a.nicho .go{margin-top:14px;color:var(--gold-d);font-weight:600;font-size:14px;display:inline-flex;gap:6px;align-items:center}

/* ---------- Steps (como funciona) ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px;counter-reset:s}
@media(max-width:860px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;position:relative}
.sec-cream .step,.sec-alt .step{background:#fff}
.step .n{width:44px;height:44px;border-radius:50%;background:var(--gold-grad-btn);color:#2a1d05;
  font-weight:700;font-size:19px;display:flex;align-items:center;justify-content:center;margin-bottom:14px;box-shadow:0 8px 18px -8px rgba(201,154,58,.7)}
.step h3{font-size:18px;margin-bottom:7px}
.step p{font-size:15px}

/* ---------- Eligibility (você pode ter) ---------- */
.elig{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center;margin-top:28px}
@media(max-width:860px){.elig{grid-template-columns:1fr;gap:22px}}
.elig .lst{list-style:none}
.elig .lst li{display:flex;gap:13px;align-items:flex-start;padding:13px 0;border-top:1px solid var(--line);font-size:16px;color:var(--body)}
.elig .lst li:first-child{border-top:0}
.elig .lst li .ck{width:26px;height:26px;flex:none;border-radius:50%;background:rgba(15,79,75,.1);
  color:var(--teal);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;margin-top:1px}
.elig .panel{background:var(--teal-grad);color:#fff;border-radius:22px;padding:30px;box-shadow:var(--shadow)}
.elig .panel .big{font-size:22px;color:#fff;font-weight:600;margin-bottom:8px}
.elig .panel p{color:#cdd9d6;font-size:15.5px;margin-bottom:18px}

/* ---------- Highlight band (retroativo) ---------- */
.band{background:var(--gold-grad-btn);color:#2a1d05;border-radius:24px;padding:34px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;box-shadow:var(--shadow)}
.band .bt{font-size:24px;font-weight:600;color:#2a1d05;max-width:600px}
.band .bt small{display:block;font-size:14.5px;font-weight:400;margin-top:6px;color:#4a3408}

/* ---------- FAQ ---------- */
.faq{margin-top:28px;max-width:780px}
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--radius-s);
  margin-bottom:12px;overflow:hidden}
.sec-cream .faq details{background:#fff}
.faq summary{cursor:pointer;list-style:none;padding:18px 22px;font-weight:500;font-size:16.5px;
  color:var(--teal);display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"+";font-size:24px;color:var(--gold-d);font-weight:400;transition:transform .2s}
.faq details[open] summary:after{transform:rotate(45deg)}
.faq .ans{padding:0 22px 20px;font-size:15.5px;color:var(--body)}

/* ---------- CTA final ---------- */
.cta-final{background:var(--teal-grad);color:#fff;text-align:center;position:relative;overflow:hidden}
.cta-final:before{content:"";position:absolute;inset:0;background:radial-gradient(50% 60% at 50% 0%,rgba(201,154,58,.18),transparent 60%)}
.cta-final .wrap{position:relative}
.cta-final h2{color:#fff;font-size:32px;margin-bottom:12px}
.cta-final p{color:#d4e0dd;font-size:18px;max-width:560px;margin:0 auto 26px}

/* ---------- Floating WhatsApp ---------- */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:80;display:flex;align-items:center;gap:10px;
  background:var(--wa);color:#063d1c;font-weight:600;font-size:15px;padding:13px 18px 13px 14px;
  border-radius:50px;box-shadow:0 14px 30px -10px rgba(37,211,102,.75);transition:transform .15s}
.wa-float:hover{transform:translateY(-2px);background:var(--wa-d)}
.wa-float .ic{width:24px;height:24px;flex:none}
.wa-float .lbl{}
@media(max-width:560px){.wa-float .lbl{display:none}.wa-float{padding:14px;right:14px;bottom:14px}}

/* ---------- Footer ---------- */
.ft{background:var(--teal-deeper);color:#9fb0ac;padding:50px 0 26px;font-size:14px}
.ft .top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px;padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.08)}
@media(max-width:860px){.ft .top{grid-template-columns:1fr;gap:24px}}
.ft .brand .cv{color:#fff;font-weight:700;font-size:20px;letter-spacing:3px}
.ft .brand .sg{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-l);margin-top:3px}
.ft p{color:#9fb0ac;font-size:14px;margin-top:12px;max-width:340px}
.ft h4{color:#fff;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:14px;font-weight:600}
.ft a.fl{display:block;color:#b9c8c4;padding:6px 0;font-size:14.5px}
.ft a.fl:hover{color:var(--gold-l)}
.ft .bot{padding-top:22px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12.5px;color:#7c8d89}
.ft .bot .disc{max-width:760px;line-height:1.5}
.ft .mk{width:40px;height:40px}

/* ---------- Popup de captação ---------- */
.cvpop-ov{position:fixed;inset:0;z-index:120;background:rgba(3,19,15,.66);backdrop-filter:blur(3px);
  display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .28s}
.cvpop-ov.on{opacity:1;visibility:visible}
.cvpop{background:var(--teal-grad);color:#fff;max-width:440px;width:100%;border-radius:24px;
  padding:36px 30px 26px;position:relative;box-shadow:0 30px 80px -18px rgba(0,0,0,.65);
  transform:translateY(18px) scale(.97);transition:transform .32s cubic-bezier(.2,.9,.3,1.2);text-align:center;overflow:hidden}
.cvpop-ov.on .cvpop{transform:none}
.cvpop:before{content:"";position:absolute;inset:0;background:radial-gradient(62% 52% at 50% 0,rgba(201,154,58,.22),transparent 62%);pointer-events:none}
.cvpop>*{position:relative}
.cvpop .x{position:absolute;top:13px;right:15px;width:32px;height:32px;border-radius:50%;border:0;
  background:rgba(255,255,255,.13);color:#fff;font-size:20px;cursor:pointer;line-height:1;transition:background .15s}
.cvpop .x:hover{background:rgba(255,255,255,.24)}
.cvpop .mk{width:64px;height:64px;border-radius:15px;margin:0 auto 15px;box-shadow:0 10px 26px -10px rgba(0,0,0,.6)}
.cvpop .kk{font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold-l);font-weight:600;margin-bottom:9px}
.cvpop h3{color:#fff;font-size:24px;line-height:1.16;margin-bottom:10px}
.cvpop h3 .gold{font-weight:700}
.cvpop p{color:#d4e0dd;font-size:15.5px;margin-bottom:20px}
.cvpop .no{display:block;margin-top:13px;color:var(--muted-l);font-size:13.5px;cursor:pointer;background:0;border:0;font-family:inherit;width:100%}
.cvpop .no:hover{color:#cdd9d6;text-decoration:underline}
@media(max-width:560px){.cvpop h3{font-size:21px}.cvpop{padding:32px 22px 22px}}

/* ---------- utility ---------- */
.mt8{margin-top:8px}.mt16{margin-top:16px}.mt24{margin-top:24px}
.hide{display:none}
