/* home page stylee */
/*
body {
    background-color: rgb(255, 255, 255);
    padding-top: 50px;
}
@media (max-width: 1200px) {
  body {
    padding-top: 30px;}
}*/
.homepage-width{
     max-width: 100%;
  padding: 70px 8% 50px 8%;
}
@media (max-width: 1200px) {
  .homepage-width {
  max-width: 100%;
  padding: 50px 5%;}
}
/* end home page stylee */
/* start page title */
.bradcrub1 {
    position: relative;
    width: 100%;
    height: 250px; 
    background-size: cover;
    background-position: center;
}
@media (max-width: 768px) {.bradcrub1 {
    position: relative;
    height: 200px; 
}}
.bradcrub1-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(62, 155, 161, 0.288); 
}
.bradcrub1-content {
    position: absolute; 
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    flex-direction: column; 
    justify-content: center; 
    align-items: center;  
    text-align: center;
    padding: 0 20px; 
  }
@media (max-width: 768px) {.bradcrub1-content h1 {
    font-size: 2rem; 
    margin: 0;
} }
@media (max-width: 768px) {.bradcrub1-content p {
    font-size: 0.9rem;
    margin-top: 10px;
}}
/* end page title */


/* start  solution about title */
  .wesolve-detail1-section {
    display: flex;
    align-items: center;
    justify-content: center;
    padding-top: 50px;
    gap: 30px;
  }
    .wesolve-detail1-image {
      flex: 1 1 300px;
      padding: 0px;
      text-align: center;
    }
    .wesolve-detail1-image img {
      max-width: 100%;
      height: auto;
    }
    .wesolve-detail1-content {
      flex: 1 1 300px;
      padding: 0px;
    }
    .wesolve-detail1-content h2 {
      margin-bottom: 10px;
    }
    .wesolve-detail1-content ul {
      padding-left: 20px;
      color: #444;
    }
    .wesolve-detail1-content ul li {
      margin-bottom: 8px;
      list-style-type: disc;
    }
    @media (max-width: 768px) {
      .wesolve-detail1-section {
        flex-direction: column;
        text-align: center;
      }
      .wesolve-detail1-content {
        text-align: left;
      }
      .wesolve-detail1-image {
        flex: 1 1 auto;
      }
    }
/* end  solution about title */

/* start what we provide section  */
    .whatweprovide1-main{ background: #f9f9f9; }
    .whatweprovidebox-detail { display: grid; grid-template-columns: repeat(1, 1fr);  gap: 20px; }
    .whatweprovide-detail-icon-box {
      background: #fff;
      padding: 10px;
      border-radius: 8px;
      border: solid 1px #008a8a;
      text-align: center;
    }
    .whatweprovide-detail-icon-box h3 { margin: 10px 0; font-size: 20px; }
    /* Tablet View: 2 columns */
    @media (min-width: 600px) {
      .whatweprovidebox-detail {
        grid-template-columns: repeat(2, 1fr);
      }
    }
    /* Desktop View: 4 columns */
    @media (min-width: 1024px) {
      .whatweprovidebox-detail {
        grid-template-columns: repeat(4, 1fr);
      }
    }
/* end what we provide section  */

/* start solution fun facts  */
.solutionfunfacts-section { padding: 40px 0; }
.solutionfunfacts-wrapper {display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; max-width: 1200px; margin: 0 auto; align-items: stretch;}
.solutionfunfacts-box { background: #f3fbfb; border-radius: 12px; padding: 28px 18px; min-height: 120px; text-align: center; box-shadow: 0 1px 4px #f9fdfd; display: flex; flex-direction: column; justify-content: center; align-items: center; }
.solutionfunfacts-box h2 { font-size: 36px; margin: 6px 0; font-weight: 700;  color: #008a8a; line-height: 1;}
.solutionfunfacts-box p {margin: 0; font-size: 15px; margin-top: 6px; text-align: center; max-width: 100%; }
/* Responsive breakpoints */
@media (max-width: 1100px) { .solutionfunfacts-wrapper { grid-template-columns: repeat(3, 1fr); }}
@media (max-width: 800px) {
  .solutionfunfacts-wrapper { grid-template-columns: repeat(2, 1fr); gap: 18px; }
  .solutionfunfacts-box h2 { font-size: 32px; }}
@media (max-width: 480px) {
  .solutionfunfacts-wrapper { grid-template-columns: 1fr; gap: 14px; padding: 24px 12px; }
  .solutionfunfacts-box { padding: 18px; }
  .solutionfunfacts-box h2 { font-size: 28px; }
}
/* end solution fun facts  */



/* start solution technology use  */
.solution-usetechnology-main{ text-align: center; padding: 70px 10px; background-color: rgb(238, 243, 243);}
.solution-usetechnology-under{ display: flex; justify-content: Center; flex-wrap: wrap; gap: 20px; margin: 0 auto;}
.solution-usetechnology-box{ flex: 1 1 200px; max-width: 300px; background-color: white; border-radius: 8px; padding: 10px; box-shadow: 0 4px 12px rgb(212 215 215);}
@media (max-width: 768px){.solution-usetechnology-box { flex: 1 1 100px; max-width: 300px;}}
.solution-usetechnology-box img{ height: 80px; margin-bottom: 10px;}
/* end solution technology use  */



/* start solution contact section */
.contect-infopage2 { display: flex; margin: 0 auto; border-radius: 10px; overflow: hidden;}
.contact-infopage2 {width: 35%; background: linear-gradient(135deg, #1e9494, #80cfcf); padding: 40px 40px; color: white; text-align: center;}
.contectpage-infoitem2 { margin-bottom: 30px;}
.contactinfo-icone2 { width: 45px; height: 45px; margin-bottom: 15px; }
.contact-formsection2 { width: 65%; background-color: #f1f1f1; display: flex; padding: 40px 50px; justify-content: center; flex-direction: column}
/* ✅ Responsive Design */
@media (max-width: 768px) {
  .contect-infopage2 { flex-direction: column; }
  .contact-infopage2,
  .contact-formsection2 { width: 100%; }
  .contact-infopage2 { padding: 30px 20px; }
  .contact-formsection2 { padding: 30px 20px; }
  .contactinfo-icone2 { width: 40px; height: 40px; }
  .contectpage-infoitem2 { margin-bottom: 30px; }
  .contact-formsection2 h2 { font-size: 22px; }
  .contact-infopage2 h2 { font-size: 22px; }
}
@media (max-width: 480px) {
  .contactinfo-icone2 { width: 35px; height: 35px; }
  .contact-infopage2, .contact-formsection2 { padding: 20px 15px;}
  .contectpage-infoitem2 p { font-size: 14px; }
  .contact-formsection2 h2,
  .contact-infopage2 h2 {font-size: 20px; }
}
/* end */


/* start portfolio section */
.portfolio-home{ padding: 50px 0px 70px 0px;}
#gallery {
  overflow: hidden;
  cursor: grab;
  user-select: none;
}
#gallery.active {
  cursor: grabbing;
}
/* Horizontal track */
#track {
  display: flex;
  transition: none;
}
/* Item cards */
.portfolio-item {
  scroll-snap-align: start;
  flex: 0 0 33%; /* full width on mobile */
  margin: 0 10px;
  background: #eff1f1;
  border-radius: 8px;
  padding: 20px;
  box-sizing: border-box;
  text-align: center;
}
/* Responsive adjustments */
@media (min-width: 320px) {
  .portfolio-item {
    flex: 0 0 100%;
  }
}
@media (min-width: 900px) {
  .portfolio-item {
    flex: 0 0 calc((100% / 3) - (20px * 2 / 3));
  }
}
.portfolio-item img {
  width: 100%;
  border-radius: 6px;
}
.title {
  margin-top: 8px;
  font-size: 20px;
  font-weight: bold;
  color: #008A8A;
}
.description {
  margin: 10px 0;
}
.portfolio-action-btn {
  padding: 6px 20px;
  background: #00000000;
  color: #000000;
  border: solid 1px;
  border-radius: 4px;
  border-color: #000000;
  font-size: 14px;
  cursor: pointer;
}
/* end */


/* start client logo section */
.client-logo-section {
  background: #e2edee;
  padding: 70px 0;
  margin: 30px 0px;
}
@media (max-width: 768px) {
  .client-logo-section {
    padding: 40px 0;
  background: #e2edee;
  }
}
.client-logo-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  padding: 0.5rem 2rem;
  background: #e2edee;
}
@media (max-width: 768px) {
  .client-logo-grid {
    padding: 0;
    background: transparent;
    gap: 0.5rem;
  }
}
.client-logo-item {
  flex: 0 0 calc((100% / 9) - (1rem * 2 / 9));
  max-width: calc((100% / 9) - (1rem * 2 / 9));
  display: flex;
  align-items: center;
  justify-content: center;
  background: #ffffff;
  padding: 15px;
  border-radius: 8px;
}
@media (max-width: 768px) {
  .client-logo-item {
    flex: 0 0 calc((100% / 3) - (1rem * 2 / 3));
    max-width: calc((100% / 3) - (1rem * 2 / 3));
    padding: 8px;
    border-radius: 5px;
  }
}
.client-logo-item img {
  max-width: 100%;
  max-height: 60px;
  object-fit: contain;
  filter: grayscale(1);
  opacity: 0.6;
  transition: filter 0.3s, opacity 0.3s;
}

.client-logo-item img:hover {
  filter: none;
  opacity: 1;
}
/* end */

/* start faq */
.faq-container { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
@media (max-width:600px){ .faq-container { grid-template-columns: 1fr; } }

.faq-item {
  border: 1px solid #008A8A;
  border-radius:10px;
  padding:20px;
  cursor:pointer;
  transition: background .3s;
}
.faq-item:hover { background:#008a8a09; }

.faq-question {
  font-weight:bold;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.faq-answer {
  display:none;
  margin-top:10px;
}
.faq-item.active .faq-answer { display:block; }
.arrow { transition: transform .3s ease; }
.faq-item.active .arrow { transform: rotate(180deg); }
/* end faq */



/* start custome testimonial */
webdetails-testimonials-inner { margin: 0 auto; }
.webdetails-testimonials-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; align-items: stretch; margin-top: 10px;}
.webdetails-testimonial-card {
  position: relative;
  padding: 20px;
  border-radius: 18px;
  background: linear-gradient(135deg, #096363ff 0%, #008a8a 100%);
  color: #ffffff;
  box-shadow: 0 10px 30px rgba(15, 18, 40, 0.06);
  overflow: visible;
  transition: transform .28s ease, box-shadow .28s ease;
}
.webdetails-testimonial-card:hover { transform: translateY(-6px);  }
/* Content inside card */
.webdetails-testimonial-content { text-align: center; margin-top: 8px; padding: 0 10px; }
.webdetails-testimonial-content h3 { margin: 10px 0 4px; font-size: 1.05rem; color: #fff; }
.webdetails-testimonial-role { margin: 0 0 10px; color: rgba(255,255,255,0.68); font-size: .9rem; }
.webdetails-testimonial-text { color: #ffffff; line-height: 1.45; font-size: .95rem; }
/* Responsive breakpoints */
@media (max-width: 991.98px) {
  .webdetails-testimonials-grid { grid-template-columns: repeat(2, 1fr); gap: 22px; }
  .webdetails-testimonial-card { min-height: 260px; padding: 10px; }
}
@media (max-width: 575.98px) {
  .webdetails-testimonials-grid { display: flex; gap: 16px; overflow-x: auto; padding-bottom: 10px; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch;}
  .webdetails-testimonial-card { flex: 0 0 84%; scroll-snap-align: center; min-width: 260px; margin: 0 6px;}
}
/* Accessibility: focus */
.webdetails-testimonial-card:focus-within, .webdetails-testimonial-card:focus { outline: 2px solid rgba(255,255,255,0.08); outline-offset: 4px; }
/* end custome testimonial */



/* start service working process section */
.servicedeyail-process-section {padding: 100px 20px 50px; max-width: 1400px; margin: auto; text-align: center; }
.servicedeyail-process-section h2 { margin-bottom: 40px;}
.servicedeyail-timeline { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 10px; margin-bottom: 0px;}
.stepser { flex: 1 1 150px; cursor: pointer; text-align: center; transition: all 0.3s ease;}
.servicedeyail-circle { position: relative; width: 40px; height: 40px; margin: auto; border-radius: 50%; border: 2px solid #ccc; line-height: 40px; font-weight: bold; background: #fff; color: #333; text-align: center;}
/* Active servicedeyail-circle styling */
.stepser.active .servicedeyail-circle { border-color: #008a8a; background: #008a8a; color: #fff;}
/* Right arrow line for active servicedeyail-circle */
.stepser.active .servicedeyail-circle::after { content: ""; position: absolute; top: 50%; left: 100%; transform: translateY(-50%); width: 40px; height: 2px; background-color: #008a8a;}
/* Optional: add a triangle arrowhead */
.stepser.active .servicedeyail-circle::before { content: ""; position: absolute; top: 50%; left: calc(100% + 40px); transform: translateY(-50%); width: 0; height: 0; border-top: 6px solid transparent; border-bottom: 6px solid transparent; border-left: 8px solid #008a8a; }
.stepser p { margin-top: 8px; font-size: 0.95rem; }
.servicedeyail-content-box { background: #fff; border: 1px solid #ddd; border-radius: 0px 0px 20px 20px; padding: 25px; text-align: left; box-shadow: 0 4px 12px rgba(0,0,0,0.05);}
.servicedeyail-content-box h3 { margin-bottom: 10px; font-size: 1.2rem; color: #008a8a;}
.servicedeyail-content-box p { font-size: 1rem; color: #555; }
/* Responsive */
@media (max-width: 768px) {
  .servicedeyail-timeline { flex-direction: column; align-items: center; margin-bottom: 0px; gap: 0px;}
  .stepser {flex: none; width: 100%; max-width: 300px;}}
/* end service working process section */
