/* ============================================
   MATTUSCHKA PARADIESGÄRTEN – Brand System
   Streng nach Corporate Design Manual V1.0
   ============================================ */
:root {
  /* MPG Brand Colors */
  --moosgruen: #006930;      /* Primärfarbe */
  --tannengruen: #054432;    /* Sekundärfarbe MPG */
  --aprikot: #f28c5a;        /* Tertiär */
  --sonnengelb: #ffda6f;     /* Tertiär */
  --mintgruen: #8ec89a;      /* Tertiär */
  --tuerkis: #009a93;        /* Tertiär */

  /* Abgeleitete Töne (Abstufungen sind laut Manual erlaubt) */
  --mint-soft: #bdd0b4;   /* etwas dunkler – Hintergrund hinter den Kacheln */
  --mint-paper: #eaf2e6;
  --tannen-deep: #032a20;
  --moss-dark: #00481f;
  --cream: #faf7f0;
  --line: rgba(5, 68, 50, 0.18);

  /* Typography */
  --font-display: 'Cormorant Garamond', 'TAN Gardenia', serif;
  --font-body: 'Manrope', 'Acumin Pro', system-ui, sans-serif;
}

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

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-weight: 400;
  background: var(--mint-soft);
  color: var(--tannengruen);
  line-height: 1.6;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ============================================
   TAN-GARDENIA STYLING – ausschließlich Großbuchstaben
   ============================================ */
.tan, h1.tan, h2.tan, h3.tan {
  font-family: var(--font-body);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: -0.005em;
  line-height: 0.95;
}

/* ============================================
   NAVIGATION
   ============================================ */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  padding: 1.25rem 2.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #043829;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  transition: padding 0.4s ease;
}

.nav.scrolled { padding: 0.75rem 2.5rem; }

.nav-logo {
  display: flex;
  align-items: center;
  text-decoration: none;
  max-height: 50px;
  overflow: hidden;
}

.nav-menu {
  display: flex;
  gap: 2.5rem;
  list-style: none;
}
.nav-menu a {
  color: white;
  text-decoration: none;
  font-size: 0.85rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  position: relative;
  padding: 0.5rem 0;
  transition: color 0.3s;
}
.nav-menu a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 0;
  height: 1px;
  background: var(--mintgruen);
  transition: width 0.4s ease;
}
.nav-menu a:hover { color: var(--mintgruen); }
.nav-menu a:hover::after { width: 100%; }

.nav-cta {
  background: var(--mintgruen);
  color: var(--tannengruen);
  padding: 0.65rem 1.3rem;
  border-radius: 999px;
  text-decoration: none;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  transition: transform 0.3s, background 0.3s;
}
.nav-cta:hover { transform: translateY(-2px); background: var(--mintgruen); color: white; }

.menu-toggle {
  display: none;
  background: none;
  border: none;
  color: white;
  cursor: pointer;
  padding: 0.5rem;
}

/* ============================================
   HERO
   ============================================ */
.hero {
  min-height: 100vh;
  position: relative;
  display: flex;
  align-items: center;
  padding: 8rem 2.5rem 4rem;
  overflow: hidden;
  background: var(--tannengruen);
  color: white;
}

.hero-bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(120deg, rgba(3,42,32,0.92) 0%, rgba(5,68,50,0.78) 50%, rgba(0,105,48,0.55) 100%),
    url('https://images.unsplash.com/photo-1585320806297-9794b3e4eeae?w=2000&q=80');
  background-size: cover;
  background-position: center;
  z-index: 0;
}

.hero-grain {
  position: absolute;
  inset: 0;
  opacity: 0.4;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  z-index: 1;
  pointer-events: none;
}

.hero-content {
  position: relative;
  z-index: 2;
  max-width: 1400px;
  margin: 0 auto;
  width: 100%;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 4rem;
  align-items: center;
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--mintgruen);
  margin-bottom: 2rem;
}
.hero-eyebrow::before {
  content: '';
  width: 32px;
  height: 1px;
  background: var(--mintgruen);
}

.hero h1 {
  font-family: var(--font-body);
  font-weight: 400;
  font-size: clamp(3rem, 9vw, 8.5rem);
  line-height: 0.92;
  text-transform: uppercase;
  letter-spacing: -0.01em;
  margin-bottom: 2rem;
}
.hero h1 .highlight {
  font-style: italic;
  color: var(--mintgruen);
  font-weight: 400;
}
.hero h1 .ampersand {
  font-weight: 300;
  font-style: italic;
  color: var(--mintgruen);
}

.hero-lead {
  font-size: 1.15rem;
  line-height: 1.7;
  max-width: 540px;
  color: rgba(255,255,255,0.85);
  margin-bottom: 2.5rem;
  font-weight: 300;
}

.hero-actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 2rem;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
  font-size: 0.9rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  transition: all 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
  border: none;
  font-family: var(--font-body);
}
.btn-primary {
  background: var(--mintgruen);
  color: var(--tannengruen);
}
.btn-primary:hover {
  background: white;
  color: var(--tannengruen);
  transform: translateY(-3px);
  box-shadow: 0 12px 30px rgba(142, 200, 154, 0.3);
}
.btn-ghost {
  background: transparent;
  color: white;
  border: 1px solid rgba(255,255,255,0.4);
}
.btn-ghost:hover {
  background: white;
  color: var(--tannengruen);
  border-color: white;
}
.btn-dark {
  background: var(--tannengruen);
  color: white;
}
.btn-dark:hover { background: var(--moosgruen); transform: translateY(-3px); }

.hero-card {
  position: relative;
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 24px;
  padding: 2.5rem;
  color: white;
}
.hero-card-label {
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--mintgruen);
  margin-bottom: 1rem;
}
.hero-card h3 {
  font-family: var(--font-body);
  font-weight: 500;
  text-transform: uppercase;
  font-size: 2rem;
  line-height: 1;
  margin-bottom: 1.25rem;
}
.hero-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 2rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(255,255,255,0.15);
}
.hero-stat .num {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 2.6rem;
  color: var(--mintgruen);
  line-height: 1;
  text-transform: uppercase;
}
.hero-stat .lbl {
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin-top: 0.4rem;
}

.scroll-hint {
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
  color: rgba(255,255,255,0.6);
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}
.scroll-hint .line {
  width: 1px;
  height: 40px;
  background: linear-gradient(180deg, transparent, var(--mintgruen));
  animation: scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%, 100% { opacity: 0.3; transform: scaleY(0.6); transform-origin: top; }
  50% { opacity: 1; transform: scaleY(1); transform-origin: top; }
}

/* ============================================
   SECTION SHELL
   ============================================ */
.section {
  padding: 8rem 2.5rem;
  position: relative;
}
.container {
  max-width: 1400px;
  margin: 0 auto;
}
.section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 4rem;
  gap: 3rem;
  flex-wrap: wrap;
}
.section-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--moosgruen);
  margin-bottom: 1.25rem;
}
.section-eyebrow::before {
  content: '';
  width: 28px; height: 1px;
  background: var(--moosgruen);
}
.section h2 {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: clamp(2.5rem, 6vw, 5rem);
  line-height: 0.95;
  text-transform: uppercase;
  color: var(--tannengruen);
  letter-spacing: -0.01em;
  max-width: 850px;
}
.section h2 .italic {
  font-style: italic;
  font-weight: 400;
  color: var(--moosgruen);
}

.section-intro {
  max-width: 380px;
  font-size: 1rem;
  color: var(--tannengruen);
  opacity: 0.75;
  line-height: 1.7;
}

/* ============================================
   PHILOSOPHIE
   ============================================ */
.philosophy {
  background: var(--mint-paper);
  text-align: center;
  padding: 7rem 2.5rem;
}
.philosophy-quote {
  font-family: var(--font-body);
  font-weight: 400;
  text-transform: uppercase;
  font-size: clamp(2.2rem, 5.5vw, 4.5rem);
  line-height: 1;
  color: var(--moosgruen);
  max-width: 1100px;
  margin: 0 auto 2rem;
  letter-spacing: -0.005em;
}
.philosophy-quote .italic {
  font-style: italic;
  color: var(--tannengruen);
}
.philosophy-attr {
  font-size: 0.8rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--tannengruen);
  opacity: 0.6;
}

/* ============================================
   SERVICES OVERVIEW – Tabs
   ============================================ */
.services-tabs {
  display: flex;
  gap: 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-bottom: 4rem;
  overflow-x: auto;
  scrollbar-width: none;
}
.services-tabs::-webkit-scrollbar { display: none; }

.service-tab {
  flex: 1;
  min-width: 240px;
  background: none;
  border: none;
  border-right: 1px solid var(--line);
  padding: 2rem 1.5rem;
  text-align: left;
  cursor: pointer;
  font-family: var(--font-body);
  color: var(--tannengruen);
  transition: all 0.4s ease;
  position: relative;
}
.service-tab:last-child { border-right: none; }
.service-tab::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 3px;
  background: var(--moosgruen);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s ease;
}
.service-tab.active::before,
.service-tab:hover::before { transform: scaleX(1); }
.service-tab.active { background: var(--moosgruen); color: white; }
.service-tab .num {
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  opacity: 0.6;
  margin-bottom: 0.5rem;
  display: block;
}
.service-tab .name {
  font-family: var(--font-body);
  text-transform: uppercase;
  font-size: 1.4rem;
  font-weight: 500;
  line-height: 1;
}

/* ============================================
   SERVICE BLOCK (large)
   ============================================ */
.service-block {
  padding: 8rem 2.5rem;
  background: var(--cream);
  position: relative;
  overflow: hidden;
}
.service-block.dark {
  background: var(--tannengruen);
  color: white;
}
.service-block.moss { background: var(--moosgruen); color: white; }
.service-block.mint { background: var(--mint-paper); }

.service-grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
}
.service-grid.reverse { direction: rtl; }
.service-grid.reverse > * { direction: ltr; }

.service-visual {
  position: relative;
  aspect-ratio: 4/5;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,0.15);
}
.service-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.2s cubic-bezier(0.2, 0.9, 0.3, 1);
}
.service-visual:hover img { transform: scale(1.05); }

.service-visual .overlay-badge {
  position: absolute;
  top: 1.5rem;
  left: 1.5rem;
  background: rgba(255,255,255,0.9);
  backdrop-filter: blur(10px);
  padding: 0.6rem 1.2rem;
  border-radius: 999px;
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--tannengruen);
  font-weight: 600;
}

.service-num {
  font-family: var(--font-body);
  font-size: 5rem;
  font-weight: 400;
  font-style: italic;
  color: var(--mintgruen);
  line-height: 1;
  margin-bottom: 1rem;
  text-transform: uppercase;
}
.service-block.dark .service-num,
.service-block.moss .service-num {
  color: var(--mintgruen);
}

.service-content h3 {
  font-family: var(--font-body);
  font-weight: 500;
  text-transform: uppercase;
  font-size: clamp(2.2rem, 4vw, 3.8rem);
  line-height: 0.95;
  margin-bottom: 1.5rem;
  letter-spacing: -0.005em;
}
.service-block:not(.dark):not(.moss) .service-content h3 { color: var(--tannengruen); }

.service-content p {
  font-size: 1.05rem;
  line-height: 1.7;
  margin-bottom: 2rem;
  opacity: 0.85;
  max-width: 540px;
}

/* ============================================
   INTERACTIVE TOGGLES – Dachbegrünung
   ============================================ */
.dach-switch {
  display: flex;
  gap: 0;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 999px;
  padding: 4px;
  margin-bottom: 2rem;
  width: fit-content;
}
.dach-switch button {
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.7);
  padding: 0.7rem 1.6rem;
  border-radius: 999px;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: all 0.4s ease;
}
.dach-switch button.active {
  background: var(--mintgruen);
  color: white;
}

.dach-features {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin: 2rem 0;
}
.dach-feat {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.12);
  padding: 1.25rem;
  border-radius: 12px;
  transition: all 0.5s ease;
}
.dach-feat .label {
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--mintgruen);
  margin-bottom: 0.35rem;
}
.dach-feat .value {
  font-family: var(--font-body);
  font-size: 1.6rem;
  text-transform: uppercase;
  font-weight: 500;
  color: white;
  line-height: 1;
}

/* ============================================
   TERRASSE – Feature configurator
   ============================================ */
.terrasse-config {
  background: var(--cream);
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 2rem;
  margin-top: 2rem;
}
.terrasse-config-title {
  font-size: 0.8rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--moosgruen);
  font-weight: 700;
  margin-bottom: 1.5rem;
}
.terrasse-options {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
.terrasse-option {
  padding: 1.25rem;
  border: 2px solid var(--line);
  border-radius: 14px;
  background: white;
  cursor: pointer;
  transition: all 0.35s ease;
  display: flex;
  gap: 1rem;
  align-items: center;
}
.terrasse-option:hover { border-color: var(--moosgruen); }
.terrasse-option.active {
  border-color: var(--moosgruen);
  background: var(--mint-paper);
}
.terrasse-option .icon {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--mint-paper);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--moosgruen);
  transition: all 0.35s ease;
}
.terrasse-option.active .icon {
  background: var(--moosgruen);
  color: white;
}
.terrasse-option .opt-name {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--tannengruen);
  margin-bottom: 0.15rem;
}
.terrasse-option .opt-desc {
  font-size: 0.78rem;
  color: var(--tannengruen);
  opacity: 0.6;
  line-height: 1.4;
}
.terrasse-summary {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}
.terrasse-summary .label {
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--tannengruen);
  opacity: 0.7;
}
.terrasse-summary .price {
  font-family: var(--font-body);
  font-size: 2rem;
  font-weight: 500;
  color: var(--moosgruen);
  text-transform: uppercase;
  line-height: 1;
}

/* ============================================
   INDOOR – plant grid + room toggle
   ============================================ */
.indoor-toggle {
  display: inline-flex;
  background: var(--mint-paper);
  border-radius: 999px;
  padding: 4px;
  margin-bottom: 2rem;
}
.indoor-toggle button {
  background: transparent;
  border: none;
  padding: 0.7rem 1.6rem;
  border-radius: 999px;
  cursor: pointer;
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--tannengruen);
  transition: all 0.4s ease;
  font-family: var(--font-body);
}
.indoor-toggle button.active {
  background: var(--moosgruen);
  color: white;
}

.plant-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.75rem;
  margin-top: 2rem;
}
.plant-card {
  aspect-ratio: 1;
  border-radius: 14px;
  background: var(--mint-paper);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  text-align: center;
  cursor: pointer;
  transition: all 0.4s ease;
  border: 1px solid transparent;
}
.plant-card:hover {
  transform: translateY(-4px);
  border-color: var(--moosgruen);
  box-shadow: 0 12px 30px rgba(0,105,48,0.12);
}
.plant-card .leaf {
  font-size: 2.2rem;
  margin-bottom: 0.5rem;
  filter: drop-shadow(0 4px 8px rgba(0,105,48,0.2));
}
.plant-card .name {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--tannengruen);
  line-height: 1.2;
}
.plant-card .tag {
  font-size: 0.65rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--moosgruen);
  margin-top: 0.3rem;
}

/* ============================================
   ROLLRASEN CALCULATOR – the star
   ============================================ */
.calc-section {
  background: linear-gradient(180deg, var(--tannengruen) 0%, var(--moss-dark) 100%);
  color: white;
  padding: 8rem 2.5rem;
  position: relative;
  overflow: hidden;
}
.calc-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 400' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
  opacity: 0.15;
  pointer-events: none;
}
.calc-section .container { position: relative; z-index: 1; }

.calc-section .section-eyebrow {
  color: var(--mintgruen);
}
.calc-section .section-eyebrow::before {
  background: var(--mintgruen);
}
.calc-section h2 { color: white; }
.calc-section h2 .italic { color: var(--mintgruen); }
.calc-section .section-intro { color: rgba(255,255,255,0.7); }

.calc-wrapper {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 3rem;
  margin-top: 3rem;
  align-items: start;
}

.calc-card {
  background: rgba(255,255,255,0.05);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 24px;
  padding: 2.5rem;
}

.calc-steps {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 2rem;
}
.calc-step-dot {
  flex: 1;
  height: 4px;
  background: rgba(255,255,255,0.15);
  border-radius: 999px;
  position: relative;
  overflow: hidden;
}
.calc-step-dot.done { background: var(--mintgruen); }
.calc-step-dot.active::after {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--mintgruen);
  animation: stepFill 0.6s ease forwards;
}
@keyframes stepFill {
  from { transform: scaleX(0); transform-origin: left; }
  to { transform: scaleX(1); transform-origin: left; }
}

.calc-step-label {
  font-size: 0.75rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--mintgruen);
  margin-bottom: 0.75rem;
}
.calc-step-title {
  font-family: var(--font-body);
  font-size: 2rem;
  font-weight: 500;
  text-transform: uppercase;
  margin-bottom: 2rem;
  line-height: 1;
}

.calc-input-row {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 1rem;
  margin-bottom: 1.25rem;
}
.calc-field { display: flex; flex-direction: column; }
.calc-field label {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
  margin-bottom: 0.5rem;
}
.calc-field input,
.calc-field select {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 10px;
  padding: 0.9rem 1rem;
  color: white;
  font-family: var(--font-body);
  font-size: 1rem;
  transition: border 0.3s;
}
.calc-field input::placeholder { color: rgba(255,255,255,0.4); }
.calc-field input:focus,
.calc-field select:focus {
  outline: none;
  border-color: var(--mintgruen);
}
.calc-field select option { background: var(--tannengruen); color: white; }

.qm-slider-wrap {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 14px;
  padding: 1.25rem;
  margin-bottom: 1.5rem;
}
.qm-slider-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 0.75rem;
}
.qm-slider-head .lbl {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.7);
}
.qm-slider-head .val {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 2rem;
  color: var(--mintgruen);
  text-transform: uppercase;
  line-height: 1;
}
.qm-slider-head .val span { font-size: 0.85rem; opacity: 0.7; }

input[type=range] {
  -webkit-appearance: none;
  width: 100%;
  background: transparent;
  cursor: pointer;
}
input[type=range]::-webkit-slider-runnable-track {
  height: 6px;
  background: linear-gradient(90deg, var(--mintgruen) 0%, var(--mintgruen) var(--fill, 50%), rgba(255,255,255,0.15) var(--fill, 50%));
  border-radius: 999px;
}
input[type=range]::-moz-range-track {
  height: 6px;
  background: rgba(255,255,255,0.15);
  border-radius: 999px;
}
input[type=range]::-moz-range-progress {
  height: 6px;
  background: var(--mintgruen);
  border-radius: 999px;
}
input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: white;
  border: 3px solid var(--mintgruen);
  margin-top: -8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
  transition: transform 0.2s;
}
input[type=range]::-webkit-slider-thumb:hover { transform: scale(1.15); }
input[type=range]::-moz-range-thumb {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: white;
  border: 3px solid var(--mintgruen);
  cursor: pointer;
}

.qm-presets {
  display: flex;
  gap: 0.5rem;
  margin-top: 1rem;
  flex-wrap: wrap;
}
.qm-preset {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  color: white;
  padding: 0.4rem 0.85rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 500;
  cursor: pointer;
  font-family: var(--font-body);
  transition: all 0.3s;
}
.qm-preset:hover, .qm-preset.active {
  background: var(--mintgruen);
  color: var(--tannengruen);
  border-color: var(--mintgruen);
  font-weight: 700;
}

/* Rasen type selector */
.rasen-types {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-top: 1rem;
}
.rasen-type {
  background: rgba(255,255,255,0.05);
  border: 2px solid rgba(255,255,255,0.12);
  border-radius: 14px;
  padding: 1.25rem 1rem;
  cursor: pointer;
  transition: all 0.35s;
  text-align: left;
  color: white;
  font-family: var(--font-body);
}
.rasen-type:hover { border-color: rgba(142,200,154,0.5); }
.rasen-type.active {
  border-color: var(--mintgruen);
  background: rgba(142,200,154,0.1);
}
.rasen-type .rt-name {
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 1.2rem;
  text-transform: uppercase;
  margin-bottom: 0.35rem;
  line-height: 1;
}
.rasen-type .rt-desc {
  font-size: 0.75rem;
  opacity: 0.7;
  line-height: 1.4;
  margin-bottom: 0.6rem;
}
.rasen-type .rt-price {
  font-size: 0.8rem;
  color: var(--mintgruen);
  font-weight: 700;
  letter-spacing: 0.05em;
}

/* Result panel */
.calc-result {
  background: white;
  color: var(--tannengruen);
  border-radius: 24px;
  padding: 2.5rem;
  position: sticky;
  top: 100px;
}
.calc-result-head {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}
.calc-result-head .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--moosgruen);
  animation: pulse 2s infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(0,105,48,0.4); }
  50% { box-shadow: 0 0 0 8px rgba(0,105,48,0); }
}
.calc-result-head .label {
  font-size: 0.7rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--moosgruen);
  font-weight: 700;
}

.result-price {
  font-family: var(--font-body);
  font-weight: 500;
  text-transform: uppercase;
  font-size: clamp(2.5rem, 5vw, 4rem);
  color: var(--tannengruen);
  line-height: 1;
  margin-bottom: 0.4rem;
  letter-spacing: -0.01em;
}
.result-price small {
  font-size: 0.5em;
  color: var(--moosgruen);
  font-style: italic;
}
.result-disclaimer {
  font-size: 0.78rem;
  color: var(--tannengruen);
  opacity: 0.55;
  line-height: 1.5;
  margin-bottom: 1.75rem;
}

.result-breakdown {
  background: var(--mint-paper);
  border-radius: 14px;
  padding: 1.25rem;
  margin-bottom: 1.5rem;
}
.breakdown-row {
  display: flex;
  justify-content: space-between;
  padding: 0.5rem 0;
  font-size: 0.88rem;
  border-bottom: 1px dashed var(--line);
}
.breakdown-row:last-child { border-bottom: none; padding-top: 0.75rem; font-weight: 700; }
.breakdown-row .lbl { color: var(--tannengruen); opacity: 0.75; }
.breakdown-row .val { color: var(--tannengruen); font-weight: 600; }

.result-contact-form {
  border-top: 1px solid var(--line);
  padding-top: 1.5rem;
}
.result-contact-form h4 {
  font-family: var(--font-body);
  text-transform: uppercase;
  font-size: 1.2rem;
  font-weight: 500;
  margin-bottom: 1rem;
  color: var(--tannengruen);
}
.contact-input {
  width: 100%;
  background: var(--mint-paper);
  border: 1px solid transparent;
  border-radius: 10px;
  padding: 0.85rem 1rem;
  font-family: var(--font-body);
  font-size: 0.95rem;
  color: var(--tannengruen);
  margin-bottom: 0.6rem;
  transition: border 0.3s;
}
.contact-input:focus {
  outline: none;
  border-color: var(--moosgruen);
}
.btn-send {
  width: 100%;
  background: var(--moosgruen);
  color: white;
  padding: 1rem;
  border: none;
  border-radius: 999px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 0.85rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.3s;
  margin-top: 0.5rem;
}
.btn-send:hover {
  background: var(--tannengruen);
  transform: translateY(-2px);
}

.success-msg {
  background: var(--mintgruen);
  color: var(--tannengruen);
  padding: 1rem;
  border-radius: 10px;
  font-size: 0.9rem;
  margin-top: 1rem;
  text-align: center;
  font-weight: 600;
  display: none;
}
.success-msg.show { display: block; animation: slideIn 0.5s ease; }
@keyframes slideIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ============================================
   CONTACT
   ============================================ */
.contact {
  background: var(--mint-paper);
  padding: 8rem 2.5rem;
}
.contact-grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: start;
}
.contact-info h2 {
  margin-bottom: 2rem;
}
.contact-list {
  list-style: none;
  margin-top: 2.5rem;
}
.contact-list li {
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--line);
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 2rem;
  align-items: center;
}
.contact-list .lbl {
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--moosgruen);
  font-weight: 700;
}
.contact-list .val {
  font-size: 1.05rem;
  color: var(--tannengruen);
}
.contact-list a {
  color: var(--tannengruen);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border 0.3s;
}
.contact-list a:hover { border-color: var(--moosgruen); }

.map-card {
  background: var(--tannengruen);
  border-radius: 24px;
  padding: 2.5rem;
  color: white;
  position: relative;
  overflow: hidden;
  aspect-ratio: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.map-card::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -30%;
  width: 100%;
  height: 100%;
  background: radial-gradient(circle, var(--moosgruen) 0%, transparent 70%);
  opacity: 0.4;
}
.map-card-top { position: relative; z-index: 1; }
.map-card-top .eye {
  font-size: 0.72rem;
  letter-spacing: 0.25em;
  color: var(--mintgruen);
  text-transform: uppercase;
  margin-bottom: 1rem;
}
.map-card-top h3 {
  font-family: var(--font-body);
  text-transform: uppercase;
  font-size: 2.5rem;
  font-weight: 500;
  line-height: 0.95;
}
.map-card-bottom { position: relative; z-index: 1; }
.map-card-bottom .city {
  font-family: var(--font-body);
  font-size: 4.5rem;
  font-weight: 500;
  text-transform: uppercase;
  color: var(--mintgruen);
  line-height: 0.9;
  font-style: italic;
}
.map-card-bottom .country {
  font-size: 0.85rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  opacity: 0.7;
  margin-top: 0.5rem;
}

/* ============================================
   FOOTER
   ============================================ */
.footer {
  background: var(--tannengruen);
  color: white;
  padding: 5rem 2.5rem 2rem;
}
.footer-grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid rgba(255,255,255,0.12);
}
.footer-brand .footer-logo {
  height: 60px;
  width: auto;
  display: block;
  margin-bottom: 1.5rem;
}
.footer-brand p {
  font-size: 0.9rem;
  line-height: 1.7;
  opacity: 0.75;
  max-width: 320px;
}
.footer-col h5 {
  font-size: 0.75rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mintgruen);
  margin-bottom: 1.25rem;
  font-weight: 700;
}
.footer-col ul { list-style: none; }
.footer-col li { margin-bottom: 0.6rem; }
.footer-col a {
  color: white;
  text-decoration: none;
  opacity: 0.75;
  font-size: 0.9rem;
  transition: opacity 0.3s;
}
.footer-col a:hover { opacity: 1; color: var(--mintgruen); }
.footer-bottom {
  max-width: 1400px;
  margin: 2rem auto 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.78rem;
  opacity: 0.6;
  flex-wrap: wrap;
  gap: 1rem;
}

/* ============================================
   ANIMATIONS – fade in on scroll
   ============================================ */
.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.9s ease, transform 0.9s cubic-bezier(0.2, 0.9, 0.3, 1);
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}
.reveal.delay-1 { transition-delay: 0.1s; }
.reveal.delay-2 { transition-delay: 0.2s; }
.reveal.delay-3 { transition-delay: 0.3s; }

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 1024px) {
  .hero-content { grid-template-columns: 1fr; gap: 3rem; }
  .service-grid { grid-template-columns: 1fr; gap: 3rem; }
  .service-grid.reverse { direction: ltr; }
  .calc-wrapper { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .plant-grid { grid-template-columns: repeat(3, 1fr); }
  .map-card { aspect-ratio: 16/9; }
  .calc-result { position: relative; top: 0; }
}

@media (max-width: 720px) {
  .nav { padding: 0.6rem 1.25rem; }
  .nav-logo img { height: 30px !important; }
  .nav-menu { display: none; }
  .menu-toggle { display: block; }
  .nav.menu-open .nav-menu {
    display: flex;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #043829;
    flex-direction: column;
    padding: 1.5rem;
    gap: 1.25rem;
    border-top: 1px solid rgba(255,255,255,0.08);
  }
  .nav-cta { display: none; }
  .hero { padding: 7rem 1.25rem 4rem; min-height: auto; }
  .section { padding: 5rem 1.25rem; }
  .service-block { padding: 5rem 1.25rem; }
  .calc-section { padding: 5rem 1.25rem; }
  .contact { padding: 5rem 1.25rem; }
  .calc-card { padding: 1.5rem; }
  .calc-result { padding: 1.75rem; }
  .calc-input-row { grid-template-columns: 1fr; }
  .rasen-types { grid-template-columns: 1fr; }
  .dach-features { grid-template-columns: 1fr; }
  .terrasse-options { grid-template-columns: 1fr; }
  .plant-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  .contact-list li { grid-template-columns: 1fr; gap: 0.4rem; padding: 1.25rem 0; }
  .services-tabs { flex-direction: column; }
  .service-tab { border-right: none; border-bottom: 1px solid var(--line); }
  .section-header { flex-direction: column; align-items: flex-start; gap: 1.5rem; }
  .hero-stats { grid-template-columns: 1fr; }
  .map-card-bottom .city { font-size: 3rem; }
}

/* ============================================
   NEW: TRUST STRIP
   ============================================ */
.trust-strip {
  background: var(--moosgruen);
  color: white;
  padding: 2.5rem 2.5rem;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.trust-grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
}
.trust-item {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.trust-item svg {
  flex-shrink: 0;
  opacity: 0.85;
  color: var(--mintgruen);
}
.trust-title {
  font-family: var(--font-body);
  text-transform: uppercase;
  font-size: 1.35rem;
  font-weight: 500;
  line-height: 1;
}
.trust-sub {
  font-size: 0.82rem;
  opacity: 0.7;
  margin-top: 0.25rem;
  letter-spacing: 0.02em;
}

/* ============================================
   NEW: SORTEN GRID
   ============================================ */
.sorten-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
  margin-top: 1rem;
}
.sorte-card {
  background: white;
  border-radius: 18px;
  padding: 2rem;
  position: relative;
  transition: transform 0.4s cubic-bezier(0.2, 0.9, 0.3, 1), box-shadow 0.4s;
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
}
.sorte-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 50px rgba(5, 68, 50, 0.15);
}
.sorte-badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: var(--mintgruen);
  color: var(--tannengruen);
  padding: 0.3rem 0.8rem;
  border-radius: 999px;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.sorte-color {
  width: 100%;
  height: 90px;
  border-radius: 12px;
  margin-bottom: 1.5rem;
  position: relative;
  overflow: hidden;
}
.sorte-color::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 400 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='2' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
}
.sorte-card h3 {
  font-family: var(--font-body);
  text-transform: uppercase;
  font-size: 1.6rem;
  font-weight: 500;
  color: var(--tannengruen);
  margin-bottom: 0.75rem;
  line-height: 1;
}
.sorte-card > p {
  font-size: 0.9rem;
  color: var(--tannengruen);
  opacity: 0.7;
  line-height: 1.55;
  margin-bottom: 1.25rem;
}
.sorte-features {
  list-style: none;
  margin-bottom: 1.25rem;
}
.sorte-features li {
  padding: 0.4rem 0;
  font-size: 0.85rem;
  color: var(--tannengruen);
  position: relative;
  padding-left: 1.2rem;
  border-bottom: 1px solid var(--line);
}
.sorte-features li:last-child { border-bottom: none; }
.sorte-features li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--moosgruen);
  font-weight: 700;
}
.sorte-price {
  font-family: var(--font-body);
  font-weight: 500;
  text-transform: uppercase;
  font-size: 2.4rem;
  color: var(--moosgruen);
  line-height: 1;
  padding-top: 1rem;
  border-top: 1px solid var(--line);
  letter-spacing: -0.005em;
}
.sorte-price small {
  font-size: 0.4em;
  font-style: italic;
  color: var(--tannengruen);
  opacity: 0.7;
  margin-left: 0.3rem;
}

/* ============================================
   NEW: ABLAUF (How it works)
   ============================================ */
.ablauf-section {
  background: var(--mint-paper);
}
.ablauf-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  margin-top: 2rem;
}
.ablauf-step {
  position: relative;
  padding: 2rem 0;
}
.ablauf-step:not(:last-child)::after {
  content: '';
  position: absolute;
  top: 3.5rem;
  right: -1rem;
  width: 2rem;
  height: 1px;
  background: linear-gradient(90deg, var(--moosgruen), transparent);
}
.ablauf-num {
  font-family: var(--font-body);
  font-weight: 400;
  font-style: italic;
  font-size: 4rem;
  color: var(--mintgruen);
  line-height: 1;
  text-transform: uppercase;
  margin-bottom: 1rem;
  letter-spacing: -0.01em;
}
.ablauf-step h3 {
  font-family: var(--font-body);
  font-weight: 500;
  text-transform: uppercase;
  font-size: 1.5rem;
  color: var(--tannengruen);
  margin-bottom: 0.75rem;
  line-height: 1;
}
.ablauf-step p {
  font-size: 0.92rem;
  color: var(--tannengruen);
  opacity: 0.75;
  line-height: 1.6;
}

/* ============================================
   NEW: m² CUSTOM INPUT (number field)
   ============================================ */
.qm-input-group {
  display: flex;
  align-items: baseline;
  gap: 0.3rem;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 10px;
  padding: 0.4rem 0.75rem;
  transition: border 0.3s;
}
.qm-input-group:focus-within {
  border-color: var(--mintgruen);
  background: rgba(255,255,255,0.15);
}
.qm-input-group input[type=number] {
  background: transparent;
  border: none;
  color: var(--mintgruen);
  font-family: var(--font-body);
  font-weight: 500;
  font-size: 2rem;
  width: 5ch;
  text-align: right;
  -moz-appearance: textfield;
  appearance: textfield;
  outline: none;
  padding: 0;
}
.qm-input-group input[type=number]::-webkit-outer-spin-button,
.qm-input-group input[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.qm-unit {
  font-family: var(--font-body);
  font-size: 1rem;
  color: var(--mintgruen);
  opacity: 0.8;
}

/* ============================================
   NEW: BUY NOW Stripe Button
   ============================================ */
.btn-buy {
  width: 100%;
  background: var(--moosgruen);
  color: white;
  padding: 1.2rem;
  border: none;
  border-radius: 999px;
  font-family: var(--font-body);
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.3s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  margin-top: 0.5rem;
  position: relative;
  overflow: hidden;
}
.btn-buy::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.18) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform 0.7s;
}
.btn-buy:hover::before { transform: translateX(100%); }
.btn-buy:hover {
  background: var(--tannengruen);
  transform: translateY(-2px);
  box-shadow: 0 12px 30px rgba(0, 105, 48, 0.3);
}
.btn-buy:disabled {
  opacity: 0.6;
  cursor: wait;
  transform: none;
}
.buy-trust {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  font-size: 0.72rem;
  letter-spacing: 0.06em;
  color: var(--tannengruen);
  opacity: 0.55;
  margin-top: 0.75rem;
  margin-bottom: 0.5rem;
}

.form-divider {
  display: flex;
  align-items: center;
  text-align: center;
  margin: 1.5rem 0 1rem;
  color: var(--tannengruen);
  opacity: 0.4;
  font-size: 0.75rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
}
.form-divider::before,
.form-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--line);
}
.form-divider span { padding: 0 1rem; }

/* Make Send button less prominent now that Buy Now is primary */
.btn-send {
  background: transparent !important;
  color: var(--tannengruen) !important;
  border: 1.5px solid var(--moosgruen) !important;
  font-weight: 600 !important;
}
.btn-send:hover {
  background: var(--moosgruen) !important;
  color: white !important;
}

textarea.contact-input {
  font-family: var(--font-body);
  resize: vertical;
  min-height: 60px;
}

/* ============================================
   RESPONSIVE additions for new sections
   ============================================ */
@media (max-width: 1024px) {
  .trust-grid { grid-template-columns: 1fr 1fr; gap: 1.5rem; }
  .sorten-grid { grid-template-columns: 1fr 1fr; }
  .ablauf-grid { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
  .ablauf-step:not(:last-child)::after { display: none; }
}
@media (max-width: 720px) {
  .trust-strip { padding: 2rem 1.25rem; }
  .trust-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .sorten-grid { grid-template-columns: 1fr; }
  .ablauf-grid { grid-template-columns: 1fr; gap: 2rem; }
  .qm-input-group input[type=number] { font-size: 1.6rem; width: 4.5ch; }
}

/* ============================================
   TYPOGRAPHY OVERRIDE
   Gardenia bleibt nur noch bei der Hero-Hauptüberschrift.
   Sonst überall Manrope (sans).
   ============================================ */
.hero h1 {
  font-family: var(--font-display) !important;
  font-weight: 500 !important;
  letter-spacing: -0.005em !important;
}
.hero h1 .ampersand,
.hero h1 .highlight {
  font-family: var(--font-display) !important;
}

/* Adjust Manrope-headings: heavier weight + tighter tracking damit sie modern wirken */
.section h2,
.calc-section h2 {
  font-family: var(--font-body) !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  font-size: clamp(2.2rem, 5vw, 4.2rem) !important;
  line-height: 1 !important;
  text-transform: none !important;
}
.section h2 .italic,
.calc-section h2 .italic {
  font-style: normal !important;
  font-weight: 800 !important;
  color: var(--moosgruen);
  font-family: var(--font-body) !important;
}
.calc-section h2 .italic { color: var(--mintgruen); }

/* H3 / sub-headers throughout */
.hero-card h3,
.service-content h3,
.sorte-card h3,
.ablauf-step h3,
.map-card-top h3,
.calc-step-title,
.result-contact-form h4 {
  font-family: var(--font-body) !important;
  font-weight: 800 !important;
  letter-spacing: -0.015em !important;
  text-transform: none !important;
  line-height: 1.05 !important;
}

/* Numbers / accents - keep bold, sleek modern */
.hero-stat .num,
.service-num,
.ablauf-num,
.sorte-price,
.result-price,
.qm-slider-head .val,
.qm-input-group input[type=number],
.qm-unit,
.map-card-bottom .city,
.trust-title {
  font-family: var(--font-body) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  text-transform: none !important;
  font-style: normal !important;
}

/* Section eyebrows - tighten up */
.section-eyebrow,
.hero-eyebrow,
.hero-card-label,
.calc-step-label,
.calc-result-head .label,
.footer-col h5 {
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
}

/* Philosophy quote (still might be there in old DOM) */
.philosophy-quote {
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
}

/* TRUST STRIP TITLES sans-serif */
.trust-title {
  font-size: 1.2rem !important;
  text-transform: none !important;
}

/* Ablauf big numbers - keep large but Manrope bold */
.ablauf-num {
  font-size: 4.5rem !important;
  color: var(--moosgruen);
  opacity: 0.18;
  font-weight: 900 !important;
}

/* Service num (currently shown in dach section but removed). Skip. */

/* Footer brand: drop SVG-styled headline since logo is image */
.footer-brand h4 { display: none; }


/* ============================================
   NEW IMAGE-RICH COMPONENTS + ANIMATIONS
   ============================================ */

/* Hero gets parallax + cinematic feel */
.hero-bg {
  background-image:
    linear-gradient(115deg, rgba(3,42,32,0.94) 0%, rgba(5,68,50,0.72) 55%, rgba(0,105,48,0.4) 100%),
    url('https://images.unsplash.com/photo-1591105575633-922c8897af9a?w=2400&q=85');
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
  animation: heroFadeIn 1.5s ease-out;
}
@keyframes heroFadeIn {
  from { transform: scale(1.05); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}

/* Floating grass blade animation - sublte decorative element */
.hero::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 80px;
  background: linear-gradient(to top, var(--mint-soft) 0%, transparent 100%);
  z-index: 2;
  pointer-events: none;
}

/* Stats: small count-up animation on number */
.hero-stat .num {
  display: inline-block;
  animation: floatUp 0.8s 0.8s both cubic-bezier(0.2, 0.9, 0.3, 1);
}
@keyframes floatUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ============================================
   SORTEN CARDS – mit echten Grasbildern
   ============================================ */
.sorte-card {
  padding: 0 !important;
  overflow: hidden;
}
.sorte-image {
  position: relative;
  width: 100%;
  aspect-ratio: 16/10;
  overflow: hidden;
}
.sorte-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1.2s cubic-bezier(0.2, 0.9, 0.3, 1);
}
.sorte-card:hover .sorte-image img {
  transform: scale(1.08);
}
.sorte-image::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(5, 68, 50, 0.25) 100%);
}
.sorte-content {
  padding: 1.75rem;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.sorte-color { display: none !important; }
.sorte-badge {
  z-index: 2;
}

/* ============================================
   GALLERY / SHOWCASE Section
   ============================================ */
.gallery-section {
  padding: 0;
  position: relative;
}
.gallery-marquee {
  display: flex;
  gap: 1rem;
  overflow-x: auto;
  scrollbar-width: none;
  padding: 0 2.5rem 4rem;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}
.gallery-marquee::-webkit-scrollbar { display: none; }
.gallery-marquee::before,
.gallery-marquee::after {
  content: '';
  flex-shrink: 0;
  width: 0;
}
.gallery-item {
  flex: 0 0 auto;
  scroll-snap-align: start;
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  width: 380px;
  aspect-ratio: 3/4;
  box-shadow: 0 16px 40px rgba(5, 68, 50, 0.15);
  transition: transform 0.5s;
}
.gallery-item:hover { transform: translateY(-6px); }
.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 1s cubic-bezier(0.2, 0.9, 0.3, 1);
}
.gallery-item:hover img { transform: scale(1.06); }
.gallery-item .caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 2rem 1.5rem 1.5rem;
  background: linear-gradient(transparent, rgba(3, 42, 32, 0.9));
  color: white;
}
.gallery-item .caption-eye {
  font-size: 0.7rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  opacity: 0.7;
  margin-bottom: 0.4rem;
  font-weight: 600;
}
.gallery-item .caption-title {
  font-weight: 700;
  font-size: 1.4rem;
  line-height: 1.1;
  letter-spacing: -0.01em;
}

/* ============================================
   IM LIEFERUMFANG (PDF Teaser auf Index)
   ============================================ */
.included-section {
  background: var(--moosgruen);
  color: white;
  padding: 5rem 2.5rem;
  position: relative;
  overflow: hidden;
}
.included-grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 4rem;
  align-items: center;
}
.included-section h2 {
  color: white !important;
}
.included-section h2 .italic {
  color: var(--mintgruen) !important;
}
.included-section .lead {
  color: rgba(255,255,255,0.8);
  font-size: 1.05rem;
  line-height: 1.7;
  margin-top: 1.5rem;
  max-width: 460px;
}
.included-bonus {
  margin-top: 2rem;
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  background: rgba(255, 218, 111, 0); /* yellow excluded */
  background: rgba(142, 200, 154, 0.18);
  border: 1px solid rgba(142, 200, 154, 0.4);
  border-radius: 12px;
  font-size: 0.9rem;
  width: fit-content;
}
.included-bonus svg { color: var(--mintgruen); flex-shrink: 0; }

.pdf-stack {
  position: relative;
  perspective: 1200px;
  min-height: 420px;
}
.pdf-doc {
  position: absolute;
  width: 280px;
  height: 380px;
  background: white;
  border-radius: 8px;
  box-shadow: 0 30px 60px rgba(0,0,0,0.4);
  transition: transform 0.6s cubic-bezier(0.2, 0.9, 0.3, 1);
  overflow: hidden;
}
.pdf-doc-1 {
  transform: rotateY(-8deg) rotateZ(-4deg) translateX(0);
  z-index: 2;
}
.pdf-doc-2 {
  transform: rotateY(-8deg) rotateZ(6deg) translateX(120px);
  z-index: 1;
}
.included-section:hover .pdf-doc-1 {
  transform: rotateY(-4deg) rotateZ(-6deg) translateX(-20px);
}
.included-section:hover .pdf-doc-2 {
  transform: rotateY(-4deg) rotateZ(8deg) translateX(140px);
}
.pdf-thumb {
  height: 60%;
  background-size: cover;
  background-position: center;
  position: relative;
}
.pdf-thumb::after {
  content: '';
  position: absolute;
  inset: 0;
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
  background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.4));
}
.pdf-doc-1 .pdf-thumb {
  background-image: url('https://images.unsplash.com/photo-1605000797499-95a51c5269ae?w=600&q=80');
}
.pdf-doc-2 .pdf-thumb {
  background-image: url('https://images.unsplash.com/photo-1416879595882-3373a0480b5b?w=600&q=80');
}
.pdf-info {
  padding: 1.25rem;
  color: var(--tannengruen);
}
.pdf-label {
  font-size: 0.65rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--moosgruen);
  font-weight: 700;
  margin-bottom: 0.4rem;
}
.pdf-title {
  font-weight: 800;
  font-size: 1.1rem;
  line-height: 1.15;
  margin-bottom: 0.5rem;
}
.pdf-meta {
  font-size: 0.72rem;
  opacity: 0.6;
  margin-top: 0.4rem;
}
.pdf-pages {
  display: flex;
  gap: 0.3rem;
  margin-top: 0.75rem;
}
.pdf-pages span {
  flex: 1;
  height: 2px;
  background: var(--mint-paper);
  border-radius: 999px;
}
.pdf-pages span.fill { background: var(--moosgruen); }

@media (max-width: 1024px) {
  .included-grid { grid-template-columns: 1fr; gap: 3rem; }
  .pdf-stack { min-height: 420px; }
}
@media (max-width: 720px) {
  .gallery-marquee { padding: 0 1.25rem 3rem; }
  .gallery-item { width: 280px; }
  .included-section { padding: 4rem 1.25rem; }
  .pdf-doc { width: 220px; height: 300px; }
  .pdf-doc-2 { transform: rotateY(-8deg) rotateZ(6deg) translateX(80px); }
}

/* ============================================
   SORTE-CARDS klickbar – Cursor + CTA-Pfeil
   ============================================ */
.sorte-card {
  cursor: pointer;
  position: relative;
}
.sorte-card:hover {
  border-color: var(--moosgruen);
}
.sorte-card .sorte-cta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--line);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--moosgruen);
  transition: gap 0.3s;
}
.sorte-card:hover .sorte-cta {
  gap: 1rem;
}
.sorte-card .sorte-cta svg {
  transition: transform 0.3s;
}
.sorte-card:hover .sorte-cta svg {
  transform: translateX(4px);
}
.sorte-content {
  /* statt flex column padding adjust */
  padding: 1.5rem 1.75rem 1.5rem !important;
  display: block !important;
}

/* ============================================
   FINAL OVERRIDE – SORTEN GRID & CARDS
   Bulletproof: vier Karten, kompakt, kein Whitespace
   ============================================ */

/* IMMER 4 Spalten ab 720px (statt erst ab 1024px) */
.sorten-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 1rem !important;
  margin-top: 1rem;
}

@media (max-width: 1024px) {
  .sorten-grid {
    grid-template-columns: repeat(4, 1fr) !important; /* 4 Spalten auch auf Tablet */
  }
}
@media (max-width: 820px) {
  .sorten-grid {
    grid-template-columns: 1fr 1fr !important; /* erst ab 820px auf 2 reduzieren */
  }
}
@media (max-width: 520px) {
  .sorten-grid {
    grid-template-columns: 1fr 1fr !important; /* Mobile: 2 Spalten – kompaktere Kacheln */
  }
}

/* Card: kein flex, einfach Block, content fließt */
.sorte-card {
  display: block !important;
  position: relative !important;
  padding: 0 !important;
  background: white;
  border-radius: 14px;
  overflow: hidden;
  cursor: pointer;
  border: 1px solid var(--line);
  transition: transform 0.4s, box-shadow 0.4s, border-color 0.3s;
  height: auto !important;
}
.sorte-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px rgba(5,68,50,0.12);
  border-color: var(--moosgruen);
}

/* BILDHÖHE FORCIERT auf 3:2 statt 4:3 oder 16:10 */
.sorte-image {
  width: 100% !important;
  aspect-ratio: 3 / 2 !important;
  height: auto !important;
  overflow: hidden;
  position: relative;
}
.sorte-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Content kompakt */
.sorte-content {
  padding: 1.25rem !important;
  display: block !important;
}

/* H3 Titel */
.sorte-card h3 {
  font-family: var(--font-body) !important;
  font-weight: 800 !important;
  font-size: 1.3rem !important;
  text-transform: none !important;
  letter-spacing: -0.015em !important;
  color: var(--tannengruen);
  margin-bottom: 0.5rem !important;
  line-height: 1.1 !important;
}

/* Description */
.sorte-card > .sorte-content > p {
  font-size: 0.85rem !important;
  color: var(--tannengruen);
  opacity: 0.7;
  line-height: 1.5 !important;
  margin-bottom: 0.85rem !important;
}

/* Features kompakt */
.sorte-features {
  list-style: none;
  margin: 0 0 0.85rem 0 !important;
  flex: none !important;
}
.sorte-features li {
  padding: 0.3rem 0 !important;
  font-size: 0.8rem !important;
  padding-left: 1.1rem !important;
  border-bottom: 1px solid var(--line);
}
.sorte-features li:last-child { border-bottom: none; }

/* Preis */
.sorte-price {
  font-family: var(--font-body) !important;
  font-weight: 800 !important;
  font-size: 1.8rem !important;
  text-transform: none !important;
  color: var(--moosgruen);
  line-height: 1 !important;
  padding-top: 0.85rem !important;
  border-top: 1px solid var(--line);
  letter-spacing: -0.02em !important;
}
.sorte-price small {
  font-size: 0.55em !important;
  font-style: normal !important;
  color: var(--tannengruen);
  opacity: 0.6;
  font-weight: 600;
  margin-left: 0.25rem;
}

/* CTA */
.sorte-cta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.85rem;
  padding-top: 0.85rem;
  border-top: 1px solid var(--line);
  font-size: 0.72rem !important;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--moosgruen);
}
.sorte-card:hover .sorte-cta svg { transform: translateX(4px); }
.sorte-cta svg { transition: transform 0.3s; flex-shrink: 0; }

/* Badge bleibt */
.sorte-badge {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  background: var(--mintgruen);
  color: var(--tannengruen);
  padding: 0.25rem 0.7rem;
  border-radius: 999px;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  z-index: 3;
}

/* ============================================
   FINAL FIXES: Hero-Transition + Trust-Strip
   ============================================ */

/* Den weißen Lichteffekt am Hero-Ende entfernen */
.hero::after {
  display: none !important;
}

/* Trust-Strip auf hellen Hintergrund umstellen */
.trust-strip {
  background: var(--mint-soft) !important;
  color: var(--tannengruen) !important;
  border-bottom: 1px solid var(--line);
  padding: 2.5rem 2.5rem;
}
.trust-strip .trust-item svg {
  color: var(--moosgruen) !important;
  opacity: 1 !important;
}
.trust-strip .trust-title {
  color: var(--tannengruen) !important;
}
.trust-strip .trust-sub {
  color: var(--tannengruen) !important;
  opacity: 0.6;
}

/* ============================================
   Kontrastfixes: Mintgrün auf Weiß ist zu hell –
   für Texte auf hellem Grund stattdessen Moosgrün
   ============================================ */
.result-price small {
  color: var(--moosgruen) !important;
}
.calc-result-head .label {
  color: var(--moosgruen) !important;
}
.sorte-cta {
  color: var(--moosgruen) !important;
}

/* ============================================
   MwSt Breakdown Hierarchie + Bonus Box
   ============================================ */
.breakdown-row.subtotal {
  padding-top: 0.65rem !important;
  border-top: 1px solid var(--line);
  font-weight: 700;
}
.breakdown-row.subtotal .lbl,
.breakdown-row.subtotal .val {
  color: var(--tannengruen);
  font-weight: 700;
}
.breakdown-row.total {
  margin-top: 0.4rem;
  padding-top: 0.75rem !important;
  border-top: 2px solid var(--moosgruen) !important;
  font-size: 1.05em;
}
.breakdown-row.total .lbl,
.breakdown-row.total .val {
  color: var(--moosgruen) !important;
  font-weight: 800 !important;
}

/* Bonus Verlegeanleitung Info Box */
.bonus-info {
  margin: 1.5rem 0 1.5rem;
  padding: 1.25rem 1.25rem;
  background: linear-gradient(135deg, rgba(142,200,154,0.18), rgba(0,154,147,0.08));
  border: 1px solid rgba(0,105,48,0.2);
  border-radius: 14px;
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  position: relative;
  overflow: hidden;
}
.bonus-info::before {
  content: '';
  position: absolute;
  top: -20%;
  right: -10%;
  width: 120px;
  height: 120px;
  background: radial-gradient(circle, rgba(142,200,154,0.4), transparent 70%);
  pointer-events: none;
}
.bonus-icon {
  flex-shrink: 0;
  width: 46px;
  height: 46px;
  border-radius: 12px;
  background: var(--moosgruen);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.bonus-content { flex: 1; position: relative; z-index: 1; }
.bonus-eyebrow {
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--moosgruen);
  font-weight: 800;
  margin-bottom: 0.35rem;
}
.bonus-title {
  font-weight: 800;
  font-size: 1rem;
  color: var(--tannengruen);
  letter-spacing: -0.01em;
  margin-bottom: 0.35rem;
  line-height: 1.2;
}
.bonus-text {
  font-size: 0.82rem;
  color: var(--tannengruen);
  opacity: 0.75;
  line-height: 1.5;
}

/* ============================================
   Calculator scroll target
   ============================================ */
.calc-wrapper {
  scroll-margin-top: 110px;
}

/* ============================================
   APRIKOT KEY ACCENTS – nur an strategischen Stellen
   ============================================ */

/* 1. Hero-Highlight "48 Stunden" – das Wertversprechen */
.hero h1 .highlight {
  color: var(--aprikot) !important;
}

/* 2. Bestseller-Badge auf Sorten-Card */
.sorte-badge {
  background: var(--aprikot) !important;
  color: var(--tannengruen) !important;
}

/* 3. Bonus-Box "Geschenk im Wert von 39 €" Eyebrow */
.bonus-eyebrow {
  color: var(--aprikot) !important;
}

/* 4. Bonus-Box Icon Hintergrund – warm-akzentuiert */
.bonus-icon {
  background: var(--aprikot) !important;
  color: var(--tannengruen) !important;
}

/* 5. Bonus-Info Border + Glow auf Aprikot ziehen für mehr Punch */
.bonus-info {
  background: linear-gradient(135deg, rgba(242,140,90,0.14), rgba(142,200,154,0.08)) !important;
  border: 1px solid rgba(242,140,90,0.35) !important;
}
.bonus-info::before {
  background: radial-gradient(circle, rgba(242,140,90,0.3), transparent 70%) !important;
}

/* ============================================
   FINAL CTA-ACCENTS – Aprikot für Conversion-Buttons
   ============================================ */

/* "Preis berechnen" Hero Button + "Jetzt bestellen" Nav-Button */
.btn-primary {
  background: var(--aprikot) !important;
  color: var(--tannengruen) !important;
}
.btn-primary:hover {
  background: white !important;
  color: var(--tannengruen) !important;
  box-shadow: 0 12px 30px rgba(242, 140, 90, 0.35) !important;
}
.nav-cta {
  background: var(--aprikot) !important;
  color: var(--tannengruen) !important;
}
.nav-cta:hover {
  background: white !important;
  color: var(--tannengruen) !important;
}

/* "Direkt online bestellen" – die Hauptconversion */
.btn-buy {
  background: var(--aprikot) !important;
  color: var(--tannengruen) !important;
}
.btn-buy:hover {
  background: white !important;
  color: var(--tannengruen) !important;
  box-shadow: 0 12px 30px rgba(242, 140, 90, 0.4) !important;
}
.btn-buy::before {
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,0.35) 50%, transparent 70%);
}

/* Rasen-Typ Card im Rechner: Aprikot bei Active */
.rasen-type:hover {
  border-color: rgba(242,140,90,0.5) !important;
}
.rasen-type.active {
  border-color: var(--aprikot) !important;
  background: rgba(242,140,90,0.12) !important;
}
.rasen-type .rt-price {
  color: var(--aprikot) !important;
}

/* Hero-Highlight "48 Stunden" zurück auf Mintgrün */
.hero h1 .highlight {
  color: var(--mintgruen) !important;
}

/* ============================================
   MOBILE OPTIMIZATION – Final pass
   ============================================ */

/* 1. ANTI-AUTO-ZOOM auf iOS – alle Text-Inputs mindestens 16px Schriftgröße
      (sonst zoomt Safari beim Fokussieren rein) */
input,
textarea,
select {
  font-size: 16px !important;
}

/* Aber für die ganz großen Display-Inputs (m²-Eingabe) wieder freigeben */
.qm-input-group input[type=number] {
  font-size: 2rem !important;
}
@media (max-width: 720px) {
  .qm-input-group input[type=number] {
    font-size: 1.6rem !important;
  }
}

/* 2. HORIZONTAL-SCROLL überall hart unterbinden */
html, body {
  overflow-x: hidden !important;
  max-width: 100vw;
  width: 100%;
}
img, svg, video, iframe {
  max-width: 100%;
  height: auto;
}

/* 3. TAP HIGHLIGHT – kein hässliches Standard-Blau, dezent in Brand-Farbe */
* {
  -webkit-tap-highlight-color: rgba(0, 105, 48, 0.15);
}
/* Bei interaktiven Elementen ganz weg (für eigene Hover-States) */
a, button, .sorte-card, .rasen-type, .qm-preset {
  -webkit-tap-highlight-color: transparent;
}

/* 4. TOUCH-ACTION – Slider soll vertikal nicht scrollen blockieren */
input[type=range] {
  touch-action: manipulation;
}

/* 5. TAP TARGETS – mindestens 44x44px wo kritisch */
@media (max-width: 720px) {
  .qm-preset {
    padding: 0.6rem 1rem !important;
    min-height: 40px;
    font-size: 0.85rem !important;
  }
  .menu-toggle {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .btn {
    min-height: 48px;
    padding: 1rem 1.75rem !important;
  }
  .btn-buy {
    min-height: 56px;
    font-size: 0.95rem !important;
  }
  .btn-send {
    min-height: 48px;
  }
}

/* 6. MOBILE-SPEZIFISCHE LAYOUT-FIXES */
@media (max-width: 720px) {
  /* Hero h1 – nicht zu groß bei schmalen Screens */
  .hero h1 {
    font-size: clamp(2.4rem, 13vw, 4rem) !important;
  }

  /* Section-Header: gleichmäßiger Abstand */
  .section-header {
    margin-bottom: 2.5rem;
  }
  .section h2,
  .calc-section h2 {
    font-size: clamp(1.8rem, 7vw, 2.8rem) !important;
  }

  /* Calc-Card Padding etwas reduzieren damit mehr Platz für Inhalte */
  .calc-card {
    padding: 1.25rem !important;
  }
  .calc-result {
    padding: 1.5rem !important;
  }
  .calc-step-title {
    font-size: 1.25rem !important;
  }
  .qm-slider-head .val {
    font-size: 1.4rem !important;
  }

  /* Bonus-Box auf Mobile flexibel */
  .bonus-info {
    flex-direction: row;
    padding: 1rem !important;
    gap: 0.75rem;
  }
  .bonus-icon {
    width: 40px;
    height: 40px;
  }
  .bonus-title { font-size: 0.95rem !important; }
  .bonus-text { font-size: 0.78rem !important; }

  /* Hero Background nicht fixed auf Mobile (Performance + Safari Bug) */
  .hero-bg {
    background-attachment: scroll !important;
  }

  /* Footer & Contact-Liste sauberer aufbauen */
  .contact-list li {
    grid-template-columns: 1fr !important;
    gap: 0.35rem !important;
  }

  /* Result-Card Sticky aufheben bei Mobile (sonst nervt es) */
  .calc-result {
    position: relative !important;
    top: 0 !important;
  }

  /* Nav Logo Höhe sicher klein */
  .nav-logo img {
    height: 30px !important;
  }
}

/* 7. SCROLL-VERHALTEN: smooth + Sticky Nav Offset */
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%; /* iOS soll Text nicht eigenständig vergrößern */
}

/* 8. ACCESSIBILITY: reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* 9. FOCUS STYLES – sichtbar für Tastaturnutzer (a11y) */
button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--aprikot);
  outline-offset: 2px;
}

/* ============================================
   MOBILE FEINSCHLIFF – Form-Layout & Spacing
   ============================================ */
@media (max-width: 720px) {
  /* Form-Grid: zweispaltige Felder stacken untereinander */
  .form-row {
    grid-template-columns: 1fr !important;
    gap: 0 !important;
  }

  /* Hero CTA-Buttons sollen full width und stapeln */
  .hero-actions {
    flex-direction: column;
    width: 100%;
  }
  .hero-actions .btn {
    width: 100%;
    justify-content: center;
  }

  /* m²-Presets Wrap-Verhalten */
  .qm-presets {
    flex-wrap: wrap;
    gap: 0.4rem;
  }

  /* PLZ + Bundesland row stacked */
  .calc-fields {
    grid-template-columns: 1fr !important;
    gap: 0.85rem !important;
  }

  /* Rasen-Typ-Karten enger packen */
  .rasen-types {
    grid-template-columns: 1fr 1fr !important;
    gap: 0.5rem !important;
  }
  .rasen-type {
    padding: 0.85rem 0.65rem !important;
  }
  .rt-name {
    font-size: 0.88rem !important;
  }

  /* Trust-Strip auf Mobile mit weniger Padding */
  .trust-strip {
    padding: 1.5rem 1rem !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 1rem !important;
  }
  .trust-title {
    font-size: 0.95rem !important;
  }
  .trust-sub {
    font-size: 0.75rem !important;
  }

  /* Container Padding etwas reduzieren */
  .container {
    padding: 0 1rem !important;
  }
}

@media (max-width: 480px) {
  /* Auf ganz kleinen Screens Trust-Strip zu single column */
  .trust-strip {
    grid-template-columns: 1fr !important;
  }
  /* Rasen-Typen single column auf ganz schmal */
  .rasen-types {
    grid-template-columns: 1fr !important;
  }
}

/* ============================================
   LIQUID GLASS REDESIGN
   – Noise-Texturen weg
   – Smooth Gradient Mesh statt Körnung
   – Backdrop-Blur Cards für Floating-Glass-Effekt
   ============================================ */

/* 1. Alle Noise-Pseudoelemente killen (Hero, Calc-Section, sonstwo) */
.hero::before,
.calc-section::before,
.section.philosophy::before,
section::before {
  background-image: none !important;
  background:
    radial-gradient(ellipse at 20% 25%, rgba(142,200,154,0.12) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 75%, rgba(0,154,147,0.10) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 100%, rgba(0,105,48,0.20) 0%, transparent 70%) !important;
  opacity: 1 !important;
  filter: blur(40px);
}

/* 2. Hero: dunkler Grundton + sanfter Gradient-Mesh, ohne Bild-Überlagerung-Härte */
.hero {
  background:
    radial-gradient(ellipse 80% 50% at 30% 20%, rgba(142,200,154,0.18) 0%, transparent 60%),
    radial-gradient(ellipse 60% 80% at 80% 80%, rgba(0,154,147,0.15) 0%, transparent 60%),
    linear-gradient(135deg, var(--tannengruen) 0%, #042e23 60%, var(--moosgruen) 130%) !important;
}
.hero-bg {
  display: none !important;
}

/* 3. Calc-Section: gleiche Behandlung, andere Akzentposition */
.calc-section {
  background:
    radial-gradient(ellipse 70% 60% at 70% 30%, rgba(142,200,154,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 50% 50% at 20% 80%, rgba(0,154,147,0.10) 0%, transparent 60%),
    linear-gradient(180deg, var(--tannengruen) 0%, #043a2c 100%) !important;
}

/* 4. HERO-CARD: Liquid Glass */
.hero-card {
  background: rgba(255, 255, 255, 0.05) !important;
  backdrop-filter: blur(24px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
  box-shadow:
    0 16px 50px rgba(0, 0, 0, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

/* 5. CALC-CARD: Liquid Glass */
.calc-card {
  background: rgba(255, 255, 255, 0.04) !important;
  backdrop-filter: blur(24px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
  border: 1px solid rgba(255, 255, 255, 0.10) !important;
  box-shadow:
    0 20px 60px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

/* 6. RESULT-CARD bleibt weiß, aber mit Glass-Touch + sanfter Tiefe */
.calc-result {
  background: rgba(255, 255, 255, 0.95) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(255, 255, 255, 0.4) !important;
  box-shadow:
    0 24px 60px rgba(0, 0, 0, 0.18),
    0 0 0 1px rgba(0, 105, 48, 0.04) !important;
}

/* 7. RASEN-TYPE Karten innerhalb Calc-Card: subtiles Glass */
.rasen-type {
  background: rgba(255, 255, 255, 0.06) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border-color: rgba(255, 255, 255, 0.12) !important;
}
.rasen-type.active {
  background: rgba(242, 140, 90, 0.15) !important;
  border-color: var(--aprikot) !important;
  box-shadow: 0 0 0 1px var(--aprikot), 0 8px 20px rgba(242,140,90,0.2) !important;
}

/* 8. SORTEN-CARDS auf der Light Section: gentle Glass */
.sorte-card {
  background: rgba(255, 255, 255, 0.7) !important;
  backdrop-filter: blur(20px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
  border: 1px solid rgba(255, 255, 255, 0.6) !important;
  box-shadow: 0 8px 24px rgba(5, 68, 50, 0.06) !important;
}
.sorte-card:hover {
  background: rgba(255, 255, 255, 0.92) !important;
  box-shadow: 0 20px 40px rgba(5, 68, 50, 0.12) !important;
}

/* 9. INPUTS & SELECTS in der Calc-Card: glass-tinted */
.calc-field input,
.calc-field select {
  background: rgba(255, 255, 255, 0.06) !important;
  backdrop-filter: blur(8px) !important;
  border: 1px solid rgba(255, 255, 255, 0.14) !important;
}
.calc-field input:focus,
.calc-field select:focus {
  background: rgba(255, 255, 255, 0.10) !important;
  border-color: rgba(242, 140, 90, 0.45) !important;
}
.qm-input-group input[type=number] {
  background: transparent !important;
}

/* 10. NAV: Liquid Glass Sticky Header */
nav {
  background: rgba(5, 68, 50, 0.75) !important;
  backdrop-filter: blur(24px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
}

/* 11. TRUST-STRIP: ganz dezent gläsern, helle Grundfarbe bleibt */
.trust-strip {
  background: linear-gradient(180deg, var(--mint-soft) 0%, rgba(223, 234, 220, 0.6) 100%) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
}

/* 12. BONUS-INFO: subtileres Glass-Glow */
.bonus-info {
  background: linear-gradient(135deg, rgba(242,140,90,0.10), rgba(142,200,154,0.05)) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(242, 140, 90, 0.25) !important;
}

/* 13. CONTACT/FOOTER: dezent gradient mesh */
footer {
  background:
    radial-gradient(ellipse at 70% 30%, rgba(142,200,154,0.08) 0%, transparent 60%),
    var(--tannengruen) !important;
}

/* ============================================
   FINAL FIX: .hero-grain (eigenes div, nicht Pseudo)
   ============================================ */
.hero-grain {
  display: none !important;
}

/* ============================================
   APRIKOT EXTRA AKZENTE IM RECHNER
   ============================================ */

/* Großzahl "100 m²" Anzeige */
.qm-slider-head .val {
  color: var(--aprikot) !important;
}

/* m²-Presets: Active-State */
.qm-preset.active,
.qm-preset:hover {
  background: var(--aprikot) !important;
  color: var(--tannengruen) !important;
  border-color: var(--aprikot) !important;
}

/* Slider Track-Fill + Thumb */
.qm-slider input[type=range]::-webkit-slider-thumb {
  background: var(--aprikot) !important;
  border-color: white !important;
  animation: mpgThumbPulse 1.8s ease-in-out infinite;
}
.qm-slider input[type=range]::-moz-range-thumb {
  background: var(--aprikot) !important;
  border-color: white !important;
  animation: mpgThumbPulse 1.8s ease-in-out infinite;
}
.qm-slider input[type=range]::-webkit-slider-runnable-track {
  background: linear-gradient(to right, var(--aprikot) 0%, var(--aprikot) var(--fill, 5%), rgba(255,255,255,0.15) var(--fill, 5%), rgba(255,255,255,0.15) 100%) !important;
}

/* Bonus: der pulsierende Result-Dot rechts auch in Aprikot */
.calc-result-head .dot {
  background: var(--aprikot) !important;
}
.calc-result-head .dot::before {
  background: var(--aprikot) !important;
}

/* ============================================
   MOBILE: Hero-Bild + Compact + Full-Width Calc
   ============================================ */

@media (max-width: 820px) {

  /* HERO mit eindrucksvollem Rollrasen-Bild im Hintergrund */
  .hero {
    background:
      linear-gradient(180deg, rgba(3,42,32,0.85) 0%, rgba(5,68,50,0.78) 45%, rgba(3,42,32,0.95) 100%),
      url('https://images.unsplash.com/photo-1611072295125-59681c5402ce?w=1200&q=85&auto=format&fit=crop') !important;
    background-size: cover !important;
    background-position: center !important;
    background-attachment: scroll !important;
    min-height: 90vh;
    padding: 3rem 1.25rem 4rem !important;
  }
  /* Soft inner glow für Stimmung */
  .hero::after {
    content: '' !important;
    display: block !important;
    position: absolute !important;
    inset: 0;
    background:
      radial-gradient(ellipse 80% 50% at 50% 10%, rgba(142,200,154,0.18) 0%, transparent 60%),
      radial-gradient(ellipse 80% 60% at 50% 100%, rgba(0,105,48,0.30) 0%, transparent 70%) !important;
    pointer-events: none;
    z-index: 0;
  }
  .hero-content { z-index: 2; position: relative; }

  /* Hero kompakter: Titel sitzt enger, Lead schmaler */
  .hero h1 {
    margin-bottom: 1rem !important;
    line-height: 0.95 !important;
  }
  .hero-lead {
    font-size: 0.95rem !important;
    margin-bottom: 1.5rem !important;
  }
  .hero-card {
    padding: 1.5rem 1.25rem !important;
    margin-top: 1.5rem;
  }
  .hero-card h3 {
    font-size: 1.4rem !important;
  }
  .hero-card-label {
    font-size: 0.65rem !important;
    margin-bottom: 0.75rem !important;
  }
  .hero-stats {
    margin-top: 1.25rem !important;
    padding-top: 1.25rem !important;
  }
  .hero-stat .num {
    font-size: 1.8rem !important;
  }
  .hero-stat .lbl {
    font-size: 0.7rem !important;
  }
  .scroll-cue { display: none !important; }

  /* SECTION-PADDINGS überall stark reduzieren */
  .section,
  .calc-section,
  .ablauf-section,
  .contact-section {
    padding: 3rem 1rem !important;
  }
  .section-header {
    margin-bottom: 1.5rem !important;
  }
  .section-intro {
    font-size: 0.92rem !important;
    margin-top: 0.85rem !important;
  }

  /* SORTEN-Section: weniger Abstand zwischen Karten */
  .sorten-grid { gap: 0.75rem !important; }
  .sorte-content { padding: 1rem !important; }
  .sorte-content p { font-size: 0.82rem !important; }
  .sorte-card h3 { font-size: 1.1rem !important; }

  /* TRUST-STRIP wirklich kompakt */
  .trust-strip {
    padding: 1.25rem 1rem !important;
  }

  /* ABLAUF: Cards näher beieinander */
  .ablauf-grid { gap: 0.75rem !important; }
  .ablauf-step { padding: 1.25rem !important; }
  .ablauf-num { font-size: 2rem !important; margin-bottom: 0.5rem !important; }
  .ablauf-step h3 { font-size: 1.1rem !important; }
  .ablauf-step p { font-size: 0.85rem !important; }
}

/* ============================================
   RECHNER VOLL BILDSCHIRMBREITE AUF MOBILE
   ============================================ */
@media (max-width: 820px) {
  /* Calc-Section: KEIN seitliches Padding mehr */
  .calc-section {
    padding-left: 0 !important;
    padding-right: 0 !important;
    padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
  }
  /* Section-Header bekommt eigenes Padding zurück damit Überschrift nicht am Rand klebt */
  .calc-section .section-header {
    padding: 0 1rem !important;
    margin-bottom: 1.25rem !important;
  }
  /* Calc-Wrapper auch full-width und ohne Margin */
  .calc-wrapper {
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 0.75rem !important;
  }
  /* Calc-Card: full width, eckige Kanten weg, sanftere Rundung nur oben/unten */
  .calc-card,
  .calc-result {
    border-radius: 0 !important;
    padding: 1.75rem 1.25rem !important;
    margin: 0 !important;
    width: 100% !important;
    border-left: none !important;
    border-right: none !important;
  }
  /* Calc-Steps Spacing */
  .calc-step {
    padding-bottom: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  /* QM-Slider Box: vollere Breite nutzen */
  .qm-slider {
    padding: 1rem !important;
  }
  .qm-slider-head .val {
    font-size: 2rem !important;
  }
  /* Inputs / Selects ein bisschen kompakter */
  .calc-field input,
  .calc-field select {
    padding: 0.75rem 0.85rem !important;
  }
  /* Result-Card: Preis kompakter */
  .result-price {
    font-size: 3.5rem !important;
  }
  .breakdown-row {
    font-size: 0.82rem !important;
  }
  /* Bonus-Box auch ohne Padding-Verschwendung */
  .bonus-info {
    margin: 1rem 0 !important;
    padding: 0.85rem !important;
  }

  /* Form (rechts unten) auch full-width passend */
  .result-contact-form {
    margin-top: 1.5rem !important;
    padding-top: 1.5rem !important;
  }
}


/* ============================================
   FINAL: GLOWS WEG · ÜBERALL SOLIDES TANNENGRÜN
   ============================================ */

/* Hero: kompletter Glow weg, solides Tannengrün */
.hero,
.hero::before,
.hero::after {
  background: var(--tannengruen) !important;
  background-image: none !important;
  filter: none !important;
}
.hero::before,
.hero::after {
  display: none !important;
}

/* Calc-Section: keine Gradients, kein Mesh – pure Eleganz */
.calc-section,
.calc-section::before,
.calc-section::after {
  background: var(--tannengruen) !important;
  background-image: none !important;
  filter: none !important;
}
.calc-section::before,
.calc-section::after {
  display: none !important;
}

/* Mobile Hero: auch kein Bild + Glow, einheitlich Tannengrün */
@media (max-width: 820px) {
  .hero {
    background: var(--tannengruen) !important;
    background-image: none !important;
  }
  .hero::after {
    display: none !important;
  }
}

/* Footer: gleiches sattes Grün, kein Mesh */
footer {
  background: var(--tannengruen) !important;
  background-image: none !important;
}

/* Trust-Strip: bleibt hell-mint, aber ohne Gradient */
.trust-strip {
  background: var(--mint-soft) !important;
  background-image: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* Section.philosophy oder andere dunkle Sections falls vorhanden: gleiches Grün */
.section[style*="tannengruen"],
.ablauf-section,
.contact-section,
.philosophy {
  background-color: var(--tannengruen) !important;
}

/* Sektion-Übergänge: keine Kontrastbänder mehr */
section[class*="section"] + section[class*="section"] {
  border-top: none !important;
}

/* Nav-Header: dezent dunkler, gut auf dem Tannengrün lesbar */
nav {
  background: rgba(3, 30, 22, 0.85) !important;
  backdrop-filter: blur(20px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
}

/* ============================================
   ABSOLUT FINAL: pure Tannengrün, KEIN Glow
   content: none deaktiviert Pseudo-Elemente komplett
   ============================================ */

/* Pseudo-Elemente komplett verhindern */
.hero::before,
.hero::after,
.calc-section::before,
.calc-section::after,
section::before,
section::after,
footer::before,
footer::after {
  content: none !important;
  display: none !important;
  background: none !important;
  background-image: none !important;
}

/* Hero & Calc-Section: hartes flaches Tannengrün */
.hero {
  background: #054432 !important;
  background-color: #054432 !important;
  background-image: none !important;
}
.calc-section {
  background: #054432 !important;
  background-color: #054432 !important;
  background-image: none !important;
}
footer {
  background: #054432 !important;
  background-color: #054432 !important;
  background-image: none !important;
}

/* Zusätzliche Overlay-Divs killen (.hero-bg, .hero-grain, falls noch da) */
.hero-bg,
.hero-grain {
  display: none !important;
  background: none !important;
}

/* Mobile auch hier: solides Grün, kein Bild, kein Glow */
@media (max-width: 820px) {
  .hero {
    background: #054432 !important;
    background-color: #054432 !important;
    background-image: none !important;
  }
  .hero::before,
  .hero::after {
    content: none !important;
    display: none !important;
  }
}

/* ============================================
   NAV-TITLELEISTE: heller Moosgrün
   absetzt sich vom dunklen Tannengrün-Hintergrund
   ============================================ */
nav {
  background: var(--moosgruen) !important;
  background-color: #006930 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}

/* Mobile-Menü-Drawer auch in der Nav-Farbe damit's konsistent ist */
.nav.menu-open .nav-menu {
  background: #043829 !important;
}

/* ============================================
   FINAL NAV-FIX: solides Moosgrün, höchste Spezifität
   ============================================ */
nav.nav,
.nav#nav {
  background: #043829 !important;
  background-color: #043829 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* ============================================
   CALC: gleiche Höhe links/rechts + solide Nav-Farbe
   ============================================ */

/* 1. Karten gleich hoch ziehen (stretch statt start) */
.calc-wrapper {
  align-items: stretch !important;
}

/* 2. Calc-Card auf solides Nav-Grün, kein Glas-Tint, kein Blur */
.calc-card {
  background: #043829 !important;
  background-color: #043829 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,0.15) !important;
}

/* 3. Result-Card auch volle Höhe (nicht sticky) – flex damit Form unten Platz hat */
.calc-result {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  position: relative !important;
  top: 0 !important;
}

/* ============================================
   MODAL: Unverbindliches Angebot anfordern
   ============================================ */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(3, 30, 22, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.modal-backdrop.is-open {
  opacity: 1;
  pointer-events: auto;
}
.modal-card {
  background: white;
  border-radius: 22px;
  padding: 2.5rem 2.25rem 2rem;
  max-width: 480px;
  width: 100%;
  position: relative;
  box-shadow: 0 30px 80px rgba(0,0,0,0.4);
  transform: translateY(20px) scale(0.96);
  transition: transform 0.4s cubic-bezier(0.2,0.9,0.3,1);
  max-height: 90vh;
  overflow-y: auto;
}
.modal-backdrop.is-open .modal-card {
  transform: translateY(0) scale(1);
}
.modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--mint-paper);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--tannengruen);
  transition: background 0.2s, color 0.2s;
}
.modal-close:hover { background: var(--tannengruen); color: white; }
.modal-eyebrow {
  font-size: 0.7rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 800;
  color: var(--aprikot);
  margin-bottom: 0.75rem;
}
.modal-card h3 {
  font-family: var(--font-body) !important;
  font-weight: 800 !important;
  text-transform: none !important;
  font-size: 1.7rem !important;
  letter-spacing: -0.02em !important;
  color: var(--tannengruen);
  margin-bottom: 0.75rem !important;
  line-height: 1.1 !important;
}
.modal-sub {
  font-size: 0.92rem;
  color: var(--tannengruen);
  opacity: 0.7;
  margin-bottom: 1.5rem;
  line-height: 1.5;
}
.modal-card .result-contact-form {
  margin: 0;
  padding: 0;
  border-top: none;
}
.modal-card .btn-send {
  margin-top: 0.5rem;
}
body.modal-open {
  overflow: hidden;
}

/* Button der das Modal öffnet (Outline-Variante) */
.btn-request {
  display: block;
  width: 100%;
  padding: 1rem 1.75rem;
  background: transparent;
  color: var(--moosgruen);
  border: 2px solid var(--moosgruen);
  border-radius: 999px;
  font-family: inherit;
  font-weight: 700;
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.3s;
}
.btn-request:hover {
  background: var(--moosgruen);
  color: white;
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(0,105,48,0.2);
}

/* ============================================
   APRIKOT-TINT FÜR BREAKDOWN & FORM-INPUTS
   ============================================ */
.result-breakdown {
  background: rgba(242, 140, 90, 0.07) !important;
  border: 1px solid rgba(242, 140, 90, 0.15) !important;
}
.breakdown-row.subtotal {
  border-top-color: rgba(242, 140, 90, 0.25) !important;
}
.breakdown-row.total {
  border-top-color: var(--moosgruen) !important;
}

/* Form-Inputs im Modal */
.modal-card .contact-input {
  background: rgba(242, 140, 90, 0.07) !important;
  border: 1px solid rgba(242, 140, 90, 0.15) !important;
}
.modal-card .contact-input:focus {
  background: rgba(242, 140, 90, 0.12) !important;
  border-color: var(--aprikot) !important;
}

/* Mobile Modal Anpassung */
@media (max-width: 720px) {
  .modal-card {
    padding: 2rem 1.5rem 1.5rem;
    border-radius: 18px;
    max-height: 95vh;
  }
  .modal-card h3 {
    font-size: 1.4rem !important;
  }
}

/* ============================================
   ELEGANT HOVER für Aprikot-Conversion-Buttons
   Kein Weiß-Flash mehr — tieferer Ton + Glow-Ring + sanfter Lift
   ============================================ */

.btn-buy,
.btn-primary,
.nav-cta {
  position: relative;
  background: var(--aprikot) !important;
  color: var(--tannengruen) !important;
  transition:
    transform 0.4s cubic-bezier(0.2, 0.9, 0.3, 1),
    box-shadow 0.45s cubic-bezier(0.2, 0.9, 0.3, 1),
    background 0.3s ease,
    letter-spacing 0.3s ease !important;
}

/* Default sanfter Schatten gibt Tiefe */
.btn-buy {
  box-shadow: 0 8px 24px rgba(242, 140, 90, 0.25);
}
.btn-primary,
.nav-cta {
  box-shadow: 0 6px 18px rgba(242, 140, 90, 0.22);
}

/* Hover: tieferer Aprikot-Ton, Glow-Ring, sanfter Lift */
.btn-buy:hover,
.btn-primary:hover,
.nav-cta:hover {
  background: #ed7a45 !important;
  color: var(--tannengruen) !important;
  transform: translateY(-3px) !important;
  letter-spacing: 0.1em !important;
  box-shadow:
    0 0 0 4px rgba(242, 140, 90, 0.16),
    0 20px 45px rgba(242, 140, 90, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
}

/* Active (gedrückt): leichter zurückfedern */
.btn-buy:active,
.btn-primary:active,
.nav-cta:active {
  transform: translateY(-1px) !important;
  transition-duration: 0.08s !important;
  box-shadow:
    0 0 0 3px rgba(242, 140, 90, 0.18),
    0 8px 18px rgba(242, 140, 90, 0.35) !important;
}

/* Subtile Shimmer-Animation beim Hover (nur btn-buy hat das ::before) */
.btn-buy::before {
  background: linear-gradient(120deg,
    transparent 30%,
    rgba(255, 255, 255, 0.22) 50%,
    transparent 70%) !important;
}

/* ============================================
   MOBILE WIZARD + KOMPAKTE SORTEN + EYEBROW-FIX
   ============================================ */

/* Desktop: alle Steps sichtbar, keine Wizard-Nav, keine Dots */
.cstep-nav { display: none; }
.cstep { display: block; }
.cstep + .cstep { margin-top: 2rem; }
.calc-steps { display: none; }

@keyframes cstepIn {
  from { opacity: 0; transform: translateX(12px); }
  to   { opacity: 1; transform: translateX(0); }
}

@media (max-width: 820px) {
  /* --- HERO: abgeschnittenes Eyebrow weg + genug Platz unter Nav --- */
  .hero-eyebrow { display: none !important; }
  .hero {
    padding-top: 6.5rem !important;
  }

  /* --- WIZARD: nur aktiver Step sichtbar --- */
  .cstep {
    display: none;
  }
  .cstep.is-active {
    display: block;
    animation: cstepIn 0.35s ease;
  }
  .cstep + .cstep { margin-top: 0; }

  /* Progress-Dots sichtbar als Wizard-Indikator */
  .calc-steps {
    display: flex !important;
    gap: 0.5rem;
    margin-bottom: 1.75rem;
  }
  .calc-step-dot {
    flex: 1;
    height: 4px;
    border-radius: 2px;
    background: rgba(255,255,255,0.15);
    transition: background 0.35s ease;
  }
  .calc-step-dot.active,
  .calc-step-dot.done {
    background: var(--aprikot);
  }

  /* Wizard-Navigation */
  .cstep-nav {
    display: flex !important;
    gap: 0.75rem;
    margin-top: 2rem;
  }
  .cstep-back,
  .cstep-next {
    flex: 1;
    padding: 1rem;
    border-radius: 999px;
    font-family: inherit;
    font-weight: 700;
    font-size: 0.82rem;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    cursor: pointer;
    border: none;
    transition: all 0.3s;
    min-height: 52px;
  }
  .cstep-back {
    background: transparent;
    border: 1.5px solid rgba(255,255,255,0.3);
    color: white;
    flex: 0 0 38%;
  }
  .cstep-back:disabled {
    opacity: 0.25;
    pointer-events: none;
  }
  .cstep-next {
    background: var(--aprikot);
    color: var(--tannengruen);
    box-shadow: 0 8px 20px rgba(242,140,90,0.3);
  }
  .cstep-next:active {
    transform: scale(0.98);
  }

  /* Rasen-Types im Wizard: volle Breite, gut tappbar */
  .rasen-types {
    grid-template-columns: 1fr 1fr !important;
    gap: 0.6rem !important;
  }
  .rasen-type {
    padding: 1rem 0.85rem !important;
    min-height: 90px;
  }

  /* --- SORTEN-CARDS: kompakt, Details erst nach Tap --- */
  .sorte-card .sorte-content > p,
  .sorte-card .sorte-features {
    display: none;
  }
  .sorte-card.expanded .sorte-content > p,
  .sorte-card.expanded .sorte-features {
    display: block;
    animation: cstepIn 0.3s ease;
  }
  .sorte-card .sorte-cta {
    display: none;
  }
  .sorte-card.expanded .sorte-cta {
    display: flex;
  }
  /* Kompaktes Bild */
  .sorte-image {
    aspect-ratio: 16/7 !important;
  }
  /* Chevron-Indikator dass es aufklappbar ist */
  .sorte-content {
    position: relative;
  }
  .sorte-content::after {
    content: '';
    position: absolute;
    top: 1.4rem;
    right: 1.1rem;
    width: 10px;
    height: 10px;
    border-right: 2px solid var(--moosgruen);
    border-bottom: 2px solid var(--moosgruen);
    transform: rotate(45deg);
    transition: transform 0.3s;
    opacity: 0.5;
  }
  .sorte-card.expanded .sorte-content::after {
    transform: rotate(-135deg);
  }
  /* Sorten-Grid einspaltig auf Mobile damit kompakt-Liste */
  .sorten-grid {
    grid-template-columns: 1fr !important;
    gap: 0.65rem !important;
  }
}

/* ============================================
   RESULT-CARD: Mobile erst nach Wizard-Ende
   ============================================ */
@media (max-width: 820px) {
  .calc-result {
    display: none !important;
  }
  .calc-wrapper.wizard-done .calc-result {
    display: flex !important;
    animation: cstepIn 0.4s ease;
  }
}

/* ============================================
   BONUS-BOX kompakter (Web + Mobile)
   ============================================ */
.bonus-info {
  margin: 1.25rem 0 !important;
  padding: 0.85rem 1rem !important;
  align-items: center !important;
  gap: 0.85rem !important;
}
.bonus-icon {
  width: 38px !important;
  height: 38px !important;
  border-radius: 10px !important;
}
.bonus-icon svg {
  width: 20px !important;
  height: 20px !important;
}
.bonus-eyebrow {
  font-size: 0.62rem !important;
  margin-bottom: 0.2rem !important;
}
.bonus-title {
  font-size: 0.92rem !important;
  margin-bottom: 0 !important;
}

/* ============================================
   FIX: Map-Card auf Mobile nicht abschneiden
   Feste aspect-ratio raus, Karte wächst mit Inhalt
   ============================================ */
@media (max-width: 820px) {
  .map-card {
    aspect-ratio: auto !important;
    min-height: 320px;
    padding: 2rem !important;
    gap: 2rem;
  }
  .map-card-top h3 {
    font-size: 2rem !important;
  }
  .map-card-bottom .city {
    font-size: 2.8rem !important;
  }
  .map-card-bottom .country {
    font-size: 0.75rem !important;
  }
}

/* ============================================
   LIEFERTERMIN-KALENDER
   ============================================ */
.calendar {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 16px;
  padding: 1.25rem;
}
.cal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}
.cal-month {
  font-weight: 800;
  font-size: 1.05rem;
  color: white;
  letter-spacing: -0.01em;
}
.cal-nav {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(255,255,255,0.08);
  border: none;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background 0.2s, opacity 0.2s;
}
.cal-nav:hover { background: rgba(255,255,255,0.16); }
.cal-nav:disabled { opacity: 0.25; pointer-events: none; }
.cal-weekdays {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.25rem;
  margin-bottom: 0.5rem;
}
.cal-weekdays span {
  text-align: center;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  padding: 0.25rem 0;
}
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0.25rem;
}
.cal-day {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  font-size: 0.85rem;
  font-weight: 600;
  color: white;
  background: transparent;
  border: none;
  cursor: pointer;
  transition: background 0.2s, transform 0.15s;
  font-family: inherit;
}
.cal-day.empty {
  pointer-events: none;
}
.cal-day.disabled {
  color: rgba(255,255,255,0.18);
  pointer-events: none;
}
.cal-day.available:hover {
  background: rgba(242,140,90,0.25);
  transform: scale(1.08);
}
.cal-day.selected {
  background: var(--aprikot);
  color: var(--tannengruen);
  font-weight: 800;
}
/* Gewählter Tag: beim Hover NICHT blasser werden – Farbe bleibt, nur minimal größer */
.cal-day.selected:hover,
.cal-day.available.selected:hover {
  background: var(--aprikot);
  color: var(--tannengruen);
  transform: scale(1.08);
}
.cal-hint {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 1rem;
  font-size: 0.72rem;
  color: rgba(255,255,255,0.5);
}
.cal-hint svg { flex-shrink: 0; opacity: 0.7; }

/* Liefertermin-Zeile im Breakdown hervorheben */
.breakdown-row.delivery-row {
  padding-bottom: 0.65rem !important;
  margin-bottom: 0.4rem;
  border-bottom: 1px dashed rgba(242,140,90,0.3);
}
.breakdown-row.delivery-row .lbl {
  color: var(--moosgruen);
  font-weight: 700;
}
.breakdown-row.delivery-row .val {
  color: var(--moosgruen) !important;
  font-weight: 800 !important;
}

@media (max-width: 720px) {
  .cal-day { font-size: 0.8rem; }
  .calendar { padding: 1rem; }
}

/* ============================================
   WIZARD GLOBAL (auch Desktop) – verschachtelt,
   Preis erst nach Abschluss aller Schritte
   ============================================ */

/* Calculator einspaltig & zentriert auf allen Größen */
.calc-wrapper {
  grid-template-columns: 1fr !important;
  max-width: 640px !important;
  margin: 3rem auto 0 !important;
  gap: 1.5rem !important;
  align-items: stretch !important;
}

/* Nur aktiver Step sichtbar – überall */
.cstep {
  display: none !important;
}
.cstep.is-active {
  display: block !important;
  animation: cstepIn 0.35s ease;
}

/* Progress-Dots immer sichtbar */
.calc-steps {
  display: flex !important;
  gap: 0.5rem;
  margin-bottom: 1.75rem;
}
.calc-step-dot {
  flex: 1;
  height: 4px;
  border-radius: 2px;
  background: rgba(255,255,255,0.15);
  transition: background 0.35s ease;
}
.calc-step-dot.active,
.calc-step-dot.done {
  background: var(--aprikot);
}

/* Wizard-Navigation immer sichtbar */
.cstep-nav {
  display: flex !important;
  gap: 0.75rem;
  margin-top: 2rem;
}
.cstep-back,
.cstep-next {
  flex: 1;
  padding: 1rem;
  border-radius: 999px;
  font-family: inherit;
  font-weight: 700;
  font-size: 0.82rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
  border: none;
  transition: all 0.3s;
  min-height: 52px;
}
.cstep-back {
  background: transparent;
  border: 1.5px solid rgba(255,255,255,0.3);
  color: white;
  flex: 0 0 38%;
}
.cstep-back:disabled {
  opacity: 0.25;
  pointer-events: none;
}
.cstep-next {
  background: var(--aprikot);
  color: var(--tannengruen);
  box-shadow: 0 8px 20px rgba(242,140,90,0.3);
}
.cstep-next:hover {
  background: #ed7a45;
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(242,140,90,0.4);
}
.cstep-next:active {
  transform: scale(0.98);
}

/* Result-Karte erst nach Wizard-Abschluss – überall */
.calc-result {
  display: none !important;
}
.calc-wrapper.wizard-done .calc-result {
  display: flex !important;
  height: auto !important;
  animation: cstepIn 0.4s ease;
}

/* Rasen-Types im Wizard: 2-spaltig, gut tappbar */
.rasen-types {
  grid-template-columns: 1fr 1fr !important;
  gap: 0.6rem !important;
}

/* ============================================
   HERO NEU: Banner-Bild als Startbild
   ============================================ */
.hero {
  padding: 0 !important;
  min-height: auto !important;
  background: var(--tannengruen) !important;
  display: block !important;
  position: relative;
}
.hero-banner {
  max-width: 1600px;
  margin: 0 auto;
  line-height: 0;
  /* Top-Padding damit das Bild unter der fixen Nav startet */
  padding-top: 70px;
}
.hero-img {
  width: 100%;
  height: auto;
  display: block;
}
.hero-cta-bar {
  display: flex;
  gap: 1rem;
  justify-content: center;
  align-items: center;
  padding: 2rem 1.5rem 3rem;
  background: var(--tannengruen);
  flex-wrap: wrap;
}

/* Screen-Reader-only H1 (SEO + Accessibility, visuell versteckt) */
.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;
}

/* Mobile: Buttons stapeln, full-width */
@media (max-width: 820px) {
  .hero {
    padding: 0 !important;
    background: var(--tannengruen) !important;
  }
  .hero-banner {
    padding-top: 64px;
  }
  .hero-cta-bar {
    flex-direction: column;
    padding: 1.5rem 1.25rem 2.5rem;
  }
  .hero-cta-bar .btn {
    width: 100%;
    justify-content: center;
  }
  /* Alte Mobile-Hero-Bild-Regel (Unsplash) deaktivieren */
  .hero::after { content: none !important; display: none !important; }
}

/* ============================================
   FINAL FIX: Slider + große m²-Zahl Aprikot
   (vorheriger Override zielte fälschlich auf .qm-slider
    statt auf das echte Element #qm)
   ============================================ */

/* Track-Fill (Webkit) – Aprikot bis zum Daumen, dann transparent */
#qm::-webkit-slider-runnable-track {
  background: linear-gradient(90deg,
    var(--aprikot) 0%,
    var(--aprikot) var(--fill, 50%),
    rgba(255,255,255,0.15) var(--fill, 50%),
    rgba(255,255,255,0.15) 100%) !important;
}
/* Daumen (Webkit) */
#qm::-webkit-slider-thumb {
  background: var(--aprikot) !important;
  border: 3px solid white !important;
  box-shadow: 0 4px 14px rgba(242,140,90,0.5) !important;
}
/* Firefox: Track, Progress, Daumen */
#qm::-moz-range-track {
  background: rgba(255,255,255,0.15) !important;
}
#qm::-moz-range-progress {
  background: var(--aprikot) !important;
}
#qm::-moz-range-thumb {
  background: var(--aprikot) !important;
  border: 3px solid white !important;
}

/* Große m²-Zahl in Aprikot */
.qm-slider-head .val {
  color: var(--aprikot) !important;
}

/* ============================================
   HERO VOLLBILD: Bild über ganze Breite & Höhe,
   Buttons als Overlay integriert
   ============================================ */
.hero {
  position: relative !important;
  height: 100vh !important;
  min-height: 560px !important;
  max-height: 1040px !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  display: block !important;
  background: var(--tannengruen) !important;
}
.hero-picture {
  position: absolute;
  inset: 0;
  display: block;
}
.hero-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block !important;
}

/* CTA-Buttons über dem Bild – Desktop: unten links über der Terrasse */
.hero-cta-overlay {
  position: absolute;
  left: 8%;
  bottom: 15%;
  display: flex;
  gap: 1rem;
  z-index: 3;
  flex-wrap: wrap;
}
.hero-cta-overlay .btn {
  box-shadow: 0 10px 30px rgba(0,0,0,0.35);
}
/* Ghost-Button über Bild gut lesbar machen */
.hero-cta-overlay .btn-ghost {
  background: rgba(5,68,50,0.45);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-color: rgba(255,255,255,0.6);
  color: white;
}
.hero-cta-overlay .btn-ghost:hover {
  background: white;
  color: var(--tannengruen);
  border-color: white;
}

/* Mobile: anderes Bild (via <picture>), Buttons unten zentriert gestapelt */
@media (max-width: 820px) {
  .hero {
    height: 100vh !important;
    min-height: 480px !important;
    max-height: none !important;
  }
  .hero-cta-overlay {
    left: 50%;
    transform: translateX(-50%);
    bottom: 7%;
    flex-direction: column;
    width: 86%;
    gap: 0.75rem;
  }
  .hero-cta-overlay .btn {
    width: 100%;
    justify-content: center;
  }
  /* Etwaige alte ::after-Regel sicher aus */
  .hero::after { content: none !important; display: none !important; }
}

/* ============================================
   HERO REVISION: volles Banner, kein Crop,
   startet unter der Nav, Buttons überlagert
   (überschreibt den vorherigen Vollbild-Cover-Block)
   ============================================ */
.hero {
  position: relative !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 70px 0 0 !important;   /* Platz für die fixe Nav */
  margin: 0 !important;
  overflow: visible !important;
  background: var(--tannengruen) !important;
  display: block !important;
}
.hero-media {
  position: relative;
  width: 100%;
  max-width: 1600px;
  margin: 0 auto;
  line-height: 0;
}
.hero-picture {
  display: block;
  width: 100%;
}
.hero-img {
  width: 100% !important;
  height: auto !important;          /* volles 16:9 – nichts beschnitten */
  object-fit: unset !important;
  display: block !important;
}

/* Buttons unten links über der Terrasse, relativ zum Bild */
.hero-cta-overlay {
  position: absolute;
  left: 8%;
  bottom: 14%;
  display: flex;
  gap: 1rem;
  z-index: 3;
  line-height: normal;
  flex-wrap: wrap;
}
.hero-cta-overlay .btn {
  box-shadow: 0 10px 30px rgba(0,0,0,0.35);
}
.hero-cta-overlay .btn-ghost {
  background: rgba(5,68,50,0.5);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-color: rgba(255,255,255,0.65);
  color: white;
}
.hero-cta-overlay .btn-ghost:hover {
  background: white;
  color: var(--tannengruen);
  border-color: white;
}

/* Mobile: anderes Bild (über <picture>), Buttons unten zentriert */
@media (max-width: 820px) {
  .hero {
    padding-top: 60px !important;
  }
  .hero-cta-overlay {
    left: 50%;
    transform: translateX(-50%);
    bottom: 6%;
    flex-direction: column;
    width: 86%;
    gap: 0.7rem;
  }
  .hero-cta-overlay .btn {
    width: 100%;
    justify-content: center;
  }
}

/* ============================================
   SORTEN-KACHELN 1/3 INS HERO-BILD RAGEN
   ============================================ */
/* Hero: kein Abstand nach unten, Bild schließt direkt an */
.hero {
  padding-bottom: 0 !important;
  margin-bottom: 0 !important;
}

/* Sorten-Section nach oben ziehen → Kacheln überlappen das Bild.
   Section ist transparent, nur die weißen Kacheln liegen über dem Bild. */
#sorten {
  padding-top: 0 !important;
  margin-top: -150px !important;   /* ≈ 1/3 Kachelhöhe ins Bild */
  position: relative;
  z-index: 5;
  background: transparent !important;
}
#sorten .container { position: relative; z-index: 5; }
#sorten .sorten-grid { position: relative; z-index: 5; }

/* Kräftigerer Schatten, damit die Kacheln über dem Bild abheben */
#sorten .sorte-card {
  box-shadow: 0 24px 60px rgba(5,68,50,0.30) !important;
}

/* Tablet/Mobile: Überlappung kleiner (Kacheln stapeln, Bild kürzer) */
@media (max-width: 1024px) {
  #sorten { margin-top: -120px !important; }
}
@media (max-width: 820px) {
  #sorten { margin-top: -70px !important; }
}

/* ============================================
   HERO FINAL FIX – Vollbreite, full-bleed, korrekte Höhe
   (setzt position:absolute aus früherem Block zurück und
    macht das Bild edge-to-edge statt im 1600px-Container)
   ============================================ */
.hero {
  position: relative !important;
  height: auto !important;
  min-height: 0 !important;
  max-height: none !important;
  padding: 0 !important;            /* Bild schliesst nahtlos an die fixe Nav an (full-bleed) */
  margin: 0 !important;
  overflow: visible !important;
  background: var(--tannengruen) !important;
  display: block !important;
  width: 100% !important;
}
.hero-media {
  position: relative !important;
  width: 100% !important;
  max-width: none !important;       /* VOLLE BREITE – kein Container mehr */
  margin: 0 !important;
  padding: 0 !important;
  line-height: 0 !important;
}
.hero-picture {
  position: static !important;      /* RESET von absolute */
  inset: auto !important;
  display: block !important;
  width: 100% !important;
  line-height: 0 !important;
}
.hero-img {
  position: static !important;      /* RESET */
  inset: auto !important;
  width: 100% !important;
  height: auto !important;          /* natürliche Proportion – kein Zoom, kein Crop */
  max-height: none !important;
  object-fit: unset !important;
  display: block !important;
}

/* Sorten-Kacheln: exakt 1,5 cm ins Bild ragen (auf jedem Web-/Desktop-Screen gleich) */
#sorten {
  margin-top: -1.5cm !important;
  padding-top: 0 !important;
  position: relative;
  z-index: 10;
  background: transparent !important;
}



/* Konsolidierte responsive Überlappung (muss als Letztes stehen) */
@media (max-width: 1024px) {
  #sorten { margin-top: -1.5cm !important; }
}
@media (max-width: 820px) {
  .hero { padding-top: 0 !important; }
  #sorten { margin-top: 28px !important; }  /* Kacheln weiter unter dem Video */
}
@media (max-width: 480px) {
  #sorten { margin-top: 28px !important; }
}

/* ============================================
   SORTEN-KARTEN: Inhalte ausrichten
   Preis + "Diese Sorte konfigurieren" auf einer Linie über alle Karten
   ============================================ */
#sorten .sorte-card {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}
#sorten .sorte-image { flex: 0 0 auto !important; }
#sorten .sorte-content {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 1 auto !important;
}
/* Preis (und die darunter folgende CTA) ans untere Ende drücken → bündig */
#sorten .sorte-price { margin-top: auto !important; }

/* ============================================
   LOGO in der Kontakt-Map-Card (oben rechts)
   ============================================ */
.map-card-logo {
  position: absolute;
  top: 2.5rem;
  right: 2.5rem;
  width: 112px;
  height: 112px;
  object-fit: contain;
  z-index: 2;
  opacity: 0.95;
}
@media (max-width: 600px) {
  .map-card-logo { width: 84px; height: 84px; top: 1.75rem; right: 1.75rem; }
}

/* ============================================
   RECHNER-LAYOUT: Intro breiter, Rechner höher & größer
   ============================================ */
.calc-section .section-intro {
  max-width: 1150px !important;   /* etwas weniger als die Überschriftsbreite */
}
.calc-section .section-header {
  margin-bottom: 2rem !important;
}
.calc-section .calc-wrapper {
  max-width: 780px !important;    /* etwas größer als vorher (640px) */
  margin-top: 1.5rem !important;
}

/* ============================================
   MOBILE HERO: volles Banner unter der Nav (Überschrift im Bild sichtbar)
   Das Querformat-Bild wird NICHT beschnitten; es startet unter der
   Nav-Leiste, damit die eingebackene Überschrift komplett sichtbar ist.
   ============================================ */
@media (max-width: 820px) {
  .hero {
    padding-top: 64px !important;   /* Bild startet unter der Nav → Überschrift sichtbar */
    background: var(--tannengruen) !important;
  }
  .hero-img {
    height: auto !important;        /* volles Bild, natürliche Proportion, kein Crop */
    object-fit: unset !important;
    object-position: center center !important;
  }
}

/* ============================================
   MOBILE SORTEN: kompaktes 2-Spalten-Raster (FINAL – muss zuletzt stehen)
   Tap auf Karte führt direkt zum Rechner, kein Aufklappen → kein Chevron.
   Karte zeigt kompakt: Bild + Name + Preis.
   ============================================ */
@media (max-width: 820px) {
  .sorten-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 0.7rem !important;
  }
  #sorten .sorte-image { aspect-ratio: 3 / 2 !important; }
  #sorten .sorte-content { padding: 0.85rem 0.9rem !important; }
  #sorten .sorte-content::after { display: none !important; } /* kein Chevron */
  #sorten .sorte-content { position: static !important; }     /* Badge wieder relativ zur Karte (über dem Bild) */
  #sorten .sorte-card h3 {
    font-size: 1.08rem !important;
    margin-bottom: 0.4rem !important;
    line-height: 1.15 !important;
  }
  #sorten .sorte-price { font-size: 1.55rem !important; }
  #sorten .sorte-price small { font-size: 0.78rem !important; }
  #sorten .sorte-badge {
    font-size: 0.6rem !important;
    padding: 0.25rem 0.6rem !important;
  }
}
@media (max-width: 380px) {
  #sorten .sorte-card h3 { font-size: 0.98rem !important; }
  #sorten .sorte-price { font-size: 1.4rem !important; }
}

/* ============================================
   MOBILE FINAL: Karte aufklappen (alle Infos) + Mobile-Bestell-Button
   ============================================ */
@media (max-width: 820px) {
  /* Aufgeklappte Karte spannt über beide Spalten → alle Infos gut lesbar */
  #sorten .sorte-card.expanded {
    grid-column: 1 / -1 !important;
  }
  /* im aufgeklappten Zustand Preis natürlich nach dem Text statt unten angedrückt */
  #sorten .sorte-card.expanded .sorte-price { margin-top: 0.7rem !important; }

  /* Chevron-Hinweis (auf der Karte → kollidiert nicht mit dem Badge über dem Bild) */
  #sorten .sorte-card::after {
    content: '';
    position: absolute;
    bottom: 1.05rem;
    right: 1.05rem;
    width: 9px; height: 9px;
    border-right: 2px solid var(--moosgruen);
    border-bottom: 2px solid var(--moosgruen);
    transform: rotate(45deg);
    opacity: 0.5;
    z-index: 3;
    pointer-events: none;
  }
  #sorten .sorte-card.expanded::after { display: none !important; } /* offen: kein Hinweis */
}

/* Mobile-"Jetzt bestellen"-Button: nur am Smartphone, mittig über den Kacheln */
.hero-cta-mobile { display: none; }
@media (max-width: 820px) {
  .hero { position: relative !important; }
  .hero-cta-mobile {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    left: 2rem;                   /* bündig mit der linken Kachel-Außenkante */
    bottom: -38px;                /* unter dem Video, oberer Rand überlappt das Video leicht */
    z-index: 15;
    background: var(--aprikot);
    color: var(--tannengruen);
    font-family: var(--font-body);
    font-weight: 800;
    font-size: 0.92rem;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 0.9rem 1.9rem;
    border-radius: 999px;
    box-shadow: 0 12px 30px rgba(242,140,90,0.45);
    text-decoration: none;
    white-space: nowrap;
  }
  .hero-cta-mobile:active { transform: scale(0.97); }
}

/* Grid bündig an #sorten-Oberkante → Kacheln überlappen exakt um die margin-top der Section (1,5cm) */
#sorten .sorten-grid { margin-top: 0 !important; }

/* ============================================
   MOBILE SORTEN-OVERLAY: angetippte Karte zentriert über allem
   (statt im Grid aufzuklappen) – Tap ausserhalb/innen schliesst,
   nur "Diese Sorte konfigurieren" führt zum Rechner.
   ============================================ */
.sorte-overlay-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(4, 40, 33, 0.66);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  z-index: 9998;
}
.sorte-overlay-backdrop.show { display: block; }
body.card-open { overflow: hidden; }

@media (max-width: 820px) {
  /* offene Karte = zentriertes Overlay (liegt jetzt im Backdrop, daher nicht #sorten-scoped) */
  .sorte-card.expanded {
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    right: auto !important;
    bottom: auto !important;
    transform: translate(-50%, -50%) !important;
    width: min(84vw, 360px) !important;
    max-height: 82vh !important;
    overflow-y: auto !important;
    grid-column: auto !important;
    z-index: 9999 !important;
    border-radius: 16px !important;
    box-shadow: 0 30px 80px rgba(0,0,0,0.45) !important;
    cursor: pointer;
  }
  .sorte-card.expanded .sorte-image { aspect-ratio: 3 / 2 !important; }
  .sorte-card.expanded .sorte-content { position: static !important; } /* Badge über dem Bild statt neben dem Titel */
  .sorte-card.expanded::after,
  .sorte-card.expanded .sorte-content::after { display: none !important; } /* kein Chevron im Overlay */
}

/* ============================================
   KARTEN-CTA als Aprikot-Button mit Glow + animiertem Pfeil
   (kein display setzen → mobile bleibt im Overlay-Logik: collapsed aus, expanded an)
   ============================================ */
.sorte-cta {
  width: fit-content !important;        /* nur so breit wie der Inhalt → kleiner */
  max-width: 100% !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0.5rem !important;
  margin-top: 1rem !important;
  padding: 0.58rem 1rem !important;     /* kompakter */
  border-top: none !important;
  border-radius: 999px !important;
  background: var(--aprikot) !important;
  color: var(--tannengruen) !important;
  font-size: 0.68rem !important;
  font-weight: 800 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  box-shadow: 0 8px 20px rgba(242,140,90,0.42) !important;
  cursor: pointer !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}
.sorte-cta svg { width: 14px !important; height: 14px !important; }
.sorte-card:hover .sorte-cta,
.sorte-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 34px rgba(242,140,90,0.6) !important;
}
/* Pfeil dauerhaft animiert (nach rechts „nudgen") */
.sorte-cta svg {
  stroke: var(--tannengruen) !important;
  animation: ctaArrowNudge 1.3s ease-in-out infinite !important;
  transition: none !important;
}
@keyframes ctaArrowNudge {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(5px); }
}

/* ============================================
   BLÜTENGRÜN – ausverkauft / „bald wieder verfügbar"
   ============================================ */
/* Eck-Badge auf der Karte (rechts oben) */
.sorte-soldout-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 6;
  display: none;
  padding: 0.42rem 0.72rem;
  border-radius: 999px;
  background: rgba(5, 68, 50, 0.92);
  color: #fff;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 6px 18px rgba(0,0,0,0.28);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}
/* Desktop: Karte ist immer „offen" → Badge sichtbar */
@media (min-width: 821px) {
  .sorte-card[data-type="bluetengruen"] .sorte-soldout-badge { display: block; }
}
/* Mobile: nur wenn die Karte geöffnet (Overlay) ist */
.sorte-card.expanded[data-type="bluetengruen"] .sorte-soldout-badge { display: block; }

/* Hinweis im Rechner-Selektor */
.rasen-type .rt-flag {
  margin-top: 0.4rem;
  display: inline-block;
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
  background: rgba(5, 68, 50, 0.1);
  color: var(--tannengruen);
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* „Bald wieder verfügbar"-Notiz im Ergebnis (ersetzt den Bestell-Bereich) */
.sold-out-notice {
  flex-direction: column;
  gap: 0.35rem;
  padding: 1.1rem 1.2rem;
  border-radius: 14px;
  background: rgba(5, 68, 50, 0.06);
  border: 1px dashed rgba(5, 68, 50, 0.4);
  text-align: center;
}
.sold-out-notice strong {
  color: var(--tannengruen);
  font-size: 1.02rem;
  font-weight: 800;
}
.sold-out-notice span {
  color: #4a6b5d;
  font-size: 0.84rem;
  line-height: 1.45;
}

/* Hero-Video: dezenter Platzhalter (Markengrün) bevor der erste Frame geladen ist
   – ersetzt das alte Poster-Bild, damit beim Reload nichts „Altes" aufblitzt */
.hero-video {
  background-color: var(--tannengruen) !important;
}

/* ============================================
   Hero: Desktop = Bild (home_web10.png); Mobil zeigt dasselbe Bild
   (Video-Toggle weiter unten überschrieben -> Bild auch auf Mobil)
   ============================================ */
.hero-pic-desktop { display: block !important; }
.hero-vid-mobile { display: none !important; }
@media (max-width: 820px) {
  .hero-pic-desktop { display: none !important; }
  .hero-vid-mobile { display: block !important; }
}

/* ============================================
   Mobile: nur "48 Stunden" + "9 Bundesländer", Symbol über Text, zentriert
   ============================================ */
@media (max-width: 820px) {
  /* "Heimisch" und "Online bestellen" ausblenden */
  .trust-item:nth-child(3),
  .trust-item:nth-child(4) { display: none !important; }
  /* Zwei Items nebeneinander */
  .trust-grid {
    grid-template-columns: 1fr 1fr !important;
    justify-items: center !important;
    gap: 1.25rem !important;
  }
  /* Symbol oberhalb des Textes, alles zentriert */
  .trust-item {
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    text-align: center !important;
    gap: 0.55rem !important;
  }
}

/* Mobile: Leerraum unter den Kacheln gen\u00e4hert an den \u00fcber den Kacheln (~28px) */
@media (max-width: 820px) {
  #sorten { padding-bottom: 0 !important; margin-bottom: 0 !important; }
  #sorten .sorten-grid { margin-bottom: 0 !important; }
  .trust-strip { padding-top: 28px !important; }
}

/* Map-Card ist jetzt ein Link (Navigation) */
a.map-card { text-decoration: none; color: inherit; cursor: pointer; display: flex; }
a.map-card:hover { transform: translateY(-3px); transition: transform .3s; }
.contact-list .val a { color: inherit; text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(0,105,48,.4); }
.contact-list .val a:hover { text-decoration-color: var(--moosgruen); }

/* ============================================
   RECHTLICHE SEITEN (Impressum / Datenschutz / AGB)
   ============================================ */
.legal-body { background: var(--mint-soft); min-height: 100vh; display: flex; flex-direction: column; }
.legal-header {
  background: var(--tannengruen);
  padding: 1rem 1.5rem;
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
}
.legal-header .legal-logo { display: inline-flex; }
.legal-header .legal-logo img { height: 40px; width: auto; display: block; }
.legal-back { color: #fff; text-decoration: none; font-size: .85rem; font-weight: 600; opacity: .85; white-space: nowrap; }
.legal-back:hover { opacity: 1; }
.legal-main { flex: 1; width: 100%; max-width: 840px; margin: 0 auto; padding: 2.5rem 1.25rem 3.5rem; }
.legal-card {
  background: #fff; border: 1px solid var(--line); border-radius: 18px;
  padding: 2.5rem; box-shadow: 0 12px 40px rgba(5,68,50,.06);
}
.legal-card h1 { color: var(--tannengruen); font-size: 1.9rem; line-height: 1.15; margin: 0 0 .4rem; }
.legal-card .legal-sub { color: #4a6b5d; font-size: .9rem; margin-bottom: 1.6rem; }
.legal-card h2 { color: var(--moosgruen); font-size: 1.12rem; margin: 1.9rem 0 .5rem; }
.legal-card p, .legal-card li { color: #2c3a33; font-size: .94rem; line-height: 1.62; }
.legal-card p { margin: .5rem 0; }
.legal-card ul { padding-left: 1.2rem; margin: .4rem 0 .8rem; }
.legal-card li { margin: .2rem 0; }
.legal-card a { color: var(--moosgruen); }
.legal-note {
  background: rgba(242,140,90,.12); border: 1px dashed var(--aprikot);
  border-radius: 12px; padding: .9rem 1.1rem; margin: 1.4rem 0; font-size: .86rem; color: #5a3a26;
}
.legal-table { width: 100%; border-collapse: collapse; margin: .4rem 0 1rem; }
.legal-table td { padding: .45rem .2rem; border-bottom: 1px solid var(--line); font-size: .92rem; vertical-align: top; }
.legal-table td:first-child { font-weight: 700; color: var(--tannengruen); width: 44%; padding-right: 1rem; }
.legal-foot { text-align: center; padding: 1.8rem 1.25rem 2.4rem; color: var(--tannengruen); font-size: .85rem; }
.legal-foot a { color: var(--tannengruen); text-decoration: none; margin: 0 .35rem; }
.legal-foot a:hover { text-decoration: underline; }
@media (max-width: 560px) {
  .legal-card { padding: 1.6rem 1.3rem; }
  .legal-card h1 { font-size: 1.55rem; }
  .legal-table td:first-child { width: 100%; display: block; border: none; padding-bottom: 0; }
  .legal-table td { display: block; border-bottom: none; padding: .1rem .2rem; }
  .legal-table tr { display: block; border-bottom: 1px solid var(--line); padding: .4rem 0; }
}

/* ===== Admin-Bereich (AGB-Seite) ===== */
.admin-trigger { margin-top: 2.5rem; text-align: center; }
.admin-trigger button {
  background: none; border: 1px solid var(--line); color: #8a9a90;
  padding: .5rem .9rem; border-radius: 999px; font-size: .78rem; cursor: pointer; font-weight: 600;
}
.admin-trigger button:hover { color: var(--tannengruen); border-color: var(--tannengruen); }
.admin-box { margin-top: 1.2rem; border: 1px solid var(--line); border-radius: 14px; padding: 1.4rem; background: #f6faf4; display: none; }
.admin-box.open { display: block; }
.admin-box h3 { color: var(--tannengruen); margin: 0 0 .3rem; font-size: 1.1rem; }
.admin-row { display: flex; gap: .6rem; align-items: center; margin: .8rem 0; flex-wrap: wrap; }
.admin-box label { font-size: .82rem; color: #2c3a33; font-weight: 600; }
.admin-box input {
  font: inherit; padding: .45rem .6rem; border: 1px solid var(--line); border-radius: 8px; width: 100px;
}
.admin-grp { margin: 1.2rem 0; }
.admin-grp > .admin-grp-title { font-weight: 800; color: var(--moosgruen); font-size: .82rem; text-transform: uppercase; letter-spacing: .05em; margin-bottom: .5rem; }
.admin-table { width: 100%; border-collapse: collapse; font-size: .85rem; }
.admin-table th, .admin-table td { padding: .35rem .4rem; text-align: left; border-bottom: 1px solid var(--line); }
.admin-table th { color: var(--tannengruen); font-size: .74rem; text-transform: uppercase; letter-spacing: .04em; }
.admin-table input { width: 78px; }
.admin-actions { display: flex; gap: .6rem; margin-top: 1.2rem; flex-wrap: wrap; }
.admin-actions button { font: inherit; font-weight: 700; padding: .6rem 1.1rem; border-radius: 999px; cursor: pointer; border: none; }
.btn-save { background: var(--moosgruen); color: #fff; }
.btn-reset { background: #fff; color: var(--tannengruen); border: 1px solid var(--line) !important; }
.admin-msg { margin-top: .8rem; font-size: .85rem; font-weight: 700; color: var(--moosgruen); }
.admin-hint { font-size: .8rem; color: #5a3a26; background: rgba(242,140,90,.12); border: 1px dashed var(--aprikot); border-radius: 10px; padding: .7rem .9rem; margin-top: 1rem; }

/* ============================================
   Rechner: Höhe richtet sich nach dem AKTIVEN Schritt (Desktop)
   Steps absolut gestapelt; die Wrap-Höhe wird per JS auf den
   aktiven Step gesetzt und sanft animiert → kein hartes Springen,
   aber Schritt 1 bleibt klein (nicht auf Kalenderhöhe aufgebläht).
   ============================================ */
@media (min-width: 821px) {
  .cstep-wrap {
    position: relative;
    transition: height 0.4s cubic-bezier(0.4, 0, 0.2, 1);
    overflow: hidden;
  }
  .cstep-wrap > .cstep {
    position: absolute;
    top: 0; left: 0;
    width: 100%;
    margin: 0 !important;
  }
  .cstep {
    display: block !important;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
  }
  .cstep.is-active {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
  }
}

/* ============================================
   Admin: Footer-Button + Overlay-Modal
   ============================================ */
.footer-admin {
  background: none; border: none; padding: 0; cursor: pointer;
  color: #fff; opacity: 0.4; font-size: 0.9rem; font-family: inherit;
  transition: opacity 0.3s, color 0.3s;
}
.footer-admin:hover { opacity: 1; color: var(--mintgruen); }

.admin-overlay {
  display: none; position: fixed; inset: 0; z-index: 9999;
  background: rgba(3, 30, 22, 0.6);
  -webkit-backdrop-filter: blur(3px); backdrop-filter: blur(3px);
  padding: 1.5rem; overflow-y: auto;
}
.admin-overlay.open { display: flex; align-items: flex-start; justify-content: center; }
.admin-modal {
  background: #fff; border-radius: 16px; padding: 1.8rem 1.8rem 1.6rem;
  max-width: 640px; width: 100%; margin: auto; position: relative;
  box-shadow: 0 30px 80px rgba(0,0,0,.3);
}
.admin-modal h3 { color: var(--tannengruen); margin: 0 0 .3rem; font-size: 1.15rem; }
.admin-close {
  position: absolute; top: .7rem; right: .9rem;
  background: none; border: none; font-size: 1.7rem; line-height: 1;
  color: #8a9a90; cursor: pointer; padding: .2rem .4rem;
}
.admin-close:hover { color: var(--tannengruen); }
body.admin-open { overflow: hidden; }
@media (max-width: 560px) {
  .admin-overlay { padding: .8rem; }
  .admin-modal { padding: 1.4rem 1.2rem; }
}

/* ============================================
   Kalender kompakter (Desktop) – damit Schritt 4 nicht riesig wird
   ============================================ */
@media (min-width: 821px) {
  .calendar { padding: 1rem; }
  .cal-header { margin-bottom: 0.7rem; }
  .cal-day { aspect-ratio: auto; height: 42px; }
  .cal-hint { margin-top: 0.7rem; }
}

/* ============================================
   Preisübersicht ersetzt den Rechner (statt darunter)
   ============================================ */
.calc-wrapper.wizard-done .calc-card { display: none !important; }
.result-back {
  align-self: flex-start;
  background: none;
  border: 1.5px solid var(--aprikot);
  color: var(--aprikot);
  border-radius: 999px;
  font-family: inherit;
  font-weight: 700;
  font-size: 0.8rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  cursor: pointer;
  padding: 0.5rem 1.1rem;
  margin-bottom: 1.25rem;
  transition: background 0.2s, color 0.2s;
}
.result-back:hover { background: var(--aprikot); color: var(--tannengruen); }

/* Pflichtfeld-Fehlermeldung im Rechner */
.calc-error {
  display: none;
  margin-top: 0.7rem;
  color: #ffb38f;
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.4;
}
.calc-error.show { display: block; }
.calc-field select.invalid { border-color: #ffb38f !important; box-shadow: 0 0 0 2px rgba(255,179,143,0.25) !important; }

/* ============================================
   Preisübersicht im Stil der Rechner-Karte (dunkelgrün, heller Text)
   ============================================ */
.calc-result {
  background: #043829 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border-color: rgba(255,255,255,0.08) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,0.15) !important;
  color: #fff !important;
}
/* Kopf */
.calc-result .calc-result-head .label { color: rgba(255,255,255,0.55) !important; }
.calc-result .calc-result-head .dot { background: var(--mintgruen) !important; }
/* Preis */
.calc-result .result-price { color: #fff !important; }
.calc-result .result-price small { color: var(--mintgruen) !important; }
.calc-result .result-disclaimer { color: rgba(255,255,255,0.55) !important; opacity: 1 !important; }
/* Breakdown-Box */
.calc-result .result-breakdown {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
}
.calc-result .breakdown-row { border-bottom-color: rgba(255,255,255,0.12) !important; }
.calc-result .breakdown-row .lbl { color: rgba(255,255,255,0.7) !important; opacity: 1 !important; }
.calc-result .breakdown-row .val { color: #fff !important; }
.calc-result .breakdown-row.delivery-row { border-bottom-color: rgba(255,255,255,0.2) !important; }
.calc-result .breakdown-row.delivery-row .lbl,
.calc-result .breakdown-row.delivery-row .val { color: var(--mintgruen) !important; }
.calc-result .breakdown-row.subtotal { border-top-color: rgba(255,255,255,0.2) !important; }
.calc-result .breakdown-row.subtotal .lbl,
.calc-result .breakdown-row.subtotal .val { color: #fff !important; }
.calc-result .breakdown-row.total { border-top-color: var(--aprikot) !important; }
.calc-result .breakdown-row.total .lbl { color: #fff !important; }
.calc-result .breakdown-row.total .val { color: var(--aprikot) !important; }
/* Bonus-Box */
.calc-result .bonus-info { border-color: rgba(255,255,255,0.14) !important; }
.calc-result .bonus-eyebrow { color: var(--mintgruen) !important; }
.calc-result .bonus-title { color: #fff !important; }
.calc-result .bonus-text { color: rgba(255,255,255,0.7) !important; opacity: 1 !important; }
/* Trust + Trenner */
.calc-result .buy-trust { color: rgba(255,255,255,0.5) !important; opacity: 1 !important; }
.calc-result .form-divider { color: rgba(255,255,255,0.4) !important; opacity: 1 !important; }
.calc-result .form-divider::before,
.calc-result .form-divider::after { background: rgba(255,255,255,0.15) !important; }
/* Buttons – wie im Wizard: Apricot primär, Outline sekundär */
.calc-result .btn-buy { background: var(--aprikot) !important; color: var(--tannengruen) !important; }
.calc-result .btn-buy:hover { background: #ed7a45 !important; box-shadow: 0 12px 28px rgba(242,140,90,0.4) !important; }
.calc-result .btn-request {
  background: transparent !important;
  color: #fff !important;
  border: 1.5px solid rgba(255,255,255,0.3) !important;
}
.calc-result .btn-request:hover {
  background: rgba(255,255,255,0.1) !important;
  color: #fff !important;
  box-shadow: none !important;
}
/* Sold-Out-Hinweis */
.calc-result .sold-out-notice {
  background: rgba(255,255,255,0.04) !important;
  border: 1px dashed rgba(255,255,255,0.25) !important;
}
.calc-result .sold-out-notice strong { color: #fff !important; }
.calc-result .sold-out-notice span { color: rgba(255,255,255,0.7) !important; }

/* ============================================
   Desktop: Abstand zwischen Kacheln und Trust-Strip kleiner
   ============================================ */
@media (min-width: 821px) {
  #sorten { padding-bottom: 1.25rem !important; }
}

/* ============================================
   Desktop: Trust-Items zentriert unter der jeweiligen Kachel
   (Gap an Sorten-Grid angeglichen → Spalten liegen exakt unter den Kacheln)
   ============================================ */
@media (min-width: 821px) {
  .trust-grid {
    gap: 1.5rem !important;
    justify-items: center !important;
  }
  .trust-item {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    gap: 0.55rem !important;
  }
}

/* ============================================
   Mobile: Rechner-Karten mit runden Ecken (wie Desktop)
   ============================================ */
@media (max-width: 820px) {
  .calc-wrapper {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  .calc-card,
  .calc-result {
    border-radius: 20px !important;
    border-left: 1px solid rgba(255,255,255,0.08) !important;
    border-right: 1px solid rgba(255,255,255,0.08) !important;
    width: auto !important;
  }
}

/* ============================================
   Preisrechner: Kopf (Eyebrow, Überschrift, Intro) zentriert – Web & Mobil
   ============================================ */
.calc-section .section-header {
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
}
.calc-section .section-header > div { width: 100%; }
.calc-section .section-eyebrow { justify-content: center !important; }
.calc-section .section-intro { margin-left: auto !important; margin-right: auto !important; }

/* ============================================
   Admin-Login: schöne PIN-Abfrage
   ============================================ */
#adminLogin { text-align: center; padding: 1.5rem 0.5rem 0.75rem; }
.admin-lock {
  width: 58px; height: 58px; margin: 0 auto 1rem;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: rgba(0,105,48,0.1); color: var(--moosgruen);
}
#adminLogin h3 { margin: 0 0 0.3rem; color: var(--tannengruen); font-size: 1.3rem; }
.admin-login-sub { color: #5a6b62; font-size: 0.92rem; margin: 0 0 1.5rem; }
.pin-input { display: flex; gap: 0.7rem; justify-content: center; }
.pin-digit {
  width: 54px; height: 64px; text-align: center;
  font-size: 1.6rem; font-weight: 700; color: var(--tannengruen);
  border: 2px solid var(--line); border-radius: 14px; background: #f6faf4;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
  -moz-appearance: textfield; appearance: none;
}
.pin-digit::-webkit-outer-spin-button,
.pin-digit::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.pin-digit:focus {
  outline: none; border-color: var(--moosgruen); background: #fff;
  box-shadow: 0 0 0 4px rgba(0,105,48,0.12);
}
.pin-digit.filled { border-color: var(--moosgruen); }
.pin-input.error .pin-digit { border-color: #e0573e; animation: pinShake 0.4s; }
.admin-err {
  display: none; color: #c0392b; font-size: 0.85rem; font-weight: 600; margin-top: 1.1rem;
}
.admin-err.show { display: block; }
@keyframes pinShake {
  0%,100% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-4px); }
  80% { transform: translateX(4px); }
}
@media (max-width: 420px) {
  .pin-digit { width: 48px; height: 58px; font-size: 1.4rem; }
}

/* ============================================
   Admin-Panel: schönere Eingabemaske
   ============================================ */
.admin-panel-head { margin-bottom: 1.1rem; }
.admin-panel-head h3 { margin: 0 0 .25rem; color: var(--tannengruen); font-size: 1.3rem; }
.admin-sub { font-size: .85rem; color: #5a6b62; margin: 0; line-height: 1.45; }

.admin-card {
  background: #f4f9f2;
  border: 1px solid #e1ebdd;
  border-radius: 14px;
  padding: 1.1rem 1.1rem 1.2rem;
  margin-bottom: 1rem;
}
.admin-card-title {
  font-weight: 800; color: var(--moosgruen); font-size: .76rem;
  text-transform: uppercase; letter-spacing: .07em; margin-bottom: .85rem;
}
.admin-note { font-size: .78rem; color: #5a6b62; margin: -.3rem 0 .8rem; line-height: 1.4; }

.admin-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: .8rem;
}
.admin-field { display: flex; flex-direction: column; gap: .35rem; }
.admin-field label { font-size: .8rem; font-weight: 600; color: var(--tannengruen); }
.admin-input {
  display: flex; align-items: stretch;
  border: 1.5px solid #d8e4d2; border-radius: 10px; overflow: hidden;
  background: #fff; transition: border-color .2s, box-shadow .2s;
}
.admin-input:focus-within {
  border-color: var(--moosgruen);
  box-shadow: 0 0 0 3px rgba(0,105,48,.1);
}
.admin-input input {
  flex: 1; min-width: 0; border: none !important; outline: none;
  background: transparent; padding: .55rem .7rem; font: inherit;
  font-weight: 700; color: var(--tannengruen);
}
.admin-input input::-webkit-outer-spin-button,
.admin-input input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.admin-input .adorn {
  display: flex; align-items: center; padding: 0 .75rem;
  background: rgba(0,105,48,.07); color: var(--moosgruen);
  font-weight: 700; font-size: .82rem;
}

/* Tabelle Zustellpreise */
.admin-table-wrap { overflow-x: auto; border-radius: 10px; }
.admin-table { width: 100%; border-collapse: collapse; font-size: .84rem; min-width: 420px; }
.admin-table thead th {
  background: rgba(0,105,48,.08); color: var(--tannengruen);
  font-size: .7rem; text-transform: uppercase; letter-spacing: .04em;
  padding: .5rem .55rem; text-align: left; border: none;
}
.admin-table thead th:first-child { border-radius: 8px 0 0 8px; }
.admin-table thead th:last-child { border-radius: 0 8px 8px 0; }
.admin-table tbody td { padding: .3rem .4rem; border-bottom: 1px solid #e6efe2; }
.admin-table tbody tr:last-child td { border-bottom: none; }
.admin-table tbody td:first-child { font-weight: 600; color: var(--tannengruen); white-space: nowrap; }
.admin-table tbody input {
  width: 72px; border: 1.5px solid #d8e4d2 !important; border-radius: 8px;
  padding: .35rem .45rem; font: inherit; font-weight: 600; color: var(--tannengruen);
  background: #fff; outline: none; transition: border-color .2s, box-shadow .2s;
}
.admin-table tbody input:focus { border-color: var(--moosgruen) !important; box-shadow: 0 0 0 3px rgba(0,105,48,.1); }
.admin-table tbody input::-webkit-outer-spin-button,
.admin-table tbody input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* Aktionen */
.admin-actions { display: flex; gap: .7rem; margin-top: 1.2rem; flex-wrap: wrap; }
.admin-actions .btn-save,
.admin-actions .btn-reset {
  font: inherit; font-weight: 700; padding: .7rem 1.4rem; border-radius: 999px;
  cursor: pointer; transition: background .2s, box-shadow .2s, transform .1s;
}
.admin-actions .btn-save { background: var(--moosgruen); color: #fff; border: none; }
.admin-actions .btn-save:hover { background: var(--tannengruen); box-shadow: 0 8px 20px rgba(0,105,48,.25); }
.admin-actions .btn-reset { background: #fff; color: var(--tannengruen); border: 1.5px solid #d8e4d2 !important; }
.admin-actions .btn-reset:hover { background: #f4f9f2; }
.admin-actions button:active { transform: translateY(1px); }
.admin-msg { margin-top: .9rem; font-size: .85rem; font-weight: 700; }

/* Kontakt-Kachel: Firmenname oben gut lesbar (Weiß auf Tannengrün) */
.map-card-top h3 { color: #ffffff !important; }

/* ============================================
   Kontakt-Kachel: "Klagenfurt" in der verspielten Display-Schrift
   ============================================ */
.map-card-bottom .city {
  font-family: var(--font-display) !important;
  font-style: italic !important;
  font-weight: 600 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* Mobil: Logo in der Kontakt-Kachel halb so groß */
@media (max-width: 820px) {
  .map-card-logo { width: 56px; height: 56px; top: 1.75rem; right: 1.75rem; }
}
@media (max-width: 600px) {
  .map-card-logo { width: 42px; height: 42px; top: 1.5rem; right: 1.5rem; }
}

/* ============================================
   Subtile Apricot-Animationen im Rechner
   ============================================ */
/* Schritt 1 – aktive Rasensorte: helleres Apricot-Segment gleitet langsam am Rahmen entlang */
@property --mpgAngle { syntax: '<angle>'; inherits: false; initial-value: 0deg; }
.rasen-type.active { position: relative; }
.rasen-type.active::after {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  padding: 2px;
  background: conic-gradient(from var(--mpgAngle),
    var(--aprikot) 0deg,
    var(--aprikot) 285deg,
    #ffc99e 318deg,
    #ffe6cd 340deg,
    #ffc99e 355deg,
    var(--aprikot) 360deg);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  animation: mpgSeg 8s linear infinite;
  pointer-events: none;
  z-index: 3;
}
@keyframes mpgSeg { to { --mpgAngle: 360deg; } }

/* Schritt 2 – Slider-Punkt: dezent pulsierender Apricot-Ring */
@keyframes mpgThumbPulse {
  0%, 100% { box-shadow: 0 4px 12px rgba(242,140,90,0.4), 0 0 0 0 rgba(242,140,90,0.5); }
  50%      { box-shadow: 0 4px 12px rgba(242,140,90,0.4), 0 0 0 8px rgba(242,140,90,0); }
}

/* Schritt 3 – Bundesland "Bitte wählen…": Helligkeit pulsiert dezent in Apricot */
.calc-field select:required:invalid {
  animation: mpgBittePulse 2.6s ease-in-out infinite;
}
@keyframes mpgBittePulse {
  0%, 100% { color: rgba(242,140,90,0.6); }
  50%      { color: rgba(242,140,90,1); }
}

/* Schritt 4 – gewähltes Datum: gleiches helleres Apricot-Segment gleitet am Rand entlang */
.cal-day.selected { position: relative; }
.cal-day.selected::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 2px;
  background: conic-gradient(from var(--mpgAngle),
    rgba(242,140,90,0) 0deg,
    rgba(242,140,90,0) 280deg,
    rgba(255,214,178,0.9) 315deg,
    #fff1e0 340deg,
    rgba(255,214,178,0.9) 355deg,
    rgba(242,140,90,0) 360deg);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  animation: mpgSeg 6s linear infinite;
  pointer-events: none;
  z-index: 3;
}

/* Bewegung reduzieren, wenn vom Nutzer gewünscht */
@media (prefers-reduced-motion: reduce) {
  .rasen-type.active::after,
  .qm-slider input[type=range]::-webkit-slider-thumb,
  .qm-slider input[type=range]::-moz-range-thumb,
  .calc-field select:required:invalid,
  .cal-day.selected::after { animation: none !important; }
}

/* Admin: hervorgehobene Zuschlag-Karte */
.admin-card.admin-card-accent {
  background: #fff4ec;
  border-color: #f3c9ad;
}
.admin-card.admin-card-accent .admin-card-title { color: #c2622f; }

/* ============================================
   Hero Desktop: Bild im 21:4-Format, volle Breite, alles rückt nach oben
   ============================================ */
@media (min-width: 821px) {
  .hero {
    min-height: 0 !important;
    height: auto !important;
    display: block !important;
    padding: 83px 0 0 0 !important;   /* nur Platz für die fixe Navigation */
    overflow: hidden !important;
  }
  .hero-media {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 0 !important;
  }
  .hero-pic-desktop {
    display: block !important;
    width: 100% !important;
    height: auto !important;                  /* echte Bildproportion */
    object-fit: unset !important;
    clip-path: inset(4cm 0 7cm 0) !important;   /* oben 4 cm, unten 7 cm wegschneiden */
    margin: -4cm 0 -7cm 0 !important;            /* Layout oben & unten nach innen ziehen -> kein Spalt */
  }
  /* Kacheln ragen etwas ins Titelbild – alles darunter rückt entsprechend nach oben */
  #sorten { margin-top: calc(-35px - 1.5cm) !important; }
}

/* Desktop: Abstand Kacheln -> Trust-Streifen halbieren */
@media (min-width: 821px) {
  .trust-strip { padding-top: 1.25rem !important; }
}

/* Mobil: dasselbe Hero-Bild wie auf Desktop (statt Video) */
@media (max-width: 820px) {
  .hero-pic-desktop { display: block !important; }
  .hero-vid-mobile { display: none !important; }
}

/* Mobil: Hero-Bild als kompaktes Banner – mittiger Ausschnitt statt dünnem Streifen */
@media (max-width: 820px) {
  .hero-pic-desktop {
    width: 100% !important;
    height: 200px !important;
    object-fit: cover !important;
    object-position: center !important;
  }
}

/* ============================================
   FIX: Hero-Überschrift (h1) ist nur für SEO/Screenreader gedacht.
   Alte .hero h1-Regeln (höhere Spezifität) durften sie auf Mobil sichtbar
   machen. Hier zwingend ausblenden – das Hero ist ein Bild, keine Text-Headline.
   ============================================ */
.hero h1,
.hero h1.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  border: 0 !important;
  font-size: 0 !important;
  line-height: 0 !important;
}

/* ============================================
   Mobil: Kacheln ragen leicht ins Hero-Bild (wie auf Desktop, -35px)
   – ersetzt die alten +28px ("weiter unter dem Video")
   ============================================ */
@media (max-width: 820px) {
  #sorten { margin-top: -35px !important; }
}

/* ============================================
   Detailansicht (Overlay): Zurück-Pfeil oben links, Pfeil in Aprikot
   – nur sichtbar wenn die Karte expandiert ist (per JS eingefügt)
   ============================================ */
.sorte-back {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 4;
  width: 40px;
  height: 40px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.94);
  color: var(--aprikot);            /* Pfeil (currentColor) in Aprikot */
  display: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.28);
  -webkit-tap-highlight-color: transparent;
  transition: background 0.2s, transform 0.15s;
}
.sorte-back:hover,
.sorte-back:active {
  background: #ffffff;
  transform: scale(1.06);
}
.sorte-card.expanded .sorte-back { display: flex; }

/* ============================================
   NAV: Menü exakt mittig (über den Kacheln) + mehr Abstand
   Nur Desktop. Menü wird aus dem Flex-Fluss genommen und
   auf Seitenmitte zentriert -> Logo links, Button rechts.
   ============================================ */
@media (min-width: 821px) {
  .nav-menu {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
    gap: 3.5rem !important;   /* mehr Platz zwischen den Punkten (vorher 2.5rem) */
  }
}
