/* ==========================================================================
   vinylrecords.dev — style.css
   Dark studio aesthetic. Smoky. Real. Not cosmic, not lounge.
   Fonts: Cinzel (headings) + Share Tech Mono (labels/annotations)
   ========================================================================== */


/* ==========================================================================
   1. CUSTOM PROPERTIES
   ========================================================================== */

:root {
  --font-heading: 'Cinzel', Georgia, serif;
  --font-mono: 'Share Tech Mono', 'Courier New', monospace;
  --bg-global: #080808;
  --text-primary: rgba(240,235,225,0.90);
  --text-muted: rgba(240,235,225,0.42);
  --grid-gap: 2px;
  --t-block: 0.25s ease;
  /* Fallback block vars — overridden per-block */
  --block-bg: #111;
  --block-accent: #fff;
  --block-accent-rgb: 255,255,255;
}


/* ==========================================================================
   2. PER-ARTIST BLOCK COLOR TOKENS
   ========================================================================== */

.block--pink-floyd         { --block-bg:#0a0a1a; --block-bg-rgb:10,10,26;   --block-accent:#a259c4; --block-accent-rgb:162,89,196; }
.block--led-zeppelin       { --block-bg:#1a0a00; --block-bg-rgb:26,10,0;    --block-accent:#e87c2a; --block-accent-rgb:232,124,42; }
.block--jimi-hendrix       { --block-bg:#0d0010; --block-bg-rgb:13,0,16;    --block-accent:#bf40ff; --block-accent-rgb:191,64,255; }
.block--grateful-dead      { --block-bg:#001a0a; --block-bg-rgb:0,26,10;    --block-accent:#e8c84a; --block-accent-rgb:232,200,74; }
.block--janis-joplin       { --block-bg:#1a0800; --block-bg-rgb:26,8,0;     --block-accent:#d4a843; --block-accent-rgb:212,168,67; }
.block--the-doors          { --block-bg:#0d0800; --block-bg-rgb:13,8,0;     --block-accent:#c9703a; --block-accent-rgb:201,112,58; }
.block--cream              { --block-bg:#0a0a00; --block-bg-rgb:10,10,0;    --block-accent:#c9b840; --block-accent-rgb:201,184,64; }
.block--jefferson-airplane { --block-bg:#080010; --block-bg-rgb:8,0,16;     --block-accent:#6a40bf; --block-accent-rgb:106,64,191; }
.block--santana            { --block-bg:#0a1000; --block-bg-rgb:10,16,0;    --block-accent:#e84a30; --block-accent-rgb:232,74,48; }
.block--fleetwood-mac      { --block-bg:#0a0010; --block-bg-rgb:10,0,16;    --block-accent:#c084e0; --block-accent-rgb:192,132,224; }
.block--david-bowie        { --block-bg:#080010; --block-bg-rgb:8,0,16;     --block-accent:#e840a0; --block-accent-rgb:232,64,160; }
.block--black-sabbath      { --block-bg:#0a0000; --block-bg-rgb:10,0,0;     --block-accent:#bf2020; --block-accent-rgb:191,32,32; }
.block--velvet-underground { --block-bg:#0d0d0d; --block-bg-rgb:13,13,13;   --block-accent:#e8e8b0; --block-accent-rgb:232,232,176; }
.block--joni-mitchell      { --block-bg:#000a10; --block-bg-rgb:0,10,16;    --block-accent:#6ab8d4; --block-accent-rgb:106,184,212; }
.block--neil-young         { --block-bg:#0a0800; --block-bg-rgb:10,8,0;     --block-accent:#c8a84a; --block-accent-rgb:200,168,74; }
.block--pearl-jam          { --block-bg:#0a0808; --block-bg-rgb:10,8,8;     --block-accent:#e87030; --block-accent-rgb:232,112,48; }


/* ==========================================================================
   3. RESET + BASE
   ========================================================================== */

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

html {
  scroll-behavior: smooth;
}

body {
  background: #080808;
  color: var(--text-primary);
  font-family: var(--font-mono);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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

a {
  color: inherit;
  text-decoration: none;
}

/* Custom scrollbar */
::-webkit-scrollbar {
  width: 4px;
}
::-webkit-scrollbar-track {
  background: #080808;
}
::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,0.15);
  border-radius: 2px;
}
::-webkit-scrollbar-thumb:hover {
  background: rgba(255,255,255,0.25);
}


/* ==========================================================================
   4. GLOBAL GRAIN TEXTURE
   ========================================================================== */

body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  opacity: 0.04;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px 200px;
}


/* ==========================================================================
   5. SITE HEADER
   ========================================================================== */

.site-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 500;
  padding: 1.5rem 2rem;
  mix-blend-mode: difference;
  user-select: none;
}

.logo-mark {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: white; /* inverts via mix-blend-mode */
}


/* ==========================================================================
   6. HERO SECTION
   ========================================================================== */

.hero {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 600px;
  background: #0a0806;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

/* Warm amber glow from bottom-center */
.hero::after {
  content: '';
  position: absolute;
  bottom: -20%;
  left: 10%;
  width: 500px;
  height: 400px;
  background: radial-gradient(ellipse, rgba(200,140,60,0.12) 0%, transparent 70%);
  pointer-events: none;
  z-index: 1;
}


/* ==========================================================================
   7. HERO EQUIPMENT — AMP (Fender Tweed CSS Art)
   ========================================================================== */

.amp {
  position: absolute;
  bottom: 80px;
  left: clamp(80px, 12vw, 200px);
  width: clamp(140px, 14vw, 220px);
  height: clamp(170px, 17vw, 265px);
  z-index: 10;
}

.amp-body {
  width: 100%;
  height: 100%;
  background:
    repeating-linear-gradient(
      90deg,
      transparent 0px, transparent 3px,
      rgba(0,0,0,0.08) 3px, rgba(0,0,0,0.08) 4px
    ),
    repeating-linear-gradient(
      0deg,
      transparent 0px, transparent 4px,
      rgba(0,0,0,0.05) 4px, rgba(0,0,0,0.05) 5px
    ),
    linear-gradient(160deg, #d4b96a 0%, #c8a84a 30%, #b8982a 70%, #c8a84a 100%);
  border-radius: 4px 4px 2px 2px;
  box-shadow: 0 8px 40px rgba(0,0,0,0.7), inset 0 1px 0 rgba(255,255,255,0.15);
  position: relative;
  overflow: hidden;
}

.amp-handle {
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%);
  width: 40%;
  height: 10px;
  background: linear-gradient(90deg, #3a2810, #6a4820, #3a2810);
  border-radius: 5px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.5);
}

.amp-panel {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 28%;
  background: linear-gradient(180deg, #aaa 0%, #c8c8c8 40%, #999 100%);
  border-bottom: 1px solid #666;
  display: flex;
  align-items: center;
  justify-content: space-around;
  padding: 0 15%;
}

.amp-knob {
  width: clamp(10px, 1.2vw, 16px);
  height: clamp(10px, 1.2vw, 16px);
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #555, #1a1a1a);
  box-shadow: 0 2px 4px rgba(0,0,0,0.6), inset 0 1px 1px rgba(255,255,255,0.1);
  position: relative;
}

.amp-knob::after {
  content: '';
  position: absolute;
  top: 15%;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  height: 35%;
  background: rgba(255,255,255,0.4);
  border-radius: 1px;
}

.amp-grille {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 62%;
  background:
    repeating-linear-gradient(
      0deg,
      transparent 0px, transparent 5px,
      rgba(0,0,0,0.15) 5px, rgba(0,0,0,0.15) 6px
    ),
    linear-gradient(160deg, #8a7230 0%, #c8a84a 50%, #7a6220 100%);
  border-top: 2px solid #888;
}

.amp-glow {
  position: absolute;
  bottom: 0;
  left: -20%;
  right: -20%;
  height: 60px;
  background: radial-gradient(ellipse, rgba(200,160,60,0.25) 0%, transparent 70%);
  pointer-events: none;
}


/* ==========================================================================
   8. HERO EQUIPMENT — ASHTRAY + CIGARETTE
   ========================================================================== */

.ashtray-group {
  position: absolute;
  bottom: 85px;
  left: clamp(260px, 26vw, 440px);
  z-index: 10;
}

.ashtray {
  width: clamp(60px, 6vw, 90px);
  height: clamp(14px, 1.5vw, 22px);
  background: linear-gradient(180deg, #e8e0d0 0%, #c8c0b0 60%, #a8a098 100%);
  border-radius: 50%;
  box-shadow: 0 4px 12px rgba(0,0,0,0.5), inset 0 2px 4px rgba(0,0,0,0.2);
  position: relative;
}

.cigarette {
  position: absolute;
  bottom: 8px;
  left: 25%;
  width: clamp(50px, 5.5vw, 80px);
  height: clamp(5px, 0.6vw, 8px);
  transform: rotate(-48deg);
  transform-origin: right center;
  background: linear-gradient(90deg,
    rgba(200,160,120,0.6) 0%,
    #f5f0e8 8%,
    #f5f0e8 75%,
    #e8d8b8 82%,
    #c8b890 88%,
    rgba(80,40,20,0.5) 100%
  );
  border-radius: 3px 1px 1px 3px;
}

.cigarette-tip {
  position: absolute;
  right: -2px;
  top: 50%;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: radial-gradient(circle at 40% 40%, #ff8c30, #e84a00 50%, #8b2000 100%);
  box-shadow: 0 0 6px 2px rgba(255,100,20,0.5), 0 0 14px 4px rgba(255,80,0,0.2);
}

.smoke {
  position: absolute;
  bottom: 100%;
  left: calc(25% + clamp(45px, 4.5vw, 68px));
  width: 16px;
  pointer-events: none;
}


/* ==========================================================================
   9. HERO EQUIPMENT — STRATOCASTER
   ========================================================================== */

.strat-wrap {
  position: absolute;
  bottom: 40px;
  left: clamp(360px, 38vw, 600px);
  z-index: 8;
  opacity: 0.7;
  filter: drop-shadow(-4px 4px 20px rgba(0,0,0,0.8));
}

.strat-wrap svg {
  width: clamp(60px, 7vw, 110px);
  height: auto;
  transform: rotate(-8deg);
}


/* ==========================================================================
   10. HERO TEXT
   ========================================================================== */

.hero-text {
  position: relative;
  z-index: 20;
  margin-left: auto;
  max-width: 60%;
  padding: clamp(2rem, 5vw, 4rem);
  padding-bottom: clamp(3rem, 6vw, 5rem);
}

.hero-signal {
  font-family: var(--font-heading);
  font-size: clamp(4rem, 10vw, 9rem);
  font-weight: 900;
  letter-spacing: -0.02em;
  color: rgba(240,230,210,0.92);
  line-height: 0.9;
  display: block;
  margin-bottom: 0.5rem;
}

.hero-tagline {
  font-family: var(--font-mono);
  font-size: clamp(0.65rem, 1vw, 0.85rem);
  letter-spacing: 0.25em;
  text-transform: lowercase;
  color: rgba(200,160,80,0.7);
  display: block;
  margin-bottom: 2.5rem;
}

.hero-cta {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.2em;
  text-transform: lowercase;
  color: rgba(240,230,210,0.35);
  display: inline-block;
  transition: color 0.3s ease;
}

.hero-cta:hover {
  color: rgba(240,230,210,0.7);
}


/* ==========================================================================
   11. ARTIST GRID
   ========================================================================== */

.artist-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: clamp(220px, 25vw, 360px);
  gap: var(--grid-gap);
  background: var(--bg-global);
}


/* ==========================================================================
   12. BLOCK BASE
   ========================================================================== */

.block {
  position: relative;
  background-color: var(--block-bg);
  background-size: cover !important;
  background-position: center 20% !important;
  background-repeat: no-repeat;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(1.25rem, 2.5vw, 2rem);
  isolation: isolate;
  cursor: default;
  /* Stagger fade-in — animationPlayState set to running by JS IntersectionObserver */
  opacity: 0;
  transform: translateY(6px);
  animation: block-appear 0.55s ease forwards;
  animation-play-state: paused;
  /* Hover transition */
  transition: transform var(--t-block), box-shadow var(--t-block), filter var(--t-block);
  will-change: transform;
}

/* Photo-to-color gradient overlay — photo at top, solid color at bottom */
.block::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(0,0,0,0.10) 25%,
    rgba(var(--block-bg-rgb, 10,10,10), 0.55) 55%,
    rgba(var(--block-bg-rgb, 10,10,10), 0.88) 75%,
    var(--block-bg) 100%
  );
  z-index: 1;
}

/* Per-block grain overlay */
.block::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: 0.055;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 180px 180px;
  mix-blend-mode: overlay;
}

.block-body {
  position: relative;
  z-index: 5;
}

/* Hover state */
.block:hover {
  transform: scale(1.015);
  box-shadow:
    0 0 0 1px rgba(var(--block-accent-rgb), 0.6),
    0 0 30px 0 rgba(var(--block-accent-rgb), 0.12);
  filter: brightness(1.07);
  z-index: 20;
}


/* ==========================================================================
   13. BLOCK SIZES
   ========================================================================== */

.block--large  { grid-column: span 2; grid-row: span 2; }
.block--medium { grid-column: span 1; grid-row: span 2; }
.block--small  { grid-column: span 1; grid-row: span 1; }


/* ==========================================================================
   14. ALBUM LABEL (circular badge top-left)
   ========================================================================== */

.block-label {
  position: absolute;
  top: clamp(0.8rem, 1.5vw, 1.25rem);
  left: clamp(0.8rem, 1.5vw, 1.25rem);
  width: clamp(48px, 5vw, 72px);
  height: clamp(48px, 5vw, 72px);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: clamp(0.38rem, 0.6vw, 0.55rem);
  letter-spacing: 0.06em;
  text-align: center;
  z-index: 6;
  cursor: default;
  transition: transform 0.4s ease;
  padding: 6px;
  line-height: 1.3;
  box-shadow: 0 2px 12px rgba(0,0,0,0.5);
}

.block:hover .block-label {
  animation: slow-spin 12s linear infinite;
}

/* Per-artist label colors */
.block--pink-floyd .block-label         { background: #eeeef5; color: #0a0a1a; border: 2px solid #ccc; }
.block--led-zeppelin .block-label       { background: #2e1a08; color: #e87c2a; border: 2px solid #e87c2a; }
.block--jimi-hendrix .block-label       { background: #200030; color: #bf40ff; border: 2px solid #bf40ff; }
.block--grateful-dead .block-label      { background: #0a0a0a; color: #e8c84a; border: 2px solid #e8c84a; }
.block--janis-joplin .block-label       { background: #3a1a08; color: #d4a843; border: 2px solid #d4a843; }
.block--the-doors .block-label          { background: #111; color: #f0e8d8; border: 2px solid #555; }
.block--cream .block-label              { background: #c8200a; color: #f0d840; border: 2px solid #f0d840; }
.block--jefferson-airplane .block-label { background: #e880c0; color: #080010; border: 2px solid #6a40bf; }
.block--santana .block-label            { background: #0a1000; color: #e84a30; border: 2px solid #e84a30; }
.block--fleetwood-mac .block-label      { background: #f8f0e8; color: #0a0010; border: 2px solid #c084e0; }
.block--david-bowie .block-label        { background: #f8f8f8; color: #0a0010; border-top: 3px solid #e84040; border-bottom: 3px solid #4060e8; }
.block--black-sabbath .block-label      { background: #1a0808; color: #bf2020; border: 2px solid #bf2020; }
.block--velvet-underground .block-label { background: #f8f000; color: #0a0a0a; border: 2px solid #e8e880; }
.block--joni-mitchell .block-label      { background: #6ab8d4; color: #000a10; border: 2px solid #4898b4; }
.block--neil-young .block-label         { background: #2e2008; color: #c8a84a; border: 2px solid #c8a84a; }
.block--pearl-jam .block-label          { background: #e870c0; color: #0a0808; border: 2px solid #e87030; }


/* ==========================================================================
   15. ARTIST NAME + HOOK LINE
   ========================================================================== */

.block-artist {
  font-family: var(--font-heading);
  font-size: clamp(1.6rem, 3.2vw, 3.2rem);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: rgba(240,235,225,0.95);
  line-height: 1.1;
  margin-bottom: 0.3rem;
}

.block--large .block-artist {
  font-size: clamp(2.2rem, 4.2vw, 4.2rem);
}

.block-hook {
  font-family: var(--font-mono);
  font-size: clamp(0.6rem, 0.85vw, 0.78rem);
  letter-spacing: 0.08em;
  color: rgba(var(--block-accent-rgb), 0.72);
  margin-bottom: clamp(0.8rem, 1.5vw, 1.25rem);
  display: block;
}


/* ==========================================================================
   16. TRACK BUTTONS
   ========================================================================== */

.block-tracks {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.track-btn {
  display: flex;
  align-items: center;
  gap: 0.6em;
  padding: 0.38em 0.7em;
  font-family: var(--font-mono);
  font-size: clamp(0.58rem, 0.75vw, 0.68rem);
  letter-spacing: 0.06em;
  color: rgba(var(--block-accent-rgb), 0.85);
  border: 1px solid rgba(var(--block-accent-rgb), 0.22);
  background: rgba(var(--block-accent-rgb), 0.05);
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
  text-decoration: none;
  width: 100%;
}

.track-btn:hover {
  background: rgba(var(--block-accent-rgb), 0.14);
  border-color: rgba(var(--block-accent-rgb), 0.55);
  color: rgba(var(--block-accent-rgb), 1);
}

.track-name {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.track-src {
  font-size: 0.55rem;
  letter-spacing: 0.12em;
  opacity: 0.5;
  flex-shrink: 0;
}


/* ==========================================================================
   17. VAULT BUTTONS (Grateful Dead archive.org)
   ========================================================================== */

.track-btn--vault {
  border-style: dashed;
  border-color: rgba(var(--block-accent-rgb), 0.35);
}

.track-btn--vault .track-src {
  background: rgba(var(--block-accent-rgb), 0.9);
  color: var(--block-bg);
  padding: 0.1em 0.4em;
  opacity: 1;
  font-weight: 700;
  letter-spacing: 0.08em;
}


/* ==========================================================================
   18. OFFICIAL SITE LINK
   ========================================================================== */

.block-official {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
  margin-top: 0.5rem;
  font-family: var(--font-mono);
  font-size: 0.6rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(240,235,225,0.3);
  transition: color 0.2s ease;
}

.block-official:hover {
  color: rgba(240,235,225,0.7);
}


/* ==========================================================================
   19. KEYFRAME ANIMATIONS
   ========================================================================== */

@keyframes block-appear {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes slow-spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

@keyframes flicker {
  0%   { transform: translateX(-50%) rotate(-1deg) scaleY(0.95); opacity: 0.9; }
  100% { transform: translateX(-50%) rotate(1.5deg) scaleY(1.05); opacity: 1; }
}

@keyframes flicker-glow {
  0%   { opacity: 0.6; transform: translateX(-50%) scale(0.9); }
  100% { opacity: 1;   transform: translateX(-50%) scale(1.1); }
}


/* ==========================================================================
   20. MYSTICAL SECTION
   ========================================================================== */

.mystical {
  position: relative;
  padding: clamp(5rem, 10vw, 9rem) clamp(2rem, 8vw, 8rem);
  background: #050505;
  overflow: hidden;
}

/* Higher-opacity grain for this section */
.mystical::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.09;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px 200px;
}

.mystical-inner {
  position: relative;
  z-index: 2;
  max-width: 860px;
}

.mystical-headline {
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 4vw, 3.5rem);
  font-weight: 400;
  letter-spacing: 0.15em;
  color: rgba(200,160,70,0.75);
  margin-bottom: 2.5rem;
}

.mystical-line {
  font-family: var(--font-heading);
  font-size: clamp(1rem, 2vw, 1.6rem);
  font-weight: 400;
  letter-spacing: 0.06em;
  color: rgba(240,230,210,0.72);
  margin-bottom: 0.5rem;
  display: block;
}

.mystical-annotation {
  font-family: var(--font-mono);
  font-size: clamp(0.58rem, 0.8vw, 0.7rem);
  letter-spacing: 0.18em;
  color: rgba(240,230,210,0.28);
  display: block;
  margin-bottom: 2rem;
}

.mystical-separator {
  width: 40px;
  height: 1px;
  background: rgba(200,160,70,0.3);
  margin: 2rem 0;
}

.twenty-seven {
  font-family: var(--font-heading);
  font-size: clamp(2rem, 5vw, 4rem);
  font-weight: 400;
  letter-spacing: 0.3em;
  color: rgba(200,160,70,0.35);
  display: block;
  margin: 2rem 0 1rem;
}

.club-names {
  font-family: var(--font-mono);
  font-size: clamp(0.62rem, 0.85vw, 0.75rem);
  letter-spacing: 0.14em;
  color: rgba(240,230,210,0.38);
  line-height: 2.2;
}

.mystical-impact {
  font-family: var(--font-heading);
  font-size: clamp(1.4rem, 3.2vw, 2.8rem);
  font-weight: 700;
  letter-spacing: 0.08em;
  color: rgba(240,230,210,0.85);
  margin: 3rem 0 0.5rem;
  display: block;
}


/* ==========================================================================
   21. MYSTICAL SECTION — CSS CANDLE
   ========================================================================== */

.candle-wrap {
  position: absolute;
  right: clamp(3rem, 8vw, 10rem);
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  opacity: 0.4;
}

.candle-body {
  width: 18px;
  height: 70px;
  background: linear-gradient(180deg, #f0e8c8 0%, #d8c898 100%);
  border-radius: 2px;
  margin: 0 auto;
  position: relative;
}

.candle-wick {
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  height: 8px;
  background: #3a2808;
  border-radius: 1px;
}

.candle-flame {
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  width: 12px;
  height: 22px;
  background: radial-gradient(ellipse at 50% 80%, #fff8e0 0%, #ffd040 35%, #ff8000 65%, transparent 100%);
  border-radius: 50% 50% 20% 20%;
  animation: flicker 1.8s ease-in-out infinite alternate;
  filter: blur(0.5px);
}

.candle-glow {
  position: absolute;
  bottom: 85%;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,180,40,0.18) 0%, transparent 70%);
  animation: flicker-glow 1.8s ease-in-out infinite alternate;
}


/* ==========================================================================
   22. FOOTER
   ========================================================================== */

.site-footer {
  padding: clamp(3rem, 6vw, 5rem) clamp(2rem, 6vw, 5rem);
  background: #040404;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0.5rem;
}

.footer-line {
  font-family: var(--font-heading);
  font-size: clamp(1.2rem, 2.5vw, 2rem);
  font-weight: 400;
  letter-spacing: 0.08em;
  color: rgba(240,230,210,0.35);
}

.footer-domain {
  font-family: var(--font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(240,230,210,0.15);
}


/* ==========================================================================
   23. RESPONSIVE
   ========================================================================== */

@media (max-width: 1100px) {
  .artist-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 800px) {
  .artist-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: clamp(200px, 40vw, 320px);
  }

  .block--large  { grid-column: span 2; grid-row: span 1; }
  .block--medium { grid-column: span 1; grid-row: span 1; }

  .amp,
  .ashtray-group,
  .strat-wrap {
    display: none;
  }

  .hero {
    min-height: 70vh;
  }

  .hero-text {
    max-width: 100%;
    margin-left: 0;
  }

  .mystical-inner {
    max-width: 100%;
  }

  .candle-wrap {
    display: none;
  }
}

@media (max-width: 540px) {
  .artist-grid {
    grid-template-columns: 1fr;
    grid-auto-rows: clamp(220px, 70vw, 340px);
  }

  .block--large,
  .block--medium {
    grid-column: span 1;
    grid-row: span 1;
  }

  .mystical {
    padding: 3rem 1.5rem;
  }
}


/* ==========================================================================
   24. REDUCED MOTION
   ========================================================================== */

@media (prefers-reduced-motion: reduce) {
  .block {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }

  .block:hover {
    transform: none;
  }

  .candle-flame,
  .candle-glow {
    animation: none;
  }

  .block-label {
    animation: none !important;
  }
}
