/* ═══════════════════════════════════════════════════════════════
   E-FEKT · Rap Artist Page — DJ E-FEKT Design System
   Red · Pure Black · Cut-Corner · Bold
   ═══════════════════════════════════════════════════════════════ */

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

  --red:         #E82C3F;
  --red-light:   #FF4757;
  --red-dim:     #A11D2D;
  --red-faint:   rgba(232,44,63,.08);
  --red-glow:    rgba(232,44,63,.25);

  --text:        #F2F0F0;
  --text-sub:    #888888;
  --text-muted:  #444444;

  --font:        'Outfit', system-ui, sans-serif;
  --ease:        cubic-bezier(.22,.61,.36,1);

  --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;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:pointer;border:none;background:none;color:inherit;font:inherit}
ul{list-style:none}

/* ─── 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-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 + Slide-Fill) ──────────────────────── */
.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;
  isolation:isolate;
  clip-path:polygon(0 0, calc(100% - 16px) 0, 100% 16px, 100% 100%, 16px 100%, 0 calc(100% - 16px));
}
.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-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
   ═══════════════════════════════════════════════════════════════ */
.nav{
  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;
}
.nav.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-brand{
  display:flex;align-items:center;gap:12px;
  color:var(--text);
  line-height:1;
}
.nav-brand-logo{
  height:56px;width:auto;object-fit:contain;
  transition:transform .3s var(--ease), filter .3s var(--ease);
}
.nav-brand:hover .nav-brand-logo{
  transform:scale(1.05);
  filter:drop-shadow(0 0 12px var(--red-glow));
}
.nav.scrolled .nav-brand-logo{height:44px}
.nav-brand-text{
  display:flex;flex-direction:column;gap:1px;
  font-size:26px;font-weight:800;
  letter-spacing:-.01em;
}
.nav-brand-text small{
  font-size:11px;font-weight:700;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--red);
  margin-top:2px;
}
.footer-logo-img{height:56px!important}
.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-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
   ═══════════════════════════════════════════════════════════════ */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;flex-direction:column;
  justify-content:center;
  overflow:hidden;
  background:var(--bg);
  padding:100px 0 0;
}
.hero-bg{
  position:absolute;inset:0;z-index:1;
  overflow:hidden;pointer-events:none;
}
.hero-bg 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)}
}
.hero-bg::after{
  content:'';position:absolute;inset:0;
  background:
    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%),
    linear-gradient(to top,
      var(--bg) 0%, rgba(8,8,8,.6) 15%, transparent 35%),
    linear-gradient(135deg, transparent 40%, rgba(232,44,63,.08) 100%);
}

.hero-content{
  position:relative;z-index:5;
  text-align:left;
  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:820px;
  animation:fadeUp .9s var(--ease) both;
}
.hero-content a,.hero-content 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-title-sub{
  display:block;
  font-size:clamp(20px,3vw,40px);
  font-weight:300;font-style:italic;
  color:var(--text-sub);
  letter-spacing:.2em;
  margin-bottom:8px;
}
.hero-title-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;
}
.hero-title-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-tagline{
  font-size:clamp(14px,1.8vw,17px);font-weight:300;
  color:var(--text-sub);letter-spacing:.04em;
  line-height:1.9;margin-bottom:36px;max-width:560px;
}
.hero-tagline em{font-style:italic;font-weight:600;color:var(--red)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;pointer-events:auto}

/* Bottom streaming bar */
.hero-bottom{
  position:absolute;
  bottom:0;left:0;right:0;
  z-index:4;
  display:flex;justify-content:center;
  padding:0 clamp(16px,4vw,60px) 24px;
  padding-top:16px;
}
.hero-bottom-inner{
  display:flex;align-items:center;gap:0;
  background:rgba(17,17,17,.85);
  backdrop-filter:blur(12px);
  border:1px solid var(--bg-border);
  clip-path:var(--cut-md);
  overflow:hidden;
}
.hero-stream-item{
  display:flex;align-items:center;gap:10px;
  padding:14px clamp(14px,2vw,28px);
  white-space:nowrap;
  transition:all .3s var(--ease);
  pointer-events:auto;
  position:relative;
}
.hero-stream-item::after{
  content:'';position:absolute;
  right:0;top:20%;bottom:20%;
  width:1px;background:var(--bg-border);
}
.hero-stream-item:last-child::after{display:none}
.hero-stream-item:hover{
  background:rgba(232,44,63,.08);
}
.hero-stream-icon{
  width:18px;height:18px;
  object-fit:contain;
  filter:invert(22%) sepia(95%) saturate(5000%) hue-rotate(340deg) brightness(90%);
  transition:transform .3s var(--ease), filter .3s var(--ease);
}
.hero-stream-item:hover .hero-stream-icon{transform:scale(1.15);filter:invert(22%) sepia(95%) saturate(5000%) hue-rotate(340deg) brightness(110%)}
.hero-stream-label{
  font-size:9px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-sub);
  transition:color .3s var(--ease);
}
.hero-stream-item:hover .hero-stream-label{color:var(--text)}

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

/* ═══════════════════════════════════════════════════════════════
   NEWS
   ═══════════════════════════════════════════════════════════════ */
.news{background:var(--bg);border-bottom:1px solid var(--bg-border)}
.news-feature{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:clamp(24px,4vw,48px);
  align-items:center;
  background:var(--bg-card);
  clip-path:var(--cut-lg);
  overflow:hidden;
}
.news-feature-media{position:relative;overflow:hidden}
.news-feature-vid{
  position:relative;
  aspect-ratio:16/9;
  cursor:pointer;
  overflow:hidden;
}
.news-feature-vid img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .5s var(--ease), filter .4s var(--ease);
}
.news-feature-vid:hover img{
  transform:scale(1.04);
  filter:brightness(.65);
}
.news-play-icon{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%) scale(.9);
  width:64px;height:64px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(232,44,63,.9);
  color:#fff;
  font-size:22px;
  clip-path:var(--cut-sm);
  opacity:0;
  transition:opacity .3s var(--ease), transform .3s var(--ease);
  pointer-events:none;
}
.news-feature-vid:hover .news-play-icon{
  opacity:1;
  transform:translate(-50%,-50%) scale(1);
}
.news-feature-content{
  padding:clamp(24px,3vw,40px) clamp(24px,3vw,40px) clamp(24px,3vw,40px) 0;
}
.news-tag{
  display:inline-block;
  font-size:9px;font-weight:800;
  letter-spacing:.2em;text-transform:uppercase;
  padding:5px 12px;
  background:var(--red);
  color:#fff;
  clip-path:polygon(4px 0, 100% 0, calc(100% - 4px) 100%, 0 100%);
  margin-bottom:14px;
}
.news-feature-title{
  font-size:clamp(24px,3.5vw,40px);
  font-weight:800;
  color:var(--text);
  line-height:1.1;
  letter-spacing:-.02em;
  margin-bottom:14px;
}
.news-feature-desc{
  font-size:14px;color:var(--text-sub);
  line-height:1.8;margin-bottom:24px;
}
.news-feature-desc strong{color:var(--text);font-weight:700}
.news-feature-actions{display:flex;gap:12px;flex-wrap:wrap}

@media(max-width:768px){
  .news-feature{grid-template-columns:1fr}
  .news-feature-content{padding:24px}
}

/* ═══════════════════════════════════════════════════════════════
   BIOGRAPHY
   ═══════════════════════════════════════════════════════════════ */
.bio{background:var(--bg-card);border-top:1px solid var(--bg-border)}
.bio-grid{
  display:grid;
  grid-template-columns:1fr 1.3fr;
  gap:var(--gap);
  align-items:start;
}
.bio-text p{
  font-size:15px;line-height:1.8;
  color:var(--text-sub);
  margin-bottom:18px;
}
.bio-text p:first-of-type{
  font-size:clamp(16px,1.8vw,19px);
  color:var(--text);
  font-weight:400;
}
.bio-quote{
  border-left:3px solid var(--red);
  padding:20px 0 20px 24px;
  margin:28px 0;
  font-style:italic;
  font-size:clamp(17px,2vw,22px);
  color:var(--text-sub);
  line-height:1.6;
}
.bio-quote cite{
  display:block;
  font-family:var(--font);
  font-size:10px;font-style:normal;
  font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--red);
  margin-top:12px;
}
.bio-timeline{
  display:flex;flex-direction:column;gap:0;
  padding-top:24px;
  border-top:1px solid var(--bg-border);
  margin-top:24px;
}
.bio-year{
  display:grid;
  grid-template-columns:80px 1fr;
  gap:20px;align-items:baseline;
  padding:14px 0;
  border-bottom:1px solid var(--bg-border);
}
.bio-year:last-child{border-bottom:none}
.bio-year-num{
  font-size:18px;font-weight:900;
  color:var(--red);
  letter-spacing:.02em;
}
.bio-year-text{
  font-size:13px;color:var(--text-sub);
  line-height:1.6;
}

/* ═══════════════════════════════════════════════════════════════
   DISCOGRAPHY
   ═══════════════════════════════════════════════════════════════ */
.discography{background:var(--bg)}

.disc-tabs{
  display:flex;gap:10px;
  margin-bottom:32px;
  flex-wrap:wrap;
}
.disc-tab{
  font-size:10px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-sub);
  padding:10px 20px;
  background:var(--bg-card);
  clip-path:var(--cut-sm);
  transition:all .25s var(--ease);
}
.disc-tab:hover{background:var(--bg-hover);color:var(--text)}
.disc-tab.active{
  background:var(--red);
  color:#fff;
}

.disc-list{
  display:flex;flex-direction:column;gap:10px;
}
.disc-cover{
  width:52px;height:52px;
  object-fit:cover;
  clip-path:var(--cut-sm);
  flex-shrink:0;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.disc-item:hover .disc-cover{
  transform:scale(1.08);
  box-shadow:0 4px 16px rgba(232,44,63,.2);
}
.disc-item{
  display:grid;
  grid-template-columns:52px 70px 1fr auto auto;
  align-items:center;
  gap:clamp(16px,3vw,32px);
  padding:20px 28px;
  background:var(--bg-card);
  clip-path:var(--cut-md);
  transition:all .3s var(--ease);
  position:relative;
  text-decoration:none;
}
.disc-item::before{
  content:'';
  position:absolute;
  top:0;bottom:0;left:0;
  width:3px;
  background:var(--red);
  opacity:.5;
  transition:opacity .3s var(--ease);
}
.disc-item:hover{
  background:var(--bg-hover);
  transform:translateX(4px);
}
.disc-item:hover::before{opacity:1}

.disc-year{
  font-size:clamp(20px,2.4vw,26px);
  font-weight:900;
  color:var(--text);
  letter-spacing:-.01em;
  line-height:1;
}
.disc-info{display:flex;flex-direction:column;gap:4px;min-width:0}
.disc-title{
  font-size:clamp(15px,1.8vw,18px);
  font-weight:800;
  color:var(--text);
  line-height:1.25;
}
.disc-meta{
  font-size:10px;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--text-sub);
}
.disc-tag{
  font-size:9px;font-weight:800;
  letter-spacing:.2em;text-transform:uppercase;
  padding:6px 12px;
  background:var(--red-faint);
  color:var(--red);
  clip-path:polygon(4px 0, 100% 0, 100% 100%, 0 100%, 0 4px);
}
.disc-link{
  font-size:18px;font-weight:800;
  color:var(--text-muted);
  transition:all .3s var(--ease);
  width:32px;height:32px;
  display:flex;align-items:center;justify-content:center;
}
.disc-item:hover .disc-link{
  color:var(--red);
  transform:translateX(4px);
}
.disc-actions{
  display:flex;align-items:center;gap:6px;flex-shrink:0;
}
.disc-action{
  width:34px;height:34px;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-elevated);
  clip-path:var(--cut-sm);
  transition:all .3s var(--ease);
  text-decoration:none;
  color:var(--text-muted);
  font-size:18px;
}
.disc-action img{
  width:16px;height:16px;
  object-fit:contain;
  filter:brightness(0) invert(.45);
  transition:filter .3s var(--ease);
}
.disc-action:hover{
  background:var(--red-faint);
  transform:translateY(-2px);
}
.disc-action:hover img{
  filter:invert(22%) sepia(95%) saturate(5000%) hue-rotate(340deg) brightness(90%);
}
.disc-action-dl:hover{
  color:var(--red);
}

.disc-list:not(.expanded) .disc-item:nth-child(n+7){display:none}
.disc-more{
  margin-top:20px;
  width:100%;
  justify-content:center;
  padding:14px 36px;
}
.disc-more.hidden{display:none}

/* ─── MUSIKVIDEOS ─────────────────────────────────────────────── */
.vid-section{margin-top:clamp(60px,8vw,100px)}
.vid-heading{
  font-size:clamp(22px,3vw,32px);
  font-weight:800;color:var(--text);
  margin-bottom:clamp(24px,4vw,40px);
  letter-spacing:-.01em;
}
.vid-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:16px;
}
.vid-card{
  display:flex;flex-direction:column;gap:10px;
}
.vid-thumb{
  position:relative;
  aspect-ratio:16/9;
  overflow:hidden;
  cursor:pointer;
  clip-path:var(--cut-md);
  background:var(--bg-card);
}
.vid-thumb img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .4s var(--ease), filter .4s var(--ease);
}
.vid-thumb:hover img{
  transform:scale(1.06);
  filter:brightness(.7);
}
.vid-play-icon{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%) scale(.9);
  width:52px;height:52px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(232,44,63,.9);
  color:#fff;
  font-size:20px;
  clip-path:var(--cut-sm);
  opacity:0;
  transition:opacity .3s var(--ease), transform .3s var(--ease);
  pointer-events:none;
}
.vid-thumb:hover .vid-play-icon{
  opacity:1;
  transform:translate(-50%,-50%) scale(1);
}
.vid-name{
  font-size:12px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-sub);
  padding-left:4px;
}

/* ═══════════════════════════════════════════════════════════════
   PODCAST
   ═══════════════════════════════════════════════════════════════ */
.podcast{background:var(--bg-card);border-top:1px solid var(--bg-border)}
.podcast-grid{display:flex;flex-direction:column;gap:16px}
.podcast-inner{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:clamp(20px,4vw,40px);
  padding:clamp(24px,3vw,40px);
  background:linear-gradient(135deg, var(--bg-elevated) 0%, rgba(232,44,63,.08) 100%);
  clip-path:var(--cut-lg);
  position:relative;overflow:hidden;
}
.podcast-inner::before{
  content:'';
  position:absolute;
  top:0;left:0;bottom:0;
  width:4px;
  background:var(--red);
}
.podcast-cover{
  width:80px;height:80px;
  object-fit:cover;
  flex-shrink:0;
  clip-path:var(--cut-sm);
  transition:transform .3s var(--ease);
}
.podcast-inner:hover .podcast-cover{transform:scale(1.05)}
.podcast-icon{
  width:60px;height:60px;
  background:var(--red);
  display:flex;align-items:center;justify-content:center;
  color:#fff;
  flex-shrink:0;
  clip-path:var(--cut-sm);
}
.podcast-content{flex:1;min-width:0}
.podcast-eyebrow{
  font-size:10px;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--red);
  margin-bottom:6px;
}
.podcast-title{
  font-size:clamp(20px,2.2vw,26px);
  font-weight:800;
  color:var(--text);
  line-height:1.2;
  margin-bottom:6px;
  letter-spacing:-.01em;
}
.podcast-desc{
  font-size:13px;color:var(--text-sub);
  line-height:1.6;
}

/* ═══════════════════════════════════════════════════════════════
   KONTAKT
   ═══════════════════════════════════════════════════════════════ */
.kontakt{background:var(--bg-card);border-top:1px solid var(--bg-border)}
.kontakt-inner{
  max-width:640px;
  margin:0 auto;
}

/* Form */
.kontakt-form{display:flex;flex-direction:column;gap:16px}
.kontakt-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.kontakt-field{display:flex;flex-direction:column;gap:6px}
.kontakt-field label{
  font-size:9px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-muted);
}
.kontakt-field input,
.kontakt-field textarea{
  background:var(--bg);
  border:1px solid var(--bg-border);
  color:var(--text);
  font-family:var(--font);
  font-size:13px;font-weight:400;
  padding:12px 16px;
  clip-path:var(--cut-sm);
  outline:none;
  transition:border-color .25s, box-shadow .25s;
  resize:vertical;
}
.kontakt-field input::placeholder,
.kontakt-field textarea::placeholder{color:var(--text-muted);font-weight:300}
.kontakt-field input:focus,
.kontakt-field textarea:focus{
  border-color:var(--red);
  box-shadow:0 0 0 2px var(--red-faint);
}
.kontakt-footer{
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
  margin-top:4px;
}
.kontakt-hint{
  font-size:10px;color:var(--text-muted);
  line-height:1.6;flex:1;min-width:200px;
}
.kontakt-hint a{color:var(--red);transition:color .25s}
.kontakt-hint a:hover{color:var(--red-light)}
.kontakt-check{
  display:flex;align-items:flex-start;gap:10px;
}
.kontakt-check input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  width:18px;height:18px;flex-shrink:0;
  margin-top:1px;
  background:var(--bg);
  border:1px solid var(--bg-border);
  clip-path:var(--cut-sm);
  cursor:pointer;
  transition:background .25s, border-color .25s;
  position:relative;
}
.kontakt-check input[type="checkbox"]:checked{
  background:var(--red);border-color:var(--red);
}
.kontakt-check input[type="checkbox"]:checked::after{
  content:'✓';
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:900;color:#fff;
}
.kontakt-check label{
  font-size:11px;color:var(--text-muted);
  line-height:1.5;cursor:pointer;
}
.kontakt-check label a{color:var(--red)}
.kontakt-check label a:hover{color:var(--red-light)}

@media(max-width:768px){
  .kontakt-inner{max-width:100%}
  .kontakt-row{grid-template-columns:1fr}
  .kontakt-footer{flex-direction:column;align-items:stretch}
  .kontakt-footer .btn{justify-content:center}
}

/* ═══════════════════════════════════════════════════════════════
   CONNECT
   ═══════════════════════════════════════════════════════════════ */
.connect{background:var(--bg)}
.connect-sub{
  font-size:10px;font-weight:700;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--text-muted);
  margin-bottom:20px;margin-top:48px;
}
.connect-sub:first-of-type{margin-top:0}

/* Streaming row – icon-centric */
.connect-stream{
  display:flex;justify-content:center;
  gap:clamp(20px,4vw,48px);
  flex-wrap:wrap;
  padding:32px 0;
  margin-bottom:12px;
  background:var(--bg-card);
  clip-path:var(--cut-lg);
}
.stream-link{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  padding:12px 16px;
  transition:transform .3s var(--ease);
}
.stream-link:hover{transform:translateY(-4px)}
.stream-link-icon{
  width:28px;height:28px;
  object-fit:contain;
  filter:brightness(0) invert(.55);
  transition:filter .3s var(--ease), transform .3s var(--ease);
}
.stream-link:hover .stream-link-icon{filter:invert(22%) sepia(95%) saturate(5000%) hue-rotate(340deg) brightness(90%);transform:scale(1.1)}
.stream-link-name{
  font-size:9px;font-weight:700;
  letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-muted);
  transition:color .3s var(--ease);
}
.stream-link:hover .stream-link-name{color:var(--text)}

/* Social grid – card style */
.connect-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:12px;
}
.connect-link{
  display:flex;align-items:center;gap:14px;
  padding:20px 22px;
  background:var(--bg-card);
  clip-path:var(--cut-md);
  transition:all .35s var(--ease);
  position:relative;
  overflow:hidden;
}
.connect-link::before{
  content:'';position:absolute;
  top:0;left:0;width:0;height:3px;
  background:var(--red);
  transition:width .35s var(--ease);
}
.connect-link:hover{
  background:var(--bg-hover);
  transform:translateY(-3px);
}
.connect-link:hover::before{width:100%}
.connect-link-icon{
  width:36px;height:36px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  background:var(--red-faint);
  clip-path:var(--cut-sm);
}
.connect-link-icon img{width:20px;height:20px;object-fit:contain;filter:invert(22%) sepia(95%) saturate(5000%) hue-rotate(340deg) brightness(90%)}
.connect-link-text{display:flex;flex-direction:column;gap:2px;min-width:0}
.connect-link-name{
  font-size:14px;font-weight:800;
  color:var(--text);line-height:1.2;
}
.connect-link-handle{
  font-size:10px;font-weight:600;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--text-muted);
}

/* ═══════════════════════════════════════════════════════════════
   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.5fr 1fr 1fr 1fr;
  gap:48px;margin-bottom:44px;
}
.footer-brand{display:flex;flex-direction:column;gap:8px;max-width:320px}
.footer-brand .nav-brand{margin-bottom:10px}
.footer-brand-tagline{
  font-size:12px;font-style:italic;
  color:var(--text-muted);line-height:1.6;
}
.footer-col{display:flex;flex-direction:column;gap:12px;padding-top:4px}
.footer-col-title{
  font-size:10px;font-weight:800;
  letter-spacing:.25em;text-transform:uppercase;
  color:var(--red);
  margin-bottom:4px;
}
.footer-col a{
  font-size:12px;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-sub);
  transition:color .25s;
}
.footer-col a:hover{color:var(--red)}

.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-credits{
  width:100%;text-align:center;
  margin-top:16px;padding-top:16px;
  border-top:1px solid var(--bg-border);
  font-size:13px!important;color:var(--text-muted);opacity:.55;letter-spacing:.06em;
}
.footer-credits strong{font-weight:700;color:var(--text-muted)}
.footer-dj-link{
  color:var(--red)!important;
  font-weight:800;
  letter-spacing:.08em;
}

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .hero-bg img{width:100%;object-position:60% 30%}
  .hero-bg::after{
    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%);
  }
  .bio-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px}
  .vid-grid{grid-template-columns:repeat(2, 1fr)}
}

@media(max-width:768px){
  .nav{background:rgba(8,8,8,.97);backdrop-filter:blur(14px)}
  .hero-bg::after{
    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%);
  }
  .nav{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);
    letter-spacing:.12em;
  }
  .nav-links a::after{display:none}
  .nav-links li:last-child a{border-bottom:none}
  .nav-burger{display:flex}

  .vid-grid{grid-template-columns:1fr}
  .disc-item{grid-template-columns:44px 1fr auto;gap:12px;padding:16px 20px}
  .disc-cover{width:44px;height:44px}
  .disc-item .disc-tag{display:none}
  .disc-item .disc-year{display:none}

  .podcast-inner{grid-template-columns:1fr;text-align:center}
  .podcast-cover{margin:0 auto}
  .podcast-icon{margin:0 auto}
  .podcast-inner::before{top:0;bottom:auto;left:0;right:0;width:100%;height:4px}

  .footer-top{grid-template-columns:1fr;gap:28px}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .hero-bottom-inner{
    overflow-x:auto;overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    width:100%;
  }
  .hero-bottom-inner::-webkit-scrollbar{display:none}
  .hero-bottom{padding:0 12px 16px;padding-top:12px}
  .hero-stream-label{font-size:8px;letter-spacing:.12em}
}

/* ═══════════════════════════════════════════════════════════════
   COOKIE BANNER
   ═══════════════════════════════════════════════════════════════ */
.cookie-banner{
  position:fixed;
  bottom:20px;left:20px;right:20px;
  max-width:640px;
  margin:0 auto;
  z-index:9998;
  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);
  pointer-events:none;
}
.cookie-banner.show{
  transform:translateY(0);
  opacity:1;
  pointer-events:auto;
}
.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-bottom-color:var(--red)}
.cookie-text strong{color:var(--text);font-weight:700}
.cookie-actions{
  display:flex;gap:10px;
  flex-wrap:wrap;
}
.cookie-actions .btn{padding:12px 24px;font-size:10px}
.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;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}
}

/* ═══════════════════════════════════════════════════════════════
   EVERSPICE POPUP
   ═══════════════════════════════════════════════════════════════ */
.es-overlay{
  position:fixed;inset:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,0);
  backdrop-filter:blur(0px);
  pointer-events:none;
  transition:background .5s var(--ease), backdrop-filter .5s var(--ease);
}
.es-overlay.active{
  background:rgba(0,0,0,.88);
  backdrop-filter:blur(20px);
  pointer-events:auto;
}
.es-popup{
  position:relative;
  max-width:520px;width:92%;
  background:linear-gradient(160deg, #0d0d0d 0%, #1a1a1a 50%, #0d0d0d 100%);
  border:1px solid rgba(232,44,63,.2);
  padding:48px 40px;
  text-align:center;
  clip-path:var(--cut-lg);
  transform:scale(.85) translateY(40px);
  opacity:0;
  transition:transform .5s var(--ease), opacity .45s var(--ease);
  overflow:hidden;
}
.es-overlay.active .es-popup{
  transform:scale(1) translateY(0);
  opacity:1;
}
.es-glow{
  position:absolute;
  top:-60%;left:50%;
  width:300px;height:300px;
  transform:translateX(-50%);
  background:radial-gradient(circle, rgba(232,44,63,.15) 0%, transparent 70%);
  pointer-events:none;
  animation:esGlowPulse 3s ease-in-out infinite alternate;
}
@keyframes esGlowPulse{
  from{opacity:.6;transform:translateX(-50%) scale(1)}
  to{opacity:1;transform:translateX(-50%) scale(1.3)}
}
.es-close{
  position:absolute;top:16px;right:16px;
  font-size:28px;color:var(--text-muted);
  line-height:1;padding:4px 8px;
  transition:color .25s, transform .25s;
  z-index:2;
}
.es-close:hover{color:var(--red);transform:rotate(90deg)}

.es-logo{
  max-width:220px;margin:0 auto 20px;
  filter:drop-shadow(0 0 30px rgba(232,44,63,.2));
  animation:esLogoIn .7s var(--ease) .2s both;
}
@keyframes esLogoIn{
  from{opacity:0;transform:translateY(16px) scale(.9)}
  to{opacity:1;transform:none}
}
.es-tagline{
  font-size:12px;font-weight:700;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--red);
  margin-bottom:20px;
  animation:esLineIn .6s var(--ease) .35s both;
}
.es-divider{
  width:60px;height:2px;margin:0 auto 20px;
  background:linear-gradient(to right, transparent, var(--red), transparent);
  animation:esLineIn .6s var(--ease) .4s both;
}
@keyframes esLineIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

.es-text{
  font-size:14px;line-height:1.8;
  color:var(--text-sub);
  margin-bottom:22px;
  animation:esLineIn .6s var(--ease) .45s both;
}
.es-text strong{color:var(--text);font-weight:800}

.es-services{
  display:flex;flex-wrap:wrap;justify-content:center;gap:8px;
  margin-bottom:28px;
  animation:esLineIn .6s var(--ease) .5s both;
}
.es-chip{
  font-size:9px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  padding:6px 14px;
  background:var(--red-faint);
  color:var(--red);
  clip-path:polygon(4px 0, 100% 0, calc(100% - 4px) 100%, 0 100%);
  transition:background .25s, transform .25s;
}
.es-chip:hover{background:rgba(232,44,63,.18);transform:translateY(-2px)}

/* Player */
.es-player{
  display:flex;align-items:center;gap:14px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--bg-border);
  padding:12px 18px;
  margin-bottom:28px;
  clip-path:var(--cut-sm);
  animation:esLineIn .6s var(--ease) .55s both;
}
.es-play-btn{
  width:42px;height:42px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--red);
  color:#fff;
  clip-path:var(--cut-sm);
  transition:background .25s, transform .25s;
}
.es-play-btn:hover{background:var(--red-light);transform:scale(1.08)}
.es-play-btn svg{width:18px;height:18px}
.es-icon-pause{display:none}
.es-play-btn.playing .es-icon-play{display:none}
.es-play-btn.playing .es-icon-pause{display:block}

.es-track-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}
.es-track-name{
  font-size:11px;font-weight:700;
  letter-spacing:.15em;text-transform:uppercase;
  color:var(--text-sub);
}
.es-progress-wrap{
  width:100%;height:4px;
  background:var(--bg-border);
  cursor:pointer;
  position:relative;
}
.es-progress-bar{
  height:100%;width:0%;
  background:var(--red);
  transition:width .15s linear;
  position:relative;
}
.es-progress-bar::after{
  content:'';position:absolute;
  right:-4px;top:50%;
  width:8px;height:8px;
  border-radius:50%;
  background:var(--red-light);
  transform:translateY(-50%);
  box-shadow:0 0 8px var(--red-glow);
}

.es-cta-line{
  font-size:13px;font-weight:400;
  color:var(--text-muted);
  margin-bottom:14px;
  animation:esLineIn .6s var(--ease) .6s both;
}
.es-cta-btn{
  animation:esLineIn .6s var(--ease) .65s both;
}

/* Footer credits link style */
.footer-credits a{color:inherit;transition:color .25s, opacity .25s;display:inline-block}
.footer-credits a:hover{opacity:1;animation:bassShake .15s ease infinite}
.footer-credits a:hover strong{color:var(--red);transition:color .25s}
@keyframes bassShake{
  0%,100%{transform:translate(0,0)}
  20%{transform:translate(-1px,1px)}
  40%{transform:translate(1px,-1px)}
  60%{transform:translate(-1px,-0.5px)}
  80%{transform:translate(1px,0.5px)}
}

@media(max-width:480px){
  .hero-actions{flex-direction:column;align-items:stretch;width:100%}
  .hero-actions .btn{justify-content:center}
}
