/* ============================================================
   DER SCHWARZE SCHWAN – One Pager
   Design Tokens
   ============================================================ */
/* Headline-Font (vom Kunden bereitgestellt) */
@font-face{
  font-family:'Schwan Display';
  src:url('font/crunchy.ttf') format('truetype');
  font-weight:400 700;
  font-style:normal;
  font-display:swap;
}

/* Google-Schriften – LOKAL eingebunden (keine Verbindung zu Google / DSGVO) */
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:500;font-display:swap;src:url('font/cormorant-garamond-500i-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:500;font-display:swap;src:url('font/cormorant-garamond-500i-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:600;font-display:swap;src:url('font/cormorant-garamond-600i-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:600;font-display:swap;src:url('font/cormorant-garamond-600i-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:300;font-display:swap;src:url('font/inter-300-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:300;font-display:swap;src:url('font/inter-300-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('font/inter-400-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('font/inter-400-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('font/inter-500-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('font/inter-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('font/inter-600-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('font/inter-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('font/inter-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('font/inter-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Playfair Display';font-style:italic;font-weight:500;font-display:swap;src:url('font/playfair-display-500i-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Playfair Display';font-style:italic;font-weight:500;font-display:swap;src:url('font/playfair-display-500i-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:500;font-display:swap;src:url('font/playfair-display-500-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:500;font-display:swap;src:url('font/playfair-display-500-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:600;font-display:swap;src:url('font/playfair-display-600-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:600;font-display:swap;src:url('font/playfair-display-600-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:700;font-display:swap;src:url('font/playfair-display-700-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Playfair Display';font-style:normal;font-weight:700;font-display:swap;src:url('font/playfair-display-700-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}

:root{
  --purple:        #7C66B1;
  --purple-deep:   #5D4D85;
  --purple-dark:   #3E3359;
  --gold:          #D4AF6A;
  --gold-soft:     #E8D5A8;
  --cream:         #FAF6EF;
  --beige:         #F3ECE0;
  --ink:           #1A1326;
  --ink-soft:      #4A4256;
  --white:         #FFFFFF;
  --line:          rgba(124,58,237,.14);
  --shadow-sm:     0 4px 20px rgba(59,7,100,.06);
  --shadow-md:     0 18px 50px rgba(59,7,100,.12);
  --shadow-lg:     0 30px 80px rgba(59,7,100,.18);
  --radius:        20px;
  --radius-sm:     14px;
  --ease:          cubic-bezier(.16,.84,.44,1);
  --maxw:          1180px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-weight:400;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:600;line-height:1.12;letter-spacing:-.01em}
/* Script-Font nur für große Headlines */
.section-title{font-family:'Schwan Display','Playfair Display',Georgia,serif;letter-spacing:0;-webkit-text-stroke:.7px currentColor}

/* ---------- Layout helpers ---------- */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{padding:clamp(64px,9vw,128px) 0}
.eyebrow{
  display:inline-block;font-family:'Inter',sans-serif;font-weight:600;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--purple);margin-bottom:18px;
}
.section-title{font-size:clamp(2rem,4.6vw,3.3rem);margin-bottom:18px;color:var(--ink)}
.section-intro{max-width:620px;color:var(--ink-soft);font-size:1.08rem}
.center{text-align:center}
.center .section-intro{margin-left:auto;margin-right:auto}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-family:'Inter',sans-serif;font-weight:600;font-size:.98rem;
  padding:15px 30px;border-radius:999px;cursor:pointer;border:none;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .35s var(--ease);
  white-space:nowrap;
}
.btn-primary{background:var(--purple);color:#fff;box-shadow:0 12px 30px rgba(124,58,237,.34)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(124,58,237,.45);background:var(--purple-deep)}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 16px 36px rgba(212,175,106,.45)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.5)}
.btn-ghost:hover{background:rgba(255,255,255,.12);transform:translateY(-3px)}
.btn-outline{background:transparent;color:var(--purple);border:1.5px solid var(--purple)}
.btn-outline:hover{background:var(--purple);color:#fff;transform:translateY(-3px)}
.btn .arrow{transition:transform .35s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:10px 32px;background:var(--purple);
  transition:box-shadow .4s var(--ease),padding .4s var(--ease);
}
.nav.scrolled{box-shadow:0 6px 26px rgba(62,51,89,.32);padding:6px 32px}
.brand{display:flex;align-items:center;flex:0 0 auto}
.brand-logo{height:56px;width:auto;display:block;transition:height .4s var(--ease)}
.nav.scrolled .brand-logo{height:46px}
.nav-links{display:flex;align-items:center;gap:clamp(18px,2vw,34px)}
.nav-links a{font-size:1rem;font-weight:500;color:rgba(255,255,255,.92);position:relative;transition:color .3s;white-space:nowrap}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--gold);transition:width .3s var(--ease)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a:hover{color:#fff}
.nav-links a.active{color:var(--gold)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:120}
.burger span{width:26px;height:2px;background:#fff;border-radius:2px;transition:transform .35s var(--ease),opacity .3s}
.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)}

/* ============================================================
   1 · HERO
   ============================================================ */
.hero{
  position:relative;overflow:hidden;
  background:var(--purple);
  padding:84px 0 0; /* oben Platz für fixierte Nav; unten schließt die Welle ab */
}
.hero__wave{display:block;width:100%;height:clamp(48px,6vw,98px);margin:clamp(26px,4vw,4px) 0 -1px}
.hero__wave path{fill:var(--white)}
.hero__banner{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;
  padding:14px 32px 0; /* bündig zu Logo (links) und Menü (rechts) – wie die Nav */
}
.hero__img{margin:0;border-radius:18px;overflow:hidden;aspect-ratio:16/11;box-shadow:0 18px 46px rgba(62,51,89,.4)}
.hero__img img{width:100%;height:100%;object-fit:cover;display:block}

/* ============================================================
   2 · WERTE
   ============================================================ */
.values{background:var(--white)}
.coaching{background:var(--white)}
.philosophy{background:var(--white)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:34px}
.value-card{
  background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);
  padding:36px 30px;transition:transform .5s var(--ease),box-shadow .7s var(--ease),border-color .6s var(--ease);
}
.value-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:transparent}
/* höhere Spezifität als .reveal, damit der Schatten weich (nicht hart) einblendet */
.values-grid .value-card{transition:opacity .7s var(--ease),transform .5s var(--ease),box-shadow .7s var(--ease),border-color .6s var(--ease)}
/* ===== Vorstellungs-/Video-Sektion (beiger Hintergrund, schmaler Content) ===== */
.video-sec{background:var(--beige);padding:clamp(20px,2.5vw,36px) 0;overflow:visible;position:relative}
/* beige Wellen oben/unten */
.vs-wave{position:absolute;left:0;width:100%;height:clamp(24px,3vw,46px);display:block;z-index:0;pointer-events:none}
.vs-wave path{fill:var(--beige)}
.vs-wave--top{top:0;transform:translateY(calc(-100% + 1px))}
.vs-wave--bottom{bottom:0;transform:translateY(calc(100% - 1px))}
.vs-watermark-clip{position:absolute;inset:0;overflow:hidden;z-index:0;pointer-events:none}
.vs-watermark{
  position:absolute;top:50%;left:calc(50% - 900px);transform:translateY(-50%);
  height:122%;width:auto;
  opacity:.08;mix-blend-mode:multiply;user-select:none;
}
.video-inner{
  position:relative;z-index:1;
  max-width:940px;margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:1fr minmax(240px,300px);
  gap:clamp(34px,5vw,68px);align-items:center;
}
.intro-title{font-family:'Schwan Display','Playfair Display',Georgia,serif;letter-spacing:0;color:var(--purple);font-size:clamp(2.5rem,5.4vw,4.2rem);margin-bottom:16px}
.intro-text{color:var(--ink-soft);font-size:1.08rem}
.video-wrap{
  aspect-ratio:9/16;width:100%;max-width:300px;margin:clamp(-92px,-9vw,-52px) auto;position:relative;z-index:1;
  border-radius:var(--radius);overflow:hidden;background:#000;
  box-shadow:0 18px 46px rgba(62,51,89,.4); /* Schatten wie bei den Hero-Bildern */
}
.video-wrap video{display:block;width:100%;height:100%;object-fit:cover}
/* ===== Story · neue Version Unter-Hero ===== */
.story{background:var(--white);padding:56px 0 61px}
.story-inner{max-width:1220px;margin:0 auto;padding:0 24px}
.story-head{text-align:center;margin:0 0 clamp(25px,3.2vw,39px)}
.story-title{font-family:'Schwan Display','Playfair Display',Georgia,serif;letter-spacing:0;color:var(--purple);font-size:clamp(2.6rem,5.2vw,4rem);line-height:1.12;-webkit-text-stroke:.6px currentColor;margin:0}
.story-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.story-text{grid-column:1 / 3;padding-right:60px}
.story-text > p{color:var(--ink-soft);font-size:1.06rem;line-height:1.8;margin-bottom:20px}
.story-text strong{font-weight:500;color:var(--purple)}
.story-media{grid-column:3;align-self:start}
.story-video{aspect-ratio:9/16;width:100%;margin:0 auto;border-radius:var(--radius);overflow:hidden;background:#000;box-shadow:0 0 44px 4px rgba(62,51,89,.38)}
.story-video video{display:block;width:100%;height:100%;object-fit:cover}
/* Zitat */
.story-quote{margin:clamp(25px,3.4vw,36px) 0;padding:0;text-align:center}
.story-quote::before{content:"\201C";display:block;font-family:'Cormorant Garamond',Georgia,serif;font-weight:600;font-size:clamp(3.4rem,5.5vw,4.6rem);line-height:.7;color:var(--gold);margin-bottom:0}
.story-quote blockquote{margin:0 auto;max-width:36ch;font-family:'Cormorant Garamond',Georgia,serif;font-style:italic;font-weight:600;font-size:clamp(1.35rem,2vw,1.75rem);line-height:1.4;color:var(--gold)}
.story-quote::after{content:"";display:block;width:48px;height:2px;border-radius:2px;background:var(--gold);margin:14px auto 0}
/* Boxen */
.story-boxes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:clamp(35px,3.5vw,46px)}
.sbox{background:#F8F3EA;border-radius:var(--radius);padding:30px 28px;overflow-wrap:break-word}
.sico{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;margin-bottom:16px;background:linear-gradient(135deg,rgba(124,102,177,.14),rgba(212,175,106,.18))}
.sico svg{width:24px;height:24px;stroke:var(--purple);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.sbox h3{font-family:'Inter',sans-serif;font-weight:600;font-size:1.12rem;letter-spacing:-.01em;color:var(--ink);margin-bottom:10px}
.sbox p{color:var(--ink-soft);font-size:.98rem;line-height:1.7}
/* Schluss-Satz */
.story-closing{text-align:center;max-width:760px;margin:clamp(40px,5vw,64px) auto 0;font-size:1.12rem;line-height:1.7;color:var(--ink);font-weight:500}
/* ===== Feature · Bild links (full-bleed) + Content rechts ===== */
.feature{background:var(--white);padding:62px 0 62px;display:grid;grid-template-columns:1fr 1fr;align-items:start}
.feature__media{grid-column:1;min-width:0}
.feature__img{
  display:block;aspect-ratio:16/11;width:100%;object-fit:cover;
  border-radius:0 26px 26px 0;box-shadow:0 22px 54px rgba(62,51,89,.16);
}
.feature__videowrap{border-radius:0 26px 26px 0;overflow:hidden;box-shadow:0 18px 40px rgba(62,51,89,.14);line-height:0}
.feature__video{display:block;width:100%;height:auto}
.feature__content{grid-column:2;padding:clamp(30px,5vw,56px) max(24px,calc(50vw - 586px)) clamp(30px,5vw,56px) clamp(34px,5vw,64px)}
.feature__title{font-family:'Schwan Display','Playfair Display',Georgia,serif;letter-spacing:0;color:var(--purple);font-size:clamp(2.4rem,4.5vw,3.4rem);line-height:1.1;-webkit-text-stroke:.6px currentColor;margin-bottom:20px}
.feature__text{color:var(--ink-soft);font-size:1.08rem;line-height:1.75;margin-bottom:30px}
.feature__text strong{font-weight:500;color:var(--purple)}
.feature__ph{display:grid;place-items:center;aspect-ratio:16/11;width:100%;border-radius:0 26px 26px 0;background:linear-gradient(135deg,#d3cadf,#e9e1d3);box-shadow:0 22px 54px rgba(62,51,89,.16)}
.feature__ph span{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--purple-deep);opacity:.75}
/* gespiegelt: Bild rechts, Text links (linke Kante = Außenkante linke Box) */
.feature--reverse .feature__media{grid-column:2;grid-row:1}
.feature--reverse .feature__content{grid-column:1;grid-row:1;padding-left:max(24px,calc(50vw - 586px));padding-right:clamp(34px,5vw,64px)}
.feature--reverse .feature__img,.feature--reverse .feature__ph{border-radius:26px 0 0 26px}
/* Tier-Coaching-Ausbildung */
.feature--sticky{padding-bottom:6px}
.feature--sticky .feature__content{padding-top:0}
.feature--sticky .feature__text{font-size:1.06rem;line-height:1.8;margin-bottom:20px}
.feature--sticky .feature__content .btn{margin-top:10px}
/* ===== Erfahre · lila Kombi-Bereich (Botschaften + Begegnungen) ===== */
.erfahre{position:relative;background:var(--purple);color:#fff;padding:clamp(67px,8.4vw,105px) 0}
.erfahre__wave{position:absolute;left:0;width:100%;height:clamp(40px,5vw,82px);z-index:1;display:block;pointer-events:none}
.erfahre__wave path{fill:var(--white)}
.erfahre__wave--top{top:-1px;transform:scaleY(-1)}
.erfahre__wave--bottom{bottom:-1px}
.erfahre .container{position:relative;z-index:2;max-width:1220px}
.erfahre__title{font-family:'Schwan Display','Playfair Display',Georgia,serif;letter-spacing:0;color:var(--gold);text-align:center;font-size:clamp(2.6rem,5.2vw,4rem);line-height:1.1;-webkit-text-stroke:.6px currentColor;margin:0 0 clamp(25px,3.5vw,39px)}
.erfahre-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);max-width:none;margin:0 auto}
.ec{text-align:center}
.ec__img{display:block;width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:18px;box-shadow:0 18px 46px rgba(0,0,0,.2);margin-bottom:24px}
.ec__img--ph{display:grid;place-items:center;box-shadow:none;border:2px dashed rgba(255,255,255,.45);background:rgba(255,255,255,.08)}
.ec__img--ph span{font-family:'Inter',sans-serif;font-size:.85rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7)}
.ec__title{font-family:'Schwan Display','Playfair Display',Georgia,serif;letter-spacing:0;color:var(--gold);font-size:clamp(2.5rem,3.9vw,3.3rem);line-height:1.1;margin-bottom:14px}
/* Überschriften im Gold-Verlauf des Logo-Schriftzugs */
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  .ec__title,.erfahre__title{background:linear-gradient(165deg,#F7E48F 0%,#E2C673 48%,#CCA049 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
  .erfahre__title{-webkit-text-stroke-width:0}
}
.ec__text{color:rgba(255,255,255,.9);font-size:1.02rem;line-height:1.7;max-width:58ch;margin:0 auto 24px}
.erfahre-contact{text-align:center;margin:clamp(40px,5.5vw,64px) auto 0;color:rgba(255,255,255,.85);font-size:1.02rem;line-height:1.7}
.erfahre-contact a{color:var(--gold-soft);text-decoration:none;transition:color .3s}
.erfahre-contact a:hover{color:#fff}
.btn-goldline{background:transparent;color:var(--gold);border:1.5px solid var(--gold)}
.btn-goldline:hover{background:var(--gold);color:var(--purple-deep);transform:translateY(-3px)}
/* ===== Termine 2026 (Kalenderblatt) ===== */
.termine{background:var(--white);padding:56px 0 clamp(45px,6.3vw,77px)}
.termine .container{max-width:1220px}
.termine__head{text-align:center;margin-bottom:clamp(22px,3.2vw,35px)}
.termine__title{font-family:'Schwan Display','Playfair Display',Georgia,serif;letter-spacing:0;color:var(--purple);font-size:clamp(2.6rem,5.2vw,4rem);line-height:1.1;-webkit-text-stroke:.6px currentColor;margin-bottom:10px}
.termine__sub{color:var(--ink-soft);font-size:1.05rem}
.termine-table{overflow-x:auto;border-radius:18px;box-shadow:var(--shadow-md);border:1px solid var(--line);-webkit-overflow-scrolling:touch}
.termine-table table{width:100%;border-collapse:collapse;min-width:760px;font-size:.95rem;table-layout:fixed}
.termine-table td,.termine-table th{overflow-wrap:break-word}
.termine-table td:nth-child(4),.termine-table th:nth-child(4){white-space:nowrap}
.termine-table thead th{background:var(--purple);color:#fff;font-family:'Inter',sans-serif;font-weight:600;text-align:left;padding:15px 18px;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}
.termine-table tbody td{padding:14px 18px;border-top:1px solid var(--line);vertical-align:top;color:var(--ink-soft);line-height:1.5}
.termine-table tbody tr:nth-child(even){background:#FBF8F2}
.termine-table .t-date{color:var(--purple);font-weight:600;white-space:nowrap}
.termine-table .t-title{color:var(--ink);font-weight:500}
.termine-table .t-title a{color:inherit;text-decoration:none;border-bottom:1px solid transparent;transition:color .2s ease,border-color .2s ease}
.termine-table .t-title a:hover{color:var(--purple);border-bottom-color:var(--purple)}
.termine-table .t-title a:hover .t-linkicon{opacity:1}
.t-linkicon{display:inline-block;vertical-align:-1px;margin-left:5px;opacity:.55;transition:opacity .2s ease}
.termine-table .t-price{color:#A87C2E;font-weight:600;white-space:nowrap}
.termine-table tr.t-highlight{background:#FBF8F2 !important}
.value-card .ico{
  width:56px;height:56px;border-radius:14px;display:grid;place-items:center;margin:0 auto 20px;
  background:linear-gradient(135deg,rgba(124,102,177,.14),rgba(212,175,106,.18));
}
.value-card .ico svg{width:28px;height:28px;stroke:var(--purple);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.value-card h3{font-family:'Inter',sans-serif;font-weight:600;font-size:1.25rem;letter-spacing:-.01em;margin-bottom:10px}
.value-card p{color:var(--ink-soft);font-size:.98rem}

/* ============================================================
   Two-column splits (3 & 5)
   ============================================================ */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:center}
.split.reverse .split__media{order:2}
.split__text h2{margin-bottom:20px}
.split__text p{color:var(--ink-soft);margin-bottom:18px;font-size:1.06rem}

/* media placeholders */
.media-ph{
  position:relative;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-md);min-height:340px;display:grid;place-items:center;
}
.media-ph.img{background:linear-gradient(135deg,#ECE3F5,#F6EEDC)}
.media-ph.purple{background:linear-gradient(135deg,var(--purple-deep),var(--purple))}
.media-ph .ph-label{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--purple-deep);
  text-align:center;padding:20px;
}
.media-ph.purple .ph-label{color:rgba(255,255,255,.85)}
.media-ph .ph-icon{width:52px;height:52px;border:2px dashed currentColor;border-radius:50%;display:grid;place-items:center;opacity:.8}
.media-ph .ph-icon svg{width:24px;height:24px;stroke:currentColor;fill:none;stroke-width:1.6}
.media-ph.video::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(closest-side at 50% 45%,rgba(212,175,106,.22),transparent 70%);
}
/* offer items */
.offer-item{display:flex;gap:16px;padding:18px 0;border-top:1px solid var(--line)}
.offer-item:last-child{border-bottom:1px solid var(--line)}
.offer-item .num{
  flex:0 0 auto;width:38px;height:38px;border-radius:50%;background:var(--purple);color:#fff;
  display:grid;place-items:center;font-weight:700;font-size:.92rem;
}
.offer-item h4{font-family:'Inter',sans-serif;font-weight:600;font-size:1.05rem;margin-bottom:3px}
.offer-item p{margin:0;font-size:.96rem;color:var(--ink-soft)}

/* ============================================================
   4 · ACADEMY
   ============================================================ */
.academy{background:var(--beige)}
.academy .split__media{order:-1}
.academy ol{counter-reset:step;margin:24px 0 30px}
.academy ol li{
  counter-increment:step;position:relative;padding:13px 0 13px 52px;
  border-bottom:1px solid var(--line);font-weight:500;
}
.academy ol li::before{
  content:counter(step);position:absolute;left:0;top:11px;
  width:34px;height:34px;border-radius:50%;
  background:rgba(124,58,237,.1);color:var(--purple);
  display:grid;place-items:center;font-family:'Playfair Display',serif;font-weight:700;font-size:1rem;
}

/* ============================================================
   6 · PRODUKTE
   ============================================================ */
.products{background:var(--beige)}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:54px}
.product-card{
  background:var(--white);border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.product-card .card-media{height:180px;position:relative;overflow:hidden;background:linear-gradient(135deg,#ECE3F5,#F6EEDC);display:grid;place-items:center}
.product-card .card-media .tag{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--purple-deep);opacity:.7}
.product-card:nth-child(3n+2) .card-media{background:linear-gradient(135deg,#E6DBF4,#EFE3CF)}
.product-card:nth-child(3n) .card-media{background:linear-gradient(135deg,#F0E6D2,#E9DDF6)}
.product-card .card-body{padding:26px 24px 28px;display:flex;flex-direction:column;flex:1}
.product-card h3{font-size:1.28rem;margin-bottom:8px}
.product-card p{color:var(--ink-soft);font-size:.95rem;margin-bottom:18px;flex:1}
.product-link{font-weight:600;color:var(--purple);font-size:.93rem;display:inline-flex;align-items:center;gap:.4em}
.product-link .arrow{transition:transform .3s var(--ease)}
.product-card:hover .product-link .arrow{transform:translateX(5px)}

/* ============================================================
   7 · STIFTUNG
   ============================================================ */
.foundation{
  color:#fff;position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--purple-dark),var(--purple-deep) 70%,var(--purple));
}
.foundation::before{content:"";position:absolute;top:-30%;right:-10%;width:520px;height:520px;border-radius:50%;background:radial-gradient(closest-side,rgba(212,175,106,.18),transparent)}
.foundation .container{position:relative;z-index:1}
.foundation .eyebrow{color:var(--gold-soft)}
.foundation .section-title{color:#fff}
.foundation .split__text p{color:rgba(255,255,255,.82)}
.foundation h3.sub{font-family:'Playfair Display',serif;font-style:italic;color:var(--gold-soft);font-size:1.4rem;font-weight:500;margin-bottom:22px}
.checklist li{position:relative;padding:12px 0 12px 38px;border-bottom:1px solid rgba(255,255,255,.14);color:rgba(255,255,255,.92)}
.checklist li::before{
  content:"";position:absolute;left:0;top:16px;width:20px;height:20px;border-radius:50%;
  background:var(--gold);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round' d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/13px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round' d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/13px no-repeat;
}
.foundation .media-ph.img{background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(212,175,106,.2));box-shadow:none;border:1px solid rgba(255,255,255,.18)}
.foundation .media-ph .ph-label{color:rgba(255,255,255,.85)}

/* ============================================================
   8 · FOOTER / CTA
   ============================================================ */
.cta-band{background:var(--cream);text-align:center}
.cta-band .section-title{max-width:18ch;margin:0 auto 16px}
.cta-band .section-intro{margin:0 auto 36px}
.cta-band .btns{display:flex;justify-content:center;gap:16px;flex-wrap:wrap}
footer{background:var(--purple-deep);color:rgba(255,255,255,.78);padding:60px 0 22px}
.footer-top{display:flex;justify-content:space-between;align-items:flex-start;gap:48px;flex-wrap:wrap;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.12)}
.footer-brand{max-width:320px}
.footer-brand .brand{color:#fff;margin-bottom:14px}
.footer-brand .brand .swan path{fill:var(--gold)}
.footer-brand p{font-size:.95rem;line-height:1.6;color:rgba(255,255,255,.65)}
.footer-cols{display:flex;gap:56px;flex-wrap:wrap}
.footer-col h4,.footer-newsletter h4{font-family:'Inter',sans-serif;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:16px}
.footer-col a{display:block;font-size:.94rem;padding:5px 0;color:rgba(255,255,255,.65);transition:color .3s,transform .3s}
.footer-col a:hover{color:#fff;transform:translateX(5px)}
.footer-newsletter{max-width:340px;flex:1 1 300px}
.newsletter-ph{width:100%;min-width:240px;min-height:120px;display:grid;place-items:center;border:1px dashed rgba(255,255,255,.35);border-radius:12px;background:rgba(255,255,255,.06);color:rgba(255,255,255,.6);font-size:.85rem;letter-spacing:.04em}
.nl-intro{color:rgba(255,255,255,.7);font-size:.9rem;line-height:1.6;margin:0 0 14px}
.nl-form{display:flex;flex-direction:column;gap:10px}
.nl-input{width:100%;padding:12px 14px;border:1px solid rgba(255,255,255,.25);border-radius:8px;background:rgba(255,255,255,.06);color:#fff;font-family:inherit;font-size:.95rem}
.nl-input::placeholder{color:rgba(255,255,255,.5)}
.nl-input:focus{outline:none;border-color:var(--gold);background:rgba(255,255,255,.1)}
.nl-btn{align-self:flex-start;padding:11px 26px;border:0;border-radius:8px;background:var(--gold);color:var(--ink,#241c33);font-family:inherit;font-weight:600;font-size:.95rem;cursor:pointer;transition:opacity .2s ease}
.nl-btn:hover{opacity:.85}
.nl-hint{color:rgba(255,255,255,.45);font-size:.75rem;line-height:1.5;margin:2px 0 0}
.nl-consent{display:flex;align-items:flex-start;gap:9px;font-size:.74rem;line-height:1.45;color:rgba(255,255,255,.58);cursor:pointer}
.nl-consent input{margin:2px 0 0;flex:0 0 auto;width:15px;height:15px;accent-color:var(--gold);cursor:pointer}
.nl-consent a{color:var(--gold-soft);text-decoration:underline}
.nl-consent a:hover{color:#fff}
/* Newsletter-Abmeldung (helle Rechtsseite) */
.unsub-form{display:flex;flex-direction:column;gap:12px;max-width:440px;margin-top:8px}
.unsub-form label{font-family:'Inter',system-ui,sans-serif;font-weight:600;color:var(--ink);font-size:.95rem}
.unsub-input{width:100%;padding:12px 14px;border:1px solid #ccc;border-radius:8px;font-family:inherit;font-size:1rem;color:var(--ink);background:#fff}
.unsub-input:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(124,102,177,.18)}
.unsub-btn{align-self:flex-start;padding:12px 30px;border:0;border-radius:8px;background:var(--purple);color:#fff;font-family:'Inter',system-ui,sans-serif;font-weight:600;font-size:.95rem;cursor:pointer;transition:background .2s ease}
.unsub-btn:hover{background:var(--purple-deep)}
.socials{display:flex;gap:12px;margin-top:28px}
.socials a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;transition:background .3s,transform .3s,border-color .3s}
.socials a:hover{background:var(--purple);border-color:var(--purple);transform:translateY(-3px)}
.socials svg{width:18px;height:18px;fill:rgba(255,255,255,.8)}
.footer-bottom{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;padding-top:20px;font-size:.85rem;color:rgba(255,255,255,.45)}
.footer-bottom a:hover{color:#fff}
.footer-mail{margin-top:10px}
.footer-mail a{color:var(--gold-soft);transition:color .3s}
.footer-mail a:hover{color:#fff}

/* ============================================================
   Scroll reveal
   ============================================================ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}.reveal.d5{transition-delay:.4s}.reveal.d6{transition-delay:.48s}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
  .hero__video::before{animation:none}
}

/* Hero-Slider-Punkte (nur mobil sichtbar) */
.hero__dots{display:none;justify-content:center;gap:10px;margin-top:16px}
.hero__dots button{width:9px;height:9px;border-radius:50%;border:none;padding:0;cursor:pointer;background:rgba(255,255,255,.45);transition:background .3s,transform .3s}
.hero__dots button.active{background:#fff;transform:scale(1.3)}

/* ============================================================
   Responsive – EIN Breakpoint (1024px)
   ============================================================ */
@media (max-width:1024px){
  /* --- Burger-Menü: klappt von oben auf --- */
  .nav-links{
    position:absolute;top:100%;left:0;right:0;
    background:var(--purple);
    flex-direction:column;align-items:stretch;gap:0;
    padding:6px 0;box-shadow:var(--shadow-lg);
    max-height:0;overflow:hidden;opacity:0;visibility:hidden;
    transition:max-height .4s var(--ease),opacity .3s var(--ease),visibility .3s;
  }
  .nav-links.open{max-height:78vh;opacity:1;visibility:visible}
  .nav-links a{color:rgba(255,255,255,.92);font-size:1.08rem;padding:13px 26px}
  .nav-links a::after{display:none}
  .burger{display:flex}

  /* --- Hero: Crossfade der 3 Bilder --- */
  .hero__banner{display:block;position:relative;grid-template-columns:none;gap:0;aspect-ratio:16/11;margin:14px 20px 0;padding:0;transform:none}
  .hero__img{position:absolute;inset:0;aspect-ratio:auto;opacity:0;transition:opacity .8s var(--ease)}
  .hero__img.active{opacity:1}
  .hero__dots{display:flex}

  /* --- Story --- */
  .story{padding:43px 0 46px}
  .story-grid{grid-template-columns:1fr;gap:26px}
  .story-text,.story-media{grid-column:auto;grid-row:auto}
  .story-text{padding-right:0}
  .story-media{order:-1}
  .story-video{max-width:none}
  .story-boxes{grid-template-columns:1fr;gap:16px;margin-top:21px}
  .story-quote{margin:21px 0}

  /* --- Lila Bereiche --- */
  .erfahre{padding:50px 0}
  .erfahre-grid{grid-template-columns:1fr;gap:40px}

  /* --- Feature (Ausbildung) --- */
  .feature{grid-template-columns:1fr;padding:20px 0 41px}
  .feature__media,.feature__content{grid-column:auto;grid-row:auto}
  .feature__media{padding:0 24px}
  .feature__img,.feature__ph,.feature--reverse .feature__img,.feature--reverse .feature__ph{aspect-ratio:16/10;border-radius:18px}
  .feature__videowrap{border-radius:18px}
  .feature__content,.feature--reverse .feature__content{padding:24px 24px 4px;max-width:none;text-align:center}
  .feature--sticky .feature__content{padding-top:26px}

  /* --- Termine als Karten --- */
  .termine{padding:41px 0}
  .termine-table{overflow:visible;border:none;box-shadow:none;border-radius:0}
  .termine-table table{display:block;width:100%;min-width:0;table-layout:auto}
  .termine-table tbody{display:block;width:100%}
  .termine-table thead{display:none}
  .termine-table tbody tr{display:block;background:#FBF8F2;border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:14px}
  .termine-table tbody td{display:block;border:none;padding:3px 0}
  .termine-table .t-date{font-size:1.05rem;margin-bottom:4px}
  .termine-table td:nth-child(4)::before{content:"Uhrzeit: ";color:var(--purple);font-weight:600}
  .termine-table td:nth-child(5)::before{content:"Preis: ";color:var(--purple);font-weight:600}

  /* --- Footer --- */
  .footer-top{flex-direction:column;gap:30px;padding-bottom:20px}

  /* --- Headlines: gut leserlich, nicht zu klein --- */
  .story-title{white-space:normal;font-size:clamp(2.5rem,8.5vw,3.4rem)}
  .erfahre__title{font-size:clamp(2.5rem,8.5vw,3.4rem)}
  .termine__title{font-size:clamp(2.5rem,8.5vw,3.4rem)}
  .legal-title{font-size:clamp(2.5rem,8.5vw,3.4rem)}
  .ec__title{font-size:clamp(2rem,6.5vw,2.6rem)}
  .feature__title{font-size:clamp(1.8rem,6vw,2.3rem)}
}

/* ============================================================
   Rechtliche Unterseiten (Impressum / Datenschutzerklärung)
   ============================================================ */
.legal-page .nav{position:sticky;top:0}
.legal-page footer{padding-top:50px}
.legal-main{background:var(--white);padding:28px 0 48px}
.legal-main .container{max-width:var(--maxw)}
.legal-title{font-family:'Schwan Display','Playfair Display',Georgia,serif;letter-spacing:0;color:var(--purple);font-size:clamp(2.6rem,5.2vw,4rem);line-height:1.1;-webkit-text-stroke:.6px currentColor;margin:0 0 28px}
.legal-main p{color:var(--ink-soft);font-size:1.05rem;line-height:1.8;margin:0 0 18px}
.legal-main p:last-child{margin-bottom:0}
.legal-main h2{font-family:'Inter',system-ui,sans-serif;color:var(--purple);font-size:1.05rem;font-weight:600;line-height:1.25;margin:2rem 0 .6rem}
.legal-main a{color:var(--purple);text-decoration:underline}
.legal-main a:hover{color:var(--purple-deep)}
.legal-main h3{font-family:'Inter',system-ui,sans-serif;color:var(--purple);font-size:1.05rem;font-weight:600;line-height:1.3;margin:1.6rem 0 .4rem}
.legal-main h4{font-family:'Inter',system-ui,sans-serif;color:var(--ink);font-size:1rem;font-weight:500;line-height:1.3;margin:1.1rem 0 .3rem}
.legal-main strong{font-weight:500}
.legal-main ul{color:var(--ink-soft);font-size:1.05rem;line-height:1.8;margin:0 0 18px;padding-left:1.4rem}
.legal-main li{margin:0 0 6px}

/* ============================================================
   Cookie-Consent-Banner
   ============================================================ */
.cc-banner{position:fixed;left:0;right:0;bottom:0;z-index:1000;display:none;padding:18px clamp(16px,4vw,40px);background:var(--purple-deep);color:rgba(255,255,255,.85);box-shadow:0 -8px 30px rgba(0,0,0,.28);font-size:.9rem;line-height:1.55}
.cc-banner.cc-open{display:block}
.cc-fab{position:fixed;left:16px;bottom:16px;z-index:999;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.22);background:var(--purple);color:#fff;display:grid;place-items:center;cursor:pointer;box-shadow:0 6px 18px rgba(0,0,0,.25);transition:transform .2s,background .2s;padding:0}
.cc-fab:hover{background:var(--purple-deep);transform:translateY(-2px)}
.cc-fab svg{width:22px;height:22px}
.cc-fab[hidden]{display:none}
@media (max-width:640px){.cc-fab{left:12px;bottom:12px;width:40px;height:40px}.cc-fab svg{width:20px;height:20px}}
.cc-inner{max-width:var(--maxw);margin:0 auto;display:flex;gap:16px 28px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.cc-text{flex:1 1 380px;min-width:240px}
.cc-text strong{color:#fff;font-weight:600}
.cc-text a{color:var(--gold-soft);text-decoration:underline}
.cc-text a:hover{color:#fff}
.cc-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cc-btn{font-family:inherit;font-size:.9rem;font-weight:600;padding:10px 22px;border-radius:8px;cursor:pointer;border:1px solid transparent;transition:opacity .2s,background .2s,border-color .2s,color .2s}
.cc-accept{background:var(--gold);color:var(--ink,#241c33);border-color:var(--gold)}
.cc-accept:hover{opacity:.85}
.cc-decline{background:transparent;color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.3)}
.cc-decline:hover{border-color:#fff;color:#fff}
@media (max-width:640px){
  .cc-banner{font-size:.85rem;padding:16px 18px}
  .cc-actions{width:100%}
  .cc-actions .cc-btn{flex:1 1 auto;text-align:center}
}
