/* =========================================
   PROJECTS PAGE
   Cinematic Portfolio + Before/After
========================================= */


/* ===============================
   HERO (Cinematic)
=============================== */

.hero.hero--projects::before{
  background:url("../assets/projects/Cover-Project.jpg") center/cover no-repeat;
  transform:scale(1.05);
}

.hero.hero--projects::after{
  background:linear-gradient(
    90deg,
    rgba(0,0,0,.75) 0%,
    rgba(0,0,0,.45) 50%,
    rgba(0,0,0,.25) 100%
  );
}

.hero.hero--projects h1{
  font-size:50px;
  font-weight:600;
  letter-spacing:-1px;
}

.hero.hero--projects p{
  font-size:17px;
  max-width:650px;
}

.hero.hero--projects .actions{
  margin-top:24px;
}


/* ===============================
   GALLERY GRID
=============================== */

.gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:26px;
}

.gitem{
  border-radius:24px;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow-soft);
  transition:.3s ease;
}

.gitem:hover{
  transform:translateY(-8px);
  box-shadow:var(--shadow-medium);
}

.gitem img{
  width:100%;
  height:260px;
  object-fit:cover;
  transition:.4s ease;
}

.gitem:hover img{
  transform:scale(1.05);
}

.gmeta{
  padding:20px;
}

.gmeta b{
  font-size:16px;
  display:block;
  margin-bottom:6px;
}

.gmeta span{
  font-size:13px;
  color:var(--muted);
}


/* ===============================
   BEFORE / AFTER SECTION
=============================== */

.ba-section{
  margin-top:60px;
  padding:50px;
  border-radius:32px;
  background:linear-gradient(
    135deg,
    rgba(122,15,27,.05),
    rgba(122,15,27,.02)
  );
  border:1px solid rgba(122,15,27,.1);
}

.ba-head{
  margin-bottom:30px;
}
.ba-meta{
  padding:22px 28px 28px;
}

.ba-meta b{
  font-size:17px;
  letter-spacing:.2px;
}

.ba-meta span{
  display:block;
  margin-top:6px;
  font-size:14px;
  line-height:1.6;
}

/* ===============================
   BA SLIDER
=============================== */

.ba-slider{
  position:relative;
  display:grid;
  grid-template-columns:60px 1fr 60px;
  align-items:center;
  gap:24px;
}

.ba-slide{
  display:none;
}

.ba-slide.is-active{
  display:block;
  animation:fadeIn .4s ease;
}

@keyframes fadeIn{
  from{opacity:0;transform:translateY(20px) scale(.98);}
  to{opacity:1;transform:none;}
}


/* NAV BUTTONS */

.ba-nav{
  width:56px;
  height:56px;
  border-radius:50%;
  border:1px solid var(--line);
  background:#fff;
  font-size:26px;
  cursor:pointer;
  box-shadow:var(--shadow-soft);
  transition:.2s ease;
}

.ba-nav:hover{
  transform:scale(1.08);
  box-shadow:var(--shadow-medium);
}


/* DOTS */

.ba-dots{
  margin-top:24px;
  display:flex;
  justify-content:center;
  gap:10px;
}

.ba-dot{
  width:12px;
  height:12px;
  border-radius:50%;
  background:#ddd;
  border:0;
  cursor:pointer;
  transition:.2s ease;
}

.ba-dot.is-active{
  background:var(--brand);
  transform:scale(1.2);
}


/* ===============================
   BEFORE / AFTER CARD
=============================== */

.ba-card{
  background:#fff;
  border-radius:28px;
  overflow:visible;
  box-shadow:var(--shadow-medium);
  border:1px solid var(--line);
}

.ba{
  position:relative;
  width:100%;
  height:480px;
  overflow:hidden;
  cursor:ew-resize;
}

.ba img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
}

.ba img.after{
  clip-path:inset(0 0 0 50%);
  transition:.1s linear;
}

/* Labels */

.ba .label{
  position:absolute;
  top:18px;
  padding:6px 14px;
  font-size:12px;
  font-weight:600;
  border-radius:999px;
  background:rgba(0,0,0,.6);
  color:#fff;
  letter-spacing:.1em;
}

.ba .label.before{ left:18px; }
.ba .label.after{ right:18px; }

/* Slider Handle */

.ba .handle{
  position:absolute;
  top:0;
  left:50%;
  width:4px;
  height:100%;
  background:#fff;
  transform:translateX(-50%);
  z-index:6;
}

.ba .handle::before{
  content:"↔";
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:50px;
  height:50px;
  border-radius:50%;
  background:var(--brand);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:600;
  box-shadow:0 12px 30px rgba(0,0,0,.3);
  transition: all .25s ease;
}
.ba:hover .handle::before{
  transform:translate(-50%,-50%) scale(1.1);
}
.ba input[type="range"]{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  opacity:0;
  cursor:ew-resize;
  z-index:5;
}

.ba::after{
  content:"";
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:120px;
  background:linear-gradient(to top, rgba(0,0,0,.4), transparent);
  pointer-events:none;
}



/* ===============================
   CTA PANEL BELOW BA
=============================== */

.panel{
  margin-top:50px;
  padding:36px;
}


/* ===============================
   RESPONSIVE
=============================== */

@media (max-width: 1100px){
  .gallery{
    grid-template-columns:repeat(2,1fr);
  }
}

@media (max-width: 900px){
  .ba-slider{
    grid-template-columns:50px 1fr 50px;
  }

  .ba{
    height:340px;
  }
}

@media (max-width: 720px){
  .gallery{
    grid-template-columns:1fr;
  }

  .ba-section{
    padding:30px;
  }

  .hero.hero--projects h1{
    font-size:34px;
  }
}