/* ==========================================================================
   Bariatric Surgeons India — Core Theme
   Brand colours are injected as CSS variables from the DB (see layout head),
   with these logo-derived defaults as a fallback.
   ========================================================================== */
:root{
    --primary:#0B4C97;
    --secondary:#12B5B0;
    --accent:#F57C00;
    --green:#2E9B2E;
    --white:#FFFFFF;
    --light:#F7FAFC;
    --dark:#1E293B;
    --grey:#64748B;
    --radius:16px;
    --radius-lg:24px;
    --shadow-sm:0 4px 12px rgba(15,23,42,.06);
    --shadow:0 12px 32px rgba(15,23,42,.10);
    --shadow-lg:0 24px 60px rgba(11,76,151,.16);
    --grad:linear-gradient(135deg,var(--primary),var(--secondary));
    --grad-warm:linear-gradient(135deg,var(--accent),#ff9d3c);
    --font:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    font-family:var(--font);
    color:var(--dark);
    background:var(--white);
    line-height:1.7;
    overflow-x:hidden;
}
a{text-decoration:none;color:var(--primary);transition:.25s}
a:hover{color:var(--secondary)}
img{max-width:100%;height:auto}
h1,h2,h3,h4,h5{font-weight:800;line-height:1.2;color:var(--dark)}
.section{padding:96px 0;position:relative}
.section-sm{padding:64px 0}
.bg-light{background:var(--light)}
.text-primary-c{color:var(--primary)!important}
.text-secondary-c{color:var(--secondary)!important}
.text-accent-c{color:var(--accent)!important}
.container{max-width:1200px}

/* ---------- Buttons ---------- */
.btn{border-radius:50px;font-weight:700;padding:.85rem 1.9rem;border:none;transition:.3s;letter-spacing:.2px}
.btn-brand{background:var(--grad);color:#fff;box-shadow:0 10px 24px rgba(11,76,151,.28)}
.btn-brand:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(11,76,151,.36);color:#fff}
.btn-accent{background:var(--grad-warm);color:#fff;box-shadow:0 10px 24px rgba(245,124,0,.3)}
.btn-accent:hover{transform:translateY(-3px);color:#fff}
.btn-outline-brand{background:transparent;color:var(--primary);border:2px solid var(--primary)}
.btn-outline-brand:hover{background:var(--primary);color:#fff;transform:translateY(-3px)}
.btn-light-glass{background:rgba(255,255,255,.15);color:#fff;border:2px solid rgba(255,255,255,.5);backdrop-filter:blur(8px)}
.btn-light-glass:hover{background:#fff;color:var(--primary)}

/* ---------- Section heading ---------- */
.eyebrow{display:inline-block;color:var(--secondary);font-weight:800;text-transform:uppercase;letter-spacing:2px;font-size:.8rem;margin-bottom:.75rem;position:relative;padding-left:0}
.eyebrow::before{content:'';display:inline-block;width:26px;height:3px;background:var(--accent);border-radius:3px;vertical-align:middle;margin-right:10px}
.section-title{font-size:clamp(1.8rem,3.4vw,2.6rem);margin-bottom:1rem}
.section-title span{color:var(--primary)}
.section-desc{color:var(--grey);max-width:640px}
.center-head{text-align:center;margin:0 auto 3.5rem}
.center-head .section-desc{margin-left:auto;margin-right:auto}

/* ---------- Top bar ---------- */
.topbar{background:linear-gradient(135deg,#0a1b33 0%,#0B4C97 60%,#0e3a6e 100%);color:#c8ddf5;font-size:.84rem;padding:.55rem 0;position:relative;z-index:1031}
.topbar::before{content:'';position:absolute;inset:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="4" height="4"><circle cx="2" cy="2" r=".4" fill="white" opacity=".06"/></svg>');pointer-events:none}
.topbar-info{display:flex;align-items:center;gap:6px}
.topbar-item{display:inline-flex;align-items:center;gap:8px;color:#c8ddf5;text-decoration:none;transition:.25s;padding:.18rem .6rem;border-radius:20px}
.topbar-item:hover{color:#fff;background:rgba(255,255,255,.08)}
.topbar-icon{width:26px;height:26px;border-radius:50%;background:rgba(18,181,176,.25);display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;color:var(--secondary)}
.topbar-divider{width:1px;height:18px;background:rgba(255,255,255,.15);margin:0 4px}
.topbar-right{display:flex;align-items:center;gap:16px}
.topbar-emergency{display:inline-flex;align-items:center;gap:8px;color:#ff9d9d;font-size:.84rem;text-decoration:none;padding:.2rem .8rem;border-radius:20px;border:1px solid rgba(255,100,100,.2);background:rgba(255,80,80,.08);transition:.25s}
.topbar-emergency:hover{background:rgba(255,80,80,.18);color:#ffb3b3}
.topbar-emergency strong{color:#fff}
.emergency-dot{width:7px;height:7px;border-radius:50%;background:#ff4d4d;display:inline-block;animation:emergencyPulse 1.4s ease-in-out infinite}
@keyframes emergencyPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.5)}}
.topbar-social{display:flex;gap:4px}
.topbar-social a{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:rgba(255,255,255,.07);color:#c8ddf5;font-size:.78rem;transition:.3s;text-decoration:none}
.topbar-social a:hover{background:var(--secondary);color:#fff;transform:translateY(-2px)}

/* ---------- Navbar ---------- */
.navbar{background:rgba(255,255,255,.98);padding:.5rem 0;box-shadow:0 1px 0 rgba(0,0,0,.04);transition:all .4s cubic-bezier(.4,0,.2,1);z-index:1030;border-bottom:1px solid rgba(0,0,0,.03)}
.navbar.sticky{position:fixed;top:0;left:0;right:0;animation:slideDown .45s cubic-bezier(.4,0,.2,1);background:rgba(255,255,255,.92);backdrop-filter:blur(20px) saturate(1.8);-webkit-backdrop-filter:blur(20px) saturate(1.8);box-shadow:0 8px 32px rgba(11,76,151,.08),0 1px 0 rgba(11,76,151,.05);border-bottom:1px solid rgba(11,76,151,.06)}
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
.navbar-brand{position:relative}
.nav-logo { height: 80px; transition: 0.3s; }
.navbar.sticky .nav-logo { height: 80px; }

/* Custom hamburger toggle */
.navbar-toggler{border:none;padding:8px;background:transparent;position:relative;width:36px;height:36px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;border-radius:8px;transition:.3s}
.navbar-toggler:focus{box-shadow:none;outline:none}
.navbar-toggler:hover{background:var(--light)}
.toggler-bar{display:block;width:22px;height:2.5px;background:var(--dark);border-radius:3px;transition:.3s}
.navbar-toggler[aria-expanded="true"] .toggler-bar:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.navbar-toggler[aria-expanded="true"] .toggler-bar:nth-child(2){opacity:0;transform:scaleX(0)}
.navbar-toggler[aria-expanded="true"] .toggler-bar:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* Nav links */
.navbar .nav-link{font-weight:700;color:var(--dark)!important;margin:0 .15rem;padding:.55rem .7rem!important;font-size:.88rem;white-space:nowrap;position:relative;border-radius:8px;transition:color .25s,background .25s}
.navbar .nav-link::before{content:'';position:absolute;left:50%;bottom:4px;width:0;height:2.5px;background:var(--grad);transition:width .3s cubic-bezier(.4,0,.2,1),left .3s cubic-bezier(.4,0,.2,1);border-radius:3px}
.navbar .nav-link:hover::before,.navbar .nav-link.active::before{width:calc(100% - 16px);left:8px}
.navbar .nav-link:hover{color:var(--primary)!important}
.navbar .nav-link:focus{box-shadow:none!important;outline:none!important}
.navbar .nav-link.active{color:var(--primary)!important}
.navbar .navbar-nav{gap:2px;align-items:center}

/* Dropdown styling */
.dropdown-menu{border:none;box-shadow:0 20px 50px rgba(15,23,42,.12),0 4px 12px rgba(15,23,42,.06);border-radius:16px;padding:.5rem;margin-top:8px!important;min-width:230px;opacity:0;transform:translateY(12px);transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);display:block;pointer-events:none;border:1px solid rgba(0,0,0,.04);background:rgba(255,255,255,.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.dropdown-menu.show,.nav-item.dropdown:hover>.dropdown-menu{opacity:1;transform:translateY(0);pointer-events:auto}
.dropdown-menu .dropdown-item{border-radius:10px;font-weight:600;padding:.6rem 1rem;font-size:.87rem;white-space:nowrap;transition:.25s;color:var(--dark)}
.dropdown-menu .dropdown-item:hover{background:linear-gradient(135deg,rgba(11,76,151,.06),rgba(18,181,176,.06));color:var(--primary);transform:translateX(4px)}
.dropdown-menu .dropdown-item i{margin-right:10px;color:var(--secondary);width:18px;text-align:center;font-size:.82rem;transition:.3s}
.dropdown-menu .dropdown-item:hover i{color:var(--primary);transform:scale(1.15)}

/* Mega menu (Resources) */
.mega-menu{min-width:480px;padding:0!important;overflow:hidden}
.mega-menu-inner{padding:1.5rem}
.mega-menu-header{margin-bottom:1rem;padding-bottom:.8rem;border-bottom:1px solid rgba(0,0,0,.05)}
.mega-menu-header h6{font-weight:800;color:var(--dark);font-size:.95rem;margin:0}
.mega-menu-header p{font-size:.8rem;color:var(--grey);margin:.3rem 0 0}
.mega-menu-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.mega-item{display:flex;align-items:center;gap:12px;padding:.65rem .8rem;border-radius:12px;text-decoration:none;color:var(--dark);transition:.25s}
.mega-item:hover{background:var(--light);transform:translateX(3px);color:var(--primary)}
.mega-item-icon{width:36px;height:36px;border-radius:10px;background:color-mix(in srgb,var(--mi-color) 12%,transparent);color:var(--mi-color);display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:.3s;flex-shrink:0}
.mega-item:hover .mega-item-icon{transform:scale(1.1);background:color-mix(in srgb,var(--mi-color) 20%,transparent)}
.mega-item-label{font-weight:600;font-size:.87rem}

/* Desktop: hover to open dropdowns */
@media(min-width:992px){
    .navbar .nav-item.dropdown:hover>.dropdown-menu{opacity:1;transform:translateY(0);pointer-events:auto}
    .navbar .nav-item.dropdown>.dropdown-menu{top:100%;left:0}
    .dropdown-mega>.dropdown-menu{left:50%;transform:translateX(-50%) translateY(12px)!important}
    .dropdown-mega:hover>.dropdown-menu{transform:translateX(-50%) translateY(0)!important}
}

/* Nav CTA area */
.nav-cta{display:flex;align-items:center;gap:16px;margin-left:12px}
.nav-phone{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--dark);padding:.5rem .8rem;border-radius:12px;transition:.25s;border:1px solid transparent}
.nav-phone:hover{background:var(--light);border-color:rgba(11,76,151,.08);color:var(--dark)}
.phone-icon{width:40px;height:40px;border-radius:50%;background:rgba(18,181,176,.1);color:var(--secondary);display:flex;align-items:center;justify-content:center;font-size:.95rem;transition:.3s}
.nav-phone:hover .phone-icon{background:var(--secondary);color:#fff;transform:rotate(-10deg)}
.phone-text{display:flex;flex-direction:column;line-height:1.2}
.phone-text small{font-size:.7rem;color:var(--grey);font-weight:600;text-transform:uppercase;letter-spacing:.5px}
.phone-text strong{font-size:.9rem;color:var(--primary)}

/* CTA button with glow */
.btn-nav-cta{position:relative;overflow:hidden;background:var(--grad);color:#fff;border:none;border-radius:50px;font-weight:700;padding:.7rem 1.5rem;font-size:.85rem;white-space:nowrap;box-shadow:0 8px 24px rgba(11,76,151,.25);transition:all .35s cubic-bezier(.4,0,.2,1);z-index:1}
.btn-nav-cta:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(11,76,151,.35);color:#fff}
.btn-nav-cta:active{transform:translateY(0)}
.btn-cta-glow{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent,rgba(255,255,255,.2),transparent 40%);animation:ctaGlow 3s linear infinite;z-index:-1}
@keyframes ctaGlow{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}

/* ---------- Hero Video ---------- */
.hero-video-section{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:#0a1b33}

/* Uploaded video background */
.hero-video-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1}

/* YouTube embed background */
.hero-yt-wrap{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.hero-yt-bg{position:absolute;top:50%;left:50%;width:100vw;height:56.25vw;min-height:100vh;min-width:177.78vh;transform:translate(-50%,-50%);border:none}

/* Poster fallback image */
.hero-poster{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}

/* Gradient overlay — darker on left for text readability */
.hero-video-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(100deg,rgba(10,27,51,.92) 0%,rgba(11,76,151,.7) 40%,rgba(18,181,176,.25) 75%,rgba(10,27,51,.6) 100%)}
.hero-video-overlay::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,transparent 0%,rgba(10,27,51,.3) 100%)}

/* Content layer */
.hero-video-content{position:relative;z-index:3;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:120px 0 80px;color:#fff}
.hero-video-inner{max-width:700px}
.hero-video-sub{display:inline-flex;align-items:center;gap:10px;color:#7fe3df;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;font-size:.82rem;margin-bottom:1.2rem;padding:.4rem .9rem;background:rgba(18,181,176,.12);border:1px solid rgba(18,181,176,.2);border-radius:30px;backdrop-filter:blur(6px)}
.hero-video-sub::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--secondary);animation:heroDot 2s ease-in-out infinite}
@keyframes heroDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}
.hero-video-section h1{color:#fff;font-size:clamp(2.2rem,5.5vw,3.8rem);margin-bottom:1.2rem;line-height:1.15;text-shadow:0 4px 30px rgba(0,0,0,.2)}
.hero-video-section p{font-size:1.15rem;color:rgba(226,232,240,.9);margin-bottom:2.2rem;max-width:580px;line-height:1.8}
.hero-video-ctas{display:flex;flex-wrap:wrap;gap:14px}

/* Scroll indicator */
.hero-scroll-indicator{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);text-align:center;color:rgba(255,255,255,.5);font-size:.72rem;font-weight:600;letter-spacing:2px;text-transform:uppercase}
.scroll-line{width:2px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);margin:8px auto 0;position:relative;border-radius:2px;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:50%;background:rgba(255,255,255,.8);animation:scrollBounce 2s ease-in-out infinite}
@keyframes scrollBounce{0%{top:-50%}50%{top:100%}100%{top:-50%}}

/* ---------- Cards ---------- */
.card-soft{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid #eef2f7;transition:.35s;overflow:hidden;height:100%}
.card-soft:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}

/* Feature / why-choose card */
.feature-card{padding:2.2rem 1.8rem;text-align:left}
.feature-card .icon{width:66px;height:66px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:#fff;background:var(--grad);margin-bottom:1.3rem;transition:.4s}
.feature-card:hover .icon{transform:rotateY(360deg)}
.feature-card h4{font-size:1.2rem;margin-bottom:.6rem}
.feature-card p{color:var(--grey);margin:0;font-size:.96rem}

/* Procedure card */
.proc-card{position:relative}
.proc-card .thumb{height:220px;overflow:hidden;position:relative}
.proc-card .thumb img{width:100%;height:100%;object-fit:cover;transition:.6s}
.proc-card:hover .thumb img{transform:scale(1.08)}
.proc-card .thumb .badge-icon{position:absolute;bottom:-26px;left:24px;width:56px;height:56px;border-radius:16px;background:var(--grad-warm);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:var(--shadow)}
.proc-card .body{padding:2.2rem 1.6rem 1.6rem}
.proc-card h4{font-size:1.22rem;margin-bottom:.6rem}
.proc-card p{color:var(--grey);font-size:.95rem}
.proc-card .more{font-weight:700;color:var(--primary);display:inline-flex;align-items:center;gap:6px}
.proc-card .more i{transition:.3s}
.proc-card:hover .more i{transform:translateX(5px)}

/* Doctor card (New 2-column design) */
.docs-new-section { background-color: #fafbfe; }
.doc-card-new { background: #fff; border-radius: 24px; box-shadow: 0 10px 40px rgba(11,76,151,.05); position: relative; overflow: hidden; padding: 20px; transition: transform 0.4s cubic-bezier(0.4,0,0.2,1); }
.doc-card-new::before { content: ''; position: absolute; top: 0; right: 0; width: 300px; height: 300px; background: radial-gradient(circle, rgba(18,181,176,.06) 0%, rgba(255,255,255,0) 70%); z-index: 0; border-radius: 50%; transform: translate(30%, -30%); }
.doc-card-new:hover { transform: translateY(-5px); box-shadow: 0 20px 50px rgba(11,76,151,.1); }

/* Left Photo Area */
.doc-photo-wrap { position: relative; height: 100%; min-height: 380px; border-radius: 16px; overflow: hidden; z-index: 1; }
.doc-photo-wrap img { width: 100%; height: 100%; object-fit: cover; object-position: top; }
.doc-rating-badge { position: absolute; top: 16px; left: 16px; background: #fff; border-radius: 20px; padding: 6px 12px; font-weight: 700; font-size: 0.85rem; color: #1e293b; box-shadow: 0 4px 15px rgba(0,0,0,.08); display: inline-flex; align-items: center; }
.doc-exp-badge { position: absolute; bottom: 20px; right: -20px; background: #fff; border-radius: 16px; padding: 12px 16px; display: inline-flex; align-items: center; gap: 8px; box-shadow: 0 8px 24px rgba(0,0,0,.1); z-index: 2; transform: translateX(-20px); }
.doc-exp-badge strong { font-size: 1.6rem; color: var(--primary); line-height: 1; }
.doc-exp-badge span { font-size: 0.55rem; color: #64748b; text-transform: uppercase; letter-spacing: 0.5px; font-weight: 700; line-height: 1.2; }

/* Right Info Area */
.doc-info-wrap { padding: 10px 10px 10px 30px; position: relative; z-index: 1; height: 100%; display: flex; flex-direction: column; justify-content: center; }
@media (max-width: 767px) { .doc-info-wrap { padding: 30px 10px 10px 10px; } }
.doc-name { font-size: 1.8rem; font-weight: 800; color: var(--primary); margin-bottom: 0.4rem; letter-spacing: -0.5px; }
.doc-role { font-size: 0.95rem; font-weight: 600; color: var(--secondary); margin-bottom: 1.2rem; }
.doc-qual-pill { background: rgba(18,181,176,0.06); color: var(--primary); display: inline-block; padding: 8px 16px; border-radius: 8px; font-size: 0.82rem; font-weight: 700; margin-bottom: 1.4rem; letter-spacing: 0.5px; width: 100%; border: 1px solid rgba(18,181,176,0.15); }

.doc-bullet-list { list-style: none; padding: 0; margin: 0 0 1.2rem 0; }
.doc-bullet-list li { position: relative; padding-left: 20px; font-size: 0.9rem; color: #64748b; margin-bottom: 0.5rem; line-height: 1.5; }
.doc-bullet-list li::before { content: ''; position: absolute; left: 0; top: 8px; width: 8px; height: 8px; background-color: var(--accent); border-radius: 50%; }

.doc-quote { font-style: italic; font-size: 0.85rem; color: #94a3b8; margin-bottom: 1.2rem; line-height: 1.5; }

.doc-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 1.8rem; }
.doc-tags span { border: 1px solid #e2e8f0; color: #64748b; font-size: 0.75rem; font-weight: 600; padding: 4px 12px; border-radius: 20px; background: #fff; }

.doc-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: auto; }
.btn-doc-primary { background: var(--primary); color: #fff; font-weight: 600; border-radius: 24px; padding: 0.65rem 1.4rem; font-size: 0.9rem; border: none; box-shadow: 0 6px 20px rgba(11,76,151,.25); transition: 0.3s; }
.btn-doc-primary:hover { background: #083870; color: #fff; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(11,76,151,.35); }
.btn-whatsapp { background: #25D366; color: #fff; font-weight: 600; border-radius: 24px; padding: 0.65rem 1.4rem; font-size: 0.9rem; border: none; box-shadow: 0 6px 20px rgba(37,211,102,.25); transition: 0.3s; display: inline-flex; align-items: center; }
.btn-whatsapp:hover { background: #20BA5A; color: #fff; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(37,211,102,.35); }

/* ---------- Counters ---------- */
.stats-band{background:var(--grad);color:#fff;position:relative;overflow:hidden}
.stats-band::before{content:'';position:absolute;inset:0;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="60" height="60"><circle cx="30" cy="30" r="1.5" fill="white" opacity="0.15"/></svg>')}
.stat-item{text-align:center;padding:1rem}
.stat-item .icon{font-size:2.2rem;margin-bottom:.6rem;color:#9fecent}
.stat-item .num{font-size:2.8rem;font-weight:800;line-height:1}
.stat-item .label{opacity:.9;font-weight:600;margin-top:.4rem}

/* ---------- About ---------- */
.about-img-wrap{position:relative}
.about-img-wrap img.main{border-radius:var(--radius-lg);box-shadow:var(--shadow)}
.about-img-wrap .badge-float{position:absolute;bottom:-24px;right:-10px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1.1rem 1.4rem;display:flex;align-items:center;gap:12px}
.about-img-wrap .badge-float .ic{width:52px;height:52px;border-radius:14px;background:var(--grad-warm);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem}
.about-list{list-style:none;padding:0;margin:1.4rem 0}
.about-list li{padding:.35rem 0;font-weight:600;color:var(--dark)}
.about-list li i{color:var(--green);margin-right:10px}

/* ---------- BMI ---------- */
.bmi-wrap{background:var(--grad);border-radius:var(--radius-lg);padding:3rem;color:#fff;box-shadow:var(--shadow-lg)}
.bmi-card{background:#fff;border-radius:var(--radius);padding:2rem;color:var(--dark)}
.bmi-result{text-align:center;padding:1.5rem;border-radius:var(--radius);background:var(--light);margin-top:1rem}
.bmi-result .value{font-size:3rem;font-weight:800}
.bmi-gauge{height:14px;border-radius:10px;background:linear-gradient(90deg,#3B82F6,#2E9B2E,#F57C00,#DC2626,#991B1B);position:relative;margin:1.5rem 0}
.bmi-pointer{position:absolute;top:-6px;width:4px;height:26px;background:var(--dark);border-radius:3px;transition:.6s}

/* ---------- Journey timeline ---------- */
.journey-container { position: relative; }
.journey-flow-line { 
    position: absolute; 
    top: 70px; 
    left: 12.5%; 
    width: 75%; 
    height: 4px; 
    background-image: linear-gradient(90deg, var(--secondary) 50%, transparent 50%);
    background-size: 20px 4px;
    z-index: 0;
    animation: flowLine 1s linear infinite;
    opacity: 0.6;
}
@keyframes flowLine {
    0% { background-position: 0 0; }
    100% { background-position: 20px 0; }
}

.journey-card { background: #fff; border-radius: 20px; padding: 2.5rem 1.5rem; text-align: center; box-shadow: 0 10px 30px rgba(11,76,151,.04); position: relative; overflow: hidden; border: 1px solid #f1f5f9; transition: 0.3s cubic-bezier(0.4, 0, 0.2, 1); z-index: 1; animation: cardGlow 8s infinite; }
.journey-card:hover { transform: translateY(-5px) !important; box-shadow: 0 20px 40px rgba(11,76,151,.1) !important; border-color: #e2e8f0 !important; animation: none; }

.journey-icon-wrap { width: 80px; height: 80px; border-radius: 24px; background: linear-gradient(135deg, rgba(11,76,151,.1), rgba(18,181,176,.1)); color: var(--primary); font-size: 2rem; display: flex; align-items: center; justify-content: center; margin: 0 auto 1.5rem; position: relative; }
.step-num { position: absolute; top: -10px; right: -10px; width: 30px; height: 30px; border-radius: 50%; background: var(--secondary); color: #fff; font-size: 0.9rem; font-weight: 800; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 10px rgba(18,181,176,.4); border: 2px solid #fff; }

.journey-title { font-size: 1.3rem; font-weight: 800; color: #1e293b; margin-bottom: 0.8rem; }
.journey-text { color: #64748b; font-size: 0.95rem; line-height: 1.6; margin-bottom: 0; }

/* Stagger sequential animations */
.col-lg-3:nth-child(1) .journey-card { animation-delay: 0s; }
.col-lg-3:nth-child(2) .journey-card { animation-delay: 2s; }
.col-lg-3:nth-child(3) .journey-card { animation-delay: 4s; }
.col-lg-3:nth-child(4) .journey-card { animation-delay: 6s; }

@keyframes cardGlow {
    0%, 20% { border-color: var(--secondary); box-shadow: 0 10px 30px rgba(18,181,176,0.15); transform: translateY(-5px); }
    25%, 100% { border-color: #f1f5f9; box-shadow: 0 10px 30px rgba(11,76,151,.04); transform: translateY(0); }
}

/* ---------- Testimonials (Google Reviews) ---------- */
.google-static-card { background: #fff; border-radius: 16px; padding: 3rem 1.5rem; box-shadow: 0 4px 15px rgba(0,0,0,.04); border: 1px solid #f1f5f9; height: 100%; transition: 0.3s; }
.google-static-card:hover { box-shadow: 0 8px 25px rgba(0,0,0,.08); }
.google-review-card { background: #fff; border-radius: 12px; padding: 1.8rem; box-shadow: 0 4px 15px rgba(0,0,0,.04); border: 1px solid #f1f5f9; transition: 0.3s; }
.google-review-card:hover { box-shadow: 0 8px 25px rgba(0,0,0,.08); transform: translateY(-3px); }
.google-avatar { width: 45px; height: 45px; border-radius: 50%; object-fit: cover; }
.google-avatar-text { width: 45px; height: 45px; border-radius: 50%; color: #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 1.2rem; }
.google-review-text { color: #475569; font-size: 0.95rem; line-height: 1.6; }

.google-nav-btn { position: absolute; top: 50%; transform: translateY(-50%); width: 40px; height: 40px; background: #fff; border: 1px solid #e2e8f0; border-radius: 50%; color: #64748b; font-size: 1rem; display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 10; box-shadow: 0 2px 8px rgba(0,0,0,.05); transition: 0.3s; }
.google-nav-btn:hover { background: #f8fafc; color: #0f172a; box-shadow: 0 4px 12px rgba(0,0,0,.1); }
.google-prev { left: -15px; }
.google-next { right: -15px; }
@media (max-width: 991px) { .google-prev { left: 5px; } .google-next { right: 5px; } }
.stars{color:#f59e0b}

/* ---------- Before/After ---------- */
.ba-card{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);background:#fff}
.ba-images{display:flex}
.ba-images .col-ba{flex:1;position:relative}
.ba-images .col-ba img{width:100%;height:280px;object-fit:cover}
.ba-images .tag{position:absolute;top:12px;left:12px;background:rgba(11,76,151,.9);color:#fff;padding:.25rem .8rem;border-radius:30px;font-size:.75rem;font-weight:700}
.ba-images .tag.after{background:rgba(46,155,46,.9);left:auto;right:12px}

/* ---------- Insurance ---------- */
.insurance-logo{background:#fff;border-radius:var(--radius);padding:1.4rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);height:110px;transition:.3s}
.insurance-logo:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.insurance-logo img{max-height:64px;object-fit:contain;filter:grayscale(1);opacity:.7;transition:.3s}
.insurance-logo:hover img{filter:grayscale(0);opacity:1}

/* ---------- Blog ---------- */
.blog-card .thumb{height:220px;overflow:hidden}
.blog-card .thumb img{width:100%;height:100%;object-fit:cover;transition:.5s}
.blog-card:hover .thumb img{transform:scale(1.07)}
.blog-card .body{padding:1.6rem}
.blog-meta{font-size:.8rem;color:var(--grey);display:flex;gap:16px;margin-bottom:.6rem}
.blog-meta .cat{color:var(--secondary);font-weight:700}
.blog-card h4{font-size:1.15rem;line-height:1.4}
.blog-card h4 a{color:var(--dark)}
.blog-card h4 a:hover{color:var(--primary)}

/* ---------- FAQ ---------- */
.accordion-item{border:none;margin-bottom:1rem;border-radius:var(--radius)!important;overflow:hidden;box-shadow:var(--shadow-sm)}
.accordion-button{font-weight:700;color:var(--dark);padding:1.2rem 1.5rem;background:#fff}
.accordion-button:not(.collapsed){color:var(--primary);background:var(--light);box-shadow:none}
.accordion-button:focus{box-shadow:none}
.accordion-button::after{background-size:1rem}
.accordion-body{color:var(--grey)}

/* ---------- Appointment ---------- */
.appointment-band{background:linear-gradient(135deg,#0a2a4f,var(--primary));color:#fff;position:relative;overflow:hidden}
.appt-form{background:#fff;border-radius:var(--radius-lg);padding:2.5rem;box-shadow:var(--shadow-lg)}
.appt-form .form-control,.appt-form .form-select,.contact-form .form-control,.contact-form .form-select{border-radius:12px;padding:.8rem 1rem;border:1.5px solid #e2e8f0;font-size:.95rem}
.appt-form .form-control:focus,.form-select:focus,.contact-form .form-control:focus{border-color:var(--secondary);box-shadow:0 0 0 3px rgba(18,181,176,.15)}
.form-label{font-weight:600;font-size:.88rem;color:var(--dark)}

/* ---------- Page banner ---------- */
.page-banner{position:relative;padding:120px 0 80px;color:#fff;background-size:cover;background-position:center;text-align:center}
.page-banner::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,30,60,.82),rgba(11,76,151,.78))}
.page-banner .inner{position:relative;z-index:2}
.page-banner h1{color:#fff;font-size:clamp(2rem,4vw,3rem)}
.page-banner .breadcrumb{justify-content:center;margin-top:.8rem}
.page-banner .breadcrumb a{color:#cbe4ff}
.page-banner .breadcrumb-item.active{color:#fff}
.page-banner .breadcrumb-item+.breadcrumb-item::before{color:#9fbfe0}

/* ---------- Footer ---------- */
.footer{background:#0a1b33;color:#94a3b8;padding:80px 0 0}
.footer h5{color:#fff;font-size:1.05rem;margin-bottom:1.4rem;position:relative;padding-bottom:.6rem}
.footer h5::after{content:'';position:absolute;left:0;bottom:0;width:36px;height:3px;background:var(--accent);border-radius:3px}
.footer a{color:#94a3b8}
.footer a:hover{color:var(--secondary);padding-left:5px}
.footer .flinks{list-style:none;padding:0}
.footer .flinks li{margin-bottom:.7rem}
.footer .flinks li i{color:var(--secondary);margin-right:8px;font-size:.8rem}
.footer .contact-line{display:flex;gap:12px;margin-bottom:1rem}
.footer .contact-line i{color:var(--accent);margin-top:4px}
.footer .fsocial a{width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.06);display:inline-flex;align-items:center;justify-content:center;margin-right:8px;color:#fff}
.footer .fsocial a:hover{background:var(--grad);transform:translateY(-4px)}
.footer-brand img{height:64px;margin-bottom:1.2rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:60px;padding:22px 0;font-size:.85rem}

/* ---------- Floating buttons ---------- */
.floaters{position:fixed;right:20px;bottom:24px;z-index:1050;display:flex;flex-direction:column;gap:12px}
.floaters a{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;box-shadow:var(--shadow);transition:.3s;position:relative}
.floaters a:hover{transform:scale(1.1);color:#fff}
.floaters .wa{background:#25D366}
.floaters .call{background:var(--accent)}
.floaters a::after{content:'';position:absolute;inset:0;border-radius:50%;border:2px solid currentColor;animation:pulse 1.8s infinite}
@keyframes pulse{0%{transform:scale(1);opacity:.7}100%{transform:scale(1.6);opacity:0}}

/* ---------- Utilities ---------- */
.divider-shape{position:absolute;left:0;right:0;line-height:0}
.hover-lift{transition:.35s}
.hover-lift:hover{transform:translateY(-6px)}
.badge-soft{background:rgba(18,181,176,.12);color:var(--secondary);font-weight:700;padding:.4rem 1rem;border-radius:30px;font-size:.78rem}
.rating-input i{cursor:pointer}

/* ---------- Detail pages ---------- */
.detail-sidebar{position:sticky;top:100px}
.side-card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.8rem;margin-bottom:1.5rem}
.side-card h5{font-size:1.05rem;margin-bottom:1rem}
.proc-list-side a{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;border-radius:12px;color:var(--dark);font-weight:600;margin-bottom:.4rem;background:var(--light)}
.proc-list-side a:hover,.proc-list-side a.active{background:var(--grad);color:#fff}
.content-block{margin-bottom:2.5rem}
.content-block h3{font-size:1.5rem;margin-bottom:1rem;padding-left:16px;border-left:4px solid var(--accent)}
.content-block ul{padding-left:1.2rem}
.content-block ul li{margin-bottom:.5rem}
.article-body{font-size:1.05rem;color:#334155}
.article-body h3{margin:1.6rem 0 .8rem;color:var(--primary)}
.article-body p{margin-bottom:1.1rem}

/* ---------- Responsive ---------- */
@media(max-width:991px){
    .section{padding:64px 0}
    .nav-logo{height:44px}
    .hero .swiper-slide{min-height:78vh}
    .navbar-collapse{background:#fff;padding:1.2rem;border-radius:16px;box-shadow:0 20px 50px rgba(15,23,42,.12);margin-top:.8rem;border:1px solid rgba(0,0,0,.04)}
    .navbar .nav-link{padding:.6rem .8rem!important;border-radius:10px}
    .navbar .nav-link:hover{background:var(--light)}
    .navbar .nav-link::before{display:none}
    .mega-menu{min-width:100%!important;position:relative!important;box-shadow:none!important;border:none!important;margin-top:0!important}
    .mega-menu-grid{grid-template-columns:1fr}
    .nav-cta{flex-direction:column;margin:1rem 0 0;gap:10px;width:100%}
    .nav-phone{width:100%;justify-content:center;background:var(--light);border-radius:12px}
    .btn-nav-cta{width:100%;text-align:center;justify-content:center;display:flex;padding:.85rem 1.5rem}
    .bmi-wrap{padding:1.6rem}
    .dropdown-menu{position:relative!important;box-shadow:none!important;border:none!important;background:var(--light)!important;margin:0!important;transform:none!important;opacity:1!important;pointer-events:auto!important}
}
@media(max-width:767px){
    .section{padding:52px 0}
    .stat-item .num{font-size:2.2rem}
    .hero p{font-size:1rem}
    .appt-form{padding:1.5rem}
    .ba-images .col-ba img{height:200px}
    .floaters a{width:50px;height:50px;font-size:1.3rem}
}
