/* ==========================================================================
   GasLab – skupni slog za registracijo in lestvico (high score)
   Vizualno usklajeno z igrami GasLab (barve, tipografija, gumbi, robovi).
   ========================================================================== */
:root{
  --red:#ED3237; --red-dark:#c41f24;
  --ink:#373435; --ink-2:#2a2829; --ink-3:#1d1b1c;
  --paper:#ffffff;
  --ok:#27c08a; --warn:#ffb020; --gold:#f4c245; --silver:#c9d1d9; --bronze:#d98a4b;
  --line:rgba(255,255,255,.10);
  --txt:#f3f1f2; --txt-dim:rgba(243,241,242,.62);
  --font:"Open Sans","Segoe UI",system-ui,-apple-system,Roboto,sans-serif;
  --r-sm:8px; --r-md:14px; --r-lg:22px; --r-pill:999px;
  --shadow-1:0 2px 6px rgba(0,0,0,.18);
  --shadow-2:0 8px 24px rgba(0,0,0,.28);
  --shadow-3:0 18px 50px rgba(0,0,0,.45);
  --ring:0 0 0 3px rgba(237,50,55,.35);
}
*{box-sizing:border-box}
html,body{margin:0; height:100%}
body{
  font-family:var(--font); color:var(--txt); background:var(--ink-3);
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(237,50,55,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(237,50,55,.08), transparent 60%);
  min-height:100%; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
.wrap{max-width:1200px; margin:0 auto; padding:24px clamp(16px,3vw,40px) 120px}

/* ---- Top bar / brand ---------------------------------------------------- */
.topbar{display:flex; align-items:center; gap:18px; padding:6px 0 22px}
.brand-plate{display:inline-flex; align-items:center; gap:14px; background:var(--paper);
  padding:12px 22px 12px 16px; border-radius:var(--r-pill); box-shadow:var(--shadow-2)}
.brand-logo{display:block; height:52px; width:auto}
.topbar .spacer{flex:1}
.topbar .tag{font-size:14px; letter-spacing:.16em; text-transform:uppercase; color:var(--txt-dim); font-weight:800}
.lang-switch{display:inline-flex; gap:4px; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:999px; padding:4px}
.lang-switch button{appearance:none; border:0; background:transparent; color:var(--txt-dim); font-weight:800; font-size:14px; padding:7px 14px; border-radius:999px; cursor:pointer; font-family:inherit; transition:background .15s,color .15s}
.lang-switch button.on{background:var(--red); color:#fff}

/* ---- Headings ----------------------------------------------------------- */
h1{font-size:clamp(26px,4vw,40px); font-weight:800; margin:0 0 6px; letter-spacing:.01em}
h1 b{color:var(--red)}
.sub{color:var(--txt-dim); font-size:clamp(15px,1.6vw,18px); margin:0 0 26px}
h2{font-size:20px; font-weight:800; margin:0}

/* ---- Buttons ------------------------------------------------------------ */
.btn{font-family:inherit; font-weight:800; font-size:17px; border:0; cursor:pointer;
  border-radius:var(--r-pill); padding:14px 26px; color:#fff; background:var(--ink-2);
  box-shadow:var(--shadow-1); transition:transform .12s ease, background .15s ease, box-shadow .15s; text-decoration:none; display:inline-flex; align-items:center; gap:10px}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--red)}
.btn.primary:hover{background:var(--red-dark)}
.btn.ghost{background:rgba(255,255,255,.06); border:1px solid var(--line)}
.btn.lg{font-size:20px; padding:18px 38px}
.btn:focus-visible{outline:none; box-shadow:var(--ring)}

/* ---- Cards / panels ----------------------------------------------------- */
.grid{display:grid; gap:20px}
.boards{grid-template-columns:repeat(2,1fr)}
@media (max-width:820px){ .boards{grid-template-columns:1fr} }
.panel{background:linear-gradient(180deg, var(--ink-2), #232021); border:1px solid var(--line);
  border-radius:var(--r-lg); padding:20px 22px; box-shadow:var(--shadow-2)}
.panel.total{grid-column:1 / -1; border-color:rgba(237,50,55,.4);
  background:linear-gradient(180deg, #2c2122, #241d1e)}
.panel-head{display:flex; align-items:center; gap:12px; margin-bottom:14px}
.panel-head .ic{font-size:26px; width:46px; height:46px; display:grid; place-items:center;
  background:rgba(237,50,55,.14); border-radius:var(--r-md)}
.panel-head .full{margin-left:auto; font-size:14px; font-weight:800; color:var(--txt-dim);
  text-decoration:none; border:1px solid var(--line); padding:7px 12px; border-radius:var(--r-pill)}
.panel-head .full:hover{color:#fff; border-color:var(--red)}

/* ---- Leaderboard table -------------------------------------------------- */
.lb{width:100%; border-collapse:collapse; font-size:16px}
.lb th{ text-align:left; font-size:12px; letter-spacing:.12em; text-transform:uppercase;
  color:var(--txt-dim); font-weight:800; padding:0 10px 10px}
.lb td{padding:11px 10px; border-top:1px solid var(--line); vertical-align:middle}
.lb tr:first-child td{border-top:0}
.lb .rank{width:46px; font-weight:800; color:var(--txt-dim); text-align:center}
.lb .pts{font-weight:800; color:var(--red); white-space:nowrap; text-align:right}
.lb .date{color:var(--txt-dim); white-space:nowrap; font-size:14px; text-align:right}
.lb .nick{font-weight:700}
.lb .badge{display:inline-grid; place-items:center; width:30px; height:30px; border-radius:50%;
  font-size:14px; font-weight:800; color:#1d1b1c}
.lb .r1 .badge{background:var(--gold)} .lb .r2 .badge{background:var(--silver)} .lb .r3 .badge{background:var(--bronze)}
.lb-empty{color:var(--txt-dim); padding:18px 10px; font-style:italic}

/* ---- Forms -------------------------------------------------------------- */
/* registracijski stolpec – logo, naslov in obrazec poravnani na isti levi rob */
.reg-col{max-width:560px; margin:0 auto}
.reg-col .formcard{margin:0}
.formcard{max-width:560px; margin:0 auto; background:linear-gradient(180deg, var(--ink-2), #232021);
  border:1px solid var(--line); border-radius:var(--r-lg); padding:30px clamp(20px,4vw,38px); box-shadow:var(--shadow-3)}
.field{margin-bottom:18px}
.field label{display:block; font-weight:800; margin-bottom:8px; font-size:15px}
.field input{width:100%; font-family:inherit; font-size:18px; color:var(--txt);
  background:var(--ink-3); border:1.5px solid var(--line); border-radius:var(--r-md); padding:14px 16px}
.field input:focus{outline:none; border-color:var(--red); box-shadow:var(--ring)}
.field .hint{color:var(--txt-dim); font-size:13px; margin-top:6px}
.consent{display:flex; gap:12px; align-items:flex-start; background:rgba(255,255,255,.04);
  border:1px solid var(--line); border-radius:var(--r-md); padding:14px 16px; margin:6px 0 22px; font-size:14px; line-height:1.5; color:var(--txt-dim)}
.consent input{width:22px; height:22px; flex:none; margin-top:2px; accent-color:var(--red)}
.err{color:#ff9a9d; font-size:14px; font-weight:700; min-height:18px; margin:4px 0 12px}
.switch-line{margin-top:18px; text-align:center; color:var(--txt-dim); font-size:14px}
.switch-line a{color:#fff; font-weight:800}

/* ---- Modal -------------------------------------------------------------- */
.modal{position:fixed; inset:0; z-index:200; display:none; place-items:center; padding:24px;
  background:rgba(18,16,17,.7); -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px)}
.modal.open{display:grid}
.modal .box{background:var(--ink-2); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:30px; max-width:520px; width:100%; text-align:center; box-shadow:var(--shadow-3)}
.modal .opt{display:flex; gap:14px; flex-direction:column; margin-top:18px}

/* ---- EU credit (discreet, kot v igrah) ---------------------------------- */
.eu-credit{position:fixed; right:20px; bottom:14px; height:64px; width:auto; opacity:.5; pointer-events:none; z-index:30}

/* ---- Misc --------------------------------------------------------------- */
.note{font-size:13px; color:var(--txt-dim); line-height:1.55}
.row{display:flex; gap:12px; flex-wrap:wrap; align-items:center}
.center{text-align:center}
.toast{position:fixed; left:50%; bottom:30px; transform:translateX(-50%) translateY(20px);
  background:var(--ok); color:#08231a; font-weight:800; padding:14px 22px; border-radius:var(--r-pill);
  box-shadow:var(--shadow-2); opacity:0; transition:.25s; z-index:300}
.toast.show{opacity:1; transform:translateX(-50%) translateY(0)}
@keyframes pop{from{opacity:0; transform:scale(.96)} to{opacity:1; transform:scale(1)}}
.panel,.formcard{animation:pop .25s ease-out}
