/* ============================================================
   ShapeMySmile — preview build /shape/
   Palette: Aubergine + Violett + Gold (editorial-klinisch)
   Headlines: Fraunces (Serif) · Body: Inter
   ============================================================ */

:root{
  /* — Brand — Aubergine + Violett — */
  --brand:#5b2a6b;          /* core violet */
  --brand-dark:#3e1c4a;     /* deep aubergine */
  --brand-deep:#2a1230;     /* near-black aubergine */
  --brand-soft:#7d4a8e;     /* lighter violet for hover/accents */

  /* — Surfaces — warm cream — */
  --cream:#fbf8f5;          /* page bg — warm off-white */
  --cream-2:#f3ecea;        /* hero band — dusty aubergine wash */
  --cream-3:#f6f1ee;        /* alt section bg */
  --cream-4:#ecdfde;        /* deeper band */
  --cream-5:#f0eae6;
  --white:#ffffff;

  /* — Stone (warm taupe-grey scale) — */
  --stone:#9a8c8e;
  --stone-2:#7a6b6d;
  --stone-3:#c6b9b8;
  --stone-4:#ddd0cd;        /* borders / hairlines */
  --stone-5:#eee5e3;

  /* — Akzent-Variablen (historisch „gold" benannt, jetzt Aubergine-Tone als CI) — */
  --gold:#7d4a8e;           /* mid-aubergine — Borders, Dashes, Akzent-Lines */
  --gold-soft:#d4b9e0;      /* light lavender — em-Akzent auf dark BG */
  --gold-deep:#5b2a6b;      /* brand-violet — Eyebrow-Text, Sup-Hochzeichen */

  /* — Status — */
  --green:#4a7a4d;
  --red:#a83c3c;

  /* — Ink — */
  --ink:#1a0d1f;
  --ink-2:#2a1230;
  --ink-3:#4a3a44;
  --muted:#7a6b6d;

  /* — Geometry — uniform 4px — */
  --r-sm:4px;
  --r-md:4px;
  --r-lg:4px;
  --r-xl:4px;
  --ease:cubic-bezier(.16,1.2,.3,1);
  --shadow-sm:0 1px 2px rgba(42,18,48,.06);
  --shadow-md:0 6px 18px rgba(42,18,48,.08);
  --shadow-lg:0 18px 44px rgba(42,18,48,.12);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  margin:0;
  font-family:'Inter','Helvetica Neue',Arial,sans-serif;
  color:var(--ink-2);
  background:var(--cream);
  line-height:1.65;
  font-size:16px;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:clip;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--brand)}
button{font:inherit;cursor:pointer;border:0;background:transparent}

/* — Typography — Headlines in Fraunces (Serif) — */
h1,h2,h3,h4,h5{
  font-family:'Fraunces','Cormorant Garamond','Times New Roman',serif;
  color:var(--brand-deep);
  font-weight:400;
  letter-spacing:-.018em;
  line-height:1.08;
  margin:0;
  font-variation-settings:"SOFT" 30,"WONK" 0;
}
h1{
  font-size:clamp(38px,6vw,72px);
  font-weight:400;
  letter-spacing:-.028em;
  line-height:1.04;
}
h1 em,h1 .accent{
  font-weight:400;font-style:italic;color:var(--brand);
  font-variation-settings:"SOFT" 50,"WONK" 0;
}
h2{font-size:clamp(28px,3.8vw,46px);font-weight:400;letter-spacing:-.022em;line-height:1.12}
h2 em,h2 .accent{font-style:italic;color:var(--brand);font-weight:400;font-variation-settings:"SOFT" 50,"WONK" 0}
h3{font-size:clamp(20px,2.2vw,26px);font-weight:500;letter-spacing:-.012em}
h4{font-size:17px;font-weight:500;letter-spacing:-.005em;color:var(--brand-deep)}

p{margin:0 0 14px;color:var(--ink-3);line-height:1.7;font-size:16px}
.lead{font-size:clamp(16px,1.4vw,19px);color:var(--ink-3);max-width:640px;line-height:1.65}

/* Editorial label — Mixed Case, kein Uppercase, dezent */
.eyebrow{
  display:inline-block;
  font-family:'Inter',sans-serif;
  font-size:13px;font-weight:500;color:var(--gold-deep);
  letter-spacing:0;text-transform:none;
  margin-bottom:18px;padding:0 0 6px;
  border-bottom:1px solid var(--gold);
  border-radius:0;
}
.text-muted{color:var(--muted)}
.text-center{text-align:center}

/* — Layout — */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.container-narrow{max-width:820px;margin:0 auto;padding:0 24px}
section{padding:56px 0}
@media(min-width:768px){section{padding:96px 0}}
.section-tight{padding:28px 0}
.section-cream{background:var(--cream-3)}
.section-band{background:var(--cream-2)}
.section-deep{background:var(--brand-deep);color:#e6d8e8}
.section-deep h1,.section-deep h2,.section-deep h3,.section-deep h4{color:#fff}
.section-deep p{color:rgba(255,255,255,.78)}

/* — Buttons — kantig, klar — */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  padding:14px 26px;font-size:14.5px;font-weight:500;letter-spacing:.02em;
  border-radius:var(--r-sm);border:1px solid transparent;
  transition:all .2s var(--ease);white-space:nowrap;cursor:pointer;
  font-family:'Inter',sans-serif;
}
.btn-primary{background:var(--brand-deep);color:#fff}
.btn-primary:hover{background:var(--brand);color:#fff}
.btn-secondary{
  background:transparent;color:var(--brand-deep);border-color:var(--brand-deep);
}
.btn-secondary:hover{background:var(--brand-deep);color:#fff}
.btn-ghost{background:transparent;color:var(--brand-deep)}
.btn-ghost:hover{color:var(--brand)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-deep);color:#fff}
.btn-sm{padding:10px 18px;font-size:13px}
.btn-lg{padding:16px 30px;font-size:15px}
.btn-full{width:100%}

/* — Header / nav — */
.nav{
  position:sticky;top:0;z-index:102;
  background:rgba(251,248,245,.92);
  backdrop-filter:saturate(180%) blur(14px);
  -webkit-backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid var(--stone-4);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:78px;max-width:1200px;margin:0 auto;padding:0 24px;
}
.nav-logo{display:flex;align-items:center;gap:10px;color:var(--brand-deep)}
.nav-logo img{height:42px;width:auto;display:block}
.nav-menu{display:none;gap:30px;align-items:center}
@media(min-width:992px){.nav-menu{display:flex}}
.nav-link{
  font-family:'Inter',sans-serif;
  color:var(--ink-2);font-size:14px;font-weight:500;letter-spacing:.005em;
  padding:10px 0;
}
.nav-link:hover{color:var(--brand)}
.nav-cta{display:flex;align-items:center;gap:8px}
/* Mobile: Termin-Button im Nav verstecken (ist im Drawer + sticky vorhanden) */
@media(max-width:680px){.nav-cta-btn{display:none}}

/* ═════════════════════════════════════════════════════════════════════
   MOBILE NAV — Bulletproof Rewrite
   Strategie:
   • Burger-Button mit klarem :checked-Pattern via JS state-class
   • Drawer: position:fixed, full-screen overlay, transform-basiert
     (display:block always — Visibility per opacity+visibility+transform)
   • Stacking-Context-sicher: z-index 9999, body.nav-open verhindert Scroll
   • iOS-Safari-tested via touch-action + -webkit-tap-highlight-color
   ═════════════════════════════════════════════════════════════════════ */

/* Burger-Button — iOS-sicher, eindeutige Hit-Area */
.nav-toggle{
  position:relative;
  display:inline-flex;flex-direction:column;justify-content:center;align-items:center;
  gap:5px;width:46px;height:46px;cursor:pointer;
  background:transparent;border:1px solid var(--stone-4);
  border-radius:var(--r-sm);user-select:none;padding:0;
  -webkit-appearance:none;appearance:none;
  -webkit-tap-highlight-color:rgba(91,42,107,.15);
  touch-action:manipulation;color:inherit;font:inherit;
  z-index:10001; /* immer über drawer */
}
.nav-toggle:hover{border-color:var(--brand-deep)}
.nav-toggle:focus-visible{outline:2px solid var(--brand);outline-offset:2px}
.nav-toggle span{
  display:block;width:22px;height:2px;background:var(--brand-deep);
  border-radius:0;transition:transform .28s var(--ease),opacity .15s var(--ease);
  pointer-events:none;transform-origin:center;
}
@media(min-width:992px){.nav-toggle{display:none}}

/* Burger → X (open state) */
.nav-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0;transform:scaleX(.3)}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Drawer: ALWAYS in DOM, hidden via opacity/visibility/transform.
   Visible: .nav-drawer.open OR body.nav-open .nav-drawer (Doppelsicherheit) */
.nav-drawer{
  position:fixed;left:0;right:0;top:0;bottom:0;
  background:var(--cream);
  z-index:10000;
  opacity:0;visibility:hidden;
  transform:translateY(-12px);
  transition:opacity .28s var(--ease), transform .28s var(--ease), visibility 0s linear .28s;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  padding-top:78px;  /* unter nav-bar; nav-bar bleibt on top via header z-index */
}
.nav-drawer.open,
body.nav-open .nav-drawer{
  opacity:1;visibility:visible;transform:translateY(0);
  transition:opacity .28s var(--ease), transform .28s var(--ease), visibility 0s linear 0s;
}

/* Body-Scroll-Lock wenn drawer offen */
body.nav-open{overflow:hidden;touch-action:none}

/* Nav-bar muss über dem drawer-padding-top sein */
.nav{z-index:10002}

.nav-drawer-inner{
  max-width:560px;margin:0 auto;padding:28px 28px 80px;
  display:flex;flex-direction:column;
}
.nav-drawer a{
  display:block;padding:18px 0;font-size:18px;font-weight:500;
  border-bottom:1px solid var(--stone-4);color:var(--ink-2);
  font-family:'Fraunces',serif;letter-spacing:-.005em;
  -webkit-tap-highlight-color:rgba(91,42,107,.10);
  text-decoration:none;
}
.nav-drawer a:hover{color:var(--brand)}
.nav-drawer a:active{color:var(--brand)}
.nav-drawer-cta{
  margin-top:24px;display:block !important;
  background:var(--brand-deep);color:#fff !important;
  padding:18px 24px !important;font-size:16px !important;
  border:0 !important;text-align:center;
  font-family:'Inter',sans-serif !important;font-weight:500;
  border-radius:var(--r-sm);
}
.nav-drawer-cta:hover{background:var(--brand)}

/* — Hero — */
.hero{padding:40px 0 64px;background:var(--cream-2);position:relative}
.hero::after{
  content:'';position:absolute;inset:auto 0 0 0;height:120px;
  background:linear-gradient(180deg,transparent,var(--cream));pointer-events:none;
}
@media(min-width:768px){.hero{padding:88px 0 112px}}
.hero-grid{display:grid;gap:48px;align-items:center;position:relative;z-index:1}
@media(min-width:900px){.hero-grid{grid-template-columns:1.05fr .95fr;gap:64px}}
.hero-copy h1{margin-bottom:24px}
.hero-copy .lead{margin-bottom:32px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:32px}
.hero-trust{display:flex;flex-wrap:wrap;gap:30px;padding-top:28px;border-top:1px solid var(--stone-4)}
.hero-trust-item{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--ink-3)}
.hero-trust-item strong{color:var(--brand-deep);font-weight:600;font-size:14px}
.hero-trust-item span{color:var(--muted)}
.hero-visual{position:relative}
.hero-visual img{
  border-radius:var(--r-md);
  box-shadow:0 28px 70px rgba(42,18,48,.16);
}

/* — Cards (treatments) — */
.grid-3{display:grid;gap:24px;grid-template-columns:1fr}
@media(min-width:640px){.grid-3{grid-template-columns:1fr 1fr}}
@media(min-width:960px){.grid-3{grid-template-columns:repeat(3,1fr)}}
.grid-2{display:grid;gap:30px;grid-template-columns:1fr}
@media(min-width:780px){.grid-2{grid-template-columns:1fr 1fr}}

.card{
  background:#fff;border:1px solid var(--stone-4);
  border-radius:var(--r-md);overflow:hidden;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease),transform .25s var(--ease);
  display:flex;flex-direction:column;
}
.card:hover{border-color:var(--brand);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.card-img{aspect-ratio:5/3;overflow:hidden;background:var(--cream-3)}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.card:hover .card-img img{transform:scale(1.03)}
.card-body{padding:24px 22px 26px;flex:1;display:flex;flex-direction:column}
@media(min-width:768px){.card-body{padding:28px 26px 30px}}
.card-eyebrow{
  font-family:'Inter',sans-serif;
  font-size:12.5px;font-weight:500;color:var(--gold-deep);
  letter-spacing:0;text-transform:none;margin-bottom:8px;
}
.card h3{margin-bottom:10px}
.card p{font-size:14.5px;margin-bottom:18px;flex:1;line-height:1.6}
.card-meta{display:flex;align-items:center;gap:16px;font-size:12.5px;color:var(--muted);margin-top:auto;padding-top:14px;border-top:1px solid var(--stone-5)}
.card-meta strong{color:var(--brand-deep);font-weight:600}
.card-link{
  display:inline-flex;align-items:center;gap:6px;
  color:var(--brand);font-weight:500;font-size:13.5px;margin-top:14px;
  letter-spacing:.02em;
}
.card-link:after{content:'→';transition:transform .2s var(--ease)}
.card-link:hover:after{transform:translateX(3px)}

/* — Section heading — */
.section-head{text-align:center;max-width:760px;margin:0 auto 64px}
.section-head h2{margin-bottom:20px}
.section-head p{font-size:17px;color:var(--ink-3);line-height:1.65}
.section-head-left{text-align:left;margin:0 0 44px;max-width:780px}

/* — Trust strip — minimal, kein pill — */
.trust-bar{background:#fff;border-top:1px solid var(--stone-4);border-bottom:1px solid var(--stone-4);padding:18px 0}
.trust-bar-inner{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:10px 36px;text-align:center;
}
.trust-bar-item{
  font-family:'Inter',sans-serif;font-size:13px;color:var(--ink-3);
  letter-spacing:0;text-transform:none;font-weight:500;
}

/* — Stats — */
.stat-row{display:grid;gap:32px;grid-template-columns:repeat(2,1fr)}
@media(min-width:780px){.stat-row{grid-template-columns:repeat(4,1fr)}}
.stat{text-align:center;padding:8px}
.stat-num{
  font-family:'Fraunces',serif;
  font-size:clamp(44px,5.5vw,68px);font-weight:400;color:var(--brand);
  letter-spacing:-.04em;line-height:1;
  font-variation-settings:"SOFT" 100;
}
.stat-label{
  margin-top:8px;font-size:13.5px;color:var(--ink-3);
  letter-spacing:0;text-transform:none;font-weight:500;
}

/* — Steps — */
.steps{display:grid;gap:24px;grid-template-columns:1fr;counter-reset:step}
@media(min-width:740px){.steps{grid-template-columns:repeat(3,1fr)}}
.step{
  background:#fff;border:1px solid var(--stone-4);border-radius:var(--r-md);
  padding:32px 28px;position:relative;counter-increment:step;
}
.step::before{
  content:counter(step,decimal-leading-zero);
  font-family:'Fraunces',serif;font-style:italic;
  display:block;font-size:36px;font-weight:400;
  color:var(--gold);letter-spacing:-.02em;line-height:1;
  margin-bottom:18px;
}
.step h3{font-size:20px;margin:0 0 12px}
.step p{font-size:14.5px;color:var(--ink-3);margin:0;line-height:1.6}

/* — FAQ — */
.faq{max-width:820px;margin:0 auto}
.faq details{
  border-bottom:1px solid var(--stone-4);padding:24px 0;
}
.faq details:first-child{border-top:1px solid var(--stone-4)}
.faq summary{
  list-style:none;
  font-family:'Fraunces',serif;font-weight:400;
  font-size:20px;color:var(--brand-deep);
  display:flex;align-items:flex-start;justify-content:space-between;gap:24px;
  outline:none;cursor:pointer;line-height:1.3;
  position:relative;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::marker{display:none}
/* SVG icon via background — bulletproof across fonts/encodings */
.faq summary::after{
  content:'';
  width:22px;height:22px;flex-shrink:0;margin-top:4px;
  background-color:transparent;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 22' fill='none' stroke='%237e6432' stroke-width='1.6' stroke-linecap='round'><line x1='11' y1='4' x2='11' y2='18'/><line x1='4' y1='11' x2='18' y2='11'/></svg>");
  background-repeat:no-repeat;background-position:center;background-size:22px;
  transition:transform .25s var(--ease);
}
.faq details[open] summary::after{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 22' fill='none' stroke='%235b2a6b' stroke-width='1.6' stroke-linecap='round'><line x1='4' y1='11' x2='18' y2='11'/></svg>");
  transform:rotate(180deg);
}
.faq details p{margin-top:14px;color:var(--ink-3);line-height:1.7;font-size:15.5px}

/* — CTA band — */
.cta-band{
  background:var(--brand-deep);
  color:#fff;padding:80px 32px;text-align:center;
  border-radius:var(--r-md);position:relative;overflow:hidden;
}
.cta-band h2{color:#fff;margin-bottom:18px;max-width:760px;margin-left:auto;margin-right:auto}
.cta-band p{color:rgba(255,255,255,.78);font-size:17px;max-width:600px;margin:0 auto 32px;line-height:1.65}
.cta-band .eyebrow{color:var(--gold-soft);border-bottom-color:rgba(255,255,255,.3);background:transparent;margin-bottom:18px;padding:0 0 6px;border-radius:0}
.cta-band .btn-primary{background:var(--gold);color:#fff}
.cta-band .btn-primary:hover{background:var(--gold-deep);color:#fff}
.cta-band .btn-secondary{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.cta-band .btn-secondary:hover{background:#fff;color:var(--brand-deep);border-color:#fff}

/* — Doctor — */
.doctor{
  display:grid;gap:32px;grid-template-columns:1fr;align-items:center;
  background:#fff;border:1px solid var(--stone-4);
  border-radius:var(--r-md);padding:28px 24px;
}
@media(min-width:780px){.doctor{grid-template-columns:300px 1fr;gap:48px;padding:48px}}
.doctor img{
  border-radius:var(--r-sm);
  aspect-ratio:4/5;object-fit:cover;width:100%;
}
.doctor-role{
  font-family:'Inter',sans-serif;
  font-size:13px;color:var(--gold-deep);font-weight:500;
  letter-spacing:0;text-transform:none;margin-bottom:10px;
}
.doctor-name{
  font-family:'Fraunces',serif;font-size:30px;font-weight:400;
  color:var(--brand-deep);margin-bottom:18px;letter-spacing:-.018em;line-height:1.1;
}
.doctor-bio{color:var(--ink-3);font-size:15.5px;line-height:1.7;margin-bottom:14px}

/* — Pricing — */
.price-grid{display:grid;gap:24px;grid-template-columns:1fr}
@media(min-width:680px){.price-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:980px){.price-grid{grid-template-columns:repeat(3,1fr)}}
.price{background:#fff;border:1px solid var(--stone-4);border-radius:var(--r-md);padding:36px 28px;text-align:left}
.price.featured{border-color:var(--brand);position:relative}
.price-name{
  font-family:'Inter',sans-serif;
  font-size:13px;color:var(--gold-deep);font-weight:500;
  letter-spacing:0;text-transform:none;margin-bottom:12px;
}
.price-amount{font-family:'Fraunces',serif;font-size:46px;font-weight:400;color:var(--brand-deep);letter-spacing:-.025em;line-height:1}
.price-amount span{font-size:14px;color:var(--muted);font-weight:500;font-family:'Inter',sans-serif}
.price-sub{font-size:13px;color:var(--muted);margin:6px 0 22px}
.price ul{list-style:none;padding:0;margin:0 0 26px}
.price li{padding:9px 0;font-size:14px;color:var(--ink-3);border-bottom:1px solid var(--stone-5);position:relative;padding-left:22px}
.price li::before{content:'—';position:absolute;left:0;color:var(--gold)}

/* — Contact rows — minimal, ohne emoji-bubbles — */
.contact-stack{display:flex;flex-direction:column;border-top:1px solid var(--stone-4)}
.contact-row{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:22px 0;border-bottom:1px solid var(--stone-4);
  transition:padding .2s var(--ease);
}
.contact-row:hover{padding-left:6px;padding-right:0}
.contact-label{
  font-family:'Inter',sans-serif;
  font-size:13.5px;color:var(--gold-deep);font-weight:500;
  letter-spacing:0;text-transform:none;flex-shrink:0;width:120px;
}
.contact-value{
  font-family:'Fraunces',serif;font-size:18px;color:var(--brand-deep);
  font-weight:400;line-height:1.35;text-align:right;flex:1;
}
@media(max-width:560px){
  .contact-row{flex-direction:column;align-items:flex-start;gap:6px}
  .contact-value{text-align:left;font-size:17px}
  .contact-label{width:auto}
}

/* — Footer — */
.footer{background:var(--brand-deep);color:rgba(255,255,255,.72);padding:72px 0 28px;margin-top:0}
.footer h4{
  font-family:'Inter',sans-serif;
  color:#fff;font-size:14px;font-weight:500;letter-spacing:0;
  text-transform:none;margin-bottom:18px;
}
.footer a{color:rgba(255,255,255,.62);font-size:14px;display:block;padding:5px 0}
.footer a:hover{color:#fff}
.footer-grid{display:grid;gap:44px;grid-template-columns:1fr;margin-bottom:52px}
@media(min-width:680px){.footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.footer-brand img{height:46px;margin-bottom:20px;filter:brightness(0) invert(1)}
.footer-brand p{color:rgba(255,255,255,.58);font-size:14px;max-width:340px;line-height:1.6}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.10);padding-top:24px;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;
  font-size:12.5px;color:rgba(255,255,255,.45);
}
.footer-bottom a{display:inline;padding:0;color:rgba(255,255,255,.55)}

/* — Doctolib sticky — minimal — */
.doctolib-sticky{
  position:fixed;right:18px;bottom:18px;z-index:90;
  background:var(--brand-deep);color:#fff;border:1px solid var(--brand-deep);
  border-radius:var(--r-sm);
  padding:14px 22px;display:inline-flex;align-items:center;
  font-family:'Inter',sans-serif;font-size:13.5px;font-weight:500;
  letter-spacing:.04em;
  box-shadow:0 12px 32px rgba(42,18,48,.22);
  transition:all .2s var(--ease);
}
.doctolib-sticky:hover{background:var(--gold);border-color:var(--gold);color:#fff}
@media(max-width:540px){.doctolib-sticky{right:12px;bottom:12px;padding:12px 18px;font-size:13px}}

/* — Consent banner — conversion-optimiert: prominenter Accept, dezente Einstellungen — */
/* Cookie-Wall: blockierender Backdrop + Scroll-Lock bis eine Wahl getroffen ist */
html.sms-consent-open{overflow:hidden}
html.sms-consent-open body{overflow:hidden}
#sms-consent-backdrop{
  position:fixed;inset:0;z-index:199;
  background:rgba(26,10,30,.6);
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
}
.consent{
  position:fixed;left:18px;right:18px;bottom:18px;z-index:200;
  background:#fff;border:1px solid var(--stone-4);border-radius:var(--r-sm);
  padding:20px 22px;box-shadow:var(--shadow-lg);display:none;
}
.consent.show{display:block}
@media(min-width:780px){.consent{left:auto;right:18px;bottom:18px;max-width:420px}}
.consent-inner{display:grid;gap:14px}
.consent-inner[hidden]{display:none}
.consent-head strong{display:block;color:var(--brand-deep);margin-bottom:6px;font-family:'Fraunces',serif;font-weight:500;font-size:18px}
.consent-head p{font-size:13.5px;color:var(--ink-3);margin:0;line-height:1.55}
.consent-head p a{color:var(--brand);text-decoration:underline;text-underline-offset:2px}
/* Prominenter Accept — volle Breite, klarer Fokus */
.consent-accept{width:100%;justify-content:center;font-size:15px;padding:13px 20px}
/* Dezenter Einstellungen-Link — bewusst zurückhaltend, kein konkurrierender Button */
.consent-link{
  display:block;margin:0 auto;background:none;border:0;cursor:pointer;
  color:var(--ink-3);font-size:12.5px;font-family:inherit;opacity:.75;
  text-decoration:underline;text-underline-offset:2px;padding:2px 6px;
}
.consent-link:hover{opacity:1;color:var(--brand-deep)}
/* Settings-Optionen */
.consent-opt{
  display:flex;align-items:flex-start;justify-content:space-between;gap:14px;
  padding:12px 14px;background:var(--cream-3);border-radius:8px;cursor:pointer;
}
.consent-opt.is-locked{opacity:.65;cursor:default}
.consent-opt-txt{display:flex;flex-direction:column;gap:3px}
.consent-opt-t{font-weight:600;font-size:13.5px;color:var(--brand-deep)}
.consent-opt-d{font-size:12px;color:var(--ink-3);line-height:1.45}
.consent-opt input[type=checkbox]{margin-top:3px;width:18px;height:18px;accent-color:var(--brand);flex-shrink:0}
.consent-actions{display:flex;gap:10px;flex-wrap:wrap}
.consent-actions .btn{flex:1;justify-content:center;white-space:nowrap}

/* — Prose / article — */
.prose{max-width:760px;margin:0 auto}
.prose h2{margin:48px 0 18px;font-size:34px}
.prose h3{margin:32px 0 12px;font-size:22px}
.prose p,.prose li{font-size:16.5px;color:var(--ink-3);line-height:1.78}
.prose ul,.prose ol{padding-left:22px;margin:0 0 18px}
.prose li{padding:5px 0}
.prose a{color:var(--brand);text-decoration:underline;text-underline-offset:3px}
.prose blockquote{border-left:2px solid var(--gold);padding:8px 0 8px 22px;margin:24px 0;color:var(--ink-2);font-family:'Fraunces',serif;font-style:italic;font-size:19px}
.prose strong{color:var(--brand-deep)}

/* ═══ Ratgeber-Artikel — links-alignt, lesbar, Boxen ohne farbige Kanten ═══ */
.rg-article{padding:48px 0 8px}
.rg-col{max-width:760px}                      /* links-alignt im Container, gleiche Kante wie H1 */
.rg-back{display:inline-block;color:var(--brand);font-size:14px;font-weight:600;text-decoration:none;margin-bottom:16px}
.rg-back:hover{text-decoration:underline;text-underline-offset:3px}
.rg-h1{font-size:40px;line-height:1.12;margin:6px 0 0}
@media(max-width:640px){.rg-h1{font-size:30px}}
.rg-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:18px 0 0;font-size:13.5px;color:var(--stone-3)}
.rg-meta-item{display:inline-flex;align-items:center;gap:6px}
.rg-meta-icon{width:15px;height:15px;display:inline-flex;color:var(--gold-deep)}
.rg-meta-icon svg{width:15px;height:15px}
.rg-meta-sep{color:var(--stone-4)}
.rg-intro{margin:24px 0 8px}
.rg-lead{font-size:19px;line-height:1.6;color:var(--brand-deep);font-weight:500;margin:0 0 14px}
.rg-intro p{font-size:16.5px;color:var(--ink-3);line-height:1.78;margin:0 0 14px}

/* Sektionen + Fließtext links-alignt */
.rg-section{margin:40px 0 0}
.rg-col h2{font-size:28px;line-height:1.2;margin:0 0 14px;color:var(--brand-deep)}
.rg-sec-intro{font-size:16.5px;color:var(--ink-3);line-height:1.78;margin:0 0 22px}

/* Item-Karten (durch dünne Trennlinien getrennt, keine Seitenkanten) */
.rg-items{display:flex;flex-direction:column}
.rg-item{padding:20px 0;border-top:1px solid var(--stone-5,#ece5e0)}
.rg-item:first-child{border-top:0;padding-top:0}
.rg-item-head{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin:0 0 8px}
.rg-item-head h3{font-size:18px;margin:0;color:var(--brand-deep)}
.rg-item p{font-size:16px;color:var(--ink-3);line-height:1.72;margin:0}
.rg-badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 9px;border-radius:999px;letter-spacing:.01em}
.rg-badge--essential{background:#efe3f3;color:#6b2f7d}
.rg-badge--recommended{background:#f6edda;color:#8a6a1f}
.rg-badge--optional{background:var(--cream-3);color:var(--stone-3)}
.rg-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.rg-tag{font-size:11.5px;color:var(--stone-3);background:var(--cream-3);border-radius:999px;padding:2px 10px}

/* Boxen — nur Flächen, keine farbige Kante */
.rg-box{border-radius:14px;padding:22px 24px;margin:28px 0}
.rg-box-head{display:flex;align-items:center;gap:9px;margin-bottom:10px}
.rg-box-icon{flex-shrink:0;width:20px;height:20px;display:inline-flex}
.rg-box-icon svg{width:20px;height:20px}
.rg-box-label{font-size:13px;font-weight:600;font-family:'Fraunces',serif;letter-spacing:.02em}
.rg-answer{background:var(--cream-2)}
.rg-answer .rg-box-icon,.rg-answer .rg-box-label{color:var(--gold-deep)}
.rg-answer p{margin:0;font-size:16.5px;color:var(--ink-2);line-height:1.72}
.rg-disclaimer{display:flex;gap:12px;align-items:flex-start;background:var(--cream-3)}
.rg-disclaimer .rg-box-icon{color:var(--stone-3);margin-top:1px}
.rg-disclaimer p{margin:0;font-size:14px;color:var(--ink-3);line-height:1.65}
.rg-expert{background:var(--cream-2)}
.rg-expert-head{display:flex;align-items:center;gap:13px;margin-bottom:12px}
.rg-expert-img{width:48px;height:48px;border-radius:50%;object-fit:cover;flex-shrink:0}
.rg-expert-head strong{display:block;color:var(--brand-deep);font-size:15px}
.rg-expert-role{display:block;font-size:12.5px;color:var(--stone-3);margin-top:1px}
.rg-expert p{margin:0;font-size:15.5px;color:var(--ink-3);line-height:1.72}
.rg-tips{background:var(--cream-3)}
.rg-tips h2{font-size:19px;margin:0 0 16px}
.rg-tip-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:13px}
.rg-tip-list li{display:flex;gap:13px;align-items:flex-start}
.rg-tip-num{flex-shrink:0;width:25px;height:25px;border-radius:50%;background:var(--brand);color:#fff;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif}
.rg-tip-list p{margin:0;font-size:15.5px;color:var(--ink-3);line-height:1.65}
.rg-fazit{background:var(--cream-2)}
.rg-fazit h2{font-size:20px;margin:0 0 12px}
.rg-fazit p{font-size:16px;color:var(--ink-3);line-height:1.72;margin:0 0 18px}
.rg-fazit-cta{display:inline-flex;align-items:center;gap:9px}
.rg-cta-arrow{display:inline-flex;width:16px;height:16px}
.rg-cta-arrow svg{width:16px;height:16px}
.rg-next{font-size:13.5px;color:var(--stone-3);margin:14px 0 0!important}

/* Weiterlesen */
.rg-related-list{list-style:none;padding:0;margin:0;display:grid;gap:10px}
@media(min-width:560px){.rg-related-list{grid-template-columns:1fr 1fr}}
.rg-related-list a{display:flex;align-items:center;gap:11px;padding:15px 16px;background:var(--cream-3);border-radius:11px;text-decoration:none;color:var(--brand-deep);font-size:14.5px;font-weight:500;transition:background .15s}
.rg-related-list a:hover{background:var(--cream-4)}
.rg-rel-arrow{flex-shrink:0;width:26px;height:26px;border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--gold-deep)}
.rg-rel-arrow svg{width:15px;height:15px}

/* FAQ-Accordion im Artikel (nutzt bestehende .faq Styles, etwas Luft) */
.rg-section .faq{margin-top:4px}

/* — Misc — */
.divider{height:1px;background:var(--stone-4);margin:48px 0}
.legal-note{font-size:11.5px;color:var(--muted);line-height:1.55;margin-top:18px}

/* — Preview banner — dezenter — */
.preview-banner{
  background:var(--brand-deep);color:rgba(255,255,255,.7);
  padding:7px 16px;font-size:11.5px;text-align:center;
  letter-spacing:0;font-family:'Inter',sans-serif;
}
.preview-banner strong{color:#fff;font-weight:600}

/* ============================================================
   DETAIL-PAGES — Slider, Pricing, BG-Pattern, Disclaimer
   ============================================================ */

/* — Subtle decorative BG for hero / sections — */
.hero-decor{position:relative;overflow:hidden}
.hero-decor::before{
  content:'';position:absolute;top:-80px;right:-100px;
  width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle at center,rgba(164,130,67,.16),transparent 60%);
  pointer-events:none;z-index:0;
}
.hero-decor::after{
  content:'';position:absolute;bottom:-120px;left:-120px;
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle at center,rgba(91,42,107,.12),transparent 65%);
  pointer-events:none;z-index:0;
}
.hero-decor > *{position:relative;z-index:1}

/* Soft serif-grid overlay (very subtle) */
.bg-pattern{position:relative}
.bg-pattern::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 1px 1px,rgba(91,42,107,.07) 1px,transparent 0);
  background-size:32px 32px;
  mask-image:linear-gradient(180deg,#000 0%,#000 60%,transparent 100%);
  -webkit-mask-image:linear-gradient(180deg,#000 0%,#000 60%,transparent 100%);
  z-index:0;
}
.bg-pattern > .container{position:relative;z-index:1}

/* — Horizontal Slider (scroll-snap, no JS) — */
.slider-wrap{margin:0 -24px;padding:0 24px;position:relative}
@media(min-width:1248px){.slider-wrap{margin:0;padding:0}}
.slider{
  display:flex;gap:18px;overflow-x:auto;
  scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;
  padding:8px 0 24px;
  scrollbar-width:thin;scrollbar-color:var(--stone-3) transparent;
}
.slider::-webkit-scrollbar{height:6px}
.slider::-webkit-scrollbar-thumb{background:var(--stone-3);border-radius:3px}
.slider::-webkit-scrollbar-track{background:transparent}
.slide{
  flex:0 0 80%;scroll-snap-align:start;
  border-radius:var(--r-md);overflow:hidden;
  background:var(--cream-3);aspect-ratio:4/3;
}
@media(min-width:640px){.slide{flex-basis:45%}}
@media(min-width:980px){.slide{flex-basis:32%}}
.slide img{width:100%;height:100%;object-fit:cover;display:block}
.slider-hint{
  font-size:12.5px;color:var(--muted);text-align:center;
  margin-top:8px;font-family:'Inter',sans-serif;
}

/* — Pricing Deck — Mobile: 2-col Grid · Desktop: horizontal scroll (4 sichtbar) — */
.pricing-deck{
  display:grid;gap:18px;
  grid-template-columns:1fr;
}
@media(min-width:560px) and (max-width:979px){
  .pricing-deck{grid-template-columns:1fr 1fr}
}
@media(min-width:980px){
  .pricing-deck{
    display:flex;flex-wrap:nowrap;gap:18px;
    overflow-x:auto;overflow-y:visible;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    padding:4px 4px 16px;margin:0 -4px;
    scrollbar-width:thin;scrollbar-color:var(--stone-3) transparent;
  }
  .pricing-deck::-webkit-scrollbar{height:8px}
  .pricing-deck::-webkit-scrollbar-thumb{background:var(--stone-3);border-radius:4px}
  .pricing-deck::-webkit-scrollbar-track{background:transparent}
  .pricing-deck .pak{
    flex:0 0 calc((100% - 54px) / 4);     /* 4 sichtbar, gap 18px × 3 = 54px */
    scroll-snap-align:start;
    min-width:260px;max-width:320px;
  }
}
@media(min-width:1280px){
  .pricing-deck .pak{
    flex:0 0 calc((100% - 54px) / 4);
    min-width:280px;
  }
}
.pak{
  background:#fff;border:1px solid var(--stone-4);
  border-radius:var(--r-md);padding:28px 22px;
  display:flex;flex-direction:column;gap:14px;
  transition:border-color .2s var(--ease),transform .25s var(--ease),box-shadow .2s var(--ease);
}
.pak:hover{border-color:var(--brand);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.pak.featured{border-color:var(--brand);background:var(--cream-3)}
.pak-name{
  font-family:'Inter',sans-serif;font-size:13.5px;font-weight:500;
  color:var(--gold-deep);letter-spacing:0;text-transform:none;
}
.pak-size{
  font-family:'Fraunces',serif;font-size:26px;font-weight:400;
  color:var(--brand-deep);letter-spacing:-.02em;line-height:1;
}
.pak-price{
  font-family:'Fraunces',serif;font-size:38px;font-weight:400;
  color:var(--brand);letter-spacing:-.025em;line-height:1;margin-top:4px;
}
.pak-price sup{font-size:14px;color:var(--gold-deep);font-weight:500;font-family:'Inter',sans-serif;margin-left:2px;top:-12px;position:relative}
.pak-sub{font-size:13px;color:var(--muted);margin:0}
.pak-list{list-style:none;padding:0;margin:8px 0 0;flex:1}
.pak-list li{
  font-size:13.5px;color:var(--ink-3);
  padding:7px 0 7px 20px;position:relative;
  border-bottom:1px solid var(--stone-5);
}
.pak-list li:last-child{border-bottom:0}
.pak-list li::before{
  content:'';position:absolute;left:0;top:14px;
  width:10px;height:1px;background:var(--gold);
}
.pak-cta{margin-top:8px}

/* — Legal-Fine — klein, grau, dezent (statt prominente Box) — */
.legal-fine{
  margin-top:36px;max-width:none;
  font-size:11.5px;line-height:1.55;color:var(--muted);
  font-family:'Inter',sans-serif;
}
/* Im Container-narrow (Datenschutz / Impressum / AGB) wieder lesbar begrenzt */
.container-narrow .legal-fine{max-width:760px}
.legal-fine p{margin:0 0 8px;color:var(--muted);font-size:11.5px;line-height:1.55}
.legal-fine p:last-child{margin-bottom:0}
.legal-fine strong{color:var(--ink-3);font-weight:500}
.legal-fine a{color:var(--ink-3);text-decoration:underline;text-underline-offset:2px}

/* Pricing card extras */
.pak-price-unit{font-family:'Inter',sans-serif;font-size:13px;font-weight:500;color:var(--muted);letter-spacing:0}
.pak-price-prefix{font-family:'Inter',sans-serif;font-size:14px;font-weight:500;color:var(--muted);letter-spacing:0;margin-right:6px;vertical-align:6px}
.pak-once{font-family:'Inter',sans-serif;font-size:12.5px;color:var(--muted);margin-top:-2px}
.pak-finex{
  font-size:10.5px;line-height:1.45;color:var(--muted);
  margin-top:10px;padding-top:10px;border-top:1px dashed var(--stone-4);
}

/* — Detail-Hero (full bleed, image right, decoration) — */
.detail-hero{
  padding:48px 0 64px;background:var(--cream-2);position:relative;overflow:hidden;
}
@media(min-width:768px){.detail-hero{padding:88px 0 110px}}
.detail-hero::before{
  content:'';position:absolute;top:-100px;right:-150px;
  width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle,rgba(164,130,67,.15),transparent 60%);
  pointer-events:none;
}
.detail-hero::after{
  content:'';position:absolute;bottom:-160px;left:-120px;
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(91,42,107,.10),transparent 65%);
  pointer-events:none;
}
.detail-hero .container{position:relative;z-index:1}
.detail-hero-grid{display:grid;gap:40px;align-items:center}
@media(min-width:900px){.detail-hero-grid{grid-template-columns:1.05fr .95fr;gap:60px}}
.detail-hero h1{margin-bottom:22px}
.detail-hero .lead{margin-bottom:28px}
.detail-hero-visual img{
  border-radius:var(--r-md);
  box-shadow:0 24px 64px rgba(42,18,48,.18);
  width:100%;
}

/* — Spec bar (Behandlungs-Eckdaten unter Hero) — */
.spec-bar{
  background:#fff;border-top:1px solid var(--stone-4);border-bottom:1px solid var(--stone-4);
  padding:18px 0;
}
.spec-bar-inner{
  display:grid;gap:14px;
  grid-template-columns:repeat(2,1fr);
}
@media(min-width:780px){
  .spec-bar-inner{
    display:flex;flex-wrap:nowrap;gap:20px;
    align-items:center;justify-content:space-between;
  }
}
.spec{display:flex;flex-direction:column;gap:2px;padding:8px 12px}
@media(min-width:780px){
  .spec{flex:1 1 0;min-width:0;padding:8px 6px}
}
.spec-label{
  font-family:'Inter',sans-serif;font-size:12px;color:var(--muted);
  letter-spacing:0;text-transform:none;
}
.spec-value{
  font-family:'Fraunces',serif;font-size:18px;color:var(--brand-deep);
  font-weight:500;letter-spacing:-.01em;line-height:1.2;
}

/* ============================================================
   HERO upgraded — Welcome-Style Top-Row + Typewriter
   ============================================================ */

/* Top-Logo-Row in Hero (Invisalign Anwender + ShapeMySmile) */
.hero-toprow{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:0 0 26px;margin-bottom:36px;
  border-bottom:1px solid var(--stone-4);
  position:relative;z-index:1;
}
.hero-toprow img{height:42px;width:auto;display:block}
@media(max-width:560px){
  .hero-toprow img{height:34px}
  .hero-toprow{padding-bottom:20px;margin-bottom:28px}
}

/* Typewriter caret */
.tw{display:inline}
.tw-text{display:inline}
.tw-caret{
  display:inline-block;width:.06em;height:.85em;
  margin-left:.04em;background:currentColor;
  vertical-align:-.06em;
  animation:tw-blink .9s steps(2) infinite;
}
@keyframes tw-blink{0%,49%{opacity:1}50%,100%{opacity:0}}
@media(prefers-reduced-motion:reduce){.tw-caret{display:none;animation:none}}

/* Subscript footnote-anchor in H1 (e.g. for ¹) */
.tw-foot{
  font-family:'Inter',sans-serif;font-weight:400;
  font-size:.28em;color:var(--muted);
  vertical-align:super;margin-left:.18em;
  text-decoration:none;
}
.tw-foot:hover{color:var(--brand)}

/* Invisalign Facts row (3 stats, big numbers, gold accent) */
.facts{
  display:grid;gap:28px;grid-template-columns:1fr;
  padding:8px 0;
}
@media(min-width:760px){.facts{grid-template-columns:repeat(3,1fr);gap:0}}
.fact{
  text-align:center;padding:18px 24px;position:relative;
}
@media(min-width:760px){
  .fact + .fact{border-left:1px solid var(--stone-4)}
}
.fact-num{
  font-family:'Fraunces',serif;font-size:clamp(38px,5vw,56px);
  font-weight:400;color:var(--brand);letter-spacing:-.03em;line-height:1;
  font-variation-settings:"SOFT" 50;
}
.fact-label{
  font-family:'Inter',sans-serif;margin-top:10px;
  font-size:14px;color:var(--ink-3);line-height:1.45;
}
.fact-source{
  font-family:'Inter',sans-serif;font-size:10.5px;color:var(--muted);
  margin-top:8px;letter-spacing:0;
}

/* Video block — Container-Ratio = native Video-Ratio (16:9), kein Crop */
.video-block{
  position:relative;border-radius:var(--r-md);overflow:hidden;
  background:#000;
  box-shadow:0 24px 64px rgba(42,18,48,.18);
  aspect-ratio:16/9;
}
.video-block video{
  width:100%;height:100%;display:block;
  object-fit:contain;  /* zeigt komplettes Video, kein Abschneiden */
  background:#000;
}
.video-block .video-caption{
  position:absolute;left:18px;bottom:14px;
  color:#fff;font-size:13px;font-family:'Inter',sans-serif;
  background:rgba(0,0,0,.4);padding:6px 12px;border-radius:var(--r-sm);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}

/* Vorher/Nachher Patient Grid */
.patient-grid{
  display:grid;gap:14px;grid-template-columns:1fr;
}
@media(min-width:640px){.patient-grid{grid-template-columns:repeat(3,1fr)}}
.patient-tile{
  border-radius:var(--r-md);overflow:hidden;aspect-ratio:3/4;
  background:var(--cream-3);
}
.patient-tile img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s var(--ease)}
.patient-tile:hover img{transform:scale(1.03)}

/* — Invisalign Facts Trio (Quellen-Fakten) — */
.facts-trio{
  display:grid;gap:32px;grid-template-columns:1fr;
  padding:24px 0;
}
@media(min-width:760px){.facts-trio{grid-template-columns:repeat(3,1fr);gap:48px}}
.fact{
  text-align:left;padding:8px 0;
  border-top:1px solid var(--stone-4);
}
@media(min-width:760px){.fact{border-top:0;border-left:1px solid var(--stone-4);padding:8px 0 8px 28px}
  .fact:first-child{border-left:0;padding-left:0}}
.fact-num{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:54px;line-height:1;color:var(--brand-deep);letter-spacing:-.025em;
}
.fact-num-unit{
  font-family:'Inter',sans-serif;font-weight:500;font-size:18px;
  color:var(--gold-deep);margin-left:4px;letter-spacing:0;
}
.fact-num sup{font-family:'Inter',sans-serif;font-size:14px;color:var(--gold-deep);font-weight:500;top:-18px;margin-left:2px}
.fact-label{
  margin-top:10px;font-size:14px;line-height:1.45;color:var(--ink-2);
  font-family:'Inter',sans-serif;
}
.fact-label sup{font-size:10px;color:var(--muted);margin-left:1px}
.facts-source{margin-top:18px;font-size:11px;color:var(--muted);font-family:'Inter',sans-serif}

/* — Slideshow — */
.slideshow{
  position:relative;border-radius:8px;overflow:hidden;
  background:transparent;
}
.slideshow-track{
  display:flex;transition:transform .55s var(--ease);will-change:transform;
}
.slide{flex:0 0 100%;aspect-ratio:16/10;background:transparent;border-radius:8px;overflow:hidden}
.slide img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;border-radius:8px}
@media(max-width:640px){.slide{aspect-ratio:4/5}}
.slide-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.9);border:1px solid var(--stone-4);
  color:var(--brand-deep);font-size:22px;line-height:1;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  -webkit-appearance:none;appearance:none;padding:0;
  touch-action:manipulation;-webkit-tap-highlight-color:transparent;
  transition:background .15s var(--ease),transform .15s var(--ease);
}
.slide-arrow:hover{background:#fff;transform:translateY(-50%) scale(1.05)}
.slide-prev{left:14px}
.slide-next{right:14px}
@media(max-width:560px){.slide-arrow{width:38px;height:38px;font-size:18px}.slide-prev{left:8px}.slide-next{right:8px}}
.slide-dots{
  position:absolute;left:0;right:0;bottom:14px;
  display:flex;gap:8px;justify-content:center;
}
.slide-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.55);border:1px solid rgba(0,0,0,.1);
  cursor:pointer;padding:0;-webkit-appearance:none;appearance:none;
  transition:background .15s var(--ease),transform .15s var(--ease);
}
.slide-dot.is-active{background:#fff;transform:scale(1.25)}

/* — Video-Badge (Anwender-Logo Overlay) — */
.video-block{position:relative}
.video-badge{
  position:absolute;left:18px;bottom:18px;
  display:flex;align-items:center;gap:12px;
  background:rgba(251,248,245,.94);
  border:1px solid rgba(255,255,255,.6);
  padding:10px 14px 10px 10px;border-radius:var(--r-md);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  max-width:calc(100% - 36px);
  box-shadow:var(--shadow-sm);
}
.video-badge img{
  width:48px;height:48px;border-radius:50%;
  object-fit:cover;flex-shrink:0;
  border:1px solid var(--stone-4);
}
.video-badge-text{display:flex;flex-direction:column;line-height:1.2;min-width:0}
.video-badge-text strong{
  font-family:'Inter',sans-serif;font-size:13px;font-weight:600;
  color:var(--brand-deep);letter-spacing:0;
}
.video-badge-text span{
  font-family:'Inter',sans-serif;font-size:12px;color:var(--ink-3);
  font-weight:400;margin-top:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
@media(max-width:560px){
  .video-badge{left:10px;bottom:10px;padding:8px 12px 8px 8px;gap:10px}
  .video-badge img{width:40px;height:40px}
  .video-badge-text strong{font-size:12px}
  .video-badge-text span{font-size:11px}
}

/* ────────────────────────────────────────────────────────────────────
   TX-CARD — Behandlungs-Karten im Pearlux-Pfingst-Stil
   Full-bleed Gradient-BG + Light-Scrim + Mono-Eyebrow + italic Serif-Name
   ──────────────────────────────────────────────────────────────────── */

.tx-grid{
  display:grid;grid-template-columns:repeat(3, 1fr);gap:18px;
  max-width:1180px;margin:0 auto;
}
@media(max-width:980px){.tx-grid{grid-template-columns:1fr;gap:14px;max-width:540px}}

.tx-card{
  position:relative;display:flex;flex-direction:column;
  border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--stone-4);
  min-height:520px;
  transition:transform .35s var(--ease), box-shadow .35s ease;
  isolation:isolate;text-decoration:none;color:inherit;
}
.tx-card:hover{transform:translateY(-3px);box-shadow:0 24px 50px -22px rgba(42,18,48,.25)}

.tx-card-bg{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-size:cover;background-position:center;
}
/* Soft white-to-cream scrim for legibility */
.tx-card-scrim{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(251,248,245,0) 0%,
    rgba(251,248,245,.32) 48%,
    rgba(251,248,245,.78) 86%,
    rgba(251,248,245,.92) 100%);
}

/* Per-treatment Background-Grafiken — Original gradient-01..06.webp aus dem Pearlux-Pattern */
.tx-card--invisalign   .tx-card-bg{background:url(/shape/assets/img/gradients/gradient-01.webp) center/cover no-repeat}
.tx-card--veneers      .tx-card-bg{background:url(/shape/assets/img/gradients/gradient-02.webp) center/cover no-repeat}
.tx-card--bleaching    .tx-card-bg{background:url(/shape/assets/img/gradients/gradient-03.webp) center/cover no-repeat}
.tx-card--pzr          .tx-card-bg{background:url(/shape/assets/img/gradients/gradient-04.webp) center/cover no-repeat}
.tx-card--anti-knirsch .tx-card-bg{background:url(/shape/assets/img/gradients/gradient-05.webp) center/cover no-repeat}
.tx-card--botulinum    .tx-card-bg{background:url(/shape/assets/img/gradients/gradient-06.webp) center/cover no-repeat}

.tx-card-inner{
  position:relative;z-index:2;
  display:flex;flex-direction:column;
  padding:26px 24px;flex:1;gap:14px;
}
.tx-card-head{margin-bottom:auto}
.tx-card-mono{
  display:block;
  font-family:'Inter',sans-serif;
  font-size:12px;font-weight:500;letter-spacing:0;text-transform:none;
  color:var(--gold-deep);
}
.tx-card-top{
  display:flex;align-items:center;gap:12px;margin-bottom:10px;
}
.tx-card-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:38px;height:38px;flex-shrink:0;border-radius:var(--r-sm);
  background:rgba(255,255,255,.7);border:1px solid rgba(42,18,48,.10);
  color:var(--brand-deep);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
}
.tx-card-icon svg{width:22px;height:22px;display:block}
.tx-card-name{
  font-family:'Fraunces','Cormorant Garamond',serif;
  font-style:italic;font-weight:400;
  font-size:clamp(32px,3.6vw,42px);line-height:1;letter-spacing:-.02em;
  color:var(--brand-deep);margin:0 0 14px;
}
.tx-card-tag-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.tx-card-tag{
  display:inline-flex;align-items:center;
  padding:5px 10px;border-radius:var(--r-sm);
  background:rgba(255,255,255,.7);
  border:1px solid rgba(42,18,48,.12);
  color:var(--brand-deep);
  font-size:11px;font-weight:500;letter-spacing:.04em;
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
}
.tx-card-spots{font-size:11.5px;color:var(--brand-deep);margin-left:auto;font-weight:500}
.tx-card-lede{
  font-size:14.5px;color:var(--ink-2);line-height:1.55;margin:10px 0 0;
  max-width:32ch;
}

.tx-card-foot{display:flex;flex-direction:column;gap:14px;margin-top:14px}
.tx-card-list{
  list-style:none;padding:14px 16px;margin:0;
  display:flex;flex-direction:column;gap:8px;
  border-radius:var(--r-sm);
  background:rgba(255,255,255,.55);
  border:1px solid rgba(42,18,48,.08);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
}
.tx-card-list li{
  font-size:13.5px;color:var(--ink-2);line-height:1.5;
  display:flex;align-items:flex-start;gap:9px;
}
.tx-card-list li::before{
  content:"";flex-shrink:0;width:10px;height:1px;background:var(--gold);
  margin-top:11px;
}

.tx-card-price{display:flex;align-items:baseline;gap:10px}
.tx-card-price-now{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:28px;color:var(--brand-deep);
  letter-spacing:-.02em;line-height:1;
}
.tx-card-price-was{font-size:13.5px;color:var(--muted);text-decoration:line-through}
.tx-card-price-unit{font-size:13px;color:var(--muted);font-family:'Inter',sans-serif;font-weight:500}

.tx-card-cta{
  display:inline-flex;align-items:center;justify-content:space-between;gap:8px;
  padding:13px 18px;border-radius:var(--r-sm);
  background:var(--brand-deep);color:#fff;
  border:1px solid var(--brand-deep);
  font-size:14px;font-weight:500;text-decoration:none;
  transition:background .2s ease;
  font-family:'Inter',sans-serif;letter-spacing:.01em;
}
.tx-card:hover .tx-card-cta{background:var(--brand)}
.tx-card-cta-arrow{transition:transform .25s ease;font-size:16px;line-height:1}
.tx-card:hover .tx-card-cta-arrow{transform:translateX(3px)}

/* ──────────────────────────────────────────────────────────────────────
   Video-Split (Desktop kompakt) — Video links, Invisalign-Facts rechts
   ────────────────────────────────────────────────────────────────────── */
.video-split{display:grid;gap:32px;grid-template-columns:1fr;align-items:center}
@media(min-width:900px){
  .video-split{grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);gap:48px}
}
.video-facts{display:flex;flex-direction:column;gap:22px}
.video-facts .fact{
  border:0;border-top:1px solid var(--stone-4);
  padding:18px 0 0;
}
.video-facts .fact:first-child{border-top:0;padding-top:0}
.video-facts .fact-num{font-size:42px;line-height:1;color:var(--brand-deep)}
.video-facts .fact-num-unit{font-size:16px}
.video-facts .fact-label{font-size:14px;margin-top:6px;color:var(--ink-2);line-height:1.45}
.video-facts .facts-source{margin-top:4px}

/* ──────────────────────────────────────────────────────────────────────
   Results-Split — Slideshow rechts klein, Features links mit Icons
   ────────────────────────────────────────────────────────────────────── */
.section-tight-y{padding:48px 0}
@media(min-width:768px){.section-tight-y{padding:64px 0}}

.results-split{
  display:grid;gap:32px;grid-template-columns:1fr;align-items:center;
}
@media(min-width:900px){
  .results-split{grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:56px}
}
.results-copy .eyebrow{margin-bottom:14px}
.results-copy h2{margin:0 0 22px}
.results-features{
  list-style:none;padding:0;margin:0 0 18px;
  display:flex;flex-direction:column;gap:18px;
}
.results-features li{
  display:grid;grid-template-columns:38px 1fr;gap:14px;align-items:flex-start;
}
/* Sowohl <svg class="ico"> als auch ungeklassifizierte SVGs als direkte
   Kinder von <li> erhalten dasselbe Box-Format — explizite Größen damit
   Desktop nicht klein (collapsed grid) und Mobile nicht riesig (intrinsic). */
.results-features .ico,
.results-features li > svg{
  width:38px;height:38px;flex-shrink:0;display:block;
  padding:7px;border-radius:8px;
  background:var(--cream-3);border:1px solid var(--stone-4);
  color:var(--brand-deep);
  box-sizing:border-box;overflow:visible;
}
.results-features li strong{
  display:block;font-family:'Inter',sans-serif;font-weight:500;
  font-size:15px;color:var(--brand-deep);margin-bottom:2px;letter-spacing:0;
}
.results-features li span{
  display:block;font-size:14px;color:var(--ink-3);line-height:1.55;
}
.results-media .slideshow-sm{max-width:560px;margin-left:auto}
.slideshow-sm .slide{aspect-ratio:4/3}
@media(max-width:900px){
  .results-media .slideshow-sm{max-width:none;margin:0 auto}
}

/* ──────────────────────────────────────────────────────────────────────
   CTA-Band — em darf nicht in brand-purple auf brand-deep stehen
   (kein Kontrast) — auf Gold setzen
   ────────────────────────────────────────────────────────────────────── */
.cta-band h2 em,
.cta-band h2 .accent,
.section-deep h2 em,
.section-deep h2 .accent{
  color:var(--gold-soft);
}

/* ──────────────────────────────────────────────────────────────────────
   Spec-Bar Icons (kleine Linien-Icons pro Eckdatum)
   ────────────────────────────────────────────────────────────────────── */
.spec{flex-direction:row !important;align-items:center;gap:12px}
.spec-icon{
  width:36px;height:36px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--stone-4);border-radius:var(--r-sm);
  color:var(--gold-deep);background:var(--cream-3);
}
.spec-icon svg{width:20px;height:20px;display:block}
.spec-text{display:flex;flex-direction:column;gap:2px;min-width:0}

/* ──────────────────────────────────────────────────────────────────────
   TX-Page — durchgehender BG mit weichen radialen Verläufen
   Treatment-Detail-Pages erhalten eine sanfte, asymmetrische Cream-Aubergine-
   Gradient-Komposition als Grundton — Sections darüber sind transparent,
   damit der BG-Flow ungebrochen erscheint.
   ────────────────────────────────────────────────────────────────────── */
.tx-page{
  position:relative;
  background:
    radial-gradient(1400px 900px at 8% 4%,   rgba(243,236,234,.95), transparent 58%),
    radial-gradient(1100px 800px at 100% 22%, rgba(236,223,222,.55), transparent 62%),
    radial-gradient(1300px 1000px at 18% 55%, rgba(246,241,238,.80), transparent 68%),
    radial-gradient(900px 700px at 92% 72%,  rgba(240,234,230,.55), transparent 65%),
    radial-gradient(1500px 1100px at 50% 100%, rgba(243,236,234,.65), transparent 70%),
    var(--cream);
}
/* Sections innerhalb .tx-page haben transparenten BG, damit der Grundverlauf
   durchscheint. Ausnahmen: .cta-band (Aubergine), .cred-box (Aubergine+Video). */
.tx-page > section,
.tx-page .section-cream,
.tx-page .section-tight-y,
.tx-page .spec-bar{
  background:transparent !important;
}
.tx-page .spec-bar{
  border-top:1px solid rgba(221,208,205,.6);
  border-bottom:1px solid rgba(221,208,205,.6);
}
/* Detail-Hero auch transparent, damit der Verlauf an der Spitze beginnt.
   Die ::before / ::after-Decorationen bleiben für die Aubergine-Akzente. */
.tx-page .detail-hero{background:transparent}

/* ──────────────────────────────────────────────────────────────────────
   Cred-Box — kompakte Behandlungsdetails-Section (laserazor-Stil)
   Dark Box mit BG-Video, Eyebrow + 2-tone Headline + Lead + Badge-Grid.
   ────────────────────────────────────────────────────────────────────── */
.cred-box{
  position:relative;overflow:hidden;isolation:isolate;
  border-radius:var(--r-md);
  padding:clamp(40px,6vw,64px);
  color:#fff;
  background:var(--brand-deep);
  max-width:1180px;margin:0 auto;
}
.cred-bg-video{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  z-index:0;opacity:.35;
}
.cred-box::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(42,18,48,.5) 0%,rgba(42,18,48,.75) 100%);
}
.cred-inner{position:relative;z-index:1}

.cred-eyebrow{
  display:inline-block;
  font-family:'Inter',sans-serif;font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;
  color:rgba(255,255,255,.5);
  margin-bottom:16px;
}
.cred-headline{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:clamp(28px,3.6vw,44px);
  letter-spacing:-.025em;line-height:1.08;
  margin:0 0 14px;color:#fff;
}
.cred-headline .thin{
  font-style:italic;font-weight:300;
  color:rgba(255,255,255,.55);
}
.cred-headline .bold{
  font-style:normal;font-weight:500;color:#fff;
}
.cred-headline em{
  /* fallback wenn der user-headline kein .thin/.bold span hat */
  font-style:italic;font-weight:300;color:rgba(255,255,255,.55);
}
.cred-lead{
  font-size:15px;color:rgba(255,255,255,.7);
  max-width:560px;line-height:1.65;
  margin:0 0 clamp(28px,3.5vw,40px);
}

.cred-grid{
  display:grid;gap:28px 32px;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
}
.cred-item h4{
  font-family:'Inter',sans-serif;font-size:14.5px;font-weight:600;
  color:#fff;letter-spacing:-.005em;
  margin:0 0 5px;line-height:1.3;
}
.cred-item p{
  font-size:12.5px;color:rgba(255,255,255,.55);
  line-height:1.55;margin:0;
}

/* ──────────────────────────────────────────────────────────────────────
   Feature-Compact (Legacy) — falls noch verwendet
   ────────────────────────────────────────────────────────────────────── */
.feature-grid-compact{
  display:flex;flex-direction:column;gap:28px;
  max-width:1180px;margin:0 auto;
}

.feature-compact{
  display:grid;grid-template-columns:1fr;
  background:#fff;border:1px solid var(--stone-4);
  border-radius:var(--r-md);overflow:hidden;
  isolation:isolate;position:relative;
  transition:border-color .25s var(--ease),transform .25s var(--ease),box-shadow .25s var(--ease);
}
@media(min-width:760px){
  .feature-compact{
    grid-template-columns:340px 1fr;
    align-items:center;
  }
  /* Alternierend: Foto bei 2. Karte rechts, bei 3. links etc. */
  .feature-compact:nth-child(even){grid-template-columns:1fr 340px}
  .feature-compact:nth-child(even) .feature-compact-media{order:2}
}
@media(min-width:1080px){
  .feature-compact{grid-template-columns:400px 1fr}
  .feature-compact:nth-child(even){grid-template-columns:1fr 400px}
}
.feature-compact:hover{
  border-color:var(--brand);transform:translateY(-2px);
  box-shadow:0 18px 40px -18px rgba(42,18,48,.18);
}

/* Foto-Box — aspect-ratio inline gesetzt (matched echtes Foto). */
.feature-compact-media{
  position:relative;
  background:var(--cream-3);
  overflow:hidden;
  /* aspect-ratio kommt inline aus build.py */
}
.feature-compact-media img{
  width:100%;height:100%;
  object-fit:cover;          /* Box matched Foto-Aspect → kein echter Crop */
  display:block;
  transition:transform .9s var(--ease);
}
.feature-compact:hover .feature-compact-media img{transform:scale(1.03)}

.feature-compact-body{
  padding:28px 28px 30px;
  display:flex;flex-direction:column;gap:12px;
}
@media(min-width:760px){.feature-compact-body{padding:32px 36px}}
@media(min-width:1080px){.feature-compact-body{padding:40px 44px}}
.feature-compact-kicker{
  display:inline-flex;align-items:center;gap:9px;
  font-family:'Inter',sans-serif;font-size:11.5px;font-weight:500;
  color:var(--gold-deep);letter-spacing:0;
}
.feature-compact-kicker svg{width:14px;height:14px;flex-shrink:0;color:var(--brand-deep)}
.feature-compact-icon{
  width:24px;height:24px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--stone-4);background:var(--cream-3);
  border-radius:50%;color:var(--brand-deep);
}
.feature-compact-icon svg{width:13px;height:13px;display:block}
.feature-compact h3{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:clamp(24px,2.4vw,30px);line-height:1.15;
  color:var(--brand-deep);letter-spacing:-.015em;margin:0;
}
.feature-compact-text{font-size:15.5px;color:var(--ink-3);line-height:1.65}
.feature-compact-text p{font-size:15.5px;color:var(--ink-3);line-height:1.65;margin:0 0 10px}
.feature-compact-text p:last-child{margin-bottom:0}
.feature-compact-text strong{color:var(--brand-deep);font-weight:500}
.feature-compact-text a{color:var(--brand);text-decoration:underline;text-underline-offset:3px}

/* Kompakte Steps-Liste (Timeline-Stil mit dezenten Goldnummern) */
.feature-compact-steps{
  list-style:none;padding:0;margin:6px 0 0;counter-reset:fcstep;
  display:flex;flex-direction:column;
}
.feature-compact-steps li{
  counter-increment:fcstep;
  display:grid;grid-template-columns:32px 1fr;gap:14px;
  padding:12px 0;align-items:start;
  font-size:14px;color:var(--ink-3);line-height:1.55;
}
.feature-compact-steps li + li{border-top:1px solid var(--stone-5)}
.feature-compact-steps li::before{
  content:counter(fcstep,decimal-leading-zero);
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:15px;color:#fff;background:var(--brand-deep);
  width:28px;height:28px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  letter-spacing:0;padding-top:1px;
}
.feature-compact-steps li strong{
  display:block;font-family:'Inter',sans-serif;font-weight:500;
  color:var(--brand-deep);font-size:13.5px;letter-spacing:0;
  margin-bottom:3px;line-height:1.3;
}

/* Kompakte Bullet-Liste */
.feature-compact-list{
  list-style:none;padding:0;margin:6px 0 0;
  display:flex;flex-direction:column;
}
.feature-compact-list li{
  font-size:14px;color:var(--ink-3);line-height:1.55;
  display:grid;grid-template-columns:14px 1fr;gap:10px;
  align-items:start;padding:8px 0;
}
.feature-compact-list li + li{border-top:1px solid var(--stone-5)}
.feature-compact-list li::before{
  content:"";width:12px;height:1px;background:var(--gold);margin-top:11px;
}
.feature-compact-list li strong{color:var(--brand-deep);font-weight:500}

/* Legacy feature-rows fallback (aktuell von keiner Page genutzt) */
.feature-rows{display:grid;gap:32px;grid-template-columns:1fr;max-width:1180px;margin:0 auto}
.feature-row{display:grid;gap:24px;grid-template-columns:1fr;align-items:center}
@media(min-width:900px){.feature-row{grid-template-columns:1fr 1fr;gap:56px}}
.feature-row-media{
  position:relative;border-radius:var(--r-md);overflow:hidden;
  aspect-ratio:4/3;
  border:1px solid var(--stone-4);
  background:linear-gradient(135deg,var(--cream-3),var(--cream-2));
  box-shadow:0 24px 60px -24px rgba(42,18,48,.25);
  isolation:isolate;
}
.feature-row-media img{
  width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .9s var(--ease);
}
.feature-row:hover .feature-row-media img{transform:scale(1.025)}
/* Aubergine-Gold-Verlauf-Schleier */
.feature-row-media::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(135deg,rgba(91,42,107,.08) 0%,transparent 45%);
}
.feature-row-media::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(circle at 100% 100%,rgba(164,130,67,.18),transparent 60%);
}

.feature-row-body{display:flex;flex-direction:column;gap:14px}

.feature-row-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--gold-deep);font-family:'Inter',sans-serif;
  font-size:12.5px;font-weight:500;letter-spacing:0;
}
.feature-row-icon{
  width:30px;height:30px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--stone-4);background:var(--cream-3);
  border-radius:var(--r-sm);color:var(--brand-deep);
}
.feature-row-icon svg{width:17px;height:17px;display:block}

.feature-row-title{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:clamp(26px,2.8vw,36px);line-height:1.12;
  color:var(--brand-deep);letter-spacing:-.02em;margin:0;
}

.feature-row-text{font-size:15.5px;color:var(--ink-3);line-height:1.7}
.feature-row-text p{font-size:15.5px;color:var(--ink-3);line-height:1.7;margin:0 0 12px}
.feature-row-text p:last-child{margin-bottom:0}
.feature-row-text strong{color:var(--brand-deep);font-weight:500}
.feature-row-text a{color:var(--brand);text-decoration:underline;text-underline-offset:3px}
.feature-row-text ul,.feature-row-text ol{margin:6px 0 0;padding:0}

/* Legacy aliases — Behandlungsseiten verwenden noch .feature-box-* Klassen
   in den Bodies (Steps-Liste / Bullet-Liste). Verhalten unverändert. */
.feature-grid{display:flex;flex-direction:column;gap:56px;max-width:1180px;margin:0 auto}
.feature-grid--3,.feature-grid--single{grid-template-columns:none}
.feature-box{
  display:grid;gap:28px;grid-template-columns:1fr;align-items:center;
  background:transparent;border:0;padding:0;
}
@media(min-width:900px){.feature-box{grid-template-columns:1fr 1fr;gap:64px}}
.feature-box:hover{transform:none;box-shadow:none;border:0}
.feature-box-icon{display:none}
.feature-box-kicker{
  display:inline-flex;align-items:center;
  color:var(--gold-deep);font-family:'Inter',sans-serif;
  font-size:12.5px;font-weight:500;letter-spacing:0;margin:0;
}
.feature-box h3{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:clamp(26px,2.8vw,36px);line-height:1.12;
  color:var(--brand-deep);letter-spacing:-.02em;margin:0;
}
.feature-box-body{font-size:15.5px;color:var(--ink-3);line-height:1.7}
.feature-box-body p{font-size:15.5px;color:var(--ink-3);line-height:1.7;margin:0 0 12px}
.feature-box-body p:last-child{margin-bottom:0}
.feature-box-body strong{color:var(--brand-deep);font-weight:500}
.feature-box-body a{color:var(--brand);text-decoration:underline;text-underline-offset:3px}

/* Strukturierte Liste innerhalb Feature-Box (Ablauf-Steps) */
.feature-box-steps{
  list-style:none;padding:0;margin:14px 0 0;
  display:flex;flex-direction:column;gap:0;counter-reset:fbstep;
}
.feature-box-steps li{
  display:grid;grid-template-columns:48px 1fr;gap:18px;align-items:start;
  counter-increment:fbstep;
  padding:18px 0;
  border-bottom:1px solid var(--stone-5);
  font-size:15px;color:var(--ink-3);line-height:1.6;
}
.feature-box-steps li:first-child{padding-top:8px}
.feature-box-steps li:last-child{border-bottom:0;padding-bottom:0}
.feature-box-steps li::before{
  content:counter(fbstep,decimal-leading-zero);
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:28px;color:var(--gold);line-height:1;letter-spacing:-.02em;
  padding-top:2px;
}
.feature-box-steps li strong{
  display:block;color:var(--brand-deep);font-weight:500;
  font-family:'Inter',sans-serif;font-size:14.5px;
  letter-spacing:0;margin-bottom:5px;line-height:1.3;
}

/* Bullet-Liste in Feature-Box (compact, mit gold dash) */
.feature-box-list{
  list-style:none;padding:0;margin:14px 0 0;
  display:flex;flex-direction:column;gap:12px;
}
.feature-box-list li{
  font-size:15px;color:var(--ink-3);line-height:1.6;
  display:grid;grid-template-columns:16px 1fr;gap:12px;align-items:start;
  padding-bottom:12px;border-bottom:1px solid var(--stone-5);
}
.feature-box-list li:last-child{border-bottom:0;padding-bottom:0}
.feature-box-list li::before{
  content:"";width:14px;height:1px;background:var(--gold);
  margin-top:11px;align-self:start;
}
.feature-box-list li strong{color:var(--brand-deep);font-weight:500}

/* Wenn nur 1 große Box (Wichtiger Hinweis o.ä.) — full width */
.feature-grid--single{grid-template-columns:1fr;max-width:920px}

/* ──────────────────────────────────────────────────────────────────────
   Doctor-Box — Arzt-Karte für Treatment-Pages
   ────────────────────────────────────────────────────────────────────── */
.doctor-box{
  display:grid;gap:0;grid-template-columns:1fr;
  background:#fff;border:1px solid var(--stone-4);
  border-radius:var(--r-md);overflow:hidden;
  position:relative;isolation:isolate;
}
.doctor-box::before{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(135deg,rgba(91,42,107,.04),transparent 50%),
             radial-gradient(circle at 90% 110%,rgba(164,130,67,.10),transparent 60%);
}
@media(min-width:780px){.doctor-box{grid-template-columns:320px 1fr;gap:0}}
.doctor-box-photo{
  position:relative;aspect-ratio:1/1;background:var(--cream-3);overflow:hidden;
}
@media(min-width:780px){.doctor-box-photo{aspect-ratio:auto;height:100%}}
.doctor-box-photo img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.doctor-box-photo::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 65%,rgba(42,18,48,.18));
}
.doctor-box-body{padding:32px 28px}
@media(min-width:780px){.doctor-box-body{padding:42px 42px}}
.doctor-box-kicker{
  font-family:'Inter',sans-serif;font-size:12.5px;font-weight:500;
  color:var(--gold-deep);letter-spacing:0;text-transform:none;
  margin:0 0 8px;
}
.doctor-box-name{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:clamp(26px,2.4vw,32px);line-height:1.1;
  color:var(--brand-deep);letter-spacing:-.02em;margin:0 0 16px;
}
.doctor-box-quote{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:clamp(17px,1.4vw,20px);color:var(--ink-2);
  line-height:1.55;margin:0 0 18px;letter-spacing:-.005em;
}
.doctor-box-bio{font-size:14.5px;color:var(--ink-3);line-height:1.65;margin:0 0 10px}
.doctor-box-bio:last-child{margin-bottom:0}
.doctor-box-creds{
  display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;
}
.doctor-box-creds span{
  font-family:'Inter',sans-serif;font-size:11.5px;font-weight:500;
  color:var(--brand-deep);background:var(--cream-3);
  border:1px solid var(--stone-4);
  padding:5px 11px;border-radius:var(--r-sm);letter-spacing:0;
}

/* ──────────────────────────────────────────────────────────────────────
   Praxis-Slideshow (autoplay) — überschreibt .slider auf Behandlungsseiten
   .slideshow-praxis ähnlich .slideshow, aber mit 16/10 ratio
   ────────────────────────────────────────────────────────────────────── */
.slideshow-praxis{position:relative;border-radius:8px;overflow:hidden;background:transparent}
.slideshow-praxis .slide{aspect-ratio:16/10;background:transparent;border-radius:8px}
.slideshow-praxis .slide img{border-radius:8px}
@media(max-width:640px){.slideshow-praxis .slide{aspect-ratio:4/3}}

/* Slideshow-Badge — sanftes Glass-Overlay mit Icon */
.slideshow-badge{
  position:absolute;left:18px;bottom:18px;z-index:2;
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(251,248,245,.92);
  border:1px solid rgba(255,255,255,.6);
  padding:9px 14px;border-radius:8px;
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 8px 24px -8px rgba(42,18,48,.25);
  font-family:'Inter',sans-serif;
  pointer-events:none;
}
.slideshow-badge-icon{
  width:24px;height:24px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:50%;background:var(--brand-deep);color:#fff;
}
.slideshow-badge-icon svg{width:13px;height:13px;display:block}
.slideshow-badge-text{display:flex;flex-direction:column;line-height:1.2}
.slideshow-badge-text strong{
  font-size:12.5px;font-weight:600;color:var(--brand-deep);letter-spacing:0;
}
.slideshow-badge-text span{
  font-size:11px;color:var(--ink-3);font-weight:400;
}
@media(max-width:560px){
  .slideshow-badge{left:10px;bottom:10px;padding:7px 11px;gap:8px}
  .slideshow-badge-icon{width:20px;height:20px}
  .slideshow-badge-text strong{font-size:11.5px}
  .slideshow-badge-text span{font-size:10.5px}
}

/* ──────────────────────────────────────────────────────────────────────
   Pricing-Deck mit Gradient-BG (tx-card-Stil aus Home)
   Full-bleed Gradient-Hintergrund + Light-Cream-Scrim
   ────────────────────────────────────────────────────────────────────── */
.pak{
  position:relative;isolation:isolate;
  background:#fff;
  overflow:hidden;
  min-height:480px;
  display:flex;flex-direction:column;gap:12px;
  padding:26px 22px;
}
/* Layer 0: Gradient-Background (per Tier-Klasse) */
.pak::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background-size:cover;background-position:center;background-repeat:no-repeat;
}
/* Layer 1: Light-Cream-Scrim für Lesbarkeit */
.pak::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(180deg,
    rgba(251,248,245,0)   0%,
    rgba(251,248,245,.30) 38%,
    rgba(251,248,245,.78) 82%,
    rgba(251,248,245,.94) 100%);
}
.pak > *{position:relative;z-index:1}

/* Tier-spezifische Gradient-Backgrounds (gradient-01..06) */
.pak--gr01::before{background-image:url(/shape/assets/img/gradients/gradient-01.webp)}
.pak--gr02::before{background-image:url(/shape/assets/img/gradients/gradient-02.webp)}
.pak--gr03::before{background-image:url(/shape/assets/img/gradients/gradient-03.webp)}
.pak--gr04::before{background-image:url(/shape/assets/img/gradients/gradient-04.webp)}
.pak--gr05::before{background-image:url(/shape/assets/img/gradients/gradient-05.webp)}
.pak--gr06::before{background-image:url(/shape/assets/img/gradients/gradient-06.webp)}

.pak:hover{transform:translateY(-3px);box-shadow:0 24px 50px -22px rgba(42,18,48,.25)}

.pak.featured{border-color:var(--brand)}
.pak.featured > .pak-name + .pak-price{
  /* Featured-Highlight per kleinem Akzent — kein riesiges Empfohlen-Tag */
}
.pak.featured::before{filter:saturate(1.15) brightness(1.02)}

.pak-icon{
  width:38px;height:38px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(42,18,48,.10);border-radius:var(--r-sm);
  color:var(--brand-deep);background:rgba(255,255,255,.7);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
}
.pak-icon svg{width:22px;height:22px;display:block}

.pak-name{
  font-family:'Inter',sans-serif;font-size:12.5px;font-weight:500;
  color:var(--gold-deep);letter-spacing:0;text-transform:none;
  margin:4px 0 0;
}

.pak-price{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:clamp(34px,3.6vw,44px);line-height:1;
  color:var(--brand-deep);letter-spacing:-.025em;margin:0;
}
.pak-price sup{font-size:14px;color:var(--gold-deep);font-weight:500;font-family:'Inter',sans-serif;margin-left:2px;top:-12px;position:relative}
.pak-price-prefix{font-family:'Inter',sans-serif;font-size:14px;font-style:normal;font-weight:500;color:var(--muted);letter-spacing:0;margin-right:6px;vertical-align:6px}
.pak-price-unit{font-family:'Inter',sans-serif;font-size:13px;font-style:normal;font-weight:500;color:var(--muted);letter-spacing:0}
.pak-once{font-family:'Inter',sans-serif;font-size:12.5px;color:var(--ink-3);margin-top:-2px}

.pak-sub{
  font-size:14px;color:var(--ink-2);line-height:1.55;margin:6px 0 0;
  max-width:32ch;
}

.pak-list{
  list-style:none;padding:14px 16px;margin:8px 0 0;
  display:flex;flex-direction:column;gap:8px;
  border-radius:var(--r-sm);
  background:rgba(255,255,255,.55);
  border:1px solid rgba(42,18,48,.08);
  -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
  flex:1;
}
.pak-list li{
  font-size:13.5px;color:var(--ink-2);line-height:1.5;
  display:flex;align-items:flex-start;gap:9px;
  padding:0;border:0;
}
.pak-list li::before{
  content:"";flex-shrink:0;width:10px;height:1px;background:var(--gold);
  margin-top:10px;
}

.pak-cta{
  margin-top:8px !important;
  display:inline-flex !important;align-items:center;justify-content:center;gap:8px;
  padding:12px 18px !important;border-radius:var(--r-sm);
  background:var(--brand-deep);color:#fff !important;
  border:1px solid var(--brand-deep) !important;
  font-size:13.5px !important;font-weight:500;text-decoration:none;
  transition:background .2s ease;
  font-family:'Inter',sans-serif;letter-spacing:.01em;
}
.pak-cta:hover{background:var(--brand) !important;color:#fff !important}

.pak-ratenrechner{
  display:inline-flex;align-items:center;gap:6px;
  font-family:'Inter',sans-serif;font-size:12.5px;font-weight:500;
  color:var(--gold-deep);text-decoration:none;
  margin-top:2px;letter-spacing:0;
  transition:color .2s var(--ease);
}
.pak-ratenrechner:hover{color:var(--brand)}
.pak-ratenrechner svg{width:14px;height:14px;flex-shrink:0}
.pak-ratenrechner::after{
  content:"→";font-size:13px;transition:transform .2s var(--ease);
}
.pak-ratenrechner:hover::after{transform:translateX(2px)}
.pak-finex{
  font-size:10.5px;line-height:1.45;color:var(--muted);
  margin-top:2px;padding-top:8px;border-top:1px dashed rgba(42,18,48,.12);
}

/* ──────────────────────────────────────────────────────────────────────
   Section-head Variants — Eyebrow auf Detail-Seiten gold-deep
   ────────────────────────────────────────────────────────────────────── */
.section-head-left .eyebrow{margin-bottom:12px}
.section-head-left h2{margin:0 0 14px}
.section-head-left p{font-size:16.5px;color:var(--ink-3);line-height:1.65;max-width:680px}

/* ──────────────────────────────────────────────────────────────────────
   Pak-Tabs (Reiter über dem Pricing-Deck — z.B. Veneer-Pakete)
   ────────────────────────────────────────────────────────────────────── */
.pak-headline-claim{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  margin:0 auto 36px;text-align:center;max-width:760px;
}
.pak-headline-rate{
  display:inline-flex;flex-direction:column;align-items:center;gap:4px;
}
.pak-headline-label{
  font-family:'Inter',sans-serif;font-size:12.5px;font-weight:500;
  color:var(--gold-deep);letter-spacing:0;text-transform:none;
}
.pak-headline-rate strong{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:clamp(40px,5.5vw,68px);line-height:1;
  color:var(--brand-deep);letter-spacing:-.025em;
}
.pak-headline-foot{
  font-family:'Inter',sans-serif;font-size:12.5px;color:var(--muted);
  line-height:1.55;max-width:560px;
}

.pak-tabs{
  display:flex;flex-wrap:wrap;gap:0;
  border-bottom:1px solid var(--stone-4);
  margin:0 auto 32px;justify-content:center;
}
.pak-tab{
  background:transparent;border:0;cursor:pointer;
  padding:14px 22px;margin:0;
  font-family:'Inter',sans-serif;font-size:14px;font-weight:500;
  color:var(--muted);letter-spacing:0;text-transform:none;
  border-bottom:2px solid transparent;
  transition:color .2s var(--ease),border-color .2s var(--ease);
  -webkit-appearance:none;appearance:none;
}
.pak-tab:hover{color:var(--brand-deep)}
.pak-tab.is-active{
  color:var(--brand-deep);
  border-bottom-color:var(--brand);
}
.pak-tab-panel{display:none}
.pak-tab-panel.is-active{display:block;animation:pak-fade .35s var(--ease)}
@keyframes pak-fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* ──────────────────────────────────────────────────────────────────────
   Pricing-Deck mit 1-3 Karten — zentriert + nicht zu breit
   ────────────────────────────────────────────────────────────────────── */
/* 1-3 Karten zentriert (PZR/Bleaching/Anti-Knirsch) — kein Horizontal-Scroll nötig */
.pricing-deck--center{
  max-width:920px;margin-left:auto;margin-right:auto;
}
@media(min-width:980px){
  .pricing-deck--center{
    display:grid;overflow:visible;flex-wrap:initial;padding:0;
  }
  .pricing-deck--center .pak{flex:initial;min-width:0;max-width:none}
}
.pricing-deck--center[data-n="1"]{max-width:480px;grid-template-columns:1fr}
.pricing-deck--center[data-n="2"]{max-width:780px;grid-template-columns:1fr}
.pricing-deck--center[data-n="3"]{grid-template-columns:1fr}
@media(min-width:680px){
  .pricing-deck--center[data-n="2"]{grid-template-columns:1fr 1fr}
  .pricing-deck--center[data-n="3"]{grid-template-columns:repeat(3,1fr)}
}

/* ──────────────────────────────────────────────────────────────────────
   SmileView Card — clickbare Vorschau-Karte mit großem Bild + CTA-Overlay
   ────────────────────────────────────────────────────────────────────── */
/* ──────────────────────────────────────────────────────────────────────
   SmileView 2-Spalter (Desktop) — Grafik links, Text + CTA rechts
   Mobile: stacked, Grafik oben.
   ────────────────────────────────────────────────────────────────────── */
.smileview-split{
  display:grid;gap:32px;grid-template-columns:1fr;align-items:center;
  max-width:1180px;margin:0 auto;
}
@media(min-width:900px){
  .smileview-split{grid-template-columns:1.05fr .95fr;gap:56px}
}
.smileview-media{
  display:block;position:relative;
  border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--stone-4);
  background:linear-gradient(135deg,var(--cream-3),#fff);
  aspect-ratio:16/10;
  box-shadow:0 24px 60px -24px rgba(42,18,48,.25);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.smileview-media:hover{transform:translateY(-2px);box-shadow:0 28px 70px -24px rgba(42,18,48,.32)}
.smileview-media img{
  width:100%;height:100%;
  object-fit:contain;
  padding:18px;
  display:block;
}
.smileview-copy{display:flex;flex-direction:column;gap:14px}
.smileview-copy .eyebrow{margin-bottom:4px}
.smileview-copy h2{margin:0 0 6px}
.smileview-copy p{margin:0;font-size:16px;color:var(--ink-3);line-height:1.65}
.smileview-btn{align-self:flex-start;margin-top:10px}
.smileview-arrow{
  display:inline-block;transition:transform .25s var(--ease);
  margin-left:6px;
}
.smileview-btn:hover .smileview-arrow{transform:translateX(4px)}
.smileview-legal{margin:14px 0 0;max-width:none;font-size:11.5px;color:var(--muted);line-height:1.55}

/* ──────────────────────────────────────────────────────────────────────
   Ratgeber-Section (Invisalign-Page) — Badge + gruppierte Artikellinks
   ────────────────────────────────────────────────────────────────────── */
.ratgeber-hero-badge{
  display:inline-flex;align-items:center;gap:14px;
  padding:14px 22px 14px 16px;
  background:linear-gradient(135deg,var(--cream-3),#fff);
  border:1px solid var(--stone-4);border-radius:var(--r-md);
  text-decoration:none;color:var(--brand-deep);
  margin-bottom:20px;
  transition:transform .25s var(--ease),border-color .25s var(--ease),box-shadow .25s var(--ease);
}
.ratgeber-hero-badge:hover{
  border-color:var(--brand);transform:translateY(-2px);
  box-shadow:0 14px 30px -16px rgba(42,18,48,.20);
}
.ratgeber-hero-badge-icon{
  width:42px;height:42px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--brand-deep);color:#fff;
  border-radius:var(--r-sm);
}
.ratgeber-hero-badge-icon svg{width:22px;height:22px}
.ratgeber-hero-badge-text{display:flex;flex-direction:column;line-height:1.15;text-align:left}
.ratgeber-hero-badge-label{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:18px;color:var(--brand-deep);letter-spacing:-.01em;
}
.ratgeber-hero-badge-count{
  font-family:'Inter',sans-serif;font-size:12.5px;font-weight:500;
  color:var(--gold-deep);letter-spacing:0;margin-top:2px;
}
.ratgeber-hero-badge-arrow{
  font-size:18px;color:var(--brand-deep);transition:transform .25s var(--ease);
}
.ratgeber-hero-badge:hover .ratgeber-hero-badge-arrow{transform:translateX(4px)}

.ratgeber-groups{
  display:grid;gap:32px;grid-template-columns:1fr;
  max-width:1180px;margin:0 auto;
}
@media(min-width:760px){.ratgeber-groups{grid-template-columns:repeat(3,1fr);gap:40px}}

.ratgeber-group{
  background:#fff;border:1px solid var(--stone-4);
  border-radius:var(--r-md);padding:28px 24px;
  position:relative;isolation:isolate;overflow:hidden;
}
.ratgeber-group::before{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(circle at 0% 0%,rgba(164,130,67,.06),transparent 55%);
}
.ratgeber-group-head{
  display:flex;align-items:center;gap:12px;
  padding-bottom:16px;margin-bottom:14px;
  border-bottom:1px solid var(--stone-4);
}
.ratgeber-group-icon{
  width:34px;height:34px;flex-shrink:0;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--stone-4);background:var(--cream-3);
  color:var(--brand-deep);border-radius:var(--r-sm);
}
.ratgeber-group-icon svg{width:18px;height:18px}
.ratgeber-group-title{
  font-family:'Fraunces',serif;font-style:italic;font-weight:400;
  font-size:20px;color:var(--brand-deep);letter-spacing:-.015em;
  margin:0;line-height:1.1;
}
.ratgeber-links{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:2px}
.ratgeber-links li{margin:0}
.ratgeber-links a{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:9px 0;font-size:14px;font-weight:500;
  color:var(--ink-2);font-family:'Inter',sans-serif;letter-spacing:0;
  border-bottom:1px solid var(--stone-5);
  text-decoration:none;
  transition:color .15s var(--ease),padding .15s var(--ease);
}
.ratgeber-links li:last-child a{border-bottom:0}
.ratgeber-links a::after{
  content:"→";color:var(--gold-deep);opacity:.4;
  transition:opacity .15s var(--ease),transform .15s var(--ease);
}
.ratgeber-links a:hover{color:var(--brand);padding-left:4px}
.ratgeber-links a:hover::after{opacity:1;transform:translateX(3px)}

.ratgeber-all{text-align:center;margin-top:36px}

/* ============================================================
   Vorher-Nachher Vergleichs-Slider
   ============================================================ */
.vornach{max-width:980px;margin:0 auto}
.vornach-frame{
  position:relative;
  margin:0;
  aspect-ratio:2 / 1;
  overflow:hidden;
  border-radius:var(--r-md);
  background:var(--stone-5);
  box-shadow:var(--shadow-lg);
  user-select:none;
  -webkit-user-select:none;
  touch-action:none;
  --pos:50%;
}
.vornach-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;display:block;pointer-events:none;
}
.vornach-img--after{
  clip-path:inset(0 0 0 var(--pos));
  -webkit-clip-path:inset(0 0 0 var(--pos));
}
.vornach-label{
  position:absolute;top:14px;z-index:3;pointer-events:none;
  font-family:'Inter',sans-serif;font-size:10.5px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  padding:6px 11px;border-radius:var(--r-sm);
  background:rgba(42,18,48,.72);color:#fff;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}
.vornach-label--before{left:14px}
.vornach-label--after{right:14px;background:rgba(125,74,142,.85)}
.vornach-handle{
  position:absolute;top:0;bottom:0;left:var(--pos);
  width:0;transform:translateX(-50%);
  cursor:ew-resize;z-index:5;
  outline:none;
}
.vornach-handle-bar{
  position:absolute;top:0;bottom:0;left:50%;
  width:2px;transform:translateX(-50%);
  background:#fff;box-shadow:0 0 0 1px rgba(42,18,48,.18);
}
.vornach-handle-knob{
  position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:48px;height:48px;border-radius:50%;
  background:#fff;color:var(--brand);
  display:grid;place-items:center;
  box-shadow:0 8px 22px rgba(42,18,48,.28),0 0 0 1px var(--gold);
  transition:transform .2s var(--ease),box-shadow .2s var(--ease);
}
.vornach-handle-knob svg{width:22px;height:22px;stroke-width:1.6}
.vornach-frame:hover .vornach-handle-knob{transform:translate(-50%,-50%) scale(1.05)}
.vornach-handle:focus-visible .vornach-handle-knob{
  box-shadow:0 8px 22px rgba(42,18,48,.32),0 0 0 3px var(--gold);
}
.vornach-caption{
  margin-top:14px;text-align:center;
  font-family:'Inter',sans-serif;font-size:12px;color:var(--muted);
  letter-spacing:.01em;line-height:1.5;
}
@media(max-width:680px){
  /* Frame-Ratio matched Bilder (1400×699 = 2:1) — kein Crop, beide Bilder voll sichtbar */
  .vornach-frame{aspect-ratio:2 / 1}
  .vornach-img{object-fit:contain;background:var(--cream-3)}
  .vornach-label{font-size:9.5px;padding:5px 9px;top:10px}
  .vornach-label--before{left:10px}
  .vornach-label--after{right:10px}
  .vornach-handle-knob{width:42px;height:42px}
  .vornach-handle-knob svg{width:18px;height:18px}
}
@media(prefers-reduced-motion:reduce){
  .vornach-handle-knob{transition:none}
}
