.svg-loader {
  height: auto;
  display: block;
  margin: 60px auto;
}

.path-loader {
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

/* === ANIMATION STROKE === */
.letter-stroke {
  fill: #1D1C58;
  fill-opacity: 0;
}

.letter-F.letter-stroke { animation-delay: 0s; }
.letter-A.letter-stroke { animation-delay: 0.2s; }
.letter-L.letter-stroke { animation-delay: 0.4s; }
.letter-L2.letter-stroke { animation-delay: 0.6s; }
.letter-E.letter-stroke { animation-delay: 0.8s; }
.letter-R.letter-stroke { animation-delay: 1.0s; }

@keyframes write-loop {
  0% {
    stroke-dashoffset: 1000;
  }
  30% {
    stroke-dashoffset: 0;
  }
  70% {
    stroke-dashoffset: 0;
  }
  100% {
    stroke-dashoffset: 1000;
  }
}

/* === ANIMATION FILL === */
.letter-fill {
  animation: fill-loop 4s ease-in-out infinite;
}

.letter-F.letter-fill { animation-delay: 0.4s; }
.letter-A.letter-fill { animation-delay: 0.6s; }
.letter-L.letter-fill { animation-delay: 0.8s; }
.letter-L2.letter-fill { animation-delay: 1.0s; }
.letter-E.letter-fill { animation-delay: 1.2s; }
.letter-R.letter-fill { animation-delay: 1.4s; }

@keyframes fill-loop {
  0%, 30% {
    fill-opacity: 0;
  }
  50%, 70% {
    fill-opacity: 1;
  }
  100% {
    fill-opacity: 0;
  }
}

/* === UNDERLINE === */
.underline-line {
  stroke: gold;
  stroke-width: 0;
  transform: translateX(100%);
  opacity: 0;
  animation: slide-loop 4s ease-in-out infinite;
  animation-delay: 1.6s;
}

@keyframes slide-loop {
  0%, 30% {
    transform: translateX(100%);
    opacity: 0;
  }
  50%, 70% {
    transform: translateX(0);
    opacity: 1;
  }
  100% {
    transform: translateX(100%);
    opacity: 0;
  }
}


/* FÜR HANDY MENU */

/* Basis Panel Style */
.menu-panel {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: transform 0.3s ease-in-out, opacity 0.3s ease-in-out;
  opacity: 0;
  pointer-events: none;
  /* Klicks ignorieren wenn unsichtbar */
  background-color: #003a63;
  /* Hintergrundfarbe sicherstellen */
}

/* Aktives Panel */
.menu-panel[data-state="active"] {
  transform: translateX(0);
  opacity: 1;
  pointer-events: auto;
  z-index: 20;
}

/* Panel wartet rechts */
.menu-panel[data-state="right"] {
  transform: translateX(100%);
}

/* Panel wartet links */
.menu-panel[data-state="left"] {
  transform: translateX(-100%);
}

/* Fokus Ringe sichtbar machen (Accessibility) */
*:focus-visible {
  outline: 2px solid #fbbf24;
  /* Gelb */
  outline-offset: 2px;
}

/* --- Mobile Menu Smooth Transitions --- */
#mobile-menu {
  transition:
    transform 420ms cubic-bezier(.22, .61, .36, 1),
    opacity 360ms ease,
    backdrop-filter 300ms ease;
  will-change: transform, opacity;
  backdrop-filter: blur(2px);
}

/* States via data-open */
#mobile-menu[data-open="false"] {
  opacity: 0;
  transform: translateX(-6%);
  pointer-events: none;
}

#mobile-menu[data-open="true"] {
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}

/* Panels slide system */
.menu-panel {
  position: absolute;
  inset: 0;
  padding-bottom: 5rem;
  /* Platz für Close-Button */
  transition: transform 420ms cubic-bezier(.22, .61, .36, 1), opacity 300ms ease;
  will-change: transform, opacity;
  opacity: 0;
  transform: translateX(8%);
  pointer-events: none;
}

.menu-panel[data-state="active"] {
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}

.menu-panel[data-state="left"] {
  opacity: 0;
  transform: translateX(-8%);
}

.menu-panel[data-state="right"] {
  opacity: 0;
  transform: translateX(8%);
}

/* Close button hover micro-interaction */
#mobile-menu-close {
  transition: transform 180ms ease;
}

#mobile-menu-close:hover {
  transform: rotate(90deg) scale(1.05);
}


#mobile-menu {
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

/* When the menu is CLOSED */
#mobile-menu[data-open="false"] {
  opacity: 0;
  visibility: hidden;
  /* Hides it from screen readers/keyboard tabbing */
  pointer-events: none;
  /* Crucial: Allows clicks to pass through to the page below */
}

/* When the menu is OPEN */
#mobile-menu[data-open="true"] {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  /* Re-enables clicks on the menu */
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {

  #mobile-menu,
  .menu-panel {
    transition: none !important;
  }
}