@font-face{ font-family:'Inter'; font-weight:400; font-display:swap; src:url('fonts/Inter-400.woff2') format('woff2'); }
@font-face{ font-family:'Inter'; font-weight:600; font-display:swap; src:url('fonts/Inter-600.woff2') format('woff2'); }
@font-face{ font-family:'Inter'; font-weight:700; font-display:swap; src:url('fonts/Inter-700.woff2') format('woff2'); }
@font-face{ font-family:'Inter'; font-weight:800; font-display:swap; src:url('fonts/Inter-800.woff2') format('woff2'); }
@font-face{ font-family:'Playfair Display'; font-weight:700; font-display:swap; src:url('fonts/PlayfairDisplay-700.woff2') format('woff2'); }

/* ============================================================
   TEAMWORK DREAMWORK
   Warm, hell, viel Weißraum. Salbeigrün, warmes Gold, Creme.
   ============================================================ */
:root{
  --bg:#FBF8F3;
  --bg-2:#F5EFE4;
  --sage-bg:#EDF2EC;
  --card:#FFFFFF;
  --ink:#2A2E2A;
  --muted:#6B7268;
  --muted-2:#8A9085;
  --sage:#5E7A63;
  --sage-d:#4C6451;
  --sage-soft:rgba(94,122,99,.12);
  --sage-line:rgba(94,122,99,.22);
  --gold:#C99A4E;
  --gold-soft:#F3E7CF;
  --deep:#28332B;
  --line:rgba(42,46,42,.08);
  --r-xl:34px; --r-lg:26px; --r-md:18px; --r-sm:12px; --r-pill:999px;
  --shadow-sm:0 6px 18px -8px rgba(40,51,43,.18);
  --shadow:0 26px 60px -28px rgba(40,51,43,.40);
  --shadow-lg:0 40px 90px -36px rgba(40,51,43,.45);
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; scroll-padding-top:96px; overflow-x:hidden; }
body{ font-family:'Inter',"Segoe UI",system-ui,sans-serif; background:var(--bg); color:var(--ink); line-height:1.7; -webkit-font-smoothing:antialiased; overflow-x:hidden; }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; }

h1,h2,h3{ font-family:'Playfair Display',Georgia,serif; line-height:1.12; font-weight:700; letter-spacing:-.005em; color:var(--ink); }

::selection{ background:var(--sage-soft); }
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{ outline:3px solid var(--sage); outline-offset:3px; border-radius:8px; }

.wrap{ max-width:1140px; margin:0 auto; padding:0 26px; }
.narrow{ max-width:820px; }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

/* ---------- Pills / Buttons / Links ---------- */
.eyebrow{ display:inline-flex; align-items:center; gap:9px; font-size:12.5px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--sage-d); }
.eyebrow::before{ content:""; width:26px; height:2px; border-radius:2px; background:var(--sage); }
.eyebrow.center{ justify-content:center; }

.pill{ display:inline-flex; align-items:center; gap:9px; font-size:13.5px; font-weight:700; padding:9px 18px; border-radius:var(--r-pill); background:#fff; color:var(--sage-d); border:1px solid var(--sage-line); box-shadow:var(--shadow-sm); }
.pill .star{ color:var(--gold); }

.btn{ display:inline-flex; align-items:center; gap:9px; padding:15px 30px; border-radius:var(--r-pill); font-weight:700; font-size:15px; cursor:pointer; border:1.5px solid transparent; transition:transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s ease, background .2s ease, color .2s ease; text-align:center; }
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--sage); color:#fff; box-shadow:0 14px 30px -12px rgba(76,100,81,.7); }
.btn-primary:hover{ background:var(--sage-d); transform:translateY(-3px); box-shadow:0 22px 44px -14px rgba(76,100,81,.75); }
.btn-ghost{ background:#fff; color:var(--ink); border-color:var(--line); box-shadow:var(--shadow-sm); }
.btn-ghost:hover{ transform:translateY(-3px); border-color:var(--sage-line); color:var(--sage-d); }
.btn-light{ background:#fff; color:var(--sage-d); }
.btn-light:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.btn-lg{ padding:17px 36px; font-size:16px; }
.btn-block{ width:100%; justify-content:center; }

.txt-link{ display:inline-flex; align-items:center; gap:6px; color:var(--sage-d); font-weight:700; font-size:15px; cursor:pointer; background:none; border:none; }
.txt-link svg{ width:16px; height:16px; transition:transform .25s ease; }
.txt-link:hover svg{ transform:translateX(4px); }

/* ---------- Header ---------- */
.header{ position:fixed; top:0; left:0; right:0; z-index:90; transition:background .3s ease, box-shadow .3s ease, backdrop-filter .3s ease; }
.header.stuck{ background:rgba(251,248,243,.85); backdrop-filter:saturate(170%) blur(14px); box-shadow:0 8px 30px -18px rgba(40,51,43,.35); }
.nav{ display:flex; align-items:center; justify-content:space-between; padding:18px 0; transition:padding .3s ease; }
.header.stuck .nav{ padding:12px 0; }
.brand{ display:flex; align-items:center; gap:12px; font-weight:800; font-size:18px; color:var(--ink); }
.brand .dot{ width:42px; height:42px; border-radius:14px; background:linear-gradient(150deg,var(--sage),var(--sage-d)); display:flex; align-items:center; justify-content:center; box-shadow:0 8px 18px -8px rgba(76,100,81,.8); transition:width .3s,height .3s; flex-shrink:0; }
.header.stuck .brand .dot{ width:38px; height:38px; }
.brand .dot svg{ width:24px; height:24px; }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a:not(.btn){ font-size:15px; font-weight:600; color:var(--muted); position:relative; cursor:pointer; }
.nav-links a:not(.btn)::after{ content:""; position:absolute; left:0; right:0; bottom:-5px; height:2px; border-radius:2px; background:var(--sage); transform:scaleX(0); transform-origin:0; transition:transform .3s cubic-bezier(.16,1,.3,1); }
.nav-links a:not(.btn):hover{ color:var(--ink); }
.nav-links a:not(.btn):hover::after{ transform:scaleX(1); }
.burger{ display:none; flex-direction:column; gap:5px; background:#fff; border:1px solid var(--line); border-radius:14px; padding:12px; cursor:pointer; box-shadow:var(--shadow-sm); }
.burger span{ width:22px; height:2px; background:var(--ink); border-radius:2px; }

/* Mobile menu */
.mmenu{ position:fixed; inset:0; z-index:120; background:var(--deep); color:#fff; padding:30px 26px; transform:translateX(100%); transition:transform .35s cubic-bezier(.16,1,.3,1); display:flex; flex-direction:column; }
.mmenu.open{ transform:none; }
.mmenu-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:40px; }
.mmenu-head .brand{ color:#fff; }
.mmenu-close{ background:rgba(255,255,255,.12); border:none; color:#fff; border-radius:12px; padding:10px; cursor:pointer; line-height:0; }
.mmenu nav a{ display:block; font-family:'Playfair Display',serif; font-size:26px; font-weight:700; padding:16px 0; border-bottom:1px solid rgba(255,255,255,.12); }
.mmenu .btn{ margin-top:auto; justify-content:center; }

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

/* ---------- Sektionen ---------- */
section{ position:relative; padding:120px 0; }
.section-head{ max-width:680px; margin-bottom:56px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head h2{ font-size:clamp(30px,4.4vw,46px); margin:18px 0 16px; }
.section-head p{ font-size:18px; color:var(--muted); }

.bg-cream{ background:var(--bg-2); }
.bg-sage{ background:var(--sage-bg); }

.blob{ position:absolute; border-radius:50%; filter:blur(10px); pointer-events:none; z-index:0; opacity:.7; }
.blob-sage{ background:radial-gradient(circle at 50% 50%, rgba(94,122,99,.20), rgba(94,122,99,0) 70%); }
.blob-gold{ background:radial-gradient(circle at 50% 50%, rgba(201,154,78,.16), rgba(201,154,78,0) 70%); }

/* Reveal */
[data-reveal]{ opacity:0; transform:translateY(20px); transition:opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); }
[data-reveal][data-d="1"]{ transition-delay:.08s; }
[data-reveal][data-d="2"]{ transition-delay:.16s; }
[data-reveal][data-d="3"]{ transition-delay:.24s; }
[data-reveal][data-d="4"]{ transition-delay:.32s; }
[data-reveal].vis{ opacity:1; transform:none; }
[data-stagger] > *{ opacity:0; transform:translateY(20px); transition:opacity .8s cubic-bezier(.16,1,.3,1), transform .8s cubic-bezier(.16,1,.3,1); }
[data-stagger].vis > *:nth-child(1){ opacity:1; transform:none; transition-delay:.05s; }
[data-stagger].vis > *:nth-child(2){ opacity:1; transform:none; transition-delay:.15s; }
[data-stagger].vis > *:nth-child(3){ opacity:1; transform:none; transition-delay:.25s; }
[data-stagger].vis > *:nth-child(4){ opacity:1; transform:none; transition-delay:.35s; }
[data-stagger].vis > *:nth-child(5){ opacity:1; transform:none; transition-delay:.45s; }
[data-stagger].vis > *:nth-child(6){ opacity:1; transform:none; transition-delay:.55s; }
[data-stagger].vis > *:nth-child(7){ opacity:1; transform:none; transition-delay:.65s; }
[data-stagger].vis > *:nth-child(8){ opacity:1; transform:none; transition-delay:.75s; }

/* ---------- HERO ---------- */
.hero{ padding:170px 0 110px; overflow:hidden; }
.hero .wrap{ position:relative; z-index:1; }
.hero-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:60px; align-items:center; }
.hero h1{ font-size:clamp(38px,5.6vw,62px); margin:24px 0 22px; }
.hero h1 .accent{ color:var(--sage); font-style:italic; }
.hero-lead{ font-size:19px; color:var(--muted); max-width:480px; margin-bottom:36px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-trust{ display:flex; align-items:center; gap:18px; margin-top:34px; color:var(--muted); font-size:14.5px; }
.avatars{ display:flex; }
.avatars span{ width:38px; height:38px; border-radius:50%; border:2.5px solid var(--bg); margin-left:-10px; background:linear-gradient(150deg,var(--sage),var(--sage-d)); display:flex; align-items:center; justify-content:center; font-weight:800; font-size:13px; color:#fff; }
.avatars span:first-child{ margin-left:0; }
.hero-stars{ color:var(--gold); letter-spacing:1px; }

.hero-media{ position:relative; }
.hero-media .glow{ position:absolute; inset:-12% -8% -8% 8%; background:radial-gradient(60% 60% at 70% 30%, rgba(201,154,78,.30), rgba(201,154,78,0) 70%), radial-gradient(70% 70% at 20% 90%, rgba(94,122,99,.30), rgba(94,122,99,0) 70%); filter:blur(20px); z-index:0; border-radius:50%; }
.media-card{ position:relative; z-index:1; border-radius:var(--r-xl); overflow:hidden; box-shadow:var(--shadow-lg); background:#fff; aspect-ratio:4/5; }
.media-card > img, .media-card > iframe{ width:100%; height:100%; object-fit:cover; display:block; border:none; }
.media-card .play-gate{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; text-align:center; padding:26px; background:linear-gradient(180deg,rgba(40,51,43,.15),rgba(40,51,43,.55)); color:#fff; cursor:pointer; border:none; width:100%; }
.play-btn{ width:74px; height:74px; border-radius:50%; background:#fff; color:var(--sage-d); border:none; display:flex; align-items:center; justify-content:center; cursor:pointer; box-shadow:0 16px 36px -12px rgba(0,0,0,.5); transition:transform .25s ease; pointer-events:none; }
.play-gate:hover .play-btn{ transform:scale(1.08); }
.play-btn svg{ width:28px; height:28px; margin-left:3px; }
.play-gate p{ font-size:13.5px; font-weight:600; max-width:280px; pointer-events:none; }
.consent-note{ font-size:12px; color:rgba(255,255,255,.78); margin-top:6px; pointer-events:none; }

.float-card{ position:absolute; z-index:2; background:#fff; border-radius:var(--r-md); padding:14px 18px; box-shadow:var(--shadow); display:flex; align-items:center; gap:12px; }
.float-card .ic{ width:40px; height:40px; border-radius:12px; background:var(--sage-soft); color:var(--sage-d); display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.float-card .ic svg{ width:22px; height:22px; }
.float-card b{ font-size:15px; display:block; }
.float-card span{ font-size:12.5px; color:var(--muted); }
.float-card.fc-1{ left:-26px; bottom:42px; }
.float-card.fc-2{ right:-18px; top:46px; }

/* ---------- KONZEPT-KARTEN ---------- */
.cards-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.card{ background:var(--card); border-radius:var(--r-lg); overflow:hidden; box-shadow:var(--shadow-sm); transition:transform .3s cubic-bezier(.16,1,.3,1), box-shadow .3s ease; }
.card:hover{ transform:translateY(-8px); box-shadow:var(--shadow); }
.card-photo{ aspect-ratio:16/11; overflow:hidden; }
.card-photo img{ width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.16,1,.3,1); }
.card:hover .card-photo img{ transform:scale(1.06); }
.card-body{ padding:26px 26px 30px; }
.card-step{ display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:50%; background:var(--sage-soft); color:var(--sage-d); font-weight:800; font-size:15px; margin-bottom:14px; }
.card-body h3{ font-size:21px; margin-bottom:8px; }
.card-body p{ font-size:15px; color:var(--muted); }

/* ---------- KLARSTELLUNG UMSATZBETEILIGUNG ---------- */
.vp-clarify{ margin-top:42px; background:linear-gradient(140deg,#F6EFE0,#EFE7D3); border-radius:var(--r-xl); padding:42px clamp(28px,4vw,52px); box-shadow:var(--shadow-sm); }
.vp-clarify-inner{ display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center; }
.vp-clarify-text h3{ font-size:24px; margin-bottom:10px; color:var(--ink); }
.vp-clarify-text p{ font-size:16px; color:var(--muted); line-height:1.7; }
.vp-clarify-list{ background:#fff; border-radius:var(--r-lg); padding:24px 28px; box-shadow:var(--shadow-sm); }
.vp-clarify-h{ font-size:13px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--sage-d); margin-bottom:14px; }
.vp-clarify-list ul{ list-style:none; padding:0; margin:0; }
.vp-clarify-list li{ display:flex; align-items:center; gap:10px; font-size:14.5px; color:var(--ink); padding:7px 0; }
.vp-clarify-list li svg{ width:18px; height:18px; color:var(--sage); flex-shrink:0; }
.vp-clarify-foot{ font-size:13.5px; color:var(--muted); margin-top:14px; padding-top:14px; border-top:1px solid var(--line); font-style:italic; }

/* ---------- ELEGANTER LEAF-DIVIDER (feine SVG-Linien) ---------- */
.leaf-divider{ display:flex; align-items:center; justify-content:center; gap:18px; margin:8px auto 36px; max-width:520px; color:var(--sage); opacity:.55; }
.leaf-divider .ld-line{ flex:1; height:1px; background:linear-gradient(90deg, transparent, currentColor 30%, currentColor 70%, transparent); }
.leaf-divider svg{ width:auto; height:22px; display:block; }
.leaf-divider svg.flip{ transform:scaleX(-1); }

.hero .wrap, section .wrap{ position:relative; z-index:1; }

/* ---------- WAS DICH ERWARTET (Pillars) ---------- */
.pillars{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.pillar{ background:#fff; border-radius:var(--r-lg); padding:32px 26px 30px; box-shadow:var(--shadow-sm); transition:transform .3s cubic-bezier(.16,1,.3,1), box-shadow .3s ease; text-align:center; }
.pillar:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.pillar-ic{ display:inline-flex; align-items:center; justify-content:center; width:48px; height:48px; border-radius:14px; background:var(--sage-soft); color:var(--sage-d); margin-bottom:18px; }
.pillar-ic svg{ width:22px; height:22px; }

/* ---------- EVENTS-GRID ---------- */
.events-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-top:48px; }
.event-card{ background:#fff; border-radius:var(--r-lg); padding:28px 24px 26px; box-shadow:var(--shadow-sm); transition:transform .3s cubic-bezier(.16,1,.3,1), box-shadow .3s ease; display:flex; flex-direction:column; }
.event-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); }
.event-ic{ display:inline-flex; align-items:center; justify-content:center; width:42px; height:42px; border-radius:12px; background:var(--sage-soft); color:var(--sage-d); margin-bottom:16px; }
.event-ic svg{ width:20px; height:20px; }
.event-card h3{ font-size:18px; margin-bottom:8px; color:var(--ink); }
.event-card p{ font-size:14px; color:var(--muted); line-height:1.6; flex:1; }
.event-card-cta{ background:linear-gradient(140deg,var(--sage-bg),var(--bg-2)); border:1px dashed var(--sage); }
.event-cta-link{ display:inline-flex; align-items:center; gap:6px; margin-top:14px; font-size:14px; font-weight:700; color:var(--sage-d); text-decoration:none; }
.event-cta-link svg{ width:14px; height:14px; transition:transform .2s ease; }
.event-cta-link:hover svg{ transform:translate(2px,-2px); }
.pillar h3{ font-family:'Inter',sans-serif; font-size:16px; font-weight:700; margin-bottom:8px; letter-spacing:.02em; }
.pillar p{ font-size:14.5px; color:var(--muted); line-height:1.65; }

/* ---------- STATS ---------- */
.stats-wrap{ position:relative; }
.stats-leaf{ position:absolute; pointer-events:none; opacity:.35; color:var(--sage); }
.stats-leaf.l1{ top:-30px; left:-20px; width:130px; transform:rotate(-22deg); }
.stats-leaf.l2{ bottom:-30px; right:-20px; width:130px; transform:rotate(160deg); }
.stats-panel{ background:linear-gradient(135deg,#EDF2EC,#E3EDE2); border-radius:var(--r-xl); padding:60px 40px; display:grid; grid-template-columns:repeat(4,1fr); gap:30px; text-align:center; box-shadow:var(--shadow-sm); position:relative; overflow:hidden; }
.stat{ position:relative; }
.stat + .stat::before{ content:""; position:absolute; left:-15px; top:50%; transform:translateY(-50%); height:60%; width:1px; background:var(--sage-line); }
.stat .num{ font-family:'Playfair Display',serif; font-weight:700; font-size:clamp(38px,5vw,56px); color:var(--sage-d); line-height:1; }
.stat .lbl{ display:block; margin-top:10px; font-size:13px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }

/* ---------- ISABEL ---------- */
.isabel-grid{ display:grid; grid-template-columns:.9fr 1.1fr; gap:50px; align-items:center; }
.isabel-photo{ position:relative; border-radius:var(--r-xl); overflow:hidden; aspect-ratio:4/5; box-shadow:var(--shadow); }
.isabel-photo img{ width:100%; height:100%; object-fit:cover; }
.isabel-photo .badge{ position:absolute; bottom:20px; left:20px; background:#fff; color:var(--sage-d); padding:10px 16px; border-radius:var(--r-pill); font-size:13px; font-weight:700; box-shadow:var(--shadow-sm); }
.isabel-text h2{ font-size:clamp(28px,4vw,42px); margin:12px 0 18px; }
.isabel-text p{ font-size:17px; color:var(--muted); margin-bottom:18px; }
.isabel-text .signature{ font-family:'Playfair Display',serif; font-style:italic; font-size:22px; color:var(--sage-d); margin-top:20px; }
.isabel-bullets{ list-style:none; margin:24px 0 28px; }
.isabel-bullets li{ display:flex; align-items:flex-start; gap:12px; font-size:15.5px; color:var(--ink); margin-bottom:12px; }
.isabel-bullets li svg{ width:20px; height:20px; color:var(--sage); flex-shrink:0; margin-top:3px; }

/* ---------- TEAM ---------- */
.team-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:22px; }
.team-card{ background:var(--card); border-radius:var(--r-lg); padding:0; text-align:center; box-shadow:var(--shadow-sm); transition:transform .3s cubic-bezier(.16,1,.3,1), box-shadow .3s ease; overflow:hidden; cursor:pointer; border:none; width:100%; font-family:inherit; }
.team-card:hover{ transform:translateY(-7px); box-shadow:var(--shadow); }
.team-media{ position:relative; aspect-ratio:3/4; overflow:hidden; background:linear-gradient(150deg,var(--sage-bg),#E3EDE2); display:flex; align-items:center; justify-content:center; }
.team-media img{ width:100%; height:100%; object-fit:cover; }
.team-media .team-init{ font-family:'Inter',sans-serif; font-weight:800; font-size:54px; letter-spacing:.02em; color:var(--sage-d); opacity:.45; }
.team-media .team-play{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; background:linear-gradient(180deg,rgba(40,51,43,0),rgba(40,51,43,.55)); opacity:0; transition:opacity .25s ease; }
.team-card:hover .team-media .team-play{ opacity:1; }
.team-media .team-play span{ width:56px; height:56px; border-radius:50%; background:#fff; color:var(--sage-d); display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow); }
.team-media .team-play svg{ width:22px; height:22px; margin-left:2px; }
.team-info{ padding:22px 18px 26px; }
.team-info h3{ font-size:18px; margin-bottom:4px; }
.team-role{ font-size:13px; font-weight:700; color:var(--sage-d); letter-spacing:.02em; }
.team-role::before{ content:""; display:inline-block; width:14px; height:1.5px; background:var(--sage); margin-right:8px; vertical-align:middle; margin-bottom:3px; }

/* ---------- VIDEO-KARTE (Chancenabend) ---------- */
.isabel-video{ position:relative; border-radius:var(--r-lg); overflow:hidden; aspect-ratio:16/9; box-shadow:var(--shadow); background:#000; }
.isabel-video > img, .isabel-video > iframe{ width:100%; height:100%; object-fit:cover; display:block; border:none; }
.isabel-video .play-gate{ position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; background:rgba(40,51,43,.55); cursor:pointer; border:none; padding:24px; }

/* ---------- GALERIE (Bento-Layout) ---------- */
.gallery{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:18px; position:relative; }
.tile{ position:relative; border:none; padding:0; cursor:pointer; border-radius:var(--r-md); overflow:hidden; background:#ddd; box-shadow:var(--shadow-sm); }
/* Bento-Größen */
.tile:nth-child(1){ grid-column:span 2; grid-row:span 2; }   /* groß */
.tile:nth-child(2){ grid-column:span 1; grid-row:span 1; }
.tile:nth-child(3){ grid-column:span 1; grid-row:span 2; }   /* hoch */
.tile:nth-child(4){ grid-column:span 1; grid-row:span 1; }
.tile:nth-child(5){ grid-column:span 2; grid-row:span 1; }   /* breit */
.tile:nth-child(6){ grid-column:span 1; grid-row:span 1; }
.tile:nth-child(7){ grid-column:span 1; grid-row:span 1; }
.tile:nth-child(8){ grid-column:span 2; grid-row:span 1; }
.tile img{ width:100%; height:100%; object-fit:cover; transition:transform .5s cubic-bezier(.16,1,.3,1); }
.tile:hover img{ transform:scale(1.07); }
.tile-cap{ position:absolute; left:0; right:0; bottom:0; padding:16px; color:#fff; font-size:13.5px; font-weight:700; text-align:left; background:linear-gradient(180deg,transparent,rgba(40,51,43,.75)); opacity:0; transform:translateY(8px); transition:opacity .3s ease, transform .3s ease; display:flex; align-items:center; gap:7px; }
.tile:hover .tile-cap{ opacity:1; transform:none; }
.tile-cap svg{ width:15px; height:15px; }

/* ---------- WATERCOLOR-DECORATION ---------- */
/* ---------- VIDEO-MODAL (für Team-Videos) ---------- */
.video-modal-card{ background:#000; border-radius:var(--r-lg); max-width:760px; width:100%; aspect-ratio:16/9; position:relative; overflow:hidden; padding:0; transform:translateY(20px) scale(.98); transition:transform .35s cubic-bezier(.16,1,.3,1); max-height:none; }
.modal.in .video-modal-card{ transform:none; }
.video-modal-card iframe{ width:100%; height:100%; border:0; display:block; }
.video-modal-card .video-portrait{ aspect-ratio:9/16; max-width:380px; margin:0 auto; }
.video-modal-card .modal-close{ background:rgba(255,255,255,.18); color:#fff; top:14px; right:14px; }
.video-modal-card .modal-close:hover{ background:rgba(255,255,255,.32); color:#fff; }

/* ---------- FOTO-BAND ---------- */
.photo-band{ position:relative; border-radius:var(--r-xl); overflow:hidden; min-height:440px; display:flex; align-items:center; box-shadow:var(--shadow); }
.photo-band img.bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.photo-band .ov{ position:absolute; inset:0; z-index:1; background:linear-gradient(110deg,rgba(40,51,43,.82),rgba(40,51,43,.45)); }
.photo-band .inner{ position:relative; z-index:2; padding:64px clamp(30px,6vw,76px); color:#fff; max-width:620px; }
.photo-band h2{ color:#fff; font-size:clamp(28px,3.6vw,40px); margin-bottom:16px; }
.photo-band p{ font-size:17px; color:rgba(255,255,255,.9); margin-bottom:28px; }
.photo-band.center{ justify-content:center; text-align:center; }
.photo-band.center .inner{ max-width:680px; }

/* ---------- MITGLIEDERBEREICH (Highlight) ---------- */
.highlight{ position:relative; overflow:hidden; border-radius:var(--r-xl); padding:80px clamp(30px,6vw,80px); text-align:center; background:linear-gradient(140deg,#F6EFE0,#EFE7D3); box-shadow:var(--shadow-sm); }
.price-pill{ display:inline-flex; align-items:center; gap:8px; background:#fff; color:var(--sage-d); border:1px solid var(--sage-line); padding:10px 20px; border-radius:var(--r-pill); font-weight:700; box-shadow:var(--shadow-sm); margin-bottom:22px; }
.price-pill .dot-gold{ width:8px; height:8px; border-radius:50%; background:var(--gold); }
.highlight h2{ font-size:clamp(28px,4vw,42px); margin-bottom:16px; }
.highlight p{ font-size:18px; color:var(--muted); max-width:560px; margin:0 auto 30px; }
.highlight .login-note{ font-size:13.5px; color:var(--muted-2); margin-top:18px; }
.highlight .login-note a{ color:var(--sage-d); font-weight:700; }

/* ---------- FAQ ---------- */
.faq{ max-width:780px; margin:0 auto; }
.faq-item{ background:#fff; border:1px solid var(--line); border-radius:var(--r-md); margin-bottom:14px; overflow:hidden; transition:box-shadow .3s ease; }
.faq-item:hover{ box-shadow:var(--shadow-sm); }
.faq-q{ display:flex; align-items:center; justify-content:space-between; width:100%; padding:22px 26px; background:none; border:none; cursor:pointer; text-align:left; font-size:16.5px; font-weight:700; color:var(--ink); }
.faq-q-icon{ width:32px; height:32px; border-radius:50%; background:var(--sage-soft); color:var(--sage-d); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:transform .3s ease, background .3s ease; }
.faq-item.open .faq-q-icon{ background:var(--sage); color:#fff; transform:rotate(45deg); }
.faq-q-icon svg{ width:14px; height:14px; }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .35s cubic-bezier(.16,1,.3,1); }
.faq-a-inner{ padding:0 26px 24px; font-size:15.5px; color:var(--muted); line-height:1.7; }

/* ---------- ABSCHLUSS-CTA ---------- */
.cta-final{ position:relative; overflow:visible; border-radius:var(--r-xl); padding:90px clamp(30px,6vw,80px); text-align:center; background:linear-gradient(140deg,var(--sage),var(--sage-d)); color:#fff; box-shadow:var(--shadow); }
.cta-final::after{ content:""; position:absolute; inset:0; border-radius:var(--r-xl); pointer-events:none; overflow:hidden; }
.cta-final h2{ color:#fff; font-size:clamp(30px,4.4vw,48px); margin-bottom:14px; }
.cta-final p{ font-size:18px; color:rgba(255,255,255,.9); max-width:520px; margin:0 auto 32px; }

/* Naturalistische Eukalyptus-Zweige im CTA */
.euka-branch{ position:absolute; color:#fff; pointer-events:none; height:auto; }
.euka-branch.eb-bl{ bottom:-30px; left:-60px; width:380px; }
.euka-branch.eb-tr{ top:-25px; right:-50px; width:280px; }

/* ---------- FOOTER ---------- */
.footer{ background:var(--deep); color:rgba(255,255,255,.72); padding:70px 0 34px; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:40px; }
.footer .brand{ color:#fff; margin-bottom:14px; }
.footer p{ font-size:14.5px; max-width:280px; }
.footer h4{ font-family:'Inter',sans-serif; font-size:13px; letter-spacing:.08em; text-transform:uppercase; color:#fff; margin-bottom:16px; }
.footer a, .footer button.linklike{ display:block; font-size:14.5px; color:rgba(255,255,255,.72); margin:9px 0; background:none; border:none; cursor:pointer; padding:0; text-align:left; }
.footer a:hover, .footer button.linklike:hover{ color:#fff; }
.footer-bottom{ margin-top:50px; padding-top:24px; border-top:1px solid rgba(255,255,255,.12); font-size:13px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; }

/* ---------- LIGHTBOX ---------- */
.lightbox{ display:none; position:fixed; inset:0; z-index:180; background:rgba(20,26,21,.94); align-items:center; justify-content:center; opacity:0; transition:opacity .3s ease; }
.lightbox.show{ display:flex; }
.lightbox.in{ opacity:1; }
.lb-img{ max-width:90vw; max-height:84vh; border-radius:var(--r-md); box-shadow:0 30px 80px rgba(0,0,0,.6); }
.lb-btn{ position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.14); border:none; color:#fff; width:54px; height:54px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.lb-btn:hover{ background:rgba(255,255,255,.26); }
.lb-prev{ left:30px; }
.lb-next{ right:30px; }
.lb-close{ position:absolute; top:30px; right:30px; background:rgba(255,255,255,.14); border:none; color:#fff; width:44px; height:44px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.lb-close:hover{ background:rgba(255,255,255,.26); }
.lb-count{ position:absolute; bottom:24px; left:50%; transform:translateX(-50%); color:rgba(255,255,255,.7); font-size:13px; font-weight:600; }

/* ---------- MODAL (Registrierung & Cookie Settings) ---------- */
.modal{ display:none; position:fixed; inset:0; z-index:160; align-items:center; justify-content:center; background:rgba(20,26,21,.6); backdrop-filter:blur(4px); opacity:0; transition:opacity .3s ease; padding:20px; overflow-y:auto; }
.modal.show{ display:flex; }
.modal.in{ opacity:1; }
.modal-card{ background:#fff; border-radius:var(--r-xl); max-width:640px; width:100%; padding:42px clamp(24px,4vw,46px); position:relative; box-shadow:var(--shadow-lg); transform:translateY(20px) scale(.98); transition:transform .35s cubic-bezier(.16,1,.3,1); max-height:calc(100vh - 40px); overflow-y:auto; margin:auto; }
.modal.in .modal-card{ transform:none; }
.modal-close{ position:absolute; top:18px; right:18px; background:var(--bg-2); border:none; color:var(--ink); width:38px; height:38px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .2s ease; }
.modal-close:hover{ background:var(--sage-soft); color:var(--sage-d); }
.modal-card h3{ font-size:26px; margin-bottom:8px; padding-right:40px; }
.modal-card .modal-lead{ font-size:15px; color:var(--muted); margin-bottom:24px; }

/* Form */
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-field{ display:flex; flex-direction:column; gap:6px; }
.form-field.full{ grid-column:1 / -1; }
.form-field label{ font-size:13.5px; font-weight:700; color:var(--ink); }
.form-field label .req{ color:var(--sage); }
.form-field input, .form-field select{ font-family:inherit; font-size:15px; padding:13px 16px; border:1.5px solid var(--line); border-radius:var(--r-sm); background:var(--bg); color:var(--ink); transition:border-color .2s ease, background .2s ease; }
.form-field input:focus, .form-field select:focus{ border-color:var(--sage); background:#fff; outline:none; }
.form-field input.error, .form-field select.error{ border-color:#C25A5A; background:#FDF1F1; }
.form-field .hint{ font-size:12.5px; color:var(--muted); }
.form-field .err-msg{ font-size:12.5px; color:#C25A5A; font-weight:600; display:none; }
.form-field.err .err-msg{ display:block; }
.checkbox{ display:flex; align-items:flex-start; gap:12px; cursor:pointer; padding:14px 0; }
.checkbox input{ width:auto; margin-top:3px; cursor:pointer; accent-color:var(--sage); flex-shrink:0; }
.checkbox .check-text{ font-size:13.5px; color:var(--muted); line-height:1.55; }
.checkbox .check-text a{ color:var(--sage-d); text-decoration:underline; }
.modal-footer{ margin-top:8px; }
.modal-footer .btn{ width:100%; justify-content:center; }
.form-submit-error{ background:#FDECEC; border:1px solid #F5C2C2; color:#9A3D3D; padding:14px 18px; border-radius:var(--r-md); font-size:14px; line-height:1.55; margin:0 0 14px; }
.form-submit-error a{ color:#9A3D3D; text-decoration:underline; }

/* Cookie Settings spezifisch */
.cookie-cat{ background:var(--bg); border-radius:var(--r-sm); padding:18px 20px; margin-bottom:14px; display:flex; align-items:flex-start; justify-content:space-between; gap:18px; }
.cookie-cat-text h4{ font-family:'Inter',sans-serif; font-size:15px; font-weight:700; color:var(--ink); margin-bottom:4px; }
.cookie-cat-text p{ font-size:13.5px; color:var(--muted); margin:0; line-height:1.55; }
.toggle{ position:relative; width:46px; height:26px; flex-shrink:0; margin-top:4px; }
.toggle input{ opacity:0; width:0; height:0; }
.toggle .slider{ position:absolute; cursor:pointer; inset:0; background:#D6D2C5; border-radius:26px; transition:background .25s ease; }
.toggle .slider::before{ content:""; position:absolute; height:20px; width:20px; left:3px; top:3px; background:#fff; border-radius:50%; transition:transform .25s ease; box-shadow:0 2px 4px rgba(0,0,0,.15); }
.toggle input:checked + .slider{ background:var(--sage); }
.toggle input:checked + .slider::before{ transform:translateX(20px); }
.toggle input:disabled + .slider{ background:var(--sage); opacity:.55; cursor:not-allowed; }

.modal-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:18px; }
.modal-actions .btn{ flex:1; min-width:140px; }

/* ---------- COOKIE BANNER ---------- */
/* ---------- COOKIE BANNER (sperrend, zentriert) ---------- */
.cookie-backdrop{ position:fixed; inset:0; background:rgba(40,51,43,.45); backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); z-index:148; opacity:0; pointer-events:none; transition:opacity .35s ease; }
.cookie-backdrop.show{ opacity:1; pointer-events:auto; }
.cookie{ position:fixed; bottom:auto; top:50%; left:50%; right:auto; max-width:520px; width:calc(100% - 40px); margin:0; background:#fff; border-radius:var(--r-lg); padding:30px clamp(22px,3vw,32px); box-shadow:var(--shadow-lg); z-index:150; transform:translate(-50%,-50%) scale(.96); opacity:0; pointer-events:none; transition:transform .4s cubic-bezier(.16,1,.3,1), opacity .3s ease; border:1px solid var(--line); }
.cookie.show{ transform:translate(-50%,-50%) scale(1); opacity:1; pointer-events:auto; }
.cookie h3{ font-family:'Inter',sans-serif; font-size:18px; font-weight:800; margin-bottom:10px; color:var(--ink); }
.cookie p{ font-size:14px; color:var(--muted); margin-bottom:20px; line-height:1.65; }
.cookie p a{ color:var(--sage-d); text-decoration:underline; }
.cookie-actions{ display:flex; gap:8px; flex-wrap:wrap; }
.cookie-actions .btn{ padding:11px 18px; font-size:13.5px; flex:1; min-width:0; justify-content:center; }

/* ---------- VIDEO-CONSENT-INLINE (Vimeo blockiert ohne Zustimmung) ---------- */
.video-consent{ position:absolute; inset:0; z-index:3; background:linear-gradient(180deg, rgba(40,51,43,.78), rgba(40,51,43,.92)); display:flex; flex-direction:column; align-items:center; justify-content:center; padding:24px clamp(18px,3vw,32px); text-align:center; gap:14px; }
.video-consent .vc-ic{ width:54px; height:54px; border-radius:50%; background:rgba(255,255,255,.12); color:#fff; display:flex; align-items:center; justify-content:center; }
.video-consent .vc-ic svg{ width:26px; height:26px; }
.video-consent h4{ font-family:'Inter',sans-serif; color:#fff; font-size:16px; font-weight:700; margin:0; max-width:340px; line-height:1.4; }
.video-consent p{ color:rgba(255,255,255,.82); font-size:13px; max-width:380px; line-height:1.55; margin:0; }
.video-consent .vc-btn{ display:inline-flex; align-items:center; gap:8px; background:#fff; color:var(--sage-d); border:none; padding:12px 22px; border-radius:var(--r-pill); font-weight:700; font-size:14px; cursor:pointer; box-shadow:0 8px 24px -8px rgba(0,0,0,.4); margin-top:4px; transition:transform .2s ease; }
.video-consent .vc-btn:hover{ transform:translateY(-2px); }
.video-consent .vc-btn svg{ width:16px; height:16px; }
.video-consent .vc-settings{ color:rgba(255,255,255,.7); font-size:12px; background:none; border:none; cursor:pointer; text-decoration:underline; }
.video-consent .vc-settings:hover{ color:#fff; }

/* Body-Sperrung wenn Cookie-Banner aktiv */
body.cookie-locked{ overflow:hidden; }

/* ---------- TOAST ---------- */
.toast{ position:fixed; bottom:30px; left:50%; transform:translateX(-50%) translateY(120%); background:var(--deep); color:#fff; padding:16px 26px; border-radius:var(--r-pill); box-shadow:var(--shadow-lg); z-index:220; display:flex; align-items:center; gap:12px; font-size:14.5px; font-weight:600; transition:transform .4s cubic-bezier(.16,1,.3,1); max-width:90vw; }
.toast.show{ transform:translateX(-50%) translateY(0); }
.toast svg{ width:22px; height:22px; color:#7FBF8F; flex-shrink:0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px){
  .hero{ padding:150px 0 80px; }
  .hero-grid{ grid-template-columns:1fr; gap:50px; }
  .hero-media{ max-width:480px; margin:0 auto; }
  .float-card.fc-1{ left:-10px; bottom:30px; }
  .float-card.fc-2{ right:-10px; top:30px; }
  .cards-3{ grid-template-columns:1fr; gap:22px; }
  .vp-clarify-inner{ grid-template-columns:1fr; gap:24px; }
  .pillars{ grid-template-columns:repeat(2,1fr); }
  .events-grid{ grid-template-columns:repeat(2,1fr); }
  .isabel-grid{ grid-template-columns:1fr; gap:40px; }
  .stats-panel{ grid-template-columns:repeat(2,1fr); gap:40px 30px; padding:50px 30px; }
  .stat + .stat::before{ display:none; }
  .stat:nth-child(2)::before, .stat:nth-child(4)::before{ display:block; left:-15px; }
  .gallery{ grid-template-columns:repeat(3,1fr); grid-auto-rows:180px; }
  .tile:nth-child(1){ grid-column:span 2; grid-row:span 2; }
  .tile:nth-child(2){ grid-column:span 1; grid-row:span 1; }
  .tile:nth-child(3){ grid-column:span 1; grid-row:span 1; }
  .tile:nth-child(4){ grid-column:span 1; grid-row:span 1; }
  .tile:nth-child(5){ grid-column:span 2; grid-row:span 1; }
  .tile:nth-child(6){ grid-column:span 1; grid-row:span 1; }
  .tile:nth-child(7){ grid-column:span 2; grid-row:span 1; }
  .tile:nth-child(8){ grid-column:span 1; grid-row:span 1; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .footer-grid > div:first-child{ grid-column:1 / -1; }
}
@media (max-width: 720px){
  section{ padding:80px 0; }
  .nav-links{ display:none; }
  .burger{ display:flex; }
  .nav-links a.btn{ display:none; }
  .hero-cta{ flex-direction:column; }
  .hero-cta .btn{ width:100%; justify-content:center; }
  .hero-trust{ flex-wrap:wrap; }
  .pillars{ grid-template-columns:1fr; }
  .events-grid{ grid-template-columns:1fr; }
  .float-card{ display:none; }
  .gallery{ grid-template-columns:repeat(2,1fr); grid-auto-rows:160px; }
  .tile:nth-child(1){ grid-column:span 2; grid-row:span 2; }
  .tile:nth-child(2){ grid-column:span 1; grid-row:span 1; }
  .tile:nth-child(3){ grid-column:span 1; grid-row:span 2; }
  .tile:nth-child(4){ grid-column:span 1; grid-row:span 1; }
  .tile:nth-child(5){ grid-column:span 2; grid-row:span 1; }
  .tile:nth-child(6){ grid-column:span 1; grid-row:span 1; }
  .tile:nth-child(7){ grid-column:span 1; grid-row:span 1; }
  .tile:nth-child(8){ grid-column:span 2; grid-row:span 1; }
  .lb-prev{ left:14px; }
  .lb-next{ right:14px; }
  .form-grid{ grid-template-columns:1fr; }
  .stats-panel{ padding:40px 22px; }
  .stat .num{ font-size:42px; }
  .stat + .stat::before{ display:none !important; }
  .photo-band .inner{ padding:46px 26px; }
  .footer-grid{ grid-template-columns:1fr; }
  .modal{ align-items:flex-start; padding:14px; }
  .modal-card{ padding:30px 22px; max-height:none; transform:none !important; margin:0 auto; }
  .modal-card h3{ font-size:22px; }
  .cookie{ padding:22px 20px; }
  .cookie-actions{ flex-direction:column; }
  .cookie-actions .btn{ width:100%; }
}

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation:none !important; transition:none !important; }
  [data-reveal], [data-stagger] > *{ opacity:1 !important; transform:none !important; }
}
/* ---------- KONZEPT-UNTERSEITE: Step-Blocks ---------- */
.step-block{ display:grid; grid-template-columns:auto 1fr; gap:36px; max-width:880px; margin:0 auto; align-items:start; }
.step-block.reverse{ grid-template-columns:1fr auto; }
.step-block.reverse .step-num{ order:2; }
.step-block.reverse .step-content{ order:1; text-align:right; }
.step-num{ font-family:'Playfair Display',serif; font-size:clamp(80px,10vw,140px); line-height:1; color:var(--sage); opacity:.6; font-weight:700; }
.step-content .eyebrow{ margin-bottom:14px; }
.step-content h2{ font-size:clamp(26px,3.6vw,38px); margin-bottom:18px; }
.step-content p{ font-size:17px; color:var(--muted); margin-bottom:16px; line-height:1.75; }
.step-content p:last-child{ margin-bottom:0; }
@media (max-width: 720px){
  .step-block, .step-block.reverse{ grid-template-columns:1fr; gap:14px; }
  .step-block.reverse .step-num{ order:1; }
  .step-block.reverse .step-content{ order:2; text-align:left; }
  .step-num{ font-size:80px; }
}

/* ---------- LEGAL-TEXT (Impressum / Datenschutz / Disclaimer) ---------- */
.legal-text{ max-width:780px; }
.legal-text h2{ font-size:24px; margin-top:32px; margin-bottom:14px; color:var(--sage-d); }
.legal-text h2:first-child{ margin-top:0; }
.legal-text h3{ font-family:'Inter',sans-serif; font-size:16px; font-weight:700; margin-top:22px; margin-bottom:10px; color:var(--ink); }
.legal-text p{ font-size:15.5px; color:var(--muted); line-height:1.75; margin-bottom:12px; }
.legal-text p strong{ color:var(--ink); }
.legal-text a{ color:var(--sage-d); text-decoration:underline; }
.legal-text ul{ margin:10px 0 16px 22px; }
.legal-text ul li{ font-size:15.5px; color:var(--muted); line-height:1.75; margin-bottom:6px; }
