/* ============================================================
   POSTO SEGURO — Home (Direção B · Editorial / Scroll-telling)
   Big editorial type · masked line reveals · sticky scenes
   Brand: black / paper / yellow · Archivo + Poppins
   ============================================================ */

:root{
  --yellow:#FFD400;
  --yellow-deep:#E9BE00;
  --ink:#0A0A0B;
  --ink-2:#0E0E12;
  --ink-3:#16161C;
  --ink-card:#141419;
  --paper:#F6F5F2;
  --paper-2:#ECEAE3;
  --line-d:rgba(255,255,255,.12);
  --line-d2:rgba(255,255,255,.20);
  --line-l:rgba(10,10,11,.12);
  --txt-d:rgba(255,255,255,.62);
  --txt-d-dim:rgba(255,255,255,.40);
  --txt-l:rgba(10,10,11,.60);
  --f-disp:'Archivo',system-ui,sans-serif;
  --f-body:'Archivo',system-ui,sans-serif;
  --f-mono:'Poppins',system-ui,sans-serif;
  --maxw:1280px;
  --pad:clamp(20px,5vw,72px);
  --ease:cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--ink); color:#fff;
  font-family:var(--f-body); -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility; overflow-x:hidden;
}
h1,h2,h3,h4{ font-family:var(--f-disp); margin:0; letter-spacing:-.03em; line-height:.96; font-weight:900; text-wrap:balance; }
p{ margin:0; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
ul{ margin:0; padding:0; list-style:none; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:var(--pad); padding-right:var(--pad); }
.section{ padding:clamp(96px,13vw,180px) 0; position:relative; }
.section[id], #topo{ scroll-margin-top:90px; }

/* surfaces */
.s-ink{ background:var(--ink); color:#fff; }
.s-ink-2{ background:var(--ink-2); color:#fff; }
.s-paper{ background:var(--paper); color:var(--ink); }
.s-yellow{ background:var(--yellow); color:var(--ink); }

/* ---- mono label / eyebrow ---- */
.kicker{
  font-family:var(--f-mono); font-size:13px; letter-spacing:.28em;
  text-transform:uppercase; font-weight:700; display:inline-flex; align-items:center; gap:12px;
}
.kicker .idx{ color:var(--yellow); }
.s-paper .kicker .idx{ color:var(--yellow-deep); }
.kicker .ln{ width:34px; height:1px; background:currentColor; opacity:.4; display:inline-block; }

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--f-disp); font-weight:800; font-size:16px; letter-spacing:-.01em;
  padding:17px 30px; border-radius:0; cursor:pointer; border:1.5px solid transparent;
  transition:transform .25s var(--ease), background .2s, color .2s, border-color .2s;
  white-space:nowrap; position:relative; overflow:hidden;
}
.btn-yellow{ background:var(--yellow); color:var(--ink); }
.btn-yellow:hover{ background:var(--yellow-deep); }
.btn-ink{ background:var(--ink); color:#fff; }
.btn-ink:hover{ background:#000; }
.btn-line-d{ background:transparent; color:#fff; border-color:var(--line-d2); }
.btn-line-d:hover{ border-color:#fff; }
.btn-line-l{ background:transparent; color:var(--ink); border-color:rgba(10,10,11,.28); }
.btn-line-l:hover{ border-color:var(--ink); }
.btn .arr{ transition:transform .25s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }
.btn-sm{ padding:13px 22px; font-size:15px; }

/* ================= NAV ================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:80;
  transition:background .35s var(--ease), border-color .35s, backdrop-filter .35s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{ background:rgba(10,10,11,.78); backdrop-filter:blur(16px) saturate(1.2); border-bottom-color:var(--line-d); }
.nav-inner{ display:flex; align-items:center; justify-content:space-between; height:84px; }
.nav .logo{ height:30px; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-links a{ font-family:var(--f-mono); font-weight:400; font-size:13px; letter-spacing:.1em; text-transform:uppercase; color:var(--txt-d); transition:color .2s; }
.nav-links a:hover{ color:#fff; }
.nav-right{ display:flex; align-items:center; gap:20px; }
.nav-sys{ font-family:var(--f-mono); font-size:13px; letter-spacing:.08em; text-transform:uppercase; color:#fff; }
.hamb{ display:none; flex-direction:column; gap:6px; background:none; border:0; cursor:pointer; padding:8px; }
.hamb span{ width:26px; height:2px; background:#fff; display:block; }

/* progress bar */
.scrollbar{ position:fixed; top:0; left:0; height:3px; width:0; background:var(--yellow); z-index:90; transition:width .1s linear; }

/* ================= masked reveal primitives ================= */
/* base state is VISIBLE — armed only in a real browser by editorial.js */
/* masked line reveal — padding/margin trick keeps descenders (g, p, ç) un-clipped */
.line-wrap{ overflow:hidden; display:block; padding-bottom:.14em; margin-bottom:-.14em; }
.line-wrap > *{ display:block; }
.armed .line-wrap > *{ transform:translateY(140%); transition:transform .9s var(--ease); }
.armed.in .line-wrap > *{ transform:translateY(0); }

.fade{ }
.armed.fade{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.armed.fade.in{ opacity:1; transform:none; }

/* stagger via inline --d (seconds) */
.armed[style*="--d"]{ transition-delay:var(--d); }
.armed .line-wrap > *{ transition-delay:var(--d, 0s); }

/* ================= HERO ================= */
.hero{ min-height:100vh; display:flex; flex-direction:column; justify-content:center; padding-top:130px; padding-bottom:60px; position:relative; overflow:hidden; }
.hero .glow{ position:absolute; border-radius:50%; filter:blur(90px); pointer-events:none; }
.hero .g1{ width:620px; height:620px; background:rgba(255,212,0,.16); top:-160px; right:-120px; }
.hero .g2{ width:420px; height:420px; background:rgba(255,212,0,.06); bottom:-120px; left:-80px; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(40px,5vw,72px); align-items:center; position:relative; z-index:2; }
.hero-head{ position:relative; z-index:2; min-width:0; }
.hero .kicker{ color:var(--txt-d); margin-bottom:30px; }
.hero h1{
  font-size:clamp(34px,4.4vw,56px); line-height:.96; letter-spacing:-.035em;
}
.hero h1 .line-wrap{ white-space:nowrap; }
.hero h1 .hl{ color:var(--yellow); }
.hero h1 .cyc{ display:inline-block; min-width:5.2ch; }
.hero-sub{ margin-top:28px; max-width:46ch; font-size:clamp(16px,1.4vw,19px); line-height:1.6; color:var(--txt-d); }
.hero-cta{ display:flex; gap:16px; flex-wrap:wrap; align-items:center; margin-top:36px; }
.hero-scroll{ margin-top:48px; display:inline-flex; align-items:center; gap:14px; font-family:var(--f-mono); font-size:12px; letter-spacing:.22em; text-transform:uppercase; color:var(--txt-d-dim); }
.hero-scroll .dl{ width:46px; height:1px; background:currentColor; position:relative; overflow:hidden; }
.hero-scroll .dl::after{ content:""; position:absolute; inset:0; background:var(--yellow); transform:translateX(-100%); animation:scrolldl 2.4s var(--ease) infinite; }
@keyframes scrolldl{ 0%{transform:translateX(-100%);} 50%{transform:translateX(0);} 100%{transform:translateX(100%);} }

/* product shot (right column) */
.hero-shot{ position:relative; min-width:0; }
.shot-frame{ border:1px solid var(--line-d2); background:var(--ink-2); }
.shot-frame .bar{ display:flex; align-items:center; gap:8px; padding:12px 16px; border-bottom:1px solid var(--line-d); }
.shot-frame .dot{ width:10px; height:10px; border-radius:50%; background:var(--line-d2); }
.shot-frame .url{ margin-left:10px; font-family:var(--f-mono); font-size:12px; letter-spacing:.04em; color:var(--txt-d-dim); }
.shot-frame img{ width:100%; }
.shot-badge{
  position:absolute; left:-18px; bottom:26px; background:var(--yellow); color:var(--ink);
  font-family:var(--f-mono); font-size:13px; font-weight:700; letter-spacing:.06em;
  padding:12px 18px; box-shadow:0 14px 40px rgba(0,0,0,.45);
}

/* ================= MARQUEE strip ================= */
.strip{ border-top:1px solid var(--line-d); border-bottom:1px solid var(--line-d); padding:26px 0; overflow:hidden; background:var(--ink); }
.strip.paper{ border-color:var(--line-l); background:var(--paper); color:var(--ink); }
.marquee{ display:flex; width:max-content; gap:0; animation:slide 32s linear infinite; }
.marquee.rev{ animation-direction:reverse; }
.marquee .it{ font-family:var(--f-disp); font-weight:900; font-size:clamp(26px,3.4vw,46px); letter-spacing:-.02em; padding:0 38px; display:inline-flex; align-items:center; gap:38px; }
.marquee .it .st{ color:var(--yellow); font-size:.6em; }
.s-paper .marquee .it .st, .strip.paper .marquee .it .st{ color:var(--yellow-deep); }
@keyframes slide{ to{ transform:translateX(-50%); } }

/* ================= MANIFESTO (citação central) ================= */
.manifesto{ padding:clamp(110px,15vw,200px) 0; }
.manifesto .wrap{ display:flex; flex-direction:column; align-items:center; text-align:center; }
.manifesto .rule{ width:56px; height:3px; background:var(--yellow); margin-top:34px; }
.manifesto .big{
  font-size:clamp(40px,5.4vw,72px); line-height:1.02; letter-spacing:-.03em; font-weight:900;
  margin-top:38px;
}
.manifesto .quote{
  margin-top:30px; font-size:clamp(22px,2.5vw,32px); line-height:1.35;
  color:var(--txt-d); max-width:34ch; font-weight:500; letter-spacing:-.01em;
}
.manifesto .quote .hl{ color:var(--yellow); font-weight:800; white-space:nowrap; }
.manifesto .meta{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,5vw,64px);
  margin-top:clamp(56px,7vw,84px); text-align:left; width:100%; max-width:880px;
}
.manifesto .meta .blk{ border-top:1px solid var(--line-d); padding-top:22px; }
.manifesto .meta h4{ font-family:var(--f-mono); font-size:13px; letter-spacing:.18em; text-transform:uppercase; color:var(--yellow); margin-bottom:14px; font-weight:700; }
.manifesto .meta p{ color:var(--txt-d); font-size:16px; line-height:1.6; }

/* ================= STATS ================= */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:0; border-top:1px solid var(--line-l); border-bottom:1px solid var(--line-l); }
.stat{
  padding:clamp(32px,4vw,52px) 36px;
  border-right:1px solid var(--line-l);
  display:flex; flex-direction:column; min-height:240px;
}
.stat:first-child{ padding-left:0; }
.stat:last-child{ border-right:0; padding-right:0; }
.stat .v{ font-family:var(--f-disp); font-weight:900; font-size:clamp(44px,6.2vw,92px); line-height:.9; letter-spacing:-.04em; white-space:nowrap; }
.stat .v .u{ font-size:.42em; vertical-align:top; }
.stat .l{ margin-top:auto; padding-top:24px; font-family:var(--f-mono); font-size:13px; letter-spacing:.06em; line-height:1.45; color:var(--txt-l); text-transform:uppercase; max-width:20ch; }

/* ================= section header ================= */
h2.shead{ font-size:clamp(32px,4.6vw,58px); line-height:.98; max-width:900px; }
.shead + .lead, .shead .lead{ font-size:clamp(17px,1.6vw,21px); line-height:1.55; max-width:54ch; }
.s-ink .shead + .lead, .s-ink-2 .shead + .lead{ color:var(--txt-d); }
.s-paper .shead + .lead{ color:var(--txt-l); }

/* ================= AUDITORIA sticky scroll ================= */
.aud{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(40px,7vw,110px); align-items:start; }
.aud-sticky{ position:sticky; top:120px; align-self:start; }
.aud-sticky h2{ font-size:clamp(34px,4.4vw,62px); margin-top:26px; }
.aud-sticky .lead{ margin-top:26px; color:var(--txt-d); font-size:17px; line-height:1.6; max-width:34ch; }
.aud-list{ display:flex; flex-direction:column; }
.aud-item{ padding:clamp(34px,4vw,54px) 0; border-top:1px solid var(--line-d); }
.aud-item:last-child{ border-bottom:1px solid var(--line-d); }
.aud-item .top{ display:flex; align-items:baseline; gap:20px; }
.aud-item .no{ font-family:var(--f-mono); font-size:14px; letter-spacing:.1em; color:var(--yellow); }
.aud-item h3{ font-size:clamp(28px,3.6vw,46px); }
.aud-item .ic{ margin-left:auto; color:var(--txt-d-dim); }
.aud-item ul{ margin-top:26px; display:grid; grid-template-columns:1fr 1fr; gap:14px 30px; }
.aud-item li{ display:flex; gap:11px; color:var(--txt-d); font-size:15.5px; line-height:1.45; }
.aud-item li svg{ flex:none; margin-top:3px; color:var(--yellow); }

/* ================= SEGMENTOS ================= */
.seg-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line-l); border:1px solid var(--line-l); margin-top:clamp(48px,6vw,80px); }
.seg{ background:var(--paper); padding:clamp(28px,3vw,40px); min-height:240px; display:flex; flex-direction:column; transition:background .3s, color .3s; position:relative; }
.seg .si{ color:var(--yellow-deep); transition:color .3s; display:inline-flex; flex:none; }
.seg .tt{ display:flex; align-items:center; gap:14px; }
.seg .tt h4{ margin-top:0; }
.seg .no{ font-family:var(--f-mono); font-size:12px; letter-spacing:.1em; color:var(--txt-l); margin-top:auto; transition:color .3s; }
.seg h4{ font-size:clamp(20px,1.8vw,26px); letter-spacing:-.02em; }
.seg p{ margin-top:16px; font-size:14.5px; line-height:1.5; color:var(--txt-l); transition:color .3s; }
.seg.cta{ background:var(--yellow); color:var(--ink); justify-content:center; gap:18px; }
.seg.cta h4{ margin-top:0; }
@media (hover:hover){
  .seg:hover{ background:var(--ink); color:#fff; }
  .seg:hover .si{ color:var(--yellow); }
  .seg:hover .no{ color:var(--txt-d); }
  .seg:hover p{ color:var(--txt-d); }
  .seg.cta:hover{ background:var(--yellow); color:var(--ink); }
  .seg.cta:hover p{ color:var(--txt-l); }
}

/* ================= FERRAMENTAS ================= */
.tools-top{ display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:end; }
.tools-top .lead{ color:var(--txt-d); font-size:18px; line-height:1.6; }
.tools-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-d); border:1px solid var(--line-d); margin-top:clamp(48px,6vw,80px); }
.tool{ background:var(--ink); padding:clamp(30px,3vw,44px); min-height:230px; display:flex; flex-direction:column; transition:background .3s; position:relative; }
.tool:hover{ background:var(--ink-3); }
.tool .ti{ color:var(--yellow); }
.tool h4{ font-size:clamp(19px,1.7vw,24px); margin-top:26px; letter-spacing:-.02em; }
.tool p{ margin-top:12px; font-size:15px; line-height:1.55; color:var(--txt-d); }
.tool .new{ position:absolute; top:22px; right:22px; font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink); background:var(--yellow); padding:4px 9px; }
.mascot{ display:grid; grid-template-columns:1fr auto; gap:40px; align-items:center; margin-top:clamp(40px,5vw,64px); padding:clamp(34px,4vw,56px); background:var(--ink-3); border:1px solid var(--line-d); }
.mascot img{ width:clamp(90px,11vw,150px); height:auto; }
.mascot h3{ font-size:clamp(24px,2.6vw,38px); }
.mascot p{ margin-top:14px; color:var(--txt-d); font-size:16px; line-height:1.6; max-width:56ch; }

/* ================= PLANOS ================= */
.plan-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-l); border:1px solid var(--line-l); margin-top:clamp(48px,6vw,80px); }
.plan{ background:var(--paper); padding:clamp(30px,3vw,44px); display:flex; flex-direction:column; position:relative; }
.plan.feat{ background:var(--ink); color:#fff; }
.plan .ptag{ font-family:var(--f-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--txt-l); }
.plan.feat .ptag{ color:var(--yellow); }
.plan .pname{ font-family:var(--f-disp); font-weight:900; font-size:clamp(26px,2.6vw,38px); margin-top:14px; letter-spacing:-.02em; }
.plan .price{ margin-top:22px; display:flex; align-items:baseline; gap:6px; }
.plan .price .v{ font-family:var(--f-disp); font-weight:900; font-size:clamp(38px,4vw,58px); letter-spacing:-.03em; }
.plan .price .per{ font-family:var(--f-mono); font-size:13px; color:var(--txt-l); }
.plan.feat .price .per{ color:var(--txt-d); }
.plan .pdesc{ margin-top:16px; font-size:15px; line-height:1.55; color:var(--txt-l); min-height:48px; }
.plan.feat .pdesc{ color:var(--txt-d); }
.plan .pbtn{ margin-top:26px; width:100%; }
.plan ul{ margin-top:30px; display:flex; flex-direction:column; gap:14px; }
.plan li{ display:flex; gap:11px; font-size:15px; line-height:1.45; }
.plan li svg{ flex:none; margin-top:2px; color:var(--yellow-deep); }
.plan.feat li svg{ color:var(--yellow); }
.plan li b{ font-weight:800; }
.badge-pop{ position:absolute; top:0; right:0; background:var(--yellow); color:var(--ink); font-family:var(--f-mono); font-size:11px; letter-spacing:.12em; text-transform:uppercase; padding:7px 13px; }

/* ================= BLOG ================= */
.blog-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line-d); border:1px solid var(--line-d); margin-top:clamp(48px,6vw,80px); }
.bpost{ background:var(--ink); display:flex; flex-direction:column; transition:background .3s; }
.bpost:hover{ background:var(--ink-3); }
.bp-cover{ aspect-ratio:16/10; overflow:hidden; border-bottom:1px solid var(--line-d); }
.bp-cover img{ width:100%; height:100%; object-fit:cover; }
.bp-ph{ display:flex; align-items:center; justify-content:center; background-image:repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 10px, transparent 10px 20px); }
.bp-ph span{ font-family:var(--f-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--txt-d-dim); }
.bp-body{ padding:24px 26px 28px; display:flex; flex-direction:column; flex:1; }
.bp-meta{ display:flex; align-items:center; gap:14px; font-family:var(--f-mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; }
.bp-tag{ color:var(--yellow); font-weight:600; }
.bp-date{ color:var(--txt-d-dim); }
.bpost h4{ margin-top:14px; font-size:clamp(18px,1.6vw,22px); letter-spacing:-.02em; line-height:1.15; }
.bpost > .bp-body > p{ margin-top:12px; font-size:14.5px; line-height:1.55; color:var(--txt-d); }
.bp-more{ margin-top:auto; padding-top:18px; font-family:var(--f-mono); font-size:12.5px; letter-spacing:.06em; color:var(--yellow); font-weight:600; }

/* página da notícia */
.art{ max-width:760px; margin:0 auto; padding-top:140px; padding-bottom:clamp(80px,10vw,140px); }
.art .bp-meta{ margin-bottom:22px; }
.art h1{ font-size:clamp(30px,4.6vw,54px); line-height:1.02; letter-spacing:-.03em; }
.art .art-cover{ margin-top:36px; border:1px solid var(--line-d); }
.art .art-cover img{ width:100%; display:block; }
.art .art-body{ margin-top:36px; }
.art .art-body p{ font-size:17px; line-height:1.75; color:var(--txt-d); margin:0 0 22px; }
.art .art-back{ display:inline-flex; align-items:center; gap:10px; margin-bottom:34px; font-family:var(--f-mono); font-size:12.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--txt-d); transition:color .2s; }
.art .art-back:hover{ color:var(--yellow); }

/* ================= TREINAMENTOS ================= */
.tr-list{ margin-top:clamp(48px,6vw,80px); border-top:1px solid var(--line-d); }
.tr-row{ display:grid; grid-template-columns:90px 1fr 2fr auto; gap:30px; align-items:center; padding:clamp(26px,3vw,40px) 0; border-bottom:1px solid var(--line-d); transition:padding-left .35s var(--ease), background .35s; }
.tr-row:hover{ padding-left:18px; }
.tr-row .no{ font-family:var(--f-mono); font-size:15px; color:var(--yellow); }
.tr-row h4{ font-size:clamp(22px,2.4vw,34px); letter-spacing:-.02em; }
.tr-row p{ color:var(--txt-d); font-size:15.5px; line-height:1.5; }
.tr-row .go{ color:var(--txt-d-dim); transition:transform .3s var(--ease), color .3s; }
.tr-row:hover .go{ color:var(--yellow); transform:translateX(6px); }

/* ================= CLIENTES ================= */
.cli-top{ display:flex; align-items:flex-end; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.cli-note{ font-family:var(--f-mono); font-size:13px; letter-spacing:.04em; color:var(--txt-l); display:flex; align-items:center; gap:10px; }
.cli-note svg{ color:var(--yellow-deep); }

/* ================= CTA + FORM ================= */
.cta-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(40px,6vw,90px); align-items:start; }
.cta-grid h2{ font-size:clamp(38px,5.4vw,76px); line-height:.98; }
.cta-grid .lead{ margin-top:26px; font-size:clamp(17px,1.6vw,20px); line-height:1.55; max-width:46ch; }
.cta-points{ margin-top:38px; display:flex; flex-direction:column; gap:16px; }
.cta-points li{ display:flex; align-items:center; gap:14px; font-family:var(--f-disp); font-weight:700; font-size:clamp(17px,1.6vw,20px); }
.form-card{ background:var(--ink); color:#fff; padding:clamp(30px,3.4vw,48px); }
.form-card h3{ font-size:clamp(24px,2.4vw,32px); }
.form-card .fsub{ margin-top:12px; color:var(--txt-d); font-size:15px; line-height:1.5; }
.field{ margin-top:22px; }
.field label{ display:block; font-family:var(--f-mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--txt-d); margin-bottom:9px; }
.field input, .field select{
  width:100%; background:transparent; border:0; border-bottom:1.5px solid var(--line-d2); color:#fff;
  font-family:var(--f-body); font-size:17px; padding:11px 0; outline:none; transition:border-color .2s;
}
.field input::placeholder{ color:var(--txt-d-dim); }
.field input:focus, .field select:focus{ border-color:var(--yellow); }
.field select option{ background:var(--ink); }
.field.err input{ border-color:#FF5F57; }
.field .msg{ color:#FF8A84; font-size:13px; margin-top:7px; font-family:var(--f-mono); display:none; }
.field.err .msg{ display:block; }
.form-card .submit{ margin-top:32px; width:100%; }
.form-card .whats{ margin-top:18px; display:flex; align-items:center; gap:9px; justify-content:center; color:var(--txt-d); font-size:13.5px; }
.form-ok{ text-align:center; padding:30px 0; }
.form-ok .ok-ic{ width:62px; height:62px; border-radius:50%; background:var(--yellow); display:flex; align-items:center; justify-content:center; margin:0 auto 22px; }
.form-ok h3{ font-size:28px; }
.form-ok p{ margin-top:14px; color:var(--txt-d); font-size:16px; line-height:1.55; }

/* ================= FOOTER ================= */
.footer{ background:var(--ink); border-top:1px solid var(--line-d); padding:clamp(70px,8vw,110px) 0 44px; }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; }
.foot-brand .logo{ height:32px; }
.foot-brand p{ margin-top:22px; color:var(--txt-d); font-size:15px; line-height:1.6; max-width:38ch; }
.foot-social{ display:flex; gap:16px; margin-top:26px; }
.foot-social a{ color:var(--txt-d); transition:color .2s; }
.foot-social a:hover{ color:var(--yellow); }
.foot-col h5{ font-family:var(--f-mono); font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--txt-d-dim); margin:0 0 20px; font-weight:700; }
.foot-col a{ display:block; color:var(--txt-d); font-size:15px; padding:7px 0; transition:color .2s; }
.foot-col a:hover{ color:#fff; }
.foot-bot{ display:flex; align-items:center; justify-content:space-between; gap:24px; margin-top:clamp(56px,7vw,90px); padding-top:30px; border-top:1px solid var(--line-d); flex-wrap:wrap; }
.foot-bot span, .foot-bot a{ font-family:var(--f-mono); font-size:12px; letter-spacing:.04em; color:var(--txt-d-dim); }
.foot-bot a:hover{ color:#fff; }

/* ================= DRAWER (mobile) ================= */
.drawer{ position:fixed; inset:0; z-index:95; background:var(--ink); display:flex; flex-direction:column; padding:24px var(--pad); transform:translateX(100%); transition:transform .4s var(--ease); }
.drawer.open{ transform:translateX(0); }
.drawer .d-top{ display:flex; align-items:center; justify-content:space-between; height:84px; }
.drawer .d-close{ background:none; border:0; color:#fff; font-size:34px; cursor:pointer; line-height:1; }
.drawer a.dl{ color:#fff; font-family:var(--f-disp); font-weight:900; font-size:34px; padding:16px 0; border-bottom:1px solid var(--line-d); letter-spacing:-.02em; }
.drawer .d-cta{ margin-top:30px; }

/* ================= RESPONSIVE ================= */
@media (max-width:1140px){
  .nav-links{ gap:24px; }
  .nav-links a{ font-size:12px; }
}
@media (max-width:1000px){
  .nav-sys{ display:none; }
}
@media (max-width:1080px){
  .hero-grid{ grid-template-columns:1fr; gap:48px; }
  .hero{ min-height:0; }
  .hero-shot{ max-width:640px; }
  .shot-badge{ left:14px; }
  .stats{ grid-template-columns:1fr 1fr; }
  .stat:nth-child(odd){ padding-left:0; }
  .stat:nth-child(even){ border-right:0; padding-right:0; }
  .stat{ border-bottom:1px solid var(--line-l); min-height:200px; }
  .stat:nth-child(n+3){ border-bottom:0; }
  .seg-grid, .tools-grid, .plan-grid{ grid-template-columns:1fr 1fr; }
  .aud{ grid-template-columns:1fr; }
  .aud-sticky{ position:static; }
}
@media (max-width:760px){
  .nav-links, .nav-sys{ display:none; }
  .hamb{ display:flex; }
  .nav-inner{ height:68px; }
  .nav .logo{ height:26px; }
  .drawer .d-top{ height:68px; }
  .drawer a.dl{ font-size:28px; padding:14px 0; }
  .section[id], #topo{ scroll-margin-top:72px; }
  .hero{ padding-top:108px; padding-bottom:48px; }
  .hero h1{ font-size:clamp(30px,9vw,44px); }
  .hero .g1{ width:380px; height:380px; right:-160px; top:-120px; }
  .hero .g2{ display:none; }
  .shot-badge{ font-size:12px; padding:10px 14px; bottom:16px; }
  .strip{ padding:18px 0; }
  .tools-top, .cta-grid{ grid-template-columns:1fr; }
  .tools-grid, .plan-grid, .stats, .blog-grid{ grid-template-columns:1fr; }
  .seg, .tool{ min-height:0; }
  /* segmentos: 2 colunas, só ícone + título; descrição abre no toque */
  .seg-grid{ grid-template-columns:1fr 1fr; }
  .seg:not(.cta){ cursor:pointer; -webkit-tap-highlight-color:transparent; padding:20px 16px 18px; }
  .seg:not(.cta) .tt{ flex-direction:column; align-items:flex-start; gap:14px; padding-right:18px; }
  .seg h4{ font-size:16.5px; line-height:1.2; }
  .seg .no{ display:none; }
  .seg:not(.cta)::after{ content:"+"; position:absolute; top:14px; right:14px; font-family:var(--f-mono); font-size:18px; line-height:1; color:var(--txt-l); transition:color .3s; }
  .seg p{ max-height:0; overflow:hidden; margin-top:0; opacity:0; transition:max-height .4s var(--ease), margin-top .4s var(--ease), opacity .3s, color .3s; }
  .seg.open{ background:var(--ink); color:#fff; }
  .seg.open .si{ color:var(--yellow); }
  .seg.open::after{ content:"\2212"; color:var(--yellow); }
  .seg.open p{ max-height:180px; margin-top:12px; opacity:1; color:var(--txt-d); }
  .seg.cta{ flex-direction:column; align-items:flex-start; justify-content:center; gap:14px; padding:20px 16px; }
  .seg.cta h4{ font-size:16.5px; }
  .seg.cta .btn{ align-self:flex-start !important; }
  .plan .pdesc{ min-height:0; }
  .stat{ border-right:0; padding-left:0; padding-right:0; min-height:0; border-bottom:1px solid var(--line-l); padding-top:26px; padding-bottom:26px; align-items:center; text-align:center; }
  .stat .l{ max-width:none; }
  .stat:last-child{ border-bottom:0; }
  .stat .l{ margin-top:16px; padding-top:0; }
  .aud-item ul{ grid-template-columns:1fr; }
  .manifesto .meta{ grid-template-columns:1fr; gap:30px; }
  .tr-row{ grid-template-columns:54px 1fr; gap:8px 18px; }
  .tr-row p, .tr-row .go{ grid-column:2; }
  .tr-row:hover{ padding-left:0; }
  .mascot{ grid-template-columns:1fr; text-align:left; gap:24px; }
  .foot-grid{ grid-template-columns:1fr 1fr; gap:36px; }
}
@media (max-width:480px){
  .btn{ padding:15px 22px; font-size:15px; }
  .btn-sm{ padding:11px 16px; font-size:14px; }
  .nav-inner{ height:62px; }
  .nav .logo{ height:23px; }
  .drawer .d-top{ height:62px; }
  .section{ padding:76px 0; }
  .section[id], #topo{ scroll-margin-top:64px; }
  .kicker{ font-size:11px; letter-spacing:.2em; }
  .hero{ padding-top:96px; }
  .hero h1{ font-size:clamp(27px,8.6vw,36px); }
  .hero-sub{ font-size:15.5px; margin-top:22px; }
  .hero-cta{ margin-top:30px; }
  .hero-cta .btn{ width:100%; }
  .hero-scroll{ margin-top:36px; }
  .shot-frame .url{ font-size:10px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
  .marquee .it{ font-size:22px; padding:0 20px; gap:20px; }
  .manifesto{ padding:88px 0; }
  .manifesto .big{ font-size:clamp(30px,9vw,40px); }
  .manifesto .quote{ font-size:19px; }
  .stats{ border-top:0; }
  .stat .v{ font-size:clamp(40px,13vw,56px); }
  h2.shead{ font-size:clamp(27px,8.4vw,36px); }
  .aud-sticky h2{ font-size:clamp(29px,9vw,40px); }
  .aud-item .top{ gap:12px; flex-wrap:wrap; }
  .aud-item h3{ font-size:26px; }
  .aud-item li{ font-size:14.5px; }
  .seg:not(.cta){ padding:18px 14px 16px; }
  .seg h4{ font-size:15.5px; }
  .tool{ padding:26px 22px; }
  .tool h4{ margin-top:18px; }
  .mascot{ padding:24px 20px; }
  .plan{ padding:28px 22px; }
  .plan .price .v{ font-size:42px; }
  .tr-row h4{ font-size:21px; }
  .tr-row p{ font-size:14.5px; }
  .cta-grid h2{ font-size:clamp(29px,9.2vw,44px); }
  .cta-points li{ font-size:16px; }
  .form-card{ padding:26px 20px 30px; }
  .foot-grid{ grid-template-columns:1fr; gap:32px; }
  .foot-bot{ flex-direction:column; align-items:flex-start; gap:14px; }
  .foot-bot > div{ flex-wrap:wrap; gap:14px 18px; }
}

/* ================= reduced motion ================= */
@media (prefers-reduced-motion:reduce){
  .armed, .armed .line-wrap > *{ opacity:1 !important; transform:none !important; transition:none !important; }
  .marquee{ animation:none !important; }
  .hero-scroll .dl::after{ animation:none !important; }
  html{ scroll-behavior:auto; }
}

/* ================= monitores grandes (≥1600px) ================= */
/* O container e a tipografia crescem junto com a tela, para o site não
   ficar "perdido" no centro de monitores 2K/4K/ultrawide. Notebooks
   (≤1536px) ficam intactos. */
@media (min-width:1600px){
  :root{ --maxw:1440px; }
  .hero h1{ font-size:clamp(56px,4.6vw,72px); }
  .hero-sub{ font-size:clamp(19px,1.45vw,22px); }
  h2.shead{ font-size:clamp(58px,4.8vw,74px); max-width:1100px; }
  .shead + .lead, .shead .lead{ font-size:clamp(21px,1.65vw,24px); }
  .manifesto .big{ font-size:clamp(72px,5.6vw,92px); }
  .manifesto .quote{ font-size:clamp(32px,2.6vw,40px); }
  .stat .v{ font-size:clamp(92px,6.4vw,116px); }
  .marquee .it{ font-size:clamp(46px,3.6vw,58px); }
  .pname{ font-size:clamp(38px,2.7vw,44px); }
  .price .v{ font-size:clamp(58px,4.2vw,68px); }
}
@media (min-width:1920px){
  :root{ --maxw:1600px; }
}
@media (min-width:2560px){
  :root{ --maxw:1840px; }
  .hero h1{ font-size:clamp(72px,4.6vw,88px); }
  h2.shead{ font-size:clamp(74px,4.8vw,90px); }
  .manifesto .big{ font-size:clamp(92px,5.6vw,112px); }
  .stat .v{ font-size:clamp(116px,6.4vw,140px); }
}
