/* ============================================================
   Zovio — holo glass UI (self-contained, no external CDN)
   ============================================================ */
/* Palette aliases now resolve from the shared theme tokens (theme.css,
   keyed on html[data-theme]). Loaded before this file; defaults to midnight. */
:root{
  --bg:var(--zt-bg); --bg2:var(--zt-bg2); --panel:var(--zt-glass);
  --panel-strong:var(--zt-glass-strong); --border:var(--zt-border);
  --border-strong:var(--zt-border-strong);
  --text:var(--zt-text); --muted:var(--zt-muted);
  --violet:var(--zt-accent); --indigo:var(--zt-accent2); --cyan:var(--zt-link);
  --emerald:var(--zt-emerald); --amber:var(--zt-amber); --rose:var(--zt-rose); --red:var(--zt-red);
  --shadow:var(--zt-shadow);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  min-height:100vh;color:var(--text);
  font-family:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:
    radial-gradient(900px 500px at 12% -8%, var(--zt-aurora2), transparent 60%),
    radial-gradient(900px 520px at 100% 0%, var(--zt-aurora3), transparent 55%),
    radial-gradient(700px 600px at 50% 120%, var(--zt-aurora1), transparent 60%),
    linear-gradient(160deg,var(--zt-bg2) 0%,var(--zt-bg) 55%,var(--zt-bg3) 100%);
  background-attachment:fixed;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--cyan);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:1080px;margin:0 auto;padding:20px 16px 80px}
.wrap-narrow{max-width:460px;margin:0 auto;padding:32px 16px 80px}

/* top bar */
.topbar{position:sticky;top:0;z-index:30;backdrop-filter:blur(18px);
  background:var(--zt-bar);border-bottom:1px solid var(--border)}
.topbar .inner{max-width:1080px;margin:0 auto;display:flex;align-items:center;
  gap:14px;padding:12px 16px}
.brand{font-weight:800;letter-spacing:.14em;font-size:18px;font-family:var(--zt-font-display);
  background:linear-gradient(90deg,var(--violet),var(--cyan));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.brand small{display:block;letter-spacing:.2em;font-size:8px;color:var(--muted)}
.spacer{flex:1}
.nav-link{color:var(--muted);font-size:13px;padding:7px 11px;border-radius:8px}
.nav-link:hover{color:#fff;background:var(--panel);text-decoration:none}
.nav-link.active{color:#fff;background:var(--panel-strong)}

/* wallet pill */
.wallet-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;
  border-radius:999px;border:1px solid var(--border-strong);
  background:linear-gradient(145deg,rgba(139,92,246,.22),rgba(56,189,248,.18));
  font-weight:700}
.wallet-pill .lbl{font-size:9px;color:var(--muted);letter-spacing:.12em;font-weight:600}
.wallet-pill .amt{font-size:15px;color:#fff}

/* glass */
.glass{background:var(--panel);border:1px solid var(--border);border-radius:16px;
  backdrop-filter:blur(20px);box-shadow:var(--shadow)}
.glass-strong{background:var(--panel-strong);border:1px solid var(--border-strong);
  border-radius:16px;backdrop-filter:blur(24px) saturate(160%);box-shadow:var(--shadow)}
.card{padding:18px 20px}
.h1{font-size:24px;font-weight:800;margin:0 0 4px;font-family:var(--zt-font-display)}
.h2{font-size:16px;font-weight:700;margin:0 0 10px}
.muted{color:var(--muted)}
.small{font-size:12px}
.center{text-align:center}
.row{display:flex;gap:12px;align-items:center}
.col{display:flex;flex-direction:column;gap:12px}
.mt{margin-top:16px}.mt2{margin-top:24px}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;font-weight:700;font-size:14px;cursor:pointer;
  padding:11px 18px;border-radius:11px;border:1px solid var(--border-strong);
  background:var(--panel-strong);color:#fff;transition:transform .06s,filter .15s}
.btn:hover{filter:brightness(1.12);text-decoration:none}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-primary{border:none;color:var(--zt-on-accent);
  background:var(--zt-grad-primary)}
.btn-emerald{border:none;color:#06281d;background:linear-gradient(145deg,#34d399,#10b981)}
.btn-rose{border:none;color:#2a0710;background:linear-gradient(145deg,#fb7185,#ef4444)}
.btn-ghost{background:transparent}
.btn-block{display:flex;width:100%}
.btn-sm{padding:7px 12px;font-size:12px;border-radius:9px}

/* forms */
label{display:block;font-size:12px;color:var(--muted);margin:0 0 6px;font-weight:600}
.input,select.input,textarea.input{width:100%;padding:12px 14px;border-radius:11px;
  background:rgba(0,0,0,.28);border:1px solid var(--border);color:#fff;
  font-family:inherit;font-size:15px;outline:none}
.input:focus{border-color:var(--border-strong);box-shadow:0 0 0 3px rgba(139,92,246,.18)}
.field{margin-bottom:14px}

/* badges */
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;
  font-size:11px;font-weight:700;border:1px solid var(--border)}
.badge::before{content:"";width:7px;height:7px;border-radius:50%;background:currentColor}
.badge-emerald{color:#6ee7b7;background:rgba(16,185,129,.12)}
.badge-amber{color:#fcd34d;background:rgba(245,158,11,.12)}
.badge-rose{color:#fda4af;background:rgba(239,68,68,.12)}
.badge-slate{color:#cbd5e1;background:rgba(148,163,184,.12)}
.badge-cyan{color:#7dd3fc;background:rgba(56,189,248,.12)}

/* game grid */
.grid{display:grid;gap:14px;grid-template-columns:repeat(2,1fr)}
@media(min-width:640px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:980px){.grid{grid-template-columns:repeat(4,1fr)}}
.tile{position:relative;height:150px;border-radius:16px;overflow:hidden;
  border:1px solid var(--border);background:var(--zt-bg2);display:block;
  box-shadow:var(--shadow);transition:transform .1s,border-color .15s}
.tile:hover{transform:translateY(-3px);border-color:var(--border-strong);text-decoration:none}
.tile.is-off{opacity:.45;pointer-events:none;filter:grayscale(.4)}
.tile .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.tile .ov{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,7,15,.15),rgba(8,7,15,.82))}
.tile .nm{position:absolute;left:12px;right:12px;bottom:10px;font-weight:800;
  font-size:15px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.6)}
.tile .kick{position:absolute;left:12px;top:10px}
.tile .orb{position:absolute;right:12px;top:12px;width:9px;height:9px;border-radius:50%;
  background:var(--emerald);box-shadow:0 0 0 4px rgba(16,185,129,.18)}

/* tables */
.table{width:100%;border-collapse:collapse;font-size:13px}
.table th,.table td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--border)}
.table th{color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.06em}
.table tr:hover td{background:rgba(255,255,255,.03)}
.amt-pos{color:#6ee7b7}.amt-neg{color:#fda4af}

/* flash */
.flash{padding:12px 16px;border-radius:12px;margin-bottom:16px;font-size:14px;
  border:1px solid var(--border)}
.flash-error{background:rgba(239,68,68,.12);border-color:rgba(239,68,68,.4);color:#fecaca}
.flash-success{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.4);color:#a7f3d0}
.flash-info{background:rgba(56,189,248,.12);border-color:rgba(56,189,248,.4);color:#bae6fd}

/* dev banner */
.devbanner{background:repeating-linear-gradient(45deg,#1a1606,#1a1606 12px,#231d07 12px,#231d07 24px);
  color:#fcd34d;font-size:12px;text-align:center;padding:6px;border-bottom:1px solid #3a3206;letter-spacing:.04em}

/* misc */
.preset{padding:8px 12px;border-radius:10px;border:1px solid var(--border);
  background:rgba(0,0,0,.25);cursor:pointer;font-weight:700;font-size:13px;color:#fff}
.preset:hover{border-color:var(--border-strong)}
.divider{height:1px;background:var(--border);margin:18px 0}
.kbd{font-size:11px;color:var(--muted)}
.stat{padding:16px 18px}
.stat .n{font-size:26px;font-weight:800}
.stat .l{font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}

/* ============================================================
   Admin backoffice — mobile layer
   ============================================================ */
/* Desktop default: nav is an inline wrapping row, burger hidden. */
.admnav{display:flex;align-items:center;flex-wrap:wrap;gap:2px}
.admnav-burger{display:none}

@media (max-width:760px){
  /* anchor the dropdown to the bar */
  .topbar .inner{position:relative;gap:8px;padding:10px 14px}
  .brand{font-size:16px}

  /* hamburger button (animates to an X when open) */
  .admnav-burger{display:inline-flex;flex-direction:column;justify-content:center;
    gap:4px;width:40px;height:40px;padding:9px;border-radius:10px;cursor:pointer;
    border:1px solid var(--border);background:var(--panel)}
  .admnav-burger span{display:block;height:2px;border-radius:2px;background:var(--text);
    transition:transform .18s,opacity .18s}
  #admnav-toggle:checked ~ .admnav-burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  #admnav-toggle:checked ~ .admnav-burger span:nth-child(2){opacity:0}
  #admnav-toggle:checked ~ .admnav-burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

  /* collapsed nav → full-width dropdown panel */
  .admnav{position:absolute;top:100%;left:0;right:0;z-index:29;display:none;
    flex-direction:column;align-items:stretch;flex-wrap:nowrap;gap:4px;
    margin-top:1px;padding:10px;
    background:color-mix(in srgb, var(--zt-bg2) 92%, transparent);
    backdrop-filter:blur(28px) saturate(140%);
    border:1px solid var(--border-strong);border-top:none;
    border-radius:0 0 14px 14px;box-shadow:var(--shadow)}
  #admnav-toggle:checked ~ .admnav{display:flex}
  .admnav .nav-link{font-size:15px;padding:12px 14px;border-radius:10px}

  /* settings/toggle card lists: one column on phones so cards don't sit
     two-up at mismatched heights (some have a balance row, some don't) */
  .card-grid{grid-template-columns:1fr}

  /* wide tables scroll horizontally instead of getting crushed/clipped */
  .glass:has(> .table){overflow-x:auto !important;-webkit-overflow-scrolling:touch}
  .glass:has(> .table) .table{min-width:560px}
  .table th,.table td{padding:9px 10px}
}
