/* /Components/Layout/MainLayout.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════════
   Magizhchi FM · MainLayout — Dark + Light Theme System
   ═══════════════════════════════════════════════════════════════ */

/* ── Dark Theme (default) ──────────────────────────────────────── */
:root[b-1w8m3y4nkw],
[data-theme="dark"][b-1w8m3y4nkw] {
    --bg-deep:        #07071a;
    --bg-surface:     #0d0d27;
    --bg-card:        rgba(15,15,40,0.85);
    --col-primary:    #7c3aed;
    --col-accent:     #ec4899;
    --col-gold:       #f59e0b;
    --col-text:       #e2e8f0;
    --col-muted:      #94a3b8;
    --col-border:     rgba(124,58,237,0.25);
    --col-toprow-bg:  rgba(13,13,39,0.92);
    --col-toprow-bd:  rgba(124,58,237,0.2);
    --col-btn-bg:     rgba(255,255,255,0.07);
    --col-btn-hover:  rgba(255,255,255,0.14);
    --col-btn-text:   #94a3b8;
    --player-bg:      rgba(7,7,26,0.93);
    --sidebar-grad:   linear-gradient(180deg, #0d1b4b 0%, #2d0540 100%);
    --player-h:       76px;
    --sidebar-w:      250px;
}

/* ── Light Theme ───────────────────────────────────────────────── */
[data-theme="light"][b-1w8m3y4nkw] {
    --bg-deep:        #f0f0fa;
    --bg-surface:     #ffffff;
    --bg-card:        rgba(255,255,255,0.92);
    --col-primary:    #6d28d9;
    --col-accent:     #db2777;
    --col-gold:       #d97706;
    --col-text:       #1e1b4b;
    --col-muted:      #6b7280;
    --col-border:     rgba(109,40,217,0.2);
    --col-toprow-bg:  rgba(255,255,255,0.95);
    --col-toprow-bd:  rgba(109,40,217,0.12);
    --col-btn-bg:     rgba(109,40,217,0.07);
    --col-btn-hover:  rgba(109,40,217,0.14);
    --col-btn-text:   #6d28d9;
    --player-bg:      rgba(30,27,75,0.97);
    --sidebar-grad:   linear-gradient(180deg, #1e1b4b 0%, #4a0e6e 100%);
}

/* ── Global ────────────────────────────────────────────────────── */
*[b-1w8m3y4nkw], *[b-1w8m3y4nkw]::before, *[b-1w8m3y4nkw]::after { box-sizing: border-box; }

html[b-1w8m3y4nkw] { transition: background-color 0.35s ease, color 0.35s ease; }

body[b-1w8m3y4nkw] {
    font-family: 'Nunito', sans-serif;
    background: var(--bg-deep);
    color: var(--col-text);
    margin: 0;
    transition: background-color 0.35s, color 0.35s;
}

/* ── Page Shell ────────────────────────────────────────────────── */
.page[b-1w8m3y4nkw] {
    position: relative;
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

main[b-1w8m3y4nkw] {
    flex: 1;
    padding-bottom: calc(var(--player-h) + 16px);
}

/* ── Sidebar ───────────────────────────────────────────────────── */
.sidebar[b-1w8m3y4nkw] {
    background: var(--sidebar-grad);
    border-right: 1px solid var(--col-border);
    transition: background 0.35s;
}

/* ── Top Row ───────────────────────────────────────────────────── */
.top-row[b-1w8m3y4nkw] {
    background: var(--col-toprow-bg);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--col-toprow-bd);
    height: 3.5rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: background 0.35s, border-color 0.35s;
}

.top-link[b-1w8m3y4nkw] {
    color: var(--col-muted);
    text-decoration: none;
    font-size: 0.82rem;
    display: flex;
    align-items: center;
    gap: 6px;
    transition: color 0.2s;
}
.top-link:hover[b-1w8m3y4nkw] { color: var(--col-text); }

.top-actions[b-1w8m3y4nkw] {
    display: flex;
    align-items: center;
    gap: 8px;
}

/* ── Top Buttons ───────────────────────────────────────────────── */
.top-btn[b-1w8m3y4nkw] {
    display: flex;
    align-items: center;
    gap: 6px;
    background: var(--col-btn-bg);
    border: 1px solid var(--col-border);
    border-radius: 8px;
    color: var(--col-btn-text);
    font-family: 'Nunito', sans-serif;
    font-size: 0.8rem;
    font-weight: 600;
    padding: 6px 12px;
    cursor: pointer;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
}
.top-btn:hover[b-1w8m3y4nkw] {
    background: var(--col-btn-hover);
    color: var(--col-text);
}

.theme-toggle[b-1w8m3y4nkw] { padding: 6px 10px; }

.install-btn[b-1w8m3y4nkw] {
    background: linear-gradient(135deg, rgba(124,58,237,0.15), rgba(236,72,153,0.1));
    border-color: rgba(124,58,237,0.35);
    color: #a78bfa;
    animation: installPulse-b-1w8m3y4nkw 2.5s ease-in-out infinite;
}
@keyframes installPulse-b-1w8m3y4nkw {
    0%, 100% { box-shadow: none; }
    50%       { box-shadow: 0 0 12px rgba(124,58,237,0.35); }
}

/* ── Article ───────────────────────────────────────────────────── */
article.content[b-1w8m3y4nkw] { padding: 1.5rem; }

/* ═══════════════════════════════════════════════════════════════
   BOTTOM PLAYER
   ═══════════════════════════════════════════════════════════════ */
.bottom-player[b-1w8m3y4nkw] {
    position: fixed;
    bottom: 0; left: 0;
    width: 100%;
    height: var(--player-h);
    background: var(--player-bg);
    backdrop-filter: blur(24px) saturate(160%);
    border-top: 1px solid rgba(124,58,237,0.35);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 24px;
    z-index: 2000;
    gap: 16px;
    transform: translateY(100%);
    transition: transform 0.45s cubic-bezier(0.34,1.56,0.64,1);
    box-shadow: 0 -8px 40px rgba(124,58,237,0.12);
}
.bottom-player.visible[b-1w8m3y4nkw] { transform: translateY(0); }

.bottom-player[b-1w8m3y4nkw]::before {
    content: '';
    position: absolute;
    top: -1px; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--col-primary) 30%, var(--col-accent) 70%, transparent);
    background-size: 200% 100%;
    animation: borderFlow-b-1w8m3y4nkw 4s linear infinite;
}
@keyframes borderFlow-b-1w8m3y4nkw {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

/* ── Player Sections ───────────────────────────────────────────── */
.player-section[b-1w8m3y4nkw] { display: flex; align-items: center; }
.player-left[b-1w8m3y4nkw]   { flex: 0 0 auto; gap: 12px; min-width: 220px; max-width: 280px; }
.player-center[b-1w8m3y4nkw] { flex: 1; flex-direction: column; gap: 6px; min-width: 0; }
.player-right[b-1w8m3y4nkw]  { flex: 0 0 auto; flex-direction: column; align-items: flex-end; gap: 6px; min-width: 140px; }

/* ── Album Art ─────────────────────────────────────────────────── */
.album-art-wrap[b-1w8m3y4nkw] { position: relative; flex-shrink: 0; }

.player-album-art[b-1w8m3y4nkw] {
    width: 52px; height: 52px;
    border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(124,58,237,0.45);
    transition: border-color 0.3s;
}
.player-album-art.spinning[b-1w8m3y4nkw] {
    animation: vinylSpin-b-1w8m3y4nkw 4s linear infinite;
    border-color: var(--col-accent);
}
@keyframes vinylSpin-b-1w8m3y4nkw {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}
.art-placeholder[b-1w8m3y4nkw] {
    background: linear-gradient(135deg, var(--col-primary), var(--col-accent));
    display: flex; align-items: center; justify-content: center;
}
.art-glow[b-1w8m3y4nkw] {
    position: absolute; inset: -6px; border-radius: 50%;
    background: radial-gradient(circle, rgba(236,72,153,0.25) 0%, transparent 70%);
    animation: glowPulse-b-1w8m3y4nkw 2.5s ease-in-out infinite;
    pointer-events: none; opacity: 0; transition: opacity 0.3s;
}
.player-album-art.spinning ~ .art-glow[b-1w8m3y4nkw] { opacity: 1; }
@keyframes glowPulse-b-1w8m3y4nkw {
    0%, 100% { transform: scale(1); opacity: 0.6; }
    50%       { transform: scale(1.15); opacity: 1; }
}

/* ── Track Text ────────────────────────────────────────────────── */
.track-text[b-1w8m3y4nkw] { min-width: 0; overflow: hidden; }
.track-title[b-1w8m3y4nkw] {
    font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.9rem;
    color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 200px;
}
.track-artist[b-1w8m3y4nkw] {
    font-size: 0.78rem; color: rgba(255,255,255,0.5);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 200px; margin-top: 2px;
}

/* ── Waveform ──────────────────────────────────────────────────── */
.waveform-row[b-1w8m3y4nkw] {
    display: flex; align-items: flex-end; gap: 3px;
    height: 30px; justify-content: center; padding: 0 8px;
}
.bar[b-1w8m3y4nkw] {
    width: 3px; height: 4px;
    background: linear-gradient(to top, var(--col-primary), var(--col-accent));
    border-radius: 2px;
}
.bar.active[b-1w8m3y4nkw] {
    animation: waveAnim-b-1w8m3y4nkw 1.3s ease-in-out infinite alternate;
    animation-delay: var(--d, 0s);
}
@keyframes waveAnim-b-1w8m3y4nkw {
    0%   { height: 3px; }
    100% { height: var(--h, 20px); }
}

/* ── Controls Row ──────────────────────────────────────────────── */
.controls-row[b-1w8m3y4nkw] {
    display: flex; align-items: center; justify-content: center; gap: 16px;
}
.live-pill[b-1w8m3y4nkw] {
    display: flex; align-items: center; gap: 5px;
    background: rgba(239,68,68,0.12); border: 1px solid rgba(239,68,68,0.3);
    border-radius: 20px; padding: 2px 9px;
    font-size: 0.68rem; font-family: 'Poppins', sans-serif; font-weight: 700;
    color: #f87171; letter-spacing: 0.08em;
}
.live-dot[b-1w8m3y4nkw] {
    width: 6px; height: 6px; background: #ef4444; border-radius: 50%;
    animation: livePulse-b-1w8m3y4nkw 1.4s ease-in-out infinite;
}
@keyframes livePulse-b-1w8m3y4nkw {
    0%, 100% { opacity: 1; transform: scale(1); }
    50%       { opacity: 0.4; transform: scale(0.7); }
}
.play-pause-btn[b-1w8m3y4nkw] {
    width: 46px; height: 46px; border-radius: 50%; border: none; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, var(--col-primary), var(--col-accent));
    box-shadow: 0 0 20px rgba(124,58,237,0.45);
    transition: transform 0.15s, box-shadow 0.15s;
}
.play-pause-btn:hover[b-1w8m3y4nkw] { transform: scale(1.08); box-shadow: 0 0 28px rgba(236,72,153,0.65); }
.play-pause-btn:active[b-1w8m3y4nkw] { transform: scale(0.96); }

.listener-info[b-1w8m3y4nkw] {
    display: flex; align-items: center; gap: 4px;
    font-size: 0.76rem; color: rgba(255,255,255,0.4);
    font-family: 'Poppins', sans-serif; font-weight: 600;
}

/* ── Progress ──────────────────────────────────────────────────── */
.song-progress-bar[b-1w8m3y4nkw] {
    width: 100%; height: 3px;
    background: rgba(255,255,255,0.06); border-radius: 2px; overflow: hidden;
}
.song-progress-bar .progress-fill[b-1w8m3y4nkw] {
    height: 100%; background: linear-gradient(90deg, var(--col-primary), var(--col-accent));
    border-radius: 2px; transition: width 1s linear;
}

/* ── Right Panel ───────────────────────────────────────────────── */
.album-name[b-1w8m3y4nkw] {
    font-size: 0.72rem; color: rgba(255,255,255,0.35);
    text-align: right; white-space: nowrap; overflow: hidden;
    text-overflow: ellipsis; max-width: 130px; font-style: italic;
}
.volume-row[b-1w8m3y4nkw] { display: flex; align-items: center; gap: 8px; }
.volume-slider[b-1w8m3y4nkw] {
    -webkit-appearance: none; appearance: none;
    width: 90px; height: 4px;
    background: rgba(255,255,255,0.1); border-radius: 2px;
    outline: none; cursor: pointer;
}
.volume-slider[b-1w8m3y4nkw]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 12px; height: 12px; border-radius: 50%;
    background: var(--col-accent); cursor: pointer;
    box-shadow: 0 0 6px rgba(236,72,153,0.55);
    transition: transform 0.15s;
}
.volume-slider[b-1w8m3y4nkw]::-webkit-slider-thumb:hover { transform: scale(1.3); }

/* ── Copy Toast ────────────────────────────────────────────────── */
.copy-toast[b-1w8m3y4nkw] {
    position: fixed;
    bottom: calc(var(--player-h) + 20px);
    left: 50%; transform: translateX(-50%);
    background: rgba(16,16,40,0.95);
    border: 1px solid rgba(124,58,237,0.4);
    color: #a78bfa;
    font-family: 'Nunito', sans-serif;
    font-size: 0.85rem; font-weight: 600;
    padding: 8px 20px; border-radius: 30px;
    z-index: 3000;
    animation: toastIn-b-1w8m3y4nkw 0.3s ease, toastOut-b-1w8m3y4nkw 0.4s ease 1.8s forwards;
}
@keyframes toastIn-b-1w8m3y4nkw  { from { opacity: 0; transform: translateX(-50%) translateY(10px); } to { opacity: 1; transform: translateX(-50%) translateY(0); } }
@keyframes toastOut-b-1w8m3y4nkw { from { opacity: 1; } to { opacity: 0; } }

/* ── Error UI ──────────────────────────────────────────────────── */
#blazor-error-ui[b-1w8m3y4nkw] {
    background: rgba(127,29,29,0.95); color: #fca5a5;
    bottom: var(--player-h); box-shadow: 0 -2px 12px rgba(0,0,0,0.4);
    display: none; left: 0; padding: 0.6rem 1.25rem;
    position: fixed; width: 100%; z-index: 3000;
    font-family: 'Nunito', sans-serif; font-size: 0.875rem;
}
#blazor-error-ui .dismiss[b-1w8m3y4nkw] {
    cursor: pointer; position: absolute; right: 0.75rem; top: 0.5rem; color: #fca5a5;
}

/* ── Responsive ────────────────────────────────────────────────── */
@media (min-width: 641px) {
    .page[b-1w8m3y4nkw] { flex-direction: row; }
    .sidebar[b-1w8m3y4nkw] { width: var(--sidebar-w); height: 100vh; position: sticky; top: 0; flex-shrink: 0; }
    .top-row[b-1w8m3y4nkw] { position: sticky; top: 0; z-index: 100; padding-left: 2rem !important; padding-right: 1.5rem !important; }
    article[b-1w8m3y4nkw] { padding-left: 2rem !important; padding-right: 1.5rem !important; }
}
@media (max-width: 640px) {
    .bottom-player[b-1w8m3y4nkw] { padding: 0 12px; gap: 10px; }
    .player-left[b-1w8m3y4nkw] { min-width: 0; }
    .player-right[b-1w8m3y4nkw] { display: none; }
    .track-title[b-1w8m3y4nkw], .track-artist[b-1w8m3y4nkw] { max-width: 120px; }
}
@media (max-width: 480px) {
    .waveform-row[b-1w8m3y4nkw] { display: none; }
}
/* /Components/Layout/NavMenu.razor.rz.scp.css */
/* ── NavMenu — Magizhchi FM Sidebar ─────────────────────────────── */

.navbar-toggler[b-pt7wqi4rpe] {
    appearance: none; cursor: pointer;
    width: 3.5rem; height: 2.5rem;
    position: absolute; top: 0.5rem; right: 1rem;
    border: 1px solid rgba(255,255,255,0.15);
    background: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255%2C255%2C255%2C0.7%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") no-repeat center/1.6rem rgba(255,255,255,0.06);
    border-radius: 8px; transition: background-color 0.2s;
}
.navbar-toggler:checked[b-pt7wqi4rpe] { background-color: rgba(124,58,237,0.3); }

.top-row[b-pt7wqi4rpe] { height: 4rem; background: rgba(0,0,0,0.28); border-bottom: 1px solid rgba(255,255,255,0.07); padding: 0 0.75rem; }

/* Brand */
.navbar-brand[b-pt7wqi4rpe] { display: flex; align-items: center; gap: 10px; text-decoration: none !important; color: white !important; padding: 4px 0; }
.brand-logo-img[b-pt7wqi4rpe] { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; flex-shrink: 0; box-shadow: 0 0 0 2px rgba(255,255,255,0.1), 0 0 16px rgba(236,72,153,0.35); transition: box-shadow 0.3s; }
.navbar-brand:hover .brand-logo-img[b-pt7wqi4rpe] { box-shadow: 0 0 0 2px rgba(255,200,0,0.4), 0 0 22px rgba(245,158,11,0.45); }
.brand-text[b-pt7wqi4rpe] { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.brand-name[b-pt7wqi4rpe] { font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 1.05rem; color: #fff; letter-spacing: -0.01em; line-height: 1.1; }
.brand-fm[b-pt7wqi4rpe] { color: #fbbf24; margin-left: 2px; }
.brand-tagline[b-pt7wqi4rpe] { font-family: 'Nunito', sans-serif; font-size: 0.6rem; color: rgba(255,255,255,0.45); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 145px; }

/* On-Air Card */
.on-air-card[b-pt7wqi4rpe] { margin: 12px 12px 4px; padding: 10px 12px; border-radius: 12px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.08); display: flex; align-items: center; gap: 10px; transition: background 0.3s, border-color 0.3s; }
.on-air-card.live[b-pt7wqi4rpe]    { background: rgba(239,68,68,0.08);  border-color: rgba(239,68,68,0.2); }
.on-air-card.playing[b-pt7wqi4rpe] { background: rgba(124,58,237,0.12); border-color: rgba(124,58,237,0.3); }
.on-air-icon[b-pt7wqi4rpe] { width: 32px; height: 32px; border-radius: 8px; background: rgba(255,255,255,0.06); display: flex; align-items: center; justify-content: center; color: #94a3b8; flex-shrink: 0; }
.on-air-card.live .on-air-icon[b-pt7wqi4rpe]    { color: #f87171; background: rgba(239,68,68,0.1); }
.on-air-card.playing .on-air-icon[b-pt7wqi4rpe] { color: #a78bfa; background: rgba(124,58,237,0.15); }
.on-air-info[b-pt7wqi4rpe] { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 1px; }
.on-air-label[b-pt7wqi4rpe] { font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.7rem; color: #e2e8f0; letter-spacing: 0.05em; text-transform: uppercase; }
.on-air-sub[b-pt7wqi4rpe] { font-family: 'Nunito', sans-serif; font-size: 0.74rem; color: #64748b; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.on-air-wave[b-pt7wqi4rpe] { display: flex; align-items: flex-end; gap: 2px; height: 18px; flex-shrink: 0; }
.mini-bar[b-pt7wqi4rpe] { width: 3px; background: #a78bfa; border-radius: 2px; animation: miniWave-b-pt7wqi4rpe 1s ease-in-out infinite alternate; }
.mini-bar:nth-child(1)[b-pt7wqi4rpe] { --mh: 10px; animation-delay: 0s; }
.mini-bar:nth-child(2)[b-pt7wqi4rpe] { --mh: 18px; animation-delay: 0.2s; }
.mini-bar:nth-child(3)[b-pt7wqi4rpe] { --mh: 13px; animation-delay: 0.1s; }
@keyframes miniWave-b-pt7wqi4rpe { from { height: 3px; } to { height: var(--mh, 12px); } }

/* Nav links */
.nav-links[b-pt7wqi4rpe] { padding-top: 4px; }
.nav-item[b-pt7wqi4rpe]  { padding-bottom: 2px; }
.nav-item[b-pt7wqi4rpe]  .nav-link { display: flex; align-items: center; gap: 10px; color: rgba(255,255,255,0.65); text-decoration: none; font-family: 'Nunito', sans-serif; font-size: 0.88rem; font-weight: 600; padding: 10px 12px; border-radius: 10px; transition: background 0.2s, color 0.2s; border: none; background: none; width: 100%; cursor: pointer; }
.nav-item[b-pt7wqi4rpe]  .nav-link:hover { background: rgba(255,255,255,0.08); color: #fff; }
.nav-item[b-pt7wqi4rpe]  .nav-link.active { background: linear-gradient(135deg, rgba(124,58,237,0.25), rgba(236,72,153,0.14)); color: #fff; border: 1px solid rgba(124,58,237,0.28); }
.nav-icon[b-pt7wqi4rpe] { display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 8px; background: rgba(255,255,255,0.06); flex-shrink: 0; transition: background 0.2s; }
.nav-item[b-pt7wqi4rpe]  .nav-link.active .nav-icon { background: linear-gradient(135deg, #7c3aed, #ec4899); color: #fff; }

/* NEW badge on Song Requests */
.nav-badge[b-pt7wqi4rpe] {
    margin-left: auto;
    font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.58rem;
    letter-spacing: 0.08em; background: linear-gradient(135deg, #7c3aed, #ec4899);
    color: white; border-radius: 5px; padding: 2px 6px;
    animation: badgePulse-b-pt7wqi4rpe 2.5s ease-in-out infinite;
}
@keyframes badgePulse-b-pt7wqi4rpe { 0%,100% { opacity:1; } 50% { opacity:0.65; } }

/* Footer */
.sidebar-footer[b-pt7wqi4rpe] { position: absolute; bottom: 0; left: 0; right: 0; padding: 12px 16px; border-top: 1px solid rgba(255,255,255,0.07); display: flex; flex-direction: column; gap: 5px; }
.footer-link[b-pt7wqi4rpe] { display: flex; align-items: center; gap: 6px; font-family: 'Nunito', sans-serif; font-size: 0.76rem; color: rgba(255,255,255,0.35); text-decoration: none; transition: color 0.2s; }
.footer-link:hover[b-pt7wqi4rpe] { color: rgba(255,255,255,0.65); }
.version-tag[b-pt7wqi4rpe] { font-size: 0.68rem; color: rgba(255,255,255,0.2); font-family: 'Nunito', sans-serif; }

/* Scrollable */
.nav-scrollable[b-pt7wqi4rpe] { display: none; position: relative; height: calc(100% - 4rem); overflow-y: auto; overflow-x: hidden; }
.nav-scrollable[b-pt7wqi4rpe]::-webkit-scrollbar { width: 3px; }
.nav-scrollable[b-pt7wqi4rpe]::-webkit-scrollbar-track { background: transparent; }
.nav-scrollable[b-pt7wqi4rpe]::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); border-radius: 2px; }
.navbar-toggler:checked ~ .nav-scrollable[b-pt7wqi4rpe] { display: block; }

@media (min-width: 641px) {
    .navbar-toggler[b-pt7wqi4rpe] { display: none; }
    .nav-scrollable[b-pt7wqi4rpe] { display: block; }
}
/* /Components/Pages/About.razor.rz.scp.css */
/* ── About Page ─────────────────────────────────────────────────── */

.about-page[b-yj3800u7cn] { display: flex; flex-direction: column; gap: 28px; max-width: 860px; }

/* Hero */
.about-hero[b-yj3800u7cn] {
    position: relative;
    display: flex; align-items: center; gap: 28px;
    background: linear-gradient(135deg, rgba(124,58,237,0.1), rgba(236,72,153,0.06));
    border: 1px solid rgba(124,58,237,0.2);
    border-radius: 20px; padding: 32px 36px;
    overflow: hidden;
    animation: fadeUp-b-yj3800u7cn 0.6s ease forwards;
}

.about-hero-glow[b-yj3800u7cn] {
    position: absolute; top: -40px; right: -40px;
    width: 220px; height: 220px; border-radius: 50%;
    background: radial-gradient(circle, rgba(236,72,153,0.2) 0%, transparent 70%);
    pointer-events: none;
}

.about-logo[b-yj3800u7cn] {
    width: 110px; height: 110px; border-radius: 50%; object-fit: cover; flex-shrink: 0;
    box-shadow: 0 0 0 3px rgba(255,255,255,0.1), 0 12px 40px rgba(124,58,237,0.35);
    animation: logoFloat-b-yj3800u7cn 4s ease-in-out infinite;
}
@keyframes logoFloat-b-yj3800u7cn {
    0%,100% { transform: translateY(0); }
    50%      { transform: translateY(-6px); }
}

.about-hero-text[b-yj3800u7cn] { display: flex; flex-direction: column; gap: 4px; }

.about-title[b-yj3800u7cn] {
    font-family: 'Poppins', sans-serif; font-weight: 800;
    font-size: 2.2rem; color: var(--col-text); margin: 0; line-height: 1.1;
}
.title-fm[b-yj3800u7cn] { color: var(--col-accent); }

.about-tagline[b-yj3800u7cn]    { font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 1rem; color: var(--col-primary); margin: 0; }
.about-tagline-en[b-yj3800u7cn] { font-size: 0.85rem; color: var(--col-muted); margin: 0; font-style: italic; }

/* Section */
.about-section[b-yj3800u7cn] {
    display: flex; gap: 20px; align-items: flex-start;
    background: var(--bg-surface); border: 1px solid var(--col-border);
    border-radius: 18px; padding: 24px;
    animation: fadeUp-b-yj3800u7cn 0.5s ease both;
}

.about-section-icon[b-yj3800u7cn] {
    width: 48px; height: 48px; border-radius: 14px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 16px rgba(124,58,237,0.3);
}

.about-section-title[b-yj3800u7cn] {
    font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 1.1rem;
    color: var(--col-text); margin: 0 0 8px;
}

.about-section-text[b-yj3800u7cn] {
    font-size: 0.9rem; color: var(--col-muted); line-height: 1.7; margin: 0;
}
.about-section-text strong[b-yj3800u7cn] { color: var(--col-text); font-weight: 700; }
.about-section-text a[b-yj3800u7cn] { color: var(--col-primary); text-decoration: none; font-weight: 600; }
.about-section-text a:hover[b-yj3800u7cn] { text-decoration: underline; }

.about-link-btn[b-yj3800u7cn] {
    display: inline-flex; align-items: center; gap: 6px;
    margin-top: 14px;
    background: linear-gradient(135deg, var(--col-primary), var(--col-accent));
    color: white; text-decoration: none;
    font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.82rem;
    padding: 8px 18px; border-radius: 20px;
    transition: opacity 0.2s, transform 0.2s;
    box-shadow: 0 4px 14px rgba(124,58,237,0.35);
}
.about-link-btn:hover[b-yj3800u7cn] { opacity: 0.88; transform: translateY(-1px); }

/* Features Grid */
.about-features[b-yj3800u7cn] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(185px, 1fr));
    gap: 14px;
}

.feature-card[b-yj3800u7cn] {
    background: var(--bg-surface); border: 1px solid var(--col-border);
    border-radius: 16px; padding: 20px 18px;
    display: flex; flex-direction: column; gap: 10px;
    transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
    animation: fadeUp-b-yj3800u7cn 0.5s ease both;
}
.feature-card:hover[b-yj3800u7cn] {
    border-color: rgba(124,58,237,0.35); transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(124,58,237,0.1);
}

.feature-icon[b-yj3800u7cn] {
    width: 46px; height: 46px; border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
}
.feature-title[b-yj3800u7cn] { font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.92rem; color: var(--col-text); }
.feature-desc[b-yj3800u7cn]  { font-size: 0.8rem; color: var(--col-muted); line-height: 1.55; }

/* Stats */
.about-stats[b-yj3800u7cn] {
    display: flex; align-items: center; justify-content: space-around;
    background: linear-gradient(135deg, rgba(124,58,237,0.08), rgba(236,72,153,0.05));
    border: 1px solid rgba(124,58,237,0.18);
    border-radius: 18px; padding: 24px 20px;
    flex-wrap: wrap; gap: 16px;
}

.stat-item[b-yj3800u7cn] { text-align: center; padding: 4px 12px; }
.stat-num[b-yj3800u7cn] {
    font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 1.8rem;
    color: var(--col-text); line-height: 1;
    background: linear-gradient(135deg, var(--col-primary), var(--col-accent));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.stat-lbl[b-yj3800u7cn] { font-size: 0.76rem; color: var(--col-muted); margin-top: 4px; font-weight: 600; }
.stat-divider[b-yj3800u7cn] { width: 1px; height: 40px; background: var(--col-border); }

/* Contact */
.about-contact[b-yj3800u7cn] {
    background: var(--bg-surface); border: 1px solid var(--col-border);
    border-radius: 18px; padding: 28px; text-align: center;
    animation: fadeUp-b-yj3800u7cn 0.5s ease both;
}
.about-contact-title[b-yj3800u7cn] { font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 1.2rem; color: var(--col-text); margin: 0 0 6px; }
.about-contact-sub[b-yj3800u7cn]   { font-size: 0.87rem; color: var(--col-muted); margin: 0 0 18px; }

.contact-links[b-yj3800u7cn] { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.contact-chip[b-yj3800u7cn] {
    display: flex; align-items: center; gap: 7px;
    background: var(--col-btn-bg); border: 1px solid var(--col-border);
    color: var(--col-text); text-decoration: none;
    font-family: 'Nunito', sans-serif; font-size: 0.85rem; font-weight: 600;
    padding: 9px 18px; border-radius: 30px;
    transition: background 0.2s, border-color 0.2s, transform 0.15s;
}
.contact-chip:hover[b-yj3800u7cn] { background: var(--col-btn-hover); border-color: var(--col-primary); transform: translateY(-1px); }

@keyframes fadeUp-b-yj3800u7cn { from { opacity:0; transform: translateY(14px); } to { opacity:1; transform: translateY(0); } }

@media (max-width: 600px) {
    .about-hero[b-yj3800u7cn] { flex-direction: column; align-items: center; text-align: center; padding: 24px 20px; }
    .about-section[b-yj3800u7cn] { flex-direction: column; }
    .about-features[b-yj3800u7cn] { grid-template-columns: 1fr 1fr; }
    .stat-divider[b-yj3800u7cn] { display: none; }
    .about-stats[b-yj3800u7cn] { gap: 20px; }
}
@media (max-width: 400px) {
    .about-features[b-yj3800u7cn] { grid-template-columns: 1fr; }
}
/* /Components/Pages/EmbedWidget.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════════
   Magizhchi FM — Embed Widget Styles
   Designed to fit in a 340×80px iframe on magizhchi.net
   ═══════════════════════════════════════════════════════════════ */

*[b-cpw4wp1ujt] { box-sizing: border-box; margin: 0; padding: 0; }

body[b-cpw4wp1ujt] {
    background: transparent;
    font-family: 'Nunito', sans-serif;
}

.widget[b-cpw4wp1ujt] {
    display: flex;
    align-items: center;
    gap: 12px;
    background: linear-gradient(135deg, rgba(13,13,39,0.97), rgba(45,5,64,0.97));
    border: 1px solid rgba(124,58,237,0.3);
    border-radius: 16px;
    padding: 12px 14px;
    width: 340px;
    min-height: 72px;
    box-shadow: 0 8px 32px rgba(0,0,0,0.5), 0 0 0 1px rgba(236,72,153,0.06);
    position: relative;
    overflow: hidden;
    transition: border-color 0.3s;
}

.widget[b-cpw4wp1ujt]::before {
    content: '';
    position: absolute;
    top: -1px; left: 0; right: 0;
    height: 1px;
    background: linear-gradient(90deg, transparent, #7c3aed 40%, #ec4899 70%, transparent);
    background-size: 200% 100%;
    animation: widgetBorder-b-cpw4wp1ujt 4s linear infinite;
}

@keyframes widgetBorder-b-cpw4wp1ujt {
    0%   { background-position: 200% 0; }
    100% { background-position: -200% 0; }
}

.widget.playing[b-cpw4wp1ujt] { border-color: rgba(124,58,237,0.5); }

/* ── Art ───────────────────────────────────────────────────────── */
.widget-art-wrap[b-cpw4wp1ujt] { position: relative; flex-shrink: 0; }

.widget-art[b-cpw4wp1ujt] {
    width: 48px; height: 48px; border-radius: 50%;
    object-fit: cover;
    border: 2px solid rgba(124,58,237,0.4);
    flex-shrink: 0;
    transition: border-color 0.3s;
}

.widget-art.spin[b-cpw4wp1ujt] {
    animation: widgetSpin-b-cpw4wp1ujt 4s linear infinite;
    border-color: #ec4899;
}

@keyframes widgetSpin-b-cpw4wp1ujt {
    from { transform: rotate(0deg); }
    to   { transform: rotate(360deg); }
}

.art-fallback[b-cpw4wp1ujt] {
    background: linear-gradient(135deg, #7c3aed, #ec4899);
    display: flex; align-items: center; justify-content: center;
}

.art-ring[b-cpw4wp1ujt] {
    position: absolute; inset: -4px; border-radius: 50%;
    border: 2px solid transparent;
    background: linear-gradient(#0d0d27, #0d0d27) padding-box,
                linear-gradient(135deg, #7c3aed, #ec4899) border-box;
    opacity: 0; transition: opacity 0.4s;
}
.widget.playing .art-ring[b-cpw4wp1ujt] { opacity: 1; animation: ringPulse-b-cpw4wp1ujt 2s ease-in-out infinite; }
@keyframes ringPulse-b-cpw4wp1ujt { 0%,100% { transform: scale(1); } 50% { transform: scale(1.06); } }

/* ── Info ──────────────────────────────────────────────────────── */
.widget-info[b-cpw4wp1ujt] { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 2px; }

.widget-station[b-cpw4wp1ujt] {
    display: flex; align-items: center; gap: 5px;
    font-family: 'Poppins', sans-serif; font-weight: 700;
    font-size: 0.65rem; color: rgba(255,255,255,0.5);
    letter-spacing: 0.06em; text-transform: uppercase;
}

.station-dot[b-cpw4wp1ujt] {
    width: 5px; height: 5px; border-radius: 50%;
    background: #ef4444; flex-shrink: 0;
}
.station-dot.pulse[b-cpw4wp1ujt] { animation: dotPulse-b-cpw4wp1ujt 1.4s ease-in-out infinite; }
@keyframes dotPulse-b-cpw4wp1ujt {
    0%,100% { box-shadow: 0 0 0 0 rgba(239,68,68,0.7); }
    70%      { box-shadow: 0 0 0 5px rgba(239,68,68,0); }
}

.widget-title[b-cpw4wp1ujt] {
    font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.85rem;
    color: #fff; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.widget-artist[b-cpw4wp1ujt] {
    font-size: 0.72rem; color: rgba(255,255,255,0.45);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* ── Controls ──────────────────────────────────────────────────── */
.widget-controls[b-cpw4wp1ujt] { display: flex; flex-direction: column; align-items: center; gap: 6px; flex-shrink: 0; }

.widget-play[b-cpw4wp1ujt] {
    width: 36px; height: 36px; border-radius: 50%; border: none; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, #7c3aed, #ec4899);
    box-shadow: 0 0 14px rgba(124,58,237,0.5);
    transition: transform 0.15s, box-shadow 0.15s;
}
.widget-play:hover[b-cpw4wp1ujt] { transform: scale(1.1); box-shadow: 0 0 20px rgba(236,72,153,0.6); }
.widget-play:active[b-cpw4wp1ujt] { transform: scale(0.95); }

.widget-open[b-cpw4wp1ujt] {
    display: flex; align-items: center;
    font-size: 0.6rem; color: rgba(255,255,255,0.3);
    text-decoration: none; gap: 3px;
    transition: color 0.2s;
}
.widget-open:hover[b-cpw4wp1ujt] { color: rgba(255,255,255,0.7); }
/* /Components/Pages/Home.razor.rz.scp.css */
/* ═══════════════════════════════════════════════════════════════
   Magizhchi FM — Home Page (supports light/dark via CSS vars)
   ═══════════════════════════════════════════════════════════════ */

.radio-home[b-cadde16wsl] {
    position: relative;
    min-height: calc(100vh - 3.5rem - 76px);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ── Blurred Hero Background ───────────────────────────────────── */
.hero-bg[b-cadde16wsl] {
    position: absolute; inset: -40px;
    background-size: cover; background-position: center;
    filter: blur(60px) saturate(1.4) brightness(0.3);
    transform: scale(1.1);
    transition: background-image 1.5s ease;
}

.hero-overlay[b-cadde16wsl] {
    position: absolute; inset: 0;
    background: radial-gradient(ellipse at center,
        rgba(7,7,26,0.5) 0%, rgba(7,7,26,0.85) 65%, rgba(7,7,26,0.98) 100%
    );
}

/* Light theme adjustments */
[data-theme="light"] .hero-overlay[b-cadde16wsl] {
    background: radial-gradient(ellipse at center,
        rgba(240,240,250,0.6) 0%, rgba(240,240,250,0.88) 65%, rgba(240,240,250,0.98) 100%
    );
}
[data-theme="light"] .hero-bg[b-cadde16wsl] {
    filter: blur(60px) saturate(1.2) brightness(0.65);
}

/* ── Hero Content ──────────────────────────────────────────────── */
.hero-content[b-cadde16wsl] {
    position: relative; z-index: 10;
    display: flex; flex-direction: column; align-items: center;
    gap: 32px; padding: 20px 10px;
    width: 100%; max-width: 900px;
    animation: heroReveal-b-cadde16wsl 0.8s cubic-bezier(0.22,1,0.36,1) forwards;
}
@keyframes heroReveal-b-cadde16wsl {
    from { opacity: 0; transform: translateY(28px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* ── Station Badge ─────────────────────────────────────────────── */
.station-badge[b-cadde16wsl] {
    display: flex; align-items: center; gap: 8px;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 30px; padding: 6px 16px;
    backdrop-filter: blur(10px);
}
[data-theme="light"] .station-badge[b-cadde16wsl] {
    background: rgba(109,40,217,0.07);
    border-color: rgba(109,40,217,0.18);
}
.badge-dot[b-cadde16wsl] { width: 8px; height: 8px; border-radius: 50%; background: #ef4444; flex-shrink: 0; }
.badge-dot.pulse[b-cadde16wsl] { animation: dotPulse-b-cadde16wsl 1.4s ease-in-out infinite; }
@keyframes dotPulse-b-cadde16wsl {
    0%, 100% { box-shadow: 0 0 0 0 rgba(239,68,68,0.7); }
    70%       { box-shadow: 0 0 0 8px rgba(239,68,68,0); }
}
.badge-label[b-cadde16wsl] { font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 0.85rem; color: var(--col-text); }
.badge-sep[b-cadde16wsl]   { color: rgba(255,255,255,0.3); }
.badge-live[b-cadde16wsl]  { font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.72rem; color: var(--col-accent); letter-spacing: 0.12em; }

/* ── Now Playing Card ──────────────────────────────────────────── */
.now-playing-card[b-cadde16wsl] {
    display: flex; align-items: center; gap: 48px;
    background: rgba(13,13,39,0.65);
    border: 1px solid rgba(124,58,237,0.2);
    border-radius: 24px; padding: 36px 44px;
    backdrop-filter: blur(28px) saturate(150%);
    width: 100%;
    box-shadow: 0 0 0 1px rgba(236,72,153,0.04), 0 32px 80px rgba(0,0,0,0.45), inset 0 1px 0 rgba(255,255,255,0.05);
}
[data-theme="light"] .now-playing-card[b-cadde16wsl] {
    background: rgba(255,255,255,0.75);
    border-color: rgba(109,40,217,0.18);
    box-shadow: 0 20px 60px rgba(109,40,217,0.12), inset 0 1px 0 rgba(255,255,255,0.9);
}

/* ── Vinyl ─────────────────────────────────────────────────────── */
.vinyl-wrap[b-cadde16wsl] { position: relative; flex-shrink: 0; width: 200px; height: 200px; }
.vinyl-disc[b-cadde16wsl] {
    width: 200px; height: 200px; border-radius: 50%;
    background: radial-gradient(circle at 50%, #1a1a2e 0%, #16162a 30%, #0d0d1f 50%, #1a1a2e 100%);
    position: relative;
    box-shadow: 0 0 0 1px rgba(255,255,255,0.04), 0 20px 60px rgba(0,0,0,0.65);
}
.vinyl-disc.spinning[b-cadde16wsl] { animation: vinylSpin-b-cadde16wsl 5s linear infinite; }
@keyframes vinylSpin-b-cadde16wsl { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.vinyl-track-1[b-cadde16wsl], .vinyl-track-2[b-cadde16wsl] {
    position: absolute; border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.04);
    top: 50%; left: 50%; transform: translate(-50%,-50%);
}
.vinyl-track-1[b-cadde16wsl] { width: 170px; height: 170px; }
.vinyl-track-2[b-cadde16wsl] { width: 140px; height: 140px; }
.vinyl-center[b-cadde16wsl] {
    position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
    width: 100px; height: 100px; border-radius: 50%; overflow: hidden;
    border: 3px solid rgba(0,0,0,0.5); box-shadow: 0 0 0 1px rgba(255,255,255,0.08);
}
.vinyl-art[b-cadde16wsl] { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
.vinyl-art-placeholder[b-cadde16wsl] {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, #7c3aed, #ec4899);
    display: flex; align-items: center; justify-content: center; border-radius: 50%;
}
.vinyl-needle[b-cadde16wsl] {
    position: absolute; top: -8px; right: -12px;
    width: 14px; height: 80px;
    transform-origin: top center; transform: rotate(-28deg);
    transition: transform 0.8s cubic-bezier(0.34,1.56,0.64,1); z-index: 5;
}
.vinyl-needle.dropped[b-cadde16wsl] { transform: rotate(-5deg); }
.needle-arm[b-cadde16wsl] { width: 3px; height: 65px; background: linear-gradient(to bottom, #94a3b8, #475569); border-radius: 2px; margin: 0 auto; }
.needle-tip[b-cadde16wsl] { width: 8px; height: 8px; border-radius: 50%; background: #f59e0b; margin: 2px auto 0; box-shadow: 0 0 6px rgba(245,158,11,0.6); }
.vinyl-glow[b-cadde16wsl] {
    position: absolute; bottom: -20px; left: 50%; transform: translateX(-50%);
    width: 160px; height: 40px; background: rgba(124,58,237,0.25);
    border-radius: 50%; filter: blur(16px); opacity: 0; transition: opacity 0.5s;
}
.vinyl-glow.active[b-cadde16wsl] { opacity: 1; }

/* ── Song Details ──────────────────────────────────────────────── */
.song-details[b-cadde16wsl] { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 10px; }

.song-top-row[b-cadde16wsl] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}

.song-meta-tag[b-cadde16wsl] {
    display: inline-flex; align-items: center;
    font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.68rem;
    letter-spacing: 0.14em; text-transform: uppercase; color: #a78bfa;
    background: rgba(124,58,237,0.12); border: 1px solid rgba(124,58,237,0.25);
    padding: 3px 10px; border-radius: 20px; width: fit-content;
}
[data-theme="light"] .song-meta-tag[b-cadde16wsl] { color: #6d28d9; background: rgba(109,40,217,0.08); border-color: rgba(109,40,217,0.2); }

/* ── Share Buttons ─────────────────────────────────────────────── */
.share-buttons[b-cadde16wsl] {
    display: flex; align-items: center; gap: 6px;
}

.share-btn[b-cadde16wsl] {
    display: flex; align-items: center; gap: 5px;
    font-family: 'Nunito', sans-serif; font-size: 0.75rem; font-weight: 700;
    border: 1px solid; border-radius: 20px; padding: 4px 11px;
    cursor: pointer; transition: all 0.2s; white-space: nowrap;
}

.share-btn.whatsapp[b-cadde16wsl] {
    background: rgba(37,211,102,0.1); border-color: rgba(37,211,102,0.3); color: #25d366;
}
.share-btn.whatsapp:hover[b-cadde16wsl] { background: rgba(37,211,102,0.2); transform: translateY(-1px); }

.share-btn.twitter[b-cadde16wsl] {
    background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.15); color: #e2e8f0;
}
[data-theme="light"] .share-btn.twitter[b-cadde16wsl] { background: rgba(0,0,0,0.04); border-color: rgba(0,0,0,0.12); color: #1e1b4b; }
.share-btn.twitter:hover[b-cadde16wsl] { background: rgba(255,255,255,0.12); transform: translateY(-1px); }

.share-btn.copy[b-cadde16wsl] {
    background: rgba(124,58,237,0.08); border-color: rgba(124,58,237,0.25); color: #a78bfa;
    padding: 4px 9px;
}
.share-btn.copy.copied[b-cadde16wsl] { background: rgba(34,197,94,0.1); border-color: rgba(34,197,94,0.3); color: #4ade80; }
.share-btn.copy:hover[b-cadde16wsl]  { background: rgba(124,58,237,0.15); transform: translateY(-1px); }

/* ── Song Title / Artist ───────────────────────────────────────── */
.song-title[b-cadde16wsl] {
    font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 1.75rem;
    color: var(--col-text); margin: 0; line-height: 1.2; letter-spacing: -0.02em; word-break: break-word;
}
.song-artist[b-cadde16wsl] { font-family: 'Nunito', sans-serif; font-size: 1rem; color: var(--col-muted); font-weight: 600; }
.song-album[b-cadde16wsl] {
    display: flex; align-items: center; gap: 5px;
    font-size: 0.82rem; color: var(--col-muted); font-style: italic; font-family: 'Nunito', sans-serif; opacity: 0.7;
}

/* ── Progress ──────────────────────────────────────────────────── */
.progress-section[b-cadde16wsl] { display: flex; flex-direction: column; gap: 5px; }
.progress-track[b-cadde16wsl] {
    position: relative; height: 4px;
    background: rgba(255,255,255,0.08); border-radius: 3px; overflow: visible;
}
[data-theme="light"] .progress-track[b-cadde16wsl] { background: rgba(0,0,0,0.08); }
.progress-fill[b-cadde16wsl] {
    position: relative; height: 100%;
    background: linear-gradient(90deg, var(--col-primary), var(--col-accent));
    border-radius: 3px; transition: width 1s linear;
}
.progress-thumb[b-cadde16wsl] {
    position: absolute; right: -5px; top: -4px;
    width: 12px; height: 12px; border-radius: 50%;
    background: var(--col-accent); box-shadow: 0 0 8px rgba(236,72,153,0.7);
}
.progress-times[b-cadde16wsl] {
    display: flex; justify-content: space-between;
    font-size: 0.72rem; color: var(--col-muted);
    font-family: 'Poppins', sans-serif; font-weight: 600; opacity: 0.6;
}

/* ── EQ Bars ───────────────────────────────────────────────────── */
.eq-bars[b-cadde16wsl] { display: flex; align-items: flex-end; gap: 3px; height: 32px; margin-top: 4px; }
.eq-bar[b-cadde16wsl] { width: 4px; height: 3px; background: linear-gradient(to top, var(--col-primary), var(--col-accent)); border-radius: 2px; }
.eq-bars.playing .eq-bar[b-cadde16wsl] { animation: eqAnim-b-cadde16wsl 1.2s ease-in-out infinite alternate; animation-delay: var(--d, 0s); }
@keyframes eqAnim-b-cadde16wsl { 0% { height: 3px; } 100% { height: var(--h, 20px); } }

/* ── Stats ─────────────────────────────────────────────────────── */
.stats-row[b-cadde16wsl] { display: flex; gap: 16px; width: 100%; justify-content: center; }
.stat-card[b-cadde16wsl] {
    flex: 1; max-width: 180px;
    background: rgba(13,13,39,0.5); border: 1px solid rgba(255,255,255,0.06);
    border-radius: 16px; padding: 18px 16px;
    display: flex; flex-direction: column; align-items: center; gap: 6px; text-align: center;
    backdrop-filter: blur(12px);
    transition: border-color 0.25s, transform 0.2s, box-shadow 0.2s;
}
[data-theme="light"] .stat-card[b-cadde16wsl] { background: rgba(255,255,255,0.75); border-color: rgba(109,40,217,0.1); }
.stat-card:hover[b-cadde16wsl] { border-color: rgba(124,58,237,0.35); transform: translateY(-3px); box-shadow: 0 12px 30px rgba(124,58,237,0.15); }
.stat-card.featured[b-cadde16wsl] { background: linear-gradient(135deg, rgba(124,58,237,0.15), rgba(236,72,153,0.08)); border-color: rgba(124,58,237,0.3); }
[data-theme="light"] .stat-card.featured[b-cadde16wsl] { background: linear-gradient(135deg, rgba(109,40,217,0.1), rgba(219,39,119,0.06)); }
.stat-icon-wrap[b-cadde16wsl] { width: 40px; height: 40px; border-radius: 12px; background: rgba(124,58,237,0.1); display: flex; align-items: center; justify-content: center; color: #a78bfa; }
.stat-card.featured .stat-icon-wrap[b-cadde16wsl] { background: linear-gradient(135deg, #7c3aed, #ec4899); color: white; box-shadow: 0 4px 16px rgba(124,58,237,0.4); }
.stat-value[b-cadde16wsl] { font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 1.4rem; color: var(--col-text); line-height: 1; }
.stat-label[b-cadde16wsl] { font-size: 0.72rem; color: var(--col-muted); font-family: 'Nunito', sans-serif; font-weight: 600; }

/* ── Loading State ─────────────────────────────────────────────── */
.loading-state[b-cadde16wsl] { position: relative; z-index: 10; display: flex; flex-direction: column; align-items: center; gap: 24px; padding: 80px 20px; animation: heroReveal-b-cadde16wsl 0.6s ease forwards; }
.loading-rings[b-cadde16wsl] { position: relative; width: 120px; height: 120px; display: flex; align-items: center; justify-content: center; }
.ring[b-cadde16wsl] { position: absolute; border-radius: 50%; border: 2px solid transparent; animation: ringRotate-b-cadde16wsl 2s linear infinite; }
.ring-1[b-cadde16wsl] { inset: 0; border-top-color: #7c3aed; animation-duration: 1.8s; }
.ring-2[b-cadde16wsl] { inset: 16px; border-top-color: #ec4899; animation-duration: 2.4s; animation-direction: reverse; }
.ring-3[b-cadde16wsl] { inset: 32px; border-top-color: #f59e0b; animation-duration: 1.4s; }
@keyframes ringRotate-b-cadde16wsl { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.ring-center[b-cadde16wsl] { position: relative; z-index: 2; width: 56px; height: 56px; border-radius: 50%; background: linear-gradient(135deg, #7c3aed, #ec4899); display: flex; align-items: center; justify-content: center; box-shadow: 0 0 30px rgba(124,58,237,0.5); }
.loading-title[b-cadde16wsl] { font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 1.5rem; color: var(--col-text); margin: 0; text-align: center; }
.loading-sub[b-cadde16wsl] { font-family: 'Nunito', sans-serif; color: var(--col-muted); font-size: 0.95rem; margin: 0; text-align: center; }

/* ── Responsive ────────────────────────────────────────────────── */
@media (max-width: 720px) {
    .now-playing-card[b-cadde16wsl] { flex-direction: column; align-items: center; text-align: center; gap: 28px; padding: 28px 24px; }
    .song-top-row[b-cadde16wsl] { justify-content: center; }
    .song-title[b-cadde16wsl] { font-size: 1.35rem; }
    .vinyl-wrap[b-cadde16wsl], .vinyl-disc[b-cadde16wsl] { width: 160px; height: 160px; }
    .vinyl-track-1[b-cadde16wsl] { width: 136px; height: 136px; }
    .vinyl-track-2[b-cadde16wsl] { width: 112px; height: 112px; }
    .vinyl-center[b-cadde16wsl]  { width: 78px; height: 78px; }
    .vinyl-needle[b-cadde16wsl]  { display: none; }
    .stats-row[b-cadde16wsl] { flex-wrap: wrap; }
    .stat-card[b-cadde16wsl] { min-width: 120px; }
}
@media (max-width: 480px) {
    .hero-content[b-cadde16wsl] { gap: 20px; padding: 24px 12px; }
    .share-btn span:not(svg)[b-cadde16wsl] { display: none; }
    .share-btn[b-cadde16wsl] { padding: 5px 8px; }
    .stats-row[b-cadde16wsl] { gap: 10px; }
    .stat-card[b-cadde16wsl] { padding: 14px 10px; }
}
/* /Components/Pages/NowPlaying.razor.rz.scp.css */
/* ── Now Playing Page ───────────────────────────────────────────── */
.np-page[b-xgb40wwpj2] { display: flex; flex-direction: column; gap: 24px; }

/* Hero */
.np-hero[b-xgb40wwpj2] { position: relative; overflow: hidden; padding: 36px 32px; border-radius: 20px; }
.np-hero-bg[b-xgb40wwpj2] { position: absolute; inset: -20px; background-size: cover; background-position: center; filter: blur(40px) brightness(0.3) saturate(1.4); transform: scale(1.08); transition: background-image 1.5s; }
.np-hero-overlay[b-xgb40wwpj2] { position: absolute; inset: 0; background: linear-gradient(135deg, rgba(13,13,39,0.78), rgba(45,5,64,0.68)); }
[data-theme="light"] .np-hero-overlay[b-xgb40wwpj2] { background: linear-gradient(135deg, rgba(30,27,75,0.72), rgba(74,14,110,0.62)); }
.np-hero-content[b-xgb40wwpj2] { position: relative; z-index: 2; display: flex; align-items: center; gap: 32px; animation: fadeUp-b-xgb40wwpj2 0.6s ease forwards; }

/* Art */
.np-art-wrap[b-xgb40wwpj2] { position: relative; flex-shrink: 0; }
.np-art[b-xgb40wwpj2] { width: 150px; height: 150px; border-radius: 50%; object-fit: cover; border: 3px solid rgba(255,255,255,0.15); box-shadow: 0 16px 48px rgba(0,0,0,0.5); }
.np-art.spinning[b-xgb40wwpj2] { animation: npSpin-b-xgb40wwpj2 5s linear infinite; }
@keyframes npSpin-b-xgb40wwpj2 { to { transform: rotate(360deg); } }
.np-art-glow[b-xgb40wwpj2] { position: absolute; inset: -10px; border-radius: 50%; background: radial-gradient(circle, rgba(236,72,153,0.3) 0%, transparent 70%); opacity: 0; transition: opacity 0.5s; animation: glowP-b-xgb40wwpj2 2.5s ease-in-out infinite; }
.np-art-glow.active[b-xgb40wwpj2] { opacity: 1; }
@keyframes glowP-b-xgb40wwpj2 { 0%,100% { transform:scale(1); } 50% { transform:scale(1.1); } }

/* Info */
.np-info[b-xgb40wwpj2] { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 8px; }
.np-badge[b-xgb40wwpj2] { display: inline-flex; align-items: center; gap: 6px; font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.67rem; letter-spacing: 0.14em; color: #f87171; background: rgba(239,68,68,0.12); border: 1px solid rgba(239,68,68,0.25); padding: 3px 10px; border-radius: 20px; width: fit-content; }
.np-dot[b-xgb40wwpj2] { width: 7px; height: 7px; border-radius: 50%; background: #ef4444; }
.np-dot.pulse[b-xgb40wwpj2] { animation: dotP-b-xgb40wwpj2 1.4s ease-in-out infinite; }
@keyframes dotP-b-xgb40wwpj2 { 0%,100% { box-shadow: 0 0 0 0 rgba(239,68,68,0.7); } 70% { box-shadow: 0 0 0 7px rgba(239,68,68,0); } }
.np-title[b-xgb40wwpj2] { font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 1.7rem; color: #fff; margin: 0; line-height: 1.15; word-break: break-word; }
.np-artist[b-xgb40wwpj2] { font-size: 1rem; color: rgba(255,255,255,0.6); font-weight: 600; }
.np-album[b-xgb40wwpj2] { display: flex; align-items: center; gap: 5px; font-size: 0.82rem; color: rgba(255,255,255,0.38); font-style: italic; }

/* Progress */
.np-progress-wrap[b-xgb40wwpj2] { display: flex; flex-direction: column; gap: 5px; margin-top: 4px; }
.np-progress-track[b-xgb40wwpj2] { position: relative; height: 4px; background: rgba(255,255,255,0.1); border-radius: 3px; }
.np-progress-fill[b-xgb40wwpj2] { position: relative; height: 100%; background: linear-gradient(90deg, var(--col-primary), var(--col-accent)); border-radius: 3px; transition: width 1s linear; }
.np-progress-thumb[b-xgb40wwpj2] { position: absolute; right: -5px; top: -4px; width: 12px; height: 12px; border-radius: 50%; background: var(--col-accent); box-shadow: 0 0 8px rgba(236,72,153,0.7); }
.np-progress-times[b-xgb40wwpj2] { display: flex; justify-content: space-between; font-size: 0.72rem; color: rgba(255,255,255,0.32); font-family: 'Poppins', sans-serif; font-weight: 600; }

/* Actions row */
.np-actions-row[b-xgb40wwpj2] { display: flex; align-items: center; gap: 12px; margin-top: 4px; flex-wrap: wrap; }
.np-eq[b-xgb40wwpj2] { display: flex; align-items: flex-end; gap: 2px; height: 28px; }
.np-eq-bar[b-xgb40wwpj2] { width: 3px; height: 3px; background: linear-gradient(to top, var(--col-primary), var(--col-accent)); border-radius: 2px; }
.np-eq.playing .np-eq-bar[b-xgb40wwpj2] { animation: eqA-b-xgb40wwpj2 1.2s ease-in-out infinite alternate; animation-delay: var(--d,0s); }
@keyframes eqA-b-xgb40wwpj2 { 0% { height: 3px; } 100% { height: var(--h,20px); } }

/* Like button */
.like-btn[b-xgb40wwpj2] {
    display: flex; align-items: center; gap: 5px;
    background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.15);
    border-radius: 20px; padding: 6px 13px; cursor: pointer; color: rgba(255,255,255,0.6);
    font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.82rem;
    transition: all 0.2s;
}
.like-btn:hover[b-xgb40wwpj2] { background: rgba(236,72,153,0.15); border-color: rgba(236,72,153,0.4); color: #f472b6; transform: scale(1.04); }
.like-btn.liked[b-xgb40wwpj2] { background: rgba(236,72,153,0.15); border-color: rgba(236,72,153,0.45); color: #f472b6; }
.like-btn.liked svg[b-xgb40wwpj2] { filter: drop-shadow(0 0 4px rgba(244,114,182,0.6)); }
.like-count[b-xgb40wwpj2] { min-width: 16px; }

/* Request link */
.np-req-link[b-xgb40wwpj2] {
    display: flex; align-items: center; gap: 5px;
    background: rgba(124,58,237,0.15); border: 1px solid rgba(124,58,237,0.3);
    border-radius: 20px; padding: 6px 13px;
    font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.8rem;
    color: #a78bfa; text-decoration: none;
    transition: background 0.2s, transform 0.15s;
}
.np-req-link:hover[b-xgb40wwpj2] { background: rgba(124,58,237,0.25); transform: scale(1.03); }

/* Loading */
.np-loading[b-xgb40wwpj2] { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 60px; color: var(--col-muted); }
.np-spinner[b-xgb40wwpj2] { width: 46px; height: 46px; border-radius: 50%; border: 3px solid var(--col-border); border-top-color: var(--col-primary); animation: npSpin-b-xgb40wwpj2 1s linear infinite; }

/* Two-column layout */
.np-columns[b-xgb40wwpj2] { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }

/* Panel */
.np-panel[b-xgb40wwpj2] { background: var(--bg-surface); border: 1px solid var(--col-border); border-radius: 18px; padding: 18px; display: flex; flex-direction: column; gap: 12px; min-height: 300px; }
.np-panel-header[b-xgb40wwpj2] { display: flex; align-items: center; justify-content: space-between; padding-bottom: 10px; border-bottom: 1px solid var(--col-border); }
.np-panel-title[b-xgb40wwpj2] { display: flex; align-items: center; gap: 7px; font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.95rem; color: var(--col-text); margin: 0; }
.np-panel-title svg[b-xgb40wwpj2] { color: var(--col-primary); }

.panel-refresh[b-xgb40wwpj2] { background: var(--col-btn-bg); border: 1px solid var(--col-border); border-radius: 8px; color: var(--col-muted); padding: 5px 8px; cursor: pointer; display: flex; align-items: center; transition: all 0.2s; }
.panel-refresh:hover:not(:disabled)[b-xgb40wwpj2] { background: var(--col-btn-hover); color: var(--col-text); }
.panel-refresh:disabled[b-xgb40wwpj2] { opacity: 0.4; cursor: not-allowed; }
.spinning-icon[b-xgb40wwpj2] { animation: npSpin-b-xgb40wwpj2 1s linear infinite; }

.np-panel-empty[b-xgb40wwpj2] { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; flex: 1; color: var(--col-muted); opacity: 0.5; font-size: 0.85rem; text-align: center; padding: 20px; }
.np-panel-empty svg[b-xgb40wwpj2] { color: var(--col-border); }

/* Mini list rows */
.mini-list[b-xgb40wwpj2] { display: flex; flex-direction: column; gap: 4px; }
.mini-row[b-xgb40wwpj2] { display: flex; align-items: center; gap: 9px; padding: 8px 10px; border-radius: 10px; border: 1px solid transparent; transition: background 0.2s, border-color 0.15s; animation: fadeUp-b-xgb40wwpj2 0.35s ease both; }
.mini-row:hover[b-xgb40wwpj2] { background: var(--col-btn-bg); border-color: var(--col-border); }
.mini-num[b-xgb40wwpj2] { width: 18px; text-align: center; font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.7rem; color: var(--col-muted); flex-shrink: 0; }
.mini-art[b-xgb40wwpj2] { width: 36px; height: 36px; border-radius: 7px; object-fit: cover; flex-shrink: 0; border: 1px solid var(--col-border); }
.mini-info[b-xgb40wwpj2] { flex: 1; min-width: 0; }
.mini-title[b-xgb40wwpj2] { font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.82rem; color: var(--col-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mini-artist[b-xgb40wwpj2] { font-size: 0.72rem; color: var(--col-muted); margin-top: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.mini-right[b-xgb40wwpj2] { display: flex; flex-direction: column; align-items: flex-end; gap: 3px; flex-shrink: 0; }
.mini-req-badge[b-xgb40wwpj2] { font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.58rem; letter-spacing: 0.08em; background: rgba(124,58,237,0.12); border: 1px solid rgba(124,58,237,0.25); color: #a78bfa; border-radius: 4px; padding: 1px 5px; }
.mini-ago[b-xgb40wwpj2] { font-size: 0.68rem; color: var(--col-muted); opacity: 0.6; }

/* Skeleton */
.mini-skeleton[b-xgb40wwpj2] { display: flex; flex-direction: column; gap: 6px; }
.mini-skel-row[b-xgb40wwpj2] { display: flex; align-items: center; gap: 9px; padding: 8px 10px; }
.mini-skel-art[b-xgb40wwpj2] { width: 36px; height: 36px; border-radius: 7px; flex-shrink: 0; background: var(--col-border); animation: shimmer-b-xgb40wwpj2 1.4s ease-in-out infinite; }
.mini-skel-lines[b-xgb40wwpj2] { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.mini-skel-l[b-xgb40wwpj2] { height: 9px; border-radius: 5px; background: var(--col-border); animation: shimmer-b-xgb40wwpj2 1.4s ease-in-out infinite; }
.mini-skel-l.long[b-xgb40wwpj2] { width: 65%; }
.mini-skel-l.short[b-xgb40wwpj2] { width: 40%; }
@keyframes shimmer-b-xgb40wwpj2 { 0%,100% { opacity:0.35; } 50% { opacity:0.8; } }
@keyframes fadeUp-b-xgb40wwpj2 { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:translateY(0); } }

@media (max-width: 680px) {
    .np-columns[b-xgb40wwpj2] { grid-template-columns: 1fr; }
    .np-hero-content[b-xgb40wwpj2] { flex-direction: column; text-align: center; gap: 20px; }
    .np-art[b-xgb40wwpj2] { width: 120px; height: 120px; }
    .np-title[b-xgb40wwpj2] { font-size: 1.35rem; }
    .np-badge[b-xgb40wwpj2], .np-actions-row[b-xgb40wwpj2] { justify-content: center; }
    .np-hero[b-xgb40wwpj2] { padding: 26px 18px; }
}
/* /Components/Pages/Schedule.razor.rz.scp.css */
/* ── Schedule Page ──────────────────────────────────────────────── */

.sched-page[b-wouhvrv9kd] { display: flex; flex-direction: column; gap: 24px; }

/* Page Header */
.page-header[b-wouhvrv9kd] {
    display: flex; align-items: center; gap: 16px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--col-border);
}
.page-header-icon[b-wouhvrv9kd] {
    width: 52px; height: 52px; border-radius: 14px; flex-shrink: 0;
    background: linear-gradient(135deg, var(--col-primary), var(--col-accent));
    display: flex; align-items: center; justify-content: center; color: white;
    box-shadow: 0 4px 20px rgba(124,58,237,0.35);
}
.page-title[b-wouhvrv9kd] {
    font-family: 'Poppins', sans-serif; font-weight: 800;
    font-size: 1.6rem; color: var(--col-text); margin: 0;
}
.page-sub[b-wouhvrv9kd] { font-size: 0.85rem; color: var(--col-muted); margin: 3px 0 0; }

/* Loading */
.sched-loading[b-wouhvrv9kd] { display: flex; flex-direction: column; align-items: center; gap: 16px; padding: 60px; color: var(--col-muted); }
.sched-spinner[b-wouhvrv9kd] {
    width: 44px; height: 44px; border-radius: 50%;
    border: 3px solid var(--col-border); border-top-color: var(--col-primary);
    animation: sched-spin-b-wouhvrv9kd 1s linear infinite;
}
@keyframes sched-spin-b-wouhvrv9kd { to { transform: rotate(360deg); } }

/* Notice */
.sched-notice[b-wouhvrv9kd] {
    display: flex; align-items: center; gap: 10px;
    background: rgba(245,158,11,0.08); border: 1px solid rgba(245,158,11,0.25);
    border-radius: 12px; padding: 12px 16px;
    font-size: 0.85rem; color: #d97706;
}

/* Schedule Grid */
.sched-grid[b-wouhvrv9kd] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 14px;
}

.sched-card[b-wouhvrv9kd] {
    position: relative;
    background: var(--bg-surface);
    border: 1px solid var(--col-border);
    border-radius: 16px;
    padding: 18px 18px 16px;
    display: flex; flex-direction: column; gap: 7px;
    transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
    animation: fadeUp-b-wouhvrv9kd 0.4s ease both;
}
.sched-card:hover[b-wouhvrv9kd] {
    border-color: rgba(124,58,237,0.35);
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(124,58,237,0.12);
}
.sched-card.current[b-wouhvrv9kd] {
    border-color: var(--col-accent);
    background: linear-gradient(135deg, rgba(124,58,237,0.06), rgba(236,72,153,0.04));
    box-shadow: 0 0 0 1px rgba(236,72,153,0.15), 0 8px 24px rgba(236,72,153,0.1);
}

/* Live badge */
.sched-live-badge[b-wouhvrv9kd] {
    display: inline-flex; align-items: center; gap: 5px;
    background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.25);
    border-radius: 20px; padding: 2px 9px; width: fit-content;
    font-family: 'Poppins', sans-serif; font-weight: 700;
    font-size: 0.64rem; letter-spacing: 0.1em; color: #f87171;
    margin-bottom: 2px;
}
.live-dot[b-wouhvrv9kd] { width: 6px; height: 6px; border-radius: 50%; background: #ef4444; animation: livePulse-b-wouhvrv9kd 1.4s ease-in-out infinite; }
@keyframes livePulse-b-wouhvrv9kd { 0%,100% { opacity:1; } 50% { opacity: 0.3; } }

.sched-time[b-wouhvrv9kd] {
    display: flex; align-items: center; gap: 5px;
    font-family: 'Poppins', sans-serif; font-weight: 700;
    font-size: 0.75rem; color: var(--col-primary);
    letter-spacing: 0.03em;
}
.sched-show-name[b-wouhvrv9kd] {
    font-family: 'Poppins', sans-serif; font-weight: 700;
    font-size: 1rem; color: var(--col-text); line-height: 1.25;
}
.sched-show-desc[b-wouhvrv9kd] { font-size: 0.8rem; color: var(--col-muted); line-height: 1.4; }

.sched-days[b-wouhvrv9kd] { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 2px; }
.day-chip[b-wouhvrv9kd] {
    font-family: 'Poppins', sans-serif; font-size: 0.65rem; font-weight: 700;
    background: var(--col-btn-bg); border: 1px solid var(--col-border);
    color: var(--col-muted); border-radius: 6px; padding: 2px 7px;
}

/* Always-on card */
.always-on-card[b-wouhvrv9kd] {
    display: flex; align-items: center; gap: 18px;
    background: linear-gradient(135deg, rgba(124,58,237,0.1), rgba(236,72,153,0.06));
    border: 1px solid rgba(124,58,237,0.25);
    border-radius: 16px; padding: 20px 24px;
}
.always-on-icon[b-wouhvrv9kd] {
    width: 56px; height: 56px; border-radius: 50%; flex-shrink: 0;
    background: linear-gradient(135deg, var(--col-primary), var(--col-accent));
    display: flex; align-items: center; justify-content: center; color: white;
    box-shadow: 0 4px 16px rgba(124,58,237,0.4);
}
.always-on-title[b-wouhvrv9kd] { font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 1rem; color: var(--col-text); margin-bottom: 4px; }
.always-on-sub[b-wouhvrv9kd]   { font-size: 0.82rem; color: var(--col-muted); line-height: 1.55; }

@keyframes fadeUp-b-wouhvrv9kd { from { opacity:0; transform: translateY(12px); } to { opacity:1; transform: translateY(0); } }

@media (max-width: 480px) {
    .sched-grid[b-wouhvrv9kd] { grid-template-columns: 1fr; }
    .always-on-card[b-wouhvrv9kd] { flex-direction: column; text-align: center; }
}
/* /Components/Pages/SongRequest.razor.rz.scp.css */
/* ── Song Request Page ──────────────────────────────────────────── */

.req-page[b-k8td1ql15d] { display: flex; flex-direction: column; gap: 24px; max-width: 780px; }

/* Page Header */
.page-header[b-k8td1ql15d] {
    display: flex; align-items: center; gap: 16px;
    padding-bottom: 20px; border-bottom: 1px solid var(--col-border);
}
.page-header-icon[b-k8td1ql15d] {
    width: 52px; height: 52px; border-radius: 14px; flex-shrink: 0;
    background: linear-gradient(135deg, var(--col-primary), var(--col-accent));
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 20px rgba(124,58,237,0.35);
}
.page-title[b-k8td1ql15d] { font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 1.6rem; color: var(--col-text); margin: 0; }
.page-sub[b-k8td1ql15d]   { font-size: 0.85rem; color: var(--col-muted); margin: 3px 0 0; }

/* Now-playing context bar */
.now-context[b-k8td1ql15d] {
    display: flex; align-items: center; gap: 12px;
    background: var(--col-btn-bg); border: 1px solid var(--col-border);
    border-radius: 12px; padding: 10px 14px;
}
.now-context-art[b-k8td1ql15d]   { width: 40px; height: 40px; border-radius: 8px; object-fit: cover; flex-shrink: 0; }
.now-context-info[b-k8td1ql15d]  { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
.now-context-label[b-k8td1ql15d] { font-size: 0.68rem; color: var(--col-accent); font-weight: 700; font-family: 'Poppins', sans-serif; letter-spacing: 0.06em; }
.now-context-title[b-k8td1ql15d] { font-size: 0.88rem; color: var(--col-text); font-weight: 700; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.now-context-artist[b-k8td1ql15d]{ font-size: 0.78rem; color: var(--col-muted); }

/* Section wrapper */
.req-section[b-k8td1ql15d] {
    background: var(--bg-surface);
    border: 1px solid var(--col-border);
    border-radius: 18px; padding: 22px;
    display: flex; flex-direction: column; gap: 16px;
}

.req-section-header[b-k8td1ql15d] { display: flex; align-items: center; gap: 14px; }
.req-section-icon[b-k8td1ql15d] {
    width: 44px; height: 44px; border-radius: 12px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
}
.req-section-icon.primary[b-k8td1ql15d] { background: linear-gradient(135deg, var(--col-primary), var(--col-accent)); box-shadow: 0 4px 14px rgba(124,58,237,0.3); }
.req-section-icon.green[b-k8td1ql15d]   { background: linear-gradient(135deg, #16a34a, #22c55e); box-shadow: 0 4px 14px rgba(34,197,94,0.3); }

.req-section-title[b-k8td1ql15d] { font-family: 'Poppins', sans-serif; font-weight: 800; font-size: 1rem; color: var(--col-text); margin: 0 0 2px; }
.req-section-sub[b-k8td1ql15d]   { font-size: 0.8rem; color: var(--col-muted); margin: 0; }

/* Search bar */
.search-bar-wrap[b-k8td1ql15d] {
    position: relative; display: flex; align-items: center;
}
.search-icon[b-k8td1ql15d] {
    position: absolute; left: 14px; color: var(--col-muted); pointer-events: none;
}
.search-input[b-k8td1ql15d] {
    width: 100%; padding: 12px 44px 12px 44px;
    background: var(--bg-deep); border: 1px solid var(--col-border);
    border-radius: 12px; color: var(--col-text);
    font-family: 'Nunito', sans-serif; font-size: 0.92rem;
    outline: none; transition: border-color 0.2s, box-shadow 0.2s;
}
.search-input:focus[b-k8td1ql15d] {
    border-color: var(--col-primary);
    box-shadow: 0 0 0 3px rgba(124,58,237,0.12);
}
.search-input[b-k8td1ql15d]::placeholder { color: var(--col-muted); opacity: 0.6; }
.search-clear[b-k8td1ql15d] {
    position: absolute; right: 12px;
    background: none; border: none; cursor: pointer;
    color: var(--col-muted); padding: 4px; border-radius: 6px;
    display: flex; transition: color 0.2s;
}
.search-clear:hover[b-k8td1ql15d] { color: var(--col-text); }

/* Track list */
.tracks-list[b-k8td1ql15d] { display: flex; flex-direction: column; gap: 6px; }

.track-row[b-k8td1ql15d] {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 12px; border-radius: 12px;
    border: 1px solid var(--col-border);
    background: var(--bg-deep);
    transition: background 0.2s, border-color 0.2s;
    animation: fadeIn-b-k8td1ql15d 0.35s ease both;
}
.track-row:hover[b-k8td1ql15d] { background: var(--col-btn-bg); border-color: rgba(124,58,237,0.25); }
.track-row.requested[b-k8td1ql15d] { opacity: 0.6; }

@keyframes fadeIn-b-k8td1ql15d { from { opacity:0; transform: translateY(8px); } to { opacity:1; transform: translateY(0); } }

.track-art[b-k8td1ql15d]  { width: 42px; height: 42px; border-radius: 8px; object-fit: cover; flex-shrink: 0; border: 1px solid var(--col-border); }
.track-info[b-k8td1ql15d] { flex: 1; min-width: 0; }
.track-title[b-k8td1ql15d]  { font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.88rem; color: var(--col-text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.track-meta[b-k8td1ql15d]   { display: flex; align-items: center; gap: 4px; font-size: 0.76rem; color: var(--col-muted); margin-top: 2px; }
.track-sep[b-k8td1ql15d]    { opacity: 0.4; }
.track-album[b-k8td1ql15d]  { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 130px; }
.track-duration[b-k8td1ql15d] { font-size: 0.72rem; color: var(--col-muted); flex-shrink: 0; font-family: 'Poppins', sans-serif; }

/* Request button */
.req-btn[b-k8td1ql15d] {
    display: flex; align-items: center; gap: 5px; flex-shrink: 0;
    border-radius: 20px; border: 1px solid; padding: 6px 14px;
    font-family: 'Nunito', sans-serif; font-size: 0.8rem; font-weight: 700;
    cursor: pointer; transition: all 0.2s; white-space: nowrap;
    background: linear-gradient(135deg, var(--col-primary), var(--col-accent));
    border-color: transparent; color: white;
    box-shadow: 0 2px 10px rgba(124,58,237,0.3);
}
.req-btn:hover:not(:disabled)[b-k8td1ql15d] { transform: translateY(-1px); box-shadow: 0 4px 16px rgba(124,58,237,0.45); }
.req-btn:disabled[b-k8td1ql15d] { cursor: not-allowed; }
.req-btn.done[b-k8td1ql15d] { background: rgba(34,197,94,0.12); border-color: rgba(34,197,94,0.3); color: #22c55e; box-shadow: none; }
.req-btn.loading[b-k8td1ql15d] { opacity: 0.7; }
.spin-icon[b-k8td1ql15d] { animation: spin-b-k8td1ql15d 1s linear infinite; }
@keyframes spin-b-k8td1ql15d { to { transform: rotate(360deg); } }

/* Empty / prompt states */
.req-empty[b-k8td1ql15d], .req-prompt[b-k8td1ql15d] {
    display: flex; flex-direction: column; align-items: center; gap: 10px;
    padding: 36px 20px; text-align: center; color: var(--col-muted);
}
.req-empty svg[b-k8td1ql15d], .req-prompt svg[b-k8td1ql15d] { color: var(--col-border); }
.req-empty p[b-k8td1ql15d], .req-prompt p[b-k8td1ql15d] { font-size: 0.9rem; margin: 0; }
.req-empty span[b-k8td1ql15d] { font-size: 0.8rem; color: rgba(148,163,184,0.6); }

/* Notice */
.req-notice[b-k8td1ql15d] {
    display: flex; align-items: flex-start; gap: 12px;
    border-radius: 12px; padding: 14px 16px; font-size: 0.85rem; line-height: 1.55;
}
.req-notice.warning[b-k8td1ql15d] {
    background: rgba(245,158,11,0.08); border: 1px solid rgba(245,158,11,0.25); color: #d97706;
}
.req-notice strong[b-k8td1ql15d] { display: block; font-weight: 700; margin-bottom: 2px; }
.req-notice svg[b-k8td1ql15d] { flex-shrink: 0; margin-top: 2px; }

/* Toast */
.req-toast[b-k8td1ql15d] {
    display: flex; align-items: center; gap: 8px;
    padding: 12px 16px; border-radius: 12px;
    font-family: 'Nunito', sans-serif; font-size: 0.88rem; font-weight: 600;
    animation: fadeIn-b-k8td1ql15d 0.3s ease;
}
.req-toast.success[b-k8td1ql15d] { background: rgba(34,197,94,0.1); border: 1px solid rgba(34,197,94,0.3); color: #22c55e; }
.req-toast.error[b-k8td1ql15d]   { background: rgba(239,68,68,0.1); border: 1px solid rgba(239,68,68,0.3); color: #f87171; }

/* Skeleton */
.req-skeleton[b-k8td1ql15d] { display: flex; flex-direction: column; gap: 6px; }
.req-skel-row[b-k8td1ql15d]  { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: 12px; border: 1px solid var(--col-border); }
.req-skel-art[b-k8td1ql15d]  { width: 42px; height: 42px; border-radius: 8px; flex-shrink: 0; }
.req-skel-text[b-k8td1ql15d] { flex: 1; display: flex; flex-direction: column; gap: 6px; }
.req-skel-line[b-k8td1ql15d] { height: 10px; border-radius: 5px; }
.req-skel-line.long[b-k8td1ql15d]  { width: 60%; }
.req-skel-line.short[b-k8td1ql15d] { width: 38%; }
.req-skel-btn[b-k8td1ql15d]  { width: 80px; height: 30px; border-radius: 20px; }
.req-skel-art[b-k8td1ql15d], .req-skel-line[b-k8td1ql15d], .req-skel-btn[b-k8td1ql15d] {
    background: var(--col-border); animation: shimmer-b-k8td1ql15d 1.4s ease-in-out infinite;
}
@keyframes shimmer-b-k8td1ql15d { 0%,100% { opacity:0.4; } 50% { opacity:0.85; } }

/* Manual form */
.manual-form[b-k8td1ql15d] { display: flex; flex-direction: column; gap: 14px; }
.form-row[b-k8td1ql15d] { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.form-field[b-k8td1ql15d] { display: flex; flex-direction: column; gap: 5px; }
.form-label[b-k8td1ql15d] { font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.78rem; color: var(--col-text); }
.required[b-k8td1ql15d] { color: var(--col-accent); }
.optional[b-k8td1ql15d] { color: var(--col-muted); font-weight: 400; }

.form-input[b-k8td1ql15d], .form-textarea[b-k8td1ql15d] {
    background: var(--bg-deep); border: 1px solid var(--col-border);
    border-radius: 10px; color: var(--col-text);
    font-family: 'Nunito', sans-serif; font-size: 0.9rem;
    padding: 10px 14px; outline: none;
    transition: border-color 0.2s, box-shadow 0.2s;
    resize: vertical;
}
.form-input:focus[b-k8td1ql15d], .form-textarea:focus[b-k8td1ql15d] {
    border-color: var(--col-primary);
    box-shadow: 0 0 0 3px rgba(124,58,237,0.12);
}
.form-input[b-k8td1ql15d]::placeholder, .form-textarea[b-k8td1ql15d]::placeholder { color: var(--col-muted); opacity: 0.55; }
.form-error[b-k8td1ql15d] { font-size: 0.82rem; color: #f87171; padding: 6px 0; }

.form-actions[b-k8td1ql15d] { display: flex; gap: 10px; flex-wrap: wrap; }
.send-btn[b-k8td1ql15d] {
    display: flex; align-items: center; gap: 8px;
    font-family: 'Poppins', sans-serif; font-weight: 700; font-size: 0.88rem;
    padding: 11px 22px; border-radius: 30px; border: none; cursor: pointer;
    transition: transform 0.15s, box-shadow 0.2s, opacity 0.2s;
}
.send-btn:hover[b-k8td1ql15d] { transform: translateY(-2px); }
.send-btn:active[b-k8td1ql15d] { transform: scale(0.97); }

.send-btn.whatsapp[b-k8td1ql15d] {
    background: linear-gradient(135deg, #25d366, #128c7e);
    color: white; box-shadow: 0 4px 16px rgba(37,211,102,0.35);
}
.send-btn.email[b-k8td1ql15d] {
    background: linear-gradient(135deg, var(--col-primary), var(--col-accent));
    color: white; box-shadow: 0 4px 16px rgba(124,58,237,0.35);
}

@media (max-width: 560px) {
    .form-row[b-k8td1ql15d] { grid-template-columns: 1fr; }
    .form-actions[b-k8td1ql15d] { flex-direction: column; }
    .send-btn[b-k8td1ql15d] { justify-content: center; }
}
