/* ═══════════════════════════════════════════════════════════════
   DJ E-FEKT · Hip-Hop / Black Music / DJ Culture
   Red Stage Lights · Pure Black · High Contrast · Bold
   ═══════════════════════════════════════════════════════════════ */

/* ─── SELF-HOSTED FONTS (DSGVO-konform, kein Google) ────────── */
@font-face {
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 200 900;
  font-display: swap;
  src: url('fonts/outfit-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Outfit';
  font-style: normal;
  font-weight: 200 900;
  font-display: swap;
  src: url('fonts/outfit-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root {
  --bg:          #080808;
  --bg-card:     #111111;
  --bg-elevated: #161616;
  --bg-border:   #222222;
  --bg-hover:    #1a1a1a;

  /* ─ One accent: Stage Red ─ */
  --red:         #E82C3F;
  --red-light:   #FF4757;
  --red-dim:     #A11D2D;
  --red-faint:   rgba(232,44,63,.08);
  --red-glow:    rgba(232,44,63,.25);

  /* ─ Text: high contrast ─ */
  --text:        #F2F0F0;
  --text-sub:    #888888;
  --text-muted:  #444444;

  --font:        'Outfit', system-ui, sans-serif;
  --ease:        cubic-bezier(.22,.61,.36,1);
  /* Cut-corner clip-paths */
  --cut-sm:  polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
  --cut-md:  polygon(0 0, calc(100% - 16px) 0, 100% 16px, 100% 100%, 16px 100%, 0 calc(100% - 16px));
  --cut-lg:  polygon(0 0, calc(100% - 22px) 0, 100% 22px, 100% 100%, 22px 100%, 0 calc(100% - 22px));
  --max-w:       1220px;
  --gap:         clamp(24px,5vw,64px);
}

/* ─── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  background:var(--bg);color:var(--text);
  font-family:var(--font);font-weight:300;
  line-height:1.65;overflow-x:hidden;
}

/* Skip link for keyboard/screen reader users (A11y + SEO) */
.skip-link{
  position:absolute;left:-9999px;top:0;
  background:var(--red);color:#fff;
  padding:12px 20px;
  font-size:12px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  z-index:999;
  clip-path:var(--cut-sm);
}
.skip-link:focus{
  left:20px;top:20px;
  outline:2px solid var(--red);
  outline-offset:2px;
}

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

img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none}
ul{list-style:none}
textarea,input,select{font-family:var(--font);font-size:inherit}

/* ─── UTILITY ────────────────────────────────────────────────── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 clamp(20px,5vw,60px)}
.section{padding:clamp(80px,10vw,140px) 0;position:relative}

/* ─── TYPOGRAPHY ─────────────────────────────────────────────── */
.section-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-size:10px;font-weight:700;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--red);margin-bottom:20px;
}
.section-eyebrow::before{
  content:'';width:28px;height:2px;
  background:var(--red);border-radius:1px;
}
.section-title{
  font-family:var(--font);
  font-size:clamp(34px,5vw,64px);
  font-weight:800;line-height:1.05;
  letter-spacing:-.02em;
  color:var(--text);
  margin-bottom:clamp(28px,5vw,52px);
}
.section-title em{
  font-style:italic;
  font-weight:300;
  color:var(--red);
}

/* ─── BUTTONS — Cut-Corner / Slash Style ─────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:15px 36px;
  font-size:12px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  transition:all .3s var(--ease);white-space:nowrap;
  position:relative;overflow:hidden;
  border:none;border-radius:0;
  /* Cut corner: top-right + bottom-left */
  clip-path:polygon(0 0, calc(100% - 16px) 0, 100% 16px, 100% 100%, 16px 100%, 0 calc(100% - 16px));
}
/* Slide-fill from left on hover */
.btn{isolation:isolate}
.btn::before{
  content:'';position:absolute;
  top:0;left:0;width:0;height:100%;
  transition:width .35s var(--ease);
  z-index:-1;
}
.btn:hover::before{width:100%}

.btn-wine{
  background:var(--red);color:#fff;
  box-shadow:0 4px 20px var(--red-glow);
}
.btn-wine::before{background:var(--red-light)}
.btn-wine:hover{
  box-shadow:0 8px 32px var(--red-glow);
  transform:translateY(-2px);
}

.btn-ghost{
  background:transparent;
  color:var(--text-sub);
  box-shadow:inset 0 0 0 1px var(--bg-border);
}
.btn-ghost::before{background:var(--red-faint)}
.btn-ghost:hover{
  color:var(--text);
  box-shadow:inset 0 0 0 1px var(--red-dim);
  transform:translateY(-2px);
}

.btn-sm{padding:11px 24px;font-size:11px;
  clip-path:polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 12px));
}
.btn-full{
  width:100%;justify-content:center;padding:17px;font-size:13px;
  clip-path:polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 18px 100%, 0 calc(100% - 18px));
}

/* Corner accent mark on primary button */
.btn-wine::after{
  content:'';position:absolute;
  top:0;right:0;
  width:16px;height:16px;
  background:linear-gradient(135deg, transparent 50%, rgba(255,255,255,.15) 50%);
  z-index:1;pointer-events:none;
  clip-path:polygon(100% 0, 0 0, 100% 100%);
}

/* ─── SCROLL REVEAL ──────────────────────────────────────────── */
.reveal,.reveal-left{
  opacity:0;transform:translateY(28px);
  transition:opacity .7s var(--ease),transform .7s var(--ease);
  transition-delay:var(--delay,0s);
}
.reveal-left{transform:translateX(-28px)}
.reveal.visible,.reveal-left.visible{opacity:1;transform:none}

/* ═══════════════════════════════════════════════════════════════
   NAVBAR
   ═══════════════════════════════════════════════════════════════ */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,5vw,60px);
  transition:background .4s,padding .4s,box-shadow .4s;
}
#navbar.scrolled{
  background:rgba(8,8,8,.95);
  backdrop-filter:blur(14px);
  padding-top:12px;padding-bottom:12px;
  box-shadow:0 1px 0 var(--bg-border);
}
.nav-logo{
  display:flex;align-items:center;
}
.nav-logo img{
  height:80px;
  width:80px;
  object-fit:contain;
  transition:height .3s var(--ease), width .3s var(--ease), filter .3s, transform .3s var(--ease);
}
.nav-logo img:hover{
  filter:drop-shadow(0 0 12px var(--red-glow));
  transform:rotate(8deg);
}
#navbar.scrolled .nav-logo img{
  height:60px;width:60px;
}
.nav-links{display:flex;align-items:center;gap:36px}
.nav-links a{
  font-size:11px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-sub);transition:color .25s;
  position:relative;
}
.nav-links a::after{
  content:'';position:absolute;
  bottom:-4px;left:0;width:0;height:2px;
  background:var(--red);
  transition:width .3s var(--ease);
}
.nav-links a:hover{color:var(--text)}
.nav-links a:hover::after{width:100%}
.nav-cta{
  background:var(--red)!important;color:#fff!important;
  padding:9px 24px;border-radius:0;
  font-size:11px!important;
  box-shadow:0 2px 12px var(--red-glow);
  clip-path:polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--red-light)!important;box-shadow:0 4px 20px var(--red-glow)!important}

.nav-burger{display:none;flex-direction:column;gap:5px;padding:4px}
.nav-burger span{
  display:block;width:22px;height:2px;
  background:var(--text);border-radius:2px;
  transition:all .3s var(--ease);
}

/* ═══════════════════════════════════════════════════════════════
   HERO — Concert Poster Style
   ═══════════════════════════════════════════════════════════════ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;flex-direction:column;
  justify-content:center;
  overflow:hidden;
  background:var(--bg);
  padding:100px 0 0;
}

/* Red spotlight bleed */
.hero-grain{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 70% 50%, rgba(232,44,63,.10) 0%, transparent 50%),
    radial-gradient(ellipse at 30% 70%, rgba(232,44,63,.05) 0%, transparent 45%);
  pointer-events:none;z-index:0;
}

/* Noise texture */
.hero-bg-lines{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  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)' opacity='0.03'/%3E%3C/svg%3E");
  background-size:200px;opacity:.5;
}

/* ─── Giant stacked title ─── */
.hero-title-block{
  position:relative;z-index:5;
  text-align:left;
  animation:fadeUp .9s var(--ease) both;
  pointer-events:none;
  display:flex;flex-direction:column;align-items:flex-start;
  padding-left:clamp(30px,6vw,80px);
  padding-right:clamp(30px,6vw,80px);
  max-width:760px;
}
.hero-title-block a,.hero-title-block button{pointer-events:auto}
.hero-label-top{
  display:inline-flex;align-items:center;gap:14px;
  font-size:11px;font-weight:700;
  letter-spacing:.35em;text-transform:uppercase;
  color:var(--red);margin-bottom:16px;
}
.hero-label-top::before{
  content:'';width:32px;height:2px;background:var(--red);
}
.hero-title{
  display:block;line-height:.82;
  margin:12px 0 16px;
}
.hero-line-dj{
  display:block;
  font-size:clamp(24px,4vw,52px);
  font-weight:300;font-style:italic;
  color:var(--text-sub);
  letter-spacing:.5em;
  margin-bottom:4px;
  /* Indent so DJ sits over the E of E-FEKT */
  padding-left:.08em;
}
.hero-line-name{
  display:block;
  font-size:clamp(70px,16vw,220px);
  font-weight:900;
  letter-spacing:.01em;
  color:var(--text);
  line-height:.82;
  position:relative;
  white-space:nowrap;
  font-feature-settings:"kern" 1;
  -webkit-text-stroke:1px rgba(255,255,255,.08);
  paint-order:stroke fill;
}
/* Subtle red shadow duplicate — hinted, not loud */
.hero-line-name::after{
  content:'E-FEKT';
  position:absolute;inset:0;
  color:transparent;
  text-shadow:
    0 0 100px rgba(232,44,63,.20),
    0 0 50px rgba(232,44,63,.10),
    4px 4px 0 rgba(232,44,63,.08);
  z-index:-1;
  pointer-events:none;
}
.hero-label-bottom{
  display:block;
  font-size:clamp(11px,1.4vw,14px);font-weight:400;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--text-muted);
  margin-top:8px;
}

.hero-title-block .hero-tagline{
  margin-top:clamp(28px,4vw,48px);
  font-size:clamp(16px,2vw,22px);
  color:var(--text-sub);
  letter-spacing:.06em;
}
.hero-title-block .hero-tagline em{
  font-style:italic;font-weight:700;
  color:var(--red);font-size:1.05em;
}

.hero-title-block .hero-actions{
  margin-top:20px;
  display:flex;gap:14px;flex-wrap:wrap;
  justify-content:center;
  pointer-events:auto;
}

/* ─── Full-bleed hero photo (artist showcase) ─── */
.hero-bg-photo{
  position:absolute;
  inset:0;
  z-index:1;
  overflow:hidden;
  pointer-events:none;
}
.hero-bg-photo img{
  position:absolute;
  top:0;right:0;
  width:70%;height:100%;
  object-fit:cover;
  object-position:50% 30%;
  filter:contrast(1.15) saturate(.9) brightness(.85);
  animation:slowZoom 20s ease-out infinite alternate;
}
@keyframes slowZoom{
  from{transform:scale(1)}
  to{transform:scale(1.08)}
}
/* Dramatic fade: dark on left, photo reveals on right */
.hero-bg-fade{
  position:absolute;inset:0;
  background:
    /* Left-to-right black to transparent fade (main) */
    linear-gradient(to right,
      var(--bg) 0%,
      var(--bg) 25%,
      rgba(8,8,8,.95) 38%,
      rgba(8,8,8,.6) 55%,
      rgba(8,8,8,.35) 75%,
      rgba(8,8,8,.5) 100%),
    /* Bottom fade into stats bar */
    linear-gradient(to top,
      var(--bg) 0%,
      rgba(8,8,8,.6) 15%,
      transparent 35%),
    /* Subtle red tint on photo side */
    linear-gradient(135deg,
      transparent 40%,
      rgba(232,44,63,.08) 100%);
}

@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

/* ─── Vinyl disc — overlapping the title ─── */
.hero-vinyl{
  position:absolute;
  z-index:3;
  right:clamp(30px,4vw,60px);
  bottom:140px;
  width:clamp(160px,14vw,220px);
  height:clamp(160px,14vw,220px);
  transition:transform .5s var(--ease), filter .5s;
  cursor:pointer;
}
.hero-vinyl:hover{
  transform:scale(1.08);
  filter:drop-shadow(0 0 40px rgba(232,44,63,.35));
}
.hero-disc{
  position:relative;width:100%;height:100%;border-radius:50%;
  background:
    radial-gradient(circle, var(--bg) 20%, transparent 21%),
    radial-gradient(circle, var(--bg-border) 21.5%, transparent 22.5%),
    repeating-radial-gradient(circle, transparent, transparent 4px, rgba(255,255,255,.02) 4.5px, transparent 5px),
    conic-gradient(from 0deg, #111, #1a1a1a, #111, #1a1a1a, #111);
  border:2px solid var(--bg-border);
  box-shadow:
    0 0 100px rgba(232,44,63,.12),
    0 0 200px rgba(232,44,63,.04),
    inset 0 0 50px rgba(0,0,0,.6);
  animation:spin 8s linear infinite;
}

/* Avatar photo as vinyl label */
.hero-disc-label{
  position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  width:38%;height:38%;
  border-radius:50%;
  overflow:hidden;
  border:3px solid var(--red);
  box-shadow:0 0 30px rgba(232,44,63,.35), inset 0 0 15px rgba(0,0,0,.4);
  /* Counter-rotate so photo stays upright while disc spins */
  animation:counterSpin 8s linear infinite;
}
.hero-disc-label img{
  width:100%;height:100%;object-fit:cover;
}
/* On hover: swap to forward-spin animation (disc is paused via JS) */
.hero-vinyl:hover .hero-disc-label{
  animation:labelSpin 10s linear infinite;
}
@keyframes spin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes counterSpin{from{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(-360deg)}}
@keyframes labelSpin{from{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(360deg)}}

.hero-disc-glow{
  position:absolute;border-radius:50%;
  border:1px solid rgba(232,44,63,.06);
  animation:pulse 4s ease-in-out infinite;
}
.hero-disc-glow:nth-child(1){inset:-30px}
.hero-disc-glow:nth-child(2){inset:-60px;border-color:rgba(232,44,63,.04);animation-delay:1.3s}
@keyframes pulse{
  0%,100%{opacity:.3;transform:scale(1)}
  50%{opacity:.7;transform:scale(1.02)}
}

/* ─── Bottom stats bar ─── */
.hero-bottom{
  position:absolute;
  bottom:0;left:0;right:0;
  z-index:4;
  display:flex;justify-content:center;
  padding:0 clamp(24px,5vw,60px) 32px;
  border-top:1px solid var(--bg-border);
  padding-top:20px;
}
.hero-bottom-left{
  display:flex;align-items:center;gap:12px;
}
.hero-stat-item{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  background:var(--bg-card);
  padding:10px 18px;
  clip-path:var(--cut-sm);
  white-space:nowrap;
}
.hero-stat-num{
  font-size:14px;font-weight:900;color:var(--red);
  letter-spacing:.02em;
}
.hero-stat-label{
  font-size:8px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-muted);
}
/* Live "available" stat with green pulse */
.hero-stat-live .hero-stat-num{
  color:#00C853;
  display:inline-flex;align-items:center;gap:6px;
}
.hero-stat-live .hero-stat-num::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:#00C853;
  box-shadow:0 0 8px #00C853;
  animation:blink 1.6s ease-in-out infinite;
}

/* Scroll hint */
.hero-scroll-hint{
  position:absolute;bottom:36px;left:50%;
  transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:8px;
  z-index:5;
  animation:fadeIn 1s var(--ease) 1.2s both;
  display:none; /* hidden — bottom bar takes its place */
}
.hero-scroll-hint span{font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--text-muted)}
.scroll-line{
  width:36px;height:2px;
  background:linear-gradient(90deg,var(--red-dim),transparent);
  animation:scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse{0%,100%{transform:scaleX(1);opacity:.5}50%{transform:scaleX(1.3);opacity:1}}

@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
@keyframes fadeRight{from{opacity:0;transform:translateX(-22px)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ═══════════════════════════════════════════════════════════════
   STATEMENT BAR
   ═══════════════════════════════════════════════════════════════ */
.statement-bar{
  overflow:hidden;
  border-top:1px solid var(--bg-border);
  border-bottom:1px solid var(--bg-border);
  background:var(--bg-card);padding:15px 0;
}
.statement-track{
  display:flex;gap:44px;white-space:nowrap;
  animation:ticker 30s linear infinite;width:max-content;
}
.statement-track span{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--text-sub);font-weight:500}
.statement-track .dot{color:var(--red);font-size:8px}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ═══════════════════════════════════════════════════════════════
   ABOUT
   ═══════════════════════════════════════════════════════════════ */
.about{background:var(--bg)}
.about-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:var(--gap);align-items:start}

.about-visual{position:sticky;top:120px}
.about-photo-frame{position:relative;padding-bottom:32px}
.about-photo-placeholder{
  aspect-ratio:3/4;background:var(--bg-card);
  clip-path:var(--cut-lg);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
/* Dark vignette over photo */
.about-photo-placeholder::before{
  content:'';position:absolute;inset:0;
  clip-path:var(--cut-lg);
  background:linear-gradient(180deg, transparent 40%, rgba(8,8,8,.6) 100%);
  z-index:1;pointer-events:none;
}
.about-photo-placeholder img{
  width:100%;height:100%;object-fit:cover;
  clip-path:var(--cut-lg);
}
.photo-initials{
  font-size:32px;font-weight:900;
  letter-spacing:.12em;color:var(--text-muted);
}

.about-stat{
  position:absolute;bottom:0;right:-16px;
  background:var(--red);color:#fff;
  padding:18px 22px;clip-path:var(--cut-sm);
  box-shadow:0 6px 24px var(--red-glow);
}
.stat-num{display:block;font-size:28px;font-weight:900;line-height:1}
.stat-label{display:block;font-size:9px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-top:4px;opacity:.8}

.about-badge{
  position:absolute;top:20px;right:-12px;
  background:var(--bg-elevated);
  padding:8px 16px;clip-path:var(--cut-sm);
  font-size:10px;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:var(--red);z-index:2;
}

.about-lead{font-size:clamp(17px,2.2vw,21px);font-weight:400;line-height:1.65;color:var(--text);margin-bottom:24px}
.about-body{font-size:15px;color:var(--text-sub);line-height:1.85;margin-bottom:20px}

.about-quote{
  border-left:3px solid var(--red);
  padding:20px 0 20px 24px;margin:32px 0;
  font-style:italic;font-size:clamp(15px,1.8vw,19px);
  color:var(--text-sub);line-height:1.7;
}

.about-stats-row{display:flex;gap:36px;padding-top:24px;border-top:1px solid var(--bg-border)}
.mini-stat span{display:block;font-size:22px;font-weight:900;color:var(--red)}
.mini-stat small{font-size:10px;letter-spacing:.12em;color:var(--text-muted);text-transform:uppercase;margin-top:3px;display:block}

/* ═══════════════════════════════════════════════════════════════
   GENRES
   ═══════════════════════════════════════════════════════════════ */
.genres{background:var(--bg-card);border-top:1px solid var(--bg-border)}
.genres-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.genre-card{
  background:var(--bg-elevated);
  padding:32px 24px;clip-path:var(--cut-lg);
  transition:all .35s var(--ease);
  display:flex;flex-direction:column;
}
.genre-card:hover{
  background:var(--bg-hover);
  transform:translateY(-3px);
  filter:brightness(1.15);
}

.genre-icon{
  font-size:22px;margin-bottom:16px;
  display:flex;width:44px;height:44px;
  align-items:center;justify-content:center;
  clip-path:var(--cut-sm);
  background:var(--red-faint);color:var(--red);
  flex-shrink:0;
}
.genre-card h3{font-size:19px;font-weight:800;color:var(--text);margin-bottom:10px}
.genre-card p{font-size:13px;color:var(--text-sub);line-height:1.7;margin-bottom:22px;flex:1}
.genre-bar{height:2px;background:var(--bg-border);border-radius:4px;position:relative;overflow:hidden;margin-top:auto}
.genre-fill{
  position:absolute;top:0;left:0;height:100%;width:0;
  background:var(--red);border-radius:4px;
  transition:width 1.2s var(--ease);
}
.genre-card.visible .genre-fill{width:var(--pct)}

/* ═══════════════════════════════════════════════════════════════
   MUSIC
   ═══════════════════════════════════════════════════════════════ */
.music{background:var(--bg)}
.music-bg-accent{
  position:absolute;top:0;right:0;width:45%;height:100%;
  background:radial-gradient(ellipse at 75% 50%, rgba(232,44,63,.05) 0%, transparent 55%);
  pointer-events:none;z-index:0;
}
.music .container{position:relative;z-index:1}
.section-header{margin-bottom:clamp(36px,6vw,68px)}

/* Music Tabs */
.music-tabs{
  display:flex;gap:10px;
  margin-bottom:28px;
  flex-wrap:nowrap;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}
.music-tabs::-webkit-scrollbar{display:none}
.music-tab{
  font-size:10px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-sub);
  padding:12px 22px;
  background:var(--bg-card);
  clip-path:var(--cut-sm);
  transition:all .25s var(--ease);
  white-space:nowrap;
  flex-shrink:0;
}
.music-tab:hover{background:var(--bg-hover);color:var(--text)}
.music-tab.active{background:var(--red);color:#fff}

@media(max-width:540px){
  .music-tabs{gap:6px}
  .music-tab{font-size:9px;padding:10px 14px;letter-spacing:.18em;flex:1;text-align:center}
}

/* Panel visibility */
.music-panel{display:none}
.music-panel.active{display:grid}

.music-grid{grid-template-columns:1.2fr 1fr 1fr;gap:16px;margin-bottom:44px}
.panel-2col{grid-template-columns:1fr 1fr}
.panel-1col{grid-template-columns:minmax(0,820px);justify-content:center}

/* Video cover variant — 16:9 aspect */
.mixtape-cover-video{
  aspect-ratio:16/9!important;
  background:var(--bg-elevated);
  position:relative;
}
.mixtape-cover-video iframe{
  position:absolute;inset:0;
  width:100%;height:100%;border:0;
  display:block;
}
.mixtape-cover-video .mixtape-cover-art{
  width:100%;height:100%;
}

/* YouTube thumbnail fallback (when embedding is disabled) */
.mixtape-cover-thumb{
  display:block;
  cursor:pointer;
  text-decoration:none;
  overflow:hidden;
}
.mixtape-cover-thumb img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .5s var(--ease), filter .4s var(--ease);
  filter:brightness(.85);
}
.mixtape-cover-thumb::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(8,8,8,.2) 0%, rgba(8,8,8,.5) 100%);
  z-index:1;pointer-events:none;
  transition:opacity .3s;
}
.mixtape-cover-thumb:hover img{
  transform:scale(1.06);
  filter:brightness(1);
}
.mixtape-cover-thumb:hover::before{opacity:.3}

.thumb-play{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  z-index:2;
  width:64px;height:64px;
  background:var(--red);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;
  box-shadow:0 8px 32px rgba(232,44,63,.4), 0 0 0 8px rgba(232,44,63,.15);
  transition:transform .3s var(--ease), box-shadow .3s;
}
.mixtape-cover-thumb:hover .thumb-play{
  transform:translate(-50%,-50%) scale(1.1);
  box-shadow:0 12px 40px rgba(232,44,63,.5), 0 0 0 12px rgba(232,44,63,.2);
}
.thumb-play svg{margin-left:3px}
.mixtape-card{
  background:var(--bg-card);
  clip-path:var(--cut-lg);
  display:flex;flex-direction:column;
  transition:all .35s var(--ease);overflow:hidden;
}
.mixtape-card:hover{
  transform:translateY(-3px);
  filter:brightness(1.15);
}

.mixtape-cover{position:relative;aspect-ratio:1;overflow:hidden}
.mixtape-cover-art{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg, var(--bg-elevated), rgba(232,44,63,.06));
  overflow:hidden;
}
.mixtape-cover-art img{
  width:100%;height:100%;object-fit:cover;
}
.mixtape-cover-art span{
  font-size:clamp(14px,2.5vw,22px);font-weight:900;
  letter-spacing:.04em;color:var(--text);
  text-align:center;line-height:1.3;padding:20px;
}
.coming-soon .mixtape-cover-art{background:linear-gradient(145deg, #0d0d0d, var(--bg))}
.coming-soon .mixtape-cover-art span{color:var(--text-muted)}

.play-btn{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:rgba(8,8,8,.55);backdrop-filter:blur(3px);
  opacity:0;transition:opacity .3s;
}
.play-btn svg{width:52px;height:52px;color:var(--red);filter:drop-shadow(0 0 12px var(--red-glow))}
.mixtape-cover:hover .play-btn{opacity:1}
.play-btn.playing{opacity:1;background:rgba(8,8,8,.8)}
.play-btn.playing svg polygon{display:none}
.play-btn.playing::after{
  content:'';display:block;
  width:6px;height:32px;background:var(--red);
  box-shadow:14px 0 0 var(--red);
  animation:audioPulse 1s ease-in-out infinite;
}
@keyframes audioPulse{
  0%,100%{transform:scaleY(1)}
  50%{transform:scaleY(.5)}
}

.mixtape-info{padding:22px;flex:1;display:flex;flex-direction:column;gap:8px}
.mixtape-tag{font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--red);font-weight:700}
.mixtape-info h3{font-size:17px;font-weight:800;color:var(--text);line-height:1.25}
.mixtape-info p{font-size:12px;color:var(--text-sub);line-height:1.65;flex:1}
.mixtape-meta{font-size:10px;color:var(--text-muted);letter-spacing:.1em}
.mixtape-actions{display:flex;gap:8px;margin-top:4px}

.streaming-note{
  text-align:center;padding:28px;
  clip-path:var(--cut-lg);
  background:var(--bg-card);
}

/* Production on demand callout */
.production-callout{
  margin-top:20px;
  background:linear-gradient(135deg, var(--bg-card) 0%, rgba(232,44,63,.08) 100%);
  clip-path:var(--cut-lg);
  padding:clamp(24px,3vw,36px);
  position:relative;
  overflow:hidden;
}
.production-callout::before{
  content:'';
  position:absolute;
  top:0;left:0;
  width:4px;height:100%;
  background:var(--red);
}
.production-callout-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:clamp(20px,4vw,40px);
  flex-wrap:wrap;
}
.production-text{flex:1;min-width:260px}
.production-eyebrow{
  font-size:10px;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--red);
  margin-bottom:8px;
}
.production-title{
  font-size:clamp(20px,2.2vw,26px);
  font-weight:800;
  color:var(--text);
  line-height:1.2;
  margin-bottom:8px;
  letter-spacing:-.01em;
}
.production-desc{
  font-size:13px;
  color:var(--text-sub);
  line-height:1.65;
}
.streaming-note p{font-size:13px;color:var(--text-sub);margin-bottom:16px}
.streaming-note strong{color:var(--text)}
.platform-links{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.platform-link{
  font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-sub);padding:10px 20px;
  border:1px solid var(--bg-border);border-radius:0;
  transition:all .25s;
  clip-path:polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));
}
.platform-link:hover{border-color:var(--red-dim);color:var(--red);background:var(--red-faint)}

/* ═══════════════════════════════════════════════════════════════
   SERVICES
   ═══════════════════════════════════════════════════════════════ */
.services{background:var(--bg-card);border-top:1px solid var(--bg-border)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:48px}
.service-card{
  background:var(--bg-elevated);
  clip-path:var(--cut-lg);padding:32px 24px;
  transition:all .35s var(--ease);
  position:relative;
}
.service-card:hover{
  transform:translateY(-3px);
  filter:brightness(1.15);
}
/* Featured service with red gradient accent */
.service-featured{
  background:linear-gradient(135deg, var(--bg-elevated) 0%, rgba(232,44,63,.08) 100%);
}
.service-featured::before{
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:3px;
  background:var(--red);
  z-index:1;
}
.service-featured .service-icon{
  background:var(--red)!important;
  color:#fff!important;
}
.service-badge{
  position:absolute;
  top:16px;right:16px;
  font-size:9px;font-weight:800;
  letter-spacing:.22em;text-transform:uppercase;
  color:#fff;
  background:var(--red);
  padding:5px 10px;
  clip-path:polygon(4px 0, 100% 0, 100% 100%, 0 100%, 0 4px);
  display:inline-flex;align-items:center;gap:6px;
}
.service-badge::before{
  content:'';
  width:5px;height:5px;border-radius:50%;
  background:#fff;
  animation:blink 1.6s ease-in-out infinite;
}

.service-icon{
  margin-bottom:18px;
  display:flex;width:56px;height:56px;
  align-items:center;justify-content:center;
  clip-path:var(--cut-sm);background:var(--red-faint);
  color:var(--red);
  transition:all .3s var(--ease);
}
.service-icon svg{
  width:28px;height:28px;
  stroke:currentColor;
  transition:transform .35s var(--ease);
}
.service-card:hover .service-icon{
  background:var(--red);color:#fff;
}
.service-card:hover .service-icon svg{
  transform:scale(1.08) rotate(-3deg);
}
.service-card h3{font-size:18px;font-weight:800;color:var(--text);margin-bottom:10px;line-height:1.25}
.service-card p{font-size:13px;color:var(--text-sub);line-height:1.7}

.services-cta{text-align:center;display:flex;flex-direction:column;align-items:center;gap:18px}
.services-cta p{font-size:15px;color:var(--text-sub)}
.services-cta strong{color:var(--text)}

/* ═══════════════════════════════════════════════════════════════
   TESTIMONIALS — Carousel
   ═══════════════════════════════════════════════════════════════ */
.testimonials{background:var(--bg)}
.carousel{
  position:relative;
  max-width:720px;
  margin:0 auto;
}
.carousel-track{
  position:relative;
  overflow:hidden;
  background:var(--bg-card);
  clip-path:var(--cut-lg);
  min-height:240px;
}
.carousel-slide{
  position:absolute;inset:0;
  padding:clamp(28px,4vw,48px) clamp(28px,4vw,56px);
  display:flex;flex-direction:column;
  justify-content:center;
  opacity:0;
  transform:translateX(40px);
  transition:opacity .5s var(--ease), transform .5s var(--ease);
  pointer-events:none;
}
.carousel-slide.active{
  opacity:1;
  transform:none;
  pointer-events:auto;
  position:relative;
}
.carousel-quote-mark{
  position:absolute;
  top:-20px;left:20px;
  font-size:clamp(90px,10vw,130px);
  line-height:1;
  font-family:Georgia, serif;
  font-weight:900;
  color:var(--red);
  opacity:.18;
  pointer-events:none;
  user-select:none;
  z-index:0;
}
.carousel-text{
  font-size:clamp(15px,1.7vw,20px);
  line-height:1.6;
  color:var(--text);
  font-weight:400;
  font-style:italic;
  margin-bottom:clamp(18px,2.4vw,28px);
  position:relative;
  z-index:1;
  max-width:600px;
}
.carousel-author{
  display:flex;flex-direction:column;gap:4px;
  padding-top:20px;
  border-top:1px solid var(--bg-border);
  position:relative;z-index:1;
}
.carousel-name{
  font-size:14px;font-weight:800;
  color:var(--text);
  letter-spacing:.02em;
}
.carousel-role{
  font-size:10px;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--red);
}

/* Controls */
.carousel-controls{
  display:flex;align-items:center;justify-content:center;
  gap:18px;
  margin-top:28px;
}
.carousel-arrow{
  width:44px;height:44px;
  background:var(--bg-elevated);
  color:var(--text-sub);
  display:flex;align-items:center;justify-content:center;
  clip-path:var(--cut-sm);
  transition:all .25s var(--ease);
}
.carousel-arrow:hover{
  background:var(--red);
  color:#fff;
  transform:scale(1.06);
}
.carousel-dots{
  display:flex;gap:10px;align-items:center;
}
.carousel-dot{
  width:8px;height:8px;
  background:var(--bg-border);
  border:none;padding:0;cursor:pointer;
  transition:all .3s var(--ease);
}
.carousel-dot.active{
  background:var(--red);
  width:24px;
  box-shadow:0 0 12px rgba(232,44,63,.4);
}

/* ═══════════════════════════════════════════════════════════════
   UPCOMING GIGS — Coming Soon Teaser
   ═══════════════════════════════════════════════════════════════ */
.gigs{
  background:var(--bg-card);
  border-top:1px solid var(--bg-border);
  position:relative;
  overflow:hidden;
}
.gigs-bg{
  position:absolute;inset:0;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(232,44,63,.10) 0%, transparent 55%),
    radial-gradient(ellipse at 70% 80%, rgba(232,44,63,.06) 0%, transparent 55%);
  pointer-events:none;
}
.gigs .container{position:relative;z-index:1}
.gigs-teaser{
  text-align:center;
  max-width:720px;
  margin:0 auto;
  padding:clamp(20px,4vw,48px) 0;
}
.gigs-teaser .section-eyebrow{margin-bottom:24px}
.gigs-title{
  font-size:clamp(44px,7vw,96px)!important;
  margin-bottom:28px!important;
  text-align:center;
}
.gigs-subtitle{
  font-size:clamp(14px,1.4vw,16px);
  color:var(--text-sub);
  line-height:1.8;
  margin-bottom:32px;
}

/* Pulse indicator */
.gigs-pulse{
  display:inline-flex;align-items:center;gap:12px;
  background:var(--bg-elevated);
  padding:12px 22px;
  clip-path:var(--cut-sm);
  margin-bottom:36px;
}
.pulse-dot{
  width:10px;height:10px;border-radius:50%;
  background:var(--red);
  position:relative;
  flex-shrink:0;
}
.pulse-dot::before,.pulse-dot::after{
  content:'';position:absolute;inset:0;border-radius:50%;
  background:var(--red);
  animation:pulseRing 2s ease-out infinite;
}
.pulse-dot::after{animation-delay:1s}
@keyframes pulseRing{
  0%{transform:scale(1);opacity:.7}
  100%{transform:scale(3);opacity:0}
}
.pulse-label{
  font-size:11px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--text);
}

.gigs-actions{
  display:flex;gap:14px;flex-wrap:wrap;
  justify-content:center;
}

/* ═══════════════════════════════════════════════════════════════
   CONTACT
   ═══════════════════════════════════════════════════════════════ */
.contact{background:var(--bg);border-top:1px solid var(--bg-border)}
.contact-bg-accent{
  position:absolute;top:0;left:0;width:35%;height:100%;
  background:radial-gradient(ellipse at 20% 50%, rgba(232,44,63,.04) 0%, transparent 55%);
  pointer-events:none;
}
.contact .container{position:relative;z-index:1}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:var(--gap);align-items:start}
.contact-left{position:sticky;top:120px}
.contact-intro{font-size:15px;color:var(--text-sub);line-height:1.85;margin-bottom:40px}
.contact-details{display:flex;flex-direction:column;gap:20px;margin-bottom:40px}
.contact-detail{display:flex;flex-direction:column;gap:4px;padding-bottom:20px;border-bottom:1px solid var(--bg-border)}
.cd-label{font-size:9px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--text-muted)}
.contact-detail span,.contact-detail a{font-size:14px;color:var(--text)}
.contact-detail a:hover{color:var(--red)}

/* Honeypot anti-spam field */
.honeypot{
  position:absolute!important;
  left:-9999px!important;top:-9999px!important;
  width:1px!important;height:1px!important;
  overflow:hidden!important;opacity:0!important;
  pointer-events:none!important;
}

/* Mail link that reveals on hover/click (anti-spam) */
.mail-link{cursor:pointer}
.mail-link::before{content:'→ '}
.mail-link.mail-revealed::before{content:''}

.social-links{display:flex;gap:8px;flex-wrap:wrap}
.social-link{
  width:40px;height:40px;
  clip-path:var(--cut-sm);
  background:var(--bg-elevated);
  display:flex;align-items:center;justify-content:center;
  color:var(--text-sub);
  transition:all .25s var(--ease);
}
.social-link svg{
  width:18px;height:18px;
  transition:transform .25s var(--ease);
}
.social-link:hover{
  color:#fff;
  background:var(--red);
  transform:translateY(-2px);
}
.social-link:hover svg{transform:scale(1.08)}

/* ─── Form ─── */
.booking-form{
  display:flex;flex-direction:column;gap:18px;
  background:var(--bg-card);
  clip-path:var(--cut-lg);padding:36px;
}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:7px}
.form-group label{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--text-sub)}
.form-group input,.form-group select,.form-group textarea{
  background:var(--bg-elevated);border:1px solid var(--bg-border);
  color:var(--text);padding:13px 16px;border-radius:0;
  font-size:14px;font-weight:300;outline:none;
  transition:border-color .25s;
  -webkit-appearance:none;appearance:none;
}
.form-group select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23444' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--red);
}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted);font-size:13px}
.form-group textarea{resize:vertical;min-height:110px}
.form-group input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(.4)}

.form-check{flex-direction:row!important;align-items:center;gap:12px}
.form-check input[type="checkbox"]{
  width:18px;height:18px;flex-shrink:0;
  accent-color:var(--red);
  border:none;padding:0;
  background:transparent;
  -webkit-appearance:checkbox!important;
  appearance:checkbox!important;
  cursor:pointer;
  margin:0;
}
.form-check label{cursor:pointer}
.form-check label{font-size:12px!important;text-transform:none!important;letter-spacing:0!important;line-height:1.5;color:var(--text-muted)!important}
.form-check a{color:var(--red);border-bottom:1px solid transparent}
.form-check a:hover{border-color:var(--red)}

.form-note{font-size:11px;color:var(--text-muted);text-align:center;letter-spacing:.05em}
.booking-form.success{pointer-events:none;opacity:.6}

/* ═══════════════════════════════════════════════════════════════
   LEGAL PAGES (Impressum, Datenschutz)
   ═══════════════════════════════════════════════════════════════ */
.legal{
  background:var(--bg);
  padding:calc(80px + 100px) 0 100px;
  position:relative;
}
.legal-header{
  margin-bottom:clamp(40px,6vw,64px);
  padding-bottom:32px;
  border-bottom:1px solid var(--bg-border);
}
.legal-header .section-eyebrow{margin-bottom:12px}
.legal-header h1{
  font-size:clamp(40px,6vw,72px);
  font-weight:900;line-height:1.05;
  letter-spacing:-.02em;
  color:var(--text);
}
.legal-content{
  max-width:820px;
  font-size:15px;
  line-height:1.75;
  color:var(--text-sub);
}
.legal-content h2{
  font-size:clamp(20px,2.4vw,26px);
  font-weight:800;
  color:var(--text);
  margin:48px 0 16px;
  letter-spacing:-.01em;
}
.legal-content h2:first-child{margin-top:0}
.legal-content h3{
  font-size:16px;font-weight:700;
  color:var(--text);
  margin:28px 0 10px;
}
.legal-content p{margin-bottom:14px}
.legal-content ul,.legal-content ol{
  margin:0 0 16px 20px;
}
.legal-content li{margin-bottom:6px}
.legal-content a{
  color:var(--red);
  border-bottom:1px solid transparent;
  transition:border-color .25s;
  word-break:break-word;
}
.legal-content a:hover{border-bottom-color:var(--red)}
.legal-content strong{color:var(--text);font-weight:700}
.legal-content .placeholder{
  display:inline-block;
  padding:2px 8px;
  background:var(--red-faint);
  color:var(--red);
  font-weight:700;
  font-size:.9em;
  letter-spacing:.02em;
}
.legal-content .legal-block{
  padding:20px 24px;
  background:var(--bg-card);
  clip-path:var(--cut-sm);
  margin:20px 0;
}
.legal-content .legal-block p:last-child{margin-bottom:0}
.legal-back{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--text-sub);
  margin-top:48px;padding-top:32px;
  border-top:1px solid var(--bg-border);
  transition:color .25s;
}
.legal-back:hover{color:var(--red)}

/* ═══════════════════════════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════════════════════════ */
.footer{background:var(--bg-card);border-top:1px solid var(--bg-border);padding:56px 0 28px}
.footer-top{
  display:grid;
  grid-template-columns:1.8fr 1fr 1fr 1fr;
  gap:clamp(32px,5vw,64px);
  margin-bottom:44px;
  align-items:center;
}
.footer-brand{display:flex;flex-direction:column;gap:16px;max-width:340px}
.footer-logo{display:flex;align-items:center;margin-bottom:4px;margin-left:12px}
.footer-logo img{height:160px;width:160px;object-fit:contain;transition:transform .3s var(--ease)}
.footer-logo img:hover{transform:rotate(8deg) scale(1.05);filter:drop-shadow(0 0 12px var(--red-glow))}
.footer-tagline{
  font-size:13px;color:var(--text-sub);
  line-height:1.7;font-weight:400;
}
.footer-quick-contact{margin-top:4px}
.footer-quick-contact .mail-link{
  font-size:11px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--red);
  cursor:pointer;
  transition:color .25s;
}
.footer-quick-contact .mail-link:hover{color:var(--red-light)}
.footer-quick-contact .mail-link::before{content:'→ '}
.footer-quick-contact .mail-link.mail-revealed::before{content:''}

.footer-col{display:flex;flex-direction:column;gap:10px}
.footer-col-title{
  font-size:10px;font-weight:800;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--red);
  margin-bottom:6px;
  padding-bottom:10px;
  border-bottom:1px solid var(--bg-border);
}
.footer-col a{
  font-size:12px;font-weight:500;
  letter-spacing:.08em;
  color:var(--text-sub);
  transition:color .25s, transform .25s;
}
.footer-col a:hover{color:var(--red);transform:translateX(3px)}
.footer-nav-shop{
  color:var(--red)!important;
  font-weight:800!important;
  letter-spacing:.14em!important;
  text-transform:uppercase;
  transition:letter-spacing .25s var(--ease), color .25s!important;
}
.footer-nav-shop:hover{
  color:var(--red-light)!important;
  letter-spacing:.18em!important;
}

.footer-divider{height:1px;background:var(--bg-border);margin-bottom:22px}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:12px;
}
.footer-bottom p{font-size:11px;color:var(--text-muted);letter-spacing:.04em}
.footer-bottom a{color:var(--text-muted);transition:color .25s}
.footer-bottom a:hover{color:var(--red)}
.footer-loc{
  display:flex;align-items:center;gap:8px;
  font-size:11px;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;
}
.footer-loc-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--red);
  box-shadow:0 0 8px var(--red);
  animation:blink 2s ease-in-out infinite;
}

/* Cookie settings button styled as link */
.footer-cookie-btn{
  background:none;border:none;padding:0;
  font:inherit;color:inherit;cursor:pointer;
  font-size:12px;font-weight:500;
  letter-spacing:.08em;
  color:var(--text-sub);
  transition:color .25s, transform .25s;
  text-align:left;
}
.footer-cookie-btn:hover{color:var(--red);transform:translateX(3px)}
/* In footer-bottom row, style inline */
.footer-bottom .footer-cookie-btn{
  font-size:11px;letter-spacing:.04em;
  color:var(--text-muted);
  transform:none;
  display:inline;
}
.footer-bottom .footer-cookie-btn:hover{color:var(--red);transform:none}

/* ═══════════════════════════════════════════════════════════════
   COOKIE BANNER
   ═══════════════════════════════════════════════════════════════ */
.cookie-banner{
  position:fixed;
  bottom:20px;left:20px;right:20px;
  max-width:640px;
  margin:0 auto;
  z-index:998;
  background:var(--bg-card);
  clip-path:var(--cut-md);
  padding:20px 24px;
  transform:translateY(calc(100% + 40px));
  opacity:0;
  transition:transform .5s var(--ease), opacity .5s var(--ease);
  box-shadow:0 -8px 40px rgba(0,0,0,.5);
  border-top:3px solid var(--red);
}
.cookie-banner.show{
  transform:translateY(0);
  opacity:1;
}
.cookie-banner-inner{
  display:flex;align-items:center;gap:24px;
  flex-wrap:wrap;
}
.cookie-content{flex:1;min-width:240px}
.cookie-title{
  font-size:14px;font-weight:800;
  color:var(--text);
  margin-bottom:6px;
  letter-spacing:.02em;
}
.cookie-text{
  font-size:12px;
  color:var(--text-sub);
  line-height:1.6;
}
.cookie-text a{
  color:var(--red);
  border-bottom:1px solid transparent;
  transition:border-color .25s;
}
.cookie-text a:hover{border-color:var(--red)}
.cookie-text strong{color:var(--text);font-weight:700}
.cookie-actions{
  display:flex;gap:10px;
  flex-wrap:wrap;
}
.cookie-actions .btn-current{
  position:relative;
}
.cookie-actions .btn-current::after{
  content:'AKTIV';
  position:absolute;
  top:-6px;right:-6px;
  background:#5A8868;
  color:#fff;
  font-size:7px;font-weight:900;
  letter-spacing:.15em;
  padding:3px 6px;
  clip-path:polygon(3px 0, 100% 0, 100% 100%, 0 100%, 0 3px);
}

@media(max-width:640px){
  .cookie-banner{bottom:0;left:0;right:0;border-radius:0;clip-path:none;max-width:none}
  .cookie-banner-inner{flex-direction:column;align-items:stretch;gap:14px}
  .cookie-actions{justify-content:stretch}
  .cookie-actions .btn{flex:1;justify-content:center}
}

/* ─── Footer credit (Everspice trigger) ─── */
.footer-credit{
  margin-top:20px;padding-top:20px;
  border-top:1px solid var(--bg-border);
  text-align:center;
}
.credit-trigger{
  font-size:10px;font-weight:500;
  letter-spacing:.1em;
  color:var(--text-muted);
  padding:0;background:none;border:none;
  cursor:pointer;
  transition:color .25s;
  font-family:var(--font);
}
.credit-trigger span{
  font-weight:800;letter-spacing:.14em;
  color:var(--text-sub);
  transition:color .25s;
}
.credit-trigger:hover{color:var(--text-sub)}
.credit-trigger:hover span{color:var(--red)}

/* ═══════════════════════════════════════════════════════════════
   EVERSPICE MODAL
   ═══════════════════════════════════════════════════════════════ */
.everspice-modal{
  position:fixed;inset:0;z-index:999;
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .4s var(--ease);
}
.everspice-modal.open{
  opacity:1;pointer-events:auto;
}
.es-overlay{
  position:absolute;inset:0;
  background:rgba(4,4,4,.92);
  backdrop-filter:blur(18px) saturate(1.2);
}
.es-dialog{
  position:relative;z-index:2;
  width:min(960px,92vw);
  max-height:90vh;
  background:var(--bg-card);
  clip-path:var(--cut-lg);
  padding:clamp(32px,5vw,56px);
  overflow:hidden;
  transform:scale(.96) translateY(20px);
  transition:transform .5s var(--ease);
}
.everspice-modal.open .es-dialog{transform:none}

/* Red glow bleed */
.es-dialog::before{
  content:'';position:absolute;
  top:-40%;left:-20%;width:80%;height:80%;
  background:radial-gradient(circle, rgba(232,44,63,.15) 0%, transparent 60%);
  pointer-events:none;z-index:0;
}

.es-close{
  position:absolute;top:20px;right:20px;z-index:5;
  width:36px;height:36px;
  background:var(--bg-elevated);
  color:var(--text);
  font-size:20px;line-height:1;
  display:flex;align-items:center;justify-content:center;
  clip-path:var(--cut-sm);
  transition:all .25s var(--ease);
}
.es-close:hover{background:var(--red);color:#fff;transform:rotate(90deg)}

.es-content{
  position:relative;z-index:1;
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:clamp(28px,4vw,48px);
  align-items:center;
}

/* ─── Left side ─── */
.es-logo{margin-bottom:20px}
.es-logo img{
  height:44px;width:auto;object-fit:contain;
}
.es-eyebrow{
  font-size:10px;font-weight:700;
  letter-spacing:.35em;text-transform:uppercase;
  color:var(--red);margin-bottom:10px;
}
.es-title{
  font-size:clamp(28px,3.6vw,42px);
  font-weight:900;line-height:1.1;
  color:var(--text);margin-bottom:18px;
  letter-spacing:-.02em;
}
.es-tagline{
  font-size:14px;line-height:1.75;
  color:var(--text-sub);margin-bottom:24px;
}
.es-tagline em{
  font-style:italic;font-weight:700;
  color:var(--red);
  display:inline-block;margin-top:4px;
}
.es-actions{
  display:flex;gap:12px;flex-wrap:wrap;
}

/* ─── Right side: Audio player ─── */
.es-player{
  background:var(--bg-elevated);
  clip-path:var(--cut-md);
  padding:24px;
  display:flex;flex-direction:column;gap:20px;
}
.es-player-vinyl{
  position:relative;
  width:100%;aspect-ratio:1;
  max-width:200px;margin:0 auto;
}
.es-player-disc{
  position:relative;width:100%;height:100%;
  border-radius:50%;
  background:
    radial-gradient(circle, var(--bg-card) 14%, transparent 15%),
    radial-gradient(circle, var(--bg-border) 15.5%, transparent 16.5%),
    repeating-radial-gradient(circle, transparent, transparent 3px, rgba(255,255,255,.02) 3.5px, transparent 4px),
    conic-gradient(from 0deg, #111, #1a1a1a, #111, #1a1a1a, #111);
  border:1px solid var(--bg-border);
  box-shadow:0 0 40px rgba(232,44,63,.15), inset 0 0 30px rgba(0,0,0,.5);
  animation:spin 4s linear infinite;
  animation-play-state:paused;
}
.es-player-disc::after{
  content:'';position:absolute;
  top:50%;left:50%;transform:translate(-50%,-50%);
  width:28%;height:28%;border-radius:50%;
  background:var(--red);
  box-shadow:inset 0 0 10px rgba(0,0,0,.4);
}
.everspice-modal.playing .es-player-disc{
  animation-play-state:running;
}

.es-player-info{display:flex;flex-direction:column;gap:6px}
.es-player-tag{
  font-size:9px;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--red);
  display:flex;align-items:center;gap:8px;
}
.es-player-tag::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--red);
  animation:blink 1.4s ease-in-out infinite;
}
.everspice-modal.playing .es-player-tag::before{background:#00C853}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.es-player-title{
  font-size:16px;font-weight:800;
  color:var(--text);line-height:1.2;
}
.es-player-artist{
  font-size:11px;color:var(--text-muted);
  letter-spacing:.1em;text-transform:uppercase;
  font-weight:600;
}
.es-player-progress{margin-top:10px}
.es-player-bar{
  height:3px;background:var(--bg-border);
  position:relative;overflow:hidden;
}
.es-player-fill{
  position:absolute;top:0;left:0;height:100%;
  width:0%;background:var(--red);
  transition:width .1s linear;
}
.es-player-time{
  display:flex;justify-content:space-between;
  font-size:10px;font-weight:600;
  color:var(--text-muted);
  letter-spacing:.08em;
  margin-top:6px;font-variant-numeric:tabular-nums;
}

.es-player-toggle{
  margin-top:8px;
  width:44px;height:44px;
  background:var(--red);color:#fff;
  display:flex;align-items:center;justify-content:center;
  clip-path:var(--cut-sm);
  align-self:flex-start;
  transition:all .25s var(--ease);
}
.es-player-toggle:hover{background:var(--red-light);transform:translateY(-2px)}

/* ─── Modal responsive ─── */
@media(max-width:768px){
  .es-content{grid-template-columns:1fr;gap:24px}
  .es-dialog{padding:40px 24px 32px;max-height:92vh;overflow-y:auto}
  .es-player-vinyl{max-width:140px}
  .es-title{font-size:26px}
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .hero-vinyl{display:none}
  .hero-bg-photo img{width:100%;object-position:60% 30%}
  .hero-bg-fade{
    background:
      linear-gradient(to right, var(--bg) 0%, rgba(8,8,8,.85) 40%, rgba(8,8,8,.55) 100%),
      linear-gradient(to top, var(--bg) 0%, rgba(8,8,8,.5) 20%, transparent 45%);
  }
  .hero-title-block{max-width:100%}
  .about-grid{grid-template-columns:1fr}
  .about-visual{position:static;max-width:400px;margin:0 auto 48px}
  .genres-grid{grid-template-columns:repeat(3,1fr)}
  .music-grid{grid-template-columns:1fr 1fr}
  .music-grid .mixtape-card:last-child{grid-column:span 2}
  .panel-1col{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .contact-left{position:static;margin-bottom:48px}
  .footer-top{grid-template-columns:1fr 1fr 1fr;gap:32px}
  .footer-brand{grid-column:1/-1;max-width:none}
}

@media(max-width:768px){
  .hero-vinyl{display:none}
  .hero-line-name{font-size:clamp(60px,20vw,120px)}
  .hero-bg-fade{
    background:
      linear-gradient(to right, var(--bg) 0%, rgba(8,8,8,.92) 30%, rgba(8,8,8,.75) 100%),
      linear-gradient(to top, var(--bg) 0%, rgba(8,8,8,.6) 20%, transparent 50%);
  }
  .hero-bottom-left{flex-wrap:wrap;justify-content:center}
  #navbar{flex-wrap:wrap}
  .nav-links{
    display:none;
    width:100%;
    margin:0;
    flex-direction:column;
    gap:0;
    padding:12px 0 8px;
    order:3;
  }
  .nav-links.open{display:flex}
  .nav-links li{width:100%}
  .nav-links a{
    display:block;
    font-size:14px;font-weight:600;
    padding:14px 4px;
    border-bottom:1px solid var(--bg-border);
  }
  .nav-links a::after{display:none}
  .nav-links li:last-child a{border-bottom:none}
  .nav-links .nav-cta{
    display:inline-block;width:auto;
    margin-top:10px;padding:12px 28px;
    border-bottom:none!important;
  }
  .nav-burger{display:flex}
  .genres-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .music-grid{grid-template-columns:1fr}
  .music-grid .mixtape-card:last-child{grid-column:span 1}
  .panel-2col{grid-template-columns:1fr}
  .carousel-track{min-height:320px}
  .form-row{grid-template-columns:1fr}
  .booking-form{padding:24px 18px}
  .footer-top{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}

@media(max-width:480px){
  .hero-vinyl{display:none}
  .hero-actions{flex-direction:column;align-items:center}
  .hero-bottom{display:none}
  .about-stats-row{flex-wrap:wrap;gap:18px}
  .mixtape-actions{flex-direction:column}
}
