/* =========================================================
   Future Leadership Conference 2026 — Styles
   Dark · Glassmorphism · Green + Purple + Blue
   ========================================================= */

:root{
  --bg:        #0e1730;
  --bg-2:      #15203c;
  --line:      rgba(255,255,255,.10);
  --line-soft: rgba(255,255,255,.06);
  --text:      #ffffff;
  --muted:     #a3a8bd;
  --muted-2:   #6b7088;

  --accent:    #b4f33a;   /* signature green */
  --accent-2:  #8fd400;
  --accent-ink:#0a0c0b;
  --purple:    #9d5cff;
  --purple-deep:#6d28d9;
  --blue:      #4f6bff;
  --blue-deep: #2f3fd6;

  --grad-brand: linear-gradient(135deg, #4f6bff 0%, #9d5cff 100%);
  --grad-brand-3: linear-gradient(120deg, #4f6bff 0%, #9d5cff 55%, #b4f33a 130%);


  /* glass */
  --glass:      rgba(255,255,255,.045);
  --glass-2:    rgba(255,255,255,.07);
  --glass-line: rgba(255,255,255,.12);
  --blur:       saturate(150%) blur(16px);
  --shadow-hover: 0 22px 48px -28px rgba(0,0,0,.9), 0 0 0 1px rgba(255,255,255,.06);

  --radius:    18px;
  --radius-lg: 26px;
  --maxw:      1320px;
  --ease:      cubic-bezier(.22,.61,.36,1);
  --font-disp:   'DM Sans', system-ui, sans-serif;      /* UI, labels, buttons, card titles */
  --font-display:'Staatliches', 'DM Sans', sans-serif;  /* poster headlines & big numbers */
  --font-body:   'DM Sans', system-ui, sans-serif;
  --font-script: 'Nothing You Could Do', cursive;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:
    radial-gradient(130% 80% at 50% -15%, rgba(79,107,255,.11), transparent 55%),
    radial-gradient(130% 80% at 50% 115%, rgba(157,92,255,.10), transparent 55%),
    var(--bg);
  background-attachment:fixed;
  color:var(--text);
  font-family:var(--font-body);
  font-size:17px;line-height:1.6;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
  position:relative;
}
/* one continuous viewport-fixed color wash — sections stay transparent so the flow is seamless */
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
svg.ic{width:1.05em;height:1.05em;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex:none}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- Typography ---------- */
.h2{font-family:var(--font-display);font-weight:400;font-size:clamp(2.2rem,5.4vw,3.8rem);line-height:1.04;letter-spacing:.01em}
.script{font-family:var(--font-script);font-weight:400;letter-spacing:0;line-height:1;font-size:1.18em;display:inline-block;text-transform:none;white-space:nowrap;vertical-align:baseline}
.accent{color:var(--accent)}
.kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-disp);text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;font-weight:700;color:var(--accent);margin-bottom:22px;padding:7px 16px 7px 14px;border-radius:999px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.12)}
.kicker::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px 1px rgba(180,243,58,.5);flex:none}
/* Eyebrows global ausgeblendet (zu generisch) */
.kicker{display:none}
.eyebrow{font-family:var(--font-disp);text-transform:uppercase;letter-spacing:.28em;font-size:.8rem;font-weight:600;color:var(--muted);margin-bottom:20px}
.lead{font-size:1.18rem;color:#e3e5f0;margin:14px 0 18px;max-width:46ch}
.muted-text{color:var(--muted);max-width:52ch}
.section-intro{color:var(--muted);max-width:58ch;margin-top:16px;font-size:1.05rem}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;font-family:var(--font-disp);font-weight:700;font-size:.95rem;padding:14px 26px;border-radius:999px;cursor:pointer;border:1.5px solid transparent;transition:transform .25s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease),color .25s var(--ease),border-color .25s;white-space:nowrap}
.btn-sm{padding:10px 20px;font-size:.85rem}
.btn-lg{padding:17px 34px;font-size:1.02rem}
.btn-block{width:100%}
.btn-accent{background:var(--accent);color:var(--accent-ink)}
.btn-accent:hover{transform:translateY(-2px);box-shadow:0 12px 36px -8px rgba(180,243,58,.55)}
.btn-ghost{background:var(--glass);color:var(--text);border-color:var(--glass-line);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.link{color:var(--accent);font-weight:600;border-bottom:1px solid transparent;transition:border .2s}
.link:hover{border-color:var(--accent)}

/* ---------- Glass helper ---------- */
.glass{background:var(--glass);border:1px solid var(--glass-line);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur)}

/* ---------- Scroll progress ---------- */
.scroll-progress{position:fixed;top:0;left:0;height:3px;width:100%;transform:scaleX(0);transform-origin:left;background:linear-gradient(90deg,var(--accent),var(--purple) 70%,var(--blue));z-index:200;will-change:transform;pointer-events:none}

/* ---------- Floating ticket CTA (mobile) ---------- */
.float-ticket{position:fixed;bottom:18px;right:18px;z-index:90;display:none;align-items:center;gap:8px;padding:13px 20px;border-radius:999px;background:var(--accent);color:var(--accent-ink);font-family:var(--font-disp);font-weight:700;font-size:.95rem;box-shadow:0 14px 32px -8px rgba(180,243,58,.6);opacity:0;transform:translateY(24px);transition:opacity .35s var(--ease),transform .35s var(--ease)}
.float-ticket svg{width:18px;height:18px}
.float-ticket.show{opacity:1;transform:none}
@media(max-width:760px){.float-ticket{display:inline-flex}}

/* ---------- Header ---------- */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s var(--ease),border-color .3s,backdrop-filter .3s;border-bottom:1px solid transparent}
.site-header.scrolled{background:rgba(10,10,18,.6);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);border-bottom:1px solid var(--line)}
.meta-bar{border-bottom:1px solid var(--line-soft)}
.meta-inner{display:flex;justify-content:flex-start;align-items:center;height:34px}
.funke-link{display:inline-flex;align-items:center;gap:8px;white-space:nowrap;font-size:.74rem;letter-spacing:.02em;text-transform:none;color:var(--muted);font-weight:500;transition:color .2s}
.funke-link span{white-space:nowrap;line-height:1}
.funke-link:hover{color:#fff}
.funke-logo{height:12px;width:auto;display:block}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:92px;gap:24px}
.brand{display:flex;align-items:center}
.brand-logo{height:40px;width:auto}
.nav-desktop{display:flex;gap:34px}
.nav-desktop a{font-family:var(--font-disp);font-weight:600;font-size:.92rem;color:#dadce8;position:relative;padding:4px 0}
.nav-desktop a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--accent);transition:width .25s var(--ease)}
.nav-desktop a:hover{color:#fff}
.nav-desktop a:hover::after{width:100%}
.nav-desktop a.is-active{color:var(--accent)}
.nav-desktop a.is-active::after{width:100%}
.mobile-nav a.is-active{color:var(--accent)}
.header-cta{display:flex;align-items:center;gap:14px}

.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.3s var(--ease)}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-nav{position:fixed;inset:0;z-index:99;background:rgba(8,8,15,.82);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s var(--ease)}
.mobile-nav.open{opacity:1;pointer-events:auto}
.mobile-nav nav{display:flex;flex-direction:column;gap:24px;text-align:center}
.mobile-nav a{font-family:var(--font-disp);font-weight:700;font-size:1.55rem}
.mobile-nav a.btn{font-size:1rem;margin-top:8px}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;padding:152px 0 90px;overflow:hidden;
  background:
    radial-gradient(60% 50% at 14% -8%, rgba(79,107,255,.28), transparent 60%),
    radial-gradient(55% 50% at 86% 4%, rgba(157,92,255,.28), transparent 60%),
    var(--bg);
}
.hero-bg{position:absolute;inset:0;background:url('../img/hero-kontor.jpg') center 38%/cover no-repeat;opacity:.7;pointer-events:none;transform:scale(1.06);
  -webkit-mask:linear-gradient(180deg,#000 0%,#000 38%,rgba(0,0,0,.4) 70%,transparent 97%);
          mask:linear-gradient(180deg,#000 0%,#000 38%,rgba(0,0,0,.4) 70%,transparent 97%)}
.hero-overlay{position:absolute;inset:0;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(10,17,38,.45) 0%, rgba(12,19,42,.72) 55%, var(--bg) 100%),
    linear-gradient(120deg, rgba(79,107,255,.26) 0%, rgba(157,92,255,.20) 48%, rgba(180,243,58,.08) 100%);
  -webkit-backdrop-filter:blur(12px) saturate(1.15);
          backdrop-filter:blur(12px) saturate(1.15)}
.hero-glow{position:absolute;width:760px;height:760px;left:50%;top:6%;transform:translateX(-50%);background:radial-gradient(circle, rgba(180,243,58,.16) 0%, rgba(157,92,255,.05) 40%, transparent 66%);filter:blur(18px);pointer-events:none}
.hero-grid-overlay{position:absolute;inset:0;pointer-events:none;opacity:.45;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:64px 64px;-webkit-mask-image:radial-gradient(circle at 50% 35%,#000 0%,transparent 72%);mask-image:radial-gradient(circle at 50% 35%,#000 0%,transparent 72%)}
.hero-inner{position:relative;text-align:center;display:flex;flex-direction:column;align-items:center}
.hero-meta{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:28px}
.pill{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:999px;border:1px solid var(--glass-line);background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);font-size:.9rem;font-weight:500;color:#eceefb}
.pill .ic{color:var(--accent)}
.hero-title{font-family:var(--font-display);font-weight:400;font-size:clamp(3rem,9vw,7rem);line-height:.95;letter-spacing:.01em;text-transform:uppercase}
.hero-title .script{text-transform:none;color:var(--accent);font-size:1.05em;display:inline-block;margin-top:.04em}
.hero-sub{margin:26px 0 0;color:#d6d9e8;font-size:clamp(1rem,2vw,1.22rem);max-width:42ch}
.hero-sub strong{color:#fff;font-weight:600}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:36px}

.countdown{display:flex;gap:14px;margin-top:48px;flex-wrap:wrap;justify-content:center}
.cd-item{min-width:90px;padding:16px 10px;border-radius:16px;background:var(--glass);border:1px solid var(--glass-line);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);display:flex;flex-direction:column;align-items:center;gap:4px}
.cd-num{font-family:var(--font-display);font-weight:400;font-size:2.7rem;line-height:1;color:#fff;font-variant-numeric:tabular-nums}
.cd-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}

.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);width:26px;height:42px;border:2px solid rgba(255,255,255,.25);border-radius:14px;display:flex;justify-content:center;padding-top:8px}
.scroll-hint span{width:4px;height:8px;background:var(--accent);border-radius:2px;animation:scrolldot 1.6s var(--ease) infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-4px)}40%{opacity:1}80%{opacity:0;transform:translateY(10px)}}

/* ---------- Marquee Band ---------- */
.band{background:var(--accent);color:var(--accent-ink);padding:18px 0;overflow:hidden;white-space:nowrap;position:relative;z-index:1}
.band-track{display:inline-flex;animation:marquee 26s linear infinite}
.band-track span{font-family:var(--font-display);font-weight:400;text-transform:uppercase;font-size:1.5rem;letter-spacing:.04em}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- Sections ---------- */
.section{padding:108px 0;position:relative}
/* fully seamless: every section shares the same transparent canvas over the page background */
.section-alt{background:transparent}
/* About: engere Sektionsabstände */
.about-page .section{padding:66px 0}
.about-page .section-cta{padding:84px 0}
/* cooler, lighter dark sections: soft floating color orbs (no clip, so they fade out softly) */
.has-glow{position:relative}
.has-glow > .container{position:relative;z-index:1}
.glow{position:absolute;z-index:0;border-radius:50%;pointer-events:none;will-change:transform;filter:blur(50px);animation:glowFloat 16s ease-in-out infinite}
.glow--blue{background:radial-gradient(circle, rgba(79,107,255,.28), transparent 68%)}
.glow--purple{background:radial-gradient(circle, rgba(157,92,255,.26), transparent 68%)}
.glow--green{background:radial-gradient(circle, rgba(180,243,58,.16), transparent 68%)}
@keyframes glowFloat{0%,100%{transform:translate(0,0)}50%{transform:translate(24px,-22px)}}
@media (prefers-reduced-motion:reduce){.glow{animation:none}}
.section-head{max-width:740px;margin-bottom:56px}
.center-note{text-align:center;margin-top:44px;color:var(--muted)}

/* ---------- Intro ---------- */
.intro-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
.stats{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--glass-line);border-radius:var(--radius-lg);overflow:hidden;background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur)}
.stat{padding:32px 30px;border-right:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft)}
.stat:nth-child(2n){border-right:none}
.stat:nth-child(n+3){border-bottom:none}
.stat-ic{display:block;color:var(--accent);margin-bottom:14px}
.stat-ic svg{width:40px;height:40px}
/* animated Lottie icon containers (lucide fallback lives inside until JSON loads) */
.licon{display:inline-flex;align-items:center;justify-content:center;line-height:0}
.licon>svg{width:100%!important;height:100%!important;display:block}
.stat-ic.licon{width:44px;height:44px;margin-bottom:16px}
.step-no .licon{width:30px;height:30px}
.stat-line{display:flex;align-items:baseline}
.stat-num{font-family:var(--font-display);font-weight:400;font-size:3.4rem;line-height:.95;color:#fff;letter-spacing:.01em}
.stat-plus{font-family:var(--font-display);font-weight:400;font-size:3.4rem;color:var(--accent);letter-spacing:.01em}
.stat-cap{display:block;color:var(--muted);margin-top:10px;font-size:.92rem;letter-spacing:.01em}

/* ---------- Journey ---------- */
.journey{display:flex;align-items:stretch;gap:18px;justify-content:center}
.journey-step{flex:1;padding:34px 30px;border-radius:var(--radius-lg);border:1px solid var(--glass-line);background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.journey-step:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.22);box-shadow:var(--shadow-hover)}
.step-no{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:16px;background:var(--grad-brand);color:#fff;margin-bottom:20px}
.step-no svg{width:26px;height:26px}
.journey-step:last-of-type .step-no{background:var(--accent);color:var(--accent-ink)}
.journey-step h3{font-family:var(--font-disp);font-weight:700;font-size:1.35rem;margin-bottom:10px}
.journey-step p{color:var(--muted);font-size:.98rem}
.journey-arrow{display:flex;align-items:center;color:var(--purple);opacity:.85}
.journey-arrow svg{width:30px;height:30px;animation:arrowNudge 1.5s var(--ease) infinite}
.journey-arrow:nth-of-type(2) svg{animation-delay:.2s}
@keyframes arrowNudge{0%,100%{transform:translateX(0);opacity:.65}50%{transform:translateX(6px);opacity:1}}

/* ---------- Speaker ---------- */
.speaker-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;perspective:1100px}
.speaker-card{position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);border:1px solid var(--glass-line);background:#11131c;transition:transform .4s var(--ease),box-shadow .4s;will-change:transform;cursor:pointer}
.speaker-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-hover)}
.speaker-card:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
/* inner clip wrapper: NOT 3D-transformed, so border-radius clipping stays intact during tilt */
.speaker-media{position:absolute;inset:0;overflow:hidden;border-radius:inherit;z-index:0}
.speaker-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .6s var(--ease);filter:saturate(1.02)}
.speaker-card:hover img{transform:scale(1.05)}
.speaker-overlay{position:absolute;inset:0;background:linear-gradient(to top, rgba(7,7,13,.96) 4%, rgba(7,7,13,.72) 26%, rgba(7,7,13,.12) 50%, transparent 68%);z-index:1;transition:opacity .4s var(--ease);border-radius:inherit}
.speaker-card:hover .speaker-overlay{opacity:.82}
/* Frosted-glass caption panel */
.speaker-info{position:absolute;left:14px;right:14px;bottom:14px;z-index:2;padding:15px 16px 16px;
  border-radius:16px;
  background:linear-gradient(160deg, rgba(30,42,72,.55), rgba(14,22,44,.42));
  border:1px solid rgba(255,255,255,.14);
  -webkit-backdrop-filter:blur(16px) saturate(150%);backdrop-filter:blur(16px) saturate(150%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16), 0 10px 30px -12px rgba(0,0,0,.7)}
.speaker-name{font-family:var(--font-display);font-weight:400;font-size:1.4rem;line-height:1;letter-spacing:.02em;text-transform:uppercase;color:#fff}
.speaker-role{color:#cfd4e6;font-size:.82rem;margin-top:8px;line-height:1.35}
/* persistenter Klick-Hinweis im Panel */
.speaker-cta{display:inline-flex;align-items:center;gap:7px;margin-top:14px;font-family:var(--font-disp);font-weight:700;font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.speaker-cta svg{width:16px;height:16px;transition:transform .3s var(--ease)}
.speaker-card:hover .speaker-cta svg{transform:translateX(5px)}
/* klar sichtbarer Öffnen-Button in der Ecke (immer aktiv gefärbt) */
.speaker-open{position:absolute;top:14px;right:14px;z-index:3;width:40px;height:40px;display:grid;place-items:center;border-radius:999px;
  background:var(--accent);color:var(--accent-ink);border:0;
  box-shadow:0 6px 18px -6px rgba(180,243,58,.7);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.speaker-open svg{width:20px;height:20px}
.speaker-card:hover .speaker-open,.speaker-card:focus-visible .speaker-open{transform:scale(1.1);box-shadow:0 10px 26px -6px rgba(180,243,58,.85)}


/* ---------- Speaker detail modal ---------- */
.spk-modal{position:fixed;inset:0;z-index:120;display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s}
.spk-modal.open{opacity:1;visibility:visible}
.spk-modal__backdrop{position:absolute;inset:0;background:rgba(4,7,16,.72);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.spk-modal__panel{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,42%) 1fr;
  width:min(760px,100%);max-height:88vh;overflow:hidden;border-radius:var(--radius-lg);
  border:1px solid var(--glass-line);background:var(--bg-2);box-shadow:0 40px 90px -30px rgba(0,0,0,.9);
  transform:translateY(16px) scale(.98);transition:transform .35s var(--ease)}
.spk-modal.open .spk-modal__panel{transform:none}
.spk-modal__media{position:relative;overflow:hidden}
.spk-modal__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center}
.spk-modal__media::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(105deg, transparent 58%, rgba(11,17,32,.55))}
.spk-modal__body{position:relative;padding:34px 34px 32px;overflow-y:auto}
.spk-modal__badge{display:inline-flex;font-family:var(--font-disp);font-weight:700;font-size:.64rem;text-transform:uppercase;letter-spacing:.14em;padding:6px 12px;border-radius:999px;background:var(--accent);color:var(--accent-ink)}
.spk-modal__badge.ghost{background:rgba(255,255,255,.06);color:#fff;border:1px solid var(--glass-line)}
.spk-modal__name{font-family:var(--font-display);font-weight:400;font-size:2rem;line-height:1.02;letter-spacing:.02em;text-transform:uppercase;color:#fff;margin:16px 0 6px}
.spk-modal__role{color:var(--accent);font-weight:600;font-size:.95rem}
.spk-modal__bio{color:#cbd0e4;font-size:.95rem;line-height:1.6;margin-top:16px}
.spk-modal__meta{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:18px;color:var(--muted);font-size:.85rem}
.spk-modal__meta span{display:inline-flex;align-items:center;gap:7px}
.spk-modal__meta svg{width:15px;height:15px;color:var(--accent)}
.spk-modal__actions{margin-top:24px}
.spk-modal__close{position:absolute;top:14px;right:14px;z-index:3;width:38px;height:38px;display:grid;place-items:center;border-radius:999px;border:1px solid var(--glass-line);background:rgba(8,8,15,.55);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);color:#fff;cursor:pointer;transition:border-color .25s,color .25s,transform .25s}
.spk-modal__close:hover{border-color:var(--accent);color:var(--accent);transform:rotate(90deg)}
.spk-modal__close svg{width:18px;height:18px}
@media (max-width:640px){
  .spk-modal__panel{grid-template-columns:1fr;max-height:92vh}
  .spk-modal__media{height:230px}
  .spk-modal__body{padding:26px 22px 26px}
}
body.modal-open{overflow:hidden}

/* ---------- atmosphere photo mosaic (1 groß oben, 2 unten) ---------- */
.photo-mosaic{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:34px}
.photo-mosaic figure{position:relative;overflow:hidden;border-radius:var(--radius);border:1px solid var(--glass-line);background:#11131c;aspect-ratio:4/3}
.photo-mosaic .m-top{grid-column:1 / -1;aspect-ratio:16/7}
.photo-mosaic img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s var(--ease);filter:saturate(1.03)}
.photo-mosaic figure:hover img{transform:scale(1.05)}
.photo-mosaic figure::after{content:"";position:absolute;inset:0;background:linear-gradient(to top, rgba(7,10,20,.55), transparent 55%);opacity:.7;transition:opacity .4s var(--ease)}
.photo-mosaic figure:hover::after{opacity:.35}
.photo-mosaic.compact{gap:14px}
.photo-mosaic.compact .m-top{aspect-ratio:16/6}
@media (max-width:600px){
  .photo-mosaic{grid-template-columns:1fr}
  .photo-mosaic .m-top{grid-column:auto;aspect-ratio:16/9}
  .photo-mosaic figure{aspect-ratio:3/2}
}

/* ---------- team grid (About) ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.team-card{position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--glass-line);background:#11131c}
.team-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .6s var(--ease);filter:saturate(1.02)}
.team-card:hover img{transform:scale(1.05)}
.team-card .team-cap{position:absolute;left:12px;right:12px;bottom:12px;z-index:2;padding:13px 15px 14px;border-radius:14px;
  background:linear-gradient(160deg, rgba(30,42,72,.55), rgba(14,22,44,.42));
  border:1px solid rgba(255,255,255,.14);
  -webkit-backdrop-filter:blur(16px) saturate(150%);backdrop-filter:blur(16px) saturate(150%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16)}
.team-name{font-family:var(--font-display);font-weight:400;font-size:1.16rem;line-height:1.02;letter-spacing:.02em;text-transform:uppercase;color:#fff}
.team-role{color:#cfd4e6;font-size:.76rem;margin-top:6px;line-height:1.3}
@media (max-width:900px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.team-grid{grid-template-columns:1fr 1fr;gap:14px}}

/* ---------- reusable frosted-glass panel ---------- */
.glass{background:linear-gradient(160deg, rgba(30,42,72,.5), rgba(14,22,44,.4));
  border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-lg);
  -webkit-backdrop-filter:blur(16px) saturate(150%);backdrop-filter:blur(16px) saturate(150%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.14), 0 18px 44px -26px rgba(0,0,0,.8)}

/* ---------- editorial split: text one side, media grid other (alternating) ---------- */
.media-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4.5vw,60px);align-items:stretch}
.media-split .ms-text{padding:clamp(28px,3vw,46px);display:flex;flex-direction:column;justify-content:center}
.media-split .ms-text .h2{margin-bottom:16px}
.media-split .ms-text .section-intro{margin:0}
.media-split .ms-text .btn{margin-top:24px;align-self:flex-start}
.media-split .ms-media{display:flex}
.media-split .ms-media .photo-mosaic{margin-top:0;flex:1;width:100%}
.media-split.reverse .ms-media{order:-1}
@media (max-width:820px){
  .media-split{grid-template-columns:1fr;gap:26px}
  .media-split.reverse .ms-media{order:0}
  .media-split .ms-text{padding:28px 26px}
}

/* ---------- Programm: digitale Programmkarte ---------- */
.track-tabs{position:relative;display:flex;gap:4px;padding:6px;width:fit-content;max-width:100%;overflow-x:auto;border-radius:999px;background:var(--glass);border:1px solid var(--glass-line);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);margin-bottom:46px;scrollbar-width:none}
.track-tabs::-webkit-scrollbar{display:none}
.track-indicator{position:absolute;top:6px;bottom:6px;left:0;width:0;border-radius:999px;background:var(--accent);box-shadow:0 10px 26px -8px rgba(180,243,58,.75);transition:transform .42s var(--ease),width .42s var(--ease);z-index:0;pointer-events:none}
.track-tab{position:relative;z-index:1;flex:0 0 auto;display:inline-flex;align-items:center;gap:8px;font-family:var(--font-disp);font-weight:600;font-size:.92rem;padding:11px 20px;border:0;background:transparent;cursor:pointer;color:#c7cbe0;border-radius:999px;white-space:nowrap;transition:color .3s var(--ease)}
.track-tab svg{width:17px;height:17px;transition:transform .3s var(--ease)}
.track-tab:hover:not(.is-active){color:#fff}
.track-tab:hover:not(.is-active) svg{transform:scale(1.12)}
.track-tab.is-active{color:var(--accent-ink)}
.tab-count{display:inline-block;margin-left:2px;padding:1px 8px;border-radius:999px;background:rgba(255,255,255,.12);font-size:.74rem;font-weight:600;line-height:1.5}
.track-tab.is-active .tab-count{background:rgba(10,12,11,.2)}

.program{display:flex;flex-direction:column}
.program > *{margin-bottom:18px}
.program > *:last-child{margin-bottom:0}

/* small full-width slot rows */
.prog-slot{display:flex;align-items:center;gap:18px;flex-wrap:wrap;padding:18px 26px;border-radius:var(--radius);border:1px solid var(--glass-line);background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);transition:border-color .3s,transform .3s var(--ease)}
.prog-slot:hover{border-color:var(--glass-line);transform:translateX(4px)}
.ps-time{font-family:var(--font-disp);font-weight:800;color:var(--accent);font-size:1.1rem;font-variant-numeric:tabular-nums;min-width:64px}
.ps-title{font-family:var(--font-disp);font-weight:700;font-size:1.12rem;flex:1}
.ps-tag{font-family:var(--font-disp);font-weight:700;font-size:.66rem;text-transform:uppercase;letter-spacing:.12em;padding:5px 12px;border-radius:999px;border:1px dashed var(--glass-line);color:var(--muted)}

/* keynote feature card */
.prog-keynote{display:flex;gap:28px;align-items:center;padding:26px 30px;border-radius:var(--radius-lg);border:1px solid var(--glass-line);background:var(--bg-2);position:relative;overflow:hidden}
.prog-keynote::after{content:"";position:absolute;right:-80px;top:-80px;width:260px;height:260px;background:radial-gradient(circle,rgba(180,243,58,.12),transparent 70%);pointer-events:none}
.pk-avatar{flex:none;width:112px;height:112px;border-radius:22px;overflow:hidden;display:flex;align-items:center;justify-content:center;font-family:var(--font-disp);font-weight:800;font-size:2rem;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:var(--accent-ink)}
.pk-avatar img{width:100%;height:100%;object-fit:cover}
.pk-time{font-family:var(--font-disp);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;color:var(--accent)}
.pk-body h3{font-family:var(--font-display);font-weight:400;font-size:1.9rem;margin:6px 0 8px;line-height:1;letter-spacing:.02em;text-transform:uppercase}
.pk-name{color:#fff;font-weight:600}
.pk-name span{color:var(--muted);font-weight:400}
.pk-desc{color:var(--muted);margin-top:6px;font-size:.96rem}

/* session block + speaker grid */
.prog-session{overflow:hidden;max-height:1600px;transition:max-height .6s var(--ease),opacity .45s var(--ease),margin .45s var(--ease),transform .45s var(--ease)}
.program .prog-session.collapsed{max-height:0;opacity:0;margin-bottom:0;transform:translateY(-10px);pointer-events:none}
/* solo = the single chosen track: emphasize + stagger speakers in */
.prog-session.solo .session-head{box-shadow:0 0 0 1px rgba(180,243,58,.45),0 26px 70px -34px rgba(157,92,255,.85)}
.prog-session.solo .spk-card{animation:cardIn .55s var(--ease) backwards}
.prog-session.solo .spk-card:nth-child(2){animation-delay:.04s}
.prog-session.solo .spk-card:nth-child(3){animation-delay:.10s}
.prog-session.solo .spk-card:nth-child(4){animation-delay:.16s}
.prog-session.solo .spk-card:nth-child(5){animation-delay:.22s}
.prog-session.solo .spk-card:nth-child(6){animation-delay:.28s}
@keyframes cardIn{from{opacity:0;transform:translateY(18px) scale(.96)}to{opacity:1;transform:none}}
.session-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.session-head{position:relative;overflow:hidden;border-radius:var(--radius);padding:26px;display:flex;flex-direction:column;justify-content:center;gap:6px;color:#fff;background:var(--grad-brand);min-height:188px}
.session-head.track-leadership{background:linear-gradient(140deg,#4f6bff,#7c3aed)}
.session-head.track-skills{background:linear-gradient(140deg,#6d28d9,#9d5cff)}
.session-head.track-machen{background:linear-gradient(140deg,#3f4fd8,#9d5cff 120%)}
.session-head::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 100% 0,rgba(255,255,255,.18),transparent 55%);pointer-events:none}
.sh-no{font-family:var(--font-disp);font-weight:800;text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;opacity:.9}
.sh-title{font-family:var(--font-display);font-weight:400;font-size:2.2rem;line-height:.98;text-transform:uppercase;letter-spacing:.02em}
.sh-time{font-size:.9rem;opacity:.9;margin-top:4px}
.sh-badge{position:absolute;top:18px;right:18px;width:34px;height:34px;border-radius:10px;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;font-family:var(--font-disp);font-weight:800}

.spk-card{position:relative;border-radius:var(--radius);padding:22px 20px;border:1px solid var(--glass-line);background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);text-align:center;display:flex;flex-direction:column;align-items:center;transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.spk-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.3);box-shadow:var(--shadow-hover);z-index:2}
.spk-av{width:74px;height:74px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;font-family:var(--font-disp);font-weight:800;font-size:1.3rem;color:#fff;background:var(--grad-brand);border:2px solid rgba(255,255,255,.14);margin-bottom:14px}
.spk-av img{width:100%;height:100%;object-fit:cover}
.spk-name{font-family:var(--font-disp);font-weight:700;font-size:1.02rem;line-height:1.2}
.spk-role{color:var(--muted);font-size:.82rem;margin-top:4px}
.spk-topic{color:#e3e5f0;font-size:.86rem;margin-top:10px;padding-top:10px;border-top:1px solid var(--line-soft);font-style:italic}

/* ---------- Soulfood ---------- */
.soul-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.soul-card{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--glass-line);background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s;display:flex;flex-direction:column}
.soul-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.22);box-shadow:var(--shadow-hover)}
.soul-media{height:172px;display:flex;align-items:center;justify-content:center;font-size:3rem;background:linear-gradient(135deg,rgba(79,107,255,.4),rgba(157,92,255,.4));overflow:hidden;position:relative}
.soul-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.soul-card:hover .soul-media img{transform:scale(1.06)}
.soul-body{padding:22px 22px 26px}
.soul-name{font-family:var(--font-disp);font-weight:700;font-size:1.12rem}
.soul-tag{display:inline-block;font-family:var(--font-disp);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.66rem;color:var(--accent);margin-bottom:8px}
.soul-desc{color:var(--muted);font-size:.92rem;margin-top:6px}
.soul-card.featured{background:var(--grad-brand);border-color:transparent}
.soul-card.featured .soul-media{background:rgba(255,255,255,.10);font-size:3.4rem}
.soul-card.featured .soul-tag{color:#fff}
.soul-card.featured .soul-desc{color:rgba(255,255,255,.85)}

/* ---------- Tickets ---------- */
.ticket-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.ticket-card{position:relative;display:flex;flex-direction:column;padding:34px 30px;border-radius:var(--radius-lg);border:1px solid var(--glass-line);background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);transition:transform .35s var(--ease),border-color .35s,box-shadow .35s}
.ticket-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,.22);box-shadow:var(--shadow-hover)}
.ticket-card.is-featured{border-color:var(--accent);background:linear-gradient(180deg,rgba(180,243,58,.10),var(--glass));box-shadow:0 30px 80px -42px rgba(180,243,58,.5)}
.ticket-ribbon{position:absolute;top:-13px;left:30px;background:var(--accent);color:var(--accent-ink);font-family:var(--font-disp);font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;padding:6px 14px;border-radius:999px}
.ticket-name{font-family:var(--font-disp);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.85rem;color:var(--muted)}
.ticket-price{font-family:var(--font-display);font-weight:400;font-size:3.1rem;margin:8px 0 2px;line-height:1;letter-spacing:.01em}
.ticket-price span{font-family:var(--font-body);font-weight:400;font-size:.85rem;color:var(--muted);margin-left:6px}
.ticket-desc{color:var(--muted);font-size:.95rem;margin-bottom:22px}
.ticket-list{list-style:none;display:grid;gap:12px;margin-bottom:28px;flex:1}
.ticket-list li{position:relative;padding-left:30px;font-size:.96rem;color:#e3e5f0}
.ticket-list li::before{content:"";position:absolute;left:0;top:2px;width:18px;height:18px;border-radius:50%;background:rgba(180,243,58,.16);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b4f33a' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:11px}

/* ---------- Location ---------- */
.location-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.arrival{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:30px}
.arrival-item h4{font-family:var(--font-disp);font-weight:700;font-size:1rem;display:flex;align-items:center;gap:10px;margin-bottom:6px}
.arrival-item h4 .ic{color:var(--accent)}
.arrival-item p{color:var(--muted);font-size:.92rem}
.location-card{display:block;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--glass-line);background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);transition:border-color .3s,transform .35s var(--ease)}
.location-card:hover{transform:translateY(-4px)}
.location-photo{aspect-ratio:16/10;overflow:hidden}
.location-photo img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.location-card:hover .location-photo img{transform:scale(1.05)}
/* Location image slider */
.location-slider{position:relative}
.location-slider .ls-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .8s var(--ease)}
.location-slider .ls-slide.is-active{opacity:1}
.ls-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:42px;height:42px;border-radius:999px;border:1px solid rgba(255,255,255,.28);background:rgba(8,12,24,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;display:grid;place-items:center;cursor:pointer;opacity:0;transition:opacity .3s var(--ease),background .3s,color .3s,border-color .3s}
.location-slider:hover .ls-nav{opacity:1}
.ls-nav:hover{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.ls-nav svg{width:20px;height:20px}
.ls-prev{left:12px}.ls-next{right:12px}
.ls-dots{position:absolute;bottom:14px;left:0;right:0;z-index:3;display:flex;justify-content:center;gap:8px}
.ls-dot{width:8px;height:8px;padding:0;border:0;border-radius:999px;background:rgba(255,255,255,.45);cursor:pointer;transition:background .3s var(--ease),width .3s var(--ease)}
.ls-dot.is-active{background:var(--accent);width:24px}
.location-addr{padding:20px 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.location-addr strong{font-family:var(--font-disp);font-weight:700;font-size:1.05rem;display:block}
.location-addr span{color:var(--muted);font-size:.9rem}
.location-maps{display:inline-flex;align-items:center;gap:6px;color:var(--accent);font-weight:600;font-size:.85rem;white-space:nowrap}
.location-maps svg{width:16px;height:16px}

/* ---------- Sponsoren ---------- */
.sponsors{display:flex;flex-direction:column;gap:36px}
.sponsor-tier-label{font-family:var(--font-disp);font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:.74rem;color:var(--muted);margin-bottom:16px;display:flex;align-items:center;gap:14px}
.sponsor-tier-label::after{content:"";flex:1;height:1px;background:var(--line-soft)}
.sponsor-row{display:grid;gap:16px}
.sponsor-row.tier-1{grid-template-columns:repeat(3,1fr)}
.sponsor-row.tier-2{grid-template-columns:repeat(4,1fr)}
.sponsor-row.tier-3{grid-template-columns:repeat(6,1fr)}
.sponsor-card{display:flex;align-items:center;justify-content:center;text-align:center;padding:26px 16px;min-height:96px;border-radius:14px;border:1px solid var(--glass-line);background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);font-family:var(--font-disp);font-weight:700;color:#dfe1ee;font-size:1.02rem;transition:transform .3s var(--ease),border-color .3s,color .3s,box-shadow .3s}
.sponsor-row.tier-3 .sponsor-card{min-height:74px;font-size:.86rem;font-weight:600}
.sponsor-card:hover{transform:translateY(-3px);border-color:rgba(255,255,255,.22);color:#fff;box-shadow:var(--shadow-hover)}
.sponsor-logo{max-width:84%;width:auto;object-fit:contain;filter:brightness(0) invert(1);opacity:.7;transition:opacity .3s var(--ease)}
.sponsor-logo.keep{filter:none;opacity:.92}
.sponsor-card:hover .sponsor-logo{opacity:1}
.partner-cta{margin-top:48px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;padding:32px 36px;border-radius:var(--radius-lg);border:1px solid rgba(157,92,255,.3);background:linear-gradient(120deg, rgba(79,107,255,.14), rgba(157,92,255,.10));backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur)}
.partner-cta h3{font-family:var(--font-disp);font-weight:800;font-size:1.4rem}
.partner-cta p{color:var(--muted);margin-top:6px}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:820px}
.faq-list{display:grid;gap:12px}
.faq-item{border:1px solid var(--glass-line);border-radius:var(--radius);background:var(--glass);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);overflow:hidden;transition:border-color .3s}
.faq-item.open{border-color:rgba(180,243,58,.4)}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:18px;padding:22px 24px;background:none;border:0;cursor:pointer;text-align:left;font-family:var(--font-disp);font-weight:600;font-size:1.08rem;color:#fff}
.faq-icon{flex:none;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--accent);color:var(--accent);position:relative;transition:.3s}
.faq-icon::before,.faq-icon::after{content:"";position:absolute;left:50%;top:50%;background:var(--accent);transition:.3s}
.faq-icon::before{width:11px;height:2px;transform:translate(-50%,-50%)}
.faq-icon::after{width:2px;height:11px;transform:translate(-50%,-50%)}
.faq-item.open .faq-icon{background:var(--accent)}
.faq-item.open .faq-icon::before,.faq-item.open .faq-icon::after{background:var(--accent-ink)}
.faq-item.open .faq-icon::after{transform:translate(-50%,-50%) scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-a p{padding:0 24px 24px;color:var(--muted)}

/* ---------- CTA / Newsletter ---------- */
.section-cta{padding:120px 0}
.cta-box{position:relative;overflow:hidden;text-align:center;padding:64px 40px;border-radius:var(--radius-lg);border:1px solid rgba(180,243,58,.22);background:linear-gradient(135deg, rgba(79,107,255,.18) 0%, rgba(157,92,255,.13) 55%, rgba(18,26,54,1) 100%), #131c38}
.cta-box>.cta-glow{position:absolute;width:620px;height:620px;left:50%;top:-55%;transform:translateX(-50%);background:radial-gradient(circle,rgba(180,243,58,.16),transparent 65%);pointer-events:none;z-index:0}
.cta-box>*{position:relative;z-index:1}
.cta-box .section-intro{margin:16px auto 0}
.news-form{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;max-width:760px;margin:34px auto 0}
.news-form input{flex:1;min-width:180px;padding:15px 18px;border-radius:12px;background:rgba(0,0,0,.28);border:1px solid var(--glass-line);color:#fff;font-family:var(--font-body);font-size:1rem}
.news-form input::placeholder{color:var(--muted-2)}
.news-form input:focus{outline:none;border-color:var(--accent)}
.news-form .btn{flex:none}
.form-note{font-size:.8rem;color:var(--muted-2);margin-top:18px;max-width:520px;margin-left:auto;margin-right:auto}
.form-success{color:var(--accent);font-family:var(--font-disp);font-weight:700;margin-top:18px}

/* ---------- Footer ---------- */
.site-footer{border-top:1px solid var(--line);padding:70px 0 32px;background:var(--bg-2)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.footer-logo{height:46px;margin-bottom:18px}
.footer-brand p{color:var(--muted);font-size:.95rem;margin-bottom:20px}
.socials{display:flex;gap:12px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid var(--glass-line);background:var(--glass);display:flex;align-items:center;justify-content:center;transition:.25s var(--ease)}
.socials svg{width:18px;height:18px;fill:#fff}
.socials a:hover{border-color:var(--accent);background:var(--accent)}
.socials a:hover svg{fill:var(--accent-ink)}
.footer-col h5{font-family:var(--font-disp);font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.8rem;color:#fff;margin-bottom:16px}
.footer-col a{display:block;color:var(--muted);font-size:.95rem;padding:5px 0;transition:color .2s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-top:50px;padding-top:24px;border-top:1px solid var(--line-soft);color:var(--muted-2);font-size:.85rem}

/* ---------- Rückblick 2025: Aftermovie ---------- */
.video-frame{position:relative;display:block;aspect-ratio:16/9;width:100%;margin:0 auto;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--glass-line);background:#0a0f1f;box-shadow:0 34px 90px -48px rgba(0,0,0,.85)}
.video-frame img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.62;transition:opacity .4s var(--ease),transform .6s var(--ease)}
.video-frame:hover img{opacity:.5;transform:scale(1.04)}
.video-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:84px;height:84px;border-radius:50%;display:grid;place-items:center;background:var(--accent);color:var(--accent-ink);box-shadow:0 14px 44px -8px rgba(180,243,58,.6);transition:transform .3s var(--ease)}
.video-frame:hover .video-play{transform:translate(-50%,-50%) scale(1.08)}
.video-play svg{width:34px;height:34px;margin-left:4px;fill:currentColor;stroke:currentColor}
.video-tag{position:absolute;left:18px;bottom:16px;font-family:var(--font-disp);font-weight:700;font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:rgba(0,0,0,.42);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:7px 13px;border-radius:999px;border:1px solid rgba(255,255,255,.16)}
.video-frame.playing{cursor:default}
.video-el{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#000;border:0}
/* Hochformat-Stimmen (9:16) */
.voice-videos{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.video-frame--portrait{aspect-ratio:9/16;width:100%;display:block}
.video-frame--portrait img{opacity:.85}
.video-frame--portrait .video-play{width:58px;height:58px}
.video-frame--portrait .video-play svg{width:24px;height:24px}
.vv-label{position:absolute;left:0;right:0;bottom:0;z-index:1;padding:34px 14px 14px;font-family:var(--font-disp);font-weight:700;font-size:.82rem;letter-spacing:.04em;color:#fff;background:linear-gradient(transparent,rgba(8,12,24,.8))}
.video-frame.is-placeholder{cursor:default}

/* ---------- Teilnehmerstimmen ---------- */
.voices-head{text-align:center;margin:66px 0 28px}
.voices-head h3{font-family:var(--font-display);font-weight:400;font-size:clamp(1.5rem,3vw,2.1rem)}
.voices-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.voice-card{position:relative;padding:34px 28px 30px;border-radius:var(--radius);border:1px solid var(--glass-line);background:var(--glass);-webkit-backdrop-filter:var(--blur);backdrop-filter:var(--blur)}
.voice-card::before{content:"\201C";position:absolute;top:2px;left:20px;font-family:var(--font-display);font-size:3.6rem;line-height:1;color:var(--accent);opacity:.4}
.voice-quote{font-size:1.04rem;line-height:1.55;color:#e9ebf6;margin:22px 0 20px}
.voice-by{display:flex;flex-direction:column;gap:2px}
.voice-name{font-family:var(--font-disp);font-weight:700;color:#fff}
.voice-role{color:var(--muted);font-size:.9rem}

/* ---------- Programm-Teaser ---------- */
.prog-teaser{position:relative;overflow:hidden;text-align:center;padding:64px 40px;border-radius:var(--radius-lg);border:1px solid var(--glass-line);background:linear-gradient(135deg, rgba(79,107,255,.15) 0%, rgba(157,92,255,.11) 55%, rgba(18,26,54,1) 100%), #131c38}
.prog-teaser>*{position:relative;z-index:1}
.prog-teaser-glow{position:absolute;z-index:0;width:520px;height:520px;left:50%;top:-46%;transform:translateX(-50%);background:radial-gradient(circle, rgba(180,243,58,.15) 0%, transparent 65%);filter:blur(22px);pointer-events:none}
.prog-teaser .kicker{margin-bottom:18px}
.prog-teaser .btn{margin-top:26px}
.prog-teaser .section-intro{margin-left:auto;margin-right:auto}

/* ---------- Sektionen mit Foto-Hintergrund (oben/unten ausgemaskt) ----------
   Nutzung: <section class="section section--photo">
              <div class="section-photo" aria-hidden="true"><img src="assets/img/DATEI.jpg" alt=""></div>
              <div class="container"> ... </div>
            </section>  */
.section--photo{position:relative;isolation:isolate}
.section--photo > .container{position:relative;z-index:1}
.section-photo{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none;
  -webkit-mask:linear-gradient(180deg, transparent 0%, #000 38%, #000 62%, transparent 100%);
          mask:linear-gradient(180deg, transparent 0%, #000 38%, #000 62%, transparent 100%)}
.section-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:1}
.section-photo::after{content:"";position:absolute;inset:0;
  background:linear-gradient(rgba(14,23,48,.80), rgba(14,23,48,.90)),
             radial-gradient(70% 60% at 80% 20%, rgba(180,243,58,.08), transparent 60%)}

/* ---------- Freistehendes Bild-Band (Fade oben/unten + seitlich) ---------- */
.image-band{position:relative;width:100%;margin:20px 0;padding:0}
.image-band img{display:block;width:100%;height:clamp(320px,56vh,600px);object-fit:cover;
  -webkit-mask:
    linear-gradient(180deg, transparent 0%, #000 20%, #000 80%, transparent 100%),
    linear-gradient(90deg, transparent 0%, #000 12%, #000 88%, transparent 100%);
  -webkit-mask-composite:source-in;
  mask:
    linear-gradient(180deg, transparent 0%, #000 20%, #000 80%, transparent 100%),
    linear-gradient(90deg, transparent 0%, #000 12%, #000 88%, transparent 100%);
  mask-composite:intersect}

/* ---------- Subpage top spacing (fixed header clearance) ---------- */
.section--top{padding-top:150px}
.back-link{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-family:var(--font-disp);font-weight:600;font-size:.92rem;margin-bottom:18px;transition:color .2s}
.back-link:hover{color:var(--accent)}
.back-link svg{width:16px;height:16px}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .intro-grid,.location-grid{grid-template-columns:1fr;gap:40px}
  .speaker-grid,.soul-grid{grid-template-columns:repeat(2,1fr)}
  .ticket-grid{grid-template-columns:1fr;max-width:460px;margin:0 auto}
  .journey{flex-direction:column}
  .journey-arrow{transform:rotate(90deg);justify-content:center}
  .session-grid{grid-template-columns:repeat(2,1fr)}
  .session-head{grid-column:1 / -1;min-height:auto}
  .sponsor-row.tier-1,.sponsor-row.tier-2{grid-template-columns:repeat(2,1fr)}
  .sponsor-row.tier-3{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:760px){
  .nav-desktop,.header-cta .btn{display:none}
  .burger{display:flex}
  .section{padding:80px 0}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr 1fr}
  .arrival{grid-template-columns:1fr}
  .cd-item{min-width:70px;padding:12px 8px}
  .cd-num{font-size:1.8rem}
  .band-track span{font-size:1rem}
  .prog-keynote{flex-direction:column;text-align:center;align-items:center}
  .brand-logo{height:32px}
  .header-inner{height:72px}
  .voices-grid{grid-template-columns:1fr}
  .voice-videos{grid-template-columns:repeat(2,1fr)}
  .video-play{width:64px;height:64px}
  .video-play svg{width:26px;height:26px}
}
@media (max-width:480px){
  .speaker-grid,.soul-grid{grid-template-columns:1fr 1fr}
  .session-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .hero{padding-top:108px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
