

:root {

  --font: "Satoshi", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  
  --bg: #f5f0e8;
  --bg2: #f6efe4;
  --border: rgba(65,44,29,.16);
  --border-soft: rgba(65,44,29,.10);

  --hover-bg: rgba(111,78,55,.06);
  
  --text: rgba(35,24,16,.92);
  --muted: rgba(35,24,16,.62);
  --muted-2: rgba(35,24,16,.148);

  --cta: #6f4e37;
  --cta-2: #4b2f23;

  /* Primär-CTA: Navbar (.nav a.cta) und .btn.primary */
  --cta-btn-gradient: linear-gradient(145deg, rgba(111, 78, 55, 0.98), rgba(75, 47, 35, 0.98));
  --cta-btn-border: rgba(61, 40, 24, 0.2);
  --cta-btn-text: #fff7ed;

  --good: #1f7a4a;
  --good-bg: rgba(31,122,74,.08);

  --shadow: 0 18px 44px rgba(61,40,24,.12);
  --shadow-2: 0 12px 28px rgba(61,40,24,.10);
  
  --radius-sm: 12px;
  --radius: 16px;
  --radius-lg: 22px;
  
  --ring: 0 0 0 3px rgba(111,78,55,.18);

  --bg-noise: url("/assets/bg_noise.webp");

  /* Max. Breite fuer Header-Innenbereiche */
  --layout-max: min(1440px, calc(100% - 2rem));
  /* Einheitliche Content-Wrapper-Breite fuer Seiteninhalte */
  --content-max: min(72rem, calc(100% - 2rem));

  /* Promo-Leiste + Glas-Navbar (Themes überschreiben in themes.css) */
  --promo-bar-gradient: linear-gradient(135deg, #3d2619 0%, #4b2f23 55%, #5a3828 100%);
  --topbar-glass-bg: rgba(255, 252, 248, 0.8);
}

* {
  box-sizing: border-box
}

h1 {
  letter-spacing: -2px;
  line-height: 90%;
}

h3 {
  font-size: 1.35rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--text);
}

html,body {
  height: 100vh;
  width:  100vw;
  font-size: 16px;
}

body {
  margin: 0;
  font-family: var(--font);
  color: var(--text);
  overflow: hidden;
  background-color: var(--bg);
  background-image:
    var(--bg-noise),
    radial-gradient(ellipse 130% 70% at 50% -25%, rgba(111, 78, 55, 0.11), transparent 58%),
    radial-gradient(ellipse 55% 45% at 100% 35%, rgba(75, 47, 35, 0.06), transparent 52%),
    radial-gradient(ellipse 50% 42% at 0% 75%, rgba(111, 78, 55, 0.05), transparent 50%);
  background-repeat: repeat, no-repeat, no-repeat, no-repeat;
  background-blend-mode: lighten, normal, normal, normal;
}

body.has-site-scroll {
  display: flex;
  flex-direction: column;
  height: 100vh;
}

.site-scroll {
  flex: 1;
  min-height: 0;
  width: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.pi {
  font-size: 1rem;
  line-height: 0;
}

.fw-bold {
  font-weight: 700;
}

.border-0 {
  border: 0 !important;
}

.grid-cols-2 {
  grid-template-columns: 1fr 1fr;
}

.grid-cols-3 {
  grid-template-columns: 1fr 1fr 1fr;
}

.grid-cols-4 {
  grid-template-columns: 1fr 1fr 1fr 1fr;
}

.grid-cols-5 {
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
}

.grid-cols-6 {
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
}

.mono {
  font-variant-numeric: tabular-nums;
}

.muted {
  color: var(--muted);
}

.pill { 
    font-size: 0.75rem;
    color: rgba(35,24,16,.78);
    border: 1px solid rgba(111,78,55,.18);
    background: rgba(111,78,55,.06);
    padding: 6px 10px;
    border-radius: 999px;
    display: flex;
    align-items: center;
    gap: 3px;
    white-space: nowrap;
}

/* Zentrierter Seitenrahmen (alle Seiten außer App — dort volle Breite) */
.site-wrap {
  box-sizing: border-box;
  width: 100%;
  max-width: var(--content-max);
  margin-inline: auto;
  padding-inline: clamp(1rem, 4vw, 2rem);
  padding-block: 1.5rem;
  min-height: calc(100vh - 5rem);
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

/* Kein flex-grow: sonst wird main künstlich voller Viewport-Höhe und der Footer sitzt unter leerem Raum */
body.has-site-scroll .site-wrap {
  flex: 0 0 auto;
  min-height: unset;
  overflow: visible;
}

@media (min-width: 900px) {
  h2 {
    text-align: left;
  }
}

.simple-page h1 {
  font-size: 1.75rem;
  font-weight: 700;
  margin: 0 0 1rem;
  color: var(--text);
}

.simple-page p {
  margin: 0 0 1rem;
  line-height: 1.55;
  color: var(--muted);
}
