@import url('./tokens.css');

/* =========================================================
   @font-face — lokal ausgeliefert (DSGVO, kein Google-CDN)
   ========================================================= */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 300 600;
  font-display: swap;
  src: url('/assets/fonts/Fraunces-Roman.woff2') format('woff2');
}
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 300 500;
  font-display: swap;
  src: url('/assets/fonts/Fraunces-Italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/assets/fonts/Inter.woff2') format('woff2');
}

/* =========================================================
   Reset (minimal)
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-rendering: optimizeLegibility; }
body, h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd, ul, ol { margin: 0; }
ul, ol { padding-left: 0; list-style: none; }
img, picture, svg { display: block; max-width: 100%; height: auto; }
button { font: inherit; color: inherit; background: none; border: 0; padding: 0; cursor: pointer; }
a { color: inherit; text-decoration: none; }
input, textarea, select { font: inherit; color: inherit; }

/* =========================================================
   Base
   ========================================================= */
html {
  font-size: 100%;
  scroll-behavior: smooth;
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

body {
  position: relative;
  font-family: var(--font-body);
  font-size: var(--text-2);
  line-height: var(--leading-body);
  letter-spacing: var(--tracking-body);
  color: var(--color-ink);
  background: var(--color-canvas);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* Verhindert horizontalen Scroll durch die Cloudy-Pseudoelemente,
     die mit left/right: -8% bewusst über die Sektionskante hinausragen. */
  overflow-x: clip;
}

::selection {
  background: var(--color-accent);
  color: var(--color-canvas);
}

h1, h2, h3, h4 {
  font-family: var(--font-display-serif);
  font-weight: 400;
  line-height: var(--leading-display);
  letter-spacing: var(--tracking-display);
  color: var(--color-ink);
  text-wrap: balance;
}

p { max-width: var(--max-w-prose); }

/* Skip-Link */
.skip-link {
  position: absolute;
  top: 0;
  left: 0;
  padding: var(--space-3) var(--space-4);
  background: var(--color-ink);
  color: var(--color-canvas);
  z-index: 100;
  transform: translateY(-110%);
  transition: transform 200ms ease-out;
}
.skip-link:focus { transform: translateY(0); outline: 2px solid var(--color-accent); outline-offset: 2px; }

/* =========================================================
   Layout primitives
   ========================================================= */
.container {
  width: 100%;
  max-width: var(--max-w-content);
  margin-inline: auto;
  padding-inline: var(--space-4);
}
@media (min-width: 768px) {
  .container { padding-inline: var(--space-6); }
}
@media (min-width: 1100px) {
  .container { padding-inline: var(--space-7); }
}

.section {
  padding-block: var(--space-7);
  background: transparent;
  --section-tint: var(--color-canvas);
  color: var(--color-ink);
  scroll-margin-top: 5.5rem; /* A3: clear sticky header on anchor jumps */
}
@media (min-width: 768px) {
  .section { padding-block: 4rem; }
}

/* A4: Off-screen accessibility helper (visually hidden, screen-reader visible) */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.section--paper { --section-tint: var(--color-paper); }

.section--stage {
  background: var(--color-canvas-stage);
  color: var(--color-ink);
}
.section--stage h1, .section--stage h2, .section--stage h3, .section--stage h4 {
  color: var(--color-ink);
}
.section--stage .eyebrow { color: var(--color-accent); }
.section--stage .ink-mute { color: var(--color-ink-mute); }
.section--stage hr,
.section--stage .rule { background: var(--color-line); }

/* 7/4 Asymmetric grid (design.md §Layout) */
.split-7-4 {
  display: grid;
  gap: var(--space-6);
}
@media (min-width: 900px) {
  .split-7-4 {
    grid-template-columns: 7fr 1fr 4fr;
    gap: 0;
    column-gap: var(--space-6);
    align-items: start;
  }
  .split-7-4 > :nth-child(1) { grid-column: 1; }
  .split-7-4 > :nth-child(2) { grid-column: 3; }
  /* Reverse: image on the left, text on the right — image stays narrow (4fr), text wide (7fr) */
  .split-7-4--reverse { grid-template-columns: 4fr 1fr 7fr; }
  .split-7-4--reverse > :nth-child(1) { grid-column: 3; }
  .split-7-4--reverse > :nth-child(2) { grid-column: 1; grid-row: 1; }
}

/* =========================================================
   Typography utilities
   ========================================================= */
.eyebrow {
  font-family: var(--font-body);
  font-size: var(--text-1);
  font-weight: 500;
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-accent);
  margin-bottom: var(--space-4);
  display: inline-block;
}

.lead {
  font-size: var(--text-3);
  line-height: 1.45;
  color: var(--color-ink);
  max-width: 56ch;
}

.ink-mute { color: var(--color-ink-mute); }

.display-1 {
  /* B3: cap auf ~80 px für Großbildschirme erweitert (über design.md text-6) */
  font-size: clamp(2.4rem, 5.5vw + 0.5rem, 5rem);
}
.display-2 {
  font-size: clamp(1.9rem, 4vw + 0.5rem, var(--text-5));
}
.display-3 {
  font-size: clamp(1.4rem, 2vw + 0.5rem, var(--text-4));
}

.pull-quote {
  font-family: var(--font-display-serif);
  font-style: italic;
  font-size: clamp(1.4rem, 2vw + 0.5rem, var(--text-4));
  line-height: 1.35;
  border-left: 1px solid var(--color-accent);
  padding-left: var(--space-5);
  margin-block: var(--space-6);
  color: var(--color-ink);
  max-width: 38ch;
}

.rule {
  height: 1px;
  background: var(--color-line);
  border: 0;
  margin-block: var(--space-6);
}

.meta {
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
}

/* =========================================================
   Links & buttons
   ========================================================= */
.link {
  color: var(--color-ink);
  border-bottom: 1px solid var(--color-accent);
  padding-bottom: 1px;
  transition: color 200ms ease-out, border-color 200ms ease-out;
}
.link:hover { color: var(--color-accent); border-color: var(--color-accent-rose); }
.section--stage .link { color: var(--color-ink); }
.section--stage .link:hover { color: var(--color-accent); }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-4) var(--space-6);
  font-family: var(--font-body);
  font-size: var(--text-2);
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0;
  background: var(--color-accent-sage);
  color: var(--color-ink);
  border: 1px solid var(--color-accent-sage);
  border-radius: 4px;
  transition: background-color 200ms ease-out, color 200ms ease-out, border-color 200ms ease-out;
  min-height: 48px;
}
.btn:hover { background: var(--color-ink); color: var(--color-canvas); border-color: var(--color-ink); }

.btn--quiet {
  background: transparent;
  color: var(--color-ink);
  border-color: var(--color-accent-sage);
}
.btn--quiet:hover { background: var(--color-accent-sage); color: var(--color-ink); }

/* =========================================================
   Focus styles (WCAG AA)
   ========================================================= */
:focus { outline: none; }
:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
  border-radius: 1px;
}
.btn:focus-visible { outline-offset: 4px; }

/* =========================================================
   Site navigation
   ========================================================= */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--color-canvas);
  isolation: isolate;
  border-bottom: 1px solid transparent;
  transition: border-color 200ms ease-out, background-color 200ms ease-out;
}
.site-nav.is-scrolled { border-bottom-color: var(--color-line); }

.site-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding-block: var(--space-4);
}

.site-nav__brand {
  font-family: var(--font-display-serif);
  font-style: italic;
  font-weight: 400;
  font-size: var(--text-3);
  letter-spacing: -0.01em;
  color: var(--color-ink);
}
.site-nav__brand span { display: inline-block; }

.site-nav__menu {
  display: none;
}
.site-nav__menu a {
  font-size: var(--text-2);
  color: var(--color-ink);
  padding-block: var(--space-2);
  transition: color 200ms ease-out;
}
.site-nav__menu a:hover { color: var(--color-accent); }
.site-nav__menu a[aria-current="page"] { border-bottom: 1px solid var(--color-accent); }

@media (min-width: 900px) {
  .site-nav__menu {
    display: flex;
    align-items: center;
    gap: var(--space-6);
  }
}

.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
}
.lang-switch a {
  color: var(--color-ink-mute);
  padding: var(--space-1) var(--space-2);
  transition: color 200ms ease-out;
}
.lang-switch a:hover { color: var(--color-ink); }
.lang-switch a[aria-current="page"] {
  color: var(--color-ink);
  border-bottom: 1px solid var(--color-accent);
}
.lang-switch__sep {
  width: 1px;
  height: 12px;
  background: var(--color-line);
}

/* Mobile nav toggle */
.nav-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border: 1px solid var(--color-line);
  background: transparent;
  color: var(--color-ink);
}
.nav-toggle__bars { display: block; width: 18px; height: 1px; background: currentColor; position: relative; }
.nav-toggle__bars::before,
.nav-toggle__bars::after {
  content: ""; position: absolute; left: 0; width: 18px; height: 1px; background: currentColor;
  transition: transform 250ms ease-out, top 250ms ease-out;
}
.nav-toggle__bars::before { top: -6px; }
.nav-toggle__bars::after { top: 6px; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bars { background: transparent; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bars::before { top: 0; transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bars::after { top: 0; transform: rotate(-45deg); }

@media (min-width: 900px) {
  .nav-toggle { display: none; }
}

.site-nav__lang-desktop { display: none; }
@media (min-width: 900px) {
  .site-nav__lang-desktop { display: inline-flex; }
}

/* Mobile overlay menu */
.mobile-menu {
  position: fixed;
  inset: 0;
  background: var(--color-canvas);
  z-index: 60;
  display: flex;
  flex-direction: column;
  padding: var(--space-6) var(--space-4);
  transform: translateY(-100%);
  opacity: 0;
  transition: transform 350ms ease-out, opacity 250ms ease-out;
  pointer-events: none;
  overflow-y: auto;
}
.mobile-menu[data-open="true"] {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}
.mobile-menu__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-6);
}
.mobile-menu__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  flex: 1;
}
.mobile-menu__list a {
  font-family: var(--font-display-serif);
  font-size: var(--text-4);
  color: var(--color-ink);
  padding-block: var(--space-2);
}
.mobile-menu__footer {
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-line);
}
@media (min-width: 900px) {
  .mobile-menu { display: none; }
}

/* =========================================================
   Hero
   ========================================================= */
.hero {
  padding-block: var(--space-7) var(--space-7);
  background: transparent;
  --section-tint: var(--color-canvas);
}
@media (min-width: 768px) {
  .hero { padding-block: 4rem 4rem; }
}

/* Hero-Inner: 2-Spalten-Grid auf Desktop (Text 7/12 · Gutter 1/12 · Foto 4/12),
   gestapelt auf Mobile mit Foto zuerst (Gesicht im ersten Eindruck). */
.hero__inner {
  display: grid;
  gap: var(--space-5);
  grid-template-areas:
    "media"
    "text";
}
@media (min-width: 768px) {
  .hero__inner {
    /* Text und Foto je max. 32rem (= 512 px) → optisch balanciert.
       Mittlere Spalte ist flexible Gutter (min space-5 = 24 px).
       Auf schmalen Viewports schrumpfen die minmax-Spalten unter 32rem. */
    grid-template-columns: minmax(0, 32rem) minmax(var(--space-5), 1fr) minmax(0, 32rem);
    grid-template-areas: "text gutter media";
    align-items: start;
    gap: 0;
  }
}
.hero__text {
  grid-area: text;
  /* Text-Breite gelockt: bei Desktop fix auf 32rem (= aktuelle 52-ch-Wirkung),
     bei schmaleren Viewports schrumpft auf Zellbreite. */
  width: min(32rem, 100%);
}
.hero__media {
  grid-area: media;
  /* JS (script.js → alignHeroMedia) setzt inline marginTop + height so,
     dass die Bild-Oberkante pixelgenau an der H1-Oberkante steht und die
     Bild-Unterkante an der Unterkante des letzten Text-Elements (.hero__cta-hint).
     overflow:hidden, damit object-fit:cover sauber zuschneidet. */
  overflow: hidden;
}
.hero__media picture {
  /* picture sitzt zwischen figure und img — muss selbst die Höhe weiterreichen,
     sonst nimmt es die intrinsische Img-Höhe an und cover greift nicht. */
  display: block;
  width: 100%;
  height: 100%;
}
.hero__media img {
  display: block;
  width: 100%;
  height: 100%; /* fällt auf intrinsische Höhe zurück, solange figure keine
                   definite Höhe hat (vor dem JS-Sizing); danach füllt es
                   exakt die JS-gesetzte figure-Höhe und cover greift. */
  object-fit: cover;
  object-position: 50% 35%; /* Subjekt liegt in oberen 30–40 % vertikal */
}
.hero h1 {
  margin-top: var(--space-5);
  margin-bottom: var(--space-6);
  text-wrap: balance;
}
.hero__text p { margin-bottom: var(--space-7); }
.hero__cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
}
/* =========================================================
   Section header
   ========================================================= */
.section__header { margin-bottom: var(--space-6); }
.section__header h2 { margin-bottom: var(--space-4); max-width: 24ch; }
.section__header p { color: var(--color-ink-mute); }

/* =========================================================
   Problem resonance
   ========================================================= */
.resonance {
  font-family: var(--font-display-serif);
  font-size: clamp(1.4rem, 2.5vw + 0.5rem, var(--text-4));
  line-height: 1.4;
  max-width: 30ch;
  color: var(--color-ink);
}
.resonance p + p { margin-top: var(--space-5); }

/* =========================================================
   Methode (split-7-4)
   ========================================================= */
.method__text > * + * { margin-top: var(--space-4); }
.method__text h3 {
  margin-top: var(--space-6);
  font-family: var(--font-body);
  font-size: var(--text-3);
  font-weight: 500;
  letter-spacing: 0;
  color: var(--color-ink);
}
.method__text p { color: var(--color-ink-mute); }

.method-list {
  margin-top: var(--space-5);
  display: grid;
  gap: var(--space-3);
}
.method-list li {
  display: flex;
  gap: var(--space-3);
  align-items: baseline;
  font-size: var(--text-2);
  color: var(--color-ink);
}
.method-list li::before {
  content: "";
  flex: 0 0 8px;
  width: 8px;
  height: 1px;
  background: var(--color-accent);
  margin-top: 0.7em;
}

/* =========================================================
   Offer cards
   ========================================================= */
.offers {
  display: grid;
  gap: var(--space-5);
}
@media (min-width: 900px) {
  .offers { grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
}

.offer-card {
  position: relative;
  z-index: 4; /* über dem globalen Linien-Layer (z:3) */
  display: flex;
  flex-direction: column;
  padding: var(--space-6);
  background: var(--color-paper);
  border: 1px solid var(--color-line);
}
.offer-card h3 {
  font-family: var(--font-display-serif);
  font-size: var(--text-4);
  margin-block: var(--space-3) var(--space-4);
}
.offer-card .eyebrow { margin-bottom: var(--space-1); }
.offer-card__body { color: var(--color-ink-mute); }

.offer-card__prices {
  margin-block: var(--space-5);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-line);
  display: grid;
  gap: var(--space-3);
}
.offer-card__price-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--space-3);
  align-items: baseline;
}
.offer-card__price-row .price {
  font-family: var(--font-display-serif);
  font-size: var(--text-3);
  color: var(--color-ink);
}
.offer-card__price-row .label {
  font-size: var(--text-2);
  color: var(--color-ink);
}
.offer-card__price-row .meta {
  text-align: right;
}

.offer-card__context {
  font-size: var(--text-1);
  color: var(--color-ink-mute);
  margin-top: var(--space-3);
  line-height: 1.5;
}

.offer-card__cta {
  margin-top: auto;
  padding-top: var(--space-5);
}

/* =========================================================
   Retreats / Events (Stage-Theme)
   ========================================================= */
.events__sub {
  font-size: var(--text-2);
  color: var(--color-accent);
  margin-bottom: var(--space-5);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
}

.event-list {
  list-style: none;
  padding: 0;
  margin: var(--space-6) 0 0;
  display: grid;
  gap: 0;
  border-top: 1px solid var(--color-line);
}
.event-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  padding-block: var(--space-6);
  border-bottom: 1px solid var(--color-line);
}
@media (min-width: 820px) {
  .event-card {
    grid-template-columns: 12rem 1fr auto;
    align-items: start;
    column-gap: var(--space-6);
    row-gap: var(--space-3);
  }
}
.event-card__eyebrow {
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
  grid-column: 1 / -1;
}
@media (min-width: 820px) {
  .event-card__eyebrow { grid-column: 1; align-self: baseline; }
}
.event-card__title {
  font-family: var(--font-display-serif);
  font-size: var(--text-4);
  line-height: 1.15;
  color: var(--color-ink);
  margin: 0;
}
@media (min-width: 820px) {
  .event-card__title { grid-column: 2; }
}
.event-card__meta {
  display: grid;
  gap: var(--space-2);
  margin: 0;
  font-size: var(--text-1);
  color: var(--color-ink-mute);
}
.event-card__meta > div { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.event-card__meta dt {
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  min-width: 4rem;
  color: var(--color-ink-mute);
  opacity: 0.7;
}
.event-card__meta dd { margin: 0; color: var(--color-ink); }
@media (min-width: 820px) {
  .event-card__meta { grid-column: 2; }
}
.event-card__desc {
  color: var(--color-ink);
  max-width: 52ch;
  margin: 0;
}
@media (min-width: 820px) {
  .event-card__desc { grid-column: 2; }
}
.event-card .btn,
.event-card .link {
  justify-self: start;
  align-self: start;
}
@media (min-width: 820px) {
  .event-card .btn,
  .event-card .link { grid-column: 3; grid-row: 2 / span 2; align-self: center; }
}

.event-list__status,
.event-list__empty {
  margin-top: var(--space-5);
  color: var(--color-ink-mute);
  max-width: 40rem;
}
.event-list__status--error { color: var(--color-accent-rose); }

.event-empty {
  margin-top: var(--space-5);
  color: var(--color-ink-mute);
  max-width: 40rem;
}

/* Event-Tabs: Retreats / Berliner Sessions — ruhig, ohne SaaS-Bouncing. */
.event-tabs {
  position: relative;
  z-index: 4;
  margin-top: var(--space-6);
}
.event-tabs__list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-6);
  border-bottom: 1px solid var(--color-line);
  margin-bottom: var(--space-6);
}
.event-tabs__tab {
  font-family: var(--font-display-serif);
  font-size: var(--text-3);
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: var(--tracking-display);
  color: var(--color-ink-mute);
  background: transparent;
  border: 0;
  border-bottom: 1px solid transparent;
  padding: var(--space-3) 0;
  margin-bottom: -1px;
  cursor: pointer;
  transition: color 200ms ease-out, border-color 200ms ease-out;
}
.event-tabs__tab:hover { color: var(--color-ink); }
.event-tabs__tab[aria-selected="true"] {
  color: var(--color-ink);
  border-bottom-color: var(--color-accent);
}
.event-tabs__tab:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 4px;
}

/* Mehr/Weniger-Toggle — zentriert unter der ersten Card,
   Text in Sage darüber, V-Pfeil in transparentem Weiß darunter,
   Pfeil pulsiert sanft nach unten als Klick-Einladung. */
.event-more__toggle {
  position: relative;
  z-index: 4;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  margin: 1.25rem auto 0;
  padding: var(--space-3) var(--space-5);
  background: transparent;
  border: 0;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 0.9rem;
  font-weight: 500;
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  width: fit-content;
}
.event-more__toggle-text {
  color: var(--color-accent-moss);
  transition: color 200ms ease-out;
  display: inline-block;
}
.event-more__toggle-icon-wrap {
  display: inline-block;
  transition: transform 300ms ease-out;
}
.event-more__toggle-icon {
  display: block;
  color: rgba(255, 255, 255, 0.65);
  transition: color 200ms ease-out;
}
@keyframes event-more-bounce {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(3px); }
}
.event-more__toggle:not([aria-expanded="true"]) .event-more__toggle-text,
.event-more__toggle:not([aria-expanded="true"]) .event-more__toggle-icon {
  animation: event-more-bounce 1.8s ease-in-out infinite;
}
.event-more__toggle[aria-expanded="true"] .event-more__toggle-icon-wrap {
  transform: rotate(180deg);
}
.event-more__toggle:hover .event-more__toggle-text { color: var(--color-ink); }
.event-more__toggle:hover .event-more__toggle-icon { color: rgba(255, 255, 255, 0.9); }
.event-more__toggle:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 4px;
}
@media (prefers-reduced-motion: reduce) {
  .event-more__toggle-icon { animation: none !important; }
  .event-more__toggle-icon-wrap { transition: none; }
}

/* Berliner Sessions — kompakte Line-Items, keine Bilder. */
.event-line-list {
  position: relative;
  z-index: 4;
  display: grid;
  gap: 0;
  border-top: 1px solid var(--color-line);
  margin-top: 0;
}
.event-line {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  padding-block: var(--space-5);
  border-bottom: 1px solid var(--color-line);
}
@media (min-width: 760px) {
  .event-line {
    grid-template-columns: 9rem 1fr auto;
    gap: var(--space-5);
    align-items: baseline;
  }
}
.event-line__date {
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
}
.event-line__title {
  font-size: var(--text-2);
  font-weight: 500;
  color: var(--color-ink);
  margin: 0;
}
.event-line__meta {
  font-size: var(--text-1);
  color: var(--color-ink-mute);
  margin: var(--space-1) 0 0;
  max-width: none;
}
.event-line__cta {
  font-size: var(--text-2);
  color: var(--color-ink);
  border-bottom: 1px solid var(--color-accent);
  padding-bottom: 1px;
  justify-self: start;
}
@media (min-width: 760px) {
  .event-line__cta { justify-self: end; }
}
.event-line__cta:hover { color: var(--color-accent); }

.event-line-empty {
  padding-block: var(--space-6);
  color: var(--color-ink-mute);
  max-width: 50rem;
}
.event-line-empty a { color: var(--color-ink); border-bottom: 1px solid var(--color-accent); }

/* Featured retreat card — Poster links, Detailblock rechts; Mobile stapelt. */
.event-featured {
  position: relative;
  z-index: 4;
  display: grid;
  gap: var(--space-6);
  background: var(--color-paper);
  border: 1px solid var(--color-line);
  padding: var(--space-5);
  margin-top: var(--space-6);
}
@media (min-width: 820px) {
  .event-featured {
    grid-template-columns: minmax(220px, 320px) 1fr;
    gap: var(--space-7);
    padding: var(--space-6);
    align-items: start;
  }
}
.event-featured__media {
  margin: 0;
  overflow: hidden;
  background: var(--color-line);
  aspect-ratio: 9 / 16;
}
.event-featured__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.event-featured__body > * + * { margin-top: var(--space-4); }
.event-featured__title {
  font-family: var(--font-display-serif);
  font-size: clamp(1.6rem, 2.5vw + 0.5rem, var(--text-5));
  line-height: 1.1;
  margin: var(--space-2) 0 0;
  max-width: 18ch;
}
.event-featured__meta {
  display: grid;
  gap: var(--space-2);
  margin: var(--space-5) 0;
  padding-block: var(--space-4);
  border-top: 1px solid var(--color-line);
  border-bottom: 1px solid var(--color-line);
}
.event-featured__meta > div {
  display: grid;
  grid-template-columns: 6rem 1fr;
  gap: var(--space-3);
  align-items: baseline;
  font-size: var(--text-2);
}
.event-featured__meta dt {
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
  margin: 0;
}
.event-featured__meta dd {
  margin: 0;
  color: var(--color-ink);
}
.event-featured__body p { color: var(--color-ink); max-width: 52ch; }
.event-featured__cta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
}
.event-featured__status {
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-accent);
}
.event-empty p { color: inherit; }

.event-retreat-hint {
  margin-top: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-line);
  color: var(--color-ink-mute);
  max-width: 48rem;
  font-size: var(--text-2);
}
.event-retreat-hint .link { color: var(--color-ink); }

/* =========================================================
   Bio split (Über Louisa)
   ========================================================= */
.bio__text > * + * { margin-top: var(--space-4); }
.bio__text p { color: var(--color-ink); }
.bio__credentials {
  margin-top: var(--space-5);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-line);
  display: grid;
  gap: var(--space-2);
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
}

/* =========================================================
   Callout (Sicherheit / Kontraindikationen)
   ========================================================= */
.callout {
  position: relative;
  z-index: 4;
  border-left: 1px solid var(--color-accent);
  padding: var(--space-5) var(--space-6);
  background: transparent;
  max-width: 56rem;
}
.callout h3 {
  font-family: var(--font-body);
  font-size: var(--text-3);
  font-weight: 500;
  letter-spacing: 0;
  margin-bottom: var(--space-3);
}
.callout p + p { margin-top: var(--space-3); }
.callout p { color: var(--color-ink); }
.callout .ink-mute { color: var(--color-ink-mute); }

/* =========================================================
   FAQ accordion
   ========================================================= */
.faq { max-width: 56rem; }
.faq details {
  border-top: 1px solid var(--color-line);
  padding-block: var(--space-4);
}
.faq details:last-of-type { border-bottom: 1px solid var(--color-line); }
.faq summary {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  cursor: pointer;
  list-style: none;
  font-family: var(--font-display-serif);
  font-size: var(--text-3);
  line-height: 1.3;
  color: var(--color-ink);
  padding-block: var(--space-2);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+";
  font-family: var(--font-body);
  font-size: var(--text-3);
  color: var(--color-accent);
  transition: transform 250ms ease-out;
  flex-shrink: 0;
  line-height: 1;
}
.faq details[open] > summary::after { content: "−"; }
.faq__body {
  padding-block: var(--space-3) var(--space-2);
  color: var(--color-ink-mute);
  max-width: 62ch;
}
.faq__body > * + * { margin-top: var(--space-3); }

/* =========================================================
   Testimonials placeholder
   ========================================================= */
.testimonials {
  display: grid;
  gap: var(--space-5);
  margin-bottom: var(--space-6);
}
@media (min-width: 900px) {
  .testimonials { grid-template-columns: repeat(3, 1fr); }
}
.testimonial-placeholder {
  position: relative;
  z-index: 4;
  background: var(--color-paper);
  border: 1px solid var(--color-line);
  padding: var(--space-6);
  aspect-ratio: 4 / 5;
  display: flex;
  align-items: flex-end;
}
.testimonial-placeholder span {
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
}

.testimonials__note {
  padding: var(--space-5);
  border: 1px dashed var(--color-line);
  color: var(--color-ink-mute);
  font-style: italic;
  max-width: 56rem;
}

/* =========================================================
   Contact section
   ========================================================= */
.contact {
  display: grid;
  gap: var(--space-7);
}
@media (min-width: 900px) {
  .contact {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-7);
    align-items: start;
  }
}

.contact__pitch p + p { margin-top: var(--space-4); }
.contact__pitch p { color: var(--color-ink); }
.contact__details {
  margin-top: var(--space-6);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-line);
  display: grid;
  gap: var(--space-3);
  font-size: var(--text-2);
}
.contact__details a { color: var(--color-ink); border-bottom: 1px solid var(--color-line); }
.contact__details a:hover { border-color: var(--color-accent); }
.contact__details dt {
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
  margin-bottom: var(--space-1);
}
.contact__details dl > * + * { margin-top: var(--space-4); }

/* Form */
.form { display: grid; gap: var(--space-5); }
.form__group { display: grid; gap: var(--space-2); }
.form__label {
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
}
.form__input,
.form__textarea,
.form__select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-2);
  background: transparent;
  border: 1px solid var(--color-line);
  border-radius: 0;
  color: var(--color-ink);
  transition: border-color 200ms ease-out;
}
.form__input:hover,
.form__textarea:hover,
.form__select:hover { border-color: var(--color-ink-mute); }
.form__input:focus-visible,
.form__textarea:focus-visible,
.form__select:focus-visible {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 2px var(--color-accent) inset;
}
.form__textarea { min-height: 8rem; resize: vertical; font-family: var(--font-body); }
.form__group--row {
  display: grid;
  gap: var(--space-4);
}
@media (min-width: 600px) {
  .form__group--row { grid-template-columns: 1fr 1fr; }
}
.form__hint {
  font-size: var(--text-1);
  color: var(--color-ink-mute);
}
.form__submit-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
  margin-top: var(--space-3);
}
.form__error {
  display: none;
  font-size: var(--text-1);
  color: var(--color-accent-rose);
  margin-top: var(--space-2);
}
.form__error[data-active="true"] { display: block; }

/* =========================================================
   Footer
   ========================================================= */
.site-footer {
  background: var(--color-canvas-stage);
  color: var(--color-ink);
  padding-block: var(--space-7);
}
.site-footer__inner {
  display: grid;
  gap: var(--space-6);
}
@media (min-width: 768px) {
  .site-footer__inner {
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: var(--space-6);
  }
}
.site-footer h3 {
  font-family: var(--font-body);
  font-size: var(--text-1);
  font-weight: 500;
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
  margin-bottom: var(--space-4);
}
.site-footer__brand {
  font-family: var(--font-display-serif);
  font-style: italic;
  font-size: var(--text-4);
  color: var(--color-ink);
  display: inline-block;
  margin-bottom: var(--space-4);
}
.site-footer__tagline {
  color: var(--color-ink-mute);
  font-size: var(--text-2);
  max-width: 36ch;
}
.site-footer ul { display: grid; gap: var(--space-3); }
.site-footer a {
  color: var(--color-ink);
  font-size: var(--text-2);
  border-bottom: 1px solid transparent;
  transition: border-color 200ms ease-out, color 200ms ease-out;
}
.site-footer a:hover { border-bottom-color: var(--color-accent); }
.site-footer .lang-switch a { color: var(--color-ink-mute); }
.site-footer .lang-switch a[aria-current="page"] { color: var(--color-ink); }

.site-footer__bottom {
  margin-top: var(--space-7);
  padding-top: var(--space-5);
  border-top: 1px solid var(--color-line);
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--space-4);
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
}

/* =========================================================
   Image figures (with aspect-ratio + placeholder)
   ========================================================= */
.figure {
  position: relative;
  z-index: 4; /* über dem globalen Linien-Layer (z:3) */
  margin: 0;
  background: var(--color-paper);
  border: 1px solid var(--color-line);
  overflow: hidden;
}
.figure--3-4 { aspect-ratio: 3 / 4; }
.figure--4-5 { aspect-ratio: 4 / 5; }
.figure--16-9 { aspect-ratio: 16 / 9; }
.figure--3-2 { aspect-ratio: 3 / 2; }
.figure img { width: 100%; height: 100%; object-fit: cover; }
.figure--placeholder {
  display: flex;
  align-items: flex-end;
  padding: var(--space-4);
}
.figure--placeholder figcaption {
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
}
.section--stage .figure {
  background: var(--color-line);
  border-color: var(--color-line);
}
.section--stage .figure--placeholder figcaption { color: var(--color-ink-mute); }

/* =========================================================
   Reveal animation (with prefers-reduced-motion respect)
   ========================================================= */
.reveal {
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 500ms ease-out, transform 500ms ease-out;
  will-change: opacity, transform;
}
.reveal.is-in {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}

/* =========================================================
   Misc / Print
   ========================================================= */
@media print {
  .site-nav, .site-footer, .nav-toggle, .mobile-menu, .hero__cta-row, .offer-card__cta { display: none; }
  body { color: #000; background: #fff; }
  a { text-decoration: underline; }
}

/* =========================================================
   Audit-Phase-2-Komponenten
   ========================================================= */

/* A5: Header invertieren, wenn er über einer Stage-Sektion steht */
.site-nav--on-deep {
  background: rgba(237, 227, 210, 0.92);
  color: var(--color-ink);
}
.site-nav--on-deep .site-nav__brand,
.site-nav--on-deep .site-nav__menu a { color: var(--color-ink); }
.site-nav--on-deep.is-scrolled { border-bottom-color: var(--color-line); }
.site-nav--on-deep .nav-toggle { border-color: var(--color-line); color: var(--color-ink); }
.site-nav--on-deep .lang-switch a { color: var(--color-ink-mute); }
.site-nav--on-deep .lang-switch a[aria-current="page"] { color: var(--color-ink); }
.site-nav--on-deep .lang-switch__sep { background: var(--color-line); }

/* Lead-Variante für Stage-Theme (Selbstkritik aus Phase 1) */
.lead--on-deep { color: var(--color-ink-mute); }

/* B1: Trust-Strip im Hero zwischen Sub und CTA */
.hero__trust {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3) var(--space-5);
  align-items: center;
  margin-bottom: var(--space-6);
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
}
.hero__trust span { display: inline-flex; align-items: center; gap: var(--space-2); }
.hero__trust span::before {
  content: "";
  width: 6px;
  height: 6px;
  background: var(--color-accent);
  border-radius: 50%;
  flex-shrink: 0;
}

/* B4: CTA-Hint unter Hero-Button */
.hero__cta-hint {
  margin-top: var(--space-3);
  font-size: var(--text-1);
  color: var(--color-ink-mute);
}

/* C2: Sage-Linie am Resonance-Ende */
.resonance-rule {
  display: block;
  width: 3rem;
  height: 1px;
  background: var(--color-accent);
  border: 0;
  margin: var(--space-6) 0 0;
}

.resonance__exit {
  margin-top: var(--space-5);
  font-size: var(--text-2);
  color: var(--color-ink-mute);
}

/* D1: Methode-Sektion ohne Bild → volle Breite */
.method--solo .method__text {
  max-width: 56rem;
}

/* E1+E2: 1:1-Säule primär markieren + kleiner Button */
.offer-card--primary {
  position: relative;
  border-top: 2px solid var(--color-accent);
}
.btn--small {
  padding: var(--space-3) var(--space-5);
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  min-height: 0;
}

/* E5: Preis-Rows als Flex */
.offer-card__price-row {
  display: flex !important;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-3);
  grid-template-columns: none !important;
}
.offer-card__price-row .meta { text-align: right; }

/* E4: Strapline über Angeboten */
.offers-strapline {
  border-top: 1px solid var(--color-line);
  padding-top: var(--space-5);
  margin-bottom: var(--space-6);
  font-family: var(--font-display-serif);
  font-size: var(--text-3);
  font-style: italic;
  color: var(--color-ink);
  max-width: 50rem;
}

/* F2: Pull-Quote-Streifen in Stage-Theme zwischen Events und Bio */
.pullquote-strip {
  background: transparent;
  color: var(--color-ink);
  padding-block: var(--space-7);
}
.pullquote-strip blockquote {
  font-family: var(--font-display-serif);
  font-style: italic;
  font-size: clamp(1.6rem, 3vw + 0.5rem, 2.4rem);
  line-height: 1.3;
  max-width: 38ch;
  color: var(--color-ink);
  border-left: 1px solid var(--color-accent);
  padding-left: var(--space-5);
}
.pullquote-strip cite {
  display: block;
  margin-top: var(--space-4);
  font-family: var(--font-body);
  font-style: normal;
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-ink-mute);
}

/* G4: Credentials in 2 Spalten Desktop */
@media (min-width: 700px) {
  .bio__credentials {
    grid-template-columns: 1fr 1fr;
    column-gap: var(--space-6);
    row-gap: var(--space-3);
  }
}

/* I3: Linien-Caret für FAQ statt +/− */
.faq summary::after {
  content: none;
}
.faq summary {
  position: relative;
  padding-right: 2rem;
}
.faq summary .faq-caret {
  position: absolute;
  right: 0;
  top: 0.7em;
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.faq summary .faq-caret line {
  stroke: var(--color-accent);
  stroke-width: 1.25;
  stroke-linecap: round;
}
.faq summary .faq-caret line.v {
  transition: opacity 200ms ease-out;
  opacity: 1;
}
.faq details[open] > summary .faq-caret line.v {
  opacity: 0;
}

/* K2: Form-Confirmation nach Submit */
.form__confirm {
  display: none;
  margin-top: var(--space-5);
  padding: var(--space-4) var(--space-5);
  border-left: 1px solid var(--color-accent);
  background: var(--color-paper);
  color: var(--color-ink);
  font-size: var(--text-2);
  line-height: 1.5;
}
.form__confirm[data-active="true"] { display: block; }
.form__confirm strong { font-weight: 500; }

/* L3: Newsletter-Hint in Footer-Spalte */
.site-footer__list-hint {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-line);
  font-size: var(--text-1);
  color: var(--color-ink-mute);
  line-height: 1.5;
}
.site-footer__list-hint a { color: var(--color-ink); border-bottom: 1px solid var(--color-line); }
.site-footer__list-hint a:hover { border-color: var(--color-accent); }

/* L2: Heilpraktiker-Hinweis größer in Tagline-Spalte */
.site-footer__credential {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-line);
  font-size: var(--text-1);
  letter-spacing: var(--tracking-caps);
  text-transform: uppercase;
  color: var(--color-accent);
}

/* M3: Reveal nur auf Sektions-Ebene (eine reveal pro Sektion statt 10) */
.reveal-section {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 600ms ease-out, transform 600ms ease-out;
}
.reveal-section.is-in {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .reveal-section { opacity: 1; transform: none; transition: none; }
}

/* M7: Begriffs-Inline-Note in der EN-Bio */
.term-note {
  font-size: var(--text-1);
  color: var(--color-ink-mute);
  font-style: italic;
  display: block;
  margin-top: var(--space-2);
}

/* =========================================================
   v0.2 — Akzent + Tint-Hintergrund pro Sektions-Thema
   Tint = gewaschene Pastell-Version der Akzentfarbe als Background.
   ========================================================= */
.section--sage  { --section-tint: var(--color-tint-sage); --color-accent: var(--color-accent); }
.section--rose  { --section-tint: var(--color-tint-rose); --color-accent: var(--color-accent-rose); }
.section--clay  { --section-tint: var(--color-tint-clay); --color-accent: var(--color-accent-clay); }
.section--moss  { --section-tint: var(--color-tint-moss); --color-accent: var(--color-accent-moss); }

.section--stage {
  --section-tint: var(--color-tint-clay);
  --color-accent: var(--color-accent-clay);
}
.pullquote-strip {
  --section-tint: var(--color-tint-moss);
  --color-accent: var(--color-accent-moss);
}

/* Cards auf Tint-Sektionen brauchen eine eigene helle Fläche, sonst verschwimmen sie */
.section--sage .offer-card,
.section--rose .offer-card,
.section--clay .offer-card,
.section--moss .offer-card,
.section--stage .offer-card { background: var(--color-paper); }

/* =========================================================
   v0.2 — Wolkige Sektions-Übergänge
   Jede Sektion zeichnet ihren Tint über ein ::before, das nach oben und unten
   in die Nachbar-Sektion hineinwächst und dort weich/turbulent ausläuft.
   Der `cloudy` SVG-Filter (in index.html definiert) macht die Kanten organisch.
   ========================================================= */
.section,
.hero,
.pullquote-strip {
  position: relative;
}
.section::before,
.hero::before,
.pullquote-strip::before {
  content: "";
  position: absolute;
  left: -8%;
  right: -8%;
  top: -180px;
  bottom: -180px;
  background: var(--section-tint);
  z-index: 0;
  mask-image: linear-gradient(
    to bottom,
    transparent 0,
    #000 220px,
    #000 calc(100% - 220px),
    transparent 100%
  );
  -webkit-mask-image: linear-gradient(
    to bottom,
    transparent 0,
    #000 220px,
    #000 calc(100% - 220px),
    transparent 100%
  );
  filter: url(#cloudy);
  pointer-events: none;
  will-change: filter;
}
/* Hero ist das erste Element — oben kein Fade nötig, sonst sieht es ausgefranst aus */
.hero::before {
  top: 0;
  mask-image: linear-gradient(to bottom, #000 0, #000 calc(100% - 220px), transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom, #000 0, #000 calc(100% - 220px), transparent 100%);
}
@media (prefers-reduced-motion: reduce) {
  /* Filter ist auch ohne Animation für manche Devices teuer — abschalten,
     fade-only-Übergang bleibt erhalten */
  .section::before,
  .hero::before,
  .pullquote-strip::before { filter: none; left: 0; right: 0; }
}

/* =========================================================
   v0.2 — Atemlinien (breath-lines)
   Sanft animierte SVG-Wellen, GPU-composited, reduced-motion-safe.
   ========================================================= */
.breath-lines {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
  color: var(--color-accent);
}
.breath-lines svg {
  width: 100%;
  height: 100%;
  display: block;
}
.breath-lines path {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.15;
  vector-effect: non-scaling-stroke;
  opacity: 0.34;
}

/* Globaler Layer — eine Wellenlandschaft über die ganze Seite,
   durchgehend von oben bis unten. Sektionen liegen darüber (z:auto),
   multiply darkens content slightly where lines pass. */
.breath-lines--global {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 3;
  mix-blend-mode: multiply;
  color: var(--color-ink);
  overflow: visible;
}
.breath-lines--global path {
  opacity: 0.13;
  animation: breath-glow 9s ease-in-out infinite alternate;
}
@keyframes breath-glow {
  0%   { opacity: 0.05; }
  50%  { opacity: 0.18; }
  100% { opacity: 0.08; }
}
@media (prefers-reduced-motion: reduce) {
  .breath-lines--global path { animation: none; opacity: 0.12; }
}

/* Textboxen über der Linien-Landschaft — Sektions-Tint mit Alpha, leicht durchscheinend.
   Sharp edges (Designprinzip „klare Kanten"). */
.hero .hero__text,
.section > .container,
.pullquote-strip > .container {
  position: relative;
  z-index: 4; /* über dem globalen Linien-Layer (z:3) */
  background: var(--color-canvas); /* default: Hafer, opak — Linien gehören zum Hintergrund */
  padding-block: var(--space-6);
}
/* Foto muss über das Hero-eigene ::before-Pseudo (z:0, Canvas-getintetes Cloudy-Layer),
   sonst tarnt der Tint das Bild in der Canvas-Farbe. */
.hero .hero__media {
  position: relative;
  z-index: 5;
}
.hero { --section-tint: var(--color-tint-moss); background: var(--color-tint-moss); }
.hero .hero__text { background: var(--color-tint-moss); }
.section--paper > .container { background: var(--color-paper); }
.section--sage  > .container { background: var(--color-tint-sage); }
.section--rose  > .container { background: var(--color-tint-rose); }
.section--clay  > .container,
.section--stage > .container { background: var(--color-tint-clay); }
.section--moss  > .container,
.pullquote-strip > .container { background: var(--color-tint-moss); }
@media (min-width: 768px) {
  .hero .hero__text,
  .section > .container,
  .pullquote-strip > .container {
    padding-block: var(--space-7);
  }
}
/* Footer: Container in canvas-stage Tint (sandiger Hafer) — passend zur Footer-Fläche. */
.site-footer .site-footer__inner {
  position: relative;
  z-index: 4;
  background: rgba(237, 227, 210, 0.78);
  padding: var(--space-6);
}

/* Generische Schutzregel: Bilder und Karten liegen IMMER über dem globalen
   Linien-Layer (z:3), damit Atemlinien ihren Inhalt nie überlagern. Greift
   auch automatisch für neu eingefügte Bilder und Karten. */
img,
picture,
.offer-card,
.figure,
.event-featured__media,
.event-card {
  position: relative;
  z-index: 4;
}

@media (prefers-reduced-motion: reduce) {
  .breath-lines path { animation: none; }
}

/* Dezenter Papier-Grain auf body — subtile Tiefe ohne sichtbare Textur */
body {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.18  0 0 0 0 0.16  0 0 0 0 0.14  0 0 0 0.035 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-repeat: repeat;
}

/* Legal pages */
.legal {
  padding-block: var(--space-7);
}
.legal__notice {
  padding: var(--space-5);
  border: 1px dashed var(--color-line);
  background: var(--color-paper);
  margin-bottom: var(--space-7);
  color: var(--color-ink-mute);
  font-style: italic;
  max-width: 56rem;
}
.legal h1 {
  font-size: clamp(1.9rem, 4vw + 0.5rem, var(--text-5));
  margin-bottom: var(--space-6);
}
.legal h2 {
  font-family: var(--font-body);
  font-size: var(--text-3);
  font-weight: 500;
  letter-spacing: 0;
  color: var(--color-ink);
  margin-top: var(--space-6);
  margin-bottom: var(--space-3);
}
.legal h3 {
  font-family: var(--font-body);
  font-size: var(--text-2);
  font-weight: 500;
  margin-top: var(--space-5);
  margin-bottom: var(--space-2);
}
.legal p, .legal li { color: var(--color-ink); max-width: var(--max-w-prose); }
.legal p + p { margin-top: var(--space-3); }
.legal ul { list-style: disc; padding-left: 1.2em; display: grid; gap: var(--space-2); }
.legal .placeholder {
  display: inline-block;
  padding: 0 0.4em;
  background: var(--color-paper);
  border-bottom: 1px solid var(--color-accent-rose);
  font-style: italic;
  color: var(--color-ink-mute);
}
