/*
Theme Name: Eifeltor - Customizer Edition
Version: 2.0.0
Author: D!E
Text Domain: eifeltor
*/

/* Original CSS combined from Website folder */
/* ================================================================
   EIFELTOR — Design Tokens
   ================================================================ */

:root {
  /* Forest greens */
  /* --forest-dark:    #2D5016;
  --forest-mid:     #4A7C59;
  --forest-light:   #7DA87B;
  --forest-pale:    #C8DFC1;
  --forest-wash:    #E8F3E2; */

  /* Forest greens — olive-shifted for gold harmony */
  --forest-dark:    #374d14;
  --forest-mid:     #546930;
  --forest-light:   #87975a;
  --forest-pale:    #c7d3a0;
  --forest-wash:    #ebf0da;

  /* Earthy woods */
  --bark-deep:      #3A2810;
  --bark-dark:      #4E3620;
  --bark-mid:       #7C5C3A;
  --bark-light:     #B89070;
  --bark-pale:      #D4B896;

  /* Warm ambers — base: #f9b513 */
  /* --amber-deep:     #bf840d;
  --amber:          #f9b513;
  --amber-bright:   #fac942;
  --amber-pale:     #fef3cb;
  --amber-wash:     #fffaeb; */


  /* Warm ambers — base: #dbbf70 */
  --amber-deep:     #81651e;
  --amber:          #dbbf70;
  --amber-bright:   #e8d192;
  --amber-pale:     hsl(44, 67%, 87%);
  --amber-wash:     hsl(43, 72%, 95%);

  /* Warm ambers — base: #c35e40 */
  /* --amber-deep:     #8c3320;
  --amber:          #c24e2a;
  --amber-bright:   #d36341;
  --amber-pale:     #f0cfc5;
  --amber-wash:     #faf1ee; */

  /* Creams & neutrals */
  --cream:          #FAF7F2;
  --cream-warm:     #EDE8DE;
  --cream-border:   #D4C8B8;
  --cream-shadow:   rgba(78, 54, 32, 0.08);

  /* Text */
  --text-deep:      #1C1A17;
  --text-warm:      #4A4540;
  --text-muted:     #74706b;
  --text-on-dark:   #F5F0E8;
  /* --text-on-amber:  #3A2810; */
  --text-on-amber:  #3A2810;
  /* --text-on-amber:  #fffaf3; */

  /* White & light overlays — for use on dark/forest/bark-background sections */
  --white:              #fff;
  --overlay-light-4:    rgba(255,255,255,0.04);
  --overlay-light-6:    rgba(255,255,255,0.06);
  --overlay-light-8:    rgba(255,255,255,0.08);
  --overlay-light-10:   rgba(255,255,255,0.10);
  --overlay-light-12:   rgba(255,255,255,0.12);
  --overlay-light-15:   rgba(255,255,255,0.15);
  --overlay-light-20:   rgba(255,255,255,0.20);
  --overlay-light-25:   rgba(255,255,255,0.25);
  --overlay-light-30:   rgba(255,255,255,0.30);
  --overlay-light-40:   rgba(255,255,255,0.40);
  --overlay-light-45:   rgba(255,255,255,0.45);
  --overlay-light-50:   rgba(255,255,255,0.50);
  --overlay-light-60:   rgba(255,255,255,0.60);
  --overlay-light-65:   rgba(255,255,255,0.65);
  --overlay-light-70:   rgba(255,255,255,0.70);
  --overlay-light-75:   rgba(255,255,255,0.75);
  --overlay-light-80:   rgba(255,255,255,0.80);
  --overlay-light-82:   rgba(255,255,255,0.82);
  --overlay-light-85:   rgba(255,255,255,0.85);
  --overlay-light-90:   rgba(255,255,255,0.90);
  --overlay-light-95:   rgba(255,255,255,0.95);

  /* Spacing scale */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --space-16: 4rem;
  --space-20: 5rem;
  --space-24: 6rem;
  --space-32: 8rem;

  /* Border radius */
  --radius-sm:   0.375rem;
  --radius-md:   0.75rem;
  --radius-lg:   1.25rem;
  --radius-xl:   2rem;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-sm:  0 1px 3px rgba(55,77,20,0.08), 0 1px 2px rgba(55,77,20,0.05);
  --shadow-md:  0 4px 12px rgba(55,77,20,0.10), 0 2px 4px rgba(55,77,20,0.06);
  --shadow-lg:  0 16px 40px rgba(55,77,20,0.12), 0 4px 8px rgba(55,77,20,0.06);
  --shadow-amber: 0 4px 20px rgba(195,94,64,0.30);

  /* Transitions */
  --ease: cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --duration-fast: 150ms;
  --duration-mid:  250ms;
  --duration-slow: 400ms;

  /* Layout */
  --nav-height: 90px;
  --container-max: min(100%, 80rem);
  --container-narrow: min(100%, 50rem);
  --container-wide: min(100%, 90rem);

  /* Warm shadows for cream-background contexts */
  --shadow-warm-sm: 0 1px 3px rgba(78,54,32,0.08), 0 1px 2px rgba(78,54,32,0.05);
  --shadow-warm-md: 0 4px 12px rgba(78,54,32,0.10), 0 2px 4px rgba(78,54,32,0.06);
  --shadow-warm-lg: 0 16px 40px rgba(78,54,32,0.12), 0 4px 8px rgba(78,54,32,0.06);

  /* Font stacks */
  --font-body:    'Source Sans 3', 'Segoe UI', system-ui, sans-serif;
  --font-heading: 'Playfair Display', Georgia, 'Times New Roman', serif;

  /* Type scale */
  --fs-2xs:     0.625rem;    /* 10px */
  --fs-xs:      0.75rem;     /* 12px */
  --fs-sm:      0.875rem;    /* 14px */
  --fs-base:    1rem;        /* 16px */
  --fs-md:      1.0625rem;   /* 17px */
  --fs-body:    1.2rem;      /* ~19px */
  --fs-lead:    1.3125rem;   /* 21px */
  --fs-lg:      1.375rem;    /* 22px */
  --fs-xl:      1.5rem;      /* 24px */
  --fs-2xl:     1.625rem;    /* 26px */
  --fs-3xl:     1.75rem;     /* 28px */
  --fs-4xl:     1.875rem;    /* 30px */
  --fs-5xl:     2rem;        /* 32px */
  --fs-6xl:     2.125rem;    /* 34px */
  --fs-7xl:     2.25rem;     /* 36px */
  --fs-h4:      clamp(1.375rem, 2vw, 1.875rem);
  --fs-h3:      clamp(1.5rem, 2.5vw, 2.25rem);
  --fs-h2:      clamp(2.125rem, 4vw, 3.25rem);
  --fs-h1:      clamp(2.5rem, 5vw, 4.25rem);
  --fs-display: clamp(3.5rem, 9vw, 8rem);
  --fs-hero:    clamp(4.25rem, 10vw, 10.75rem);
}

@media (max-width: 640px) {
  :root {
    /* --space-6: 1.25rem;
    --space-8: 1.5rem; */

    --fs-2xs:     0.8000rem;   /* 12.8px — ×1.05 scale */
    --fs-xs:      0.8400rem;   /* 13.4px */
    --fs-sm:      0.8820rem;   /* 14.1px */
    --fs-base:    0.9261rem;   /* 14.8px */
    --fs-md:      0.9724rem;   /* 15.6px */
    --fs-body:    1.0210rem;   /* 16.3px */
    --fs-lead:    1.0721rem;   /* 17.2px */
    --fs-lg:      1.1257rem;   /* 18.0px */
    --fs-xl:      1.1820rem;   /* 18.9px */
    --fs-2xl:     1.2411rem;   /* 19.9px */
    --fs-3xl:     1.3031rem;   /* 20.8px */
    --fs-4xl:     1.3683rem;   /* 21.9px */
    --fs-5xl:     1.4367rem;   /* 23.0px */
    --fs-6xl:     1.5085rem;   /* 24.1px */
    --fs-7xl:     1.5839rem;   /* 25.3px */
    --fs-h4:      clamp(1.375rem, 2vw, 1.875rem);
    --fs-h3:      clamp(1.5rem, 2.5vw, 2.25rem);
    --fs-h2:      clamp(2.125rem, 4vw, 3.25rem);
    --fs-h1:      clamp(2.5rem, 5vw, 4.25rem);
    --fs-display: clamp(3.5rem, 9vw, 8rem);
    --fs-hero:    clamp(4.25rem, 10vw, 10.75rem);
  }
}/* ================================================================
   EIFELTOR — Reset, Base, Typography, Layout Utilities, Buttons
   ================================================================ */

/* ----------------------------------------------------------------
   RESET & BASE
   ---------------------------------------------------------------- */

:root {
  color-scheme: light;
}

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
}

body {
  background-color: var(--cream);
  color: var(--text-warm);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;

  hyphens: auto;
  hyphenate-limit-chars: 12 2 2;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: var(--forest-mid);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease);
  outline-offset: var(--space-1);
}

a:hover,
a:focus-visible {
  color: var(--forest-dark);
}

a:not(.btn):not(.nav-links a):not(.nav-mobile .nav-mobile-links a):hover,
a:not(.btn):not(.nav-links a):not(.nav-mobile .nav-mobile-links a):hover {
  text-decoration: underline;
}

ul { list-style: none; }

button {
  font-family: inherit;
  cursor: pointer;
  border: none;
  background: none;
}

table { border-collapse: collapse; }

/* ----------------------------------------------------------------
   TYPOGRAPHY
   ---------------------------------------------------------------- */
h1, h2, h3, h4 {
  font-family: var(--font-heading);
  color: var(--text-deep);
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: -0.01em;
  overflow-wrap: break-word;
  word-break: break-word;
  hyphenate-limit-chars: 12 4 4;
}

h1, .h1 { font-size: var(--fs-h1); }
h2, .h2 { font-size: var(--fs-h2); }
h3, .h3 { font-size: var(--fs-h3); }
h4, .h4 { font-size: var(--fs-h4); }

.display-title {
  font-size: var(--fs-display);
  line-height: 1.05;
  letter-spacing: -0.03em;
}

p {
  line-height: 1.7;
  overflow-wrap: break-word;
  word-break: break-word;
}

p + * { margin-top: var(--space-2); }

.flex-col > p + * {
  margin-top: 0;
}

.lead {
  font-size: var(--fs-lg);
  line-height: 1.65;
  color: var(--text-warm);
}

strong { font-weight: 600; }

address {
  font-style: normal;
  line-height: 1.65;
}





/* ----------------------------------------------------------------
   CARD BASE
   ---------------------------------------------------------------- */
.card {
  background-color: var(--cream-warm);
  border-radius: var(--radius-lg);
  /* box-shadow: var(--shadow-sm); */
  box-shadow: var(--shadow-md);
}

.card-padding {
  padding: var(--space-8);
}


/* ----------------------------------------------------------------
   SECTION BACKGROUND VARIANTS
   ---------------------------------------------------------------- */
.bg-cream     { background-color: var(--cream); }
.bg-cream-warm { background-color: var(--cream-warm); }
.bg-forest    { background-color: var(--forest-dark); }
.bg-forest-wash { background-color: var(--forest-wash); }

/* Warm-tinted shadows for feature-splits on cream backgrounds */
.bg-cream .card,
.bg-cream-warm .card {
  box-shadow: var(--shadow-warm-md);
}

/* Harmonize feature-split body panel with forest-wash section background */
.bg-forest-wash .feature-split .feature-split-body {
  background-color: var(--white);
}

/* ----------------------------------------------------------------
   LAYOUT UTILITIES
   ---------------------------------------------------------------- */
.container {
  width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--space-6);
}

.container-narrow {
  width: var(--container-narrow);
}

.container-wide {
  width: var(--container-wide);
}

.grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-8);
}
@media (max-width: 900px) {
  .grid-2 { grid-template-columns: 1fr; }
}

.flex { display: flex; }
.flex-col { flex-direction: column; }
.flex-wrap { flex-wrap: wrap; }
.gap-2 { gap: var(--space-2); }
.gap-4 { gap: var(--space-4); }
.flex-1 { flex: 1 0 auto; }

.section {
  padding-block: var(--space-16) var(--space-20);
}

/* Generous top padding for sections that open a visual chapter */
.section.section-open {
  padding-block-start: var(--space-32);
}

/* Tighter bottom padding for sections whose feature-split provides its own visual weight */
.section.section-tight-bottom {
  padding-block-end: var(--space-16);
}

.section-sm {
  padding-block: var(--space-16);
}

/* ----------------------------------------------------------------
   BUTTONS
   ---------------------------------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0.75rem 1.75rem;
  border-radius: var(--radius-full);
  font-family: var(--font-body);
  font-size: var(--fs-md);
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: all var(--duration-mid) var(--ease-out);
  white-space: nowrap;
  border: 0.125rem solid transparent;
  text-decoration: none;
  outline-offset: var(--space-1);
}

.btn-primary {
  background-color: var(--amber);
  /* background-image: linear-gradient(to bottom, var(--amber-pale) 5%, var(--amber-bright) 10%, var(--amber-bright) 40%, var(--amber) 60%); */
  color: var(--text-on-amber);
  border-color: var(--amber);
}

.btn-primary:hover,
.btn-primary:focus-visible {
  background-color: var(--amber-bright);
  border-color: var(--amber-bright);
  color: var(--text-on-amber);
  transform: translateY(-1px);
}

.btn-secondary {
  background-color: transparent;
  color: var(--forest-mid);
  border-color: var(--forest-mid);
}

.btn-secondary:hover,
.btn-secondary:focus-visible {
  background-color: var(--forest-mid);
  color: var(--white);
  transform: translateY(-1px);
}

.btn-outline-light {
  background-color: transparent;
  color: var(--overlay-light-90);
  border-color: var(--overlay-light-40);
}

.btn-outline-light:hover,
.btn-outline-light:focus-visible {
  background-color: var(--overlay-light-12);
  color: var(--white);
  border-color: var(--overlay-light-70);
}

.btn-lg {
  padding: 1rem 2.25rem;
  font-size: var(--fs-lead);
}

.btn svg {
  width: 1.125em;
  height: 1.125em;
  flex-shrink: 0;
}

.feature-note {
  font-size: var(--fs-base);
  color: var(--text-muted);
}

.bg-forest .feature-note {
  color: var(--overlay-light-50);
}



@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition-duration: 0.01ms !important;
  }
}


/* ----------------------------------------------------------------
   PRINT
   ---------------------------------------------------------------- */
@media print {
  .site-nav, .hero-scroll, .nav-toggle, .nav-mobile { display: none; }
  .page-hero { height: auto; }
}


/* DEBUG */
/* *, *::before, *::after {
  outline: 1px solid rgba(255 0 0 / .5) !important;
} *//* ================================================================
   EIFELTOR — Navigation
   ================================================================ */

.site-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  height: var(--nav-height);
  transition: background-color var(--duration-mid) var(--ease),
              box-shadow var(--duration-mid) var(--ease);
}

.site-nav.solid {
  background-color: var(--cream);
  box-shadow: 0 1px 0 var(--cream-border), var(--shadow-sm);
}

.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
  padding-block: var(--space-2);
}

/* Logo */
.nav-logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  color: inherit;
  flex-shrink: 0;
  height: 100%;
}

.nav-logo img {
  width: auto;
  /* height: 100%; */
  height: calc(var(--nav-height) * 1.1);
  align-self: start;
  /* max-width: 10rem; */
}

/* Nav logo mark (letter badge) */

/* Nav links */
.nav-links {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.nav-links a {
  font-size: var(--fs-md);
  font-weight: 500;
  color: var(--text-warm);
  padding: 0.4rem 0.75rem;
  border-radius: var(--radius-sm);
  transition: color var(--duration-fast) var(--ease),
              background-color var(--duration-fast) var(--ease);
  text-decoration: none;
}

.nav-links a:hover,
.nav-links a:focus-visible,
.nav-links a.active {
  color: var(--text-on-amber);
  background-color: var(--amber-bright);
}

/* Language switcher (pill style) */
.nav-lang {
  display: flex;
  align-items: center;
  gap: 0;
  background-color: var(--cream-warm);
  border-radius: var(--radius-full);
  padding: 0.125rem;
  border: 1px solid var(--cream-border);
}

.nav-lang a {
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  padding: 0.3rem 0.7rem;
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: all var(--duration-fast) var(--ease);
}

.nav-lang a:hover,
.nav-lang a:focus-visible {
  color: var(--text-deep);
  background-color: var(--cream);
}

.nav-lang a.active {
  background-color: var(--forest-mid);
  color: var(--white);
}

/* Language switcher (dropdown style) */

/* Nav right cluster */
.nav-right {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

/* Nav actions cluster */

/* Hamburger */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 0.3125rem;
  width: 2.75rem;
  height: 2.75rem;
  padding: 0.25rem;
  border-radius: var(--radius-sm);
  cursor: pointer;
  background: none;
  border: none;
}

.nav-toggle span {
  display: block;
  height: 0.125rem;
  background-color: var(--text-deep);
  border-radius: 0.125rem;
  transition: all var(--duration-mid) var(--ease);
  transform-origin: center;
}

/* Mobile menu overlay */
.nav-mobile {
  position: fixed;
  inset: 0;
  z-index: 999;
  background-color: var(--forest-dark);
  padding: calc(var(--nav-height) + var(--space-8)) var(--space-8) var(--space-8);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-0.5rem);
  transition: opacity var(--duration-mid) var(--ease-out),
              transform var(--duration-mid) var(--ease-out),
              visibility 0s linear var(--duration-mid);
}

.nav-mobile.open {
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
  visibility: visible;
}

.nav-mobile .nav-mobile-links {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: var(--space-8);
}

.nav-mobile .nav-mobile-links a {
  font-family: var(--font-heading);
  font-size: var(--fs-7xl);
  color: var(--text-on-dark);
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--overlay-light-10);
  display: block;
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease);
}

.nav-mobile .nav-mobile-links a:hover { color: var(--amber-bright); }

.nav-mobile .nav-mobile-lang {
  display: flex;
  gap: var(--space-4);
  margin-top: var(--space-8);
}

.nav-mobile .nav-mobile-lang a {
  font-size: var(--fs-body);
  font-weight: 600;
  color: var(--overlay-light-60);
  letter-spacing: 0.08em;
  text-decoration: none;
}

.nav-mobile .nav-mobile-lang a.active { color: var(--amber-bright); }

/* Responsive */
@media (max-width: 940px) {
  .nav-links { display: none; }
  .nav-lang  { display: none; }
  .nav-toggle { display: flex; }
}
/* ================================================================
   EIFELTOR — Hero Sections
   ================================================================ */

/* ---- Full-height homepage hero ---- */
.hero {
  position: relative;
  min-height: 100svh;
  min-height: 100vh;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background-color: var(--forest-dark);
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(18, 34, 10, 0.06) 0%,
    rgba(18, 34, 10, 0.15) 42%,
    rgba(18, 34, 10, 0.72) 68%,
    rgba(18, 34, 10, 0.93) 100%
  );
  z-index: 1;
}

.hero-content {
  position: relative;
  z-index: 2;
  padding-top: calc(var(--nav-height) + var(--space-20));
  padding-bottom: var(--space-20);
}

.hero-title {
  font-family: var(--font-heading);
  color: var(--white);
  margin-bottom: var(--space-6);
  text-shadow: 0 2px 32px rgba(0,0,0,0.2);
  animation: heroReveal 0.9s cubic-bezier(0, 0, 0.2, 1) 0.3s both;
}

.hero-title.display-title {
  font-size: var(--fs-display);
  line-height: 0.92;
  letter-spacing: -0.04em;
}

.hero-title em {
  font-style: italic;
  color: var(--amber);
}

.hero-subtitle {
  font-size: var(--fs-2xl);
  color: var(--overlay-light-82);
  line-height: 1.6;
  margin-bottom: var(--space-10);
  max-width: 50rem;
  animation: heroReveal 0.7s cubic-bezier(0, 0, 0.2, 1) 0.55s both;
}

.hero-actions {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  animation: heroReveal 0.7s cubic-bezier(0, 0, 0.2, 1) 0.75s both;
}

.hero-scroll {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: var(--overlay-light-60);
  font-size: var(--fs-5xl);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  animation: heroFloat 2.8s cubic-bezier(0.45, 0, 0.55, 1) infinite;
}

.hero-scroll svg {
  width: 1em;
  height: 1em;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.5;
}

@keyframes heroReveal {
  from { opacity: 0; transform: translateY(1.375rem); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes heroFloat {
  0%, 100% { transform: translateX(-50%) translateY(0);  opacity: 0.5; }
  50%       { transform: translateX(-50%) translateY(0.5rem); opacity: 0.85; }
}

/* Tree canopy hero-to-content transition */

/* ---- Inner page hero (smaller, with photo) ---- */
.page-hero {
  position: relative;
  min-height: 30rem;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background-color: var(--forest-dark);
}

/* Support inline background-image on .page-hero */
.page-hero[style] {
  background-size: cover;
  background-position: center 20%;
  background-repeat: no-repeat;
}

.page-hero-bg {
  position: absolute;
  inset: 0;
}

.page-hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%;
}

.page-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(26,48,16,0.85) 0%,
    rgba(26,48,16,0.3) 60%,
    rgba(26,48,16,0.15) 100%
  );
}

.page-hero-content {
  position: relative;
  z-index: 2;
  padding-block: calc(var(--nav-height) + var(--space-20)) var(--space-12);
}

.page-hero-content .section-label {
  color: var(--amber-bright);
  margin-bottom: var(--space-3);
  display: block;
}

.page-hero-content h1 {
  color: var(--white);
  text-shadow: 0 2px 16px rgba(0,0,0,0.3);
  margin-bottom: var(--space-3);
}

.page-hero-content p {
  color: var(--overlay-light-85);
  font-size: var(--fs-lead);
  max-width: 50rem;
}

.page-hero-eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--amber-bright);
  display: block;
  margin-bottom: var(--space-3);
}

.page-hero-title {
  color: var(--white);
  text-shadow: 0 2px 16px rgba(0,0,0,0.35);
  margin-bottom: var(--space-3);
  font-size: clamp(2rem, 5vw, 3.25rem);
}

.page-hero-sub {
  color: var(--overlay-light-85);
  font-size: var(--fs-lead);
  max-width: 35rem;
  margin-bottom: var(--space-5);
}

.page-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
}

/* ---- Plain page header (no photo) ---- */

/* Page header banner (utility pages) */
.page-header-banner {
  background-color: var(--forest-dark);
  background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%234A7C59' fill-opacity='0.18'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  padding: calc(var(--nav-height) + var(--space-12)) var(--space-6) var(--space-12);
}

.page-header-banner .container { max-width: var(--container-max); }
.page-header-banner h1 { color: var(--white); margin-bottom: var(--space-3); }
.page-header-banner p  { color: var(--overlay-light-80); font-size: var(--fs-lead); max-width: 35rem; }

/* Responsive */
@media (max-width: 640px) {
  .page-hero { min-height: 22.5rem; }
}
/* ================================================================
   EIFELTOR — Forms & Contact
   ================================================================ */

/* ----------------------------------------------------------------
   CONTACT LAYOUT
   ---------------------------------------------------------------- */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: var(--space-12);
  align-items: start;
}

.contact-card h3 {
  font-size: var(--fs-2xl);
  margin-bottom: var(--space-6);
}

.contact-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* ----------------------------------------------------------------
   FORM CONTROLS
   ---------------------------------------------------------------- */
/* .form-group {
  margin-bottom: var(--space-5);
} */

.form-label {
  display: block;
  font-size: var(--fs-base);
  font-weight: 600;
  color: var(--text-warm);
  margin-bottom: var(--space-2);
}

.form-control {
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: var(--cream);
  border: 1px solid var(--cream-border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--text-deep);
  transition: border-color var(--duration-fast) var(--ease),
              box-shadow var(--duration-fast) var(--ease);
  -webkit-appearance: none;
  appearance: none;
}

.form-control:focus {
  border-color: var(--forest-mid);
  box-shadow: 0 0 0 3px rgba(74,124,89,0.15);
}

.form-control:focus-visible {
  outline: 2px solid var(--forest-mid);
  outline-offset: 1px;
}

textarea.form-control {
  min-height: 7.5rem;
  resize: vertical;
}

.form-label-optional {
  font-weight: 400;
  color: var(--text-muted);
}

/* ----------------------------------------------------------------
   CONTACT PAGE (cards + map + directions)
   ---------------------------------------------------------------- */

.contact-card h2 {
  font-size: var(--fs-xl);
  margin-bottom: var(--space-3);
}

.contact-card address { font-style: normal; line-height: 1.7; color: var(--text-warm); }

/* ----------------------------------------------------------------
   CONTACT ENTITIES — two-column entity cards
   ---------------------------------------------------------------- */

.contact-entity-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  border-top: 1px solid var(--cream-border);
  padding-top: var(--space-6);
  margin-top: var(--space-6);
}

.contact-entity-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
}

/* .contact-entity-icon {
  width: 2.25rem;
  height: 2.25rem;
  background: var(--forest-wash);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 0.125rem;
} */

.contact-entity-icon svg {
  width: 2rem;
  height: 2rem;
  stroke: var(--amber-deep);
  fill: none;
}

.contact-entity-item-label {
  display: block;
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: var(--space-1);
}

.contact-entity-item-value {
  display: block;
  font-size: var(--fs-body);
  /* font-weight: 500; */
  color: var(--text-deep);
  line-height: 1.5;
}

.contact-entity-item-value a,
a.contact-entity-item-value {
  color: var(--forest-dark);
  text-decoration: none;
}

.contact-entity-item-value a:hover,
a.contact-entity-item-value:hover {
  color: var(--forest-mid);
  text-decoration: underline;
}

/* Map wrapper */
.map-wrapper {
  /* border-radius: var(--radius-lg); */
  overflow: hidden;
  box-shadow: var(--shadow-md);
  height: 100%;
}

.map-wrapper iframe { display: block; width: 100%; height: 100%;}

/* ----------------------------------------------------------------
   RESERVATION FORMS
   ---------------------------------------------------------------- */
.reservation-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

.reservation-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  /* margin-bottom: var(--space-5); */
}

.reservation-form .form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin-bottom: 0;
}

.reservation-form .form-label {
  margin-bottom: 0;
}

.reservation-form .form-group-full {
  grid-column: 1 / -1;
}

.reservation-form label {
  font-size: var(--fs-base);
  font-weight: 600;
  color: var(--text-warm);
}

.reservation-form label:has(input[type="checkbox"]) {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
}

.reservation-form input:not(input[type="checkbox"]),
.reservation-form select,
.reservation-form textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: var(--cream);
  border: 1px solid var(--cream-border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--text-deep);
  transition: border-color var(--duration-fast) var(--ease),
              box-shadow var(--duration-fast) var(--ease);
  -webkit-appearance: none;
  appearance: none;
}

.reservation-form input:not(input[type="checkbox"]):focus,
.reservation-form select:focus,
.reservation-form textarea:focus {
  outline: none;
  border-color: var(--forest-mid);
  box-shadow: 0 0 0 3px rgba(74,124,89,0.15);
}

.reservation-form textarea { min-height: 6.25rem; resize: vertical; }

.reservation-form select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239A958E' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}

.required {
  color: var(--amber-deep);
  font-size: var(--fs-xs);
}

.form-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-6);
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--cream-border);
  flex-wrap: wrap;
}

.form-privacy {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  max-width: 25rem;
}

.form-privacy a { color: var(--forest-mid); }

/* Responsive */
@media (max-width: 900px) {
  .contact-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .reservation-form .form-row { grid-template-columns: 1fr; }
  .form-footer { flex-direction: column; align-items: flex-start; }
}
/* ================================================================
   EIFELTOR — Footer
   ================================================================ */

.site-footer {
  background-color: var(--bark-deep);
  color: var(--text-on-dark);
  padding: var(--space-16) var(--space-6) var(--space-8);
  position: relative;
}

.site-footer::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 0.25rem;
  background: linear-gradient(90deg, var(--forest-mid), var(--amber), var(--forest-mid));
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1.5fr 1.5fr;
  gap: var(--space-10);
  max-width: var(--container-max);
  margin-inline: auto;
  margin-bottom: var(--space-12);
}

.footer-brand p {
  color: rgba(245,240,232,0.6);
  font-size: var(--fs-md);
  margin-top: var(--space-4);
  line-height: 1.6;
}

.footer-bottom {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-top: var(--space-8);
  border-top: 1px solid var(--overlay-light-8);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.footer-bottom p {
  font-size: var(--fs-sm);
  color: rgba(245,240,232,0.4);
}

/* Footer semantic aliases */
.footer-logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.footer-logo span:not(.nav-logo-mark) {
  font-family: var(--font-heading);
  font-size: var(--fs-2xl);
  font-weight: 700;
  color: var(--text-on-dark);
}

.footer-heading {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(245,240,232,0.45);
  margin-bottom: var(--space-5);
}

.footer-tagline {
  color: rgba(245,240,232,0.6);
  font-size: var(--fs-md);
  line-height: 1.6;
}

.footer-address {
  color: rgba(245,240,232,0.6);
  font-size: var(--fs-md);
  line-height: 1.6;
  margin-top: var(--space-3);
  font-style: normal;
}

.footer-season {
  font-size: var(--fs-base);
  color: var(--amber-bright);
  margin-bottom: var(--space-4);
  font-weight: 600;
}

.hours-list {
  /* display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-2) var(--space-4); */
  font-size: var(--fs-md);
}

.hours-list dd + * {
  margin-top: var(--space-4);
}

.hours-list dt { color: rgba(245,240,232,0.5); }
.hours-list dd { color: rgba(245,240,232,0.85); font-weight: 500; line-height: 1.25; }

.footer-nav ul {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.footer-nav ul li a {
  color: rgba(245,240,232,0.75);
  font-size: var(--fs-md);
  transition: color var(--duration-fast) var(--ease);
}

.footer-nav ul li a:hover { color: var(--amber-bright); }

/* Footer contact list with inline SVGs */
.footer-contact .contact-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.footer-contact .contact-list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--fs-md);
}

.footer-contact .contact-list li svg {
  width: 1rem;
  height: 1rem;
  stroke: var(--amber);
  fill: none;
  stroke-width: 2;
  flex-shrink: 0;
  margin-top: 0.125rem;
}

.footer-contact .contact-list li a {
  color: rgba(245,240,232,0.75);
  /* text-decoration: none; */
}

.footer-contact .contact-list li a:hover { color: var(--amber-bright); }

.footer-lang {
  display: flex;
  gap: var(--space-4);
}

.footer-lang a {
  font-size: var(--fs-sm);
  font-weight: 700;
  letter-spacing: 0.06em;
  color: rgba(245,240,232,0.4);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease);
}

.footer-lang a:hover { color: var(--amber-bright); }

.footer-bottom nav {
  display: flex;
  gap: var(--space-5);
}

.footer-bottom nav a {
  font-size: var(--fs-sm);
  color: rgba(245,240,232,0.4);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease);
}

.footer-bottom nav a:hover { color: var(--amber-bright); }

/* Responsive */
@media (max-width: 1100px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 900px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .footer-nav ul {
    gap: var(--space-1);
  }
}
/* ================================================================
   EIFELTOR — Global Responsive Breakpoints
   ================================================================ */



@media (max-width: 640px) {

  .container { padding-inline: var(--space-4); }
  .section { padding-block: var(--space-12); }
  .section-sm { padding-block: var(--space-10); }

  .hero-actions { flex-direction: column; align-items: flex-start; }
  .hero-actions .btn { width: 100%; justify-content: center; }
  .room-teaser-grid { grid-template-columns: 1fr; }

  .feature-split-body {
    padding: var(--space-10) var(--space-6);
  }

  .season-bar-inner { flex-direction: column; align-items: flex-start; }
  .season-bar-info  { flex-direction: column; gap: var(--space-3); }
}
/* ================================================================
   ANIMATION — Scroll-triggered fade-up
   ================================================================ */
/* ================================================================
   ATTRACTIONS — Rows, grid, and cards
   ================================================================ */

/* ----------------------------------------------------------------
   ATTRACTION ROWS (full-bleed two-col layout)
   ---------------------------------------------------------------- */

/* ----------------------------------------------------------------
   ATTRACTION GRID & CARDS (compact grid layout)
   ---------------------------------------------------------------- */
.attraction-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 30rem), 1fr));
  gap: var(--space-6);
}

.attraction-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform var(--duration-mid) var(--ease),
              box-shadow var(--duration-mid) var(--ease);
}

.attraction-card:hover {
  transform: translateY(-0.1875rem);
  box-shadow: var(--shadow-md);
}

.attraction-card-image {
  height: 13.75rem;
  overflow: hidden;
}

.attraction-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease);
}

.attraction-card:hover .attraction-card-image img {
  transform: scale(1.04);
}

.attraction-card-body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-6);
  flex: 1;
}

.attraction-card-body h3 {
  font-size: var(--fs-2xl);
}

.attraction-card-body p {
  color: var(--text-warm);
  font-size: var(--fs-md);
  flex: 1;
}

.attraction-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--space-4);
  border-top: 1px solid var(--cream-border);
  margin-top: auto;
  gap: var(--space-6)
}
/* ================================================================
   Closure Banner
   Temporary notice strip for closed attractions.
   Place directly after the hero / page-hero element.
   ================================================================ */

.closure-banner {
  background: var(--bark-deep);
  border-top: 3px solid var(--amber);
  border-bottom: 3px solid var(--amber);
  padding: var(--space-5) 0;
}

.closure-banner-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-5);
}

.closure-banner-icon {
  flex-shrink: 0;
  color: var(--amber);
  width: 2rem;
  height: 2rem;
}

.closure-banner-icon svg {
  width: 2rem;
  height: 2rem;
  display: block;
}

.closure-banner-title {
  display: block;
  font-family: var(--font-heading);
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--cream);
  margin-bottom: var(--space-1);
  letter-spacing: 0.01em;
}

.closure-banner-text {
  margin: 0;
  font-size: var(--fs-md);
  line-height: 1.55;
  color: var(--text-on-dark);
  opacity: 0.8;
}

@media (max-width: 640px) {
  .closure-banner-inner {
    flex-direction: column;
    text-align: center;
    gap: var(--space-3);
    align-items: center;
  }
}
/* ================================================================
   CTA — Kombiticket banner, booking CTA block
   ================================================================ */

/* ----------------------------------------------------------------
   KOMBITICKET BANNER
   ---------------------------------------------------------------- */
.kombi-banner {
  background: linear-gradient(135deg, var(--amber) 0%, var(--amber-bright) 100%);
  border-radius: var(--radius-xl);
  padding: var(--space-10) var(--space-12);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-8);
  box-shadow: var(--shadow-amber);
  overflow: hidden;
  position: relative;
}

.kombi-banner::before {
  content: '';
  position: absolute;
  top: -30%;
  right: -5%;
  width: 20rem;
  height: 20rem;
  background: var(--overlay-light-8);
  border-radius: 50%;
}

.kombi-banner::after {
  content: '';
  position: absolute;
  bottom: -40%;
  right: 10%;
  width: 12.5rem;
  height: 12.5rem;
  background: var(--overlay-light-6);
  border-radius: 50%;
}

.kombi-banner-text {
  position: relative;
  z-index: 1;
}

.kombi-banner-text h3 {
  color: var(--text-on-amber);
  font-size: var(--fs-5xl);
  margin-bottom: var(--space-2);
}

.kombi-banner-text p {
  color: rgba(58,40,16,0.8);
  font-size: var(--fs-body);
}

.kombi-banner .btn {
  position: relative;
  z-index: 1;
  flex-shrink: 0;
  background-color: var(--text-on-amber);
  color: var(--amber);
  border-color: var(--text-on-amber);
}

.kombi-banner .btn:hover {
  background-color: var(--white);
  color: var(--amber-deep);
  border-color: var(--white);
}

/* Space between kombi banner and a following price section */
.kombi-banner + .price-section {
  margin-top: var(--space-10);
}

@media (max-width: 900px) {

  .kombi-banner {
    flex-direction: column;
    text-align: center;
    padding: var(--space-8);
  }
}

/* Centered CTA row below a price section (e.g. kombi inquiry button) */
.price-section-cta {
  text-align: center;
  margin-top: var(--space-10);
}

/* ----------------------------------------------------------------
   NEWSLETTER SECTION
   ---------------------------------------------------------------- */
.newsletter-section {
  background-color: var(--forest-dark);
  padding: var(--space-16) var(--space-6);
  position: relative;
  overflow: hidden;
}

.newsletter-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  align-items: center;
  max-width: var(--container-max);
  color: var(--overlay-light-80);
  margin-inline: auto;
}

.newsletter-text h2 {
  color: var(--text-on-dark);
  /* font-size: var(--fs-4xl); */
  margin-bottom: var(--space-3);
}

.newsletter-text p {
  font-size: var(--fs-body);
  line-height: 1.65;
}

.newsletter-text .section-label.amber {
  color: var(--amber);
  margin-bottom: var(--space-3);
}

.newsletter-form-row {
  display: flex;
  gap: var(--space-3);
}

.newsletter-input {
  flex: 1;
  min-width: 0;
  padding: 0.8125rem 1.125rem;
  background-color: var(--cream);
  border: 1px solid var(--cream-border);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  color: var(--text-deep);
  transition: border-color var(--duration-fast) var(--ease),
              box-shadow var(--duration-fast) var(--ease);
}

.newsletter-input::placeholder {
  color: var(--text-muted);
}

.newsletter-input:focus {
  outline: none;
  border-color: var(--amber);
  box-shadow: 0 0 0 3px rgba(249,181,19,0.25);
}

.newsletter-btn {
  flex-shrink: 0;
  white-space: nowrap;
}

.newsletter-privacy {
  margin-top: var(--space-4);
  font-size: var(--fs-sm);
  color: var(--overlay-light-60);
  line-height: 1.5;
}

.newsletter-privacy a {
  color: var(--overlay-light-70);
  text-decoration: underline;
  /* text-underline-offset: 0.2em; */
}

.newsletter-privacy a:hover {
  color: var(--amber);
}

/* Screen-reader only helper */
.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;
}

@media (max-width: 900px) {
  .newsletter-inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }
}

@media (max-width: 560px) {
  .newsletter-form-row {
    flex-direction: column;
  }

  .newsletter-btn {
    width: 100%;
    text-align: center;
  }
}

/* ----------------------------------------------------------------
   BOOKING CTA BLOCK
   ---------------------------------------------------------------- */
/* ================================================================
   FEATURE SPLIT — Two-col image+body layouts, pills, lists
   ================================================================ */

/* ----------------------------------------------------------------
   FEATURE SPLITS
   ---------------------------------------------------------------- */
.feature-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  min-height: 32.5rem;
  overflow: hidden;
  margin-bottom: var(--space-8);
}
.feature-split.no-rounded-border {
  border-radius: 0;
}

.feature-split-image {
  position: relative;
  overflow: hidden;
}

.feature-split-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease);
}

.feature-split:hover .feature-split-image img {
  transform: scale(1.03);
}

.feature-split-body {
  padding: var(--space-16) var(--space-12);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: var(--space-5);
  /* background-color: var(--cream-warm); */
}

.feature-split.bg-forest .feature-split-body {
  background-color: var(--forest-dark);
}

.feature-split.bg-forest .feature-split-body h2,
.feature-split.bg-forest .feature-split-body h3 { color: var(--text-on-dark); }
.feature-split.bg-forest .feature-split-body p { color: var(--overlay-light-80); }
.feature-split.bg-forest .feature-split-body a:not(.btn) { color: var(--amber-bright); }
.feature-split.bg-forest .feature-split-body a:not(.btn):hover { color: var(--amber-wash); }
.feature-split.bg-forest .feature-split-body .section-label { color: var(--amber-bright); }

.feature-split-body > p + * {
  margin-top: 0;
}

.feature-split-body .section-label {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.feature-split-actions {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

/* Image-dominant split: 60/40 */

/* ----------------------------------------------------------------
   ATTRACTION PILLS
   ---------------------------------------------------------------- */
.feature-attractions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.feature-attraction-pill {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  background-color: var(--forest-wash);
  border-radius: var(--radius-sm);
  padding: 0.3rem 0.75rem;
  font-size: var(--fs-md);
  font-weight: 500;
  color: var(--forest-dark);
}

.feature-split.bg-forest .feature-attraction-pill {
  background-color: var(--overlay-light-10);
  color: var(--overlay-light-90);
}

/* ----------------------------------------------------------------
   CHECK LIST
   ---------------------------------------------------------------- */
.check-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.check-list li {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-size: var(--fs-md);
  color: var(--text-warm);
}

.check-list li svg {
  width: 1.125rem;
  height: 1.125rem;
  flex-shrink: 0;
  stroke: var(--amber-deep);
}

.feature-split.bg-forest .check-list li { color: var(--overlay-light-85); }
.feature-split.bg-forest .check-list li svg { stroke: var(--amber-bright); }

/* ----------------------------------------------------------------
   FEATURE LIST
   ---------------------------------------------------------------- */
.feature-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.feature-list li {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-md);
  color: var(--text-warm);
}

.feature-split.bg-forest .feature-list li { color: var(--overlay-light-85); }

.feature-list li svg {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: var(--amber-deep);
}

.feature-split.bg-forest .feature-list li svg { color: var(--amber-bright); }

/* AGB note inside feature-split */


@media (max-width: 900px) {
  .feature-split {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .feature-split-image {
    height: 17.5rem;
  }

  .feature-split-body {
    padding: var(--space-10) var(--space-8);
  }
}/* ================================================================
   GALLERY — Photo gallery (asymmetric grid)
   ================================================================ */
/* ================================================================
   HOTEL — Extras grid, features row, hotel highlights, gallery two-up
   ================================================================ */

/* ----------------------------------------------------------------
   EXTRAS GRID (hotel extras)
   ---------------------------------------------------------------- */
.extras-grid {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-6);
}

.extra-item {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  background: var(--cream-warm);
  border-radius: var(--radius-lg);
  padding: var(--space-5) var(--space-6);
  border: 1px solid var(--cream-border);
}

/* .extra-icon {
  width: 2.75rem;
  height: 2.75rem;
  background: var(--amber-pale);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
} */

.extra-icon svg {
  width: 2rem;
  height: 2rem;
  stroke: var(--amber-deep);
  fill: none;
}

.extra-info {
  flex: 1;
}

.extra-info p {
  margin-top: var(--space-1);
  /* font-size: var(--fs-base); */
  /* color: var(--text-muted); */
}

.extra-price {
  font-family: var(--font-body);
  font-size: var(--fs-xl);
  font-weight: 700;
  flex-shrink: 0;
  white-space: nowrap;
}

.extra-price-unit {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 400;
  color: var(--text-muted);
}

/* ----------------------------------------------------------------
   FEATURES ROW (hotel/restaurant intro icons)
   ---------------------------------------------------------------- */

/* ----------------------------------------------------------------
   HOTEL HIGHLIGHTS — asymmetric callout + pills
   ---------------------------------------------------------------- */

/* ----------------------------------------------------------------
   GALLERY TWO-UP
   ---------------------------------------------------------------- */
.gallery-two {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-top: var(--space-8);
}

.gallery-item {
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--cream-warm);
}

.gallery-item img {
  width: 100%;
  height: 18.75rem;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease);
}

.gallery-item:hover img { transform: scale(1.04); }

.gallery-item figcaption {
  padding: var(--space-3) var(--space-4);
  font-size: var(--fs-sm);
  color: var(--text-muted);
  font-style: italic;
}

@media (max-width: 640px) {
  .gallery-two { grid-template-columns: 1fr; }
  .gallery-item img { height: 13.75rem; }
}

/* ----------------------------------------------------------------
   ROOM TEASER GRID (homepage hotel preview)
   ---------------------------------------------------------------- */
.room-teaser-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-top: var(--space-6);
}

.room-teaser {
  background-color: var(--cream);
  border: 1px solid var(--cream-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  text-align: center;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.room-teaser-price {
  font-family: var(--font-body);
  font-size: var(--fs-3xl);
  font-weight: 700;
  color: var(--forest-dark);
  line-height: 1;
  margin-top: var(--space-3);
}

.room-teaser-price small {
  display: block;
  font-size: var(--fs-xs);
  font-weight: 400;
  color: var(--text-muted);
  margin-top: var(--space-1);
  letter-spacing: 0.02em;
}

.room-teaser-name {
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--text-warm);
}

/* ----------------------------------------------------------------
   ROOM CARDS (hotel page)
   ---------------------------------------------------------------- */

.room-card {
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform var(--duration-mid) var(--ease),
              box-shadow var(--duration-mid) var(--ease);
}

.room-card:hover {
  transform: translateY(-0.25rem);
  box-shadow: var(--shadow-lg);
}

.room-card-image {
  height: 15rem;
  overflow: hidden;
  position: relative;
}

.room-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--ease);
}

.room-card:hover .room-card-image img {
  transform: scale(1.05);
}

.room-card-body {
  padding: var(--space-6);
  flex: 1;
  display: flex;
  flex-direction: column;
}

.room-card-body h3 {
  margin-bottom: var(--space-2);
}

.room-card-body p {
  color: var(--text-warm);
  font-size: var(--fs-md);
  flex: 1;
  margin-bottom: var(--space-5);
}

/* ----------------------------------------------------------------
   AMENITIES
   ---------------------------------------------------------------- */

/* ----------------------------------------------------------------
   ROOM CARDS — supplementary layout
   ---------------------------------------------------------------- */
.room-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.room-card-header {
  display: flex;
  flex-direction: column;;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.room-desc {
  font-size: var(--fs-md);
  color: var(--text-warm);
  margin-bottom: var(--space-5);
  flex: 1;
}

.room-amenities {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-6);
}

.room-amenities li {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--fs-md);
  color: var(--text-warm);
}

.room-amenities li svg {
  width: 1.5rem;
  height: 1.5rem;
  flex-shrink: 0;
  color: var(--amber-deep);
}

.room-card-featured {
  border: 0.125rem solid var(--amber);
}

.room-card-badge-top {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  background: var(--amber);
  color: var(--text-on-amber);
  font-size: var(--fs-base);
  font-weight: 700;
  padding: 0.2rem 0.65rem;
  border-radius: var(--radius-full);
  letter-spacing: 0.04em;
}
/* ================================================================
   INFO — Callout boxes, info banner, info grid
   ================================================================ */

/* ----------------------------------------------------------------
   INFO CALLOUT BOX
   ---------------------------------------------------------------- */

/* ----------------------------------------------------------------
   STARS RATING
   ---------------------------------------------------------------- */
.star-rating {
  display: flex;
  gap: 0.1875rem;
  color: var(--amber);
}

.star-rating svg {
  width: 1.125rem;
  height: 1.125rem;
  fill: currentColor;
}

/* ----------------------------------------------------------------
   INFO BANNER (1-row CTA strip)
   ---------------------------------------------------------------- */

/* ----------------------------------------------------------------
   INFO GRID (2-2 callout boxes)
   ---------------------------------------------------------------- */
/* ================================================================
   PRICING — Price tables, price section cards, price rows
   ================================================================ */

/* ----------------------------------------------------------------
   PRICE SECTION HEADINGS
   ---------------------------------------------------------------- */
.price-section h3 {
  font-size: var(--fs-4xl);
  margin-bottom: var(--space-6);
  padding-bottom: var(--space-4);
  border-bottom: 0.125rem solid var(--cream-border);
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.price-section h3 svg {
  width: 2rem;
  height: 2rem;
  stroke: var(--amber-deep);
  fill: none;
}

.price-subsection h4 {
  font-size: var(--fs-lg);
  color: var(--forest-dark);
  margin-bottom: var(--space-4);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* ----------------------------------------------------------------
   PRICE TABLE
   ---------------------------------------------------------------- */
.price-table {
  width: 100%;
  background-color: var(--cream-warm);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  border-bottom: 1px solid var(--cream-border);
  gap: var(--space-4);
}

.price-row:last-child {
  border-bottom: none;
}

.price-row:nth-child(even) {
  background-color: var(--overlay-light-50);
}

.price-row-label {
  font-weight: 500;
  color: var(--text-warm);
  flex: 1;
}

.price-row-note {
  font-size: var(--fs-base);
  color: var(--text-muted);
  flex: 1;
  text-align: center;
}

.price-row-amount {
  font-family: var(--font-heading);
  font-size: var(--fs-xl);
  font-weight: 700;
  color: var(--text-deep);
  min-width: 5rem;
  text-align: right;
}

.price-row-amount.highlight {
  color: var(--amber-deep);
}

.price-table--sans .price-row-amount {
  font-family: var(--font-body);
}


/* ----------------------------------------------------------------
   PRICE CHIP
   ---------------------------------------------------------------- */
.price-chip {
  display: inline-flex;
  align-items: baseline;
  gap: var(--space-1);
  background-color: var(--amber-pale);
  border-radius: var(--radius-md);
  padding: 0.375rem 1rem;
  border: 1px solid var(--amber);
}

.price-chip .price-amount {
  font-family: var(--font-body);
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--amber-deep);
}

.price-chip .price-unit {
  font-size: var(--fs-base);
  color: var(--bark-mid);
}

.price-chip.unstyled {
  padding: 0;
  border: none;
  background-color: transparent;
}

.price-chip.unstyled .price-amount,
.price-chip.unstyled .price-unit {
  color: unset;
}/* ---- Prose content ---- */
.prose {
	min-width: 0; /* prevent grid blowout */
}

.prose-section {
	padding-top: var(--space-10);
	margin-top: var(--space-10);
	border-top: 1px solid var(--cream-border);
}

.prose-section > * + * {
	margin-top: var(--space-6);
}

.prose-section:first-child {
	padding-top: 0;
	margin-top: 0;
	border-top: none;
}

.prose h2 {
	font-family: var(--font-heading);
	font-size: var(--fs-h3);
	color: var(--text-deep);
	margin-bottom: var(--space-5);
	line-height: 1.25;
}

.prose h2 .section-number {
	display: block;
	font-family: var(--font-body);
	font-size: var(--fs-sm);
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--amber-deep);
	margin-bottom: var(--space-2);
}

.prose h3 {
	font-family: var(--font-body);
	font-size: var(--fs-lg);
	font-weight: 600;
	color: var(--text-deep);
	margin-top: var(--space-8);
	margin-bottom: var(--space-3);
}

.prose p {
	font-size: var(--fs-body);
	line-height: 1.8;
	color: var(--text-warm);
	margin-bottom: var(--space-5);
	/* max-width: 68ch; */
}

.prose p:last-child {
	margin-bottom: 0;
}

.prose ul,
.prose ol {
	padding-left: var(--space-6);
	margin-bottom: var(--space-5);
}

.prose li {
	font-size: var(--fs-body);
	line-height: 1.8;
	color: var(--text-warm);
	margin-bottom: var(--space-2);
	max-width: 68ch;
}

.prose ul li::marker {
	color: var(--forest-mid);
}

.prose ol li::marker {
	color: var(--text-muted);
	font-weight: 600;
}

.prose a {
	color: var(--forest-mid);
	text-decoration: underline;
	text-decoration-color: var(--forest-pale);
	text-underline-offset: 3px;
	transition: color var(--duration-fast) var(--ease),
				text-decoration-color var(--duration-fast) var(--ease);
}

.prose a:hover {
	color: var(--forest-dark);
	text-decoration-color: var(--forest-mid);
}

.prose strong {
	color: var(--text-deep);
}

/* Callout / note box */
.prose-note {
	background-color: var(--forest-wash);
	border-left: 3px solid var(--forest-mid);
	border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
	padding: var(--space-5) var(--space-6);
	margin-bottom: var(--space-5);
}

.prose-note p {
	margin-bottom: 0;
	font-size: var(--fs-md);
}

@media (max-width: 640px) {
	.prose h2 {
	font-size: var(--fs-h4);
	}
}/* ================================================================
   RESERVATION — Sidebar, contact list, check-in/out
   ================================================================ */

/* Layout: uses .contact-grid from forms.css (identical grid) */

.reservation-sidebar {
  /* border: 1px solid var(--cream-border); */
  position: sticky;
  top: calc(var(--nav-height) + var(--space-6));
}

.reservation-sidebar h3 {
  font-size: var(--fs-2xl);
  margin-bottom: var(--space-3);
}

.reservation-sidebar > p {
  font-size: var(--fs-md);
  color: var(--text-warm);
  line-height: 1.65;
  /* margin-bottom: var(--space-6); */
}

.reservation-contact-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding-top: var(--space-6);
  border-top: 1px solid var(--cream-border);
  margin-top: var(--space-6);
}

.reservation-contact-item {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--fs-md);
  color: var(--text-warm);
  line-height: 1.5;
}

.reservation-contact-item svg {
  width: 1.125rem;
  height: 1.125rem;
  stroke: var(--amber-deep);
  fill: none;
  flex-shrink: 0;
  margin-top: 0.125rem;
}

.reservation-contact-item a {
  color: var(--forest-dark);
  font-weight: 500;
}

.reservation-contact-item a:hover { color: var(--forest-mid); }

.reservation-checkinout {
  margin-top: var(--space-6);
  padding-top: var(--space-6);
  border-top: 1px solid var(--cream-border);
}

.reservation-checkinout .section-label {
  margin-bottom: var(--space-3);
}

.reservation-checkinout-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.reservation-checkinout-list li {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  font-size: var(--fs-md);
  color: var(--text-warm);
  line-height: 1.45;
}

.reservation-checkinout-list li svg {
  width: 1.125rem;
  height: 1.125rem;
  stroke: var(--amber-deep);
  flex-shrink: 0;
  margin-top: 0.125rem;
}

@media (max-width: 900px) {
  .contact-grid {
    grid-template-columns: 1fr;
  }
  .reservation-sidebar {
    position: static;
  }
  .room-cards { grid-template-columns: 1fr 1fr; }
  .feature-split-body { padding: var(--space-10) var(--space-8); }
}

@media (max-width: 640px) {
  .room-cards { grid-template-columns: 1fr; }
}
/* ================================================================
   SECTION — Season bar, section headers, backgrounds, wave
   ================================================================ */

/* ----------------------------------------------------------------
   SEASON BAR
   ---------------------------------------------------------------- */
.season-bar {
  background-color: var(--amber-pale);
  /* border-bottom: 1px solid var(--amber-pale); */
}

.season-bar-inner {
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
  padding-block: var(--space-4);
}

.season-bar-info {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-6);
  flex-wrap: wrap;
}

.season-bar-item {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-size: var(--fs-md);
  font-weight: 500;
  /* color: var(--text-warm); */
  color: var(--text-on-amber);
  text-align: center;
}

.season-bar-item svg {
  width: 1.125rem;
  height: 1.125rem;
  color: var(--amber-deep);
  flex-shrink: 0;
}

.season-bar-item strong { color: var(--text-deep); }

/* Season bar aliases */




.section-label {
  display: block;
  font-family: var(--font-body);
  font-size: var(--fs-base);
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--forest-mid);
}

.section-label.amber { color: var(--amber); }

/* ----------------------------------------------------------------
   SECTION HEADERS
   ---------------------------------------------------------------- */
.section-header {
  position: relative;
  isolation: isolate;
  margin-bottom: var(--space-12);
  margin-inline: auto;
  font-size: var(--fs-lead);
}

.section-header::before {
  content: '';
  position: absolute;
  top: -1.75rem;
  bottom: -1.25rem;
  max-width: 60vw;
  max-height: 60vw;
  left: -3.25rem;
  background: var(--amber-bright);
  aspect-ratio: 1;
  clip-path: shape(from 8.59% 36.20%,curve to 24.92% 17.45% with 12.01% 22.40%,curve to 49.29% 14.71% with 37.82% 12.51%,curve to 70.08% 22.77% with 60.75% 16.91%,curve to 83.22% 39.31% with 79.41% 28.63%,curve to 83.84% 61.14% with 87.03% 50.00%,curve to 71.68% 80.68% with 80.66% 72.27%,curve to 49.06% 91.98% with 62.70% 89.09%,curve to 25.83% 84.71% with 35.42% 94.88%,curve to 10.70% 62.26% with 16.24% 74.53%,curve to 8.59% 36.20% with 5.17% 50.00%);
  z-index: -1;
  opacity: 0.1;
  pointer-events: none;
}

.bg-forest-wash .section-header::before {
  background: var(--forest-pale);
  opacity: 0.5;
  border-radius: 45% 55% 62% 38% / 48% 52% 45% 55%;
}

.section-header .section-label {
  margin-bottom: var(--space-3);
  font-size: var(--fs-body);
  color: var(--text-warm);
}

.section-header h2 {
  margin-bottom: var(--space-5);
}

.section-header.centered {
  text-align: center;
}

.section-header.centered::before {
  left: 50%;
  translate: -50% 0;
}

.section-header.centered p {
  margin-inline: auto;

  max-width: 50rem;
}

/* Decorative leaf accent */
.leaf-accent {
  display: inline-block;
  width: 3rem;
  height: 0.25rem;
  background-color: var(--forest-mid);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-5);
}

/* Section semantic aliases */

/* ================================================================
   CLOSURE BANNER - Startseite Meldung (Customizer)
   ================================================================ */

.closure-banner {
  background-color: var(--bark-dark);
  color: var(--text-on-dark);
  padding: var(--space-4) 0;
}

.closure-banner-inner {
  display: flex;
  align-items: center;
  gap: var(--space-4);
}

.closure-banner-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  color: var(--amber);
  stroke-linecap: round;
  stroke-linejoin: round;
}

.closure-banner-content {
  flex: 1;
}

.closure-banner-title {
  display: block;
  font-weight: 600;
  font-size: var(--fs-md);
  margin-bottom: var(--space-1);
  color: var(--text-on-dark);
}

.closure-banner-text {
  font-size: var(--fs-base);
  opacity: 0.9;
  margin: 0;
}

@media (max-width: 768px) {
  .closure-banner-inner {
    flex-direction: column;
    text-align: center;
    gap: var(--space-2);
  }
  
  .closure-banner-icon {
    width: 32px;
    height: 32px;
  }
}

/* ================================================================
   CF7 Button Styles - Gold/Pill Shape
   ================================================================ */

.form-footer input[type="submit"].wpcf7-submit,
.form-footer .wpcf7-submit,
.wpcf7-form .wpcf7-submit,
input.wpcf7-submit {
    background-color: #c9a962 !important;
    color: #3d3a35 !important;
    padding: 0.75rem 1.5rem !important;
    border-radius: 9999px !important;
    font-weight: 500 !important;
    border: none !important;
    cursor: pointer !important;
    font-size: 0.875rem !important;
    line-height: 1.5 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 2.5rem !important;
    text-transform: none !important;
}

.form-footer input[type="submit"].wpcf7-submit:hover,
.form-footer .wpcf7-submit:hover {
    background-color: #b8984d !important;
    color: #2a2825 !important;
}
