/* ============================================================================
   JOHN'S SLOTS — neon-luxe / retro-futuristic theme
   ========================================================================== */
:root{
  --bg:#070512;
  --bg-2:#0c0a1f;
  --gold:#ffd35a;
  --gold-2:#f2a23b;
  --violet:#8a4bff;
  --violet-2:#bd8bff;
  --magenta:#ff3ea5;
  --cyan:#21e8c9;
  --ink:#f4effe;
  --muted:#a89fce;
  --line:rgba(255,255,255,.09);
  --glass:rgba(255,255,255,.045);
  --glass-2:rgba(255,255,255,.08);
  --danger:#ff5274;
  --radius:18px;
  --shadow:0 30px 80px -30px rgba(0,0,0,.75);
  --font-display:"Unbounded",system-ui,sans-serif;
  --font-label:"Syne",system-ui,sans-serif;
  --font-body:"Sora",system-ui,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
a{color:inherit}
button{font-family:inherit;cursor:pointer}
input,textarea,select{font-family:inherit}
::selection{background:var(--magenta);color:#fff}

/* ---------- animated background -------------------------------------- */
.bg{position:fixed;inset:0;z-index:-3;background:
  radial-gradient(60% 50% at 15% 10%, rgba(138,75,255,.42), transparent 60%),
  radial-gradient(55% 55% at 85% 20%, rgba(255,62,165,.32), transparent 60%),
  radial-gradient(60% 60% at 80% 95%, rgba(33,232,201,.22), transparent 60%),
  radial-gradient(50% 50% at 30% 95%, rgba(255,211,90,.20), transparent 60%),
  linear-gradient(160deg,var(--bg),var(--bg-2));
}
.bg::before{ /* drifting conic shimmer */
  content:"";position:absolute;inset:-30%;
  background:conic-gradient(from 0deg,transparent,rgba(255,211,90,.08),transparent 25%,rgba(138,75,255,.10),transparent 55%,rgba(33,232,201,.07),transparent 80%);
  animation:spin 60s linear infinite;filter:blur(40px);opacity:.7;
}
.grain{position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
@keyframes spin{to{transform:rotate(360deg)}}

/* floating chips */
.chips{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.chips i{position:absolute;width:42px;height:42px;border-radius:50%;
  border:3px dashed rgba(255,255,255,.25);opacity:.15;
  background:radial-gradient(circle at 30% 30%,rgba(255,211,90,.5),transparent 70%);
  animation:float 18s linear infinite;}
.chips i:nth-child(1){left:8%;top:110%;animation-duration:22s}
.chips i:nth-child(2){left:24%;top:120%;animation-duration:28s;animation-delay:-6s}
.chips i:nth-child(3){left:48%;top:115%;animation-duration:20s;animation-delay:-3s}
.chips i:nth-child(4){left:68%;top:125%;animation-duration:30s;animation-delay:-12s}
.chips i:nth-child(5){left:86%;top:118%;animation-duration:24s;animation-delay:-9s}
@keyframes float{to{transform:translateY(-140vh) rotate(540deg)}}

/* ---------- shared bits ---------------------------------------------- */
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
.glass{background:var(--glass);border:1px solid var(--line);border-radius:var(--radius);
  backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);
  box-shadow:var(--shadow);}
.label{font-family:var(--font-label);text-transform:uppercase;letter-spacing:.22em;font-weight:700;
  font-size:.72rem;color:var(--muted)}
.glow{background:linear-gradient(90deg,#fff,var(--gold) 40%,var(--gold-2));-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 18px rgba(255,211,90,.35))}
.hint{color:var(--muted);font-size:.9rem}
.center{text-align:center}
.hidden{display:none!important}

.btn{border:none;border-radius:14px;padding:13px 22px;font-weight:700;font-size:.96rem;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#241400;
  box-shadow:0 12px 30px -10px rgba(255,180,60,.7),inset 0 1px 0 rgba(255,255,255,.6);
  transition:transform .15s ease,box-shadow .15s ease,filter .15s ease;letter-spacing:.01em}
.btn:hover{transform:translateY(-2px);box-shadow:0 20px 40px -10px rgba(255,180,60,.9)}
.btn:active{transform:translateY(0)}
.btn:disabled{filter:grayscale(.6) brightness(.7);cursor:not-allowed;transform:none;box-shadow:none}
.btn.ghost{background:var(--glass-2);color:var(--ink);border:1px solid var(--line);box-shadow:none}
.btn.ghost:hover{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.btn.violet{background:linear-gradient(135deg,var(--violet),var(--magenta));color:#fff;
  box-shadow:0 12px 30px -10px rgba(180,90,255,.8)}
.btn.danger{background:transparent;border:1px solid rgba(255,82,116,.5);color:var(--danger);box-shadow:none}
.btn.danger:hover{background:rgba(255,82,116,.12)}
.btn.sm{padding:8px 14px;font-size:.85rem;border-radius:11px}

input,textarea,select{width:100%;background:rgba(0,0,0,.28);border:1px solid var(--line);
  color:var(--ink);border-radius:12px;padding:12px 14px;font-size:.96rem;outline:none;transition:.15s}
input:focus,textarea:focus,select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(255,211,90,.18)}
label.f{display:block;margin:14px 0 6px;font-size:.82rem;color:var(--muted);font-weight:600}

.toast-wrap{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:1000;display:flex;flex-direction:column;gap:10px;align-items:center}
.toast{background:rgba(15,12,30,.95);border:1px solid var(--line);border-left:4px solid var(--gold);
  padding:13px 18px;border-radius:12px;font-size:.92rem;box-shadow:var(--shadow);animation:tin .25s ease;max-width:90vw}
.toast.err{border-left-color:var(--danger)}
.toast.ok{border-left-color:var(--cyan)}
@keyframes tin{from{opacity:0;transform:translateY(-12px)}}

/* ============================================================================
   AUTH SCREEN
   ========================================================================== */
#auth{min-height:100vh;display:grid;place-items:center;padding:40px 18px}
.auth-card{width:100%;max-width:440px;padding:38px 34px}
.brand{font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;line-height:.95}
.auth-card .brand{font-size:2.5rem;text-align:center}
.brand .sub{display:block;font-family:var(--font-label);font-weight:700;font-size:.7rem;letter-spacing:.5em;
  color:var(--muted);margin-top:10px;text-transform:uppercase}
.tabs{display:flex;gap:6px;background:rgba(0,0,0,.3);padding:6px;border-radius:14px;margin:26px 0 10px}
.tabs button{flex:1;border:none;background:transparent;color:var(--muted);padding:11px;border-radius:10px;font-weight:700;font-family:var(--font-label);letter-spacing:.06em;text-transform:uppercase;font-size:.82rem;transition:.18s}
.tabs button.active{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#241400}
.legal{margin-top:18px;font-size:.74rem;color:var(--muted);text-align:center;line-height:1.6}
.badge18{display:inline-block;border:1px solid rgba(255,82,116,.5);color:#ff9bb1;border-radius:999px;padding:2px 10px;font-weight:700;font-size:.72rem;margin-bottom:6px}

/* ============================================================================
   APP SHELL
   ========================================================================== */
header.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(14px);
  background:linear-gradient(180deg,rgba(7,5,18,.85),rgba(7,5,18,.5));border-bottom:1px solid var(--line)}
.topbar .row{display:flex;align-items:center;gap:18px;height:72px}
.logo{font-family:var(--font-display);font-weight:800;font-size:1.35rem;letter-spacing:-.02em;white-space:nowrap}
.logo small{display:block;font-family:var(--font-label);font-size:.52rem;letter-spacing:.42em;color:var(--muted);font-weight:700;margin-top:-2px}
nav.tabsnav{display:flex;gap:4px;margin-left:8px;flex:1;overflow-x:auto;scrollbar-width:none}
nav.tabsnav::-webkit-scrollbar{display:none}
nav.tabsnav button{border:none;background:transparent;color:var(--muted);font-family:var(--font-label);
  text-transform:uppercase;letter-spacing:.12em;font-weight:700;font-size:.78rem;padding:9px 14px;border-radius:10px;white-space:nowrap;transition:.18s;position:relative}
nav.tabsnav button:hover{color:var(--ink)}
nav.tabsnav button.active{color:#241400;background:linear-gradient(135deg,var(--gold),var(--gold-2));box-shadow:0 8px 20px -8px rgba(255,180,60,.7)}
.bal{display:flex;align-items:center;gap:9px;background:rgba(0,0,0,.34);border:1px solid var(--line);
  padding:8px 14px;border-radius:999px;font-weight:800;white-space:nowrap}
.bal .coin{width:20px;height:20px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#fff6c8,var(--gold-2));box-shadow:0 0 12px rgba(255,211,90,.8)}
.bal .amt{font-family:var(--font-display);font-size:1rem}
.userbox{display:flex;align-items:center;gap:10px}
.uname{font-size:.85rem;color:var(--muted);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

main{padding:34px 0 80px}
.view{display:none}
.view.active{display:block;animation:viewin .5s ease}
@keyframes viewin{from{opacity:0;transform:translateY(14px)}}

.view-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.view-head h2{font-family:var(--font-display);font-weight:800;font-size:clamp(1.7rem,4vw,2.6rem);margin:6px 0 0;letter-spacing:-.02em}
.live-pill{display:inline-flex;align-items:center;gap:8px;background:rgba(33,232,201,.1);border:1px solid rgba(33,232,201,.4);
  color:var(--cyan);padding:7px 14px;border-radius:999px;font-weight:700;font-size:.82rem}
.live-dot{width:9px;height:9px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan);animation:pulse 1.4s infinite}
@keyframes pulse{50%{opacity:.35;transform:scale(.7)}}

/* ---------- dashboard ------------------------------------------------- */
.dash{display:grid;grid-template-columns:1.15fr .85fr;gap:22px}
@media(max-width:880px){.dash{grid-template-columns:1fr}}
.hero{padding:34px;position:relative;overflow:hidden}
.hero .label{margin-bottom:8px}
.hero h1{font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,5vw,3.1rem);line-height:1.02;margin:0 0 14px;letter-spacing:-.02em}
.bigbal{display:flex;align-items:baseline;gap:10px;margin:18px 0 6px}
.bigbal .n{font-family:var(--font-display);font-weight:800;font-size:clamp(2.4rem,7vw,3.6rem)}
.stat-row{display:flex;gap:26px;margin-top:22px;flex-wrap:wrap}
.stat .k{font-family:var(--font-display);font-size:1.4rem;font-weight:800}
.stat .l{font-size:.78rem;color:var(--muted);font-family:var(--font-label);text-transform:uppercase;letter-spacing:.14em}

/* daily spin slot */
.spinbox{padding:30px;display:flex;flex-direction:column;align-items:center;text-align:center}
.reel-frame{position:relative;width:230px;height:150px;margin:18px 0 8px;border-radius:18px;overflow:hidden;
  background:linear-gradient(180deg,#1a1430,#0a0718);border:1px solid var(--line);
  box-shadow:inset 0 0 40px rgba(0,0,0,.7),0 0 0 4px rgba(255,211,90,.12)}
.reel-frame::before,.reel-frame::after{content:"";position:absolute;left:0;right:0;height:50px;z-index:3;pointer-events:none}
.reel-frame::before{top:0;background:linear-gradient(#0a0718,transparent)}
.reel-frame::after{bottom:0;background:linear-gradient(transparent,#0a0718)}
.reel-line{position:absolute;top:50%;left:8px;right:8px;height:50px;transform:translateY(-50%);z-index:2;
  border-radius:10px;border:2px solid var(--gold);box-shadow:0 0 22px rgba(255,211,90,.45)}
.reel{position:absolute;left:0;right:0;top:0;will-change:transform}
.reel .cell{height:50px;display:grid;place-items:center;font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--gold);text-shadow:0 0 14px rgba(255,211,90,.4)}
.won{font-family:var(--font-display);font-weight:800;font-size:1.6rem;margin:8px 0 2px}

/* ---------- cards / lists -------------------------------------------- */
.cards{display:grid;gap:16px}
.card{padding:22px 24px;transition:transform .18s ease,border-color .18s}
.card:hover{transform:translateY(-3px);border-color:rgba(255,211,90,.3)}
.card h3{font-family:var(--font-display);font-weight:700;font-size:1.18rem;margin:0 0 6px}
.card .meta{font-size:.76rem;color:var(--muted);font-family:var(--font-label);letter-spacing:.08em;text-transform:uppercase}
.card p{margin:10px 0 0;color:#d9d2f3;white-space:pre-wrap}
.tag{display:inline-block;background:linear-gradient(135deg,var(--violet),var(--magenta));color:#fff;
  font-weight:800;font-size:.74rem;padding:4px 12px;border-radius:999px;margin-bottom:8px;letter-spacing:.04em}
.tag.gift{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#241400}
.empty{padding:50px 24px;text-align:center;color:var(--muted)}
.empty .big{font-size:2.4rem;margin-bottom:8px}

/* ---------- lucky draw ------------------------------------------------ */
.draw-grid{display:grid;grid-template-columns:1fr 360px;gap:24px;align-items:start}
@media(max-width:900px){.draw-grid{grid-template-columns:1fr}}
.wheel-stage{padding:30px;display:flex;flex-direction:column;align-items:center}
.wheel-shell{position:relative;width:min(420px,82vw);aspect-ratio:1}
.wheel-pointer{position:absolute;top:-6px;left:50%;transform:translateX(-50%);z-index:5;
  width:0;height:0;border-left:18px solid transparent;border-right:18px solid transparent;
  border-top:30px solid var(--gold);filter:drop-shadow(0 4px 10px rgba(255,211,90,.7))}
.wheel-canvas{width:100%;height:100%;border-radius:50%;
  box-shadow:0 0 0 8px rgba(255,255,255,.04),0 0 0 16px rgba(255,211,90,.1),0 30px 70px -20px #000;
  transition:transform 0s;}
.wheel-hub{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:4;
  width:60px;height:60px;border-radius:50%;background:radial-gradient(circle at 35% 30%,#fff7cf,var(--gold-2));
  display:grid;place-items:center;font-size:1.4rem;box-shadow:0 0 24px rgba(255,211,90,.7),inset 0 -4px 8px rgba(0,0,0,.3)}
.winner-banner{margin-top:22px;text-align:center;min-height:30px}
.winner-banner .who{font-family:var(--font-display);font-weight:800;font-size:1.8rem}
.countdown{display:flex;gap:10px;justify-content:center;margin:6px 0 2px}
.cd{background:rgba(0,0,0,.35);border:1px solid var(--line);border-radius:12px;padding:10px 14px;min-width:64px;text-align:center}
.cd b{font-family:var(--font-display);font-size:1.5rem;display:block}
.cd span{font-size:.66rem;color:var(--muted);text-transform:uppercase;letter-spacing:.14em}
.parts{padding:24px}
.parts ol{margin:12px 0 0;padding:0;list-style:none;counter-reset:p}
.parts li{counter-increment:p;display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:12px;margin-bottom:7px;
  background:rgba(255,255,255,.03);border:1px solid var(--line);font-weight:600}
.parts li::before{content:counter(p);width:26px;height:26px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--font-display);font-size:.8rem;background:linear-gradient(135deg,var(--violet),var(--magenta));color:#fff;flex:none}
.parts li.win{border-color:var(--gold);background:rgba(255,211,90,.12);box-shadow:0 0 0 1px var(--gold)}

/* ---------- downloads ------------------------------------------------- */
.dl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}
.dl-card{padding:24px;display:flex;flex-direction:column;gap:14px;align-items:flex-start;position:relative;overflow:hidden}
.dl-card .ic{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;font-size:1.7rem;
  background:linear-gradient(135deg,rgba(138,75,255,.4),rgba(255,62,165,.35));border:1px solid var(--line)}
.dl-card h4{font-family:var(--font-display);font-weight:700;font-size:1.05rem;margin:0}
.dl-card .soon{color:var(--muted);font-size:.82rem}
.dl-card a.btn{text-decoration:none;align-self:stretch;text-align:center}

/* ---------- admin ----------------------------------------------------- */
.admin-tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:22px}
.admin-tabs button{border:1px solid var(--line);background:var(--glass);color:var(--muted);
  padding:9px 16px;border-radius:11px;font-family:var(--font-label);text-transform:uppercase;letter-spacing:.08em;font-weight:700;font-size:.78rem;transition:.16s}
.admin-tabs button.active{color:#241400;background:linear-gradient(135deg,var(--gold),var(--gold-2))}
.panel{display:none}
.panel.active{display:block;animation:viewin .35s ease}
.adm-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px}
@media(max-width:820px){.adm-grid{grid-template-columns:1fr}.dash{grid-template-columns:1fr}}
.box{padding:24px}
.box h3{font-family:var(--font-display);font-weight:700;margin:0 0 4px;font-size:1.2rem}
.row-2{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}
.mini-list{margin-top:16px;display:flex;flex-direction:column;gap:8px;max-height:340px;overflow:auto}
.mini{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:11px 14px;border-radius:11px;background:rgba(255,255,255,.03);border:1px solid var(--line)}
.mini .t{font-weight:700}
.dlrow{display:grid;grid-template-columns:120px 1fr;gap:8px;margin-bottom:8px}
@media(max-width:560px){.dlrow{grid-template-columns:1fr}}
.warn{font-size:.78rem;color:#ffd0a8;background:rgba(255,160,80,.08);border:1px solid rgba(255,160,80,.25);
  padding:12px 14px;border-radius:12px;margin-top:14px}
footer{padding:30px 0;text-align:center;color:var(--muted);font-size:.8rem;border-top:1px solid var(--line)}
