@font-face {
  font-family: 'MargotMarker';
  src: url('../fonts/margotmarker-webfont.woff2') format('woff2'),
       url('../fonts/margotmarker-webfont.woff') format('woff');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#292826;--bg-soft:#2e2d2a;
  --orange:#E0894C;--olive:#AAA245;--gold:#C8A84E;
  --border:rgba(224,137,76,.14);--border-soft:rgba(224,137,76,.06);
  --display: 'MargotMarker', 'Caveat', cursive; --body: 'Lora', serif;
  --body-line-height: 1.85;
  --body-letter-spacing: .008em;
  --body-size: .94rem;
  --p-spacing-bottom: 1.2em;
}
body[data-font="nunito"]{
  --body: 'Nunito', -apple-system, sans-serif;
  --body-line-height: 1.78;
  --body-letter-spacing: .006em;
  --body-size: .92rem;
  --p-spacing-bottom: 1.1em;
}
body[data-font="montserrat"]{
  --body: 'Montserrat', -apple-system, sans-serif;
  --body-line-height: 1.3;
  --body-letter-spacing: -.02em;
  --body-size: .78rem;
  --p-spacing-bottom: .5em;
  font-weight: 600;
  word-spacing: -.05em;
  /* Premium-Tuning ausschalten — bleibt hart */
  font-feature-settings:"kern" 0, "liga" 0;
  text-rendering:optimizeSpeed;
  -webkit-font-smoothing:auto;
}
body[data-font="montserrat"] p,
body[data-font="montserrat"] li,
body[data-font="montserrat"] .hero-lead{
  font-weight:600;
  word-spacing:-.05em;
}
body[data-font="montserrat"] h1.no-margot,
body[data-font="montserrat"] h2.no-margot,
body[data-font="montserrat"] h3.no-margot,
body[data-font="montserrat"] h2,
body[data-font="montserrat"] h3{
  letter-spacing:-.02em;
  font-weight:700;
}
html{scroll-behavior:smooth;font-size:clamp(17px,4.2vw,18px)}
body{
  font-family:var(--body);color:var(--orange);background:var(--bg);
  line-height:var(--body-line-height);letter-spacing:var(--body-letter-spacing);
  overflow-x:hidden;
  /* Premium Typografie für Lora + Nunito */
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:"kern" 1, "liga" 1, "calt" 1;
  font-kerning:normal;
  background-image:
    radial-gradient(ellipse at 15% 8%,rgba(200,168,78,.04) 0%,transparent 55%),
    radial-gradient(ellipse at 85% 92%,rgba(170,162,69,.05) 0%,transparent 55%);
}
/* Nunito: zusätzlicher Word-spacing für Eleganz */
body[data-font="nunito"] p,
body[data-font="nunito"] .hero-lead,
body[data-font="nunito"] li{
  word-spacing:.02em;
}
/* Lora-italic: schöner Kontrast für em/blockquote */
body em,body i{font-style:italic;font-feature-settings:"kern" 1,"liga" 1}
svg.defs{position:absolute;width:0;height:0}

/* ALLE Hs in Margot */
h1,h2,h3,h4,h5,h6{font-family:var(--display);font-weight:700;line-height:1}
/* Für Überschriften mit Umlauten (Margot Marker hat keine sauberen Umlaute) */
h1.no-margot,h2.no-margot,h3.no-margot{
  font-family:var(--body);font-weight:600;letter-spacing:0;line-height:1.2;
}
h1.no-margot{font-size:clamp(2rem,4.5vw,3rem)}
h2.no-margot{font-size:clamp(1.3rem,2.4vw,1.75rem)}
h3.no-margot{font-size:clamp(1rem,1.6vw,1.2rem)}
h1{color:var(--orange)}
h2{color:var(--gold);font-weight:600;line-height:1.1}
h3{color:var(--olive);font-weight:600;line-height:1.1}

p{line-height:var(--body-line-height);font-size:var(--body-size);color:var(--orange);margin-bottom:var(--p-spacing-bottom)}
em{color:var(--gold);font-style:italic}
strong{color:var(--orange);font-weight:600}
a{color:inherit}

/* Zitate: Lora italic + Margot-Anführungszeichen */
blockquote{
  font-family:var(--body);font-style:italic;font-weight:500;
  color:var(--orange);line-height:1.65;
  position:relative;
}

/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:1rem 2rem;display:flex;align-items:center;
  justify-content:space-between;transition:all .4s;
}
nav.scrolled{
  background:rgba(41,40,38,.94);backdrop-filter:blur(18px);
  padding:.7rem 2rem;border-bottom:1px solid var(--border-soft);
}
.nav-logo img{height:120px;display:block;transition:height .3s}
nav.scrolled .nav-logo img{height:90px}
.nav-links{display:flex;gap:1.8rem;list-style:none;align-items:center}
.nav-links a{
  text-decoration:none;color:var(--olive);font-size:.78rem;
  font-family:var(--body);font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  transition:color .3s;position:relative;
}
.nav-links a:not(.nav-cta)::after{
  content:'';position:absolute;bottom:-6px;left:0;width:0;
  height:1px;background:var(--orange);transition:width .3s;
}
.nav-links a:hover{color:var(--orange)}
.nav-links a:hover::after{width:100%}
.nav-links .nav-cta{color:var(--bg);background:var(--orange);padding:.55rem 1.3rem;border-radius:999px;font-style:italic;letter-spacing:.02em;text-transform:none;font-size:.85rem;font-weight:500}
.nav-links .nav-cta:hover{background:var(--gold)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;z-index:200}
.burger span{width:22px;height:1.5px;background:var(--orange)}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s,transform .9s}
.reveal.in{opacity:1;transform:none}

.wrap{max-width:760px;margin:0 auto;padding:0 1.5rem}
.wide{max-width:1100px;margin:0 auto;padding:0 1.5rem}
section{padding:5rem 0;position:relative}

/* HERO */
.hero{
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:clamp(4rem,12vw,7rem) 1.5rem clamp(2rem,5vw,3rem);
  text-align:center;position:relative;
  overflow:hidden;
}
.hero-inner{position:relative;z-index:2;max-width:640px;width:100%}
.hero-logo{
  max-width:320px;width:62vw;margin:0 auto 2rem;
  filter:drop-shadow(0 2px 12px rgba(224,137,76,.1));
  animation:breathe 6s ease-in-out infinite;
  display:block;
}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.02)}}

.hero-rule{
  width:48px;height:1px;background:var(--gold);
  margin:1rem auto 2rem;opacity:.6;
  animation:lineGrow 1.2s .3s both ease-out;
}
@keyframes lineGrow{from{width:0;opacity:0}to{width:48px;opacity:.6}}

.hero-claim{
  font-family:var(--display);font-weight:700;
  font-size:clamp(2.6rem,5.5vw,3.8rem);color:var(--orange);
  line-height:1;letter-spacing:0;text-transform:none;
  margin-bottom:1rem;
  animation:fadeUp 1.2s .5s both;
}
.hero-lead{
  font-family:var(--body);font-size:clamp(1.1rem,2.5vw,1.2rem);
  color:var(--gold);line-height:1.65;margin-bottom:2.5rem;
  max-width:520px;margin-left:auto;margin-right:auto;
  animation:fadeUp 1.2s .8s both;
}
.hero-lead em{color:var(--gold);font-style:italic;font-weight:500}

.hero-services{
  list-style:none;font-family:var(--body);font-weight:700;
  font-size:clamp(.95rem,2.2vw,1rem);letter-spacing:.22em;text-transform:uppercase;
  color:var(--olive);line-height:2.4;
  animation:fadeUp 1.2s 1.1s both;
}
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

.hero-scroll{
  position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--body);font-size:.6rem;
  letter-spacing:.3em;text-transform:uppercase;
  color:var(--olive);opacity:.7;text-decoration:none;
  z-index:3;font-weight:700;transition:opacity .3s;
}
.hero-scroll:hover{opacity:1}
.hero-scroll svg{animation:floatScroll 2s ease-in-out infinite;stroke:currentColor}
@keyframes floatScroll{0%,100%{transform:translateY(0);opacity:.6}50%{transform:translateY(3px);opacity:1}}

/* Pfötchen im Hero-BG */
.hero-paw-bg{
  position:absolute;color:var(--olive);opacity:.045;
  pointer-events:none;z-index:1;
}
.hero-paw-bg.paw-a{
  width:80px;height:80px;top:14%;left:10%;
  transform:rotate(-18deg);
  animation:drift 20s ease-in-out infinite;
}
.hero-paw-bg.paw-b{
  width:54px;height:54px;top:62%;right:9%;
  transform:rotate(24deg);
  animation:drift 24s ease-in-out infinite -6s;
}
@keyframes drift{0%,100%{transform:translateY(0) rotate(-18deg)}50%{transform:translateY(-12px) rotate(-14deg)}}
@media(prefers-reduced-motion:reduce){
  .hero-logo,.hero-paw-bg,.hero-scroll svg,.hero-claim,.hero-lead,.hero-services,.hero-rule{animation:none;opacity:1;width:48px}
}

/* Services-Ticker */
.services-strip{
  border-top:1px solid var(--border-soft);
  border-bottom:1px solid var(--border-soft);
  padding:1.6rem 0;overflow:hidden;background:var(--bg-soft);
}
.services-track{
  display:flex;gap:3.5rem;align-items:center;
  animation:scrollStrip 50s linear infinite;width:max-content;
  font-family:var(--display);font-size:2rem;color:var(--orange);
  letter-spacing:.02em;line-height:1;
}
.services-track .dot{
  display:inline-flex;align-items:center;justify-content:center;
  width:1.1em;height:1.1em;color:var(--gold);flex-shrink:0;
}
.services-track .dot svg{width:100%;height:100%;fill:currentColor}
@keyframes scrollStrip{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Section Head */
.section-kicker{
  font-family:var(--body);font-size:.62rem;font-weight:700;
  letter-spacing:.3em;text-transform:uppercase;color:var(--olive);
  display:flex;align-items:center;justify-content:center;
  gap:1.2rem;margin-bottom:.6rem;
}
.section-kicker::before,.section-kicker::after{
  content:'';width:24px;height:1px;background:var(--olive);opacity:.6;
}
.section-title{
  font-family:var(--display);font-weight:700;
  font-size:clamp(3.5rem,7.5vw,5.5rem);color:var(--orange);
  text-align:center;line-height:.9;margin-bottom:1rem;
}
.section-sub{
  font-family:var(--display);font-weight:600;
  font-size:clamp(1.4rem,2.6vw,1.9rem);color:var(--gold);
  text-align:center;line-height:1.2;
  max-width:580px;margin:0 auto 3.5rem;
}

/* ANGEBOT */
.angebot{padding:6rem 0;border-top:1px solid var(--border)}
.angebot-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border:1px solid var(--border);background:var(--border);
}
.l-card{
  padding:2.5rem 2rem;background:var(--bg);
  transition:background .4s,transform .4s;position:relative;
}
.l-card:hover{background:var(--bg-soft)}
.l-card-num{
  font-family:var(--display);font-size:2.4rem;color:var(--gold);
  opacity:.55;line-height:1;margin-bottom:.8rem;
  transition:opacity .4s,transform .4s;
}
.l-card:hover .l-card-num{opacity:1;transform:translateX(4px)}
.l-card h3{font-size:clamp(1.5rem,2.5vw,1.9rem);margin-bottom:.4rem}
.l-card p{font-size:.88rem;line-height:1.75}

/* Paw-Feature (Berner Senn) */
.paw-feature{
  padding:5rem 1.5rem;text-align:center;
  border-top:1px solid var(--border);
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg-soft) 50%,var(--bg) 100%);
}
.paw-feature h2{font-size:clamp(1.8rem,3.5vw,2.4rem);margin-bottom:2rem}
.paw-img{
  width:340px;height:360px;margin:0 auto;
  clip-path:url(#pawShape);-webkit-clip-path:url(#pawShape);
  object-fit:cover;filter:grayscale(8%) contrast(1.03);
  transition:filter .6s;display:block;
  animation:heartbeat 1.8s ease-in-out infinite;
  transform-origin:center 60%;
}
.paw-img:hover{filter:grayscale(0%);animation-play-state:paused}
@keyframes heartbeat{
  0%,100%{transform:scale(1)}
  14%{transform:scale(1.04)}
  28%{transform:scale(1)}
  42%{transform:scale(1.06)}
  70%{transform:scale(1)}
}
@media(prefers-reduced-motion:reduce){.paw-img{animation:none}}
.paw-caption{
  max-width:500px;margin:1.8rem auto 0;
  font-size:.88rem;font-style:italic;opacity:.8;
}

/* Zitat-Sektion */
.quote-section{
  padding:6rem 1.5rem;border-top:1px solid var(--border);
  text-align:center;
}
.quote-mark{
  font-family:var(--display);font-size:5rem;color:var(--gold);
  line-height:.4;margin-bottom:.5rem;display:block;opacity:.6;
}
.quote-section blockquote{
  font-family:var(--body);font-style:italic;font-weight:500;
  font-size:clamp(1.3rem,2.4vw,1.8rem);color:var(--orange);
  max-width:780px;margin:0 auto 2rem;line-height:1.5;
}
.quote-section cite{
  display:block;font-family:var(--body);font-style:normal;
  font-size:.66rem;font-weight:700;
  letter-spacing:.28em;text-transform:uppercase;color:var(--olive);
}

/* ÜBER MICH */
.about{padding:6rem 0;border-top:1px solid var(--border)}
.about h1{font-size:clamp(3.5rem,7.5vw,5.5rem);text-align:center}
/* Handgeschriebene Überschriften als PNG (Margot mit manuell gesetzten Umlaut-Punkten) */
.h-img{display:block;margin:0 auto;max-width:100%;height:auto}
.h-img-uebermich{max-width:min(75%,420px);margin-bottom:1.5rem}
.about-intro{
  font-family:var(--body);font-style:italic;font-weight:500;
  font-size:clamp(1.05rem,1.8vw,1.25rem);color:var(--gold);
  text-align:center;margin:0 auto 3rem;max-width:620px;line-height:1.6;
}

.gold-portrait-wrap{text-align:center;margin-bottom:3rem}
.gold-portrait{position:relative;display:inline-block}
.gold-portrait img{
  width:240px;height:240px;object-fit:cover;border-radius:50%;
  border:3px solid var(--gold);filter:grayscale(8%);
  transition:transform .5s,border-color .5s,filter .5s;display:block;
}
.gold-portrait:hover img{transform:scale(1.04);border-color:var(--orange);filter:grayscale(0%)}
.gold-portrait .ring-paw{
  position:absolute;bottom:-6px;right:-6px;
  background:var(--bg);border:2px solid var(--gold);
  border-radius:50%;width:52px;height:52px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;transition:transform .3s,border-color .3s;
}
.gold-portrait:hover .ring-paw{transform:scale(1.12) rotate(-14deg);border-color:var(--orange)}

.story{max-width:640px;margin:0 auto;padding:0 1rem}
.story h2{
  font-size:clamp(1.8rem,3.5vw,2.4rem);
  margin:2.5rem 0 1rem;text-align:left;color:var(--gold);
}
.story p{margin-bottom:1.1rem;text-align:left}

/* So arbeite ich */
.approach{padding:6rem 0;border-top:1px solid var(--border);background:var(--bg-soft)}
.approach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem}
.approach-item{padding:2rem 1.5rem;border-top:2px solid var(--orange)}
.approach-num{
  font-family:var(--display);font-size:2.5rem;color:var(--gold);
  line-height:1;margin-bottom:1rem;
}
.approach-item h3{font-size:clamp(1.5rem,2.3vw,1.8rem);margin-bottom:.6rem;text-align:left}
.approach-item p{font-size:.88rem;text-align:left}

/* Profil */
.profile{padding:6rem 0;border-top:1px solid var(--border)}
.profile-table{max-width:780px;margin:0 auto}
.profile-row{
  display:grid;grid-template-columns:180px 1fr;gap:2rem;
  padding:1.4rem 0;border-bottom:1px solid var(--border-soft);
  align-items:baseline;
}
.profile-row:last-child{border-bottom:none}
.profile-key{
  font-family:var(--display);font-size:1.8rem;
  color:var(--gold);line-height:1;
}
.profile-val{font-size:.92rem;line-height:1.75}

.signature-block{
  max-width:720px;margin:4rem auto 0;padding:3rem 2rem;
  text-align:center;border-top:1px solid var(--border);
}
.signature-quote{
  font-family:var(--body);font-style:italic;font-weight:500;
  font-size:clamp(1.1rem,2vw,1.35rem);color:var(--orange);
  line-height:1.6;margin-bottom:1.5rem;
}
.signature-name{
  font-family:var(--display);font-size:2.6rem;color:var(--orange);
  display:block;line-height:1;
}
.signature-role{
  font-family:var(--body);font-size:.64rem;font-weight:700;
  letter-spacing:.28em;text-transform:uppercase;
  color:var(--olive);margin-top:.5rem;
}

/* Fade-Galerie */
.gallery-section{padding:4rem 1.5rem;text-align:center}
.gallery-section h1{font-size:clamp(2.5rem,5vw,3.5rem);margin-bottom:2rem}
.fade-gallery{
  position:relative;width:100%;max-width:520px;
  aspect-ratio:4/3;margin:0 auto;overflow:hidden;
  border-radius:24px;
}
.fade-gallery img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:0;filter:grayscale(10%);
  transition:opacity 1.2s ease,transform 6s ease;transform:scale(1);
}
.fade-gallery img.active{opacity:1;transform:scale(1.04)}
.fade-dots{display:flex;justify-content:center;gap:.5rem;margin-top:1.2rem}
.fade-dot{
  width:22px;height:2px;background:rgba(224,137,76,.25);
  border:none;cursor:pointer;transition:all .3s;padding:0;border-radius:2px;
}
.fade-dot.active{background:var(--orange)}
.fade-dot:hover{background:var(--gold)}

/* Marquee */
.marquee-section{overflow:hidden;border-top:1px solid var(--border)}
.marquee-track{display:flex;gap:0;animation:marqueeScroll 55s linear infinite;width:max-content}
.marquee-track:hover{animation-play-state:paused}
.marquee-img{
  height:180px;flex-shrink:0;object-fit:cover;
  filter:grayscale(18%) contrast(1.02);
  transition:filter .5s,transform .5s;
}
.marquee-img:hover{filter:grayscale(0%);transform:scale(1.04);z-index:2;position:relative}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Preise */
.pricing{padding:6rem 0;border-top:1px solid var(--border);background:var(--bg-soft)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.3rem;margin-bottom:2rem}
.price-card{
  padding:2.3rem 1.8rem;border:1px solid var(--border);
  background:var(--bg);text-align:center;transition:all .4s;position:relative;
}
.price-card:hover{border-color:var(--orange);transform:translateY(-3px)}
.price-card.featured{border-color:var(--orange);overflow:hidden}
.price-card.featured::before{
  content:'AM HÄUFIGSTEN';
  position:absolute;top:.8rem;right:-2.2rem;
  transform:rotate(30deg);
  background:var(--orange);color:var(--bg);
  font-family:var(--body);font-size:.52rem;
  font-weight:700;letter-spacing:.22em;padding:.2rem 2.5rem;
}
.price-card h3{font-size:clamp(1.85rem,3vw,2.4rem);margin-bottom:.3rem;text-align:center;line-height:1.05}
.price-duration{
  font-family:var(--display);font-size:1.85rem;
  color:var(--gold);margin-bottom:1.5rem;line-height:1;
}
.price-amount{
  font-family:var(--display);font-size:3.6rem;
  color:var(--orange);line-height:.9;font-weight:700;
}
.price-currency{
  font-family:var(--body);font-size:.9rem;font-weight:500;
  letter-spacing:.1em;display:block;color:var(--orange);
  opacity:.6;margin-top:-.2rem;
}
.price-desc{
  font-size:.92rem;line-height:1.65;
  margin-top:1.5rem;padding-top:1.2rem;
  border-top:1px solid var(--border-soft);opacity:.9;
}
.abo-row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:.9rem;
  max-width:100%;margin:0 auto 2rem;
}

/* Hausbesuch / km-Pauschale */
.hausbesuch{
  max-width:680px;margin:0 auto;
  padding:1rem 1.4rem;
  background:rgba(200,168,78,.06);
  border:1px solid rgba(200,168,78,.25);
  border-left:3px solid var(--gold);
  border-radius:8px;
}
.hausbesuch-inner{
  display:flex;align-items:center;gap:1rem;
}
.hausbesuch-icon{
  font-size:2rem;color:var(--gold);
  font-family:Georgia,serif;
  line-height:1;flex-shrink:0;
  width:2rem;text-align:center;
}
.hausbesuch-text{flex:1;display:flex;flex-direction:column;gap:.2rem;line-height:1.3}
.hausbesuch-text strong{
  color:var(--orange);font-weight:600;font-size:1.2rem;
  font-family:var(--body);letter-spacing:.01em;
}
.hausbesuch-text span{color:var(--orange);opacity:.8;font-size:.95rem;font-style:italic}
.hausbesuch-price{
  color:var(--gold);font-weight:700;font-size:1.85rem;
  font-family:var(--display);letter-spacing:.02em;
  white-space:nowrap;line-height:1;
}
.hausbesuch-price small{
  font-family:var(--body);font-size:.85rem;
  font-weight:400;opacity:.75;margin-left:.15rem;
}
.abo{padding:1.5rem 1.3rem;border:1px dashed var(--border);text-align:center;font-size:.9rem}
.abo h3{font-size:1.7rem;color:var(--olive);margin-bottom:.5rem;text-align:center;line-height:1.05}
.abo .amount{
  font-family:var(--display);color:var(--gold);
  font-size:2.7rem;font-weight:700;line-height:1;
  display:block;margin-top:.6rem;
}

/* CTA + Kontakt */
.cta-kontakt{padding:6rem 0;border-top:1px solid var(--border)}
.cta-kontakt-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.cta-left h1{font-size:clamp(2.5rem,5vw,3.5rem);margin-bottom:1rem;line-height:.95;text-align:left}
.cta-left h2{font-size:clamp(1.5rem,2.8vw,2rem);margin-bottom:1.5rem;text-align:left}
.cta-left p{margin-bottom:1.2rem}
.cta-left .btn-wrap{margin-top:2rem}
.btn{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:.95rem 2.2rem;font-family:var(--body);
  font-size:.95rem;font-weight:500;font-style:italic;
  letter-spacing:.01em;
  text-decoration:none;cursor:pointer;
  transition:all .35s;border:1px solid var(--orange);
  border-radius:999px;
  color:var(--orange);background:transparent;
}
.btn::after{content:'→';display:inline-block;transition:transform .3s ease}
.btn:hover{background:var(--orange);color:var(--bg)}
.btn:hover::after{transform:translateX(5px)}
.btn-solid{background:var(--orange);color:var(--bg)}
.btn-solid:hover{background:var(--gold);border-color:var(--gold);color:var(--bg)}
.btn-nopfeil::after{display:none}

.contact-card{padding:2.5rem;border:1px solid var(--border);background:var(--bg-soft)}
.contact-card h3{font-size:clamp(1.6rem,2.8vw,2rem);margin-bottom:2rem;text-align:left}
.contact-row{
  padding:.9rem 0;border-bottom:1px solid var(--border-soft);
  display:grid;grid-template-columns:150px 1fr;gap:1rem;font-size:.92rem;
  align-items:baseline;
}
.contact-row:last-child{border-bottom:none}
.contact-row dt{
  font-family:var(--display);font-size:1.8rem;
  color:var(--gold);line-height:1;
}
.contact-row dd a{text-decoration:none;color:var(--orange)}
.contact-row dd a:hover{color:var(--gold)}

/* Footer */
/* =========================================================
   FOOTER
   ========================================================= */
footer{
  border-top:1px solid var(--border);
  padding:3.5rem 1.5rem 1.5rem;
  background:var(--bg-soft);
  margin-top:5rem;
}
.ft{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr auto 1fr;
  gap:3rem;align-items:start;
}
.ft-info{text-align:left}
.ft-info strong{
  font-family:var(--display);font-size:1.4rem;
  color:var(--orange);display:block;margin-bottom:.6rem;line-height:1;
}
.ft-info p{font-size:.88rem;line-height:1.7;color:var(--orange);opacity:.8}

.ft-logo{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}
.ft-logo img{display:block}
.ft-links{
  font-family:var(--body);font-size:.72rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
}
.ft-links a{
  color:var(--olive);text-decoration:none;cursor:pointer;
  transition:color .3s;
}
.ft-links a:hover{color:var(--orange)}
.ft-links span{color:var(--olive);opacity:.35;margin:0 .4rem}
.ft-social{display:flex;gap:1rem;justify-content:center;margin-top:.2rem}
.ft-social a{
  color:var(--olive);transition:color .3s,transform .3s;
  display:inline-flex;align-items:center;justify-content:center;
}
.ft-social a:hover{color:var(--orange);transform:translateY(-2px)}
.ft-social svg{display:block}

.ft-contact{text-align:right}
.ft-contact p{
  font-size:.92rem;line-height:1.6;color:var(--orange);
  margin-bottom:.3rem;
}
.ft-contact a{color:var(--orange);text-decoration:none;transition:color .3s}
.ft-contact a:hover{color:var(--gold)}
.ft-contact .ft-wa{
  display:inline-flex;align-items:center;gap:.4rem;
  font-weight:600;
}
.ft-contact .ft-wa-hint{
  font-size:.72rem;font-style:italic;color:var(--gold);
  opacity:.7;margin-bottom:.6rem;
}

.ft-bottom{
  max-width:1100px;margin:2.5rem auto 0;padding-top:1.2rem;
  border-top:1px solid var(--border);text-align:center;
}
.ft-bottom p{
  font-size:.72rem;color:var(--orange);opacity:.45;
  letter-spacing:.02em;
}
.ft-bottom a{color:var(--olive);text-decoration:none;transition:color .3s}
.ft-bottom a:hover{color:var(--orange);text-decoration:underline}

@media(max-width:760px){
  .ft{grid-template-columns:1fr;gap:2rem;text-align:center}
  .ft-info,.ft-contact{text-align:center}
}

/* =========================================================
   IMPRESSUM / DATENSCHUTZ POPUPS
   ========================================================= */
.popup-overlay{
  display:none;position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.7);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  align-items:center;justify-content:center;padding:1rem;
}
.popup-overlay.open{display:flex}
.popup-box{
  background:var(--bg);max-width:600px;width:100%;
  max-height:85vh;overflow-y:auto;
  padding:2.5rem 2rem;position:relative;
  border:1px solid var(--border);border-radius:16px;
}
.popup-close{
  position:absolute;top:.8rem;right:1rem;
  background:none;border:none;font-size:1.8rem;line-height:1;
  cursor:pointer;color:var(--orange);transition:color .3s;
}
.popup-close:hover{color:var(--gold)}
.popup-box h3{
  font-family:var(--display);font-weight:400;
  font-size:2rem;color:var(--orange);
  line-height:1;margin-bottom:1.5rem;
}
.popup-box p{
  font-size:.92rem;line-height:1.75;
  color:var(--orange);margin-bottom:1rem;
}
.popup-box p strong{
  color:var(--olive);display:block;margin-bottom:.2rem;
  font-size:.72rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;
}
.popup-box p a{color:var(--orange);text-decoration:underline}
.popup-box p a:hover{color:var(--gold)}
.popup-stand{
  font-size:.72rem;color:var(--gold);opacity:.6;
  margin-top:1.5rem;font-style:italic;
}

@media(max-width:900px){
  .angebot-grid{grid-template-columns:1fr}
  .approach-grid{grid-template-columns:1fr;gap:1.5rem}
  .pricing-grid{grid-template-columns:1fr}
  .abo-row{grid-template-columns:1fr 1fr}
  .hausbesuch-inner{flex-wrap:wrap;gap:.6rem}
  .hausbesuch-text{min-width:0;flex:1 1 60%}
  .hausbesuch-price{margin-left:auto}
  .cta-kontakt-inner{grid-template-columns:1fr;gap:2.5rem}
  .cta-left h1,.cta-left h2{text-align:center}
  .profile-row{grid-template-columns:1fr;gap:.3rem}
  .abo-row{grid-template-columns:1fr}
}
@media(max-width:600px){
  nav{padding:.9rem 1.2rem}
  .wide,.wrap{padding:0 1rem}
  .l-card{padding:2rem 1.2rem}
  .approach-item{padding:1.5rem 1rem}
  .price-card{padding:2rem 1.2rem}
  .contact-card{padding:1.8rem 1.2rem}
  .nav-links{
    display:none;position:fixed;top:0;left:0;right:0;bottom:0;
    background:rgba(41,40,38,.98);backdrop-filter:blur(20px);
    flex-direction:column;justify-content:center;align-items:center;
    gap:2rem;padding:2rem;z-index:150;
  }
  .nav-links.open{display:flex}
  .nav-links a{font-size:1.2rem!important;letter-spacing:.18em}
  .nav-links .nav-cta{font-size:1.1rem!important;padding:.9rem 2rem}
  .burger{display:flex}
  .burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .burger.open span:nth-child(2){opacity:0}
  .burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
  .burger span{transition:transform .3s,opacity .3s}
  .gold-portrait img{width:200px;height:200px}
  .paw-img{width:280px;height:300px}
  .marquee-img{height:140px}
}
/* =========================================================
   FLOATING KONTAKT-BUTTON (dezent, mitscrollend)
   ========================================================= */
.floating-kontakt{
  position:fixed;right:1.5rem;bottom:1.5rem;z-index:200;
  display:inline-flex;align-items:center;gap:.6rem;
  padding:.85rem 1.4rem;
  background:var(--orange);color:var(--bg);
  font-family:var(--body);font-weight:500;font-style:italic;
  font-size:.95rem;letter-spacing:.02em;
  text-decoration:none;border-radius:999px;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  transition:background .3s,color .3s,transform .3s;
  cursor:pointer;border:none;
  max-width:calc(100vw - 3rem);
}
.floating-kontakt:hover{background:var(--gold);transform:translateY(-2px)}
.floating-kontakt svg{width:18px;height:18px;fill:currentColor;flex-shrink:0}
.floating-kontakt-text{display:inline;white-space:nowrap}
@media(max-width:600px){
  .floating-kontakt{
    right:1rem;bottom:1rem;
    width:52px;height:52px;
    padding:0;gap:0;
    display:flex;align-items:center;justify-content:center;
    border-radius:50%;
    max-width:52px;
  }
  .floating-kontakt-text{display:none}
  .floating-kontakt svg{width:24px;height:24px}
}
/* Genug Platz am Seitenende, damit der Button nichts mehr verdeckt */
body{padding-bottom:80px}
@media(max-width:600px){body{padding-bottom:70px}}

/* =========================================================
   KONTAKT-POPUP (Formular)
   ========================================================= */
.k-overlay{
  display:none;position:fixed;inset:0;z-index:500;
  background:rgba(0,0,0,.7);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  align-items:center;justify-content:center;padding:1rem;
}
.k-overlay.open{display:flex}
.k-box{
  background:var(--bg);max-width:540px;width:100%;
  max-height:92vh;overflow-y:auto;
  padding:2.5rem 2rem 2rem;
  position:relative;border:1px solid var(--border);
  border-radius:16px;
}
.k-close{
  position:absolute;top:.8rem;right:1rem;
  background:none;border:none;font-size:1.8rem;line-height:1;
  cursor:pointer;color:var(--orange);transition:color .3s;
}
.k-close:hover{color:var(--gold)}
.k-title{
  font-family:var(--display);font-size:2.2rem;font-weight:400;
  color:var(--orange);line-height:1;margin-bottom:.4rem;text-align:center;
}
.k-sub{
  font-family:var(--body);font-style:italic;font-size:.92rem;
  color:var(--gold);text-align:center;margin-bottom:2rem;line-height:1.5;
}
.k-form{display:flex;flex-direction:column;gap:.9rem}
.k-field label{
  display:block;font-family:var(--body);font-size:.72rem;
  font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--olive);margin-bottom:.35rem;
}
.k-field input,.k-field select,.k-field textarea{
  width:100%;padding:.75rem .9rem;
  background:var(--bg-soft);color:var(--orange);
  border:1px solid var(--border);border-radius:8px;
  font-family:var(--body);font-size:.95rem;
  transition:border-color .3s,background .3s;
}
.k-field input:focus,.k-field select:focus,.k-field textarea:focus{
  outline:none;border-color:var(--orange);background:var(--bg);
}
.k-field textarea{min-height:110px;resize:vertical;line-height:1.55}
.k-field select{cursor:pointer}
.k-field select option{background:var(--bg);color:var(--orange)}

.k-checks{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:.2rem}
.k-check{
  display:inline-flex;align-items:center;gap:.4rem;
  font-family:var(--body);font-size:.88rem;color:var(--orange);
  cursor:pointer;user-select:none;
}
.k-check input{
  width:16px;height:16px;margin:0;cursor:pointer;
  accent-color:var(--orange);
}
.k-honey{position:absolute;left:-10000px;opacity:0;pointer-events:none}

.k-submit{
  margin-top:.5rem;padding:.95rem 1.5rem;
  background:var(--orange);color:var(--bg);
  font-family:var(--body);font-weight:500;font-style:italic;
  font-size:1rem;letter-spacing:.02em;
  border:none;border-radius:999px;cursor:pointer;
  transition:background .3s,color .3s;
}
.k-submit:hover{background:var(--gold)}
.k-submit:disabled{opacity:.6;cursor:wait}
.k-note{
  font-size:.75rem;color:var(--orange);opacity:.55;
  text-align:center;margin-top:.6rem;line-height:1.5;
}
.k-note strong{color:var(--gold);font-weight:600}

/* ============= NEWS-BANNER (im Hero) ============= */
.hero-news{
  max-width:480px;
  margin:1.5rem auto 1.8rem;
  padding:1rem 1.2rem;
  background:linear-gradient(180deg,rgba(200,168,78,.12) 0%,rgba(200,168,78,.06) 100%);
  border:1px solid rgba(200,168,78,.4);
  border-left:3px solid var(--gold);
  border-radius:8px;
  display:flex;align-items:flex-start;gap:.9rem;
  text-align:left;
  animation:newsAppear .6s ease-out both;
}
/* Aktion = Orange */
.hero-news-aktion{
  background:linear-gradient(180deg,rgba(224,137,76,.14) 0%,rgba(224,137,76,.06) 100%);
  border-color:rgba(224,137,76,.45);
  border-left-color:var(--orange);
}
.hero-news-aktion .hero-news-icon{background:var(--orange)}
.hero-news-aktion .hero-news-body strong{color:var(--orange)}
.hero-news-aktion .hero-news-zeit{color:var(--gold)}

/* Hinweis = Olive */
.hero-news-hinweis{
  background:linear-gradient(180deg,rgba(170,162,69,.14) 0%,rgba(170,162,69,.05) 100%);
  border-color:rgba(170,162,69,.45);
  border-left-color:var(--olive);
}
.hero-news-hinweis .hero-news-icon{background:var(--olive)}
.hero-news-hinweis .hero-news-body strong{color:var(--olive)}
.hero-news-hinweis .hero-news-zeit{color:var(--orange);opacity:.7}

@keyframes newsAppear{
  from{opacity:0;transform:translateY(-8px)}
  to{opacity:1;transform:none}
}
.hero-news-icon{
  flex-shrink:0;width:1.9rem;height:1.9rem;border-radius:50%;
  background:var(--gold);color:var(--bg);
  font-family:Georgia,serif;font-weight:700;font-size:1.05rem;
  display:flex;align-items:center;justify-content:center;
  margin-top:.05rem;
}
.hero-news-body{flex:1;min-width:0}
.hero-news-body strong{
  color:var(--gold);font-weight:600;font-size:1rem;
  font-family:var(--body);letter-spacing:.01em;
}
.hero-news-zeit{color:var(--orange);opacity:.75;font-size:.9rem}
.hero-news-body p{
  color:var(--orange);font-size:.9rem;margin:.25rem 0 0;
  line-height:1.5;font-style:italic;
}
@media (max-width:600px){
  .hero-news{margin:1rem .5rem 1.4rem;padding:.8rem 1rem;gap:.7rem}
  .hero-news-icon{width:1.6rem;height:1.6rem;font-size:.95rem}
  .hero-news-body strong{font-size:.92rem}
  .hero-news-body p{font-size:.85rem}
}

/* ============= FONT-SWITCHER ============= */
.font-switch{
  position:fixed;top:0;left:0;right:0;z-index:9999;
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.8rem;
  background:linear-gradient(180deg,var(--orange) 0%,#d47a3e 100%);
  padding:.65rem 1rem;
  font-family:'Montserrat',sans-serif;
  font-size:.78rem;letter-spacing:.06em;
  box-shadow:0 4px 16px rgba(0,0,0,.35);
  color:var(--bg);
}
.font-switch-label{font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.72rem}
.font-switch-question{font-weight:500;font-style:italic;font-size:.85rem;letter-spacing:0}
.font-switch button{
  background:transparent;border:1.5px solid var(--bg);color:var(--bg);
  cursor:pointer;padding:.4rem 1rem;border-radius:999px;
  font-family:inherit;font-size:.78rem;letter-spacing:.08em;
  text-transform:uppercase;font-weight:700;transition:all .25s;
}
.font-switch button:hover{background:rgba(41,40,38,.15)}
.font-switch button.active{background:var(--bg);color:var(--orange)}
body{padding-top:3.2rem}
nav{top:3.2rem !important}
@media (max-width:600px){
  .font-switch{padding:.55rem .6rem;gap:.4rem;font-size:.7rem}
  .font-switch-label{font-size:.62rem;letter-spacing:.08em}
  .font-switch-question{font-size:.72rem}
  .font-switch button{padding:.3rem .7rem;font-size:.65rem}
  body{padding-top:5.5rem}
  nav{top:5.5rem !important}
}