:root{--bg: #1A1A1A;--bg-dark: #0D0D0D;--bg-light: #696969;--bg-list-hover: #333333;--bg-list-active: #262626;--bg-list-playing: #383838;--text: #E0E0E0;--text-muted: #a7a7a7;--accent: #E0E0E0;--accent-hover: #404040;--red: #cd0025;--green: #22c55e;--surface: var(--bg-list-active);--surface-2: var(--bg-list-hover);--border: rgba(255, 255, 255, .06);--positive: var(--green);--overlay-soft: rgba(255, 255, 255, .06);--overlay-med: rgba(255, 255, 255, .1);--overlay-hard: rgba(255, 255, 255, .18);--backdrop: rgba(0, 0, 0, .45);--divider: #2a2a2a;--icon-filter: brightness(0) invert(.65);--icon-filter-hover: brightness(0) invert(.75);--logo-filter: none;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--radius-pill: 999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--col-width: 480px;--font-stack: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif}:root.theme-light{--bg: #E1E1E1;--bg-dark: #CDCDCD;--bg-light: #888888;--bg-list-hover: #C5C5C5;--bg-list-active: #D3D3D3;--bg-list-playing: #B5B5B5;--text: #414141;--text-muted: #6C6C6C;--accent: #414141;--accent-hover: #B0B0B0;--border: rgba(0, 0, 0, .1);--overlay-soft: rgba(0, 0, 0, .05);--overlay-med: rgba(0, 0, 0, .08);--overlay-hard: rgba(0, 0, 0, .16);--backdrop: rgba(0, 0, 0, .35);--divider: #BFBFBF;--icon-filter: brightness(0) invert(.4);--icon-filter-hover: brightness(0) invert(.25);--logo-filter: brightness(0) invert(.25)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font-stack);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}button,input,select,textarea{font:inherit;color:inherit}button{background:none;border:0;cursor:pointer}a{color:inherit}@font-face{font-family:Inter;font-weight:100 900;font-style:normal;font-display:swap;src:url(/fonts/InterVariable.woff2) format("woff2")}@font-face{font-family:Inter;font-weight:100 900;font-style:italic;font-display:swap;src:url(/fonts/InterVariable-Italic.woff2) format("woff2")}html,body{background:var(--bg);color:var(--text);font-family:"Inter",var(--font-stack);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed;overflow-x:hidden}.page{min-height:100dvh;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding-top:max(0px,env(safe-area-inset-top));padding-bottom:max(0px,env(safe-area-inset-bottom))}.container{width:100%;max-width:var(--col-width);padding:16px 28px;display:flex;flex-direction:column;gap:16px}@media not (display-mode: browser){.container{max-width:none}}*{scrollbar-width:none;-ms-overflow-style:none}*::-webkit-scrollbar{display:none}.text-link{color:var(--accent)}.bottom-actions{display:flex;flex-direction:column;align-items:center;gap:8px;margin:16px 0 max(16px,env(safe-area-inset-bottom))}.store-badge{display:inline-flex;align-items:center;padding:8px 14px;border-radius:var(--radius-pill);font-size:13px;color:var(--text-muted);text-decoration:none;background:none;border:1px solid var(--border);cursor:pointer;transition:color .12s ease,border-color .12s ease}.store-badge:hover{color:var(--text);border-color:var(--overlay-hard)}.store-badge--ext{display:none}@media (min-width: 700px) and (display-mode: browser){.store-badge--ext{display:inline-flex}}.toast{position:fixed;bottom:calc(env(safe-area-inset-bottom) + 16px);left:50%;transform:translate(-50%) translateY(120%);background:var(--surface);color:var(--text);padding:10px 16px;border-radius:var(--radius-pill);font-size:13px;opacity:0;transition:opacity .18s ease,transform .18s ease;pointer-events:none;z-index:1000}.toast.is-visible{opacity:1;transform:translate(-50%) translateY(0)}.player-section{position:relative;display:flex;align-items:center;gap:2px;width:100%}.player-card{background:var(--bg-dark);border-radius:100px;padding:12px 16px;display:flex;align-items:center;gap:16px;opacity:0;transition:opacity .1s ease;width:100%}.player-card.loaded{opacity:1}.player-controls{flex-shrink:0}.play-pause-btn{width:50px;height:50px;border-radius:50%;border:none;background:var(--bg-light);color:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .2s ease;outline:none;position:relative;box-shadow:inset 1px 1px #ffffff1a}.play-pause-btn .pause-icon{margin-left:0;display:inline-flex;align-items:center;justify-content:center;width:35px;height:35px;line-height:1;font-size:0}.play-pause-btn .play-icon svg,.play-pause-btn .pause-icon svg{width:35px;height:35px;display:block;fill:currentColor}.play-pause-btn:hover{background:var(--red)}.play-pause-btn:focus{box-shadow:0 0 0 3px #6b46c14d}.play-pause-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.spinner{display:flex;gap:3px;align-items:center;justify-content:center;margin-left:0}.spinner span{width:4px;height:4px;margin:.2px;background:var(--bg-dark);border-radius:50%;display:inline-block;animation:buffering 1.4s ease-in-out infinite both}.spinner span:nth-child(1){animation-delay:-.32s}.spinner span:nth-child(2){animation-delay:-.16s}.spinnerspan:nth-child(3){animation-delay:0s}@keyframes buffering{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.player-info{flex:1;display:flex;align-items:center;gap:12px;min-width:0;overflow:hidden}.station-logo-container{flex-shrink:0;position:relative}.station-logo{width:65px;height:65px;border:solid 2px var(--bg-light);border-radius:50%;object-fit:cover;background-color:var(--text);cursor:pointer;transition:opacity .2s ease,transform .2s ease}.station-logo:hover{opacity:.8;transform:scale(.95)}.station-initials{width:65px;height:65px;border-radius:50%;background:var(--bg-light);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:var(--text);cursor:pointer;transition:opacity .2s ease,transform .2s ease}.station-initials:hover{opacity:.8;transform:scale(.95)}.station-details{min-width:0;flex:1}.station-name{font-size:16px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;transition:margin-bottom .3s ease}.now-playing{margin-bottom:0;max-height:0;overflow:hidden;opacity:0;transition:max-height .3s ease,opacity .3s ease,margin-bottom .3s ease;position:relative}.now-playing.show{max-height:50px;opacity:1;margin-bottom:6px}.now-playing-text{font-size:13px;font-weight:500;color:var(--text-muted);white-space:nowrap;display:inline-block;max-width:195px;overflow:hidden;text-overflow:ellipsis;vertical-align:bottom}.now-playing-text.is-marquee{max-width:none;overflow:visible;text-overflow:clip;animation:now-playing-marquee var(--marquee-duration, 9s) linear infinite}@keyframes now-playing-marquee{0%,12%{transform:translate(0)}46%,58%{transform:translate(var(--marquee-shift, -100px))}92%,to{transform:translate(0)}}@media (prefers-reduced-motion: reduce){.now-playing-text.is-marquee{animation:none;max-width:195px;overflow:hidden;text-overflow:ellipsis}}.station-country-line{display:flex;align-items:center;gap:8px;transition:margin-top .3s ease}.station-country{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:1px 4px;background:var(--bg);border-radius:2px;margin-left:-4px}.player-actions{flex-shrink:0}.volume-controls{position:absolute;right:-25px;display:flex;flex-direction:column-reverse;align-items:center;gap:3px;padding:2px 4px;opacity:0;transition:opacity .1s ease;touch-action:none}.player-section .player-card.loaded+.volume-controls{opacity:1}.volume-dot{width:5px;height:5px;border-radius:50%;background:var(--bg-dark);cursor:pointer;transition:width .18s ease,height .18s ease,background .15s ease;padding:0;border:0;flex:0 0 auto;box-sizing:border-box;appearance:none;-webkit-appearance:none}.volume-dot.is-filled,.volume-dot:hover{background:var(--bg-light)}.volume-controls.is-dragging .volume-dot{width:var(--vd-size, 6px);height:var(--vd-size, 6px)}.volume-controls.is-dragging .volume-dot.is-filled{background:var(--red)}.visit-btn{color:var(--bg-light);text-decoration:none;font-size:12px;font-weight:500;padding:0;border:none;background:none;transition:color .2s ease}.visit-btn:hover{color:var(--red)}.station-country-line{display:flex;align-items:center;gap:8px}.btn-add-favorite{display:flex;align-items:center;justify-content:center;padding:2px;border-radius:50%;align-self:center}.btn-add-favorite{display:flex;align-items:center;justify-content:center;padding:2px;border-radius:50%}.btn-add-favorite:hover{background:var(--overlay-med)}.heart-icon{width:12px;height:12px;fill:transparent;stroke:var(--text-muted);stroke-width:2;transition:fill .2s ease,stroke .2s ease;margin-bottom:-1.5px}.btn-add-favorite:hover .heart-icon{stroke:var(--red)}.btn-add-favorite.is-favorited .heart-icon{fill:var(--red);stroke:var(--red)}.btn-icon{width:24px;height:24px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:50px;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s ease;line-height:1}.btn-icon:hover{background:var(--overlay-med);color:var(--text)}.favorites-section{flex-shrink:0;display:flex;flex-direction:column;margin-top:10px}.favorites-header{display:flex;align-items:center;margin-bottom:12px;width:100%}.list-selector{display:flex;flex-direction:column;gap:4px;width:100%}.list-header{display:flex;align-items:center;justify-content:space-between;width:100%}.dock-title{display:flex;align-items:center;gap:8px}.dock-logo{width:auto;height:28px;filter:var(--icon-filter);cursor:pointer;transition:opacity .2s ease}.dock-logo:hover{opacity:.7}.dock-label{font-size:13px;color:var(--text-muted);font-weight:600;margin:0;flex-shrink:0}.favorites-actions{display:flex;gap:8px;align-items:center}.btn-export,.btn-import{color:var(--text-muted)}.btn-export:hover,.btn-import:hover{color:var(--text);background:var(--overlay-med)}.btn-export .icon,.btn-import .icon{width:14px;height:14px;filter:var(--icon-filter);transition:filter .2s ease}.btn-export:hover .icon,.btn-import:hover .icon{filter:var(--icon-filter-hover)}.favorites-list{min-height:57px;max-height:225px;overflow-y:auto;border-radius:8px;background:var(--bg-dark);transition:max-height .3s ease}body.search-active .favorites-list{max-height:57px}.station-item{display:flex;align-items:center;padding:12px 16px;cursor:pointer;transition:background .2s ease;border-bottom:1px solid var(--divider);touch-action:pan-x pan-y;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.station-list-rows.reorder-active .station-item{touch-action:none}.station-item:hover{background:var(--bg-list-hover)}.station-item:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.station-item:last-child{border-bottom:none;border-bottom-left-radius:8px;border-bottom-right-radius:8px}.station-item.playing{background:var(--bg-list-playing)}.station-item.playing .station-item-name:after{content:"";display:inline-block;width:6px;height:6px;background-color:var(--red);border-radius:50%;margin-left:8px;vertical-align:middle;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.station-item-logo{width:32px;height:32px;border:solid 1px var(--bg-light);border-radius:50%;object-fit:cover;margin-right:12px;flex-shrink:0;background-color:#fff}.station-item-initials{width:32px;height:32px;border-radius:50%;background:var(--bg-light);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:var(--text);margin-right:12px;flex-shrink:0}.station-item-info{flex:1;min-width:0}.station-item-name{font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.station-item-country{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px}.station-item-actions{display:flex;align-items:center;gap:8px;opacity:0;transition:opacity .2s ease}.station-item:hover .station-item-actions{opacity:1}.btn-remove{width:24px;height:24px;color:var(--text)}.btn-remove svg{width:14px;height:14px;opacity:.7;transition:opacity .2s ease}.btn-remove:hover{background:var(--overlay-med);color:var(--red)}.btn-remove:hover svg{opacity:1}.btn-drag{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;cursor:grab;touch-action:none}.btn-drag:active{cursor:grabbing}.btn-drag:hover{background:var(--overlay-hard)}.btn-drag svg{width:14px;height:14px;opacity:.7;transition:opacity .2s ease}.btn-drag:hover svg{opacity:1}.station-item.dragging{background:var(--bg-list-active);transform:scale(1.02);opacity:.95;z-index:5;position:relative;transition:transform .12s ease}@media (max-width: 699px),not (display-mode: browser){.station-item-actions{opacity:1}}.empty-state{display:flex;align-items:center;justify-content:center;height:auto;min-height:57px;text-align:center;color:var(--text-muted);font-size:14px}.list-share-row{display:flex;justify-content:center;margin:6px 0 2px}.share-list-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-pill);color:var(--text-muted);font:inherit;font-size:12px;font-weight:500;cursor:pointer;transition:color .12s ease,border-color .12s ease,background .12s ease;-webkit-tap-highlight-color:transparent}.share-list-btn:hover{color:var(--text);border-color:var(--red);background:#cd002514}.share-list-btn__icon{width:14px;height:14px;flex-shrink:0}.logo-slot{position:relative;display:inline-flex;flex-shrink:0;line-height:0}.logo-slot--sm{margin-right:12px}.logo-cycle-btn{position:absolute;right:-2px;bottom:-2px;width:18px;height:18px;border-radius:50%;border:1px solid var(--bg-dark, #1a1a1a);background:#000000c7;color:var(--text, #fff);padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.7);pointer-events:none;transition:opacity .15s ease,transform .15s ease,background .15s ease}.logo-cycle-btn svg{width:10px;height:10px;display:block}@media (hover: hover) and (pointer: fine){.logo-slot:hover .logo-cycle-btn{opacity:1;transform:scale(1);pointer-events:auto}}.logo-slot.is-pressed .logo-cycle-btn{opacity:1;transform:scale(1);pointer-events:auto}.logo-cycle-btn:hover{background:var(--red, #e23a3a)}.logo-cycle-btn:focus-visible{outline:2px solid var(--accent, #fff);outline-offset:1px;opacity:1;transform:scale(1);pointer-events:auto}.logo-slot--lg .logo-cycle-btn{width:24px;height:24px;right:0;bottom:0}.logo-slot--lg .logo-cycle-btn svg{width:13px;height:13px}.logo-slot[data-overridden="1"] .logo-cycle-btn{background:var(--red, #e23a3a)}.list-dropdown{position:relative}.favorites-section.list-dropdown-open{overflow:visible}.list-dropdown-btn{display:flex;align-items:center;gap:6px;background:none;border:none;padding:0 8px;border-radius:4px;cursor:pointer;font-size:13px;color:var(--text);transition:background-color .2s ease}.list-dropdown-btn:hover{background-color:var(--background-hover)}.dropdown-arrow{font-size:10px;transition:transform .2s ease}.list-dropdown-btn.open .dropdown-arrow{transform:rotate(180deg)}.list-dropdown-menu{position:absolute;top:100%;right:0;margin-top:10px;min-width:250px;background:var(--bg);border-radius:8px;z-index:1000;overflow:hidden;animation:dropdownSlide .2s ease}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.list-items{max-height:200px;overflow-y:auto}.list-item{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;font-size:12px;color:var(--text);transition:background-color .2s ease;position:relative}.list-item:hover{background-color:var(--bg-list-hover)}.list-item.active{background-color:var(--red);color:var(--text)}.list-item.active:hover{background-color:var(--red-dark, var(--red))}.list-item-content{display:flex;align-items:center;justify-content:space-between;width:100%;flex:1}.list-name{cursor:pointer;flex:1}.list-item-actions{display:flex;align-items:center;gap:4px}.action-icon{width:14px;height:14px;opacity:.7;color:var(--text-muted)}.list-export-btn{opacity:0;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:22px;height:22px}.list-item:hover .list-export-btn{opacity:1}.list-export-btn:hover{background-color:var(--overlay-med)}.list-export-btn:hover .action-icon{opacity:1;color:var(--text)}.list-edit-btn,.list-share-btn{opacity:0;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:22px;height:22px}.list-item:hover .list-edit-btn,.list-item:hover .list-share-btn{opacity:1}.list-edit-btn:hover,.list-share-btn:hover{background-color:var(--overlay-med)}.list-edit-btn:hover .action-icon,.list-share-btn:hover .action-icon{opacity:1;color:var(--text)}.list-more-btn{display:none;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;flex-shrink:0;align-items:center;justify-content:center;width:32px;height:32px}.list-more-btn:hover{background-color:var(--overlay-med)}.action-icon--more{width:18px;height:18px;opacity:1}.list-count{font-size:11px;color:var(--text-muted);min-width:20px;text-align:right}.list-remove-btn{opacity:0;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;font-size:19px;line-height:1;transition:all .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center;width:22px;height:22px}.list-item:hover .list-remove-btn{opacity:1}.list-remove-btn:hover{background-color:var(--overlay-med);color:var(--red)}.list-item.active .list-count,.list-item.active .list-remove-btn{color:#fffc}.list-item.active .list-remove-btn:hover{background-color:#fff3;color:var(--text)}.list-actions{border-top:1px solid var(--divider);padding:8px;display:flex;gap:0}.add-list-btn{display:flex;align-items:center;gap:6px;flex:1;background:none;border:none;padding:6px 8px;border-radius:4px;cursor:pointer;font-size:12px;color:var(--text-muted);transition:all .2s ease}.add-list-btn:hover{background-color:var(--bg-list-hover);color:var(--text)}.plus-icon{font-size:14px;font-weight:700;width:14px;height:14px;display:flex;align-items:center;justify-content:center}.list-actions-divider{width:1px;background:var(--divider);margin:4px 0}.import-list-btn{display:flex;align-items:center;gap:6px;flex:1;background:none;border:none;padding:6px 8px;border-radius:4px;cursor:pointer;font-size:12px;color:var(--text-muted);transition:all .2s ease}.import-list-btn:hover{background-color:var(--bg-list-hover);color:var(--text)}.import-icon{width:14px;height:14px;color:var(--text-muted)}.import-list-btn:hover .import-icon{color:var(--text)}.search-section{flex-shrink:0;margin-top:10px}.search-input-container{position:relative;margin-bottom:12px}#searchInput{width:100%;padding:12px 16px;background:var(--bg-dark);border:1px solid transparent;border-radius:50px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s ease}#searchInput:focus,body.search-active #searchInput{border-color:var(--bg-light)}#searchInput::placeholder{color:var(--text-muted)}.clear-search-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:24px;height:24px;border:none;background:transparent;color:var(--accent);cursor:pointer;border-radius:50px;display:flex;align-items:center;justify-content:center;font-size:16px}.clear-search-btn:hover{background:var(--overlay-med);color:var(--text)}.search-filters{display:flex;gap:8px;margin-bottom:12px;padding:0 4px}.filter-btn{flex:1;padding:1px 12px;border:1px solid var(--text-muted);border-radius:20px;background:transparent;color:var(--text-muted);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:center}.filter-btn:hover{background:var(--overlay-soft);border-color:var(--text);color:var(--text)}.filter-btn.active{background:var(--text-muted);color:var(--bg);border-color:var(--text-muted)}.filter-btn.active:hover{background:var(--text);opacity:.9}.search-results{background:var(--bg-dark);border-radius:8px}.search-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-muted);gap:12px;text-align:center}.loading-spinner{width:20px;height:20px;border:2px solid var(--bg-light);border-top:2px solid var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.search-error{display:flex;align-items:center;justify-content:center;padding:40px 20px;color:#ff6b6b;text-align:center;font-size:14px}.search-results-list{max-height:220px;overflow-y:auto}.search-item{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid var(--divider);transition:background .2s ease;cursor:pointer}.search-item:hover{background:var(--bg-list-hover)}.search-item:first-child{border-top-left-radius:8px;border-top-right-radius:8px}.search-item:last-child{border-bottom:none;border-bottom-left-radius:8px;border-bottom-right-radius:8px}.search-item-actions{display:flex;gap:8px;margin-left:auto;padding-right:4px}.btn-add{display:flex;align-items:center;justify-content:center;padding:2px;border-radius:50%;border:none}.btn-add:hover{background:var(--overlay-med)}.btn-add .heart-icon{width:12px;height:12px;fill:var(--red);transition:fill .2s ease;margin-bottom:-1.5px}.btn-add:hover .heart-icon{fill:var(--red);opacity:.8}.btn-preview{color:var(--accent)}.btn-preview:hover{background:#6b46c11a;color:var(--accent-hover)}.btn-station-info{background:none;border:0;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;transition:color .16s ease}.btn-station-info:hover{color:var(--text)}.btn-station-info .info-icon{width:16px;height:16px}.station-info-body{display:flex;flex-direction:column;gap:18px}.station-info__header{display:flex;align-items:center;gap:14px}.station-info__logo,.station-info__hero{width:60px;height:60px;border-radius:12px;object-fit:cover;background:#fff;flex-shrink:0}.station-info__hero{border-radius:12px}.station-info__initials{width:60px;height:60px;border-radius:12px;background:var(--bg-list-hover);color:var(--text);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:22px;flex-shrink:0}.station-info__meta{min-width:0;flex:1}.station-info__name{color:var(--text);font-size:16px;font-weight:600;margin-bottom:6px;word-break:break-word}.station-info__tags{display:flex;flex-wrap:wrap;gap:4px}.station-info__tag{font-size:11px;color:var(--text-muted);background:var(--overlay-soft);padding:2px 8px;border-radius:999px;letter-spacing:.02em}.station-info__section{display:flex;flex-direction:column;gap:6px}.station-info__section h4{margin:0;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.station-info__about{margin:0;color:var(--text);font-size:13.5px;line-height:1.55}.station-info__source{margin:0;font-size:11.5px;color:var(--text-muted)}.station-info__source a{color:var(--text-muted);text-decoration:underline;text-underline-offset:2px}.station-info__loading{margin:0;font-size:13px;color:var(--text-muted);font-style:italic}.station-info__stream{display:grid;grid-template-columns:1fr 1fr;gap:6px 14px;margin:0}.station-info__stream>div{display:flex;justify-content:space-between;align-items:baseline;gap:8px;padding:4px 0;border-bottom:1px solid var(--border)}.station-info__stream dt{font-size:11px;color:var(--text-muted);letter-spacing:.04em;text-transform:uppercase;margin:0}.station-info__stream dd{font-size:13px;color:var(--text);margin:0;text-align:right}.station-info__actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.station-info__action{flex:1;text-align:center;text-decoration:none}@media (max-width: 699px),not (display-mode: browser){.station-info__stream{grid-template-columns:1fr}}.mobile-lists{display:flex;flex-direction:column;flex:1;min-height:0}.list-tabs{flex:0 0 auto}.lists-carousel{flex:1;min-height:0}.list-tabs{display:flex;align-items:center;gap:4px;padding:0 12px;border-bottom:1px solid var(--overlay-soft);background:var(--bg);position:sticky;top:0;z-index:5}.list-tabs__scroller{flex:1;display:flex;gap:4px;overflow-x:auto;scroll-behavior:smooth;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch;padding:8px 0}.list-tab{flex-shrink:0;padding:7px 14px;background:transparent;border:0;border-radius:999px;color:var(--text-muted);font:inherit;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;-webkit-tap-highlight-color:transparent;transition:color .16s ease,background .16s ease,transform .1s ease;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.list-tab:active{transform:scale(.95)}.list-tab.is-active{color:var(--text);background:var(--bg-list-hover)}.list-tabs__menu-btn{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:0;border-radius:50%;color:var(--text-muted);cursor:pointer;margin-left:4px;-webkit-tap-highlight-color:transparent;transition:color .16s ease,background .16s ease,transform .1s ease}.list-tabs__menu-btn:hover{background:var(--overlay-soft);color:var(--text)}.list-tabs__menu-btn:active{transform:scale(.9)}.list-tabs__menu-btn svg{width:20px;height:20px}.lists-carousel{display:flex;flex:1;min-height:0;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch}.list-page{flex:0 0 100%;scroll-snap-align:start;scroll-snap-stop:always;overflow-y:auto;padding:12px 16px calc(180px + env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch}.list-page .favorites-list{background:var(--bg-dark);border-radius:8px;overflow:hidden;min-height:57px}.list-page .empty-state{display:flex;align-items:center;justify-content:center;min-height:57px;padding:12px 16px;text-align:center;color:var(--text-muted);font-size:14px}.play-pause-btn{transition:transform .1s ease}.play-pause-btn:active{transform:scale(.92)}.btn-add-favorite,.btn-station-info,.btn-remove,.btn-add,.list-more-btn,.filter-btn,.visit-btn,.mobile-topbar__btn,.modal-close-btn,.off-canvas__close,.search-overlay__close{transition:transform .1s ease}.btn-add-favorite:active,.btn-station-info:active,.btn-remove:active,.btn-add:active,.list-more-btn:active,.filter-btn:active,.visit-btn:active,.mobile-topbar__btn:active,.modal-close-btn:active,.off-canvas__close:active,.search-overlay__close:active{transform:scale(.9)}.btn-primary,.btn-secondary,.list-action-row,.station-info__action,.off-canvas__item,.add-list-btn,.import-list-btn,.about__more-btn,.share-copy-btn,.btn-audio-reset{transition:transform .1s ease}.btn-primary:active,.btn-secondary:active,.list-action-row:active,.station-info__action:active,.off-canvas__item:active,.add-list-btn:active,.import-list-btn:active,.about__more-btn:active,.share-copy-btn:active,.btn-audio-reset:active{transform:scale(.97)}.toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%);background:var(--bg-list-hover);color:var(--text);padding:12px 20px;border-radius:8px;font-size:14px;opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:1000}.toast.show{opacity:1;pointer-events:all}.toast.error{background:var(--red)}.toast.success{background:var(--green)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--backdrop);-webkit-backdrop-filter:blur(14px) saturate(120%);backdrop-filter:blur(14px) saturate(120%);display:none;align-items:center;justify-content:center;z-index:2000;opacity:0;transition:opacity .3s ease}.modal.show{display:flex;opacity:1;pointer-events:all}.modal-content{background:var(--bg-dark);border-radius:12px;width:315px;max-width:90vw;animation:modalSlide .3s ease}@keyframes modalSlide{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:30px 40px 0;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:14px;color:var(--text)}.modal-close-btn{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-muted);padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;-webkit-tap-highlight-color:transparent;outline:none}.modal-close-btn:focus{outline:none}.modal-close-btn:focus-visible{outline:2px solid rgba(255,255,255,.3);outline-offset:2px}.modal-close-btn:hover{background-color:var(--background-hover);color:var(--text)}.modal-body{padding:14px 24px}.modal-body label{display:block;font-size:12px;color:var(--text-muted);margin-bottom:8px}.modal-body input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:6px;background:var(--background);color:var(--text);font-size:13px;box-sizing:border-box}.stream-status-section{margin-bottom:15px}.btn-audio-reset{margin-top:5px}.modal-body input:focus{outline:none;border-color:var(--red);box-shadow:0 0 0 2px #ef444433}.error-message{color:var(--red);font-size:11px;margin-top:8px}.about__lead{margin:0 0 18px;color:var(--text);font-size:14px;line-height:1.55}.about__section{margin:18px 0 6px;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.modal-body .about__section+p,.modal-body .about__section+ul{margin-top:0}.about__tech p{margin:0 0 12px;font-size:13px;line-height:1.55;color:var(--text-muted)}.about__tech p strong,.about__tech p em{color:var(--text);font-weight:600}.about__tech p em{font-style:italic}.about__tech p code{background:var(--overlay-med);padding:1px 5px;border-radius:4px;font-size:12px}.about__list{margin:0 0 10px;padding-left:18px;font-size:13px;color:var(--text-muted);line-height:1.55}.about__list li{margin-bottom:4px}.about__list strong,.modal-body .about__lead strong{color:var(--text);font-weight:600}.about__list code{background:var(--overlay-med);padding:1px 5px;border-radius:4px;font-size:12px}.about__footer{margin:22px 0 0;padding-top:14px;border-top:1px solid var(--border);font-size:12px;color:var(--text-muted)}.about__more-btn{display:inline-block;margin:4px 0 16px;padding:6px 14px;background:transparent;border:1px solid var(--overlay-hard);border-radius:999px;color:var(--text-muted);font-family:inherit;font-size:12px;font-weight:500;cursor:pointer;transition:color .16s ease,border-color .16s ease,background .16s ease}.about__more-btn:hover{color:var(--text);border-color:var(--text-muted);background:var(--overlay-soft)}.about__more-label-expanded,#aboutModalBody.show-tech .about__more-label-collapsed{display:none}#aboutModalBody.show-tech .about__more-label-expanded{display:inline}.about__tech{display:none}#aboutModalBody.show-tech .about__tech{display:block}.modal-footer{display:flex;gap:8px;padding:16px 20px;border-top:1px solid var(--border);justify-content:flex-end}.btn-secondary{background:none;border:1px solid var(--border);color:var(--text-muted);padding:8px 16px;border-radius:6px;cursor:pointer;font-size:12px;transition:all .2s ease}.btn-secondary:hover{background-color:var(--background-hover);color:var(--text)}.btn-primary{background:var(--red);border:none;color:var(--text);padding:8px 16px;border-radius:6px;cursor:pointer;font-size:12px;transition:all .2s ease}.btn-primary:hover{background-color:var(--red-dark, var(--red))}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.modal-links{display:flex;flex-direction:column;gap:12px;margin-top:20px}.modal-link{display:inline-block;color:var(--red);text-decoration:none;font-size:13px;font-weight:500;padding:8px 12px;border:1px solid var(--red);border-radius:6px;text-align:center;transition:all .2s ease}.modal-link:hover{background-color:var(--red);color:var(--text)}.dock-logo-modal{width:auto;height:30px;filter:var(--logo-filter)}.share-hint{margin:0 0 12px;color:var(--text-muted);font-size:12px;line-height:1.5}#shareLinkInput{font-family:ui-monospace,SF Mono,Consolas,monospace;font-size:11px;color:var(--text-muted);cursor:text;user-select:all;margin-bottom:12px}.share-copy-btn{width:100%;padding:10px 16px;font-size:13px}.choice-modal-footer{flex-wrap:wrap}.choice-modal-footer #choiceCancelBtn{margin-right:auto}.list-action-row{display:flex;align-items:center;gap:14px;width:100%;padding:14px 18px;border:0;background:none;color:var(--text);font:inherit;font-size:15px;text-align:left;cursor:pointer;border-radius:10px;transition:background .14s ease;-webkit-tap-highlight-color:transparent}.list-action-row:hover,.list-action-row:active{background:var(--overlay-soft)}.list-action-row--danger{color:var(--red)}.list-action-icon{width:20px;height:20px;flex-shrink:0;color:currentColor}.list-actions-body{padding:6px 10px 12px}@media (max-width: 699px),not (display-mode: browser){.modal:not(#infoModal){align-items:flex-end;height:100dvh}.modal:not(#infoModal) .modal-content{width:100%;max-width:none;border-radius:18px 18px 0 0;padding-bottom:max(12px,env(safe-area-inset-bottom));animation:modalSlideUp .28s cubic-bezier(.22,1,.36,1)}@keyframes modalSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal:not(#infoModal) .modal-header{padding:18px 20px 0}.modal:not(#infoModal) .modal-body{padding:14px 20px}.modal:not(#infoModal) .modal-footer{padding:6px 20px 12px;gap:10px}.modal:not(#infoModal) .modal-body input{padding:14px;font-size:16px;border-radius:10px}.modal:not(#infoModal) .btn-primary,.modal:not(#infoModal) .btn-secondary{flex:1;padding:14px 16px;font-size:15px;border-radius:10px;min-height:48px}.modal:not(#infoModal) .modal-content:before{content:"";display:block;width:36px;height:4px;margin:8px auto 0;border-radius:999px;background:var(--overlay-hard)}.modal:not(#infoModal) #shareLinkInput{font-size:13px;padding:14px}}@media (min-width: 700px) and (display-mode: browser){.modal .modal-content{display:flex;flex-direction:column;max-height:85vh}.modal .modal-header,.modal .modal-footer{flex-shrink:0}.modal .modal-body{overflow-y:auto;flex:1 1 auto;min-height:0}#stationInfoModal .modal-content{width:420px}#infoModal .modal-content{width:520px}}.btn-audio-reset{padding:1px 12px;font-size:11px;background:var(--accent-hover);color:var(--text);border:none;border-radius:20px;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-audio-reset:hover{background:var(--red);color:#fff}.install-info-modal-root.modal{background:var(--backdrop)}.install-info-modal{max-width:420px;padding:24px 22px 20px;text-align:left;border-radius:16px;background:var(--bg-list-active);border:1px solid var(--border)}.install-info__title{margin:0 0 8px;font-size:18px;font-weight:600;letter-spacing:-.005em;color:var(--text)}.install-info__lead{margin:0 0 14px;color:var(--text-muted);font-size:14px;line-height:1.55}.install-info__lead strong,.install-info__benefits strong,.install-info__hint strong,.install-info__steps strong{color:var(--text);font-weight:600}.install-info__benefits{margin:0 0 16px;padding:0;list-style:none;display:flex;flex-direction:column;gap:6px}.install-info__benefits li{position:relative;padding-left:18px;font-size:13.5px;color:var(--text-muted);line-height:1.5}.install-info__benefits li:before{content:"";position:absolute;left:0;top:9px;width:6px;height:6px;border-radius:50%;background:var(--red);opacity:.85}.install-info__steps{margin:0 0 16px;padding:0;list-style:none;counter-reset:step;display:flex;flex-direction:column;gap:10px}.install-info__steps li{counter-increment:step;position:relative;padding-left:30px;font-size:14px;color:var(--text);line-height:1.5;min-height:22px}.install-info__steps li:before{content:counter(step);position:absolute;left:0;top:0;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;background:#cd002526;color:var(--red);border-radius:50%;font-size:12px;font-weight:700;line-height:1}.install-info__inline-icon{width:16px;height:16px;vertical-align:-3px;margin:0 2px}.install-info__primary,.install-info__secondary{display:block;width:100%;font-family:inherit;font-weight:500;cursor:pointer;text-align:center;border:0;border-radius:var(--radius-pill);margin-top:6px;transition:background .12s ease,color .12s ease;text-decoration:none}.install-info__primary{padding:11px 18px;background:var(--red);color:#fff;font-size:14px}.install-info__primary:hover{background:#b50020}.install-info__secondary{padding:9px 18px;background:transparent;color:var(--text-muted);font-size:13px}.install-info__secondary:hover{background:var(--overlay-soft);color:var(--text)}.install-info__hint{margin:8px 0 6px;font-size:12px;color:var(--text-muted);line-height:1.5}.install-info__hint code{background:var(--overlay-med);padding:1px 6px;border-radius:4px;font-size:12px}.install-walk{margin:0 0 10px;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}.install-walk__step{display:flex;gap:10px;align-items:flex-start}.install-walk__num{flex:0 0 22px;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;background:var(--red);color:#fff;border-radius:50%;font-weight:700;font-size:12px;line-height:1;margin-top:1px}.install-walk__body{flex:1;min-width:0}.install-walk__caption{margin:0 0 5px;font-size:13.5px;color:var(--text);line-height:1.3}.install-walk__caption strong{font-weight:700}.install-walk__de{color:var(--text-muted);font-size:12.5px;font-weight:400}.install-walk__visual{background:var(--bg-dark);border:1px solid var(--border);border-radius:10px;padding:6px 8px;display:flex;align-items:center;justify-content:center;min-height:40px}.install-walk__visual--stack{flex-direction:column;gap:6px;align-items:stretch}.ios-urlbar{display:flex;align-items:center;gap:8px;background:var(--bg-list-hover);border-radius:999px;padding:8px 14px;width:100%;font-size:13px;color:var(--text-muted)}.ios-urlbar__aa{font-size:14px;color:var(--text-muted);font-weight:600}.ios-urlbar__aa small{font-size:10px;vertical-align:super;margin-left:-2px}.ios-urlbar__lock,.ios-urlbar__refresh{width:14px;height:14px;color:var(--text-muted);flex-shrink:0}.ios-urlbar__lock svg,.ios-urlbar__refresh svg{width:100%;height:100%}.ios-urlbar__host{flex:1;text-align:center;color:var(--text);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ios-toolbar{display:flex;align-items:center;gap:8px;width:100%}.ios-toolbar__btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--overlay-soft);color:var(--text);font-size:16px;flex-shrink:0}.ios-toolbar__pill{flex:1;text-align:center;background:var(--overlay-soft);border-radius:999px;padding:8px 12px;font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ios-toolbar__btn--target{position:relative;background:#cd00252e;color:#fff;box-shadow:0 0 0 2px var(--red);animation:walkPulse 1.6s ease-in-out infinite}.ios-toolbar__dots{font-size:16px;line-height:1;letter-spacing:0;font-weight:700}@keyframes walkPulse{0%,to{box-shadow:0 0 0 2px var(--red),0 0 #cd002566}50%{box-shadow:0 0 0 2px var(--red),0 0 0 10px #cd002500}}.ios-menu{display:flex;align-items:center;gap:10px;width:100%;background:var(--bg-list-active);border-radius:10px;padding:9px 12px}.ios-menu--target{background:#cd002529;border:1px solid rgba(205,0,37,.55)}.ios-menu__icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;color:var(--text);flex-shrink:0}.ios-menu__icon svg{width:100%;height:100%}.ios-menu__icon--plus{font-size:24px;font-weight:300;line-height:1}.ios-menu__label{flex:1;font-size:14px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ios-menu__label small{color:var(--text-muted);font-size:12px;font-weight:400;margin-left:2px}.ios-confirm-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;background:var(--bg-list-active);border-radius:10px;padding:6px 10px}.ios-confirm-bar__label{color:var(--text);font-size:13px;font-weight:500}.ios-confirm-bar__btn{background:#0a84ff;color:#fff;border-radius:999px;padding:6px 14px;font-size:13px;font-weight:600;white-space:nowrap}.ios-confirm-bar__btn small{color:#ffffffb8;font-weight:400;margin-left:2px}@media (max-width: 699px),not (display-mode: browser){.install-info-modal-root.modal .install-info-modal{max-height:92dvh;display:flex;flex-direction:column}.install-info-modal-root.modal .install-info-modal .modal-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.install-info-modal-root.modal .install-info__title{font-size:16px;margin-bottom:8px}}@media (min-width: 700px) and (display-mode: browser){.install-info-modal-root.modal,body.viz-active .install-info-modal-root.modal{position:fixed!important;top:0;left:0;width:100%;height:100%;background:transparent;pointer-events:none;justify-content:flex-start;align-items:flex-end}.install-info-modal-root.modal .install-info-modal{pointer-events:auto;margin:0 0 20px 20px;transform:translate(-20px);opacity:0;transition:transform .24s cubic-bezier(.22,1,.36,1),opacity .2s ease}.install-info-modal-root.modal.show .install-info-modal{transform:translate(0);opacity:1}}.install-section{position:relative;transition:opacity .26s cubic-bezier(.22,1,.36,1),transform .26s cubic-bezier(.22,1,.36,1)}.install-section.is-dismissed{opacity:0;transform:translateY(8px) scale(.98);pointer-events:none}.install-section.is-entering{opacity:0;transform:translateY(16px) scale(.96)}.install-section__close{position:absolute;top:6px;right:6px;width:26px;height:26px;display:flex;align-items:center;justify-content:center;background:none;border:0;border-radius:50%;color:var(--text-muted);cursor:pointer;padding:0;z-index:1;transition:background .12s ease,color .12s ease}.install-section__close:hover{background:var(--overlay-med);color:var(--text)}.install-section__toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:6px 32px 6px 4px;background:none;border:0;color:var(--text-muted);font-size:12px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;cursor:pointer}.install-section__toggle:hover{color:var(--text)}.install-section__chevron{width:14px;height:14px;color:var(--text-muted);transition:transform .2s ease}.install-section.is-collapsed .install-section__chevron{transform:rotate(-90deg)}.install-section__body{margin-top:8px}.install-section__intro{margin:0 0 12px;color:var(--text-muted);font-size:13px;line-height:1.45}.install-section__row{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.install-section__label{font-size:12px;color:var(--text-muted);letter-spacing:.02em}.install-section__buttons{display:flex;flex-wrap:wrap;gap:6px}.install-section__btn{background:var(--bg-list-active);color:var(--text);border:1px solid transparent;border-radius:var(--radius-pill);padding:6px 12px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;text-align:center;transition:background .12s ease,border-color .12s ease,color .12s ease}.install-section__btn:hover{background:var(--bg-list-hover)}.install-section__btn.is-current{border-color:var(--red);box-shadow:0 0 0 1px #cd002533 inset;color:var(--text)}.install-section__back{display:inline-flex;align-items:center;gap:4px;margin-bottom:8px;padding:4px 8px 4px 4px;background:none;border:0;border-radius:var(--radius-pill);color:var(--text-muted);cursor:pointer;font:inherit;font-size:12px;transition:background .12s ease,color .12s ease}.install-section__back:hover{background:var(--overlay-soft);color:var(--text)}.install-section__back svg{width:14px;height:14px}.install-section__detail .install-info__title{margin:0 0 8px;font-size:14px}.install-section__detail .install-info__lead{font-size:12.5px;margin:0 0 10px}.install-section__detail .install-info__benefits{margin:0 0 12px;gap:4px}.install-section__detail .install-info__benefits li,.install-section__detail .install-info__steps li{font-size:12.5px}.install-section__detail .install-info__steps{gap:6px}.install-section__detail .install-info__primary,.install-section__detail .install-info__secondary{font-size:12.5px;padding-top:8px;padding-bottom:8px}.install-section__detail .install-info__hint{font-size:11px;margin:6px 0}@media (max-width: 699px),not (display-mode: browser){.install-section{margin-top:4px;padding:12px 0 0;border-top:1px solid var(--border)}.install-section__close{display:none}.install-section__buttons{width:100%}.install-section__btn{flex:1}}@media (min-width: 700px) and (display-mode: browser){.install-section{position:fixed;right:20px;bottom:20px;width:340px;max-width:calc(100vw - 40px);padding:14px 16px 16px;background:var(--bg-list-active);border:1px solid var(--border);border-radius:16px;z-index:60}.install-section__toggle{display:none}.install-section__body{display:block!important;margin-top:0}.install-section__intro{margin:0 0 10px;padding-right:24px;font-size:13px;color:var(--text)}}.mobile-topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:8px 12px;padding-top:calc(8px + env(safe-area-inset-top));background:var(--bg);border-bottom:1px solid var(--border)}.mobile-topbar__btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:0;border-radius:10px;color:var(--text);cursor:pointer;padding:0}.mobile-topbar__btn:hover{background:var(--bg-list-hover)}.mobile-topbar__btn svg{width:22px;height:22px}.mobile-topbar__logo{display:flex;align-items:center;text-decoration:none}.mobile-topbar__logo img{height:26px;width:auto;filter:var(--logo-filter)}.off-canvas{position:fixed;inset:0;z-index:80;pointer-events:none;visibility:hidden}.off-canvas.is-open{pointer-events:auto;visibility:visible}.off-canvas__backdrop{position:absolute;inset:0;background:#00000080;opacity:0;transition:opacity .2s ease}.off-canvas.is-open .off-canvas__backdrop{opacity:1}.off-canvas__panel{position:absolute;top:0;left:0;bottom:0;width:min(82vw,320px);background:var(--bg);border-right:1px solid var(--border);transform:translate(-100%);transition:transform .22s ease;display:flex;flex-direction:column;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.off-canvas.is-open .off-canvas__panel{transform:translate(0)}.off-canvas__header{position:relative;display:flex;align-items:center;justify-content:center;padding:20px 18px 12px}.off-canvas__brand{display:flex;flex-direction:column;align-items:center;gap:2px;margin:0 auto}.off-canvas__logo{height:24px;width:auto;filter:var(--logo-filter)}.off-canvas__version{font-size:10px;letter-spacing:.02em;color:var(--text-muted);opacity:.6;pointer-events:none;user-select:none}.off-canvas__close{position:absolute;top:50%;right:18px;transform:translateY(-50%);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:none;border:0;border-radius:50%;color:var(--text-muted);font-size:22px;cursor:pointer;padding:0}.off-canvas__close:hover{background:var(--bg-list-hover);color:var(--text)}.off-canvas__nav{display:flex;flex-direction:column;padding:6px 8px;gap:2px;flex:1}.off-canvas__item{display:flex;align-items:center;gap:10px;padding:14px;color:var(--text);text-decoration:none;background:none;border:0;border-radius:10px;font-size:15px;font-family:inherit;cursor:pointer;text-align:left;width:100%}.off-canvas__item:hover{background:var(--bg-list-hover)}.off-canvas__item--muted{color:var(--text-muted);font-size:13px;margin-top:auto}.off-canvas__item--cta{background:#cd00252e;border:1px solid rgba(205,0,37,.6);font-weight:600;margin-bottom:6px}.off-canvas__item--cta:hover{background:#cd00254d;border-color:var(--red)}.off-canvas__item--cta .off-canvas__chev{color:var(--text)}.off-canvas__icon{width:16px;height:16px}.off-canvas__chev{margin-left:auto;color:var(--text-muted);font-size:16px}.search-overlay,body.viz-active .search-overlay{position:fixed!important;inset:0;z-index:70;background:var(--bg);transform:translate(100%);transition:transform .22s ease;display:flex;flex-direction:column;pointer-events:none;visibility:hidden}.search-overlay.is-open{transform:translate(0);pointer-events:auto;visibility:visible}.search-overlay__header{display:flex;align-items:center;gap:8px;padding:8px 12px;padding-top:calc(8px + env(safe-area-inset-top));border-bottom:1px solid var(--border)}.search-overlay__close{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:0;border-radius:10px;color:var(--text);font-size:24px;cursor:pointer;padding:0;line-height:1}.search-overlay__close:hover{background:var(--bg-list-hover)}.search-overlay__title{margin:0;font-size:16px;font-weight:500;color:var(--text)}.search-overlay__body{flex:1;min-height:0;display:flex;flex-direction:column;padding:12px 12px calc(12px + env(safe-area-inset-bottom))}.search-overlay .search-section{display:flex!important;flex-direction:column;flex:1;min-height:0}.search-overlay .search-input-container,.search-overlay .search-filters{flex:0 0 auto}.search-overlay .search-results{margin-top:12px;flex:1;min-height:0;display:flex;flex-direction:column}.search-overlay .search-results-list{flex:1;min-height:0;max-height:none;overflow-y:auto}.footer-pill{display:inline-flex;align-items:center;padding:8px 18px;border-radius:var(--radius-pill);font-size:13px;font-weight:500;color:var(--text);background:var(--bg-list-active);text-decoration:none;border:0;cursor:pointer;transition:background .12s ease,color .12s ease}.footer-pill:hover{background:var(--bg-list-hover)}.footer-pill--sm{padding:6px 12px;font-size:12px}.footer-pill--cta{border:1px solid rgba(205,0,37,.6);color:var(--text)}.footer-pill--cta:hover{background:#cd00252e;border-color:var(--red)}.site-footer-desktop{position:fixed;left:0;right:0;bottom:0;z-index:50;background:var(--bg-dark);border-top:1px solid var(--border);padding:14px 24px;transform:translateY(100%);transition:transform .28s cubic-bezier(.2,.7,.2,1);pointer-events:none}.site-footer-desktop.is-revealed{transform:translateY(0);pointer-events:auto}.site-footer-desktop__inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap}.site-footer-desktop__version{font-size:11px;letter-spacing:.02em;color:var(--text-muted);opacity:.6;pointer-events:none;user-select:none}html.is-standalone .site-footer-desktop{display:none}.theme-toggle__icon{width:18px;height:18px;flex-shrink:0;color:currentColor}.theme-toggle__icon--moon{display:block}.theme-toggle__icon--sun,[aria-pressed=true] .theme-toggle__icon--moon{display:none}[aria-pressed=true] .theme-toggle__icon--sun{display:block}.theme-toggle__label--light,[aria-pressed=true] .theme-toggle__label--dark{display:none}[aria-pressed=true] .theme-toggle__label--light{display:inline}.theme-toggle--row{display:flex;align-items:center;gap:10px;padding:14px;color:var(--text);background:none;border:0;border-radius:10px;font:inherit;font-size:15px;cursor:pointer;text-align:left;width:100%;-webkit-tap-highlight-color:transparent;transition:background .16s ease}.theme-toggle--row:hover{background:var(--bg-list-hover)}.theme-toggle--row__label{flex:1}.theme-toggle__switch{position:relative;width:40px;height:22px;flex-shrink:0;pointer-events:none}.theme-toggle__track{position:absolute;inset:0;background:var(--bg-light);border-radius:999px;transition:background .16s ease}.theme-toggle__track:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;background:var(--text);border-radius:50%;transition:transform .16s ease,background .16s ease}[aria-pressed=true] .theme-toggle__track{background:var(--accent)}[aria-pressed=true] .theme-toggle__track:after{transform:translate(18px);background:var(--bg)}.theme-toggle--pill{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:1px solid var(--overlay-hard);border-radius:999px;color:var(--text-muted);cursor:pointer;transition:color .16s ease,border-color .16s ease,background .16s ease}.theme-toggle--pill:hover{color:var(--text);border-color:var(--text-muted);background:var(--overlay-soft)}.theme-toggle--pill .theme-toggle__icon{width:16px;height:16px}.tool-btn{position:absolute;right:var(--space-3);width:28px;height:28px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-pill);display:inline-flex;align-items:center;justify-content:center;z-index:3;user-select:none;transition:background-color .12s ease,color .12s ease}.tool-btn:hover{color:var(--text);background:var(--overlay-med)}.tool-btn__icon,.tool-btn__icon svg,.tool-btn__icon svg *{pointer-events:none}.tool-btn__icon{display:inline-flex;align-items:center;justify-content:center}.tool-btn__icon svg{display:block;width:16px;height:16px}.tool-btn__pill{position:absolute;right:calc(100% + 6px);top:50%;transform:translateY(-50%) translate(8px);background:var(--text);color:var(--bg);font-size:11px;font-weight:600;letter-spacing:.02em;padding:4px 10px;border-radius:var(--radius-pill);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .14s ease,transform .18s cubic-bezier(.2,.7,.2,1)}.tool-btn:hover,.tool-btn:focus-visible{z-index:10}.tool-btn:hover .tool-btn__pill,.tool-btn:focus-visible .tool-btn__pill{opacity:1;transform:translateY(-50%) translate(0)}@media (pointer: coarse){.tool-btn{display:none}}.player-card-minimize-btn{top:var(--space-3);right:var(--space-3)}.player-card-drag-handle{top:var(--space-3);right:calc(var(--space-3) + 36px);cursor:grab}.container-solid-toggle{top:var(--space-3);right:calc(var(--space-3) + 72px)}.viz-trigger-btn{top:var(--space-3);right:calc(var(--space-3) + 108px)}.player-card-drag-handle.is-dragging{cursor:grabbing}.container-solid-toggle,.container-solid-toggle:hover,.container-solid-toggle.is-active{color:#ffffff73}:root.theme-light .container-solid-toggle,:root.theme-light .container-solid-toggle:hover,:root.theme-light .container-solid-toggle.is-active{color:#00000073}@media (min-width: 700px) and (display-mode: browser){.player-card-minimize-btn{top:18px;right:18px}.player-card-drag-handle{top:18px;right:54px}.container-solid-toggle{top:18px;right:90px}.viz-trigger-btn{top:18px;right:126px}}.container.has-tools{position:relative}.container.has-tools.is-dragged{position:fixed;left:var(--container-x, 0);top:var(--container-y, 0);margin:0;z-index:5}@media (min-width: 700px) and (display-mode: browser){.container{backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);isolation:isolate;will-change:backdrop-filter;transform:translateZ(0);transition:padding .26s cubic-bezier(.2,.7,.2,1),gap .26s ease,background-color .8s cubic-bezier(.4,0,.2,1),backdrop-filter .8s cubic-bezier(.4,0,.2,1),-webkit-backdrop-filter .8s cubic-bezier(.4,0,.2,1)}}.favorites-section,.search-section,.install-section{overflow:hidden;transition:max-height .28s cubic-bezier(.2,.7,.2,1),opacity .22s ease,margin .26s ease,padding .26s ease,transform .26s ease;max-height:2000px}.container.is-minimized .favorites-section,.container.is-minimized .search-section,.container.is-minimized .install-section{max-height:0;opacity:0;margin-top:0;margin-bottom:0;padding-top:0;padding-bottom:0;transform:translateY(-4px);pointer-events:none}@media (min-width: 700px) and (display-mode: browser){.container.is-minimized{padding:44px 16px 10px;gap:0}}.container.is-minimized{padding:44px 12px 10px;gap:0}.container.is-minimized .tool-btn{top:8px}@media (min-width: 700px) and (display-mode: browser){.container.is-minimized .player-card-minimize-btn{top:8px;right:16px}.container.is-minimized .player-card-drag-handle{top:8px;right:52px}.container.is-minimized .container-solid-toggle{top:8px;right:88px}.container.is-minimized .viz-trigger-btn{top:8px;right:124px}}.container.is-minimized .volume-controls{display:none}.container.is-minimized .player-card{padding:8px 12px}.container.is-minimized .station-logo,.container.is-minimized .station-initials{width:44px;height:44px;font-size:12px;border-width:1px}.container.is-minimized .station-name{font-size:14px}.container.is-minimized .now-playing.show{max-height:18px;margin-bottom:0}.container.is-minimized .play-pause-btn{width:40px;height:40px}.container.is-minimized .play-pause-btn .play-icon svg,.container.is-minimized .play-pause-btn .pause-icon svg{width:26px;height:26px}.viz-drawer{position:fixed;inset:0;z-index:1000;display:none;pointer-events:none}.viz-drawer.show{display:block;pointer-events:auto}.viz-drawer__backdrop{position:absolute;inset:0;background:#0006;opacity:0;transition:opacity .2s ease}.viz-drawer.show .viz-drawer__backdrop{opacity:1}.viz-drawer__panel{position:absolute;top:0;right:0;bottom:0;width:340px;max-width:92vw;background:var(--bg);border-left:1px solid var(--border);display:flex;flex-direction:column;transform:translate(100%);transition:transform .24s cubic-bezier(.2,.7,.2,1)}.viz-drawer.show .viz-drawer__panel{transform:translate(0)}.viz-drawer__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-4) var(--space-3);border-bottom:1px solid var(--border)}.viz-drawer__header h3{margin:0;font-size:14px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;color:var(--text)}.viz-drawer__close{background:transparent;border:none;color:var(--text-muted);font-size:22px;line-height:1;cursor:pointer;width:32px;height:32px;border-radius:var(--radius-pill);display:inline-flex;align-items:center;justify-content:center}.viz-drawer__close:hover{background:var(--overlay-med);color:var(--text)}.viz-drawer__body{flex:1 1 auto;overflow-y:auto;padding:var(--space-3) var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.viz-drawer__toggle-row{display:flex;align-items:center;justify-content:space-between}.viz-toggle{display:inline-flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--text);cursor:pointer;user-select:none}.viz-toggle input[type=checkbox]{width:18px;height:18px;accent-color:var(--text)}.viz-drawer__status{font-size:12px;color:var(--text-muted);display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--bg-list-active);border-radius:var(--radius-sm)}.viz-drawer__connect-btn{align-self:flex-start;padding:6px 12px;background:var(--text);color:var(--bg);border:none;border-radius:var(--radius-pill);font-size:12px;font-weight:600;cursor:pointer}.viz-drawer__connect-btn:disabled{opacity:.6;cursor:default}.viz-drawer__group{display:flex;flex-direction:column;gap:var(--space-1)}.viz-drawer__group-title{display:flex;justify-content:space-between;align-items:baseline;text-transform:uppercase;font-size:11px;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-1)}.viz-drawer__group-credit{font-size:10px;color:var(--text-muted);text-decoration:none}.viz-drawer__group-credit:hover{color:var(--text);text-decoration:underline}.viz-drawer__item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--bg-list-active);color:var(--text);border:1px solid transparent;border-radius:var(--radius-sm);font-size:13px;text-align:left;cursor:pointer;transition:background-color .12s ease,border-color .12s ease}.viz-drawer__item:hover{background:var(--bg-list-hover)}.viz-drawer__item.is-active{border-color:var(--overlay-hard);background:var(--bg-list-hover)}.viz-drawer__item-check{opacity:0;color:var(--text);font-size:13px}.viz-drawer__item.is-active .viz-drawer__item-check{opacity:1}.viz-drawer__controls-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:var(--space-1)}.viz-control{display:grid;grid-template-columns:100px 1fr 44px;align-items:center;gap:var(--space-2);font-size:12px;margin-bottom:var(--space-2)}.viz-control__label{color:var(--text-muted)}.viz-control input[type=range]{width:100%;accent-color:var(--text)}.viz-control__readout{color:var(--text);font-variant-numeric:tabular-nums;text-align:right}.viz-control select,.viz-control__button{grid-column:2 / 4;background:var(--bg-list-active);border:1px solid var(--border);color:var(--text);border-radius:var(--radius-sm);padding:6px 8px;font-size:12px}.viz-control__button{cursor:pointer}.viz-control__button:hover{background:var(--bg-list-hover)}.viz-control .viz-toggle{grid-column:2 / 4}.viz-drawer__empty{color:var(--text-muted);font-size:12px}.viz-drawer__footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--border);font-size:11px;color:var(--text-muted)}.viz-drawer__footer a{color:var(--text);text-decoration:underline}html{background:var(--bg)}body.viz-active{background:transparent}#vizCanvas2d,#vizCanvasGl,#vizCanvasMilkdrop{z-index:0}body.viz-active .page,body.viz-active .mobile-topbar,body.viz-active .off-canvas{position:relative;z-index:1}body.viz-active .search-overlay,body.viz-active .modal,body.viz-active .toast{z-index:1}.idb-banner{position:fixed;top:8px;left:50%;transform:translate(-50%,calc(-100% - 16px));z-index:1100;max-width:calc(100vw - 24px);width:480px;display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:var(--surface);border:1px solid rgba(205,0,37,.45);border-radius:var(--radius-md);color:var(--text);font-size:12px;line-height:1.45;transition:transform .24s cubic-bezier(.2,.7,.2,1);pointer-events:auto}.idb-banner.is-visible{transform:translate(-50%)}.idb-banner__icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:18px;height:18px;margin-top:1px;color:var(--red)}.idb-banner__icon svg{display:block;width:100%;height:100%}.idb-banner__text{flex:1;min-width:0;color:var(--text-muted)}.idb-banner__text strong{color:var(--text);font-weight:600}.idb-banner__link{color:var(--text);text-decoration:underline}.idb-banner__link:hover{color:var(--red)}.idb-banner__action{flex-shrink:0;padding:4px 10px;background:transparent;border:1px solid var(--border);border-radius:var(--radius-pill);color:var(--text-muted);font-size:11px;font-weight:500;cursor:pointer;transition:background-color .12s ease,border-color .12s ease,color .12s ease}.idb-banner__action:hover{background:var(--overlay-soft);color:var(--text);border-color:var(--text-muted)}.idb-banner__action--primary{background:var(--red);border-color:var(--red);color:#fff}.idb-banner__action--primary:hover{background:#b80021;border-color:#b80021;color:#fff}@media (max-width: 699px){.idb-banner{top:60px;width:auto;left:12px;right:12px;transform:translateY(calc(-100% - 80px));font-size:11px}.idb-banner.is-visible{transform:translate(0)}}@media (pointer: fine){body{background:transparent}}.app-background{position:fixed;inset:0;z-index:-1;background-color:transparent;background-size:cover;background-position:center;background-repeat:no-repeat;pointer-events:none;opacity:0;transition:opacity .52s cubic-bezier(.4,0,.2,1);transform:translateZ(0);will-change:opacity}.app-background.is-visible{opacity:1}.app-background[data-gradient],.bg-gallery__item[data-gradient],.bg-create__preset[data-gradient]{background:radial-gradient(ellipse var(--p0-r) var(--p0-r) at var(--p0-x) var(--p0-y),var(--p0-c) 0%,transparent 55%),radial-gradient(ellipse var(--p1-r) var(--p1-r) at var(--p1-x) var(--p1-y),var(--p1-c) 0%,transparent 55%),radial-gradient(ellipse var(--p2-r) var(--p2-r) at var(--p2-x) var(--p2-y),var(--p2-c) 0%,transparent 55%),radial-gradient(ellipse var(--p3-r) var(--p3-r) at var(--p3-x) var(--p3-y),var(--p3-c) 0%,transparent 55%),var(--base)}:root{--bg-btn-bg: rgba(13, 13, 13, .72);--bg-btn-bg-hover: rgba(28, 28, 28, .88);--bg-btn-border: rgba(255, 255, 255, .1);--bg-btn-border-hover: rgba(255, 255, 255, .2);--bg-surface: rgba(13, 13, 13, .78);--bg-surface-border: rgba(255, 255, 255, .1);--bg-menu-hover: rgba(255, 255, 255, .08)}:root.theme-light{--bg-btn-bg: rgba(255, 255, 255, .78);--bg-btn-bg-hover: rgba(255, 255, 255, .92);--bg-btn-border: rgba(0, 0, 0, .12);--bg-btn-border-hover: rgba(0, 0, 0, .22);--bg-surface: rgba(245, 245, 245, .85);--bg-surface-border: rgba(0, 0, 0, .1);--bg-menu-hover: rgba(0, 0, 0, .06)}.bg-controls{position:fixed;right:14px;bottom:17px;z-index:60;display:flex;align-items:center;gap:6px;pointer-events:auto;transition:opacity .2s ease}.bg-btn{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--bg-btn-border);background-color:var(--bg-btn-bg);color:var(--text);cursor:pointer;padding:0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background-color .12s ease,border-color .12s ease,transform .12s ease,opacity .2s ease}.bg-btn:hover{background-color:var(--bg-btn-bg-hover);border-color:var(--bg-btn-border-hover)}.bg-btn:active{transform:scale(.94)}.bg-btn svg{display:block;width:12px;height:12px}.bg-btn--menu svg{width:14px;height:14px}.bg-controls.is-blank .bg-btn--prev,.bg-controls.is-blank .bg-btn--next,.bg-controls.is-empty .bg-btn--prev,.bg-controls.is-empty .bg-btn--next{display:none}.bg-controls.is-blank .bg-btn--menu{opacity:0;pointer-events:none}body.footer-revealed .bg-controls.is-blank .bg-btn--menu{opacity:1;pointer-events:auto}.bg-menu{position:fixed;z-index:70;min-width:224px;padding:6px;background:var(--bg-surface);border:1px solid var(--bg-surface-border);border-radius:12px;backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);display:none;flex-direction:column;gap:2px}.bg-menu.is-open{display:flex}.bg-menu.is-measuring{visibility:hidden}.bg-menu__item{display:grid;grid-template-columns:18px 1fr 14px;align-items:center;gap:10px;padding:8px 10px;background:transparent;border:0;border-radius:8px;color:var(--text);font-size:13px;text-align:left;cursor:pointer;transition:background-color .12s ease}.bg-menu__item:hover:not(.is-disabled){background:var(--bg-menu-hover)}.bg-menu__item.is-disabled{opacity:.45;cursor:default;pointer-events:none}.bg-menu__icon{display:inline-flex;align-items:center;justify-content:center;color:var(--text-muted)}.bg-menu__icon svg{display:block;width:18px;height:18px}.bg-menu__label{white-space:nowrap}.bg-menu__check{display:inline-flex;align-items:center;justify-content:center;color:var(--text);opacity:0}.bg-menu__check svg{display:block;width:14px;height:14px}.bg-menu__item.is-active .bg-menu__check{opacity:1}.bg-gallery{position:fixed;right:14px;bottom:90px;z-index:65;width:280px;max-height:60vh;display:none;flex-direction:column;background:#141414;border:1px solid var(--bg-surface-border);border-radius:12px;overflow:hidden}.bg-gallery.is-open{display:flex}:root.theme-light .bg-gallery{background:#d5d5d5}.bg-gallery__header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--bg-surface-border)}.bg-gallery__title{margin:0;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.bg-gallery__close{width:22px;height:22px;border:0;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.bg-gallery__close:hover{background:var(--bg-menu-hover);color:var(--text)}.bg-gallery__close svg{display:block;width:14px;height:14px}.bg-gallery__list{padding:10px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px;overflow-y:auto}.bg-gallery__empty{grid-column:1 / -1;margin:8px 4px;font-size:12px;color:var(--text-muted)}.bg-gallery__item{position:relative;aspect-ratio:1 / 1;border-radius:8px;background-color:var(--bg-menu-hover);background-size:cover;background-position:center;cursor:grab;outline:1px solid var(--bg-surface-border);outline-offset:-1px;transition:transform .12s ease,outline-color .12s ease,box-shadow .12s ease}.bg-gallery__item:hover{outline-color:#ffffff4d}:root.theme-light .bg-gallery__item:hover{outline-color:#0000004d}.bg-gallery__item.is-current{outline-color:var(--red);outline-width:2px;outline-offset:-2px}.bg-gallery__item.is-dragging{opacity:.4;cursor:grabbing}.bg-gallery__item.is-drop-before{box-shadow:-2px 0 0 0 var(--red)}.bg-gallery__item.is-drop-after{box-shadow:2px 0 0 0 var(--red)}.bg-gallery__item-delete{position:absolute;top:4px;right:4px;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:50%;background:#000000a6;color:#fff;cursor:pointer;opacity:0;transition:opacity .12s ease,background-color .12s ease;padding:0}.bg-gallery__item:hover .bg-gallery__item-delete{opacity:1}.bg-gallery__item-delete:hover{background:var(--red)}.bg-gallery__item-delete svg{display:block;width:11px;height:11px}.bg-create{position:fixed;right:14px;bottom:90px;z-index:66;width:280px;max-height:78vh;display:none;flex-direction:column;background:#141414;border:1px solid var(--bg-surface-border);border-radius:12px;overflow:hidden;color:var(--text)}.bg-create.is-open{display:flex}:root.theme-light .bg-create{background:#d5d5d5}.bg-create__header{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-bottom:1px solid var(--bg-surface-border)}.bg-create__title{margin:0;font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}.bg-create__close{width:22px;height:22px;border:0;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.bg-create__close:hover{background:var(--bg-menu-hover);color:var(--text)}.bg-create__close svg{display:block;width:14px;height:14px}.bg-create__body{padding:10px 12px 4px;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.bg-create__group{display:flex;flex-direction:column;gap:6px}.bg-create__group-title{margin:0;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.bg-create__presets{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.bg-create__preset{aspect-ratio:1 / 1;border-radius:6px;border:0;padding:0;cursor:pointer;background-size:cover;outline:1px solid var(--bg-surface-border);outline-offset:-1px;transition:transform .1s ease,outline-color .1s ease}.bg-create__preset:hover{transform:scale(1.06);outline-color:#ffffff59}:root.theme-light .bg-create__preset:hover{outline-color:#00000059}.bg-create__points{display:flex;gap:6px}.bg-create__point{flex:1;height:28px;border:1px solid var(--bg-surface-border);border-radius:6px;background:var(--text-muted);color:#fff;font-size:11px;font-weight:600;cursor:pointer;padding:0;display:inline-flex;align-items:center;justify-content:center;text-shadow:0 1px 2px rgba(0,0,0,.5);transition:outline-color .1s ease,transform .1s ease}.bg-create__point.is-selected{outline:2px solid var(--text);outline-offset:1px;transform:scale(1.04)}.bg-create__swatches{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.bg-create__swatch{aspect-ratio:1 / 1;border:1px solid var(--bg-surface-border);border-radius:50%;padding:0;cursor:pointer;transition:transform .1s ease}.bg-create__swatch:hover{transform:scale(1.12)}.bg-create__custom-label{display:inline-flex;align-items:center;gap:8px;font-size:11px;color:var(--text-muted);cursor:pointer}.bg-create__custom-input{width:32px;height:22px;padding:0;border:1px solid var(--bg-surface-border);border-radius:4px;background:transparent;cursor:pointer}.bg-create__size{width:100%;accent-color:var(--text)}.bg-create__drift{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--text);cursor:pointer;padding:6px 0}.bg-create__drift-input{width:16px;height:16px;accent-color:var(--text)}.bg-create__footer{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--bg-surface-border)}.bg-create__btn{flex:1;height:32px;border-radius:8px;border:1px solid var(--bg-surface-border);background:transparent;color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:background-color .1s ease,border-color .1s ease}.bg-create__btn:hover{background:var(--bg-menu-hover)}.bg-create__btn--primary{background:var(--text);color:var(--bg);border-color:var(--text)}.bg-create__btn--primary:hover{background:var(--text);opacity:.9}.bg-mesh-handles{position:fixed;inset:0;z-index:64;pointer-events:none;display:none}.bg-mesh-handles.is-open{display:block}.bg-mesh-handle{position:absolute;width:28px;height:28px;margin:0;padding:0;border:2px solid #fff;border-radius:50%;cursor:grab;pointer-events:auto;transform:translate(-50%,-50%);box-shadow:0 0 0 1px #0006;transition:transform .1s ease}.bg-mesh-handle:hover{transform:translate(-50%,-50%) scale(1.12)}.bg-mesh-handle.is-selected{border-width:3px;box-shadow:0 0 0 2px #0009,0 0 0 4px #ffffffd9}.bg-mesh-handle.is-dragging{cursor:grabbing;transform:translate(-50%,-50%) scale(1.2)}@media (max-width: 699px){.bg-controls,.bg-menu,.bg-gallery,.bg-create,.bg-mesh-handles{display:none!important}}.notes-flag{position:fixed;top:50%;right:0;transform:translateY(-50%);z-index:80;display:flex;align-items:center;justify-content:center;padding:0;margin:0;width:26px;height:96px;border:1px solid var(--border);border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);background:var(--bg-dark);color:var(--text-muted);cursor:pointer;transition:background-color .18s ease,color .18s ease,transform .2s ease,opacity .2s ease}.notes-flag:hover{background:var(--bg-list-hover);color:var(--text);transform:translateY(-50%) translate(-3px)}.notes-flag.is-tucked{opacity:0;pointer-events:none;transform:translateY(-50%) translate(8px)}.notes-flag__inner{display:flex;flex-direction:column;align-items:center;gap:6px}.notes-flag__inner svg{width:14px;height:14px}.notes-flag__label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;writing-mode:vertical-rl;transform:rotate(180deg);font-weight:600}@media (pointer: coarse){.notes-flag{display:none}}.notes-panel{position:fixed;display:flex;flex-direction:column;background:#4141415c;backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-lg);z-index:90;overflow:hidden;opacity:0;pointer-events:none;transition:opacity .18s ease,transform .2s ease}:root.theme-light .notes-panel{background:#9393935c}body.container-solid .notes-panel{background:#141414;backdrop-filter:none;-webkit-backdrop-filter:none}:root.theme-light body.container-solid .notes-panel{background:#d5d5d5}.notes-panel.is-open{opacity:1;pointer-events:auto}.notes-panel--desktop{top:50%;right:24px;transform:translate(40px,-50%);width:360px;height:min(560px,calc(100vh - 80px))}.notes-panel--desktop.is-open{transform:translateY(-50%)}.notes-panel--desktop.is-positioned{top:var(--notes-y, 80px);left:var(--notes-x, auto);right:auto;transform:none!important}.notes-panel--desktop.is-dragging{transition:none;user-select:none}.notes-panel--mobile{inset:0;width:100%;height:100dvh;border-radius:0;border:none;transform:translate(100%)}.notes-panel--mobile.is-open{transform:translate(0)}.notes-panel__header{display:flex;align-items:center;gap:4px;padding:8px 8px 8px 4px;border-bottom:1px solid var(--overlay-soft);background:transparent;flex-shrink:0}.notes-panel__drag{display:inline-flex;align-items:center;padding:4px 2px;margin-right:2px;cursor:grab;color:var(--text-muted);touch-action:none;flex-shrink:0}.notes-panel__drag svg{width:16px;height:16px}.notes-panel.is-dragging .notes-panel__drag{cursor:grabbing}.notes-panel__page-picker{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-list-hover);border:0;border-radius:var(--radius-pill);color:var(--text);font:inherit;font-size:12.5px;font-weight:600;cursor:pointer;white-space:nowrap;max-width:180px;-webkit-tap-highlight-color:transparent;transition:background-color .16s ease,transform .1s ease}.notes-panel__page-picker:hover{background:var(--overlay-med)}.notes-panel__page-picker:active{transform:scale(.97)}.notes-panel__page-picker-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notes-panel__page-picker-chev{font-size:9px;color:var(--text-muted)}.notes-panel__spacer{flex:1 1 auto}.notes-panel__icon-btn{flex-shrink:0;width:30px;height:30px;display:inline-flex;align-items:center;justify-content:center;padding:0;background:transparent;border:0;border-radius:50%;color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:color .16s ease,background-color .16s ease,transform .1s ease}.notes-panel__icon-btn:hover{background:var(--overlay-soft);color:var(--text)}.notes-panel__icon-btn:active{transform:scale(.9)}.notes-panel__icon-btn svg{width:16px;height:16px}.notes-panel__search{padding:8px 10px;border-bottom:1px solid var(--overlay-soft);background:transparent;flex-shrink:0}.notes-panel__search-input{width:100%;padding:7px 10px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font:inherit;font-size:13px;outline:none;transition:border-color .16s ease}.notes-panel__search-input::placeholder{color:var(--text-muted)}.notes-panel__search-input:focus{border-color:var(--overlay-hard)}.notes-panel__capture-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin:10px;padding:9px 14px;border:1px solid var(--border);border-radius:var(--radius-pill);background-color:var(--bg-list-active);color:var(--text);font:inherit;font-size:12.5px;font-weight:600;letter-spacing:.02em;cursor:pointer;transition:background-color .16s ease,border-color .16s ease,transform .1s ease;-webkit-tap-highlight-color:transparent}.notes-panel__capture-btn:hover{background-color:var(--bg-list-hover);border-color:var(--overlay-hard)}.notes-panel__capture-btn:active{transform:scale(.98)}.notes-panel__capture-btn.is-disabled,.notes-panel__capture-btn:disabled{background-color:transparent;color:var(--text-muted);cursor:not-allowed}.notes-panel__capture-btn.is-disabled svg,.notes-panel__capture-btn:disabled svg{color:var(--text-muted)}.notes-panel__capture-btn svg{width:15px;height:15px;color:var(--red)}.notes-panel__list{flex:1 1 auto;overflow-y:auto;padding:0 10px 10px;scroll-behavior:smooth}.notes-panel__list::-webkit-scrollbar{width:8px}.notes-panel__list::-webkit-scrollbar-thumb{background:var(--overlay-med);border-radius:4px}.notes-panel__day{position:sticky;top:0;z-index:1;padding:8px 4px 4px;margin-top:4px;font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);background:linear-gradient(180deg,var(--bg) 70%,transparent)}.notes-panel__empty{padding:32px 16px;text-align:center;color:var(--text-muted);font-size:13px}.notes-card{position:relative;background:var(--bg-list-active);border:1px solid var(--border);border-radius:var(--radius-md);padding:10px 12px;margin-bottom:8px;transition:background-color .16s ease}.notes-card:hover{background:var(--bg-list-hover)}.notes-card__head{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:4px}.notes-card__meta{display:flex;align-items:center;gap:6px;min-width:0;font-size:11.5px;color:var(--text-muted)}.notes-card__time{font-variant-numeric:tabular-nums;font-weight:600;color:var(--text)}.notes-card__sep{color:var(--text-muted);opacity:.6}.notes-card__station{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.notes-card__menu-btn{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:0;background:transparent;border-radius:50%;color:var(--text-muted);cursor:pointer;transition:background-color .16s ease,color .16s ease}.notes-card__menu-btn:hover{background:var(--overlay-med);color:var(--text)}.notes-card__menu-btn svg{width:14px;height:14px}.notes-card__track{margin:2px 0 6px;font-size:12.5px;color:var(--text);font-style:italic;white-space:normal;overflow-wrap:anywhere;line-height:1.35}.notes-card__body{font-size:13px;line-height:1.45;color:var(--text);white-space:pre-wrap;cursor:text;word-wrap:break-word}.notes-card__body--empty{color:var(--text-muted);font-style:italic}.notes-card__body a{color:var(--red);text-decoration:underline}.notes-card__edit{display:block;width:100%;min-height:60px;max-height:220px;resize:none;padding:6px 8px;font:inherit;font-size:13px;line-height:1.45;color:var(--text);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);outline:none;transition:border-color .16s ease}.notes-card__edit:focus{border-color:var(--overlay-hard)}.notes-panel__footer{display:flex;align-items:center;padding:8px 10px;border-top:1px solid var(--overlay-soft);background:transparent;flex-shrink:0}.notes-panel__new-note{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:transparent;border:1px dashed var(--border);color:var(--text-muted);border-radius:var(--radius-pill);font:inherit;font-size:12.5px;cursor:pointer;transition:background-color .16s ease,color .16s ease,border-color .16s ease}.notes-panel__new-note:hover{background:var(--overlay-soft);color:var(--text);border-color:var(--overlay-hard)}.notes-panel__new-note svg{width:13px;height:13px}.notes-popup-menu{position:fixed;z-index:95;min-width:180px;padding:4px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:1px}.notes-popup-menu__item{display:flex;align-items:center;padding:8px 12px;border:0;background:transparent;color:var(--text);font:inherit;font-size:12.5px;text-align:left;border-radius:4px;cursor:pointer;transition:background-color .16s ease}.notes-popup-menu__item:hover{background:var(--bg-list-hover)}.notes-popup-menu__item.is-danger{color:var(--red)}.notes-popup-menu__item.is-danger:hover{background:var(--overlay-med)}.notes-popup-menu__item.is-active{background:var(--bg-list-hover);color:var(--text);font-weight:600}.notes-popup-menu__separator{height:1px;margin:4px 6px;background:var(--overlay-soft)}.notes-popup-menu--picker{max-height:320px;overflow-y:auto}.btn-capture-note{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;margin-left:4px;padding:0;border:0;background:transparent;color:var(--text-muted);border-radius:50%;cursor:pointer;transition:color .16s ease,background-color .16s ease,transform .12s ease}.btn-capture-note:hover{color:var(--red);background:var(--overlay-soft)}.btn-capture-note svg{width:16px;height:16px}.btn-capture-note.is-pulsing{animation:notes-capture-pulse .48s ease;color:var(--red)}@keyframes notes-capture-pulse{0%{transform:scale(1)}35%{transform:scale(1.22)}to{transform:scale(1)}}.toast__action{margin-left:12px;padding:4px 10px;background:transparent;border:1px solid var(--overlay-hard);color:var(--text);border-radius:var(--radius-pill);font:inherit;font-size:12px;cursor:pointer;transition:background-color .16s ease}.toast__action:hover{background:var(--overlay-med)}body.notes-overlay-open{overflow:hidden}@media (max-width: 699px),not (display-mode: browser){.app-background,#appBackgroundA,#appBackgroundB,.bg-controls,.bg-menu,.bg-gallery,.bg-create,.bg-mesh-handles,.notes-flag,.container-solid-toggle{display:none!important}}@media (max-width: 699px),not (display-mode: browser){.desktop-only{display:none!important}html,body{height:100dvh;overflow:hidden}body{display:flex;flex-direction:column}.mobile-topbar{flex:0 0 auto}.page{justify-content:flex-start;flex:1;min-height:0;height:auto;overflow:hidden}.container{flex:1;min-height:0;padding:12px 0 0;gap:12px}.favorites-section{padding:0 16px}.favorites-list{max-height:none}.search-section{display:none}.player-section{position:fixed;bottom:0;left:0;right:0;z-index:50;flex-direction:column-reverse;align-items:stretch;gap:0;background:var(--bg);border-top:1px solid var(--border);padding:8px 12px calc(12px + env(safe-area-inset-bottom))}.player-section .player-card{border-radius:100px;margin:0;width:100%}.volume-controls{display:none!important}.favorites-section{visibility:hidden;pointer-events:none;height:0;overflow:visible;margin:0;padding:0}.favorites-section .list-dropdown-menu{visibility:visible;pointer-events:auto}.list-dropdown-menu{position:fixed!important;inset:auto 0 0!important;margin:0!important;min-width:0!important;width:100%;max-width:none;border-radius:18px 18px 0 0;background:var(--bg-dark);z-index:2100;padding-bottom:max(8px,env(safe-area-inset-bottom))}.list-dropdown-menu:before{content:"";display:block;width:36px;height:4px;margin:8px auto 4px;border-radius:999px;background:var(--overlay-hard)}body.list-menu-open:before{content:"";position:fixed;inset:0;background:#00000073;-webkit-backdrop-filter:blur(14px) saturate(120%);backdrop-filter:blur(14px) saturate(120%);z-index:2099}.list-edit-btn,.list-share-btn,.list-export-btn,.list-remove-btn{display:none!important}.list-more-btn{display:flex}.list-item{padding:14px 16px;gap:10px}.list-name{font-size:15px}.install-section{display:none!important}#infoModal.modal{align-items:stretch;justify-content:stretch;background:var(--bg);-webkit-backdrop-filter:none;backdrop-filter:none;transition:opacity .2s ease}#infoModal .modal-content{width:100%;max-width:none;height:100%;border-radius:0;box-shadow:none;background:var(--bg);display:flex;flex-direction:column;transform:translate(100%);transition:transform .26s cubic-bezier(.22,1,.36,1);animation:none}#infoModal.show .modal-content{transform:translate(0)}#infoModal .modal-header{padding:max(16px,env(safe-area-inset-top)) 20px 12px;border-bottom:1px solid var(--overlay-soft);flex-shrink:0}#infoModal .modal-body{padding:20px 20px max(20px,env(safe-area-inset-bottom));overflow-y:auto;flex:1}}@media (min-width: 700px) and (display-mode: browser){.mobile-only{display:none!important}.container{padding:59px 34px;background:#4141415c;border-radius:25px}:root.theme-light .container{background:#9393935c}.container.is-solid{background:#141414;backdrop-filter:blur(0px) saturate(100%);-webkit-backdrop-filter:blur(0px) saturate(100%)}:root.theme-light .container.is-solid{background:#d5d5d5}.page{min-height:100dvh}}html.is-standalone .desktop-only{display:none!important}html.is-standalone,html.is-standalone body{height:100dvh;overflow:hidden}html.is-standalone body{display:flex;flex-direction:column}html.is-standalone .mobile-topbar{flex:0 0 auto}html.is-standalone .page{justify-content:flex-start;flex:1;min-height:0;height:auto;overflow:hidden}html.is-standalone .container{flex:1;min-height:0;padding:12px 0 0;gap:12px;max-width:none;background:transparent;border-radius:0}html.is-standalone .favorites-section{padding:0;visibility:hidden;pointer-events:none;height:0;overflow:visible;margin:0}html.is-standalone .favorites-section .list-dropdown-menu{visibility:visible;pointer-events:auto}html.is-standalone .search-section{display:none}html.is-standalone .player-section{position:fixed;bottom:0;left:0;right:0;z-index:50;flex-direction:column-reverse;align-items:stretch;gap:0;background:var(--bg);border-top:1px solid var(--border);padding:8px 12px calc(12px + env(safe-area-inset-bottom))}html.is-standalone .player-section .player-card{border-radius:100px;margin:0;width:100%}html.is-standalone .volume-controls{display:none!important}html.is-standalone .list-dropdown-menu{position:fixed!important;inset:auto 0 0!important;margin:0!important;min-width:0!important;width:100%;max-width:none;border-radius:18px 18px 0 0;background:var(--bg-dark);z-index:2100;padding-bottom:max(8px,env(safe-area-inset-bottom))}html.is-standalone .list-edit-btn,html.is-standalone .list-share-btn,html.is-standalone .list-export-btn,html.is-standalone .list-remove-btn{display:none!important}html.is-standalone .list-more-btn{display:flex}html.is-standalone .install-section,html.is-standalone .app-background,html.is-standalone #appBackgroundA,html.is-standalone #appBackgroundB,html.is-standalone .bg-controls,html.is-standalone .bg-menu,html.is-standalone .bg-gallery,html.is-standalone .bg-create,html.is-standalone .bg-mesh-handles,html.is-standalone .notes-flag,html.is-standalone .container-solid-toggle{display:none!important}html.is-standalone body{background:var(--bg)}
