/* ============================================================
   header
   ============================================================ */
/* =========================================================
   FÓRNOVA — Header / Navigation (sektions-spezifisch)
   Alle Selektoren mit .fv-header (Kollisionsschutz). Mobile-first.
   ========================================================= */

.fv-header {
  position: sticky;
  top: 0;
  z-index: 100;
  /* Mobile: KEIN backdrop-filter — sonst wird das fixed Mobile-Menü
     am Header statt am Viewport ausgerichtet (Containing-Block-Falle).
     Blur kommt erst ab Desktop dazu (siehe Media-Query unten). */
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  border-bottom: 1px solid var(--line-soft);
  transition: background .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease);
}

.fv-header.is-scrolled {
  background: color-mix(in srgb, var(--paper) 92%, transparent);
  border-bottom-color: var(--line);
  box-shadow: var(--shadow-soft);
}

.fv-header__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 4.5rem;
  padding-block: .85rem;
  transition: min-height .3s var(--ease), padding-block .3s var(--ease);
}

.fv-header.is-scrolled .fv-header__bar {
  min-height: 3.75rem;
  padding-block: .5rem;
}

/* ---- Wortmarke ---- */
.fv-header__brand {
  position: relative;
  z-index: 101; /* über dem Mobile-Panel (z 90) sichtbar bleiben */
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(1.5rem, 1.2rem + 1vw, 1.85rem);
  letter-spacing: -0.01em;
  line-height: 1;
  color: var(--ink);
  white-space: nowrap;
}
.fv-header__accent { color: var(--tomato); }

/* ---- Aktionsbereich rechts ---- */
.fv-header__actions {
  position: relative;
  z-index: 101; /* Burger/X über dem Mobile-Panel klickbar halten */
  display: flex;
  align-items: center;
  gap: .75rem;
}

/* CTA auf kleinen Screens ausblenden (liegt im Mobile-Panel) */
.fv-header__cta { display: none; }
.fv-header__cta--mobile { display: inline-flex; margin-top: 1.5rem; }

/* ---- Burger ---- */
.fv-header__burger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  margin-right: -.4rem;
  border-radius: var(--radius);
  color: var(--ink);
}
.fv-header__burger-box {
  position: relative;
  display: block;
  width: 24px;
  height: 16px;
}
.fv-header__burger-line {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  border-radius: 2px;
  background: currentColor;
  transition: transform .3s var(--ease), opacity .2s var(--ease), top .3s var(--ease);
}
.fv-header__burger-line:nth-child(1) { top: 0; }
.fv-header__burger-line:nth-child(2) { top: 7px; }
.fv-header__burger-line:nth-child(3) { top: 14px; }

.fv-header__burger[aria-expanded="true"] .fv-header__burger-line:nth-child(1) {
  top: 7px;
  transform: rotate(45deg);
}
.fv-header__burger[aria-expanded="true"] .fv-header__burger-line:nth-child(2) {
  opacity: 0;
}
.fv-header__burger[aria-expanded="true"] .fv-header__burger-line:nth-child(3) {
  top: 7px;
  transform: rotate(-45deg);
}

/* ---- Mobile-Nav: Vollflächiges Panel ---- */
.fv-header__nav {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(2rem, 8vw, 4rem);
  background: var(--paper);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-1.5rem);
  transition: opacity .35s var(--ease), transform .35s var(--ease), visibility .35s var(--ease);
}
.fv-header__nav.is-open {
  opacity: 1;
  visibility: visible;
  transform: none;
}

.fv-header__list {
  display: flex;
  flex-direction: column;
  gap: .25rem;
}
.fv-header__link {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 1.2rem + 3vw, 2.4rem);
  font-weight: 460;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--ink);
  padding: .35rem 0;
  transition: color .2s var(--ease);
}
.fv-header__link:hover { color: var(--tomato); }

/* ---- Desktop ---- */
@media (min-width: 720px) {
  /* Desktop: Menü ist statisch -> Blur ist hier gefahrlos */
  .fv-header {
    background: color-mix(in srgb, var(--paper) 82%, transparent);
    -webkit-backdrop-filter: saturate(140%) blur(12px);
    backdrop-filter: saturate(140%) blur(12px);
  }
  .fv-header.is-scrolled {
    background: color-mix(in srgb, var(--paper) 88%, transparent);
  }

  .fv-header__burger { display: none; }
  .fv-header__cta { display: inline-flex; }
  .fv-header__cta--mobile { display: none; }

  .fv-header__nav {
    position: static;
    inset: auto;
    z-index: auto;
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
    padding: 0;
    background: transparent;
    opacity: 1;
    visibility: visible;
    transform: none;
  }

  .fv-header__list {
    flex-direction: row;
    align-items: center;
    gap: clamp(1.25rem, 2.5vw, 2.25rem);
  }
  .fv-header__link {
    font-family: var(--font-sans);
    font-size: .95rem;
    font-weight: 500;
    letter-spacing: 0;
    padding: .4rem 0;
    position: relative;
  }
  .fv-header__link::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background: var(--tomato);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .25s var(--ease);
  }
  .fv-header__link:hover::after { transform: scaleX(1); }
}


/* ============================================================
   hero
   ============================================================ */
/* =========================================================
   FÓRNOVA — Sektion: Hero (Kollisionsschutz: .fv-hero)
   Mobile-first, editorial-asymmetrisch.
   ========================================================= */

.fv-hero {
  padding-top: clamp(3.5rem, 9vw, 7rem);
  overflow: hidden;
}

.fv-hero__grid {
  display: grid;
  gap: clamp(2rem, 6vw, 3.5rem);
}

.fv-hero__copy {
  align-self: center;
}

.fv-hero__copy .display {
  margin-block: 0.2rem 0.4rem;
}

/* Detail-Streifen — getrennt durch feine Punkte */
.fv-hero__detail {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  column-gap: 0.8rem;
  row-gap: 0.4rem;
  /* margin-top: 1.6rem; entfernt, da die Klasse .stack bereits margin-top hinzufügt */
  padding-top: 1rem;
  border-top: 1px solid var(--line);
  font-family: var(--font-sans);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-soft);
}

.fv-hero__detail li {
  display: inline-flex;
  align-items: center;
}

.fv-hero__detail li:not(:last-child)::after {
  content: "";
  width: 4px;
  height: 4px;
  margin-left: 0.8rem;
  border-radius: 50%;
  background: var(--tomato);
  opacity: 0.75;
}

.fv-hero__media .media {
  box-shadow: var(--shadow-card);
}

/* ---- Aufwertung ab Tablet: asymmetrisches Split-Layout ---- */
@media (min-width: 720px) {
  .fv-hero__grid {
    grid-template-columns: 1.08fr 0.92fr;
    align-items: center;
  }

  .fv-hero__copy {
    padding-right: clamp(0.5rem, 3vw, 2.5rem);
  }

  /* Bild weniger extrem hochziehen, um den massiven Freiraum zu verhindern */
  .fv-hero__media .media {
    aspect-ratio: 4 / 4.5;
  }

  /* Bild leicht versetzt — redaktioneller, weniger Raster-starr */
  .fv-hero__media {
    transform: translateY(1.5rem);
  }
}

@media (min-width: 1024px) {
  .fv-hero__grid {
    grid-template-columns: 1.15fr 0.85fr;
  }
}


/* ============================================================
   produkte
   ============================================================ */
/* =========================================================
   FÓRNOVA — Sektion "Produkte" (Kollisionsschutz: #produkte / .fv-produkte)
   ========================================================= */

/* Karten als Spalte, damit media -> tag -> h3 -> Text sauber gestapelt sind */
#produkte .card {
  display: flex;
  flex-direction: column;
}

/* Media oben absetzen, Abstand zum Tag */
#produkte .card .media {
  margin-bottom: 1.2rem;
}

/* Tag links als eigene Zeile, nicht über volle Breite ziehen */
#produkte .card .tag {
  align-self: flex-start;
  margin-bottom: 0.7rem;
}

/* etwas Luft zwischen Produktname und Beschreibung */
#produkte .card h3 {
  margin-bottom: 0.5rem;
}

/* feiner gold-Akzent oben an der Karte beim Hover */
#produkte .card {
  border-top: 2px solid transparent;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-top-color .35s var(--ease);
}
#produkte .card:hover {
  border-top-color: var(--gold);
}

/* Mobile-first: ab Tablet Karten leicht höher atmen lassen */
@media (min-width: 720px) {
  #produkte .card .media {
    margin-bottom: 1.4rem;
  }
  #produkte .card .muted {
    max-width: 38ch;
  }
}


/* ============================================================
   handwerk
   ============================================================ */
/* =========================================================
   FÓRNOVA — Sektion "Handwerk / Über Daniel"
   Alle Selektoren mit #handwerk / .fv-handwerk (Kollisionsschutz).
   Mobile-first, Aufwertung ab 720px.
   ========================================================= */

/* Lead-Grid: Text vertikal mittig zum Portrait ausrichten */
#handwerk .fv-handwerk__lead {
  align-items: center;
}

/* Portrait etwas eingerückt, damit der Text Raum bekommt */
#handwerk .fv-handwerk__portrait .media {
  box-shadow: var(--shadow-soft);
}

/* Trennlinie als Atempause zwischen Story und Prozess */
#handwerk .fv-handwerk__rule {
  margin-block: clamp(2.6rem, 6vw, 4.2rem);
}

/* Prozess-Schritte: aufrecht, mit etwas Luft um die Nummer */
#handwerk .fv-handwerk__steps > li > * + * {
  margin-top: 0.55rem;
}
#handwerk .fv-handwerk__steps .kicker-num {
  display: inline-block;
  font-size: 1.6rem;
}

@media (min-width: 720px) {
  /* Portrait redaktionell etwas schmaler als die Textspalte */
  #handwerk .fv-handwerk__lead {
    grid-template-columns: 0.85fr 1fr;
  }

  /* Schritte tragen oben eine feine Linie — wie ein Editorial-Raster */
  #handwerk .fv-handwerk__steps > li {
    padding-top: 1.4rem;
    border-top: 1px solid var(--line);
  }
}


/* ============================================================
   catering
   ============================================================ */
/* =========================================================
   FÓRNOVA — Sektion "Catering & Service"
   Nur sektions-spezifische Regeln. Alle Selektoren unter #catering / .fv-catering.
   Mobile-first, Aufwertung ab 720px. Tokens aus base.css.
   ========================================================= */

/* Karten auf dunklem Grund lesbar machen:
   abgesetzter, halbtransparenter Paper-Ton + heller Text + dezente Linie. */
#catering .fv-offer {
  background: rgba(244, 238, 225, 0.05);
  border: 1px solid rgba(244, 238, 225, 0.14);
  color: var(--paper);
}
#catering .fv-offer h3 { color: var(--paper); }
#catering .fv-offer p { color: rgba(244, 238, 225, 0.74); }
#catering .fv-offer .tag { margin-bottom: 0.9rem; }
#catering .fv-offer:hover {
  background: rgba(244, 238, 225, 0.08);
  border-color: rgba(216, 163, 62, 0.4);
}

/* "So läuft's" — Mini-Ablauf */
#catering .fv-process {
  margin-top: clamp(3rem, 7vw, 5rem);
  padding-top: clamp(2.2rem, 5vw, 3.2rem);
  border-top: 1px solid rgba(244, 238, 225, 0.16);
}
#catering .fv-process .eyebrow { margin-bottom: 1.6rem; }

#catering .fv-steps {
  display: grid;
  gap: clamp(1.6rem, 4vw, 2.4rem);
  counter-reset: none;
}
#catering .fv-step h3 {
  color: var(--paper);
  margin-top: 0.35rem;
}
#catering .fv-step .kicker-num {
  color: var(--gold);
  font-size: 1.4rem;
}
#catering .fv-step .muted { color: rgba(244, 238, 225, 0.66); }

/* CTA */
#catering .fv-cta {
  margin-top: clamp(2.6rem, 6vw, 4rem);
  justify-content: center;
}

@media (min-width: 720px) {
  #catering .fv-steps {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--gap);
  }
  /* Trennstriche zwischen den Schritten (nicht vor dem ersten) */
  #catering .fv-step + .fv-step {
    border-left: 1px solid rgba(244, 238, 225, 0.16);
    padding-left: var(--gap);
  }
  #catering .fv-cta { justify-content: flex-start; }
}


/* ============================================================
   galerie
   ============================================================ */
/* =========================================================
   FÓRNOVA — Sektion "Galerie"
   Asymmetrisches Magazin-Raster. Mobile-first.
   Alle Selektoren unter #galerie / .fv-galerie (Kollisionsschutz).
   ========================================================= */

/* Grundraster: mobil 2 Spalten, dichtes Packen */
#galerie .fv-galerie__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-auto-flow: dense;
  gap: clamp(0.75rem, 2.4vw, 1.25rem);
}

#galerie .fv-galerie__cell {
  margin: 0;
  min-width: 0;
}

#galerie .fv-galerie__cell .media {
  width: 100%;
  height: 100%;
  box-shadow: var(--shadow-soft);
}

/* Hero darf schon mobil über beide Spalten gehen */
#galerie .fv-galerie__cell--hero {
  grid-column: span 2;
}

/* Sanfter Zoom beim Hover (auf dem Platzhalter dezent) */
#galerie .fv-galerie__cell .media {
  transition: transform .5s var(--ease), box-shadow .5s var(--ease);
}
#galerie .fv-galerie__cell .media:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-card);
}

/* ---- ab 720px: vollwertiges 4-Spalten-Magazin ---- */
@media (min-width: 720px) {
  #galerie .fv-galerie__grid {
    grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 1fr;
  }

  /* Hero: groß, zwei Spalten und zwei Reihen */
  #galerie .fv-galerie__cell--hero {
    grid-column: span 2;
    grid-row: span 2;
  }

  /* Hohe Hochformate über zwei Reihen */
  #galerie .fv-galerie__cell--tall,
  #galerie .fv-galerie__cell--portrait {
    grid-row: span 2;
  }

  /* Breites Catering-Bild über zwei Spalten */
  #galerie .fv-galerie__cell--wide {
    grid-column: span 2;
  }

  /* Damit gespannte Zellen die volle Höhe füllen */
  #galerie .fv-galerie__cell--hero .media,
  #galerie .fv-galerie__cell--tall .media,
  #galerie .fv-galerie__cell--portrait .media {
    aspect-ratio: auto;
  }
}


/* ============================================================
   kontakt
   ============================================================ */
/* =========================================================
   FÓRNOVA — Sektion: Kontakt / Anfrage
   Alle Selektoren unter #kontakt / .fv-kontakt (Kollisionsschutz)
   ========================================================= */

.fv-kontakt__grid {
  align-items: start;
}

/* ---- Kontakt-Infos (links) ---- */
.fv-kontakt__info {
  margin-top: 1.6rem;
}
.fv-kontakt__info li {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.fv-kontakt__label {
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-faint);
}
.fv-kontakt__value {
  font-size: 1.05rem;
}
.fv-kontakt__hint {
  margin-top: 1.6rem;
  font-size: 0.85rem;
}

/* ---- Formular (rechts) ---- */
.fv-kontakt__form {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}
.fv-kontakt__row {
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}
.fv-kontakt__field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  flex: 1;
}
.fv-kontakt__field label {
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--ink);
}
.fv-kontakt__req {
  color: var(--tomato);
}

.fv-kontakt__field input,
.fv-kontakt__field select,
.fv-kontakt__field textarea {
  font: inherit;
  width: 100%;
  padding: 0.7rem 0.85rem;
  color: var(--ink);
  background: var(--paper-warm);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  transition: border-color .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
}
.fv-kontakt__field textarea {
  resize: vertical;
  min-height: 7rem;
  line-height: 1.55;
}
.fv-kontakt__field select {
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%235C5147' stroke-width='1.6'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.85rem center;
  background-size: 16px;
  padding-right: 2.4rem;
}
.fv-kontakt__field input::placeholder,
.fv-kontakt__field textarea::placeholder {
  color: var(--ink-faint);
}
.fv-kontakt__field input:focus,
.fv-kontakt__field select:focus,
.fv-kontakt__field textarea:focus {
  outline: none;
  border-color: var(--tomato);
  background: var(--paper);
  box-shadow: 0 0 0 3px rgba(193,59,43,.12);
}

.fv-kontakt__form .btn--primary {
  align-self: flex-start;
  margin-top: 0.4rem;
}

/* ---- Bestätigung (vom JS befüllt) ---- */
.fv-kontakt__status {
  margin-top: 0.2rem;
  padding: 0.85rem 1rem;
  border-radius: var(--radius);
  background: rgba(88,110,64,.12);
  border: 1px solid rgba(88,110,64,.28);
  color: var(--basil);
  font-size: 0.92rem;
  font-weight: 500;
}

/* ---- Desktop-Aufwertung ---- */
@media (min-width: 720px) {
  .fv-kontakt__row {
    flex-direction: row;
  }
  .fv-kontakt__field--narrow {
    max-width: 12rem;
  }
}


/* ============================================================
   footer
   ============================================================ */
/* =========================================================
   FÓRNOVA — Sektion: Footer
   Alle Selektoren mit #footer / .fv-footer (Kollisionsschutz)
   ========================================================= */

.fv-footer {
  padding-block: clamp(3.5rem, 7vw, 5.5rem) clamp(2rem, 4vw, 3rem);
}

.fv-footer__top {
  display: grid;
  gap: clamp(2.25rem, 5vw, 3rem);
}

/* Wortmarke */
.fv-footer__mark {
  font-family: var(--font-display);
  font-size: clamp(1.7rem, 1.3rem + 1.8vw, 2.4rem);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1;
}

.fv-footer__tagline {
  max-width: 36ch;
}

/* Listen in Nav + Kontakt */
.fv-footer__nav .eyebrow,
.fv-footer__contact .eyebrow {
  margin-bottom: 1rem;
}

.fv-footer__nav ul,
.fv-footer__contact ul {
  display: grid;
  gap: 0.55rem;
}

.fv-footer__link {
  color: rgba(244, 238, 225, 0.78);
  border-bottom: 1px solid transparent;
  transition: color 0.25s var(--ease), border-color 0.25s var(--ease);
}

.fv-footer__link:hover {
  color: var(--paper);
  border-color: rgba(244, 238, 225, 0.45);
}

.fv-footer__social {
  margin-top: 1.1rem;
  color: var(--gold);
}

.fv-footer__social:hover {
  border-color: var(--gold);
}

/* Trennlinie auf dunklem Grund */
.fv-footer__rule {
  background: rgba(244, 238, 225, 0.16);
  margin-block: clamp(2.25rem, 5vw, 3rem) 1.5rem;
}

/* Untere Zeile */
.fv-footer__bottom {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: 0.85rem;
}

.fv-footer__note {
  font-family: var(--font-display);
  font-style: italic;
  color: rgba(244, 238, 225, 0.6);
}

/* ---- Aufwertung ab Tablet ---- */
@media (min-width: 720px) {
  .fv-footer__top {
    grid-template-columns: 1.6fr 0.9fr 1.1fr;
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
  }

  .fv-footer__bottom {
    flex-direction: row;
    justify-content: space-between;
    align-items: baseline;
  }
}


