/* ============================================================
   C-MOVA — Design System v4 "Premium / LanderX"
   base.css · tokens, reset, type, utilities, nav, buttons, footer
   ============================================================ */

/* ─── FONTS (Fontshare) ─── */
/* Clash Display = display headlines · Satoshi = body/UI */

/* ─── 1. TOKENS ─────────────────────────────────────────────── */
:root {
  /* brand accent — KEPT from original DS */
  --accent:        #c851f0;
  --accent-2:      #9c12ca;
  --accent-hi:     #e9a5ff;
  --accent-deep:   #6c0a93;
  --grad:          linear-gradient(120deg, #e9a5ff 0%, #c851f0 38%, #9c12ca 100%);
  --grad-soft:     linear-gradient(120deg, #c851f0, #9c12ca);

  --accent-dim:    color-mix(in oklab, var(--accent) 12%, transparent);
  --accent-border: color-mix(in oklab, var(--accent) 30%, transparent);
  --accent-glow:   color-mix(in oklab, var(--accent) 45%, transparent);

  /* near-black, slightly cool-purple toned */
  --bg:        #060509;
  --bg-1:      #0a0810;
  --bg-2:      #0e0b16;
  --surface:   rgba(255,255,255,.025);
  --surface-2: rgba(255,255,255,.045);
  --line:      rgba(255,255,255,.07);
  --line-2:    rgba(255,255,255,.12);

  --text:      #f6f5f8;
  --text-2:    rgba(246,245,248,.62);
  --text-3:    rgba(246,245,248,.40);
  --text-4:    rgba(246,245,248,.26);

  --pos:       #36e07f; /* profit green */
  --pos-dim:   rgba(54,224,127,.12);
  --pos-border:rgba(54,224,127,.26);

  --font-display: 'Clash Display', 'Satoshi', system-ui, sans-serif;
  --font: 'Satoshi', system-ui, -apple-system, sans-serif;

  --nav-h: 74px;
  --maxw: 1200px;

  --r-sm: .625rem;
  --r-md: 1rem;
  --r-lg: 1.5rem;
  --r-xl: 2rem;
  --r-2xl: 2.75rem;

  --ease: cubic-bezier(.22,1,.36,1);
  --ease-spring: cubic-bezier(.34,1.4,.5,1);

  --sh-sm: 0 1px 2px rgba(0,0,0,.4);
  --sh-md: 0 8px 30px rgba(0,0,0,.45);
  --sh-lg: 0 30px 80px -20px rgba(0,0,0,.7);
  --sh-glow: 0 20px 70px -18px var(--accent-glow);
}

/* ─── 2. RESET ──────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }
body {
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  font-weight:400;
  letter-spacing:-.011em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg,video { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
::selection { background:color-mix(in oklab, var(--accent) 40%, transparent); color:#fff; }

/* ─── 3. PAGE BACKDROP ──────────────────────────────────────── */
.bg-field {
  position:fixed; inset:0; z-index:-2; pointer-events:none; overflow:hidden;
  background:
    radial-gradient(1200px 700px at 50% -10%, color-mix(in oklab, var(--accent) 18%, transparent), transparent 60%),
    var(--bg);
}
.bg-grid {
  position:fixed; inset:0; z-index:-1; pointer-events:none;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 90% 60% at 50% 0%, #000 0%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 90% 60% at 50% 0%, #000 0%, transparent 70%);
}

/* ─── 4. TYPE ───────────────────────────────────────────────── */
.display {
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(2.7rem,6.4vw,5.6rem);
  line-height:.98;
  letter-spacing:-.03em;
}
.h-xl {
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(2.1rem,4.4vw,3.6rem);
  line-height:1.02;
  letter-spacing:-.028em;
}
.h-lg {
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(1.7rem,3vw,2.5rem);
  line-height:1.08;
  letter-spacing:-.02em;
}
.h-md {
  font-family:var(--font-display);
  font-weight:600;
  font-size:clamp(1.35rem,2vw,1.7rem);
  line-height:1.15;
  letter-spacing:-.015em;
}
.lede {
  font-size:clamp(1.02rem,1.25vw,1.18rem);
  color:var(--text-2);
  line-height:1.62;
  font-weight:400;
}
.body { color:var(--text-2); }
.muted { color:var(--text-3); }
.accent { color:var(--accent-hi); }

.grad-text {
  background:var(--grad);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}

/* Clash Display has a narrow space glyph; restore natural word gap */
.display, .h-xl, .h-lg, .h-md, .hero__title,
.bento .cell .k, .hero__stat b, .product__name, .product__price .to,
.residual b, .reward .amt, .reward .prize, .voucher .amt, .voucher .vc b,
.pin-card .lname, .indication__win b, .tbl tr.hot strong {
  word-spacing:.14em;
}

.eyebrow {
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--font);
  font-size:.74rem; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--accent-hi);
}
.eyebrow::before {
  content:''; width:18px; height:1px;
  background:linear-gradient(90deg, transparent, var(--accent));
}
.eyebrow--center::before { display:none; }

.footnote { font-size:.78rem; color:var(--text-4); line-height:1.6; }

/* ─── 5. LAYOUT ─────────────────────────────────────────────── */
.container { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 1.5rem; }
.section { position:relative; padding:clamp(4.5rem,9vw,8rem) 0; }
.section--tight { padding:clamp(3rem,6vw,5rem) 0; }
.center { text-align:center; }
.sec-head { max-width:680px; margin:0 0 clamp(2.5rem,5vw,3.75rem); display:flex; flex-direction:column; gap:1.1rem; }
.sec-head.center { margin-left:auto; margin-right:auto; align-items:center; }

/* ─── 6. CARD / PANEL ───────────────────────────────────────── */
.panel {
  position:relative;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
}
.panel--hair { background:var(--bg-1); }

/* gradient hairline border helper */
.edge-glow {
  position:relative;
}
.edge-glow::before {
  content:''; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:linear-gradient(140deg, var(--accent-border), transparent 45%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  pointer-events:none;
}

/* ─── 7. BUTTONS ────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  font-family:var(--font); font-size:.95rem; font-weight:600; line-height:1;
  padding:.92rem 1.5rem; border-radius:999px;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .25s, border-color .25s, color .25s;
  white-space:nowrap; position:relative; isolation:isolate;
}
.btn svg { transition:transform .35s var(--ease); }
.btn:active { transform:translateY(0) scale(.985); }

.btn--primary {
  color:#fff;
  background:var(--grad-soft);
  box-shadow:0 10px 30px -8px var(--accent-glow), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn--primary::after {
  content:''; position:absolute; inset:0; border-radius:inherit; z-index:-1;
  background:linear-gradient(120deg, var(--accent-hi), var(--accent));
  opacity:0; transition:opacity .3s;
}
.btn--primary:hover { transform:translateY(-2px); box-shadow:0 16px 40px -8px var(--accent-glow), inset 0 1px 0 rgba(255,255,255,.3); }
.btn--primary:hover::after { opacity:1; }
.btn--primary:hover svg { transform:translateX(3px); }

.btn--ghost {
  color:var(--text);
  background:var(--surface-2);
  border:1px solid var(--line-2);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
}
.btn--ghost:hover { transform:translateY(-2px); border-color:var(--accent-border); background:var(--accent-dim); color:#fff; }

.btn--lg { padding:1.05rem 1.9rem; font-size:1.02rem; }
.btn--sm { padding:.66rem 1.1rem; font-size:.86rem; }

/* ─── 8. PILL / CHIP ────────────────────────────────────────── */
.tagline-pill {
  display:inline-flex; align-items:center; gap:.6rem;
  font-size:.8rem; font-weight:500; letter-spacing:.01em;
  padding:.5rem .95rem .5rem .7rem; border-radius:999px;
  color:var(--text); width:fit-content;
  background:var(--surface-2); border:1px solid var(--line-2);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
}
.tagline-pill .dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 0 4px color-mix(in oklab, var(--accent) 25%, transparent);
}
.tagline-pill .live {
  position:relative; display:inline-flex; width:8px; height:8px;
}
.tagline-pill .live::before, .tagline-pill .live::after {
  content:''; position:absolute; inset:0; border-radius:50%; background:var(--accent);
}
.tagline-pill .live::after { animation:ping 1.8s var(--ease) infinite; }
@keyframes ping { 0%{ transform:scale(1); opacity:.7;} 80%,100%{ transform:scale(2.6); opacity:0;} }

.chip {
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.5rem 1rem; border-radius:999px;
  font-size:.85rem; color:var(--text-2);
  background:var(--surface); border:1px solid var(--line);
  transition:border-color .25s, color .25s, background .25s, transform .25s;
}
.chip:hover { color:#fff; border-color:var(--accent-border); background:var(--accent-dim); transform:translateY(-2px); }

/* ─── 9. NAVBAR ─────────────────────────────────────────────── */
.nav {
  position:fixed;
  top:1rem; left:50%; transform:translateX(-50%);
  right:auto; width:calc(100% - 2rem); max-width:1200px;
  z-index:1000;
  display:flex; align-items:center;
  height:auto;
  padding:.6rem 1rem;
  border-radius:var(--r-xl);
  background:color-mix(in oklab, var(--bg-1) 55%, transparent);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border:1px solid var(--line-2);
  box-shadow:0 8px 40px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.07);
  transition:background .35s var(--ease), box-shadow .35s;
}
.nav.scrolled {
  background:color-mix(in oklab, var(--bg-1) 75%, transparent);
  box-shadow:0 12px 50px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.09), 0 0 0 1px var(--accent-border);
}
.nav__inner { width:100%; padding:0 .5rem; display:flex; align-items:center; gap:1.25rem; }
.nav__logo { flex-shrink:0; display:flex; align-items:center; }
.nav__logo img { height:26px; width:auto; }
.nav__links { display:none; align-items:center; gap:.15rem; margin:0 auto; }
.nav__links a {
  font-size:.92rem; font-weight:500; color:var(--text-2);
  padding:.5rem .95rem; border-radius:999px; transition:color .2s, background .2s;
}
.nav__links a:hover { color:#fff; background:var(--surface-2); }
.nav__actions { display:flex; align-items:center; gap:.7rem; flex-shrink:0; }
.nav__pdf { display:none; }

.burger { display:flex; flex-direction:column; gap:5px; padding:.4rem; }
.burger span { width:22px; height:2px; background:var(--text); border-radius:2px; transition:transform .3s var(--ease), opacity .2s; }
.nav.menu-open .burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav.menu-open .burger span:nth-child(2){ opacity:0; }
.nav.menu-open .burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

.nav__mobile {
  position:fixed; top:calc(var(--nav-h) + 12px); left:50%; transform:translateX(-50%) translateY(-8px);
    width:calc(100% - 2rem); max-width:1200px;
    left:8px; right:8px; transform:none;
  z-index:998;
  display:flex; flex-direction:column; gap:.2rem; padding:1.25rem 1.5rem 1.75rem;
  background:color-mix(in oklab, var(--bg-1) 90%, transparent);
  backdrop-filter:blur(24px) saturate(180%); -webkit-backdrop-filter:blur(24px) saturate(180%);
  border:1px solid var(--line-2); border-radius:var(--r-xl);
  box-shadow:0 16px 50px rgba(0,0,0,.5);
  opacity:0; pointer-events:none;
  transition:opacity .35s var(--ease), transform .35s var(--ease);
}
.nav__mobile.open { opacity:1; transform:translateY(0); pointer-events:auto; left:8px; right:8px; }
.nav__mobile a { font-size:1rem; color:var(--text-2); padding:.8rem .25rem; border-bottom:1px solid var(--line); }
.nav__mobile .btn { margin-top:1rem; }

/* ─── 10. MARQUEE ───────────────────────────────────────────── */
.marquee {
  position:relative; overflow:hidden; padding:1.1rem 0;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:var(--bg-1);
}
.marquee::before, .marquee::after {
  content:''; position:absolute; top:0; bottom:0; width:140px; z-index:2; pointer-events:none;
}
.marquee::before { left:0; background:linear-gradient(90deg, var(--bg-1), transparent); }
.marquee::after { right:0; background:linear-gradient(270deg, var(--bg-1), transparent); }
.marquee__track { display:flex; width:max-content; animation:scroll-x 42s linear infinite; }
.marquee:hover .marquee__track { animation-play-state:paused; }
@keyframes scroll-x { to { transform:translateX(-50%); } }
.marquee__group { display:flex; align-items:center; }
.marquee__item {
  display:inline-flex; align-items:center; gap:.7rem; padding:0 2.2rem;
  font-size:.92rem; color:var(--text-2); white-space:nowrap; font-weight:500;
}
.marquee__item .star { color:var(--accent); font-size:.7rem; }

/* ─── 11. FOOTER ────────────────────────────────────────────── */
.footer { border-top:1px solid var(--line); background:var(--bg-1); padding:clamp(3rem,5vw,4.5rem) 0 2.5rem; }
.footer__top { display:grid; grid-template-columns:1fr; gap:2.5rem; padding-bottom:2.5rem; border-bottom:1px solid var(--line); }
.footer__brand { display:flex; flex-direction:column; align-items:flex-start; gap:1rem; max-width:320px; }
.footer__brand img { height:26px; width:auto; }
.footer__brand p { color:var(--text-3); font-size:.92rem; }
.footer__cols { display:grid; grid-template-columns:repeat(2,1fr); gap:2rem; }
.footer__col h4 { font-size:.76rem; letter-spacing:.14em; text-transform:uppercase; color:var(--text-4); margin-bottom:1rem; font-weight:700; }
.footer__col a { display:block; color:var(--text-2); font-size:.92rem; padding:.32rem 0; transition:color .2s; }
.footer__col a:hover { color:var(--accent-hi); }
.footer__bottom { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:1rem; padding-top:2rem; }
.footer__bottom span { color:var(--text-4); font-size:.82rem; }

/* ─── 12. REVEAL (CSS transitions, guarded by html.js) ──────── */
/* Content is visible by default; only hidden once JS confirms it
   can reveal it — so a JS failure never leaves a blank page.      */
html.js [data-reveal]:not([data-children]) {
  opacity:0; transform:translateY(26px);
  transition:opacity .85s var(--ease), transform .85s var(--ease);
}
html.js [data-reveal]:not([data-children]).in { opacity:1; transform:none; }
html.js .rv-child {
  opacity:0; transform:translateY(24px);
  transition:opacity .75s var(--ease), transform .75s var(--ease);
}
html.js [data-reveal].in .rv-child { opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  html.js [data-reveal], html.js .rv-child { opacity:1 !important; transform:none !important; transition:none !important; }
}

/* ─── 13. RESPONSIVE ────────────────────────────────────────── */
@media (min-width:560px){
  .footer__top { grid-template-columns:1.4fr 1fr; }
  .footer__cols { grid-template-columns:repeat(3,1fr); }
}
@media (min-width:900px){
  .nav__links { display:flex; }
  .burger { display:none; }
}
@media (min-width:1040px){
  .nav__pdf { display:inline-flex; }
}

/* Mobile navbar tweaks: make the nav more compact and better fit small screens */
@media (max-width:767px){
  /* Forçar navbar a respeitar a largura do viewport em mobile */
  .nav {
    /* give lateral spacing on mobile so nav doesn't touch screen edges */
    left:12px !important; right:12px !important; transform:none !important; width:auto !important; max-width:calc(100% - 24px) !important; top:.6rem;
    padding:.35rem .6rem !important; border-radius:60px; box-sizing:border-box; margin:0 !important;
  }
  .nav__inner { padding:0 .5rem; display:flex; align-items:center; justify-content:space-between; }
  /* logo left, menu/actions right — make logo container circular */
  .nav__logo { flex:0 0 auto; display:flex; align-items:center; justify-content:flex-start; padding:.22rem; border-radius:100%; }
  .nav__logo img { height:22px; width:auto; display:block; }
  .nav__actions { margin-left:auto; display:flex; align-items:center; gap:.5rem; }
  .nav__actions .btn--primary { padding:.55rem .9rem; font-size:.9rem; }
  /* Esconder o botão "Acessar" na navbar em mobile */
  .nav__actions > a.btn--primary { display:none; }
  /* reduzir largura do "sidebar" mobile e garantir que respeite a viewport */
  .nav__mobile { top: calc(var(--nav-h) + 8px); left:8px; right:8px; width:auto; max-width:calc(100% - 16px); transform:none; box-sizing:border-box; }
  /* tornar o botão do burger circular e com fundo discreto */
  .burger { border-radius:100%; padding:.5rem; background:var(--surface-2); }
  /* garantir que não haja overflow horizontal causado pela navbar */
  html, body { overflow-x:hidden; }
}
