/*
Theme Name: Blue Note Avant-Garde — Mogno Edition
Theme URI: https://mognomusic.com
Author: Mogno Music
Author URI: https://mognomusic.com
Description: Jazz-inspired WordPress block theme with Mogno Music branding. Avant-garde typography (Alfa Slab One + Barlow), crimson/navy/cream palette. Custom post types for Albums, Artists, and Groups. WooCommerce compatible.
Version: 3.1.0
Requires at least: 6.4
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: bluenote
*/

/* ==========================================================================
   DESIGN TOKENS  (local aliases for theme.json vars)
   ========================================================================== */

:root {
  --mn-navy:      var(--wp--preset--color--navy,      #0f1f3d);
  --mn-crimson:   var(--wp--preset--color--crimson,   #8b0016);
  --mn-crimson-dk:var(--wp--preset--color--crimson-dk,#6b0011);
  --mn-cream:     var(--wp--preset--color--cream,     #f5f0e8);
  --mn-surface:   var(--wp--preset--color--surface,   #edeae0);
  --mn-muted:     var(--wp--preset--color--muted,     #d4cfc4);
  --mn-text-muted:var(--wp--preset--color--text-muted,#7a7060);
  --mn-white:     #ffffff;

  --mn-font-display: var(--wp--preset--font-family--display, 'Alfa Slab One', Georgia, serif);
  --mn-font-body:    var(--wp--preset--font-family--body,    'Barlow', system-ui, sans-serif);
  --mn-font-mono:    var(--wp--preset--font-family--mono,    'Courier New', monospace);

  --mn-radius:    0px;
  --mn-trans:     0.25s ease;
  --mn-shadow:    0 4px 20px rgba(15, 31, 61, 0.12);
  --mn-shadow-lg: 0 12px 40px rgba(10, 8, 20, 0.22);

  /* header / ticker heights — used for scroll-offset */
  --mn-header-h:  80px;
  --mn-ticker-h:  48px;
}

/* ==========================================================================
   RESET & BASE
   ========================================================================== */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html, body { width: 100%; overflow-x: hidden; }

body {
  font-family: var(--mn-font-body);
  background-color: var(--mn-cream);
  color: var(--mn-navy);
  line-height: 1.65;
}

img { max-width: 100%; height: auto; display: block; }

a { color: var(--mn-crimson); transition: color var(--mn-trans); }
a:hover { color: var(--mn-navy); }

/* ==========================================================================
   UTILITY
   ========================================================================== */

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0;
  margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border-width: 0;
}

.text-crimson { color: var(--mn-crimson); }
.text-navy    { color: var(--mn-navy); }
.text-muted   { color: var(--mn-text-muted); }
.font-display { font-family: var(--mn-font-display); }
.font-mono    { font-family: var(--mn-font-mono); }

/* ==========================================================================
   GEOMETRY & DIVIDERS  (Avant-garde Bauhaus style)
   ========================================================================== */

.mn-divider {
  display: flex; align-items: center; gap: 1.5rem; margin: 3rem 0;
}
.mn-divider::before,
.mn-divider::after {
  content: ''; flex: 1; height: 2px; background-color: var(--mn-navy);
}
.mn-divider--crimson::before,
.mn-divider--crimson::after { background-color: var(--mn-crimson); }
.mn-divider--muted::before,
.mn-divider--muted::after   { background-color: var(--mn-muted); }

.mn-bar {
  width: 110px; height: 8px; background-color: var(--mn-navy);
  margin-bottom: 2rem;
}
.mn-bar--crimson { background-color: var(--mn-crimson); }

.mn-badge {
  display: inline-block;
  font-family: var(--mn-font-body);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mn-crimson);
  background: transparent;
  border: 1px solid rgba(139, 0, 22, 0.35);
  padding: 0.25rem 0.65rem;
  line-height: 1.6;
}

/* ==========================================================================
   GENRE BADGES & FILTER BAR
   ========================================================================== */

.genre-badge {
  display: inline-block;
  font-family: var(--mn-font-body);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mn-cream);
  background-color: var(--mn-navy);
  padding: 0.35rem 0.9rem;
  text-decoration: none;
  transition: background-color var(--mn-trans), color var(--mn-trans);
}
.genre-badge:hover,
.genre-badge.active { background-color: var(--mn-crimson); color: var(--mn-cream); }

.genre-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-bottom: 3rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--mn-muted);
}
.genre-filter-bar .genre-badge--all { background-color: var(--mn-crimson); }

/* ==========================================================================
   ALBUM CARD  (used in archives, related sections, artist/group pages)
   ========================================================================== */

.album-card {
  background-color: var(--mn-white);
  border: 1px solid var(--mn-muted);
  display: flex;
  flex-direction: column;
  transition: border-color var(--mn-trans), box-shadow var(--mn-trans), transform var(--mn-trans);
  overflow: hidden;
  position: relative;
}
.album-card:hover {
  border-color: var(--mn-crimson);
  box-shadow: var(--mn-shadow);
  transform: translateY(-3px);
}

.album-card-image {
  aspect-ratio: 1;
  overflow: hidden;
  background-color: var(--mn-navy);
  position: relative;
}
.album-card-image img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.album-card:hover .album-card-image img { transform: scale(1.06); }

/* No-image placeholder */
.album-card-image-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background-color: var(--mn-navy);
}
.album-card-image-placeholder::before {
  content: '';
  width: 60%;
  height: 60%;
  border: 3px solid var(--mn-crimson);
  border-radius: 50%;
}

.album-card-genre {
  position: absolute;
  top: 0.75rem; left: 0.75rem;
  z-index: 2;
}

.album-card-content {
  padding: 1.4rem 1.4rem 0.8rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.album-card-title {
  font-family: var(--mn-font-display);
  font-size: 1.1rem;
  font-weight: 400;
  color: var(--mn-navy);
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin-bottom: 0.4rem;
}
.album-card-title a { color: var(--mn-navy); text-decoration: none; }
.album-card-title a:hover { color: var(--mn-crimson); }

.album-card-artist {
  font-family: var(--mn-font-body);
  font-size: 0.85rem;
  font-weight: 300;
  font-style: italic;
  color: var(--mn-text-muted);
  margin-bottom: 0.35rem;
}
.album-card-artist a { color: var(--mn-text-muted); text-decoration: none; }
.album-card-artist a:hover { color: var(--mn-crimson); }

.album-card-ref {
  font-family: var(--mn-font-mono);
  font-size: 0.65rem;
  color: var(--mn-muted);
  letter-spacing: 0.08em;
  margin-top: auto;
  padding-top: 0.5rem;
}

.album-card-price {
  font-family: var(--mn-font-display);
  font-size: 1.3rem;
  color: var(--mn-crimson);
  font-weight: 400;
  padding: 0.6rem 1.4rem 0;
  border-top: 1px solid var(--mn-muted);
  margin-top: auto;
}

.album-card-footer {
  padding: 0.8rem 1.4rem 1.4rem;
  display: flex;
  gap: 0.75rem;
  align-items: center;
}

/* Card CTA button */
.btn-card-primary {
  font-family: var(--mn-font-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-cream);
  background-color: var(--mn-navy);
  padding: 0.65rem 1.4rem;
  border: 2px solid var(--mn-navy);
  text-decoration: none;
  transition: background-color var(--mn-trans), border-color var(--mn-trans), color var(--mn-trans);
  display: inline-block;
  cursor: pointer;
}
.btn-card-primary:hover {
  background-color: var(--mn-crimson);
  border-color: var(--mn-crimson);
  color: var(--mn-cream);
}
.btn-card-secondary {
  font-family: var(--mn-font-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-navy);
  background-color: transparent;
  padding: 0.65rem 1.4rem;
  border: 2px solid var(--mn-muted);
  text-decoration: none;
  transition: border-color var(--mn-trans), color var(--mn-trans);
  display: inline-block;
  cursor: pointer;
}
.btn-card-secondary:hover { border-color: var(--mn-navy); color: var(--mn-navy); }

/* WooCommerce add-to-cart inside card */
.album-card .woocommerce-loop-product__link,
.album-card .add_to_cart_button.wc-forward,
.album-card .add_to_cart_button {
  display: inline-block;
  font-family: var(--mn-font-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-cream);
  background-color: var(--mn-navy);
  padding: 0.65rem 1.4rem;
  border: 2px solid var(--mn-navy);
  text-decoration: none;
  transition: background-color var(--mn-trans), border-color var(--mn-trans);
}
.album-card .add_to_cart_button:hover {
  background-color: var(--mn-crimson);
  border-color: var(--mn-crimson);
}

/* Albums grid */
.albums-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 2rem;
}

/* ==========================================================================
   ARTIST CARD
   ========================================================================== */

.artist-card {
  display: flex;
  flex-direction: column;
  text-align: center;
  transition: transform var(--mn-trans);
  cursor: pointer;
}
.artist-card:hover { transform: translateY(-4px); }

.artist-photo {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background-color: var(--mn-navy);
  margin-bottom: 1.2rem;
  position: relative;
}
.artist-photo img { width: 100%; height: 100%; object-fit: cover; }

.artist-name {
  font-family: var(--mn-font-display);
  font-size: 1.05rem;
  font-weight: 400;
  color: var(--mn-navy);
  letter-spacing: -0.02em;
  text-transform: uppercase;
  margin-bottom: 0.3rem;
}
.artist-name a { color: var(--mn-navy); text-decoration: none; }
.artist-name a:hover { color: var(--mn-crimson); }

.artist-instrument {
  font-family: var(--mn-font-body);
  font-size: 0.82rem;
  font-weight: 300;
  font-style: italic;
  color: var(--mn-text-muted);
}

.artist-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 2rem;
}

/* ==========================================================================
   SINGLE ALBUM LAYOUT
   ========================================================================== */

.single-album-wrapper {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 5rem;
  align-items: start;
  margin: 3rem 0 5rem;
}
@media (max-width: 900px) {
  .single-album-wrapper { grid-template-columns: 1fr; gap: 3rem; }
}

/* Sticky sidebar */
.album-sidebar {
  position: sticky;
  top: calc(var(--mn-header-h) + 2rem);
  height: fit-content;
}

/* Cover image */
.album-cover-wrap {
  width: 100%;
  aspect-ratio: 1;
  overflow: hidden;
  background-color: var(--mn-navy);
  margin-bottom: 2rem;
  box-shadow: var(--mn-shadow-lg);
}
.album-cover-wrap img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Info panels */
.album-info-panel {
  background-color: var(--mn-surface);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  border-left: 4px solid var(--mn-crimson);
}
.album-info-panel--navy { border-left-color: var(--mn-navy); }

.album-info-panel dl { margin: 0; }
.album-info-panel dt {
  font-family: var(--mn-font-body);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mn-text-muted);
  margin-top: 1rem;
  margin-bottom: 0.3rem;
}
.album-info-panel dt:first-of-type { margin-top: 0; }
.album-info-panel dd {
  font-size: 0.95rem;
  color: var(--mn-navy);
  margin: 0 0 0.25rem 0;
}

.album-price-display {
  font-family: var(--mn-font-display);
  font-size: 1.8rem;
  font-weight: 400;
  color: var(--mn-crimson);
  margin-bottom: 1.2rem;
  line-height: 1;
}

/* Streaming buttons */
.streaming-panel {
  background-color: var(--mn-surface);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  border-left: 4px solid var(--mn-navy);
}
.streaming-panel-label {
  font-family: var(--mn-font-body);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mn-text-muted);
  margin-bottom: 1rem;
}
.streaming-buttons {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem;
}
.streaming-btn {
  display: flex; align-items: center; justify-content: center;
  padding: 0.7rem 0.5rem;
  font-family: var(--mn-font-body);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mn-white);
  text-decoration: none;
  transition: opacity var(--mn-trans);
}
.streaming-btn:hover { opacity: 0.82; color: var(--mn-white); }
.streaming-btn-apple   { background-color: #c5362b; }
.streaming-btn-spotify { background-color: #1db954; }
.streaming-btn-deezer  { background-color: #ff0084; }
.streaming-btn-qobuz   { background-color: #002185; }

/* Main content column */
.album-main {}

.album-header {
  margin-bottom: 2.5rem;
}
.album-main-title {
  font-family: var(--mn-font-display);
  font-size: clamp(2rem, 5vw, 3.8rem);
  font-weight: 400;
  line-height: 1;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--mn-navy);
  margin-bottom: 1rem;
}
.album-byline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 2rem;
  align-items: center;
}
.album-byline a {
  font-family: var(--mn-font-body);
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--mn-crimson);
  text-decoration: none;
  border-bottom: 1px solid rgba(139, 0, 22, 0.35);
}
.album-byline a:hover { border-color: var(--mn-crimson); }
.album-byline-sep {
  color: var(--mn-muted);
  font-size: 0.75rem;
}

/* Language toggle */
.language-toggle {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 1.5rem;
}
.lang-toggle {
  font-family: var(--mn-font-body);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0.45rem 1rem;
  border: 1px solid var(--mn-muted);
  background: transparent;
  color: var(--mn-text-muted);
  cursor: pointer;
  transition: all var(--mn-trans);
}
.lang-toggle.active,
.lang-toggle:hover {
  background-color: var(--mn-navy);
  color: var(--mn-cream);
  border-color: var(--mn-navy);
}

.album-description {
  font-size: 1rem;
  line-height: 1.75;
  color: var(--mn-navy);
  margin-bottom: 2rem;
}
.album-description p { margin-bottom: 1rem; }

/* ==========================================================================
   TRACK LISTING
   ========================================================================== */

.track-list { list-style: none; margin: 0; padding: 0; }

.track-item {
  display: grid;
  grid-template-columns: 44px 1fr auto;
  gap: 1.2rem;
  padding: 1.2rem 0;
  border-bottom: 1px solid var(--mn-muted);
  align-items: center;
  transition: background-color var(--mn-trans);
}
.track-item:first-child { border-top: 1px solid var(--mn-muted); }
.track-item:hover { background-color: var(--mn-surface); padding-left: 0.5rem; padding-right: 0.5rem; }

.track-number {
  font-family: var(--mn-font-mono);
  font-size: 0.75rem;
  color: var(--mn-text-muted);
  text-align: right;
}
.track-info {}
.track-title {
  font-family: var(--mn-font-display);
  font-size: 0.95rem;
  font-weight: 400;
  letter-spacing: -0.01em;
  text-transform: uppercase;
  color: var(--mn-navy);
  margin: 0 0 0.2rem;
}
.track-details {
  font-size: 0.78rem;
  color: var(--mn-text-muted);
  font-style: italic;
  margin: 0;
}
.track-duration {
  font-family: var(--mn-font-mono);
  font-size: 0.82rem;
  color: var(--mn-text-muted);
  white-space: nowrap;
}
.track-expanded {
  grid-column: 1 / -1;
  font-size: 0.82rem;
  padding-top: 0.5rem;
  color: var(--mn-text-muted);
}
.track-expanded summary {
  cursor: pointer;
  font-weight: 600;
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--mn-crimson);
}
.track-mp3-link {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 0.5rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--mn-navy);
  text-decoration: none;
  border-bottom: 1px solid var(--mn-muted);
  transition: border-color var(--mn-trans), color var(--mn-trans);
}
.track-mp3-link:hover { color: var(--mn-crimson); border-color: var(--mn-crimson); }

/* ==========================================================================
   MUSICIANS GRID
   ========================================================================== */

.musicians-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1.2rem;
  margin: 1.5rem 0;
}
.musician-card {
  background-color: var(--mn-surface);
  padding: 1.4rem;
  border-left: 3px solid var(--mn-muted);
  transition: border-color var(--mn-trans);
}
.musician-card:hover { border-color: var(--mn-navy); }
.musician-name {
  font-family: var(--mn-font-display);
  font-size: 0.95rem;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  color: var(--mn-navy);
  margin: 0 0 0.3rem;
}
.musician-name a { color: var(--mn-navy); text-decoration: none; }
.musician-name a:hover { color: var(--mn-crimson); }
.musician-instrument {
  font-size: 0.82rem;
  font-style: italic;
  color: var(--mn-text-muted);
  margin: 0 0 0.4rem;
}
.musician-bio {
  font-size: 0.8rem;
  color: var(--mn-text-muted);
  margin: 0;
  line-height: 1.55;
}

/* ==========================================================================
   CREDITS GRID
   ========================================================================== */

.credits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
  margin: 1.5rem 0;
}
.credit-item {
  padding: 1rem 1.2rem;
  border-top: 2px solid var(--mn-navy);
}
.credit-name {
  font-family: var(--mn-font-display);
  font-size: 0.9rem;
  font-weight: 400;
  text-transform: uppercase;
  color: var(--mn-navy);
  margin: 0 0 0.2rem;
}
.credit-name a { color: var(--mn-navy); text-decoration: none; }
.credit-name a:hover { color: var(--mn-crimson); }
.credit-role {
  font-size: 0.78rem;
  font-style: italic;
  color: var(--mn-crimson);
  margin: 0;
}

/* ==========================================================================
   SINGLE ARTIST LAYOUT
   ========================================================================== */

.single-artist-wrapper {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 5rem;
  align-items: start;
  margin: 3rem 0 5rem;
}
@media (max-width: 860px) {
  .single-artist-wrapper { grid-template-columns: 1fr; gap: 3rem; }
}
.artist-sidebar {
  position: sticky;
  top: calc(var(--mn-header-h) + 2rem);
  height: fit-content;
}
.artist-sidebar-photo {
  width: 100%;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  background-color: var(--mn-navy);
  margin-bottom: 2rem;
  box-shadow: var(--mn-shadow);
}
.artist-sidebar-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.artist-contact-panel {
  background-color: var(--mn-surface);
  padding: 1.4rem;
  border-left: 4px solid var(--mn-navy);
  font-size: 0.88rem;
  line-height: 1.6;
}
.artist-contact-panel dt {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mn-text-muted);
  margin-bottom: 0.5rem;
}
.artist-main-title {
  font-family: var(--mn-font-display);
  font-size: clamp(2rem, 4vw, 3.5rem);
  font-weight: 400;
  line-height: 1;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--mn-navy);
  margin-bottom: 0.6rem;
}
.artist-instrument-line {
  font-size: 1rem;
  font-style: italic;
  color: var(--mn-text-muted);
  margin-bottom: 2rem;
  font-weight: 300;
}

/* Groups list on artist page */
.groups-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 1.2rem;
  margin: 1.5rem 0;
}
.group-link-card {
  background-color: var(--mn-surface);
  padding: 1.4rem;
  border-left: 4px solid var(--mn-navy);
  text-decoration: none;
  display: block;
  transition: border-color var(--mn-trans), box-shadow var(--mn-trans);
}
.group-link-card:hover { border-color: var(--mn-crimson); box-shadow: var(--mn-shadow); }
.group-link-card-name {
  font-family: var(--mn-font-display);
  font-size: 0.95rem;
  font-weight: 400;
  text-transform: uppercase;
  color: var(--mn-navy);
  margin: 0 0 0.35rem;
}
.group-link-card:hover .group-link-card-name { color: var(--mn-crimson); }
.group-link-card-excerpt {
  font-size: 0.82rem;
  color: var(--mn-text-muted);
  margin: 0;
  line-height: 1.5;
}

/* ==========================================================================
   SINGLE GROUP LAYOUT
   ========================================================================== */

.single-group-wrapper { margin: 3rem 0 5rem; }

.group-hero {
  background-color: var(--mn-navy);
  color: var(--mn-cream);
  padding: 4rem 5rem;
  margin-bottom: 4rem;
  position: relative;
  overflow: hidden;
}
.group-hero::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 200px; height: 200px;
  background-color: var(--mn-crimson);
  transform: rotate(25deg);
  opacity: 0.3;
}
.group-hero-title {
  font-family: var(--mn-font-display);
  font-size: clamp(2.2rem, 5vw, 4rem);
  font-weight: 400;
  line-height: 1;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--mn-cream);
  margin-bottom: 1rem;
  position: relative;
}
.group-hero-excerpt {
  font-size: 1rem;
  font-weight: 300;
  line-height: 1.7;
  color: rgba(245, 240, 232, 0.75);
  max-width: 60ch;
  position: relative;
}
@media (max-width: 768px) {
  .group-hero { padding: 3rem 2rem; }
}

/* Members */
.group-members-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1.2rem;
  margin: 1.5rem 0;
}
.member-card {
  background-color: var(--mn-surface);
  padding: 1.4rem;
  border-top: 3px solid var(--mn-navy);
  transition: border-color var(--mn-trans);
}
.member-card:hover { border-color: var(--mn-crimson); }
.member-name {
  font-family: var(--mn-font-display);
  font-size: 0.95rem;
  font-weight: 400;
  text-transform: uppercase;
  color: var(--mn-navy);
  margin: 0 0 0.3rem;
}
.member-name a { color: var(--mn-navy); text-decoration: none; }
.member-name a:hover { color: var(--mn-crimson); }
.member-instrument {
  font-size: 0.82rem;
  font-style: italic;
  color: var(--mn-text-muted);
  margin: 0;
}

/* Booking panel */
.booking-panel {
  background-color: var(--mn-navy);
  color: var(--mn-cream);
  padding: 2.5rem 3rem;
  margin-top: 3rem;
  position: relative;
}
.booking-panel-label {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--mn-crimson);
  margin-bottom: 1rem;
  display: block;
}
.booking-panel h3 {
  color: var(--mn-cream);
  font-family: var(--mn-font-display);
  font-size: 1.6rem;
  font-weight: 400;
  text-transform: uppercase;
  margin-bottom: 1.2rem;
}
.booking-panel p,
.booking-panel address { font-size: 0.95rem; line-height: 1.7; font-style: normal; color: rgba(245,240,232,0.8); }

/* ==========================================================================
   ARCHIVE HERO BANNER
   ========================================================================== */

.archive-banner {
  background-color: var(--mn-navy);
  color: var(--mn-cream);
  padding: 5rem var(--wp--preset--spacing--50, 3rem) 4rem;
  position: relative;
  overflow: hidden;
  margin-bottom: 4rem;
}
.archive-banner::after {
  content: '';
  position: absolute;
  bottom: -40px; right: -40px;
  width: 160px; height: 160px;
  background-color: var(--mn-crimson);
  transform: rotate(18deg);
  opacity: 0.25;
}
.archive-banner-eyebrow {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--mn-crimson);
  margin-bottom: 1rem;
  display: block;
}
.archive-banner-title {
  font-family: var(--mn-font-display);
  font-size: clamp(2.5rem, 5vw, 4.5rem);
  font-weight: 400;
  line-height: 1;
  letter-spacing: -0.03em;
  text-transform: uppercase;
  color: var(--mn-cream);
  margin-bottom: 1.2rem;
}
.archive-banner-desc {
  font-size: 1rem;
  font-weight: 300;
  color: rgba(245,240,232,0.7);
  max-width: 55ch;
}

/* ==========================================================================
   SECTION HEADINGS (used in single pages)
   ========================================================================== */

.mn-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 2rem;
}
.mn-section-head h2,
.mn-section-head h3 {
  font-family: var(--mn-font-display);
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  color: var(--mn-navy);
  margin: 0;
}
.mn-section-head-link {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mn-crimson);
  text-decoration: none;
  border-bottom: 1px solid rgba(139,0,22,0.35);
  transition: border-color var(--mn-trans);
}
.mn-section-head-link:hover { border-color: var(--mn-crimson); }

/* ==========================================================================
   PRODUCTION NOTES PANEL
   ========================================================================== */

.production-notes-panel {
  background-color: var(--mn-surface);
  padding: 2rem 2.5rem;
  border-left: 4px solid var(--mn-navy);
  margin-bottom: 3rem;
}
.production-notes-panel h3 {
  font-family: var(--mn-font-display);
  font-size: 1rem;
  font-weight: 400;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 1rem;
}
.production-notes-panel p { font-size: 0.9rem; line-height: 1.7; color: var(--mn-text-muted); }

/* ==========================================================================
   VIDEOS SECTION
   ========================================================================== */

.videos-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.5rem;
  margin: 1.5rem 0;
}
.video-embed { aspect-ratio: 16/9; overflow: hidden; }
.video-embed iframe { width: 100%; height: 100%; border: none; }

/* ==========================================================================
   RELATED ALBUMS  (appears at bottom of single pages)
   ========================================================================== */

.related-albums-section {
  margin-top: 4rem;
  padding-top: 3rem;
  border-top: 1px solid var(--mn-muted);
}

/* ==========================================================================
   PAGINATION
   ========================================================================== */

.archive-pagination {
  margin-top: 4rem;
  display: flex;
  justify-content: center;
}
.archive-pagination .page-numbers {
  display: inline-flex;
  gap: 0.4rem;
}
.archive-pagination .page-numbers a,
.archive-pagination .page-numbers span {
  display: inline-block;
  width: 40px; height: 40px;
  line-height: 40px;
  text-align: center;
  font-family: var(--mn-font-body);
  font-size: 0.82rem;
  font-weight: 600;
  text-decoration: none;
  color: var(--mn-navy);
  border: 1px solid var(--mn-muted);
  transition: all var(--mn-trans);
}
.archive-pagination .page-numbers a:hover { border-color: var(--mn-navy); }
.archive-pagination .page-numbers .current {
  background-color: var(--mn-crimson);
  color: var(--mn-cream);
  border-color: var(--mn-crimson);
}

/* ==========================================================================
   WooCommerce OVERRIDES
   ========================================================================== */

/* Reset WC adding its own sans-serif overrides */
.woocommerce,
.woocommerce-page {
  font-family: var(--mn-font-body);
}

/* Notices */
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info {
  border-top-color: var(--mn-navy);
  background-color: var(--mn-surface);
  color: var(--mn-navy);
}
.woocommerce .woocommerce-error {
  border-top-color: var(--mn-crimson);
  background-color: var(--mn-surface);
}

/* Add to cart button (WC native, on single product page created from album) */
.woocommerce .single_add_to_cart_button,
.woocommerce button.button.alt,
.woocommerce a.button.alt {
  font-family: var(--mn-font-body) !important;
  font-size: 0.82rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  background-color: var(--mn-navy) !important;
  color: var(--mn-cream) !important;
  border: 2px solid var(--mn-navy) !important;
  border-radius: 0 !important;
  padding: 1rem 2.5rem !important;
  transition: background-color var(--mn-trans), border-color var(--mn-trans) !important;
}
.woocommerce .single_add_to_cart_button:hover,
.woocommerce button.button.alt:hover,
.woocommerce a.button.alt:hover {
  background-color: var(--mn-crimson) !important;
  border-color: var(--mn-crimson) !important;
}

/* Quantity input */
.woocommerce .quantity input.qty {
  border: 1px solid var(--mn-muted);
  border-radius: 0;
  font-family: var(--mn-font-mono);
  color: var(--mn-navy);
}
.woocommerce .quantity input.qty:focus { border-color: var(--mn-navy); outline: none; }

/* Cart / checkout tables */
.woocommerce table.shop_table { border: 1px solid var(--mn-muted); border-radius: 0; }
.woocommerce table.shop_table th {
  font-family: var(--mn-font-body);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--mn-text-muted);
  background-color: var(--mn-surface);
}
.woocommerce table.shop_table td { border-color: var(--mn-muted); }

/* Price */
.woocommerce .price,
.woocommerce .amount {
  font-family: var(--mn-font-display);
  color: var(--mn-crimson);
}

/* Order meta (on checkout) */
.woocommerce .shop_attributes th {
  font-family: var(--mn-font-body);
  font-size: 0.7rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--mn-text-muted);
}

/* ==========================================================================
   bluenote_album_purchase_button ACTION HOOK  (custom non-WC checkout)
   ========================================================================== */

.bluenote-purchase-wrap {
  margin-top: 1.2rem;
}
.bluenote-purchase-wrap form { margin: 0; }
/* PayPal / Stripe embedded button container */
.bluenote-paypal-btn img { max-width: 100%; height: auto; }

/* ==========================================================================
   ANIMATIONS
   ========================================================================== */

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(28px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.fade-up { animation: fadeUp 0.65s ease forwards; }
.fade-in { animation: fadeIn 0.65s ease forwards; }

.animate-on-scroll {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.animate-on-scroll.is-visible { opacity: 1; transform: translateY(0); }

.stagger-children > * {
  opacity: 0;
  transform: translateY(18px);
  animation: fadeUp 0.5s ease forwards;
}
.stagger-children > *:nth-child(1) { animation-delay: 0.08s; }
.stagger-children > *:nth-child(2) { animation-delay: 0.18s; }
.stagger-children > *:nth-child(3) { animation-delay: 0.28s; }
.stagger-children > *:nth-child(4) { animation-delay: 0.38s; }
.stagger-children > *:nth-child(5) { animation-delay: 0.48s; }
.stagger-children > *:nth-child(6) { animation-delay: 0.58s; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 768px) {
  .albums-grid { grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); }
  .artist-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); }
  .musicians-grid,
  .credits-grid,
  .group-members-list { grid-template-columns: 1fr 1fr; }
  .streaming-buttons { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
  .albums-grid { grid-template-columns: 1fr; }
  .artist-grid { grid-template-columns: 1fr 1fr; }
  .musicians-grid,
  .credits-grid,
  .group-members-list,
  .groups-list { grid-template-columns: 1fr; }
}

/* ==========================================================================
   FSE BLOCK RESET
   ========================================================================== */

.wp-site-blocks > footer { margin-block-start: 0; }

/* Give the content area room for the sticky ticker */
.wp-site-blocks { padding-bottom: var(--mn-ticker-h); }
