/* =============================================
   MOBILE SLIDE-IN MENÜ
   ============================================= */

.mobile-menu-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  z-index: 200;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.mobile-menu-overlay.is-open {
  display: block;
  opacity: 1;
}

.mobile-menu {
  position: fixed;
  top: 0;
  right: 0;
  width: min(320px, 85vw);
  height: 100%;
  background: var(--cream);
  z-index: 300;
  transform: translateX(100%);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  display: flex;
  flex-direction: column;
  padding: 2rem 2rem 3rem;
  box-shadow: -4px 0 24px rgba(0,0,0,0.12);
}

.mobile-menu.is-open {
  transform: translateX(0);
}

.mobile-menu-close {
  align-self: flex-end;
  background: none;
  border: none;
  font-size: 1.4rem;
  color: var(--mid);
  cursor: pointer;
  padding: 0.25rem;
  line-height: 1;
  transition: color 0.2s;
  margin-bottom: 2rem;
}

.mobile-menu-close:hover { color: var(--gold); }

.mobile-menu-links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.mobile-menu-links li a {
  display: block;
  padding: 1rem 0;
  font-family: 'Montserrat', sans-serif;
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--dark);
  text-decoration: none;
  border-bottom: 1px solid var(--light);
  transition: color 0.2s, padding-left 0.2s;
}

.mobile-menu-links li a:hover {
  color: var(--gold);
  padding-left: 0.5rem;
}

.mobile-menu-links .mobile-menu-termin {
  margin-top: 1.5rem;
  background: var(--gold) !important;
  color: #fff !important;
  text-align: center;
  padding: 0.9rem 1rem !important;
  border-bottom: none !important;
  letter-spacing: 0.18em !important;
  transition: background 0.2s !important;
}

.mobile-menu-links .mobile-menu-termin:hover {
  background: #b5924f !important;
  padding-left: 0 !important;
}

body.menu-open { overflow: hidden; }

/* =============================================
   GLOBAL BUTTON STYLE — Gold
   ============================================= */

.cta-button,
.fp-btn-white,
.fp-btn-dark,
.ulm-cta-btn,
.bk-modal-cta,
.termin-btn,
button[type="submit"].termin-btn {
  background: var(--gold) !important;
  color: #fff !important;
  border: none !important;
  letter-spacing: 0.18em !important;
  transition: background 0.25s, transform 0.2s !important;
}

.cta-button:hover,
.fp-btn-white:hover,
.fp-btn-dark:hover,
.ulm-cta-btn:hover,
.bk-modal-cta:hover,
.termin-btn:hover {
  background: #b5924f !important;
  color: #fff !important;
  transform: translateY(-2px) !important;
}

/* =============================================
   RESPONSIVE — Tablet & Mobile
   ============================================= */

@media (max-width: 768px) {

  /* ── Hero — Querformat-Ansicht auf Mobilgeräten ── */
  .hero {
    /* Querformat: 16:9-ähnliches Verhältnis statt hochkant */
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: 16 / 9 !important;
  }

  /* Slides: Fokus auf Bildmitte, passend für Querformat */
  .slide {
    background-position: center center !important;
    background-size: cover !important;
  }

  /* Glitter-Canvas komplett ausblenden auf Mobilgeräten */
  .hero-glitter {
    display: none !important;
  }

  .hero-content {
    padding: 0 1.5rem !important;
    align-items: center !important;
    text-align: center !important;
  }

  .hero-eyebrow {
    font-size: 0.65rem !important;
    letter-spacing: 4px !important;
  }

  .hero-title {
    font-size: clamp(1.6rem, 7vw, 2.8rem) !important;
    text-align: center !important;
    margin-bottom: 0.4rem !important;
  }

  .sale-dates {
    font-size: 0.8rem !important;
    letter-spacing: 3px !important;
    text-align: center !important;
    margin-bottom: 0.3rem !important;
  }

  .sale-tagline {
    text-align: center !important;
    font-size: 0.95rem !important;
    margin-bottom: 0.8rem !important;
  }

  .hero-desc {
    display: none !important; /* Platzsparen im Querformat */
  }

  .hero .cta-button {
    padding: 0.7rem 1.8rem !important;
    font-size: 0.8rem !important;
    letter-spacing: 2px !important;
  }

  .hero-overlay {
    background: linear-gradient(
      180deg,
      rgba(0,0,0,0.45) 0%,
      rgba(0,0,0,0.2) 50%,
      rgba(0,0,0,0.45) 100%
    ) !important;
  }

  .slide-indicators {
    right: 50% !important;
    transform: translateX(50%) !important;
    bottom: 12px !important;
  }

  /* ── Navigation ── */
  .nav-inner {
    grid-template-columns: 44px 1fr 44px;
    height: 60px;
    padding: 0 1rem;
  }

  .nav-left,
  .nav-right {
    display: none !important;
  }

  .nav-center {
    justify-self: center;
    padding: 0;
  }

  .nav-hamburger {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    width: 44px;
    height: 44px;
    z-index: 10;
  }

  .nav-hamburger span {
    display: block;
    width: 22px;
    height: 1.5px;
    background: var(--dark);
    transition: transform 0.25s, opacity 0.25s;
  }

  /* ── Front Page ── */
  .fp-about-inner {
    grid-template-columns: 1fr !important;
    text-align: center;
    padding: 2.5rem 1.5rem !important;
  }

  .fp-about-deco { display: none !important; }

  .fp-about-text {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .fp-gold-rule {
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .fp-section-title {
    font-size: clamp(1.6rem, 6vw, 2rem) !important;
    text-align: center !important;
  }

  .fp-about-text p {
    text-align: center;
  }

  .fp-brands {
    padding: 2.5rem 1.5rem !important;
  }

  .fp-vib {
    padding: 3rem 1.5rem !important;
    text-align: center;
  }

  .fp-vib-inner {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  /* ── Layout ── */
  .page-wrapper {
    grid-template-columns: 1fr;
    gap: 2rem;
    margin: 2rem auto;
    padding: 0 1rem;
  }

  /* ── Footer ── */
  footer {
    margin-top: 2.5rem;
    padding: 2.5rem 1.25rem 0;
  }

  .footer-cols {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .footer-col {
    padding: 1.25rem 0;
    border-bottom: 1px solid #ddd9d1;
  }

  .footer-col:last-child { border-bottom: none; }
  .footer-right { text-align: left; }

  .footer-socials-wrap {
    flex-direction: row !important;
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  /* ── Über Lady M mobile ── */
  .ulm-intro-band {
    padding: 2rem 1.25rem 1.75rem !important;
  }

  .ulm-intro-band .ulm-heading {
    font-size: clamp(1.6rem, 7vw, 2.2rem) !important;
  }

  .ulm-section--split {
    grid-template-columns: 1fr !important;
    gap: 1.75rem !important;
    padding: 2.5rem 1.25rem !important;
  }

  .ulm-section--reverse {
    direction: ltr !important;
  }

  /* Image comes first on mobile, text below */
  .ulm-section--split .ulm-section-img {
    order: -1;
  }

  .ulm-img-placeholder {
    aspect-ratio: 4 / 3 !important; /* wider on mobile */
  }

  .ulm-gallery {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 0.5rem !important;
  }

  .ulm-gallery-section {
    padding: 2.5rem 1.25rem 0 !important;
  }

  /* ── Kontakt + Termin handled in their own CSS files at 600px ── */

  /* ── Kontakt + Termin: handled in their own CSS at 600px ── */

}

/* ── Very small screens ── */
@media (max-width: 400px) {
  .hero {
    min-height: 420px !important;
  }

  .hero-title {
    font-size: 2.2rem !important;
  }

  .fp-brand-list span {
    font-size: 0.65rem !important;
    padding: 0.3rem 0.6rem !important;
  }
}
