/* =====================================================
   YRYDYUM — STYLE.CSS (REFATORADO / PADRÃO GLOBAL)
   Dark default + Light minimal (sem degradês no light)
   FIXES MENU:
   - adiciona .navActions (layout estável: toggle + hamb + CTA)
   - corrige underline do menu (hover/active) sem “sumir”/sem shift
   - evita “encavalamento” do toggle com CTA (gap + nowrap + shrink)
   - melhora responsivo (CTA some em 560px, mas mantém espaçamento)
   ===================================================== */

/* =========================
   01) THEME TOKENS (DEFAULT: DARK)
   ========================= */
:root{
  /* core */
  --bg:#0b0c10;
  --panel:#14161d;
  --panel2:#0f1117;

  --border:#232633;
  --border2:#2b2f40;

  --text:#eef0f6;
  --muted:#9aa0b2;

  --accent:#ff7a18;
  --accent2:#ffb054;

  --radius:14px;
  --blur:20px;
  --maxWide:1440px;

  --shadow:0 16px 60px rgba(0,0,0,.42);
  --shadow-sm:0 10px 30px rgba(0,0,0,.28);

  --font: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";

  /* status */
  --ok:#22c55e;
  --err:#ef4444;
  --warn:#f59e0b;

  /* controls (dark) */
  --control-bg:#12141b;
  --control-border:rgba(35,38,51,.85);
  --control-placeholder:rgba(154,160,178,.75);
  --control-focus:rgba(255,176,84,.95);
  --control-focus-ring:rgba(255,122,24,.16);

  /* surfaces */
  --surface-hover:rgba(255,255,255,.02);
  --surface-accent:rgba(255,122,24,.06);
  --surface-accent-border:rgba(255,122,24,.25);

  /* toggle */
  --toggle-bg:#12141b;
  --toggle-hover:#161923;
  --toggle-ring:rgba(255,122,24,.18);

  /* links */
  --link:rgba(255,176,84,.95);
  --link-underline:rgba(255,122,24,.35);

  /* selection */
  --selection-bg: rgba(255,122,24,.22);
  --selection-fg: var(--text);
}

/* =========================
   02) LIGHT THEME OVERRIDES (SEM DEGRADÊS)
   ========================= */
html[data-theme="light"],
body.theme-light{
  --bg:#ffffff;
  --panel:#ffffff;
  --panel2:#f8fafc;

  --border:#e5e7eb;
  --border2:#d1d5db;

  --text:#0f172a;
  --muted:#64748b;

  --shadow:0 16px 60px rgba(15,23,42,.12);
  --shadow-sm:0 10px 30px rgba(15,23,42,.10);

  --control-bg:#ffffff;
  --control-border:rgba(229,231,235,.95);
  --control-placeholder:rgba(100,116,139,.60);

  /* no light tudo laranja do logo */
  --control-focus:rgba(255,122,24,.95);
  --control-focus-ring:rgba(255,122,24,.14);

  --surface-hover:rgba(2,6,23,.03);
  --surface-accent:rgba(255,122,24,.06);
  --surface-accent-border:rgba(255,122,24,.22);

  --toggle-bg:#ffffff;
  --toggle-hover:#f1f5f9;
  --toggle-ring:rgba(255,122,24,.16);

  --link:rgba(255,122,24,.95);
  --link-underline:rgba(255,122,24,.28);

  --selection-bg: rgba(255,122,24,.18);
  --selection-fg: var(--text);
}

/* Helps native inputs/select look right */
html{ color-scheme: dark; }
html[data-theme="light"]{ color-scheme: light; }
body.theme-light{ color-scheme: light; }

/* =========================
   03) RESET / BASE
   ========================= */
*{ box-sizing:border-box; }
html,body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--font);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{ text-decoration:none; color:inherit; }
img,video{ max-width:100%; display:block; }
button{ font:inherit; }
:focus-visible{ outline:2px solid var(--accent2); outline-offset:2px; }

::selection{ background: var(--selection-bg); color: var(--selection-fg); }

/* trava scroll quando drawer abre */
body.drawer-open{ overflow:hidden; }

/* melhora autofill no dark */
input:-webkit-autofill,
textarea:-webkit-autofill,
select:-webkit-autofill{
  -webkit-text-fill-color: var(--text);
  transition: background-color 9999s ease-in-out 0s;
  box-shadow: 0 0 0 1000px var(--control-bg) inset;
}

/* =========================
   04) LAYOUT / UTIL
   ========================= */
.container{ max-width:var(--maxWide); margin:auto; padding:0 24px; }
section{ padding:112px 0; }

.small{ font-size:13px; color:var(--muted); }
.full{ max-width:none; }
.mt-32{ margin-top:32px; }
.mt6{ margin-top:6px; }
.sectionSpacer{ height:18px; }

/* listas padrão */
ul.full{
  margin:14px 0 0;
  padding-left:18px;
  color:var(--muted);
  line-height:1.75;
}
ul.full li{ margin:8px 0; }

/* links “legais” */
.link,
.legalCard a{
  color:var(--text);
  text-decoration:underline;
  text-decoration-color:var(--link-underline);
  text-underline-offset:3px;
}
.link:hover,
.legalCard a:hover{
  text-decoration-color:var(--link);
}

/* Acessibilidade: skip link */
.skipLink{
  position:absolute;
  left:-999px;
  top:12px;
  z-index:9999;
  background:var(--panel);
  border:1px solid var(--border);
  color:var(--text);
  padding:10px 12px;
  border-radius:12px;
}
.skipLink:focus{ left:12px; }

/* fallback sem JS */
.noscript{
  padding:12px 16px;
  background:var(--panel2);
  color:var(--text);
  border-bottom:1px solid var(--border);
  font-family:var(--font);
}

/* =========================
   05) HEADER / NAV
   ========================= */
header{
  position:fixed;
  top:0;
  width:100%;
  z-index:100;
  backdrop-filter:blur(var(--blur));
  background:rgba(11,12,16,.78);
  border-bottom:1px solid var(--border);
}
html[data-theme="light"] header,
body.theme-light header{
  background:rgba(255,255,255,.82);
}

.nav{
  height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  min-width:0; /* evita overflow do menu */
}

.logo{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:650;
  letter-spacing:.2px;
  flex:0 0 auto;
}
.logo-img{ height:28px; width:auto; display:block; }
.logo-text{ display:block; }

/* =========================
   05.1) NAV ACTIONS (FIX encavalamento)
   ========================= */
.navActions{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
  white-space:nowrap;
}

/* garante que botões não “esticam” */
.navActions > *{ flex:0 0 auto; }

/* =========================
   06) MENU DESKTOP (UNDERLINE MODERNO GLOBAL)
   - underline via background-size (zero layout shift)
   - garante linha visível: background-position + padding-bottom
   - corrige bug “sumiu”: evita calc(100% + 8px) e usa bottom fixo
   ========================= */
.menu{
  display:flex;
  gap:24px;
  align-items:center;
  flex:1 1 auto;
  justify-content:center; /* deixa menu central sem empurrar actions */
  min-width:0;
}

/* link base */
.menu a{
  font-size:14px;
  color:var(--muted);
  display:inline-flex;
  align-items:center;
  line-height:1;
  padding:10px 2px 14px; /* bottom maior = espaço pro underline */
  text-decoration:none;
  white-space:nowrap;

  /* underline moderno */
  background-image:linear-gradient(var(--accent), var(--accent));
  background-repeat:no-repeat;
  background-size:0% 2px;
  background-position:0 100%; /* linha no “rodapé” do link */
  transition:color .16s ease, background-size .18s ease;
}

/* hover/active */
.menu a:hover,
.menu a.active{
  color:var(--text);
  background-size:100% 2px;
}

/* evita “cortar” underline por overflow do header */
header,
.nav,
.menu{ overflow:visible; }

/* =========================
   07) CTA (dark pode degradê / light sólido)
   ========================= */
.cta{
  padding:12px 20px;
  border-radius:999px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#0b0c10;
  font-weight:650;
  font-size:14px;
  box-shadow:0 10px 30px rgba(255,122,24,.18);
}
html[data-theme="light"] .cta,
body.theme-light .cta{
  background:var(--link);
  color:#ffffff;
  box-shadow:0 10px 30px rgba(255,122,24,.18);
}
.cta--inline{ display:inline-block; }

/* =========================
   08) THEME TOGGLE
   ========================= */
.themeToggle{
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--toggle-bg);
  color:var(--text);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition:background .18s ease, border-color .18s ease, transform .18s ease, box-shadow .18s ease;
  box-shadow:0 1px 0 rgba(255,255,255,.04) inset;
  position:relative;
  overflow:hidden;
  -webkit-tap-highlight-color:transparent;
}
.themeToggle:hover{
  background:var(--toggle-hover);
  border-color:var(--border2);
  transform:translateY(-1px);
}
.themeToggle:active{ transform:translateY(0) scale(.99); }
.themeToggle:focus-visible{
  outline:none;
  box-shadow:0 0 0 3px var(--toggle-ring);
}
.themeToggle svg{ width:18px; height:18px; display:block; }

/* 2 ícones */
.themeToggle .ttIcon{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  transition:opacity .18s ease, transform .22s ease;
}
.themeToggle .ttIcon.sun{ opacity:0; transform:translateY(6px) scale(.92); }
.themeToggle .ttIcon.moon{ opacity:1; transform:translateY(0) scale(1); }

/* light: sol */
html[data-theme="light"] .themeToggle .ttIcon.sun,
body.theme-light .themeToggle .ttIcon.sun{ opacity:1; transform:translateY(0) scale(1); }
html[data-theme="light"] .themeToggle .ttIcon.moon,
body.theme-light .themeToggle .ttIcon.moon{ opacity:0; transform:translateY(-6px) scale(.92); }

/* fallback 1 svg */
.themeToggle > svg{ transition:transform .22s ease, opacity .18s ease; }
html[data-theme="light"] .themeToggle > svg,
body.theme-light .themeToggle > svg{ transform:rotate(18deg) scale(1.02); }

/* =========================
   09) HAMB + DRAWER (base)
   ========================= */
.hamb{
  width:44px;
  height:44px;
  border-radius:12px;
  display:none;
  align-items:center;
  justify-content:center;
  border:1px solid var(--border);
  background:var(--panel);
  color:var(--text);
}

.hamb-lines{ width:18px; height:12px; position:relative; display:block; }
.hamb-lines span{
  position:absolute;
  left:0; right:0;
  height:2px;
  border-radius:2px;
  background:var(--text);
}
.hamb-lines span:nth-child(1){ top:0; }
.hamb-lines span:nth-child(2){ top:5px; opacity:.9; }
.hamb-lines span:nth-child(3){ bottom:0; }

#drawerBack{
  position:fixed;
  inset:0;
  z-index:120;
  background:rgba(0,0,0,.58);
  display:none;
  opacity:0;
  transition:opacity .18s ease;
}
#drawerBack.is-open{ display:block; opacity:1; }

#drawer{
  position:fixed;
  top:0;
  right:0;
  height:100%;
  width:min(360px,92vw);
  z-index:130;
  background:rgba(18,20,27,.98);
  border-left:1px solid var(--border);
  transform:translateX(105%);
  transition:transform .22s ease;
  padding:18px;
}
html[data-theme="light"] #drawer,
body.theme-light #drawer{ background:rgba(255,255,255,.98); }
#drawer.is-open{ transform:translateX(0); }

.drawerTop{ display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.drawerBrand{ display:flex; align-items:center; gap:10px; font-weight:650; }
.drawer-logo{ height:26px; width:auto; }

.drawerClose{
  width:42px;
  height:42px;
  border-radius:12px;
  border:1px solid var(--border);
  background:transparent;
  color:var(--text);
}

.drawerMenu{ display:flex; flex-direction:column; gap:10px; margin-top:10px; }
.drawerMenu a{
  padding:12px 12px;
  border-radius:12px;
  border:1px solid rgba(35,38,51,0);
}
.drawerMenu a:hover{ border-color:var(--border); background:var(--surface-hover); }
.drawerMenu a.active{ border-color:var(--surface-accent-border); background:var(--surface-accent); }
.drawerCTA{ margin-top:14px; }

/* =========================
   10) TIPOGRAFIA BASE
   ========================= */
h1{ font-size:56px; line-height:1.05; margin:0 0 18px; letter-spacing:-.02em; }
h2{ font-size:38px; margin:0 0 10px; letter-spacing:-.01em; }
h3{ font-size:18px; margin:0 0 6px; }

p{
  color:var(--muted);
  max-width:760px;
  margin:0;
  line-height:1.65;
}

.accent{ color:var(--accent); }
html[data-theme="light"] .accent,
body.theme-light .accent{ color:var(--link); }

/* =========================
   11) HERO
   ========================= */
.hero{
  padding-top:120px;
  position:relative;
  overflow:hidden;
  min-height:calc(100svh - 72px);
  display:flex;
  align-items:center;
}

.heroMedia{
  position:absolute;
  inset:0;
  z-index:-3;
  opacity:.28;
  filter:saturate(1.1) contrast(1.05);
  transform:scale(1.03);
}
.heroMedia img,.heroMedia video{ width:100%; height:100%; object-fit:cover; }

.heroBg{
  position:absolute;
  inset:0;
  z-index:-2;
  background:
    radial-gradient(900px 520px at 20% -10%, rgba(255,122,24,.16), transparent),
    radial-gradient(900px 520px at 80% 0%, rgba(255,176,84,.10), transparent);
}
html[data-theme="light"] .heroBg,
body.theme-light .heroBg{ background:none; }

.heroOverlay{
  position:absolute;
  inset:0;
  z-index:-1;
  background:linear-gradient(180deg, rgba(11,12,16,.55), rgba(11,12,16,.93));
}
html[data-theme="light"] .heroOverlay,
body.theme-light .heroOverlay{ background:rgba(255,255,255,.92); }

.hero--center{ text-align:center; }

.heroCenter{
  width:100%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:14px;
  padding:64px 0 10px;
}

.heroTitle{ max-width:980px; margin:0; }
.heroSub{ max-width:820px; font-size:16px; }

.heroActions{
  margin-top:18px;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.heroActions--center{ justify-content:center; }

.heroScrollHint{
  margin-top:64px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
  padding:0;
  border:none;
  background:none;
  border-radius:0;
  color:var(--muted);
  font-size:14px;
  user-select:none;
  -webkit-tap-highlight-color:transparent;
}
.heroScrollHint:hover{ color:var(--text); }

.heroScrollText{ font-size:14px; letter-spacing:.3px; }

.heroScrollIcon{
  width:28px;
  height:28px;
  display:grid;
  place-items:center;
  border-radius:999px;
  border:1px solid rgba(255,122,24,.35);
  background:rgba(255,122,24,.08);
  color:var(--accent2);
  animation:heroScrollBounce 1.4s ease-in-out infinite;
}
html[data-theme="light"] .heroScrollIcon,
body.theme-light .heroScrollIcon{
  border-color:rgba(255,122,24,.25);
  background:rgba(255,122,24,.06);
  color:var(--link);
}
.heroScrollIcon svg{ width:16px; height:16px; }

@keyframes heroScrollBounce{
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(6px); }
}

/* =========================
   12) BUTTONS
   ========================= */
.btn{
  padding:14px 18px;
  border-radius:12px;
  background:var(--panel);
  border:1px solid var(--border);
  font-weight:650;
  font-size:14px;
  color:var(--text);
  position:relative;
  overflow:hidden;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease, filter .18s ease, background .18s ease;
  transform:translateZ(0);
  user-select:none;
  -webkit-tap-highlight-color:transparent;
}
.btn:hover{ transform:translateY(-1px); border-color:var(--border2); }
.btn:active{ transform:translateY(0px) scale(.99); }

.btn.primary{
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#0b0c10;
  border:none;
  box-shadow:0 12px 40px rgba(255,122,24,.20);
}
html[data-theme="light"] .btn.primary,
body.theme-light .btn.primary{
  background:var(--link);
  color:#ffffff;
  box-shadow:0 12px 40px rgba(255,122,24,.18);
}

.btn--pill{ border-radius:999px; padding:14px 20px; }

/* shine */
.btn--shine::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:linear-gradient(115deg,
    transparent 0%,
    rgba(255,255,255,.00) 35%,
    rgba(255,255,255,.55) 48%,
    rgba(255,255,255,.00) 60%,
    transparent 100%);
  transform:translateX(-130%) skewX(-12deg);
  opacity:0;
  pointer-events:none;
}
.btn--shine:hover::before{
  opacity:.28;
  transform:translateX(130%) skewX(-12deg);
  transition:transform .75s ease, opacity .2s ease;
}
.btn.primary.btn--shine:hover{
  filter:saturate(1.05);
  box-shadow:0 18px 55px rgba(255,122,24,.22);
}
html[data-theme="light"] .btn.primary.btn--shine:hover,
body.theme-light .btn.primary.btn--shine:hover{
  box-shadow:0 18px 55px rgba(255,122,24,.22);
}

/* =========================
   13) SECTION HEAD
   ========================= */
.sectionHead{
  margin-bottom:34px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

/* =========================
   14) GRID / CARDS
   ========================= */
.grid{ display:grid; gap:18px; }
.grid.cols-1{ grid-template-columns:1fr; }
.grid.cols-2{ grid-template-columns:repeat(2,1fr); }
.grid.cols-3{ grid-template-columns:repeat(3,1fr); }
.grid.cols-4{ grid-template-columns:repeat(4,1fr); }

.card{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px;
  position:relative;
  overflow:hidden;
  transform:translateZ(0);
}

/* glow (não bloqueia clique) */
.card::after{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(420px at var(--x,50%) var(--y,50%), rgba(255,122,24,.20), transparent 60%);
  opacity:0;
  transition:opacity .3s ease;
  pointer-events:none;
}
.card:hover::after{ opacity:1; }

.cardMeta{ display:flex; gap:10px; align-items:center; margin-bottom:10px; }

.tag{
  font-size:12px;
  padding:4px 10px;
  border-radius:999px;
  border:1px solid var(--surface-accent-border);
  background:var(--surface-accent);
  color:var(--accent2);
}
html[data-theme="light"] .tag,
body.theme-light .tag{ color:var(--link); }

.cardIcon{
  width:34px;
  height:34px;
  border-radius:12px;
  border:1px solid var(--surface-accent-border);
  background:rgba(255,122,24,.10);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#ffd1a8;
  font-weight:800;
}
html[data-theme="light"] .cardIcon,
body.theme-light .cardIcon{
  color:var(--text);
  background:rgba(255,122,24,.08);
  border-color:rgba(255,122,24,.22);
}

/* =========================
   15) FAQ
   ========================= */
.faq{ display:grid; gap:12px; }
.faqItem{
  border:1px solid var(--border);
  border-radius:14px;
  background:rgba(20,22,29,.90);
  overflow:hidden;
}
html[data-theme="light"] .faqItem,
body.theme-light .faqItem{ background:#ffffff; }

.faqBtn{
  width:100%;
  padding:16px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  background:transparent;
  border:none;
  color:var(--text);
  cursor:pointer;
  text-align:left;
}
.faqBtn span{ font-weight:650; }
.faqBtn em{ font-style:normal; color:var(--muted); font-size:13px; }

.faqPanel{
  max-height:0;
  overflow:hidden;
  border-top:1px solid rgba(35,38,51,.6);
  transition:max-height .22s ease;
}
html[data-theme="light"] .faqPanel,
body.theme-light .faqPanel{ border-top:1px solid rgba(229,231,235,.95); }

.faqPanel > div{
  padding:14px 16px;
  color:var(--muted);
  line-height:1.6;
  font-size:14px;
}

/* =========================
   16) CONTACT FORM
   ========================= */
.emailAccent{
  color: var(--accent2);
  font-weight: 700;
  text-decoration: none;
  border-bottom: 1px dashed rgba(255,176,84,.55);
  padding-bottom: 1px;
}
.emailAccent:hover{
  color: var(--accent);
  border-bottom-color: rgba(255,122,24,.75);
}
html[data-theme="light"] .emailAccent,
body.theme-light .emailAccent{
  color:var(--link);
  border-bottom-color:rgba(255,122,24,.28);
}
html[data-theme="light"] .emailAccent:hover,
body.theme-light .emailAccent:hover{
  border-bottom-color:rgba(255,122,24,.45);
}

.contactCard{ position:relative; isolation:isolate; }

.contactForm{
  margin-top:10px;
  display:flex;
  flex-direction:column;
  gap:16px;
}

.formGrid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
}
.formFull{ grid-column:1 / -1; }

.formField{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.formField label{
  font-size:13px;
  color:var(--muted);
}

.formField input,
.formField select,
.formField textarea{
  width:100%;
  background:var(--control-bg);
  border:1px solid var(--control-border);
  border-radius:12px;
  padding:12px 14px;
  color:var(--text);
  font-family:var(--font);
  font-size:14px;
  outline:none;
  pointer-events:auto;
  position:relative;
  z-index:2;
  transition:border-color .18s ease, box-shadow .18s ease, filter .18s ease, background .18s ease;
}

.formField textarea{
  resize:vertical;
  min-height:120px;
}

.formField input::placeholder,
.formField textarea::placeholder{
  color:var(--control-placeholder);
}

.formField input:focus,
.formField select:focus,
.formField textarea:focus{
  border-color:var(--control-focus);
  box-shadow:0 0 0 3px var(--control-focus-ring);
  filter:saturate(1.02);
}

.formField input:disabled,
.formField select:disabled,
.formField textarea:disabled{
  opacity:.6;
  cursor:not-allowed;
}

/* select arrow */
.formField select{
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--muted) 50%),
    linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) calc(50% - 3px),
    calc(100% - 12px) calc(50% - 3px);
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
  padding-right:42px;
}

/* dropdown */
.formField select option{
  background:var(--panel);
  color:var(--text);
}
.formField select option[value=""]{ color:var(--muted); }

.formField select,
.formField select option{ color-scheme: dark; }
html[data-theme="light"] .formField select,
html[data-theme="light"] .formField select option,
body.theme-light .formField select,
body.theme-light .formField select option{ color-scheme: light; }

.formActions{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.formHint{ margin:0; max-width:none; opacity:.95; }

/* select wrapper */
.selectWrap{ position:relative; width:100%; }

/* Honeypot anti-bot */
.hp{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  overflow:hidden !important;
}

/* form status */
#formStatus{
  min-height:18px;
  margin-top:10px;
}
.formStatus--ok{ color:var(--ok); }
.formStatus--err{ color:var(--err); }

/* =========================
   17) FOOTER
   ========================= */
footer{
  border-top:1px solid var(--border);
  padding:56px 0 30px;
  color:var(--muted);
  background:var(--bg);
}
html[data-theme="light"] footer,
body.theme-light footer{ background:#ffffff; }

.footerGrid{
  display:grid;
  grid-template-columns:1.6fr 1fr 1fr 1fr;
  gap:24px;
}

.footerTitle{ color:var(--text); font-weight:650; margin:0 0 10px; }
.footerCol a{ display:block; padding:7px 0; color:var(--muted); font-size:14px; }
.footerCol a:hover{ color:var(--text); }

.footerBottom{
  margin-top:26px;
  padding-top:18px;
  border-top:1px solid rgba(35,38,51,.7);
  display:flex;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}
html[data-theme="light"] .footerBottom,
body.theme-light .footerBottom{ border-top:1px solid rgba(229,231,235,.95); }

.footerBrand{ display:flex; align-items:center; gap:10px; margin-bottom:12px; }
.footer-logo{ height:28px; width:auto; }
.footerText{ max-width:520px; line-height:1.6; }
.heart{ color:#e11d48; }

/* =========================
   18) SCROLL UP
   ========================= */
#scrollUp{
  position:fixed;
  right:18px;
  bottom:18px;
  width:46px;
  height:46px;
  border-radius:14px;
  border:1px solid var(--border);
  background:var(--panel);
  color:var(--text);
  display:grid;
  place-items:center;
  box-shadow:var(--shadow);
  opacity:0;
  pointer-events:none;
  transform:translateY(8px);
  transition:
    opacity .18s ease,
    transform .18s ease,
    border-color .18s ease,
    box-shadow .18s ease,
    filter .18s ease,
    background .18s ease,
    color .18s ease;
  z-index:140;
  overflow:hidden;
}
#scrollUp:hover{
  border-color: rgba(255,122,24,.55);
  box-shadow: 0 16px 60px rgba(255,122,24,.12);
  filter: saturate(1.05);
  background: rgba(255,122,24,.10);
  color: var(--accent2);
}
html[data-theme="light"] #scrollUp:hover,
body.theme-light #scrollUp:hover{
  border-color: rgba(255,122,24,.35);
  box-shadow: 0 16px 60px rgba(255,122,24,.12);
  background: rgba(255,122,24,.06);
  color: var(--link);
}

#scrollUp::before{
  content:"";
  position:absolute;
  inset:-2px;
  background: linear-gradient(115deg,
    transparent 0%,
    rgba(255,255,255,0) 35%,
    rgba(255,255,255,.55) 48%,
    rgba(255,255,255,0) 60%,
    transparent 100%);
  transform: translateX(-130%) skewX(-12deg);
  opacity:0;
  pointer-events:none;
}
#scrollUp:hover::before{
  opacity:.22;
  transform: translateX(130%) skewX(-12deg);
  transition: transform .75s ease, opacity .2s ease;
}
#scrollUp svg{ width:18px; height:18px; }

/* =========================
   19) REVEAL ON SCROLL
   ========================= */
.reveal{
  opacity:0;
  transform:translateY(14px);
  transition:opacity .55s ease, transform .55s ease;
  will-change:opacity, transform;
}
.reveal.is-visible{ opacity:1; transform:translateY(0); }
.reveal.d1{ transition-delay:.06s; }
.reveal.d2{ transition-delay:.12s; }
.reveal.d3{ transition-delay:.18s; }

/* =========================
   20) LEGAL PAGES
   ========================= */
.legalPage{ padding-top:120px; }
.legalCard{ max-width:980px; margin:0 auto; }
.legalCard h2{
  font-size:22px;
  margin:22px 0 10px;
  letter-spacing:-.01em;
}
.legalCard p{ max-width:none; }
.legalCard ul{
  margin:10px 0 18px;
  padding-left:18px;
  color:var(--muted);
  line-height:1.75;
}
.legalCard li{ margin:8px 0; }

/* =========================
   21) RESPONSIVE
   ========================= */
@media (min-width:1600px){
  .container{ max-width:1520px; }
  h1{ font-size:64px; }
}

@media (max-width:1100px){
  section{ padding:102px 0; }
  .hero{ min-height:calc(100svh - 72px); }
}

/* a partir daqui: some menu desktop, entra hamb */
@media (max-width:900px){
  h1{ font-size:42px; }
  h2{ font-size:32px; }
  .menu{ display:none; }
  .hamb{ display:flex; }
  .footerGrid{ grid-template-columns:1fr 1fr; }

  .grid.cols-2{ grid-template-columns:1fr; }
  .grid.cols-3{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .grid.cols-4{ grid-template-columns:repeat(2, minmax(0, 1fr)); }

  .formGrid{ grid-template-columns:1fr; }
  .legalPage{ padding-top:106px; }
  .legalCard h2{ font-size:20px; }
}

@media (max-width:560px){
  .container{ padding:0 16px; }
  .nav{ height:66px; }

  /* CTA some no mobile pequeno, mas actions mantém gap */
  .cta{ display:none; }

  h1{ font-size:36px; }
  .footerGrid{ grid-template-columns:1fr; }
  .logo-text{ display:none; }
  .logo-img{ height:26px; }
  .btn--pill{ padding:13px 18px; }

  .grid.cols-2{ grid-template-columns:1fr; }
  .grid.cols-3{ grid-template-columns:1fr; }
  .grid.cols-4{ grid-template-columns:1fr; }

  .card{ min-width:0; }
  .card h3, .card p{ overflow-wrap:anywhere; }
}

/* =========================
   22) REDUCED MOTION
   ========================= */
@media (prefers-reduced-motion: reduce){
  *{
    scroll-behavior:auto !important;
    transition:none !important;
    animation:none !important;
  }
  .reveal{ opacity:1 !important; transform:none !important; }
  #scrollUp::before{ display:none !important; }
}
