/* ============================================================
   PROCON — "North Shore Monolith"
   Hand-authored design system. No framework. Self-hosted type.
   ============================================================ */

/* ---------- Self-hosted type ---------- */
@font-face{font-family:"Clash Display";src:url("/assets/fonts/ClashDisplay-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Clash Display";src:url("/assets/fonts/ClashDisplay-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Clash Display";src:url("/assets/fonts/ClashDisplay-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Switzer";src:url("/assets/fonts/Switzer-400.woff2") format("woff2");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Switzer";src:url("/assets/fonts/Switzer-500.woff2") format("woff2");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Switzer";src:url("/assets/fonts/Switzer-600.woff2") format("woff2");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Switzer";src:url("/assets/fonts/Switzer-700.woff2") format("woff2");font-weight:700;font-style:normal;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --iron:#13171A; --iron-2:#1B2126; --iron-3:#272E34;
  --paper:#F3F0E9; --paper-2:#E8E2D6;
  --ink:#13171A; --ink-soft:#585C5C;
  --mist:rgba(243,240,233,.64); --mist-2:rgba(243,240,233,.40);
  --timber:#B07A37;            /* warm accent — eyebrows, rules, mark */
  --superior:#8FB7C8;          /* cold North-Shore accent — rare pop */
  --line:rgba(19,23,26,.14);
  --line-d:rgba(243,240,233,.16);
  --clash:"Clash Display",ui-sans-serif,Georgia,serif;
  --switzer:"Switzer",ui-sans-serif,system-ui,sans-serif;
  --maxw:1320px;
  --gut:clamp(1.25rem,4.5vw,4.5rem);
  --ease:cubic-bezier(.22,.61,.21,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --r:2px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0}
html{-webkit-text-size-adjust:100%;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}
body{font-family:var(--switzer);background:var(--paper);color:var(--ink);font-size:clamp(1rem,.55vw + .85rem,1.0625rem);line-height:1.65;font-weight:400;overflow-x:hidden}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--ink);color:var(--paper)}
:focus-visible{outline:2px solid var(--superior);outline-offset:3px}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--clash);font-weight:600;line-height:.98;letter-spacing:-.02em}
.display{font-family:var(--clash);font-weight:500;font-size:clamp(2rem,3.2vw,3.1rem);line-height:1.08;letter-spacing:-.02em}
.h-sec{font-size:clamp(1.45rem,2vw,1.95rem);line-height:1.18;letter-spacing:-.015em;font-weight:500}
.h-sub{font-size:clamp(1.12rem,1.4vw,1.3rem);line-height:1.25}
.eyebrow{font-family:var(--switzer);font-weight:600;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--timber);display:inline-flex;align-items:center;gap:.85rem}
.eyebrow::before{content:"";width:2.2rem;height:1px;background:var(--timber);opacity:.85}
.eyebrow--center::after{content:"";width:2.2rem;height:1px;background:var(--timber);opacity:.85}
.lead{font-size:clamp(1.08rem,1.2vw,1.25rem);line-height:1.55;font-weight:400;letter-spacing:-.005em}
.measure{max-width:60ch}.measure-sm{max-width:46ch}
.tnum{font-variant-numeric:tabular-nums lining-nums}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gut);width:100%}
.section{padding-block:clamp(4rem,9vh,7.5rem)}
.on-iron{background:var(--iron);color:var(--paper)}
.on-iron .eyebrow{color:var(--superior)}
.on-iron .eyebrow::before,.on-iron .eyebrow--center::after{background:var(--superior)}
.hr{height:1px;background:var(--line);border:0}
.on-iron .hr{background:var(--line-d)}

/* ---------- Buttons (architectural, sharp) ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.7rem;font-family:var(--switzer);font-weight:600;font-size:.94rem;letter-spacing:.01em;padding:1.05rem 1.7rem;border-radius:var(--r);border:1px solid transparent;transition:background .4s var(--ease),color .4s var(--ease),border-color .4s var(--ease),transform .5s var(--ease-out);will-change:transform}
.btn--solid{background:var(--ink);color:var(--paper)}
.btn--solid:hover{background:#000}
.on-iron .btn--solid{background:var(--paper);color:var(--ink)}
.on-iron .btn--solid:hover{background:#fff}
.btn--ghost{border-color:var(--line);color:var(--ink)}
.btn--ghost:hover{border-color:var(--ink)}
.on-iron .btn--ghost{border-color:var(--line-d);color:var(--paper)}
.on-iron .btn--ghost:hover{border-color:var(--paper)}
.btn__dot{width:5px;height:5px;border-radius:50%;background:var(--timber);transition:transform .5s var(--ease-out)}
.btn:hover .btn__dot{transform:scale(2.4)}

/* animated text underline */
.ulink{position:relative;font-weight:600}
.ulink::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease-out)}
.ulink:hover::after{transform:scaleX(1)}

/* ---------- Film grain (cinematic) ---------- */
.grain::after{content:"";position:fixed;inset:0;z-index:9;pointer-events:none;opacity:.045;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}


/* ---------- Reveal-on-scroll ---------- */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease-out),transform 1.1s var(--ease-out);transition-delay:var(--rd,0ms)}
[data-reveal].is-in{opacity:1;transform:none}
.reveal-line{display:block;overflow:hidden}
.reveal-line>span{display:block;transform:translateY(102%);transition:transform 1.1s var(--ease-out);transition-delay:var(--rd,0ms)}
.is-in .reveal-line>span,.reveal-line.is-in>span{transform:none}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important}
  [data-reveal],.reveal-line>span{opacity:1!important;transform:none!important;transition:none!important}
}

/* ---------- Header: dark utility top-bar + solid white main bar ---------- */
:root{--tbh:40px;--hbh:82px}
@media(max-width:1023px){:root{--tbh:38px;--hbh:66px}}
body:has(#head){padding-top:calc(var(--tbh) + var(--hbh))}
.head{position:fixed;inset:0 0 auto;z-index:50}
.topbar{background:var(--iron);color:var(--paper);overflow:hidden;transition:margin-top .45s var(--ease)}
.head.is-stuck .topbar{margin-top:calc(-1 * var(--tbh))}
.topbar__in{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:var(--tbh);font-size:.78rem;letter-spacing:.03em}
.topbar__l{display:flex;align-items:center;gap:1.4rem;min-width:0}
.topbar__tag{display:none;margin:0;color:var(--mist);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.topbar__tel{font-weight:600;white-space:nowrap;display:inline-flex;align-items:center;gap:.45rem;font-variant-numeric:tabular-nums}
.topbar__tel svg{width:12px;height:12px;flex:none}
.topbar__r{display:flex;align-items:center;gap:1.3rem;flex:none}
.topbar__mail{display:none;color:var(--mist);transition:color .3s}
.topbar__mail:hover{color:var(--paper)}
.topbar__cta{background:var(--timber);color:#fff;font-weight:600;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;border-radius:100px;padding:.4rem 1.05rem;white-space:nowrap;transition:filter .3s}
.topbar__cta:hover{filter:brightness(1.14)}
@media(min-width:760px){.topbar__tag{display:block}}
@media(min-width:1100px){.topbar__mail{display:inline}}
.headbar{background:#fff;color:var(--iron);border-bottom:1px solid var(--line);box-shadow:0 1px 10px rgba(10,12,14,.05);transition:box-shadow .4s}
.head.is-stuck .headbar{box-shadow:0 5px 20px rgba(10,12,14,.1)}
.head__in{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;height:var(--hbh);transition:height .4s var(--ease)}
.head.is-stuck .head__in{height:64px}
.brand{display:inline-flex;align-items:center}
.brand img{display:block;height:60px;width:auto;transition:height .4s var(--ease)}
.head.is-stuck .brand img{height:46px}
@media(max-width:1023px){.brand img{height:48px}.head.is-stuck .head__in{height:58px}.head.is-stuck .brand img{height:42px}}
.foot__brand img{display:block;height:60px;width:auto;border-radius:6px}
.nav{display:none;gap:2.1rem}
.nav a{font-family:var(--switzer);font-weight:500;font-size:.92rem;letter-spacing:.01em;position:relative;padding-block:.4rem}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease-out)}
.nav a:hover::after{transform:scaleX(1)}
.head__cta{display:none;align-items:center;gap:1.4rem}
.head__tel{font-weight:600;font-size:.92rem}
.burger{display:inline-flex;flex-direction:column;gap:6px;width:44px;height:44px;align-items:center;justify-content:center}
.burger span{width:24px;height:1.5px;background:currentColor;transition:transform .4s var(--ease),opacity .3s}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}
@media(min-width:1024px){.nav{display:flex}.head__cta{display:flex}.burger{display:none}}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:45;background:var(--iron);color:var(--paper);transform:translateY(-100%);transition:transform .6s var(--ease);display:flex;flex-direction:column;padding:7rem var(--gut) 2.5rem;visibility:hidden}
.drawer.is-open{transform:none;visibility:visible}
.drawer a{font-family:var(--clash);font-weight:500;font-size:clamp(1.5rem,5vw,2rem);padding-block:.45rem;border-bottom:1px solid var(--line-d)}
.drawer__foot{margin-top:auto;display:flex;gap:1rem;padding-top:2rem}
.drawer__foot .btn{flex:1;justify-content:center}
@media(min-width:1024px){.drawer{display:none}}

/* ---------- Hero (photo-first, cinematic) ---------- */
.hero{position:relative;min-height:calc(78svh - var(--tbh) - var(--hbh));display:flex;flex-direction:column;justify-content:flex-end;background:var(--iron);color:#fff;overflow:hidden;padding-bottom:clamp(2.5rem,6vh,4rem)}
.hero__contour{position:absolute;inset:0;width:100%;height:100%;opacity:.5;pointer-events:none}
.hero__photo{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero__photo img{width:100%;height:100%;object-fit:cover;object-position:center 42%;display:block;transform:scale(1.06);animation:kenburns 24s var(--ease) forwards}
@keyframes kenburns{from{transform:scale(1.12) translateY(1.5%)}to{transform:scale(1.02) translateY(0)}}
.hero__photo::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,12,14,.88) 0%,rgba(10,12,14,.46) 26%,rgba(10,12,14,.08) 52%,rgba(10,12,14,.18) 88%,rgba(10,12,14,.34) 100%)}
.hero--page .hero__photo img{animation:none;transform:none}
.hero__h1--xl{font-size:clamp(2.2rem,4.2vw,3.8rem);line-height:1.04;letter-spacing:-.025em;font-weight:600}
.hero__bottom{position:relative;z-index:2;display:grid;gap:1.8rem}
.hero__sub{display:grid;gap:1.6rem;max-width:56ch}
@media(min-width:1024px){.hero__bottom{grid-template-columns:1fr auto;align-items:end}.hero__sub{grid-row:2;grid-column:1}}
.wx{display:inline-flex;align-items:center;gap:.65rem;font-size:.8rem;letter-spacing:.06em;color:rgba(255,255,255,.78);border:1px solid rgba(255,255,255,.22);border-radius:100px;padding:.5rem 1.05rem;backdrop-filter:blur(8px);background:rgba(10,12,14,.25)}
.wx i{width:6px;height:6px;border-radius:50%;background:var(--superior);animation:wxpulse 2.6s ease infinite}
@keyframes wxpulse{0%,100%{opacity:1}50%{opacity:.35}}
.wx b{font-weight:600;color:#fff;font-variant-numeric:tabular-nums}
.hero__glow{position:absolute;inset:0;background:radial-gradient(120% 80% at 78% 8%,rgba(143,183,200,.16),transparent 55%),radial-gradient(90% 70% at 5% 100%,rgba(176,122,55,.12),transparent 60%);pointer-events:none}
.hero__top{position:absolute;top:0;left:0;right:0}
.hero__wrap{position:relative;z-index:2}
.hero__h1{margin-block:.2em .55em}
.hero__meta{display:flex;flex-wrap:wrap;gap:1.5rem 2.5rem;align-items:center}
.pill{display:inline-flex;align-items:center;gap:.6rem;font-size:.82rem;letter-spacing:.02em;color:var(--mist)}
.pill::before{content:"";width:6px;height:6px;background:var(--timber);transform:rotate(45deg)}
.scrollcue{position:absolute;right:var(--gut);bottom:clamp(2.5rem,6vh,5rem);z-index:2;display:flex;align-items:center;gap:.8rem;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--mist-2);writing-mode:vertical-rl}
.scrollcue i{display:block;width:1px;height:54px;background:linear-gradient(var(--mist),transparent);animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- Gallery ---------- */
.gal{display:grid;gap:clamp(1.8rem,3.5vw,2.8rem) clamp(1.2rem,2.5vw,2rem)}
.gal figure{margin:0;display:grid;align-content:start;gap:.85rem}
.gal__media{position:relative;overflow:hidden;border-radius:var(--r);background:var(--iron-2)}
.gal img{width:100%;height:100%;object-fit:cover;display:block;aspect-ratio:4/3;max-height:19rem;transition:transform 1.1s var(--ease)}
.gal figure:hover img{transform:scale(1.035)}
.gal figcaption{display:grid;gap:.35rem;padding-right:.5rem}
.gal figcaption .tag{font-family:var(--switzer);font-weight:600;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--timber)}
.gal figcaption .cap{font-size:.92rem;line-height:1.55;color:var(--ink-soft);max-width:44ch}
.on-iron .gal figcaption .tag{color:var(--superior)}
.on-iron .gal figcaption .cap{color:var(--mist)}
.gal--wide img{aspect-ratio:21/9}
@media(min-width:640px){.gal{grid-template-columns:repeat(2,1fr)}.gal--wide{grid-column:1/-1}}
@media(min-width:1100px){.gal{grid-template-columns:repeat(3,1fr)}}
.gal--wide img{max-height:22rem}
.gal--wide figcaption .cap{max-width:64ch}

/* ---------- Marquee ---------- */
.marquee{overflow:hidden;border-block:1px solid var(--line-d);padding-block:1rem}
.marquee__t{display:inline-flex;gap:3.5rem;white-space:nowrap;will-change:transform;animation:slide 42s linear infinite}
.marquee__t span{font-family:var(--clash);font-weight:500;font-size:clamp(1rem,1.4vw,1.3rem);color:var(--mist)}
.marquee__t i{align-self:center;width:7px;height:7px;background:var(--timber);transform:rotate(45deg)}
@keyframes slide{to{transform:translateX(-50%)}}

/* ---------- Stat row ---------- */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem 1.5rem}
.stat__n{font-family:var(--clash);font-weight:600;font-size:clamp(1.5rem,2vw,2rem);line-height:1;letter-spacing:-.012em}
.stat__l{margin-top:.7rem;font-size:.9rem;color:var(--mist);max-width:22ch}
@media(min-width:768px){.stats{grid-template-columns:repeat(4,1fr)}}

/* ---------- Services index list ---------- */
.svc{border-top:1px solid var(--line)}
.svc__row{display:grid;grid-template-columns:auto 1fr;gap:1.1rem 1.4rem;align-items:start;padding-block:clamp(1.8rem,3vw,2.7rem);border-bottom:1px solid var(--line);transition:padding-left .5s var(--ease)}
.svc__row:hover{padding-left:1.1rem}
.svc__no{font-family:var(--clash);font-weight:500;font-size:1rem;color:var(--ink-soft);padding-top:.7rem}
.svc__name{font-family:var(--clash);font-weight:600;font-size:clamp(1.25rem,2vw,1.75rem);letter-spacing:-.015em;transition:color .4s}
.svc__row:hover .svc__name{color:var(--timber)}
.svc__desc{margin-top:.5rem;color:var(--ink-soft);max-width:54ch}
.svc__go{grid-column:2;margin-top:.9rem;font-size:.85rem;font-weight:600;letter-spacing:.02em;color:var(--timber);display:inline-flex;align-items:center;gap:.6rem;opacity:0;transform:translateX(-8px);transition:opacity .4s,transform .4s var(--ease-out)}
.svc__row:hover .svc__go{opacity:1;transform:none}
@media(min-width:768px){.svc__row{grid-template-columns:5.5rem 1fr auto}.svc__go{grid-column:auto;margin-top:0;align-self:center}}

/* ---------- Differentiators ---------- */
.diff{display:grid;gap:clamp(3rem,6vw,5.5rem)}
.diff__item{display:grid;gap:1rem 3rem;align-items:start;padding-top:clamp(2rem,4vw,3.5rem);border-top:1px solid var(--line-d)}
.diff__n{font-family:var(--clash);font-weight:600;font-size:clamp(1.8rem,3vw,2.6rem);color:var(--superior);line-height:.85}
@media(min-width:768px){.diff__item{grid-template-columns:auto 1fr}}

/* ---------- Process ---------- */
.proc{display:grid;gap:2.5rem}
.proc__s{padding-top:1.4rem;border-top:1.5px solid var(--line)}
.proc__n{font-family:var(--clash);font-weight:600;font-size:1.1rem;color:var(--timber)}
.proc__h{margin-top:.5rem;font-size:1.3rem}
.proc__p{margin-top:.6rem;color:var(--ink-soft)}
@media(min-width:768px){.proc{grid-template-columns:repeat(4,1fr);gap:1.5rem}}

/* ---------- Quote ---------- */
.quote{font-family:var(--clash);font-weight:500;font-size:clamp(1.3rem,2vw,1.8rem);line-height:1.3;letter-spacing:-.012em}

/* ---------- FAQ ---------- */
.faq{border-top:1px solid var(--line)}
.faq__i{border-bottom:1px solid var(--line)}
.faq__s{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:2rem;cursor:pointer;padding-block:1.35rem;font-family:var(--clash);font-weight:600;font-size:clamp(1.02rem,1.3vw,1.2rem);letter-spacing:-.008em}
.faq__s::-webkit-details-marker{display:none}
.faq__q{font:inherit;letter-spacing:inherit;margin:0}
.faq__m{position:relative;flex:0 0 18px;width:18px;height:18px}
.faq__m::before,.faq__m::after{content:"";position:absolute;background:var(--timber);transition:transform .4s var(--ease)}
.faq__m::before{top:50%;left:0;width:100%;height:1.5px;transform:translateY(-50%)}
.faq__m::after{left:50%;top:0;height:100%;width:1.5px;transform:translateX(-50%)}
.faq[open] .faq__m::after{transform:translateX(-50%) scaleY(0)}
.faq__a{padding-bottom:1.7rem;color:var(--ink-soft);max-width:68ch}
.on-iron .faq,.on-iron .faq__i{border-color:var(--line-d)}
.on-iron .faq__a{color:var(--mist)}

/* ---------- Footer ---------- */
.foot{background:var(--iron);color:var(--mist)}
.foot a:hover{color:var(--paper)}
.foot__grid{display:grid;gap:3rem}
.foot__brand{font-family:var(--clash);font-weight:600;font-size:1.4rem;color:var(--paper);display:inline-flex;align-items:center;gap:.7rem}
.foot h2{font-family:var(--switzer);font-weight:600;font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mist-2)}
.foot ul{list-style:none;padding:0;display:grid;gap:.8rem;margin-top:1.3rem}
.foot address{font-style:normal;margin-top:1.3rem;display:grid;gap:.7rem}
@media(min-width:768px){.foot__grid{grid-template-columns:1.4fr .9fr .9fr 1.2fr}}

/* ---------- Sticky mobile bar ---------- */
.mbar{position:fixed;inset:auto 0 0;z-index:40;display:flex;gap:.7rem;padding:.7rem;background:color-mix(in srgb,var(--paper) 92%,transparent);backdrop-filter:blur(10px);border-top:1px solid var(--line)}
.mbar .btn{flex:1;justify-content:center;padding-block:.95rem}
@media(min-width:1024px){.mbar{display:none}}

/* utilities */
.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}
.skip{position:fixed;top:-100px;left:1rem;z-index:70;background:var(--ink);color:var(--paper);padding:.7rem 1.1rem;border-radius:var(--r);transition:top .3s}
.skip:focus{top:1rem}
.stack-lg{display:grid;gap:clamp(2.5rem,5vw,4.5rem)}
.grid-edit{display:grid;gap:clamp(2rem,4vw,4.5rem)}
@media(min-width:1024px){.grid-edit{grid-template-columns:1fr 1.25fr;align-items:start}}

/* ============================================================
   SERVICE PAGES (hub + spokes)
   ============================================================ */

/* Breadcrumb */
.crumb{display:flex;flex-wrap:wrap;align-items:center;gap:.7rem;font-size:.78rem;letter-spacing:.04em;color:var(--mist-2)}
.crumb a:hover{color:var(--paper)}
.crumb li{display:flex;align-items:center;gap:.7rem;list-style:none}
.crumb li+li::before{content:"";width:5px;height:5px;background:var(--timber);transform:rotate(45deg);flex:0 0 auto}
.crumb [aria-current]{color:var(--mist)}

/* Compact service/city hero (iron) */
.shero{position:relative;background:var(--iron);color:var(--paper);overflow:hidden;padding-top:clamp(3.2rem,7vh,5rem)}
.shero .hero__contour{opacity:.42}
.shero__h1{margin-block:1rem .6em;font-size:clamp(1.7rem,2.8vw,2.6rem)}
.shero__pills{display:flex;flex-wrap:wrap;gap:1.4rem 2.2rem;margin-top:.4rem}

/* "What's included" list */
.ilist{display:grid;gap:0;border-top:1px solid var(--line);margin-top:1.5rem}
.ilist li{list-style:none;display:grid;grid-template-columns:auto 1fr;gap:1.1rem;align-items:baseline;padding-block:1.1rem;border-bottom:1px solid var(--line)}
.ilist li::before{content:"";width:8px;height:8px;background:var(--timber);transform:rotate(45deg);margin-top:.5rem}
.ilist b{font-weight:600}
.ilist span{color:var(--ink-soft)}

/* Spec block — pricing | timeline */
.spec{display:grid;gap:2rem;border-top:1px solid var(--line);padding-top:2rem;margin-top:2rem}
.spec__k{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--timber)}
.spec__v{font-family:var(--clash);font-weight:600;font-size:clamp(1.4rem,2vw,1.9rem);line-height:1.05;margin-top:.7rem;letter-spacing:-.012em}
.spec__n{margin-top:.7rem;color:var(--ink-soft);max-width:40ch}
@media(min-width:640px){.spec{grid-template-columns:1fr 1fr;gap:3rem}}

/* Materials / branded note */
.matnote{border-left:2px solid var(--timber);padding:.4rem 0 .4rem 1.4rem;margin-top:1.5rem}
.matnote b{font-family:var(--clash);font-weight:600}

/* Related services + city strip */
.rel{display:grid;gap:1rem;margin-top:1.6rem}
.rel__card{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.5rem 1.6rem;border:1px solid var(--line);border-radius:var(--r);transition:border-color .4s,transform .5s var(--ease-out)}
.rel__card:hover{border-color:var(--timber);transform:translateX(4px)}
.rel__card b{font-family:var(--clash);font-weight:600;font-size:1.2rem}
.rel__card span{color:var(--timber);font-size:1.4rem;line-height:1}
@media(min-width:768px){.rel{grid-template-columns:repeat(3,1fr)}.rel__card{flex-direction:column;align-items:flex-start;gap:2.5rem}}

/* Hub service grid */
.hubgrid{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);margin-top:clamp(2.5rem,5vw,4rem)}
.hubgrid a{background:var(--paper);padding:clamp(1.6rem,2.4vw,2.2rem);display:flex;flex-direction:column;min-height:12rem;transition:background .4s}
.hubgrid a:hover{background:var(--paper-2)}
.hubgrid .num{font-family:var(--clash);font-weight:500;color:var(--ink-soft);font-size:.95rem}
.hubgrid .nm{font-family:var(--clash);font-weight:600;font-size:clamp(1.18rem,1.6vw,1.45rem);letter-spacing:-.012em;margin-top:1.2rem;line-height:1.15}
.hubgrid .ds{color:var(--ink-soft);margin-top:.7rem;font-size:.96rem}
.hubgrid .go{margin-top:auto;padding-top:1.4rem;color:var(--timber);font-weight:600;font-size:.85rem;letter-spacing:.02em}
@media(min-width:640px){.hubgrid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.hubgrid{grid-template-columns:repeat(3,1fr)}}

/* ---------- Contact + Forms ---------- */
.contactgrid{display:grid;gap:clamp(2.5rem,5vw,5rem)}
@media(min-width:900px){.contactgrid{grid-template-columns:1.15fr .85fr}}
.field{margin-bottom:1.4rem}
.field label{display:block;font-size:.82rem;font-weight:600;letter-spacing:.02em;margin-bottom:.5rem}
.field .req{color:var(--timber)}
.field input,.field select,.field textarea{width:100%;font-family:var(--switzer);font-size:1rem;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:.85rem 1rem;transition:border-color .3s,box-shadow .3s}
.field textarea{min-height:8rem;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--timber);box-shadow:0 0 0 3px rgba(176,122,55,.16)}
.field--error input,.field--error select,.field--error textarea{border-color:#B3261E;box-shadow:0 0 0 3px rgba(179,38,30,.12)}
.field .err{display:none;margin-top:.45rem;font-size:.8rem;color:#B3261E}
.field--error .err{display:block}
.form__hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form__note{font-size:.8rem;color:var(--ink-soft);margin-top:.4rem}
.form__ok{display:none;border:1px solid var(--line);border-radius:var(--r);padding:clamp(2rem,4vw,3rem);text-align:left}
.form__ok h3{font-family:var(--clash);font-weight:600;font-size:1.6rem}
.form.is-sent .form__body{display:none}
.form.is-sent .form__ok{display:block}
.cdetails{display:grid;gap:1.8rem;align-content:start}
.cdetails .lbl{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--timber);margin-bottom:.5rem}
.cdetails a:hover{color:var(--timber)}
.cbig{font-family:var(--clash);font-weight:600;font-size:clamp(1.5rem,3vw,2rem);letter-spacing:-.01em}
.hours{display:grid;grid-template-columns:auto 1fr;gap:.3rem 1.5rem;font-size:.95rem;color:var(--ink-soft)}

/* ---------- Map embed (city pages) ---------- */
.map-embed{margin-top:1.6rem;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--paper-2);min-height:380px}
.map-embed iframe{display:block;width:100%;height:420px;border:0;filter:grayscale(.35) contrast(1.04)}
.on-iron .map-embed{border-color:var(--line-d)}

/* ============================================================
   NORTHSHORE EDITORIAL — v2 component layer
   ============================================================ */

/* ---------- Editorial split (photo + text) ---------- */
.edsplit{display:grid;gap:clamp(2rem,4vw,4rem);align-items:center}
.edsplit__media{position:relative;overflow:hidden;border-radius:var(--r)}
.edsplit__media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;max-height:24rem;transition:transform 1.4s var(--ease)}
.edsplit__media:hover img{transform:scale(1.04)}
.edsplit__media figcaption{position:absolute;left:0;right:0;bottom:0;padding:1.1rem 1.3rem;font-size:.78rem;letter-spacing:.05em;color:rgba(255,255,255,.85);background:linear-gradient(to top,rgba(10,12,14,.72),transparent)}
@media(min-width:1024px){
  .edsplit{grid-template-columns:1fr 1.1fr}
  .edsplit--rev .edsplit__media{order:2}
  .edsplit__media--tall img{aspect-ratio:1/1;max-height:28rem}
}

/* ---------- Full-width image break (parallax) ---------- */
.imgbreak{position:relative;height:clamp(11rem,28vh,17rem);overflow:hidden}
.imgbreak img{position:absolute;inset:-18% 0;width:100%;height:136%;object-fit:cover;will-change:transform}
.imgbreak__cap{position:absolute;left:var(--gut);bottom:1.6rem;z-index:2;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.imgbreak::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,12,14,.35),transparent 40%)}

/* ---------- Work cards (selected projects) ---------- */
.work{display:grid;gap:clamp(1.8rem,3vw,2.8rem)}
.work__card{display:grid;gap:.9rem;align-content:start}
.work__media{position:relative;overflow:hidden;border-radius:var(--r);aspect-ratio:3/2;max-height:20rem}
.work__card--wide .work__media{aspect-ratio:21/9;max-height:24rem}
.work__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease)}
.work__card:hover .work__media img{transform:scale(1.05)}
.work__media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(10,12,14,.32),transparent 45%);opacity:0;transition:opacity .6s}
.work__card:hover .work__media::after{opacity:1}
.work__meta{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:.3rem 1rem}
.work__title{font-family:var(--clash);font-weight:600;font-size:clamp(1.05rem,1.3vw,1.25rem);letter-spacing:-.01em}
.work__tag{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--timber);white-space:nowrap}
.work__desc{color:var(--ink-soft);font-size:.95rem;max-width:50ch}
.on-iron .work__desc{color:var(--mist)}
@media(min-width:680px){
  .work{grid-template-columns:repeat(2,1fr)}
  .work__card--wide{grid-column:1/-1}
}

/* ---------- Spec sheet (The ProCon Standard) ---------- */
.specsheet{border-top:1px solid var(--line-d)}
.specsheet__row{display:grid;grid-template-columns:auto 1fr;gap:1.2rem 2rem;padding-block:clamp(1.6rem,3vw,2.4rem);border-bottom:1px solid var(--line-d);align-items:baseline}
.specsheet__no{font-family:var(--clash);font-weight:500;font-size:.95rem;color:var(--superior)}
.specsheet__k{font-family:var(--clash);font-weight:600;font-size:clamp(1.1rem,1.5vw,1.4rem);letter-spacing:-.012em}
.specsheet__v{grid-column:2;color:var(--mist);max-width:62ch}
@media(min-width:900px){
  .specsheet__row{grid-template-columns:5rem 1fr 1.4fr}
  .specsheet__v{grid-column:auto}
}

/* ---------- Giant pull-quote testimonial ---------- */
.bigquote{font-family:var(--clash);font-weight:500;font-size:clamp(1.2rem,1.8vw,1.65rem);line-height:1.4;letter-spacing:-.012em;text-wrap:balance}
.bigquote .qmark{color:var(--timber)}
.bigquote__by{margin-top:2rem;display:flex;align-items:center;gap:1rem;font-size:.9rem;color:var(--ink-soft)}
.bigquote__by::before{content:"";width:3rem;height:1px;background:var(--timber)}
.on-iron .bigquote__by{color:var(--mist)}

/* ---------- Before / After slider ---------- */
.ba{position:relative;overflow:hidden;border-radius:var(--r);aspect-ratio:16/9;max-height:26rem;max-width:56rem;margin-inline:auto;user-select:none;touch-action:none}
.ba img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;pointer-events:none}
.ba__after{clip-path:inset(0 0 0 50%)}
.ba__handle{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#fff;cursor:ew-resize;z-index:3}
.ba__handle::after{content:"⟨ ⟩";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:#fff;color:var(--iron);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;letter-spacing:-1px;box-shadow:0 4px 18px rgba(0,0,0,.35)}
.ba__lbl{position:absolute;top:1rem;z-index:2;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:#fff;background:rgba(10,12,14,.55);padding:.4rem .8rem;border-radius:100px;backdrop-filter:blur(6px)}
.ba__lbl--b{left:1rem}.ba__lbl--a{right:1rem}

/* ---------- Lightbox ---------- */
.lbox{position:fixed;inset:0;z-index:80;background:rgba(10,12,14,.94);display:none;align-items:center;justify-content:center;padding:clamp(1rem,4vw,4rem)}
.lbox.is-open{display:flex}
.lbox img{max-width:100%;max-height:82vh;object-fit:contain;border-radius:var(--r)}
.lbox__cap{position:absolute;left:50%;bottom:2rem;transform:translateX(-50%);color:rgba(255,255,255,.85);font-size:.88rem;text-align:center;max-width:60ch;padding-inline:1rem}
.lbox__x{position:absolute;top:1.4rem;right:1.6rem;color:#fff;font-size:1rem;letter-spacing:.14em;text-transform:uppercase;opacity:.8}
.lbox__x:hover{opacity:1}
.lbox__nav{position:absolute;top:50%;transform:translateY(-50%);color:#fff;font-size:2rem;padding:1rem;opacity:.7}
.lbox__nav:hover{opacity:1}
.lbox__prev{left:.6rem}.lbox__next{right:.6rem}
.gal .gal__media{cursor:zoom-in}

/* ---------- Giant footer wordmark ---------- */
.foot__giant{font-family:var(--clash);font-weight:600;font-size:clamp(2rem,5vw,4.2rem);line-height:.9;letter-spacing:-.025em;color:var(--iron-2);user-select:none;text-align:center;padding-top:clamp(1.2rem,2.5vw,2rem);overflow:hidden;white-space:nowrap}
.foot__giant span{display:inline-block;background:linear-gradient(to bottom,rgba(243,240,233,.16),rgba(243,240,233,.03));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Service feature hero image (sub-pages) ---------- */
.shero__media{position:relative;margin-top:clamp(2.5rem,5vw,4rem);overflow:hidden}
.shero__media img{width:100%;height:clamp(10rem,26vh,16rem);object-fit:cover;display:block}
.shero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(19,23,26,.4),transparent 35%)}

/* ---------- Mid-page CTA band (CRO) ---------- */
.ctaband{background:var(--iron-2);color:var(--paper);padding:clamp(2.2rem,4.5vw,3.4rem) 0;margin-block:clamp(2.5rem,5vw,4rem)}
.ctaband__in{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.2rem 2rem}
.ctaband__h{font-family:var(--clash);font-weight:600;font-size:clamp(1.2rem,1.9vw,1.6rem);letter-spacing:-.015em;margin:0}
.ctaband__sub{color:var(--mist);font-size:.92rem;margin:.35rem 0 0}
.ctaband__act{display:flex;gap:.9rem;flex-wrap:wrap;align-items:center}
/* ---------- Reviews (live from Google) ---------- */
.rv{display:grid;gap:clamp(1.2rem,2.5vw,2rem)}
@media(min-width:700px){.rv{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1100px){.rv{grid-template-columns:repeat(3,1fr)}}
.rv__card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:clamp(1.3rem,2.5vw,1.8rem);display:grid;gap:.8rem;align-content:start}
.rv__head{display:flex;align-items:center;gap:.8rem}
.rv__ava{border-radius:50%;flex:0 0 auto}
.rv__name{font-family:var(--clash);font-weight:600;font-size:.98rem}
.rv__time{font-size:.78rem;color:var(--ink-soft)}
.rv__stars{color:var(--timber);letter-spacing:.12em;font-size:.95rem}
.rv__text{color:var(--ink-soft);font-size:.94rem;line-height:1.6}
.rv__big{display:flex;align-items:center;gap:.6rem;font-size:1.1rem}
.rv__big .rv__stars{font-size:1.2rem}
.rv__empty{grid-column:1/-1;padding:clamp(2rem,4vw,3rem);border:1.5px dashed var(--line);border-radius:var(--r)}
