/* ==========================================================================
   Escutaris — Landing Page (público frio) · projeto independente
   Design System Escutaris v2: Garet (títulos) + Poppins (corpo),
   off-white dominante, terracota = assinatura/CTA, verde = autoridade.
   ========================================================================== */

/* Garet — fonte oficial dos títulos (auto-hospedada) */
@font-face { font-family:"Garet"; src:url("fonts/garet/Garet-Regular.woff2") format("woff2"); font-weight:400; font-display:swap; }
@font-face { font-family:"Garet"; src:url("fonts/garet/Garet-Medium.woff2") format("woff2"); font-weight:500; font-display:swap; }
@font-face { font-family:"Garet"; src:url("fonts/garet/Garet-Bold.woff2") format("woff2"); font-weight:700; font-display:swap; }
@font-face { font-family:"Garet"; src:url("fonts/garet/Garet-Extra-Bold.woff2") format("woff2"); font-weight:800; font-display:swap; }

:root{
  /* Âncora / verdes */
  --green:#46603a; --green-dark:#34492a; --poseidon:#222d19; --hermes:#565e48;
  /* Espectro quente */
  --amber:#c98a42; --cobre:#a95821; --terracota:#b95839; --terracota-deep:#2b180a; --brasa:#be3a1b;
  /* Neutros / superfícies */
  --off-white:#f8f7f4; --areia:#f6f0e9; --oat:#f0f0e8; --epic:#e4dfd9; --white:#fefefe;
  --border:#e4dfd9; --muted:#565e48;
  /* Tipografia */
  --display:"Garet", system-ui, -apple-system, "Segoe UI", sans-serif;
  --body:"Poppins", system-ui, -apple-system, "Segoe UI", sans-serif;
  --maxw:1180px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; font-family:var(--body); font-weight:300; color:var(--poseidon);
  background:var(--off-white); line-height:1.7; font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; }
h1,h2,h3,h4{ font-family:var(--display); color:var(--poseidon); margin:0; line-height:1.12; font-weight:800; letter-spacing:-0.01em; }
p{ margin:0; }

/* Layout ------------------------------------------------------------------ */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:24px; }
.section{ padding-block:84px; }
@media (max-width:760px){ .section{ padding-block:56px; } }
.bg-areia{ background:var(--areia); } .bg-white{ background:var(--white); }
.bg-oat{ background:var(--oat); } .bg-off{ background:var(--off-white); }

.eyebrow{
  display:inline-block; font-family:var(--body); font-weight:600; font-size:11px;
  text-transform:uppercase; letter-spacing:0.22em; color:var(--terracota); margin-bottom:16px;
}
.eyebrow--amber{ color:var(--cobre); }
.lead{ font-size:clamp(17px,2.2vw,20px); color:var(--muted); line-height:1.7; }
h2.h{ font-size:clamp(28px,4.4vw,48px); }
.maxprose{ max-width:60ch; }

/* Botões ------------------------------------------------------------------ */
.btn{
  display:inline-flex; align-items:center; gap:9px; font-family:var(--display); font-weight:500;
  font-size:15px; line-height:1; padding:15px 26px; border-radius:3px; border:1.5px solid transparent;
  cursor:pointer; text-decoration:none; transition:background-color .18s ease, color .18s ease, transform .18s ease, border-color .18s ease;
}
.btn--cta{ background:var(--terracota); color:#fff; }
.btn--cta:hover{ background:var(--terracota-deep); }
.btn--ghost{ background:transparent; color:var(--poseidon); border-color:var(--poseidon); }
.btn--ghost:hover{ border-color:var(--amber); color:var(--green-dark); }
.btn--ondark{ background:var(--terracota); color:#fff; }
.btn--ondark:hover{ background:#fff; color:var(--poseidon); }
.btn .wa{ width:17px; height:17px; fill:currentColor; }
.btn:focus-visible, a:focus-visible, summary:focus-visible{ outline:2px solid var(--green); outline-offset:3px; }
.cta-note{ font-size:13px; color:var(--muted); margin-top:12px; }

/* Header ------------------------------------------------------------------ */
.site-header{
  position:sticky; top:0; z-index:50; background:rgba(248,247,244,.86);
  backdrop-filter:saturate(140%) blur(8px); border-bottom:1px solid var(--border);
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; padding-block:14px; }
.site-header .logo{ height:34px; width:auto; }
.site-header .wa-mini{ font-size:14px; }

/* Hero -------------------------------------------------------------------- */
.hero{ padding-block:64px 92px; overflow:hidden; }
.hero__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; }
.badge{
  display:inline-flex; align-items:center; gap:9px; font-size:12px; font-weight:500;
  letter-spacing:.04em; color:var(--green-dark); background:var(--oat);
  border:1px solid var(--border); padding:7px 14px; border-radius:999px; margin-bottom:22px;
}
.badge .dot{ width:7px; height:7px; border-radius:50%; background:var(--terracota); }
.hero h1{ font-size:clamp(32px,5vw,54px); margin-bottom:22px; }
.hero h1 .hi{ color:var(--terracota); }
.hero .sub{ font-size:clamp(16px,2.2vw,19px); color:var(--muted); margin-bottom:30px; max-width:46ch; }
.hero .actions{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero .pull{
  margin-top:38px; padding-left:18px; border-left:3px solid var(--terracota);
  font-family:var(--display); font-weight:500; font-size:clamp(16px,2vw,19px); color:var(--poseidon); max-width:48ch;
}

/* Composição em camadas (signature) --------------------------------------- */
.layer{ position:relative; padding-bottom:42px; }
.layer__panel{
  width:84%; margin-left:auto; overflow:hidden; border-radius:14px;
  border:1px solid rgba(34,45,25,.10); box-shadow:0 16px 44px rgba(34,45,25,.14);
}
.layer__panel img{ width:100%; height:100%; object-fit:cover; aspect-ratio:16/10; }
.layer__card{
  position:absolute; left:0; bottom:0; width:62%; background:#fff; overflow:hidden;
  border-radius:12px; border:1px solid rgba(34,45,25,.10); box-shadow:0 10px 36px rgba(0,0,0,.16);
}
.winbar{ display:flex; align-items:center; gap:8px; padding:9px 14px; background:var(--areia); border-bottom:1px solid var(--border); }
.winbar .dots{ display:flex; gap:6px; }
.winbar .dots i{ width:9px; height:9px; border-radius:50%; background:var(--border); display:block; }
.winbar .wt{ font-size:10.5px; text-transform:uppercase; letter-spacing:.16em; color:var(--muted); font-weight:600; margin-inline:auto; padding-right:24px; }
.layer__card .media{ position:relative; }
.layer__card .media img{ width:100%; height:auto; }
.playbadge{
  position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px;
  background:rgba(34,45,25,.30); color:#fff; font-family:var(--display); font-weight:500; font-size:13px;
  border:0; cursor:pointer; width:100%; transition:background-color .2s ease;
}
.playbadge:hover{ background:rgba(34,45,25,.42); }
.playbadge .circ{ width:54px; height:54px; border-radius:50%; background:var(--terracota); display:grid; place-items:center; box-shadow:0 6px 20px rgba(34,45,25,.35); transition:transform .2s ease; }
.playbadge:hover .circ{ transform:scale(1.06); }
.playbadge .circ svg{ width:20px; height:20px; fill:#fff; margin-left:3px; }

/* Lightbox de vídeo ------------------------------------------------------- */
.vmodal[hidden]{ display:none; }
.vmodal{ position:fixed; inset:0; z-index:90; display:flex; align-items:center; justify-content:center; padding:24px; }
.vmodal__backdrop{ position:absolute; inset:0; background:rgba(34,45,25,.78); animation:vfade .2s ease; }
.vmodal__box{ position:relative; width:min(960px,100%); }
.vmodal__frame{ position:relative; width:100%; aspect-ratio:16/9; background:#000; border-radius:10px; overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,.4); }
.vmodal__frame iframe, .vmodal__frame video{ position:absolute; inset:0; width:100%; height:100%; border:0; object-fit:contain; background:#000; }
.vmodal__msg{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center; color:#fff; font-family:var(--body); font-size:14px; padding:24px; }
.vmodal__close{
  position:absolute; top:-14px; right:-10px; width:40px; height:40px; border-radius:50%; border:0; cursor:pointer;
  background:#fff; color:var(--poseidon); font-size:24px; line-height:1; display:grid; place-items:center; box-shadow:0 6px 18px rgba(0,0,0,.3);
}
@media (max-width:560px){ .vmodal__close{ top:-46px; right:0; } }
@keyframes vfade{ from{ opacity:0; } to{ opacity:1; } }
@media (prefers-reduced-motion:reduce){ .vmodal__backdrop{ animation:none; } .playbadge .circ, .playbadge:hover .circ{ transition:none; transform:none; } }

/* Painel emoldurado simples (tipo B) -------------------------------------- */
.frame{ overflow:hidden; border-radius:14px; border:1px solid rgba(34,45,25,.10); box-shadow:0 16px 44px rgba(34,45,25,.12); }
.frame img{ width:100%; height:100%; object-fit:cover; }

/* Grid utilitário --------------------------------------------------------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:center; }
.split--media-first .media{ order:-1; }

/* Cartões "custo de não agir" --------------------------------------------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:40px; }
.card{ background:#fff; border:1px solid var(--border); border-top:3px solid var(--terracota); padding:26px 24px; }
.card h3{ font-size:18px; margin-bottom:8px; }
.card p{ font-size:14.5px; color:var(--muted); }

/* Contraste ficção × ação (paleta de dados) ------------------------------- */
.contrast{ display:grid; grid-template-columns:1fr 1fr; border:1px solid var(--border); background:#fff; margin-top:8px; }
.contrast .col{ padding:30px 28px; }
.contrast .col:first-child{ border-right:1px solid var(--border); }
.contrast .label{ font-size:11px; text-transform:uppercase; letter-spacing:.16em; font-weight:600; margin-bottom:18px; }
.contrast .col--bad .label{ color:var(--muted); }
.contrast .col--good .label{ color:var(--terracota); }
.contrast ul{ list-style:none; margin:0; padding:0; display:grid; gap:14px; }
.contrast li{ display:flex; gap:12px; align-items:flex-start; line-height:1.5; }
.contrast li svg{ width:17px; height:17px; flex:0 0 auto; margin-top:3px; }
.contrast .col--bad li{ color:var(--muted); } .contrast .col--bad svg{ stroke:var(--brasa); }
.contrast .col--good li{ color:var(--poseidon); } .contrast .col--good svg{ stroke:var(--green); }
.quote-strong{ margin-top:26px; padding-left:18px; border-left:4px solid var(--terracota); font-family:var(--display); font-weight:700; font-size:clamp(17px,2.2vw,21px); max-width:52ch; }

/* Passos (sequência real → numerados) ------------------------------------- */
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; margin-top:44px; counter-reset:s; }
.step{ position:relative; padding-top:18px; border-top:2px solid var(--epic); }
.step .n{ font-family:var(--display); font-weight:800; font-size:34px; color:var(--terracota); line-height:1; margin-bottom:12px; display:block; }
.step h3{ font-size:17px; margin-bottom:8px; }
.step p{ font-size:14.5px; color:var(--muted); }

/* Entregáveis ------------------------------------------------------------- */
.checklist{ list-style:none; margin:0; padding:0; display:grid; gap:16px; }
.checklist li{ display:flex; gap:13px; align-items:flex-start; }
.checklist li svg{ width:20px; height:20px; flex:0 0 auto; margin-top:2px; stroke:var(--green); }
.checklist b{ color:var(--poseidon); font-weight:600; }
.checklist span{ color:var(--muted); }

/* Bloco de autoridade (verde) — único por página -------------------------- */
.authority{ background:var(--green); color:#fff; }
.authority h2, .authority h3{ color:#fff; }
.authority .eyebrow{ color:var(--amber); }
.authority .lead{ color:rgba(255,255,255,.82); }
.diff{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px 40px; margin-top:36px; }
.diff .item{ padding:20px 0; border-top:1px solid rgba(255,255,255,.16); }
.diff .item h3{ font-size:17px; margin-bottom:6px; }
.diff .item p{ color:rgba(255,255,255,.78); font-size:14.5px; }
.rt-card{
  margin-top:40px; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.16);
  border-radius:12px; padding:24px 26px; display:flex; gap:8px; flex-direction:column;
}
.rt-card .who{ font-family:var(--display); font-weight:700; font-size:18px; color:#fff; }
.rt-card .cred{ color:var(--amber); font-weight:600; letter-spacing:.04em; font-size:14px; }
.rt-card .role{ color:rgba(255,255,255,.78); font-size:14px; }

/* Perfis "para quem é" ---------------------------------------------------- */
.perfis{ display:grid; grid-template-columns:repeat(2,1fr); border:1px solid var(--border); background:#fff; }
.perfil{ padding:30px 28px; border-bottom:1px solid var(--border); }
.perfil:nth-child(odd){ border-right:1px solid var(--border); }
.perfil:nth-last-child(-n+2){ border-bottom:none; }
.perfil .n{ font-family:var(--display); font-weight:800; font-size:40px; color:var(--terracota); line-height:1; display:block; margin-bottom:14px; }
.perfil h3{ font-size:19px; margin-bottom:8px; }
.perfil p{ color:var(--muted); font-size:14.5px; }

/* Prova ------------------------------------------------------------------- */
.logos{ display:flex; flex-wrap:wrap; gap:14px 28px; align-items:center; margin-top:8px; margin-bottom:48px; }
.logos span{ font-family:var(--display); font-weight:700; color:var(--hermes); font-size:15px; opacity:.9; }
.logos .sep{ width:5px; height:5px; border-radius:50%; background:var(--epic); }
.depos{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.depo{ background:#fff; border:1px solid var(--border); padding:26px 24px; display:flex; flex-direction:column; gap:16px; }
.depo .mark{ font-family:var(--display); font-weight:800; font-size:40px; color:var(--epic); line-height:.6; height:22px; }
.depo p{ font-size:15px; color:var(--poseidon); line-height:1.6; }
.depo .by{ margin-top:auto; font-size:13px; color:var(--muted); }
.depo .by b{ color:var(--poseidon); font-weight:600; display:block; font-size:14px; }
.selos{ display:flex; flex-wrap:wrap; gap:12px; margin-top:40px; }
.selo{ font-size:12.5px; color:var(--muted); border:1px solid var(--border); padding:8px 14px; border-radius:999px; }
.selo b{ color:var(--green-dark); font-weight:600; }

/* FAQ --------------------------------------------------------------------- */
.faq{ max-width:820px; margin-top:36px; }
.faq details{ border-bottom:1px solid var(--border); }
.faq summary{
  list-style:none; cursor:pointer; padding:20px 40px 20px 0; position:relative;
  font-family:var(--display); font-weight:500; font-size:17px; color:var(--poseidon);
}
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; position:absolute; right:6px; top:18px; font-size:24px; color:var(--terracota); font-family:var(--body); transition:transform .2s ease; }
.faq details[open] summary::after{ content:"–"; }
.faq .a{ padding:0 40px 22px 0; color:var(--muted); font-size:15px; }

/* CTA final --------------------------------------------------------------- */
.cta-final{ background:var(--areia); text-align:center; }
.cta-final h2{ font-size:clamp(26px,4vw,42px); max-width:20ch; margin-inline:auto; }
.cta-final p{ color:var(--muted); margin:18px auto 30px; max-width:48ch; }

/* Footer ------------------------------------------------------------------ */
.footer{ background:var(--poseidon); color:rgba(255,255,255,.72); padding-block:46px; font-size:13.5px; }
.footer .logo{ height:30px; margin-bottom:18px; }
.footer .slogan{ font-family:var(--display); color:#fff; font-size:15px; margin-bottom:14px; }
.footer .rt{ color:rgba(255,255,255,.82); }
.footer .fine{ margin-top:18px; color:rgba(255,255,255,.5); font-size:12px; }

/* WhatsApp flutuante (mobile) --------------------------------------------- */
.wa-float{
  position:fixed; right:18px; bottom:18px; z-index:60; display:none; align-items:center; gap:9px;
  background:var(--terracota); color:#fff; text-decoration:none; font-family:var(--display); font-weight:500;
  padding:14px 20px; border-radius:999px; box-shadow:0 8px 28px rgba(34,45,25,.28); font-size:14px;
}
.wa-float svg{ width:19px; height:19px; fill:#fff; }

/* Reveal ------------------------------------------------------------------ */
.reveal{ opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }

/* Responsivo -------------------------------------------------------------- */
@media (max-width:920px){
  .hero__grid{ grid-template-columns:1fr; gap:40px; }
  .split{ grid-template-columns:1fr; gap:32px; }
  .split--media-first .media{ order:0; }
  .cards{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr 1fr; gap:28px; }
  .depos{ grid-template-columns:1fr; }
  .diff{ grid-template-columns:1fr; }
  .layer__panel{ width:100%; }
  .layer__card{ position:relative; width:88%; margin:-34px auto 0; bottom:auto; left:auto; }
}
@media (max-width:560px){
  .contrast{ grid-template-columns:1fr; } .contrast .col:first-child{ border-right:none; border-bottom:1px solid var(--border); }
  .perfis{ grid-template-columns:1fr; } .perfil:nth-child(odd){ border-right:none; }
  .perfil:nth-last-child(2){ border-bottom:1px solid var(--border); }
  .steps{ grid-template-columns:1fr; }
  .site-header .wa-mini{ display:none; }
  .wa-float{ display:inline-flex; }
}
@media (prefers-reduced-motion:reduce){
  *{ scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; transition:none; }
  .playbadge{ transition:none; }
}

/* ===== Isca digital (lead magnet) ======================================== */
.isca{ background:var(--white); }
.isca__grid{ display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:center; }
.isca__list{ list-style:none; margin:22px 0 0; padding:0; display:grid; gap:13px; }
.isca__list li{ display:flex; gap:12px; align-items:flex-start; color:var(--muted); }
.isca__list svg{ width:19px; height:19px; flex:0 0 auto; margin-top:2px; stroke:var(--green); }
.isca__card{ background:var(--areia); border:1px solid var(--border); border-radius:14px; padding:30px 28px; box-shadow:0 14px 40px rgba(34,45,25,.10); }
.isca__card h3{ font-size:20px; margin-bottom:6px; }
.isca__card .small{ font-size:13px; color:var(--muted); margin-bottom:20px; }
.field{ margin-bottom:14px; }
.field label{ display:block; font-size:12.5px; font-weight:500; color:var(--poseidon); margin-bottom:5px; }
.field input, .field select{ width:100%; font-family:var(--body); font-size:15px; color:var(--poseidon); background:#fff; border:1px solid var(--border); border-radius:6px; padding:11px 13px; }
.field input:focus, .field select:focus{ outline:2px solid var(--green); outline-offset:1px; border-color:var(--green); }
.hp{ position:absolute !important; left:-9999px; width:1px; height:1px; overflow:hidden; }
.consent{ display:flex; gap:9px; align-items:flex-start; font-size:12.5px; color:var(--muted); margin:8px 0 18px; line-height:1.5; }
.consent input{ margin-top:3px; flex:0 0 auto; }
.consent a{ color:var(--terracota); text-decoration:underline; }
.isca__card .btn{ width:100%; justify-content:center; }
.form-msg{ font-size:13.5px; margin-top:12px; min-height:1px; }
.form-msg.err{ color:var(--brasa); }
.isca__success{ text-align:center; padding:6px 0; }
.isca__success .ok{ width:54px; height:54px; border-radius:50%; background:var(--green); display:grid; place-items:center; margin:0 auto 16px; }
.isca__success .ok svg{ width:26px; height:26px; stroke:#fff; }
.isca__success h3{ margin-bottom:8px; }
.isca__success p{ color:var(--muted); font-size:14.5px; margin-bottom:18px; }
@media (max-width:920px){ .isca__grid{ grid-template-columns:1fr; gap:32px; } }
