/* =================================================================
   SPREE BBQ — Dark Smokehouse Design System
   ================================================================= */
:root {
  --bg:        #0d0907;
  --bg-alt:    #16100c;
  --bg-card:   #1c150f;
  --bone:      #f4ece0;
  --bone-soft: rgba(244,236,224,.72);
  --bone-mute: rgba(244,236,224,.45);
  --line:      rgba(244,236,224,.10);
  --line-soft: rgba(244,236,224,.06);
  --ember:     #a0251f;
  --ember-hot: #c0342c;
  --flame:     #a0251f;
  --gold:      #c9a35b;
  --char:      #2a1d14;

  --font-display: 'Playfair Display', Georgia, serif;
  --font-hero:    'Bebas Neue', 'Oswald', Impact, sans-serif;
  --font-body:    'Inter', system-ui, sans-serif;
  --font-mono:    'DM Mono', ui-monospace, monospace;

  --pad:    clamp(1.25rem, 4vw, 4.5rem);
  --pad-y:  clamp(4rem, 10vw, 9rem);
  --radius: 18px;
  --radius-lg: 28px;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  background-color: var(--bg);
}
body {
  font-family: var(--font-body);
  background: transparent;
  color: var(--bone);
  line-height: 1.55;
  font-size: 17px;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
/* Festes Hintergrundbild — funktioniert auch auf iOS Safari,
   wo background-attachment: fixed nicht zuverlässig läuft */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -1;
  background-image:
    linear-gradient(rgba(13, 9, 7, .88), rgba(13, 9, 7, .92)),
    url('Hintergrund.jpg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  pointer-events: none;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
ul { list-style: none; }
::selection { background: var(--ember); color: var(--bone); }

/* ---------- Navigation ---------- */
.nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 90;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem var(--pad);
  transition: background .35s, border-color .35s, padding .35s;
  border-bottom: 1px solid transparent;
}
.nav.is-scrolled {
  background: rgba(13, 9, 7, .82);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-color: var(--line);
  padding-block: .8rem;
}
.nav.is-open {
  background: rgba(13, 9, 7, .98);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.nav__logo {
  position: relative;
  z-index: 101;
  display: flex;
  align-items: center;
  gap: .9rem;
  line-height: 1;
}
.nav__logo img {
  height: 68px; width: 68px;
  object-fit: contain;
  border-radius: 50%;
  background: var(--bg);
}
.nav.is-scrolled .nav__logo img { height: 56px; width: 56px; }
.nav__logo-text {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 20px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.nav__logo-text small {
  display: block;
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--bone-mute);
  margin-top: 3px;
}
.nav__menu {
  display: flex;
  gap: 2.2rem;
  font-size: 14px;
  font-weight: 500;
}
.nav__menu a {
  position: relative;
  padding: .25rem 0;
  color: var(--bone-soft);
  transition: color .25s;
}
.nav__menu a:hover,
.nav__menu a.is-active { color: var(--bone); }
.nav__menu a::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -3px;
  height: 1px; background: var(--ember);
  transform: scaleX(0); transform-origin: right; transition: transform .35s;
}
.nav__menu a:hover::after,
.nav__menu a.is-active::after { transform: scaleX(1); transform-origin: left; }

/* Hamburger — nur auf Mobile sichtbar */
.nav__toggle {
  display: none;
  position: relative;
  width: 46px; height: 46px;
  border: 1px solid var(--bone-mute);
  border-radius: 999px;
  background: transparent;
  place-items: center;
  cursor: pointer;
  transition: background .25s, border-color .25s;
  z-index: 101;
}
@media (max-width: 820px) {
  .nav__toggle { display: grid; }
}
.nav__toggle:hover { background: var(--bone); border-color: var(--bone); }
.nav__toggle-lines { display: grid; gap: 5px; }
.nav__toggle-lines > span {
  display: block;
  width: 18px;
  height: 1.5px;
  background: var(--bone);
  transition: transform .3s cubic-bezier(.2,.8,.2,1), opacity .2s, background .25s;
}
.nav__toggle:hover .nav__toggle-lines > span { background: var(--bg); }
.nav.is-open .nav__toggle-lines > span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav.is-open .nav__toggle-lines > span:nth-child(2) { opacity: 0; }
.nav.is-open .nav__toggle-lines > span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile-Overlay-Menü */
@media (max-width: 820px) {
  .nav__menu {
    position: fixed;
    inset: 0;
    background: var(--bg);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 2rem;
    font-size: 1.6rem;
    transform: translateX(100%);
    transition: transform .4s cubic-bezier(.2,.8,.2,1);
    z-index: 100;
  }
  .nav__menu a { color: var(--bone); }
  .nav__menu a::after { display: none; }
  .nav.is-open .nav__menu { transform: translateX(0); }
}

/* ---------- HERO ---------- */
.hero {
  position: relative;
  min-height: 100svh;
  display: grid;
  align-items: end;
  overflow: hidden;
  isolation: isolate;
}
.hero__bg { position: absolute; inset: 0; z-index: -2; }
.hero__bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  transform: scale(1.04);
  animation: heroDrift 18s ease-in-out infinite alternate;
}
@keyframes heroDrift {
  from { transform: scale(1.04) translate3d(0, 0, 0); }
  to   { transform: scale(1.10) translate3d(-1.5%, -1%, 0); }
}
@media (max-width: 720px) {
  .hero__bg img {
    transform: none;
    animation: heroPan 28s ease-in-out infinite;
  }
}
@keyframes heroPan {
  0%   { object-position: 50% center; }
  25%  { object-position: 65% center; }
  75%  { object-position: 35% center; }
  100% { object-position: 50% center; }
}
.hero__bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 70% 35%, transparent 0%, rgba(13,9,7,.55) 70%),
    linear-gradient(to top, var(--bg) 0%, rgba(13,9,7,.55) 38%, rgba(13,9,7,.15) 70%, rgba(13,9,7,.45) 100%);
}

.hero__inner {
  position: relative;
  padding: 8rem var(--pad) clamp(2.5rem, 5vw, 4.5rem);
  width: 100%;
  max-width: 1280px;
  margin: 0;
  display: grid;
  justify-items: start;
  text-align: left;
  gap: 1.6rem;
}
.hero__title, .hero__lead, .hero__actions { justify-self: start; text-align: left; }
.hero__title {
  font-family: var(--font-hero);
  font-weight: 400;
  font-size: clamp(2.4rem, 6.4vw, 5.8rem);
  line-height: .95;
  letter-spacing: .005em;
  text-transform: uppercase;
  max-width: 16ch;
}
.hero__title em {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  text-transform: none;
  letter-spacing: -0.02em;
  color: var(--flame);
}
.hero__lead {
  font-size: clamp(1rem, 1.2vw, 1.18rem);
  line-height: 1.55;
  max-width: 580px;
  color: var(--bone-soft);
}
.hero__actions {
  display: flex;
  gap: .9rem;
  flex-wrap: wrap;
  margin-top: .4rem;
}
@media (max-width: 900px) {
  .hero__inner { padding-top: 7rem; }
}

/* ---------- Subpage Header (kleiner als Hero) ---------- */
.page-head {
  position: relative;
  padding: 9rem var(--pad) 3rem;
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 1.2rem;
}
.page-head__eyebrow {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.05rem;
  color: var(--flame);
  display: inline-flex;
  align-items: center;
  gap: .85rem;
}
.page-head__eyebrow::before {
  content: '';
  display: inline-block;
  width: 36px;
  height: 1px;
  background: currentColor;
}
.page-head__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2.6rem, 5.6vw, 4.6rem);
  line-height: .98;
  letter-spacing: -0.02em;
  max-width: 18ch;
}
.page-head__title em { font-style: italic; font-weight: 500; color: var(--flame); }
.page-head__lead {
  color: var(--bone-soft);
  max-width: 620px;
  font-size: 1.05rem;
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  padding: 1rem 1.7rem;
  border-radius: 999px;
  font-weight: 500;
  font-size: 15px;
  letter-spacing: .01em;
  transition: transform .3s cubic-bezier(.2,.8,.2,1), background .25s, color .25s, box-shadow .3s, border-color .25s;
}
.btn--primary {
  background: var(--ember);
  color: var(--bone);
  box-shadow: 0 14px 30px -12px rgba(160,37,31,.7);
}
.btn--primary:hover {
  background: var(--ember-hot);
  transform: translateY(-2px);
  box-shadow: 0 18px 40px -12px rgba(192,52,44,.8);
}
.btn--ghost {
  background: rgba(244,236,224,.04);
  color: var(--bone);
  border: 1px solid var(--bone-mute);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.btn--ghost:hover {
  background: var(--bone);
  color: var(--bg);
  border-color: var(--bone);
}
.btn--full { width: 100%; justify-content: center; }
.btn svg { width: 18px; height: 18px; }

/* ---------- Marquee ---------- */
.marquee {
  border-block: 1px solid var(--line);
  background: rgba(22, 16, 12, .85);
  color: var(--bone);
  overflow: hidden;
  padding: 1.4rem 0;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.6rem, 3.4vw, 2.6rem);
  letter-spacing: -0.01em;
}
.marquee__track {
  display: inline-flex;
  white-space: nowrap;
  gap: 2.2rem;
  animation: marquee 42s linear infinite;
  padding-left: 2.2rem;
}
.marquee__track span:nth-child(odd)  { color: var(--bone); }
.marquee__track span:nth-child(even) { color: var(--ember); font-style: normal; font-weight: 700; }
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ---------- Section heading ---------- */
.section-head {
  padding: var(--pad-y) var(--pad) 3rem;
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 1rem 4rem;
  align-items: end;
}
.section-head--center { text-align: center; grid-template-columns: 1fr; gap: 1.2rem; padding-bottom: 3rem; }
.section-head--flush  { padding-inline: 0; padding-top: 0; }
.section-head__num {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.05rem;
  letter-spacing: 0;
  text-transform: none;
  color: var(--flame);
  align-self: start;
  padding-top: .35rem;
  display: inline-flex;
  align-items: center;
  gap: .85rem;
}
.section-head__num::before {
  content: '';
  display: inline-block;
  width: 36px;
  height: 1px;
  background: currentColor;
}
.section-head--center .section-head__num { justify-self: center; }
.section-head--center .section-head__num::after {
  content: '';
  display: inline-block;
  width: 36px;
  height: 1px;
  background: currentColor;
}
.section-head__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2.4rem, 5.6vw, 4.6rem);
  line-height: .98;
  letter-spacing: -0.02em;
  grid-column: 1 / -1;
}
.section-head__title em { font-style: italic; font-weight: 500; color: var(--flame); }
.section-head--center .section-head__title { grid-column: auto; }
.section-head__lead {
  grid-column: 2 / -1;
  max-width: 580px;
  color: var(--bone-soft);
  font-size: 1.05rem;
}
@media (max-width: 800px) {
  .section-head { grid-template-columns: 1fr; gap: 1rem; }
  .section-head__lead { grid-column: 1; }
}

/* ---------- TEASER (Landing-Sektionen mit Link auf Subpage) ---------- */
.teaser {
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--pad-y) var(--pad);
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(2.5rem, 5vw, 5rem);
  align-items: center;
}
.teaser--reverse { grid-template-columns: 1.1fr 1fr; }
.teaser--reverse .teaser__visual { order: 2; }
.teaser__visual {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 5;
  background: var(--bg-card);
  max-width: 480px;
  width: 100%;
}
.teaser__visual img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.teaser__visual:hover img { transform: scale(1.04); }
.teaser__text { display: grid; gap: 1.2rem; }
.teaser__text h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2rem, 4.4vw, 3.4rem);
  line-height: 1.02;
  letter-spacing: -0.02em;
}
.teaser__text h2 em { font-style: italic; font-weight: 500; color: var(--flame); }
.teaser__text p {
  color: var(--bone-soft);
  font-size: 1.05rem;
  max-width: 540px;
}
.teaser__actions {
  display: flex;
  gap: .9rem;
  flex-wrap: wrap;
  margin-top: .6rem;
}
.teaser__actions--center {
  justify-content: center;
  margin-top: 2.5rem;
}
@media (max-width: 900px) {
  .teaser, .teaser--reverse { grid-template-columns: 1fr; }
  .teaser--reverse .teaser__visual { order: 0; }
  .teaser__visual { aspect-ratio: 4 / 3; max-width: none; }
}

/* ---------- SPEISEN-PITCH (Landing Hero-Pitch für individuelles Buffet) ---------- */
.speisen-pitch {
  padding: var(--pad-y) var(--pad);
  background: rgba(22, 16, 12, .55);
  border-block: 1px solid var(--line);
}
.speisen-pitch__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 3rem;
  justify-items: center;
  text-align: center;
}
.speisen-pitch__head {
  display: grid;
  gap: 1.3rem;
  justify-items: center;
  max-width: 720px;
}
.speisen-pitch__head h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2.4rem, 5.6vw, 4.4rem);
  line-height: .98;
  letter-spacing: -0.02em;
}
.speisen-pitch__head h2 em { font-style: italic; font-weight: 500; color: var(--flame); }
.speisen-pitch__head p {
  color: var(--bone-soft);
  font-size: 1.1rem;
  max-width: 600px;
}
.speisen-pitch__media {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  width: 100%;
  max-width: 1100px;
}
.speisen-pitch__media figure {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 16 / 10;
  background: var(--bg-card);
}
.speisen-pitch__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.speisen-pitch__media figure:hover img { transform: scale(1.04); }
@media (max-width: 700px) {
  .speisen-pitch__media { grid-template-columns: 1fr; }
}

.speisen-pitch__pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  width: 100%;
  max-width: 1100px;
}
.pillar {
  background: var(--bg-alt);
  padding: 2.4rem 2rem;
  display: grid;
  gap: .8rem;
  align-content: start;
  text-align: left;
  transition: background .35s;
}
.pillar:hover { background: rgba(160,37,31,.06); }
.pillar__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ember);
}
.pillar h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.3rem, 2vw, 1.6rem);
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.pillar p {
  color: var(--bone-soft);
  font-size: .96rem;
}
@media (max-width: 800px) {
  .speisen-pitch__pillars { grid-template-columns: 1fr; }
}

/* ---------- ANLÄSSE-STRIP (kompakte Liste auf Landing) ---------- */
.anlaesse-strip {
  background: rgba(22, 16, 12, .55);
  border-block: 1px solid var(--line);
  padding: var(--pad-y) var(--pad);
}
.anlaesse-strip__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  gap: 2rem;
  text-align: center;
  justify-items: center;
}
.anlaesse-strip__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2rem, 4.4vw, 3.4rem);
  line-height: 1.02;
  letter-spacing: -0.02em;
}
.anlaesse-strip__title em { font-style: italic; font-weight: 500; color: var(--flame); }
.anlaesse-strip__tags {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  justify-content: center;
  max-width: 800px;
}
.anlaesse-strip__tags li {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  padding: .65rem 1.1rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  color: var(--bone-soft);
  transition: background .25s, color .25s, border-color .25s;
}
.anlaesse-strip__tags li:hover {
  background: var(--ember);
  border-color: var(--ember);
  color: var(--bone);
}

/* ---------- PREISKALKULATOR ---------- */
.kalk { padding: 0 var(--pad) var(--pad-y); }
.kalk__inner {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: clamp(2rem, 4vw, 3.5rem);
  align-items: start;
}
@media (max-width: 900px) { .kalk__inner { grid-template-columns: 1fr; } }

.kalk-form { display: grid; gap: 2.5rem; }

.kalk-block {
  display: grid;
  gap: 1.2rem;
}
.kalk-block__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  flex-wrap: wrap;
  gap: .5rem;
  border-bottom: 1px solid var(--line);
  padding-bottom: .9rem;
}
.kalk-block__head h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.4rem, 2.4vw, 1.8rem);
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.kalk-block__head h2 em { font-style: italic; font-weight: 500; color: var(--flame); }
.kalk-block__hint {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--bone-mute);
}

.kalk-people {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  align-items: center;
  padding: 1.2rem 1.4rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(244,236,224,.02);
}
.kalk-people label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--gold);
}
.kalk-people input {
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 700;
  background: transparent;
  border: 0;
  color: var(--bone);
  outline: none;
  width: 110px;
  text-align: right;
  padding: 0;
  -moz-appearance: textfield;
}
.kalk-people input::-webkit-outer-spin-button,
.kalk-people input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.kalk-items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .8rem;
}
@media (max-width: 600px) { .kalk-items { grid-template-columns: 1fr; } }

.kalk-item {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: .6rem 1rem;
  padding: 1rem 1.2rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(244,236,224,.02);
  cursor: pointer;
  transition: background .25s, border-color .25s, transform .2s;
  user-select: none;
}
.kalk-item:hover { border-color: var(--bone-mute); background: rgba(244,236,224,.05); }
.kalk-item input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.kalk-item__name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.kalk-item__desc {
  grid-column: 1 / -1;
  margin-top: -0.2rem;
  color: var(--bone-mute);
  font-size: .85rem;
}
.kalk-item__price {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .08em;
  color: var(--bone-soft);
  white-space: nowrap;
}
.kalk-item.is-checked {
  background: rgba(160,37,31,.16);
  border-color: var(--ember);
}
.kalk-item.is-checked .kalk-item__price { color: var(--bone); }
.kalk-item__qty {
  grid-column: 1 / -1;
  margin-top: .35rem;
  display: none;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ember);
}
.kalk-item__qty strong {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--bone);
  margin-right: .4rem;
}
.kalk-item.is-checked .kalk-item__qty { display: block; }

/* Sidebar Summary */
.kalk-summary {
  position: sticky;
  top: 7rem;
  display: grid;
  gap: 1rem;
  padding: 1.8rem 1.6rem;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: rgba(13,9,7,.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.kalk-summary__label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
}
.kalk-summary__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: .95rem;
  color: var(--bone-soft);
  padding: .35rem 0;
}
.kalk-summary__row strong {
  font-family: var(--font-display);
  font-weight: 600;
  color: var(--bone);
}
.kalk-summary__divider {
  height: 1px;
  background: var(--line);
  margin: .4rem 0;
}
.kalk-summary__total {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-top: .4rem;
}
.kalk-summary__total span {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--bone-mute);
}
.kalk-summary__total strong {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2rem, 3.5vw, 2.6rem);
  color: var(--ember);
  letter-spacing: -0.02em;
}
.kalk-summary__per {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .1em;
  color: var(--bone-mute);
  text-align: right;
}
.kalk-summary__cta { margin-top: .6rem; }
.kalk-summary__note {
  font-size: 11px;
  color: var(--bone-mute);
  line-height: 1.5;
  margin-top: .4rem;
}

.kalk-summary__handle { display: none; }

@media (max-width: 900px) {
  .kalk-summary {
    position: fixed;
    bottom: 0; left: 0; right: 0;
    top: auto;
    border-radius: 18px 18px 0 0;
    box-shadow: 0 -10px 30px rgba(0,0,0,.5);
    z-index: 80;
    background: rgba(13,9,7,.96);
    padding: .6rem 1.2rem 1.2rem;
    gap: .4rem;
  }

  /* Bottom-Sheet Handle */
  .kalk-summary__handle {
    display: grid;
    justify-items: center;
    gap: .35rem;
    background: none;
    border: 0;
    color: var(--bone-mute);
    font-family: var(--font-mono);
    font-size: 10px;
    letter-spacing: .2em;
    text-transform: uppercase;
    padding: .4rem 0 .6rem;
    cursor: pointer;
    width: 100%;
    transition: color .25s;
  }
  .kalk-summary__handle:hover { color: var(--bone); }
  .kalk-summary__grip {
    display: block;
    width: 44px;
    height: 4px;
    background: var(--bone-mute);
    border-radius: 99px;
    transition: background .25s, width .25s;
  }
  .kalk-summary.is-expanded .kalk-summary__grip {
    background: var(--ember);
    width: 60px;
  }
  .kalk-summary.is-expanded .kalk-summary__handle-text::after { content: ' verbergen'; }
  .kalk-summary:not(.is-expanded) .kalk-summary__handle-text::after { content: ' anzeigen'; }

  .kalk-summary__label { display: none; }

  /* Detail-Bereich klappt aus */
  .kalk-summary__rows {
    max-height: 0;
    overflow: hidden;
    transition: max-height .4s cubic-bezier(.2,.8,.2,1);
  }
  .kalk-summary.is-expanded .kalk-summary__rows {
    max-height: 320px;
    padding-bottom: .4rem;
  }
  .kalk-summary__divider { display: none; }
  .kalk-summary.is-expanded .kalk-summary__divider { display: block; }
  .kalk-summary__note { display: none; }
  .kalk-summary.is-expanded .kalk-summary__note { display: block; }

  .kalk-form { padding-bottom: 11rem; }
}

/* ---------- QR-LANDING (für Visitenkarten-QR-Code) ---------- */
.qr-page {
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: 2rem 1.2rem;
}
.qr-card {
  width: 100%;
  max-width: 440px;
  display: grid;
  gap: 1.4rem;
  text-align: center;
  padding: 2.4rem 1.8rem;
  background: rgba(13, 9, 7, .65);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: 0 30px 60px -20px rgba(0,0,0,.6);
}
.qr-card__logo {
  width: 100px;
  height: 100px;
  object-fit: contain;
  margin: 0 auto;
  border-radius: 50%;
}
.qr-card__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.8rem, 7vw, 2.3rem);
  line-height: 1;
  letter-spacing: -0.02em;
}
.qr-card__title em { font-style: italic; font-weight: 500; color: var(--flame); }
.qr-card__lead {
  color: var(--bone-soft);
  font-size: 1rem;
  line-height: 1.5;
}
.qr-card__lead strong {
  color: var(--bone);
  font-family: var(--font-display);
  font-weight: 700;
  font-style: italic;
}
.qr-card__cta {
  width: 100%;
  justify-content: center;
  margin-top: .2rem;
}
.qr-divider {
  display: flex;
  align-items: center;
  gap: .8rem;
  margin: .4rem 0 .2rem;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--bone-mute);
}
.qr-divider::before,
.qr-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--line);
}
.qr-actions { display: grid; gap: .5rem; }
.qr-action {
  display: flex;
  align-items: center;
  gap: .9rem;
  padding: .85rem 1.2rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(244,236,224,.02);
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1rem;
  color: var(--bone);
  text-align: left;
  transition: background .25s, border-color .25s, transform .2s;
}
.qr-action:hover {
  background: rgba(160,37,31,.18);
  border-color: var(--ember);
  transform: translateY(-2px);
}
.qr-action svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  color: var(--ember);
  transition: color .2s;
}
.qr-action:hover svg { color: var(--bone); }
.qr-action__arrow {
  margin-left: auto;
  color: var(--bone-mute);
  font-family: var(--font-mono);
}

/* ---------- BANNER-SPEISEKARTE (Druck-Layout) ---------- */
.banner {
  max-width: 720px;
  margin: 6rem auto;
  padding: clamp(2rem, 5vw, 3rem);
  background: var(--bg-alt);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  display: grid;
  gap: 2rem;
  position: relative;
}
.banner__head {
  text-align: center;
  display: grid;
  gap: 1rem;
  justify-items: center;
}
.banner__head img {
  width: 120px;
  height: 120px;
  object-fit: contain;
  border-radius: 50%;
}
.banner__title {
  font-family: var(--font-hero);
  font-weight: 400;
  font-size: clamp(2.4rem, 6vw, 3.6rem);
  letter-spacing: .01em;
  text-transform: uppercase;
  line-height: .95;
}
.banner__subtitle {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: 1.15rem;
  color: var(--flame);
}
.banner__divider {
  height: 1px;
  background: var(--line);
}
.banner__section {
  display: grid;
  gap: .9rem;
}
.banner__section h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
  color: var(--ember);
  text-transform: uppercase;
}
.banner__items { display: grid; gap: .55rem; }
.banner__item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 1rem;
  align-items: baseline;
  font-size: .98rem;
}
.banner__item-name {
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: -0.005em;
}
.banner__item-desc {
  font-size: .82rem;
  color: var(--bone-soft);
  margin-top: 1px;
  display: block;
}
.banner__item-price {
  font-family: var(--font-mono);
  font-size: .85rem;
  letter-spacing: .04em;
  color: var(--ember);
  white-space: nowrap;
}
.banner__foot {
  text-align: center;
  display: grid;
  gap: .5rem;
  padding-top: 1rem;
  border-top: 1px solid var(--line);
}
.banner__foot strong {
  font-family: var(--font-display);
  font-size: 1.1rem;
  font-weight: 700;
}
.banner__foot a {
  color: var(--ember);
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: .08em;
}
.banner__hint {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--bone-mute);
}

.banner-toolbar {
  max-width: 720px;
  margin: 2rem auto 0;
  padding: 0 var(--pad);
  display: flex;
  gap: .8rem;
  justify-content: center;
  flex-wrap: wrap;
}

@media print {
  body::before, .nav, .banner-toolbar, .footer { display: none !important; }
  body { background: white; color: black; }
  .banner {
    margin: 0;
    background: white;
    color: black;
    border: none;
    box-shadow: none;
    page-break-after: avoid;
  }
  .banner__title, .banner__item-name, .banner__foot strong { color: black; }
  .banner__section h3, .banner__item-price, .banner__foot a, .banner__subtitle { color: #a0251f; }
  .banner__item-desc, .banner__hint { color: #555; }
  .banner__divider, .banner__foot { border-color: #ccc; background: #ddd; }
}

/* ---------- FINAL CTA (Landing Schluss-Block) ---------- */
.final-cta {
  padding: var(--pad-y) var(--pad);
  background: rgba(13, 9, 7, .55);
  border-top: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.final-cta::before {
  content: '';
  position: absolute;
  top: -200px; left: 50%;
  width: 520px; height: 520px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--ember) 0%, transparent 65%);
  opacity: .14;
  filter: blur(40px);
  pointer-events: none;
  transform: translateX(-50%);
}
.final-cta__inner {
  max-width: 760px;
  margin: 0 auto;
  text-align: center;
  display: grid;
  gap: 1.4rem;
  position: relative;
}
.final-cta__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2.2rem, 5vw, 3.8rem);
  line-height: 1;
  letter-spacing: -0.02em;
}
.final-cta__title em { font-style: italic; font-weight: 500; color: var(--flame); }
.final-cta__lead {
  color: var(--bone-soft);
  font-size: 1.05rem;
  max-width: 520px;
  margin: 0 auto;
}
.final-cta__actions {
  display: flex;
  gap: .9rem;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: .6rem;
}

/* ---------- PHILOSOPHIE ---------- */
.pitch {
  padding: var(--pad-y) var(--pad);
  padding-top: max(var(--pad-y), 7rem);
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.1fr 1fr;
  gap: clamp(1.8rem, 3.5vw, 3.5rem);
  align-items: center;
}
.pitch__photo {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 3 / 4;
  background: var(--bg-card);
}
.pitch__photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.pitch__photo:hover img { transform: scale(1.04); }
.pitch__photo--right { margin-top: 3rem; }
@media (max-width: 1000px) {
  .pitch { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .pitch__text { grid-column: 1 / -1; order: -1; }
  .pitch__photo--right { margin-top: 0; }
}
@media (max-width: 720px) {
  .pitch {
    display: flex;
    flex-direction: column;
    gap: .4rem;
    padding-top: 7rem;
    padding-bottom: clamp(3.5rem, 9vw, 5rem);
  }
  .pitch__text { display: contents; }
  .pitch__photo {
    width: 78%;
    max-width: 340px;
    aspect-ratio: 4 / 5;
    margin: 0;
    box-shadow: 0 18px 40px -22px rgba(0, 0, 0, .65);
  }
  .pitch__photo--left {
    order: 2;
    align-self: flex-start;
    transform: rotate(-1.5deg);
    margin-top: 1.2rem;
    margin-bottom: -.5rem;
  }
  .pitch__stats {
    order: 3;
    width: 100%;
    margin: 0;
    padding-block: .9rem;
    border-block: 1px solid var(--line);
    gap: .8rem;
  }
  .pitch__stat strong { font-size: clamp(1.5rem, 5.5vw, 2rem); }
  .pitch__stat span   { font-size: 10px; letter-spacing: .14em; }
  .pitch__photo--right {
    order: 4;
    align-self: flex-end;
    margin-top: 0;
    transform: rotate(1.5deg);
  }
  .pitch__text > .section-head__num,
  .pitch__text > h1,
  .pitch__text > h2,
  .pitch__text > p { order: 1; }
  .pitch__text > h1,
  .pitch__text > h2 { margin-top: .4rem; }
  .pitch__text > p  { margin-top: .4rem; }
}
.pitch__text h1,
.pitch__text h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2rem, 4.4vw, 3.6rem);
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin-bottom: 1.5rem;
}
.pitch__text h1 em,
.pitch__text h2 em { font-style: italic; font-weight: 500; color: var(--flame); }
.pitch__text p {
  color: var(--bone-soft);
  font-size: 1.05rem;
  margin-bottom: 1.2rem;
  max-width: 520px;
}
.pitch__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: 2.5rem;
  padding-top: 2.5rem;
  border-top: 1px solid var(--line);
}
.pitch__stat { display: grid; gap: .25rem; }
.pitch__stat strong {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2rem, 3.5vw, 2.8rem);
  color: var(--bone);
  letter-spacing: -0.02em;
  line-height: 1;
}
.pitch__stat span {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--bone-mute);
}

/* Wenn Pitch direkt vor Setup steht: Luft dazwischen reduzieren */
.pitch:has(+ .setup) { padding-bottom: 2rem; }
.pitch + .setup .section-head { padding-top: 2.5rem; padding-bottom: 1.5rem; }

/* ---------- UNSERE SPEISEN ---------- */
.speisen { padding-bottom: var(--pad-y); }

.speisen__intro {
  max-width: 1280px;
  margin: 0 auto;
  padding: var(--pad-y) var(--pad) clamp(2.5rem, 5vw, 5rem);
  display: grid;
  grid-template-columns: 0.78fr 1.1fr;
  gap: clamp(2.5rem, 5vw, 5rem);
  align-items: center;
}
.speisen__intro-visual {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 3 / 4;
  background: var(--bg-card);
  max-width: 380px;
  justify-self: start;
}
.speisen__intro-visual img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.speisen__intro-visual:hover img { transform: scale(1.04); }
.speisen__intro-text h2 {
  margin-top: 1rem;
  margin-bottom: 1.5rem;
}
.speisen__intro-text p {
  color: var(--bone-soft);
  font-size: 1.05rem;
  margin-bottom: 1.2rem;
  max-width: 540px;
}
@media (max-width: 900px) {
  .speisen__intro { grid-template-columns: 1fr; }
  .speisen__intro-visual {
    aspect-ratio: 4/3;
    order: 2;
    max-width: none;
    justify-self: stretch;
  }
  .speisen__intro-text { order: 1; }
}

.speisen__head {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--pad) 3rem;
  display: grid;
  grid-template-columns: 1.15fr 0.95fr;
  gap: clamp(1.6rem, 3vw, 3rem);
  align-items: start;
}
.speisen__head-text { display: grid; gap: 1.2rem; }
.speisen__head h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.8rem, 3.6vw, 2.8rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  max-width: 22ch;
}
.speisen__head h3 em { font-style: italic; font-weight: 500; color: var(--flame); }
.speisen__head p {
  color: var(--bone-soft);
  max-width: 580px;
  font-size: 1.02rem;
}
.speisen__head-photo {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 12 / 5;
  margin-top: 1rem;
  align-self: start;
  background: var(--bg-card);
}
.speisen__head-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s cubic-bezier(.2,.8,.2,1);
}
.speisen__head-photo:hover img { transform: scale(1.04); }
@media (max-width: 800px) {
  .speisen__head { grid-template-columns: 1fr; }
  .speisen__head-photo { margin-top: 0; }
}

/* Slider */
.slider-container { position: relative; width: 100%; overflow: hidden; }
.slider-track {
  display: flex;
  gap: 1.25rem;
  padding: .5rem var(--pad) 1.5rem;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
  cursor: grab;
}
.slider-track::-webkit-scrollbar { display: none; }
.slider-track:active { cursor: grabbing; }
.slider-track.is-dragging { cursor: grabbing; scroll-behavior: auto; }

.food-card {
  flex: 0 0 clamp(260px, 28vw, 360px);
  position: relative;
  overflow: hidden;
  aspect-ratio: 3 / 4;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  transition: transform .5s cubic-bezier(.2,.8,.2,1), border-color .35s;
}
.food-card:hover { transform: translateY(-4px); border-color: rgba(160,37,31,.5); }
.food-card__image {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.4s cubic-bezier(.2,.8,.2,1);
}
.food-card:hover .food-card__image { transform: scale(1.06); }
.food-card__content {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 1.6rem 1.6rem 1.5rem;
  background: linear-gradient(to top, rgba(13,9,7,.95) 0%, rgba(13,9,7,.6) 50%, transparent 90%);
}
.food-card__name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.45rem;
  letter-spacing: -0.01em;
  line-height: 1.05;
  margin-bottom: .5rem;
}
.food-card__desc {
  font-size: .9rem;
  color: var(--bone-soft);
  line-height: 1.5;
}

.slider-nav {
  display: flex;
  justify-content: center;
  gap: .8rem;
  margin-top: 1rem;
}
.slider-btn {
  width: 52px; height: 52px;
  border: 1px solid var(--bone-mute);
  background: transparent;
  color: var(--bone);
  border-radius: 50%;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: background .25s, color .25s, border-color .25s, transform .25s;
}
.slider-btn svg { width: 18px; height: 18px; }
.slider-btn:hover {
  background: var(--ember);
  border-color: var(--ember);
  color: var(--bone);
  transform: translateY(-2px);
}

/* ---------- ESSENSSTAND & GRILL ---------- */
.setup { padding-bottom: var(--pad-y); }
.setup__grid {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 var(--pad);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
}
.setup-card {
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .5s cubic-bezier(.2,.8,.2,1), border-color .35s;
}
.setup-card:hover { transform: translateY(-6px); border-color: rgba(160,37,31,.4); }
.setup-card__media { aspect-ratio: 16 / 10; overflow: hidden; }
.setup-card__media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.4s cubic-bezier(.2,.8,.2,1);
}
.setup-card:hover .setup-card__media img { transform: scale(1.05); }
.setup-card__body {
  padding: 2rem 2.2rem 2.2rem;
  display: flex;
  flex-direction: column;
  gap: .9rem;
}
.setup-card__body h3 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(1.4rem, 2.4vw, 1.95rem);
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.setup-card__body p { color: var(--bone-soft); font-size: .98rem; }
.setup-card__list {
  margin-top: .5rem;
  display: grid;
  gap: .55rem;
}
.setup-card__list li {
  position: relative;
  padding-left: 1.5rem;
  font-size: .94rem;
  color: var(--bone-soft);
}
.setup-card__list li::before {
  content: '';
  position: absolute;
  left: 0; top: .55em;
  width: 12px; height: 1px;
  background: var(--ember);
}
@media (max-width: 800px) {
  .setup__grid { grid-template-columns: 1fr; }
}

/* ---------- ANLÄSSE (Vollansicht auf Subpage) ---------- */
.anlaesse {
  background: rgba(22, 16, 12, .55);
  border-block: 1px solid var(--line);
}
.anlaesse__grid {
  max-width: 1280px;
  margin: 0 auto var(--pad-y);
  margin-inline: var(--pad);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
@media (min-width: 1344px) {
  .anlaesse__grid { margin-inline: auto; }
}
.anlass {
  background: var(--bg-alt);
  padding: 2rem 1.8rem;
  display: grid;
  gap: .65rem;
  align-content: start;
  transition: background .35s;
}
.anlass:hover { background: rgba(160,37,31,.06); }
.anlass h4 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.35rem;
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.anlass p { color: var(--bone-soft); font-size: .94rem; }
@media (max-width: 900px) { .anlaesse__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .anlaesse__grid { grid-template-columns: 1fr; } }

/* ---------- ABLAUF / Process ---------- */
.process {
  background: rgba(22, 16, 12, .55);
  border-block: 1px solid var(--line);
  padding: var(--pad-y) var(--pad);
}
.process__inner { max-width: 1280px; margin: 0 auto; }
.process__grid {
  margin-top: 3rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.step {
  padding: 2.2rem 1.8rem;
  border-right: 1px solid var(--line);
  display: grid;
  gap: .9rem;
  align-content: start;
  position: relative;
  transition: background .35s;
}
.step:last-child { border-right: 0; }
.step:hover { background: rgba(160,37,31,.06); }
.step__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--ember);
}
.step h4 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.4rem;
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.step p { color: var(--bone-soft); font-size: .95rem; }
@media (max-width: 900px) {
  .process__grid { grid-template-columns: repeat(2, 1fr); }
  .step:nth-child(2) { border-right: 0; }
  .step:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
}
@media (max-width: 540px) {
  .process__grid { grid-template-columns: 1fr; }
  .step { border-right: 0; border-bottom: 1px solid var(--line); }
  .step:last-child { border-bottom: 0; }
}

.process__cta {
  margin-top: 3rem;
  text-align: center;
  display: grid;
  gap: 1.4rem;
  justify-items: center;
}
.process__cta-lead {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.4rem, 2.4vw, 1.9rem);
  color: var(--bone);
}
.process__cta-buttons {
  display: flex;
  gap: .9rem;
  flex-wrap: wrap;
  justify-content: center;
}

/* ---------- GALERIE — Doppel-Slider ---------- */
.gallery { padding-bottom: var(--pad-y); }

.gallery-slider {
  position: relative;
  margin-top: 1.4rem;
  overflow: hidden;
  --slide-h: 320px;
  --slide-gap: 14px;
}
.gallery-slider:first-of-type { margin-top: 1rem; }
.gallery-slider::before,
.gallery-slider::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 80px;
  z-index: 4;
  pointer-events: none;
}
.gallery-slider::before { left: 0;  background: linear-gradient(90deg,  var(--bg), transparent); }
.gallery-slider::after  { right: 0; background: linear-gradient(270deg, var(--bg), transparent); }

.gallery-slider__track {
  display: flex;
  width: max-content;
  animation: gallery-marquee 46s linear infinite;
  will-change: transform;
}
.gallery-slider:hover .gallery-slider__track { animation-play-state: paused; }
.gallery-slider--reverse .gallery-slider__track {
  animation-direction: reverse;
  animation-duration: 52s;
}

.gallery-slider__slide {
  flex: 0 0 auto;
  width: clamp(220px, calc((100vw - 80px) / 3 - var(--slide-gap)), 460px);
  height: var(--slide-h);
  margin-right: var(--slide-gap);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: zoom-in;
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--line);
}
.gallery-slider__slide img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .6s ease;
  user-select: none;
  -webkit-user-drag: none;
  pointer-events: none;
}
.gallery-slider__slide:hover img { transform: scale(1.05); }

@keyframes gallery-marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

@media (max-width: 800px) {
  .gallery-slider { --slide-h: 240px; }
  .gallery-slider__slide { width: clamp(200px, calc((100vw - 40px) / 2 - var(--slide-gap)), 360px); }
  .gallery-slider::before, .gallery-slider::after { width: 40px; }
}
@media (max-width: 480px) {
  .gallery-slider__slide { width: calc(85vw - var(--slide-gap)); }
}

/* ---------- LIGHTBOX ---------- */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,.95);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .3s ease;
}
.lightbox.is-open { opacity: 1; }
.lightbox__img {
  max-width: 92vw;
  max-height: 88vh;
  object-fit: contain;
  user-select: none;
  -webkit-user-drag: none;
  border-radius: 6px;
}
.lightbox__close,
.lightbox__btn {
  position: absolute;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.18);
  color: var(--bone);
  cursor: pointer;
  border-radius: 999px;
  display: grid;
  place-items: center;
  transition: background .2s, border-color .2s, transform .2s;
}
.lightbox__close { top: 1.4rem; right: 1.4rem; width: 44px; height: 44px; font-size: 22px; line-height: 1; }
.lightbox__btn   { top: 50%; transform: translateY(-50%); width: 52px; height: 52px; font-size: 28px; line-height: 1; }
.lightbox__btn--prev { left: 1.4rem; }
.lightbox__btn--next { right: 1.4rem; }
.lightbox__close:hover,
.lightbox__btn:hover { background: var(--ember); border-color: var(--ember); }
.lightbox__counter {
  position: absolute;
  bottom: 1.4rem;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(244,236,224,.6);
}
@media (max-width: 600px) {
  .lightbox__btn { width: 40px; height: 40px; font-size: 20px; }
  .lightbox__btn--prev { left: .8rem; }
  .lightbox__btn--next { right: .8rem; }
  .lightbox__close { top: .8rem; right: .8rem; }
}

/* ---------- CONTACT ---------- */
.contact {
  position: relative;
  padding: var(--pad-y) var(--pad);
  padding-top: max(var(--pad-y), 7rem);
  background: rgba(22, 16, 12, .55);
  border-top: 1px solid var(--line);
  overflow: hidden;
}
.contact::before {
  content: '';
  position: absolute;
  top: -200px; right: -200px;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--ember) 0%, transparent 65%);
  opacity: .14;
  filter: blur(40px);
  pointer-events: none;
}
.contact__inner {
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
}
.contact__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(2.4rem, 5.6vw, 4.6rem);
  line-height: .98;
  letter-spacing: -0.02em;
  margin: 1rem 0 1.2rem;
  max-width: 16ch;
}
.contact__title em { font-style: italic; font-weight: 500; color: var(--flame); }
.contact__lead {
  color: var(--bone-soft);
  max-width: 540px;
  margin-bottom: 3rem;
  font-size: 1.05rem;
}
.contact__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 1rem;
}
@media (max-width: 600px) { .contact__grid { grid-template-columns: 1fr; } }

.contact__location {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 1rem;
  margin-bottom: 3.5rem;
}
.contact-card--address { display: flex; flex-direction: column; }
.contact__map-frame {
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--line);
  min-height: 280px;
  background: var(--bg-card);
}
.contact__map-frame iframe {
  width: 100%;
  height: 100%;
  min-height: 280px;
  border: 0;
  display: block;
  filter: grayscale(.35) brightness(.88) contrast(1.05);
  transition: filter .3s;
}
.contact__map-frame:hover iframe { filter: none; }
@media (max-width: 700px) {
  .contact__location { grid-template-columns: 1fr; }
  .contact__map-frame { min-height: 240px; }
}

.contact-card {
  display: flex;
  flex-direction: column;
  gap: .5rem;
  padding: 1.6rem 1.5rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(244,236,224,.02);
  transition: background .25s, transform .3s, border-color .25s;
}
.contact-card:not(.contact-card--static):hover {
  background: var(--ember);
  border-color: var(--ember);
  transform: translateY(-4px);
}
.contact-card__label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
  transition: color .25s;
}
.contact-card:not(.contact-card--static):hover .contact-card__label { color: rgba(244,236,224,.92); }
.contact-card__value {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.25;
}
.contact-card__cta {
  margin-top: auto;
  padding-top: 1rem;
  font-size: 13px;
  color: var(--bone-mute);
  transition: color .25s;
}
.contact-card:not(.contact-card--static):hover .contact-card__cta { color: rgba(244,236,224,.95); }

/* Social CTA */
.contact__social {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: .8rem;
  margin: 2.4rem 0 3rem;
}
.contact__social-btn { gap: .8rem; }
.contact__social-btn svg { width: 1.15em; height: 1.15em; }
@media (max-width: 600px) {
  .contact__social { flex-direction: column; align-items: stretch; }
  .contact__social-btn { width: 100%; justify-content: center; }
}

/* Form */
.contact__form-wrap {
  border-top: 1px solid var(--line);
  padding-top: 3rem;
  max-width: 760px;
  margin: 0 auto;
}
.contact-form { display: grid; gap: 1.3rem; }
.contact-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.3rem; }
@media (max-width: 600px) { .contact-form__row { grid-template-columns: 1fr; } }
.contact-form label { display: grid; gap: .4rem; }
.contact-form span {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold);
}
.contact-form input,
.contact-form select,
.contact-form textarea {
  font: inherit;
  font-size: 1rem;
  background: transparent;
  color: var(--bone);
  border: 0;
  border-bottom: 1px solid var(--line);
  padding: .75rem 0;
  outline: none;
  transition: border-color .25s;
  border-radius: 0;
}
.contact-form select {
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--bone) 50%),
    linear-gradient(135deg, var(--bone) 50%, transparent 50%);
  background-position: calc(100% - 14px) 55%, calc(100% - 8px) 55%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 1.5rem;
  cursor: pointer;
}
.contact-form select option { background: var(--bg-alt); color: var(--bone); }
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus { border-color: var(--ember); }
.contact-form textarea { resize: vertical; min-height: 120px; }

.contact-form input[type="date"] {
  color-scheme: dark;
  cursor: pointer;
}
.contact-form input[type="date"]::-webkit-calendar-picker-indicator {
  filter: invert(.9);
  opacity: .55;
  cursor: pointer;
  transition: opacity .2s;
}
.contact-form input[type="date"]::-webkit-calendar-picker-indicator:hover { opacity: 1; }

.contact-form__honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.contact-form__consent {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
  padding: 1rem 1.1rem;
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid var(--line-soft);
  border-radius: 10px;
  cursor: pointer;
  font-size: .88rem;
  line-height: 1.55;
  color: var(--bone-soft);
  transition: border-color .2s, background-color .2s;
}
.contact-form__consent:hover {
  border-color: rgba(201, 163, 91, 0.3);
  background: rgba(255, 255, 255, 0.04);
}
.contact-form__consent:has(input:checked) {
  border-color: rgba(201, 163, 91, 0.4);
  background: rgba(201, 163, 91, 0.05);
}
.contact-form__consent input {
  margin-top: 2px;
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  accent-color: var(--gold);
  cursor: pointer;
}
.contact-form__consent a {
  color: var(--ember-hot);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.contact-form__consent a:hover { color: var(--bone); }

.contact-form__status {
  display: none;
  padding: .9rem 1.1rem;
  border-radius: 6px;
  font-size: .92rem;
  line-height: 1.5;
}
.contact-form__status.is-loading {
  display: block;
  color: var(--bone-soft);
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--line-soft);
}
.contact-form__status.is-success {
  display: block;
  color: #9bd6a6;
  background: rgba(70, 160, 95, 0.12);
  border: 1px solid rgba(70, 160, 95, 0.45);
}
.contact-form__status.is-error {
  display: block;
  color: #e3a4a0;
  background: rgba(160, 37, 31, 0.15);
  border: 1px solid rgba(160, 37, 31, 0.5);
}

/* ---------- FOOTER ---------- */
.footer {
  padding: 3.5rem var(--pad) 2rem;
  background: rgba(13, 9, 7, .85);
  border-top: 1px solid var(--line);
}
.footer__inner { max-width: 1280px; margin: 0 auto; }
.footer__top {
  display: grid;
  grid-template-columns: 1fr auto 1.2fr;
  gap: 3rem;
  align-items: start;
  padding-bottom: 3rem;
  border-bottom: 1px solid var(--line);
}
@media (max-width: 800px) { .footer__top { grid-template-columns: 1fr; } }

.footer__brand {
  display: flex;
  align-items: center;
  gap: 1rem;
  line-height: 1.25;
}
.footer__brand img { height: 50px; width: 50px; border-radius: 50%; }
.footer__brand p {
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.footer__brand p small {
  display: block;
  font-family: var(--font-mono);
  font-weight: 400;
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--bone-mute);
  margin-top: 4px;
  text-transform: uppercase;
}
.footer__claim {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(1.6rem, 3.6vw, 2.6rem);
  line-height: 1;
  letter-spacing: -0.01em;
  text-align: right;
  color: var(--bone-soft);
}
.footer__claim em { font-style: normal; color: var(--ember); font-weight: 700; }
@media (max-width: 800px) { .footer__claim { text-align: left; } }
.footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
  font-size: 14px;
  align-self: end;
  justify-content: flex-end;
}
@media (max-width: 800px) { .footer__links { justify-content: flex-start; } }
.footer__links a { color: var(--bone-soft); transition: color .25s; }
.footer__links a:hover { color: var(--ember); }

.footer__bottom {
  padding-top: 1.5rem;
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--bone-mute);
}
@media (max-width: 600px) { .footer__bottom { flex-direction: column; gap: .5rem; } }
.footer__credit a { color: var(--bone-soft); transition: color .25s; }
.footer__credit a:hover { color: var(--ember); }

/* ---------- Reveal animations ---------- */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .9s ease, transform .9s ease; }
.reveal.is-in { opacity: 1; transform: none; }
.reveal-stagger > * { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; }
.reveal-stagger.is-in > * { opacity: 1; transform: none; }
.reveal-stagger.is-in > *:nth-child(1) { transition-delay: .05s; }
.reveal-stagger.is-in > *:nth-child(2) { transition-delay: .15s; }
.reveal-stagger.is-in > *:nth-child(3) { transition-delay: .25s; }
.reveal-stagger.is-in > *:nth-child(4) { transition-delay: .35s; }
.reveal-stagger.is-in > *:nth-child(5) { transition-delay: .45s; }
.reveal-stagger.is-in > *:nth-child(6) { transition-delay: .55s; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .reveal, .reveal-stagger > * { opacity: 1; transform: none; }
}

/* ---------- TOAST ---------- */
.toast {
  position: fixed;
  bottom: 1.5rem;
  left: 50%;
  z-index: 10000;
  padding: .85rem 1.4rem;
  background: var(--bg-card);
  color: var(--bone);
  border: 1px solid var(--line);
  border-radius: 999px;
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.5);
  font-size: .9rem;
  letter-spacing: .01em;
  opacity: 0;
  transform: translate(-50%, 24px);
  transition: opacity .3s ease, transform .35s cubic-bezier(.2, .8, .2, 1);
  white-space: nowrap;
  max-width: calc(100vw - 2rem);
  pointer-events: none;
}
.toast.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}
.toast--success { border-color: rgba(201, 163, 91, 0.4); }
.toast--error { border-color: rgba(160, 37, 31, 0.5); color: #e3a4a0; }
@media (max-width: 480px) {
  .toast {
    left: 1rem;
    right: 1rem;
    transform: translate(0, 24px);
    white-space: normal;
    text-align: center;
  }
  .toast.is-visible { transform: translate(0, 0); }
}

/* ---------- CONSENT BANNER (dezent, unten rechts) ---------- */
.consent-banner {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  width: calc(100% - 3rem);
  max-width: 400px;
  max-height: calc(100vh - 3rem);
  overflow-y: auto;
  background: var(--bg-card);
  color: var(--bone);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow:
    0 20px 50px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(201, 163, 91, 0.06);
  z-index: 9999;
  font-size: .9rem;
  line-height: 1.55;
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .3s ease, transform .35s cubic-bezier(.2, .8, .2, 1);
}
.consent-banner.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.consent-banner__inner {
  padding: 1.5rem 1.6rem 1.3rem;
}

.consent-banner__icon {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 30% 30%, rgba(201, 163, 91, 0.2), transparent 60%),
    linear-gradient(135deg, rgba(201, 163, 91, 0.12), rgba(160, 37, 31, 0.18));
  border: 1px solid rgba(201, 163, 91, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 .9rem;
  color: var(--gold);
}
.consent-banner__icon svg { width: 18px; height: 18px; }

.consent-banner__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 1.2;
  letter-spacing: -0.01em;
  margin: 0 0 .55rem;
  color: var(--bone);
}
.consent-banner__title em {
  font-style: italic;
  font-weight: 400;
  color: var(--gold);
}

.consent-banner__text {
  margin: 0 0 1.1rem;
  color: var(--bone-soft);
  font-size: .85rem;
  line-height: 1.55;
}
.consent-banner__text strong { color: var(--bone); font-weight: 600; }
.consent-banner__text a {
  color: var(--ember-hot);
  text-decoration: underline;
  text-underline-offset: 2px;
}

.consent-banner__categories {
  display: grid;
  gap: .4rem;
  margin-bottom: 1.1rem;
}
.consent-banner__cat {
  display: flex;
  align-items: flex-start;
  gap: .7rem;
  cursor: pointer;
  padding: .65rem .8rem;
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid var(--line-soft);
  border-radius: 8px;
  color: var(--bone-soft);
  font-size: .82rem;
  transition: border-color .2s, background-color .2s;
}
.consent-banner__cat:not(.is-required):hover {
  border-color: rgba(201, 163, 91, 0.3);
  background: rgba(255, 255, 255, 0.04);
}
.consent-banner__cat input {
  margin-top: 2px;
  flex-shrink: 0;
  width: 15px;
  height: 15px;
  accent-color: var(--gold);
  cursor: pointer;
}
.consent-banner__cat.is-required { cursor: default; }
.consent-banner__cat.is-required input { cursor: not-allowed; }
.consent-banner__cat strong {
  display: block;
  color: var(--bone);
  font-weight: 600;
  margin-bottom: .1rem;
}
.consent-banner__cat-desc {
  display: block;
  font-size: .76rem;
  color: var(--bone-mute);
  line-height: 1.4;
}

.consent-banner__actions {
  display: grid;
  gap: .4rem;
}
.consent-banner__actions-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .4rem;
}
.consent-banner__actions .btn {
  padding: .7rem 1rem;
  font-size: .78rem;
  letter-spacing: .05em;
  width: 100%;
  justify-content: center;
}

.consent-banner__legal {
  margin: 1rem 0 0;
  font-size: .72rem;
  color: var(--bone-mute);
  text-align: center;
}
.consent-banner__legal a { color: var(--bone-soft); text-decoration: underline; text-underline-offset: 2px; }
.consent-banner__legal a:hover { color: var(--bone); }

@media (max-width: 600px) {
  .consent-banner {
    right: 1rem;
    left: 1rem;
    bottom: 1rem;
    width: auto;
    max-width: none;
  }
  .consent-banner__actions-row { grid-template-columns: 1fr; }
}

/* ---------- MAPS PLACEHOLDER ---------- */
.map-placeholder {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 280px;
  background: var(--bg-alt);
  border: 1px solid var(--line);
  border-radius: 4px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .9rem;
  padding: 1.8rem 1.4rem;
  text-align: center;
  color: var(--bone-soft);
}
.map-placeholder__text {
  margin: 0;
  font-size: .92rem;
  line-height: 1.55;
  max-width: 380px;
  color: var(--bone-soft);
}
.map-placeholder__text strong { color: var(--bone); }
.map-placeholder__note {
  margin: 0;
  font-size: .8rem;
  color: var(--bone-mute);
}
.map-placeholder__note a { color: var(--flame); text-decoration: underline; }
.map-placeholder.is-loaded {
  padding: 0;
  min-height: auto;
  background: none;
  border: 0;
  border-radius: 0;
}
.map-placeholder.is-loaded iframe {
  width: 100%;
  height: 100%;
  min-height: 280px;
  border: 0;
  display: block;
}

/* ---------- LEGAL PAGES (Impressum / Datenschutz) ---------- */
.legal {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 var(--pad) 6rem;
  color: var(--bone-soft);
  line-height: 1.75;
  font-size: 1rem;
}

.legal__lead {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 1.35rem;
  line-height: 1.5;
  color: var(--bone);
  margin: 0 0 3.5rem;
  padding: 0 0 2.2rem;
  border-bottom: 1px solid var(--line);
  letter-spacing: -0.005em;
}
.legal__lead em { color: var(--gold); font-style: italic; }

.legal__toc {
  margin: 0 0 3.5rem;
  padding: 1.6rem 1.8rem;
  background: rgba(255, 255, 255, 0.025);
  border: 1px solid var(--line);
  border-radius: 12px;
}
.legal__toc-title {
  font-family: var(--font-display);
  font-style: italic;
  font-size: .8rem;
  color: var(--gold);
  letter-spacing: .18em;
  text-transform: uppercase;
  margin: 0 0 1rem;
}
.legal__toc-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: .35rem 1.5rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.legal__toc-list li::before { display: none; }
.legal__toc-list li { padding-left: 0; margin: 0; }
.legal__toc-list a {
  display: flex;
  align-items: baseline;
  gap: .65rem;
  padding: .35rem 0;
  font-size: .9rem;
  color: var(--bone-soft);
  text-decoration: none;
  transition: color .2s;
}
.legal__toc-list a:hover { color: var(--bone); }
.legal__toc-list a span:first-child {
  font-family: var(--font-display);
  font-style: italic;
  color: var(--gold);
  font-size: .82rem;
  flex-shrink: 0;
  min-width: 1.5em;
}
@media (max-width: 600px) {
  .legal__toc-list { grid-template-columns: 1fr; }
  .legal__toc { padding: 1.3rem 1.4rem; }
}

.legal__section {
  position: relative;
  padding: 3rem 0 0;
  margin: 3rem 0 0;
  border-top: 1px solid var(--line);
  scroll-margin-top: 6rem;
}
.legal__section:first-of-type {
  border-top: 0;
  padding-top: 0;
  margin-top: 0;
}
.legal__num {
  display: block;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 500;
  font-size: .82rem;
  letter-spacing: .25em;
  color: var(--gold);
  margin: 0 0 .6rem;
  text-transform: uppercase;
}
.legal__section h2 {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(1.5rem, 2.6vw, 1.9rem);
  line-height: 1.2;
  letter-spacing: -0.015em;
  color: var(--bone);
  margin: 0 0 1.2rem;
}
.legal__section h2 em { font-style: italic; font-weight: 500; color: var(--gold); }
.legal__section h3 {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.15rem;
  color: var(--bone);
  margin: 1.8rem 0 .6rem;
}

.legal p { margin: 0 0 1.1rem; }
.legal p:last-child { margin-bottom: 0; }

.legal ul {
  list-style: none;
  margin: 0 0 1.2rem;
  padding: 0;
}
.legal li {
  position: relative;
  padding-left: 1.4rem;
  margin: 0 0 .5rem;
}
.legal li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .75em;
  width: 8px;
  height: 1px;
  background: var(--gold);
}
.legal li strong { color: var(--bone); }

.legal a {
  color: var(--ember-hot);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition: color .2s;
}
.legal a:hover { color: var(--bone); }
.legal strong { color: var(--bone); font-weight: 600; }
.legal code {
  font-family: var(--font-mono);
  font-size: .88em;
  background: rgba(255, 255, 255, 0.04);
  padding: .15em .4em;
  border-radius: 4px;
  color: var(--bone);
}

.legal__contact-box {
  margin: 1.4rem 0;
  padding: 1.4rem 1.6rem;
  background: rgba(201, 163, 91, 0.04);
  border: 1px solid rgba(201, 163, 91, 0.18);
  border-radius: 10px;
  border-left: 3px solid var(--gold);
}
.legal__contact-box p { margin: 0; }
.legal__contact-box p + p { margin-top: .35rem; }

.legal__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  align-items: center;
  justify-content: space-between;
  margin-top: 4.5rem;
  padding: 1.6rem 1.8rem;
  background: var(--bg-card);
  border: 1px solid var(--line);
  border-radius: 12px;
  font-size: .88rem;
  color: var(--bone-mute);
}
.legal__meta strong { color: var(--bone); font-weight: 500; }
.legal__meta a { color: var(--ember-hot); }
