/* =========================================================
   responsive.css — Breakpoints raw&royal
   Mobile-first. Overrides greifen ab den jeweiligen
   min-width Schwellen nach oben, Ausnahmen via max-width.

   Breakpoints:
   --bp-sm:  480px   (kleines Phone)
   --bp-md:  768px   (Tablet / großes Phone landscape)
   --bp-lg:  1024px  (kleines Desktop / Tablet landscape)
   --bp-xl:  1280px  (Desktop)
   ========================================================= */

/* -------------------------------------------------------
   NAV
------------------------------------------------------- */

/* Mobile: Burger sichtbar, Links weg — schon in components.css.
   Hier nur feintuning. */

@media (max-width: 480px) {
  .nav__inner {
    padding-inline: var(--space-5);
  }
  .nav__logo {
    font-size: var(--text-base);
  }
}

/* -------------------------------------------------------
   HERO
------------------------------------------------------- */

@media (max-width: 768px) {
  .hero {
    min-height: 100svh;
  }
  .hero__content {
    padding-inline: var(--space-6);
    padding-bottom: var(--space-16);
  }
  .hero__actions {
    flex-direction: column;
    align-items: flex-start;
  }
  .hero__actions .btn {
    width: 100%;
    text-align: center;
    justify-content: center;
  }
}

@media (max-width: 480px) {
  .hero__scroll-hint {
    display: none; /* zu wenig Platz auf kleinen Phones */
  }
}

/* -------------------------------------------------------
   VOLLBILD-PANELS
------------------------------------------------------- */

@media (max-width: 768px) {
  .panel {
    min-height: 80vh;
  }

  .panel__content {
    padding: 0 var(--space-6) var(--space-12);
  }

  /* ROYAL-Inhalt auf Mobile: wieder links, nicht rechts */
  .panel__content--right {
    align-self: flex-start;
    text-align: left;
  }

  .panel__punch--right {
    justify-content: flex-start;
  }

  .panel__punch--right::after {
    display: none;
  }

  .panel__punch--right::before {
    content: '';
    display: block;
    width: 24px;
    height: 1px;
    background: rgba(184, 145, 92, 0.45);
    flex-shrink: 0;
  }

  .panel__tags--dark {
    justify-content: flex-start;
  }

  /* Bildplatzhalter auf Mobile kleiner / ausblenden */
  .panel__img-hint {
    width: 120px;
    height: 85px;
    top: var(--space-6);
    right: var(--space-6);
  }

  .panel__img-hint--left {
    left: var(--space-6);
  }
}

@media (max-width: 480px) {
  .panel__headline {
    font-size: clamp(60px, 18vw, 100px);
  }

  /* Bildplatzhalter auf kleinen Phones ganz weg */
  .panel__img-hint {
    display: none;
  }
}

/* -------------------------------------------------------
   KONTAKT
------------------------------------------------------- */

@media (max-width: 768px) {
  .kontakt__headline {
    font-size: var(--text-xl);
    max-width: none;
  }
}

@media (max-width: 480px) {
  .kontakt__grid {
    grid-template-columns: 1fr 1fr;
  }

  .contact-card {
    padding: var(--space-4) var(--space-4);
  }
}

/* -------------------------------------------------------
   FOOTER
------------------------------------------------------- */

@media (max-width: 768px) {
  .footer__inner {
    grid-template-columns: 1fr;
    gap: var(--space-8);
  }

  .footer__nav {
    justify-content: flex-start;
    gap: var(--space-2) var(--space-5);
  }
}

/* -------------------------------------------------------
   DESKTOP — Atmen lassen
------------------------------------------------------- */

@media (min-width: 1280px) {
  .panel__content {
    padding-left: clamp(var(--space-16), 6vw, var(--space-32));
    padding-bottom: clamp(var(--space-20), 8vw, var(--space-40));
  }

  .panel__content--right {
    padding-right: clamp(var(--space-16), 6vw, var(--space-32));
    padding-left: 0;
  }

  .panel__content--center {
    padding-inline: clamp(var(--space-16), 6vw, var(--space-32));
  }
}

/* -------------------------------------------------------
   REDUCED MOTION — Animationen respektieren
   (bereits in reset.css via prefers-reduced-motion,
   hier: reveal-Klassen sofort sichtbar)
------------------------------------------------------- */

@media (prefers-reduced-motion: reduce) {
  .reveal,
  .reveal--left,
  .reveal--right,
  .hero__claim,
  .hero__sub,
  .hero__actions {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }

  .hero__scroll-hint {
    animation: none !important;
  }
}
