/* =========================================================================
   components.css — Kino-Grammatik
   Projekt: hypnose-sylvia-manninga.de

   Eine einzige Sprache, für jede Seite:
     1. Buttons
     2. Mobile-Navigation (Drawer)
     3. Cinema-Hero           (.cinema)
     4. Chapter               (.chapter)
     5. Establishing-Shot     (.shot)
     6. Pull-Quote            (.pullquote)
     7. Film-Close / CTA-Band (.close)
     8. Formular / Fields
     9. FAQ (details/summary)
    10. Preis-Tabellen
    11. Kontakt-Kacheln
    12. Map-Frame
    13. Breadcrumb
    14. Scroll-Reveal-Basis
    15. Utility / Kompatibilität
   ========================================================================= */


/* =========================================================================
   1. Buttons
   ========================================================================= */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 28px;
  min-height: 52px;
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-decoration: none;
  border: 1px solid transparent;
  border-radius: var(--r-pill);
  cursor: pointer;
  transition: transform var(--t-fast) var(--ease-std),
              background var(--t-base) var(--ease-std),
              color var(--t-base) var(--ease-std),
              border-color var(--t-base) var(--ease-std),
              box-shadow var(--t-base) var(--ease-std);
  white-space: nowrap;
  text-align: center;
  box-sizing: border-box;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

@media (max-width: 32rem) {
  .cinema__ctas, .close__ctas {
    flex-direction: column;
    align-items: stretch;
    gap: var(--s-3);
  }
  .cinema__ctas > .btn,
  .close__ctas > .btn {
    width: 100%;
    min-width: 0;
  }
  .cinema__ctas > .btn--link,
  .close__ctas > .btn--link {
    width: auto;
    align-self: flex-start;
    padding-inline: 0;
  }
}

.btn--primary {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}
.btn--primary:hover {
  background: var(--navy-deep);
  box-shadow: 0 8px 24px -10px rgba(20, 35, 62, 0.4);
}

.btn--accent, .btn--sage {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
.btn--accent:hover, .btn--sage:hover {
  background: var(--accent-deep);
  box-shadow: 0 8px 24px -10px rgba(232, 99, 45, 0.5);
}

.btn--ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--ink);
}
.btn--ghost:hover {
  background: var(--ink);
  color: var(--paper);
}

.btn--ghost-invert {
  background: transparent;
  color: var(--paper);
  border-color: rgba(245, 240, 232, 0.5);
}
.btn--ghost-invert:hover {
  background: var(--paper);
  color: var(--ink);
  border-color: var(--paper);
}

.btn--link {
  padding: 0;
  min-height: 0;
  background: transparent;
  border: 0;
  color: var(--ink);
  text-transform: none;
  letter-spacing: 0.01em;
  font-size: var(--fs-sm);
  border-radius: 0;
  border-bottom: 1px solid var(--line);
  padding-bottom: 2px;
}
.btn--link:hover { border-bottom-color: var(--ink); transform: none; }

.btn__arrow {
  width: 14px;
  height: 14px;
  transition: transform var(--t-base) var(--ease-out);
}
.btn:hover .btn__arrow { transform: translateX(4px); }


/* =========================================================================
   2. Mobile-Navigation — Drawer
   ========================================================================= */
.nav-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border: 0;
  background: transparent;
  color: var(--ink);
  position: relative;
  z-index: 220;
  transition: color var(--t-base) var(--ease-std);
}
@media (min-width: 56rem) { .nav-toggle { display: none; } }

.nav-toggle__bars {
  position: relative;
  width: 24px;
  height: 14px;
}
.nav-toggle__bars::before,
.nav-toggle__bars::after {
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: 1.5px;
  background: currentColor;
  border-radius: 1px;
  transition: transform var(--t-base) var(--ease-std),
              top var(--t-base) var(--ease-std),
              bottom var(--t-base) var(--ease-std);
}
.nav-toggle__bars::before { top: 0; }
.nav-toggle__bars::after  { bottom: 0; }
.nav-toggle[aria-expanded="true"] .nav-toggle__bars::before { top: 6.5px; transform: rotate(45deg); }
.nav-toggle[aria-expanded="true"] .nav-toggle__bars::after  { bottom: 6.5px; transform: rotate(-45deg); }
.nav-toggle[aria-expanded="true"] { color: #FAF6EE; }

.nav-drawer {
  position: fixed;
  inset: 0;
  background: #17120E;
  color: #FAF6EE;
  z-index: 150;
  padding:
    calc(68px + env(safe-area-inset-top, 0px) + 1.25rem)
    clamp(1.25rem, 6vw, 2rem)
    max(2rem, env(safe-area-inset-bottom, 0px));
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(-6px);
  transition: opacity var(--t-base) var(--ease-std),
              transform var(--t-base) var(--ease-std),
              visibility var(--t-base) var(--ease-std);
  display: flex;
  flex-direction: column;
  gap: var(--s-6);
}
.nav-drawer[data-open="true"] {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}
@media (min-width: 56rem) { .nav-drawer { display: none; } }

.nav-drawer__label {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: rgba(250, 246, 238, 0.6);
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  margin-bottom: var(--s-5);
}
.nav-drawer__label::before {
  content: "";
  width: 32px;
  height: 1px;
  background: var(--accent-soft);
  opacity: 0.6;
}

.nav-drawer__list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}
.nav-drawer__list li { padding: 0; margin: 0; }
.nav-drawer__list li::before { display: none; }

.nav-drawer__link {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-4);
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(1.875rem, 7vw, 2.375rem);
  line-height: 1.08;
  letter-spacing: -0.015em;
  color: #FAF6EE;
  text-decoration: none;
  padding-block: clamp(0.875rem, 2.2vh, 1.25rem);
  border-bottom: 1px solid rgba(250, 246, 238, 0.14);
  transition: color var(--t-fast) var(--ease-std),
              padding-left var(--t-base) var(--ease-out),
              border-color var(--t-fast) var(--ease-std);
  min-height: 48px;
}
.nav-drawer__link:hover,
.nav-drawer__link:focus-visible {
  color: var(--accent-soft);
  padding-left: 6px;
  border-color: rgba(244, 168, 122, 0.3);
}
.nav-drawer__link small {
  font-family: var(--font-body);
  font-size: 0.6875rem;
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: rgba(250, 246, 238, 0.45);
  font-weight: 500;
  flex: 0 0 auto;
}
.nav-drawer__link em {
  font-style: italic;
  font-weight: 400;
  color: var(--accent-soft);
}

.nav-drawer__contact {
  margin-top: auto;
  padding-top: var(--s-6);
  border-top: 1px solid rgba(250, 246, 238, 0.14);
  display: grid;
  gap: var(--s-4);
  font-size: var(--fs-base);
  color: rgba(250, 246, 238, 0.92);
}
.nav-drawer__contact > div:first-child {
  margin-bottom: var(--s-2);
  color: rgba(250, 246, 238, 0.75);
}
.nav-drawer__contact a {
  color: #FAF6EE;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-weight: 400;
  min-height: 44px;
  padding-block: 4px;
}
.nav-drawer__contact a:hover { color: var(--accent-soft); }
.nav-drawer__contact svg {
  color: var(--accent-soft);
  width: 20px; height: 20px; flex: 0 0 20px;
}
.nav-drawer__contact .label {
  display: block;
  font-size: var(--fs-xs);
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: rgba(250, 246, 238, 0.55);
  margin-bottom: 6px;
}


/* =========================================================================
   3. Cinema-Hero — Full-Viewport, Bild + Text-Overlay.
   Das Herzstück jeder Seite: Ken-Burns-Zoom, dunkler Gradient, große
   Serif-Headline, darunter ruhige Lede und CTAs.
   ========================================================================= */
.cinema {
  position: relative;
  min-height: clamp(36rem, 92vh, 56rem);
  margin-top: calc(-1 * var(--hdr-h));
  padding-top: var(--hdr-h);
  isolation: isolate;
  overflow: hidden;
  background: #15110E;
  color: #FAF6EE;
  display: flex;
  align-items: flex-end;
}
@media (min-width: 56rem) {
  .cinema {
    margin-top: calc(-1 * var(--hdr-h-d));
    padding-top: var(--hdr-h-d);
  }
}
.cinema--short {
  min-height: clamp(28rem, 70vh, 42rem);
}

/* Bildebene — absolute, full-bleed, mit Ken-Burns-Zoom. */
.cinema__media {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.cinema__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
  filter: contrast(1.03) saturate(0.92) brightness(0.85);
  animation: kenburns 22s var(--ease-std) both;
  transform-origin: center 30%;
}
@keyframes kenburns {
  from { transform: scale(1.02); }
  to   { transform: scale(1.12); }
}
@media (prefers-reduced-motion: reduce) {
  .cinema__media img { animation: none; transform: none; }
}

/* Dunkel-Gradient für Lesbarkeit — sehr filmisch nach unten gezogen. */
.cinema__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      to top,
      rgba(20, 18, 16, 0.88) 0%,
      rgba(20, 18, 16, 0.55) 38%,
      rgba(20, 18, 16, 0.25) 70%,
      rgba(20, 18, 16, 0.0) 100%
    );
}

/* Vignetten-Randverdunkelung — subtil, nur Atmosphäre. */
.cinema::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: radial-gradient(140% 100% at 50% 50%, transparent 55%, rgba(0,0,0,0.35));
  pointer-events: none;
}

.cinema__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-block: clamp(3rem, 8vh, 6rem) clamp(3.5rem, 10vh, 7rem);
}

.cinema__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: var(--accent-soft);
  margin: 0 0 var(--s-5);
  opacity: 0;
  transform: translateY(6px);
  animation: cinemaFade 900ms var(--ease-out) 200ms forwards;
}
.cinema__eyebrow::before {
  content: "";
  width: var(--s-7);
  height: 1px;
  background: var(--accent-soft);
  opacity: 0.75;
}

.cinema__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-4xl);
  line-height: 0.96;
  letter-spacing: var(--track-xtight);
  color: #FAF6EE;
  margin: 0 0 var(--s-6);
  max-width: 22ch;
  text-wrap: balance;
  text-shadow: 0 4px 40px rgba(0,0,0,0.35);
}
.cinema__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--accent-soft);
}
.cinema__title .line {
  display: block;
  overflow: hidden;
}
.cinema__title .line > span {
  display: inline-block;
  transform: translateY(110%);
  animation: cinemaReveal 1100ms var(--ease-out) forwards;
}
.cinema__title .line:nth-child(1) > span { animation-delay: 200ms; }
.cinema__title .line:nth-child(2) > span { animation-delay: 360ms; }
.cinema__title .line:nth-child(3) > span { animation-delay: 520ms; }
@keyframes cinemaReveal {
  to { transform: translateY(0); }
}
@keyframes cinemaFade {
  to { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .cinema__title .line > span { transform: none; animation: none; }
  .cinema__eyebrow { opacity: 1; transform: none; animation: none; }
}

.cinema__lead {
  font-size: clamp(1.0625rem, 0.95rem + 0.5vw, 1.25rem);
  line-height: 1.55;
  color: rgba(250, 246, 238, 0.85);
  max-width: 38ch;
  margin: 0 0 var(--s-7);
  font-weight: 400;
  opacity: 0;
  transform: translateY(6px);
  animation: cinemaFade 900ms var(--ease-out) 600ms forwards;
}

.cinema__ctas {
  display: flex;
  gap: var(--s-4);
  flex-wrap: wrap;
  align-items: center;
  opacity: 0;
  transform: translateY(6px);
  animation: cinemaFade 900ms var(--ease-out) 800ms forwards;
}
.cinema .btn--ghost {
  color: #FAF6EE;
  border-color: rgba(250, 246, 238, 0.55);
}
.cinema .btn--ghost:hover {
  background: #FAF6EE;
  color: var(--ink);
  border-color: #FAF6EE;
}

/* Scroll-Indikator unten — fein, nur Andeutung. */
.cinema__scroll {
  position: absolute;
  z-index: 3;
  left: 50%;
  bottom: clamp(1.5rem, 3vh, 2.5rem);
  transform: translateX(-50%);
  font-family: var(--font-body);
  font-size: 0.6875rem;
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: rgba(250, 246, 238, 0.6);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  animation: cinemaFade 900ms var(--ease-out) 1000ms both;
}
.cinema__scroll::after {
  content: "";
  width: 1px;
  height: 32px;
  background: linear-gradient(to bottom, rgba(250, 246, 238, 0.5), transparent);
  animation: scrollPulse 2.2s var(--ease-std) infinite;
}
@keyframes scrollPulse {
  0%,100% { opacity: 0.35; transform: scaleY(0.8); }
  50%     { opacity: 1;    transform: scaleY(1); }
}
@media (prefers-reduced-motion: reduce) {
  .cinema__scroll::after { animation: none; }
}


/* =========================================================================
   4. Chapter — Das Kapitel.
   Struktur: riesige Nummer + Titel + schmale Textspalte.
   Alternativen: .chapter--split (Text + Bild), .chapter--center (zentriert).
   ========================================================================= */
.chapter {
  padding-block: clamp(5rem, 10vw, 9rem);
  position: relative;
}
@media (min-width: 72rem) {
  .chapter { padding-block: clamp(7rem, 12vw, 11rem); }
}

.chapter--warm  { background: var(--paper-warm); }
.chapter--deep  { background: var(--paper-deep); }
.chapter--sand  { background: var(--sand); }
.chapter--peach { background: var(--peach); }
.chapter--ink   { background: var(--ink); color: var(--paper); }
.chapter--ink p  { color: rgba(250, 245, 236, 0.82); }
.chapter--ink h2, .chapter--ink h3 { color: var(--paper); }

.chapter__grid {
  display: grid;
  gap: var(--s-7);
  grid-template-columns: 1fr;
}
@media (min-width: 56rem) {
  .chapter__grid {
    grid-template-columns: minmax(11rem, 14rem) minmax(0, 1fr);
    gap: clamp(2rem, 4vw, 4rem);
    align-items: start;
  }
  .chapter--reverse .chapter__grid {
    grid-template-columns: minmax(0, 1fr) minmax(11rem, 14rem);
  }
  .chapter--reverse .chapter__head { order: 2; }
}

.chapter__head {
  position: sticky;
  top: calc(var(--hdr-h-d) + 2rem);
  align-self: start;
}
@media (max-width: 55.99rem) {
  .chapter__head { position: static; }
}

.chapter__num {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(4rem, 3rem + 4vw, 7rem);
  line-height: 0.9;
  letter-spacing: -0.02em;
  color: var(--accent);
  display: block;
  margin-bottom: var(--s-4);
  opacity: 0.92;
}
@media (max-width: 55.99rem) {
  .chapter__num { font-size: clamp(2.75rem, 2rem + 3vw, 4rem); }
}
.chapter--ink .chapter__num { color: var(--accent-soft); }

.chapter__label {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: var(--ink-mute);
}
.chapter__label::before {
  content: "";
  width: var(--s-6);
  height: 1px;
  background: var(--ink-mute);
  opacity: 0.5;
}
.chapter--ink .chapter__label { color: rgba(250, 245, 236, 0.65); }
.chapter--ink .chapter__label::before { background: rgba(250, 245, 236, 0.4); }

.chapter__body {
  max-width: 40rem;
}
.chapter__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--fs-2xl);
  line-height: 1.02;
  letter-spacing: var(--track-xtight);
  color: inherit;
  margin: 0 0 var(--s-6);
  text-wrap: balance;
}
.chapter__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--accent-deep);
}
.chapter--ink .chapter__title em { color: var(--accent-soft); }

.chapter__lede {
  font-size: var(--fs-md);
  line-height: 1.55;
  color: var(--ink-soft);
  margin: 0 0 var(--s-6);
  font-weight: 400;
  max-width: 38ch;
}
.chapter--ink .chapter__lede { color: rgba(250, 245, 236, 0.88); }

.chapter__text p {
  font-size: var(--fs-base);
  line-height: var(--lh-loose);
  max-width: 38em;
}
.chapter__text p + p { margin-top: var(--s-5); }

.chapter__text em {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  color: var(--ink);
}
.chapter--ink .chapter__text em { color: var(--paper); }

/* Liste innerhalb Chapter — sparsame Haken, keine Kacheln. */
.chapter__list {
  list-style: none;
  padding: 0;
  margin: var(--s-6) 0 0;
  display: grid;
  gap: var(--s-4);
}
.chapter__list li {
  padding: 0 0 0 var(--s-6);
  position: relative;
  font-size: var(--fs-base);
  line-height: 1.55;
  color: var(--ink-soft);
}
.chapter__list li::before {
  content: "";
  position: absolute;
  left: 0; top: 0.75em;
  width: var(--s-4);
  height: 1px;
  background: var(--accent);
}

/* Chapter mit Bild-Spalte daneben (Split). */
.chapter__art {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: var(--r-md);
  background: var(--sand);
  box-shadow: 0 30px 60px -28px rgba(20, 18, 16, 0.3);
  margin-top: var(--s-7);
}
.chapter__art img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 25%;
  filter: contrast(1.02);
}
@media (min-width: 56rem) {
  .chapter--withArt .chapter__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: clamp(3rem, 5vw, 5rem);
    align-items: center;
  }
  .chapter--withArt .chapter__head {
    position: static;
  }
  .chapter--withArt.chapter--reverse .chapter__head { order: 1; }
  .chapter--withArt.chapter--reverse .chapter__art  { order: 2; }
  .chapter__art { margin-top: 0; }
}


/* =========================================================================
   5. Establishing-Shot — full-bleed Bild zwischen Kapiteln.
   Cinematische Atempause. Optionaler Caption-Text unten links.
   ========================================================================= */
.shot {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: #15110E;
}
.shot__media {
  position: relative;
  aspect-ratio: 21 / 9;
  max-height: 88vh;
  overflow: hidden;
}
@media (max-width: 55.99rem) {
  .shot__media { aspect-ratio: 4 / 5; max-height: none; }
}
.shot__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%;
  filter: contrast(1.04) saturate(0.92) brightness(0.88);
  transform: scale(1.04);
  transition: transform var(--t-film) var(--ease-out);
}
/* Sanfter Parallax-Effekt via data-parallax (JS setzt translateY). */
[data-parallax] { will-change: transform; }

.shot__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(20, 18, 16, 0.72) 0%,
    rgba(20, 18, 16, 0.25) 40%,
    rgba(20, 18, 16, 0) 70%
  );
  pointer-events: none;
}

.shot__caption {
  position: absolute;
  z-index: 2;
  left: var(--gutter);
  right: var(--gutter);
  bottom: clamp(1.5rem, 4vw, 3rem);
  max-width: 40rem;
  color: #FAF6EE;
  text-shadow: 0 2px 24px rgba(20, 18, 16, 0.5);
}
.shot__label {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--font-body);
  font-size: 0.6875rem;
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: rgba(250, 246, 238, 0.85);
  margin-bottom: var(--s-4);
}
.shot__label::before {
  content: "";
  width: 32px;
  height: 1px;
  background: var(--accent-soft);
}
.shot__text {
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 1.1rem + 1.4vw, 2.25rem);
  line-height: 1.15;
  letter-spacing: -0.015em;
  color: #FAF6EE;
  margin: 0;
  max-width: 24ch;
  font-weight: 400;
}
.shot__text em { font-style: italic; font-weight: 400; color: var(--accent-soft); }


/* =========================================================================
   6. Pull-Quote — Leitsatz in ruhiger Textsektion.
   ========================================================================= */
.pullquote-wrap {
  padding-block: clamp(5rem, 9vw, 8rem);
  position: relative;
}
.pullquote {
  max-width: 52rem;
  margin: 0 auto;
  text-align: left;
  position: relative;
}
.pullquote::before {
  content: "";
  display: block;
  width: 3rem;
  height: 1px;
  background: var(--accent);
  margin-bottom: var(--s-6);
}
.pullquote__text {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 1rem + 2.4vw, 3rem);
  line-height: 1.18;
  font-style: italic;
  font-weight: 400;
  color: var(--ink);
  margin: 0 0 var(--s-5);
  text-wrap: balance;
  letter-spacing: -0.015em;
}
.pullquote__text em { font-style: normal; font-weight: 500; }
.pullquote__attr {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-size: var(--fs-xs);
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: var(--ink-mute);
}
.pullquote__attr::before {
  content: "";
  width: var(--s-6);
  height: 1px;
  background: var(--ink-mute);
  opacity: 0.55;
}


/* =========================================================================
   7. Film-Close / CTA-Band — warmer Abschluss mit Image-Option.
   ========================================================================= */
.close {
  position: relative;
  padding-block: clamp(5rem, 10vw, 8rem);
  background: var(--peach);
  color: var(--ink);
  overflow: hidden;
  isolation: isolate;
}
.close::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent) 30%, var(--accent) 70%, transparent);
  opacity: 0.45;
}
.close__inner {
  display: grid;
  gap: var(--s-6);
  grid-template-columns: 1fr;
  align-items: center;
  max-width: var(--c-lg);
  margin: 0 auto;
  padding-inline: var(--gutter);
  position: relative;
  z-index: 1;
}
@media (min-width: 56rem) {
  .close__inner { grid-template-columns: 1.4fr auto; gap: var(--s-9); }
}
.close__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: var(--accent-deep);
  margin: 0 0 var(--s-5);
}
.close__eyebrow::before {
  content: "";
  width: var(--s-6);
  height: 1px;
  background: var(--accent-deep);
  opacity: 0.6;
}
.close__title {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  line-height: 1.05;
  font-weight: 500;
  color: var(--ink);
  margin: 0 0 var(--s-4);
  letter-spacing: -0.02em;
  text-wrap: balance;
  max-width: 20ch;
}
.close__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--accent-deep);
}
.close__lead {
  color: var(--ink-soft);
  max-width: 48ch;
  margin: 0;
  font-size: var(--fs-md);
  line-height: 1.6;
}
.close__ctas {
  display: flex;
  gap: var(--s-3);
  flex-wrap: wrap;
}


/* =========================================================================
   8. Formular / Fields
   ========================================================================= */
.form {
  display: grid;
  gap: var(--s-5);
  max-width: 42rem;
}
.form__row { display: grid; gap: var(--s-5); }
@media (min-width: 40rem) {
  .form__row--2 { grid-template-columns: 1fr 1fr; }
}

.field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.field__label {
  font-size: var(--fs-xs);
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 500;
}
.field__control {
  font: inherit;
  font-size: var(--fs-base);
  width: 100%;
  padding: 14px 16px;
  background: var(--paper-warm);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  color: var(--ink);
  transition: border-color var(--t-fast) var(--ease-std),
              background var(--t-fast) var(--ease-std),
              box-shadow var(--t-fast) var(--ease-std);
}
.field__control:hover { border-color: var(--ink-mute); }
.field__control:focus {
  border-color: var(--accent);
  background: #fff;
  box-shadow: 0 0 0 3px var(--accent-veil);
  outline: none;
}
textarea.field__control { min-height: 160px; resize: vertical; }

.field[data-error="true"] .field__control {
  border-color: #B84A2C;
  background: #fcf6f3;
}
.field__hint { font-size: var(--fs-xs); color: var(--ink-mute); }
.field__error {
  display: none;
  font-size: var(--fs-xs);
  color: #B84A2C;
}
.field[data-error="true"] .field__error { display: block; }

.checkbox {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  line-height: 1.5;
  cursor: pointer;
}
.checkbox input {
  margin-top: 4px;
  width: 18px; height: 18px;
  accent-color: var(--accent);
}

.form__submit { margin-top: var(--s-3); }

.form-feedback {
  display: flex;
  align-items: flex-start;
  gap: var(--s-4);
  padding: var(--s-4) var(--s-5);
  border-radius: var(--r-md);
  margin-bottom: var(--s-5);
  font-size: var(--fs-sm);
  line-height: 1.5;
}
.form-feedback[hidden] { display: none; }
.form-feedback svg { width: 22px; height: 22px; flex: 0 0 22px; margin-top: 2px; }
.form-feedback strong { display: block; font-weight: 600; color: var(--ink); margin-bottom: 2px; }
.form-feedback span { color: var(--ink-soft); }
.form-feedback--error {
  background: #FCF3EF;
  border: 1px solid #E9CCB8;
  color: #B84A2C;
}
.form-feedback--error svg { color: #B84A2C; }


/* =========================================================================
   9. FAQ
   ========================================================================= */
.faq {
  display: grid;
  gap: 0;
  max-width: var(--c-sm);
  margin-inline: auto;
}
.faq__item { border-top: 1px solid var(--line); }
.faq__item:last-child { border-bottom: 1px solid var(--line); }
.faq__summary {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--s-5);
  padding: var(--s-5) 0;
  cursor: pointer;
  list-style: none;
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 500;
  color: var(--ink);
  line-height: 1.3;
  letter-spacing: var(--track-tight);
  transition: color var(--t-fast) var(--ease-std);
}
.faq__summary::-webkit-details-marker { display: none; }
.faq__summary:hover { color: var(--accent-deep); }
.faq__plus {
  flex: 0 0 28px;
  width: 28px; height: 28px;
  position: relative;
  margin-top: 6px;
  transition: transform var(--t-base) var(--ease-out);
}
.faq__plus::before,
.faq__plus::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  background: var(--ink-soft);
}
.faq__plus::before { width: 14px; height: 1px; }
.faq__plus::after  { width: 1px;  height: 14px; }
.faq__item[open] .faq__plus { transform: rotate(45deg); }
.faq__body {
  padding: 0 0 var(--s-6);
  color: var(--ink-soft);
  font-size: var(--fs-base);
  line-height: var(--lh-loose);
  max-width: 60ch;
}


/* =========================================================================
   10. Preis-Tabellen
   ========================================================================= */
.price {
  background: var(--paper-warm);
  border: 1px solid var(--line-soft);
  border-radius: var(--r-lg);
  padding: var(--s-7) var(--s-6);
  display: flex;
  flex-direction: column;
  height: 100%;
}
.price__label {
  font-size: var(--fs-xs);
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: var(--accent-deep);
  margin-bottom: var(--s-4);
}
.price__title {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 500;
  margin: 0 0 var(--s-3);
  color: var(--ink);
  letter-spacing: var(--track-tight);
  line-height: 1.1;
}
.price__duration {
  font-size: var(--fs-sm);
  color: var(--ink-mute);
  margin-bottom: var(--s-5);
}
.price__amount {
  font-family: var(--font-display);
  font-size: 2.25rem;
  font-weight: 500;
  letter-spacing: var(--track-tight);
  color: var(--ink);
  margin-bottom: var(--s-5);
  line-height: 1;
}
.price__amount small {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  color: var(--ink-mute);
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  display: block;
  margin-top: 6px;
}
.price__list {
  padding: 0;
  margin: 0 0 var(--s-6);
  list-style: none;
  flex: 1;
}
.price__list li {
  position: relative;
  padding: 10px 0 10px 1.5rem;
  font-size: var(--fs-sm);
  color: var(--ink-soft);
  border-bottom: 1px solid var(--line-soft);
}
.price__list li:last-child { border-bottom: 0; }
.price__list li::before {
  content: "";
  position: absolute;
  left: 0; top: 18px;
  width: 10px; height: 1px;
  background: var(--accent-deep);
}
.price--feature {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.price--feature .price__title,
.price--feature .price__amount { color: var(--paper); }
.price--feature .price__label { color: var(--accent-soft); }
.price--feature .price__duration { color: rgba(245, 240, 232, 0.6); }
.price--feature .price__list li {
  color: rgba(245, 240, 232, 0.78);
  border-color: rgba(245, 240, 232, 0.14);
}


/* =========================================================================
   11. Kontakt-Kacheln
   ========================================================================= */
.contact-tiles {
  display: grid;
  gap: var(--s-5);
  grid-template-columns: 1fr;
}
@media (min-width: 48rem) {
  .contact-tiles { grid-template-columns: repeat(3, 1fr); }
}
.contact-tile {
  background: var(--paper-warm);
  border: 1px solid var(--line-soft);
  border-radius: var(--r-lg);
  padding: var(--s-6);
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
  text-decoration: none;
  color: inherit;
  transition: transform var(--t-base) var(--ease-out),
              box-shadow var(--t-base) var(--ease-out),
              border-color var(--t-base) var(--ease-out);
}
.contact-tile:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--accent-soft);
}
.contact-tile__icon { width: 28px; height: 28px; color: var(--accent-deep); }
.contact-tile__label {
  font-size: var(--fs-xs);
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: var(--ink-mute);
}
.contact-tile__value {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  letter-spacing: var(--track-tight);
  color: var(--ink);
  line-height: 1.1;
}


/* =========================================================================
   12. Map-Frame
   ========================================================================= */
.map-frame {
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  background: var(--sand);
  aspect-ratio: 16 / 10;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-mute);
  font-size: var(--fs-sm);
  position: relative;
}
.map-frame iframe { width: 100%; height: 100%; border: 0; display: block; }


/* =========================================================================
   13. Breadcrumb
   ========================================================================= */
.crumbs {
  font-size: var(--fs-xs);
  letter-spacing: 0.04em;
  color: var(--ink-mute);
  padding-top: var(--s-5);
}
.crumbs ol {
  list-style: none;
  padding: 0; margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
}
.crumbs li { padding: 0; margin: 0; }
.crumbs li::before { display: none; }
.crumbs li + li::before {
  content: "/";
  display: inline-block;
  margin-right: 10px;
  color: var(--line);
}
.crumbs a { text-decoration: none; color: var(--ink-mute); }
.crumbs a:hover { color: var(--ink); }
.crumbs [aria-current="page"] { color: var(--ink-soft); }


/* =========================================================================
   14. Öffnungszeiten-Tabelle (Anfahrt)
   ========================================================================= */
.hours {
  margin: 0;
  display: grid;
  gap: 0;
  max-width: 36rem;
}
.hours__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--s-5);
  padding-block: clamp(0.875rem, 1.5vh, 1.125rem);
  border-top: 1px solid var(--line);
  font-size: var(--fs-md);
}
.hours__row:last-child { border-bottom: 1px solid var(--line); }
.hours__row dt {
  font-family: var(--font-display);
  font-size: 1.375rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.hours__row dd {
  font-family: var(--font-body);
  font-size: 0.9375rem;
  letter-spacing: 0.08em;
  color: var(--ink-soft);
  margin: 0;
  font-variant-numeric: tabular-nums;
}
.hours__row--closed dt,
.hours__row--closed dd {
  color: var(--ink-mute);
}

/* Auf dunklem Untergrund. */
.chapter--ink .hours__row { border-color: rgba(245, 240, 232, 0.16); }
.chapter--ink .hours__row dt { color: var(--paper); }
.chapter--ink .hours__row dd { color: rgba(245, 240, 232, 0.82); }


/* =========================================================================
   15. Scroll-Reveal / Motion-Basis
   ========================================================================= */
[data-reveal] {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity var(--t-slow) var(--ease-out),
              transform var(--t-slow) var(--ease-out);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}
[data-reveal="true"] {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1; transform: none; transition: none; }
}

/* Divider — schmale horizontale Linie, animiert beim Scrollen. */
.rule {
  display: block;
  height: 1px;
  background: var(--line);
  border: 0;
  width: 0;
  margin: 0;
  transition: width var(--t-film) var(--ease-out);
}
[data-reveal="true"] .rule,
.rule[data-reveal="true"] { width: 100%; }


/* =========================================================================
   Kompatibilitäts-Aliasse für bestehendes Markup
   (FAQ, Impressum, Datenschutz, 404, Danke — Legal-Seiten, keine Cinema)
   ========================================================================= */
.hero { position: relative; overflow: hidden; isolation: isolate; }
.hero--image { display: block; padding: 0; background: var(--paper); }

/* Quiet-Hero: schlichte Textsektion oben, kein Cinema. */
.hero--quiet {
  padding-block: clamp(4rem, 8vh, 6rem) var(--s-7);
  display: block;
  text-align: left;
}
.hero--quiet .hero__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(2.25rem, 1.5rem + 3.2vw, 4rem);
  line-height: 1.02;
  letter-spacing: var(--track-xtight);
  margin: 0 0 var(--s-5);
  text-wrap: balance;
}
.hero--quiet .hero__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--accent-deep);
}
.hero--quiet .hero__meta {
  display: inline-flex;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: var(--track-xwide);
  text-transform: uppercase;
  color: var(--accent-deep);
  margin-bottom: var(--s-5);
}
.hero--quiet .hero__meta::before {
  content: "";
  width: var(--s-7);
  height: 1px;
  background: var(--accent-deep);
  opacity: 0.7;
}
.hero--quiet .hero__lead,
.hero--quiet .lead {
  font-size: var(--fs-md);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 52ch;
  margin: 0 0 var(--s-6);
}

/* Section-Header Kompat */
.section-header { max-width: var(--c-sm); margin: 0 auto var(--s-8); }
.section-header--center { text-align: center; margin-inline: auto; }
.section-header__title {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: 500;
  letter-spacing: -0.025em;
  line-height: 1.04;
  margin: 0 0 var(--s-3);
  color: var(--ink);
}
.section-header__title em { font-style: italic; font-weight: 500; color: var(--accent-deep); }
.section-header__lead {
  max-width: 52ch;
  color: var(--ink-soft);
  font-size: var(--fs-md);
  line-height: 1.55;
  margin: 0;
}
.section-header--center .section-header__lead { margin-inline: auto; }

/* CTA-Band Kompat — wie .close, aber für altes Markup. */
.cta-band {
  position: relative;
  padding-block: clamp(5rem, 10vw, 8rem);
  background: var(--peach);
  color: var(--ink);
  overflow: hidden;
  isolation: isolate;
}
.cta-band::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--accent) 30%, var(--accent) 70%, transparent);
  opacity: 0.45;
}
.cta-band__inner {
  display: grid;
  gap: var(--s-6);
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 56rem) {
  .cta-band__inner { grid-template-columns: 1.4fr auto; gap: var(--s-9); }
}
.cta-band__title {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  line-height: 1.05;
  font-weight: 500;
  color: var(--ink);
  margin: 0 0 var(--s-3);
  letter-spacing: -0.02em;
  text-wrap: balance;
  max-width: 22ch;
}
.cta-band__title em {
  font-style: italic;
  font-weight: 500;
  color: var(--accent-deep);
}
.cta-band__lead {
  color: var(--ink-soft);
  max-width: 48ch;
  margin: 0;
  font-size: var(--fs-md);
  line-height: 1.6;
}
.cta-band__ctas {
  display: flex;
  gap: var(--s-3);
  flex-wrap: wrap;
}

/* Info-Card Kompat — schlichte Liste-in-Spalten-Variante. */
.info-card {
  padding: var(--s-5) 0 var(--s-5) var(--s-5);
  border-left: 1px solid var(--line);
  list-style: none;
}
.info-card::before { display: none; }
.info-card__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.375rem;
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin: 0 0 var(--s-3);
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
}
.info-card__text {
  margin: 0;
  color: var(--ink-soft);
  font-size: var(--fs-base);
  line-height: var(--lh-base);
}

/* Legal-Seiten Container (Impressum/Datenschutz) */
.legal-section {
  padding-block: clamp(3rem, 6vw, 5rem);
}
.legal-section h2 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 500;
  letter-spacing: -0.015em;
  color: var(--ink);
  margin: var(--s-6) 0 var(--s-3);
}
.legal-section h3 {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  font-weight: 600;
  color: var(--ink);
  margin: var(--s-5) 0 var(--s-2);
}
.legal-section p,
.legal-section li {
  font-size: var(--fs-base);
  line-height: var(--lh-loose);
  color: var(--ink-soft);
}


/* =========================================================================
   16. Polish & Micro-Motion
   Feine Details, die das Ganze "filmisch" machen. Diese Sektion ist bewusst
   am Ende, damit die Basis-Komponenten klar bleiben.
   ========================================================================= */

/* ---- 16.1 Film-Grain auf Cinema + Shot ----------------------------------
   SVG-Noise als data-URI, blendmode soft-light — wirkt wie 35mm-Filmkorn,
   ohne JPEG-Kompressionsartefakte. Sehr subtil, nur Atmosphäre. */
.cinema::after,
.shot::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  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.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.96 0 0 0 0 0.93 0 0 0 0 0.85 0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/></svg>");
  background-size: 180px 180px;
  mix-blend-mode: soft-light;
  opacity: 0.35;
}
.shot { position: relative; }
.shot::before { z-index: 2; }
@media (prefers-reduced-motion: reduce) {
  .cinema::after, .shot::before { opacity: 0.22; }
}

/* Caption auf shot und Content im cinema müssen über dem Grain liegen. */
.cinema__inner, .shot__caption { z-index: 3; }


/* ---- 16.2 Logo-Lift über Cinema-Hero -----------------------------------
   Das Logo hat eine Navy-Fläche built-in. Auf dunklem Cinema wird diese
   Fläche fast unsichtbar. Lift per drop-shadow + sanftem Glow. */
.site-header.is-atop .brand__logo {
  filter:
    drop-shadow(0 1px 2px rgba(0, 0, 0, 0.6))
    drop-shadow(0 4px 20px rgba(0, 0, 0, 0.45));
}


/* ---- 16.3 Cinema-Eyebrow: Linie zeichnet sich. ------------------------- */
.cinema__eyebrow::before {
  width: 0;
  animation: eyebrow-line-draw 1.1s var(--ease-out) 500ms forwards;
}
@keyframes eyebrow-line-draw {
  from { width: 0; }
  to   { width: var(--s-7); }
}
@media (prefers-reduced-motion: reduce) {
  .cinema__eyebrow::before { width: var(--s-7); animation: none; }
}


/* ---- 16.4 Chapter-Nummer: Fade + Slide beim Reveal --------------------- */
.chapter__head .chapter__num {
  opacity: 0;
  transform: translateY(12px) scale(0.98);
  transition:
    opacity var(--t-slow) var(--ease-out) 80ms,
    transform var(--t-slow) var(--ease-out) 80ms;
}
.chapter__head[data-reveal="true"] .chapter__num {
  opacity: 0.92;
  transform: translateY(0) scale(1);
}
.chapter--ink .chapter__head[data-reveal="true"] .chapter__num { opacity: 1; }
@media (prefers-reduced-motion: reduce) {
  .chapter__head .chapter__num { opacity: 0.92; transform: none; transition: none; }
}


/* ---- 16.5 Chapter-Label: Linie zeichnet beim Reveal ------------------- */
.chapter__label::before {
  transition: width var(--t-slow) var(--ease-out) 240ms;
}
[data-reveal] .chapter__label::before { width: 0; }
[data-reveal="true"] .chapter__label::before { width: var(--s-6); }


/* ---- 16.6 Pull-Quote: Riesiges Anführungszeichen als Akzent ----------- */
.pullquote {
  padding-left: clamp(1rem, 4vw, 3rem);
}
.pullquote::after {
  content: "\201C";
  position: absolute;
  left: -0.05em;
  top: -0.55em;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(7rem, 10vw + 3rem, 13rem);
  line-height: 1;
  color: var(--accent);
  opacity: 0.18;
  pointer-events: none;
  user-select: none;
  font-feature-settings: "liga" 1;
}
.pullquote::before {
  margin-bottom: var(--s-5);
}


/* ---- 16.7 Shot: Subtiler Ken-Burns + Filter-Lift ---------------------- */
.shot__media img {
  animation: shot-drift 28s var(--ease-std) infinite alternate;
}
@keyframes shot-drift {
  from { transform: scale(1.04) translateZ(0); }
  to   { transform: scale(1.12) translate(1%, -1%) translateZ(0); }
}
@media (prefers-reduced-motion: reduce) {
  .shot__media img { animation: none; }
}
/* Wenn JS Parallax den Transform überschreibt, bricht Ken-Burns — das ist OK,
   Parallax hat Priorität. */


/* ---- 16.8 Button-Arrow: Schwung + Leading-Line ------------------------ */
.btn { position: relative; overflow: hidden; }
.btn--primary::before,
.btn--accent::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg,
    transparent 0%,
    rgba(255,255,255,0.18) 50%,
    transparent 100%);
  transform: translateX(-120%);
  transition: transform 700ms var(--ease-out);
  pointer-events: none;
}
.btn--primary:hover::before,
.btn--accent:hover::before {
  transform: translateX(120%);
}


/* ---- 16.9 Reading-Progress: dünner, subtiler ------------------------- */
.reading-progress {
  height: 1.5px;
  background: linear-gradient(90deg, var(--accent-soft) 0%, var(--accent) 50%, var(--accent-deep) 100%);
  box-shadow: 0 0 8px rgba(232, 99, 45, 0.35);
}


/* ---- 16.10 Cinema-Scroll-Indikator: Text + Linie gemeinsam fade ----- */
.cinema__scroll {
  transition: opacity 400ms var(--ease-std);
}
.site-header:not(.is-atop) ~ main .cinema__scroll {
  opacity: 0;
}


/* ---- 16.11 Chapter: breiterer Textfluss bei --withArt-Sonderfall ---- */
.chapter__body > .contact-tiles,
.chapter__body > .form,
.chapter__body > .grid,
.chapter__body > .hours {
  max-width: none;
}


/* ---- 16.12 Shot-Caption: noch etwas mehr Textschatten bei schwerer Bildhelligkeit */
.shot__text {
  text-shadow:
    0 2px 24px rgba(20, 18, 16, 0.55),
    0 1px 3px rgba(20, 18, 16, 0.4);
}


/* ---- 16.13 Close: sanfte radiale Wärme-Fläche hinter Text ----------- */
.close {
  background:
    radial-gradient(60rem 40rem at 85% 120%, rgba(232, 99, 45, 0.14), transparent 60%),
    radial-gradient(50rem 35rem at 10% -10%, rgba(255, 251, 242, 0.8), transparent 55%),
    var(--peach);
}


/* ---- 16.14 Focus-Ring einheitlich auf allen Cinema-Elementen -------- */
.cinema a:focus-visible,
.shot a:focus-visible,
.close a:focus-visible {
  outline-color: var(--accent-soft);
  outline-offset: 4px;
}


/* ---- 16.15 Chapter-Body: kleines Atempause-Polster oben auf Mobile -- */
@media (max-width: 55.99rem) {
  .chapter__body { margin-top: var(--s-3); }
  .chapter__num { display: inline-block; margin-right: 0; }
}
