body { font-family: 'Inter', system-ui, sans-serif; }

body,
p,
li,
.text-justify,
.prose p,
.prose li,
article p,
article li {
  text-align: justify;
  hyphens: auto;               /* automatischer Zeilenumbruch mit Trennung – sehr wichtig für DE! */
  -webkit-hyphens: auto;
  -ms-hyphens: auto;
}

/* Ausnahmen: Überschriften, Buttons, zentrierte Texte etc. bleiben left/center */
h1, h2, h3, h4, h5, h6,
.font-bold,
.font-black,
.text-center,
button,
a.btn-like,                /* falls du so was hast */
.review-box p {            /* kurze Zitate oft besser linksbündig */
  text-align: left !important;   /* oder inherit, je nach Design */
}

/* Hero-Überschrift & Subline bleiben zentriert → bereits text-center */
.gradient-hero h1,
.gradient-hero p {
  text-align: center;
}

/* Optional: Bessere Lesbarkeit bei schmalen Spalten (Mobile) */
@media (max-width: 640px) {
  body,
  p,
  li {
    text-align: left;          /* Blocksatz auf sehr schmalen Screens oft schlechter lesbar */
    hyphens: none;
  }
}

.gradient-hero {
  background: linear-gradient(135deg, var(--tw-gradient-stops));
  --tw-gradient-from: #000814 var(--tw-gradient-from-position);
  --tw-gradient-to: #001d3d var(--tw-gradient-to-position);
  --tw-gradient-stops: var(--tw-gradient-from), #003566 50%, #000814 var(--tw-gradient-to-position);
}

/* Sprach-Dropdown */
.language-dropdown {
  position: relative;
}
.language-dropdown-content {
  display: none;
  position: absolute;
  right: 0;
  top: 100%;
  background-color: #001d3d;
  min-width: 140px;
  box-shadow: 0 8px 16px rgba(0,0,0,0.4);
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid #334155;
  z-index: 1000;
}
.language-dropdown:hover .language-dropdown-content {
  display: block;
}
.language-item {
  display: flex;
  align-items: center;
  padding: 10px 16px;
  color: #e0e7ff;
  text-decoration: none;
  transition: background 0.2s;
}
.language-item:hover {
  background-color: #003566;
}
.flag {
  width: 24px;
  height: 18px;
  margin-right: 10px;
  border-radius: 2px;
  object-fit: cover;
}

/* Ken-Burns-Schwenk – pausiert bei Hover */
.service-image-container {
  overflow: hidden;
  border-radius: 24px;
  box-shadow: 0 10px 40px rgba(0,0,0,0.5);
}

.service-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  will-change: transform;
  animation: pan-smooth 20s infinite ease-in-out;
}

@keyframes pan-smooth {
  0%   { transform: translateX(-15%) scale(1.25); }
  50%  { transform: translateX( 15%) scale(1.25); }
  100% { transform: translateX(-15%) scale(1.25); }
}

.service-image-container:hover .service-image {
  animation-play-state: paused;
}

@media (prefers-reduced-motion: reduce) {
  .service-image {
    animation: none !important;
    transform: scale(1.1) !important;
  }
}

/* Logo-Größe und Anpassung */
.logo-img {
  height: 44px;
  width: auto;
  max-width: 220px;
  object-fit: contain;
}

/* Optional: Schatten beim Scrollen */
#modal-content::-webkit-scrollbar {
  width: 6px;
}
#modal-content::-webkit-scrollbar-thumb {
  background-color: #334155;
  border-radius: 3px;
}

#modal .sticky {
  transition: box-shadow 0.2s;
}
#modal-content.scrolling .sticky {
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

.reviews-wrapper,
.partners-wrapper {
  will-change: transform;          /* Performance */
  display: flex;
  flex-wrap: nowrap;               /* Sehr wichtig! */
}

.reviews-wrapper > *,
.partners-wrapper > * {
  flex: 0 0 auto;                  /* Kein Wachsen/Schrumpfen */
}

.reviews-container,
.partner-container {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding: 1.5rem 0;
  cursor: grab;
  user-select: none;
}

.reviews-container:active,
.partner-container:active {
  cursor: grabbing;
}

.reviews-track,
.partner-track {
  display: flex;
  will-change: transform;
  backface-visibility: hidden;
  touch-action: pan-y; /* verhindert vertikales Scrollen beim Drag */
}

.review-box,
.partner-box {
  flex: 0 0 auto;
  transition: all 0.35s ease;
}

/* Hervorhebung des zentrierten / aktiven Elements (Reviews) */
.review-box.active {
  border-color: #ffc300;
  box-shadow: 0 0 30px rgba(255, 195, 0, 0.3);
  transform: scale(1.07);
  z-index: 10;
}

/* Partner etwas dezenter */
.partner-box {
  /* opacity: 0.85; */
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.partner-box:hover {
  opacity: 1;
  transform: scale(1.08);
}

/* Optional: mehr Luft bei sehr kleinen Bildschirmen */
@media (max-width: 640px) {
  .reviews-track,
  .partner-track {
    gap: 1rem !important;
  }
  .review-box {
    max-width: 85vw;
  }
}

.reviews-container,
.partner-container {
  position: relative;
  overflow: hidden;
  cursor: grab;
  user-select: none;
}

.reviews-container:active,
.partner-container:active {
  cursor: grabbing;
}

/* ==========================================================================
   True seamless infinite horizontal marquee – pure CSS
   ========================================================================== */

.marquee-container {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding: 1.5rem 0;
  --gap: 1.75rem;           /* Abstand zwischen Items – später anpassbar */
  --duration: 60s;          /* Basisgeschwindigkeit – wird pro Container überschrieben */
}

.marquee-track {
  display: flex;
  flex-wrap: nowrap;
  gap: var(--gap);
  width: max-content;       /* Sehr wichtig! */
  will-change: transform;
  animation: scroll-left var(--duration) linear infinite;
}

.marquee-container:hover .marquee-track,
.marquee-container:focus-within .marquee-track {
  animation-play-state: paused;
}

/* Geschwindigkeiten pro Typ */
.reviews-container {
  --duration: 90s;          /* langsamer & edler für Text */
  --gap: 2rem;
}

.partner-container {
  --duration: 50s;          /* flotter für viele kleine Logos */
  --gap: 3rem;              /* mehr Luft bei Logos */
}

/* Die eigentliche Animation */
@keyframes scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(calc(-50% - var(--gap) / 2));
    /* -50% weil wir doppelt rendern → genau eine Kopie verschieben */
  }
}

/* Responsives Feintuning */
@media (max-width: 640px) {
  .reviews-container  { --gap: 1.25rem; --duration: 70s; }
  .partner-container  { --gap: 2rem;    --duration: 40s; }
}

/* Einzelne Boxen (wie vorher) */
.review-box,
.partner-box {
  flex: 0 0 auto;
  transition: transform 0.35s ease;
  background-color: white;
  border-radius: 5px;
  padding:20px;
}

.review-box:hover,
.partner-box:hover {
  transform: scale(1.04);
}

