/* ==========================================================================
   style.css is COMPILED from the files in /assets/css/parts/ (in order).
   Do NOT edit style.css directly — edit the relevant part and run:
       bash assets/css/build-css.sh
   Source order is preserved exactly, so the cascade is identical to the parts.
   ========================================================================== */
/* ============================================================
   HealthDigital v2 — Modern Healthcare Agency Stylesheet
   ============================================================ *//* --- Design Tokens --- */:root{
  /* Primary palette — softer teal-to-sky healthcare feel */
  --primary:#0d9488;
  --primary-hover:#0f766e;
  --primary-light:rgba(13,148,136,.08);
  --primary-ring:rgba(13,148,136,.18);
  --secondary:#7dd3fc;
  --accent:#34d399;
  --accent-light:#ecfdf5;

  /* Neutrals */
  --ink:#1e293b;
  --text:#475569;
  --muted:#94a3b8;
  --line:#e2e8f0;
  --soft:#f8fafc;
  --blue-soft:#f0f9ff;
  --white:#ffffff;

  /* Shadows — very soft */
  --shadow-xs:0 1px 2px rgba(15,23,42,.04);
  --shadow-sm:0 4px 12px rgba(15,23,42,.05);
  --shadow:0 8px 30px rgba(15,23,42,.07);
  --shadow-lg:0 20px 50px rgba(15,23,42,.09);
  --shadow-primary:0 8px 24px rgba(13,148,136,.15);

  /* Radius */
  --radius-sm:10px;
  --radius:16px;
  --radius-lg:22px;
  --radius-full:999px;

  /* Transitions */
  --ease:cubic-bezier(.4,0,.2,1);
  --duration:.25s;
}/* --- Reset & Base --- */*,*::before,*::after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{
  margin:0;
  font-family:'Plus Jakarta Sans','Inter',system-ui,-apple-system,sans-serif;
  color:var(--text);
  background:var(--soft);
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}body.single-hd_doctor{
  background:#f8fafc;
}/* --- Typography (calmer weights) --- */h1,h2,h3,h4,h5,h6{
  font-family:'Plus Jakarta Sans','Inter',system-ui,sans-serif;
  color:var(--ink);
  line-height:1.18;
  letter-spacing:-.02em;
  margin:0 0 14px;
  text-wrap:balance;
}h1{font-size:clamp(32px,4.4vw,54px);font-weight:700}h2{font-size:clamp(24px,2.8vw,38px);font-weight:600}h3{font-size:clamp(17px,1.4vw,22px);font-weight:600}h4{font-size:17px;font-weight:600}p{margin:0 0 16px}strong,b{font-weight:600;color:var(--ink)}a{text-decoration:none;color:inherit;transition:color var(--duration) var(--ease)}img{max-width:100%;display:block;height:auto}ul{padding-left:20px}:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:4px}/* --- Layout --- */.container{width:min(1200px,90%);margin:auto}/* --- Topbar --- */
.site-topbar {
  background: var(--ink);
  color: var(--muted);
  font-size: 13px;
  padding: 8px 4%;
}
.site-topbar-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}
.site-topbar a {
  color: #cbd5e1;
  font-weight: 500;
  transition: color var(--duration) var(--ease);
}
.site-topbar a:hover {
  color: var(--white);
}
.site-topbar-links, .site-topbar-account {
  display: flex;
  gap: 16px;
  align-items: center;
}
.site-topbar-account a:first-child {
  color: var(--accent);
}

/* --- Header --- */.site-header{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;gap:16px;justify-content:space-between;
  padding:12px 4%;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(226,232,240,.6);
  box-shadow:0 1px 8px rgba(15,23,42,.03);
}.logo{
  font-weight:700;color:var(--ink);font-size:19px;
  white-space:nowrap;letter-spacing:-.015em;
  display:flex;align-items:center;gap:8px;
}.logo span{
  display:inline-grid;place-items:center;
  background:linear-gradient(135deg,var(--primary),#38bdf8);
  color:white;border-radius:10px;width:30px;height:30px;
  font-size:16px;font-weight:700;
  box-shadow:0 4px 12px rgba(13,148,136,.2);
}/* Navigation */nav{display:flex;gap:2px;font-weight:500;font-size:13.5px}nav a{
  color:var(--text);border-radius:var(--radius-full);
  padding:7px 12px;
  transition:background var(--duration) var(--ease),color var(--duration) var(--ease);
}nav a:hover,nav a.active{color:var(--primary);background:var(--primary-light)}/* --- Buttons --- */.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 24px;border-radius:var(--radius-full);
  background:var(--primary);color:var(--white);
  font-weight:600;font-size:14.5px;border:0;cursor:pointer;
  box-shadow:var(--shadow-primary);
  transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease),background var(--duration) var(--ease);
}.btn:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(13,148,136,.22);background:var(--primary-hover)}.btn:active{transform:translateY(0)}.btn.ghost{
  background:var(--white);color:var(--primary);
  border:1.5px solid rgba(13,148,136,.25);box-shadow:none;
}.btn.ghost:hover{background:var(--primary-light);border-color:var(--primary)}.btn.light{background:var(--white);color:var(--primary)}.btn.dark{background:var(--ink);color:var(--white);box-shadow:0 8px 24px rgba(30,41,59,.18)}.btn.small{padding:9px 16px;font-size:13.5px}/* Mobile menu button */.menu{
  display:none;background:var(--white);
  border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:7px 11px;font-size:20px;cursor:pointer;
}/* --- Mobile Slide Panel --- */.mobile-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.3);z-index:60;opacity:0;pointer-events:none;transition:opacity .3s var(--ease)}.mobile-panel{
  position:fixed;top:0;right:0;bottom:0;width:min(340px,86vw);
  background:var(--white);z-index:70;padding:24px;
  transform:translateX(100%);transition:transform .3s var(--ease);
  box-shadow:var(--shadow-lg);overflow-y:auto;
}.mobile-panel nav{display:grid;gap:4px;margin-top:20px}.mobile-panel nav a{padding:12px 14px;font-size:15px;border-radius:var(--radius-sm)}.mobile-panel .close{
  margin-left:auto;display:grid;place-items:center;
  width:40px;height:40px;border-radius:var(--radius-sm);
  border:1px solid var(--line);background:var(--white);
  font-size:22px;cursor:pointer;
}body.menu-open .mobile-backdrop{opacity:1;pointer-events:auto}body.menu-open .mobile-panel{transform:none}/* --- Hero --- */.hero{
  position:relative;isolation:isolate;overflow:hidden;
  padding:56px 0 64px;
  background:linear-gradient(160deg,var(--soft) 0%,#ecfeff 35%,#f0f9ff 65%,var(--soft) 100%);
}.hero::after{
  content:"";position:absolute;right:-80px;top:-100px;
  width:380px;height:380px;border-radius:50%;
  background:radial-gradient(circle,rgba(125,211,252,.18),transparent 70%);
  z-index:-1;animation:hdFloat 10s ease-in-out infinite;
}.hero::before{
  content:"";position:absolute;left:-60px;bottom:-60px;
  width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle,rgba(52,211,153,.12),transparent 70%);
  z-index:-1;
}.hero.image{min-height:480px;display:grid;align-items:center;background-size:cover;background-position:center}.hero.image::before{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(30,41,59,.88) 0%,rgba(13,148,136,.55) 50%,rgba(30,41,59,.15) 100%);z-index:-1;border-radius:0;width:auto;height:auto;left:0;bottom:0}.hero.image::after{display:none}.hero.image h1,.hero.image p{color:white}.hero.image p{color:rgba(255,255,255,.88);font-size:16.5px;max-width:680px}.hero.image .pill{background:rgba(255,255,255,.12);color:rgba(255,255,255,.9);border-color:rgba(255,255,255,.18)}.hd-page-hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(300px, 420px);
  gap:44px;
  align-items:center;
}.hd-hero-copy{
  min-width:0;
}.hd-page-visual{
  position:relative;
  width:100%;
  max-width:420px;
  aspect-ratio:4 / 3;
  justify-self:end;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.24);
  border-radius:24px;
  background:rgba(255,255,255,.14);
  box-shadow:0 28px 70px rgba(15,23,42,.22);
  backdrop-filter:blur(12px);
}.hd-page-visual img{
  width:100%;
  max-width:100%;
  height:100%;
  min-height:0;
  display:block;
  object-fit:cover;
}.hd-page-visual-note{
  position:absolute;
  left:16px;
  right:16px;
  bottom:16px;
  display:grid;
  gap:4px;
  padding:14px;
  color:#ffffff;
  border:1px solid rgba(255,255,255,.14);
  border-radius:16px;
  background:rgba(15,23,42,.78);
  backdrop-filter:blur(10px);
}.hd-page-visual-note strong{
  color:#ffffff;
  font-size:15px;
}.hd-page-visual-note span{
  color:#dbeafe;
  font-size:13px;
  line-height:1.45;
}.hd-card-icon{
  width:58px;
  height:58px;
  display:grid;
  place-items:center;
  margin:0 0 18px;
  padding:12px;
  border:1px solid rgba(13,148,136,.16);
  border-radius:18px;
  background:linear-gradient(180deg, #f0fdfa 0%, #ffffff 100%);
  box-shadow:0 14px 30px rgba(13,148,136,.08);
}.hd-card-icon img{
  width:100%;
  height:100%;
  object-fit:contain;
}.hd-inline-icon{
  width:15px;
  height:15px;
  display:inline-block;
  vertical-align:-2px;
  object-fit:contain;
}.hd-responsible-marketing{
  background:#ffffff;
}.hd-responsible-marketing .card{
  border-color:rgba(13,148,136,.16);
}.hd-responsible-marketing h2{
  font-size:clamp(22px, 2.2vw, 30px);
}.hd-responsible-marketing .btn{
  margin-top:8px;
}.product-hero h1{font-size:clamp(36px,5.5vw,60px);line-height:1.06;max-width:680px;font-weight:700}.product-hero .hero-grid{grid-template-columns:minmax(0,.92fr) minmax(400px,1.08fr)}.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}.pill,.eyebrow{
  display:inline-flex;padding:6px 14px;border-radius:var(--radius-full);
  background:var(--primary-light);color:var(--primary);
  font-weight:600;font-size:13px;margin-bottom:14px;
  border:1px solid rgba(13,148,136,.12);
}.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}/* --- Sections --- */.section{padding:56px 0}.section.alt{background:var(--white)}.section.dark{background:#0f172a}.section.dark h2,.section.dark h3,.section.dark h4,.section.dark p{color:white}.section-head{display:flex;align-items:end;justify-content:space-between;gap:28px;margin-bottom:24px}.section-head p{max-width:560px;color:var(--muted)}/* --- Grid System --- */.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.grid.two{grid-template-columns:repeat(2,1fr)}.grid.four{grid-template-columns:repeat(4,1fr)}.split,.comparison,.contact-grid,.scenario-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:36px;align-items:center}/* --- Cards --- */.card,.price,.form,.panel,.preview-card,.stack-card,.check-card,.scenario-card,.blog-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:28px;
  box-shadow:var(--shadow-sm);
  transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease),border-color var(--duration) var(--ease);
}.cards .card,.preview-card,.blog-card{overflow:hidden}.cards .card:hover,.preview-card:hover,.blog-card:hover,.card:hover,.stack-card:hover,.check-card:hover,.scenario-card:hover,.niche-card:hover,.dash-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow);
  border-color:rgba(13,148,136,.18);
}/* Card media */.card-media,.preview-media,.blog-media{
  aspect-ratio:16/10;margin:-28px -28px 20px;
  overflow:hidden;background:#e0f2fe;
}.card-media img,.preview-media img,.blog-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}.card:hover .card-media img,.preview-card:hover .preview-media img,.blog-card:hover .blog-media img{transform:scale(1.04)}/* Icon box */.icon{

  width:64px;height:64px;border-radius:16px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--primary-light),rgba(125,211,252,.12));
  color:var(--primary);font-size:28px;font-weight:700;
  margin-bottom:14px;
}/* --- Dashboard UI Visual (Hero) --- */.product-ui{
  position:relative;border-radius:var(--radius-lg);
  background:linear-gradient(150deg,#0f172a 0%,#1e3a5f 100%);
  padding:16px;
  box-shadow:0 24px 60px rgba(15,23,42,.25);
  border:1px solid rgba(255,255,255,.08);
}.ui-top{display:flex;gap:6px;margin-bottom:12px}.ui-top span{width:10px;height:10px;border-radius:50%;background:rgba(148,163,184,.5)}.ui-top span:first-child{background:#ef4444}.ui-top span:nth-child(2){background:#f59e0b}.ui-top span:nth-child(3){background:#22c55e}.ui-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:10px}.ui-panel{background:rgba(255,255,255,.95);border-radius:var(--radius-sm);padding:16px;color:var(--ink)}.ui-panel.dark{background:rgba(2,6,23,.6);color:#e2e8f0}.ui-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--primary);font-weight:700;margin-bottom:8px}.ui-panel.dark .ui-label{color:var(--secondary)}.ui-bars{display:grid;gap:7px}.ui-bars i{display:block;height:8px;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--primary),var(--secondary))}.ui-bars i:nth-child(2){width:72%}.ui-bars i:nth-child(3){width:46%}.ui-flow{display:grid;gap:7px;margin-top:10px}.ui-flow span{display:flex;justify-content:space-between;gap:12px;background:var(--soft);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:13px;font-weight:500}.ui-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}.ui-metrics strong{display:block;font-size:22px;color:var(--primary);font-weight:600}.ui-metrics small{color:var(--muted);font-size:11px}/* --- Slab (dark section with glow) --- */.section-slab{
  background:#0f172a;color:var(--white);position:relative;overflow:hidden;
}.section-slab::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(ellipse at 75% 15%,rgba(13,148,136,.15),transparent 40%),
             radial-gradient(ellipse at 15% 85%,rgba(125,211,252,.12),transparent 40%);
}.section-slab .container{position:relative}.section-slab h2,.section-slab h3,.section-slab p{color:var(--white)}.section-slab .stack-card p,.section-slab .check-card p{color:var(--text)}.section-slab .stack-card strong,.section-slab .check-card strong{color:var(--ink)}/* Architecture / process steps */.architecture{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:28px}.arch-step{
  position:relative;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.1);border-radius:var(--radius);
  padding:20px;backdrop-filter:blur(10px);
}.arch-step strong{display:block;color:var(--white);margin-bottom:6px;font-size:15px}.arch-step span{color:#cbd5e1;font-size:13.5px;line-height:1.55}.arch-step::after{
  content:"→";position:absolute;right:-10px;top:50%;transform:translateY(-50%);
  color:var(--secondary);font-weight:700;font-size:14px;
}.arch-step:last-child::after{display:none}/* --- Badges / Tags --- */.badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:18px}.badges span{
  padding:7px 14px;background:var(--blue-soft);border-radius:var(--radius-full);
  font-weight:500;color:#0c4a6e;font-size:13px;border:1px solid rgba(14,165,233,.1);
}.hero.image .badges span{background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.12)}/* --- Feature list (green dots) --- */.feature-list{display:grid;gap:8px;margin:16px 0 20px;padding:0;list-style:none}.feature-list li{display:flex;gap:10px;align-items:flex-start;font-size:15px}.feature-list li::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent);margin-top:9px;flex:0 0 auto}.check-list{display:grid;gap:8px;list-style:none;padding:0;margin:14px 0}.check-list li{display:flex;gap:9px;color:var(--text);font-size:14.5px}.check-list li::before{content:"";width:7px;height:7px;background:linear-gradient(135deg,var(--primary),var(--secondary));border-radius:50%;margin-top:8px;flex:0 0 auto}/* --- Stat grid --- */.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-grid div{background:var(--white);border-radius:var(--radius);padding:24px;border:1px solid var(--line);box-shadow:var(--shadow-xs)}.stat-grid strong{display:block;font-size:26px;color:var(--primary);font-weight:600}/* --- Niche grid --- */.niche-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.niche-card{
  background:var(--white);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow-xs);
  transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease);
}.niche-card strong{display:block;color:var(--ink);font-size:16px;margin-bottom:5px}.niche-card span{color:var(--muted);font-size:13.5px}.niche-grid.has-icons{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}.niche-grid.has-icons .niche-card{
  display:grid;
  align-content:start;
  gap:10px;
  min-height:190px;
}.niche-grid.has-icons .hd-card-icon{
  width:52px;
  height:52px;
  margin:0 0 4px;
  border-radius:16px;
}.niche-grid.has-icons .hd-card-icon img{
  width:28px;
  height:28px;
  object-fit:contain;
  box-shadow:none;
}/* --- Pricing --- */.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.price.featured{border-color:rgba(13,148,136,.35);box-shadow:0 16px 48px rgba(13,148,136,.1)}.money{font-size:28px;font-weight:700;color:var(--ink)}/* --- Forms --- */.form{display:grid;gap:14px}.form label{display:grid;gap:6px;color:var(--ink);font-weight:600;font-size:14px}.form input,.form textarea,.form select{
  width:100%;padding:13px 14px;
  border:1px solid var(--line);border-radius:var(--radius-sm);
  font:inherit;font-weight:400;background:var(--white);color:var(--text);
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
}.form input:focus,.form textarea:focus,.form select:focus{
  outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring);
}input,select,textarea{
  font:inherit;font-weight:400;border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:13px 14px;
  background:var(--white);color:var(--text);
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
}input:focus,select:focus,textarea:focus{
  outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-ring);
}/* --- Visual / Mockup --- */.visual{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:340px;background:#e0f2fe}.visual img{width:100%;height:100%;min-height:340px;object-fit:cover}.visual-badge{
  position:absolute;left:18px;right:18px;bottom:18px;
  background:rgba(255,255,255,.95);border-radius:var(--radius-sm);
  padding:16px;box-shadow:var(--shadow);
}.visual-badge strong{display:block;color:var(--ink);font-size:18px;line-height:1.3}.visual-badge span{display:block;color:var(--primary);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:5px}/* Mockup device */.mockup{border-radius:14px;background:#0f172a;padding:10px;box-shadow:var(--shadow-lg)}.mockup-bar{height:16px;border-radius:var(--radius-full);background:linear-gradient(90deg,#334155,#475569);margin-bottom:8px}.mockup-screen{aspect-ratio:16/10;border-radius:8px;overflow:hidden;background:var(--white)}.mockup-screen img{width:100%;height:100%;object-fit:cover}/* --- Sample dashboard --- */.sample-dashboard{display:grid;grid-template-columns:1fr 1fr;gap:14px}.dash-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-xs)}.dash-card strong{display:block;color:var(--ink);font-size:24px;font-weight:600}.dash-line{height:8px;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--primary),var(--secondary));margin-top:10px}.dash-line.short{width:60%}.dash-line.mid{width:76%}/* --- Section Feature / Comparison --- */.section-feature{padding:80px 0;background:radial-gradient(circle at 10% 20%,rgba(224,242,254,.5) 0,transparent 30%),linear-gradient(180deg,var(--white),var(--soft))}.comparison-pro{overflow:hidden;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow);background:var(--white)}.comparison-pro table{width:100%;border-collapse:collapse}.comparison-pro th,.comparison-pro td{width:50%;vertical-align:top;padding:16px}.comparison-pro th{background:var(--blue-soft)}.comparison-pro td:nth-child(2),.comparison-pro th:nth-child(2){background:#f0fdfa}/* --- Block/tool grids --- */.block-showcase{display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:start}.block-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.block-item{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-xs)}.block-item strong{display:block;color:var(--ink);margin-bottom:4px}.block-item span{font-size:13.5px;color:var(--muted)}.tool-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.tool-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.tool-card h3{margin-bottom:8px}.tool-card .tools{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.tool-card .tools span{background:var(--soft);color:var(--ink);border-radius:var(--radius-full);padding:6px 10px;font-size:13px;font-weight:500}.setup-map{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.setup-step{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}.setup-step b{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:var(--white);margin-bottom:12px;font-size:14px}.setup-step strong{display:block;color:var(--ink);font-size:16px;margin-bottom:5px}/* --- Demo lab --- */.demo-lab{display:grid;grid-template-columns:1.08fr .92fr;gap:26px;align-items:center}.device-stage{position:relative;min-height:400px}.desktop-frame,.phone-frame{background:#0f172a;border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow-lg)}.desktop-frame{border-radius:var(--radius-lg);padding:10px}.desktop-frame img{aspect-ratio:16/10;width:100%;object-fit:cover;border-radius:var(--radius-sm)}.phone-frame{position:absolute;right:8px;bottom:-16px;width:32%;min-width:140px;border-radius:24px;padding:8px}.phone-screen{background:var(--white);border-radius:18px;padding:12px;min-height:240px}.phone-pill{width:42%;height:4px;border-radius:var(--radius-full);background:#cbd5e1;margin:0 auto 12px}.phone-card{border:1px solid var(--line);border-radius:var(--radius-sm);padding:10px;margin-bottom:8px}.phone-card strong{display:block;color:var(--ink);font-size:13px}.phone-card span{font-size:11px;color:var(--muted)}.funnel-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:24px}.funnel-strip div{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-xs)}.funnel-strip strong{display:block;color:var(--ink);margin-bottom:4px;font-size:14px}.funnel-strip span{font-size:12.5px;color:var(--muted)}/* --- Market/template cards --- */.template-filters{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 24px}.filter-btn{
  border:1px solid var(--line);background:var(--white);border-radius:var(--radius-full);
  padding:8px 14px;font-weight:600;color:var(--text);font-size:13px;cursor:pointer;
  transition:all var(--duration) var(--ease);
}.filter-btn.active{background:var(--ink);color:var(--white);border-color:var(--ink)}.market-card{display:grid;grid-template-columns:1.05fr .95fr;gap:20px;align-items:stretch;padding:20px}.market-visual{display:grid;grid-template-columns:1fr 110px;gap:8px;align-items:end}.market-desktop{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.market-mobile{border-radius:20px;background:#0f172a;padding:6px;box-shadow:var(--shadow)}.market-mobile img,.market-desktop img{width:100%;height:100%;object-fit:cover}.market-mobile img{aspect-ratio:9/16;border-radius:16px}.market-desktop img{aspect-ratio:16/10}.meta-row{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}.meta-row span{background:var(--blue-soft);color:#0c4a6e;border-radius:var(--radius-full);padding:5px 9px;font-size:11.5px;font-weight:600}/* --- Schema / Code --- */.schema-box{background:#020617;color:#cbd5e1;border-radius:var(--radius-lg);padding:22px;border:1px solid rgba(255,255,255,.08);box-shadow:var(--shadow)}.schema-box code{white-space:pre-wrap;color:#a7f3d0;font-size:13px}.code-panel{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:18px}.code-panel code{display:block;background:#020617;color:#a7f3d0;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:14px;font-size:13px;white-space:normal}/* --- Library cards --- */.block-library{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.library-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}.library-card strong{display:block;color:var(--ink);font-size:17px;margin-bottom:5px}.library-card span{color:var(--muted);font-size:13.5px}.mini-preview{margin-top:14px;border-radius:var(--radius);background:linear-gradient(135deg,var(--blue-soft),#ecfeff);border:1px solid #bae6fd;padding:12px}.mini-line{height:7px;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--primary),var(--secondary));margin:7px 0}.mini-line.short{width:56%}.mini-line.mid{width:76%}/* --- System tabs --- */.system-tabs{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 22px}.system-tab{border:1px solid var(--line);background:var(--white);color:var(--text);border-radius:var(--radius-full);padding:8px 14px;font-weight:600;font-size:13px;cursor:pointer}.system-tab.active{background:var(--ink);color:var(--white);border-color:var(--ink)}.system-panel{display:none}.system-panel.active{display:grid}.system-shot{display:grid;grid-template-columns:1fr 1fr;gap:16px}.system-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}.system-card strong{display:block;color:var(--ink);font-size:20px;margin-bottom:6px}/* Stack flow */.stack-flow{display:grid;gap:8px}.stack-flow span{display:flex;align-items:center;justify-content:center;min-height:44px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--blue-soft),#ecfeff);border:1px solid #bae6fd;font-weight:600;color:#0c4a6e;font-size:14px}.stack-card strong,.check-card strong{display:block;color:var(--ink);font-size:17px;margin-bottom:5px}.section.dark .stack-card p,.section.dark .check-card p{color:var(--text)}.section.dark .stack-card strong,.section.dark .check-card strong{color:var(--ink)}/* --- Comparison table --- */.comparison table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--radius-sm);overflow:hidden;box-shadow:var(--shadow-sm)}td,th{padding:14px 16px;border-bottom:1px solid var(--line);text-align:left}th{color:var(--ink);font-weight:600}/* --- Audit card --- */.audit-card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}.metric-row{display:grid;grid-template-columns:1fr auto;gap:4px 12px;border-bottom:1px solid var(--line);padding:12px 0}.metric-row:last-child{border-bottom:0}.metric-row span{font-weight:600;color:var(--ink)}.metric-row strong{color:var(--primary)}.metric-row small{grid-column:1/-1;color:var(--muted);font-size:13px}/* --- Location --- */.location-map{display:grid;gap:8px}.location-map strong{font-size:20px;color:var(--ink);margin-bottom:4px}.location-map span{background:var(--soft);border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px;font-weight:500;color:var(--text)}/* --- Map placeholder --- */.map{min-height:240px;display:grid;place-items:center;background:linear-gradient(135deg,#e0f2fe,var(--white));border-radius:var(--radius)}/* --- FAQ --- */.faq-list{display:grid;gap:10px;margin-top:18px}.faq-item{
  background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-xs);
}.faq-item summary{font-weight:600;color:var(--ink);cursor:pointer;font-size:15px}.faq-item summary::marker{color:var(--primary)}.faq-item div,.faq-item p{margin-top:10px;font-size:14.5px;line-height:1.65}/* --- Footer --- */.footer{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;
  gap:28px;background:#0f1e2e;color:#cbd5e1;padding:60px 4% 50px;
}.footer h4{color:var(--white);font-weight:600;font-size:15px;margin-bottom:12px}.footer .logo{color:var(--white);margin-bottom:12px}.footer p{font-size:14px;line-height:1.65;color:#94a3b8}.footer a{display:block;margin:6px 0;font-weight:400;font-size:14px;color:#cbd5e1;transition:color .2s var(--ease)}.footer a:hover{color:var(--secondary)}/* --- Sticky CTA & WhatsApp --- */.sticky-cta{
  position:fixed;right:20px;bottom:20px;z-index:30;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--ink);color:var(--white);border-radius:var(--radius-full);
  padding:12px 18px;font-weight:600;font-size:13.5px;
  line-height:1.2;white-space:nowrap;max-width:calc(100vw - 40px);
  box-shadow:0 8px 28px rgba(15,23,42,.2);
  transition:transform var(--duration) var(--ease),box-shadow var(--duration) var(--ease);
}.sticky-cta:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(15,23,42,.28)}.whatsapp{
  position:fixed;left:20px;bottom:20px;z-index:30;
  background:#25d366;color:var(--white);width:52px;height:52px;
  border-radius:50%;display:grid;place-items:center;
  box-shadow:0 8px 24px rgba(37,211,102,.25);
  transition:transform var(--duration) var(--ease);
}.whatsapp:hover{transform:translateY(-2px)}.whatsapp svg{width:24px;height:24px;fill:currentColor}/* --- Lead Form (WP) --- */.hd-wp-lead-form{
  background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:28px;
  box-shadow:var(--shadow);
}.hd-form-header{margin-bottom:8px}.hd-form-header .eyebrow{margin-bottom:8px}.hd-form-header h3{font-size:22px;margin:4px 0 6px}.hd-form-header p{font-size:14px;margin:0;color:var(--muted)}.hd-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.hd-field{display:grid;gap:6px;color:var(--ink);font-weight:600;font-size:13.5px}.hd-field span{font-size:13px}.hd-field-full{margin-top:0}.hd-form-grid .hd-field-full{grid-column:1/-1}.hd-schedule-panel{margin:4px 0 0;background:linear-gradient(135deg,#f8fafc,#eef7ff);border:1px solid #bfdbfe;border-radius:var(--radius-lg);padding:18px}.hd-schedule-head{display:grid;gap:5px;margin-bottom:14px}.hd-schedule-head strong{font-size:18px;color:var(--ink)}.hd-schedule-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:14px;align-items:start}.hd-time-slots{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.hd-time-slots label{cursor:pointer}.hd-time-slots input{position:absolute;opacity:0;pointer-events:none}.hd-time-slots span{display:grid;place-items:center;min-height:42px;border:1px solid #cbd5e1;border-radius:12px;background:var(--white);font-weight:600;color:var(--ink);transition:background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease),transform .2s var(--ease)}.hd-time-slots input:focus-visible + span{outline:3px solid rgba(37,99,235,.25);outline-offset:2px}.hd-time-slots input:checked + span{background:var(--primary);border-color:var(--primary);color:#fff;transform:translateY(-1px)}.hd-consent{
  display:flex!important;align-items:flex-start;gap:10px!important;
  color:var(--text)!important;font-size:13px!important;font-weight:400!important;
}.hd-consent input{width:auto!important;margin-top:3px}.hd-form-message{display:none;border-radius:var(--radius-sm);padding:12px 14px;font-weight:500;font-size:14px}.hd-form-message.success{display:block;background:var(--accent-light);color:#047857;border:1px solid #a7f3d0}.hd-form-message.error{display:block;background:#fef2f2;color:#b91c1c;border:1px solid #fecaca}/* --- Lead Popup --- */.hd-popup-open{overflow:hidden}.hd-lead-popup{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;padding:20px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s var(--ease),visibility .25s var(--ease)}.hd-lead-popup.is-open{opacity:1;visibility:visible;pointer-events:auto}.hd-popup-backdrop{position:absolute;inset:0;background:rgba(2,6,23,.68);backdrop-filter:blur(8px)}.hd-popup-dialog{position:relative;width:min(980px,100%);max-height:92vh;overflow:auto;display:grid;grid-template-columns:.9fr 1.1fr;gap:18px;background:linear-gradient(135deg,#f8fafc,#fff);border:1px solid rgba(255,255,255,.5);border-radius:28px;padding:22px;box-shadow:0 40px 120px rgba(2,6,23,.38);transform:translateY(18px) scale(.98);transition:transform .25s var(--ease)}.hd-lead-popup.is-open .hd-popup-dialog{transform:none}.hd-popup-close{position:absolute;right:16px;top:14px;width:38px;height:38px;border:0;border-radius:999px;background:#0f172a;color:#fff;font-size:24px;line-height:1;cursor:pointer;z-index:2}.hd-popup-copy{border-radius:22px;padding:26px;background:radial-gradient(circle at 15% 20%,rgba(37,99,235,.16),transparent 35%),linear-gradient(135deg,#0f172a,#164e63);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:420px}.hd-popup-copy h2{color:#fff;font-size:clamp(28px,3.6vw,44px);margin:8px 0 12px}.hd-popup-copy p{color:#dbeafe}.hd-popup-copy .eyebrow{color:#93c5fd}.hd-popup-list{display:grid;gap:10px;margin:20px 0 0;padding:0;list-style:none}.hd-popup-list li{display:flex;gap:9px;align-items:flex-start;color:#e0f2fe}.hd-popup-list li:before{content:"";width:8px;height:8px;border-radius:50%;background:#22c55e;margin-top:9px;flex:0 0 auto}.hd-popup-form{box-shadow:none;border-radius:22px}.hd-popup-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}/* --- Demo Site Styles --- */.demo-site{background:#f7fbff;color:#233044}.demo-nav{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:14px 5%;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);border-bottom:1px solid #dbe7f3}.demo-brand{font-weight:700;color:var(--primary);font-size:20px}.demo-nav nav{display:flex;gap:14px}.demo-hero{padding:76px 0;background:linear-gradient(135deg,#ecfeff,var(--white) 48%,#dbeafe)}.demo-hero-grid{display:grid;grid-template-columns:1fr .9fr;gap:34px;align-items:center}.demo-hero h1{font-size:clamp(34px,5.2vw,58px)}.demo-photo{border-radius:24px;overflow:hidden;box-shadow:var(--shadow);border:8px solid var(--white)}.demo-photo img{width:100%;height:420px;object-fit:cover}.demo-section{padding:70px 0}.demo-section.alt{background:var(--white)}.demo-services{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.demo-card{background:var(--white);border:1px solid #dbe7f3;border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.demo-card strong{display:block;color:var(--ink);font-size:18px;margin-bottom:8px}.demo-band{background:var(--primary);color:var(--white);padding:56px 0}.demo-band h2,.demo-band p{color:var(--white)}.demo-band .demo-card,.demo-band .demo-card p,.demo-band .demo-card li{color:var(--text)}.demo-band .demo-card strong{color:var(--ink)}.demo-form{display:grid;gap:12px;background:var(--white);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow)}.demo-form label{display:grid;gap:6px;color:var(--ink);font-weight:600}.demo-form input,.demo-form select,.demo-form textarea{border:1px solid #cbd5e1;border-radius:var(--radius-sm);padding:13px;font:inherit}.demo-faq{display:grid;gap:12px}.demo-faq details{background:var(--white);border:1px solid #dbe7f3;border-radius:var(--radius);padding:18px}.demo-faq summary{font-weight:600;color:var(--ink);cursor:pointer}/* --- Elementor compatibility --- */.healthdigital-editable-page{min-height:55vh}.healthdigital-elementor-full{overflow:hidden}.healthdigital-elementor-canvas{min-height:100vh}.hd-elementor-original-block-section{padding:0!important}.hd-elementor-original-block-section > .elementor-container{max-width:none!important}.hd-elementor-original-block-section .elementor-column-gap-no>.elementor-column>.elementor-element-populated{padding:0}.hd-elementor-original-block{width:100%}.hd-elementor-form-block-section .elementor-widget-shortcode{max-width:900px;margin:0 auto}.hd-elementor-hero .elementor-container{align-items:center}.hd-elementor-title .elementor-heading-title{font-size:clamp(34px,5vw,64px);line-height:1.04;letter-spacing:0;color:var(--ink)}.hd-elementor-intro{font-size:18px;color:var(--muted);max-width:680px}.hd-elementor-hero-image img{border-radius:28px;box-shadow:0 28px 80px rgba(15,23,42,.18);aspect-ratio:4/3;object-fit:cover;width:100%}.hd-elementor-headline-section .elementor-heading-title{font-size:clamp(28px,3vw,42px);color:var(--ink)}.hd-elementor-highlights .elementor-column-wrap,.hd-elementor-highlights .elementor-widget-wrap{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.hd-elementor-highlight{background:var(--white);border:1px solid var(--line);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm)}.hd-elementor-highlight .elementor-icon-box-title{font-size:18px;margin:0 0 8px}.hd-elementor-original-content{background:var(--white)}.hd-elementor-imported-page{max-width:100%;overflow:hidden}.hd-elementor-imported-page > .section:first-child{padding-top:24px}.hd-imported-form-note{background:#eff6ff;border:1px solid #bfdbfe;color:#075985;border-radius:var(--radius);padding:16px;margin:20px 0;font-weight:600}.hd-elementor-lead-section .elementor-container{align-items:center}.hd-elementor-fallback{max-width:100%;overflow:hidden}/* --- Animations (lightweight) --- */.js .reveal{opacity:0;transform:translateY(20px);transition:opacity .55s var(--ease),transform .55s var(--ease)}.js .reveal.visible{opacity:1;transform:none}.js .reveal.visible .card,
.js .reveal.visible .preview-card,
.js .reveal.visible .market-card,
.js .reveal.visible .stack-card,
.js .reveal.visible .block-item,
.js .reveal.visible .arch-step,
.js .reveal.visible .niche-card,
.js .reveal.visible .check-card{animation:riseIn .5s var(--ease) both}.js .reveal.visible :nth-child(2){animation-delay:.05s}.js .reveal.visible :nth-child(3){animation-delay:.1s}.js .reveal.visible :nth-child(4){animation-delay:.15s}.js .reveal.visible :nth-child(5){animation-delay:.2s}.hero-grid > *,.split > *,.contact-grid > *{animation:hdSoftIn .6s var(--ease) both}.hero-grid > *:nth-child(2),.split > *:nth-child(2){animation-delay:.08s}@keyframes riseIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@keyframes hdFloat{0%,100%{transform:translate3d(0,0,0)}50%{transform:translate3d(-18px,20px,0)}}@keyframes hdSoftIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}/* --- Responsive --- */@media(max-width:1100px){
  .site-header .primary-nav,.site-header .btn.small{display:none}
  .menu{display:block}
  .hero{padding:56px 0 64px}
  .hero.image{min-height:auto}
  .hero-grid,.product-hero .hero-grid,.grid,.grid.two,.grid.four,
  .hd-page-hero-grid,
  .split,.comparison,.contact-grid,.scenario-grid,.footer,
  .stat-grid,.ui-grid,.architecture,.block-showcase,.block-list,
  .niche-grid,.sample-dashboard,.demo-lab,.funnel-strip,
  .market-card,.market-visual,.demo-hero-grid,.demo-services,
  .tool-grid,.setup-map,.block-library,.system-shot{grid-template-columns:1fr}
  .hd-form-grid,.code-panel{grid-template-columns:1fr}
  .hd-schedule-grid{grid-template-columns:1fr}
  .hd-time-slots{grid-template-columns:repeat(2,minmax(0,1fr))}
  .section{padding:40px 0}
  .section-head{display:block}
  .price.featured{transform:none}
  .visual,.visual img{min-height:260px}
  .device-stage{min-height:auto}
  .phone-frame{position:relative;right:auto;bottom:auto;width:100%;margin-top:14px}
  .sticky-cta{left:auto;right:16px;text-align:center}
  .arch-step::after{display:none}
}@media(max-width:560px){
  h1{font-size:30px}
  .btn{width:100%}
  .actions{width:100%}
  .card,.price,.form,.panel,.preview-card,.stack-card,.check-card,.scenario-card,.blog-card{padding:20px}
  .card-media,.preview-media,.blog-media{margin:-20px -20px 16px}
  .hd-wp-lead-form{padding:20px}
  .hd-time-slots{grid-template-columns:1fr}
  .hd-elementor-highlights .elementor-column-wrap,.hd-elementor-highlights .elementor-widget-wrap{grid-template-columns:1fr}
  .hd-popup-dialog{grid-template-columns:1fr;padding:14px;border-radius:22px}
  .hd-popup-copy{min-height:auto;padding:22px}
  .hd-popup-fields{grid-template-columns:1fr}
  .sticky-cta{left:auto;right:12px;bottom:14px;padding:11px 14px}
  .whatsapp{left:12px;bottom:12px;width:48px;height:48px}
}.footer-bottom{grid-column:1/-1;border-top:1px solid rgba(255,255,255,.08);padding-top:22px;margin-top:10px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px}.footer-bottom p{margin:0;font-size:13px;color:rgba(255,255,255,.45)}.footer-legal{display:flex;flex-wrap:wrap;gap:12px 20px}.footer-legal a{font-size:13px;color:rgba(255,255,255,.45)}.footer-legal a:hover{color:rgba(255,255,255,.7)}@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .js .reveal{opacity:1;transform:none}
  .hero::after,.hero-grid > *,.split > *,.contact-grid > *{animation:none!important}
}/* ============================================================
   v2.5 — Mobile optimization + Hero image + Business Listings
   ============================================================ *//* --- Hero image (replaces dashboard graphic) --- */.hero-image-wrap{
  position:relative;
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 22px 52px rgba(15,23,42,.15);
  border:1px solid rgba(13,148,136,.16);
  aspect-ratio:16 / 9;
  max-height:300px;
  background:#eaf6f8;
}.hero-image-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}.hero-image-wrap::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(150deg,rgba(15,23,42,.25) 0%,rgba(22,78,99,.10) 60%,transparent 100%);
  pointer-events:none;
}/* --- CTA mobile improvements --- */.btn{
  -webkit-tap-highlight-color:transparent;
  min-height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}.btn.small{ min-height:38px; }/* --- Form mobile optimization (applies everywhere) --- */.form input:not([type="checkbox"]):not([type="radio"]),
.form select,
.form textarea,
.hd-wp-lead-form input:not([type="checkbox"]):not([type="radio"]),
.hd-wp-lead-form select,
.hd-wp-lead-form textarea{
  font-size:16px; /* prevents iOS zoom on focus */
  -webkit-appearance:none;
  appearance:none;
}.hd-field input:not([type="checkbox"]):not([type="radio"]),
.hd-field select,
.hd-field textarea{
  min-height:46px;
}.hd-field textarea{ min-height:96px; }.hd-field select{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;
  background-position:right 14px center;
  padding-right:38px;
}/* Larger touch targets for time-slot radios */.hd-time-slots label{ min-height:44px; }/* Consent checkbox — visible, themed, with a clear tick */.hd-consent{
  display:flex !important;
  align-items:flex-start !important;
  gap:10px !important;
  min-height:44px;
  cursor:pointer;
  font-size:13.5px !important;
  font-weight:400 !important;
  color:var(--text) !important;
}.hd-consent input[type="checkbox"]{
  -webkit-appearance:none !important;
  appearance:none !important;
  width:20px !important;
  height:20px !important;
  min-width:20px !important;
  border:2px solid #94a3b8 !important;
  border-radius:5px !important;
  background:#ffffff !important;
  display:inline-block !important;
  position:relative !important;
  cursor:pointer !important;
  margin:1px 0 0 !important;
  flex-shrink:0 !important;
  transition:background .15s var(--ease), border-color .15s var(--ease);
}.hd-consent input[type="checkbox"]:hover{
  border-color:var(--primary) !important;
}.hd-consent input[type="checkbox"]:checked{
  background:var(--primary) !important;
  border-color:var(--primary) !important;
}.hd-consent input[type="checkbox"]:checked::after{
  content:"";
  position:absolute;
  left:5px; top:1px;
  width:6px; height:11px;
  border:solid #ffffff;
  border-width:0 2.5px 2.5px 0;
  transform:rotate(45deg);
}.hd-consent input[type="checkbox"]:focus-visible{
  outline:3px solid rgba(13,148,136,.30);
  outline-offset:2px;
}/* --- Popup mobile optimization --- */.hd-lead-popup{ padding:0; }.hd-popup-dialog{
  scrollbar-width:thin;
  -webkit-overflow-scrolling:touch;
}@media(max-width:760px){
  /* Slide-up sheet behavior on phones */
  .hd-lead-popup{ align-items:flex-end; }
  .hd-popup-dialog{
    width:100%;
    max-height:88vh;
    border-radius:22px 22px 0 0;
    padding:14px 12px 16px;
    grid-template-columns:1fr;
    transform:translateY(100%);
    transition:transform .3s var(--ease);
    gap:8px;
  }
  .hd-lead-popup.is-open .hd-popup-dialog{ transform:none; }

  /* Hide the dark sales copy panel on phones — the form alone */
  .hd-popup-copy{ display:none; }

  .hd-popup-close{
    width:40px; height:40px; font-size:24px;
    top:8px; right:8px;
    background:#0f172a; color:#fff;
  }

  /* Compact popup form on mobile */
  .hd-popup-form{
    padding:14px 10px 6px !important;
    box-shadow:none;
    border-radius:14px;
  }
  .hd-popup-form .hd-form-header{
    margin-bottom:10px;
  }
  .hd-popup-form .hd-form-header .eyebrow{
    font-size:11px;
    margin-bottom:4px;
  }
  .hd-popup-form .hd-form-header h3{
    font-size:18px;
    line-height:1.25;
    margin:0 0 4px;
  }
  .hd-popup-form .hd-form-header p{
    font-size:12.5px;
    line-height:1.45;
    margin:0;
    color:#64748b;
  }
  .hd-popup-fields{
    grid-template-columns:1fr 1fr !important;
    gap:8px !important;
  }
  /* Make selects/long fields full width */
  .hd-popup-fields .hd-field:nth-child(3),
  .hd-popup-fields .hd-field:nth-child(4){
    grid-column:1 / -1;
  }
  .hd-popup-fields .hd-field{
    margin:0;
  }
  .hd-popup-fields .hd-field span{
    font-size:11.5px;
    margin-bottom:2px;
    font-weight:600;
    color:#475569;
  }
  .hd-popup-fields .hd-field input,
  .hd-popup-fields .hd-field select{
    padding:9px 11px;
    min-height:42px !important;
    font-size:15px;
  }
  .hd-popup-form .hd-consent{
    margin:8px 0 6px !important;
    font-size:12px !important;
    line-height:1.4;
    min-height:auto;
  }
  .hd-popup-form .hd-consent input[type="checkbox"]{
    width:18px !important; height:18px !important; min-width:18px !important;
  }
  .hd-popup-form .btn{
    padding:11px 16px;
    font-size:14.5px;
  }
}/* --- Sticky CTA + WhatsApp mobile cleanup --- */@media(max-width:560px){
  .sticky-cta{
    left:auto; right:14px; bottom:14px;
    padding:12px 16px;
    min-height:46px;
    border-radius:999px;
    box-shadow:0 12px 28px rgba(2,6,23,.22);
  }
  .whatsapp{
    left:14px; right:auto; bottom:14px;
    width:50px; height:50px;
    box-shadow:0 12px 28px rgba(34,197,94,.32);
  }
  .hd-popup-fields{ gap:10px; }
  .hd-schedule-grid{ gap:10px; }
}/* --- Contact / static forms become touch friendly --- */@media(max-width:760px){
  .form{ padding:20px; border-radius:18px; }
  .form input, .form select, .form textarea{ padding:12px 14px; }
  .form .btn{ width:100%; }
  .hd-form-grid{ grid-template-columns:1fr; gap:12px; }
  .actions{ flex-direction:column; align-items:stretch; }
  .actions .btn{ width:100%; }
  .pricing-grid, .grid.three, .grid.four, .pricing{ grid-template-columns:1fr; }
}/* Header mobile visual polish */@media(max-width:1100px){
  .site-header{ padding:12px 16px; gap:8px; }
  .site-header .logo{ font-size:18px; }
  .menu{
    background:transparent; border:0; font-size:26px;
    width:44px; height:44px; cursor:pointer;
    display:flex; align-items:center; justify-content:center;
    color:var(--ink);
  }
}/* ============================================================
   Business Listings (paid directory)
   ============================================================ */.hd-directory{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:18px;
  margin-top:24px;
}.hd-listing-card{
  background:#fff;
  border:1px solid #e2e8f0;
  border-radius:18px;
  padding:20px;
  display:flex;
  flex-direction:column;
  gap:10px;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}.hd-listing-card:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 40px rgba(15,23,42,.10);
}.hd-listing-card .hd-listing-logo{
  width:64px; height:64px; border-radius:14px;
  background:#f1f5f9; display:grid; place-items:center;
  overflow:hidden;
}.hd-listing-card .hd-listing-logo img{ width:100%; height:100%; object-fit:cover; }.hd-listing-card h3{ margin:0; font-size:18px; line-height:1.25; }.hd-listing-card .hd-listing-meta{
  display:flex; flex-wrap:wrap; gap:8px; font-size:12px;
}.hd-listing-card .hd-listing-meta span{
  background:#f1f5f9; color:#475569;
  padding:4px 10px; border-radius:999px;
  font-weight:500;
}.hd-listing-card .hd-listing-featured{
  background:linear-gradient(90deg,#fbbf24,#f59e0b);
  color:#78350f; font-weight:700;
}.hd-listing-card p{ color:#475569; font-size:14px; margin:0; flex:1; }.hd-listing-card .hd-listing-actions{ display:flex; gap:8px; margin-top:6px; flex-wrap:wrap; }.hd-listing-card .hd-listing-actions a{
  font-size:13px; font-weight:600; color:var(--primary);
  text-decoration:none;
}.hd-listing-card .hd-listing-actions a.btn{
  color:#fff; padding:8px 14px; min-height:36px;
}.hd-directory-filters{
  display:flex; flex-wrap:wrap; gap:10px; margin:20px 0;
  align-items:center;
}.hd-directory-filters input,
.hd-directory-filters select{
  padding:10px 14px; border:1px solid #cbd5e1;
  border-radius:10px; font-size:15px; min-height:42px;
  background:#fff;
}.hd-directory-filters input{ flex:1; min-width:200px; }/* Business application / registration form */.hd-business-form{
  background:#fff; border:1px solid #e2e8f0;
  border-radius:22px; padding:28px;
  display:grid; gap:14px;
  max-width:720px; margin:0 auto;
  box-shadow:0 18px 40px rgba(15,23,42,.06);
}.hd-business-form h2{ margin:0 0 6px; }.hd-business-form .hd-plan-grid{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:12px; margin:8px 0 6px;
}.hd-business-form .hd-plan{
  border:2px solid #e2e8f0; border-radius:14px;
  padding:14px; cursor:pointer; transition:border-color .2s,background .2s;
}.hd-business-form .hd-plan:has(input:checked){
  border-color:var(--primary); background:#eef7ff;
}.hd-business-form .hd-plan input{ display:none; }.hd-business-form .hd-plan strong{ display:block; font-size:16px; margin-bottom:4px; }.hd-business-form .hd-plan .hd-plan-price{ font-size:20px; color:var(--primary); font-weight:800; }.hd-business-form .hd-plan small{ color:#64748b; font-size:12px; }.hd-business-form .hd-message{
  padding:12px 16px; border-radius:12px;
  font-size:14px;
}.hd-business-form .hd-message.is-success{ background:#dcfce7; color:#166534; }.hd-business-form .hd-message.is-error{ background:#fee2e2; color:#991b1b; }/* Auth (login/register) panel */.hd-auth-panel{
  background:#fff; border:1px solid #e2e8f0;
  border-radius:22px; padding:32px;
  max-width:460px; margin:60px auto;
  box-shadow:0 18px 40px rgba(15,23,42,.06);
}.hd-auth-panel h2{ margin-top:0; }.hd-auth-panel .hd-auth-tabs{
  display:flex; gap:6px; margin-bottom:20px;
  background:#f1f5f9; padding:4px; border-radius:12px;
}.hd-auth-panel .hd-auth-tabs a{
  flex:1; text-align:center; padding:10px 12px;
  border-radius:9px; font-weight:600;
  color:#475569; text-decoration:none;
  transition:background .2s,color .2s;
}.hd-auth-panel .hd-auth-tabs a.is-active{
  background:#fff; color:var(--ink);
  box-shadow:0 2px 6px rgba(2,6,23,.06);
}.hd-auth-panel form{ display:grid; gap:12px; }.hd-auth-panel label span{
  display:block; font-size:13px; color:#475569;
  margin-bottom:4px; font-weight:600;
}.hd-auth-panel input{
  width:100%; padding:12px 14px;
  border:1px solid #cbd5e1; border-radius:10px;
  font-size:16px; min-height:46px;
}.hd-auth-panel .hd-auth-foot{
  font-size:13px; color:#64748b; text-align:center;
}/* Account / dashboard styles */.hd-account-shell{
  display:grid; grid-template-columns:240px 1fr; gap:24px;
  margin:32px 0;
}.hd-account-nav{
  background:#fff; border:1px solid #e2e8f0;
  border-radius:18px; padding:16px;
  display:flex; flex-direction:column; gap:4px;
}.hd-account-nav a{
  padding:10px 12px; border-radius:10px;
  font-weight:500; color:#334155; text-decoration:none;
}.hd-account-nav a:hover{ background:#f1f5f9; }.hd-account-nav a.is-active{ background:#eef7ff; color:var(--primary); font-weight:600; }.hd-account-main{
  background:#fff; border:1px solid #e2e8f0;
  border-radius:18px; padding:24px;
}.hd-listing-status{
  display:inline-block; padding:4px 10px;
  border-radius:999px; font-size:12px; font-weight:600;
}.hd-listing-status.is-pending{ background:#fef3c7; color:#92400e; }.hd-listing-status.is-active{ background:#dcfce7; color:#166534; }.hd-listing-status.is-expired{ background:#fee2e2; color:#991b1b; }@media(max-width:760px){
  .hd-account-shell{ grid-template-columns:1fr; }
  .hd-account-nav{ flex-direction:row; overflow-x:auto; }
  .hd-business-form{ padding:20px; border-radius:18px; }
  .hd-business-form .hd-plan-grid{ grid-template-columns:1fr; }
  .hd-auth-panel{ padding:22px; margin:24px auto; border-radius:18px; }
  .hd-directory-filters{ flex-direction:column; align-items:stretch; }
}/* ============================================================
   v2.6 — Color & visibility fixes
   ============================================================ *//* New button variant for dark backgrounds (transparent + white outline) */.btn.outline-light{
  background:transparent !important;
  color:#ffffff !important;
  border:1.5px solid rgba(255,255,255,.45) !important;
  box-shadow:none !important;
}.btn.outline-light:hover{
  background:rgba(255,255,255,.08) !important;
  border-color:#ffffff !important;
}/* Force readable colors for ghost button on dark sections.
   Previously the white ghost background made white text invisible. */.section-slab .btn.ghost,
.hero[style*="background"] .btn.ghost,
.demo-hero .btn.ghost,
[class*="hero "] .btn.ghost{
  background:transparent !important;
  color:#ffffff !important;
  border:1.5px solid rgba(255,255,255,.45) !important;
}.section-slab .btn.ghost:hover,
.demo-hero .btn.ghost:hover{
  background:rgba(255,255,255,.10) !important;
  border-color:#ffffff !important;
}/* Force light .btn variant text color to stay primary even when parents
   try to inherit "color: white". This was the empty-pill bug. */.btn.light,
.section-slab .btn.light{
  background:#ffffff !important;
  color:var(--primary) !important;
}.btn.light:hover{ background:#f1f5f9 !important; }/* Sticky CTA — always dark with white text, regardless of context.
   The "Get Free Website Audit" floating pill was rendering white-on-white. */.sticky-cta,
a.sticky-cta{
  background:#0f172a !important;
  color:#ffffff !important;
  text-decoration:none;
}.sticky-cta:hover{
  background:#1e293b !important;
  color:#ffffff !important;
}/* WhatsApp icon — never inherit currentColor for the SVG fill.
   Was rendering white-on-green = invisible icon. */.whatsapp{ color:#ffffff; }.whatsapp svg{ fill:#ffffff !important; }.whatsapp svg path{ fill:#ffffff !important; }/* Site header logo — make sure brand text is dark on a light header,
   white on a transparent/dark header. */.site-header{ background:#ffffff; }.site-header .logo{ color:var(--ink); }.site-header .logo span{ color:var(--primary); }.site-header nav a{ color:var(--ink); }.site-header nav a:hover{ color:var(--primary); }.site-header .btn.small{
  background:var(--primary) !important;
  color:#ffffff !important;
}/* When the header is over a dark hero (rare), use the .site-header.dark modifier */.site-header.dark{ background:transparent; }.site-header.dark .logo,
.site-header.dark nav a{ color:#ffffff; }/* Footer bottom bar — fix the "white-on-white" Sitemap link too. */.footer .footer-bottom a,
.footer-legal a{
  color:rgba(255,255,255,.7) !important;
}.footer .footer-bottom a:hover{ color:#ffffff !important; }/* Ensure white-on-dark CTA strips have readable secondary text */.section-slab p{ color:#cbd5e1 !important; }.section-slab .eyebrow{ color:rgba(125,211,252,.9) !important; }/* Form input visibility (some browsers show black-on-black if user has
   dark mode forced) — pin colors explicitly. */.hd-wp-lead-form input,
.hd-wp-lead-form select,
.hd-wp-lead-form textarea,
.form input,
.form select,
.form textarea{
  background:#ffffff !important;
  color:var(--ink) !important;
  border:1px solid var(--line) !important;
}.hd-wp-lead-form input::placeholder,
.form input::placeholder{ color:#94a3b8 !important; }/* Popup form field labels visible inside the popup */.hd-popup-form .hd-field span{ color:var(--ink) !important; }/* ============================================================
   Demo Marketplace cards (Envato-style preview grid)
   ============================================================ */.hd-demo-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:24px;
  margin-top:28px;
}.hd-demo-grid-2{ grid-template-columns:repeat(2, minmax(0, 1fr)); }.hd-demo-grid-4{ grid-template-columns:repeat(4, minmax(0, 1fr)); }.hd-demo-card{
  background:#ffffff;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease);
}.hd-demo-card:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 50px rgba(15,23,42,.10);
}.hd-demo-thumb{
  position:relative;
  aspect-ratio:16/10;
  background:#0f172a;
  overflow:hidden;
}.hd-demo-thumb img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .4s var(--ease);
}.hd-demo-card:hover .hd-demo-thumb img{ transform:scale(1.04); }.hd-demo-thumb-overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(15,23,42,0) 50%, rgba(15,23,42,.55) 100%);
  display:flex; align-items:flex-end; justify-content:center;
  padding:14px;
  opacity:0;
  transition:opacity .2s var(--ease);
}.hd-demo-card:hover .hd-demo-thumb-overlay,
.hd-demo-card:focus-within .hd-demo-thumb-overlay{ opacity:1; }.hd-demo-thumb-overlay .btn{
  background:#ffffff !important;
  color:var(--primary) !important;
}.hd-demo-body{
  padding:20px;
  display:flex; flex-direction:column; gap:8px;
  flex:1;
}.hd-demo-body h3{ margin:4px 0 2px; font-size:18px; line-height:1.25; }.hd-demo-body p{ font-size:14px; color:var(--text); margin:0; }.hd-demo-badge{
  display:inline-block;
  font-size:11px; font-weight:700; letter-spacing:.06em; text-transform:uppercase;
  color:var(--primary);
  background:var(--primary-light);
  padding:4px 10px;
  border-radius:999px;
  align-self:flex-start;
}.hd-demo-features{
  list-style:none; padding:0; margin:6px 0 0;
  display:grid; grid-template-columns:1fr 1fr; gap:6px;
}.hd-demo-features li{
  font-size:12.5px; color:#475569;
  padding-left:16px; position:relative;
}.hd-demo-features li::before{
  content:"✓"; position:absolute; left:0; top:0;
  color:var(--primary); font-weight:700;
}.hd-demo-actions{
  margin-top:auto; padding-top:14px;
  display:flex; gap:8px; flex-wrap:wrap;
}.hd-demo-actions .btn{ flex:1; min-width:120px; }.btn.outline{
  background:transparent;
  color:var(--ink);
  border:1.5px solid var(--line);
  box-shadow:none;
}.btn.outline:hover{
  background:#f8fafc;
  border-color:var(--primary);
  color:var(--primary);
}@media(max-width:960px){
  .hd-demo-grid,
  .hd-demo-grid-4{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}@media(max-width:560px){
  .hd-demo-grid,
  .hd-demo-grid-2,
  .hd-demo-grid-4{ grid-template-columns:1fr; }
  .hd-demo-features{ grid-template-columns:1fr; }
  .hd-demo-thumb-overlay{ opacity:1; }
}/* ============================================================
   List Your Business promo banner (Practo-style invitation)
   ============================================================ */.hd-list-business-banner{
  padding:56px 0;
  background:linear-gradient(120deg, #0d9488 0%, #0891b2 100%);
  color:#ffffff;
  margin:40px 0;
}.hd-list-business-inner{
  display:grid;
  grid-template-columns:1.4fr .6fr;
  gap:32px;
  align-items:center;
}.hd-list-business-banner .eyebrow{
  color:rgba(255,255,255,.85) !important;
  background:rgba(255,255,255,.10);
  padding:6px 12px;
  border-radius:999px;
  font-size:12px;
  display:inline-block;
  margin-bottom:12px;
}.hd-list-business-banner h2{
  color:#ffffff !important;
  margin:0 0 10px;
  font-size:28px;
  line-height:1.2;
}.hd-list-business-banner p{
  color:rgba(255,255,255,.92) !important;
  margin:0 0 16px;
  font-size:15.5px;
}.hd-list-business-points{
  list-style:none; padding:0; margin:0;
  display:grid; gap:8px;
}.hd-list-business-points li{
  color:rgba(255,255,255,.92);
  font-size:14px;
  padding-left:24px;
  position:relative;
}.hd-list-business-points li::before{
  content:"✓";
  position:absolute; left:0; top:0;
  width:18px; height:18px;
  background:rgba(255,255,255,.18);
  border-radius:50%;
  display:grid; place-items:center;
  font-size:11px; font-weight:700;
  color:#ffffff;
}.hd-list-business-cta{
  display:flex; flex-direction:column; gap:10px;
}.hd-list-business-cta .btn{
  background:#ffffff !important;
  color:var(--primary) !important;
  width:100%;
  justify-content:center;
}.hd-list-business-cta .btn.outline{
  background:transparent !important;
  color:#ffffff !important;
  border:1.5px solid rgba(255,255,255,.55) !important;
}.hd-list-business-cta .btn.outline:hover{
  background:rgba(255,255,255,.10) !important;
}@media(max-width:760px){
  .hd-list-business-inner{ grid-template-columns:1fr; gap:20px; }
  .hd-list-business-banner{ padding:40px 0; margin:24px 0; }
  .hd-list-business-banner h2{ font-size:24px; }
}/* ============================================================
   Business Listings — onboarding (Practo-style 3-step + register)
   ============================================================ */.hd-business-onboard{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:28px;
  align-items:start;
}.hd-business-onboard-intro{
  display:flex; flex-direction:column; gap:18px;
}.hd-business-steps{
  display:grid; gap:14px;
}.hd-business-step{
  background:#ffffff;
  border:1px solid var(--line);
  border-radius:14px;
  padding:16px 18px;
  display:grid;
  grid-template-columns:44px 1fr;
  gap:14px;
  align-items:flex-start;
}.hd-business-step-num{
  width:36px; height:36px; border-radius:50%;
  background:var(--primary); color:#ffffff;
  display:grid; place-items:center;
  font-weight:700; font-size:16px;
  grid-row:1 / span 2;
}.hd-business-step strong{
  display:block; color:var(--ink);
  font-size:15.5px; margin-bottom:4px;
  grid-column:2;
}.hd-business-step p{
  margin:0; font-size:13.5px; color:#475569;
  grid-column:2;
}.hd-business-perks{
  background:linear-gradient(135deg, rgba(13,148,136,.08), rgba(125,211,252,.10));
  border:1px solid rgba(13,148,136,.15);
  border-radius:14px;
  padding:16px 18px;
}.hd-business-perks strong{
  display:block; color:var(--ink); margin-bottom:8px;
  font-size:14px;
}.hd-business-perks ul{
  list-style:none; padding:0; margin:0;
  display:grid; gap:6px;
}.hd-business-perks li{
  font-size:13.5px; color:#334155;
  padding-left:20px; position:relative;
}.hd-business-perks li::before{
  content:"✓";
  position:absolute; left:0; top:0;
  color:var(--primary); font-weight:700;
}.hd-business-register{
  position:sticky;
  top:24px;
}.hd-business-register h3{ margin-top:0; }.hd-business-register label.hd-field{ margin:0; }.hd-business-register label.hd-field span{
  display:block; font-size:13px; color:#475569;
  margin-bottom:4px; font-weight:600;
}.hd-business-register label.hd-field input{
  width:100%; padding:11px 14px;
  border:1px solid #cbd5e1; border-radius:10px;
  font-size:16px; min-height:46px;
}.hd-business-register .btn{ width:100%; }@media(max-width:880px){
  .hd-business-onboard{ grid-template-columns:1fr; }
  .hd-business-register{ position:static; }
}/* Wider apply form layout when logged in (single column) */.hd-business-form .hd-form-grid{
  display:grid; gap:12px;
  grid-template-columns:repeat(2, minmax(0, 1fr));
}.hd-business-form .hd-field span{
  display:block; font-size:13px; color:#475569;
  margin-bottom:4px; font-weight:600;
}.hd-business-form .hd-field input,
.hd-business-form .hd-field select,
.hd-business-form .hd-field textarea{
  width:100%; padding:11px 14px;
  border:1px solid #cbd5e1; border-radius:10px;
  font-size:16px; min-height:46px;
}.hd-business-form .hd-field textarea{ min-height:120px; }@media(max-width:600px){
  .hd-business-form .hd-form-grid{ grid-template-columns:1fr; }
}/* Dynamic-block wrapper spacing on static pages */.hd-dynamic-block-wrap{ padding-top:24px; padding-bottom:24px; }/* ============================================================
   v2.7 — Quick form (compact 3-field inline form for hero/sidebar)
   ============================================================ */.hd-quick-form{
  background:#ffffff;
  border:1px solid var(--line);
  border-radius:18px;
  padding:22px;
  display:grid;
  gap:12px;
  box-shadow:0 18px 40px rgba(15,23,42,.08);
  max-width:420px;
}.hd-quick-form.is-compact{ padding:20px 18px; }.hd-quick-form-head{
  display:grid; gap:4px;
  margin-bottom:2px;
}.hd-quick-form-head strong{
  font-size:18px;
  font-weight:700;
  color:var(--ink);
  line-height:1.25;
}.hd-quick-form-head span{
  font-size:13.5px;
  color:#475569;
  line-height:1.45;
}.hd-quick-form-grid{
  display:grid;
  gap:10px;
}.hd-quick-form .hd-field{ margin:0; }.hd-quick-form .hd-field input{
  width:100%;
  padding:11px 14px;
  border:1px solid #cbd5e1;
  border-radius:10px;
  font-size:15.5px;
  min-height:44px;
  background:#ffffff;
  color:var(--ink);
  transition:border-color .15s var(--ease), box-shadow .15s var(--ease);
}.hd-quick-form .hd-field input:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(13,148,136,.18);
}.hd-quick-form .hd-consent{
  font-size:12.5px !important;
  color:#64748b !important;
  margin:2px 0 4px;
}.hd-quick-form .btn{ width:100%; padding:12px; font-size:15px; }.hd-quick-form-foot{
  margin:6px 0 0;
  text-align:center;
  font-size:12.5px;
  color:#64748b;
}.hd-quick-form-foot a{
  color:var(--primary);
  font-weight:600;
  text-decoration:none;
}.hd-quick-form-foot a:hover{ text-decoration:underline; }/* Hero quick form sits alongside the hero content on desktop */.product-hero .hero-grid > .hd-quick-form,
.hero .hero-grid > .hd-quick-form{
  align-self:center;
  margin:0;
}/* Screen reader only utility */.screen-reader-text{
  position:absolute !important;
  width:1px; height:1px;
  padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0);
  white-space:nowrap; border:0;
}@media(max-width:760px){
  .hd-quick-form{ padding:18px 16px; border-radius:16px; }
  .hd-quick-form-head strong{ font-size:17px; }
  .hd-quick-form .btn{ font-size:14.5px; }
}/* Hero side stack: image + quick form */.hero-side{
  display:grid;
  gap:18px;
  align-items:start;
  width:100%;
  max-width:560px;
  justify-self:end;
}.hero-side .hero-image-wrap{ margin:0; }.hero-side .hd-quick-form{
  margin:0;
  width:100%;
  max-width:none;
}@media(max-width:1100px){
  .hero-side{ margin-top:18px; }
}/* ============================================================
   v2.7 — Image library shortcodes
   ============================================================ *//* Image strip */.hd-image-strip-section{ padding:48px 0; }.hd-image-strip{
  display:grid;
  gap:14px;
  grid-template-columns:repeat(4, 1fr);
}.hd-image-strip-3{ grid-template-columns:repeat(3, 1fr); }.hd-image-strip-2{ grid-template-columns:repeat(2, 1fr); }.hd-image-card{
  margin:0;
  aspect-ratio:4/3;
  overflow:hidden;
  background:#0f172a;
  position:relative;
}.hd-image-card.is-rounded{ border-radius:14px; }.hd-image-card img{
  width:100%; height:100%; object-fit:cover;
  display:block;
  transition:transform .5s var(--ease);
}.hd-image-card:hover img{ transform:scale(1.05); }/* Image split (image + text two-column) */.hd-image-split-section{ padding:64px 0; }.hd-image-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
  align-items:center;
}.hd-image-split-section.is-flipped .hd-image-split{
  grid-template-areas:"body media";
}.hd-image-split-section.is-flipped .hd-image-split-media{ grid-area:media; }.hd-image-split-section.is-flipped .hd-image-split-body{ grid-area:body; }.hd-image-split-media{
  border-radius:18px;
  overflow:hidden;
  aspect-ratio:5/4;
  background:#0f172a;
  box-shadow:0 24px 50px rgba(15,23,42,.10);
}.hd-image-split-media img{
  width:100%; height:100%; object-fit:cover; display:block;
}.hd-image-split-body .eyebrow{
  color:var(--primary);
  font-weight:700;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:10px;
}.hd-image-split-body h2{
  margin:0 0 14px;
  font-size:30px;
  line-height:1.2;
}.hd-image-split-body p{
  margin:0 0 18px;
  color:var(--text);
  font-size:16px;
  line-height:1.65;
}.hd-process-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(300px, 420px);
  gap:28px;
  align-items:stretch;
}.hd-process-layout .architecture{
  grid-template-columns:repeat(2, minmax(0, 1fr));
  align-self:stretch;
}.hd-process-visual,
.hd-section-image-card,
.hd-final-cta-grid figure{
  position:relative;
  margin:0;
  overflow:hidden;
  border:1px solid rgba(148,163,184,.22);
  border-radius:22px;
  background:#eaf6f8;
  box-shadow:0 22px 54px rgba(15,23,42,.13);
}.hd-process-visual{
  background:#0f172a;
}.hd-process-visual img,
.hd-section-image-card img,
.hd-final-cta-grid figure img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}.hd-process-visual figcaption,
.hd-section-image-card figcaption{
  position:absolute;
  left:16px;
  right:16px;
  bottom:16px;
  padding:13px 14px;
  color:#e5f1ff;
  font-weight:700;
  font-size:13px;
  line-height:1.45;
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  background:rgba(15,23,42,.78);
  backdrop-filter:blur(10px);
}.hd-execution-split{
  align-items:start;
}.hd-section-image-card{
  aspect-ratio:16 / 10;
  margin-bottom:18px;
}.hd-section-image-card.is-large{
  aspect-ratio:4 / 3;
  margin-bottom:0;
}.hd-tight-grid{
  gap:16px;
}.hd-audit-cta-card.has-image{
  overflow:hidden;
  padding:0;
}.hd-audit-cta-card.has-image > img{
  width:100%;
  aspect-ratio:16 / 9;
  object-fit:cover;
  display:block;
}.hd-audit-cta-card.has-image > div{
  display:grid;
  gap:14px;
  padding:24px;
}.hd-final-cta-section{
  padding:56px 0;
}.hd-final-cta-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(280px, 420px);
  gap:36px;
  align-items:center;
}.hd-final-cta-grid h2{
  color:#ffffff;
}.hd-final-cta-grid p{
  max-width:580px;
  margin:0 0 24px;
  color:#94a3b8;
}.hd-final-cta-grid .actions{
  justify-content:flex-start;
}.hd-final-cta-grid figure{
  aspect-ratio:4 / 3;
  border-color:rgba(255,255,255,.13);
}/* Hero banner (for inner pages) */.hd-hero-banner{
  padding:96px 0 88px;
  background-size:cover;
  background-position:center;
  color:#ffffff;
  position:relative;
}.hd-hero-banner h1{
  color:#ffffff !important;
  margin:0 0 14px;
  font-size:clamp(28px, 4.4vw, 52px);
  line-height:1.15;
  max-width:780px;
}.hd-hero-banner p{
  color:rgba(255,255,255,.92) !important;
  margin:0 0 22px;
  font-size:17px;
  line-height:1.55;
  max-width:680px;
}.hd-hero-banner-eyebrow{
  display:inline-block;
  padding:6px 14px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;
  color:#ffffff;
  font-size:12px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.06em;
  margin-bottom:14px;
}.hd-hero-banner .btn{
  background:#ffffff !important;
  color:var(--primary) !important;
}/* Asymmetric gallery (1 big + 4 small) */.hd-image-gallery-section{ padding:64px 0; }.hd-image-gallery{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  grid-template-rows:repeat(2, 200px);
  gap:14px;
}.hd-gallery-item{
  margin:0;
  overflow:hidden;
  border-radius:14px;
  background:#0f172a;
}.hd-gallery-item img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .5s var(--ease);
}.hd-gallery-item:hover img{ transform:scale(1.05); }/* First image spans 2x2 (big) */.hd-gallery-item-1{ grid-column:1 / 3; grid-row:1 / 3; }.hd-gallery-item-2{ grid-column:3 / 4; grid-row:1 / 2; }.hd-gallery-item-3{ grid-column:4 / 5; grid-row:1 / 2; }.hd-gallery-item-4{ grid-column:3 / 4; grid-row:2 / 3; }.hd-gallery-item-5{ grid-column:4 / 5; grid-row:2 / 3; }@media(max-width:960px){
  .hd-image-strip,
  .hd-image-strip-3,
  .hd-image-strip-2{ grid-template-columns:repeat(2, 1fr); }
  .hd-image-split{ grid-template-columns:1fr; gap:24px; }
  .hd-image-split-section.is-flipped .hd-image-split{
    grid-template-areas:"media" "body";
  }
  .hd-image-split-body h2{ font-size:24px; }
  .hd-image-gallery{
    grid-template-columns:repeat(2, 1fr);
    grid-template-rows:repeat(3, 180px);
  }
  .hd-gallery-item-1{ grid-column:1 / 3; grid-row:1 / 2; }
  .hd-gallery-item-2{ grid-column:1 / 2; grid-row:2 / 3; }
  .hd-gallery-item-3{ grid-column:2 / 3; grid-row:2 / 3; }
  .hd-gallery-item-4{ grid-column:1 / 2; grid-row:3 / 4; }
  .hd-gallery-item-5{ grid-column:2 / 3; grid-row:3 / 4; }
  .hd-hero-banner{ padding:64px 0; }
}@media(max-width:560px){
  .hd-image-strip,
  .hd-image-strip-3{ grid-template-columns:1fr 1fr; }
  .hd-image-strip-section{ padding:32px 0; }
  .hd-image-split-section{ padding:40px 0; }
}/* ============================================================
   v2.8 — Directory page polish + date / time slot fixes
   ============================================================ *//* Directory page intro text — was using --muted (#94a3b8), too light */.hd-business-directory-section .section-head p{
  color:#475569 !important;
  font-size:15.5px;
}.hd-business-directory-section .section-head p a{
  color:var(--primary);
  text-decoration:none;
}.hd-business-directory-section .section-head p a:hover{
  text-decoration:underline;
}/* Filter bar — themed, with proper spacing */.hd-directory-filters{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:20px 0 28px;
  align-items:center;
  background:#ffffff;
  padding:14px;
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:0 4px 14px rgba(15,23,42,.04);
}.hd-directory-filters input,
.hd-directory-filters select{
  padding:11px 14px;
  border:1px solid #cbd5e1;
  border-radius:10px;
  font-size:15px;
  min-height:44px;
  background:#ffffff;
  color:var(--ink);
}.hd-directory-filters input::placeholder{
  color:#64748b !important;
}.hd-directory-filters input{ flex:1; min-width:220px; }.hd-directory-filters select{
  min-width:180px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;
  background-position:right 12px center;
  padding-right:36px;
  -webkit-appearance:none;
  appearance:none;
}.hd-directory-filters input:focus,
.hd-directory-filters select:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(13,148,136,.18);
}.hd-directory-filters .btn{
  padding:11px 22px;
  min-height:44px;
}/* Empty-state messaging — make it look intentional */.hd-directory-empty{
  background:#ffffff;
  border:1px dashed #cbd5e1;
  border-radius:18px;
  padding:48px 24px;
  text-align:center;
  margin-top:8px;
}.hd-directory-empty h3{
  margin:0 0 8px;
  font-size:20px;
  color:var(--ink);
}.hd-directory-empty p{
  color:#64748b;
  margin:0 0 18px;
  font-size:14.5px;
}.hd-directory-empty .btn{
  margin:0 auto;
}/* Date input — fix the washed-out native look */.hd-field input[type="date"]{
  color:var(--ink) !important;
  background:#ffffff;
  font-family:inherit;
  cursor:pointer;
  padding:11px 14px;
  font-size:15px;
}.hd-field input[type="date"]::-webkit-datetime-edit{
  color:var(--ink);
}.hd-field input[type="date"]::-webkit-calendar-picker-indicator{
  cursor:pointer;
  opacity:.6;
  filter:invert(38%) sepia(70%) saturate(380%) hue-rotate(140deg);
  transition:opacity .2s var(--ease);
  font-size:18px;
}.hd-field input[type="date"]::-webkit-calendar-picker-indicator:hover{
  opacity:1;
}.hd-field input[type="date"]:focus{
  outline:none;
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(13,148,136,.18);
}/* Time-slot pills — refined */.hd-time-slots{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:8px;
}.hd-time-slots label{
  cursor:pointer;
  position:relative;
}.hd-time-slots input[type="radio"]{
  position:absolute !important;
  opacity:0 !important;
  pointer-events:none !important;
  width:1px;
  height:1px;
}.hd-time-slots span{
  display:grid;
  place-items:center;
  min-height:46px;
  padding:6px 8px;
  border:1.5px solid #cbd5e1;
  border-radius:12px;
  background:#ffffff;
  font-weight:600;
  font-size:13px;
  color:var(--ink);
  line-height:1.2;
  text-align:center;
  transition:all .15s var(--ease);
  user-select:none;
}.hd-time-slots label:hover span{
  border-color:var(--primary);
  background:rgba(13,148,136,.06);
  color:var(--primary);
}.hd-time-slots input[type="radio"]:focus-visible + span{
  outline:3px solid rgba(13,148,136,.30);
  outline-offset:2px;
}.hd-time-slots input[type="radio"]:checked + span{
  background:var(--primary);
  border-color:var(--primary);
  color:#ffffff;
  box-shadow:0 4px 12px rgba(13,148,136,.25);
}@media(max-width:560px){
  .hd-time-slots{ grid-template-columns:repeat(3, minmax(0, 1fr)); gap:6px; }
  .hd-time-slots span{ min-height:42px; font-size:12px; }
}/* Schedule panel — slightly tighter on mobile */@media(max-width:760px){
  .hd-schedule-panel{ padding:14px; }
  .hd-schedule-grid{ grid-template-columns:1fr; gap:14px; }
}/* ============================================================
   v2.8 — Doctor profiles (Practo-style)
   ============================================================ */.hd-doctor-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:18px;
  margin-top:8px;
}.hd-doctor-card{
  background:#ffffff;
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease);
}.hd-doctor-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 40px rgba(15,23,42,.10);
}.hd-doctor-card.is-featured{
  border-color:rgba(245,158,11,.4);
  background:linear-gradient(180deg, #fffbeb 0%, #ffffff 60%);
}.hd-doctor-photo{
  position:relative;
  width:100%;
  aspect-ratio:1/1;
  background:#f1f5f9;
  overflow:hidden;
}.hd-doctor-photo img{
  width:100%; height:100%; object-fit:cover; display:block;
}.hd-doctor-photo-placeholder{
  width:100%; height:100%;
  display:grid; place-items:center;
  font-size:48px; font-weight:700; color:var(--primary);
  background:linear-gradient(135deg, rgba(13,148,136,.10), rgba(125,211,252,.20));
}.hd-doctor-verified{
  position:absolute; right:10px; top:10px;
  width:28px; height:28px; border-radius:50%;
  background:var(--primary); color:#ffffff;
  display:grid; place-items:center;
  font-size:14px; font-weight:700;
  box-shadow:0 4px 10px rgba(13,148,136,.30);
}.hd-doctor-body{
  padding:16px 18px;
  display:flex; flex-direction:column; gap:6px;
  flex:1;
}.hd-doctor-body h3{
  margin:2px 0;
  font-size:17px;
  line-height:1.25;
  color:var(--ink);
}.hd-doctor-specialty{
  margin:0;
  color:var(--primary);
  font-weight:600;
  font-size:13.5px;
}.hd-doctor-qual{
  margin:0;
  color:#64748b;
  font-size:12.5px;
}.hd-doctor-meta{
  display:flex; flex-wrap:wrap; gap:8px;
  margin-top:6px;
  font-size:12px;
  color:#475569;
}.hd-doctor-meta span{
  background:#f1f5f9;
  padding:3px 10px;
  border-radius:999px;
  font-weight:500;
}.hd-doctor-clinic{
  margin:4px 0 0;
  font-size:13px;
  color:#475569;
}.hd-doctor-badge{
  display:inline-block;
  background:linear-gradient(90deg,#fbbf24,#f59e0b);
  color:#78350f;
  font-weight:700;
  font-size:11px;
  padding:3px 10px;
  border-radius:999px;
  align-self:flex-start;
  text-transform:uppercase;
  letter-spacing:.04em;
}.hd-doctor-actions{
  margin-top:auto;
  padding-top:10px;
  display:flex; gap:8px;
}.hd-doctor-actions .btn{
  flex:1; justify-content:center;
}/* Single doctor profile page */.hd-single-doctor .section{
  padding:64px 0 80px;
}.hd-single-doctor .container{
  width:min(1040px,90%);
}.hd-doctor-profile{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:36px;
  align-items:start;
  background:#ffffff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:32px;
  box-shadow:0 18px 40px rgba(15,23,42,.06);
}.hd-doctor-photo-large{
  aspect-ratio:1/1;
  width:300px;
  max-width:100%;
  border-radius:18px;
  position:relative;
  overflow:hidden;
}.hd-doctor-quick-facts{
  margin-top:16px;
  display:grid; gap:8px;
}.hd-doctor-quick-facts div{
  display:flex; justify-content:space-between; gap:12px;
  font-size:13.5px;
  padding:8px 0;
  border-bottom:1px solid #f1f5f9;
}.hd-doctor-quick-facts span{ color:#64748b; }.hd-doctor-quick-facts strong{ color:var(--ink); }.hd-doctor-profile-right h1{
  margin:0 0 4px;
  font-size:28px;
  line-height:1.2;
}.hd-doctor-profile-right .hd-doctor-specialty{
  font-size:17px;
  margin-bottom:6px;
}.hd-doctor-profile-right .hd-doctor-qual{
  font-size:14px;
  margin-bottom:18px;
}.hd-doctor-bio{
  font-size:15px;
  line-height:1.65;
  color:var(--text);
  margin-bottom:24px;
}.hd-doctor-section{
  margin-top:20px;
  padding-top:20px;
  border-top:1px solid #f1f5f9;
}.hd-doctor-section h3{
  margin:0 0 8px;
  font-size:16px;
  color:var(--ink);
}.hd-doctor-section p{
  margin:4px 0;
  font-size:14.5px;
  color:#475569;
}.hd-doctor-actions-large{
  margin-top:24px;
  padding-top:0;
  flex-wrap:wrap;
}.hd-doctor-actions-large .btn{
  min-width:140px;
  flex:0 1 auto;
}@media(max-width:760px){
  .hd-doctor-profile{
    grid-template-columns:1fr;
    padding:20px;
    gap:20px;
  }
  .hd-doctor-photo-large{ width:100%; max-width:280px; margin:0 auto; }
  .hd-doctor-quick-facts{ max-width:280px; margin-left:auto; margin-right:auto; }
}/* === Enhanced Typography & Icons === *//* Larger section icons */.card .icon, .feature .icon, .niche-card .icon, .service-card .icon {
  width: 64px; height: 64px; border-radius: 16px;
  font-size: 28px;
}/* Larger SVG icons inside cards */.card svg, .feature svg, .niche-card svg {
  width: 32px; height: 32px;
}/* Better heading typography */h1 { font-weight: 800; letter-spacing: -0.03em; }h2 { font-weight: 700; letter-spacing: -0.02em; }h3 { font-weight: 700; }/* Hero heading more impactful */.hero h1 {
  font-size: clamp(36px, 4.5vw, 58px);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.03em;
}/* Better badge/pill styling */.pill {
  font-weight: 700;
  letter-spacing: 0.02em;
}/* Stat numbers bigger */.stat-grid strong, .stat strong, .metric strong {
  font-size: clamp(28px, 3vw, 42px);
  font-weight: 800;
  letter-spacing: -0.02em;
}/* Image strips from shortcodes */.hd-image-strip-section img, .hd-image-gallery img, .hd-image-split img {
  border-radius: 16px;
  box-shadow: 0 20px 50px rgba(15, 23, 42, .09);
}/* Better card hover */.card:hover, .price:hover, .niche-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 60px rgba(15, 23, 42, .12);
}/* Smooth transitions */.card, .price, .niche-card, .btn {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}/* === Audit Fix: Full-width CTA forms === */.hd-dynamic-block-wrap .form,
.section .form {
  max-width: 580px;
  margin: 0 auto;
}/* Full-width final CTA form sections */.section:last-of-type .form,
.hd-cta-full .form {
  max-width: 640px;
  margin: 0 auto;
  background: var(--white);
  border-radius: var(--radius);
  padding: 36px;
  box-shadow: var(--shadow);
  border: 1px solid var(--line);
}/* === Audit Fix: Card text too small === */.card p, .niche-card p, .price p {
  font-size: 15px;
  line-height: 1.65;
  color: #475569;
}.card h3, .niche-card h3 {
  font-size: 18px;
  margin-bottom: 8px;
}/* === Audit Fix: Better heading hierarchy === */.eyebrow, .pill {
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--primary);
  margin-bottom: 10px;
}/* === Audit Fix: Stronger section headings === */h2 {
  font-size: clamp(26px, 3vw, 40px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.15;
}/* === Audit Fix: Card hover effects === */.card, .niche-card, .price, .block-item {
  transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}.card:hover, .niche-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 60px rgba(15, 23, 42, .12);
  border-color: rgba(13, 148, 136, .2);
}.price:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 60px rgba(13, 148, 136, .12);
}/* === Audit Fix: Better service page card distinction === */.card .icon svg {
  width: 28px;
  height: 28px;
}/* Featured/core service cards */.card.featured, .price.featured {
  border: 2px solid var(--primary);
  position: relative;
}.card.featured::before {
  content: 'Core Service';
  position: absolute;
  top: -12px;
  left: 20px;
  background: var(--primary);
  color: white;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 12px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}/* === Audit Fix: Business listing card improvements === */.hd-listing-card {
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 40px;
  box-shadow: var(--shadow);
}.hd-listing-card h1 {
  font-size: 28px;
}.hd-listing-meta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 12px 0 20px;
}.hd-listing-meta span {
  font-size: 13px;
  padding: 4px 12px;
  border-radius: var(--radius-full);
  background: var(--bg);
  color: #475569;
  font-weight: 500;
}.hd-listing-featured {
  background: linear-gradient(135deg, var(--primary-light), rgba(125, 211, 252, .15)) !important;
  color: var(--primary) !important;
  font-weight: 700 !important;
}.hd-listing-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--line);
}.hd-listing-logo img {
  width: 80px;
  height: 80px;
  object-fit: contain;
  border-radius: 12px;
  border: 1px solid var(--line);
  margin-bottom: 12px;
}/* === Audit Fix: Doctor card improvements === */.hd-doc-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
  background: var(--white);
  box-shadow: var(--shadow-xs);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}.hd-doc-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow);
}.hd-doc-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--primary-light), rgba(125, 211, 252, .2));
  display: grid;
  place-items: center;
  font-size: 28px;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: 12px;
}.hd-doc-verified {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary);
  background: var(--primary-light);
  padding: 3px 10px;
  border-radius: var(--radius-full);
}/* === Audit Fix: Form field improvements === */.form input, .form select, .form textarea {
  padding: 14px 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  font-size: 15px;
  transition: border-color 0.2s, box-shadow 0.2s;
  background: var(--white);
}.form input:focus, .form select:focus, .form textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(13, 148, 136, .1);
}/* === Audit Fix: FAQ accordion improvements === */.faq dt {
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
  transition: color 0.2s;
}.faq dt:hover {
  color: var(--primary);
}.faq dd {
  font-size: 15px;
  line-height: 1.7;
  color: #475569;
  padding: 12px 0 18px;
}/* === Audit Fix: Image strips with captions === */.hd-image-strip-section figcaption,
.hd-image-gallery figcaption {
  font-size: 13px;
  color: #64748b;
  margin-top: 8px;
  text-align: center;
}/* === Audit Fix: Pricing cards desktop layout === */@media (min-width: 768px) {
  .pricing-grid, .price-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    align-items: start;
  }
}/* === Audit Fix: Stat counter larger on mobile === */@media (max-width: 640px) {
  .stat-grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .hero h1 {
    font-size: 32px;
  }
}/* === Footer disclaimer === */.footer-disclaimer {
  border-top: 1px solid rgba(255,255,255,.06);
  padding: 14px 0;
  font-size: 12px;
  color: #64748b;
  line-height: 1.6;
}/* ============================================================
   Final polish — forms and CTAs across all pages
   ============================================================ */.form,
.hd-wp-lead-form,
.hd-business-form,
.demo-form{
  width:100%;
  max-width:640px;
  margin-left:auto;
  margin-right:auto;
  background:#ffffff;
  border:1px solid #e2e8f0;
  border-radius:18px;
  padding:28px;
  box-shadow:0 18px 46px rgba(15,23,42,.07);
  overflow:hidden;
}.hd-quick-form{
  width:min(100%, 440px);
  max-width:440px;
  margin-left:auto;
  margin-right:auto;
  padding:24px;
  border-radius:18px;
  gap:14px;
}.hd-dynamic-block-wrap > .form,
.hd-dynamic-block-wrap > .hd-wp-lead-form,
.hd-dynamic-block-wrap > .hd-quick-form{
  margin-left:auto;
  margin-right:auto;
}.hd-form-header,
.hd-quick-form-head{
  margin:0 0 10px;
}.hd-form-header h3,
.hd-quick-form-head strong,
.hd-business-form h3,
.demo-form h3{
  display:block;
  margin:0 0 6px;
  color:var(--ink);
  font-size:clamp(19px, 1.6vw, 24px);
  line-height:1.25;
  letter-spacing:0;
}.hd-form-header p,
.hd-quick-form-head span{
  color:#64748b;
  font-size:14px;
  line-height:1.55;
}.hd-form-grid,
.hd-business-form .hd-form-grid{
  gap:14px;
}.hd-field{
  min-width:0;
}.hd-field span:not(.screen-reader-text),
.form label,
.demo-form label{
  color:#334155;
  font-size:13px;
  font-weight:700;
  line-height:1.35;
}.form input:not([type="checkbox"]):not([type="radio"]),
.form select,
.form textarea,
.hd-wp-lead-form input:not([type="checkbox"]):not([type="radio"]),
.hd-wp-lead-form select,
.hd-wp-lead-form textarea,
.hd-business-form input:not([type="checkbox"]):not([type="radio"]),
.hd-business-form select,
.hd-business-form textarea,
.demo-form input,
.demo-form select,
.demo-form textarea{
  width:100%;
  min-height:48px;
  padding:12px 15px;
  border:1px solid #d6e0ea !important;
  border-radius:12px;
  background:#ffffff !important;
  color:var(--ink) !important;
  font-size:16px;
  line-height:1.35;
  box-shadow:none;
  transition:border-color .18s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease);
}.form textarea,
.hd-wp-lead-form textarea,
.hd-business-form textarea,
.demo-form textarea{
  min-height:116px;
  resize:vertical;
}.form select,
.hd-wp-lead-form select,
.hd-business-form select,
.demo-form select{
  padding-right:42px;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23475569' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat;
  background-position:right 14px center;
}.form input::placeholder,
.form textarea::placeholder,
.hd-wp-lead-form input::placeholder,
.hd-wp-lead-form textarea::placeholder,
.hd-business-form input::placeholder,
.hd-business-form textarea::placeholder,
.demo-form input::placeholder,
.demo-form textarea::placeholder{
  color:#8da0ba !important;
  opacity:1;
}.form input:not([type="checkbox"]):not([type="radio"]):focus,
.form select:focus,
.form textarea:focus,
.hd-wp-lead-form input:not([type="checkbox"]):not([type="radio"]):focus,
.hd-wp-lead-form select:focus,
.hd-wp-lead-form textarea:focus,
.hd-business-form input:not([type="checkbox"]):not([type="radio"]):focus,
.hd-business-form select:focus,
.hd-business-form textarea:focus,
.demo-form input:focus,
.demo-form select:focus,
.demo-form textarea:focus{
  outline:none;
  border-color:var(--primary) !important;
  box-shadow:0 0 0 4px rgba(13,148,136,.14);
}.hd-consent{
  position:relative;
  display:flex !important;
  align-items:flex-start !important;
  gap:10px !important;
  min-height:auto;
  margin:2px 0 4px;
  padding:0;
  color:#64748b !important;
  font-size:13px !important;
  line-height:1.45;
}.hd-consent span{
  min-width:0;
}.hd-consent input[type="checkbox"]{
  width:20px !important;
  height:20px !important;
  min-width:20px !important;
  margin:0 !important;
  display:grid !important;
  place-items:center !important;
}.hd-consent input[type="checkbox"]:checked::after{
  left:auto !important;
  top:auto !important;
  width:6px !important;
  height:11px !important;
  margin-top:-2px !important;
  border-width:0 2.5px 2.5px 0 !important;
  transform:rotate(45deg) !important;
}.form .btn,
.hd-wp-lead-form .btn,
.hd-business-form .btn,
.demo-form .btn{
  width:100%;
  min-height:48px;
  border-radius:999px;
  padding:12px 20px;
  font-size:15px;
}.btn,
a.btn,
button.btn{
  text-align:center;
  line-height:1.2;
  white-space:normal;
}.actions .btn,
.hd-doctor-actions .btn,
.hd-listing-actions .btn,
.hd-demo-actions .btn{
  width:auto;
}.sticky-cta,
a.sticky-cta{
  display:inline-flex !important;
  align-items:center;
  justify-content:center;
  width:auto !important;
  min-width:0;
  max-width:calc(100vw - 40px);
  min-height:44px;
  padding:12px 18px !important;
  border-radius:999px !important;
  line-height:1.15;
  white-space:nowrap;
  box-shadow:0 14px 34px rgba(2,6,23,.22) !important;
}.whatsapp{
  width:52px !important;
  height:52px !important;
  min-width:52px;
  border-radius:50% !important;
}@media(max-width:760px){
  .form,
  .hd-wp-lead-form,
  .hd-business-form,
  .demo-form,
  .hd-quick-form{
    max-width:100%;
    padding:20px;
    border-radius:16px;
  }

  .hd-form-grid,
  .hd-business-form .hd-form-grid,
  .hd-popup-fields{
    grid-template-columns:1fr;
  }

  .sticky-cta,
  a.sticky-cta{
    right:14px !important;
    bottom:14px !important;
    left:auto !important;
    max-width:calc(100vw - 88px);
    min-height:46px;
    padding:11px 15px !important;
    font-size:13px;
  }

  .whatsapp{
    left:14px !important;
    bottom:14px !important;
    right:auto !important;
    width:50px !important;
    height:50px !important;
    min-width:50px;
  }
}@media(max-width:420px){
  .sticky-cta,
  a.sticky-cta{
    max-width:calc(100vw - 82px);
    font-size:12.5px;
  }
}/* ============================================================
   Public business listing page
   ============================================================ */body.single-hd_business{
  background:#f8fafc;
}.hd-single-business .section{
  padding:64px 0 80px;
}.hd-single-business .container{
  width:min(920px,90%);
}.hd-single-business .hd-listing-card{
  width:100%;
  max-width:780px !important;
  margin:0 auto !important;
  display:block;
  padding:36px 40px;
  border-radius:20px;
  box-shadow:0 22px 56px rgba(15,23,42,.08);
}.hd-single-business .hd-listing-logo{
  width:76px;
  height:76px;
  margin:0 0 18px;
  border-radius:16px;
  background:#f1f5f9;
  overflow:hidden;
}.hd-single-business .hd-listing-logo img{
  width:100%;
  height:100%;
  object-fit:contain;
  margin:0;
}.hd-single-business .hd-listing-card h1{
  margin:0 0 10px !important;
  font-size:clamp(30px, 4vw, 44px);
  line-height:1.08;
  letter-spacing:-.02em;
}.hd-single-business .hd-listing-card > p{
  margin:0 0 16px;
  color:#475569;
  font-size:16px;
  line-height:1.65;
}.hd-single-business .hd-listing-card > p strong{
  color:var(--ink);
  font-size:17px;
}.hd-single-business .hd-listing-meta{
  margin:16px 0 26px;
  gap:8px;
}.hd-single-business .hd-listing-meta span{
  background:#f1f5f9;
  color:#475569;
}.hd-single-business .hd-listing-card > div:not(.hd-listing-logo):not(.hd-listing-meta):not(.hd-listing-actions){
  color:#475569;
  font-size:15.5px;
  line-height:1.7;
}.hd-single-business .hd-listing-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-top:24px;
  padding-top:22px;
  border-top:1px solid #e2e8f0;
}.hd-single-business .hd-listing-actions .btn,
.hd-single-business .hd-listing-actions a.btn{
  width:auto;
  min-width:118px;
  min-height:46px;
  padding:11px 18px;
  border-radius:999px;
  font-size:14px;
  line-height:1.2;
  font-weight:700;
  color:#ffffff !important;
  background:var(--primary) !important;
  border:1.5px solid var(--primary) !important;
  box-shadow:0 10px 22px rgba(13,148,136,.16);
}.hd-single-business .hd-listing-actions .btn.ghost,
.hd-single-business .hd-listing-actions a.btn.ghost{
  color:var(--primary) !important;
  background:#ffffff !important;
  border-color:rgba(13,148,136,.28) !important;
  box-shadow:none;
}.hd-single-business .hd-listing-actions .btn:hover,
.hd-single-business .hd-listing-actions a.btn:hover{
  background:var(--primary-hover) !important;
  border-color:var(--primary-hover) !important;
  color:#ffffff !important;
}.hd-single-business .hd-listing-actions .btn.ghost:hover,
.hd-single-business .hd-listing-actions a.btn.ghost:hover{
  background:var(--primary-light) !important;
  border-color:var(--primary) !important;
  color:var(--primary) !important;
}@media(max-width:760px){
  .hd-single-business .section{
    padding:42px 0 64px;
  }

  .hd-single-business .hd-listing-card{
    padding:24px 20px;
    border-radius:18px;
  }

  .hd-single-business .hd-listing-actions{
    display:grid;
    grid-template-columns:1fr;
  }

  .hd-single-business .hd-listing-actions .btn,
  .hd-single-business .hd-listing-actions a.btn{
    width:100%;
  }
}/* ============================================================
   Floating CTA buttons — final sizing guard
   ============================================================ */.sticky-cta,
a.sticky-cta{
  position:fixed !important;
  inset:auto 22px 22px auto !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:auto !important;
  min-width:0 !important;
  max-width:240px !important;
  height:52px !important;
  min-height:52px !important;
  max-height:52px !important;
  aspect-ratio:auto !important;
  padding:0 20px !important;
  border:0 !important;
  border-radius:999px !important;
  background:#0f172a !important;
  color:#ffffff !important;
  font-size:13.5px !important;
  font-weight:800 !important;
  line-height:1 !important;
  white-space:nowrap !important;
  overflow:hidden !important;
  text-align:center !important;
  text-decoration:none !important;
  box-shadow:0 16px 34px rgba(2,6,23,.24) !important;
  z-index:80 !important;
}.sticky-cta:hover,
a.sticky-cta:hover{
  transform:translateY(-2px);
  background:#1e293b !important;
}.sticky-cta-full,
.sticky-cta-short{
  display:block;
  color:inherit;
  line-height:1;
}.sticky-cta-short{
  display:none;
}.whatsapp,
a.whatsapp{
  position:fixed !important;
  inset:auto auto 22px 22px !important;
  display:grid !important;
  place-items:center !important;
  width:52px !important;
  min-width:52px !important;
  max-width:52px !important;
  height:52px !important;
  min-height:52px !important;
  max-height:52px !important;
  aspect-ratio:1 / 1 !important;
  padding:0 !important;
  border:0 !important;
  border-radius:50% !important;
  background:#22c55e !important;
  color:#ffffff !important;
  overflow:hidden !important;
  box-shadow:0 16px 34px rgba(34,197,94,.30) !important;
  z-index:80 !important;
}.whatsapp svg,
a.whatsapp svg{
  width:24px !important;
  height:24px !important;
  display:block !important;
}@media(max-width:760px){
  .sticky-cta,
  a.sticky-cta{
    inset:auto 14px 14px auto !important;
    max-width:124px !important;
    height:48px !important;
    min-height:48px !important;
    max-height:48px !important;
    padding:0 16px !important;
    font-size:13px !important;
  }

  .sticky-cta-full{
    display:none;
  }

  .sticky-cta-short{
    display:block;
  }

  .whatsapp,
  a.whatsapp{
    inset:auto auto 14px 14px !important;
    width:50px !important;
    min-width:50px !important;
    max-width:50px !important;
    height:50px !important;
    min-height:50px !important;
    max-height:50px !important;
  }
}@media(max-width:380px){
  .sticky-cta,
  a.sticky-cta{
    max-width:112px !important;
    padding:0 14px !important;
    font-size:12.5px !important;
  }
}/* Business profile action buttons — final color guard */body.single-hd_business .panel > .eyebrow{
  display:none !important;
}body.single-hd_business .split{
  grid-template-columns:1fr !important;
}body.single-hd_business .split > aside{
  display:none !important;
}body.single-hd_business .split > article.panel{
  width:min(920px,90%) !important;
  margin:0 auto !important;
  padding:0 !important;
  border:0 !important;
  box-shadow:none !important;
  background:transparent !important;
}body.single-hd_business .hd-listing-actions a.btn{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:auto !important;
  min-width:118px !important;
  min-height:46px !important;
  padding:11px 18px !important;
  color:#ffffff !important;
  background:var(--primary) !important;
  border:1.5px solid var(--primary) !important;
  border-radius:999px !important;
  box-shadow:0 10px 22px rgba(13,148,136,.16) !important;
  font-size:14px !important;
  font-weight:800 !important;
  line-height:1.2 !important;
  text-indent:0 !important;
  overflow:visible !important;
}body.single-hd_business .hd-listing-actions a.btn.ghost{
  color:var(--primary) !important;
  background:#ffffff !important;
  border-color:rgba(13,148,136,.30) !important;
  box-shadow:none !important;
}body.single-hd_business .hd-listing-actions a.btn.ghost:hover{
  color:var(--primary) !important;
  background:var(--primary-light) !important;
  border-color:var(--primary) !important;
}@media(max-width:760px){
  body.single-hd_business .hd-listing-actions{
    display:grid !important;
    grid-template-columns:1fr !important;
  }

  body.single-hd_business .hd-listing-actions a.btn{
    width:100% !important;
  }
}/* Doctor directory — compact cards */.hd-doctor-directory-section .container{
  width:min(1120px,90%);
}.hd-doctor-directory-section .hd-doctor-grid{
  grid-template-columns:repeat(auto-fill, minmax(230px, 260px));
  justify-content:start;
  gap:18px;
}.hd-doctor-directory-section .hd-doctor-card{
  max-width:260px;
  border-radius:16px;
}.hd-doctor-directory-section .hd-doctor-photo{
  aspect-ratio:4 / 3;
}.hd-doctor-directory-section .hd-doctor-photo-placeholder{
  font-size:36px;
}.hd-doctor-directory-section .hd-doctor-body{
  padding:14px 16px 16px;
  gap:5px;
}.hd-doctor-directory-section .hd-doctor-body h3{
  font-size:16px;
}.hd-doctor-directory-section .hd-doctor-meta{
  gap:6px;
  margin-top:5px;
}.hd-doctor-directory-section .hd-doctor-meta span{
  padding:3px 9px;
  font-size:11.5px;
}.hd-doctor-directory-section .hd-doctor-actions .btn{
  min-height:40px;
  padding:9px 14px;
  font-size:13.5px;
}.hd-doctor-bio p{
  margin:0 0 12px;
}.hd-doctor-bio p:last-child{
  margin-bottom:0;
}@media(max-width:760px){
  .hd-doctor-directory-section .hd-doctor-grid{
    grid-template-columns:repeat(auto-fill, minmax(210px, 1fr));
  }

  .hd-doctor-directory-section .hd-doctor-card{
    max-width:none;
  }

  .hd-doctor-directory-section .hd-doctor-photo{
    aspect-ratio:5 / 3;
  }
}/* Services page — top form, image and long bottom content */.hd-services-top{
  padding-top:60px;
  padding-bottom:72px;
  background:linear-gradient(180deg, #ffffff 0%, #f7fbff 100%);
}.hd-services-top .split{
  grid-template-columns:minmax(0, 1.08fr) minmax(380px, .92fr);
  align-items:stretch;
  gap:32px;
}.hd-services-image-only{
  padding-top:56px;
}.hd-services-image-only .service-top-image{
  max-width:1040px;
  margin:0 auto;
}.service-top-image,
.hero-support-image{
  position:relative;
  width:100%;
  max-width:100%;
  min-height:500px;
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:24px;
  background:#eaf6f8;
  box-shadow:0 28px 70px rgba(15,23,42,.14);
}.service-top-image::after,
.hero-support-image::after{
  content:"";
  position:absolute;
  inset:auto 0 0;
  height:50%;
  background:linear-gradient(180deg, rgba(15,23,42,0) 0%, rgba(15,23,42,.72) 100%);
  pointer-events:none;
}.service-top-image img,
.hero-support-image img{
  width:100%;
  max-width:100%;
  height:100%;
  min-height:500px;
  display:block;
  object-fit:cover;
}.service-image-note{
  position:absolute;
  left:24px;
  right:24px;
  bottom:24px;
  z-index:1;
  display:grid;
  gap:7px;
  padding:20px;
  color:#ffffff;
  border:1px solid rgba(255,255,255,.12);
  border-radius:18px;
  background:rgba(15,23,42,.78);
  backdrop-filter:blur(12px);
  box-shadow:0 18px 36px rgba(15,23,42,.24);
}.service-image-note strong{
  color:#ffffff;
  font-size:20px;
  line-height:1.25;
}.service-image-note span{
  color:#e5f1ff;
  font-size:15.5px;
  line-height:1.6;
}.hd-bottom-cta{
  padding-top:48px;
}.hd-cta-panel{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:28px;
  align-items:center;
  padding:34px;
  border:1px solid rgba(15,148,136,.22);
  border-radius:24px;
  color:#ffffff;
  background:linear-gradient(135deg, #0f766e 0%, #14b8a6 100%);
  box-shadow:0 24px 60px rgba(15,23,42,.14);
}.hd-cta-panel h2{
  color:#ffffff;
  margin:8px 0 10px;
}.hd-cta-panel p{
  max-width:680px;
  color:rgba(255,255,255,.86);
  margin:0;
}.hd-cta-panel .eyebrow{
  color:#dffaf6;
  border-color:rgba(255,255,255,.24);
  background:rgba(255,255,255,.12);
}.hd-cta-panel .actions{
  justify-content:flex-end;
}.hd-cta-panel .btn{
  background:#ffffff;
  color:#0f766e;
  border-color:#ffffff;
}.hd-cta-panel .btn.ghost{
  color:#ffffff;
  background:transparent;
  border-color:rgba(255,255,255,.65);
}.hd-audit-cta-card{
  align-self:stretch;
  display:grid;
  align-content:center;
  gap:16px;
}.hd-audit-cta-card .actions{
  margin-top:4px;
}.hd-services-top .form{
  width:100%;
  align-self:stretch;
  padding:34px;
  border-radius:24px;
  box-shadow:0 22px 48px rgba(15,23,42,.10);
}.hd-services-top .form h2{
  margin:0 0 8px;
  font-size:26px;
  line-height:1.2;
}.hd-services-top .form p{
  margin:0 0 18px;
  color:var(--muted);
}.hd-services-top .form textarea{
  min-height:108px;
  resize:vertical;
}.hd-services-top .form .btn{
  width:100%;
}.hd-services-deep-content{
  display:grid;
  gap:28px;
  margin-top:18px;
}.hd-services-copy-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:20px;
}.hd-services-copy-grid article{
  padding:26px;
  border:1px solid var(--border);
  border-radius:18px;
  background:#ffffff;
  box-shadow:0 14px 34px rgba(15,23,42,.06);
}.hd-services-copy-grid h3{
  margin:0 0 12px;
  font-size:20px;
}.hd-services-copy-grid p{
  margin:0 0 12px;
  color:var(--muted);
  line-height:1.7;
}.hd-services-copy-grid p:last-child{
  margin-bottom:0;
}.hd-services-proof-row{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
}.hd-services-proof-row div{
  display:grid;
  gap:6px;
  padding:18px;
  border:1px solid rgba(13,148,136,.18);
  border-radius:16px;
  background:linear-gradient(180deg, #f0fdfa 0%, #ffffff 100%);
}.hd-services-proof-row strong{
  color:var(--primary);
  font-size:15px;
}.hd-services-proof-row span{
  color:var(--muted);
  font-size:13.5px;
  line-height:1.55;
}@media(max-width:900px){
  .hd-services-copy-grid,
  .hd-services-proof-row{
    grid-template-columns:1fr 1fr;
  }
}@media(max-width:760px){
  .hd-services-top{
    padding-top:34px;
    padding-bottom:48px;
  }

  .hd-services-top .split{
    grid-template-columns:1fr;
    gap:20px;
  }

  .service-top-image,
  .hero-support-image,
  .hero-support-image img,
  .service-top-image img{
    min-height:300px;
  }

  .service-image-note{
    left:14px;
    right:14px;
    bottom:14px;
    padding:15px;
    border-radius:16px;
  }

  .service-image-note strong{
    font-size:17px;
  }

  .service-image-note span{
    font-size:14px;
  }

  .hd-services-top .form{
    padding:22px;
    border-radius:18px;
  }

  .hd-services-top .form h2{
    font-size:22px;
  }

  .hd-services-copy-grid,
  .hd-services-proof-row{
    grid-template-columns:1fr;
  }

  .hd-services-copy-grid article{
    padding:20px;
  }
}/* Services page conversion/readability pass */.site-header nav a{
  font-size:14.5px;
  font-weight:600;
}.site-header nav a.is-active,
.site-header nav .current-menu-item > a,
.site-header nav .current_page_item > a{
  color:var(--primary);
  background:var(--primary-light);
  border-radius:999px;
  padding:8px 12px;
}.site-header .btn.small{
  min-height:42px;
  padding:11px 18px;
  font-size:14px;
  font-weight:800;
}.services-page .hero,
body.page-slug-services .hero{
  min-height:620px;
}.services-page .services-hero-grid,
body.page-slug-services .services-hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(360px, 440px);
  gap:46px;
  align-items:center;
}.services-page .services-hero-copy,
body.page-slug-services .services-hero-copy{
  min-width:0;
}.services-page .hero h1,
body.page-slug-services .hero h1{
  max-width:760px;
}.services-page .hero p,
body.page-slug-services .hero p{
  font-size:18px;
  line-height:1.65;
}.services-page .section:not(.section-slab) p,
body.page-slug-services .section:not(.section-slab) p{
  color:#475569;
}.services-page .badges span,
body.page-slug-services .badges span{
  font-size:14px;
  font-weight:700;
  padding:9px 14px;
}.services-page .services-hero-form,
body.page-slug-services .services-hero-form{
  width:100%;
  max-width:440px;
  justify-self:end;
  padding:28px;
  color:var(--text);
  background:rgba(255,255,255,.96);
  border:1px solid rgba(255,255,255,.72);
  border-radius:24px;
  box-shadow:0 26px 60px rgba(15,23,42,.22);
  backdrop-filter:blur(14px);
}.services-page .hero.image .services-hero-form h2,
body.page-slug-services .hero.image .services-hero-form h2{
  margin:0 0 8px;
  color:var(--ink);
  font-size:25px;
  line-height:1.2;
}.services-page .hero.image .services-hero-form p,
body.page-slug-services .hero.image .services-hero-form p{
  margin:0 0 16px;
  color:#64748b;
  font-size:15px;
  line-height:1.55;
}.services-page .services-hero-form textarea,
body.page-slug-services .services-hero-form textarea{
  min-height:96px;
  resize:vertical;
}.services-page .services-hero-form .hd-consent,
body.page-slug-services .services-hero-form .hd-consent{
  color:#64748b;
}.services-page .services-hero-form .btn,
body.page-slug-services .services-hero-form .btn{
  width:100%;
}.services-page .hero .services-hero-form .hd-quick-form-foot,
body.page-slug-services .hero .services-hero-form .hd-quick-form-foot,
.services-page .hero .hd-quick-form-foot,
body.page-slug-services .hero .hd-quick-form-foot{
  margin:10px 0 0;
  color:#64748b;
  font-size:14px;
  line-height:1.5;
  text-align:center;
}.services-page .hero .services-hero-form .hd-quick-form-foot a,
body.page-slug-services .hero .services-hero-form .hd-quick-form-foot a,
.services-page .hero .hd-quick-form-foot a,
body.page-slug-services .hero .hd-quick-form-foot a{
  color:var(--primary);
  font-weight:800;
}.hd-service-overview .container,
.hd-package-section .container,
.hd-elementor-dynamic-block-section .elementor-container{
  max-width:1220px;
}.hd-service-overview .card{
  position:relative;
  padding-top:28px;
}.hd-service-overview .card .hd-card-icon{
  margin-bottom:14px;
}.service-label{
  position:static;
  display:inline-flex;
  align-items:center;
  width:max-content;
  min-height:24px;
  margin:0 0 14px;
  padding:4px 9px;
  color:var(--primary);
  background:var(--primary-light);
  border:1px solid rgba(13,148,136,.14);
  border-radius:999px;
  font-size:11px;
  font-weight:900;
  line-height:1;
  text-transform:uppercase;
  letter-spacing:.04em;
}.hd-service-overview .card.is-core{
  border-color:rgba(13,148,136,.24);
  box-shadow:0 18px 42px rgba(13,148,136,.08);
}.hd-service-overview .card h3,
.hd-service-overview .card p,
.cards-grid .card h3,
.cards-grid .card p{
  line-height:1.55;
}.hd-service-overview .card p,
.cards-grid .card p,
.price p,
.price li{
  font-size:15.5px;
  line-height:1.7;
}.section-slab .architecture{
  counter-reset:service-step;
  gap:16px;
}.section-slab .arch-step{
  min-height:160px;
  padding:24px 18px 22px;
}.section-slab .arch-step::before{
  counter-increment:service-step;
  content:counter(service-step);
  display:grid;
  place-items:center;
  width:30px;
  height:30px;
  margin-bottom:14px;
  color:#04111f;
  background:var(--secondary);
  border-radius:999px;
  font-size:14px;
  font-weight:900;
}.section-slab .arch-step strong{
  font-size:16px;
}.section-slab .arch-step span{
  font-size:14.5px;
  line-height:1.65;
}.hd-package-section .pricing{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:20px;
}.hd-package-section .price{
  display:flex;
  flex-direction:column;
  min-height:100%;
}.hd-package-section .price .btn{
  margin-top:auto;
  align-self:flex-start;
}.best-for,
.recommended{
  display:inline-flex;
  width:max-content;
  max-width:100%;
  padding:6px 10px;
  margin-bottom:12px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  line-height:1.35;
}.best-for{
  color:#475569;
  background:#f1f5f9;
}.recommended{
  color:#ffffff;
  background:var(--primary);
}.hd-image-card{
  position:relative;
}.hd-image-card figcaption{
  position:absolute;
  left:12px;
  right:12px;
  bottom:12px;
  padding:8px 10px;
  color:#ffffff;
  background:rgba(15,23,42,.78);
  border-radius:10px;
  font-size:13px;
  font-weight:800;
  line-height:1.25;
  text-align:center;
}.hd-services-deliverables-intro{
  max-width:760px;
  margin:30px 0 22px;
}.hd-services-deliverables-intro h2{
  margin:0 0 10px;
  font-size:clamp(28px, 3vw, 38px);
}.hd-services-deliverables-intro p{
  margin:0;
  color:var(--muted);
  font-size:16px;
  line-height:1.7;
}.hd-system-flow{
  display:grid;
  grid-template-columns:repeat(6, minmax(0, 1fr));
  gap:10px;
  padding:18px;
  border:1px solid rgba(13,148,136,.16);
  border-radius:18px;
  background:#ffffff;
  box-shadow:0 12px 32px rgba(15,23,42,.06);
}.hd-system-flow span{
  position:relative;
  display:grid;
  place-items:center;
  min-height:58px;
  padding:10px 12px;
  color:var(--ink);
  background:var(--primary-light);
  border:1px solid rgba(13,148,136,.16);
  border-radius:14px;
  font-size:13.5px;
  font-weight:900;
  line-height:1.25;
  text-align:center;
}.hd-system-flow span:not(:last-child)::after{
  content:"→";
  position:absolute;
  right:-14px;
  z-index:2;
  color:var(--primary);
  font-weight:900;
}.faq-list{
  gap:12px;
}.faq-item{
  padding:0;
  overflow:hidden;
}.faq-item summary{
  position:relative;
  min-height:58px;
  display:flex;
  align-items:center;
  padding:18px 54px 18px 20px;
  font-size:16px;
  line-height:1.4;
  list-style:none;
}.faq-item summary::-webkit-details-marker{
  display:none;
}.faq-item summary::after{
  content:"+";
  position:absolute;
  right:20px;
  top:50%;
  transform:translateY(-50%);
  width:26px;
  height:26px;
  display:grid;
  place-items:center;
  color:var(--primary);
  background:var(--primary-light);
  border-radius:50%;
  font-size:18px;
  font-weight:900;
}.faq-item[open] summary::after{
  content:"-";
}.faq-item div,
.faq-item p{
  margin:0;
  padding:0 20px 20px;
  color:var(--muted);
  font-size:15.5px;
  line-height:1.75;
}.hd-list-business-inner{
  gap:28px;
}.hd-list-business-inner h2{
  max-width:780px;
}.hd-list-business-cta{
  min-width:260px;
}.footer p,
.footer a{
  font-size:15px;
}.footer-contact{
  display:grid;
  gap:4px;
  margin:14px 0;
}.footer-contact a{
  color:#e2e8f0;
  font-weight:700;
}.footer-mini-disclaimer{
  max-width:620px;
  color:#a7b4c5 !important;
}@media(max-width:980px){
  .hd-package-section .pricing,
  .hd-system-flow,
  .hd-process-layout,
  .hd-final-cta-grid{
    grid-template-columns:1fr;
  }

  .hd-process-layout .architecture{
    grid-template-columns:1fr;
  }

  .hd-system-flow span:not(:last-child)::after{
    content:"↓";
    right:auto;
    bottom:-16px;
    top:auto;
  }
}@media(max-width:760px){
  .site-header nav a{
    font-size:15px;
  }

  .services-page .hero p,
  body.page-slug-services .hero p{
    font-size:16px;
  }

  .services-page .hero,
  body.page-slug-services .hero{
    min-height:auto;
  }

  .services-page .services-hero-grid,
  body.page-slug-services .services-hero-grid{
    grid-template-columns:1fr;
    gap:24px;
  }

  .services-page .services-hero-form,
  body.page-slug-services .services-hero-form{
    max-width:none;
    justify-self:stretch;
    padding:22px;
    border-radius:20px;
  }

  .hd-page-visual{
    max-width:none;
    justify-self:stretch;
  }

  .service-top-image,
  .hero-support-image,
  .service-top-image img,
  .hero-support-image img{
    min-height:auto;
  }

  .services-page .hero.image .services-hero-form h2,
  body.page-slug-services .hero.image .services-hero-form h2{
    font-size:22px;
  }

  .hd-service-overview .card p,
  .cards-grid .card p,
  .price p,
  .price li{
    font-size:15px;
  }

  .section-slab .architecture{
    grid-template-columns:1fr;
  }

  .section-slab .arch-step{
    min-height:auto;
  }

  .hd-package-section{
    overflow-x:hidden;
  }

  .hd-package-section .container{
    width:min(100% - 32px, 1220px);
    max-width:100%;
  }

  .hd-package-section .pricing,
  .hd-package-section .price{
    width:100%;
    max-width:100%;
    min-width:0;
  }

  .hd-package-section .price{
    overflow:hidden;
    padding:20px;
    overflow-wrap:anywhere;
  }

  .hd-package-section .price:hover{
    transform:none;
  }

  .hd-package-section .price .btn{
    width:100%;
    max-width:100%;
    justify-content:center;
    text-align:center;
    white-space:normal;
  }

  .best-for,
  .recommended{
    width:100%;
    max-width:100%;
    min-width:0;
    justify-content:center;
    text-align:center;
    white-space:normal;
  }

  .best-for{
    font-size:11.5px;
    line-height:1.35;
  }

  .hd-list-business-cta{
    min-width:0;
  }

  .niche-grid.has-icons{
    grid-template-columns:1fr;
  }

  .niche-grid.has-icons .niche-card{
    min-height:0;
  }

  .hd-process-visual img,
  .hd-section-image-card img,
  .hd-final-cta-grid figure img{
    min-height:auto;
  }

  .hd-final-cta-grid .actions{
    justify-content:stretch;
  }

  .hd-cta-panel{
    grid-template-columns:1fr;
    padding:24px;
    border-radius:20px;
  }

  .hd-cta-panel .actions{
    justify-content:stretch;
  }

  .hd-cta-panel .btn{
    width:100%;
    justify-content:center;
    text-align:center;
    white-space:normal;
  }

  .hd-audit-cta-card .actions{
    display:grid;
  }
}/* ============================================================
   v3.15 — Layout & Spacing Fixes
   ============================================================ *//* 1. Hide "Built for every kind of healthcare practice" SVG icons section */.hd-built-for-section,
.hd-practice-types-section,
.hd-image-strip-section{
  display:none !important;
}/* 2. Hide "Need marketing help or directory visibility" teal gradient banner */.hd-list-business-banner{
  display:none !important;
}/* 3. Fix image empty spaces — remove aspect-ratio forcing whitespace */.hd-section-image-card{
  aspect-ratio:auto;
  margin-bottom:14px;
}.hd-section-image-card.is-large{
  aspect-ratio:auto;
}.hd-final-cta-grid figure{
  aspect-ratio:auto;
}.hd-page-visual{
  aspect-ratio:auto;
}/* 4. Fix buttons overlapping on images in CTA sections */.hd-audit-cta-card.has-image > img{
  aspect-ratio:16 / 9;
  object-fit:cover;
  object-position:center top;
}.hd-final-cta-grid figure img{
  object-position:center top;
}/* 5. Fix pricing page card overlap — give .pricing proper layout */.pricing{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:20px;
}.pricing .price{
  display:flex;
  flex-direction:column;
  min-height:100%;
}.pricing .price .btn{
  margin-top:auto;
  align-self:flex-start;
}/* 6. Tighter spacing between all adjacent sections */.section + .section{
  padding-top:40px;
}.section-slab + .section{
  padding-top:48px;
}/* 7. Fix hero-image-wrap empty space */.hero-image-wrap{
  aspect-ratio:auto;
  max-height:none;
}.hero-image-wrap img{
  max-height:300px;
}/* 8. Fix niche-grid (Who We Help) icon cards — remove excessive min-height */.niche-grid.has-icons .niche-card{
  min-height:auto;
}/* 9. Fix page-visual note overlapping on hero images */.hd-page-visual{
  min-height:0;
}.hd-page-visual img{
  min-height:220px;
}/* 10. Fix process visual to not stretch with empty space */.hd-process-visual{
  display:flex;
  flex-direction:column;
}.hd-process-visual img{
  flex:1;
  min-height:0;
}/* 11. Responsive pricing fix */@media(max-width:980px){
  .pricing{
    grid-template-columns:1fr;
  }
}/* 12. Reduce resources/themes page gap between hero and first section */.hero + .section{
  padding-top:40px;
}/* ==========================================================================
   Phase 4 — accessibility + hardened template components
   (Appended block; Phase 5 will fold these into the organised structure.)
   ========================================================================== *//* Screen-reader-only utility */.screen-reader-text {
    border: 0;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    width: 1px;
    margin: -1px;
    padding: 0;
    overflow: hidden;
    position: absolute !important;
    word-wrap: normal !important;
}/* Skip link becomes visible on focus */.skip-link.screen-reader-text:focus {
    clip: auto;
    clip-path: none;
    height: auto;
    width: auto;
    margin: 0;
    padding: 12px 18px;
    left: 12px;
    top: 12px;
    z-index: 100000;
    background: #0b1b2b;
    color: #fff;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
}/* Visible, consistent focus state for keyboard users */a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
summary:focus-visible,
[tabindex]:focus-visible {
    outline: 3px solid #1a73e8;
    outline-offset: 2px;
    border-radius: 4px;
}/* Don't show a focus ring on the programmatically-focused main wrapper */main[tabindex="-1"]:focus {
    outline: none;
}/* Breadcrumbs */.breadcrumbs {
    font-size: 0.875rem;
    padding: 14px 0 0;
}.breadcrumbs-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}.breadcrumbs-item + .breadcrumbs-item::before {
    content: "/";
    margin-right: 6px;
    opacity: 0.5;
}.breadcrumbs-item[aria-current="page"] span {
    opacity: 0.7;
}/* Post meta line */.post-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    font-size: 0.9rem;
    opacity: 0.85;
    margin: 10px 0 20px;
}.post-meta-cat { text-decoration: underline; }/* Single post layout helpers */.single-featured { margin: 0 0 24px; }.single-faq { margin-top: 32px; }.single-faq .faq-item { padding: 12px 0; border-top: 1px solid rgba(0,0,0,0.08); }.single-faq summary { cursor: pointer; font-weight: 600; }.cta-aside { position: sticky; top: 90px; }/* Archive / search headers + pagination */.archive-header,
.search-header { margin-bottom: 28px; }.search-count { opacity: 0.8; }.pagination,
.nav-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 32px;
}.pagination .page-numbers {
    display: inline-flex;
    min-width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
    padding: 0 12px;
    border: 1px solid rgba(0,0,0,0.15);
    border-radius: 8px;
    text-decoration: none;
}.pagination .page-numbers.current {
    background: #0b1b2b;
    color: #fff;
    border-color: #0b1b2b;
}/* No-results / 404 helpful links */.no-results .helpful-links ul,
.error-404-links ul {
    list-style: none;
    margin: 8px 0 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 10px 18px;
}.error-404-links {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 24px;
    margin: 24px 0;
}/* ==========================================================================
   Phase 4.1 — header menu fix (ul/li nav output) + nav scoping
   ========================================================================== *//* The primary menu is now a <ul>; make it a clean horizontal bar on desktop.
   NOTE: the desktop flex is scoped to min-width so it never overrides the
   max-width:1100px rule that hides .primary-nav on mobile (media queries add
   no specificity, so an unscoped rule later in the file would win). */@media (min-width: 1101px) {
    .site-header .primary-nav { display: flex; align-items: center; }
}.primary-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 2px;
}.primary-menu li { margin: 0; padding: 0; }.primary-menu li::marker { content: ""; }/* belt-and-braces: no bullets *//* Mobile slide-out panel: stack the same menu vertically, no bullets. */.mobile-panel .primary-nav { display: block; }.mobile-panel .primary-menu { display: grid; gap: 4px; }/* The global nav{display:flex} / mobile nav{display:none} rules were written
   for the header only. Keep the new structural navs (breadcrumbs, helpful
   links) displaying normally on every breakpoint. */.breadcrumbs,
.no-results .helpful-links { display: block; }.breadcrumbs .breadcrumbs-list,
.no-results .helpful-links ul { display: flex; }/* ==========================================================================
   Phase 4.1 — default homepage helpers (built-in front page)
   ========================================================================== */.front-page--default .cta-band {
    text-align: center;
    background: var(--primary-light, #eef7ff);
    border-radius: var(--radius, 16px);
    margin: 24px 4%;
}.front-page--default .grid.cards.three {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 20px;
}.front-page--default .card h3 { margin-top: 0; }



































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































































   













/* ---------------------------------------------------------------
   App-Like Features: SPA Page Transitions
   --------------------------------------------------------------- */

/* Loader overlay */
.hd-page-loader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background: var(--primary);
    z-index: 9999;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.3s ease;
    pointer-events: none;
}

.hd-page-loader.is-active {
    transform: scaleX(0.4); /* fake progress */
    animation: hd-loading 1.5s infinite linear;
}

@keyframes hd-loading {
    0% { transform: scaleX(0); transform-origin: left; }
    50% { transform: scaleX(0.7); transform-origin: left; }
    50.1% { transform: scaleX(0.7); transform-origin: right; }
    100% { transform: scaleX(0); transform-origin: right; }
}

/* Page fade transition */
#content, main {
    transition: opacity 0.3s var(--ease), transform 0.3s var(--ease);
}

body.is-navigating #content,
body.is-navigating main {
    opacity: 0.4;
    transform: translateY(10px);
}
