/* =====================================================================
   Via da Gam Row — estilo-pista.css
   Identidade visual: "Pista Neon" — asfalto nocturno + velocidade
   Paleta: asfalto #0b0f1a / superfície #141b2e / lima eléctrica #c8ff2d
           coral #ff5a3c / cião #2de8ff
   Tipografia: Orbitron (marca) · Rajdhani (títulos) · Inter (texto)
   ===================================================================== */

:root {
  --asfalto: #0b0f1a;
  --asfalto-2: #0f1626;
  --superficie: #141b2e;
  --superficie-2: #1b2540;
  --linha: #27314c;
  --lima: #c8ff2d;
  --lima-escura: #9fce1f;
  --coral: #ff5a3c;
  --ciao: #2de8ff;
  --texto: #e9eefb;
  --texto-suave: #9aa6c4;
  --branco: #ffffff;
  --sombra: 0 18px 50px -18px rgba(0, 0, 0, .65);
  --raio: 16px;
  --raio-s: 10px;
  --max: 1180px;
  --transicao: .25s cubic-bezier(.4, .14, .3, 1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  font-family: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  background: var(--asfalto);
  color: var(--texto);
  line-height: 1.65;
  overflow-x: hidden;
  font-size: 16px;
}

/* faixa de "estrada" tracejada de fundo */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(900px 500px at 85% -5%, rgba(45, 232, 255, .10), transparent 60%),
    radial-gradient(800px 600px at 0% 100%, rgba(255, 90, 60, .10), transparent 55%),
    linear-gradient(180deg, var(--asfalto), var(--asfalto-2));
}

img, svg { display: block; max-width: 100%; }
a { color: var(--ciao); text-decoration: none; transition: color var(--transicao); }
a:hover { color: var(--lima); }

h1, h2, h3, h4 { font-family: "Rajdhani", "Inter", sans-serif; line-height: 1.08; font-weight: 700; letter-spacing: .2px; }

.container { width: 100%; max-width: var(--max); margin-inline: auto; padding-inline: 20px; }

.seccao { padding: clamp(56px, 9vw, 110px) 0; position: relative; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  font-family: "Rajdhani", sans-serif; font-weight: 600;
  text-transform: uppercase; letter-spacing: 3px; font-size: .8rem;
  color: var(--lima); margin-bottom: 14px;
}
.eyebrow::before {
  content: ""; width: 26px; height: 3px; border-radius: 3px;
  background: linear-gradient(90deg, var(--lima), transparent);
}

.titulo-seccao { font-size: clamp(1.9rem, 4.6vw, 3rem); margin-bottom: 14px; }
.titulo-seccao em { color: var(--coral); font-style: normal; }
.subtitulo-seccao { color: var(--texto-suave); max-width: 60ch; font-size: 1.05rem; }

/* ====================== BOTÕES ====================== */
.btn {
  --c: var(--asfalto);
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: "Rajdhani", sans-serif; font-weight: 700; font-size: 1.05rem;
  text-transform: uppercase; letter-spacing: 1.2px;
  padding: 14px 28px; border-radius: 999px; border: 0; cursor: pointer;
  background: linear-gradient(95deg, var(--lima), var(--lima-escura));
  color: var(--c); box-shadow: 0 10px 28px -10px rgba(200, 255, 45, .6);
  transition: transform var(--transicao), box-shadow var(--transicao), filter var(--transicao);
}
.btn:hover { transform: translateY(-3px); box-shadow: 0 16px 34px -10px rgba(200, 255, 45, .7); filter: brightness(1.05); color: var(--asfalto); }
.btn:active { transform: translateY(0); }
.btn--ghost {
  background: transparent; color: var(--texto);
  border: 1.5px solid var(--linha); box-shadow: none;
}
.btn--ghost:hover { border-color: var(--ciao); color: var(--ciao); box-shadow: 0 0 0 1px var(--ciao); }
.btn--coral { background: linear-gradient(95deg, var(--coral), #ff7a45); color: #1a0a06; box-shadow: 0 10px 28px -10px rgba(255, 90, 60, .6); }
.btn--coral:hover { color: #1a0a06; }

/* ====================== HEADER ====================== */
.cabecalho {
  position: sticky; top: 0; z-index: 60;
  backdrop-filter: blur(12px);
  background: rgba(11, 15, 26, .78);
  border-bottom: 1px solid var(--linha);
}
.cabecalho .container { display: flex; align-items: center; justify-content: space-between; height: 70px; gap: 18px; }

.marca { display: flex; align-items: center; gap: 11px; font-family: "Orbitron", sans-serif; font-weight: 800; font-size: 1.15rem; letter-spacing: .5px; color: var(--branco); }
.marca:hover { color: var(--branco); }
.marca .logo { width: 40px; height: 40px; flex: 0 0 auto; filter: drop-shadow(0 4px 10px rgba(45, 232, 255, .35)); }
.marca b { color: var(--lima); }

.nav { display: flex; align-items: center; gap: 6px; }
.nav a {
  color: var(--texto-suave); font-family: "Rajdhani", sans-serif; font-weight: 600;
  font-size: 1rem; padding: 8px 14px; border-radius: 999px; letter-spacing: .4px;
}
.nav a:hover { color: var(--texto); background: var(--superficie); }
.nav .btn { padding: 9px 20px; font-size: .95rem; }

.menu-toggle { display: none; background: none; border: 1px solid var(--linha); color: var(--texto); width: 44px; height: 40px; border-radius: 10px; cursor: pointer; }
.menu-toggle svg { margin: auto; }

/* ====================== HERO ====================== */
.hero { position: relative; padding: clamp(60px, 10vw, 120px) 0 clamp(50px, 8vw, 90px); overflow: hidden; }
.hero::after {
  /* linhas de velocidade diagonais */
  content: ""; position: absolute; inset: -20% -10%; z-index: -1; opacity: .5;
  background:
    repeating-linear-gradient(115deg, transparent 0 38px, rgba(45, 232, 255, .04) 38px 40px),
    repeating-linear-gradient(115deg, transparent 0 120px, rgba(255, 90, 60, .035) 120px 123px);
  transform: skewY(-2deg);
}
.hero-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 50px; align-items: center; }

.hero h1 { font-size: clamp(2.4rem, 6.4vw, 4.4rem); letter-spacing: -.5px; }
.hero h1 .flash {
  background: linear-gradient(100deg, var(--lima), var(--ciao));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.hero p.lead { color: var(--texto-suave); font-size: clamp(1.05rem, 2.4vw, 1.25rem); margin: 22px 0 30px; max-width: 54ch; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; }
.hero-stats { display: flex; gap: 28px; margin-top: 38px; flex-wrap: wrap; }
.hero-stats .stat strong { font-family: "Orbitron", sans-serif; font-size: 1.7rem; color: var(--branco); display: block; }
.hero-stats .stat span { color: var(--texto-suave); font-size: .85rem; text-transform: uppercase; letter-spacing: 1.5px; }

/* painel "velocímetro" do hero */
.hero-painel {
  position: relative; background:
    radial-gradient(120% 120% at 50% 0%, var(--superficie-2), var(--superficie));
  border: 1px solid var(--linha); border-radius: 24px; padding: 30px;
  box-shadow: var(--sombra); overflow: hidden;
}
.hero-painel::before {
  content: ""; position: absolute; top: -40%; right: -30%; width: 70%; height: 80%;
  background: radial-gradient(circle, rgba(200, 255, 45, .18), transparent 70%);
}
.veloc { display: grid; place-items: center; gap: 8px; }
.veloc-num { font-family: "Orbitron", sans-serif; font-size: 3.4rem; font-weight: 800; color: var(--lima); text-shadow: 0 0 22px rgba(200, 255, 45, .35); }
.veloc-num small { font-size: 1rem; color: var(--texto-suave); margin-left: 4px; }
.veloc-label { text-transform: uppercase; letter-spacing: 3px; font-size: .75rem; color: var(--texto-suave); }
.barras { display: flex; gap: 6px; margin-top: 18px; width: 100%; }
.barras span { height: 10px; flex: 1; border-radius: 4px; background: var(--linha); }
.barras span:nth-child(-n+7) { background: linear-gradient(90deg, var(--coral), var(--lima)); }
.mini-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 22px; }
.mini-tags span { font-size: .78rem; padding: 5px 12px; border-radius: 999px; background: var(--asfalto); border: 1px solid var(--linha); color: var(--texto-suave); }

/* ====================== DESTAQUES ====================== */
.grid-destaques { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 44px; }
.card-destaque {
  background: linear-gradient(180deg, var(--superficie), var(--asfalto-2));
  border: 1px solid var(--linha); border-radius: var(--raio); padding: 28px 24px;
  transition: transform var(--transicao), border-color var(--transicao);
  position: relative; overflow: hidden;
}
.card-destaque:hover { transform: translateY(-6px); border-color: rgba(45, 232, 255, .5); }
.card-destaque .ico { width: 52px; height: 52px; border-radius: 13px; display: grid; place-items: center; background: var(--asfalto); border: 1px solid var(--linha); margin-bottom: 18px; }
.card-destaque h3 { font-size: 1.3rem; margin-bottom: 8px; }
.card-destaque p { color: var(--texto-suave); font-size: .96rem; }

/* ====================== ANÁLISES (jogos) ====================== */
.grid-jogos { display: grid; grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); gap: 24px; margin-top: 46px; }
.jogo {
  background: var(--superficie); border: 1px solid var(--linha);
  border-radius: var(--raio); overflow: hidden; display: flex; flex-direction: column;
  transition: transform var(--transicao), box-shadow var(--transicao);
}
.jogo:hover { transform: translateY(-6px); box-shadow: var(--sombra); }
.jogo-capa { position: relative; overflow: hidden; background: linear-gradient(135deg, var(--superficie-2), var(--asfalto-2)); border-bottom: 1px solid var(--linha); }
.jogo-capa img { width: 100%; max-width: 100%; height: auto; aspect-ratio: 1 / 1; object-fit: cover; display: block; transition: transform var(--transicao); }
.jogo:hover .jogo-capa img { transform: scale(1.05); }
.jogo-capa svg { width: 100%; height: 100%; }
.jogo-corpo { padding: 20px 22px 24px; display: flex; flex-direction: column; flex: 1; }
.jogo-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
.jogo h3 { font-size: 1.25rem; }
.jogo .genero { font-size: .72rem; text-transform: uppercase; letter-spacing: 1.5px; color: var(--ciao); font-weight: 700; font-family: "Rajdhani", sans-serif; }
.jogo p { color: var(--texto-suave); font-size: .93rem; flex: 1; margin-bottom: 16px; }
.jogo-rodape { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.nota { display: inline-flex; align-items: baseline; gap: 4px; font-family: "Orbitron", sans-serif; font-weight: 700; color: var(--lima); font-size: 1.15rem; }
.nota small { color: var(--texto-suave); font-size: .8rem; font-family: "Inter", sans-serif; font-weight: 400; }
.estrelas { color: var(--coral); letter-spacing: 2px; font-size: .95rem; }
.plataformas { display: flex; gap: 6px; margin-top: 12px; }
.plataformas span { font-size: .72rem; padding: 3px 9px; border-radius: 6px; background: var(--asfalto); border: 1px solid var(--linha); color: var(--texto-suave); }

/* ====================== RANKING ====================== */
.tabela-wrap { margin-top: 44px; border: 1px solid var(--linha); border-radius: var(--raio); overflow: hidden; background: var(--superficie); }
.tabela { width: 100%; border-collapse: collapse; }
.tabela caption { text-align: left; padding: 18px 22px; color: var(--texto-suave); font-size: .9rem; border-bottom: 1px solid var(--linha); }
.tabela th, .tabela td { padding: 15px 18px; text-align: left; border-bottom: 1px solid var(--linha); font-size: .95rem; }
.tabela thead th { background: var(--asfalto-2); font-family: "Rajdhani", sans-serif; text-transform: uppercase; letter-spacing: 1px; font-size: .8rem; color: var(--texto-suave); }
.tabela tbody tr:last-child td { border-bottom: 0; }
.tabela tbody tr:hover { background: var(--superficie-2); }
.pos { font-family: "Orbitron", sans-serif; font-weight: 800; color: var(--lima); }
.pos.ouro { color: #ffd34d; } .pos.prata { color: #cdd7ef; } .pos.bronze { color: #ff9c5b; }
.barra-nota { display: block; height: 8px; border-radius: 5px; background: var(--linha); position: relative; min-width: 90px; }
.barra-nota i { position: absolute; inset: 0; border-radius: 5px; background: linear-gradient(90deg, var(--coral), var(--lima)); }

/* ====================== FAQ ====================== */
.faq { margin-top: 40px; display: grid; gap: 14px; max-width: 860px; }
.faq details { background: var(--superficie); border: 1px solid var(--linha); border-radius: var(--raio-s); overflow: hidden; }
.faq summary { cursor: pointer; padding: 18px 22px; font-family: "Rajdhani", sans-serif; font-weight: 600; font-size: 1.12rem; list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 14px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-size: 1.5rem; color: var(--lima); transition: transform var(--transicao); line-height: 1; }
.faq details[open] summary::after { transform: rotate(45deg); }
.faq details[open] summary { color: var(--lima); }
.faq p { padding: 0 22px 20px; color: var(--texto-suave); }

/* ====================== SOBRE ====================== */
.sobre-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; }
.sobre-grid p { color: var(--texto-suave); margin-bottom: 16px; }
.lista-check { list-style: none; display: grid; gap: 12px; margin-top: 8px; }
.lista-check li { display: flex; gap: 12px; align-items: flex-start; color: var(--texto); }
.lista-check li::before { content: "▸"; color: var(--lima); font-weight: 700; margin-top: 1px; }
.sobre-quadro { background: linear-gradient(160deg, var(--superficie-2), var(--asfalto-2)); border: 1px solid var(--linha); border-radius: 22px; padding: 34px; box-shadow: var(--sombra); }
.sobre-quadro .num-grande { font-family: "Orbitron", sans-serif; font-size: 3rem; color: var(--ciao); }

/* ====================== SUBSCREVER (form) ====================== */
.subscrever { position: relative; }
.form-wrap {
  margin-top: 40px; display: grid; grid-template-columns: 1.05fr 1fr; gap: 0;
  background: linear-gradient(135deg, var(--superficie-2), var(--asfalto-2));
  border: 1px solid var(--linha); border-radius: 24px; overflow: hidden; box-shadow: var(--sombra);
}
.form-lado { padding: clamp(28px, 4vw, 46px); }
.form-lado.intro { background:
    radial-gradient(120% 120% at 0% 0%, rgba(45, 232, 255, .12), transparent 55%),
    radial-gradient(120% 120% at 100% 100%, rgba(255, 90, 60, .1), transparent 50%);
  border-right: 1px solid var(--linha); display: flex; flex-direction: column; justify-content: center; }
.form-lado.intro h2 { font-size: clamp(1.7rem, 3.6vw, 2.4rem); margin-bottom: 12px; }
.form-lado.intro p { color: var(--texto-suave); }
.form-lado.intro ul { list-style: none; margin-top: 20px; display: grid; gap: 10px; }
.form-lado.intro li { display: flex; gap: 10px; color: var(--texto); font-size: .95rem; }
.form-lado.intro li::before { content: "✓"; color: var(--lima); font-weight: 800; }

/* cartão do formulário */
.form-cartao {
  position: relative;
  background: linear-gradient(180deg, var(--superficie), var(--asfalto-2));
  border: 1px solid var(--linha); border-radius: 20px;
  padding: clamp(22px, 3.4vw, 34px); overflow: hidden;
  box-shadow: 0 22px 60px -30px rgba(0, 0, 0, .8);
}
.form-cartao::before {
  content: ""; position: absolute; left: 0; right: 0; top: 0; height: 4px;
  background: linear-gradient(90deg, var(--coral), var(--lima), var(--ciao));
}
.form-cabecalho { margin-bottom: 22px; }
.form-pill {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: "Rajdhani", sans-serif; font-weight: 700; font-size: .72rem;
  text-transform: uppercase; letter-spacing: 2px; color: var(--asfalto);
  background: linear-gradient(95deg, var(--lima), var(--lima-escura));
  padding: 5px 13px; border-radius: 999px; margin-bottom: 12px;
}
.form-cabecalho h3 { font-size: clamp(1.3rem, 2.6vw, 1.7rem); margin-bottom: 6px; }
.form-cabecalho p { color: var(--texto-suave); font-size: .95rem; }

#subscribeForm { display: grid; gap: 16px; }
.campo-linha { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.campo { display: grid; gap: 7px; }
.obrig { color: var(--coral); }
.campo label { font-family: "Rajdhani", sans-serif; font-weight: 600; font-size: .95rem; letter-spacing: .4px; color: var(--texto); }
.campo input[type="text"], .campo input[type="tel"], .campo input[type="email"] {
  width: 100%; padding: 13px 15px; border-radius: var(--raio-s);
  background: var(--asfalto); border: 1.5px solid var(--linha); color: var(--texto);
  font-size: 1rem; font-family: inherit; transition: border-color var(--transicao), box-shadow var(--transicao);
}
.campo input::placeholder { color: #5e6a86; }
.campo input:focus { outline: none; border-color: var(--lima); box-shadow: 0 0 0 3px rgba(200, 255, 45, .18); }
.consentimento {
  display: flex; gap: 11px; align-items: flex-start; font-size: .9rem; color: var(--texto-suave);
  background: var(--asfalto); border: 1px solid var(--linha); border-radius: var(--raio-s);
  padding: 13px 15px;
}
.consentimento input { width: 19px; height: 19px; margin-top: 2px; accent-color: var(--lima); flex: 0 0 auto; cursor: pointer; }
.consentimento a { text-decoration: underline; color: var(--ciao); }
#subscribeForm .btn { width: 100%; margin-top: 4px; font-size: 1.1rem; padding: 16px 28px; }
.nota-priv { font-size: .8rem; color: var(--texto-suave); text-align: center; }

#successMsg {
  display: none; margin-top: 6px; padding: 14px 16px; border-radius: var(--raio-s);
  background: rgba(200, 255, 45, .1); border: 1px solid var(--lima); color: var(--lima);
  font-weight: 600; text-align: center; font-family: "Rajdhani", sans-serif; font-size: 1.05rem;
}
#successMsg.show { display: block; animation: surge .4s ease; }
@keyframes surge { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* ====================== FOOTER ====================== */
.rodape { background: var(--asfalto-2); border-top: 1px solid var(--linha); padding: 64px 0 28px; margin-top: 20px; }
.rodape-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr; gap: 36px; }
.rodape h4 { font-family: "Rajdhani", sans-serif; text-transform: uppercase; letter-spacing: 1.5px; font-size: .9rem; color: var(--texto-suave); margin-bottom: 16px; }
.rodape ul { list-style: none; display: grid; gap: 9px; }
.rodape ul a { color: var(--texto); font-size: .95rem; }
.rodape ul a:hover { color: var(--lima); }
.rodape .marca { margin-bottom: 14px; }
.rodape .desc { color: var(--texto-suave); font-size: .92rem; max-width: 34ch; }
.nap { color: var(--texto-suave); font-size: .92rem; display: grid; gap: 8px; }
.nap a { color: var(--ciao); }
.nap strong { color: var(--texto); display: block; font-family: "Rajdhani", sans-serif; }
.rodape-base { margin-top: 44px; padding-top: 22px; border-top: 1px solid var(--linha); display: flex; flex-wrap: wrap; gap: 14px; justify-content: space-between; align-items: center; color: var(--texto-suave); font-size: .86rem; }
.rodape-base nav { display: flex; flex-wrap: wrap; gap: 16px; }
.rodape-base nav a { color: var(--texto-suave); }

/* ====================== PÁGINAS LEGAIS / TEXTO ====================== */
.pagina-doc { padding-top: clamp(40px, 7vw, 80px); }
.doc-cabecalho { border-bottom: 1px solid var(--linha); padding-bottom: 26px; margin-bottom: 36px; }
.doc-cabecalho h1 { font-size: clamp(2rem, 5vw, 3.2rem); margin-bottom: 10px; }
.doc-cabecalho .atualizado { color: var(--texto-suave); font-size: .9rem; }
.doc { max-width: 820px; }
.doc h2 { font-size: 1.55rem; margin: 38px 0 12px; color: var(--branco); }
.doc h3 { font-size: 1.2rem; margin: 24px 0 8px; color: var(--ciao); }
.doc p, .doc li { color: var(--texto-suave); margin-bottom: 12px; }
.doc ul, .doc ol { padding-left: 22px; margin-bottom: 14px; }
.doc li { margin-bottom: 6px; }
.doc strong { color: var(--texto); }
.doc a { text-decoration: underline; }
.migalhas { font-size: .85rem; color: var(--texto-suave); margin-bottom: 18px; }
.migalhas a { color: var(--ciao); }

.tabela-doc { width: 100%; border-collapse: collapse; margin: 16px 0 22px; border: 1px solid var(--linha); border-radius: var(--raio-s); overflow: hidden; }
.tabela-doc th, .tabela-doc td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--linha); font-size: .92rem; color: var(--texto-suave); }
.tabela-doc th { background: var(--asfalto-2); color: var(--texto); font-family: "Rajdhani", sans-serif; }

/* ====================== 404 ====================== */
.erro404 { min-height: 70vh; display: grid; place-items: center; text-align: center; padding: 60px 20px; }
.erro404 .codigo { font-family: "Orbitron", sans-serif; font-size: clamp(5rem, 22vw, 11rem); font-weight: 800; line-height: .9; background: linear-gradient(120deg, var(--coral), var(--lima)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.erro404 h1 { font-size: clamp(1.6rem, 5vw, 2.6rem); margin: 8px 0 14px; }
.erro404 p { color: var(--texto-suave); margin-bottom: 26px; max-width: 46ch; }

/* contacto */
.contacto-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin-top: 40px; align-items: start; }
.cartao-contacto { background: var(--superficie); border: 1px solid var(--linha); border-radius: var(--raio); padding: 26px; display: flex; gap: 16px; align-items: flex-start; margin-bottom: 16px; }
.cartao-contacto .ico { width: 46px; height: 46px; flex: 0 0 auto; border-radius: 12px; background: var(--asfalto); border: 1px solid var(--linha); display: grid; place-items: center; }
.cartao-contacto h3 { font-size: 1.1rem; margin-bottom: 4px; }
.cartao-contacto p, .cartao-contacto a { color: var(--texto-suave); font-size: .95rem; }

/* ====================== RESPONSIVO ====================== */
@media (max-width: 900px) {
  .hero-grid, .sobre-grid, .form-wrap, .contacto-grid { grid-template-columns: 1fr; }
  .campo-linha { grid-template-columns: 1fr; }
  .form-lado.intro { border-right: 0; border-bottom: 1px solid var(--linha); }
  .grid-destaques { grid-template-columns: 1fr 1fr; }
  .rodape-grid { grid-template-columns: 1fr 1fr; }
  .nav { position: fixed; inset: 70px 0 auto 0; flex-direction: column; align-items: stretch; gap: 4px; background: var(--asfalto-2); border-bottom: 1px solid var(--linha); padding: 14px 20px 22px; transform: translateY(-130%); transition: transform var(--transicao); }
  .nav.aberto { transform: translateY(0); }
  .nav a { padding: 12px 14px; }
  .nav .btn { margin-top: 6px; }
  .menu-toggle { display: grid; }
}
@media (max-width: 560px) {
  .grid-destaques, .rodape-grid { grid-template-columns: 1fr; }
  .hero-stats { gap: 20px; }
  .seccao { padding: 50px 0; }
  .tabela th:nth-child(4), .tabela td:nth-child(4) { display: none; }
}

/* =====================================================================
   LAYOUT EXCLUSIVO main.html — barra lateral vertical (side-rail)
   (as restantes páginas continuam a usar .cabecalho / .nav)
   ===================================================================== */
.trilho {
  position: fixed; top: 0; left: 0; bottom: 0; width: 100px; z-index: 70;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 18px 10px;
  background: rgba(11, 15, 26, .92);
  backdrop-filter: blur(12px);
  border-right: 1px solid var(--linha);
  overflow-y: auto;
}
.trilho-marca { display: flex; flex-direction: column; align-items: center; gap: 6px; color: var(--branco); flex: 0 0 auto; }
.trilho-marca:hover { color: var(--branco); }
.trilho-marca .logo { width: 42px; height: 42px; filter: drop-shadow(0 4px 10px rgba(45, 232, 255, .35)); }
.trilho-wordmark { display: none; }
.trilho-wordmark b { color: var(--lima); }

.rail-nav { display: flex; flex-direction: column; align-items: stretch; gap: 4px; width: 100%; margin-top: 10px; }
.rail-nav a {
  display: flex; flex-direction: column; align-items: center; gap: 5px;
  padding: 10px 4px; border-radius: 14px; text-align: center;
  color: var(--texto-suave); font-family: "Rajdhani", sans-serif; font-weight: 600;
  font-size: .66rem; text-transform: uppercase; letter-spacing: .6px;
  border: 1px solid transparent;
  transition: color var(--transicao), background var(--transicao), border-color var(--transicao);
}
.rail-nav a svg { width: 23px; height: 23px; }
.rail-nav a:hover { color: var(--texto); background: var(--superficie); }
.rail-nav a.ativa { color: var(--lima); background: var(--asfalto-2); border-color: rgba(200, 255, 45, .35); }

.trilho-cta {
  margin-top: auto; width: 100%; flex: 0 0 auto;
  display: flex; flex-direction: column; align-items: center; gap: 5px;
  padding: 12px 4px; border-radius: 14px; text-align: center;
  background: linear-gradient(160deg, var(--coral), #ff7a45); color: #1a0a06;
  font-family: "Rajdhani", sans-serif; font-weight: 700; font-size: .66rem;
  text-transform: uppercase; letter-spacing: .6px;
  box-shadow: 0 10px 24px -12px rgba(255, 90, 60, .7);
  transition: filter var(--transicao);
}
.trilho-cta:hover { color: #1a0a06; filter: brightness(1.06); }
.trilho-cta svg { width: 22px; height: 22px; }

.palco { margin-left: 100px; }

/* =====================================================================
   HERO — velocímetro (gauge SVG) + numerais grandes
   ===================================================================== */
.hero-veloc { display: flex; flex-direction: column; align-items: center; gap: 22px; }
.veloc-disco {
  position: relative; width: 100%; max-width: 360px;
  background: radial-gradient(120% 120% at 50% 0%, var(--superficie-2), var(--superficie));
  border: 1px solid var(--linha); border-radius: 24px;
  padding: 30px 30px 34px; box-shadow: var(--sombra); overflow: hidden;
}
.veloc-disco::before {
  content: ""; position: absolute; top: -40%; right: -30%; width: 70%; height: 80%;
  background: radial-gradient(circle, rgba(200, 255, 45, .16), transparent 70%);
}
.veloc-disco .gauge { width: 100%; height: auto; position: relative; }
.gauge-fill { stroke-dasharray: 78 100; animation: encherGauge 1.6s cubic-bezier(.2, .7, .2, 1) .15s both; }
@keyframes encherGauge { from { stroke-dasharray: 0 100; } to { stroke-dasharray: 78 100; } }
.veloc-leitura { position: absolute; left: 0; right: 0; bottom: 30px; text-align: center; }
.veloc-disco .veloc-num { font-size: clamp(3rem, 8vw, 4.4rem); justify-content: center; display: flex; align-items: baseline; }

/* =====================================================================
   GAME RAILS — carrosséis horizontais com scroll-snap
   ===================================================================== */
.pista { margin-top: 36px; }
.pista-cabecalho { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.pista-nome { display: flex; align-items: center; gap: 12px; font-size: 1.15rem; color: var(--texto); }
.bandeira { width: 22px; height: 16px; border-radius: 3px; border: 1px solid var(--linha); flex: 0 0 auto;
  background: repeating-conic-gradient(#e9eefb 0 25%, #0b0f1a 0 50%) 0 0 / 8px 8px; }
.pista-dica { font-family: "Rajdhani", sans-serif; font-size: .78rem; text-transform: uppercase; letter-spacing: 1.5px; color: var(--ciao); }

.rail-track {
  display: flex; gap: 18px; overflow-x: auto; scroll-snap-type: x mandatory;
  padding: 6px 2px 16px; scroll-padding-left: 2px;
  scrollbar-width: thin; scrollbar-color: var(--linha) transparent;
}
.rail-track::-webkit-scrollbar { height: 8px; }
.rail-track::-webkit-scrollbar-track { background: transparent; }
.rail-track::-webkit-scrollbar-thumb { background: var(--linha); border-radius: 99px; }
.rail-card {
  flex: 0 0 clamp(220px, 60%, 264px); scroll-snap-align: start;
  background: var(--superficie); border: 1px solid var(--linha); border-radius: var(--raio);
  overflow: hidden; display: flex; flex-direction: column;
  transition: transform var(--transicao), border-color var(--transicao);
}
.rail-card:hover { transform: translateY(-5px); border-color: rgba(45, 232, 255, .5); }
.rail-capa { aspect-ratio: 16 / 10; overflow: hidden; background: linear-gradient(135deg, var(--superficie-2), var(--asfalto-2)); border-bottom: 1px solid var(--linha); }
.rail-capa img { width: 100%; height: 100%; object-fit: cover; object-position: center; transition: transform var(--transicao); }
.rail-card:hover .rail-capa img { transform: scale(1.05); }
.rail-corpo { padding: 14px 16px 18px; display: flex; flex-direction: column; gap: 6px; }
.rail-corpo h4 { font-family: "Rajdhani", sans-serif; font-size: 1.1rem; line-height: 1.15; }
.rail-corpo .nota { margin-top: 2px; }

/* =====================================================================
   GRELHA DE PARTIDA — secção exclusiva deste site
   ===================================================================== */
.grelha-cabecalho { text-align: center; max-width: 760px; margin: 0 auto; }
.grelha-cabecalho .eyebrow { justify-content: center; }
.grelha-cabecalho .subtitulo-seccao { margin-inline: auto; }
.semaforo { display: flex; justify-content: center; gap: 10px; margin-top: 22px; }
.semaforo span {
  width: 16px; height: 16px; border-radius: 50%;
  background: #3a1414; border: 1px solid #5a1f1f; box-shadow: inset 0 0 5px rgba(0, 0, 0, .6);
  transition: background .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.grelha.ativa .semaforo span { background: radial-gradient(circle at 35% 30%, #d3ff8c, var(--lima)); border-color: var(--lima-escura); box-shadow: 0 0 12px rgba(200, 255, 45, .65); }
.grelha.ativa .semaforo span:nth-child(1) { transition-delay: 0s; }
.grelha.ativa .semaforo span:nth-child(2) { transition-delay: .12s; }
.grelha.ativa .semaforo span:nth-child(3) { transition-delay: .24s; }
.grelha.ativa .semaforo span:nth-child(4) { transition-delay: .36s; }
.grelha.ativa .semaforo span:nth-child(5) { transition-delay: .48s; }

.grelha-pista { position: relative; margin-top: 40px; padding-top: 26px; }
.linha-meta {
  position: absolute; top: 0; left: 0; right: 0; height: 14px; border-radius: 5px; opacity: .9;
  background: repeating-conic-gradient(#e9eefb 0 25%, #0b0f1a 0 50%) 0 0 / 14px 14px;
}
.grelha-slots { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; align-items: start; }
.slot:nth-child(even) { margin-top: 36px; }

.slot {
  position: relative; overflow: hidden;
  background: linear-gradient(180deg, var(--superficie), var(--asfalto-2));
  border: 1px solid var(--linha); border-radius: var(--raio); padding: 20px 20px 22px;
  transition: transform var(--transicao), border-color var(--transicao);
}
.slot:hover { transform: translateY(-4px); border-color: rgba(45, 232, 255, .45); }
.slot::before {
  content: ""; position: absolute; top: 0; bottom: 0; left: 0; width: 6px; opacity: .55;
  background: repeating-linear-gradient(180deg, var(--lima) 0 10px, var(--asfalto) 10px 20px);
}
.lane-num { position: absolute; top: 14px; right: 16px; font-family: "Orbitron", sans-serif; font-weight: 800; font-size: 1.5rem; color: var(--ciao); opacity: .85; letter-spacing: 1px; }
.slot-head { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; padding-left: 10px; }
.slot-capa { width: 64px; height: 64px; flex: 0 0 auto; border-radius: 12px; overflow: hidden; border: 1px solid var(--linha); background: var(--asfalto-2); }
.slot-capa img { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.slot-id h3 { font-family: "Rajdhani", sans-serif; font-size: 1.16rem; line-height: 1.1; }
.slot-genero { font-size: .7rem; text-transform: uppercase; letter-spacing: 1.4px; color: var(--ciao); font-weight: 700; font-family: "Rajdhani", sans-serif; }
.medidores { list-style: none; display: grid; gap: 11px; padding-left: 10px; }
.medidores li { display: grid; grid-template-columns: 80px 1fr 34px; align-items: center; gap: 10px; }
.med-nome { font-family: "Rajdhani", sans-serif; font-weight: 600; font-size: .72rem; text-transform: uppercase; letter-spacing: .7px; color: var(--texto-suave); }
.med-bar { position: relative; height: 9px; border-radius: 5px; background: var(--linha); overflow: hidden; }
.med-bar i { position: absolute; inset: 0; width: 0; border-radius: 5px; background: linear-gradient(90deg, var(--coral), var(--lima)); transition: width 1.1s cubic-bezier(.2, .7, .2, 1); transition-delay: calc(var(--pos, 1) * .05s); }
.grelha.ativa .med-bar i { width: var(--v); }
.med-val { font-family: "Orbitron", sans-serif; font-weight: 700; font-size: .9rem; color: var(--lima); text-align: right; }
.grelha-legenda { text-align: center; color: var(--texto-suave); font-size: .85rem; margin-top: 28px; }

/* =====================================================================
   AJUSTES DE CENTRAGEM / ALINHAMENTO
   ===================================================================== */
.grid-jogos { display: flex; flex-wrap: wrap; justify-content: center; gap: 24px; }
.grid-jogos .jogo { flex: 1 1 300px; max-width: 360px; }
.jogo-capa img { object-position: center; }

/* =====================================================================
   RESPONSIVO — barra lateral colapsa para tira superior / off-canvas
   ===================================================================== */
@media (max-width: 900px) {
  .trilho {
    flex-direction: row; align-items: center; justify-content: flex-start;
    top: 0; left: 0; right: 0; bottom: auto; width: auto; height: 60px;
    padding: 0 16px; gap: 12px; overflow: visible;
    border-right: 0; border-bottom: 1px solid var(--linha);
  }
  .trilho-marca { flex-direction: row; gap: 10px; margin-right: auto; }
  .trilho-marca .logo { width: 34px; height: 34px; }
  .trilho-wordmark { display: inline; font-family: "Orbitron", sans-serif; font-weight: 800; font-size: 1rem; letter-spacing: .5px; color: var(--branco); }
  .rail-nav {
    position: fixed; top: 60px; left: 0; right: 0; margin-top: 0;
    flex-direction: column; gap: 4px; padding: 14px 18px 20px;
    background: var(--asfalto-2); border-bottom: 1px solid var(--linha);
    transform: translateY(-135%); transition: transform var(--transicao);
    max-height: calc(100vh - 60px); overflow-y: auto;
  }
  .rail-nav.aberto { transform: translateY(0); }
  .rail-nav a { flex-direction: row; justify-content: flex-start; gap: 14px; padding: 12px 14px; font-size: .98rem; letter-spacing: .4px; }
  .rail-nav a svg { width: 20px; height: 20px; }
  .trilho-cta { margin-top: 0; width: auto; flex-direction: row; gap: 8px; padding: 9px 15px; font-size: .72rem; }
  .palco { margin-left: 0; padding-top: 60px; }
}
@media (max-width: 760px) {
  .grelha-slots { grid-template-columns: 1fr; }
  .slot:nth-child(even) { margin-top: 0; }
  .medidores li { grid-template-columns: 72px 1fr 30px; }
}
@media (max-width: 560px) {
  .rail-card { flex-basis: clamp(200px, 80%, 240px); }
  .trilho-cta span { display: none; }
  .trilho-cta { padding: 9px 11px; }
}

@media (prefers-reduced-motion: reduce) { * { scroll-behavior: auto !important; animation: none !important; transition: none !important; } }
