/* =========================================================
   ONE MORE GmbH - Produktions-Stylesheet (Keystone)
   Designsprache nach Variante A + design-system.json.
   Referenz A (beetroot) = Layout/Rhythmus, Referenz B (cheetah) = Premium-Typo/Motion.
   Palette: Marken-Weinrot / Schwarz / Weiss. Du-Form. Schweizer Konventionen.
   Dieses Stylesheet ist verbindlich fuer ALLE Unterseiten. NICHT aendern.
   Unterseiten ergaenzen nur eigenes <head>-scoped CSS, falls noetig.
   ========================================================= */

/* =========================================================
   SELF-HOSTED FONTS (woff2, latin-Subset, font-display:swap)
   ========================================================= */
@font-face{
  font-family:'Montserrat';
  font-style:normal;font-weight:600;font-display:swap;
  src:url('assets/fonts/montserrat-600.woff2') format('woff2');
}
@font-face{
  font-family:'Montserrat';
  font-style:normal;font-weight:700;font-display:swap;
  src:url('assets/fonts/montserrat-700.woff2') format('woff2');
}
@font-face{
  font-family:'Source Sans 3';
  font-style:normal;font-weight:400;font-display:swap;
  src:url('assets/fonts/source-sans-3-400.woff2') format('woff2');
}
@font-face{
  font-family:'Source Sans 3';
  font-style:normal;font-weight:500;font-display:swap;
  src:url('assets/fonts/source-sans-3-500.woff2') format('woff2');
}

:root{
  /* Farben (Marken-Palette) */
  --brand-wine:#7A1228;
  --brand-wine-hover:#5E0E1F;
  --brand-wine-soft:#9E1A38;
  --bg-light:#FFFFFF;
  --bg-light-alt:#F6F4F2;
  --bg-dark:#121212;
  --bg-dark-soft:#1A1718;
  --text-on-light:#1A1718;
  --text-on-dark:#FFFFFF;
  --text-muted-on-dark:#C9C7C8;
  --text-muted-on-light:#5A5558;
  --line:#E4E1E0;
  --line-on-dark:rgba(255,255,255,0.16);
  --overlay:rgba(18,18,18,0.5);

  /* Layout */
  --container-max:1280px;
  --content-max:1200px;
  --reading-max:1080px;
  --narrow-max:550px;
  --section-pad-x:86px;

  /* Spacing */
  --space-xs:11px;
  --space-s:34px;
  --space-m:68px;
  --space-l:104px;
  --hero-top:130px;
  --card-pad:30px;

  /* Type */
  --font-display:'Montserrat',system-ui,-apple-system,Segoe UI,sans-serif;
  --font-body:'Source Sans 3',system-ui,-apple-system,Segoe UI,sans-serif;
  --ls-caps:1px;

  /* Button */
  --btn-radius:6px;

  /* Motion */
  --reveal-dur:1s;
  --reveal-ease:cubic-bezier(.215,.61,.355,1);
  --hover-dur:.2s;
  --hover-ease:ease;

  /* Demo-/Vorschau-Banner (leicht entfernbar). Auf 0px setzen bei Go-Live. */
  --demo-banner-h:0px;
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:20px;
  line-height:1.6;
  color:var(--text-on-light);
  background:var(--bg-light);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--font-display);margin:0;}
p{margin:0 0 1em;}
ul,ol{margin:0;padding:0;list-style:none;}

.container{
  width:100%;
  max-width:var(--container-max);
  margin-inline:auto;
  padding-inline:var(--section-pad-x);
}
.section{padding-block:var(--space-l);}
.section--alt{background:var(--bg-light-alt);}

/* ---- Accessibility ---- */
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:1200;
  background:var(--brand-wine);color:#fff;padding:12px 20px;
  font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:var(--ls-caps);
}
.skip-link:focus{left:12px;top:calc(var(--demo-banner-h) + 12px);}
a:focus-visible,button:focus-visible,summary:focus-visible,[tabindex]:focus-visible{
  outline:3px solid var(--brand-wine-soft);outline-offset:3px;
}

/* =========================================================
   DEMO-/VORSCHAU-BANNER (Webnio-Konvention, leicht entfernbar)
   Beim Go-Live: dieses Markup loeschen UND --demo-banner-h:0px setzen.
   ========================================================= */
.demo-banner{
  position:fixed;top:0;left:0;width:100%;z-index:1100;
  height:var(--demo-banner-h);
  display:flex;align-items:center;justify-content:center;gap:10px;
  background:var(--bg-dark-soft);color:#fff;
  font-family:var(--font-display);font-weight:600;font-size:12.5px;
  text-transform:uppercase;letter-spacing:var(--ls-caps);
  border-bottom:1px solid var(--line-on-dark);
  padding:0 16px;text-align:center;
}
.demo-banner strong{color:var(--brand-wine-soft);font-weight:700;}

/* =========================================================
   TYPO-BAUSTEINE
   ========================================================= */
.eyebrow{
  font-family:var(--font-display);font-weight:600;
  text-transform:uppercase;letter-spacing:2px;font-size:14px;
  color:var(--brand-wine);margin:0 0 18px;
}
.eyebrow--light{color:var(--text-muted-on-dark);}

.accent-h{
  font-family:var(--font-display);font-weight:600;
  font-size:clamp(28px,4vw,40px);line-height:1.2;
  text-transform:uppercase;letter-spacing:var(--ls-caps);
  color:var(--brand-wine);margin:0 0 28px;
}
.accent-h--on-dark{color:var(--text-on-dark);}

/* Ghost-Frage-Heading (Referenz A: WAS?/WER?) */
.ghost-q{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(48px,9vw,84px);line-height:.9;
  color:transparent;
  -webkit-text-stroke:1.5px var(--line);
  text-stroke:1.5px var(--line);
  margin:0 0 8px;letter-spacing:-1px;
}
.ghost-q--dark{-webkit-text-stroke-color:var(--line-on-dark);text-stroke-color:var(--line-on-dark);}

.lead{
  font-size:clamp(18px,1.4vw,21px);line-height:1.66;
  color:var(--text-muted-on-light);max-width:60ch;
}
.lead--wide{max-width:72ch;}

/* =========================================================
   BUTTONS (genau ein Stil: Weinrot solid + Outline-Pendant)
   ========================================================= */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--font-display);font-weight:700;font-size:17px;
  text-transform:uppercase;letter-spacing:var(--ls-caps);
  padding:18px 34px;border-radius:var(--btn-radius);
  border:2px solid transparent;cursor:pointer;
  transition:all var(--hover-dur) var(--hover-ease);
  line-height:1;text-align:center;
}
.btn--solid{background:var(--brand-wine);color:#fff;border-color:var(--brand-wine);}
.btn--solid:hover{background:var(--brand-wine-hover);border-color:var(--brand-wine-hover);}
.btn--ghost{background:transparent;color:var(--text-on-light);border-color:var(--text-on-light);}
.btn--ghost:hover{background:var(--brand-wine);border-color:var(--brand-wine);color:#fff;}
/* Outline-Variante auf dunklem Grund (Hero, Diagnostik) */
.hero .btn--ghost,.diag .btn--ghost,.subhero .btn--ghost{color:#fff;border-color:#fff;}
.hero .btn--ghost:hover,.diag .btn--ghost:hover,.subhero .btn--ghost:hover{background:var(--brand-wine);border-color:var(--brand-wine);}
.btn--lg{padding:20px 40px;font-size:18px;}
.btn--xl{padding:24px 50px;font-size:19px;}
.btn--block{width:100%;}

/* =========================================================
   TOPBAR / NAV
   transparent ueber Hero, solid #121212 beim Scrollen.
   Fixe Topbar wird um das Demo-Banner nach unten versetzt.
   ========================================================= */
.topbar{
  position:fixed;top:var(--demo-banner-h);left:0;width:100%;z-index:100;
  transition:background var(--hover-dur) var(--hover-ease),box-shadow var(--hover-dur) var(--hover-ease);
}
.topbar__inner{
  max-width:var(--container-max);margin-inline:auto;
  padding:22px var(--section-pad-x);
  display:flex;align-items:center;gap:32px;
}
.topbar__logo{display:inline-flex;align-items:center;}
.topbar__logo img{height:62px;width:auto;transition:height var(--hover-dur) var(--hover-ease);}
.topbar__logo .logo-dark{display:none;}
.topbar__nav{display:flex;gap:28px;margin-left:auto;}
.topbar__nav a{
  font-family:var(--font-display);font-weight:500;font-size:14.5px;
  text-transform:uppercase;letter-spacing:var(--ls-caps);
  color:#fff;padding:6px 0;position:relative;
  transition:color var(--hover-dur) var(--hover-ease);
}
.topbar__nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--brand-wine-soft);transition:width var(--hover-dur) var(--hover-ease);
}
.topbar__nav a:hover::after,.topbar__nav a[aria-current="page"]::after{width:100%;}
.topbar__nav a[aria-current="page"]{color:var(--brand-wine-soft);}
.topbar__cta{padding:12px 22px;font-size:14px;}

/* scrolled state */
.topbar.is-scrolled{background:var(--bg-dark);box-shadow:0 1px 0 var(--line-on-dark);}
.topbar.is-scrolled .topbar__inner{padding-top:14px;padding-bottom:14px;}
.topbar.is-scrolled .topbar__logo img{height:50px;}

/* Variante fuer Unterseiten mit kompaktem Hero: Topbar von Anfang an solid */
.topbar--solid{background:var(--bg-dark);box-shadow:0 1px 0 var(--line-on-dark);}

.burger{display:none;background:none;border:0;flex-direction:column;gap:5px;padding:8px;margin-left:auto;cursor:pointer;}
.burger span{display:block;width:26px;height:2px;background:#fff;transition:all var(--hover-dur) var(--hover-ease);}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0;}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* Mobile-Menue: standardmaessig aus (auch auf Desktop, auch ohne JS). */
.mobile-menu{
  display:none;flex-direction:column;gap:4px;
  background:var(--bg-dark);padding:18px var(--section-pad-x) 28px;
}
.mobile-menu a{
  font-family:var(--font-display);font-weight:600;font-size:16px;
  text-transform:uppercase;letter-spacing:var(--ls-caps);color:#fff;
  padding:14px 0;border-bottom:1px solid var(--line-on-dark);
}
.mobile-menu .btn{margin-top:18px;border-bottom:0;}

/* =========================================================
   HERO (Startseite)
   ========================================================= */
.hero{
  position:relative;min-height:92vh;display:flex;align-items:flex-end;
  color:#fff;overflow:hidden;
}
.hero__media{position:absolute;inset:0;z-index:0;}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:center 42%;}
.hero__overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(18,18,18,.50) 0%,rgba(18,18,18,.30) 38%,rgba(18,18,18,.88) 100%),
    linear-gradient(90deg,rgba(18,18,18,.78) 0%,rgba(18,18,18,.45) 42%,rgba(18,18,18,.12) 75%);
}
.hero__inner{
  position:relative;z-index:1;
  max-width:var(--container-max);margin-inline:auto;width:100%;
  padding:0 var(--section-pad-x) clamp(70px,9vh,120px);
}
.hero__title{
  font-weight:700;font-size:clamp(40px,7vw,82px);line-height:1.0;
  margin:0 0 24px;max-width:16ch;
}
.hero__lead{
  font-size:clamp(18px,1.5vw,22px);line-height:1.55;
  max-width:58ch;color:rgba(255,255,255,.92);margin:0 0 36px;
}
.hero__actions{display:flex;flex-wrap:wrap;gap:16px;}
.hero__scroll{
  position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:1;
}
.hero__scroll span{
  display:block;width:22px;height:36px;border:2px solid rgba(255,255,255,.6);border-radius:14px;position:relative;
}
.hero__scroll span::after{
  content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;border-radius:2px;
  background:#fff;transform:translateX(-50%);animation:scrolldot 1.6s infinite;
}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0);}40%{opacity:1;}80%{opacity:0;transform:translate(-50%,12px);}100%{opacity:0;}}

/* =========================================================
   SUBPAGE-HERO (kompakt, dunkel) - fuer alle Unterseiten
   ========================================================= */
.subhero{
  position:relative;overflow:hidden;color:#fff;
  background:var(--bg-dark);
  padding:calc(var(--hero-top) + var(--demo-banner-h) + 40px) var(--section-pad-x) 64px;
}
.subhero__media{position:absolute;inset:0;z-index:0;}
.subhero__media img{width:100%;height:100%;object-fit:cover;object-position:center 30%;filter:saturate(.85);}
.subhero__overlay{
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(18,18,18,.78) 0%,rgba(18,18,18,.62) 60%,rgba(18,18,18,.88) 100%);
}
.subhero__inner{
  position:relative;z-index:1;max-width:var(--container-max);margin-inline:auto;
}
.subhero__crumbs{
  font-family:var(--font-display);font-weight:600;font-size:13px;
  text-transform:uppercase;letter-spacing:var(--ls-caps);
  color:var(--text-muted-on-dark);margin:0 0 16px;
}
.subhero__crumbs a:hover{color:#fff;}
.subhero__crumbs span{color:var(--brand-wine-soft);}
.subhero__title{
  font-weight:700;font-size:clamp(34px,5.5vw,64px);line-height:1.05;
  margin:0 0 18px;max-width:18ch;
}
.subhero__lead{
  font-size:clamp(17px,1.4vw,20px);line-height:1.55;
  max-width:60ch;color:rgba(255,255,255,.92);margin:0;
}

/* =========================================================
   TRUST-ZEILE (Vertrauen)
   ========================================================= */
.trust{background:var(--bg-dark);color:#fff;}
.trust__inner{
  max-width:var(--container-max);margin-inline:auto;
  padding:48px var(--section-pad-x);
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
}
.trust__item{padding:0 28px;border-left:1px solid var(--line-on-dark);}
.trust__item:first-child{border-left:0;padding-left:0;}
.trust__k{
  display:block;font-family:var(--font-display);font-weight:700;font-size:20px;
  text-transform:uppercase;letter-spacing:var(--ls-caps);color:#fff;margin-bottom:8px;
}
.trust__k::before{content:"";display:inline-block;width:24px;height:3px;background:var(--brand-wine-soft);margin-right:10px;vertical-align:middle;}
.trust__v{display:block;font-size:15px;line-height:1.45;color:var(--text-muted-on-dark);}

/* =========================================================
   WAS? / Leistungen-Teaser
   ========================================================= */
.was{background:var(--bg-light);}
.was__head{
  display:grid;grid-template-columns:0.9fr 1.6fr;gap:48px;align-items:start;
  margin-bottom:var(--space-m);
}
.was__intro .accent-h{margin-top:6px;}
.was__grid{display:grid;grid-template-columns:0.8fr 2fr;gap:56px;align-items:start;}

/* gestapelte Weinrot-Leistungs-Buttons (Referenz A) */
.service-list{display:flex;flex-direction:column;gap:12px;position:sticky;top:calc(var(--hero-top) + var(--demo-banner-h) - 30px);}
.service-list__item{
  display:flex;align-items:center;justify-content:space-between;
  background:var(--brand-wine);color:#fff;
  font-family:var(--font-display);font-weight:600;font-size:16px;
  text-transform:uppercase;letter-spacing:var(--ls-caps);
  padding:18px 22px;border-radius:var(--btn-radius);
  transition:background var(--hover-dur) var(--hover-ease),transform var(--hover-dur) var(--hover-ease);
}
.service-list__item i{font-style:normal;font-size:24px;transition:transform var(--hover-dur) var(--hover-ease);}
.service-list__item:hover{background:var(--brand-wine-hover);transform:translateX(4px);}
.service-list__item:hover i{transform:translateX(4px);}

.areas{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.area figure{margin:0;overflow:hidden;aspect-ratio:4/5;}
.area figure img{width:100%;height:100%;object-fit:cover;filter:saturate(.85);transition:transform .6s var(--reveal-ease);}
.area:hover figure img{transform:scale(1.05);}
.area__body{padding-top:20px;}
.area__body h3{
  font-weight:600;font-size:22px;text-transform:uppercase;letter-spacing:var(--ls-caps);
  margin:0 0 10px;color:var(--text-on-light);
}
.area__body h3::before{content:"";display:block;width:34px;height:3px;background:var(--brand-wine);margin-bottom:14px;}
.area__body p{font-size:16px;line-height:1.55;color:var(--text-muted-on-light);margin:0;}

/* =========================================================
   FEATURE-PANEL (vollschwarz, EINMAL pro Seite)
   ========================================================= */
.panel{background:var(--bg-dark);color:#fff;}
.panel__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;}
.panel__lead{font-size:19px;line-height:1.6;color:var(--text-muted-on-dark);max-width:52ch;margin-bottom:28px;}
.panel__media{margin:0;overflow:hidden;border-radius:8px;}
.panel__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;filter:saturate(.9);}

.ticklist{margin:0 0 32px;display:flex;flex-direction:column;gap:14px;}
.ticklist li{position:relative;padding-left:38px;font-size:17px;line-height:1.45;color:#fff;}
.ticklist li::before{
  content:"";position:absolute;left:0;top:2px;width:24px;height:24px;border-radius:50%;
  background:var(--brand-wine);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9.55 17.6 4.4 12.45l1.4-1.4 3.75 3.75 8.25-8.25 1.4 1.4z'/></svg>") center/16px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9.55 17.6 4.4 12.45l1.4-1.4 3.75 3.75 8.25-8.25 1.4 1.4z'/></svg>") center/16px no-repeat;
}
.ticklist--light li{color:var(--text-on-light);}

.price-block{display:flex;align-items:baseline;gap:10px;margin-bottom:30px;}
.price-block__label{font-family:var(--font-display);font-weight:600;font-size:16px;text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--text-muted-on-dark);}
.price-block__amount{font-family:var(--font-display);font-weight:700;font-size:clamp(34px,4vw,48px);color:var(--brand-wine-soft);line-height:1;}
.price-block__per{font-family:var(--font-display);font-weight:500;font-size:18px;color:var(--text-muted-on-dark);}

/* =========================================================
   WARUM / Erfolgsformel (Timeline)
   ========================================================= */
.warum{background:var(--bg-light-alt);}
.warum .lead--wide{margin-bottom:var(--space-m);}

.formula{
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
  position:relative;padding-top:62px;list-style:none;margin:0;
}
.formula::before{
  content:"";position:absolute;top:21px;left:12.5%;right:12.5%;height:2px;
  background:linear-gradient(90deg,var(--brand-wine) 0%,var(--brand-wine) 66%,var(--brand-wine-soft) 100%);
  z-index:0;
}
.formula__step{position:relative;display:flex;flex-direction:column;}
.formula__node{
  position:absolute;top:-62px;left:50%;transform:translateX(-50%);
  width:22px;height:22px;border-radius:50%;
  background:#fff;border:3px solid var(--brand-wine);z-index:2;
}
.formula__step--accent .formula__node{
  background:var(--brand-wine);border-color:var(--brand-wine);
  box-shadow:0 0 0 6px rgba(122,18,40,.16);
}
.formula__step:nth-child(2){margin-top:26px;}
.formula__step:nth-child(3){margin-top:52px;}
.formula__step:nth-child(4){margin-top:78px;}
.formula__card{position:relative;background:#fff;border:1px solid var(--line);border-radius:8px;padding:30px 26px;}
.formula__card::before{
  content:"";position:absolute;top:-26px;left:50%;transform:translateX(-50%);
  width:2px;height:26px;background:var(--brand-wine);opacity:.45;
}
.formula__step--accent .formula__card{background:var(--brand-wine);border-color:var(--brand-wine);}
.formula__num{
  font-family:var(--font-display);font-weight:700;font-size:18px;
  color:var(--brand-wine);letter-spacing:1px;display:block;margin-bottom:16px;
}
.formula__card h3{font-weight:600;font-size:22px;text-transform:uppercase;letter-spacing:var(--ls-caps);margin:0 0 12px;color:var(--text-on-light);}
.formula__card p{font-size:16px;line-height:1.5;color:var(--text-muted-on-light);margin:0;}
.formula__step--accent .formula__num,
.formula__step--accent .formula__card h3{color:#fff;}
.formula__step--accent .formula__card p{color:rgba(255,255,255,.92);}
.formula__step--accent .formula__card::before{background:#fff;opacity:.6;}

/* =========================================================
   WER? / Inhaber-Block (Bild-Text-Reihe)
   ========================================================= */
.wer{background:var(--bg-light);}
.wer__grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:center;}
.wer__media{margin:0;overflow:hidden;border-radius:8px;}
.wer__media img{width:100%;object-fit:cover;aspect-ratio:4/5;filter:saturate(.88);}
.wer__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:14px;}

/* =========================================================
   TEAM-KARTEN (click-to-expand)
   ========================================================= */
.team-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:var(--space-s);
}
.team-card{
  background:var(--bg-light);border:1px solid var(--line);border-radius:10px;
  overflow:hidden;display:flex;flex-direction:column;text-align:left;
  font:inherit;color:inherit;cursor:pointer;padding:0;width:100%;
  transition:border-color var(--hover-dur) var(--hover-ease),box-shadow var(--hover-dur) var(--hover-ease);
}
.team-card:hover{border-color:var(--brand-wine);box-shadow:0 18px 40px -28px rgba(122,18,40,.45);}
.team-card__photo{position:relative;margin:0;aspect-ratio:4/5;overflow:hidden;background:var(--bg-light-alt);}
.team-card__photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.88);}
/* sauberer Foto-Platzhalter (NACHLIEFERN) */
.team-card__placeholder{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  background:repeating-linear-gradient(135deg,var(--bg-light-alt) 0 14px,#EFEBE9 14px 28px);
  color:var(--text-muted-on-light);
  font-family:var(--font-display);font-weight:600;font-size:12px;
  text-transform:uppercase;letter-spacing:var(--ls-caps);text-align:center;padding:0 18px;
}
.team-card__body{padding:24px 26px 26px;display:flex;flex-direction:column;flex:1;}
.team-card__name{font-weight:700;font-size:22px;text-transform:uppercase;letter-spacing:var(--ls-caps);margin:0 0 6px;color:var(--text-on-light);}
.team-card__role{font-family:var(--font-display);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--brand-wine);margin:0 0 14px;}
.team-card__role--soft{color:var(--text-muted-on-light);}
.team-card__bio{font-size:16px;line-height:1.55;color:var(--text-muted-on-light);margin:0;
  max-height:0;overflow:hidden;opacity:0;
  transition:max-height .4s var(--reveal-ease),opacity .3s var(--hover-ease),margin .3s var(--hover-ease);
}
.team-card[aria-expanded="true"] .team-card__bio{max-height:420px;opacity:1;margin-top:4px;}
.team-card__toggle{
  margin-top:auto;display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-display);font-weight:600;font-size:13px;
  text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--brand-wine);padding-top:16px;
}
.team-card__toggle i{font-style:normal;transition:transform var(--hover-dur) var(--hover-ease);}
.team-card[aria-expanded="true"] .team-card__toggle i{transform:rotate(180deg);}
.team-card__meta{
  font-family:var(--font-display);font-weight:600;font-size:12.5px;text-transform:uppercase;letter-spacing:var(--ls-caps);
  color:var(--text-muted-on-light);margin:14px 0 0;
}
.team-card__meta a{color:var(--brand-wine);}

/* =========================================================
   PROGRAMME (asymmetrische Preis-Karten)
   ========================================================= */
.programme{background:var(--bg-light-alt);}
.programme__head{max-width:var(--reading-max);margin:0 auto var(--space-m);text-align:center;}
.programme__head .accent-h{color:var(--brand-wine);}
.programme__head .lead{margin-inline:auto;}
.prog-cards{display:grid;grid-template-columns:1.08fr .92fr;gap:30px;align-items:start;}
.prog-card{border-radius:10px;overflow:hidden;display:flex;flex-direction:column;}
.prog-card--featured{background:var(--bg-dark);color:#fff;position:relative;box-shadow:0 24px 60px -34px rgba(122,18,40,.55);}
.prog-card--light{background:#fff;border:1px solid var(--line);color:var(--text-on-light);margin-top:34px;}
.prog-card__body{padding:38px 38px 40px;display:flex;flex-direction:column;flex:1;}
.prog-card--light .prog-card__body{padding:40px 36px 38px;}

.prog-card__photo{position:relative;margin:0;aspect-ratio:16/10;overflow:hidden;}
.prog-card__photo img{width:100%;height:100%;object-fit:cover;object-position:center 35%;filter:saturate(.9);}
.prog-card__photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,18,18,0) 55%,rgba(18,18,18,.7) 100%);}
.prog-card__flag{
  position:absolute;top:20px;left:20px;z-index:2;
  background:var(--brand-wine);color:#fff;font-family:var(--font-display);font-weight:700;
  font-size:12px;text-transform:uppercase;letter-spacing:var(--ls-caps);
  padding:8px 15px;border-radius:4px;
}
.prog-card__tag{
  font-family:var(--font-display);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:var(--ls-caps);
  color:var(--brand-wine);margin:0 0 14px;
}
.prog-card__name{font-weight:700;font-size:30px;text-transform:uppercase;letter-spacing:var(--ls-caps);margin:0 0 14px;line-height:1.1;}
.prog-card--featured .prog-card__name{color:#fff;}
.prog-card--light .prog-card__name{color:var(--brand-wine);}
.prog-card__for{font-size:16px;line-height:1.5;margin:0 0 24px;color:var(--text-muted-on-dark);}
.prog-card__for strong{font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:13px;display:block;margin-bottom:4px;color:var(--brand-wine-soft);}
.prog-card--light .prog-card__for{color:var(--text-muted-on-light);}
.prog-card--light .prog-card__for strong{color:var(--brand-wine);}
.ticklist--card{margin-bottom:28px;}
.ticklist--card li{font-size:16px;}
.prog-card__price{margin-top:auto;display:flex;align-items:baseline;gap:8px;padding:22px 0 26px;border-top:1px solid var(--line-on-dark);}
.prog-card__price--light{border-top-color:var(--line);}
.prog-card__from{font-family:var(--font-display);font-weight:600;font-size:15px;text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--text-muted-on-dark);}
.prog-card__amount{font-family:var(--font-display);font-weight:700;font-size:clamp(30px,3.4vw,42px);line-height:1;}
.prog-card--featured .prog-card__amount{color:var(--brand-wine-soft);}
.prog-card--light .prog-card__amount{color:var(--brand-wine);}
.prog-card__per{font-family:var(--font-display);font-weight:500;font-size:17px;color:var(--text-muted-on-light);}
.prog-card--featured .prog-card__per{color:var(--text-muted-on-dark);}
.programme__note{text-align:center;margin-top:36px;font-size:16px;color:var(--text-muted-on-light);}
.programme__note strong{color:var(--brand-wine);}

/* =========================================================
   DIAGNOSTIK-STREIFEN (Bild-Bruch)
   ========================================================= */
.diag{position:relative;color:#fff;min-height:520px;display:flex;align-items:center;overflow:hidden;}
.diag__media{position:absolute;inset:0;z-index:0;}
.diag__media img{width:100%;height:100%;object-fit:cover;object-position:center 30%;}
.diag__overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(18,18,18,.85) 0%,rgba(18,18,18,.55) 55%,rgba(18,18,18,.25) 100%);}
.diag__inner{position:relative;z-index:1;max-width:var(--container-max);margin-inline:auto;width:100%;padding:80px var(--section-pad-x);}
.diag__inner p{max-width:46ch;font-size:19px;line-height:1.6;color:rgba(255,255,255,.92);margin-bottom:28px;}

/* =========================================================
   KUNDENSTIMMEN + YouTube-Thumbnail-Facade
   ========================================================= */
.stimmen{background:var(--bg-light);}
.stimmen .lead--wide{margin-bottom:var(--space-s);}
.stimmen__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:var(--space-s);}
.stimme{margin:0;background:var(--bg-light-alt);border-radius:10px;overflow:hidden;border-top:4px solid var(--brand-wine);display:flex;flex-direction:column;}
/* YouTube-Thumbnail-Facade (statt Buchstaben-Avatar) */
.stimme__thumb{
  position:relative;display:block;margin:0;aspect-ratio:16/10;overflow:hidden;
  background:var(--bg-dark);cursor:pointer;width:100%;border:0;padding:0;
}
.stimme__thumb img{width:100%;height:100%;object-fit:cover;transition:filter var(--hover-dur) var(--hover-ease),transform .6s var(--reveal-ease);filter:brightness(.78);}
.stimme__thumb:hover img{filter:brightness(.6);transform:scale(1.04);}
.stimme__play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:58px;height:58px;border-radius:50%;background:var(--brand-wine);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:20px;padding-left:4px;
  transition:transform var(--hover-dur) var(--hover-ease),background var(--hover-dur) var(--hover-ease);
}
.stimme__thumb:hover .stimme__play{transform:translate(-50%,-50%) scale(1.1);background:var(--brand-wine-hover);}
.stimme__body{padding:30px 30px 32px;display:flex;flex-direction:column;flex:1;}
.stimme__big{font-family:var(--font-display);font-weight:700;font-size:clamp(30px,3.4vw,42px);color:var(--brand-wine);line-height:1;margin:0 0 16px;text-transform:uppercase;}
.stimme__quote{font-size:18px;line-height:1.55;color:var(--text-on-light);margin:0 0 18px;}
.stimme__who{font-family:var(--font-display);font-weight:600;font-size:14px;text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--text-muted-on-light);margin-bottom:0;}
.stimmen__note{margin-top:28px;font-size:14px;line-height:1.55;color:var(--text-muted-on-light);max-width:74ch;}
.stimmen__note a{color:var(--brand-wine);text-decoration:underline;text-underline-offset:2px;}

/* =========================================================
   YOUTUBE-FACADE (click-to-load, ein grosses Video)
   ========================================================= */
.yt{background:var(--bg-light-alt);}
.yt__head{max-width:var(--reading-max);margin:0 auto var(--space-s);text-align:center;}
.yt__head .accent-h,.yt__head .lead{margin-inline:auto;}
.yt-facade{
  position:relative;display:block;border:0;padding:0;cursor:pointer;width:100%;
  border-radius:12px;overflow:hidden;max-width:980px;margin-inline:auto;aspect-ratio:16/9;background:var(--bg-dark);
}
.yt-facade img{width:100%;height:100%;object-fit:cover;filter:brightness(.7) saturate(.9);transition:filter var(--hover-dur) var(--hover-ease);}
.yt-facade:hover img{filter:brightness(.55) saturate(.9);}
.yt-facade__play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:88px;height:88px;border-radius:50%;background:var(--brand-wine);
  color:#fff;font-size:30px;display:flex;align-items:center;justify-content:center;
  padding-left:6px;transition:transform var(--hover-dur) var(--hover-ease),background var(--hover-dur) var(--hover-ease);
}
.yt-facade:hover .yt-facade__play{transform:translate(-50%,-50%) scale(1.08);background:var(--brand-wine-hover);}
.yt-facade__label{
  position:absolute;left:28px;bottom:24px;color:#fff;
  font-family:var(--font-display);font-weight:600;font-size:16px;
  text-transform:uppercase;letter-spacing:var(--ls-caps);text-align:left;
}
/* nach Klick eingesetztes iframe fuellt den Rahmen */
.yt-facade iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}

/* =========================================================
   CTA-BANNER
   ========================================================= */
.cta-banner{background:var(--brand-wine);color:#fff;text-align:center;padding-block:var(--space-l);position:relative;overflow:hidden;}
.cta-banner__inner{position:relative;z-index:1;}
.cta-banner__logo{position:absolute;width:520px;max-width:80vw;opacity:.06;left:50%;top:50%;transform:translate(-50%,-50%);z-index:0;pointer-events:none;}
.cta-banner__title{font-weight:700;font-size:clamp(34px,5vw,60px);line-height:1.05;margin:0 0 20px;}
.cta-banner__lead{font-size:20px;color:rgba(255,255,255,.92);max-width:54ch;margin:0 auto 36px;}
.cta-banner .btn--solid{background:#fff;color:var(--brand-wine);border-color:#fff;}
.cta-banner .btn--solid:hover{background:var(--bg-dark);color:#fff;border-color:var(--bg-dark);}
.cta-banner__hint{margin-top:22px;font-size:14px;color:rgba(255,255,255,.7);}

/* =========================================================
   BUCHUNG (Virtuagym-Widget)
   ========================================================= */
.booking{background:var(--bg-light-alt);}
.booking__head{max-width:var(--reading-max);margin:0 auto var(--space-s);text-align:center;}
.booking__head .accent-h{color:var(--brand-wine);}
.booking__head .lead{margin-inline:auto;}
.booking__head .lead a{color:var(--brand-wine);text-decoration:underline;text-underline-offset:2px;}
.booking__widget{
  max-width:var(--content-max);margin-inline:auto;
  background:#fff;border:1px solid var(--line);border-radius:12px;
  padding:24px;min-height:220px;
}
.booking__fallback{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;min-height:180px;text-align:center;color:var(--text-muted-on-light);font-size:16px;
}

/* =========================================================
   AKKORDEON (FAQ)
   ========================================================= */
.faq{max-width:var(--reading-max);margin-inline:auto;}
.faq__item{border-bottom:1px solid var(--line);}
.faq__item:first-child{border-top:1px solid var(--line);}
.faq__q{
  width:100%;background:none;border:0;cursor:pointer;text-align:left;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:26px 0;color:var(--text-on-light);
  font-family:var(--font-display);font-weight:600;font-size:clamp(17px,1.6vw,20px);
  text-transform:uppercase;letter-spacing:.4px;line-height:1.3;
}
.faq__q:hover{color:var(--brand-wine);}
.faq__icon{flex:0 0 auto;width:24px;height:24px;position:relative;}
.faq__icon::before,.faq__icon::after{content:"";position:absolute;top:50%;left:50%;background:var(--brand-wine);transition:transform var(--hover-dur) var(--hover-ease);}
.faq__icon::before{width:18px;height:2px;transform:translate(-50%,-50%);}
.faq__icon::after{width:2px;height:18px;transform:translate(-50%,-50%);}
.faq__q[aria-expanded="true"] .faq__icon::after{transform:translate(-50%,-50%) scaleY(0);}
.faq__a{overflow:hidden;max-height:0;transition:max-height .4s var(--reveal-ease);}
.faq__a-inner{padding:0 0 26px;font-size:17px;line-height:1.6;color:var(--text-muted-on-light);max-width:70ch;}
.faq__a-inner a{color:var(--brand-wine);text-decoration:underline;text-underline-offset:2px;}

/* =========================================================
   MAPS-FACADE (Google Maps erst nach Consent/Klick)
   ========================================================= */
.maps-facade{
  position:relative;display:flex;align-items:center;justify-content:center;
  width:100%;min-height:340px;border-radius:12px;overflow:hidden;cursor:pointer;
  border:1px solid var(--line);background:var(--bg-dark);text-align:center;
}
.maps-facade__bg{position:absolute;inset:0;opacity:.4;}
.maps-facade__bg img{width:100%;height:100%;object-fit:cover;}
.maps-facade__cta{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:14px;color:#fff;padding:24px;}
.maps-facade__cta p{margin:0;font-size:15px;color:var(--text-muted-on-dark);max-width:40ch;}
.maps-facade iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}

/* =========================================================
   KONTAKT-NAP (Kontaktseite)
   ========================================================= */
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:56px;align-items:start;}
.nap-card{background:var(--bg-light-alt);border:1px solid var(--line);border-radius:12px;padding:38px 34px;}
.nap-card h3{font-weight:700;font-size:18px;text-transform:uppercase;letter-spacing:var(--ls-caps);margin:0 0 20px;color:var(--brand-wine);}
.nap-list li{margin-bottom:16px;font-size:17px;line-height:1.5;color:var(--text-on-light);}
.nap-list li strong{font-family:var(--font-display);font-weight:600;font-size:12.5px;text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--text-muted-on-light);display:block;margin-bottom:2px;}
.nap-list a{color:var(--brand-wine);}
.nap-list a:hover{text-decoration:underline;text-underline-offset:2px;}

/* =========================================================
   LEGAL-TYPO (Impressum / Datenschutz)
   ========================================================= */
.legal{max-width:var(--reading-max);margin-inline:auto;}
.legal h2{font-family:var(--font-display);font-weight:600;font-size:clamp(22px,2.4vw,28px);text-transform:uppercase;letter-spacing:.6px;color:var(--brand-wine);margin:48px 0 16px;}
.legal h2:first-child{margin-top:0;}
.legal h3{font-family:var(--font-display);font-weight:600;font-size:19px;text-transform:uppercase;letter-spacing:.4px;color:var(--text-on-light);margin:30px 0 10px;}
.legal p,.legal li{font-size:17px;line-height:1.7;color:var(--text-on-light);}
.legal ul{list-style:disc;padding-left:22px;margin:0 0 1em;}
.legal ul li{margin-bottom:8px;}
.legal a{color:var(--brand-wine);text-decoration:underline;text-underline-offset:2px;word-break:break-word;}
.legal__updated{font-size:14px;color:var(--text-muted-on-light);margin-bottom:40px;}
.legal table{width:100%;border-collapse:collapse;margin:0 0 1.4em;font-size:15px;}
.legal th,.legal td{text-align:left;padding:12px 14px;border:1px solid var(--line);vertical-align:top;line-height:1.5;}
.legal th{background:var(--bg-light-alt);font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:.4px;font-size:13px;color:var(--text-on-light);}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{background:var(--bg-dark-soft);color:#fff;}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr 1.2fr;gap:48px;padding-block:var(--space-m);}
.footer__logo{height:74px;width:auto;margin-bottom:22px;}
.footer__claim{font-family:var(--font-display);font-weight:700;font-size:22px;margin:0 0 6px;}
.footer__claim-sub{font-size:15px;color:var(--text-muted-on-dark);max-width:30ch;}
.footer__h{font-family:var(--font-display);font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:var(--ls-caps);margin:0 0 20px;color:#fff;}
.footer__col ul li{margin-bottom:12px;}
.footer__col a,.footer__nap li{font-size:15px;color:var(--text-muted-on-dark);transition:color var(--hover-dur) var(--hover-ease);}
.footer__col a:hover{color:#fff;}
.footer__nap li{margin-bottom:8px;line-height:1.4;}
.footer__nap a{color:var(--text-muted-on-dark);}
.footer__nap a:hover{color:#fff;}
.footer__social{margin-top:24px;display:flex;flex-wrap:wrap;gap:8px 18px;}
.footer__social a{font-family:var(--font-display);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:var(--ls-caps);color:#fff;}
.footer__social a:hover{color:var(--brand-wine-soft);}
.footer__bar{
  border-top:1px solid var(--line-on-dark);
  max-width:var(--container-max);margin-inline:auto;
  padding:24px var(--section-pad-x);
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  font-size:13px;color:var(--text-muted-on-dark);
}
.footer__bar p{margin:0;}
.footer__bar a{color:var(--text-muted-on-dark);}
.footer__bar a:hover{color:#fff;}

/* =========================================================
   COOKIE-BANNER
   ========================================================= */
.cookie{
  position:fixed;left:50%;bottom:20px;transform:translateX(-50%);
  z-index:1200;width:min(680px,calc(100% - 32px));
  background:var(--bg-dark-soft);color:#fff;border:1px solid var(--line-on-dark);
  border-radius:12px;padding:24px 26px;box-shadow:0 24px 60px -24px rgba(0,0,0,.6);
  display:none;
}
.cookie.is-visible{display:block;}
.cookie__title{font-family:var(--font-display);font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:var(--ls-caps);margin:0 0 8px;}
.cookie__text{font-size:14.5px;line-height:1.55;color:var(--text-muted-on-dark);margin:0 0 18px;}
.cookie__text a{color:var(--brand-wine-soft);text-decoration:underline;text-underline-offset:2px;}
.cookie__actions{display:flex;flex-wrap:wrap;gap:12px;}
.cookie .btn{padding:13px 24px;font-size:14px;}
.cookie__decline{background:transparent;color:#fff;border-color:var(--line-on-dark);}
.cookie__decline:hover{background:rgba(255,255,255,.08);border-color:#fff;}

/* =========================================================
   REVEAL-MOTION
   ========================================================= */
.reveal{opacity:0;transform:translateY(24px);transition:opacity var(--reveal-dur) var(--reveal-ease),transform var(--reveal-dur) var(--reveal-ease);}
.reveal.is-in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none;}
  .hero__scroll span::after{animation:none;}
  html{scroll-behavior:auto;}
  *{scroll-behavior:auto!important;}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  :root{--section-pad-x:40px;}
  .was__head{grid-template-columns:1fr;gap:24px;}
  .was__grid{grid-template-columns:1fr;gap:40px;}
  .service-list{position:static;flex-direction:row;flex-wrap:wrap;}
  .service-list__item{flex:1 1 240px;}
  .panel__grid,.wer__grid{grid-template-columns:1fr;gap:40px;}
  .panel__media,.wer__media{order:-1;max-width:520px;}
  .contact-grid{grid-template-columns:1fr;gap:36px;}
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .trust__inner{grid-template-columns:1fr 1fr;gap:0;}
  .trust__item{padding:20px 0;border-left:0;border-top:1px solid var(--line-on-dark);}
  .trust__item:nth-child(2){border-left:1px solid var(--line-on-dark);padding-left:24px;}
  .trust__item:nth-child(4){border-left:1px solid var(--line-on-dark);padding-left:24px;}
  .trust__item:nth-child(-n+2){border-top:0;}
  .formula{grid-template-columns:1fr;gap:0;padding-top:0;padding-left:40px;}
  .formula::before{top:8px;bottom:8px;left:9px;right:auto;width:2px;height:auto;
    background:linear-gradient(180deg,var(--brand-wine) 0%,var(--brand-wine) 66%,var(--brand-wine-soft) 100%);}
  .formula__step{margin-top:0!important;padding-bottom:30px;}
  .formula__step:last-child{padding-bottom:0;}
  .formula__node{top:8px;left:-31px;transform:none;}
  .formula__card::before{display:none;}
  .footer__grid{grid-template-columns:1fr 1fr;gap:36px;}
}

@media (max-width:760px){
  :root{--section-pad-x:24px;--space-l:64px;--space-m:48px;}
  body{font-size:18px;}
  .topbar__nav,.topbar__cta{display:none;}
  .burger{display:flex;}
  .topbar.is-scrolled,.topbar--solid{background:var(--bg-dark);}
  .topbar:not(.is-scrolled):not(.topbar--solid){background:rgba(18,18,18,.4);}
  .mobile-menu.is-open{display:flex;}
  .hero{min-height:88vh;}
  .areas{grid-template-columns:1fr;gap:24px;}
  .area figure{aspect-ratio:16/10;}
  .service-list__item{flex:1 1 100%;}
  .prog-cards{grid-template-columns:1fr;}
  .prog-card--light{margin-top:0;}
  .stimmen__grid{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:1fr;}
  .formula{grid-template-columns:1fr;}
  .trust__inner{grid-template-columns:1fr;}
  .trust__item{border-left:0!important;padding-left:0!important;border-top:1px solid var(--line-on-dark);}
  .trust__item:first-child{border-top:0;}
  .footer__grid{grid-template-columns:1fr;gap:32px;}
  .footer__bar{flex-direction:column;gap:6px;}
  .hero__actions .btn{width:100%;}
  .cookie__actions .btn{flex:1 1 auto;}
}

/* ===== "Was?"-Sektion Redesign: Bereiche fuehren, Leistungen als leichte Liste ===== */
.was__areas{margin-bottom:var(--space-m);}
.was__services{display:flex;flex-wrap:wrap;align-items:center;gap:14px 20px;
  border-top:1px solid var(--line);padding-top:var(--space-s);}
.was__services-label{font-family:var(--font-display);font-weight:700;font-size:13px;
  text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--brand-wine);}
.service-chips{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:10px;}
.service-chips a{display:inline-flex;align-items:center;padding:9px 16px;
  border:1.5px solid var(--line);border-radius:6px;background:#fff;
  font-family:var(--font-display);font-weight:600;font-size:13px;
  text-transform:uppercase;letter-spacing:.04em;color:var(--text-on-light);text-decoration:none;
  transition:background var(--hover-dur) var(--hover-ease),border-color var(--hover-dur) var(--hover-ease),color var(--hover-dur) var(--hover-ease);}
.service-chips a:hover{background:var(--brand-wine);border-color:var(--brand-wine);color:#fff;}
.was__all{margin-left:auto;display:inline-flex;align-items:center;gap:8px;white-space:nowrap;
  font-family:var(--font-display);font-weight:700;font-size:14px;
  text-transform:uppercase;letter-spacing:.04em;color:var(--brand-wine);text-decoration:none;}
.was__all i{font-style:normal;font-size:20px;transition:transform var(--hover-dur) var(--hover-ease);}
.was__all:hover i{transform:translateX(4px);}
@media (max-width:680px){
  .was__all{margin-left:0;}
}

/* ===== Preis-Sektion: Vergleichstabelle (Variante 2) ===== */
.programme .compare-panel{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;
  display:grid;grid-template-columns:1fr 1px 1fr;margin-top:var(--space-s);}
.programme .divider-vertical{background:var(--line);width:1px;}
.programme .col{display:flex;flex-direction:column;padding:36px 32px;}
.programme .col--flagship{background:var(--bg-light-alt);position:relative;}
.programme .col--flagship::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--brand-wine);}
.programme .col-head{min-height:132px;}
.programme .badge{display:inline-block;font-family:var(--font-display);font-weight:600;text-transform:uppercase;
  letter-spacing:var(--ls-caps);font-size:.7rem;padding:5px 11px;border-radius:6px;margin-bottom:14px;}
.programme .badge--flagship{background:var(--brand-wine);color:#fff;}
.programme .badge--soft{background:transparent;color:var(--text-muted-on-light);border:1px solid var(--line);}
.programme .col-name{font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:var(--ls-caps);
  font-size:1.5rem;line-height:1.1;color:var(--text-on-light);margin-bottom:16px;}
.programme .price{font-family:var(--font-display);font-weight:700;font-size:clamp(1.8rem,3.4vw,2.35rem);
  line-height:1.05;color:var(--text-on-light);letter-spacing:.5px;}
.programme .col--flagship .price{color:var(--brand-wine);}
.programme .price-prefix{display:block;font-family:var(--font-body);font-weight:500;font-size:.8rem;
  text-transform:uppercase;letter-spacing:var(--ls-caps);color:var(--text-muted-on-light);margin-bottom:4px;}
.programme .price-suffix{font-family:var(--font-body);font-weight:400;font-size:.95rem;color:var(--text-muted-on-light);letter-spacing:0;}
.programme .row-divider{border-top:1px solid var(--line);margin:22px 0;}
.programme .col--flagship .row-divider{border-top-color:#D9D4D2;}
.programme .for-whom{min-height:84px;}
.programme .for-whom .label{font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-caps);
  font-size:.72rem;color:var(--brand-wine);display:block;margin-bottom:7px;}
.programme .for-whom p{font-size:.98rem;color:var(--text-on-light);}
.programme .features{list-style:none;margin:22px 0 0;padding:0;flex-grow:1;}
.programme .features li{position:relative;padding-left:30px;margin-bottom:13px;font-size:.97rem;color:var(--text-on-light);}
.programme .features li:last-child{margin-bottom:0;}
.programme .features li svg{position:absolute;left:0;top:3px;width:17px;height:17px;}
.programme .compare-panel .cta{display:inline-flex;align-items:center;justify-content:center;margin-top:28px;width:100%;
  padding:14px 24px;font-family:var(--font-display);font-weight:600;text-transform:uppercase;letter-spacing:var(--ls-caps);
  font-size:.82rem;text-decoration:none;border-radius:6px;
  transition:background-color var(--hover-dur) var(--hover-ease),color var(--hover-dur) var(--hover-ease),border-color var(--hover-dur) var(--hover-ease);}
.programme .cta--solid{background:var(--brand-wine);color:#fff;border:1px solid var(--brand-wine);}
.programme .cta--solid:hover{background:var(--brand-wine-hover);border-color:var(--brand-wine-hover);}
.programme .cta--outline{background:transparent;color:var(--brand-wine);border:1px solid var(--brand-wine);}
.programme .cta--outline:hover{background:var(--brand-wine);color:#fff;}
@media (max-width:760px){
  .programme .compare-panel{grid-template-columns:1fr;}
  .programme .divider-vertical{width:auto;height:1px;}
  .programme .col-head,.programme .for-whom{min-height:0;}
  .programme .col{padding:30px 24px;}
}

/* ===== Magazin-Feature-Block (Foto + ueberlappende Karte), Variante 2 ===== */
.feature{position:relative;display:grid;grid-template-columns:60% 40%;align-items:center;min-height:540px;}
.feature__media{position:relative;grid-column:1;grid-row:1;align-self:stretch;border-radius:10px;overflow:hidden;background:var(--bg-dark-soft);box-shadow:0 18px 40px -22px rgba(18,18,18,.45);}
.feature__media img{display:block;width:100%;height:100%;min-height:500px;object-fit:cover;filter:saturate(.9);}
.feature__card{position:relative;grid-column:2;grid-row:1;z-index:2;margin-left:-110px;margin-top:56px;
  background:#fff;border:1px solid var(--line);border-radius:10px;padding:44px 42px;
  box-shadow:0 24px 60px -24px rgba(18,18,18,.35),0 4px 14px -8px rgba(18,18,18,.18);}
.feature--flip{grid-template-columns:40% 60%;}
.feature--flip .feature__media{grid-column:2;}
.feature--flip .feature__card{grid-column:1;margin-left:0;margin-right:-110px;}
.feature__eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:700;
  font-size:.72rem;letter-spacing:var(--ls-caps);text-transform:uppercase;color:var(--brand-wine);margin:0 0 18px;}
.feature__eyebrow::before{content:"";width:26px;height:2px;background:var(--brand-wine);display:inline-block;}
.feature__title{font-family:var(--font-display);font-weight:700;font-size:clamp(1.55rem,2.3vw,1.9rem);line-height:1.18;
  letter-spacing:var(--ls-caps);text-transform:uppercase;color:var(--text-on-light);margin:0 0 22px;}
.feature__title::after{content:"";display:block;width:54px;height:3px;background:var(--brand-wine);margin-top:22px;}
.feature__card p{font-size:1.02rem;line-height:1.6;color:var(--text-muted-on-light);margin:0 0 16px;}
.feature__card p:last-of-type{margin-bottom:0;}
.feature__card p strong{color:var(--text-on-light);font-weight:600;}
.feature__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:26px;}
@media (max-width:860px){
  .feature,.feature--flip{display:block;min-height:0;grid-template-columns:1fr;}
  .feature__media,.feature--flip .feature__media{border-radius:10px 10px 0 0;}
  .feature__media img{min-height:260px;max-height:400px;}
  .feature__card,.feature--flip .feature__card{margin:0;border-radius:0 0 10px 10px;padding:32px 24px;box-shadow:0 18px 40px -26px rgba(18,18,18,.3);}
}
