/* ============================================================
   Startseite V4.1 — eigenes, sauberes Stylesheet (SSOT-Keimzelle)
   Keine Abhängigkeit vom Altsystem. Kein emergency-fix.css. Keine !important.
   CI: Ink #1A1A1A / Gold #C9A84C / Paper #F5F3EF · Playfair Display + Inter
   ============================================================ */

:root{
  --ink:#1A1A1A;
  --ink-soft:#262522;
  --gold:#C9A84C;
  --gold-deep:#B0913B;
  --paper:#F5F3EF;
  --paper-deep:#EDEAE3;
  --muted:#6E6A60;
  --line:rgba(26,26,26,.14);
  --line-light:rgba(245,243,239,.18);
  --display:'Playfair Display', Georgia, serif;
  --body:'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms;transition-duration:.01ms}
}
body{
  font-family:var(--body);
  background:var(--paper);
  color:var(--ink);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px}

.skip-link{
  position:absolute;left:-9999px;top:0;z-index:200;
  background:var(--ink);color:var(--paper);padding:12px 18px;font-weight:600;
}
.skip-link:focus{left:12px;top:12px}

/* ---------- shared ---------- */
.eyebrow{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-deep);font-weight:600;margin-bottom:14px;
}
.eyebrow::before{content:"";display:inline-block;width:28px;height:1px;background:var(--gold);vertical-align:middle;margin-right:12px}
h2{font-family:var(--display);font-weight:500;font-size:clamp(28px,4vw,42px);line-height:1.15;letter-spacing:-.01em}
.section{padding:96px 0}
.section + .section{border-top:1px solid var(--line)}
.lede{color:var(--muted);max-width:560px;margin-top:16px}

.btn{
  display:inline-block;font-family:var(--body);font-weight:600;font-size:15px;
  padding:15px 32px;text-decoration:none;letter-spacing:.01em;
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
  cursor:pointer;border:none;
}
.btn:focus-visible{outline:3px solid var(--gold);outline-offset:3px}
.btn-gold{background:var(--gold);color:var(--ink)}
.btn-gold:hover{background:var(--gold-deep);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--ink);box-shadow:inset 0 0 0 1.5px var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--paper)}
.btn-outline-light{background:transparent;color:var(--paper);box-shadow:inset 0 0 0 1.5px rgba(245,243,239,.6)}
.btn-outline-light:hover{background:var(--paper);color:var(--ink)}
/* Lead-CTA: größerer, dominanter Gold-Button (Hero-Termin). Ein klarer Fokus. */
.btn-lead{font-size:17px;font-weight:700;padding:17px 38px;box-shadow:0 6px 20px rgba(201,168,76,.32)}
.btn-lead:hover{box-shadow:0 8px 26px rgba(201,168,76,.42)}

/* Reveal ist reine Progressive Enhancement: ohne JS (.js fehlt) ist alles sichtbar. */
.reveal{opacity:1}
.js .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s ease,transform .7s ease}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){ .js .reveal{opacity:1;transform:none;transition:none} }

/* PLATZHALTER-Marker (nur Staging — darf nie versehentlich live gehen) */
.ph{
  display:inline-block;font-family:var(--body);font-size:10px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  background:#B00020;color:#fff;padding:2px 7px;border-radius:3px;
  vertical-align:middle;margin-left:8px;
}
[data-todo]{position:relative}
/* Review-Badge fuer best-guess Bildzuordnungen (dezent, gold — nicht das rote .ph) */
.rev{
  display:inline-block;font-family:var(--body);font-size:9px;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  background:rgba(201,168,76,.92);color:#1A1A1A;padding:1px 6px;border-radius:3px;
  vertical-align:middle;margin-left:7px;
}

/* ---------- header ---------- */
header{
  position:sticky;top:0;z-index:50;
  background:var(--ink);
  border-bottom:1px solid rgba(201,168,76,.28);   /* dezent gold statt heller Linie */
  transition:background .25s ease, backdrop-filter .25s ease, border-color .25s ease;
}
header.scrolled{
  background:rgba(26,26,26,.82);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
}
.nav{display:flex;align-items:center;justify-content:space-between;min-height:68px;padding:7px 0}
.logo{display:flex;align-items:center;text-decoration:none}
.logo img{height:88px;width:auto;display:block}            /* Logo bestimmt die Proportion */
.nav-links{display:flex;gap:28px;align-items:center}
.nav-links a{font-size:14px;font-weight:500;color:var(--paper);text-decoration:none;opacity:.70;transition:opacity .15s}
.nav-links a:hover{opacity:1}
.nav-phone{font-size:14px;font-weight:600;color:var(--paper);text-decoration:none;opacity:1;border-bottom:1px solid var(--gold)}
@media(max-width:860px){.nav-links a:not(.nav-phone){display:none}}
@media(max-width:860px){.logo img{height:64px}}           /* Mobile: Logo skaliert, Telefon bleibt */

/* ---------- hero ---------- */
.hero{padding:110px 0 90px;position:relative;overflow:hidden}
.hero::after{
  content:"";position:absolute;right:-180px;top:-120px;width:560px;height:560px;
  border:1px solid rgba(201,168,76,.35);border-radius:50%;pointer-events:none;
}
.hero::before{
  content:"";position:absolute;right:-60px;top:30px;width:560px;height:560px;
  border:1px solid rgba(201,168,76,.18);border-radius:50%;pointer-events:none;
}
.hero .wrap{position:relative;z-index:2}
.hero h1{
  font-family:var(--display);font-weight:500;
  font-size:clamp(40px,6.4vw,72px);line-height:1.06;letter-spacing:-.015em;
  max-width:13ch;
}
.hero h1 em{font-style:italic;color:var(--gold-deep)}
.hero .sub{font-size:18px;color:var(--muted);margin:24px 0 40px;max-width:46ch}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero-doors{
  margin-top:64px;padding-top:28px;border-top:1px solid var(--line);
  display:flex;gap:0;flex-wrap:wrap;
}
.door{flex:1;min-width:200px;padding:6px 24px 6px 0;text-decoration:none;color:var(--ink)}
.door + .door{border-left:1px solid var(--line);padding-left:24px}
.door .d-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.door .d-title{font-family:var(--display);font-size:19px;font-style:italic;margin-top:4px;transition:color .15s}
.door:hover .d-title{color:var(--gold-deep)}
@media(max-width:680px){
  .door + .door{border-left:none;border-top:1px solid var(--line);padding-left:0;padding-top:18px;margin-top:12px}
  .hero-doors{flex-direction:column}
}
/* Mobile-first Hero: 3 Türen + beide CTAs müssen in Viewport 1 passen (Zielgruppe 50+, Konzept Pkt 11) */
@media(max-width:680px){
  .hero{padding:56px 0 56px}
  .hero h1{font-size:clamp(32px,8.4vw,46px)}
  .hero .sub{font-size:16px;margin:14px 0 22px}
  .hero-ctas{gap:12px}
  .hero-ctas .btn{width:100%;text-align:center;padding:14px 24px}
  .hero-doors{margin-top:24px;padding-top:16px}
  .door{padding:0;min-width:0}
  .door + .door{padding-top:12px;margin-top:10px}
  .door .d-title{font-size:17px}
}

/* Hero-Video (Flag hero_video / ?video=1) — abgedunkelt hinter der Typo */
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden;display:none;background:var(--ink)}
.hero-media video,.hero-media .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(20,18,15,.78),rgba(20,18,15,.45))}
.hero.hero--has-video .hero-media{display:block}
.hero.hero--has-video::before,.hero.hero--has-video::after{opacity:.5}
.hero.hero--has-video h1,.hero.hero--has-video .sub{color:var(--paper)}
.hero.hero--has-video h1 em{color:var(--gold)}
.hero.hero--has-video .door{color:var(--paper)}
.hero.hero--has-video .door + .door{border-left-color:var(--line-light)}
.hero.hero--has-video .hero-doors{border-top-color:var(--line-light)}
.hero.hero--has-video .btn-outline{color:var(--paper);box-shadow:inset 0 0 0 1.5px rgba(245,243,239,.6)}
.hero.hero--has-video .btn-outline:hover{background:var(--paper);color:var(--ink)}

/* ---------- bereich 1: direkt suchen ---------- */
.search-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:48px}
@media(max-width:780px){.search-grid{grid-template-columns:1fr}}
.search-card{
  background:#fff;border:1px solid var(--line);padding:40px 36px;
  display:flex;flex-direction:column;gap:14px;
  transition:box-shadow .2s ease,transform .2s ease;
}
.search-card:hover{box-shadow:0 14px 40px rgba(26,26,26,.08);transform:translateY(-2px)}
.search-card h3{font-family:var(--display);font-size:26px;font-weight:600}
.search-card p{color:var(--muted);font-size:15px;flex:1}
.search-card .meta{font-size:13px;color:var(--muted)}
.search-card .meta strong{color:var(--ink);font-weight:600}
.search-card .btn{align-self:flex-start;margin-top:8px}
.card-icon{width:40px;height:40px;color:var(--gold-deep)}
.live-dot{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--gold-deep);margin-right:7px;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

.chips{margin-top:40px}
.chips-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:14px}
.chips-row{display:flex;gap:10px;flex-wrap:wrap}
.chip{
  font-size:14px;font-weight:500;color:var(--ink);text-decoration:none;
  border:1px solid var(--line);background:#fff;padding:9px 18px;border-radius:100px;
  transition:border-color .15s,background .15s;
}
.chip:hover{border-color:var(--gold);background:rgba(201,168,76,.08)}

/* ---------- bereich 2: warum auszeit ---------- */
.proof-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:48px}
@media(max-width:780px){.proof-grid{grid-template-columns:1fr}}
.proof{background:var(--paper);padding:36px 32px}
.proof h3{font-family:var(--display);font-size:21px;font-weight:600;margin-bottom:10px}
.proof p{color:var(--muted);font-size:15px}
.proof p strong{color:var(--ink)}

.team-band{
  margin-top:56px;display:flex;align-items:center;gap:36px;flex-wrap:wrap;
  background:#fff;border:1px solid var(--line);padding:32px 36px;
}
.faces{display:flex}
.face{
  width:58px;height:58px;border-radius:50%;background:var(--ink);color:var(--gold);
  font-family:var(--display);font-size:20px;font-style:italic;
  display:flex;align-items:center;justify-content:center;
  border:3px solid var(--paper);margin-left:-12px;overflow:hidden;
}
.face:first-child{margin-left:0}
.face img{width:100%;height:100%;object-fit:cover}
.team-text{flex:1;min-width:240px}
.team-text .names{font-family:var(--display);font-size:19px;font-weight:600}
.team-text .role{font-size:13px;color:var(--muted)}
.team-actions{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.phone-link{font-family:var(--display);font-size:22px;font-weight:600;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--gold)}
.phone-sub{font-size:12px;color:var(--muted)}
.btn-quiet{font-size:13px;padding:10px 20px}
.stars{color:var(--gold-deep);letter-spacing:2px;font-size:15px}
.review-line{font-size:13px;color:var(--muted);margin-top:4px}
.wa-inline{font-size:13px;font-weight:600;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--gold)}

/* ---------- bereich 3: concierge (signature) ---------- */
.concierge{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.concierge::after{
  content:"";position:absolute;left:-200px;bottom:-260px;width:600px;height:600px;
  border:1px solid rgba(201,168,76,.25);border-radius:50%;
}
.concierge .eyebrow{color:var(--gold)}
.concierge h2{color:var(--paper)}
.conc-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:64px;align-items:center;position:relative;z-index:1}
@media(max-width:880px){.conc-grid{grid-template-columns:1fr;gap:44px}}
.conc-copy p{color:rgba(245,243,239,.72);margin-top:18px;max-width:46ch}
.privacy{
  margin:28px 0 32px;padding:16px 20px;border-left:2px solid var(--gold);
  font-size:15px;color:var(--paper);
}
.privacy strong{font-family:var(--display);font-style:italic;font-weight:500;font-size:17px;letter-spacing:.01em}
.privacy span{display:block;font-size:13px;color:rgba(245,243,239,.6);margin-top:4px}

.chat{
  background:var(--ink-soft);border:1px solid rgba(245,243,239,.12);
  padding:28px;min-height:330px;display:flex;flex-direction:column;gap:16px;
}
.chat-head{display:flex;align-items:center;gap:10px;padding-bottom:14px;border-bottom:1px solid var(--line-light);font-size:13px;color:rgba(245,243,239,.6)}
.chat-head .cdot{width:8px;height:8px;border-radius:50%;background:var(--gold)}
.bubble{max-width:88%;padding:13px 16px;font-size:14.5px;line-height:1.55}
.bubble.user{align-self:flex-end;background:rgba(201,168,76,.16);border:1px solid rgba(201,168,76,.35);color:var(--paper)}
.bubble.bot{align-self:flex-start;background:rgba(245,243,239,.07);border:1px solid var(--line-light);color:rgba(245,243,239,.92)}
.bubble.bot em{font-family:var(--display);font-style:italic;color:var(--gold)}
.caret{display:inline-block;width:1px;height:1em;background:var(--gold);vertical-align:-2px;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.typing{display:inline-flex;gap:4px;padding:4px 2px}
.typing i{width:5px;height:5px;border-radius:50%;background:rgba(245,243,239,.5);animation:tp 1.2s infinite}
.typing i:nth-child(2){animation-delay:.18s}.typing i:nth-child(3){animation-delay:.36s}
@keyframes tp{0%,60%,100%{opacity:.3;transform:none}30%{opacity:1;transform:translateY(-3px)}}

/* ---------- bereich 4: maßgeschneidert ---------- */
.tailor-list{margin-top:44px;border-top:1px solid var(--line)}
.tailor-item{
  display:flex;align-items:baseline;gap:28px;padding:24px 8px;
  border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink);
  transition:padding-left .2s ease,background .2s ease;
}
.tailor-item:hover{padding-left:20px;background:rgba(201,168,76,.06)}
.tailor-item .t-name{font-family:var(--display);font-size:clamp(22px,3vw,30px);font-weight:500;flex:0 0 auto}
.tailor-item .t-desc{color:var(--muted);font-size:14.5px;flex:1}
.tailor-item .t-arrow{font-family:var(--display);font-size:22px;color:var(--gold-deep);opacity:0;transition:opacity .2s}
.tailor-item:hover .t-arrow{opacity:1}
@media(max-width:640px){.tailor-item{flex-wrap:wrap;gap:6px}.tailor-item .t-desc{flex-basis:100%}}
.tailor-cta{margin-top:36px;display:flex;gap:24px;align-items:center;flex-wrap:wrap}
.tailor-cta .quiet-link{font-size:14px;color:var(--muted);text-decoration:none;border-bottom:1px solid var(--line)}
.tailor-cta .quiet-link:hover{color:var(--ink);border-bottom-color:var(--gold)}

/* ---------- bereich 5: reisewelten ---------- */
.worlds{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:48px}
@media(max-width:900px){.worlds{grid-template-columns:repeat(2,1fr)}}
.world{
  position:relative;aspect-ratio:4/5;text-decoration:none;overflow:hidden;
  display:flex;align-items:flex-end;padding:22px;
}
.world .w-bg{position:absolute;inset:0;transition:transform .5s ease;background-size:cover;background-position:center}
.world:hover .w-bg{transform:scale(1.05)}
.world .w-name{position:relative;font-family:var(--display);font-size:21px;font-style:italic;color:var(--paper);text-shadow:0 1px 14px rgba(0,0,0,.4);z-index:1}
.world::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(26,26,26,.55))}
/* duotone tile moods (Fallback laut Entscheidung TD-2) */
.w1{background:linear-gradient(160deg,#3d3326,#191510)}
.w2{background:linear-gradient(160deg,#2a3038,#15181d)}
.w3{background:linear-gradient(160deg,#273430,#121a17)}
.w4{background:linear-gradient(160deg,#403028,#1b130f)}
.w5{background:linear-gradient(160deg,#2c3a45,#141d23)}
.w6{background:linear-gradient(160deg,#36404a,#181d23)}
.w7{background:linear-gradient(160deg,#44392a,#1d1812)}
.w8{background:linear-gradient(160deg,#2e4146,#131e21)}
.w-bg::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 70% 20%, rgba(201,168,76,.22), transparent 55%);
}

/* ---------- bereich 6: unentschlossen ---------- */
.spark-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:44px}
@media(max-width:720px){.spark-grid{grid-template-columns:1fr}}
.spark{
  border:1px dashed rgba(201,168,76,.7);padding:36px 32px;background:transparent;
  display:flex;flex-direction:column;gap:10px;text-decoration:none;color:var(--ink);
  transition:background .2s ease;
}
.spark:hover{background:rgba(201,168,76,.07)}
.spark h3{font-family:var(--display);font-size:24px;font-weight:600}
.spark p{color:var(--muted);font-size:15px}
.spark .go{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-deep);margin-top:6px}

/* ---------- bereich 7: magazin ---------- */
.mag-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:44px}
@media(max-width:820px){.mag-grid{grid-template-columns:1fr}}
.mag-card{
  background:#fff;border:1px solid var(--line);text-decoration:none;color:var(--ink);
  display:flex;flex-direction:column;overflow:hidden;
  transition:box-shadow .2s ease,transform .2s ease;
}
.mag-card:hover{box-shadow:0 14px 40px rgba(26,26,26,.08);transform:translateY(-2px)}
.mag-card .m-img{aspect-ratio:3/2;overflow:hidden;background:var(--paper-deep)}
.mag-card .m-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.mag-card:hover .m-img img{transform:scale(1.04)}
.mag-card .m-body{padding:22px 24px 26px;display:flex;flex-direction:column;gap:8px;flex:1}
.mag-card .m-kind{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.mag-card .m-title{font-family:var(--display);font-size:21px;font-weight:600;line-height:1.25}
.mag-card .m-meta{font-size:13px;color:var(--muted);margin-top:auto}
.mag-cta{margin-top:32px}
.mag-cta a{font-size:14px;font-weight:600;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--gold)}
.mag-cta a:hover{color:var(--gold-deep)}

/* ---------- bereich 8: highlights ---------- */
.hl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:44px}
@media(max-width:820px){.hl-grid{grid-template-columns:1fr}}
.hl{background:var(--paper);padding:28px 26px;text-decoration:none;color:var(--ink);transition:background .15s}
.hl:hover{background:#fff}
.hl .h-kind{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:600}
.hl .h-name{font-family:var(--display);font-size:20px;font-weight:600;margin-top:6px;display:block}

/* ---------- footer ---------- */
footer{background:var(--ink);color:rgba(245,243,239,.65);padding:72px 0 40px;margin-top:96px}
.foot-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:36px}
@media(max-width:820px){.foot-grid{grid-template-columns:repeat(2,1fr)}}
.foot-grid h4{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:16px}
.foot-grid a{display:block;color:rgba(245,243,239,.65);text-decoration:none;font-size:14px;margin-bottom:10px;transition:color .15s}
.foot-grid a:hover{color:var(--paper)}
.foot-base{margin-top:56px;padding-top:24px;border-top:1px solid var(--line-light);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:13px}
.foot-base .logo{display:inline-flex;align-items:center}
.foot-base .logo img{height:30px;width:auto;display:block}
.foot-base .foot-legal{display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center}
.foot-base .foot-legal a{color:rgba(245,243,239,.5);text-decoration:none;font-size:12px;transition:color .15s}
.foot-base .foot-legal a:hover{color:var(--paper)}

/* ---------- WhatsApp Float ---------- */
.wa-float{
  position:fixed;bottom:22px;right:22px;z-index:60;
  width:56px;height:56px;border-radius:50%;
  background:var(--ink);color:var(--gold);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(26,26,26,.28);text-decoration:none;
  transition:background .15s,color .15s,transform .15s;
}
.wa-float:hover{background:var(--gold);color:var(--ink);transform:translateY(-2px)}
.wa-float svg{width:28px;height:28px}

/* ---------- A/B dev toggle (Staging-Vorschau concierge_live) ---------- */
.ab-toggle{
  position:fixed;bottom:18px;left:18px;z-index:60;
  background:var(--ink);color:var(--paper);border:1px solid rgba(201,168,76,.5);
  font-size:12px;font-weight:600;padding:9px 14px;cursor:pointer;letter-spacing:.04em;
}
.ab-toggle span{color:var(--gold)}

/* ---------- Sticky Termin-CTA (läuft ab Hero-Ende mit) ---------- */
/* Progressive Enhancement wie .reveal: ohne JS dauerhaft sichtbar, mit JS erst nach Scroll. */
.sticky-termin{
  position:fixed;bottom:22px;right:90px;z-index:70;
  display:inline-flex;align-items:center;gap:9px;
  background:var(--gold);color:var(--ink);
  font-family:var(--body);font-weight:700;font-size:15px;letter-spacing:.01em;
  padding:14px 24px;border-radius:40px;text-decoration:none;
  box-shadow:0 8px 24px rgba(26,26,26,.30);
  transition:opacity .3s ease,transform .3s ease,background .15s ease,box-shadow .15s ease;
}
.sticky-termin svg{width:18px;height:18px}
.sticky-termin:hover{background:var(--gold-deep);transform:translateY(-2px);box-shadow:0 10px 28px rgba(26,26,26,.34)}
.js .sticky-termin{opacity:0;transform:translateY(14px);pointer-events:none}
.js .sticky-termin.visible{opacity:1;transform:none;pointer-events:auto}

@media (max-width:768px){
  /* Mobil: volle Breite als prominente Bottom-Bar; Floats wandern darüber. */
  .sticky-termin{left:16px;right:16px;bottom:16px;justify-content:center;
    border-radius:14px;padding:16px;font-size:16px}
  .wa-float{bottom:84px;right:16px}
  .ab-toggle{bottom:84px;left:16px}
}
