html { font-size: var(--font-size-desktop); }
[x-cloak] { display: none !important; }

:root {
    --color-pink-glow: #ff00de;
    --color-pink: #f0f;
    --color-cyan-glow: #00d9ff;
    --color-cyan: #0ff;
    --color-glass-border: rgba(255, 0, 222, 0.2);
    --color-glass-bg: rgba(23, 10, 41, 0.6);
}

/* Custom Synthwave Styles */
body {
    background: linear-gradient(to bottom, #1a0229 0%, #3b0764 100%);
    color: #e5e7eb; /* gray-200 */
}
@keyframes header-flicker {
    0%, 100% { opacity: 1; }
    20% { opacity: 0.2; text-shadow: none; }
    25% { opacity: 1; }
    40% { opacity: 0.5; text-shadow: none; }
    45% { opacity: 1; }
}
.neon-text-pink { text-shadow: 0 0 5px var(--color-pink), 0 0 10px var(--color-pink), 0 0 15px var(--color-pink), 0 0 20px var(--color-pink-glow); }
.neon-text-cyan { text-shadow: 0 0 5px var(--color-cyan), 0 0 10px var(--color-cyan), 0 0 15px var(--color-cyan), 0 0 20px var(--color-cyan-glow); }
@keyframes neon-startup-flicker {
    0% { border-color: #d946ef; box-shadow: 0 0 3px #d946ef; }
    15% { border-color: transparent; box-shadow: none; }
    30% { border-color: #d946ef; box-shadow: 0 0 3px #d946ef; }
    45% { border-color: transparent; box-shadow: none; }
    60% { border-color: #22d3ee; box-shadow: 0 0 10px #22d3ee; }
    100% { border-color: #22d3ee; box-shadow: 0 0 10px #22d3ee; }
}
.search-wrapper.flickering {
    animation: neon-startup-flicker 0.5s ease-out;
}
.search-wrapper.search-active,
.search-wrapper:focus-within {
    border-color: #22d3ee;
    box-shadow: 0 0 10px #22d3ee;
}
@keyframes welcome-fly-by {
    0% { transform: translateX(-110vw) skewX(-20deg); opacity: 0.1; }
    15% { transform: translateX(0) skewX(0deg); opacity: 1; }
    85% { transform: translateX(0) skewX(0deg); opacity: 1; }
    100% { transform: translateX(110vw) skewX(20deg); opacity: 0.1; }
}
.welcome-glow {
    color: #fff;
    text-shadow: 0 0 10px var(--color-pink), 0 0 20px var(--color-pink), 0 0 30px var(--color-pink), 0 0 40px var(--color-pink-glow), 0 0 70px var(--color-pink-glow), 0 0 80px var(--color-pink-glow), 0 0 100px var(--color-pink-glow);
}
.cover-glow { box-shadow: 0 0 35px 5px rgba(255, 0, 222, 0.5); }
.temporary-glow {
    box-shadow: 0 0 30px 10px rgba(255, 0, 222, 0.7);
    border-radius: 0.375rem;
    transition: box-shadow 0.5s ease-in-out;
}
@keyframes spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}
@keyframes loading-progress {
    from { background-size: 0% 100%; }
    to   { background-size: 100% 100%; }
}
.disc-spin {
    animation: spin 4s linear infinite;
}
body.modal-open .disc-spin {
    animation-play-state: paused;
}
.loading-spinner {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    border: 8px solid rgba(0, 217, 255, 0.2);
    border-top-color: var(--color-cyan-glow);
    animation: spin 1s ease-in-out infinite;
    box-shadow: 0 0 25px rgba(0, 217, 255, 0.6);
}
.glassmorphism { background-color: var(--color-glass-bg); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border: 1px solid var(--color-glass-border); }
.notification-toast { backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
.notification-info { background-color: rgba(0, 217, 255, 0.15); border: 1px solid var(--color-cyan-glow); box-shadow: 0 0 8px var(--color-cyan-glow); }
.notification-success { background-color: rgba(0, 255, 128, 0.15); border: 1px solid #00ff80; box-shadow: 0 0 8px #00ff80; }
.notification-warning { background-color: rgba(255, 255, 0, 0.15); border: 1px solid #ffff00; box-shadow: 0 0 8px #ffff00; }
.notification-error { background-color: rgba(255, 0, 0, 0.15); border: 1px solid #ff0000; box-shadow: 0 0 8px #ff0000; }
@keyframes animated-border {
    from { border-image-source: linear-gradient(to right, var(--color-pink-glow), var(--color-cyan-glow), var(--color-pink-glow)); }
    to { border-image-source: linear-gradient(to right, var(--color-cyan-glow), var(--color-pink-glow), var(--color-cyan-glow)); }
}
@keyframes flicker-in {
    0%   { opacity: 0; }
    10%  { opacity: 0; transform: scale(1.02); }
    12%  { opacity: 1; transform: scale(1); }
    20%  { opacity: 1; }
    22%  { opacity: 0; transform: scale(0.98); }
    24%  { opacity: 1; transform: scale(1); }
    40%  { opacity: 1; }
    42%  { opacity: 0; }
    44%  { opacity: 1; }
    100% { opacity: 1; }
}
footer.glassmorphism { background-color: rgba(23, 10, 41, 0.10); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); }
.table-hover tr:hover { background-color: rgba(0, 217, 255, 0.1); }
.active-song-row { background-color: rgba(0, 217, 255, 0.2) !important; color: #fff; }
.active-song-unlisted { color: #ffc980 !important; }
.preloading-song-row {
    position: relative;
    z-index: 0;
    background-color: rgba(107, 114, 128, 0.1) !important;
    color: #fff;
    background-image: linear-gradient(to right, rgba(6, 182, 212, 0.4), rgba(6, 182, 212, 0.4));
    background-repeat: no-repeat;
    animation: loading-progress 30s linear infinite;
}
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: #1f2937; }
::-webkit-scrollbar-thumb { background: var(--color-pink); border-radius: 8px; }
::-webkit-scrollbar-thumb:hover { background: var(--color-pink-glow); }
/* Custom range input styles */
input[type=range] { -webkit-appearance: none; appearance: none; background: transparent; cursor: pointer; }
input[type=range]::-webkit-slider-runnable-track { height: 8px; background: linear-gradient(to right, var(--color-cyan-glow) var(--progress, 0%), rgba(0, 217, 255, 0.2) var(--progress, 0%)); border-radius: 5px; }
input[type=range]::-moz-range-track { height: 8px; background: linear-gradient(to right, var(--color-cyan-glow) var(--progress, 0%), rgba(0, 217, 255, 0.2) var(--progress, 0%)); border-radius: 5px; }
input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; margin-top: -6px; background-color: var(--color-pink); height: 20px; width: 20px; border-radius: 50%; border: 2px solid var(--color-cyan-glow); box-shadow: 0 0 8px var(--color-pink); }
input[type=range]::-moz-range-thumb { border: none; border-radius: 50%; background-color: var(--color-pink); height: 20px; width: 20px; border-radius: 50%; border: 2px solid var(--color-cyan-glow); box-shadow: 0 0 8px var(--color-pink); }

/* Custom select dropdown styles */
.synth-select {
    -webkit-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%2300d9ff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");
    background-position: right 0.5rem center;
    background-repeat: no-repeat;
    background-size: 1.5em 1.5em;
    padding-right: 2.5rem;
}

.synth-select option {
    background: #1a0229;
    color: #e5e7eb;
}
/* Cover art shiny hover effect */
.cover-shiny-parent {
    position: relative;
    overflow: hidden;
}
.cover-shiny-parent::before {
    content: '';
    position: absolute;
    z-index: 2; /* Sit on top of the image */
    top: 0;
    left: -150%;
    width: 50%;
    height: 100%;
    background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 50%, rgba(255, 255, 255, 0) 100%);
    transform: skewX(-25deg);
    transition: left 0.8s ease-in-out;
}
.cover-shiny-parent:hover::before {
    left: 150%;
}
.sidebar-search-input { font-size: 0.9em; }
.sidebar-search-input::placeholder { color: #9ca3af; opacity: 0.7; }
@media (max-width: 799px) {
    html { font-size: var(--font-size-mobile); }
    .page-header { margin-bottom: 0 !important; }
    .header-title, .header-extra-buttons, .header-rating-label { display: none; }
    .header-filters-container { margin-top: 0 !important; }
    .header-filters-container > div:first-child { gap: 0.1rem !important; }
    .sidebars-container-wrapper {
        flex-direction: row !important;
        gap: 0.5rem !important;
    }
    .sidebar {
        flex: 1 1 50% !important;
        max-height: 40vh;
        min-height: 100px;
        padding: 0 0.5rem !important;
        min-width: 0;
    }
    .sidebar h2 { font-size: 1rem !important; margin-bottom: 0.125rem !important; }
    .sidebar ul { font-size: 0.9em; }
    .tracklist-col-album, .tracklist-col-genre, .tracklist-col-duration { display: none; }
    .tracklist-table th { font-size: 0.9rem !important; padding: 2px 4px !important; }
    .tracklist-table td { font-size: 0.85rem !important; padding: 2px 4px !important; }
    .lyrics-content { font-size: 0.9em; }
    .player-cover-art-mobile, .player-cover-art-desktop { display: none !important; }
    .desktop-player-info { padding-left: 1rem !important; }
    .footer-player { height: auto !important; }
    .table-hover tr:hover { background-color: transparent; }
    .sidebar h2:hover .neon-text-cyan { animation: none; }
}
.tracklist-header {
    background-color: rgba(23, 10, 41, 0.8);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
}
.tooltip {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    margin-bottom: 0.5rem;
    width: max-content;
    padding: 0.5rem 0.75rem;
    background-color: rgba(17, 24, 39, 0.8);
    border: 1px solid var(--color-glass-border);
    border-radius: 0.375rem;
    color: #e5e7eb;
    font-size: 0.875rem;
    white-space: nowrap;
    pointer-events: none;
    opacity: 0;
    transition-property: opacity;
    transition-duration: 300ms;
    z-index: 1000;
}
@media (hover: hover) {
    .group:hover .tooltip {
        opacity: 1;
    }
}
.slider-control {
    transition: filter 2s ease-out;
}
.slider-control.glowing-fuchsia {
    filter: drop-shadow(0 0 15px var(--color-pink)) drop-shadow(0 0 25px var(--color-pink));
    transition: filter 0.05s ease-out;
}
.slider-control.glowing-cyan {
    filter: drop-shadow(0 0 15px var(--color-cyan)) drop-shadow(0 0 25px var(--color-cyan));
    transition: filter 0.05s ease-out;
}
@keyframes speed-widget-appear {
    0%   { opacity: 0; box-shadow: 0 0 0 0 rgba(0, 217, 255, 0); transform: scale(0.8); }
    50%  { opacity: 1; box-shadow: 0 0 80px 40px rgba(0, 217, 255, 0.9); transform: scale(1.1); }
    100% { opacity: 1; box-shadow: 0 0 0 0 rgba(0, 217, 255, 0); transform: scale(1); }
}
.speed-widget-appear-animation {
    animation: speed-widget-appear 0.5s ease-out;
}
@keyframes speed-widget-disappear {
    0%   { opacity: 1; transform: scale(1); }
    50%  { opacity: 1; transform: scale(1.1); }
    100% { opacity: 0; transform: scale(0.8); }
}
.speed-widget-disappear-animation {
    animation: speed-widget-disappear 0.8s ease-in;
}

@keyframes song-clicked-pulse {
    0% { background-color: rgba(0, 217, 255, 0); }
    50% { background-color: rgba(0, 217, 255, 0.4); }
    100% { background-color: rgba(0, 217, 255, 0); }
}
tr.song-clicked-animation {
    animation: song-clicked-pulse 0.6s ease-out;
}

@keyframes jiggle {
    0%, 100% { transform: rotate(0); }
    25% { transform: rotate(-15deg); }
    50% { transform: rotate(15deg); }
    75% { transform: rotate(-10deg); }
}
.header-extra-buttons button:hover svg,
.footer-player button:hover svg {
    animation: jiggle 0.4s;
}

/* perfect effect of neon styled flickering turning on */
@keyframes sidebar-title-flicker {
    0%, 100% { opacity: 1; }
    5%  { opacity: 0.3; text-shadow: none; }
    20%  { opacity: 1; }
    30%  { opacity: 0.2; text-shadow: none; }
    90%  { opacity: 1; }
}
.sidebar h2:hover .neon-text-cyan {
    animation: sidebar-title-flicker 0.32s ease-out;
}

.sidebar.small-font-sidebar li {
    font-size: 80%;
}

.header-title {
    position: relative;
}

.header-title.flickering {
    animation: header-flicker 0.3s ease-in-out;
}
.header-title::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: -5px;
    height: 2px;
    background: linear-gradient(to right, transparent, var(--color-pink-glow) 20%, var(--color-pink-glow) 80%, transparent);
    filter: blur(4px);
}

footer.footer-player.is-playing {
    border-image-slice: 1;
    border-image-source: linear-gradient(to right, var(--color-pink-glow), var(--color-cyan-glow));
    animation: animated-border 2s linear infinite alternate;
}

.modal-content-host[x-show] .modal-content {
    animation: flicker-in 0.5s ease-out;
}

.lyrics-modal-glow {
    box-shadow: 0 0 10px rgba(217, 70, 239, 0.8),
                0 0 30px rgba(217, 70, 239, 0.6),
                0 0 60px rgba(217, 70, 239, 0.4);
}

.lyrics-modal-glow .neon-text-cyan {
    text-shadow: 0 0 5px var(--color-cyan), 0 0 10px var(--color-cyan-glow);
}

.lyrics-content {
    font-family: 'Courier New', Courier, monospace;
    font-size: 1.1em;
    line-height: 1.6;
}
.lyrics-content::-webkit-scrollbar {
    width: 8px;
}
.lyrics-content::-webkit-scrollbar-thumb {
    background: var(--color-cyan);
}

.lyrics-scroll-container::-webkit-scrollbar {
    display: none;
}

.lyrics-scroll-container {
    -ms-overflow-style: none;
    scrollbar-width: none;
}

/* Performance overrides */
.effects-disabled .neon-text-pink,
.effects-disabled .neon-text-cyan,
.effects-disabled .welcome-glow {
    text-shadow: none;
}

.effects-disabled .search-wrapper.search-active,
.effects-disabled .search-wrapper:focus-within,
.effects-disabled .cover-glow,
.effects-disabled .temporary-glow,
.effects-disabled .loading-spinner,
.effects-disabled .notification-info,
.effects-disabled .notification-success,
.effects-disabled .notification-warning,
.effects-disabled .notification-error,
.effects-disabled input[type=range]::-webkit-slider-thumb,
.effects-disabled input[type=range]::-moz-range-thumb {
    box-shadow: none !important;
}

.effects-disabled .glassmorphism,
.effects-disabled .notification-toast,
.effects-disabled footer.glassmorphism,
.effects-disabled .tracklist-header {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    background-color: rgba(23, 10, 41, 0.9);
}


.effects-disabled footer.glassmorphism {
    background-color: rgba(23, 10, 41, 0.85);
}

.effects-disabled .slider-control.glowing-fuchsia,
.effects-disabled .slider-control.glowing-cyan {
    filter: none;
}

.effects-disabled .disc-spin,
.effects-disabled .speed-widget-appear-animation,
.effects-disabled .speed-widget-disappear-animation,
.effects-disabled tr.song-clicked-animation,
.effects-disabled .header-extra-buttons button:hover svg,
.effects-disabled .footer-player button:hover svg,
.effects-disabled .sidebar h2:hover .neon-text-cyan {
    animation: none;
}

.effects-disabled .preloading-song-row {
    animation: none;
    background-image: none;
}

.effects-disabled .cover-shiny-parent::before {
    content: none;
}

.effects-disabled .header-title::after {
    display: none;
}

.effects-disabled .header-title.flickering,
.effects-disabled .modal-content-host[x-show] .modal-content {
    animation: none;
}

.effects-disabled .lyrics-modal-glow {
    box-shadow: none !important;
    transition: none !important;
    border-color: rgba(217, 70, 239, 0.8);
}

.effects-disabled footer.footer-player.is-playing {
    animation: none;
    border-image: none;
}

.effects-disabled .page-header {
    z-index: 30;
}

/* Embed Mode Styles */
.embed-mode .footer-player {
    border-top: 1px solid var(--color-glass-border) !important;
    background-color: rgba(23, 10, 41, 0.95) !important;
    animation: none !important;
    border-image: none !important;
}
.embed-mode .tracklist-container {
    border: none !important;
}

/* Fix for borders not showing in PWA/app window mode */
@media (display-mode: standalone) {
    .footer-player {
        bottom: 1px !important;
        right: 2px !important;
        left: 1px !important;
    }
}
