/* Modern neon responsive straight-labels */
*{box-sizing:border-box}
:root{
  --bg:#090a0f; --bg-elev:#0f131a; --panel:#121826;
  --text:#e7ecf3; --muted:#98a3b3;
  --primary:#00e5ff; --accent:#ff2d55; --good:#2ed573; --bad:#ff4757;
  --glow: 0 0 24px rgba(0,229,255,.35), 0 0 48px rgba(0,229,255,.15);
}
html,body{height:100%;margin:0;color:var(--text);
  background:radial-gradient(1200px 800px at 30% -10%, #162033 0%, #0b0e16 40%, var(--bg) 100%) fixed;
  font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial}
body{overflow-x:hidden}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.bg-grid{position:fixed;inset:0;pointer-events:none;
  background:
    radial-gradient(50% 50% at 50% 50%, rgba(0,229,255,.08), transparent 60%),
    repeating-linear-gradient(90deg, rgba(255,255,255,.03) 0 1px, transparent 1px 60px),
    repeating-linear-gradient(0deg, rgba(255,255,255,.02) 0 1px, transparent 1px 60px)}

.header{padding:2rem 1rem 1rem;text-align:center}
.logo{font-weight:800;letter-spacing:.02em;margin:0;font-size:clamp(2rem,5vw,3rem)}
.logo span{color:var(--primary);text-shadow:var(--glow)}
.tagline{margin:.25rem 0 0;color:var(--muted)}
.container{max-width:1200px;margin:0 auto;padding:1rem}

.panel{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(0,0,0,.1));
  border:1px solid rgba(255,255,255,.06);border-radius:16px;padding:12px 16px;
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.zip-form{display:flex;gap:.5rem;align-items:center}
.zip-form label{font-size:.95rem;color:var(--muted)}
#zip{padding:.65rem .8rem;border-radius:10px;border:1px solid rgba(255,255,255,.08);width:12ch;background:var(--bg-elev);color:var(--text)}
#zip:focus{outline:none;box-shadow:0 0 0 3px rgba(0,229,255,.25);border-color:transparent}
.btn{padding:.65rem 1rem;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:var(--bg-elev);color:var(--text);cursor:pointer;transition:transform .08s ease, box-shadow .2s ease, background .2s ease}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-primary{background:linear-gradient(180deg, rgba(0,229,255,.15), rgba(0,0,0,0));border-color:rgba(0,229,255,.35);box-shadow:var(--glow)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,.12);color:var(--muted)}

.filters{display:flex;gap:1rem;align-items:center}
.switch{display:flex;gap:.4rem;align-items:center;color:var(--muted)}
.switch input{accent-color:var(--primary)}

.stage{position:relative;display:grid;place-items:center;margin:28px auto}
.wheel-shadow{
  position:absolute;width:780px;height:780px;border-radius:50%;
  background:radial-gradient(60% 60% at 50% 50%, rgba(0,229,255,.12), transparent 70%);
  filter:blur(10px);z-index:0;pointer-events:none;
}
.wheel-wrap{position:relative;display:grid;place-items:center}
#wheel{
  display:block;width:90vw;max-width:780px;height:auto;border-radius:50%;
  box-shadow:0 20px 60px rgba(0,0,0,.6), 0 0 0 2px rgba(255,255,255,.06) inset;
  cursor:pointer;outline:none;z-index:1;transition:filter .25s ease;
}
#wheel.spinning{filter:brightness(1.05) saturate(1.08) drop-shadow(0 10px 40px rgba(0,229,255,.25))}
.pointer{
  position:absolute;top:50%;right:calc(50% - 45vw);transform:translate(50%,-50%);
  width:0;height:0;border-left:26px solid var(--accent);
  border-top:16px solid transparent;border-bottom:16px solid transparent;
  filter:drop-shadow(0 6px 12px rgba(255,45,85,.35));z-index:2;animation:pulse 2s ease-in-out infinite;
}
@media(min-width:800px){ .pointer{ right:calc(50% - 390px);} #wheel{ width:780px; } }
@keyframes pulse{0%,100%{transform:translate(50%,-50%) scale(1)}50%{transform:translate(50%,-50%) scale(1.05)}}

.center-cap{ position:absolute; inset:0; display:grid; place-items:center; z-index:3; pointer-events:none; }
.center-cap .btn{ pointer-events:auto }
.btn-glow{letter-spacing:.08em;font-weight:800;
  background:linear-gradient(180deg, rgba(0,229,255,.25), rgba(0,229,255,.05));
  border-color:rgba(0,229,255,.45);box-shadow:var(--glow); color:var(--text);
}

.result{display:grid;place-items:center;margin:10px auto}
.card{
  width:min(680px,92vw);border:1px solid rgba(255,255,255,.08);border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(0,0,0,.25));
  box-shadow:0 12px 40px rgba(0,0,0,.5);padding:16px 16px 18px;backdrop-filter: blur(8px);
}
.card.hidden{display:none}
.card-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}
.card-header h2{margin:0;font-size:1.4rem;text-shadow:0 0 20px rgba(0,229,255,.25)}
.icon-btn{background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:10px;color:var(--muted);padding:.35rem .5rem;cursor:pointer}
.muted{color:var(--muted);margin:.2rem 0 .6rem}
.badges{display:flex;flex-wrap:wrap;gap:.5rem;margin:.4rem 0 .8rem}
.badge{font-size:.85rem;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:.25rem .65rem;color:var(--text)}
.actions{display:flex;gap:.5rem;justify-content:flex-end}

.error{margin-top:10px;padding:.6rem .8rem;border-radius:10px;background:#2a1215;border:1px solid #5a1b23;color:#ffd9de;box-shadow:0 8px 18px rgba(0,0,0,.35)}
.error.hidden{display:none}

.footer{padding:1rem;text-align:center;color:var(--muted)}
