/* xl - DESKTOP STYLES */ 
@media (min-width: 1120px) {
  /* ------------------------------------ 1. Hero ------------------------------------ */
  /* ---------------- imagens rodam com o scroll ---------------- */
  .home-hero-img-01 { transform: translateY(10px) rotate(-1deg); }
  .home-hero-img-02 { transform: translateY(0px); }
  .home-hero-img-03 { transform: translateY(10px) rotate(1deg); }
  
  
  /* ------------------------------------ 2. Secção com video com scroll ------------------------------------ */
  /* Ativa o encaixe de scroll na página (aplica isto no contentor pai de todas as secções ou no body) */
  html, body {
    scroll-snap-type: y proximity;
  }
  
  /* A tua secção agarra-se ao centro do ecrã quando o utilizador faz scroll perto dela */
  .home-seccao-video-scroll {
    scroll-snap-align: center;
    scroll-snap-stop: always;
    position: relative !important;
    overflow: hidden !important;
  }
  
  /* Container interno limpo */
  .oxy-container-3845-188 {
    overflow: hidden !important;
    display: flex !important;
    align-items: flex-start !important;
  }
  
  /* COLUNA DA ESQUERDA */
  .home-coluna-scroll {
    height: 588px !important; /* Força a ter exatamente a mesma altura que deste ao teu vídeo */
    overflow-y: scroll !important;
    scroll-behavior: auto;
    padding-top: 40px !important;
    padding-bottom: 300px !important; /* Espaço para o último item subir */
  
    /* Esconder barras de scroll */
    &::-webkit-scrollbar { display: none; }
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  
  /* Elementos de texto com 50% de opacidade */
  .home-coluna-scroll > div {
    opacity: 0.5;
    transition: opacity 0.3s ease, transform 0.3s ease;
    transform: scale(0.95);
  }
  
  .home-coluna-scroll > div.item-ativo {
    opacity: 1 !important;
    transform: scale(1);
  }
  
  /* COLUNA DA DIREITA (Vídeo) */
  .video-scroll {
    height: 588px !important;
  }
  .video-scroll video {
    height: 100% !important;
    width: 100%;
    object-fit: cover;
  }
  
}

/* ------------------------------------
   1. Hero - carrossel SmartLite
   ------------------------------------ */

.oxy-container-3845-105.smartlite-carousel-ready {
  position: relative !important;
  isolation: isolate;
  display: block !important;
  width: 100% !important;
  height: clamp(250px, 28vw, 390px) !important;
  margin-top: 44px;
  padding-top: 0 !important;
  overflow: visible !important;
  perspective: 1200px;
}

.oxy-container-3845-105.smartlite-carousel-ready::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: 0;
  width: min(62vw, 900px);
  height: 1px;
  transform: translateX(-50%);
  background: rgba(0, 0, 0, 0.72);
}

.oxy-container-3845-105.smartlite-carousel-ready > img {
  position: absolute !important;
  top: 8px;
  left: 50%;
  display: block;
  width: min(60vw, 860px) !important;
  max-width: none !important;
  height: auto !important;
  border-radius: 8px;
  object-fit: contain;
  box-shadow: 0 28px 60px rgba(13, 13, 13, 0.24);
  opacity: 0;
  pointer-events: none;
  transform-origin: 50% 84%;
  transition:
    transform 720ms cubic-bezier(0.22, 1, 0.36, 1),
    opacity 420ms ease,
    filter 420ms ease;
  will-change: transform, opacity;
}

.oxy-container-3845-105.smartlite-carousel-ready > img.is-active {
  z-index: 5;
  opacity: 1;
  filter: saturate(1.04) contrast(1.02);
  transform: translate3d(-50%, 0, 0) rotate(0deg) scale(1);
}

.oxy-container-3845-105.smartlite-carousel-ready > img.is-left {
  z-index: 3;
  opacity: 0.96;
  transform: translate3d(calc(-50% - min(48vw, 690px)), 34px, -120px) rotate(-4deg) scale(0.75);
}

.oxy-container-3845-105.smartlite-carousel-ready > img.is-right {
  z-index: 3;
  opacity: 0.96;
  transform: translate3d(calc(-50% + min(48vw, 690px)), 34px, -120px) rotate(4deg) scale(0.75);
}

.oxy-container-3845-105.smartlite-carousel-ready > img.is-far-left {
  z-index: 1;
  opacity: 0.24;
  transform: translate3d(calc(-50% - min(78vw, 1120px)), 58px, -220px) rotate(-7deg) scale(0.62);
}

.oxy-container-3845-105.smartlite-carousel-ready > img.is-far-right {
  z-index: 1;
  opacity: 0.24;
  transform: translate3d(calc(-50% + min(78vw, 1120px)), 58px, -220px) rotate(7deg) scale(0.62);
}

.oxy-container-3845-105.smartlite-carousel-ready > img.is-hidden {
  z-index: 0;
  opacity: 0;
  transform: translate3d(-50%, 80px, -300px) rotate(0deg) scale(0.55);
}

@media (max-width: 767px) {
  .oxy-container-3845-105.smartlite-carousel-ready {
    height: 170px !important;
    margin-top: 38px;
    overflow: hidden !important;
  }

  .oxy-container-3845-105.smartlite-carousel-ready::after {
    width: min(60vw, 360px);
  }

  .oxy-container-3845-105.smartlite-carousel-ready > img {
    top: 18px;
    width: min(74vw, 420px) !important;
    border-radius: 6px;
  }

  .oxy-container-3845-105.smartlite-carousel-ready > img.is-left {
    transform: translate3d(calc(-50% - 58vw), 18px, -120px) rotate(-4deg) scale(0.74);
  }

  .oxy-container-3845-105.smartlite-carousel-ready > img.is-right {
    transform: translate3d(calc(-50% + 58vw), 18px, -120px) rotate(4deg) scale(0.74);
  }

  .oxy-container-3845-105.smartlite-carousel-ready > img.is-far-left,
  .oxy-container-3845-105.smartlite-carousel-ready > img.is-far-right {
    opacity: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .oxy-container-3845-105.smartlite-carousel-ready > img {
    transition: none;
  }
}

/* ------------------------------------
   2. Secção com vídeo com scroll
   Mantido do código anterior, mas limpo para CSS puro.
   ------------------------------------ */

html,
body {
  scroll-snap-type: y proximity;
}

.home-seccao-video-scroll {
  scroll-snap-align: center;
  scroll-snap-stop: always;
  position: relative !important;
  overflow: hidden !important;
  width: 100%;
}

.oxy-container-3845-188 {
  overflow: hidden !important;
  display: flex !important;
  align-items: stretch !important;
}

.home-coluna-scroll {
  overflow-y: scroll !important;
  scroll-behavior: auto;
  padding-top: 20px !important;
  padding-bottom: 300px !important;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.home-coluna-scroll::-webkit-scrollbar {
  display: none;
}

.home-coluna-scroll > div {
  opacity: 0.5;
  transition: opacity 0.3s ease, transform 0.3s ease;
  transform: scale(0.95);
}

.home-coluna-scroll > div.item-ativo {
  opacity: 1 !important;
  transform: scale(1);
}

.video-scroll {
  height: auto !important;
  display: flex;
  align-items: center;
}

.video-scroll .ee-video-container {
  width: 100%;
  height: 100%;
}

.video-scroll video {
  width: 100%;
  height: auto !important;
  display: block;
}

