/* ==============================
   Carousel image sizing
============================== */
.carousel-img {
    width: 100%;
    height: 65vh;
    object-fit: cover;
  }
  
  /* Tablet */
  @media (max-width: 992px) {
    .carousel-img {
      height: 50vh;
    }
  }
  
  /* Mobile */
  @media (max-width: 768px) {
    .carousel-img {
      height: 40vh;
    }
  }
  
  /* ==============================
     Centered caption
  ============================== */
  .carousel-caption-centered {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 90%;
    text-align: center;
    color: #fff;
    opacity: 0;
    background: #00418ba1;
    height: 50vh;
    padding: 38px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    box-shadow: inset 0 0 20px 0px #a3afcc;
  }
  
  /* Mobile text scaling */
  @media (max-width: 768px) {
    .carousel-caption-centered h2 {
      font-size: 1.5rem;
    }
  
    .carousel-caption-centered p {
      font-size: 1rem;
    }
  }
  
  /* ==============================
     Animation
  ============================== */
  @keyframes scaleIn {
    from {
      opacity: 0;
      transform: translate(-50%, -50%) scale(0.85);
    }
    to {
      opacity: 1;
      transform: translate(-50%, -50%) scale(1);
    }
  }
  
  /* Trigger animation on active slide */
  .carousel-item.active .carousel-caption-centered {
    animation: scaleIn 1s ease forwards;
    animation-delay: 0.3s;
  }
  

.modal-header{
    background: #1254a3;
}

table thead.bg-site-primary{
    background: #1254a3;
}

.modal-header-1{
    background: #ebebeb;
}
.modal-header-1 .modal-title{
    text-align: center;
    width: 100%;
    color: #2d2d2d !important;
}
.content-sub-title{
    color: #1254a3;
    font-weight: 600;
    font-size: 18px;
    margin-bottom: 10px;
}
.slider-content{
    border-radius: 27px;
    background: #00000026;
    padding: 35px 70px;
    text-align: center;
}

.slider-area.slider-gsp-top{
    height: 700px;
}

.slider-content-title{ font-size: clamp(1.6rem, 4vw, 3rem); margin-bottom: 0.75rem; }
p.slider-content-text {
    font-size: clamp(0.95rem, 2.2vw, 1.25rem); margin: 0; letter-spacing: 0.5px;
}
.slider-content-title,.slider-content-text{
    text-shadow: 0 0 6px #000000;
    color: #000 !important;
    text-align: center;
    text-shadow: -1px 1px 4px #ffffff;
}

@keyframes text-blink {
    0% { opacity: 1; }
    50% { opacity: 0; color: }
    100% { opacity: 1; color: }
}
#prd-latest-nav{
    position: absolute;
    top: 0;
    right: 46px;
    display: inline-table;
    bottom: 0;
    margin: auto 0;
    background: #ffffff;
    padding: 10px 24px;
    box-shadow: 0px 0px 0px 1px #084283;
}

#prd-latest-nav a{
    text-align: center;
    font-size: 18px;
    color: #600370;
    animation: text-blink 1s infinite;
}
#prd-latest-nav a i{ vertical-align: text-top; color: #158808; }

.fs-30{
    font-size: 30px;
}
.fs-16{
    font-size: 16px;
}
.fs-14{
    font-size: 14px;
}
.fs-12{
    font-size: 12px;
}

.fs-13{
    font-size: 13px;
}

.w-65{
    width: 65% !important;
}
.modal-header .modal-title{
    color: #fff;
}
.modal-header .btn-close{
    background-color: #ffffff;
    border-radius: 50%;
    opacity: 1;
}
#btn_gSearch {
    border-left: none;
    background: #efefef;
    color: #0063d5;
    border-color: #dfdfdf;
}

.gsp-btn.btn-dark{
    background: #5d5d5d;
    color: #ffffff;
    border: 1px solid #5d5d5d;
}

#form-prodsearch {
    width: 95%;
    display: flex;
    margin: 0 auto;
}

#globalSearch {
    border-color: #dfdfdf;
}

.form-control:focus {
    box-shadow: none;
    border-color: inherit;
    outline: 0;
}

.gsp-footer-widget__contact {
    font-size: 18px !important;
}

.partner-item {
    padding: 20px;
}

.partner-item img {
    max-width: 150px;
    width: 100%;
    height: auto;
    object-fit: contain;
}

.gsp-team__title {
    word-wrap: break-word;
    overflow-wrap: break-word;
    word-break: break-word;
}

.gsp-team__title a {
    display: inline-block;
    max-width: 100%;
}

.team-active .swiper-wrapper {
    align-items: stretch;
}

.team-active .swiper-slide {
    height: auto;
    display: flex;
}
#featured-products{ border-top: 6px solid rgb(18 84 163 / 34%); border-bottom: 6px solid rgb(18 84 163 / 34%);  }
.team-active .gsp-team {
    width: 100%;
    display: flex;
    flex-direction: column;
}

.team-active .gsp-team__thumb {
    min-height: 250px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.team-active .gsp-team__content {
    flex: 1;
}

.delivery-partners-wrapper{
    display: flex;
    align-items: center;
    justify-content: center;
}
.delivery-partners-wrapper img {
    max-width: 150px;
    width: 100%;
    height: auto;
    object-fit: contain;
}

.map-icon a{
    position: relative;
    width: 200px; 
    display: block;
    border: 1px solid #dbdbdb;
    padding: 4px; 
    margin: 0 auto;
}

.map-icon a img{
    width: 100%;
    height: 100%;
    object-fit: contain;
}


.gsp-footer-top {
    padding: 50px;
    background: rgb(242 248 255);
    background-image: url(../../assets/img/shape/pattern1.png) !important;
}

.footer-area-bottom {
    background: #1253a5;
    padding: 15px 0;
}

.filter-pagination-bar {
    position: relative;
    margin: 30px 0 40px;
}

.filter-pagination-bar .prdfilter-bg {
    position: absolute;
    inset: 0;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 25px 60px rgba(15, 46, 94, 0.08);
}

.a2zpagination {
    display: grid;
    grid-template-columns: repeat(26, minmax(0, 1fr));
    overflow: hidden;
    box-shadow: 0 3rem 2rem rgba(0, 0, 0, 0.05), 0 0 1rem rgba(0, 0, 0, 0.025);
}

.a2zpagination li {
    position: relative;
}

.a2zpagination li a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 64px;
    border: 1px solid rgba(9, 48, 104, 0.08);
    border-width: 0 1px 1px 0;
    border-left: none;
    font-weight: 700;
    font-size: 16px;
    color: #0452a7;
    letter-spacing: 0.04em;
    transition: all 0.25s ease;
}

.a2zpagination li a:hover {
    color: #0c53a5;
    box-shadow: inset 0px 0px 13px 4px #1151a69e;
}

.a2zpagination li.active a {
    color: #0c53a5;
    box-shadow: inset 0px 0px 13px 4px #1151a69e;
}
.gspproditem_thumb { min-height: 172px; background: #fff; }
.gspproditem_thumb a{
    display: block;
    width: 75%;
    margin: 10px auto 0;
}

@media (max-width: 915px) {
    .a2zpagination {
        grid-template-columns: repeat(8, minmax(0, 1fr));
    }

    .mission-vision-card-inner{
        align-items: center;
        flex-direction: column;
    }
    .values-card { margin-top: 20px; }
}

@media (max-width: 575px) {
    .a2zpagination {
        grid-template-columns: repeat(5, minmax(0, 1fr));
        padding: 14px;
    }

    .a2zpagination li a {
        height: 54px;
        font-size: 14px;
    }
}

.home-products-display .gsp-section-title{ font-size: 25px !important; }

/* Product Tabs Styling */
.product-tabs {
    display: flex;
    list-style: none;
    margin: 30px 0 40px;
    padding: 0;
    border-bottom: 2px solid #e5e9f0;
    gap: 0;
}

.product-tabs .tab-item {
    padding: 18px 35px;
    font-size: 16px;
    font-weight: 600;
    color: #6b7280;
    cursor: pointer;
    position: relative;
    transition: all 0.3s ease;
    background: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    margin-bottom: -2px;
}

.product-tabs .tab-item:hover {
    color: #0452a7;
    background: rgba(4, 82, 167, 0.05);
}

.product-tabs .tab-item.active {
    color: #0452a7;
    border-bottom-color: #0452a7;
    background: rgba(4, 82, 167, 0.05);
}

.product-tabs .tab-item.active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 3px;
    background: #0452a7;
}

.tab-content {
    animation: fadeIn 0.3s ease-in;
}

@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@media (max-width: 767px) {
    .product-tabs {
        flex-wrap: wrap;
        gap: 5px;
    }
    
    .product-tabs .tab-item {
        padding: 14px 20px;
        font-size: 14px;
        flex: 1;
        min-width: calc(33.333% - 4px);
        text-align: center;
    }
}

/* Mission & Vision Section Enhanced Styling */
.values-icon img{
    width: 100%;
    padding: 25px;
}
.mission-vision-card {
    background: #ffffff;
    border-radius: 15px;
    padding: 30px 10px 20px;
    height: 100%;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.08);
    transition: all 0.4s ease;
    position: relative;
    overflow: hidden;
}

.mission-vision-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 5px;
    background: linear-gradient(90deg, #0E63FF 0%, #10D0A1 100%);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s ease;
}

.mission-vision-card:hover::before {
    transform: scaleX(1);
}

.mission-vision-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}

.mission-vision-card-inner {
    position: relative;
    z-index: 1;
}

.mission-vision-icon-wrapper {
    text-align: center;
    width: -webkit-fill-available;
}

.mission-vision-icon {
    display: inline-block;
    width: 100px;
    height: 100px;
    line-height: 100px;
    text-align: center;
    border-radius: 50%;
    background-color: var(--gp-icon-blue-light);
    transition: all 0.4s ease;
    position: relative;
    margin-bottom: 15px;
}

.mission-vision-icon i {
    font-size: 40px;
    color: var(--gp-icon-blue);
    transition: all 0.4s ease;
}

.mission-vision-icon.pink-icon {
    background-color: var(--gp-icon-pink-light);
}

.mission-vision-icon.pink-icon i {
    color: var(--gp-icon-pink);
}

.mission-vision-card:hover .mission-vision-icon {
    transform: scale(1.1) rotate(5deg);
}

.mission-vision-card:hover .mission-vision-icon i {
    transform: scale(1.1);
}

.mission-vision-content {
    text-align: center;
    padding: 0 40px;
}

.mission-vision-title {
    font-size: 24px;
    color: var(--gp-heading-primary);
    position: relative;
    padding-bottom: 15px;
}

.mission-vision-content p {
    font-size: 16px;
    line-height: 1.8;
    color: var(--gp-text-body);
    margin-bottom: 20px;
}

.mission-vision-content p:last-child {
    margin-bottom: 0;
}

@media (max-width: 991px) {
    .mission-vision-card {
        padding: 40px 30px;
        margin-bottom: 30px;
    }
    
    .mission-vision-icon {
        width: 85px;
        height: 85px;
        line-height: 85px;
    }
    
    .mission-vision-icon i {
        font-size: 35px;
    }
    
    .mission-vision-title {
        font-size: 24px;
    }

    .row.mv-card-row{
        flex-direction: column;
        align-items: center;
    }
    .values-card-col, .mission-vision-card-col{
        width: 100%;
    }
}

@media (max-width: 767px) {
    .mission-vision-card {
        padding: 35px 25px;
    }
    
    .mission-vision-icon {
        width: 75px;
        height: 75px;
        line-height: 75px;
    }
    
    .mission-vision-icon i {
        font-size: 30px;
    }
    
    .mission-vision-title {
        font-size: 22px;
    }
    
    .mission-vision-content p {
        font-size: 15px;
    }
}

.mission-vision-card-inner{
    display: flex;
    justify-content: center;
    align-items: center;
}

/* Clients Section Styling */
.clients-area {
    background-color: #f8f9fa;
}

.client-item {
    height: 100%;
    transition: all 0.3s ease;
}

.client-item__inner {
    background: #ffffff;
    border-radius: 12px;
    padding: 30px 20px;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.06);
    transition: all 0.3s ease;
    border: 1px solid #e9ecef;
    min-height: 150px;
}

.client-item__inner:hover {
    transform: translateY(0px);
    box-shadow: 0 10px 30px rgba(0, 99, 213, 0.15);
    border-color: #0063d5;
}

.client-item__logo {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
}

.client-item__logo img {
    max-width: 100%;
    /* max-height: 80px; */
    width: 100%;
    height: auto;
    object-fit: contain; 
    transition: all 0.3s ease;
}

.client-item__inner:hover .client-item__logo img {
    filter: grayscale(0%);
    opacity: 1;
    transform: scale(1.05);
}

.gsp-section_description {
    font-size: 16px;
    color: #6c757d;
    max-width: 700px;
    margin: 0 auto;
    line-height: 1.6;
}

@media (max-width: 1199px) {
    .client-item__inner {
        padding: 25px 15px;
        min-height: 140px;
    }
    
    .client-item__logo img {
        max-height: 70px;
    }
}

@media (max-width: 991px) {
    .client-item__inner {
        padding: 20px 15px;
        min-height: 130px;
    }
    
    .client-item__logo img {
        max-height: 65px;
    }
}

@media (max-width: 767px) {
    .client-item__inner {
        padding: 20px 10px;
        min-height: 120px;
    }
    
    .client-item__logo img {
        max-height: 60px;
    }
    
    .gsp-section_description {
        font-size: 14px;
        padding: 0 15px;
    }
}

.clients-scroll-wrapper {
    overflow: hidden;
    position: relative;
    padding: 20px 0;
}

.clients-scroll-row {
    overflow: hidden;
    margin-bottom: 20px;
}

.clients-scroll-inner {
    display: flex;
    gap: 20px;
    width: fit-content;
    animation: scroll-horizontal 15s linear infinite;
}

.clients-scroll-reverse {
    animation: scroll-horizontal-reverse 45s linear infinite;
}

.slider-content__shape {
    opacity: 0.1 !important;
}

.client-scroll-item {
    flex-shrink: 0;
    width: 120px;
}

.client-scroll-item .client-item__inner {
    min-height: 120px;
    padding: 20px;
}

.client-scroll-item .client-item__logo img {
    /* max-height: 60px; */
}

@keyframes scroll-horizontal {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

@keyframes scroll-horizontal-reverse {
    0% {
        transform: translateX(-50%);
    }
    100% {
        transform: translateX(0);
    }
}

@media (max-width: 991px) {
    .client-scroll-item {
        width: 180px;
    }
}

@media (max-width: 767px) {
    .client-scroll-item {
        width: 150px;
    }
    
    .client-scroll-item .client-item__inner {
        min-height: 100px;
        padding: 15px;
    }
    
    .client-scroll-item .client-item__logo img {
        max-height: 50px;
    }
}

/* Services Page Styling */
.services-category-header {
    text-align: center;
    margin-bottom: 40px;
}

.services-category-title {
    font-size: 32px;
    color: #0452a7;
    position: relative;
    display: inline-block;
    padding-bottom: 15px;
}

.services-category-title::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 80px;
    height: 3px;
    background: linear-gradient(90deg, #0E63FF 0%, #10D0A1 100%);
}

.service-list-item {
    display: flex;
    align-items: center;
    padding: 25px;
    background: #ffffff;
    border-radius: 12px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.06);
    transition: all 0.3s ease;
    border: 1px solid #e9ecef;
    height: 100%;
}

.service-list-item:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0, 99, 213, 0.15);
    border-color: #0063d5;
}

.service-list-icon {
    width: 50px;
    height: 50px;
    min-width: 50px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(4, 82, 167, 0.1);
    border-radius: 10px;
    margin-right: 20px;
    transition: all 0.3s ease;
}

.service-list-icon i {
    font-size: 24px;
    color: #0452a7;
    transition: all 0.3s ease;
}

.service-list-item:hover .service-list-icon {
    background: #0452a7;
    transform: scale(1.1);
}

.service-list-item:hover .service-list-icon i {
    color: #ffffff;
}

.service-list-content {
    flex: 1;
}

.service-list-content h5 {
    font-size: 16px;
    font-weight: 500;
    color: #2c3e50;
    margin: 0;
    line-height: 1.5;
    transition: all 0.3s ease;
}

.service-list-item:hover .service-list-content h5 {
    color: #0452a7;
}

@media (max-width: 991px) {
    .services-category-title {
        font-size: 28px;
    }
    
    .service-list-item {
        padding: 20px;
    }
    
    .service-list-icon {
        width: 45px;
        height: 45px;
        min-width: 45px;
        margin-right: 15px;
    }
    
    .service-list-icon i {
        font-size: 20px;
    }
    
    .service-list-content h5 {
        font-size: 15px;
    }
}

@media (max-width: 767px) {
    .services-category-title {
        font-size: 24px;
    }
    
    .service-list-item {
        padding: 18px;
        flex-direction: column;
        text-align: center;
    }
    
    .service-list-icon {
        margin-right: 0;
        margin-bottom: 15px;
    }
    
    .service-list-content h5 {
        font-size: 14px;
    }
}

.gsp-footer-widget__links ul li a::before
 {
    content: "\f061";
    font-family: "Font Awesome";
    font-weight: 900;
    position: absolute;
    left: -10px;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transition: all 0.3s ease-out 0s;
    -moz-transition: all 0.3s ease-out 0s;
    -ms-transition: all 0.3s ease-out 0s;
    -o-transition: all 0.3s ease-out 0s;
    transition: all 0.3s ease-out 0s;
}

/* Accreditation Grid */

.accreditation-area .container {
    position: relative;
    z-index: 1;
}

.accreditation-grid {
    display: flex;
    padding: 10px;
    justify-content: center;
}

.accreditation-card img {
    width: 100%;
    height: auto;
    transition: transform 0.3s ease, filter 0.3s ease, opacity 0.3s ease;
    box-shadow: 0px 8px 9px 0px #d1d1d1;
    border-radius: 50%;
    border: 1px solid #ccc;
    padding: 0;
}

.accreditation-card span {
    margin-top: 15px;
    font-size: 15px;
    font-weight: 600;
    color: #0b265e;
}

.accreditation-card:hover img {
    transform: scale(1.05);
}

/* Search Not Found Styles */
.search-not-found{
    width: 150px;
}

.search-not-found-text {
    max-width: 800px;
    margin: 0 auto;
    padding: 20px;
}

.search-not-found-text h5 {
    color: var(--gp-site-primary);
    font-weight: 600;
    font-size: 22px;
}

.search-not-found-text p {
    font-size: 16px;
    line-height: 1.6;
    color: #4a5568;
}

/* Product Request Form Styles */
.product-request-form-container {
    padding: 10px 25px;
}

.product-request-form-wrapper {
    background: #fff;
    border-radius: 12px;
    padding: 40px;
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.08);
    border: 1px solid #e5e7eb;
}

.product-request-form-wrapper h5 {
    color: var(--gp-site-primary);
    font-weight: 600;
    font-size: 24px;
}

.product-request-form-wrapper .form-label {
    font-weight: 500;
    color: #374151;
    margin-bottom: 8px;
    font-size: 14px;
}

.product-request-form-wrapper .form-control {
    border: 1px solid #d1d5db;
    border-radius: 6px;
    padding: 10px 15px;
    font-size: 14px;
    transition: all 0.3s ease;
}

.product-request-form-wrapper .form-control:focus {
    border-color: var(--gp-site-primary);
    box-shadow: 0 0 0 3px rgba(4, 82, 167, 0.1);
    outline: none;
}

.product-request-form-wrapper textarea.form-control {
    resize: vertical;
}

.product-request-form-wrapper .gsp-btn {
    padding: 12px 40px;
    font-size: 16px;
}

@media (max-width: 767px) {
    .product-request-form-wrapper {
        padding: 25px 20px;
    }
    
    .search-not-found-text {
        padding: 15px;
    }
    
    .search-not-found-text h5 {
        font-size: 20px;
    }
    
    .search-not-found-text p {
        font-size: 14px;
    }
}

/* Text Selection */
::selection {
    background: var(--gp-site-primary);
    color: #fff;
}

::-moz-selection {
    background: var(--gp-site-primary);
    color: #fff;
}

@media (max-width: 767px) {
    .accreditation-grid {
        gap: 15px;
    }

    .accreditation-card span {
        font-size: 14px;
    }
}

.prod-grid-col {
    display: flex;
    position: relative;
    overflow: hidden;
    align-items: stretch;
}

.gspproditem {
    border: 1px solid #d1d1d1;
    background: #ffffff;
    border-radius: 5px;
    width: 100%;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: space-between;
    padding: 1px;
}

.gspproditem:hover {
    border-color: #d5d5d5;
    box-shadow: 0 0 11px 0px rgb(4 4 4 / 13%);
}

.gspproditem_content {
    background: #dae3ff57;
    padding: 5px;
    border-top: 1px solid #d5e3ff;
    position: relative;
}

span.api-indic-grid {
    padding: 0px 4px;
    border-radius: 5px;
    position: absolute;
    color: #c500a2;
    top: 5px;
    left: 5px;
    /* background: #fadcff; */
    font-size: 11px;
    line-height: 15px;
    border: 1px solid #c500a2;
}

/* Category Products Page Styles */
.category-page-products {
    padding: 20px 0;
}

.category-page-sidebar {
    background: #FFF;
    border: 1px solid #e0e0e0;
    margin-bottom: 20px;
    height: calc(100vh - 200px);
    min-height: 400px;
    display: flex;
    flex-direction: column;
    padding: 20px 0 0;
}

.category-page-sidebar h5 {
    font-weight: 600;
    color: #333;
    margin-bottom: 15px;
    text-transform: uppercase;
    font-size: 14px;
    letter-spacing: 1px;
    flex-shrink: 0;
    text-align: center;
    margin-bottom: 0;
}

.category-page-list {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    margin: 0;
    padding: 20px;
}

.category-page-list::-webkit-scrollbar {
    width: 8px;
}

.category-page-list::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 4px;
}

.category-page-list::-webkit-scrollbar-thumb {
    background: #888;
    border-radius: 4px;
}

.category-page-list::-webkit-scrollbar-thumb:hover {
    background: #555;
}

.category-page-list li a {
    color: #666;
    text-decoration: none;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    padding: 8px 12px;
    text-transform: capitalize;
    line-height: 21px;
}

.category-page-list li .category-icon i{
    /* clip-path: polygon(0 25%, 50% 0, 100% 25%, 100% 75%, 50% 100%, 0 75%); */
    background-color: #e5e5e5;
    display: inline-block;
    height: 15px;
    width: 15px;
    transform: translateY(5px);
    flex: 0 0 auto;
    margin-right: 10px;
}
span.category-icon {
    margin: 0;
}
.category-page-list li.active a,
.category-page-list li a:hover {
    color: #0c53a5;
    font-weight: 700;
}
.category-page-list li.active a i,
.category-page-list li a:hover i{
    background-color: #0c53a5;
}

.category-page-list li.category-divider {
    padding: 15px 20px 8px;
    margin-top: 10px;
    border-top: 1px solid #e0e0e0;
}

.category-page-list li.category-divider span {
    font-size: 12px;
    font-weight: 600;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

@media (max-width: 915px) {
    .category-page-products .category-page-sidebar {
        width: 100%;
        min-height: auto;
        height: auto;
        padding: 15px 15px 5px;
        border-radius: 12px;
    }

    .category-page-products .category-page-sidebar h5 {
        text-align: left;
        margin-bottom: 10px;
        letter-spacing: 0.08em;
        font-size: 12px;
        color: #888;
    }

    .category-page-products .category-page-list {
        display: flex;
        gap: 12px;
        overflow-x: auto;
        overflow-y: hidden;
        padding: 5px 0 10px;
        white-space: nowrap;
    }

    .category-page-products .category-page-list::-webkit-scrollbar {
        height: 6px;
    }

    .category-page-products .category-page-list li {
        flex: 0 0 auto;
        margin-bottom: 0;
    }

    .category-page-products .category-page-list li a {
        border: 1px solid #e0e0e0;
        border-radius: 999px;
        padding: 8px 18px;
        justify-content: flex-start;
        min-width: max-content;
    }

    .category-page-products .category-page-list li .category-icon i {
        transform: translateY(0);
        margin-right: 6px;
    }
    
    .category-page-products .category-page-list li .category-icon {
        display: none;
    }

    .category-page-products .category-sidebar-col,
    .category-page-products .category-content-col {
        flex: 0 0 100%;
        max-width: 100%;
    }
}

.category-page-description h4 {
    font-size: 24px;
    font-weight: 600;
    color: #333;
    margin-bottom: 10px;
}

.category-page-description p {
    color: #666;
    margin-bottom: 0;
}

.gspproditem.parentProduct {
    border: 4px solid #4d89ce;
    position: relative;
    box-shadow: 7px 5px 6px 1px #cecece;
}
.gspproditem.parentProduct:after {
    position: absolute;
    top: 0;
    right: -13px;
    bottom: 0;
    margin: auto 0;
    height: fit-content;
    font-size: 25px;
    color: #4f8acc;
    font-family: "Font Awesome";
    font-weight: 900;
    content: "\f0da";
}
.tbl-product-details tr,
.tbl-product-details tr td{ 
    padding: 8px 10px;
}
.tbl-product-details tr td:first-child{ 
    font-size: 15px;
    letter-spacing: 1px;
    width: 200px;
    font-weight: 600;
}

.product-details-content .tbl-product-details tr td:first-child{
    background: #e7f2ff57;
    font-family: math;
}
.price-list-table thead{
    background: var(--gp-site-primary);
    color: #FFF;
}
.price-list-table thead th{
    font-weight: normal;
}

.product-details-content table{
    box-shadow: 0px 8px 15px 0px #cccccc;
    height: 100%;
    margin: 0;
    border: 2px solid #dddddd;
}
.cart-count-badge {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 25px;
    height: 25px;
    border-radius: 50%;
    color: #000000;
    font-size: 11px;
    font-weight: 600;
    position: absolute;
    top: 6px;
    right: -21px;
}

.std-analysis-list {
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
}

.std-analysis-box span {
    color: #fff;
    background-color: #006a96;
    border-radius: 15px;
    padding: 2px 10px;
    margin: 0 15px 10px 0;
    font-size: 13px;
}
.std-analysis-box span i{
    font-size: 16px;
    margin-right: 5px;
    vertical-align: middle;
}
.cart-area{ min-height: 10%; }
.cart-dynamic, .cart-empty-section{ display: none; }
.table-content table.cart-table td{ padding: 0px 10px !important; }
.cart-empty-row td{ padding: 20px !important;  display: none;}
.cart-empty-section { margin: 120px 0; }
.product-button .gsp-btn,
.product-button .gsp-btn-second{
    padding: 10px 20px;
    font-size: 14px;
    text-transform: capitalize;
    font-weight: normal;
}
.prod-detail-col2 .product{
    height: 100%;
    display: flex;
}

.product-details-header .product-dtitle{
    font-weight: 400;
    line-height: 1.3;
    border-bottom: 1px solid #efefef;
    padding: 10px 0;
}

.cart-table thead{ background: var(--gp-site-primary); color: #ffffff; }
.cart-quantity-container {
    margin: 15px 10px;
}

/* Container */
.custom-check {
    position: relative;
    display: flex;
    cursor: pointer;
    align-items: center;
}

/* Hide original checkbox */
.custom-check input {
    position: absolute;
    opacity: 0;
    cursor: pointer;
}

/* Box Style */
.custom-check .checkmark {
    width: 20px;
    height: 20px;
    display: inline-block;
    border: 2px solid #afafaf;
    border-radius: 4px;
    background-color: #ffffff;
    position: relative;
    margin-right: 5px;
}

/* Green checkmark */
.custom-check input:checked + .checkmark::after {
    content: "";
    position: absolute;
    left: 8px;
    top: -6px;
    width: 9px;
    height: 18px;
    border: solid #07b500;
    border-width: 0 3px 3px 0;
    transform: rotate(45deg);
}

.sub-titles-line{
    border-bottom: 1px solid #CCC;
    padding-bottom: 10px;
}

.cart-cx-info{
    background: #f7f7f7;
    padding: 25px;
    border-radius: 12px;
    box-shadow: 0px 8px 8px 0px #cccccc;
}

.top-contact-info li {
    display: flex;
    align-items: center;
    justify-content: space-evenly;
}

.top-contact-info li a{
 text-decoration: none;
 font-size: 14px;
}
.top-contact-info-icon{
    width: 25px;
    height: 25px;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--gp-site-primary);
    border-radius: 50%;
    color: #ffffff;
    font-size: 12px;
    margin-right: 10px;
}

.header-menu-bottom-categories {
    width: 100%;
    padding: 2px 30px;
    /* border-bottom: 1px solid #eceef3; */
    background: linear-gradient(135deg, #0452a7 0%, #033d7a 100%);
}

.hdrCatGrid {
    display: block;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0;
    padding: 0;
    list-style: none;
    width: 65%;
    margin: 0 auto;
}

.hdrCatGrid .row{}

.hdrCatGrid li {
    position: relative;
    margin: 0;
    padding: 4px;
    transition: .3s;
    width: max-content;
}

.hdrCatGrid li:last-child {
    border-right: none;
}

.hdrCatGrid li.active::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 3px;
    background: #ffc107;
}

.hdrCatGrid a {
    display: block;
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    text-decoration: none;
    text-transform: capitalize;
    list-style: none;
    white-space: nowrap;
    text-align: center;
    transition: .3s;
    border: 1px solid #2d5d93;
    padding: 2px 13px;
    margin: 2px;
    box-shadow: inset 0 0 19px 0px #0d192e;
}

.hdrCatGrid a:hover {
    color: #ffc107;
    transform: translateY(-1px);
}

.hdrCatGrid li.active a {
    color: #ffc107;
    font-weight: 600;
}

/* Responsive */
@media (max-width: 1200px) {
    .header-menu-bottom-categories {
        padding: 8px 15px;
    }

    .hdrCatGrid a {
        padding: 8px 12px;
        font-size: 13px;
    }
}

@media (max-width: 768px) {
    #prd-latest-nav {
        top: 54.5vh;
        right: 0;
        left: 0;
        margin: 0 auto;
        z-index: 95;
    }

    .header-menu-bottom-categories {
        padding: 6px 10px;
    }
    .carousel-caption-centered{ width: 85%; }

    .hdrCatGrid {
        gap: 2px;
        display: flex;
        flex-wrap: wrap;
        width: 95%;
        justify-content: space-between;
        height: 90px;
        overflow-y: auto;
    }

    .hdrCatGrid li {
        flex: 1 1 calc(50% - 2px);
        border-right: none;
    }

    .hdrCatGrid li:last-child,
    .hdrCatGrid li:nth-last-child(2):nth-child(odd) {
        border-bottom: none;
    }

    .hdrCatGrid a {
        width: 100%;
        padding: 8px 10px;
        font-size: 12px;
        text-align: center;
    }
}

/* FAQ Enhanced Styles */
.faq-accordion .accordion-button{ background-color: #FFF !important; }

.faq-accordion .accordion-button:not(.collapsed), .faq-accordion .accordion-button:not(.collapsed):hover { 
    color: #ffffff !important;
    background: #1254a3 !important;
}
.faq-accordion .accordion-button:not(.collapsed)::after{ color: #ffffff !important; }

.faq-accordion .accordion-content p{ color: #000 !important; }

.faq-accordion .accordion-content{ background-color: #FFF !important; }

.faq-accordion .accordion-button:hover {
    background: #f8f9fa !important;
    color: #0452a7 !important;
}

/* .faq-accordion .accordion-button:not(.collapsed):hover {
    background: linear-gradient(135deg, #e0f0ff 0%, #d8ecff 100%) !important;
} */

.faq-accordion .accordion-items:hover {
    box-shadow: 0 2px 8px rgba(4, 82, 167, 0.1);
}

@media (max-width: 768px) {
    .faq-accordion .accordion-button {
        font-size: 16px !important;
        padding: 20px 20px !important;
    }
    
    .faq-accordion .accordion-body {
        padding: 20px 20px 25px 50px !important;
        font-size: 15px !important;
    }
}
.terms-page .gsp-section-title{ font-size: 25px !important; }

.quality-policy-tagline {
  border-top: 1px solid #e2e8f0;
  padding: 1.75rem 1.5rem;
  background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
  border-left: 4px solid var(--gp-site-primary, #0c53a5);
  border-radius: 0 8px 8px 0;
}

.quality-policy-tagline-text {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--gp-heading-primary, #171151);
  letter-spacing: 0.01em;
}

.news-ticker {
    height: 200px; 
    overflow: hidden;
    position: relative;
    background: #fff;
    border: 1px solid #ddd;
    border-radius: .25rem;
  }

  .news-ticker .ticker_inner {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    animation: scrollUp linear infinite;
    animation-play-state: running;
  }
  .news-ticker:hover .ticker_inner,
  .news-ticker:focus-within .ticker_inner {
    animation-play-state: paused;
  }

  .ticker-item {
    padding: .6rem;
    border-bottom: 1px dashed #f0f0f0;
    background: transparent;
  }

  @keyframes scrollUp {
    0%   { transform: translateY(0); }
    100% { transform: translateY(-50%); }
  }

  .mob-hdr-top {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
  .mobi-cart.header-cart-list {
    position: absolute;
    top: 10px;
    right: 14%;
}
.gspproditem .prdStatusIndic{
    position: absolute;
    right: 3px;
    top: 3px;
}
.prdStatusIndic {
    font-family: Sans-serif;
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    line-height: 150%;
    letter-spacing: 1px;
    border-radius: 4px;
    padding: 2px 8px;
}
.prd-container{
    width: 90% !important;
    margin: 0 auto;
    padding: 0;
}
.prdContRow {
    display: flex;
}
.prdContRow .prdContCol1 {
    color: #545454;
    font-weight: 600;
    width: 50%;
    text-align: end;
}

.prod-detail-col1{
    border: 1px solid #e3e3e3;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin-right: 24px;
    height: max-content;
    padding: 30px 10px;
}

.newProd-active .gspproditem{ height: 100%; }
.newProd-active .swiper-slide{ height:unset !important; }

.currency-select .current{ margin-top: -6px; display: block; }

.prf-aside{ color: #FFF; padding: 0; border-right: 1px solid #e1dcdc; }
.prf-header{ background: #00abc1; color: #FFF; padding: 20px 10px 10px; }
.tbl-profile-details td{ font-size: 14px; padding: 4px; border: none; }
.prf-aside ul li{ border:none; padding: 10px 30px; }
.prf-aside ul li.active{ background: none; }
.prf-aside ul li.active a{ font-weight: 600; color: var(--gp-site-primary);}
.acc-set-row{ box-shadow: 0px 0px 10px #CCC; }
a#deleteAccountBtn {
    position: absolute;
    right: 10px;
    top: 10px;
    color: #FFF;
    font-size: 12px;
}

.ft-sm-links a img {
    width: 30px;
    margin: 6px 20px 0 0;
}

/* Order Details Drawer Styles */
#analysisModalDrawer {
    z-index: 9999;
}
.order-drawer {
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    z-index: 9999;
    display: none;
}

.order-drawer.active {
    display: block;
}

.order-drawer-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    opacity: 0;
    transition: opacity 0.3s ease;
}

.order-drawer.active .order-drawer-overlay {
    opacity: 1;
}

.order-drawer-content {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    max-width: 600px;
    height: 100%;
    background: #fff;
    box-shadow: -2px 0 10px rgba(0, 0, 0, 0.1);
    transform: translateX(100%);
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
}

.order-drawer.active .order-drawer-content {
    transform: translateX(0);
}

.order-drawer-header {
    padding: 20px;
    border-bottom: 1px solid #e9ecef;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #f8f9fa;
}

.btn-close-drawer {
    background: none;
    border: none;
    font-size: 24px;
    color: #6c757d;
    cursor: pointer;
    padding: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    transition: all 0.2s;
}

.btn-close-drawer:hover {
    background: #e9ecef;
    color: #000;
}

.order-drawer-body {
    flex: 1;
    overflow-y: auto;
    padding: 20px;
}

@media (max-width: 768px) {
    .order-drawer-content {
        max-width: 100%;
    }
}

/* Order Drawer Icon Color */
.order-drawer-header .fa-receipt {
    color: #00ab8d;
}

.coa-analysis-list {
    list-style: none;
    padding-left: 0;
 }
 .coa-analysis-list li {
    padding: 5px 0 5px 25px;
    position: relative;
 }
 .coa-analysis-list li:before {
    content: "★";
    position: absolute;
    left: 0;
    color:#e300d3;
 }

/* Enhanced Expertise Description Styles */
.expertise-intro-text {
    font-size: 16px;
    line-height: 1.8;
    color: #4a5568;
    margin-bottom: 25px;
}

.expertise-features-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    margin-bottom: 30px;
}

.expertise-feature-item {
    background: #f8f9fa;
    border-radius: 12px;
    padding: 20px;
    display: flex;
    gap: 15px;
    transition: all 0.3s ease;
    border: 1px solid #e9ecef;
    position: relative;
    overflow: hidden;
}

.expertise-feature-item::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: linear-gradient(180deg, #0452a7 0%, #0E63FF 100%);
    transform: scaleY(0);
    transition: transform 0.3s ease;
}

.expertise-feature-item:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 25px rgba(4, 82, 167, 0.12);
    border-color: #0452a7;
    background: #ffffff;
}

.expertise-feature-item:hover::before {
    transform: scaleY(1);
}

.feature-number {
    width: 40px;
    height: 40px;
    min-width: 40px;
    background: linear-gradient(135deg, #0452a7 0%, #0E63FF 100%);
    color: #ffffff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 18px;
    box-shadow: 0 4px 12px rgba(4, 82, 167, 0.25);
    transition: all 0.3s ease;
}

.expertise-feature-item:hover .feature-number {
    transform: scale(1.1) rotate(5deg);
    box-shadow: 0 6px 18px rgba(4, 82, 167, 0.35);
}

.feature-content {
    flex: 1;
}

.feature-title {
    font-size: 18px;
    color: #0452a7;
    margin-bottom: 10px;
    margin-top: 0;
}

.feature-content p {
    font-size: 15px;
    line-height: 1.7;
    color: #4a5568;
    margin-bottom: 0;
}

.expertise-capabilities-list {
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin-top: 20px;
}

.capability-item {
    background: #ffffff;
    border: 1px solid #e9ecef;
    border-radius: 10px;
    padding: 20px;
    display: flex;
    align-items: flex-start;
    gap: 20px;
    transition: all 0.3s ease;
    position: relative;
}

.capability-item:hover {
    transform: translateX(5px);
    box-shadow: 0 5px 20px rgba(4, 82, 167, 0.1);
    border-color: #0452a7;
}

.capability-icon {
    width: 50px;
    height: 50px;
    min-width: 50px;
    background: linear-gradient(135deg, rgba(4, 82, 167, 0.1) 0%, rgba(14, 99, 255, 0.1) 100%);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}

.capability-icon i {
    font-size: 24px;
    color: #0452a7;
    transition: all 0.3s ease;
}

.capability-item:hover .capability-icon {
    background: linear-gradient(135deg, #0452a7 0%, #0E63FF 100%);
    transform: scale(1.1);
}

.capability-item:hover .capability-icon i {
    color: #ffffff;
}

.capability-content {
    flex: 1;
}

.capability-title {
    font-size: 17px;
    color: #2c3e50;
    margin-bottom: 8px;
    margin-top: 0;
    transition: color 0.3s ease;
}

.capability-item:hover .capability-title {
    color: #0452a7;
}

.capability-content p {
    font-size: 15px;
    line-height: 1.7;
    color: #4a5568;
    margin-bottom: 0;
}

@media (max-width: 991px) {
    .expertise-features-grid {
        grid-template-columns: 1fr;
        gap: 18px;
    }
    
    .expertise-feature-item {
        padding: 18px;
    }
    
    .feature-number {
        width: 36px;
        height: 36px;
        min-width: 36px;
        font-size: 16px;
    }
    
    .capability-item {
        padding: 18px;
    }
    
    .capability-icon {
        width: 45px;
        height: 45px;
        min-width: 45px;
    }
    
    .capability-icon i {
        font-size: 22px;
    }
}

@media (max-width: 767px) {
    .expertise-intro-text {
        font-size: 15px;
        margin-bottom: 20px;
    }
    
    .expertise-features-grid {
        gap: 15px;
        margin-bottom: 25px;
    }
    
    .expertise-feature-item {
        padding: 15px;
        flex-direction: column;
        text-align: center;
    }
    
    .feature-number {
        margin: 0 auto;
    }
    
    .feature-title {
        font-size: 16px;
    }
    
    .feature-content p {
        font-size: 14px;
    }
    
    .capability-item {
        padding: 15px;
        flex-direction: column;
        text-align: center;
    }
    
    .capability-icon {
        margin: 0 auto;
    }
    
    .capability-title {
        font-size: 16px;
    }
    
    .capability-content p {
        font-size: 14px;
    }
}


.our-expertises-section .services-item-gsp-title{ font-size: 20px; }
.expertise-page-container { 
    background: #f8fdff;
    border: 1px solid #d8e2e7;
    box-shadow: 0 0 6px #afd1de;
    padding: 40px;
 }

 h6.content-sub-title{ font-weight: normal !important; }
 a.research-item__btn.readmore{ 
    font-size: 10px;
    padding: 2px 10px;
    text-transform: none !important;
 }
 a.research-item__btn.readmore:hover{
    color: #ffffff !important;
    background-color: var(--gp-site-primary) !important;
 }
 #our-expertises .services-item{ background-color: transparent !important; }

/* Highlights – two-column layout */
.gpt-highlights-section {
  --gpt-accent: var(--gp-site-primary, #0c53a5);
  --gpt-heading: var(--gp-heading-primary, #171151);
  --gpt-text: #1e293b;
  --gpt-muted: #64748b;
  padding: 0;
}

.gpt-highlights-row {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  min-height: 440px;
  border-radius: 0 0 0 16px;
  overflow: hidden;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12);
}

.gpt-highlights-panel {
 
  background: linear-gradient(165deg, #0d3a6b 0%, #0c53a5 50%, #1e5ba8 100%);
  padding: 2.5rem 2rem;
  position: relative;
  border-radius: 0 0 0 16px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.gpt-highlights-indicators button{
    background-color: #656565 !important;
}

.gpt-highlights-indicators button.active{
    background-color: var(--gp-site-primary) !important;
}

.gpt-highlights-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23ffffff' fill-opacity='0.04' d='M20 18h-2v-2h2v2zm0 4h-2v-2h2v2zm0-12h-2V8h2v2zm4 8h-2v-2h2v2zm0-8h-2V8h2v2zm4 8h-2v-2h2v2zm0-8h-2V8h2v2z'/%3E%3C/svg%3E");
  pointer-events: none;
}

.gpt-highlights-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.45rem 1.1rem;
  background: rgba(125, 211, 252, 0.95);
  color: #0c4a6e;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 50px;
  margin-bottom: 1.25rem;
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.4);
  position: relative;
  width: fit-content;
}

.gpt-highlights-badge i {
  font-size: 0.9rem;
  color: #0369a1;
}

.gpt-highlights-heading {
  font-size: 2rem;
  color: #fff;
  margin: 0 0 0.6rem 0;
  letter-spacing: -0.02em;
  line-height: 1.2;
  position: relative;
}

.gpt-highlights-subtitle {
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.9);
  margin: 0;
  font-weight: 500;
  line-height: 1.5;
  position: relative;
}

.gpt-highlights-carousel-wrap {
  flex: 1;
  min-width: 0;
  min-height: 440px;
  position: relative;
}

.gpt-highlights-carousel {
  height: 440px;
  overflow: hidden;
  border-radius: 0;
  position: relative;
}

.gpt-highlights-inner,
.gpt-highlights-item {
  height: 100%;
}

.gpt-highlights-item {
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.gpt-highlights-carousel .carousel-item-next,
.gpt-highlights-carousel .active.carousel-item-end {
  transform: translateY(100%);
}

.gpt-highlights-carousel .carousel-item-prev,
.gpt-highlights-carousel .active.carousel-item-start {
  transform: translateY(-100%);
}

.gpt-highlights-card {
  height: 100%;
  padding: 2rem 2rem 3.25rem;
  background: #fff;
  border-left: 5px solid var(--gpt-accent);
  overflow-y: auto;
  border-radius: 0 16px 16px 0;
}

.gpt-highlights-card-title {
  font-size: 1.1rem;
  color: var(--gpt-heading);
  margin: 0 0 1.25rem 0;
  line-height: 1.4;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.4rem 0.5rem;
}

.gpt-slide-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 8px;
  background: var(--gpt-accent);
  color: #fff;
  font-size: 0.9rem;
  flex-shrink: 0;
}

.gpt-point {
  margin-bottom: 1rem;
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
}

.gpt-point-icon {
  color: var(--gpt-accent);
  font-size: 0.8rem;
  margin-top: 0.5rem;
  flex-shrink: 0;
}

.gpt-point-content {
  flex: 1;
  min-width: 0;
}

.gpt-point strong {
  display: block;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--gpt-text);
  margin-bottom: 0.15rem;
}

.gpt-point p,
.gpt-point ul {
  margin: 0;
  font-size: 0.875rem;
  line-height: 1.6;
  color: var(--gpt-muted);
}

.gpt-point ul {
  padding-left: 1.25rem;
}

.gpt-simple-list {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.gpt-simple-list li {
  position: relative;
  padding-left: 1.4rem;
  margin-bottom: 0.5rem;
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--gpt-text);
}

.gpt-simple-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5rem;
  width: 6px;
  height: 6px;
  background: var(--gpt-accent);
}

.gpt-highlights-indicators {
  bottom: 1rem;
  display: flex;
  justify-content: center;
  gap: 0.4rem;
}

.gpt-highlights-indicators button {
  width: 10px !important;
  height: 10px !important;
  border-radius: 50% !important;
  background: #cbd5e1;
  border: none !important;
  transition: background 0.2s, transform 0.2s;
}

.gpt-highlights-indicators button.active {
  background: var(--gpt-accent);
  transform: scale(1.1);
  width: 10px !important;
  height: 10px !important;
  border-radius: 50% !important;
}

@media (max-width: 991px) {
  .gpt-highlights-row {
    flex-direction: column;
    min-height: 0;
    border-radius: 16px;
  }
  .gpt-highlights-panel {
    flex: 0 0 auto;
    padding: 2rem 1.5rem;
    border-radius: 16px 16px 0 0;
    text-align: center;
  }
  .gpt-highlights-badge {
    margin-left: auto;
    margin-right: auto;
  }
  .gpt-highlights-carousel-wrap {
    min-height: 380px;
  }
  .gpt-highlights-carousel {
    height: 380px;
  }
  .gpt-highlights-card {
    border-radius: 0 0 16px 16px;
    padding: 1.5rem 1.5rem 2.75rem;
  }
}

@media (max-width: 576px) {
  .gpt-highlights-panel {
    flex: 0 0 280px;
    padding: 1.5rem 1rem;
  }
  .gpt-highlights-heading {
    font-size: 1.5rem;
  }
  .gpt-highlights-subtitle {
    font-size: 0.875rem;
  }
  .gpt-highlights-carousel {
    height: 340px;
  }
  .gpt-highlights-carousel-wrap {
    min-height: 340px;
  }
}

/* Highlights - end */
.text-purple { color: #960097 !important; }
.gsp-synthesis-detail .gsp-syn-title{ color: #0452a7; }
.gsp-synthesis-detail{ background: #f7f7ff; }
.gsp-synthesis-detail .gsp-syn-card{ border-top: 4px solid #0452a7; }
.gsp-synthesis-detail .gsp-syn-card .capability-icon i{ font-size: 1.35rem; color: #0452a7; }
.gsp-synthesis-detail .expertise-capabilities-list .row{ margin-top: 0; }
.gsp-synthesis-detail .gsp-list-item{ padding: 0.3rem 0.75rem; margin: 0 -0.75rem; }
.gsp-synthesis-detail .gsp-list-item:last-child{ border-bottom: 0; }
.gsp-synthesis-detail .gsp-list-item i, .gsp-synthesis-detail .gsp-list-item:hover i{ width: 1.25rem; color: #0452a7; margin-top: 0.15rem; }
.gsp-synthesis-detail .gsp-why-card{ background: linear-gradient(135deg, #f8fdff 0%, #e8f4fc 100%); border: 1px solid #d0e5f5; }
.gsp-synthesis-detail .capability-item:hover .capability-icon i{ color: #fff !important; }

.services-bgs .capability-item,
.services-bgs .trans-card{ background-color: #ffffff38 !important; border-top: none; box-shadow: 0 0 7px #5f5f5f !important; }
.services-bgs .capability-item ul li{ font-size: 16px; }


.about-banner-part.breadcrumb_overlay .banner-overlay {
    position: absolute;
    content: "";
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: rgb(23 17 81 / 14%);
    z-index: 0;
 }
.about-banner-part.breadcrumb_overlay .gsp-breadcrumb{ position: absolute; bottom: 30%; padding: 20px; }

/* about-banner.jpeg is 1536×1024 (3:2); same aspect as the box so cover = full width, full image, no crop */
.about-banner-part.breadcrumb_area{ padding-top: 0; padding-bottom: 0; }
.about-banner-part.breadcrumb_overlay{
    width: 100%;
    z-index: 1; 
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

@media (max-width: 768px) {
.about-banner-part.breadcrumb_overlay .gsp-breadcrumb_title{ font-size: 17px; }
}

.content-bg{
    position: absolute !important;
    height: 100%;
    width: 100%;
    top: 0;
    z-index: -2;
    background-repeat: no-repeat;
    background-size: cover;
}

/* --- Carousel: two-col-data-banner (left / right column alignment) --- */
.two-col-data-banner {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-around;
    align-items: center;
    gap: clamp(0.75rem, 2vw, 1.5rem);
    padding: clamp(0.75rem, 2.5vw, 2rem) clamp(1rem, 4vw, 2.75rem);
    pointer-events: none;
}

.two-col-data-banner > * {
    pointer-events: auto;
}

/* Plain columns (no carousel-caption-centered): same banner card treatment */
.two-col-data-banner > .banner-data-left:not(.carousel-caption-centered),
.two-col-data-banner > .banner-data-right:not(.carousel-caption-centered) {
    position: relative;
    flex: 0 1 min(47%, 26rem);
    max-width: min(47%, 26rem);
    padding: clamp(1.15rem, 2.4vw, 1.65rem) clamp(1.2rem, 2.6vw, 1.55rem);
    text-align: left;
    color: #fff;
    background: linear-gradient(
        155deg,
        rgba(13, 58, 107, 0.92) 0%,
        rgba(12, 83, 165, 0.88) 45%,
        rgba(18, 72, 128, 0.84) 100%
    );
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow:
        0 18px 50px rgba(0, 18, 56, 0.42),
        0 6px 16px rgba(0, 0, 0, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.2);
    overflow: hidden;
}

.two-col-data-banner > .banner-data-left:not(.carousel-caption-centered) {
    border-left: 4px solid rgba(125, 211, 252, 0.95);
}

.two-col-data-banner > .banner-data-right:not(.carousel-caption-centered) {
    border-right: 4px solid rgba(125, 211, 252, 0.95);
}

.two-col-data-banner > .banner-data-left:not(.carousel-caption-centered) .gpt-highlights-card-title,
.two-col-data-banner > .banner-data-right:not(.carousel-caption-centered) .gpt-highlights-card-title {
    position: relative;
    z-index: 1;
    color: #fff;
    font-size: clamp(1.02rem, 1.5vw, 1.2rem);
    font-weight: 600;
    margin: 0 0 1rem 0;
    padding-bottom: 0.85rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.14);
}

.two-col-data-banner > .banner-data-left:not(.carousel-caption-centered) .gpt-slide-icon,
.two-col-data-banner > .banner-data-right:not(.carousel-caption-centered) .gpt-slide-icon {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.two-col-data-banner > .banner-data-left:not(.carousel-caption-centered) .gpt-simple-list,
.two-col-data-banner > .banner-data-right:not(.carousel-caption-centered) .gpt-simple-list {
    position: relative;
    z-index: 1;
}

.two-col-data-banner > .banner-data-left:not(.carousel-caption-centered) .gpt-simple-list li,
.two-col-data-banner > .banner-data-right:not(.carousel-caption-centered) .gpt-simple-list li {
    color: rgba(241, 245, 255, 0.94);
    font-size: clamp(0.86rem, 1.15vw, 0.95rem);
    margin-bottom: 0.55rem;
    line-height: 1.55;
}

.two-col-data-banner > .banner-data-left:not(.carousel-caption-centered) .gpt-simple-list li:last-child,
.two-col-data-banner > .banner-data-right:not(.carousel-caption-centered) .gpt-simple-list li:last-child {
    margin-bottom: 0;
}

.two-col-data-banner > .banner-data-left:not(.carousel-caption-centered) .gpt-simple-list li::before,
.two-col-data-banner > .banner-data-right:not(.carousel-caption-centered) .gpt-simple-list li::before {
    background: linear-gradient(135deg, #7dd3fc 0%, #38bdf8 100%);
    box-shadow: 0 0 0 2px rgba(12, 83, 165, 0.35);
    top: 0.55rem;
}

/* When columns use carousel-caption-centered: exit absolute centering so flex can place left/right */
.two-col-data-banner > .carousel-caption-centered {
    position: relative;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto;
    transform: none;
    flex: 0 1 min(47%, 26rem);
    max-width: min(47%, 26rem);
    width: 100%;
    height: auto;
    min-height: 0;
    margin: 0;
    opacity: 1;
    animation: none !important;
    justify-content: flex-start;
    padding: clamp(1.15rem, 2.4vw, 1.65rem) clamp(1.2rem, 2.6vw, 1.55rem);
    background: linear-gradient(
        155deg,
        rgba(13, 58, 107, 0.92) 0%,
        rgba(12, 83, 165, 0.88) 45%,
        rgba(18, 72, 128, 0.84) 100%
    );
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.14);
    box-shadow:
        0 18px 50px rgba(0, 18, 56, 0.42),
        0 6px 16px rgba(0, 0, 0, 0.18),
        inset 0 1px 0 rgba(255, 255, 255, 0.2);
    overflow: hidden;
}

.carousel-item.active .two-col-data-banner > .carousel-caption-centered {
    animation: none !important;
}

.two-col-data-banner > .banner-data-left.carousel-caption-centered {
    text-align: left;
    align-items: flex-start;
}

.two-col-data-banner > .banner-data-right.carousel-caption-centered {
    text-align: left;
    align-items: flex-start;
}

.two-col-data-banner > .carousel-caption-centered .gpt-highlights-card-title {
    position: relative;
    z-index: 1;
    color: #fff;
    font-size: 1.2rem;
    font-weight: normal;
    margin: 0 0 1rem 0;
    padding-bottom: 0.85rem;
    width: 100%;
    border-bottom: 1px solid rgba(255, 255, 255, 0.14);
    letter-spacing: -0.01em;
    line-height: 1.35;
    text-shadow: none;
}

.two-col-data-banner > .carousel-caption-centered .gpt-slide-icon {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.two-col-data-banner > .carousel-caption-centered .gpt-simple-list {
    position: relative;
    z-index: 1;
    width: 100%;
}

.two-col-data-banner > .carousel-caption-centered .gpt-simple-list li {
    color: rgba(241, 245, 255, 0.94);
    margin-bottom: 0.55rem;
    font-size: clamp(0.86rem, 1.15vw, 0.95rem);
    line-height: 1.55;
}

.two-col-data-banner > .carousel-caption-centered .gpt-simple-list li:last-child {
    margin-bottom: 0;
}

.two-col-data-banner > .carousel-caption-centered .gpt-simple-list li::before {
    background: linear-gradient(135deg, #7dd3fc 0%, #38bdf8 100%);
    box-shadow: 0 0 0 2px rgba(12, 83, 165, 0.35);
    top: 0.55rem;
}

@media (max-width: 992px) {
    .two-col-data-banner {
        flex-wrap: wrap;
        justify-content: space-between;
        align-items: flex-start;
        align-content: center;
    }

    .two-col-data-banner > .banner-data-left:not(.carousel-caption-centered),
    .two-col-data-banner > .banner-data-right:not(.carousel-caption-centered),
    .two-col-data-banner > .carousel-caption-centered {
        flex: 1 1 calc(50% - 0.5rem);
        max-width: calc(50% - 0.5rem);
        min-width: 0;
    }
}

@media (max-width: 768px) {
    .two-col-data-banner {
        flex-direction: column;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: stretch;
        gap: 1rem;
        padding: 1rem 1rem 1.25rem;
    }

    .two-col-data-banner > .banner-data-left:not(.carousel-caption-centered),
    .two-col-data-banner > .banner-data-right:not(.carousel-caption-centered),
    .two-col-data-banner > .carousel-caption-centered {
        flex: 1 1 auto;
        max-width: 100%;
        width: 100%;
        margin-left: 0;
        margin-right: 0;
    }
}

@media (max-width: 576px) {
    .two-col-data-banner > .banner-data-left:not(.carousel-caption-centered),
    .two-col-data-banner > .banner-data-right:not(.carousel-caption-centered),
    .two-col-data-banner > .carousel-caption-centered {
        padding: 1rem 1rem;
    }

    .two-col-data-banner .gpt-highlights-card-title {
        font-size: 1rem;
    }

    .two-col-data-banner .gpt-simple-list li {
        font-size: 0.85rem;
    }
}

/* ========== #carouselExampleCaptions (homepage hero only): responsive banner ==========
   Scoped by ID; does not change global .carousel-img / .carousel-caption-centered. */
#carouselExampleCaptions {
    position: relative;
    overflow: hidden;
}

#carouselExampleCaptions .carousel-item {
    position: relative;
}

/* Fluid slide image height (overrides generic .carousel-img only here) */
#carouselExampleCaptions .carousel-img {
    width: 100%;
    display: block;
    /* height: clamp(270px, 80vh, 670px);
    max-height: min(670px, 80vh); */
    height:calc(100vh - 90px);
    object-fit: cover;
    object-position: center;
}

/* Slides 1–3: direct caption — not fixed 50vh; fits small laptops & phones */
#carouselExampleCaptions .carousel-item > .carousel-caption-centered {
    width: min(92%, 840px);
    max-width: 92%;
    height: auto;
    min-height: 0;
    max-height: min(78vh, calc(100% - 1rem));
    overflow-x: hidden;
    overflow-y: auto;
    padding: clamp(1rem, 2.8vw, 2.25rem) clamp(1rem, 3.5vw, 1.75rem);
    box-sizing: border-box;
    -webkit-overflow-scrolling: touch;
}

#carouselExampleCaptions .carousel-item > .carousel-caption-centered .slider-content-title {
    font-size: clamp(1.3rem, calc(2.2vw + 0.9rem), 2.85rem);
    line-height: 1.2;
}

#carouselExampleCaptions .carousel-item > .carousel-caption-centered .slider-content-text {
    font-size: clamp(0.88rem, calc(1.1vw + 0.55rem), 1.22rem);
    line-height: 1.55;
}

#carouselExampleCaptions .carousel-item > .carousel-caption-centered .slider-content-title.mb-45 {
    margin-bottom: clamp(0.65rem, 2vw, 2.5rem);
}

/* ~13" / small laptop */
@media (max-width: 1440px) {
    #carouselExampleCaptions .carousel-img {
        height: clamp(210px, 50vh, 540px);
        max-height: min(540px, 70vh);
    }

    #carouselExampleCaptions .carousel-item > .carousel-caption-centered {
        max-height: min(76vh, calc(100% - 0.75rem));
    }
}

@media (max-width: 1200px) {
    #carouselExampleCaptions .carousel-img {
        height: clamp(200px, 48vh, 480px);
        max-height: min(480px, 66vh);
    }

    #carouselExampleCaptions .carousel-item > .carousel-caption-centered {
        width: min(94%, 720px);
    }
}

/* Tablet */
@media (max-width: 992px) {
    #carouselExampleCaptions .carousel-img {
        height: clamp(195px, 44vh, 420px);
        max-height: min(420px, 60vh);
    }

    #carouselExampleCaptions .carousel-item > .carousel-caption-centered {
        width: min(94%, 640px);
        padding: clamp(0.9rem, 2.5vw, 1.65rem) clamp(0.85rem, 3vw, 1.35rem);
        max-height: min(74vh, calc(100% - 0.5rem));
    }

    #carouselExampleCaptions .carousel-control-prev,
    #carouselExampleCaptions .carousel-control-next {
        width: 11%;
        min-width: 2.75rem;
    }

    #carouselExampleCaptions .two-col-data-banner {
        padding: clamp(0.5rem, 2vw, 1.15rem) clamp(0.65rem, 3vw, 1.15rem);
        gap: clamp(0.4rem, 1.5vw, 0.9rem);
        justify-content: space-between;
    }

    #carouselExampleCaptions .two-col-data-banner > .carousel-caption-centered {
        flex: 1 1 calc(50% - 0.35rem);
        max-width: calc(50% - 0.35rem);
        min-width: 0;
        padding: clamp(0.75rem, 2vw, 1.2rem) clamp(0.65rem, 2vw, 1rem);
    }
}

/* Mobile */
@media (max-width: 768px) {
    #carouselExampleCaptions .carousel-img {
        height: clamp(175px, 38vh, 340px);
        max-height: min(340px, 54vh);
    }

    #carouselExampleCaptions .carousel-item > .carousel-caption-centered {
        width: min(96%, 100%);
        padding: clamp(0.7rem, 2.2vw, 1.2rem) clamp(0.6rem, 2.5vw, 1rem);
        max-height: min(70vh, calc(100% - 0.45rem));
    }

    #carouselExampleCaptions .carousel-item > .carousel-caption-centered .slider-content-title {
        font-size: clamp(1.15rem, calc(1.8vw + 0.85rem), 1.85rem);
    }

    #carouselExampleCaptions .carousel-item > .carousel-caption-centered .slider-content-text {
        font-size: clamp(0.82rem, calc(0.9vw + 0.5rem), 1.05rem);
    }

    #carouselExampleCaptions .carousel-indicators {
        margin-bottom: 0.35rem;
        padding-left: 0;
        padding-right: 0;
    }

    #carouselExampleCaptions .carousel-control-prev,
    #carouselExampleCaptions .carousel-control-next {
        width: 12%;
        min-width: 2.5rem;
    }

    #carouselExampleCaptions .two-col-data-banner {
        flex-direction: column;
        flex-wrap: nowrap;
        justify-content: flex-start;
        align-items: stretch;
        align-content: stretch;
        padding: 0.6rem 0.6rem 0.75rem;
        gap: 0.6rem;
        overflow-y: auto;
        max-height: 100%;
        box-sizing: border-box;
    }

    #carouselExampleCaptions .two-col-data-banner > .carousel-caption-centered {
        flex: 1 1 auto;
        max-width: 100%;
        width: 100%;
    }
}

@media (max-width: 576px) {
    #carouselExampleCaptions .carousel-img {
        height: clamp(150px, 34vh, 280px);
        max-height: min(280px, 50vh);
    }

    #carouselExampleCaptions .carousel-item > .carousel-caption-centered {
        width: 94%;
        padding: 0.65rem 0.55rem;
    }

    #carouselExampleCaptions .carousel-item > .carousel-caption-centered .slider-content-text br {
        display: none;
    }

    #carouselExampleCaptions .two-col-data-banner > .carousel-caption-centered {
        padding: 0.7rem 0.65rem;
    }

    #carouselExampleCaptions .two-col-data-banner .gpt-highlights-card-title {
        font-size: 0.95rem;
    }

    #carouselExampleCaptions .two-col-data-banner .gpt-simple-list li {
        font-size: 0.8rem;
    }
}

/* Short landscape (phones / small laptops): keep hero usable */
@media (max-height: 520px) and (orientation: landscape) {
    #carouselExampleCaptions .carousel-img {
        height: clamp(110px, 36vh, 220px);
        max-height: 220px;
    }

    #carouselExampleCaptions .carousel-item > .carousel-caption-centered {
        max-height: min(52vh, 200px);
        padding: 0.45rem 0.65rem;
    }

    #carouselExampleCaptions .two-col-data-banner {
        padding: 0.4rem 0.5rem;
        gap: 0.45rem;
    }
}

/* --- Homepage statistics strip --- */
.gsp-stats-section {
    position: relative;
    padding: 4.25rem 0 4.75rem;
    background: linear-gradient(165deg, #f8fafc 0%, #ffffff 38%, #f1f5f9 100%);
    overflow: hidden;
}

.gsp-stats-section::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
    background: linear-gradient(
        90deg,
        var(--gp-heading-primary, #171151) 0%,
        var(--gp-site-primary, #0c53a5) 45%,
        #38bdf8 100%
    );
    opacity: 0.92;
}

.gsp-stats-section::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 50% at 50% -20%, rgba(12, 83, 165, 0.08), transparent 55%);
    pointer-events: none;
}

.gsp-stats-section .container {
    z-index: 1;
}

.gsp-stats-intro {
    max-width: 36rem;
}

.gsp-stats-item {
    position: relative;
    height: 100%;
    padding: 1.65rem 1.2rem 1.75rem;
    text-align: center;
    background: #fff;
    border-radius: 16px;
    border: 1px solid rgba(12, 83, 165, 0.12);
    box-shadow:
        0 4px 6px -1px rgba(23, 17, 81, 0.05),
        0 12px 36px -8px rgba(12, 83, 165, 0.1);
    transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
}

.gsp-stats-item:hover {
    transform: translateY(-5px);
    border-color: rgba(12, 83, 165, 0.22);
    box-shadow:
        0 12px 24px -6px rgba(23, 17, 81, 0.08),
        0 22px 48px -12px rgba(12, 83, 165, 0.18);
}

.gsp-stats-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3.5rem;
    height: 3.5rem;
    margin: 0 auto 1.1rem;
    font-size: 1.3rem;
    color: #fff;
    border-radius: 14px;
    background: linear-gradient(145deg, #0d3a6b 0%, var(--gp-site-primary, #0c53a5) 55%, #1e5ba8 100%);
    box-shadow: 0 10px 28px rgba(12, 83, 165, 0.38);
}

.gsp-stats-value {
    margin: 0 0 0.55rem;
    font-size: clamp(1.85rem, 2.8vw, 2.45rem);
    font-weight: 700;
    line-height: 1.1;
    letter-spacing: -0.02em;
    color: var(--gp-heading-primary, #171151);
    background: linear-gradient(135deg, #171151 0%, #0c53a5 55%, #1e40af 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

@supports not ((-webkit-background-clip: text) or (background-clip: text)) {
    .gsp-stats-value {
        background: none;
        -webkit-text-fill-color: unset;
        color: var(--gp-heading-primary, #171151);
    }
}

.gsp-stats-label {
    margin: 0;
    font-size: 0.7rem;
    font-weight: 600;
    line-height: 1.5;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: #64748b;
}

@media (max-width: 991px) {
    .gsp-stats-section {
        padding: 3.25rem 0 3.75rem;
    }
}

@media (max-width: 575px) {
    .gsp-stats-item {
        padding: 1.35rem 1rem 1.45rem;
    }

    .gsp-stats-icon {
        width: 3.1rem;
        height: 3.1rem;
        font-size: 1.15rem;
        margin-bottom: 0.95rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .gsp-stats-item {
        transition: none;
    }

    .gsp-stats-item:hover {
        transform: none;
    }
}

/* --- Newsletter area: dark blue feature strip (4 columns) --- */
.gsp-feature-strip {
    position: relative;
    padding: 2.35rem 1rem 2.5rem;
    overflow: hidden;
    text-align: center;
    border-radius: 14px;
    background: linear-gradient(165deg, #0a2744 0%, var(--gp-site-primary, #0c53a5) 48%, #061a2e 100%);
    box-shadow: 0 18px 50px rgba(7, 26, 46, 0.35);
}

.gsp-feature-strip::before {
    content: "";
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='%23ffffff' fill-opacity='0.06' d='M20 18h-2v-2h2v2zm0 4h-2v-2h2v2zm0-12h-2V8h2v2zm4 8h-2v-2h2v2zm0-8h-2V8h2v2zm4 8h-2v-2h2v2zm0-8h-2V8h2v2z'/%3E%3C/svg%3E");
    pointer-events: none;
    opacity: 0.9;
}

.gsp-feature-strip__inner {
    position: relative;
    z-index: 1;
    max-width: 17rem;
    margin-left: auto;
    margin-right: auto;
    padding-left: 0.35rem;
    padding-right: 0.35rem;
}

@media (min-width: 992px) {
    .gsp-feature-strip__col:not(:last-child) .gsp-feature-strip__inner {
        border-right: 1px solid rgba(255, 255, 255, 0.2);
        padding-right: 1.5rem;
        margin-right: 0;
        max-width: none;
    }

    .gsp-feature-strip__col:not(:first-child) .gsp-feature-strip__inner {
        padding-left: 1.5rem;
    }

    .gsp-feature-strip__col:first-child .gsp-feature-strip__inner {
        padding-left: 0.35rem;
    }
}

.gsp-feature-strip__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3.1rem;
    height: 3.1rem;
    margin: 0 auto 1rem;
    font-size: 1.15rem;
    color: #fff;
    border-radius: 50%;
    border: 1px solid rgba(255, 255, 255, 0.38);
    background: rgba(255, 255, 255, 0.08);
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08);
}

.gsp-feature-strip__title {
    margin: 0 0 0.45rem;
    font-size: 1.05rem;
    font-weight: 700;
    line-height: 1.35;
    color: #fff;
    letter-spacing: 0.01em;
}

.gsp-feature-strip__text {
    margin: 0;
    font-size: 0.875rem;
    line-height: 1.55;
    color: rgba(255, 255, 255, 0.9);
}

@media (max-width: 991px) {
    .gsp-feature-strip {
        padding: 2rem 0.85rem;
    }

    .gsp-feature-strip__col:not(:last-child) .gsp-feature-strip__inner {
        padding-bottom: 1.25rem;
        margin-bottom: 0.25rem;
        border-bottom: 1px solid rgba(255, 255, 255, 0.14);
    }

    .gsp-feature-strip__col:last-child .gsp-feature-strip__inner {
        padding-bottom: 0;
        margin-bottom: 0;
        border-bottom: none;
    }
}

@media (max-width: 575px) {
    .gsp-feature-strip {
        border-radius: 12px;
        padding: 1.65rem 0.65rem;
    }

    .gsp-feature-strip__title {
        font-size: 1rem;
    }

    .gsp-feature-strip__text {
        font-size: 0.82rem;
    }
}

.data-count-strip{
    background-image: url("assets/img/shape/shape-bg-05.png");
    position: relative;
    padding: 2.35rem 1rem 2.5rem;
    overflow: hidden;
    text-align: center;
    background: linear-gradient(165deg, #0a2744 0%, var(--gp-site-primary, #0c53a5) 48%, #061a2e 100%);
    box-shadow: 0 18px 50px rgba(7, 26, 46, 0.35);
}

/* --- Homepage hero slide 4: glassmorphism lab banner (scoped to this item only) --- */
#carouselExampleCaptions .carousel-item.gsp-hero-glass-slide {
    position: relative;
}

#carouselExampleCaptions .gsp-hero-glass-slide__img {
    object-position: center 30%;
}

#carouselExampleCaptions .gsp-hero-glass-slide__stack {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    overflow: hidden;
}

#carouselExampleCaptions .gsp-hero-glass-slide__tint {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        165deg,
        rgba(8, 45, 88, 0.52) 0%,
        rgba(12, 83, 165, 0.4) 42%,
        rgba(6, 40, 78, 0.48) 100%
    );
}

#carouselExampleCaptions .gsp-hero-glass-slide__flare {
    position: absolute;
    inset: 0;
    background: radial-gradient(
        ellipse 125% 60% at 50% -8%,
        rgba(255, 255, 255, 0.42) 0%,
        rgba(186, 230, 253, 0.14) 38%,
        transparent 60%
    );
}

#carouselExampleCaptions .gsp-hero-glass-slide__bottom-glow {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 45%;
    background: radial-gradient(
        ellipse 110% 75% at 50% 100%,
        rgba(125, 211, 252, 0.24) 0%,
        transparent 58%
    );
}

#carouselExampleCaptions .gsp-hero-glass-slide__mesh {
    position: absolute;
    width: min(44%, 300px);
    height: min(40%, 260px);
    opacity: 0.38;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140' viewBox='0 0 140 140'%3E%3Cg stroke='%2338bdf8' stroke-width='0.7' fill='%2338bdf8'%3E%3Ccircle cx='12' cy='18' r='1.4'/%3E%3Ccircle cx='48' cy='10' r='1.4'/%3E%3Ccircle cx='82' cy='28' r='1.4'/%3E%3Ccircle cx='28' cy='52' r='1.4'/%3E%3Ccircle cx='62' cy='58' r='1.4'/%3E%3Ccircle cx='96' cy='72' r='1.4'/%3E%3Cline x1='12' y1='18' x2='48' y2='10'/%3E%3Cline x1='48' y1='10' x2='82' y2='28'/%3E%3Cline x1='12' y1='18' x2='28' y2='52'/%3E%3Cline x1='82' y1='28' x2='62' y2='58'/%3E%3Cline x1='28' y1='52' x2='96' y2='72'/%3E%3Cline x1='62' y1='58' x2='96' y2='72'/%3E%3C/g%3E%3C/svg%3E");
    background-size: 140px 140px;
    filter: drop-shadow(0 0 10px rgba(56, 189, 248, 0.45));
}

#carouselExampleCaptions .gsp-hero-glass-slide__mesh--tr {
    top: 3%;
    right: 1%;
}

#carouselExampleCaptions .gsp-hero-glass-slide__mesh--bl {
    bottom: 5%;
    left: 1%;
    transform: rotate(180deg);
}

.carousel-control-next, .carousel-control-prev, .carousel-indicators{ z-index: 3 !important; }

#carouselExampleCaptions .gsp-hero-glass-slide__content {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: clamp(0.55rem, 1.8vh, 1.35rem);
    padding: clamp(0.5rem, 1.8vw, 1.1rem) clamp(0.65rem, 3vw, 1.85rem) clamp(0.65rem, 2vw, 1.25rem);
    box-sizing: border-box;
    max-height: 100%;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

/* Entrance animation only on first paint (before first slide change). Re-applying on
   every .active toggle caused the glass cards to reset to opacity 0 and replay — read as flicker. */
#carouselExampleCaptions:not(.gsp-hero-content-static) .carousel-item.active .gsp-hero-glass-slide__content {
    animation: gspGlassSlideIn 0.85s ease 0.18s both;
}

@keyframes gspGlassSlideIn {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

#carouselExampleCaptions .gsp-hero-glass-slide__brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
    flex-shrink: 0;
}

#carouselExampleCaptions .gsp-hero-glass-slide__shield {
    width: clamp(42px, 7.5vw, 54px);
    height: auto;
    filter: drop-shadow(0 4px 16px rgba(0, 40, 90, 0.32));
}

#carouselExampleCaptions .gsp-hero-glass-slide__wordmark {
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1.12;
}

#carouselExampleCaptions .gsp-hero-glass-slide__wordmark-line {
    font-size: clamp(1rem, 2.3vw, 1.42rem);
    font-weight: 700;
    letter-spacing: 0.03em;
    color: #1a2b4b;
    text-shadow:
        0 0 20px rgba(255, 255, 255, 0.7),
        0 1px 0 rgba(255, 255, 255, 0.45);
}

#carouselExampleCaptions .gsp-hero-glass-slide__wordmark-line--sub {
    font-size: clamp(0.88rem, 1.9vw, 1.12rem);
    font-weight: 600;
}

#carouselExampleCaptions .gsp-hero-glass-slide__cards {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: center;
    gap: clamp(0.55rem, 1.8vw, 1.25rem);
    width: 100%;
    max-width: 1080px;
}

#carouselExampleCaptions .gsp-hero-glass-slide__card {
    flex: 1 1 min(48%, 22rem);
    /* max-width: min(48%, 22rem); */

    padding: clamp(0.8rem, 1.9vw, 1.2rem) clamp(0.9rem, 2vw, 1.3rem);
    /* background: rgba(255, 255, 255, 0.22); */
    background: rgb(233 233 233 / 60%);
    /* backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px); */
    border: 1px solid rgba(255, 255, 255, 0.85);
    border-radius: 14px;
    box-shadow:
        0 0 16px rgba(255, 255, 255, 0.5),
        0 0 36px rgba(56, 189, 248, 0.15),
        inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

#carouselExampleCaptions .gsp-hero-glass-slide__title {
    margin: 0 0 0.7rem 0;
    padding-bottom: 0.6rem;
    border-bottom: 1px solid rgba(26, 43, 75, 0.14);
    font-size: clamp(0.92rem, 1.8vw, 1.8rem);
    font-weight: 500;
    color: #000000;
    text-align: center;
    line-height: 1.32;
    text-shadow: 0 0 5px #ffffff;
}

#carouselExampleCaptions .gsp-hero-glass-slide__list {
    list-style: none;
    margin: 0;
    padding: 0 50px;
    text-align: left;
}

#carouselExampleCaptions .gsp-hero-glass-slide__list li {
    position: relative;
    position: relative;
    padding-left: 1.1rem;
    margin-bottom: 0.4rem;
    font-size: clamp(0.78rem, 1.55vw, 1.2rem);
    line-height: 1.48;
    color: #000000;
    font-weight: 500;
    text-shadow: 1px 0px 12px #ffffff;
}

#carouselExampleCaptions .gsp-hero-glass-slide__list li:last-child {
    margin-bottom: 0;
}

#carouselExampleCaptions .gsp-hero-glass-slide__list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.5em;
    width: 10px;
    height: 10px;
    background: linear-gradient(135deg, #38bdf8 0%, #1b1c1c 100%);
    box-shadow: 0 0 10px rgba(56, 189, 248, 0.8);
    border-radius: 1px;
}

@media (max-width: 992px) {
    #carouselExampleCaptions .gsp-hero-glass-slide__card {
        flex: 1 1 calc(50% - 0.4rem);
        max-width: calc(50% - 0.4rem);
        min-width: 0;
    }
}

@media (max-width: 768px) {
    #carouselExampleCaptions .gsp-hero-glass-slide__cards {
        flex-direction: column;
        flex-wrap: nowrap;
        align-items: stretch;
    }

    #carouselExampleCaptions .gsp-hero-glass-slide__card {
        flex: 1 1 auto;
        max-width: 100%;
    }

    #carouselExampleCaptions .gsp-hero-glass-slide__mesh {
        opacity: 0.26;
    }
}

@media (max-width: 576px) {
    #carouselExampleCaptions .gsp-hero-glass-slide__content {
        justify-content: flex-start;
        padding-top: 0.45rem;
    }

    #carouselExampleCaptions .gsp-hero-glass-slide__shield {
        width: 38px;
    }

    #carouselExampleCaptions .gsp-hero-glass-slide__title {
        font-size: 0.9rem;
    }

    #carouselExampleCaptions .gsp-hero-glass-slide__list li {
        font-size: 0.78rem;
    }
}

@media (max-height: 520px) and (orientation: landscape) {
    #carouselExampleCaptions .gsp-hero-glass-slide__brand {
        flex-direction: row;
        align-items: center;
        gap: 0.55rem;
    }

    #carouselExampleCaptions .gsp-hero-glass-slide__wordmark {
        align-items: flex-start;
    }
}

.services-overview-section .about-thumb-shape{ left: -50px; }

@media (max-width: 800px) {
    .as-thumb-2hx{
        width: 250px !important;
        left: 10px !important;
        bottom: -60px;
    }
}