/* =====================================================================
   Fit und Faktisch — Design System (winwebdesign-Footprint)
   ===================================================================== */

@font-face{font-family:'Cormorant Garamond';src:url('../fonts/cormorant-garamond-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Cormorant Garamond';src:url('../fonts/cormorant-garamond-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Onest';src:url('../fonts/onest-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Onest';src:url('../fonts/onest-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Onest';src:url('../fonts/onest-700.woff2') format('woff2');font-weight:700;font-style:normal;font-display:swap}

:root{
  --c-olive:#485B12;
  --c-bronze:#CD853F;
  --c-bordeaux:#7B0237;
  --c-peach:#E0A876;
  --c-peach2:#E9967A;
  --c-cream:#FAF7F0;
  --c-text:#2D322C;
  --c-muted:#4F4D4D;
  --c-neutral:#E5E0D5;
  --c-white:#FFFFFF;

  --font-head:'Cormorant Garamond',Georgia,serif;
  --font-body:'Onest',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

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

*,*::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-cream);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-olive);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--c-bordeaux)}
h1,h2,h3,h4{font-family:var(--font-head);font-weight:600;line-height:1.12;color:var(--c-text);letter-spacing:.3px}
h1{font-size:clamp(2.6rem,6vw,4rem)}
h2{font-size:clamp(2rem,4vw,2.8rem)}
h3{font-size:clamp(1.3rem,2.4vw,1.7rem)}
p{margin-bottom:1rem}
:focus-visible{outline:3px solid var(--c-olive);outline-offset:3px;border-radius:4px}

.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--white{background:var(--c-white)}
.eyebrow{font-family:var(--font-body);font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--c-bronze);font-size:.8rem;text-align:center;margin-bottom:.5rem}
.section-title{text-align:center;margin-bottom:2.5rem}
.lead{font-size:1.2rem;color:var(--c-muted);max-width:62ch;margin-inline:auto}

.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-bordeaux);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:#5e021c;color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--olive{background:var(--c-olive);color:#fff}
.btn--olive:hover{background:#374a0d;color:#fff;transform:translateY(-2px)}
.btn--outline{background:transparent;color:var(--c-olive);border-color:var(--c-olive)}
.btn--outline:hover{background:var(--c-olive);color:#fff;transform:translateY(-2px)}
.btn--lg{padding:1.05rem 2.4rem;font-size:1.08rem}

.site-header{position:fixed;inset:0 0 auto 0;z-index:100;background:rgba(250,247,240,.92);backdrop-filter:blur(8px);border-bottom:1px solid transparent;transition:box-shadow .3s var(--ease),border-color .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:54px;width:auto;transition:height .3s var(--ease)}
.site-header.scrolled .brand img{height:44px}
.nav{display:flex;align-items:center;gap:1.6rem}
.nav a{font-weight:500;color:var(--c-text);font-family:var(--font-body);text-transform:uppercase;letter-spacing:.04em;font-size:.92rem}
.nav a.active,.nav a:hover{color:var(--c-olive)}
.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-olive);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:1rem;color:var(--c-text)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;color:var(--c-olive)}

/* Split-Hero */
.hero{position:relative;background:var(--c-cream)}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;min-height:92vh;align-items:center}
.hero-text{padding:calc(var(--header-h) + 2rem) clamp(1rem,4vw,3rem) 3rem clamp(1rem,5vw,4rem)}
.hero-text h1{margin-bottom:1.2rem}
.hero-text p{font-size:1.2rem;color:var(--c-muted);max-width:42ch;margin-bottom:2rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem}
.hero-img{position:relative;height:100%;min-height:50vh;background-position:center top;background-size:cover;background-repeat:no-repeat}
/* Bilder mit Personen: Kopf/Gesicht immer sichtbar */
.img-top{object-position:top center!important}
.card img.img-top{object-position:top center!important}

.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-olive)}
.card .btn{margin-top:auto;align-self:flex-start}

.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.3rem;color:var(--c-text)}
.faq-q::after{content:"+";position:absolute;right:.25rem;top:50%;transform:translateY(-50%);font-size:1.6rem;color:var(--c-olive);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)}

.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-olive)}

.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:#b3261e}
.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-olive);box-shadow:0 0 0 3px rgba(72,91,18,.18)}
.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:#eef3e2;color:#3c4d10;border:1px solid #93a85a}
.form-msg.err{display:block;background:#fbe9e7;color:#9b2c1f;border:1px solid #e1897d}

.tabs{display:flex;gap:.6rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}
.tab-btn{font-family:var(--font-body);font-weight:600;padding:.7rem 1.4rem;border-radius:var(--radius-pill);border:2px solid var(--c-neutral);background:#fff;color:var(--c-text);cursor:pointer;transition:all .2s var(--ease)}
.tab-btn.active{background:var(--c-olive);color:#fff;border-color:var(--c-olive)}
.tab-panel{display:none}
.tab-panel.active{display:block}

.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-peach)}
.footer-brand img{height:56px;margin-bottom:1rem;background:#fff;border-radius:10px;padding:6px}
.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}

.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-olive)}
.fab--top{background:var(--c-bronze);opacity:0;pointer-events:none}
.fab--top.show{opacity:1;pointer-events:auto}

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

@media(max-width:900px){
  .grid--3,.testi{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-grid{grid-template-columns:1fr;min-height:auto}
  .hero-img{min-height:60vh;order:-1}
  .hero-text{padding-top:calc(var(--header-h) + 2.5rem)}
}
@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:var(--c-cream);padding:1.5rem;gap:1.2rem;box-shadow:var(--shadow);border-top:1px solid var(--c-neutral)}
  .grid--3,.grid--2,.testi,.form-row,.footer-grid{grid-template-columns:1fr}
}
@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}
}
