@tailwind base;@tailwind components;@tailwind utilities;:root{color-scheme:light dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";background:#0b0c10;color:#f6f7fb}.max-w-3xl{max-width:48rem}.mx-auto{margin-left:auto;margin-right:auto}.p-4{padding:1rem}.mb-4{margin-bottom:1rem}.mt-1{margin-top:.25rem}.mt-3{margin-top:.75rem}.space-y-3>*+*{margin-top:.75rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-3{gap:.75rem}.w-12{width:3rem}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-gray-600{color:#606770}.font-semibold{font-weight:600}.font-bold{font-weight:700}.border{border:1px solid rgba(255,255,255,.08)}.rounded{border-radius:.5rem}.divide-y>*+*{border-top:1px solid rgba(255,255,255,.08)}.tabular-nums{font-variant-numeric:tabular-nums}.btn-liked{background:#e6f7ff1f;border-color:#91d5ff80;color:#6ee7ff}.btn-danger{background:#ffecec22;border-color:#ffb3b355;color:#ff4d4f}:root{--bg: #0b0c10;--panel: rgba(20,20,24,.7);--border: rgba(255,255,255,.08);--text: #f6f7fb;--muted: #a0a4b8;--brand: #6ee7ff;--brand-2:#b26eff;--accent:#1f8fff}.shell{min-height:100%;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:40;height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 .875rem;background:radial-gradient(1200px 300px at -10% -60%,rgba(110,231,255,.25),transparent 60%),radial-gradient(900px 300px at 110% 140%,rgba(178,110,255,.25),transparent 60%),linear-gradient(90deg,#090c12eb,#090c12eb);-webkit-backdrop-filter:blur(10px) saturate(1.2);backdrop-filter:blur(10px) saturate(1.2);border-bottom:1px solid var(--border);box-shadow:0 2px 18px #00000059}.topbar.topbar-lg{height:68px}.brand{display:flex;align-items:center;gap:.6rem}.brand-logo{height:28px;width:auto;display:block}.brand-logo-lg{height:48px}.topbar-right{display:flex;gap:.5rem;align-items:center}.user-email{font-size:.9rem;color:#fff;opacity:.95;padding:.35rem .6rem;border-right:0;border-radius:.6rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{border:1px solid rgba(255,255,255,.18);color:#eaeaea;padding:.4rem .7rem;border-radius:.55rem;background:#ffffff0a}.logout-btn:hover{background:#ffffff14}.content{width:min(1200px,96%);margin:1.25rem auto 3rem}.tabs-wrap{display:flex;gap:.5rem;margin:.5rem 0 .75rem}.tab{padding:.5rem .9rem;border-radius:999px;border:1px solid var(--border);background:#ffffff05;color:var(--muted);cursor:pointer}.tab:hover{color:var(--text);border-color:#ffffff2e}.tab-active{color:#0b1220;background:linear-gradient(135deg,var(--brand),var(--brand-2));border-color:transparent}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--border);padding:.55rem .9rem;border-radius:.7rem;cursor:pointer;background:#ffffff08;color:var(--text);transition:.15s ease}.btn:hover{transform:translateY(-1px);border-color:#ffffff2e}.btn-ghost{background:transparent}.btn-primary{background:linear-gradient(135deg,var(--brand),var(--brand-2));border-color:transparent;color:#081018;font-weight:700}.btn-primary:hover{filter:brightness(.98)}.input{width:100%;padding:.65rem .9rem;border:1px solid var(--border);border-radius:.7rem;background:#ffffff05;color:var(--text);outline:none}.input.big{padding:.85rem 1rem;font-size:1.05rem}.card{border:1px solid var(--border);background:#ffffff08;border-radius:1rem;padding:1rem}.card:hover{border-color:#ffffff2e;box-shadow:0 6px 24px #00000040}.row{display:flex;justify-content:space-between;align-items:center;gap:1rem}.login-badge.login-mark{width:56px;height:56px;margin:0 auto .85rem;padding:0;border:none;background:transparent;display:grid;place-items:center;filter:drop-shadow(0 6px 18px rgba(0,0,0,.35))}.login-badge.login-mark svg{display:block}.login-card h1{margin-top:.2rem}.login-hero{min-height:100vh;background:#000 url(/bg.jpg) center/cover no-repeat fixed;position:relative;display:grid;place-items:center}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(1200px 600px at 20% -10%,rgba(110,231,255,.25),transparent 40%),radial-gradient(1200px 600px at 120% 110%,rgba(178,110,255,.25),transparent 40%),#0000008c}.hero-noise{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.06;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="160" height="160" viewBox="0 0 160 160"><filter id="n"><feTurbulence type="fractalNoise" baseFrequency=".9" numOctaves="2" stitchTiles="stitch"/></filter><rect width="100%" height="100%" filter="url(%23n)" opacity=".6"/></svg>')}.login-card{position:relative;z-index:1;width:min(560px,92%);padding:2rem;border-radius:18px;border:1px solid var(--border);background:#0f10188c;-webkit-backdrop-filter:blur(12px) saturate(1.2);backdrop-filter:blur(12px) saturate(1.2);text-align:center}.login-card h1{margin:0 0 .5rem;font-size:2.25rem;letter-spacing:.2px}.login-card .sub{margin:.25rem 0 1rem;color:var(--muted)}.login-badge{width:56px;height:56px;margin:0 auto .75rem;border-radius:14px;background:#ffffff0f;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;overflow:hidden}.login-form{display:flex;gap:.6rem;margin-top:.75rem}.login-form .big{flex:1}.tiny{margin-top:.75rem;font-size:.85rem;color:var(--muted)}.notes{position:absolute;inset:-40px -10px auto auto;pointer-events:none;opacity:.55}.notes span{display:inline-block;font-size:2rem;margin:0 .15rem;animation:float 7s linear infinite}.notes span:nth-child(2){animation-delay:1s}.notes span:nth-child(3){animation-delay:2s}@keyframes float{0%{transform:translateY(0);opacity:.2}50%{opacity:1}to{transform:translateY(-30px);opacity:.2}}@media (prefers-color-scheme: light){body{background:#fafafa;color:#111}}.list-head{position:sticky;top:0;background:linear-gradient(180deg,#ffffffe6,#fff0);padding-bottom:.25rem;z-index:5}@media (prefers-color-scheme: dark){.list-head{background:linear-gradient(180deg,#0b0c10e6,#0b0c1000)}}.artist-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.artist-left{display:flex;align-items:center;gap:.85rem;min-width:0}.artist-name{font-weight:600;letter-spacing:.1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.avatar{width:56px;height:56px;border-radius:12px;overflow:hidden;flex:0 0 56px;border:1px solid var(--border, rgba(0,0,0,.1));background:#0e1117}.avatar-img{width:100%;height:100%;object-fit:cover;display:block}.artist-row img{width:56px;height:56px;object-fit:cover}.btn-like{min-width:102px;justify-content:center;background:#f8fafc;border:1px solid #cbd5e1;color:#0f172a;font-weight:600}.btn-like:hover{filter:brightness(.98);transform:translateY(-1px)}.btn-like.is-liked{background:linear-gradient(135deg,var(--brand, #6ee7ff),var(--brand-2, #b26eff));color:#0b1220;border-color:transparent}@media (prefers-color-scheme: dark){.btn-like{background:#ffffff0f;border-color:#ffffff1f;color:#e7e9ef}}.page-grid{display:grid;grid-template-columns:260px 1fr 300px;gap:1.25rem}@media (max-width: 1100px){.page-grid{grid-template-columns:1fr}}.subheader{position:relative;margin:.75rem 0 1rem;padding:.8rem 1rem;background:transparent;border:1px solid transparent;box-shadow:none;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.subheader .stat{color:#fff;font-weight:600;font-size:.92rem;background:#0a0c12e0;border:1px solid rgba(255,255,255,.18);padding:.42rem .7rem;border-radius:999px;box-shadow:0 1px 8px #00000059,inset 0 0 0 1px #ffffff0a;letter-spacing:.1px}.subheader .stat b{color:#fff;font-weight:700}.subheader .stat.clickable{cursor:pointer;transition:transform .12s ease,background .12s ease}.subheader .stat.clickable:hover{transform:translateY(-1px);background:#12161ef2}.rail{position:sticky;top:68px;align-self:start;height:fit-content}.rail .section-title{font-weight:700;margin:0 0 .5rem;font-size:.95rem;color:var(--muted)}.rail .card+.card{margin-top:.75rem}.chips{display:flex;flex-wrap:wrap;gap:.5rem}.chip{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem .55rem;border-radius:999px;border:1px solid var(--border);background:#ffffff08;max-width:100%}.chip .chip-name{max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chip .chip-x{border:none;background:transparent;cursor:pointer;color:var(--muted)}.chip .chip-x:hover{color:var(--text)}.avatar.sm{width:28px;height:28px;border-radius:999px}.avatar.sm img,.avatar.sm .avatar-img{width:100%;height:100%;object-fit:cover;display:block}.mini-list{display:flex;flex-direction:column;gap:.6rem}.mini-row{display:flex;justify-content:space-between;gap:.75rem;text-decoration:none;color:inherit;border-radius:.5rem;padding:.3rem .35rem}.mini-row:hover{background:#ffffff0a}.mini-row .meta{color:var(--muted);font-size:.86rem}.mini-row .title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card.compact{padding:.75rem}.radius-editor{display:flex;align-items:center;gap:.6rem}.radius-input{width:96px;padding:.5rem .65rem;border-radius:.7rem;border:1px solid var(--border);background:#fff;color:#111;font-weight:600;letter-spacing:.2px;box-shadow:0 1px #00000008;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.radius-input::placeholder{color:#6b7280}.radius-input:focus{outline:none;border-color:#6ee7ff99;box-shadow:0 0 0 3px #6ee7ff40}@media (prefers-color-scheme: dark){.radius-input{background:#ffffff14;color:#fff;border-color:#ffffff2e}.radius-input::placeholder{color:#fff9}}.radius-editor .btn{margin-left:.1rem}.input.search{background:#fff;color:#111;border:1px solid #cbd5e1;box-shadow:0 1px #00000005}.input.search::placeholder{color:#6b7280}@media (prefers-color-scheme: dark){.input.search{background:#111;color:#e7e9ef;border:1px solid rgba(255,255,255,.18)}.input.search::placeholder{color:#9aa1ad}}.genre-filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.genre-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;padding:.44rem .7rem;border-radius:999px;font-size:.86rem;background:transparent;color:#111;border:1px solid #111;transition:background .12s ease,transform .12s ease,border-color .12s ease}.genre-chip:hover{background:#0000000d;transform:translateY(-1px)}.genre-chip.is-active{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;border-color:transparent;font-weight:700}.login-logo{display:block;margin:0 auto .85rem;width:400px;height:80px;filter:drop-shadow(0 6px 18px rgba(0,0,0,.35));border-radius:12px}.login-word{display:block;width:min(240px,70%);margin:0 auto .35rem}
