/* BeThatHost — Motion-Schicht (edel + lebendig, performant).
   Respektiert prefers-reduced-motion. Greift site-weit über /assets/motion.css. */

html { scroll-behavior: smooth; }

/* ---------- Scroll-Reveal (JS vergibt .reveal-init, dann .is-visible) ---------- */
@media (prefers-reduced-motion: no-preference) {
  .reveal-init {
    opacity: 0;
    transform: translateY(22px);
    transition: opacity 0.7s cubic-bezier(0.22, 0.7, 0.2, 1),
      transform 0.7s cubic-bezier(0.22, 0.7, 0.2, 1);
    will-change: opacity, transform;
  }
  .reveal-init.is-visible {
    opacity: 1;
    transform: none;
  }

  /* Hero-Eintritt — gestaffelt */
  .hero .hero-inner > * {
    animation: hhqHeroIn 0.85s both cubic-bezier(0.22, 0.7, 0.2, 1);
  }
  .hero .hero-inner > *:nth-child(1) { animation-delay: 0.05s; }
  .hero .hero-inner > *:nth-child(2) { animation-delay: 0.16s; }
  .hero .hero-inner > *:nth-child(3) { animation-delay: 0.3s; }
  .hero .hero-inner > *:nth-child(4) { animation-delay: 0.44s; }
  @keyframes hhqHeroIn {
    from { opacity: 0; transform: translateY(24px); }
    to { opacity: 1; transform: none; }
  }

  /* Schimmer auf dem hervorgehobenen Hero-Wort */
  .hero h1 .glow {
    background-size: 220% auto;
    animation: hhqGlow 7s ease-in-out infinite;
  }
  @keyframes hhqGlow {
    0%, 100% { background-position: 0% center; }
    50% { background-position: 120% center; }
  }

  /* Portal-Kacheln: sanfter Bild-Zoom bei Hover (eigene Ebene = sicher) */
  .occ .bg { transition: transform 0.5s cubic-bezier(0.22, 0.7, 0.2, 1); }
  .occ:hover .bg { transform: scale(1.06); }
}

/* ---------- Feiner Button-Glanz (dezent, immer aktiv) ---------- */
.btn-primary,
.pick a.cta {
  position: relative;
  overflow: hidden;
}
.btn-primary::after,
.pick a.cta::after {
  content: "";
  position: absolute;
  top: 0;
  left: -130%;
  width: 60%;
  height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255, 255, 255, 0.4), transparent);
  transform: skewX(-20deg);
  transition: left 0.6s ease;
  pointer-events: none;
}
.btn-primary:hover::after,
.pick a.cta:hover::after { left: 140%; }

/* ---------- Etwas mehr Tiefe bei Karten-Hover ---------- */
.post-card, .cat-card, .occ {
  transition: transform 0.22s cubic-bezier(0.22, 0.7, 0.2, 1),
    box-shadow 0.22s ease, border-color 0.22s ease;
}
