/* Casos de éxito | Refinado de ficha informativa | v4 */

.casos-carousel-stage .caso-content{
  width:min(330px,23vw);
  max-height:clamp(430px,38vw,600px);
  overflow:hidden;
  gap:clamp(12px,1vw,18px);
  padding:clamp(18px,1.7vw,26px);
  border-color:rgba(31,42,36,.075);
  background:linear-gradient(135deg, rgba(255,253,247,.92), rgba(246,241,232,.88));
  box-shadow:0 18px 48px rgba(31,42,36,.075);
}

.casos-carousel-stage .caso-card-top{
  gap:clamp(10px,.9vw,15px);
}

.casos-carousel-stage .caso-content-kicker{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  color:rgba(31,42,36,.68);
  font-size:clamp(.72rem,.82vw,.9rem);
  font-weight:800;
  line-height:1.25;
  letter-spacing:-.02em;
}

.casos-carousel-stage .caso-card-top h3,
.casos-carousel-stage .caso-card h3{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  font-size:clamp(1.62rem,2.15vw,2.85rem);
  line-height:.98;
  letter-spacing:-.055em;
}

.casos-carousel-stage .caso-excerpt,
.casos-carousel-stage .caso-card p{
  display:-webkit-box;
  -webkit-line-clamp:4;
  -webkit-box-orient:vertical;
  overflow:hidden;
  max-width:290px;
  color:rgba(31,42,36,.68);
  font-size:clamp(.76rem,.8vw,.88rem);
  line-height:1.52;
  font-weight:520;
}

.casos-carousel-stage .caso-meta{
  max-width:290px;
  gap:10px;
}

.casos-carousel-stage .caso-service{
  padding-bottom:10px;
  border-bottom:1px solid rgba(31,42,36,.28);
}

.casos-carousel-stage .caso-service,
.casos-carousel-stage .caso-proof{
  gap:4px;
}

.casos-carousel-stage .caso-meta small{
  color:rgba(31,42,36,.32);
  font-size:clamp(.72rem,.8vw,.88rem);
  font-weight:820;
}

.casos-carousel-stage .caso-meta strong{
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  color:rgba(31,42,36,.72);
  font-size:clamp(.72rem,.76vw,.84rem);
  font-weight:620;
  line-height:1.38;
}

.casos-carousel-stage .caso-link{
  min-width:124px;
  min-height:42px;
  width:max-content;
  margin-top:clamp(6px,.9vw,14px);
  padding:10px 22px;
  font-size:.84rem;
  font-weight:650;
}

/* Profundidad visual del carrusel */
.casos-carousel-stage .casos-carousel-viewport{
  height:clamp(520px,38vw,650px);
}

.casos-carousel-stage .caso-card-visual{
  width:min(680px,40vw);
  height:clamp(350px,29vw,500px);
  opacity:calc(1 - (var(--abs-offset) * .30));
  filter:saturate(calc(1 - (var(--abs-offset) * .16))) contrast(calc(1 - (var(--abs-offset) * .08))) brightness(calc(1 - (var(--abs-offset) * .13))) blur(calc(var(--abs-offset) * .45px));
  transform:
    translate(-50%,-50%)
    translateX(calc(var(--offset) * min(22vw,395px)))
    translateY(calc(var(--abs-offset) * 18px))
    scale(calc(1 - (var(--abs-offset) * .18)));
}

.casos-carousel-stage .caso-card-visual.is-active{
  width:min(920px,54vw);
  height:auto;
  aspect-ratio:16 / 9;
  opacity:1;
  filter:none;
  transform:translate(calc(-50% - min(16vw,300px)),-50%) scale(1);
}

.casos-carousel-stage .caso-card-visual.is-near{
  opacity:.34;
}

.casos-carousel-stage .caso-card-visual.is-far{
  opacity:.16;
}

.casos-carousel-stage .caso-card-visual:not(.is-active) .caso-media{
  box-shadow:none;
}

.casos-carousel-stage .caso-card-visual:not(.is-active) .caso-media:after{
  content:"";
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  background:rgba(255,253,247,.42);
  backdrop-filter:blur(1.6px) saturate(.72);
  -webkit-backdrop-filter:blur(1.6px) saturate(.72);
}

.casos-carousel-stage .caso-card-visual.is-active .caso-media{
  border-radius:clamp(32px,3vw,56px);
}

.casos-carousel-stage .caso-card-visual.is-active .caso-media img,
.casos-carousel-stage .caso-card-visual.is-active .caso-media video,
.casos-carousel-stage .caso-card-visual.is-active .caso-media-video{
  object-position:center center;
}

.casos-carousel-stage .caso-media-video,
.casos-carousel-stage .caso-video-poster-layer{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center center;
}

.casos-carousel-stage .caso-video-poster-layer{
  position:absolute;
  inset:0;
  z-index:2;
  opacity:0;
  transition:opacity .28s ease;
  pointer-events:none;
}

.casos-carousel-stage .caso-card-visual:not(.is-active) .caso-video-poster-layer{
  opacity:1;
}

.casos-carousel-stage .caso-card-visual:not(.is-active) .caso-media-video.has-poster-layer{
  opacity:0;
}

.casos-carousel-stage .caso-content{
  left:calc(100% + clamp(18px,2vw,34px));
}

.casos-carousel-stage .casos-carousel-controls{
  box-shadow:none !important;
}

@media(max-width:1180px){
  .casos-carousel-stage .caso-content{
    width:min(290px,31vw);
    padding:20px;
  }

  .casos-carousel-stage .caso-card-top h3,
  .casos-carousel-stage .caso-card h3{
    font-size:clamp(1.5rem,2.7vw,2.35rem);
  }

  .casos-carousel-stage .caso-card-visual.is-active{
    width:min(720px,58vw);
    transform:translate(calc(-50% - min(12vw,180px)),-50%) scale(1);
  }
}

@media(max-width:900px){
  .casos-grid-section{
    padding-top:clamp(30px,7vw,54px);
    padding-bottom:clamp(42px,8vw,72px);
  }

  .casos-carousel-stage{
    gap:14px;
    padding-top:0;
  }

  .casos-carousel-stage .casos-carousel-viewport{
    height:auto !important;
    min-height:0 !important;
    overflow:visible !important;
    padding:0 18px !important;
  }

  .casos-carousel-stage .casos-carousel-track{
    height:auto !important;
    align-items:stretch;
  }

  .casos-carousel-stage .caso-card-visual,
  .casos-carousel-stage .caso-card-visual.is-active{
    aspect-ratio:auto;
    position:relative !important;
    top:auto !important;
    left:auto !important;
    flex:0 0 calc(100vw - 36px) !important;
    width:auto !important;
    height:auto !important;
    min-height:0 !important;
    display:flex !important;
    flex-direction:column !important;
    filter:none;
    opacity:1;
    transform:none !important;
    overflow:visible !important;
  }

  .casos-carousel-stage .caso-card-visual:not(.is-active){
    display:none !important;
  }

  .casos-carousel-stage .caso-card-visual:not(.is-active) .caso-media:after{
    display:none;
  }

  .casos-carousel-stage .caso-media{
    width:100%;
    height:auto !important;
    aspect-ratio:16 / 10 !important;
    border-radius:28px !important;
    box-shadow:none !important;
  }

  .casos-carousel-stage .caso-media img,
  .casos-carousel-stage .caso-media video,
  .casos-carousel-stage .caso-media-video{
    width:100%;
    height:100%;
    object-fit:cover;
  }

  .casos-carousel-stage .caso-content{
    position:relative !important;
    inset:auto !important;
    left:auto !important;
    top:auto !important;
    width:100% !important;
    max-width:none !important;
    max-height:none !important;
    margin-top:12px !important;
    padding:18px 18px 20px !important;
    border-radius:24px !important;
    opacity:1 !important;
    transform:none !important;
    overflow:visible !important;
    gap:12px;
    box-shadow:none !important;
    background:rgba(255,253,247,.92);
  }

  .casos-carousel-stage .caso-card-visual:not(.is-active) .caso-content{
    opacity:1 !important;
    transform:none !important;
  }

  .casos-carousel-stage .caso-card-top{
    gap:9px;
  }

  .casos-carousel-stage .caso-content-kicker{
    display:-webkit-box;
    -webkit-line-clamp:1;
    -webkit-box-orient:vertical;
    overflow:hidden;
    font-size:.74rem;
    line-height:1.2;
  }

  .casos-carousel-stage .caso-card-top h3,
  .casos-carousel-stage .caso-card h3{
    display:block;
    font-size:clamp(2rem,8vw,3rem);
    line-height:.98;
  }

  .casos-carousel-stage .caso-excerpt,
  .casos-carousel-stage .caso-card p{
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
    overflow:hidden;
    max-width:none;
    font-size:.92rem;
    line-height:1.45;
  }

  .casos-carousel-stage .caso-meta{
    max-width:none;
    gap:8px;
  }

  .casos-carousel-stage .caso-service,
  .casos-carousel-stage .caso-proof{
    gap:3px;
  }

  .casos-carousel-stage .caso-service{
    padding-bottom:8px;
  }

  .casos-carousel-stage .caso-meta small{
    font-size:.68rem;
  }

  .casos-carousel-stage .caso-meta strong{
    -webkit-line-clamp:1;
    font-size:.78rem;
    line-height:1.28;
  }

  .casos-carousel-stage .caso-link{
    min-width:0;
    min-height:42px;
    width:max-content;
    margin-top:6px;
    padding:10px 22px;
    font-size:.86rem;
  }

  .casos-carousel-stage .casos-carousel-controls{
    width:min(100% - 36px,420px) !important;
    margin-top:10px !important;
    padding:0 !important;
    justify-content:center !important;
    gap:12px !important;
    background:transparent !important;
    box-shadow:none !important;
  }

  .casos-carousel-stage .casos-carousel-btn{
    width:48px;
    height:48px;
    box-shadow:none !important;
  }
}

@media(max-width:520px){
  .casos-carousel-stage .caso-media{
    aspect-ratio:16 / 11 !important;
  }

  .casos-carousel-stage .caso-content{
    padding:16px !important;
    gap:10px;
  }

  .casos-carousel-stage .caso-card-top h3,
  .casos-carousel-stage .caso-card h3{
    font-size:clamp(1.82rem,8.4vw,2.45rem);
  }

  .casos-carousel-stage .caso-proof{
    display:none;
  }
}
