/* nunito-regular - latin */
@font-face {
  font-display: swap; 
  font-family: 'Nunito';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/nunito-v26-latin-regular.woff2') format('woff2'); 
}
/* nunito-italic - latin */
@font-face {
  font-display: swap; 
  font-family: 'Nunito';
  font-style: italic;
  font-weight: 400;
  src: url('../fonts/nunito-v26-latin-italic.woff2') format('woff2'); 
}
/* nunito-700 - latin */
@font-face {
  font-display: swap; 
  font-family: 'Nunito';
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/nunito-v26-latin-700.woff2') format('woff2'); 
}
/* nunito-700italic - latin */
@font-face {
  font-display: swap; 
  font-family: 'Nunito';
  font-style: italic;
  font-weight: 700;
  src: url('../fonts/nunito-v26-latin-700italic.woff2') format('woff2'); 
}

/* oooh-baby-regular - latin */
@font-face {
  font-display: swap; 
  font-family: 'Oooh Baby';
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/oooh-baby-v4-latin-regular.woff2') format('woff2'); 
}

body {
  font-family: 'Nunito', sans-serif;
  font-style: normal;
}

/* Photo Grid Styles */
.photo-grid {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 1.5rem;
  position: relative;
  z-index: 1;
}

@media (min-width: 768px) {
  .photo-grid {
      grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .photo-grid {
      grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1280px) {
  .photo-grid {
      grid-template-columns: repeat(4, 1fr);
  }
}

@media (min-width: 1536px) {
  .photo-grid {
      grid-template-columns: repeat(5, 1fr);
  }
}

.photo-wrapper {
  position: relative;
  width: 100%;
  padding-bottom: 75%;
  background-color: rgb(68, 64, 60);
}

.photo-wrapper img {
  position: absolute;
  width: calc(100% - 1.5rem);
  height: calc(100% - 1.5rem);
  left: 0.75rem;
  top: 0.75rem;
  object-fit: contain;
}

/* Mobile Menu Styles */
.mobile-menu-container {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 50;
  display: none;
}

.mobile-menu-container.active {
  display: block;
}

.mobile-menu-backdrop {
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
}

.mobile-menu-content {
  position: absolute;
  top: 4.5rem;
  left: 1rem;
  right: 1rem;
  background-color: rgb(245, 245, 244);
  border-radius: 0.5rem;
  box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1),
              0 2px 4px -2px rgb(0 0 0 / 0.1);
}

/* Back to Top Button */
#myBtn {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 49;
  border: none;
  outline: none;
  background-color: #1E3A8A;
  color: white;
  cursor: pointer;
  padding: 8px;
  border-radius: 8px;
}

#myBtn:hover {
  background-color: #555;
}

/* Transition Classes für Alpine.js */
.transition-opacity {
  transition-property: opacity;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

.duration-200 {
  transition-duration: 200ms;
}

.duration-150 {
  transition-duration: 150ms;
}

.opacity-0 {
  opacity: 0;
}

.opacity-100 {
  opacity: 1;
}

/* Safari Tastaturnavigation Fixes */
/* Explizite Fokussierbarkeit für alle interaktiven Elemente */
a[href], button, [role="button"], [tabindex]:not([tabindex="-1"]) {
    -webkit-user-select: none;
    -moz-user-select: none;
    user-select: none;
}

/* Safari-spezifische Regeln */
@supports (-webkit-appearance: none) {
    /* Entferne Safari-spezifische Tap-Highlights */
    a[href], button, [role="button"] {
        -webkit-tap-highlight-color: transparent;
    }
    
    /* Stelle sicher, dass Links fokussierbar sind */
    a[href]:not([tabindex="-1"]) {
        -webkit-user-select: none;
    }
}

/* Verstärkte Focus-Styles für bessere Safari-Unterstützung */
a[href]:focus,
button:focus,
[role="button"]:focus,
[role="menuitem"]:focus {
    outline: 2px solid #9CCE37 !important;
    outline-offset: 2px !important;
    border-radius: 4px;
    background-color: rgba(156, 206, 55, 0.1) !important;
}

/* Spezielle Behandlung für Navigation Links */
.nav-link:focus,
.focus-visible:focus {
    outline: 2px solid #9CCE37 !important;
    outline-offset: 2px !important;
    border-radius: 4px;
    background-color: rgba(156, 206, 55, 0.1);
}

/* Mobile Menu Links */
.mobile-menu-content a:focus {
    outline: 2px solid #9CCE37 !important;
    outline-offset: 2px !important;
    border-radius: 4px;
    background-color: rgba(156, 206, 55, 0.2) !important;
}

/* Dropdown Menu Items */
[role="menuitem"]:focus {
    outline: 2px solid #9CCE37 !important;
    outline-offset: 2px !important;
    border-radius: 4px;
    background-color: rgba(156, 206, 55, 0.1) !important;
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
    a[href]:focus,
    button:focus,
    [role="button"]:focus {
        outline: 3px solid #000 !important;
        background-color: #fff !important;
        color: #000 !important;
    }
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
    a[href]:focus,
    button:focus,
    [role="button"]:focus {
        transition: none !important;
    }
}