/* ===== DESIGN TOKENS ===== */
:root{
  --teal:#066b6b;
  --teal-dark:#044f4f;
  --teal-light:#0a8585;
  --navy:#0d2438;
  --navy-light:#16334d;
  --gold:#d4af37;
  --gold-soft:#e6c75e;
  --white:#ffffff;
  --off:#f4f8f8;
  --ink:#1a2b35;
  --muted:#5e7682;
  --line:#e2ecec;
  --whatsapp:#25d366;
  --shadow:0 10px 35px rgba(13,36,56,.12);
  --shadow-sm:0 4px 16px rgba(13,36,56,.08);
  --radius:16px;
  --max:1180px;
  --serif:'Playfair Display',serif;
  --sans:'Inter',system-ui,sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:120px;overflow-x:hidden}
body{font-family:var(--sans);color:var(--ink);background:var(--white);line-height:1.65;overflow-x:hidden}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{max-width:var(--max);margin:0 auto;padding:0 22px}
.section{padding:84px 0}
h1,h2,h3,h4{font-family:var(--serif);line-height:1.2;color:var(--navy)}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.85rem 1.6rem;border-radius:50px;font-weight:600;font-size:.95rem;transition:.25s;cursor:pointer;border:none;white-space:nowrap}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:var(--navy)}
.btn-whatsapp{background:var(--whatsapp);color:#fff}
.btn-navy{background:var(--navy);color:#fff}
.btn-outline{background:transparent;border:2px solid var(--teal);color:var(--teal)}
.btn-lg{padding:1rem 1.8rem;font-size:1rem}

/* ===== TOP BAR ===== */
.topbar{background:var(--navy);color:#cfe3e3;font-size:.82rem}
.topbar-inner{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;padding:.5rem 22px}
.topbar a{color:#cfe3e3;transition:.2s}
.topbar a:hover{color:var(--gold)}
.topbar-item i{color:var(--gold);margin-right:.3rem}
.topbar-socials{margin-left:auto;display:flex;gap:.7rem}
.topbar-socials a:hover{color:var(--gold)}

/* ===== NAVBAR ===== */
.navbar{position:sticky;top:0;z-index:900;background:rgba(255,255,255,.97);backdrop-filter:blur(8px);box-shadow:var(--shadow-sm);transition:.3s}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;padding:.7rem 22px}
.navbar-logo{display:flex;align-items:center}
.navbar-logo img{height:52px;width:auto;display:block}
/* brand-mark retained for footer use */
.brand{display:flex;align-items:center;gap:.7rem}
.brand-mark{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--teal),var(--teal-light));color:#fff;display:grid;place-items:center;font-size:1.1rem;box-shadow:var(--shadow-sm)}
.brand-text strong{display:block;font-family:var(--serif);font-size:1.1rem;color:var(--navy);line-height:1.1}
.brand-text small{font-size:.72rem;color:var(--teal);font-weight:600;letter-spacing:.5px}
.nav-links{display:flex;align-items:center;gap:1.4rem}
.nav-links a{font-weight:500;font-size:.92rem;color:var(--ink);transition:.2s}
.nav-links a:hover{color:var(--teal)}
.nav-cta{background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:var(--navy)!important;padding:.55rem 1.2rem;border-radius:50px;font-weight:600}
.nav-cta:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.nav-toggle{display:none;background:none;border:none;font-size:1.5rem;color:var(--navy);cursor:pointer}

/* ===== HERO ===== */
.hero{position:relative;background:linear-gradient(135deg,var(--navy) 0%,var(--teal-dark) 60%,var(--teal) 100%);color:#fff;overflow:hidden}
.hero-overlay{position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(212,175,55,.18),transparent 45%);pointer-events:none}
.hero-inner{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;padding:72px 22px}
.hero-eyebrow{display:inline-block;background:rgba(212,175,55,.18);color:var(--gold-soft);padding:.4rem 1rem;border-radius:50px;font-size:.78rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;margin-bottom:1rem}
.hero h1{color:#fff;font-size:clamp(2.4rem,5vw,3.6rem);margin-bottom:.4rem}
.hero-urdu{font-family:'Noto Nastaliq Urdu',serif;font-size:1.4rem;color:var(--gold-soft);margin-bottom:.6rem;line-height:2}
.hero-quals{font-weight:600;letter-spacing:1px;color:#bfe0e0;margin-bottom:1rem}
.hero-sub{color:#dcecec;max-width:520px;margin-bottom:1.8rem}
.hero-sub strong{color:var(--gold-soft)}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.2rem}
.hero-stats{display:flex;gap:2rem;flex-wrap:wrap}
.hero-stat strong{display:block;font-family:var(--serif);font-size:1.7rem;color:var(--gold-soft)}
.hero-stat span{font-size:.82rem;color:#bfe0e0}
/* ===== HERO PHOTO — matches old 60:40 design exactly ===== */
.hero-photo{
  position:relative;
  /* container is the styled card — not the img */
  width:100%;
  max-width:420px;
  margin-left:auto;
  aspect-ratio:4/5;
  border-radius:22px;
  border:5px solid rgba(255,255,255,.14);
  box-shadow:0 28px 64px rgba(0,0,0,.38);
  overflow:hidden;           /* clips the img inside */
}
.hero-photo picture{
  display:block;
  width:100%;
  height:100%;
}
.hero-photo img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center top; /* face stays in frame */
  display:block;
  border-radius:0;            /* radius already on .hero-photo */
  border:none;
  box-shadow:none;
}
.hero-badge{position:absolute;bottom:18px;left:-8px;background:#fff;color:var(--teal);padding:.6rem 1.1rem;border-radius:50px;font-weight:600;font-size:.85rem;box-shadow:var(--shadow);z-index:2}
.hero-badge i{color:var(--whatsapp);margin-right:.3rem}

/* ===== TRUST BAR ===== */
.trust-bar{background:var(--off);border-bottom:1px solid var(--line)}
.trust-inner{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 2.4rem;padding:1.3rem 22px}
.trust-item{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem;color:var(--navy)}
.trust-item i{color:var(--gold);font-size:1.1rem}

/* ===== SECTION HEAD ===== */
.section-head{text-align:center;max-width:680px;margin:0 auto 52px}
.section-eyebrow{display:inline-block;color:var(--teal);font-weight:700;font-size:.8rem;letter-spacing:2px;text-transform:uppercase;margin-bottom:.6rem}
.section-eyebrow.light{color:var(--gold-soft)}
.section-head h2{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:.6rem}
.section-lead{color:var(--muted);font-size:1.05rem}

/* ===== ABOUT ===== */
.about{background:var(--white)}
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
.about-img{position:relative}
.about-img img{border-radius:20px;box-shadow:var(--shadow);width:100%;object-fit:cover;aspect-ratio:4/5}
.about-langs{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem;justify-content:center}
.about-langs span{background:var(--off);color:var(--teal);padding:.4rem .9rem;border-radius:50px;font-size:.82rem;font-weight:600}
.about-content h2{font-size:clamp(1.7rem,3vw,2.4rem);margin-bottom:1rem}
.about-content p{color:var(--muted);margin-bottom:1rem}
.about-content p strong{color:var(--ink)}
.timeline,.hospitals{margin-top:1.6rem}
.timeline h3,.hospitals h3{font-size:1.2rem;color:var(--teal);margin-bottom:.8rem}
.timeline ul,.hospitals ul{list-style:none}
.timeline li{display:flex;gap:1rem;padding:.6rem 0;border-bottom:1px dashed var(--line)}
.tl-year{flex:0 0 60px;font-weight:700;color:var(--gold);font-family:var(--serif)}
.tl-text{color:var(--muted)}
.tl-text strong{color:var(--ink)}
.hospitals li{padding:.5rem 0;color:var(--muted)}
.hospitals li i{color:var(--teal);margin-right:.6rem}
.hospitals li em{color:var(--gold);font-style:normal;font-weight:600}

/* ===== SIGNATURE SERVICES ===== */
.signature{background:var(--off)}
.signature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.sig-card{background:#fff;border-radius:var(--radius);padding:2rem 1.6rem;box-shadow:var(--shadow-sm);transition:.3s;border:1px solid var(--line);position:relative}
.sig-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.sig-icon{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,var(--teal),var(--teal-light));color:#fff;display:grid;place-items:center;font-size:1.6rem;margin-bottom:1.2rem}
.sig-card h3{font-size:1.25rem;margin-bottom:.5rem}
.sig-card p{color:var(--muted);font-size:.93rem}
.sig-feature{grid-row:span 2;grid-column:1;background:linear-gradient(160deg,var(--navy),var(--teal-dark));color:#fff;display:flex;flex-direction:column;justify-content:center}
.sig-feature h3{color:#fff;font-size:1.7rem}
.sig-feature p{color:#cfe3e3}
.sig-feature .sig-icon{background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:var(--navy);width:74px;height:74px;font-size:1.9rem}
.sig-tag{display:inline-block;background:rgba(212,175,55,.2);color:var(--gold-soft);padding:.3rem .9rem;border-radius:50px;font-size:.72rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin-bottom:.6rem;width:fit-content}
.sig-urdu{font-family:'Noto Nastaliq Urdu',serif;color:var(--gold-soft)!important;font-size:1.1rem;margin-bottom:.6rem!important}
.sig-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;color:var(--gold-soft);font-weight:600}
.sig-link i{transition:.2s}
.sig-link:hover i{transform:translateX(5px)}

/* ===== GALLERY / BEFORE-AFTER ===== */
.gallery{background:var(--white)}

/* === Case label (shared by all before/after cards) === */
.case-label{font-size:.76rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--teal)}

/* === Card Grid === */
.ba-cards-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:36px}
.ba-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--line);padding:1rem}
.ba-card .case-label{display:block;margin-bottom:.6rem}
.ba-card-wide{grid-column:span 2}

/* === Vertical Before / After stack (Before on top, After below) === */
/* Each image is shown in full — NO cropping. object-fit:contain on a flexible
   container respects the photo's natural aspect ratio so burned-in text and
   any edge detail is always fully visible on desktop, tablet and mobile. */
.ba-card-stack{display:flex;flex-direction:column;gap:12px}
.ba-shot{position:relative;margin:0;border-radius:12px;overflow:hidden;background:#0b0b0b;line-height:0}
/* Image scales to the card width and keeps its own height — nothing is trimmed */
.ba-shot img{display:block;width:100%;height:auto;max-width:100%;object-fit:contain}
.ba-card-tag{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);padding:.25rem .75rem;border-radius:50px;font-size:.72rem;font-weight:700;letter-spacing:1px;white-space:nowrap;z-index:5}
/* The wide Case 5 card spans two columns; cap its image width and centre it so
   it stays balanced with the other cards while remaining fully uncropped. */
.ba-card-wide .ba-shot img{max-width:560px;margin:0 auto}
.before-tag{background:rgba(13,36,56,.8);color:#fff}
.after-tag{background:rgba(6,107,107,.9);color:#fff}
.ba-card-desc{font-size:.82rem;color:var(--muted);margin-top:.7rem;text-align:center}

/* ===== "Watch on TikTok" badge (gallery before/after) ===== */
/* min 40x40 tap target on mobile; icon looks smaller via padding.
   Sits in the bottom-right corner of the Before image only. */
.tt-badge{
  position:absolute;
  right:10px;
  bottom:10px;
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  border-radius:10px;
  background:rgba(0,0,0,.55);
  -webkit-backdrop-filter:blur(6px);
  backdrop-filter:blur(6px);
  color:#fff;
  font-size:.95rem;
  text-decoration:none;
  box-shadow:0 2px 10px rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.25);
  z-index:15;            /* above the image and Before/After tag */
  pointer-events:auto;
  cursor:pointer;
  transition:background .2s ,transform .2s;
}
.tt-badge:hover{background:rgba(0,0,0,.78);transform:scale(1.06)}
.tt-badge i{pointer-events:none}
/* invisible hit-area extension so the tap target is >=40x40 on touch */
.tt-badge::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;border-radius:12px}
/* slightly smaller visual chip inside cards, same tap area */
.ba-shot .tt-badge{right:8px;bottom:8px;width:30px;height:30px;font-size:.85rem}

.video-feature{background:linear-gradient(135deg,var(--navy),var(--teal-dark));border-radius:var(--radius);padding:2.4rem;color:#fff;text-align:center;margin-bottom:1.2rem}
.video-feature h3{color:#fff;font-size:1.5rem;margin-bottom:.6rem}
.video-feature h3 i{color:#1877f2}
.video-feature p{color:#cfe3e3;max-width:560px;margin:0 auto 1.4rem}
.video-feature-btns{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.video-feature-btns .btn-outline{border-color:#fff;color:#fff}
.gallery-note{text-align:center;color:var(--muted);font-size:.82rem;font-style:italic}

/* ===== ALL SERVICES ===== */
.all-services{background:var(--off)}
.service-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.service-item{background:#fff;border-radius:12px;padding:1.1rem 1.2rem;display:flex;align-items:center;gap:.9rem;box-shadow:var(--shadow-sm);transition:.25s;border:1px solid var(--line)}
.service-item:hover{transform:translateY(-3px);border-color:var(--teal)}
.service-item i{color:var(--teal);font-size:1.2rem;flex-shrink:0;width:24px;text-align:center}
.service-item span{font-size:.92rem;font-weight:500}
.service-item small{display:block;font-family:'Noto Nastaliq Urdu',serif;color:var(--gold);font-size:.85rem}
.conditions{margin-top:48px;background:#fff;border-radius:var(--radius);padding:2rem;box-shadow:var(--shadow-sm)}
.conditions h3{font-size:1.3rem;color:var(--teal);margin-bottom:1.2rem;text-align:center}
.condition-tags{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}
.condition-tags span{background:var(--off);color:var(--navy);padding:.45rem 1rem;border-radius:50px;font-size:.85rem;border:1px solid var(--line);transition:.2s}
.condition-tags span:hover{background:var(--teal);color:#fff;border-color:var(--teal)}

/* ===== CLINICS ===== */
.clinics{background:var(--white)}
.clinic-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:22px;margin-bottom:48px}
.clinic-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--line);transition:.3s;display:flex;flex-direction:column}
.clinic-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.clinic-head{background:linear-gradient(135deg,var(--teal),var(--teal-dark));color:#fff;padding:1.1rem 1.3rem;display:flex;align-items:center;gap:.7rem}
.clinic-head i{font-size:1.3rem;color:var(--gold-soft)}
.clinic-head h3{color:#fff;font-size:1.1rem}
.clinic-body{padding:1.2rem 1.3rem;flex:1}
.clinic-body p{color:var(--muted);font-size:.9rem;margin-bottom:.5rem}
.clinic-body p i{color:var(--teal);width:18px;margin-right:.3rem}
.clinic-fee{display:inline-block;background:var(--off);color:var(--teal);font-weight:700;padding:.35rem .9rem;border-radius:50px;font-size:.85rem;margin-top:.4rem}
.clinic-online .clinic-head{background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:var(--navy)}
.clinic-online .clinic-head i,.clinic-online .clinic-head h3{color:var(--navy)}
.maps{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.map-box h3{font-size:1.05rem;color:var(--navy);margin-bottom:.8rem}
.map-box h3 i{color:var(--teal)}
.map-box iframe{width:100%;height:300px;border:0;border-radius:var(--radius);box-shadow:var(--shadow-sm)}

/* ===== CLINICS — desktop/laptop balance (single location) ===== */
/* Mobile (<=760px) layout is handled in the media query below and is left unchanged. */
@media(min-width:761px){
  /* Centre the single clinic card so it isn't stretched edge-to-edge */
  .clinic-grid{grid-template-columns:1fr;max-width:560px;margin-left:auto;margin-right:auto}
  /* Single map: full width, comfortable height, centred for balance */
  .maps{grid-template-columns:1fr;max-width:820px;margin-left:auto;margin-right:auto}
  .maps .map-box iframe{height:380px}
}

/* ===== REVIEWS ===== */
.reviews{background:var(--off)}
.rating-badges{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;margin-top:1.2rem}
.rating-badge{background:#fff;border-radius:14px;padding:.9rem 1.4rem;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:.8rem;border:1px solid var(--line)}
.rating-badge strong{font-family:var(--serif);font-size:1.8rem;color:var(--gold)}
.rating-badge span{font-size:.82rem;color:var(--muted);text-align:left}
.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px}
.review-card{background:#fff;border-radius:var(--radius);padding:1.8rem;box-shadow:var(--shadow-sm);border:1px solid var(--line);position:relative}
.review-card .quote-mark{font-size:2.5rem;color:var(--teal);opacity:.18;position:absolute;top:12px;right:18px;font-family:var(--serif)}
.review-stars{color:var(--gold);margin-bottom:.8rem}
.review-card p{color:var(--ink);font-style:italic;margin-bottom:1rem}
.review-meta{display:flex;align-items:center;justify-content:space-between}
.review-author{font-weight:600;color:var(--navy)}
.review-src{font-size:.75rem;color:#fff;background:var(--teal);padding:.2rem .7rem;border-radius:50px}

/* ===== BOOK ===== */
.book{background:var(--off)}
.book-card{background:linear-gradient(135deg,var(--navy),var(--teal-dark));border-radius:24px;padding:3rem;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;box-shadow:var(--shadow)}
.book-text h2{color:#fff;font-size:2.2rem;margin-bottom:.6rem}
.book-text p{color:#cfe3e3}
.book-btns{display:flex;flex-direction:column;gap:1rem}
.book-btns .btn-outline{border-color:#fff;color:#fff}

/* ===== FOOTER ===== */
.footer{background:var(--navy);color:#bfd4d4}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:60px 22px 40px}
.footer-brand{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}
.footer-brand strong{color:#fff;font-family:var(--serif);font-size:1.15rem}
.footer-brand small{color:var(--gold-soft)}
.footer-about{font-size:.9rem;line-height:1.7;margin-bottom:1.2rem}
.footer-socials{display:flex;gap:.7rem}
.footer-socials a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff;transition:.25s}
.footer-socials a:hover{background:var(--gold);color:var(--navy);transform:translateY(-3px)}
.footer-col h4{color:#fff;font-size:1.05rem;margin-bottom:1rem}
.footer-list{list-style:none}
.footer-list li{font-size:.88rem;margin-bottom:.7rem;line-height:1.5}
.footer-list li strong{color:#fff}
.footer-list a{transition:.2s}
.footer-list a:hover{color:var(--gold)}
.footer-list i{color:var(--gold);margin-right:.4rem}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:1.2rem 0;text-align:center;font-size:.82rem}
.footer-nav{display:flex;justify-content:center;flex-wrap:wrap;gap:.4rem 1.4rem;margin-bottom:.8rem}
.footer-nav a{color:#bfd4d4;font-weight:500;transition:.2s}
.footer-nav a:hover{color:var(--gold)}

/* ===== FLOATING BUTTONS ===== */
.float-btn{position:fixed;z-index:950;display:flex;align-items:center;gap:.5rem;border-radius:50px;box-shadow:0 6px 20px rgba(0,0,0,.25);font-weight:600;transition:.3s}
.float-whatsapp{bottom:24px;right:24px;background:var(--whatsapp);color:#fff;padding:.85rem 1.4rem;font-size:.95rem;animation:pulse 2.2s infinite}
.float-whatsapp i{font-size:1.3rem}
.float-whatsapp:hover{transform:translateY(-3px)}
.float-book{bottom:24px;left:24px;background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:var(--navy);padding:.85rem 1.4rem;font-size:.95rem}
.float-book:hover{transform:translateY(-3px)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* ===== SUB-PAGES (About / Contact / Privacy) ===== */
.page-hero{background:linear-gradient(135deg,var(--navy),var(--teal-dark));color:#fff;padding:64px 0 56px;text-align:center}
.page-hero h1{color:#fff;font-size:2.4rem;margin-bottom:.6rem}
.page-hero p{color:#cfe3e3;max-width:680px;margin:0 auto;font-size:1rem}
.page-hero .breadcrumb{font-size:.82rem;color:var(--gold-soft);margin-bottom:1rem}
.page-hero .breadcrumb a{color:var(--gold-soft)}
.page-hero .breadcrumb a:hover{color:#fff}
.page-body{padding:64px 0}
.page-prose{max-width:820px;margin:0 auto}
.page-prose h2{font-size:1.6rem;margin:1.8rem 0 .8rem;color:var(--navy)}
.page-prose h3{font-size:1.15rem;margin:1.4rem 0 .5rem;color:var(--teal)}
.page-prose p{color:var(--muted);margin-bottom:1rem;line-height:1.8}
.page-prose ul{margin:0 0 1.2rem 1.2rem;color:var(--muted);line-height:1.8}
.page-prose li{margin-bottom:.4rem}
.page-prose strong{color:var(--ink)}
.page-prose a{color:var(--teal);font-weight:600}
.page-prose a:hover{color:var(--gold)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px;max-width:980px;margin:0 auto;align-items:start}
.contact-cards{display:grid;gap:18px}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:1.4rem 1.5rem}
.contact-card h3{display:flex;align-items:center;gap:.6rem;font-size:1.05rem;color:var(--navy);margin-bottom:.6rem;font-family:var(--sans)}
.contact-card h3 i{color:var(--teal)}
.contact-card p,.contact-card a{color:var(--muted);font-size:.92rem;line-height:1.7;display:block}
.contact-card a{color:var(--teal);font-weight:500}
.contact-card a:hover{color:var(--gold)}
.contact-map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);min-height:360px;border:1px solid var(--line)}
.contact-map iframe{width:100%;height:100%;min-height:360px;border:0;display:block}
.about-page-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:40px;align-items:start;max-width:1000px;margin:0 auto}
.about-page-grid img{border-radius:var(--radius);box-shadow:var(--shadow)}
.cred-list{list-style:none;margin:0!important}
.cred-list li{padding-left:1.6rem;position:relative}
.cred-list li::before{content:"\f00c";font-family:"Font Awesome 6 Free";font-weight:900;color:var(--teal);position:absolute;left:0;top:.15rem;font-size:.8rem}
@media(max-width:820px){
  .contact-grid,.about-page-grid{grid-template-columns:1fr}
  .page-hero h1{font-size:1.9rem}
}

/* ===== REVEAL ANIMATION ===== */
.reveal{opacity:0;transform:translateY(36px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* ===== RESPONSIVE ===== */
/* ===== ABOUT — extras ===== */
.about-urdu{font-family:'Noto Nastaliq Urdu',serif;font-size:1.1rem;color:var(--gold);margin-bottom:.8rem;line-height:2}
.about-philosophy{margin-top:1.6rem;background:var(--off);border-left:4px solid var(--gold);border-radius:0 12px 12px 0;padding:1.2rem 1.4rem}
.about-philosophy h3{font-size:1.1rem;color:var(--teal);margin-bottom:.7rem}
.about-philosophy h3 i{color:var(--gold);margin-right:.5rem}
.about-philosophy p{color:var(--muted);margin-bottom:.5rem;font-size:.93rem}

/* ===== SIGNATURE — urdu sub-label ===== */
.sig-urdu-sm{font-family:'Noto Nastaliq Urdu',serif;font-size:.95rem;color:var(--gold);margin-bottom:.4rem!important;display:block;line-height:2}

/* ===== BEFORE/AFTER INFO ROW ===== */
.ba-info-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px}
.ba-info-item{display:flex;align-items:flex-start;gap:.7rem;background:var(--off);border-radius:12px;padding:1rem 1.1rem;border:1px solid var(--line)}
.ba-info-item i{color:var(--teal);font-size:1.1rem;flex-shrink:0;margin-top:.1rem}
.ba-info-item span{font-size:.86rem;color:var(--muted);line-height:1.5}
.ba-info-item strong{color:var(--ink)}

/* ===== REVIEW extras ===== */
.review-type{display:block;font-size:.75rem;color:var(--muted);margin-top:.1rem}
.review-note{background:linear-gradient(135deg,var(--teal-dark),var(--navy));border-radius:var(--radius);padding:1.6rem;display:flex;align-items:center;gap:1.2rem;grid-column:span 1}
.review-note-icon{font-size:1.8rem;color:var(--gold-soft);flex-shrink:0}
.review-note p{color:#cfe3e3;font-size:.9rem;margin:0}
.review-note a{color:var(--gold-soft);font-weight:600}

/* ===== TOPBAR hide timings on small screen ===== */
@media(max-width:860px){.topbar-item-hide{display:none}}

/* ===== FAQ SECTION ===== */
.faq-section{background:var(--off)}
.faq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;align-items:start}
.faq-group{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--line)}
.faq-group-title{background:linear-gradient(135deg,var(--teal),var(--teal-dark));color:#fff;margin:0;padding:1rem 1.3rem;font-size:1rem;font-family:var(--sans);display:flex;align-items:center;gap:.6rem}
.faq-group-title i{color:var(--gold-soft)}
.faq-list{padding:.4rem 0}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item:last-child{border-bottom:none}
.faq-q{width:100%;background:none;border:none;text-align:left;padding:.95rem 1.3rem;font-size:.9rem;font-weight:600;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:flex-start;gap:.8rem;line-height:1.45;font-family:var(--sans);transition:.2s}
.faq-q:hover{color:var(--teal);background:rgba(6,107,107,.04)}
.faq-q i{color:var(--teal);font-size:.75rem;flex-shrink:0;margin-top:.2rem;transition:transform .3s}
.faq-item.open .faq-q i{transform:rotate(180deg)}
.faq-item.open .faq-q{color:var(--teal)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{padding:.2rem 1.3rem 1rem;color:var(--muted);font-size:.88rem;line-height:1.65;margin:0}
.faq-a strong{color:var(--ink)}
.faq-a em{color:var(--teal);font-style:normal}

@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr;text-align:center}
  .hero-photo{margin:0 auto;max-width:340px}  /* center the card container on mobile */
  .hero-photo picture{display:block;width:100%;height:100%}
  .hero-btns,.hero-stats{justify-content:center}
  .hero-badge{left:50%;transform:translateX(-50%)}
  .about-grid{grid-template-columns:1fr}
  .about-img img{max-width:420px;margin:0 auto}
  .signature-grid{grid-template-columns:repeat(2,1fr)}
  .sig-feature{grid-row:span 1;grid-column:span 2}
  .book-card{grid-template-columns:1fr}
  .ba-cards-grid{grid-template-columns:1fr}
  .ba-card-wide{grid-column:span 1}
  .faq-grid{grid-template-columns:1fr}
  .ba-info-row{grid-template-columns:1fr}
  .review-note{grid-column:span 1}
}
@media(max-width:760px){
  .nav-links{position:fixed;top:0;right:0;height:100vh;width:75%;max-width:320px;background:#fff;flex-direction:column;align-items:flex-start;padding:90px 30px;gap:1.4rem;box-shadow:-10px 0 30px rgba(0,0,0,.15);transform:translateX(100%);transition:transform .35s}
  .nav-links.open{transform:translateX(0)}
  .nav-toggle{display:block;z-index:1000}
  .topbar-item{display:none}
  .topbar-item:first-child{display:flex}  /* keep phone number on mobile */
  .topbar-socials{margin-left:auto}
  .maps,.signature-grid{grid-template-columns:1fr}
  .sig-feature{grid-column:span 1}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .section{padding:60px 0}
  .float-book span,.float-whatsapp span{display:none}
  .float-book{padding:0;width:54px;height:54px;justify-content:center;border-radius:50%;font-size:1.3rem}
  .float-whatsapp{padding:0;width:54px;height:54px;justify-content:center;border-radius:50%;font-size:1.3rem}
  .float-whatsapp i{font-size:1.5rem}
  .navbar-logo img{height:38px}

  /* ===== BOOK SECTION — mobile-friendly ===== */
  .book-card{padding:1.6rem 1.3rem;border-radius:18px;gap:1.4rem;overflow:hidden}
  /* keep grid children from expanding past the card width */
  .book-text,.book-btns{min-width:0;max-width:100%}
  .book-text h2{font-size:1.6rem;overflow-wrap:break-word;word-break:break-word;hyphens:auto}
  /* allow address/appointment text to wrap and stay inside the card */
  .book-text p{font-size:.92rem;overflow-wrap:break-word;word-break:break-word;hyphens:auto}
  .book-text p strong{overflow-wrap:break-word;word-break:break-word}
  .book-btns{gap:.7rem}
  /* shrink oversized stacked buttons so they no longer look cramped */
  .book-btns .btn-lg{padding:.8rem 1rem;font-size:.92rem;width:100%;max-width:100%;box-sizing:border-box;justify-content:flex-start}
  /* let long button labels wrap instead of overflowing the container */
  .book-btns .btn{white-space:normal;overflow-wrap:break-word;word-break:break-word;text-align:left}
  .book-btns .btn-lg i{flex:0 0 auto;width:18px;text-align:center}
  /* clear the floating Book Now (left) & WhatsApp (right) buttons */
  .book-btns{padding-bottom:78px}

  /* ===== ABOUT PAGE — mobile image & text fit ===== */
  /* keep grid children from spilling past the viewport */
  .about-page-grid > *{min-width:0;max-width:100%}
  /* image stays fully inside its container with proper responsive scaling */
  .about-page-grid img{width:100%;height:auto;max-width:100%;display:block;object-fit:cover;box-sizing:border-box}
  /* comfortable spacing between the image and the text below it */
  .about-page-grid{gap:28px}
  /* text wraps correctly and stays inside the content area */
  .page-prose{max-width:100%}
  .page-prose p,.page-prose li,.page-prose h2,.page-prose h3{overflow-wrap:break-word;word-break:break-word;hyphens:auto}
  .page-prose p{margin-bottom:1.1rem;line-height:1.75}
  .page-prose h2{font-size:1.4rem;margin:1.6rem 0 .7rem}
  .page-prose ul{margin:0 0 1.2rem 1.1rem}
  .page-prose li{margin-bottom:.5rem;line-height:1.7}

  /* ===== ABOUT PAGE — CTA button responsiveness ===== */
  /* allow the "Contact & Book an Appointment" button text to wrap so the
     full button stays inside the viewport on narrow screens (no overflow) */
  .page-prose .btn{white-space:normal;overflow-wrap:break-word;word-break:break-word;max-width:100%;box-sizing:border-box;text-align:center}

  /* ===== CONTACT PAGE — CTA button spacing ===== */
  /* stack Call Now / WhatsApp vertically, centered, with clear spacing */
  .contact-cta-btns{display:flex;flex-direction:column;align-items:center;gap:16px}
  .contact-cta-btns .nbsp-sep{display:none}
  .contact-cta-btns .btn-lg{width:auto;max-width:100%;justify-content:center}
}
/* extra-small phones */
@media(max-width:420px){
  .book-card{padding:1.4rem 1rem}
  .book-text h2{font-size:1.4rem}
  .book-text p{font-size:.88rem}
  .book-btns .btn-lg{padding:.75rem .9rem;font-size:.86rem;align-items:flex-start}

  /* ===== ABOUT PAGE — extra-small phones ===== */
  .about-page-grid{gap:22px}
  .page-prose h2{font-size:1.28rem}
  .page-prose p,.page-prose li{font-size:.94rem}
  /* keep CTA button comfortably inside the smallest viewports */
  .page-prose .btn{padding:.8rem 1.1rem;font-size:.9rem}

  /* ===== CONTACT PAGE — extra-small phones ===== */
  /* keep stacked CTA buttons fully visible without horizontal overflow */
  .contact-cta-btns .btn-lg{max-width:100%;box-sizing:border-box}
}
