
/* ---- Body font: Glacial Indifference, Regular only (no bold used) ---- */
@font-face{font-family:'Glacial Indifference';
  src:url('assets/fonts/GlacialIndifference-Regular.otf') format('opentype');
  font-weight:400;font-style:normal;font-display:swap}
/* Headings use the same Glacial Indifference font, larger and tracked. */
*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#2B2C2F; --ink-soft:#433e36; --mut:#544c3e;
  --bone:#FFFCF7; --cream:#FBF4E6; --sand:#F2EAD9; --stone:#EBE0CB;
  --champ:#C1B391; --bronze:#AC996D; --gold:#9a8550;
  --hair:rgba(43,44,47,.16); --hair-soft:rgba(43,44,47,.10);
  --r:3px;
  --display:'Glacial Indifference',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --body:'Glacial Indifference',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --wrap:1280px; --ease:cubic-bezier(.42,0,.06,1);
}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--body);background:var(--bone);color:var(--ink);
  line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  font-synthesis:none}
html.js body{opacity:0;transition:opacity .8s var(--ease)}
html.js body.loaded{opacity:1}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
ul{list-style:none}
::selection{background:var(--champ);color:var(--ink)}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

.wrap{max-width:var(--wrap);width:100%;margin:0 auto;padding:0 44px}
.section{padding:140px 0;position:relative}
.section--sand{background:var(--sand)}
.section--cream{background:var(--cream)}
.section--tight{padding:96px 0}
main{overflow:clip}

h1,h2,h3,h4{font-family:var(--display);font-weight:400;line-height:1.08;
  letter-spacing:0;text-wrap:balance}
h1{font-size:clamp(1.95rem,3.9vw,3.35rem);text-transform:uppercase;
  letter-spacing:.05em;line-height:1.22}
h2{font-size:clamp(1.5rem,2.75vw,2.25rem);text-transform:uppercase;
  letter-spacing:.06em;line-height:1.26}
h3{font-size:clamp(1.1rem,1.8vw,1.4rem);text-transform:uppercase;
  letter-spacing:.07em;line-height:1.36}
h4{font-size:.95rem;text-transform:uppercase;letter-spacing:.085em;
  line-height:1.5;font-weight:400}
em{font-style:normal}
b,strong{font-weight:400}
p{font-size:.98rem;letter-spacing:.005em;line-height:1.72}
.display-em{color:var(--gold)}

.kicker{font-family:var(--body);font-size:.73rem;font-weight:400;
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold)}
.kicker.center{text-align:center;display:block}
.hero .kicker{white-space:nowrap}

.lead{font-size:clamp(1rem,1.15vw,1.12rem);line-height:1.7;letter-spacing:.005em;
  color:var(--ink-soft);font-weight:400}
.muted{color:var(--mut)}
.measure{max-width:58ch}

/* ---- buttons & links ---- */
.btn{position:relative;isolation:isolate;overflow:hidden;display:inline-flex;
  align-items:center;gap:13px;font-family:var(--body);font-size:.76rem;
  font-weight:400;letter-spacing:.16em;text-transform:uppercase;
  padding:21px 40px;border-radius:2px;cursor:pointer;border:1px solid transparent;
  white-space:nowrap;
  transition:color .5s var(--ease),border-color .5s var(--ease),transform .55s var(--ease)}
.btn::before{content:"";position:absolute;inset:0;z-index:-1;transform:scaleX(0);
  transform-origin:left;transition:transform .62s cubic-bezier(.62,0,.04,1)}
.btn:hover::before,.btn:focus-visible::before{transform:scaleX(1)}
.btn .arw{transition:transform .5s var(--ease)}
.btn:hover .arw{transform:translateX(7px)}
.btn-solid{background:var(--ink);color:var(--bone)}
.btn-solid::before{background:var(--champ)}
.btn-solid:hover,.btn-solid:focus-visible{color:var(--ink)}
.btn-outline{background:transparent;border-color:var(--hair);color:var(--ink)}
.btn-outline::before{background:var(--ink)}
.btn-outline:hover,.btn-outline:focus-visible{color:var(--bone);border-color:var(--ink)}
.btn-light{background:var(--bone);color:var(--ink)}
.btn-light::before{background:var(--champ)}
.btn-light:hover,.btn-light:focus-visible{color:var(--ink)}
.btn-ghost{background:transparent;border-color:rgba(255,252,247,.5);color:var(--bone)}
.btn-ghost::before{background:var(--bone)}
.btn-ghost:hover,.btn-ghost:focus-visible{color:var(--ink);border-color:var(--bone)}
.tlink{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);
  font-size:.8rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;
  padding-bottom:6px;position:relative;color:var(--ink)}
.tlink::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:var(--ink);transform-origin:right;transition:transform .4s var(--ease)}
.tlink:hover::after{transform:scaleX(0);transform-origin:left}
.tlink .arw{transition:transform .3s var(--ease)}
.tlink:hover .arw{transform:translateX(5px)}

/* ---- scroll progress + back to top ---- */
.progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--bronze);
  z-index:120;transition:width .1s linear}
.to-top{position:fixed;right:26px;bottom:26px;width:50px;height:50px;border-radius:50%;
  background:var(--ink);color:var(--bone);border:none;cursor:pointer;z-index:95;
  display:flex;align-items:center;justify-content:center;font-size:1rem;
  opacity:0;transform:translateY(14px) scale(.85);pointer-events:none;
  transition:opacity .4s var(--ease),transform .4s var(--ease),background .3s}
.to-top.show{opacity:1;transform:none;pointer-events:auto}
.to-top:hover{background:var(--bronze);color:var(--ink)}

/* ---- header ---- */
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:var(--bone);
  padding:10px 18px;z-index:300}
.skip:focus{left:8px;top:8px}
.site-header{position:fixed;top:0;left:0;right:0;z-index:90;
  border-bottom:1px solid transparent;transition:background .4s var(--ease),
  border-color .4s,box-shadow .4s}
.header-inner{display:flex;align-items:center;justify-content:space-between;
  height:96px;gap:30px;transition:height .4s var(--ease)}
.brand{display:block;flex:none;position:relative;z-index:3}
.brand img{height:39px;width:auto;transition:height .4s var(--ease)}
.nav{display:flex;gap:8px;margin-left:auto}
.nav a{font-size:.73rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;
  padding:13px 17px;position:relative;color:var(--ink)}
.nav a::after{content:"";position:absolute;left:17px;right:17px;bottom:9px;height:1px;
  background:var(--bronze);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease)}
.nav a:hover::after,.nav a[aria-current="page"]::after{transform:scaleX(1)}
.header-cta{margin-left:8px}
.site-header.scrolled{background:rgba(255,252,247,.92);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-color:var(--hair-soft);box-shadow:0 10px 40px -30px rgba(0,0,0,.5)}
.site-header.scrolled .header-inner{height:74px}
.site-header.scrolled .brand img{height:33px}
.brand .logo-l{display:none}
.header-overlay:not(.scrolled) .logo-d{display:none}
.header-overlay:not(.scrolled) .logo-l{display:block}
.header-overlay:not(.scrolled) .nav a{color:var(--bone)}
.header-overlay:not(.scrolled) .nav a::after{background:var(--bone)}
.header-overlay:not(.scrolled) .header-cta{color:var(--bone);
  border-color:rgba(255,252,247,.55)}
.header-overlay:not(.scrolled) .header-cta::before{background:var(--bone)}
.header-overlay:not(.scrolled) .header-cta:hover{color:var(--ink);
  border-color:var(--bone)}
.header-overlay:not(.scrolled) .menu-toggle span{background:var(--bone)}

.menu-toggle{display:none;width:48px;height:48px;background:none;border:none;
  cursor:pointer;position:relative;z-index:3;margin-right:-12px}
.menu-toggle span{position:absolute;left:13px;right:13px;height:1.5px;background:var(--ink);
  transition:transform .45s var(--ease),top .35s var(--ease),bottom .35s var(--ease)}
.menu-toggle span:nth-child(1){top:19px}
.menu-toggle span:nth-child(2){bottom:19px}
body.menu-open .menu-toggle span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
body.menu-open .menu-toggle span:nth-child(2){bottom:auto;top:50%;transform:translateY(-50%) rotate(-45deg)}
/* When the mobile menu is open, the bg is bone (white) — force the close X dark */
body.menu-open .menu-toggle span,
body.menu-open .header-overlay:not(.scrolled) .menu-toggle span{background:var(--ink)}

.mobile-nav{position:fixed;inset:0;z-index:80;background:var(--bone);color:var(--ink);
  display:flex;flex-direction:column;padding:138px 40px 52px;
  clip-path:inset(0 0 100% 0);transition:clip-path .68s var(--ease);visibility:hidden}
body.menu-open .mobile-nav{clip-path:inset(0 0 0 0);visibility:visible}
.mobile-nav nav{display:flex;flex-direction:column}
.mobile-nav a.m-link{font-family:var(--display);font-size:1.8rem;font-weight:400;
  letter-spacing:-.025em;color:var(--ink);padding:20px 2px;
  border-bottom:1px solid var(--hair-soft);
  transition:color .3s var(--ease),padding-left .4s var(--ease)}
.mobile-nav a.m-link:first-child{border-top:1px solid var(--hair-soft)}
.mobile-nav a.m-link[aria-current="page"]{color:var(--gold)}
.mobile-nav a.m-link:active{color:var(--gold);padding-left:12px}
.mobile-nav .m-foot{margin-top:auto;padding-top:46px}
.mobile-nav .m-foot .m-lab{font-size:.68rem;font-weight:400;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.mobile-nav .m-foot a{display:block;font-size:1.12rem;color:var(--ink);padding:3px 0}
.mobile-nav .m-foot span{display:block;font-size:.9rem;color:var(--mut);margin-top:10px}

/* ---- hero (full-bleed) ---- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  overflow:hidden;background:#141310;padding:132px 0 96px}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:50% 30%;
  transform:scale(1.05);animation:heroZoom 22s var(--ease) both}
@keyframes heroZoom{to{transform:scale(1.17)}}
.hero-veil{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(108deg,rgba(17,16,13,.88) 0%,rgba(17,16,13,.64) 32%,
      rgba(17,16,13,.40) 60%,rgba(17,16,13,.50) 100%),
    linear-gradient(180deg,rgba(17,16,13,.52) 0%,rgba(17,16,13,.06) 26%,
      rgba(17,16,13,.06) 60%,rgba(17,16,13,.74) 100%)}
.hero .wrap{position:relative;z-index:2;width:100%}
.hero-inner{max-width:1140px}
.hero .kicker{color:var(--champ)}
.hero h1{margin:26px 0 0;color:var(--bone);
  font-size:clamp(2.05rem,4.3vw,3.5rem);letter-spacing:.05em;line-height:1.2}
.hero h1 .display-em{color:var(--champ)}
.hero .lead{margin-top:26px;max-width:880px;color:rgba(255,252,247,.85)}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:40px;align-items:center}
.hero-trust{margin-top:46px;padding-top:30px;
  border-top:1px solid rgba(255,252,247,.24);display:flex;gap:46px;flex-wrap:wrap}
.hero-trust .ht b{font-family:var(--display);font-size:1.06rem;font-weight:400;
  display:block;color:var(--bone)}
.hero-trust .ht span{font-size:.82rem;color:rgba(255,252,247,.62)}
.hero-scroll{position:absolute;left:0;right:0;bottom:26px;z-index:2;
  display:flex;flex-direction:column;align-items:center;gap:11px;
  font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,252,247,.72)}
.hero-scroll .sl{width:1px;height:56px;background:rgba(255,252,247,.30);
  position:relative;overflow:hidden}
.hero-scroll .sl::after{content:"";position:absolute;left:0;top:0;width:1px;
  height:42%;background:var(--champ);animation:scrollLine 2.6s var(--ease) infinite}
@keyframes scrollLine{0%{transform:translateY(-100%)}
  60%,100%{transform:translateY(238%)}}

/* ---- page hero (inner) ---- */
.page-hero{padding:200px 0 96px;position:relative;text-align:center}
.page-hero .crumb{font-size:.78rem;color:var(--mut);margin-bottom:22px;
  letter-spacing:.05em}
.page-hero .crumb a:hover{color:var(--gold)}
.page-hero .kicker{display:block;margin-bottom:34px}
.page-hero h1{max-width:900px;margin:0 auto}
.page-hero h1.h1-wide{max-width:none}
.page-hero .lead{margin:26px auto 0;max-width:56ch}
.page-hero-rule{width:1px;height:64px;background:var(--hair);margin:40px auto 0}

/* ---- image placeholder ---- */
.ph{position:relative;background:var(--stone);overflow:hidden;border-radius:var(--r);
  display:flex;align-items:center;justify-content:center}
.ph-in{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;
  padding:30px}
.ph-mono{width:46px;opacity:.62}
.ph-label{font-size:.68rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold)}
.ph-sub{font-family:var(--display);font-size:1.02rem;color:var(--mut);
  max-width:22ch;line-height:1.4}
.ph-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.arch{border-radius:50% 50% var(--r) var(--r) / 30% 30% var(--r) var(--r)}

/* ---- parallax wrap ---- */
.par{overflow:hidden;position:relative}
.par .ph{height:128%;position:absolute;top:-14%;left:0;right:0;will-change:transform;
  backface-visibility:hidden}

/* ---- section heading ---- */
.head-row{display:flex;justify-content:space-between;align-items:flex-end;
  gap:48px;margin-bottom:70px}
.head-row .htext{flex:1;min-width:0}
.head-row h2{margin-top:20px;font-size:clamp(1.5rem,2.3vw,2.1rem);
  white-space:nowrap}
.head-center{text-align:center;max-width:900px;margin:0 auto 74px}
.head-center h2{margin-top:20px}
.head-center p{margin-top:20px}
.head-center p,.head-center .lead{max-width:58ch;margin-left:auto;margin-right:auto}
.head-proc{max-width:1000px}
.head-proc .lead{max-width:56ch;margin-left:auto;margin-right:auto}
.head-wide{max-width:1000px}
.head-wide p{max-width:54ch;margin-left:auto;margin-right:auto}
.pl{display:inline-block;white-space:nowrap}
@media(max-width:768px){.head-proc,.head-wide{max-width:60ch}
  .pl{white-space:normal;display:inline}}

/* ---- two-col split ---- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.split.wide-left{grid-template-columns:1.06fr .94fr}
.split.wide-right{grid-template-columns:.94fr 1.06fr}
.stext .kicker{display:block;margin-bottom:22px}
.stext h2{margin-bottom:24px}
.stext p+p{margin-top:16px}
.stext .btn,.stext .tlink{margin-top:30px}

/* ---- marquee ---- */
.marquee{padding:22px 0;overflow:hidden}
.marquee-track{display:flex;gap:0;width:max-content;animation:scroll 38s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.mq-item{font-family:var(--display);font-size:clamp(.92rem,1.4vw,1.18rem);font-weight:400;
  white-space:nowrap;padding:0 30px;display:flex;align-items:center;
  gap:52px;color:var(--ink)}
.mq-item img{width:15px;opacity:.7}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---- stats ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{text-align:center;padding:0 22px;border-left:1px solid var(--hair-soft)}
.stat:first-child{border-left:none}
.stat .num{font-family:var(--display);font-size:clamp(2.9rem,5vw,4.3rem);
  font-weight:400;color:var(--bronze);line-height:1}
.stat .lab{margin-top:14px;font-size:.84rem;color:var(--mut);letter-spacing:.04em}
.num-star{font-size:.3em;color:var(--gold);vertical-align:.78em;margin-left:.06em}

/* ---- service cards (borderless) ---- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.svc-card{display:block;cursor:pointer}
.svc-card .svc-img{margin-bottom:22px}
.svc-card .svc-img .ph{aspect-ratio:3/4}
.svc-card .svc-img img,.svc-card .svc-img .ph{transition:transform .7s var(--ease)}
.svc-card:hover .svc-img .ph{transform:scale(1.035)}
@media(max-width:900px){.svc-grid{grid-template-columns:repeat(2,1fr);gap:46px 30px}}
@media(max-width:540px){.svc-grid{grid-template-columns:1fr}}
.svc-num{font-family:var(--display);font-size:1.05rem;color:var(--gold)}
.svc-card h3{margin:10px 0 12px;transition:color .3s}
.svc-card:hover h3{color:var(--gold)}
.svc-card p{font-size:1rem;color:var(--mut);max-width:42ch}
.svc-card .tlink{margin-top:20px}

/* ---- detailed service rows ---- */
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:78px;align-items:center;
  padding:84px 0;border-top:1px solid var(--hair-soft)}
.svc-row:first-child{border-top:none;padding-top:20px}
.svc-row.flip .svc-media{order:2}
.svc-row .tag{font-family:var(--display);font-size:1.05rem;color:var(--gold)}
.svc-row h3{margin:12px 0 18px;font-size:clamp(1.8rem,2.8vw,2.5rem);font-weight:400}
.svc-row .svc-media .ph{aspect-ratio:5/4}
.incl{margin-top:28px;display:grid;grid-template-columns:1fr 1fr;gap:13px 26px}
.incl li{display:flex;gap:11px;font-size:.95rem;color:var(--mut);align-items:flex-start}
.incl li::before{content:"";width:6px;height:6px;margin-top:8px;flex:none;
  background:var(--bronze);border-radius:50%}

/* ---- projects ---- */
.filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:54px;justify-content:center}
.filter button{font-family:var(--body);font-size:.78rem;font-weight:400;
  letter-spacing:.08em;text-transform:uppercase;padding:11px 22px;
  border:1px solid var(--hair);background:none;border-radius:100px;cursor:pointer;
  color:var(--mut);transition:.3s var(--ease)}
.filter button:hover{border-color:var(--ink);color:var(--ink)}
.filter button.active{background:var(--ink);border-color:var(--ink);color:var(--bone)}
.proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:48px 32px}
body.page-projects .proj-grid{grid-template-columns:repeat(4,1fr);gap:42px 24px}
@media(max-width:1100px){body.page-projects .proj-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){body.page-projects .proj-grid{grid-template-columns:1fr}}
.proj-card{display:block}
.proj-card .pwrap{overflow:hidden;border-radius:50% 50% var(--r) var(--r)/30% 30% var(--r) var(--r);
  position:relative}
.proj-card .ph{aspect-ratio:3/3.4;border-radius:0}
.proj-card .pview{position:absolute;left:0;right:0;bottom:0;padding:22px;
  background:linear-gradient(transparent,rgba(43,44,47,.55));color:var(--bone);
  font-size:.78rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;
  opacity:0;transform:translateY(8px);transition:.4s var(--ease)}
.proj-card:hover .pview{opacity:1;transform:none}
.proj-meta{padding:22px 4px 0}
.proj-meta .proj-cat{font-size:.7rem;font-weight:400;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold)}
.proj-meta h3{margin:9px 0 4px;font-size:1.3rem}
.proj-meta .loc{font-size:.88rem;color:var(--mut)}
.proj-card.hide{display:none}

/* ---- process ---- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
.step{position:relative;padding-top:40px}
.step::before{content:"";position:absolute;top:7px;left:0;right:0;height:1px;
  background:var(--hair)}
.step::after{content:"";position:absolute;top:6px;left:-9%;width:36px;height:3px;
  border-radius:2px;background:var(--bronze);opacity:0;
  animation:stepflow 4.4s linear infinite}
.step:nth-child(2)::after{animation-delay:1.1s}
.step:nth-child(3)::after{animation-delay:2.2s}
.step:nth-child(4)::after{animation-delay:3.3s}
@keyframes stepflow{0%{left:-9%;opacity:0}9%,91%{opacity:1}100%{left:100%;opacity:0}}
.step .dot{position:absolute;top:1px;left:0;width:13px;height:13px;border-radius:50%;
  background:var(--champ)}
.step .snum{font-family:var(--display);font-size:1rem;color:var(--gold)}
.step h4{margin:9px 0 12px}
.step p{font-size:.93rem;color:var(--mut)}

/* ---- values (airy) ---- */
.values{display:grid;grid-template-columns:repeat(4,1fr);gap:44px}
.value{position:relative;padding-top:30px;border-top:1px solid var(--hair)}
.value .vnum{font-family:var(--display);color:var(--gold);font-size:1.05rem}
.value h3{margin:14px 0 10px;font-size:1.15rem}
.value p{color:var(--mut);font-size:.96rem}

/* ---- quote ---- */
.quote{max-width:72rem;margin:0 auto;text-align:center}
.quote .qmono{width:40px;margin:0 auto 26px;opacity:.7}
.grev-badge{display:inline-flex;align-items:center;gap:12px;margin:0 auto 22px;
  padding:8px 16px;border:1px solid var(--line);border-radius:999px;background:var(--bone)}
.grev-badge .grev-stars{color:var(--bronze);letter-spacing:3px;font-size:.85rem}
.grev-badge .grev-meta{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mut)}
.grev-link{margin-top:30px;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase}
.grev-link a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--bronze);padding-bottom:2px;transition:color .25s,border-color .25s}
.grev-link a:hover{color:var(--bronze)}
.quote blockquote{font-family:var(--display);font-size:clamp(1.4rem,2.55vw,2.15rem);
  font-weight:400;line-height:1.46;letter-spacing:-.01em}
.quote blockquote .display-em{font-weight:400}
.quote .cite{margin-top:32px;font-size:.83rem;letter-spacing:.1em;text-transform:uppercase}
.quote .cite b{font-weight:400}
.quote .cite span{color:var(--mut)}
.qrow{display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.qcard{padding:46px 44px;background:var(--bone);border-radius:var(--r)}
.section--sand .qcard,.section--cream .qcard{background:var(--bone)}
.qcard .stars{color:var(--bronze);letter-spacing:4px;font-size:.78rem;margin-bottom:20px}
.qcard p{font-family:var(--display);font-size:1.3rem;line-height:1.5;font-weight:400}
.qcard .cite{margin-top:24px;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}
.qcard .cite b{font-weight:400}
.qcard .cite span{color:var(--mut)}

/* ---- people ---- */
.people{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.people-sm{max-width:1060px;margin-left:auto;margin-right:auto;gap:54px}
.person .ph{aspect-ratio:4/5}
.person .pwrap{margin-bottom:28px;overflow:hidden}
.person .role{color:var(--gold);font-size:.74rem;font-weight:400;
  letter-spacing:.18em;text-transform:uppercase}
.person h3{margin:14px 0 12px;font-size:1.3rem;font-weight:400}
.person p{font-size:1rem;color:var(--mut)}

/* ---- cta band ---- */
.cta-band{text-align:center;padding:0}
.cta-inner{padding:120px 0;border-top:1px solid var(--hair-soft)}
.cta-band h2{max-width:none;margin:22px auto 0;font-weight:400}
.cta-band .lead{margin:22px auto 0;max-width:64ch}
.cta-band .btn-row{margin-top:42px;display:flex;gap:16px;justify-content:center;
  flex-wrap:wrap}

/* ---- contact ---- */
.contact-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:80px;align-items:start}
.form{display:grid;gap:30px;margin-top:34px}
.field{display:flex;flex-direction:column;gap:9px}
.field label{font-size:.74rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ink-soft)}
.field .req{color:var(--bronze)}
.field input,.field select,.field textarea{font-family:var(--body);font-size:1.02rem;
  padding:11px 2px;border:none;border-bottom:1.5px solid var(--hair);
  background:transparent;color:var(--ink);transition:border-color .3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;
  border-color:var(--ink)}
.field textarea{resize:vertical;min-height:96px;line-height:1.6}
.field select{cursor:pointer}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.hp{position:absolute;left:-9999px}
.form-note{font-size:.82rem;color:var(--mut);line-height:1.55}
.form-ok{display:none;margin-top:34px;padding:34px 32px;background:var(--cream);
  border-radius:var(--r);border:1px solid var(--hair-soft)}
.form-ok.show{display:block}
.form-ok b{font-family:var(--display);font-size:1.4rem;font-weight:400;display:block;
  margin-bottom:8px}
.form-ok p{font-size:.97rem;color:var(--mut)}

.contact-card{background:var(--cream);border-radius:var(--r);padding:50px 46px;
  border:1px solid var(--hair-soft)}
.contact-card h3{margin-bottom:8px;font-weight:400}
.contact-card .cc-lead{font-size:.96rem;color:var(--mut);margin-bottom:14px}
.ctline{padding:22px 0;border-top:1px solid var(--hair-soft);display:block}
.ctline .cl-lab{font-size:.7rem;font-weight:400;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold);margin-bottom:7px}
.ctline .cl-val{font-size:1.08rem}
.ctline a.cl-val{transition:color .25s}
.ctline a.cl-val:hover{color:var(--gold)}

/* ---- faq ---- */
.faq{max-width:820px;margin:0 auto}
.faq-item{border-top:1px solid var(--hair-soft)}
.faq-item:last-child{border-bottom:1px solid var(--hair-soft)}
.faq-q{width:100%;text-align:left;background:none;border:none;cursor:pointer;
  font-family:var(--display);font-size:clamp(1.15rem,1.8vw,1.4rem);font-weight:400;
  color:var(--ink);padding:30px 50px 30px 0;position:relative;display:block}
.faq-q .pm{position:absolute;right:4px;top:50%;width:17px;height:17px;
  transform:translateY(-50%)}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;background:var(--bronze);
  transition:transform .35s var(--ease)}
.faq-q .pm::before{left:0;right:0;top:8px;height:1.5px}
.faq-q .pm::after{top:0;bottom:0;left:8px;width:1.5px}
.faq-item.open .pm::after{transform:scaleY(0)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.faq-a-in{padding:0 50px 32px 0;color:var(--mut);font-size:1.02rem}

/* ---- service area ---- */
.area-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:64px;align-items:center}
.suburbs{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.suburbs span{font-size:.85rem;padding:9px 17px;border:1px solid var(--hair);
  border-radius:100px;color:var(--mut)}

/* ---- footer ---- */
.site-footer{background:var(--stone);color:var(--ink);padding:96px 0 38px}
.foot-top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.25fr;gap:54px;
  padding-bottom:60px;border-bottom:1px solid var(--hair-soft)}
.foot-brand img{height:38px;margin-bottom:24px}
.foot-brand p{color:var(--mut);font-size:.97rem;max-width:32ch}
.foot-col h4{font-family:var(--body);font-size:.82rem;font-weight:400;
  letter-spacing:.03em;color:var(--gold);margin-bottom:20px}
.foot-col a,.foot-col p{display:block;color:var(--ink-soft);font-size:.97rem;
  padding:5px 0;transition:color .25s}
.site-footer h4,.site-footer p,.site-footer a{text-transform:none}
.foot-col a:hover{color:var(--gold)}
.foot-bot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;
  padding-top:30px;font-size:.82rem;color:var(--mut)}
.foot-bot a:hover{color:var(--gold)}

/* ---- reveal ---- */
html.js .rv{opacity:0;transform:translateY(34px);
  transition:opacity 1s var(--ease),transform 1s var(--ease)}
html.js .rv.in{opacity:1;transform:none}
html.js .rv-img{opacity:0;transform:scale(1.04);
  transition:clip-path 1.15s var(--ease),transform 1.4s var(--ease)}
html.js .rv-img.in{opacity:1;transform:scale(1)}
html.js .rv-line{clip-path:inset(-12% 0 102% 0);transform:translateY(8px);
  transition:clip-path 1.15s var(--ease),transform 1.15s var(--ease)}
html.js .rv-line.in{clip-path:inset(-12% 0 -12% 0);transform:none}
html.js .d1{transition-delay:.12s}
html.js .d2{transition-delay:.24s}
html.js .d3{transition-delay:.36s}

/* ---- responsive ---- */
@media(max-width:1040px){
  .split,.split.wide-left,.split.wide-right,.contact-grid,.area-grid{
    grid-template-columns:1fr;gap:48px}
  .stats{grid-template-columns:repeat(2,1fr);gap:48px 0}
  .stat:nth-child(3){border-left:none}
  .process,.values{grid-template-columns:repeat(2,1fr);gap:48px 40px}
  .svc-row,.svc-row.flip .svc-media{grid-template-columns:1fr;order:0}
  .svc-row .svc-media{order:-1}
  .people{grid-template-columns:1fr;gap:56px}
  .foot-top{grid-template-columns:1fr 1fr;gap:42px}
}
@media(max-width:740px){
  .wrap{padding:0 24px}
  .hero .kicker{font-size:.57rem;letter-spacing:.12em}
  .section{padding:92px 0}
  .section--tight{padding:72px 0}
  .hero{padding:120px 0 84px}
  .page-hero{padding:158px 0 72px}
  .nav,.header-cta{display:none}
  .menu-toggle{display:flex}
  .proj-grid,.qrow,.incl,.field-2{grid-template-columns:1fr}
  .proj-grid{gap:42px}
  .stats{grid-template-columns:1fr;gap:40px}
  .stat{border-left:none}
  .head-row{flex-direction:column;align-items:flex-start;gap:6px}
  .head-row h2{white-space:normal}
  .foot-top{grid-template-columns:1fr;gap:38px}
  .hero-trust{gap:24px 30px}
  .to-top{right:18px;bottom:18px}
}
/* ---- lightbox ---- */
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(16,15,13,.97);
  display:flex;align-items:center;justify-content:center;
  opacity:0;visibility:hidden;transition:opacity .45s var(--ease),visibility .45s}
.lightbox.open{opacity:1;visibility:visible}
.lb-stage{position:relative;display:flex;align-items:center;justify-content:center}
.lb-stage img{max-width:88vw;max-height:84vh;width:auto;height:auto;border-radius:2px;
  box-shadow:0 50px 100px -34px rgba(0,0,0,.85);opacity:0;
  transition:opacity .4s var(--ease)}
.lightbox.ready .lb-stage img{opacity:1}
.lb-close,.lb-nav{border:1px solid rgba(255,252,247,.32);background:rgba(16,15,13,.42);
  color:var(--bone);border-radius:50%;cursor:pointer;display:flex;align-items:center;
  justify-content:center;transition:background .3s var(--ease),border-color .3s var(--ease)}
.lb-close:hover,.lb-nav:hover{background:rgba(255,252,247,.16);border-color:var(--bone)}
.lb-close{position:absolute;top:24px;right:26px;width:50px;height:50px;font-size:1.3rem}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;
  font-size:1rem}
.lb-prev{left:26px}.lb-next{right:26px}
.lb-count{position:absolute;bottom:24px;left:0;right:0;text-align:center;
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;
  color:rgba(255,252,247,.6)}

/* ---- gallery (uniform fixed-aspect grid, fills cleanly) ---- */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:8px}
.gitem{margin:0;padding:0;border:0;background:var(--stone);cursor:pointer;
  overflow:hidden;border-radius:2px;position:relative;display:block;
  aspect-ratio:4/5}
.gitem img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .9s var(--ease)}
.gitem::after{content:"";position:absolute;inset:0;background:rgba(20,19,16,0);
  transition:background .45s var(--ease)}
.gitem .gicon{position:absolute;inset:0;margin:auto;width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;border:1px solid var(--bone);
  border-radius:50%;color:var(--bone);opacity:0;transform:scale(.8);z-index:2;
  transition:opacity .4s var(--ease),transform .4s var(--ease);font-size:.9rem}
.gitem:hover img{transform:scale(1.06)}
.gitem:hover::after{background:rgba(20,19,16,.34)}
.gitem:hover .gicon{opacity:1;transform:scale(1)}
@media(max-width:900px){.gallery{grid-template-columns:repeat(2,1fr);gap:10px}}
@media(max-width:520px){.gallery{grid-template-columns:1fr}}

/* ---- testimonial carousel ---- */
.tcar{position:relative;max-width:72rem;margin:0 auto;text-align:center}
.tcar-track{display:grid}
.tslide{grid-area:1/1;opacity:0;transform:translateY(10px);pointer-events:none;
  transition:opacity .7s var(--ease),transform .7s var(--ease)}
.tslide.active{opacity:1;transform:none;pointer-events:auto}
.tdots{display:flex;gap:11px;justify-content:center;margin-top:42px}
.tdot{width:9px;height:9px;border-radius:50%;border:1px solid var(--bronze);
  background:transparent;cursor:pointer;padding:0;
  transition:background .3s var(--ease),transform .3s var(--ease)}
.tdot.active{background:var(--bronze);transform:scale(1.18)}

/* ---- featured spotlight ---- */
.spotlight{position:relative;min-height:86vh;display:flex;align-items:flex-end;
  overflow:hidden;background:#141310}
.spotlight-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.spotlight-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.vid-wrap{position:relative;aspect-ratio:16/9;background:#141310;
  border-radius:3px;overflow:hidden;
  box-shadow:0 36px 90px -42px rgba(0,0,0,.5)}
.vid-wrap .vid{width:100%;height:100%;object-fit:cover;display:block}
.spotlight-veil{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(102deg,rgba(17,16,13,.88) 0%,rgba(17,16,13,.54) 40%,
      rgba(17,16,13,.22) 70%,rgba(17,16,13,.36) 100%),
    linear-gradient(0deg,rgba(17,16,13,.74) 0%,rgba(17,16,13,0) 46%)}
.spotlight .wrap{position:relative;z-index:2;width:100%;padding-top:11vh;
  padding-bottom:9vh}
.spot-inner{max-width:640px;color:var(--bone)}
.spot-inner .kicker{color:var(--champ)}
.spot-inner h2{color:var(--bone);margin-top:18px}
.spot-inner h2 .display-em{color:var(--champ)}
.spot-inner .lead{color:rgba(255,252,247,.85);margin-top:20px;max-width:46ch}
.spot-meta{display:flex;gap:36px;flex-wrap:wrap;margin:32px 0 34px}
.spot-meta .sm b{font-family:var(--display);font-weight:400;font-size:1.06rem;
  display:block;color:var(--bone)}
.spot-meta .sm span{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(255,252,247,.56)}

/* ---- gallipoli image strip (home page) ---- */
.gstrip{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:32px}
.gstrip-item{display:block;overflow:hidden;border-radius:3px;background:var(--stone);
  aspect-ratio:4/5;position:relative}
.gstrip-item img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform .9s var(--ease)}
.gstrip-item:hover img{transform:scale(1.04)}
@media(max-width:880px){.gstrip{grid-template-columns:repeat(3,1fr)}
  .gstrip-item:nth-child(n+4){display:none}}

/* ---- intro reveal ---- */
.intro{position:fixed;inset:0;z-index:300;background:#141310;display:flex;
  align-items:center;justify-content:center;
  transition:transform 1s var(--ease),visibility 1s}
.intro.done{transform:translateY(-101%);visibility:hidden}
.intro-mark{display:flex;flex-direction:column;align-items:center;gap:24px}
.intro-mark img{width:min(330px,60vw);opacity:0;transform:translateY(16px) scale(.98);
  animation:introUp 1.1s var(--ease) .25s forwards}
.intro-line{width:0;height:1px;background:var(--champ);
  animation:introLine 1s var(--ease) 1.05s forwards}
.intro-tag{font-size:.64rem;letter-spacing:.34em;text-transform:uppercase;
  color:rgba(255,252,247,.6);opacity:0;
  animation:introUp .9s var(--ease) 1.25s forwards}
@keyframes introUp{to{opacity:1;transform:none}}
@keyframes introLine{to{width:168px}}

/* ---- case study ---- */
.cs-meta{display:flex;flex-wrap:wrap;margin:38px auto 0;max-width:780px;
  border-top:1px solid var(--hair);border-bottom:1px solid var(--hair)}
.cs-meta .csm{flex:1;min-width:150px;padding:22px 24px;text-align:center;
  border-right:1px solid var(--hair)}
.cs-meta .csm:last-child{border-right:0}
.cs-meta .csm span{display:block;font-size:.66rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--gold);margin-bottom:9px}
.cs-meta .csm b{font-family:var(--display);font-weight:400;font-size:1.12rem;
  text-transform:none;letter-spacing:-.01em}
.cs-feature .par{aspect-ratio:16/9}
.cs-next{display:flex;align-items:center;justify-content:space-between;gap:30px;
  flex-wrap:wrap;padding:44px 0;border-top:1px solid var(--hair)}
.cs-next .csn-lab{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;
  color:var(--gold)}
.cs-next h3{margin-top:9px}
@media(max-width:900px){.gallery{columns:2}}
@media(max-width:600px){.gallery{columns:1}
  .cs-meta .csm{flex:1 1 50%;min-width:0;border-bottom:1px solid var(--hair)}
  .spot-meta{gap:22px}}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.001s!important}
  html.js .rv,html.js .rv-img,html.js .rv-line{opacity:1;transform:none}
}
