/* ══════════════════════════════════════
   DR BHATT'S DENTAL CARE — SHARED CSS
   Salesforce Design System
   ══════════════════════════════════════ */

/* Inter — closest Google Fonts visual match to Salesforce Sans (geometric sans, double-story 'a', clean proportions) */
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,300;0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;0,14..32,800;0,14..32,900;1,14..32,400&display=swap');

:root {
  /* ── SALESFORCE BRAND PALETTE (exact) ── */
  --sf-blue:      #0176D3;   /* Salesforce Blue — true primary */
  --sf-blue-d:    #014486;   /* Salesforce Blue Dark — hover/active */
  --sf-blue-l:    #EAF5FF;   /* Light blue tint — backgrounds */
  --sf-blue-xl:   #F3F8FF;   /* Extra light blue */
  --sf-blue-acc:  #1B96FF;   /* Accent blue — highlights */

  --navy:    #032D60;         /* Salesforce Deep Navy — headings, footer */
  --navy2:   #01172E;         /* Deeper navy — darkest */
  --navy3:   #0B4B98;         /* Mid navy — hover states */

  --blue:    #0176D3;         /* Salesforce Primary Blue */
  --blue-d:  #014486;
  --blue-l:  #EAF5FF;
  --blue-xl: #F3F8FF;
  --blue-acc:#1B96FF;

  --gold:    #FF9900;         /* Orange accent for CTAs */
  --white:   #FFFFFF;
  --grey:    #F3F3F3;         /* Salesforce section bg — neutral cool grey */
  --grey2:   #E5E7EB;
  --border:  #DDDBDA;         /* Salesforce border color */
  --text:    #181818;         /* Near-black — body text */
  --muted:   #3E3E3C;         /* Salesforce body text dark */
  --muted-l: #706E6B;         /* Salesforce muted — lighter */
  --red:     #BA0517;         /* Salesforce error red */

  /* ── SALESFORCE FONT STACK ── */
  --font-family-sans: 'Inter', 'Salesforce Sans', system-ui, -apple-system,
    BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial,
    'Noto Sans', sans-serif;

  --shadow:    0 2px 12px rgba(0,0,0,.08);
  --shadow-md: 0 4px 24px rgba(0,0,0,.10);
  --shadow-lg: 0 8px 40px rgba(0,0,0,.12);
  --shadow-xl: 0 16px 56px rgba(0,0,0,.14);
  --radius:    12px;
  --radius-lg: 16px;
  --radius-sm: 6px;

  /* ── Legacy aliases — keeps other pages working ── */
  --teal:    #0176D3;
  --teal-d:  #014486;
  --teal-l:  #EAF5FF;
  --dark:    #032D60;
  --silver:  #E5E7EB;
  --accent:  #1B96FF;
  --lb-blue: #DDDBDA;
  --lb-blue2: #EAF5FF;
  --off:     #F3F8FF;
  --cream:   #FFFFFF;
  --cream2:  #F8F8F8;
  --beige:   #E5E7EB;
  --beige2:  #F8F8F8;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-family-sans);color:var(--text);background:#EEF5FC;line-height:1.72;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-size:1rem;font-weight:400;}
h1,h2,h3,h4,h5,h6,.sec-title,.hl-title{font-family:var(--font-family-sans);font-weight:800;letter-spacing:-.022em;line-height:1.1;color:var(--navy);}
h4,h5,h6{font-weight:700;letter-spacing:-.014em;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
ul{list-style:none;}
button,input,select,textarea{font-family:inherit;}
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--lb-blue);}
::-webkit-scrollbar-thumb{background:var(--teal);border-radius:4px;}

/* ── CONTAINER ── */
.container{max-width:1160px;margin:0 auto;padding:0 12px;}

.navbar{
  background:#fff;
  border-bottom:1px solid rgba(0,0,0,.1);
  box-shadow:0 1px 8px rgba(0,0,0,.06);
  position:fixed;top:0;left:0;right:0;z-index:9999;transition:all .3s;
}
.btn-book-nav{display:inline-flex;align-items:center;gap:8px;background:#25D366;color:#fff;padding:12px 26px;border-radius:50px;font-size:.95rem;font-weight:700;transition:all .25s;white-space:nowrap;box-shadow:0 2px 12px rgba(37,211,102,.3);}
.btn-book-nav:hover{background:#1ebe5d;transform:translateY(-1px);}
.navbar.scrolled{background:#fff;box-shadow:0 2px 16px rgba(0,0,0,.1);}
.navbar .container{height:76px;display:flex;align-items:center;justify-content:space-between;gap:16px;max-width:1280px;margin:0 auto;padding:0 clamp(20px,3vw,48px);width:100%;}
.logo{display:flex;align-items:center;gap:10px;}
.logo-badge{width:42px;height:42px;background:linear-gradient(135deg,var(--navy),var(--blue));border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.85rem;color:#fff;flex-shrink:0;}
.logo-name{font-weight:800;font-size:1.05rem;color:var(--navy);white-space:nowrap;}
.nav-links{display:flex;align-items:center;gap:4px;}
.nav-links a{color:var(--navy);transition:color .2s;padding:8px 20px;border-radius:0;font-size:1rem;font-weight:700;opacity:.72;background:none;border:none;}
.nav-links a:hover{background:none;color:var(--blue-acc);opacity:1;padding:8px 20px;border:none;}
.nav-links a.active{background:none;color:var(--navy);font-weight:800;opacity:1;padding:8px 20px;border:none;}
.nav-actions{display:flex;align-items:center;gap:10px;flex-shrink:0;margin: left 32px; margin-right: 10px;}
.btn-wa-nav{
  display:inline-flex;align-items:center;gap:7px;
  background:#25D366;color:#fff;padding:9px 18px;border-radius:6px;
  font-size:.85rem;font-weight:700;transition:all .25s;white-space:nowrap;
  box-shadow:0 2px 10px rgba(37,211,102,.25);
}
.btn-wa-nav svg{width:16px;height:16px;}
.btn-wa-nav:hover{background:#1ebe5d;transform:translateY(-1px);}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px;}
.hamburger span{display:block;width:24px;height:2.5px;background:var(--navy);border-radius:2px;transition:all .3s;}
.hamburger.open span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

/* ── PAGE HEADER ── */
.page-header{background:linear-gradient(135deg,var(--navy) 0%,var(--navy3) 100%);padding:120px 0 52px;text-align:center;}
.page-header .tag,.tag{display:inline-block;background:rgba(1,118,211,.2);color:#6FC7FF;padding:4px 14px;border-radius:4px;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px;}
.page-header h1{font-size:clamp(2.2rem,5vw,3.5rem);font-weight:900;color:#fff;margin-bottom:12px;}
.page-header p{font-size:.95rem;color:rgba(255,255,255,.6);max-width:520px;margin:0 auto;}

/* ── SECTIONS ── */
.section{padding:96px 0;}
.section-white{background:#fff;}
.section-alt{background:#F3F3F3;}
.section-dark{background:var(--navy);}
.sec-tag,.sec-eyebrow{
  display:inline-block;background:rgba(1,118,211,.09);color:var(--blue);
  padding:5px 16px;border-radius:4px;font-size:.82rem;font-weight:800;
  letter-spacing:.14em;text-transform:uppercase;margin-bottom:20px;
  border:1px solid rgba(1,118,211,.18);
}
.sec-title{
  font-size:clamp(3.2rem,5.5vw,5rem);
  font-weight:900;color:var(--navy);
  margin-bottom:20px;line-height:1.02;
  letter-spacing:-.04em;
}
.sec-title em{color:var(--blue);font-style:normal;}
.sec-sub{font-size:1.18rem;color:var(--muted-l);max-width:640px;line-height:1.82;font-weight:400;}
.sec-sub-center{margin:0 auto;text-align:center;}
.text-center{text-align:center;}
.text-center .sec-sub{margin:0 auto;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:6px;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .25s;border:none;letter-spacing:.01em;}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 2px 10px rgba(1,118,211,.25);}
.btn-primary:hover{background:var(--navy);transform:translateY(-2px);box-shadow:0 6px 20px rgba(3,45,96,.35);}
.btn-outline{background:transparent;color:var(--blue);border:1.5px solid var(--blue);border-radius:6px;}
.btn-outline:hover{background:var(--navy);color:#fff;border-color:var(--navy);transform:translateY(-1px);}
.btn-navy{background:var(--blue);color:#fff;border-radius:6px;box-shadow:0 2px 10px rgba(1,118,211,.25);}
.btn-navy:hover{background:var(--navy);transform:translateY(-2px);box-shadow:0 6px 20px rgba(3,45,96,.35);}
.btn-wa{background:#25D366;color:#fff;box-shadow:0 2px 10px rgba(37,211,102,.3);border-radius:6px;}
.btn-wa:hover{background:#1ebe5d;transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,211,102,.4);}
.btn-white{background:#fff;color:var(--blue);border-radius:6px;box-shadow:0 2px 10px rgba(0,0,0,.1);}
.btn-white:hover{background:var(--blue-l);transform:translateY(-1px);}
.btn-lg{padding:16px 36px;font-size:1rem;}
.btn-full{width:100%;justify-content:center;}

.hero-cta-wrap {
  display: flex;
  gap: 12px;
  margin-top: 20px;
}


/* ── HERO CTA BUTTONS ── */
.hl-hero-btns{
  display:flex;gap:14px;
  margin:20px 0 24px;
  flex-wrap:wrap;
}
.hl-btn-wa,.hl-btn-call{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 26px;border-radius:6px;
  font-size:.93rem;font-weight:700;
  cursor:pointer;transition:all .25s;
  text-decoration:none;flex:1;
  justify-content:center;
  min-width:160px;
}
.hl-btn-wa{
  background:#25D366;color:#fff;
  box-shadow:0 2px 12px rgba(37,211,102,.35);
}
.hl-btn-wa:hover{background:#1ebe5d;transform:translateY(-2px);box-shadow:0 6px 20px rgba(37,211,102,.45);}
.hl-btn-call{
  background:var(--blue);
  color:#fff;
  border:2px solid transparent;
  box-shadow:0 2px 12px rgba(1,118,211,.25);
}
.hl-btn-call:hover{background:var(--navy);transform:translateY(-2px);border-color:transparent;}

@media(max-width:640px){
  .hl-hero-btns{flex-direction:row;gap:10px;}
  .hl-btn-wa,.hl-btn-call{min-width:0;flex:1;padding:13px 12px;font-size:.82rem;}
}


.hero-cta-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  padding: 14px;
  border-radius: 12px;
  text-decoration: none;
  font-weight: 600;
  font-size: 15px;

  transition: all 0.3s ease;
}

/* WhatsApp */
.hero-cta-whatsapp {
  background: linear-gradient(135deg, #25d366, #1ebe5d);
  color: white;
}

/* Call */
.hero-cta-call {
  background: #ffffff;
  color: #0b1f3a;
  border: 1px solid #ddd;
}

/* Hover */
.hero-cta-btn:hover {
  transform: translateY(-2px);
}

@media (max-width: 400px) {
  .hero-cta-btn {
    font-size: 13px;
    padding: 12px;
  }
}

/* ── FORMS ── */
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-label{font-size:.8rem;font-weight:600;color:var(--navy);}
.form-label span{color:var(--red);}
.form-control{border:1.5px solid var(--border);border-radius:10px;padding:11px 14px;font-size:.87rem;color:var(--text);background:var(--cream);outline:none;transition:border-color .2s;width:100%;}
.form-control:focus{border-color:var(--teal);}
.form-control.error{border-color:var(--red);}
select.form-control{cursor:pointer;}
textarea.form-control{resize:vertical;}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form-full{grid-column:1/-1;}

/* ── HERO ── */
.hero{background:#fff;padding:0;}
.hero .container { max-width:none; padding:0; }
.hero-bg{
  position:relative;
  background:#F0F6FF;
  background-image:
    radial-gradient(ellipse 60% 50% at 95% 5%,  rgba(1,118,211,.12)  0%, transparent 65%),
    radial-gradient(ellipse 45% 40% at 3%  95%,  rgba(3,45,96,.08)    0%, transparent 55%),
    radial-gradient(ellipse 40% 35% at 50% 50%,  rgba(255,255,255,.60) 0%, transparent 70%);
  min-height:85vh;
  min-height:85svh;
  display:flex;
  align-items:center;
  padding-top:70px;
  overflow:hidden;
  border-bottom:1px solid rgba(1,118,211,.12);
}

/* Hero grid */
.hero-grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:40px;
  align-items:stretch;
  padding:32px 0 40px clamp(20px,4vw,60px);
  width:100%;
}
.clinic-photo-card{display:none;}

/* Left side */
.hero-left{display:flex;flex-direction:column;justify-content:center;}

/* Location pill */
.hl-location{
  display:inline-flex;align-items:center;gap:8px;
  font-size:.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:var(--blue);margin-bottom:22px;
  background:var(--blue-xl);
  border:1.5px solid rgba(1,118,211,.25);
  padding:7px 16px;border-radius:6px;
  width:fit-content;
  backdrop-filter:blur(8px);
  box-shadow:0 2px 8px rgba(1,118,211,.12);
}
.hl-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--blue);flex-shrink:0;
  box-shadow:0 0 6px var(--blue-acc);
}

/* Title */
.hl-title{
  font-size:clamp(3.0rem,5.2vw,4.8rem);
  font-weight:900;color:var(--navy);
  line-height:1.00;letter-spacing:-0.032em;
  margin-bottom:20px;
}
.hl-title em{
  color:var(--blue);font-style:normal;
}

/* Subtext */
.hl-sub{
  font-size:.93rem;color:var(--muted);
  line-height:1.8;margin-bottom:24px;max-width:440px;
}

/* Checklist */
.hl-checks{
  list-style:none;padding:0;margin:0 0 28px 0;
  display:grid;grid-template-columns:1fr 1fr;
  gap:10px 20px;
}
.hl-checks li{
  display:flex;align-items:center;gap:8px;
  font-size:.84rem;font-weight:600;color:var(--text);
}
.hl-checks li svg{width:15px;height:15px;flex-shrink:0;}

/* Stats box — elevated white cards */
.hl-stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:12px;
  background:transparent;
  border:none;
  border-radius:0;
  overflow:visible;
}
.hl-stat{
  background:#ffffff;
  border-radius:8px;
  padding:20px 14px;
  text-align:center;
  transition:all .28s;
  box-shadow:0 2px 12px rgba(0,0,0,.07);
  border:1px solid rgba(0,0,0,.08);
  backdrop-filter:none;
}
.hl-stat:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(180,120,0,.16);}
.hl-stat strong{
  display:block;
  font-size:clamp(1.4rem,2.4vw,1.9rem);
  font-weight:900;color:var(--blue);
  line-height:1;margin-bottom:5px;
  letter-spacing:-.025em;
}
.hl-stat span{
  font-size:.70rem;color:var(--muted-l);
  font-weight:700;line-height:1.35;
  text-transform:uppercase;letter-spacing:.04em;
}

/* Clinic photo card below text */
.clinic-photo-card{
  border-radius:var(--radius-lg);overflow:hidden;
  background:linear-gradient(135deg,rgba(1,118,211,.15),rgba(3,45,96,.5));
  border:1px solid rgba(255,255,255,.15);
  aspect-ratio:16/7;
  display:flex;align-items:center;justify-content:center;
  font-size:4rem;
  margin-top:28px;
  position:relative;
  backdrop-filter:blur(4px);
}
.clinic-photo-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border-radius:var(--radius-lg);}
.clinic-photo-card-label{
  position:absolute;bottom:12px;left:14px;
  background:rgba(3,45,96,.8);color:#fff;
  font-size:.75rem;font-weight:700;
  padding:5px 12px;border-radius:6px;
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.15);
}



/* Right contact card */
.hero-contact-card{
  background:var(--lb-blue2);
  background-image:
    linear-gradient(135deg, rgba(1,118,211,.35) 0%, rgba(3,45,96,.25) 50%, rgba(1,118,211,.20) 100%),
    url('assets/clinic-interior.jpeg');
  background-size:cover;
  background-position:center;
  border-radius:16px 0 0 16px;
  padding:0;
  box-shadow:0 24px 64px rgba(1,118,211,.25), 0 0 0 2px rgba(1,118,211,.20);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  position:relative;
  overflow:hidden;
  min-height:520px;
  align-self:stretch;
}
/* subtle top accent line */
.hero-contact-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue),var(--navy));
}
.hero-contact-card h3{font-size:1.2rem;font-weight:900;color:var(--navy);margin-bottom:6px;}
.hero-contact-card>p{font-size:.85rem;color:var(--muted);margin-bottom:24px;line-height:1.6;}

/* Contact options */
.contact-option{
  display:flex;align-items:center;gap:16px;
  padding:18px 20px;border-radius:8px;
  border:2px solid var(--border);
  margin-bottom:12px;
  text-decoration:none;
  transition:all .25s;
  cursor:pointer;
}
.contact-option:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(3,45,96,.1);}
.contact-option-wa{background:linear-gradient(135deg,#e7fdf0,#d4f8e4);border-color:#25D366;}
.contact-option-wa:hover{border-color:#25D366;box-shadow:0 6px 20px rgba(37,211,102,.25);}
.contact-option-call{background:linear-gradient(135deg,#E6F1FB,#C5DDF7);border-color:#0176D3;}
.contact-option-call:hover{border-color:#0176D3;box-shadow:0 6px 20px rgba(1,118,211,.2);}
.contact-option-email{background:linear-gradient(135deg,#fef9f0,#fef3c7);border-color:#F59E0B;}
.contact-option-email:hover{border-color:#F59E0B;box-shadow:0 6px 20px rgba(245,158,11,.2);}
.contact-option-icon{width:50px;height:50px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.contact-option-wa .contact-option-icon{background:#25D366;}
.contact-option-call .contact-option-icon{background:#0176D3;}
.contact-option-email .contact-option-icon{background:#F59E0B;}
.contact-option-text strong{display:block;font-size:.95rem;font-weight:800;color:var(--navy);margin-bottom:2px;}
.contact-option-text span{font-size:.8rem;color:var(--muted);font-weight:500;}

.hours-badge{
  display:flex;align-items:center;gap:10px;
  background:var(--off);border:1px solid var(--border);
  border-radius:8px;padding:14px 16px;margin-top:4px;
}
.hours-badge svg{width:18px;height:18px;color:var(--teal);flex-shrink:0;}
.hours-badge span{font-size:.82rem;color:var(--navy);font-weight:600;line-height:1.4;}

/* ── CONTACT QUICK ── */
.contact-quick{background:var(--white);padding:64px 0;}
.contact-options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:40px;max-width:600px;margin-left:auto;margin-right:auto;}
.contact-options-grid .contact-option{margin-bottom:0;}
.contact-options-grid .hours-badge{grid-column:1/-1;margin-top:0;}

/* ── WHATSAPP BANNER ── */

/* ── HERO PHOTO RIGHT ── */
.hero-photo-right{
  display:flex;align-items:center;justify-content:center;
}
.hero-photo-frame{
  position:relative;
  width:100%;
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 32px 80px rgba(3,45,96,.32), 0 0 0 1px rgba(255,255,255,.15);
  aspect-ratio:4/5;
  background:linear-gradient(135deg,rgba(1,118,211,.2),rgba(3,45,96,.5));
  display:flex;align-items:center;justify-content:center;font-size:6rem;
}
.hero-photo-frame img{
  width:100%;height:100%;object-fit:cover;
  display:block;border-radius:20px;
  position:absolute;inset:0;
}
.hero-photo-badge{
  position:absolute;bottom:18px;left:16px;
  background:rgba(255,255,255,.97);
  border-radius:12px;padding:12px 16px;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 8px 24px rgba(3,45,96,.2);
  max-width:calc(100% - 32px);
}
.hero-photo-badge-dot{
  width:10px;height:10px;border-radius:50%;
  background:#25D366;flex-shrink:0;
  box-shadow:0 0 8px rgba(37,211,102,.6);
  animation:pulse-green 2s infinite;
}
@keyframes pulse-green{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.7;transform:scale(1.2);}}
.hero-photo-badge-text strong{
  display:block;font-size:.8rem;font-weight:800;color:var(--navy);line-height:1.2;
}
.hero-photo-badge-text span{font-size:.7rem;color:#5A6A85;font-weight:500;}
.hero-photo-rating{
  position:absolute;top:16px;right:16px;
  background:var(--navy);color:#fff;
  border-radius:50px;padding:7px 14px;
  font-size:.75rem;font-weight:800;
  display:flex;align-items:center;gap:5px;
  box-shadow:0 4px 16px rgba(10,31,68,.4);
}

/* ── CONTACT QUICK SECTION ── */
.contact-quick{
  background:#fff;
  padding:72px 0 64px;
  border-bottom:1px solid #E8EEF8;
  margin-top:0;
}
.contact-quick-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
  max-width:1180px;
  margin:36px auto 0;
  padding: 0 16px;
}
.contact-quick-note{
  margin-top:22px;
  text-align:center;
}
.contact-quick-note a{
  color:var(--navy);
  font-weight:700;
  font-size:.95rem;
  text-decoration:none;
  border-bottom:1px solid rgba(3,45,96,.15);
  padding-bottom:2px;
}
.contact-quick-note a:hover{color:var(--teal);border-bottom-color:var(--teal);}
.cq-card{
  background:#fff;
  border:1px solid rgba(0,0,0,.09);
  border-radius:12px;
  padding:28px 24px;
  text-align:center;
  transition:all .3s;
  box-shadow:0 2px 14px rgba(0,0,0,.07);
  min-height:280px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.cq-card:hover:not(:has(.cq-btn:hover)){box-shadow:0 8px 32px rgba(0,0,0,.13);transform:none;border-width:2px;}
.cq-card:has(.cq-btn:hover){box-shadow:0 2px 14px rgba(0,0,0,.07) !important;border-width:1px !important;}
.cq-card-wa:hover:not(:has(.cq-btn:hover))   { border-color:#25D366; box-shadow:0 8px 32px rgba(37,211,102,.18); }
.cq-card-call:hover:not(:has(.cq-btn:hover)) { border-color:var(--blue); box-shadow:0 8px 32px rgba(1,118,211,.18); }
.cq-card-email:hover:not(:has(.cq-btn:hover)){ border-color:var(--navy); box-shadow:0 8px 32px rgba(3,45,96,.15); }
.cq-icon{
  width:56px;height:56px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;
  font-size:1.2rem;
}
.cq-icon-wa{background:rgba(37,211,102,.10);color:#25D366;}
.cq-icon-call{background:rgba(1,118,211,.10);color:var(--blue);}
.cq-icon-email{background:rgba(3,45,96,.07);color:var(--navy);}
.cq-card h3{font-size:1.22rem;font-weight:800;color:var(--navy);margin-bottom:8px;transition:color .2s;}
.cq-card:hover:not(:has(.cq-btn:hover)) h3{color:var(--blue);}
.cq-card:has(.cq-btn:hover) h3{color:var(--navy);}
.cq-card p{font-size:.95rem;color:var(--muted-l);margin-bottom:20px;font-weight:500;}
.cq-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:11px 22px;border-radius:6px;
  font-size:.88rem;font-weight:700;
  transition:all .25s;text-decoration:none;
  width:100%;
  margin:0;
}
.cq-btn-wa{background:#25D366;color:#fff;box-shadow:0 2px 10px rgba(37,211,102,.2);}
.cq-btn-wa:hover{background:#1ebe5d;transform:translateY(-1px);}
.cq-btn-call{background:var(--blue);color:#fff;box-shadow:0 2px 10px rgba(1,118,211,.2);}
.cq-btn-call:hover{background:var(--navy);transform:translateY(-1px);}
.cq-btn-email{background:var(--navy);color:#fff;box-shadow:0 2px 10px rgba(3,45,96,.18);}
.cq-btn-email:hover{background:var(--navy2);transform:translateY(-1px);}

@media(max-width:768px){
  .contact-quick-grid{grid-template-columns:1fr;}
  .hero-grid{grid-template-columns:1fr !important;}
}

.wa-banner{background:#F3F3F3;padding:52px 0;border-top:1px solid rgba(0,0,0,.07);border-bottom:1px solid rgba(0,0,0,.07);}
.wa-banner-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;}
.wa-banner h2{font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:900;color:var(--navy);margin-bottom:6px;}
.wa-banner p{color:var(--muted-l);font-size:1.05rem;max-width:480px;}
.wa-banner-btns{display:flex;gap:12px;flex-wrap:wrap;align-items:center;flex-shrink:0;}
.wa-big-btn{display:flex;align-items:center;gap:12px;background:#25D366;color:#fff;padding:14px 26px;border-radius:6px;font-size:.97rem;font-weight:700;box-shadow:0 2px 12px rgba(37,211,102,.3);transition:all .25s;white-space:nowrap;}
.wa-big-btn:hover{background:#1ebe5d;transform:translateY(-1px);}
.wa-big-btn svg{width:22px;height:22px;}
.call-btn-outline{display:flex;align-items:center;gap:10px;color:var(--blue);border:1.5px solid var(--blue);padding:13px 22px;border-radius:6px;font-size:.93rem;font-weight:700;transition:all .25s;white-space:nowrap;}
.call-btn-outline:hover{background:var(--navy);color:#fff;border-color:var(--navy);}

/* ── SERVICES ── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px;}
.service-card{background:#fff;border:1px solid rgba(0,0,0,.09);border-radius:12px;padding:0;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.07);}
.service-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--navy));transform:scaleX(0);transition:transform .3s;transform-origin:left;}
.service-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.14);transform:translateY(-5px);}
.service-card:hover::after{transform:scaleX(1);}
.svc-card-img{width:100%;height:200px;object-fit:cover;display:block;transition:transform .4s ease;}
.service-card:hover .svc-card-img{transform:scale(1.04);}
.service-card-body{padding:22px 24px 26px;background:#fff;}
.svc-icon{width:44px;height:44px;border-radius:8px;background:var(--blue-l);display:flex;align-items:center;justify-content:center;margin-bottom:14px;border:1px solid rgba(1,118,211,.15);}
.svc-icon svg{width:22px;height:22px;stroke:var(--blue);}
.service-card h3{font-size:.97rem;font-weight:800;color:var(--navy);margin-bottom:8px;}
.service-card p{font-size:.82rem;color:var(--muted-l);line-height:1.7;}

/* ── WHY CHOOSE US — REFERENCE IMAGE STYLE ── */
.why-section-bg {
  background: #EEF5FC;
  padding: 96px 0;
  position: relative;
  overflow: hidden;
  border-top: 1px solid rgba(1,118,211,.10);
  border-bottom: 1px solid rgba(1,118,211,.10);
}
.why-section-bg::before {
  content: '';
  position: absolute;
  top: -80px; right: -80px;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(1,118,211,.18) 0%, transparent 70%);
  pointer-events: none;
}
.why-section-bg::after {
  content: '';
  position: absolute;
  bottom: -60px; left: -60px;
  width: 400px; height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(27,150,255,.10) 0%, transparent 70%);
  pointer-events: none;
}

/* Hub layout: 3 left | center photo | 3 right */
.why-premium-layout {
  display: grid;
  grid-template-columns: 1fr 360px 1fr;
  gap: 48px;
  align-items: center;
  margin-top: 56px;
  position: relative;
  z-index: 1;
}
.why-col {
  display: flex;
  flex-direction: column;
  gap: 32px;
}

/* ── Why card — icon left, title, description (same direction both cols) ── */
.why-pcard {
  background: transparent;
  border-radius: 0;
  padding: 0;
  display: flex;
  align-items: flex-start;
  gap: 18px;
  box-shadow: none;
  border: none;
  transition: none;
  position: relative;
  overflow: visible;
}
.why-pcard::before { display: none; }
.why-pcard:hover {
  transform: none;
  box-shadow: none;
  border-color: transparent;
  background: transparent;
}

/* Icon box — circular, on dark navy bg */
.why-pcard-icon {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: rgba(255,255,255,.10);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  border: 2px solid var(--blue);
  transition: background .25s;
}
.why-pcard-icon svg {
  width: 24px;
  height: 24px;
  stroke: var(--blue);
}
.why-pcard:hover .why-pcard-icon {
  background: var(--blue-l);
  border-color: var(--blue);
}

.why-pcard-body h4 {
  font-size: 1.02rem;
  font-weight: 800;
  color: var(--navy);
  margin-bottom: 6px;
  letter-spacing: -.015em;
}
.why-pcard-body p {
  font-size: .88rem;
  color: var(--muted-l);
  line-height: 1.72;
}

/* Right column — same direction as left (icon left, text right) */
.why-col-right {
  align-items: flex-start;
}
.why-col-right .why-pcard {
  flex-direction: row;
  text-align: left;
}
.why-col-right .why-pcard::before {
  display: none;
}

/* Why section headings — on light blue bg */
.why-section-bg .sec-eyebrow {
  background: rgba(1,118,211,.09);
  color: var(--blue);
  border-color: rgba(1,118,211,.18);
}
.why-section-bg .sec-title { color: var(--navy); }
.why-section-bg .sec-title em { color: var(--blue); }
.why-section-bg .sec-sub { color: var(--muted-l); }

/* Center photo */
.why-center-photo {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
}
.why-photo-ring {
  width: 300px;
  height: 300px;
  border-radius: 50%;
  padding: 8px;
  background: linear-gradient(135deg, var(--blue-acc) 0%, var(--blue) 50%, var(--navy) 100%);
  box-shadow: 0 16px 56px rgba(37,99,235,.28);
  position: relative;
}
.why-photo-ring::before {
  content: '';
  position: absolute;
  inset: -10px;
  border-radius: 50%;
  border: 2px dashed rgba(96,165,250,.4);
  animation: rotate-ring 20s linear infinite;
}
@keyframes rotate-ring {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
.why-photo-inner {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--lb-blue2), var(--beige2));
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border: 4px solid #fff;
}
.why-photo-inner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}
.why-photo-placeholder {
  font-size: 5rem;
  opacity: .5;
}
/* Decorative dots around photo */
.why-dot-tl, .why-dot-tr, .why-dot-bl, .why-dot-br {
  position: absolute;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--blue-acc);
}
.why-dot-tl { top: 20px; left: 10px; }
.why-dot-tr { top: 20px; right: 10px; background: var(--blue); }
.why-dot-bl { bottom: 20px; left: 10px; background: var(--blue); }
.why-dot-br { bottom: 20px; right: 10px; }

/* Center label below photo */
.why-photo-label {
  margin-top: 22px;
  text-align: center;
}
.why-photo-label strong {
  display: block;
  font-size: 1.05rem;
  font-weight: 900;
  color: #ffffff;
  letter-spacing: -.02em;
}
.why-photo-label span {
  font-size: .8rem;
  color: rgba(255,255,255,.55);
  font-weight: 600;
}

@media(max-width: 900px) {
  .why-premium-layout {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .why-center-photo {
    order: -1;
  }
  .why-photo-ring { width: 220px; height: 220px; }
}

/* Keep old .why-grid and .why-card for other pages */
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px;}
.why-card{background:#fff;border-radius:var(--radius);border:none;padding:28px 24px;transition:all .3s;border-top:3px solid var(--teal);box-shadow:0 4px 24px rgba(27,58,107,.1);}
.why-card:hover{box-shadow:0 12px 40px rgba(27,58,107,.18);transform:translateY(-4px);}
.why-num{font-size:2.2rem;font-weight:900;color:var(--teal);opacity:.4;line-height:1;margin-bottom:10px;}
.why-card h4{font-size:.95rem;font-weight:800;color:var(--navy);margin-bottom:8px;}
.why-card p{font-size:.83rem;color:var(--muted);line-height:1.7;}

/* ── DOCTOR ── */
.doctor-grid{display:grid;grid-template-columns:380px 1fr;gap:56px;align-items:center;}
.doctor-img-wrap{position:relative;}
.doctor-img{width:100%;aspect-ratio:3/4;border-radius:12px;overflow:hidden;background:linear-gradient(135deg,var(--navy),var(--teal));display:flex;align-items:center;justify-content:center;font-size:8rem;}
.doctor-img img{width:100%;height:100%;object-fit:cover;}
.doctor-badge{position:absolute;bottom:-16px;right:-16px;background:var(--blue);border-radius:8px;padding:14px 18px;display:flex;align-items:center;gap:10px;box-shadow:0 4px 20px rgba(1,118,211,.3);}
.doctor-badge strong{font-size:1.5rem;font-weight:900;color:#fff;line-height:1;}
.doctor-badge span{font-size:.72rem;font-weight:700;color:rgba(255,255,255,.9);line-height:1.3;}
.doctor-info h2,.doctor-title-h2{font-size:clamp(1.5rem,2.5vw,2rem);font-weight:900;color:var(--navy);margin-bottom:4px;}
.doctor-title{font-size:.9rem;color:var(--teal);font-weight:700;margin-bottom:14px;}
.doctor-desc{font-size:.9rem;color:var(--muted);line-height:1.8;margin-bottom:20px;}
.doctor-quals,.qual-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:22px;}
.qual-tag{background:var(--teal-l);border:1px solid rgba(1,118,211,.2);color:var(--navy);font-size:.74rem;font-weight:700;padding:5px 12px;border-radius:6px;}
.doctor-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;}
.doctor-list li{display:flex;align-items:center;gap:10px;font-size:.87rem;color:var(--text);}
.doctor-list li svg{width:16px;height:16px;color:var(--teal);flex-shrink:0;}

/* ── ABOUT ── */
.about-story{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.about-img{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;background:linear-gradient(135deg,var(--navy),var(--teal));display:flex;align-items:center;justify-content:center;font-size:7rem;}
.about-img img{width:100%;height:100%;object-fit:cover;}

/* ── MISSION ── */
.mission-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px;}
.mission-card{background:linear-gradient(135deg,#6D28D9 0%,#7C3AED 50%,#8B5CF6 100%);border-radius:var(--radius);border:none;padding:28px 22px;text-align:center;transition:all .3s;border-top:3px solid rgba(255,255,255,.35);box-shadow:0 4px 24px rgba(109,40,217,.25);}
.mission-card:hover{box-shadow:0 12px 40px rgba(109,40,217,.45);transform:translateY(-4px);}
.mission-icon{font-size:2.2rem;margin-bottom:14px;}
.mission-card h4{font-size:.95rem;font-weight:800;color:#fff;margin-bottom:8px;}
.mission-card p{font-size:.82rem;color:rgba(255,255,255,.82);line-height:1.7;}

/* ── WHY LIST ── */
.why-list{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px;}
.why-list-item{background:linear-gradient(135deg,#0D2251 0%,#1A3478 50%,#1E40AF 100%);border:none;border-radius:var(--radius);padding:22px 24px;transition:all .3s;box-shadow:0 4px 24px rgba(13,34,81,.3);}
.why-list-item:hover{box-shadow:0 12px 36px rgba(13,34,81,.5);transform:translateY(-3px);}
.why-list-item h4{font-size:.95rem;font-weight:800;color:#fff;margin-bottom:8px;}
.why-list-item p{font-size:.83rem;color:rgba(255,255,255,.75);line-height:1.7;}

/* ── TESTIMONIALS ── */
.testi-section{background:#F3F3F3;padding:80px 0 0;border-top:1px solid rgba(0,0,0,.07);}
.testi-section .sec-eyebrow,.testi-section .sec-tag{background:rgba(1,118,211,.09);color:var(--blue);border-color:rgba(1,118,211,.18);}
.testi-section .sec-title{color:var(--navy);}
.testi-section .sec-sub{color:var(--muted-l);}
.elfsight-wrap{padding:40px 0 0;}

/* ── GOOGLE RATING ── */
.google-rating-section{background:#F3F3F3;padding:0 0 64px;}
.google-rating-card{background:#fff;border:1px solid rgba(0,0,0,.09);border-radius:12px;padding:36px 44px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;box-shadow:0 2px 14px rgba(0,0,0,.07);}
.google-rating-left{display:flex;align-items:center;gap:20px;}
.google-logo-badge{width:60px;height:60px;border-radius:12px;background:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 12px rgba(0,0,0,.12);font-size:2rem;border:1px solid rgba(0,0,0,.07);}
.google-rating-text h3{font-size:1.25rem;font-weight:900;color:var(--navy);margin-bottom:4px;}
.google-rating-text p{font-size:.88rem;color:var(--muted-l);}
.google-stars{display:flex;gap:3px;margin-top:6px;}
.google-stars span{color:#FBBC05;font-size:1.2rem;}
.rate-google-btn{display:flex;align-items:center;gap:10px;background:var(--blue);color:#fff;padding:13px 24px;border-radius:6px;font-size:.92rem;font-weight:800;box-shadow:0 2px 12px rgba(1,118,211,.25);transition:all .25s;white-space:nowrap;}
.rate-google-btn:hover{background:var(--navy);transform:translateY(-1px);box-shadow:0 6px 20px rgba(3,45,96,.35);}

/* ── EMERGENCY ── */
.emergency-section{background:var(--navy);padding:56px 0;}
.emergency-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap;}
.em-text h2{font-size:clamp(1.8rem,3vw,2.6rem);font-weight:900;color:#fff;margin-bottom:8px;letter-spacing:-.02em;}
.em-text p{color:rgba(255,255,255,.7);font-size:.9rem;max-width:480px;}
.em-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}
.em-phone{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);border-radius:8px;padding:14px 22px;color:#fff;transition:all .2s;}
.em-phone:hover{background:rgba(255,255,255,.18);}
.em-phone strong{display:block;font-size:1.1rem;font-weight:800;}
.em-phone small{font-size:.73rem;opacity:.75;}
.em-wa-btn{display:flex;align-items:center;gap:8px;background:#25D366;color:#fff;padding:14px 22px;border-radius:6px;font-weight:700;font-size:.9rem;transition:all .2s;box-shadow:0 2px 10px rgba(37,211,102,.3);}
.em-wa-btn:hover{background:#1ebe5d;}

/* ── FAQ ── */
.faq-list{max-width:780px;margin:48px auto 0;}
.faq-item{border:1px solid rgba(0,0,0,.09);border-radius:8px;margin-bottom:8px;overflow:hidden;background:#fff;transition:border-color .25s,box-shadow .25s;}
.faq-item:hover{border-color:rgba(1,118,211,.28);box-shadow:0 2px 12px rgba(0,0,0,.07);}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;cursor:pointer;gap:16px;}
.faq-q h4{font-size:1.08rem;font-weight:700;color:var(--navy);transition:color .2s;}
.faq-item:hover .faq-q h4,.faq-item.open .faq-q h4{color:var(--blue);}
.faq-toggle{width:26px;height:26px;border-radius:50%;background:var(--blue-l);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:var(--blue);flex-shrink:0;transition:all .3s;}
.faq-item.open .faq-toggle{background:var(--blue);color:#fff;transform:rotate(45deg);}
.faq-item.open{border-color:rgba(1,118,211,.35);box-shadow:0 4px 16px rgba(1,118,211,.1);}
.faq-a{display:none;padding:0 22px 18px;font-size:.98rem;color:var(--muted-l);line-height:1.8;border-top:1px solid rgba(1,118,211,.1);padding-top:14px;}
.faq-item.open .faq-a{display:block;}

/* ── GALLERY ── */
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:40px;}
.gallery-item{border-radius:var(--radius);overflow:hidden;aspect-ratio:1;background:linear-gradient(135deg,var(--navy),var(--teal));display:flex;align-items:center;justify-content:center;font-size:3.5rem;position:relative;cursor:pointer;}
.gallery-item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.gallery-overlay{position:absolute;inset:0;background:rgba(11,31,58,.6);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;}
.gallery-overlay span{color:#fff;font-size:.85rem;font-weight:700;border:2px solid #fff;padding:6px 16px;border-radius:50px;}
.gallery-item:hover .gallery-overlay{opacity:1;}
.gallery-caption{position:absolute;bottom:0;left:0;right:0;background:rgba(11,31,58,.85);color:#fff;font-size:.75rem;font-weight:600;padding:8px 12px;text-align:center;opacity:0;transition:opacity .3s;}
.gallery-item:hover .gallery-caption{opacity:1;}

/* ── GALLERY SCROLL ── */
.gal-scroll-wrap{position:relative;}
.gal-scroll{
  display:flex;gap:20px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:8px 4px 20px;
  scrollbar-width:thin;
  scrollbar-color:var(--teal) transparent;
}
.gal-scroll::-webkit-scrollbar{height:4px;}
.gal-scroll::-webkit-scrollbar-thumb{background:var(--teal);border-radius:4px;}

/* Gallery card */
.gal-card{
  flex:0 0 300px;
  scroll-snap-align:start;
  border-radius:16px;
  overflow:hidden;
  cursor:pointer;
  background:linear-gradient(135deg,var(--navy),var(--teal));
  transition:all .3s;
  border:2px solid transparent;
  display:flex;
  flex-direction:column;
}
.gal-card:hover{transform:translateY(-4px);border-color:var(--teal);box-shadow:0 8px 28px rgba(10,181,160,.2);}
.gal-card-img{
  position:relative;
  height:230px;
  overflow:hidden;
  flex-shrink:0;
}
.gal-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.gal-card:hover .gal-card-img img{transform:scale(1.06);}
.gal-card-fallback{
  display:none;position:absolute;inset:0;
  align-items:center;justify-content:center;
  font-size:3.5rem;
  background:linear-gradient(135deg,var(--navy),var(--teal));
}
.gal-card-tag{
  position:absolute;top:12px;left:12px;
  background:var(--teal);color:#fff;
  font-size:.64rem;font-weight:700;
  padding:3px 10px;border-radius:20px;
  letter-spacing:.07em;text-transform:uppercase;
}
.gal-card-body{
  padding:14px 16px;
  background:#fff;
  flex:1;
}
.gal-card-body h3{
  font-size:.88rem;font-weight:700;
  color:var(--navy);margin:0;line-height:1.3;
}

/* Scroll arrows */
.gal-scroll-arrow{
  position:absolute;top:44%;transform:translateY(-50%);
  width:38px;height:38px;border-radius:50%;
  background:#fff;border:1px solid var(--border);
  box-shadow:0 2px 12px rgba(0,0,0,.12);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:10;transition:all .2s;
}
.gal-scroll-arrow svg{width:16px;height:16px;stroke:var(--navy);}
.gal-scroll-arrow:hover{background:var(--teal);border-color:var(--teal);}
.gal-scroll-arrow:hover svg{stroke:#fff;}
.gal-arrow-left{left:-16px;}
.gal-arrow-right{right:-16px;}

/* Gallery page grid — same card but in a proper grid */
.gal-page-grid{
  display:flex;
  gap:20px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:8px 4px 20px;
  scrollbar-width:thin;
  scrollbar-color:var(--teal) transparent;
  margin-top:0;
}
.gal-page-grid::-webkit-scrollbar{height:4px;}
.gal-page-grid::-webkit-scrollbar-thumb{background:var(--teal);border-radius:4px;}
.gal-page-grid .gal-card{flex:0 0 320px;scroll-snap-align:start;}


@media(max-width:640px){
  .gal-page-grid .gal-card{flex:0 0 82vw;max-width:340px;}
  .gal-page-grid .gal-card-img{height:260px;}
  .gal-card{
    flex:0 0 85vw;
  }
  .gal-card-img{
    height:260px;
  }
  .gal-scroll{
  padding-left:16px;
  padding:8px 4px 20px;
}
  .gal-scroll-arrow{display:none;}
}

/* ── GALLERY LIGHTBOX ── */
#lb-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.92);z-index:99999;
  align-items:center;justify-content:center;
  padding:16px;
  animation:lbFadeIn .25s ease;
}
#lb-overlay.lb-open{display:flex;}
@keyframes lbFadeIn{from{opacity:0}to{opacity:1}}

#lb-box{
  position:relative;display:flex;flex-direction:column;
  align-items:center;width:100%;max-width:860px;
  max-height:95vh;
}

#lb-close{
  position:absolute;top:-14px;right:-14px;z-index:2;
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.15);border:none;color:#fff;
  font-size:1.1rem;cursor:pointer;display:flex;
  align-items:center;justify-content:center;
  transition:background .2s;
}
#lb-close:hover{background:rgba(255,255,255,.35);}

#lb-stage{
  display:flex;align-items:center;gap:12px;
  width:100%;max-height:70vh;
}

#lb-img-wrap{
  flex:1;display:flex;align-items:center;
  justify-content:center;position:relative;
  min-height:200px;max-height:70vh;
}

#lb-img{
  max-width:100%;max-height:70vh;
  object-fit:contain;border-radius:10px;
  display:block;
}

#lb-emoji{
  display:none;font-size:6rem;
  align-items:center;justify-content:center;
  width:100%;min-height:200px;
}

#lb-prev,#lb-next{
  flex-shrink:0;width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.15);border:none;color:#fff;
  font-size:1.8rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;
}
#lb-prev:hover,#lb-next:hover{background:rgba(255,255,255,.35);}

#lb-caption{
  color:#fff;font-size:.92rem;font-weight:600;
  margin:10px 0 4px;text-align:center;
}
#lb-counter{
  color:rgba(255,255,255,.5);font-size:.75rem;
  margin-bottom:10px;
}

/* Thumbnail strip */
#lb-thumbs{
  display:flex;gap:8px;flex-wrap:wrap;justify-content:center;
  max-width:100%;
}
.lb-thumb{
  width:58px;height:58px;border-radius:8px;
  background-size:cover;background-position:center;
  background-color:rgba(255,255,255,.1);
  cursor:pointer;border:2px solid transparent;
  transition:border-color .2s,opacity .2s;
  opacity:.55;flex-shrink:0;
}
.lb-thumb:hover{opacity:.85;}
.lb-thumb-active{opacity:1;border-color:#fff;}

@media(max-width:600px){
  #lb-prev,#lb-next{width:34px;height:34px;font-size:1.4rem;}
  #lb-close{top:-10px;right:-6px;}
  .lb-thumb{width:46px;height:46px;}
}

/* ── CONTACT ── */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.contact-form-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);padding:36px;box-shadow:var(--shadow-lg);}
.contact-form-card h3{font-size:1.2rem;font-weight:800;color:var(--navy);margin-bottom:4px;}
.contact-form-card>p{font-size:.85rem;color:var(--muted);margin-bottom:24px;}
.contact-info-cards{display:flex;flex-direction:column;gap:14px;margin-bottom:24px;}
.ci-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;display:flex;align-items:flex-start;gap:16px;transition:all .3s;}
.ci-card:hover{border-color:var(--teal);box-shadow:var(--shadow);}
.ci-icon{width:44px;height:44px;border-radius:12px;background:var(--teal-l);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ci-icon svg{width:20px;height:20px;color:var(--teal);}
.ci-card h5{font-size:.82rem;font-weight:700;color:var(--navy);margin-bottom:4px;text-transform:uppercase;letter-spacing:.06em;}
.ci-card p{font-size:.85rem;color:var(--muted);line-height:1.65;}
.ci-card a{color:var(--teal);font-weight:600;}
.contact-map{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);}

/* ── APPOINTMENT PAGE ── */
.appt-features{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:48px;}
.appt-feat{text-align:center;padding:28px 20px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all .3s;}
.appt-feat:hover{border-color:var(--teal);box-shadow:var(--shadow);}
.appt-feat-icon{width:56px;height:56px;border-radius:16px;background:var(--teal-l);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;}
.appt-feat-icon svg{width:26px;height:26px;color:var(--teal);}
.appt-feat h4{font-size:.95rem;font-weight:800;color:var(--navy);margin-bottom:6px;}
.appt-feat p{font-size:.83rem;color:var(--muted);line-height:1.65;}
.appt-form-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);padding:40px;box-shadow:var(--shadow-lg);}
.appt-form-card h3{font-size:1.25rem;font-weight:900;color:var(--navy);margin-bottom:4px;}
.appt-form-card>p{font-size:.85rem;color:var(--muted);margin-bottom:28px;}
.appt-help{text-align:center;font-size:.83rem;color:var(--muted);margin-top:16px;}
.appt-help a{color:var(--teal);font-weight:700;}

footer{background:#0A1F44;color:rgba(255,255,255,.7);padding:64px 0 0;}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1.3fr 1.3fr;gap:40px;padding-bottom:48px;}
.footer-brand .logo-name{color:#fff;}
.footer-brand p{font-size:.85rem;color:rgba(255,255,255,.5);line-height:1.75;margin:14px 0 20px;max-width:240px;}
.footer-socials{display:flex;gap:9px;}
.fsoc{width:36px;height:36px;border-radius:6px;background:rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:all .2s;border:1px solid rgba(255,255,255,.12);}
.fsoc:hover{background:var(--blue);border-color:var(--blue);transform:translateY(-2px);}
.footer-col h5{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:rgba(255,255,255,.4);margin-bottom:16px;}
.footer-links li{margin-bottom:9px;}
.footer-links a{font-size:.87rem;color:rgba(255,255,255,.58);transition:color .2s;}
.footer-links a:hover{color:#fff;}
.footer-contact-item{display:flex;align-items:flex-start;gap:10px;font-size:.84rem;color:rgba(255,255,255,.58);margin-bottom:10px;}
.footer-contact-item svg{width:16px;height:16px;color:var(--blue-acc);flex-shrink:0;margin-top:3px;}
.footer-contact-item a{color:rgba(255,255,255,.58);}
.footer-contact-item a:hover{color:#fff;}
.footer-hours-item{display:flex;align-items:center;gap:8px;font-size:.83rem;color:rgba(255,255,255,.58);margin-bottom:8px;}
.footer-hours-item svg{width:15px;height:15px;color:var(--blue-acc);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:20px 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;}
.footer-bottom p{font-size:.8rem;color:rgba(255,255,255,.32);}
.footer-bottom a{color:rgba(255,255,255,.45);transition:color .2s;font-size:.8rem;}
.footer-bottom a:hover{color:#fff;}

/* ── FLOATING BTNS ── */
.float-btns{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:10px;align-items:flex-end;}
.fab{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s;box-shadow:0 4px 16px rgba(0,0,0,.15);border:none;}
.fab-wa{background:#25D366;color:#fff;}
.fab-wa:hover{background:#1ebe5d;transform:scale(1.1);}
.fab-call{background:var(--teal);color:#fff;}
.fab-call:hover{background:var(--teal-d);transform:scale(1.1);}
.fab-label{font-size:.72rem;font-weight:700;background:var(--navy);color:#fff;padding:4px 10px;border-radius:6px;opacity:0;transition:opacity .2s;pointer-events:none;white-space:nowrap;}
.fab-wrap{display:flex;align-items:center;gap:9px;}
.fab-wrap:hover .fab-label{opacity:1;}

/* ── TOAST ── */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--navy);color:#fff;padding:13px 24px;border-radius:50px;font-size:.88rem;font-weight:500;z-index:9999;opacity:0;transition:all .4s ease;white-space:nowrap;pointer-events:none;box-shadow:0 8px 32px rgba(0,0,0,.25);}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast.success{background:#0f766e;}
.toast.error{background:#c53030;}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ── ADMIN ── */
.admin-login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--teal-l) 0%,#e8f4f8 100%);padding:24px;}
.admin-login-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);padding:44px 40px;width:100%;max-width:440px;box-shadow:var(--shadow-lg);text-align:center;}
.admin-badge{width:64px;height:64px;background:linear-gradient(135deg,var(--navy),var(--teal));border-radius:16px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:1.1rem;color:#fff;margin:0 auto 18px;}
.admin-login-card h2{font-size:1.6rem;font-weight:900;color:var(--navy);margin-bottom:5px;}
.admin-login-card>p{font-size:.85rem;color:var(--muted);margin-bottom:28px;}
.admin-login-card .form-group{text-align:left;margin-bottom:14px;}
.admin-header{background:var(--white);border-bottom:1px solid var(--border);padding:0 28px;height:64px;display:flex;align-items:center;justify-content:space-between;}
.admin-nav{display:flex;align-items:center;gap:8px;}
.admin-nav-btn{padding:7px 14px;border-radius:8px;font-size:.83rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;background:transparent;color:var(--muted);}
.admin-nav-btn.active,.admin-nav-btn:hover{background:var(--teal-l);color:var(--teal);}
.admin-logout{background:none;color:var(--muted);font-size:.83rem;font-weight:600;cursor:pointer;padding:7px 14px;border-radius:8px;border:1px solid var(--border);transition:all .2s;}
.admin-logout:hover{background:#fff0f0;color:var(--red);border-color:var(--red);}
.admin-main{max-width:1200px;margin:0 auto;padding:32px 24px;}
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px;}
.admin-stat-card{background:var(--white);border-radius:var(--radius);border:1px solid var(--border);padding:20px 22px;display:flex;justify-content:space-between;align-items:center;}
.admin-stat-card h4{font-size:.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:5px;}
.admin-stat-card strong{font-size:1.9rem;font-weight:900;color:var(--navy);display:block;}
.admin-stat-icon{width:44px;height:44px;border-radius:11px;background:var(--teal-l);display:flex;align-items:center;justify-content:center;}
.admin-stat-icon svg{width:22px;height:22px;color:var(--teal);}
.admin-section-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;margin-bottom:24px;}
.admin-section-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;}
.admin-section-header h3{font-size:1rem;font-weight:700;color:var(--navy);}
.admin-filter{display:flex;gap:8px;flex-wrap:wrap;}
.filter-btn{padding:6px 14px;border-radius:50px;border:1.5px solid var(--border);background:var(--white);color:var(--muted);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s;}
.filter-btn.active,.filter-btn:hover{background:var(--teal);border-color:var(--teal);color:#fff;}
.admin-table{width:100%;border-collapse:collapse;}
.admin-table th{padding:12px 16px;font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);text-align:left;background:#f8fafc;border-bottom:1px solid var(--border);white-space:nowrap;}
.admin-table td{padding:14px 16px;font-size:.86rem;color:var(--text);border-bottom:1px solid var(--border);vertical-align:top;}
.admin-table tr:last-child td{border-bottom:none;}
.admin-table tr:hover td{background:var(--teal-l);}
.status-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:50px;font-size:.72rem;font-weight:700;}
.status-pending{background:#fef3c7;color:#d97706;}
.status-confirmed{background:#d1fae5;color:#065f46;}
.status-cancelled{background:#fee2e2;color:#991b1b;}
.appt-action-btn{padding:5px 11px;border-radius:7px;font-size:.74rem;font-weight:600;cursor:pointer;border:none;transition:all .2s;margin-right:5px;}
.confirm-btn{background:#d1fae5;color:#065f46;}
.confirm-btn:hover{background:#065f46;color:#fff;}
.cancel-btn{background:#fee2e2;color:#991b1b;}
.cancel-btn:hover{background:#991b1b;color:#fff;}
.delete-btn{background:#f1f5f9;color:var(--muted);}
.delete-btn:hover{background:var(--red);color:#fff;}
.admin-empty{padding:56px 24px;text-align:center;color:var(--muted);}
.admin-search{padding:8px 14px;border:1.5px solid var(--border);border-radius:9px;font-size:.85rem;outline:none;color:var(--text);background:var(--white);transition:border-color .2s;min-width:200px;}
.admin-search:focus{border-color:var(--teal);}
.loading-row td{text-align:center;padding:40px;color:var(--muted);font-size:.9rem;}

/* ── SERVICES PAGE ── */
.svc-page-grid{display:block;}
.svc-filters,.svc-tab-wrap{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px;}
.svc-tab{padding:8px 18px;border-radius:30px;border:1.5px solid var(--border);background:var(--white);font-size:.82rem;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s;}
.svc-tab:hover{border-color:var(--teal);color:var(--teal);}
.svc-tab.active{background:var(--teal);border-color:var(--teal);color:#fff;}
.svc-featured{background:var(--white);border-radius:18px;border:2px solid var(--teal);overflow:hidden;margin-bottom:28px;display:none;animation:slideIn .35s ease;}
.svc-featured.show{display:block;}
@keyframes slideIn{from{opacity:0;transform:translateY(-14px)}to{opacity:1;transform:translateY(0)}}
.svc-feat-header{padding:28px 32px;display:flex;align-items:flex-start;gap:20px;border-bottom:1px solid var(--border);}
.svc-feat-icon{width:64px;height:64px;border-radius:16px;background:linear-gradient(135deg,var(--navy),var(--teal));display:flex;align-items:center;justify-content:center;font-size:2rem;flex-shrink:0;}
.svc-feat-title h2{font-size:1.35rem;font-weight:800;color:var(--navy);margin-bottom:6px;}
.svc-cat-badge{display:inline-block;background:var(--teal-l);color:var(--teal);font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 10px;border-radius:20px;}
.svc-feat-body{padding:24px 32px;}
.svc-feat-body p{font-size:.9rem;color:var(--muted);line-height:1.8;margin-bottom:16px;}
.svc-feat-points{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:20px;}
.svc-feat-point{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--navy);}
.svc-feat-point svg{width:16px;height:16px;stroke:var(--teal);flex-shrink:0;}
.svc-feat-actions{display:flex;gap:12px;flex-wrap:wrap;}
/* Featured panel image */
.svc-feat-img-wrap{width:100%;height:260px;overflow:hidden;background:linear-gradient(135deg,var(--navy),var(--teal));position:relative;}
.svc-feat-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;}
.svc-feat-img-fallback{display:none;position:absolute;inset:0;align-items:center;justify-content:center;font-size:5rem;background:linear-gradient(135deg,var(--navy),var(--teal));}

.svc-cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.svc-card{background:var(--white);border-radius:16px;border:1px solid var(--border);cursor:pointer;transition:all .25s;display:flex;flex-direction:column;overflow:hidden;padding:0;}
.svc-card:hover{border-color:var(--teal);box-shadow:0 8px 28px rgba(10,181,160,.15);transform:translateY(-4px);}
.svc-card.active{border-color:var(--teal);box-shadow:0 8px 28px rgba(10,181,160,.2);}
.svc-card-img{position:relative;width:100%;height:220px;background:linear-gradient(135deg,var(--navy),var(--teal));overflow:hidden;flex-shrink:0;}
.svc-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease;}
.svc-card:hover .svc-card-img img{transform:scale(1.06);}
.svc-card-img-fallback{display:none;position:absolute;inset:0;align-items:center;justify-content:center;font-size:3rem;background:linear-gradient(135deg,var(--navy),var(--teal));}
.svc-card-content{display:flex;gap:14px;align-items:flex-start;padding:16px 18px 18px;flex:1;}
.svc-card-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--navy),var(--teal));display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;}
.svc-card-body{flex:1;}
.svc-card-body h4{font-size:.9rem;font-weight:700;color:var(--navy);margin-bottom:4px;line-height:1.3;}
.svc-card-body p{font-size:.78rem;color:var(--muted);line-height:1.6;margin:0;}
.svc-card-cat{font-size:.66rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;}
.now-viewing-badge{position:absolute;top:16px;right:16px;background:var(--teal);color:#fff;font-size:.7rem;font-weight:700;padding:4px 12px;border-radius:20px;}
.svc-sidebar{position:sticky;top:88px;}
.sidebar-card{background:var(--white);border-radius:16px;border:1px solid var(--border);padding:22px;margin-bottom:18px;}
.sidebar-card h4{font-size:.88rem;font-weight:700;color:var(--navy);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border);}
.svc-list-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--silver);cursor:pointer;transition:all .2s;}
.svc-list-item:last-child{border:none;padding-bottom:0;}
.svc-list-item:hover{color:var(--teal);}
.svc-list-item svg{width:14px;height:14px;stroke:var(--teal);flex-shrink:0;}
.svc-list-item span{font-size:.8rem;font-weight:500;color:var(--navy);}
.svc-list-item:hover span{color:var(--teal);}

/* TREATMENTS */
.treatments-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px;}
.t-tab{padding:8px 18px;border-radius:30px;border:1.5px solid var(--border);background:var(--white);font-size:.82rem;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s;}
.t-tab:hover{border-color:var(--teal);color:var(--teal);}
.t-tab.active{background:var(--teal);border-color:var(--teal);color:#fff;}
.treat-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:32px;}
.treat-item{display:flex;align-items:flex-start;gap:16px;padding:20px 22px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);transition:all .3s;}
.treat-item:hover{border-color:var(--teal);box-shadow:var(--shadow);}
.treat-num{font-size:1.5rem;font-weight:900;color:var(--teal);opacity:.3;line-height:1;flex-shrink:0;}
.treat-item h4{font-size:.92rem;font-weight:700;color:var(--navy);margin-bottom:5px;}
.treat-item p{font-size:.82rem;color:var(--muted);line-height:1.65;}

/* ── OR DIVIDER ── */
.or-divider{display:flex;align-items:center;gap:10px;margin:20px 0 16px;}
.or-divider::before,.or-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.or-divider span{font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;}

/* ══════════════════════════════════════
   RESPONSIVE — ALL BREAKPOINTS
   ══════════════════════════════════════ */

/* ── TABLET (max 1024px) ── */
@media(max-width:1024px){
  /* Hero */
  .hero-grid{grid-template-columns:1fr;gap:32px;}
  .hero-bg{min-height:auto;padding:120px 0 56px;}
  .hero-contact-card{max-width:560px;}
  .hl-title{font-size:clamp(2.2rem,5vw,3.2rem);}
  .hl-stats{max-width:100%;}

  /* Doctor & About */
  .doctor-grid{grid-template-columns:1fr;gap:36px;}
  .doctor-img-wrap{max-width:400px;margin:0 auto;}
  .about-story{grid-template-columns:1fr;gap:32px;}

  /* Grids */
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .mission-grid{grid-template-columns:repeat(2,1fr);}
  .contact-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px;}
  .admin-stats{grid-template-columns:repeat(2,1fr);}

  /* Services page */
  .svc-page-grid{display:block;}
  .svc-page-grid > *{min-width:0;}
  .svc-sidebar{position:static;}

  /* Other */
  .google-rating-card{flex-direction:column;align-items:flex-start;gap:20px;}

  /* Blog scroll */
  .blog-grid{grid-template-columns:repeat(2,1fr);}
}

/* ── HAMBURGER NAV (max 900px) ── */
@media(max-width:900px){
  .nav-links{
    display:none;position:fixed;
    top:70px;left:0;right:0;
    height:calc(100vh - 70px);
    background:var(--beige2);
    flex-direction:column;
    padding:16px;gap:4px;
    z-index:10000;overflow-y:auto;
    box-shadow:0 8px 32px rgba(27,58,107,.12);
  }
  .nav-links.open{display:flex;}
  .nav-links a{
    padding:13px 16px;font-size:.98rem;
    border-radius:10px;width:100%;display:block;
    color:var(--navy);
    font-weight:600;
    opacity:.85;
  }
  .nav-links a:hover,.nav-links a.active{
    background:var(--blue);color:#fff;opacity:1;
  }
  .hamburger{display:flex;}
  .btn-wa-nav span.nav-text{display:none;}
  .btn-book-nav{display:none;}
}

/* ── MOBILE (max 768px) ── */
@media(max-width:768px){
  /* General */
  .section{padding:48px 0;}
  .container{padding:0 12px;}

  /* Navbar — shrink logo */
  .navbar .container{height:62px;}
  .logo img{height:44px !important;}
  .logo span strong{font-size:.88rem !important;}
  .logo span span{font-size:.72rem !important;}

  /* Hero */
  .hero-bg{
    padding:0;
    min-height:auto;
    background-image:none !important;
    background-color:transparent !important;
    display:block;
  }

  /* On mobile, hero-grid becomes flex column */
  .hero-grid{
    display:flex;
    flex-direction:column;
    gap:0;
    padding:0;
  }

  /* hero-left — blue tint matching brand theme on mobile */
  .hero-left{
    padding:90px 14px 36px;
    background-color:#032D60;
    background-image:
      linear-gradient(160deg, rgba(1,118,211,0.38) 0%, rgba(3,45,96,0.55) 50%, rgba(3,45,96,0.50) 100%),
      url('assets/clinic-interior.jpeg');
    background-size:cover;
    background-position:30% top;
    background-repeat:no-repeat;
    min-height:96svh;
  }
  /* Text colours for blue-tinted mobile hero */
  .hero-left .hl-title { color:#fff !important; text-shadow:0 2px 16px rgba(0,0,0,.3); }
  .hero-left .hl-sub   { color:rgba(255,255,255,.90) !important; }
  .hero-left .hl-location { color:var(--blue) !important; background:var(--blue-xl) !important; border-color:rgba(1,118,211,.30) !important; box-shadow:0 2px 8px rgba(1,118,211,.15) !important; }
  .hero-left .hl-checks li { color:rgba(255,255,255,.88) !important; }
  .hero-left .hl-checks li strong { color:#fff !important; }
  .hero-left .hl-stats { background:rgba(255,255,255,.14) !important; backdrop-filter:blur(8px); border-color:rgba(255,255,255,.18) !important; }
  .hero-left .hl-stat { background:#ffffff !important; border-color:rgba(0,0,0,.08) !important; box-shadow:0 2px 12px rgba(0,0,0,.07) !important; }
  .hero-left .hl-stat strong { color:var(--blue) !important; }
  .hero-left .hl-stat span   { color:var(--muted-l) !important; }

  /* hero contact card comes BELOW the bg image section on white */
  .hero-contact-card{
    border-radius:0 !important;
    box-shadow:none !important;
    border-top:3px solid var(--teal);
    background:#fff !important;
    padding:28px 16px 32px !important;
    display:none !important;
  }
  .hero-contact-card::before{display:none !important;}
  .hero-bg::after{display:none;}

  .hl-title{font-size:clamp(2rem,8vw,2.8rem);}
  .hl-sub{font-size:.88rem;}
  .hl-location{margin-top:0;margin-bottom:14px;}
  .hl-checks{grid-template-columns:1fr;gap:8px;}
  .hl-checks li{font-size:.83rem;}

  /* Stats — mobile 2x2 grid, stays inside bg */
  .hl-stats{
    grid-template-columns:repeat(2,1fr);
    border-radius:12px;
    margin-top:20px;
    background:rgba(255,255,255,.7);
  }
  .hl-stat{padding:10px 6px;}
  .hl-stat strong{font-size:1rem;margin-bottom:4px;line-height:1.2;}
  .hl-stat span{font-size:.55rem;line-height:1.3;display:inline-block;margin:0;}
  .hl-stat span br{line-height:1.3;}
  .hl-stats .hl-stat:nth-child(2n){border-right:none;}

  .contact-option{padding:14px 14px;gap:12px;}
  .contact-option-icon{width:42px;height:42px;}
  .contact-option-text strong{font-size:.88rem;}
  .contact-option-text span{font-size:.75rem;}

  /* WhatsApp banner */
  .wa-banner-inner{flex-direction:column;gap:20px;}
  .wa-banner h2{font-size:1.3rem;}
  .wa-banner-btns{flex-direction:column;width:100%;}
  .wa-big-btn,.call-btn-outline{width:100%;justify-content:center;}

  /* Services — home page: horizontal scroll strip */
  .services-grid{
    display:flex !important;
    overflow-x:auto !important;
    overflow-y:visible !important;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    gap:16px !important;
    padding:8px 4px 24px !important;
    margin-top:32px !important;
    scrollbar-width:thin;
    scrollbar-color:var(--teal) rgba(10,191,173,.1);
    flex-wrap:nowrap !important;
  }
  .services-grid::-webkit-scrollbar{height:4px;}
  .services-grid::-webkit-scrollbar-thumb{background:var(--teal);border-radius:4px;}
  .services-grid .service-card{
    flex:0 0 80vw !important;
    max-width:340px !important;
    min-width:260px !important;
    scroll-snap-align:start;
    flex-shrink:0 !important;
  }
  /* Match blog card image height */
  .services-grid .svc-card-img,
  .services-grid .service-card .svc-card-img{height:220px !important;}

  /* Contact Quick */
  .contact-quick{padding:48px 0;}
  .contact-options-grid{grid-template-columns:1fr;gap:12px;margin-top:32px;max-width:400px;margin-left:auto;margin-right:auto;}

  /* Services page mobile — handled by inline style in services.html */

  /* Why / Mission */
  .why-grid{grid-template-columns:1fr;}
  .mission-grid{grid-template-columns:1fr 1fr;}
  .why-list{grid-template-columns:1fr;}

  /* Doctor */
  .doctor-img-wrap{max-width:100%;}
  .doctor-img{aspect-ratio:4/3;min-height:280px;}
  .doctor-badge{right:0;bottom:-12px;}

  /* Gallery */
  .gallery-grid{
    display:flex !important;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    gap:14px;
    padding:8px 4px 20px;
    grid-template-columns:unset !important;
    margin-left:0;
    margin-right:0;
  }
  .gallery-grid .gallery-item{
    flex:0 0 80vw;
    max-width:340px;
    min-width:260px;
    height:320px;
    scroll-snap-align:start;
    margin:0;
  }

  /* Gallery top filter pills (all/clinic/treatments) */
  .filter-bar{
    position:sticky;
    top:70px;
    z-index:100;
    background:var(--beige2);
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
    justify-content:flex-start;
    gap:10px;
    padding:12px 8px;
    margin:0 -8px 10px;
    width:calc(100% + 16px);
    border-bottom:1px solid rgba(193,167,120,.25);
  }
  .filter-bar::-webkit-scrollbar{height:4px;}
  .filter-bar::-webkit-scrollbar-thumb{background:var(--teal);border-radius:4px;}
  .filter-bar .filter-pill{
    flex:0 0 auto;
    scroll-snap-align:start;
    white-space:nowrap;
  }

  /* Gallery page 'all-section' card strip */
  .all-scroll-wrap{margin:0;padding:0 4px;min-height:auto;}
  .all-scroll-track{padding:10px 4px 28px;gap:16px;}
  .all-cat-card{flex:0 0 92vw;max-width:380px;height:520px;}

  .cat-scroll-track{padding:10px 4px 28px;}
  .cat-photos-grid{grid-template-columns:repeat(2,minmax(180px,1fr));gap:14px;}

  /* Blog — horizontal scroll on mobile */
  .blog-grid{
    display:flex !important;
    overflow-x:auto !important;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    grid-template-columns:unset !important;
    gap:14px;
    padding:4px 4px 16px;
    scrollbar-width:thin;
    scrollbar-color:var(--teal) transparent;
  }
  .blog-grid .blog-card{flex:0 0 76vw !important;scroll-snap-align:start;}

  /* Contact */
  .contact-grid{grid-template-columns:1fr;gap:28px;}
  .contact-form-card{padding:24px 16px;}

  /* Forms */
  .form-grid-2{grid-template-columns:1fr;}
  .appt-form-card{padding:24px 16px;}
  .appt-features{grid-template-columns:1fr;}

  /* Emergency */
  .emergency-inner{flex-direction:column;gap:20px;}
  .em-actions{flex-direction:column;width:100%;}
  .em-phone,.em-wa-btn{width:100%;justify-content:center;}

  /* Footer */
  .footer-grid{grid-template-columns:1fr;gap:28px;}
  .footer-bottom{flex-direction:column;text-align:center;gap:8px;}

  /* Google rating */
  .google-rating-card{padding:20px 16px;}
  .google-rating-left{flex-direction:column;align-items:flex-start;gap:12px;}

  /* Admin */
  .admin-stats{grid-template-columns:1fr 1fr;}

  /* Page header */
  .page-header{padding:100px 0 36px;}
  .page-header h1{font-size:1.6rem;}

  /* Float buttons — move higher on mobile */
  .float-btns{bottom:16px;right:16px;}
  .fab{width:48px;height:48px;}

  /* Scroll arrows hide on mobile */
  .blog-arrow{display:none;}
}

/* ── SMALL PHONES (max 380px) ── */
@media(max-width:380px){
  .hl-title{font-size:1.9rem;}
  .mission-grid{grid-template-columns:1fr;}
  .contact-option{flex-direction:column;text-align:center;}
  .wa-banner h2{font-size:1.1rem;}
}
/* ── BLOG ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px;}
.blog-card{background:var(--cream);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;transition:all .3s;display:flex;flex-direction:column;}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);}
.blog-card-img{position:relative;height:200px;background:linear-gradient(135deg,var(--navy),var(--teal));overflow:hidden;flex-shrink:0;}
.blog-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.blog-card:hover .blog-card-img img{transform:scale(1.05);}
.blog-card-img-fallback{display:none;position:absolute;inset:0;align-items:center;justify-content:center;font-size:3.5rem;background:linear-gradient(135deg,var(--navy),var(--teal));}
.blog-tag{position:absolute;top:14px;left:14px;background:var(--teal);color:#fff;font-size:.68rem;font-weight:700;padding:4px 12px;border-radius:20px;letter-spacing:.06em;text-transform:uppercase;}
.blog-card-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1;}
.blog-date{font-size:.75rem;color:var(--muted);font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:.06em;}
.blog-card-body h3{font-size:.97rem;font-weight:800;color:var(--navy);margin-bottom:10px;line-height:1.4;}
.blog-card-body p{font-size:.82rem;color:var(--muted);line-height:1.7;flex:1;margin:0;}
.blog-read-more{display:inline-flex;align-items:center;gap:5px;margin-top:16px;font-size:.82rem;font-weight:700;color:var(--teal);transition:gap .2s;}
.blog-read-more:hover{gap:10px;}

/* ── SCROLL STRIP (shared by blog & gallery) ── */
.blog-scroll-wrap{position:relative;}
.blog-scroll{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:8px 4px 24px;scrollbar-width:thin;scrollbar-color:var(--teal) #eef;}
.blog-scroll::-webkit-scrollbar{height:5px;}
.blog-scroll::-webkit-scrollbar-track{background:#f0fdfc;border-radius:4px;}
.blog-scroll::-webkit-scrollbar-thumb{background:var(--teal);border-radius:4px;}
.blog-card{flex:0 0 320px;scroll-snap-align:start;background:var(--white);border-radius:18px;border:1px solid var(--border);overflow:hidden;transition:all .3s;cursor:pointer;display:flex;flex-direction:column;}
.blog-card:hover{box-shadow:0 8px 32px rgba(10,181,160,.15);transform:translateY(-4px);border-color:var(--teal);}
.blog-card-img{position:relative;height:200px;background:linear-gradient(135deg,var(--navy),var(--teal));overflow:hidden;flex-shrink:0;}
.blog-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.blog-card:hover .blog-card-img img{transform:scale(1.06);}
.blog-card-img-fallback{display:none;position:absolute;inset:0;align-items:center;justify-content:center;font-size:3.5rem;background:linear-gradient(135deg,var(--navy),var(--teal));}
.blog-tag{position:absolute;top:14px;left:14px;background:var(--teal);color:#fff;font-size:.65rem;font-weight:700;padding:4px 12px;border-radius:20px;letter-spacing:.08em;text-transform:uppercase;}
.blog-card-body{padding:20px 20px 22px;display:flex;flex-direction:column;flex:1;}
.blog-date{font-size:.72rem;color:var(--muted);font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:.06em;}
.blog-card-body h3{font-size:.97rem;font-weight:800;color:var(--navy);margin-bottom:10px;line-height:1.4;}
.blog-card-body p{font-size:.82rem;color:var(--muted);line-height:1.7;flex:1;margin:0;}
.blog-read-btn{display:inline-flex;align-items:center;gap:6px;margin-top:16px;padding:9px 18px;background:var(--teal-l);color:var(--teal);border:none;border-radius:50px;font-size:.8rem;font-weight:700;cursor:pointer;transition:all .2s;font-family:inherit;align-self:flex-start;}
.blog-read-btn:hover{background:var(--teal);color:#fff;}
.blog-arrow{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:#fff;border:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.1);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:all .2s;}
.blog-arrow:hover{background:var(--teal);border-color:var(--teal);}
.blog-arrow:hover svg{stroke:#fff;}
.blog-arrow svg{width:20px;height:20px;stroke:var(--navy);}
.blog-arrow-left{left:-16px;}
.blog-arrow-right{right:-16px;}
@media(max-width:768px){.blog-arrow{display:none;}}
@media(max-width:640px){.blog-card{flex:0 0 260px;}}
/* ── MOB SCROLL ARROWS ── */
.mob-scroll-wrap{position:relative;}
.mob-arrow{display:none;}
@media(max-width:640px){
  .mob-arrow{
    display:flex;
    position:absolute;top:42%;transform:translateY(-50%);
    width:32px;height:32px;border-radius:50%;
    background:#fff;border:1px solid var(--border);
    box-shadow:0 2px 10px rgba(0,0,0,.15);
    align-items:center;justify-content:center;
    cursor:pointer;z-index:10;
  }
  .mob-arrow svg{width:14px;height:14px;stroke:var(--navy);}
  .mob-arrow-left{left:-6px;}
  .mob-arrow-right{right:-6px;}
}

/* ══════════════════════════════
   HOME GALLERY SCROLL
   ══════════════════════════════ */
.hg-wrap{
  position:relative;
  margin:0 -4px;
}
.hg-scroll{
  display:flex;
  gap:16px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:8px 8px 20px;
  scrollbar-width:thin;
  scrollbar-color:var(--teal) rgba(10,191,173,.1);
}
.hg-scroll::-webkit-scrollbar{height:4px;}
.hg-scroll::-webkit-scrollbar-track{background:rgba(10,191,173,.08);border-radius:4px;}
.hg-scroll::-webkit-scrollbar-thumb{background:var(--teal);border-radius:4px;}

/* Each item */
.hg-item{
  flex:0 0 280px;
  height:320px;
  scroll-snap-align:start;
  border-radius:16px;
  overflow:hidden;
  position:relative;
  cursor:pointer;
  background:linear-gradient(135deg,var(--navy),var(--teal));
  transition:transform .3s,box-shadow .3s;
  flex-shrink:0;
}
.hg-item:hover{transform:scale(1.02);box-shadow:0 12px 36px rgba(10,181,160,.25);}
.hg-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.hg-item:hover img{transform:scale(1.06);}
.hg-fallback{
  display:none;position:absolute;inset:0;
  align-items:center;justify-content:center;
  font-size:4rem;
  background:linear-gradient(135deg,var(--navy),var(--teal));
}
.hg-overlay{
  position:absolute;inset:0;
  background:rgba(11,31,58,.45);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .3s;
}
.hg-overlay svg{width:32px;height:32px;}
.hg-item:hover .hg-overlay{opacity:1;}
.hg-item.hg-video .hg-overlay{opacity:1;background:rgba(11,31,58,.3);}

/* Play button for video */
.hg-play{
  width:60px;height:60px;border-radius:50%;
  background:rgba(255,255,255,.92);
  display:flex;align-items:center;justify-content:center;
}
.hg-play svg{width:24px;height:24px;margin-left:4px;}

/* Caption bar at bottom */
.hg-caption{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(11,31,58,.9),transparent);
  padding:28px 16px 14px;
  display:flex;flex-direction:column;gap:4px;
}
.hg-tag{
  display:inline-block;
  background:var(--teal);color:#fff;
  font-size:.62rem;font-weight:700;
  padding:3px 10px;border-radius:20px;
  letter-spacing:.07em;text-transform:uppercase;
  align-self:flex-start;
}
.hg-tag-video{background:#e53e3e;}
.hg-caption strong{color:#fff;font-size:.88rem;font-weight:700;}

/* Big arrows */
.hg-arrow{
  position:absolute;top:50%;transform:translateY(-60%);
  width:48px;height:48px;border-radius:50%;
  background:#fff;border:2px solid var(--border);
  box-shadow:0 4px 20px rgba(0,0,0,.15);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:10;transition:all .25s;
}
.hg-arrow svg{width:20px;height:20px;stroke:var(--navy);}
.hg-arrow:hover{background:var(--teal);border-color:var(--teal);}
.hg-arrow:hover svg{stroke:#fff;}
.hg-arrow-left{left:-22px;}
.hg-arrow-right{right:-22px;}

/* Gallery page uses same hg-wrap + gal-page-grid as flex scroll */
.gal-page-grid{
  display:flex;
  gap:16px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  -webkit-overflow-scrolling:touch;
  padding:8px 8px 20px;
  scrollbar-width:thin;
  scrollbar-color:var(--teal) rgba(10,191,173,.1);
}
.gal-page-grid::-webkit-scrollbar{height:4px;}
.gal-page-grid::-webkit-scrollbar-thumb{background:var(--teal);border-radius:4px;}
.gal-card{
  flex:0 0 260px;
  height:300px;
  scroll-snap-align:start;
  border-radius:16px;
  overflow:hidden;
  position:relative;
  cursor:pointer;
  background:linear-gradient(135deg,var(--navy),var(--teal));
  transition:transform .3s,box-shadow .3s;
  flex-shrink:0;
  border:2px solid transparent;
}
.gal-card:hover{transform:scale(1.02);border-color:var(--teal);box-shadow:0 10px 32px rgba(10,181,160,.2);}
.gal-card-img{position:absolute;inset:0;}
.gal-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s;}
.gal-card:hover .gal-card-img img{transform:scale(1.06);}
.gal-card-fallback{
  display:none;position:absolute;inset:0;
  align-items:center;justify-content:center;
  font-size:3.5rem;
  background:linear-gradient(135deg,var(--navy),var(--teal));
}
.gal-card-tag{
  position:absolute;top:12px;left:12px;z-index:2;
  background:var(--teal);color:#fff;
  font-size:.62rem;font-weight:700;
  padding:3px 10px;border-radius:20px;
  letter-spacing:.07em;text-transform:uppercase;
}
.gal-card-body{
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(11,31,58,.88),transparent);
  padding:28px 14px 12px;z-index:2;
}
.gal-card-body h3{color:#fff;font-size:.85rem;font-weight:700;margin:0;}

@media(max-width:768px){
  .hg-arrow{display:none;}
  .hg-item{flex:0 0 240px;height:280px;}
  .gal-card{flex:0 0 220px;height:260px;}
}
@media(max-width:480px){
  .hg-item{flex:0 0 200px;height:250px;}
  .gal-card{flex:0 0 190px;height:230px;}
}

/* ══════════════════════════════════
   HOME MINI GALLERY
   ══════════════════════════════════ */
.mg-wrap{position:relative;margin-top:40px;}

/* Desktop — 3 columns normal grid, no scroll */
.mg-scroll{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.mg-btn{display:none;}

/* Category card */
.mg-cat-card{
  height:380px;
  position:relative;border-radius:22px;overflow:hidden;
  cursor:pointer;
  background:linear-gradient(135deg,var(--navy),var(--teal));
  box-shadow:0 6px 28px rgba(11,31,58,.14);
  transition:transform .3s,box-shadow .3s;
  border:3px solid transparent;
}
.mg-cat-card:hover{
  transform:translateY(-8px);
  box-shadow:0 20px 56px rgba(10,191,173,.28);
  border-color:var(--teal);
}
.mg-cat-card img{
  position:absolute;inset:0;
  width:100%;height:100%;object-fit:cover;
  display:block;transition:transform .5s;
}
.mg-cat-card:hover img{transform:scale(1.07);}
.mg-cat-emoji{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  font-size:5rem;
  background:linear-gradient(135deg,var(--navy),var(--teal));
}
.mg-cat-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(11,31,58,.95) 0%,rgba(11,31,58,.15) 60%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:24px;
  transition:background .3s;
}
.mg-cat-card:hover .mg-cat-overlay{
  background:linear-gradient(to top,rgba(11,31,58,.97) 0%,rgba(11,31,58,.25) 60%,transparent 100%);
}
.mg-cat-icon{
  position:absolute;top:14px;left:14px;
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;
  background:rgba(255,255,255,.15);
  backdrop-filter:blur(6px);
  border:1.5px solid rgba(255,255,255,.2);
}
.mg-cat-count{
  position:absolute;top:14px;right:14px;
  background:rgba(10,191,173,.85);
  color:#fff;font-size:.68rem;font-weight:700;
  padding:4px 11px;border-radius:50px;
  letter-spacing:.06em;
  backdrop-filter:blur(6px);
}
.mg-cat-name{
  color:#fff;font-size:1.15rem;font-weight:900;
  margin-bottom:5px;line-height:1.2;
}
.mg-cat-desc{
  color:rgba(255,255,255,.65);font-size:.8rem;
  line-height:1.5;margin-bottom:16px;
}
.mg-cat-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.15);
  border:1.5px solid rgba(255,255,255,.38);
  color:#fff;font-size:.8rem;font-weight:700;
  padding:8px 18px;border-radius:50px;
  backdrop-filter:blur(6px);
  transition:all .25s;align-self:flex-start;
}
.mg-cat-card:hover .mg-cat-cta{background:var(--teal);border-color:var(--teal);}
.mg-cat-cta svg{width:14px;height:14px;transition:transform .2s;}
.mg-cat-card:hover .mg-cat-cta svg{transform:translateX(3px);}

/* Tablet — horizontal scroll with arrows */
@media(max-width:768px){
  .mg-wrap{padding:0;}
  .mg-scroll{
    display:flex;gap:20px;
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    padding:10px 4px 24px;
    scrollbar-width:thin;
    scrollbar-color:var(--teal) rgba(10,191,173,.1);
  }
  .mg-scroll::-webkit-scrollbar{height:4px;}
  .mg-scroll::-webkit-scrollbar-thumb{background:var(--teal);border-radius:4px;}
  .mg-cat-card{flex:0 0 260px;height:320px;scroll-snap-align:start;flex-shrink:0;}
  .mg-btn{
    position:absolute;
    top:calc(10px + 160px);
    transform:translateY(-50%);
    width:44px;height:44px;border-radius:50%;
    background:#fff;border:2px solid var(--border);
    box-shadow:0 4px 16px rgba(0,0,0,.15);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;z-index:10;transition:all .2s;
  }
  .mg-btn svg{width:18px;height:18px;stroke:var(--navy);}
  .mg-btn:hover{background:var(--teal);border-color:var(--teal);}
  .mg-btn:hover svg{stroke:#fff;}
  .mg-prev{left:-6px;}
  .mg-next{right:-6px;}
}

/* Mobile — swipe only, no arrows */
@media(max-width:480px){
  .mg-wrap{padding:0;}
  .mg-btn{display:none !important;}
  .mg-scroll{padding:10px 16px 24px;}
  .mg-cat-card{flex:0 0 82vw;height:300px;}
}

/* ── HOME MINI GALLERY LIGHTBOX ── */
#mg-lb-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.93);z-index:99999;
  align-items:center;justify-content:center;
  padding:20px;
}
#mg-lb-overlay.open{display:flex;animation:mgLbIn .25s ease;}
@keyframes mgLbIn{from{opacity:0}to{opacity:1}}
#mg-lb-box{
  position:relative;display:flex;flex-direction:column;
  align-items:center;width:100%;max-width:900px;max-height:95vh;
}
#mg-lb-header{
  width:100%;display:flex;align-items:center;
  justify-content:space-between;margin-bottom:14px;
}
#mg-lb-label{
  display:inline-flex;align-items:center;
  background:var(--teal);color:#fff;
  font-size:.7rem;font-weight:700;
  padding:5px 14px;border-radius:50px;
  letter-spacing:.07em;text-transform:uppercase;
}
#mg-lb-counter{color:rgba(255,255,255,.5);font-size:.83rem;font-weight:600;}
#mg-lb-close{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.15);border:none;
  color:#fff;font-size:1.2rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;flex-shrink:0;
}
#mg-lb-close:hover{background:rgba(255,255,255,.35);}
#mg-lb-stage{display:flex;align-items:center;gap:14px;width:100%;}
#mg-lb-prev,#mg-lb-next{
  flex-shrink:0;width:50px;height:50px;border-radius:50%;
  background:rgba(255,255,255,.15);
  border:2px solid rgba(255,255,255,.22);
  color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;
}
#mg-lb-prev:hover,#mg-lb-next:hover{background:var(--teal);border-color:var(--teal);}
#mg-lb-prev svg,#mg-lb-next svg{width:20px;height:20px;}
#mg-lb-img-wrap{
  flex:1;display:flex;align-items:center;
  justify-content:center;max-height:62vh;
}
#mg-lb-img{
  max-width:100%;max-height:62vh;object-fit:contain;
  border-radius:12px;display:block;
  transition:opacity .2s,transform .2s;
}
#mg-lb-img.switching{opacity:0;transform:scale(.96);}
#mg-lb-emoji{
  display:none;font-size:7rem;
  align-items:center;justify-content:center;
  width:100%;height:280px;
}
#mg-lb-caption{
  color:#fff;font-size:.93rem;font-weight:700;
  margin:14px 0 3px;text-align:center;
}
#mg-lb-sub{
  color:rgba(255,255,255,.5);font-size:.78rem;
  text-align:center;margin-bottom:12px;
}
#mg-lb-thumbs{
  display:flex;gap:9px;flex-wrap:wrap;
  justify-content:center;max-width:100%;
}
.mg-lb-thumb{
  width:60px;height:60px;border-radius:9px;
  background-size:cover;background-position:center;
  background-color:rgba(255,255,255,.1);
  cursor:pointer;border:2.5px solid transparent;
  transition:border-color .2s,opacity .2s;
  opacity:.5;flex-shrink:0;
}
.mg-lb-thumb:hover{opacity:.8;}
.mg-lb-thumb.active{opacity:1;border-color:var(--teal);}
.mg-lb-thumb-emoji{
  display:flex;align-items:center;justify-content:center;
  font-size:1.7rem;background:rgba(255,255,255,.08);
}
#mg-lb-dots{display:none;gap:8px;justify-content:center;margin-top:4px;}
.mg-lb-dot{
  width:8px;height:8px;border-radius:50%;
  background:rgba(255,255,255,.3);cursor:pointer;
  transition:background .2s,transform .2s;
}
.mg-lb-dot.active{background:var(--teal);transform:scale(1.3);}
@media(max-width:700px){
  #mg-lb-thumbs{display:none;}
  #mg-lb-dots{display:flex;}
  #mg-lb-prev,#mg-lb-next{width:38px;height:38px;}
  #mg-lb-prev svg,#mg-lb-next svg{width:17px;height:17px;}
  #mg-lb-stage{gap:8px;}
}

/* ══════════════════════════════════
   GALLERY PAGE NAV ARROWS
   ══════════════════════════════════ */
.gal-nav-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:52px;height:52px;border-radius:50%;
  background:#fff;border:2px solid var(--border);
  box-shadow:0 4px 20px rgba(0,0,0,.15);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:10;transition:all .2s;
}
.gal-nav-btn svg{width:22px;height:22px;stroke:var(--navy);}
.gal-nav-btn:hover{background:var(--teal);border-color:var(--teal);}
.gal-nav-btn:hover svg{stroke:#fff;}
.gal-nav-prev{left:-24px;}
.gal-nav-next{right:-24px;}

/* Make gallery page cards taller */
.gal-card-img{height:240px !important;}
.gal-page-grid .gal-card{flex:0 0 300px !important;}

@media(max-width:640px){
  .gal-nav-btn{display:none;}
  .gal-card-img{height:180px !important;}
  .gal-page-grid .gal-card{flex:0 0 220px !important;}
}
/* ── GALLERY TABS SCROLL (override) ── */
.gal-tabs{
  display:flex !important;
  flex-wrap:nowrap !important;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
  padding-bottom:6px;
  gap:10px;
  margin-top:32px;
}
.gal-tabs::-webkit-scrollbar{display:none;}
.gal-tab{flex-shrink:0 !important;}

/* ── CONTACT QUICK RESPONSIVE ── */
@media(max-width:900px){
  .contact-quick-grid{grid-template-columns:1fr;}
  .cq-card{
    padding:24px 20px;
    display:grid;
    grid-template-columns:auto 1fr;
    grid-template-rows:auto auto auto;
    text-align:left;
    min-height:auto;
    gap:12px 12px;
  }
  .cq-card h3{margin-bottom:0;font-size:.9rem;grid-column:2;grid-row:1;}
  .cq-card p{margin-bottom:0;font-size:.8rem;grid-column:2;grid-row:2;}
  .cq-icon{margin:0;width:48px;height:48px;grid-column:1;grid-row:1 / span 2;}
  .cq-btn{margin:0;padding:8px 16px;font-size:.85rem;grid-column:1 / span 2;grid-row:3;text-align:center;margin-top:10px;}
}
@media(min-width:481px) and (max-width:900px){
  .contact-quick-grid{grid-template-columns:repeat(3,1fr);}
}

/* ── HERO PHOTO RESPONSIVE ── */
@media(max-width:768px){
  .hero-grid{grid-template-columns:1fr !important;}
  .hero-bg{
    background:#C2DEFF;
    background-image:
      radial-gradient(ellipse 90% 55% at 95% 5%,  rgba(1,118,211,.28)  0%, rgba(27,150,255,.14) 50%, transparent 70%),
      radial-gradient(ellipse 70% 55% at 3%  90%,  rgba(3,45,96,.16)    0%, transparent 60%),
      radial-gradient(ellipse 60% 50% at 50% 50%,  rgba(255,255,255,.35) 0%, transparent 65%);
  }
  .hl-stats{grid-template-columns:repeat(2,1fr);gap:10px;}
  .contact-quick-grid{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .hl-stats{grid-template-columns:repeat(2,1fr);gap:8px;}
  .hl-stat{padding:14px 10px;}
  .hl-stat strong{font-size:1.2rem;}
}
/* ══════════════════════════════════════
   ADDITIONS — Icons, Read More, Slider dots
   ══════════════════════════════════════ */

/* ── Read More button on home service cards ── */
.svc-read-more {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: 14px;
  font-size: .82rem;
  font-weight: 700;
  color: var(--blue);
  text-decoration: none;
  letter-spacing: .01em;
  border: none;
  border-bottom: 1.5px solid rgba(1,118,211,.28);
  padding: 0 0 2px;
  border-radius: 0;
  transition: all .2s;
  width: fit-content;
}
.svc-read-more svg { flex-shrink: 0; transition: transform .2s; }
.svc-read-more:hover {
  color: var(--blue-d);
  border-bottom-color: var(--blue-d);
  gap: 9px;
}
.svc-read-more:hover svg { transform: translateX(3px); }

/* ── Icon on HOME service cards (now white bg) ── */
.service-card .svc-icon {
  background: var(--blue-l);
  border: 1.5px solid rgba(30,144,255,.2);
  border-radius: 12px;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  flex-shrink: 0;
}
.service-card .svc-icon svg {
  width: 24px;
  height: 24px;
  stroke: var(--blue);
}

.svc-card-content .svc-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--blue-l) !important;
  flex-shrink: 0;
  margin-right: 2px;
}
.svc-card-content .svc-card-icon svg {
  stroke: var(--blue);
}

/* Also override the base .svc-card-icon rule for service cards */
.svc-cards-grid .svc-card-icon {
  background: var(--blue-l) !important;
}

/* ── Mission card icon (about page) ── */
.mission-icon {
  width: 60px;
  height: 60px;
  border-radius: 16px;
  background: rgba(255,255,255,.18);
  border: 1.5px solid rgba(255,255,255,.3);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 16px;
}
.mission-icon svg { stroke: #fff; }

/* ── Why list item heading with inline SVG ── */
.why-list-item h4 {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .95rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: 8px;
}
.why-list-item h4 svg { stroke: #93C5FD; flex-shrink: 0; }

/* ── Circular slider dots (like image) ── */
.slider-dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 20px;
}
.slider-dots .dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #D1D5DB;
  border: 2px solid #D1D5DB;
  transition: all .3s ease;
  cursor: pointer;
  padding: 0;
  outline: none;
  flex-shrink: 0;
}
.slider-dots .dot.active {
  background: var(--blue);
  border-color: var(--blue);
  width: 10px;
  height: 10px;
  border-radius: 50%;
}

/* ── Svc feat icon container fix ── */
.svc-feat-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 14px;
  background: var(--blue);
  flex-shrink: 0;
}
.svc-feat-icon svg { stroke: #fff; }
/* ═══════════════════════════════════════════════════════
   AUTO-CAROUSEL ENGINE — Services · Gallery · Blog
   ═══════════════════════════════════════════════════════ */

/* ── Shared carousel shell ── */
.carousel-section { padding: 96px 0; }
.carousel-section.bg-white  { background: #fff; }
.carousel-section.bg-grey   { background: #F3F3F3; border-top:1px solid rgba(0,0,0,.07); border-bottom:1px solid rgba(0,0,0,.07); }
.carousel-section.bg-navy   { background: #EFF6FF; border-top:1px solid rgba(1,118,211,.12); border-bottom:1px solid rgba(1,118,211,.12); }
.carousel-section.bg-navy .sec-eyebrow { background:rgba(1,118,211,.12);color:var(--blue);border-color:rgba(1,118,211,.25); }
.carousel-section.bg-navy .sec-title   { color:var(--navy) !important; }
.carousel-section.bg-navy .sec-title em { color:var(--blue) !important; }
.carousel-section.bg-navy .sec-sub     { color:var(--muted) !important; }

.carousel-header { text-align:center; margin-bottom:52px; }

/* Track + clip */
.carousel-viewport { overflow:hidden; border-radius:20px; }
.carousel-track {
  display:flex;
  gap:22px;
  transition:transform .55s cubic-bezier(.4,0,.2,1);
  will-change:transform;
  touch-action:pan-y;
}

/* Progress bar */
.carousel-progress-wrap {
  height:3px; background:var(--grey2);
  border-radius:2px; margin:24px auto 0; max-width:300px; overflow:hidden;
}
.carousel-section.bg-navy .carousel-progress-wrap { background:rgba(30,144,255,.15); }
.carousel-progress-bar {
  height:100%;
  background:linear-gradient(90deg,var(--blue),var(--navy));
  border-radius:2px; width:0%; transition:width .08s linear;
}
.carousel-section.bg-navy .carousel-progress-bar { background:linear-gradient(90deg,var(--blue),var(--navy)); }

/* Dot nav */
.carousel-dots { display:flex;justify-content:center;gap:8px;margin-top:18px; }
.carousel-dot {
  width:8px;height:8px;border-radius:50%;border:none;cursor:pointer;
  background:#C9C9C7;padding:0;transition:all .3s;
}
.carousel-section.bg-navy .carousel-dot { background:#C9C9C7; }
.carousel-dot.is-active { background:var(--blue); width:26px; border-radius:4px; }
.carousel-section.bg-navy .carousel-dot.is-active { background:var(--blue); }

/* Arrow buttons */
.carousel-arrows { display:flex;justify-content:center;gap:12px;margin-top:20px; }
.carousel-arrow {
  width:44px;height:44px;border-radius:50%;background:#fff;
  border:1.5px solid rgba(0,0,0,.15);display:flex;align-items:center;
  justify-content:center;cursor:pointer;transition:all .25s;
  box-shadow:0 2px 8px rgba(0,0,0,.09);
}
.carousel-arrow:hover { background:var(--navy);border-color:var(--navy); }
.carousel-arrow:hover svg { stroke:#fff; }
.carousel-arrow svg { width:18px;height:18px;stroke:var(--navy);fill:none;stroke-width:2.5; }
.carousel-section.bg-navy .carousel-arrow { background:#fff;border-color:rgba(0,0,0,.13); }
.carousel-section.bg-navy .carousel-arrow svg { stroke:var(--navy); }
.carousel-section.bg-navy .carousel-arrow:hover { background:var(--blue);border-color:var(--blue); }
.carousel-section.bg-navy .carousel-arrow:hover svg { stroke:#fff; }

/* ─── SERVICE CARDS ─── */
.svc-car-card {
  flex:0 0 calc(33.333% - 15px); min-width:0;
  background:#fff; border:1px solid rgba(0,0,0,.09);
  border-radius:12px; overflow:hidden;
  box-shadow:0 2px 12px rgba(0,0,0,.07);
  transition:box-shadow .3s, border-color .3s;
  position:relative; cursor:pointer;
}
.svc-car-card:hover { box-shadow:0 14px 40px rgba(0,0,0,.18); border-color:rgba(0,0,0,.12); }
.svc-car-img-wrap { overflow:hidden;position:relative; }
.svc-car-img-wrap::after {
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:50%;
  background:linear-gradient(to bottom, rgba(80,80,80,.52) 0%, transparent 100%);
  opacity:0;
  transition:opacity .4s ease;
  pointer-events:none;
}
.svc-car-card:hover .svc-car-img-wrap::after { opacity:1; }
.svc-car-img {
  width:100%;height:210px;object-fit:cover;display:block;
  background:var(--grey);transition:transform .55s cubic-bezier(.25,.46,.45,.94);
}
.svc-car-card:hover .svc-car-img { transform:scale(1.07); }
.svc-car-badge {
  position:absolute;top:14px;left:14px;
  background:var(--blue);color:#fff;
  font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 11px;border-radius:4px;
}
.svc-car-body { padding:22px 24px 26px;background:#fff; }
.svc-car-icon {
  width:42px;height:42px;border-radius:8px;
  background:var(--blue-l);border:1px solid rgba(1,118,211,.15);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;
}
.svc-car-icon svg { width:20px;height:20px;stroke:var(--blue);fill:none;stroke-width:2; }
.svc-car-body h3 { font-size:1.15rem;font-weight:700;color:var(--navy);margin-bottom:10px;line-height:1.2;transition:color .2s; }
.svc-car-card:hover:not(:has(.svc-car-link:hover)) .svc-car-body h3 { color:var(--blue); }
.svc-car-card:has(.svc-car-link:hover) .svc-car-body h3 { color:var(--navy) !important; }
.svc-car-body p { font-size:.92rem;color:var(--muted-l);line-height:1.72;margin-bottom:18px; }
.svc-car-link {
  display:inline-flex;align-items:center;gap:7px;
  font-size:.88rem;font-weight:700;color:var(--navy);
  background:none;padding:0;border:none;border-radius:0;
  text-decoration:none;
  border-bottom:1.5px solid rgba(3,45,96,.32);
  padding-bottom:2px;
  transition:color .2s, border-color .2s, gap .2s;
  margin-top:4px;
  box-shadow:none;
  width:fit-content;
}
.svc-car-link svg { display:inline-block;width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2.5;transition:transform .2s;flex-shrink:0; }
.svc-car-link:hover { background:none; box-shadow:none; text-decoration:none; color:var(--blue); border-bottom-color:var(--blue); gap:11px; }
.svc-car-link:hover svg { transform:translateX(3px); }
/* Removed: card hover rule — link reacts only to its own hover */

/* ─── GALLERY CARDS ─── */
.gal-car-card {
  flex:0 0 calc(33.333% - 15px); min-width:0;
  border-radius:18px;overflow:hidden;position:relative;
  cursor:pointer;aspect-ratio:4/3;
  box-shadow:0 4px 22px rgba(10,31,68,.1);
  transition:box-shadow .3s;
}
.gal-car-card:hover { box-shadow:0 8px 32px rgba(10,31,68,.22); }
/* Top-half grey scrim on hover — matches service/blog cards */
.gal-car-card::before {
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:50%;
  background:linear-gradient(to bottom, rgba(80,80,80,.52) 0%, transparent 100%);
  opacity:0;
  transition:opacity .4s ease;
  pointer-events:none;
  z-index:2;
}
.gal-car-card:hover::before { opacity:1; }
.gal-car-bg {
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;font-size:4.5rem;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy3) 100%);
}
.gal-car-card img {
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;transition:transform .6s cubic-bezier(.25,.46,.45,.94);
}
.gal-car-card:hover img { transform:scale(1.08); }
.gal-car-overlay {
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,31,68,.82) 0%,rgba(10,31,68,.05) 45%,transparent 100%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:22px;
  transition:background .4s ease;
}
.gal-car-card:hover .gal-car-overlay {
  background:linear-gradient(to top,rgba(10,31,68,.92) 0%,rgba(10,31,68,.15) 42%,transparent 100%);
}
.gal-car-cat {
  font-size:.62rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  color:var(--blue);background:rgba(30,144,255,.18);border:1px solid rgba(30,144,255,.28);
  padding:3px 10px;border-radius:50px;width:fit-content;margin-bottom:8px;
}
.gal-car-overlay h3 { font-size:1.05rem;font-weight:800;color:#fff;margin-bottom:4px; }
.gal-car-overlay p  { font-size:.78rem;color:rgba(255,255,255,.75);line-height:1.5; }
.gal-car-count {
  position:absolute;top:14px;right:14px;
  background:rgba(10,31,68,.72);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.16);
  color:#fff;font-size:.7rem;font-weight:700;padding:4px 12px;border-radius:50px;
}

/* ─── BLOG CARDS ─── */
.blog-car-card {
  flex:0 0 calc(33.333% - 15px); min-width:0;
  background:#fff;border:1px solid rgba(0,0,0,.09);border-radius:12px;
  overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.07);
  transition:box-shadow .3s, border-color .3s;display:flex;flex-direction:column;
  cursor:pointer;
}
.blog-car-card:hover { box-shadow:0 4px 22px rgba(0,0,0,.15); border-color:rgba(0,0,0,.12); }
.blog-car-img-wrap { position:relative;overflow:hidden; }
.blog-car-img-wrap::after {
  content:'';
  position:absolute;
  top:0;left:0;right:0;
  height:50%;
  background:linear-gradient(to bottom, rgba(80,80,80,.52) 0%, transparent 100%);
  opacity:0;
  transition:opacity .4s ease;
  pointer-events:none;
}
.blog-car-card:hover .blog-car-img-wrap::after { opacity:1; }
.blog-car-img {
  width:100%;height:200px;object-fit:cover;display:block;
  background:var(--grey);transition:transform .55s cubic-bezier(.25,.46,.45,.94);
}
.blog-car-card:hover .blog-car-img { transform:scale(1.07); }
.blog-car-tag {
  position:absolute;top:14px;left:14px;
  background:var(--blue);color:#fff;
  font-size:.62rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  padding:4px 11px;border-radius:4px;
}
.blog-car-body { padding:22px 24px 26px;flex:1;display:flex;flex-direction:column; }
.blog-car-date { font-size:.72rem;color:var(--muted-l);font-weight:600;margin-bottom:10px; }
.blog-car-body h3 { font-size:1.12rem;font-weight:700;color:var(--navy);margin-bottom:10px;line-height:1.22;transition:color .2s; }
.blog-car-card:hover:not(:has(.blog-car-link:hover)) .blog-car-body h3 { color:var(--blue); }
.blog-car-card:has(.blog-car-link:hover) .blog-car-body h3 { color:var(--navy) !important; }
.blog-car-body p   { font-size:.92rem;color:var(--muted-l);line-height:1.72;flex:1; }
.blog-car-link {
  display:inline-flex;align-items:center;gap:7px;margin-top:18px;
  font-size:.88rem;font-weight:700;color:var(--navy);
  background:none;padding:0;border:none;border-radius:0;
  text-decoration:none;
  border-bottom:1.5px solid rgba(3,45,96,.32);
  padding-bottom:2px;
  width:fit-content;transition:color .2s, border-color .2s, gap .2s;
  box-shadow:none;
}
.blog-car-link svg { display:inline-block;width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2.5;transition:transform .2s;flex-shrink:0; }
.blog-car-link:hover { background:none; box-shadow:none; text-decoration:none; color:var(--blue); border-bottom-color:var(--blue); gap:11px; }
.blog-car-link:hover svg { transform:translateX(3px); }
/* Removed: card hover rule — link reacts only to its own hover */

/* ─── RESPONSIVE ─── */
@media(max-width:900px) {
  .svc-car-card,.blog-car-card { flex:0 0 calc(50% - 11px); }
  .gal-car-card { flex:0 0 calc(50% - 11px); min-height:280px; }
}
@media(max-width:600px) {
  .svc-car-card { flex:0 0 80vw; }
  .blog-car-card { flex:0 0 80vw; }
  .gal-car-card  { flex:0 0 92vw; min-height:0; aspect-ratio:unset; height:460px; }
  .carousel-track { gap:14px; }
  .carousel-section { padding:64px 0; }
}
/* Gallery / Blog section headings — always fully visible */
.carousel-section .carousel-header.reveal {
  opacity: 1 !important;
  transform: none !important;
}
.carousel-section .carousel-header .sec-title {
  color: var(--navy) !important;
}
.carousel-section .carousel-header .sec-eyebrow {
  color: var(--blue) !important;
  opacity: 1 !important;
}
.carousel-section .carousel-header .sec-sub {
  color: var(--muted) !important;
  opacity: 1 !important;
}
@media(min-width:901px) {
  .gal-car-card { min-height:420px; }
}

/* Override any leftover purple on service icons */
.svc-card-content .svc-card-icon,
.svc-cards-grid .svc-card-icon,
.svc-feat-icon { background:var(--blue-l) !important; }
.svc-card-content .svc-card-icon svg,
.svc-cards-grid .svc-card-icon svg { stroke:var(--blue) !important; }
.svc-feat-icon { background:var(--blue) !important; }
.svc-feat-icon svg { stroke:#fff !important; }
/* ══════════════════════════════════════════════════════
   SALESFORCE DESIGN REFINEMENTS — April 2026
   ══════════════════════════════════════════════════════ */

/* ── 1. BUTTONS — no layout shift on hover ──────────── */
/* Remove all translateY from button hovers — only colour/shadow change */
.btn-primary:hover,
.btn-outline:hover,
.btn-navy:hover,
.btn-wa:hover,
.btn-white:hover,
.btn-book-nav:hover,
.btn-wa-nav:hover { transform: none !important; }

/* Keep box-shadow changes but strip movement */
.btn-primary:hover { box-shadow: 0 4px 18px rgba(1,118,211,.38); }
.btn-navy:hover    { box-shadow: 0 4px 18px rgba(3,45,96,.32); }
.btn-wa:hover      { box-shadow: 0 4px 18px rgba(37,211,102,.42); }

/* Hero CTA buttons */
.hl-btn-wa,
.hl-btn-call       { transition: background .22s, box-shadow .22s, color .22s; }
.hl-btn-wa:hover,
.hl-btn-call:hover { transform: none !important; }

/* CQ card buttons */
.cq-card:hover:not(:has(.cq-btn:hover)) { transform: none !important; }

/* ── 2. CARD HOVER — Salesforce style ───────────────── */
/* Service cards: image zoom + stronger shadow, card stays */
.svc-car-card { transition: box-shadow .32s, border-color .32s; }
.svc-car-card:hover {
  box-shadow: 0 14px 40px rgba(0,0,0,.18);
  border-color: rgba(0,0,0,.12);
  transform: none !important;
}

/* Blog cards: same */
.blog-car-card { transition: box-shadow .32s, border-color .32s; }
.blog-car-card:hover {
  box-shadow: 0 14px 40px rgba(0,0,0,.16);
  border-color: rgba(0,0,0,.12);
  transform: none !important;
}

/* Gallery cards: deeper shadow on hover, card stays */
.gal-car-card { transition: box-shadow .32s; }
.gal-car-card:hover {
  box-shadow: 0 16px 48px rgba(10,31,68,.36);
  transform: none !important;
}

/* Image zoom is already on all 3 card types — ensure consistent timing */
.svc-car-img  { transition: transform .55s cubic-bezier(.25,.46,.45,.94); }
.blog-car-img { transition: transform .55s cubic-bezier(.25,.46,.45,.94); }
.gal-car-card img { transition: transform .60s cubic-bezier(.25,.46,.45,.94); }

.svc-car-card:hover  .svc-car-img  { transform: scale(1.08); }
.blog-car-card:hover .blog-car-img { transform: scale(1.08); }
.gal-car-card:hover  img           { transform: scale(1.10); }

/* Salesforce "read more" text colour lift on hover */
/* svc/blog link hover handled above */

/* ── 3. GALLERY & BLOG ARROWS — desktop hidden, mobile shown ── */
#galPrev, #galNext,
#blogPrev, #blogNext { display: none; }

@media (max-width: 600px) {
  #galPrev, #galNext,
  #blogPrev, #blogNext { display: flex; }

  /* On mobile show arrow row for gallery & blog */
  .carousel-section #galPrev,
  .carousel-section #galNext,
  .carousel-section #blogPrev,
  .carousel-section #blogNext {
    display: flex;
  }
}

/* ── 4. SALESFORCE TYPOGRAPHY — bold, high-contrast headings ── */
h1, h2, h3, h4, h5, h6,
.sec-title, .hl-title {
  font-weight: 800;           /* Salesforce uses 800, not 900 */
  color: var(--navy);
  letter-spacing: -.022em;   /* matches Salesforce heading tightness */
}

.sec-title {
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.08;
  color: var(--navy);
}

/* Salesforce eyebrow — soft blue pill badge */
.sec-eyebrow, .sec-tag {
  background: rgba(1,118,211,.09);
  color: var(--blue);
  border: 1px solid rgba(1,118,211,.20);
  font-weight: 800;
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: 50px;       /* pill shape like Salesforce */
  display: inline-block;
  margin-bottom: 14px;
}

/* Blue accent em inside headings */
.sec-title em, .hl-title em {
  color: var(--sf-blue-acc);
  font-style: normal;
}

/* Tighten sub-text for Salesforce body style */
.sec-sub {
  font-size: .97rem;
  color: var(--muted-l);
  line-height: 1.80;
  font-weight: 400;
}

/* Section card headings (h3 inside cards) — size set per card type above */
.svc-car-body h3,
.blog-car-body h3 {
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -.02em;
}

/* ── 5. SALESFORCE CARD STYLE — white bg, clean border, inner shadow ── */
.svc-car-card,
.blog-car-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,.09);
  border-radius: var(--radius);
  box-shadow: 0 2px 12px rgba(0,0,0,.07);
}

/* ── 6. GALLERY SECTION — keep bg-navy but text contrast ── */
.carousel-section.bg-navy .sec-title { color: #fff; }
.carousel-section.bg-navy .sec-title em { color: var(--sf-blue-acc); }
.carousel-section.bg-navy .sec-sub { color: rgba(255,255,255,.65); }
.carousel-section.bg-navy .sec-eyebrow {
  background: rgba(255,255,255,.12);
  color: #A8D8FF;
  border-color: rgba(255,255,255,.2);
}
/* ══════════════════════════════════════════════════════
   APRIL 2026 — UI POLISH PASS
   ══════════════════════════════════════════════════════ */

/* ── SERVICE / BLOG CARD: half-bottom shadow on hover ── */
.svc-car-card:hover,
.blog-car-card:hover {
  box-shadow: 0 18px 44px -8px rgba(0,0,0,.22), 0 2px 8px rgba(0,0,0,.07);
}

/* ── CONTACT CARDS: stronger base border, no movement ── */
.cq-card { border:1.5px solid rgba(0,0,0,.09); transition: border-color .25s, box-shadow .25s; }
.cq-card:hover:not(:has(.cq-btn:hover)) { transform: none !important; }

/* ═══════════════════════════════════════════════════════
   DOCTOR SECTION — PREMIUM REDESIGN
   ═══════════════════════════════════════════════════════ */
.doctor-section-premium {
  background: #ffffff;
  padding: 96px 0;
  position: relative;
  overflow: hidden;
}
.doctor-section-premium::before {
  content:'';
  position:absolute;
  top:-120px;right:-120px;
  width:480px;height:480px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(1,118,211,.08) 0%, transparent 70%);
  pointer-events:none;
}
.doctor-photo-mobile { display: none; }
.doctor-section-premium .doctor-grid {
  gap:64px;
  align-items:center;
}

/* Doctor image — portrait card */
.doctor-section-premium .doctor-img-wrap {
  position:relative;
}
.doctor-section-premium .doctor-img {
  width:100%;
  aspect-ratio:4/5;
  border-radius:20px;
  overflow:hidden;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  box-shadow:0 24px 64px rgba(3,45,96,.22), 0 4px 16px rgba(0,0,0,.1);
}
.doctor-section-premium .doctor-img img {
  width:100%;height:100%;object-fit:cover;object-position:top center;
}
.doctor-section-premium .doctor-badge {
  position:absolute;
  bottom:24px;left:-20px;
  background:#fff;
  border-radius:12px;
  padding:14px 20px;
  display:flex;align-items:center;gap:12px;
  box-shadow:0 8px 32px rgba(0,0,0,.18);
  border:1px solid rgba(0,0,0,.06);
}
.doctor-section-premium .doctor-badge strong {
  font-size:1.8rem;font-weight:900;color:var(--blue);line-height:1;
}
.doctor-section-premium .doctor-badge span {
  font-size:.72rem;font-weight:700;color:var(--muted);line-height:1.3;
}

/* Doctor info panel */
.doctor-info-panel {
  display:flex;
  flex-direction:column;
  gap:0;
}
.doctor-info-panel .sec-eyebrow {
  margin-bottom:10px;
}
.doctor-info-panel h2.sec-title {
  font-size:clamp(2rem,3vw,2.8rem);
  margin-bottom:6px;
}
.doctor-info-panel .doctor-title {
  font-size:1rem;
  color:var(--blue);
  font-weight:700;
  margin-bottom:28px;
}

/* Mini stats row */
.doctor-mini-stats {
  display:flex;
  gap:0;
  margin-bottom:28px;
  border:1px solid rgba(1,118,211,.18);
  border-radius:12px;
  overflow:hidden;
  background:#fff;
  box-shadow:0 2px 12px rgba(0,0,0,.06);
}
.doctor-mini-stat {
  flex:1;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:20px 16px;
  text-align:center;
  border-right:1px solid rgba(1,118,211,.14);
}
.doctor-mini-stat:last-child { border-right:none; }
.doctor-mini-stat strong {
  display:block;
  font-size:1.9rem;
  font-weight:900;
  color:var(--blue);
  line-height:1;
  margin-bottom:5px;
}
.doctor-mini-stat span {
  font-size:.74rem;
  color:var(--muted-l);
  font-weight:600;
  line-height:1.3;
}

/* Doctor description */
.doctor-info-panel .doctor-desc {
  font-size:1rem;
  color:var(--muted);
  line-height:1.82;
  margin-bottom:24px;
  border-left:3px solid var(--blue);
  padding-left:16px;
}

/* Qual tags */
.doctor-info-panel .qual-tags {
  display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px;
}
.doctor-info-panel .qual-tag {
  background:var(--blue-l);
  border:1px solid rgba(1,118,211,.2);
  color:var(--navy);
  font-size:.78rem;font-weight:700;
  padding:6px 14px;border-radius:50px;
  transition:background .2s,border-color .2s;
}
.doctor-info-panel .qual-tag:hover {
  background:var(--blue);color:#fff;border-color:var(--blue);
}

/* Responsive doctor */
@media(max-width:900px) {
  .doctor-section-premium .doctor-grid {
    grid-template-columns:1fr;gap:40px;
  }
  .doctor-section-premium .doctor-img-wrap { max-width:380px;margin:0 auto; }
  .doctor-section-premium .doctor-badge { left:0; }
  /* Hide left-col photo, show inline mobile photo */
  .doctor-img-wrap:not(.doctor-photo-mobile) { display:none !important; }
  .doctor-photo-mobile { display:block !important; margin:24px 0 8px; max-width:100%; }
  .doctor-photo-mobile .doctor-img { aspect-ratio:4/3; border-radius:14px; }
  .doctor-photo-mobile .doctor-badge { left:0; }
}
@media(max-width:600px) {
  .doctor-section-premium { padding:64px 0; }
  .doctor-mini-stats { flex-direction:row; }
  .doctor-mini-stat { padding:16px 10px; }
  .doctor-mini-stat strong { font-size:1.4rem; }
  .doctor-info-panel .doctor-desc { font-size:.93rem; }
}

/* ══════════════════════════════════════
   INSIDE CLINIC BANNER — CINEMATIC SECTION
   ══════════════════════════════════════ */
.clinic-banner-section {
  position: relative;
  height: 680px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  text-align: center;
}

/* Laptop / desktop breakpoint — keep it tall */
@media(min-width:1024px) {
  .clinic-banner-section { height: 720px; }
}

/* ── VIDEO EMBED inside clinic banner ── */
.clinic-banner-video-wrap {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.clinic-banner-video-wrap video,
.clinic-banner-video-wrap iframe {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  pointer-events: none;
}
/* When using a video, hide the static bg image */
.clinic-banner-section.has-video .clinic-banner-bg {
  display: none;
}
/* Play button overlay — for modal video trigger */
.clinic-video-play-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: rgba(255,255,255,.92);
  border: none;
  cursor: pointer;
  box-shadow: 0 8px 40px rgba(0,0,0,.35);
  transition: all .3s;
  margin-bottom: 8px;
}
.clinic-video-play-btn svg {
  width: 28px;
  height: 28px;
  color: var(--navy);
  margin-left: 4px;
}
.clinic-video-play-btn:hover {
  transform: scale(1.1);
  background: #fff;
  box-shadow: 0 16px 56px rgba(0,0,0,.45);
}
/* Video modal overlay */
.clinic-video-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: rgba(0,0,0,.86);
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(6px);
}
.clinic-video-modal.open {
  display: flex;
}
.clinic-video-modal-inner {
  position: relative;
  width: min(900px, 92vw);
  aspect-ratio: 16/9;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 32px 80px rgba(0,0,0,.5);
}
.clinic-video-modal-inner video,
.clinic-video-modal-inner iframe {
  width: 100%;
  height: 100%;
  border: none;
  display: block;
}
.clinic-video-modal-close {
  position: absolute;
  top: -44px;
  right: 0;
  background: rgba(255,255,255,.12);
  border: none;
  color: #fff;
  font-size: 1.6rem;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s;
}
.clinic-video-modal-close:hover { background: rgba(255,255,255,.25); }
.clinic-banner-bg {
  position: absolute;
  inset: 0;
  background-image: url('assets/clinic-interior.jpeg');
  background-size: cover;
  background-position: center 30%;
  background-repeat: no-repeat;
  transform: scale(1.04);
  transition: transform 8s ease;
}
.clinic-banner-section:hover .clinic-banner-bg { transform: scale(1.07); }
.clinic-banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(3,45,96,.45) 0%,
    rgba(3,45,96,.62) 60%,
    rgba(3,45,96,.72) 100%
  );
}
.clinic-banner-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
  padding: 0 20px;
}
.clinic-banner-eyebrow {
  display: inline-block;
  background: rgba(255,255,255,.15);
  color: #fff;
  border: 1px solid rgba(255,255,255,.35);
  padding: 5px 18px;
  border-radius: 50px;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  backdrop-filter: blur(6px);
}
.clinic-banner-title {
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.15;
  letter-spacing: -.02em;
  max-width: 700px;
  text-shadow: 0 2px 20px rgba(0,0,0,.3);
}
.clinic-banner-title em {
  color: #7DC8FF;
  font-style: normal;
}
.clinic-banner-btn { display: none; }
.clinic-banner-play {
  width: 38px;
  height: 38px;
  background: var(--navy);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  flex-shrink: 0;
  transition: background .3s;
}
.clinic-banner-btn:hover .clinic-banner-play { background: var(--blue); }
.clinic-banner-play svg {
  width: 14px; height: 14px;
  margin-left: 2px;
}

@media(max-width:600px) {
  .clinic-banner-section { height: 480px; }
  .clinic-banner-title { font-size: 1.5rem; line-height: 1.3; }
  .clinic-banner-btn { padding: 12px 22px; font-size: .88rem; }
}

/* Clinic video label under play button */
.clinic-video-label {
  color: rgba(255,255,255,.80);
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  margin-top: -12px;
}
/* ═══════════════════════════════════════════════════════════
   SITE OVERRIDES — Navbar, Services Grid, Blog Grid
   ═══════════════════════════════════════════════════════════ */

/* ── NAVBAR REDESIGN ── */
.navbar {
  background: rgba(255,255,255,0.98) !important;
  border-bottom: none !important;
  border-top: 3px solid var(--blue) !important;
  box-shadow: 0 2px 24px rgba(1,118,211,.10), 0 1px 0 rgba(0,0,0,.05) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.navbar.scrolled {
  box-shadow: 0 4px 28px rgba(1,118,211,.16), 0 1px 0 rgba(0,0,0,.07) !important;
}
/* Nav links: pill highlight */
.nav-links a {
  padding: 7px 14px !important;
  border-radius: 8px !important;
  font-size: .88rem !important;
  font-weight: 600 !important;
  opacity: 1 !important;
  color: var(--muted) !important;
  letter-spacing: .01em;
  transition: all .18s !important;
}
.nav-links a:hover {
  background: var(--blue-xl) !important;
  color: var(--blue) !important;
  border: none !important;
}
.nav-links a.active {
  background: var(--blue-xl) !important;
  color: var(--blue) !important;
  font-weight: 700 !important;
  border: none !important;
}
/* Appointment CTA — styled blue instead of WhatsApp green */
.btn-wa-nav,
.btn-book-nav {
  background: var(--blue) !important;
  box-shadow: 0 2px 14px rgba(1,118,211,.28) !important;
  border-radius: 8px !important;
  padding: 10px 20px !important;
  font-size: .85rem !important;
}
.btn-wa-nav:hover,
.btn-book-nav:hover {
  background: var(--navy) !important;
  box-shadow: 0 4px 18px rgba(3,45,96,.30) !important;
  transform: translateY(-1px) !important;
}

/* ── HOME PAGE: Services 3×2 Static Grid ── */
.svc-home-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media(max-width:960px) {
  .svc-home-grid { grid-template-columns: repeat(2, 1fr); }
}
@media(max-width:600px) {
  .svc-home-grid { grid-template-columns: 1fr; }
}

/* ── SERVICES PAGE: 3-col on desktop, slider on mobile ── */
@media(min-width:769px) {
  .svc-cards-grid { grid-template-columns: repeat(3, 1fr) !important; gap: 22px; }
  .svc-page-arrows { display: none !important; }
  #svcDots { display: none !important; }
}
@media(max-width:768px) {
  .svc-cards-grid {
    display: flex !important;
    flex-direction: row !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    gap: 14px !important;
    padding: 8px 4px 12px !important;
    scrollbar-width: thin;
    scrollbar-color: var(--blue) var(--blue-xl);
  }
  .svc-cards-grid::-webkit-scrollbar { height: 4px; }
  .svc-cards-grid::-webkit-scrollbar-thumb { background: var(--blue); border-radius: 4px; }
  .svc-cards-grid .svc-card {
    flex: 0 0 82vw !important;
    scroll-snap-align: start !important;
    min-width: 280px !important;
    width: auto !important;
  }
  .svc-cards-grid .svc-card .svc-card-img { height: 280px !important; }
  .svc-page-arrows {
    display: flex !important;
    justify-content: center;
    gap: 12px;
    margin-top: 18px;
  }
  .svc-page-btn {
    width: 46px; height: 46px; border-radius: 50%;
    background: #fff; border: 1.5px solid var(--border);
    box-shadow: 0 2px 12px rgba(0,0,0,.10);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: all .2s;
  }
  .svc-page-btn:hover { background: var(--blue); border-color: var(--blue); }
  .svc-page-btn:hover svg { stroke: #fff; }
  .svc-page-btn svg { width: 18px; height: 18px; stroke: var(--navy); fill: none; stroke-width: 2.5; }
}

/* ── BLOG PAGE: 3×2 grid desktop, horizontal scroll + arrows BELOW on mobile ── */
@media(min-width:769px) {
  .blog-scroll-wrap { padding: 0 !important; overflow: visible !important; }
  .blog-scroll {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    overflow-x: visible !important;
    scroll-snap-type: none !important;
    padding: 8px 0 16px !important;
  }
  .blog-card { flex: none !important; width: 100% !important; }
  .blog-arrow { display: none !important; }
  .blog-arrows-below { display: none !important; }
}
@media(max-width:768px) {
  .blog-scroll-wrap { padding: 0 !important; overflow: visible !important; }
  .blog-scroll {
    overflow-x: auto !important;
    scroll-snap-type: x mandatory !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 8px 4px 12px !important;
  }
  .blog-card { flex: 0 0 82vw !important; scroll-snap-align: start !important; min-width: 280px !important; }
  .blog-arrow-left,
  .blog-arrow-right { display: none !important; }
  .blog-arrows-below { display: flex !important; }
}
/* ── BLOG PAGE: below-cards arrow row (mobile only) ── */
.blog-arrows-below {
  display: none;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-top: 20px;
}
.blog-below-btn {
  width: 46px; height: 46px;
  border-radius: 50%;
  background: #fff;
  border: 1.5px solid var(--border);
  box-shadow: 0 2px 12px rgba(0,0,0,.10);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all .2s;
}
.blog-below-btn:hover { background: var(--blue); border-color: var(--blue); }
.blog-below-btn:hover svg { stroke: #fff; }
.blog-below-btn svg { width: 18px; height: 18px; stroke: var(--navy); fill: none; stroke-width: 2.5; }
/* ── SERVICES PAGE — APPOINTMENT CTA BANNER ── */
.svc-appt-banner {
  background: var(--navy);
  padding: 64px 0;
  border-top: 3px solid var(--blue);
}
.svc-appt-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
}
.svc-appt-eyebrow {
  display: inline-block;
  background: rgba(1,118,211,.25);
  color: #7DC8FF;
  padding: 4px 14px;
  border-radius: 4px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.svc-appt-title {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 900;
  color: #fff;
  margin-bottom: 8px;
  letter-spacing: -.02em;
}
.svc-appt-sub {
  font-size: .93rem;
  color: rgba(255,255,255,.65);
  max-width: 420px;
  line-height: 1.7;
}
.svc-appt-btns {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  flex-shrink: 0;
}
.svc-appt-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 26px;
  border-radius: 8px;
  font-size: .95rem;
  font-weight: 700;
  text-decoration: none;
  transition: all .25s;
  white-space: nowrap;
}
.svc-appt-btn-wa {
  background: #25D366;
  color: #fff;
  box-shadow: 0 2px 14px rgba(37,211,102,.30);
}
.svc-appt-btn-wa:hover {
  background: #1ebe5d;
  transform: translateY(-2px);
  box-shadow: 0 6px 22px rgba(37,211,102,.42);
}
.svc-appt-btn-call {
  background: rgba(255,255,255,.10);
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.30);
}
.svc-appt-btn-call:hover {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.55);
  transform: translateY(-2px);
}
@media(max-width: 768px) {
  .svc-appt-inner { flex-direction: column; align-items: flex-start; gap: 28px; }
  .svc-appt-btns { width: 100%; flex-direction: column; }
  .svc-appt-btn { width: 100%; justify-content: center; }
}
/* ── PAGE HEADER — CTA BUTTONS (services page) ── */
.page-header-btns {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 28px;
}
.phdr-btn {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 13px 24px;
  border-radius: 8px;
  font-size: .92rem;
  font-weight: 700;
  text-decoration: none;
  transition: all .25s;
  white-space: nowrap;
}
.phdr-btn-wa {
  background: #25D366;
  color: #fff;
  box-shadow: 0 2px 14px rgba(37,211,102,.35);
}
.phdr-btn-wa:hover {
  background: #1ebe5d;
  transform: translateY(-2px);
  box-shadow: 0 6px 22px rgba(37,211,102,.45);
}
.phdr-btn-call {
  background: rgba(255,255,255,.15);
  color: #fff;
  border: 1.5px solid rgba(255,255,255,.40);
  backdrop-filter: blur(8px);
}
.phdr-btn-call:hover {
  background: rgba(255,255,255,.25);
  border-color: rgba(255,255,255,.70);
  transform: translateY(-2px);
}
@media(max-width: 600px) {
  .page-header-btns { flex-direction: column; align-items: center; }
  .phdr-btn { width: 100%; max-width: 320px; justify-content: center; }
}