/* =============================================================================
   Libitina Bestattungen – Basislayout
   ============================================================================= */

/* ============================================================================
   1. Variablen
   ========================================================================== */

:root {
  --libitina-bg: #f6f4ee;
  --libitina-bg-alt: #f6f4ee;
  --libitina-gold: #caa568;
  --libitina-gold-light: #e1c58a;
  --libitina-text: #111111;
  --libitina-text-muted: #c0c0c0;

  --libitina-font-base: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI",
    sans-serif;
  --libitina-max-width: 1200px;

  --libitina-radius: 8px;
  --libitina-transition-fast: 150ms ease-out;

  /* geschätzte Header-Höhe mobil für Abstand zum Menü */
  --libitina-header-mobile: 72px;
}

/* ============================================================================
   2. Reset & Basis
   ========================================================================== */

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

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  padding: 0;
  font-family: var(--libitina-font-base);
  color: var(--libitina-text);
  background-color: var(--libitina-bg);
  line-height: 1.6;
}

/* Links */
a {
  color: var(--libitina-gold);
  text-decoration: none;
  transition: color var(--libitina-transition-fast);
}

a:hover,
a:focus-visible {
  color: var(--libitina-gold-light);
}

/* Container */
.container {
  width: 100%;
  max-width: var(--libitina-max-width);
  margin: 0 auto;
  padding: 0 16px;
}

/* Screenreader-Only-Text */
.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* ============================================================================
   3. HEADER – Libitina (schwarz / gold, responsiv)
   ========================================================================== */

/* Header-Grundfläche (sticky) */
.lb-site-header {
  background-color: #000;
  color: #fff;
  position: sticky;
  top: 0;
  z-index: 1000;
}

/* Innenbereich */
.lb-header-inner {
  max-width: var(--libitina-max-width);
  margin: 0 auto;
  padding: 0.75rem 1.2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.lb-header-left,
.lb-header-center,
.lb-header-right {
  display: flex;
  align-items: center;
}

/* Logo Desktop */
.lb-header-left .custom-logo,
.lb-header-left img {
  display: block;
  height: 56px;
  max-height: 56px;
  width: auto;
}

/* ===== Navigation Grundzustand (Desktop-Default) ===== */

.lb-main-nav {
  display: block;
}

.lb-main-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 1.5rem;
}

.lb-main-menu > li {
  position: relative; /* für Desktop-Dropdowns */
}

.lb-main-menu > li > a {
  text-decoration: none;
  color: var(--libitina-gold);
  font-weight: 500;
}

/* Aktiver/aktueller Menüpunkt (oder Vorfahre) oben: weiß */
.lb-main-menu > li.current-menu-item > a,
.lb-main-menu > li.current_page_item > a,
.lb-main-menu > li.current-menu-ancestor > a,
.lb-main-menu > li.current_page_ancestor > a {
  color: #ffffff !important;
}

/* Hover Desktop: weiß */
.lb-main-menu > li > a:hover {
  color: #ffffff !important;
}

/* Untermenü-Links default: gold */
.lb-main-menu .sub-menu a {
  color: var(--libitina-gold);
}

/* aktiver Untermenüpunkt weiß */
.lb-main-menu .sub-menu li.current-menu-item > a,
.lb-main-menu .sub-menu li.current_page_item > a {
  color: #ffffff !important;
}

/* Top-Level: wenn aktiv oder Vorfahre -> Pfeil weiß */
.lb-main-menu > li.current-menu-item.menu-item-has-children > a::after,
.lb-main-menu > li.current_page_item.menu-item-has-children > a::after,
.lb-main-menu > li.current-menu-ancestor.menu-item-has-children > a::after,
.lb-main-menu > li.current_page_ancestor.menu-item-has-children > a::after {
  color: #ffffff;
}

/* Untermenü: Pfeil nur bei direkt aktiver Seite weiß */
.lb-main-menu .sub-menu li.current-menu-item.menu-item-has-children > a::after,
.lb-main-menu .sub-menu li.current_page_item.menu-item-has-children > a::after {
  color: #ffffff;
}

/* ===== Notfallnummer rechts (Desktop) ===== */

.lb-header-phone-desktop {
  text-align: right;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  line-height: 1.2;
}

.lb-header-phone-label {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--libitina-gold);
}

.lb-header-phone-number {
  font-size: 1rem;
  text-decoration: none;
  color: #fff;
  font-weight: 700;
}

/* ===== Burger & Telefonhörer – Basis ===== */

.lb-header-burger,
.lb-header-phone-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: transparent;
  border: none;
  padding: 0.4rem;
  cursor: pointer;
  color: #fff;
  box-shadow: none;
}

/* Burger-Icon */
.lb-header-burger {
  width: 32px;
  height: 24px;
  flex-direction: column;
  justify-content: space-between;
  padding: 4px 0;
}

.lb-burger-line {
  width: 100%;
  height: 3px;
  background-color: var(--libitina-gold);
  border-radius: 2px;
  display: block;
}

/* Telefonhörer-Bild */
.lb-phone-img {
  width: 26px;
  height: auto;
  display: block;
}

/* (falls irgendwo noch das alte Icon benutzt wird) */
.lb-phone-icon {
  font-size: 1.3rem;
}

/* Toggle-Button für Mobil-Untermenüs (Plus/Pfeil) – Default: sichtbar */
.lb-submenu-toggle {
  background: none;
  border: none;
  color: var(--libitina-gold);
  cursor: pointer;
  font-size: 1rem;
  padding: 0;
  margin-left: 0.4rem;
  line-height: 1;
  display: inline-block;
  vertical-align: middle;
}

/* Wenn offen -> Pfeil gedreht & weiß */
.lb-main-menu li.submenu-open > .lb-submenu-toggle {
  transform: rotate(180deg);
  color: #ffffff;
}

/* ===== Streifen unter dem Header ===== */

.lb-header-strip {
  background: linear-gradient(to right, #111, var(--libitina-gold), #111);
  padding: 0.35rem 1rem;
  text-align: center;
}

.lb-header-strip-text {
  color: #fff;
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* ============================================================================
   4. Filial-Auswahl Overlay (Telefonhörer mobil)
   ========================================================================== */

.lb-branch-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.75);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.lb-branch-overlay.is-open {
  display: flex;
}

.lb-branch-dialog {
  background: #000;
  border: 1px solid var(--libitina-gold);
  border-radius: 8px;
  padding: 1.5rem;
  max-width: 360px;
  width: 90%;
  position: relative;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.8);
}

.lb-branch-close {
  position: absolute;
  top: 0.3rem;
  right: 0.5rem;
  background: none;
  border: none;
  font-size: 1.6rem;
  line-height: 1;
  color: #fff;
  cursor: pointer;
}

.lb-branch-title {
  margin: 0 0 1rem;
  text-align: center;
  font-size: 1.1rem;
  color: var(--libitina-gold);
}

.lb-branch-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.lb-branch-btn {
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
  padding: 0.9rem 1rem;
  border-radius: 999px;
  border: 1px solid var(--libitina-gold);
  text-decoration: none;
  color: #fff;
  font-weight: 600;
  transition: background 0.2s ease, color 0.2s ease, transform 0.1s ease;
}

.lb-branch-btn:hover,
.lb-branch-btn:focus {
  background: var(--libitina-gold);
  color: #000;
  transform: translateY(-1px);
}

/* ============================================================================
   5. Content-Bereich
   ========================================================================== */

.site-content {
  padding: 32px 0 48px;
}

.libitina-article {
  background: var(--libitina-bg-alt);
  padding: 24px;
  margin-bottom: 24px;
  border-radius: var(--libitina-radius);
  border: 1px solid rgba(255, 255, 255, 0.05);
}

/* ============================================================================
   6. Footer
   ========================================================================== */

.site-footer {
  background: #000;
  color: var(--libitina-text-muted);
  padding: 24px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

.footer-inner {
  max-width: var(--libitina-max-width);
  margin: 0 auto;
  padding: 0 16px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.footer-menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 16px;
}

/* ============================================================================
   7. Medien / Videos – responsive Wrapper
   ========================================================================== */

.libitina-media-responsive {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  overflow: hidden;
  border-radius: var(--libitina-radius);
}

.libitina-media-responsive iframe,
.libitina-media-responsive video,
.libitina-media-responsive img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ============================================================================
   8. Responsiv – Breakpoints
   ========================================================================== */

/* ---- Mobile (bis 960px) ---- */
@media (max-width: 960px) {

  .lb-header-inner {
    padding: 1rem 1rem;
  }

  /* Logo mobil etwas kleiner */
  .lb-header-left .custom-logo,
  .lb-header-left img {
    height: 48px;
    max-height: 48px;
  }

  .lb-header-left {
    flex: 0 0 auto;
  }

  .lb-header-center {
    flex: 1 1 auto;
    justify-content: center;
    position: relative;
    z-index: 1000;
  }

  .lb-header-right {
    flex: 0 0 auto;
  }

  /* Burger & Telefonhörer sichtbar */
  .lb-header-burger,
  .lb-header-phone-toggle {
    display: inline-flex;
  }

  .lb-header-phone-toggle {
    margin-right: 10px;
  }

  /* Mobile Menü-Box als Overlay unter dem Header */
  .lb-main-nav {
    display: none;
    position: fixed;
    top: 72px;              /* ca. Header-Höhe; bei Bedarf anpassen */
    left: 50%;
    transform: translateX(-50%);
    background: #000;
    padding: 4px 0;
    border-radius: 6px;
    width: 90vw;
    max-width: 420px;
    z-index: 1100;
    border: 1px solid rgba(255, 255, 255, 0.15);
  }

  .lb-main-nav.is-open {
    display: block;
  }

  /* Menüeinträge vertikal */
  .lb-main-menu {
    flex-direction: column;
    align-items: stretch;
    padding: 5px 10px;
    gap: 0.5rem;
  }

  /* Top-Level einspaltig */
  .lb-main-menu > li {
    list-style: none;
  }

  /* Untermenüs: nach unten, nicht zur Seite */
  .lb-main-menu .sub-menu {
    list-style: none;
    margin: 0.25rem 0 0;
    padding-left: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.05);
    display: none;
    position: static !important;
    left: auto !important;
    top: auto !important;
    width: 100%;
  }

  /* sichtbar, wenn JS .submenu-open gesetzt hat */
  .lb-main-menu li.submenu-open > .sub-menu {
    display: block;
  }

  /* 3. Ebene etwas weiter eingerückt */
  .lb-main-menu .sub-menu .sub-menu {
    padding-left: 1rem;
    border-top: none;
  }

  /* Auf Mobil: keine ::after-Pfeile, nur die echten Buttons */
  .lb-main-menu > li.menu-item-has-children > a::after,
  .lb-main-menu .sub-menu > li.menu-item-has-children > a::after {
    content: none !important;
  }

  /* Link & Pfeil direkt nebeneinander */
  .lb-main-menu > li > a,
  .lb-main-menu .sub-menu > li > a {
    display: inline;
  }

  /* Pfeil-Button direkt hinter dem Text */
  .lb-submenu-toggle {
    position: static;
    display: inline-block;
    margin-left: 0.35rem;
    vertical-align: middle;
    min-width: auto;
    text-align: left;
  }

  .lb-main-menu li.submenu-open > .lb-submenu-toggle {
    transform: rotate(180deg);
    color: #ffffff;
  }

  /* Desktop-Notfallnummer verstecken */
  .lb-header-phone-desktop {
    display: none;
  }

  .footer-inner {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* ---- Desktop ab 961px ---- */
@media (min-width: 961px) {

  .lb-header-burger,
  .lb-header-phone-toggle {
    display: none !important;
  }

  .lb-main-nav {
    display: block;
    position: static;
  }

  .lb-main-menu {
    flex-direction: row;
    padding: 0;
    gap: 1.5rem;
  }

  .lb-header-phone-desktop {
    display: flex;
  }

  /* Pfeil an Top-Level-Punkten mit Untermenü (Desktop) */
  .lb-main-menu > li.menu-item-has-children > a::after {
    content: "▾";
    margin-left: 0.4rem;
    font-size: 0.95em;
    color: var(--libitina-gold);
    vertical-align: middle;
  }

  /* Pfeil auch bei 2. Ebene mit Untermenü */
  .lb-main-menu .sub-menu > li.menu-item-has-children > a::after {
    content: "▾";
    margin-left: 0.35rem;
    font-size: 0.9em;
    color: var(--libitina-gold);
  }

  /* 2. Ebene als klassisches Dropdown */
  .lb-main-menu > li > .sub-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    background: #000;
    padding: 0.5rem 1rem;
    border-radius: 6px;
    min-width: 220px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    z-index: 1001;
  }

  .lb-main-menu > li:hover > .sub-menu {
    display: block;
  }

  /* Gemeinsame Submenü-Styles (Ebene 2+3) */
  .lb-main-menu .sub-menu {
    list-style: none;
    margin: 0;
    padding: 0.25rem 0;
  }

  .lb-main-menu .sub-menu li {
    width: 100%;
  }

  .lb-main-menu .sub-menu a {
    display: block;
    padding: 0.25rem 0;
    white-space: normal;
    text-align: left;
  }

  /* 3. Ebene – bei Hover der 2. Ebene sichtbar */
  .lb-main-menu .sub-menu .sub-menu {
    display: none;
    padding-left: 1rem;
  }

  .lb-main-menu .sub-menu > li:hover > .sub-menu {
    display: block;
  }

  /* Hover in Ebene 2/3: Text + Pfeil weiß */
  .lb-main-menu .sub-menu > li > a:hover {
    color: #ffffff !important;
  }

  .lb-main-menu .sub-menu > li.menu-item-has-children > a:hover::after {
    color: #ffffff !important;
  }

  /* WICHTIG: Pfeil-Buttons nur auf Mobil */
  .lb-submenu-toggle {
    display: none !important;
  }
}


/* ============================================================================
   9. Sprachumschalter
   ========================================================================== */

.lb-header-phone-desktop {
  margin-right: 15px;
}

.lb-lang-switcher {
  position: relative;
  margin-left: 1rem;
  font-size: 0.8rem;
}

.lb-lang-switcher__button {
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
}

.lb-lang-switcher__current-circle {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid var(--libitina-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  color: var(--libitina-gold);
  text-transform: uppercase;
}

.lb-lang-switcher__menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  padding: 6px 8px;
  margin: 0;
  list-style: none;
  border-radius: 12px;
  background: rgba(0, 0, 0, 0.96);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.7);
  border: 1px solid rgba(255, 255, 255, 0.12);
  z-index: 50;
}

.lb-lang-switcher__item {
  margin: 0;
}

.lb-lang-switcher__link {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2px;
  text-decoration: none;
}

.lb-lang-switcher__circle {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 1px solid var(--libitina-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 600;
  color: var(--libitina-gold);
  text-transform: uppercase;
  opacity: 0.9;
}

.lb-lang-switcher__link:hover .lb-lang-switcher__circle,
.lb-lang-switcher__link:focus-visible .lb-lang-switcher__circle {
  opacity: 1;
}

.lb-lang-switcher__menu[hidden] {
  display: none;
}

.lb-lang-switcher.is-open .lb-lang-switcher__menu {
  display: block;
}

/* ============================================================================
   10. Globaler Hintergrund
   ========================================================================== */

html,
body {
  background-color: var(--libitina-bg) !important;
}

/* alle Wrapper durchsichtig machen */
.wp-site-blocks,
.site,
.site-content,
.entry-content,
.wp-block-post-content,
.wp-block-group,
.wp-block-cover,
.wp-block-cover__inner-container,
.wp-block-template-part,
#page,
#content {
  background-color: transparent !important;
}

/* Inline-Hintergründe überschreiben */
*[style*="background-color"] {
  background-color: transparent !important;
}
