/* fewo-pirna.com — „Sandstein"
   Pixelreferenz: design/Fewo Pirna Layout.dc.html, Optionen 1b / 2a–2d.
   Trennung ausschließlich über 1px-Linien, keine Schatten. Breakpoint ≤768px. */

/* ---------- Fonts (self-hosted, DSGVO) ---------- */
@font-face {
  font-family: 'Source Serif 4'; font-style: normal; font-weight: 400; font-display: swap;
  src: url('/assets/fonts/source-serif-4-v14-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Source Serif 4'; font-style: italic; font-weight: 400; font-display: swap;
  src: url('/assets/fonts/source-serif-4-v14-latin-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Source Serif 4'; font-style: normal; font-weight: 600; font-display: swap;
  src: url('/assets/fonts/source-serif-4-v14-latin-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Source Serif 4'; font-style: normal; font-weight: 700; font-display: swap;
  src: url('/assets/fonts/source-serif-4-v14-latin-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Public Sans'; font-style: normal; font-weight: 400; font-display: swap;
  src: url('/assets/fonts/public-sans-v21-latin-regular.woff2') format('woff2');
}
@font-face {
  font-family: 'Public Sans'; font-style: normal; font-weight: 600; font-display: swap;
  src: url('/assets/fonts/public-sans-v21-latin-600.woff2') format('woff2');
}
@font-face {
  font-family: 'Public Sans'; font-style: normal; font-weight: 700; font-display: swap;
  src: url('/assets/fonts/public-sans-v21-latin-700.woff2') format('woff2');
}

/* ---------- Basis ---------- */
*, *::before, *::after { box-sizing: border-box; }
img { max-width: 100%; height: auto; display: block; }
picture { display: contents; }
source { display: none; } /* sonst belegen <source> als display:contents-Kinder Grid-Zellen */
h1, h2, h3, p { margin: 0; }
a { color: inherit; }
button { font: inherit; color: inherit; background: none; border: none; padding: 0; cursor: pointer; }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 100;
  background: var(--green); color: var(--bg); padding: 10px 16px; font: 600 14px var(--font-sans);
}
.skip-link:focus { left: 0; }

a.btn-primary, a.btn-outline { text-decoration: none; text-align: center; }

/* ---------- Navigation ---------- */
.nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px var(--page-pad); background: var(--bg); gap: 20px;
}
.nav__wordmark {
  font: 700 21px var(--font-serif); text-decoration: none; color: var(--ink); flex-shrink: 0;
}
.nav__claim { font-weight: 400; font-style: italic; color: var(--ink-mute); }
.nav__links { display: flex; align-items: center; gap: 26px; font-size: var(--text-ui); }
.nav__links a { text-decoration: none; }
.nav__links a:hover:not(.nav__cta) { color: var(--green); }
.nav__links a.is-active {
  font-weight: 700; border-bottom: 2px solid var(--ochre); padding-bottom: 2px;
}
.nav__cta { padding: 9px 18px; font-size: 13px; }
.nav__burger { display: none; flex-direction: column; gap: 4px; padding: 6px; }
.nav__burger span { width: 20px; height: 2px; background: var(--ink); display: block; transition: transform var(--transition), opacity var(--transition); }
.nav__burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav__burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.mobilmenu {
  display: none; flex-direction: column; gap: 0;
  padding: 8px var(--page-pad-mobile) 24px; background: var(--bg);
  border-bottom: 1px solid var(--line-strong);
}
.mobilmenu a:not(.btn-primary) {
  text-decoration: none; font: 600 17px var(--font-sans); padding: 14px 0;
  border-bottom: 1px solid var(--line);
}
.mobilmenu .btn-primary { margin-top: 18px; }
.mobilmenu.is-open { display: flex; }

/* ---------- Hero (1b) ---------- */
.hero {
  display: grid; grid-template-columns: 1fr 1.15fr;
  border-top: 1px solid var(--line-strong); border-bottom: 1px solid var(--line-strong);
}
.hero__text {
  padding: 64px var(--page-pad); display: flex; flex-direction: column;
  justify-content: space-between; gap: 40px; border-right: 1px solid var(--line-strong);
}
.hero__eyebrow { margin-bottom: 18px; }
.hero h1 { font: 600 var(--text-hero)/1.05 var(--font-serif); text-wrap: pretty; }
.hero__unten { display: flex; flex-direction: column; gap: 16px; }
.hero__unten p { font-size: var(--text-lead); line-height: 1.65; color: var(--ink-soft); max-width: 48ch; }
.hero__buttons { display: flex; gap: 12px; }
.hero__bild { position: relative; min-height: 480px; }
.hero__bild img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero__badge {
  position: absolute; left: 20px; bottom: 20px; background: var(--bg);
  padding: 10px 16px; font: 600 12.5px var(--font-sans); border: 1px solid var(--line-strong);
}

/* ---------- Wohnungszeilen (1b) ---------- */
.sektionskopf { padding: 56px var(--page-pad) 8px; }
.sektionskopf h2 { font: 600 var(--text-h2) var(--font-serif); margin-bottom: 8px; }
.sektionskopf p { font-size: 14px; color: var(--ink-mute); margin-bottom: 28px; }

.zeilen { display: flex; flex-direction: column; }
.zeile {
  display: grid; grid-template-columns: 90px 300px 1fr 170px 130px; gap: var(--gap);
  align-items: center; padding: 22px var(--page-pad);
  border-top: 1px solid var(--line); text-decoration: none;
  transition: background var(--transition);
}
.zeile:last-child { border-bottom: 1px solid var(--line); }
.zeile:hover { background: var(--paper); }
.zeile__num { font: 600 var(--num-row) var(--font-serif); color: var(--ochre); }
.zeile__num--light { color: var(--ochre-light); }
.zeile__img, .zeile__foto img { width: 100%; height: 120px; object-fit: cover; border-radius: var(--radius-img); }
.zeile__foto--platzhalter {
  height: 120px; border-radius: var(--radius-img);
  background: repeating-linear-gradient(45deg, var(--sand), var(--sand) 8px, #e7e0cf 8px, #e7e0cf 16px);
  display: flex; align-items: center; justify-content: center;
}
.zeile__foto--platzhalter span { font: 11px ui-monospace, monospace; color: var(--ink-faint); }
.zeile__titel { display: block; font-weight: 700; font-size: 17px; margin-bottom: 4px; }
.zeile__desc { display: block; font-size: 14px; line-height: 1.55; color: var(--ink-soft); }
.zeile__meta-mobil { display: none; }
.zeile__preis { font-size: 15px; }
.zeile__preis span { font-size: 12.5px; color: var(--ink-mute); }
.zeile__btn { padding: 9px 0; text-align: center; font-size: 13px; }
.zeile__vormerken { font: 600 13px var(--font-sans); color: var(--ochre); }
.zeile__btn--bald {
  border: 1.5px dashed var(--ink-faint); color: var(--ink-mute); border-radius: var(--radius-btn);
  font-weight: 600;
}

/* ---------- Widget-Band ---------- */
.band { background: var(--green); color: var(--bg); padding: 52px var(--page-pad); }
.band__head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 18px; gap: 16px; }
.band__head h2 { font: 600 var(--text-h3) var(--font-serif); }
.band__note { font-size: 13px; opacity: .75; }
.band__fallback { border-top: 1px solid rgba(246, 242, 234, .3); padding-top: 22px; }
.band__fallback p { font-size: 15px; line-height: 1.6; opacity: .9; max-width: 60ch; margin-bottom: 18px; }
.band__fallback-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; font-size: 16px; }
.band__fallback-row a { color: var(--bg); font-weight: 600; }
.band__cta {
  display: inline-block; border: 1.5px solid var(--bg); border-radius: var(--radius-btn);
  padding: 12px 22px; font: 600 14px var(--font-sans); text-decoration: none; color: var(--bg);
  transition: background var(--transition), color var(--transition); margin-left: 10px;
}
.band__cta:hover { background: var(--bg); color: var(--green); }
/* Feratel-Widget: helle Fläche auf dem grünen Band, damit die Buchungssuche
   lesbar ist; das Widget selbst bringt via Shadow DOM eigene Styles mit.
   min-height reserviert Platz gegen Layout-Shift, bis das Skript geladen hat. */
.band__widget {
  background: var(--bg); border-radius: 6px; padding: 20px;
  min-height: 132px; color: var(--ink);
}
.band__widget dwapp-accommodation { display: block; }
.band__widget-nojs { font-size: 15px; color: var(--ink-soft); margin: 0; }
.band__widget-nojs a { color: var(--green); font-weight: 600; }

/* ---------- Garten + Zitat (1b) ---------- */
.garten {
  display: grid; grid-template-columns: 1.2fr 1fr;
  border-bottom: 1px solid var(--line);
}
.garten__text { padding: var(--page-pad); border-right: 1px solid var(--line); }
.garten__text .eyebrow { margin-bottom: 14px; }
.garten__text h2 { font: 600 30px var(--font-serif); margin-bottom: 14px; }
.garten__text p { font-size: 15px; line-height: 1.65; color: var(--ink-soft); margin-bottom: 24px; }
.garten__bilder { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--gap-tight); }
.garten__img { width: 100%; height: 130px; object-fit: cover; border-radius: var(--radius-img); }
.zitat {
  padding: var(--page-pad); display: flex; flex-direction: column;
  justify-content: center; gap: 26px; background: var(--sand);
}
.zitat__zeichen { font: 400 64px/0 var(--font-serif); color: var(--ochre); margin-top: 20px; }
.zitat p { font: italic 400 var(--text-quote)/1.5 var(--font-serif); }
.zitat__attribution { font-size: 13px; color: var(--ink-mute); }

/* ---------- Umgebung + Karte (1b) ---------- */
.umgebung { display: grid; grid-template-columns: 1fr 1fr 1fr; }
.umgebung__karte { padding: 40px 32px; border-right: 1px solid var(--line); }
.umgebung__karte:first-child { padding-left: var(--page-pad); }
.umgebung__karte .eyebrow { margin-bottom: 10px; }
.umgebung__titel { font-weight: 700; font-size: 17px; margin-bottom: 6px; }
.umgebung__karte p { font-size: 14px; line-height: 1.55; color: var(--ink-soft); }

/* ---------- Karten-Consent ---------- */
.karte {
  position: relative; min-height: 170px;
  background: repeating-linear-gradient(45deg, var(--sand), var(--sand) 10px, #e7e0cf 10px, #e7e0cf 20px);
}
.karte__consent {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 8px; text-align: center; padding: 16px;
}
.karte__pin { width: 12px; height: 12px; border-radius: 50%; background: var(--green); display: block; }
.karte__label { font: 11px ui-monospace, monospace; color: var(--ink-mute); }
.karte__hinweis { font-size: 12.5px; color: var(--ink-soft); max-width: 36ch; }
.karte iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.karte__osmlink {
  position: absolute; right: 8px; bottom: 8px; background: var(--bg);
  font-size: 11.5px; padding: 5px 9px; border: 1px solid var(--line-strong); text-decoration: none;
}

/* ---------- Detailseite (2a) ---------- */
.detail__kopf { padding: 20px var(--page-pad) 28px; border-top: 1px solid var(--line-strong); }
.breadcrumb { font-size: 13px; color: var(--ink-mute); margin-bottom: 14px; }
.breadcrumb a { text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb [aria-current] { color: var(--ink); font-weight: 600; }
.detail__titelzeile { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; }
.detail__titelgruppe { display: flex; align-items: baseline; gap: 18px; }
.detail__num { font: 600 var(--num-detail)/1 var(--font-serif); color: var(--ochre); }
.detail__num--light { color: var(--ochre-light); }
.detail__titelgruppe h1 { font: 600 var(--text-h1)/1.05 var(--font-serif); }
.detail__meta { display: flex; gap: 20px; margin-top: 14px; font-size: 14.5px; color: var(--ink-soft); flex-wrap: wrap; }
.detail__buchung { display: flex; flex-direction: column; align-items: flex-end; gap: 10px; flex-shrink: 0; }
.detail__preis { font-size: 22px; }
.detail__preis span { font-size: 14px; color: var(--ink-mute); }
.detail__preis--folgt { font-size: 15px; font-style: italic; color: var(--ink-mute); }
.detail__buchung .btn-primary { padding: 13px 28px; }

/* Galerie */
.galerie {
  display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 230px 230px;
  gap: var(--gap-tight); padding: 0 var(--page-pad) 40px;
}
.galerie__gross { grid-row: span 2; position: relative; }
.galerie__gross img, .galerie__kachel img, .galerie__mehr img {
  width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius-img);
}
.galerie__gross, .galerie__kachel, .galerie__mehr { overflow: hidden; border-radius: var(--radius-img); position: relative; display: block; }
.galerie__overlay {
  position: absolute; inset: 0; background: rgba(38, 48, 42, .55);
  display: flex; align-items: center; justify-content: center;
  color: var(--bg); font: 600 14px var(--font-sans);
}

/* Lightbox */
.lightbox { border: none; padding: 0; background: transparent; width: 100vw; max-width: 100vw; height: 100vh; max-height: 100vh; }
.lightbox::backdrop { background: rgba(38, 48, 42, .92); }
.lightbox[open] { display: flex; align-items: center; justify-content: center; }
.lightbox__buehne { max-width: min(1200px, 88vw); max-height: 86vh; }
.lightbox__bild { margin: 0; }
.lightbox__bild img { width: auto; height: auto; max-width: min(1200px, 88vw); max-height: 80vh; object-fit: contain; }
.lightbox__bild figcaption { color: var(--bg); font-size: 13px; text-align: center; padding-top: 10px; }
.lightbox__schliessen {
  position: fixed; top: 18px; right: 24px; color: var(--bg); font-size: 34px; line-height: 1; z-index: 2;
}
.lightbox__pfeil { position: fixed; top: 50%; transform: translateY(-50%); color: var(--bg); font-size: 44px; padding: 12px 18px; z-index: 2; }
.lightbox__pfeil--zurueck { left: 12px; }
.lightbox__pfeil--vor { right: 12px; }
.lightbox__zaehler { position: fixed; bottom: 18px; left: 50%; transform: translateX(-50%); color: var(--bg); font-size: 13px; }

/* Beschreibung + Sidebar */
.detail__inhalt {
  display: grid; grid-template-columns: 1.5fr 1fr;
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.detail__beschreibung { padding: var(--section-pad) var(--page-pad); border-right: 1px solid var(--line); }
.detail__beschreibung .eyebrow { margin-bottom: 14px; }
.detail__beschreibung h2 { font: 600 var(--text-h3) var(--font-serif); margin-bottom: 16px; }
.detail__beschreibung p { font-size: var(--text-body); line-height: 1.7; color: var(--ink-soft); margin-bottom: 16px; }
.detail__ausstattung-titel { margin-top: 12px; }
.ausstattung {
  list-style: none; padding: 0; margin: 0;
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px 24px;
  font-size: 14.5px; color: var(--ink-soft);
}
.ausstattung li::before { content: "✓ "; }
.detail__sidebar {
  padding: var(--section-pad) var(--page-pad); background: var(--sand);
  display: flex; flex-direction: column; gap: 22px;
}
.detail__sidebar .eyebrow { margin-bottom: 12px; }
.preisliste { display: flex; flex-direction: column; font-size: 14.5px; }
.preisliste__zeile { display: flex; justify-content: space-between; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--line); }
.preisliste__zeile:last-child { border-bottom: none; }
.kontaktkasten {
  background: var(--bg); border: 1px solid var(--line); padding: 20px;
  display: flex; flex-direction: column; gap: 8px;
}
.kontaktkasten__titel { font-weight: 700; font-size: 14.5px; }
.kontaktkasten__text { font-size: 14px; color: var(--ink-soft); line-height: 1.6; }
.kontaktkasten__text a { text-decoration: none; }
.querlinks { display: flex; flex-direction: column; gap: 8px; }
.querlinks__titel { font: 600 13px var(--font-sans); color: var(--ink-mute); }
.querlinks__chips { display: flex; gap: 10px; flex-wrap: wrap; }
.chip {
  border: 1.5px solid var(--green); color: var(--green); padding: 8px 14px;
  font: 600 13px var(--font-sans); border-radius: var(--radius-btn); text-decoration: none;
  transition: background var(--transition), color var(--transition);
}
.chip:hover { background: var(--green); color: var(--bg); }
.chip--geplant { border-style: dashed; border-color: var(--ink-faint); color: var(--ink-mute); }
.chip--geplant:hover { background: transparent; color: var(--ink-mute); }

/* ---------- Preise (2b) ---------- */
.seitenkopf { padding: var(--section-pad) var(--page-pad) 36px; border-top: 1px solid var(--line-strong); }
.seitenkopf h1 { font: 600 var(--text-h1)/1.05 var(--font-serif); margin-bottom: 10px; }
.seitenkopf p { font-size: var(--text-body); color: var(--ink-soft); max-width: 64ch; line-height: 1.65; }

.preistabelle-wrap { padding: 0 var(--page-pad) 40px; overflow-x: auto; }
.preistabelle { min-width: 720px; }
.preistabelle__kopf {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
  background: var(--green); color: var(--bg);
  font-size: 13px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase;
}
.preistabelle__kopf span { padding: 14px 20px; }
.preistabelle__zeile {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; align-items: center;
  font-size: 15px; border: 1px solid var(--line); border-top: none;
}
.preistabelle__zeile:nth-child(even) { background: var(--paper); }
.preistabelle__zeile span { padding: 16px 20px; }
.preistabelle__zeile a { text-decoration: none; }
.preistabelle__zeile a:hover { text-decoration: underline; }
.preistabelle__num { font: 600 18px var(--font-serif); color: var(--ochre); margin-right: 10px; }
.preistabelle__num--light { color: var(--ochre-light); }
.preistabelle__preis { font-weight: 700; }
.preistabelle__zeile--geplant { color: var(--ink-mute); }
.preistabelle__folgt { font-style: italic; }

.hinweistrio {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.hinweistrio > div { padding: 36px 32px; border-right: 1px solid var(--line); }
.hinweistrio > div:first-child { padding-left: var(--page-pad); }
.hinweistrio > div:last-child { border-right: none; padding-right: var(--page-pad); }
.hinweistrio .eyebrow { margin-bottom: 10px; }
.hinweistrio p { font-size: 14.5px; line-height: 1.6; color: var(--ink-soft); }

/* ---------- Kontakt & Anreise (2c) ---------- */
.kontakt { display: grid; grid-template-columns: 1fr 1.2fr; border-top: 1px solid var(--line-strong); }
.kontakt__links { padding: var(--section-pad) var(--page-pad); border-right: 1px solid var(--line); }
.kontakt__links h1 { font: 600 var(--text-h1)/1.05 var(--font-serif); margin-bottom: 24px; }
.kontakt__daten { display: flex; flex-direction: column; font-size: 15px; }
.kontakt__zeile { display: flex; justify-content: space-between; gap: 16px; padding: 14px 0; border-top: 1px solid var(--line); }
.kontakt__zeile:last-child { border-bottom: 1px solid var(--line); }
.kontakt__zeile > span:first-child { color: var(--ink-mute); }
.kontakt__wert { text-align: right; line-height: 1.5; }
.kontakt__zeile a { text-decoration: none; }
.kontakt__rechts { display: flex; flex-direction: column; }
.kontakt__rechts .karte { flex: 1; min-height: 340px; }
.anreise { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--line); }
.anreise__spalte { padding: 30px 32px; }
.anreise__spalte:first-child { border-right: 1px solid var(--line); }
.anreise .eyebrow { margin-bottom: 10px; }
.anreise p { font-size: 14.5px; line-height: 1.6; color: var(--ink-soft); }

/* Formular */
.formular { margin-top: 28px; }
.formular__eyebrow { margin-bottom: 14px; }
.formular form { display: flex; flex-direction: column; gap: 12px; }
.formular__row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 10px; }
.formular__feld { display: flex; flex-direction: column; gap: 5px; }
.formular__feld label { font: 600 12.5px var(--font-sans); color: var(--ink-soft); }
.formular input, .formular select, .formular textarea {
  border: 1px solid var(--field-border); background: var(--paper);
  padding: 13px 14px; font: 400 14px var(--font-sans); color: var(--ink);
  border-radius: 0; width: 100%; appearance: none;
}
.formular textarea { min-height: 70px; resize: vertical; }
.formular ::placeholder { color: var(--ink-faint); opacity: 1; }
/* Placeholder-Farbe fürs Select, solange nichts gewählt ist (:has — ältere
   Browser zeigen harmlos die Volltonfarbe) */
.formular select:has(option[value=""]:checked) { color: var(--ink-faint); }
.formular input:focus, .formular select:focus, .formular textarea:focus {
  outline: 2px solid var(--green); outline-offset: -1px;
}
.formular__submit { padding: 14px 0; width: 100%; }
/* Fehlerbox: ohne JS via :target sichtbar (anfrage.php leitet auf ?fehler=1#fehler),
   mit JS zusätzlich über [data-fehlerbox] */
.formular__fehler {
  display: none;
  border: 1px solid var(--ochre); background: var(--paper); color: var(--ink);
  font-size: 14px; line-height: 1.5; padding: 12px 14px; margin-bottom: 12px;
}
.formular__fehler:target, .formular__fehler.is-sichtbar { display: block; }
.hp { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }

/* ---------- Textseiten (Impressum etc.) ---------- */
.page { padding: var(--section-pad) var(--page-pad) 64px; border-top: 1px solid var(--line-strong); max-width: 860px; }
.page h1 { font: 600 var(--text-h1)/1.05 var(--font-serif); margin-bottom: 24px; }
.page__body h2 { font: 600 22px var(--font-serif); margin: 28px 0 10px; }
.page__body p { font-size: var(--text-body); line-height: 1.7; color: var(--ink-soft); margin-bottom: 12px; }
.page__body a { color: var(--green); }

/* ---------- Footer ---------- */
.footer {
  border-top: 1px solid var(--line-strong); padding: 36px var(--page-pad);
  display: flex; justify-content: space-between; gap: 24px;
  font-size: var(--text-meta); color: var(--ink-soft);
}
.footer b { color: var(--ink); }
.footer a { text-decoration: none; }
.footer a:hover { text-decoration: underline; }
.footer__links { display: flex; gap: 22px; flex-shrink: 0; }

/* ---------- Tablet (769–1024px): Design definiert nur 1280/390 — dazwischen
   Nav kompakt, Wohnungszeilen ohne Button-Spalte, Kontakt einspaltig ---------- */
@media (min-width: 769px) and (max-width: 1024px) {
  .nav { padding: 18px 32px; gap: 14px; }
  .nav__claim { display: none; }
  .nav__links { gap: 14px; font-size: 13px; }
  .nav__cta { padding: 8px 14px; }

  .hero__text { padding: 48px 32px; }
  .hero h1 { font-size: 44px; }
  .sektionskopf { padding-left: 32px; padding-right: 32px; }
  .zeile { grid-template-columns: 56px 200px 1fr 130px; gap: 16px; padding: 20px 32px; }
  .zeile__num { font-size: 32px; }
  .zeile__btn { display: none; }
  .zeile__img, .zeile__foto img, .zeile__foto--platzhalter { height: 96px; }

  .band, .footer, .seitenkopf, .preistabelle-wrap, .detail__kopf { padding-left: 32px; padding-right: 32px; }
  .galerie { padding-left: 32px; padding-right: 32px; }
  .garten__text, .zitat { padding: 40px 32px; }
  .umgebung__karte:first-child { padding-left: 32px; }
  .detail__beschreibung, .detail__sidebar { padding: 40px 32px; }
  .hinweistrio > div:first-child { padding-left: 32px; }
  .hinweistrio > div:last-child { padding-right: 32px; }
  .page { padding-left: 32px; padding-right: 32px; }

  .kontakt { grid-template-columns: 1fr; }
  .kontakt__links { border-right: none; border-bottom: 1px solid var(--line); padding: 40px 32px; }
}

/* ---------- Mobile (2d), Breakpoint ≤768px ---------- */
@media (max-width: 768px) {
  .nav { padding: 16px var(--page-pad-mobile); border-bottom: 1px solid var(--line-strong); }
  .nav__wordmark { font-size: 17px; }
  .nav__claim { display: none; }
  .nav__links { display: none; }
  .nav__burger { display: flex; }

  /* Reihenfolge wie 2d: Eyebrow/H1 → Intro → Foto → Buttons */
  .hero { display: flex; flex-direction: column; border-top: none; }
  .hero__text, .hero__unten { display: contents; }
  .hero__kopf { order: 0; padding: 26px var(--page-pad-mobile) 0; }
  .hero__eyebrow { font-size: 10.5px; margin-bottom: 12px; }
  .hero h1 { font-size: 32px; line-height: 1.08; margin-bottom: 14px; }
  .hero__unten p { order: 1; padding: 0 var(--page-pad-mobile); font-size: 14.5px; line-height: 1.6; margin-bottom: 18px; }
  .hero__bild { order: 2; min-height: 230px; height: 230px; }
  .hero__badge { left: 12px; bottom: 12px; padding: 8px 12px; font-size: 11px; }
  .hero__buttons { order: 3; flex-direction: column; gap: 10px; padding: 18px var(--page-pad-mobile) 24px; }
  .hero__buttons a { min-height: 44px; font-size: 14.5px; display: flex; align-items: center; justify-content: center; }

  .sektionskopf { padding: 32px var(--page-pad-mobile) 4px; }
  .sektionskopf h2 { font-size: 26px; }
  .zeile {
    grid-template-columns: 44px 96px 1fr; gap: var(--gap-tight);
    padding: 16px var(--page-pad-mobile);
  }
  .zeile__num { font-size: 24px; }
  .zeile__img, .zeile__foto img { height: 68px; width: 96px; }
  .zeile__foto--platzhalter { height: 68px; width: 96px; }
  .zeile__titel { font-size: 14px; margin-bottom: 2px; }
  .zeile__nur-desktop, .zeile__desc, .zeile__preis, .zeile__btn, .zeile__vormerken { display: none; }
  .zeile__meta-mobil { display: block; font-size: 12.5px; color: var(--ink-mute); }
  .zeile__meta-mobil b { color: var(--ink); }

  .band { padding: 24px var(--page-pad-mobile); }
  .band__head { flex-direction: column; gap: 4px; margin-bottom: 12px; }
  .band__head h2 { font-size: 19px; }
  .band__cta { margin-left: 0; }

  .garten { grid-template-columns: 1fr; }
  .garten__text { padding: 32px var(--page-pad-mobile); border-right: none; border-bottom: 1px solid var(--line); }
  .zitat { padding: 32px var(--page-pad-mobile); }
  .umgebung { grid-template-columns: 1fr; }
  .umgebung__karte { padding: 24px var(--page-pad-mobile); border-right: none; border-bottom: 1px solid var(--line); }
  .umgebung__karte:first-child { padding-left: var(--page-pad-mobile); }
  .karte { min-height: 220px; }

  .detail__kopf { padding: 16px var(--page-pad-mobile) 22px; }
  .detail__titelzeile { flex-direction: column; align-items: flex-start; gap: 18px; }
  .detail__titelgruppe { gap: 12px; }
  .detail__num { font-size: 38px; }
  .detail__titelgruppe h1 { font-size: 28px; }
  .detail__meta { gap: 10px; font-size: 13.5px; }
  .detail__buchung { align-items: flex-start; width: 100%; }
  .detail__buchung .btn-primary { width: 100%; }
  .galerie {
    grid-template-columns: 1fr 1fr; grid-template-rows: 200px 130px 130px;
    padding: 0 var(--page-pad-mobile) 28px;
  }
  .galerie__gross { grid-column: span 2; grid-row: span 1; }
  .detail__inhalt { grid-template-columns: 1fr; }
  .detail__beschreibung { padding: 32px var(--page-pad-mobile); border-right: none; border-bottom: 1px solid var(--line); }
  .ausstattung { grid-template-columns: 1fr; }
  .detail__sidebar { padding: 32px var(--page-pad-mobile); }

  .seitenkopf { padding: 32px var(--page-pad-mobile) 24px; }
  .seitenkopf h1 { font-size: 30px; }
  .preistabelle-wrap { padding: 0 var(--page-pad-mobile) 28px; }
  .hinweistrio { grid-template-columns: 1fr; }
  .hinweistrio > div { padding: 24px var(--page-pad-mobile); border-right: none; border-bottom: 1px solid var(--line); }
  .hinweistrio > div:first-child { padding-left: var(--page-pad-mobile); }
  .hinweistrio > div:last-child { border-bottom: none; padding-right: var(--page-pad-mobile); }

  .kontakt { grid-template-columns: 1fr; }
  .kontakt__links { padding: 32px var(--page-pad-mobile); border-right: none; }
  .kontakt__links h1 { font-size: 30px; }
  .anreise { grid-template-columns: 1fr; }
  .anreise__spalte { padding: 24px var(--page-pad-mobile); }
  .anreise__spalte:first-child { border-right: none; border-bottom: 1px solid var(--line); }
  .formular__row { grid-template-columns: 1fr; }

  .page { padding: 32px var(--page-pad-mobile) 48px; }
  .page h1 { font-size: 30px; }

  .footer { flex-direction: column; gap: 6px; padding: 24px var(--page-pad-mobile); font-size: 13px; }
  .footer__links { gap: 14px; flex-wrap: wrap; }

  .lightbox__pfeil { font-size: 34px; padding: 10px; }
}
