:root{
  --bg:        #0a0a0c;
  --bg-2:      #111114;
  --panel:     #15151a;
  --line:      #24242c;
  --line-2:    #34343e;
  --ink:       #f4f4f5;
  --ink-dim:   #c8c8d0;
  --ink-mute:  #7e7e8a;
  --pink:      #2dd4ff;
  --pink-2:    #7eeaff;
  --rose:      #0aa8d4;
  --orange:    #ff7a18;
  --orange-2:  #ffb547;
  --ember:     #ff3a08;
  --ember-2:   #ff6a14;
  --lava:      #ff4a08;
  --gold:      #ffcf5a;
  --gold-2:    #ffe89a;
  --gold-deep: #b8801f;
  --green:     #6dd66d;
}
*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  /* âncoras (#vantagens etc.) não ficam atrás do nav sticky */
  scroll-padding-top:88px;
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  .hero-scroll-hint{animation:none;}
}
html,body{margin:0;padding:0}
body{
  background: var(--bg);
  color:var(--ink);
  font-family:'Fredoka', system-ui, sans-serif;
  font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  position:relative;
}
/* Landing: body opaco cobre z-index negativo do wallpaper — deixar transparente */
body.index-landing{
  background:transparent;
  min-height:100vh;
}
/* Fundo: <img> cobre WebViews que não pintam background-image no div (Electron / Chromium antigo) */
.site-bg{
  position:fixed;
  inset:0;
  z-index:0;
  background-color:#0a0612;
  pointer-events:none;
  overflow:hidden;
}
.site-bg__img{
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
  /* fallback se o src falhar */
  min-height:100vh;
  min-width:100%;
}
/* Fallback CSS quando a imagem não carrega */
.site-bg{
  background-image:url("../landing-design/site-bg.png");
  background-position:center center;
  background-size:cover;
  background-repeat:no-repeat;
}
/* Véu semi-transparente: wallpaper aparece por baixo; texto e cartões ficam nítidos (sem opacity no pai) */
.site-content-layer{
  position:relative;
  z-index:1;
  min-height:100vh;
  background:rgba(8, 6, 14, 0.90);
  overflow-x:hidden;
}
/* WebView antigo: garantir área do wallpaper (evita img em altura 0 / max-width global em <img>) */
html.dd-launcher-webview .site-bg{
  width:100%;
  min-height:100vh;
  min-height:-webkit-fill-available;
}
html.dd-launcher-webview .site-bg__img{
  max-width:none;
  width:100%;
  min-height:100vh;
  min-height:-webkit-fill-available;
}
/* removido body::before antigo — wallpaper em .site-bg */
::selection{background:var(--pink);color:#062a36}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
img{display:block;max-width:100%}
.wrap{max-width:1320px;margin:0 auto;padding:0 36px}
.body-font{font-family:'Inter', sans-serif}

/* NAV — espaçamento com margin (sem gap: compatível com WebView / launcher antigo) */
.nav{position:sticky;top:0;z-index:40;backdrop-filter:blur(14px);background:rgba(10,10,12,.85);border-bottom:1px solid var(--line)}
.nav-row{display:flex;align-items:center;justify-content:space-between;height:88px;width:100%}
.nav-row > * + *{margin-left:16px}
.brand{display:flex;align-items:center;flex-shrink:0}
.brand > * + *{margin-left:10px}
.brand img{height:60px;width:auto;filter:drop-shadow(0 4px 8px rgba(255,90,0,.5))}
@media (min-width:561px){
  body.index-landing:not(.index-landing--compact-nav) .brand img{
    height:70px;
    margin-left:-14px;
  }
  body.index-landing:not(.index-landing--compact-nav) .nav-links{
    transform:translateX(-12px);
  }
}
.nav-links{display:flex;flex:1;justify-content:center;min-width:0;color:var(--ink-dim);font-size:15px;font-weight:500}
.nav-links > a + a{margin-left:28px}
.nav-links a:hover{color:var(--gold-2)}
.nav-cta{display:flex;align-items:center;flex-shrink:0;margin-left:auto}
.nav-cta > * + *{margin-left:12px}
.pill{border:1px solid var(--line-2);background:rgba(30,30,36,.6);color:var(--ink);padding:8px 14px;border-radius:999px;font-size:13px;font-weight:500;cursor:pointer;display:inline-flex;align-items:center}
.pill > * + *{margin-left:8px}
.pill .dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--green)}

/* Launcher / Chromium antigo (classe via PHP pelo User-Agent): barra mais baixa sem depender do inject da app */
html.dd-launcher-webview{scroll-padding-top:92px}
body.index-landing.index-landing--compact-nav .nav{
  padding:8px 0;
  box-sizing:border-box;
}
body.index-landing.index-landing--compact-nav .nav-row{
  /* Três colunas iguais: links ficam no centro real da barra (flex+flex:1 desviava à direita: logo > largura que Entrar) */
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  column-gap:16px;
  height:76px;
}
body.index-landing.index-landing--compact-nav .nav-row > * + *{
  margin-left:0;
}
body.index-landing.index-landing--compact-nav .brand{
  align-items:center;
  justify-self:start;
  grid-column:1;
}
body.index-landing.index-landing--compact-nav .brand img{
  height:100px;
  width:auto;
  max-height:100px;
  margin-left: -24px;
}
body.index-landing.index-landing--compact-nav .nav-links{
  flex:unset;
  justify-self:center;
  grid-column:2;
  font-size:16px;
  align-items:center;
}
body.index-landing.index-landing--compact-nav .nav-links a{
  display:inline-flex;
  align-items:center;
  line-height:1.25;
}
body.index-landing.index-landing--compact-nav .nav-cta{
  align-items:center;
  justify-self:end;
  margin-left:0;
  grid-column:3;
}
body.index-landing.index-landing--compact-nav .nav-links > a + a{
  margin-left:16px;
}
body.index-landing.index-landing--compact-nav .nav-cta .btn-ghost{
  padding:9px 18px;
  font-size:15px;
  border-radius:14px;
  box-shadow:0 3px 0 0 #0d0d12;
}
/* Hero: texto um pouco maior no launcher (viewport/WebView pequeno encolhe a sensação de leitura) */
body.index-landing.index-landing--compact-nav .hero p.lead{
  font-size:19px;
  line-height:1.62;
}
body.index-landing.index-landing--compact-nav .hero-eye{
  font-size:13px;
  padding:7px 14px;
}
body.index-landing.index-landing--compact-nav .hero h1{
  font-size:clamp(46px, 7.5vw, 96px);
}
body.index-landing.index-landing--compact-nav .hero-meta .val{
  font-size:18px;
}
body.index-landing.index-landing--compact-nav .hero-meta .lbl{
  font-size:13px;
  line-height:1.15;
}
body.index-landing.index-landing--compact-nav #vantagens,
body.index-landing.index-landing--compact-nav #modos,
body.index-landing.index-landing--compact-nav #raras{
  scroll-margin-top:92px;
}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:14px;font-family:'Fredoka', sans-serif;font-weight:700;font-size:15px;cursor:pointer;border:none;position:relative;transition:transform .18s ease, filter .15s ease, box-shadow .18s ease;text-shadow:0 1px 0 rgba(0,0,0,.18)}
/* Texto solto + .arrow: o seletor > * + * não cria margem (só há um elemento filho) */
.btn > * + *{margin-left:10px}
.btn .arrow{margin-left:12px;flex-shrink:0}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(2px)}
.btn-play{
  color:#fff;
  background:linear-gradient(180deg, #ffb547 0%, #ff7a18 50%, #e84800 100%);
  box-shadow:
    0 0 0 2px #6e2200, 0 0 0 4px #ffd98a, 0 0 0 5px #6e2200,
    0 8px 0 0 #6e2200, 0 14px 24px -8px rgba(255,90,0,.7),
    inset 0 2px 0 rgba(255,255,255,.45), inset 0 -8px 12px rgba(180,40,0,.4);
  text-shadow:0 2px 0 rgba(120,30,0,.7), 0 0 12px rgba(255,210,120,.6);
  letter-spacing:.04em;text-transform:uppercase;
}
.btn-play:hover{
  filter:brightness(1.06) saturate(1.1);
  transform:translateY(-3px);
  color:#fff;
}
.btn-play:active{transform:translateY(4px);box-shadow:0 0 0 2px #6e2200, 0 0 0 4px #ffd98a, 0 0 0 5px #6e2200, 0 4px 0 0 #6e2200, 0 6px 12px -4px rgba(255,90,0,.7), inset 0 2px 0 rgba(255,255,255,.45), inset 0 -8px 12px rgba(180,40,0,.4)}
.btn-play .arrow{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:#fff5ea;color:#e84800;font-size:10px;box-shadow:inset 0 -2px 0 rgba(120,30,0,.2)}
.btn-pink{color:#3a1a00;background:linear-gradient(180deg, #ffe08a 0%, #ffb547 50%, #e88a14 100%);box-shadow:0 0 0 2px #6e3a00, 0 0 0 4px #fff1bf, 0 0 0 5px #6e3a00, 0 6px 0 0 #6e3a00, 0 12px 20px -8px rgba(232,138,20,.55), inset 0 2px 0 rgba(255,255,255,.55);text-shadow:0 2px 0 rgba(255,241,191,.5)}
.btn-pink:hover{
  filter:brightness(1.05);
  transform:translateY(-3px);
  color:#3a1a00;
}
.btn-pink:active{transform:translateY(3px);box-shadow:0 0 0 2px #6e3a00, 0 0 0 4px #fff1bf, 0 0 0 5px #6e3a00, 0 3px 0 0 #6e3a00, 0 6px 12px -4px rgba(232,138,20,.55), inset 0 2px 0 rgba(255,255,255,.5)}
.btn-ghost{color:var(--gold-2);background:rgba(30,30,36,.6);border:1px solid var(--line-2);box-shadow:0 4px 0 0 #0d0d12;padding:12px 20px;font-weight:600;transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease, filter .15s ease}
.btn-ghost:hover{
  color:var(--gold-2);
  transform:translateY(-2px);
  border-color:rgba(255,207,90,.45);
  filter:brightness(1.08);
  box-shadow:0 6px 0 0 #0d0d12;
}
.btn-ghost:active{transform:translateY(3px);box-shadow:0 1px 0 0 #0d0d12}
.btn-lg{padding:18px 32px;font-size:18px;border-radius:16px}
.btn-xl{padding:22px 40px;font-size:22px;border-radius:18px}

/* HERO */
.hero{position:relative;padding:64px 0 120px;overflow:visible}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(circle at 18% 22%, rgba(255,207,90,.7) 0 2px, transparent 3px),
    radial-gradient(circle at 80% 12%, rgba(255,180,210,.7) 0 1.5px, transparent 2.5px),
    radial-gradient(circle at 30% 80%, rgba(255,143,192,.6) 0 1.5px, transparent 2.5px),
    radial-gradient(circle at 92% 70%, rgba(255,232,154,.7) 0 2px, transparent 3px),
    radial-gradient(circle at 50% 8%, rgba(255,255,255,.8) 0 1px, transparent 2px),
    radial-gradient(circle at 8% 60%, rgba(255,255,255,.5) 0 1px, transparent 2px),
    radial-gradient(circle at 65% 88%, rgba(255,207,90,.5) 0 1.5px, transparent 2.5px);
}
.hero-inner{
  position:relative;
  display:grid;
  grid-template-columns:minmax(320px, 1fr) minmax(0, 1.12fr);
  align-items:center;
  justify-items:start;
}
/* Um só espaçamento entre colunas (evita soma estranha em engines antigos) */
.hero-inner > *:first-child{
  margin-right:64px;
  margin-left:0;
  min-width:0;
  max-width:100%;
  justify-self:start;
  display:block;
  text-align:left;
}
.hero-inner > *:last-child{
  margin-left:0;
  min-width:0;
  width:100%;
  justify-self:stretch;
}
/* Faixa de meta: até ~520px de “respiro” para os três blocos, sem estourar a coluna */
.hero-inner > *:first-child .hero-meta{
  width:100%;
  max-width:520px;
}
.hero-eye{display:inline-flex;align-items:center;padding:8px 16px;background:linear-gradient(180deg, rgba(255,207,90,.18), rgba(255,143,192,.12));border:1px solid var(--gold);border-radius:999px;color:var(--gold-2);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.12em}
.hero-eye::before{content:"";display:inline-block;width:8px;height:8px;margin-right:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold)}
.hero h1{
  font-family:'Luckiest Guy', cursive;font-weight:400;
  font-size:clamp(48px, 6.6vw, 96px);line-height:1.02;letter-spacing:-.01em;
  margin:18px 0 22px;color:#fff;
  text-shadow:0 2px 0 #1a1a22, 0 4px 0 #0d0d12, 0 6px 0 #050507, 0 12px 24px rgba(0,0,0,.6);
}
.hero h1 .pink{color:var(--pink);text-shadow:0 2px 0 #0d6a85, 0 4px 0 #074a5c, 0 6px 0 #042a36, 0 12px 24px rgba(45,212,255,.45)}
.hero h1 .gold{
  background:linear-gradient(180deg, #ffd9a8 0%, #ff8a3d 45%, #ff5a00 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  text-shadow:none;
  filter:drop-shadow(0 3px 0 #8a2700) drop-shadow(0 5px 0 #5a1a00) drop-shadow(0 10px 18px rgba(255,90,0,.5));
}
.hero p.lead{font-family:'Inter', sans-serif;color:var(--ink-dim);font-size:18px;max-width:520px;margin:0 auto 32px 0;line-height:1.6}
.hero-cta{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;width:100%}
.hero-cta > *{margin-right:16px;margin-bottom:16px}
.hero-cta > *:last-child{margin-right:0}
.hero-meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  margin-top:40px;
  line-height:1.2;
  padding-bottom:4px;
  overflow:visible;
}
.hero-meta > *{
  display:flex;
  align-items:center;
  flex:0 0 auto;
  max-width:100%;
  margin-right:32px;
  margin-bottom:16px;
}
.hero-meta > *:last-child{margin-right:0}
.hero-meta .item > .ico{
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  margin-right:16px;
}
.hero-meta .ico{
  position:relative;
  width:40px;
  height:40px;
  border-radius:10px;
  background:linear-gradient(180deg, #5a1a00, #2a0c06);
  box-shadow:inset 0 -3px 0 rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.08), 0 0 0 1px rgba(255,207,90,.35);
  overflow:visible;
}
.hero-meta .ico img{
  position:absolute;
  top:50%;
  left:50%;
  width:26px;
  height:26px;
  margin:-13px 0 0 -13px;
  object-fit:contain;
  filter:drop-shadow(0 1px 0 rgba(0,0,0,.4));
}
.hero-meta .item > div{
  display:block;
  min-height:40px;
  min-width:0;
  max-width:none;
  margin-top:0;
  overflow:visible;
}
.hero-meta .val{font-family:'Luckiest Guy', cursive;font-size:17px;line-height:1.05;color:#fff;letter-spacing:-.01em;margin:4px 0 0;padding:0;white-space:normal}
.hero-meta .lbl{font-size:12px;line-height:1.15;color:var(--ink-mute);font-weight:500;font-family:'Inter', sans-serif;margin:2px 0 0;padding:0}

/* Indicador “há mais abaixo” (primeiro bloco / hero) — círculo fixo */
.hero-scroll-hint{
  display:flex;
  align-items:center;
  justify-content:center;
  margin:40px auto 0;
  width:44px;
  height:44px;
  padding:0;
  box-sizing:border-box;
  color:var(--gold-2);
  text-decoration:none;
  font-size:22px;
  line-height:1;
  opacity:0.9;
  border:1px solid rgba(255,207,90,.35);
  border-radius:50%;
  background:rgba(20,18,28,.55);
  transition:color .2s ease, opacity .2s ease, border-color .2s ease;
  animation:heroScrollHintPulse 2s ease-in-out infinite;
}
.hero-scroll-hint:hover{
  color:var(--gold);
  opacity:1;
  border-color:rgba(255,207,90,.55);
}
.hero-scroll-hint__icon{display:block;font-size:16px;line-height:1}
@keyframes heroScrollHintPulse{
  0%, 100%{opacity:0.82}
  50%{opacity:1}
}

.hero-art{position:relative;border-radius:24px;overflow:visible;aspect-ratio:16/9;background:#000;box-shadow:0 0 0 1px rgba(255,207,90,.4), 0 0 0 4px #15151a, 0 0 0 5px #2a2a32, 0 30px 60px -20px rgba(0,0,0,.85), 0 0 80px rgba(255,90,18,.18)}
.hero-art::after{content:"";position:absolute;inset:0;border-radius:18px;pointer-events:none;box-shadow:inset 0 0 0 2px rgba(255,255,255,.15)}
.hero-art img{width:100%;height:100%;object-fit:cover;border-radius:18px}
.ribbon{position:absolute;top:-14px;left:24px;background:linear-gradient(180deg, #ff7a18 0%, #c93a00 100%);color:#fff5ea;font-family:'Luckiest Guy';font-size:18px;letter-spacing:.04em;padding:8px 18px;border-radius:8px;box-shadow:0 0 0 3px #fff5ea, 0 0 0 5px #6e2200, 0 8px 16px -4px rgba(0,0,0,.5);transform:rotate(-4deg);z-index:3;text-shadow:0 2px 0 #6e2200}
.badge-new{position:absolute;top:-22px;right:-22px;width:96px;height:96px;background:radial-gradient(circle, var(--gold-2) 0%, var(--gold) 60%, var(--gold-deep) 100%);color:#5a3a00;font-family:'Luckiest Guy';font-size:18px;display:grid;place-items:center;border-radius:50%;transform:rotate(12deg);box-shadow:0 0 0 3px #fff5ea, 0 0 0 5px #5a3a00, 0 12px 24px -8px rgba(0,0,0,.6);z-index:3;text-align:center;line-height:1}
.badge-new::before{content:"";position:absolute;inset:8px;border:2px dashed #5a3a00;border-radius:50%;opacity:.4}

/* STRIP */
.strip{background:linear-gradient(180deg, rgba(255,207,90,.04), rgba(255,255,255,.02));border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden}
.strip-track{display:flex;padding:18px 0;font-family:'Luckiest Guy';font-size:18px;letter-spacing:.04em;color:var(--gold-2);white-space:nowrap;animation:slide 40s linear infinite}
.strip-track > span{margin-right:48px}
.strip-track span{display:inline-flex;align-items:center}
.strip-track span::after{content:"✦";margin-left:18px;color:var(--pink);font-size:14px}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* Sections */
.section{padding:110px 0;position:relative}
/* Faixas após hero: strip já é a 1ª. Seguintes alternam — 2º e 4º = gradiente (#vantagens, #raras); 3º e 5º = véu opacity (#modos, .cta) */
#vantagens,
#raras{
  background:radial-gradient(ellipse 60% 80% at 50% 0%, rgba(45,212,255,.05), transparent 60%), linear-gradient(180deg, #0d0d12 0%, #08080a 100%);
  border-bottom:1px solid var(--line);
}
#modos,
.cta{
  background:linear-gradient(180deg, rgba(10,10,14,.58) 0%, rgba(6,6,10,.42) 100%);
}
#modos{
  border-bottom:1px solid var(--line);
}
#vantagens, #modos, .section-armas{padding-top:64px}
.section-armas .section-head .hero-eye,
#vantagens .section-head .hero-eye,
#modos .section-head .hero-eye{margin-bottom:50px}
.section-head{text-align:center;max-width:720px;margin:0 auto 64px}
.section-head h2{font-family:'Luckiest Guy';font-weight:400;font-size:clamp(38px, 5vw, 64px);line-height:1.08;margin:14px 0 18px;color:#fff;text-shadow:0 2px 0 #1a1a22, 0 4px 0 #0d0d12, 0 6px 0 #050507, 0 10px 20px rgba(0,0,0,.6);letter-spacing:.02em}
.section-head h2 .pink{color:var(--pink);text-shadow:0 2px 0 #0d6a85, 0 4px 0 #074a5c, 0 6px 0 #042a36, 0 10px 20px rgba(45,212,255,.35)}
.section-head .sub{font-family:'Inter', sans-serif;color:var(--ink-dim);font-size:17px;line-height:1.6}

/* Advantage cards */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);margin:-11px}
.feat-grid > *{margin:11px}
.card{position:relative;border-radius:20px;padding:30px 26px 26px;background:linear-gradient(180deg, #15151a 0%, #0e0e12 100%);box-shadow:0 0 0 1px var(--line-2), 0 18px 30px -14px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.04);overflow:hidden;transition:transform .25s ease}
.card:hover{transform:translateY(-4px)}
.card::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 90% 0%, rgba(255,207,90,.06), transparent 50%), radial-gradient(circle at 0% 100%, rgba(45,212,255,.04), transparent 50%)}
.card .corner{position:absolute;width:14px;height:14px;background:var(--gold);opacity:.5;box-shadow:0 0 0 1px #0d0d12}
.card .corner.tl{top:6px;left:6px;clip-path:polygon(0 0,100% 0,0 100%)}
.card .corner.tr{top:6px;right:6px;clip-path:polygon(0 0,100% 0,100% 100%)}
.card .corner.bl{bottom:6px;left:6px;clip-path:polygon(0 0,0 100%,100% 100%)}
.card .corner.br{bottom:6px;right:6px;clip-path:polygon(100% 0,100% 100%,0 100%)}
.card-icon{width:80px;height:80px;border-radius:18px;background:linear-gradient(160deg, #2a0c06 0%, #1a0604 100%);box-shadow:0 0 0 3px #5a3a00, 0 0 0 4px rgba(255,207,90,.4), 0 8px 16px -4px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.06);display:grid;place-items:center;margin-bottom:18px;position:relative;overflow:hidden}
.card-icon img{width:52px;height:52px;object-fit:contain;filter:drop-shadow(0 2px 0 rgba(0,0,0,.5))}
.card h3{font-family:'Luckiest Guy';font-weight:400;font-size:24px;letter-spacing:.02em;margin:0 0 10px;color:var(--gold-2);text-shadow:0 2px 0 #0d0d12, 0 0 16px rgba(255,207,90,.2)}
.card p{font-family:'Inter', sans-serif;color:var(--ink-dim);font-size:14.5px;line-height:1.6;margin:0}
.card .num{position:absolute;top:18px;right:22px;font-family:'Luckiest Guy';color:rgba(255,207,90,.25);font-size:42px}

/* Modes — fundo da faixa vem de #modos (véu neste ciclo); só layout dos cards abaixo */
/* Flex: mesma altura nos três cards da linha (float não estica) */
.modes-grid{
  display:flex;
  flex-wrap:wrap;
  align-items:stretch;
  margin:0;
  padding:0;
}
.modes-grid > .mode{
  float:none;
  width:32%;
  margin-right:2%;
  margin-bottom:0;
  box-sizing:border-box;
}
.modes-grid > .mode:nth-child(3n){
  margin-right:0;
}
/* Desktop: altura mínima igual para os três; align-self reforça stretch em WebViews antigos */
@media (min-width: 981px){
  .modes-grid > .mode{
    min-height:528px;
    align-self: stretch;
  }
}
.mode{display:flex;flex-direction:column;width:100%;min-height:0;position:relative;border-radius:20px;overflow:hidden;background:linear-gradient(180deg, #15151a, #0e0e12);box-shadow:0 0 0 1px var(--line-2), 0 16px 28px -12px rgba(0,0,0,.7)}
/* min-height: engines sem aspect-ratio ainda mostram área da foto; foto em <img> funciona no launcher antigo */
.mode-thumb{
  flex-shrink:0;
  width:100%;
  min-height:200px;
  aspect-ratio:16/10;
  background:#1a1a22;
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--line-2);
  border-radius:19px 19px 0 0;
}
.mode-thumb--photo::before{display:none}
.mode-thumb:not(.mode-thumb--photo){
  background:radial-gradient(circle at 30% 30%, rgba(45,212,255,.08), transparent 60%), repeating-linear-gradient(135deg, #1c1c22 0 12px, #15151a 12px 24px);
  display:grid;
  place-items:center;
  color:rgba(244,244,245,.4);
  font-family:'Inter', sans-serif;
  font-size:12px;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.mode-thumb:not(.mode-thumb--photo)::before{content:"";position:absolute;inset:14px;border:2px dashed rgba(255,207,90,.3);border-radius:12px}
.mode-thumb-photo{
  position:absolute;
  top:-1px;
  left:-1px;
  width:calc(100% + 2px);
  height:calc(100% + 2px);
  max-width:none;
  object-fit:cover;
  object-position:center center;
  display:block;
  z-index:0;
}
.mode-thumb .tag{position:absolute;top:14px;left:14px;z-index:2;background:linear-gradient(180deg, #15151a, #0a0a0c);color:var(--gold-2);font-family:'Luckiest Guy';font-size:13px;letter-spacing:.04em;padding:6px 12px;border-radius:8px;box-shadow:0 0 0 1px var(--gold), 0 4px 10px rgba(0,0,0,.5);transform:rotate(-3deg)}
.mode-thumb .tag.gold{background:linear-gradient(180deg, var(--gold-2), var(--gold-deep));color:#1a1a22;box-shadow:0 0 0 1px #0d0d12, 0 4px 10px rgba(0,0,0,.5)}
.mode-body{
  flex:1 1 auto;
  display:flex;
  flex-direction:column;
  padding:14px 16px 15px;
  width:100%;
  box-sizing:border-box;
  position:relative;
  z-index:1;
  background:#14141a;
  min-height:0;
}
.mode h4{font-family:'Luckiest Guy';font-weight:400;margin:0;padding:0;font-size:21px;line-height:1.12;letter-spacing:.02em;color:var(--gold-2);text-shadow:0 2px 0 #0d0d12}
.mode p{font-family:'Inter';color:var(--ink-dim);font-size:13px;margin:6px 0 0;line-height:1.5}
.mode-meta{display:flex;flex-wrap:wrap;margin-top:auto;padding-top:10px}
.mode-meta .chip{margin-right:7px;margin-bottom:6px}
.mode-meta .chip:last-child{margin-right:0}
.chip{padding:4px 10px;border-radius:999px;background:rgba(30,30,36,.7);border:1px solid var(--line-2);color:var(--ink-dim);font-size:11.5px;font-weight:600;font-family:'Inter'}
.chip.hot{background:linear-gradient(180deg, rgba(255,122,24,.2), rgba(255,90,0,.2));border-color:var(--orange-2);color:var(--orange-2)}

/* Characters */
.chars-grid{display:grid;grid-template-columns:repeat(4,1fr);margin:-11px}
.chars-grid > *{margin:11px}
/* Characters — layout em coluna (evita ícone/texto colados em WebViews sem absolute/grid fiável) */
.char{
  position:relative;
  min-height:300px;
  border-radius:18px;
  overflow:hidden;
  background:linear-gradient(180deg, rgba(45,212,255,.06) 0%, rgba(255,122,24,.06) 100%), repeating-linear-gradient(45deg, #15151a 0 10px, #0e0e12 10px 20px);
  box-shadow:0 0 0 1px var(--line-2), 0 14px 24px -10px rgba(0,0,0,.7);
  display:flex;
  flex-direction:column;
  align-items:stretch;
  padding:18px;
  transition:transform .25s ease;
}
.char:hover{transform:translateY(-4px) rotate(-1deg)}
.weapon-art{
  position:relative;
  flex:1 1 auto;
  min-height:160px;
  margin:0 0 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:radial-gradient(circle at 50% 50%, rgba(255,207,90,.22), transparent 70%);
  border-radius:14px;
  overflow:hidden;
}
.weapon-art img{
  max-width:78%;
  max-height:120px;
  width:auto;
  height:auto;
  border-radius:18px;
  background:linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.05));
  box-shadow:0 0 0 1px rgba(0,0,0,.6), 0 0 0 2px rgba(255,207,90,.45), 0 10px 22px rgba(0,0,0,.6), 0 0 28px rgba(255,180,80,.18);
  image-rendering:pixelated;
}
.char .name{
  font-family:'Luckiest Guy';
  font-size:20px;
  line-height:1.15;
  letter-spacing:.02em;
  color:#fff;
  text-shadow:0 2px 0 #0d0d12, 0 0 16px rgba(0,0,0,.7);
  position:relative;
  z-index:2;
  margin:0;
  padding:2px 0 0 4px;
}
.char .role{
  font-family:'Inter';
  font-size:12px;
  font-weight:600;
  line-height:1.3;
  color:var(--gold-2);
  text-transform:uppercase;
  letter-spacing:.14em;
  position:relative;
  z-index:2;
  margin:0 0 6px;
  padding-left:4px;
}
/* CTA — faixa com véu como #modos; padding aqui */
.cta{padding:80px 0 120px;text-align:center;position:relative}
.cta-card{position:relative;border-radius:28px;padding:70px 32px 80px;background:linear-gradient(180deg, rgba(8,8,10,.85) 0%, rgba(8,8,10,.95) 100%), url("../landing-design/lava-bg.png") center/cover, #0a0a0c;box-shadow:0 0 0 1px var(--line-2), 0 30px 60px -20px rgba(0,0,0,.85), 0 0 120px rgba(255,90,18,.15);overflow:hidden}
.cta-eye{margin-bottom:50px;display:inline-flex}
.btn-pink .arrow{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:#3a1a00;color:#ffd98a;font-size:11px}
.cta-card::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 80% 60% at 50% 100%, rgba(255,80,10,.18), transparent 65%), radial-gradient(ellipse 60% 50% at 50% 0%, rgba(0,0,0,.5), transparent 60%);z-index:0}
.cta-card > *{position:relative;z-index:1}
.cta-card::before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 12% 30%, rgba(255,207,90,.7) 0 2px, transparent 3px), radial-gradient(circle at 88% 22%, rgba(255,143,192,.7) 0 2px, transparent 3px), radial-gradient(circle at 22% 78%, rgba(255,255,255,.6) 0 1.5px, transparent 2.5px), radial-gradient(circle at 78% 82%, rgba(255,207,90,.6) 0 1.5px, transparent 2.5px), radial-gradient(circle at 50% 50%, rgba(255,143,192,.5) 0 1px, transparent 2px)}
.cta h2{font-family:'Luckiest Guy';font-weight:400;font-size:clamp(40px, 6vw, 76px);letter-spacing:.02em;line-height:1;margin:0 0 18px;color:#fff;text-shadow:0 3px 0 #1a1a22, 0 5px 0 #0d0d12, 0 7px 0 #050507, 0 12px 24px rgba(0,0,0,.7);position:relative}
.cta h2 .pink{color:var(--pink);text-shadow:0 3px 0 #0d6a85, 0 5px 0 #074a5c, 0 7px 0 #042a36, 0 12px 24px rgba(45,212,255,.45)}
.cta p{font-family:'Inter';color:var(--ink-dim);max-width:520px;margin:0 auto 36px;font-size:17px;position:relative}
.cta .actions{display:flex;justify-content:center;flex-wrap:wrap;position:relative;margin:-7px}
.cta .actions > *{margin:7px}
.cta-no-dl{
  margin-top:20px;
  margin-left:-9px;
  margin-right:-9px;
  font-family:'Inter';
  font-size:13px;
  font-weight:500;
  color:var(--gold-2);
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  position:relative;
}
.cta-no-dl > *{margin:9px}
.cta-no-dl span::before{content:"✓ ";color:var(--green);font-weight:700}

/* Footer */
footer{border-top:1px solid var(--line);padding:44px 0 36px;color:var(--ink-mute);font-size:13px;background:rgba(6, 5, 10, 0.9)}
.foot-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;margin:-9px}
.foot-row > *{margin:9px}
.foot-links{display:flex;flex-wrap:wrap;font-family:'Inter';margin:-11px}
.foot-links > *{margin:11px}
.foot-links a:hover{color:var(--gold-2)}
.legal{font-family:'Inter';font-size:12px}
footer .brand img{
  height:52px;
  width:auto;
  filter:drop-shadow(0 2px 8px rgba(255,90,0,.4));
}

/* Responsive */
@media (max-width: 980px){
  .hero{padding:40px 0 88px}
  .hero-inner{grid-template-columns:1fr}
  .hero-inner > *:first-child{margin-right:0;margin-bottom:52px}
  .hero-inner > *:last-child{margin-left:0}
  .hero-art{max-width:560px;margin:0 auto;width:100%}
  .badge-new{width:80px;height:80px;font-size:14px;top:-16px;right:-12px}
  .feat-grid{grid-template-columns:1fr 1fr}
  .modes-grid > .mode{
    float:none;
    width:100%;
    margin-right:0;
    margin-bottom:20px;
  }
  .modes-grid > .mode:last-child{
    margin-bottom:0;
  }
  .chars-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
  .nav-cta{margin-left:auto}
  .section{padding:80px 0}
}
@media (max-width: 560px){
  .wrap{padding:0 18px}
  .hero h1{font-size:46px}
  .hero p.lead{font-size:16px}
  .hero-cta{flex-direction:column;width:100%}
  .hero-cta .btn{width:100%}
  .hero-cta > *{margin-right:0;margin-bottom:14px}
  .hero-cta > *:last-child{margin-bottom:0}
  .hero-meta{margin-top:28px}
  .hero-meta > *{margin-right:24px;margin-bottom:14px}
  .hero-meta > *:last-child{margin-right:0}
  .feat-grid{grid-template-columns:1fr}
  .chars-grid{grid-template-columns:1fr 1fr;margin:-7px}
  .chars-grid > *{margin:7px}
  #main-nav .brand img{height:36px}
  footer .brand img{height:44px}
  .cta-card{padding:50px 22px 60px}
  .foot-row{flex-direction:column;align-items:flex-start}
  .ribbon{font-size:14px;padding:6px 12px;top:-10px;left:14px}
}

/* ── Integração PHP / modais (index) ── */
.navbar, footer.bootstrap { display: none !important; }
a.btn { text-decoration: none; }
/* Evita tema global (ex. novo-tema) a mudar a cor do texto dos botões no hover */
body.index-landing a.btn.btn-play:hover { color: #fff !important; }
body.index-landing a.btn.btn-pink:hover { color: #3a1a00 !important; }
body.index-landing a.btn.btn-ghost:hover { color: var(--gold-2) !important; }
.hero-meta button.item {
  appearance: none;
  border: none;
  background: transparent;
  padding: 0;
  font: inherit;
  color: inherit;
  text-align: left;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
}
.nav.scrolled {
  background: rgba(6, 6, 8, 0.94);
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.45);
}
