:root{
  --bg:#0a0a0f; --bg-2:#101019; --card:#13131f; --card-2:#171726;
  --line:#23233a; --line-2:#2e2e48;
  --txt:#eef0ff; --mut:#9aa0c4; --dim:#6b7099;
  --cyan:#19e3ff; --magenta:#ff2bd6; --lime:#9dff3c;
  --bass:#ff2bd6;   /* bass section accent */
  --house:#19e3ff;  /* house section accent */
  --accent:#19e3ff;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --sans:"Space Grotesk",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{font-family:var(--sans);background:var(--bg);color:var(--txt);
  -webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;line-height:1.45;
  padding-bottom:env(safe-area-inset-bottom)}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--magenta);color:#0a0a0f}
:focus-visible{outline:2px solid var(--cyan);outline-offset:2px;border-radius:4px}

.glow{position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(60% 40% at 85% -5%, rgba(255,43,214,.16), transparent 60%),
    radial-gradient(55% 45% at 5% 0%, rgba(25,227,255,.14), transparent 60%),
    radial-gradient(80% 50% at 50% 120%, rgba(157,255,60,.06), transparent 60%)}

.wrap{max-width:780px;margin:0 auto;padding:0 14px}

/* ---------- header ---------- */
.top{position:sticky;top:0;z-index:30;background:color-mix(in srgb,var(--bg) 86%,transparent);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.bar{max-width:780px;margin:0 auto;padding:12px 14px 10px;display:flex;align-items:center;gap:14px}
.brand{display:flex;align-items:baseline;gap:8px}
.logo{color:var(--magenta);font-weight:700;letter-spacing:-2px;text-shadow:0 0 14px rgba(255,43,214,.6)}
.brand-name{font-weight:700;font-size:20px;letter-spacing:1px}
.brand-sub{font-size:10.5px;color:var(--dim);font-family:var(--mono);text-transform:uppercase;letter-spacing:2px}
.nav{margin-left:auto;display:flex;align-items:center;gap:6px}
.nav a{font-size:13px;font-weight:600;color:var(--mut);padding:6px 10px;border-radius:8px}
.nav a:hover{color:var(--txt)}
.nav a.active{color:var(--bg);background:var(--cyan)}
.ghost{background:transparent;border:1px solid var(--line-2);color:var(--mut);border-radius:8px;
  padding:6px 9px;font-size:14px;line-height:1}
.ghost:hover{color:var(--txt);border-color:var(--cyan)}

.tabs{max-width:780px;margin:0 auto;padding:0 14px 11px;display:flex;gap:7px;overflow-x:auto;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tabs button{white-space:nowrap;background:var(--card);border:1px solid var(--line);color:var(--mut);
  font-size:12.5px;font-weight:600;padding:6px 13px;border-radius:999px;transition:all .14s}
.tabs button:hover{border-color:var(--line-2);color:var(--txt)}
.tabs button.on{color:var(--bg);border-color:transparent;
  background:linear-gradient(100deg,var(--cyan),var(--magenta));box-shadow:0 0 18px -6px var(--magenta)}

/* ---------- toolbar ---------- */
.toolbar{max-width:780px;margin:13px auto 4px;padding:0 14px;display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.inp{background:var(--card);border:1px solid var(--line);color:var(--txt);border-radius:9px;
  padding:8px 11px;font-size:13px;font-family:inherit}
.inp:focus{border-color:var(--cyan);outline:none}
#q{flex:1;min-width:160px}
.sel{appearance:none;padding-right:26px;background-image:linear-gradient(45deg,transparent 50%,var(--mut) 50%),linear-gradient(135deg,var(--mut) 50%,transparent 50%);
  background-position:calc(100% - 14px) 16px,calc(100% - 9px) 16px;background-size:5px 5px;background-repeat:no-repeat}
.pill{background:var(--card);border:1px solid var(--line);color:var(--mut);font-size:12.5px;font-weight:600;
  padding:8px 12px;border-radius:9px;transition:all .14s}
.pill:hover{color:var(--txt);border-color:var(--line-2)}
.pill.on{color:var(--bg);background:var(--lime);border-color:transparent;box-shadow:0 0 16px -6px var(--lime)}
.ghost2{color:var(--dim)}

/* ---------- list ---------- */
main.wrap{padding-top:8px;padding-bottom:70px;min-height:60vh}
.loading,.empty{color:var(--mut);text-align:center;padding:54px 16px;font-size:14px}
.empty .big{font-size:34px;display:block;margin-bottom:8px;opacity:.7}
.empty .hint{color:var(--dim);font-size:12.5px;margin-top:6px}

.daygroup{margin:18px 0 0}
.dayhdr{position:sticky;top:108px;z-index:10;display:flex;align-items:baseline;gap:10px;
  padding:7px 2px 7px;margin-bottom:2px;background:linear-gradient(var(--bg),var(--bg) 70%,transparent)}
.dow{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--cyan);letter-spacing:1px;text-transform:uppercase}
.dfull{font-size:12.5px;color:var(--dim)}
.dcount{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--dim)}

.row{display:flex;gap:13px;align-items:center;padding:11px 12px;margin:6px 0;
  background:var(--card);border:1px solid var(--line);border-radius:13px;transition:border-color .14s,transform .14s}
.row:hover{border-color:var(--line-2);transform:translateX(2px)}
.row.bass{border-left:3px solid var(--bass)}
.row.house{border-left:3px solid var(--house)}
.row.both{border-left:3px solid;border-image:linear-gradient(var(--house),var(--bass)) 1}
.cal{flex:none;width:46px;text-align:center}
.cal .m{font-family:var(--mono);font-size:10px;font-weight:700;color:var(--mut);text-transform:uppercase;letter-spacing:.5px}
.cal .d{font-size:22px;font-weight:700;line-height:1;margin-top:1px}
.thumb{flex:none;width:44px;height:44px;border-radius:9px;object-fit:cover;background:var(--card-2);border:1px solid var(--line)}
.info{flex:1;min-width:0}
.title{font-size:15px;font-weight:600;color:#fff;line-height:1.2;display:flex;gap:7px;align-items:center;flex-wrap:wrap}
.star{color:var(--lime);font-size:11px}
.sub{font-size:12.5px;color:var(--mut);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sub .city{color:var(--dim)}
.meta-r{flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:5px}
.time{font-family:var(--mono);font-size:11px;color:var(--dim)}
.tix{font-size:11px;font-weight:700;color:var(--bg);background:var(--cyan);padding:4px 9px;border-radius:7px;white-space:nowrap}
.tix:hover{background:var(--magenta)}
.badge{font-family:var(--mono);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;
  padding:2px 6px;border-radius:5px;border:1px solid currentColor}
.badge.bass{color:var(--bass)}.badge.house{color:var(--house)}

/* ---------- My Artists ---------- */
.section-h{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--dim);
  margin:22px 2px 8px;display:flex;align-items:center;gap:10px}
.section-h::after{content:"";flex:1;height:1px;background:var(--line)}
.acard{display:flex;gap:12px;align-items:center;padding:11px 12px;margin:7px 0;background:var(--card);
  border:1px solid var(--line);border-radius:13px}
.acard .thumb{width:48px;height:48px;border-radius:50%}
.acard .info{flex:1;min-width:0}
.acard .an{font-size:15px;font-weight:600;color:#fff}
.acard .next{font-size:12px;color:var(--mut);margin-top:2px}
.acard .cnt{font-family:var(--mono);font-size:11px;color:var(--cyan)}
.acard .warn{color:var(--magenta);font-size:11px}
.rm{background:transparent;border:1px solid var(--line-2);color:var(--mut);border-radius:8px;padding:6px 10px;font-size:12px;font-weight:600}
.rm:hover{color:#fff;border-color:var(--magenta);background:rgba(255,43,214,.12)}
.addbar{display:flex;gap:7px;margin:14px 0 4px;flex-wrap:wrap}
.addbar .inp{flex:1;min-width:150px}

/* ---------- artist detail ---------- */
.ahero{display:flex;gap:15px;align-items:center;margin:16px 2px 6px}
.ahero img{width:74px;height:74px;border-radius:50%;object-fit:cover;border:1px solid var(--line-2)}
.ahero h2{margin:0;font-size:24px}
.ahero .tag{font-size:12px;color:var(--mut);font-family:var(--mono)}
.back{display:inline-block;color:var(--cyan);font-size:13px;font-weight:600;margin:14px 2px 0}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:60;background:rgba(5,5,10,.72);display:flex;align-items:flex-end;justify-content:center}
.modal[hidden]{display:none}
@media(min-width:560px){.modal{align-items:center}}
.sheet{width:100%;max-width:520px;background:var(--bg-2);border:1px solid var(--line-2);
  border-radius:18px 18px 0 0;max-height:86vh;overflow:auto;padding:16px 16px 26px}
@media(min-width:560px){.sheet{border-radius:18px}}
.sheet-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.sheet-head h3{margin:0;font-size:17px}
.field{margin:12px 0}
.field label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--dim);margin-bottom:5px;font-family:var(--mono)}
.field .inp,.field .sel{width:100%}
.btn{background:linear-gradient(100deg,var(--cyan),var(--magenta));color:var(--bg);border:0;border-radius:10px;
  padding:11px 14px;font-weight:700;font-size:14px;width:100%}
.btn:disabled{opacity:.5}
.cand{display:flex;gap:10px;align-items:center;padding:9px;border:1px solid var(--line);border-radius:10px;margin:7px 0;cursor:pointer}
.cand:hover{border-color:var(--cyan)}
.cand img{width:40px;height:40px;border-radius:8px;object-fit:cover;background:var(--card)}
.cand .cn{font-weight:600;font-size:14px}
.cand .cm{font-size:11.5px;color:var(--mut)}
.note{font-size:12px;color:var(--mut);line-height:1.5}
.seg{display:flex;gap:6px}
.seg button{flex:1;background:var(--card);border:1px solid var(--line);color:var(--mut);padding:8px;border-radius:9px;font-weight:600;font-size:13px}
.seg button.on{color:var(--bg)}
.seg button.on.bass{background:var(--bass);border-color:transparent}
.seg button.on.house{background:var(--house);border-color:transparent}
.toast{position:fixed;left:50%;bottom:74px;transform:translateX(-50%);background:var(--card-2);border:1px solid var(--line-2);
  color:var(--txt);padding:10px 16px;border-radius:10px;font-size:13px;z-index:80;box-shadow:0 8px 30px rgba(0,0,0,.5)}
.demo-banner{background:linear-gradient(100deg,rgba(255,43,214,.16),rgba(25,227,255,.12));
  border:1px solid var(--line-2);border-radius:11px;padding:10px 13px;margin:12px 0 4px;font-size:12.5px;color:var(--mut)}
.demo-banner b{color:var(--txt)}

/* ---------- footer ---------- */
.foot{max-width:780px;margin:0 auto;padding:18px 14px 30px;color:var(--dim);font-size:11.5px;
  font-family:var(--mono);text-align:center}
.foot .dot{margin:0 7px;opacity:.5}

@media(max-width:560px){
  .dayhdr{top:104px}
  .brand-sub{display:none}
  .cal{width:40px}.cal .d{font-size:20px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important}}
