/* =====================================================================
   Stani's Haus und Garten – Design System
   Farbkonzept: Warmes Grün (aus Logo) + Anthrazit · Premium · 2026
   ===================================================================== */

:root{
  /* Marke */
  --green:        #6FA82C;
  --green-deep:   #517E1C;
  --green-bright: #9AD023;
  --green-tint:   #EEF5E1;
  --green-tint-2: #E3EFCF;

  --anthracite:   #2A2D2C;
  --anthracite-2: #1E2120;
  --anthracite-3: #353A38;
  --anthracite-card: #32383600;

  --cream:        #F8F7F2;
  --cream-2:      #F1EFE7;
  --white:        #FFFFFF;
  --ink:          #21241F;
  --muted:        #62675E;
  --muted-light:  #A9AEA2;
  --line:         #E7E4DA;
  --line-dark:    #3C413F;

  --radius-xl: 32px;
  --radius-lg: 24px;
  --radius-md: 16px;
  --radius-sm: 10px;

  --shadow-sm: 0 4px 14px rgba(33,36,31,.06);
  --shadow-md: 0 18px 40px -18px rgba(33,36,31,.22);
  --shadow-lg: 0 40px 80px -30px rgba(33,36,31,.35);
  --shadow-green: 0 16px 34px -12px rgba(111,168,44,.55);

  --maxw: 1240px;
  --gap: clamp(1.5rem, 4vw, 4rem);

  --ff-head: "Manrope", "Segoe UI", system-ui, -apple-system, sans-serif;
  --ff-body: "Inter", "Segoe UI", system-ui, -apple-system, sans-serif;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ----------------------- Reset ----------------------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.65;
  font-size:clamp(16px,1.05vw,17.5px);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4{font-family:var(--ff-head);font-weight:800;line-height:1.12;letter-spacing:-.02em;color:var(--ink)}

/* ----------------------- Layout ----------------------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.2rem)}
.section{padding-block:clamp(3.5rem,7vw,6.5rem)}
.section--tight{padding-block:clamp(2.5rem,5vw,4rem)}
.center{text-align:center}
.mx-auto{margin-inline:auto}

/* ----------------------- Typo helpers ----------------------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--ff-head);font-weight:700;font-size:.82rem;
  letter-spacing:.14em;text-transform:uppercase;color:var(--green-deep);
  margin-bottom:1rem;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--green);border-radius:2px}
.eyebrow--light{color:var(--green-bright)}
.eyebrow--center{justify-content:center}

h1,.h1{font-size:clamp(2.3rem,5.2vw,4.1rem)}
h2,.h2{font-size:clamp(1.9rem,3.8vw,3rem)}
h3,.h3{font-size:clamp(1.3rem,2vw,1.7rem)}
.lead{font-size:clamp(1.08rem,1.5vw,1.3rem);color:var(--muted);max-width:62ch}
.section-head{max-width:64ch}
.section-head.center{margin-inline:auto}
.section-head p{margin-top:1rem}
.text-green{color:var(--green-deep)}

/* ----------------------- Buttons ----------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:var(--ff-head);font-weight:700;font-size:1rem;
  padding:.95rem 1.7rem;border-radius:999px;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),color .25s var(--ease);
  white-space:nowrap;line-height:1;
}
.btn svg{width:1.15em;height:1.15em;flex:none}
.btn--primary{background:var(--green);color:#fff;box-shadow:var(--shadow-green);position:relative;overflow:hidden}
.btn--primary::after{content:"";position:absolute;top:0;left:-120%;width:55%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.38),transparent);transform:skewX(-18deg);pointer-events:none}
.btn--primary:hover::after{left:140%;transition:left .75s var(--ease)}
.btn--primary:hover{background:var(--green-deep);transform:translateY(-2px);box-shadow:0 20px 40px -12px rgba(111,168,44,.7)}
.btn--ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.32)}
.btn--ghost:hover{background:rgba(255,255,255,.16);transform:translateY(-2px)}
.btn--dark{background:var(--anthracite);color:#fff}
.btn--dark:hover{background:#000;transform:translateY(-2px)}
.btn--outline{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn--outline:hover{border-color:var(--green);color:var(--green-deep);transform:translateY(-2px)}
.btn--lg{padding:1.15rem 2.1rem;font-size:1.08rem}
.btn--block{width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem}
.btn-row--center{justify-content:center}

/* Telefonzeile als Button */
.btn--phone{gap:.7rem}

/* ----------------------- Header ----------------------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(248,247,242,.82);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,box-shadow .3s,background .3s;
}
.site-header.scrolled{border-color:var(--line);box-shadow:0 6px 24px -16px rgba(0,0,0,.25)}
.nav{display:flex;align-items:center;gap:1.5rem;height:78px}
.nav__logo{display:flex;align-items:center;flex:none}
.nav__logo img{height:46px;width:auto}
.nav__links{display:flex;align-items:center;gap:.35rem;margin-left:auto}
.nav__links a{
  font-family:var(--ff-head);font-weight:600;font-size:.97rem;color:var(--ink);
  padding:.55rem .8rem;border-radius:999px;transition:background .2s,color .2s;
  position:relative;
}
.nav__links a:hover{color:var(--green-deep);background:var(--green-tint)}
.nav__links a.active{color:var(--green-deep)}
.nav__cta{display:flex;align-items:center;gap:.7rem;margin-left:.6rem}
.nav__phone{
  display:inline-flex;align-items:center;gap:.5rem;font-family:var(--ff-head);
  font-weight:700;color:var(--ink);padding:.55rem .85rem;border-radius:999px;transition:color .2s;
}
.nav__phone:hover{color:var(--green-deep)}
.nav__phone svg{width:1.1em;height:1.1em;color:var(--green)}
.nav__phone span{font-size:.97rem}

/* Dropdown Leistungen */
.has-drop{position:relative}
.drop{
  position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(8px);
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-md);
  box-shadow:var(--shadow-md);padding:.5rem;min-width:270px;
  opacity:0;visibility:hidden;transition:.22s var(--ease);
}
.has-drop:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop a{display:flex;align-items:center;gap:.7rem;padding:.7rem .8rem;border-radius:var(--radius-sm);font-size:.95rem}
.drop a:hover{background:var(--green-tint)}
.drop a .dot{width:34px;height:34px;border-radius:9px;background:var(--green-tint-2);display:grid;place-items:center;flex:none;color:var(--green-deep)}
.drop a .dot svg{width:18px;height:18px}

/* Burger */
.burger{display:none;flex-direction:column;gap:5px;padding:.6rem;margin-left:auto;border-radius:10px}
.burger span{width:24px;height:2.5px;background:var(--ink);border-radius:2px;transition:.3s}
body.nav-open .burger span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
body.nav-open .burger span:nth-child(2){opacity:0}
body.nav-open .burger span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* Mobile menu */
.mobile-nav{
  position:fixed;inset:0 0 0 auto;width:min(86vw,360px);z-index:70;
  background:var(--anthracite);color:#fff;padding:6rem 1.6rem 2rem;
  transform:translateX(105%);transition:transform .4s var(--ease);
  display:flex;flex-direction:column;gap:.2rem;overflow-y:auto;
}
body.nav-open .mobile-nav{transform:translateX(0)}
.mobile-nav a{padding:.95rem .4rem;font-family:var(--ff-head);font-weight:600;font-size:1.1rem;border-bottom:1px solid var(--line-dark)}
.mobile-nav a:hover{color:var(--green-bright)}
.mobile-nav .btn{margin-top:1.4rem}
.mobile-nav .m-phone{color:var(--green-bright);border:none;margin-top:.6rem}
.nav-overlay{position:fixed;inset:0;background:rgba(20,22,21,.55);z-index:65;opacity:0;visibility:hidden;transition:.3s}
body.nav-open .nav-overlay{opacity:1;visibility:visible}

/* ----------------------- Hero ----------------------- */
.hero{position:relative;padding-top:clamp(1.5rem,3vw,2.5rem)}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,3.5vw,3.2rem);align-items:center}
.hero__content{max-width:38rem}
.hero h1{margin-bottom:1.3rem}
.hero h1 .hl{color:var(--green-deep)}
.hero__content .lead{margin-bottom:2rem}
.hero__media{position:relative}
.hero__media img{width:100%;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);object-fit:cover;aspect-ratio:4/4.6}
.hero__badge{
  position:absolute;left:-18px;bottom:34px;background:#fff;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);padding:1rem 1.3rem;display:flex;align-items:center;gap:.85rem;
}
.hero__badge .num{font-family:var(--ff-head);font-weight:800;font-size:2rem;color:var(--green-deep);line-height:1}
.hero__badge .lbl{font-size:.85rem;color:var(--muted);line-height:1.25;max-width:11ch}
.hero__badge--top{top:28px;bottom:auto;left:auto;right:-14px}
.hero__badge--top .ic{width:42px;height:42px;border-radius:12px;background:var(--green-tint);color:var(--green-deep);display:grid;place-items:center}
.hero-trust{display:flex;flex-wrap:wrap;gap:1.4rem 2rem;margin-top:2.2rem}
.hero-trust li{display:flex;align-items:center;gap:.55rem;font-weight:600;font-size:.95rem}
.hero-trust svg{width:1.2em;height:1.2em;color:var(--green)}

/* ----------------------- Hero VOLLFLÄCHIG (Startseite) ----------------------- */
.hero-full{
  position:relative;min-height:clamp(580px,92vh,960px);
  display:grid;place-items:center;text-align:center;overflow:hidden;isolation:isolate;
}
.hero-full__bg{position:absolute;inset:0;z-index:-2}
.hero-full__bg img{width:100%;height:100%;object-fit:cover;object-position:32% center}
/* Abdunklung für Lesbarkeit – Bild bleibt schön sichtbar */
.hero-full__bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(180deg,rgba(24,27,26,.42) 0%,rgba(24,27,26,.28) 38%,rgba(20,22,21,.82) 100%)}
.hero-full::before{content:"";position:absolute;inset:0;z-index:-1;background:
  radial-gradient(120% 95% at 50% 32%,transparent 38%,rgba(18,20,19,.55) 100%)}
.hero-full__inner{width:100%;max-width:860px;padding:clamp(2rem,6vw,4.5rem) clamp(1.2rem,5vw,2rem)}
.hero-full__card{
  background:rgba(24,27,26,.34);backdrop-filter:blur(9px) saturate(135%);-webkit-backdrop-filter:blur(9px) saturate(135%);
  border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-xl);
  padding:clamp(1.8rem,4.5vw,3.4rem) clamp(1.5rem,4vw,3.2rem);
  box-shadow:0 50px 100px -45px rgba(0,0,0,.7);
  animation:heroIn 1s var(--ease) both;
}
@keyframes heroIn{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}
.hero-full .hero-brand{font-family:var(--ff-head);font-weight:800;font-size:clamp(1.35rem,3.1vw,2.15rem);color:#fff;line-height:1.12;margin-bottom:.5rem;text-shadow:0 2px 18px rgba(0,0,0,.3)}
.hero-full .hero-brand .hl{color:var(--green-bright)}
.hero-full .hero-brand .gmbh{font-weight:600;font-size:.7em;opacity:.78}
.hero-full .hero-sub{display:block;font-family:var(--ff-head);font-weight:600;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:#CBD0C5;margin-bottom:1.1rem}
.hero-full .eyebrow{justify-content:center;color:var(--green-bright);margin-bottom:1.1rem}
.hero-full .eyebrow::before{background:var(--green-bright)}
.hero-full h1{color:#fff;font-size:clamp(2.5rem,6.2vw,5.1rem);margin-bottom:1.2rem;text-shadow:0 2px 24px rgba(0,0,0,.28)}
.hero-full h1 .hl{color:var(--green-bright)}
.hero-full .lead{color:#E9ECE3;margin:0 auto 2rem;max-width:54ch}
.hero-full .btn-row{justify-content:center;margin-bottom:.4rem}
.hero-trust--light{justify-content:center;margin-top:1.8rem}
.hero-trust--light li{color:#fff;font-size:.96rem}
.hero-trust--light svg{color:var(--green-bright)}
.hero-scroll{
  position:absolute;left:50%;bottom:24px;transform:translateX(-50%);
  width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  color:#fff;border:1.5px solid rgba(255,255,255,.4);background:rgba(255,255,255,.06);
  backdrop-filter:blur(4px);animation:scrollBob 2.2s var(--ease) infinite;transition:background .25s,border-color .25s;
}
.hero-scroll:hover{background:var(--green);border-color:var(--green)}
.hero-scroll svg{width:22px;height:22px}
@keyframes scrollBob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}
@media (prefers-reduced-motion:reduce){.hero-full__card,.hero-scroll{animation:none}}

/* ----------------------- Trust strip ----------------------- */
.trustbar{background:var(--white);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trustbar__inner{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding-block:2.2rem}
.trust-item{display:flex;gap:.9rem;align-items:flex-start}
.trust-item .ic{width:48px;height:48px;flex:none;border-radius:14px;background:var(--green-tint);color:var(--green-deep);display:grid;place-items:center}
.trust-item .ic svg{width:24px;height:24px}
.trust-item h4{font-size:1.02rem;margin-bottom:.15rem}
.trust-item p{font-size:.9rem;color:var(--muted);line-height:1.45}

/* ----------------------- Services ----------------------- */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(1.2rem,2.5vw,2rem);margin-top:3rem}
.service-card{
  position:relative;background:#fff;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s;
  display:flex;flex-direction:column;
}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md);border-color:var(--green-tint-2)}
.service-card__media{position:relative;aspect-ratio:13/10;overflow:hidden}
.service-card__media img{width:100%;height:100%;object-fit:cover;object-position:center 28%;transition:transform .6s var(--ease)}
.service-card:hover .service-card__media img{transform:scale(1.06)}
.service-card__num{
  position:absolute;top:14px;left:14px;background:rgba(42,45,44,.78);color:#fff;
  font-family:var(--ff-head);font-weight:700;font-size:.8rem;letter-spacing:.05em;
  padding:.35rem .7rem;border-radius:999px;backdrop-filter:blur(4px);
}
.service-card__body{padding:1.6rem 1.6rem 1.8rem;display:flex;flex-direction:column;flex:1}
.service-card__body h3{margin-bottom:.6rem}
.service-card__body p{color:var(--muted);font-size:.98rem;margin-bottom:1.2rem}
.service-card__tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:1.3rem}
.service-card__tags span{font-size:.78rem;font-weight:600;color:var(--green-deep);background:var(--green-tint);padding:.3rem .65rem;border-radius:999px}
.service-card__link{margin-top:auto;display:inline-flex;align-items:center;gap:.5rem;font-family:var(--ff-head);font-weight:700;color:var(--green-deep)}
.service-card__link svg{width:1.1em;height:1.1em;transition:transform .25s}
.service-card:hover .service-card__link svg{transform:translateX(4px)}

/* ----------------------- Dark feature band ----------------------- */
.darkband{background:var(--anthracite);color:#fff;position:relative;overflow:hidden}
.darkband::before{content:"";position:absolute;inset:0;background:
  radial-gradient(60% 80% at 85% 10%,rgba(154,208,35,.16),transparent 60%),
  radial-gradient(50% 70% at 5% 95%,rgba(111,168,44,.12),transparent 60%);}
.darkband .container{position:relative}
.darkband h2,.darkband h3{color:#fff}
.darkband .lead{color:#C9CEC3}
.why-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:center}
.why-features{display:grid;gap:1.1rem;margin-top:2rem}
.why-feature{display:flex;gap:1rem;padding:1.2rem 1.3rem;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);transition:.3s}
.why-feature:hover{background:rgba(255,255,255,.07);border-color:rgba(154,208,35,.3)}
.why-feature .ic{width:46px;height:46px;flex:none;border-radius:12px;background:rgba(154,208,35,.16);color:var(--green-bright);display:grid;place-items:center}
.why-feature .ic svg{width:23px;height:23px}
.why-feature h4{color:#fff;font-size:1.08rem;margin-bottom:.2rem}
.why-feature p{color:#B7BDB0;font-size:.92rem;line-height:1.5}
.why-media img{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;object-fit:cover;aspect-ratio:13/12;object-position:center 28%}
.stat-row{display:flex;flex-wrap:wrap;gap:2.4rem;margin-top:2.4rem}
.stat .n{font-family:var(--ff-head);font-weight:800;font-size:2.6rem;color:var(--green-bright);line-height:1}
.stat .l{color:#B7BDB0;font-size:.9rem;margin-top:.3rem}

/* ----------------------- Vorstellung Stani ----------------------- */
.intro-stani{background:linear-gradient(180deg,var(--cream) 0%,#EEEDE4 100%)}
.intro-stani__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.intro-stani h2{font-size:clamp(2rem,4.2vw,3.1rem);margin-bottom:1.1rem}
.intro-stani h2 .text-green{color:var(--green-deep)}
.intro-stani__lead{font-size:clamp(1.08rem,1.6vw,1.3rem);color:var(--ink);font-weight:500;margin-bottom:1rem;line-height:1.55}
.intro-stani__text p{color:var(--muted);margin-bottom:1rem}
.intro-stani__actions{display:flex;align-items:center;gap:1.6rem 2rem;margin-top:2rem;flex-wrap:wrap}
.scroll-cue{display:inline-flex;align-items:center;gap:.9rem;font-family:var(--ff-head);font-weight:700;color:var(--ink)}
.scroll-cue__arrow{flex:none;width:50px;height:50px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;box-shadow:var(--shadow-green);animation:scrollBob2 2s var(--ease) infinite;transition:background .25s}
.scroll-cue__arrow svg{width:23px;height:23px}
.scroll-cue:hover .scroll-cue__arrow{background:var(--green-deep)}
.scroll-cue__label{font-size:1.08rem}
@keyframes scrollBob2{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}
.text-link{display:inline-flex;align-items:center;gap:.35rem;font-family:var(--ff-head);font-weight:600;font-size:.95rem;color:var(--muted);border-bottom:1px solid transparent;padding-bottom:1px;transition:color .2s,border-color .2s}
.text-link svg{width:1em;height:1em;transition:transform .25s var(--ease)}
.text-link:hover{color:var(--green-deep);border-color:var(--green)}
.text-link:hover svg{transform:translateX(3px)}
@media (prefers-reduced-motion:reduce){.scroll-cue__arrow{animation:none}}

/* ----------------------- Leistungen-Verteiler (Vollbild + Liquid Glass) ----------------------- */
.leistungen-hub{position:relative;min-height:calc(100vh - 78px);min-height:calc(100svh - 78px);display:grid;place-items:center;overflow:hidden;background:var(--anthracite-2);padding-block:clamp(1.6rem,4vh,3.2rem)}
.leistungen-hub__bg{position:absolute;inset:0;z-index:0}
.leistungen-hub__bg img{width:100%;height:100%;object-fit:cover}
.leistungen-hub__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,22,21,.78) 0%,rgba(20,22,21,.90) 100%)}
.leistungen-hub .container{position:relative;z-index:1;width:100%}
.leistungen-hub .section-head{margin-bottom:0}
.leistungen-hub h1{color:#fff;font-size:clamp(1.9rem,3.6vw,2.8rem)}
.leistungen-hub .section-head p{margin-top:.7rem}
.leistungen-hub .lead{color:#C9CEC3}
.hub-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(.9rem,1.6vw,1.3rem);max-width:880px;margin:clamp(1.6rem,3.2vh,2.4rem) auto 0}
.glass-card{position:relative;display:flex;flex-direction:column;gap:.35rem;padding:clamp(1.3rem,2.2vw,1.8rem);border-radius:var(--radius-lg);background:rgba(255,255,255,.07);backdrop-filter:blur(18px) saturate(150%);-webkit-backdrop-filter:blur(18px) saturate(150%);border:1px solid rgba(255,255,255,.16);box-shadow:0 24px 50px -22px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.20);overflow:hidden;transition:transform .35s var(--ease),background .35s,border-color .35s}
.glass-card::before{content:"";position:absolute;inset:0;background:linear-gradient(125deg,rgba(255,255,255,.17),transparent 42%);pointer-events:none}
.glass-card:hover{transform:translateY(-7px);background:rgba(255,255,255,.12);border-color:rgba(154,208,35,.55)}
.glass-card__num{position:absolute;top:.9rem;right:1.1rem;font-family:var(--ff-head);font-weight:800;font-size:.9rem;color:rgba(255,255,255,.28)}
.glass-card__ic{width:48px;height:48px;border-radius:14px;background:rgba(154,208,35,.18);color:var(--green-bright);display:grid;place-items:center;margin-bottom:.3rem;position:relative}
.glass-card__ic svg{width:24px;height:24px}
.glass-card h3{color:#fff;font-size:clamp(1.15rem,1.7vw,1.4rem);position:relative}
.glass-card p{color:#CBD0C5;font-size:.92rem;line-height:1.45;flex:1;position:relative}
.glass-card__link{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--ff-head);font-weight:700;font-size:.95rem;color:var(--green-bright);margin-top:.45rem;position:relative}
.glass-card__link svg{width:1.1em;height:1.1em;transition:transform .25s var(--ease)}
.glass-card:hover .glass-card__link svg{transform:translateX(4px)}
.hub-cta{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap;margin-top:clamp(1.6rem,3.2vh,2.4rem)}
.stani-frame{position:relative;max-width:500px;margin-inline:auto;aspect-ratio:9/10;border-radius:var(--radius-xl);overflow:hidden;background:#bcd2a6 url("../images/vorstellung-bg.jpg") center/cover;box-shadow:var(--shadow-lg);transition:box-shadow .4s var(--ease),transform .4s var(--ease)}
.stani-frame::before{content:"";position:absolute;inset:0;background:radial-gradient(62% 52% at 50% 28%,rgba(154,208,35,.20),transparent 72%);z-index:0}
.stani-frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 48%,rgba(42,45,44,.32) 100%);z-index:1}
.stani-frame:hover{box-shadow:0 55px 95px -35px rgba(33,36,31,.55);transform:translateY(-5px)}
.stani-frame__cut{position:absolute;left:50%;bottom:0;transform:translateX(-50%);height:95%;width:auto;max-width:none;object-fit:contain;object-position:bottom center;z-index:2;filter:drop-shadow(0 16px 26px rgba(0,0,0,.34))}
.stani-frame__badge{position:absolute;z-index:3;left:16px;bottom:16px;display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.94);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.6);border-radius:999px;padding:.55rem 1rem;font-family:var(--ff-head);font-weight:700;font-size:.92rem;color:var(--ink);box-shadow:var(--shadow-md)}
.stani-frame__badge svg{width:1.1rem;height:1.1rem;color:var(--green-deep)}
/* Pfeil am CTA: gleitet beim Hover nach rechts (kein Dauerwippen) */
.arrow-anim{display:inline-grid;place-items:center}
.arrow-anim svg{width:1.15em;height:1.15em;transition:transform .25s var(--ease)}
.btn:hover .arrow-anim svg{transform:translateX(5px)}

/* ----------------------- Process ----------------------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;margin-top:3rem;counter-reset:step}
.step{position:relative;padding:1.8rem 1.5rem;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}
.step::before{
  counter-increment:step;content:counter(step,decimal-leading-zero);
  font-family:var(--ff-head);font-weight:800;font-size:1.05rem;color:#fff;
  width:44px;height:44px;border-radius:50%;background:var(--green);display:grid;place-items:center;
  margin-bottom:1.1rem;box-shadow:var(--shadow-green);
}
.step h4{font-size:1.12rem;margin-bottom:.45rem}
.step p{color:var(--muted);font-size:.93rem}

/* ----------------------- Testimonials ----------------------- */
.tst-wrap{margin-top:3rem}
.tst-grid{columns:3;column-gap:1.5rem}
.tst-card{
  break-inside:avoid;margin-bottom:1.5rem;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:1.7rem 1.6rem;box-shadow:var(--shadow-sm);
}
.tst-card .stars{display:flex;gap:.18rem;color:#F2B705;margin-bottom:.9rem}
.tst-card .stars svg{width:1.05rem;height:1.05rem}
.tst-card .quote-title{font-family:var(--ff-head);font-weight:800;font-size:1.1rem;margin-bottom:.6rem;color:var(--ink)}
.tst-card p{color:#4C514A;font-size:.97rem}
.tst-card .who{display:flex;align-items:center;gap:.75rem;margin-top:1.2rem;padding-top:1.1rem;border-top:1px solid var(--line)}
.tst-card .who .av{width:44px;height:44px;border-radius:50%;background:var(--green-tint);color:var(--green-deep);display:grid;place-items:center;font-family:var(--ff-head);font-weight:800;flex:none}
.tst-card .who b{display:block;font-size:.95rem}
.tst-card .who small{color:var(--muted);font-size:.82rem}

/* ----------------------- CTA band (Anthrazit-Wand) ----------------------- */
.cta-band{position:relative;color:#fff;border-radius:var(--radius-xl);overflow:hidden;margin-block:clamp(2rem,5vw,4rem)}
.cta-band__bg{position:absolute;inset:0;z-index:0}
.cta-band__bg img{width:100%;height:100%;object-fit:cover}
.cta-band__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(26,29,28,.92)0%,rgba(26,29,28,.7)45%,rgba(26,29,28,.45)100%)}
.cta-band__inner{position:relative;z-index:1;padding:clamp(2.5rem,5vw,4.5rem)}
.cta-band h2{color:#fff;max-width:18ch;margin-bottom:1rem}
.cta-band p{color:#D4D8CE;max-width:48ch;margin-bottom:2rem}
.cta-band .phone-big{display:inline-flex;align-items:center;gap:.7rem;font-family:var(--ff-head);font-weight:800;font-size:1.5rem;color:var(--green-bright);margin-top:.4rem}
.cta-band .phone-big svg{width:1.3rem;height:1.3rem}

/* Schmales CTA-Repeat */
.minicta{background:var(--green-tint);border-radius:var(--radius-xl);padding:clamp(2rem,4vw,3.2rem);display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.minicta h3{font-size:clamp(1.4rem,2.4vw,2rem);max-width:24ch}
.minicta p{color:var(--muted);margin-top:.4rem}

/* ----------------------- FAQ ----------------------- */
.faq{max-width:840px;margin:3rem auto 0}
.faq-item{border:1px solid var(--line);border-radius:var(--radius-md);background:#fff;margin-bottom:.9rem;overflow:hidden;transition:box-shadow .25s,border-color .25s}
.faq-item[open]{box-shadow:var(--shadow-sm);border-color:var(--green-tint-2)}
.faq-item summary{
  list-style:none;cursor:pointer;padding:1.25rem 1.4rem;display:flex;align-items:center;gap:1rem;
  font-family:var(--ff-head);font-weight:700;font-size:1.05rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary .pm{margin-left:auto;width:30px;height:30px;flex:none;border-radius:50%;background:var(--green-tint);color:var(--green-deep);display:grid;place-items:center;transition:.3s}
.faq-item[open] summary .pm{background:var(--green);color:#fff;transform:rotate(45deg)}
.faq-item .faq-body{padding:0 1.4rem 1.4rem;color:var(--muted)}

/* ----------------------- Page hero (Unterseiten) ----------------------- */
.page-hero{background:var(--anthracite);color:#fff;position:relative;overflow:hidden;padding-top:clamp(2.5rem,5vw,4rem)}
.page-hero::before{content:"";position:absolute;inset:0;background:
  radial-gradient(50% 70% at 90% 0%,rgba(154,208,35,.16),transparent 60%);}
.page-hero .container{position:relative}
.breadcrumb{display:flex;gap:.5rem;align-items:center;font-size:.86rem;color:#9FA59A;margin-bottom:1.3rem;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--green-bright)}
.breadcrumb .sep{opacity:.5}
.page-hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(1.5rem,3vw,3rem);align-items:center;padding-bottom:clamp(2.5rem,5vw,4rem)}
.page-hero h1{color:#fff;margin-bottom:1.1rem}
.page-hero .lead{color:#C9CEC3}
.page-hero__media img{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;object-fit:cover;aspect-ratio:13/10;object-position:center 30%}
.page-hero .btn-row{margin-top:2rem}

/* ----------------------- Content / Prose ----------------------- */
.prose{max-width:760px}
.prose.wide{max-width:900px}
.prose h2{margin:2.5rem 0 1rem}
.prose h3{margin:2rem 0 .8rem;font-size:1.3rem}
.prose p{margin-bottom:1.1rem;color:#41463E}
.prose ul.check{display:grid;gap:.7rem;margin:1.3rem 0}
.prose ul.check li{position:relative;padding-left:2.1rem;color:#41463E}
.prose ul.check li::before{content:"";position:absolute;left:0;top:2px;width:22px;height:22px;border-radius:50%;background:var(--green-tint);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23517E1C' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:13px}

.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center}
.split--reverse .split__media{order:2}
.split__media img{border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;object-fit:cover;aspect-ratio:11/8.5;object-position:center 28%}
.split__media.tall img{aspect-ratio:4/4.6}

/* Leistungs-Detailliste */
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.6rem}
.detail-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.6rem 1.5rem;box-shadow:var(--shadow-sm);transition:.3s}
.detail-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.detail-card .ic{width:50px;height:50px;border-radius:14px;background:var(--green-tint);color:var(--green-deep);display:grid;place-items:center;margin-bottom:1.1rem}
.detail-card .ic svg{width:25px;height:25px}
.detail-card h3{font-size:1.15rem;margin-bottom:.5rem}
.detail-card p{color:var(--muted);font-size:.94rem}

/* Preis/Hinweis-Box */
.note-box{background:var(--green-tint);border:1px solid var(--green-tint-2);border-left:4px solid var(--green);border-radius:var(--radius-md);padding:1.4rem 1.5rem;margin:2rem 0}
.note-box h4{color:var(--green-deep);margin-bottom:.4rem}
.note-box p{color:#41463E;margin:0;font-size:.97rem}
/* Ausfüll-Platzhalter in Rechtstexten */
.ph{background:#FFF4D6;border:1px dashed #E0B500;border-radius:6px;padding:1px 8px;font-weight:600;color:#8A6A00}

/* Side card (Leistungs-Sidebar) */
.layout-2col{display:grid;grid-template-columns:1fr 340px;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.sidecard{background:var(--anthracite);color:#fff;border-radius:var(--radius-lg);padding:1.8rem;box-shadow:var(--shadow-md)}
.sidecard h3{color:#fff;font-size:1.3rem;margin-bottom:.6rem}
.sidecard p{color:#C2C7BC;font-size:.93rem;margin-bottom:1.3rem}
.sidecard .phone-big{display:flex;align-items:center;gap:.6rem;color:var(--green-bright);font-family:var(--ff-head);font-weight:800;font-size:1.3rem;margin:1.2rem 0}
.sidecard .phone-big svg{width:1.2rem;height:1.2rem}
.sidecard ul{display:grid;gap:.6rem;margin-top:1.3rem;padding-top:1.3rem;border-top:1px solid var(--line-dark)}
.sidecard ul li{display:flex;gap:.6rem;align-items:center;font-size:.9rem;color:#D4D8CE}
.sidecard ul li svg{width:1.05rem;height:1.05rem;color:var(--green-bright);flex:none}
.other-services{margin-top:2.5rem}
.other-services a{display:flex;align-items:center;justify-content:space-between;padding:.95rem 1.1rem;border:1px solid var(--line);border-radius:var(--radius-md);background:#fff;margin-bottom:.6rem;font-family:var(--ff-head);font-weight:600;transition:.25s}
.other-services a:hover{border-color:var(--green);color:var(--green-deep);transform:translateX(4px)}
.other-services a svg{width:1.1rem;height:1.1rem;color:var(--green)}

/* ----------------------- Galerie ----------------------- */
.gallery-filter{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:2.4rem}
.gallery-filter button{padding:.6rem 1.2rem;border-radius:999px;border:1.5px solid var(--line);font-family:var(--ff-head);font-weight:600;font-size:.9rem;transition:.25s;background:#fff}
.gallery-filter button:hover{border-color:var(--green)}
.gallery-filter button.active{background:var(--green);border-color:var(--green);color:#fff}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-top:2.4rem}
.gallery-item{position:relative;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;aspect-ratio:1;box-shadow:var(--shadow-sm)}
.gallery-item img{width:100%;height:100%;object-fit:cover;object-position:center 30%;transition:transform .55s var(--ease)}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item .ov{position:absolute;inset:0;background:linear-gradient(0deg,rgba(26,29,28,.78),transparent 55%);opacity:0;transition:.3s;display:flex;align-items:flex-end;padding:1.1rem}
.gallery-item:hover .ov{opacity:1}
.gallery-item .ov span{color:#fff;font-family:var(--ff-head);font-weight:700;font-size:.95rem}
.gallery-item .ov .cat{color:var(--green-bright);font-size:.78rem;display:block;text-transform:uppercase;letter-spacing:.08em}

/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:120;background:rgba(18,20,19,.92);display:none;align-items:center;justify-content:center;padding:2rem}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:84vh;border-radius:var(--radius-md);box-shadow:var(--shadow-lg)}
.lightbox__close,.lightbox__nav{position:absolute;background:rgba(255,255,255,.12);color:#fff;width:52px;height:52px;border-radius:50%;display:grid;place-items:center;transition:.25s}
.lightbox__close:hover,.lightbox__nav:hover{background:var(--green)}
.lightbox__close{top:1.5rem;right:1.5rem}
.lightbox__nav svg{width:24px;height:24px}
.lightbox__prev{left:1.5rem;top:50%;transform:translateY(-50%)}
.lightbox__next{right:1.5rem;top:50%;transform:translateY(-50%)}

/* ----------------------- Über mich ----------------------- */
.about-hero img{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;aspect-ratio:4/4.7;object-fit:cover}
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:3rem}
.value{padding:1.7rem 1.5rem;border-radius:var(--radius-lg);background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.value .ic{width:48px;height:48px;border-radius:14px;background:var(--green-tint);color:var(--green-deep);display:grid;place-items:center;margin-bottom:1rem}
.value h3{font-size:1.15rem;margin-bottom:.4rem}
.value p{color:var(--muted);font-size:.94rem}
.timeline{margin-top:3rem;display:grid;gap:0;position:relative;padding-left:2rem}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--green-tint-2)}
.tl-item{position:relative;padding:0 0 2rem 1.6rem}
.tl-item::before{content:"";position:absolute;left:-2rem;top:4px;width:16px;height:16px;border-radius:50%;background:var(--green);border:3px solid var(--cream);box-shadow:0 0 0 2px var(--green-tint-2)}
.tl-item h4{font-size:1.1rem}
.tl-item .yr{font-family:var(--ff-head);font-weight:700;color:var(--green-deep);font-size:.9rem;margin-bottom:.2rem}
.tl-item p{color:var(--muted);font-size:.94rem;margin-top:.2rem}
/* Timeline auf dunklem Hintergrund ("Mein Weg") gut lesbar machen */
.darkband .timeline::before{background:rgba(255,255,255,.16)}
.darkband .tl-item::before{border-color:var(--anthracite);box-shadow:0 0 0 2px rgba(154,208,35,.5)}
.darkband .tl-item h4{color:#fff}
.darkband .tl-item .yr{color:var(--green-bright)}
.darkband .tl-item p{color:#C8CDC2}

/* ----------------------- Kontakt ----------------------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.8rem,4vw,3.5rem);align-items:start}
.contact-cards{display:grid;gap:1rem}
.contact-card{display:flex;gap:1rem;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.4rem 1.5rem;box-shadow:var(--shadow-sm);transition:.25s}
.contact-card:hover{border-color:var(--green-tint-2);transform:translateY(-3px)}
.contact-card .ic{width:48px;height:48px;flex:none;border-radius:14px;background:var(--green-tint);color:var(--green-deep);display:grid;place-items:center}
.contact-card h4{font-size:1.05rem;margin-bottom:.15rem}
.contact-card a,.contact-card p{color:var(--muted);font-size:.97rem}
.contact-card a:hover{color:var(--green-deep)}
.contact-map{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);margin-top:1rem}
.contact-map img,.contact-map iframe{width:100%;display:block;border:0;aspect-ratio:3/2}
/* Google-Maps Einwilligung (lädt erst nach Klick) */
.map-consent{position:relative;width:100%;aspect-ratio:3/2;background:var(--anthracite);display:grid;place-items:center;text-align:center;overflow:hidden}
.map-consent::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 90% at 50% 0,rgba(154,208,35,.16),transparent 60%)}
.map-consent__inner{position:relative;padding:clamp(1.4rem,4vw,2.2rem);max-width:440px}
.map-consent__ic{width:54px;height:54px;border-radius:16px;background:rgba(154,208,35,.16);color:var(--green-bright);display:grid;place-items:center;margin:0 auto 1rem}
.map-consent__ic svg{width:26px;height:26px}
.map-consent h4{color:#fff;font-size:1.15rem;margin-bottom:.4rem}
.map-consent p{color:#C2C7BC;font-size:.88rem;line-height:1.55;margin-bottom:1.3rem}
.map-consent__remember{display:flex;gap:.5rem;align-items:center;justify-content:center;font-size:.8rem;color:var(--muted-light);margin-top:1rem;cursor:pointer}
.map-consent__remember input{width:auto;accent-color:var(--green)}

/* ----------------------- Formular (inline + Modal) ----------------------- */
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.6rem,3vw,2.4rem);box-shadow:var(--shadow-md)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1rem;display:flex;flex-direction:column;gap:.4rem}
.field label{font-family:var(--ff-head);font-weight:600;font-size:.9rem;color:var(--ink)}
.field label .req{color:var(--green-deep)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:1rem;padding:.85rem 1rem;border:1.5px solid var(--line);
  border-radius:var(--radius-sm);background:var(--cream);color:var(--ink);transition:.2s;width:100%;
}
.field textarea{resize:vertical;min-height:120px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);background:#fff;box-shadow:0 0 0 4px rgba(111,168,44,.12)}
.field--check{flex-direction:row;align-items:flex-start;gap:.7rem}
.field--check input{width:auto;margin-top:.25rem}
.field--check label{font-weight:400;color:var(--muted);font-size:.86rem;line-height:1.5}
.form-note{font-size:.82rem;color:var(--muted-light);margin-top:.6rem;text-align:center}
.form-msg{display:none;padding:1rem 1.2rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.95rem}
.form-msg.ok{display:block;background:var(--green-tint);color:var(--green-deep);border:1px solid var(--green-tint-2)}
.form-msg.err{display:block;background:#FDECEC;color:#B42318;border:1px solid #F8C9C4}
/* honeypot */
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ----------------------- Modal ----------------------- */
.modal{position:fixed;inset:0;z-index:200;display:none;align-items:flex-start;justify-content:center;padding:clamp(1rem,4vh,3rem) 1rem;overflow-y:auto}
.modal.open{display:flex}
.modal__overlay{position:fixed;inset:0;background:rgba(20,22,21,.6);backdrop-filter:blur(4px);animation:fade .3s}
.modal__dialog{position:relative;z-index:1;width:100%;max-width:600px;background:var(--cream);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;animation:pop .35s var(--ease)}
.modal__head{background:var(--anthracite);color:#fff;padding:1.7rem 1.8rem;position:relative;overflow:hidden}
.modal__head::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 100% at 90% 0,rgba(154,208,35,.22),transparent 60%)}
.modal__head .eyebrow{position:relative}
.modal__head h3{position:relative;color:#fff;font-size:1.5rem}
.modal__head p{position:relative;color:#C9CEC3;font-size:.93rem;margin-top:.3rem}
.modal__close{position:absolute;top:1.1rem;right:1.1rem;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;display:grid;place-items:center;transition:.25s;z-index:2}
.modal__close:hover{background:var(--green);transform:rotate(90deg)}
.modal__body{padding:clamp(1.4rem,3vw,2rem)}
.modal__alt{text-align:center;margin-top:1rem;font-size:.92rem;color:var(--muted)}
.modal__alt a{color:var(--green-deep);font-weight:700}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:none}}
body.modal-open{overflow:hidden}

/* ----------------------- Footer ----------------------- */
.site-footer{background:var(--anthracite-2);color:#C2C7BC;padding-top:clamp(3rem,6vw,5rem)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:2.5rem;padding-bottom:3rem}
.site-footer .f-logo{margin-bottom:1.1rem}
.site-footer .f-logo img{height:48px;filter:brightness(0) invert(1);opacity:.95}
.site-footer p{font-size:.93rem;line-height:1.6;max-width:34ch}
.footer-col h4{color:#fff;font-size:1rem;margin-bottom:1.1rem}
.footer-col ul{display:grid;gap:.6rem}
.footer-col a{font-size:.93rem;transition:.2s}
.footer-col a:hover{color:var(--green-bright)}
.footer-contact li{display:flex;gap:.65rem;align-items:flex-start;font-size:.93rem;margin-bottom:.7rem}
.footer-contact svg{width:1.1rem;height:1.1rem;color:var(--green-bright);flex:none;margin-top:.2rem}
.footer-social{display:flex;gap:.6rem;margin-top:1.3rem}
.footer-social a{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.07);display:grid;place-items:center;transition:.25s}
.footer-social a:hover{background:var(--green);transform:translateY(-3px)}
.footer-social svg{width:18px;height:18px;color:#fff}
.footer-bottom{border-top:1px solid var(--line-dark);padding-block:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:var(--muted-light)}
.footer-bottom a:hover{color:var(--green-bright)}

/* ----------------------- Floating call (mobile) ----------------------- */
.floating-call{position:fixed;right:16px;bottom:16px;z-index:55;display:none;gap:.7rem}
.floating-call a,.floating-call button{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow-md);color:#fff;padding:0;cursor:pointer}
.floating-call .fc-phone{background:var(--green)}
.floating-call .fc-mail{background:var(--anthracite)}
.floating-call svg{width:24px;height:24px}

/* ----------------------- Reveal animation ----------------------- */
/* Inhalt ist standardmäßig sichtbar; nur mit aktivem JS (html.js) wird animiert.
   So bleibt die Seite auch ohne/bei langsamem JavaScript voll lesbar. */
.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}*{scroll-behavior:auto!important}}

/* ----------------------- Responsive ----------------------- */
@media (max-width:1040px){
  .nav__links,.nav__phone span{display:none}
  .nav__cta .btn{display:none}
  .burger{display:flex}
  .floating-call{display:flex;flex-direction:column}
  .footer-grid{grid-template-columns:1fr 1fr}
  .trustbar__inner{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .detail-grid{grid-template-columns:1fr 1fr}
  .tst-grid{columns:2}
}
@media (max-width:860px){
  .hero__grid,.why-grid,.split,.page-hero__grid,.contact-grid,.layout-2col,.intro-stani__grid{grid-template-columns:1fr}
  /* Hero-Bild auf Mobile auf die rechte Seite (Garten/Berge) fokussieren, kein halber Stani */
  .hero-full__bg img{object-position:right center}
  .intro-stani__visual{order:-1}
  .stani-frame{max-width:380px}
  .split--reverse .split__media{order:0}
  .hero__media img{aspect-ratio:16/12}
  .services-grid{grid-template-columns:1fr}
  .values{grid-template-columns:1fr}
  .sidecard{position:static}
  .why-media{order:-1}
}
@media (max-width:620px){
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .trustbar__inner,.detail-grid,.hub-grid{grid-template-columns:1fr}
  .tst-grid{columns:1}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .step{padding:1.4rem 1.2rem}
  .minicta{flex-direction:column;align-items:flex-start}
  .hero__badge{left:0}
  .footer-bottom{flex-direction:column;text-align:center}
}
