/* ==========================================
   Global Base
   ========================================== */
body {
  overflow-x: hidden;
}

/* ==========================================
   Material Symbols
   ========================================== */
.material-symbols-outlined {
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  vertical-align: middle;
}

.star-rating {
  font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  color: #f59e0b;
}

/* ==========================================
   Hamburger Icon
   ========================================== */
.hamburger-line {
  display: block;
  height: 2px;
  border-radius: 9999px;
  background-color: currentColor;
  transition:
    transform 0.35s cubic-bezier(0.23, 1, 0.32, 1),
    opacity   0.25s ease,
    width     0.3s  ease,
    margin    0.3s  ease;
  transform-origin: center;
}
.hamburger-line:nth-child(1) { width: 20px; }
.hamburger-line:nth-child(2) { width: 20px; }
.hamburger-line:nth-child(3) { width: 13px; margin-left: 7px; }

#mobile-menu-btn.is-open .hamburger-line:nth-child(1) {
  transform: translateY(7.5px) rotate(45deg);
}
#mobile-menu-btn.is-open .hamburger-line:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
#mobile-menu-btn.is-open .hamburger-line:nth-child(3) {
  width: 20px;
  margin-left: 0;
  transform: translateY(-7.5px) rotate(-45deg);
}

/* ==========================================
   Mobile Menu Overlay
   ========================================== */
#mobile-menu {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}
#mobile-menu.is-open {
  opacity: 1;
  pointer-events: auto;
}

.mobile-nav-item {
  opacity: 0;
  transform: translateX(28px);
  transition: opacity 0.45s ease, transform 0.45s cubic-bezier(0.23, 1, 0.32, 1);
}
.mobile-nav-item.animate-in {
  opacity: 1;
  transform: none;
}

/* ==========================================
   Scroll Animations
   ========================================== */
[data-animate] {
  opacity: 0;
  transition: opacity 0.7s ease, transform 0.7s ease;
}

[data-animate="fade-up"]    { transform: translateY(40px); }
[data-animate="fade-right"] { transform: translateX(-40px); }
[data-animate="fade-left"]  { transform: translateX(40px); }
[data-animate="scale-in"]   { transform: scale(0.92); }

[data-animate].is-visible {
  opacity: 1;
  transform: none;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  [data-animate]     { opacity: 1; transform: none; transition: none; }
  .mobile-nav-item   { opacity: 1; transform: none; transition: none; }
  .hamburger-line    { transition: none; }
}

/* ==========================================
   Parallax Hero Image
   ========================================== */
.parallax-img {
  will-change: transform;
  transition: transform 0.1s linear;
}

/* ==========================================
   Small Screen Responsive Fixes (320–375 px)
   ========================================== */
@media (max-width: 374px) {
  /* Hero h1: etwas kompakter auf 320 px damit die lange Überschrift nicht zu groß wirkt */
  h1.font-headline {
    font-size: 1.875rem; /* 30px statt 36px (text-4xl) */
    line-height: 1.15;
  }

  /* Footer: zweispaltige Kacheln haben auf 320 px zu wenig Raum –
     beide Spalten untereinander statt nebeneinander */
  footer .grid.grid-cols-2 {
    grid-template-columns: 1fr;
  }
  footer .col-span-1 {
    grid-column: span 1 / span 1;
  }
}
