:root{--bg-primary: #000000;--bg-secondary: #0a0a0a;--bg-tertiary: #141414;--bg-card: rgba(255, 255, 255, .03);--bg-glass: rgba(255, 255, 255, .06);--bg-glass-hover: rgba(255, 255, 255, .1);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .65);--text-muted: rgba(255, 255, 255, .35);--border-subtle: rgba(255, 255, 255, .06);--border-medium: rgba(255, 255, 255, .12);--accent-trance: #00e5ff;--accent-hard: #ff1744;--accent-acid: #76ff03;--accent-deep: #7c4dff;--accent-dark: #ff9100;--accent: #ffffff;--accent-glow: rgba(255, 255, 255, .15);--accent-dim: rgba(255, 255, 255, .05);--font-primary: "Outfit", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", monospace;--text-xs: .6875rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.125rem;--text-xl: 1.5rem;--text-2xl: 2rem;--text-3xl: 2.75rem;--text-4xl: 3.75rem;--weight-light: 300;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-black: 900;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 16px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .6);--shadow-glow: 0 0 40px var(--accent-glow);--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .15s;--duration-normal: .3s;--duration-slow: .5s;--z-base: 1;--z-overlay: 100;--z-player: 200;--z-narrator: 300;--z-modal: 400}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-primary);font-weight:var(--weight-regular);color:var(--text-primary);background:var(--bg-primary);line-height:1.5;overflow-x:hidden;min-height:100vh;min-height:100dvh}body:before,body:after{display:none}#app{position:relative;z-index:var(--z-base);min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:var(--weight-bold);line-height:1.15;letter-spacing:-.02em}a{color:var(--accent);text-decoration:none;transition:opacity var(--duration-fast) var(--ease-out)}a:hover{opacity:.8}button{font-family:var(--font-primary);cursor:pointer;border:none;background:none;color:inherit;font-size:inherit}img,svg{display:block;max-width:100%}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#fff3}::selection{background:var(--accent);color:var(--bg-primary)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes livePulse{0%,to{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 0 8px transparent}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes equalizerBar{0%,to{height:4px}50%{height:16px}}.header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-8);position:sticky;top:0;z-index:var(--z-overlay);background:#0a0a0fd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle)}.header__logo{display:flex;align-items:center;gap:var(--space-3)}.header__logo-icon{width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--accent) 0%,rgba(255,255,255,.1) 100%);display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);box-shadow:var(--shadow-glow);transition:background var(--duration-slow) var(--ease-out),box-shadow var(--duration-slow) var(--ease-out)}.header__logo-text{font-size:var(--text-xl);font-weight:var(--weight-black);letter-spacing:-.03em;background:linear-gradient(135deg,var(--text-primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header__live-badge{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:var(--bg-glass);font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.08em;color:var(--accent)}.header__live-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:livePulse 2s var(--ease-out) infinite}.main{flex:1;display:flex;flex-direction:column;padding:var(--space-8);padding-bottom:140px}.section-title{font-size:var(--text-sm);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:var(--space-6)}.stations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-5);margin-bottom:var(--space-12)}.station-card{position:relative;padding:var(--space-6);border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);overflow:hidden;animation:fadeInUp var(--duration-slow) var(--ease-out) both}.station-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--station-color);opacity:.6;transition:opacity var(--duration-normal) var(--ease-out)}.station-card:hover{background:var(--bg-glass-hover);border-color:var(--border-medium);transform:translateY(-2px);box-shadow:var(--shadow-md)}.station-card:hover:before{opacity:1}.station-card.active{border-color:var(--station-color);background:#ffffff0d;box-shadow:0 0 30px rgba(var(--station-color-rgb, 0, 229, 255),.15)}.station-card.active:before{opacity:1;height:3px}.station-card__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-4)}.station-card__number{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);font-weight:var(--weight-medium)}.station-card__equalizer{display:flex;align-items:flex-end;gap:2px;height:16px;opacity:0;transition:opacity var(--duration-normal) var(--ease-out)}.station-card.active .station-card__equalizer{opacity:1}.station-card__equalizer-bar{width:3px;background:var(--station-color);border-radius:2px;animation:equalizerBar .8s ease-in-out infinite}.station-card__equalizer-bar:nth-child(2){animation-delay:.15s}.station-card__equalizer-bar:nth-child(3){animation-delay:.3s}.station-card__equalizer-bar:nth-child(4){animation-delay:.1s}.station-card__name{font-size:var(--text-lg);font-weight:var(--weight-bold);margin-bottom:var(--space-1);color:var(--text-primary)}.station-card__genre{font-size:var(--text-sm);color:var(--station-color);font-weight:var(--weight-medium);margin-bottom:var(--space-3)}.station-card__description{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5;margin-bottom:var(--space-4)}.station-card__meta{display:flex;align-items:center;gap:var(--space-4);font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}.station-card__bpm{display:flex;align-items:center;gap:var(--space-1)}.player{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-player);background:#0a0a0feb;backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-top:1px solid var(--border-subtle);padding:var(--space-4) var(--space-8);transform:translateY(100%);transition:transform var(--duration-slow) var(--ease-out)}.player.visible{transform:translateY(0)}.player__inner{display:flex;align-items:center;gap:var(--space-6);max-width:1200px;margin:0 auto}.player__visualizer-container{width:56px;height:56px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0;background:var(--bg-tertiary);position:relative}.player__visualizer-canvas{width:100%;height:100%}.player__info{flex:1;min-width:0}.player__station-name{font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:2px}.player__time-slot{font-size:10px;font-weight:var(--weight-semibold);color:var(--text-muted);letter-spacing:.06em;padding:1px 6px;border-radius:var(--radius-sm);background:#9c27b026;display:inline-block;margin-bottom:2px;transition:all var(--duration-normal) var(--ease-out)}.player__track-name{font-size:var(--text-base);font-weight:var(--weight-semibold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.player__track-artist{font-size:var(--text-sm);color:var(--text-secondary)}.player__controls{display:flex;align-items:center;gap:var(--space-3)}.player__btn{width:40px;height:40px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background:var(--bg-glass);color:var(--text-primary);transition:all var(--duration-fast) var(--ease-out);font-size:var(--text-lg)}.player__btn:hover{background:var(--bg-glass-hover);transform:scale(1.05)}.player__btn--play{width:48px;height:48px;background:var(--accent);color:var(--bg-primary);font-size:var(--text-xl)}.player__btn--play:hover{background:var(--accent);opacity:.9;transform:scale(1.08)}.player__live-indicator{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);background:#ff17441f;border:1px solid rgba(255,23,68,.3);font-size:var(--text-xs);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.12em;color:#ff1744;white-space:nowrap}.player__live-dot{width:8px;height:8px;border-radius:50%;background:#ff1744;animation:livePulse 1.5s ease-in-out infinite}.player__btn--narrator{width:40px;height:40px;border-radius:var(--radius-full);background:var(--bg-glass);border:1px solid var(--border-subtle);color:var(--text-primary);font-size:18px;cursor:pointer;transition:all var(--duration-fast) var(--ease-out);display:flex;align-items:center;justify-content:center}.player__btn--narrator:hover{background:var(--accent-dim);border-color:var(--accent);transform:scale(1.1)}.player__volume{display:flex;align-items:center;gap:var(--space-2)}.player__volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100px;height:4px;border-radius:2px;background:var(--bg-glass);outline:none}.player__volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out)}.player__volume-slider::-webkit-slider-thumb:hover{transform:scale(1.3)}.player__progress{position:absolute;top:-2px;left:0;right:0;height:3px;background:#ffffff0d}.player__progress-bar{height:100%;background:var(--accent);border-radius:0 2px 2px 0;width:0%;transition:width 1s linear}.visualizer-section{width:100%;height:180px;border-radius:var(--radius-lg);overflow:hidden;background:var(--bg-card);border:1px solid var(--border-subtle);margin-bottom:var(--space-8);position:relative}.visualizer-canvas{width:100%;height:100%}.visualizer-section__overlay{position:absolute;bottom:0;left:0;right:0;padding:var(--space-4) var(--space-6);background:linear-gradient(transparent,#0a0a0fe6);display:flex;align-items:flex-end;justify-content:space-between}.visualizer-section__track-info{display:flex;flex-direction:column;gap:2px}.visualizer-section__track-title{font-size:var(--text-lg);font-weight:var(--weight-bold)}.visualizer-section__track-artist{font-size:var(--text-sm);color:var(--text-secondary)}.visualizer-section__bpm{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--accent);font-weight:var(--weight-medium)}.narrator-overlay{position:fixed;bottom:100px;left:50%;transform:translate(-50%) translateY(20px);z-index:var(--z-narrator);background:#0a0a0ff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--accent);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-6);display:flex;align-items:center;gap:var(--space-4);max-width:500px;opacity:0;pointer-events:none;transition:all var(--duration-normal) var(--ease-out);box-shadow:0 0 40px var(--accent-glow)}.narrator-overlay.visible{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0)}.narrator-overlay__icon{width:40px;height:40px;border-radius:var(--radius-full);background:var(--accent-dim);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:var(--text-lg);animation:pulse 1.5s ease-in-out infinite}.narrator-overlay__text{font-size:var(--text-sm);color:var(--text-primary);line-height:1.5;font-weight:var(--weight-medium)}.narrator-overlay__label{font-size:var(--text-xs);color:var(--accent);text-transform:uppercase;letter-spacing:.1em;font-weight:var(--weight-semibold);margin-bottom:2px}.mixing-overlay{position:fixed;top:80px;left:50%;transform:translate(-50%) translateY(-20px);z-index:var(--z-overlay);display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);background:#0a0a0feb;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--accent);box-shadow:0 0 30px var(--accent-glow),0 4px 20px #00000080;opacity:0;pointer-events:none;transition:all .4s var(--ease-out)}.mixing-overlay.visible{opacity:1;pointer-events:auto;transform:translate(-50%) translateY(0)}.mixing-overlay__icon{font-size:var(--text-lg);animation:mixPulse 1s ease-in-out infinite}.mixing-overlay__text{font-size:var(--text-sm);font-weight:var(--weight-black);text-transform:uppercase;letter-spacing:.2em;color:var(--accent);background:linear-gradient(90deg,var(--accent),var(--text-primary),var(--accent));background-size:200% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:mixTextShimmer 2s linear infinite}@keyframes mixPulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}@keyframes mixTextShimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.loading-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:var(--bg-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-6);transition:opacity var(--duration-slow) var(--ease-out)}.loading-screen__logo{font-size:var(--text-3xl);font-weight:var(--weight-black);letter-spacing:-.03em;background:linear-gradient(135deg,var(--text-primary),var(--accent-trance));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.loading-screen__spinner{width:32px;height:32px;border:2px solid var(--border-subtle);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.loading-screen__progress{width:200px;text-align:center}.loading-screen__progress-bar{width:100%;height:3px;background:var(--border-subtle);border-radius:2px;overflow:hidden;margin-bottom:var(--space-2)}.loading-screen__progress-fill{height:100%;background:var(--accent, #a855f7);border-radius:2px;width:0%;transition:width .3s ease-out}.loading-screen__progress-text{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.station-card__loading{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--border-subtle);opacity:0;transition:opacity .3s ease}.station-card--loading .station-card__loading{opacity:1}.station-card__loading-fill{height:100%;background:var(--accent, #a855f7);width:0%;transition:width .15s ease-out;animation:stationLoadPulse 1.5s ease-in-out infinite}@keyframes stationLoadPulse{0%,to{opacity:.6}50%{opacity:1}}.station-card--connecting:after{content:"Connecting...";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#000000b3;color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--weight-medium);border-radius:inherit;animation:connectPulse 1s ease-in-out infinite}@keyframes connectPulse{0%,to{opacity:.8}50%{opacity:1}}@media(max-width:768px){.header{padding:var(--space-4)}.main{padding:var(--space-4);padding-bottom:130px}.stations-grid{grid-template-columns:1fr;gap:var(--space-4)}.player__inner{gap:var(--space-3)}.player{padding:var(--space-3) var(--space-4)}.player__volume{display:none}.visualizer-section{height:140px}.header__logo-text{font-size:var(--text-lg)}}@media(max-width:480px){.player__track-artist{display:none}.visualizer-section{height:120px}}.voting-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;pointer-events:none;opacity:0;transition:opacity .3s ease}.voting-overlay.visible{opacity:1;pointer-events:auto}.voting-overlay__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.voting-overlay__content{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6)}.voting-overlay__header{text-align:center;margin-bottom:var(--space-6)}.voting-overlay__title{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.voting-overlay__countdown{font-size:var(--text-lg);font-weight:var(--weight-semibold);color:var(--accent);font-variant-numeric:tabular-nums}.voting-overlay__countdown--urgent{color:#ef4444;animation:countdownPulse .5s ease-in-out infinite}@keyframes countdownPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.voting-overlay__options{display:flex;flex-direction:column;gap:var(--space-3);width:100%;max-width:400px}.voting-option{position:relative;background:#ffffff0d;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-3);align-items:center;cursor:pointer;transition:all .2s ease}.voting-option:hover{background:#ffffff14;border-color:var(--accent)}.voting-option--selected{border-color:var(--accent);background:#a855f71a}.voting-option--voted{cursor:default}.voting-option--winner{border-color:#22c55e;background:#22c55e1a}.voting-option--loser{opacity:.4}.voting-option__number{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:var(--text-primary);border-radius:50%;font-weight:var(--weight-bold);font-size:var(--text-sm)}.voting-option__info{min-width:0}.voting-option__title{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voting-option__artist{font-size:var(--text-sm);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voting-option__stats{text-align:right}.voting-option__percent{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--accent)}.voting-option__count{font-size:var(--text-xs);color:var(--text-secondary)}.voting-option__progress{position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--border-subtle);border-radius:0 0 var(--radius-lg) var(--radius-lg);overflow:hidden}.voting-option__progress-fill{height:100%;background:var(--accent);width:0%;transition:width .3s ease-out}.voting-overlay__footer{margin-top:var(--space-4);text-align:center}.voting-overlay__total{font-size:var(--text-sm);color:var(--text-secondary)}@media(max-width:480px){.voting-option{grid-template-columns:1fr;gap:var(--space-2)}.voting-option__number{width:24px;height:24px;font-size:var(--text-xs)}.voting-option__stats{display:none}}.station-carousel{position:relative;width:100%;overflow:hidden;padding:var(--space-6) 0}.station-carousel__track{display:flex;gap:var(--space-4);overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;padding:0 var(--space-4);cursor:grab}.station-carousel__track::-webkit-scrollbar{display:none}.station-carousel.is-dragging .station-carousel__track{cursor:grabbing;scroll-behavior:auto}.station-carousel__item{flex:0 0 auto;width:140px;scroll-snap-align:center;position:relative;transition:transform var(--duration-normal) var(--ease-out)}.station-carousel__item:hover{transform:scale(1.05)}.station-carousel__item.active{transform:scale(1.1)}.station-carousel__item.active .station-carousel__art-inner{box-shadow:0 0 40px var(--station-color)}.station-carousel__art{position:relative;width:100%;aspect-ratio:1;border-radius:var(--radius-xl);overflow:hidden;background:var(--bg-card);border:2px solid var(--border-subtle);transition:all var(--duration-normal) var(--ease-out)}.station-carousel__item.active .station-carousel__art{border-color:var(--station-color)}.station-carousel__art-inner{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--station-color) 0%,rgba(var(--station-color-rgb),.3) 100%);position:relative}.station-carousel__art-icon{font-size:48px;color:#ffffffe6;text-shadow:0 2px 10px rgba(0,0,0,.3)}.station-carousel__art-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.4) 100%)}.station-carousel__info{margin-top:var(--space-3);text-align:center}.station-carousel__name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.station-carousel__genre{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px}.station-carousel__status{position:absolute;top:var(--space-2);right:var(--space-2);width:8px;height:8px;border-radius:50%;background:var(--border-subtle)}.station-carousel__status-dot{display:block;width:100%;height:100%;border-radius:50%;background:var(--text-muted)}.station-carousel__status.connecting .station-carousel__status-dot{background:var(--accent);animation:pulse 1s infinite}.station-carousel__gradient-left,.station-carousel__gradient-right{position:absolute;top:0;bottom:0;width:60px;pointer-events:none;z-index:1}.station-carousel__gradient-left{left:0;background:linear-gradient(90deg,var(--bg-primary) 0%,transparent 100%)}.station-carousel__gradient-right{right:0;background:linear-gradient(270deg,var(--bg-primary) 0%,transparent 100%)}.album-cover-display{position:relative;width:100%;max-width:400px;margin:0 auto;aspect-ratio:1;border-radius:var(--radius-2xl);overflow:hidden;background:var(--bg-card);border:1px solid var(--border-subtle)}.album-cover-display__art{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent) 0%,rgba(var(--accent-rgb),.3) 100%);position:relative}.album-cover-display__art-icon{font-size:120px;color:#ffffffe6;text-shadow:0 4px 20px rgba(0,0,0,.3)}.album-cover-display__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.6) 100%)}.album-cover-display__info{position:absolute;bottom:0;left:0;right:0;padding:var(--space-6);color:#fff}.album-cover-display__title{font-size:var(--text-xl);font-weight:var(--weight-bold);margin-bottom:var(--space-1)}.album-cover-display__artist{font-size:var(--text-base);opacity:.9}.stop-play-button{position:fixed;bottom:var(--space-8);right:var(--space-8);width:64px;height:64px;border-radius:50%;background:var(--accent);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #0000004d;transition:all var(--duration-normal) var(--ease-out);z-index:var(--z-overlay)}.stop-play-button:hover{transform:scale(1.1);box-shadow:0 6px 30px #0006}.stop-play-button:active{transform:scale(.95)}.stop-play-button__icon{width:24px;height:24px;fill:#fff}.stop-play-button.muted{background:var(--bg-card);border:2px solid var(--border-medium)}.stop-play-button.muted .stop-play-button__icon{fill:var(--text-secondary)}.geo-background{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.geo-background__canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.geo-background__shape{position:absolute;border:1px solid var(--border-subtle);opacity:.1;animation:geoFloat 20s ease-in-out infinite}.geo-background__shape:nth-child(1){width:300px;height:300px;top:10%;left:10%;border-radius:30% 70% 70% 30%/30% 30% 70% 70%;animation-delay:0s}.geo-background__shape:nth-child(2){width:200px;height:200px;top:60%;right:15%;border-radius:50%;animation-delay:-5s}.geo-background__shape:nth-child(3){width:150px;height:150px;bottom:20%;left:20%;border-radius:0;transform:rotate(45deg);animation-delay:-10s}.geo-background__shape:nth-child(4){width:250px;height:250px;top:30%;right:30%;border-radius:60% 40% 30% 70%/60% 30% 70% 40%;animation-delay:-15s}@keyframes geoFloat{0%,to{transform:translate(0) rotate(0)}25%{transform:translate(20px,-20px) rotate(5deg)}50%{transform:translate(-10px,20px) rotate(-5deg)}75%{transform:translate(-20px,-10px) rotate(3deg)}}.app-container{display:flex;flex-direction:column;min-height:100vh;position:relative;z-index:var(--z-base)}.app-header{padding:var(--space-4) var(--space-6);background:#0a0a0fd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:var(--z-overlay)}.station-tabs{display:flex;align-items:center;justify-content:center;gap:var(--space-2);max-width:600px;margin:0 auto}.station-tabs__container{display:flex;align-items:center;gap:var(--space-1);flex:1;overflow-x:auto;padding:var(--space-1);scrollbar-width:none;-ms-overflow-style:none}.station-tabs__container::-webkit-scrollbar{display:none}.station-tab{padding:var(--space-3) var(--space-5);background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--weight-medium);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);white-space:nowrap}.station-tab:hover{color:var(--text-primary)}.station-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.station-tabs__info{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-glass);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);flex-shrink:0}.station-tabs__info:hover{background:var(--bg-glass-hover);color:var(--text-primary);border-color:var(--accent)}.app-main{flex:1;display:flex;flex-direction:column;align-items:center;padding:var(--space-8) var(--space-6);padding-bottom:180px;overflow-y:auto}.album-display-section{width:100%;display:flex;flex-direction:column;align-items:center;opacity:0;transform:translateY(20px);transition:all var(--duration-slow) var(--ease-out)}.album-display-section.visible{opacity:1;transform:translateY(0)}.album-display{display:flex;flex-direction:column;align-items:center;text-align:center}.album-display__artwork{width:280px;height:280px;border-radius:var(--radius-2xl);background:linear-gradient(135deg,var(--station-color, var(--accent)) 0%,rgba(var(--station-color-rgb, 0, 229, 255),.3) 100%);box-shadow:0 20px 60px rgba(var(--station-color-rgb, 0, 229, 255),.2),0 8px 32px #0006;display:flex;align-items:center;justify-content:center;position:relative;transition:all var(--duration-normal) var(--ease-out)}.album-display__artwork:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:inherit;background:linear-gradient(135deg,var(--accent),transparent);opacity:.3;z-index:-1}.album-display__artwork.changing{transform:scale(.95);opacity:.7}.album-display__artwork-inner{font-size:80px;color:#ffffffe6;text-shadow:0 4px 20px rgba(0,0,0,.3)}.album-display__info{margin-top:var(--space-6);max-width:400px}.album-display__title{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-2);line-height:1.3}.album-display__artist{font-size:var(--text-base);color:var(--text-secondary);margin-bottom:var(--space-2)}.album-display__meta{font-size:var(--text-sm);color:var(--accent);font-weight:var(--weight-medium);display:none}.voting-section{width:100%;max-width:500px;margin-top:var(--space-8)}.voting-cards{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-5);opacity:0;transform:translateY(10px);transition:all var(--duration-normal) var(--ease-out)}.voting-cards.visible{opacity:1;transform:translateY(0)}.voting-cards.active{border-color:var(--accent-dim)}.voting-cards__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.voting-cards__title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary)}.voting-cards__countdown{font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--accent);font-variant-numeric:tabular-nums}.voting-cards__countdown--urgent{color:#ef4444;animation:countdownPulse .5s ease-in-out infinite}.voting-cards__options{display:flex;flex-direction:column;gap:var(--space-3)}.voting-cards__empty{text-align:center;padding:var(--space-6) var(--space-4)}.voting-cards__empty-text{font-size:var(--text-sm);color:var(--text-secondary);margin-bottom:var(--space-1)}.voting-cards__empty-sub{font-size:var(--text-xs);color:var(--text-muted)}.voting-card{position:relative;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:var(--space-4);display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-3);align-items:center;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.voting-card:hover{background:var(--bg-glass-hover);border-color:var(--border-medium)}.voting-card--selected{border-color:var(--accent);background:#9c27b01a}.voting-card--voted{cursor:default}.voting-card--winner{border-color:#22c55e;background:#22c55e1a;animation:celebrate .6s ease}.voting-card--loser{opacity:.4}@keyframes celebrate{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.voting-card__number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:var(--text-primary);border-radius:50%;font-weight:var(--weight-bold);font-size:var(--text-xs)}.voting-card__info{min-width:0}.voting-card__artist{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voting-card__stats{text-align:right}.voting-card__percent{font-size:var(--text-sm);font-weight:var(--weight-bold);color:var(--accent)}.voting-card__count{font-size:var(--text-xs);color:var(--text-muted)}.voting-card__progress{position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--border-subtle);border-radius:0 0 var(--radius-md) var(--radius-md);overflow:hidden}.voting-card__progress-fill{height:100%;background:var(--accent);width:0%;transition:width .3s ease-out}.app-footer{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-player);background:#0a0a0ff2;backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-top:1px solid var(--border-subtle)}.player-controls{transform:translateY(100%);transition:transform var(--duration-slow) var(--ease-out)}.player-controls.visible{transform:translateY(0)}.player-controls__progress{position:relative;height:4px;background:#ffffff0d}.player-controls__progress-bar{position:relative;height:100%;cursor:pointer}.player-controls__progress-fill{height:100%;background:var(--accent);width:0%;transition:width .1s linear}.player-controls__progress-thumb{position:absolute;top:50%;width:12px;height:12px;background:var(--text-primary);border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 8px #0006;pointer-events:none}.player-controls__time{position:absolute;top:8px;right:var(--space-6);display:flex;gap:var(--space-1);font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-muted)}.player-controls__main{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);max-width:1200px;margin:0 auto}.player-controls__left{display:flex;align-items:center;gap:var(--space-4)}.player-controls__station{font-size:var(--text-xs);font-weight:var(--weight-semibold);text-transform:uppercase;letter-spacing:.1em;color:var(--accent)}.player-controls__live{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:#ff17441f;border:1px solid rgba(255,23,68,.3);font-size:var(--text-xs);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.12em;color:#ff1744}.player-controls__live-dot{width:6px;height:6px;border-radius:50%;background:#ff1744;animation:livePulse 1.5s ease-in-out infinite}.player-controls__center{display:flex;align-items:center;gap:var(--space-4)}.player-controls__btn{width:44px;height:44px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;background:var(--bg-glass);border:1px solid var(--border-subtle);color:var(--text-primary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.player-controls__btn:hover:not(:disabled){background:var(--bg-glass-hover);transform:scale(1.05)}.player-controls__btn:disabled{opacity:.3;cursor:not-allowed}.player-controls__btn--play{width:56px;height:56px;background:var(--accent);border-color:var(--accent)}.player-controls__btn--play:hover:not(:disabled){background:var(--accent);opacity:.9;transform:scale(1.08)}.player-controls__btn.muted{background:var(--bg-card);border-color:var(--border-medium)}.player-controls__right{display:flex;align-items:center;gap:var(--space-4)}.player-controls__volume{display:flex;align-items:center;gap:var(--space-2)}.player-controls__volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:80px;height:4px;border-radius:2px;background:var(--bg-glass);outline:none}.player-controls__volume-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;transition:transform var(--duration-fast) var(--ease-out)}.player-controls__volume-slider::-webkit-slider-thumb:hover{transform:scale(1.3)}@media(max-width:768px){.album-display__artwork{width:220px;height:220px}.album-display__title{font-size:var(--text-lg)}.player-controls__main{padding:var(--space-3) var(--space-4)}.player-controls__btn{width:40px;height:40px}.player-controls__btn--play{width:48px;height:48px}.player-controls__volume,.player-controls__time{display:none}.voting-card{grid-template-columns:1fr;gap:var(--space-2)}.voting-card__stats{display:none}}@media(max-width:480px){.album-display__artwork{width:180px;height:180px}.album-display__artwork-inner{font-size:60px}.station-tab{padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}}.bg-visualizer{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;pointer-events:none}.bg-visualizer__canvas{width:100%;height:100%}.app-layout{display:flex;min-height:100vh}.app-layout__main{flex:1;display:flex;flex-direction:column;min-width:0}.app-layout__sidebar{width:320px;flex-shrink:0;border-left:1px solid var(--border-subtle);background:#00000080;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);overflow-y:auto;padding:var(--space-6)}.track-history{display:flex;flex-direction:column;gap:var(--space-8)}.track-history__section{display:flex;flex-direction:column;gap:var(--space-4)}.track-history__title{font-size:var(--text-xs);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.track-history__empty{font-size:var(--text-sm);color:var(--text-muted);text-align:center;padding:var(--space-4)}.track-history-item{display:flex;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-md);background:#ffffff05;border:1px solid var(--border-subtle);transition:all .2s var(--ease-out)}.track-history-item--current{background:#ffffff0d;border-color:var(--accent)}.track-history-item--next{opacity:.7}.track-history-item--played{opacity:.5}.track-history-item__artwork{position:relative;width:48px;height:48px;border-radius:var(--radius-sm);overflow:hidden;background:#ffffff08;flex-shrink:0}.track-history-item__image{width:100%;height:100%;object-fit:cover;filter:grayscale(100%)}.track-history-item__playing-indicator{position:absolute;bottom:4px;right:4px;display:flex;gap:2px;align-items:flex-end;padding:2px;background:#000c;border-radius:2px}.track-history-item__playing-indicator span{width:2px;background:var(--accent);animation:equalizerBar .8s ease-in-out infinite}.track-history-item__playing-indicator span:nth-child(1){height:6px;animation-delay:0s}.track-history-item__playing-indicator span:nth-child(2){height:10px;animation-delay:.2s}.track-history-item__playing-indicator span:nth-child(3){height:4px;animation-delay:.4s}.track-history-item__info{display:flex;flex-direction:column;gap:2px;min-width:0}.track-history-item__title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-history-item__artist{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hero-section{display:flex;flex-direction:column;align-items:center;padding:var(--space-8) var(--space-6);text-align:center}.hero-section__artwork-inner{width:280px;height:280px;border-radius:var(--radius-lg);background:#ffffff05;display:flex;align-items:center;justify-content:center;font-size:60px;color:#ffffff1a;border:1px solid var(--border-subtle)}.hero-artwork__station{font-size:var(--text-xs);color:var(--accent);text-transform:uppercase;letter-spacing:.1em;margin-top:var(--space-1)}.hero-artwork__image,.station-card__image,.glass-player__artwork-image,.voting-card__image{filter:grayscale(100%)}.station-card__playing-dot{background:var(--accent)}.glass-player{background:#000000e6;border-top:1px solid var(--border-subtle)}.glass-player__btn--play{background:var(--text-primary);color:var(--bg-primary)}.glass-player__btn--play:hover{background:var(--text-secondary);box-shadow:0 4px 12px #fff3}.voting-card--selected{background:#ffffff14;border-color:var(--accent)}.voting-card--winner{background:#ffffff14;border-color:var(--text-primary)}.voting-card__bar-fill{background:var(--accent)}@media(max-width:1024px){.app-layout{flex-direction:column}.app-layout__sidebar{width:100%;border-left:none;border-top:1px solid var(--border-subtle);max-height:300px}}@media(max-width:768px){.hero-section__artwork-inner,.hero-artwork__image{width:220px;height:220px}.app-layout__sidebar{display:none}}.app-background{position:fixed;top:0;left:0;width:100%;height:100%;z-index:-1;pointer-events:none}.app-background__blur{position:absolute;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;filter:blur(80px);opacity:.3;transition:background .8s var(--ease-out),opacity .8s var(--ease-out)}.app-background__overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(180deg,#0a0a0fcc,#0a0a0ff2)}.app-container{position:relative;display:flex;flex-direction:column;min-height:100vh;padding-bottom:120px}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:#0a0a0f99;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.05);position:sticky;top:0;z-index:100}.app-header__logo{display:flex;align-items:center;gap:var(--space-2)}.app-header__logo-icon{font-size:24px;color:var(--accent)}.app-header__logo-text{font-size:var(--text-lg);font-weight:var(--weight-black);letter-spacing:-.02em;color:var(--text-primary)}.app-header__live{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);background:#ff3b301a;font-size:var(--text-xs);font-weight:var(--weight-semibold);color:#ff3b30;text-transform:uppercase;letter-spacing:.1em}.app-header__live-dot{width:6px;height:6px;border-radius:50%;background:#ff3b30;animation:livePulse 2s var(--ease-out) infinite}.app-main{flex:1;padding:var(--space-6);overflow-y:auto;overflow-x:hidden}.hero-section{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-8) 0;margin-bottom:var(--space-8)}.hero-section__artwork{margin-bottom:var(--space-6)}.hero-section__artwork-inner{width:300px;height:300px;border-radius:var(--radius-xl);background:#ffffff08;display:flex;align-items:center;justify-content:center;font-size:80px;color:#fff3;border:1px solid rgba(255,255,255,.05);transition:all .4s var(--ease-out)}.hero-section__info{max-width:400px}.hero-section__title{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-2)}.hero-section__artist{font-size:var(--text-md);color:var(--text-muted)}.hero-artwork{display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.hero-artwork__container{position:relative}.hero-artwork__image{width:300px;height:300px;border-radius:var(--radius-xl);object-fit:cover;transition:opacity .3s var(--ease-out);box-shadow:0 20px 50px #00000080}.hero-artwork__shadow{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);width:80%;height:40px;background:radial-gradient(ellipse,rgba(0,0,0,.6) 0%,transparent 70%);filter:blur(15px);z-index:-1}.hero-artwork__info{text-align:center;max-width:400px}.hero-artwork__track{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text-primary);margin-bottom:var(--space-1);line-height:1.2}.hero-artwork__artist{font-size:var(--text-lg);color:var(--text-muted)}.station-section{margin-bottom:var(--space-10)}.station-section__title{font-size:var(--text-sm);font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:var(--space-4)}.station-grid{position:relative;margin:0 calc(var(--space-6) * -1);padding:0 var(--space-6)}.station-grid__scroll{display:flex;gap:var(--space-4);overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding-bottom:var(--space-3);-webkit-overflow-scrolling:touch}.station-grid__scroll::-webkit-scrollbar{height:4px}.station-grid__scroll::-webkit-scrollbar-track{background:#ffffff05;border-radius:2px}.station-grid__scroll::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.station-card{flex:0 0 160px;display:flex;flex-direction:column;gap:var(--space-2);scroll-snap-align:start;background:none;border:none;padding:0;cursor:pointer;transition:transform .2s var(--ease-out)}.station-card:hover{transform:scale(1.05)}.station-card:active{transform:scale(.98)}.station-card__artwork{position:relative;width:160px;height:160px;border-radius:var(--radius-lg);overflow:hidden;background:#ffffff08}.station-card__image{width:100%;height:100%;object-fit:cover;transition:transform .3s var(--ease-out)}.station-card:hover .station-card__image{transform:scale(1.1)}.station-card--active .station-card__artwork{box-shadow:0 0 0 2px var(--accent)}.station-card__playing{position:absolute;bottom:var(--space-2);right:var(--space-2);display:flex;gap:2px;align-items:flex-end;padding:var(--space-1);background:#000000b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-sm)}.station-card__playing-dot{width:3px;background:var(--accent);animation:equalizerBar .8s ease-in-out infinite}.station-card__playing-dot:nth-child(1){height:8px;animation-delay:0s}.station-card__playing-dot:nth-child(2){height:12px;animation-delay:.2s}.station-card__playing-dot:nth-child(3){height:6px;animation-delay:.4s}.station-card__connecting-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.station-card__spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.station-card__info{display:flex;flex-direction:column;gap:2px}.station-card__name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.station-card__genre{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voting-section-wrapper{margin-top:var(--space-8)}.voting-section__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-10) var(--space-6);background:#ffffff05;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.05)}.voting-section__empty-icon{font-size:48px;margin-bottom:var(--space-3);opacity:.3}.voting-section__empty-text{font-size:var(--text-md);color:var(--text-muted)}.voting-section{background:#ffffff08;border-radius:var(--radius-lg);padding:var(--space-6);border:1px solid rgba(255,255,255,.05);opacity:0;transform:translateY(20px);transition:opacity .3s var(--ease-out),transform .3s var(--ease-out)}.voting-section--active{opacity:1;transform:translateY(0)}.voting-section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4)}.voting-section__title{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--text-primary)}.voting-section__timer{font-size:var(--text-md);font-weight:var(--weight-semibold);color:var(--accent);font-variant-numeric:tabular-nums}.voting-section__winner-badge{padding:var(--space-1) var(--space-3);background:#4cd96433;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-bold);color:#4cd964;text-transform:uppercase;letter-spacing:.1em}.voting-section__options{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}.voting-card{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:#ffffff0d;border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-md);cursor:pointer;transition:all .2s var(--ease-out)}.voting-card:hover{background:#ffffff14;border-color:#ffffff1a;transform:translateY(-2px)}.voting-card--selected{background:rgba(var(--accent-rgb, 147, 51, 234),.15);border-color:var(--accent)}.voting-card--winner{background:#4cd96426;border-color:#4cd964;cursor:default}.voting-card--winner:hover{transform:none}.voting-card__artwork{width:100%;aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;background:#0000004d}.voting-card__image{width:100%;height:100%;object-fit:cover}.voting-card__info{display:flex;flex-direction:column;gap:2px}.voting-card__title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voting-card__artist{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.voting-card__votes{display:flex;align-items:center;gap:var(--space-2)}.voting-card__bar{flex:1;height:4px;background:#ffffff1a;border-radius:2px;overflow:hidden}.voting-card__bar-fill{height:100%;background:var(--accent);transition:width .3s var(--ease-out)}.voting-card__percentage{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);min-width:35px;text-align:right;font-variant-numeric:tabular-nums}.voting-card__badge{position:absolute;top:var(--space-2);right:var(--space-2);width:32px;height:32px;border-radius:50%;background:#4cd964e6;display:flex;align-items:center;justify-content:center;color:#fff}.glass-player{position:fixed;bottom:0;left:0;right:0;z-index:200;background:#1e1e23d9;backdrop-filter:blur(40px) saturate(180%);-webkit-backdrop-filter:blur(40px) saturate(180%);border-top:1px solid rgba(255,255,255,.1);transform:translateY(100%);transition:transform .4s var(--ease-out)}.glass-player--visible{transform:translateY(0)}.glass-player__content{display:flex;align-items:center;gap:var(--space-6);padding:var(--space-4) var(--space-6);max-width:1200px;margin:0 auto}.glass-player__track{flex:0 0 300px;display:flex;align-items:center;gap:var(--space-3)}.glass-player__artwork{width:56px;height:56px;border-radius:var(--radius-sm);overflow:hidden;background:#ffffff0d;flex-shrink:0}.glass-player__artwork-image{width:100%;height:100%;object-fit:cover}.glass-player__info{display:flex;flex-direction:column;gap:2px;min-width:0}.glass-player__title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.glass-player__artist{font-size:var(--text-xs);color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.glass-player__controls{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-4)}.glass-player__btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:none;color:var(--text-primary);cursor:pointer;transition:all .2s var(--ease-out)}.glass-player__btn:hover{background:#ffffff1a;transform:scale(1.1)}.glass-player__btn:active{transform:scale(.95)}.glass-player__btn--secondary{opacity:.7}.glass-player__btn--secondary:hover{opacity:1}.glass-player__btn--play{width:48px;height:48px;background:var(--accent);color:#fff}.glass-player__btn--play:hover{background:var(--accent);transform:scale(1.1);box-shadow:0 4px 12px rgba(var(--accent-rgb, 147, 51, 234),.4)}.glass-player__volume{flex:0 0 200px;display:flex;align-items:center;gap:var(--space-2)}.glass-player__btn--volume{width:32px;height:32px}.glass-player__volume-slider{flex:1}.glass-player__volume-slider input[type=range]{width:100%;height:4px;border-radius:2px;background:#ffffff1a;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.glass-player__volume-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer;transition:transform .2s var(--ease-out)}.glass-player__volume-slider input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.3)}.glass-player__volume-slider input[type=range]::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:#fff;cursor:pointer;border:none;transition:transform .2s var(--ease-out)}.glass-player__volume-slider input[type=range]::-moz-range-thumb:hover{transform:scale(1.3)}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-primary);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-6);z-index:9999;transition:opacity .5s var(--ease-out)}.loading-screen.hidden{opacity:0;pointer-events:none}.loading-screen__logo{font-size:var(--text-3xl);font-weight:var(--weight-black);letter-spacing:-.02em;color:var(--text-primary)}.loading-screen__spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@media(max-width:768px){.app-main{padding:var(--space-4)}.hero-section{padding:var(--space-6) 0}.hero-artwork__image,.hero-section__artwork-inner{width:240px;height:240px}.hero-artwork__track,.hero-section__title{font-size:var(--text-xl)}.station-grid{margin:0 calc(var(--space-4) * -1);padding:0 var(--space-4)}.station-card{flex:0 0 140px}.station-card__artwork{width:140px;height:140px}.voting-section__options{grid-template-columns:1fr}.glass-player__content{flex-wrap:wrap;gap:var(--space-3);padding:var(--space-3) var(--space-4)}.glass-player__track{flex:1 1 100%}.glass-player__controls{flex:1 1 auto}.glass-player__volume{flex:0 0 auto;width:120px}}@media(max-width:480px){.hero-artwork__image,.hero-section__artwork-inner{width:200px;height:200px}.station-card{flex:0 0 120px}.station-card__artwork{width:120px;height:120px}.glass-player__volume{display:none}.glass-player__btn{width:36px;height:36px}.glass-player__btn--play{width:44px;height:44px}}
