/* ===========================================================
   Carlos Sodré · Site (Direção B · Editorial Humano)
   Sistema visual compartilhado
   =========================================================== */
:root{
  --navy:#0B2E63;
  --navy-deep:#07234d;
  --blue:#1E8FD5;
  --sky:#00AAF8;
  --red:#E2142A;
  --ink:#16202e;
  --muted:#5a6677;
  --cream:#faf7f1;
  --cream2:#f3eee4;
  --line:#e7e2d6;
  --paper:#ffffff;
  --disp:"Archivo",system-ui,sans-serif;
  --body:"Source Sans 3",system-ui,sans-serif;
  --maxw:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--cream);line-height:1.62;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 44px}
.disp{font-family:var(--disp)}
.eyebrow{font-family:var(--disp);font-size:13px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--red)}
.eyebrow.sky{color:var(--blue)}
.center{text-align:center}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--disp);font-weight:700;font-size:14.5px;padding:13px 26px;border-radius:40px;transition:.2s;letter-spacing:.01em;cursor:pointer;border:none;white-space:nowrap}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:#bd1023;transform:translateY(-1px)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:#0a2550}
.btn-out{border:2px solid var(--navy);color:var(--navy);background:transparent}
.btn-out:hover{background:var(--navy);color:#fff}
.btn-sky{background:var(--sky);color:var(--navy-deep)}
.btn-sky:hover{background:#fff}
.btn-wout{border:2px solid rgba(255,255,255,.55);color:#fff;background:transparent}
.btn-wout:hover{background:#fff;color:var(--navy)}
.btn-lg{padding:16px 32px;font-size:16px}

/* ---------- header / nav ---------- */
header.site{position:sticky;top:0;z-index:60;background:rgba(250,247,241,.92);backdrop-filter:blur(10px);border-bottom:1px solid rgba(231,226,214,.7)}
.nav{display:flex;align-items:center;justify-content:space-between;height:88px}
.brand{display:flex;align-items:center;gap:13px}
.brand .mark{position:relative;width:48px;height:48px;border-radius:13px;background:linear-gradient(150deg,#0e3573,#072350);color:#fff;display:grid;place-items:center;font-family:var(--disp);font-weight:800;font-size:17px;letter-spacing:.05em;flex:none;overflow:hidden;padding-bottom:4px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.1),0 6px 14px -7px rgba(8,42,96,.7)}
.brand .mark::before{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--red)}
.brand .mark::after{content:"";position:absolute;left:8px;right:8px;bottom:7px;height:1.5px;background:var(--sky);opacity:.55}
.brand .bt{display:flex;flex-direction:column;justify-content:center}
.brand .bt b{font-family:var(--disp);font-size:19px;font-weight:800;color:var(--navy);letter-spacing:-.01em;line-height:1;white-space:nowrap}
.brand .bt span{font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:3px;white-space:nowrap}
.menu{display:flex;gap:25px;align-items:center}
.menu a{font-family:var(--disp);font-size:15px;font-weight:600;color:var(--navy);transition:.2s;white-space:nowrap;position:relative;padding:4px 0}
.menu a:hover{color:var(--red)}
.menu a.active{color:var(--red)}
.menu a.active::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:2px;background:var(--red);border-radius:2px}
.nav-cta{display:flex;align-items:center;gap:14px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:24px;height:2.5px;background:var(--navy);border-radius:2px;transition:.2s}

/* mobile menu */
.mobile-menu{display:none;position:fixed;inset:88px 0 0;background:var(--cream);z-index:55;padding:30px 44px;flex-direction:column;gap:6px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--disp);font-weight:700;font-size:22px;color:var(--navy);padding:14px 0;border-bottom:1px solid var(--line)}
.mobile-menu .btn{margin-top:20px;justify-content:center}

/* ---------- page hero (interior pages) ---------- */
.phero{background:var(--navy);color:#fff;position:relative;overflow:hidden}
.phero::before{content:"";position:absolute;right:-8%;top:-40%;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(0,170,248,.22),transparent 65%)}
.phero .wrap{position:relative;padding:78px 44px 84px}
.phero .crumb{font-family:var(--disp);font-size:13px;font-weight:600;letter-spacing:.06em;color:#9fb6d8;margin-bottom:20px}
.phero .crumb a:hover{color:var(--sky)}
.phero h1{font-family:var(--disp);font-weight:800;font-size:clamp(40px,5.4vw,72px);line-height:.98;letter-spacing:-.025em;max-width:900px}
.phero h1 .hl{color:var(--sky)}
.phero p.lead{font-size:20px;color:#bccadf;max-width:620px;margin-top:24px}

/* ---------- sections ---------- */
section{padding:96px 0}
.sec-head{max-width:760px;margin-bottom:56px}
.sec-head h2{font-family:var(--disp);font-weight:800;font-size:clamp(32px,4.2vw,52px);line-height:1.02;letter-spacing:-.02em;color:var(--navy);margin-top:16px}
.sec-head p{font-size:18px;color:var(--muted);margin-top:14px}
.sec-head.center{margin-left:auto;margin-right:auto}

/* ---------- slogan strip ---------- */
.strip{background:var(--navy);color:#fff;padding:22px 0;overflow:hidden}
.strip .row{display:flex;gap:54px;align-items:center;justify-content:center;flex-wrap:wrap}
.strip .row span{font-family:var(--disp);font-weight:700;font-size:20px;letter-spacing:.02em}
.strip .row i{width:7px;height:7px;border-radius:50%;background:var(--sky)}

/* ---------- footer ---------- */
footer.site{background:var(--navy-deep);color:#a9b6cc;padding:80px 0 40px;font-size:15px}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.1)}
footer.site .foot-brand .mark{position:relative;width:46px;height:46px;border-radius:13px;background:#fff;color:var(--navy);display:grid;place-items:center;font-family:var(--disp);font-weight:800;font-size:17px;letter-spacing:.05em;margin-bottom:18px;overflow:hidden;padding-bottom:4px}
footer.site .foot-brand .mark::before{content:"";position:absolute;left:0;right:0;bottom:0;height:4px;background:var(--red)}
.foot-brand p{max-width:290px;color:#8a98b0}
footer.site h4{color:#fff;font-family:var(--disp);font-size:14px;letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px;font-weight:700}
footer.site ul{list-style:none;display:flex;flex-direction:column;gap:11px}
footer.site ul a{transition:.2s}
footer.site ul a:hover{color:var(--sky)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;font-size:13px;color:#76849c;flex-wrap:wrap;gap:14px}
.foot-social{display:flex;gap:12px}
.foot-social a{width:38px;height:38px;border-radius:12px;border:1px solid rgba(255,255,255,.18);display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:12px;transition:.2s}
.foot-social a:hover{background:var(--sky);border-color:var(--sky);color:var(--navy)}

/* ---------- reusable cards / bits ---------- */
.pill-tag{display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:40px;padding:9px 18px 9px 12px;font-family:var(--disp);font-weight:600;font-size:13.5px;color:var(--navy)}
.pill-tag i{width:9px;height:9px;border-radius:50%;background:var(--sky)}

.bandeira-card{background:#fff;border-radius:22px;padding:38px 32px 34px;border:1px solid var(--line);transition:.25s;display:block}
.bandeira-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px -34px rgba(11,46,99,.45);border-color:transparent}
.bandeira-card .ic{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;background:var(--cream2);margin-bottom:24px}
.bandeira-card .ic svg{width:28px;height:28px;stroke:var(--navy);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.bandeira-card:nth-child(3n+1) .ic{background:#e7f3fb}.bandeira-card:nth-child(3n+1) .ic svg{stroke:var(--blue)}
.bandeira-card:nth-child(3n+2) .ic{background:#fdeaec}.bandeira-card:nth-child(3n+2) .ic svg{stroke:var(--red)}
.bandeira-card h3{font-family:var(--disp);font-weight:700;font-size:22px;color:var(--navy);margin-bottom:10px}
/* editorial number treatment (replaces icons) */
.bandeira-card .bnum{font-family:var(--disp);font-weight:800;font-size:46px;line-height:1;letter-spacing:-.03em;color:var(--navy);display:inline-block;position:relative;margin-bottom:24px;padding-bottom:16px}
.bandeira-card .bnum::after{content:"";position:absolute;left:2px;bottom:0;width:36px;height:3px;border-radius:3px;background:var(--blue);transition:.25s}
.bandeira-card:nth-child(3n+2) .bnum::after{background:var(--red)}
.bandeira-card:nth-child(3n) .bnum::after{background:var(--sky)}
.bandeira-card:hover .bnum::after{width:56px}
/* consistent line-icon rendering everywhere */
.ic svg,.big-ic svg{stroke-linecap:round;stroke-linejoin:round}
.bandeira-card p{font-size:16px;color:var(--muted)}

/* impact numbers */
.imp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.imp b{font-family:var(--disp);font-weight:800;font-size:clamp(50px,6.6vw,88px);line-height:.9;color:var(--navy);letter-spacing:-.03em;display:block}
.imp b .u{color:var(--red)}
.imp span{font-size:15.5px;color:var(--muted);margin-top:14px;display:block;max-width:210px}
.imp-grid.on-navy b{color:#fff}
.imp-grid.on-navy b .u{color:var(--sky)}
.imp-grid.on-navy span{color:#b9c6dd}

/* generic form controls */
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.field label{font-family:var(--disp);font-weight:600;font-size:14px;color:var(--navy)}
.field input,.field select,.field textarea{font-family:var(--body);font-size:16px;padding:14px 16px;border:1.5px solid var(--line);border-radius:12px;background:#fff;color:var(--ink);transition:.2s;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(30,143,213,.12)}
.field textarea{resize:vertical;min-height:130px}

/* ---------- responsive ---------- */
@media(max-width:1080px){
  .menu,.nav-cta .btn{display:none}
  .burger{display:flex}
  .nav-cta{gap:0}
}
@media(max-width:900px){
  .wrap{padding:0 22px}
  .imp-grid{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  section{padding:68px 0}
  .phero .wrap{padding:54px 22px 60px}
}

/* ---------- footer legal row ---------- */
.foot-legal{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.foot-legal a,.link-btn{color:#9fb0cc;font-size:13px;transition:.2s}
.foot-legal a:hover,.link-btn:hover{color:var(--sky)}
.link-btn{background:none;border:none;cursor:pointer;font-family:var(--body);padding:0}

/* ---------- legal pages (prose) ---------- */
.legal{padding:80px 0 110px}
.legal .wrap{max-width:880px}
.legal .legal-meta{font-size:14px;color:var(--muted);margin-bottom:40px;padding-bottom:24px;border-bottom:1px solid var(--line)}
.legal h2{font-family:var(--disp);font-weight:800;font-size:clamp(22px,2.6vw,30px);letter-spacing:-.01em;color:var(--navy);margin:42px 0 14px}
.legal h2:first-of-type{margin-top:0}
.legal h2 .ix{color:var(--blue);font-size:.7em;margin-right:10px}
.legal h3{font-family:var(--disp);font-weight:700;font-size:19px;color:var(--navy);margin:26px 0 10px}
.legal p{font-size:16.5px;color:#3a485f;margin-bottom:16px}
.legal ul{margin:0 0 18px 0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.legal ul li{position:relative;padding-left:26px;font-size:16.5px;color:#3a485f}
.legal ul li::before{content:"";position:absolute;left:4px;top:10px;width:7px;height:7px;border-radius:50%;background:var(--sky)}
.legal a{color:var(--blue);text-decoration:underline;text-underline-offset:2px}
.legal .callout{background:#fff;border:1px solid var(--line);border-left:4px solid var(--sky);border-radius:0 12px 12px 0;padding:22px 26px;margin:26px 0}
.legal .callout p{margin:0;color:#41506a}
.legal .toc{background:var(--cream2);border-radius:18px;padding:28px 30px;margin-bottom:44px}
.legal .toc h4{font-family:var(--disp);font-weight:700;font-size:14px;letter-spacing:.06em;text-transform:uppercase;color:var(--navy);margin-bottom:14px}
.legal .toc ol{margin:0;padding-left:20px;columns:2;column-gap:40px}
.legal .toc li{margin-bottom:8px;font-size:15px}
.legal .toc a{color:var(--navy);text-decoration:none}
.legal .toc a:hover{color:var(--blue);text-decoration:underline}
.legal section, .legal .sec{scroll-margin-top:110px}

/* ---------- cookie banner ---------- */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:80;background:var(--navy-deep);color:#dbe3f0;transform:translateY(110%);transition:transform .45s cubic-bezier(.22,1,.36,1);box-shadow:0 -10px 40px -16px rgba(0,0,0,.5)}
.cookie-banner.show{transform:translateY(0)}
.cb-inner{display:flex;align-items:center;gap:32px;padding:22px 44px}
.cb-text{flex:1}
.cb-text strong{font-family:var(--disp);font-weight:700;font-size:16px;color:#fff;display:block;margin-bottom:4px}
.cb-text p{font-size:13.5px;line-height:1.55;color:#aebbd0;max-width:760px}
.cb-text a{color:var(--sky);text-decoration:underline}
.cb-actions{display:flex;gap:12px;flex-wrap:wrap;flex-shrink:0}
.cb-sm{padding:11px 18px;font-size:13.5px}
.cookie-banner .btn-ghost{border:1.5px solid rgba(255,255,255,.4);color:#fff;background:transparent;border-radius:40px}
.cookie-banner .btn-ghost:hover{background:#fff;color:var(--navy)}

/* ---------- cookie modal ---------- */
.cookie-modal{position:fixed;inset:0;z-index:90;background:rgba(7,22,46,.6);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;padding:24px}
.cookie-modal.show{display:flex}
.cm-card{background:var(--cream);border-radius:22px;max-width:580px;width:100%;max-height:88vh;overflow:auto;padding:40px 40px 32px;position:relative;box-shadow:0 40px 90px -30px rgba(7,22,46,.6)}
.cm-close{position:absolute;top:18px;right:20px;background:none;border:none;font-size:30px;line-height:1;color:var(--muted);cursor:pointer;transition:.2s}
.cm-close:hover{color:var(--navy)}
.cm-card h3{font-family:var(--disp);font-weight:800;font-size:26px;color:var(--navy);letter-spacing:-.01em;margin:8px 0 10px}
.cm-intro{font-size:14.5px;color:#41506a;margin-bottom:24px}
.cm-intro a{color:var(--blue);text-decoration:underline}
.cm-list{display:flex;flex-direction:column;gap:12px}
.cm-cat{display:block;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 20px;cursor:pointer}
.cm-cat-h{display:flex;align-items:center;justify-content:space-between;gap:14px}
.cm-name{font-family:var(--disp);font-weight:700;font-size:16px;color:var(--navy)}
.cm-desc{font-size:13.5px;color:var(--muted);margin-top:8px}
.cm-lock{font-family:var(--disp);font-weight:600;font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:#1f9d57;background:#e9f6ee;padding:5px 12px;border-radius:30px;flex-shrink:0}
.cm-switch{position:relative;width:46px;height:26px;flex-shrink:0}
.cm-switch input{position:absolute;opacity:0;width:100%;height:100%;margin:0;cursor:pointer}
.cm-slider{position:absolute;inset:0;background:#cdd4df;border-radius:30px;transition:.2s}
.cm-slider::before{content:"";position:absolute;left:3px;top:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.cm-switch input:checked + .cm-slider{background:var(--blue)}
.cm-switch input:checked + .cm-slider::before{transform:translateX(20px)}
.cm-foot{display:flex;justify-content:space-between;gap:14px;margin-top:26px;flex-wrap:wrap}
.cm-foot .btn-ghost{border:2px solid var(--navy);color:var(--navy);background:transparent}
.cm-foot .btn-ghost:hover{background:var(--navy);color:#fff}

@media(max-width:760px){
  .cb-inner{flex-direction:column;align-items:flex-start;gap:16px;padding:20px 22px}
  .cb-actions{width:100%}
  .cb-sm{flex:1}
  .legal .toc ol{columns:1}
  .foot-legal{gap:14px}
}

/* crédito do tema (additivo) */
.foot-credit{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,.06);text-align:center}
.foot-credit span{font-size:12px;color:rgba(169,182,204,.38);letter-spacing:.02em}

/* defensivo: navegação nunca exibe marcadores de lista (aditivo) */
.menu ul,.menu ol,.menu li,.mobile-menu ul,.mobile-menu ol,.mobile-menu li{list-style:none;margin:0;padding:0}
.menu li{display:inline-flex;align-items:center}
