/* ============================================================
   CARDIOCARE TANZANIA — SHARED STYLESHEET v2
   Brand colors: #021e59 (navy) · #b91c1c (crimson)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400;1,500&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');

:root {
    --brand:        #021e59;
    --brand-dark:   #011240;
    --brand-mid:    #0d2e7a;
    --brand-light:  #e6eaf4;
    --crimson:      #b91c1c;
    --crimson-dark: #991b1b;
    --cream:        #f7f8fc;
    --warm-white:   #eef1f8;
    --white:        #ffffff;
    --border:       rgba(2,30,89,0.09);
    --gray-soft:    #7a849a;
    --gray-mid:     #3e4860;
    --text-dark:    #131c2e;

    --font-display: 'Cormorant Garamond', Georgia, serif;
    --font-body:    'DM Sans', system-ui, sans-serif;

    --nav-h:        70px;
    --section-pad:  90px;
    --container:    1200px;
    --pad:          60px;
    --r-sm:         3px;
    --r-md:         8px;
    --ease:         0.26s ease;
    --shadow-sm:    0 2px 10px rgba(2,30,89,0.07);
    --shadow-md:    0 8px 32px rgba(2,30,89,0.12);
    --shadow-lg:    0 20px 56px rgba(2,30,89,0.16);
}

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--cream);color:var(--text-dark);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
ul,ol{list-style:none}
button{cursor:pointer;font-family:var(--font-body)}

/* ── CONTAINER ── */
.cc-container{max-width:var(--container);margin:0 auto;padding:0 var(--pad)}

/* ── SECTIONS ── */
.cc-section{padding:var(--section-pad) 0}
.cc-section--brand{background:var(--brand)}
.cc-section--dark{background:var(--brand-dark)}
.cc-section--warm{background:var(--warm-white)}
.cc-section--cream{background:var(--cream)}
.cc-section--white{background:var(--white)}

/* ── LABEL TAG ── */
.cc-tag{display:inline-flex;align-items:center;gap:10px;margin-bottom:14px}
.cc-tag__dot{width:6px;height:6px;background:var(--crimson);border-radius:50%;flex-shrink:0}
.cc-tag__dot--brand{background:var(--brand)}
.cc-tag__text{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--crimson);font-weight:600}
.cc-tag__text--brand{color:var(--brand)}
.cc-tag__text--white{color:rgba(255,255,255,.6)}

/* ── HEADINGS ── */
.cc-heading{font-family:var(--font-display);font-size:clamp(28px,3vw,48px);font-weight:600;line-height:1.1;color:var(--brand);margin-bottom:12px}
.cc-heading--white{color:#fff}
.cc-subheading{font-size:15px;line-height:1.8;color:var(--gray-soft);max-width:580px}
.cc-subheading--white{color:rgba(255,255,255,.55)}
.cc-section-header{margin-bottom:52px}
.cc-section-header--center{text-align:center}
.cc-section-header--center .cc-tag{justify-content:center}
.cc-section-header--center .cc-subheading{margin:0 auto}

/* ── DIVIDER ── */
.cc-divider{width:50px;height:2px;background:linear-gradient(90deg,var(--crimson),transparent);margin:12px 0 20px}
.cc-divider--brand{background:linear-gradient(90deg,var(--brand),transparent)}
.cc-divider--center{margin:12px auto 20px}

/* ── BUTTONS ── */
.cc-btn{display:inline-block;padding:13px 30px;font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;border:none;border-radius:var(--r-sm);transition:all var(--ease)}
.cc-btn--primary{background:var(--crimson);color:#fff}
.cc-btn--primary:hover{background:var(--crimson-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.cc-btn--brand{background:var(--brand);color:#fff}
.cc-btn--brand:hover{background:var(--brand-mid);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.cc-btn--outline{background:transparent;color:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.35)}
.cc-btn--outline:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.08)}
.cc-btn--outline-dark{background:transparent;color:var(--brand);border:1px solid rgba(2,30,89,.22)}
.cc-btn--outline-dark:hover{border-color:var(--crimson);color:var(--crimson)}

/* ══════════════════════════════════════
   TOP BAR
══════════════════════════════════════ */
.cc-topbar{background:var(--brand);border-bottom:1px solid rgba(255,255,255,.08);padding:9px 0}
.cc-topbar__inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.cc-topbar__socials{display:flex;gap:6px}
.cc-topbar__social{width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);font-size:11px;transition:all .2s}
.cc-topbar__social:hover{border-color:#fff;color:#fff;background:rgba(255,255,255,.1)}
.cc-topbar__info{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.cc-topbar__item{display:flex;align-items:center;gap:7px;color:rgba(255,255,255,.68);font-size:12.5px}
.cc-topbar__item i{color:rgba(255,255,255,.45);font-size:11px}
.cc-topbar__item a{color:rgba(255,255,255,.68);transition:color .2s}
.cc-topbar__item a:hover{color:#fff}
.cc-topbar__appt{background:var(--crimson);color:#fff!important;padding:7px 16px;border-radius:var(--r-sm);font-size:11px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;transition:background .2s}
.cc-topbar__appt:hover{background:var(--crimson-dark)}

/* ══════════════════════════════════════
   NAVIGATION
══════════════════════════════════════ */
.cc-nav{position:sticky;top:0;z-index:900;background:#fff;box-shadow:0 2px 16px rgba(2,30,89,.10);border-bottom:2px solid var(--crimson)}
.cc-nav__inner{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h)}
.cc-nav__brand img{height:44px;width:auto}
.cc-nav__menu{display:flex;align-items:center;gap:2px}
.cc-nav__item{position:relative}

.cc-nav__link{display:flex;align-items:center;gap:5px;height:var(--nav-h);padding:0 14px;font-size:13.5px;font-weight:500;color:var(--gray-mid);white-space:nowrap;transition:color .2s;position:relative}
.cc-nav__link::after{content:'';position:absolute;bottom:0;left:12px;right:12px;height:2px;background:var(--crimson);border-radius:2px 2px 0 0;transform:scaleX(0);transition:transform .22s}
.cc-nav__link:hover,.cc-nav__item.active .cc-nav__link{color:var(--crimson)}
.cc-nav__link:hover::after,.cc-nav__item.active .cc-nav__link::after{transform:scaleX(1)}

.cc-nav__arrow{display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;transition:transform .2s;flex-shrink:0;opacity:.5;margin-left:2px}
.cc-nav__item:hover .cc-nav__arrow{transform:rotate(180deg)}

/* ── MEGA MENU — hover-to-change-details ── */
.cc-megamenu{
    position:absolute;top:calc(var(--nav-h) + 2px);left:50%;transform:translateX(-50%);
    width:820px;background:#fff;
    border-top:3px solid var(--crimson);
    box-shadow:0 24px 64px rgba(2,30,89,.18);
    border-radius:0 0 var(--r-md) var(--r-md);
    display:none;z-index:1000;overflow:hidden;
}
.cc-nav__item:hover .cc-megamenu{display:flex}

/* Left: service list */
.cc-megamenu__sidebar{
    width:230px;flex-shrink:0;
    background:var(--warm-white);
    border-right:1px solid var(--border);
    padding:16px 0;
}
.cc-megamenu__sidebar-hd{
    font-size:10px;letter-spacing:.18em;text-transform:uppercase;
    color:var(--gray-soft);font-weight:600;
    padding:0 18px 12px;display:block;
    border-bottom:1px solid var(--border);margin-bottom:6px;
}

.cc-mm-item{
    display:flex;align-items:center;justify-content:space-between;
    padding:10px 18px;font-size:13.5px;
    color:var(--gray-mid);cursor:pointer;
    transition:all .18s;border-left:3px solid transparent;
    user-select:none;
}
.cc-mm-item:hover,.cc-mm-item.cc-active{
    background:var(--white);color:var(--crimson);
    border-left-color:var(--crimson);
}
.cc-mm-item__arrow{opacity:0;font-size:11px;transition:opacity .18s;color:var(--crimson)}
.cc-mm-item:hover .cc-mm-item__arrow,
.cc-mm-item.cc-active .cc-mm-item__arrow{opacity:1}

/* Right: detail panels */
.cc-megamenu__content{flex:1;position:relative;min-height:360px}
.cc-mm-panel{
    position:absolute;inset:0;padding:28px 30px;
    display:none;opacity:0;transition:opacity .22s ease;
}
.cc-mm-panel.cc-active{display:block;opacity:1}

.cc-mm-panel__img{width:100%;height:145px;object-fit:cover;border-radius:var(--r-sm);margin-bottom:14px}
.cc-mm-panel__title{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--brand);margin-bottom:9px;line-height:1.2}
.cc-mm-panel__desc{font-size:13.5px;line-height:1.75;color:var(--gray-mid);margin-bottom:14px}
.cc-mm-panel__features{display:grid;grid-template-columns:1fr 1fr;gap:5px 12px;margin-bottom:16px}
.cc-mm-panel__features li{font-size:12.5px;color:var(--gray-mid);display:flex;align-items:center;gap:7px}
.cc-mm-panel__features li::before{content:'';width:5px;height:5px;background:var(--crimson);border-radius:50%;flex-shrink:0}

/* ── MOBILE TOGGLE ── */
.cc-nav__toggle{display:none;flex-direction:column;gap:5px;padding:8px;background:none;border:none}
.cc-nav__toggle span{display:block;width:23px;height:2px;background:var(--brand);border-radius:2px;transition:all .3s}
.cc-nav__toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.cc-nav__toggle.open span:nth-child(2){opacity:0;width:0}
.cc-nav__toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ══════════════════════════════════════
   MOBILE MENU — single clean slide panel
══════════════════════════════════════ */
.cc-mobile-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:940;display:none;opacity:0;transition:opacity .3s}
.cc-mobile-backdrop.open{display:block;opacity:1}

.cc-mobile-menu{
    position:fixed;top:0;right:0;
    width:min(310px,100vw);height:100%;
    background:var(--brand);z-index:950;
    transform:translateX(100%);
    transition:transform .36s cubic-bezier(.4,0,.2,1);
    display:flex;flex-direction:column;
    box-shadow:-8px 0 40px rgba(2,30,89,.4);
    overflow:hidden;
}
.cc-mobile-menu.open{transform:translateX(0)}

/* Single header inside the panel — logo + close only */
.cc-mobile-menu__head{
    padding:14px 18px;background:#fff;
    border-bottom:2px solid var(--crimson);
    display:flex;align-items:center;justify-content:space-between;
    flex-shrink:0;
}
.cc-mobile-menu__head img{height:36px;width:auto}
.cc-mobile-menu__close-btn{
    width:34px;height:34px;border-radius:50%;
    background:none;border:1px solid rgba(2,30,89,.18);
    display:flex;align-items:center;justify-content:center;
    font-size:20px;color:var(--brand);line-height:1;transition:background .2s;
}
.cc-mobile-menu__close-btn:hover{background:var(--brand-light)}

/* Scrollable body */
.cc-mobile-menu__body{flex:1;overflow-y:auto;padding-bottom:16px}

.cc-mobile-menu__link{
    display:flex;align-items:center;justify-content:space-between;
    padding:15px 22px;
    font-family:var(--font-display);font-size:21px;font-weight:600;
    color:#fff;border-bottom:1px solid rgba(255,255,255,.07);
    transition:background .18s;
}
.cc-mobile-menu__link:hover{background:rgba(255,255,255,.05)}
.cc-mobile-menu__link--cta{background:var(--crimson);color:#fff;font-size:14px;font-family:var(--font-body);letter-spacing:.06em;text-transform:uppercase;justify-content:center}
.cc-mobile-menu__link--cta:hover{background:var(--crimson-dark)}

.cc-mobile-toggle-icon{font-size:16px;opacity:.55;transition:transform .25s;font-style:normal;flex-shrink:0}
.cc-mobile-menu__link.open .cc-mobile-toggle-icon{transform:rotate(180deg)}

.cc-mobile-sub{max-height:0;overflow:hidden;transition:max-height .35s ease;background:rgba(0,0,0,.18)}
.cc-mobile-sub.open{max-height:500px}
.cc-mobile-sub a{
    display:flex;align-items:center;gap:10px;
    padding:11px 30px;font-size:14px;
    color:rgba(255,255,255,.62);
    border-bottom:1px solid rgba(255,255,255,.04);
    transition:all .18s;
}
.cc-mobile-sub a::before{content:'';width:4px;height:4px;background:var(--crimson);border-radius:50%;flex-shrink:0}
.cc-mobile-sub a:hover{color:#fff;background:rgba(255,255,255,.05);padding-left:36px}

/* ══════════════════════════════════════
   HERO SLIDER
══════════════════════════════════════ */
.cc-hero{position:relative;overflow:hidden;background:var(--brand-dark)}
.cc-hero__track{display:flex;transition:transform .72s cubic-bezier(.4,0,.2,1)}
.cc-hero__slide{min-width:100%;position:relative;height:clamp(460px,82vh,780px);overflow:hidden}
.cc-hero__slide-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.06);transition:transform 7s ease}
.cc-hero__slide.cc-active .cc-hero__slide-img{transform:scale(1)}

.cc-hero__overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(2,18,64,.85) 0%,rgba(2,18,64,.52) 55%,rgba(2,18,64,.18) 100%)}
.cc-hero__slide--right .cc-hero__overlay{background:linear-gradient(-105deg,rgba(2,18,64,.85) 0%,rgba(2,18,64,.52) 55%,rgba(2,18,64,.18) 100%)}
.cc-hero__slide--center .cc-hero__overlay{background:radial-gradient(ellipse at center,rgba(2,18,64,.75) 0%,rgba(2,18,64,.38) 100%)}

.cc-hero__content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding:0 var(--pad);max-width:var(--container);margin:0 auto;left:0;right:0}
.cc-hero__slide--right .cc-hero__content{align-items:flex-end;text-align:right}
.cc-hero__slide--center .cc-hero__content{align-items:center;text-align:center}

.cc-hero__kicker,.cc-hero__title,.cc-hero__desc,.cc-hero__actions{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.cc-hero__slide.cc-active .cc-hero__kicker{opacity:1;transform:none;transition-delay:.2s}
.cc-hero__slide.cc-active .cc-hero__title{opacity:1;transform:none;transition-delay:.38s}
.cc-hero__slide.cc-active .cc-hero__desc{opacity:1;transform:none;transition-delay:.54s}
.cc-hero__slide.cc-active .cc-hero__actions{opacity:1;transform:none;transition-delay:.68s}

.cc-hero__kicker{display:inline-flex;align-items:center;gap:10px;margin-bottom:16px}
.cc-hero__kicker-line{width:32px;height:1px;background:rgba(255,255,255,.5)}
.cc-hero__kicker-text{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.75);font-weight:500}
.cc-hero__title{font-family:var(--font-display);font-size:clamp(32px,5vw,66px);font-weight:600;color:#fff;line-height:1.06;margin-bottom:14px;max-width:640px}
.cc-hero__title em{font-style:italic;color:#a8c0f0}
.cc-hero__desc{font-size:clamp(14px,1.4vw,16px);line-height:1.78;color:rgba(255,255,255,.70);max-width:500px;margin-bottom:32px}
.cc-hero__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.cc-hero__slide--right .cc-hero__actions{justify-content:flex-end}
.cc-hero__slide--center .cc-hero__actions{justify-content:center}

.cc-hero__btn{position:absolute;top:50%;transform:translateY(-50%);z-index:10;width:48px;height:48px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(8px);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;transition:all .22s}
.cc-hero__btn--prev{left:22px}
.cc-hero__btn--next{right:22px}
.cc-hero__btn:hover{background:var(--crimson);border-color:var(--crimson)}

.cc-hero__dots{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:10}
.cc-hero__dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.35);border:none;padding:0;transition:all .25s;cursor:pointer}
.cc-hero__dot.cc-active{background:#fff;width:26px;border-radius:4px}

/* ── STATS BAR ── */
.cc-statsbar{background:var(--brand)}
.cc-statsbar__grid{display:grid;grid-template-columns:repeat(4,1fr)}
.cc-statsbar__item{padding:26px 16px;text-align:center;border-right:1px solid rgba(255,255,255,.10)}
.cc-statsbar__item:last-child{border-right:none}
.cc-statsbar__num{font-family:var(--font-display);font-size:44px;font-weight:700;color:#fff;line-height:1;display:block}
.cc-statsbar__label{font-size:11px;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.48);margin-top:5px;display:block}

/* ── ABOUT ── */
.cc-about__grid{display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:center}
.cc-about__img-stack{position:relative;height:490px}
.cc-about__img-main{position:absolute;width:74%;height:400px;object-fit:cover;top:0;right:0;border-radius:var(--r-sm)}
.cc-about__img-secondary{position:absolute;width:52%;height:240px;object-fit:cover;bottom:0;left:0;border-radius:var(--r-sm);border:7px solid var(--cream);z-index:2}
.cc-about__badge{position:absolute;top:50%;left:-10px;transform:translateY(-50%);background:var(--crimson);color:#fff;padding:20px 18px;text-align:center;width:128px;z-index:3;border-radius:var(--r-sm)}
.cc-about__badge-num{font-family:var(--font-display);font-size:38px;font-weight:700;line-height:1;display:block}
.cc-about__badge-label{font-size:10px;letter-spacing:.1em;text-transform:uppercase;opacity:.88;margin-top:5px;line-height:1.3;display:block}
.cc-about__body{font-size:15px;line-height:1.85;color:var(--gray-mid);margin-top:18px;margin-bottom:16px}

.cc-motto{background:var(--brand);padding:20px 24px;border-left:3px solid var(--crimson);border-radius:0 var(--r-sm) var(--r-sm) 0;margin-top:24px}
.cc-motto__label{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.52);display:block;margin-bottom:6px}
.cc-motto__text{font-family:var(--font-display);font-size:21px;font-weight:500;font-style:italic;color:#fff}

/* ── MVV ── */
.cc-mvv__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(255,255,255,.05)}
.cc-mvv__card{background:var(--brand);padding:42px 34px;position:relative;overflow:hidden;transition:background .3s}
.cc-mvv__card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--crimson);opacity:0;transition:opacity .3s}
.cc-mvv__card:hover{background:rgba(1,18,64,.95)}
.cc-mvv__card:hover::before{opacity:1}
.cc-mvv__icon{width:48px;height:48px;background:rgba(255,255,255,.08);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.cc-mvv__icon i{font-size:20px;color:rgba(255,255,255,.75)}
.cc-mvv__kicker{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.48);display:block;margin-bottom:9px}
.cc-mvv__title{font-family:var(--font-display);font-size:24px;font-weight:600;color:#fff;margin-bottom:12px;line-height:1.2}
.cc-mvv__body{font-size:14px;line-height:1.8;color:rgba(255,255,255,.50)}

/* ── VALUES ── */
.cc-values__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.cc-value__card{background:#fff;padding:30px 18px;text-align:center;border-bottom:2px solid transparent;border-radius:var(--r-sm);box-shadow:var(--shadow-sm);transition:all .3s}
.cc-value__card:hover{border-bottom-color:var(--crimson);transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.cc-value__icon{width:50px;height:50px;background:var(--brand-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.cc-value__icon i{font-size:20px;color:var(--brand)}
.cc-value__title{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--brand);margin-bottom:8px}
.cc-value__desc{font-size:13px;line-height:1.7;color:var(--gray-soft)}

/* ── UNITS ── */
.cc-units__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.cc-unit__card{background:#fff;border-radius:var(--r-sm);overflow:hidden;display:grid;grid-template-columns:88px 1fr;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:all .3s}
.cc-unit__card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.cc-unit__side{background:var(--brand);display:flex;align-items:center;justify-content:center;min-height:148px;position:relative;overflow:hidden}
.cc-unit__side-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.35}
.cc-unit__side-icon{position:relative;z-index:1;color:#fff;font-size:28px;opacity:.9}
.cc-unit__body{padding:22px 24px}
.cc-unit__label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--crimson);font-weight:600;display:block;margin-bottom:5px}
.cc-unit__title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--brand);margin-bottom:7px;line-height:1.2}
.cc-unit__desc{font-size:13px;line-height:1.7;color:var(--gray-soft)}
.cc-unit__link{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--crimson);display:inline-block;margin-top:10px}
.cc-unit__link:hover{opacity:.8}

/* ── SERVICES ── */
.cc-services__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(255,255,255,.05)}
.cc-service__card{background:rgba(255,255,255,.03);padding:38px 30px;position:relative;overflow:hidden;transition:background .3s}
.cc-service__card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--crimson);transform:scaleX(0);transition:transform .3s}
.cc-service__card:hover{background:rgba(255,255,255,.06)}
.cc-service__card:hover::after{transform:scaleX(1)}
.cc-service__icon{width:52px;height:52px;background:rgba(255,255,255,.08);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;margin-bottom:17px}
.cc-service__icon i{font-size:22px;color:rgba(255,255,255,.80)}
.cc-service__title{font-family:var(--font-display);font-size:21px;font-weight:600;color:#fff;margin-bottom:9px;line-height:1.2}
.cc-service__desc{font-size:13.5px;line-height:1.75;color:rgba(255,255,255,.46)}

/* ── FUNFACTS ── */
.cc-funfacts{position:relative;overflow:hidden}
.cc-funfacts__bg{position:absolute;inset:0;background:url('../images/cardio-9.jpg') center/cover no-repeat;filter:brightness(.22)}
.cc-funfacts__overlay{position:absolute;inset:0;background:rgba(2,18,64,.72)}
.cc-funfacts__inner{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr)}
.cc-funfact{text-align:center;padding:68px 20px;border-right:1px solid rgba(255,255,255,.08)}
.cc-funfact:last-child{border-right:none}
.cc-funfact__icon{font-size:30px;color:rgba(255,255,255,.38);margin-bottom:13px;display:block}
.cc-funfact__num{font-family:var(--font-display);font-size:58px;font-weight:700;color:#fff;line-height:1;display:block}
.cc-funfact__label{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.48);margin-top:7px;display:block;font-weight:600}

/* ── WHY US ── */
.cc-why__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cc-why__card{background:#fff;padding:32px 22px;border-radius:var(--r-sm);box-shadow:var(--shadow-sm);border-top:3px solid var(--brand);transition:all .3s}
.cc-why__card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-top-color:var(--crimson)}
.cc-why__icon{font-size:30px;color:var(--brand);margin-bottom:12px;display:block;transition:color .3s}
.cc-why__card:hover .cc-why__icon{color:var(--crimson)}
.cc-why__title{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--brand);margin-bottom:8px}
.cc-why__desc{font-size:13.5px;line-height:1.75;color:var(--gray-soft)}

/* ── TESTIMONIALS ── */
.cc-testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cc-testimonial__card{background:#fff;padding:30px 26px;border-radius:var(--r-sm);box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:all .3s}
.cc-testimonial__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.cc-testimonial__quote{font-family:var(--font-display);font-size:66px;color:var(--brand);opacity:.09;line-height:.6;margin-bottom:12px;display:block}
.cc-testimonial__text{font-family:var(--font-display);font-size:16px;font-style:italic;line-height:1.75;color:var(--gray-mid);margin-bottom:20px}
.cc-testimonial__author{display:flex;align-items:center;gap:12px}
.cc-testimonial__avatar{width:44px;height:44px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--brand-light)}
.cc-testimonial__name{font-weight:600;font-size:14px;color:var(--brand);display:block}
.cc-testimonial__org{font-size:12px;color:var(--gray-soft);display:block}

/* ── FAQ ── */
.cc-faq__grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:start}
.cc-faq__item{border-bottom:1px solid rgba(2,30,89,.09)}
.cc-faq__question{width:100%;background:none;border:none;padding:18px 0;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-display);font-size:17px;font-weight:600;color:var(--brand);text-align:left;gap:12px;cursor:pointer}
.cc-faq__icon{width:26px;height:26px;flex-shrink:0;border:1px solid var(--brand);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--brand);font-size:17px;font-style:normal;font-family:monospace;transition:all .2s}
.cc-faq__item.open .cc-faq__icon{background:var(--crimson);border-color:var(--crimson);color:#fff}
.cc-faq__answer{max-height:0;overflow:hidden;transition:max-height .35s ease}
.cc-faq__answer-inner{padding-bottom:16px;font-size:14px;line-height:1.8;color:var(--gray-mid)}
.cc-faq__item.open .cc-faq__answer{max-height:220px}

/* ── CONTACT CARD ── */
.cc-contact__card{background:var(--brand);padding:38px 36px;border-radius:var(--r-sm)}
.cc-contact__title{font-family:var(--font-display);font-size:28px;font-weight:600;color:#fff;margin-bottom:3px}
.cc-contact__sub{font-size:13px;color:rgba(255,255,255,.42);margin-bottom:26px}
.cc-contact__item{display:flex;align-items:flex-start;gap:14px;margin-bottom:18px}
.cc-contact__icon{width:37px;height:37px;background:rgba(255,255,255,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cc-contact__icon i{font-size:13px;color:rgba(255,255,255,.65)}
.cc-contact__label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.42);display:block;margin-bottom:3px}
.cc-contact__value{font-size:14px;color:rgba(255,255,255,.80)}
.cc-contact__divider{height:1px;background:rgba(255,255,255,.07);margin:20px 0}
.cc-hours__row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.05);color:rgba(255,255,255,.55);font-size:13px}
.cc-hours__row:last-child{border-bottom:none}
.cc-hours__val{color:rgba(255,255,255,.85)}
.cc-hours__val--red{color:#f87171}

/* ── TABS ── */
.cc-tabs__nav{display:flex;border-bottom:1px solid var(--border);overflow-x:auto}
.cc-tabs__btn{padding:14px 22px;font-size:13px;font-weight:500;color:var(--gray-soft);background:none;border:none;border-bottom:2px solid transparent;white-space:nowrap;transition:all .2s;cursor:pointer;margin-bottom:-1px}
.cc-tabs__btn.active,.cc-tabs__btn:hover{color:var(--crimson);border-bottom-color:var(--crimson)}
.cc-tabs__pane{display:none;padding:38px 0}
.cc-tabs__pane.active{display:block}
.cc-tabs__pane-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.cc-tabs__pane-img{border-radius:var(--r-sm);overflow:hidden}
.cc-tabs__pane-img img{width:100%;height:320px;object-fit:cover}

/* ── NEWS ── */
.cc-news__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cc-news__card{background:#fff;border-radius:var(--r-sm);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:all .3s}
.cc-news__card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.cc-news__img-wrap{position:relative;overflow:hidden;height:190px}
.cc-news__img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.cc-news__card:hover .cc-news__img-wrap img{transform:scale(1.06)}
.cc-news__date-badge{position:absolute;top:13px;left:13px;background:var(--crimson);color:#fff;padding:6px 11px;text-align:center;border-radius:var(--r-sm);line-height:1}
.cc-news__date-day{font-size:20px;font-weight:700;display:block}
.cc-news__date-mon{font-size:10px;text-transform:uppercase;letter-spacing:.1em;display:block;margin-top:2px}
.cc-news__body{padding:18px}
.cc-news__meta{display:flex;gap:12px;margin-bottom:8px}
.cc-news__meta-item{font-size:11.5px;color:var(--gray-soft);display:flex;align-items:center;gap:5px}
.cc-news__title{font-family:var(--font-display);font-size:19px;font-weight:700;color:var(--brand);margin-bottom:8px;line-height:1.3;transition:color .2s}
.cc-news__card:hover .cc-news__title{color:var(--crimson)}
.cc-news__excerpt{font-size:13px;line-height:1.7;color:var(--gray-soft);margin-bottom:12px}
.cc-news__read-more{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--crimson)}

/* ── FOOTER ── */
.cc-footer{background:#040f2e;color:rgba(255,255,255,.48)}
.cc-footer__main{padding:72px 0 52px}
.cc-footer__grid{display:grid;grid-template-columns:2.1fr 1fr 1fr 1.5fr;gap:50px}
.cc-footer__brand-tag{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.38);display:block;margin-bottom:14px}
.cc-footer__desc{font-size:13.5px;line-height:1.8;margin-bottom:22px}
.cc-footer__socials{display:flex;gap:9px}
.cc-footer__social{width:33px;height:33px;border-radius:50%;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;font-size:12px;color:rgba(255,255,255,.42);transition:all .2s}
.cc-footer__social:hover{border-color:rgba(255,255,255,.5);color:#fff;background:rgba(255,255,255,.07)}
.cc-footer__col-title{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#fff;font-weight:600;margin-bottom:18px;display:block}
.cc-footer__links{display:flex;flex-direction:column;gap:8px}
.cc-footer__links a{font-size:13.5px;color:rgba(255,255,255,.46);transition:color .2s;display:flex;align-items:center;gap:8px}
.cc-footer__links a:hover{color:rgba(255,255,255,.88)}
.cc-footer__links a::before{content:'';width:4px;height:4px;background:var(--crimson);border-radius:50%;flex-shrink:0}
.cc-footer__newsletter input{width:100%;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);padding:12px 13px;color:#fff;font-size:13px;border-radius:var(--r-sm);margin-bottom:8px;font-family:var(--font-body);transition:border-color .2s}
.cc-footer__newsletter input::placeholder{color:rgba(255,255,255,.26)}
.cc-footer__newsletter input:focus{outline:none;border-color:rgba(255,255,255,.32)}
.cc-footer__newsletter button{width:100%;background:var(--crimson);color:#fff;border:none;padding:13px;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;border-radius:var(--r-sm);font-family:var(--font-body);transition:background .2s}
.cc-footer__newsletter button:hover{background:var(--crimson-dark)}
.cc-footer__bottom{border-top:1px solid rgba(255,255,255,.06);padding:18px 0}
.cc-footer__bottom-inner{display:flex;justify-content:space-between;align-items:center;font-size:12px;flex-wrap:wrap;gap:8px}
.cc-footer__motto{font-family:var(--font-display);font-size:14px;font-style:italic;color:rgba(255,255,255,.48)}

/* ── PAGE HERO (inner pages) ── */
.cc-page-hero{position:relative;height:290px;background:var(--brand);display:flex;align-items:center;overflow:hidden}
.cc-page-hero__img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.25}
.cc-page-hero__overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(2,18,64,.88),rgba(2,18,64,.45))}
.cc-page-hero__content{position:relative;z-index:2}
.cc-page-hero__title{font-family:var(--font-display);font-size:clamp(28px,4vw,50px);font-weight:600;color:#fff;margin-bottom:11px}
.cc-breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px}
.cc-breadcrumb a{color:rgba(255,255,255,.52);transition:color .2s}
.cc-breadcrumb a:hover{color:#fff}
.cc-breadcrumb__sep{color:rgba(255,255,255,.28)}
.cc-breadcrumb__current{color:rgba(255,255,255,.82)}

/* ── SCROLL REVEAL ── */
.cc-reveal{opacity:0;transform:translateY(22px);transition:opacity .68s ease,transform .68s ease}
.cc-reveal.visible{opacity:1;transform:translateY(0)}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:1100px){
    :root{--pad:32px;--section-pad:72px}
    .cc-about__grid,.cc-faq__grid{grid-template-columns:1fr;gap:40px}
    .cc-about__img-stack{height:380px}
    .cc-values__grid{grid-template-columns:repeat(3,1fr)}
    .cc-why__grid{grid-template-columns:repeat(2,1fr)}
    .cc-footer__grid{grid-template-columns:1fr 1fr;gap:32px}
    .cc-tabs__pane-inner{gap:28px}
}

@media(max-width:900px){
    :root{--section-pad:58px}
    .cc-nav__menu{display:none}
    .cc-nav__toggle{display:flex}
    .cc-statsbar__grid{grid-template-columns:repeat(2,1fr)}
    .cc-statsbar__item{border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
    .cc-statsbar__item:nth-child(odd){border-right:1px solid rgba(255,255,255,.08)}
    .cc-statsbar__item:last-child{border-bottom:none}
    .cc-mvv__grid{grid-template-columns:1fr;gap:2px}
    .cc-units__grid{grid-template-columns:1fr}
    .cc-services__grid{grid-template-columns:repeat(2,1fr)}
    .cc-testimonials__grid{grid-template-columns:1fr 1fr;gap:14px}
    .cc-news__grid{grid-template-columns:1fr 1fr;gap:14px}
    .cc-funfacts__inner{grid-template-columns:repeat(2,1fr)}
    .cc-funfact{border-right:none;border-bottom:1px solid rgba(255,255,255,.07)}
    .cc-funfact:nth-child(odd){border-right:1px solid rgba(255,255,255,.07)}
    .cc-tabs__pane-inner{grid-template-columns:1fr}
    .cc-hero__btn{width:38px;height:38px;font-size:14px}
    .cc-hero__btn--prev{left:10px}
    .cc-hero__btn--next{right:10px}
}

@media(max-width:640px){
    :root{--section-pad:48px;--pad:18px}
    .cc-topbar__info{display:none}
    .cc-topbar__appt{display:none}
    .cc-topbar .cc-container{justify-content:center}
    .cc-hero__slide{height:clamp(400px,90vw,530px)}
    .cc-hero__btn{display:none}
    .cc-hero__title{font-size:clamp(26px,7.5vw,38px)}
    .cc-hero__desc{font-size:14px}
    .cc-hero__actions .cc-btn{padding:11px 22px;font-size:11px}
    /* About image stack simplified on mobile */
    .cc-about__img-stack{height:auto;position:static}
    .cc-about__img-main{position:static;width:100%;height:240px}
    .cc-about__img-secondary{display:none}
    .cc-about__badge{position:static;transform:none;display:flex;flex-direction:row;align-items:center;gap:10px;width:auto;padding:10px 16px;margin-top:-22px}
    .cc-about__badge-num{font-size:26px}
    .cc-services__grid{grid-template-columns:1fr}
    .cc-values__grid{grid-template-columns:1fr 1fr}
    .cc-why__grid{grid-template-columns:1fr}
    .cc-testimonials__grid{grid-template-columns:1fr}
    .cc-news__grid{grid-template-columns:1fr}
    .cc-funfacts__inner{grid-template-columns:1fr 1fr}
    .cc-faq__grid{grid-template-columns:1fr;gap:32px}
    .cc-footer__grid{grid-template-columns:1fr;gap:26px}
    .cc-footer__bottom-inner{flex-direction:column;text-align:center}
    .cc-units__grid{grid-template-columns:1fr}
    .cc-unit__card{grid-template-columns:70px 1fr}
    .cc-unit__side{min-height:115px}
    .cc-statsbar__num{font-size:36px}
}

@media(max-width:400px){
    .cc-values__grid{grid-template-columns:1fr}
    .cc-funfacts__inner{grid-template-columns:1fr}
    .cc-funfact{border-right:none!important;border-bottom:1px solid rgba(255,255,255,.07)}
}