/*
Theme Name: WJZZ Detroit Jazz Radio
Theme URI: https://wjzzdetroitradio.com/
Author: Chocolate Picasso / Black Quantum Studios
Author URI: https://chazzoriginalzart.com/
Description: A black-and-gold Art Deco WordPress theme for WJZZ Detroit Jazz Radio with live stream hero, album cover viewer, schedule cards, registry links, and legacy jazz sections.
Version: 1.0.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: wjzz-detroit
Tags: custom-logo, one-column, entertainment, music, block-styles
*/

:root{
  --wjzz-black:#050505;
  --wjzz-deep:#0d0d0d;
  --wjzz-card:#14110a;
  --wjzz-gold:#c9a84c;
  --wjzz-gold-bright:#f3d36b;
  --wjzz-cream:#fff2bf;
  --wjzz-muted:#b6a979;
  --wjzz-line:rgba(201,168,76,.35);
  --wjzz-red:#6d1414;
  --wjzz-font-display:Georgia,"Times New Roman",serif;
  --wjzz-font-body:Arial,Helvetica,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(circle at 12% 0%,rgba(201,168,76,.14),transparent 28%),
    linear-gradient(180deg,#050505 0%,#0b0b0b 42%,#030303 100%);
  color:#f7edc5;
  font-family:var(--wjzz-font-body);
  line-height:1.55;
}
a{color:var(--wjzz-gold-bright);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:10px;top:10px;width:auto;height:auto;background:#fff;color:#000;padding:10px;z-index:99999}

.wjzz-site-header{
  position:sticky;top:0;z-index:9999;
  background:rgba(0,0,0,.92);
  border-bottom:1px solid var(--wjzz-line);
  backdrop-filter:blur(12px);
}
.admin-bar .wjzz-site-header{top:32px}
@media(max-width:782px){.admin-bar .wjzz-site-header{top:46px}}
.wjzz-header-inner{
  max-width:1180px;margin:0 auto;padding:12px 20px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.wjzz-brand{display:flex;align-items:center;gap:12px;min-width:220px}
.wjzz-logo-ring{
  width:54px;height:54px;border-radius:50%;
  border:2px solid var(--wjzz-gold);display:grid;place-items:center;
  font-family:var(--wjzz-font-display);font-weight:bold;color:var(--wjzz-gold-bright);
  box-shadow:0 0 24px rgba(201,168,76,.18), inset 0 0 18px rgba(201,168,76,.12);
}
.custom-logo{max-height:54px;width:auto}
.wjzz-title{margin:0;font-family:var(--wjzz-font-display);font-size:1.35rem;letter-spacing:.12em;color:#fff;text-transform:uppercase}
.wjzz-tagline{margin:0;color:var(--wjzz-muted);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase}
.wjzz-nav ul{list-style:none;margin:0;padding:0;display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.wjzz-nav a{color:#fff2bf;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase}
.wjzz-mini-player{display:flex;align-items:center;gap:10px;min-width:220px;justify-content:flex-end}
.wjzz-play-button{width:42px;height:42px;border-radius:50%;border:1px solid var(--wjzz-gold);background:var(--wjzz-gold);color:#000;cursor:pointer;font-weight:bold}
.wjzz-on-air{display:flex;align-items:center;gap:7px;color:#fff2bf;font-size:.75rem;letter-spacing:.15em;text-transform:uppercase}
.wjzz-dot{width:8px;height:8px;border-radius:50%;background:#e8c45f;box-shadow:0 0 12px rgba(232,196,95,.95);animation:wjzzBlink 1.3s infinite}

.wjzz-hero{position:relative;overflow:hidden;min-height:72vh;border-bottom:1px solid var(--wjzz-line)}
.wjzz-hero:before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px),
    linear-gradient(0deg,rgba(255,255,255,.025) 1px,transparent 1px),
    radial-gradient(circle at 72% 34%,rgba(201,168,76,.22),transparent 30%);
  background-size:32px 32px,32px 32px,auto;
  opacity:.8;
}
.wjzz-hero:after{
  content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.95),rgba(0,0,0,.6),rgba(0,0,0,.85));
}
.wjzz-hero-inner{position:relative;z-index:2;max-width:1180px;margin:0 auto;padding:86px 20px;display:grid;grid-template-columns:1.3fr .7fr;gap:42px;align-items:center}
.wjzz-eyebrow{color:var(--wjzz-gold);letter-spacing:.22em;text-transform:uppercase;font-size:.82rem;margin:0 0 14px}
.wjzz-hero h1{font-family:var(--wjzz-font-display);font-size:clamp(4.8rem,13vw,11rem);line-height:.82;margin:0;color:#fff;text-shadow:0 0 30px rgba(201,168,76,.2);letter-spacing:.02em}
.wjzz-hero-sub{font-family:var(--wjzz-font-display);font-size:clamp(1.6rem,4vw,3.4rem);color:var(--wjzz-gold-bright);margin:0 0 14px}
.wjzz-hero-copy{max-width:720px;color:#d8cfa5;font-size:1rem;letter-spacing:.04em}
.wjzz-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.wjzz-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 18px;border:1px solid var(--wjzz-gold);border-radius:999px;text-transform:uppercase;letter-spacing:.14em;font-size:.78rem;font-weight:700;text-decoration:none!important}
.wjzz-btn-gold{background:linear-gradient(180deg,#f2d36b,#b78d2d);color:#050505!important}
.wjzz-btn-outline{color:var(--wjzz-gold-bright)!important;background:rgba(0,0,0,.2)}
.wjzz-anniversary{justify-self:end;width:min(320px,100%);aspect-ratio:1;border-radius:50%;border:2px solid var(--wjzz-gold);display:grid;place-items:center;text-align:center;background:radial-gradient(circle,rgba(201,168,76,.18),rgba(0,0,0,.88));box-shadow:0 0 70px rgba(201,168,76,.16), inset 0 0 35px rgba(201,168,76,.12)}
.wjzz-anniversary span{display:block}.wjzz-anniversary .num{font-family:var(--wjzz-font-display);font-size:6rem;line-height:.85;color:#fff}.wjzz-anniversary .small{letter-spacing:.22em;text-transform:uppercase;color:var(--wjzz-muted);font-size:.76rem}.wjzz-anniversary .years{font-family:var(--wjzz-font-display);font-size:1.8rem;color:var(--wjzz-gold-bright)}

.wjzz-city-ticker{overflow:hidden;border-bottom:1px solid var(--wjzz-line);border-top:1px solid rgba(201,168,76,.12);background:#090909;color:var(--wjzz-muted);white-space:nowrap;padding:12px 0;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;text-align:center}

.wjzz-section{padding:72px 20px}.wjzz-wrap{max-width:1180px;margin:0 auto}.wjzz-section-header{display:flex;justify-content:space-between;gap:20px;align-items:end;margin-bottom:26px}.wjzz-section-title{font-family:var(--wjzz-font-display);font-size:clamp(2rem,4.6vw,4.2rem);line-height:1;margin:0;color:#fff}.wjzz-section-kicker{display:block;color:var(--wjzz-gold);letter-spacing:.22em;text-transform:uppercase;font-size:.75rem;margin-bottom:10px}

/* Album Cover Viewer */
.wjzz-cover-viewer,.wjzz-cover-viewer *{box-sizing:border-box}.wjzz-cover-viewer{width:100%;max-width:980px;margin:0 auto;padding:18px;color:var(--wjzz-gold);font-family:var(--wjzz-font-display)}.wjzz-cover-frame{position:relative;padding:18px;border:1px solid rgba(201,168,76,.55);background:radial-gradient(circle at 20% 20%,rgba(201,168,76,.14),transparent 28%),linear-gradient(135deg,#020202 0%,#111 48%,#050505 100%);box-shadow:0 22px 70px rgba(0,0,0,.75),inset 0 0 40px rgba(201,168,76,.08);overflow:hidden}.wjzz-cover-frame:before{content:"";position:absolute;inset:8px;border:1px solid rgba(201,168,76,.35);pointer-events:none}.wjzz-cover-frame:after{content:"WJZZ DETROIT RADIO · EST. 1959 · JAZZ TRANSMISSION";position:absolute;left:50%;bottom:7px;transform:translateX(-50%);width:max-content;max-width:90%;color:rgba(201,168,76,.52);font-size:10px;letter-spacing:.22em;text-align:center;white-space:nowrap}.wjzz-cover-inner{position:relative;z-index:2;display:grid;grid-template-columns:minmax(220px,340px) 1fr;gap:26px;align-items:center;padding:28px;min-height:360px;background:linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.025) 1px,transparent 1px),radial-gradient(circle at 80% 10%,rgba(201,168,76,.10),transparent 34%);background-size:22px 22px,22px 22px,auto}.wjzz-cover-art-wrap{position:relative;aspect-ratio:1/1;width:100%;max-width:340px;margin:0 auto;padding:12px;border:1px solid rgba(201,168,76,.58);background:linear-gradient(145deg,rgba(201,168,76,.12),rgba(0,0,0,.2)),#070707;box-shadow:inset 0 0 24px rgba(201,168,76,.08),0 18px 44px rgba(0,0,0,.65)}.wjzz-current-cover{position:relative;z-index:2;display:block;width:100%;height:100%;object-fit:cover;background:#050505;border:1px solid rgba(255,255,255,.07);filter:contrast(1.05) saturate(.96)}.wjzz-vinyl-glow{position:absolute;inset:-18px;z-index:1;background:radial-gradient(circle,rgba(201,168,76,.22),transparent 62%);opacity:.65;animation:wjzzPulse 4.8s ease-in-out infinite;pointer-events:none}.wjzz-track-panel{position:relative;padding:26px;min-height:260px;border-left:1px solid rgba(201,168,76,.38);background:linear-gradient(180deg,rgba(201,168,76,.08),rgba(0,0,0,.08))}.wjzz-live-badge{display:inline-flex;align-items:center;gap:9px;margin-bottom:18px;padding:7px 10px;border:1px solid rgba(201,168,76,.45);color:var(--wjzz-gold-bright);background:rgba(0,0,0,.34);font-size:11px;letter-spacing:.18em;text-transform:uppercase}.wjzz-current-title{margin:0 0 10px;color:#f7dc84;font-size:clamp(28px,4.4vw,56px);line-height:.95;letter-spacing:.02em;text-transform:uppercase;text-shadow:0 0 22px rgba(201,168,76,.16)}.wjzz-current-artist{margin:0;color:#fff1b8;font-size:clamp(17px,2vw,24px);line-height:1.25;letter-spacing:.045em}.wjzz-divider{width:100%;height:1px;margin:22px 0 16px;background:linear-gradient(90deg,transparent,rgba(201,168,76,.78),transparent)}.wjzz-current-album,.wjzz-last-updated{margin:0;color:var(--wjzz-muted);font-size:13px;line-height:1.6;letter-spacing:.08em;text-transform:uppercase}.wjzz-last-updated{margin-top:12px;color:rgba(201,168,76,.58);font-size:11px}

.wjzz-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.wjzz-card{border:1px solid var(--wjzz-line);background:linear-gradient(180deg,rgba(201,168,76,.10),rgba(0,0,0,.22));padding:24px;min-height:160px;box-shadow:0 14px 34px rgba(0,0,0,.25)}.wjzz-card time,.wjzz-card .label{display:block;color:var(--wjzz-gold);font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px}.wjzz-card h3{margin:0 0 8px;font-family:var(--wjzz-font-display);color:#fff;font-size:1.6rem}.wjzz-card p{margin:0;color:var(--wjzz-muted)}

.wjzz-legacy{background:radial-gradient(circle at 20% 30%,rgba(109,20,20,.28),transparent 30%),#070707;border-top:1px solid var(--wjzz-line);border-bottom:1px solid var(--wjzz-line)}.wjzz-split{display:grid;grid-template-columns:1fr .9fr;gap:34px;align-items:center}.wjzz-venue-card{min-height:360px;border:1px solid var(--wjzz-line);display:grid;place-items:center;text-align:center;padding:34px;background:linear-gradient(135deg,rgba(201,168,76,.16),rgba(0,0,0,.62)),radial-gradient(circle at 50% 30%,rgba(255,255,255,.08),transparent 32%)}.wjzz-venue-card h3{font-family:var(--wjzz-font-display);font-size:clamp(2rem,4vw,3.6rem);line-height:1;margin:0;color:#fff}.wjzz-venue-card p{color:var(--wjzz-muted);letter-spacing:.12em;text-transform:uppercase}

.wjzz-footer{background:#030303;border-top:1px solid var(--wjzz-line);padding:46px 20px 24px}.wjzz-footer-grid{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:26px}.wjzz-footer h4{color:#fff;margin:0 0 12px;font-family:var(--wjzz-font-display)}.wjzz-footer p,.wjzz-footer li{color:var(--wjzz-muted);font-size:.92rem}.wjzz-footer ul{list-style:none;margin:0;padding:0}.wjzz-footer-bottom{max-width:1180px;margin:30px auto 0;border-top:1px solid rgba(201,168,76,.18);padding-top:18px;color:rgba(201,168,76,.62);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase}

@keyframes wjzzPulse{0%,100%{opacity:.35;transform:scale(.98)}50%{opacity:.8;transform:scale(1.02)}}
@keyframes wjzzBlink{0%,100%{opacity:.35}50%{opacity:1}}

@media(max-width:900px){.wjzz-header-inner{display:grid;grid-template-columns:1fr;justify-items:center}.wjzz-mini-player{justify-content:center}.wjzz-hero-inner,.wjzz-split{grid-template-columns:1fr}.wjzz-anniversary{justify-self:center}.wjzz-card-grid,.wjzz-footer-grid{grid-template-columns:1fr}.wjzz-section-header{display:block}.wjzz-cover-inner{grid-template-columns:1fr}.wjzz-track-panel{border-left:0;border-top:1px solid rgba(201,168,76,.35);padding:22px 0 8px}.wjzz-cover-frame:after{font-size:8px;letter-spacing:.12em}}
