:root{--bg-base: #121212;--bg-elevated: #181818;--bg-highlight: #282828;--bg-press: #3e3e3e;--text-base: #ffffff;--text-subdued: #c7c7c7;--text-muted: #8a8a8a;--accent-primary: #fa2d48;--accent-hover: #ff4d63;--accent-active: #e01b35;--success: #1ed760;--warning: #ffa500;--error: #e22134;--shadow-base: 0 8px 24px rgba(0, 0, 0, .5);--shadow-elevated: 0 16px 40px rgba(0, 0, 0, .6);--blur-amount: 10px;--sidebar-width: 240px;--topbar-height: 64px;--player-height: 90px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--safe-area-top: env(safe-area-inset-top);--safe-area-bottom: env(safe-area-inset-bottom);--safe-area-left: env(safe-area-inset-left);--safe-area-right: env(safe-area-inset-right)}[data-theme=light]{--bg-base: #ffffff;--bg-elevated: #f6f6f6;--bg-highlight: #ebebeb;--bg-press: #d4d4d4;--text-base: #000000;--text-subdued: #6a6a6a;--text-muted: #b3b3b3;--shadow-base: 0 8px 24px rgba(0, 0, 0, .1);--shadow-elevated: 0 16px 40px rgba(0, 0, 0, .15)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,Arial,sans-serif;background:var(--bg-base);color:var(--text-base);line-height:1.6;overflow:hidden;padding-top:env(safe-area-inset-top)}#root{height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:12px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-press);border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#4a4a4a}.header{height:var(--topbar-height);background:var(--bg-base);border-bottom:1px solid rgba(255,255,255,.1);padding:0 var(--spacing-lg);padding-top:var(--safe-area-top);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(var(--blur-amount));backdrop-filter:blur(var(--blur-amount))}.header-content{width:100%;height:100%;display:flex;align-items:center;justify-content:space-between;position:relative}.menu-toggle{display:none}.logo-section{display:flex;align-items:center;gap:var(--spacing-md)}.logo-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center}.logo-icon img{width:100%;height:100%;object-fit:contain}.logo-text{display:flex;flex-direction:column}.logo{font-size:1.5rem;font-weight:700;color:var(--text-base);letter-spacing:-.5px}.tagline{font-size:.75rem;color:var(--text-subdued);font-weight:400}.header-nav{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:4px;background:#ffffff0d;padding:4px;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.nav-tab{display:flex;align-items:center;gap:8px;padding:8px 16px;color:var(--text-subdued);text-decoration:none;font-size:.875rem;font-weight:600;border-radius:8px;transition:all .2s ease}.nav-tab:hover{color:var(--text-base);background:#ffffff0d}.nav-tab.active{color:#fff;background:var(--accent-primary);box-shadow:0 2px 8px #fa2d484d}.header-actions{display:flex;align-items:center;gap:var(--spacing-sm)}.theme-toggle{width:40px;height:40px;border-radius:50%;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-base);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.theme-toggle:hover{background:#ffffff1a;transform:scale(1.05);border-color:var(--text-base)}.app-container{display:flex;flex:1;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-base);padding:var(--spacing-lg);overflow-y:auto;border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;transition:padding-bottom .3s ease}.sidebar.has-player{padding-bottom:calc(var(--player-height) + var(--spacing-lg))}.sidebar-section,.filters-container{flex:1;display:flex;flex-direction:column}.sidebar-title{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-subdued);margin-bottom:var(--spacing-md)}.filter-group{margin-bottom:var(--spacing-md)}.filter-label{font-size:.75rem;font-weight:700;color:var(--text-subdued);margin-bottom:var(--spacing-sm);display:flex;align-items:center;gap:var(--spacing-sm);text-transform:uppercase;letter-spacing:1px}.filter-icon{font-size:.875rem;color:var(--accent-primary)}.filter-input,.filter-select{width:100%;padding:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--text-base);font-size:.875rem;font-family:inherit;transition:all .2s}.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--accent-primary);background:#ffffff1a}.filter-input::placeholder{color:var(--text-muted)}.clear-filters-btn{width:100%;padding:12px;background:transparent;border:1px dashed var(--text-subdued);border-radius:8px;color:var(--text-subdued);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .2s;margin-top:var(--spacing-xl);display:flex;align-items:center;justify-content:center;gap:8px}.clear-filters-btn:hover{border-color:var(--error);color:var(--error);background:#e221340d;transform:none}.favorites-toggle{display:flex;gap:4px;background:#ffffff0d;padding:4px;border-radius:12px;border:1px solid rgba(255,255,255,.1);margin-bottom:var(--spacing-lg)}.toggle-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;background:transparent;border:none;border-radius:8px;color:var(--text-subdued);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.toggle-btn:hover{color:var(--text-base);background:#ffffff0d}.toggle-btn.active{background:var(--accent-primary);color:#fff;box-shadow:0 2px 8px #fa2d484d}.main-content{flex:1;background:var(--bg-base);overflow-y:auto;padding:var(--spacing-lg) var(--spacing-xl);padding-bottom:calc(var(--player-height) + var(--spacing-xl))}.content-header{margin-bottom:var(--spacing-xl)}.content-title{font-size:2rem;font-weight:900;color:var(--text-base);margin-bottom:var(--spacing-xs);letter-spacing:-1px}.content-subtitle{font-size:.875rem;color:var(--text-subdued)}.stations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-lg)}.station-card{background:var(--bg-elevated);border-radius:8px;padding:var(--spacing-md);transition:all .3s cubic-bezier(.4,0,.2,1);cursor:pointer;position:relative}.station-card:hover{background:var(--bg-highlight);transform:translateY(-4px)}.station-card-header{position:relative;margin-bottom:var(--spacing-md)}.station-artwork{width:100%;aspect-ratio:1;background:linear-gradient(135deg,var(--accent-primary) 0%,#9b1d3a 100%);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:3rem;margin-bottom:var(--spacing-md);box-shadow:var(--shadow-base);position:relative;overflow:hidden}.station-artwork:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(0,0,0,.3) 100%)}.favorite-btn{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:32px;height:32px;border-radius:50%;background:#0009;-webkit-backdrop-filter:blur(var(--blur-amount));backdrop-filter:blur(var(--blur-amount));border:none;color:#fff;font-size:1rem;cursor:pointer;opacity:0;transition:all .2s;display:flex;align-items:center;justify-content:center;z-index:2}.station-card:hover .favorite-btn{opacity:1}.favorite-btn.active{opacity:1;color:var(--accent-primary)}.favorite-btn:hover{transform:scale(1.1)}.play-overlay{position:absolute;bottom:var(--spacing-sm);right:var(--spacing-sm);width:48px;height:48px;border-radius:50%;background:var(--success);border:none;color:#000;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(8px);transition:all .3s;box-shadow:0 8px 16px #0006;z-index:2}.station-card:hover .play-overlay,.play-overlay.playing{opacity:1;transform:translateY(0)}.play-overlay:hover{transform:scale(1.05);background:#1fdf64}.station-card-body{padding:0}.station-name{font-size:1rem;font-weight:700;color:var(--text-base);margin-bottom:var(--spacing-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.station-info{display:flex;flex-direction:column;gap:var(--spacing-xs)}.station-meta{font-size:.875rem;color:var(--text-subdued);display:flex;align-items:center;gap:var(--spacing-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.station-tags{display:flex;gap:var(--spacing-xs);flex-wrap:wrap;margin-top:var(--spacing-xs)}.tag{font-size:.75rem;color:var(--text-subdued);background:var(--bg-highlight);padding:2px 8px;border-radius:4px}.sticky-player{position:fixed;bottom:0;left:0;right:0;height:var(--player-height);background:var(--bg-elevated);border-top:1px solid rgba(255,255,255,.1);padding:0 var(--spacing-md);display:flex;align-items:center;z-index:200}.player-content{width:100%;display:grid;grid-template-columns:30% 40% 30%;align-items:center;gap:var(--spacing-md)}.player-info{display:flex;align-items:center;gap:var(--spacing-md);min-width:0}.player-artwork{width:56px;height:56px;background:linear-gradient(135deg,var(--accent-primary) 0%,#9b1d3a 100%);border-radius:4px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;flex-shrink:0}.player-details{min-width:0;flex:1}.player-station-name{font-size:.875rem;font-weight:600;color:var(--text-base);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}.player-station-details{font-size:.75rem;color:var(--text-subdued);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-controls-center{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg)}.player-controls-right{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm)}.player-btn{width:32px;height:32px;border-radius:50%;background:transparent;border:none;color:var(--text-subdued);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.player-btn:hover{color:var(--text-base);transform:scale(1.1);background:#ffffff1a}.player-btn.play-pause{width:48px;height:48px;background:var(--text-base);color:var(--bg-base);font-size:1.25rem;box-shadow:0 4px 12px #0000004d}.player-btn.play-pause:hover{transform:scale(1.05);background:var(--text-base);color:var(--bg-base)}.player-btn.stop{color:var(--text-subdued)}.player-btn.stop:hover{color:var(--error)}.visualizer-container{margin-left:var(--spacing-md);height:24px;display:flex;align-items:center}.wave-animation{display:flex;gap:2px;align-items:center;height:16px}.wave-bar{width:2px;background:var(--success);border-radius:2px;animation:wave 1s ease-in-out infinite}.wave-bar:nth-child(1){animation-delay:0s;height:6px}.wave-bar:nth-child(2){animation-delay:.1s;height:10px}.wave-bar:nth-child(3){animation-delay:.2s;height:14px}.wave-bar:nth-child(4){animation-delay:.3s;height:10px}@keyframes wave{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) 0;gap:var(--spacing-md)}.spinner{width:40px;height:40px;border:3px solid var(--bg-highlight);border-top-color:var(--text-base);border-radius:50%;animation:spin .8s linear infinite}.loading-text{color:var(--text-subdued);font-size:.875rem}.error-container{background:#e221341a;border:1px solid var(--error);border-radius:8px;padding:var(--spacing-lg);margin:var(--spacing-lg) 0;text-align:center}.error-title{color:var(--error);font-size:1.125rem;font-weight:700;margin-bottom:var(--spacing-xs)}.error-message{color:var(--text-subdued);font-size:.875rem}.no-results{text-align:center;padding:var(--spacing-xl) 0}.no-results-icon{font-size:4rem;color:var(--text-muted);margin-bottom:var(--spacing-md);opacity:.3}.no-results-text{color:var(--text-subdued);font-size:1rem}.load-more-container{display:flex;justify-content:center;margin:var(--spacing-xl) 0}.load-more-btn{padding:var(--spacing-md) var(--spacing-xl);background:transparent;border:1px solid var(--text-subdued);border-radius:500px;color:var(--text-base);font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s}.load-more-btn:hover{border-color:var(--text-base);transform:scale(1.02)}.equalizer-control{position:relative}.equalizer-popup{position:absolute;bottom:140%;left:50%;transform:translate(-50%);background:var(--bg-elevated);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:var(--spacing-md);box-shadow:var(--shadow-elevated);z-index:300;width:300px;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%)}}.equalizer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:var(--spacing-xs)}.equalizer-header h3{font-size:.875rem;font-weight:700;display:flex;align-items:center;gap:var(--spacing-sm);color:var(--text-base)}.close-btn{background:transparent;border:none;color:var(--text-subdued);font-size:1.25rem;cursor:pointer;padding:0;line-height:1}.close-btn:hover{color:var(--text-base)}.equalizer-bands{display:flex;justify-content:space-between;height:150px}.eq-band{display:flex;flex-direction:column;align-items:center;height:100%}.eq-slider{writing-mode:vertical-lr;direction:rtl;appearance:auto;width:8px;height:100%;background:var(--bg-highlight);border-radius:4px;outline:none;cursor:pointer}.eq-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--accent-primary);border-radius:50%;cursor:pointer;box-shadow:0 2px 4px #0000004d}.eq-label{font-size:.625rem;color:var(--text-subdued);margin-top:var(--spacing-sm);text-align:center}.player-btn.eq-btn.active{color:var(--accent-primary)}@media(max-width:1200px){.stations-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}@media(max-width:1024px){:root{--sidebar-width: 260px}.sidebar{position:fixed;left:-100%;top:calc(var(--topbar-height) + var(--safe-area-top));height:calc(100vh - var(--topbar-height) - var(--safe-area-top));z-index:150;transition:left .3s ease;box-shadow:var(--shadow-elevated);background:var(--bg-base)}.sidebar.open{left:0}.menu-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-highlight);border:none;border-radius:8px;color:var(--text-base);cursor:pointer;font-size:1.25rem;transition:all .2s}.menu-toggle:hover{background:var(--bg-press)}.sidebar-overlay{position:fixed;inset:0;background:#000000b3;z-index:149;opacity:0;pointer-events:none;transition:opacity .3s;top:var(--topbar-height)}.sidebar-overlay.active{opacity:1;pointer-events:all}.stations-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.player-content{grid-template-columns:30% 40% 30%}.playback-indicator{display:none}}@media(max-width:768px){:root{--topbar-height: 56px;--player-height: 80px;--spacing-lg: 16px;--spacing-xl: 24px}.header{padding:0 var(--spacing-md)}.nav-tab span{display:none}.nav-tab{padding:8px}.logo{font-size:1.25rem}.tagline{display:none}.logo-icon{width:36px;height:36px;font-size:1.125rem}.theme-toggle{width:36px;height:36px}.main-content{padding:var(--spacing-md);padding-bottom:calc(var(--player-height) + var(--spacing-md))}.content-title{font-size:1.5rem}.content-subtitle{font-size:.8125rem}.stations-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.station-card{padding:var(--spacing-sm)}.station-name{font-size:.9375rem}.station-meta{font-size:.8125rem}.tag{font-size:.6875rem}.play-overlay{opacity:1;transform:translateY(0)}.sticky-player{padding:0 var(--spacing-sm);height:var(--player-height)}.player-content{display:flex;justify-content:space-between;gap:var(--spacing-sm)}.player-controls-center{gap:var(--spacing-md)}.player-controls-center .stop{display:none}.player-controls-right{display:flex;gap:var(--spacing-xs)}.player-controls-right .identify-btn,.player-controls-right .volume-control,.player-controls-right .equalizer-control,.player-controls-right .visualizer-container{display:none}.player-controls-right .share-btn,.player-controls-right .sleep-timer{display:flex}.player-info{gap:var(--spacing-sm)}.player-artwork{width:48px;height:48px}.player-station-name{font-size:.8125rem}.player-station-details{font-size:.6875rem}.player-controls{gap:var(--spacing-sm);position:absolute;right:var(--spacing-sm);top:50%;transform:translateY(-50%)}.player-btn{width:28px;height:28px;font-size:.875rem}.player-btn:nth-child(2){width:36px;height:36px;font-size:1rem}.sidebar{width:80%;max-width:300px}.filter-label{font-size:.8125rem}.filter-input,.filter-select{font-size:.8125rem;padding:var(--spacing-sm)}.favorites-toggle{margin-bottom:var(--spacing-md)}.toggle-btn{font-size:.8125rem;padding:var(--spacing-xs) var(--spacing-sm)}.load-more-btn{padding:var(--spacing-sm) var(--spacing-lg);font-size:.8125rem}}@media(max-width:480px){.stations-grid{grid-template-columns:1fr;gap:var(--spacing-sm)}.main-content{padding:var(--spacing-sm)}.content-title{font-size:1.25rem}.sidebar{width:85%}.player-btn:first-child{display:none}}@media(hover:none)and (pointer:coarse){.filter-input,.filter-select,.clear-filters-btn,.toggle-btn,.play-overlay,.favorite-btn{min-height:44px}.play-overlay{opacity:1;transform:translateY(0)}.favorite-btn{opacity:1}.station-card:hover{transform:none}*{-webkit-tap-highlight-color:rgba(250,45,72,.2)}}@media(max-width:900px)and (orientation:landscape){.main-content{padding-bottom:calc(var(--player-height) + var(--spacing-sm))}.stations-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.sidebar{height:calc(100vh - var(--topbar-height))}}button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--text-base);outline-offset:2px}.station-card,.player-btn,.toggle-btn,.favorite-btn,.play-overlay{-webkit-user-select:none;user-select:none}.song-history-overlay{position:fixed;inset:0;background:#000000b3;z-index:250;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.song-history-panel{position:fixed;top:0;right:0;width:400px;height:100vh;background:var(--bg-elevated);box-shadow:var(--shadow-elevated);z-index:251;display:flex;flex-direction:column;animation:slideInRight .3s ease}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.song-history-header{padding:var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between}.song-history-title{font-size:1.25rem;font-weight:700;color:var(--text-base);display:flex;align-items:center;gap:var(--spacing-sm)}.song-history-close{width:36px;height:36px;border-radius:50%;background:var(--bg-highlight);border:none;color:var(--text-base);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.song-history-close:hover{background:var(--bg-press);transform:scale(1.05)}.song-history-content{flex:1;overflow-y:auto;padding:var(--spacing-lg)}.song-history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) 0;text-align:center;color:var(--text-subdued)}.song-history-empty .empty-icon{font-size:4rem;opacity:.3;margin-bottom:var(--spacing-md)}.song-history-empty p{font-size:1rem;font-weight:600;margin-bottom:var(--spacing-xs)}.empty-subtitle{font-size:.875rem;color:var(--text-muted)}.song-history-actions{margin-bottom:var(--spacing-md)}.clear-history-btn{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:1px solid var(--text-subdued);border-radius:500px;color:var(--text-base);font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s}.clear-history-btn:hover{border-color:var(--error);color:var(--error)}.song-history-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.song-history-item{display:flex;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-highlight);border-radius:8px;transition:all .2s}.song-history-item:hover{background:var(--bg-press)}.song-item-icon{width:40px;height:40px;background:var(--accent-primary);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;flex-shrink:0}.song-item-info{flex:1;min-width:0}.song-item-title{display:flex;flex-direction:column;gap:2px;margin-bottom:var(--spacing-xs)}.song-title{font-size:.9375rem;font-weight:600;color:var(--text-base);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-artist{font-size:.8125rem;color:var(--text-subdued);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-item-meta{display:flex;align-items:center;gap:var(--spacing-sm);font-size:.75rem;color:var(--text-muted)}.song-station{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-time{display:flex;align-items:center;gap:4px;flex-shrink:0}.now-playing-badge{display:inline-flex;align-items:center;padding:2px 8px;background:var(--success);color:#000;font-size:.625rem;font-weight:700;border-radius:4px;margin-left:var(--spacing-xs);text-transform:uppercase;letter-spacing:.5px}@media(max-width:768px){.song-history-panel{width:100%;max-width:100%}.song-history-header{padding:var(--spacing-md)}.song-history-title{font-size:1.125rem}.song-history-content{padding:var(--spacing-md)}.song-history-item{padding:var(--spacing-sm)}.song-item-icon{width:36px;height:36px;font-size:.875rem}.song-title{font-size:.875rem}.song-artist{font-size:.75rem}}.identify-btn{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary))!important;color:#fff!important;transition:all .3s ease}.identify-btn:hover:not(:disabled){transform:scale(1.1);box-shadow:0 4px 12px rgba(var(--accent-primary-rgb),.4)}.identify-btn:disabled{opacity:.6;cursor:not-allowed}.identify-btn.identifying{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.now-playing-badge.identified{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}@media(max-width:768px){.identify-btn{width:40px;height:40px}.spinner-small{width:14px;height:14px}}.header-nav{display:flex;gap:8px;align-items:center}.nav-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;background:transparent;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;transition:all .3s ease;font-size:.9rem;font-weight:500}.nav-tab:hover{background:#ffffff1a;color:var(--text-primary)}.nav-tab.active{background:var(--accent-primary);color:#fff}.nav-tab svg{font-size:1.1rem}@media(max-width:768px){.header-nav{position:absolute;bottom:-50px;left:50%;transform:translate(-50%);background:var(--bg-secondary);padding:8px;border-radius:12px;box-shadow:0 4px 12px #0000004d}.nav-tab span{display:none}.nav-tab{padding:10px}}.map-view{width:100%;height:calc(100vh - 80px);display:flex;flex-direction:column}.map-view-header{padding:20px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.map-view-title{font-size:1.5rem;margin:0;color:var(--text-primary)}.map-view-stats{color:var(--text-secondary);font-size:.9rem}.world-map-container{flex:1;position:relative}.world-map{width:100%;height:100%}.map-legend{position:absolute;bottom:20px;right:20px;background:var(--bg-secondary);padding:12px;border-radius:8px;box-shadow:0 2px 8px #0000004d;z-index:1000}.legend-item{display:flex;align-items:center;gap:8px;margin-bottom:8px;font-size:.85rem;color:var(--text-secondary)}.legend-item:last-child{margin-bottom:0}.map-marker-single{width:12px;height:12px;background:var(--accent-primary);border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0000004d}.map-marker-cluster{width:30px;height:30px;background:var(--accent-primary);border:3px solid white;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;box-shadow:0 2px 8px #0006}.station-popup .leaflet-popup-content-wrapper{background:var(--bg-secondary);color:var(--text-primary);border-radius:8px;padding:0}.station-popup .leaflet-popup-tip{background:var(--bg-secondary)}.popup-container{max-height:300px;overflow-y:auto}.popup-station{padding:12px;display:flex;justify-content:space-between;align-items:center;gap:12px}.popup-station-info{flex:1}.popup-station-name{font-weight:600;margin-bottom:4px;color:var(--text-primary)}.popup-station-details{font-size:.85rem;color:var(--text-secondary);margin-bottom:4px}.popup-station-tags{font-size:.75rem;color:var(--accent-primary)}.popup-station-actions{display:flex;gap:8px}.popup-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all .2s ease}.popup-btn:hover{transform:scale(1.1);background:var(--accent-primary)}.popup-btn.fav-btn.active{background:#e74c3c}.stats-view{width:100%;min-height:calc(100vh - 80px);padding:20px;background:var(--bg-primary);overflow-y:auto}.stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.stats-title{font-size:2rem;margin:0;color:var(--text-primary)}.clear-stats-btn{padding:10px 20px;background:#e74c3c;color:#fff;border:none;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:8px;font-weight:500;transition:all .3s ease}.clear-stats-btn:hover{background:#c0392b;transform:translateY(-2px)}.stats-loading{text-align:center;padding:40px;color:var(--text-secondary);font-size:1.2rem}.stats-overview{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:var(--bg-secondary);padding:20px;border-radius:12px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0003;transition:transform .3s ease}.stat-card:hover{transform:translateY(-4px)}.stat-icon{width:50px;height:50px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem}.stat-content{flex:1}.stat-value{font-size:1.8rem;font-weight:700;color:var(--text-primary);margin-bottom:4px}.stat-label{font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.stats-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px;margin-bottom:30px}.chart-container{background:var(--bg-secondary);padding:20px;border-radius:12px;box-shadow:0 2px 8px #0003}.chart-container.full-width{grid-column:1 / -1}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.chart-title{font-size:1.2rem;margin:0 0 20px;color:var(--text-primary)}.time-range-selector{display:flex;gap:8px}.time-range-selector button{padding:6px 12px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-secondary);cursor:pointer;transition:all .3s ease;font-size:.85rem}.time-range-selector button:hover{background:var(--bg-secondary);color:var(--text-primary)}.time-range-selector button.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.no-data{text-align:center;padding:40px;color:var(--text-secondary);font-style:italic}.stats-favorites{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.favorite-card{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));padding:24px;border-radius:12px;display:flex;align-items:center;gap:16px;color:#fff;box-shadow:0 4px 12px #0000004d}.favorite-icon{font-size:2rem;opacity:.9}.favorite-content{flex:1}.favorite-label{font-size:.85rem;opacity:.9;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.favorite-value{font-size:1.3rem;font-weight:700}@media(max-width:768px){.stats-view{padding:15px}.stats-title{font-size:1.5rem}.stats-overview,.stats-charts{grid-template-columns:1fr}.chart-container,.stat-card{padding:15px}.stat-value{font-size:1.5rem}}.volume-control{position:relative;display:flex;align-items:center;margin-left:8px}.volume-btn{transition:all .3s ease}.volume-slider-container{position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-10px);background:var(--bg-elevated);padding:16px 12px;border-radius:12px;box-shadow:0 8px 24px #0009;border:1px solid rgba(255,255,255,.1);opacity:0;pointer-events:none;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:10px;min-width:60px}.volume-slider-container.show{opacity:1;pointer-events:all;transform:translate(-50%) translateY(-20px)}.volume-slider{writing-mode:vertical-lr;direction:rtl;width:10px;height:120px;padding:0;margin:0;background:linear-gradient(to top,var(--accent-primary) 0%,var(--accent-primary) var(--volume-percent, 100%),var(--bg-press) var(--volume-percent, 100%),var(--bg-press) 100%);border-radius:5px;outline:none;cursor:pointer;border:1px solid rgba(255,255,255,.1)}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--accent-primary);border-radius:50%;cursor:pointer;transition:all .2s ease}.volume-slider::-webkit-slider-thumb:hover{transform:scale(1.2);background:var(--accent-hover)}.volume-slider::-moz-range-thumb{width:16px;height:16px;background:var(--accent-primary);border-radius:50%;cursor:pointer;border:none;transition:all .2s ease}.volume-slider::-moz-range-thumb:hover{transform:scale(1.2);background:var(--accent-hover)}.volume-value{font-size:.85rem;color:var(--text-base);font-weight:700;background:var(--bg-press);padding:4px 8px;border-radius:4px;min-width:45px;text-align:center}.toast-container{position:fixed;top:80px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px}.toast{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 12px #0000004d;border-left:4px solid;animation:slideIn .3s ease;min-width:300px}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-success{border-left-color:var(--success)}.toast-error{border-left-color:var(--error)}.toast-warning{border-left-color:var(--warning)}.toast-info{border-left-color:var(--accent-primary)}.toast-icon{font-size:1.5rem;flex-shrink:0}.toast-success .toast-icon{color:var(--success)}.toast-error .toast-icon{color:var(--error)}.toast-warning .toast-icon{color:var(--warning)}.toast-info .toast-icon{color:var(--accent-primary)}.toast-message{flex:1;color:var(--text-base);font-size:.9rem;line-height:1.4}.toast-close{background:none;border:none;color:var(--text-subdued);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.toast-close:hover{background:var(--bg-press);color:var(--text-base)}.skip-link{position:absolute;top:-40px;left:0;background:var(--accent-primary);color:#fff;padding:8px 16px;text-decoration:none;border-radius:0 0 4px;z-index:100000;font-weight:600;transition:top .3s ease}.skip-link:focus{top:0}@media(max-width:768px){.toast-container{right:10px;left:10px;max-width:none}.toast{min-width:auto}.volume-slider-container{right:0;left:auto;transform:translate(0) translateY(-10px)}.volume-slider-container.show{transform:translate(0) translateY(-20px)}}.sleep-timer-container{position:relative}.sleep-timer-btn,.share-btn{transition:all .3s ease}.sleep-timer-active{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-secondary);border-radius:20px;font-size:.9rem;color:var(--accent-primary);font-weight:600}.sleep-timer-cancel{background:none;border:none;color:var(--text-subdued);cursor:pointer;padding:4px;display:flex;align-items:center;transition:color .2s ease}.sleep-timer-cancel:hover{color:var(--text-base)}.sleep-timer-popup{position:absolute;bottom:100%;right:0;transform:translateY(-10px);background:var(--bg-elevated);padding:16px;border-radius:12px;box-shadow:0 8px 24px #0009;border:1px solid rgba(255,255,255,.1);min-width:200px;z-index:1000}.sleep-timer-popup h4{margin:0 0 12px;font-size:.9rem;color:var(--text-base)}.sleep-timer-options{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.sleep-timer-option{padding:8px;background:var(--bg-secondary);border:1px solid var(--bg-press);border-radius:8px;color:var(--text-base);cursor:pointer;font-size:.85rem;transition:all .2s ease}.sleep-timer-option:hover{background:var(--bg-press);border-color:var(--accent-primary);color:var(--accent-primary)}.sleep-timer-close{width:100%;padding:8px;background:var(--bg-press);border:none;border-radius:8px;color:var(--text-subdued);cursor:pointer;font-size:.85rem;transition:all .2s ease}.sleep-timer-close:hover{background:var(--bg-secondary);color:var(--text-base)}.skeleton{animation:skeleton-loading 1.5s infinite ease-in-out}@keyframes skeleton-loading{0%{opacity:.6}50%{opacity:.8}to{opacity:.6}}.skeleton-artwork{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-press) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-line{height:16px;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-press) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:4px;margin-bottom:8px}.skeleton-title{width:80%;height:18px}.skeleton-subtitle{width:60%;height:14px}.skeleton-tags{display:flex;gap:8px;margin-top:8px}.skeleton-tag{width:60px;height:24px;background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-press) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:12px}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-primary);padding:20px}.error-boundary-content{text-align:center;max-width:500px}.error-icon{font-size:4rem;margin-bottom:1rem}.error-boundary h1{color:var(--text-base);margin-bottom:1rem}.error-boundary p{color:var(--text-subdued);margin-bottom:2rem}.error-reload-btn{padding:12px 24px;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease}.error-reload-btn:hover{background:var(--accent-hover);transform:translateY(-2px)}.legal-page{max-width:900px;margin:0 auto;padding:40px 20px;min-height:calc(100vh - 200px);max-height:calc(100vh - 100px);overflow-y:auto}.legal-content{background:var(--bg-secondary);padding:40px;border-radius:12px}.legal-content h1{color:var(--text-base);margin-bottom:1rem;font-size:2.5rem}.legal-updated{color:var(--text-subdued);font-size:.9rem;margin-bottom:2rem;font-style:italic}.legal-content section{margin-bottom:2rem}.legal-content h2{color:var(--text-base);margin-bottom:1rem;margin-top:2rem;font-size:1.8rem}.legal-content h3{color:var(--text-base);margin-bottom:.75rem;margin-top:1.5rem;font-size:1.3rem}.legal-content p{color:var(--text-subdued);line-height:1.8;margin-bottom:1rem}.legal-content ul{list-style:disc;margin-left:2rem;margin-bottom:1rem}.legal-content li{color:var(--text-subdued);line-height:1.8;margin-bottom:.5rem}.legal-content strong{color:var(--text-base);font-weight:600}.app-footer{background:var(--bg-secondary);border-top:1px solid var(--bg-press);margin-top:60px;padding:40px 20px 20px}.footer-content{max-width:1200px;margin:0 auto 30px;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:40px}.footer-section h4{color:var(--text-base);margin-bottom:1rem;font-size:1.1rem}.footer-section p{color:var(--text-subdued);font-size:.9rem;line-height:1.6}.footer-links{list-style:none;padding:0}.footer-links li{margin-bottom:.5rem}.footer-link{background:none;border:none;color:var(--text-subdued);cursor:pointer;font-size:.9rem;padding:0;text-align:left;transition:color .2s ease}.footer-link:hover{color:var(--accent-primary)}.footer-social{display:flex;gap:15px}.footer-social a{color:var(--text-subdued);font-size:1.5rem;transition:color .2s ease}.footer-social a:hover{color:var(--accent-primary)}.footer-bottom{text-align:center;padding-top:20px;border-top:1px solid var(--bg-press);color:var(--text-muted);font-size:.85rem}.footer-version{margin-top:5px;color:var(--text-muted)}@media(max-width:768px){.legal-content{padding:20px}.legal-content h1{font-size:2rem}.legal-content h2{font-size:1.5rem}.footer-content{grid-template-columns:1fr;gap:30px}}.legal-links{margin-top:auto;padding-top:20px;border-top:1px solid var(--bg-press);display:flex;flex-direction:row;justify-content:center;gap:16px}.legal-link-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:var(--bg-highlight);border:none;color:var(--text-subdued);cursor:pointer;border-radius:50%;transition:all .2s ease;font-size:1.1rem}.legal-link-btn:hover{background:var(--bg-press);color:var(--text-base)}.legal-link-btn svg{font-size:1.1rem;flex-shrink:0}.app-version{margin-top:15px;padding-top:15px;border-top:1px solid var(--bg-press);text-align:center}.app-version span{color:var(--text-muted);font-size:.75rem;font-weight:600}.legal-content p{text-align:justify;text-justify:inter-word}.legal-content ul,.legal-content ol{text-align:left}.language-switcher{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--bg-press)}.language-icon{color:var(--text-subdued);font-size:1rem}.language-select{background:transparent;border:none;color:var(--text-base);font-size:.9rem;cursor:pointer;outline:none;padding:0}.language-select option{background:var(--bg-elevated);color:var(--text-base)}.language-switcher:hover{border-color:var(--accent-primary)}.language-switcher:hover .language-icon{color:var(--accent-primary)}@media(max-width:768px){.language-switcher{padding:8px;width:36px;height:36px;justify-content:center}.language-select{position:absolute;opacity:0;width:36px;height:36px;cursor:pointer}.header-nav{display:none}}
