/* ============ TOKENS ============ */
:root{
  --ink:#0A0A0A;
  --ink-raised:#151412;
  --ink-card:#1A1815;
  --bone:#EFE9DD;
  --bone-dim:#E0D8C7;
  --paper:#FFFFFF;
  --brass:#B08D57;
  --brass-bright:#D0AB6E;
  --concrete:#938C80;
  --concrete-dim:#615B50;
  --line-brass:rgba(176,141,87,.30);
  --line-dark:rgba(255,255,255,.10);
  --line-light:rgba(10,10,10,.14);
  --shadow:0 30px 70px -25px rgba(0,0,0,.85);
  --maxw:1280px;
  --gut:clamp(20px,5vw,72px);
  --ff-display:"Big Shoulders Display",sans-serif;
  --ff-body:"Archivo",sans-serif;
  --ff-mono:"IBM Plex Mono",monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--ff-body);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--brass);color:var(--ink)}

/* grain overlay on dark */
body::before{
  content:"";position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============ TYPE HELPERS ============ */
.mono{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase}
.eyebrow{font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:var(--brass)}
.display{font-family:var(--ff-display);font-weight:800;line-height:.92;letter-spacing:-.01em;text-transform:uppercase}
.shell{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}

/* section number marker */
.sec-head{display:flex;align-items:baseline;gap:1.2rem;margin-bottom:2.6rem}
.sec-head .num{font-family:var(--ff-mono);font-size:.8rem;letter-spacing:.2em;color:var(--brass);padding-top:.3rem}
.sec-head .label{font-family:var(--ff-mono);font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--concrete)}
.rule{height:1px;background:var(--line-brass);flex:1;align-self:center}

/* ============ HEADER ============ */
header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem var(--gut);
  transition:background .35s ease, padding .35s ease, border-color .35s ease;
  border-bottom:1px solid transparent;
}
/* always-on top scrim so logo + nav read over bright hero imagery */
header::before{content:"";position:absolute;left:0;right:0;top:0;height:170px;z-index:-1;pointer-events:none;
  background:linear-gradient(180deg,rgba(10,10,10,.78) 0%,rgba(10,10,10,.4) 45%,rgba(10,10,10,0) 100%);
  transition:opacity .35s ease}
header.scrolled::before{opacity:0}
header.scrolled{background:rgba(10,10,10,.92);backdrop-filter:blur(10px);padding-block:.7rem;border-bottom-color:var(--line-brass)}
.brand{display:flex;align-items:center;gap:.95rem}
.brand .mark{height:124px;width:auto;flex:none;transition:height .35s ease}
.brand .wm{display:flex;flex-direction:column;font-family:var(--ff-display);text-transform:uppercase;line-height:.86}
.brand .wm-top{display:flex;justify-content:center;gap:.5em;font-weight:800;font-size:1.08rem;letter-spacing:.03em;color:var(--brass);transition:font-size .35s ease}
.brand .wm-main{font-weight:900;font-size:1.92rem;letter-spacing:.04em;color:var(--bone);transition:font-size .35s ease}
/* condense on scroll so the sticky header doesn't eat the viewport */
header.scrolled .mark{height:68px}
header.scrolled .wm-top{font-size:.78rem}
header.scrolled .wm-main{font-size:1.34rem}
nav.main{display:flex;align-items:center;gap:2rem}
nav.main a{font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bone);opacity:.8;transition:opacity .2s,color .2s}
nav.main a:hover{opacity:1;color:var(--brass-bright)}
.cta-btn{
  font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  background:var(--brass);color:var(--ink);font-weight:500;
  padding:.78rem 1.3rem;border:1px solid var(--brass);
  transition:background .2s,transform .2s;white-space:nowrap;cursor:pointer
}
.cta-btn:hover{background:var(--brass-bright);transform:translateY(-1px)}
.cta-btn.ghost{background:transparent;color:var(--brass);}
.cta-btn.ghost:hover{background:var(--brass);color:var(--ink)}
.hamb{display:none;background:none;border:none;color:var(--bone);cursor:pointer;flex-direction:column;gap:5px}
.hamb span{width:26px;height:2px;background:var(--bone);display:block;transition:.3s}

/* ============ HERO ============ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero .bg{position:absolute;inset:0;z-index:0}
.hero .bg img{width:100%;height:100%;object-fit:cover;filter:contrast(1.04) brightness(.82) grayscale(.12)}
.hero .bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,.55) 0%,rgba(10,10,10,.25) 40%,rgba(10,10,10,.92) 100%),
             linear-gradient(90deg,rgba(10,10,10,.7) 0%,rgba(10,10,10,0) 55%)}
.hero .inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(3rem,8vh,7rem);padding-top:9rem}
.hero .eyebrow{display:inline-block;margin-bottom:1.6rem;background:var(--brass);color:var(--ink);padding:.55rem .9rem;letter-spacing:.2em}
.hero h1{font-family:var(--ff-display);font-weight:900;text-transform:uppercase;
  font-size:clamp(3.2rem,11vw,9.5rem);line-height:.86;letter-spacing:-.015em;color:var(--paper);
  text-shadow:0 2px 40px rgba(0,0,0,.5)}
.hero h1 .br{color:var(--brass)}
.hero .sub{max-width:46ch;margin-top:1.8rem;font-size:1.12rem;color:var(--bone);opacity:.9}
.hero .actions{margin-top:2.4rem;display:flex;gap:1rem;flex-wrap:wrap}
.hero .scrolldown{position:absolute;bottom:1.6rem;right:var(--gut);z-index:2;display:flex;align-items:center;gap:.6rem;color:var(--concrete)}
.hero .scrolldown .mono{font-size:.62rem}
.hero .scrolldown .arrow{width:1px;height:38px;background:var(--brass);position:relative;animation:dropline 2.4s ease-in-out infinite}
@keyframes dropline{0%,100%{transform:scaleY(.4);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}}

/* corner registration ticks */
.regtick{position:absolute;z-index:3;width:18px;height:18px;border:1px solid var(--line-brass)}
.regtick.tl{top:84px;left:18px;border-right:0;border-bottom:0}
.regtick.tr{top:84px;right:18px;border-left:0;border-bottom:0}
.regtick.bl{bottom:18px;left:18px;border-right:0;border-top:0}
.regtick.br{bottom:18px;right:18px;border-left:0;border-top:0}

/* ============ SECTION BASE ============ */
section{position:relative}
.pad{padding-block:clamp(5rem,11vh,9rem)}
.light{background:var(--bone);color:var(--ink)}
.light .eyebrow{color:#9A6E2E}
.light .sec-head .label{color:var(--concrete-dim)}
.light .rule{background:var(--line-light)}

/* ============ ABOUT (01) ============ */
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.about h2{font-family:var(--ff-display);font-weight:800;text-transform:uppercase;font-size:clamp(2.4rem,5vw,4.2rem);line-height:.94;letter-spacing:-.01em}
.about h2 .br{color:#9A6E2E}
.about p{margin-top:1.4rem;max-width:54ch;font-size:1.05rem;color:#3A352D}
.about p strong{color:#1A1610;font-weight:700}
.about .pull{font-family:var(--ff-display);font-weight:700;font-size:clamp(1.5rem,2.7vw,2.15rem);line-height:1.06;text-transform:none;letter-spacing:0;color:#1A1610;border-left:3px solid var(--brass);padding-left:1.15rem;margin:2.1rem 0;max-width:26ch}
.values{margin-top:2.4rem;display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--line-light)}
.values div{padding:1.1rem .2rem;border-bottom:1px solid var(--line-light);font-family:var(--ff-display);font-weight:700;font-size:1.5rem;text-transform:uppercase;letter-spacing:.01em;display:flex;align-items:center;gap:.7rem}
.values div span{font-family:var(--ff-mono);font-size:.7rem;color:#9A6E2E;font-weight:400}
.about .portrait{position:sticky;top:112px;aspect-ratio:4/5;background:#D8D0BF;overflow:hidden;border:1px solid var(--line-light)}
.about .portrait .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;text-align:center;flex-direction:column;gap:.6rem;color:#8A8270;font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;padding:2rem}
.about .portrait .ph svg{width:46px;height:46px;opacity:.5}
.about .portrait img.photo{width:100%;height:100%;object-fit:cover}
.about .stamp{position:absolute;bottom:1rem;left:1rem;font-family:var(--ff-mono);font-size:.62rem;letter-spacing:.2em;color:#9A6E2E;text-transform:uppercase}

/* ============ SERVICES (02) — big-type split index ============ */
.svc-list{display:flex;flex-direction:column;border-top:1px solid var(--line-brass)}
.svc{display:grid;grid-template-columns:clamp(2.6rem,6vw,5.5rem) minmax(0,1fr) auto auto;
  gap:clamp(1rem,3vw,2.6rem);align-items:baseline;
  padding:clamp(1.3rem,2.6vw,2.3rem) 0;border-bottom:1px solid var(--line-brass);
  transition:padding .3s,background .3s;position:relative}
.svc:hover{background:linear-gradient(90deg,rgba(176,141,87,.08),transparent);padding-left:1rem}
.svc .snum{font-family:var(--ff-display);font-weight:800;font-size:clamp(1.7rem,4.5vw,3.4rem);
  line-height:1;color:var(--brass);opacity:.55;transition:opacity .3s}
.svc:hover .snum{opacity:1}
.svc h3{font-family:var(--ff-display);font-weight:800;font-size:clamp(1.9rem,4.6vw,3.5rem);
  text-transform:uppercase;line-height:.9;letter-spacing:-.01em;color:var(--bone)}
.svc:hover h3{color:var(--paper)}
.svc .desc{justify-self:end;text-align:right;align-self:center;color:var(--concrete);font-size:.95rem;max-width:32ch}
.svc .arr{align-self:center;color:var(--brass);font-size:1.5rem;transition:transform .3s}
.svc:hover .arr{transform:translateX(6px)}

/* ============ FEATURED TESTIMONIAL — light interstitial, centered ============ */
.feature-quote{background:var(--paper);color:var(--ink);padding-block:clamp(4.5rem,10vh,8rem);border-block:1px solid var(--line-light);text-align:center}
.feature-quote .fq-mark{font-family:var(--ff-display);font-weight:900;font-size:clamp(4.5rem,10vw,8rem);line-height:.7;color:#9A6E2E;opacity:.32;margin-bottom:.3rem}
.feature-quote .eyebrow{display:block;margin-bottom:1.8rem;color:#9A6E2E}
.feature-quote .fq-pull{font-family:var(--ff-display);font-weight:800;text-transform:uppercase;
  font-size:clamp(2.4rem,6.2vw,5.4rem);line-height:.92;letter-spacing:-.015em;color:var(--ink);max-width:20ch;margin-inline:auto}
.feature-quote .fq-pull .br{color:#9A6E2E}
.feature-quote .fq-body{margin:2.4rem auto 0;max-width:62ch}
.feature-quote .fq-body p{color:#3A352D;font-size:1.05rem;margin-top:1.1rem}
.feature-quote .fq-body p:first-child{margin-top:0}
.feature-quote .fq-attr{margin:2.6rem auto 0;padding-top:1.6rem;border-top:1px solid var(--line-light);display:flex;flex-direction:column;align-items:center;gap:.35rem;max-width:62ch}
.feature-quote .fq-name{font-family:var(--ff-display);font-weight:700;font-size:1.5rem;text-transform:uppercase;letter-spacing:.01em;color:#1A1610}
.feature-quote .fq-role{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:#9A6E2E}

/* ============ HERO 1B — WHAT TO EXPECT (cinematic) ============ */
.expect{position:relative;overflow:hidden;display:flex;align-items:center;min-height:84svh}
.expect .bg{position:absolute;inset:0;z-index:0}
.expect .bg img{width:100%;height:100%;object-fit:cover;filter:contrast(1.05) brightness(.72) grayscale(.12)}
.expect .bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(10,10,10,.5) 0%,rgba(10,10,10,.38) 45%,rgba(10,10,10,.8) 100%),
             linear-gradient(90deg,rgba(10,10,10,.7) 0%,rgba(10,10,10,.1) 62%,rgba(10,10,10,0) 100%)}
.expect .inner{position:relative;z-index:2;width:100%;padding-block:clamp(3.5rem,9vh,7rem)}
.expect .eyebrow{display:inline-block;background:var(--brass);color:var(--ink);padding:.5rem .85rem;letter-spacing:.2em;margin-bottom:1.4rem}
.expect h2{font-family:var(--ff-display);font-weight:900;text-transform:uppercase;
  font-size:clamp(2.8rem,8vw,7rem);line-height:.86;letter-spacing:-.015em;color:var(--paper)}
.expect h2 .br{color:var(--brass)}
.expect .lede{max-width:48ch;margin-top:1.4rem;font-size:1.12rem;color:var(--bone);opacity:.9}
.expect .lede-emph{max-width:40ch;margin-top:1.1rem;font-family:var(--ff-display);font-weight:700;
  text-transform:none;letter-spacing:0;font-size:clamp(1.35rem,2.4vw,2rem);line-height:1.12;color:var(--paper)}
.expect .lede-emph .br{color:var(--brass-bright)}
.expect .pillars{margin-top:clamp(2.4rem,5vw,4rem);display:grid;grid-template-columns:repeat(3,1fr);
  gap:0;border-top:1px solid var(--line-brass)}
.expect .pillar{padding:1.8rem clamp(1rem,2.2vw,2rem) 0 0;border-right:1px solid var(--line-brass)}
.expect .pillar:last-child{border-right:0;padding-right:0}
.expect .pillar .pnum{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.2em;color:var(--brass)}
.expect .pillar h3{font-family:var(--ff-display);font-weight:800;text-transform:uppercase;
  font-size:clamp(1.3rem,2.2vw,1.75rem);line-height:.98;letter-spacing:-.005em;color:var(--paper);margin-top:.8rem}
.expect .pillar p{color:var(--bone);opacity:.78;font-size:.96rem;margin-top:.7rem;max-width:30ch}

/* ============ GALLERY (03) ============ */
.filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2.4rem}
.filters button{font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  background:transparent;color:var(--concrete);border:1px solid var(--line-dark);padding:.6rem 1.05rem;cursor:pointer;transition:.2s}
.filters button:hover{color:var(--bone);border-color:var(--line-brass)}
.filters button.active{background:var(--brass);color:var(--ink);border-color:var(--brass)}
.masonry{column-count:3;column-gap:14px}
@media(max-width:900px){.masonry{column-count:2}}
@media(max-width:560px){.masonry{column-count:1}}
.tile{break-inside:avoid;margin-bottom:14px;position:relative;overflow:hidden;cursor:pointer;background:var(--ink-raised)}
.tile img{width:100%;filter:grayscale(.2) contrast(1.04);transition:filter .45s,transform .6s}
.tile:hover img{filter:grayscale(0);transform:scale(1.05)}
.tile .ov{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1rem;
  background:linear-gradient(0deg,rgba(10,10,10,.85),transparent 60%);opacity:0;transition:opacity .35s}
.tile:hover .ov{opacity:1}
.tile .ov .cat{font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.2em;color:var(--brass-bright);text-transform:uppercase}
.tile .ov .cap{font-family:var(--ff-body);font-size:.92rem;color:var(--paper);margin-top:.2rem}
.tile.hide{display:none}
/* homepage "view full gallery" cta */
.gallery-cta{text-align:center;margin-top:3rem}
.gallery-cta .count{display:block;font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--concrete);margin-top:1rem}

/* ============ GALLERY PAGE INTRO ============ */
.page-intro{padding-top:10rem;padding-bottom:.5rem}
.page-intro .back{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--brass);display:inline-block;margin-bottom:1.4rem}
.page-intro .back:hover{color:var(--brass-bright)}
.page-intro h1{font-family:var(--ff-display);font-weight:900;text-transform:uppercase;font-size:clamp(2.8rem,8vw,6rem);line-height:.88;letter-spacing:-.01em}
.page-intro h1 .br{color:var(--brass)}
.page-intro p{color:var(--concrete);margin-top:1.1rem;max-width:52ch}

/* ============ TESTIMONIALS (04) — light · field-notes cards ============ */
.quotes{display:flex;flex-direction:column;gap:clamp(1.5rem,3vw,2.4rem);max-width:var(--maxw);margin-inline:auto}
.quote{
  position:relative;overflow:hidden;
  display:grid;grid-template-columns:minmax(190px,250px) 1fr;
  gap:clamp(1.4rem,3.4vw,3.6rem);
  background:var(--paper);
  border:1px solid var(--line-light);border-left:3px solid var(--brass);
  padding:clamp(1.7rem,3vw,3.1rem) clamp(1.5rem,3vw,3.3rem);
  box-shadow:0 26px 60px -40px rgba(0,0,0,.45);
}
.quote::after{ /* ghost quotation watermark */
  content:"\201D";position:absolute;top:-.12em;right:.06em;pointer-events:none;
  font-family:var(--ff-display);font-weight:900;line-height:1;
  font-size:clamp(7rem,15vw,13rem);color:#9A6E2E;opacity:.07;
}
.quote .meta{position:relative;z-index:1}
.quote .meta .idx{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.22em;color:var(--brass)}
.quote .meta .qm{display:block;font-family:var(--ff-display);font-weight:900;font-size:3.4rem;line-height:.55;color:#9A6E2E;margin:.5rem 0 0}
.quote .meta .name{font-family:var(--ff-display);font-weight:800;text-transform:uppercase;font-size:clamp(1.5rem,2.1vw,2rem);line-height:.95;letter-spacing:-.005em;color:#1A1610;margin-top:1.05rem}
.quote .meta .role{font-family:var(--ff-mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:#9A6E2E;margin-top:.55rem;line-height:1.5}
.quote .body{position:relative;z-index:1;max-width:60ch}
.quote .body p{font-size:1.05rem;line-height:1.62;color:#3A352D;margin-top:1rem}
.quote .body p:first-child{margin-top:0}
.quote .body .lede{font-family:var(--ff-display);font-weight:700;text-transform:none;letter-spacing:0;font-size:clamp(1.4rem,2.3vw,1.95rem);line-height:1.1;color:#1A1610}
.quote .body strong.hl{font-weight:700;color:#1A1610;background:linear-gradient(transparent 62%,rgba(176,141,87,.22) 0)}

/* ============ CONTACT (05) ============ */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.contact h2{font-family:var(--ff-display);font-weight:700;text-transform:none;font-size:clamp(1.8rem,3.6vw,2.9rem);line-height:1.06;letter-spacing:-.005em;max-width:20ch}
.contact h2 .br{color:var(--brass)}
.cinfo{margin-top:2rem}
.cinfo .row{padding:1.1rem 0;border-bottom:1px solid var(--line-dark)}
.cinfo .row .k{font-family:var(--ff-mono);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass)}
.cinfo .row .v{font-size:1.15rem;margin-top:.3rem;color:var(--bone)}
.cinfo .row .v a:hover{color:var(--brass-bright)}
.badges{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:1.6rem}
.badge{font-family:var(--ff-mono);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);border:1px solid var(--line-brass);padding:.5rem .8rem}
form{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
form .full{grid-column:1/-1}
label{display:block;font-family:var(--ff-mono);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--concrete);margin-bottom:.45rem}
input,select,textarea{width:100%;background:var(--ink-raised);border:1px solid var(--line-dark);color:var(--bone);
  font-family:var(--ff-body);font-size:1rem;padding:.85rem .9rem;transition:border-color .2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--brass)}
textarea{min-height:130px;resize:vertical}
.submit{font-family:var(--ff-mono);font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;background:var(--brass);color:var(--ink);
  border:none;padding:1.05rem;font-weight:500;cursor:pointer;transition:background .2s}
.submit:hover{background:var(--brass-bright)}
.turnstile-note{font-family:var(--ff-mono);font-size:.6rem;color:var(--concrete-dim);letter-spacing:.1em;text-transform:uppercase}
.hp{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none}
.cf-turnstile{min-height:65px}
.form-status{font-family:var(--ff-body);font-size:.92rem;line-height:1.4;margin-top:-.2rem}
.form-status:empty{display:none}
.form-status.is-ok{color:var(--brass-bright)}
.form-status.is-err{color:#e0796b}

/* ============ FOOTER ============ */
footer{border-top:1px solid var(--line-brass);padding-block:3.5rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;align-items:start}
footer .wm{font-family:var(--ff-display);font-weight:900;font-size:1.7rem;text-transform:uppercase;line-height:.85}
footer .wm small{display:block;font-family:var(--ff-mono);font-weight:400;font-size:.56rem;letter-spacing:.3em;color:var(--brass);margin-top:.3rem}
footer .col .k{font-family:var(--ff-mono);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);margin-bottom:.8rem}
footer .col a,footer .col p{display:block;color:var(--concrete);font-size:.95rem;margin-bottom:.4rem}
footer .col a:hover{color:var(--bone)}
.foot-bottom{margin-top:3rem;padding-top:1.5rem;border-top:1px solid var(--line-dark);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.foot-bottom .mono{color:var(--concrete-dim);font-size:.64rem}
.foot-bottom .mono a{color:var(--brass)}

/* ============ MOBILE STICKY BAR ============ */
.mobile-bar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1100;
  grid-template-columns:1fr 1fr;border-top:1px solid var(--brass)}
.mobile-bar a{padding:1.05rem;text-align:center;font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase}
.mobile-bar .call{background:var(--brass);color:var(--ink);font-weight:500}
.mobile-bar .msg{background:var(--ink-raised);color:var(--brass)}

/* ============ LIGHTBOX ============ */
.lb{position:fixed;inset:0;z-index:2000;background:rgba(10,10,10,.97);display:none;align-items:center;justify-content:center;padding:3rem}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:82vh;object-fit:contain;box-shadow:var(--shadow)}
.lb .cap{position:absolute;bottom:1.6rem;left:0;right:0;text-align:center;font-family:var(--ff-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--concrete)}
.lb .close{position:absolute;top:1.4rem;right:1.6rem;font-family:var(--ff-mono);font-size:.8rem;letter-spacing:.1em;color:var(--bone);cursor:pointer;background:none;border:1px solid var(--line-dark);padding:.5rem .9rem}
.lb .nav{position:absolute;top:50%;transform:translateY(-50%);font-family:var(--ff-display);font-size:2.4rem;color:var(--brass);cursor:pointer;background:none;border:none;padding:1rem}
.lb .prev{left:1rem}.lb .next{right:1rem}

/* ============ RESPONSIVE ============ */
@media(max-width:860px){
  nav.main{display:none}
  header .cta-btn.ghost{display:none}
  .hamb{display:flex}
  .about-grid,.contact-grid{grid-template-columns:1fr}
  .quote{grid-template-columns:1fr;gap:1.1rem}
  .quote .meta{display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem 1rem}
  .quote .meta .qm{display:none}
  .quote .meta .name{margin-top:0}
  .quote .meta .role{margin-top:0}
  .svc{grid-template-columns:clamp(2.2rem,11vw,3.4rem) 1fr auto;gap:1rem}
  .svc .desc{display:none}
  .expect .pillars{grid-template-columns:1fr;border-top:0}
  .expect .pillar{border-right:0;border-top:1px solid var(--line-brass);padding:1.4rem 0 0}
  .foot-grid{grid-template-columns:1fr}
  .mobile-bar{display:grid}
  body{padding-bottom:54px}
  .about .portrait{aspect-ratio:3/4;margin-top:2rem;position:static}
  .regtick{display:none}
  /* keep mobile logo at the size Josh approved */
  .brand .mark{height:96px}
  header.scrolled .mark{height:56px}
}

/* nav drawer (mobile) */
.drawer{position:fixed;inset:0;z-index:1050;background:var(--ink);display:none;flex-direction:column;align-items:center;justify-content:center;gap:2rem}
.drawer.open{display:flex}
.drawer a{font-family:var(--ff-display);font-weight:700;font-size:2.2rem;text-transform:uppercase;color:var(--bone)}
.drawer a:hover{color:var(--brass)}
.drawer .close{position:absolute;top:1.4rem;right:var(--gut);font-family:var(--ff-mono);color:var(--brass);cursor:pointer;background:none;border:none;font-size:.9rem;letter-spacing:.1em}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}
