/* ============================================
   Hearing Wellness Clinic – Indiranagar
   css/style.css
   EchoPx Technologies | www.echopx.com

   IMAGE PATHS USED:
   - images/logo.png       (navbar logo)
   - images/hero-doctor.jpg (who we are section)
============================================ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Poppins',sans-serif;color:#1c2b35;background:#fff;-webkit-font-smoothing:antialiased}

/* ── BRAND TOKENS ── */
:root{
  --blue:    #0097B2;
  --blue2:   #006F85;
  --blue3:   #004F62;
  --bluelt:  #E5F6FA;
  --bluemid: #B8E8F3;
  --red:     #E5222A;
  --red2:    #C01920;
  --white:   #fff;
  --light:   #EAF7FB;
  --border:  #C2E8F2;
  --text:    #1c2b35;
  --muted:   #5a7a85;
  --dark:    #141E28;
  --dark2:   #1C2B38;
}


/* ── NAVBAR ── */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:998;
  background:#fff;border-bottom:2px solid var(--border);
  height:60px;display:flex;align-items:center;
  justify-content:space-between;padding:0 24px;
  box-shadow:0 2px 16px rgba(0,151,178,0.1);
  gap:12px;
}
.nb-logo{display:flex;align-items:center;flex-shrink:0}
.nb-lm{display:none}
/* ── NAV MENU ── */
.nb-menu{
  display:flex;align-items:center;gap:2px;
  list-style:none;margin:0;padding:0;
  flex:1;justify-content:center;
}
.nb-menu li a{
  display:block;padding:8px 11px;
  font-size:0.77rem;font-weight:600;
  color:var(--text);text-decoration:none;
  border-radius:6px;white-space:nowrap;
  transition:background .15s,color .15s;
}
.nb-menu li a:hover,.nb-menu li a.active{
  background:var(--bluelt);color:var(--blue2);
}
/* ── NAVBAR RIGHT ── */
.nb-r{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nb-echs{
  background:var(--bluelt);color:var(--blue2);
  font-size:0.65rem;font-weight:700;
  padding:4px 10px;border-radius:4px;border:1px solid var(--border);
  letter-spacing:0.05em;display:none;
}
.nb-ph{
  color:var(--blue2);font-size:0.8rem;font-weight:700;
  text-decoration:none;display:flex;align-items:center;gap:5px;
  white-space:nowrap;
}
.nb-cta{
  background:var(--blue);color:#fff;
  padding:9px 18px;border-radius:7px;
  font-size:0.78rem;font-weight:700;
  text-decoration:none;
  transition:background .15s,transform .1s;
  white-space:nowrap;
}
.nb-cta:hover{background:var(--blue2);transform:translateY(-1px)}
/* ── HAMBURGER BUTTON ── */
.nb-ham{
  display:none;flex-direction:column;
  justify-content:center;gap:5px;
  background:none;border:none;cursor:pointer;
  padding:6px;width:36px;height:36px;flex-shrink:0;
}
.nb-ham span{
  display:block;height:2px;width:22px;
  background:var(--blue2);border-radius:2px;
  transition:transform .25s,opacity .2s;
}
.nb-ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nb-ham.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nb-ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(min-width:640px){.nb-echs{display:inline-block}}

/* ── HERO ── */
.hero{
  margin-top:60px;
  background:#ffffff;
  border-bottom:1.5px solid var(--border);
  padding:56px 28px 64px;position:relative;overflow:hidden;
}
.hero::before{display:none}
.hero-in{
  max-width:1160px;margin:0 auto;
  display:grid;grid-template-columns:1fr 400px;gap:56px;align-items:start;
  position:relative;
}
.htag{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--blue);color:#fff;
  font-size:0.7rem;font-weight:700;
  padding:5px 14px;border-radius:25px;
  letter-spacing:0.07em;text-transform:uppercase;
  margin-bottom:18px;
}
.hero h1{
  font-size:clamp(1.8rem,3.4vw,2.7rem);
  font-weight:700;color:var(--text);
  line-height:1.2;margin-bottom:16px;
  letter-spacing:-0.02em;
}
.hero h1 em{
  color:var(--blue2);
  font-style:normal;
  font-weight:800;
}
.hero h1 span{color:var(--text)}
.hero-tagline{
  font-size:1.05rem;font-weight:700;
  color:var(--blue2);margin-bottom:12px;
}
.hero-sub{
  color:var(--muted);font-size:0.93rem;
  line-height:1.75;margin-bottom:28px;max-width:500px;
}
/* Phone strip */
.hero-phone{
  background:#fff;border-radius:10px;
  padding:16px 22px;margin-bottom:24px;
  border:2px solid var(--bluemid);
  display:inline-block;
  box-shadow:0 2px 16px rgba(0,151,178,0.1);
}
.hero-phone .toll{font-size:0.72rem;font-weight:700;color:var(--blue);letter-spacing:0.06em;text-transform:uppercase;margin-bottom:4px}
.hero-phone .num{font-size:1.3rem;font-weight:900;color:var(--blue2)}
.hero-phone .num a{color:inherit;text-decoration:none}
.hero-phone .sub{font-size:0.72rem;color:var(--muted);margin-top:4px}
.hero-phone .sub a{color:var(--blue);font-weight:600;text-decoration:none}
/* Pills */
.hpills{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:28px}
.hp{
  display:flex;align-items:center;gap:6px;
  background:#fff;border:1.5px solid var(--border);
  color:var(--blue2);
  padding:7px 14px;border-radius:7px;
  font-size:0.77rem;font-weight:600;
  box-shadow:0 1px 4px rgba(0,151,178,0.07);
}
/* Stats row */
.hstats{
  display:flex;gap:0;
  background:#fff;border:1.5px solid var(--border);
  border-radius:12px;overflow:hidden;
  box-shadow:0 2px 12px rgba(0,151,178,0.08);
}
.hst{flex:1;padding:16px 10px;text-align:center;border-right:1.5px solid var(--border)}
.hst:last-child{border-right:none}
.hst-n{font-size:1.5rem;font-weight:900;color:var(--blue);line-height:1;margin-bottom:4px}
.hst-l{font-size:0.66rem;color:var(--muted);font-weight:500;line-height:1.3}

/* ── FORM CARD ── */
.fcard{
  background:#fff;border-radius:16px;
  padding:30px 26px;
  box-shadow:0 20px 60px rgba(0,151,178,0.18);
  border:2px solid var(--border);
  position:relative;
}
.fcard::before{
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--red),#FF6B6B);
  border-radius:16px 16px 0 0;
}
.fbadge{
  display:inline-flex;align-items:center;gap:6px;
  background:#FFF1F2;color:var(--red);
  font-size:0.72rem;font-weight:700;
  padding:5px 12px;border-radius:5px;
  margin-bottom:14px;border:1px solid #FFC9CC;
}
.fcard h2{font-size:1.15rem;font-weight:800;color:var(--blue3);margin-bottom:4px;line-height:1.3}
.ftag{font-size:0.77rem;color:var(--muted);margin-bottom:18px}
.fg{margin-bottom:11px}
.fg input,.fg select,.fg textarea{
  width:100%;border:1.5px solid #C2DCE3;
  border-radius:8px;padding:11px 14px;
  font-size:0.85rem;font-family:'Poppins',sans-serif;
  color:var(--text);background:#F4FBFD;outline:none;
  transition:border-color .15s,box-shadow .15s;
  -webkit-appearance:none;
}
.fg input::placeholder,.fg textarea::placeholder{color:#99BAC5}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(0,151,178,0.12);background:#fff;
}
.fg textarea{resize:vertical;min-height:64px}
.fpri{display:flex;align-items:center;gap:6px;font-size:0.7rem;font-weight:600;color:#059669;margin-bottom:12px}
.btn-sub{
  width:100%;background:var(--blue);color:#fff;
  border:none;cursor:pointer;padding:13px;border-radius:9px;
  font-size:0.92rem;font-weight:700;font-family:'Poppins',sans-serif;
  box-shadow:0 4px 18px rgba(0,151,178,0.35);
  transition:background .15s,transform .1s;
}
.btn-sub:hover{background:var(--blue2);transform:translateY(-1px)}
.f-or{text-align:center;font-size:0.74rem;color:var(--muted);margin:12px 0;position:relative}
.f-or::before,.f-or::after{content:'';position:absolute;top:50%;width:36%;height:1px;background:var(--border)}
.f-or::before{left:0}.f-or::after{right:0}
.f-cb{
  display:flex;align-items:center;justify-content:center;gap:7px;
  background:#FFF1F2;color:var(--red);
  border:1.5px solid var(--red);border-radius:9px;
  padding:11px;text-decoration:none;font-size:0.88rem;font-weight:700;
  transition:background .15s;
}
.f-cb:hover{background:var(--red);color:#fff}
.fsuc{
  display:none;background:#F0FDF4;border:2px solid #16A34A;
  border-radius:10px;padding:20px;text-align:center;
  color:#166534;font-size:0.88rem;font-weight:600;line-height:1.65;
}

/* ── BRAND LOGO BAR ── */
.brandbar{
  background:#fff;border-top:2px solid var(--border);
  border-bottom:2px solid var(--border);
  padding:20px 28px;
}
.brandbar-in{
  max-width:1160px;margin:0 auto;
  display:flex;align-items:center;justify-content:center;
  gap:0;flex-wrap:nowrap;overflow:hidden;
}
.bb-item{
  flex:1;min-width:120px;
  padding:12px 16px;text-align:center;
  border-right:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
}
.bb-item:last-child{border-right:none}
.bb-item span{
  font-size:0.9rem;font-weight:900;color:var(--text);
  letter-spacing:-0.02em;
}
.bb-item span em{color:var(--blue);font-style:normal}

/* ── MARQUEE ── */
.mq{background:var(--blue2);overflow:hidden;padding:12px 0;white-space:nowrap}
.mq-in{
  display:inline-flex;gap:24px;
  align-items:center;
  animation:mq 18s linear infinite;
  will-change:transform;
}
.mq-logo{
  display:inline-flex;align-items:center;justify-content:center;
  background:#fff;border-radius:8px;
  padding:7px 16px;height:50px;flex-shrink:0;
}
.mq-logo img{height:28px;width:auto;max-width:100px;object-fit:contain;display:block}
@keyframes mq{
  0%{transform:translateX(0)}
  100%{transform:translateX(calc(-25%))}
}

/* ── STATS BAR ── */
.sbar{background:var(--light);border-bottom:2px solid var(--border);padding:16px 28px 0}
.sbar-heading{
  text-align:center;
  font-size:1.1rem;font-weight:700;
  color:var(--blue2);
  padding:14px 0 4px;
  letter-spacing:-0.01em;
}
.sbar-in{max-width:1160px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr)}
.si{padding:18px 16px;text-align:center;border-right:1px solid var(--border)}
.si:last-child{border-right:none}
.si-n{font-size:1.8rem;font-weight:900;color:var(--blue);line-height:1;margin-bottom:5px}
.si-l{font-size:0.72rem;color:var(--muted);font-weight:500;line-height:1.4}

/* ── SECTION BASE ── */
.s{padding:72px 28px}
.sl{background:var(--light)}
.w{max-width:1160px;margin:0 auto}
.eye{font-size:0.68rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--blue);margin-bottom:8px}
.stitle{font-size:clamp(1.55rem,2.5vw,2.1rem);font-weight:800;color:var(--blue3);line-height:1.22;margin-bottom:12px;letter-spacing:-0.02em}
.stitle em{color:var(--blue);font-style:normal}
.ssub{font-size:0.92rem;color:var(--muted);line-height:1.75;max-width:580px}
.cx{text-align:center}.cx .ssub{margin:0 auto}

/* ── EXCEPTIONAL SECTION ── */





/* ── WELCOME SPLIT ── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.sv{
  border-radius:20px;aspect-ratio:4/3;
  position:relative;overflow:hidden;
  border:2px solid var(--border);
  background:var(--bluelt);
}
.sv img{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;display:block;
}
.sv::after{display:none}
.sc .ssub{max-width:none}
.slist{margin-top:20px;display:flex;flex-direction:column;gap:10px}
.sitem{
  display:flex;align-items:flex-start;gap:10px;

  font-size:0.84rem;color:var(--text);line-height:1.6;
}
.sitem::before{
  content:'✓';
  width:22px;height:22px;border-radius:50%;
  background:var(--blue);color:#fff;
  font-size:0.65rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:2px;
}

/* ── OUR VALUES BAND ── */
.val-band{
  background:var(--blue);padding:52px 28px;text-align:center;
}
.val-band .vt{font-size:0.75rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.7);margin-bottom:10px}
.val-band h2{font-size:clamp(1.4rem,2.2vw,1.8rem);font-weight:800;color:#fff;margin-bottom:14px;letter-spacing:-0.02em}
.val-band p{color:rgba(255,255,255,0.82);font-size:0.92rem;line-height:1.75;max-width:640px;margin:0 auto}

/* ── WHY CHOOSE US (accordion style) ── */
.wcu-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-top:44px}
.wcu-left .ssub{max-width:none;margin-bottom:24px}
.acc-item{
  border:1.5px solid var(--border);border-radius:10px;
  margin-bottom:10px;overflow:hidden;background:#fff;
  transition:border-color .15s,box-shadow .15s;
}
.acc-item:hover{border-color:var(--blue);box-shadow:0 3px 14px rgba(0,151,178,0.1)}
.acc-head{
  padding:14px 18px;
  display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;
}
.acc-head .num{font-size:0.7rem;font-weight:800;color:var(--blue);margin-right:10px;letter-spacing:0.04em}
.acc-head .lbl{font-size:0.86rem;font-weight:700;color:var(--text)}
.acc-head .arr{font-size:0.8rem;color:var(--blue);transition:transform .2s}
.acc-head:hover .arr{transform:rotate(90deg)}
.wcu-visual{
  background:linear-gradient(135deg,var(--bluelt),var(--bluemid));
  border-radius:20px;min-height:360px;
  display:flex;align-items:center;justify-content:center;
  font-size:6rem;border:2px solid var(--border);
}

/* ── WHAT WE OFFER ── */
.og{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px}
.oc{
  background:#fff;border-radius:14px;padding:30px 24px;
  border:1.5px solid var(--border);
  position:relative;overflow:hidden;
  transition:box-shadow .2s,transform .2s,border-color .2s;
}
.oc:hover{box-shadow:0 12px 36px rgba(0,151,178,0.13);transform:translateY(-4px);border-color:var(--blue)}
.oc::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue),var(--blue2));
  transform:scaleX(0);transform-origin:left;transition:transform .2s;
}
.oc:hover::after{transform:scaleX(1)}
.oc-num{
  font-size:3.5rem;font-weight:900;color:var(--bluelt);line-height:1;
  position:absolute;top:14px;right:18px;letter-spacing:-0.04em;
}
.oc-icon{width:54px;height:54px;border-radius:12px;background:var(--bluelt);display:flex;align-items:center;justify-content:center;margin-bottom:18px;flex-shrink:0}
.oc-icon svg{width:28px;height:28px}
.oc h3{font-size:0.95rem;font-weight:700;color:var(--blue2);margin-bottom:8px}
.oc p{font-size:0.82rem;color:var(--muted);line-height:1.7}

/* ── WHO WE ARE ── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.sc .ssub{max-width:none}
.slist{margin-top:20px;display:flex;flex-direction:column;gap:10px}
.sitem{display:flex;align-items:flex-start;gap:10px;font-size:0.84rem;color:var(--text);line-height:1.6}
.sitem::before{
  content:'✓';width:22px;height:22px;border-radius:50%;
  background:var(--blue);color:#fff;font-size:0.65rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;
}

/* ── HOW IT WORKS ── */
.strow{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:50px;position:relative}
.strow::before{
  content:'';position:absolute;top:27px;left:12%;right:12%;height:2px;
  background:repeating-linear-gradient(90deg,var(--border) 0,var(--border) 8px,transparent 8px,transparent 16px);
}
.step{text-align:center;padding:0 16px;position:relative}
.sc2{
  width:56px;height:56px;border-radius:50%;
  background:var(--blue);color:#fff;
  font-size:1.2rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 18px;
  box-shadow:0 4px 18px rgba(0,151,178,0.35);
  position:relative;z-index:1;
}
.step h4{font-size:0.88rem;font-weight:700;color:var(--blue3);margin-bottom:8px}
.step p{font-size:0.78rem;color:var(--muted);line-height:1.65}

/* ── APPROACH TABS ── */
.approach-grid{display:grid;grid-template-columns:220px 1fr;gap:0;border:1.5px solid var(--border);border-radius:14px;overflow:hidden;margin-top:40px}
.ap-tabs{background:var(--light);border-right:1.5px solid var(--border)}
.ap-tab{
  padding:16px 20px;cursor:pointer;
  font-size:0.84rem;font-weight:600;color:var(--muted);
  border-bottom:1px solid var(--border);
  transition:background .15s,color .15s;
  display:flex;align-items:center;gap:8px;
}
.ap-tab:last-child{border-bottom:none}
.ap-tab.active,.ap-tab:hover{background:var(--blue);color:#fff}
.ap-panel{padding:28px 32px;background:#fff}
.ap-panel h3{font-size:1rem;font-weight:700;color:var(--blue2);margin-bottom:12px}
.ap-panel p{font-size:0.86rem;color:var(--muted);line-height:1.75}

/* ── HEARING IMPAIRMENT SECTION ── */
.hi-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center;margin-bottom:56px}
.hi-grid:last-child{margin-bottom:0}
.hi-visual{
  background:linear-gradient(135deg,var(--bluelt),var(--bluemid));
  border-radius:20px;aspect-ratio:4/3;
  display:flex;align-items:center;justify-content:center;
  font-size:5rem;border:2px solid var(--border);
}
.hi-content h3{font-size:1.1rem;font-weight:700;color:var(--blue);margin-bottom:12px}
.hi-content p{font-size:0.88rem;color:var(--muted);line-height:1.75;margin-bottom:16px}
.hi-list{display:flex;flex-direction:column;gap:8px}
.hi-list li{
  list-style:none;display:flex;align-items:flex-start;gap:9px;
  font-size:0.84rem;color:var(--text);line-height:1.55;
}
.hi-list li::before{content:'•';color:var(--blue);font-size:1.2rem;line-height:1;flex-shrink:0}

/* ── AREAS ── */
.arsec{background:var(--blue);padding:68px 28px}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.chip{background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.25);color:rgba(255,255,255,0.9);padding:8px 18px;border-radius:25px;font-size:0.8rem;font-weight:600;transition:background .15s}
.chip:hover{background:rgba(255,255,255,0.22)}
.chip.pr{background:var(--red);border-color:var(--red);font-weight:700}
.agrid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:32px}
.ab{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);border-radius:12px;padding:20px 22px;box-sizing:border-box}
.ab h4{font-size:0.68rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:#FFF9C4;margin-bottom:8px}
.ab p{font-size:0.84rem;color:rgba(255,255,255,0.85);line-height:1.75}
.ab a{color:#FFF9C4;text-decoration:none;font-weight:600}
.ab a:hover{text-decoration:underline}

/* ── BRANDS ── */
.bgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.bc{
  background:#fff;border-radius:12px;
  padding:24px 20px;border:1.5px solid var(--border);
  text-align:left;display:flex;flex-direction:column;gap:10px;
  transition:box-shadow .2s,border-color .2s,transform .2s;
}
.bc:hover{border-color:var(--blue);box-shadow:0 8px 24px rgba(0,151,178,0.1);transform:translateY(-3px)}
.bc-logo{height:36px;display:flex;align-items:center;margin-bottom:2px}
.bc-logo img{max-height:32px;max-width:130px;width:auto;height:auto;object-fit:contain;display:block}
/* Product image card */
.bc-product{
  background:var(--bluelt);border-radius:8px;
  padding:12px;display:flex;align-items:center;gap:12px;
  border:1px solid var(--border);
}
.bc-prod-img-wrap{
  width:64px;height:64px;flex-shrink:0;
  background:#fff;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--border);overflow:hidden;
}
.bc-prod-img{
  width:100%;height:100%;object-fit:contain;
  /* IMAGE PLACEHOLDER — replace src with official product image */
}
/* Placeholder style when image not yet uploaded */
.bc-prod-img[src*="products/"]{
  opacity:1;filter:none;
}
.bc-prod-name{font-size:0.82rem;font-weight:700;color:var(--blue2);margin-bottom:2px}
.bc-prod-tag{font-size:0.7rem;font-weight:500;color:var(--muted);font-style:italic}
.bc p{font-size:0.78rem;color:var(--muted);line-height:1.65;flex:1}

/* ── REVIEWS ── */
.rh{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:20px;margin-bottom:36px}
.rscore{display:flex;align-items:center;gap:14px;background:var(--bluelt);border:1.5px solid var(--border);border-radius:12px;padding:16px 22px}
.rsn{font-size:2.8rem;font-weight:900;color:var(--blue);line-height:1}
.rst{color:#F59E0B;font-size:1rem}
.rsc{font-size:0.72rem;color:var(--muted);font-weight:600;margin-top:3px}
.rg{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rc{background:#fff;border-radius:14px;padding:24px;border:1.5px solid var(--border);position:relative}
.rc::before{content:'\201C';position:absolute;top:-4px;left:20px;font-size:5rem;color:var(--bluelt);line-height:1;font-family:Georgia,serif}
.r-st{color:#F59E0B;font-size:0.85rem;margin:22px 0 12px}
.r-tx{font-size:0.85rem;color:#3d5a65;line-height:1.75;margin-bottom:16px;font-style:italic}
.rvr{display:flex;align-items:center;gap:10px}
.ra{width:38px;height:38px;border-radius:50%;background:var(--blue);color:#fff;font-size:0.82rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rn2{font-size:0.83rem;font-weight:700;color:var(--blue3)}
.rl{font-size:0.72rem;color:var(--muted)}

/* ── HAPPY CUSTOMERS GALLERY ── */
.hcg-section{
  background:var(--bluelt);
  padding:44px 28px;
  position:relative;overflow:visible;height:auto;
}
.hcg-white{background:#fff!important}
.hcg-section .w{max-width:900px}
.hcg-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;margin-top:24px;height:auto;
}
.hcg-card{
  background:#fff;border-radius:8px;
  overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,0.08);
  transition:transform .25s,box-shadow .25s;
  position:relative;height:auto;
}
.hcg-white .hcg-card{box-shadow:0 2px 8px rgba(0,151,178,0.1);border:1px solid var(--border)}
.hcg-card:hover{
  transform:translateY(-3px);
  box-shadow:0 6px 16px rgba(0,151,178,0.14);
}
.hcg-img{
  width:100%;
  height:auto;
  max-height:220px;
  object-fit:contain;
  display:block;
  background:#f4f4f4;
}
/* ── GOOGLE MAP ── */
.map-wrap{margin-top:24px;border-radius:12px;overflow:hidden}

/* ── WHY CHOOSE ── */
.wch-section{background:var(--blue3);padding:52px 28px}
.wch-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:12px;margin-top:32px;
}
.wch-card{
  background:rgba(255,255,255,0.08);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:10px;padding:16px 18px;
  display:flex;align-items:center;gap:12px;
  transition:background .2s,transform .15s;
}
.wch-card:hover{
  background:rgba(255,255,255,0.15);
  transform:translateY(-2px);
}
.wch-icon{
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,0.12);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.wch-icon svg{stroke:#fff;width:18px;height:18px}
.wch-title{
  font-size:0.86rem;font-weight:700;
  color:#fff;line-height:1.3;white-space:nowrap;
}

/* ── TYPES OF HEARING AIDS ── */
.types-grid{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:16px;margin-top:40px;
}
.type-card{
  background:#fff;border-radius:14px;
  overflow:hidden;
  border:1.5px solid var(--border);
  display:flex;flex-direction:column;
  transition:box-shadow .2s,transform .2s,border-color .2s;
}
.type-card:hover{
  box-shadow:0 10px 28px rgba(0,151,178,0.12);
  transform:translateY(-4px);border-color:var(--blue);
}
.type-img-wrap{display:none}
.type-img{display:none}
.type-img-placeholder{display:none}
.type-body{padding:16px 14px;display:flex;flex-direction:column;gap:4px;flex:1}
.type-badge{
  display:inline-block;
  background:var(--blue);color:#fff;
  font-size:0.62rem;font-weight:700;
  padding:3px 9px;border-radius:20px;
  letter-spacing:0.04em;margin-bottom:6px;
  align-self:flex-start;
}
.type-badge-alt{background:var(--blue2)}
.type-badge-green{background:#16a34a}
.type-card h3{font-size:1.3rem;font-weight:900;color:var(--blue2);line-height:1}
.type-full{font-size:0.72rem;font-weight:600;color:var(--muted);margin-bottom:8px}
.type-card p{font-size:0.78rem;color:var(--muted);line-height:1.65}
.types-note{
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;margin-top:28px;
  font-size:0.88rem;color:var(--muted);
  padding:18px 24px;background:var(--bluelt);
  border-radius:12px;border:1px solid var(--border);
  flex-wrap:wrap;
}
.types-note-text{flex:1;min-width:200px}
.types-cta-btn{
  display:inline-flex;align-items:center;
  background:var(--blue);color:#fff!important;
  font-size:0.88rem;font-weight:700;
  padding:11px 24px;border-radius:8px;
  text-decoration:none!important;
  white-space:nowrap;flex-shrink:0;
  transition:background .15s,transform .1s;
  box-shadow:0 4px 14px rgba(0,151,178,0.3);
}
.types-cta-btn:hover{background:var(--blue2);transform:translateY(-1px)}

/* ── BRAND PRODUCT IMAGE — RAW (no white box) ── */
.bc-prod-img-wrap{
  width:64px;height:64px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.bc-raw{background:transparent!important;border:none!important;border-radius:0!important}
.bc-prod-img{width:100%;height:100%;object-fit:contain;display:block}

/* ── PRICE FORM BAND ── */
.pb{
  background:linear-gradient(135deg,var(--bluelt),#D8F0F7);
  border-top:2px solid var(--border);border-bottom:2px solid var(--border);
  padding:60px 28px;text-align:center;
}
.pf{max-width:440px;margin:28px auto 0;background:#fff;border-radius:14px;padding:28px;border:1.5px solid var(--border);box-shadow:0 6px 24px rgba(0,151,178,0.12)}
.pf .fg{margin-bottom:12px}

/* ── SCHEDULE CTA ── */
.sched{background:var(--blue);padding:64px 28px;text-align:center}
.sched h2{font-size:clamp(1.7rem,2.8vw,2.3rem);font-weight:800;color:#fff;margin-bottom:12px;letter-spacing:-0.02em}
.sched p{color:rgba(255,255,255,0.8);font-size:0.93rem;line-height:1.7;margin-bottom:28px;max-width:600px;margin-left:auto;margin-right:auto}
.sched-num{font-size:1.8rem;font-weight:900;color:#FFF9C4;margin-bottom:24px}
.sched-num a{color:inherit;text-decoration:none}
.cr{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-white{background:#fff;color:var(--blue2);padding:14px 32px;border-radius:9px;font-size:0.95rem;font-weight:700;text-decoration:none;box-shadow:0 4px 16px rgba(0,0,0,0.15);transition:transform .1s}
.btn-white:hover{transform:translateY(-2px)}
.btn-outline-w{background:transparent;color:#fff;padding:14px 28px;border-radius:9px;border:2px solid rgba(255,255,255,0.4);font-size:0.95rem;font-weight:600;text-decoration:none;transition:background .15s,border-color .15s}
.btn-outline-w:hover{background:rgba(255,255,255,0.12);border-color:#fff}

/* ── FOOTER ── */
footer{background:var(--dark2);padding:40px 28px 20px}
.foot-in{max-width:1160px;margin:0 auto}
.foot-grid{display:grid;grid-template-columns:1fr 1.2fr 1.2fr;gap:40px;margin-bottom:32px}
.foot-brand .fb-name{font-size:1rem;font-weight:800;color:#fff;margin-bottom:4px}
.foot-brand .fb-sub{font-size:0.72rem;color:rgba(255,255,255,0.5);margin-bottom:14px}
.foot-brand p{font-size:0.8rem;color:rgba(255,255,255,0.6);line-height:1.7}
.foot-col h4{font-size:0.72rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-bottom:14px}
.foot-col ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.foot-col ul li a{font-size:0.8rem;color:rgba(255,255,255,0.65);text-decoration:none;transition:color .15s}
.foot-col ul li a:hover{color:#fff}
.foot-locs{display:flex;flex-wrap:wrap;gap:6px 14px}
.foot-locs a{font-size:0.76rem;color:rgba(255,255,255,0.6);text-decoration:none;transition:color .15s}
.foot-locs a:hover{color:var(--blue)}
.foot-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:18px;text-align:center;font-size:0.75rem;color:rgba(255,255,255,0.35)}
.foot-bottom a{color:var(--blue);text-decoration:none}
.foot-bottom a:hover{color:#fff}

/* ── FLOATING BUTTONS ── */
.fwa{
  position:fixed;bottom:22px;left:22px;z-index:900;
  width:52px;height:52px;border-radius:50%;
  background:#25D366;color:#fff;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;
  box-shadow:0 4px 18px rgba(37,211,102,0.45);
  transition:transform .2s;
}
.fwa:hover{transform:scale(1.12)}
.fcall{
  position:fixed;bottom:22px;right:22px;z-index:900;
  width:52px;height:52px;border-radius:50%;
  background:var(--blue);color:#fff;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;
  box-shadow:0 4px 18px rgba(0,151,178,0.45);
  transition:transform .2s;
  animation:pulse 2s infinite;
}
.fcall:hover{transform:scale(1.12)}
@keyframes pulse{
  0%,100%{box-shadow:0 4px 18px rgba(0,151,178,0.45)}
  50%{box-shadow:0 4px 28px rgba(0,151,178,0.75),0 0 0 8px rgba(0,151,178,0.12)}
}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.hl>*{animation:fadeUp .6s ease both}
.htag{animation-delay:.05s}.hero h1{animation-delay:.13s}.hero-tagline{animation-delay:.18s}.hero-sub{animation-delay:.23s}.hero-phone{animation-delay:.28s}.hpills{animation-delay:.33s}.hstats{animation-delay:.4s}
.fcard{animation:fadeUp .65s ease .2s both}

/* ── LOGO IMAGE ── */
.nb-logo-img{height:38px;width:auto;display:block;object-fit:contain}

/* ══════════════════════════════════════════
   STICKY MOBILE CALL BAR (mobile only)
══════════════════════════════════════════ */
.sticky-call-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;z-index:1000;
  padding:10px 16px;
}
.sticky-call-bar a{
  display:flex;align-items:center;justify-content:center;
  gap:10px;height:52px;width:100%;
  color:#fff;text-decoration:none;
  font-size:1rem;font-weight:800;
  letter-spacing:0.01em;
  background:var(--blue);
  border-radius:14px;
  box-shadow:0 4px 18px rgba(0,151,178,0.45);
}
.sticky-call-bar svg{flex-shrink:0}

/* ══════════════════════════════════════════
   RESPONSIVE — TABLET (≤1000px)
══════════════════════════════════════════ */
@media(max-width:1000px){
  /* Layout */
  .hero-in,.split{grid-template-columns:1fr;gap:28px}
  .fcard{max-width:100%}
  .hero{padding:36px 20px 40px}

  /* Nav */
  .nb-menu{display:none}
  .nb-ham{display:flex}
  .nb-ph{display:none}
  .nb-menu.open{
    display:flex;flex-direction:column;align-items:flex-start;gap:0;
    position:fixed;top:60px;left:0;right:0;
    background:#fff;
    border-bottom:2px solid var(--border);
    padding:8px 0;
    box-shadow:0 8px 24px rgba(0,151,178,0.12);
    z-index:997;
  }
  .nb-menu.open li{width:100%}
  .nb-menu.open li a{padding:13px 24px;font-size:0.9rem;border-radius:0;border-bottom:1px solid var(--border)}
  .nb-menu.open li:last-child a{border-bottom:none}

  /* Stats */
  .sbar-in{grid-template-columns:repeat(3,1fr)}
  .si{padding:18px 10px}
  .si-n{font-size:1.5rem}

  /* Sections */
  .wch-grid{grid-template-columns:1fr 1fr}
  .wch-title{white-space:normal}
  .og{grid-template-columns:repeat(2,1fr)}
  .types-grid{grid-template-columns:repeat(3,1fr)}
  .bgrid{grid-template-columns:repeat(2,1fr)}
  .hcg-grid{grid-template-columns:repeat(3,1fr)}
  .hcg-img{max-height:160px}
  .rg{grid-template-columns:1fr}
  .rh{flex-direction:column;align-items:flex-start}

  /* Who We Are — hide image, show content only */
  .sv{display:none}

  /* Footer */
  .foot-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════
   RESPONSIVE — MOBILE (≤640px)
══════════════════════════════════════════ */
@media(max-width:640px){
  /* Base */
  body{padding-bottom:72px} /* space for sticky call bar */
  .s{padding:44px 16px}
  .sl{padding:44px 16px}
  .w{padding:0}

  /* Navbar */
  .navbar{padding:0 16px;height:56px}
  .nb-logo-img{height:32px}
  .nb-cta{display:none}

  /* Hero */
  .hero{margin-top:56px;padding:28px 16px 36px;border-bottom:1.5px solid var(--border)}
  .hero h1{font-size:1.7rem;line-height:1.2}
  .hero-tagline{font-size:0.88rem}
  .hero-sub{font-size:0.86rem}
  .htag{font-size:0.68rem;padding:5px 12px}
  .hpills{gap:7px}
  .hp{font-size:0.73rem;padding:6px 10px}
  .fcard{border-radius:12px;padding:22px 18px}
  .fcard h2{font-size:1rem}
  .btn-sub{font-size:0.88rem;padding:12px}
  .f-cb{font-size:0.82rem}

  /* Marquee */
  .mq{padding:9px 0}
  .mq-in span{font-size:0.74rem}

  /* Stats — force single row on mobile */
  .sbar{padding:0 10px}
  .sbar-in{grid-template-columns:repeat(5,1fr);overflow-x:auto}
  .si{padding:10px 6px;border-right:1px solid var(--border)}
  .si-n{font-size:1.1rem}
  .si-l{font-size:0.55rem}
  .si:last-child{display:block;border-right:none}

  /* Why Choose */
  .wch-section{padding:40px 16px}
  .wch-grid{grid-template-columns:1fr;gap:10px}
  .wch-card{padding:14px 14px}
  .wch-icon{width:34px;height:34px}
  .wch-icon svg{width:16px;height:16px}
  .wch-title{font-size:0.82rem}

  /* Services */
  .og{grid-template-columns:1fr;gap:14px}
  .oc{padding:22px 18px}
  .oc-num{font-size:2.5rem}
  .oc h3{font-size:0.9rem}
  .oc p{font-size:0.8rem}

  /* Who We Are */
  .split{grid-template-columns:1fr}
  .sv{display:none}
  .sc .ssub{font-size:0.86rem}
  .sitem{font-size:0.82rem}
  .stitle{font-size:1.4rem}

  /* Areas */
  .arsec{padding:44px 16px}
  .agrid{
    display:grid;
    grid-template-columns:calc(50% - 8px) calc(50% - 8px);
    grid-template-rows:auto auto;
    gap:16px;
  }
  .ab{
    padding:16px;
    width:100%;
    box-sizing:border-box;
    min-height:0;
  }
  .chips{gap:7px}
  .chip{font-size:0.73rem;padding:6px 12px}
  .map-wrap{margin-top:18px}
  .map-wrap iframe{height:220px}

  /* Brands */
  .bgrid{grid-template-columns:1fr;gap:14px}
  .bc{padding:18px 16px}
  .bc-product{padding:10px}
  .bc-prod-img-wrap{width:52px;height:52px}

  /* Types of Hearing Aids */
  .types-grid{grid-template-columns:1fr 1fr;gap:12px}
  .type-body{padding:12px}
  .type-card h3{font-size:1.1rem}

  /* Happy Customers */
  .hcg-section{padding:36px 16px}
  .hcg-grid{grid-template-columns:1fr 1fr;gap:10px}
  .hcg-img{max-height:150px}

  /* Reviews */
  .rg{grid-template-columns:1fr;gap:14px}
  .rh{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:24px}
  .rscore{padding:12px 16px}
  .rsn{font-size:2.2rem}
  .rc{padding:18px}
  .r-tx{font-size:0.82rem}

  /* Pricing form */
  .pb{padding:36px 16px}
  .pf{padding:20px 16px;margin-top:20px}

  /* Schedule CTA */
  .sched{padding:44px 16px}
  .sched h2{font-size:1.5rem}
  .sched-num{font-size:1.4rem}
  .cr{flex-direction:column;align-items:center;gap:10px}
  .btn-white,.btn-outline-w{width:100%;text-align:center;padding:13px}

  /* Footer */
  footer{padding:32px 16px 16px}
  .foot-grid{grid-template-columns:1fr;gap:24px}
  .foot-locs{gap:5px 12px}

  /* Hide floating buttons on mobile — sticky bar replaces them */
  .fwa{display:none}
  .fcall{display:none}

  /* Show sticky call bar */
  .sticky-call-bar{display:block}
}