/* ============================================================
   Concurso Redragon · 10 Anos — identidade esports (dark/crimson)
   Rajdhani (display) + Barlow (texto), self-hosted.
   ============================================================ */
@font-face{font-family:'Rajdhani';font-style:normal;font-weight:600;font-display:swap;src:url(fonts/Rajdhani-600.woff2) format('woff2')}
@font-face{font-family:'Rajdhani';font-style:normal;font-weight:700;font-display:swap;src:url(fonts/Rajdhani-700.woff2) format('woff2')}
@font-face{font-family:'Barlow';font-style:normal;font-weight:400;font-display:swap;src:url(fonts/Barlow-400.woff2) format('woff2')}
@font-face{font-family:'Barlow';font-style:normal;font-weight:500;font-display:swap;src:url(fonts/Barlow-500.woff2) format('woff2')}
@font-face{font-family:'Barlow';font-style:normal;font-weight:600;font-display:swap;src:url(fonts/Barlow-600.woff2) format('woff2')}

:root{
  --red:#e4002b; --red-2:#ff2b45; --red-3:#ff6076; --glow:rgba(228,0,43,.45);
  --bg:#08080a; --bg-2:#0d0d10; --panel:#121218; --panel-2:#17171e;
  --line:#24242c; --line-2:#34343f;
  --text:#f4f4f6; --text-2:#a6a6b2; --text-3:#6b6b77;
  --ok:#2fd27a; --err:#ff5470;
  --disp:'Rajdhani',-apple-system,BlinkMacSystemFont,sans-serif;
  --body:'Barlow',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--body); color:var(--text); font-size:15px; line-height:1.55;
  background:var(--bg);
  background-image:
    radial-gradient(900px 460px at 50% -160px, rgba(228,0,43,.20), transparent 70%),
    radial-gradient(700px 500px at 100% 8%, rgba(228,0,43,.07), transparent 60%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased; padding:0 16px 70px;
}
.wrap{max-width:700px;margin:0 auto}
a{color:var(--red-3);text-decoration:none}
a:hover{color:var(--red-2)}
::selection{background:var(--red);color:#fff}

/* diminui o brilho quando rola, dá foco no conteúdo */
h1,h2,h3{font-family:var(--disp);font-weight:700;letter-spacing:.01em;line-height:1.05;margin:0}

/* ---------------- TOPBAR ---------------- */
.topbar{position:sticky;top:0;z-index:50;background:rgba(8,8,10,.82);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar-in{display:flex;align-items:center;justify-content:space-between;height:58px}
.topbar .brand{font-family:var(--disp);font-weight:700;font-size:19px;letter-spacing:.4em;color:#fff;text-indent:.4em}
.topbar .brand::before{content:'';display:inline-block;width:9px;height:9px;margin-right:13px;background:var(--red);transform:rotate(45deg);box-shadow:0 0 10px var(--glow);vertical-align:middle}
.topnav{display:flex;align-items:center;gap:6px}
.tn-link{background:transparent;border:1px solid transparent;color:var(--text-2);font-family:var(--disp);font-weight:600;font-size:13.5px;letter-spacing:.05em;text-transform:uppercase;padding:8px 13px;border-radius:8px;cursor:pointer;transition:.15s}
.tn-link:hover{color:#fff;border-color:var(--line-2)}
.tn-strong{border-color:var(--red);color:#fff}
.tn-strong:hover{background:var(--red);border-color:var(--red)}
.tn-user{color:var(--text-3);font-size:13px;max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:4px}
@media(max-width:560px){.tn-user{display:none}.tn-link{padding:8px 10px;font-size:12.5px}}

/* ---------------- HERO (2 colunas) ---------------- */
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:32px;align-items:end;padding:54px 4px 30px}
.kicker{display:inline-flex;align-items:center;gap:11px;font-family:var(--disp);font-weight:600;font-size:12.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--red-3);margin-bottom:14px}
.kicker::before{content:'';width:28px;height:2px;background:var(--red)}
.hero h1{font-size:clamp(38px,7vw,66px);text-transform:uppercase;
  background:linear-gradient(180deg,#fff 46%,#cfcfd6);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 46px rgba(228,0,43,.22)}
.hero h1 em{font-style:normal;color:var(--red-2);-webkit-text-fill-color:var(--red-2);text-shadow:0 0 28px var(--glow)}
.hero-r{padding-bottom:8px}
.lede{font-family:var(--body);color:var(--text-2);font-size:16px;margin:0}
.hero-meta{display:flex;gap:28px;margin-top:20px}
.hero-meta div{display:flex;flex-direction:column;gap:2px}
.hero-meta span{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);font-weight:600}
.hero-meta strong{font-family:var(--disp);font-weight:600;font-size:16px;color:#fff}
@media(max-width:640px){.hero{grid-template-columns:1fr;gap:16px;align-items:start;padding-top:34px}}

/* ---------------- PROMO (countdown | prêmio, tabulado) ---------------- */
.promo{display:grid;grid-template-columns:auto 1fr;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 18px 50px -22px rgba(0,0,0,.9)}
.promo-col{padding:18px 22px}
.promo-cd{border-right:1px solid var(--line)}
.promo-label{font-family:var(--disp);font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--red-3);margin-bottom:12px}
.countdown{display:flex;gap:8px}
.cd{min-width:56px;text-align:center;background:#0b0b0e;border:1px solid var(--line);border-radius:8px;padding:8px 6px 6px}
.cd b{font-family:var(--disp);font-weight:700;font-size:26px;color:#fff;display:block;line-height:1;font-variant-numeric:tabular-nums}
.cd span{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-3);font-weight:600}
.prize{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:9px 18px}
.prize li{font-family:var(--disp);font-weight:600;font-size:15px;color:#fff;position:relative;padding-left:16px;text-transform:uppercase;letter-spacing:.02em;line-height:1.15}
.prize li::before{content:'';position:absolute;left:0;top:6px;width:7px;height:7px;background:var(--red);transform:rotate(45deg);box-shadow:0 0 8px var(--glow)}
.prize li span{display:block;font-family:var(--body);font-weight:500;font-size:11px;letter-spacing:.05em;color:var(--text-3);text-transform:none}
@media(max-width:640px){.promo{grid-template-columns:1fr}.promo-cd{border-right:none;border-bottom:1px solid var(--line)}}
@media(max-width:420px){.cd{min-width:48px}.cd b{font-size:21px}}

/* ---------------- PAINÉIS (cards) ---------------- */
.card{position:relative;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:12px;padding:22px 20px;margin-top:14px;box-shadow:0 18px 50px -22px rgba(0,0,0,.9),inset 0 1px 0 rgba(255,255,255,.025);overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--red),transparent);opacity:.8}
.card h2{font-size:22px;text-transform:uppercase;margin-bottom:4px}
.card h2::after{content:'';display:block;width:34px;height:3px;background:var(--red);border-radius:2px;margin-top:8px}
.card h3{font-size:17px;text-transform:uppercase;color:#fff;margin:2px 0 10px}
.hint{color:var(--text-3);font-size:13px;margin:6px 0}

/* ---------------- inputs ---------------- */
label{display:block;font-family:var(--disp);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-2);margin:14px 0 6px}
input[type=text],input[type=email],input[type=password],input[type=url]{
  width:100%;padding:12px 13px;background:#0b0b0e;border:1px solid var(--line-2);border-radius:9px;color:var(--text);font-family:var(--body);font-size:15px;outline:none;transition:border-color .16s,box-shadow .16s,background .16s}
input::placeholder{color:#54545e}
input:focus{border-color:var(--red);background:#0d0d11;box-shadow:0 0 0 3px rgba(228,0,43,.16)}
input.good{border-color:var(--ok)} input.bad{border-color:var(--err)}

/* ---------------- botões ---------------- */
.btn{position:relative;width:100%;padding:13px;border:none;border-radius:10px;
  background:linear-gradient(180deg,var(--red-2),var(--red));color:#fff;
  font-family:var(--disp);font-weight:700;font-size:16px;letter-spacing:.09em;text-transform:uppercase;cursor:pointer;overflow:hidden;
  box-shadow:0 8px 22px -8px var(--glow),inset 0 1px 0 rgba(255,255,255,.28);transition:transform .08s,box-shadow .18s,filter .18s;margin-top:14px}
.btn::after{content:'';position:absolute;top:0;left:-60%;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);transform:skewX(-20deg);transition:left .5s}
.btn:hover{box-shadow:0 12px 30px -8px var(--glow),inset 0 1px 0 rgba(255,255,255,.28)}
.btn:hover::after{left:130%}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.55;cursor:default;box-shadow:none}
.btn:disabled::after{display:none}
.btn.ghost{background:transparent;border:1px solid var(--line-2);color:var(--text);box-shadow:none}
.btn.ghost:hover{border-color:var(--red);color:#fff}
.btn.btn-sm{width:auto;padding:8px 16px;font-size:13px;margin:0}

/* ---------------- auth tabs ---------------- */
.auth .atabs{display:flex;gap:5px;background:#0b0b0e;border:1px solid var(--line);padding:4px;border-radius:10px;margin-bottom:16px}
.atab{flex:1;padding:10px;border:none;background:transparent;color:var(--text-3);font-family:var(--disp);font-weight:600;font-size:14px;letter-spacing:.06em;text-transform:uppercase;border-radius:7px;cursor:pointer;transition:.15s}
.atab.on{background:linear-gradient(180deg,var(--red-2),var(--red));color:#fff;box-shadow:0 6px 16px -8px var(--glow)}
.linkline{text-align:center;margin-top:14px;font-size:13.5px}
.consent{display:flex;gap:10px;align-items:flex-start;font-family:var(--body);font-size:12.5px;color:var(--text-2);font-weight:400;margin:13px 0 0;cursor:pointer;line-height:1.45}
.consent input{margin-top:1px;accent-color:var(--red);width:17px;height:17px;flex:none}

/* ---------------- header do portal ---------------- */
.phead{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--line);font-size:13.5px;color:var(--text-2)}
.vbanner{background:linear-gradient(180deg,rgba(255,176,80,.10),rgba(255,176,80,.05));border:1px solid rgba(255,176,80,.4);color:#ffcb8a;border-radius:9px;padding:11px 13px;font-size:12.5px;margin-bottom:16px}

/* ---------------- game tiles (angular / neon) ---------------- */
.gtabs{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin:4px 0 8px}
.gtile{--gc:#e4002b;position:relative;height:98px;border:1px solid var(--line-2);border-radius:11px;cursor:pointer;color:#fff;overflow:hidden;
  display:flex;align-items:flex-end;padding:11px;text-align:left;
  background:radial-gradient(120% 90% at 12% 0%, color-mix(in srgb,var(--gc) 26%, transparent), transparent 60%),linear-gradient(180deg,#15151b,#0c0c10);
  clip-path:polygon(0 0,100% 0,100% calc(100% - 15px),calc(100% - 15px) 100%,0 100%);
  transition:transform .12s,box-shadow .2s,border-color .2s}
.gtile .gimg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.5}
.gtile::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(0,0,0,.72))}
.gtile::after{content:'';position:absolute;left:0;bottom:0;width:100%;height:3px;background:var(--gc);box-shadow:0 0 12px var(--gc);opacity:.9}
.gtile:hover{transform:translateY(-3px);border-color:var(--red);box-shadow:0 14px 30px -14px var(--glow)}
.gtile.on{border-color:var(--red-2);box-shadow:0 0 0 1px var(--red-2),0 14px 34px -14px var(--glow)}
.gtile.on::after{background:var(--red-2);box-shadow:0 0 16px var(--red-2)}
.gname{position:relative;z-index:1;font-family:var(--disp);font-weight:700;font-size:16px;letter-spacing:.02em;text-transform:uppercase;text-shadow:0 2px 8px rgba(0,0,0,.9);line-height:1.05}
.gcount{position:absolute;top:9px;right:9px;z-index:1;background:var(--red);color:#fff;font-family:var(--disp);font-weight:700;font-size:11px;letter-spacing:.04em;padding:2px 8px;border-radius:999px;box-shadow:0 4px 10px -3px var(--glow)}

/* ---------------- área de envio ---------------- */
.gamearea{border-top:1px solid var(--line);margin-top:16px;padding-top:16px}
.slots{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:10px}
.slot{position:relative;border:1px solid var(--line-2);border-radius:10px;padding:11px;background:#0b0b0e;min-height:100px}
.slot.empty{display:flex;flex-direction:column;gap:9px;justify-content:center;border-style:dashed}
.slot.filled{display:flex;gap:11px;align-items:center;background:linear-gradient(180deg,var(--panel-2),var(--panel))}
.slot.filled img{width:100px;height:56px;object-fit:cover;border-radius:7px;flex:none;border:1px solid var(--line)}
.sinfo{min-width:0;flex:1}
.stitle{font-size:12.5px;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:9px}
.del{background:transparent;border:1px solid var(--err);color:var(--err);border-radius:7px;padding:6px 13px;font-family:var(--disp);font-weight:600;font-size:12px;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;transition:.15s}
.del:hover{background:var(--err);color:#0b0b0e}

/* ---------------- como funciona (steps) ---------------- */
.steps{margin:0;padding:0;list-style:none;counter-reset:s}
.steps li{counter-increment:s;position:relative;padding:12px 0 12px 46px;color:var(--text-2);font-size:14.5px;border-bottom:1px solid var(--line)}
.steps li:last-child{border-bottom:none}
.steps li::before{content:counter(s);position:absolute;left:0;top:9px;width:30px;height:30px;border-radius:8px;background:linear-gradient(180deg,var(--red-2),var(--red));color:#fff;font-family:var(--disp);font-weight:700;font-size:15px;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 14px -6px var(--glow)}

.pwchg{margin-top:18px;padding-top:14px;border-top:1px solid var(--line);font-size:13px}

/* ---------------- hint "selecione um jogo" ---------------- */
.hint.arrow{text-align:center;padding:20px 0 6px;font-size:14px;color:var(--text-2)}

/* ---------------- modal ---------------- */
.modal-bk{position:fixed;inset:0;z-index:100;background:rgba(4,4,6,.72);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:20px;animation:mfade .16s ease}
@keyframes mfade{from{opacity:0}}
.modal-card{position:relative;width:100%;max-width:390px;background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line-2);border-radius:13px;padding:26px 22px 22px;box-shadow:0 30px 80px -18px rgba(0,0,0,.95);animation:mrise .18s ease}
@keyframes mrise{from{transform:translateY(10px);opacity:.6}}
.modal-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--red),transparent)}
.modal-card h3{font-size:21px;text-transform:uppercase;margin-bottom:6px}
.modal-card input{margin-top:10px}
.modal-x{position:absolute;top:9px;right:13px;background:none;border:none;color:var(--text-3);font-size:27px;line-height:1;cursor:pointer;transition:.15s}
.modal-x:hover{color:#fff}

/* ---------------- feedback ---------------- */
.msg{margin-top:12px;font-size:13.5px;min-height:16px;text-align:center;font-weight:500}
.msg.err{color:var(--err)} .msg.ok{color:var(--ok)}
.done{text-align:center}
.done .check{width:64px;height:64px;margin:4px auto 12px;border-radius:50%;background:radial-gradient(circle,rgba(47,210,122,.18),transparent);border:1px solid var(--ok);color:var(--ok);font-size:30px;line-height:62px;box-shadow:0 0 30px -6px rgba(47,210,122,.4)}
.spinner{width:38px;height:38px;border:3px solid var(--line-2);border-top-color:var(--red);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}
.foot{text-align:center;color:var(--text-3);font-size:11.5px;margin-top:28px;letter-spacing:.02em}

@media(max-width:520px){
  .hero{padding-top:34px}
  .slots{grid-template-columns:1fr}
  .slot.filled img{width:84px;height:48px}
  .cd{min-width:52px} .cd b{font-size:20px}
}
