/* ── ANIMATIONS ── */
/* ── ANIMATIONS ── */
  @keyframes fadeUp {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  @keyframes fadeIn {
    from { opacity: 0; }
    to   { opacity: 1; }
  }

  @keyframes underlineGrow {
    to { transform: scaleX(1); }
  }

  @keyframes rotateBg {
    to { transform: rotate(360deg); }
  }

  @keyframes float {
    0%, 100% { transform: translateY(0px); }
    50% { transform: translateY(-12px); }
  }

  @keyframes pulseGlow {
    0%, 100% { box-shadow: 0 0 15px rgba(123,95,255,0.15), 0 0 30px rgba(123,95,255,0.05); }
    50% { box-shadow: 0 0 25px rgba(123,95,255,0.3), 0 0 50px rgba(123,95,255,0.1); }
  }

  @keyframes shimmer {
    0% { background-position: -200% center; }
    100% { background-position: 200% center; }
  }

  @keyframes borderGlow {
    0%, 100% { border-color: rgba(123,95,255,0.2); }
    50% { border-color: rgba(160,132,255,0.5); }
  }

  @keyframes slideInLeft {
    from { opacity: 0; transform: translateX(-40px); }
    to   { opacity: 1; transform: translateX(0); }
  }

  @keyframes slideInRight {
    from { opacity: 0; transform: translateX(40px); }
    to   { opacity: 1; transform: translateX(0); }
  }

  @keyframes scaleIn {
    from { opacity: 0; transform: scale(0.9); }
    to   { opacity: 1; transform: scale(1); }
  }

  @keyframes breathe {
    0%, 100% { opacity: 0.6; }
    50% { opacity: 1; }
  }

  @keyframes floatParticle {
    0% { transform: translateY(0) translateX(0); opacity: 0; }
    10% { opacity: 1; }
    90% { opacity: 1; }
    100% { transform: translateY(-100vh) translateX(var(--drift, 20px)); opacity: 0; }
  }

  @keyframes runeRotate {
    0% { transform: rotate(0deg); opacity: 0.3; }
    50% { opacity: 0.6; }
    100% { transform: rotate(360deg); opacity: 0.3; }
  }

  @keyframes gradientShift {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
  }

  /* Scroll-triggered reveal animations */
  .reveal {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.7s ease, transform 0.7s ease;
  }
  .reveal.visible {
    opacity: 1;
    transform: translateY(0);
  }
  .reveal-left {
    opacity: 0;
    transform: translateX(-40px);
    transition: opacity 0.7s ease, transform 0.7s ease;
  }
  .reveal-left.visible {
    opacity: 1;
    transform: translateX(0);
  }
  .reveal-right {
    opacity: 0;
    transform: translateX(40px);
    transition: opacity 0.7s ease, transform 0.7s ease;
  }
  .reveal-right.visible {
    opacity: 1;
    transform: translateX(0);
  }

  /* Particle dots */
  .particles {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 3;
  }

  .particle {
    position: absolute;
    width: 2px; height: 2px;
    border-radius: 50%;
    background: rgba(160, 130, 255, 0.5);
    animation: twinkle var(--d, 3s) var(--delay, 0s) infinite;
  }

  /* Floating ambient particles */
  .ambient-particle {
    position: absolute;
    width: var(--size, 3px);
    height: var(--size, 3px);
    border-radius: 50%;
    background: radial-gradient(circle, var(--color, rgba(160,130,255,0.6)) 0%, transparent 70%);
    animation: floatParticle var(--dur, 8s) var(--delay, 0s) infinite linear;
    pointer-events: none;
  }

  /* Decorative rune circles */
  .rune-circle {
    position: absolute;
    border: 1px solid rgba(123,95,255,0.15);
    border-radius: 50%;
    animation: runeRotate var(--dur, 20s) linear infinite;
    pointer-events: none;
  }
  .rune-circle::before {
    content: '';
    position: absolute;
    top: -2px; left: 50%;
    width: 4px; height: 4px;
    background: rgba(160,132,255,0.4);
    border-radius: 50%;
    transform: translateX(-50%);
  }

  @keyframes twinkle {
    0%, 100% { opacity: 0.2; transform: scale(1); }
    50% { opacity: 0.9; transform: scale(1.5); }
  }


  /* ── VIDEO BACKGROUND für alle Sektionen ── */
  .section-video-wrap {
    position: relative;
    width: 100%;
    min-height: 100vh;
    overflow: hidden;
  }
  .section-video-wrap .bg-video {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.35;
    filter: saturate(0.6) brightness(0.5) sepia(0.2);
    z-index: 0;
  }
  .section-video-wrap .bg-overlay {
    position: absolute;
    inset: 0;
    z-index: 1;
    background: linear-gradient(180deg, rgba(5,3,15,0.65) 0%, rgba(8,5,25,0.45) 50%, rgba(5,3,15,0.7) 100%);
  }
  .section-video-wrap .section-content {
    position: relative;
    z-index: 2;
    width: 100%;
  }
