/* =========================
   Basis / Tokens & Reset
   ========================= */
:root{
  --clr-bg:#ffffff;
  --clr-text:#202427;
  --clr-muted:#5b666e;
  --clr-border:#e8ebed;
  --brand-green:#afc974;
  --brand-green-1:#5a854d;
  --brand-green-2:#444e43;
  --container:1100px;
  --radius:16px;
  --ease:cubic-bezier(.2,.7,0,1);
  --underline:2px;
  --safe-top: env(safe-area-inset-top);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:64px}
body{margin:0;font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;background:var(--clr-bg);color:var(--brand-green-2)}
img{max-width:100%;height:auto;display:block}
h1,h2,h3{line-height:1.15;margin:0 0 .5rem}
p{margin:.25rem 0 .75rem}
a{color:inherit;text-decoration:none}
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
:focus-visible{outline:3px solid color-mix(in srgb, var(--brand-green) 55%, transparent);outline-offset:3px}

/* =========================
   Layout Helpers
   ========================= */
.container{width:min(100%,var(--container));margin-inline:auto;padding:clamp(8px,2vw,12px)}
.section{padding:3rem 0}
.section-title{font-size:clamp(28px,4vw,40px);letter-spacing:-.01em;color:var(--brand-green-2)}
.subtitle{color:var(--brand-green);font-weight:600;opacity:.9;margin-top:.25rem}
.muted{color:var(--brand-green-1)}
.on-green{background:var(--brand-green);color:var(--brand-green-2)}
.deko{max-width:90px; transform: translateX(-40px);}
.grid{display:grid;gap:clamp(16px,3vw,32px)}
.grid--2{grid-template-columns:1.1fr .9fr}
.grid--3{grid-template-columns:repeat(3,1fr)}
.align-center{align-items:center}
@media (max-width:1024px){.grid--2,.grid--3{grid-template-columns:1fr}}
section[id]{scroll-margin-top:74px}

/* =========================
   Header & Navigation
   ========================= */
.site-header{position:sticky;top:0;z-index:50;background:#fff;border-bottom:1px solid var(--clr-border)}
.site-header__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:64px}
.logo{display:flex;flex-direction:column;line-height:1}
.logo_img{max-width:clamp(160px,38vw,300px);height:auto}
.nav{display:flex;gap:22px;align-items:center}
.nav a{position:relative;padding:12px 2px 10px;font-weight:700;color:var(--brand-green-1);transition:font-weight .15s var(--ease)}
.nav a::after{content:"";position:absolute;left:0;right:0;bottom:2px;height:var(--underline);background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);border-radius:var(--underline)}
.nav a:hover::after{transform:scaleX(1)}
.nav a.is-active{font-weight:800}
.nav a.is-active::after{transform:scaleX(1)}
.nav-toggle{display:none;background:transparent;border:0;width:44px;height:44px;border-radius:8px}
.nav-toggle:focus-visible{outline:2px solid var(--brand-green)}
.burger{width:20px;height:2px;background:var(--brand-green);position:relative;display:block;margin:auto}
.burger::before,.burger::after{content:"";position:absolute;left:0;right:0;height:2px;background:var(--brand-green)}
.burger::before{top:-6px}.burger::after{top:6px}
@media (max-width:880px){
  .site-header__inner{padding-inline:12px}
  .nav-toggle{display:inline-grid;place-content:center}
  .nav{display:none;flex-direction:column;align-items:flex-start;background:#fff;position:fixed;inset:calc(64px + var(--safe-top,0px)) 0 auto 0;border-bottom:1px solid var(--clr-border);padding:8px 0;z-index:100}
  .nav[aria-expanded="true"]{display:flex}
  .nav a{padding:14px 16px;line-height:1.2;border-bottom:1px solid color-mix(in srgb, var(--clr-border) 80%, transparent)}
  .nav a:last-child{border-bottom:0}
  .nav a::after{bottom:6px}
}

/* =========================
   Intro
   ========================= */
.intro{position:relative;isolation:isolate;background:#fff}
.intro h2{font-size:clamp(28px,4vw,36px);color:var(--brand-green-2)}
.intro p{color:var(--clr-text)}

/* gleich breite Medien-Spalte rechts */
.intro-media{
  position:relative;

  width:100%;
  max-inline-size:320px;       /* gemeinsame Breite */
}
.portrait{
  display:block;
  width:100%;
  height:auto;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  border-radius:16px;
}

/* grüner Versatz-Hintergrund hinter dem Portrait */
.accent-box{
  position:absolute;
  top:+8%;
  right:-8%;                   /* bewusst versetzt nach rechts */
  width:320px;
  height: 320px;
  background:var(--brand-green-1);
  z-index:-1;
  border-radius:0;
  box-shadow:none;
  border-radius:16px;
}

@media (max-width:900px){
  .intro-media{max-inline-size:none;}
  .accent-box{top:-6%;right:-4%;width:clamp(200px,52vw,360px);height:clamp(150px,56vw,200px)}
}
@media (max-width:640px){
  .accent-box{top:-2%;right:-2%;width:clamp(160px,48vw,320px);height:clamp(140px,52vw,260px)}
}


/* =========================
   Dresden / Bildkarte & Banner
   ========================= */
/* Dresden-Bild nicht nach rechts schieben */
#dresden .image-card{
  justify-self: start;        /* links in der Spalte */
  margin-inline: 0;           /* kein Auto-Margin */
  width: 100%;                /* volle Spaltenbreite */
  max-inline-size: none;      /* keine künstliche Begrenzung */
}
#dresden .image-card img{
  display:block;
  width:100%;
  height:auto;
  object-fit:cover;
   border-radius:16px;
}

/* Optional: gleiche Spaltenbreite wie Text, falls vorher 1.1fr/.9fr aktiv ist */
#dresden .grid--2{
  grid-template-columns: 1fr 1fr;
}


.banner{width:100%;overflow:hidden}
.banner img{
  display:block;width:100%;height:auto;
  aspect-ratio:21/9;object-fit:cover;object-position:center;
  max-height:clamp(160px,28vw,320px)
}

@media (max-width:900px){
  .image-card{max-inline-size:none;}
}


/* =========================
   Badge
   ========================= */
.badge{display:inline-block;margin-top:14px;padding:8px 12px;border:2px solid currentColor;border-radius:999px;font-weight:700}

/* =========================
   Reveal (für #kpi-details)
   ========================= */
.reveal{overflow:hidden;max-height:0;opacity:0;transition:max-height .45s var(--ease),opacity .3s var(--ease)}
.reveal.open{opacity:1}
.reveal__inner{padding:12px 2px 2px;color:var(--clr-muted)}
.reveal hr{border:none;border-top:1px solid var(--clr-border);margin:10px 0}

/* =========================
   KPI-Karten
   ========================= */
.ml-kpi{margin-inline:auto}
.ml-kpi__head{display:flex;align-items:flex-end;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.ml-kpi__head h2{margin:0 0 .15rem;font-weight:800;letter-spacing:-.01em;color:var(--brand-green-2);font-size:clamp(22px,3vw,28px)}
.ml-kpi__grid{display:grid;gap:16px;grid-template-columns:repeat(5,minmax(0,1fr));padding-bottom: 2rem;}
@media (max-width:1100px){.ml-kpi__grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:640px){.ml-kpi__grid{grid-template-columns:1fr}}
.ml-kpi__card{display:grid;grid-template-rows:auto auto;gap:14px;border:1.5px solid var(--clr-border);border-radius:var(--radius);background:#fff;box-shadow:0 10px 30px rgba(0,0,0,.06);padding:16px}
.ml-kpi__meta{display:grid;gap:6px;align-content:start;min-height:112px}
.ml-kpi__value{font-weight:900;letter-spacing:-.02em;color:var(--brand-green-1);font-variant-numeric:tabular-nums;font-size:clamp(26px,4.2vw,42px);line-height:1.1}
.ml-kpi__label{color:var(--brand-green-2)}
.ml-kpi__chart{display:grid;gap:6px;align-content:start}
.ml-kpi__spark{width:100%;height:48px;display:block}
.ml-kpi__src{margin:0;color:var(--clr-muted);font-size:12px}

/* Mobile: Karten nebeneinander mit Seitenscroll */
@media (max-width:700px){
  .ml-kpi__grid{display:flex;overflow-x:auto;gap:12px;padding:6px 12px 12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
  .ml-kpi__grid>.ml-kpi__card{flex:0 0 85%;min-width:0;scroll-snap-align:start}
  .ml-kpi__value{font-size:clamp(22px,7.5vw,34px)}
}

/* Hintergrund für Zahlen & Fakten */
.ml-kpi.section {
  background: var(--brand-green); /* dein Dunkelgrün */
  color: #fff;                      /* Text lesbar machen */
}

/* Karten anpassen, damit sie sich abheben */
.ml-kpi__card {
  background: #fff;
  color: var(--brand-green-2);
}


/* =========================
   Angebot (Variante 3)
   ========================= */
.ml-offer3{color:var(--brand-green-2)}
.ml-offer3__container{width:min(100%,var(--container));margin-inline:auto;padding:clamp(16px,2.5vw,24px)}
.ml-offer3__title{margin:0 0 clamp(10px,2vw,18px);font-size:clamp(28px,4vw,40px);letter-spacing:-.01em}
.ml-offer3__row{display:grid;gap:clamp(16px,3vw,28px);grid-template-columns:minmax(260px,.96fr) 1.04fr;align-items:start;margin-bottom:clamp(14px,3.5vw,24px)}
.ml-offer3__row--reverse{grid-template-columns:1.04fr minmax(260px,.96fr)}
.ml-offer3__row--reverse .ml-offer3__media{order:2;justify-self:end}
.ml-offer3__row--reverse .ml-offer3__copy{order:1}
@media (max-width:900px){.ml-offer3__row,.ml-offer3__row--reverse{grid-template-columns:1fr}.ml-offer3__row--reverse .ml-offer3__media,.ml-offer3__row--reverse .ml-offer3__copy{order:initial;justify-self:initial}}
.ml-offer3__media{margin:0;inline-size:100%;max-inline-size:520px;justify-self:start;filter:drop-shadow(0 10px 24px rgba(0,0,0,.10));border-radius:18px;overflow:hidden}
.ml-offer3__media img{display:block;width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;object-position:center;border-radius:inherit}
.ml-offer3__copy{display:grid;gap:12px;align-content:start;max-width:60ch}
.ml-offer3__h3{margin:0;line-height:1.2;color:var(--brand-green-1);font-size:clamp(22px,3vw,28px);font-weight:800}
.ml-offer3__btn{justify-self:start;display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border:2px solid var(--brand-green-2);border-radius:10px;background:#fff;color:var(--brand-green-2);font-weight:800;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease}
.ml-offer3__btn:hover{transform:translateY(-1px);background:var(--brand-green);border-color:var(--brand-green);box-shadow:0 10px 24px rgba(0,0,0,.08)}

/* =========================
   Kontakt
   ========================= */
.ml-contact{--bg:var(--brand-green);--text:var(--brand-green-2);--muted:var(--brand-green-1);--border:var(--clr-border);--shadow:0 10px 30px rgba(0,0,0,.10);background:var(--bg);color:var(--text);padding:clamp(28px,6vw,56px) 0}
.ml-contact__container{width:min(100%,var(--container));margin-inline:auto;padding:clamp(16px,5vw,24px)}
.ml-contact__title{margin:0 0 .25rem;font-size:clamp(28px,4vw,40px);letter-spacing:-.01em}
.ml-contact__lead{margin:0 0 1rem}
.ml-contact__form{background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:clamp(16px,3vw,28px)}
.ml-contact__row{display:grid;gap:clamp(12px,2.5vw,18px);grid-template-columns:1fr 1fr}
@media (max-width:720px){.ml-contact__row{grid-template-columns:1fr}}
.ml-field{display:grid;gap:6px}
.ml-field label{font-weight:700;color:var(--muted)}
.ml-field input[type="text"],.ml-field input[type="email"],.ml-field input[type="tel"],.ml-field textarea,.ml-field select{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:14px 16px;background:#fff;color:var(--text);font:inherit;transition:border-color .2s ease,box-shadow .2s ease}
.ml-field textarea{resize:vertical;min-height:140px}
.ml-field input:focus,.ml-field textarea:focus,.ml-field select:focus{outline:none;border-color:var(--muted);box-shadow:0 0 0 4px color-mix(in srgb, var(--bg) 35%, transparent)}
.ml-field input[aria-invalid="true"],.ml-field textarea[aria-invalid="true"]{border-color:#b04141}
.ml-error{min-height:1.05em;color:#b04141;font-size:12px}
.ml-consent label{display:flex;gap:.3rem;align-items:flex-start;font-size:.95rem;line-height:1.4}
.ml-contact__actions{display:flex;align-items:center;gap:16px;margin-top:6px;flex-wrap:wrap}
.ml-contact__hint{margin:0;color:var(--muted);font-size:12px}
.ml-btn{position:relative;display:inline-flex;align-items:center;gap:.6rem;border:2px solid var(--text);color:var(--text);background:#fff;border-radius:999px;padding:.8rem 1.2rem;font-weight:900;cursor:pointer;transition:transform .15s ease,background .2s ease,border-color .2s ease,box-shadow .2s ease}
.ml-btn:hover{transform:translateY(-1px);background:var(--bg);border-color:var(--bg);box-shadow:0 10px 22px rgba(0,0,0,.08)}
.ml-btn[disabled]{opacity:.7;cursor:not-allowed}
.ml-btn__spinner{inline-size:1.05em;block-size:1.05em;border-radius:50%;border:2px solid color-mix(in srgb, var(--text) 30%, transparent);border-top-color:var(--text);display:none;animation:mlspin .9s linear infinite}
.ml-btn.sending .ml-btn__spinner{display:inline-block}
@keyframes mlspin{to{transform:rotate(360deg)}}
.ml-status{margin-top:10px;font-size:.95rem}
.ml-status.ok{color:#2a704f}
.ml-status.err{color:#b04141}
.ml-contact__hp{position:absolute;left:-10000px;opacity:0;height:0;width:0}

/* =========================
   Footer (aktuelle Variante)
   ========================= */
.ml-contact + .site-footer{margin-top:0}
.site-footer{--ft-bg:var(--brand-green-2);--ft-text:#fff;--ft-dim:color-mix(in srgb,#ffffff 82%, transparent);--ft-accent:var(--brand-green);background:var(--ft-bg);color:var(--ft-text);padding:clamp(28px,5vw,56px) 0 0}
.site-footer .container{width:min(100%,var(--container));margin-inline:auto;padding:clamp(16px,2.5vw,24px)}
.footer-grid{display:grid;gap:clamp(16px,3vw,28px);grid-template-columns:1.3fr .8fr .8fr .8fr;align-items:start}
@media (max-width:980px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer-head{margin:0 0 .4rem;font-weight:600;color:#fff}
.footer-address{font-style:normal}
.contact-list{list-style:none;padding:0;margin:.25rem 0 0;display:grid;gap:.5rem}
.contact-list li{display:flex;gap:.55rem;align-items:center;color:var(--ft-dim)}
.site-footer a{color:var(--ft-dim);text-decoration:none;border-radius:8px;padding:2px 4px;transition:color .2s ease,background-color .2s ease}
.site-footer a:hover{color:#fff;background:rgba(255,255,255,.08)}
.site-footer a:focus-visible{outline:3px solid color-mix(in srgb, var(--ft-accent) 55%, transparent);outline-offset:2px}
.footer-nav ul,.footer-legal ul,.footer-extra ul{list-style:none;padding:0;margin:0;display:grid;gap:.45rem}
.footer-bottom{margin-top:clamp(18px,3.5vw,28px);border-top:1px solid color-mix(in srgb,#ffffff 16%, transparent);padding:12px 0 16px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;color:var(--ft-dim)}

/* =========================
   CTA-Button & Modal
   ========================= */
.ml-glowbtn-wrapper{display:flex;justify-content:center;align-items:center}
.ml-imagebtn{display:inline-block;width:clamp(160px,42vw,300px);height:auto;aspect-ratio:1/1;background:url("assets/klartext_button.png") no-repeat center/contain;border:none;cursor:pointer;text-decoration:none;transition:transform .16s ease,box-shadow .22s ease,background-image .08s linear}
.ml-imagebtn:hover,.ml-imagebtn:focus{background-image:url("assets/klartext_button_hover.png")}
.ml-modal{position:fixed;inset:0;z-index:1000;display:none;place-items:center;padding:clamp(12px,3vw,32px)}
.ml-modal[aria-hidden="false"]{display:grid}
.ml-modal__backdrop{position:absolute;inset:0;background:rgba(17,24,39,.55);backdrop-filter:blur(3px)}
.ml-modal__dialog{position:relative;width:min(900px,92vw);max-height:min(88vh,1200px);overflow-y:auto;border-radius:20px;padding:clamp(24px,4vw,48px);background:
  url("assets/klartext_hintergrund.png") center center no-repeat,
  linear-gradient(180deg,#f8fbf2 0%,#ffffff 100%);background-size:620px auto,cover;box-shadow:0 20px 60px rgba(0,0,0,.28);color:var(--brand-green-2)}
.ml-modal__close{position:absolute;top:14px;right:14px;inline-size:44px;block-size:44px;border-radius:12px;background:#fff;border:1px solid var(--clr-border);box-shadow:0 6px 16px rgba(0,0,0,.08);font-size:24px;line-height:1;display:grid;place-items:center;cursor:pointer}
.ml-modal__close:hover{background:var(--brand-green);color:var(--brand-green-2);border-color:var(--brand-green)}
.ml-modal__header h2{font-size:clamp(1.5rem,2vw + 1rem,2rem);font-weight:800;line-height:1.3;margin-bottom:1rem;white-space:normal}
.ml-modal__content{font-size:1rem;line-height:1.6;font-weight:400;color:var(--brand-green-2)}
.ml-modal__content strong{font-weight:700}
.ml-modal__content.grid-2col{display:grid;grid-template-columns:1.2fr .8fr;gap:2rem;align-items:center}
@media (max-width:768px){.ml-modal__content.grid-2col{grid-template-columns:1fr}.ml-modal__media{margin-top:1.5rem}}
.ml-modal__media img{width:100%;max-width:340px;height:auto;border-radius:16px;object-fit:cover}
.ml-modal__actions{margin-top:clamp(16px,3vw,28px);display:flex;justify-content:flex-start}
.ml-cta{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.4rem;border-radius:12px;font-weight:800;text-decoration:none;border:2px solid var(--brand-green-2);color:var(--brand-green-2);background:#fff;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,border-color .2s ease}
.ml-cta:hover{transform:translateY(-1px);background:var(--brand-green);border-color:var(--brand-green);box-shadow:0 10px 24px rgba(0,0,0,.08)}

/* =========================
   Kleine Mobile-Feinschliffe
   ========================= */
@media (max-width:560px){
  .footer-grid{grid-template-columns:1fr}
  .site-footer .container{padding-inline:16px}
}

/* ===== CTA: On-Scroll-Animation ===== */
.cta-wrap{ position:relative; }
.cta-hint{
  position:absolute;
  right:18px;         /* sitzt leicht auf dem PNG */
  bottom:46px;
  width:64px; height:64px;
  pointer-events:none;
  opacity:0;
  transform: translate(10px,10px) scale(.96);
}
.cta-cursor-img{ width:36px; height:auto; filter:drop-shadow(0 2px 6px rgba(0,0,0,.2)); transform: translate(-60px, 0);}
.cta-ripple{
  position:absolute; left:-60px; top:0px;
  width:16px; height:16px; border-radius:50%;
  border:2px solid var(--brand-green); opacity:0; transform:scale(.6);
}


/* Animationen */
@keyframes cta-pop{
  0%{opacity:0; transform:translate(10px,10px) scale(.96)}
  12%{opacity:1; transform:translate(0,0) scale(1)}
  55%{opacity:1; transform:translate(0,0) scale(1)}
  72%{opacity:1; transform:translate(0,0) scale(.96)}
  100%{opacity:0; transform:translate(10px,10px) scale(.95)}
}
@keyframes cta-ripple{
  0%{opacity:0; transform:scale(.6)}
  30%{opacity:.35; transform:scale(1)}
  70%{opacity:.18; transform:scale(1.45)}
  100%{opacity:0; transform:scale(1.7)}
}
.cta-hint.is-animating{ animation: cta-pop 3.6s ease-out forwards; }
.cta-hint.is-animating .cta-ripple{ animation: cta-ripple 1.2s ease-out 1.1s forwards; }

/* Buttonzustände, damit der PNG-Button sichtbar reagiert */
.ml-imagebtn{
  transition: transform .16s ease, box-shadow .22s ease, background-image .08s linear;
}
.ml-imagebtn.is-sim-hover{ background-image:url("assets/klartext_button_hover.png"); }
.ml-imagebtn.is-sim-click{ transform:scale(0.97); }

/* Accessibility: Animationen respektieren */
@media (prefers-reduced-motion: reduce){
  .cta-hint, .cta-hint *{ animation:none !important; }
  .ml-imagebtn{ transition:none; }
}


/* Buch-Link hervorheben */
.book-link {
  color: var(--brand-green-1);       /* dein kräftiges Grün */
  transition: color .2s ease, background .2s ease;
}

.book-link:hover,
.book-link:focus {
  color: var(--brand-green-2);       /* dunkleres Grün beim Hover */
  background: color-mix(in srgb, var(--brand-green) 25%, transparent);
  border-radius: 4px;
}


/* =========================
   Produkte
   ========================= */
.product { padding: clamp(16px, 2.5vw, 24px); }
.product-card{
  display:grid;
  grid-template-columns: minmax(220px, 360px) 1fr;
  gap: clamp(16px, 3vw, 28px);
  align-items:start;
  padding: clamp(16px, 3vw, 28px);
}
.product-media{ margin:0; align-self:start; }
.product-media img{
  display:block;
  width:100%; height:auto;
  aspect-ratio: 3 / 4; /* hochkant */

}
.product-copy{ display:grid; gap: 10px; align-content:start; max-width: 68ch; }
.product-title{ color: var(--brand-green-1); font-weight: 800; font-size: clamp(22px, 3vw, 28px); line-height:1.2; }
.product-desc{ color: var(--clr-text); }
.product-actions{ display:flex; gap:12px; flex-wrap:wrap; margin-top: 4px; }
.product-meta{ margin: 6px 0 0; color: var(--clr-muted); }

.ml-offer3__btn.btn-secondary{
  border-color: var(--brand-green-1);
  color: var(--brand-green-1);
  background: #fff;
}
.ml-offer3__btn.btn-secondary:hover{
  background: var(--brand-green);
  border-color: var(--brand-green);
  color: var(--brand-green-2);
}

@media (max-width: 820px){
  .product-card{ grid-template-columns: 1fr; }
  .product-media{ max-inline-size: 360px; }
}





.product-meta a {
  border-radius: 6px;
  padding: 2px 4px;
  transition: background-color .2s ease, color .2s ease;
}

.product-meta a:hover,
.product-meta a:focus {
  background: rgba(0,0,0,0.05); /* hellgrau wie im Footer-Hover */
  color: var(--brand-green-2);
}


/* =========================
   Mobile-Optimierungen (≤ 560px)
   ========================= */
@media (max-width:560px){

  /* 1) Logo etwas größer */
  .logo_img{
    max-width: 220px;       /* vorher clamp(160px,...) */
  }

  /* 2) Libelle nicht nach links schieben */
  .deko{
    transform: none;        /* Überschreibt translateX(-40px) */
    max-width: 72px;
    margin-bottom: 6px;
  }

  /* 3) Texte etwas kleiner + kompaktere Abstände */
  body{ font-size: 15px; }  /* global leicht kleiner */
  .section{ padding: 2.2rem 0; }
  .section-title{ font-size: clamp(22px, 6vw, 28px); }
  h3{ font-size: clamp(18px, 5.2vw, 22px); }
  p{ margin: .15rem 0 .6rem; }

  /* 4) Romy-Anton-Bild kleiner (kein Vollbild) */
  .intro-media{
    max-inline-size: 260px;     /* deckelt die Breite auf Phones */
    margin-inline: auto;        /* mittig, wenn allein in Spalte */
  }
  .accent-box{
    width: 0px;
    height: 0px;
  }

  /* 5) Dresden: nicht zweigeteilt – Bild zuerst, dann Text */
  #dresden .grid--2{
    grid-template-columns: 1fr;   /* einspaltig */
  }
  #dresden .image-card{
    order: -1;                     /* Bild vor den Text */
    margin: 0 0 12px 0;
  }

  /* 6) Kontakt: AGB/Consent-Text kleiner & sauber ausgerichtet */
  .ml-consent label{
    font-size: .85rem;
    line-height: 1.35;
    gap: .5rem;
    align-items: flex-start;       /* Checkbox oben bündig */
  }
  .ml-consent input[type="checkbox"]{
    margin-top: .25rem;            /* optische Korrektur */
    flex: 0 0 auto;
  }

  /* Optional: Formular generell etwas zarter auf Mobile */
  .ml-field label{ font-size: .9rem; }
  .ml-contact__hint{ font-size: .75rem; }
}

/* =========================
   Mobile Vollbild-Menü
   ========================= */
@media (max-width:880px){
  .nav{
    position: fixed;
    inset: 0;                       /* nimmt den ganzen Screen ein */
    padding: clamp(24px,6vw,32px);
    background: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;        /* mittig */
    align-items: center;
    gap: clamp(12px,3.5vh,22px);
    border: 0;                      /* keine Linien */
    opacity: 0;
    transform: translateY(-6px);
    pointer-events: none;
    transition: opacity .25s var(--ease), transform .25s var(--ease);
  }
  .nav[aria-expanded="true"]{
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }

  .nav a{
    border: 0;                      /* sicherheitshalber */
    padding: 12px 8px;
    font-size: clamp(18px,5.6vw,26px);
    font-weight: 800;
  }
  .nav a::after{ display:none }     /* keine Underlines im Overlay */

  /* Burger-Button über Overlay sichtbar lassen */
  .nav-toggle{ position: relative; z-index: 1001; }

  /* Body scrollen verhindern, wenn Menü offen (per JS .menu-open) */
  body.menu-open{ overflow: hidden; }
  
  /* =========================
   Footer zentrieren
   ========================= */
  .site-footer .container,
  .footer-grid{
    text-align: center;
  }
  .footer-grid{ justify-items: center; }
  .footer-brand, .footer-nav, .footer-legal, .footer-extra{
    width: 100%;
  }
  .footer-nav ul, .footer-legal ul, .footer-extra ul, .contact-list{
    align-items: center;
    justify-items: center;
  }
  .contact-list li{ justify-content: center; }

  /* Footer-Logo mittig */
  .site-footer .logo_img {
    display: block;
    margin-inline: auto;   /* mittig horizontal */
    max-width: 220px;      /* bleibt responsiv */
    height: auto;
  }


}


/* ========= Mehr-Infos Modal: Branding-konform ========= */
.ml-cta--ghost{
  display:inline-flex; align-items:center; gap:.5rem;
  border:2px solid var(--brand-green-2);
  background:#fff; color:var(--brand-green-2);
  border-radius:12px; padding:.6rem 1rem; font-weight:800;
  transition:transform .15s ease, background .2s ease, border-color .2s ease;
}
.ml-cta--ghost:hover{ transform: translateY(-1px); background: var(--brand-green); border-color: var(--brand-green); }

/* Modal inhaltlich neu gestylt */
.mi-modal{
  /* nutzt bereits deine ml-modal__dialog Basis */
  background: linear-gradient(180deg,#f8fbf2 0%, #ffffff 100%);
}

.mi-sub{ margin:.25rem 0 0; color: var(--brand-green-1); }

.mi-content{ display:grid; gap:16px; }

/* KPI Grid */
.mi-kpi{
  display:grid; gap:12px;
  grid-template-columns: repeat(2,minmax(0,1fr));
}
@media (min-width:720px){ .mi-kpi{ grid-template-columns: repeat(4,minmax(0,1fr)); } }
.mi-kpi__card{
  background:#fff; border:1.5px solid var(--clr-border); border-radius:16px;
  padding:14px; box-shadow:0 8px 22px rgba(0,0,0,.06);
}
.mi-kpi__card b{
  display:block; font-size:clamp(18px,2.8vw,22px); color:var(--brand-green-1); letter-spacing:-.01em;
}
.mi-kpi__card span{ color:var(--brand-green-2); font-size:.95rem; }

/* Panels / Split */
.mi-panel{
  background:#fff; border:1.5px solid var(--clr-border); border-radius:16px;
  padding:16px; box-shadow:0 8px 22px rgba(0,0,0,.06);
}
.mi-panel h3{ margin:0 0 .35rem; font-size:clamp(18px,2.6vw,20px); color:var(--brand-green-1); }
.mi-list{ margin:.2rem 0 0; padding-left:1.15rem; }
.mi-list li{ margin:.18rem 0; }

.mi-split{ display:grid; gap:14px; }
@media (min-width:900px){ .mi-split{ grid-template-columns: 1.2fr .8fr; } }

.mi-calc{
  margin-top:8px; border:1.5px dashed var(--clr-border);
  background: color-mix(in srgb, var(--brand-green) 20%, transparent);
  border-radius:12px; padding:12px;
}
.mi-note{ color: var(--brand-green-1); font-size:.92rem; }

.mi-cta{ display:flex; justify-content:flex-start; margin-top:4px; }

/* leichte Verdichtung im Modal */
#ml-modal-mehrinfos .ml-modal__header{ margin-bottom:.25rem; }
#ml-modal-mehrinfos .ml-modal__content{ font-size:1rem; }

/* Linkstil in Quellenliste */
.mi-sources a{
  color: var(--brand-green-1);
  border-radius:6px; padding:2px 4px;
  transition: background-color .2s ease, color .2s ease;
}
.mi-sources a:hover{ background: rgba(0,0,0,.05); color: var(--brand-green-2); }


/* ============ FAQ Akkordeon (JS-frei mit <details>) ============ */
.ml-faq .section-title{ color:#fff; }
.ml-faq .subtitle{ color:#fff; opacity:.9; }

.ml-faq__list{
  display:grid;
  gap:12px;
  margin-top:10px;
}

/* Card-Container */
.ml-acc{
  background:#fff;
  border:1.5px solid var(--clr-border);
  border-radius:16px;
  box-shadow:0 8px 22px rgba(0,0,0,.06);
  overflow:hidden;
}

/* Summary-Leiste */
.ml-acc__sum{
  list-style:none;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:clamp(14px,2.5vw,18px);
  color:var(--brand-green-2);
  cursor:pointer;
  position:relative;
}
.ml-acc__sum::-webkit-details-marker{ display:none; } /* Safari/Chrome Marker aus */
.ml-acc__sum::after{
  content:"+";
  color:var(--brand-green-1);
  font-weight:900;
  line-height:1;
  transform: translateY(-1px);
  transition: transform .2s var(--ease);
}
.ml-acc[open] .ml-acc__sum::after{
  content:"–";
  transform:none;
}

/* Panel-Inhalt mit sanfter „max-height“-Transition */
.ml-acc__panel{
  overflow:hidden;
  max-height:0;
  transition:max-height .45s var(--ease);
  padding:0 clamp(14px,2.5vw,18px);
}
.ml-acc[open] .ml-acc__panel{
  /* groß genug wählen, damit Content hineinpasst */
  max-height: 1200px;
  padding-bottom: clamp(14px,2.5vw,18px);
}

.ml-faq__bullets{
  margin:.4rem 0 0;
  padding-left:1.1rem;
  display:grid; gap:.35rem;
  color:var(--brand-green-2);
}
.ml-faq__bullets .src{
  color: var(--brand-green-1);
  font-style: normal;
  font-size: .9em;
}
.ml-faq__note{
  margin:.6rem 0 0;
  color: var(--brand-green-1);
  font-size:.92rem;
}

/* optional: nur ein Panel gleichzeitig offen lassen – rein visuell */
.ml-acc + .ml-acc{ margin-top: 0; }


.tooltip {
  position: relative;
  display: inline-block;
  margin-left: 6px;
  width: 20px;
  height: 20px;
  line-height: 18px;
  text-align: center;
  font-weight: 700;
  font-size: 0.85rem;

  color: var(--brand-green-2);
  background: #fff;
  cursor: default;
  transition: background .2s ease, color .2s ease;
}


.tooltip::after {
  content: attr(data-tooltip);
  position: absolute;
  left: 50%;
  bottom: calc(100% + 10px);
  transform: translateX(-50%);
  width: max-content;
  max-width: 300px;
  padding: 10px 14px;
  font-size: 0.9rem;
  line-height: 1.4;
  color: var(--brand-green-2);
  background: #fff;
  border: 1px solid var(--clr-border);
  border-radius: var(--radius);
  box-shadow: 0 8px 22px rgba(0,0,0,.12);
  opacity: 0;
  pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
  z-index: 999;
}

.tooltip:hover::after,
.tooltip:focus::after {
  opacity: 1;
  transform: translateX(-50%) translateY(-4px);
}


/* === Produkt-Galerie (passt zu deinen Tokens) === */
.p-gallery{ display:grid; gap:10px; }
.p-gallery__stage{
  position:relative; border-radius:16px; overflow:hidden;


}
.p-gallery__img{ display:block; width:100%; height:auto; aspect-ratio:3/4; object-fit:cover; }

.p-gallery__nav{
  position:absolute; top:50%; transform:translateY(-50%);
  inline-size:36px; block-size:36px; border-radius:999px;
  border:1.5px solid var(--clr-border); background:#fff; color:var(--brand-green-2);
  display:grid; place-items:center; font-size:20px; font-weight:800; cursor:pointer;
  transition:transform .15s var(--ease), background .2s var(--ease), border-color .2s var(--ease);
}
.p-gallery__nav:hover{ transform:translateY(-50%) scale(1.04); background:var(--brand-green); border-color:var(--brand-green); }
.p-gallery__nav.is-prev{ left:10px; }
.p-gallery__nav.is-next{ right:10px; }

.p-gallery__thumbs{
  display:flex; gap:8px; overflow-x:auto; padding:2px;
  -webkit-overflow-scrolling:touch; scroll-snap-type:x proximity;
}
.p-gallery__thumb{
  flex:0 0 auto; scroll-snap-align:center;
  border:2px solid var(--clr-border); border-radius:10px; background:#fff;
  padding:2px; cursor:pointer; transition:border-color .2s var(--ease), transform .15s var(--ease);
}
.p-gallery__thumb:hover{ transform:translateY(-1px); border-color:var(--brand-green); }
.p-gallery__thumb.is-active{ border-color:var(--brand-green-1); }
.p-gallery__thumb img{
  display:block; width:60px; height:80px; object-fit:cover; border-radius:6px;
}

@media (max-width:820px){
  .p-gallery__thumb img{ width:52px; height:70px; }
}


/* ===============================
   Schöne Navigation-Buttons (‹ ›)
   =============================== */
.p-gallery__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  inline-size: 42px;
  block-size: 42px;

  border: none;
  border-radius: 50%;
  background: var(--clr-bg);
  color: var(--brand-green-1);

  display: grid;
  place-items: center;
  font-size: 22px;
  font-weight: 700;
  cursor: pointer;

  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.15);
  transition:
    transform 0.18s var(--ease),
    background 0.25s var(--ease),
    box-shadow 0.25s var(--ease);
}

/* Positionierung */
.p-gallery__nav.is-prev { left: 5px; }
.p-gallery__nav.is-next { right: 5px; }

/* Hover- & Fokus-Effekt */
.p-gallery__nav:hover,
.p-gallery__nav:focus-visible {
  background: var(--brand-green);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.2);
  transform: translateY(-50%) scale(1.07);
  outline: none;
}

/* Aktiv beim Klicken */
.p-gallery__nav:active {
  transform: translateY(-50%) scale(0.95);
  box-shadow: 0 3px 8px rgba(0, 0, 0, 0.2);
}

/* Mobile: Buttons kleiner und dezenter */
@media (max-width: 700px) {
  .p-gallery__nav {
    inline-size: 36px;
    block-size: 36px;
    font-size: 20px;
  }
}
