/* ════════════════════════════════════════
   Hero
   ════════════════════════════════════════ */
.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  background: var(--brown-dark);
}

.hero-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(160deg,
      rgba(61,43,31,0.82) 0%,
      rgba(61,43,31,0.55) 50%,
      rgba(160,120,80,0.45) 100%),
    url('https://images.unsplash.com/photo-1567206563114-c179706a56a4?auto=format&fit=crop&w=1600&q=75')
    center / cover no-repeat;
}

.hero-content {
  position: relative;
  z-index: 1;
  color: var(--cream);
  max-width: 720px;
  padding: var(--space-md);
}

.hero-eyebrow {
  font-family: var(--font-script);
  font-size: clamp(2rem, 6vw, 4rem);
  color: var(--sand-light);
  display: block;
  margin-bottom: 0.5rem;
  line-height: 1.1;
}

.hero h1 {
  color: var(--cream);
  letter-spacing: 0.01em;
  margin-bottom: var(--space-sm);
}

.hero-tagline {
  font-size: 0.9rem;
  color: rgba(253,248,240,0.75);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: var(--space-md);
}

.hero-cta {
  display: flex;
  gap: var(--space-sm);
  justify-content: center;
  flex-wrap: wrap;
}

.hero-meta {
  margin-top: var(--space-md);
  font-size: 0.82rem;
  color: var(--sand-light);
  letter-spacing: 0.08em;
}
.hero-meta strong { color: var(--cream); }

/* Scroll-Pfeil */
.scroll-hint {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(253,248,240,0.5);
  font-size: 1.5rem;
  animation: bounce 2s infinite;
}
@keyframes bounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(8px); }
}

/* ════════════════════════════════════════
   Versprechen (3 Highlights)
   ════════════════════════════════════════ */
.versprechen {
  background: var(--cream-dark);
}

.versprechen-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-md);
}

/* ════════════════════════════════════════
   Teaser-Blöcke (Sorten / Über uns)
   ════════════════════════════════════════ */
.teaser-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-lg);
  align-items: center;
}
.teaser-block.reverse { direction: rtl; }
.teaser-block.reverse > * { direction: ltr; }

.teaser-img {
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 4 / 3;
}
.teaser-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.teaser-img:hover img { transform: scale(1.04); }

.teaser-text .eyebrow {
  font-family: var(--font-script);
  font-size: 1.6rem;
  color: var(--terracotta);
  display: block;
  margin-bottom: 0.4rem;
}
.teaser-text p {
  color: var(--text-secondary);
  line-height: 1.75;
  margin-bottom: var(--space-md);
}

@media (max-width: 768px) {
  .teaser-block,
  .teaser-block.reverse { grid-template-columns: 1fr; direction: ltr; }
}

/* ════════════════════════════════════════
   Saisonales Banner
   ════════════════════════════════════════ */
.seasonal-band {
  background: var(--terracotta);
  color: var(--white);
  text-align: center;
  padding: var(--space-md) var(--space-md);
}
.seasonal-band h2 { color: var(--white); margin-bottom: 0.5rem; }
.seasonal-band p  { color: rgba(255,255,255,0.85); margin-bottom: var(--space-sm); max-width: 560px; margin-inline: auto; }

/* ════════════════════════════════════════
   Öffnungszeiten-Leiste (Homepage)
   ════════════════════════════════════════ */
.hours-bar {
  background: var(--brown-dark);
  color: var(--cream);
  padding: var(--space-md) 0;
}
.hours-bar-inner {
  display: flex;
  gap: var(--space-lg);
  justify-content: center;
  flex-wrap: wrap;
  text-align: center;
}
.hours-item .label {
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--sand-light);
  display: block;
  margin-bottom: 0.3rem;
}
.hours-item .value {
  font-family: var(--font-serif);
  font-size: 1.1rem;
  color: var(--cream);
}
