/* ============================================
   DR. SRUTHI BALAJI – INNER PAGES CSS
   pages.css – All inner page styles
   ============================================ */

/* ── PAGE HERO BANNER (about / doctors / services) ── */
.page-hero {
  position: relative;
  padding: 140px 0 80px;
  background: linear-gradient(135deg, #051e4a 0%, var(--blue) 60%, #1a85e5 100%);
  overflow: hidden;
  text-align: center;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none'%3E%3Ccircle cx='40' cy='40' r='30' stroke='%23ffffff' stroke-opacity='0.04' stroke-width='1'/%3E%3C/g%3E%3C/svg%3E");
}
.page-hero-shapes span {
  position: absolute;
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
}
.page-hero-shapes span:nth-child(1) { width:400px;height:400px;top:-150px;right:-100px; }
.page-hero-shapes span:nth-child(2) { width:250px;height:250px;bottom:-80px;left:-60px; }
.page-hero-shapes span:nth-child(3) { width:120px;height:120px;top:40%;right:15%; }
.page-hero-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.12);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.25);
  color: #fff;
  font-size: .78rem;
  font-weight: 600;
  padding: 6px 18px;
  border-radius: 50px;
  margin-bottom: 18px;
  letter-spacing: .05em;
}
.page-hero-pill i { color: #7dd3fc; }
.page-hero h1 {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2rem, 5vw, 3.4rem);
  font-weight: 800;
  color: #fff;
  margin-bottom: 16px;
  line-height: 1.15;
}
.page-hero h1 span { color: #7dd3fc; }
.page-hero p {
  font-size: 1.05rem;
  color: rgba(255,255,255,0.82);
  max-width: 580px;
  margin: 0 auto 24px;
  line-height: 1.75;
}
.breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .82rem;
  color: rgba(255,255,255,0.65);
  position: relative;
  z-index: 1;
}
.breadcrumb a { color: rgba(255,255,255,0.75); transition: var(--tr); }
.breadcrumb a:hover { color: #fff; }
.breadcrumb i { font-size: .6rem; color: rgba(255,255,255,0.45); }
.page-hero-wave { position: absolute; bottom: -1px; left: 0; right: 0; pointer-events: none; }
.page-hero-wave svg { width: 100%; display: block; }

/* ── ACTIVE NAV ── */
.nav-link.current { color: var(--blue) !important; background: var(--sky) !important; }

/* ── CTA STRIP ── */
.cta-strip {
  background: linear-gradient(135deg, var(--blue-dark), var(--blue));
  padding: 70px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-strip::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='20' fill='none' stroke='%23fff' stroke-opacity='.04'/%3E%3C/svg%3E");
}
.cta-strip h2 { font-family:'Playfair Display',serif; font-size:clamp(1.8rem,3.5vw,2.4rem); color:#fff; margin-bottom:12px; position:relative; }
.cta-strip h2 span { color: #a8d8ff; }
.cta-strip p { color:rgba(255,255,255,.78); margin-bottom:28px; font-size:1rem; position:relative; }
.cta-strip .cta-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; position:relative; }

/* ── SCROLL ANIMATIONS ── */
[data-aos] {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
[data-aos="fade-right"] { transform: translateX(-28px); }
[data-aos="fade-left"]  { transform: translateX(28px); }
[data-aos="zoom-in"]    { transform: scale(0.9); }
[data-aos].aos-animate  { opacity: 1; transform: translate(0) scale(1); }

/* ══════════════════════════════════════
   ABOUT PAGE
══════════════════════════════════════ */
.about-page-mission {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items: center;
}

/* ── Image column ── */
.about-mission-img {
  position: relative;
  border-radius: 24px;
  overflow: visible;
}

/* main image frame */
.about-mission-img-frame {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(11,107,206,.18);
  border: 3px solid #fff;
}
.about-mission-img-frame img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  object-position: center center;
  display: block;
  transition: transform .6s ease;
}
.about-mission-img:hover .about-mission-img-frame img {
  transform: scale(1.04);
}

/* corner accent */
.about-mission-img-frame::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(11,107,206,.45) 100%);
  z-index: 1;
  pointer-events: none;
}

/* decorative border frame behind image */
.about-mission-img::before {
  content: '';
  position: absolute;
  top: 18px;
  left: 18px;
  right: -18px;
  bottom: -18px;
  border-radius: 24px;
  background: linear-gradient(135deg, var(--sky-mid), var(--border));
  z-index: -1;
}

/* floating dots decoration */
.about-mission-img::after {
  content: '';
  position: absolute;
  top: -24px; right: -24px;
  width: 100px; height: 100px;
  background: radial-gradient(circle, var(--blue) 1.5px, transparent 1.5px);
  background-size: 14px 14px;
  opacity: .25;
  z-index: 0;
}

/* badge */
.about-mission-img-badge {
  position: absolute;
  bottom: -20px; left: 28px;
  background: #fff;
  border-radius: 16px;
  padding: 14px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: 0 12px 40px rgba(11,107,206,.2);
  border: 1.5px solid var(--border);
  z-index: 3;
  animation: badgePop .6s cubic-bezier(.34,1.56,.64,1) .5s both;
}
@keyframes badgePop {
  from { opacity:0; transform:scale(.7) translateY(10px); }
  to   { opacity:1; transform:scale(1) translateY(0); }
}
.about-mission-img-badge i {
  font-size: 1.8rem;
  color: #f59e0b;
  animation: iconSpin 2s ease .8s both;
}
@keyframes iconSpin {
  from { transform:rotate(-20deg) scale(.8); }
  to   { transform:rotate(0deg) scale(1); }
}
.about-mission-img-badge strong { display:block; font-size:1rem; font-weight:800; color:var(--text); }
.about-mission-img-badge span  { font-size:.73rem; color:var(--text-light); }

/* ── Text column ── */
.about-mission-text { padding-top: 10px; }
.about-mission-text h2 { margin-bottom: 20px; }
.about-mission-text p  { color:var(--text-mid); line-height:1.85; margin-bottom:16px; font-size:.95rem; }

/* mission values grid — improved */
.mission-values { display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:28px; }
.mission-val {
  display: flex;
  align-items: flex-start;
  gap: 13px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
  box-shadow: var(--shadow-sm);
  position: relative;
  overflow: hidden;
}
.mission-val::before {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
  background: var(--blue);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s ease;
}
.mission-val:hover::before { transform: scaleX(1); }
.mission-val:hover {
  border-color: var(--blue);
  transform: translateY(-5px);
  box-shadow: var(--shadow-md);
}
.mission-val i {
  width: 40px; height: 40px;
  background: var(--sky);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  font-size: 1rem;
  flex-shrink: 0;
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
}
.mission-val:hover i {
  background: var(--blue);
  color: #fff;
  transform: rotate(-8deg) scale(1.1);
}
.mission-val div strong { display:block; font-size:.86rem; font-weight:700; color:var(--text); margin-bottom:3px; }
.mission-val div span   { font-size:.76rem; color:var(--text-mid); line-height:1.45; }

/* Timeline */
.timeline { display:flex; flex-direction:column; gap:0; position:relative; max-width:700px; margin:0 auto; }
.timeline::before {
  content:''; position:absolute; left:28px; top:0; bottom:0;
  width:2px; background:linear-gradient(180deg,var(--blue),var(--sky-mid));
}
.timeline-item { display:flex; gap:28px; padding:0 0 36px 0; position:relative; }
.tl-dot {
  width:56px; height:56px; background:var(--blue); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:1.1rem; flex-shrink:0;
  box-shadow:0 4px 16px rgba(11,107,206,.35); position:relative; z-index:1;
}
.tl-body { padding-top:10px; }
.tl-year { font-size:.75rem; font-weight:700; color:var(--blue); letter-spacing:.08em; text-transform:uppercase; margin-bottom:4px; }
.tl-body h4 { font-size:1rem; font-weight:700; color:var(--text); margin-bottom:4px; }
.tl-body p  { font-size:.85rem; color:var(--text-mid); line-height:1.65; }

/* Accreditations */
.accred-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.accred-card {
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px 20px; text-align:center;
  box-shadow:var(--shadow-sm); transition:var(--tr);
}
.accred-card:hover { border-color:var(--blue); transform:translateY(-4px); box-shadow:var(--shadow-md); }
.accred-icon { font-size:2.2rem; color:var(--blue); margin-bottom:12px; }
.accred-card h4 { font-size:.9rem; font-weight:700; color:var(--text); margin-bottom:6px; }
.accred-card p  { font-size:.78rem; color:var(--text-light); line-height:1.5; }

/* Credentials strip */
.credentials-strip {
  display:grid; grid-template-columns:repeat(4,1fr); gap:0;
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); margin-top:60px;
}
.cred-item {
  padding:28px 20px; text-align:center;
  border-right:1px solid var(--border); transition:var(--tr);
}
.cred-item:last-child { border-right:none; }
.cred-item:hover { background:var(--sky); }
.cred-item i      { font-size:1.6rem; color:var(--blue); margin-bottom:10px; display:block; }
.cred-item strong { display:block; font-size:1.3rem; font-weight:800; color:var(--text); }
.cred-item span   { font-size:.75rem; color:var(--text-light); }

/* ══════════════════════════════════════
   DOCTORS PAGE
══════════════════════════════════════ */
.doctors-page-grid { display:grid; grid-template-columns:1fr 1fr; gap:40px; max-width:940px; margin:0 auto; }
.doctor-page-card { background:var(--white); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md); border:1px solid var(--border); transition:var(--tr); }
.doctor-page-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.doctor-page-img { position:relative; height:340px; overflow:hidden; }
.doctor-page-img img { width:100%; height:100%; object-fit:cover; object-position:top; transition:transform .5s ease; }
.doctor-page-card:hover .doctor-page-img img { transform:scale(1.04); }
.doctor-page-img-overlay {
  position:absolute; bottom:0; left:0; right:0;
  background:linear-gradient(0deg,rgba(5,30,70,.85) 0%,transparent 100%);
  padding:24px 20px 16px;
}
.doctor-page-img-overlay .spec-pill {
  display:inline-flex; align-items:center; gap:6px;
  background:var(--blue); color:#fff; font-size:.72rem; font-weight:700;
  padding:4px 14px; border-radius:50px; letter-spacing:.05em; text-transform:uppercase;
}
.doctor-page-body { padding:26px; }
.doctor-page-body h3 { font-size:1.2rem; font-weight:700; color:var(--text); margin-bottom:4px; }
.doctor-page-body .deg { font-size:.82rem; color:var(--text-light); margin-bottom:14px; }
.doctor-page-qual {
  display:flex; align-items:flex-start; gap:8px;
  background:var(--sky); border-radius:var(--radius-sm); padding:10px 14px;
  font-size:.82rem; color:var(--blue); font-weight:500; margin-bottom:14px;
}
.doctor-page-qual i { flex-shrink:0; margin-top:2px; }
.doctor-expertise h5 { font-size:.78rem; font-weight:700; color:var(--text-light); letter-spacing:.06em; text-transform:uppercase; margin-bottom:10px; }
.expertise-tags { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:18px; }
.expertise-tags span { background:var(--sky-mid); color:var(--blue-dark); font-size:.72rem; font-weight:600; padding:4px 12px; border-radius:50px; }
.doctor-page-social { display:flex; gap:10px; }
.doctor-page-social a {
  width:36px; height:36px; background:var(--sky); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--blue); font-size:.85rem; border:1px solid var(--border); transition:var(--tr);
}
.doctor-page-social a:hover { background:var(--blue); color:#fff; border-color:var(--blue); }

/* ══════════════════════════════════════
   SERVICES PAGE
══════════════════════════════════════ */
.services-page-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.svc-page-card {
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--radius-lg); overflow:hidden; transition:var(--tr);
  display:flex; flex-direction:column; box-shadow:var(--shadow-sm);
}
.svc-page-card:hover { transform:translateY(-7px); box-shadow:var(--shadow-lg); border-color:var(--blue); }
.svc-page-img { position:relative; height:200px; overflow:hidden; }
.svc-page-img img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.svc-page-card:hover .svc-page-img img { transform:scale(1.06); }
.svc-page-icon {
  position:absolute; top:14px; left:14px;
  width:42px; height:42px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.1rem; backdrop-filter:blur(6px);
}
.svc-page-icon.p { background:rgba(46,125,50,.88); color:#fff; }
.svc-page-icon.f { background:rgba(11,107,206,.88); color:#fff; }
.svc-page-icon.o { background:rgba(5,30,70,.9); color:#7dd3fc; }
.svc-page-icon.a { background:rgba(194,24,91,.88); color:#fff; }
.svc-page-icon.c { background:rgba(230,126,34,.9); color:#fff; }
.svc-page-icon.i { background:rgba(142,68,173,.88); color:#fff; }
.svc-page-body { padding:22px; flex:1; display:flex; flex-direction:column; }
.svc-page-body h3 { font-size:1rem; font-weight:700; color:var(--text); margin-bottom:8px; }
.svc-page-body p  { font-size:.82rem; color:var(--text-mid); line-height:1.65; margin-bottom:14px; }
.svc-page-list { flex:1; display:flex; flex-direction:column; gap:6px; margin-bottom:18px; }
.svc-page-list li { display:flex; align-items:center; gap:8px; font-size:.8rem; color:var(--text-mid); }
.svc-page-list i  { color:var(--blue); font-size:.7rem; flex-shrink:0; }
.svc-page-btn {
  display:inline-flex; align-items:center; gap:6px;
  border:1.5px solid var(--blue); color:var(--blue);
  padding:9px 18px; border-radius:50px; font-size:.8rem; font-weight:600;
  transition:var(--tr); align-self:flex-start; margin-top:auto; text-decoration:none;
}
.svc-page-btn:hover { background:var(--blue); color:#fff; }

/* Process steps */
.process-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:0; position:relative; }
.process-steps::before {
  content:''; position:absolute; top:28px; left:12.5%; right:12.5%;
  height:2px; background:linear-gradient(90deg,var(--blue),var(--sky-mid));
}
.process-step { text-align:center; padding:0 16px; position:relative; }
.step-num {
  width:56px; height:56px; background:var(--blue); color:#fff; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; font-weight:800; margin:0 auto 18px; position:relative; z-index:1;
  box-shadow:0 4px 16px rgba(11,107,206,.35);
}
.process-step h4 { font-size:.92rem; font-weight:700; color:var(--text); margin-bottom:6px; }
.process-step p  { font-size:.8rem; color:var(--text-mid); line-height:1.6; }

/* ══════════════════════════════════════
   GALLERY PAGE
══════════════════════════════════════ */

/* Hero */
.gh-hero { position:relative; padding:140px 0 0; background:linear-gradient(135deg,#020c1f 0%,#05234e 50%,#0B6BCE 100%); overflow:hidden; }
.gh-orb { position:absolute; border-radius:50%; filter:blur(90px); pointer-events:none; animation:ghOrbFloat 9s ease-in-out infinite; }
.gh-orb-1 { width:500px;height:500px;top:-180px;right:-100px;background:rgba(11,107,206,.35);animation-delay:0s; }
.gh-orb-2 { width:350px;height:350px;bottom:-100px;left:-80px;background:rgba(37,211,102,.1);animation-delay:3s; }
.gh-orb-3 { width:200px;height:200px;top:35%;left:30%;background:rgba(125,211,252,.1);animation-delay:5.5s; }
@keyframes ghOrbFloat { 0%,100%{transform:translate(0,0) scale(1);} 50%{transform:translate(18px,-18px) scale(1.07);} }
.gh-sparkles { position:absolute;inset:0;pointer-events:none; }
.gh-sparkle { position:absolute;width:3px;height:3px;border-radius:50%;background:#7dd3fc;animation:sparkleTwinkle ease-in-out infinite; }
@keyframes sparkleTwinkle { 0%,100%{opacity:.1;transform:scale(.8);} 50%{opacity:.9;transform:scale(1.6);} }
.gh-hero-inner { position:relative;z-index:2;text-align:center;padding-bottom:52px; }
.gh-eyebrow {
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.1);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.2);color:#7dd3fc;
  font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  padding:5px 18px;border-radius:50px;margin-bottom:18px;
  animation:fadeDown .6s ease both;
}
@keyframes fadeDown{from{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}
.gh-title { font-family:'Playfair Display',serif;font-size:clamp(2.2rem,5vw,3.6rem);font-weight:800;color:#fff;line-height:1.12;margin-bottom:14px;animation:fadeUp .7s ease .1s both; }
.gh-title span{color:#7dd3fc;}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.gh-sub { font-size:.98rem;color:rgba(255,255,255,.72);max-width:500px;margin:0 auto 22px;line-height:1.75;animation:fadeUp .7s ease .2s both; }
.gh-breadcrumb { display:inline-flex;align-items:center;gap:8px;font-size:.8rem;color:rgba(255,255,255,.5);animation:fadeUp .7s ease .3s both; }
.gh-breadcrumb a { color:rgba(255,255,255,.72);text-decoration:none;transition:color .25s; }
.gh-breadcrumb a:hover{color:#fff;}
.gh-breadcrumb i{font-size:.56rem;color:rgba(255,255,255,.3);}
.gh-breadcrumb .cur{color:#7dd3fc;font-weight:600;}
.gh-wave{position:relative;z-index:2;line-height:0;}
.gh-wave svg{width:100%;display:block;}

/* Filter tabs */
.gf-section{background:#fff;padding:56px 0 0;}
.gf-tabs-wrap{display:flex;justify-content:center;margin-bottom:44px;}
.gf-tabs { display:flex;gap:8px;flex-wrap:wrap;justify-content:center;background:var(--sky);border:1.5px solid var(--border);border-radius:60px;padding:6px; }
.gf-tab { padding:9px 22px;border-radius:50px;font-size:.82rem;font-weight:600;border:none;cursor:pointer;background:transparent;color:var(--text-mid);transition:all .3s cubic-bezier(.34,1.56,.64,1);font-family:'Poppins',sans-serif;position:relative; }
.gf-tab.active { background:var(--blue);color:#fff;box-shadow:0 4px 16px rgba(11,107,206,.35);transform:scale(1.05); }
.gf-tab:hover:not(.active){background:#fff;color:var(--blue);transform:scale(1.02);}
.gf-tab-count { display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:rgba(0,0,0,.12);color:inherit;font-size:.65rem;font-weight:800;margin-left:5px; }
.gf-tab.active .gf-tab-count{background:rgba(255,255,255,.25);}

/* Gallery grid */
.gg-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:70px; }
.gg-item { position:relative;border-radius:18px;overflow:hidden;cursor:pointer;aspect-ratio:4/3;background:var(--sky);box-shadow:var(--shadow-sm);transition:all .4s cubic-bezier(.34,1.56,.64,1); }
.gg-item:hover { transform:translateY(-8px) scale(1.02);box-shadow:0 20px 50px rgba(11,107,206,.2);z-index:2; }
.gg-item img { width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s ease; }
.gg-item:hover img{transform:scale(1.1);}
.gg-item::before { content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.15) 50%,transparent 100%);transform:translateX(-100%);pointer-events:none;z-index:2; }
.gg-item:hover::before { animation:shimmerSlide .7s ease; }
@keyframes shimmerSlide{0%{transform:translateX(-100%);}100%{transform:translateX(100%);}}
.gg-overlay { position:absolute;inset:0;background:linear-gradient(180deg,transparent 25%,rgba(5,30,70,.88) 100%);display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:22px 18px;opacity:0;transition:opacity .35s ease; }
.gg-item:hover .gg-overlay{opacity:1;}
.gg-overlay-icon { width:46px;height:46px;background:rgba(255,255,255,.2);backdrop-filter:blur(8px);border:1.5px solid rgba(255,255,255,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;margin-bottom:10px;transform:scale(0) rotate(-90deg);transition:transform .35s cubic-bezier(.34,1.56,.64,1) .05s; }
.gg-item:hover .gg-overlay-icon{transform:scale(1) rotate(0deg);}
.gg-overlay-label { color:#fff;font-size:.84rem;font-weight:600;transform:translateY(12px);opacity:0;transition:transform .3s ease .08s,opacity .3s ease .08s; }
.gg-item:hover .gg-overlay-label{transform:translateY(0);opacity:1;}
.gg-overlay-cat { font-size:.68rem;font-weight:500;color:rgba(255,255,255,.65);text-transform:uppercase;letter-spacing:.07em;transform:translateY(8px);opacity:0;transition:transform .3s ease .12s,opacity .3s ease .12s;margin-top:2px; }
.gg-item:hover .gg-overlay-cat{transform:translateY(0);opacity:1;}
.gg-cat-pill { position:absolute;top:12px;left:12px;z-index:3;font-size:.66rem;font-weight:700;padding:4px 11px;border-radius:50px;letter-spacing:.05em;text-transform:uppercase;backdrop-filter:blur(6px);transform:translateY(-6px);opacity:0;transition:all .35s cubic-bezier(.34,1.56,.64,1); }
.gg-item:hover .gg-cat-pill{transform:translateY(0);opacity:1;}
.gg-cat-pill.clinic   {background:rgba(11,107,206,.8);color:#fff;}
.gg-cat-pill.pediatric{background:rgba(46,125,50,.8);color:#fff;}
.gg-cat-pill.ortho    {background:rgba(5,30,70,.85);color:#7dd3fc;}
.gg-cat-pill.smile    {background:rgba(194,24,91,.8);color:#fff;}
.gg-item.hidden{display:none;}
.gg-item.entering{animation:itemEnter .45s cubic-bezier(.34,1.56,.64,1) both;}
@keyframes itemEnter{from{opacity:0;transform:scale(.85) translateY(20px);}to{opacity:1;transform:scale(1) translateY(0);}}
.gg-empty { grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--text-light);font-size:.95rem;display:none; }

/* Lightbox */
.glb { display:none;position:fixed;inset:0;background:rgba(2,10,30,.94);z-index:99999;align-items:center;justify-content:center;backdrop-filter:blur(12px); }
.glb.open{display:flex;}
.glb-wrap { position:relative;max-width:88vw;max-height:88vh;text-align:center;animation:lbIn .35s cubic-bezier(.34,1.56,.64,1) both; }
@keyframes lbIn{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
.glb-img { max-width:100%;max-height:80vh;object-fit:contain;display:block;border-radius:16px;box-shadow:0 30px 80px rgba(0,0,0,.6); }
.glb-caption { color:rgba(255,255,255,.75);font-size:.9rem;font-weight:500;margin-top:14px;letter-spacing:.03em; }
.glb-counter { color:rgba(255,255,255,.4);font-size:.75rem;margin-top:4px; }
.glb-btn { position:absolute;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1.5px solid rgba(255,255,255,.2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease; }
.glb-btn:hover{background:var(--blue);border-color:var(--blue);transform:scale(1.1);}
.glb-close{width:44px;height:44px;font-size:1rem;top:16px;right:16px;position:fixed;}
.glb-prev{width:50px;height:50px;font-size:1.1rem;top:50%;left:20px;transform:translateY(-50%);}
.glb-next{width:50px;height:50px;font-size:1.1rem;top:50%;right:20px;transform:translateY(-50%);}
.glb-prev:hover{transform:translateY(-50%) scale(1.1);}
.glb-next:hover{transform:translateY(-50%) scale(1.1);}
.glb-thumbs { display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:14px;max-width:600px;margin-left:auto;margin-right:auto; }
.glb-thumb { width:50px;height:38px;border-radius:7px;overflow:hidden;border:2px solid transparent;cursor:pointer;transition:all .25s ease;opacity:.55; }
.glb-thumb.active{border-color:#7dd3fc;opacity:1;transform:scale(1.08);}
.glb-thumb:hover{opacity:.85;}
.glb-thumb img{width:100%;height:100%;object-fit:cover;}

/* Gallery CTA */
.gcta { background:linear-gradient(135deg,#051a3e,var(--blue));padding:70px 0;text-align:center;position:relative;overflow:hidden; }
.gcta::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='20' fill='none' stroke='%23fff' stroke-opacity='.04'/%3E%3C/svg%3E");}
.gcta h2{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3.5vw,2.5rem);color:#fff;margin-bottom:12px;position:relative;}
.gcta h2 span{color:#7dd3fc;}
.gcta p{color:rgba(255,255,255,.75);margin-bottom:28px;font-size:1rem;position:relative;}
.gcta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;}

/* ══════════════════════════════════════
   CONTACT PAGE
══════════════════════════════════════ */

/* Breadcrumb hero */
.bc-hero { background:linear-gradient(120deg,#020d22 0%,#073d8a 55%,#0B6BCE 100%);padding:110px 0 0;position:relative;overflow:hidden; }
.bc-hero-shapes span { position:absolute;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none; }
.bc-hero-shapes span:nth-child(1){width:520px;height:520px;top:-200px;right:-120px;}
.bc-hero-shapes span:nth-child(2){width:280px;height:280px;bottom:-80px;left:-60px;}
.bc-hero-shapes span:nth-child(3){width:140px;height:140px;top:40%;right:22%;}
.bc-dots span { position:absolute;width:5px;height:5px;border-radius:50%;background:rgba(125,211,252,.35);animation:dotPulse 3s ease-in-out infinite;pointer-events:none; }
@keyframes dotPulse{0%,100%{transform:scale(1);opacity:.35;}50%{transform:scale(2.2);opacity:.7;}}
.bc-inner { position:relative;z-index:2;padding-bottom:48px; }
.bc-eyebrow { display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#7dd3fc;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 16px;border-radius:50px;margin-bottom:16px;animation:fadeDown .6s ease both; }
@keyframes fadeDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
.bc-title { font-family:'Playfair Display',serif;font-size:clamp(2rem,4.5vw,3.2rem);font-weight:800;color:#fff;line-height:1.15;margin-bottom:14px;animation:fadeUp .7s ease .1s both; }
.bc-title span{color:#7dd3fc;}
.bc-sub { font-size:.98rem;color:rgba(255,255,255,.72);max-width:520px;line-height:1.75;margin-bottom:24px;animation:fadeUp .7s ease .2s both; }
.bc-breadcrumb { display:inline-flex;align-items:center;gap:8px;font-size:.8rem;color:rgba(255,255,255,.55);animation:fadeUp .7s ease .3s both; }
.bc-breadcrumb a { color:rgba(255,255,255,.75);text-decoration:none;transition:color .25s; }
.bc-breadcrumb a:hover{color:#fff;}
.bc-breadcrumb i{font-size:.58rem;color:rgba(255,255,255,.35);}
.bc-breadcrumb .active{color:#7dd3fc;font-weight:600;}
.bc-wave{position:relative;z-index:2;line-height:0;}
.bc-wave svg{width:100%;display:block;}

/* Contact detail cards */
.cd-section { background:var(--sky);padding:80px 0 70px;position:relative;overflow:hidden; }
.cd-section::after { content:'';position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(11,107,206,.06),transparent 70%);top:-120px;right:-120px;pointer-events:none; }
.cd-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:56px; }
.cd-card { background:#fff;border:1.5px solid var(--border);border-radius:20px;padding:32px 22px 28px;text-align:center;text-decoration:none;display:flex;flex-direction:column;align-items:center;box-shadow:var(--shadow-sm);transition:transform .35s cubic-bezier(.34,1.56,.64,1),box-shadow .35s ease,border-color .35s ease;position:relative;overflow:hidden; }
.cd-card::before { content:'';position:absolute;bottom:0;left:0;right:0;height:3px;border-radius:0 0 20px 20px;transform:scaleX(0);transform-origin:left;transition:transform .4s ease; }
.cd-card.blue::before{background:var(--blue);}
.cd-card.green::before{background:var(--green);}
.cd-card.orange::before{background:var(--orange);}
.cd-card.pink::before{background:#e91e63;}
.cd-card:hover { transform:translateY(-10px) scale(1.02);box-shadow:var(--shadow-lg); }
.cd-card:hover::before{transform:scaleX(1);}
.cd-card.blue:hover{border-color:var(--blue);}
.cd-card.green:hover{border-color:var(--green);}
.cd-card.orange:hover{border-color:var(--orange);}
.cd-card.pink:hover{border-color:#e91e63;}
.cd-icon-wrap { width:68px;height:68px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:1.55rem;margin-bottom:18px;transition:transform .35s cubic-bezier(.34,1.56,.64,1); }
.cd-card:hover .cd-icon-wrap{transform:rotate(-8deg) scale(1.15);}
.cd-card.blue .cd-icon-wrap{background:#e3f2fd;color:var(--blue);}
.cd-card.green .cd-icon-wrap{background:#e8f5e9;color:#2e7d32;}
.cd-card.orange .cd-icon-wrap{background:#fff3e0;color:var(--orange);}
.cd-card.pink .cd-icon-wrap{background:#fce4ec;color:#e91e63;}
.cd-card h4{font-size:.95rem;font-weight:700;color:var(--text);margin-bottom:8px;}
.cd-card p{font-size:.85rem;color:var(--text-mid);font-weight:500;margin-bottom:4px;line-height:1.5;}
.cd-card small{font-size:.74rem;color:var(--text-light);}

/* Hours */
.cd-hours-wrap { background:#fff;border:1.5px solid var(--border);border-radius:20px;padding:36px 40px;box-shadow:var(--shadow-sm);display:grid;grid-template-columns:1fr 1px 1fr 1px 1fr;gap:0;align-items:center;overflow:hidden;position:relative; }
.cd-hours-wrap::before { content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(11,107,206,.03),transparent 60%);pointer-events:none; }
.cd-hours-divider{width:1px;background:var(--border);align-self:stretch;margin:0 28px;}
.cd-hour-item{text-align:center;}
.cd-hour-day{font-size:.8rem;font-weight:700;color:var(--text-light);letter-spacing:.06em;text-transform:uppercase;margin-bottom:6px;}
.cd-hour-time{font-size:1rem;font-weight:700;color:var(--text);}
.cd-hour-badge{display:inline-block;background:#e8f5e9;color:#2e7d32;font-size:.65rem;font-weight:700;letter-spacing:.06em;padding:3px 10px;border-radius:50px;margin-top:5px;}
.cd-hour-badge.appt{background:#fff3e0;color:var(--orange);}
.cd-social-row{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:28px;flex-wrap:wrap;}
.cd-social-label{font-size:.8rem;color:var(--text-light);font-weight:600;}
.cd-social-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 20px;border-radius:50px;font-size:.82rem;font-weight:600;border:1.5px solid;text-decoration:none;transition:all .3s ease;position:relative;overflow:hidden;}
.cd-social-btn::after{content:'';position:absolute;inset:0;transform:scaleX(0);transform-origin:left;transition:transform .3s ease;}
.cd-social-btn:hover::after{transform:scaleX(1);}
.cd-social-btn i,.cd-social-btn span{position:relative;z-index:1;}
.cd-social-btn:hover{color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.15);}
.cd-social-btn.fb{border-color:#1877f2;color:#1877f2;}.cd-social-btn.fb::after{background:#1877f2;}
.cd-social-btn.ig{border-color:#e1306c;color:#e1306c;}.cd-social-btn.ig::after{background:#e1306c;}
.cd-social-btn.wa{border-color:var(--green);color:var(--green);}.cd-social-btn.wa::after{background:var(--green);}

/* Form section */
.cf-section{background:#fff;padding:80px 0;position:relative;overflow:hidden;}
.cf-section::before{content:'';position:absolute;top:-80px;right:-80px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(11,107,206,.05),transparent 70%);pointer-events:none;}
.cf-section::after{content:'';position:absolute;bottom:-60px;left:-60px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(37,211,102,.04),transparent 70%);pointer-events:none;}
.cf-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:56px;align-items:start;position:relative;z-index:1;}
.cf-left h2{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,2.8vw,2.1rem);color:var(--text);line-height:1.2;margin-bottom:12px;}
.cf-left h2 span{color:var(--blue);}
.cf-left > p{font-size:.92rem;color:var(--text-mid);line-height:1.8;margin-bottom:30px;}
.cf-features{display:flex;flex-direction:column;gap:12px;}
.cf-feat{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--sky);border:1px solid var(--border);border-left:3px solid var(--blue);border-radius:0 12px 12px 0;transition:all .3s ease;}
.cf-feat:hover{background:#e0f0ff;transform:translateX(6px);box-shadow:var(--shadow-sm);}
.cf-feat-icon{width:38px;height:38px;background:var(--blue);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.9rem;flex-shrink:0;transition:transform .3s ease;}
.cf-feat:hover .cf-feat-icon{transform:rotate(10deg) scale(1.1);}
.cf-feat-text strong{display:block;font-size:.85rem;font-weight:700;color:var(--text);}
.cf-feat-text span{font-size:.76rem;color:var(--text-mid);}
.cf-form-card{background:#fff;border-radius:24px;border:1.5px solid var(--border);box-shadow:0 20px 70px rgba(11,107,206,.11),0 2px 10px rgba(11,107,206,.05);overflow:hidden;}
.cff-header{background:linear-gradient(130deg,#051a3e 0%,#0B6BCE 100%);padding:26px 32px 22px;position:relative;overflow:hidden;}
.cff-header::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='50' height='50' viewBox='0 0 50 50' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='25' cy='25' r='18' fill='none' stroke='%23fff' stroke-opacity='.05'/%3E%3C/svg%3E");}
.cff-header h3{font-family:'Playfair Display',serif;font-size:1.4rem;color:#fff;margin-bottom:4px;position:relative;}
.cff-header p{font-size:.8rem;color:rgba(255,255,255,.65);position:relative;}
.cff-body{padding:28px 32px 32px;}
.cff-body .frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.cff-body .fg{margin-bottom:14px;}
.cff-body .fg label{display:block;font-size:.78rem;font-weight:600;color:var(--text-mid);margin-bottom:5px;}
.cff-body .fg label span{color:#e53935;}
.cff-body .fg input,.cff-body .fg select,.cff-body .fg textarea{width:100%;padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;font-size:.88rem;font-family:'Poppins',sans-serif;color:var(--text);background:#fff;transition:border-color .25s,box-shadow .25s,background .25s;outline:none;box-sizing:border-box;appearance:auto;}
.cff-body .fg input:focus,.cff-body .fg select:focus,.cff-body .fg textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(11,107,206,.08);background:#f8fcff;}
.cff-body .fg input.error,.cff-body .fg select.error,.cff-body .fg textarea.error{border-color:#e53935!important;box-shadow:0 0 0 3px rgba(229,57,53,.09)!important;}
.cff-body .fg textarea{resize:vertical;min-height:90px;}
.cf-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 22px;border-radius:50px;font-size:.88rem;font-weight:700;font-family:'Poppins',sans-serif;border:none;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;}
.cf-btn.submit{background:linear-gradient(135deg,#1b5e20,#43a047);color:#fff;box-shadow:0 6px 22px rgba(46,125,50,.28);}
.cf-btn.submit:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(46,125,50,.38);}

/* Map */
.cmap-section{background:var(--sky);padding:80px 0 90px;position:relative;overflow:hidden;}
.cmap-section::before{content:'';position:absolute;bottom:-100px;right:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(11,107,206,.06),transparent 70%);pointer-events:none;}
.cmap-grid{display:grid;grid-template-columns:340px 1fr;gap:28px;align-items:stretch;}
.cmap-info{background:#fff;border-radius:20px;padding:32px 26px;border:1.5px solid var(--border);box-shadow:var(--shadow-md);display:flex;flex-direction:column;}
.cmap-info h3{font-family:'Playfair Display',serif;font-size:1.25rem;color:var(--text);margin-bottom:5px;}
.cmap-info h3 span{color:var(--blue);}
.cmap-info > p{font-size:.8rem;color:var(--text-light);margin-bottom:22px;line-height:1.6;}
.cmap-row{display:flex;align-items:flex-start;gap:13px;padding:12px 0;border-bottom:1px solid var(--border);transition:padding-left .25s ease;cursor:default;}
.cmap-row:last-of-type{border-bottom:none;}
.cmap-row:hover{padding-left:5px;}
.cmap-row-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.9rem;flex-shrink:0;transition:transform .3s ease;}
.cmap-row:hover .cmap-row-icon{transform:scale(1.1) rotate(-5deg);}
.cmap-row-icon.b{background:var(--sky);color:var(--blue);}
.cmap-row-icon.g{background:#e8f5e9;color:#2e7d32;}
.cmap-row-icon.o{background:#fff3e0;color:var(--orange);}
.cmap-row-icon.p{background:#fce4ec;color:#e91e63;}
.cmap-row-icon.n{background:#e8eaf6;color:#3949ab;}
.cmap-row strong{display:block;font-size:.82rem;font-weight:700;color:var(--text);}
.cmap-row span,.cmap-row a{font-size:.78rem;color:var(--text-mid);line-height:1.5;text-decoration:none;}
.cmap-row a:hover{color:var(--blue);text-decoration:underline;}
.cmap-dir-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:22px;padding:13px;background:var(--blue);color:#fff;border-radius:50px;font-size:.85rem;font-weight:700;text-decoration:none;transition:all .3s ease;box-shadow:0 6px 20px rgba(11,107,206,.28);}
.cmap-dir-btn:hover{background:var(--blue-dark);transform:translateY(-2px);}
.cmap-frame{border-radius:20px;overflow:hidden;box-shadow:var(--shadow-lg);border:1.5px solid var(--border);position:relative;min-height:460px;}
.cmap-frame iframe{width:100%;height:100%;min-height:460px;border:none;display:block;}
.cmap-pin-badge{position:absolute;bottom:20px;right:20px;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-radius:14px;padding:12px 16px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-md);border:1px solid var(--border);}
.cmap-pin-badge i{color:#e53935;font-size:1.2rem;animation:pinBounce 1.4s ease-in-out infinite;}
@keyframes pinBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
.cmap-pin-badge strong{display:block;font-size:.8rem;color:var(--text);font-weight:700;}
.cmap-pin-badge span{font-size:.72rem;color:var(--text-light);}

/* Success modal */
.smodal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:10001;align-items:center;justify-content:center;backdrop-filter:blur(6px);}
.smodal-overlay.active{display:flex;}
.smodal-box{background:#fff;border-radius:24px;padding:48px 40px;max-width:450px;width:90%;text-align:center;box-shadow:0 32px 80px rgba(0,0,0,.2);animation:modalPop .4s cubic-bezier(.34,1.56,.64,1) both;position:relative;overflow:hidden;}
@keyframes modalPop{from{opacity:0;transform:scale(.75) translateY(24px);}to{opacity:1;transform:scale(1) translateY(0);}}
.smodal-icon{font-size:3.8rem;color:#2e7d32;margin-bottom:14px;animation:iconPop .45s cubic-bezier(.34,1.56,.64,1) .15s both;}
@keyframes iconPop{from{transform:scale(0)}to{transform:scale(1)}}
.smodal-box h3{font-size:1.35rem;font-weight:700;color:var(--text);margin-bottom:8px;}
.smodal-box p{color:var(--text-mid);font-size:.9rem;line-height:1.7;margin-bottom:22px;}
.smodal-wa{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--green);color:#fff;padding:13px;border-radius:50px;font-size:.9rem;font-weight:700;text-decoration:none;margin-bottom:12px;transition:all .3s ease;}
.smodal-wa:hover{background:#1fb855;transform:translateY(-2px);}
.smodal-close{display:block;width:100%;padding:11px;border:1.5px solid var(--border);border-radius:50px;color:var(--text-mid);font-size:.86rem;font-weight:600;cursor:pointer;font-family:'Poppins',sans-serif;background:transparent;transition:all .3s ease;}
.smodal-close:hover{border-color:var(--blue);color:var(--blue);}
.smodal-confetti{position:absolute;inset:0;pointer-events:none;overflow:hidden;}
.conf-piece{position:absolute;border-radius:2px;animation:confFall 2s ease-in forwards;}
@keyframes confFall{0%{transform:translateY(-10px) rotate(0deg);opacity:1;}100%{transform:translateY(320px) rotate(720deg);opacity:0;}}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media(max-width:960px){
  .about-page-mission{grid-template-columns:1fr;gap:60px;}
  .about-mission-img img{height:360px;}
  .about-mission-img::before{display:none;}
  .about-mission-img-badge{bottom:-16px;left:16px;}
  .accred-grid{grid-template-columns:repeat(2,1fr);}
  .credentials-strip{grid-template-columns:repeat(2,1fr);}
  .credentials-strip .cred-item:nth-child(2){border-right:none;}
  .doctors-page-grid{grid-template-columns:1fr;max-width:500px;}
  .services-page-grid{grid-template-columns:repeat(2,1fr);}
  .process-steps{grid-template-columns:repeat(2,1fr);gap:32px;}
  .process-steps::before{display:none;}
  .gg-grid{grid-template-columns:repeat(2,1fr);}
  .cd-grid{grid-template-columns:repeat(2,1fr);}
  .cd-hours-wrap{grid-template-columns:1fr;gap:20px;}
  .cd-hours-divider{display:none;}
  .cf-grid{grid-template-columns:1fr;gap:40px;}
  .cmap-grid{grid-template-columns:1fr;}
  .cmap-info{position:static;}
  .mission-values{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .page-hero{padding:120px 0 60px;}
  .accred-grid{grid-template-columns:1fr 1fr;}
  .services-page-grid{grid-template-columns:1fr;}
  .cd-grid{grid-template-columns:1fr 1fr;}
  .cff-body .frow{grid-template-columns:1fr;}
  .cff-body{padding:20px 18px 24px;}
  .cff-header{padding:20px 18px 16px;}
  .cmap-frame{min-height:300px;}
  .cmap-frame iframe{min-height:300px;}
  .credentials-strip{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){
  .gg-grid{grid-template-columns:1fr;}
  .cd-grid{grid-template-columns:1fr;}
  .gf-tabs{gap:5px;}
  .gf-tab{padding:7px 14px;font-size:.76rem;}
  .glb-prev{left:8px;}
  .glb-next{right:8px;}
}

/* ══════════════════════════════════════
   DOCTORS PAGE — PREMIUM CARD DESIGN
══════════════════════════════════════ */

/* ── Doctor Card Layout ── */
.dr-card {
  display: grid;
  grid-template-columns: 380px 1fr;
  gap: 0;
  background: #fff;
  border-radius: 24px;
  border: 1.5px solid var(--border);
  box-shadow: 0 20px 60px rgba(11,107,206,.10);
  overflow: hidden;
  margin-bottom: 50px;
  transition: box-shadow .4s ease, transform .4s ease;
  max-height: 580px;
}
.dr-card:hover {
  box-shadow: 0 32px 80px rgba(11,107,206,.18);
  transform: translateY(-4px);
}
.dr-card.reverse { grid-template-columns: 1fr 380px; }
.dr-card.reverse .dr-img-col  { order: 2; }
.dr-card.reverse .dr-info-col { order: 1; }

/* ── Image Column ── */
.dr-img-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  position: relative;
  overflow: hidden;
  height: 580px;
  background: linear-gradient(170deg, #0a1f44 0%, #0B6BCE 100%);
}
.dr-card.reverse .dr-img-col {
  background: linear-gradient(170deg, #1a0a44 0%, #6b21a8 60%, #0B6BCE 100%);
}
.dr-img-col::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='20' cy='20' r='1.5' fill='%23fff' fill-opacity='.06'/%3E%3C/svg%3E");
  z-index: 0;
  pointer-events: none;
}
.dr-img-col::after { display: none; }

/* ── Doctor Photo ── */
.dr-img-wrap {
  position: relative;
  width: 100%;
  flex: 1;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  z-index: 2;
  overflow: hidden;
}
.dr-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  position: relative;
  z-index: 2;
  filter: drop-shadow(0 10px 30px rgba(0,0,0,.4));
  transition: transform .5s cubic-bezier(.34,1.56,.64,1);
}
.dr-card:hover .dr-img-wrap img {
  transform: scale(1.04);
}

/* glow effect behind photo */
.dr-img-glow {
  position: absolute;
  bottom: 80px; left: 50%;
  transform: translateX(-50%);
  width: 320px; height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(11,107,206,.5), transparent 65%);
  filter: blur(50px);
  pointer-events: none;
  z-index: 1;
  animation: glowPulse 3s ease-in-out infinite;
}
.dr-img-glow.ortho {
  background: radial-gradient(circle, rgba(107,33,168,.5), transparent 65%);
}
@keyframes glowPulse {
  0%,100% { opacity: .8; transform: translateX(-50%) scale(1); }
  50%      { opacity: 1;  transform: translateX(-50%) scale(1.18); }
}

/* bottom fade so image blends into social row area */
.dr-img-fade {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 100px;
  background: linear-gradient(0deg, #0B6BCE 0%, transparent 100%);
  z-index: 3;
  pointer-events: none;
}
.dr-card.reverse .dr-img-fade {
  background: linear-gradient(0deg, #6b21a8 0%, transparent 100%);
}

/* Social buttons */
.dr-social-row {
  display: flex;
  gap: 10px;
  z-index: 5;
  position: relative;
  padding: 0 0 22px;
}
.dr-exp-badge {
  position: absolute;
  top: 24px; right: 20px;
  background: rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  border: 1.5px solid rgba(255,255,255,.2);
  border-radius: 16px;
  padding: 12px 16px;
  text-align: center;
  z-index: 4;
  animation: badgeFloat 4s ease-in-out infinite;
}
.dr-exp-badge.ortho {
  background: rgba(107,33,168,.25);
  border-color: rgba(167,139,250,.3);
}
@keyframes badgeFloat {
  0%,100% { transform: translateY(0); }
  50%      { transform: translateY(-6px); }
}
.dr-exp-num {
  display: block;
  font-size: 1.6rem;
  font-weight: 800;
  color: #fff;
  line-height: 1;
}
.dr-exp-num sup { font-size: .9rem; }
.dr-exp-lbl {
  font-size: .65rem;
  color: rgba(255,255,255,.7);
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
}

/* Social buttons */
.dr-social-row {
  display: flex;
  gap: 10px;
  z-index: 3;
  margin-top: 0;
  padding: 0;
  position: relative;
}
.dr-social-btn {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,.12);
  backdrop-filter: blur(6px);
  border: 1.5px solid rgba(255,255,255,.2);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  text-decoration: none;
  transition: all .3s cubic-bezier(.34,1.56,.64,1);
}
.dr-social-btn:hover {
  background: rgba(255,255,255,.25);
  transform: scale(1.15) translateY(-3px);
  border-color: rgba(255,255,255,.5);
}
.dr-social-btn.wa:hover { background: rgba(37,211,102,.5); border-color: #25d366; }

/* ── Info Column ── */
.dr-info-col {
  padding: 44px 36px 28px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow-y: auto;
  height: 580px;
}

/* spec pill */
.dr-spec-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 50px;
  margin-bottom: 10px;
  width: fit-content;
}
.dr-spec-pill.pediatric {
  background: linear-gradient(135deg, #e8f5e9, #c8e6c9);
  color: #1b5e20;
  border: 1px solid #a5d6a7;
}
.dr-spec-pill.ortho {
  background: linear-gradient(135deg, #ede7f6, #d1c4e9);
  color: #4a148c;
  border: 1px solid #ce93d8;
}

/* doctor name */
.dr-name {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.4rem, 2.4vw, 1.9rem);
  font-weight: 800;
  color: var(--text);
  margin-bottom: 2px;
  line-height: 1.15;
}
.dr-role {
  font-size: .82rem;
  color: var(--text-light);
  margin-bottom: 12px;
  font-weight: 500;
}

/* qualifications box */
.dr-qual-box {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: var(--sky);
  border: 1px solid var(--border);
  border-left: 3px solid var(--blue);
  border-radius: 0 10px 10px 0;
  padding: 10px 14px;
  margin-bottom: 14px;
  font-size: .82rem;
  color: var(--text-mid);
  line-height: 1.5;
}
.dr-qual-box i { color: var(--blue); margin-top: 2px; flex-shrink: 0; font-size: .95rem; }
.dr-qual-box strong { color: var(--blue); }

/* description */
.dr-desc {
  font-size: .84rem;
  color: var(--text-mid);
  line-height: 1.7;
  margin-bottom: 10px;
}

/* specialisations */
.dr-spec-section { margin-bottom: 14px; }
.dr-spec-title {
  font-size: .72rem;
  font-weight: 700;
  color: var(--text-light);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 7px;
}
.dr-spec-title i { color: var(--blue); }
.dr-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.dr-tags span {
  background: var(--sky);
  border: 1px solid var(--border);
  color: var(--blue-dark);
  font-size: .7rem;
  font-weight: 600;
  padding: 4px 11px;
  border-radius: 50px;
  transition: all .25s ease;
}
.dr-tags span:hover {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
  transform: translateY(-2px);
}

/* stats row */
.dr-stats-row {
  display: flex;
  align-items: center;
  background: var(--sky);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 18px;
  margin-bottom: 16px;
}
.dr-stat { flex: 1; text-align: center; }
.dr-stat strong { display: block; font-size: 1.2rem; font-weight: 800; color: var(--text); line-height: 1; }
.dr-stat span   { font-size: .68rem; color: var(--text-light); font-weight: 500; letter-spacing: .04em; }
.dr-stat-div    { width: 1px; height: 32px; background: var(--border); }

/* book button */
.dr-book-btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: var(--blue);
  color: #fff;
  padding: 14px 28px;
  border-radius: 50px;
  font-size: .9rem;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 6px 22px rgba(11,107,206,.3);
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
  width: fit-content;
  position: relative;
  overflow: hidden;
}
.dr-book-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.15);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s ease;
}
.dr-book-btn:hover::before { transform: scaleX(1); }
.dr-book-btn:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(11,107,206,.4); }
.dr-book-btn.ortho {
  background: linear-gradient(135deg, #6b21a8, #9333ea);
  box-shadow: 0 6px 22px rgba(107,33,168,.3);
}
.dr-book-btn.ortho:hover { box-shadow: 0 12px 32px rgba(107,33,168,.4); }

/* ── Why grid ── */
.dr-why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.dr-why-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 20px;
  padding: 30px 24px;
  text-align: center;
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
  box-shadow: var(--shadow-sm);
}
.dr-why-card:hover {
  border-color: var(--blue);
  transform: translateY(-8px);
  box-shadow: var(--shadow-lg);
}
.dr-why-icon {
  width: 60px; height: 60px;
  background: var(--sky);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  color: var(--blue);
  margin: 0 auto 16px;
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
}
.dr-why-card:hover .dr-why-icon {
  background: var(--blue);
  color: #fff;
  transform: rotate(-8deg) scale(1.1);
}
.dr-why-card h4 { font-size: .98rem; font-weight: 700; color: var(--text); margin-bottom: 8px; }
.dr-why-card p  { font-size: .83rem; color: var(--text-mid); line-height: 1.7; }

/* ── RESPONSIVE ── */
@media(max-width:1000px){
  .dr-card,
  .dr-card.reverse { grid-template-columns: 1fr; max-height: none; }
  .dr-card.reverse .dr-img-col  { order: 1; }
  .dr-card.reverse .dr-info-col { order: 2; }
  .dr-img-col { height: 420px; }
  .dr-info-col { padding: 28px 24px; height: auto; overflow-y: visible; }
  .dr-why-grid { grid-template-columns: repeat(2,1fr); }
}
@media(max-width:600px){
  .dr-info-col { padding: 22px 18px; }
  .dr-stats-row { padding: 10px 12px; }
  .dr-stat strong { font-size: 1rem; }
  .dr-why-grid { grid-template-columns: 1fr; }
  .dr-img-col { height: 340px; }
}

/* ══════════════════════════════════════
   SERVICES PAGE
══════════════════════════════════════ */

/* ── 2-column service grid ── */
.sv-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}

/* ── Service Card — horizontal layout ── */
.sv-card {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 20px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-sm);
  position: relative;
  transition: transform .4s cubic-bezier(.34,1.56,.64,1),
              box-shadow .4s ease,
              border-color .3s ease;
}
.sv-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 24px 60px rgba(11,107,206,.16);
  border-color: var(--blue);
}
.sv-card.featured {
  border-color: #6b21a8;
  box-shadow: 0 8px 32px rgba(107,33,168,.15);
}
.sv-card.featured:hover { border-color: #6b21a8; box-shadow: 0 24px 60px rgba(107,33,168,.25); }

/* popular badge */
.sv-popular-badge {
  position: absolute;
  top: 14px; right: 14px;
  z-index: 10;
  background: linear-gradient(135deg,#6b21a8,#9333ea);
  color: #fff;
  font-size: .62rem;
  font-weight: 800;
  padding: 4px 12px;
  border-radius: 50px;
  letter-spacing: .08em;
  text-transform: uppercase;
  box-shadow: 0 4px 14px rgba(107,33,168,.4);
}

/* image area — top */
.sv-img {
  position: relative;
  height: 220px;
  overflow: hidden;
  flex-shrink: 0;
}
.sv-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .55s ease;
}
.sv-card:hover .sv-img img { transform: scale(1.08); }

/* dark overlay on image */
.sv-img-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5,20,50,.1) 0%, rgba(5,20,50,.6) 100%);
  transition: opacity .3s ease;
}
.sv-card:hover .sv-img-overlay { opacity: .75; }

/* icon badge on image */
.sv-icon-badge {
  position: absolute;
  top: 14px; left: 14px;
  width: 42px; height: 42px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.05rem;
  box-shadow: 0 4px 14px rgba(0,0,0,.25);
  transition: transform .35s cubic-bezier(.34,1.56,.64,1);
  z-index: 2;
}
.sv-card:hover .sv-icon-badge { transform: scale(1.12) rotate(-6deg); }

/* service title on image */
.sv-img-title {
  position: absolute;
  bottom: 12px; left: 14px; right: 14px;
  color: #fff;
  font-size: .88rem;
  font-weight: 700;
  text-shadow: 0 2px 8px rgba(0,0,0,.4);
  transform: translateY(4px);
  opacity: 0;
  transition: all .35s ease;
  z-index: 2;
}
.sv-card:hover .sv-img-title { transform: translateY(0); opacity: 1; }

/* body */
.sv-body {
  padding: 18px 18px 22px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.sv-desc {
  font-size: .8rem;
  color: var(--text-mid);
  line-height: 1.65;
  margin-bottom: 14px;
}

/* list */
.sv-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
  margin-bottom: 16px;
  list-style: none;
}
.sv-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .78rem;
  color: var(--text-mid);
  transition: color .25s, transform .25s;
}
.sv-list li:hover { color: var(--text); transform: translateX(3px); }
.sv-list i {
  font-size: .72rem;
  color: var(--blue);
  flex-shrink: 0;
  transition: transform .25s;
}
.sv-list li:hover i { transform: scale(1.2); }

/* book button */
.sv-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--btn-color, var(--blue));
  color: #fff;
  padding: 10px 20px;
  border-radius: 50px;
  font-size: .8rem;
  font-weight: 700;
  text-decoration: none;
  align-self: flex-start;
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
  box-shadow: 0 4px 16px rgba(0,0,0,.18);
  position: relative;
  overflow: hidden;
}
.sv-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,.18);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s ease;
}
.sv-btn:hover::before { transform: scaleX(1); }
.sv-btn:hover { transform: translateY(-3px); box-shadow: 0 8px 24px rgba(0,0,0,.22); }

/* ── CLINIC HIGHLIGHTS ── */
.sv-highlights-section {
  background: linear-gradient(135deg, #051e4a 0%, var(--blue) 60%, #1a85e5 100%);
  padding: 90px 0;
  position: relative;
  overflow: hidden;
}
.sv-highlights-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='20' fill='none' stroke='%23fff' stroke-opacity='.04'/%3E%3C/svg%3E");
  pointer-events: none;
}
.sv-highlights-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.sv-hl-card {
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 18px;
  padding: 28px 20px;
  text-align: center;
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
  position: relative;
  overflow: hidden;
}
.sv-hl-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,.06), transparent);
  border-radius: inherit;
}
.sv-hl-card:hover {
  background: rgba(255,255,255,.16);
  transform: translateY(-8px) scale(1.02);
  border-color: rgba(255,255,255,.3);
  box-shadow: 0 16px 40px rgba(0,0,0,.2);
}
.sv-hl-icon {
  width: 58px; height: 58px;
  background: rgba(255,255,255,.15);
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.45rem;
  color: #fff;
  margin: 0 auto 16px;
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
}
.sv-hl-card:hover .sv-hl-icon {
  background: rgba(255,255,255,.28);
  transform: rotate(-8deg) scale(1.12);
}
.sv-hl-card h4 {
  font-size: .92rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 8px;
  position: relative;
}
.sv-hl-card p {
  font-size: .78rem;
  color: rgba(255,255,255,.72);
  line-height: 1.65;
  position: relative;
}

/* 7th card spans to center on 4-col grid */
.sv-hl-card:nth-child(5) { grid-column: 1; }
.sv-hl-card:nth-child(6) { grid-column: 2; }
.sv-hl-card:nth-child(7) { grid-column: 3 / span 2; }

/* ── TREATMENT JOURNEY — HORIZONTAL ── */
.sv-journey {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  position: relative;
  max-width: 100%;
  margin: 0 auto;
}
/* connecting line across all steps */
.sv-journey::before {
  content: '';
  position: absolute;
  top: 22px;
  left: calc(12.5%);
  right: calc(12.5%);
  height: 2px;
  background: linear-gradient(90deg, var(--blue), var(--sky-mid), var(--blue));
  z-index: 0;
}
.sv-journey-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  padding: 0 12px;
}
/* step number circle */
.sv-journey-num {
  width: 44px; height: 44px;
  background: var(--blue);
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 800;
  flex-shrink: 0;
  position: relative;
  z-index: 2;
  box-shadow: 0 4px 16px rgba(11,107,206,.35);
  transition: transform .35s cubic-bezier(.34,1.56,.64,1), box-shadow .3s ease;
  margin-bottom: 20px;
  border: 3px solid #fff;
}
.sv-journey-step:hover .sv-journey-num {
  transform: scale(1.18);
  box-shadow: 0 8px 24px rgba(11,107,206,.5);
}
/* hide the old vertical line */
.sv-journey-line { display: none; }

/* card body below the number */
.sv-journey-body {
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 16px;
  padding: 20px 18px;
  flex: 1;
  box-shadow: var(--shadow-sm);
  transition: all .35s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  width: 100%;
}
.sv-journey-step:hover .sv-journey-body {
  border-color: var(--blue);
  box-shadow: var(--shadow-md);
  transform: translateY(-5px);
}
.sv-journey-icon {
  width: 48px; height: 48px;
  background: var(--sky);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--blue);
  flex-shrink: 0;
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
}
.sv-journey-step:hover .sv-journey-icon {
  background: var(--blue);
  color: #fff;
  transform: rotate(-8deg) scale(1.1);
}
.sv-journey-body h4 { font-size: .92rem; font-weight: 700; color: var(--text); margin: 0; }
.sv-journey-body p  { font-size: .8rem; color: var(--text-mid); line-height: 1.6; margin: 0; }

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .sv-grid { grid-template-columns: 1fr; }

}
@media(max-width:960px){
  .sv-highlights-grid { grid-template-columns: repeat(2,1fr); }
  .sv-hl-card:nth-child(5),
  .sv-hl-card:nth-child(6),
  .sv-hl-card:nth-child(7) { grid-column: auto; }
  .sv-journey { grid-template-columns: repeat(2,1fr); gap: 24px; }
  .sv-journey::before { display: none; }
}
@media(max-width:640px){
  .sv-grid { grid-template-columns: 1fr; }


  .sv-highlights-grid { grid-template-columns: 1fr; }
  .sv-journey { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════
   ABOUT PAGE — EXTRA SECTIONS
══════════════════════════════════════ */

/* ── SECTION 2: Gold Medal Achievement ── */
.ab-achieve-section {
  background: linear-gradient(135deg, #020c1f 0%, #0a2144 50%, #0B6BCE 100%);
  padding: 90px 0;
  position: relative;
  overflow: hidden;
}
.ab-achieve-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='20' fill='none' stroke='%23fff' stroke-opacity='.03'/%3E%3C/svg%3E");
  pointer-events: none;
}

.ab-achieve-grid {
  display: grid;
  grid-template-columns: 1fr 480px;
  gap: 70px;
  align-items: center;
}

/* content side */
.ab-achieve-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.2);
  color: #fbbf24;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 6px 16px;
  border-radius: 50px;
  margin-bottom: 20px;
}
.ab-achieve-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.6rem, 3vw, 2.3rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.2;
  margin-bottom: 18px;
}
.ab-achieve-title span { color: #fbbf24; }

.ab-achieve-desc {
  font-size: .92rem;
  color: rgba(255,255,255,.78);
  line-height: 1.85;
  margin-bottom: 32px;
}
.ab-achieve-desc strong { color: #fbbf24; }

.ab-achieve-points {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ab-achieve-pt {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  padding: 16px 18px;
  transition: all .3s ease;
}
.ab-achieve-pt:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(251,191,36,.3);
  transform: translateX(5px);
}
.ab-achieve-pt-icon {
  width: 40px; height: 40px;
  background: linear-gradient(135deg,#b45309,#fbbf24);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: .95rem;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(251,191,36,.3);
}
.ab-achieve-pt strong {
  display: block;
  font-size: .85rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 2px;
}
.ab-achieve-pt span {
  font-size: .76rem;
  color: rgba(255,255,255,.6);
  line-height: 1.4;
}

/* image side */
.ab-achieve-img-wrap {
  position: relative;
}
.ab-achieve-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  pointer-events: none;
  animation: abOrbFloat 6s ease-in-out infinite;
}
.ab-achieve-orb-1 {
  width: 280px; height: 280px;
  background: rgba(251,191,36,.18);
  top: -60px; right: -60px;
}
.ab-achieve-orb-2 {
  width: 180px; height: 180px;
  background: rgba(11,107,206,.25);
  bottom: -40px; left: -40px;
  animation-delay: 3s;
}
@keyframes abOrbFloat {
  0%,100% { transform: translate(0,0); }
  50%      { transform: translate(12px,-12px); }
}

.ab-achieve-img-frame {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.5);
  border: 2px solid rgba(251,191,36,.25);
}
.ab-achieve-img-frame img {
  width: 100%;
  height: 420px;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform .6s ease;
}
.ab-achieve-img-frame:hover img { transform: scale(1.04); }

.ab-achieve-img-badge {
  position: absolute;
  bottom: 20px; left: 20px;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(251,191,36,.4);
  border-radius: 14px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.ab-achieve-img-badge i { color: #fbbf24; font-size: 1.5rem; }
.ab-achieve-img-badge strong { display: block; font-size: .88rem; font-weight: 700; color: #fff; }
.ab-achieve-img-badge span  { font-size: .72rem; color: rgba(255,255,255,.6); }

/* ── SECTION 3: Invisalign / iTero ── */
.ab-invis-section {
  background: #fff;
  padding: 90px 0;
  position: relative;
  overflow: hidden;
}
.ab-invis-section::before {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 45%;
  height: 100%;
  background: linear-gradient(135deg, var(--sky) 0%, #dbeeff 100%);
  clip-path: polygon(15% 0, 100% 0, 100% 100%, 0% 100%);
  pointer-events: none;
}

.ab-invis-grid {
  display: grid;
  grid-template-columns: 480px 1fr;
  gap: 70px;
  align-items: center;
  position: relative;
  z-index: 1;
}

/* image side */
.ab-invis-img-wrap { position: relative; }
.ab-invis-img-frame {
  border-radius: 24px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 1.5px solid var(--border);
}
.ab-invis-img-frame img {
  width: 100%;
  height: 480px;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform .6s ease;
}
.ab-invis-img-frame:hover img { transform: scale(1.04); }

/* floating stat cards */
.ab-invis-stat {
  position: absolute;
  background: #fff;
  border-radius: 16px;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: 0 8px 32px rgba(11,107,206,.18);
  border: 1.5px solid var(--border);
  animation: abStatFloat 4s ease-in-out infinite;
}
.ab-invis-stat-1 {
  top: -20px; right: -24px;
  animation-delay: 0s;
}
.ab-invis-stat-2 {
  bottom: 30px; left: -24px;
  animation-delay: 2s;
}
@keyframes abStatFloat {
  0%,100%{ transform:translateY(0); }
  50%    { transform:translateY(-7px); }
}
.ab-invis-stat i {
  font-size: 1.5rem;
  color: var(--blue);
  flex-shrink: 0;
}
.ab-invis-stat strong { display:block; font-size:.95rem; font-weight:800; color:var(--text); line-height:1; }
.ab-invis-stat span   { font-size:.72rem; color:var(--text-light); line-height:1.4; }

/* content side */
.ab-invis-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg,#ede7f6,#d1c4e9);
  border: 1px solid #ce93d8;
  color: #4a148c;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 6px 16px;
  border-radius: 50px;
  margin-bottom: 18px;
}
.ab-invis-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.5rem, 2.8vw, 2.1rem);
  font-weight: 800;
  color: var(--text);
  line-height: 1.2;
  margin-bottom: 16px;
}
.ab-invis-title span { color: var(--blue); }

.ab-invis-desc {
  font-size: .9rem;
  color: var(--text-mid);
  line-height: 1.85;
  margin-bottom: 26px;
}
.ab-invis-desc strong { color: var(--blue); }

.ab-invis-features {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 28px;
}
.ab-invis-feat {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  background: var(--sky);
  border: 1px solid var(--border);
  border-radius: 12px;
  transition: all .3s ease;
}
.ab-invis-feat:hover {
  border-color: var(--blue);
  transform: translateX(5px);
  box-shadow: var(--shadow-sm);
}
.ab-invis-feat > i {
  color: var(--blue);
  font-size: 1rem;
  margin-top: 2px;
  flex-shrink: 0;
}
.ab-invis-feat strong { display:block; font-size:.85rem; font-weight:700; color:var(--text); margin-bottom:2px; }
.ab-invis-feat span   { font-size:.76rem; color:var(--text-mid); line-height:1.4; }

.ab-invis-btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: var(--blue);
  color: #fff;
  padding: 14px 28px;
  border-radius: 50px;
  font-size: .9rem;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 6px 22px rgba(11,107,206,.3);
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
}
.ab-invis-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(11,107,206,.4);
  background: var(--blue-dark);
}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .ab-achieve-grid { grid-template-columns:1fr; gap:44px; }
  .ab-achieve-grid .ab-achieve-img-wrap { order:-1; }
  .ab-achieve-img-frame img { height:320px; }
  .ab-invis-grid { grid-template-columns:1fr; gap:44px; }
  .ab-invis-img-frame img { height:340px; }
  .ab-invis-stat-1 { top:-14px; right:10px; }
  .ab-invis-stat-2 { bottom:10px; left:10px; }
  .ab-invis-section::before { display:none; }
}
@media(max-width:600px){
  .ab-achieve-img-frame img { height:240px; }
  .ab-invis-img-frame img { height:260px; }
  .ab-invis-stat { display:none; }
}

/* ══════════════════════════════════════
   ABOUT PAGE — EXTRA SECTIONS
══════════════════════════════════════ */

/* ── SECTION 2: Gold Medal Achievement ── */
.ab-achieve-section {
  background: linear-gradient(135deg, #020c1f 0%, #0a2144 50%, #0B6BCE 100%);
  padding: 90px 0;
  position: relative;
  overflow: hidden;
}
.ab-achieve-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='30' cy='30' r='20' fill='none' stroke='%23fff' stroke-opacity='.03'/%3E%3C/svg%3E");
  pointer-events: none;
}

.ab-achieve-grid {
  display: grid;
  grid-template-columns: 1fr 480px;
  gap: 70px;
  align-items: center;
}

/* content side */
.ab-achieve-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.2);
  color: #fbbf24;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 6px 16px;
  border-radius: 50px;
  margin-bottom: 20px;
}
.ab-achieve-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.6rem, 3vw, 2.3rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.2;
  margin-bottom: 18px;
}
.ab-achieve-title span { color: #fbbf24; }

.ab-achieve-desc {
  font-size: .92rem;
  color: rgba(255,255,255,.78);
  line-height: 1.85;
  margin-bottom: 32px;
}
.ab-achieve-desc strong { color: #fbbf24; }

.ab-achieve-points {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.ab-achieve-pt {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  padding: 16px 18px;
  transition: all .3s ease;
}
.ab-achieve-pt:hover {
  background: rgba(255,255,255,.12);
  border-color: rgba(251,191,36,.3);
  transform: translateX(5px);
}
.ab-achieve-pt-icon {
  width: 40px; height: 40px;
  background: linear-gradient(135deg,#b45309,#fbbf24);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: .95rem;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(251,191,36,.3);
}
.ab-achieve-pt strong {
  display: block;
  font-size: .85rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 2px;
}
.ab-achieve-pt span {
  font-size: .76rem;
  color: rgba(255,255,255,.6);
  line-height: 1.4;
}

/* image side */
.ab-achieve-img-wrap {
  position: relative;
}
.ab-achieve-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  pointer-events: none;
  animation: abOrbFloat 6s ease-in-out infinite;
}
.ab-achieve-orb-1 {
  width: 280px; height: 280px;
  background: rgba(251,191,36,.18);
  top: -60px; right: -60px;
}
.ab-achieve-orb-2 {
  width: 180px; height: 180px;
  background: rgba(11,107,206,.25);
  bottom: -40px; left: -40px;
  animation-delay: 3s;
}
@keyframes abOrbFloat {
  0%,100% { transform: translate(0,0); }
  50%      { transform: translate(12px,-12px); }
}

.ab-achieve-img-frame {
  position: relative;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.5);
  border: 2px solid rgba(251,191,36,.25);
}
.ab-achieve-img-frame img {
  width: 100%;
  height: 420px;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform .6s ease;
}
.ab-achieve-img-frame:hover img { transform: scale(1.04); }

.ab-achieve-img-badge {
  position: absolute;
  bottom: 20px; left: 20px;
  background: rgba(0,0,0,.75);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(251,191,36,.4);
  border-radius: 14px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.ab-achieve-img-badge i { color: #fbbf24; font-size: 1.5rem; }
.ab-achieve-img-badge strong { display: block; font-size: .88rem; font-weight: 700; color: #fff; }
.ab-achieve-img-badge span  { font-size: .72rem; color: rgba(255,255,255,.6); }

/* ── SECTION 3: Invisalign / iTero ── */
.ab-invis-section {
  background: #fff;
  padding: 90px 0;
  position: relative;
  overflow: hidden;
}
.ab-invis-section::before {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 45%;
  height: 100%;
  background: linear-gradient(135deg, var(--sky) 0%, #dbeeff 100%);
  clip-path: polygon(15% 0, 100% 0, 100% 100%, 0% 100%);
  pointer-events: none;
}

.ab-invis-grid {
  display: grid;
  grid-template-columns: 480px 1fr;
  gap: 70px;
  align-items: center;
  position: relative;
  z-index: 1;
}

/* image side */
.ab-invis-img-wrap { position: relative; }
.ab-invis-img-frame {
  border-radius: 24px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  border: 1.5px solid var(--border);
}
.ab-invis-img-frame img {
  width: 100%;
  height: 480px;
  object-fit: cover;
  object-position: center;
  display: block;
  transition: transform .6s ease;
}
.ab-invis-img-frame:hover img { transform: scale(1.04); }

/* floating stat cards */
.ab-invis-stat {
  position: absolute;
  background: #fff;
  border-radius: 16px;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 12px;
  box-shadow: 0 8px 32px rgba(11,107,206,.18);
  border: 1.5px solid var(--border);
  animation: abStatFloat 4s ease-in-out infinite;
}
.ab-invis-stat-1 {
  top: -20px; right: -24px;
  animation-delay: 0s;
}
.ab-invis-stat-2 {
  bottom: 30px; left: -24px;
  animation-delay: 2s;
}
@keyframes abStatFloat {
  0%,100%{ transform:translateY(0); }
  50%    { transform:translateY(-7px); }
}
.ab-invis-stat i {
  font-size: 1.5rem;
  color: var(--blue);
  flex-shrink: 0;
}
.ab-invis-stat strong { display:block; font-size:.95rem; font-weight:800; color:var(--text); line-height:1; }
.ab-invis-stat span   { font-size:.72rem; color:var(--text-light); line-height:1.4; }

/* content side */
.ab-invis-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg,#ede7f6,#d1c4e9);
  border: 1px solid #ce93d8;
  color: #4a148c;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 6px 16px;
  border-radius: 50px;
  margin-bottom: 18px;
}
.ab-invis-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.5rem, 2.8vw, 2.1rem);
  font-weight: 800;
  color: var(--text);
  line-height: 1.2;
  margin-bottom: 16px;
}
.ab-invis-title span { color: var(--blue); }

.ab-invis-desc {
  font-size: .9rem;
  color: var(--text-mid);
  line-height: 1.85;
  margin-bottom: 26px;
}
.ab-invis-desc strong { color: var(--blue); }

.ab-invis-features {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 28px;
}
.ab-invis-feat {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  background: var(--sky);
  border: 1px solid var(--border);
  border-radius: 12px;
  transition: all .3s ease;
}
.ab-invis-feat:hover {
  border-color: var(--blue);
  transform: translateX(5px);
  box-shadow: var(--shadow-sm);
}
.ab-invis-feat > i {
  color: var(--blue);
  font-size: 1rem;
  margin-top: 2px;
  flex-shrink: 0;
}
.ab-invis-feat strong { display:block; font-size:.85rem; font-weight:700; color:var(--text); margin-bottom:2px; }
.ab-invis-feat span   { font-size:.76rem; color:var(--text-mid); line-height:1.4; }

.ab-invis-btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  background: var(--blue);
  color: #fff;
  padding: 14px 28px;
  border-radius: 50px;
  font-size: .9rem;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 6px 22px rgba(11,107,206,.3);
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
}
.ab-invis-btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(11,107,206,.4);
  background: var(--blue-dark);
}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .ab-achieve-grid { grid-template-columns:1fr; gap:44px; }
  .ab-achieve-grid .ab-achieve-img-wrap { order:-1; }
  .ab-achieve-img-frame img { height:320px; }
  .ab-invis-grid { grid-template-columns:1fr; gap:44px; }
  .ab-invis-img-frame img { height:340px; }
  .ab-invis-stat-1 { top:-14px; right:10px; }
  .ab-invis-stat-2 { bottom:10px; left:10px; }
  .ab-invis-section::before { display:none; }
}
@media(max-width:600px){
  .ab-achieve-img-frame img { height:240px; }
  .ab-invis-img-frame img { height:260px; }
  .ab-invis-stat { display:none; }
}