/* 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;
}
.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;
}

/* 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);
}
.player-action-btn.is-disabled {
    opacity: 0.5;
    pointer-events: none;
}

.player-viz {
    display: none;
    width: calc(100% - 24px);
    height: 96px;
    margin: 10px 12px 0;
    border: 1px solid rgba(51,255,0,0.25);
    background: rgba(0,0,0,0.35);
    box-shadow: inset 0 0 22px rgba(51,255,0,0.06);
}
: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;
    }
}

/* 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;
}

/* --- 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;
}

/* 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);
    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));
    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-actions {
    margin-top: 14px;
    display: flex;
    gap: 10px;
    align-items: center;
    flex-wrap: wrap;
}

.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;
}

.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: space-between;
    align-items: baseline;
    gap: 10px;
    border-bottom: 1px dashed var(--terminal-dim);
    padding-bottom: 8px;
}

.rail-head h3 {
    margin: 0;
    font-size: 1rem;
    letter-spacing: 1px;
}

.rail-sub {
    font-size: 0.75rem;
    opacity: 0.7;
}

.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;
    }

    .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;
}
.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;
}

/* 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); box-shadow: 0 0 8px rgba(51,255,0,0.20); background: rgba(0,255,0,0.05); }

.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 {
    border-color: var(--terminal-green);
    color: var(--terminal-green);
    box-shadow: 0 0 5px var(--terminal-dim);
    background: rgba(0,255,0,0.05);
}

/* 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 {
    border-color: var(--alert-color);
    color: var(--alert-color);
}

/* --- PLAYER BAR --- */
.player-bar {
    position: fixed;
    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%;
    }
.player-info {
    flex: 1;
    max-width: 300px;
    font-size: 0.8rem;
    min-width: 0; /* allow children to shrink instead of forcing overflow */
}

#status-display {
    color: var(--terminal-dim);
    font-size: 0.7rem;
}

/* Make the status line feel like an intentional UI element */
#status-display {
    display: inline-block;
    padding: 3px 8px;
    border: 1px dashed rgba(38,186,1,0.55);
    background: rgba(0, 40, 0, 0.20);
    border-radius: 999px;
    letter-spacing: 0.2px;
}

/* --- CUSTOM PLAYER UI (desktop look everywhere, including mobile) --- */
#audio-player {
    position: absolute;
    left: -99999px;
    width: 1px;
    height: 1px;
    opacity: 0;
    pointer-events: none;
}

.player-ui {
    display: flex;
    align-items: center;
    gap: 10px;
    flex: 2;
    min-width: 260px;
    min-width: 0; /* critical: let seek bar shrink on small screens */
}

.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;
}

.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: 42px;
        min-width: 42px;
        max-width: 42px;
        height: 34px;
        align-self: center;
    }

    /* 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;
    }

    .player-bar:not(.is-collapsed) .player-info {
        width: 100%;
        margin-bottom: 10px;
    }

    .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: center;
    }

    .player-bar:not(.is-collapsed) .player-vol-label {
        display: block;
        text-align: center;
        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: 10px 12px 0;
        align-items: center;
        gap: 12px;
    }

    .player-bar:not(.is-collapsed) .player-cover {
        width: 96px;
        height: 96px;
        border-color: rgba(51,255,0,0.5);
    }

    .player-bar:not(.is-collapsed) .player-action-btn {
        padding: 10px 12px;
        font-size: 0.9rem;
    }

    .player-bar:not(.is-collapsed) .player-viz {
        display: block;
    }

    .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;
    }

    .player-seek {
        flex: 1 1 100%;
        min-width: 0;
    }

    /* Extra guard: avoid horizontal overflow on tiny screens */
    .player-bar {
        overflow-x: hidden;
    }

    .player-volume {
        width: 92px;
    }

    /* 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);
    }
}

#now-playing-title {
    font-weight: bold;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* 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;
}