/* =========================================================
   SAGAR CLINIC — Premium Medical Website Stylesheet
   "Sagar" means ocean — the palette and motion language
   (deep teal tones + a recurring ECG/wave "vital line")
   are drawn directly from that name.
   ========================================================= */

/* ---------- 1. DESIGN TOKENS ---------- */
:root{
  /* Colors */
  --clr-bg:        #FBFCFB;
  --clr-surface:   #FFFFFF;
  --clr-mint:      #EAF6F1;
  --clr-mint-2:    #DCF0E8;
  --clr-primary:   #0E7C66;
  --clr-primary-dark:#0A5C4C;
  --clr-primary-light:#14A085;
  --clr-ink:       #0F2624;
  --clr-ink-soft:  #4D6663;
  --clr-accent:    #FF7A55;
  --clr-accent-dark:#E85F3B;
  --clr-gold:      #F4B740;
  --clr-line:      rgba(15,38,36,0.08);

  /* Typography */
  --font-display: 'Fraunces', serif;
  --font-body: 'Plus Jakarta Sans', sans-serif;

  /* Shadows */
  --shadow-sm: 0 4px 14px rgba(15,38,36,0.06);
  --shadow-md: 0 14px 34px rgba(15,38,36,0.10);
  --shadow-lg: 0 26px 60px rgba(15,38,36,0.16);
  --shadow-accent: 0 14px 30px rgba(255,122,85,0.30);

  /* Misc */
  --radius-sm: 12px;
  --radius-md: 20px;
  --radius-lg: 32px;
  --ease: cubic-bezier(.22,1,.36,1);
}

/* ---------- 2. RESET / BASE ---------- */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--font-body);
  color:var(--clr-ink);
  background:var(--clr-bg);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; height:auto; display:block; }
a{ text-decoration:none; color:inherit; }
ul{ list-style:none; margin:0; padding:0; }
::selection{ background:var(--clr-accent); color:#fff; }

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-display);
  color:var(--clr-ink);
  font-weight:700;
  margin:0;
}

::-webkit-scrollbar{ width:10px; }
::-webkit-scrollbar-track{ background:var(--clr-mint); }
::-webkit-scrollbar-thumb{ background:var(--clr-primary-light); border-radius:10px; }

/* Focus visibility for accessibility */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible{
  outline:3px solid var(--clr-accent);
  outline-offset:2px;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

/* ---------- 3. PRELOADER ---------- */
#preloader{
  position:fixed; inset:0; z-index:9999;
  background:var(--clr-bg);
  display:flex; align-items:center; justify-content:center;
  transition:opacity .6s var(--ease), visibility .6s var(--ease);
}
#preloader.loaded{ opacity:0; visibility:hidden; pointer-events:none; }
.loader-pulse{ width:64px; height:64px; position:relative; }
.loader-pulse svg{ width:100%; height:100%; }
.loader-pulse .heart-path{
  fill:none; stroke:var(--clr-primary); stroke-width:4; stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:300; stroke-dashoffset:300;
  animation:drawPulse 1.4s ease-in-out infinite;
}
@keyframes drawPulse{
  0%{ stroke-dashoffset:300; }
  60%{ stroke-dashoffset:0; }
  100%{ stroke-dashoffset:-300; }
}

/* ---------- 4. UTILITIES ---------- */
.section{ padding:30px 0; position:relative; }
.section-sm{ padding:4rem 0; }
@media (max-width:767px){
  .section{ padding:4.2rem 0; }
}

.eyebrow{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--font-body); font-weight:700; letter-spacing:.18em;
  text-transform:uppercase; font-size:.78rem; color:var(--clr-accent-dark);
  margin-bottom:.9rem;
}
.eyebrow::before{
  content:""; width:26px; height:2px; background:var(--clr-accent); border-radius:2px;
}
.eyebrow.center{ justify-content:center; }

.section-title{
  font-size:clamp(1.9rem,3.2vw,2.85rem);
  line-height:1.15; letter-spacing:-.01em; margin-bottom:1rem;
}
.section-title em{ font-style:italic; color:var(--clr-primary); }
.section-sub{
  color:var(--clr-ink-soft); font-size:1.05rem; max-width:620px;
}
.mx-auto-text{ margin-left:auto; margin-right:auto; text-align:center; }

.text-grad{
  background:linear-gradient(100deg,var(--clr-primary) 10%,var(--clr-primary-light) 50%,var(--clr-accent) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}

/* Buttons */
.btn-clinic{
  position:relative; display:inline-flex; align-items:center; justify-content:center; gap:.6rem;
  font-family:var(--font-body); font-weight:700; font-size:.95rem;
  padding:.95rem 1.9rem; border-radius:50px; border:none; cursor:pointer;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease);
  white-space:nowrap; isolation:isolate; overflow:hidden;
}
.btn-clinic.btn-primary-clinic{
  background:linear-gradient(135deg,var(--clr-accent),var(--clr-accent-dark));
  color:#fff; box-shadow:var(--shadow-accent);
}
.btn-clinic.btn-primary-clinic:hover{ transform:translateY(-4px); box-shadow:0 20px 36px rgba(255,122,85,0.4); color:#fff; }
.btn-clinic.btn-outline-clinic{
  background:transparent; color:var(--clr-primary-dark);
  border:2px solid var(--clr-primary); 
}
.btn-clinic.btn-outline-clinic:hover{ background:var(--clr-primary); color:#fff; transform:translateY(-4px); box-shadow:var(--shadow-md); }
.btn-clinic.btn-light-clinic{
  background:#fff; color:var(--clr-primary-dark); box-shadow:var(--shadow-sm);
}
.btn-clinic.btn-light-clinic:hover{ transform:translateY(-4px); box-shadow:var(--shadow-md); }
.btn-clinic .shine{
  position:absolute; top:0; left:-60%; width:40%; height:100%;
  background:linear-gradient(120deg, transparent, rgba(255,255,255,.55), transparent);
  transform:skewX(-20deg); transition:left .6s var(--ease);
}
.btn-clinic:hover .shine{ left:130%; }
.btn-clinic i{ font-size:.95em; transition:transform .35s var(--ease); }
.btn-clinic:hover i.fa-arrow-right, .btn-clinic:hover i.fa-chevron-right{ transform:translateX(4px); }

/* Glass card */
.glass-card{
  background:rgba(255,255,255,0.66);
  border:1px solid rgba(255,255,255,0.6);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  box-shadow:var(--shadow-md);
  border-radius:var(--radius-md);
}

/* Vital / ECG divider — signature element */
.vital-divider{ width:100%; overflow:hidden; line-height:0; }
.vital-divider svg{ width:100%; height:46px; display:block; }
.vital-divider path{
  fill:none; stroke:var(--clr-primary-light); stroke-width:2.4; stroke-linecap:round; stroke-linejoin:round;
  stroke-dasharray:1400; stroke-dashoffset:1400;
  transition:stroke-dashoffset 1.8s var(--ease);
}
.vital-divider.in-view path{ stroke-dashoffset:0; }
.vital-divider.accent path{ stroke:var(--clr-accent); }

/* ---------- 5. SCROLL REVEAL ---------- */
[data-reveal]{ opacity:0; transition:opacity .8s var(--ease), transform .8s var(--ease); will-change:transform,opacity; }
[data-reveal="fade-up"]{ transform:translateY(42px); }
[data-reveal="fade-down"]{ transform:translateY(-42px); }
[data-reveal="fade-left"]{ transform:translateX(-52px); }
[data-reveal="fade-right"]{ transform:translateX(52px); }
[data-reveal="zoom-in"]{ transform:scale(.85); }
[data-reveal].in-view{ opacity:1; transform:none; }

/* ---------- 6. NAVBAR ---------- */
.custom-navbar{
  background:#fff;
  backdrop-filter:blur(0px);
  -webkit-backdrop-filter:blur(0px);
  padding:1.35rem 0;
  transition:all .45s var(--ease);
  border-bottom:1px solid transparent;
}
.custom-navbar.scrolled{
   background:#fff;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  padding:.7rem 0;
  border-bottom:1px solid var(--clr-line);
  box-shadow:0 8px 30px rgba(15,38,36,0.06);
}
.brand-logo{ display:flex; align-items:center; gap:.6rem; font-family:var(--font-display); font-weight:800; font-size:1.5rem; color:var(--clr-ink); }
.brand-mark{ width:38px; height:38px; flex-shrink:0; }
.brand-accent{ color:var(--clr-primary); }

.custom-navbar .navbar-nav .nav-link{
  font-weight:600; color:var(--clr-ink); padding:.55rem 1rem; position:relative; transition:color .3s;
}
.custom-navbar .navbar-nav .nav-link::after{
  content:""; position:absolute; left:1rem; right:1rem; bottom:.25rem; height:2px;
  background:var(--clr-accent); transform:scaleX(0); transform-origin:left; transition:transform .35s var(--ease);
}
.custom-navbar .navbar-nav .nav-link:hover, .custom-navbar .navbar-nav .nav-link.active{ color:var(--clr-primary-dark); }
.custom-navbar .navbar-nav .nav-link:hover::after, .custom-navbar .navbar-nav .nav-link.active::after{ transform:scaleX(1); }

.nav-phone{ display:flex; align-items:center; gap:.5rem; font-weight:700; color:var(--clr-primary-dark); padding:.5rem 1rem; }
.nav-phone i{ color:var(--clr-accent); }

.btn-book-now{
  background:linear-gradient(135deg,var(--clr-primary),var(--clr-primary-dark));
  color:#fff; border:none; font-weight:700; padding:.7rem 1.5rem; border-radius:50px;
  margin-left:.6rem; box-shadow:0 10px 22px rgba(14,124,102,0.32); transition:all .35s var(--ease);
}
.btn-book-now:hover{ transform:translateY(-3px) scale(1.03); box-shadow:0 16px 28px rgba(14,124,102,0.4); }

.navbar-toggler{ border:none; box-shadow:none !important; }

/* ---------- 7. HERO ---------- */
.hero{
  position:relative; padding:9.5rem 0 5rem; overflow:hidden;
  background:linear-gradient(180deg,#F4FAF8 0%, var(--clr-bg) 70%);
}
.hero-blob{
  position:absolute; border-radius:50%; filter:blur(60px); z-index:0; opacity:.55;
}
.hero-blob.b1{ width:480px; height:480px; background:radial-gradient(circle,var(--clr-mint-2),transparent 70%); top:-180px; right:-120px; animation:driftSlow 14s ease-in-out infinite; }
.hero-blob.b2{ width:340px; height:340px; background:radial-gradient(circle,#FFE3D6,transparent 70%); bottom:-120px; left:-100px; animation:driftSlow 18s ease-in-out infinite reverse; }
@keyframes driftSlow{ 0%,100%{ transform:translate(0,0); } 50%{ transform:translate(30px,-26px); } }

.hero-vital-bg{ position:absolute; inset:auto 0 8% 0; opacity:.25; z-index:0; }
.hero-vital-bg svg{ width:100%; height:80px; }
.hero-vital-bg path{ fill:none; stroke:var(--clr-primary); stroke-width:2; stroke-dasharray:6 10; animation:dashFlow 6s linear infinite; }
@keyframes dashFlow{ to{ stroke-dashoffset:-160; } }

.hero-content{ position:relative; z-index:2; }
.hero-eyebrow-chip{
  display:inline-flex; align-items:center; gap:.5rem; background:#fff; border:1px solid var(--clr-line);
  padding:.45rem 1rem .45rem .6rem; border-radius:50px; font-size:.82rem; font-weight:700; color:var(--clr-primary-dark);
  box-shadow:var(--shadow-sm); margin-bottom:1.5rem;
}
.hero-eyebrow-chip .dot{ width:8px; height:8px; border-radius:50%; background:var(--clr-accent); animation:dotPulse 1.6s ease-in-out infinite; }
@keyframes dotPulse{ 0%,100%{ transform:scale(1); opacity:1;} 50%{ transform:scale(1.5); opacity:.5; } }

.hero h1{
  font-size:clamp(2.4rem,5vw,3.85rem); line-height:1.08; letter-spacing:-.015em; margin-bottom:1.4rem;
}
.hero h1 .letter{ display:inline-block; opacity:0; transform:translateY(28px); animation:letterIn .6s var(--ease) forwards; }
@keyframes letterIn{ to{ opacity:1; transform:translateY(0); } }

.hero-text{ font-size:1.12rem; color:var(--clr-ink-soft); max-width:540px; margin-bottom:2.1rem; }

.hero-cta-row{ display:flex; flex-wrap:wrap; gap:1rem; margin-bottom:2.6rem; }

.hero-quickstats{ display:flex; gap:2rem; flex-wrap:wrap; }
.hero-quickstats .qs-item{ display:flex; flex-direction:column; }
.hero-quickstats .qs-num{ font-family:var(--font-display); font-weight:800; font-size:1.7rem; color:var(--clr-primary-dark); }
.hero-quickstats .qs-label{ font-size:.8rem; color:var(--clr-ink-soft); font-weight:600; }

/* Hero visual */
.hero-visual{ position:relative; z-index:1; min-height:460px; }
.hero-image-wrap{
  position:relative; width:min(420px,86%); margin:0 auto;
  border-radius:42% 58% 64% 36%/48% 42% 58% 52%;
  overflow:hidden; box-shadow:var(--shadow-lg);
  animation:float 6s ease-in-out infinite;
  border:6px solid #fff;
}
@keyframes float{ 0%,100%{ transform:translateY(0) rotate(0deg); } 50%{ transform:translateY(-20px) rotate(1deg); } }
.hero-image-wrap img{ width:100%; height:100%; object-fit:cover; aspect-ratio:4/5; }

.float-badge{
  position:absolute; display:flex; align-items:center; gap:.6rem;
  background:rgba(255,255,255,0.85); backdrop-filter:blur(10px);
  padding:.7rem 1rem; border-radius:var(--radius-md); box-shadow:var(--shadow-md);
  font-weight:700; font-size:.85rem; color:var(--clr-ink); border:1px solid rgba(255,255,255,.6);
}
.float-badge i{ font-size:1.1rem; }
.float-badge.fb1{ top:6%; left:-8%; animation:float 5s ease-in-out infinite; }
.float-badge.fb2{ bottom:14%; right:-10%; animation:float 5.6s ease-in-out infinite .4s; }
.float-badge.fb3{ top:46%; right:-14%; animation:float 4.8s ease-in-out infinite .8s; color:var(--clr-accent-dark); }
.float-badge .fb-sub{ display:block; font-size:.7rem; color:var(--clr-ink-soft); font-weight:600; }
.float-badge.fb1 i{ color:var(--clr-primary); }
.float-badge.fb3 i{ color:var(--clr-accent); }

@media (max-width:991px){
  .float-badge.fb1{ left:0; top:0; }
  .float-badge.fb2{ right:0; bottom:6%; }
  .float-badge.fb3{ right:0; top:42%; }
}

/* Trust strip */
.trust-strip{
  position:relative; z-index:3; margin-top:-3rem;
}
.trust-strip .glass-card{
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between;
  padding:1.6rem 2.2rem; gap:1.2rem;
}
.trust-item{ display:flex; align-items:center; gap:.8rem; }
.trust-item .ti-icon{
  width:46px; height:46px; border-radius:50%; background:var(--clr-mint); display:flex; align-items:center; justify-content:center;
  color:var(--clr-primary); font-size:1.1rem; flex-shrink:0;
}
.trust-item strong{ display:block; font-size:.95rem; }
.trust-item span{ font-size:.8rem; color:var(--clr-ink-soft); }

/* ---------- 8. STATS ---------- */
.stats-section{ background:var(--clr-ink); position:relative; overflow:hidden; color:#fff; }
.stats-section .vital-row{ position:absolute; inset:0; opacity:.15; }
.stat-card{ text-align:center; position:relative; z-index:1; padding:1rem; }
.stat-num{ font-family:var(--font-display); font-weight:800; font-size:clamp(2.2rem,4vw,3.2rem); color:#fff; }
.stat-num .plus{ color:var(--clr-accent); }
.stat-label{ font-size:.92rem; color:rgba(255,255,255,0.7); font-weight:600; margin-top:.4rem; letter-spacing:.03em; }
.stat-icon{ font-size:1.4rem; color:var(--clr-primary-light); margin-bottom:.6rem; }

/* ---------- 9. SERVICE CARDS ---------- */
.service-card{
  background:#fff; border-radius:var(--radius-md); padding:2.2rem 1.8rem; height:100%;
  box-shadow:var(--shadow-sm); border:1px solid var(--clr-line); position:relative; overflow:hidden;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease);
}
.service-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg,var(--clr-primary),var(--clr-accent));
  transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease);
}
.service-card:hover{ transform:translateY(-12px); box-shadow:var(--shadow-lg); }
.service-card:hover::before{ transform:scaleX(1); }
.service-icon{
  width:68px; height:68px; border-radius:22px; background:var(--clr-mint); display:flex; align-items:center; justify-content:center;
  font-size:1.7rem; color:var(--clr-primary); margin-bottom:1.4rem; transition:all .5s var(--ease);
}
.service-card:hover .service-icon{ background:var(--clr-primary); color:#fff; transform:rotate(-8deg) scale(1.08); }
.service-card h3{ font-size:1.25rem; margin-bottom:.6rem; }
.service-card p{ color:var(--clr-ink-soft); font-size:.94rem; margin-bottom:1.1rem; }
.service-link{ font-weight:700; color:var(--clr-primary-dark); font-size:.88rem; display:inline-flex; align-items:center; gap:.4rem; }
.service-link i{ transition:transform .35s var(--ease); font-size:.78rem; }
.service-card:hover .service-link i{ transform:translateX(5px); }

/* Detailed (services page) cards with image */
.service-detail-card{
  background:#fff; border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-sm);
  border:1px solid var(--clr-line); height:100%; transition:transform .5s var(--ease), box-shadow .5s var(--ease);
  display:flex; flex-direction:column;
}
.service-detail-card:hover{ transform:translateY(-10px); box-shadow:var(--shadow-lg); }
.sdc-img{ position:relative; height:210px; overflow:hidden; }
.sdc-img img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.service-detail-card:hover .sdc-img img{ transform:scale(1.12) rotate(1deg); }
.sdc-badge{
  position:absolute; bottom:-26px; left:24px; width:58px; height:58px; border-radius:18px;
  background:linear-gradient(135deg,var(--clr-primary),var(--clr-primary-dark)); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:1.4rem; box-shadow:var(--shadow-md);
  transition:transform .5s var(--ease);
}
.service-detail-card:hover .sdc-badge{ transform:rotate(-10deg) scale(1.08); }
.sdc-body{ padding:2.3rem 1.6rem 1.7rem; flex:1; display:flex; flex-direction:column; }
.sdc-body h3{ font-size:1.3rem; margin-bottom:.6rem; }
.sdc-body p{ color:var(--clr-ink-soft); font-size:.94rem; margin-bottom:1rem; }
.sdc-tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-bottom:1.3rem; }
.sdc-tags span{ background:var(--clr-mint); color:var(--clr-primary-dark); font-size:.75rem; font-weight:700; padding:.3rem .7rem; border-radius:50px; }
.sdc-body .service-link{ margin-top:auto; }

/* Process steps (services page) */
.step-card{ text-align:center; padding:1.5rem 1rem; position:relative; }
.step-num{
  width:64px; height:64px; border-radius:50%; margin:0 auto 1.1rem; display:flex; align-items:center; justify-content:center;
  background:#fff; border:2px dashed var(--clr-primary-light); color:var(--clr-primary-dark); font-family:var(--font-display);
  font-weight:800; font-size:1.4rem; transition:all .4s var(--ease);
}
.step-card:hover .step-num{ background:var(--clr-primary); color:#fff; border-style:solid; transform:scale(1.1); }
.step-card h4{ font-size:1.05rem; margin-bottom:.5rem; }
.step-card p{ color:var(--clr-ink-soft); font-size:.88rem; }

/* ---------- 10. DOCTORS ---------- */
.doctor-card{
  position:relative; border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-sm);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease); background:#fff;
}
.doctor-card:hover{ transform:translateY(-10px); box-shadow:var(--shadow-lg); }
.doctor-photo{ position:relative; height:300px; overflow:hidden; }
.doctor-photo img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.doctor-card:hover .doctor-photo img{ transform:scale(1.08); }
.doctor-social{
  position:absolute; bottom:-60px; left:0; right:0; display:flex; justify-content:center; gap:.6rem;
  padding:1rem; transition:bottom .45s var(--ease);
  background:linear-gradient(0deg,rgba(15,38,36,0.55),transparent);
}
.doctor-card:hover .doctor-social{ bottom:0; }
.doctor-social a{
  width:36px; height:36px; border-radius:50%; background:#fff; color:var(--clr-primary-dark);
  display:flex; align-items:center; justify-content:center; transition:all .3s var(--ease); font-size:.85rem;
}
.doctor-social a:hover{ background:var(--clr-accent); color:#fff; transform:translateY(-4px); }
.doctor-info{ padding:1.4rem 1.3rem; text-align:center; }
.doctor-info h4{ font-size:1.15rem; margin-bottom:.2rem; }
.doctor-info span{ color:var(--clr-accent-dark); font-weight:700; font-size:.85rem; }
.doctor-info .doc-tagline{ display:block; margin-top:.6rem; color:var(--clr-ink-soft); font-size:.85rem; }

/* ---------- 11. TESTIMONIALS ---------- */
.testimonial-card{
  background:#fff; border-radius:var(--radius-md); padding:2.4rem 2rem; box-shadow:var(--shadow-sm);
  border:1px solid var(--clr-line); position:relative; height:100%;
}
.testimonial-card .quote-mark{
  font-family:var(--font-display); font-size:4rem; color:var(--clr-mint-2); position:absolute; top:.6rem; right:1.3rem; line-height:1;
  z-index:0;
}
.testimonial-stars{ color:var(--clr-gold); margin-bottom:1rem; font-size:.9rem; }
.testimonial-text{ font-family:var(--font-display); font-style:italic; font-size:1.08rem; color:var(--clr-ink); position:relative; z-index:1; margin-bottom:1.4rem; }
.testimonial-person{ display:flex; align-items:center; gap:.8rem; }
.testimonial-person img{ width:50px; height:50px; border-radius:50%; object-fit:cover; border:2px solid var(--clr-mint-2); }
.testimonial-person strong{ display:block; font-size:.95rem; }
.testimonial-person span{ font-size:.8rem; color:var(--clr-ink-soft); }

#testimonialCarousel .carousel-control-prev, #testimonialCarousel .carousel-control-next{
  width:46px; height:46px; top:auto; bottom:-4.2rem; background:#fff; border-radius:50%; opacity:1;
  box-shadow:var(--shadow-sm); transition:all .3s var(--ease);
}
#testimonialCarousel .carousel-control-prev{ left:calc(50% - 60px); }
#testimonialCarousel .carousel-control-next{ left:calc(50% + 14px); right:auto; }
#testimonialCarousel .carousel-control-prev:hover, #testimonialCarousel .carousel-control-next:hover{ background:var(--clr-primary); }
#testimonialCarousel .carousel-control-prev-icon, #testimonialCarousel .carousel-control-next-icon{ filter:invert(0.3); width:1.1rem; height:1.1rem; }
#testimonialCarousel .carousel-control-prev:hover .carousel-control-prev-icon,
#testimonialCarousel .carousel-control-next:hover .carousel-control-next-icon{ filter:invert(1); }
.carousel-indicators{ position:relative; margin-top:3.6rem; }
.carousel-indicators [data-bs-target]{ background:var(--clr-mint-2); width:9px; height:9px; border-radius:50%; opacity:1; }
.carousel-indicators .active{ background:var(--clr-accent); width:26px; border-radius:50px; }

/* ---------- 12. CTA BAND ---------- */
.cta-band{
  position:relative; overflow:hidden; border-radius:var(--radius-lg); margin:0 auto;
  background:linear-gradient(120deg,var(--clr-primary-dark),var(--clr-primary) 60%,var(--clr-primary-light));
  padding:3.6rem 2.5rem; color:#fff; isolation:isolate;
}
.cta-band .cta-wave{ position:absolute; inset:0; opacity:.18; }
.cta-band .cta-wave svg{ width:100%; height:100%; }
.cta-band .cta-wave path{ fill:none; stroke:#fff; stroke-width:2; stroke-dasharray:8 12; animation:dashFlow 8s linear infinite; }
.cta-band h2{ color:#fff; font-size:clamp(1.7rem,3vw,2.4rem); margin-bottom:.8rem; }
.cta-band p{ color:rgba(255,255,255,0.85); margin-bottom:1.8rem; max-width:520px; }
.cta-phone-pill{
  display:inline-flex; align-items:center; gap:.7rem; background:rgba(255,255,255,0.14); border:1px solid rgba(255,255,255,0.3);
  padding:.7rem 1.3rem; border-radius:50px; color:#fff; font-weight:700;
}
.cta-phone-pill i{ background:#fff; color:var(--clr-primary-dark); width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; }

/* ---------- 13. FOOTER ---------- */
.site-footer{ background:var(--clr-ink); color:rgba(255,255,255,0.75); position:relative; }
.footer-wave{ line-height:0; transform:translateY(1px); background:var(--clr-bg); }
.footer-wave svg{ width:100%; height:60px; display:block; }
.footer-top{ padding:5rem 0 2.5rem; }
.footer-brand{ display:flex; align-items:center; gap:.6rem; font-family:var(--font-display); font-weight:800; font-size:1.5rem; color:#fff; margin-bottom:1.1rem; }
.footer-about p{ font-size:.92rem; line-height:1.7; }
.footer-social{ display:flex; gap:.7rem; margin-top:1.4rem; }
.footer-social a{
  width:38px; height:38px; border-radius:50%; background:rgba(255,255,255,0.08); display:flex; align-items:center; justify-content:center;
  transition:all .35s var(--ease); color:#fff;
}
.footer-social a:hover{ background:var(--clr-accent); transform:translateY(-4px) rotate(8deg); }
.footer-heading{ color:#fff; font-size:1.05rem; margin-bottom:1.4rem; position:relative; }
.footer-links li{ margin-bottom:.7rem; }
.footer-links a{ font-size:.92rem; transition:all .3s; display:inline-flex; align-items:center; gap:.5rem; }
.footer-links a i{ font-size:.65rem; color:var(--clr-accent); transition:transform .3s; }
.footer-links a:hover{ color:#fff; padding-left:4px; }
.footer-links a:hover i{ transform:translateX(3px); }
.footer-contact li{ display:flex; gap:.7rem; margin-bottom:1rem; font-size:.92rem; align-items:flex-start; }
.footer-contact i{ color:var(--clr-accent); margin-top:.2rem; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,0.1); padding:1.4rem 0; font-size:.85rem; }
.footer-bottom a{ color:var(--clr-accent); font-weight:600; }

/* ---------- 14. FLOATING UI ---------- */
.fab-whatsapp{
  position:fixed; left:22px; bottom:26px; z-index:1040; width:58px; height:58px; border-radius:50%;
  background:#25D366; color:#fff; display:flex; align-items:center; justify-content:center; font-size:1.6rem;
  box-shadow:0 10px 26px rgba(37,211,102,0.45); transition:transform .35s var(--ease);
}
.fab-whatsapp:hover{ transform:scale(1.1) rotate(8deg); color:#fff; }
.fab-whatsapp .ring{
  position:absolute; inset:0; border-radius:50%; border:2px solid #25D366; animation:ringPulse 2s ease-out infinite;
}
@keyframes ringPulse{
  0%{ transform:scale(1); opacity:.7; }
  100%{ transform:scale(1.9); opacity:0; }
}

.fab-book{
  position:fixed; right:0; bottom:120px; z-index:1040;
  background:linear-gradient(135deg,var(--clr-accent),var(--clr-accent-dark)); color:#fff;
  padding:.85rem 1.3rem .85rem 1.1rem; border-radius:50px 0 0 50px; font-weight:700; font-size:.88rem;
  display:flex; align-items:center; gap:.55rem; box-shadow:0 10px 26px rgba(255,122,85,0.4); border:none;
  transition:all .4s var(--ease);
}
.fab-book:hover{ padding-right:1.8rem; box-shadow:0 14px 32px rgba(255,122,85,0.55); }
.fab-book i{ font-size:1.05rem; animation:wiggle 2.6s ease-in-out infinite; }
@keyframes wiggle{ 0%,100%{ transform:rotate(0); } 10%{ transform:rotate(-12deg); } 20%{ transform:rotate(10deg); } 30%{ transform:rotate(0); } }

.fab-top{
  position:fixed; right:22px; bottom:26px; z-index:1039; width:46px; height:46px; border-radius:50%;
  background:#fff; color:var(--clr-primary-dark); border:1px solid var(--clr-line); display:flex; align-items:center; justify-content:center;
  box-shadow:var(--shadow-sm); opacity:0; visibility:hidden; transform:translateY(12px); transition:all .4s var(--ease);
}
.fab-top.show{ opacity:1; visibility:visible; transform:translateY(0); }
.fab-top:hover{ background:var(--clr-primary); color:#fff; }

@media (max-width:575px){
  .fab-whatsapp{ width:50px; height:50px; font-size:1.35rem; left:16px; bottom:16px; }
  .fab-book span{ display:none; }
  .fab-book{ padding:.85rem; border-radius:50%; right:16px; bottom:84px; }
  .fab-top{ right:16px; bottom:16px; width:42px; height:42px; }
}

/* ---------- 15. APPOINTMENT MODAL ---------- */
.modal-clinic .modal-content{
  border:none; border-radius:28px; overflow:hidden; box-shadow:var(--shadow-lg);
  animation:modalPop .5s var(--ease);
}
@keyframes modalPop{ from{ transform:scale(.88); opacity:0; } to{ transform:scale(1); opacity:1; } }
.modal-clinic-header{
  background:linear-gradient(120deg,var(--clr-primary-dark),var(--clr-primary)); color:#fff; padding:2rem 2.2rem 4.4rem; position:relative; overflow:hidden;
}
.modal-clinic-header .mh-wave{ position:absolute; inset:0; opacity:.2; }
.modal-clinic-header .mh-wave svg{ width:100%; height:100%; }
.modal-clinic-header .mh-wave path{ fill:none; stroke:#fff; stroke-width:2; stroke-dasharray:6 10; animation:dashFlow 6s linear infinite; }
.modal-clinic-header h3{ color:#fff; font-size:1.5rem; position:relative; z-index:1; }
.modal-clinic-header p{ color:rgba(255,255,255,.85); font-size:.9rem; margin-top:.4rem; position:relative; z-index:1; }
.modal-clinic .btn-close{ filter:invert(1); opacity:.9; position:relative; z-index:2; }
.modal-clinic-body{ padding:0 2.2rem 2.2rem; margin-top:-2.6rem; position:relative; z-index:2; }

.float-field{ position:relative; margin-bottom:1.3rem; }
.float-field input, .float-field select, .float-field textarea{
  width:100%; border:1.5px solid var(--clr-line); border-radius:14px; padding:1rem .9rem .5rem; font-size:.95rem;
  background:#fff; transition:border-color .3s, box-shadow .3s; font-family:var(--font-body);
}
.float-field textarea{ min-height:90px; resize:vertical; }
.float-field label{
  position:absolute; left:.95rem; top:1rem; font-size:.92rem; color:var(--clr-ink-soft);
  transition:all .25s var(--ease); pointer-events:none; background:#fff; padding:0 .2rem;
}
.float-field input:focus, .float-field select:focus, .float-field textarea:focus{
  border-color:var(--clr-primary); box-shadow:0 0 0 4px rgba(14,124,102,0.12); outline:none;
}
.float-field input:focus ~ label, .float-field input:not(:placeholder-shown) ~ label,
.float-field select:focus ~ label, .float-field select.has-value ~ label,
.float-field textarea:focus ~ label, .float-field textarea:not(:placeholder-shown) ~ label{
  top:-.55rem; left:.7rem; font-size:.74rem; color:var(--clr-primary-dark); font-weight:700;
}
.modal-success{ text-align:center; padding:2rem 1rem; }
.modal-success i{ font-size:3.4rem; color:var(--clr-primary); margin-bottom:1rem; animation:zoomPop .5s var(--ease); }
@keyframes zoomPop{ from{ transform:scale(0); } 70%{ transform:scale(1.15); } to{ transform:scale(1); } }

/* ---------- 16. PAGE BANNER (about/services/contact) ---------- */
.page-banner{
  position:relative; padding:9.5rem 0 4.5rem; overflow:hidden;
  background:linear-gradient(180deg,#F4FAF8 0%, var(--clr-bg) 100%);
}
.page-banner .hero-blob{ opacity:.5; }
.page-banner h1{ font-size:clamp(2.1rem,4vw,3.1rem); margin-bottom:.8rem; position:relative; z-index:1; }
.breadcrumb-clinic{ display:flex; gap:.5rem; align-items:center; font-weight:600; color:var(--clr-ink-soft); position:relative; z-index:1; font-size:.92rem; }
.breadcrumb-clinic a{ color:var(--clr-primary-dark); }
.breadcrumb-clinic i{ font-size:.7rem; }

/* ---------- 17. ABOUT PAGE ---------- */
.story-img-wrap{ position:relative; }
.story-img-wrap img{ border-radius:var(--radius-lg); box-shadow:var(--shadow-md); }
.story-img-wrap .story-badge{
  position:absolute; bottom:-1.6rem; right:-1.4rem; background:#fff; padding:1.2rem 1.5rem; border-radius:var(--radius-md);
  box-shadow:var(--shadow-md); text-align:center; animation:float 6s ease-in-out infinite;
}
.story-badge .num{ font-family:var(--font-display); font-weight:800; font-size:1.9rem; color:var(--clr-accent-dark); }
.story-badge .lbl{ font-size:.75rem; color:var(--clr-ink-soft); font-weight:700; text-transform:uppercase; letter-spacing:.05em; }
@media (max-width:767px){ .story-img-wrap{ margin-bottom:2.4rem; } .story-img-wrap .story-badge{ right:.6rem; } }

.mv-card{
  background:#fff; border-radius:var(--radius-md); padding:2.4rem; height:100%; box-shadow:var(--shadow-sm); border:1px solid var(--clr-line);
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.mv-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); }
.mv-icon{ width:60px; height:60px; border-radius:18px; display:flex; align-items:center; justify-content:center; font-size:1.5rem; margin-bottom:1.3rem; color:#fff; }
.mv-card.mission .mv-icon{ background:linear-gradient(135deg,var(--clr-primary),var(--clr-primary-light)); }
.mv-card.vision .mv-icon{ background:linear-gradient(135deg,var(--clr-accent),var(--clr-accent-dark)); }
.mv-card p{ color:var(--clr-ink-soft); font-size:.96rem; }

/* Timeline */
.timeline{ position:relative; max-width:900px; margin:0 auto; }
.timeline::before{
  content:""; position:absolute; left:50%; top:0; bottom:0; width:2px; background:var(--clr-mint-2); transform:translateX(-50%);
}
.timeline-item{ position:relative; width:50%; padding:0 3rem 3.2rem; }
.timeline-item:nth-child(odd){ left:0; text-align:right; }
.timeline-item:nth-child(even){ left:50%; text-align:left; }
.timeline-dot{
  position:absolute; top:0; width:18px; height:18px; border-radius:50%; background:var(--clr-accent); border:4px solid var(--clr-bg);
  box-shadow:0 0 0 2px var(--clr-accent);
}
.timeline-item:nth-child(odd) .timeline-dot{ right:-9px; }
.timeline-item:nth-child(even) .timeline-dot{ left:-9px; }
.timeline-year{ font-family:var(--font-display); font-weight:800; color:var(--clr-primary-dark); font-size:1.3rem; }
.timeline-card{ background:#fff; border-radius:var(--radius-sm); padding:1.3rem 1.5rem; box-shadow:var(--shadow-sm); margin-top:.6rem; border:1px solid var(--clr-line); }
.timeline-card p{ font-size:.9rem; color:var(--clr-ink-soft); margin:0; }
@media (max-width:767px){
  .timeline::before{ left:18px; }
  .timeline-item, .timeline-item:nth-child(even){ width:100%; left:0; text-align:left; padding:0 0 2.4rem 3rem; }
  .timeline-item:nth-child(odd) .timeline-dot, .timeline-item:nth-child(even) .timeline-dot{ left:9px; right:auto; }
}

/* Values */
.value-card{ text-align:center; padding:2.2rem 1.2rem; border-radius:var(--radius-md); background:#fff; box-shadow:var(--shadow-sm); border:1px solid var(--clr-line); height:100%; transition:all .4s var(--ease); }
.value-card:hover{ transform:translateY(-8px) scale(1.02); box-shadow:var(--shadow-md); background:var(--clr-mint); }
.value-card .vi{ width:60px; height:60px; border-radius:50%; background:var(--clr-mint); color:var(--clr-primary); display:flex; align-items:center; justify-content:center; font-size:1.5rem; margin:0 auto 1.1rem; transition:all .4s var(--ease); }
.value-card:hover .vi{ background:var(--clr-primary); color:#fff; transform:rotate(360deg); }
.value-card h4{ font-size:1.05rem; margin-bottom:.5rem; }
.value-card p{ font-size:.86rem; color:var(--clr-ink-soft); margin:0; }

/* Doctor profile (about) */
.profile-card{ background:#fff; border-radius:var(--radius-lg); box-shadow:var(--shadow-md); padding:2.6rem; }
.profile-credentials li{ display:flex; gap:.7rem; margin-bottom:.8rem; font-size:.92rem; align-items:flex-start; }
.profile-credentials i{ color:var(--clr-primary); margin-top:.2rem; }
.signature-text{ font-family:var(--font-display); font-style:italic; font-size:1.6rem; color:var(--clr-primary-dark); margin-top:1rem; }

/* ---------- 18. CONTACT PAGE ---------- */
.contact-info-card{
  background:#fff; border-radius:var(--radius-md); padding:2rem 1.6rem; text-align:center; box-shadow:var(--shadow-sm);
  border:1px solid var(--clr-line); height:100%; transition:all .4s var(--ease);
}
.contact-info-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); }
.cic-icon{ width:60px; height:60px; border-radius:50%; background:var(--clr-mint); color:var(--clr-primary); display:flex; align-items:center; justify-content:center; font-size:1.4rem; margin:0 auto 1.1rem; transition:all .4s var(--ease); }
.contact-info-card:hover .cic-icon{ background:var(--clr-accent); color:#fff; transform:scale(1.1); }
.contact-info-card h4{ font-size:1rem; margin-bottom:.5rem; }
.contact-info-card p{ font-size:.88rem; color:var(--clr-ink-soft); margin:0; }

.contact-form-wrap{ background:#fff; border-radius:var(--radius-lg); padding:2.6rem; box-shadow:var(--shadow-md); border:1px solid var(--clr-line); }
.map-wrap{ border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md); height:100%; min-height:420px; position:relative; }
.map-wrap iframe{ width:100%; height:100%; min-height:420px; border:0; filter:saturate(1.05); }
.map-pin-badge{
  position:absolute; top:1.4rem; left:1.4rem; background:#fff; padding:.8rem 1.2rem; border-radius:50px; box-shadow:var(--shadow-sm);
  font-weight:700; font-size:.85rem; display:flex; align-items:center; gap:.5rem; color:var(--clr-primary-dark); z-index:2;
}
.map-pin-badge i{ color:var(--clr-accent); }

.accordion-clinic .accordion-item{ border:none; margin-bottom:1rem; border-radius:var(--radius-sm) !important; overflow:hidden; box-shadow:var(--shadow-sm); }
.accordion-clinic .accordion-button{
  font-weight:700; font-family:var(--font-body); color:var(--clr-ink); padding:1.1rem 1.4rem; background:#fff;
}
.accordion-clinic .accordion-button:not(.collapsed){ background:var(--clr-mint); color:var(--clr-primary-dark); box-shadow:none; }
.accordion-clinic .accordion-button:focus{ box-shadow:none; }
.accordion-clinic .accordion-button::after{ filter:hue-rotate(120deg); }
.accordion-clinic .accordion-body{ font-size:.92rem; color:var(--clr-ink-soft); }

/* ---------- 19. MISC ANIMATIONS ---------- */
@keyframes spinSlow{ to{ transform:rotate(360deg); } }
.spin-slow{ animation:spinSlow 16s linear infinite; }

@keyframes shimmer{ 0%{ background-position:-200% 0; } 100%{ background-position:200% 0; } }

/* counter ticking emphasis */
.counted{ animation:popOnce .4s var(--ease); }
@keyframes popOnce{ 50%{ transform:scale(1.12); } }

/* Image error fallback */
img.img-fallback{
  background:linear-gradient(135deg,var(--clr-mint),var(--clr-mint-2));
  display:flex; align-items:center; justify-content:center; min-height:160px;
}

/* generic responsive container tweak */
@media (min-width:1400px){ .container{ max-width:1260px; } }
