/ * === Globales Basis-Stylesheet für alle Seiten === */
:root{
  --bg:#fff5e9;
  --container:#fdecd5;
  --ink:#663a1f;
  --border:#fbe2c1;
  --brand:#663a1f;
  --radius:18px;
  --shadow:0 18px 50px rgba(102,58,31,.10);

  --btn-radius:44px;
  --btn-pad-y:16px;
  --btn-pad-x:28px;
  --btn-border:2px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  letter-spacing:.1px;
  -webkit-tap-highlight-color:transparent;
}

/* Layout */
.container{max-width:1120px;margin:0 auto;padding:0 24px}
.section{padding:88px 0}
.alt{background:var(--container);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.hr{height:1px;background:var(--border);opacity:.9;border:0}
.center{text-align:center}

/* Header (Desktop) */
.site-header{
  position:sticky;top:0;z-index:1000;
  background:rgba(255,245,233,.75);
  backdrop-filter:saturate(180%) blur(8px);
  border-bottom:1px solid var(--border);
}
.nav{
  height:72px;
  display:flex;align-items:center;justify-content:space-between;
}
.brand{display:flex;gap:12px;align-items:center;text-decoration:none;color:var(--ink);font-weight:700}
.brand img{width:40px;height:40px;border-radius:14px;object-fit:cover}
.brand span{font-size:20px}
.nav-links{display:flex;gap:22px;align-items:center}
.nav-links a{color:var(--ink);text-decoration:none;font-size:14px;opacity:.85}
.nav-links a:hover{opacity:1}

/* aktiver Menüpunkt */
.nav-links a[aria-current="page"]{opacity:1;position:relative}
.nav-links a[aria-current="page"]::after{
  content:"";position:absolute;left:0;right:0;bottom:-8px;height:2px;background:var(--ink);opacity:.6;border-radius:2px;
}

/* Burger-Button (wird am Handy eingeblendet) */
.menu-toggle{display:none;width:32px;height:24px;padding:0;border:none;background:transparent;cursor:pointer;flex-direction:column;justify-content:space-between}
.menu-toggle span{display:block;height:3px;border-radius:999px;background:var(--ink);transition:transform .25s ease,opacity .25s ease}
.nav-scrim{display:none}

/* Mobile menu social (base hidden) */
.nav-social{ display:none; }
.nav-social .icons{ display:flex; gap:12px; }
.nav-social .social{ width:40px; height:40px; border-radius:999px; display:inline-flex; align-items:center; justify-content:center; background:#fff; color:var(--ink); text-decoration:none; box-shadow:0 4px 12px rgba(102,58,31,.08); border:1px solid rgba(102,58,31,.08); }
.nav-social .social span{ font-size:12px; font-weight:800; letter-spacing:.5px; }

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;text-align:center;
  padding:var(--btn-pad-y) var(--btn-pad-x);
  border-radius:var(--btn-radius);
  border:var(--btn-border) solid var(--brand);
  font-weight:800;font-size:18px;line-height:1;
  color:#fff;background:var(--brand);
  text-decoration:none;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
}
.btn-outline{background:transparent;color:var(--brand)}
.btn:hover{transform:translateY(-1px)}
.cta-row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}

/* Reveal (sanftes Einblenden) */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .6s ease, transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Footer (global, shared) */
.site-footer{border-top:1px solid var(--border)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:24px 16px}
.footer-inner p{margin:0;white-space:nowrap}
.footer-links{display:flex;gap:18px;align-items:center}
.footer-links a{color:var(--ink);text-decoration:none;font-size:14px;opacity:.85}
.footer-links a:hover{opacity:1}

@media (max-width:768px){
  .footer-inner{flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:10px}
  .footer-links{gap:14px;flex-wrap:wrap;justify-content:center}
}

/* Mobile Header / Menü */
@media (max-width:768px){
  html,body{max-width:100%;overflow-x:hidden}
  .site-header{
    background:rgba(255,245,233,.96);
    box-shadow:0 4px 18px rgba(102,58,31,.08);
    padding-top:env(safe-area-inset-top);
  }
  .nav{height:72px;justify-content:center;position:relative}
  .brand{position:absolute;left:50%;transform:translateX(-50%)}
  .brand span{display:none}
  .brand img{width:68px;height:68px;border-radius:999px;box-shadow:0 6px 18px rgba(102,58,31,.12)}
  .menu-toggle{display:flex;position:absolute;right:18px;top:50%;transform:translateY(-50%);z-index:2000}

  .nav-links{
    position:fixed;left:0;right:0;top:72px;
    height:calc(100dvh - 72px);min-height:calc(100vh - 72px);
    display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:24px;
    padding:24px 16px max(24px, env(safe-area-inset-bottom));
    background:linear-gradient(180deg, rgba(255,245,233,.98) 0%, rgba(255,245,233,.96) 100%);
    backdrop-filter:blur(10px);
    transform:translateY(-100%);opacity:0;pointer-events:none;
    transition:transform .26s ease, opacity .26s ease;z-index:1500;
  }
  .nav-links a{font-size:18px;opacity:.75;padding:12px 16px;border:0;background:transparent;box-shadow:none;border-radius:12px;font-weight:700;letter-spacing:.2px}
  .nav-links a[aria-current="page"]{ color: var(--brand); opacity:1; }
  .nav-links a[aria-current="page"]::after{ display:none; }
  .nav-links a:active{transform:translateY(1px)}
  .nav-scrim{display:block;position:fixed;inset:72px 0 0 0;background:rgba(0,0,0,.15);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1400}
  .nav-social{ display:flex; flex-direction:column; align-items:center; gap:10px; margin-top:auto; padding-top:18px; border-top:1px solid var(--border); }
  .nav-social .caption{ font-size:12px; opacity:.75; }
  .nav-open .nav-links{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-open .nav-scrim{opacity:1;pointer-events:auto}
  .nav-open .menu-toggle span:nth-child(1){transform:translateY(10px) rotate(45deg)}
  .nav-open .menu-toggle span:nth-child(2){opacity:0}
  .nav-open .menu-toggle span:nth-child(3){transform:translateY(-10px) rotate(-45deg)}
}
/* ===== FAQ width + mobile tuning (global) ===== */
#faq .cards{
  /* weniger breit, mittig wie die anderen Bereiche */
  max-width: 960px;
  margin: 0 auto;
  grid-template-columns: 1fr !important; /* eine Spalte */
  gap: 16px;
}

#faq .card{
  padding: 22px 24px;
  border-radius: 18px;
}
#faq .card h3{ margin: 0 0 8px; }
#faq .card p{  margin: 0; }

/* Mobil: noch etwas kompakter und mit Randabstand */
@media (max-width: 768px){
  #faq .cards{ max-width: 92vw; gap: 12px; }
  #faq .card{  padding: 18px; }
}
/* === Unified hero headline (global) === */
.hero-content h1, /* index & beratung */
.hero h1 {        /* app and other pages */
  font-size: clamp(36px, 7vw, 100px);
  line-height: 1.04;
  margin: 0 0 10px;
  letter-spacing: -.02em;
  color: var(--ink);
}

/* Headings color default (fallback for pages without hero blocks) */
h1,h2,h3,h4,h5,h6{ color: var(--ink); }