/* ===========  HULZAY — shared styles  =========== */
:root{
  --bg:#0a0710;
  --bg2:#140a1c;
  --card:#1a1022;
  --line:#2c1c3a;
  --ink:#f6eefb;
  --muted:#b39bc7;
  --pink:#ff2bc2;
  --pink2:#ff5ea8;
  --violet:#7b3cff;
  --glow:0 0 24px rgba(255,43,194,.55);
  --ok:#34d399;
  --warn:#fbbf24;
  --bad:#fb6a6a;
  --radius:20px;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(123,60,255,.25), transparent 60%),
    radial-gradient(800px 600px at -10% 110%, rgba(255,43,194,.18), transparent 55%),
    var(--bg);
  color:var(--ink);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:480px;margin:0 auto;padding:22px 18px 40px;min-height:100vh;display:flex;flex-direction:column}
.grow{flex:1}

/* ---- brand bar ---- */
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.18em;font-size:15px}
.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--pink);box-shadow:var(--glow)}
.brand small{display:block;font-weight:500;letter-spacing:.02em;color:var(--muted);font-size:11px;margin-top:2px}
.tagchip{margin-left:auto;font-size:10px;letter-spacing:.14em;color:var(--pink2);
  border:1px solid var(--line);padding:5px 10px;border-radius:999px;text-transform:uppercase}

/* ---- hero ---- */
.hero{position:relative;border-radius:var(--radius);overflow:hidden;margin-top:18px;
  aspect-ratio:4/5;box-shadow:0 20px 50px rgba(0,0,0,.5)}
.hero img{width:100%;height:100%;object-fit:cover;display:block}
.hero .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,7,16,.05),rgba(10,7,16,.92))}
.hero .cap{position:absolute;left:18px;right:18px;bottom:16px}
.hero h1{margin:0;font-size:30px;line-height:1.05;font-weight:800}
.hero h1 b{color:var(--pink)}
.hero p{margin:6px 0 0;color:var(--muted);font-size:14px}

/* ---- generic blocks ---- */
h2.step{font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--pink2);margin:26px 0 4px}
.lead{font-size:22px;font-weight:800;margin:0 0 14px}
.sub{color:var(--muted);font-size:14px;margin:0 0 18px;line-height:1.5}
.card{background:linear-gradient(180deg,var(--card),var(--bg2));border:1px solid var(--line);
  border-radius:var(--radius);padding:18px}

/* ---- form ---- */
label{display:block;font-size:12px;letter-spacing:.04em;color:var(--muted);margin:14px 0 6px}
input{width:100%;background:#0e0814;border:1px solid var(--line);color:var(--ink);
  border-radius:14px;padding:15px 14px;font-size:16px;outline:none;transition:border .15s,box-shadow .15s}
input:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(255,43,194,.18)}
input::placeholder{color:#6b5780}
.hint{font-size:12px;color:var(--muted);margin-top:6px}
.err{color:var(--bad);font-size:13px;margin-top:12px;min-height:18px}

/* ---- buttons ---- */
.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;
  border:none;border-radius:999px;padding:16px;font-size:16px;font-weight:700;cursor:pointer;
  color:#fff;background:linear-gradient(90deg,var(--violet),var(--pink));box-shadow:var(--glow);
  transition:transform .08s,filter .15s;margin-top:20px}
.btn:active{transform:scale(.985)}
.btn:disabled{filter:grayscale(.5) brightness(.7);box-shadow:none;cursor:default}
.btn.ghost{background:transparent;border:1px solid var(--line);box-shadow:none;color:var(--ink)}
.btn.ok{background:linear-gradient(90deg,#15a36a,#34d399);box-shadow:0 0 22px rgba(52,211,153,.4)}
.btn.lg{font-size:18px;padding:18px}
.btn.ig{background:linear-gradient(90deg,#feda75,#fa7e1e,#d62976,#962fbf,#4f5bd5);
  box-shadow:0 0 22px rgba(214,41,118,.45)}
.btn.sm{padding:12px;font-size:14px;margin-top:10px}

/* ---- front-page quick-links hub ---- */
.hub{margin-top:24px;border-top:1px solid var(--line);padding-top:16px}
.hublabel{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:2px}
.hubrow{display:flex;gap:10px}
.hubrow .btn{flex:1}

/* ---- dish card ---- */
.dish{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:var(--card)}
.dish .pic{position:relative;aspect-ratio:4/3;overflow:hidden}
.dish .pic img{width:100%;height:100%;object-fit:cover}
.dish .free{position:absolute;top:12px;left:12px;background:var(--pink);color:#fff;font-weight:800;
  font-size:12px;letter-spacing:.08em;padding:6px 12px;border-radius:999px;box-shadow:var(--glow)}
.dish .body{padding:16px}
.dish .body h3{margin:0;font-size:20px}
.dish .body p{margin:6px 0 0;color:var(--muted);font-size:14px;line-height:1.5}
.gal{display:flex;gap:8px;margin-top:12px}
.gal img{flex:1;width:0;aspect-ratio:1;object-fit:cover;border-radius:12px;border:1px solid var(--line)}

/* ---- token ticket ---- */
.ticket{position:relative;border-radius:24px;overflow:hidden;margin-top:8px;text-align:center;
  border:1px solid var(--line)}
.ticket .bg{position:absolute;inset:0}
.ticket .bg img{width:100%;height:100%;object-fit:cover;filter:saturate(1.1)}
.ticket .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,7,16,.55),rgba(10,7,16,.9))}
.ticket .inner{position:relative;padding:30px 20px 26px}
.ticket .k{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--pink2)}
.ticket .num{font-size:84px;font-weight:800;line-height:1;margin:6px 0 4px;
  text-shadow:0 0 30px rgba(255,43,194,.6)}
.ticket .who{color:var(--ink);font-size:16px;font-weight:600}
.ticket .note{color:var(--muted);font-size:13px;margin-top:10px}
.dashline{height:1px;background:repeating-linear-gradient(90deg,var(--line) 0 8px,transparent 8px 16px);margin:0}

.steps{display:flex;gap:6px;margin:18px 0 2px}
.steps .s{flex:1;height:4px;border-radius:3px;background:var(--line)}
.steps .s.on{background:linear-gradient(90deg,var(--violet),var(--pink))}

.foot{text-align:center;color:#6b5780;font-size:11px;letter-spacing:.06em;margin-top:26px}

/* ---- staff / admin tables ---- */
.toolbar{display:flex;gap:10px;align-items:center;margin:14px 0}
.tokin{font-size:34px;font-weight:800;text-align:center;letter-spacing:.1em}
.stat{display:flex;gap:10px;margin:16px 0}
.stat .box{flex:1;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:14px;text-align:center}
.stat .box b{display:block;font-size:26px}
.stat .box span{font-size:11px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
table{width:100%;border-collapse:collapse;font-size:13px;margin-top:6px}
th,td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.06em}
.pill{font-size:11px;padding:3px 9px;border-radius:999px;font-weight:700}
.pill.issued{background:rgba(251,191,36,.15);color:var(--warn)}
.pill.collected{background:rgba(52,211,153,.15);color:var(--ok)}
.result{margin-top:16px;border-radius:16px;padding:18px;text-align:center;font-weight:700;font-size:18px;display:none}
.result.show{display:block}
.result.good{background:rgba(52,211,153,.12);border:1px solid rgba(52,211,153,.4);color:var(--ok)}
.result.warnb{background:rgba(251,191,36,.12);border:1px solid rgba(251,191,36,.4);color:var(--warn)}
.result.badb{background:rgba(251,106,106,.12);border:1px solid rgba(251,106,106,.4);color:var(--bad)}
.center{text-align:center}
a.link{color:var(--pink2)}
.spin{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);
  border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
/* ---- live counter ---- */
.counter{display:block;margin:14px 0 0;background:linear-gradient(180deg,var(--card),var(--bg2));
  border:1px solid var(--line);border-radius:14px;padding:12px 14px}
.counter .row{display:flex;align-items:center;gap:8px}
.counter .flame{font-size:18px;line-height:1}
.counter .ctxt{font-size:14px;font-weight:700}
.counter .ctxt b{color:var(--pink)}
.counter .bar{margin-top:9px;height:7px;border-radius:5px;background:#0e0814;overflow:hidden;border:1px solid var(--line)}
.counter .bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--violet),var(--pink));
  box-shadow:0 0 12px rgba(255,43,194,.5);transition:width .5s ease}

/* ---- consent checkbox ---- */
.check{display:flex;align-items:flex-start;gap:10px;margin:16px 0 0;font-size:13px;
  color:var(--muted);cursor:pointer}
.check input{width:18px;height:18px;flex:0 0 auto;margin-top:1px;accent-color:var(--pink)}
.check span{line-height:1.45}

.hide{display:none!important}
