/* ===== Lokale Web-Fonts (selbst gehostet, ersetzt Google Fonts) ===== */
/* Public Sans 400 latin-ext */
@font-face { font-family: 'Public Sans'; font-style: normal; font-weight: 400; font-display: swap; src: url(/assets/fonts/public-sans-400-latin-ext.woff2) format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
/* Public Sans 400 latin */
@font-face { font-family: 'Public Sans'; font-style: normal; font-weight: 400; font-display: swap; src: url(/assets/fonts/public-sans-400-latin.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
/* Public Sans 500 latin-ext */
@font-face { font-family: 'Public Sans'; font-style: normal; font-weight: 500; font-display: swap; src: url(/assets/fonts/public-sans-500-latin-ext.woff2) format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
/* Public Sans 500 latin */
@font-face { font-family: 'Public Sans'; font-style: normal; font-weight: 500; font-display: swap; src: url(/assets/fonts/public-sans-500-latin.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
/* Public Sans 600 latin-ext */
@font-face { font-family: 'Public Sans'; font-style: normal; font-weight: 600; font-display: swap; src: url(/assets/fonts/public-sans-600-latin-ext.woff2) format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
/* Public Sans 600 latin */
@font-face { font-family: 'Public Sans'; font-style: normal; font-weight: 600; font-display: swap; src: url(/assets/fonts/public-sans-600-latin.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
/* Public Sans 700 latin-ext */
@font-face { font-family: 'Public Sans'; font-style: normal; font-weight: 700; font-display: swap; src: url(/assets/fonts/public-sans-700-latin-ext.woff2) format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
/* Public Sans 700 latin */
@font-face { font-family: 'Public Sans'; font-style: normal; font-weight: 700; font-display: swap; src: url(/assets/fonts/public-sans-700-latin.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
/* Spectral 400 latin-ext */
@font-face { font-family: 'Spectral'; font-style: normal; font-weight: 400; font-display: swap; src: url(/assets/fonts/spectral-400-latin-ext.woff2) format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
/* Spectral 400 latin */
@font-face { font-family: 'Spectral'; font-style: normal; font-weight: 400; font-display: swap; src: url(/assets/fonts/spectral-400-latin.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
/* Spectral 500 latin-ext */
@font-face { font-family: 'Spectral'; font-style: normal; font-weight: 500; font-display: swap; src: url(/assets/fonts/spectral-500-latin-ext.woff2) format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
/* Spectral 500 latin */
@font-face { font-family: 'Spectral'; font-style: normal; font-weight: 500; font-display: swap; src: url(/assets/fonts/spectral-500-latin.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }
/* Spectral 600 latin-ext */
@font-face { font-family: 'Spectral'; font-style: normal; font-weight: 600; font-display: swap; src: url(/assets/fonts/spectral-600-latin-ext.woff2) format('woff2'); unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF; }
/* Spectral 600 latin */
@font-face { font-family: 'Spectral'; font-style: normal; font-weight: 600; font-display: swap; src: url(/assets/fonts/spectral-600-latin.woff2) format('woff2'); unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD; }

/* ============================================================
   HYALVOMED – Gemeinsames Stylesheet (Design A)
   Wird von allen Seiten (Dachseite, Standorte, Behandlungen) genutzt.
   ============================================================ */
:root{
  --ink:#1d2a2b;--muted:#5d6c6c;--teal:#0e5a61;--teal-700:#0a444a;--gold:#b08642;
  --sand:#f6f1e9;--sand-2:#efe7da;--line:#e6dccd;--paper:#ffffff;--maxw:1200px;--r:14px;
  --shadow:0 10px 34px -18px rgba(20,40,42,.45);
  --serif:"Spectral",Georgia,serif;--sans:"Public Sans",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.14;margin:0;letter-spacing:-.01em}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:600;font-size:15px;padding:13px 24px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:.18s;white-space:nowrap}
.btn-primary{background:var(--teal);color:#fff}
.btn-primary:hover{background:var(--teal-700)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{filter:brightness(.94)}
.eyebrow{font-family:var(--sans);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin:0 0 14px}

/* ---------- Utility bar ---------- */
.topbar{background:var(--ink);color:#dfe7e6;font-size:13.5px}
.topbar .wrap{display:flex;align-items:center;gap:22px;height:42px}
.topbar .ti{display:flex;align-items:center;gap:7px;white-space:nowrap}
.topbar svg{width:15px;height:15px;flex:none;opacity:.8}
.topbar .sep{flex:1}
.topbar a:hover{color:#fff}
.topbar .soc{display:flex;gap:12px}
.topbar .soc a{opacity:.8}.topbar .soc a:hover{opacity:1}
@media(max-width:880px){.topbar .hide-sm{display:none}}

/* ---------- Header ---------- */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.header .wrap{display:flex;align-items:center;gap:28px;height:74px}
.brand{display:flex;align-items:center;gap:12px;flex:none}
.brand .logo{height:44px;width:auto;display:block}
.brand .city{font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);background:var(--sand);border:1px solid var(--line);border-radius:999px;padding:3px 10px}
nav.main{display:flex;gap:26px;font-size:15px;font-weight:500;margin-left:auto}
nav.main a{padding:6px 0;position:relative;color:var(--muted)}
nav.main a:hover,nav.main a.active{color:var(--ink)}
nav.main a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--teal);transition:.2s}
nav.main a:hover::after,nav.main a.active::after{right:0}
.header .cta{flex:none}
.burger{display:none;margin-left:auto;background:none;border:1.5px solid var(--line);border-radius:10px;width:44px;height:44px;cursor:pointer}
.burger span{display:block;width:18px;height:2px;background:var(--ink);margin:3px auto}
.m-cta{display:none}
@media(max-width:1040px){
  nav.main{position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;align-items:stretch;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow);margin-left:0;padding:6px 0 14px;transform:translateY(-10px);opacity:0;pointer-events:none;transition:transform .2s,opacity .2s}
  .header.menu-open nav.main{transform:none;opacity:1;pointer-events:auto}
  nav.main a{padding:14px 28px;color:var(--ink);font-size:16px}
  nav.main a::after{display:none}
  nav.main .m-cta{display:inline-flex;justify-content:center;margin:12px 28px 2px}
  .header .cta{display:none}
  .burger{display:block}
  .header.menu-open .burger{border-color:var(--teal)}
}

/* ---------- Breadcrumb ---------- */
.crumb{background:var(--sand);border-bottom:1px solid var(--line)}
.crumb .wrap{display:flex;align-items:center;gap:9px;height:46px;font-size:13px;color:var(--muted);flex-wrap:wrap}
.crumb a:hover{color:var(--teal)}
.crumb b{color:var(--ink);font-weight:600;font-family:var(--sans)}
.crumb .ch{opacity:.5}

/* ---------- Generic section ---------- */
section{padding:52px 0}
.sec-head{max-width:700px;margin:0 auto 34px;text-align:center}
.sec-head h2{font-size:clamp(28px,3.4vw,42px)}
.sec-head p{color:var(--muted);font-size:17px;margin:16px 0 0}
.center-cta{text-align:center;margin-top:46px}

/* ---------- Home hero (city + brand) ---------- */
.hero{position:relative;min-height:600px;display:flex;align-items:center;overflow:hidden;border-bottom:1px solid var(--line);background:var(--sand)}
.hero > image-slot{position:absolute;inset:0;width:100%;height:100%;--r:0}
.hero-slider{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity 1.1s ease}
.hero-slide.on{opacity:1}
.hero-dots{position:absolute;left:28px;bottom:24px;z-index:3;display:flex;gap:9px;pointer-events:auto}
.hero-dots button{width:10px;height:10px;border-radius:50%;border:0;background:rgba(20,40,42,.28);cursor:pointer;padding:0;transition:.2s}
.hero-dots button.on{background:var(--teal);width:26px;border-radius:6px}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(90deg,rgba(246,241,233,0) 16%,rgba(246,241,233,.5) 40%,rgba(246,241,233,.92) 64%)}
.hero .wrap{position:relative;z-index:2;width:100%;display:flex;justify-content:flex-end;padding:64px 28px;pointer-events:none}
.hero-copy{width:min(540px,44vw);pointer-events:none}
.hero h1{font-size:clamp(36px,4.6vw,58px);color:var(--ink)}
.hero h1 b{color:var(--teal);font-weight:600}
.hero p.lead{font-size:19px;color:#4c574f;max-width:48ch;margin:22px 0 0}
.hero .acts{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px;pointer-events:auto}
.hero .trust{display:flex;gap:26px;margin-top:36px;flex-wrap:wrap}
.hero .trust div{display:flex;flex-direction:column}
.hero .trust b{font-family:var(--serif);font-size:26px;color:var(--teal);line-height:1}
.hero .trust span{font-size:13px;color:#5a655d;margin-top:4px}
@media(max-width:760px){
  .hero{min-height:520px}
  .hero .wrap{justify-content:center;padding:44px 24px}
  .hero-copy{width:min(560px,100%);text-align:left}
  .hero::after{background:linear-gradient(180deg,rgba(246,241,233,.5) 0%,rgba(246,241,233,.78) 45%,rgba(246,241,233,.92) 100%)}
}

/* ---------- Treatments grid ---------- */
.treatments{background:var(--paper)}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:#fff;transition:.2s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--sand-2)}
.card image-slot{width:100%;height:170px}
.card .body{padding:18px 18px 20px;display:flex;flex-direction:column;gap:6px;flex:1}
.card .kick{font-size:12px;color:var(--gold);font-weight:700;letter-spacing:.04em}
.card h3{font-size:21px}
.card p{font-size:14px;color:var(--muted);margin:2px 0 0;flex:1}
.card .more{font-size:13.5px;font-weight:600;color:var(--teal);margin-top:12px;display:inline-flex;align-items:center;gap:6px}
.card:hover .more{gap:10px}
@media(max-width:980px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid{grid-template-columns:1fr}}

/* ---------- Location ---------- */
.location{background:var(--sand)}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.loc-map{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);min-height:380px;position:relative}
.loc-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.15) contrast(1.02)}
.loc-list{list-style:none;padding:0;margin:26px 0 0;display:flex;flex-direction:column;gap:14px}
.loc-list li{display:flex;gap:12px;align-items:flex-start;font-size:15px}
.loc-list svg{width:20px;height:20px;color:var(--teal);flex:none;margin-top:2px}
.loc-list b{display:block}
.loc-list span{color:var(--muted);font-size:14px}
@media(max-width:860px){.loc-grid{grid-template-columns:1fr;gap:28px}}

/* ---------- App / PWA ---------- */
.app{background:var(--ink);color:#eef3f2}
.app .wrap{display:grid;grid-template-columns:1fr auto;gap:48px;align-items:center}
.app .eyebrow{color:var(--gold)}
.app h2{color:#fff;font-size:clamp(28px,3.4vw,42px)}
.app p{color:#b9c6c5;font-size:17px;max-width:48ch;margin:16px 0 26px}
.app .feats{display:flex;gap:28px;flex-wrap:wrap;margin:0 0 30px;padding:0;list-style:none}
.app .feats li{display:flex;align-items:center;gap:9px;font-size:14.5px;color:#dbe5e4}
.app .feats svg{width:18px;height:18px;color:var(--gold)}
.app .acts{display:flex;gap:14px;flex-wrap:wrap}
.phone{width:248px;height:506px;border-radius:34px;background:#0a1414;border:8px solid #060d0d;box-shadow:var(--shadow);padding:10px;position:relative;flex:none}
.phone .screen{height:100%;border-radius:24px;overflow:hidden;background:#fff}
.phone .appshot{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
@media(max-width:820px){.app .wrap{grid-template-columns:1fr}.phone{margin:0 auto}}

/* ---------- Standort chooser (Dachseite) ---------- */
.chooser{background:var(--paper)}
.ch-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.ch-card{position:relative;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;display:flex;flex-direction:column;transition:.2s}
.ch-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--sand-2)}
.ch-card .pic{position:relative;height:230px;overflow:hidden}
.ch-card .pic img{width:100%;height:100%;object-fit:cover}
.ch-card .pic .tag{position:absolute;left:18px;top:18px;background:rgba(255,255,255,.94);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal)}
.ch-card .body{padding:28px 30px 32px;display:flex;flex-direction:column;flex:1}
.ch-card h3{font-size:30px}
.ch-card .addr{color:var(--muted);font-size:15px;margin:10px 0 0;display:flex;gap:9px;align-items:flex-start}
.ch-card .addr svg{width:18px;height:18px;color:var(--teal);flex:none;margin-top:2px}
.ch-card .tags{display:flex;gap:8px;flex-wrap:wrap;margin:20px 0 26px}
.ch-card .tags i{font-style:normal;font-size:12.5px;background:var(--sand);color:var(--teal);border:1px solid var(--line);border-radius:999px;padding:5px 12px;font-weight:600}
.ch-card .acts{display:flex;gap:12px;flex-wrap:wrap;margin-top:auto}
@media(max-width:760px){.ch-grid{grid-template-columns:1fr}}

/* ---------- Treatment hero ---------- */
.thero{background:linear-gradient(180deg,var(--sand) 0%,var(--sand-2) 100%);border-bottom:1px solid var(--line);overflow:hidden}
.thero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;padding:44px 28px}
.thero-copy{max-width:560px}
.thero h1{font-size:clamp(34px,4.4vw,54px);color:var(--ink)}
.thero h1 b{color:var(--teal);font-weight:600}
.thero p.lead{font-size:18.5px;color:#4c574f;margin:20px 0 0}
.thero .acts{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.thero .meta{display:flex;gap:30px;margin-top:34px;flex-wrap:wrap}
.thero .meta div{display:flex;flex-direction:column}
.thero .meta b{font-family:var(--serif);font-size:22px;color:var(--teal);line-height:1}
.thero .meta span{font-size:13px;color:#5a655d;margin-top:5px}
.thero-fig{position:relative;justify-self:center}
.thero-fig .frame{position:relative;z-index:1;border-radius:20px;overflow:hidden;border:7px solid #fff;box-shadow:0 30px 60px -28px rgba(20,40,42,.45)}
.thero-fig .frame img{width:clamp(320px,38vw,440px);aspect-ratio:1/1;object-fit:cover;display:block}
.thero-fig .ring{position:absolute;right:-30px;bottom:-28px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(176,134,66,.22),rgba(176,134,66,0) 70%);z-index:0}
.thero-fig .chip{position:absolute;left:-18px;top:28px;z-index:2;background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 16px;box-shadow:var(--shadow);display:flex;align-items:center;gap:11px}
.thero-fig .chip svg{width:22px;height:22px;color:var(--teal);flex:none}
.thero-fig .chip b{font-family:var(--serif);font-size:15px;display:block;line-height:1.1}
.thero-fig .chip span{font-size:12px;color:var(--muted)}
@media(max-width:900px){.thero .wrap{grid-template-columns:1fr;gap:36px;padding:36px 28px}.thero-fig{order:-1}.thero-fig .frame img{width:min(380px,80vw)}.thero-fig .chip{left:6px}}

/* ---------- Local callout bar ---------- */
.locbar{background:var(--ink);color:#e7efed}
.locbar .wrap{display:flex;align-items:center;gap:16px;padding:18px 28px;font-size:15px}
.locbar svg{width:24px;height:24px;color:#e9d6ad;flex:none}
.locbar b{color:#fff;font-family:var(--serif);font-size:16px}
.locbar span{color:#bcd0ce}
.locbar a{margin-left:auto;color:#fff;font-weight:600;white-space:nowrap;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:1px}
.locbar a:hover{border-color:#fff}
@media(max-width:760px){.locbar .wrap{flex-wrap:wrap}.locbar a{margin-left:0}}

/* ---------- Prose + aside ---------- */
.lead-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:start}
.prose p{font-size:16.5px;color:#3c4848;margin:0 0 18px;max-width:62ch}
.prose p:last-child{margin-bottom:0}
.prose strong{color:var(--ink)}
.aside{background:var(--sand);border:1px solid var(--line);border-radius:var(--r);padding:28px 26px}
.aside h3{font-size:20px;margin-bottom:8px}
.aside p{font-size:14.5px;color:var(--muted);margin:0}
.aside .li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;margin-top:14px}
.aside .li svg{width:19px;height:19px;color:var(--teal);flex:none;margin-top:2px}
.aside .li b{font-family:var(--sans);display:block;margin-bottom:1px}
.aside .li span{color:var(--muted)}
@media(max-width:820px){.lead-grid{grid-template-columns:1fr;gap:30px}}

/* ---------- Spectrum ---------- */
.spectrum{background:var(--sand)}
.spec-box{max-width:860px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:38px 40px;box-shadow:var(--shadow)}
.spec-track{height:14px;border-radius:999px;background:linear-gradient(90deg,#cfe0de 0%,var(--teal) 100%);position:relative;margin:30px 0 14px}
.spec-track .dot{position:absolute;top:50%;width:22px;height:22px;border-radius:50%;background:#fff;border:3px solid var(--gold);transform:translate(-50%,-50%);box-shadow:0 4px 10px rgba(0,0,0,.15)}
.spec-ends{display:flex;justify-content:space-between;gap:20px}
.spec-ends div{max-width:42%}
.spec-ends h4{font-size:18px}
.spec-ends.l h4{color:var(--ink)}
.spec-ends p{font-size:13.5px;color:var(--muted);margin:4px 0 0}
.spec-ends .r{text-align:right}
.spec-note{text-align:center;font-size:15px;color:#3c4848;margin:24px 0 0}
.spec-note b{color:var(--teal)}

/* ---------- Zones ---------- */
.zones .z-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:54px;align-items:center}
.z-fig{position:relative;justify-self:center;background:radial-gradient(circle at 50% 42%,var(--sand) 0%,#fff 72%);border:1px solid var(--line);border-radius:50%;padding:22px;box-shadow:var(--shadow)}
.z-fig img{width:300px;height:300px;border-radius:50%;object-fit:cover}
.z-cols{display:grid;grid-template-columns:1fr 1fr;gap:22px 32px}
.z-col h4{font-family:var(--sans);font-size:12.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin:0 0 14px;display:flex;align-items:center;gap:9px}
.z-col h4::before{content:"";width:18px;height:1.5px;background:var(--gold)}
.z-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px}
.z-col li{display:flex;gap:10px;align-items:center;font-size:15px}
.z-col li svg{width:16px;height:16px;color:var(--teal);flex:none}
@media(max-width:860px){.zones .z-grid{grid-template-columns:1fr;gap:34px}.z-fig img{width:240px;height:240px}}
@media(max-width:480px){.z-cols{grid-template-columns:1fr}}

/* ---------- Methods ---------- */
.methods{background:var(--sand)}
.m-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.m-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 30px;box-shadow:var(--shadow)}
.m-card .ic{width:48px;height:48px;border-radius:12px;background:var(--sand-2);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.m-card .ic svg{width:24px;height:24px;color:var(--teal)}
.m-card h3{font-size:23px}
.m-card .tag{font-size:12px;font-weight:700;color:var(--gold);letter-spacing:.04em;text-transform:uppercase;margin:14px 0 0}
.m-card p{font-size:15px;color:var(--muted);margin:7px 0 0}
@media(max-width:760px){.m-grid{grid-template-columns:1fr}}

/* ---------- Process ---------- */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.proc{position:relative;padding:28px 24px;border:1px solid var(--line);border-radius:var(--r);background:#fff}
.proc .n{font-family:var(--serif);font-size:34px;color:var(--sand-2);font-weight:600;line-height:1}
.proc h3{font-size:18px;margin:8px 0 8px}
.proc p{font-size:14px;color:var(--muted);margin:0}
@media(max-width:860px){.proc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.proc-grid{grid-template-columns:1fr}}

/* ---------- Why ---------- */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.why-card{border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;background:#fff}
.why-card .n{font-family:var(--serif);font-size:15px;color:var(--gold);font-weight:600}
.why-card h3{font-size:22px;margin:10px 0 10px}
.why-card p{font-size:15px;color:var(--muted);margin:0}
@media(max-width:820px){.why-grid{grid-template-columns:1fr}}

/* ---------- Care ---------- */
.care{background:var(--ink);color:#dfe9e8}
.care .sec-head h2{color:#fff}
.care .sec-head p{color:#a9bdbb}
.care-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.care-card{background:#16292a;border:1px solid #294040;border-radius:var(--r);padding:30px 30px}
.care-card h3{color:#fff;font-size:21px;display:flex;align-items:center;gap:12px}
.care-card h3 svg{width:22px;height:22px;color:#e9d6ad}
.care-card ul{list-style:none;margin:18px 0 0;padding:0;display:flex;flex-direction:column;gap:13px}
.care-card li{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:#c9dad8}
.care-card li svg{width:18px;height:18px;color:#7fb0ac;flex:none;margin-top:2px}
.care-card li b{color:#fff;font-weight:600}
.care-note{margin-top:24px;display:flex;gap:14px;align-items:flex-start;background:#16292a;border:1px solid #294040;border-left:3px solid var(--gold);border-radius:10px;padding:20px 24px;font-size:14.5px;color:#bccfce}
.care-note svg{width:22px;height:22px;color:#e9d6ad;flex:none;margin-top:1px}
.care-note b{color:#fff}
@media(max-width:760px){.care-grid{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:840px;margin:0 auto}
details.faq{border:1px solid var(--line);border-radius:12px;background:#fff;margin-bottom:12px;overflow:hidden}
details.faq summary{list-style:none;cursor:pointer;padding:20px 24px;font-family:var(--serif);font-size:18px;font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:16px}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary .pl{width:24px;height:24px;flex:none;position:relative}
details.faq summary .pl::before,details.faq summary .pl::after{content:"";position:absolute;background:var(--teal);border-radius:2px;transition:.2s}
details.faq summary .pl::before{top:11px;left:4px;width:16px;height:2px}
details.faq summary .pl::after{top:4px;left:11px;width:2px;height:16px}
details.faq[open] summary .pl::after{transform:rotate(90deg);opacity:0}
details.faq .ans{padding:0 24px 22px;font-size:15.5px;color:#41504f;max-width:64ch}

/* ---------- CTA section (scoped so it never hits the header .cta button) ---------- */
section.cta{background:var(--sand);text-align:center}
section.cta .wrap{max-width:820px}
section.cta h2{font-size:clamp(28px,3.6vw,42px)}
section.cta p{color:var(--muted);font-size:17px;margin:16px auto 28px;max-width:54ch}
section.cta .acts{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}

/* ---------- Footer ---------- */
footer{background:#0b1516;color:#aebcbb;font-size:14px;padding:64px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px}
footer h4{font-family:var(--sans);font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin:0 0 16px}
footer a:hover{color:#fff}
footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:9px}
.foot-brand .name{font-family:var(--serif);font-size:22px;color:#fff}
.foot-brand p{margin:14px 0 0;max-width:30ch;line-height:1.7}
.pay{display:flex;gap:8px;margin-top:16px}
.pay span{font-size:11px;font-weight:700;border:1px solid #2a3a3a;border-radius:6px;padding:5px 9px;color:#cdd9d8}
.foot-bottom{border-top:1px solid #1c2a2a;margin-top:44px;padding-top:22px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:12.5px;color:#7f8f8e}
.foot-bottom a{text-decoration:underline;text-underline-offset:2px}
@media(max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ---------- Reviews ---------- */
.reviews{background:var(--paper)}
.rev-top{display:grid;grid-template-columns:auto 1fr;gap:36px;align-items:center;max-width:760px;margin:0 auto 46px;text-align:left}
.rev-score{text-align:center;background:var(--sand);border:1px solid var(--line);border-radius:var(--r);padding:26px 30px;flex:none}
.rev-score .num{font-family:var(--serif);font-size:52px;line-height:1;color:var(--teal)}
.rev-score .stars{display:flex;gap:3px;justify-content:center;margin:8px 0 6px}
.rev-score .stars svg{width:18px;height:18px;color:var(--gold)}
.rev-score .cnt{font-size:13px;color:var(--muted)}
.rev-intro h2{font-size:clamp(26px,3vw,36px)}
.rev-intro p{color:var(--muted);font-size:16px;margin:12px 0 18px}
.rev-intro .glink{display:inline-flex;align-items:center;gap:9px;font-weight:600;color:var(--teal);font-size:15px}
.rev-intro .glink svg{width:18px;height:18px}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.rev-card{border:1px solid var(--line);border-radius:var(--r);background:#fff;padding:26px 26px;display:flex;flex-direction:column;gap:14px}
.rev-card .stars{display:flex;gap:3px}
.rev-card .stars svg{width:16px;height:16px;color:var(--gold)}
.rev-card p{font-size:15.5px;color:#3c4848;margin:0;flex:1;line-height:1.6}
.rev-card .who{display:flex;align-items:center;gap:11px;font-size:14px}
.rev-card .who .av{width:36px;height:36px;border-radius:50%;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex:none}
.rev-card .who b{font-weight:600}
.rev-card .who span{color:var(--muted);font-size:12.5px;display:block}
@media(max-width:860px){.rev-top{grid-template-columns:1fr;text-align:center;gap:22px}.rev-grid{grid-template-columns:1fr}}

/* ---------- Beauty Club ---------- */
.club{background:var(--sand)}
.club .sec-head .eyebrow{color:var(--gold)}

/* ---------- Ratgeber: FAQ-Kategorie-Label ---------- */
.faq-cat{font-family:var(--sans);font-size:12.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin:38px 0 16px;display:flex;align-items:center;gap:11px}
.faq-cat:first-child{margin-top:0}
.faq-cat::before{content:"";width:22px;height:1.5px;background:var(--gold);flex:none}
.club-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;max-width:900px;margin:0 auto;align-items:stretch}
.plan{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:36px 34px;display:flex;flex-direction:column;box-shadow:var(--shadow)}
.plan.feat{border:1.5px solid var(--gold);box-shadow:0 26px 60px -26px rgba(176,134,66,.5)}
.plan .ribbon{position:absolute;top:-14px;left:34px;background:var(--gold);color:#fff;font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:6px 15px;border-radius:999px;box-shadow:0 8px 18px -8px rgba(176,134,66,.8)}
.plan .tier{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.plan h3{font-size:25px;margin:8px 0 0;letter-spacing:-.01em}
.plan h3 b{color:var(--teal);font-weight:600}
.plan .price{display:flex;align-items:baseline;gap:7px;margin:18px 0 2px}
.plan .price b{font-family:var(--serif);font-size:46px;color:var(--teal);line-height:1;font-weight:600}
.plan .price span{font-size:15px;color:var(--muted)}
.plan .psub{font-size:13.5px;color:var(--muted);margin:0 0 4px}
.plan ul{list-style:none;margin:24px 0 28px;padding:22px 0 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:13px;flex:1}
.plan li{display:flex;gap:11px;align-items:flex-start;font-size:15px;color:#33403f}
.plan li svg{width:19px;height:19px;flex:none;margin-top:2px}
.plan li svg{color:var(--gold)}
.plan li b{color:var(--ink);font-weight:600}
.plan .btn{justify-content:center;width:100%}
.club-note{max-width:900px;margin:22px auto 0;text-align:center;font-size:13px;color:var(--muted)}
@media(max-width:760px){.club-grid{grid-template-columns:1fr;gap:34px}}

/* ---------- Beauty Club: Vergleichstabelle ---------- */
.compare{background:var(--paper)}
.ctable{max-width:840px;margin:0 auto;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);background:#fff}
.ctable .crow{display:grid;grid-template-columns:1.7fr 1fr 1.1fr}
.ctable .crow + .crow{border-top:1px solid var(--line)}
.ctable .c{padding:16px 18px;font-size:15px;display:flex;align-items:center;justify-content:center;text-align:center;gap:8px}
.ctable .c.lbl{justify-content:flex-start;text-align:left;color:#33403f;font-weight:500}
.ctable .c.hi{background:linear-gradient(180deg,rgba(176,134,66,.09),rgba(176,134,66,.05))}
.ctable .chead .c{padding:22px 18px;font-family:var(--serif);font-size:20px;color:var(--teal)}
.ctable .chead{background:var(--sand);border-bottom:1px solid var(--line)}
.ctable .chead .c.hi{background:linear-gradient(180deg,var(--gold),#9c7536);color:#fff;position:relative}
.ctable .chead .c.lbl{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.ctable .chead .tag{display:block;font-family:var(--sans);font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;opacity:.9;margin-top:3px}
.ctable .val{font-family:var(--serif);font-weight:600;color:var(--ink)}
.ctable .c.hi .val{color:var(--teal)}
.ctable .yes{width:20px;height:20px;color:var(--teal)}
.ctable .c.hi .yes{color:var(--gold)}
.ctable .no{color:#c2c8c4;font-size:18px;line-height:1}
.ctable .crow.foot .c{padding:24px 18px}
@media(max-width:620px){
  .ctable .c{padding:13px 12px;font-size:13.5px}
  .ctable .chead .c{font-size:17px;padding:16px 12px}
}

/* ---------- Kontakt-Sektion (Dachseite) ---------- */
.contact{background:var(--paper)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;max-width:960px;margin:0 auto}
.contact-card{border:1px solid var(--line);border-radius:18px;background:#fff;padding:32px 34px;box-shadow:var(--shadow);display:flex;flex-direction:column}
.contact-card .chead{display:flex;align-items:center;gap:13px}
.contact-card .tag{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);background:var(--sand);border:1px solid var(--line);border-radius:999px;padding:5px 13px;flex:none}
.contact-card h3{font-size:24px}
.contact-card .addr{display:flex;gap:9px;align-items:flex-start;color:var(--muted);font-size:14.5px;margin:14px 0 0}
.contact-card .addr svg{width:18px;height:18px;color:var(--teal);flex:none;margin-top:2px}
.clist{list-style:none;margin:20px 0 24px;padding:20px 0 0;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:4px;flex:1}
.clist a{display:flex;align-items:center;gap:14px;padding:11px 12px;border-radius:12px;transition:.16s}
.clist a:hover{background:var(--sand)}
.clist .ic{width:42px;height:42px;border-radius:50%;background:var(--sand);display:flex;align-items:center;justify-content:center;flex:none}
.clist .ic svg{width:20px;height:20px;color:var(--teal)}
.clist .ic.wa{background:#25d366}
.clist .ic.wa svg{color:#fff}
.clist .t span{display:block;font-size:12px;color:var(--muted);letter-spacing:.02em}
.clist .t b{font-family:var(--sans);font-size:16px;color:var(--ink);font-weight:600}
.contact-card .btn{justify-content:center;width:100%}
@media(max-width:760px){.contact-grid{grid-template-columns:minmax(0,1fr)}}
@media(max-width:440px){.contact-card .btn{white-space:normal;text-align:center}}

/* ---------- WhatsApp-Chat-Button ---------- */
.wa-fab{position:fixed;right:18px;bottom:18px;z-index:95;width:58px;height:58px;border-radius:50%;background:#25d366;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 26px -8px rgba(18,140,76,.65);transition:transform .18s ease,box-shadow .18s ease}
.wa-fab:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 14px 32px -8px rgba(18,140,76,.8)}
.wa-fab img{width:30px;height:30px;display:block}
@media(max-width:560px){.wa-fab{width:54px;height:54px;right:14px;bottom:14px}}
@media print{.wa-fab{display:none}}


/* ============================================================
   Wiederhergestellte behandlungsspezifische Styles (aus A-Seiten)
   ============================================================ */
/* mechanism */
.mech{background:var(--sand)}
/* areas */
.area-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.area-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.area-card .media{height:200px;overflow:hidden;position:relative}
.area-card .media img{width:100%;height:100%;object-fit:cover}
.area-card .media.icon{background:radial-gradient(circle at 50% 40%,var(--sand) 0%,var(--sand-2) 100%);display:flex;align-items:center;justify-content:center}
.area-card .media.icon svg{width:56px;height:56px;color:var(--teal);stroke-width:1.5}
.area-card .media .label{position:absolute;left:16px;bottom:14px;background:rgba(13,21,22,.62);backdrop-filter:blur(4px);color:#fff;font-family:var(--sans);font-weight:700;font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:6px 12px;border-radius:999px}
.area-card .bd{padding:26px 28px}
.area-card h3{font-size:22px}
.area-card ul{list-style:none;margin:14px 0 0;padding:0;display:flex;flex-direction:column;gap:9px}
.area-card li{display:flex;gap:10px;align-items:flex-start;font-size:14.5px;color:#41504f}
.area-card li svg{width:17px;height:17px;color:var(--teal);flex:none;margin-top:3px}
@media(max-width:820px){.area-grid{grid-template-columns:1fr}}
/* know band */
.know{background:var(--ink);color:#dfe9e8}
.know .sec-head h2{color:#fff}
.know .sec-head p{color:#a9bdbb}
.know-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.know-card{background:#16292a;border:1px solid #294040;border-radius:var(--r);padding:30px 28px}
.know-card .ic{width:46px;height:46px;border-radius:12px;background:rgba(233,214,173,.12);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.know-card .ic svg{width:23px;height:23px;color:#e9d6ad}
.know-card h3{color:#fff;font-size:20px}
.know-card p{font-size:14.5px;color:#bccfce;margin:8px 0 0}
@media(max-width:760px){.know-grid{grid-template-columns:1fr}}
/* mechanism process */
.mech{background:var(--sand)}
.m-note{margin-top:26px;background:var(--teal);color:#eaf3f2;border-radius:var(--r);padding:24px 28px;display:flex;gap:16px;align-items:center}
.m-note svg{width:30px;height:30px;flex:none;color:#e9d6ad}
.m-note b{font-family:var(--serif);font-size:19px;color:#fff}
.m-note span{display:block;font-size:14.5px;color:#bcd5d3;margin-top:3px}
/* ---------- Also treat ---------- */
.also{background:var(--sand)}
.also-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:8px}
.also-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px 20px;text-align:center}
.also-card .ic{width:46px;height:46px;border-radius:50%;background:var(--sand);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.also-card .ic svg{width:23px;height:23px;color:var(--teal)}
.also-card b{font-family:var(--serif);font-size:17px;display:block}
.also-card span{font-size:13px;color:var(--muted);display:block;margin-top:5px;line-height:1.5}
@media(max-width:900px){.also-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:540px){.also-grid{grid-template-columns:repeat(2,1fr)}}
.also-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:8px}
@media(max-width:900px){.also-grid{grid-template-columns:repeat(2,1fr)}}
/* mixes */
.mix{background:var(--sand)}
.mix-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.mix-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 28px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.mix-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--drop,#0e5a61)}
.mix-card .ic{width:48px;height:48px;border-radius:50%;background:var(--sand);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.mix-card .ic svg{width:24px;height:24px;color:var(--drop,#0e5a61)}
.mix-card h3{font-size:22px}
.mix-card .sub{font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--gold);margin:6px 0 0}
.mix-card p{font-size:14.5px;color:var(--muted);margin:10px 0 0}
.mix-card .tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:16px}
.mix-card .tags span{font-size:11.5px;font-weight:600;color:#3c4848;background:var(--sand);border:1px solid var(--line);border-radius:999px;padding:4px 10px}
@media(max-width:880px){.mix-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.mix-grid{grid-template-columns:1fr}}
/* kur band */
.kur{background:var(--ink);color:#dfe9e8}
.kur .wrap{display:grid;grid-template-columns:1fr auto;gap:36px;align-items:center}
.kur .eyebrow{color:#e9d6ad}
.kur h2{color:#fff;font-size:clamp(26px,3vw,36px)}
.kur p{color:#bccfce;font-size:16px;margin:14px 0 0;max-width:60ch}
.kur .stats{display:flex;gap:30px;margin-top:24px;flex-wrap:wrap}
.kur .stats b{font-family:var(--serif);font-size:30px;color:#e9d6ad;line-height:1;display:block}
.kur .stats span{font-size:13px;color:#a9bdbb;margin-top:6px;display:block}
.kur .act{flex:none}
@media(max-width:820px){.kur .wrap{grid-template-columns:1fr;gap:24px}}
/* why */
.why{background:var(--sand)}

/* ============================================================
   Preisseite (preise.html)
   ============================================================ */
.phero{background:linear-gradient(180deg,var(--sand) 0%,var(--sand-2) 100%);border-bottom:1px solid var(--line)}
.phero .wrap{padding:44px 28px 38px;display:grid;grid-template-columns:1.3fr .7fr;gap:48px;align-items:end}
.phero h1{font-size:clamp(36px,4.6vw,56px)}
.phero h1 b{color:var(--teal);font-weight:600}
.phero p.lead{font-size:18px;color:#4c574f;margin:18px 0 0;max-width:52ch}
.phero .trust{display:flex;flex-direction:column;gap:12px}
.phero .trust .ti{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:#3c4848}
.phero .trust .ti svg{width:20px;height:20px;color:var(--teal);flex:none;margin-top:2px}
.phero .trust .ti b{font-weight:600}
@media(max-width:860px){.phero .wrap{grid-template-columns:1fr;gap:28px;padding:40px 28px}}
.catnav{position:sticky;top:74px;z-index:40;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.catnav .wrap{display:flex;gap:10px;padding:14px 28px;overflow-x:auto;scrollbar-width:none}
.catnav .wrap::-webkit-scrollbar{display:none}
.catnav a{font-size:13.5px;font-weight:600;color:var(--muted);padding:8px 15px;border-radius:999px;border:1px solid var(--line);white-space:nowrap;transition:.16s}
.catnav a:hover{color:var(--teal);border-color:var(--teal)}
@media(max-width:1040px){.catnav{top:0}}
.pwrap{padding:64px 0 30px}
.pcat{scroll-margin-top:150px;margin-bottom:58px}
.pcat-head{display:flex;gap:16px;align-items:center;margin-bottom:26px;padding-bottom:20px;border-bottom:2px solid var(--sand-2)}
.pcat-head .ic{width:54px;height:54px;border-radius:14px;background:var(--sand);display:flex;align-items:center;justify-content:center;flex:none}
.pcat-head .ic svg{width:27px;height:27px;color:var(--teal)}
.pcat-head h2{font-size:clamp(24px,2.6vw,32px)}
.pcat-head p{font-size:14.5px;color:var(--muted);margin:3px 0 0}
.pgroups{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(330px,100%),1fr));gap:20px;align-items:start}
.pgroup{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;box-shadow:var(--shadow)}
.pgroup h4{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin:0 0 8px;display:flex;align-items:center;gap:9px}
.pgroup h4::before{content:"";width:16px;height:1.5px;background:var(--gold)}
.prow{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--line)}
.prow:last-child{border-bottom:none}
.prow .nm{font-size:15px;color:var(--ink);display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.prow .pr{font-family:var(--serif);font-weight:600;font-size:17px;color:var(--teal);white-space:nowrap}
.prow .pr .ab{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--muted);margin-right:2px}
.pop{font-family:var(--sans);font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:#fff;background:var(--gold);border-radius:999px;padding:2px 8px}
.pinfo{background:var(--sand)}
.pinfo .wrap{padding:64px 28px}
.pinfo .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pinfo .card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 26px}
.pinfo .card .ic{width:44px;height:44px;border-radius:50%;background:var(--sand);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.pinfo .card .ic svg{width:22px;height:22px;color:var(--teal)}
.pinfo .card h3{font-size:20px}
.pinfo .card p{font-size:14.5px;color:var(--muted);margin:8px 0 0}
.pinfo .card a{color:var(--teal);text-decoration:underline;text-underline-offset:2px}
@media(max-width:820px){.pinfo .grid{grid-template-columns:1fr}}

/* ============================================================
   Ratgeber-Hub (ratgeber/)
   ============================================================ */
.rhero{background:linear-gradient(180deg,var(--sand) 0%,var(--sand-2) 100%);border-bottom:1px solid var(--line)}
.rhero .wrap{padding:40px 28px 32px;max-width:820px}
.rhero h1{font-size:clamp(34px,4.4vw,52px)}
.rhero h1 b{color:var(--teal);font-weight:600}
.rhero p.lead{font-size:18px;color:#4c574f;margin:18px 0 0}
.art-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.art-card{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:var(--r);background:#fff;overflow:hidden;transition:.2s}
.art-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--sand-2)}
.art-card .top{background:var(--sand);padding:22px 24px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line)}
.art-card .top svg{width:26px;height:26px;color:var(--teal);flex:none}
.art-card .top .tag{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}
.art-card .bd{padding:22px 24px;display:flex;flex-direction:column;gap:10px;flex:1}
.art-card h3{font-size:21px}
.art-card p{font-size:14.5px;color:var(--muted);margin:0;flex:1}
.art-card .more{font-size:13.5px;font-weight:600;color:var(--teal);margin-top:6px}
@media(max-width:860px){.art-grid{grid-template-columns:1fr}}

/* Artikel-Layout */
.article{max-width:760px;margin:0 auto}
.article .lead-p{font-size:19px;color:#3c4848;margin:0 0 26px;line-height:1.6}
.article h2{font-size:clamp(24px,2.6vw,30px);margin:40px 0 14px}
.article h3{font-size:20px;margin:28px 0 10px}
.article p{font-size:16.5px;color:#3c4848;margin:0 0 16px}
.article strong{color:var(--ink)}
.article ul{margin:0 0 18px;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.article ul li{display:flex;gap:11px;font-size:16px;color:#3c4848}
.article ul li svg{width:20px;height:20px;color:var(--teal);flex:none;margin-top:3px}
.article .callout{background:var(--sand);border:1px solid var(--line);border-left:3px solid var(--gold);border-radius:10px;padding:20px 24px;margin:26px 0;font-size:15.5px;color:#3c4848}
.article .callout b{color:var(--ink)}
.toc{background:var(--sand);border:1px solid var(--line);border-radius:var(--r);padding:22px 26px;margin:0 0 34px}
.toc h4{font-family:var(--sans);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin:0 0 10px}
.toc ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.toc a{font-size:15px;color:var(--teal)}
.toc a:hover{text-decoration:underline}
.article .qa{border-top:1px solid var(--line);padding-top:22px;margin-top:34px}

/* Teaser-Band auf Behandlungsseiten */
.ratteaser{background:var(--sand)}
.ratteaser .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ratteaser .rt{display:flex;flex-direction:column;gap:8px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;transition:.2s}
.ratteaser .rt:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--sand-2)}
.ratteaser .rt .k{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}
.ratteaser .rt h3{font-size:18px}
.ratteaser .rt p{font-size:14px;color:var(--muted);margin:0;flex:1}
.ratteaser .rt .more{font-size:13.5px;font-weight:600;color:var(--teal);margin-top:8px}
@media(max-width:860px){.ratteaser .wrap{grid-template-columns:1fr}}

/* Autorenzeile + Antwort-zuerst (Ratgeber) */
.byline{display:flex;align-items:center;gap:11px;margin:24px 0 0;font-size:14px;color:var(--muted)}
.byline .av{width:40px;height:40px;border-radius:50%;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex:none;font-family:var(--sans)}
.byline b{color:var(--ink);font-weight:600}
.byline svg{width:15px;height:15px;color:var(--teal);vertical-align:-2px;margin-right:3px}
.tldr{background:#eef4f3;border:1px solid #cfe0de;border-radius:12px;padding:18px 22px;margin:0 0 28px;font-size:16.5px;color:#26403f;line-height:1.6}
.tldr b{color:var(--teal);display:block;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px;font-family:var(--sans);font-weight:700}

/* Statische Kachelbilder + Platzhalter */
.card>img{width:100%;height:170px;object-fit:cover;display:block}
.card .noimg{height:170px;background:var(--sand-2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px}
.card .noimg svg{width:40px;height:40px;color:var(--teal);opacity:.55}
.card .noimg span{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);opacity:.7}

/* Hero-Überblendung rein per CSS (Slide 1 liegt fest, Slide 2 blendet darüber) */
.hero-slider .hero-slide{opacity:1}
@media (prefers-reduced-motion: no-preference){
  .hero-slider .hero-slide:nth-child(2){animation:heroFade 13s infinite}
}
@keyframes heroFade{0%,6%{opacity:0}46%,54%{opacity:1}94%,100%{opacity:0}}
/* ---------- Fix Header-Overflow auf schmalen Handys (S25+ ~384-412px) ---------- */
@media(max-width:440px){
  .header .wrap{gap:12px;padding-left:16px;padding-right:16px}
  .brand{gap:8px}
  .brand .logo{height:36px}
  .brand .city{font-size:10px;padding:3px 8px;letter-spacing:.10em}
}
@media(max-width:360px){
  .brand .logo{height:32px}
  .header .wrap{padding-left:14px;padding-right:14px}
}

/* ---------- Weitere Mobile-Overflow-Fixes (minmax verhindert 1fr-Blowout) ---------- */
.club-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
@media(max-width:760px){.club-grid{grid-template-columns:minmax(0,1fr)}}
@media(max-width:440px){.plan .btn,.contact-card .btn{white-space:normal;text-align:center}}
.also-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
@media(max-width:900px){.also-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
.also-card b{overflow-wrap:anywhere}

/* Lange CTA-Buttons auf schmalen Screens umbrechen statt Overflow */
@media(max-width:440px){.btn{white-space:normal;text-align:center}}

/* PayPal-Subscription-Button-Container (Beauty Club) */
.pp-btn{margin-top:6px;min-height:46px}

