/* Kenyon & Sons — self-hosted fonts (latin subset, variable woff2) */
@font-face{font-family:'Bricolage Grotesque';font-style:normal;font-weight:400 800;font-display:swap;src:url(/assets/fonts/bricolage-grotesque.woff2) format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}
@font-face{font-family:'Hanken Grotesk';font-style:normal;font-weight:400 700;font-display:swap;src:url(/assets/fonts/hanken-grotesk.woff2) format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;}

:root{
  /* Brand blues (kept from existing identity) */
  --blue-900:#062b54;
  --blue-800:#0a3a72;
  --blue-700:#0d52a0;
  --blue-600:#1268c7;
  --blue-500:#1f86e8;
  --blue-400:#5aa9f0;
  --blue-300:#9fcdf7;
  --blue-100:#dcebfb; /* unused safeguard */
  --sky-100:#e7f3ff;
  --sky-50:#f3f9ff;

  /* Warm heating accent (the "hot" half of HVAC) */
  --ember-600:#e7611f;
  --ember-500:#fb7a2b;
  --ember-400:#ff9d57;

  /* Neutrals / cream */
  --cream:#fbf7f0;
  --paper:#ffffff;
  --ink:#0a2440;
  --ink-soft:#3a5170;
  --ink-mute:#4a627d; /* darkened from #566f8a → 6.30:1 on #fff (WCAG 1.4.3 AA) */
  --line:rgba(10,40,72,.10);

  /* Glass */
  --glass-bg:rgba(255,255,255,.55);
  --glass-bg-strong:rgba(255,255,255,.72);
  --glass-brd:rgba(255,255,255,.7);
  --glass-shadow:0 24px 60px -22px rgba(10,40,72,.45);
  --glass-sheen:linear-gradient(180deg,rgba(255,255,255,.85),rgba(255,255,255,0) 42%);

  --r-sm:14px;
  --r-md:22px;
  --r-lg:34px;
  --r-xl:46px;

  --maxw:1240px;

  --font-display:'Bricolage Grotesque',system-ui,sans-serif;
  --font-body:'Hanken Grotesk',system-ui,sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--sky-50);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;}
picture{display:contents;}
a{color:inherit;text-decoration:none;}

/* Visible keyboard focus (WCAG 2.4.7) */
:focus-visible{outline:3px solid var(--blue-500);outline-offset:2px;border-radius:4px;}
.btn:focus-visible,.cat-pill:focus-visible{outline:3px solid var(--blue-800);outline-offset:3px;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

/* ---------- Type ---------- */
.display{
  font-family:var(--font-display);
  font-weight:700;
  line-height:.96;
  letter-spacing:-.025em;
  margin:0;
  text-wrap:balance;
}
h1.display{font-size:clamp(3rem,7.4vw,6.6rem);}
h2.display{font-size:clamp(2.3rem,5vw,4.3rem);}
h3.display{font-size:clamp(1.5rem,2.4vw,2.2rem);}
.eyebrow{
  font-family:var(--font-display);
  font-weight:600;
  font-size:.82rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--blue-600);
  display:inline-flex;align-items:center;gap:.55em;
}
.eyebrow::before{content:"";width:26px;height:2px;border-radius:2px;background:var(--blue-500);display:inline-block;}
.lead{font-size:clamp(1.05rem,1.5vw,1.32rem);line-height:1.5;color:var(--ink-soft);max-width:60ch;text-wrap:pretty;}
.muted{color:var(--ink-mute);}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--blue-600);
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--font-display);font-weight:600;font-size:1.02rem;
  padding:.95em 1.5em;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,background .25s;
  position:relative;white-space:nowrap;
}
.btn svg{width:1.05em;height:1.05em;}
.btn-primary{
  background:linear-gradient(180deg,var(--blue-500),var(--blue-700));
  color:#fff;
  box-shadow:0 12px 28px -10px rgba(18,104,199,.85),inset 0 1px 0 rgba(255,255,255,.45);
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 38px -12px rgba(18,104,199,.95),inset 0 1px 0 rgba(255,255,255,.5);}
.btn-ember{
  background:linear-gradient(180deg,var(--ember-500),var(--ember-600));
  color:#fff;
  box-shadow:0 12px 28px -10px rgba(231,97,31,.8),inset 0 1px 0 rgba(255,255,255,.45);
}
.btn-ember:hover{transform:translateY(-3px);}
.btn-glass{
  background:var(--glass-bg-strong);
  color:var(--ink);
  border-color:var(--glass-brd);
  backdrop-filter:blur(14px) saturate(150%);
  -webkit-backdrop-filter:blur(14px) saturate(150%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.7),0 10px 24px -14px rgba(10,40,72,.4);
}
.btn-glass:hover{transform:translateY(-3px);background:#fff;}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line);}
.btn-ghost:hover{background:rgba(255,255,255,.6);}
.btn-lg{font-size:1.12rem;padding:1.08em 1.8em;}
.btn:active{transform:translateY(-1px) scale(.98);transition-duration:.08s;}

/* ---------- Glass card ---------- */
.glass{
  position:relative;
  background:var(--glass-bg);
  border:1px solid var(--glass-brd);
  border-radius:var(--r-lg);
  backdrop-filter:blur(22px) saturate(160%);
  -webkit-backdrop-filter:blur(22px) saturate(160%);
  box-shadow:var(--glass-shadow);
  overflow:hidden;
}
.glass::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:var(--glass-sheen);pointer-events:none;opacity:.9;
}
.glass>*{position:relative;z-index:1;}

/* ---------- Floating nav ---------- */
.nav{
  position:fixed;top:18px;left:0;right:0;z-index:100;
  display:flex;justify-content:center;padding:0 18px;
  transition:top .3s;
}
.nav-inner{
  width:min(var(--maxw),100%);
  display:flex;align-items:center;gap:22px;
  padding:11px 11px 11px 22px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(255,255,255,.75);
  border-radius:999px;
  backdrop-filter:blur(20px) saturate(170%);
  -webkit-backdrop-filter:blur(20px) saturate(170%);
  box-shadow:0 14px 40px -18px rgba(10,40,72,.5),inset 0 1px 0 rgba(255,255,255,.8);
}
.nav-logo{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:700;font-size:1.12rem;color:var(--ink);letter-spacing:-.01em;}
.nav-logo img{height:38px;width:auto;}
.brand-logo{height:44px;width:auto;border-radius:11px;flex:none;display:block;}
.brand-logo.lg{height:50px;border-radius:13px;}
.foot-logo{background:#fff;padding:7px 9px;height:56px;border-radius:12px;box-shadow:0 6px 18px -10px rgba(0,0,0,.5);}
.logo-mark{width:42px;height:42px;border-radius:13px;display:grid;place-items:center;flex:none;
  background:linear-gradient(160deg,var(--blue-400),var(--blue-700) 70%,var(--blue-800));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55),0 8px 18px -8px rgba(18,104,199,.7);}
.logo-mark svg{width:23px;height:23px;color:#fff;}
.logo-mark{display:none;} /* fallback shown only if logo img fails (JS) */
.logo-mark.lg{width:48px;height:48px;border-radius:15px;}
.logo-mark.lg svg{width:26px;height:26px;}
.nav-logo small{display:block;font-family:var(--font-body);font-weight:500;font-size:.6rem;letter-spacing:.18em;color:var(--blue-600);text-transform:uppercase;margin-top:1px;}
.nav-links{display:flex;gap:4px;margin-left:auto;}
.nav-links a{
  font-family:var(--font-display);font-weight:500;font-size:.96rem;color:var(--ink-soft);
  padding:.5em .95em;border-radius:999px;transition:background .2s,color .2s;
}
.nav-links a:hover,.nav-links a.active{background:rgba(18,104,199,.1);color:var(--blue-700);}
.nav-cta{display:flex;align-items:center;gap:9px;}
.nav-phone{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:600;color:var(--ink);padding:.5em .6em;white-space:nowrap;}
.nav-phone svg{width:18px;height:18px;color:var(--blue-600);}
.nav-burger{display:none;width:44px;height:44px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.7);align-items:center;justify-content:center;cursor:pointer;}
.nav-burger span{display:block;width:18px;height:2px;background:var(--ink);position:relative;}
.nav-burger span::before,.nav-burger span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink);}
.nav-burger span::before{top:-6px;}.nav-burger span::after{top:6px;}

/* mobile menu sheet */
.mobile-menu{
  position:fixed;inset:0;z-index:99;display:none;
  background:rgba(6,43,84,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.mobile-menu.open{display:block;}
.mobile-sheet{
  position:absolute;top:84px;left:14px;right:14px;
  background:#fff;border-radius:var(--r-lg);padding:18px;
  box-shadow:0 30px 70px -20px rgba(10,40,72,.6);
}
.mobile-sheet a{display:block;font-family:var(--font-display);font-weight:600;font-size:1.2rem;padding:14px 12px;border-radius:14px;color:var(--ink);}
.mobile-sheet a:hover{background:var(--sky-100);}
.skip-link{
  position:fixed;left:18px;top:18px;z-index:200;
  transform:translateY(-140%);
  background:var(--blue-900);color:#fff;
  padding:12px 16px;border-radius:999px;
  font-family:var(--font-display);font-weight:700;
  box-shadow:0 12px 30px -14px rgba(10,40,72,.7);
}
.skip-link:focus{transform:none;outline:3px solid var(--ember-400);outline-offset:3px;}

/* ---------- Sections ---------- */
section{position:relative;}
.section{padding:clamp(70px,9vw,130px) 0;}
.section-head{max-width:64ch;margin-bottom:54px;}
.section-head .lead{margin-top:18px;}
.center{text-align:center;margin-left:auto;margin-right:auto;}
.center .lead{margin-left:auto;margin-right:auto;}

/* ---------- Footer ---------- */
.footer{background:var(--blue-900);color:#cfe2f7;padding:80px 0 36px;position:relative;overflow:hidden;}
.footer-title{font-family:var(--font-display);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:#7fb0e4;margin:0 0 18px;line-height:1.2;}
.footer a{color:#cfe2f7;display:block;padding:5px 0;transition:color .2s;}
.footer a:hover{color:#fff;}
.footer-grid{display:grid;grid-template-columns:1.5fr 1.7fr 1fr 1.1fr;gap:40px;}
.foot-svc .svc-cols{columns:2;column-gap:22px;}
.foot-svc .svc-cols a{break-inside:avoid;-webkit-column-break-inside:avoid;}
.footer-bottom{margin-top:56px;padding-top:24px;border-top:1px solid rgba(255,255,255,.14);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.86rem;color:#8fb5dd;}
.footer-areas{margin-top:40px;padding-top:26px;border-top:1px solid rgba(255,255,255,.14);}
.footer-areas .footer-title{margin-bottom:14px;}
.footer-areas .links{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.footer-areas .links a{display:inline-flex;align-items:center;min-height:32px;color:#cfe2f7;padding:6px 12px;font-size:.92rem;border:1px solid rgba(255,255,255,.18);border-radius:999px;line-height:1.2;transition:color .2s,border-color .2s,background .2s;}
.footer-areas .links a:hover{color:#fff;}
.footer-bottom a{display:inline;color:#a9cdf0;padding:0;}
.footer-bottom a:hover{color:#fff;}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;}.reveal.d2{transition-delay:.16s;}.reveal.d3{transition-delay:.24s;}.reveal.d4{transition-delay:.32s;}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .reveal{opacity:1;transform:none;transition:none;}
  .marquee,.vcol{animation:none;}
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important;}
}

/* ---------- Marquee ---------- */
.marquee{display:flex;gap:18px;width:max-content;animation:scrollx var(--dur,40s) linear infinite;}
.marquee.rev{animation-direction:reverse;}
.marquee-mask{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.marquee-mask:hover .marquee{animation-play-state:paused;}
@keyframes scrollx{to{transform:translateX(-50%);}}

/* vertical marquee columns (community wall) */
.vcol{display:flex;flex-direction:column;gap:16px;animation:scrolly var(--dur,30s) linear infinite;}
.vcol.rev{animation-direction:reverse;}
@keyframes scrolly{to{transform:translateY(-50%);}}

/* ---------- Utility ---------- */
.pill{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-display);font-weight:600;font-size:.84rem;padding:.5em .95em;border-radius:999px;background:rgba(18,104,199,.1);color:var(--blue-700);}
.pill-ember{background:rgba(231,97,31,.12);color:var(--ember-600);}
.grid{display:grid;gap:24px;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0;}
.dot{width:7px;height:7px;border-radius:50%;background:#3fcf6a;box-shadow:0 0 0 4px rgba(63,207,106,.2);display:inline-block;}

@media (max-width:1040px){
  .nav-links{display:none;}
  .nav-burger{display:flex;}
  body{padding-bottom:76px;}
}
@media (max-width:600px){
  .nav-phone{display:none;}
}

/* ---------- Sticky mobile call/book bar ---------- */
.mobile-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:120;
  display:none;gap:10px;
  padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.88);
  border-top:1px solid var(--glass-brd);
  backdrop-filter:blur(18px) saturate(170%);
  -webkit-backdrop-filter:blur(18px) saturate(170%);
  box-shadow:0 -12px 34px -18px rgba(10,40,72,.55);
}
.mobile-bar a{display:inline-flex;align-items:center;justify-content:center;gap:.5em;}
.mobile-bar .mbar-call{flex:1.6;}
.mobile-bar .mbar-book{flex:1;}
.mobile-bar svg{width:1.05em;height:1.05em;}
@media (max-width:1040px){.mobile-bar{display:flex;}}
@media (max-width:920px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
@media (max-width:560px){
  .wrap{padding:0 18px;}
  .footer-grid{grid-template-columns:1fr;}
}


/* ---------- Borderless fieldset (semantic group, no visual chrome) ---------- */
.field-fieldset{border:0;margin:0;padding:0;min-inline-size:0;}
.field-fieldset>legend{padding:0;display:block;width:100%;
  font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--ink-soft);}

/* ---------- Form error banner (WCAG 3.3.1 — error identification) ---------- */
.form-error{display:flex;gap:11px;align-items:flex-start;margin:14px 0 2px;padding:13px 16px;
  border-radius:13px;border:1px solid rgba(231,97,31,.4);background:rgba(231,97,31,.1);
  color:#9a3b12;font-size:.92rem;line-height:1.45;}
.form-error[hidden]{display:none;}
.form-error a{color:#9a3b12;font-weight:700;text-decoration:underline;}
.form-error-ic{flex:none;display:grid;place-items:center;color:var(--ember-600);margin-top:1px;}
.form-error-ic svg{width:20px;height:20px;}

/* ---------- Fallback for browsers without backdrop-filter ---------- */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){
  .nav-inner{background:rgba(255,255,255,.95);}
  .glass{background:var(--glass-bg-strong);}
  .btn-glass{background:#fff;}
  .mobile-bar{background:rgba(255,255,255,.97);}
  .mobile-menu{background:rgba(6,43,84,.78);}
}
