:root{--bg: #0c0c10;--panel: #16161d;--panel-2: #1e1e28;--text: #f2f2f5;--muted: #9a9aa8;--accent: #1db954;--accent-2: #7c5cff;--error: #ff5d5d;--warn: #ffb84d;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:radial-gradient(1200px 600px at 70% -10%,#1c1530 0%,var(--bg) 55%);color:var(--text);height:100vh;height:100dvh;overflow:hidden}.shell{max-width:560px;margin:0 auto;height:100vh;height:100dvh;display:flex;flex-direction:column;padding:max(14px,env(safe-area-inset-top)) 16px max(14px,env(safe-area-inset-bottom))}h1{font-size:30px;margin:8px 0 4px;letter-spacing:-.02em}.muted{color:var(--muted)}a{color:var(--accent-2)}button{font:inherit;cursor:pointer;border-radius:999px;border:none;padding:11px 18px;transition:transform .08s ease,opacity .15s ease,background .15s ease}button:active{transform:scale(.97)}button:disabled{opacity:.5;cursor:default}.primary{background:var(--accent);color:#04130a;font-weight:600}.ghost{background:var(--panel-2);color:var(--text)}.ghost.icon{padding:8px 12px;font-size:16px}.big{padding:15px 22px;font-size:16px}.card{border-radius:14px;padding:14px 16px;margin:12px 0;line-height:1.5}.card.small{font-size:13px;padding:10px 12px}.card.warn{background:#2a2113;border:1px solid #5a4516}.card.error{background:#2a1416;border:1px solid #5a1d22;color:#ffd4d4}code{background:#0004;padding:2px 6px;border-radius:6px;font-size:.92em}.redirect-uri{margin-top:8px;background:#000000055;border:1px solid #ffffff1f;border-radius:8px;padding:10px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;-webkit-user-select:all;user-select:all;word-break:break-all}.intro-screen{height:100vh;height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;text-align:center;background:radial-gradient(130% 90% at 50% -10%,#2a1b46 0%,var(--bg) 60%)}.intro-inner{width:100%;max-width:380px;display:flex;flex-direction:column;align-items:center}.brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}.logo-dot{display:grid;place-items:center;background:linear-gradient(145deg,var(--accent),var(--accent-2));color:#fff;border-radius:14px;width:40px;height:40px;font-size:22px}.logo-dot.big{width:64px;height:64px;font-size:34px;border-radius:20px;box-shadow:0 12px 40px -8px var(--accent-2)}.brand-name{font-size:40px;font-weight:800;letter-spacing:-.03em;margin:0}.tagline{font-size:17px;line-height:1.5;color:#e6e6ee;margin:4px 0 0}.intro-subtitle{color:var(--muted);margin:14px 0 0}.how{list-style:none;padding:0;margin:26px 0 28px;display:flex;flex-direction:column;gap:12px;text-align:left;width:100%}.how li{display:flex;align-items:center;gap:12px;color:#d8d8e2;font-size:15px}.how .num{flex:none;width:26px;height:26px;display:grid;place-items:center;border-radius:50%;background:var(--panel-2);color:var(--accent);font-weight:700;font-size:13px}.cta{width:100%}.setup-note{margin-top:18px;font-size:12px;color:var(--muted);width:100%}.setup-note summary{cursor:pointer}.topbar{flex:none;display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.brand-mini{font-weight:800;letter-spacing:-.02em;font-size:18px;display:flex;align-items:center;gap:7px}.brand-mini .logo-dot{width:26px;height:26px;font-size:15px;border-radius:9px}.topbar-right{display:flex;align-items:center;gap:8px}.avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.badge{display:inline-block;font-size:12px;padding:2px 8px;border-radius:999px}.badge.ok{background:#0f3a22;color:#5ce698}.badge.warn{background:#3a2c0f;color:var(--warn)}.viewtabs{flex:none;display:flex;gap:6px;background:var(--panel);padding:4px;border-radius:999px;margin-bottom:12px}.tab{flex:1;background:transparent;color:var(--muted);padding:8px;font-weight:600;font-size:14px}.tab.active{background:var(--panel-2);color:var(--text)}.feed{flex:1;min-height:0;display:flex;flex-direction:column;touch-action:pan-y}.feed-top{flex:none;display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.counter{font-weight:700;font-size:14px}.skip-link{background:transparent;color:var(--muted);font-size:13px;padding:4px 6px}.story-card{flex:1;min-height:0;border-radius:22px;padding:20px 18px;display:flex;flex-direction:column;border:1px solid #ffffff12;animation:cardIn .4s cubic-bezier(.2,.7,.2,1)}@keyframes cardIn{0%{opacity:0;transform:translateY(20px) scale(.99)}to{opacity:1;transform:none}}.card-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;margin:2px -4px;padding:0 4px;-webkit-mask-image:linear-gradient(to bottom,transparent 0,#000 10px,#000 calc(100% - 14px),transparent 100%);mask-image:linear-gradient(to bottom,transparent 0,#000 10px,#000 calc(100% - 14px),transparent 100%)}.card-foot{flex:none;padding-top:14px}.intro-card{background:radial-gradient(120% 80% at 20% 0%,#2a1b46,#15131f 60%)}.kicker{flex:none;text-transform:uppercase;letter-spacing:.14em;font-size:11px;color:var(--accent-2);font-weight:700;margin-bottom:12px}.intro-text{font-size:17px;line-height:1.5;font-weight:500;margin:0}.hint{margin-top:12px;color:var(--muted);font-size:12px;text-align:center}.listening-card{background:radial-gradient(120% 80% at 50% 0%,#11233a,#121019 65%);align-items:center;text-align:center;justify-content:center}.mystery{margin:8px 0 18px}.pulse{width:128px;height:128px;border-radius:50%;display:grid;place-items:center;font-size:56px;font-weight:800;color:#fffc;background:radial-gradient(circle,#1db95433 0%,transparent 70%);animation:pulse 1.6s ease-in-out infinite}.pulse.paused{animation-play-state:paused;opacity:.6}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #1db95433}50%{transform:scale(1.06);box-shadow:0 0 60px 10px #1db95422}}.listening-card .listening-label{font-size:17px;font-weight:600;margin-bottom:18px}.listening-card .card-foot{width:100%}.progress{height:5px;background:#ffffff1a;border-radius:999px;margin:8px 0 4px;overflow:hidden}.progress.wide{width:100%;height:6px}.bar{height:100%;background:var(--accent);transition:width .5s linear}.times{display:flex;justify-content:space-between;font-size:12px}.listen-controls,.reveal-controls{display:flex;gap:10px;margin-top:14px;width:100%}.listen-controls .big,.reveal-controls .big{flex:1}.reveal-card{background:radial-gradient(120% 80% at 80% 0%,#143524,#121019 60%)}.reveal-head{flex:none;display:flex;gap:14px;align-items:center;margin-bottom:14px}.reveal-cover{width:72px;height:72px;border-radius:12px;object-fit:cover;flex:none}.reveal-meta{min-width:0}.reveal-artist{font-size:21px;font-weight:800;letter-spacing:-.02em;line-height:1.15}.reveal-track{margin:2px 0 6px;font-size:14px}.reveal-story{font-size:15px;line-height:1.6;color:#e6e6ee;margin:0}.feed-error{flex:none;margin-top:10px}.player{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;background:var(--panel);border-radius:18px;padding:16px}.status-row{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:14px;margin-bottom:14px}.dot{width:9px;height:9px;border-radius:50%}.dot.ok{background:var(--accent);box-shadow:0 0 8px var(--accent)}.dot.pending{background:var(--warn)}.now-playing{display:flex;gap:14px;background:var(--panel-2);border-radius:14px;padding:14px;margin-bottom:16px}.now-playing.empty{color:var(--muted);font-size:14px;display:block}.now-playing img{width:88px;height:88px;border-radius:10px;object-fit:cover}.np-meta{flex:1;min-width:0}.title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.controls{display:flex;gap:8px;margin-top:10px}.controls button{padding:8px 14px;font-size:14px}.search{display:flex;gap:8px;margin-bottom:12px}.search input{flex:1;background:var(--panel-2);border:1px solid #ffffff14;color:var(--text);border-radius:999px;padding:11px 16px;font:inherit;outline:none}.search input:focus{border-color:var(--accent-2)}.results{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.results li{display:flex;align-items:center;gap:12px;background:var(--panel-2);padding:8px 10px;border-radius:12px}.results img{width:48px;height:48px;border-radius:8px;object-fit:cover}.results .meta{flex:1;min-width:0}.results button{padding:8px 14px;font-size:14px}
