/* ================================================================
   MEDISCAN THEME CSS v1.0
   Complete shared styles for all pages
   ================================================================ */

/* ================================================================
   1. ROOT VARIABLES
   ================================================================ */
:root {
  --blue: #0075ba;
  --blue-dark: #005a91;
  --blue-deeper: #003d66;
  --blue-light: #e8f4fd;
  --blue-50: rgba(0,117,186,.05);
  --blue-10: rgba(0,117,186,.1);
  --green: #79AE2D;
  --green-dark: #638e24;
  --green-light: #f2f8e8;
  --green-50: rgba(121,174,45,.05);
  --green-10: rgba(121,174,45,.1);
  --dark: #0f172a;
  --dark-800: #1e293b;
  --dark-700: #334155;
  --text: #475569;
  --text-light: #94a3b8;
  --white: #fff;
  --bg: #fff;
  --bg-alt: #f8fafc;
  --border: #e2e8f0;
  --border-light: #f1f5f9;
  --shadow-sm: 0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
  --shadow: 0 4px 6px -1px rgba(15,23,42,.07), 0 2px 4px -2px rgba(15,23,42,.05);
  --shadow-md: 0 10px 15px -3px rgba(15,23,42,.08), 0 4px 6px -4px rgba(15,23,42,.04);
  --shadow-lg: 0 20px 25px -5px rgba(15,23,42,.08), 0 8px 10px -6px rgba(15,23,42,.04);
  --shadow-xl: 0 25px 50px -12px rgba(15,23,42,.18);
  --glow-blue: 0 8px 32px rgba(0,117,186,.18);
  --glow-green: 0 8px 32px rgba(121,174,45,.18);
  --r-sm: 8px;
  --r: 12px;
  --r-lg: 16px;
  --r-xl: 24px;
  --r-2xl: 32px;
  --r-full: 9999px;
  --ease: cubic-bezier(.4,0,.2,1);
  --ease-out: cubic-bezier(0,0,.2,1);
  --ease-bounce: cubic-bezier(.34,1.56,.64,1);
  --font-h: 'Plus Jakarta Sans', sans-serif;
  --font-b: 'Inter', sans-serif;
  --max-w: 1280px;
  --header-h: 80px;
  --topbar-h: 42px;
}

/* ================================================================
   2. RESET & BASE
   ================================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-b);font-size:16px;line-height:1.7;color:var(--text);background:var(--bg);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit;transition:all .3s var(--ease)}
ul,ol{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;outline:none;background:none}
input,textarea,select{font-family:inherit;outline:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-h);color:var(--dark);line-height:1.2;font-weight:700}
::selection{background:var(--blue);color:#fff}

/* ================================================================
   3. UTILITIES
   ================================================================ */
.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 24px}
.section{padding:100px 0}
.section-label{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--blue);background:linear-gradient(135deg,var(--blue-light),rgba(121,174,45,.08));padding:10px 22px;border-radius:var(--r-full);margin-bottom:20px;border:1px solid rgba(0,117,186,.08)}
.section-label i{font-size:8px}
.section-title{font-size:clamp(30px,4.2vw,46px);margin-bottom:18px;letter-spacing:-.02em}
.section-title .tg{background:linear-gradient(135deg,var(--blue),var(--green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.section-sub{font-size:17px;color:var(--text);max-width:620px;line-height:1.85}
.section-header{text-align:center;margin-bottom:64px}
.section-header .section-sub{margin:0 auto}

/* ================================================================
   4. BUTTONS
   ================================================================ */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-h);font-size:15px;font-weight:600;padding:15px 34px;border-radius:var(--r-full);transition:all .4s var(--ease);position:relative;overflow:hidden}
.btn::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s}
.btn:hover::before{left:100%}
.btn-primary{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;box-shadow:var(--glow-blue)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,117,186,.3)}
.btn-green{background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;box-shadow:var(--glow-green)}
.btn-green:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(121,174,45,.3)}
.btn-outline{border:2px solid var(--border);color:var(--dark);background:transparent}
.btn-outline:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-50);transform:translateY(-3px)}
.btn-white{background:rgba(255,255,255,.95);color:var(--dark);backdrop-filter:blur(10px);box-shadow:var(--shadow)}
.btn-white:hover{background:#fff;transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.btn-ghost{color:#fff;border:2px solid rgba(255,255,255,.25);background:rgba(255,255,255,.06);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.4);transform:translateY(-3px)}
.btn-signin{background:var(--white);color:var(--blue);border:2px solid var(--blue);padding:11px 28px;font-size:14px}
.btn-signin i{font-size:15px}
.btn-signin:hover{background:var(--blue);color:#fff;transform:translateY(-2px);box-shadow:var(--glow-blue)}
.btn-sm{padding:11px 24px;font-size:14px}
.btn i{font-size:13px;transition:transform .3s var(--ease)}
.btn:hover i{transform:translateX(4px)}
.btn-view{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;border-radius:var(--r);box-shadow:var(--glow-blue)}
.btn-view:hover{box-shadow:0 12px 40px rgba(0,117,186,.3)}
.btn-dir{background:var(--bg-alt);color:var(--dark);border:1px solid var(--border);border-radius:var(--r)}
.btn-dir:hover{border-color:var(--green);color:var(--green);background:var(--green-50)}

/* ================================================================
   5. ANIMATIONS
   ================================================================ */
.reveal{opacity:0;transform:translateY(50px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.revealed{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-50px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-left.revealed{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(50px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-right.revealed{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(.92);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal-scale.revealed{opacity:1;transform:scale(1)}

/* ================================================================
   6. ACCENT LINE
   ================================================================ */
.accent-line{height:4px;background:linear-gradient(90deg,var(--blue),var(--green),var(--blue));background-size:200% 100%;animation:gradientShift 4s ease infinite;position:relative;z-index:10001}
@keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}

/* ================================================================
   7. TOP BAR
   ================================================================ */
.top-bar{background:linear-gradient(135deg,var(--dark),var(--dark-800));color:rgba(255,255,255,.75);font-size:13px;padding:10px 0;position:relative;z-index:10000;height:var(--topbar-h);display:flex;align-items:center}
.top-bar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.tb-left{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.tb-left a,.tb-left span{display:inline-flex;align-items:center;gap:7px;color:rgba(255,255,255,.75);font-size:13px}
.tb-left a:hover{color:var(--green)}
.tb-left i{color:var(--green);font-size:12px}
.tb-right{display:flex;gap:6px}
.tb-right a{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.06);color:rgba(255,255,255,.6);font-size:13px;transition:all .3s var(--ease)}
.tb-right a:hover{background:var(--green);color:#fff;transform:translateY(-2px) scale(1.1)}

/* ================================================================
   8. HEADER & NAVIGATION
   ================================================================ */
.header{position:sticky;top:0;z-index:9999;background:rgba(255,255,255,.92);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid transparent;transition:all .4s var(--ease);height:var(--header-h)}
.header.scrolled{border-bottom-color:rgba(0,0,0,.06);box-shadow:0 4px 30px rgba(0,0,0,.06);height:70px}
.header .container{display:flex;align-items:center;justify-content:space-between;height:100%}
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.logo-img{width:48px;height:48px;border-radius:var(--r);background:linear-gradient(135deg,var(--blue),var(--green));display:flex;align-items:center;justify-content:center;transition:transform .3s var(--ease);overflow:hidden}
.logo:hover .logo-img{transform:scale(1.05)}
.logo-img .lp{color:#fff;font-size:22px;font-weight:900;font-family:var(--font-h)}
.logo-img img{width:100%;height:100%;object-fit:contain}
.logo-txt{display:flex;flex-direction:column}
.logo-txt .brand{font-family:var(--font-h);font-size:22px;font-weight:800;color:var(--dark);line-height:1.1}
.logo-txt .brand span{color:var(--blue)}
.logo-txt .tag{font-size:10px;color:var(--text-light);letter-spacing:1.5px;text-transform:uppercase;font-weight:600}
.nav{display:flex;align-items:center;gap:2px}
.nav>li{position:relative}
.nav>li>a{display:flex;align-items:center;gap:5px;padding:10px 18px;font-size:15px;font-weight:500;color:var(--dark-700);border-radius:var(--r);transition:all .3s var(--ease);position:relative}
.nav>li>a::after{content:'';position:absolute;bottom:4px;left:18px;right:18px;height:2px;background:linear-gradient(90deg,var(--blue),var(--green));border-radius:1px;transform:scaleX(0);transition:transform .3s var(--ease)}
.nav>li>a:hover,.nav>li>a.active{color:var(--blue)}
.nav>li>a:hover::after,.nav>li>a.active::after{transform:scaleX(1)}
.nav>li>a .chv{font-size:10px;transition:transform .3s;color:var(--text-light)}
.nav>li:hover>a .chv{transform:rotate(180deg);color:var(--blue)}
.dropdown{position:absolute;top:calc(100% + 12px);left:0;min-width:280px;background:rgba(255,255,255,.98);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:var(--r-lg);box-shadow:0 20px 60px rgba(0,0,0,.12),0 0 0 1px rgba(0,0,0,.04);padding:12px;opacity:0;visibility:hidden;transform:translateY(12px);transition:all .35s var(--ease);z-index:999999}
.dropdown::before{content:'';position:absolute;top:-8px;left:30px;width:16px;height:16px;background:rgba(255,255,255,.88);border-radius:3px;transform:rotate(45deg);box-shadow:-2px -2px 4px rgba(0,0,0,.03)}
.nav>li:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown a{display:flex;align-items:center;gap:14px;padding:12px 16px;font-size:14px;font-weight:500;color:var(--dark-700);border-radius:var(--r-sm);transition:all .25s var(--ease)}
.dropdown a:hover{background:linear-gradient(135deg,var(--blue-50),var(--green-50));color:var(--blue);padding-left:22px}
.dropdown a i{width:20px;text-align:center;font-size:16px;color:var(--blue);opacity:.6;transition:opacity .3s}
.dropdown a:hover i{opacity:1}
.dropdown-divider{height:1px;background:var(--border-light);margin:6px 0}
.header-right{display:flex;align-items:center;gap:14px}
.hamburger{display:none;width:44px;height:44px;align-items:center;justify-content:center;border-radius:var(--r);background:var(--bg-alt);flex-direction:column;gap:5px;cursor:pointer;transition:all .3s}
.hamburger:hover{background:var(--blue-light)}
.hamburger span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:all .3s var(--ease)}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ================================================================
   9. MOBILE MENU
   ================================================================ */
.mob-ov{position:fixed;top:0;left:0;width:100%;height:100vh;background:rgba(15,23,42,.6);backdrop-filter:blur(6px);z-index:99998;opacity:0;visibility:hidden;transition:all .4s var(--ease)}
.mob-ov.open{opacity:1;visibility:visible}
.mob-pnl{position:absolute;top:0;right:0;width:min(400px,88vw);height:100%;background:#fff;transform:translateX(100%);transition:transform .45s var(--ease);overflow-y:auto;display:flex;flex-direction:column}
.mob-ov.open .mob-pnl{transform:translateX(0)}
.mob-top{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}
.mob-close{width:40px;height:40px;border-radius:var(--r);background:var(--bg-alt);display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--dark);transition:all .3s}
.mob-close:hover{background:#fee2e2;color:#ef4444}
.mob-body{flex:1;padding:16px 24px;overflow-y:auto}
.mob-nav>li{border-bottom:1px solid var(--border-light)}
.mob-nav>li>a{display:flex;align-items:center;justify-content:space-between;padding:16px 0;font-size:16px;font-weight:600;color:var(--dark);font-family:var(--font-h);transition:color .3s}
.mob-nav>li>a:hover{color:var(--blue)}
.mob-nav>li>a .mc{font-size:12px;color:var(--text-light);transition:all .3s}
.mob-nav>li.open>a .mc{transform:rotate(180deg);color:var(--blue)}
.mob-sub{max-height:0;overflow:hidden;transition:max-height .35s ease;padding:0 0 0}
.mob-sub a{display:flex;align-items:center;gap:12px;padding:11px 14px;font-size:14px;color:var(--text);border-radius:var(--r-sm);margin-bottom:2px;transition:all .25s}
.mob-sub a:hover{background:var(--blue-light);color:var(--blue)}
.mob-sub a i{width:20px;text-align:center;color:var(--blue);font-size:15px;opacity:.6}
.mob-foot{padding:20px 24px;border-top:1px solid var(--border)}
.mob-foot .btn{width:100%;justify-content:center;margin-bottom:14px}
.mob-foot-info{display:flex;flex-direction:column;gap:12px}
.mob-foot-info a{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--text)}
.mob-foot-info a i{color:var(--green);width:20px;text-align:center}

/* ================================================================
   10. HERO SLIDER (Homepage)
   ================================================================ */
.hero{position:relative;overflow:hidden;background:var(--dark)}
.hero-slide{min-height:calc(100vh - var(--header-h) - var(--topbar-h) - 4px);display:flex;align-items:center;padding:60px 0 100px;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.15);transform:scale(1.05)}
.hero-bg-ov{position:absolute;inset:0}
.hero-slide .container{display:flex;align-items:center;gap:60px;position:relative;z-index:2}
.hero-content{flex:1;max-width:640px}
.hero-badge{display:inline-flex;align-items:center;gap:10px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(10px);padding:8px 22px 8px 8px;border-radius:var(--r-full);font-size:13px;font-weight:600;color:rgba(255,255,255,.9);margin-bottom:28px}
.hero-badge-icon{width:30px;height:30px;border-radius:50%;background:var(--green);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px}
.hero-title{font-size:clamp(36px,5.2vw,62px);font-weight:900;line-height:1.08;margin-bottom:24px;color:#fff;letter-spacing:-.03em}
.hero-title .hl{background:linear-gradient(135deg,#7dd3fc,var(--green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-desc{font-size:17px;line-height:1.85;color:rgba(255,255,255,.75);margin-bottom:40px;max-width:540px}
.hero-btns{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hero-stats-row{display:flex;gap:40px;margin-top:52px;padding-top:32px;border-top:1px solid rgba(255,255,255,.12)}
.hero-stat .num{font-family:var(--font-h);font-size:32px;font-weight:900;color:#fff}
.hero-stat .num span{color:var(--green)}
.hero-stat .lbl{font-size:13px;color:rgba(255,255,255,.5);margin-top:2px}
.hero-visual{flex:1;position:relative;display:flex;justify-content:center;align-items:center;min-height:500px}
.hero-card-main{width:400px;height:480px;border-radius:var(--r-2xl);overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.1)}
.hero-card-main img{width:100%;height:100%;object-fit:cover}
.hero-glass{position:absolute;background:rgba(255,255,255,.12);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:1px solid rgba(255,255,255,.18);border-radius:var(--r-lg);padding:18px 22px;display:flex;align-items:center;gap:14px;z-index:3;animation:glassFloat 5s ease-in-out infinite}
.hero-glass-1{top:30px;right:-20px;animation-delay:0s}
.hero-glass-2{bottom:50px;left:-40px;animation-delay:1.8s}
.hero-glass-3{top:55%;right:-50px;animation-delay:.9s}
@keyframes glassFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.hg-i{width:48px;height:48px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.hg-i.b{background:rgba(0,117,186,.2);color:#7dd3fc}
.hg-i.g{background:rgba(121,174,45,.2);color:#a3e635}
.hg-t .v{font-family:var(--font-h);font-size:20px;font-weight:800;color:#fff}
.hg-t .l{font-size:11px;color:rgba(255,255,255,.6)}
.hero-deco{position:absolute;border-radius:50%;z-index:0;pointer-events:none}
.hero-deco-1{width:600px;height:600px;background:radial-gradient(circle,rgba(0,117,186,.15),transparent 70%);top:-200px;right:-200px}
.hero-deco-2{width:400px;height:400px;background:radial-gradient(circle,rgba(121,174,45,.12),transparent 70%);bottom:-150px;left:5%}
.hero .swiper-pagination{bottom:30px!important}
.hero .swiper-pagination-bullet{width:36px;height:4px;border-radius:4px;background:rgba(255,255,255,.25);opacity:1;transition:all .4s}
.hero .swiper-pagination-bullet-active{width:52px;background:#fff}

/* ================================================================
   11. STATS BAR
   ================================================================ */
.stats-bar{position:relative;z-index:10;margin-top:-56px;margin-bottom:20px}
.stats-inner{background:rgba(255,255,255,.82);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:var(--r-2xl);box-shadow:0 20px 60px rgba(0,0,0,.08),0 0 0 1px rgba(0,0,0,.03);padding:42px 52px;display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.stat-item{text-align:center;position:relative}
.stat-item:not(:last-child)::after{content:'';position:absolute;right:-16px;top:50%;transform:translateY(-50%);width:1px;height:50px;background:linear-gradient(to bottom,transparent,var(--border),transparent)}
.stat-number{font-family:var(--font-h);font-size:clamp(34px,3.8vw,48px);font-weight:900;color:var(--dark);line-height:1;margin-bottom:6px}
.stat-number .ac{color:var(--green)}
.stat-number .ab{color:var(--blue)}
.stat-label{font-size:14px;color:var(--text-light);font-weight:500}

/* ================================================================
   12. ABOUT SECTION
   ================================================================ */
.about{background:var(--white);position:relative;overflow:hidden}
.about::before{content:'';position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,var(--blue-50),transparent 70%);top:-100px;right:-100px;pointer-events:none}
.about .container{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-visual{position:relative}
.about-main-img{border-radius:var(--r-2xl);overflow:hidden;aspect-ratio:4/3.2;box-shadow:var(--shadow-xl)}
.about-main-img img{width:100%;height:100%;object-fit:cover}
.about-accent{position:absolute;top:30px;left:-16px;width:6px;height:140px;border-radius:3px;background:linear-gradient(to bottom,var(--green),var(--blue))}
.about-badge{position:absolute;bottom:-24px;right:-24px;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;padding:26px 30px;border-radius:var(--r-xl);box-shadow:var(--glow-blue);text-align:center}
.about-badge .bn{font-family:var(--font-h);font-size:40px;font-weight:900;display:block;line-height:1}
.about-badge .bt{font-size:13px;opacity:.85;margin-top:6px}
.about-text{font-size:16px;color:var(--text);line-height:1.9;margin-bottom:24px}
.about-checks{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:36px}
.about-check{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-alt);border-radius:var(--r);border:1px solid var(--border-light);transition:all .35s var(--ease)}
.about-check:hover{background:var(--blue-light);border-color:rgba(0,117,186,.1);transform:translateX(4px)}
.about-check i{color:var(--green);font-size:16px;flex-shrink:0}
.about-check span{font-size:14px;font-weight:600;color:var(--dark)}

/* ================================================================
   13. SERVICE CARDS
   ================================================================ */
.services{position:relative;overflow:hidden;padding:100px 0 120px;background:linear-gradient(180deg,#f8fafc 0%,#eef5ff 40%,#f0fdf4 70%,#fff 100%)}
.services .bg-shapes{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.services .bg-shapes .shape{position:absolute;border-radius:50%}
.services .bg-shapes .s1{width:600px;height:600px;background:radial-gradient(circle,rgba(0,117,186,.05),transparent 65%);top:-200px;right:-200px}
.services .bg-shapes .s2{width:500px;height:500px;background:radial-gradient(circle,rgba(121,174,45,.04),transparent 65%);bottom:-150px;left:-150px}
.services .bg-shapes .s3{width:300px;height:300px;border:50px solid rgba(0,117,186,.02);top:30%;left:50%;transform:translateX(-50%)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;position:relative;z-index:2}
.svc-card{position:relative;border-radius:var(--r-xl);overflow:hidden;background:#fff;transition:all .5s var(--ease);cursor:pointer}
.svc-card::before{content:'';position:absolute;inset:-2px;z-index:-1;border-radius:calc(var(--r-xl) + 2px);background:linear-gradient(135deg,var(--blue),var(--green),var(--blue));background-size:300% 300%;opacity:0;transition:opacity .5s var(--ease)}
.svc-card:hover::before{opacity:1;animation:borderGlow 3s ease infinite}
@keyframes borderGlow{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.svc-card:hover{transform:translateY(-14px);box-shadow:0 30px 80px rgba(0,117,186,.12)}
.svc-card-img{height:240px;position:relative;overflow:hidden}
.svc-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease-out),filter .5s;filter:brightness(.92) saturate(1.05)}
.svc-card:hover .svc-card-img img{transform:scale(1.1);filter:brightness(1) saturate(1.15)}
.svc-card-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,23,42,.05) 0%,rgba(15,23,42,.15) 50%,rgba(15,23,42,.65) 100%);transition:all .5s}
.svc-card:hover .svc-card-img::after{background:linear-gradient(180deg,rgba(0,117,186,.1) 0%,rgba(0,117,186,.15) 40%,rgba(0,117,186,.6) 100%)}
.svc-num{position:absolute;top:18px;right:18px;z-index:5;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-size:14px;font-weight:800;color:#fff;transition:all .4s var(--ease)}
.svc-card:hover .svc-num{background:var(--green);border-color:var(--green);transform:rotate(360deg)}
.svc-img-title{position:absolute;bottom:0;left:0;right:0;z-index:5;padding:24px 28px;display:flex;align-items:center;gap:14px}
.svc-img-icon{width:52px;height:52px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;box-shadow:0 8px 24px rgba(0,0,0,.2);transition:all .4s var(--ease-bounce)}
.svc-img-icon.ib{background:linear-gradient(135deg,var(--blue),#0e8fd8);color:#fff}
.svc-img-icon.ig{background:linear-gradient(135deg,var(--green),#8cc63f);color:#fff}
.svc-card:hover .svc-img-icon{transform:scale(1.15) rotate(-10deg)}
.svc-img-title h3{font-size:22px;font-weight:800;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.2)}
.svc-body{padding:28px}
.svc-body p{font-size:14px;color:var(--text);line-height:1.85;margin-bottom:20px}
.svc-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.svc-tag{font-size:12px;font-weight:600;padding:6px 14px;border-radius:var(--r-full);transition:all .3s var(--ease)}
.svc-tag.blue{color:var(--blue);background:var(--blue-light);border:1px solid rgba(0,117,186,.08)}
.svc-tag.green{color:var(--green-dark);background:var(--green-light);border:1px solid rgba(121,174,45,.08)}
.svc-card:hover .svc-tag.blue{background:var(--blue);color:#fff;border-color:var(--blue)}
.svc-card:hover .svc-tag.green{background:var(--green);color:#fff;border-color:var(--green)}
.svc-cta{display:flex;align-items:center;justify-content:space-between;padding-top:20px;border-top:1px solid var(--border-light)}
.svc-cta-link{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:700;color:var(--blue);transition:all .3s var(--ease)}
.svc-cta-link:hover{gap:14px;color:var(--blue-dark)}
.svc-cta-link i{font-size:11px;transition:transform .3s}
.svc-card:hover .svc-cta-link i{transform:translateX(4px)}
.svc-cta-arrow{width:40px;height:40px;border-radius:50%;background:var(--blue-light);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .4s var(--ease)}
.svc-card:hover .svc-cta-arrow{background:var(--blue);color:#fff;transform:translateX(4px)}

/* ================================================================
   14. WHY CHOOSE US (Dark Section)
   ================================================================ */
.why-section{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--dark),var(--dark-800));color:#fff}
.why-section .pat{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(0,117,186,.15),transparent 50%),radial-gradient(circle at 80% 20%,rgba(121,174,45,.1),transparent 50%);pointer-events:none}
.why-section .container{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.why-content .section-label{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.1);color:#fff}
.why-content .section-title{color:#fff}
.why-content .section-sub{color:rgba(255,255,255,.65);margin-bottom:40px}
.why-features{display:flex;flex-direction:column;gap:18px}
.why-card{display:flex;gap:20px;padding:24px;border-radius:var(--r-lg);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(6px);transition:all .4s var(--ease)}
.why-card:hover{background:rgba(255,255,255,.08);border-color:rgba(121,174,45,.3);transform:translateX(8px)}
.wc-i{width:52px;height:52px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;transition:all .4s var(--ease)}
.wc-i.wb{background:rgba(0,117,186,.15);color:#7dd3fc}
.wc-i.wg{background:rgba(121,174,45,.15);color:#a3e635}
.why-card:hover .wc-i.wb{background:var(--blue);color:#fff}
.why-card:hover .wc-i.wg{background:var(--green);color:#fff}
.why-card h4{font-size:17px;font-weight:700;color:#fff;margin-bottom:6px}
.why-card p{font-size:14px;color:rgba(255,255,255,.55);line-height:1.7}
.why-visual{position:relative;display:flex;justify-content:center}
.why-img-card{width:100%;max-width:460px;aspect-ratio:3/4;border-radius:var(--r-2xl);overflow:hidden;border:1px solid rgba(255,255,255,.08);box-shadow:0 30px 80px rgba(0,0,0,.3)}
.why-img-card img{width:100%;height:100%;object-fit:cover}
.why-fb{position:absolute;bottom:30px;left:-30px;background:rgba(255,255,255,.12);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.15);border-radius:var(--r-lg);padding:22px 28px;display:flex;align-items:center;gap:14px;z-index:3}
.why-fb .bi{width:50px;height:50px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px}
.why-fb .bv{font-family:var(--font-h);font-size:24px;font-weight:900;color:#fff}
.why-fb .bl{font-size:12px;color:rgba(255,255,255,.6)}

/* ================================================================
   15. BRANCHES
   ================================================================ */
.branches{background:var(--bg-alt);position:relative;overflow:hidden}
.branch-filters{display:flex;justify-content:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.bf-btn{padding:12px 28px;border-radius:var(--r-full);font-family:var(--font-h);font-size:14px;font-weight:600;background:#fff;color:var(--text);border:2px solid var(--border);cursor:pointer;transition:all .35s}
.bf-btn.active,.bf-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:var(--glow-blue);transform:translateY(-2px)}
.branch-count{text-align:center;margin-bottom:40px;font-size:15px;color:var(--text)}
.branch-count strong{color:var(--blue);font-weight:800;font-size:18px}
.branch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.b-card{background:#fff;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);transition:all .5s var(--ease);display:flex;flex-direction:column;position:relative}
.b-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;z-index:2;background:linear-gradient(90deg,var(--blue),var(--green));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.b-card:hover{transform:translateY(-10px);box-shadow:0 24px 64px rgba(0,0,0,.1);border-color:transparent}
.b-card:hover::before{transform:scaleX(1)}
.b-visual{position:relative;height:160px;overflow:hidden;background:linear-gradient(135deg,var(--blue),var(--blue-dark))}
.b-visual.kerala-bg{background:linear-gradient(135deg,#0075ba,#00a8e8)}
.b-visual.karnataka-bg{background:linear-gradient(135deg,#79AE2D,#4a8c0f)}
.b-visual-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 80% 20%,rgba(255,255,255,.08),transparent 50%),radial-gradient(circle at 20% 80%,rgba(255,255,255,.05),transparent 50%)}
.b-visual-content{position:relative;z-index:2;padding:24px 28px;height:100%;display:flex;flex-direction:column;justify-content:space-between}
.b-visual-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.b-region-tag{padding:5px 14px;border-radius:var(--r-full);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:#fff;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.2);white-space:nowrap;flex-shrink:0}
.b-name{font-size:22px;font-weight:900;color:#fff;line-height:1.25;text-shadow:0 2px 8px rgba(0,0,0,.1)}
.b-visual-bottom{display:flex;align-items:center;gap:12px}
.b-partner-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:#fff;background:rgba(255,255,255,.15);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.2);padding:6px 14px;border-radius:var(--r-full)}
.b-partner-badge i{font-size:10px}
.b-visual-icon{position:absolute;bottom:-20px;right:20px;z-index:3;width:56px;height:56px;border-radius:50%;background:#fff;box-shadow:0 8px 24px rgba(0,0,0,.12);display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--blue);transition:all .4s var(--ease-bounce)}
.b-card:hover .b-visual-icon{transform:scale(1.1) rotate(-10deg)}
.b-body{padding:36px 28px 20px;flex:1;display:flex;flex-direction:column}
.b-contacts{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}
.b-contact{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--text)}
.b-contact i{width:32px;height:32px;border-radius:var(--r-sm);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;background:var(--bg-alt);color:var(--blue);transition:all .3s}
.b-card:hover .b-contact i{background:var(--blue-light)}
.b-contact a{color:var(--text);transition:color .3s}
.b-contact a:hover{color:var(--blue)}
.b-contact span{line-height:1.5}
.b-fac-header{display:flex;align-items:center;gap:8px;margin-bottom:14px;padding-top:20px;border-top:1px solid var(--border-light)}
.b-fac-header span{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-light)}
.b-fac-header .dot{width:6px;height:6px;border-radius:50%;background:var(--green)}
.b-facilities{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:auto;padding-bottom:24px}
.b-fac{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;padding:8px 14px;border-radius:var(--r);transition:all .35s var(--ease)}
.b-fac i{font-size:13px}
.b-fac.mri{background:linear-gradient(135deg,rgba(0,117,186,.06),rgba(0,117,186,.02));color:var(--blue);border:1px solid rgba(0,117,186,.1)}
.b-fac.ct{background:linear-gradient(135deg,rgba(121,174,45,.06),rgba(121,174,45,.02));color:var(--green-dark);border:1px solid rgba(121,174,45,.1)}
.b-fac.us{background:linear-gradient(135deg,rgba(139,92,246,.06),rgba(139,92,246,.02));color:#7c3aed;border:1px solid rgba(139,92,246,.1)}
.b-fac.lab{background:rgba(245,158,11,.06);color:#b45309;border:1px solid rgba(245,158,11,.12)}
.b-fac.mammo{background:rgba(236,72,153,.06);color:#be185d;border:1px solid rgba(236,72,153,.12)}
.b-card:hover .b-fac{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.b-footer{padding:0 28px 28px}
.b-actions{display:flex;gap:10px}
.b-actions .btn{flex:1;justify-content:center;padding:12px 16px;font-size:13px}
.branches-more{text-align:center;margin-top:48px}

/* ================================================================
   16. TESTIMONIALS
   ================================================================ */
.testimonials{background:linear-gradient(160deg,#f0f7ff,#f0fdf4);position:relative;overflow:hidden}
.testimonials::before{content:'';position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(0,117,186,.06),transparent 70%);top:-150px;left:-100px;pointer-events:none}
.test-wrap{position:relative;padding:0 52px}
.test-card{background:rgba(255,255,255,.75);backdrop-filter:blur(10px);border:1px solid rgba(0,0,0,.04);border-radius:var(--r-xl);padding:36px;box-shadow:var(--shadow-sm);transition:all .4s var(--ease);display:flex;flex-direction:column;height:auto}
.test-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:rgba(0,117,186,.08)}
.test-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.test-top .qi{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--green));color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px}
.test-stars{color:#f59e0b;font-size:14px;display:flex;gap:2px}
.test-text{font-size:15px;line-height:1.9;color:var(--dark-700);margin-bottom:24px;font-style:italic;flex:1}
.test-author{display:flex;align-items:center;gap:14px;padding-top:20px;border-top:1px solid var(--border-light)}
.test-av{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--blue-light),var(--green-light));display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-size:16px;font-weight:700;color:var(--blue);border:2px solid var(--border);flex-shrink:0}
.test-name{font-family:var(--font-h);font-size:15px;font-weight:700;color:var(--dark)}
.test-role{font-size:12px;color:var(--text-light)}
.test-nav-btn{position:absolute;top:50%;z-index:10;width:48px;height:48px;border-radius:50%;background:#fff;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--dark);cursor:pointer;transition:all .3s var(--ease);transform:translateY(-50%)}
.test-nav-btn:hover{background:var(--blue);color:#fff;box-shadow:var(--glow-blue)}
.test-prev{left:0}
.test-next{right:0}
.testimonials .swiper-pagination{position:relative;margin-top:40px;bottom:0!important}
.testimonials .swiper-pagination-bullet{background:var(--border);opacity:1;width:10px;height:10px;transition:all .4s}
.testimonials .swiper-pagination-bullet-active{background:var(--blue);width:28px;border-radius:5px}

/* ================================================================
   17. CTA SECTION
   ================================================================ */
.cta-section{padding:80px 0}
.cta-box{background:linear-gradient(135deg,var(--blue),var(--green));border-radius:var(--r-2xl);padding:76px 64px;display:flex;align-items:center;justify-content:space-between;gap:48px;position:relative;overflow:hidden}
.cta-box::before{content:'';position:absolute;width:400px;height:400px;border-radius:50%;background:rgba(255,255,255,.06);top:-200px;right:-100px}
.cta-box::after{content:'';position:absolute;width:250px;height:250px;border-radius:50%;background:rgba(255,255,255,.04);bottom:-120px;left:5%}
.cta-content{position:relative;z-index:2;flex:1}
.cta-content h2{font-size:clamp(28px,3.5vw,40px);color:#fff;margin-bottom:14px;font-weight:800}
.cta-content p{font-size:17px;color:rgba(255,255,255,.8);max-width:520px;line-height:1.8}
.cta-acts{position:relative;z-index:2;display:flex;gap:16px;flex-shrink:0;flex-wrap:wrap}

/* ================================================================
   18. FOOTER
   ================================================================ */
.footer{background:var(--dark);color:rgba(255,255,255,.65);padding:80px 0 0}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.4fr;gap:48px;margin-bottom:60px}
.footer-brand .logo{margin-bottom:20px}
.footer-brand .logo-img{background:linear-gradient(135deg,var(--blue),var(--green))}
.footer-brand .logo-txt .brand{color:#fff}
.footer-brand .logo-txt .brand span{color:var(--green)}
.footer-brand .logo-txt .tag{color:rgba(255,255,255,.35)}
.footer-brand>p{font-size:14px;line-height:1.9;margin-bottom:24px;color:rgba(255,255,255,.45)}
.footer-social{display:flex;gap:10px}
.footer-social a{width:42px;height:42px;border-radius:var(--r);background:rgba(255,255,255,.05);color:rgba(255,255,255,.45);display:inline-flex;align-items:center;justify-content:center;font-size:16px;transition:all .35s var(--ease)}
.footer-social a:hover{background:var(--green);color:#fff;transform:translateY(-3px)}
.footer-col h4{font-size:16px;font-weight:700;color:#fff;margin-bottom:24px;position:relative;padding-bottom:14px}
.footer-col h4::after{content:'';position:absolute;bottom:0;left:0;width:32px;height:3px;border-radius:2px;background:linear-gradient(90deg,var(--green),var(--blue))}
.footer-col ul li{margin-bottom:11px}
.footer-col ul a{font-size:14px;color:rgba(255,255,255,.45);display:flex;align-items:center;gap:8px;transition:all .3s}
.footer-col ul a:hover{color:var(--green);padding-left:6px}
.footer-col ul a i{font-size:9px;color:var(--green);opacity:0;transition:opacity .3s}
.footer-col ul a:hover i{opacity:1}
.footer-contact li{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}
.footer-contact li i{color:var(--green);margin-top:5px;width:16px;text-align:center;flex-shrink:0;font-size:14px}
.footer-contact li span{font-size:14px;color:rgba(255,255,255,.45);line-height:1.7}
.footer-contact li a{color:rgba(255,255,255,.5);transition:color .3s}
.footer-contact li a:hover{color:var(--green)}
.footer-nl{margin-top:20px}
.footer-nl p{font-size:13px;color:rgba(255,255,255,.4);margin-bottom:12px}
.nl-form{display:flex;border-radius:var(--r);overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.nl-form input{flex:1;padding:13px 16px;background:rgba(255,255,255,.04);border:none;color:#fff;font-size:14px}
.nl-form input::placeholder{color:rgba(255,255,255,.25)}
.nl-form button{padding:13px 22px;background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;font-weight:600;font-size:14px;transition:all .3s}
.nl-form button:hover{filter:brightness(1.1)}
.footer-btm{border-top:1px solid rgba(255,255,255,.06);padding:24px 0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.footer-btm p{font-size:13px;color:rgba(255,255,255,.35)}
.footer-btm a{color:rgba(255,255,255,.4);transition:color .3s}
.footer-btm a:hover{color:var(--green)}
.fbl{display:flex;gap:24px}
.fbl a{font-size:13px;color:rgba(255,255,255,.35)}
.fbl a:hover{color:var(--green)}
.footer-mini{background:var(--dark);color:rgba(255,255,255,.5);padding:24px 0;text-align:center;font-size:13px}
.footer-mini a{color:rgba(255,255,255,.6);transition:color .3s}
.footer-mini a:hover{color:var(--green)}
.fml{display:flex;justify-content:center;gap:20px;margin-top:8px}

/* ================================================================
   19. WHATSAPP & BACK TO TOP
   ================================================================ */
.wa-float{position:fixed;bottom:30px;left:30px;z-index:9990;display:flex;align-items:center;gap:12px}
.wa-btn{width:56px;height:56px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 8px 24px rgba(37,211,102,.35);transition:all .35s var(--ease);animation:whatsappPulse 2s infinite}
.wa-btn:hover{transform:scale(1.1)}
.wa-tip{background:var(--dark);color:#fff;padding:10px 16px;border-radius:var(--r);font-size:13px;font-weight:600;white-space:nowrap;box-shadow:var(--shadow-lg);opacity:0;transform:translateX(-10px);transition:all .3s var(--ease);pointer-events:none}
.wa-float:hover .wa-tip{opacity:1;transform:translateX(0)}
@keyframes whatsappPulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.4)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}
.btt{position:fixed;bottom:30px;right:30px;z-index:9990;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;box-shadow:var(--glow-blue);opacity:0;visibility:hidden;transform:translateY(20px);transition:all .4s var(--ease);cursor:pointer}
.btt.visible{opacity:1;visibility:visible;transform:translateY(0)}
.btt:hover{background:linear-gradient(135deg,var(--green),var(--green-dark));box-shadow:var(--glow-green);transform:translateY(-4px)}

/* ================================================================
   20. PAGE HERO (Inner Pages)
   ================================================================ */
.page-hero{position:relative;overflow:hidden;padding:80px 0;min-height:380px;display:flex;align-items:center}
.page-hero-bg{position:absolute;inset:0;z-index:0}
.page-hero-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.12)}
.page-hero-ov{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,117,186,.88),rgba(121,174,45,.6))}
.page-hero .container{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:40px}
.page-hero-content{max-width:640px}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.6);margin-bottom:20px;flex-wrap:wrap}
.breadcrumb a{color:rgba(255,255,255,.7);transition:color .3s}
.breadcrumb a:hover{color:#fff}
.breadcrumb i{font-size:10px}
.page-hero-content h1{font-size:clamp(32px,5vw,52px);font-weight:900;color:#fff;margin-bottom:16px;letter-spacing:-.02em}
.page-hero-content h1 .hl{background:linear-gradient(135deg,#7dd3fc,var(--green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.page-hero-content>p{font-size:18px;color:rgba(255,255,255,.75);line-height:1.8;max-width:560px;margin-bottom:32px}
.ph-deco{position:absolute;border-radius:50%;pointer-events:none;z-index:1}
.ph-d1{width:400px;height:400px;border:60px solid rgba(255,255,255,.03);top:-150px;right:-100px}
.ph-d2{width:250px;height:250px;background:rgba(255,255,255,.02);bottom:-80px;left:10%}
.hero-info-panel{background:rgba(255,255,255,.1);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.15);border-radius:var(--r-xl);padding:32px;min-width:300px;flex-shrink:0}
.hero-info-panel h3{font-size:18px;font-weight:800;color:#fff;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.hero-info-panel h3 i{color:#a3e635}
.hip-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}
.hip-item:last-child{margin-bottom:0}
.hip-icon{width:36px;height:36px;border-radius:var(--r-sm);background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-size:14px;color:#a3e635;flex-shrink:0}
.hip-item h4{font-size:14px;font-weight:700;color:#fff;margin-bottom:1px}
.hip-item p{font-size:13px;color:rgba(255,255,255,.6)}
.hero-info-cards{display:flex;flex-direction:column;gap:16px;flex-shrink:0}
.hero-info-card{background:rgba(255,255,255,.1);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:var(--r-lg);padding:20px 24px;display:flex;align-items:center;gap:16px;min-width:260px;transition:all .3s}
.hero-info-card:hover{background:rgba(255,255,255,.16);transform:translateX(-6px)}
.hic-icon{width:48px;height:48px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.hic-icon.b{background:rgba(0,117,186,.25);color:#7dd3fc}
.hic-icon.g{background:rgba(121,174,45,.25);color:#a3e635}
.hic-text h4{font-size:15px;font-weight:700;color:#fff;margin-bottom:2px}
.hic-text p{font-size:12px;color:rgba(255,255,255,.6)}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap}
.hero-stat-box{text-align:center}
.hero-stat-box .num{font-family:var(--font-h);font-size:36px;font-weight:900;color:#fff}
.hero-stat-box .num span{color:#a3e635}
.hero-stat-box .lbl{font-size:13px;color:rgba(255,255,255,.55);margin-top:2px}

/* ================================================================
   21. SERVICE DETAIL PAGES
   ================================================================ */
.svc-overview{background:var(--white);position:relative;overflow:hidden}
.svc-overview .container{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.svc-ov-img{border-radius:var(--r-2xl);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-xl);position:relative}
.svc-ov-img img{width:100%;height:100%;object-fit:cover}
.ov-badge{position:absolute;bottom:20px;left:20px;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);border-radius:var(--r-lg);padding:16px 20px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-lg)}
.ov-badge-icon{width:44px;height:44px;border-radius:var(--r);background:linear-gradient(135deg,var(--blue),var(--green));color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px}
.ov-badge-text .v{font-family:var(--font-h);font-size:18px;font-weight:800;color:var(--dark)}
.ov-badge-text .l{font-size:11px;color:var(--text-light)}
.svc-ov-highlights{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:32px}
.svc-ov-hl{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-alt);border-radius:var(--r);border:1px solid var(--border-light);transition:all .35s}
.svc-ov-hl:hover{background:var(--blue-light);border-color:rgba(0,117,186,.1);transform:translateX(4px)}
.svc-ov-hl i{color:var(--green);font-size:16px;flex-shrink:0}
.svc-ov-hl span{font-size:14px;font-weight:600;color:var(--dark)}

/* Types grid */
.svc-types{background:var(--bg-alt)}
.types-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.type-card{background:#fff;border-radius:var(--r-xl);padding:32px 24px;border:1px solid var(--border);text-align:center;transition:all .45s var(--ease);position:relative;overflow:hidden}
.type-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--green));transform:scaleX(0);transform-origin:left;transition:transform .5s}
.type-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-xl);border-color:transparent}
.type-card:hover::before{transform:scaleX(1)}
.type-icon{width:64px;height:64px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 20px;transition:all .4s var(--ease-bounce)}
.type-icon.b{background:var(--blue-light);color:var(--blue)}
.type-icon.g{background:var(--green-light);color:var(--green)}
.type-card:hover .type-icon.b{background:var(--blue);color:#fff;transform:scale(1.1) rotate(-10deg)}
.type-card:hover .type-icon.g{background:var(--green);color:#fff;transform:scale(1.1) rotate(-10deg)}
.type-card h3{font-size:17px;font-weight:700;margin-bottom:10px}
.type-card p{font-size:14px;color:var(--text);line-height:1.7}

/* Procedure */
.procedure{background:var(--white)}
.procedure .container{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.proc-steps{display:flex;flex-direction:column}
.proc-step{display:flex;gap:24px;padding:28px 0;border-bottom:1px solid var(--border-light);transition:all .3s}
.proc-step:hover{transform:translateX(6px)}
.proc-step:last-child{border-bottom:none}
.proc-num{width:48px;height:48px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-size:18px;font-weight:800;transition:all .4s var(--ease)}
.proc-num.b{background:var(--blue-light);color:var(--blue)}
.proc-num.g{background:var(--green-light);color:var(--green)}
.proc-step:hover .proc-num.b{background:var(--blue);color:#fff}
.proc-step:hover .proc-num.g{background:var(--green);color:#fff}
.proc-step h4{font-size:17px;font-weight:700;margin-bottom:4px}
.proc-step p{font-size:14px;color:var(--text);line-height:1.7}
.proc-img{border-radius:var(--r-2xl);overflow:hidden;aspect-ratio:4/3.5;box-shadow:var(--shadow-xl)}
.proc-img img{width:100%;height:100%;object-fit:cover}

/* Technology dark section */
.tech-section{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--dark),var(--dark-800));color:#fff}
.tech-section .pat{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(0,117,186,.15),transparent 50%),radial-gradient(circle at 80% 20%,rgba(121,174,45,.1),transparent 50%);pointer-events:none}
.tech-section .container{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.tech-content .section-label{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.1);color:#fff}
.tech-content .section-title{color:#fff}
.tech-content p{color:rgba(255,255,255,.7);font-size:16px;line-height:1.9;margin-bottom:20px}
.tech-specs{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px}
.tech-spec{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);padding:20px;transition:all .35s}
.tech-spec:hover{background:rgba(255,255,255,.1);border-color:rgba(121,174,45,.3);transform:translateY(-4px)}
.tech-spec h4{font-size:15px;font-weight:700;color:#fff;margin-bottom:4px;display:flex;align-items:center;gap:8px}
.tech-spec h4 i{color:var(--green);font-size:14px}
.tech-spec p{font-size:13px;color:rgba(255,255,255,.5);line-height:1.6}
.tech-img{border-radius:var(--r-2xl);overflow:hidden;aspect-ratio:4/3;box-shadow:0 30px 80px rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.08)}
.tech-img img{width:100%;height:100%;object-fit:cover}

/* Benefits */
.benefits{background:var(--bg-alt)}
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.benefit-card{background:#fff;border-radius:var(--r-xl);padding:36px 28px;border:1px solid var(--border);transition:all .45s var(--ease);text-align:center}
.benefit-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:transparent}
.benefit-icon{width:68px;height:68px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 20px;transition:all .4s var(--ease-bounce)}
.benefit-icon.b{background:var(--blue-light);color:var(--blue)}
.benefit-icon.g{background:var(--green-light);color:var(--green)}
.benefit-card:hover .benefit-icon.b{background:var(--blue);color:#fff;transform:scale(1.12) rotate(-10deg)}
.benefit-card:hover .benefit-icon.g{background:var(--green);color:#fff;transform:scale(1.12) rotate(-10deg)}
.benefit-card h3{font-size:18px;font-weight:700;margin-bottom:10px}
.benefit-card p{font-size:14px;color:var(--text);line-height:1.8}

/* FAQ */
.faq{background:var(--white)}
.faq .container{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:flex-start}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;transition:all .3s}
.faq-item.active{border-color:var(--blue);box-shadow:0 4px 20px rgba(0,117,186,.08)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;cursor:pointer;font-family:var(--font-h);font-size:16px;font-weight:600;color:var(--dark);transition:all .3s;gap:16px}
.faq-q:hover{color:var(--blue)}
.faq-item.active .faq-q{color:var(--blue);background:var(--blue-50)}
.faq-q .faq-toggle{width:32px;height:32px;border-radius:50%;flex-shrink:0;background:var(--bg-alt);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-light);transition:all .3s}
.faq-item.active .faq-toggle{background:var(--blue);color:#fff;transform:rotate(180deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.faq-item.active .faq-a{max-height:300px}
.faq-a-inner{padding:0 24px 20px;font-size:15px;color:var(--text);line-height:1.85}

/* Related */
.related{background:var(--bg-alt)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.rel-card{background:#fff;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);transition:all .45s var(--ease)}
.rel-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:transparent}
.rel-img{height:180px;overflow:hidden;position:relative}
.rel-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.rel-card:hover .rel-img img{transform:scale(1.06)}
.rel-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(15,23,42,.4) 100%)}
.rel-body{padding:24px}
.rel-body h3{font-size:18px;font-weight:700;margin-bottom:8px}
.rel-body p{font-size:14px;color:var(--text);line-height:1.7;margin-bottom:16px}
.rel-link{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--blue);transition:gap .3s}
.rel-card:hover .rel-link{gap:12px}
.rel-link i{font-size:11px}

/* ================================================================
   22. BRANCH DETAIL PAGES
   ================================================================ */
.branch-details{background:var(--white)}
.branch-details .container{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:flex-start}
.bd-main h2{margin-bottom:24px}
.bd-main p{font-size:16px;color:var(--text);line-height:1.9;margin-bottom:20px}
.fac-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin:36px 0}
.fac-card-mini{padding:24px;border-radius:var(--r-lg);border:1px solid var(--border);background:#fff;display:flex;align-items:flex-start;gap:16px;transition:all .35s var(--ease)}
.fac-card-mini:hover{border-color:var(--blue);background:var(--blue-50);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.fcm-icon{width:48px;height:48px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;transition:all .4s var(--ease-bounce)}
.fcm-icon.b{background:var(--blue-light);color:var(--blue)}
.fcm-icon.g{background:var(--green-light);color:var(--green)}
.fcm-icon.p{background:rgba(236,72,153,.08);color:#be185d}
.fac-card-mini:hover .fcm-icon.b{background:var(--blue);color:#fff;transform:scale(1.08)}
.fac-card-mini:hover .fcm-icon.g{background:var(--green);color:#fff;transform:scale(1.08)}
.fac-card-mini:hover .fcm-icon.p{background:#ec4899;color:#fff;transform:scale(1.08)}
.fcm-text h4{font-size:15px;font-weight:700;margin-bottom:4px}
.fcm-text p{font-size:13px;color:var(--text);line-height:1.6}
.partner-banner{background:var(--blue-light);border:1px solid rgba(0,117,186,.1);border-radius:var(--r-lg);padding:20px 24px;margin-bottom:28px;display:flex;align-items:center;gap:14px}
.partner-banner i{font-size:24px;color:var(--blue)}
.partner-banner h4{font-size:15px;font-weight:700;color:var(--dark);margin-bottom:2px}
.partner-banner p{font-size:13px;color:var(--text)}
.bd-sidebar{position:sticky;top:100px}
.sidebar-card{background:var(--bg-alt);border-radius:var(--r-xl);padding:32px;border:1px solid var(--border-light);margin-bottom:24px}
.sidebar-card h4{font-size:18px;font-weight:800;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.sidebar-card h4 i{color:var(--blue)}
.sc-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px}
.sc-item:last-child{margin-bottom:0}
.sc-item i{width:36px;height:36px;border-radius:var(--r-sm);background:var(--blue-light);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;margin-top:2px}
.sc-item h5{font-size:13px;font-weight:700;color:var(--dark);margin-bottom:2px}
.sc-item p{font-size:14px;color:var(--text);line-height:1.5}
.sc-item a{color:var(--blue);font-weight:600}
.sc-item a:hover{color:var(--blue-dark)}
.sidebar-card.cta-card{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;border:none}
.sidebar-card.cta-card h4{color:#fff}
.sidebar-card.cta-card h4 i{color:#a3e635}
.sidebar-card.cta-card p{color:rgba(255,255,255,.8);font-size:14px;line-height:1.7;margin-bottom:20px}
.sidebar-card.cta-card .btn{width:100%;justify-content:center}

/* Map */
.map-full{background:var(--bg-alt)}
.map-full .container{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch}
.map-frame{border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--shadow-lg);min-height:400px}
.map-frame iframe{width:100%;height:100%;border:0}
.map-info{display:flex;flex-direction:column;justify-content:center}
.map-how{margin-top:32px}
.map-how h4{font-size:16px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.map-how h4 i{color:var(--green)}
.landmark{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;border-radius:var(--r);border:1px solid var(--border-light);margin-bottom:8px;font-size:14px;color:var(--text);transition:all .3s}
.landmark:hover{border-color:var(--blue);background:var(--blue-50);transform:translateX(4px)}
.landmark i{color:var(--blue);font-size:14px;width:20px;text-align:center;flex-shrink:0}

/* Other branches */
.other-branches{background:var(--white)}
.ob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ob-card{background:var(--bg-alt);border-radius:var(--r-xl);padding:28px;border:1px solid var(--border-light);transition:all .4s var(--ease)}
.ob-card:hover{background:#fff;border-color:var(--blue);transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.ob-card h3{font-size:17px;font-weight:700;margin-bottom:10px}
.ob-card .ob-loc{font-size:13px;color:var(--text);margin-bottom:12px;display:flex;align-items:flex-start;gap:8px}
.ob-card .ob-loc i{color:var(--blue);margin-top:3px;flex-shrink:0}
.ob-facs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.ob-fac{font-size:11px;font-weight:600;padding:4px 10px;border-radius:var(--r-full);background:var(--blue-light);color:var(--blue)}
.ob-card a{font-size:14px;font-weight:600;color:var(--blue);display:inline-flex;align-items:center;gap:6px}
.ob-card:hover a{gap:10px}

/* ================================================================
   23. FACILITIES PAGE
   ================================================================ */
.gallery{background:var(--white)}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,240px);gap:16px}
.gallery-item{position:relative;border-radius:var(--r-xl);overflow:hidden;cursor:pointer;transition:all .5s var(--ease)}
.gallery-item:hover{transform:scale(1.02);z-index:2}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.gallery-item:hover img{transform:scale(1.1)}
.gallery-item::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(15,23,42,.6) 100%)}
.gallery-item .g-label{position:absolute;bottom:20px;left:20px;z-index:2;color:#fff;font-family:var(--font-h);font-weight:700;font-size:16px;opacity:0;transform:translateY(10px);transition:all .4s .1s}
.gallery-item:hover .g-label{opacity:1;transform:translateY(0)}
.gallery-item .g-zoom{position:absolute;top:16px;right:16px;z-index:2;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;opacity:0;transition:all .3s}
.gallery-item:hover .g-zoom{opacity:1}
.gallery-item.large{grid-column:span 2;grid-row:span 2}
.gallery-item.wide{grid-column:span 2}

/* Equipment */
.equipment{background:var(--bg-alt)}
.equip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.equip-card{background:#fff;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--border);transition:all .45s var(--ease)}
.equip-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-xl);border-color:transparent}
.equip-img{height:220px;overflow:hidden;position:relative}
.equip-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.equip-card:hover .equip-img img{transform:scale(1.06)}
.equip-img::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(15,23,42,.4) 100%)}
.equip-badge{position:absolute;top:16px;left:16px;z-index:2;padding:6px 16px;border-radius:var(--r-full);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#fff;background:var(--blue)}
.equip-body{padding:28px}
.equip-body h3{font-size:20px;font-weight:800;margin-bottom:10px}
.equip-body p{font-size:14px;color:var(--text);line-height:1.8;margin-bottom:16px}
.equip-specs{display:flex;flex-wrap:wrap;gap:8px}
.equip-spec{font-size:12px;font-weight:600;padding:5px 12px;border-radius:var(--r-full);background:var(--blue-light);color:var(--blue);border:1px solid rgba(0,117,186,.06)}

/* Why facilities dark */
.why-fac{background:linear-gradient(160deg,var(--dark),var(--dark-800));color:#fff;position:relative;overflow:hidden}
.why-fac .pat,.fac-overview .pat{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(0,117,186,.15),transparent 50%),radial-gradient(circle at 80% 20%,rgba(121,174,45,.1),transparent 50%);pointer-events:none}
.fac-overview{background:linear-gradient(160deg,var(--dark),var(--dark-800));color:#fff;position:relative;overflow:hidden}
.fac-overview .container,.why-fac .container{position:relative;z-index:2}
.why-fac-grid,.fac-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.why-fac-card,.fac-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);backdrop-filter:blur(6px);border-radius:var(--r-xl);padding:36px 24px;text-align:center;transition:all .4s var(--ease)}
.why-fac-card:hover,.fac-card:hover{background:rgba(255,255,255,.08);border-color:rgba(121,174,45,.3);transform:translateY(-8px)}
.wfc-icon,.fac-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 20px;transition:all .4s var(--ease-bounce)}
.wfc-icon.b,.fac-icon.b{background:rgba(0,117,186,.15);color:#7dd3fc}
.wfc-icon.g,.fac-icon.g{background:rgba(121,174,45,.15);color:#a3e635}
.why-fac-card:hover .wfc-icon.b,.fac-card:hover .fac-icon.b{background:var(--blue);color:#fff;transform:scale(1.12) rotate(-10deg)}
.why-fac-card:hover .wfc-icon.g,.fac-card:hover .fac-icon.g{background:var(--green);color:#fff;transform:scale(1.12) rotate(-10deg)}
.why-fac-card h3,.fac-card h3{font-size:17px;font-weight:700;color:#fff;margin-bottom:8px}
.why-fac-card p,.fac-card p{font-size:14px;color:rgba(255,255,255,.55);line-height:1.7}

/* Intro section (facilities) */
.intro{background:var(--white);position:relative;overflow:hidden}
.intro .container{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.intro-img{border-radius:var(--r-2xl);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-xl)}
.intro-img img{width:100%;height:100%;object-fit:cover}
.intro-features{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:28px}
.intro-feat{display:flex;align-items:center;gap:12px;padding:14px 18px;background:var(--bg-alt);border-radius:var(--r);border:1px solid var(--border-light);transition:all .35s}
.intro-feat:hover{background:var(--blue-light);border-color:rgba(0,117,186,.1);transform:translateX(4px)}
.intro-feat i{color:var(--green);font-size:16px;flex-shrink:0}
.intro-feat span{font-size:14px;font-weight:600;color:var(--dark)}

/* ================================================================
   24. APPOINTMENT PAGE
   ================================================================ */
.appt-section{background:var(--white);position:relative;overflow:hidden}
.appt-layout{display:grid;grid-template-columns:1.3fr 1fr;gap:72px;align-items:flex-start}
.appt-steps{display:flex;align-items:center;gap:0;margin-bottom:48px}
.appt-step{flex:1;text-align:center;position:relative}
.appt-step::after{content:'';position:absolute;top:22px;left:calc(50% + 24px);right:calc(-50% + 24px);height:3px;background:var(--border);z-index:0}
.appt-step:last-child::after{display:none}
.appt-step.active::after{background:linear-gradient(90deg,var(--blue),var(--green))}
.appt-step.completed::after{background:var(--green)}
.step-num{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-size:16px;font-weight:800;margin:0 auto 10px;position:relative;z-index:2;background:var(--bg-alt);color:var(--text-light);border:2px solid var(--border);transition:all .4s var(--ease)}
.appt-step.active .step-num{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;border-color:var(--blue);box-shadow:var(--glow-blue)}
.appt-step.completed .step-num{background:var(--green);color:#fff;border-color:var(--green)}
.step-label{font-size:13px;font-weight:600;color:var(--text-light)}
.appt-step.active .step-label{color:var(--blue);font-weight:700}
.appt-step.completed .step-label{color:var(--green)}
.appt-panels{position:relative}
.appt-panel{display:none;animation:panelIn .5s var(--ease)}
.appt-panel.active{display:block}
@keyframes panelIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.form-card{background:#fff;border-radius:var(--r-xl);padding:40px;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.form-card h3{font-size:24px;font-weight:800;margin-bottom:8px}
.form-card .form-desc{font-size:15px;color:var(--text);margin-bottom:32px}
.fg{margin-bottom:22px}
.fg label{display:block;font-size:13px;font-weight:600;color:var(--dark);margin-bottom:8px;letter-spacing:.3px}
.fg label .req{color:#ef4444}
.input-w{position:relative}
.input-w i.ii{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:15px;color:var(--text-light);pointer-events:none;transition:color .3s}
.input-w input,.input-w select,.input-w textarea{width:100%;padding:15px 16px 15px 48px;border:2px solid var(--border);border-radius:var(--r);font-size:15px;color:var(--dark);background:#fff;transition:all .3s var(--ease);-webkit-appearance:none}
.input-w textarea{padding:15px 16px;min-height:100px;resize:vertical}
.input-w input:focus,.input-w select:focus,.input-w textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,117,186,.08)}
.input-w input:focus~i.ii,.input-w select:focus~i.ii{color:var(--blue)}
.input-w input::placeholder,.input-w textarea::placeholder{color:#cbd5e1}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.svc-selector{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}
.svc-opt{padding:20px 16px;border-radius:var(--r-lg);border:2px solid var(--border);background:#fff;text-align:center;cursor:pointer;transition:all .35s var(--ease)}
.svc-opt:hover{border-color:var(--blue);background:var(--blue-50)}
.svc-opt.selected{border-color:var(--blue);background:var(--blue-light);box-shadow:0 0 0 3px rgba(0,117,186,.12)}
.svc-opt input{display:none}
.svc-opt-icon{font-size:24px;color:var(--blue);margin-bottom:10px;transition:transform .3s var(--ease-bounce)}
.svc-opt.selected .svc-opt-icon{transform:scale(1.15)}
.svc-opt h4{font-size:14px;font-weight:700;color:var(--dark)}
.svc-opt.selected h4{color:var(--blue)}
.time-slots{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:24px}
.time-slot{padding:12px;border-radius:var(--r);border:2px solid var(--border);background:#fff;text-align:center;cursor:pointer;transition:all .3s;font-size:14px;font-weight:600;color:var(--dark)}
.time-slot:hover{border-color:var(--green);background:var(--green-50)}
.time-slot.selected{border-color:var(--green);background:var(--green-light);color:var(--green-dark)}
.time-slot.disabled{opacity:.4;cursor:not-allowed;pointer-events:none}
.time-slot input{display:none}
.form-nav{display:flex;justify-content:space-between;align-items:center;margin-top:32px;padding-top:24px;border-top:1px solid var(--border-light)}
.appt-sidebar{position:sticky;top:100px}

/* ================================================================
   25. CAREERS PAGE
   ================================================================ */
.why-join{background:var(--white)}
.why-join .container{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.wj-img{border-radius:var(--r-2xl);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-xl)}
.wj-img img{width:100%;height:100%;object-fit:cover}
.perks{background:var(--bg-alt)}
.perks-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.perk-card{background:#fff;border-radius:var(--r-xl);padding:32px 24px;border:1px solid var(--border);text-align:center;transition:all .45s var(--ease)}
.perk-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:transparent}
.perk-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;margin:0 auto 18px;transition:all .4s var(--ease-bounce)}
.perk-icon.b{background:var(--blue-light);color:var(--blue)}
.perk-icon.g{background:var(--green-light);color:var(--green)}
.perk-card:hover .perk-icon.b{background:var(--blue);color:#fff;transform:scale(1.1) rotate(-10deg)}
.perk-card:hover .perk-icon.g{background:var(--green);color:#fff;transform:scale(1.1) rotate(-10deg)}
.perk-card h3{font-size:16px;font-weight:700;margin-bottom:8px}
.perk-card p{font-size:13px;color:var(--text);line-height:1.7}
.jobs{background:var(--white)}
.job-filters{display:flex;justify-content:center;gap:8px;margin-bottom:48px;flex-wrap:wrap}
.job-filter{padding:10px 24px;border-radius:var(--r-full);font-family:var(--font-h);font-size:14px;font-weight:600;background:#fff;color:var(--text);border:2px solid var(--border);cursor:pointer;transition:all .35s}
.job-filter.active,.job-filter:hover{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:var(--glow-blue);transform:translateY(-2px)}
.jobs-list{display:flex;flex-direction:column;gap:20px;max-width:900px;margin:0 auto}
.job-card{background:#fff;border:1px solid var(--border);border-radius:var(--r-xl);padding:32px;transition:all .4s var(--ease);display:flex;align-items:center;justify-content:space-between;gap:24px}
.job-card:hover{border-color:var(--blue);box-shadow:0 8px 30px rgba(0,117,186,.08);transform:translateY(-4px)}
.job-left{flex:1}
.job-title{font-size:20px;font-weight:800;margin-bottom:8px}
.job-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px}
.job-tag{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text);font-weight:500}
.job-tag i{color:var(--blue);font-size:12px}
.job-desc{font-size:14px;color:var(--text);line-height:1.7}
.job-badges{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.job-badge{font-size:11px;font-weight:600;padding:4px 12px;border-radius:var(--r-full)}
.job-badge.blue{background:var(--blue-light);color:var(--blue)}
.job-badge.green{background:var(--green-light);color:var(--green-dark)}
.job-right{flex-shrink:0}
.apply{background:var(--bg-alt)}
.apply .container{max-width:800px}
.apply-form{background:#fff;border-radius:var(--r-xl);padding:48px;border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.apply-form h3{font-size:24px;font-weight:800;margin-bottom:8px}
.apply-form .form-desc{font-size:15px;color:var(--text);margin-bottom:32px}
.file-upload{border:2px dashed var(--border);border-radius:var(--r-lg);padding:32px;text-align:center;cursor:pointer;transition:all .3s;background:var(--bg-alt)}
.file-upload:hover{border-color:var(--blue);background:var(--blue-50)}
.file-upload i{font-size:32px;color:var(--blue);margin-bottom:12px;display:block}
.file-upload p{font-size:14px;color:var(--text);margin-bottom:4px}
.file-upload span{font-size:12px;color:var(--text-light)}
.file-upload input{display:none}

/* ================================================================
   26. SIGN IN PAGE
   ================================================================ */
.signin-page{min-height:calc(100vh - var(--header-h) - var(--topbar-h) - 4px);display:flex}
.signin-visual{flex:0 0 45%;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.signin-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.signin-visual-ov{position:absolute;inset:0;background:linear-gradient(160deg,rgba(0,117,186,.9),rgba(121,174,45,.75))}
.signin-visual-content{position:relative;z-index:2;text-align:center;padding:60px 48px;color:#fff;max-width:480px}
.big-logo{width:80px;height:80px;border-radius:var(--r-xl);background:rgba(255,255,255,.15);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-size:36px;font-weight:900;color:#fff;margin:0 auto 32px}
.signin-visual-content h2{font-size:32px;font-weight:800;color:#fff;margin-bottom:16px}
.signin-visual-content p{font-size:16px;color:rgba(255,255,255,.8);line-height:1.8}
.signin-form-panel{flex:1;display:flex;align-items:center;justify-content:center;padding:48px;background:var(--bg-alt)}
.signin-container{width:100%;max-width:480px}
.signin-tabs{display:flex;gap:0;margin-bottom:40px;background:#fff;border-radius:var(--r-lg);padding:6px;box-shadow:var(--shadow-sm);border:1px solid var(--border-light)}
.signin-tab{flex:1;padding:16px;text-align:center;font-family:var(--font-h);font-size:15px;font-weight:700;color:var(--text-light);border-radius:var(--r);cursor:pointer;transition:all .35s var(--ease);display:flex;align-items:center;justify-content:center;gap:10px}
.signin-tab i{font-size:18px}
.signin-tab.active{color:#fff;box-shadow:var(--shadow-md)}
.signin-tab.patient-tab.active{background:linear-gradient(135deg,var(--blue),var(--blue-dark))}
.signin-tab.doctor-tab.active{background:linear-gradient(135deg,var(--green),var(--green-dark))}
.signin-tab:not(.active):hover{color:var(--dark);background:var(--bg-alt)}
.signin-forms{position:relative}
.signin-form{display:none;animation:formFadeIn .5s var(--ease)}
.signin-form.active{display:block}
@keyframes formFadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.form-welcome{margin-bottom:32px}
.form-welcome h2{font-size:28px;font-weight:800;margin-bottom:8px}
.form-welcome h2 .accent-b{color:var(--blue)}
.form-welcome h2 .accent-g{color:var(--green)}
.form-welcome p{font-size:15px;color:var(--text)}
.input-group{margin-bottom:20px}
.input-group label{display:block;font-size:13px;font-weight:600;color:var(--dark);margin-bottom:8px}
.input-wrap{position:relative;display:flex;align-items:center}
.input-wrap i.input-icon{position:absolute;left:16px;font-size:16px;color:var(--text-light);transition:color .3s;pointer-events:none}
.input-wrap input{width:100%;padding:15px 16px 15px 48px;border:2px solid var(--border);border-radius:var(--r);font-size:15px;color:var(--dark);background:#fff;transition:all .3s var(--ease)}
.input-wrap input::placeholder{color:#cbd5e1}
.input-wrap input:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,117,186,.08)}
.doctor-form .input-wrap input:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(121,174,45,.08)}
.input-wrap .toggle-pass{position:absolute;right:16px;font-size:16px;color:var(--text-light);cursor:pointer;transition:color .3s;background:none;border:none;padding:4px}
.input-wrap .toggle-pass:hover{color:var(--dark)}
.form-options{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.remember{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text);cursor:pointer}
.remember input[type="checkbox"]{width:18px;height:18px;accent-color:var(--blue);cursor:pointer}
.doctor-form .remember input[type="checkbox"]{accent-color:var(--green)}
.forgot{font-size:14px;font-weight:600;color:var(--blue)}
.forgot:hover{color:var(--blue-dark)}
.doctor-form .forgot{color:var(--green)}
.btn-submit{width:100%;padding:16px;border-radius:var(--r);font-family:var(--font-h);font-size:16px;font-weight:700;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .4s var(--ease);position:relative;overflow:hidden}
.btn-submit::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .6s}
.btn-submit:hover::before{left:100%}
.btn-submit.patient-btn{background:linear-gradient(135deg,var(--blue),var(--blue-dark));box-shadow:var(--glow-blue)}
.btn-submit.patient-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(0,117,186,.3)}
.btn-submit.doctor-btn{background:linear-gradient(135deg,var(--green),var(--green-dark));box-shadow:var(--glow-green)}
.btn-submit.doctor-btn:hover{transform:translateY(-2px)}
.btn-submit i{font-size:14px;transition:transform .3s}
.btn-submit:hover i{transform:translateX(4px)}
.form-divider{display:flex;align-items:center;gap:16px;margin:28px 0}
.form-divider::before,.form-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.form-divider span{font-size:13px;color:var(--text-light);font-weight:500;white-space:nowrap}
.social-login{display:flex;gap:12px;margin-bottom:28px}
.social-btn{flex:1;padding:14px;border-radius:var(--r);border:2px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;gap:10px;font-size:14px;font-weight:600;color:var(--dark);transition:all .3s var(--ease);cursor:pointer}
.social-btn:hover{border-color:var(--blue);background:var(--blue-50);transform:translateY(-2px)}
.social-btn .google-icon{color:#ea4335}
.social-btn .phone-icon{color:var(--green)}
.form-register{text-align:center;font-size:14px;color:var(--text)}
.form-register a{font-weight:700;color:var(--blue)}
.form-register a:hover{color:var(--blue-dark)}
.doctor-form .form-register a{color:var(--green)}
.security-note{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:24px;padding-top:24px;border-top:1px solid var(--border-light);font-size:12px;color:var(--text-light)}
.security-note i{color:var(--green);font-size:14px}

/* ================================================================
   27. POPUP
   ================================================================ */
.popup-overlay{position:fixed;inset:0;z-index:99999;background:rgba(15,23,42,.7);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .5s var(--ease);padding:20px}
.popup-overlay.active{opacity:1;visibility:visible}
.popup-box{position:relative;width:100%;max-width:820px;background:#fff;border-radius:var(--r-2xl);overflow:hidden;box-shadow:0 40px 100px rgba(0,0,0,.25);transform:scale(.85) translateY(30px);transition:transform .5s var(--ease-bounce)}
.popup-overlay.active .popup-box{transform:scale(1) translateY(0)}
.popup-close{position:absolute;top:16px;right:16px;z-index:10;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--dark);box-shadow:0 4px 12px rgba(0,0,0,.1);transition:all .3s var(--ease);cursor:pointer;border:none}
.popup-close:hover{background:#fee2e2;color:#ef4444;transform:rotate(90deg)}
.popup-inner{display:flex;min-height:440px}
.popup-visual{flex:0 0 42%;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.popup-visual img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.popup-visual-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(0,117,186,.85),rgba(121,174,45,.7))}
.popup-visual-content{position:relative;z-index:2;text-align:center;padding:40px 30px;color:#fff}
.popup-offer-badge{display:inline-block;background:rgba(255,255,255,.2);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.25);padding:6px 20px;border-radius:var(--r-full);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2px;margin-bottom:20px}
.popup-offer-amount{display:flex;flex-direction:column;align-items:center;margin-bottom:12px}
.popup-off{font-family:var(--font-h);font-size:80px;font-weight:900;line-height:1;background:linear-gradient(135deg,#fff,#a3e635);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.popup-off-text{font-family:var(--font-h);font-size:28px;font-weight:800;letter-spacing:6px;text-transform:uppercase;margin-top:-8px}
.popup-offer-on{font-size:15px;color:rgba(255,255,255,.85)}
.popup-info{flex:1;padding:48px 40px;display:flex;flex-direction:column;justify-content:center}
.popup-logo{display:flex;align-items:center;gap:10px;margin-bottom:20px}
.popup-logo-icon{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--blue),var(--green));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-h);font-size:16px;font-weight:900}
.popup-logo span{font-family:var(--font-h);font-size:18px;font-weight:800;color:var(--dark)}
.popup-logo span span{color:var(--blue)}
.popup-info h2{font-size:26px;font-weight:800;margin-bottom:12px;color:var(--dark)}
.popup-desc{font-size:15px;color:var(--text);line-height:1.8;margin-bottom:24px}
.popup-desc strong{color:var(--green);font-weight:700}
.popup-features{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:28px}
.popup-feat{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--dark)}
.popup-feat i{color:var(--green);font-size:14px}
.popup-actions{display:flex;align-items:center;gap:16px;margin-bottom:20px}
.popup-cta{padding:14px 32px;font-size:15px}
.popup-skip{font-size:14px;color:var(--text-light);font-weight:500;background:none;border:none;cursor:pointer;transition:color .3s;padding:8px}
.popup-skip:hover{color:var(--blue)}
.popup-note{font-size:12px;color:var(--text-light);display:flex;align-items:center;gap:6px}
.popup-note i{color:var(--green);font-size:13px}

/* Image-Only Mode */
.popup-box.popup-image-only{max-width:600px;padding:0;background:transparent;overflow:visible}
.popup-box.popup-image-only .popup-close{top:-14px;right:-14px;background:#fff;box-shadow:0 4px 15px rgba(0,0,0,.2)}
.popup-img-only{display:block}
.popup-img-only a{display:block}
.popup-img-only img{width:100%;height:auto;max-height:80vh;object-fit:contain;border-radius:var(--r-xl);display:block}

/* Image-Only Mobile */
@media(max-width:600px){
  .popup-box.popup-image-only{max-width:92vw}
  .popup-box.popup-image-only .popup-close{top:-10px;right:-10px;width:36px;height:36px;font-size:14px}
}
/* ================================================================
   28. ABOUT PAGE SPECIFICS
   ================================================================ */
.story{background:var(--white);position:relative;overflow:hidden}
.story .container{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story-visual{position:relative}
.story-img-main{border-radius:var(--r-2xl);overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow-xl)}
.story-img-main img{width:100%;height:100%;object-fit:cover}
.story-img-secondary{position:absolute;bottom:-30px;right:-30px;width:200px;height:200px;border-radius:var(--r-xl);overflow:hidden;border:6px solid #fff;box-shadow:var(--shadow-lg)}
.story-img-secondary img{width:100%;height:100%;object-fit:cover}
.story-accent{position:absolute;top:30px;left:-16px;width:6px;height:140px;border-radius:3px;background:linear-gradient(to bottom,var(--green),var(--blue))}
.story-experience{position:absolute;top:-20px;right:20px;background:linear-gradient(135deg,var(--green),var(--green-dark));color:#fff;padding:20px 24px;border-radius:var(--r-xl);text-align:center;box-shadow:var(--glow-green)}
.story-experience .num{font-family:var(--font-h);font-size:36px;font-weight:900;line-height:1}
.story-experience .txt{font-size:12px;opacity:.85;margin-top:4px}
.mvv{background:var(--bg-alt)}
.mvv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.mvv-card{background:#fff;border-radius:var(--r-xl);padding:40px 32px;border:1px solid var(--border);position:relative;overflow:hidden;transition:all .45s var(--ease)}
.mvv-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--green));transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.mvv-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-xl);border-color:transparent}
.mvv-card:hover::before{transform:scaleX(1)}
.mvv-icon{width:68px;height:68px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:24px;transition:all .4s var(--ease-bounce)}
.mvv-icon.blue{background:var(--blue-light);color:var(--blue)}
.mvv-icon.green{background:var(--green-light);color:var(--green)}
.mvv-card:hover .mvv-icon.blue{background:var(--blue);color:#fff;transform:scale(1.1) rotate(-10deg)}
.mvv-card:hover .mvv-icon.green{background:var(--green);color:#fff;transform:scale(1.1) rotate(-10deg)}
.mvv-card h3{font-size:22px;font-weight:800;margin-bottom:14px}
.mvv-card p{font-size:15px;color:var(--text);line-height:1.85}
.accreditations{background:var(--white)}
.accred-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.accred-card{background:var(--bg-alt);border-radius:var(--r-xl);padding:36px 28px;text-align:center;border:1px solid var(--border-light);transition:all .4s var(--ease)}
.accred-card:hover{background:#fff;transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.accred-icon{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--blue-light),var(--green-light));display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--blue);margin:0 auto 20px;transition:all .4s var(--ease)}
.accred-card:hover .accred-icon{transform:scale(1.12) rotate(-8deg);background:linear-gradient(135deg,var(--blue),var(--green));color:#fff}
.accred-card h4{font-size:16px;font-weight:700;margin-bottom:8px}
.accred-card p{font-size:13px;color:var(--text);line-height:1.7}

/* ================================================================
   29. CONTACT PAGE MAP
   ================================================================ */
.map-section{background:var(--bg-alt)}
.map-section .container{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:stretch}
.map-contact-card{display:flex;align-items:center;gap:18px;padding:20px 24px;background:#fff;border-radius:var(--r-lg);border:1px solid var(--border);transition:all .35s var(--ease)}
.map-contact-card:hover{border-color:var(--blue);background:var(--blue-50);transform:translateX(6px)}
.mcc-icon{width:52px;height:52px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.mcc-icon.b{background:var(--blue-light);color:var(--blue)}
.mcc-icon.g{background:var(--green-light);color:var(--green)}
.map-contact-card:hover .mcc-icon.b{background:var(--blue);color:#fff}
.map-contact-card:hover .mcc-icon.g{background:var(--green);color:#fff}
.mcc-text h4{font-size:15px;font-weight:700;color:var(--dark);margin-bottom:2px}
.mcc-text p{font-size:14px;color:var(--text)}
.mcc-text a{color:var(--blue);font-weight:600}

/* ================================================================
   30. MOBILE SWIPER OVERRIDES
   ================================================================ */
.mobile-swiper-wrap{margin:0 -16px;padding:0 0 20px}
.mobile-swiper-wrap .swiper{padding:0 16px 40px;overflow:visible}
.mobile-swiper-wrap .swiper-slide{height:auto!important}
.mobile-swiper-wrap .swiper-slide>*{height:100%}
.mobile-swiper-wrap .swiper-pagination{position:relative;bottom:0!important;margin-top:8px}
.mobile-swiper-wrap .swiper-pagination-bullet{width:8px;height:8px;background:var(--border);opacity:1;transition:all .3s}
.mobile-swiper-wrap .swiper-pagination-bullet-active{background:var(--blue);width:24px;border-radius:4px}
.mobile-swiper-wrap .b-card,.mobile-swiper-wrap .svc-card,.mobile-swiper-wrap .type-card,
.mobile-swiper-wrap .benefit-card,.mobile-swiper-wrap .perk-card,.mobile-swiper-wrap .team-card,
.mobile-swiper-wrap .equip-card,.mobile-swiper-wrap .mvv-card,.mobile-swiper-wrap .accred-card,
.mobile-swiper-wrap .rel-card,.mobile-swiper-wrap .ob-card,.mobile-swiper-wrap .why-fac-card,
.mobile-swiper-wrap .fac-card,.mobile-swiper-wrap .fac-card-mini,.mobile-swiper-wrap .gallery-item{height:100%;margin:0}
.mobile-swiper-wrap .gallery-item{height:200px!important;border-radius:var(--r-lg)}
.mobile-swiper-wrap .gallery-item.large,.mobile-swiper-wrap .gallery-item.wide{grid-column:auto!important;grid-row:auto!important}
.why-fac .mobile-swiper-wrap .swiper-pagination-bullet,.fac-overview .mobile-swiper-wrap .swiper-pagination-bullet{background:rgba(255,255,255,.2)}
.why-fac .mobile-swiper-wrap .swiper-pagination-bullet-active,.fac-overview .mobile-swiper-wrap .swiper-pagination-bullet-active{background:#fff}
@media(min-width:769px){.mobile-swiper-wrap{display:none!important}}

/* ================================================================
   WORDPRESS BODY CLASS RESETS
   ================================================================ */
/* WP adds margins/padding via its own stylesheet — neutralise them */
.wp-site-blocks,
.wp-block-group,
.entry-content,
.wp-block-post-content { all: unset; }

/* Prevent WP block styles from breaking nav */
.header ul,
.header li,
.mob-nav ul,
.mob-nav li { list-style: none; margin: 0; padding: 0; }

/* Ensure mob-sub open state works */
.mob-nav .has-sub.open > .mob-sub { max-height: 500px; }
.mob-nav .has-sub.open > a .mc { transform: rotate(180deg); color: var(--blue); }


/* When admin bar is showing (logged-in users), offset the sticky header */
.admin-bar .header {
  top: 32px;
}

/* On mobile WP shrinks admin bar to 46px */
@media screen and (max-width: 782px) {
  .admin-bar .header {
    top: 46px;
  }
}

/* Ensure nav dropdown clears the admin bar */
.admin-bar .dropdown {
  z-index: 99998;
}

/* Fix: body padding so content isn't hidden under sticky header + admin bar */
.admin-bar body,
html.admin-bar {
  scroll-padding-top: calc(var(--header-h) + 32px);
}

/* ================================================================
   BASE OVERFLOW + LOGO FIX (all screens)
   ================================================================ */
html, body { overflow-x: hidden; }
.ms-has-custom-logo {
  display: flex !important;
  align-items: center !important;
  text-decoration: none !important;
  gap: 0 !important;
}
.ms-full-logo {
  height: 50px;
  width: auto;
  max-width: 220px;
  object-fit: contain;
  display: block;
}
.header.scrolled .ms-full-logo { height: 40px; }
