/* =====================================================
   Bram_Banner – Voordeur Banner (Lift & Mount FINAL)
   ===================================================== */

/* --- Container --- */
.brm-banner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;                /* cellen vullen hele hoogte */
  height: 260px;
  border-radius: .25rem;
  overflow: hidden;
  background: #fff;
  isolation: isolate;
}

/* --- Achtergrond --- */
.brm-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: var(--bg);
  background-size: cover;
  background-position: center;
  transform-origin: center;
  animation: brm-ken 22s ease-in-out infinite alternate;
}
@keyframes brm-ken {
  0% { transform: scale(1.02); }
  100% { transform: scale(1.06); }
}

/* --- Licht verloop links --- */
.brm-banner::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    90deg,
    rgba(255,255,255,.94) 0%,
    rgba(255,255,255,.6) 40%,
    rgba(255,255,255,.1) 65%,
    rgba(255,255,255,0) 85%
  );
  pointer-events: none;
}

/* --- Tekstblok --- */
.brm-banner__info {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  justify-content: center;             /* verticaal centreren tekst */
  height: 100%;
  padding: 1.5rem 2rem;
  text-align: right;
  font-family: "Open Sans", Arial, sans-serif;
  box-sizing: border-box;
}

.brm-banner__headline {
  margin: 0 0 1.1rem;
  font-weight: 800;
  font-size: 2.9rem;
  line-height: 1.05;
  /* color: #0a2c64; */
}

.brm-banner__textstack {
  position: relative;
  min-height: 74px;
  overflow: hidden;
}

.brm-banner__textlayer {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateX(40px);
  transition: opacity 900ms cubic-bezier(.45,.05,.2,1.2),
              transform 900ms cubic-bezier(.45,.05,.2,1.2);
}
.brm-banner__textlayer.visible {
  opacity: 1;
  transform: translateX(0);
  transition-delay: .12s;
}

.brm-banner__prodtitle {
  font-weight: 700;
  font-size: 2.2rem;
  color: #0c4279;
  margin-bottom: .25rem;
}
.brm-banner__price {
  font-size: 2.4rem;
  font-weight: 600;
  color: #0c4279;
}

/* --- Stage rechts --- */
.brm-banner__stage {
  position: relative;
  z-index: 2;
  height: 100%;
  perspective: 1000px;
  overflow: visible;
}

/* --- Frames --- */
.brm-banner__frame {
  position: absolute;
  top: 50%;
  right: 10%;
  transform: translateY(-50%);
  opacity: 0;
  display: none;
  transform-origin: center center;
}
.brm-banner__frame.is-active {
  display: block;
  opacity: 1;
  animation: mountIn 1.4s cubic-bezier(.25,.8,.25,1) forwards;
  z-index: 5;
}
.brm-banner__frame.is-fading {
  display: block;
  opacity: 0;
  animation: mountOut 1s cubic-bezier(.6,.05,.4,1) forwards;
  z-index: 4;
}

/* --- Lift & Mount animatie --- */
@keyframes mountIn {
  0% {
    opacity: 0;
    transform: translateY(80%) translateX(40px)
               rotateX(20deg) rotateY(10deg) scale(.9);
  }
  45% {
    opacity: 1;
    transform: translateY(-52%) translateX(-6px)
               rotateX(-2deg) rotateY(-4deg) scale(1.05);
  }
  70% {
    transform: translateY(-48%) translateX(2px)
               rotateX(1deg) rotateY(2deg) scale(1.02);
  }
  100% {
    opacity: 1;
    transform: translateY(-50%) translateX(0)
               rotateX(0deg) rotateY(0deg) scale(1);
  }
}
@keyframes mountOut {
  0% { opacity: 1; transform: translateY(-50%) translateX(0) scale(1); }
  100% {
    opacity: 0;
    transform: translateY(-60%) translateX(-40px)
               rotateY(-10deg) scale(.95);
    filter: blur(2px);
  }
}

/* --- Bord zelf --- */
.brm-banner__plate {
  display: block;
  position: relative;
  z-index: 6;
  height: 200px;                         /* vaste hoogte desktop */
  width: auto;
  object-fit: contain;
  filter:
    drop-shadow(-5px 8px 18px rgba(0,0,0,.25))
    drop-shadow(-12px 6px 16px rgba(0,0,0,.1))
    saturate(1.03);
}

/* Glansreflectie bij binnenkomst */
.brm-banner__plate::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg,
    rgba(255,255,255,0) 30%,
    rgba(255,255,255,.45) 60%,
    rgba(255,255,255,0) 80%);
  opacity: 0;
  animation: shine 1.8s ease-out .5s forwards;
}
@keyframes shine {
  0%   { opacity: 0; transform: translateX(-100%) skewX(-15deg); }
  30%  { opacity: .6; }
  100% { opacity: 0; transform: translateX(120%) skewX(-15deg); }
}

/* --- Responsief --- */
@media (max-width: 520px) {
  .brm-banner {
    height: 180px;
    grid-template-columns: 1.05fr 0.95fr;
  }

  .brm-banner__info {
    text-align: left;
    padding: 1rem;
    justify-content: center;            /* verticaal gecentreerd op mobiel */
  }

  .brm-banner__headline {
    font-size: 2.2rem;                  /* iets groter dan vorige */
    margin-bottom: .5rem;
  }
  .brm-banner__prodtitle { font-size: 1.4rem; }
  .brm-banner__price { font-size: 1.3rem; }

  .brm-banner__frame { right: 6%; }
  .brm-banner__plate {
    height: 150px;                      /* groter op mobiel */
    max-width: none;
  }
}

@media (max-width: 400px) {
  .brm-banner__headline { font-size: 2rem; }
  .brm-banner__prodtitle { font-size: 1.2rem; }
}

/* ======== Core Web Vitals: prefers-reduced-motion ======== */
@media (prefers-reduced-motion: reduce) {
  .brm-banner__frame,
  .brm-banner__textlayer {
    animation: none !important;
    transition: none !important;
  }
}

/* ======== Toegankelijkheid & klikdoelen ======== */
.brm-banner__textlink {
  display: inline-block;
  text-decoration: none;
}

/* (Optioneel) Zorg dat images nooit buiten hun frame clippen in edge cases */
.brm-banner__plate {
  max-width: 100%;
  /* hoogte is in CSS elders 200px op desktop & 150px mobiel → dimensies kloppen met HTML-attributen */
}

/* Correctie voor achtergrondpositie op mobiel */
@media (max-width: 600px) {
  .brm-banner::before {
    background-position: 80% center; /* iets meer naar links */
    background-size: 150%;
  }
}