/* ===== VARIÁVEIS E BASE ===== */
:root {
    --font-family: 'Space Grotesk', sans-serif;
    --font-size-base: 16px;
    --transition-fast: 0.2s ease;
    --transition-medium: 0.4s cubic-bezier(0.25, 1, 0.5, 1);
    --transition-slow: 1.5s ease-in-out;
    --border-radius-large: 24px;
    --border-radius-medium: 12px;
    --border-radius-small: 8px;
}

/* TEMA DARK (PADRÃO) */
body.dark-theme {
    --text-primary: #f0f0f5; --text-secondary: #a0a0b8;
    --bg-primary: #0d0c1d; --bg-secondary: #171629;
    --surface-primary: rgba(36, 34, 61, 0.4); --surface-hover: rgba(55, 52, 92, 0.6);
    --stroke-primary: rgba(100, 100, 120, 0.2); --accent-primary: #c026d3; 
    --accent-secondary: #7c3aed; --accent-primary-glow: rgba(192, 38, 211, 0.6);
    --error-color: #f47174; --success-color: #34d399;
    --btn-bg: var(--accent-primary); --btn-shadow: 0 0 20px var(--accent-primary-glow); --btn-text: white;
}

/* TEMAS (light, golden, cherry) */
body.light-theme { --text-primary: #111827; --text-secondary: #4b5563; --bg-primary: #f4f5f7; --bg-secondary: #ffffff; --surface-primary: rgba(255, 255, 255, 0.4); --surface-hover: rgba(243, 244, 246, 0.8); --stroke-primary: #e5e7eb; --accent-primary: #a21caf; --accent-secondary: #6d28d9; --accent-primary-glow: rgba(162, 28, 175, 0.6); --error-color: #ef4444; --success-color: #10b981; --btn-bg: var(--accent-primary); --btn-shadow: 0 5px 15px var(--accent-primary-glow); --btn-text: white; }
body.golden-theme { --text-primary: #f0e5d1; --text-secondary: #c7bba8; --bg-primary: #1a1611; --bg-secondary: #2c251e; --surface-primary: rgba(50, 42, 32, 0.4); --surface-hover: rgba(80, 68, 54, 0.6); --stroke-primary: rgba(160, 140, 110, 0.2); --accent-primary: #d4af37; --accent-secondary: #b99830; --accent-primary-glow: rgba(212, 175, 55, 0.5); --error-color: #f47174; --success-color: #34d399; --btn-bg: linear-gradient(145deg, #f0e68c, #d4af37); --btn-shadow: inset 0 1px 1px rgba(255,255,255,0.3), inset 0 -1px 1px rgba(0,0,0,0.2), 0 0 20px var(--accent-primary-glow); --btn-text: var(--bg-primary); }
body.cherry-theme { --text-primary: #212121; --text-secondary: #5f5f5f; --bg-primary: #fdf6f7; --bg-secondary: #ffffff; --surface-primary: rgba(255, 255, 255, 0.5); --surface-hover: rgba(250, 235, 237, 0.8); --stroke-primary: #fce1e4; --accent-primary: #e11d48; --accent-secondary: #f43f5e; --accent-primary-glow: rgba(225, 29, 72, 0.4); --error-color: #ef4444; --success-color: #10b981; --btn-bg: var(--accent-primary); --btn-shadow: 0 5px 15px var(--accent-primary-glow); --btn-text: white; }

* { margin: 0; padding: 0; box-sizing: border-box; }
html { font-size: var(--font-size-base); }
body { background-color: var(--bg-primary); color: var(--text-primary); font-family: var(--font-family); display: flex; justify-content: center; align-items: center; height: 100vh; overflow: hidden; transition: background-color var(--transition-fast), color var(--transition-fast); }
body.font-size-small html { font-size: 14px; } 
body.font-size-medium html { font-size: 16px; } 
body.font-size-large html { font-size: 18px; }
body.animations-off * { transition: none !important; animation: none !important; }

/* ===== UTILIDADES E ANIMAÇÕES ===== */
.background-overlay { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(135deg, var(--accent-secondary) 0%, var(--accent-primary) 100%); opacity: 0.1; z-index: -1; filter: blur(100px); }
@keyframes fadeIn { from { opacity: 0; transform: scale(0.98); } to { opacity: 1; transform: scale(1); } }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes ken-burns { 0% { transform: scale(1.02) rotate(-1deg); } 100% { transform: scale(1.07) rotate(1deg); } }

/** NOVO: Animação de marquee "ping-pong" com pausas nas pontas **/
@keyframes elegantMarquee { 
    0%   { transform: translateX(0); }
    15%  { transform: translateX(0); } /* Pausa no início */
    45%  { transform: translateX(var(--marquee-distance)); } /* Desliza para o final */
    60%  { transform: translateX(var(--marquee-distance)); } /* Pausa no final */
    90%  { transform: translateX(0); } /* Desliza de volta para o início */
    100% { transform: translateX(0); } /* Pausa antes de repetir */
}

#preloader { position: fixed; inset: 0; background: var(--bg-primary); z-index: 100; display:flex; justify-content: center; align-items: center; transition: opacity 0.5s ease; }
.spinner { width: 40px; height: 40px; border: 4px solid var(--surface-hover); border-top-color: var(--accent-primary); border-radius: 50%; animation: spin 1s linear infinite; }

/* ===== LAYOUT PRINCIPAL ===== */
.radio-container { width: 100%; height: 100%; display: flex; flex-direction: column; overflow: hidden; background-color: transparent; animation: fadeIn 0.5s ease-in-out; }
.player-main { display: flex; flex: 1; overflow: hidden; position: relative; }
@keyframes error-flash { 0%, 100% { box-shadow: 0 0 0 0 transparent; } 50% { box-shadow: 0 0 15px 3px var(--error-color); } }
.player-main.error-flash { animation: error-flash 0.5s ease-out; }

/* ===== PLAYER LAYOUT: MOBILE FIRST ===== */
.player-content { display: flex; flex-direction: column; justify-content: space-between; align-items: center; width: 100%; height: 100%; padding: 1rem; position: relative; z-index: 5; }
.header-bar { width: 100%; display: flex; justify-content: space-between; align-items: center; }
.header-center { display: flex; flex-direction: column; align-items: center; gap: 0.5rem; }
.app-title { font-size: 1.1rem; font-weight: 700; letter-spacing: 4px; color: var(--text-secondary); }
.header-actions { display: flex; align-items: center; gap: 0.5rem; }
#infoBtn, #favoriteBtn { visibility: hidden; opacity: 0; transition: opacity 0.3s, visibility 0.3s; }
#infoBtn.visible, #favoriteBtn.visible { visibility: visible; opacity: 1; }
.header-right-controls { display: flex; gap: 0.5rem; }

#favoriteBtn.favorited i { color: var(--accent-primary); transform: scale(1.1); font-weight: 900; }

.album-art-container { position: relative; width: clamp(280px, 85vw, 400px); height: clamp(280px, 85vw, 400px); border-radius: var(--border-radius-medium); box-shadow: 0 10px 30px rgba(0,0,0,0.2); overflow: hidden; flex-shrink: 0; }
.album-art-overlay-content { position: absolute; inset: 0; z-index: 3; display: flex; flex-direction: column; justify-content: space-between; padding: 1.5rem; background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, transparent 50%, rgba(0,0,0,0.5) 100%); }
.track-info { text-align: left; overflow: hidden; width: 100%; }
.marquee-container { width: 100%; white-space: nowrap; overflow: hidden; }

/** ALTERADO: Aplica a nova animação de marquee com suavização **/
.marquee-container.marquee .marquee-span { 
    display: inline-block; 
    padding-right: 40px; /* Espaço para evitar corte abrupto */
    animation: elegantMarquee var(--marquee-duration, 15s) ease-in-out infinite;
}

.track-info h2 { font-size: 1.5rem; font-weight: 700; text-shadow: 0 1px 5px rgba(0,0,0,0.5); color: #fff; }
.track-info p { font-size: 1rem; color: #fff; opacity: 0.8; text-shadow: 0 1px 3px rgba(0,0,0,0.5); }
.now-playing-desktop { display: none; }

/* Elementos de Fundo da Arte */
.album-art-bg { position: absolute; inset: 0; width: 100%; height: 100%; background-size: cover; background-position: center; animation: ken-burns 40s ease-in-out infinite alternate; transition: opacity var(--transition-slow); will-change: opacity; }
#bgImage1 { z-index: 1; opacity: 1; }
#bgImage2 { z-index: 0; opacity: 0; }
#albumArtCanvas { z-index: 2; }
#particleCanvas { z-index: 3; }
.noise-overlay { z-index: 4; }
#albumArtCanvas, #particleCanvas, .noise-overlay, .feedback-overlay { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; }
.noise-overlay { opacity: 0.08; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E"); }
.feedback-overlay { z-index: 10; display: flex; justify-content: center; align-items: center; background: rgba(0,0,0,0.5); font-size: 5rem; color: var(--accent-primary); opacity: 0; visibility: hidden; transition: opacity 0.3s, visibility 0.3s; }
.feedback-overlay i { animation: spin 1.5s linear infinite; }
.contrast-scrim { display: none; }

/* Selo de Licença Simplificado */
.license-seal { position: absolute; bottom: 1rem; right: 1rem; z-index: 5; background-color: rgba(0,0,0,0.5); backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px); color: #fff; font-size: 0.65rem; padding: 3px 6px; border-radius: 4px; border: 1px solid rgba(255,255,255,0.1); font-weight: 500; opacity: 0; visibility: hidden; transition: opacity 0.5s, visibility 0.5s; pointer-events: none; }
.license-seal.visible { opacity: 0.7; visibility: visible; }

/* Rodapé do Player */
.player-footer { display: flex; flex-direction: column; align-items: center; gap: 1rem; width: 100%; max-width: 350px; padding-bottom: 1rem; }
#waveformCanvas { width: 100%; height: 40px; margin-bottom: 0.5rem; }
.volume-control { display: flex; align-items: center; gap: 1rem; width: 100%; }
.volume-control i { font-size: 24px; color: var(--text-secondary); }
#volumeSlider { -webkit-appearance: none; appearance: none; width: 100%; height: 5px; background-color: rgba(255,255,255,0.2); outline: none; border-radius: 5px; cursor: pointer; }
#volumeSlider::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 18px; height: 18px; background: var(--text-primary); border-radius: 50%; transition: background var(--transition-fast); }
#volumeSlider::-moz-range-thumb { width: 18px; height: 18px; background: var(--text-primary); border-radius: 50%; border: none; transition: background var(--transition-fast); }
#volumeSlider:hover::-webkit-slider-thumb, #volumeSlider:hover::-moz-range-thumb { background: var(--accent-primary); }
.controls { display: flex; align-items: center; justify-content: center; gap: 1.5rem; }
.control-button { background: none; border: none; color: var(--text-secondary); cursor: pointer; transition: color var(--transition-fast), transform var(--transition-fast); }
.control-button:hover { color: var(--text-primary); } .control-button:active { transform: scale(0.9); }
.control-button i { font-size: 32px; filter: drop-shadow(0 1px 2px rgba(0,0,0,0.3)); }
.play-pause { background: var(--btn-bg); color: var(--btn-text); border-radius: 50%; width: 72px; height: 72px; display: grid; place-items: center; box-shadow: var(--btn-shadow); border: none; }
.play-pause:hover { transform: scale(1.05); } 
.play-pause i { font-size: 36px; grid-column: 1; grid-row: 1; transition: opacity 0.2s, transform 0.2s; }
.play-pause .ph-pause { opacity: 0; transform: scale(0.5); }
.play-pause.playing .ph-play { opacity: 0; transform: scale(0.5); }
.play-pause.playing .ph-pause { opacity: 1; transform: scale(1); }

/* LISTA DE ESTAÇÕES */
.station-list-panel { background: var(--surface-primary); backdrop-filter: blur(30px); -webkit-backdrop-filter: blur(30px); display: flex; flex-direction: column; border-top: 1px solid var(--stroke-primary); position: fixed; bottom: 0; left: 0; right: 0; height: calc(100% - 60px); top: 60px; transform: translateY(110%); transition: transform var(--transition-medium); z-index: 10; padding: 1rem; }
.station-list-panel.list-open { transform: translateY(0); }
.station-list-header { display: flex; justify-content: space-between; align-items: center; padding-bottom: 0.5rem; flex-shrink: 0; }
.station-list-header h3 { font-size: 1.2rem; }
.search-bar { display: flex; align-items: center; gap: 0.5rem; background-color: var(--surface-hover); border-radius: var(--border-radius-small); padding: 0.75rem 1rem; border: 1px solid var(--stroke-primary); flex-shrink: 0; }
.search-bar i { font-size: 20px; color: var(--text-secondary); }
#searchInput { background: none; border: none; outline: none; color: var(--text-primary); font-size: 1rem; width: 100%; }
.list-tabs { display: flex; gap: 0.5rem; padding: 0.75rem 0; flex-shrink: 0; border-bottom: 1px solid var(--stroke-primary); margin-bottom: 0.5rem;}
.tab-btn { flex: 1; background: none; border: none; padding: 0.75rem; font-size: 1rem; font-weight: 500; font-family: var(--font-family); color: var(--text-secondary); cursor: pointer; border-radius: var(--border-radius-small); transition: background-color var(--transition-fast), color var(--transition-fast); }
.tab-btn.active { background-color: var(--surface-hover); color: var(--text-primary); }
.station-list-wrapper { flex: 1; overflow-y: auto; scrollbar-width: thin; scrollbar-color: var(--surface-hover) transparent; padding-right: 8px; min-height: 0; }
.category-header { font-size: 0.9rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-secondary); padding: 1.5rem 0.5rem 0.5rem; }
.station-item { display: flex; align-items: center; gap: 1rem; padding: 0.75rem; border-radius: var(--border-radius-small); cursor: pointer; transition: background-color var(--transition-fast), border-color var(--transition-fast); border: 1px solid transparent; }
.station-item:hover { background-color: var(--surface-hover); }
.station-item.active { background-color: var(--accent-primary); color: var(--btn-text) !important; border-color: var(--accent-primary-glow); }
.station-item.active p { color: var(--btn-text) !important; opacity: 0.8; }

/** NOVO: Estilização avançada para a arte da estação na lista **/
.station-art {
    width: 48px;
    height: 48px;
    border-radius: 6px;
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
    background-color: var(--surface-hover);
    /* `isolation` evita que o blend-mode afete elementos fora deste container */
    isolation: isolate;
}

/* CAMADA 1 (INFERIOR): A imagem em escala de cinza */
.station-art::before {
    content: '';
    position: absolute;
    inset: 0;
    /* A URL da imagem é passada pela variável CSS do JavaScript */
    background-image: var(--station-thumbnail-url);
    background-size: cover;
    background-position: center;
    /* O filtro é aplicado diretamente nesta camada, sem afetar as outras */
    filter: grayscale(1) contrast(1.1);
}

/* CAMADA 2 (SUPERIOR): A cor + blend mode */
.station-art::after {
    content: '';
    position: absolute;
    inset: 0;
    /* Fundo com o gradiente de cor da estação */
    background: linear-gradient(135deg, 
        var(--station-color1, var(--accent-primary)), 
        var(--station-color2, var(--accent-secondary))
    );
    /* 'mix-blend-mode: color' aplica a cor do gradiente na luminosidade da imagem abaixo */
    mix-blend-mode: color;
    opacity: 0.85;
}

.station-info { flex-grow: 1; min-width: 0; }
.station-info h3 { font-size: 1rem; font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.station-info p { font-size: 0.875rem; color: var(--text-secondary); }
.station-actions { display: flex; align-items: center; gap: 0.5rem; }
.station-status-container { width: 24px; display: flex; justify-content: center; align-items: center; }
.station-status { width: 8px; height: 8px; border-radius: 50%; background-color: transparent; border: 2px solid var(--text-secondary); transition: border-color var(--transition-fast), background-color var(--transition-fast), box-shadow var(--transition-fast); }
.station-item.active .station-status { border-color: var(--btn-text); }
.station-item .station-favorite-btn i { color: var(--text-secondary); }
.station-item:hover .station-favorite-btn i { color: var(--text-primary); }
.station-item.favorited .station-favorite-btn i { font-weight: 900; color: var(--accent-primary); }
@keyframes pulse { 0%, 100% { transform: scale(1); box-shadow: 0 0 5px var(--accent-primary-glow); } 50% { transform: scale(1.4); box-shadow: 0 0 12px var(--accent-primary-glow); } }
.station-status.loading { border-color: transparent; background-color: var(--accent-primary); animation: pulse 1.5s infinite; }
.no-results { text-align: center; color: var(--text-secondary); padding: 2rem; }
.favorite-track-item { display: flex; align-items: center; gap: 1rem; padding: 0.75rem; border-radius: var(--border-radius-small); cursor: pointer; transition: background-color var(--transition-fast); }
.favorite-track-item:hover { background-color: var(--surface-hover); }
.favorite-track-info { flex-grow: 1; min-width: 0; }
.favorite-track-info h3 { font-size: 1rem; font-weight: 500; }
.favorite-track-info p { font-size: 0.875rem; color: var(--text-secondary); }
.favorite-track-item .play-fav-btn i { font-size: 24px; color: var(--text-secondary); }
.favorite-track-item:hover .play-fav-btn i { color: var(--accent-primary); }

/* MODAIS (Configurações e Info) */
.modal-overlay { position: fixed; inset: 0; background: rgba(10, 10, 20, 0.6); display: none; justify-content: center; align-items: center; z-index: 50; opacity: 0; transition: opacity var(--transition-fast); backdrop-filter: blur(10px); }
.modal-overlay.visible { display: flex; opacity: 1; }
.modal-content { background: var(--surface-primary); backdrop-filter: blur(30px); -webkit-backdrop-filter: blur(30px); border: 1px solid var(--stroke-primary); border-radius: var(--border-radius-large); padding: 1.5rem; width: 95vw; max-width: 500px; max-height: 90vh; transform: scale(0.95); transition: transform var(--transition-medium); display: flex; flex-direction: column; }
.modal-overlay.visible .modal-content { transform: scale(1); }
.modal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1.5rem; }
.modal-header h2 { font-size: 1.5rem; }
.modal-body { flex: 1; overflow-y: auto; padding-right: 0.5rem; scrollbar-width: thin; scrollbar-color: var(--surface-hover) transparent; }
.info-item { padding: 0.75rem 0; font-size: 0.9rem; border-bottom: 1px solid var(--stroke-primary); }
.info-item:last-child { border-bottom: none; }
.info-item strong { color: var(--text-secondary); display: block; margin-bottom: 0.25rem; font-weight: 500;}
.info-item span, .info-item a { word-break: break-word; color: var(--text-primary); }
.info-item a { text-decoration: none; color: var(--accent-primary); }
.info-item a:hover { text-decoration: underline; }


/* ÍCONES E BOTÕES */
.icon-button { position: relative; background: none; border: none; color: var(--text-secondary); cursor: pointer; padding: 0.5rem; transition: all var(--transition-fast); }
.icon-button:hover { color: var(--text-primary); transform: scale(1.1); }
.icon-button i { font-size: 24px; filter: drop-shadow(0 1px 2px rgba(0,0,0,0.3)); display: block; }
.icon-button .tooltip { visibility: hidden; background-color: var(--text-primary); color: var(--bg-primary); text-align: center; border-radius: 6px; padding: 5px 8px; position: absolute; z-index: 1; bottom: 125%; left: 50%; transform: translateX(-50%); opacity: 0; transition: opacity 0.3s; font-size: 0.8rem; white-space: nowrap; }
.icon-button:hover .tooltip { visibility: visible; opacity: 1; }
.header-bar .icon-button { background-color: rgba(0, 0, 0, 0.25); backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px); border-radius: 50%; color: var(--text-primary); }
.header-bar .icon-button:hover { background-color: rgba(0, 0, 0, 0.4); transform: scale(1.1); }

/* MODAL DE CONFIGURAÇÕES (Itens específicos) */
.setting-item { display: flex; justify-content: space-between; align-items: center; padding: 1rem 0; border-bottom: 1px solid var(--stroke-primary); }
.settings-subtitle { font-size: 0.9rem; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; color: var(--text-secondary); padding-top: 1.5rem; border-top: 1px solid var(--stroke-primary); margin-top: 1rem; }
.theme-selector { display: flex; gap: 0.75rem; }
.theme-swatch { width: 36px; height: 36px; border-radius: var(--border-radius-small); border: 2px solid var(--stroke-primary); cursor: pointer; transition: transform 0.2s, box-shadow 0.2s; position: relative; }
.theme-swatch:hover { transform: scale(1.1); }
.theme-swatch.active { border-color: var(--accent-primary); box-shadow: 0 0 10px var(--accent-primary-glow); }
.theme-swatch[data-theme="dark"] { background: linear-gradient(135deg, #0d0c1d, #171629); }
.theme-swatch[data-theme="light"] { background: linear-gradient(135deg, #f4f5f7, #ffffff); }
.theme-swatch[data-theme="golden"] { background: linear-gradient(135deg, #2c251e, #1a1611); }
.theme-swatch[data-theme="cherry"] { background: linear-gradient(135deg, #fdf6f7, #fce1e4); }
.custom-select { position: relative; width: 150px; }
.selected-option { background: var(--surface-hover); border: 1px solid var(--stroke-primary); border-radius: var(--border-radius-small); padding: 0.5rem 1rem; cursor: pointer; display: flex; justify-content: space-between; align-items: center; }
.options-list { list-style: none; position: absolute; top: calc(100% + 0.5rem); left: 0; right: 0; background: var(--bg-secondary); border: 1px solid var(--stroke-primary); border-radius: var(--border-radius-small); z-index: 60; max-height: 0; overflow: hidden; transition: max-height 0.3s ease, padding 0.3s ease, opacity 0.3s; opacity: 0; }
.custom-select.open .options-list { max-height: 200px; padding: 0.5rem 0; opacity: 1; }
.options-list li { padding: 0.5rem 1rem; cursor: pointer; }
.options-list li:hover { background-color: var(--surface-hover); }
.switch { position: relative; display: inline-block; width: 50px; height: 28px; }
.switch input { opacity: 0; width: 0; height: 0; }
.slider { position: absolute; cursor: pointer; inset: 0; background-color: var(--surface-hover); transition: .4s; border-radius: 28px; }
.slider:before { position: absolute; content: ""; height: 20px; width: 20px; left: 4px; bottom: 4px; background-color: white; transition: .4s; border-radius: 50%; }
input:checked + .slider { background-color: var(--accent-primary); }
input:checked + .slider:before { transform: translateX(22px); }
.shortcuts-list { display: flex; flex-direction: column; gap: 0.5rem; padding-top: 0.5rem; }
.shortcut-item { display: flex; justify-content: space-between; align-items: center; font-size: 0.9rem; }
kbd { background-color: var(--surface-hover); border: 1px solid var(--stroke-primary); border-radius: 4px; padding: 2px 6px; font-family: monospace; }

/* LAYOUT DESKTOP */
@media (min-width: 1024px) {
    #toggleListBtn { display: none; }
    .station-list-header { display: none; }
    .radio-container { display: grid; grid-template-columns: 1fr 420px; width: 90vw; max-width: 1400px; height: 90vh; max-height: 850px; border-radius: var(--border-radius-large); box-shadow: 0 20px 60px rgba(0,0,0,0.3); background: var(--surface-primary); border: 1px solid var(--stroke-primary); overflow: hidden; }
    .player-main { border-radius: var(--border-radius-large) 0 0 var(--border-radius-large); }
    .player-content { align-items: center; padding: 2rem; }
    .album-art-container { display: none; }
    .now-playing-desktop { display: flex; flex-grow: 1; flex-direction: column; justify-content: center; align-items: center; text-align: center; position: relative; width: 100%; }
    .now-playing-desktop .track-info { z-index: 5; width: 80%; }
    #stationName-desktop { font-size: 3rem; }
    #songInfo-desktop { font-size: 1.25rem; }
    .now-playing-desktop .marquee-container.marquee span { animation-duration: var(--marquee-duration, 20s); }
    .now-playing-desktop .license-seal { position: absolute; bottom: 2rem; right: 2rem; }
    .album-art-bg, #albumArtCanvas, #particleCanvas, .noise-overlay { border-radius: 0; }
    .contrast-scrim { display: block; position: absolute; inset: 0; z-index: 4; background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, transparent 60%); pointer-events: none; }
    #waveformCanvas { height: 50px; margin-bottom: 1.5rem; }
    .header-bar .icon-button, .controls .control-button:not(.play-pause) { background: rgba(255, 255, 255, 0.05); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border: 1px solid rgba(255, 255, 255, 0.1); border-radius: var(--border-radius-medium); color: var(--text-primary); padding: 0.75rem; }
    .header-bar .icon-button:hover, .controls .control-button:not(.play-pause):hover { background: rgba(255, 255, 255, 0.15); border-color: rgba(255, 255, 255, 0.2); }
    .volume-control { background: rgba(255, 255, 255, 0.05); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border: 1px solid rgba(255, 255, 255, 0.1); border-radius: var(--border-radius-medium); padding: 0.5rem 1rem; }
    .station-list-panel { position: static; transform: none; height: 100%; top: auto; border-radius: 0 var(--border-radius-large) var(--border-radius-large) 0; border: none; border-left: 1px solid var(--stroke-primary); background: transparent; backdrop-filter: none; -webkit-backdrop-filter: none; padding: 1rem; display: flex; flex-direction: column; overflow: hidden; }
    .station-list-wrapper { flex-grow: 1; min-height: 0; }
    .modal-content { max-height: 80vh; }
}