/* =====================================================================
   Reflexzone 9606 — Design System
   Basis-Stylesheet (winwebdesign-Footprint). Für weitere Seiten nur
   die :root-Tokens + @font-face anpassen.
   ===================================================================== */

/* ---------- Self-hosted Fonts (DSGVO) ---------- */
@font-face{font-family:'Crimson Pro';src:url('../fonts/crimson-pro-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Crimson Pro';src:url('../fonts/crimson-pro-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Roboto';src:url('../fonts/roboto-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Roboto';src:url('../fonts/roboto-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Roboto';src:url('../fonts/roboto-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}

/* ---------- Design Tokens ---------- */
:root{
  --c-sage:#7FCEAA;        /* Primär Salbeigrün */
  --c-sage-deep:#459470;   /* Tief-Salbeigrün */
  --c-cream:#FBF0E3;       /* Background warm */
  --c-peach-l:#F8E1CB;     /* Pfirsich hell */
  --c-peach:#FFBC7D;       /* Pfirsich Akzent */
  --c-neutral:#DDD9D3;     /* Trennlinien */
  --c-text:#4E5152;        /* Fliesstext */
  --c-muted:#7A7A7A;       /* Sekundärtext */
  --c-white:#FFFFFF;

  --font-head:'Crimson Pro',Georgia,'Times New Roman',serif;
  --font-body:'Roboto',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  --maxw:1200px;
  --radius:16px;
  --radius-pill:999px;
  --shadow-sm:0 2px 8px rgba(78,81,82,.08);
  --shadow:0 10px 30px rgba(78,81,82,.10);
  --shadow-lg:0 20px 50px rgba(78,81,82,.14);
  --header-h:88px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset / Base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  font-size:1.0625rem;line-height:1.65;color:var(--c-text);
  background:var(--c-white);overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-sage-deep);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--c-sage)}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:600;line-height:1.2;color:var(--c-text);letter-spacing:.2px}
h1{font-size:clamp(2.2rem,5vw,3.2rem)}
h2{font-size:clamp(1.8rem,3.5vw,2.4rem)}
h3{font-size:clamp(1.25rem,2.2vw,1.5rem)}
p{margin-bottom:1rem}
:focus-visible{outline:3px solid var(--c-sage-deep);outline-offset:3px;border-radius:4px}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1rem,4vw,2rem)}
.section{padding-block:clamp(3rem,7vw,6rem)}
.section--cream{background:var(--c-cream)}
.section--peach{background:var(--c-peach-l)}
.eyebrow{font-family:var(--font-body);font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--c-sage-deep);font-size:.82rem;text-align:center;margin-bottom:.5rem}
.section-title{text-align:center;margin-bottom:2.5rem}
.lead{font-size:1.15rem;color:var(--c-muted);max-width:60ch;margin-inline:auto}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-weight:700;font-size:1rem;
  padding:.85rem 1.8rem;border-radius:var(--radius-pill);border:2px solid transparent;cursor:pointer;
  transition:transform .2s var(--ease),background .2s var(--ease),box-shadow .2s var(--ease);text-align:center;line-height:1.2}
.btn--primary{background:var(--c-sage-deep);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:var(--c-sage);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--outline{background:transparent;color:var(--c-sage-deep);border-color:var(--c-sage-deep)}
.btn--outline:hover{background:var(--c-sage-deep);color:#fff;transform:translateY(-2px)}
.btn--lg{padding:1.05rem 2.4rem;font-size:1.08rem}

/* ---------- Header ---------- */
.site-header{position:fixed;inset:0 0 auto 0;z-index:100;background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid transparent;transition:box-shadow .3s var(--ease),border-color .3s var(--ease),padding .3s var(--ease)}
.site-header.scrolled{box-shadow:var(--shadow-sm);border-color:var(--c-neutral)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:var(--header-h);transition:height .3s var(--ease)}
.site-header.scrolled .header-inner{height:70px}
.brand img{height:58px;width:auto;transition:height .3s var(--ease)}
.site-header.scrolled .brand img{height:46px}
.nav{display:flex;align-items:center;gap:1.6rem}
.nav a{font-weight:500;color:var(--c-text);font-family:var(--font-body)}
.nav a.active,.nav a:hover{color:var(--c-sage-deep)}
.header-cta{display:flex;align-items:center;gap:1.2rem}
.header-phone{display:flex;align-items:center;gap:.6rem}
.header-phone .ico{width:42px;height:42px;border-radius:50%;background:var(--c-sage);display:grid;place-items:center;color:#fff;flex:none}
.header-phone small{display:block;font-size:.78rem;color:var(--c-muted)}
.header-phone strong{font-size:1.02rem;color:var(--c-text)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;color:var(--c-sage-deep)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;
  background:var(--c-text) center/cover no-repeat;margin-top:0}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(30,38,40,.72) 0%,rgba(30,38,40,.30) 70%)}
.hero .container{position:relative;z-index:2;padding-top:var(--header-h)}
.hero h1{color:#fff;max-width:18ch;text-shadow:0 2px 20px rgba(0,0,0,.25)}
.hero p{color:rgba(255,255,255,.94);font-size:1.25rem;max-width:46ch;margin-block:1.2rem 2rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}

/* ---------- Cards ---------- */
.grid{display:grid;gap:1.8rem}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card img{aspect-ratio:4/3;object-fit:cover;width:100%}
.card-body{padding:1.5rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.card-body h3{color:var(--c-sage-deep)}
.card .btn{margin-top:auto;align-self:flex-start}

/* ---------- Pricing ---------- */
.price-table{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:820px;margin-inline:auto}
.price{background:#fff;border:1px solid var(--c-neutral);border-radius:var(--radius);padding:2rem 1.5rem;text-align:center}
.price .min{font-family:var(--font-head);font-size:1.4rem;color:var(--c-sage-deep)}
.price .chf{font-size:2.4rem;font-weight:700;font-family:var(--font-head);margin-block:.3rem}

/* ---------- FAQ Accordion ---------- */
.faq{max-width:780px;margin-inline:auto}
.faq-item{border-bottom:1px solid var(--c-neutral)}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:1.25rem 2.5rem 1.25rem 0;position:relative;
  font-family:var(--font-head);font-size:1.15rem;color:var(--c-text)}
.faq-q::after{content:"+";position:absolute;right:.25rem;top:50%;transform:translateY(-50%);font-size:1.6rem;color:var(--c-sage-deep);transition:transform .25s var(--ease)}
.faq-q[aria-expanded="true"]::after{transform:translateY(-50%) rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s var(--ease)}
.faq-a-inner{padding:0 0 1.25rem;color:var(--c-muted)}

/* ---------- Testimonials ---------- */
.testi{display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr)}
.testi blockquote{background:#fff;border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-sm);font-style:italic;color:var(--c-text)}
.testi cite{display:block;margin-top:1rem;font-style:normal;font-weight:700;color:var(--c-sage-deep)}

/* ---------- Forms ---------- */
.form{max-width:680px;margin-inline:auto;display:grid;gap:1.1rem}
.form-row{display:grid;gap:1.1rem;grid-template-columns:1fr 1fr}
.field{display:flex;flex-direction:column;gap:.4rem}
.field label{font-weight:500;font-size:.95rem}
.field .req{color:#c0392b}
.field input,.field select,.field textarea{font-family:var(--font-body);font-size:1rem;padding:.8rem 1rem;border:1px solid var(--c-neutral);
  border-radius:10px;background:#fff;color:var(--c-text);transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--c-sage);box-shadow:0 0 0 3px rgba(127,206,170,.25)}
.field textarea{min-height:140px;resize:vertical}
.field--check{flex-direction:row;align-items:flex-start;gap:.6rem}
.field--check input{margin-top:.25rem}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-msg{padding:1rem 1.2rem;border-radius:10px;font-weight:500;display:none}
.form-msg.ok{display:block;background:#e6f5ee;color:#1e6e4c;border:1px solid #7FCEAA}
.form-msg.err{display:block;background:#fbe9e7;color:#9b2c1f;border:1px solid #e1897d}

/* ---------- Footer ---------- */
.site-footer{background:var(--c-text);color:rgba(255,255,255,.8);padding-block:3.5rem 1.5rem}
.site-footer h4{color:#fff;font-family:var(--font-body);font-weight:700;font-size:1rem;letter-spacing:.04em;margin-bottom:1rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
.site-footer a{color:rgba(255,255,255,.8)}
.site-footer a:hover{color:var(--c-sage)}
.footer-brand img{height:64px;filter:brightness(0) invert(1);opacity:.95;margin-bottom:1rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.15);padding-top:1.5rem;display:flex;flex-wrap:wrap;gap:.6rem 1.5rem;justify-content:space-between;font-size:.85rem;color:rgba(255,255,255,.6)}
.footer-bottom a{color:rgba(255,255,255,.6)}
.credit{font-size:.82rem;opacity:.7}

/* ---------- Floating action buttons ---------- */
.fab-stack{position:fixed;right:1.2rem;bottom:1.2rem;z-index:90;display:flex;flex-direction:column;gap:.7rem}
.fab{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:var(--shadow);
  transition:transform .2s var(--ease),opacity .3s var(--ease)}
.fab:hover{transform:scale(1.08);color:#fff}
.fab--wa{background:#25D366}
.fab--phone{background:var(--c-sage-deep)}
.fab--top{background:var(--c-peach);opacity:0;pointer-events:none}
.fab--top.show{opacity:1;pointer-events:auto}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .grid--3,.price-table,.testi{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:760px){
  .nav,.header-phone small,.header-phone strong{display:none}
  .nav-toggle{display:grid;place-items:center}
  .nav.open{display:flex;position:fixed;inset:var(--header-h) 0 auto 0;flex-direction:column;background:#fff;
    padding:1.5rem;gap:1.2rem;box-shadow:var(--shadow);border-top:1px solid var(--c-neutral)}
  .nav.open a{font-size:1.15rem}
  .grid--3,.grid--2,.price-table,.testi,.form-row,.footer-grid{grid-template-columns:1fr}
  .hero{min-height:78vh}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
  .card:hover,.btn:hover,.fab:hover{transform:none}
}


/* ===== QA-Fixes (auto) ===== */

/* Kontrast/Sichtbarkeit (Links & Akzentfarbe) — Bestätigt am echten Code. Der Token --c-sage-deep:#459470 (styles.css */
:root{--c-sage-deep:#357757}
/* A) Header/Mobile-Nav — Bestätigt am echten Code. In styles.css (Z. 186) ist das geöffnete Mob */
@media(max-width:760px){.nav.open{inset:var(--header-h) 0 0 0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}}
/* Kontrast/Sichtbarkeit (Footer) — Bestätigt am echten Code: Der Footer-Hintergrund ist --c-text #4E5152 */
.footer-bottom,.footer-bottom a{color:rgba(255,255,255,.82)}.credit{opacity:1}
/* Fokusring vs. Button-Flaeche — Bestaetigt: In styles.css Zeile 55 ist der globale Fokusring `:focus-v */
:focus-visible{outline:3px solid #fff;outline-offset:2px;box-shadow:0 0 0 6px var(--c-sage-deep),0 0 0 8px #fff;border-radius:4px}
/* Text ueber Bild (Hero) — Bestaetigt im echten Code: styles.css Zeile 97 definiert .hero::after */
.hero::after{background:linear-gradient(100deg,rgba(30,38,40,.78) 0%,rgba(30,38,40,.48) 70%)}.hero p{text-shadow:0 1px 12px rgba(0,0,0,.45)}
/* C) Kontrast/Sichtbarkeit — Bestätigt: --c-muted:#7A7A7A (styles.css Z.23) wird für Sekundärtext i */
:root{--c-muted:#6B6B6B}
/* C) Kontrast/Sichtbarkeit – Footer — Bestätigt am echten Code (assets/css/styles.css Z.154,160-162; Footer- */
.footer-bottom,.footer-bottom a{color:rgba(255,255,255,.85)}.credit{opacity:1;color:rgba(255,255,255,.85)}
/* C) Kontrast/Sichtbarkeit – Footer-Copyright/Rechtszeile unter WCAG AA — Bestätigt am echten Code: .footer-bottom (styles.css Zeile 160) setzt */
.footer-bottom,.footer-bottom a{color:rgba(255,255,255,.82)}
/* A) Mobile – Fehlender Body-Scroll-Lock bei offenem Mobilmenü — Das Problem ist real: Das mobile Menue (.nav.open, styles.css Zeile 18 */
body:has(.nav.open){overflow:hidden}
/* B) Mobile/Hero-Hoehe — Bestaetigt am echten Code. In styles.css Zeile 95 hat .hero base min-h */
@media(max-width:480px){.hero{min-height:auto;padding-block:2.5rem}.hero .container{padding-top:calc(var(--header-h) + 1.5rem);padding-bottom:.5rem}}
/* A) Mobiles Menue – Spalt beim Schrumpfen — Bestätigt: Das mobile Menue .nav.open ist mit inset:var(--header-h) 0 */
@media(max-width:760px){.site-header.scrolled .nav.open{top:70px}}
/* A) Mobiles Menue – Scroll-Lock bei offenem Overlay — Auf Mobil (max-width:760px) ist das offene Menue `.nav.open` ein posit */
@media(max-width:760px){body:has(.nav.open){overflow:hidden}}
/* A) FAB ueberlappt Footer/Cookie — Teilweise bestaetigt. REAL: Der FAB-Stack (.fab-stackposition:fixed;r */
@media(max-width:760px){.fab-stack{right:.8rem;bottom:.8rem;gap:.5rem}.fab{width:48px;height:48px}body:has(.cookie-banner:not([hidden])) .fab-stack{opacity:0;pointer-events:none}}
/* C) Kontrast/Sichtbarkeit – Eyebrow — Bestaetigt: .eyebrow (styles.css Zeile 62) nutzt color:var(--c-sage-de */
.eyebrow{color:#357355}
/* A) Mobile – kein Body-Scroll-Lock bei offenem Menü — Bestätigt: Das mobile Menü .nav.open ist position:fixed; inset:var(--h */
@media(max-width:760px){body:has(.nav.open){overflow:hidden;touch-action:none}}

/* QA-Fix final: AA-stärkste Token-Werte (last wins) */
:root{--c-muted:#606060}
