/* HClinic public microsite — shared structure. Skins (aurora/classic/midnight/noir)
   set the theme variables below; --accent / --accent-rgb come from the clinic. */
:root{
  --bg:#f6f8fc; --surface:#ffffff; --card:#ffffff; --text:#101828;
  --muted:#5a6b85; --line:rgba(16,24,40,.10); --radius:20px;
  --hero-text:#0b1220; --nav-bg:rgba(255,255,255,.78); --shadow:0 24px 60px -28px rgba(16,24,40,.4);
  --font:'Cairo',-apple-system,Segoe UI,Tahoma,sans-serif; --head:'Changa','Cairo',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.7;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3{font-family:var(--head);line-height:1.2;font-weight:800}
section{scroll-margin-top:80px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;cursor:pointer;
  font-family:inherit;font-weight:700;font-size:15px;padding:13px 26px;border-radius:14px;transition:.18s;white-space:nowrap}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 12px 30px -10px rgba(var(--accent-rgb),.7)}
.btn-primary:hover{filter:brightness(1.07);transform:translateY(-2px)}
.btn-ghost{background:rgba(var(--accent-rgb),.10);color:var(--accent);border:1px solid rgba(var(--accent-rgb),.28)}
.btn-ghost:hover{background:rgba(var(--accent-rgb),.18)}
.btn-wa{background:#25d366;color:#fff}.btn-wa:hover{filter:brightness(1.05)}
.btn svg{width:18px;height:18px}

/* NAV */
.site-nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 5vw;background:var(--nav-bg);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:.25s}
.site-nav.scrolled{border-bottom-color:var(--line);box-shadow:0 8px 30px -20px rgba(0,0,0,.4)}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--head);font-weight:800;font-size:20px;color:var(--text)}
.brand img{width:42px;height:42px;border-radius:11px;object-fit:cover}
.nav-links{display:flex;gap:26px;font-weight:600;color:var(--muted)}
.nav-links a:hover{color:var(--accent)}
.nav-cta{padding:10px 20px;font-size:14px}

/* HERO */
.site-hero{position:relative;padding:64px 5vw 72px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-inner{position:relative;z-index:1;max-width:1140px;margin:0 auto;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.eyebrow{display:inline-block;font-weight:700;color:var(--accent);background:rgba(var(--accent-rgb),.12);
  padding:6px 14px;border-radius:30px;font-size:13px;margin-bottom:18px}
.hero-copy h1{font-size:clamp(30px,5vw,52px);color:var(--hero-text);margin-bottom:16px}
.hero-copy p{font-size:clamp(15px,2.2vw,19px);color:var(--muted);max-width:30em;margin-bottom:28px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:26px;
  padding:28px;text-align:center;box-shadow:var(--shadow)}
.doc-photo{width:200px;height:200px;margin:0 auto 16px;border-radius:50%;overflow:hidden;
  border:5px solid rgba(var(--accent-rgb),.18);box-shadow:0 16px 40px -16px rgba(var(--accent-rgb),.6)}
.doc-photo img{width:100%;height:100%;object-fit:cover}
.doc-photo.logo-fallback{display:flex;align-items:center;justify-content:center;background:rgba(var(--accent-rgb),.06)}
.doc-photo.logo-fallback img{width:64%;height:auto;object-fit:contain}
.doc-name{font-family:var(--head);font-weight:800;font-size:21px;color:var(--text)}
.doc-title{color:var(--accent);font-weight:600;font-size:14px;margin-top:3px}
.hero-badges{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:16px}
.hero-badges span{font-size:12.5px;font-weight:600;color:var(--muted);background:rgba(var(--accent-rgb),.08);padding:6px 12px;border-radius:20px}

/* SECTIONS */
.site-section{padding:64px 5vw;max-width:1240px;margin:0 auto}
.section-head{text-align:center;max-width:640px;margin:0 auto 40px}
.section-head.start{text-align:start;margin-inline:0}
.kicker{display:inline-block;font-weight:800;letter-spacing:.04em;color:var(--accent);font-size:13px;text-transform:uppercase;margin-bottom:8px}
.section-head h2{font-size:clamp(24px,3.6vw,38px);color:var(--text)}

.about-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:36px;align-items:center}
.about-text p{color:var(--muted);font-size:17px;margin-bottom:14px}
.about-stats{display:grid;gap:14px}
.about-stats .stat{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px 20px;display:flex;align-items:baseline;gap:12px}
.about-stats .stat b{font-family:var(--head);font-size:30px;color:var(--accent)}
.about-stats .stat span{color:var(--muted);font-weight:600}

.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:16px}
.service-card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:24px;transition:.2s}
.service-card:hover{transform:translateY(-4px);border-color:rgba(var(--accent-rgb),.4);box-shadow:var(--shadow)}
.svc-ic{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:15px;
  font-size:26px;background:rgba(var(--accent-rgb),.12);margin-bottom:14px}
.svc-t{font-family:var(--head);font-weight:700;font-size:18px;color:var(--text)}
.svc-d{color:var(--muted);font-size:14px;margin-top:6px}

.hours-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;max-width:1140px;margin:0 auto;align-items:stretch}
.hours-box{background:var(--card);border:1px solid var(--line);border-radius:22px;padding:32px;display:flex;flex-direction:column;gap:16px}
.hours-list{list-style:none}
.hours-list li{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px dashed var(--line);font-size:15px}
.hours-list li:last-child{border:0}
.hours-list li span{color:var(--muted)}.hours-list li b{color:var(--text)}
.addr{color:var(--muted);font-size:14px}
.hours-box .btn{align-self:flex-start;margin-top:auto}
.map-box{border-radius:22px;overflow:hidden;border:1px solid var(--line);min-height:340px;background:var(--card)}
.map-box iframe{width:100%;height:100%;min-height:340px;border:0;display:block}
.map-placeholder{height:100%;min-height:340px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:24px;color:var(--muted)}
.map-placeholder span{font-size:42px}

.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.gallery-grid figure{border-radius:16px;overflow:hidden;aspect-ratio:4/3;border:1px solid var(--line)}
.gallery-grid img{width:100%;height:100%;object-fit:cover;transition:.4s}
.gallery-grid figure:hover img{transform:scale(1.06)}

.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.review-card{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:24px}
.review-card .stars{color:#fbbf24;font-size:18px;letter-spacing:2px}
.review-card p{color:var(--text);margin:12px 0;font-size:15.5px}
.rev-by{color:var(--muted);font-weight:700;font-size:14px}

/* CONTACT */
.site-contact{padding-bottom:80px}
.contact-card{background:var(--card);border:1px solid var(--line);border-radius:26px;overflow:hidden;
  display:grid;grid-template-columns:1fr 1fr;box-shadow:var(--shadow)}
.contact-info{padding:42px}
.contact-info h2{margin:6px 0 18px}
.contact-list{list-style:none;display:grid;gap:12px;margin-bottom:22px}
.contact-list a,.contact-list li{color:var(--text);font-weight:600;font-size:16px}
.contact-list a:hover{color:var(--accent)}
.contact-cta{display:flex;gap:10px;flex-wrap:wrap}
.socials{display:flex;gap:10px;margin-top:22px}
.socials a{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:12px;
  background:rgba(var(--accent-rgb),.10);color:var(--accent);transition:.18s}
.socials a:hover{background:var(--accent);color:#fff;transform:translateY(-2px)}
.booking-inline{background:rgba(var(--accent-rgb),.06);padding:42px;display:flex;flex-direction:column;gap:12px}
.booking-inline h3{font-size:22px;margin-bottom:6px;color:var(--text)}
.booking-inline input,.bm-dialog input,.bm-dialog textarea,.booking-inline textarea{
  width:100%;border:1.5px solid var(--line);background:var(--surface);color:var(--text);
  border-radius:12px;padding:13px 15px;font-family:inherit;font-size:15px;outline:none;transition:.15s}
.booking-inline input:focus,.bm-dialog input:focus,.bm-dialog textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(var(--accent-rgb),.16)}
.form-msg{font-size:14px;font-weight:600;min-height:18px}
.form-msg.ok{color:#16a34a}.form-msg.err{color:#dc2626}

/* FOOTER */
.site-footer{padding:40px 5vw;border-top:1px solid var(--line);text-align:center;display:grid;gap:8px;color:var(--muted)}
.foot-brand{display:flex;align-items:center;justify-content:center;gap:10px;font-family:var(--head);font-weight:800;font-size:18px;color:var(--text)}
.foot-brand img{width:34px;height:34px;border-radius:9px}
.foot-meta{font-size:14px}.foot-copy{font-size:13px}.foot-copy a{color:var(--accent);font-weight:700}

/* FAB */
.fab{position:fixed;bottom:20px;inset-inline-start:20px;z-index:40;display:flex;align-items:center;gap:10px}
.fab-wa{display:inline-flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:50%;background:#25d366;color:#fff;box-shadow:0 12px 30px -8px rgba(37,211,102,.7)}
.fab-book{border:0;cursor:pointer;font-family:var(--head);font-weight:800;font-size:15px;color:#fff;background:var(--accent);
  padding:15px 24px;border-radius:30px;box-shadow:0 14px 34px -10px rgba(var(--accent-rgb),.8)}
.fab-book:hover,.fab-wa:hover{transform:translateY(-3px)}

/* BOOKING MODAL */
.booking-modal{position:fixed;inset:0;z-index:90;display:flex;align-items:center;justify-content:center;padding:18px}
.booking-modal[hidden]{display:none}
.bm-backdrop{position:absolute;inset:0;background:rgba(8,10,22,.55);backdrop-filter:blur(4px)}
.bm-dialog{position:relative;width:100%;max-width:460px;max-height:92vh;overflow:auto;background:var(--surface);
  border-radius:22px;padding:30px;box-shadow:0 40px 90px -30px rgba(0,0,0,.6);animation:bm-in .25s ease}
@keyframes bm-in{from{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:none}}
.bm-x{position:absolute;top:14px;inset-inline-end:16px;border:0;background:transparent;font-size:26px;line-height:1;color:var(--muted);cursor:pointer}
.bm-dialog h3{font-size:24px;color:var(--text)}
.bm-sub{color:var(--muted);font-size:14px;margin:6px 0 18px}
.bm-dialog form{display:grid;gap:12px}
.bm-dialog label,.booking-inline label{display:grid;gap:6px;font-size:13px;font-weight:600;color:var(--muted)}
.bm-dialog label .opt,.booking-inline .opt{color:var(--muted);font-weight:400;opacity:.7}
.bm-submit{margin-top:4px}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* responsive */
@media (max-width:880px){
  .hero-inner,.about-grid,.hours-grid,.contact-card{grid-template-columns:1fr}
  .hero-card{max-width:360px;margin:0 auto;order:-1}
  .nav-links{display:none}
  .about-stats{grid-template-columns:repeat(3,1fr)}
  .about-stats .stat{flex-direction:column;align-items:center;text-align:center;gap:2px}
  .booking-inline{order:2}
}
@media (max-width:520px){
  .nav-cta{display:none}
  .about-stats{grid-template-columns:1fr}
  .fab-book{padding:13px 18px;font-size:14px}
}
