/* =================================================================
   By Schuetz — Fassung B „Die Titelei"  ·  Kohle & Messing
   Genau 2 Farben: #161614 (Kohle) + #D9C58F (Messing)
   Schriften: Marcellus (Display) · Jost (Fließtext) — self-hosted (DSGVO, keine CDN)
   ================================================================= */

/* ---- Schriften lokal (woff2 in fonts/) — keine Übertragung an Dritte ---- */
@font-face {
  font-family: 'Marcellus'; font-style: normal; font-weight: 400; font-display: swap;
  src: url(fonts/marcellus-400-latinext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Marcellus'; font-style: normal; font-weight: 400; font-display: swap;
  src: url(fonts/marcellus-400-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Jost'; font-style: normal; font-weight: 300 500; font-display: swap;
  src: url(fonts/jost-normal-latinext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Jost'; font-style: normal; font-weight: 300 500; font-display: swap;
  src: url(fonts/jost-normal-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Jost'; font-style: italic; font-weight: 400; font-display: swap;
  src: url(fonts/jost-400i-latinext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Jost'; font-style: italic; font-weight: 400; font-display: swap;
  src: url(fonts/jost-400i-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
  --kohle: #161614;
  --messing: #D9C58F;
  --messing-15: rgba(217, 197, 143, 0.15);
  --messing-35: rgba(217, 197, 143, 0.35);
  --messing-65: rgba(217, 197, 143, 0.65);
  --kopf-h: 68px;            /* Höhe der festen Kopfleiste — auch für Scroll-Offset */
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Jost', sans-serif;
  background: var(--kohle);
  color: var(--messing);
  font-size: 16.5px;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
body.menue-offen { overflow: hidden; }              /* Scroll-Sperre bei offenem Mobil-Menü */
::selection { background: var(--messing); color: var(--kohle); }
a { color: inherit; }
img, svg { display: block; }

:where(a, button, input, select, textarea, summary):focus-visible {
  outline: 2px solid var(--messing);
  outline-offset: 4px;
  border-radius: 1px;
}

.skip {
  position: absolute; left: 16px; top: -60px; z-index: 80;
  background: var(--messing); color: var(--kohle);
  padding: 12px 18px; font-size: 13px; letter-spacing: 0.18em; text-transform: uppercase;
  text-decoration: none; transition: top 0.2s ease;
}
.skip:focus { top: 12px; }

.wrap { max-width: 1080px; margin: 0 auto; padding: 0 28px; }
.marcellus { font-family: 'Marcellus', serif; }

/* ---- Zurechtfindbarkeit: Lesefortschritt ganz oben ---- */
.fortschritt {
  position: fixed; left: 0; top: 0; width: 100%; height: 2px; z-index: 60;
  background: var(--messing-15);
}
.fortschritt span {
  display: block; height: 100%; width: 0; background: var(--messing);
  transition: width 0.08s linear;
}

/* ============================ Kopfleiste ============================ */
.kopf {
  position: sticky; top: 0; z-index: 50;
  background: var(--kohle);
  border-bottom: 1px solid var(--messing-35);
  transition: box-shadow 0.25s ease, border-color 0.25s ease;
}
.kopf.gescrollt { box-shadow: 0 10px 30px -18px rgba(0,0,0,0.9); border-bottom-color: var(--messing-65); }
.kopf-innen {
  max-width: 1080px; margin: 0 auto; padding: 0 28px;
  height: var(--kopf-h);
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
}
.marke { text-decoration: none; display: inline-flex; flex: 0 0 auto; }
.marke .signet {
  font-family: 'Marcellus', serif; font-size: 19px; letter-spacing: 0.28em;
  border: 1px solid var(--messing); padding: 7px 11px 7px 17px;
}

nav.haupt { display: flex; align-items: center; gap: 30px; }
nav.haupt a {
  position: relative; text-decoration: none;
  font-size: 12.5px; letter-spacing: 0.26em; text-transform: uppercase;
  color: var(--messing-65); transition: color 0.2s ease;
}
nav.haupt a:not(.nav-cta)::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -7px; height: 1px;
  background: var(--messing); transform: scaleX(0); transform-origin: left; transition: transform 0.25s ease;
}
nav.haupt a:not(.nav-cta):hover { color: var(--messing); }
nav.haupt a:not(.nav-cta):hover::after,
nav.haupt a:not(.nav-cta).aktiv::after { transform: scaleX(1); }
nav.haupt a.aktiv { color: var(--messing); }       /* aktueller Abschnitt (Scroll-Spy) */

/* CTA in der Leiste */
.nav-cta {
  color: var(--kohle) !important; background: var(--messing);
  padding: 10px 20px; border: 1px solid var(--messing);
  letter-spacing: 0.2em; font-size: 11.5px;
}
.nav-cta:hover { background: transparent; color: var(--messing) !important; }

/* Hamburger */
.menue-schalter {
  display: none; flex-direction: column; justify-content: center; gap: 5px;
  width: 44px; height: 44px; padding: 11px; cursor: pointer;
  background: transparent; border: 1px solid var(--messing-35);
}
.menue-schalter span { display: block; height: 1.5px; width: 100%; background: var(--messing); transition: transform 0.25s ease, opacity 0.2s ease; }
body.menue-offen .menue-schalter span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
body.menue-offen .menue-schalter span:nth-child(2) { opacity: 0; }
body.menue-offen .menue-schalter span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.menue-backdrop {
  position: fixed; inset: 0; z-index: 40; background: rgba(11,11,10,0.6);
  backdrop-filter: blur(1px);
}

/* ---- Knopf (allgemein) ---- */
.knopf {
  display: inline-block; text-decoration: none; font-size: 13px; letter-spacing: 0.24em;
  text-transform: uppercase; background: var(--messing); color: var(--kohle);
  padding: 16px 34px; border: 1px solid var(--messing); transition: background 0.2s ease, color 0.2s ease;
}
.knopf:hover { background: transparent; color: var(--messing); }
.knopf.fein { background: transparent; color: var(--messing); }
.knopf.fein:hover { background: var(--messing); color: var(--kohle); }

/* ---- Scroll-Offset: Überschriften nicht unter der Leiste verstecken ---- */
section, .auftakt, #top { scroll-margin-top: calc(var(--kopf-h) + 22px); }

/* ============================ Auftakt / Titelei ============================ */
.auftakt { padding: 78px 0 84px; border-top: none; }
.auftakt-grid { display: grid; grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr); gap: 60px; align-items: center; }
.vorwort { font-size: 12px; letter-spacing: 0.4em; text-transform: uppercase; color: var(--messing-65); margin-bottom: 22px; }
.auftakt h1 {
  font-family: 'Marcellus', serif; font-weight: 400;
  font-size: clamp(28px, 3.4vw, 44px); line-height: 1.16; letter-spacing: 0.01em;
  max-width: 22ch;
}
.auftakt .geleit { max-width: 50ch; margin: 22px 0 0; font-size: 16.5px; color: var(--messing-65); }
.auftakt .geleit strong { color: var(--messing); font-weight: 500; }
.einladung { margin-top: 36px; display: flex; flex-wrap: wrap; gap: 18px; }

/* Maßblatt-Karte (Eckdaten auf einen Blick) */
.masstafel { border: 1px solid var(--messing); padding: 30px 32px 24px; position: relative; }
.masstafel::before { content: ""; position: absolute; inset: 7px; border: 1px solid var(--messing-35); pointer-events: none; }
.tafelkopf {
  font-family: 'Marcellus', serif; font-size: 19px; letter-spacing: 0.06em;
  display: flex; align-items: center; justify-content: center; gap: 16px; margin: 4px 0 18px;
}
.tafelkopf::before, .tafelkopf::after { content: ""; flex: 0 0 auto; width: 6px; height: 6px; background: var(--messing); transform: rotate(45deg); }
.masstafel ul { list-style: none; }
.masstafel li {
  display: flex; align-items: baseline; justify-content: space-between; gap: 18px;
  padding: 12px 2px; border-bottom: 1px dotted var(--messing-35); font-size: 14px;
}
.masstafel li:last-of-type { border-bottom: 0; }
.masstafel li b { font-family: 'Marcellus', serif; font-weight: 400; font-size: 15px; white-space: nowrap; }
.masstafel li span:last-child { color: var(--messing-65); text-align: right; }
.tafelmehr {
  display: block; text-align: center; margin-top: 18px; padding-top: 16px;
  border-top: 1px solid var(--messing-35);
  font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; text-decoration: none; color: var(--messing-65);
  transition: color 0.2s ease;
}
.tafelmehr:hover { color: var(--messing); }

/* ============================ Abschnitte ============================ */
section { padding: 88px 0; border-top: 1px solid var(--messing-35); }
.kapitel { text-align: center; margin-bottom: 54px; }
.kapitel .ziffer { font-family: 'Marcellus', serif; font-size: 15px; letter-spacing: 0.4em; color: var(--messing-65); display: block; margin-bottom: 14px; }
h2 { font-family: 'Marcellus', serif; font-weight: 400; font-size: clamp(27px, 3.6vw, 42px); line-height: 1.16; }
h3 { font-weight: 400; }

/* Schnitte / Preisverzeichnis mit Punktlinien (kurze Werte → Leader OK) */
.menue { display: grid; gap: 42px; max-width: 820px; margin: 0 auto; }
.gang .gangtitel { display: flex; align-items: baseline; gap: 14px; }
.gang .gangtitel h3 { font-family: 'Marcellus', serif; font-size: 25px; white-space: nowrap; }
.gang .gangtitel .punkte { flex: 1; border-bottom: 1px dotted var(--messing-35); transform: translateY(-6px); }
.gang .gangtitel .preis { font-family: 'Marcellus', serif; font-size: 25px; white-space: nowrap; }
.gang .widmung { font-style: italic; font-size: 14.5px; color: var(--messing-65); margin: 5px 0 12px; }
.gang .zutaten { font-size: 15px; color: var(--messing-65); }
.gang .zutaten b { color: var(--messing); font-weight: 500; }
.gang .konditionen { font-size: 13px; letter-spacing: 0.04em; color: var(--messing-65); margin-top: 10px; }
.menue-fuss { text-align: center; font-size: 13px; color: var(--messing-65); margin-top: 42px; font-style: italic; }
.menue-fuss a { color: var(--messing); text-decoration: none; font-style: normal; letter-spacing: 0.04em; white-space: nowrap; }
.menue-fuss a:hover { text-decoration: underline; }

/* Ablauf — römische Ziffern */
.gaenge { max-width: 660px; margin: 0 auto; }
.akt { display: grid; grid-template-columns: 80px 1fr; gap: 26px; padding: 30px 0; border-bottom: 1px dotted var(--messing-35); }
.akt:last-child { border-bottom: none; }
.akt .roem { font-family: 'Marcellus', serif; font-size: 30px; text-align: right; line-height: 1.1; }
.akt h3 { font-family: 'Marcellus', serif; font-size: 22px; margin-bottom: 4px; }
.akt .takt { font-size: 11.5px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--messing-65); display: block; margin-bottom: 10px; }
.akt p { font-size: 15px; color: var(--messing-65); }
.akt p b { color: var(--messing); font-weight: 500; }

/* Rundum-Paket — 4 Säulen + Stichpunkte */
.rundum-sub { text-align: center; max-width: 720px; margin: -34px auto 46px; font-size: 17px; color: var(--messing-65); line-height: 1.6; }
.saeulen { display: grid; grid-template-columns: repeat(4, 1fr); max-width: 980px; margin: 0 auto; }
.saeule { padding: 0 28px; text-align: center; border-left: 1px solid var(--messing-35); }
.saeule:first-child { border-left: none; }
.saeule h3 { font-family: 'Marcellus', serif; font-size: 22px; color: var(--messing); margin-bottom: 12px; }
.saeule p { font-size: 14.5px; color: var(--messing-65); line-height: 1.6; }
.stichpunkte { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px 34px; max-width: 900px; margin: 52px auto 0; padding-top: 34px; border-top: 1px solid var(--messing-35); }
.stichpunkte span { font-size: 12.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--messing); }

/* Referenz — Gravur-Tafel */
.gravur { border: 1px solid var(--messing); padding: 50px 48px; position: relative; max-width: 780px; margin: 0 auto; }
.gravur::before { content: ""; position: absolute; inset: 8px; border: 1px solid var(--messing-35); pointer-events: none; }
.gravur h3 { font-family: 'Marcellus', serif; font-size: 26px; text-align: center; margin-bottom: 24px; }
.gravur p { font-size: 15.5px; color: var(--messing-65); margin-bottom: 16px; }
.gravur p strong { color: var(--messing); font-weight: 500; }
.gravur .fakten { display: flex; justify-content: center; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.gravur .fakten span { font-size: 11.5px; letter-spacing: 0.18em; text-transform: uppercase; border: 1px solid var(--messing-35); padding: 7px 14px; }
.gravur .fakten .akzent { border-color: var(--messing); }

/* Kontakt */
.empfang { max-width: 660px; margin: 0 auto; }
.empfang > p { text-align: center; font-size: 16.5px; color: var(--messing-65); margin-bottom: 40px; }
.empfang > p strong { color: var(--messing); font-weight: 500; }
.kontaktdaten { display: flex; justify-content: center; flex-wrap: wrap; gap: 14px 40px; margin-bottom: 46px; font-size: 14.5px; }
.kontaktdaten span b { font-weight: 500; letter-spacing: 0.04em; }
form { display: grid; gap: 22px; }
label { font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--messing-65); display: block; margin-bottom: 8px; }
input, select, textarea {
  width: 100%; font: inherit; font-size: 15.5px; color: var(--messing);
  background: transparent; border: 1px solid var(--messing-35); padding: 13px 15px; border-radius: 0;
  transition: border-color 0.2s ease;
}
input:hover, select:hover, textarea:hover { border-color: var(--messing-65); }
input::placeholder, textarea::placeholder { color: var(--messing-35); }
select option { background: var(--kohle); color: var(--messing); }
.zwei { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
form button {
  font: inherit; font-size: 13px; letter-spacing: 0.24em; text-transform: uppercase; cursor: pointer;
  background: var(--messing); color: var(--kohle); border: 1px solid var(--messing); padding: 17px;
  transition: background 0.2s ease, color 0.2s ease;
}
form button:hover { background: transparent; color: var(--messing); }
.ds { font-size: 12.5px; color: var(--messing-65); text-align: center; }

/* ============================ Fuß ============================ */
footer { border-top: 1px solid var(--messing-35); padding: 44px 0 56px; }
.fuss { display: flex; flex-direction: column; align-items: center; gap: 20px; text-align: center; }
.fuss-nav { display: flex; flex-wrap: wrap; justify-content: center; gap: 14px 28px; }
.fuss-nav a { text-decoration: none; font-size: 11.5px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--messing-65); }
.fuss-nav a:hover { color: var(--messing); }
.fuss-zeile { font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--messing-65); }
.fuss-recht { font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--messing-65); }
.fuss-recht a { margin: 0 6px; }

/* ============================ Schweber: nach oben + WhatsApp ============================ */
.schweber { position: fixed; right: 24px; bottom: 24px; z-index: 30; display: flex; flex-direction: column; align-items: flex-end; gap: 14px; }
.hoch {
  width: 48px; height: 48px; cursor: pointer;
  background: var(--kohle); color: var(--messing); border: 1px solid var(--messing);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transform: translateY(8px);
  transition: opacity 0.25s ease, transform 0.25s ease, background 0.2s ease, color 0.2s ease;
}
.hoch[hidden] { display: none; }
.hoch.sichtbar { opacity: 1; pointer-events: auto; transform: none; }
.hoch:hover { background: var(--messing); color: var(--kohle); }
.hoch svg { width: 20px; height: 20px; }
.wa {
  position: relative; display: flex; align-items: center; gap: 10px;
  background: var(--kohle); color: var(--messing); border: 1px solid var(--messing);
  padding: 13px 20px; text-decoration: none;
  font-size: 11.5px; letter-spacing: 0.24em; text-transform: uppercase;
  transition: background 0.2s ease, color 0.2s ease;
}
.wa::after { content: ""; position: absolute; inset: 4px; border: 1px solid var(--messing-35); pointer-events: none; }
.wa:hover { background: var(--messing); color: var(--kohle); }
.wa svg { width: 20px; height: 20px; fill: currentColor; }

/* =================================================================
   Unterseite „Das Maßblatt" (konditionen.html)
   ================================================================= */
.seitenkopf { text-align: center; padding: 36px 0 0; }
/* Sichtbarer Zurück-Knopf (links ausgerichtet trotz zentriertem Kopf) */
.zurueck-knopf {
  display: flex; align-items: center; gap: 10px; width: fit-content; margin: 0 auto 40px 0;
  padding: 11px 20px 11px 16px; border: 1px solid var(--messing-35);
  font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--messing); text-decoration: none;
  transition: border-color 0.2s ease, background 0.2s ease;
}
.zurueck-knopf:hover { border-color: var(--messing); background: var(--messing-15); }
.zurueck-knopf .pfeil { font-size: 16px; line-height: 1; transition: transform 0.2s ease; }
.zurueck-knopf:hover .pfeil { transform: translateX(-3px); }
.seitenkopf .vorwort { margin-bottom: 16px; }
.seitenkopf .titel { font-family: 'Marcellus', serif; font-weight: 400; font-size: clamp(30px, 4.2vw, 50px); line-height: 1.15; }
.seitenkopf .geleit { max-width: 52ch; margin: 20px auto 0; font-size: 16px; color: var(--messing-65); }

/* Maßblatt als Formblatt */
.blatt { max-width: 720px; margin: 0 auto; border: 1px solid var(--messing); }
.blatt-kopf {
  display: flex; align-items: baseline; justify-content: space-between; gap: 16px;
  padding: 20px 32px; border-bottom: 1px solid var(--messing);
}
.blatt-kopf .bk-titel { font-family: 'Marcellus', serif; font-size: 19px; letter-spacing: 0.04em; }
.blatt-kopf .bk-no { font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--messing-65); }
.posten {
  display: grid; grid-template-columns: 190px 1fr; gap: 6px 28px;
  padding: 17px 32px; border-bottom: 1px dotted var(--messing-35);
}
.posten:last-child { border-bottom: 0; }
.posten dt { font-family: 'Marcellus', serif; font-size: 17px; }
.posten dd { font-size: 15px; color: var(--messing-65); }
.posten dd b { color: var(--messing); font-weight: 500; }

/* FAQ — Accordions */
.fragen { max-width: 720px; margin: 0 auto; }
.fragen details { border-bottom: 1px dotted var(--messing-35); }
.fragen summary {
  font-family: 'Marcellus', serif; font-size: 19px; padding: 22px 38px 22px 0;
  cursor: pointer; list-style: none; position: relative; transition: color 0.2s ease;
}
.fragen summary::-webkit-details-marker { display: none; }
.fragen summary::after {
  content: ""; position: absolute; right: 6px; top: 50%;
  width: 8px; height: 8px; border-right: 1px solid var(--messing); border-bottom: 1px solid var(--messing);
  transform: translateY(-70%) rotate(45deg); transition: transform 0.2s ease;
}
.fragen details[open] summary::after { transform: translateY(-30%) rotate(225deg); }
.fragen summary:hover { color: var(--messing); }
.fragen .antwort { padding: 0 0 24px; font-size: 15px; color: var(--messing-65); max-width: 62ch; }
.fragen .antwort b { color: var(--messing); font-weight: 500; }
.seitenschluss { text-align: center; padding: 70px 0 90px; border-top: 1px solid var(--messing-35); }
.seitenschluss p { font-family: 'Marcellus', serif; font-size: 22px; margin-bottom: 28px; }

/* Rechtstext (Impressum / Datenschutz / AGB) */
.rechtstext { max-width: 760px; margin: 0 auto; }
.rechtstext > h2 { font-family: 'Marcellus', serif; font-weight: 400; font-size: clamp(21px, 2.6vw, 28px); text-align: left; line-height: 1.25; margin: 44px 0 14px; }
.rechtstext > h2:first-child { margin-top: 0; }
.rechtstext h3 { font-family: 'Marcellus', serif; font-weight: 400; font-size: 18px; margin: 26px 0 8px; }
.rechtstext p { font-size: 15.5px; color: var(--messing-65); margin-bottom: 14px; }
.rechtstext ul { list-style: none; margin: 0 0 16px; }
.rechtstext li { position: relative; padding-left: 22px; margin-bottom: 8px; font-size: 15.5px; color: var(--messing-65); }
.rechtstext li::before { content: ""; position: absolute; left: 2px; top: 11px; width: 5px; height: 5px; background: var(--messing-65); transform: rotate(45deg); }
.rechtstext a { color: var(--messing); }
.rechtstext strong, .rechtstext b { color: var(--messing); font-weight: 500; }
.rechtstext .adresse { color: var(--messing); font-style: normal; line-height: 1.9; margin-bottom: 16px; }
.rechtstext .stand { font-size: 13px; color: var(--messing-65); font-style: italic; margin-top: 40px; padding-top: 18px; border-top: 1px dotted var(--messing-35); }

/* =================================================================
   Bewegungs-Reduktion respektieren
   ================================================================= */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; }
}

/* =================================================================
   Mobil / Tablet
   ================================================================= */
@media (max-width: 860px) {
  .menue-schalter { display: flex; }
  nav.haupt {
    position: fixed; left: 0; right: 0; top: var(--kopf-h); z-index: 45;
    flex-direction: column; align-items: stretch; gap: 0;
    background: var(--kohle); border-bottom: 1px solid var(--messing-35);
    padding: 8px 24px 26px; max-height: calc(100dvh - var(--kopf-h)); overflow-y: auto;
    transform: translateY(-14px); opacity: 0; visibility: hidden; pointer-events: none;
    transition: opacity 0.25s ease, transform 0.25s ease, visibility 0.25s;
  }
  body.menue-offen nav.haupt { transform: none; opacity: 1; visibility: visible; pointer-events: auto; }
  nav.haupt a:not(.nav-cta) {
    padding: 17px 2px; border-bottom: 1px dotted var(--messing-35);
    font-size: 14px; letter-spacing: 0.18em;
  }
  nav.haupt a:not(.nav-cta)::after { display: none; }
  nav.haupt a:not(.nav-cta).aktiv { padding-left: 14px; border-left: 2px solid var(--messing); }
  .nav-cta { margin-top: 20px; text-align: center; padding: 15px 20px; }
}

@media (max-width: 760px) {
  .auftakt-grid { grid-template-columns: 1fr; gap: 40px; }
  .auftakt { padding: 52px 0 64px; }
  section { padding: 64px 0; }
  .akt { grid-template-columns: 50px 1fr; gap: 18px; }
  .akt .roem { font-size: 22px; }
  .saeulen { grid-template-columns: 1fr 1fr; gap: 34px 0; }
  .saeule { border-left: none; padding: 0 10px; }
  .gravur { padding: 36px 24px; }
  .zwei { grid-template-columns: 1fr; }
  .gang .gangtitel { flex-wrap: wrap; }
  .gang .gangtitel .punkte { display: none; }
  .gang .gangtitel .preis { margin-left: auto; }
  .posten { grid-template-columns: 1fr; gap: 3px; padding: 16px 22px; }
  .blatt-kopf { padding: 18px 22px; }
  .wa span { display: none; }
  .wa { padding: 13px; }
  .schweber { right: 16px; bottom: 16px; }
}
