/* ================= GLOBAL ================= */
*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:poppins
    
}
html,body{
    overflow-x:hidden
    
}

/* ================= REUSABLE ================= */
.re-desc{
    padding:80px 0
    
}
.home-titleheader{
    text-align:center;
    font-size:22px;
    color:rgba(51,51,51);
    font-weight:500;
    text-transform:uppercase
}
.custom-lead{
    margin-top:40px;
    font-size:18px;
    color:rgba(127,126,126);
    text-align:justify
}
.hr-role-box {
  transition: all 0.3s ease-in-out;
}
 /*Hover effect */
.hr-role-box:hover {
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
  transform: translateY(-5px);/* optional slight lift */
}
/* ================= NAVBAR ================= */
#mainNavbar{top:0;width:100%;z-index:1000;transition:.4s}
#mainNavbar.sticky-navbar{position:fixed;background:#323d3f;animation:slideDown .4s}
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
.navbar{background:#323d3f}
.custom-logo{width: auto;   /* adjust to match your navbar */
  height: 70px;
  display: block;}
.navbar .nav-link.active{color:#ffc107!important}
.navbar .dropdown-menu{display:none}
.navbar .dropdown:hover .dropdown-menu{display:block;opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu{opacity:0;visibility:hidden;transform:translateY(10px);transition:.3s}

/* ================= HERO ================= */

.carousel-item.custom-itmes {
    height: 90vh;
    overflow: hidden;
    position: relative;
}

.carousel-item.custom-itmes picture {
    display: block;
    width: 100%;
    height: 100%;
}
.carousel-item.custom-itmes img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
}
.custom-caption{
    position:absolute;
    bottom:30px;
    left:50%;
    transform:translateX(-50%);
    text-align:center
}
.custom-caption h5{
    color:#fff;
    font-size:28px;
    font-weight:600;
    background:rgba(0,0,0,.4);
    padding:10px 20px;
    border-radius:6px
    
}
/*.custom-itmes{height:90vh}*/
/*.custom-itmes img{width:100%!important;height:100%!important}*/

/* ================= CONTACT ================= */
.cont-wraper{background:#ddd;color:#616161;display:flex;align-items:center;justify-content:center;flex-direction:column;padding:40px}
.cont-wraper p{font-size:22px;line-height:1.5;font-weight:300}

/* ================= CARDS ================= */
.custom-cardgroup{gap:20px;margin-top:40px}
.custom-card{border:none}
.custom-card img{border-radius:10px!important}
.cus-cardtitle{text-align:center;text-transform:uppercase}

/* ================= TESTIMONIAL ================= */
.clientreview-wrapper{background:#ddd;margin-top:80px}
.custom-swip{padding:40px!important;width:80%}
.testimonial-card{background:#fff;padding:25px;border-radius:12px;text-align:center;box-shadow:0 10px 25px rgba(0,0,0,.1);min-height:285px;display:flex;flex-direction:column;justify-content:space-between}
.client-img{width:60px;height:60px;border-radius:50%;margin:0 auto 10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:bold}

/* ================= PROJECT ================= */
.pro-cardwrepper{
    padding: 80px 0px 80px 0px;
}
.project-content h3{
    font-size: 22px ;
}
.project-card{position:relative;overflow:hidden;border-radius:10px;height:260px}
.project-img{width:100%;height:100%;object-fit:cover;transition:.5s}
.project-card::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.6);opacity:0;transition:.4s;z-index:1}
.project-content{position:absolute;left:20px;right:20px;bottom:-72px;color:#fff;z-index:2;transition:.4s}
.project-card:hover .project-img{transform:scale(1.1)}
.project-card:hover::before{opacity:1}
.project-card:hover .project-content{bottom:20px}

/* ================= FAQ ================= */
.accordion-body{font-size:16px;color:rgba(127,126,126);text-align:justify}

/* ================= SLIDER ================= */

.cus-swslider{width:32.6%!important}

.custom-carousel-caption{
  top:50%;
  left:50%;
  bottom:auto;
  transform:translate(-50%,-50%);
  text-align:center;
  z-index:10
}

/* THUMBNAILS */
.thumbSlider{
  height:300px;
  width:80%;
  margin-top:80px;
  position:relative;
  overflow:hidden
}

.thumbSlider .swiper-slide{cursor:pointer}

.thumbSlider .swiper-slide img{
  width:100%;
  height:281px;
  object-fit:cover;
  border-radius:10px
}

.thumbSlider .swiper-slide-thumb-active{
  opacity:1;
  border:2px solid #000
}

/* NAV BUTTONS */
.thumbSlider .swiper-button-next,
.thumbSlider .swiper-button-prev{
  position:absolute;
  top:54%;
  transform:translateY(-50%);
  z-index:10;
  width:35px;
  height:35px;
  background:#fff;
  border-radius:50%;
  color:#000
}

/* LEFT POSITION */
.thumb-prev,
.thumb-next{left:10px}

/* ICON SIZE */
.thumbSlider .swiper-button-next:after,
.thumbSlider .swiper-button-prev:after{
  font-size:14px;
  font-weight:900
}

/* ================= CLIENT DETAILS ================= */

.clt-wrapper{
  display:flex;
  justify-content:center;
  align-items:center;
  margin:60px 0
}

.client-details{
  text-align:center;
  color:rgba(127,126,126);
  line-height: 15px;
}

.project-brief{padding:0 180px}

/* ================= VIDEO ================= */

.au-video iframe{border-radius:8px}


/* ================= BEFORE AFTER ================= */

.pper{
  display:flex;
  justify-content:space-between;
  margin-bottom:80px
}
.ba-wrapper{width:48%}



.ba-container {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: 10px;
}

.ba-after-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.ba-after-wrapper img {
  clip-path: inset(0 50% 0 0); /* initial 50% reveal */
}

.ba-before,
.ba-after-wrapper img {
  /*position: absolute;*/
  /*top: 0;*/
  /*left: 0;*/
  /*width: 100%;*/
  /*height: 100%;*/
  /*object-fit: cover;*/
  width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    image-rendering: high-quality;
}

/* SLIDER (MERGED SAFE) */
.ba-slider{
  position:absolute;
  top:0;
  left:50%;
  width:3px;
  height:100%;
  background:#fff;
  cursor:ew-resize;
  z-index:10;
  display:flex;
  align-items:center;
  justify-content:center
}
/* HANDLE */
.dboble-arrow-custom{
  position:absolute;
  width:40px;
  height:40px;
  background:#fff;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#333;
  font-size:18px;
  font-weight:bold;
  box-shadow:0 2px 10px rgba(0,0,0,0.2);
  user-select:none
}
/* HOVER */
.dboble-arrow-custom:hover{
  transform:scale(1.1)
}
/* LABEL ROW */
.ba-label-row{
  position:absolute;
  bottom:10px;
  left:0;
  width:100%;
  display:flex;
  justify-content:space-between;
  padding:0 10px;
  z-index:20;
  margin-top:0
}
/* BUTTON */
.ba-btn{
  padding:8px 15px;
  border-radius:20px;
  font-size:12px;
  background:rgba(0,0,0,0.6);
  color:#fff;
  border:none;
  backdrop-filter:blur(4px)
}
/*--------------306 view--------------------*/
.wide-view{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
/* ================= CONTACT PAGE ================= */
.alwraper{
    display:flex;
    justify-content:space-between;
    height:65vh;align-items:center;
    padding:20px 0
    
}
.arccontact-form{
    width:50%
    
}

/* ================= TEAM ================= */
.woner-details{
    text-align:center
    
}
.woner-details p{
    font-size:18px;color:rgba(127,126,126)
    
}
.team-card{
    height:400px!important
    
}
/* ================= STATS SECTION ================= */

.fv-stats-section{
  padding:80px 20px;
  background:#f8f9fa;
  color:#222
}

/* OVERLAY */
.fv-overlay{display:none}

/* CONTAINER */
.fv-container{
  max-width:1200px;
  margin:auto;
  text-align:center
}

/* HEADING */
.fv-heading h2{
  font-size:36px;
  font-weight:600;
  margin-bottom:10px;
  color:#222
}

/*.fv-heading p{*/
/*  font-size:16px;*/
/*  color:#666;*/
/*  margin-bottom:50px*/
/*}*/

/* GRID */
.fv-stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:25px
}

/* CARD */
.fv-stat{
  background:#fff;
  padding:30px 20px;
  border-radius:10px;
  transition:.3s ease;
  box-shadow:0 5px 20px rgba(0,0,0,0.08)
}

.fv-stat:hover{transform:translateY(-5px)}

/* ICON */
.fv-icon{
  font-size:28px;
  margin-bottom:12px
}

/* COUNTER */
.fv-counter{
  font-size:34px;
  font-weight:700;
  color:#0d6efd;
  margin-bottom:8px
}

/* TEXT */
/*.fv-stat p{*/
/*  font-size:14px;*/
/*  color:#555*/
/*}*/

/* ================= ABOUT PAGE ================= */

.about-page .container{
  width:90%;
  max-width:1200px;
  margin:auto
}

.about-page section p.section-subtitle{
  text-align:center;
  color:#666;
  margin-bottom:50px
}

/* WHY US */
.about-page .why-us{background:#fff}

.about-page .why-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:30px;
  padding: 60px 0px;
}

.about-page .why-grid div{
  background:#f9fafb;
  padding:25px;
  border-radius:12px;
  border:1px solid #eee;
  transition:.3s
}

.about-page .why-grid div:hover{
  transform:translateY(-5px);
  box-shadow:0 10px 25px rgba(0,0,0,0.08)
}

/* PROCESS */
.about-page .process{background:#f8f9fa;padding:40px 0px}

.about-page .process-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:25px;
  padding: 60px 0px;
}

.about-page .process-grid div{
  background:#fff;
  padding:25px;
  border-radius:12px;
  border:1px solid #eee;
  transition:.3s;
  position:relative
}

.about-page .process-grid div:hover{
  transform:translateY(-5px);
  box-shadow:0 10px 25px rgba(0,0,0,0.08)
}

.about-page .process-grid h4{
  font-size:18px;
  margin-bottom:10px;
  padding-left:35px;
  position:relative
}

.about-page .process-grid h4::before{
  content:attr(data-step);
  position:absolute;
  left:0;
  top:0;
  background:#0d6efd;
  color:#fff;
  width:28px;
  height:28px;
  font-size:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
 
}

/* INDUSTRIES */
.about-page .industries{background:#fff}

.about-page .industry-list{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:15px;
  margin-top:30px;
  padding: 60px 0px;
}

.about-page .industry-list li{
  list-style:none;
  background:#f9fafb;
  padding:15px 20px;
  border-radius:8px;
  border:1px solid #eee;
  transition:.3s
}

.about-page .industry-list li:hover{
  background:#0d6efd;
  color:#fff
}

/* COMMITMENT */
.about-page .commitment{
  background:#f8f9fa;
  text-align:center;
  padding:40px 0px
}

.about-page .commitment p{
  max-width:800px;
  margin:auto;
  line-height:1.7;
  padding: 60px 0px;
}
/* ================= SERVICE MODAL ================= */
.service-modal{display:none;position:fixed;z-index:9999;inset:0;background:rgba(0,0,0,.7)}
.modal-content{background:#fff;margin:5% auto;padding:30px;width:70%;border-radius:12px;position:relative}
.modal-body{display:flex;gap:30px;align-items:center}
.modal-body img{width:30%;border-radius:10px}
.modal-body div{width:60%}
.close-btn{position:absolute;right:20px;top:10px;font-size:30px;cursor:pointer}

/* ================= MEDIA ================= */
.media-filters{
    display:flex;
    justify-content:center;
    gap:12px;
    flex-wrap:wrap
    
}
.filter-btn{
    padding:8px 18px;
    border-radius:25px;
    border:1px solid #000;
    background:transparent
    
}
.filter-btn.active{
    background:#000;
    color:#fff
    
}
.media-card{
    border:1px solid #ddd;
    border-radius:12px;
    padding:10px;
    text-align:center;
    transition:.3s
    
}
.media-card:hover{
    transform:translateY(-6px)
    
}
.media-card img{
    width:100%;
    border-radius:10px
    
}
.video-box iframe{
    width:100%;
    height:220px;
    border-radius:10px
    
}

/* ================= FOOTER ================= */
.footer-link{
    color:#f8f9fa;
    text-decoration:none;
    transition:.3s
    
}
.footer-link:hover{
    color:#0d6efd
    
}
.social-icon{
    width:35px;
    height:35px;
    line-height:35px;
    border-radius:50%;
    text-align:center;
    color:#fff;
    display:inline-block;
    margin:0 8px;
    transition:.3s
    
}
.social-icon:hover{
    transform:translateY(-3px)
    
}
.footer-logo{
    max-width:320px
    
}
.footer-logo img{
    width:100%;object-fit:contain
    
}

/* ================= RESPONSIVE ================= */
@media(max-width:992px){
  #main-cont{padding:0 20px}
  .process-grid{grid-template-columns:repeat(2,1fr)}
}

@media(max-width:768px){
  .custom-swip{width:95%;padding:20px!important}
  .testimonial-card{padding:15px}
  .modal-body{flex-direction:column}
  .modal-body img,.modal-body div{width:100%}
  .alwraper{flex-direction:column;height:auto}
  .arccontact-form{width:100%}
}

@media(max-width:600px){
  .pper{flex-direction:column}
  .ba-wrapper{width:100%}
}
