/* ==========================================================================
   mobile.css — Stile für die mobile Version (Smartphones)
   Wird nach style.css geladen und überschreibt dort, wo nötig.
   Enthält außerdem den Safe-Area-Fix gegen das Clipping in Dynamic Island /
   Statusleiste (Akku, Uhrzeit) auf modernen iPhones.
   ========================================================================== */

@media (max-width: 767px) {

  /* Spacing für mobile reduzieren */
  :root {
    --space-2xl: 5rem;
    --space-xl: 3.5rem;

    /* Banner unter Dynamic Island / Notch schieben (+ kleiner Abstand).
       env() liegt nur im Abstand, nicht in der Banner-Höhe – die bleibt fix. */
    --nav-gap: calc(env(safe-area-inset-top, 0px) + 1.25rem);
  }

  /* Banner: volle Breite mit seitlichem Abstand.
     will-change: transform → eigener GPU-Layer für ruckelfreies Ein-/Ausgleiten. */
  .nav {
    padding: var(--nav-gap) var(--space-sm) 0;
    will-change: transform;
  }

  /* Beim Hinunterscrollen gleitet das Banner nach oben aus dem Bild,
     beim Hochscrollen kommt es zurück (Klasse wird per JS gesetzt). */
  .nav--hidden {
    transform: translateY(-180%);
  }

  /* Inhalt unter dem Banner beginnen lassen */
  .legal-page {
    padding-top: calc(var(--nav-gap) + var(--nav-banner-height) + var(--space-md));
  }

  /* Hero: volle Bildschirmhöhe, damit die nächste Sektion NICHT durchscheint */
  .hero {
    min-height: 100vh;       /* Fallback */
    min-height: 100dvh;      /* dynamische Viewport-Höhe (iOS-Browserleiste) */
    padding-top: calc(var(--nav-gap) + var(--nav-banner-height) + var(--space-lg));
  }

  /* Pfeil im "Entdecken"-Button auf Touch-Geräten entfernen */
  .hero__cta svg {
    display: none;
  }

  /* Nav */
  .btn--nav {
    padding: 0.4rem 1rem;
  }

  /* Sprachumschalter mittig im Banner */
  .lang-toggle {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }

  /* Hscroll → normaler vertikaler Abschnitt, Projekte ausblenden */
  .hscroll {
    height: auto;
  }

  .hscroll__sticky {
    position: relative;
    height: auto;
    overflow: visible;
  }

  .hscroll__track {
    display: block;
    transform: none !important;
  }

  .hscroll__panel {
    width: 100%;
    height: auto;
  }

  .hscroll .about {
    height: auto;
    display: block;
    padding: var(--space-xl) 0;
  }

  .about__pillars { gap: var(--space-sm); }
  .pillar { padding: var(--space-sm); }

  /* Services: Fokus auf 3D, Texte ausblenden */
  .services {
    height: auto;
    min-height: auto;
  }

  .services__sticky {
    position: relative;
    height: auto;
    padding: var(--space-xl) 0;
    overflow: visible;
  }

  .services__layout {
    grid-template-columns: 1fr;
    gap: var(--space-md);
  }

  .services__visual {
    order: 2;
  }

  .services__nav {
    order: 1;
  }

  .services__options {
    display: none;
  }

  .services__pieces {
    transform: perspective(700px) rotateX(10deg) rotateY(-20deg);
    max-width: 300px;
    margin: 0 auto;
    padding: 1rem;
  }

  .service-piece {
    height: 85px;
  }

  .service-piece__label {
    font-size: var(--fs-sm);
    letter-spacing: 0.08em;
  }

  /* Kontakt: Cycler-Layoutshift verhindern */
  .contact__cycler {
    display: block;
  }

  /* Kontakt: Button zentrieren */
  .btn--submit {
    align-self: center;
  }

  /* Legal */
  .legal-hero {
    padding: var(--space-lg) 0 var(--space-md);
  }

  .legal-hero__nav {
    gap: var(--space-md);
  }

  .legal-section {
    padding-bottom: var(--space-lg);
    margin-bottom: var(--space-lg);
  }

}

/* querformat */
@media (max-height: 600px) and (orientation: landscape) {
  .hero {
    min-height: auto;
    padding: calc(var(--nav-height) + 2rem + var(--space-lg)) 0 var(--space-lg);
  }
}
