/* ================================================================
   Lakeside Medical Group — Medical Demo
   Nova AI Solutions Showcase Demo

   Identity: calm, clean, trustworthy. Soft mint + healing teal,
   friendly Poppins headings on a humanist Mulish body, generous
   rounding and gentle shadows. Reads like a welcoming family
   practice — not a tech/marketing site.
   ================================================================ */

:root {
  --bg:          #f5faf9;
  --bg-white:    #ffffff;
  --bg-soft:     #ecf6f4;   /* mint section */
  --mint:        #eafaf6;
  --deep:        #0d3b39;   /* calming deep-teal "dark" sections */
  --deep-2:      #0a302e;
  --deep-cta:    #0b2b33;

  --teal:        #0d9488;
  --teal-light:  #14b8a6;
  --teal-deep:   #0b6e66;
  --teal-dim:    rgba(13,148,136,0.08);
  --teal-border: rgba(13,148,136,0.22);
  --blue:        #3b82f6;
  --purple:      #8b5cf6;

  --text:        #16302c;
  --text-muted:  #566b71;
  --text-dim:    #93a4a6;
  --border:      #e3eeeb;
  --border-dark: rgba(255,255,255,0.12);
  --success:     #1f9d57;

  --radius:      14px;
  --radius-lg:   22px;
  --shadow:      0 6px 24px rgba(13,59,57,0.07);
  --shadow-md:   0 18px 50px rgba(13,59,57,0.13);
  --transition:  0.3s cubic-bezier(0.23,1,0.32,1);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:17px; }
body { background:var(--bg); color:var(--text); font-family:'Mulish',sans-serif; line-height:1.65; overflow-x:hidden; }
h1,h2,h3,h4 { font-family:'Poppins',sans-serif; line-height:1.18; letter-spacing:-0.01em; }
a { color:inherit; text-decoration:none; }
::-webkit-scrollbar { width:8px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--teal); border-radius:8px; }
:focus-visible { outline:3px solid var(--teal); outline-offset:2px; }

/* NOVA DEMO BANNER (intentionally Nova-branded) */
.nova-banner {
  position:fixed; top:0; left:0; right:0; z-index:9999;
  background:rgba(7,11,28,0.96); backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(0,200,255,0.3); padding:0 5%; height:44px;
  display:flex; align-items:center;
}
.nova-banner-inner { display:flex; align-items:center; gap:0.75rem; font-size:0.8rem; width:100%; }
.nova-banner-logo { font-family:'Mulish',sans-serif; font-weight:700; color:#00c8ff; }
.nova-banner-sep { color:rgba(255,255,255,0.3); }
.nova-banner-text { color:rgba(255,255,255,0.65); flex:1; }
.nova-banner-cta {
  padding:0.32rem 0.95rem; background:linear-gradient(135deg,#00c8ff,#a259ff);
  border-radius:50px; color:#fff; font-weight:700; font-size:0.78rem;
  white-space:nowrap; transition:opacity 0.2s;
}
.nova-banner-cta:hover { opacity:0.88; }

/* CLIENT NAV */
.m-nav {
  position:fixed; top:44px; left:0; right:0; z-index:100;
  background:rgba(255,255,255,0.92); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border); box-shadow:0 2px 16px rgba(13,59,57,0.05);
}
.m-nav-inner { max-width:1200px; margin:0 auto; padding:0 5%; height:74px; display:flex; align-items:center; gap:2rem; }
.m-nav-logo { display:flex; align-items:center; gap:0.75rem; flex-shrink:0; }
.m-logo-icon { width:42px; height:42px; background:var(--mint); border:1px solid var(--teal-border); border-radius:50%; display:flex; align-items:center; justify-content:center; }
.m-logo-icon svg { width:20px; height:20px; }
.m-logo-name { font-family:'Poppins',sans-serif; font-weight:700; font-size:1.02rem; display:block; color:var(--text); }
.m-logo-sub { font-size:0.68rem; color:var(--text-muted); display:block; }
.m-nav-links { display:flex; gap:2rem; list-style:none; flex:1; justify-content:center; }
.m-nav-links a { font-size:0.92rem; color:var(--text-muted); font-weight:600; transition:color 0.2s; }
.m-nav-links a:hover { color:var(--teal); }
.m-nav-cta {
  padding:0.7rem 1.5rem; background:var(--teal); color:#fff;
  border-radius:50px; font-family:'Poppins',sans-serif; font-size:0.88rem; font-weight:600;
  flex-shrink:0; white-space:nowrap; transition:background var(--transition), transform 0.15s;
  box-shadow:0 6px 18px rgba(13,148,136,0.25);
}
.m-nav-cta:hover { background:var(--teal-deep); transform:translateY(-1px); }
.m-hamburger { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; }
.m-hamburger span { width:24px; height:2px; background:var(--text); border-radius:2px; display:block; }

/* BUTTONS */
.m-btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  padding:0.9rem 2rem; border-radius:50px;
  background:var(--teal); color:#fff;
  font-family:'Poppins',sans-serif; font-size:0.98rem; font-weight:600;
  cursor:pointer; border:none; transition:background var(--transition), transform 0.15s, box-shadow 0.2s;
  box-shadow:0 8px 24px rgba(13,148,136,0.28);
}
.m-btn-primary:hover { background:var(--teal-deep); transform:translateY(-2px); box-shadow:0 12px 32px rgba(13,148,136,0.36); }
.m-btn-ghost {
  display:inline-flex; align-items:center; gap:8px;
  padding:0.9rem 2rem; border-radius:50px;
  background:transparent; color:var(--text);
  font-family:'Poppins',sans-serif; font-size:0.98rem; font-weight:600;
  cursor:pointer; border:1.5px solid var(--border); transition:border-color var(--transition), background var(--transition), color var(--transition);
}
.m-btn-ghost:hover { border-color:var(--teal-border); background:var(--teal-dim); color:var(--teal); }
.m-btn-secondary {
  display:inline-flex; align-items:center; gap:6px;
  padding:0.65rem 1.5rem; border-radius:50px;
  background:var(--teal-dim); color:var(--teal-deep); border:1px solid var(--teal-border);
  font-family:'Poppins',sans-serif; font-size:0.88rem; font-weight:600;
  cursor:pointer; transition:background var(--transition);
}
.m-btn-secondary:hover { background:rgba(13,148,136,0.16); }

/* LAYOUT */
.m-container { max-width:1200px; margin:0 auto; padding:0 5%; }
.m-section { padding:6.5rem 0; background:var(--bg-white); }
.m-section-alt { padding:6.5rem 0; background:var(--bg); }
.m-section-dark { padding:6.5rem 0; background:linear-gradient(160deg,#0d3b39,#0a302e); }
.m-section-light { padding:6.5rem 0; background:var(--bg-soft); }

.m-section-header { text-align:center; margin-bottom:3.5rem; }
.m-header-light { text-align:center; margin-bottom:3.5rem; }
.m-eyebrow { font-family:'Poppins',sans-serif; font-size:0.78rem; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; color:var(--teal); margin-bottom:0.6rem; display:block; }
.m-eyebrow-light { color:#7fe9d8; }
.m-section-title { font-size:clamp(2rem,3.6vw,2.8rem); font-weight:700; margin-bottom:1rem; color:var(--text); }
.m-title-light { color:#f4fbfa; }
.m-section-sub { color:var(--text-muted); font-size:1.05rem; max-width:560px; margin:0 auto; line-height:1.7; }
.m-sub-light { color:rgba(255,255,255,0.72); }
.m-teal { color:var(--teal); }

/* HERO */
.m-hero {
  min-height:100vh; display:flex; align-items:center; padding-top:118px;
  background:
    radial-gradient(ellipse 70% 60% at 80% 20%, var(--mint), transparent 70%),
    radial-gradient(ellipse 60% 50% at 0% 90%, #eef7f6, transparent 70%),
    var(--bg-white);
}
.m-hero-inner { max-width:1200px; margin:0 auto; padding:4rem 5% 4rem; display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.m-hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:0.45rem 1.1rem; border:1px solid var(--teal-border);
  border-radius:50px; background:var(--mint);
  font-size:0.82rem; font-weight:600; color:var(--teal-deep);
  letter-spacing:0.02em; margin-bottom:1.5rem;
}
.m-badge-dot { width:7px; height:7px; border-radius:50%; background:var(--teal); box-shadow:0 0 8px var(--teal); animation:mpulse 2s infinite; }
@keyframes mpulse { 0%,100%{opacity:1;} 50%{opacity:0.3;} }
.m-hero-title { font-size:clamp(2.5rem,5vw,4rem); font-weight:700; line-height:1.1; margin-bottom:1.5rem; color:var(--text); }
.m-hero-sub { font-size:1.12rem; color:var(--text-muted); line-height:1.75; max-width:500px; margin-bottom:2rem; }
.m-hero-actions { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:2rem; }
.m-hero-trust { display:flex; flex-direction:column; gap:0.7rem; }
.m-trust-item { display:flex; align-items:center; gap:0.5rem; font-size:0.92rem; color:var(--text-muted); }

/* Hero card stack */
.m-hero-visual { display:flex; align-items:flex-start; justify-content:center; }
.m-hero-card-stack { display:flex; flex-direction:column; gap:1rem; width:100%; max-width:370px; }
.m-hero-card { border-radius:var(--radius-lg); padding:1.6rem; border:1px solid var(--border); background:var(--bg-white); box-shadow:var(--shadow); transition:transform var(--transition), box-shadow var(--transition); }
.m-hero-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.m-card-primary { background:linear-gradient(150deg,#ffffff,#f3fbf9); }
.m-card-secondary { background:var(--mint); border-color:var(--teal-border); }
.m-card-tertiary { background:var(--bg-white); }
.m-card-label { font-size:0.7rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-muted); margin-bottom:0.35rem; }
.m-card-value { font-family:'Poppins',sans-serif; font-size:1.2rem; font-weight:700; margin-bottom:0.2rem; color:var(--text); }
.m-card-sub { font-size:0.82rem; color:var(--text-muted); margin-bottom:0.75rem; }
.m-card-book-btn { padding:0.55rem 1.3rem; background:var(--teal); color:#fff; border:none; border-radius:50px; font-family:'Poppins',sans-serif; font-size:0.84rem; font-weight:600; cursor:pointer; transition:background 0.2s; }
.m-card-book-btn:hover { background:var(--teal-deep); }
.m-card-check { display:flex; align-items:center; gap:6px; font-size:0.82rem; color:var(--teal-deep); font-weight:600; }

/* STATS BAR */
.m-stats-bar { background:linear-gradient(120deg,#0d3b39,#0b332f); padding:2.25rem 0; }
.m-stats-inner { max-width:1200px; margin:0 auto; padding:0 5%; display:flex; align-items:center; justify-content:center; gap:0; }
.m-stat { text-align:center; padding:0 3rem; }
.m-stat-num { font-family:'Poppins',sans-serif; font-size:2.3rem; font-weight:700; color:#5eead4; margin-bottom:0.2rem; }
.m-stat-label { font-size:0.82rem; color:rgba(255,255,255,0.62); }
.m-stat-div { width:1px; height:46px; background:rgba(255,255,255,0.14); }

/* SERVICES */
.m-services-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.m-service-card {
  background:var(--bg-white); border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:2rem; box-shadow:var(--shadow);
  transition:border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}
.m-service-card:hover { border-color:var(--teal-border); transform:translateY(-5px); box-shadow:var(--shadow-md); }
.m-service-icon { width:56px; height:56px; border-radius:50%; background:var(--mint); border:1px solid var(--teal-border); display:flex; align-items:center; justify-content:center; margin-bottom:1.25rem; }
.m-service-icon svg { width:24px; height:24px; stroke:var(--teal); }
.m-icon-urgent { background:rgba(239,68,68,0.08); border-color:rgba(239,68,68,0.2); }
.m-icon-urgent svg { stroke:#e0564b; }
.m-icon-telehealth { background:rgba(59,130,246,0.08); border-color:rgba(59,130,246,0.2); }
.m-icon-telehealth svg { stroke:var(--blue); }
.m-service-title { font-size:1.25rem; font-weight:600; margin-bottom:0.6rem; color:var(--text); }
.m-service-desc { font-size:0.92rem; color:var(--text-muted); line-height:1.7; margin-bottom:1.25rem; }
.m-service-link { font-size:0.88rem; font-weight:600; color:var(--teal); display:inline-flex; align-items:center; gap:4px; transition:gap 0.2s; }
.m-service-link:hover { gap:8px; }

/* AUTOMATION WORKFLOWS (on calm deep-teal) */
.m-workflows { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.m-workflow-card { background:rgba(255,255,255,0.05); border:1px solid var(--border-dark); border-radius:var(--radius-lg); padding:2rem; transition:border-color var(--transition), background var(--transition); }
.m-workflow-card:hover { border-color:rgba(94,234,212,0.4); background:rgba(255,255,255,0.07); }
.m-workflow-header { display:flex; align-items:center; gap:1rem; margin-bottom:1.75rem; }
.m-workflow-icon { width:48px; height:48px; border-radius:50%; background:rgba(94,234,212,0.14); border:1px solid rgba(94,234,212,0.3); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.m-workflow-icon svg { width:22px; height:22px; stroke:#5eead4; }
.m-wf-icon-blue { background:rgba(96,165,250,0.14); border-color:rgba(96,165,250,0.3); }
.m-wf-icon-blue svg { stroke:#93c5fd; }
.m-wf-icon-purple { background:rgba(167,139,250,0.14); border-color:rgba(167,139,250,0.3); }
.m-wf-icon-purple svg { stroke:#c4b5fd; }
.m-workflow-label { font-size:0.66rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:rgba(255,255,255,0.45); margin-bottom:0.15rem; }
.m-workflow-title { font-family:'Poppins',sans-serif; font-size:1.05rem; font-weight:600; color:#f4fbfa; }

/* Flow diagram */
.m-flow { display:flex; flex-direction:column; gap:0; margin-bottom:1.5rem; }
.m-flow-node { padding:0.7rem 1rem; border-radius:10px; background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.12); font-size:0.85rem; color:#e8f5f3; font-weight:500; display:flex; align-items:center; gap:6px; }
.m-node-start { border-color:rgba(94,234,212,0.4); background:rgba(94,234,212,0.10); color:#a7f3e6; }
.m-node-end { border-color:rgba(74,222,128,0.4); background:rgba(74,222,128,0.10); color:#bbf7d0; }
.m-flow-arrow { display:flex; flex-direction:column; align-items:center; padding:3px 0; }
.m-flow-line { width:2px; height:20px; background:linear-gradient(180deg,rgba(94,234,212,0.4),rgba(94,234,212,0.1)); }
.m-flow-label-inline { font-size:0.66rem; color:rgba(255,255,255,0.4); letter-spacing:0.05em; padding:1px 0; }
.m-workflow-result { display:flex; align-items:flex-start; gap:0.5rem; font-size:0.82rem; color:rgba(255,255,255,0.6); line-height:1.5; }
.m-result-dot { width:7px; height:7px; border-radius:50%; background:#5eead4; flex-shrink:0; margin-top:0.35rem; }
.m-workflow-result strong { color:#fff; }

/* SCHEDULER */
.m-scheduler { max-width:760px; margin:0 auto; background:var(--bg-white); border:1px solid var(--border); border-radius:var(--radius-lg); box-shadow:var(--shadow-md); overflow:hidden; }
.m-sched-steps { display:flex; align-items:center; padding:1.5rem 2rem; background:var(--bg-soft); border-bottom:1px solid var(--border); }
.m-sched-step { display:flex; align-items:center; gap:0.5rem; }
.m-sched-step-num { width:30px; height:30px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Poppins',sans-serif; font-size:0.78rem; font-weight:700; background:#fff; border:1px solid var(--border); color:var(--text-muted); flex-shrink:0; transition:all 0.3s; }
.m-sched-step.active .m-sched-step-num { background:var(--teal); color:#fff; border-color:var(--teal); }
.m-sched-step.done .m-sched-step-num { background:rgba(31,157,87,0.15); color:var(--success); border-color:rgba(31,157,87,0.35); }
.m-sched-step-label { font-size:0.8rem; font-weight:600; color:var(--text-muted); }
.m-sched-step.active .m-sched-step-label { color:var(--teal); }
.m-sched-step-connector { flex:1; height:2px; background:var(--border); }
.m-sched-panel { padding:2.5rem; display:none; }
.m-sched-panel.active { display:block; }
.m-sched-q { font-size:1.4rem; font-weight:600; margin-bottom:1.5rem; color:var(--text); }

/* Visit types */
.m-visit-types { display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; }
.m-visit-type { display:flex; align-items:center; gap:1rem; padding:1.3rem 1.5rem; border:1.5px solid var(--border); border-radius:var(--radius); background:var(--bg-white); cursor:pointer; text-align:left; transition:all 0.2s; font-family:'Mulish',sans-serif; }
.m-visit-type:hover { border-color:var(--teal-border); background:var(--mint); }
.m-visit-type.selected { border-color:var(--teal); background:var(--mint); box-shadow:0 0 0 3px rgba(13,148,136,0.10); }
.m-vt-icon { width:40px; height:40px; display:flex; align-items:center; justify-content:center; border-radius:50%; background:var(--mint); border:1px solid var(--teal-border); flex-shrink:0; }
.m-vt-icon svg { width:18px; height:18px; stroke:var(--teal); }
.m-vt-urgent { background:rgba(239,68,68,0.08); border-color:rgba(239,68,68,0.2); }
.m-vt-urgent svg { stroke:#e0564b; }
.m-vt-telehealth { background:rgba(59,130,246,0.08); border-color:rgba(59,130,246,0.2); }
.m-vt-telehealth svg { stroke:var(--blue); }
.m-vt-name { font-family:'Poppins',sans-serif; font-size:0.96rem; font-weight:600; color:var(--text); }
.m-vt-desc { font-size:0.8rem; color:var(--text-muted); margin-top:0.15rem; }

/* Provider + slots */
.m-provider-select { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; margin-bottom:1.5rem; }
.m-providers { display:flex; flex-direction:column; gap:0.75rem; }
.m-provider-btn { display:flex; align-items:center; gap:0.75rem; padding:0.9rem 1rem; border:1.5px solid var(--border); border-radius:var(--radius); background:var(--bg-white); cursor:pointer; transition:all 0.2s; text-align:left; font-family:'Mulish',sans-serif; }
.m-provider-btn:hover { border-color:var(--teal-border); }
.m-provider-btn.active { border-color:var(--teal); background:var(--mint); }
.m-provider-avatar { width:38px; height:38px; border-radius:50%; background:var(--teal); display:flex; align-items:center; justify-content:center; font-family:'Poppins',sans-serif; font-size:0.72rem; font-weight:700; color:#fff; flex-shrink:0; }
.m-provider-name { font-size:0.9rem; font-weight:700; color:var(--text); }
.m-provider-spec { font-size:0.74rem; color:var(--text-muted); }
.m-slots-label { font-size:0.74rem; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; color:var(--text-muted); margin-bottom:0.75rem; }
.m-slots-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:0.5rem; }
.m-slot { padding:0.65rem; border:1.5px solid var(--border); border-radius:10px; background:var(--bg-white); cursor:pointer; font-size:0.85rem; font-weight:600; color:var(--text); text-align:center; font-family:'Mulish',sans-serif; transition:all 0.2s; }
.m-slot:hover { border-color:var(--teal-border); background:var(--mint); color:var(--teal-deep); }
.m-slot.selected { border-color:var(--teal); background:var(--teal); color:#fff; }
.m-slot-taken { background:var(--bg); color:var(--text-dim); cursor:not-allowed; opacity:0.5; }
.m-sched-next { width:100%; justify-content:center; }
.m-sched-next:disabled { opacity:0.4; cursor:not-allowed; }

/* Sched form */
.m-sched-summary { padding:0.85rem 1.1rem; background:var(--mint); border:1px solid var(--teal-border); border-radius:10px; font-size:0.85rem; color:var(--teal-deep); font-weight:600; margin-bottom:1.25rem; }
.m-sched-form { display:flex; flex-direction:column; gap:1rem; }
.m-sched-form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.m-sched-form-group { display:flex; flex-direction:column; gap:0.35rem; }
.m-sched-label { font-size:0.76rem; font-weight:700; text-transform:uppercase; letter-spacing:0.06em; color:var(--text-muted); }
.m-sched-input { background:var(--bg); border:1.5px solid var(--border); border-radius:10px; padding:0.75rem 1rem; color:var(--text); font-family:'Mulish',sans-serif; font-size:0.95rem; outline:none; width:100%; transition:border-color 0.2s, box-shadow 0.2s, background 0.2s; }
.m-sched-input:focus { border-color:var(--teal); background:#fff; box-shadow:0 0 0 3px rgba(13,148,136,0.12); }
.m-sched-select { -webkit-appearance:none; cursor:pointer; }

/* Confirmed */
.m-confirmed { text-align:center; padding:0.5rem 0; }
.m-confirmed-icon { margin-bottom:1.25rem; }
.m-confirmed-title { font-family:'Poppins',sans-serif; font-size:1.7rem; font-weight:700; margin-bottom:1.5rem; color:var(--text); }
.m-confirmed-details { background:var(--bg); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; margin-bottom:1.25rem; }
.m-confirmed-row { display:flex; justify-content:space-between; padding:0.8rem 1.25rem; border-bottom:1px solid var(--border); font-size:0.9rem; }
.m-confirmed-row:last-child { border-bottom:none; }
.m-confirmed-row span:first-child { color:var(--text-muted); }
.m-confirmed-row span:last-child { font-weight:700; color:var(--text); }
.m-confirmed-auto { display:flex; flex-direction:column; gap:0.5rem; margin-bottom:1.5rem; text-align:left; max-width:380px; margin-left:auto; margin-right:auto; }
.m-auto-item { display:flex; align-items:center; gap:0.5rem; font-size:0.85rem; color:var(--text-muted); }
.m-auto-item svg { flex-shrink:0; }

/* INSURANCE */
.m-insurance-grid { display:flex; flex-wrap:wrap; gap:0.75rem; justify-content:center; margin-bottom:2rem; }
.m-insurance-badge { padding:0.7rem 1.4rem; border:1.5px solid var(--border); border-radius:50px; font-size:0.88rem; font-weight:600; color:var(--text); background:var(--bg-white); box-shadow:var(--shadow); transition:border-color var(--transition), transform var(--transition); }
.m-insurance-badge:hover { border-color:var(--teal-border); transform:translateY(-2px); }
.m-insurance-selfpay { border-color:var(--teal-border); color:var(--teal-deep); background:var(--mint); }
.m-insurance-note { display:flex; align-items:flex-start; gap:0.75rem; justify-content:center; font-size:0.92rem; color:var(--teal-deep); text-align:center; max-width:580px; margin:0 auto; line-height:1.65; }
.m-insurance-note svg { flex-shrink:0; margin-top:2px; }

/* PROVIDERS SECTION */
.m-providers-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.m-provider-card { background:var(--bg-white); border:1px solid var(--border); border-radius:var(--radius-lg); padding:2.25rem; text-align:center; box-shadow:var(--shadow); transition:box-shadow var(--transition), transform var(--transition); }
.m-provider-card:hover { box-shadow:var(--shadow-md); transform:translateY(-4px); }
.m-provider-photo { width:88px; height:88px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-family:'Poppins',sans-serif; font-size:1.2rem; font-weight:700; color:#fff; margin:0 auto 1.25rem; }
.m-provider-name-lg { font-size:1.15rem; font-weight:600; margin-bottom:0.3rem; color:var(--text); }
.m-provider-spec-lg { font-size:0.78rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--teal); font-weight:700; margin-bottom:1rem; }
.m-provider-bio { font-size:0.9rem; color:var(--text-muted); line-height:1.7; margin-bottom:1.5rem; }

/* CONTACT */
.m-contact-inner { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:start; }
.m-contact-cards { display:flex; flex-direction:column; gap:1.25rem; margin-top:1.5rem; }
.m-contact-card { display:flex; align-items:flex-start; gap:1rem; }
.m-cc-icon { width:46px; height:46px; border-radius:50%; background:var(--mint); border:1px solid var(--teal-border); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.m-cc-icon svg { width:20px; height:20px; stroke:var(--teal); }
.m-cc-label { font-size:0.72rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-muted); margin-bottom:0.2rem; }
.m-cc-value { font-size:0.96rem; font-weight:600; color:var(--text); line-height:1.5; }
.m-map-placeholder { border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--border); box-shadow:var(--shadow); }
.m-map-inner { height:280px; display:flex; align-items:center; justify-content:center; }

/* NOVA CTA (intentionally Nova-branded) */
.nova-cta-section { padding:6rem 0; background:var(--deep-cta); }
.nova-cta-inner { max-width:680px; margin:0 auto; text-align:center; padding:0 5%; }
.nova-cta-badge { display:inline-block; padding:0.32rem 0.95rem; margin-bottom:1.5rem; background:rgba(0,200,255,0.08); border:1px solid rgba(0,200,255,0.25); border-radius:50px; font-size:0.74rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:#00c8ff; }
.nova-cta-title { font-family:'Poppins',sans-serif; font-size:clamp(1.8rem,3.5vw,2.5rem); font-weight:700; letter-spacing:-0.01em; margin-bottom:1rem; color:#f1f5f9; }
.nova-cta-sub { color:rgba(255,255,255,0.72); font-size:1.02rem; line-height:1.7; margin-bottom:2.25rem; }
.nova-cta-actions { display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }
.nova-cta-btn-primary { padding:0.9rem 2rem; background:linear-gradient(135deg,#00c8ff,#a259ff); border-radius:50px; color:#fff; font-weight:700; transition:opacity 0.2s, transform 0.2s; box-shadow:0 0 30px rgba(0,200,255,0.3); }
.nova-cta-btn-primary:hover { opacity:0.9; transform:translateY(-1px); }
.nova-cta-btn-ghost { padding:0.9rem 2rem; background:transparent; border:1px solid rgba(255,255,255,0.18); border-radius:50px; color:#f1f5f9; font-weight:600; transition:border-color 0.2s; }
.nova-cta-btn-ghost:hover { border-color:rgba(0,200,255,0.3); }

/* FOOTER */
.m-footer { background:var(--deep-2); padding:2.75rem 0; }
.m-footer-inner { display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:1.5rem; margin-bottom:1rem; }
.m-footer-logo { display:flex; align-items:center; gap:0.6rem; font-family:'Poppins',sans-serif; font-weight:600; font-size:1rem; color:#f4fbfa; margin-bottom:0.5rem; }
.m-footer-logo-icon { width:30px; height:30px; background:var(--teal); border-radius:50%; display:flex; align-items:center; justify-content:center; }
.m-footer-copy { font-size:0.78rem; color:rgba(255,255,255,0.45); }
.m-footer-links { display:flex; gap:1.5rem; flex-wrap:wrap; }
.m-footer-links a { font-size:0.84rem; color:rgba(255,255,255,0.6); transition:color 0.2s; }
.m-footer-links a:hover { color:#5eead4; }
.m-footer-nova { font-size:0.78rem; color:rgba(255,255,255,0.4); border-top:1px solid rgba(255,255,255,0.08); padding-top:1rem; }
.m-footer-nova a { color:#5eead4; }

/* RESPONSIVE */
@media (max-width:960px) {
  .m-hero-inner { grid-template-columns:1fr; gap:3rem; }
  .m-services-grid { grid-template-columns:repeat(2,1fr); }
  .m-workflows { grid-template-columns:1fr; }
  .m-provider-select { grid-template-columns:1fr; }
  .m-providers-grid { grid-template-columns:1fr; max-width:420px; margin:0 auto; }
  .m-contact-inner { grid-template-columns:1fr; gap:3rem; }
}
/* Collapse the nav to a menu button before the links crowd the CTA */
@media (max-width:1024px) {
  .m-nav-links { display:none; }
  .m-hamburger { display:flex; }
  .m-nav-links.open { display:flex; flex-direction:column; position:fixed; top:118px; left:0; right:0; background:rgba(255,255,255,0.98); backdrop-filter:blur(20px); padding:2rem; gap:1.5rem; border-bottom:1px solid var(--border); box-shadow:var(--shadow); }
}
@media (max-width:640px) {
  .m-nav-links { display:none; }
  .m-hamburger { display:flex; }
  .m-nav-links.open { display:flex; flex-direction:column; position:fixed; top:118px; left:0; right:0; background:rgba(255,255,255,0.98); backdrop-filter:blur(20px); padding:2rem; gap:1.5rem; border-bottom:1px solid var(--border); box-shadow:var(--shadow); }
  .m-services-grid { grid-template-columns:1fr; }
  .m-visit-types { grid-template-columns:1fr; }
  .m-sched-form-row { grid-template-columns:1fr; }
  .m-stats-inner { flex-wrap:wrap; justify-content:center; }
  .m-stat { padding:1rem 1.5rem; }
  .m-stat-div { display:none; }
  .nova-banner-text { display:none; }
}
