@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;600;700&family=Plus+Jakarta+Sans:wght@400;600;700&display=swap');

:root{
  --bg:#0b0f17;
  --card:#0f1623;
  --text:#e9eefc;
  --muted:#a8b3cf;
  --accent:#22d3ee;
  --accent2:#facc15;
  --danger:#ff5b6e;
  --ok:#22c55e;
  --border: rgba(255,255,255,.08);
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --radius: 18px;
  --radius-sm: 12px;
  --max: 1100px;
  font-synthesis-weight:none;
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family: "Space Grotesk","Plus Jakarta Sans", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Apple Color Emoji","Segoe UI Emoji";
  background: radial-gradient(1200px 600px at 10% 0%, rgba(110,231,255,.10), transparent 60%),
              radial-gradient(900px 500px at 90% 10%, rgba(167,139,250,.10), transparent 55%),
              var(--bg);
  color:var(--text);
}
a{color:inherit;text-decoration:none}
.container{max-width:var(--max);margin:0 auto;padding:24px}
.topbar{position:sticky;top:0;z-index:20;background:rgba(11,15,23,.7);backdrop-filter: blur(10px);border-bottom:1px solid var(--border)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{font-weight:800;letter-spacing:.5px;display:flex;align-items:center;gap:10px}
.brand-logo{height:26px;width:auto;display:block}
.nav{display:flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.muted{color:var(--muted)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border);padding:12px 16px;border-radius:999px;background:linear-gradient(135deg, rgba(34,211,238,.28), rgba(250,204,21,.28));box-shadow: var(--shadow);cursor:pointer;transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease}
.btn:hover{transform:translateY(-1px);border-color: rgba(255,255,255,.2)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-sm{padding:8px 12px;font-size:14px}
.btn-ghost{background:rgba(255,255,255,.04);box-shadow:none}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
.btn-view{background:linear-gradient(120deg,#22c55e,#38bdf8);color:#0b0f17;border-color:rgba(255,255,255,.45);box-shadow:0 10px 22px rgba(34,197,94,.35),0 8px 18px rgba(56,189,248,.25)}
.btn-view:hover{box-shadow:0 14px 26px rgba(34,197,94,.45),0 12px 22px rgba(56,189,248,.35)}
.btn-action{background:linear-gradient(120deg,#38bdf8,#facc15);color:#0b0f17;border-color:rgba(255,255,255,.45);box-shadow:0 10px 22px rgba(56,189,248,.3),0 8px 18px rgba(250,204,21,.25)}
.btn-action:hover{box-shadow:0 14px 26px rgba(56,189,248,.4),0 12px 22px rgba(250,204,21,.35)}
.btn-danger{background:linear-gradient(120deg,#fb7185,#f43f5e);color:#0b0f17;border-color:rgba(255,255,255,.45);box-shadow:0 10px 22px rgba(251,113,133,.35),0 8px 18px rgba(244,63,94,.3)}
.btn-danger:hover{box-shadow:0 14px 26px rgba(251,113,133,.45),0 12px 22px rgba(244,63,94,.4)}
.btn-share{background:linear-gradient(120deg,#22d3ee,#38bdf8);border-color:rgba(255,255,255,.35);box-shadow:0 12px 26px rgba(34,211,238,.35),0 10px 22px rgba(56,189,248,.3)}
.btn-share:hover{box-shadow:0 16px 30px rgba(34,211,238,.45),0 12px 26px rgba(56,189,248,.38)}
.btn-cta{background:linear-gradient(120deg,#f97316,#facc15);border-color:rgba(255,255,255,.38);box-shadow:0 12px 26px rgba(249,115,22,.35),0 10px 24px rgba(250,204,21,.3)}
.btn-cta:hover{box-shadow:0 16px 30px rgba(249,115,22,.45),0 12px 26px rgba(250,204,21,.38)}
.btn-cta-bright{background:linear-gradient(120deg,#fb7185,#facc15);color:#0b0f17}
.card{background:rgba(15,22,35,.78);border:1px solid var(--border);border-radius:var(--radius);box-shadow: var(--shadow)}
.card-inner{padding:20px}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:1fr}
@media (min-width: 860px){.grid-2{grid-template-columns: 1.2fr .8fr}}
h1{font-size:40px;line-height:1.05;margin:0 0 8px}
h2{margin:0 0 10px;font-size:22px}
p{margin:0 0 10px;color:var(--muted);line-height:1.6}
.badge{display:inline-flex;gap:8px;align-items:center;padding:6px 10px;border-radius:999px;border:1px solid var(--border);color:var(--muted);font-size:13px}
.kpi{display:flex;gap:14px;flex-wrap:wrap}
.kpi .pill{padding:10px 12px;border:1px solid var(--border);border-radius:999px;background:rgba(255,255,255,.03);color:var(--muted)}
.kpi .pill-accent{background:linear-gradient(120deg,rgba(34,211,238,.25),rgba(56,189,248,.25));color:#eafcff;border-color:rgba(255,255,255,.2)}
.kpi .pill-accent b{color:#7dd3fc}
.kpi .pill-accent-alt{background:linear-gradient(120deg,rgba(249,115,22,.3),rgba(250,204,21,.3));color:#fff1d6;border-color:rgba(255,255,255,.2)}
.kpi .pill-accent-alt b{color:#fde047}
.progress{height:10px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden;border:1px solid var(--border)}
.progress > div{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2))}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.input, select{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:rgba(0,0,0,.25);color:var(--text)}
.input option, select option{color:#0b0f17;background:#f8fafc}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.form-span-2{grid-column:1 / -1}
@media (min-width: 980px){.form-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width: 720px){.form-grid{grid-template-columns:1fr}}
@media (max-width: 780px){
  .topbar-inner{flex-direction:column;align-items:flex-start}
  .nav{width:100%;justify-content:flex-start}
  .brand{width:100%;justify-content:flex-start}
}
.label{font-size:13px;color:var(--muted);margin:10px 0 6px}
.table{width:100%;border-collapse:collapse}
.table th,.table td{padding:10px 10px;border-bottom:1px solid var(--border);text-align:left;font-size:14px}
.table th{color:var(--muted);font-weight:700}
.alert{padding:12px 14px;border-radius:14px;border:1px solid var(--border);margin:16px 0}
.alert-error{border-color: rgba(255,107,107,.35);background: rgba(255,107,107,.08)}
.alert-ok{border-color: rgba(61,220,151,.35);background: rgba(61,220,151,.08)}
.footer{border-top:1px solid var(--border);margin-top:40px;background:rgba(0,0,0,.15)}
.footer-inner{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;color:var(--muted);padding:18px 0}
.hr{height:1px;background:var(--border);margin:18px 0}
.small{font-size:13px;color:var(--muted)}
.medal{font-size:20px;margin-right:6px}
.prize-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.prize-card{border-radius:var(--radius-sm);transition:transform .18s ease, border-color .18s ease;background:linear-gradient(180deg,rgba(255,255,255,.02),rgba(0,0,0,.2))}
.prize-card:hover{transform:translateY(-2px);border-color: rgba(255,255,255,.18)}
.prize-card .card-inner{display:flex;flex-direction:column;gap:8px}
.prize-card .medal{filter:drop-shadow(0 4px 10px rgba(250,204,21,.35))}
.prize-image{display:block;width:100%;margin-top:8px;border:1px solid var(--border);background:rgba(0,0,0,.25);padding:8px;cursor:pointer;position:relative;border-radius:14px;overflow:hidden}
.prize-image img{width:100%;height:190px;object-fit:cover;display:block;border-radius:10px;filter:saturate(1.08)}
.prize-zoom{position:absolute;bottom:12px;right:12px;background:linear-gradient(120deg,#22d3ee,#facc15);color:#0b0f17;font-size:12px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.35);box-shadow:0 10px 20px rgba(34,211,238,.25)}
.prize-list{display:grid;gap:10px}
.prize-item{display:flex;align-items:center;gap:12px;border:1px solid var(--border);border-radius:12px;padding:12px;background:rgba(255,255,255,.02)}
.prize-icon{font-size:22px;width:32px;text-align:center}
.prize-meta{flex:1}
.prize-title{font-weight:700;margin-bottom:4px}
.prize-thumb{border:0;background:none;padding:0;border-radius:10px;overflow:hidden;cursor:pointer}
.prize-thumb img{width:72px;height:72px;object-fit:cover;display:block;border:1px solid var(--border)}
.prize-detail-list{display:grid;gap:12px}
.prize-detail-item{display:flex;align-items:center;justify-content:space-between;gap:16px;border:1px solid var(--border);border-radius:14px;padding:14px;background:rgba(255,255,255,.02)}
.prize-detail-info{flex:1}
.prize-detail-media{border:1px solid var(--border);background:rgba(0,0,0,.25);padding:8px;border-radius:14px;position:relative;cursor:pointer}
.prize-detail-media img{width:150px;height:120px;object-fit:cover;border-radius:10px;display:block}
@media (max-width: 720px){
  .prize-detail-item{flex-direction:column;align-items:flex-start}
  .prize-detail-media img{width:100%;height:180px}
}
.ticket-picker{margin-top:8px}
.ticket-divider{display:flex;align-items:center;gap:10px;margin:12px 0;color:var(--muted)}
.ticket-divider:before,.ticket-divider:after{content:"";flex:1;height:1px;background:var(--border)}
.ticket-divider span{font-size:12px;padding:2px 8px;border:1px solid var(--border);border-radius:999px;background:rgba(255,255,255,.03)}
.ticket-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(38px,1fr));gap:8px;padding:8px;border:1px solid var(--border);border-radius:12px;background:rgba(0,0,0,.15)}
.ticket-num{position:relative;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.06);color:var(--text);border-radius:8px;padding:10px 0;font-weight:700;font-size:13px;cursor:pointer;transition:transform .12s ease,border-color .12s ease,background .12s ease}
.ticket-num:hover{transform:translateY(-1px);border-color:rgba(255,255,255,.28)}
.ticket-num.selected{background:linear-gradient(120deg,#38bdf8,#fb923c);color:#0b0f17;border-color:rgba(255,255,255,.3)}
.ticket-num.sold{background:rgba(255,255,255,.05);color:var(--muted);border-color:rgba(255,255,255,.08);cursor:not-allowed}
.ticket-num.sold::before,
.ticket-num.sold::after{content:"";position:absolute;left:6px;right:6px;top:50%;height:2px;background:#ff5b6e;transform-origin:center}
.ticket-num.sold::before{transform:translateY(-50%) rotate(45deg)}
.ticket-num.sold::after{transform:translateY(-50%) rotate(-45deg)}
.ticket-summary{display:flex;gap:16px;flex-wrap:wrap;margin-top:10px}
.prize-mini{display:grid;gap:8px;margin-top:6px}
.prize-mini-item{display:flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:10px;padding:6px;background:rgba(255,255,255,.03)}
.prize-mini-item img{width:32px;height:32px;border-radius:8px;object-fit:cover;border:1px solid rgba(255,255,255,.12)}
.ticket-picker .btn-ghost{background:linear-gradient(120deg,#0ea5e9,#f97316);color:#0b0f17;border-color:rgba(255,255,255,.5);box-shadow:0 10px 20px rgba(14,165,233,.35),0 8px 16px rgba(249,115,22,.28)}
.ticket-picker .btn-ghost:hover{transform:translateY(-1px);box-shadow:0 16px 30px rgba(14,165,233,.55),0 14px 26px rgba(249,115,22,.48)}
.ticket-picker .btn-ghost.active{background:linear-gradient(120deg,#22c55e,#facc15);color:#0b0f17;border-color:rgba(255,255,255,.7);box-shadow:0 16px 34px rgba(34,197,94,.45),0 14px 28px rgba(250,204,21,.45)}
.ticket-picker .label{color:#facc15;font-weight:700;letter-spacing:.2px}
.max-highlight{color:#fde047;font-weight:700}
.ticket-divider span{background:linear-gradient(120deg,#22d3ee,#facc15);color:#0b0f17;border-color:rgba(255,255,255,.45)}
.how-steps{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:10px 0 6px}
@media (max-width: 700px){.how-steps{grid-template-columns:1fr}}
.how-card{border:1px solid var(--border);border-radius:12px;padding:12px;background:rgba(255,255,255,.03)}
.how-title{font-weight:700;margin-bottom:6px}
.how-strip{border-bottom:1px solid var(--border);background:rgba(0,0,0,.2)}
.how-strip-inner{max-width:var(--max);margin:0 auto;padding:10px 24px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.how-pill{font-size:13px;border:1px solid var(--border);border-radius:999px;padding:6px 10px;background:rgba(255,255,255,.04)}
.event-link{display:block;transition:transform .18s ease,border-color .18s ease}
.event-link:hover{transform:translateY(-2px);border-color: rgba(255,255,255,.18)}
.admin-hero{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px}
.admin-hero h1{margin:0;font-size:28px}
.admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.stat-card{background:rgba(15,22,35,.85);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.stat-label{font-size:13px;color:var(--muted)}
.stat-value{font-size:24px;font-weight:800;margin:6px 0 8px}
.stat-sub{font-size:12px;color:var(--muted)}
.stat-highlight{background:linear-gradient(140deg,rgba(34,211,238,.18),rgba(250,204,21,.18))}
.user-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:10px}
.admin-grid-2{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px;margin-top:16px}
.chart-card{background:rgba(15,22,35,.85);border:1px solid var(--border);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.chart-title{font-weight:700;margin-bottom:8px}
.bar-chart{display:flex;gap:8px;align-items:flex-end;height:140px;padding:8px 4px;background:rgba(0,0,0,.2);border-radius:12px}
.bar-chart .bar{flex:1;min-width:18px;background:linear-gradient(180deg,#38bdf8,#f97316);border-radius:8px;position:relative}
.bar-chart.alt .bar{background:linear-gradient(180deg,#22c55e,#facc15)}
.bar-chart .bar span{position:absolute;top:-18px;left:50%;transform:translateX(-50%);font-size:11px;color:var(--muted)}
.bar-labels{display:flex;gap:8px;justify-content:space-between;margin-top:8px;font-size:11px;color:var(--muted)}
.raffle-board{display:grid;gap:16px}
.raffle-shell{padding:26px;position:relative;overflow:hidden}
.raffle-board{position:relative;overflow:hidden;border-radius:16px}
.raffle-board > :not(.raffle-rain){position:relative;z-index:1}
.raffle-rain{position:absolute;inset:0;pointer-events:none;z-index:0}
.raffle-rain span{position:absolute;left:var(--x);top:-30%;font-size:var(--size);color:rgba(34,211,238,.28);opacity:.45;letter-spacing:2px;font-family:"Space Grotesk","Plus Jakarta Sans", ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono","Courier New", monospace;animation:raffleRain var(--d) linear infinite;animation-delay:var(--delay);text-shadow:0 0 18px rgba(34,211,238,.25)}
.raffle-display{border:1px solid var(--border);border-radius:16px;padding:100px 25px;background:rgba(0,0,0,.18);text-align:center;position:relative;overflow:hidden}
.raffle-display.spinning{background:linear-gradient(120deg,rgba(34,211,238,.22),rgba(250,204,21,.18),rgba(251,113,133,.2));background-size:200% 200%;animation:raffleGlow 6s ease-in-out infinite}
.raffle-display.spinning:after{content:"";position:absolute;inset:-40%;background:radial-gradient(circle at 50% 50%, rgba(250,204,21,.25), transparent 55%);animation:rafflePulse 2.2s ease-in-out infinite}
.raffle-number{font-size:130px;font-weight:900;letter-spacing:10px;color:#facc15;text-shadow:0 0 30px rgba(250,204,21,.5)}
.raffle-name{margin-top:6px;font-size:16px;color:var(--muted)}
.raffle-timer{margin-top:6px;font-size:14px;color:#22d3ee}
.raffle-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.raffle-card{border:1px solid var(--border);border-radius:14px;padding:14px;background:rgba(15,22,35,.85)}
.raffle-card-inner{display:flex;gap:12px;align-items:center;justify-content:space-between}
.raffle-prize-img{width:84px;height:84px;object-fit:cover;border-radius:12px;border:1px solid rgba(255,255,255,.12)}
.raffle-title{font-weight:700;margin-bottom:4px}
.raffle-prize{font-size:13px;color:var(--muted);margin-bottom:8px}
.raffle-result{font-size:13px;color:var(--muted);margin-bottom:8px}
.tickets-meta{display:grid;gap:4px;margin:6px 0 12px}
.tickets-title{font-weight:700;font-size:16px}
.tickets-sub{font-size:12px;color:var(--muted)}
.tickets-list{display:flex;flex-wrap:wrap;gap:8px}
.ticket-chip{padding:8px 12px;border:1px solid var(--border);border-radius:999px;background:rgba(255,255,255,.08);font-weight:700;font-size:18px}
.winner-modal .winner-content{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:min(460px,90vw)}
.winner-badge{font-size:12px;letter-spacing:.4px;padding:6px 10px;border-radius:999px;background:linear-gradient(120deg,#22d3ee,#facc15);color:#0b0f17}
.winner-number{font-size:72px;font-weight:900;letter-spacing:8px;color:#facc15;text-shadow:0 0 26px rgba(250,204,21,.5)}
.winner-name{font-size:20px;font-weight:700}
.winner-prize{font-size:14px;color:var(--muted)}
@keyframes raffleGlow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes rafflePulse{0%,100%{transform:scale(0.98);opacity:.6}50%{transform:scale(1.03);opacity:1}}
@keyframes raffleRain{0%{transform:translateY(-160%)}100%{transform:translateY(260%)}}
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:50}
.modal.open{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(5,8,14,.7);backdrop-filter: blur(6px)}
.modal-content{position:relative;max-width:min(900px,92vw);max-height:85vh;background:rgba(10,14,22,.9);border:1px solid var(--border);border-radius:16px;box-shadow: var(--shadow);padding:14px;z-index:1}
.modal-content img{max-width:100%;max-height:70vh;display:block;border-radius:12px}
.modal-close{position:absolute;top:10px;right:10px;border:1px solid var(--border);background:rgba(0,0,0,.4);color:var(--text);border-radius:999px;padding:6px 10px;cursor:pointer}
.modal-caption{margin-top:10px;font-size:13px;color:var(--muted)}
