/* ============================================================
   Components — header, nav, footer, marquee, hero
   Flat, grounded, editorial. No glow, no gradient.
   ============================================================ */

/* ---- Top utility bar ---- */
.topbar{background:var(--ink);color:var(--paper);font-size:var(--fs-xs)}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:36px;padding-block:.3rem}
.topbar a{display:inline-flex;align-items:center;gap:.4rem;color:var(--paper);font-weight:500}
.topbar .tb-left{display:flex;gap:1.4rem;align-items:center}
.topbar .tb-rate{display:inline-flex;align-items:center;gap:.45rem;color:#cdd3dc}
.topbar .stars{font-size:.85em}
@media(max-width:680px){.topbar .tb-hide{display:none}}

/* ---- Header / nav ---- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.88);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s}
.site-header.scrolled{border-bottom-color:var(--line);box-shadow:var(--sh-1)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1.25rem;min-height:70px}
.brand{display:flex;align-items:center;gap:.6rem;flex-shrink:0;z-index:2}
.brand img{height:27px;width:auto;max-width:none}
@media(max-width:600px){.brand img{height:22px}}
.nav-links{display:flex;align-items:center;gap:.15rem}
.nav-links a{font-size:var(--fs-sm);font-weight:500;color:var(--ink-2);padding:.5rem .58rem;border-radius:var(--r-sm);transition:color .2s,background .2s;white-space:nowrap}
.nav-links a:hover{color:var(--ink);background:var(--paper-2)}
.nav-cta{display:flex;align-items:center;gap:.7rem}
.nav-phone{font-weight:600;font-size:var(--fs-sm);color:var(--ink);display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap}
.nav-phone:hover{color:var(--accent)}

/* dropdown */
.has-drop{position:relative}
.drop-toggle{display:inline-flex;align-items:center;gap:.3rem}
.drop-toggle svg{width:.7em;height:.7em;transition:transform .25s}
.has-drop:hover .drop-toggle svg{transform:rotate(180deg)}
.drop{position:absolute;top:calc(100% + .3rem);left:50%;transform:translateX(-50%) translateY(8px);min-width:520px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-3);padding:.6rem;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;z-index:50}
.has-drop:hover .drop,.has-drop:focus-within .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop-grid{display:grid;grid-template-columns:1fr 1fr;gap:.15rem}
.drop a{display:flex;gap:.7rem;align-items:flex-start;padding:.65rem .75rem;border-radius:var(--r);background:none}
.drop a:hover{background:var(--paper-2)}
.drop .di-ic{width:32px;height:32px;border-radius:7px;display:grid;place-items:center;background:var(--accent-050);flex-shrink:0;color:var(--accent)}
.drop a:hover .di-ic{background:var(--accent);color:#fff}
.drop .di-ic svg{width:17px;height:17px}
.drop .di-t{display:block;font-weight:600;color:var(--ink);font-size:var(--fs-sm);line-height:1.2}
.drop .di-d{display:block;font-size:var(--fs-xs);color:var(--ink-3);margin-top:2px;line-height:1.35}

/* mobile nav */
.mobile-panel{display:none}
.nav-toggle{display:none;width:44px;height:44px;border-radius:8px;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav-toggle span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s,opacity .3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:1120px){
  .nav-links,.nav-phone{display:none}
  .nav-toggle{display:flex}
  .mobile-panel{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:var(--card);z-index:120;transform:translateX(100%);transition:transform .35s var(--ease);padding:5.5rem 1.5rem 2rem;overflow-y:auto;box-shadow:var(--sh-3);display:flex;flex-direction:column;gap:.2rem;border-left:1px solid var(--line)}
  .mobile-panel.open{transform:none}
  .mobile-panel a{padding:.8rem .3rem;font-size:var(--fs-md);font-weight:600;border-bottom:1px solid var(--line-2);color:var(--ink)}
  .mobile-panel .btn{margin-top:1rem}
  .scrim{position:fixed;inset:0;background:rgba(9,20,38,.45);z-index:110;opacity:0;visibility:hidden;transition:opacity .3s}
  .scrim.open{opacity:1;visibility:visible}
}

/* ---- Hero: editorial split, no glow ---- */
.hero{position:relative;background:var(--paper);border-bottom:1px solid var(--line)}
.hero-inner{padding-block:clamp(2.6rem,6vw,5rem);display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(2rem,4vw,3.4rem);align-items:center}
@media(max-width:940px){.hero-inner{grid-template-columns:1fr;gap:2.2rem}}
.hero h1{margin-bottom:1.15rem}
.hero-sub{font-size:var(--fs-md);color:var(--ink-2);max-width:46ch;margin-bottom:1.6rem;line-height:1.5}
.hero-cta{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center}
.hero-proof{display:flex;align-items:center;gap:.9rem;margin-top:1.7rem;flex-wrap:wrap}
.hero-proof .avatars{display:flex}
.hero-proof .avatars img{width:38px;height:38px;border-radius:50%;border:2px solid var(--paper);margin-left:-11px;object-fit:cover}
.hero-proof .avatars img:first-child{margin-left:0}
.hero-proof .hp-txt{font-size:var(--fs-sm);color:var(--ink-2);line-height:1.35}
.hero-proof .hp-txt b{color:var(--ink)}

/* hero functional tool panel (the real Health Check entry) */
.hero-tool{background:var(--navy);color:var(--on-navy);border-radius:var(--r-xl);padding:clamp(1.6rem,3vw,2.2rem)}
.hero-tool .ht-ey{font-family:var(--label);font-weight:600;font-size:var(--fs-xs);letter-spacing:.12em;text-transform:uppercase;color:#9fc0ff;display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}
.hero-tool .ht-ey svg{width:15px;height:15px;color:#fff}
.hero-tool h2{color:#fff;font-size:var(--fs-lg);margin-bottom:.55rem;letter-spacing:-.02em}
.hero-tool .ht-lede{color:var(--on-navy-mute);font-size:var(--fs-sm);margin-bottom:1.25rem;line-height:1.5}
.ht-form{display:flex;gap:.5rem;background:rgba(255,255,255,.07);border:1px solid var(--line-navy);border-radius:var(--r);padding:.4rem .4rem .4rem 1rem;align-items:center}
.ht-form input{flex:1;background:none;border:none;color:#fff;font-size:var(--fs-sm);min-width:0}
.ht-form input::placeholder{color:var(--on-navy-mute)}
.ht-form .btn{flex-shrink:0}
.hero-tool .ht-foot{margin-top:.85rem;font-size:var(--fs-xs);color:var(--on-navy-mute);display:flex;align-items:center;gap:.45rem}
.hero-tool .ht-foot svg{width:13px;height:13px;color:var(--good)}

/* ---- Logo marquee (trust strip): grayscale, hover = pause + full color ---- */
.marquee-wrap{padding-block:clamp(1.5rem,3vw,2.4rem);background:#fff;border-block:1px solid var(--line-2)}
.marquee-label{text-align:center;font-family:var(--label);font-size:var(--fs-xs);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-bottom:1.4rem}
.marquee{position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent)}
.marquee-track{display:flex;align-items:center;gap:clamp(2.8rem,6vw,5.5rem);width:max-content;animation:marquee 34s linear infinite;will-change:transform}
.marquee-track:hover{animation-play-state:paused}
.marquee-logo{display:inline-flex;align-items:center;flex-shrink:0}
.marquee-logo img{height:clamp(28px,3.4vw,38px);width:auto;filter:grayscale(1) opacity(.62);transition:filter .35s var(--ease),transform .35s var(--ease)}
.marquee-logo:hover img{filter:grayscale(0) opacity(1);transform:scale(1.07)}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none;flex-wrap:wrap;justify-content:center;width:auto}.marquee-logo img{filter:grayscale(0) opacity(1)}}

/* ---- Stat figure ---- */
.stat{display:flex;flex-direction:column;gap:.15rem}
.stat .num{font-family:var(--display);font-weight:800;font-size:var(--fs-xl);letter-spacing:-.03em;line-height:1;color:var(--ink)}
.stat .num em{font-style:normal;color:var(--accent)}
.stat .lbl{font-size:var(--fs-sm);color:var(--ink-3)}
.section--navy .stat .num{color:#fff}
.section--navy .stat .lbl{color:var(--on-navy-mute)}

/* ---- Footer ---- */
.site-footer{background:var(--navy-deep);color:var(--on-navy-mute);padding-block:clamp(3rem,6vw,5rem) 2rem;border-top:3px solid var(--accent)}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:2.4rem}
@media(max-width:880px){.footer-top{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:520px){.footer-top{grid-template-columns:1fr}}
.footer-brand img{height:26px;margin-bottom:1.1rem;width:auto;max-width:100%}
.footer-brand p{font-size:var(--fs-sm);color:var(--on-navy-mute);max-width:34ch}
.footer-col h4{font-family:var(--body);font-size:var(--fs-xs);text-transform:uppercase;letter-spacing:.11em;color:#fff;font-weight:700;margin-bottom:1rem}
.footer-col ul{display:flex;flex-direction:column;gap:.55rem}
.footer-col a{font-size:var(--fs-sm);color:var(--on-navy-mute);transition:color .2s}
.footer-col a:hover{color:#fff}
.site-footer a.btn-primary{color:#fff}
.site-footer a.btn-primary:hover{color:#fff}
.footer-brand a{display:inline-block}
.footer-contact{display:flex;flex-direction:column;gap:.6rem;font-size:var(--fs-sm)}
.footer-contact .fc-row{display:flex;gap:.55rem;align-items:flex-start;color:var(--on-navy-mute)}
.footer-contact .fc-row:hover{color:#fff}
.footer-contact svg{width:16px;height:16px;flex-shrink:0;margin-top:2px;color:var(--accent)}
.footer-bot{margin-top:2.6rem;padding-top:1.5rem;border-top:1px solid var(--line-navy);display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;font-size:var(--fs-xs);color:var(--on-navy-mute)}
.footer-bot a{color:var(--on-navy-mute)}.footer-bot a:hover{color:#fff}
.footer-rule{display:none}

/* ---- CTA band ---- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--r-xl);background:var(--navy);color:#fff;padding:clamp(2.4rem,5vw,4rem);text-align:center}
.cta-band-inner{position:relative;z-index:1;max-width:58ch;margin-inline:auto}
.cta-band h2{color:#fff;margin-bottom:.9rem}
.cta-band p{color:var(--on-navy-mute);margin-inline:auto;margin-bottom:1.7rem}
.cta-actions{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap}
