/* Webfont – schnell über CDN. Für DSGVO später lokal hosten. */
@import url('https://fonts.googleapis.com/css2?family=Sofia+Sans:wght@400;600&display=swap');

/* ================================
   Design Tokens
================================ */
:root{
  --bg:#fffdfa;
  --ink:#1e1c19;
  --muted:#6d665f;

  --brand:#B9844D;
  --brand-700:#855f36;
  --accent:#53A339;
  --paper:#f4eee7;
  --line:#e6ded5;

  /* Fonts */
  --ff-sans:"Sofia Sans",system-ui,-apple-system,"Segoe UI",Roboto,Inter,Arial,sans-serif;
  --ff-serif:"Georgia",ui-serif,serif; /* nur für Hero-H1 */

  --fs-900:clamp(32px,3.2vw,48px);
  --fs-800:clamp(26px,2.6vw,36px);
  --fs-700:clamp(22px,2.2vw,28px);
  --fs-600:20px; --fs-500:18px; --fs-400:16px; --fs-300:14px;

  --radius:14px; --gap:22px; --container:1120px;
}

/* ================================
   Base
================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font:var(--fs-400)/1.65 var(--ff-sans);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  letter-spacing:.005em;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
p{margin:0 0 1rem}
.lead{font-size:var(--fs-500);color:var(--muted)}
.small{font-size:var(--fs-300);color:var(--muted)}
hr{border:0;height:1px;background:var(--line);margin:2.4rem 0}

.container{width:min(100% - 2rem,var(--container));margin-inline:auto}
.section{padding:clamp(36px,6vw,80px) 0}
.section--tight{padding:32px 0}

/* ================================
   Typografie Überschriften
   (wie auf deinem Screenshot: Sans, keine Versalien)
================================ */
h1,h2,h3{
  font-family:var(--ff-sans);
  font-weight:600;
  letter-spacing:.01em;
  margin:0 0 .6rem;
  color:var(--ink);
}
h1{font-size:clamp(28px,2.8vw,44px); line-height:1.25}
h2{font-size:clamp(24px,2.4vw,36px); line-height:1.3}
h3{font-size:var(--fs-600); line-height:1.3}

/* Ausnahme: Start-Hero-Überschrift (Claim) bleibt Serif & Uppercase */
.hero h1{
  font-family:var(--ff-serif);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:.06em;
  font-size:var(--fs-900);
  line-height:1.22;
  margin:0 0 .4rem;
}

/* ================================
   Header / Navigation
================================ */
.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:#fff;
  border-bottom:1px solid var(--line);
  backdrop-filter:saturate(120%) blur(6px);
}

.nav{display:flex;align-items:center;gap:20px;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.brand img{height:42px;width:auto;object-fit:contain}
.brand__name{font-weight:600;letter-spacing:.02em}

/* Desktop: Navi mittig, Logo links */
@media (min-width:861px){
  .nav{
    display:grid;
    grid-template-columns:1fr auto 1fr;  /* links Logo | Mitte Navi | rechts leer */
    align-items:center;
    gap:20px;
  }
  .brand{margin:0;justify-self:start}
  .nav__items{justify-self:center}
}

.nav__items{display:flex;align-items:center;gap:12px}
.nav__items a{padding:8px 10px;border-radius:8px;font-weight:600}
.nav__items a.is-active{background:var(--paper)}
.nav__items a:focus-visible{outline:2px solid var(--brand-700);outline-offset:2px}

/* Mobile Burger */
.nav__toggle{display:none}
.nav__burger{display:none;width:44px;height:44px;align-items:center;justify-content:center;cursor:pointer}
.nav__burger span,
.nav__burger span::before,
.nav__burger span::after{
  content:"";
  display:block;
  width:22px;
  height:2px;
  background:var(--ink);
  position:relative;
}
.nav__burger span::before{position:absolute;top:-7px}
.nav__burger span::after{position:absolute;top:7px}

@media (max-width:860px){
  .nav__burger{display:flex}
  .nav__items{
    position:fixed;
    inset:64px 0 auto 0;
    background:#fff;
    border-bottom:1px solid var(--line);
    padding:10px;
    gap:6px;
    display:none;
  }
  .nav__items a{display:block;padding:12px}
  .nav__toggle:checked ~ .nav__items{display:block}
}

/* ================================
   Hero
================================ */
.hero{margin-top:18px;background:linear-gradient(180deg,#fff 0%,#fff 60%,var(--paper) 60%)}
.hero__wrap{
  display:grid;
  gap:clamp(16px,3vw,28px);
  grid-template-columns:1.3fr 1fr;
  align-items:stretch;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
}
.hero__img{aspect-ratio:16/9;width:100%;object-fit:cover}
.hero__pane{background:var(--paper);padding:clamp(18px,3.2vw,32px)}
.kicker{letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-size:var(--fs-300)}
.hero .sub{color:var(--muted);font-size:var(--fs-500)}
.actions{display:flex;gap:10px;margin-top:12px}

.btn{display:inline-block;padding:10px 14px;border-radius:10px;background:var(--brand);color:#fff;font-weight:700;text-decoration:none}
.btn:hover{background:var(--brand-700)}
.btn--ghost{background:transparent;color:var(--brand);border:2px solid var(--brand)}
.btn--ghost:hover{background:var(--paper)}

/* ================================
   Grid / Cards
================================ */
.grid{display:grid;gap:var(--gap)}
.grid--2{grid-template-columns:1fr 1fr}
.grid--3{grid-template-columns:repeat(3,1fr)}
@media (max-width:900px){.grid--3{grid-template-columns:1fr 1fr}}
@media (max-width:640px){
  .grid--2,.grid--3{grid-template-columns:1fr}
  .hero__wrap{grid-template-columns:1fr}
}

.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.card h3{margin:.2rem 0}
.link{font-weight:700;text-underline-offset:2px}

/* ================================
   Media / Utilities
================================ */
.media{border-radius:12px;border:1px solid var(--line);background:#fff}
.checklist{padding-left:1.1rem}
.checklist li{margin:.3rem 0}
.map{display:block;width:100%;aspect-ratio:16/10;background:var(--paper);border:1px solid var(--line);border-radius:12px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ================================
   Footer (responsive, robust)
================================ */
.site-footer{
  border-top:1px solid var(--line);
  background:#fff;
  padding:28px 0;
  margin-top:24px;
}

.footer__grid{
  display:grid;
  gap:12px;
  /* Passt sich automatisch an 1–4 Spalten an, ohne Quetschen */
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  align-items:start;
}

/* Social + Rechtslinks dürfen umbrechen */
.footer__social{ display:flex; gap:.8rem; flex-wrap:wrap; }
.footer__links { display:flex; gap:12px; flex-wrap:wrap; }

/* Klickziele */
.footer__social a{ display:inline-flex; align-items:center; justify-content:center; padding:.25rem; border-radius:8px; }
.footer__social svg{ width:22px; height:22px; }

/* Umbruchverhalten für Kontakt ohne HTML-Änderungen */
.site-footer a[href^="tel:"]    { white-space:nowrap; }      /* Tel bleibt kompakt */
.site-footer a[href^="mailto:"] { overflow-wrap:anywhere; }   /* Mail darf brechen */

/* Feintuning Stufen (optional) */
@media (max-width: 900px){
  .footer__grid{ grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 560px){
  .footer__grid{ grid-template-columns: 1fr; }
}


