/* ==========================================================================
   Services / Mission Section
   Extracted from style.css — scoped styles for ServicesSection.tsx
   ========================================================================== */

/*------------------- Service Accordion -------------------*/
.accordion-item-wrapp {
  border-top: 1px solid var(--title-color);
  padding-top: 30px;
  margin-left: 40px;
  /* Large devices */
  /* Medium devices */
}

@media (max-width: 1199px) {
  .accordion-item-wrapp {
    padding-left: 30px;
    padding-top: 30px;
    margin-left: 30px;
  }
}

@media (max-width: 991px) {
  .accordion-item-wrapp {
    margin-left: 0;
    padding: 0;
    border: none;
  }
}

.accordion-item-wrapp:not(:last-child) {
  margin-bottom: 24px;
}

.accordion-item-content:not(:last-child) .accordion-item {
  margin-bottom: 30px;
}

.accordion-item {
  -webkit-transition: 0.4s ease-in-out;
  transition: 0.4s ease-in-out;
  background: transparent;
  overflow: hidden;
  border-bottom: 1px solid var(--title-color);
  padding-bottom: 30px;
  -webkit-transition: all 0.4s ease-in-out;
  transition: all 0.4s ease-in-out;
}

.accordion-item_info {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.accordion-item_wrapp {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
  /* Extra small devices */
}

@media (max-width: 575px) {
  .accordion-item_wrapp {
    display: block;
  }
}

.accordion-item_number {
  border: 1px solid #7A8392;
  width: 50px;
  height: 50px;
  line-height: 50px;
  text-align: center;
  border-radius: 30px;
  font-size: 24px;
  font-weight: 600;
  display: block;
  color: #7A8392;
}

.accordion-item_content {
  color: #fff;
  padding: 0 30px 0px 110px;
  overflow: hidden;
  will-change: max-height;
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
  /* Extra small devices */
}

@media (max-width: 575px) {
  .accordion-item_content {
    padding: 0 30px 0px 0px;
  }
}

.accordion-item .box-title {
  font-size: 30px;
  font-weight: 600;
  line-height: 40px;
  color: var(--white-color);
  margin-top: -0.2rem;
  margin-bottom: 20px;
  display: block;
  /* Small devices */
  /* Extra small devices */
}

@media (max-width: 767px) {
  .accordion-item .box-title {
    font-size: 24px;
    line-height: 34px;
  }
}

@media (max-width: 575px) {
  .accordion-item .box-title {
    font-size: 24px;
    line-height: 34px;
    margin-top: 20px;
  }
}

.accordion-item .icon {
  min-width: 50px;
  height: 50px;
  line-height: 50px;
  text-align: center;
  border-radius: 50%;
  border: 1px solid #7A8392;
  /* Medium devices */
}

@media (max-width: 991px) {
  .accordion-item .icon {
    margin-bottom: 30px;
  }
}

.accordion-item i {
  color: #7A8392;
  font-size: 20px;
  font-weight: 400;
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
}

.accordion-item .accordion-button {
  font-size: 30px;
  font-weight: 600;
  font-family: var(--title-font);
  border: 0;
  color: var(--title-color);
  background: transparent;
  padding: 40px 0 35px 0;
  gap: 10px;
  margin-bottom: 0;
  text-align: left;
  display: block;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  position: relative;
  border-radius: 0 !important;
  /* Extra small devices */
}

@media (max-width: 575px) {
  .accordion-item .accordion-button {
    padding: 25px 0 20px 0;
  }
}

.accordion-item .accordion-button:after {
  display: none;
}

.accordion-item .accordion-button:focus {
  outline: none;
  box-shadow: none;
}

.accordion-item .accordion-button:not(.collapsed) {
  box-shadow: none;
  border-bottom: none;
  background-color: transparent;
  padding: 40px 0 5px 0;
}

.accordion-item .accordion-button:not(.collapsed) .accordion-item_number {
  border-color: var(--theme-color);
  color: var(--theme-color);
}

.accordion-item .accordion-button:not(.collapsed) .box-title {
  color: var(--theme-color);
}

.accordion-item .accordion-button:not(.collapsed) .icon {
  border-color: var(--theme-color);
}

.accordion-item .accordion-button:not(.collapsed) i {
  color: var(--theme-color);
}

.accordion-item .accordion-button:not(.collapsed):after {
  content: '\f068';
  -webkit-transform: rotate(0);
      -ms-transform: rotate(0);
          transform: rotate(0);
}

.accordion-item .accordion-button.collapsed {
  border-bottom: 1px solid var(--title-color);
}

.accordion-item .accordion-collapse {
  border: none;
}

.accordion-item .accordion-body {
  background-color: transparent;
  border: none;
  padding: 0px 30px 30px 110px;
  border-bottom: 1px solid var(--title-color);
  /* Extra small devices */
}

@media (max-width: 575px) {
  .accordion-item .accordion-body {
    padding: 0 20px 30px 0;
  }
}

.accordion-item .faq-text {
  font-size: 16px;
  font-weight: 400;
  line-height: 26px;
  margin: -0.4rem 0 0rem 90px;
  color: #7A8392;
  max-width: 572px;
  /* Extra small devices */
}

@media (max-width: 575px) {
  .accordion-item .faq-text {
    margin-left: 0;
  }
}

.accordion-item .faq-img {
  height: 100%;
}

.accordion-item .faq-img img {
  height: 100%;
  object-fit: cover;
}

.accordion-item:hover {
  border-color: var(--theme-color);
}

.accordion-item:hover .accordion-item_number {
  border-color: var(--theme-color);
  color: var(--theme-color);
}

.accordion-item:hover .box-title {
  color: var(--theme-color);
}

.accordion-item:hover .icon {
  border-color: var(--theme-color);
}

.accordion-item:hover .icon i {
  color: var(--theme-color);
}

/*------------------- Tabs / Image Panel -------------------*/
#tabs-content {
  overflow: hidden;
}

.according-img-tab {
  border-radius: 30px;
  /* Large devices */
}

@media (max-width: 1199px) {
  .according-img-tab {
    height: 450px;
  }
}

.according-img-tab img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 30px;
}

/*------------------- Service Button -------------------*/
.th-btn.ser-btn {
  width: 133px;
  height: 133px;
  color: var(--white-color);
  padding: 18px 10px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-flow: column;
      -ms-flex-flow: column;
          flex-flow: column;
}

.th-btn.ser-btn span {
  margin-top: 5px;
  display: block;
}

.th-btn.ser-btn:hover:before {
  top: -55px;
}

/*------------------- Service Featured -------------------*/
.service-featured {
  position: relative;
  text-align: center;
}

.service-featured.style2 {
  background: var(--white-color);
  box-shadow: 0px 4px 50px #EFEFEF;
  border-radius: 30px;
  padding: 30px 25px;
  margin-top: 50px;
  /* Extra small devices */
}

@media (max-width: 375px) {
  .service-featured.style2 {
    padding: 30px 20px;
  }
}

.service-featured.style2 .box-icon {
  position: absolute;
  top: -50px;
  left: calc(50% - 50px);
  background-color: var(--white-color);
  box-shadow: 0px 10px 30px 6px rgba(20, 18, 46, 0.1);
  margin: auto;
}

.service-featured.style2 .box-title {
  margin: 45px 0 15px 0;
}

.service-featured.style2 .box-text {
  margin-bottom: 15px;
}

.service-featured.style2 .th-btn:after {
  background-color: #EBEEFF;
}

.service-featured.style2:hover .th-btn {
  color: var(--white-color);
}

.service-featured.style2:hover .th-btn:after {
  background-color: var(--theme-color);
}

.service-featured.style3 {
  background-color: var(--white-color);
  box-shadow: 0px 4px 50px #EFEFEF;
  border-radius: 30px;
  padding: 40px 40px 30px 40px;
  /* Medium Large devices */
}

@media (max-width: 1399px) {
  .service-featured.style3 {
    padding: 30px;
  }
}

.service-featured.style3 .box-img {
  margin-bottom: 40px;
}

.service-featured.style3 .box-text {
  margin-bottom: 20px;
}

.service-featured.style3 .th-btn:after {
  background-color: #EBEEFF;
}

.service-featured.style3:hover .th-btn {
  color: var(--white-color);
}

.service-featured.style3:hover .th-btn:after {
  background-color: var(--theme-color);
}

.service-featured_wrapp:not(:last-child) .box-shape {
  position: absolute;
  top: 50%;
  left: 100%;
  z-index: 2;
  width: 228px;
  height: 2px;
  display: block;
  /* Large devices */
}

@media (max-width: 1199px) {
  .service-featured_wrapp:not(:last-child) .box-shape {
    display: none;
  }
}

.service-featured_wrapp:not(:last-child) .box-shape:before {
  content: "";
  position: absolute;
  left: 0%;
  top: 30%;
  width: 228px;
  border: 2px solid;
  border-image-slice: 1;
  border-width: 2px;
  border-left: 0;
  border-right: 0;
  border-bottom: 0;
  border-image-source: linear-gradient(to right, var(--theme-color), rgba(70, 98, 255, 0));
  z-index: 1;
}

.service-featured_wrapp:not(:last-child) .box-shape:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 4%;
  width: 228px;
  height: 2px;
  background-color: var(--smoke-color);
  z-index: -1;
}

.service-featured .box-icon {
  position: relative;
  width: 100px;
  height: 100px;
  line-height: 100px;
  text-align: center;
  display: block;
  border-radius: 50%;
  background: var(--theme-color);
  margin: auto auto 40px auto;
  z-index: 2;
}

.service-featured .box-icon img {
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}

.service-featured .box-text {
  margin-bottom: 12px;
}

.service-featured .th-btn {
  position: relative;
  background-color: transparent;
  color: var(--title-color);
  padding: 13px 21.5px;
  z-index: 2;
  font-weight: 500;
  font-size: 14px;
}

.service-featured .th-btn:before {
  display: none;
}

.service-featured .th-btn:after {
  content: "";
  position: absolute;
  left: 34%;
  top: 0%;
  width: 40px;
  height: 40px;
  background-color: var(--theme-color);
  border-radius: 20px;
  z-index: -1;
  -webkit-transition: all 0.4s ease-in-out;
  transition: all 0.4s ease-in-out;
}

.service-featured .th-btn i {
  font-size: 14px;
  margin-left: 5px;
}

.service-featured:hover .box-icon img {
  -webkit-transform: scale(-1) rotate(180deg);
      -ms-transform: scale(-1) rotate(180deg);
          transform: scale(-1) rotate(180deg);
}

.service-featured:hover .th-btn:after {
  width: 100%;
  left: 0;
}

/*------------------- Service Area -------------------*/
.service-area {
  position: relative;
  z-index: 2;
  background-color: #F8F8F8;
}

.service-area:before {
  content: "";
  position: absolute;
  inset: 0;
  -webkit-mask-image: url("/assets/img/bg/service_bg_shape.png");
          mask-image: url("/assets/img/bg/service_bg_shape.png");
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  background-color: #0A0A0A;
  z-index: -1;
  /* Medium devices */
}

@media (max-width: 991px) {
  .service-area:before {
    -webkit-mask-size: cover;
            mask-size: cover;
    -webkit-mask-position: 100% right;
            mask-position: 100% right;
  }
}

.service-area .th-btn.ser-btn {
  /* Medium devices */
}

@media (max-width: 991px) {
  .service-area .th-btn.ser-btn {
    color: var(--title-color);
  }
}

.service-accordion.style2 {
  margin-top: 80px;
}

.service-accordion.style2 .accordion-item-wrapp {
  padding: 0;
  margin: 0;
  border: none;
}

.accordion-item.style2 {
  border: 1px solid #1F1F1F;
  border-radius: 24px;
  padding: 30px;
  -webkit-transition: all 0.4s ease-in-out;
  transition: all 0.4s ease-in-out;
  margin-top: 0;
}

.accordion-item.style2:hover {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid #1F1F1F;
  border-radius: 24px;
}

.tabs-content.style2 {
  -webkit-transform: rotate(15deg);
      -ms-transform: rotate(15deg);
          transform: rotate(15deg);
  width: 424px;
  height: 660px;
  margin-left: 100px;
  /* Extra large devices */
  /* Medium devices */
}

@media (max-width: 1500px) {
  .tabs-content.style2 {
    margin: 0;
    width: 100%;
  }
}

@media (max-width: 991px) {
  .tabs-content.style2 {
    height: 350px;
    margin-bottom: 60px;
  }
  .tabs-content.style2 .according-img-tab {
    height: 350px;
  }
}

/* ==========================================================================
   Layout fix: image fills the full height of the accordion column
   ========================================================================== */

/* Make columns stretch to equal height */
.service-accordion .row {
  align-items: stretch !important;
}

.service-accordion .col-xl-4 {
  display: flex !important;
  flex-direction: column !important;
}

/* #tabs-content fills the full column height */
#tabs-content {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
  overflow: hidden !important;
}

/* Each tab panel fills the container */
.according-img-tab {
  flex: 1 !important;
  height: 100% !important;
  min-height: 0 !important;
}

/* Image fills the tab panel */
.according-img-tab img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

/* Mobile / tablet: reset flex and use fixed height */
@media (max-width: 1199px) {
  .service-accordion .col-xl-4 {
    display: block !important;
  }

  #tabs-content {
    height: 380px !important;
  }

  .according-img-tab {
    height: 100% !important;
  }
}

/* On phones, hide the decorative image column entirely —
   the accordion text stands on its own and reads cleanly */
@media (max-width: 767px) {
  .service-accordion .col-xl-4 {
    display: none !important;
  }
}
