/* ============================================================
   SEKTIONEN: Willkommen, Marquee, Musik, Band, Story, Live,
   News, Video, Galerie, Merch, Kontakt
   ============================================================ */

/* Willkommen */
.welcome{
  min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;
}
.welcome::before{
  content:"";position:absolute;top:-5%;left:50%;
  width:70vw;height:110%;
  transform:translateX(-50%);
  background:radial-gradient(ellipse 50% 60% at 50% 0%, rgba(180,120,200,.16), transparent 70%);
  pointer-events:none;
  animation:lampPulse 7s ease-in-out infinite;
}
@keyframes lampPulse{
  0%,100%{opacity:.85;transform:translateX(-50%) scaleX(1)}
  50%{opacity:1.1;transform:translateX(-50%) scaleX(1.07)}
}
.welcome h1{
  font-family:var(--display);
  font-size:clamp(3rem,11vw,9.5rem);
  text-transform:uppercase;line-height:.9;
}
.welcome__inner{
  display:flex;flex-direction:column;align-items:center;
  will-change:transform;
}
.welcome h1 .big{display:block;filter:drop-shadow(5px 5px 0 rgba(94,58,115,.6))}
.welcome h1 .small{
  display:block;font-size:.24em;letter-spacing:.45em;
  color:var(--grey);font-family:var(--body);font-weight:700;
  margin-bottom:.5em;
}
.welcome__sub{
  margin-top:26px;
  font-family:var(--marker);
  font-size:clamp(1.1rem,2.6vw,1.6rem);
  color:var(--purple-hot);
  transform:rotate(-2deg);
}
.welcome__loc{
  margin-top:14px;
  font-family:var(--display);
  font-size:.8rem;letter-spacing:.28em;text-transform:uppercase;color:var(--grey);
}
.welcome__cta{margin-top:38px;display:flex;gap:18px;flex-wrap:wrap;justify-content:center}

/* Creaky lugt von rechts in die Hero – erscheint erst nach dem Eintreten */
.creaky-peek{
  position:absolute;right:0;top:56%;
  transform:translateX(105%);
  opacity:0;
  transition:transform 1s cubic-bezier(.2,1.4,.4,1) .9s, opacity .4s ease .9s;
  pointer-events:none;
}
body.entered .creaky-peek{transform:translateX(38%) rotate(-14deg);opacity:1}
.creaky-peek__head{
  width:clamp(90px,12vw,160px);
  aspect-ratio:1;
  background:#fdfdfb;
  border:6px solid #0c0b0d;
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;gap:27%;
  box-shadow:0 10px 30px rgba(0,0,0,.45);
  animation:creakyBob 5.5s ease-in-out infinite;
}
@keyframes creakyBob{0%,100%{translate:0 0}50%{translate:0 -7px}}
.creaky-peek__eye{
  width:17%;height:26%;
  background:#0c0b0d;border-radius:50%;
  margin-left:-8%;
  animation:creakyBlink 4.6s infinite;
  transform-origin:center;
}
.creaky-peek__eye--r{animation-delay:.05s}
@keyframes creakyBlink{
  0%,91%,100%{transform:scaleY(1)}
  93%,95%{transform:scaleY(.06)}
  97%{transform:scaleY(1)}
}

/* Marquee */
.marquee{
  background:var(--purple);color:var(--black);
  overflow:hidden;padding:12px 0;
  transform:rotate(-1.2deg) scale(1.02);
  border-top:3px solid var(--black);border-bottom:3px solid var(--black);
  position:relative;z-index:3;
}
.marquee__track{display:flex;width:max-content;animation:scrollM 22s linear infinite}
.marquee__track span{
  font-family:var(--display);
  font-size:1.3rem;letter-spacing:.1em;text-transform:uppercase;
  white-space:nowrap;padding:0 24px;
}
@keyframes scrollM{to{transform:translateX(-50%)}}

/* Anlage */
.amp{
  max-width:780px;margin:0 auto;
  background:linear-gradient(to bottom,#26212b,#141018);
  border:3px solid #050406;border-radius:14px;
  padding:22px 22px 26px;
  box-shadow:0 24px 60px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.07);
  transform:rotate(-.5deg);
}
.amp__top{display:flex;align-items:center;justify-content:space-between;padding:0 4px 16px}
.amp__brand{font-family:var(--display);font-size:.8rem;letter-spacing:.3em;text-transform:uppercase;color:var(--grey)}
.amp__knobs{display:flex;gap:14px;align-items:center}
.amp__knobs .knob{
  width:22px;height:22px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#8a8290,#2a242e);
  box-shadow:0 2px 5px rgba(0,0,0,.6);
  position:relative;
}
.amp__knobs .knob::after{
  content:"";position:absolute;top:2px;left:50%;
  width:2px;height:7px;background:var(--purple-hot);
  transform:translateX(-50%);transform-origin:bottom;
}
.amp__led{
  width:10px;height:10px;border-radius:50%;
  background:var(--purple-hot);
  box-shadow:0 0 12px var(--purple-hot);
  animation:blink 2.2s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
.amp__grille{
  border:2px solid #000;border-radius:10px;
  background:repeating-linear-gradient(45deg, rgba(255,255,255,.03) 0 2px, transparent 2px 7px),#0b090d;
  padding:14px;
}
.amp__grille iframe{width:100%;height:352px;border:0;border-radius:10px;display:block}
/* Zwei-Klick-Lösung: Spotify lädt erst nach Einwilligung */
.consent{
  min-height:352px;border-radius:10px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  text-align:center;padding:30px 24px;
  background:repeating-linear-gradient(45deg,#1c1722 0 14px,#15111b 14px 28px);
}
.consent p{font-family:var(--marker);font-size:1.2rem;color:var(--purple-hot)}
.consent__btn{
  cursor:pointer;border:0;
  font-family:var(--display);
  font-size:1rem;letter-spacing:.12em;text-transform:uppercase;
  background:var(--purple);color:var(--black);
  padding:14px 28px;
  box-shadow:4px 4px 0 var(--purple-deep);
  transition:transform .15s,box-shadow .15s,background .15s;
}
.consent__btn:hover{background:var(--purple-hot);transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--purple-deep)}
.consent small{color:var(--grey);font-size:.74rem;max-width:420px;line-height:1.5}
.consent small a{color:var(--purple-hot)}
/* Honigtopf-Feld: unsichtbar für Menschen, sichtbar für Spam-Bots */
.hp-field{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0}
.music__hint{text-align:center;color:var(--grey);font-size:.85rem;margin-top:24px;font-family:var(--marker)}

/* Polaroids (gepinnt einfliegend) – Reihe 1: die vier festen Mitglieder,
   Reihe 2: "Du?" und Creaky, mittig zentriert */
.band__grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:56px 34px;
  max-width:1280px;margin:0 auto;
}
.band__grid .polaroid:nth-child(5){grid-column:2}
.band__grid .polaroid:nth-child(6){grid-column:3}
@media(max-width:940px){
  .band__grid{grid-template-columns:repeat(2,1fr);max-width:640px}
  .band__grid .polaroid:nth-child(5),
  .band__grid .polaroid:nth-child(6){grid-column:auto}
}
@media(max-width:560px){.band__grid{grid-template-columns:1fr;max-width:340px}}
.polaroid{
  background:var(--paper);color:#1a1a1a;
  padding:14px 14px 18px;
  position:relative;
  box-shadow:0 14px 34px rgba(0,0,0,.55);
  transition:box-shadow .25s;
  will-change:transform;
}
.polaroid:hover{box-shadow:0 22px 50px rgba(0,0,0,.7);z-index:5}
.polaroid::before{
  content:"";position:absolute;top:-14px;left:50%;z-index:2; /* liegt ÜBER dem Foto */
  width:110px;height:30px;
  transform:translateX(-50%) rotate(-4deg);
  background:rgba(207,142,230,.45);
  border-left:1px dashed rgba(0,0,0,.15);
  border-right:1px dashed rgba(0,0,0,.15);
}
.polaroid__img{aspect-ratio:1/1.05;overflow:hidden;background:#222}
.polaroid__img img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(1) contrast(1.15);
  transition:filter .3s;
}
.polaroid:hover .polaroid__img img{filter:grayscale(0) contrast(1.05)}
.polaroid__ph{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  background:repeating-linear-gradient(45deg,#1c1722 0 14px,#15111b 14px 28px);
  color:var(--purple-hot);font-family:var(--marker);font-size:5rem;
}
.polaroid__ph img{height:88%;width:auto}
.polaroid__name{font-family:var(--marker);font-size:1.9rem;margin-top:12px;line-height:1}
.polaroid__role{
  font-family:var(--display);
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--purple-deep);margin-top:4px;
}
.polaroid__bio{font-size:.86rem;line-height:1.5;margin-top:10px;color:#3a3a3a}

/* Story */
.story__wrap{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);
  gap:70px;align-items:start;
}
@media(max-width:920px){.story__wrap{grid-template-columns:1fr}}
.story__text p{margin-bottom:1.25em;color:#d6d3cd;font-size:1.05rem}
.story__text .hl{
  background-image:linear-gradient(var(--purple),var(--purple));
  background-repeat:no-repeat;background-size:0% 100%;
  color:var(--white);
  padding:0 .25em;font-weight:700;
  box-decoration-break:clone;-webkit-box-decoration-break:clone;
  transition:color .2s;
}
.story__text .hl.on{color:var(--black)}
.tape{
  position:sticky;top:110px;
  background:linear-gradient(to bottom,#262129,#17131b);
  border:3px solid #050406;
  box-shadow:0 18px 44px rgba(0,0,0,.65), inset 0 1px 0 rgba(255,255,255,.08);
  padding:26px 24px 22px;
  transform:rotate(1.4deg);
}
.tape__label{
  background:var(--paper);color:#1a1a1a;
  font-family:var(--marker);font-size:1.05rem;
  padding:10px 14px;transform:rotate(-1deg);
  margin-bottom:18px;
  box-shadow:0 2px 8px rgba(0,0,0,.4);
}
.tape__label small{display:block;font-family:var(--body);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:#666;margin-top:2px}
.tape__window{
  background:#0a080c;border:2px solid #000;border-radius:8px;
  display:flex;align-items:center;justify-content:space-around;
  padding:18px 12px;margin-bottom:18px;
}
.reel{
  width:54px;height:54px;border-radius:50%;
  border:4px solid #3a3340;
  background:radial-gradient(circle,#1d1822 30%,#0a080c 31%);
  position:relative;
}
.reel::before{
  content:"";position:absolute;inset:18px;border-radius:50%;
  background:conic-gradient(var(--purple) 0 30deg,#241d2a 30deg 120deg,var(--purple) 120deg 150deg,#241d2a 150deg 240deg,var(--purple) 240deg 270deg,#241d2a 270deg 360deg);
}
.tape.playing .reel::before{animation:spin 1.1s linear infinite}
.tape.playing .reel--r::before{animation-duration:.8s}
@keyframes spin{to{transform:rotate(360deg)}}
.tape__band{flex:1;height:4px;margin:0 8px;background:repeating-linear-gradient(90deg,#3a3340 0 6px,#241d2a 6px 12px)}
.tape__btn{
  width:100%;cursor:pointer;
  font-family:var(--display);
  font-size:.95rem;letter-spacing:.14em;text-transform:uppercase;
  background:var(--purple);color:var(--black);
  border:0;padding:14px;
  box-shadow:0 4px 0 var(--purple-deep);
  transition:transform .1s,box-shadow .1s;
}
.tape__btn:hover{background:var(--purple-hot)}
.tape__btn:active{transform:translateY(3px);box-shadow:0 1px 0 var(--purple-deep)}
.tape__note{font-size:.72rem;color:var(--grey);margin-top:12px;line-height:1.5}

/* Tourplakat */
.poster{
  max-width:680px;margin:0 auto;
  background:var(--black);
  border:3px solid var(--white);
  box-shadow:14px 14px 0 var(--purple-deep), 0 24px 60px rgba(0,0,0,.65);
  padding:48px 38px 30px;
  position:relative;
  will-change:transform;
}
.poster::before,.poster::after{
  content:"";position:absolute;top:-16px;
  width:96px;height:30px;
  background:rgba(207,142,230,.45);
  border-left:1px dashed rgba(0,0,0,.2);
  border-right:1px dashed rgba(0,0,0,.2);
}
.poster::before{left:-26px;transform:rotate(-38deg)}
.poster::after{right:-26px;transform:rotate(38deg)}
.poster__kicker{
  text-align:center;font-family:var(--display);
  font-size:.72rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--grey);margin-bottom:10px;
}
.poster h3{
  text-align:center;font-family:var(--display);
  font-size:clamp(2.8rem,8vw,5rem);
  text-transform:uppercase;line-height:.9;margin-bottom:8px;
}
.poster h3 .out{-webkit-text-stroke:2px var(--purple-hot);color:transparent}
.poster__sub{
  text-align:center;font-family:var(--marker);color:var(--purple-hot);
  font-size:1.05rem;transform:rotate(-1.5deg);margin-bottom:30px;
}
.gig{
  display:grid;grid-template-columns:110px 1fr auto;
  gap:8px 22px;align-items:center;
  padding:16px 4px;
  border-bottom:2px dashed var(--line);
  font-family:var(--display);text-transform:uppercase;
  letter-spacing:.04em;font-size:1.15rem;
}
.gig .date{color:var(--purple-hot)}
.gig .venue small{
  display:block;font-family:var(--body);font-weight:500;text-transform:none;letter-spacing:0;
  font-size:.78rem;color:var(--grey);
}
.gig--ghost{color:rgba(244,242,238,.32)}
.gig--ghost .date{color:rgba(207,142,230,.4)}
@media(max-width:640px){.gig{grid-template-columns:1fr;gap:4px}}
.poster__cta{text-align:center;padding:28px 0 10px}
.poster__foot{
  text-align:center;font-family:var(--display);
  font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--grey);
  border-top:2px solid var(--line);padding-top:16px;margin-top:10px;
}

/* News-Flyer */
.news{background:var(--wall);border-top:3px solid #050406;border-bottom:3px solid #050406}
.news__grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:40px;
  grid-auto-rows:1fr; /* alle Flyer gleich hoch – auch in der zweiten Reihe */
}
.flyer{
  border:3px solid var(--white);
  padding:30px 26px 34px;
  background:var(--black);
  position:relative;
  will-change:transform;
  display:flex;flex-direction:column;align-items:flex-start;
}
.flyer::before{
  content:"";position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  width:20px;height:20px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,var(--purple-hot),var(--purple-deep) 70%);
  box-shadow:0 3px 6px rgba(0,0,0,.6);
}
.flyer__date{
  display:inline-block;font-family:var(--display);
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  background:var(--purple);color:var(--black);
  padding:5px 12px;transform:rotate(-2deg);margin-bottom:16px;
}
.flyer h3{font-family:var(--body);font-weight:700;font-size:1.22rem;line-height:1.3;margin-bottom:10px}
.flyer p{font-size:.93rem;color:#c9c6c0}
.flyer__link{
  margin-top:auto;padding-top:16px; /* sitzt immer unten im Flyer */
  font-family:var(--display);
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--purple-hot);text-decoration:none;
  border-bottom:2px solid var(--purple-deep);
  transition:color .15s,border-color .15s;
}
.flyer__link:hover{color:var(--white);border-color:var(--purple-hot)}

/* TV */
.tv{max-width:900px;margin:0 auto;will-change:transform}
.tv__body{
  background:linear-gradient(to bottom,#2b2530,#16121a);
  border:3px solid #050406;border-radius:22px;
  padding:26px 26px 18px;
  box-shadow:0 24px 60px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.07);
}
.tv__screen{
  position:relative;aspect-ratio:16/9;
  background:#000;border-radius:10px;overflow:hidden;
  border:3px solid #000;
  box-shadow:inset 0 0 40px rgba(0,0,0,.9);
}
.tv__screen iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
/* Vorschaubild + Play-Button: Klick öffnet das Video auf YouTube */
.tv__link{position:absolute;inset:0;display:block}
.tv__link img{width:100%;height:100%;object-fit:cover;transition:transform .3s,filter .3s;filter:saturate(.85)}
.tv__link:hover img{transform:scale(1.03);filter:saturate(1.05)}
.tv__play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:78px;height:78px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:rgba(20,19,22,.78);border:3px solid var(--purple-hot);
  color:var(--purple-hot);font-size:1.7rem;padding-left:7px;
  box-shadow:0 0 24px rgba(207,142,230,.35);
  transition:transform .2s,background .2s,color .2s;
}
.tv__link:hover .tv__play{
  transform:translate(-50%,-50%) scale(1.12);
  background:var(--purple);color:var(--black);
}
.tv__on{
  position:absolute;inset:0;background:#000;z-index:3;
  transform-origin:center;will-change:transform;
}
.tv__screen::after{
  content:"";position:absolute;inset:0;pointer-events:none;z-index:4;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,.03) 0 1px,transparent 1px 3px);
  border-radius:8px;
}
.tv__panel{display:flex;align-items:center;justify-content:space-between;padding:14px 6px 0}
.tv__knobs{display:flex;gap:12px}
.tv__knobs span{
  width:16px;height:16px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#7a727f,#2a242e);
  box-shadow:0 2px 4px rgba(0,0,0,.6);
}
.tv__brand{font-family:var(--display);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--grey)}
.tv__onair{
  font-family:var(--display);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--purple-hot);display:flex;align-items:center;gap:7px;
}
.tv__onair::before{
  content:"";width:9px;height:9px;border-radius:50%;
  background:var(--purple-hot);
  box-shadow:0 0 10px var(--purple-hot);
  animation:blink 1.6s ease-in-out infinite;
}
.tv__legs{display:flex;justify-content:space-between;padding:0 60px}
.tv__legs span{width:18px;height:34px;background:linear-gradient(to bottom,#1c171f,#0a080c);border-radius:0 0 5px 5px}
.video__hint{text-align:center;color:var(--grey);font-size:.85rem;margin-top:26px;font-family:var(--marker)}

/* Galerie: horizontale Fotowand */
.gallery{padding-left:0;padding-right:0}
.gallery .sec-head{padding:0 max(6vw, calc((100% - 1360px) / 2))}
.gallery__track{
  display:flex;gap:40px;
  padding:30px max(6vw, calc((100% - 1360px) / 2)) 60px;
  width:max-content;
  will-change:transform;
}
.frame{
  flex:0 0 auto;width:min(320px,72vw);
  background:var(--paper);
  padding:10px 10px 34px;
  box-shadow:0 12px 30px rgba(0,0,0,.55);
  position:relative;
  transition:box-shadow .25s;
}
.frame:nth-child(odd){transform:rotate(-2deg)}
.frame:nth-child(even){transform:rotate(1.6deg) translateY(12px)}
.frame::before{
  content:"";position:absolute;top:-10px;left:50%;transform:translateX(-50%);
  width:18px;height:18px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,var(--purple-hot),var(--purple-deep));
  box-shadow:0 2px 5px rgba(0,0,0,.5);
}
.frame img{aspect-ratio:4/3;object-fit:cover;width:100%}
.frame__ph{
  aspect-ratio:4/3;
  background:repeating-linear-gradient(45deg,#1c1722 0 14px,#15111b 14px 28px);
  display:flex;align-items:center;justify-content:center;
  color:var(--grey);font-family:var(--marker);
  font-size:1rem;text-align:center;padding:14px;
}
.frame__cap{
  position:absolute;left:14px;right:14px;bottom:8px;
  font-family:var(--marker);font-size:.92rem;color:#3a3a3a;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.gallery__hint{padding:0 max(6vw, calc((100% - 1360px) / 2));color:var(--grey);font-size:.85rem;font-family:var(--marker)}

/* Kühlschrank */
.merch__wrap{
  display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);
  gap:70px;align-items:center;
}
@media(max-width:920px){.merch__wrap{grid-template-columns:1fr;justify-items:center}}
.fridge{
  width:min(100%,340px);
  background:linear-gradient(105deg,#e9e6e1,#cfccc7 60%,#bfbcb7);
  border:3px solid #050406;border-radius:18px;
  padding:22px 20px;position:relative;
  box-shadow:0 24px 60px rgba(0,0,0,.65), inset -8px 0 18px rgba(0,0,0,.12);
  will-change:transform;
}
.fridge::before{
  content:"";position:absolute;right:-12px;top:14%;
  width:10px;height:120px;border-radius:6px;
  background:linear-gradient(to right,#a9a6a1,#6d6a66);
  box-shadow:2px 3px 6px rgba(0,0,0,.4);
}
.fridge::after{content:"";position:absolute;left:0;right:0;top:30%;height:3px;background:rgba(0,0,0,.25)}
.magnet{position:absolute;border-radius:50%;box-shadow:0 2px 5px rgba(0,0,0,.4)}
.magnet--1{width:22px;height:22px;background:var(--purple);top:18px;right:34px}
.magnet--2{width:16px;height:16px;background:#1a1a1a;top:48px;left:26px}
.magnet--3{width:18px;height:18px;background:var(--purple-deep);bottom:30px;right:48px}
.fridge__photo{
  display:block;background:#fff;padding:8px 8px 10px;
  transform:rotate(2.4deg);
  box-shadow:0 8px 22px rgba(0,0,0,.35);
  margin:14% auto 18px;width:86%;
  position:relative;transition:transform .2s;
}
.fridge__photo:hover{transform:rotate(0) scale(1.03)}
.fridge__photo::before{
  content:"";position:absolute;top:-9px;left:50%;transform:translateX(-50%);
  width:20px;height:20px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,var(--purple-hot),var(--purple-deep));
  box-shadow:0 2px 5px rgba(0,0,0,.4);z-index:2;
}
.fridge__note{
  background:#fdf6b2;color:#1a1a1a;
  font-family:var(--marker);font-size:1rem;line-height:1.3;
  padding:14px 16px;transform:rotate(-2deg);
  width:78%;margin:0 auto;
  box-shadow:0 6px 16px rgba(0,0,0,.3);
  animation:swayNote 5.5s ease-in-out infinite alternate;
}
@keyframes swayNote{from{rotate:-2.6deg}to{rotate:-1.2deg}}
.merch__text p{color:#d6d3cd;margin:18px 0 32px;font-size:1.05rem}
.merch__text .scribble{
  font-family:var(--marker);color:var(--purple-hot);
  font-size:1.2rem;display:block;transform:rotate(-2deg);
}

/* Kontakt */
.contact{background:var(--wall);border-top:3px solid #050406}
.contact__wrap{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);gap:70px;align-items:start}
@media(max-width:920px){.contact__wrap{grid-template-columns:1fr}}
.contact__intro p{color:#d6d3cd;margin-bottom:30px;font-size:1.05rem}
.socials{display:flex;flex-wrap:wrap;gap:14px}
.socials a{
  font-family:var(--display);
  font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;
  text-decoration:none;border:2px solid var(--white);
  padding:12px 20px;background:var(--black);
  transition:all .15s;
}
.socials a:nth-child(odd){transform:rotate(-1.5deg)}
.socials a:nth-child(even){transform:rotate(1.5deg)}
.socials a:hover{background:var(--purple);color:var(--black);border-color:var(--purple);transform:rotate(0) scale(1.06)}
.newsletter{
  margin-top:36px;border:2px dashed var(--purple);
  padding:22px 20px;background:rgba(180,120,200,.06);
  transform:rotate(-.6deg);
}
.newsletter h3{font-family:var(--marker);font-size:1.25rem;color:var(--purple-hot);margin-bottom:6px}
.newsletter p{font-size:.88rem;color:#c9c6c0;margin-bottom:16px}
.newsletter__row{display:flex;gap:10px;flex-wrap:wrap}
.newsletter input{
  flex:1;min-width:180px;
  background:var(--black);border:2px solid var(--white);color:var(--white);
  font-family:var(--body);font-size:.95rem;padding:12px 14px;
}
.newsletter input:focus{outline:none;border-color:var(--purple)}
.newsletter button{
  cursor:pointer;border:0;
  font-family:var(--display);
  font-size:.9rem;letter-spacing:.1em;text-transform:uppercase;
  background:var(--purple);color:var(--black);
  padding:12px 22px;
  box-shadow:4px 4px 0 var(--purple-deep);
  transition:transform .15s,box-shadow .15s;
}
.newsletter button:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--purple-deep)}
.clipboard{
  background:linear-gradient(to bottom,#4a3a2e,#2e2219);
  border-radius:10px;
  padding:54px 22px 22px;position:relative;
  box-shadow:0 22px 54px rgba(0,0,0,.6);
  transform:rotate(.8deg);
}
.clipboard::before{
  content:"";position:absolute;top:14px;left:50%;transform:translateX(-50%);
  width:120px;height:26px;border-radius:8px;
  background:linear-gradient(to bottom,#b8b2bc,#5d5762);
  box-shadow:0 3px 7px rgba(0,0,0,.5);
}
.clipboard__paper{background:var(--paper);color:#1a1a1a;padding:30px 26px;box-shadow:0 4px 14px rgba(0,0,0,.35)}
.clipboard__paper h3{font-family:var(--marker);font-size:1.5rem;margin-bottom:20px;transform:rotate(-1deg)}
.form{display:grid;gap:18px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:560px){.form__row{grid-template-columns:1fr}}
.form label{
  display:block;font-family:var(--display);
  font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;
  color:#6b6b6b;margin-bottom:6px;
}
.form input,.form textarea{
  width:100%;background:transparent;
  border:none;border-bottom:2px solid #1a1a1a;
  color:#1a1a1a;font-family:var(--marker);font-size:1.05rem;
  padding:8px 2px;transition:border-color .2s;
}
.form input:focus,.form textarea:focus{outline:none;border-bottom-color:var(--purple-deep)}
.form textarea{min-height:120px;resize:vertical;border:2px solid #1a1a1a;padding:12px}
.form__consent{display:flex;gap:10px;align-items:flex-start;font-size:.82rem;color:#444}
.form__consent input{width:auto;margin-top:4px;accent-color:var(--purple-deep)}
.form button{justify-self:start}

/* Sende-Status unter Kontaktformular & Album-Alarm */
.form__status{
  font-family:var(--marker);font-size:.95rem;
  color:var(--purple-hot);margin-top:10px;
}
.form__status--error{color:#e05c5c}
.clipboard .form__status{color:var(--purple-deep)}
.clipboard .form__status--error{color:#a33}

/* Offene Tür mit Creaki – genutzt auf der 404-Seite */
.outro__door{
  width:min(760px,92%);
  margin:0 auto;
  filter:drop-shadow(0 0 34px rgba(180,120,200,.18));
}
.outro__text{
  font-family:var(--marker);
  font-size:clamp(1.1rem,2.6vw,1.5rem);
  color:var(--purple-hot);
  transform:rotate(-1.5deg);
  margin-top:6px;
}
