/* ─────────────────────────────────────────────
   Winterhill — site styles
   v0.1 · May 2026
───────────────────────────────────────────── */

@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url('/fonts/inter-latin.woff2') format('woff2-variations'),
       url('/fonts/inter-latin.woff2') format('woff2');
}

@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 500 800;
  font-display: swap;
  src: url('/fonts/manrope-latin.woff2') format('woff2-variations'),
       url('/fonts/manrope-latin.woff2') format('woff2');
}

:root{
  --teal:        #2F5050;
  --teal-dark:   #1F3838;
  --brass:       #B08842;
  --brass-deep:  #8E6E36;
  --bone:        #F5F1EA;
  --bone-dim:    #ECE6DA;
  --slate:       #3B4A4D;
  --slate-mid:   #5A6669;
  --slate-soft:  #8A9092;
  --ink:         #161A1B;

  --rule:         rgba(59,74,77,0.18);
  --rule-strong:  rgba(59,74,77,0.32);
  --rule-on-teal: rgba(245,241,234,0.16);

  --container:    1240px;
  --gutter:       32px;

  --r-xs: 2px;
  --r-sm: 4px;
  --r-md: 6px;
  --r-lg: 8px;

  --t-fast: 160ms cubic-bezier(.2,.7,.3,1);
  --t-med:  260ms cubic-bezier(.2,.7,.3,1);
}

/* ── reset ── */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bone);
  color:var(--ink);
  font-family:'Inter','Helvetica Neue',Arial,sans-serif;
  font-weight:400;
  font-size:17px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:'ss01','cv11';
}
a{color:inherit;text-decoration:none;}
button{font:inherit;border:0;background:none;cursor:pointer;color:inherit;}
img,svg{display:block;max-width:100%;}
input,textarea,select{font:inherit;color:inherit;}

/* ── typography ── */
.h-display{
  font-family:'Manrope',sans-serif; font-weight:700;
  font-size: clamp(48px, 7vw, 84px);
  line-height:1.02; letter-spacing:-0.035em;
  color:var(--teal);
  text-wrap:balance;
}
.h1{
  font-family:'Manrope',sans-serif; font-weight:700;
  font-size: clamp(36px, 4.4vw, 56px);
  line-height:1.10; letter-spacing:-0.022em;
  color:var(--teal);
  text-wrap:balance;
}
.h2{
  font-family:'Manrope',sans-serif; font-weight:600;
  font-size: clamp(26px, 2.6vw, 34px);
  line-height:1.18; letter-spacing:-0.015em;
  color:var(--teal);
  text-wrap:balance;
}
.h3{
  font-family:'Manrope',sans-serif; font-weight:600;
  font-size:20px; line-height:1.30; letter-spacing:-0.005em;
  color:var(--teal);
}
.lede{
  font-family:'Manrope',sans-serif; font-weight:500;
  font-size:21px; line-height:1.42; letter-spacing:-0.005em;
  color:var(--slate); text-wrap:pretty;
  max-width:62ch;
}
.body{
  font-size:17px; line-height:1.55; color:var(--ink); text-wrap:pretty;
  max-width:62ch;
}
.body-dim{color:var(--slate);}
.small{font-size:13.5px; line-height:1.45; letter-spacing:0.005em; color:var(--slate);}
.eyebrow{
  font-family:'Inter',sans-serif; font-weight:600; font-size:12px;
  letter-spacing:0.18em; text-transform:uppercase; color:var(--brass);
}
.eyebrow .num{color:var(--slate); margin-right:14px; font-variant-numeric:tabular-nums;}
.label{
  font-family:'Inter',sans-serif; font-weight:600; font-size:13px;
  letter-spacing:0.05em; text-transform:uppercase; color:var(--teal);
}

/* ── layout ── */
.container{
  width:100%; max-width:var(--container);
  margin:0 auto;
  padding:0 var(--gutter);
}
.section{padding: 96px 0;}
.section-tight{padding: 64px 0;}
.section-eyebrow{margin-bottom:18px;}
.hr-fine{height:1px; background:var(--rule); margin:0;}

/* ── header ── */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(245,241,234,0.86);
  backdrop-filter:saturate(140%) blur(8px);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--rule);
}
.site-header .row{
  display:flex; align-items:center; gap:32px;
  height:80px;
}
.brand{
  display:inline-flex; align-items:center; gap:10px;
  margin-right:auto;
}
.brand svg{height:40px; width:auto;}
.brand .tag{
  display:none;
  font-family:'Inter',sans-serif; font-weight:600; font-size:11px;
  letter-spacing:0.16em; text-transform:uppercase; color:var(--slate);
  padding-left:12px; border-left:1px solid var(--rule-strong);
  margin-left:4px;
}
@media (min-width:880px){ .brand .tag{display:inline-block;} }

.nav{
  display:flex; align-items:center; gap:28px;
}
.nav a{
  font-family:'Inter',sans-serif; font-weight:500; font-size:15px;
  color:var(--slate); padding:8px 0;
  position:relative;
  transition: color var(--t-fast);
}
.nav a:hover{color:var(--teal);}
.nav a.is-active{color:var(--teal); font-weight:600;}
.nav a.is-active::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:2px; background:var(--brass);
}

/* ── buttons ── */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  height:44px; padding:0 18px;
  font-family:'Inter',sans-serif; font-weight:600; font-size:14.5px;
  letter-spacing:0.01em;
  border-radius:var(--r-lg);
  transition: transform var(--t-fast), background var(--t-fast), color var(--t-fast), box-shadow var(--t-fast);
  white-space:nowrap;
}
.btn:active{transform:translateY(1px);}
.btn-brass{background:var(--brass); color:var(--bone);}
.btn-brass:hover{background:var(--brass-deep);}
.btn-teal{background:var(--teal); color:var(--bone);}
.btn-teal:hover{background:var(--teal-dark);}
.btn-ghost{
  background:transparent; color:var(--teal);
  box-shadow: inset 0 0 0 1.5px var(--rule-strong);
}
.btn-ghost:hover{box-shadow: inset 0 0 0 1.5px var(--teal);}
.btn-bone-on-teal{
  background:var(--bone); color:var(--teal);
}
.btn-bone-on-teal:hover{background:#fff;}
.btn-link{
  display:inline-flex; align-items:center; gap:8px;
  color:var(--teal); font-weight:600; font-size:14.5px;
  border-bottom:1px solid var(--rule-strong); padding-bottom:2px;
  transition: border-color var(--t-fast), color var(--t-fast);
}
.btn-link:hover{border-color:var(--brass); color:var(--brass-deep);}
.btn-link .arr{transition: transform var(--t-fast);}
.btn-link:hover .arr{transform:translateX(3px);}

/* ── hero ── */
.hero{
  padding-top: 88px;
  padding-bottom: 96px;
  position:relative;
  overflow:hidden;
}
.hero-grid{
  display:grid; grid-template-columns: 1.35fr 1fr; gap:64px;
  align-items:center;
}
@media (max-width: 900px){ .hero-grid{ grid-template-columns:1fr; gap:48px; } }

.hero .tagline{
  display:inline-flex; align-items:center; gap:10px;
  padding:6px 12px 6px 8px;
  border-radius:99px;
  background: rgba(176,136,66,0.08);
  border:1px solid rgba(176,136,66,0.20);
  color:var(--brass-deep);
  font-family:'Inter',sans-serif; font-size:12.5px; font-weight:600;
  letter-spacing:0.06em;
}
.hero .tagline .pip{
  width:6px; height:6px; background:var(--brass); border-radius:1px;
}
.hero h1{
  margin: 24px 0 28px;
  font-family:'Manrope',sans-serif; font-weight:700;
  font-size: clamp(46px, 6.4vw, 78px);
  line-height:1.02; letter-spacing:-0.035em;
  color:var(--teal); text-wrap:balance;
}
.hero h1 em{
  font-style:normal; position:relative;
}
.hero h1 em::after{
  content:""; position:absolute;
  left:0; right:0; bottom:0.04em; height:0.085em;
  background:var(--brass);
  z-index:-1; opacity:0.85;
}
.hero p.lede{font-size:21.5px;}
.hero .cta-row{
  display:flex; gap:14px; align-items:center; margin-top:36px;
  flex-wrap:wrap;
}
.hero .promise{
  margin-top:48px;
  display:flex; gap:30px; flex-wrap:wrap;
  padding-top:24px;
  border-top:1px solid var(--rule);
}
.hero .promise .item{
  display:flex; flex-direction:column; gap:4px;
}
.hero .promise .item .n{
  font-family:'Manrope',sans-serif; font-weight:700; font-size:26px;
  color:var(--teal); letter-spacing:-0.02em; line-height:1;
}
.hero .promise .item .n .brass{color:var(--brass);}
.hero .promise .item .l{
  font-size:12px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--slate); font-weight:600;
}

/* hero graphic: mast on hill */
.hero-graphic{
  position:relative; aspect-ratio: 1 / 1; max-width:520px; justify-self:end; width:100%;
}
.hero-graphic svg{width:100%; height:100%;}

/* ── teal mode (hero variant) ── */
body.hero-dark .hero{
  background:var(--teal); color:var(--bone);
}
body.hero-dark .hero h1{color:var(--bone);}
body.hero-dark .hero h1 em::after{opacity:1;}
body.hero-dark .hero p.lede{color:rgba(245,241,234,0.78);}
body.hero-dark .hero .promise{border-color: var(--rule-on-teal);}
body.hero-dark .hero .promise .item .n{color:var(--bone);}
body.hero-dark .hero .promise .item .l{color:rgba(245,241,234,0.55);}
body.hero-dark .hero .tagline{
  background: rgba(176,136,66,0.16); border-color: rgba(176,136,66,0.40); color:#E5C083;
}
body.hero-dark .hero .btn-brass{background:var(--brass); color:var(--bone);}
body.hero-dark .hero .btn-ghost{box-shadow: inset 0 0 0 1.5px rgba(245,241,234,0.30); color:var(--bone);}
body.hero-dark .hero .btn-ghost:hover{box-shadow: inset 0 0 0 1.5px var(--bone);}

/* ── services grid ── */
.svc-head{
  display:grid; grid-template-columns: 1fr auto; align-items:end; gap:32px;
  margin-bottom:56px;
}
@media (max-width:720px){.svc-head{grid-template-columns:1fr;}}

.svc-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:1px;
  background:var(--rule);
  border:1px solid var(--rule);
}
.svc-card{
  background:var(--bone);
  padding:36px 32px 32px;
  display:flex; flex-direction:column;
  min-height:340px;
  position:relative;
  transition: background var(--t-fast);
}
.svc-card:hover{background:var(--bone-dim);}
.svc-card .top{
  display:flex; justify-content:space-between; align-items:flex-start;
  margin-bottom:24px;
}
.svc-card .num{
  font-family:'Manrope',sans-serif; font-weight:700;
  font-size:13px; letter-spacing:0.06em; color:var(--slate-soft);
  font-variant-numeric:tabular-nums;
}
.svc-card h3{
  margin:0 0 14px;
  font-family:'Manrope',sans-serif; font-weight:700;
  font-size:30px; line-height:1.08; letter-spacing:-0.02em; color:var(--teal);
}
.svc-card p{margin:0 0 24px; color:var(--slate-mid); font-size:15.5px; line-height:1.55;}
.svc-card ul{
  list-style:none; padding:0; margin:0 0 24px;
  display:flex; flex-direction:column; gap:8px;
  font-size:14px; color:var(--slate);
}
.svc-card ul li{display:flex; gap:10px; align-items:flex-start;}
.svc-card ul li::before{
  content:""; flex:0 0 auto; width:5px; height:5px; background:var(--brass);
  border-radius:1px; margin-top:9px;
}
.svc-card .stat{
  margin-top:auto;
  padding-top:20px;
  border-top:1px dashed var(--rule);
  display:flex; align-items:baseline; gap:10px;
}
.svc-card .stat .n{
  font-family:'Manrope',sans-serif; font-weight:700; font-size:30px;
  color:var(--teal); letter-spacing:-0.02em; line-height:1;
}
.svc-card .stat .u{
  font-size:13px; color:var(--slate); font-weight:500; letter-spacing:0.01em;
}

/* feature service card (full-width) */
.svc-feature{
  grid-column: 1 / -1;
  background:var(--teal);
  color:var(--bone);
  padding:44px 40px;
  display:grid; grid-template-columns: 1fr auto; gap:48px; align-items:center;
  min-height:auto;
}
.svc-feature h3{color:var(--bone); font-size:32px;}
.svc-feature p{color:rgba(245,241,234,0.78); margin:0; font-size:16px; max-width:64ch;}
.svc-feature .num{color:rgba(245,241,234,0.45);}

/* ── sectors / who we serve ── */
.sectors{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:1px;
  background:var(--rule);
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
@media (max-width:760px){.sectors{grid-template-columns:repeat(2,1fr);}}
.sector{
  background:var(--bone);
  padding:28px 24px;
  display:flex; flex-direction:column; gap:8px;
  transition: background var(--t-fast);
}
.sector:hover{background:var(--bone-dim);}
.sector .nm{
  font-family:'Manrope',sans-serif; font-weight:600; font-size:18px;
  color:var(--teal); letter-spacing:-0.005em;
}
.sector .ex{font-size:13.5px; color:var(--slate); line-height:1.45;}

/* ── how we work ── */
.steps{
  display:grid; grid-template-columns:repeat(4,1fr); gap:32px;
}
@media (max-width:900px){.steps{grid-template-columns:repeat(2,1fr);}}
@media (max-width:560px){.steps{grid-template-columns:1fr;}}
.step{display:flex; flex-direction:column; gap:14px;}
.step .head{
  display:flex; align-items:center; gap:14px;
  padding-bottom:14px; border-bottom:1px solid var(--rule);
}
.step .num{
  font-family:'Manrope',sans-serif; font-weight:700; font-size:30px;
  color:var(--brass); letter-spacing:-0.02em; line-height:1; font-variant-numeric:tabular-nums;
}
.step h3{margin:0; font-size:19px; line-height:1.2;}
.step p{margin:0; font-size:15px; color:var(--slate-mid); line-height:1.55;}

/* ── proof / testimonials ── */
.proof{
  background: var(--bone-dim);
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.testi-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:32px;
}
@media (max-width:900px){.testi-grid{grid-template-columns:1fr; gap:24px;}}
.testi{
  background:var(--bone);
  padding:32px 28px;
  display:flex; flex-direction:column; gap:18px;
  border:1px solid var(--rule);
  position:relative;
}
.testi .mark{
  font-family:'Manrope',sans-serif; font-weight:700; font-size:38px;
  line-height:0; color:var(--brass); height:0;
}
.testi blockquote{
  margin:0;
  font-family:'Manrope',sans-serif; font-weight:500; font-size:18px;
  line-height:1.4; color:var(--teal); letter-spacing:-0.005em;
  text-wrap:pretty;
}
.testi .by{
  margin-top:auto;
  padding-top:14px;
  border-top:1px solid var(--rule);
  display:flex; flex-direction:column; gap:2px;
}
.testi .by .nm{font-weight:600; font-size:14px; color:var(--ink);}
.testi .by .ti{font-size:13px; color:var(--slate);}

/* vendor logos band */
.vendors{
  display:grid; grid-template-columns:repeat(4,1fr); gap:0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
@media (max-width:760px){.vendors{grid-template-columns:repeat(2,1fr);}}
.vendor{
  height:88px; display:grid; place-items:center;
  font-family:'Manrope',sans-serif; font-weight:700; font-size:16px;
  color:var(--slate-mid); letter-spacing:-0.005em;
  border-right:1px solid var(--rule);
  transition: color var(--t-fast), background var(--t-fast);
}
.vendor:last-child{border-right:0;}
.vendor:hover{color:var(--teal); background:var(--bone-dim);}
@media (max-width:760px){
  .vendor{border-right:1px solid var(--rule);}
  .vendor:nth-child(2n){border-right:0;}
  .vendor:nth-child(n+3){border-top:1px solid var(--rule);}
}

/* PSTN banner */
.pstn-banner{
  background:var(--brass);
  color:var(--bone);
  border-bottom:1px solid rgba(0,0,0,0.08);
}
.pstn-banner .container{
  display:flex; align-items:center; gap:18px;
  padding-top:10px; padding-bottom:10px;
  flex-wrap:wrap;
}
.pstn-banner .pip{
  width:8px; height:8px; background:var(--bone); border-radius:50%;
  flex:0 0 auto;
}
.pstn-banner p{
  margin:0; flex:1; min-width:0;
  font-family:'Inter',sans-serif; font-size:14.5px; line-height:1.4;
}
.pstn-banner p strong{font-weight:600;}
.pstn-banner .pstn-cta{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Inter',sans-serif; font-weight:600; font-size:13.5px;
  letter-spacing:0.04em; color:var(--bone);
  padding:6px 12px; border-radius:var(--r-md);
  background:rgba(20,28,30,0.18);
  transition: background var(--t-fast);
  flex:0 0 auto;
}
.pstn-banner .pstn-cta:hover{background:rgba(20,28,30,0.32);}

/* Partner accreditations */
.accred-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:1px;
  background:var(--rule);
  border:1px solid var(--rule);
}
@media (max-width:900px){.accred-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:520px){.accred-grid{grid-template-columns:1fr;}}
.accred{
  background:var(--bone);
  padding:28px 24px;
  display:flex; flex-direction:column; gap:12px;
  transition: background var(--t-fast);
}
.accred:hover{background:var(--bone-dim);}
.accred .ti{
  font-family:'Manrope',sans-serif; font-weight:700; font-size:18px;
  color:var(--teal); letter-spacing:-0.005em; line-height:1.2;
}
.accred .status{
  display:inline-flex; align-self:flex-start;
  padding:4px 10px; border-radius:99px;
  background: rgba(176,136,66,0.12);
  border:1px solid rgba(176,136,66,0.32);
  color:var(--brass-deep);
  font-family:'Inter',sans-serif; font-weight:600; font-size:11.5px;
  letter-spacing:0.12em; text-transform:uppercase;
}
.accred .meta{
  font-size:13.5px; color:var(--slate); line-height:1.45;
  margin-top:auto;
}

/* stub pages */
.stub{max-width:62ch;}
.stub-list{
  list-style:none; padding:0; margin:18px 0 0;
  display:flex; flex-direction:column; gap:14px;
}
.stub-list li{
  display:flex; gap:14px; align-items:flex-start;
  font-size:16.5px; line-height:1.55; color:var(--ink);
}
.stub-list li::before{
  content:""; flex:0 0 auto; width:6px; height:6px; background:var(--brass);
  border-radius:1px; margin-top:11px;
}
.stub a{color:var(--teal); border-bottom:1px solid var(--rule-strong);}
.stub a:hover{color:var(--brass-deep); border-color:var(--brass);}
.page-header .breadcrumb a{color:inherit;}
.page-header .breadcrumb a:hover{color:var(--brass-deep);}

/* footer legal links */
.legal-links{display:inline-flex; align-items:center; gap:0; flex-wrap:wrap;}
.legal-links a{color:rgba(245,241,234,0.72); transition:color var(--t-fast);}
.legal-links a:hover{color:var(--bone);}

/* ── cta band ── */
.cta-band{
  background:var(--teal); color:var(--bone);
  padding:80px 0;
}
.cta-band .inner{
  display:grid; grid-template-columns: 1fr auto; gap:48px; align-items:center;
}
@media (max-width:760px){.cta-band .inner{grid-template-columns:1fr;}}
.cta-band h2{color:var(--bone); margin:0 0 14px; font-size: clamp(32px,3.8vw,46px); letter-spacing:-0.025em; line-height:1.1;}
.cta-band p{margin:0; color:rgba(245,241,234,0.75); font-size:18px; max-width:48ch;}
.cta-band .actions{display:flex; gap:14px; flex-wrap:wrap;}

/* ── footer ── */
.site-footer{
  background:var(--teal); color:var(--bone);
  padding:64px 0 28px;
}
.site-footer a{color:rgba(245,241,234,0.72); transition:color var(--t-fast);}
.site-footer a:hover{color:var(--bone);}
.footer-grid{
  display:grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap:48px;
  padding-bottom:48px;
  border-bottom:1px solid var(--rule-on-teal);
}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr; gap:32px;}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr;}}
.footer-grid .brand-blk svg{height:48px;}
.footer-grid .blurb{color:rgba(245,241,234,0.65); font-size:14px; margin-top:18px; line-height:1.55; max-width:42ch;}
.footer-col h4{
  font-family:'Inter',sans-serif; font-weight:600; font-size:12px;
  letter-spacing:0.18em; text-transform:uppercase; color:var(--brass);
  margin:0 0 18px;
}
.footer-col ul{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:10px; font-size:14px;}
.legal{
  display:flex; justify-content:space-between; align-items:center; gap:24px;
  padding-top:24px; font-size:12px; color:rgba(245,241,234,0.55); flex-wrap:wrap;
}
.legal .dot{display:inline-block;width:5px;height:5px;background:var(--brass);border-radius:1px;margin:0 10px;transform:translateY(-1px);}

/* ── pages: services / about / contact ── */
.page-header{
  padding-top:80px; padding-bottom:64px;
  border-bottom:1px solid var(--rule);
}
.page-header .breadcrumb{
  font-family:'Inter',sans-serif; font-size:12px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--brass); font-weight:600; margin-bottom:18px;
}
.page-header .breadcrumb .sep{color:var(--slate-soft); margin:0 10px;}
.page-header h1{
  margin:0 0 22px;
  font-family:'Manrope',sans-serif; font-weight:700;
  font-size: clamp(40px, 5.4vw, 68px);
  line-height:1.04; letter-spacing:-0.03em; color:var(--teal);
  max-width:18ch; text-wrap:balance;
}
.page-header .lede{font-size:21px; max-width:54ch;}

/* services detail rows */
.svc-detail{
  padding: 72px 0;
  border-bottom:1px solid var(--rule);
}
.svc-detail:last-child{border-bottom:0;}
.svc-detail .row{
  display:grid; grid-template-columns: 0.4fr 1fr 0.7fr; gap:48px;
  align-items:start;
}
@media (max-width:900px){.svc-detail .row{grid-template-columns:1fr; gap:32px;}}
.svc-detail .left .eyebrow{margin-bottom:8px;}
.svc-detail .left h2{margin:8px 0 0;}
.svc-detail .mid p{margin:0 0 18px;}
.svc-detail .mid ul{
  list-style:none; padding:0; margin:18px 0 0;
  display:grid; grid-template-columns:1fr 1fr; gap:10px 24px;
}
.svc-detail .mid ul li{
  display:flex; gap:10px; align-items:flex-start;
  font-size:15px; color:var(--slate);
}
.svc-detail .mid ul li::before{
  content:""; flex:0 0 auto; width:5px; height:5px; background:var(--brass);
  margin-top:9px; border-radius:1px;
}
.svc-detail .right .stat-card{
  background:var(--bone-dim); border:1px solid var(--rule); padding:24px;
  display:flex; flex-direction:column; gap:10px;
}
.svc-detail .right .stat-card .n{
  font-family:'Manrope',sans-serif; font-weight:700; font-size:46px;
  color:var(--teal); letter-spacing:-0.025em; line-height:1;
}
.svc-detail .right .stat-card .u{font-size:14px; color:var(--slate); line-height:1.4;}
.svc-detail .right .stat-card + .stat-card{margin-top:14px;}

/* about — narrative */
.story{
  display:grid; grid-template-columns: 0.4fr 1fr; gap:64px;
  margin-bottom: 80px;
}
@media (max-width:820px){.story{grid-template-columns:1fr; gap:32px;}}
.story .left{position:sticky; top:96px; align-self:start;}
.story .left h2{margin:8px 0 0;}
.story .right p{margin:0 0 18px; font-size:18px; line-height:1.6; max-width:64ch;}
.story .right p:first-child::first-letter{
  font-family:'Manrope',sans-serif; font-weight:700;
  font-size:64px; color:var(--brass);
  float:left; line-height:0.9; padding:6px 12px 0 0;
}

.founder{
  display:grid; grid-template-columns: 1fr 1.4fr; gap:48px; align-items:center;
  background:var(--bone-dim); border:1px solid var(--rule);
  padding:40px;
}
@media (max-width:760px){.founder{grid-template-columns:1fr;}}
.founder .portrait{
  background:var(--teal); color:var(--bone);
  aspect-ratio: 4/5; max-width:260px;
  display:flex; align-items:flex-end; padding:24px;
  position:relative; overflow:hidden;
}
.founder .portrait::before{
  content:""; position:absolute; inset:0;
  background: radial-gradient(120% 100% at 50% 30%, rgba(176,136,66,0.18), transparent 55%);
}
.founder .portrait .nm{
  font-family:'Manrope',sans-serif; font-weight:700; font-size:24px; line-height:1.1; position:relative;
}
.founder .portrait .ti{
  font-size:13px; letter-spacing:0.14em; text-transform:uppercase; color:rgba(245,241,234,0.65); position:relative;
}
.founder blockquote{
  margin:0;
  font-family:'Manrope',sans-serif; font-weight:500; font-size:22px;
  line-height:1.4; color:var(--teal); letter-spacing:-0.01em; text-wrap:pretty;
}
.founder .sign{
  margin-top:18px; font-size:14px; color:var(--slate);
}

/* contact */
.contact-grid{
  display:grid; grid-template-columns: 1fr 1fr; gap:64px;
  align-items:start;
}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr;}}
.form{
  display:flex; flex-direction:column; gap:18px;
}
.field{display:flex; flex-direction:column; gap:6px;}
.field label{
  font-family:'Inter',sans-serif; font-weight:600; font-size:12px;
  letter-spacing:0.12em; text-transform:uppercase; color:var(--slate);
}
.field input, .field textarea, .field select{
  width:100%; padding:12px 14px;
  background:var(--bone); border:1px solid var(--rule-strong);
  border-radius:var(--r-md);
  font-size:15.5px; color:var(--ink);
  transition: border-color var(--t-fast), background var(--t-fast);
}
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none; border-color:var(--teal); background:#fff;
}
.field .help{font-size:12.5px; color:var(--slate-soft);}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
@media (max-width:520px){.field-row{grid-template-columns:1fr;}}
.form .submit-row{
  display:flex; align-items:center; gap:18px; margin-top:6px;
}
.form .submit-row .small{flex:1;}

.contact-side{
  display:flex; flex-direction:column; gap:24px;
}
.contact-block{
  display:flex; flex-direction:column; gap:6px;
  padding:20px 0; border-bottom:1px solid var(--rule);
}
.contact-block:last-of-type{border-bottom:0;}
.contact-block .k{
  font-family:'Inter',sans-serif; font-weight:600; font-size:11.5px;
  letter-spacing:0.18em; text-transform:uppercase; color:var(--brass);
}
.contact-block .v{
  font-family:'Manrope',sans-serif; font-weight:600; font-size:22px;
  color:var(--teal); letter-spacing:-0.01em;
}
.contact-block .v a{color:var(--teal);}
.contact-block .v a:hover{color:var(--brass-deep);}
.contact-block .meta{font-size:13.5px; color:var(--slate); margin-top:2px;}

.coverage{
  position:relative;
  background:var(--bone-dim); border:1px solid var(--rule);
  aspect-ratio: 4/3; overflow:hidden;
}

/* ── form flash ── */
#form-flash{
  transition: opacity 200ms;
  opacity: 0;
  min-height: 1.45em;
}
#form-flash[data-kind="ok"]{color:var(--teal);}
#form-flash[data-kind="err"]{color:#A14242;}

/* ── helpers ── */
.flex-row{display:flex; align-items:center; gap:12px;}
.spacer-l{margin-left:auto;}
[hidden]{display:none !important;}
.route{display:none;}
.route.is-active{display:block;}
