/* --- PLAYER: Core styles (needed before mobile overrides) --- */
.player-info {
    flex: 1;
    max-width: 300px;
    font-size: 0.8rem;
    min-width: 0; /* allow children to shrink instead of forcing overflow */
}

#now-playing-title {
    font-weight: bold;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.player-ui {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 2;
    min-width: 0; /* critical: let seek bar shrink on small screens */
}

/* Extra now-playing content (cover + artist/support buttons). Hidden in collapsed dock; shown in expanded mobile sheet. */
.player-extra {
    display: none;
    align-items: center;
    gap: 12px;
    min-width: 0;
    flex: 0 0 auto;
}

/* Desktop: keep the artist/action buttons visible in the dock. */
@media (min-width: 900px) {
    .player-extra {
        display: flex;
    }
}

/* Mobile/tablet: show the extras when the player is expanded (sheet mode) */
@media (max-width: 899px) {
    .player-bar:not(.is-collapsed) .player-extra {
        display: flex;
    }
}
.player-cover {
    width: 72px;
    height: 72px;
    border: 1px solid rgba(51,255,0,0.35);
    background: rgba(0,0,0,0.45);
    background-size: cover;
    background-position: center;
    box-shadow: 0 0 14px rgba(51,255,0,0.12);
    flex: 0 0 auto;
    position: relative;
    overflow: hidden;
}

/* Dock-friendly sizing: keep cover + buttons compact so they don't feel out of place */
.player-bar.is-collapsed .player-cover {
    width: 44px;
    height: 44px;
}

.player-bar.is-collapsed .player-action-btn {
    padding: 6px 8px;
    font-size: 0.8rem;
}

/* CRT glass overlay for cover art (subtle scanlines + vignette) */
.player-cover::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to bottom,
        rgba(255,255,255,0) 0%,
        rgba(255,255,255,0) 48%,
        rgba(0,0,0,0.20) 50%,
        rgba(0,0,0,0.20) 100%
    );
    background-size: 100% 6px;
    opacity: 0.35;
    pointer-events: none;
}

.player-cover::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 35%, rgba(0,0,0,0), rgba(0,0,0,0.55));
    opacity: 0.55;
    pointer-events: none;
}
.player-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    min-width: 0;
}
.player-action-btn {
    border: 1px solid var(--terminal-dim);
    border-radius: 6px;
    padding: 8px 10px;
    background: rgba(0,0,0,0.35);
    color: var(--terminal-green);
    font-family: var(--font-stack);
    font-size: 0.85rem;
    cursor: pointer;
    text-decoration: none;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
}
.player-action-btn:hover {
    border-color: var(--terminal-green);
    box-shadow: 0 0 10px rgba(51,255,0,0.25);
}
/* Give the hero / track / player support buttons the same vivid hover treatment
   as `.donate-btn:hover` so their background becomes neon green and text turns black. */
#hero-support-btn:hover,
#track-page-support:hover,
#player-support-btn:hover {
    background: var(--terminal-green);
    color: #000;
    border-color: var(--terminal-green);
    box-shadow: 0 0 10px rgba(51,255,0,0.28);
    text-decoration: none;
}
.player-action-btn.is-disabled {
    opacity: 0.5;
    pointer-events: none;
}
:root {
    --bg-color: #050505;
    --terminal-green: #33ff00;
    --terminal-dim: #26ba01;
    --alert-color: #ff3300;
    --font-stack: 'Courier New', Courier, monospace;
        --player-height: 104px;
        --player-collapsed-height: 56px;
        --player-expanded-height: 52vh;
}

/* --- GLOBAL RESET --- */
* {
    box-sizing: border-box;
}

body, html {
    margin: 0;
    padding: 0;
    height: 100%;
    background-color: var(--bg-color);
    color: var(--terminal-green);
    font-family: var(--font-stack);
    /* Prevent scroll when overlay is active (managed by JS) */
}

/* --- FULL-PAGE BACKGROUND VISUALIZER (subtle, non-disruptive) --- */
#bg-viz {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
    pointer-events: none;
    /* Tweak: more visible neon glow, still subtle behind content */
    opacity: 0.32;
    mix-blend-mode: screen;
    filter: blur(0.35px) saturate(1.35) contrast(1.05);
}

/* Respect reduced-motion preferences: disable the background visualizer entirely */
@media (prefers-reduced-motion: reduce) {
    #bg-viz {
        display: none !important;
        animation: none !important;
        transition: none !important;
    }

    /* Also disable bass-hit UI motion effects */
    .bass-hit {
        animation: none !important;
        transform: none !important;
        filter: none !important;
        text-shadow: none !important;
    }
}

/* --- BASS HIT (audio-reactive UI punch) --- */
@keyframes bassHitJitter {
    0%   { transform: translate3d(0, 0, 0) scale(1); }
    18%  { transform: translate3d(-1px, 0, 0) scale(1.03); }
    42%  { transform: translate3d(1px, 0, 0) scale(1.02); }
    65%  { transform: translate3d(-1px, 0, 0) scale(1.01); }
    100% { transform: translate3d(0, 0, 0) scale(1); }
}

/* Default: subtle shake + brighter glow. Apply to selected elements via JS. */
.bass-hit {
    animation: bassHitJitter 120ms cubic-bezier(.36,.07,.19,.97) both;
    filter: saturate(1.15) brightness(1.15);
}

/* Logo-specific extra glow (keeps it readable but punchy) */
.logo.bass-hit {
    text-shadow:
        0 0 6px rgba(51,255,0,0.55),
        0 0 16px rgba(51,255,0,0.25);
}

/* Ensure overlays/content sit above the background viz */
#disclaimer-overlay,
#maintenance-overlay,
#main-site,
.scanlines {
    position: relative;
    z-index: 1;
}

a { color: var(--terminal-green); text-decoration: none; transition: 0.2s; cursor: pointer; }
a:hover { text-shadow: 0 0 5px var(--terminal-green); }

/* --- CRT SCANLINES EFFECT --- */
.scanlines {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        to bottom,
        rgba(255,255,255,0),
        rgba(255,255,255,0) 50%,
        rgba(0,0,0,0.2) 50%,
        rgba(0,0,0,0.2)
    );
    background-size: 100% 4px;
    pointer-events: none;
    z-index: 9999; /* Always on top */
}

/* --- DISCLAIMER OVERLAY --- */
#disclaimer-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--bg-color);
    z-index: 5000; /* High z-index to block site */
    padding: 20px;
}

.terminal-box {
    border: 2px solid var(--terminal-green);
    padding: 30px;
    max-width: 650px;
    width: 100%;
    box-shadow: 0 0 20px rgba(51, 255, 0, 0.2);
    background: #000;
}

/* Disclaimer icon (CRT-like glowing box) */
.disclaimer-icon-wrap {
    display: flex;
    justify-content: center;
    margin-bottom: 16px;
}
.disclaimer-icon {
    width: 120px;
    height: 120px;
    border-radius: 8px;
    border: 1px solid rgba(51,255,0,0.16);
    background-size: cover;
    background-position: center;
    box-shadow: 0 0 28px rgba(51,255,0,0.20), inset 0 0 18px rgba(0,0,0,0.45);
    position: relative;
    overflow: hidden;
    display: block;
    animation: crtGlow 2.8s ease-in-out infinite;
}
.disclaimer-icon::after {
    /* subtle scanlines overlay */
    content: "";
    position: absolute;
    inset: 0;
    background-image: repeating-linear-gradient(
        0deg,
        rgba(0,0,0,0) 0px,
        rgba(0,0,0,0.04) 1px,
        rgba(0,0,0,0) 2px
    );
    opacity: 0.35;
    pointer-events: none;
    mix-blend-mode: multiply;
    animation: crtFlicker 3s steps(6, end) infinite;
}
.disclaimer-icon::before {
    /* inner vignette to emulate CRT curvature */
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 30%, rgba(255,255,255,0.02), rgba(0,0,0,0.55));
    pointer-events: none;
}

/* Contact modal styles */
.contact-modal {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,0.6);
    z-index: 6000;
}
.contact-modal-box {
    background: #050505;
    border: 1px solid var(--terminal-green);
    padding: 20px;
    width: min(720px, 94%);
    max-width: 720px;
    box-shadow: 0 0 28px rgba(51,255,0,0.12);
}
.contact-modal-box h2 { margin-top: 0; }
.contact-sub { color: #cfcfcf; margin-bottom: 10px; }
.contact-grid { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.contact-option {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 12px;
    border: 1px dashed var(--terminal-dim);
    color: var(--terminal-green);
    background: rgba(0,0,0,0.35);
    text-decoration: none;
}
.contact-option:hover { background: var(--terminal-green); color: #000; border-style: solid; box-shadow: 0 0 10px rgba(51,255,0,0.25); }
.contact-or { text-align:center; opacity:0.6; margin: 8px 0; }
.contact-form label { display:block; margin:6px 0 2px; color: #cfcfcf; }
.contact-form input, .contact-form textarea { width:100%; padding:8px; border:1px solid var(--terminal-dim); background: rgba(0,0,0,0.4); color: var(--terminal-green); }
.contact-actions { display:flex; gap:8px; margin-top:10px; }

@keyframes crtGlow {
    0% {
        box-shadow: 0 0 20px rgba(51,255,0,0.16), inset 0 0 12px rgba(0,0,0,0.45);
        transform: translateY(0);
    }
    50% {
        box-shadow: 0 0 44px rgba(51,255,0,0.30), inset 0 0 22px rgba(0,0,0,0.55);
        transform: translateY(-1px);
    }
    100% {
        box-shadow: 0 0 20px rgba(51,255,0,0.16), inset 0 0 12px rgba(0,0,0,0.45);
        transform: translateY(0);
    }
}

@keyframes crtFlicker {
    0% { opacity: 0.36; }
    4% { opacity: 0.42; }
    6% { opacity: 0.28; }
    8% { opacity: 0.5; }
    12% { opacity: 0.34; }
    100% { opacity: 0.35; }
}


/* --- MAIN SITE LAYOUT --- */
#main-site {
    display: none; /* Hidden until JS activates it */
        padding-bottom: var(--player-height); /* Space for player (can change when collapsed) */
    min-height: 100vh;
}

/* Navigation */
.top-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px;
    border-bottom: 1px solid var(--terminal-dim);
    position: sticky;
    top: 0;
    background: rgba(5, 5, 5, 0.9);
    backdrop-filter: blur(5px);
    z-index: 100;
}

/* Keep long nav labels from creating horizontal overflow */
.top-nav, .top-nav * {
    max-width: 100%;
}

.logo {
    font-size: 1.5rem;
    font-weight: bold;
    letter-spacing: -1px;
}

.footer-links-mini {
    position: absolute;
    right: 20px;
    bottom: 5px;
    font-size: 0.7rem;
    opacity: 0.6;
}
.footer-links-mini a:hover {
    opacity: 1;
    text-shadow: 0 0 3px var(--terminal-green);
}

.user-nav {
    display: flex;
    gap: 15px;
    align-items: center;
}

/* Visualization mode select in header */
.top-nav .viz-select {
    height: 38px;
    min-height: 38px;
    box-sizing: border-box;
    padding: 0 10px;
    border: 1px solid var(--terminal-dim);
    background: #000; /* black background */
    color: var(--terminal-green); /* terminal-green text */
    text-align: center; /* center text */
    border-radius: 4px;
    font-family: var(--font-stack);
    font-size: 0.9rem;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 140px;
}
.top-nav .viz-select option { background: #000; color: var(--terminal-green); }
.top-nav .viz-select { display: inline-flex; align-items: center; justify-content: center; }

/* Small label placed before the viz select */
.top-nav .viz-label {
    color: var(--terminal-green);
    font-family: var(--font-stack);
    font-size: 0.85rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 38px;
    padding: 0 6px;
    margin-left: 8px;
    text-transform: uppercase;
}

/* Make the select more visible on desktop: vivid border and slight glow */
.top-nav .viz-select {
    margin-left: 6px;
    border-color: var(--terminal-green);
    box-shadow: 0 0 8px rgba(51,255,0,0.06);
}

/* Ensure select remains usable on small screens; collapse width if needed */
@media (max-width: 520px) {
    .top-nav .viz-select { width: 110px; margin-left: 6px; }
    .top-nav .viz-label { display: none; }
}

/* Unified Nav Item Styling to guarantee identical height/alignment */
.user-badge, 
.user-nav button, 
.user-nav .nav-link {
    height: 38px !important;
    min-height: 38px !important;
    box-sizing: border-box !important;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--terminal-dim);
    border-radius: 4px;
    background: transparent;
    color: var(--terminal-green);
    font-family: var(--font-stack);
    font-size: 0.9rem; /* Ensure text size matches */
    padding: 0 15px;
    margin: 0;
    line-height: 1;
    text-transform: uppercase;
    appearance: none; /* Strip default OS button styles */
}

.user-badge {
    gap: 10px;
    cursor: pointer;
    padding-left: 10px; /* Adjust for avatar */
}

.user-badge:hover {
    border-color: var(--terminal-green);
    box-shadow: 0 0 5px var(--terminal-green);
}

.user-nav button, .user-nav .nav-link {
    cursor: pointer;
}

.user-nav button:hover, .user-nav .nav-link:hover {
    background: var(--terminal-green);
    color: #000;
    text-shadow: none;
}

.avatar-small {
    width: 24px;
    height: 24px;
    border-radius: 50%;
}

.login-btn {
    border: 1px solid var(--terminal-green);
    padding: 5px 10px;
    font-size: 0.9rem;
}

.login-btn:hover {
    background: var(--terminal-green);
    color: #000;
}

/* Hero Section */
.hero-section {
    padding: 40px 20px;
    text-align: center;
    border-bottom: 1px dashed var(--terminal-dim);
}

.hero-sub {
    opacity: 0.7;
    font-style: italic;
}

/* --- BROADCAST DASHBOARD --- */
.broadcast-hero {
    margin-top: 25px;
    border: 1px solid var(--terminal-dim);
    /* Keep the existing gradient but add a semi-transparent dark layer so the viz shows through */
    background: radial-gradient(circle at 20% 0%, rgba(51,255,0,0.08), rgba(0,0,0,0.85) 55%),
                linear-gradient(180deg, rgba(0,0,0,0.0), rgba(0,0,0,0.6));
    background-color: rgba(0,0,0,0.38); /* semi-transparent overlay */
    backdrop-filter: blur(4px) saturate(1.05);
    overflow: hidden;
    position: relative;
}

.broadcast-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to bottom,
        rgba(255,255,255,0) 0%,
        rgba(255,255,255,0) 46%,
        rgba(0,0,0,0.25) 50%,
        rgba(0,0,0,0.25) 100%
    );
    background-size: 100% 6px;
    opacity: 0.35;
    pointer-events: none;
    animation: heroScan 7s linear infinite;
}

@keyframes heroScan {
    0% { background-position: 0 0; }
    100% { background-position: 0 60px; }
}

.broadcast-hero-inner {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 16px;
    padding: 18px;
    position: relative;
    z-index: 1;
}

.broadcast-hero-cover {
    width: 220px;
    height: 220px;
    border: 1px solid var(--terminal-dim);
    background: rgba(0,0,0,0.6);
    background-size: cover;
    background-position: center;
    position: relative;
    box-shadow: 0 0 16px rgba(51,255,0,0.15);
}

.broadcast-hero-cover::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(circle at 50% 50%, rgba(0,0,0,0), rgba(0,0,0,0.45));
    pointer-events: none;
}

.broadcast-kicker {
    font-size: 0.8rem;
    letter-spacing: 1px;
    opacity: 0.8;
    margin-bottom: 8px;
}

.broadcast-artist {
    font-size: 2.0rem;
    font-weight: bold;
    color: var(--terminal-green);
    text-shadow: 0 0 8px rgba(51,255,0,0.25);
    line-height: 1.05;
}

.broadcast-artist,
.broadcast-title {
    min-width: 0;
    overflow-wrap: anywhere;
}

.broadcast-title {
    font-size: 1.0rem;
    opacity: 0.85;
    margin-top: 8px;
    color: #fff;
}

.broadcast-info {
    margin-top: 10px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.broadcast-info .info-chip {
    display: inline-flex;
    align-items: center;
    height: 24px;
    padding: 0 8px;
    border: 1px dashed rgba(38,186,1,0.65);
    background: rgba(0,0,0,0.35);
    color: rgba(51,255,0,0.92);
    font-size: 0.72rem;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    white-space: nowrap;
}

/* --- Artist stats panel (minimal, low-bandwidth UI) --- */
.profile-stats-panel {
    margin: 10px 0 6px;
    padding: 10px 12px;
    border: 1px dashed rgba(38,186,1,0.55);
    background: rgba(0,0,0,0.35);
}

.profile-stats-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
}

.profile-stats-spark {
    margin: 8px 0 0;
    padding: 8px;
    border: 1px solid rgba(38,186,1,0.35);
    background: rgba(0,0,0,0.4);
    color: rgba(51,255,0,0.88);
    font-size: 0.75rem;
    line-height: 1.3;
    overflow-x: auto;
    white-space: pre;
}

.profile-top-tracks {
    margin-top: 10px;
    font-size: 0.78rem;
    opacity: 0.92;
}

.profile-top-tracks table {
    width: 100%;
    border-collapse: collapse;
}

.profile-top-tracks th,
.profile-top-tracks td {
    padding: 6px 6px;
    border-bottom: 1px solid rgba(38,186,1,0.18);
    text-align: left;
    vertical-align: top;
}

.profile-top-tracks th {
    opacity: 0.7;
    font-weight: normal;
}

.broadcast-actions {
    margin-top: 14px;
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

/* Make hero buttons feel like a matched set (same height, baseline, padding) */
.broadcast-actions button,
.broadcast-actions .nav-link {
    height: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    box-sizing: border-box;
}

.broadcast-actions .nav-link {
    border: 1px solid var(--terminal-dim);
    padding: 12px 15px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-transform: uppercase;
}

/* Disabled look for hero/action buttons inside the hero actions container */
.broadcast-actions .is-disabled {
    opacity: 0.5;
    pointer-events: none;
}

.broadcast-chip {
    margin-top: 14px;
    display: inline-block;
    border: 1px dashed var(--terminal-dim);
    padding: 4px 8px;
    font-size: 0.75rem;
    opacity: 0.85;
}

.rail {
    margin-top: 26px;
}

.rail-head {
    display: flex;
    justify-content: flex-start;
    align-items: baseline;
    gap: 10px;
    border-bottom: 1px dashed var(--terminal-dim);
    padding-bottom: 8px;
    width: 100%;
}

.rail-head h3 {
    margin: 0;
    font-size: 1rem;
    letter-spacing: 1px;
}

.rail-sub {
    font-size: 0.75rem;
    opacity: 0.7;
    display: none;
}

.rail-track {
    margin-top: 12px;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 170px;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 10px;
    scrollbar-color: var(--terminal-dim) rgba(0,0,0,0.2);
}

.rail-track::-webkit-scrollbar { height: 8px; }
.rail-track::-webkit-scrollbar-thumb { background: rgba(38,186,1,0.45); }
.rail-track::-webkit-scrollbar-track { background: rgba(0,0,0,0.2); }

/* --- TRACK PAGE (detail view) --- */
.track-page {
    margin-top: 26px;
    border: 1px solid var(--terminal-dim);
    background: radial-gradient(circle at 80% 0%, rgba(0,180,255,0.10), rgba(0,0,0,0.92) 55%),
                linear-gradient(180deg, rgba(0,0,0,0.25), rgba(0,0,0,0.85));
    padding: 16px;
    position: relative;
    overflow: hidden;
}

.track-page::before {
    content: "";
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        to bottom,
        rgba(255,255,255,0.0) 0px,
        rgba(255,255,255,0.0) 5px,
        rgba(0,180,255,0.06) 6px
    );
    opacity: 0.3;
    pointer-events: none;
}

.track-page-head {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 16px;
    align-items: start;
}

.track-page-cover {
    width: 220px;
    height: 220px;
    border: 1px solid var(--terminal-dim);
    background: rgba(0,0,0,0.6);
    background-size: cover;
    background-position: center;
    box-shadow: 0 0 18px rgba(0,180,255,0.12);
}

.track-page-kicker {
    font-size: 0.8rem;
    opacity: 0.75;
    letter-spacing: 1px;
}

.track-page-artist {
    margin-top: 8px;
    font-size: 1.8rem;
    font-weight: bold;
}

.track-page-title {
    margin-top: 6px;
    color: #fff;
    opacity: 0.9;
}

.track-page-actions {
    margin-top: 14px;
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

/* Make track-page action buttons equally sized */
.track-page-actions > button,
.track-page-actions > a {
    flex: 1 1 220px;
    min-width: 220px;
    height: 44px;
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 14px;
}

.track-page-actions > button {
    border: 1px solid var(--terminal-dim);
    background: transparent;
    color: var(--terminal-green);
    font-family: var(--font-stack);
    text-transform: uppercase;
    cursor: pointer;
}

.track-page-actions > button:hover {
    border-color: var(--terminal-green);
    box-shadow: 0 0 8px rgba(51,255,0,0.20);
}

.track-page-actions .nav-link {
    border: 1px solid var(--terminal-dim);
    padding: 0 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-transform: uppercase;
}

.track-page-actions .nav-link:hover {
    border-color: var(--terminal-green);
    box-shadow: 0 0 8px rgba(51,255,0,0.20);
    background: rgba(0,255,0,0.05);
}

.track-page-facts {
    margin-top: 14px;
    font-size: 0.75rem;
    opacity: 0.8;
    border-top: 1px dashed rgba(38,186,1,0.55);
    padding-top: 10px;
}

.track-page-rails {
    position: relative;
    z-index: 1;
    margin-top: 18px;
}

@media (max-width: 720px) {
    .track-page-head {
        grid-template-columns: 1fr;
    }
    .track-page-cover {
        width: 100%;
        height: 240px;
    }
}

/* Cover-first cards (rails + future grid) */
.track-card2 {
    border: 1px solid var(--terminal-dim);
    background: rgba(0, 0, 0, 0.55);
    padding: 10px;
    cursor: pointer;
    position: relative;
    transition: transform 0.15s, border-color 0.15s, box-shadow 0.15s;
}

.track-card2:hover {
    border-color: var(--terminal-green);
    box-shadow: 0 0 14px rgba(51,255,0,0.18);
    transform: translateY(-2px);
}

.track-card2::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
    opacity: 0;
    background: linear-gradient(90deg, rgba(51,255,0,0), rgba(51,255,0,0.08), rgba(51,255,0,0));
}

.track-card2:hover::after {
    opacity: 1;
    animation: cardGlitch 0.6s linear 1;
}

@keyframes cardGlitch {
    0% { transform: translateX(-30%); }
    100% { transform: translateX(30%); }
}

.track-card2-cover {
    width: 100%;
    aspect-ratio: 1 / 1;
    border: 1px solid var(--terminal-dim);
    background: rgba(0,0,0,0.6);
    background-size: cover;
    background-position: center;
    margin-bottom: 10px;
}

.track-card2-artist {
    font-weight: bold;
    font-size: 1.0rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.track-card2-title {
    font-size: 0.8rem;
    opacity: 0.85;
    color: #fff;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 4px;
}

.track-card2-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    font-size: 0.7rem;
    padding: 2px 6px;
    border: 1px dashed var(--terminal-dim);
    background: rgba(0,0,0,0.55);
}

@media (max-width: 720px) {
    .broadcast-hero-inner {
        grid-template-columns: 1fr;
    }
    .broadcast-hero-cover {
        width: 100%;
        height: 220px;
    }
    .rail-track {
        grid-auto-columns: 150px;
    }
}

/* --- MOBILE POLISH (phones) --- */
@media (max-width: 520px) {
    :root {
        --player-height: 132px;
        --player-collapsed-height: 56px;
        --player-expanded-height: 52vh;
    }

    .top-nav {
        padding: 12px;
        gap: 8px;
        display: flex;
        flex-direction: column;
        align-items: stretch;
    }

    .logo {
        font-size: 1.1rem;
        line-height: 1.1;
        display: block;
        width: 100%;
        text-align: center;
    }

    .user-nav {
        width: 100%;
        justify-content: center;
        gap: 8px;
        flex-wrap: nowrap;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        display: grid;
        grid-auto-flow: column;
        grid-auto-columns: max-content;
        align-items: center;
        padding-bottom: 2px; /* tiny breathing room above the border */
    }

    /* Subtle fade hint that the header buttons row can scroll */
    .user-nav {
        mask-image: linear-gradient(to right, rgba(0,0,0,0) 0%, rgba(0,0,0,1) 10%, rgba(0,0,0,1) 90%, rgba(0,0,0,0) 100%);
        -webkit-mask-image: linear-gradient(to right, rgba(0,0,0,0) 0%, rgba(0,0,0,1) 10%, rgba(0,0,0,1) 90%, rgba(0,0,0,0) 100%);
    }

    .user-nav::-webkit-scrollbar { height: 0; }

    .user-badge,
    .user-nav button,
    .user-nav .nav-link {
        height: 34px !important;
        min-height: 34px !important;
        padding: 0 10px;
        font-size: 0.75rem;
        white-space: nowrap;
    }

    /* Ensure a clear "hand" cursor for header CTAs */
    .logo,
    .user-badge,
    .user-nav button,
    .user-nav .nav-link {
        cursor: pointer;
    }

    span.nav-item:hover {
        cursor: pointer;
    }

    .content-wrapper {
        padding: 12px;
    }

    .hero-section {
        padding: 26px 12px;
    }

    .broadcast-hero {
        margin-top: 16px;
    }

    .broadcast-hero-inner {
        padding: 12px;
    }

    .broadcast-kicker {
        font-size: 0.7rem;
    }

    .broadcast-artist {
        font-size: 1.35rem;
    }

    .broadcast-title {
        font-size: 0.95rem;
    }

    .broadcast-actions {
        gap: 8px;
    }

    .broadcast-actions button,
    .broadcast-actions .nav-link {
        flex: 1 1 140px;
        min-width: 140px;
    }

    .player-bar {
        padding: 0 12px;
        gap: 10px;
        flex-wrap: wrap;
        align-items: center;
        justify-content: flex-start;
    }

    .player-info {
        max-width: none;
        width: 100%;
    }

    audio {
        flex: 0 0 auto;
        width: 100%;
    }

    .footer-links-mini {
        right: 12px;
    }
}

/* On mobile, the fixed/absolute mini footer links overlap the custom player controls.
   Let them flow as a normal row and stack under the player UI. */
@media (max-width: 520px) {
    .footer-links-mini {
        position: static;
        width: 100%;
        margin-top: 6px;
        text-align: right;
        opacity: 0.6;
    }

    .player-bar {
        height: auto;
        padding-top: 10px;
        padding-bottom: 10px;
    }

    /* On narrow screens, keep the info compact and avoid taking a full row if possible */
    .player-info {
        max-width: none;
        width: 100%;
    }
}

/* Profile Header */
.profile-header {
    display: flex;
    align-items: center;
    gap: 20px;
    justify-content: center;
}
.avatar-large {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    border: 2px solid var(--terminal-green);
    box-shadow: 0 0 15px rgba(51, 255, 0, 0.4);
    object-fit: cover;
    cursor: pointer;
}

.avatar-large:hover {
    box-shadow: 0 0 18px rgba(51, 255, 0, 0.55);
}
.profile-info {
    text-align: left;
}
/* Artist bio on profile header */
.profile-bio {
    margin-top: 8px;
    padding: 10px;
    border-left: 3px solid rgba(38,186,1,0.45);
    background: rgba(0,0,0,0.45);
    color: rgba(204,255,204,0.95);
    font-size: 0.95rem;
    line-height: 1.35;
    max-width: 680px;
    white-space: pre-wrap;
}

/* Profile edit modal: make the bio field wider and align label vertically */
.modal-content .form-group--bio {
    display: flex;
    gap: 12px;
    align-items: center; /* vertically center label */
}
.modal-content .form-group--bio label {
    flex: 0 0 180px; /* fixed label column */
    margin: 0;
    padding-right: 6px;
    text-transform: uppercase;
    font-size: 0.85rem;
}
.modal-content .form-group--bio textarea {
    flex: 1 1 auto;
    min-height: 120px;
    max-width: calc(100% - 200px);
    width: 100%;
    resize: vertical;
    padding: 10px;
    background: rgba(0,0,0,0.75);
    border: 1px solid rgba(38,186,1,0.22);
    color: var(--terminal-green);
    font-family: var(--font-stack);
    font-size: 0.95rem;
    line-height: 1.3;
}

/* On small screens stack label above textarea */
@media (max-width: 520px) {
    .modal-content .form-group--bio {
        display: block;
    }
    .modal-content .form-group--bio label {
        display: block;
        margin-bottom: 6px;
        flex: none;
    }
    .modal-content .form-group--bio textarea {
        max-width: 100%;
    }
}
.back-btn {
    margin-top: 10px;
    padding: 5px 10px;
    font-size: 0.8rem;
    border: 1px dashed var(--terminal-dim);
    display: block;
    width: 100%;
    box-sizing: border-box;
}
.back-btn:hover {
    border-style: solid;
}

.profile-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: stretch;
}

/* Profile-only card wall (different vibe from homepage rails) */
.profile-cards {
    margin-top: 18px;
    border: 1px dashed rgba(38,186,1,0.6);
    background: radial-gradient(circle at 60% 0%, rgba(255,0,255,0.08), rgba(0,0,0,0.9) 50%),
                linear-gradient(180deg, rgba(0,0,0,0.35), rgba(0,0,0,0.8));
    padding: 14px;
    position: relative;
    overflow: hidden;
}

.profile-cards::before {
    content: "";
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(
        to bottom,
        rgba(255,255,255,0.0) 0px,
        rgba(255,255,255,0.0) 3px,
        rgba(255,0,255,0.06) 4px
    );
    opacity: 0.35;
    pointer-events: none;
}

.profile-cards-grid {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
    gap: 12px;
}

.profile-cards .track-card2 {
    background: rgba(0,0,0,0.65);
    border-color: rgba(38,186,1,0.55);
}

.profile-cards .track-card2:hover {
    box-shadow: 0 0 14px rgba(255,0,255,0.10), 0 0 14px rgba(51,255,0,0.10);
}

.profile-cards .track-card2-badge {
    border-color: rgba(255,0,255,0.55);
    color: #ff8cff;
    display: none;
}

/* Track Grid */
.content-wrapper {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
}

/* Track Grid - Converted to List View per user request */
.track-grid {
    display: flex;
    flex-direction: column;
    gap: 15px; /* Spacing between rows */
    margin-top: 20px;
}

.track-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 1px solid var(--terminal-dim);
    padding: 15px;
    background: rgba(0, 50, 0, 0.1);
    transition: background 0.2s;
}

.track-item:hover {
    border-color: var(--terminal-green);
    background: rgba(0, 50, 0, 0.2);
}

.track-main {
    display: flex;
    flex-grow: 1;
    align-items: center;
    gap: 15px;
    overflow: hidden; /* Fix for flex children overflowing */
}

.track-cover {
    width: 52px;
    height: 52px;
    border: 1px solid var(--terminal-dim);
    border-radius: 2px;
    object-fit: cover;
    flex-shrink: 0;
    background: rgba(0, 0, 0, 0.6);
}

.track-cover.placeholder {
    display: inline-block;
}

.play-btn {
    cursor: pointer;
    color: var(--terminal-green);
    font-size: 1.2rem;
    flex-shrink: 0;
}
.play-btn:hover {
    text-shadow: 0 0 5px var(--terminal-green);
}

/* Card action rows (play/support/edit/delete) should look like a consistent button set */
.track-card2 .play-btn,
.track-card2 .donate-btn,
.track-card2 .admin-edit-btn,
.track-card2 .admin-del-btn {
    height: 32px;
    /* padding: 0 12px; */
    font-size: 0.8rem;
    border-radius: 0;
    border: 1px dashed var(--terminal-dim);
    background: rgba(0,0,0,0.35);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    line-height: 1;
    text-transform: uppercase;
    letter-spacing: 0.3px;
}

.track-card2 .play-btn { color: var(--terminal-green); }
.track-card2 .play-btn:hover { border-style: solid; border-color: var(--terminal-green); text-shadow: none; box-shadow: 0 0 8px rgba(51,255,0,0.20); }

.track-card2 .donate-btn { color: var(--terminal-green); }
.track-card2 .donate-btn:hover { 
    border-style: solid; 
    border-color: var(--terminal-green);
    background: var(--terminal-green);
    color: #000;
    box-shadow: 0 0 10px rgba(51,255,0,0.28);
    text-decoration: none;
}

.track-card2 .admin-edit-btn { color: #cfcfcf; }
.track-card2 .admin-edit-btn:hover { border-style: solid; border-color: var(--terminal-green); color: #fff; box-shadow: 0 0 8px rgba(51,255,0,0.20); }

.track-card2 .admin-del-btn { color: var(--alert-color); border-color: rgba(255,51,0,0.5); }
.track-card2 .admin-del-btn:hover { border-style: solid; border-color: var(--alert-color); box-shadow: 0 0 8px rgba(255,51,0,0.18); }

.track-title {
    color: #fff;
    font-weight: bold;
    cursor: pointer;
    white-space: nowrap;
}

.track-by {
    opacity: 0.5;
    font-size: 0.8rem;
}

.track-artist {
    color: var(--terminal-green);
    opacity: 0.9; /* Use opacity instead of dark color variable */
    cursor: pointer;
    text-decoration: underline;
    white-space: nowrap;
}
.track-artist:hover {
    opacity: 1;
    text-shadow: 0 0 5px var(--terminal-green);
}

/* Admin controls (used inside cards) */
.admin-edit-btn,
.admin-del-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 30px;
    padding: 0 10px;
    border: 1px dashed var(--terminal-dim);
    background: rgba(0,0,0,0.35);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    cursor: pointer;
    user-select: none;
    line-height: 1;
}

.admin-edit-btn {
    color: #cfcfcf;
}

.admin-edit-btn:hover {
    border-style: solid;
    border-color: var(--terminal-green);
    color: #fff;
}

.admin-del-btn {
    color: var(--alert-color);
    border-color: rgba(255,51,0,0.5);
}

.admin-del-btn:hover {
    border-style: solid;
    border-color: var(--alert-color);
    box-shadow: 0 0 8px rgba(255,51,0,0.18);
}

.donate-btn {
    white-space: nowrap;
    flex-shrink: 0; /* Prevent button squashing */
    text-align: center;
    min-width: unset;
}
.donate-btn:hover {
    /* Match play button hover: vivid neon background + dark text for contrast */
    border-color: var(--terminal-green);
    color: #000;
    background: var(--terminal-green);
    box-shadow: 0 0 10px rgba(51,255,0,0.28);
    text-decoration: none;
}

/* Track Card Styling (Legacy/Unused but kept for reference if needed) */
.track-card {
    border: 1px solid var(--terminal-dim);
    padding: 15px;
    background: rgba(255, 255, 255, 0.02);
    transition: all 0.2s;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.track-card:hover {
    border-color: var(--terminal-green);
    box-shadow: 0 0 10px rgba(51, 255, 0, 0.1);
    transform: translateY(-2px);
}

.track-art-placeholder {
    width: 100%;
    height: 150px;
    background: #111;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--terminal-dim);
    margin-bottom: 15px;
    border: 1px solid var(--terminal-dim);
}

.card-title {
    font-weight: bold;
    margin-bottom: 5px;
    color: #fff;
}

.card-artist {
    font-size: 0.9rem;
    color: var(--terminal-green);
    margin-bottom: 15px;
}

.card-actions {
    display: flex;
    gap: 10px;
    margin-top: auto;
}

/* Make play/support buttons on cards fill the row evenly */
.card-actions-equal {
    margin-top: 10px;
    display: flex;
    gap: 10px;
    align-items: stretch;
}

.card-actions-equal > .play-btn,
.card-actions-equal > .donate-btn {
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Management row (edit/delete) under cards */
.card-manage-actions {
    margin-top: 8px;
    display: flex;
    gap: 10px;
    align-items: stretch;
}

/* Make edit/delete fill the row evenly and feel like a matched set */
.track-card2 .card-manage-actions > .admin-edit-btn,
.track-card2 .card-manage-actions > .admin-del-btn {
    /* flex: 1 1 0; */
    min-width: 0;
    height: 32px;
}

.play-btn, .donate-link {
    /* flex: 1; */
    padding: 8px;
    text-align: center;
    border: 1px solid var(--terminal-green);
    cursor: pointer;
    font-size: 0.8rem;
    text-transform: uppercase;
}

.play-btn:hover {
    background: var(--terminal-green);
    color: #000;
}

.donate-link {
    border-color: var(--terminal-dim);
    color: var(--terminal-dim);
}

.donate-link:hover {
    /* Make donate-link hover match play button visual for consistency */
    border-color: var(--terminal-green);
    background: var(--terminal-green);
    color: #000;
    text-decoration: none;
}

/* --- PLAYER BAR --- */
.player-bar {
    position: fixed;
    /* Fixed elements are also a containing block; children with position:absolute
       will position relative to this box (which is what we want for the toggle). */
    bottom: 0;
    left: 0;
    width: 100%;
        height: var(--player-height);
    background: radial-gradient(circle at 30% 0%, rgba(51,255,0,0.10), rgba(0,0,0,0.85) 45%),
                linear-gradient(180deg, rgba(0,0,0,0.92), rgba(0,0,0,0.98));
    border-top: 2px solid var(--terminal-green);
    box-shadow: 0 -10px 24px rgba(0,0,0,0.55);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 20px;
    z-index: 200;
    box-sizing: border-box;
    overflow: hidden; /* never show scrollbars in the player dock */
    transition: height 220ms ease;
}

/* Toggle handle (mobile-first; hidden on desktop) */
.player-toggle {
    display: none;
    border: 0;
    background: transparent;
    color: var(--terminal-green);
    padding: 0;
    cursor: pointer;
    height: 100%;
    align-self: stretch;
    margin-right: 10px;
}

.player-grip {
    display: inline-block;
    width: 30px;
    height: 6px;
    border-radius: 999px;
    background: rgba(51,255,0,0.35);
    box-shadow: 0 0 12px rgba(51,255,0,0.18);
}

    /* Collapsible player (mostly for mobile) */
    .player-bar.is-collapsed {
        height: var(--player-collapsed-height);
    }

    .player-bar.is-collapsed .player-ui {
        display: none;
    }

    .player-bar.is-collapsed .footer-links-mini {
        display: none;
    }

    .player-bar.is-collapsed #now-playing-title {
        max-width: 70vw;
    }

    .player-bar .player-ui {
        max-width: 100%;
        margin-left: 10px;
    }
/* (Base .player-info moved to top to prevent accidental override/collapse.) */

/* Streaming status line: keep it available for debugging/state.
   If you don't want it visually long-term, we can restyle or tuck it away later. */
#status-display {
    display: block;
}

/* Ensure player text is readable even if some upstream styles change */
.player-bar {
    color: var(--terminal-green);
}

.player-info {
    min-height: 24px;
}

/* --- CUSTOM PLAYER UI (desktop look everywhere, including mobile) --- */
#audio-player {
    position: absolute;
    left: -99999px;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

/* (Base .player-ui moved to top; remove the stray min-width:260px that could force odd wrapping.) */

.player-btn {
    border: 1px solid var(--terminal-green);
    background: rgba(0, 0, 0, 0.55);
    color: var(--terminal-green);
    font-family: var(--font-stack);
    text-transform: uppercase;
    cursor: pointer;
    padding: 7px 10px;
    line-height: 1;
    white-space: nowrap;
    border-radius: 6px;
    box-shadow: inset 0 0 0 1px rgba(51,255,0,0.12);
    transition: transform 0.08s ease, background 0.2s ease, box-shadow 0.2s ease;
    max-width: 120px;
}

.player-btn:hover {
    background: rgba(51, 255, 0, 0.12);
    box-shadow: 0 0 10px rgba(51, 255, 0, 0.18);
}

.player-btn:active {
    transform: translateY(1px);
}

.player-btn.is-playing {
    border-style: solid;
}

.player-time {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.75rem;
    color: var(--terminal-dim);
    white-space: nowrap;
    min-width: 115px;
}

.player-seek {
    flex: 1;
    min-width: 0;
    accent-color: var(--terminal-green);
    height: 24px;
}

.player-volume-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    white-space: nowrap;
}

.player-vol-label {
    font-size: 0.7rem;
    color: var(--terminal-dim);
}

.player-volume {
    width: 110px;
    accent-color: var(--terminal-green);
    height: 24px;
}

/* Custom range styling (makes it feel less “default input”) */
.player-seek,
.player-volume {
    background: transparent;
    -webkit-appearance: none;
    appearance: none;
}

/* "Lightsaber" track baseline */
.player-seek::-webkit-slider-runnable-track,
.player-volume::-webkit-slider-runnable-track {
    height: 6px;
    border-radius: 999px;
    background:
        linear-gradient(90deg, rgba(51,255,0,0.12), rgba(51,255,0,0.35) 55%, rgba(51,255,0,0.12)),
        radial-gradient(circle at 50% 50%, rgba(255,255,255,0.22), rgba(255,255,255,0.0) 55%);
    box-shadow:
        0 0 10px rgba(51,255,0,0.22),
        0 0 22px rgba(51,255,0,0.12),
        inset 0 0 0 1px rgba(51,255,0,0.18);
}

.player-seek::-webkit-slider-thumb,
.player-volume::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 16px;
    height: 16px;
    margin-top: -5px;
    border-radius: 10px;
    background:
        radial-gradient(circle at 35% 35%, rgba(255,255,255,0.95), rgba(255,255,255,0.35) 35%, rgba(51,255,0,0.95) 70%),
        linear-gradient(180deg, rgba(255,255,255,0.25), rgba(0,0,0,0.25));
    border: 1px solid rgba(0,0,0,0.75);
    box-shadow:
        0 0 12px rgba(51,255,0,0.55),
        0 0 26px rgba(51,255,0,0.22);
}

/* Firefox */
.player-seek::-moz-range-track,
.player-volume::-moz-range-track {
    height: 6px;
    border-radius: 999px;
    background:
        linear-gradient(90deg, rgba(51,255,0,0.12), rgba(51,255,0,0.35) 55%, rgba(51,255,0,0.12)),
        radial-gradient(circle at 50% 50%, rgba(255,255,255,0.22), rgba(255,255,255,0.0) 55%);
    box-shadow:
        0 0 10px rgba(51,255,0,0.22),
        0 0 22px rgba(51,255,0,0.12),
        inset 0 0 0 1px rgba(51,255,0,0.18);
}

.player-seek::-moz-range-thumb,
.player-volume::-moz-range-thumb {
    width: 16px;
    height: 16px;
    border-radius: 10px;
    background:
        radial-gradient(circle at 35% 35%, rgba(255,255,255,0.95), rgba(255,255,255,0.35) 35%, rgba(51,255,0,0.95) 70%),
        linear-gradient(180deg, rgba(255,255,255,0.25), rgba(0,0,0,0.25));
    border: 1px solid rgba(0,0,0,0.75);
    box-shadow:
        0 0 12px rgba(51,255,0,0.55),
        0 0 26px rgba(51,255,0,0.22);
}

/* Mobile: keep desktop-like look, just allow wrapping and full-width seek */
@media (max-width: 520px) {
    .player-toggle {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 44px;
        min-width: 44px;
        max-width: 44px;
        height: 34px;
        align-self: center;
        border: 1px solid rgba(51,255,0,0.35);
        border-radius: 10px;
        background: rgba(0,0,0,0.35);
        box-shadow: 0 0 14px rgba(51,255,0,0.10);
        font-size: 18px;
        line-height: 1;
    }

    /* Use the button chevron symbol; keep the old grip element hidden if present in HTML. */
    .player-grip {
        display: none;
    }

    /* Collapsed: compact dock */
    .player-bar.is-collapsed {
        height: var(--player-collapsed-height);
        padding-top: 6px;
        padding-bottom: 6px;
        align-items: center;
    }

    /* Expanded: half-screen panel */
    .player-bar:not(.is-collapsed) {
        height: var(--player-expanded-height);
        padding-top: 12px;
        padding-bottom: 12px;
        align-items: flex-start;
    }

    /* Put the toggle handle near the top of the expanded sheet */
    .player-bar:not(.is-collapsed) .player-toggle {
        position: absolute;
        top: 8px;
        left: 12px;
        z-index: 2;
    }

    .player-bar:not(.is-collapsed) .player-info {
        width: 100%;
        margin-bottom: 10px;
    }

    /* Make room so the handle doesn't collide with the first row */
    .player-bar:not(.is-collapsed) .player-info {
        padding-top: 34px;
    }

    .player-bar:not(.is-collapsed) .player-ui {
        width: 100%;
        margin-top: 6px;
    }

    /* Expanded mobile sheet: distribute controls evenly across the full width */
    .player-bar:not(.is-collapsed) .player-ui {
        display: grid;
        grid-template-columns: 1fr 1fr auto;
        align-items: center;
        column-gap: 10px;
        row-gap: 8px;
    }

    .player-bar:not(.is-collapsed) #player-btn-play,
    .player-bar:not(.is-collapsed) #player-btn-stop {
        justify-self: stretch;
        width: 100%;
        text-align: center;
    }

    .player-bar:not(.is-collapsed) .player-time {
        justify-self: end;
        min-width: 0;
        font-variant-numeric: tabular-nums;
    }

    .player-bar:not(.is-collapsed) .player-volume-wrap {
        grid-column: 1 / -1;
        width: 100%;
        justify-self: stretch;
        margin-left: 0;
        display: grid;
        grid-template-rows: auto auto;
        row-gap: 6px;
        justify-items: stretch;
    }

    .player-bar:not(.is-collapsed) .player-vol-label {
        display: block;
        text-align: left;
        width: 100%;
        color: var(--terminal-dim);
        letter-spacing: 1px;
    }

    .player-bar:not(.is-collapsed) .player-volume {
        width: 100%;
        max-width: 100%;
    }

    .player-bar:not(.is-collapsed) .player-seek {
        grid-column: 1 / -1;
        width: 100%;
    }

    .player-bar:not(.is-collapsed) #now-playing-title {
        white-space: normal;
    }

    /* Expanded sheet: show cover + action buttons and give them room */
    .player-bar:not(.is-collapsed) .player-extra {
        display: flex;
        width: 100%;
        padding: 8px 12px 0;
        align-items: center;
        gap: 12px;
    }

    /* Safety override: ensure expanded sheet never hides the main player UI blocks */
    .player-bar:not(.is-collapsed) .player-info,
    .player-bar:not(.is-collapsed) .player-ui,
    .player-bar:not(.is-collapsed) .player-extra {
        display: flex;
        opacity: 1;
        visibility: visible;
    }

    /* Re-apply intended layout modes after forcing display:flex */
    .player-bar:not(.is-collapsed) .player-ui {
        display: grid;
    }

    .player-bar:not(.is-collapsed) .player-cover {
        width: 156px;
        height: 156px;
        border-color: rgba(51,255,0,0.5);
    }

    /* Stack ARTIST / SUPPORT vertically on the right */
    .player-bar:not(.is-collapsed) .player-actions {
        margin-left: auto;
        flex: 1;
        display: flex;
        flex-direction: column;
        align-items: stretch;
        justify-content: center;
        gap: 10px;
        min-width: 0;
    }

    .player-bar:not(.is-collapsed) .player-action-btn {
        padding: 9px 10px;
        font-size: 0.88rem;
        width: 100%;
        justify-content: center;
    }

    /* Center the current title below the cover art, above controls */
    .player-bar:not(.is-collapsed) #now-playing-title {
        display: block;
        width: 100%;
        padding: 8px 12px 0;
        text-align: center;
    }

    .player-ui {
        flex: 1 1 100%;
        width: 100%;
        flex-wrap: wrap;
        gap: 8px;
        min-width: 0;
    }

    .player-time {
        min-width: 0;
        flex: 1 1 auto;
    }

    .player-volume-wrap {
        margin-left: auto;
        flex: 1 1 auto;
        justify-content: flex-end;
    }

    /* Expanded sheet: volume should span full width */
    .player-bar:not(.is-collapsed) .player-volume-wrap {
        margin-left: 0;
        justify-content: stretch;
    }

    .player-seek {
        flex: 1 1 100%;
        min-width: 0;
    }

    /* Extra guard: avoid horizontal overflow on tiny screens */
    .player-bar {
        overflow-x: hidden;
    }

    /* Don't clamp the volume slider on mobile; allow full width in the expanded sheet */
    .player-volume {
        width: 100%;
    }

    /* Move legal links outside the control area so the player stays clean */
    .footer-links-mini {
        position: fixed;
        right: 12px;
        left: 12px;
        bottom: calc(var(--player-collapsed-height) + 10px);
        width: auto;
        text-align: right;
        background: rgba(0,0,0,0.65);
        border: 1px dashed rgba(38,186,1,0.35);
        padding: 4px 8px;
        border-radius: 10px;
        pointer-events: auto;
    }

    /* When expanded, float the links higher so they don't collide visually */
    .player-bar:not(.is-collapsed) .footer-links-mini {
        bottom: calc(var(--player-expanded-height) + 10px);
    }
}

/* (Base #now-playing-title moved to top.) */

/* Leave any other audio elements alone, but don't style the hidden #audio-player */
audio:not(#audio-player) {
    flex: 2;
    height: 30px;
    /* Customizing audio player is hard; we now use custom UI for the main player. */
    filter: invert(1) hue-rotate(90deg) contrast(2);
}

/* --- MODAL STYLES (From previous step) --- */
.modal-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
    z-index: 3000;
    justify-content: center;
    align-items: center;
}

.modal-terminal {
    width: 90%;
    max-width: 500px;
    background: #000;
    border: 2px solid var(--terminal-green);
    box-shadow: 0 0 20px rgba(51, 255, 0, 0.3);
    color: var(--terminal-green);
}

.upload-step {
    border: 1px dashed rgba(38,186,1,0.7);
    padding: 10px;
    background: rgba(0, 50, 0, 0.10);
    margin-bottom: 12px;
}

/* Primary call-to-action inside Step 1 */
.btn-primary-scan {
    width: auto;
    padding: 10px 14px;
    border: 1px solid var(--terminal-green);
    background: rgba(51,255,0,0.10);
    color: var(--terminal-green);
    font-family: var(--font-stack);
    text-transform: uppercase;
    letter-spacing: 0.6px;
    cursor: pointer;
    position: relative;
    transition: transform 0.08s ease, box-shadow 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.btn-primary-scan::after {
    content: "";
    position: absolute;
    inset: -6px;
    border: 1px dashed rgba(51,255,0,0.35);
    opacity: 0.65;
    pointer-events: none;
}

.btn-primary-scan:hover {
    background: rgba(51,255,0,0.18);
    box-shadow: 0 0 14px rgba(51,255,0,0.25);
}

.btn-primary-scan:active {
    transform: translateY(1px);
}

@keyframes scanPulse {
    0% {
        box-shadow: 0 0 0 rgba(51,255,0,0.00);
        transform: translateZ(0) scale(1);
    }
    55% {
        box-shadow: 0 0 26px rgba(51,255,0,0.34);
        transform: translateZ(0) scale(1.03);
    }
    100% {
        box-shadow: 0 0 0 rgba(51,255,0,0.00);
        transform: translateZ(0) scale(1);
    }
}

.btn-primary-scan {
    will-change: transform, box-shadow;
    animation: scanPulse 1.65s ease-in-out infinite;
}

/* Extra outer glow ring that pulses with the animation (more visible on CRT-ish palettes) */
.btn-primary-scan::before {
    content: "";
    position: absolute;
    inset: -10px;
    border-radius: 6px;
    background: radial-gradient(circle, rgba(51,255,0,0.18), rgba(51,255,0,0.00) 60%);
    opacity: 0.0;
    pointer-events: none;
    transition: opacity 0.2s ease;
}

@keyframes scanRing {
    0% { opacity: 0.00; }
    55% { opacity: 0.85; }
    100% { opacity: 0.00; }
}

.btn-primary-scan::before {
    animation: scanRing 1.65s ease-in-out infinite;
}

/* Once step 1 is completed, stop pulsing to reduce distraction */
.btn-primary-scan.is-complete {
    animation: none;
    box-shadow: 0 0 10px rgba(51,255,0,0.18);
}

.btn-primary-scan.is-complete::before {
    animation: none;
    opacity: 0.0;
}

.upload-step-hint {
    margin-top: 8px;
    font-size: 0.75rem;
    opacity: 0.75;
}

.upload-step-title {
    font-weight: bold;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
}

.upload-step-sub {
    font-size: 0.75rem;
    opacity: 0.75;
    margin-bottom: 10px;
}

.form-sep {
    margin: 12px 0;
    padding: 8px 10px;
    border-top: 1px dashed var(--terminal-dim);
    border-bottom: 1px dashed var(--terminal-dim);
    font-size: 0.75rem;
    letter-spacing: 0.4px;
    opacity: 0.85;
}

.modal-header {
    background: var(--terminal-green);
    color: #000;
    padding: 10px;
    display: flex;
    justify-content: space-between;
    align-items: center; /* Ensure alignment */
    font-weight: bold;
}

.close-btn {
    border: 1px solid #000;
    color: #000;
    padding: 2px 8px; /* Smaller visible button */
    font-weight: bold;
    flex-grow: 0; /* Prevention form stretching */
}
.close-btn:hover {
    background: #000;
    color: var(--terminal-green);
    border-color: #000; 
}

.modal-content { padding: 20px; }

/* Utilities */
.blink { animation: blinker 1s linear infinite; }
@keyframes blinker { 50% { opacity: 0; } }

.hidden { display: none !important; }

/* Disclaimer specific overrides */
.german-text {
    opacity: 0.8;
    font-style: italic;
    margin-top: 20px;
    border-top: 1px dashed var(--terminal-dim);
    padding-top: 20px;
}
.btn-container { margin-top: 30px; display: flex; gap: 10px; flex-wrap: wrap; }
button {
    background: transparent;
    border: 1px solid var(--terminal-green);
    color: var(--terminal-green);
    padding: 15px;
    font-family: inherit;
    cursor: pointer;
    text-transform: uppercase;
    flex-grow: 1;
}
button:hover { background: var(--terminal-green); color: black; }
button.exit-btn { border-color: var(--alert-color); color: var(--alert-color); }
button.exit-btn:hover { background: var(--alert-color); }
.legal-footer { margin-top: 20px; font-size: 0.7rem; text-align: center; opacity: 0.6; }

/* Form Elements inside Modal */
input {
    width: 100%;
    padding: 10px;
    background: #111;
    border: 1px solid var(--terminal-dim);
    color: #fff;
    margin-bottom: 10px;
    font-family: inherit;
}

/* --- PROFILE / TRACK CARDS --- */
.profile-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 16px;
    padding: 16px;
}

.track-card2 {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 12px;
    border-radius: 8px;
    cursor: pointer;
    /* Slightly transparent so the background visualizer can shine through */
    background: rgba(0, 0, 0, 0.42);
    border: 1px solid rgba(51,255,0,0.08);
    color: var(--terminal-green);
    box-shadow: 0 6px 18px rgba(0,0,0,0.55);
    backdrop-filter: blur(4px) saturate(1.15);
    transition: transform 0.14s ease, box-shadow 0.14s ease, border-color 0.14s ease;
}

.track-card2:hover {
    transform: translateY(-4px);
    box-shadow: 0 14px 30px rgba(0,0,0,0.65);
    border-color: rgba(51,255,0,0.18);
}

.track-card2-cover {
    width: 100%;
    padding-top: 100%; /* square */
    background-size: cover;
    background-position: center;
    border-radius: 6px;
    overflow: hidden;
    position: relative;
    box-shadow: inset 0 0 18px rgba(0,0,0,0.45);
}

.track-card2-artist {
    font-size: 0.85rem;
    opacity: 0.95;
    text-shadow: 0 0 6px rgba(0,0,0,0.6);
}

.track-card2-title {
    font-weight: bold;
    font-size: 0.95rem;
    line-height: 1.05;
    text-shadow: 0 0 6px rgba(0,0,0,0.6);
}

.track-card2-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    font-size: 0.7rem;
    padding: 4px 6px;
    background: rgba(0,0,0,0.35);
    border: 1px solid rgba(51,255,0,0.08);
    border-radius: 4px;
}

.card-actions-equal {
    display: flex;
    gap: 8px;
    align-items: center;
}

.card-manage-actions {
    position: absolute;
    right: 18px;
    top: 8px;
    display: flex;
    gap: 38px;
}

    div#user-nav span.nav-item:hover {
       cursor: pointer;
    }
