/* ============================================================
   LU4 Events Wittenberg · lu4events.de
   Lokale Fonts (DSGVO) · Palette: Aubergine / Gold / Rosé / Violett
   ============================================================ */

/* ---------- Lokale Variable Fonts (OFL-Lizenz, siehe /assets/fonts/) ---------- */
@font-face{
  font-family:'Fraunces';
  src:url('../fonts/Fraunces-Variable.woff2') format('woff2');
  font-weight:100 900;font-style:normal;font-display:swap;
}
@font-face{
  font-family:'Fraunces';
  src:url('../fonts/Fraunces-Italic-Variable.woff2') format('woff2');
  font-weight:100 900;font-style:italic;font-display:swap;
}
@font-face{
  font-family:'Outfit';
  src:url('../fonts/Outfit-Variable.woff2') format('woff2');
  font-weight:100 900;font-style:normal;font-display:swap;
}

/* ---------- Tokens ---------- */
:root{
  --ev-ink:        #131019;
  --ev-ink-soft:   #1C1726;
  --ev-ivory:      #F6F1E7;
  --ev-ivory-dim:  rgba(246,241,231,.66);
  --ev-gold:       #D9B26A;
  --ev-rose:       #D4838F;
  --ev-violet:     #8B6FC9;
  --ev-grad:       linear-gradient(100deg,#D9B26A 0%,#D4838F 48%,#8B6FC9 100%);
  --ev-font-display:'Fraunces',Georgia,serif;
  --ev-font-body:  'Outfit',system-ui,sans-serif;
  --ev-max:        1180px;
  --ev-radius:     22px;
  --ev-ease:       cubic-bezier(.22,.8,.24,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--ev-font-body);
  background:var(--ev-ink);
  color:var(--ev-ivory);
  line-height:1.6;font-weight:300;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
.ev-wrap{max-width:var(--ev-max);margin:0 auto;padding:0 24px}

/* ---------- Barrierefreiheit: Skip-Link & Fokus ---------- */
.ev-skip{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--ev-gold);color:#181220;padding:12px 22px;border-radius:0 0 12px 0;
  font-weight:600;
}
.ev-skip:focus{left:0}
:focus-visible{outline:2px solid var(--ev-gold);outline-offset:3px;border-radius:4px}
.ev-visually-hidden{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;
}

/* ---------- Eyebrow & Gradient-Text ---------- */
.ev-eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-size:.78rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ev-gold);font-weight:500;
}
.ev-eyebrow::before{content:"";width:34px;height:1px;background:var(--ev-grad)}
.ev-grad-text{
  background:var(--ev-grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.ev-italic{font-style:italic}

/* ============================================================
   HEADER / NAVIGATION
   ============================================================ */
.ev-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(19,16,25,.72);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(246,241,231,.08);
}
.ev-header-inner{
  max-width:var(--ev-max);margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;
  height:74px;
}
.ev-brand img{height:42px;width:auto}
.ev-nav{display:flex;align-items:center;gap:30px}
.ev-nav a{
  font-size:.92rem;letter-spacing:.06em;color:var(--ev-ivory-dim);
  padding:6px 2px;position:relative;transition:color .3s ease;
}
.ev-nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--ev-grad);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ev-ease);
}
.ev-nav a:hover,.ev-nav a[aria-current="page"]{color:var(--ev-ivory)}
.ev-nav a:hover::after,.ev-nav a[aria-current="page"]::after{transform:scaleX(1)}
.ev-nav .ev-nav-cta{
  border:1px solid rgba(217,178,106,.55);border-radius:999px;
  padding:9px 22px;color:var(--ev-gold);
}
.ev-nav .ev-nav-cta::after{display:none}
.ev-nav .ev-nav-cta:hover{background:var(--ev-gold);color:#181220}
/* Burger */
.ev-burger{
  display:none;background:none;border:0;cursor:pointer;padding:10px;
  width:46px;height:46px;flex-direction:column;justify-content:center;gap:6px;
}
.ev-burger span{display:block;width:24px;height:2px;background:var(--ev-ivory);transition:transform .3s var(--ev-ease),opacity .3s}
.ev-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.ev-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.ev-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
@media (max-width:880px){
  .ev-burger{display:flex}
  .ev-nav{
    position:fixed;top:74px;left:0;right:0;
    flex-direction:column;align-items:flex-start;gap:4px;
    background:rgba(19,16,25,.97);border-bottom:1px solid rgba(246,241,231,.1);
    padding:18px 24px 26px;
    transform:translateY(-130%);transition:transform .4s var(--ev-ease);
    visibility:hidden;
  }
  .ev-nav.is-open{transform:translateY(0);visibility:visible}
  .ev-nav a{font-size:1.05rem;padding:10px 0;width:100%}
  .ev-nav .ev-nav-cta{margin-top:10px;text-align:center}
}

/* ============================================================
   HERO (Startseite, Slider + Aurora)
   ============================================================ */
.ev-hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
  overflow:hidden;isolation:isolate;
  padding-top:74px;
}
.ev-hero-slides{position:absolute;inset:0;z-index:-3}
.ev-hero-slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  opacity:0;transition:opacity 1.4s ease;
  transform:scale(1.06);
  animation:ev-kenburns 9s ease-out forwards paused;
}
.ev-hero-slide.s1{background-image:url('https://images.unsplash.com/photo-1677768062274-fdd45caac233?auto=format&fit=crop&w=1800&h=1200&q=75')}
.ev-hero-slide.s2{background-image:url('https://images.unsplash.com/photo-1572116469696-31de0f17cc34?auto=format&fit=crop&w=1800&h=1200&q=75')}
.ev-hero-slide.s3{background-image:url('https://images.unsplash.com/photo-1593443821262-5625fcd78f49?auto=format&fit=crop&w=1800&h=1200&q=75')}
.ev-hero-slide.s4{background-image:url('https://images.unsplash.com/photo-1492684223066-81342ee5ff30?auto=format&fit=crop&w=1800&h=1200&q=75')}
.ev-hero-slide.is-active{opacity:1;animation-play-state:running}
@keyframes ev-kenburns{from{transform:scale(1.14)}to{transform:scale(1.0)}}
.ev-hero-dots{
  position:absolute;z-index:4;bottom:38px;
  left:max(24px,calc((100% - var(--ev-max))/2 + 24px));
  display:flex;gap:10px;
  opacity:0;animation:ev-fade 1s 1.4s forwards;
}
.ev-hero-dots button{
  width:36px;height:14px;border:0;padding:5px 0;cursor:pointer;background:transparent;
}
.ev-hero-dots button::before{
  content:"";display:block;height:4px;border-radius:4px;
  background:rgba(246,241,231,.3);transition:background .3s ease;
}
.ev-hero-dots button.is-active::before{background:var(--ev-gold)}
.ev-aurora{position:absolute;inset:-20%;z-index:-2;filter:blur(90px);opacity:.42;pointer-events:none}
.ev-aurora span{position:absolute;border-radius:50%;mix-blend-mode:screen}
.ev-aurora span:nth-child(1){width:55vw;height:55vw;left:-12%;top:-8%;background:radial-gradient(circle,#8B6FC9 0%,transparent 65%);animation:ev-float1 22s var(--ev-ease) infinite alternate}
.ev-aurora span:nth-child(2){width:48vw;height:48vw;right:-10%;top:18%;background:radial-gradient(circle,#D4838F 0%,transparent 65%);animation:ev-float2 26s var(--ev-ease) infinite alternate}
.ev-aurora span:nth-child(3){width:42vw;height:42vw;left:28%;bottom:-22%;background:radial-gradient(circle,#D9B26A 0%,transparent 65%);animation:ev-float3 30s var(--ev-ease) infinite alternate}
@keyframes ev-float1{from{transform:translate(0,0) scale(1)}to{transform:translate(9vw,7vh) scale(1.18)}}
@keyframes ev-float2{from{transform:translate(0,0) scale(1.1)}to{transform:translate(-8vw,-6vh) scale(.92)}}
@keyframes ev-float3{from{transform:translate(0,0) scale(.95)}to{transform:translate(6vw,-9vh) scale(1.2)}}
.ev-hero::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    linear-gradient(105deg,rgba(19,16,25,.92) 0%,rgba(19,16,25,.66) 48%,rgba(19,16,25,.38) 100%),
    radial-gradient(ellipse at 50% 120%,rgba(19,16,25,0) 0%,rgba(19,16,25,.85) 75%),
    repeating-linear-gradient(0deg,rgba(255,255,255,.012) 0 1px,transparent 1px 3px);
}
.ev-hero-inner{position:relative;padding:90px 24px 60px;max-width:var(--ev-max);margin:0 auto;width:100%}
.ev-hero .ev-eyebrow{margin-bottom:28px}
.ev-hero h1{
  font-family:var(--ev-font-display);font-weight:330;
  font-size:clamp(2.6rem,7.2vw,5.6rem);line-height:1.04;letter-spacing:-.01em;
  max-width:14ch;
}
.ev-hero h1 .ev-line{display:block;overflow:hidden}
.ev-hero h1 .ev-line > span{display:block;transform:translateY(110%);animation:ev-rise 1.1s var(--ev-ease) forwards}
.ev-hero h1 .ev-line:nth-child(2) > span{animation-delay:.15s}
.ev-hero h1 .ev-line:nth-child(3) > span{animation-delay:.3s}
@keyframes ev-rise{to{transform:translateY(0)}}
.ev-rotator{display:inline-block;position:relative;font-style:italic;font-weight:420;min-width:7.2ch}
.ev-rotator b{
  font-weight:inherit;position:absolute;left:0;top:0;white-space:nowrap;
  opacity:0;transform:translateY(.45em) rotateX(50deg);
  transition:opacity .6s var(--ev-ease),transform .6s var(--ev-ease);
  background:var(--ev-grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.ev-rotator b.is-on{opacity:1;transform:translateY(0) rotateX(0);position:relative}
.ev-hero p{
  margin-top:30px;max-width:46ch;font-size:1.08rem;color:var(--ev-ivory-dim);
  opacity:0;animation:ev-fade 1s .7s var(--ev-ease) forwards;
}
@keyframes ev-fade{to{opacity:1}}
.ev-hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:40px;opacity:0;animation:ev-fade 1s .95s var(--ev-ease) forwards}
.ev-btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 30px;border-radius:999px;font-size:.95rem;font-weight:500;letter-spacing:.04em;
  transition:transform .35s var(--ev-ease),box-shadow .35s var(--ev-ease);
  cursor:pointer;border:0;font-family:inherit;
}
.ev-btn--grad{background:var(--ev-grad);color:#181220;box-shadow:0 8px 32px rgba(212,131,143,.28)}
.ev-btn--grad:hover{transform:translateY(-3px);box-shadow:0 14px 42px rgba(212,131,143,.4)}
.ev-btn--ghost{border:1px solid rgba(246,241,231,.28);color:var(--ev-ivory);background:transparent}
.ev-btn--ghost:hover{border-color:var(--ev-gold);transform:translateY(-3px)}
.ev-scrollhint{
  position:absolute;bottom:34px;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:10px;
  font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ev-ivory-dim);
  opacity:0;animation:ev-fade 1s 1.4s forwards;
}
.ev-scrollhint::after{
  content:"";width:1px;height:52px;
  background:linear-gradient(var(--ev-gold),transparent);
  animation:ev-drip 2.2s var(--ev-ease) infinite;transform-origin:top;
}
@keyframes ev-drip{0%{transform:scaleY(0)}45%{transform:scaleY(1)}100%{transform:scaleY(0);transform-origin:bottom}}

/* ============================================================
   SUBPAGE-HERO (kompakter Kopf für Unterseiten)
   ============================================================ */
.ev-pagehero{
  position:relative;padding:170px 24px 80px;overflow:hidden;isolation:isolate;
}
.ev-pagehero::before{
  content:"";position:absolute;inset:-30% -10%;z-index:-1;filter:blur(90px);opacity:.3;pointer-events:none;
  background:
    radial-gradient(circle at 15% 20%,#8B6FC9 0%,transparent 40%),
    radial-gradient(circle at 85% 30%,#D4838F 0%,transparent 40%),
    radial-gradient(circle at 50% 110%,#D9B26A 0%,transparent 45%);
}
.ev-pagehero-inner{max-width:var(--ev-max);margin:0 auto}
.ev-pagehero h1{
  font-family:var(--ev-font-display);font-weight:330;
  font-size:clamp(2.4rem,6vw,4.2rem);line-height:1.08;margin-top:18px;max-width:18ch;
}
.ev-pagehero p{margin-top:22px;max-width:54ch;color:var(--ev-ivory-dim);font-size:1.06rem}

/* ============================================================
   MARQUEE
   ============================================================ */
.ev-marquee{
  border-top:1px solid rgba(246,241,231,.08);
  border-bottom:1px solid rgba(246,241,231,.08);
  padding:22px 0;overflow:hidden;white-space:nowrap;
  background:var(--ev-ink-soft);
}
.ev-marquee-track{display:inline-flex;gap:56px;animation:ev-scrollx 36s linear infinite;will-change:transform}
.ev-marquee span{
  font-family:var(--ev-font-display);font-style:italic;font-weight:380;
  font-size:1.35rem;color:var(--ev-ivory-dim);display:inline-flex;align-items:center;gap:56px;
}
.ev-marquee span::after{content:"✦";font-style:normal;font-size:.8rem;color:var(--ev-gold)}
@keyframes ev-scrollx{to{transform:translateX(-50%)}}

/* ============================================================
   STATEMENT – Wort-für-Wort Scroll-Reveal
   ============================================================ */
.ev-statement{padding:160px 24px}
.ev-statement-text{
  max-width:880px;margin:0 auto;
  font-family:var(--ev-font-display);font-weight:340;
  font-size:clamp(1.7rem,4.2vw,3rem);line-height:1.35;text-align:center;
}
.ev-statement-text .w{opacity:.1;transition:opacity .5s linear}
.ev-statement-text .w.is-lit{opacity:1}
.ev-statement-text em{font-style:italic}
.ev-statement-text em.w.is-lit{
  background:var(--ev-grad);-webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}

/* ============================================================
   BEREICHE
   ============================================================ */
.ev-areas{padding:40px 0 60px}
.ev-areas-head{text-align:center;margin-bottom:80px;padding:0 24px}
.ev-areas-head h2{
  font-family:var(--ev-font-display);font-weight:330;
  font-size:clamp(2.1rem,5vw,3.6rem);margin-top:18px;line-height:1.1;
}
.ev-area{
  display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center;
  max-width:var(--ev-max);margin:0 auto 130px;padding:0 24px;
}
.ev-area:nth-child(even of .ev-area){grid-template-columns:.9fr 1.1fr}
.ev-area:nth-child(even of .ev-area) .ev-area-media{order:2}
.ev-area-media{
  position:relative;border-radius:var(--ev-radius);overflow:hidden;
  aspect-ratio:4/3.1;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  isolation:isolate;transform:translateZ(0);
}
.ev-area-media::before{
  content:"";position:absolute;inset:0;z-index:1;border-radius:inherit;
  border:1px solid rgba(246,241,231,.14);pointer-events:none;
}
.ev-area-media img{width:100%;height:124%;object-fit:cover;will-change:transform;transform:translateY(0)}
.ev-area-media .ev-area-tag{
  position:absolute;z-index:2;left:18px;bottom:18px;
  padding:8px 18px;border-radius:999px;font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
  background:rgba(19,16,25,.62);backdrop-filter:blur(8px);border:1px solid rgba(246,241,231,.18);
}
.ev-area-body h2,.ev-area-body h3{
  font-family:var(--ev-font-display);font-weight:340;
  font-size:clamp(1.9rem,3.6vw,2.8rem);line-height:1.12;margin:16px 0 20px;
}
.ev-area-body p{color:var(--ev-ivory-dim);max-width:48ch}
.ev-area-facts{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;list-style:none}
.ev-area-facts li{
  font-size:.82rem;letter-spacing:.05em;padding:8px 16px;border-radius:999px;
  border:1px solid rgba(246,241,231,.16);color:var(--ev-ivory-dim);
}
.ev-area-link{
  display:inline-flex;align-items:center;gap:10px;margin-top:30px;
  font-weight:500;font-size:.95rem;letter-spacing:.04em;color:var(--ev-gold);
}
.ev-area-link svg{transition:transform .35s var(--ev-ease)}
.ev-area-link:hover svg{transform:translateX(6px)}

/* ============================================================
   ANLÄSSE
   ============================================================ */
.ev-occasions{padding:120px 24px;background:var(--ev-ink-soft);position:relative;overflow:hidden}
.ev-occasions::before{
  content:"";position:absolute;width:60vw;height:60vw;right:-25vw;top:-30vw;border-radius:50%;
  background:radial-gradient(circle,rgba(139,111,201,.16) 0%,transparent 65%);pointer-events:none;
}
.ev-occasions-head{max-width:var(--ev-max);margin:0 auto 64px}
.ev-occasions-head h2{
  font-family:var(--ev-font-display);font-weight:330;
  font-size:clamp(2.1rem,5vw,3.4rem);margin-top:18px;line-height:1.12;max-width:16ch;
}
.ev-occ-grid{
  max-width:var(--ev-max);margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
.ev-occ{
  position:relative;border-radius:var(--ev-radius);padding:34px 30px;min-height:210px;
  border:1px solid rgba(246,241,231,.1);background:rgba(246,241,231,.025);
  display:flex;flex-direction:column;justify-content:flex-end;gap:8px;
  transition:transform .45s var(--ev-ease),border-color .45s var(--ev-ease),background .45s var(--ev-ease);
  overflow:hidden;
}
.ev-occ::before{
  content:"";position:absolute;inset:0;border-radius:inherit;opacity:0;transition:opacity .45s var(--ev-ease);
  background:linear-gradient(140deg,rgba(217,178,106,.13),rgba(212,131,143,.1) 50%,rgba(139,111,201,.13));
}
.ev-occ:hover{transform:translateY(-6px);border-color:rgba(217,178,106,.4)}
.ev-occ:hover::before{opacity:1}
.ev-occ .ev-occ-ico{font-size:1.7rem;margin-bottom:auto}
.ev-occ h3{font-family:var(--ev-font-display);font-weight:400;font-size:1.45rem;position:relative}
.ev-occ p{font-size:.92rem;color:var(--ev-ivory-dim);position:relative}

/* ============================================================
   FAQ (Accordion, nativ barrierefrei via details/summary)
   ============================================================ */
.ev-faq{padding:130px 24px}
.ev-faq-head{max-width:760px;margin:0 auto 56px;text-align:center}
.ev-faq-head h2{
  font-family:var(--ev-font-display);font-weight:330;
  font-size:clamp(2.1rem,5vw,3.2rem);margin-top:18px;line-height:1.12;
}
.ev-faq-list{max-width:760px;margin:0 auto;display:grid;gap:14px}
.ev-faq-item{
  border:1px solid rgba(246,241,231,.12);border-radius:18px;
  background:rgba(246,241,231,.02);overflow:hidden;
  transition:border-color .3s ease;
}
.ev-faq-item[open]{border-color:rgba(217,178,106,.45)}
.ev-faq-item summary{
  list-style:none;cursor:pointer;padding:22px 58px 22px 26px;position:relative;
  font-family:var(--ev-font-display);font-weight:400;font-size:1.15rem;
}
.ev-faq-item summary::-webkit-details-marker{display:none}
.ev-faq-item summary::after{
  content:"+";position:absolute;right:24px;top:50%;transform:translateY(-50%);
  font-family:var(--ev-font-body);font-weight:300;font-size:1.6rem;color:var(--ev-gold);
  transition:transform .3s var(--ev-ease);
}
.ev-faq-item[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.ev-faq-item .ev-faq-a{padding:0 26px 24px;color:var(--ev-ivory-dim);max-width:62ch}

/* ============================================================
   GALERIE
   ============================================================ */
.ev-gallery{max-width:var(--ev-max);margin:0 auto;padding:20px 24px 120px}
.ev-gallery-group{margin-bottom:70px}
.ev-gallery-group h2{
  font-family:var(--ev-font-display);font-weight:340;font-size:1.9rem;margin:14px 0 26px;
}
.ev-gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ev-gallery-grid figure{
  position:relative;border-radius:18px;overflow:hidden;
  border:1px solid rgba(246,241,231,.12);
  aspect-ratio:16/11;
  transition:transform .4s var(--ev-ease),border-color .4s ease;
}
.ev-gallery-grid figure:hover{transform:translateY(-5px);border-color:rgba(217,178,106,.45)}
.ev-gallery-grid img{width:100%;height:100%;object-fit:cover}
.ev-gallery-grid figcaption{
  position:absolute;left:0;right:0;bottom:0;padding:30px 16px 12px;
  font-size:.82rem;letter-spacing:.06em;color:var(--ev-ivory);
  background:linear-gradient(transparent,rgba(19,16,25,.85));
}

/* ============================================================
   ÜBER UNS / Inhaltsblöcke
   ============================================================ */
.ev-split{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
  max-width:var(--ev-max);margin:0 auto;padding:60px 24px;
}
.ev-split-media{
  border-radius:var(--ev-radius);overflow:hidden;
  border:1px solid rgba(246,241,231,.14);
  box-shadow:0 30px 80px rgba(0,0,0,.5);
  aspect-ratio:4/3.1;
}
.ev-split-media img{width:100%;height:100%;object-fit:cover}
.ev-split-body h2{
  font-family:var(--ev-font-display);font-weight:340;
  font-size:clamp(1.9rem,3.6vw,2.7rem);line-height:1.14;margin:16px 0 20px;
}
.ev-split-body p{color:var(--ev-ivory-dim);margin-bottom:16px;max-width:52ch}
.ev-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
  max-width:var(--ev-max);margin:0 auto;padding:40px 24px 110px;
}
.ev-stat{
  border:1px solid rgba(246,241,231,.12);border-radius:var(--ev-radius);
  padding:30px;text-align:center;background:rgba(246,241,231,.02);
}
.ev-stat strong{
  display:block;font-family:var(--ev-font-display);font-weight:380;
  font-size:2.4rem;line-height:1.1;margin-bottom:8px;
}
.ev-stat span{font-size:.9rem;color:var(--ev-ivory-dim);letter-spacing:.04em}

/* ============================================================
   KONTAKT
   ============================================================ */
.ev-contact{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:start;
  max-width:var(--ev-max);margin:0 auto;padding:30px 24px 120px;
}
.ev-contact-info{display:grid;gap:18px}
.ev-info-card{
  border:1px solid rgba(246,241,231,.12);border-radius:18px;
  padding:26px;background:rgba(246,241,231,.02);
}
.ev-info-card h2,.ev-info-card h3{
  font-family:var(--ev-font-display);font-weight:400;font-size:1.25rem;margin-bottom:12px;
}
.ev-info-card p,.ev-info-card address{font-style:normal;color:var(--ev-ivory-dim);font-size:.96rem}
.ev-info-card a{color:var(--ev-gold);text-decoration:underline;text-underline-offset:3px}
.ev-info-card ul{list-style:none;color:var(--ev-ivory-dim);font-size:.96rem;display:grid;gap:6px}
.ev-info-card .ev-route-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.ev-info-card .ev-route-links a{
  text-decoration:none;font-size:.85rem;color:var(--ev-ivory);
  border:1px solid rgba(246,241,231,.2);border-radius:999px;padding:8px 16px;
  transition:border-color .3s ease;
}
.ev-info-card .ev-route-links a:hover{border-color:var(--ev-gold)}
/* Formular */
.ev-form{
  border:1px solid rgba(246,241,231,.12);border-radius:var(--ev-radius);
  padding:36px;background:rgba(246,241,231,.02);
}
.ev-form h2{
  font-family:var(--ev-font-display);font-weight:380;font-size:1.7rem;margin-bottom:8px;
}
.ev-form > p{color:var(--ev-ivory-dim);font-size:.94rem;margin-bottom:26px}
.ev-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ev-field{display:flex;flex-direction:column;gap:7px}
.ev-field--full{grid-column:1 / -1}
.ev-field label{font-size:.86rem;letter-spacing:.05em;color:var(--ev-ivory)}
.ev-field label .req{color:var(--ev-rose)}
.ev-field input,.ev-field select,.ev-field textarea{
  font-family:inherit;font-size:1rem;font-weight:300;
  color:var(--ev-ivory);background:rgba(19,16,25,.55);
  border:1px solid rgba(246,241,231,.18);border-radius:12px;
  padding:13px 16px;width:100%;
  transition:border-color .3s ease;
}
.ev-field input:focus,.ev-field select:focus,.ev-field textarea:focus{
  outline:none;border-color:var(--ev-gold);
}
.ev-field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--ev-gold) 50%),linear-gradient(135deg,var(--ev-gold) 50%,transparent 50%);background-position:calc(100% - 21px) 50%,calc(100% - 15px) 50%;background-size:6px 6px;background-repeat:no-repeat}
.ev-field select option{background:var(--ev-ink-soft);color:var(--ev-ivory)}
.ev-field textarea{min-height:140px;resize:vertical}
.ev-field .ev-hint{font-size:.78rem;color:var(--ev-ivory-dim)}
.ev-check{display:flex;align-items:flex-start;gap:12px;grid-column:1 / -1}
.ev-check input{width:20px;height:20px;margin-top:3px;accent-color:#D9B26A;flex-shrink:0}
.ev-check label{font-size:.88rem;color:var(--ev-ivory-dim)}
.ev-check a{color:var(--ev-gold);text-decoration:underline;text-underline-offset:3px}
/* Honeypot: für Menschen unsichtbar, für Bots ein Köder */
.ev-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.ev-form-status{
  display:none;margin-top:18px;padding:14px 18px;border-radius:12px;font-size:.92rem;
  border:1px solid rgba(217,178,106,.5);background:rgba(217,178,106,.08);color:var(--ev-ivory);
}
.ev-form-status.is-visible{display:block}

/* ============================================================
   RECHTSSEITEN (Impressum, Datenschutz, AGB, Barrierefreiheit)
   ============================================================ */
.ev-legal{max-width:820px;margin:0 auto;padding:20px 24px 120px}
.ev-legal h2{
  font-family:var(--ev-font-display);font-weight:380;font-size:1.6rem;
  margin:46px 0 14px;line-height:1.2;
}
.ev-legal h3{
  font-family:var(--ev-font-display);font-weight:400;font-size:1.2rem;margin:30px 0 10px;
}
.ev-legal p,.ev-legal li{color:var(--ev-ivory-dim);margin-bottom:12px;font-size:.98rem}
.ev-legal ul{padding-left:22px;margin-bottom:14px}
.ev-legal a{color:var(--ev-gold);text-decoration:underline;text-underline-offset:3px}
.ev-legal address{font-style:normal;color:var(--ev-ivory-dim);margin-bottom:12px}
.ev-placeholder{
  display:inline-block;background:rgba(212,131,143,.14);border:1px dashed rgba(212,131,143,.55);
  border-radius:6px;padding:1px 8px;color:#E8B7BE;font-size:.94em;
}
.ev-legal-note{
  border:1px solid rgba(217,178,106,.4);border-radius:14px;background:rgba(217,178,106,.06);
  padding:18px 22px;margin:26px 0;
}
.ev-legal-note p{margin:0;color:var(--ev-ivory)}

/* ============================================================
   CTA
   ============================================================ */
.ev-cta{padding:150px 24px;position:relative;overflow:hidden;text-align:center}
.ev-cta::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 70% 90% at 50% 110%,rgba(212,131,143,.22),transparent 70%),
    radial-gradient(ellipse 50% 70% at 20% 120%,rgba(217,178,106,.18),transparent 70%),
    radial-gradient(ellipse 50% 70% at 80% 120%,rgba(139,111,201,.2),transparent 70%);
}
.ev-cta-inner{position:relative;max-width:760px;margin:0 auto}
.ev-cta h2{
  font-family:var(--ev-font-display);font-weight:330;
  font-size:clamp(2.3rem,5.6vw,4rem);line-height:1.1;
}
.ev-cta p{margin:24px auto 40px;max-width:44ch;color:var(--ev-ivory-dim);font-size:1.06rem}

/* ============================================================
   FOOTER
   ============================================================ */
.ev-footer{
  border-top:1px solid rgba(246,241,231,.08);
  padding:64px 24px 0;font-size:.92rem;color:var(--ev-ivory-dim);
  background:var(--ev-ink-soft);
}
.ev-footer-grid{
  max-width:var(--ev-max);margin:0 auto;
  display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:46px;
  padding-bottom:46px;
}
.ev-footer-brand img{height:52px;width:auto;margin-bottom:18px}
.ev-footer-brand p{max-width:34ch}
.ev-footer h2{
  font-family:var(--ev-font-display);font-weight:400;font-size:1.1rem;
  color:var(--ev-ivory);margin-bottom:16px;
}
.ev-footer ul{list-style:none;display:grid;gap:9px}
.ev-footer a{transition:color .3s ease}
.ev-footer a:hover{color:var(--ev-gold)}
.ev-footer address{font-style:normal;display:grid;gap:9px}
.ev-social{display:flex;gap:12px;margin-top:18px}
.ev-social a{
  width:42px;height:42px;border-radius:50%;
  border:1px solid rgba(246,241,231,.2);
  display:inline-flex;align-items:center;justify-content:center;
  transition:border-color .3s ease,transform .3s var(--ev-ease);
}
.ev-social a:hover{border-color:var(--ev-gold);transform:translateY(-3px)}
.ev-social svg{width:18px;height:18px;fill:var(--ev-ivory-dim)}
.ev-footer-bottom{
  border-top:1px solid rgba(246,241,231,.08);
  padding:22px 0;font-size:.84rem;
}
.ev-footer-bottom .ev-wrap{
  display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:0;
}
.ev-footer-bottom nav{display:flex;gap:22px;flex-wrap:wrap}

/* ============================================================
   COOKIE-/INFO-BANNER
   ============================================================ */
.ev-cookie{
  position:fixed;left:16px;right:16px;bottom:16px;z-index:150;
  max-width:680px;margin:0 auto;
  background:rgba(28,23,38,.97);border:1px solid rgba(217,178,106,.4);
  border-radius:18px;padding:22px 26px;
  box-shadow:0 24px 70px rgba(0,0,0,.55);
  display:none;
}
.ev-cookie.is-visible{display:block}
.ev-cookie h2{
  font-family:var(--ev-font-display);font-weight:400;font-size:1.15rem;margin-bottom:8px;
}
.ev-cookie p{font-size:.9rem;color:var(--ev-ivory-dim);margin-bottom:16px}
.ev-cookie p a{color:var(--ev-gold);text-decoration:underline;text-underline-offset:3px}
.ev-cookie-actions{display:flex;gap:12px;flex-wrap:wrap}
.ev-cookie .ev-btn{padding:11px 24px;font-size:.88rem}

/* ============================================================
   tvOS-PARALLAX-TILT (nur Anlass-Karten)
   ============================================================ */
.ev-tilt{will-change:transform}
.ev-tilt.is-in{transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s ease}
.ev-tilt .ev-shine{
  position:absolute;inset:0;z-index:5;pointer-events:none;
  border-radius:inherit;opacity:0;transition:opacity .3s ease;
  background:
    radial-gradient(140px 140px at var(--mx,50%) var(--my,50%),
      rgba(255,236,200,.5),rgba(255,236,200,.1) 40%,rgba(255,236,200,0) 70%),
    linear-gradient(calc(var(--ang,120) * 1deg),
      rgba(255,255,255,0) 38%,
      rgba(217,178,106,.22) 48%,
      rgba(246,241,231,.4) 50%,
      rgba(212,131,143,.22) 52%,
      rgba(255,255,255,0) 62%);
  mix-blend-mode:soft-light;
}
.ev-tilt.is-tilting .ev-shine{opacity:1}
.ev-occ.ev-tilt{position:relative}
@media (hover:none){
  .ev-tilt .ev-shine{display:none}
}

/* ---------- Scroll-Reveal ---------- */
.ev-reveal{opacity:0;transform:translateY(36px);transition:opacity .9s var(--ev-ease),transform .9s var(--ev-ease)}
.ev-reveal.is-in{opacity:1;transform:none}
.ev-reveal[data-delay="1"]{transition-delay:.12s}
.ev-reveal[data-delay="2"]{transition-delay:.24s}
.ev-reveal[data-delay="3"]{transition-delay:.36s}

/* ---------- 404 ---------- */
.ev-404{
  min-height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:120px 24px;position:relative;overflow:hidden;
}
.ev-404 .ev-code{
  font-family:var(--ev-font-display);font-weight:330;font-size:clamp(6rem,20vw,12rem);line-height:1;
}
.ev-404 h1{
  font-family:var(--ev-font-display);font-weight:380;font-size:clamp(1.6rem,4vw,2.4rem);margin:14px 0 12px;
}
.ev-404 p{color:var(--ev-ivory-dim);margin-bottom:34px;max-width:44ch}

/* ---------- Responsive ---------- */
@media (max-width:920px){
  .ev-area,
  .ev-area:nth-child(even of .ev-area){grid-template-columns:1fr;gap:34px;margin-bottom:96px}
  .ev-area:nth-child(even of .ev-area) .ev-area-media{order:0}
  .ev-occ-grid{grid-template-columns:repeat(2,1fr)}
  .ev-split{grid-template-columns:1fr;gap:36px}
  .ev-contact{grid-template-columns:1fr;gap:36px}
  .ev-stats{grid-template-columns:1fr 1fr}
  .ev-gallery-grid{grid-template-columns:1fr 1fr}
  .ev-footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  .ev-occ-grid{grid-template-columns:1fr}
  /* Fix mobile Ansicht: Scroll-Hinweis kollidierte mit CTA-Buttons
     und Slider-Dots – auf Touch-Geräten ausblenden, Inhalt bekommt
     mehr Abstand nach unten zu den Dots. */
  .ev-scrollhint{display:none}
  .ev-hero-inner{padding-top:60px;padding-bottom:110px}
  .ev-statement{padding:110px 24px}
  .ev-form-grid{grid-template-columns:1fr}
  .ev-form{padding:26px 20px}
  .ev-gallery-grid{grid-template-columns:1fr}
  .ev-footer-grid{grid-template-columns:1fr}
  .ev-stats{grid-template-columns:1fr}
  .ev-pagehero{padding:140px 24px 56px}
}
/* ---------- Reduced Motion ---------- */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
  .ev-hero h1 .ev-line > span{transform:none}
  .ev-hero p,.ev-hero-cta,.ev-scrollhint,.ev-hero-dots{opacity:1}
  .ev-hero-slide{transform:none;transition:opacity .4s ease!important}
  .ev-tilt{transform:none!important}
  .ev-tilt .ev-shine{display:none}
  .ev-rotator b{position:relative;opacity:1;transform:none}
  .ev-rotator b:not(:first-child){display:none}
  .ev-reveal{opacity:1;transform:none}
  .ev-statement-text .w{opacity:1}
}

/* ---------- Utility (statt Inline-Styles, wegen strikter CSP) ---------- */
.ev-mt-lg{margin-top:24px}
.ev-mt-sm{margin-top:12px}
.ev-note-sm{margin-top:10px;font-size:.85rem}

/* ---------- Button in Link-Optik (Footer: Cookie-Hinweis erneut öffnen) ---------- */
.ev-linklike{
  background:none;border:0;padding:0;margin:0;cursor:pointer;
  font:inherit;color:inherit;letter-spacing:inherit;
  transition:color .3s ease;
}
.ev-linklike:hover{color:var(--ev-gold)}
