/* ============================================================
   IVAN'S Standortseite — ergänzende Modul-Stile
   Baut auf assets/styles.css auf (Tokens & Komponenten von dort).
   Hier NUR neue Module der Standort-Vorlage.
   ============================================================ */

/* ---------- Varianten-Logik (Vorlage: Barbershop | Salon) ----------
   html[data-variante] steuert, welche Inhalte sichtbar sind.
   .nur-barbershop / .nur-salon = variantenspezifische Inhalte. */
html[data-variante="barbershop"] .nur-salon { display: none !important; }
html[data-variante="salon"] .nur-barbershop { display: none !important; }

/* ============================================================
   MODUL 01 · Header-Ergänzungen (Back-Link + Buchungs-CTA)
   ============================================================ */
.nav-back { display: inline-flex; align-items: center; gap: 6px; }
.nav-back::before { content: "←"; color: var(--gold); }
.nav-book {
  background: var(--gold); color: #000 !important;
  padding: 11px 20px; border-radius: var(--radius);
  font-weight: 600; transition: background 0.2s;
}
.nav-book:hover { background: var(--gold-deep); }
.nav-tel { display: none; }

/* ============================================================
   MODUL 02 · Hero (lokal)
   ============================================================ */
.hero-meta { display: flex; flex-wrap: wrap; gap: var(--s-2); }
.meta-chip {
  display: inline-flex; align-items: center; gap: 8px;
  border: 1px solid var(--line); border-radius: var(--radius);
  padding: 8px 14px; font-size: 13px; color: var(--text-2);
}
.meta-chip .punkt { width: 7px; height: 7px; border-radius: 50%; background: var(--gold); }
.stern-zeile { display: flex; align-items: center; gap: 10px; font-size: 13px; color: var(--text-2); letter-spacing: 0.04em; }

/* ============================================================
   MODUL 03 · Philosophie (kompakt, variantenspezifische Säulen)
   ============================================================ */
.philo-kompakt { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--s-6); align-items: center; }
.philo-kompakt .ph { aspect-ratio: 16 / 11; min-height: 0; }

/* ============================================================
   MODUL 05 · Signature / Empfehlung
   ============================================================ */
.signature-card {
  border: 1px solid var(--gold-deep); border-radius: var(--radius);
  background: var(--bg-2);
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-5);
  padding: var(--s-5);
}
.signature-copy { display: flex; flex-direction: column; gap: var(--s-2); align-items: flex-start; }
.signature-badge {
  font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; font-weight: 600;
  background: var(--gold); color: #000; padding: 4px 12px; border-radius: var(--radius);
}
.signature-card h3 { font-family: var(--font-serif); font-size: clamp(26px, 3vw, 36px); font-weight: 500; line-height: 1.15; }
.signature-card p { color: var(--text-2); font-size: 15px; text-wrap: pretty; }
.signature-liste { display: flex; flex-direction: column; gap: 10px; margin: var(--s-1) 0; }
.signature-liste li { display: flex; align-items: baseline; gap: 12px; font-size: 15px; color: var(--text-1); }
.signature-liste li::before { content: "—"; color: var(--gold); }
.signature-preis { font-family: var(--font-serif); font-size: 30px; color: var(--gold); }
.signature-preis small { font-family: var(--font-sans); font-size: 12px; color: var(--text-2); margin-left: 8px; }
.signature-card .ph { aspect-ratio: 4 / 3; min-height: 0; }

/* ============================================================
   MODUL 06 · Preise (Repeater: Zeile = Leistung + Preis)
   ============================================================ */
.preis-spalten { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-5); }
.preis-gruppe { display: flex; flex-direction: column; gap: var(--s-2); }
.preis-zeilen { display: flex; flex-direction: column; }
.preis-zeile {
  display: flex; align-items: baseline; gap: var(--s-2);
  padding: 14px 0; border-bottom: 1px solid var(--line-soft);
}
.preis-zeile .leistung { font-size: 15px; color: var(--text-1); }
.preis-zeile .leistung small { display: block; font-size: 12px; color: var(--text-2); }
.preis-zeile .leader { flex: 1; border-bottom: 1px dotted #3F3F46; transform: translateY(-4px); }
.preis-zeile .preis { font-family: var(--font-serif); font-size: 18px; color: var(--gold); white-space: nowrap; }
.preis-fussnote { margin-top: var(--s-4); font-size: 13px; color: var(--text-2); display: flex; align-items: center; gap: 10px; }
.preis-fussnote::before { content: ""; width: 24px; height: 1px; background: var(--gold); flex: 0 0 auto; }

/* ============================================================
   MODUL 08 · Team (Repeater: Karte = Foto, Name, Rolle)
   ============================================================ */
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s-3); }
.team-card {
  background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius);
  padding: var(--s-3); display: flex; flex-direction: column; gap: var(--s-2);
}
.team-card .ph { aspect-ratio: 4 / 5; min-height: 0; padding: var(--s-2); }
.team-card h4 { font-family: var(--font-serif); font-size: 20px; font-weight: 500; }
.team-card .rolle { font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold); }

/* ============================================================
   MODUL 10 · Standort & Öffnungszeiten (NAP + Karte + Zeiten)
   ============================================================ */
.nap-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-5); align-items: stretch; }
.nap-card {
  background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius);
  padding: var(--s-5); display: flex; flex-direction: column; gap: var(--s-3);
}
.nap-zeile { display: flex; flex-direction: column; gap: 2px; }
.nap-zeile .label { font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); }
.nap-zeile .wert { font-size: 16px; color: var(--text-1); }
.nap-zeile .wert small { color: var(--text-2); font-size: 13px; }
.zeiten-tabelle { display: flex; flex-direction: column; }
.zeiten-zeile {
  display: flex; justify-content: space-between; gap: var(--s-2);
  padding: 9px 0; border-bottom: 1px solid var(--line-soft);
  font-size: 14px; color: var(--text-2);
}
.zeiten-zeile.heute { color: var(--text-1); }
.zeiten-zeile.heute .tag::after { content: " · heute"; color: var(--gold); font-size: 12px; }
.zeiten-zeile .zeit { font-variant-numeric: tabular-nums; }
.nap-actions { display: flex; flex-wrap: wrap; gap: var(--s-2); margin-top: var(--s-1); }
.anfahrt-hinweis { font-size: 13px; color: var(--text-2); border-top: 1px solid var(--line-soft); padding-top: var(--s-2); }
.nap-map.ph { min-height: 100%; aspect-ratio: auto; }

/* ============================================================
   MODUL 11 · FAQ (Repeater: Akkordeon-Item)
   ============================================================ */
.faq-liste { display: flex; flex-direction: column; max-width: 800px; }
.faq-item { border-bottom: 1px solid var(--line); }
.faq-item summary {
  cursor: pointer; list-style: none;
  display: flex; justify-content: space-between; align-items: baseline; gap: var(--s-3);
  padding: var(--s-3) 0;
  font-family: var(--font-serif); font-size: 19px; font-weight: 500; color: var(--text-1);
  transition: color 0.2s;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; color: var(--gold); font-family: var(--font-sans); font-size: 22px; line-height: 1; flex: 0 0 auto; }
.faq-item[open] summary::after { content: "–"; }
.faq-item summary:hover { color: var(--gold); }
.faq-item .faq-antwort { padding: 0 0 var(--s-3); color: var(--text-2); font-size: 15px; max-width: 680px; text-wrap: pretty; }

/* ============================================================
   MODUL 12 · Buchung / Termin
   ============================================================ */
.buchung-box {
  border: 1px solid var(--gold-deep); border-radius: var(--radius);
  background: var(--bg-2);
  padding: var(--s-6); display: flex; flex-direction: column; align-items: center; gap: var(--s-3);
  text-align: center;
}
.buchung-box .ph { width: 100%; max-width: 720px; aspect-ratio: 16 / 7; min-height: 0; }
.buchung-alternativ { font-size: 14px; color: var(--text-2); }
.buchung-alternativ a { color: var(--gold); }
.buchung-alternativ a:hover { color: var(--gold-deep); }

/* ============================================================
   Schwebende Aktionen (sticky Buchen + WhatsApp, mobil Anrufen)
   ============================================================ */
.float-stack {
  position: fixed; right: var(--s-3); bottom: var(--s-3); z-index: 60;
  display: flex; flex-direction: column; align-items: flex-end; gap: var(--s-2);
}
.float-whatsapp {
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--bg-2); border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  transition: border-color 0.2s; box-shadow: 0 8px 24px rgba(0,0,0,0.5);
}
.float-whatsapp:hover { border-color: var(--gold); }
.float-whatsapp svg { width: 24px; height: 24px; fill: var(--text-2); }
.float-whatsapp:hover svg { fill: var(--gold); }
.float-buchen { box-shadow: 0 8px 24px rgba(0,0,0,0.5); }
.mobile-cta-bar { display: none; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1020px) {
  .team-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 860px) {
  .philo-kompakt, .signature-card, .preis-spalten, .nap-grid { grid-template-columns: 1fr; }
  .nap-map.ph { aspect-ratio: 16 / 10; }
  .team-grid { grid-template-columns: repeat(2, 1fr); }
  /* Mobile: persistente Leiste mit Anrufen + Buchen */
  body { padding-bottom: 72px; }
  .float-stack { bottom: 88px; }
  .float-buchen { display: none; }
  .mobile-cta-bar {
    display: flex; gap: var(--s-2); position: fixed; left: 0; right: 0; bottom: 0; z-index: 60;
    background: rgba(0,0,0,0.94); backdrop-filter: blur(12px);
    border-top: 1px solid var(--line); padding: 12px var(--s-3);
  }
  .mobile-cta-bar .btn { flex: 1; padding: 14px 10px; }
}
@media (max-width: 560px) {
  .team-grid { grid-template-columns: 1fr; }
}
