/* vietnamese */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 300 700;
  font-display: swap;
  src: url(/assets/fonts/fraunces-01.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 300 700;
  font-display: swap;
  src: url(/assets/fonts/fraunces-02.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Fraunces';
  font-style: italic;
  font-weight: 300 700;
  font-display: swap;
  src: url(/assets/fonts/fraunces-03.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* vietnamese */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url(/assets/fonts/fraunces-04.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url(/assets/fonts/fraunces-05.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Fraunces';
  font-style: normal;
  font-weight: 300 700;
  font-display: swap;
  src: url(/assets/fonts/fraunces-06.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: italic;
  font-weight: 300 800;
  font-display: swap;
  src: url(/assets/fonts/jakarta-07.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: italic;
  font-weight: 300 800;
  font-display: swap;
  src: url(/assets/fonts/jakarta-08.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: italic;
  font-weight: 300 800;
  font-display: swap;
  src: url(/assets/fonts/jakarta-09.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: italic;
  font-weight: 300 800;
  font-display: swap;
  src: url(/assets/fonts/jakarta-10.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 300 800;
  font-display: swap;
  src: url(/assets/fonts/jakarta-11.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 300 800;
  font-display: swap;
  src: url(/assets/fonts/jakarta-12.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 300 800;
  font-display: swap;
  src: url(/assets/fonts/jakarta-13.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 300 800;
  font-display: swap;
  src: url(/assets/fonts/jakarta-14.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


/* ==========================================================================
   Tierheilpraxis Yvonne Krüger — Design-System
   Editorial Luxury: warmes Creme, tiefes Grün, Fraunces + Plus Jakarta Sans
   ========================================================================== */

:root {
  /* Farben */
  --cream: #f7f2e7;
  --cream-soft: #fdfbf4;
  --paper: #fffdf6;
  --sage: #ecf2e0;
  --mint-wash: #e3eede;
  --ink: #1e2a1c;
  --ink-soft: #51604d;
  --green: #325831;
  --green-deep: #24391f;
  --green-night: #1b2d18;
  --teal: #009780;
  --teal-ink: #007765;
  --mint: #a1c5b2;
  --mint-pale: #dde8dc;
  --line: rgba(36, 57, 31, 0.12);
  --line-soft: rgba(36, 57, 31, 0.08);

  /* Typo */
  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans: "Plus Jakarta Sans", "Segoe UI", system-ui, sans-serif;

  /* Bewegung */
  --ease: cubic-bezier(0.32, 0.72, 0, 1);
  --ease-soft: cubic-bezier(0.22, 1, 0.36, 1);

  /* Maße */
  --shell: 76rem;
  --radius: 1.75rem;
  --radius-sm: 1.1rem;

  /* Sanfte Wellenkante für Sektionsübergänge */
  --wave: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 8' preserveAspectRatio='none'%3E%3Cpath d='M0 5.4 C 15 2.6, 33 7.4, 52 4.6 C 70 2.2, 86 6.6, 100 3.6 L 100 8 L 0 8 Z' fill='%23000'/%3E%3C/svg%3E");
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--sans);
  font-size: 1.0625rem;
  line-height: 1.7;
  color: var(--ink);
  background: var(--cream);
  -webkit-font-smoothing: antialiased;
  overflow-x: clip;
}
img, svg, video { display: block; max-width: 100%; height: auto; }
input, button, textarea, select { font: inherit; }
a { color: inherit; }
ul[class], ol[class] { list-style: none; padding: 0; }
summary { list-style: none; cursor: pointer; }
summary::-webkit-details-marker { display: none; }
:focus-visible { outline: 2px solid var(--teal); outline-offset: 3px; border-radius: 4px; }

::selection { background: var(--green); color: var(--cream-soft); }

/* Filmkorn — fest, klickdurchlässig */
.grain {
  position: fixed; inset: 0; z-index: 80; pointer-events: none;
  opacity: 0.05; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.92' numOctaves='2'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.55'/%3E%3C/svg%3E");
}

/* ---------- Typografie ---------- */
h1, h2, h3, .display {
  font-family: var(--serif);
  font-weight: 540;
  line-height: 1.08;
  letter-spacing: -0.015em;
  color: var(--ink);
  text-wrap: balance;
  font-variation-settings: "opsz" 110, "SOFT" 40, "WONK" 0;
}
h1 { font-size: clamp(2.45rem, 5.2vw + 0.6rem, 4.6rem); }
h2 { font-size: clamp(1.9rem, 2.6vw + 0.7rem, 3rem); }
h3 { font-size: clamp(1.25rem, 1vw + 0.85rem, 1.6rem); line-height: 1.25; }
.h-italic { font-style: italic; font-weight: 480; color: var(--green); }
.h-teal { font-style: italic; font-weight: 480; color: var(--teal-ink); }

p { max-width: 64ch; }
.lead {
  font-size: clamp(1.1rem, 0.5vw + 1rem, 1.3rem);
  line-height: 1.65;
  color: var(--ink-soft);
  max-width: 56ch;
}
strong { font-weight: 700; color: var(--ink); }
.muted { color: var(--ink-soft); }
.small { font-size: 0.9rem; }

/* (Eyebrow-Pillen entfernt — Sektionen starten direkt mit der Überschrift) */

/* ---------- Layout ---------- */
.shell { max-width: var(--shell); margin-inline: auto; padding-inline: clamp(1.25rem, 4vw, 2.5rem); }
.section { padding-block: clamp(4.5rem, 9vw, 8rem); position: relative; }
.section--tight { padding-block: clamp(3rem, 6vw, 5rem); }
.section--dark {
  background: var(--green-deep);
  color: var(--cream);
  border-radius: 3.6rem 2.2rem 4rem 2rem / 2.2rem 3.8rem 2rem 3.6rem;
  margin-inline: clamp(0.5rem, 1.5vw, 1.25rem);
}
.section--dark h1, .section--dark h2, .section--dark h3 { color: var(--cream-soft); }
.section--dark p, .section--dark .lead { color: rgba(246, 242, 234, 0.78); }
.section--dark strong { color: var(--cream-soft); }
.section--paper { background: var(--sage); }

/* Wellenkanten: oben und unten leicht geschwungen statt schnurgerade */
.section--paper, .trust, .site-foot { position: relative; }
.section--paper::before, .trust::before, .site-foot::before,
.section--paper::after, .trust::after {
  content: ""; position: absolute; left: 0; right: 0;
  height: clamp(1.5rem, 2.8vw, 2.6rem);
  background: inherit;
  -webkit-mask: var(--wave) center / 100% 100% no-repeat;
  mask: var(--wave) center / 100% 100% no-repeat;
  pointer-events: none;
}
.section--paper::before, .trust::before, .site-foot::before { bottom: 100%; }
.section--paper::after, .trust::after { top: 100%; transform: scale(-1); }
/* Übergang Foto → Trust-Band: kräftigerer, gegenläufiger Schwung mit Mint-Kammlinie */
.trust::before {
  height: clamp(2.6rem, 4.5vw, 4.4rem);
  transform: scaleX(-1);
}
.trust__crest {
  position: absolute; bottom: 100%; left: 0;
  width: 100%; height: clamp(2.6rem, 4.5vw, 4.4rem);
  transform: scaleX(-1) translateY(1px);
  pointer-events: none;
}
@media (max-width: 56rem) {
  /* Mobil geht die grüne Fläche nahtlos ins Band über — Welle und Linie stören dort */
  .trust::before, .trust__crest { display: none; }
}

.sec-head { max-width: 46rem; margin-bottom: clamp(2.5rem, 5vw, 4rem); display: grid; gap: 1.1rem; justify-items: start; }
.sec-head > p { margin-top: 0.25rem; }

/* ---------- Header / Island-Nav ---------- */
.skip-link {
  position: absolute; left: 1rem; top: -4rem; z-index: 200;
  background: var(--green-deep); color: var(--cream-soft);
  padding: 0.6rem 1.2rem; border-radius: 999px;
  transition: top 0.3s var(--ease);
}
.skip-link:focus { top: 1rem; }

.site-head {
  position: fixed; inset-inline: 0; top: 0; z-index: 100;
  padding: clamp(0.7rem, 2vw, 1.1rem) clamp(0.75rem, 2.5vw, 1.5rem) 0;
  pointer-events: none;
}
.site-head__bar {
  pointer-events: auto;
  max-width: var(--shell); margin-inline: auto;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  background: rgba(253, 251, 246, 0.82);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  border: 1px solid rgba(36, 57, 31, 0.09);
  box-shadow: 0 18px 40px -28px rgba(27, 45, 24, 0.45);
  border-radius: 999px;
  padding: 0.5rem 0.55rem 0.5rem 1.1rem;
  transition: box-shadow 0.5s var(--ease);
}
.brand { display: inline-flex; align-items: center; gap: 0.7rem; text-decoration: none; }
.brand img { height: 2.6rem; width: auto; }
/* Schriftzug als echter Text, angelehnt an die Logo-Typografie */
.brand b {
  display: block;
  font-family: var(--sans); font-weight: 700; font-size: 0.82rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--green-deep); line-height: 1.15;
}
.brand small {
  display: block;
  font-family: var(--serif); font-weight: 600; font-size: 1.02rem;
  letter-spacing: 0.01em; color: var(--teal-ink); line-height: 1.15;
}

.nav-links { display: flex; align-items: center; gap: 0.25rem; }
.nav-links a {
  text-decoration: none; font-size: 0.92rem; font-weight: 600;
  color: var(--ink-soft); padding: 0.5rem 0.85rem; border-radius: 999px;
  transition: color 0.4s var(--ease), background 0.4s var(--ease);
}
.nav-links a:hover { color: var(--ink); background: rgba(36, 57, 31, 0.06); }
.nav-links a[aria-current="page"] { color: var(--green-deep); background: rgba(50, 88, 49, 0.1); }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: 0.7rem;
  background: var(--green); color: var(--cream-soft);
  text-decoration: none; font-weight: 600; font-size: 0.95rem;
  border: 0; cursor: pointer;
  border-radius: 999px; padding: 0.42rem 0.45rem 0.42rem 1.35rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.14), 0 14px 28px -18px rgba(27, 45, 24, 0.8);
  transition: transform 0.5s var(--ease), box-shadow 0.5s var(--ease), background 0.5s var(--ease);
}
.btn:hover { transform: translateY(-2px); background: var(--teal-ink); }
.btn:active { transform: scale(0.98); }
.btn__circle {
  width: 2.3rem; height: 2.3rem; border-radius: 50%;
  background: rgba(255, 255, 255, 0.13);
  display: inline-flex; align-items: center; justify-content: center;
  transition: transform 0.5s var(--ease), background 0.5s var(--ease);
}
.btn:hover .btn__circle { transform: translate(2px, -1px) scale(1.06); background: var(--teal); }
.btn__circle svg { width: 1rem; height: 1rem; }

.btn--light { background: var(--cream-soft); color: var(--green-deep); box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 14px 28px -18px rgba(0, 0, 0, 0.55); }
.btn--light:hover { background: #fff; }
.btn--light .btn__circle { background: rgba(36, 57, 31, 0.09); }
.btn--light:hover .btn__circle { background: var(--mint); }

.btn--ghost {
  display: inline-flex; align-items: center; gap: 0.55rem;
  padding: 0.78rem 1.4rem; border-radius: 999px;
  border: 1px solid var(--line); background: transparent;
  color: var(--ink); text-decoration: none; font-weight: 600; font-size: 0.95rem;
  transition: border-color 0.4s var(--ease), background 0.4s var(--ease), transform 0.5s var(--ease);
}
.btn--ghost:hover { border-color: var(--green); background: rgba(50, 88, 49, 0.06); transform: translateY(-2px); }
.on-dark .btn--ghost { border-color: rgba(246, 242, 234, 0.3); color: var(--cream-soft); }
.on-dark .btn--ghost:hover { border-color: var(--mint); background: rgba(255, 255, 255, 0.06); }

/* Hamburger */
.nav-toggle {
  display: none;
  width: 2.9rem; height: 2.9rem; border-radius: 50%;
  border: 1px solid var(--line); background: var(--cream-soft);
  position: relative; cursor: pointer;
}
.nav-toggle span {
  position: absolute; left: 50%; top: 50%; width: 1.15rem; height: 1.6px;
  background: var(--ink); border-radius: 2px;
  transition: transform 0.45s var(--ease), opacity 0.3s var(--ease);
}
.nav-toggle span:nth-child(1) { transform: translate(-50%, calc(-50% - 4px)); }
.nav-toggle span:nth-child(2) { transform: translate(-50%, calc(-50% + 4px)); }
.nav-open .nav-toggle span:nth-child(1) { transform: translate(-50%, -50%) rotate(45deg); }
.nav-open .nav-toggle span:nth-child(2) { transform: translate(-50%, -50%) rotate(-45deg); }

/* Mobile Overlay */
.nav-overlay {
  position: fixed; inset: 0; z-index: 90;
  background: rgba(246, 242, 234, 0.92);
  backdrop-filter: blur(26px); -webkit-backdrop-filter: blur(26px);
  display: grid; align-content: center; justify-items: center; gap: 0.4rem;
  opacity: 0; visibility: hidden; transition: opacity 0.5s var(--ease), visibility 0.5s;
}
.nav-open .nav-overlay { opacity: 1; visibility: visible; }
.nav-overlay a {
  font-family: var(--serif); font-size: clamp(1.7rem, 6vw, 2.4rem); font-weight: 540;
  text-decoration: none; color: var(--ink); padding: 0.35rem 1rem;
  opacity: 0; transform: translateY(18px);
  transition: opacity 0.55s var(--ease), transform 0.55s var(--ease), color 0.3s;
}
.nav-overlay a:hover { color: var(--green); font-style: italic; }
.nav-overlay a[aria-current="page"] { color: var(--green); }
.nav-open .nav-overlay a { opacity: 1; transform: none; }
.nav-overlay a:nth-child(1) { transition-delay: 0.08s; }
.nav-overlay a:nth-child(2) { transition-delay: 0.13s; }
.nav-overlay a:nth-child(3) { transition-delay: 0.18s; }
.nav-overlay a:nth-child(4) { transition-delay: 0.23s; }
.nav-overlay a:nth-child(5) { transition-delay: 0.28s; }
.nav-overlay a:nth-child(6) { transition-delay: 0.33s; }
.nav-overlay a:nth-child(7) { transition-delay: 0.38s; }
.nav-overlay .overlay-meta {
  margin-top: 1.6rem; text-align: center; font-size: 0.92rem; color: var(--ink-soft);
  opacity: 0; transition: opacity 0.6s var(--ease) 0.45s;
}
.nav-open .nav-overlay .overlay-meta { opacity: 1; }
.nav-open { overflow: hidden; }

@media (max-width: 64rem) {
  .nav-links, .site-head__bar > .btn { display: none; }
  .nav-toggle { display: block; }
}
@media (min-width: 64.0625rem) {
  .nav-overlay { display: none; }
}

/* ---------- Fullscreen-Hero mit geschwungener Farbfläche ---------- */
.hero-full {
  position: relative;
  height: 100dvh;
  min-height: 36rem;
  display: flex;
  align-items: stretch;
  overflow: clip;
}
.hero-full__bg { position: absolute; inset: 0; overflow: clip; }
.hero-full__bg > img {
  width: 130%; max-width: none; height: 100%;
  margin-left: 11vw;
  object-fit: cover; object-position: 50% 38%;
}
.hero-full__bg::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(27, 45, 24, 0.14), transparent 16%);
  pointer-events: none;
}
.hero-full__panel {
  position: relative; z-index: 2;
  width: clamp(32rem, calc((100% - var(--shell)) / 2 + 44rem), 66%);
  display: flex; align-items: center;
}
.hero-full__shape {
  position: absolute; inset: 0; width: 100%; height: 100%;
  filter: drop-shadow(26px 0 50px rgba(27, 45, 24, 0.35));
  pointer-events: none;
}
/* Animierte Lage ohne Filter — der Blur der Unterschicht muss nicht je Frame neu rechnen */
.hero-full__shape--anim { filter: none; }
.hero-full__content {
  position: relative;
  display: grid; gap: 1.3rem; justify-items: start;
  padding-top: clamp(6.5rem, 12vh, 8rem);
  padding-bottom: clamp(4rem, 10vh, 7rem);
  padding-right: clamp(5rem, 28%, 13rem);
  padding-left: clamp(2.75rem, calc((100vw - var(--shell)) / 2 + 2.5rem), 7rem);
  max-width: 100%;
}
.hero-full__content > * { max-width: 28rem; }
.hero-full h1 { font-size: clamp(2.3rem, 3.2vw + 0.6rem, 3.7rem); color: var(--cream-soft); }
.hero-full h1 .h-italic { color: var(--mint); }
.hero-full .lead { max-width: 44ch; color: rgba(246, 242, 234, 0.82); }
.hero-full .hero__note { color: rgba(246, 242, 234, 0.7); }
.hero-full .hero__note strong { color: var(--cream-soft); }
.hero-full__bg .hero-full__badge {
  position: absolute; right: clamp(1rem, 3vw, 2.5rem); bottom: clamp(1.2rem, 4vh, 2.6rem);
  left: auto; top: auto;
}
@media (max-width: 56rem) {
  .hero-full { flex-direction: column; height: auto; min-height: 100dvh; }
  .hero-full__bg { position: relative; flex: 1; min-height: 24rem; height: auto; }
  .hero-full__bg > img { width: 165%; margin-left: -29vw; object-position: 50% 22%; }
  /* Oben aufgeräumt: Siegel steht im Trust-Band direkt darunter */
  .hero-full__bg .hero-full__badge, .hero-full .hero__note { display: none; }
  .hero-full .lead { font-size: 1.02rem; }
  .hero-full .hero__actions { gap: 0.6rem; }
  .hero-full .btn--ghost { padding: 0.66rem 1.15rem; font-size: 0.9rem; }
  .hero-full__bg::after { background: linear-gradient(to top, rgba(27, 45, 24, 0.25), transparent 30%); }
  .hero-full__panel {
    width: 100%;
    margin-top: -2.4rem;
    border-radius: 2.8rem 1.4rem 0 0 / 2.3rem 1.1rem 0 0;
    box-shadow: 0 -24px 50px -36px rgba(27, 45, 24, 0.5);
    background-color: #2b4a28;
    background-image: linear-gradient(155deg, #35592e, #1f3a1d);
  }
  .hero-full__shape { display: none; }
  .hero-full__content {
    padding: 1.9rem clamp(1.25rem, 4vw, 2.5rem) 2rem;
    gap: 1rem;
  }
  .hero-full__content > * { max-width: none; }
  .hero-full h1 { font-size: clamp(2.05rem, 7.5vw, 2.5rem); }
  .hero-full__bg .hero-full__badge { bottom: 3.4rem; right: 0.9rem; left: 0.9rem; padding: 0.65rem 0.9rem; gap: 0.7rem; }
  .hero-full__bg .hero-full__badge img { width: 2.9rem; }
  .hero-full__bg .hero-full__badge b { font-size: 0.86rem; }
  .hero-full__bg .hero-full__badge span { font-size: 0.76rem; }
}

/* ---------- Hero (Unterseiten-Variante, ungenutzt auf Start) ---------- */
.hero { padding-top: clamp(6.5rem, 13vw, 10.5rem); padding-bottom: clamp(3.5rem, 7vw, 6rem); position: relative; overflow-x: clip; }
.hero__grid { display: grid; gap: clamp(2rem, 4vw, 4.5rem); align-items: center; }
@media (min-width: 56rem) { .hero__grid { grid-template-columns: 0.92fr 1.08fr; } }
@media (max-width: 56rem) { .hero__media { order: -1; } }
.hero__copy { display: grid; gap: 1.4rem; justify-items: start; }
.hero__copy .lead { margin-top: 0.2rem; }
.hero__actions { display: flex; flex-wrap: wrap; gap: 0.8rem; margin-top: 0.6rem; align-items: center; }
.hero__note { font-size: 0.88rem; color: var(--ink-soft); }

/* Hero-Bild: großes Squircle mit Doppelrahmen */
.arch {
  position: relative;
  background: rgba(36, 57, 31, 0.06);
  border: 1px solid rgba(36, 57, 31, 0.1);
  padding: 0.55rem;
  border-radius: 2.4rem;
  box-shadow: 0 40px 80px -50px rgba(27, 45, 24, 0.55);
}
.arch img {
  width: 100%; height: 100%; object-fit: cover;
  border-radius: calc(2.4rem - 0.55rem);
}
.arch--hero { aspect-ratio: 0.82; max-height: 46rem; }
.arch--hero img { height: 100%; width: 100%; }
@media (max-width: 56rem) { .arch--hero { aspect-ratio: 0.88; max-height: min(32rem, 118vw); } }

/* Dekor hinter dem Hero-Bild: weicher Schein + versetzte Konturlinie */
.hero__media { position: relative; }
.hero__media::before {
  content: ""; position: absolute; inset: -14% -10% auto auto;
  width: 75%; aspect-ratio: 1; border-radius: 50%;
  background: radial-gradient(circle, rgba(161, 197, 178, 0.5), transparent 65%);
  z-index: -1; pointer-events: none;
}
.hero__media::after {
  content: ""; position: absolute; inset: 0;
  border: 1.5px solid var(--mint);
  border-radius: 2.4rem;
  transform: rotate(2.2deg) translate(1rem, -0.8rem);
  pointer-events: none;
  z-index: -1;
}
@media (max-width: 56rem) {
  .hero__media::after { transform: rotate(1.6deg) translate(0.5rem, -0.5rem); }
}

/* Schwebende Fakten-Karte am Hero-Bild */
.float-card {
  position: absolute; left: clamp(-1.5rem, -3vw, -2.5rem); bottom: clamp(1.2rem, 4vw, 2.6rem);
  display: flex; align-items: center; gap: 1rem;
  background: rgba(253, 251, 246, 0.94);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(36, 57, 31, 0.1);
  border-radius: 1.4rem;
  padding: 1rem 1.3rem;
  box-shadow: 0 24px 50px -30px rgba(27, 45, 24, 0.6);
  max-width: 24rem;
}
.float-card img { width: 4.6rem; height: auto; flex: none; }
.float-card b { font-size: 0.98rem; line-height: 1.35; display: block; margin-bottom: 0.15rem; white-space: nowrap; }
.float-card span { font-size: 0.84rem; color: var(--ink-soft); line-height: 1.45; }
@media (max-width: 56rem) {
  .float-card { left: 0.9rem; right: 0.9rem; bottom: 0.9rem; max-width: none; }
}

/* ---------- Trust-Bar ---------- */
.trust {
  background: var(--green-night);
  color: var(--cream);
}
.trust__grid {
  display: grid;
  padding-block: clamp(1.6rem, 3.5vw, 2.4rem);
}
@media (min-width: 44rem) { .trust__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 64rem) { .trust__grid { grid-template-columns: repeat(4, 1fr); } }
.trust__item {
  display: flex; gap: 0.95rem; align-items: flex-start;
  padding: 0.9rem clamp(1rem, 2vw, 1.6rem);
}
@media (min-width: 64rem) {
  .trust__item + .trust__item { border-left: 1px solid rgba(246, 242, 234, 0.13); }
  .trust__item:first-child { padding-left: 0; }
}
@media (min-width: 44rem) and (max-width: 63.9rem) {
  .trust__item:nth-child(even) { border-left: 1px solid rgba(246, 242, 234, 0.13); }
}
@media (max-width: 43.9rem) {
  .trust__item + .trust__item { border-top: 1px solid rgba(246, 242, 234, 0.13); }
  .trust__item { padding-inline: 0; }
}
.trust__item .ic {
  flex: none; width: 2.6rem; height: 2.6rem; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(161, 197, 178, 0.14);
  border: 1px solid rgba(161, 197, 178, 0.25);
}
.trust__item .ic svg { width: 1.2rem; height: 1.2rem; color: var(--mint); }
.trust__item b { display: block; font-size: 0.95rem; line-height: 1.4; color: var(--cream-soft); }
.trust__item span { font-size: 0.84rem; color: rgba(246, 242, 234, 0.62); line-height: 1.45; }
.trust__item a { color: var(--mint); }

/* ---------- Karten / Bento ---------- */
.bento { display: grid; gap: 1.1rem; }
@media (min-width: 44rem) { .bento { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 64rem) { .bento { grid-template-columns: repeat(3, 1fr); } }
.bento .span-2 { grid-column: span 1; }
@media (min-width: 44rem) { .bento .span-2 { grid-column: span 2; } }

.card {
  position: relative;
  background: rgba(36, 57, 31, 0.045);
  border: 1px solid rgba(36, 57, 31, 0.09);
  border-radius: var(--radius);
  padding: 0.45rem;
  transition: transform 0.6s var(--ease), box-shadow 0.6s var(--ease);
}
.card__in {
  background: var(--paper);
  border-radius: calc(var(--radius) - 0.45rem);
  box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.7);
  padding: clamp(1.4rem, 3vw, 2rem);
  height: 100%;
  display: grid; gap: 0.7rem; align-content: start;
}
a.card { display: block; text-decoration: none; }
a.card:hover { transform: translateY(-5px); box-shadow: 0 30px 60px -42px rgba(27, 45, 24, 0.55); }
.card h3 { display: flex; align-items: center; justify-content: space-between; gap: 0.7rem; }
.card .go {
  flex: none; width: 2rem; height: 2rem; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(50, 88, 49, 0.08); color: var(--green-deep);
  transition: transform 0.5s var(--ease), background 0.4s var(--ease), color 0.4s var(--ease);
}
.card .go svg { width: 0.9rem; height: 0.9rem; }
a.card:hover .go { background: var(--green-deep); color: var(--cream-soft); transform: translate(2px, -2px); }
.card p { font-size: 0.97rem; color: var(--ink-soft); }
.card .tag { font-size: 0.78rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--teal-ink); }

.card--dark { background: rgba(255, 255, 255, 0.07); border-color: rgba(255, 255, 255, 0.12); }
.card--dark .card__in { background: var(--green-night); box-shadow: inset 0 1px 1px rgba(255, 255, 255, 0.06); }
.card--dark h3 { color: var(--cream-soft); }
.card--dark p { color: rgba(246, 242, 234, 0.72); }

/* ---------- Split (Bild + Text) ---------- */
.split { display: grid; gap: clamp(2.2rem, 5vw, 4.5rem); align-items: center; }
@media (min-width: 56rem) {
  .split { grid-template-columns: 1fr 1fr; }
  .split--wide-text { grid-template-columns: 1.15fr 0.85fr; }
  .split > .order-first { order: -1; }
}
.split__copy { display: grid; gap: 1.15rem; justify-items: start; }

.frame {
  background: rgba(36, 57, 31, 0.06);
  border: 1px solid rgba(36, 57, 31, 0.1);
  padding: 0.55rem; border-radius: var(--radius);
  box-shadow: 0 36px 70px -48px rgba(27, 45, 24, 0.55);
  position: relative;
}
.frame img { width: 100%; border-radius: calc(var(--radius) - 0.45rem); object-fit: cover; }
.split > .frame img, .split > div > .frame img { aspect-ratio: 0.9; }
.frame--tilt { transform: rotate(-1.6deg); }
.frame--tilt-r { transform: rotate(1.4deg); }
@media (max-width: 48rem) { .frame--tilt, .frame--tilt-r { transform: none; } }
.frame figcaption {
  position: absolute; left: 1.2rem; bottom: 1.2rem;
  background: rgba(27, 45, 24, 0.72); color: var(--cream-soft);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  font-size: 0.8rem; padding: 0.45rem 0.9rem; border-radius: 999px;
}

/* ---------- Zahlen / Fakten ---------- */
.facts { display: grid; gap: 1.1rem; }
@media (min-width: 40rem) { .facts { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 64rem) { .facts--4 { grid-template-columns: repeat(4, 1fr); } .facts--3 { grid-template-columns: repeat(3, 1fr); } }
.fact {
  border-top: 1px solid var(--line);
  padding-top: 1.1rem;
}
.fact b {
  font-family: var(--serif); font-weight: 560; font-size: clamp(1.9rem, 2.5vw, 2.6rem);
  line-height: 1.05; display: block; color: var(--green-deep);
}
.fact b small { font-size: 0.55em; font-weight: 540; }
.fact span { font-size: 0.92rem; color: var(--ink-soft); display: block; margin-top: 0.35rem; line-height: 1.5; }
.on-dark .fact { border-color: rgba(246, 242, 234, 0.18); }
.on-dark .fact b { color: var(--cream-soft); }
.on-dark .fact span { color: rgba(246, 242, 234, 0.65); }

/* ---------- Ablauf / Schritte ---------- */
.steps { display: grid; gap: 1.1rem; counter-reset: step; }
@media (min-width: 56rem) { .steps { grid-template-columns: repeat(3, 1fr); } .steps--4 { grid-template-columns: repeat(4, 1fr); } }
.step {
  counter-increment: step;
  background: var(--paper);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius);
  padding: clamp(1.5rem, 3vw, 2rem);
  position: relative;
  display: grid; gap: 0.6rem; align-content: start;
}
.step::before {
  content: "0" counter(step);
  font-family: var(--serif); font-style: italic; font-weight: 480;
  font-size: 2.2rem; line-height: 1; color: var(--teal);
}
.step h3 { font-size: 1.2rem; }
.step p { font-size: 0.96rem; color: var(--ink-soft); }
.step b { color: var(--green-deep); }

/* ---------- Preise ---------- */
.price-list { display: grid; gap: 0; border-top: 1px solid var(--line); }
.price-row {
  display: grid; gap: 0.2rem 1.5rem;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  padding: 1.15rem 0.2rem;
  border-bottom: 1px solid var(--line-soft);
}
.price-row dt { font-weight: 600; }
.price-row dt small { display: block; font-weight: 400; font-size: 0.88rem; color: var(--ink-soft); max-width: 40ch; }
.price-row dd {
  margin: 0; font-family: var(--serif); font-weight: 560;
  font-size: 1.45rem; color: var(--teal-ink); white-space: nowrap;
}
.price-row dd small { font-family: var(--sans); font-size: 0.8rem; font-weight: 500; color: var(--ink-soft); display: inline-block; min-width: 2.4rem; }

/* ---------- FAQ ---------- */
.faq { display: grid; gap: 0.8rem; max-width: 52rem; }
.faq details {
  background: var(--paper);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-sm);
  overflow: clip;
  transition: box-shadow 0.5s var(--ease);
}
.faq details[open] { box-shadow: 0 24px 50px -40px rgba(27, 45, 24, 0.5); }
.faq summary {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: 1.1rem 1.3rem;
  font-weight: 600; font-size: 1.02rem; line-height: 1.45;
}
.faq summary .ind {
  flex: none; width: 1.9rem; height: 1.9rem; border-radius: 50%;
  border: 1px solid var(--line); display: inline-flex; align-items: center; justify-content: center;
  transition: transform 0.5s var(--ease), background 0.4s var(--ease), color 0.4s var(--ease);
}
.faq summary .ind svg { width: 0.85rem; height: 0.85rem; }
.faq details[open] summary .ind { transform: rotate(45deg); background: var(--green-deep); color: var(--cream-soft); border-color: var(--green-deep); }
.faq .faq__body { padding: 0 1.3rem 1.3rem; color: var(--ink-soft); font-size: 0.98rem; display: grid; gap: 0.6rem; justify-items: start; }
.faq .faq__body a { color: var(--teal-ink); font-weight: 600; }

/* ---------- Listen mit Häkchen / Punkten ---------- */
.checks { display: grid; gap: 0.65rem; }
.checks li { display: flex; gap: 0.7rem; align-items: flex-start; font-size: 0.99rem; }
.checks li svg { flex: none; width: 1.15rem; height: 1.15rem; margin-top: 0.28rem; color: var(--teal-ink); }
.checks li.no svg { color: #b4543c; }
.on-dark .checks li svg { color: var(--mint); }

/* ---------- Hinweis-Boxen ---------- */
.note {
  border-left: 3px solid var(--teal);
  background: rgba(0, 151, 128, 0.06);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  padding: 1.1rem 1.4rem;
  font-size: 0.95rem; color: var(--ink-soft);
  max-width: 56rem;
}
.note--warn { border-color: #b4543c; background: rgba(180, 84, 60, 0.06); }
.note b, .note strong { color: var(--ink); }
.note a { color: var(--teal-ink); font-weight: 600; }

.legal-note { font-size: 0.82rem; color: var(--ink-soft); line-height: 1.6; max-width: 56rem; }

/* ---------- Zitat ---------- */
.pull {
  font-family: var(--serif); font-weight: 500; font-style: italic;
  font-size: clamp(1.45rem, 2.4vw + 0.6rem, 2.3rem);
  line-height: 1.35; letter-spacing: -0.01em;
  max-width: 46rem; text-wrap: balance;
}
.pull em { color: var(--teal); font-style: italic; }
.pull-by { margin-top: 1.2rem; font-family: var(--sans); font-size: 0.9rem; color: var(--ink-soft); display: flex; align-items: center; gap: 0.7rem; }
.pull-by::before { content: ""; width: 2.2rem; height: 1px; background: var(--mint); }

/* ---------- CTA-Band ---------- */
.cta-band {
  background: var(--green-deep);
  border-radius: 3.2rem 2rem 3.6rem 1.9rem / 2rem 3.4rem 1.9rem 3.2rem;
  padding: clamp(2.5rem, 6vw, 4.5rem);
  position: relative; overflow: clip;
  display: grid; gap: 1.5rem; justify-items: start;
}
.cta-band::after {
  content: ""; position: absolute; right: -12%; top: -45%;
  width: 32rem; height: 32rem; border-radius: 50%;
  background: radial-gradient(circle, rgba(0, 151, 128, 0.34), transparent 65%);
  pointer-events: none;
}
.cta-band h2 { color: var(--cream-soft); max-width: 22ch; }
.cta-band p { color: rgba(246, 242, 234, 0.78); max-width: 52ch; }
.cta-band .hours { font-size: 0.88rem; color: rgba(246, 242, 234, 0.65); }
.cta-band .row { display: flex; flex-wrap: wrap; gap: 0.8rem; align-items: center; position: relative; z-index: 1; }

/* ---------- Kontakt ---------- */
.contact-cards { display: grid; gap: 1.1rem; }
@media (min-width: 56rem) { .contact-cards { grid-template-columns: repeat(2, 1fr); } }
.contact-card .card__in { gap: 0.4rem; }
.contact-card .big {
  font-family: var(--serif); font-weight: 560;
  font-size: clamp(1.4rem, 2vw, 1.8rem);
  color: var(--green-deep); text-decoration: none;
  overflow-wrap: anywhere;
}
.contact-card .big:hover { color: var(--teal-ink); }

/* Kontaktformular */
.contact-form .card__in { gap: 1.05rem; }
.ff { display: grid; gap: 0.4rem; }
.ff label { font-weight: 600; font-size: 0.93rem; }
.ff label span { font-weight: 400; color: var(--ink-soft); }
.ff input, .ff textarea {
  border: 1px solid var(--line);
  border-radius: 0.85rem;
  background: var(--cream-soft);
  padding: 0.78rem 1rem;
  color: var(--ink);
  transition: border-color 0.3s var(--ease), background 0.3s var(--ease);
}
.ff input:focus, .ff textarea:focus {
  border-color: var(--teal);
  background: #fff;
  outline: none;
}
.ff textarea { resize: vertical; min-height: 8rem; }
/* Honeypot: für Menschen unsichtbar, im DOM vorhanden */
.ff--hp {
  position: absolute !important;
  width: 1px; height: 1px;
  overflow: hidden;
  clip-path: inset(50%);
  white-space: nowrap;
}
.ff-consent {
  display: flex; gap: 0.65rem; align-items: flex-start;
  font-size: 0.88rem; color: var(--ink-soft); line-height: 1.55;
  cursor: pointer;
}
.ff-consent input {
  width: 1.15rem; height: 1.15rem; flex: none;
  margin-top: 0.18rem;
  accent-color: var(--green);
  cursor: pointer;
}
.ff-consent a { color: var(--teal-ink); }
.ff-status { display: none; font-weight: 600; font-size: 0.95rem; line-height: 1.5; }
.ff-status.show { display: block; }
.ff-status.err { color: #a4442e; }
.ff-status.ok { color: var(--green-deep); }
.contact-form .btn { justify-self: start; }
.contact-form .btn[disabled] { opacity: 0.55; pointer-events: none; }

.hours-table { width: 100%; border-collapse: collapse; font-size: 0.97rem; max-width: 30rem; }
.hours-table td { padding: 0.55rem 0; border-bottom: 1px solid var(--line-soft); vertical-align: top; }
.hours-table td:last-child { text-align: right; white-space: nowrap; font-weight: 600; }

/* ---------- Zertifikate ---------- */
.certs { display: grid; gap: 1.1rem; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 56rem) { .certs { grid-template-columns: repeat(3, 1fr); } }
.cert { text-decoration: none; }
.cert .frame { padding: 0.4rem; }
.cert img { aspect-ratio: 1.414 / 1; object-fit: cover; object-position: top; background: #fff; }
.cert.portrait img { aspect-ratio: 1 / 1.35; }
.cert figcaption { position: static; background: none; color: var(--ink-soft); font-size: 0.85rem; padding: 0.7rem 0.3rem 0.1rem; backdrop-filter: none; -webkit-backdrop-filter: none; }
.cert:hover .frame { box-shadow: 0 30px 60px -40px rgba(27, 45, 24, 0.65); }

/* ---------- Orte ---------- */
.places { display: grid; gap: 0; border-top: 1px solid var(--line); max-width: 52rem; }
.place {
  display: grid; grid-template-columns: 1fr auto; gap: 0.2rem 1.2rem; align-items: center;
  padding: 1.05rem 0.2rem; border-bottom: 1px solid var(--line-soft);
  text-decoration: none;
  transition: background 0.4s var(--ease), padding 0.4s var(--ease);
}
.place:hover { background: rgba(50, 88, 49, 0.05); padding-inline: 0.8rem; border-radius: 0.8rem; }
.place b { font-family: var(--serif); font-weight: 560; font-size: 1.25rem; }
.place span { grid-column: 1; font-size: 0.9rem; color: var(--ink-soft); }
.place .dist { grid-column: 2; grid-row: 1 / span 2; font-size: 0.85rem; font-weight: 600; color: var(--teal-ink); white-space: nowrap; display: inline-flex; align-items: center; gap: 0.45rem; }
.place .dist svg { width: 0.95rem; height: 0.95rem; }

/* ---------- Footer ---------- */
.site-foot {
  background: var(--green-night); color: rgba(246, 242, 234, 0.75);
  margin-top: clamp(4rem, 8vw, 7rem);
}
.site-foot__main {
  display: grid; gap: clamp(2rem, 5vw, 3.5rem);
  padding-block: clamp(3rem, 7vw, 5.5rem) clamp(2rem, 4vw, 3rem);
}
@media (min-width: 56rem) { .site-foot__main { grid-template-columns: 1.4fr 1fr 1fr 1fr; } }
.site-foot h2 { color: var(--cream-soft); font-size: clamp(1.7rem, 2.6vw, 2.4rem); max-width: 16ch; }
.site-foot .foot-brand { display: grid; gap: 1.1rem; justify-items: start; align-content: start; }
.site-foot .foot-col { display: grid; gap: 0.55rem; align-content: start; font-size: 0.94rem; }
.site-foot .foot-col b { color: var(--cream-soft); font-size: 0.78rem; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 0.5rem; }
.site-foot a { color: rgba(246, 242, 234, 0.75); text-decoration: none; transition: color 0.3s; width: fit-content; }
.site-foot a:hover { color: var(--cream-soft); }
.site-foot a.btn--light, .site-foot a.btn--light:hover { color: var(--green-deep); }
.site-foot address { font-style: normal; line-height: 1.7; }
.site-foot__legal {
  border-top: 1px solid rgba(246, 242, 234, 0.12);
  padding-block: 1.4rem 1.8rem;
  display: flex; flex-wrap: wrap; gap: 0.5rem 1.8rem; align-items: center;
  font-size: 0.82rem; color: rgba(246, 242, 234, 0.5);
}
.site-foot__legal a { color: rgba(246, 242, 234, 0.6); }
.foot-credit { display: inline-flex; align-items: center; gap: 0.6rem; }
.foot-credit img { height: 2.2rem; width: auto; opacity: 0.9; transition: opacity 0.3s; }
.foot-credit:hover img { opacity: 1; }
.site-foot__hwg {
  padding-top: 1.6rem;
  font-size: 0.78rem; line-height: 1.6; color: rgba(246, 242, 234, 0.45);
  max-width: 72ch;
}

/* ---------- Breadcrumb / Subpage-Hero ---------- */
.page-hero {
  padding-top: clamp(7.5rem, 13vw, 10.5rem); padding-bottom: clamp(2.5rem, 5vw, 4rem);
  position: relative;
}
.page-hero::before {
  content: ""; position: absolute; inset: 0 auto auto 0;
  width: min(46rem, 80vw); height: 100%;
  background: radial-gradient(ellipse at 18% 30%, rgba(161, 197, 178, 0.4), transparent 65%);
  pointer-events: none;
}
.page-hero .sec-head { position: relative; }
.page-hero .sec-head { margin-bottom: 0; max-width: 52rem; }
.crumbs { display: flex; flex-wrap: wrap; gap: 0.4rem; font-size: 0.85rem; color: var(--ink-soft); margin-bottom: 0.4rem; }
.crumbs a { color: var(--ink-soft); text-decoration: none; }
.crumbs a:hover { color: var(--green); }
.crumbs li:not(:last-child)::after { content: "·"; margin-left: 0.4rem; }
.crumbs [aria-current] { color: var(--green-deep); font-weight: 600; }

/* ---------- Prosa (Impressum/Datenschutz) ---------- */
.prose { max-width: 46rem; display: grid; gap: 1rem; }
.prose h2 { font-size: 1.5rem; margin-top: 1.6rem; }
.prose h3 { font-size: 1.15rem; margin-top: 0.8rem; }
.prose ul { padding-left: 1.2rem; }
.prose a { color: var(--teal-ink); }

/* ---------- Seitenübergänge: weicher Crossfade ---------- */
@view-transition { navigation: auto; }
::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 0.45s;
  animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
}
/* Header bleibt beim Wechsel optisch stehen, nur der Inhalt blendet */
.site-head { view-transition-name: site-head; }
@media (prefers-reduced-motion: reduce) {
  ::view-transition-group(*),
  ::view-transition-old(*),
  ::view-transition-new(*) { animation: none !important; }
}

/* ---------- Reveal-Animationen ---------- */
@media (prefers-reduced-motion: no-preference) {
  .rv { opacity: 0; transform: translateY(26px); filter: blur(6px); transition: opacity 0.9s var(--ease-soft), transform 0.9s var(--ease-soft), filter 0.9s var(--ease-soft); }
  .rv.in { opacity: 1; transform: none; filter: none; }
  .rv-1 { transition-delay: 0.08s; } .rv-2 { transition-delay: 0.16s; } .rv-3 { transition-delay: 0.24s; } .rv-4 { transition-delay: 0.32s; }
}

/* ---------- Deko: Blatt-Linie ---------- */
.leaf-deco { position: absolute; pointer-events: none; color: var(--mint); opacity: 0.55; }
.leaf-deco svg { width: 100%; height: 100%; }

/* ---------- Consent-Banner (nur aktiv, wenn ein einwilligungspflichtiges
   Tool konfiguriert ist) ---------- */
.consent {
  position: fixed; z-index: 120;
  right: clamp(1rem, 2.5vw, 1.75rem); bottom: clamp(1rem, 2.5vw, 1.75rem);
  max-width: 23.5rem;
}
.consent__card {
  background: var(--cream-soft);
  border: 1px solid rgba(36, 57, 31, 0.14);
  border-radius: 1.4rem;
  box-shadow: 0 30px 70px -34px rgba(27, 45, 24, 0.65);
  padding: 1.25rem 1.4rem;
  display: grid; gap: 0.65rem;
}
.consent__card b { font-family: var(--serif); font-weight: 600; font-size: 1.1rem; }
.consent__card p { font-size: 0.86rem; line-height: 1.55; color: var(--ink-soft); }
.consent__card p a { color: var(--teal-ink); }
.consent__row { display: flex; gap: 0.6rem; margin-top: 0.2rem; }
/* Gleichwertige Buttons: gleiche Größe, gleiche Form — EU-konform */
.cbtn {
  flex: 1; border: 0; cursor: pointer;
  border-radius: 999px; padding: 0.7rem 1rem;
  font-weight: 700; font-size: 0.92rem;
  transition: transform 0.4s var(--ease), filter 0.3s;
}
.cbtn:hover { transform: translateY(-1px); filter: brightness(1.06); }
.cbtn--ok { background: var(--green); color: var(--cream-soft); }
.cbtn--deny { background: var(--ink-soft); color: var(--cream-soft); }

.consent__layer { display: grid; gap: 0.65rem; }
.consent__layer[hidden] { display: none; }
.consent__textlink {
  background: none; border: 0; padding: 0; cursor: pointer;
  font: inherit; font-size: inherit; font-weight: 600;
  color: var(--teal-ink); text-decoration: underline;
}
.consent__settings-link { justify-self: center; font-size: 0.82rem; margin-top: 0.1rem; }
.consent__service {
  border-top: 1px solid var(--line-soft);
  padding-top: 0.65rem;
  display: grid; gap: 0.3rem;
}
.consent__service-head {
  display: flex; gap: 0.55rem; align-items: center;
  font-size: 0.9rem; cursor: pointer;
}
.consent__service-head input {
  width: 1.05rem; height: 1.05rem; flex: none;
  accent-color: var(--green); cursor: pointer;
}
.consent__service-head input:disabled { cursor: default; }
.consent__service p { font-size: 0.78rem; line-height: 1.5; color: var(--ink-soft); }
/* Einstellungs-Ebene kann lang werden: innerhalb der Karte scrollen */
#consent-layer2 { max-height: min(70dvh, 34rem); overflow-y: auto; padding-right: 0.25rem; }

/* Desktop: Karte unten rechts — die Hero-CTAs liegen links und bleiben frei.
   Die Siegel-Karte weicht solange aus. */
.consent-open .hero-full__badge { opacity: 0; pointer-events: none; transition: opacity 0.3s; }

/* Mobil/Tablet (gestapeltes Hero-Layout): Banner als Bottom-Sheet; solange er
   offen ist, weicht das Hero-Foto, damit Headline und CTAs voll sichtbar sind. */
@media (max-width: 56rem) {
  .consent { left: 0.75rem; right: 0.75rem; bottom: 0.75rem; max-width: none; }
  .consent-open .hero-full__bg { display: none; }
  .consent-open .hero-full { min-height: 0; }
  .consent-open .hero-full__panel { margin-top: 0; border-radius: 0; }
  .consent-open .hero-full__content { padding-top: 6.5rem; }
  .consent-open body, .consent-open main { padding-bottom: 0; }
  .consent-open .site-foot { padding-bottom: 14rem; }
}

/* ---------- Druck ---------- */
@media print {
  .site-head, .grain, .nav-overlay, .cta-band, .site-foot__main { display: none; }
}
