:root{--bg: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f5f5f5;--text-primary: #111111;--text-secondary: #888888;--text-tertiary: #666666;--border: #e5e5e5;--border-hover: #cccccc;--card-bg: #ffffff;--shadow: rgba(0,0,0,.08);--player-bg: #ffffff;--overlay-bg: rgba(0,0,0,.25);--scrollbar: #e0e0e0;--theme-meta: #ffffff}.dark{--bg: #1a1a1a;--bg-secondary: #222222;--bg-tertiary: #2a2a2a;--text-primary: #e5e5e5;--text-secondary: #888888;--text-tertiary: #aaaaaa;--border: #333333;--border-hover: #555555;--card-bg: #242424;--shadow: rgba(0,0,0,.3);--player-bg: #1a1a1a;--overlay-bg: rgba(0,0,0,.5);--scrollbar: #333333;--theme-meta: #1a1a1a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%;overflow:hidden}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;line-height:1.5;color:var(--text-primary);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background .3s ease,color .3s ease}button,input,select{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer;border:none;background:none}input:focus,select:focus,button:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:var(--bg);z-index:1000;transition:opacity .4s ease,visibility .4s ease}.loading-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}.loading-content{text-align:center}.loading-spinner{width:32px;height:32px;border:2px solid var(--border);border-top-color:var(--text-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:15px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.loading-sub{font-size:12px;color:var(--text-secondary)}.retry-btn{margin-top:16px;padding:8px 20px;background:var(--text-primary);color:var(--bg);border-radius:8px;font-size:13px;font-weight:500;transition:opacity .15s ease}.retry-btn:hover{opacity:.85}.main-layout{display:flex;height:100vh;padding-bottom:72px}.left-panel{width:40%;min-width:360px;max-width:560px;display:flex;flex-direction:column;border-right:1px solid var(--border);background:var(--bg-secondary);transition:background .3s ease,border-color .3s ease}.panel-header{padding:20px 20px 12px;background:var(--card-bg);border-bottom:1px solid var(--border);flex-shrink:0;transition:background .3s ease,border-color .3s ease}.header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.header-actions{display:flex;align-items:center;gap:8px}.app-title{font-size:18px;font-weight:600;letter-spacing:-.3px;color:var(--text-primary)}.station-count{font-size:12px;font-weight:500;color:var(--text-secondary);background:var(--bg-tertiary);padding:2px 8px;border-radius:12px;white-space:nowrap}.filter-bar{display:flex;align-items:center;gap:8px}.filter-group{position:relative;flex:1}.filter-select{width:100%;-moz-appearance:none;appearance:none;-webkit-appearance:none;padding:7px 28px 7px 10px;border:1px solid var(--border);border-radius:8px;background:var(--card-bg);font-size:12px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:border-color .15s ease,background .3s ease;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.filter-select:hover{border-color:var(--border-hover)}.filter-select:focus{border-color:var(--text-primary)}.filter-badge{position:absolute;right:26px;top:50%;transform:translateY(-50%);font-size:10px;font-weight:600;color:var(--text-secondary);background:var(--bg-tertiary);padding:1px 5px;border-radius:6px;pointer-events:none}.icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;color:var(--text-tertiary);transition:all .15s ease;flex-shrink:0}.icon-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.icon-btn.active{background:var(--text-primary);color:var(--bg)}.icon-btn:disabled{opacity:.3;cursor:not-allowed}.station-grid{flex:1;overflow-y:auto;padding:16px 20px 20px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px;align-content:start}.station-grid::-webkit-scrollbar{width:6px}.station-grid::-webkit-scrollbar-track{background:transparent}.station-grid::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:3px}.station-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:12px;cursor:pointer;transition:all .15s ease;position:relative;overflow:hidden}.station-card:hover{border-color:var(--border-hover);box-shadow:0 1px 4px var(--shadow);transform:translateY(-1px)}.station-card:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.station-card.active{border-color:var(--text-primary);box-shadow:0 0 0 1px var(--text-primary)}.station-card.highlighted{background:var(--bg-tertiary)}.station-card.playing .card-status{background:#10b981;animation:pulse 2s ease-in-out infinite}.station-card.playing .eq-bars{display:flex}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.eq-bars{display:none;align-items:center;gap:2px;height:16px;flex-shrink:0}.eq-bars span{display:block;width:3px;background:#10b981;border-radius:1px;animation:equalize 1.2s ease-in-out infinite}.eq-bars span:nth-child(1){height:10px;animation-delay:0s}.eq-bars span:nth-child(2){height:6px;animation-delay:.2s}.eq-bars span:nth-child(3){height:14px;animation-delay:.4s}@keyframes equalize{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.card-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}.card-status{width:8px;height:8px;border-radius:50%;background:var(--border);flex-shrink:0}.card-fav{margin-left:auto;opacity:0;transition:opacity .15s ease;color:var(--border-hover)}.station-card:hover .card-fav,.station-card.favorite .card-fav{opacity:1}.station-card.favorite .card-fav{color:#ef4444}.card-name{font-size:12px;font-weight:600;color:var(--text-primary);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;margin-bottom:6px;min-height:32px}.card-meta{display:flex;flex-wrap:wrap;gap:4px}.card-tag{font-size:10px;font-weight:500;color:var(--text-secondary);background:var(--bg-tertiary);padding:2px 6px;border-radius:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.card-tag-warn{color:#d97706;background:#fef3c7}.dark .card-tag-warn{color:#fbbf24;background:#78350f}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-secondary);text-align:center}.empty-state-icon{margin-bottom:12px;opacity:.4}.empty-state-text{font-size:14px;font-weight:500;margin-bottom:16px}.empty-state-btn{padding:7px 16px;font-size:12px;font-weight:500;background:var(--text-primary);color:var(--bg);border-radius:8px;transition:opacity .15s ease}.empty-state-btn:hover{opacity:.85}.right-panel{flex:1;position:relative;background:var(--bg);overflow:hidden;transition:background .3s ease}#globe-container{position:absolute;top:0;right:0;bottom:0;left:0}#globe-container canvas{display:block}.globe-overlay{position:absolute;bottom:20px;left:50%;transform:translate(-50%);pointer-events:none;z-index:10}.globe-hint{font-size:11px;font-weight:500;color:var(--text-secondary);background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:6px 12px;border-radius:20px;border:1px solid var(--border);display:flex;align-items:center;gap:6px}.dark .globe-hint{background:#1e1e1ee6}.kbd{font-family:Inter,monospace;font-size:10px;font-weight:600;color:var(--text-tertiary);background:var(--bg-tertiary);padding:2px 5px;border-radius:4px;border:1px solid var(--border)}.player-bar{position:fixed;bottom:0;left:0;right:0;height:72px;background:var(--player-bg);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:100;transition:background .3s ease,border-color .3s ease}.player-left{display:flex;align-items:center;gap:14px;min-width:0;flex:1}.play-btn{position:relative;width:40px;height:40px;border-radius:50%;background:var(--text-primary);color:var(--bg);display:flex;align-items:center;justify-content:center;transition:transform .15s ease,background .15s ease;flex-shrink:0}.play-btn:hover:not(:disabled){background:var(--text-tertiary);transform:scale(1.05)}.play-btn:disabled{background:var(--border);color:var(--text-secondary);cursor:not-allowed}.buffering-spinner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;gap:3px}.buffering-dot{width:5px;height:5px;border-radius:50%;background:var(--bg);animation:buffer-bounce 1.2s ease-in-out infinite}.buffering-dot:nth-child(2){animation-delay:.2s}.buffering-dot:nth-child(3){animation-delay:.4s}@keyframes buffer-bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.player-info{min-width:0}.player-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-meta{font-size:11px;color:var(--text-secondary);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-center{display:flex;align-items:center;justify-content:center;flex:1}.volume-wrap{display:flex;align-items:center;gap:8px;color:var(--text-secondary)}.vol-icon{display:flex;align-items:center;color:var(--text-tertiary);transition:color .15s ease}.vol-icon:hover{color:var(--text-primary)}.volume-wrap input[type=range]{width:100px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border);border-radius:2px;outline:none;cursor:pointer}.volume-wrap input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--text-primary);cursor:pointer;transition:transform .15s ease}.volume-wrap input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}.volume-display{font-size:11px;font-weight:600;color:var(--text-secondary);min-width:32px;text-align:right}.player-right{display:flex;align-items:center;gap:4px;flex:1;justify-content:flex-end}.sleep-wrap{position:relative;display:flex;align-items:center;gap:6px}.sleep-menu{position:absolute;bottom:calc(100% + 8px);right:0;background:var(--card-bg);border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 20px var(--shadow);padding:6px;display:none;flex-direction:column;gap:2px;min-width:100px;z-index:50}.sleep-menu.open{display:flex}.sleep-menu button{padding:6px 10px;border-radius:6px;font-size:12px;font-weight:500;color:var(--text-primary);text-align:left;transition:background .1s ease}.sleep-menu button:hover{background:var(--bg-tertiary)}.sleep-timer-display{font-size:11px;font-weight:600;color:#10b981;min-width:40px;text-align:right}.search-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:none;align-items:flex-start;justify-content:center;padding-top:12vh}.search-modal.open{display:flex}.search-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--overlay-bg);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.search-container{position:relative;width:100%;max-width:600px;margin:0 20px;background:var(--card-bg);border-radius:14px;box-shadow:0 20px 60px var(--shadow);overflow:hidden;display:flex;flex-direction:column;max-height:70vh}.search-input-wrap{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border);color:var(--text-secondary)}.search-input-wrap input{flex:1;border:none;font-size:15px;font-weight:400;color:var(--text-primary);background:transparent}.search-input-wrap input::placeholder{color:var(--text-secondary)}.search-kbd{font-size:10px;font-weight:600;color:var(--text-secondary);background:var(--bg-tertiary);padding:3px 6px;border-radius:5px;border:1px solid var(--border)}.search-results{overflow-y:auto;padding:8px}.search-result-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background .1s ease}.search-result-item:hover,.search-result-item.selected{background:var(--bg-tertiary)}.search-result-dot{width:8px;height:8px;border-radius:50%;background:var(--border);flex-shrink:0}.search-result-info{min-width:0;flex:1}.search-result-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-meta{font-size:11px;color:var(--text-secondary);margin-top:1px}.search-empty{padding:40px;text-align:center;color:var(--text-secondary);font-size:13px}.scene-tooltip{font-family:Inter,sans-serif!important;font-size:12px!important;font-weight:500!important;color:var(--text-primary)!important;background:#fffffff2!important;-webkit-backdrop-filter:blur(8px)!important;backdrop-filter:blur(8px)!important;border:1px solid var(--border)!important;border-radius:8px!important;padding:8px 12px!important;box-shadow:0 4px 16px var(--shadow)!important;max-width:240px!important;line-height:1.4!important}.dark .scene-tooltip{background:#282828f2!important}.scene-tooltip .tooltip-name{font-weight:600!important;margin-bottom:2px!important}.scene-tooltip .tooltip-meta{font-size:11px!important;color:var(--text-secondary)!important}@media (max-width: 1100px){.station-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.left-panel{width:50%;min-width:280px}}@media (max-width: 768px){.left-panel{width:100%;max-width:none;min-width:0}.right-panel{height:40vh;min-height:200px}.main-layout{flex-direction:column}}@media (max-width: 640px){.left-panel{height:60vh;border-right:none;border-bottom:1px solid var(--border)}.right-panel{height:40vh;min-height:200px}.main-layout{flex-direction:column-reverse;padding-bottom:72px}.station-grid{grid-template-columns:repeat(2,1fr)}.player-center,.globe-overlay{display:none}.panel-header{padding:14px 14px 10px}.station-grid{padding:12px 14px 16px}}@media (max-width: 400px){.station-grid{grid-template-columns:1fr}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
