:root{
  --ink:#0F1419; --panel:#151C24; --line:#26303B;
  --bone:#E9E6DF; --slate:#9AA6B2; --steel:#7FA6C4; --steel-dim:#4E6E88;
  --amber:#D9A036; --amber-dim:rgba(217,160,54,.45);
  --serif:'Iowan Old Style','Palatino Linotype',Palatino,Georgia,'Times New Roman',serif;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
  --mono:ui-monospace,'SF Mono','Cascadia Mono',Consolas,'Liberation Mono',Menlo,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{background:var(--ink);color:var(--bone);font:16px/1.65 var(--sans);-webkit-font-smoothing:antialiased}
a{color:var(--steel);text-decoration:none}
a:hover{color:var(--bone)}
:focus-visible{outline:2px solid var(--steel);outline-offset:2px}
.skip{position:absolute;left:-999px;top:0;background:var(--steel);color:var(--ink);padding:8px 14px;z-index:99;font-family:var(--mono);font-size:12px}
.skip:focus{left:12px;top:12px}
.wrap{max-width:1000px;margin:0 auto;padding:0 24px}

/* header */
.site-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:18px;
  padding:26px 0 22px;border-bottom:1px solid var(--line)}
.wordmark{display:inline-flex;flex-direction:column;gap:2px}
.wm-name{font-family:var(--serif);font-size:19px;letter-spacing:.16em;color:var(--bone)}
.wm-sub{font-family:var(--mono);font-size:9px;letter-spacing:.52em;color:var(--steel)}
.nav{display:flex;gap:26px;flex-wrap:wrap;align-items:center}
.nav a{font-family:var(--mono);font-size:12px;letter-spacing:.14em;color:var(--slate)}
.nav a:hover{color:var(--bone)}
.nav a.here{color:var(--steel);border-bottom:1px dotted var(--steel-dim);padding-bottom:2px}
.nav a.cta{border:1px solid var(--steel-dim);padding:8px 14px;border-radius:2px;color:var(--steel)}
.nav a.cta:hover{background:rgba(127,166,196,.08)}

/* hero */
.hero{padding:88px 0 68px}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(34px,5.6vw,56px);line-height:1.08;
  letter-spacing:-.005em;max-width:17.5em}
.hero .lede{margin-top:26px;font-size:18px;line-height:1.7;color:var(--slate);max-width:38em}
.btnrow{margin-top:38px;display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-block;font-family:var(--mono);font-size:12px;letter-spacing:.18em;
  padding:13px 24px;border:1px solid var(--steel);color:var(--steel);border-radius:2px}
.btn:hover{background:rgba(127,166,196,.09);color:var(--steel)}
.btn.primary{background:var(--steel);color:var(--ink);font-weight:700}
.btn.primary:hover{background:#93B8D2;color:var(--ink)}

/* eyebrow with dotted leader — the register motif */
.eyebrow{display:flex;align-items:center;gap:16px;font-family:var(--mono);font-size:11px;
  letter-spacing:.3em;color:var(--steel)}
.eyebrow::after{content:"";flex:1;border-top:1px dotted var(--steel-dim)}
.metaline{display:flex;align-items:center;gap:16px;font-family:var(--mono);font-size:11px;
  letter-spacing:.24em;color:var(--slate);margin-bottom:34px}
.metaline::after{content:"";flex:1;border-top:1px dotted var(--steel-dim)}

section{border-top:1px solid var(--line);padding:66px 0}
section:first-of-type{border-top:0}
h2{font-family:var(--serif);font-weight:500;font-size:27px;line-height:1.25;margin:34px 0 14px}
.eyebrow + h2{margin-top:30px}
h3{font-family:var(--serif);font-weight:500;font-size:20px;line-height:1.3;margin:0 0 8px}
p{margin:0 0 16px;max-width:44em}
p.dim{color:var(--slate)}
ul.plain{list-style:none;margin:0 0 16px}
ul.plain li{padding:9px 0;border-bottom:1px dotted var(--line);max-width:44em}

/* service entries */
.entry{padding:30px 0;border-bottom:1px dotted var(--line)}
.entry:last-child{border-bottom:0}
.entry-row{display:flex;align-items:baseline;gap:14px;margin-bottom:10px}
.entry-row .leader{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-5px)}
.tag{font-family:var(--mono);font-size:10px;letter-spacing:.26em;color:var(--steel);white-space:nowrap}
.entry p{color:var(--slate);margin-bottom:8px}
.entry a.more{font-family:var(--mono);font-size:11px;letter-spacing:.16em}

/* boundary clauses */
.boundary{border-left:2px solid var(--steel-dim);padding:12px 18px;margin:18px 0 6px;max-width:44em;color:var(--slate)}
.boundary b{font-family:var(--mono);font-weight:600;font-size:10px;letter-spacing:.26em;color:var(--steel);
  display:block;margin-bottom:6px}

/* audience line */
.aud{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;color:var(--steel);margin:0 0 14px;max-width:52em}

/* record strip */
.record{display:flex;flex-wrap:wrap;column-gap:14px;row-gap:8px;font-family:var(--mono);font-size:12px;
  letter-spacing:.12em;color:var(--bone);align-items:center}
.record .dot{color:var(--steel)}

/* principles */
.principles{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:30px;margin-top:28px}
.principles p{color:var(--slate);font-size:15px}

/* closing band */
.band{border-top:1px solid var(--line);padding:60px 0}
.band h2{margin-top:0}

/* about photo slot */
.about-grid{display:grid;grid-template-columns:1fr 240px;gap:44px;align-items:start}
.photo-slot{border:1px dotted var(--steel-dim);border-radius:2px;background:var(--panel);
  aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;text-align:center;padding:16px}
.photo-slot span{font-family:var(--mono);font-size:10px;letter-spacing:.22em;color:var(--slate);line-height:2}
@media(max-width:720px){.about-grid{grid-template-columns:1fr}.photo-slot{max-width:240px}}

/* forms */
form{max-width:34em;margin-top:8px}
.field{margin-bottom:18px}
label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--slate);margin-bottom:7px}
input[type=text],input[type=email],textarea{width:100%;background:var(--panel);border:1px solid var(--line);
  border-radius:2px;color:var(--bone);font:15px/1.5 var(--sans);padding:12px 13px}
input:focus,textarea:focus{border-color:var(--steel);outline:none}
.consent{display:flex;gap:12px;align-items:flex-start;margin:22px 0;max-width:34em}
.consent input{margin-top:4px;accent-color:#7FA6C4}
.consent span{font-size:13.5px;color:var(--slate);line-height:1.6}
.formnote{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--amber);margin-top:14px}
button.btn{background:var(--steel);color:var(--ink);border:1px solid var(--steel);cursor:pointer;font-weight:700}
button.btn:hover{background:#93B8D2}

/* legal pages */
.dateline{font-family:var(--mono);font-size:11px;letter-spacing:.16em;color:var(--slate);margin:10px 0 30px}
.legalbody h2{font-size:20px;margin:34px 0 10px}
.legalbody p,.legalbody li{color:var(--slate);font-size:15px}
.legalbody ul{margin:0 0 16px 20px;max-width:44em}
article.legalbody{padding-bottom:70px}

/* footer */
footer{border-top:1px solid var(--line);padding:52px 0 60px;margin-top:20px}
footer .legal{font-size:13px;color:var(--slate);max-width:54em}
.footlinks{display:flex;gap:20px;flex-wrap:wrap;margin:26px 0 18px}
.footlinks a{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--slate)}
.footlinks a:hover{color:var(--bone)}
.copyline{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--steel-dim)}
@media(max-width:560px){
  .entry-row{flex-wrap:wrap}.entry-row .leader{display:none}
  .hero{padding:64px 0 52px}
}

/* ============ v1.1 additions ============ */

/* sticky header */
.site-head{position:sticky;top:0;z-index:40;background:rgba(15,20,25,.88);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}

/* hero scale + scroll cue */
.hero h1{font-size:clamp(36px,6vw,62px)}
.scrollcue{margin-top:56px;display:inline-flex;align-items:center;gap:12px;
  font-family:var(--mono);font-size:10px;letter-spacing:.3em;color:var(--steel-dim)}
.scrollcue::before{content:"";width:1px;height:34px;background:linear-gradient(var(--steel),transparent);
  animation:cue 2.2s ease-in-out infinite}
@keyframes cue{0%,100%{transform:translateY(0);opacity:.9}50%{transform:translateY(7px);opacity:.4}}
@media (prefers-reduced-motion:reduce){.scrollcue::before{animation:none}}

/* service entry hover */
.entry{position:relative;padding-left:0;transition:padding-left .35s ease}
.entry::before{content:"";position:absolute;left:0;top:30px;bottom:30px;width:2px;
  background:var(--steel);transform:scaleY(0);transform-origin:top;transition:transform .35s ease}
.entry:hover{padding-left:20px}
.entry:hover::before{transform:scaleY(1)}
.entry:hover h3 a{color:var(--bone)}
.entry .num{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--steel-dim);margin-right:10px}
@media (prefers-reduced-motion:reduce){.entry,.entry::before{transition:none}}

/* stats strip */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:34px}
.stat-num{font-family:var(--serif);font-size:52px;line-height:1;color:var(--bone)}
.stat-plus{font-family:var(--serif);font-size:30px;color:var(--steel);vertical-align:14px}
.stat-label{display:block;margin-top:10px;font-family:var(--mono);font-size:11px;
  letter-spacing:.18em;color:var(--slate)}
.stat-label-solo{display:block;font-family:var(--mono);font-size:12px;letter-spacing:.14em;
  color:var(--bone);border-left:2px solid var(--steel-dim);padding-left:14px;line-height:1.9}

/* audience selector */
.aud-tabs{display:flex;gap:10px;flex-wrap:wrap;margin:30px 0 26px}
.aud-tabs button{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--slate);
  background:none;border:1px solid var(--line);border-radius:2px;padding:10px 16px;cursor:pointer;
  transition:color .25s,border-color .25s}
.aud-tabs button:hover{color:var(--bone);border-color:var(--steel-dim)}
.aud-tabs button[aria-selected="true"]{color:var(--steel);border-color:var(--steel)}
.aud-panel{border-left:2px solid var(--steel-dim);padding:14px 20px;margin-bottom:14px;max-width:44em}
.aud-panel h3{margin-bottom:6px}
.aud-panel p{color:var(--slate);margin-bottom:10px}
.aud-panel a{font-family:var(--mono);font-size:11px;letter-spacing:.16em}

/* FAQ accordion */
.faq{max-width:44em;margin-top:26px}
.faq details{border-bottom:1px dotted var(--line)}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:baseline;
  gap:16px;padding:18px 0;font-family:var(--serif);font-size:18px;color:var(--bone)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--mono);color:var(--steel);transition:transform .25s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--slate);font-size:15px;padding-bottom:18px;margin:0}
@media (prefers-reduced-motion:reduce){.faq summary::after{transition:none}}

/* portrait */
.portrait{display:block}
.portrait img{width:100%;height:auto;border:1px solid var(--line);border-radius:2px;display:block}
.portrait figcaption{font-family:var(--mono);font-size:10px;letter-spacing:.2em;color:var(--steel-dim);margin-top:10px}

/* scroll reveals (only when JS + motion allowed) */
.js-anim .reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease}
.js-anim .reveal.in{opacity:1;transform:none}

/* mobile pass */
@media(max-width:560px){
  .stat-num{font-size:42px}
  .aud-tabs button{flex:1 1 44%}
  .nav{gap:16px}
  .nav a{padding:4px 0}
}

/* utility classes (inline-style removal for strict CSP) */
.mt0{margin-top:0}.mt24{margin-top:24px}.mt26{margin-top:26px}.mt28{margin-top:28px}
.mt30{margin-top:30px}.mt34{margin-top:34px}.mt36{margin-top:36px}
.pb44{padding-bottom:44px}
.legal-h1{font-family:var(--serif);font-weight:500;font-size:34px;margin-top:18px}
.hl{color:var(--bone)}

/* ============ v1.2 Depth & Emphasis ============ */

/* bolder hero type (Exaggerated-Minimalism-informed, brand-safe) */
.hero h1{font-size:clamp(38px,6.6vw,68px);letter-spacing:-.02em}

/* emphasis accent — styling only, no new wording */
.acc{color:var(--steel);font-style:normal;
  text-decoration:underline;text-decoration-color:var(--steel-dim);
  text-decoration-thickness:2px;text-underline-offset:8px}

/* 3D: service card tilt (JS sets --rx/--ry; CSS-only lift fallback on hover) */
section[aria-labelledby="wwd"]{perspective:1200px}
.entry{transform:rotateX(var(--rx,0)) rotateY(var(--ry,0)) translateZ(0);
  transform-style:preserve-3d;will-change:transform;
  transition:transform .3s ease,box-shadow .3s ease,padding-left .35s ease}
.entry:hover{box-shadow:0 18px 44px -18px rgba(0,0,0,.65)}
@media (prefers-reduced-motion:reduce){.entry{transition:padding-left .35s ease;transform:none!important}}

/* 3D: hero depth layers (JS parallax on fine pointers only) */
.hero{perspective:900px}
.hero .metaline,.hero h1,.hero .lede,.hero .btnrow{
  transform:translate3d(var(--px,0),var(--py,0),0);transition:transform .25s ease-out}
@media (prefers-reduced-motion:reduce){.hero .metaline,.hero h1,.hero .lede,.hero .btnrow{transform:none!important}}

/* 3D: portrait lift */
.portrait{perspective:800px}
.portrait img{transition:transform .4s ease,box-shadow .4s ease}
.portrait:hover img{transform:rotateY(-4deg) translateZ(14px);
  box-shadow:-14px 18px 40px -16px rgba(0,0,0,.7),0 0 0 1px var(--steel-dim)}
@media (prefers-reduced-motion:reduce){.portrait:hover img{transform:none;box-shadow:none}}

/* stats numerals: soft extruded depth */
.stat-num{text-shadow:0 1px 0 #2b3947,0 2px 0 #26313d,0 3px 0 #212a35,0 6px 14px rgba(0,0,0,.5)}

/* reveals: slight z-depth entry */
.js-anim .reveal{transform:translateY(16px) perspective(700px) rotateX(3deg)}
.js-anim .reveal.in{transform:none}

/* ============ v1.2b minimal living background ============ */

/* drifting ledger dot-grid, whole site, barely-there */
body{position:relative}
body::before{content:"";position:fixed;inset:-60%;z-index:0;pointer-events:none;
  background-image:radial-gradient(circle, #7FA6C4 1px, transparent 1.5px);
  background-size:34px 34px;opacity:.045;
  animation:griddrift 90s linear infinite}
@keyframes griddrift{from{transform:translate3d(0,0,0)}to{transform:translate3d(34px,34px,0)}}

/* one slow-breathing steel glow behind the hero */
.hero{position:relative}
.hero::before{content:"";position:absolute;top:-30%;right:-15%;z-index:-1;pointer-events:none;
  width:60vw;height:60vw;max-width:720px;max-height:720px;border-radius:50%;
  background:radial-gradient(circle, rgba(127,166,196,.10), transparent 62%);
  animation:breathe 9s ease-in-out infinite alternate}
@keyframes breathe{from{opacity:.5;transform:scale(.94)}to{opacity:1;transform:scale(1.05)}}

/* content sits above the grid */
.wrap{position:relative;z-index:1}

@media (prefers-reduced-motion:reduce){
  body::before{animation:none}
  .hero::before{animation:none;opacity:.6}
}

/* ============ v1.3 unification (inner pages) ============ */
:root{
  --ink:#0a1220; --panel:#0e1930; --line:rgba(233,237,243,.14);
  --bone:#e9edf3; --slate:#8a94a6; --steel:#5b9bd5; --steel-dim:#3d6b96;
  --serif:'Inter Tight',-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  --sans:'Inter Tight',-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Consolas,Menlo,monospace;
}
h1,h2,h3,.wm-name{font-weight:600;letter-spacing:-.02em}
body{font-weight:300}

/* ============ v1.3.1 consistency layer ============ */
.wrap{max-width:none;width:min(1360px,92vw);padding:0}
main{padding-top:6.5rem}
.hero{padding-top:2rem}

nav{position:fixed;top:0;left:0;right:0;z-index:50;background:rgba(10,18,32,.55);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid rgba(233,237,243,.07)}
.nav-inner{width:min(1360px,92vw);margin-inline:auto;display:flex;justify-content:space-between;align-items:center;padding:1.3rem 0}
.logo.wordmark{display:inline-flex;flex-direction:column;gap:2px}
nav .wm-name{font-family:var(--sans);font-weight:600;font-size:1.02rem;letter-spacing:.16em;color:var(--bone);line-height:1}
nav .wm-sub{font-family:var(--mono);font-size:.5rem;letter-spacing:.52em;color:var(--steel)}
.nav-links{display:flex;gap:2.4rem;align-items:center}
.nav-links a{font-family:var(--mono);font-size:.62rem;letter-spacing:.24em;color:var(--bone);position:relative}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;width:100%;height:1px;background:var(--steel);transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.65,0,.35,1)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-links a.here{color:var(--steel)}
.nav-links a.cta{border:1px solid rgba(91,155,213,.5);padding:.55rem .95rem;border-radius:2px;color:var(--steel)}
.nav-links a.cta::after{display:none}
.nav-links a.cta:hover{background:rgba(91,155,213,.08)}
@media (max-width:760px){.nav-links{display:none}}

.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;pointer-events:none;z-index:99;border-radius:50%;transform:translate(-50%,-50%)}
.cursor-dot{width:6px;height:6px;background:var(--steel)}
.cursor-ring{width:36px;height:36px;border:1px solid rgba(91,155,213,.55);transition:width .3s,height .3s,background .3s}
.cursor-ring.is-hover{width:64px;height:64px;background:rgba(91,155,213,.1)}
@media (hover:none),(prefers-reduced-motion:reduce){.cursor-dot,.cursor-ring{display:none}}
#progress{position:fixed;top:0;left:0;height:2px;width:100%;z-index:60}
#progress i{display:block;height:100%;background:var(--steel);transform:scaleX(0);transform-origin:left}

footer{border-top:1px solid var(--line);padding:3rem 0 2rem;margin-top:20px}
.fwrap{width:min(1360px,92vw);margin-inline:auto}
.foot-top{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;margin-bottom:2.5rem}
.foot-top .col{display:flex;flex-direction:column;gap:.8rem}
.foot-top a{font-family:var(--mono);font-size:.6rem;letter-spacing:.24em;color:var(--slate);transition:color .3s}
.foot-top a:hover{color:var(--steel)}
.foot-legal{font-size:.72rem;color:var(--slate);max-width:72ch;line-height:1.8}
.foot-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:2rem;padding-top:1.6rem;border-top:1px solid var(--line);font-family:var(--mono);font-size:.55rem;letter-spacing:.24em;color:var(--slate)}

/* ============ v1.4 mobile navigation ============ */
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:2px;padding:.6rem .7rem;cursor:pointer}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--bone);margin:4px 0;transition:transform .3s,opacity .3s}
@media (max-width:760px){
  .nav-toggle{display:block}
  nav.open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:rgba(10,18,32,.97);border-bottom:1px solid var(--line);padding:1rem 4vw 1.5rem}
  nav.open .nav-links a{padding:.95rem 0;font-size:.72rem;opacity:1}
  nav.open .nav-links a.cta{margin-top:.8rem}
  nav.open .nav-toggle span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  nav.open .nav-toggle span:nth-child(2){opacity:0}
  nav.open .nav-toggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
}
