/* Side menu visual overrides (kept separate from main stylesheet) */
.side-menu {
  background: #111111 !important;
}

.side-menu .title,
.side-menu p,
.side-menu .nmbr,
.side-menu .email,
.side-menu .ibt-btn-rounded,
.side-menu .social-icon li a,
.side-menu .social-icon li a i,
.side-menu .close-btn,
.side-menu .close-btn i {
  color: #ffffff !important;
}

.side-menu .ibt-btn.ibt-btn-outline-3 {
  border-color: #ffffff !important;
  background: transparent !important;
}

.side-menu .ibt-btn.ibt-btn-outline-3::before,
.side-menu .ibt-btn.ibt-btn-outline-3::after {
  background: #ffffff !important;
}

.side-menu .ibt-btn.ibt-btn-outline-3 span {
  color: #ffffff !important;
}

.side-menu .ibt-btn.ibt-btn-outline-3:hover,
.side-menu .ibt-btn.ibt-btn-outline-3:focus {
  background: #ffffff !important;
  border-color: #ffffff !important;
}

.side-menu .ibt-btn.ibt-btn-outline-3:hover span,
.side-menu .ibt-btn.ibt-btn-outline-3:focus span {
  color: #111111 !important;
}

/* Header top bar overrides to match template black/white look */
.vs-header6 .header-top-content4,
.vs-header15 .header-top-content4 {
  background-color: #111111 !important;
  border: 0 !important;
}

.vs-header6 .header-top-content4 .top-bar-contacts li span,
.vs-header6 .header-top-content4 .top-bar-socials li span,
.vs-header15 .header-top-content4 .top-bar-contacts li span,
.vs-header15 .header-top-content4 .top-bar-socials li span {
  color: #919191 !important;
}

.vs-header6 .header-top-content4 .top-bar-contacts li a,
.vs-header6 .header-top-content4 .top-bar-socials li a,
.vs-header15 .header-top-content4 .top-bar-contacts li a,
.vs-header15 .header-top-content4 .top-bar-socials li a {
  color: #ffffff !important;
}

.vs-header6 .header-top-content4 .top-bar-socials li a:hover,
.vs-header15 .header-top-content4 .top-bar-socials li a:hover {
  color: #ffffff !important;
  opacity: 0.85;
}

/* Keep About banner spacing aligned with template */
.page-banner11 {
  margin-top: 21px !important;
}


/* Preloader Styling */

#preloader {
  background-color: #ffffff !important;
}

#preloader .loader {
  background: none !important;
  padding: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  animation: none !important;
}


#preloader .loader img {
  filter: none !important;
  opacity: 1 !important;
  width: 90px;
  height: auto;
}


/* Scroll Button */
#scrollBtn i {
  color: #ffffff !important;
}


/* Menu Arrow deletion */

.main-menu ul li > a::after,
.main-menu ul li > a::before,
.menu-item::after {
  display: none !important;
  content: none !important;
}

.main-menu ul li a .fa-angle-down,
.main-menu ul li a .fa-chevron-down,
.main-menu ul li a .icon-arrow-down {
  display: none !important;
}




.sec-title .title.animated-heading,
.sec-title p,
.sec-title .sub-title,
.footer-content .title,
.contact-content2 .title {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

.contact-content2 .contact-info-row-secondary {
  align-items: flex-end;
}

.contact-content2 .contact-info-row-secondary .call-center2 .social-icon {
  margin-top: 0;
}

blockquote,
.staff-text {
  opacity: 1 !important;
  visibility: visible !important;
}

/* Share Box Target Design Overrides */
.team-card .share-box {
  width: 50px !important;
  border-radius: 25px !important;
  /* Ensures the top has border radius when opened */
}

.team-card .share-icon {
  width: 50px !important;
  height: 50px !important;
  line-height: 50px !important;
  background-color: #111111 !important;
  /* Match target black */
  color: #ffffff !important;
  border-radius: 50% !important;
  /* Perfect circle */
}

.team-card .social-links {
  width: 50px !important;
  background-color: #111111 !important;
  /* Match target black */
  border-radius: 25px !important;
  /* Match the pill shape */
}

.team-card .social-links li a i {
  color: #ffffff !important;
  /* Ensure icons are clearly visible */
}

/* Hero Slider Navigation Overrides - EXACTLY from template style.css */
.hero-style6 .slider-btn {
  bottom: auto !important;
  top: 44% !important;
  left: auto !important;
  right: -38px !important;
  line-height: unset !important;
  -webkit-transform: translateY(-50%) rotate(-90deg) !important;
  -ms-transform: translateY(-50%) rotate(-90deg) !important;
  transform: translateY(-50%) rotate(-90deg) !important;
  z-index: 999999 !important;
  background-color: #ecf0f4 !important;
  display: flex !important;
  align-items: center !important;
}

.hero-style6 .slider-btn::before {
  content: "" !important;
  position: absolute !important;
  left: -19px !important;
  bottom: 0 !important;
  width: 20px !important;
  height: 20px !important;
  background-image: url(../images/layers/hero-shape7.png) !important;
}

.hero-style6 .slider-btn::after {
  content: "" !important;
  position: absolute !important;
  right: -20px !important;
  top: 40px !important;
  width: 20px !important;
  height: 20px !important;
  background-image: url(../images/layers/hero-shape6.png) !important;
  -webkit-transform: rotate(179deg) !important;
  -ms-transform: rotate(179deg) !important;
  transform: rotate(179deg) !important;
}

.hero-style6 .slider-btn .swiper-button-next,
.hero-style6 .slider-btn .swiper-button-prev {
  position: relative !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  margin: 0 !important;
  width: 0px !important;
  height: auto !important;
  background-color: unset !important;
  padding: 0 !important;
  border: 0 !important;
  outline: none !important;
  -webkit-transition: all 0.3s ease !important;
  transition: all 0.3s ease !important;
  display: block !important;
}

.hero-style6 .slider-btn .swiper-button-next::after,
.hero-style6 .slider-btn .swiper-button-prev::after {
  display: none !important;
}

.hero-style6 .slider-btn .swiper-button-next {
  margin: 0 13px 0px 0px !important;
  -webkit-transform: rotate(-90deg) !important;
  -ms-transform: rotate(-90deg) !important;
  transform: rotate(-90deg) !important;
}

.hero-style6 .slider-btn .swiper-button-next::before {
  content: "\e845" !important;
  font: 400 normal 11px/1em "fontello" !important;
  font-size: 14px !important;
}

.hero-style6 .slider-btn .swiper-button-prev {
  margin: 0 0 0 13px !important;
  -webkit-transform: rotate(90deg) !important;
  -ms-transform: rotate(90deg) !important;
  transform: rotate(90deg) !important;
}

.hero-style6 .slider-btn .swiper-button-prev::before {
  content: "\e845" !important;
  font: 400 normal 11px/1em "fontello" !important;
  font-size: 14px !important;
}

.hero-style6 .slider-btn .swiper-button-prev:hover,
.hero-style6 .slider-btn .swiper-button-next:hover {
  color: var(--color-primary) !important;
}


.side-menu::after {
  background-image: none;
}

/* Services page: clean card layout for dynamic API content */
.service-card-clean {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 520px;
  margin-bottom: 24px;
  background: #ffffff;
  border: 1px solid #ece7f3;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.service-card-clean:hover {
  transform: translateY(-6px);
  box-shadow: 0 14px 35px rgba(15, 23, 42, 0.15);
}

.service-card-clean__image {
  width: calc(100% - 28px);
  height: 240px;
  margin: 14px 14px 0;
  border-radius: 16px;
  object-fit: cover;
  object-position: center;
  display: block;
}

.service-card-clean__body {
  padding: 16px 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  color: #120f16;
}

.service-card-clean__title {
  margin: 0;
  font-size: 23px;
  line-height: 1.35;
  color: #120f16;
}

.service-card-clean__description,
.service-card-clean__description p {
  margin: 0;
  font-size: 15px;
  line-height: 1.75;
  color: #000000;
  display: -webkit-box;
  -webkit-line-clamp: 5;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}

.service-card-clean.rtl .service-card-clean__body {
  text-align: right;
}

.service-card-clean.ltr .service-card-clean__body {
  text-align: left;
}

.service-card-clean__truncation-tail {
  margin: 0;
  padding-top: 6px;
  font-size: 15px;
  line-height: 1.75;
  color: #000000;
}

.service-card-clean__truncation-tail.rtl {
  text-align: right;
}

.service-card-clean__truncation-tail.ltr {
  text-align: left;
}

.service-card-clean__dots {
  letter-spacing: 0.02em;
}

.service-card-clean__see-more {
  font-weight: 600;
  color: var(--color-primary);
  text-decoration: none;
}

.service-card-clean__see-more:hover {
  text-decoration: underline;
}

.service-card-clean__footer {
  margin-top: auto;
  padding-top: 10px;
}

.service-card-clean__footer.rtl {
  text-align: right;
}

.service-card-clean__footer.ltr {
  text-align: left;
}

.project-card-btn {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
}

/* Service single (theme: .service-single-sec + .ser-detail) */
.service-single-page.rtl .ser-detail .sec-title {
  text-align: right;
}

.service-single-page.ltr .ser-detail .sec-title {
  text-align: left;
}

.service-single-page__body--html {
  margin-top: 18px;
}

.service-single-page__body--html p {
  font-weight: 500;
  line-height: 1.75;
  font-size: 16px;
  color: var(--color-content-black2, #120f16);
  margin: 16px 0 0;
}

.service-single-page__body--html p:first-child {
  margin-top: 0;
}

.page-banner9 {
  background-image: url(../images/bg/contact-us-banner.jpg) !important;
}

.page-banner5 {
  background-image: url(../images/bg/projects-banner2.png) !important;
  background-position: center center !important;
}

.page-banner3 {
  background-image: url(../images/bg/services-banner.png) !important;
  background-position: center center !important;
}

.page-banner11 {
  background-image: url(../images/bg/about-us-banner2.png) !important;
  background-position: center center !important;
}

/* About banner: nudge vertical label so "The BI Tech" stays inside */
.page-banner11 .staff-text {
  bottom: 18px;
  font-size: 90px;
}

@media (max-width: 1201px) {
  .page-banner11 .staff-text {
    font-size: 58px;
  }
}

.hero-sec-info3 {
  max-height: 650px !important;
}

/* Hero home – exp box without video thumbnail */
.hero-home-exp-box {
  padding-left: 40px !important;
  width: auto !important;
}

@media (max-width: 820px) {
  .hero-style6 .hero-content6 {
    height: 920px !important;
  }

  .hero-style6 .hero-sec-info3 {
    max-height: none !important;
  }

  .hero-style6 .hero-home-exp-box {
    bottom: 12px !important;
    left: 18px !important;
    right: auto !important;
    width: auto !important;
    min-width: unset !important;
    max-width: 280px !important;
    padding: 20px 16px 20px 40px !important;
    z-index: 1;
  }

  .hero-style6 .hero-text6 {
    z-index: 2;
  }
}

@media (max-width: 577px) {
  .hero-style6 .hero-content6 {
    height: 880px !important;
  }
}

@media (max-width: 390px) {
  .hero-style6 .hero-content6 {
    height: 840px !important;
  }

  .hero-style6 .hero-home-exp-box {
    max-width: 260px !important;
    padding: 16px 12px 16px 36px !important;
  }
}

.mt-20 {
  margin-top: 80px !important;
}

.video-img img {
  height: 124px;
}


/* Side Menu Colour Change */

.side-menu::before,
.side-menu3::before {
  background-image: linear-gradient(to bottom, var(--color-primary), var(--color-secondary)) !important;
}

/* Home Counter Overrides */
.counter-box2 .counter-number {
  font-size: 90px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  display: inline-block !important;
  background-image: linear-gradient(104deg, #1A5C1A 0%, #00C9A7 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  font-family: var(--font-primary) !important;
}

.exp-box p {
  font-size: 22px !important;
  line-height: 1.3 !important;
  color: var(--color-content-black2) !important;
}

/* Card button overrides to match the templates */
.service-card-clean {
  position: relative !important;
}

.service-card-clean .ser-btn3 {
  color: var(--color-heading, #120f16) !important;
  border-color: var(--color-heading, #120f16) !important;
}

.service-card-clean .ser-btn3:hover {
  color: var(--color-heading, #120f16) !important;
}

.service-card-clean .ser-btn3::before,
.service-card-clean .ser-btn3::after {
  color: var(--color-heading, #120f16) !important;
}

.service-card-clean__title a {
  color: inherit !important;
  text-decoration: none !important;
  transition: color 0.25s ease !important;
}

.service-card-clean__title a:hover {
  color: var(--color-primary, #00c9a7) !important;
  text-decoration: none !important;
}

/* Privacy policy modal (aligned with video-modal overlay pattern) */
.privacy-policy-modal {
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  z-index: 9999999999999;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 24px;
  background-color: rgba(0, 0, 0, 0.5);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.privacy-policy-modal.show {
  opacity: 1;
}

.privacy-policy-modal__panel {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 860px;
  max-height: min(90vh, 900px);
  background: #ffffff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.35);
}

.privacy-policy-modal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px 28px;
  border-bottom: 1px solid #e8e8e8;
  background: #111111;
}

.privacy-policy-modal__header .title {
  margin: 0;
  font-size: 24px;
  line-height: 1.3;
  color: #ffffff;
  font-family: "Sora", sans-serif;
}

.privacy-policy-modal__header .close-btn {
  position: static;
  flex-shrink: 0;
  border: 0;
  background: transparent;
  font-size: 32px;
  line-height: 1;
  color: #ffffff;
  cursor: pointer;
  padding: 0 4px;
  transition: opacity 0.2s ease;
}

.privacy-policy-modal__header .close-btn:hover {
  opacity: 0.75;
}

.privacy-policy-modal__body {
  flex: 1;
  overflow-y: auto;
  padding: 28px 32px 32px;
  color: var(--color-content-black2, #444444);
  font-size: 16px;
  line-height: 1.7;
  font-family: "Manrope", sans-serif;
}

.privacy-policy-modal__state {
  text-align: center;
  padding: 48px 16px;
}

.privacy-policy-modal__state i {
  font-size: 28px;
  color: var(--color-primary, #1a5c1a);
}

.privacy-policy-modal__state p {
  margin: 12px 0 0;
}

.privacy-policy-modal__state--error p {
  color: #b42318;
}

.privacy-policy-content h1,
.privacy-policy-content h2,
.privacy-policy-content h3,
.privacy-policy-content h4 {
  color: var(--color-heading, #120f16);
  font-family: "Sora", sans-serif;
  margin-bottom: 12px;
}

.privacy-policy-content p,
.privacy-policy-content li {
  margin-bottom: 12px;
}

.privacy-policy-content a {
  color: var(--color-primary, #1a5c1a);
  text-decoration: underline;
}

.privacy-policy-content ul,
.privacy-policy-content ol {
  padding-inline-start: 1.25rem;
  margin-bottom: 16px;
}

@media (max-width: 577px) {
  .privacy-policy-modal {
    padding: 16px;
  }

  .privacy-policy-modal__header {
    padding: 18px 20px;
  }

  .privacy-policy-modal__header .title {
    font-size: 20px;
  }

  .privacy-policy-modal__body {
    padding: 20px;
  }
}

/* Service page testimonial counter: use brand primary instead of white outline/text */
.testimonial-content .testi-count h4 span {
  -webkit-text-stroke: 1px var(--color-primary, #1a5c1a);
}

.testimonial-content .testi-count > span {
  color: var(--color-primary, #1a5c1a);
}

.team-img .sub-title {
  font-size: 45px;
  white-space: nowrap;
  line-height: 1.15;
}

.footer-style1 .contact-info .call-center .location-text,
.contact-content2 .call-center2 .location-text {
  max-width: 260px;
}