:root{color:#eef7f2;background:#070b0d;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{width:100%;min-width:320px;height:100%;margin:0;overflow:hidden}button,input{font:inherit}button{cursor:pointer}.app-shell{position:relative;width:100%;height:100%;min-height:640px;isolation:isolate;background:radial-gradient(circle at 24% 30%,rgba(85,205,158,.16),transparent 32%),radial-gradient(circle at 78% 72%,rgba(237,170,71,.12),transparent 28%),#070b0d}.globe-scene{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.globe-scene canvas{display:block;width:100%;height:100%;touch-action:none}.globe-scene-placeholder,.globe-scene-unavailable{background:radial-gradient(circle at 44% 45%,rgba(80,182,146,.2),transparent 18%),radial-gradient(circle at 44% 45%,rgba(16,54,62,.5),transparent 28%)}.topbar{position:absolute;top:24px;left:28px;right:28px;z-index:2;display:flex;align-items:flex-start;justify-content:space-between;gap:20px;pointer-events:none}.eyebrow{margin:0 0 4px;color:#8ef0bd;font-size:.78rem;font-weight:800;letter-spacing:0;text-transform:uppercase}h1{margin:0;color:#fff;font-size:clamp(2rem,4.7vw,5.8rem);font-weight:850;line-height:.92;letter-spacing:0}.status-pill{min-width:104px;border:1px solid rgba(145,240,189,.28);border-radius:999px;padding:7px 11px;color:#c9f5e1;background:rgba(8,17,18,.72);font-size:.72rem;font-weight:700;line-height:1;pointer-events:auto;text-align:center;text-decoration:none;box-shadow:0 12px 40px #00000038;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.status-pill:hover{border-color:#8ef0bd8f;color:#fff}.station-panel{position:absolute;top:132px;right:28px;bottom:112px;z-index:3;display:flex;width:min(380px,calc(100vw - 40px));min-height:320px;flex-direction:column;overflow:hidden;border:1px solid rgba(215,237,226,.22);border-radius:8px;background:linear-gradient(145deg,rgba(255,255,255,.11),rgba(255,255,255,.03)),rgba(9,15,16,.6);box-shadow:0 24px 80px #00000061;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);transition:top .18s ease,bottom .18s ease,width .18s ease,height .18s ease,min-height .18s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease}.station-panel.expanded{top:76px;width:min(430px,calc(100vw - 56px));border-color:#8ef0bd57;background:linear-gradient(145deg,rgba(255,255,255,.12),rgba(255,255,255,.04)),rgba(9,15,16,.74);box-shadow:0 30px 96px #00000075}.station-panel.collapsed{top:132px;bottom:auto;width:178px;height:auto;min-height:64px;border-color:#8ef0bd47;background:linear-gradient(145deg,rgba(142,240,189,.14),rgba(255,255,255,.05)),rgba(8,17,18,.46);box-shadow:0 18px 64px #0000004d}.panel-header{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:8px;padding:16px 16px 12px}.panel-sheet-handle{display:none;border:0;color:inherit;background:transparent}.panel-sheet-handle span{display:block;width:44px;height:5px;border-radius:999px;background:rgba(207,232,222,.42)}.search-box{display:grid;gap:8px;color:#cfe8de;font-size:.82rem;font-weight:800}.search-box input{width:100%;min-height:44px;border:1px solid rgba(207,232,222,.16);border-radius:6px;outline:none;padding:0 12px;color:#fff;background:rgba(255,255,255,.08);box-shadow:inset 0 1px #ffffff0f}.search-box input:focus{border-color:#8ef0bdb8;box-shadow:0 0 0 3px #8ef0bd1f}.panel-actions{display:grid;grid-template-columns:38px 38px;gap:7px;margin-top:20px}.panel-collapse-button,.panel-stretch-button,.panel-expand-button{border:1px solid rgba(207,232,222,.16);color:#dff4ec;background:rgba(255,255,255,.07)}.panel-collapse-button,.panel-stretch-button{display:grid;width:38px;height:38px;place-items:center;border-radius:999px}.panel-collapse-button span{width:14px;height:2px;border-radius:999px;background:#c9f5e1}.panel-stretch-button span{position:relative;width:15px;height:18px}.panel-stretch-button span:before,.panel-stretch-button span:after{position:absolute;left:3px;width:9px;height:9px;border-color:#c9f5e1;border-style:solid;content:""}.panel-stretch-button span:before{top:0;border-width:2px 2px 0 0;transform:rotate(-45deg)}.panel-stretch-button span:after{bottom:0;border-width:0 0 2px 2px;transform:rotate(-45deg)}.panel-stretch-button[aria-pressed=true]{border-color:#8ef0bd8f;background:rgba(142,240,189,.15)}.panel-collapse-button:hover,.panel-stretch-button:hover,.panel-expand-button:hover{border-color:#8ef0bd7a;background:rgba(142,240,189,.12)}.panel-expand-button{display:grid;grid-template-columns:34px minmax(0,1fr);width:100%;min-height:64px;align-items:center;gap:10px;border:0;padding:10px 12px;text-align:left}.search-glyph{position:relative;display:block;width:30px;height:30px;border:1px solid rgba(142,240,189,.42);border-radius:999px;background:rgba(142,240,189,.12)}.search-glyph:before{position:absolute;top:8px;left:8px;width:9px;height:9px;border:2px solid #c9f5e1;border-radius:999px;content:""}.search-glyph:after{position:absolute;right:8px;bottom:8px;width:9px;height:2px;border-radius:999px;background:#c9f5e1;content:"";transform:rotate(45deg);transform-origin:center}.panel-expand-copy{display:grid;min-width:0;gap:1px}.panel-expand-copy strong{overflow:hidden;color:#fff;font-size:.86rem;text-overflow:ellipsis;white-space:nowrap}.panel-expand-copy small{overflow:hidden;color:#9bb9ae;font-size:.72rem;font-weight:750;text-overflow:ellipsis;white-space:nowrap}.library-toolbar{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:0 16px 12px}.library-toolbar button{display:flex;min-height:36px;align-items:center;justify-content:center;gap:7px;border:1px solid rgba(207,232,222,.12);border-radius:6px;color:#b9d1c8;background:rgba(255,255,255,.05);font-size:.78rem;font-weight:850}.library-toolbar button:hover,.library-toolbar button.active{border-color:#ffcf5a6b;color:#fff3c2;background:rgba(255,207,90,.12)}.library-toolbar span{min-width:24px;border-radius:999px;padding:2px 6px;color:#08100e;background:#8ef0bd;font-size:.68rem;font-weight:900;text-align:center}.station-count{padding:0 16px 12px;color:#83a497;font-size:.8rem;font-weight:700}.station-list{flex:1;min-height:0;overflow:auto;padding:0 10px 10px}.station-row{display:grid;grid-template-columns:minmax(0,1fr) auto;width:100%;min-height:68px;align-items:center;gap:8px;border:1px solid transparent;border-radius:6px;padding:0 8px 0 0;color:#edf8f3;background:transparent;text-align:left}.station-row:hover{background:rgba(255,255,255,.06)}.station-row.selected{border-color:#ffcf5a80;background:rgba(255,207,90,.1)}.station-row.playing{border-color:#8ef0bdb8;background:linear-gradient(90deg,rgba(142,240,189,.16),rgba(255,207,90,.07)),rgba(255,255,255,.03)}.station-row.favorite{border-color:#8ef0bd38}.station-select-button{display:grid;width:100%;min-height:66px;align-items:center;border:0;border-radius:6px;padding:10px 8px 10px 10px;color:inherit;background:transparent;text-align:left}.station-select-button:focus-visible,.station-play-button:focus-visible,.favorite-button:focus-visible,.player-favorite-button:focus-visible,.library-toolbar button:focus-visible,.panel-collapse-button:focus-visible,.panel-stretch-button:focus-visible,.panel-expand-button:focus-visible{outline:3px solid rgba(142,240,189,.34);outline-offset:2px}.station-row-main{display:grid;min-width:0;gap:3px}.station-row strong,.current-station p{overflow:hidden;margin:0;text-overflow:ellipsis;white-space:nowrap}.station-row strong{font-size:.98rem}.station-row small,.current-station span,.station-meta{overflow:hidden;color:#9bb9ae;font-size:.82rem;text-overflow:ellipsis;white-space:nowrap}.station-row-actions{display:flex;align-items:center;gap:7px}.station-codec{min-width:48px;border-radius:999px;padding:5px 8px;color:#0c1514;background:#8ef0bd;font-size:.68rem;font-weight:900;text-align:center;text-transform:uppercase}.station-play-button{min-width:54px;height:34px;border:0;border-radius:999px;padding:0 11px;color:#08100e;background:#ffcf5a;box-shadow:0 8px 24px #ffcf5a33;font-size:.7rem;font-weight:950}.station-play-button:hover{background:#f2b942}.station-play-button.active{color:#08100e;background:#8ef0bd;box-shadow:0 8px 26px #8ef0bd3d}.favorite-button,.player-favorite-button{display:grid;width:34px;height:34px;place-items:center;border:1px solid rgba(207,232,222,.16);border-radius:999px;background:rgba(255,255,255,.06)}.favorite-button:hover,.favorite-button[aria-pressed=true],.player-favorite-button:hover,.player-favorite-button.active{border-color:#ffcf5aa3;background:rgba(255,207,90,.14)}.favorite-icon{width:16px;height:16px;background:#9bb9ae;clip-path:polygon(50% 0%,61% 34%,98% 35%,68% 56%,79% 91%,50% 70%,21% 91%,32% 56%,2% 35%,39% 34%)}.favorite-button[aria-pressed=true] .favorite-icon,.player-favorite-button.active .favorite-icon{background:#ffcf5a}.empty-state{margin:8px;border:1px dashed rgba(207,232,222,.2);border-radius:6px;padding:26px 16px;color:#a6c3b8;background:rgba(255,255,255,.04);font-size:.9rem;font-weight:750;text-align:center}.now-playing{position:absolute;right:28px;bottom:24px;left:28px;z-index:4;display:grid;grid-template-columns:auto minmax(0,1fr) auto auto auto;min-height:72px;align-items:center;gap:16px;border:1px solid rgba(215,237,226,.16);border-radius:8px;padding:12px;background:rgba(9,15,16,.82);box-shadow:0 24px 80px #0000006b;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.player-favorite-button{width:44px;height:44px}.transport-button,.secondary-button{min-height:44px;border:0;border-radius:6px;padding:0 18px;font-weight:850}.transport-button{min-width:84px;color:#08100e;background:#ffcf5a}.transport-button:hover{background:#f2b942}.secondary-button{color:#dff4ec;background:rgba(255,255,255,.08)}.secondary-button:hover{background:rgba(255,255,255,.14)}.current-station{min-width:0}.current-station p{color:#fff;font-size:1.05rem;font-weight:850}.station-meta{max-width:180px;font-weight:750}.error-text{color:#ffad8a}.favorite-toast{position:absolute;bottom:112px;left:50%;z-index:5;min-width:178px;transform:translate(-50%);border:1px solid rgba(255,207,90,.32);border-radius:999px;padding:10px 16px;color:#fff6d6;background:rgba(29,23,8,.86);box-shadow:0 18px 60px #00000061;font-size:.82rem;font-weight:850;text-align:center;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}@media (max-width: 760px){html,body,#root{overflow:hidden}.app-shell{--mobile-player-bottom:calc(22px + env(safe-area-inset-bottom));--mobile-panel-bottom:calc(122px + env(safe-area-inset-bottom));--mobile-panel-clearance:calc(206px + env(safe-area-inset-bottom));height:100dvh;min-height:680px;overflow:hidden}.topbar{top:18px;left:18px;right:18px;gap:10px}h1{max-width:220px}.status-pill{min-width:auto;max-width:116px;padding:7px 9px;font-size:.68rem;white-space:nowrap}.app-shell.library-expanded h1{opacity:0}.station-panel{top:auto;right:14px;bottom:var(--mobile-panel-bottom);left:14px;width:auto;height:min(330px,42dvh);max-height:calc(100dvh - var(--mobile-panel-clearance));min-height:250px;touch-action:pan-y}.station-panel.expanded{top:auto;bottom:var(--mobile-panel-bottom);width:auto;height:calc(100dvh - var(--mobile-panel-clearance));max-height:calc(100dvh - var(--mobile-panel-clearance));min-height:0;background:linear-gradient(145deg,rgba(255,255,255,.12),rgba(255,255,255,.04)),rgba(9,15,16,.88)}.station-panel.collapsed{top:auto;right:14px;bottom:var(--mobile-panel-bottom);left:auto;width:164px;height:auto;min-height:58px}.panel-sheet-handle{display:grid;height:30px;flex:0 0 auto;place-items:center;padding:8px 0 3px;touch-action:none}.panel-sheet-handle:active span,.panel-sheet-handle[aria-expanded=true] span{background:rgba(142,240,189,.72)}.panel-header{grid-template-columns:minmax(0,1fr) auto;gap:7px;padding:4px 14px 10px}.panel-actions{grid-template-columns:36px 36px;gap:6px}.panel-collapse-button,.panel-stretch-button{width:36px;height:36px}.panel-expand-button{min-height:58px;padding:9px 10px}.now-playing{right:14px;bottom:var(--mobile-player-bottom);left:14px;grid-template-columns:minmax(0,1fr) auto auto;gap:10px}.now-playing .transport-button{display:none}.station-row{gap:6px;padding-right:6px}.station-row-actions{gap:5px}.station-codec{min-width:44px;padding:5px 7px;font-size:.64rem}.station-play-button{min-width:50px;padding:0 9px;font-size:.66rem}.station-meta{display:none}.transport-button,.secondary-button{min-width:auto;padding:0 12px}.player-favorite-button{width:42px;height:42px}.favorite-toast{bottom:var(--mobile-panel-bottom)}}
