/* ===== Variables ===== */
:root {
    --bg:        #08081a;
    --bg2:       #0f0f26;
    --bg3:       #171730;
    --card:      #1a1a38;
    --border:    rgba(138,43,226,.2);
    --purple:    #8a2be2;
    --cyan:      #00d4ff;
    --purple-glow: rgba(138,43,226,.35);
    --cyan-glow:   rgba(0,212,255,.25);
    --text:      #e0e0ff;
    --muted:     #7878aa;
    --radius:    14px;
    --radius-sm: 8px;
    --t:         .25s ease;
    --player-h:  72px;
    --font-hd:   'Orbitron', monospace;
    --font:      'Inter', sans-serif;
}

/* ===== Reset ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
    background:var(--bg);
    color:var(--text);
    font-family:var(--font);
    overflow-x:hidden;
    line-height:1.6;
    padding-bottom:var(--player-h);
    display:flex;
    flex-direction:column;
    min-height:100vh;
}
a { text-decoration:none; color:inherit; }
img { max-width:100%; }
button { cursor:pointer; }

/* ===== Starfield ===== */
#starfield { position:fixed; inset:0; z-index:0; pointer-events:none; }

/* ===== Preloader ===== */
#preloader {
    position:fixed; inset:0; background:var(--bg);
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    z-index:99999; transition:opacity .6s,visibility .6s;
}
#preloader.hidden { opacity:0; visibility:hidden; }
.loader-ring {
    width:72px; height:72px; border:3px solid transparent;
    border-top-color:var(--purple); border-right-color:var(--cyan);
    border-radius:50%; animation:spin 1s linear infinite; margin-bottom:20px;
}
@keyframes spin { to { transform:rotate(360deg); } }
.loader-text {
    font-family:var(--font-hd); font-size:22px; letter-spacing:8px;
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.loader-sub { font-size:13px; color:var(--muted); margin-top:6px; letter-spacing:2px; }

/* ===== Scrollbar ===== */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--purple); border-radius:3px; }

/* ===== Navbar ===== */
.navbar {
    position:fixed; top:0; left:0; right:0; z-index:1000;
    padding:14px 0; transition:var(--t); background:transparent;
}
.navbar.scrolled {
    background:rgba(8,8,26,.94); backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border); padding:8px 0;
}
.nav-container {
    max-width:1200px; margin:0 auto; padding:0 24px;
    display:flex; align-items:center; gap:24px;
}
.nav-logo {
    display:flex; align-items:center; gap:10px;
    font-family:var(--font-hd); font-size:18px; font-weight:800;
    flex-shrink:0;
}
.nav-logo i { color:var(--purple); font-size:22px; }
.text-accent { color:var(--cyan); }
.nav-links {
    list-style:none; display:flex; gap:28px; margin-left:auto;
}
.nav-links a {
    font-size:14px; font-weight:500; color:var(--muted);
    transition:var(--t); letter-spacing:.5px; position:relative;
}
.nav-links a::after {
    content:''; position:absolute; bottom:-3px; left:0; width:0; height:2px;
    background:linear-gradient(90deg,var(--purple),var(--cyan)); transition:var(--t);
}
.nav-links a:hover, .nav-links a.active { color:var(--text); }
.nav-links a:hover::after, .nav-links a.active::after { width:100%; }
.nav-user { flex-shrink:0; }
.nav-toggle { display:none; flex-direction:column; gap:5px; padding:4px; }
.nav-toggle span { width:22px; height:2px; background:var(--text); transition:var(--t); }
.nav-toggle.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.nav-toggle.active span:nth-child(2) { opacity:0; }
.nav-toggle.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* ===== Buttons ===== */
.btn {
    display:inline-flex; align-items:center; gap:8px;
    padding:11px 26px; border:none; border-radius:50px;
    font-family:var(--font); font-size:14px; font-weight:600;
    cursor:pointer; transition:var(--t); letter-spacing:.3px;
}
.btn-primary {
    background:linear-gradient(135deg,var(--purple),var(--cyan)); color:#fff;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 28px var(--purple-glow); }
.btn-outline {
    background:transparent; border:1px solid var(--border); color:var(--text);
}
.btn-outline:hover { border-color:var(--purple); background:var(--purple-glow); }
.btn-glow { animation:glow-pulse 3s ease-in-out infinite; }
@keyframes glow-pulse {
    0%,100% { box-shadow:0 0 16px var(--purple-glow); }
    50%      { box-shadow:0 0 32px var(--purple-glow),0 0 48px var(--cyan-glow); }
}
.btn-sm { padding:7px 16px; font-size:13px; }
.btn-block { width:100%; justify-content:center; }
.btn-danger { background:#e03; color:#fff; }
.btn-danger:hover { background:#c00; }

/* ===== Hero ===== */
.hero {
    position:relative; min-height:100vh;
    display:flex; align-items:center; justify-content:center;
    z-index:1; overflow:hidden;
}
.hero-overlay {
    position:absolute; inset:0;
    background:radial-gradient(ellipse at center,rgba(138,43,226,.12),transparent 68%);
    pointer-events:none;
}
.hero-content { text-align:center; padding:0 24px; position:relative; z-index:2; }
.hero-badge {
    display:inline-flex; align-items:center; gap:8px;
    padding:8px 20px; border:1px solid var(--purple); border-radius:50px;
    font-family:var(--font-hd); font-size:11px; letter-spacing:3px; color:var(--purple);
    margin-bottom:28px;
}
.live-dot {
    width:8px; height:8px; border-radius:50%; background:#44ff44;
    animation:blink 1.4s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.2} }
.hero-title {
    font-family:var(--font-hd); font-size:clamp(56px,11vw,130px);
    font-weight:900; line-height:1; margin-bottom:16px;
}
.text-stroke { -webkit-text-stroke:2px var(--text); -webkit-text-fill-color:transparent; }
.text-gradient {
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.hero-subtitle {
    font-size:clamp(16px,2.5vw,28px); color:var(--muted);
    font-weight:300; letter-spacing:4px; margin-bottom:24px;
}
.hero-meta {
    display:flex; justify-content:center; gap:28px; flex-wrap:wrap;
    margin-bottom:36px; font-size:13px; color:var(--muted); letter-spacing:.5px;
}
.hero-meta i { color:var(--purple); margin-right:6px; }
.hero-actions { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
/* ===== Hero waveform ===== */
.hero-waveform {
    position:absolute; bottom:0; left:0; right:0;
    height:120px; display:flex; align-items:flex-end;
    justify-content:center; gap:3px; pointer-events:none;
    overflow:hidden;
}
.hero-waveform span {
    flex-shrink:0; width:4px; min-height:4px;
    background:linear-gradient(to top, rgba(138,43,226,.6), rgba(0,212,255,.3));
    border-radius:2px 2px 0 0;
    animation:hero-wave 1.2s ease-in-out infinite alternate;
}
@keyframes hero-wave {
    0%   { height:4px;  opacity:.3; }
    100% { height:80px; opacity:.7; }
}

/* ===== Hero "Nu speelt" kaartje ===== */
.hero-now-playing {
    display:inline-flex; align-items:center; gap:12px;
    margin-top:32px; padding:12px 18px;
    background:rgba(255,255,255,.05); backdrop-filter:blur(16px);
    border:1px solid rgba(255,255,255,.1); border-radius:50px;
    font-size:13px; max-width:340px;
}
.hnp-art {
    width:36px; height:36px; border-radius:8px; flex-shrink:0;
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    overflow:hidden;
}
.hnp-art img { width:100%; height:100%; object-fit:cover; }
.hnp-info { min-width:0; flex:1; text-align:left; }
.hnp-label { font-size:9px; color:var(--cyan); letter-spacing:2px; font-family:var(--font-hd); margin-bottom:2px; }
.hnp-title { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.hnp-artist { font-size:11px; color:var(--muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.hnp-eq { height:20px; margin-left:4px; flex-shrink:0; }

.scroll-indicator {
    position:absolute; bottom:36px; left:50%; transform:translateX(-50%);
    display:flex; flex-direction:column; align-items:center; gap:6px;
    color:var(--muted); font-size:11px; letter-spacing:2px;
    animation:bounce 2s infinite;
}
@keyframes bounce {
    0%,20%,50%,80%,100% { transform:translateX(-50%) translateY(0); }
    40% { transform:translateX(-50%) translateY(-8px); }
    60% { transform:translateX(-50%) translateY(-4px); }
}

/* ===== Sections ===== */
.section { padding:90px 0; position:relative; z-index:1; }
.section-dark { background:var(--bg2); }
.container { max-width:1200px; margin:0 auto; padding:0 24px; }
.section-header { text-align:center; margin-bottom:56px; }
.section-badge {
    display:inline-block; padding:5px 14px; border:1px solid var(--purple);
    border-radius:50px; font-family:var(--font-hd); font-size:10px;
    letter-spacing:3px; color:var(--purple); margin-bottom:14px;
}
.section-title { font-family:var(--font-hd); font-size:clamp(28px,4vw,42px); font-weight:700; margin-bottom:10px; }
.section-desc { font-size:16px; color:var(--muted); }

/* ===== Schedule ===== */
.schedule-tabs {
    display:flex; gap:8px; overflow-x:auto; padding-bottom:4px;
    margin-bottom:28px; scrollbar-width:none;
}
.schedule-tabs::-webkit-scrollbar { display:none; }
.schedule-tab {
    flex-shrink:0; padding:8px 20px; border-radius:50px;
    border:1px solid var(--border); background:transparent;
    color:var(--muted); font-size:13px; font-family:var(--font);
    cursor:pointer; transition:var(--t); white-space:nowrap;
}
.schedule-tab.active, .schedule-tab:hover {
    border-color:var(--purple); color:var(--text);
    background:rgba(138,43,226,.12);
}
.schedule-tab.today { border-color:var(--cyan); color:var(--cyan); }
.schedule-list { display:flex; flex-direction:column; gap:12px; }
.schedule-row {
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); padding:20px 24px;
    display:grid; grid-template-columns:120px 1fr auto;
    gap:16px; align-items:center; transition:var(--t);
}
.schedule-row:hover { border-color:var(--purple); transform:translateX(4px); }
.schedule-row.live { border-color:var(--cyan); }
.schedule-row.live .schedule-time { color:var(--cyan); }
.schedule-time { font-family:var(--font-hd); font-size:13px; color:var(--muted); }
.schedule-show { font-weight:600; font-size:15px; }
.schedule-show small { display:block; color:var(--muted); font-weight:400; font-size:13px; margin-top:2px; }
.schedule-genre {
    padding:4px 12px; border-radius:50px; border:1px solid var(--border);
    font-size:11px; color:var(--muted); white-space:nowrap;
}
.live-badge {
    display:inline-flex; align-items:center; gap:5px;
    padding:3px 10px; border-radius:50px;
    background:rgba(0,212,255,.12); color:var(--cyan);
    font-size:11px; font-family:var(--font-hd); letter-spacing:1px;
}

/* ===== Request ===== */
.request-grid { display:grid; grid-template-columns:1fr 380px; gap:40px; align-items:start; }
.request-form-card {
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); padding:32px;
}
.request-login-prompt {
    text-align:center; display:flex; flex-direction:column;
    align-items:center; gap:16px; padding:20px 0;
}
.request-login-prompt i { font-size:48px; color:var(--muted); }
.request-login-prompt p { color:var(--muted); }
.request-type-toggle {
    display:flex; gap:0; margin-bottom:24px;
    border:1px solid var(--border); border-radius:var(--radius-sm); overflow:hidden;
}
.toggle-btn {
    flex:1; padding:10px; background:transparent; border:none;
    color:var(--muted); font-size:13px; font-family:var(--font);
    cursor:pointer; transition:var(--t);
}
.toggle-btn.active { background:var(--purple); color:#fff; }
.search-box {
    position:relative; margin-bottom:12px;
}
.search-box i {
    position:absolute; left:14px; top:50%; transform:translateY(-50%);
    color:var(--muted); font-size:14px;
}
.search-box input {
    width:100%; padding:12px 14px 12px 40px;
    background:var(--bg); border:1px solid var(--border);
    border-radius:var(--radius-sm); color:var(--text);
    font-family:var(--font); font-size:14px; outline:none; transition:var(--t);
}
.search-box input:focus { border-color:var(--purple); }
.song-results { max-height:260px; overflow-y:auto; margin-bottom:12px; border-radius:var(--radius-sm); }
.song-result {
    display:flex; align-items:center; gap:10px;
    padding:8px 12px; border-radius:var(--radius-sm);
    cursor:pointer; transition:var(--t);
}
.song-result:hover { background:rgba(138,43,226,.15); }
.sr-art {
    width:42px; height:42px; flex-shrink:0; border-radius:6px;
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    overflow:hidden; display:flex; align-items:center; justify-content:center;
    font-size:16px; color:rgba(255,255,255,.4);
}
.sr-art img { width:100%; height:100%; object-fit:cover; display:block; }
.sr-info { min-width:0; flex:1; }
.sr-info strong { display:block; font-size:13px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sr-info span   { display:block; font-size:11px; color:var(--muted); }
.sr-album { color:var(--border) !important; font-size:10px !important; }
.sr-preview { color:var(--cyan); font-size:11px; flex-shrink:0; }
.sr-loading { padding:14px; text-align:center; color:var(--muted); font-size:13px; }
.sr-empty   { padding:12px 14px; color:var(--muted); font-size:13px; }

.selected-song {
    display:flex; align-items:center; gap:12px; padding:12px 14px;
    background:rgba(138,43,226,.12); border:1px solid var(--purple);
    border-radius:var(--radius-sm); margin-bottom:12px;
}
.selected-song-art {
    width:44px; height:44px; border-radius:6px; object-fit:cover; flex-shrink:0; display:block;
}
.selected-song-meta { min-width:0; flex:1; }
.selected-song-meta strong { display:block; font-size:13px; }
.selected-song-meta span   { display:block; font-size:11px; color:var(--muted); }
.selected-song i { color:var(--purple); flex-shrink:0; }
.form-group { margin-bottom:14px; }
.form-group input,
.form-group textarea {
    width:100%; padding:12px 14px;
    background:var(--bg); border:1px solid var(--border);
    border-radius:var(--radius-sm); color:var(--text);
    font-family:var(--font); font-size:14px; outline:none; transition:var(--t);
    resize:vertical;
}
.form-group input:focus, .form-group textarea:focus { border-color:var(--purple); }
.request-note { font-size:12px; color:var(--muted); text-align:center; margin-top:10px; }
.recent-requests h3 { font-family:var(--font-hd); font-size:16px; margin-bottom:20px; }
.request-item {
    padding:14px 0; border-bottom:1px solid var(--border);
    display:flex; flex-direction:column; gap:4px;
}
.request-item:last-child { border-bottom:none; }
.request-item strong { font-size:14px; }
.request-item span { font-size:12px; color:var(--muted); }
.request-status {
    display:inline-block; padding:2px 8px; border-radius:4px;
    font-size:11px; font-family:var(--font-hd);
}
.status-queued  { background:rgba(0,212,255,.15); color:var(--cyan); }
.status-played  { background:rgba(68,255,68,.12);  color:#4f4; }
.status-pending { background:rgba(255,170,0,.12);  color:#fa0; }
.loading-rows { display:flex; flex-direction:column; gap:12px; }
.loading-row {
    height:52px; border-radius:var(--radius-sm);
    background:linear-gradient(90deg,var(--card) 25%,var(--bg3) 50%,var(--card) 75%);
    background-size:200% 100%; animation:shimmer 1.4s infinite;
}
@keyframes shimmer { to { background-position:-200% 0; } }
.hidden { display:none !important; }

/* ===== DJs ===== */
.djs-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
    gap:24px;
}
.dj-card {
    border-radius:20px; overflow:hidden;
    border:1px solid var(--border);
    background:var(--card);
    transition:.3s ease;
    cursor:default;
    position:relative;
}
.dj-card:hover {
    border-color:rgba(138,43,226,.6);
    transform:translateY(-8px);
    box-shadow:0 20px 60px rgba(138,43,226,.25), 0 0 0 1px rgba(138,43,226,.15);
}

/* Photo area — portrait ratio */
.dj-photo {
    position:relative; width:100%; aspect-ratio:3/4;
    overflow:hidden;
}
.dj-photo img {
    width:100%; height:100%; object-fit:cover;
    display:block; transition:.5s ease;
}
.dj-card:hover .dj-photo img { transform:scale(1.07); }

/* Fallback: beautiful gradient background */
.dj-photo-fallback {
    background:
        radial-gradient(ellipse at 30% 20%, rgba(138,43,226,.5) 0%, transparent 60%),
        radial-gradient(ellipse at 70% 80%, rgba(0,212,255,.3) 0%, transparent 60%),
        linear-gradient(160deg, #0d0820 0%, #130826 50%, #080f1a 100%);
}

/* Initials circle in fallback */
.dj-initials-wrap {
    position:absolute; inset:0;
    display:flex; align-items:center; justify-content:center;
}
.dj-initials {
    width:80px; height:80px; border-radius:50%;
    background:rgba(255,255,255,.06);
    border:2px solid rgba(255,255,255,.12);
    backdrop-filter:blur(8px);
    display:flex; align-items:center; justify-content:center;
    font-family:var(--font-hd); font-size:26px; font-weight:900;
    color:rgba(255,255,255,.7); letter-spacing:-1px; user-select:none;
    box-shadow:0 0 30px rgba(138,43,226,.3), inset 0 0 20px rgba(0,212,255,.05);
}

/* Floating rings in fallback */
.dj-ring {
    position:absolute; border-radius:50%;
    border:1px solid rgba(138,43,226,.2);
    animation:dj-ring-spin 12s linear infinite;
}
.dj-ring:nth-child(1) { width:120px; height:120px; top:50%; left:50%; margin:-60px 0 0 -60px; }
.dj-ring:nth-child(2) { width:160px; height:160px; top:50%; left:50%; margin:-80px 0 0 -80px; border-color:rgba(0,212,255,.15); animation-duration:18s; animation-direction:reverse; }
@keyframes dj-ring-spin { to { transform:rotate(360deg); } }

/* Genre badge — always visible, top */
.dj-genre-tag {
    position:absolute; top:14px; left:14px; z-index:3;
    padding:4px 12px; border-radius:50px;
    background:rgba(0,212,255,.12); border:1px solid rgba(0,212,255,.35);
    color:var(--cyan); font-size:9px; font-family:var(--font-hd);
    letter-spacing:1.5px; backdrop-filter:blur(8px);
    transition:.3s ease;
}
.dj-card:hover .dj-genre-tag {
    background:rgba(0,212,255,.2);
    border-color:var(--cyan);
    box-shadow:0 0 10px rgba(0,212,255,.2);
}

/* Bottom overlay — always visible */
.dj-overlay {
    position:absolute; bottom:0; left:0; right:0; z-index:2;
    background:linear-gradient(to top, rgba(8,8,26,.98) 0%, rgba(8,8,26,.7) 55%, transparent 100%);
    padding:20px 16px 16px;
    display:flex; flex-direction:column; gap:6px;
    transition:.3s ease;
}

.dj-overlay-name {
    font-family:var(--font-hd); font-size:15px; font-weight:800;
    color:#fff; line-height:1.2;
}
.dj-overlay-role {
    font-size:12px; color:rgba(160,160,200,.8);
    font-weight:400; letter-spacing:.3px;
}

/* Social icons — slide up on hover */
.dj-socials {
    display:flex; gap:7px; margin-top:4px;
    opacity:0; transform:translateY(8px);
    transition:.3s ease;
}
.dj-card:hover .dj-socials { opacity:1; transform:translateY(0); }

.dj-social {
    width:30px; height:30px; border-radius:50%;
    background:rgba(255,255,255,.1); backdrop-filter:blur(8px);
    border:1px solid rgba(255,255,255,.15);
    display:inline-flex; align-items:center; justify-content:center;
    font-size:13px; color:#fff; transition:.2s ease;
}
.dj-social:hover { background:var(--purple); border-color:var(--purple); transform:scale(1.1); }

/* Mobile */
@media (max-width:600px) {
    .djs-grid { grid-template-columns:1fr 1fr; gap:14px; }
    .dj-overlay-name { font-size:13px; }
    .dj-overlay-role { font-size:11px; }
    .dj-initials { width:60px; height:60px; font-size:20px; }
}
@media (max-width:380px) {
    .djs-grid { grid-template-columns:1fr; }
}

/* ===== Stats ===== */
.stats-section { background:var(--bg2); padding:70px 0; }
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:24px; text-align:center; }
.stat-item { padding:24px; }
.stat-item i { font-size:32px; color:var(--purple); margin-bottom:14px; display:block; }
.stat-number {
    display:block; font-family:var(--font-hd); font-size:42px; font-weight:700;
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; line-height:1.2;
}
.stat-label { font-size:13px; color:var(--muted); letter-spacing:1.5px; margin-top:4px; }

/* ===== About ===== */
.about-content { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.about-text p { font-size:16px; color:var(--muted); margin-bottom:14px; line-height:1.8; }
.about-features { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:20px; }
.about-feature { display:flex; align-items:center; gap:10px; font-size:14px; }
.about-feature i { color:var(--purple); font-size:16px; }
.about-visual { display:flex; justify-content:center; }
.about-image-inner {
    width:260px; height:260px; border-radius:50%;
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    display:flex; align-items:center; justify-content:center;
    font-size:72px; color:#fff; position:relative;
    box-shadow:0 0 60px var(--purple-glow);
}
.orbit-ring {
    position:absolute; inset:-18px; border:2px solid var(--cyan);
    border-radius:50%; animation:spin 12s linear infinite;
    border-top-color:transparent; border-bottom-color:transparent;
}

/* ===== Contact ===== */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; }
.contact-info { display:flex; flex-direction:column; gap:20px; }
.contact-item { display:flex; gap:14px; align-items:flex-start; }
.contact-item i { font-size:22px; color:var(--purple); margin-top:2px; flex-shrink:0; }
.contact-item h4 { font-family:var(--font-hd); font-size:14px; margin-bottom:2px; }
.contact-item p { font-size:14px; color:var(--muted); }
.contact-socials { display:flex; gap:10px; }
.social-link {
    width:40px; height:40px; border-radius:50%; border:1px solid var(--border);
    display:flex; align-items:center; justify-content:center;
    font-size:16px; color:var(--muted); transition:var(--t);
}
.social-link:hover { border-color:var(--purple); color:var(--purple); background:var(--purple-glow); }
.contact-form { display:flex; flex-direction:column; gap:12px; }

/* ===== Footer ===== */
.footer { background:var(--bg2); border-top:1px solid var(--border); padding:60px 0 0; position:relative; z-index:1; margin-top:auto; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:36px; margin-bottom:36px; }
.footer-brand h3 { font-family:var(--font-hd); font-size:18px; margin-bottom:10px; }
.footer-brand p { font-size:14px; color:var(--muted); line-height:1.7; margin-bottom:16px; }
.footer-socials { display:flex; gap:10px; }
.footer-socials a {
    width:36px; height:36px; border-radius:50%; border:1px solid var(--border);
    display:flex; align-items:center; justify-content:center;
    font-size:15px; color:var(--muted); transition:var(--t);
}
.footer-socials a:hover { border-color:var(--purple); color:var(--purple); }
.footer-links h4 { font-family:var(--font-hd); font-size:12px; letter-spacing:1px; margin-bottom:14px; color:var(--text); }
.footer-links ul { list-style:none; }
.footer-links li { margin-bottom:8px; }
.footer-links a { font-size:14px; color:var(--muted); transition:var(--t); }
.footer-links a:hover { color:var(--purple); }
.footer-newsletter h4 { font-family:var(--font-hd); font-size:12px; letter-spacing:1px; margin-bottom:8px; }
.footer-newsletter p { font-size:13px; color:var(--muted); margin-bottom:14px; }
.newsletter-form { display:flex; }
.newsletter-form input {
    flex:1; padding:10px 14px;
    background:var(--bg); border:1px solid var(--border); border-right:none;
    border-radius:var(--radius-sm) 0 0 var(--radius-sm);
    color:var(--text); font-family:var(--font); font-size:13px; outline:none;
}
.newsletter-form button {
    padding:10px 18px;
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    border:none; border-radius:0 var(--radius-sm) var(--radius-sm) 0;
    color:#fff; transition:var(--t);
}
.newsletter-form button:hover { opacity:.88; }
.footer-badges { display:flex; gap:12px; margin-top:12px; }
.badge-item { font-size:12px; color:var(--muted); display:flex; align-items:center; gap:5px; }
.badge-item i { color:var(--purple); }
.footer-bottom {
    border-top:1px solid var(--border); padding:20px 0;
    display:flex; justify-content:space-between; flex-wrap:wrap;
    gap:8px; font-size:13px; color:var(--muted);
}
.footer-license a { color:var(--muted); text-decoration:underline; }
.footer-license i { color:var(--purple); }

/* ===== Back to Top ===== */
.back-to-top {
    position:fixed; bottom:calc(var(--player-h) + 16px); right:20px;
    width:40px; height:40px; border-radius:50%;
    border:1px solid var(--border); background:var(--card);
    color:var(--text); font-size:16px;
    display:flex; align-items:center; justify-content:center;
    opacity:0; visibility:hidden; transition:var(--t); z-index:900;
}
.back-to-top.visible { opacity:1; visibility:visible; }
.back-to-top:hover { border-color:var(--purple); }

/* ===== Player Bar ===== */
.player-bar {
    position:fixed; bottom:0; left:0; right:0;
    height:var(--player-h); background:rgba(8,8,26,.97);
    backdrop-filter:blur(24px); border-top:1px solid var(--border);
    z-index:1000;
}
.player-bar-inner {
    max-width:1400px; margin:0 auto; height:100%;
    padding:0 20px; display:flex; align-items:center; gap:16px;
}
.pb-art {
    width:44px; height:44px; border-radius:8px; flex-shrink:0;
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    display:flex; align-items:center; justify-content:center;
    font-size:18px; color:#fff; overflow:hidden;
}
.pb-art img { width:100%; height:100%; object-fit:cover; }
.pb-logo-mark {
    font-family:var(--font-hd); font-size:9px; font-weight:800;
    color:#fff; letter-spacing:.5px; text-align:center; line-height:1.3;
    pointer-events:none;
}
.pb-logo-mark span { color:var(--cyan); }
.pb-info { display:flex; flex-direction:column; min-width:0; flex:1; max-width:220px; }
.pb-title {
    font-family:var(--font-hd); font-size:12px; font-weight:600;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.pb-artist { font-size:11px; color:var(--muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.pb-eq {
    display:flex; align-items:flex-end; gap:3px; height:28px; flex-shrink:0; opacity:0; transition:opacity .3s;
}
.pb-eq.active { opacity:1; }
.pb-eq span {
    width:3px; height:6px; background:linear-gradient(to top,var(--purple),var(--cyan));
    border-radius:2px; animation:eq-bar 1.1s ease-in-out infinite;
    animation-play-state:paused;
}
.pb-eq.active span { animation-play-state:running; }
.pb-eq span:nth-child(1) { animation-delay:0s; }
.pb-eq span:nth-child(2) { animation-delay:.2s; }
.pb-eq span:nth-child(3) { animation-delay:.4s; }
.pb-eq span:nth-child(4) { animation-delay:.6s; }
@keyframes eq-bar { 0%,100%{height:4px} 50%{height:22px} }
.pb-controls { display:flex; align-items:center; gap:12px; flex-shrink:0; }
.pb-play-btn {
    width:44px; height:44px; border-radius:50%; border:none;
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    color:#fff; font-size:16px; display:flex; align-items:center; justify-content:center;
    transition:var(--t);
}
.pb-play-btn:hover { transform:scale(1.08); box-shadow:0 0 18px var(--purple-glow); }
.pb-volume { display:flex; align-items:center; gap:8px; }
.pb-vol-icon { background:none; border:none; color:var(--muted); font-size:15px; transition:var(--t); }
.pb-vol-icon:hover { color:var(--text); }
#volumeSlider {
    -webkit-appearance:none; width:80px; height:3px;
    border-radius:2px; background:var(--border); outline:none; cursor:pointer;
}
#volumeSlider::-webkit-slider-thumb {
    -webkit-appearance:none; width:14px; height:14px;
    border-radius:50%; background:var(--purple); cursor:pointer;
}
.pb-meta { display:flex; flex-direction:column; align-items:flex-end; gap:3px; flex-shrink:0; margin-left:auto; }
.pb-status { display:flex; align-items:center; gap:6px; font-size:11px; font-family:var(--font-hd); letter-spacing:1px; }
.status-dot {
    width:7px; height:7px; border-radius:50%; background:#555;
    animation:blink 1.4s ease-in-out infinite;
}
.pb-listeners { font-size:11px; color:var(--muted); }
.pb-request-btn {
    flex-shrink:0; width:36px; height:36px; border-radius:50%;
    border:1px solid var(--border); background:transparent;
    color:var(--muted); display:flex; align-items:center; justify-content:center;
    font-size:14px; transition:var(--t);
}
.pb-request-btn:hover { border-color:var(--cyan); color:var(--cyan); }

/* ===== Toast ===== */
.toast {
    position:fixed; bottom:calc(var(--player-h) + 16px); left:50%;
    transform:translateX(-50%) translateY(12px);
    background:var(--card); border:1px solid var(--border);
    padding:12px 24px; border-radius:50px;
    font-size:14px; opacity:0; transition:opacity .3s,transform .3s;
    z-index:1100; white-space:nowrap; pointer-events:none;
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }
.toast.success { border-color:var(--cyan); color:var(--cyan); }
.toast.error   { border-color:#f44; color:#f44; }

/* ===== Generic page hero (news/top25/etc.) ===== */
.page-hero {
    padding:140px 0 60px; text-align:center;
    background:radial-gradient(ellipse at center,rgba(138,43,226,.1),transparent 70%);
    position:relative; z-index:1;
}
.page-hero h1 { font-family:var(--font-hd); font-size:clamp(28px,5vw,48px); font-weight:800; margin-bottom:10px; }
.page-hero p { color:var(--muted); font-size:16px; }

/* ===== News cards ===== */
.news-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:24px; }
.news-card {
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); overflow:hidden; transition:var(--t);
    display:flex; flex-direction:column;
}
.news-card:hover { border-color:var(--purple); transform:translateY(-4px); box-shadow:0 8px 32px var(--purple-glow); }
.news-thumb { height:180px; background:var(--bg3); overflow:hidden; }
.news-thumb img { width:100%; height:100%; object-fit:cover; transition:transform .4s; }
.news-card:hover .news-thumb img { transform:scale(1.04); }
.news-thumb-placeholder {
    height:100%; display:flex; align-items:center; justify-content:center;
    font-size:48px; color:var(--border);
}
.news-body { padding:20px; flex:1; display:flex; flex-direction:column; }
.news-meta { font-size:12px; color:var(--muted); margin-bottom:10px; display:flex; gap:12px; }
.news-body h3 { font-family:var(--font-hd); font-size:16px; margin-bottom:8px; line-height:1.4; }
.news-body p { font-size:14px; color:var(--muted); flex:1; line-height:1.6; }
.news-read-more { margin-top:14px; }

/* ===== Top 25 ===== */
.top25-list { display:flex; flex-direction:column; gap:10px; }
.top25-row {
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); padding:12px 16px;
    display:grid; grid-template-columns:44px 48px 1fr auto;
    gap:12px; align-items:center; transition:var(--t);
}
.top25-row:hover { border-color:var(--purple); transform:translateX(3px); }
.top25-rank {
    font-family:var(--font-hd); font-size:20px; font-weight:800;
    color:var(--border); text-align:center;
}
.top25-row:nth-child(1) .top25-rank { color:gold; }
.top25-row:nth-child(2) .top25-rank { color:silver; }
.top25-row:nth-child(3) .top25-rank { color:#cd7f32; }
.top25-cover {
    width:48px; height:48px; border-radius:var(--radius-sm);
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    overflow:hidden; flex-shrink:0;
    display:flex; align-items:center; justify-content:center;
    font-size:18px; color:rgba(255,255,255,.4);
}
.top25-cover img { width:100%; height:100%; object-fit:cover; display:block; }
.top25-info strong { font-size:15px; display:block; }
.top25-info span   { font-size:13px; color:var(--muted); display:block; margin-top:2px; }
.top25-actions { display:flex; align-items:center; gap:8px; }
.vote-btn {
    display:flex; align-items:center; gap:6px;
    padding:8px 16px; border-radius:50px;
    border:1px solid var(--border); background:transparent;
    color:var(--muted); font-size:13px; transition:var(--t);
    white-space:nowrap;
}
.vote-btn:hover:not(:disabled) { border-color:var(--purple); color:var(--purple); }
.vote-btn.voted { border-color:var(--purple); color:var(--purple); background:var(--purple-glow); }
.vote-btn:disabled { opacity:.5; cursor:default; }
.yt-btn {
    width:36px; height:36px; border-radius:50%; flex-shrink:0;
    border:1px solid rgba(255,50,50,.3); background:transparent;
    color:#f44; display:flex; align-items:center; justify-content:center;
    font-size:15px; transition:var(--t);
}
.yt-btn:hover { background:#f44; color:#fff; border-color:#f44; }
.top25-login-note { text-align:center; margin-top:20px; color:var(--muted); font-size:14px; }
.top25-login-note a { color:var(--cyan); }

/* ===== Auth pages ===== */
.auth-section {
    min-height:100vh; display:flex; align-items:center; justify-content:center;
    padding:100px 24px; position:relative; z-index:1;
}
.auth-card {
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); padding:40px; width:100%; max-width:420px;
}
.auth-card h2 { font-family:var(--font-hd); font-size:24px; margin-bottom:6px; }
.auth-card p { color:var(--muted); font-size:14px; margin-bottom:28px; }
.auth-card .form-group { margin-bottom:16px; }
.auth-footer { margin-top:20px; text-align:center; font-size:14px; color:var(--muted); }
.auth-footer a { color:var(--cyan); }
.form-label { display:block; font-size:13px; color:var(--muted); margin-bottom:6px; }
.form-error { color:#f55; font-size:13px; margin-top:8px; }

/* ===== Legal pages ===== */
.legal-section { padding:140px 0 80px; position:relative; z-index:1; }
.legal-content { max-width:780px; margin:0 auto; }
.legal-content h1 { font-family:var(--font-hd); font-size:32px; margin-bottom:8px; }
.legal-content .last-updated { color:var(--muted); font-size:13px; margin-bottom:36px; }
.legal-content h2 { font-family:var(--font-hd); font-size:18px; margin:28px 0 10px; color:var(--cyan); }
.legal-content p  { font-size:15px; color:var(--muted); line-height:1.8; margin-bottom:14px; }
.legal-content ul { padding-left:20px; margin-bottom:14px; }
.legal-content li { font-size:15px; color:var(--muted); line-height:1.8; margin-bottom:6px; }

/* ===== Contact pagina ===== */
.contact-hero { text-align:center; }
.contact-hero h1 { font-family:var(--font-hd); font-size:clamp(28px,5vw,52px); font-weight:800; margin-bottom:10px; }
.contact-hero p  { color:var(--muted); font-size:16px; }

.contact-page-section { padding-top:20px; }
.contact-page-container { max-width:860px; margin:0 auto; }

/* Info cards */
.contact-cards {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:20px; margin-bottom:48px;
}
.contact-card {
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); padding:28px 24px;
    text-align:center; transition:var(--t);
}
.contact-card:hover { border-color:var(--purple); transform:translateY(-3px); box-shadow:0 8px 32px var(--purple-glow); }
.contact-card-icon {
    width:52px; height:52px; border-radius:50%;
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    display:flex; align-items:center; justify-content:center;
    font-size:20px; color:#fff; margin:0 auto 14px;
}
.contact-card h3 { font-family:var(--font-hd); font-size:13px; letter-spacing:1px; margin-bottom:6px; }
.contact-card p  { font-size:14px; color:var(--muted); }
.contact-card-socials { display:flex; gap:8px; justify-content:center; margin-top:4px; }

/* Centered form */
.contact-form-wrap { display:flex; justify-content:center; }
.contact-form-card {
    background:var(--card); border:1px solid var(--border);
    border-radius:var(--radius); padding:36px 40px;
    width:100%; max-width:600px;
}
.contact-form-card h2 { font-family:var(--font-hd); font-size:20px; margin-bottom:6px; }
.contact-form-sub { font-size:14px; color:var(--muted); margin-bottom:28px; }
.cf-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.cf-group { display:flex; flex-direction:column; gap:6px; margin-bottom:14px; }
.cf-label { font-size:12px; color:var(--muted); letter-spacing:.3px; }
.cf-group input,
.cf-group textarea {
    padding:12px 14px; background:var(--bg); border:1px solid var(--border);
    border-radius:var(--radius-sm); color:var(--text);
    font-family:var(--font); font-size:14px; outline:none; transition:var(--t);
    width:100%;
}
.cf-group input:focus,
.cf-group textarea:focus { border-color:var(--purple); }
.cf-group textarea { resize:vertical; min-height:130px; }
.cf-error {
    background:rgba(255,68,68,.1); border:1px solid rgba(255,68,68,.3);
    color:#f55; border-radius:var(--radius-sm); padding:10px 14px;
    font-size:13px; margin-bottom:14px;
}
.contact-success {
    background:rgba(0,212,255,.08); border:1px solid rgba(0,212,255,.25);
    color:var(--cyan); border-radius:var(--radius-sm); padding:20px;
    text-align:center; font-size:15px; margin-bottom:16px;
    display:flex; align-items:center; justify-content:center; gap:10px;
}
.contact-success i { font-size:20px; }

/* Contact CTA op homepage */
.contact-cta {
    text-align:center; padding:20px 0;
    display:flex; flex-direction:column; align-items:center; gap:16px;
}
.contact-cta-icon {
    width:64px; height:64px; border-radius:50%;
    background:linear-gradient(135deg,var(--purple),var(--cyan));
    display:flex; align-items:center; justify-content:center;
    font-size:24px; color:#fff;
    box-shadow:0 0 32px var(--purple-glow);
}
.contact-cta-title { font-family:var(--font-hd); font-size:clamp(22px,4vw,34px); font-weight:700; }
.contact-cta-desc  { font-size:16px; color:var(--muted); max-width:480px; }

/* ===== Responsive ===== */
@media (max-width:1024px) {
    .request-grid  { grid-template-columns:1fr; }
    .about-content { grid-template-columns:1fr; }
    .contact-grid  { grid-template-columns:1fr; }
    .footer-grid   { grid-template-columns:1fr 1fr; }
    #volumeSlider  { width:60px; }
}

@media (max-width:768px) {
    /* Navigatie */
    .nav-links {
        position:fixed; top:0; right:-100%; width:260px; height:100vh;
        background:rgba(8,8,26,.98); flex-direction:column;
        align-items:center; justify-content:center; gap:28px;
        transition:.35s ease; border-left:1px solid var(--border);
        z-index:1001;
    }
    .nav-links.active { right:0; }
    .nav-toggle { display:flex; margin-left:auto; }
    .nav-user   { display:none; }

    /* Secties */
    .section      { padding:60px 0; }
    .stats-section { padding:50px 0; }
    .page-hero    { padding:110px 0 40px; }
    .section-header { margin-bottom:36px; }

    /* Hero */
    .hero-meta    { flex-direction:column; gap:8px; }
    .hero-actions { flex-direction:column; align-items:stretch; gap:10px; }
    .hero-actions .btn { justify-content:center; }
    .hero-badge   { font-size:9px; letter-spacing:2px; }

    /* Schedule */
    .schedule-row   { grid-template-columns:80px 1fr; }
    .schedule-genre { display:none; }

    /* About */
    .about-visual   { display:none; }
    .about-features { grid-template-columns:1fr; }

    /* Hero waveform smaller op mobiel */
    .hero-waveform { height:70px; gap:2px; }
    .hero-waveform span { width:3px; }
    .hero-now-playing { max-width:100%; font-size:12px; padding:10px 14px; }

    /* Footer */
    .footer-grid    { grid-template-columns:1fr; }
    .footer         { padding:40px 0 0; }
    .footer-bottom  { flex-direction:column; gap:6px; text-align:center; }

    /* Player bar — compact op mobiel */
    .pb-info    { display:flex; max-width:none; flex:1; min-width:0; }
    .pb-eq      { display:none; }
    .pb-meta    { display:none; }
    .pb-request-btn { display:none; }
    .pb-artist  { display:none; }
    #volumeSlider { display:none; }
    .player-bar-inner { gap:10px; padding:0 14px; }

    /* Stats */
    .stats-grid { grid-template-columns:1fr; }

    /* Top 25 — cover verbergen op mobiel */
    .top25-row    { grid-template-columns:36px 1fr auto; gap:10px; }
    .top25-cover  { display:none; }
    .yt-btn       { display:none; }

    /* iOS: voorkom autozoom op inputs */
    input, textarea, select {
        font-size:16px !important;
    }
}

@media (max-width:480px) {
    /* Hero titel */
    .hero-title { font-size:48px; }

    /* Container meer padding */
    .container { padding:0 16px; }

    /* Knoppen alleen in hero full-width */
    .hero-actions .btn { width:100%; }

    /* News */
    .news-grid { grid-template-columns:1fr; }

    /* Schedule tabs scrollen */
    .schedule-tabs { gap:6px; }
    .schedule-tab  { padding:6px 14px; font-size:12px; }

    /* Schedule row */
    .schedule-row  { padding:14px 16px; grid-template-columns:72px 1fr; }
    .schedule-time { font-size:11px; }
    .schedule-show { font-size:14px; }

    /* Top 25 */
    .top25-rank { font-size:18px; }
    .top25-info strong { font-size:14px; }
    .vote-btn   { padding:6px 10px; font-size:12px; }

    /* Auth */
    .auth-card { padding:28px 20px; }

    /* Contact pagina cards */
    .contact-cards { grid-template-columns:1fr; gap:14px; margin-bottom:32px; }
    .contact-form-card { padding:28px 20px; }
    .cf-row { grid-template-columns:1fr; gap:0; }

    /* Footer licentie balk wrappen */
    .footer-bottom { font-size:12px; }
}
/* ===== Article pagina ===== */
.article-hero { position:relative; min-height:420px; display:flex; align-items:flex-end; overflow:hidden; }
.article-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; filter:brightness(.45); }
.article-hero-gradient { position:absolute; inset:0; background:linear-gradient(to top, var(--bg) 0%, rgba(8,8,26,.6) 60%, transparent 100%); }
.article-hero-content { position:relative; z-index:2; padding:48px 24px 36px; max-width:800px; margin:0 auto; width:100%; }
.article-hero-fallback { background:radial-gradient(ellipse at center, rgba(138,43,226,.15), transparent 70%); padding-top:120px; }
.article-meta-bar { display:flex; align-items:center; gap:12px; margin-bottom:20px; }
.article-author-avatar { width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,var(--purple),var(--cyan)); display:flex; align-items:center; justify-content:center; font-family:var(--font-hd); font-size:12px; font-weight:800; flex-shrink:0; }
.article-author-name { font-size:13px; font-weight:600; }
.article-author-date { font-size:12px; color:var(--muted); }
.article-readtime { margin-left:auto; font-size:12px; color:var(--muted); display:flex; align-items:center; gap:5px; }
.article-body-wrap { max-width:760px; margin:0 auto; padding:40px 24px 80px; }
.article-back-btn { display:inline-flex; align-items:center; gap:8px; color:var(--muted); font-size:13px; margin-bottom:32px; transition:var(--t); }
.article-back-btn:hover { color:var(--cyan); }
.article-title { font-family:var(--font-hd); font-size:clamp(22px,4vw,38px); font-weight:900; line-height:1.2; margin-bottom:16px; }
.article-excerpt-lead { font-size:18px; color:var(--muted); line-height:1.7; margin-bottom:28px; border-left:3px solid var(--purple); padding-left:16px; }
.article-content { font-size:16px; color:#b8b8d8; line-height:1.85; }
.article-content p { margin-bottom:18px; }
.article-content h2 { font-family:var(--font-hd); font-size:20px; color:var(--cyan); margin:32px 0 12px; }
.article-content h3 { font-family:var(--font-hd); font-size:16px; color:var(--text); margin:24px 0 10px; }
.article-content ul, .article-content ol { padding-left:22px; margin-bottom:18px; }
.article-content li { margin-bottom:6px; }
.article-content a { color:var(--cyan); text-decoration:underline; }
.article-content blockquote { border-left:3px solid var(--purple); padding:12px 20px; margin:20px 0; background:var(--card); border-radius:0 var(--radius-sm) var(--radius-sm) 0; font-style:italic; color:var(--muted); }

/* ===== Auth split layout ===== */
.auth-split { display:grid; grid-template-columns:3fr 2fr; min-height:100vh; }
.auth-split-visual {
    background:linear-gradient(135deg, #08081a 0%, #130826 40%, #08081a 100%);
    display:flex; flex-direction:column; align-items:center; justify-content:center;
    padding:60px 40px; position:relative; overflow:hidden;
}
.auth-visual-logo { font-family:var(--font-hd); font-size:26px; font-weight:900; margin-bottom:48px; display:flex; align-items:center; gap:12px; }
.auth-visual-logo i { color:var(--purple); font-size:32px; }
.auth-visual-logo span { color:var(--cyan); }
.auth-visual-sphere {
    width:200px; height:200px; border-radius:50%;
    background:radial-gradient(circle at 35% 35%, rgba(138,43,226,.6), rgba(0,212,255,.2) 60%, transparent);
    box-shadow:0 0 60px rgba(138,43,226,.4), 0 0 120px rgba(0,212,255,.1);
    animation:sphere-pulse 4s ease-in-out infinite; margin-bottom:48px;
    position:relative;
}
.auth-visual-sphere::after { content:''; position:absolute; inset:-16px; border-radius:50%; border:1px solid rgba(0,212,255,.2); animation:spin 12s linear infinite; }
@keyframes sphere-pulse { 0%,100%{transform:scale(1);box-shadow:0 0 60px rgba(138,43,226,.4)} 50%{transform:scale(1.04);box-shadow:0 0 80px rgba(138,43,226,.5),0 0 140px rgba(0,212,255,.15)} }
.auth-visual-quote { font-family:var(--font-hd); font-size:13px; letter-spacing:4px; color:var(--muted); margin-bottom:40px; }
.auth-visual-features { list-style:none; display:flex; flex-direction:column; gap:14px; }
.auth-visual-features li { display:flex; align-items:center; gap:12px; font-size:14px; color:var(--muted); }
.auth-visual-features li i { color:var(--cyan); width:18px; text-align:center; }
.auth-visual-bg { position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:0; }
.auth-visual-bg span { position:absolute; border-radius:50%; background:var(--purple); opacity:.06; animation:float-orb 8s ease-in-out infinite; }
@keyframes float-orb { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-20px)} }
.auth-split-form {
    background:rgba(15,15,38,.95); display:flex; align-items:center;
    justify-content:center; padding:40px 32px; min-height:100vh;
}
.auth-form-inner { width:100%; max-width:360px; }
.auth-form-inner .section-badge { display:inline-block; margin-bottom:20px; }
.auth-form-inner h2 { font-family:var(--font-hd); font-size:26px; font-weight:800; margin-bottom:6px; }
.auth-form-inner > p { color:var(--muted); font-size:14px; margin-bottom:28px; }
.auth-form-group { margin-bottom:16px; }
.auth-form-group label { display:block; font-size:12px; color:var(--muted); margin-bottom:7px; letter-spacing:.3px; }
.auth-form-group input {
    width:100%; padding:13px 16px; background:rgba(255,255,255,.05);
    border:1px solid var(--border); border-radius:var(--radius-sm);
    color:var(--text); font-family:var(--font); font-size:15px; outline:none; transition:var(--t);
}
.auth-form-group input:focus { border-color:var(--purple); background:rgba(138,43,226,.07); }
.auth-form-footer { margin-top:20px; text-align:center; font-size:14px; color:var(--muted); }
.auth-form-footer a { color:var(--cyan); }
.auth-form-error { background:rgba(255,68,68,.1); border:1px solid rgba(255,68,68,.3); color:#f55; border-radius:var(--radius-sm); padding:10px 14px; font-size:13px; margin-bottom:14px; }
@media (max-width:768px) {
    .auth-split { grid-template-columns:1fr; }
    .auth-split-visual { display:none; }
    .auth-split-form { min-height:100vh; padding:40px 24px; }
}

/* ===== PATCH v2: betere form-inputs, complete mobile, extra polish ===== */

/* Overal: inputs makkelijker zichtbaar */
input, textarea, select {
    -webkit-appearance: none;
    appearance: none;
}

/* Contact form inputs verhoogde zichtbaarheid */
.cf-group input,
.cf-group textarea {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(138,43,226,.35);
    color: var(--text);
}
.cf-group input:focus,
.cf-group textarea:focus {
    border-color: var(--purple);
    background: rgba(138,43,226,.08);
    box-shadow: 0 0 0 3px rgba(138,43,226,.12);
}
.cf-group input::placeholder,
.cf-group textarea::placeholder { color: var(--muted); opacity: .8; }

/* Request form inputs */
.form-group input,
.form-group textarea {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(138,43,226,.3);
}
.form-group input:focus,
.form-group textarea:focus {
    border-color: var(--purple);
    box-shadow: 0 0 0 3px rgba(138,43,226,.1);
}

/* Search box input */
.search-box input {
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(138,43,226,.3);
}
.search-box input:focus {
    border-color: var(--purple);
    box-shadow: 0 0 0 3px rgba(138,43,226,.1);
}

/* Auth form inputs zichtbaarder */
.auth-form-group input {
    background: rgba(255,255,255,.06);
    border: 1px solid rgba(138,43,226,.35);
}
.auth-form-group input:focus {
    border-color: var(--cyan);
    background: rgba(0,212,255,.05);
    box-shadow: 0 0 0 3px rgba(0,212,255,.08);
}
.auth-form-group input::placeholder { color: var(--muted); opacity: .7; }

/* Contact form card extra polish */
.contact-form-card {
    border: 1px solid rgba(138,43,226,.3);
    box-shadow: 0 4px 40px rgba(138,43,226,.08);
}

/* CF label makkelijker leesbaar */
.cf-label {
    font-size: 12px;
    font-weight: 500;
    color: rgba(120,120,170,.9);
    letter-spacing: .5px;
}

/* Nieuws pagina thumb placeholder */
.news-thumb-placeholder {
    width:100%; height:100%;
    display:flex; align-items:center; justify-content:center;
    font-size:36px; color:rgba(138,43,226,.25);
    background: linear-gradient(135deg, rgba(138,43,226,.06), rgba(0,212,255,.04));
}

/* Schedule section: verberg dag-naam op smal scherm */
@media (max-width:600px) {
    .schedule-row { grid-template-columns:72px 1fr; padding:14px; }
    .schedule-genre { display:none; }
    .schedule-show small { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
}

/* Request grid op tablet/mobiel */
@media (max-width:860px) {
    .request-grid { grid-template-columns:1fr; gap:24px; }
    .recent-requests { order:1; }
    .request-form-card { order:2; }
}

/* Contact pagina op tablet */
@media (max-width:860px) {
    .contact-cards { grid-template-columns:1fr 1fr; }
    .contact-page-container { padding:0; }
}
@media (max-width:600px) {
    .contact-cards { grid-template-columns:1fr; }
    .contact-form-card { padding:24px 16px; }
    .cf-row { grid-template-columns:1fr; }
}

/* DJ grid op mobiel */
@media (max-width:600px) {
    .djs-grid { grid-template-columns:1fr 1fr; gap:12px; }
}
@media (max-width:400px) {
    .djs-grid { grid-template-columns:1fr; }
}

/* Footer op mobiel */
@media (max-width:600px) {
    .footer-grid { grid-template-columns:1fr; gap:28px; }
    .footer-bottom { flex-direction:column; gap:6px; text-align:center; font-size:12px; }
}

/* Auth split — betere mobiel ervaring */
@media (max-width:480px) {
    .auth-split-form { padding:32px 20px; }
    .auth-form-inner h2 { font-size:22px; }
}

/* Player bar op kleine schermen */
@media (max-width:380px) {
    .pb-info { max-width:120px; }
    .pb-title { font-size:12px; }
}

/* Top 25 op hele kleine schermen */
@media (max-width:360px) {
    .top25-row { grid-template-columns:28px 1fr auto; gap:8px; padding:10px 12px; }
    .top25-rank { font-size:14px; }
    .vote-btn { padding:6px 10px; font-size:12px; }
}

/* Algemene section spacing mobiel */
@media (max-width:480px) {
    .section { padding:48px 0; }
    .section-header { margin-bottom:28px; }
    .section-title { font-size:26px; }
    .hero-actions .btn { font-size:13px; padding:10px 20px; }
    .about-features { grid-template-columns:1fr; gap:12px; }
    .about-content { gap:32px; }
    .stats-section { padding:40px 0; }
}

/* About sectie op mobiel */
@media (max-width:768px) {
    .about-content { grid-template-columns:1fr; }
    .about-visual { display:none; }
}

/* Schedule login-note */
.schedule-empty { padding:32px; text-align:center; color:var(--muted); font-size:14px; }

/* Contact CTA mobile */
@media (max-width:480px) {
    .contact-cta-title { font-size:22px; }
    .contact-cta-desc  { font-size:14px; }
}

/* Article pagina mobiel */
@media (max-width:600px) {
    .article-hero { min-height:300px; }
    .article-hero-content { padding:32px 16px 24px; }
    .article-title { font-size:24px; }
    .article-body-wrap { padding:28px 16px 60px; }
    .article-excerpt-lead { font-size:15px; }
    .article-content { font-size:15px; }
    .article-meta-bar { flex-wrap:wrap; gap:8px; }
    .article-readtime { margin-left:0; }
}

/* News grid mobiel */
@media (max-width:600px) {
    .news-grid { grid-template-columns:1fr; }
    .news-card { margin-bottom:4px; }
}

/* Page hero mobiel */
@media (max-width:480px) {
    .page-hero { padding:100px 0 32px; }
    .page-hero h1 { font-size:28px; }
    .page-hero p { font-size:14px; }
}

/* Navbar logo op mobiel kleiner */
@media (max-width:380px) {
    .nav-logo { font-size:15px; }
    .nav-logo i { font-size:18px; }
}

/* ===== Einde patch v2 ===== */
