:root{--bg: #0d1117;--accent: #58a6ff;--glow: rgba(88, 166, 255, .3);color-scheme:dark;font-family:Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden;background:var(--bg);color:#e6edf3}.app{position:relative;display:flex;flex-direction:column;height:100vh;overflow:hidden}.bg-image{position:fixed;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;background-repeat:no-repeat;transition:background-image .8s ease;z-index:0;filter:blur(4px) saturate(1.2);transform:scale(1.02)}.top-bar{position:relative;z-index:10;background:#00000080;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.08);padding:10px 20px;flex-shrink:0}.top-bar-inner{display:flex;flex-direction:column;align-items:center;justify-content:center;max-width:1400px;margin:0 auto;gap:10px}.url-text{font-size:11px;font-family:SF Mono,Fira Code,Consolas,monospace;color:#ffffff80;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:400px}.url-placeholder{font-size:11px;color:#ffffff40;font-style:italic}.themes-row{display:flex;align-items:center;justify-content:center;gap:14px;flex-shrink:0}.theme-btn{width:52px;height:52px;border-radius:14px;border:2px solid transparent;cursor:pointer;transition:all .3s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:#ffffff14;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.theme-btn:hover{transform:scale(1.1);background:#ffffff24}.theme-btn.active{transform:scale(1.12);background:#ffffff2e}.theme-icon{font-size:24px;line-height:1}.theme-label{font-size:8px;font-weight:700;color:#ffffffb3;text-transform:uppercase;letter-spacing:.05em;line-height:1}.loading-state{display:flex;flex-direction:column;align-items:center;gap:16px;padding:48px 0;color:#ffffff80;font-size:.85rem}.spinner{width:36px;height:36px;border-radius:50%;border:3px solid;border-top-color:var(--accent);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.main-content{position:relative;z-index:2;display:grid;grid-template-columns:360px 1fr;flex:1;overflow:hidden}.station-panel{display:flex;flex-direction:column;background:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-right:1px solid rgba(255,255,255,.06);overflow:hidden}.station-header{padding:20px 20px 12px;flex-shrink:0}.station-header h1{font-size:1.4rem;font-weight:700;letter-spacing:-.02em;text-align:center}.gitlawb-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:linear-gradient(135deg,#58a6ff,#a371f7);color:#fff;font-size:16px;font-weight:800;flex-shrink:0}.subtitle{font-size:.8rem;color:#ffffff73;margin-bottom:12px}.now-playing-bar{display:flex;align-items:center;gap:8px;white-space:nowrap;width:100%;padding:10px 14px;border-radius:10px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);overflow:hidden}.np-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.np-label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#fff6}.np-name{font-size:12px;font-weight:600;color:#ffffffd9;overflow:hidden;text-overflow:ellipsis;min-width:0}.np-pause-btn{flex-shrink:0;margin-left:auto;width:28px;height:28px;border-radius:8px;border:1px solid;background:#ffffff0f;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.np-pause-btn:hover{background:#ffffff1f}.station-list{flex:1;overflow-y:auto;padding:0 12px 12px}.station-list::-webkit-scrollbar{width:6px}.station-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.station-group{margin-bottom:16px}.group-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;font-weight:700;padding:8px 8px 6px;position:sticky;top:0;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:6px;z-index:1}.station-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:10px 12px;margin-bottom:4px;border-radius:10px;border:1px solid rgba(255,255,255,.06);background:#ffffff05;color:#e6edf3;cursor:pointer;transition:all .2s;text-align:left;font-family:inherit}.station-item:hover{background:#ffffff0f;border-color:#ffffff1f}.station-item.active{transform:translate(2px)}.station-info{display:flex;flex-direction:column;gap:2px}.station-name{font-size:.88rem;font-weight:600}.station-meta{font-size:.72rem;color:#fff6}.equalizer{display:flex;gap:2px;align-items:flex-end;height:18px}.equalizer span{width:3px;border-radius:1px;animation:eq .6s ease-in-out infinite alternate}.equalizer span:nth-child(1){height:8px;animation-delay:0s}.equalizer span:nth-child(2){height:14px;animation-delay:.15s}.equalizer span:nth-child(3){height:10px;animation-delay:.3s}@keyframes eq{0%{height:4px}to{height:18px}}.viz-area{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background:transparent}.viz-content{position:relative;z-index:2;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.viz-station-name{font-size:2.4rem;font-weight:800;letter-spacing:-.03em;text-shadow:0 0 40px var(--glow)}.viz-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;pointer-events:none}.viz-clock{font-size:3.5rem;font-weight:700;letter-spacing:.05em;text-shadow:0 0 30px var(--glow);font-variant-numeric:tabular-nums;font-family:inherit}.viz-quote{font-size:.95rem;font-weight:500;text-align:center;max-width:90%;letter-spacing:.02em;font-style:italic;text-shadow:0 0 20px var(--glow)}.url-row{display:flex;align-items:center;gap:8px}.url-copy-btn{flex-shrink:0;width:28px;height:28px;border-radius:6px;border:1px solid rgba(255,255,255,.12);background:#ffffff0f;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:0}.url-copy-btn:hover{background:#ffffff1f;border-color:#ffffff40}.viz-genre{font-size:.9rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.1em}.play-btn{margin-top:12px;padding:10px 36px;border-radius:24px;border:none;font-size:.9rem;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s}.play-btn:hover{transform:scale(1.05);box-shadow:0 0 24px var(--glow)}.viz-placeholder{position:relative;z-index:2;font-size:1.1rem}.no-results{text-align:center;color:#ffffff59;padding:40px 0;font-size:.9rem}.toast{position:absolute;top:8px;left:50%;transform:translate(-50%);z-index:10;padding:10px 24px;border-radius:10px;background:#000000d9;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid;color:#ffffffe6;font-size:.85rem;font-weight:600;animation:toastIn .3s ease,toastOut .3s ease 2.7s forwards;white-space:nowrap;box-shadow:0 4px 16px #00000080;pointer-events:none}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(-8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(-8px)}}.click-ripple{position:fixed;width:0;height:0;border-radius:50%;border:2px solid rgba(255,255,255,.35);pointer-events:none;z-index:9999;transform:translate(-50%,-50%);animation:rippleExpand .7s ease-out forwards}@keyframes rippleExpand{0%{width:0;height:0;opacity:1;border-width:2px}to{width:120px;height:120px;opacity:0;border-width:1px}}@media(max-width:900px){.url-row{justify-content:center}.url-text{max-width:70vw}.themes-row{gap:10px}.theme-btn{width:44px;height:44px}.theme-icon{font-size:20px}.theme-label{display:none}.app{overflow:hidden}.main-content{grid-template-columns:1fr;grid-template-rows:1fr auto;flex:1;min-height:0;overflow:hidden}.station-panel{display:flex;flex-direction:column;border-right:none;overflow:hidden;min-height:0}.station-list{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.viz-area{flex-shrink:0;height:15vh;max-height:15vh;min-height:60px;border-top:1px solid rgba(255,255,255,.15);background:#00000080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:3}.viz-clock{font-size:1.8rem;font-weight:600}.viz-quote{font-size:.75rem}}
