*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    letter-spacing: 0;
    line-height: 1.6;
    margin: 0;
    scroll-behavior: smooth;
    min-height: 100vh;
    padding-bottom:2px;
}

img,
video,
iframe {
    max-width: 100%;
    height: auto;
}
:root {
    --color-primary: #00984A;
    --color-secondary-green: #146930;
    --color-accent: #65B32E;
    --color-secondary: #E6E24A;
    --color-danger: #D93025;
    --color-danger-text: #EA4335;
    --color-orange: #FFAB4B;
    --color-white: #FFFFFF;
    --color-black: #1D1D1B;
    --color-text: #1A1A1A;
    --color-text-secondary: #2A2A2A;
    --color-border: #BABDC1;
    --color-grey-bg: #F5F5F5;
    --color-badge: #DEE2E6;
    --color-grey: #7C7C7C;
    --bg-home: linear-gradient(66.85deg, #F8F9DB 35.66%, #E0F0D6 65.61%);
    --bg-gradient: linear-gradient(180deg, #E0F0D6 0%, #FFFFFF 100%);
    --bg-gradient-dark: linear-gradient(313.6deg, #EEF0C4 9.32%, #CEE5BD 53.4%);
    --bg-light: linear-gradient(180deg, #FFFFFF 13.56%, #F9F9DB 100%);
    --bg-light-gradient: linear-gradient(91.47deg, #FFFFFF 1.82%, #FFFEE0 100%);
    --bg-invert: linear-gradient(180deg, #F9F9DB 13.56%, #FFFFFF 100%);
    --bg-invert-blue: linear-gradient(180deg, #FFFFFF 0%, #E0F0D6 100%);
    --bg-banner: linear-gradient(90deg, #00984A 0%, rgba(0, 152, 74, 0) 78.16%);
    --bg-blue: linear-gradient(180deg, #FFFFFF 0%, #E0F0D6 100%);
    --btn-gradient: linear-gradient(360deg, #E6E24A 0%, #65B32E 100%);
    --green-gradient: radial-gradient(154.8% 170% at 50% -11.45%, #FFFFFF 0%, #00984A 100%);
    --card-header-bg: linear-gradient(91.47deg, #FFFFFF 1.82%, #FFFEE0 100%);
    --banner-bg: radial-gradient(50% 50% at 50% 50%, rgba(20, 105, 48, 0.8) 0%, rgba(101, 179, 46, 0.8) 100%);
    --bg-grey: #F8F8F6;
    --color-facebook: #1877F2;
    --color-x: #000000;
    --color-whatsapp: #25D366;
    --color-linkedin: #0077B5;
    --color-pinterest: #E60023;
    --shadow-card: 0px 4px 20px rgba(0, 0, 0, 0.05);
    --radius-sm: .5rem;
    --radius-md: 1rem;
    --radius-btn: .5rem;
    --space-xxs: .25rem;
    --space-xs: .5rem;
    --space-sm: .75rem;
    --space-md: 1rem;
    --space-lg: 1.5rem;
    --space-xl: 2rem;
    --space-fluid: clamp(.5rem, 2vw, 1.5rem);
    --header-height: 110px;
}

::-webkit-scrollbar {
    width: 3px;
}

::-webkit-scrollbar-track {
    background: rgba(0, 0, 0, 0.10);
}

::-webkit-scrollbar-thumb {
    background: var(--color-badge);

}

[data-animate] {
    opacity: 0;
    transform: scale(.95) translateY(30px);
    transition: all .5s ease-out
}

[data-animate].visible {
    opacity: 1;
    transform: scale(1) translateY(0)
}

[data-animate="fade-up"] {
    transform: translateY(30px)
}

[data-animate="fade-right"] {
    transform: translateX(-30px)
}

[data-animate="fade-left"] {
    transform: translateX(30px)
}

a {
    color: var(--color-black);
    text-decoration: underline;
}

a:hover,
a:active {
    color: var(--color-primary);
    text-decoration: underline;
}

.bg-light-section,
.bg-secondry-light-section,
.green-backgound,
.videos-section,
.blog-section,
.information-section,
.services-overview-section,
.lcm-section,
.why-metropolis-section,
.mobile-section {
    background: var(--bg-light);
}

.wellness-section {
    background: var(--bg-light) !important;
}

.gradient-section,
.csr-section,
.Collaborations-section {
    background: var(--bg-gradient);
}

.green-backgound {
    background: var(--green-gradient);
}

.clicn-section,
.test-regularly-section,
.home-test-banner {
    background-color: var(--color-accent);
}

.videos-section,
.values-section,
.test-conditions-section,
.bg-secondry-light-section,
.comprehensive-health-solutions-section,
.methodology-section {
    background: var(--bg-invert)
}

.dark-gradient-background {
    background: var(--bg-gradient-dark)
}

.bg-light-grey {
    background-color: #F8F8F6;
}

.platform-bg {
    background: url('../images/backgrounds/Layout-bg.webp') no-repeat center center;
    background-size: cover;
    background-attachment: fixed;
    color: var(--color-white)
}

.green-bg-section {
    background-color: var(--color-primary)
}

.gradient-section,
.bg-secondry-light-section,
.section-spacing,
.platform-bg,
.green-bg-section {
    padding: clamp(1rem, 6vw, 1.2rem) 0;
}

.light-bg-section {
    background-color: var(--color-white);
    padding: 1rem 0
}

.scrollable-container {
    max-height: 72vh;
    overflow-y: auto;
}

.section-img {
    width: 100%;
    height: clamp(12rem, 30vw, 22rem);
    object-fit: cover;
    border-radius: var(--radius-sm);
}

.min-w-300 {
    min-width: 300px;
}

.logo-xs {
    width: 5rem;
    height: auto;
}

.hero-carousel {
    background-color: var(--color-primary);
    position: relative;
    border-radius: 2rem;
    padding: 1.875rem clamp(1.25rem, 4vw, 1.25rem);
    margin: clamp(1rem, 3vw, 1.2rem);
    overflow: hidden;
    padding-top: calc(65px + 50px);
}

.hero-section .carousel,
.hero-section .carousel-inner,
.hero-section .carousel-item {
    height: 100%;
    /*  min-height: 380px; */
}

.hero-carousel-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
    align-items: center
}

/* .hero-responsive-img {
    width: 100%;
    height: auto;
    max-height: 650px;
    object-fit: contain;
} */
.hero-responsive-img {
    width: 100%;
    height: auto;
    object-fit: cover;
    max-height: 650px;
    border-radius: 1rem;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
}

.hero-peek-carousel .carousel-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: visible;
}

.hero-peek-carousel .carousel-item {
    flex: 0 0 70%;
    margin: 0 -15%;
    transition: transform 0.5s ease, opacity 0.5s ease;
    opacity: 0.5;
    z-index: 1;
}

.hero-peek-carousel .carousel-item.active {
    flex: 0 0 100%;
    opacity: 1;
    z-index: 2;
}

.hero-carousel .carousel-inner {
    overflow: hidden;
}

.hero-peek-carousel .carousel-item img {
    transition: transform 1.5s ease-in-out;
}

.hero-peek-carousel .carousel-item.active img {
    transform: translateX(0);
}

.dark-gradient-background-image:not(.booked-icon) {
    width: 350px !important;
    object-fit: cover;
}

.left-content h1 {
    color: white;
    margin-bottom: 1.25rem;
    line-height: 1.2
}

.left-content p {
    color: rgba(255, 255, 255, .95);
    margin-bottom: 1.875rem;
    line-height: 1.6
}

.carousel-indicators [data-bs-target] {
    width: calc(.75rem + .25vw);
    height: calc(.75rem + .25vw);
    border-radius: 50%;
    background-color: var(--color-primary);
    position: relative
}

.carousel-indicators [data-bs-target]::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: calc(3rem + .5vw);
    height: calc(3rem + .5vw)
}

.carousel-indicators {
    gap: .75rem
}

.hero-section .hero-container {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.section-heading {
    margin-bottom: 1rem;
    color: var(--color-black)
}

.section-subtitle {
    color: var(--color-text);
    margin-bottom: 2rem
}

.carousel-indicators .active {
    background-color: green;
    opacity: 1
}

.carousel-controls {
    bottom: .938rem;
    left: 2.188rem
}

.indicator-container {
    background: var(--color-primary)
}

.indicator {
    width: .75rem;
    height: .75rem;
    border-radius: 50%;
    background-color: rgba(255, 255, 255, .4);
    cursor: pointer;
    transition: all .3s ease
}

.indicator.active {
    background-color: var(--color-white);
    border-radius: .375rem
}

.right-content {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center
}

.carousel-banner-img {
    max-width: 12.5rem;
    width: 100%
}

.carousel-banner-wrapper {
    width: clamp(12.5rem, 18vw, 20rem);
    height: clamp(12.5rem, 18vw, 20rem);
    margin: 0 auto;
    border-radius: 50%;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-white);
}

.carousel-banner-wrapper img {
    opacity: 0;
    transition: opacity .5s ease-in-out
}

.carousel-banner-wrapper img.active {
    opacity: 1
}

.fade-text {
    opacity: 0;
    transform: translateY(10px);
    transition: opacity .6s ease, transform .6s ease
}

.fade-text.active {
    opacity: 1;
    transform: translateY(0)
}

carousel-banner-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.search-form {
    display: grid;
    grid-template-columns: repeat(3, 1fr) auto;
    gap: .938rem;
    align-items: end
}

.search-form-content {
    display: none;
    opacity: 0;
    transition: opacity .3s ease
}

.search-form-content.active {
    display: grid;
    opacity: 1
}

.search-form-content-nearby {
    grid-template-columns: 1fr auto
}

.search-btn {
    background-color: var(--color-primary);
    color: var(--color-white);
    border: none;
    padding: .75rem 20px;
    border-radius: .5rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all .3s ease;
    height: 3rem;
    width: 3rem
}

.search-btn:hover {
    background-color: var(--color-primary);
    transform: translateY(-2px)
}

.search-card {
    border-radius: .938rem;
    box-shadow: 0 10px 40px rgba(0, 0, 0, .05);
    position: relative;
    max-width: 50%;
    margin: -110px auto 20px;
    z-index: 10
}

.tabs-wrapper {
    position: relative;
    margin: -110px auto 20px;
}

.tabs-floating {
    position: absolute;
    top: -30px;
    z-index: 5;
    border-radius: 12px;
}


.awards-section {
    background-color: var(--color-accent);
    overflow-x: hidden
}

/*  .blog-section,
 .information-section {
     padding: clamp(2rem, 5vw, 4rem) 1rem
 } */

/* ============================= */
/*           Breadcrumb             */
/* ============================= */
.breadcrumb-container {
    padding: 0.9rem 0em;
}

.custom-breadcrumb {
    display: flex;
    align-items: center;
    gap: .5rem;
    color: var(--color-text);
    background-color: var(--color-grey-bg);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
    padding: clamp(.5rem, 1vw, .6rem) clamp(.9rem, 4vw, 1rem);
    margin-bottom: 0.5rem;
}


.custom-breadcrumb a {
    color: var(--color-grey);
    text-decoration: none
}

.custom-breadcrumb a:hover {
    color: var(--color-primary);
}

.custom-breadcrumb span {
    color: var(--color-text)
}

.custom-breadcrumb a:last-child {
    color: var(--color-primary);
    pointer-events: none;
}

.custom-breadcrumb>*:last-child {
    color: var(--color-primary);

}

/* ============================= */
/*           Text             */
/* ============================= */
.custom-text-primary {
    color: var(--color-secondary-green)
}

.custom-text-primary-green {
    color: var(--color-primary)
}

.custom-text-secondary {
    color: var(--color-text)
}

.custom-text-light {
    color: var(--color-white)
}

.custom-text-dark {
    color: var(--color-black)
}

.custom-text-grey {
    color: var(--color-grey)
}

.discount-text {
    color: var(--color-danger-text);
}


/* ============================= */
/*           Buttons             */
/* ============================= */
.btn-custom {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    line-height: 1.2;
    text-align: center;
    text-decoration: none;
    cursor: pointer;
    border: 2px solid transparent;
    border-radius: var(--radius-btn);
    padding: clamp(.5rem, 1vw, .7rem) clamp(1rem, 2vw, 1.2rem);
    user-select: none;
    position: relative;
    overflow: hidden;
    white-space: nowrap;
    background-color: transparent;
    z-index: 1
}

.btn-custom::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 0;
    background: transparent;
    z-index: -1;
}

.btn-custom:hover::before {
    height: 100%
}

.btn-clicked {
    box-shadow: 0 2px .5rem rgba(0, 123, 255, .3)
}

.btn-custom-primary {
    background: var(--btn-gradient);
    color: var(--color-black);
    border: none
}

.btn-custom-primary:hover {
    background: var(--color-primary);
    color: var(--color-white);

}

.btn-custom-secondary {
    background-color: var(--color-secondary);
    color: var(--color-black)
}

.btn-custom-secondary:hover {
    background-color: var(--color-white);
    color: var(--color-primary)
}

.btn-custom-success {
    background-color: var(--color-primary);
    color: var(--color-white)
}

.btn-custom-success:hover {
    color: var(--color-white);
}

.btn-custom-light {
    background: var(--color-white);
    color: var(--color-primary);
    border: 1px solid var(--color-primary)
}

.btn-custom-light:hover {
    background: var(--color-white);
    color: var(--color-primary)
}

.btn-custom-dimmed {
    background: var(--bg-grey);
    color: var(--color-border);
}

.btn-custom-dimmed:hover {
    background: var(--color-black);
    color: var(--color-white)
}

.btn-custom-outline {
    background-color: transparent;
    border: 1px solid var(--color-border);
    color: var(--color-text);
}

.btn-custom-outline:hover {
    background-color: var(--color-grey);
    color: var(--color-white);

}

.btn-custom-outline-success {
    background-color: var(--color-white);
    color: var(--color-primary);
    border: 1px solid var(--color-primary)
}

.btn-custom-outline-dark {
    border: 1px solid var(--color-black);
    color: var(--color-black)
}

.btn-custom-outline-dark:hover {
    background-color: var(--color-black);
    color: var(--color-white);
}

.btn-custom-outline-light {
    border: 1px solid var(--color-white);
    color: var(--color-white)
}

.btn-custom-outline-light:hover {
    background-color: var(--color-white);
    color: var(--color-black);
}

.btn-custom-outline-danger {
    border: 2px solid var(--color-danger);
    color: var(--color-danger)
}

.btn-custom-outline-danger:hover {
    background-color: var(--color-danger);
    color: var(--color-white);
}

.btn-custom-link {
    background: none;
    border: none;
    color: var(--color-primary);
    padding: 0
}

.btn-custom-link:hover {
    text-decoration: underline
}

.btn-custom-trash {
    background: none;
    border: none;
    cursor: pointer;
}

.btn-custom-icon {
    padding: .5rem;
    width: 2.5rem;
    height: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-white);
    border-radius: .5rem;
    border: 1px solid var(--color-border);
    color: var(--color-black);
    text-decoration: none
}

.btn-custom-icon:hover {
    background-color: var(--color-primary);
    color: var(--color-white)
}

.checkbox-btn input[type="radio"] {
    margin-right: 8px;
    accent-color: var(--color-primary);
}

.checkbox-btn:has(input:checked) {
    border-color: var(--color-primary);

}

.checkbox-btn-group {
    display: flex;
    gap: clamp(0.5rem, 1vw, 0.75rem);
}

.checkbox-btn {
    display: inline-flex;
    align-items: center;
    flex: 1;
    padding: clamp(0.3rem, 1vw, 0.2rem);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-btn);
    cursor: pointer;
    text-align: center;
    transition: all 0.3s ease;
}

.btn-custom-sm {
    padding: .4rem .5rem
}

.btn-custom-md {
    padding: .5rem 0.6rem
}

.btn-custom-lg {
    padding: .75rem 1.5rem
}

.btn-custom-block {
    display: flex;
    width: 100%
}

.btn-custom:disabled,
.btn-custom.disabled {
    opacity: .6;
    cursor: not-allowed
}

.btn-custom.loading {
    pointer-events: none;
    opacity: .7;
    position: relative
}

.btn-custom.loading::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 10.5rem;
    height: 10.5rem;
    border: 2px solid var(--color-white);
    border-top-color: transparent;
    border-radius: 50%
}

@keyframes spin {
    100% {
        transform: translate(-50%, -50%) rotate(360deg)
    }
}

.btn-custom .btn-icon-left {
    margin-right: .5rem
}

.btn-custom .btn-icon-right {
    margin-left: .5rem
}

.icon-svg {
    width: clamp(20px, 2vw, 24px);
    height: clamp(20px, 2vw, 24px)
}

.icon-fa,
.icon-green {
    color: var(--color-primary)
}

/* ============================= */
/*           Cards             */
/* ============================= */
.card {
    display: flex;
    flex-direction: column;
    width: 100%;
    justify-content: space-between;
    border: 1px solid var(--color-border);
    height: 100%;
    background-color: var(--color-white);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: 0 0 8px 0 #00000015;
    /*     margin: 8px 0px; */
}

.card-wrapper .card:hover {
    box-shadow: 0 8px 18px rgba(0, 0, 0, .08);
    border-color: var(--color-border);
    border-width: 1px
}

.card-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    align-items: stretch
}

.card-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 4.2rem;
    background-color: var(--color-white);
    color: var(--color-black);
    padding: .5rem 1rem;
    border-bottom: 1px solid var(--color-border);
    border-top-left-radius: var(--radius-md);
    border-top-right-radius: var(--radius-md);
    line-height: 1.4;
}

.packages-header {
    margin: 10px 2px;
}

.card-header-background {
    background: var(--card-header-bg);
}

.card::after {
    opacity: 0;
    transition: opacity .3s ease
}

.card-body {
    display: flex;
    flex-direction: column;
    justify-content: space-evenly;
    flex: 1;
    height: 100%;
    padding: 1rem;
    text-align: start
}

/*  .card-body .d-flex {
     margin-top: auto
 }
 */
.card-title {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: normal;
    margin-bottom: 0.4rem;
}

.card-footer {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 3rem;
    padding: .75rem 1rem;
    border-top: 1px solid var(--color-border)
}

.card-media {
    width: 100%;
    padding: 1rem;
    box-sizing: border-box;
    border-radius: var(--radius-md);
    overflow: hidden;
    background-color: var(--color-white)
}

.card-media img {
    height: clamp(8rem, 25vw, 10rem);
    object-fit: cover;
    border-radius: var(--radius-md);
    display: block;
}

.test-media img {
    height: clamp(11rem, 25vw, 0rem);
}

.card-media-inner {
    border-radius: inherit;
    overflow: hidden
}

.card-icon {
    width: clamp(4rem, 5vw, 5rem);
    height: clamp(4rem, 5vw, 5rem);
    object-fit: contain;
    margin-bottom: .75rem
}

.card-author {
    display: flex;
    align-items: center;
    padding: clamp(.4rem, 2vw, .6rem)
}

.card-avatar {
    width: clamp(2rem, 5vw, 2.5rem);
    height: clamp(2rem, 5vw, 2.5rem);
    background-color: #e9ecef;
    border-radius: 50%;
    overflow: hidden
}

.card-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%
}

.card-text {
    color: var(--color-grey);
    line-height: 1.5;
    margin-bottom: 0.8rem;
}

.card-desc {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    overflow: hidden;
    text-overflow: ellipsis;
    gap: .5rem;
    margin: 0.8rem 0;
    line-height: 1.4;
    color: var(--color-grey);
    /*    flex: 1 1 auto; */
}

.card-value,
.card-info,
.card-cta,
.test-name,
.test-price {
    color: var(--color-black)
}

.info-p {
    margin-top: auto
}

.card-cta {
    text-decoration: none;
    transition: color .2s
}

.card-cta:hover {
    text-decoration: underline
}

.card-info {
    color: var(--color-text)
}

.card-info i,
.year-experience {
    color: var(--color-primary)
}

.card-info p {
    margin-bottom: .5rem
}

/* ============================= */
/*           Card variants             */
/* ============================= */
.card-primary {
    border-left: 4px solid var(--color-primary);
}

.card-accent {
    border-left: 4px solid var(--color-accent);
}

.card-secondary {
    border-left: 4px solid var(--color-secondary);
}

.card-experience {
    width: clamp(250px, 50%, 420px);
    margin: 0 auto;
    border: 1px solid var(--color-primary);
    padding: clamp(1rem, 2vw, 2rem);
    text-align: center;
    z-index: 2
}


.expert-card {
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-border);
    overflow: hidden;
    box-shadow: var(--shadow-card);
    padding: 0.6rem;
}


.expert-img-wrapper {
    background: radial-gradient(154.8% 170% at 50% -11.45%, var(--color-white) 0%, #00984A 100%);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    display: flex;
    justify-content: center;
    align-items: flex-end;
    height: clamp(12rem, 25vw, 14.5rem);
    border-radius: var(--radius-sm);
    position: relative;
}

.director-img-wrapper {
    background: radial-gradient(154.8% 170% at 50% -11.45%, var(--color-white) 0%, #9fd6bb 100%);
}

.expert-card .card-body {
    padding: 1rem 0rem;
    color: var(--color-grey);
}

.expert-img {
    width: clamp(40%, 50%, 55%);
    height: auto;
    object-fit: contain;
    display: block;
    height: 90%;
}

.director-img {
    width: 100%;
    height: 100%;
}

.bordered-card {
    flex: 1;
    min-width: 0;
    border-radius: var(--radius-sm);
    padding: clamp(0.8rem, 1vw + 0.5rem, 1.25rem) clamp(1rem, 2vw + 0.5rem, 1.5rem);
    position: relative;
    cursor: pointer;
    transition: all 0.2s ease;
}

.card-details {
    padding: clamp(1rem, 2vw, 1.5rem);
    flex-direction: row;
    z-index: 1;
    margin-top: clamp(-2.5rem, -3vw, -2.8rem)
}

.card-testimonial {
    border-radius: 10px;
    padding: clamp(.75rem, 2vw, 10px);
    box-shadow: none;
    height: 100%;
}

.outline-card-layout {
    box-shadow: none !important
}

.outline-card-layout:hover {
    border: 1px solid var(--color-border);
    transform: none
}

/* ============================= */
/*           Tags             */
/* ============================= */
.card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
    margin: .5rem 0
}

.tag {
    background-color: var(--color-badge);
    color: var(--color-text-secondary);
    border-radius: var(--radius-md);
    padding: 0.25rem 0.75rem;
    display: inline-flex;
    align-items: center;
    gap: 0.625rem;
}

.tag-secondry {
    background-color: var(--color-secondary)
}

.tag-orange {
    background-color: var(--color-orange)
}

.booking-badge {
    border: 1px solid #333;
    border-radius: 8px;
    padding: 4px 12px;
    display: flex;
    align-items: center;
    gap: 6px;
    background: transparent;
    color: var(--color-primary)
}

.experience-badge {
    position: absolute;
    top: 0.9rem;
    left: 0.9rem;
    padding: 0.35rem 0.875rem;
    border-radius: var(--radius-btn);
    border: 1px solid var(--color-white);
    background: linear-gradient(180deg,
            rgba(255, 255, 255, 0.15) 0%,
            rgba(255, 255, 255, 0.3) 100%);
    backdrop-filter: blur(var(--badge-blur));
    -webkit-backdrop-filter: blur(var(--badge-blur));
}

.custom-pill {
    background: var(--color-white);
    color: var(--color-primary);
    width: fit-content;
    padding: 3px 8px;
    border-radius: var(--radius-sm);
}

/* ============================= */
/*           Inputs             */
/* ============================= */
.form-check-input:checked {
    background-color: #00984A;
    border-color: #00984A;
}

.form-check-input[type=checkbox] {
    border-radius: .15em;
    margin-top: 0rem;
}

.custom-radio {
    width: clamp(0.8rem, 1vw, 1.2rem);
    height: clamp(0.8rem, 1vw, 1.2rem);
    border: 0.1rem solid #bbb;
    border-radius: 50%;
    position: relative;
}

.custom-radio.selected {
    border-color: #00984A;
}

.custom-radio.selected::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 8px;
    height: 8px;
    background-color: #00984A;
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

.dropdown-toggle::after {
    display: none
}


.dropdown-toggle .fa-chevron-down {
    margin-left: .375rem;
    transition: transform .2s
}

.dropdown.show .fa-chevron-down {
    transform: rotate(180deg)
}

.otp-input {
    width: 50px !important;
    background-color: transparent !important;
    height: 50px;
    text-align: center;
    border: 2px solid #ddd;
    border-radius: .5rem;
    transition: border-color .3s ease
}

.parameter-count img {
    vertical-align: middle;
    position: relative;
    top: .5px
}

.upload-field:hover,
.upload-field:focus-within {
    border-color: #28a745;
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
}

.border-bottom-gradient {
    border-bottom: 1px solid;
    border-image: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, var(--color-white)fff 50%, rgba(255, 255, 255, 0) 100%);
    border-image-slice: 1
}

.price {
    color: var(--color-dark, #222)
}

/* ============================= */
/*           Video frame             */
/* ============================= */
.video-container {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #000;
    border-radius: .75rem;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center
}

.video-thumb-wrapper {
    position: relative;
    cursor: pointer;
}

.video-thumbnail {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden
}

.video-thumbnail img {
    display: block
}

.video-play-btn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    cursor: pointer;
}

.video-container iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
    border-radius: .75rem;
    object-fit: cover
}

.card-video {
    position: relative;
    cursor: pointer
}

.card-video img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .3s ease
}

.card-video:hover img {
    transform: scale(1.05)
}

.card-video .play-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: white;
    opacity: .9;
    transition: opacity .3s ease;
    pointer-events: none
}

.card-video:hover .play-icon {
    opacity: 1
}

.video-slide {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    text-align: center
}

.video-slide .card-video {
    width: 100%;
    border: none;
    background: var(--color-white);
    border-radius: .75rem;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0, 0, 0, .08)
}

.video-title {
    margin-top: .75rem;
    color: var(--color-black);
    line-height: 1.4;
    max-width: 90%
}

.card-video .card-body {
    flex: 1;
    padding-top: .75rem;
    text-align: center;
    display: flex
}

.cards-row {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scroll-behavior: smooth
}

.cards-row .card-wrapper {
    flex: 0 0 25%
}

.cards-row::-webkit-scrollbar {
    display: none
}

.cards-row .card {
    width: 100%
}

/* ============================= */
/*           Sqaure Cards             */
/* ============================= */
.square-card {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-btn);
    background-color: var(--color-white);
    padding: var(--space-sm);
    width: clamp(110px, 12vw, 134px);
    height: clamp(90px, 9vw, 107px);
    cursor: pointer;
    transition: all .2s ease
}

.square-card img {
    height: 40px;
    margin-bottom: var(--space-xs)
}

.square-card-text {
    color: var(--color-text);
    transition: color .2s
}

.square-card.active,
.square-card:hover {
    border-color: var(--color-primary);
    background-color: var(--color-primary)
}

.square-card.active .square-card-text,
.square-card:hover .square-card-text {
    color: var(--color-white)
}

.selectable-card {
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 1rem;
    cursor: pointer;
    position: relative;
    transition: all 0.2s ease;
}

.selectable-card:hover {
    border-color: var(--color-primary);
}

.selectable-card.selected {
    border-color: var(--color-primary);
    background-color: var(--color-white);
}

.icon {
    width: clamp(10.375rem, 2vw, 22px);
    height: clamp(10.375rem, 2vw, 22px);
    object-fit: contain;
    display: block
}

.extra-text {
    color: var(--color-text)
}

.readmore-text {
    display: none;
}

/* ============================= */
/*        Banner            */
/* ============================= */
.hero-image img {
    width: 100%;
    height: auto;
    display: block
}

.hero-section {
    background: var(--bg-home);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    /*  min-height: 560px; */
    width: 100%;
}

.hero-content {
    display: flex;
    align-items: center;
    /*  min-height: 500px  */
}

.hero-text {
    position: relative;
    text-align: center;
    margin-top: clamp(160px, 20vh, 12.5rem);
    margin-bottom: 2rem;
    padding: 2rem;
    z-index: 2
}

.hero-text h1,
.hero-text h2 {
    color: var(--color-primary)
}


.hero-overlay {
    display: block;
    width: clamp(260px, 25vw, 480px);
    margin: 0 auto 1rem;
    /*  aspect-ratio: 1/ 1; */
    object-fit: cover
}

.banner-img {
    width: 100%;
    max-width: 600px
}


.cta-banner-img {
    position: relative;
    z-index: 2;
    max-width: 400px
}


.cta-vector {
    position: absolute;
    width: 700px;
    height: auto;
    z-index: 1;
    opacity: 0.9;
}

/* Vector 1 position */
.cta-vector-1 {
    top: 0%;
    right: 30%;
}

/* Vector 2 position */
.cta-vector-2 {
    bottom: 0%;
    right: 5%;
}

/* ============================= */
/*           Form             */
/* ============================= */
.custom-form-container {
    background-color: var(--color-white);
    border-radius: var(--radius-md);
    padding: clamp(.7rem, 5vw, .8rem);
    border: 1px solid var(--color-border)
}

.custom-form-container.bg-light-grey {
    background-color: #F8F8F6;
}

.custom-form-title {
    color: var(--color-primary);
    margin-bottom: 1rem
}


.custom-form-container .form-control:focus {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-card)
}

.view-details {
    color: var(--color-primary);
    text-decoration: none;
    margin-left: .938rem
}

.view-details:hover {
    text-decoration: underline
}

.form-control {
    border-radius: .5rem;
    padding: .5rem 0.9rem;
    border: 1px solid var(--color-border, #ddd);
    background-color: var(--color-grey-bg, #f8f9fa);
    transition: border-color .2s ease, box-shadow .2s ease;
    width: 100%
}

.form-select {
    padding-right: 2rem;
    appearance: none;
    background-repeat: no-repeat;
    background-position: right .75rem center;
    background-size: 12px
}

.search-icon {
    position: absolute;
    left: 10px;
    top: 50%;
    transform: translateY(-50%)
}

.form-control:focus,
.form-select:focus {
    border-color: var(--color-primary, #00984a);
    box-shadow: 0 0 0 .25rem rgba(0, 152, 74, .15);
    outline: none
}

.col-md-6 input.form-control {
    flex: 1;
    min-width: 0
}

label {
    display: inline-block;
    margin-bottom: .2rem;
    color: var(--color-black, #000)
}

/* ============================= */
/*           Filter Tabs             */
/* ============================= */
.filters {
    border: 1px solid var(--color-border);
    border-radius: clamp(10px, 1vw, 10px);
    padding: clamp(3px, .5vw, 4px)
}

.filters .active-tab {
    width: auto;
    min-width: clamp(6rem, 20vw, 5rem);
    height: clamp(2.5rem, 5vh, 3rem);
    border-radius: clamp(.5rem, 1vw, .625rem);
    padding: 0 clamp(1rem, 3vw, 1.5rem);
    background-color: rgba(0, 152, 74, 1);
    color: var(--color-white);
    white-space: nowrap
}

.filters .inactive-tab {
    color: var(--color-text)
}

.filters .inactive-tab:hover {
    border-color: var(--color-primary);
    color: var(--color-white)
}

.filter-selection {
    color: var(--color-grey);
    border: 1px solid #BABDC1;
    border-radius: clamp(0.8rem, 0.5vw, 1rem) !important;
}

.packages-cards-wrapper {
    -webkit-overflow-scrolling: touch;
    padding-bottom: 1rem;
    -ms-overflow-style: none;
    scrollbar-width: none
}

.packages-cards-wrapper::-webkit-scrollbar {
    display: none
}

.packages-header p {
    color: var(--color-text)
}

.bottom-cta {
    background: var(--color-primary);
    color: white;
    padding: 20px 0;
    text-align: center;
    border-top-left-radius: 20px;
    border-top-right-radius: 20px
}

.component-title {
    color: var(--dark-green);
    margin-bottom: 1.5rem
}

.banner-background {
    background: linear-gradient(90deg, #00984a 0%, #007b39 100%);
    box-shadow: 0 8px 20px rgba(0, 0, 0, .15)
}

.banner-background .row {
    flex-wrap: wrap;
    align-items: center
}

.tests-section {
    background: var(--bg-invert)
}

.test-list {
    width: 100%;
    overflow: hidden;
    background-color: white;
    border-radius: 1.5rem;
    padding: 1rem;
    border: 1px solid var(--color-border)
}

.test-list .test-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: .8rem 0;
    flex-wrap: wrap;
    border-bottom: 1px solid var(--color-border); 
    gap: 1rem
}

.test-list .test-item:not(.d-none):last-of-type {
    border-bottom: none !important
}

.test-right {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    white-space: nowrap
}

.test-action {
    display: flex;
    align-items: center;
    gap: 1rem
}

.test-price {
    white-space: nowrap
}

.filter-wrapper {
    position: relative;
    overflow: hidden
}

.filter-buttons {
    display: flex;
    gap: 1rem;
    overflow-x: auto;
    scroll-behavior: smooth;
    padding-bottom: .5rem;
    -ms-overflow-style: none;
    scrollbar-width: none;
    transition: scroll-left .3s
}

.filter-buttons::-webkit-scrollbar {
    display: none
}

.grid-buttons {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(1, 1fr);
}

/* ============================= */
/*           Swiper             */
/* ============================= */
.swiper {
    visibility: visible;
    opacity: 1
}

.swiper-slide {
    display: flex
}

.swiper-slide .card {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column
}

.swiper-lazy-preloader {
    width: 30px;
    height: 30px;
    border: 3px solid #ddd;
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin .8s linear infinite;
    margin: auto;
    transition: opacity .3s ease
}

@keyframes spin {
    to {
        transform: rotate(360deg)
    }
}

.scroll-arrows-header {
    display: flex;
    gap: 16px
}

.scroll-arrow,
.pacakage-arrow-right,
.pacakage-arrow-left {
    transition: opacity .2s ease
}

.scroll-arrow {
    width: 35px;
    height: 35px;
    border-radius: 50%;
    border: 2px solid var(--color-primary);
    background: var(--color-white);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all .3s ease;
    opacity: .8
}

.scroll-arrow:hover {
    transform: scale(1.1);
}

.scroll-arrow.disabled {
    opacity: .3;
    pointer-events: none;
    border-color: grey
}

.disabled-arrow {
    opacity: .3;
    cursor: not-allowed;
    pointer-events: none
}

#stories-swiper .swiper-button-next,
#stories-swiper .swiper-button-prev {
    color: var(--color-white);
}

.swiper-slide img.loaded {
    visibility: visible;
    transition: visibility .3s ease-in
}

.swiper.swiper-initialized {
    opacity: 1
}

#testimonials-Section .swiper-pagination-bullet,
#member-swiper .swiper-pagination-bullet {
    width: 16px;
    height: 16px;
    margin: 0 6px;
    border-radius: 50%;
    background: var(--color-primary);
    opacity: 1;
    transition: transform 0.3s ease;
}

#testimonials-Section .swiper-pagination-bullet-active,
#member-swiper .swiper-pagination-bullet-active {
    transform: scale(1.2);
}


.scroll-arrow[style*="display:none"],
.scroll-arrow[style*="visibility:hidden"] {
    display: none !important;
}

.clickable-organ {
    cursor: pointer;
    transition: transform .2s ease, box-shadow .2s ease
}

.clickable-organ:hover {
    transform: scale(1.05)
}

.why-us-section,
.offer-section,
.information-section,
.risk-section,
.process-section {
    overflow: hidden;
    background: var(--bg-invert-blue);
}

.stat-icon-box {
    width: 68px;
    height: 68px;
    margin: 0 auto 1rem
}


/* ============================= */
/*           Testimonial             */
/* ============================= */
.testimonials-section {
    padding: 1.875rem 0;
    position: relative;
    overflow: hidden;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md)
}

.testimonials-section::before,
.testimonials-section::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    z-index: 0
}

.testimonials-section::before {
    width: clamp(150px, 15vw, 225px);
    height: clamp(80px, 10vw, 124px);
    top: clamp(-40px, -5vw, -50px);
    right: clamp(2px, 2vw, 2px);
    background-image: url(../images/vector/vector-1.webp);
    background-size: cover;
    background-repeat: no-repeat
}

.testimonials-section::after {
    width: clamp(12.5rem, 30vw, 334px);
    height: clamp(70px, 12vw, 110.5rem);
    bottom: clamp(-80px, -6vw, -42px);
    left: clamp(-50px, -8vw, -60px);
    background-image: url(../images/vector/vector.webp);
    /* background-size: cover; */
    background-repeat: no-repeat;
}

.review-text {
    color: var(--color-grey);
    line-height: 1.6;
    margin-bottom: .55rem
}

.author-info {
    display: flex;
    justify-content: space-between;
    align-items: center
}

.author-name {
    color: var(--color-black)
}

.rating {
    color: var(--color-white);
    padding: 4px 10px;
    border-radius: 5px
}

.rating-user {
    padding: 4px 3px !important;
}

.star-5 {
    background-color: #27ae60
}

.rating i {
    color: var(--color-secondary);
    margin-right: 2px
}

.rating i:last-child {
    margin-right: 0
}

.app-promo-section {
    background-color: var(--light-green-bg);
    overflow-x: hidden
}

.empty-box {
    background-color: var(--color-secondary);
}

.app-image-placeholder {
    border-radius: 1.25rem;
    overflow: hidden
}

.app-image-placeholder img {
    object-fit: cover;
    height: 100%;
    width: 100%;
    display: block
}

.app-content-box {
    background: var(--bg-invert-blue);
    border-radius: 1.25rem;
    display: flex;
    flex-direction: column;
    justify-content: center
}

.app-store-icon {
    width: 1.25rem;
    height: auto
}

.app-store-text .subtext {
    color: var(--color-text)
}

.faq-section>* {
    position: relative;
    z-index: 2
}

.faq-section {
    position: relative;
    /* padding: clamp(4rem, 6vw, 6rem) 0; */
    overflow: hidden
}

.col-lg-4 {
    position: relative
}

/* ============================= */
/*           Map             */
/* ============================= */
.maplibre-marker {
    cursor: pointer;
    background-image: url(../images/icons/mapmarker_green.svg);
    width: clamp(40px, 10vw, 60px);
    height: clamp(40px, 10vw, 60px);
    background-size: contain;
    background-repeat: no-repeat;
    transform: translate(-50%, -50%);
    opacity: 1
}

.col-xl-4.mt-2 .map-container {
    height: 100vh;
    position: relative
}

#map {
    width: 100%;
    height: 100%;
    border-radius: var(--radius-md)
}

.marker-card {
    position: absolute;
    background: white;
    padding: 8px 12px;
    border-radius: 8px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .2);
    pointer-events: none;
    display: none;
    z-index: 10
}

.maplibre-marker:hover {
    transform: scale(1.1)
}

.map-container {
    position: relative;
    /*   margin-bottom: clamp(1rem, 2vw, 1.25rem); */
}

#map_address {
    width: 100%;
    height: clamp(15rem, 30vw, 18.75rem);
    border-radius: clamp(0.5rem, 1vw, 0.5rem);
}

.map-search {
    position: absolute;
    top: clamp(0.5rem, 1vw, 0.625rem);
    left: 50%;
    transform: translateX(-50%);
    width: 80%;
    z-index: 10;
}

.show-dropdown {
    padding: .375rem .75rem;
    border: 1px solid var(--color-border);
    border-radius: 4px
}

/* ============================= */
/*           Paging             */
/* ============================= */
.pagination-container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 30px;
    padding: 20px 0
}

.pagination {
    display: flex;
    gap: 5px;
    list-style: none;
    margin: 0;
    padding: 0
}

.page-item {
    margin: 0
}

.page-link {
    padding: 8px 12px;
    background-color: rgba(248, 248, 246, 1);
    border-color: transparent;
    color: var(--color-black);
    text-decoration: none;
    border-radius: 4px;
    cursor: pointer;
    transition: all .3s ease
}

.page-link:hover {
    background-color: var(--color-badge);
    border-color: transparent
}

.page-item.active .page-link {
    background-color: transparent;
    color: var(--color-primary);
    border-color: transparent
}

.status-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: var(--color-grey);
}

/* 
 .status-dot {
     width: 8px;
     height: 8px;
     border-radius: 50%;
     background: #28a745
 }
 */

.custom-accordion .accordion-item {
    border: 1px solid var(--color-border);
    border-radius: clamp(.5rem, 1vw, 1rem);
    margin-bottom: clamp(.5rem, 1vw, 1rem);
    overflow: hidden
}

.custom-list {
    list-style: none;
    padding-left: 1.2rem;
}

.custom-list li {
    position: relative;
    margin-bottom: 6px;
    color: var(--color-grey);
}

.custom-list li::before {
    content: "•";
    position: absolute;
    left: -1.2rem;
    top: 0;
    color: var(--color-black);
}

.custom-list li strong {
    color: var(--color-black);
}

/* ============================= */
/*           Accordion             */
/* ============================= */
.custom-accordion .accordion-button {
    display: block;
    width: 100%;
    padding: clamp(.4rem, 1.5vw, .8rem) clamp(.8rem, 2vw, 1rem);
    color: var(--bs-accordion-btn-color, #000);
    background-color: transparent !important;
    border: 0;
    text-align: left;
    overflow-anchor: none;
    transition: background-color .3s ease, color .3s ease;
    position: relative
}

.custom-accordion .accordion-button::after {
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%);
    width: 1.25rem;
    height: 1.25rem;
    background-size: 1.25rem
}

.accordion-collapse {
    transition: height .3s ease
}

.accordion-collapse.show .accordion-body {
    max-height: 500px
}

.question-accordion .accordion-item {
    border: none;
    border-bottom: 1px solid var(--color-border);
    background-color: transparent !important;
    border-radius: 0
}

/*  .section-spacing {
     padding: clamp(2rem, 6vw, 4rem) 0;
 } */

.about-section {
    background-color: var(--bg-grey)
}

.pathology-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(12.5rem, 1fr));
    margin-top: .938rem
}

.pathology-item {
    padding: .5rem 0;
    color: var(--color-text);
    text-decoration: none;
    transition: color .3s ease
}

.pathology-item:hover {
    color: var(--color-primary);
    text-decoration: none
}

.accordion-button {
    background-color: transparent;
    border-bottom: 1px solid var(--color-border);
    box-shadow: none;
    padding: .5rem
}

.accordion-button:not(.collapsed) {
    background-color: transparent;
    color: var(--color-black) !important
}

.accordion-button:focus {
    box-shadow: none
}

.newsletter-section {
    padding: 5px;
    margin-top: 40px
}

.social-links {
    display: flex;
    gap: 10px;
    margin-top: 1.875rem
}

.social-link {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--color-primary);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    transition: background-color .3s ease
}

.social-link:hover {
    background: #1e7e34;
    color: white
}

.help-content {
    flex: 1;
    z-index: 2
}

.help-content h2 {
    margin-bottom: .75rem
}

.help-content p {
    margin-bottom: 1.5rem;
    opacity: .95
}

.health-conditions-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1rem
}

/* ---------- Condition Card ---------- */
.condition-card {
    display: flex;
    align-items: flex-start;
    gap: 1rem;
    padding: 1.25rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-white);
    cursor: pointer;
    transition: all .2s;
}

.condition-card:hover {
    border-color: var(--color-primary);
    box-shadow: var(--shadow-card);
}

.condition-icon {
    width: 3rem;
    height: 3rem;
    flex-shrink: 0;
}

.condition-content {
    flex: 1;
}

.condition-title {
    color: var(--color-black);
    margin-bottom: .25rem;
}

.condition-description {
    color: var(--color-text);
    line-height: 1.4;
}

/* ---------- Precision Card ---------- */
.precision-card {
    background: linear-gradient(135deg, var(--color-primary) 0%, #00C76A 100%);
    border-radius: 20px;
    padding: 40px 50px;
    max-width: 900px;
    width: 100%;
    color: white;
    position: relative;
    overflow: hidden;
    display: grid;
    gap: 40px;
    align-items: center;
}

.precision-card::before {
    content: '';
    position: absolute;
    left: -50px;
    top: -50px;
    width: 300px;
    height: 300px;
    border: 2px solid rgba(255, 255, 255, .1);
    border-radius: 50%;
}

.precision-card::after {
    content: '';
    position: absolute;
    right: -100px;
    bottom: -100px;
    width: 250px;
    height: 250px;
    border: 2px solid rgba(255, 255, 255, .05);
    border-radius: 50%;
}

.precision-image-placeholder {
    width: 180px;
    height: 240px;
    border: 2px solid rgba(255, 255, 255, .3);
    border-radius: 16px;
    background: rgba(255, 255, 255, .1);
    z-index: 1;
}

.precision-content {
    z-index: 1;
}


.test-section {
    padding: 3rem 2rem;
}

.test-container {
    display: grid;
    grid-template-columns: 480px 1fr;
    gap: 20px;
    /*     margin-bottom: 40px; */
}

.details-card {
    background-color: var(--color-primary);
    border-radius: 16px;
    color: var(--color-white);
    height: 95%;
    padding: 1rem;
}

.details-card h3 {
    padding-bottom: 10px;
}

.detail-item {
    display: flex;
    align-items: flex-start;
    padding: 10px;
    border-radius: 8px;
    transition: background 0.3s, color 0.3s;
}

.detail-item:hover {
    background: rgba(255, 255, 255, .1);
}

.detail-item.active {
    background-color: #28a745;
    color: var(--color-white);
    border-radius: 6px;
}

.detail-item.active .detail-title {
    color: var(--color-white);
}

.detail-icon {
    width: 24px;
    height: 24px;
    margin-right: 15px;
    flex-shrink: 0;
    margin-top: 2px;
}

.detail-content {
    flex: 1;
}

.detail-title {
    margin-bottom: 4px;
}

.detail-text {
    opacity: .9;
    line-height: 1.5;
}

.overview-card {
    background: rgba(254, 255, 228, 1);
    padding: 35px;
    border-radius: 1rem 1rem 0 0;
}

.overview-card h2 {
    color: #1f2937;
    margin-bottom: 20px;
}

.overview-text {
    color: #6b7280;
    line-height: 1.8;
    margin-bottom: 25px;
}

.bottom-section {
    border-radius: 16px;
    padding: 35px;
    display: grid;
    grid-template-columns: 1fr 580px;
    gap: 40px;
    align-items: center;
    background: rgba(254, 255, 228, 1);
    margin-top: -1rem;
}

/* ---------- Bottom Section Image ---------- */
.bottom-section img {
    max-width: 100%;
    height: auto;
}

.sfection {
    margin-bottom: 4rem;
    padding: 30px 20px
}

.info-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px 0;
    /*      margin-top: 24px */
}

.info-box {
    display: flex;
    align-items: center;
    background: var(--color-white);
    border: 1px solid var(--color-primary);
    border-radius: 8px;
    padding: 10px;
    gap: 12px;
    width: 85%
}

.info-icon {
    width: 64px;
    height: 64px;
    background: var(--color-primary);
    color: var(--color-white);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
}

.test-icon {
    width: 100px;
    height: 100px;
}


.info-text {
    flex: 1
}

.info-card {
    background: var(--color-white);
    transition: box-shadow .2s ease;
}

.info-card:hover {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.price-card {
    border-radius: 15px;
    background: var(--color-white);
    text-align: center;
    border: 1px solid var(--color-primary);
    margin-top: 5px
}

.price-card h2 {
    background: var(--color-primary);
    color: var(--color-white);
    margin: 0;
    padding: 18px;
    border-top-left-radius: 10px;
    border-top-right-radius: 10px
}

.price-card .price {
    margin: 15px 0 10px;
    color: #111
}

.price-card .btn {
    padding: 6px 20px;
    border-radius: 8px
}


/* Payment Summary */
.summary-row {
    padding: 0.4rem 0;
}

.summary-total {
    padding-top: 0.5rem;
    margin-top: 0.5rem;
    border-top: 1px solid var(--color-border);
}


/* Member List */
.member-selection-content {
    overflow: visible;
    /* ensure buttons not clipped */
}

.member-sidebar-sticky {
    position: relative;
    bottom: 110px;
    transition: bottom 0.3s ease;
}

.member-progress-steps .arrow {
    display: none;
}

.address-cards {
    margin-top: clamp(-9rem, -25vw, 0rem);

}

.date-card.date-card.active,
.date-card:hover {
    border-color: var(--color-primary);
    background-color: var(--bg-grey);
}

.date-selection-wrapper {
    margin-bottom: 32px;
    overflow: hidden;
}

.date-scroll-container {
    display: flex;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 8px;
    scrollbar-width: thin;
    scrollbar-color: #E5E7EB transparent;
}

.date-scroll-container::-webkit-scrollbar {
    height: 6px;
}

.date-scroll-container::-webkit-scrollbar-track {
    background: transparent;
}

.date-scroll-container::-webkit-scrollbar-thumb {
    background: #E5E7EB;
    border-radius: 3px;
}


.cart-list-item {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
}

/* Time Slot Section */
.time-slot-section {
    margin-bottom: 32px;
}

.time-period-tabs {
    background: var(--bg-grey);

}

.tab-content-item {
    display: none;
}

.tab-content-item.active {
    display: block;
}

.booking-sidebar-menu .sidebar-menu-item.active {
    background: #f2f6ff;
    border-radius: var(--radius-md);
}

/* Time Slots Grid */
.time-slots-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 12px;
    margin-bottom: 20px;
}

.time-slot-btn {
    padding: clamp(0.4rem, 0.6vw + 0.3rem, 0.6rem) clamp(0.8rem, 1vw + 0.5rem, 0.8rem);
    background: var(--bg-grey);
    border-radius: clamp(0.4rem, 0.8vw, 0.625rem);
    color: var(--color-grey);
    cursor: pointer;
    transition: all 0.3s ease;
    text-align: center;
    border: none;

}

.time-slot-btn:hover {
    border-color: #00984A;
    background: #F0F9F4;
    color: #00984A;
}

.time-slot-btn.active {
    background: #00984A;
    border-color: #00984A;
    color: #FFFFFF;
}

.time-slot-btn:disabled {
    background: #F9FAFB;
    border-color: #E5E7EB;
    color: #D1D5DB;
    cursor: not-allowed;
}

.slot-availability-info {
    max-width: 30rem;
    /* ≈550px */
    background: var(--card-header-bg, #f9f9f9);
}

/* ==========================================
    Review & Pay Styles
    ========================================== */
.review-card {
    background-color: var(--bg-grey);
}

.order-confirm-icon {
    width: 80px;
    height: 80px;
    margin: 0 auto 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

/* ==========================================
   My Booking Styles
   ========================================== */

.my-booking-section {
    background-color: var(--color-white);
    padding: 40px 0 60px;
}

/* Booking Sidebar */
.booking-sidebar {
    background: var(--color-white);
    border-radius: 16px;
    border: 1px solid var(--color-border);
    overflow: hidden;
}

.booking-sidebar-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

.sidebar-menu-item {
    border-bottom: 1px solid var(--color-border);
}

.sidebar-menu-item:last-child {
    border-bottom: none;
}

.sidebar-menu-link {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    color: #1D1D1B;
    text-decoration: none;
    transition: all 0.3s ease;
}

.sidebar-menu-link i {
    width: 20px;
    color: var(--color-grey);
}

.sidebar-menu-item.active .sidebar-menu-link {
    background: #F0F9F4;
    color: var(--color-primary);
}

.sidebar-menu-item.active .sidebar-menu-link i {
    color: var(--color-primary);
}

.sidebar-menu-item.active {
    border-bottom: none !important;
}

.sidebar-menu-link:hover {
    background: #F9FAFB;
}

/* Booking Details Grid */
.booking-details-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px;
    padding: 20px 0;
}

.booking-detail-item {
    display: flex;
    flex-direction: column;

}

/* Booking Actions */
.booking-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
}


/* ============================= */
/*           Progress tabs             */
/* ============================= */
.member-progress-steps {
    background-color: var(--color-white)fff;
    padding: clamp(12px, 2vw, 18px) clamp(16px, 3vw, 20px);
    margin-bottom: clamp(16px, 3vw, 32px);
    width: 66%;
    border-radius: clamp(20px, 1vw, 25px);
    box-shadow: var(--shadow-card);
    border: 1px solid var(--color-border);
}

.progress-steps {
    display: flex;
    align-items: center;
    max-width: 100%;
    width: 100%;
    margin: 0 auto;
    position: relative;
    padding: 0;
    gap: 90px;
}

.progress-step {
    display: flex;
    align-items: center;
    position: relative;
    z-index: 2;
    gap: 5px;
    justify-content: space-between;
    cursor: pointer;
    transition: all 0.3s ease;
}

.progress-step:hover .progress-step-label {
    color: var(--color-primary);
}

.progress-step:not(:last-child)::after {
    content: '';
    position: absolute;
    right: -100px;
    top: 50%;
    width: 100px;
    height: 2px;
    background-color: #E0E0E0;
    transform: translateY(-50%);
    z-index: 1;
    transition: background-color 0.3s ease;
}

.progress-step.completed .progress-step-icon {
    background-color: var(--color-primary);
    border: 2px solid var(--color-primary);
    color: var(--color-white);
    box-shadow: 0 2px 4px rgba(0, 152, 74, 0.2);
}

.progress-step-icon,
.progress-step:not(:last-child)::after {
    transition: all 0.3s ease;
}

.progress-step.completed:not(:last-child)::after {
    background-color: var(--color-primary);
}

.progress-step-icon {
    width: 2rem;
    height: 2rem;
    border-radius: 50%;
    background-color: var(--color-white);
    border: 2px dashed var(--color-border);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-grey);
    flex-shrink: 0;
}

.progress-step-label {
    color: var(--color-grey);
    white-space: nowrap;
}

.progress-step.active .progress-step-icon {
    border: 2px solid var(--color-black);
    color: var(--color-black);
    background-color: var(--color-white);
}

/* ==========================================
   Booking Detail Styles
   ========================================== */

.test-detail-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(0.75rem, 2vw, 1.5rem);
    margin-bottom: clamp(0.75rem, 2vw, 1.25rem);
    padding-bottom: 0;
    border-bottom: none;
}

.test-detail-col {
    display: flex;
    flex-direction: column;
}

.test-booked-name:last-child {
    margin-bottom: 0;
}

.ordertimeline {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
    padding: 2rem 0 1rem;
}

.ordertimeline::before {
    content: "";
    position: absolute;
    top: 45px;
    left: 0;
    right: 0;
    height: 3px;
    background: repeating-linear-gradient(to right,
            #E5E7EB 0,
            #E5E7EB 6px,
            transparent 6px,
            transparent 12px);
    z-index: 1;
}

.ordertimeline .timeline-item {
    position: relative;
    text-align: center;
    flex: 1;
    z-index: 2;
}

.ordertimeline .timeline-dot {
    width: 30px;
    height: 30px;
    background: var(--color-white);
    border-radius: 50%;
    margin: 0 auto 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px dotted var(--color-grey);
}

.ordertimeline .timeline-item.completed .timeline-dot,
.timeline-dot.completed {
    background: var(--color-primary);
    border: 2px solid var(--color-primary);
    color: var(--color-white);
}

.ordertimeline .timeline-item.completed .timeline-dot::after,
.timeline-dot.completed::after {
    content: "✔";
}

.ordertimeline .timeline-item.active .timeline-dot,
.timeline-dot.current {
    background: var(--color-white);
    border: 2px solid #000;
}

.ordertimeline .timeline-item.upcoming .timeline-dot,
.timeline-dot.upcoming {
    border: 2px dotted var(--color-border);
}

/* 
 .timeline-container {
     display: flex;
     flex-direction: column;
     padding-left: clamp(0.5rem, 1vw, 0.5rem);

 }

 .timeline-item {
     display: flex;
     gap: clamp(0.5rem, 2vw, 1rem);
     position: relative;
     padding-bottom: clamp(1.5rem, 4vw, 2.5rem);
 }

 .timeline-item:last-child {
     padding-bottom: 0;
 }

 .timeline-dot {
     width: clamp(1rem, 2vw, 1.125rem);
     height: clamp(1rem, 2vw, 1.125rem);
     border-radius: 50%;
     border: 0.125rem solid #D1D5DB;
     background: var(--color-white);
     flex-shrink: 0;
     margin-top: 0.25rem;
 }



 .timeline-item.completed .timeline-dot {
     background: #00984A;
     border-color: #00984A;
 }

 .timeline-item.active .timeline-dot {
     background: var(--color-white);
     border-color: #00984A;
     border-width: 0.1875rem;
 }


 .timeline-item.completed h6,
 .timeline-item.active h6 {
     color: #1F2937;
 }

 .timeline-item:not(.completed):not(.active) h6 {
     color: var(--color-white)fff;
 } */

.tracking-map-card {
    background: white;
    border-radius: 1rem;
    overflow: hidden;
    box-shadow: 0 clamp(0.125rem, 1vw, 0.75rem) clamp(0.75rem, 2vw, 1.5rem) rgba(0, 0, 0, 0.08);
    position: relative;
}

.tracking-map {
    width: 100%;
    height: clamp(25rem, 50vh, 34.375rem);
    position: relative;
}

.phlebo-details-card {
    position: absolute;
    bottom: clamp(1rem, 3vw, 1.25rem);
    left: clamp(1rem, 3vw, 1.25rem);
    right: clamp(1rem, 3vw, 1.25rem);
    background: white;
    border-radius: 0.75rem;
    padding: clamp(0.75rem, 2vw, 1rem);
    box-shadow: 0 clamp(0.25rem, 1vw, 1.25rem) clamp(1rem, 3vw, 1.25rem) rgba(0, 0, 0, 0.15);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: clamp(0.5rem, 2vw, 1rem);
}

.phlebo-info-section {
    display: flex;
    gap: clamp(0.5rem, 2vw, 0.75rem);
    flex: 1;
    align-items: center;
}

.phlebo-avatar {
    width: clamp(3rem, 8vw, 3.5rem);
    height: clamp(3rem, 8vw, 3.5rem);
    border-radius: 50%;
    overflow: hidden;
    flex-shrink: 0;
}

.phlebo-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.phlebo-details {
    flex: 1;
    min-width: 0;
}

.phlebo-name-section {
    display: flex;
    align-items: center;
    gap: clamp(0.25rem, 1vw, 0.5rem);
    margin-bottom: clamp(0.25rem, 1vw, 0.25rem);
}

.phlebo-name {
    color: var(--color-black);
    margin: 0;
}

.phlebo-status-badge {
    background: #FFF4E6;
    color: #F59E0B;
    padding: 0.125rem 0.5rem;
    border-radius: 0.25rem;
}

.phlebo-rating {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    margin-bottom: clamp(0.25rem, 1vw, 0.25rem);
}

.phlebo-specialty {
    color: var(--color-grey);
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.phlebo-actions {
    display: flex;
    align-items: center;
    gap: clamp(0.5rem, 2vw, 0.75rem);
    flex-shrink: 0;
}

.phlebo-visits {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
}

.visits-label {
    color: var(--color-grey);
}

.visits-count {
    color: var(--color-black);
}

.phlebo-marker {
    width: clamp(2.5rem, 6vw, 2.5rem);
    height: clamp(2.5rem, 6vw, 2.5rem);
    background: var(--color-primary);
    border: 0.1875rem solid white;
    border-radius: 50%;
    box-shadow: 0 clamp(0.125rem, 1vw, 0.5rem) clamp(0.5rem, 1vw, 0.5rem) rgba(0, 0, 0, 0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-white);
}

.destination-marker {
    width: clamp(2rem, 5vw, 2rem);
    height: clamp(2rem, 5vw, 2rem);
    background: #F59E0B;
    border: 0.1875rem solid white;
    border-radius: 50%;
    box-shadow: 0 clamp(0.125rem, 1vw, 0.5rem) clamp(0.5rem, 1vw, 0.5rem) rgba(0, 0, 0, 0.3);
}

.wallet-expiry-info {
    background: linear-gradient(91deg, #FFFFFF, #FFFEE0);
    border: 0.0625rem solid #D1D5DB;
    padding: clamp(0.5rem, 1vw, 0.8rem);
    border-radius: 0.375rem;
}

.cancel-icon {
    width: clamp(5rem, 10vw, 5rem);
    height: clamp(5rem, 10vw, 5rem);
    background-color: #ffe5e5;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 1rem auto;
}

.detail-label-width {
    min-width: clamp(9rem, 25vw, 11.25rem);
}


.hero-bg {
    min-height: 70vh;
    padding-top: 4rem;
    padding-bottom: 4rem;
    background-image: url('../images/photos/About_us.png');
    background-size: cover;
    background-position: center;
}

.hero-bg::before {
    content: "";
    position: absolute;
    inset: 0;
}

.hero-bg .container {
    position: relative;
    z-index: 2;
}

/* --- Leadership Section --- */
.leader-img {
    width: 200px;
    object-fit: cover;
    float: left;
    margin-right: 1.5rem;
    margin-bottom: 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
}

.timeline-item::before {
    content: '';
    position: absolute;
    left: 20px;
    top: 0;
    bottom: 0;
    width: 2px;
    z-index: 1;
}

.timeline-marker {
    width: 42px;
    height: 42px;
    background-color: var(--color-white);
    border: 3px solid var(--color-primary);
    ;
    border-radius: 50%;
    position: relative;
    z-index: 2;
    flex-shrink: 0;
}

.timeline-content {
    padding-left: 1.5rem;
}

.timeline-content strong {
    display: block;
    color: var(--color-primary);
}

/* --- Team Grid Section --- */
.team-card {
    text-align: center;
    margin-bottom: 1.5rem;
}

.team-card .img-placeholder {
    min-height: 180px;
    /* Adjust as needed */
    margin-bottom: 1rem;
}

.team-card h6 {
    margin-bottom: 0.25rem;
}

.team-card span {
    color: var(--color-grey);
}

/* --- Dark Banner Section --- */
.dark-banner {
    background-color: var(--color-primary);
    color: var(--color-white);
}

.dark-banner h3 {
    margin-bottom: 1.5rem;
}

.score-circle-wrapper {
    position: relative;
    width: clamp(6rem, 20vw, 9.375rem);
    height: clamp(6rem, 20vw, 9.375rem);
}

.score-circle-bg {
    stroke: #f0f0f0;
    stroke-width: 0.625rem;
    fill: none;
}

.score-circle-progress {
    stroke: var(--color-primary);
    stroke-width: 0.625rem;
    fill: none;
    stroke-linecap: round;
    transform: rotate(-90deg);
    transform-origin: center;
}

.score-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
}

.score-value {
    line-height: 1;
}

.score-label {
    margin-top: 0.25rem;
}

.health-status-list {
    list-style: none;
    padding: 0;
    margin-top: 1.5rem;
}

.health-status-item {
    display: flex;
    gap: 0.75rem;
    padding: 1rem 0;
    border-bottom: 0.0625rem solid var(--color-border);
}

.health-status-item:last-child {
    border-bottom: none;
}

.status-icon {
    width: 2.5rem;
    height: 2.5rem;
    flex-shrink: 0;
}

.status-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.status-info {
    flex: 1;
}

.status-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
}

.status-progress {
    background: #f5f5f5;
    height: 0.375rem;
    border-radius: 0.1875rem;
    overflow: hidden;
}

.progress-bar {
    height: 100%;
    transition: width 0.3s ease;
}

.progress-bar.bg-success {
    background: #65b32e;
}

.progress-bar.bg-warning {
    background: #f59e0b;
}

.badge-count {
    display: inline-flex;
    align-items: flex-start;
    gap: 0.25rem;
    padding: 0.25rem 0.5rem;
    border: 0.0625rem solid #e5e7eb;
    border-radius: 10rem;
    color: #444;
    background: var(--color-white);
    max-width: 9.375rem;
    white-space: normal;
}

.badge-count:hover {
    background: #f0f0f0;
    border-color: #d0d0d0;
}

.organ-status-toggle .status-group {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.4rem 0.5rem;
    border: 2px solid var(--color-border);
    border-radius: var(--radius-md);
}

.status-item {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    white-space: nowrap;
}

.separator {
    border: 0;
    height: 2px;
    background-color: var(--color-primary);
    margin: 0.1rem 0;
}

.badge-circle {
    background: var(--color-accent);
    color: var(--color-white);
    width: clamp(2rem, 10vw, 2rem);
    height: clamp(2rem, 6vw, 1rem);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
}

.organ-section {
    margin-bottom: 1rem;
}


.organ-header {
    gap: 1rem;
}

.organ-icon {
    width: clamp(2.5rem, 10vw, 3.125rem);
    height: clamp(2.5rem, 10vw, 3.125rem);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.375rem;
}

.organ-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.organ-status-toggle {
    display: flex;
    gap: 0.5rem;
}

.status-btn {
    border: 0.0625rem solid #e8e8e8;
    background: #fafafa;
    padding: 0.375rem 0.75rem;
    border-radius: 0.375rem;
    color: var(--color-grey);
    cursor: pointer;
    transition: all 0.2s;
}

.status-btn:hover {
    background: #f0f0f0;
}

.status-btn span {
    color: var(--color-black);
}

.status-btn-icon {
    border: none;
    background: transparent;
    padding: 0.5rem;

}

.organ-section.organ-expanded {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: 15px;
}

.organ-content {
    padding-top: 1.25rem;
    border-top: 0.0625rem solid #f0f0f0;
}

.parameter-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1rem;
}

.parameter-name {
    color: #1a1a1a;
    margin: 0;
}

.range-scale {
    margin-top: 1rem;
}

.range-numbers {
    display: flex;
    justify-content: space-between;
    color: #888;
    margin-bottom: 0.375rem;
}


.status-dot {
    width: 12px;
    height: 12px;
    border: 2px solid var(--color-secondary);
    background-color: var(--color-danger);
    border-radius: 50%;
    display: inline-block;
}

.fade-step {
    opacity: 0;
    transform: translateY(10px);
    transition: all .35s ease;
}

.fade-step.show {
    opacity: 1;
    transform: translateY(0);
}

/* ---------------------------------------
   Leader
--------------------------------------- */
.leader-vector {
    position: absolute;
    right: -42px;
    top: -1px;
    width: 322px;
    height: auto;
}

.leader-card:hover {
    border-color: #cfcfcf !important;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.06);
}

/* ---------------------------------------
   Values Circle (Green Circle)
--------------------------------------- */
.values-wrapper {
    width: 400px;
    height: 400px;
    position: relative;
}

.center-circle {
    width: 230px;
    height: 230px;
    background: #eef9e8;
    border-radius: 50%;
    border: 6px solid var(--color-white);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.outer-img {
    width: 110px;
    position: absolute;
    top: 0;
    left: 0;
}

.inner-icon {
    width: 70px;
    height: 70px;
    background: var(--color-white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    left: 20px;
    top: 20px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.inner-icon img {
    width: 38px;
}

.value-item {
    position: absolute;
}

.item-left {
    top: 15%;
    left: -70px;
}

.item-right {
    top: 15%;
    right: -70px;
}

.item-bottom {
    bottom: -70px;
    left: 50%;
    transform: translateX(-50%);
}

/* ---------------------------------------
   Values Triangle (Large SVG Triangle Layout)
--------------------------------------- */
.values-triangle {
    width: 500px;
    height: 470px;
    position: relative;
}

.vt-center {
    width: 330px;
    height: 330px;
    background: #e7f5dd;
    border-radius: 50%;
    border: 10px solid var(--color-white)fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -55%);
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.08);
}

.vt-icon-wrap {
    width: 150px;
    height: 150px;
    position: relative;
}

.vt-bg {
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.vt-icon-inner {
    width: 90px;
    height: 90px;
    background: var(--color-white);
    border-radius: 50%;
    position: absolute;
    top: 25px;
    left: 25px;
    display: flex;
    justify-content: center;
    align-items: center;
}

.vt-icon-inner img {
    width: 55px;
}

.vt-text {
    margin-top: 10px;
}

.vt-left,
.vt-right,
.vt-bottom {
    display: flex;
    align-items: center;
    gap: 10px;
}

.vt-left {
    position: absolute;
    top: 64px;
    left: -35px;
    flex-direction: row;
}

.vt-right {
    position: absolute;
    top: 65px;
    right: -60px;
    flex-direction: row;
}

.vt-bottom {
    position: absolute;
    bottom: -17px;
    left: 50%;
    transform: translateX(-50%);
    flex-direction: column;
    gap: 8px;
}

/* ---------------------------------------
   CSR Boxes
--------------------------------------- */
.csr-box {
    background: var(--color-white);
    border: 1px solid #e5e5e5;
    border-radius: 8px;
    transition: all 0.3s ease;
    color: var(--color-grey);
}

.csr-box:hover {
    border-color: #cdd6ff;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
}

/* ---------------------------------------
   Service Image & Stack Tabs
--------------------------------------- */
.service-image-box {
    height: 280px;
}

.stack-tabs {
    height: 150px;
}

.stack-tab {
    background: #dff0d4;
    padding: 14px 20px;
    border-radius: 14px;
    position: absolute;
    width: 80%;
    cursor: pointer;
    transition: 0.3s;
    box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.08);
}

.stack-tab:nth-child(1) {
    top: 0;
    z-index: 3;
}

.stack-tab:nth-child(2) {
    top: 30px;
    z-index: 2;
}

.stack-tab:nth-child(3) {
    top: 60px;
    z-index: 1;
}

.stack-tab.active {
    background: #2e7d32;
    color: var(--color-white);
    transform: scale(1.04);
}

.stack-content {
    background: #eef8e8;
    border-radius: 16px;
    min-height: 200px;
    transition: 0.3s;
}

/* ---------------------------------------
   Stack Slider (Card Dock Animation)
--------------------------------------- */
.stack-wrapper {
    position: relative;
    width: 100%;
    /* max-width: 1500px; */
    height: 320px;
    margin: 0 auto;
}

.service-card-stack {
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%) translateY(var(--y-offset, 0px)) scale(var(--scale, 0.9));
    width: 90%;
    transition: 0.35s ease;
    cursor: pointer;
    z-index: var(--z, 1);
}

.service-card-stack.active {
    transform: translateX(-50%) translateY(0) scale(1);
    z-index: 100;
}

.inner-card {
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 12px 35px rgba(0, 0, 0, 0.18);
    transition: 0.3s ease;
    display: flex;
    align-items: center;
    padding: 20px;
    color: var(--color-white);
}

/* ---------------------------------------
   Timeline OLD → No duplicates removed
--------------------------------------- */
.timeline-container {
    position: relative;
    max-width: 900px;
    margin: 0 auto;
    /*  padding: 40px 0; */
}

.timeline-line {
    position: absolute;
    left: 50%;
    top: 0;
    bottom: 0;
    width: 8px;
    background: var(--color-border);
    transform: translateX(-50%);
    border-radius: 4px;
}

.timeline-item {
    position: relative;
    padding: 50px 0;
}

.timeline-dot {
    width: 30px;
    height: 30px;
    background: var(--color-white);
    border: 5px solid var(--color-accent);
    border-radius: 50%;
    position: absolute;
    left: 50%;
    top: 0;
    transform: translateX(-50%);
    z-index: 3;
}

.timeline-year {
    position: absolute;
    top: -1rem;
    color: var(--color-black);
}

.timeline-year.left {
    left: calc(50% - 8%);
    text-align: right;
}

.timeline-year.right {
    right: calc(50% - 8%);
    text-align: left;
}

.timeline-content {
    width: 42%;
    line-height: 1.45;
    color: var(--color-grey);
    position: absolute;
    top: 25px;
}

.timeline-content.left {
    left: calc(50% - 46%);
    text-align: right;
}

.timeline-content.right {
    right: calc(50% - 42%);
    text-align: left;
}

.timeline-connector {
    position: absolute;
    top: 18px;
    width: 38%;
    border-top: 1.6px dashed var(--color-border);
}

.timeline-connector.left {
    left: 50%;
    transform: translateX(-100%);
}

.timeline-connector.right {
    left: 50%;
}

.about-hero-section {
    position: relative;
    width: 100%;
    background:
        linear-gradient(rgba(0, 0, 0, 0.75), rgba(0, 0, 0, 0.6)),
        url('../images/backgrounds/About_us.webp') center top / cover no-repeat;
}

.overlay-hero-section {
    background:
        linear-gradient(rgba(0, 0, 0, 0.75), rgba(0, 0, 0, 0.6)),
        url('../images/backgrounds/reseacrh_lab.webp') center top / cover no-repeat;
}

.home-visit-section {
    background:
        linear-gradient(rgba(0, 0, 0, 0.75), rgba(0, 0, 0, 0.6)),
        url('../images/backgrounds/home_visit.webp') center top / cover no-repeat;
}

.card-toggle {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.card-toggle .left-part {
    display: flex;
    align-items: center;
    gap: 10px;
}

.toggle-arrow {
    transition: transform 0.3s ease;
    display: inline-block;
    transform: rotate(90deg);
}

.collapsed .toggle-arrow {
    transform: rotate(0deg);
}


.divider {
    height: 0.5px;
    background: var(--color-border);
    margin: 6px 0;
}

.details-bg-img {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 221px;
    opacity: 0.5;
    pointer-events: none;
    user-select: none;
}

/* Web  stories */
.stories-grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 16px;
}

.story-card {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
    cursor: pointer;
    aspect-ratio: 9 / 12;
    background: linear-gradient(135deg, #2d7a5f, #4a9d7f);
}

.story-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    opacity: 0.85;
    transition: transform 0.3s ease, opacity 0.3s ease;
}

.story-card:hover img {
    transform: scale(1.05);
    opacity: 1;
}

.story-overlay {
    position: absolute;
    bottom: 0;
    width: 100%;
    padding: 30px 20px 20px;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.85), transparent);
    color: var(--color-white);
}

.story-date {
    opacity: 0.9;
}

.story-modal {
    display: none;
    position: fixed;
    inset: 0;
    background: linear-gradient(90deg, #005f35, #00803f, #4a9d2c);
    z-index: 99999;
    justify-content: center;
    align-items: center;
}

.story-frame {
    width: 350px;
    height: 92vh;
    border-radius: 20px;
    overflow: hidden;
    position: relative;
    background: #158b32;
}

.story-frame img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.top-right-icons {
    position: absolute;
    top: 18px;
    right: 22px;
    display: flex;
    gap: 20px;
}

.top-right-icons i {
    color: var(--color-white);
    cursor: pointer;
}

.nav-btn {
    width: 55px;
    height: 55px;
    background: var(--color-white);
    border-radius: 50%;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
}

.nav-left {
    left: calc(50% - 320px);
}

.nav-right {
    right: calc(50% - 320px);
}

.progress-wrapper {
    position: absolute;
    top: 12px;
    left: calc(50% - 210px);
    width: 420px;
    display: flex;
    gap: 6px;
}

.progress-segment {
    flex: 1;
    height: 4px;
    background: rgba(255, 255, 255, 0.35);
    border-radius: 5px;
}

.progress-fill {
    width: 0%;
    height: 100%;
    background: var(--color-white);
    transition: width linear;
}

.replay-btn {
    position: absolute;
    bottom: 40px;
    right: 40px;
    width: 60px;
    height: 60px;
    background: var(--color-white);
    border-radius: 50%;
    display: none;
    justify-content: center;
    align-items: center;
    cursor: pointer;
}

/* ============================= */
/*           Blogs page            */
/* ============================= */
.blog-hero-image {
    width: 100%;
    height: 350px;
    border-radius: var(--radius-sm);
    position: relative;
    overflow: hidden;
    margin: 30px 0;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;

}

.most-viewed-news .card a:hover div.text-dark {
    color: var(--color-primary) !important;
}

.blog-table-container {
    margin: 30px 0;
    overflow-x: auto;
}

.blog-table-container {
    margin: 30px 0;
    overflow-x: auto;
    border-radius: 12px;
    border: 1px solid var(--color-border);
}

.blog-custom-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    border-radius: 12px;
    overflow: hidden;
}

.blog-custom-table th {
    background: #F8F8F6;
    padding: 12px;
    text-align: left;
    border-bottom: 1px solid var(--color-border);
}

.blog-custom-table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--color-border);
}

.blog-custom-table tr:last-child td {
    border-bottom: none;
}

.blog-tabs-row {
    display: flex;
    gap: 8px;
    margin-bottom: 12px;
}

.blog-side-tab {
    flex: 1;
    border-radius: 10px;
    padding: 8px 10px;
    text-align: center;
    cursor: pointer;
    user-select: none;
}

.share-icon {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-decoration: none;
    transition: opacity .2s;
}

/* Brand Colors */
.bg-facebook {
    background-color: var(--color-facebook);
}

.bg-x {
    background-color: var(--color-x);
}

.bg-whatsapp {
    background-color: var(--color-whatsapp);
}

.bg-linkedin {
    background-color: var(--color-linkedin);
}

.bg-pinterest {
    background-color: var(--color-pinterest);
}

.share-icon:hover {
    opacity: 0.75;
}

.blog-side-tab.active {
    background: var(--btn-gradient);
}

.blog-card-img img {
    width: 520px;
    height: auto;
    object-fit: cover;
}

.blog-card-desc {
    -webkit-line-clamp: 3;
}

.blog-card img {
    height: 100%;
}

.blog-dropdown .dropdown-menu {
    display: block;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    pointer-events: none;
    transition:
        opacity .25s ease,
        transform .25s ease,
        visibility .25s;
}

.blog-dropdown:hover>.dropdown-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
}

.blog-dropdown .nav-link i {
    transition: transform .25s ease;
}

.blog-dropdown:hover .nav-link i {
    transform: rotate(180deg);
}

.blog-menu {
    max-height: 300px;
    overflow-y: auto;
}

.blog-menu .dropdown-item {
    display: flex;
    align-items: center;
    gap: .5rem;
}

.blog-menu-icon-box {
    width: 30px;
    height: 30px;
    border: 1px solid var(--color-badge);
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
}

.featured-card img {
    transition: transform .4s ease;
}

.featured-card:hover img {
    transform: scale(1.05);
}

.featured-card {
    height: 320px;
    position: relative;
    overflow: hidden;
}

.overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0));
}

.small-thumb {
    width: 70px;
    height: 70px;
    flex-shrink: 0;
}

.small-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ===============================
   PDF CONTENT AREA
=============================== */
.pdf-toolbar {
    background: #323232;
    color: white;
    padding: 10px 12px;
    position: sticky;
    top: 0;
    z-index: 2000;
    display: flex;
    align-items: center;
    justify-content: space-between;
    position: relative;
    white-space: nowrap;
    overflow-x: auto;
    gap: 14px;
    scrollbar-width: none;
}

.pdf-toolbar::-webkit-scrollbar {
    display: none;
}

.toolbar-left,
.toolbar-center,
.toolbar-right {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-shrink: 0;
}

.toolbar-center {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
}

.pdf-toolbar button {
    background: transparent;
    border: none;
    color: #fff;
    padding: 6px 8px;
    border-radius: 4px;
}

.pdf-toolbar button:hover {
    background: #444;
}

.pdf-toolbar input[type="number"] {
    background: #444;
    border: 1px solid #555;
    color: #fff;
    width: 55px;
    text-align: center;
    border-radius: 4px;
}

.zoom-value {
    min-width: 45px;
    text-align: center;
}

.pdf-sidebar {
    width: 260px;
    background: #f7f7f7;
    border-right: 1px solid #ddd;
    position: fixed;
    top: 50px;
    bottom: 0;
    left: -260px;
    z-index: 1200;
    padding: 20px;
    overflow-y: auto;
    transition: 0.35s ease;
}

.pdf-sidebar.active {
    left: 0;
}

.pdf-sidebar h5 {
    margin-bottom: 14px;
}

.page-thumb {
    background: white;
    border: 1px solid #ccc;
    width: 100%;
    aspect-ratio: 3/4;
    margin-bottom: 15px;
    overflow: hidden;
    cursor: pointer;
    border-radius: 4px;
}

.page-thumb-inner {
    transform: scale(0.23);
    transform-origin: top left;
    pointer-events: none;
}

.pdf-sidebar-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.35);
    display: none;
    z-index: 1100;
}

.pdf-sidebar-overlay.show {
    display: block;
}

.pdf-wrapper {
    display: flex;
}

.pdf-container {
    background: #525252;
    min-height: calc(100vh - 55px);
    margin-left: 0;
    flex-grow: 1;
    display: flex;
    justify-content: center;
    padding: 20px;
    transition: margin-left 0.35s ease;
}

.pdf-page {
    background: var(--color-white);
    max-width: 850px;
    width: 100%;
    padding: 40px;
    min-height: 1100px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
    transform-origin: top center;
}

.director-wrapper {
    display: flex;
    gap: 28px;
    align-items: flex-start;
    box-sizing: border-box;
    min-height: 72vh;
}

.director-sidebar-toggle {
    display: none;
    background: var(--color-primary);
    color: var(--color-white);
    border: 0;
    padding: 10px 14px;
    border-radius: 8px;
    cursor: pointer;
}

.director-sidebar {
    width: 23.125rem;
    background: var(--color-white);
    border: 1px solid var(--color-border);
    padding: 20px;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.03);
    max-height: calc(100vh - 56px);
    overflow: auto;
    position: relative;
    transition: transform .28s ease;
}

.director-sidebar h2 {
    margin: 6px 0 18px 0;
}

.director-nav-section-title {
    margin: 14px 0 8px 0;
}

.director-nav-item {
    padding: 12px;
    border-radius: 8px;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    cursor: pointer;
    transition: background .18s ease, color .18s ease;
    background: transparent;
    border: 1px solid transparent;
}

.director-nav-item:hover {
    background: var(--color-grey-bg);
    color: var(--color-black);
}

.director-nav-item.active {
    background: var(--color-primary);
    color: var(--color-white);
    box-shadow: inset 0 -2px 0 rgba(0, 0, 0, 0.02);
}

.director-nav-item i.fa-chevron-right {
    transition: transform .18s ease;
    color: inherit;
    opacity: .9;
}

.director-nav-item.open i.fa-chevron-right {
    transform: rotate(90deg);
}


.director-submenu {
    max-height: 0;
    overflow: hidden;
    transition: max-height .28s ease;
    margin-left: 10px;
    margin-bottom: 6px;
}

.director-submenu-item {
    padding: 10px 12px;
    border-left: 3px solid transparent;
    margin: 6px 6px;
    border-radius: 6px;
    cursor: pointer;
    transition: color .15s, background .15s;
    display: block;
    text-decoration: none;
}

.director-submenu-item:hover {
    color: var(--color-primary);
    background: transparent;
}

.director-submenu-item.active {
    background-color: var(--color-badge);
}


.director-content {
    flex: 1;
    background: var(--color-white);
    padding: 26px;
    border-radius: 10px;
    border: 1px solid var(--color-border);
    max-height: calc(100vh - 56px);
    overflow: auto;
    box-shadow: 0 6px 18px rgba(0, 0, 0, 0.03);
}

.director-content h1 {
    margin: 0 0 16px 0;
}

.director-doc-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.director-doc-item {
    display: flex;
    gap: 10px;
    align-items: center;
}

.director-doc-item i {
    color: var(--color-danger);
    width: 18px;
    text-align: center;
}

.director-doc-item a {
    text-decoration: underline;
}

.section-hr {
    height: 1px;
    background: var(--color-border);
    margin: 14px 0 18px 0;
    border-radius: 2px;
}

.fellowship-cards {
    display: flex;
    gap: 8px;
    height: 750px;
}

.card-item {
    position: relative;
    border-radius: 15px;
    overflow: hidden;
    cursor: pointer;
    flex: 1;
    min-width: 100px;
    transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    background-size: cover;
    background-position: center;
}

.card-item.active {
    flex: 3;
}

.card-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0.3), rgba(0, 0, 0, 0.6));
    padding: 14px 25px;
    display: flex;
    flex-direction: column;
}

.card-title-vertical {
    writing-mode: vertical-rl;
    transform: rotate(180deg);
    color: #fff;
    letter-spacing: 3px;
    margin: auto 0;
    opacity: 1;
    transition: all 0.6s;
}

.card-item.active .card-title-vertical {
    opacity: 0;
    display: none;
}

.card-content {
    opacity: 0;
    transform: translateY(20px);
    max-height: 0;
    overflow: hidden;
    transition: all 0.6s ease 0.2s;
    color: #fff;
}

.card-item.active .card-content {
    opacity: 1;
    transform: translateY(0);
    max-height: 3000px;
}

.card-content ul {
    list-style: none;
    padding: 0;
}

.card-content li {
    padding-left: 25px;
    position: relative;
    margin-bottom: 6px;
}

.card-content li:before {
    content: "•";
    position: absolute;
    left: 8px;
}

.knowledge-info-box {
    background: rgba(255, 255, 255, 0.25);
    backdrop-filter: blur(10px);
    padding: 15px 20px;
    border-radius: 10px;
    border: 1px solid rgba(255, 255, 255, 0.3);
    margin: 20px 0;
}


.info-green-box {
    background: var(--color-primary);
    color: var(--color-white);
    padding: 10px;
    border-radius: 12px;
    margin-top: 25px;
}

.info-title {
    margin-bottom: 4px
}

.info-subtitle {
    margin-bottom: 20px;
    color: var(--color-secondary);
}

.contact-row {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 14px;
}

.contact-icon {
    height: 36px;
    width: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
}

.card-item::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image:
        radial-gradient(circle at 20% 50%, rgba(255, 255, 255, 0.1) 0%, transparent 50%),
        radial-gradient(circle at 80% 80%, rgba(255, 255, 255, 0.08) 0%, transparent 50%);
    pointer-events: none;
    z-index: 1;
}

.card-1 {
    background: linear-gradient(rgba(20, 105, 48, .8), rgba(20, 105, 48, .8)),
        url('../images/photos/detail_1.png') center/cover;
}

.card-2 {
    background: linear-gradient(rgba(0, 152, 74, .45), rgba(0, 152, 74, .45)),
        url('../images/photos/deatil_2.png') center/cover;
}

.card-3 {
    background: linear-gradient(rgba(0, 152, 74, .45), rgba(0, 152, 74, .45)),
        url('../images/photos/detail_3.png') center/cover;
}

.card-4 {
    background: linear-gradient(rgba(0, 152, 74, .45), rgba(0, 152, 74, .45)),
        url('../images/photos/detail_4.png') center/cover;
}

.card-5 {
    background: linear-gradient(rgba(0, 152, 74, .45), rgba(0, 152, 74, .45)),
        url('../images/photos/detail_3.png') center/cover;
}

.card-6 {
    background: linear-gradient(rgba(0, 152, 74, .45), rgba(0, 152, 74, .45)),
        url('../images/photos/deatil_2.png') center/cover;
}

.partner-hero-section {
    position: relative;
    width: 100%;
    bottom: 23px;
    max-width: 100%;
    margin: 0 auto;
    min-height: clamp(500px, 60vh, 604px);
    background-image: url(../images/photos/indian-physician-patient-shaking-hands-medical-consultation\ 1.png);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    overflow: hidden;
    z-index: 1;
}

.partner-hero-section::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 50%;
    height: 100%;
    background: linear-gradient(90deg, rgba(0, 0, 0, 0.90) 0%, rgba(0, 0, 0, 0.75) 40%, rgba(0, 0, 0, 0) 100%);
    z-index: 2;
}

.partner-hero-content {
    position: relative;
    z-index: 3;
    height: 100%;
    min-height: clamp(500px, 60vh, 604px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}


.offer-section {
    width: 100%;
    padding: 2rem 1rem 8rem 1rem;
    position: relative;
    z-index: 1;
}

.partner-video-section {
    margin-top: -12rem;
    padding: 3rem 0;
    position: relative;
    z-index: 2;
}

.offer-section-header {
    position: relative;
    top: 30px;
    max-width: 600px;
    margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
}

.overlap-section {
    margin-top: -8%;
}

.offer-video-wrapper {
    max-width: 1000px;
    margin: 0 auto;
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
}

.offer-video-container {
    position: relative;
    width: 100%;
    background: #000;
    border-radius: var(--radius-md);
    overflow: hidden;
}

.offer-video-container .video-thumbnail {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.offer-video-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.benefits-footer {
    bottom: 0;
    height: auto;
    padding: 3rem 2rem;
}

.benefits-section {
    height: 820px;
    padding: clamp(3.5rem, 7vw, 6rem) 0 0;
    background: var(--color-white);
}

.benefits-section-header {
    max-width: 600px;
    margin-bottom: clamp(2.5rem, 5vw, 3.5rem);
}

.benefits-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: clamp(1.25rem, 2.5vw, 1.75rem);
    margin-bottom: 0;
    position: relative;
    z-index: 2;
}

.benefit-card {
    background: var(--color-white);
    border: 1px solid #E5E7EB;
    border-radius: var(--radius-md);
    padding: clamp(1.75rem, 3vw, 2.25rem);
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.benefit-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 152, 74, 0.12);
    border-color: var(--color-primary);
}

.benefit-card-icon {
    width: clamp(2.75rem, 5vw, 3.25rem);
    height: clamp(2.75rem, 5vw, 3.25rem);
    margin-bottom: 1.25rem;
}

.benefit-card-icon svg,
.benefit-card-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.benefits-footer {
    background: linear-gradient(0deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
    background-image: url(../images/photos/indian-physician-patient-shaking-hands-medical-consultation\ 1.png);
    height: 550px;
    position: relative;
    z-index: 1;
    bottom: 400px;
    padding: clamp(2.5rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 3rem);
    margin-top: clamp(-1px, 0vw, 0);
}

.benefits-footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(0deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
    z-index: 2;
}

.benefits-footer-text {
    position: relative;
    top: 395px;
    z-index: 3;
    max-width: 900px;
    margin: 0 auto;
}


.requirements-section {
    position: relative;
    background: linear-gradient(135deg, #7EC844 0%, #4A9D2F 100%);
    padding: clamp(4rem, 8vw, 6rem) 0;
    overflow: hidden;
}

.requirements-section::before {
    content: '';
    position: absolute;
    top: -100px;
    right: -100px;
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.1) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}

.requirements-section::after {
    content: '';
    position: absolute;
    bottom: -150px;
    right: 10%;
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.08) 0%, transparent 70%);
    border-radius: 50%;
    pointer-events: none;
}

.requirements-section-header {
    max-width: 700px;
    margin-bottom: clamp(3rem, 6vw, 4.5rem);
    position: relative;
    z-index: 2;
}

.step-number-img {
    width: 50px;
    /* adjust size */
    height: 40px;
    display: inline-block;
}

.requirements-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    position: relative;
    z-index: 2;
    color: var(--color-white);
}

.requirement-step {
    padding: clamp(2rem, 4vw, 3rem) clamp(1.5rem, 3vw, 2rem);
    border-right: 1px solid rgba(255, 255, 255, 0.2);
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
    min-height: 250px;
    display: flex;
    flex-direction: column;
    transition: all 0.3s ease;
    position: relative;
}

.requirement-step:nth-child(3n) {
    border-right: none;
}

.requirement-step:nth-child(4),
.requirement-step:nth-child(5),
.requirement-step:nth-child(6) {
    border-bottom: none;
}

.requirement-step:hover {
    background: rgba(255, 255, 255, 0.1);
}

.requirement-step::before {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    height: 2px;
    background: var(--color-white);
    transition: width 0.4s ease;
}

.requirement-step:hover::before {
    width: 100%;
}

.steps-to-become-section {
    position: relative;
    padding: clamp(4rem, 8vw, 6rem) 0;
    background: var(--color-white);
}

.steps-cards-container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 30px;
    margin-top: clamp(2rem, 4vw, 3rem);
    border-radius: var(--radius-md);
    overflow: hidden;
    position: relative;
}

.steps-cards-container::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    width: 1px;
    height: 100%;
    transform: translateX(-50%);
    z-index: 1;
}

.step-card {
    background: var(--color-white);
    border: none;
    border: 1px solid var(--color-border);
    border-radius: 0;
    overflow: hidden;
    transition: all 0.3s ease;
    display: flex;
    flex-direction: column;
    position: relative;
}

.step-card:hover {
    background: #FAFFFE;
}

.step-card-image {
    width: 100%;
    height: clamp(200px, 25vw, 300px);
    overflow: hidden;
    position: relative;
}

.step-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.step-card:hover .step-card-image img {
    transform: scale(1.05);
}

.step-card-content {
    padding: clamp(1.5rem, 3vw, 2rem);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.wch-img {
    aspect-ratio: 1 / 1;
    object-fit: cover;
}


.wch-video {
    aspect-ratio: 16 / 9;
}


.wch-text {
    line-height: 1.45;
}

.wch-img {
    max-height: 255px;
    object-fit: cover;
    border-radius: 1rem;
    width: 100%;
}

.method-step {
    position: relative;
    padding-left: 20px;
}

.method-line {
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--color-primary);
    border-radius: 10px;
}

.icon-wrapper {
    width: 60px;
    height: 60px;
    min-width: 60px;
    min-height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #dee2e6;
    border-radius: 0.5rem;
    flex-shrink: 0;
}

.icon-wrapper img {
    max-width: 40px;
    max-height: 40px;
}

.decorative-img {
    max-width: 140px;
    pointer-events: none;
}

.clinic-img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.publication-grid {
    grid-template-columns: repeat(2, 1fr);
}

.academic-banner {
    background: var(--banner-bg);
}

.academic-banner-top {
    padding: 30px 0;
}

.circle-bg {
    display: flex;
    align-items: center;
    justify-content: center;
}

.illustration-img {
    width: clamp(177px, 65%, 458px);
    height: auto;
    object-fit: contain;
    position: absolute;
    bottom: 0;
    left: clamp(1rem, 4%, 3rem);
    transform: translateY(50%);
}

.banner-bottom {
    background: #146930;
    min-height: 50px;
}

.apply-arrow-img {
    width: 60px;
    height: auto;
}

/* ================= Progress Bar ================= */
.test-bar-container {
    display: flex;
    margin-bottom: 50px;
    position: relative;
}

.test-step {
    flex: 1;
    height: 40px;
    background: #e0e0e0;
    color: var(--color-black);
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    clip-path: polygon(0 0,
            calc(100% - 20px) 0,
            100% 50%,
            calc(100% - 20px) 100%,
            0 100%,
            20px 50%);
}

.test-step:first-child {
    clip-path: polygon(0 0,
            calc(100% - 20px) 0,
            100% 50%,
            calc(100% - 20px) 100%,
            0 100%);
}

.test-step:last-child {
    clip-path: polygon(0 0,
            100% 0,
            100% 100%,
            0 100%,
            20px 50%);
}

.test-step.active {
    background: var(--color-primary);
    color: #fff;
}

.question-title {
    margin-bottom: 30px;
    color: var(--color-black)a1a;
}

.option-btn {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--color-border);
    border-radius: 8px;
    background: #fff;
    color: var(--color-grey);
    cursor: pointer;
    transition: all .2s ease;
    text-align: center;
    margin-bottom: 15px;
}

.option-btn:hover {
    border-color: var(--color-primary);
    background: #f0fdf4;
}

.option-btn.selected {
    border-color: #16a34a;
    background: #dcfce7;
    color: var(--color-primary);
}

.button-group {
    display: flex;
    justify-content: flex-end;
    gap: 15px;
    margin-top: 50px;
}

.bmi-calculator {
    border: 1px solid var(--color-border);
    border-radius: 12px;
    padding: 30px;
    margin-bottom: 30px;
}

.bmi-calculator h3 {
    text-align: center;
    margin-bottom: 25px;
}

.result-container {
    text-align: center;
    padding: 40px;
}

.result-medium {
    color: #FED70D;
}

.result-description {
    color: var(--color-grey);
    line-height: 1.6;
    max-width: 700px;
    margin: 0 auto;
}

.gauge-img-wrapper {
    position: relative;
    width: 340px;
    margin: auto;
}

.gauge-bg {
    width: 100%;
    display: block;
}

.needle-img {
    position: absolute;
    bottom: 17%;
    left: 50%;
    width: 70px;
    height: 6px;
    background: var(--color-black);
    transform-origin: 0% 50%;
    transform: rotate(-90deg);
    border-radius: 6px;
    transition: transform 1.5s ease-out;
}

.needle-img::after {
    content: "";
    position: absolute;
    left: -5px;
    top: -11px;
    width: 30px;
    height: 30px;
    background: linear-gradient(145deg, #333, #111);
    border-radius: 50%;
}

.container-card {
    background: var(--color-white);
    border-radius: var(--radius-md);
    padding: 40px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .1);
}

.bmi-inputs {
    display: flex;
    gap: 15px;
    align-items: flex-end;
}

.input-group-custom {
    flex: 1;
}

.bmi-btn {
    margin-left: auto;
    height: 46px;
    white-space: nowrap;
}

.compact-card {
    max-width: 20rem;
}

.logo-size {
    height: 5rem;
    object-fit: contain;
}

.step-badge {
    position: absolute;
    bottom: 0.75rem;
    left: 0.75rem;
    width: 4rem;
    height: 4rem;
    background: #FFFFFF66;
    color: var(--color-black);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(10px);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.banner-vector {
    position: absolute;
    pointer-events: none;
}

.banner-vector-top {
    width: 12rem;
    transform: translate(35%, -35%);
}

.banner-vector-bottom {
    width: 14rem;
    transform: translate(-35%, 35%);
}

.container-custom {
    max-width: 1400px;
    margin: 0 auto;

}



.tab-content-area {
    background: white;
}

.tab-pane {
    display: none;
}

.tab-pane.active {
    display: block;
}

.page-header {
    text-align: center;
    margin-bottom: 10px;
}


.content-wrapper {
    display: flex;
    gap: 45px;
    margin-top: 30px;
}

.left-section {
    flex: 0 0 530px;
}

.right-section {
    flex: 1;
}

.address-box {
    padding: 8px 12px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
}

.testimonial-box {
    color: var(--color-grey);
    padding: 20px;
    margin-bottom: 15px;
    border-radius: 4px;
}

#pageNumbers {
    display: flex;
    gap: 5px;
}

.pagination-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    margin-top: 20px;
    gap: 10px;
}

.show-entries {
    display: flex;
    align-items: center;
    gap: 8px;
}

.show-entries select {
    border: 1px solid var(--color-border);
    border-radius: 0.3rem;
    padding: 0.35rem 0.65rem;
    height: 35px;
    line-height: 1.2;
}

.pagination-numbers {
    display: flex;
    align-items: center;
    gap: 5px;
    flex-wrap: nowrap;
}

.pagination-numbers button {
    background: var(--color-white);
    border: 1px solid var(--color-border);
    cursor: pointer;
    border-radius: 0.3rem;
    font-size: 0.875rem;
    padding: 0.35rem 0.65rem;
    min-width: 35px;
    height: 35px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pagination-numbers button.active {
    background: var(--color-badge);
    color: var(--color-black);
    border-color: var(--color-badge);
}

.accreditation-logo {
    height: auto;

}

/* =========================
   STICKY TABS
========================= */

.fit-tabs {
    display: inline-flex;
    gap: 10px;
    overflow-x: auto;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding: 6px 12px;
    background: #f6f6f6;
    border-radius: 10px;
}

.fit-tabs::-webkit-scrollbar {
    display: none;
}

.fit-tabs a {
    padding: 8px 18px;
    border-radius: 10px;
    color: #374151;
    text-decoration: none;
    white-space: nowrap;
    flex-shrink: 0;
    transition: all 0.25s ease;
}

.fit-tabs a.active {
    background: var(--color-primary);
    color: var(--color-white);
}

.fit-content {
    padding-top: 24px;
}

.fit-block {
    padding: 15px 0 20px;
    scroll-margin-top: 80px;
}

.fit-block p {
    margin-bottom: 16px;
    color: var(--color-grey)
}

/* =========================
   READ MORE (NO JS CONFLICT)
========================= */
.fit-read {
    max-height: 1500px;
    overflow: hidden;
    transition: max-height 0.3s ease;
}

.fit-block.expanded .fit-read {
    max-height: none;
}

.fit-read-more {
    display: block;
}

.fit-block.expanded .fit-read-more {
    display: block;
}

/* Button VISIBILITY controlled by JS ONLY */
.fit-read-btn {
    display: none;
    margin-top: 12px;
}

/* Optional text indicator */
.fit-read-btn::after {
    content: " More ▼";
}

.fit-block.expanded .fit-read-btn::after {
    content: " Less ▲";
}

/* =========================
   CARDS
========================= */
.fit-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
    margin-top: 16px;
}

/* =========================
   LISTS
========================= */
.fit-list {
    list-style: none;
    padding: 0;
    margin-top: 16px;
}

.fit-list li {
    position: relative;
    padding-left: 26px;
    margin-bottom: 12px;
    color: #4b5563;
}

.fit-list li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 9px;
    width: 10px;
    height: 10px;
    background: var(--color-primary);
    border-radius: 50%;
}

.fit-page-grid {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 1rem;
    align-items: start;
    padding: 2rem;
}

.fit-left {
    overflow: auto;
}

.fit-right {
    position: sticky;
    top: 20px;
}

.fit-tabs-sticky {
    position: sticky;
        top: var(--header-height);
        z-index: 999;
        background: #fff;
    box-shadow:
        0 6px 12px rgba(255, 255, 255, 0.6),
        0 2px 10px rgba(0, 0, 0, 0.05);
 
}

.truncate-1 {
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mfbt-list {
    max-height: calc(5 * 72px);
    overflow-y: auto;
}

.mfbt-item {
    min-height: 72px;
}

.mfbt-list {
    scrollbar-width: thin;
}

.mfbt-list::-webkit-scrollbar {
    width: 6px;
}

.mfbt-list::-webkit-scrollbar-thumb {
    background: #ccc;
    border-radius: 6px;
}

.mfbt-scroll {
    max-height: calc(5 * 72px);
    overflow-y: auto;
}

.mfbt-item {
    min-height: 72px;
}

.result-grid {
    display: grid;
    gap: 16px;
}

.result-card {
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 14px;
    background: #fff;
}

.result-row {
    display: grid;
    grid-template-columns: 150px 1fr;
    gap: 12px;
    margin-bottom: 8px;
}

.result-row:last-child {
    margin-bottom: 0;
}

.fit-top-sticky-bar {
    position: fixed;
    top: 50px;
    left: 0;
    right: 0;
    background: var(--color-white);
    z-index: 1000;
    transform: translateY(-100%);
    opacity: 0;
    transition: transform 0.3s ease, opacity 0.3s ease;
}

.fit-top-sticky-bar.is-visible {
    transform: translateY(0);
    opacity: 1;
}

.fit-top-inner {
    margin: auto;
    padding: 8px 5px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;

}

.fit-top-cta {
    display: flex;
    align-items: center;
    gap: 12px;
}
#fit-faq {
    max-height: calc(100vh - 120px);
    overflow-y: auto;
    padding-right: 8px;
}

#fit-faq {
    scrollbar-width: none;
    -ms-overflow-style: none;
}

#fit-faq::-webkit-scrollbar {
    display: none;
}
.action-icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--color-primary);
}

.action-icon i {
    font-size: 18px;
}

.health-test-list {
    display: flex;
    gap: 1rem;
    overflow-x: auto;
    padding-bottom: 0.5rem;
    scroll-behavior: smooth;
}

.health-test-list::-webkit-scrollbar {
    height: 6px;
}

.health-test-list::-webkit-scrollbar-thumb {
    background-color: rgba(0, 128, 0, 0.6);
    border-radius: 3px;
}

.health-test-list::-webkit-scrollbar-track {
    background: transparent;
}

.health-test-list {
    scrollbar-width: thin;
    scrollbar-color: rgba(0, 128, 0, 0.6) transparent;
}

