/* ============================================================
   The Design Artistry — shared stylesheet (multi-page studio)
   ============================================================ */
:root{
  --paper:#F8F7F4;        /* Warm White */
  --taupe:#A89D92;        /* Taupe */
  --ink:#222222;          /* Charcoal */
  --gold:#B08A4A;         /* Gold Accent */
  --ink-deep:#1b1a18;     /* warm near-black */
  --paper-2:#F1EFEA;
  --line:rgba(34,34,34,.14);
  --line-soft:rgba(168,157,146,.34);
  --muted:#6f6862;
  --f-disp:"Cormorant Garamond",Georgia,serif;
  --f-ui:"Inter",system-ui,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --gut:clamp(1.25rem,5vw,5rem);
  --maxw:1320px;
  --vh:1svh;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{overflow-x:clip;scroll-behavior:auto;-webkit-tap-highlight-color:transparent}
html.menu-open,html.menu-open body{overflow:hidden;overscroll-behavior:none}
body{background:var(--paper);color:var(--ink);font-family:var(--f-ui);font-weight:300;
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:clip;font-variant-ligatures:none}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;-webkit-appearance:none;appearance:none;padding:0}
img,video{display:block;max-width:100%}
::selection{background:var(--gold);color:#fff}
body::after{content:"";position:fixed;inset:0;z-index:200;pointer-events:none;opacity:.035;mix-blend-mode:multiply;
  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.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.wrap{width:min(100% - var(--gut)*2,var(--maxw));margin-inline:auto}
section{position:relative}
.eyebrow{font-size:11px;letter-spacing:.36em;text-transform:uppercase;color:var(--gold);font-weight:500}
h1,h2,h3{font-family:var(--f-disp);font-weight:500;line-height:1.12;letter-spacing:0;padding-bottom:.04em}
em{font-style:italic}

/* motion-kit primitive CSS */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
[data-reveal].is-in{opacity:1;transform:none}
.mk-mask{opacity:1;transform:none}
.mk-line{display:block;overflow:hidden;padding-bottom:.2em;margin-bottom:-.2em}
.mk-line-i{display:block;transform:translateY(112%);transition:transform 1.05s var(--ease)}
.mk-mask.is-in .mk-line-i{transform:none}
.mk-mask.is-in .mk-line:nth-child(2) .mk-line-i{transition-delay:.08s}
.mk-mask.is-in .mk-line:nth-child(3) .mk-line-i{transition-delay:.16s}
.mk-mask.is-in .mk-line:nth-child(4) .mk-line-i{transition-delay:.24s}
.mk-stag{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease);transition-delay:calc(var(--si)*80ms)}
[data-stagger].is-in .mk-stag{opacity:1;transform:none}

#kitProgress{position:fixed;top:0;left:0;height:2px;width:0;z-index:120;background:var(--gold);transform-origin:0 50%}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .5s var(--ease),box-shadow .5s var(--ease),padding .5s var(--ease);padding:24px 0}
.nav .wrap{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;flex-direction:row;align-items:center;gap:11px;line-height:1;color:#fff;transition:color .5s var(--ease)}
.brandmark{height:42px;width:auto;display:block;flex-shrink:0}
.brandtxt{display:flex;flex-direction:column}
.brand b{font-family:var(--f-disp);font-weight:400;font-size:18px;letter-spacing:.16em;text-transform:uppercase}
.brandtxt span{font-size:9px;letter-spacing:.34em;text-transform:uppercase;opacity:.7;margin-top:5px}
@media(max-width:520px){.brandmark{height:34px}.brand b{font-size:14.5px;letter-spacing:.12em}.brandtxt span{font-size:8px;letter-spacing:.26em}}
.navlinks{display:flex;align-items:center;gap:clamp(16px,2.2vw,36px)}
.navlinks a{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#fff;opacity:.86;transition:color .5s var(--ease),opacity .3s}
.navlinks a.lnk:hover,.navlinks a.lnk.active{opacity:1;color:var(--gold)}
.navlinks .enquire{border:1px solid rgba(255,255,255,.4);padding:11px 22px;border-radius:40px;opacity:1;transition:.4s var(--ease)}
.navlinks .enquire:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.nav.solid{background:rgba(248,247,244,.85);backdrop-filter:blur(16px) saturate(1.3);box-shadow:0 1px 0 var(--line);padding:15px 0}
.nav.solid .brand{color:var(--ink)}
.nav.solid .navlinks a{color:var(--ink)}
.nav.solid .navlinks .enquire{border-color:var(--line)}
.nav.solid .navlinks .enquire:hover{color:#fff;border-color:var(--gold)}
/* pages with a light hero get solid nav always (set on body) */
body.lighttop .nav .brand{color:var(--ink)}
body.lighttop .nav .navlinks a{color:var(--ink)}
body.lighttop .nav .navlinks .enquire{border-color:var(--line)}
.navtoggle{display:none}
@media(max-width:920px){
  .navlinks{position:fixed;inset:0;background:var(--ink-deep);flex-direction:column;justify-content:center;gap:30px;
    transform:translateY(-100%);opacity:0;visibility:hidden;pointer-events:none;
    transition:transform .6s var(--ease),opacity .4s var(--ease),visibility 0s linear .6s;z-index:99}
  .navlinks.open{transform:none;opacity:1;visibility:visible;pointer-events:auto;transition:transform .6s var(--ease),opacity .4s var(--ease),visibility 0s}
  .navlinks a{color:#fff!important;font-size:21px;font-family:var(--f-disp);letter-spacing:.04em;text-transform:none;opacity:.9}
  .navlinks .enquire{border-color:rgba(255,255,255,.4)}
  .navtoggle{display:flex;flex-direction:column;justify-content:center;gap:6px;z-index:100;width:28px;height:28px}
  .navtoggle i{height:2px;width:100%;border-radius:2px;background:#fff;transition:.4s var(--ease);filter:drop-shadow(0 1px 2px rgba(0,0,0,.55))}
  .nav.solid .navtoggle i,body.lighttop .navtoggle i{background:var(--ink);filter:none}
  /* backdrop-filter on an ancestor becomes the containing block for position:fixed
     children, collapsing the full-screen menu overlay to the nav height. Drop it on
     mobile so .navlinks stays viewport-fixed; use a near-opaque bg instead. */
  .nav.solid{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(248,247,244,.97)}
  .navtoggle.open i{background:#fff}
  .navtoggle.open i:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
  .navtoggle.open i:nth-child(2){opacity:0}
  .navtoggle.open i:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
}

/* ---------- HERO (home) ---------- */
.hero{height:calc(var(--vh)*100);min-height:600px;position:relative;display:flex;align-items:flex-end;overflow:hidden}
.hero .bg{position:absolute;inset:0;z-index:0}
.hero .bg video,.hero .bg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,19,17,.46),rgba(20,19,17,.08) 32%,rgba(20,19,17,.64))}
.hero .inner{position:relative;z-index:2;color:#fff;padding-bottom:clamp(64px,11vh,140px)}
.hero .eyebrow{color:#e8dcc4}
.hero h1{font-size:clamp(2.4rem,1rem + 5.6vw,5.6rem);font-weight:300;margin-top:24px;max-width:18ch;text-shadow:0 2px 60px rgba(0,0,0,.4)}
.hero h1 em{color:#e6d6b6}
.hero .sub{margin-top:28px;max-width:52ch;font-size:clamp(1rem,.95rem + .3vw,1.16rem);opacity:.9;line-height:1.65}
.hero .cta{margin-top:36px;display:flex;gap:14px;flex-wrap:wrap}
.scrollcue{position:absolute;left:50%;bottom:28px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:#fff;opacity:.6}
.scrollcue .ln{width:1px;height:44px;background:linear-gradient(#e6d6b6,transparent);overflow:hidden;position:relative}
.scrollcue .ln::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold);animation:drop 2s var(--ease) infinite}
@keyframes drop{0%{top:-55%}70%{top:105%}100%{top:105%}}
@media(max-width:860px){.scrollcue{display:none}}
/* Mobile hero legibility (2026-06-23): cover-crop lands on the lit staircase and
   the text block is taller relative to the viewport, so the .08 mid-zone of the
   default scrim left copy low-contrast. Deepen a bottom-weighted scrim so the
   text always sits on a readable base, and give the eyebrow/sub their own shadow. */
@media(max-width:760px){
  .hero .bg::after{background:linear-gradient(180deg,rgba(20,19,17,.34) 0%,rgba(20,19,17,.14) 20%,rgba(20,19,17,.58) 58%,rgba(20,19,17,.84) 100%)}
  .hero .inner{padding-bottom:clamp(48px,9vh,96px)}
  .hero .eyebrow{color:#efe6d2;text-shadow:0 1px 18px rgba(0,0,0,.55)}
  .hero .sub{opacity:1;text-shadow:0 1px 22px rgba(0,0,0,.5)}
}

/* ---------- PAGE HERO (inner pages) ---------- */
.phero{padding:calc(clamp(110px,18vh,180px) + 40px) 0 clamp(46px,8vh,90px);border-bottom:1px solid var(--line);background:var(--paper)}
.phero .eyebrow{display:block;margin-bottom:22px}
.phero h1{font-size:clamp(2.4rem,1rem + 5vw,5rem);font-weight:300;max-width:18ch}
.phero h1 em{color:var(--gold)}
.phero .lede{color:var(--muted);max-width:56ch;margin-top:26px;font-size:clamp(1.02rem,.96rem + .35vw,1.2rem)}
.crumb{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
.crumb a:hover{color:var(--gold)}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:50px;font-size:13px;letter-spacing:.04em;transition:.4s var(--ease);border:1px solid var(--line)}
.btn.primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.btn.primary:hover{background:var(--gold);border-color:var(--gold);transform:translateY(-2px);box-shadow:0 16px 40px -14px rgba(176,138,74,.6)}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px)}
.btn.light{border-color:rgba(255,255,255,.4);color:#fff}
.btn.light:hover{background:#fff;color:var(--ink);border-color:#fff;transform:translateY(-2px)}
.btn.gold{background:var(--gold);border-color:var(--gold);color:#fff}
.btn.gold:hover{background:#9c7838;border-color:#9c7838;transform:translateY(-2px)}

/* ---------- STATEMENT ---------- */
.statement{padding:clamp(80px,13vh,170px) 0}
.statement .grid{display:grid;grid-template-columns:1fr;gap:clamp(34px,6vw,80px)}
.statement h2{font-size:clamp(1.9rem,1rem + 3.6vw,3.7rem);font-weight:300;line-height:1.12;max-width:20ch}
.statement h2 em{color:var(--gold)}
.statement .col2{max-width:56ch}
.statement .col2 p{color:var(--muted);font-size:clamp(1rem,.96rem + .2vw,1.12rem);margin-bottom:1.4em}
.statement .col2 p:last-child{margin-bottom:0}
@media(min-width:900px){.statement .grid{grid-template-columns:1.1fr .9fr;align-items:start;gap:clamp(48px,6vw,96px)}}

/* ---------- SECTION HEAD ---------- */
.shead{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:18px;margin-bottom:clamp(40px,7vh,76px)}
.shead h2{font-size:clamp(1.8rem,1rem + 3.2vw,3.3rem);font-weight:300;max-width:22ch}
.shead h2 em{color:var(--gold)}
.shead .more{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--gold);padding-bottom:4px;transition:.3s}
.shead .more:hover{color:var(--gold)}

/* ---------- SELECTED WORK / PROJECT GRID ---------- */
.work{padding:clamp(70px,12vh,150px) 0}
.wgrid{display:grid;grid-template-columns:1fr;gap:clamp(46px,7vw,90px)}
@media(min-width:820px){.wgrid{grid-template-columns:repeat(2,1fr);column-gap:clamp(34px,4vw,70px);row-gap:clamp(70px,9vw,120px)}
  .witem.tall{margin-top:clamp(40px,7vw,120px)}}
.witem{display:block}
.witem .frame{position:relative;overflow:hidden;background:var(--paper-2);aspect-ratio:4/3}
.witem .frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s var(--ease);transform:scale(1.02)}
.witem:hover .frame img{transform:scale(1.07)}
.witem .meta{display:flex;justify-content:space-between;align-items:baseline;margin-top:20px;gap:18px;border-top:1px solid var(--line);padding-top:16px}
.witem .meta .l .no{font-family:var(--f-disp);font-style:italic;color:var(--gold);font-size:13px}
.witem .meta .l h3{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.3rem,1rem + 1.1vw,1.75rem);margin-top:4px;line-height:1.1}
.witem .meta .l .loc{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:8px}
.witem .meta .r{text-align:right;flex-shrink:0}
.witem .meta .r .val{font-family:var(--f-disp);font-size:clamp(1.05rem,1rem + .5vw,1.4rem);color:var(--ink)}
.witem .meta .r .style{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:6px;max-width:18ch}
.witem.feat{grid-column:1/-1}
.witem.feat .frame{aspect-ratio:21/9}
@media(max-width:819px){.witem.feat .frame{aspect-ratio:4/3}}

/* ---------- DISCIPLINES / SERVICES TEASER ---------- */
.disc{padding:clamp(70px,11vh,130px) 0;background:var(--paper-2);border-top:1px solid var(--line)}
.dgrid{display:grid;grid-template-columns:1fr;gap:0}
.dcard{padding:34px 0;border-top:1px solid var(--line)}
.dcard:last-child{border-bottom:1px solid var(--line)}
.dcard .no{font-family:var(--f-disp);font-style:italic;color:var(--gold);font-size:15px;margin-bottom:14px}
.dcard h4{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.4rem,1rem + 1.6vw,2rem);line-height:1.1}
.dcard p{color:var(--muted);max-width:60ch;margin-top:14px;font-size:.98rem}
@media(min-width:760px){.dgrid{grid-template-columns:repeat(2,1fr);column-gap:clamp(40px,6vw,90px)}
  .dcard:nth-last-child(2){border-bottom:1px solid var(--line)}}

/* ---------- WHY CHOOSE US ---------- */
.why{padding:clamp(80px,13vh,160px) 0}
.whygrid{display:grid;grid-template-columns:1fr;gap:0;margin-top:clamp(40px,6vh,70px)}
.whycard{padding:32px 0;border-top:1px solid var(--line);display:grid;grid-template-columns:1fr;gap:10px}
.whycard:last-child{border-bottom:1px solid var(--line)}
.whycard .no{font-family:var(--f-disp);font-style:italic;color:var(--gold);font-size:14px}
.whycard h4{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.25rem,1rem + 1vw,1.6rem)}
.whycard p{color:var(--muted);font-size:.98rem;max-width:62ch}
@media(min-width:780px){.whycard{grid-template-columns:.4fr .6fr;gap:clamp(30px,5vw,80px);align-items:baseline}}

/* ---------- PHILOSOPHY (dark) ---------- */
.phil{background:var(--ink-deep);color:var(--paper);padding:clamp(84px,14vh,180px) 0;position:relative;overflow:hidden}
.phil::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.05;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='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.phil .quote{font-family:var(--f-disp);font-weight:300;font-size:clamp(1.7rem,1rem + 3.4vw,3.6rem);line-height:1.16;max-width:24ch;margin-bottom:clamp(50px,8vh,100px)}
.phil .quote em{color:var(--gold)}
.pgrid{display:grid;grid-template-columns:1fr;gap:0;border-top:1px solid rgba(255,255,255,.14)}
.pcard{padding:30px 0;border-bottom:1px solid rgba(255,255,255,.14)}
.pcard .no{font-family:var(--f-disp);font-style:italic;color:var(--gold);font-size:14px}
.pcard h4{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.3rem,1rem + 1.2vw,1.7rem);margin-top:12px}
.pcard p{color:rgba(248,247,244,.66);margin-top:12px;font-size:.96rem;max-width:38ch}
@media(min-width:760px){.pgrid{grid-template-columns:repeat(4,1fr);column-gap:clamp(28px,3vw,56px)}.pcard{border-bottom:0}}

/* ---------- CARD STACK (why + phil) ---------- */
.cardstack{position:relative;margin-top:clamp(38px,6vh,72px);display:flex;flex-direction:column;gap:clamp(14px,2vh,22px)}
.stackcard{position:sticky;top:calc(94px + var(--i,0)*16px);border-radius:16px;padding:clamp(26px,3.6vw,52px);
  display:grid;grid-template-columns:1fr;gap:14px;will-change:transform,filter;transform-origin:center top}
.stackcard .sc-no{font-family:var(--f-disp);font-style:italic;color:var(--gold);font-size:15px}
.stackcard h4{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.3rem,1rem + 1.5vw,2rem)}
.stackcard p{font-size:1rem;line-height:1.62;max-width:60ch}
@media(min-width:780px){.stackcard{grid-template-columns:.34fr .66fr;gap:clamp(28px,5vw,80px);align-items:start}}
/* WHY — light cards on the paper section */
.why .stackcard{background:var(--paper);border:1px solid var(--line);box-shadow:0 30px 70px -34px rgba(34,34,34,.32)}
.why .stackcard p{color:var(--muted)}
@media (prefers-reduced-motion:reduce){.stackcard{position:static}}

/* PHIL — single line that lights up + travels left→right as you scroll */
.phil .pgrid{position:relative}
.phil .pgrid::after{content:"";position:absolute;top:-1px;left:0;height:2px;width:100%;pointer-events:none;
  transform-origin:left center;transform:scaleX(var(--lit,0));
  background:linear-gradient(90deg,rgba(176,138,74,.15),rgba(176,138,74,.85) 72%,#f3e6c6);
  box-shadow:0 0 14px rgba(176,138,74,.55)}

/* ---------- REACH / STATS ---------- */
.reach{padding:clamp(76px,12vh,150px) 0;text-align:center;border-bottom:1px solid var(--line)}
.reach .eyebrow{display:block;margin-bottom:24px}
.reach h2{font-size:clamp(1.7rem,1rem + 3vw,3.2rem);font-weight:300;max-width:22ch;margin:0 auto;line-height:1.14}
.reach h2 em{color:var(--gold)}
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:48px 24px;margin-top:clamp(50px,8vh,90px)}
@media(min-width:760px){.stats{grid-template-columns:repeat(3,1fr)}}
.stat .n{font-family:var(--f-disp);font-weight:300;font-size:clamp(2.6rem,1rem + 5vw,4.6rem);line-height:1;color:var(--ink)}
.stat .n span{color:var(--gold)}
.stat .lbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:14px}

/* ---------- CONTACT ---------- */
.contact{padding:clamp(84px,14vh,180px) 0;background:var(--paper-2)}
.contact .eyebrow{display:block;margin-bottom:26px}
.contact h2{font-size:clamp(2.2rem,1rem + 5vw,5rem);font-weight:300;line-height:1.1;max-width:16ch}
.contact h2 em{color:var(--gold)}
.contact .lede{color:var(--muted);max-width:48ch;margin-top:26px;font-size:clamp(1rem,.96rem + .3vw,1.15rem)}
.contact .cta{margin-top:42px;display:flex;gap:16px;flex-wrap:wrap}
.cdetails{margin-top:54px;display:flex;gap:clamp(26px,6vw,72px);flex-wrap:wrap;border-top:1px solid var(--line);padding-top:32px}
.cdetails .b{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:9px}
.cdetails a,.cdetails p{font-size:15px;color:var(--ink)}

/* ---------- PROSE (about / journal article) ---------- */
.prose{padding:clamp(56px,9vh,110px) 0 clamp(70px,11vh,140px)}
.prose .body{max-width:66ch;margin-inline:auto}
.prose .body p{color:var(--ink);opacity:.86;font-size:clamp(1.05rem,1rem + .35vw,1.22rem);line-height:1.78;margin-bottom:1.5em}
.prose .body p.lead{font-family:var(--f-disp);font-weight:300;font-size:clamp(1.4rem,1rem + 1.4vw,2rem);line-height:1.35;opacity:1;color:var(--ink);margin-bottom:1.1em}
.prose .body h3{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.4rem,1rem + 1.4vw,2rem);margin:1.6em 0 .5em}
.prose .body em{color:var(--ink)}
.prose figure{margin:clamp(40px,6vh,80px) 0}
.prose figure img{width:100%}
.prose figcaption{font-size:12px;letter-spacing:.04em;color:var(--muted);margin-top:12px}
.pullquote{font-family:var(--f-disp);font-weight:300;font-size:clamp(1.6rem,1rem + 2.6vw,2.8rem);line-height:1.2;color:var(--ink);margin:clamp(40px,6vh,80px) 0;max-width:22ch}
.pullquote em{color:var(--gold)}

/* ---------- SERVICES PAGE ---------- */
.svc{padding:clamp(50px,8vh,90px) 0 clamp(70px,11vh,140px)}
.svcgroup{display:grid;grid-template-columns:1fr;gap:18px 60px;padding:clamp(34px,5vh,56px) 0;border-top:1px solid var(--line)}
.svcgroup:last-child{border-bottom:1px solid var(--line)}
.svcgroup .head .no{font-family:var(--f-disp);font-style:italic;color:var(--gold);font-size:14px}
.svcgroup .head h3{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.5rem,1rem + 1.8vw,2.2rem);margin-top:8px}
.svcgroup .head p{color:var(--muted);margin-top:14px;font-size:.98rem;max-width:46ch}
.svclist{list-style:none;display:grid;grid-template-columns:1fr;gap:0;align-self:start}
.svclist li{padding:15px 0;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;font-size:1.05rem}
.svclist li:first-child{border-top:1px solid var(--line)}
.svclist li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0}
@media(min-width:860px){.svcgroup{grid-template-columns:.42fr .58fr}.svclist{grid-template-columns:repeat(2,1fr);column-gap:48px}
  .svclist li:nth-child(2){border-top:1px solid var(--line)}}

/* ---------- PROJECT DETAIL ---------- */
.pj-hero{height:clamp(440px,76vh,820px);position:relative;overflow:hidden;display:flex;align-items:flex-end}
.pj-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pj-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,19,17,.3),rgba(20,19,17,0) 36%,rgba(20,19,17,.66))}
.pj-hero .inner{position:relative;z-index:2;color:#fff;padding-bottom:clamp(40px,7vh,80px)}
.pj-hero .crumb{color:rgba(255,255,255,.7)}
.pj-hero .crumb a:hover{color:#fff}
.pj-hero h1{font-size:clamp(2.2rem,1rem + 4.6vw,4.6rem);font-weight:300;max-width:18ch;margin-top:8px}
.pj-hero .subt{font-family:var(--f-disp);font-style:italic;color:#e6d6b6;font-size:clamp(1.1rem,1rem + .8vw,1.6rem);margin-top:14px}
.pj-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:30px 24px;padding:clamp(40px,6vh,70px) 0;border-bottom:1px solid var(--line)}
@media(min-width:820px){.pj-meta{grid-template-columns:repeat(4,1fr)}}
.pj-meta .b{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.pj-meta .v{font-size:1.02rem;color:var(--ink)}
.pj-body{padding:clamp(48px,7vh,80px) 0 clamp(56px,9vh,100px)}
.pj-narr{display:grid;grid-template-columns:1fr;gap:clamp(40px,6vh,72px)}
.pj-move .k{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.pj-move h3{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.5rem,1rem + 1.8vw,2.3rem);max-width:20ch;line-height:1.1}
.pj-move p{color:var(--ink);opacity:.84;font-size:clamp(1.02rem,1rem + .3vw,1.16rem);line-height:1.76;margin-top:18px;max-width:60ch}
@media(min-width:860px){.pj-move{display:grid;grid-template-columns:.36fr .64fr;gap:clamp(30px,5vw,80px);align-items:start}.pj-move p{margin-top:0}}
.pj-galhead{border-top:1px solid var(--line);padding-top:22px;margin-top:clamp(20px,4vh,40px);margin-bottom:clamp(20px,3vh,30px)}
.pj-grid,.pj-pair{display:grid;grid-template-columns:1fr;gap:clamp(14px,2vw,22px)}
.pj-grid{padding-bottom:clamp(44px,7vh,90px)}
.pj-grid figure,.pj-pair figure{margin:0;overflow:hidden;background:var(--paper-2)}
.pj-grid img,.pj-pair img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform 1.2s var(--ease)}
.pj-grid figure:hover img,.pj-pair figure:hover img{transform:scale(1.04)}
@media(min-width:720px){.pj-grid,.pj-pair{grid-template-columns:repeat(2,1fr)}}
.pj-gallery{display:grid;grid-template-columns:1fr;gap:clamp(16px,2.4vw,28px);padding-bottom:clamp(40px,7vh,90px)}
.pj-gallery img{width:100%;background:var(--paper-2)}
.pj-gallery .full{grid-column:1/-1;max-width:860px;width:100%;margin-inline:auto}
@media(min-width:760px){.pj-gallery{grid-template-columns:repeat(2,1fr)}}
/* Design Notes — full client brief */
.pj-notes{background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:clamp(54px,9vh,110px) 0;margin:clamp(20px,4vh,50px) 0}
.pj-noteshead{margin-bottom:clamp(30px,5vh,60px)}
.pj-noteshead h2{font-family:var(--f-disp);font-weight:300;font-size:clamp(1.7rem,1rem + 2.6vw,2.9rem);margin-top:14px;line-height:1.1}
.pj-noteshead h2 em{color:var(--gold)}
.pj-notesgrid{display:grid;grid-template-columns:1fr;gap:clamp(26px,3vw,44px) clamp(34px,5vw,80px)}
@media(min-width:720px){.pj-notesgrid{grid-template-columns:repeat(2,1fr)}}
.pj-note{border-top:1px solid var(--line-soft);padding-top:18px}
.pj-note h4{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.12rem,1rem + .55vw,1.4rem);color:var(--ink);line-height:1.2}
.pj-note p{color:var(--ink);opacity:.8;font-size:1.02rem;line-height:1.7;margin-top:9px;max-width:52ch}
.pj-next{border-top:1px solid var(--line);padding:clamp(40px,6vh,70px) 0;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.pj-next .lbl{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.pj-next h3{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.4rem,1rem + 1.6vw,2.2rem);margin-top:6px}
.pj-next a:hover h3{color:var(--gold)}

/* ---------- JOURNAL INDEX ---------- */
.jgrid{display:grid;grid-template-columns:1fr;gap:clamp(40px,5vw,56px);padding:clamp(50px,8vh,90px) 0 clamp(70px,11vh,140px)}
@media(min-width:780px){.jgrid{grid-template-columns:repeat(3,1fr)}}
.jcard .frame{aspect-ratio:4/3;overflow:hidden;background:var(--paper-2)}
.jcard .frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.jcard:hover .frame img{transform:scale(1.06)}
.jcard .cat{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-top:18px}
.jcard h3{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.3rem,1rem + 1vw,1.7rem);margin-top:10px;line-height:1.12}
.jcard p{color:var(--muted);font-size:.96rem;margin-top:10px}

/* ---------- FOOTER ---------- */
.foot{background:var(--ink-deep);color:var(--paper);padding:clamp(56px,8vh,90px) 0 40px}
.foot .top{display:flex;justify-content:space-between;flex-wrap:wrap;gap:34px;align-items:flex-start}
.foot .brand b{color:#fff}.foot .brand span{opacity:.6}
.foot nav{display:flex;gap:26px;flex-wrap:wrap}
.foot nav a{font-size:12px;letter-spacing:.12em;text-transform:uppercase;opacity:.7;transition:.3s}
.foot nav a:hover{opacity:1;color:var(--gold)}
.foot .btm{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-top:clamp(46px,7vh,80px);padding-top:24px;border-top:1px solid rgba(255,255,255,.14);font-size:12px;color:rgba(248,247,244,.5);letter-spacing:.04em}
.foot .btm a{color:var(--gold)}

/* ---------- WHATSAPP FLOAT ---------- */
.wa{position:fixed;right:clamp(16px,3vw,30px);bottom:clamp(16px,3vw,30px);z-index:130;width:56px;height:56px;border-radius:50%;
  background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px -8px rgba(0,0,0,.4);transition:.35s var(--ease)}
.wa:hover{transform:translateY(-3px) scale(1.05)}
.wa svg{width:30px;height:30px;fill:#fff}

@media (prefers-reduced-motion: reduce){
  .hero .bg video{display:none}
  .scrollcue .ln::after{animation:none}
  [data-reveal],.mk-line-i,.mk-stag{opacity:1!important;transform:none!important}
}

/* ============ About — editorial image pair + gallery (added 2026-06-16) ============ */
.ab-pair{display:grid;grid-template-columns:1fr 1fr;gap:clamp(12px,1.6vw,20px);margin:clamp(40px,6vh,80px) 0}
.ab-pair figure{margin:0;overflow:hidden;background:var(--paper-2)}
.ab-pair img{width:100%;height:100%;aspect-ratio:4/5;object-fit:cover;display:block;transform:scale(1.02);transition:transform 1.3s var(--ease)}
.ab-pair figure:hover img{transform:scale(1.06)}
@media(max-width:560px){.ab-pair{grid-template-columns:1fr}.ab-pair img{aspect-ratio:4/3}}

.ab-gal{padding:clamp(56px,9vh,112px) 0;border-top:1px solid var(--line);background:var(--paper-2)}
.ab-gal h2{font-family:var(--f-disp);font-weight:300;font-size:clamp(1.7rem,1rem + 2.6vw,2.9rem);max-width:20ch}
.ab-gal h2 em{color:var(--gold)}
.ab-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.5vw,20px)}
.ab-grid figure{margin:0;position:relative;overflow:hidden;background:var(--paper)}
.ab-grid img{width:100%;height:100%;aspect-ratio:4/3;object-fit:cover;display:block;transform:scale(1.02);transition:transform 1.5s var(--ease)}
.ab-grid figure:hover img{transform:scale(1.07)}
.ab-grid figcaption{position:absolute;left:0;right:0;bottom:0;padding:34px 18px 15px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#fff;background:linear-gradient(transparent,rgba(20,18,16,.66));opacity:0;transform:translateY(8px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.ab-grid figure:hover figcaption{opacity:1;transform:none}
@media(max-width:860px){.ab-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.ab-grid{grid-template-columns:1fr}}

/* ============ Services — stacking cards / self-decking (added 2026-06-16) ============ */
.svc-stack{display:flex;flex-direction:column;gap:clamp(20px,3.5vh,40px);max-width:1060px;margin:0 auto;padding:clamp(16px,3vh,34px) 0 clamp(46px,9vh,100px)}
.scard{position:sticky;background:var(--paper);border:1px solid var(--line);border-radius:16px;
  padding:clamp(30px,4vw,60px);overflow:hidden;transform-origin:50% 0;will-change:transform;
  box-shadow:0 1px 0 rgba(255,255,255,.55) inset, 0 34px 76px -44px rgba(40,32,22,.6);
  min-height:clamp(320px,56vh,448px);
  display:grid;grid-template-columns:1fr;gap:clamp(22px,3vw,46px);align-content:center}
.scard:nth-child(1){top:clamp(86px,12vh,118px)}
.scard:nth-child(2){top:calc(clamp(86px,12vh,118px) + 16px)}
.scard:nth-child(3){top:calc(clamp(86px,12vh,118px) + 32px)}
.scard:nth-child(4){top:calc(clamp(86px,12vh,118px) + 48px)}
.scard .gh{position:absolute;top:-.14em;right:.06em;font-family:var(--f-disp);font-style:italic;font-weight:300;
  font-size:clamp(7rem,17vw,14rem);line-height:1;color:var(--gold);opacity:.08;pointer-events:none;user-select:none}
.scard .s-no{font-family:var(--f-disp);font-style:italic;color:var(--gold);font-size:14px;letter-spacing:.02em}
.scard h3{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.7rem,1rem + 2.4vw,2.9rem);margin-top:10px;line-height:1.1}
.scard .blurb{color:var(--muted);margin-top:16px;font-size:1.02rem;line-height:1.72;max-width:44ch}
.scard .s-items{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:0 36px;align-self:center}
.scard .s-items li{padding:14px 0;border-top:1px solid var(--line);display:flex;align-items:center;gap:13px;font-size:1.02rem;color:var(--ink)}
.scard .s-items li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--gold);flex-shrink:0}
@media(min-width:820px){.scard{grid-template-columns:.47fr .53fr;align-items:center}}
@media(max-width:560px){.scard .s-items{grid-template-columns:1fr}.scard .s-items li:first-child{border-top:1px solid var(--line)}}
@media (prefers-reduced-motion: reduce){.scard{position:relative;top:auto!important}}

/* ============ Social icons (added 2026-06-17) ============ */
.socials{display:flex;align-items:center;gap:12px}
.socials a{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;
  border:1px solid currentColor;opacity:.62;transition:.35s var(--ease)}
.socials a:hover{opacity:1;color:var(--gold);border-color:var(--gold);transform:translateY(-2px)}
.socials svg{width:15px;height:15px;fill:currentColor;display:block}
.socials.big a{width:46px;height:46px}.socials.big svg{width:19px;height:19px}

/* footer right column + socials */
.foot-right{display:flex;flex-direction:column;align-items:flex-end;gap:22px}
.foot .foot-soc{color:#fff}
@media(max-width:680px){.foot-right{align-items:flex-start}.foot .top{gap:26px}}

/* ============ Contact — brand emblem + follow (added 2026-06-17) ============ */
.contact-brand{padding:clamp(40px,7vh,80px) 0;border-top:1px solid var(--line);text-align:center}
.contact-brand .wrap{display:flex;flex-direction:column;align-items:center;gap:34px}
.contact-emblem{width:auto;height:clamp(200px,28vw,272px);opacity:.95}
.contact-follow{display:flex;flex-direction:column;align-items:center;gap:16px}
.contact-follow .b{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold)}
.contact-brand .socials{color:var(--ink)}

/* ============ Careers — public listings (added 2026-06-17) ============ */
.careers{padding:clamp(46px,8vh,96px) 0 clamp(70px,11vh,140px)}
.careers-head{margin-bottom:clamp(28px,5vh,52px)}
.joblist{display:flex;flex-direction:column;gap:clamp(20px,3vh,34px)}
.jl-state{color:var(--muted);font-size:1.02rem;padding:20px 0}
.jobcard{border:1px solid var(--line);border-radius:16px;padding:clamp(26px,3.4vw,44px);background:var(--paper);
  box-shadow:0 1px 0 rgba(255,255,255,.55) inset,0 30px 64px -46px rgba(40,32,22,.5);transition:.45s var(--ease)}
.jobcard:hover{border-color:var(--line-soft);transform:translateY(-3px);box-shadow:0 1px 0 rgba(255,255,255,.6) inset,0 40px 80px -44px rgba(40,32,22,.6)}
.jc-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap}
.jc-head h3{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.5rem,1rem + 1.8vw,2.3rem);line-height:1.12}
.jc-role{color:var(--gold);font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-top:10px}
.jc-chips{display:flex;gap:10px;flex-wrap:wrap}
.chip{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);border-radius:40px;padding:7px 15px}
.jc-desc{color:var(--ink);opacity:.84;font-size:clamp(1rem,.97rem + .25vw,1.12rem);line-height:1.74;margin-top:22px;max-width:70ch}
.jc-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.jl-empty{text-align:center;max-width:48ch;margin:clamp(20px,5vh,50px) auto 0}
.jl-empty h3{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.5rem,1rem + 1.8vw,2.2rem)}
.jl-empty p{color:var(--muted);margin-top:18px;font-size:1.05rem;line-height:1.7}
.jl-empty .cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:32px}

/* ============ Careers admin (added 2026-06-17) ============ */
.adminbody{background:var(--paper-2)}
.adminbody::after{display:none}
.admin-wrap{width:min(100% - 2.5rem,860px);margin:0 auto;padding:clamp(40px,7vh,80px) 0 100px}
.admin-top{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:34px}
.admin-top h1{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.6rem,1rem + 2vw,2.4rem);margin-top:10px}
.admin-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:clamp(26px,3.4vw,42px);margin-bottom:24px;
  box-shadow:0 30px 64px -50px rgba(40,32,22,.5)}
.admin-card h2{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.3rem,1rem + 1.2vw,1.8rem)}
.muted{color:var(--muted);font-size:.96rem}
.admin-gate{max-width:480px}
.admin-gate p{margin:12px 0 22px}
#gateForm{display:flex;gap:12px;flex-wrap:wrap}
.admin-form{display:flex;flex-direction:column;gap:18px;margin-top:24px}
.admin-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:560px){.admin-row{grid-template-columns:1fr}}
.admin-form label,.admin-gate label{display:flex;flex-direction:column;gap:8px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.admin-form label span{color:var(--gold)}
.admin-wrap input,.admin-wrap textarea{font-family:var(--f-ui);font-size:1rem;font-weight:300;color:var(--ink);background:var(--paper-2);
  border:1px solid var(--line);border-radius:10px;padding:13px 15px;transition:.3s var(--ease);width:100%}
.admin-wrap textarea{resize:vertical;line-height:1.6}
.admin-wrap input:focus,.admin-wrap textarea:focus{outline:none;border-color:var(--gold);background:var(--paper)}
.admin-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}
.btn[disabled]{opacity:.5;pointer-events:none}
.btn.del{border-color:rgba(150,40,40,.4);color:#9b2c2c}
.btn.del:hover{background:#9b2c2c;border-color:#9b2c2c;color:#fff}
.btn.mini{padding:9px 18px;font-size:12px}
.admin-listhead{display:flex;justify-content:space-between;align-items:baseline;gap:14px;margin-bottom:18px}
.admin-list{display:flex;flex-direction:column;gap:14px}
.admin-item{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;border:1px solid var(--line);border-radius:12px;padding:20px 22px;background:var(--paper-2)}
.ai-main{flex:1;min-width:220px}
.ai-main h4{font-family:var(--f-disp);font-weight:400;font-size:1.25rem}
.ai-meta{color:var(--gold);font-size:11px;letter-spacing:.12em;text-transform:uppercase;margin-top:8px}
.ai-desc{color:var(--muted);font-size:.94rem;margin-top:10px;line-height:1.6}
.ai-actions{display:flex;gap:10px;align-items:flex-start;flex-wrap:wrap}
.admin-err{color:#9b2c2c;font-size:.92rem;margin-top:14px}
.admin-msg{font-size:.94rem;margin-top:16px}
.admin-msg.ok{color:#2e6b3e}.admin-msg.bad{color:#9b2c2c}

/* ============ Logo mark — adaptive contrast (added 2026-06-17) ============ */
/* taupe mark over light nav/contact; render white over dark hero + footer */
.brandmark{transition:filter .5s var(--ease),height .5s var(--ease)}
.nav .brandmark{filter:brightness(0) invert(1);opacity:.96}
.nav.solid .brandmark,body.lighttop .nav .brandmark{filter:none;opacity:1}
.foot .brandmark{filter:brightness(0) invert(1);opacity:.9}
/* the hidden attribute must beat .btn's display:inline-flex */
[hidden]{display:none!important}

/* ============ Portfolio page (added 2026-06-18) ============ */
.pf-clients{padding:clamp(50px,8vh,100px) 0;background:var(--paper-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pf-clients .eyebrow{display:block;margin-bottom:10px}
.pf-clientgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:0 clamp(28px,4vw,64px)}
.pf-clientgrid span{padding:15px 0;border-top:1px solid var(--line);font-family:var(--f-disp);font-weight:400;font-size:1.02rem;color:var(--ink);transition:color .3s var(--ease)}
.pf-clientgrid span:hover{color:var(--gold)}
.pf-clientgrid span[hidden]{display:none}
.pf-more-btn{margin-top:26px;display:inline-flex;align-items:center;gap:9px;font-family:var(--f-ui);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);background:none;border:0;border-bottom:1px solid var(--gold);padding:0 0 5px;cursor:pointer;transition:color .3s var(--ease)}
.pf-more-btn:hover{color:var(--gold)}
.pf-more-btn .pm-ar{font-size:13px;line-height:1;transition:transform .35s var(--ease)}
.pf-more-btn[aria-expanded="true"] .pm-ar{transform:rotate(180deg)}

.pf-block{padding:clamp(54px,9vh,120px) 0;border-top:1px solid var(--line)}
.pf-block:first-of-type,.pf-stripe + .pf-block{border-top:0}
.pf-head{display:grid;grid-template-columns:1fr;gap:20px;margin-bottom:clamp(30px,5vh,56px)}
.pf-no{font-family:var(--f-disp);font-style:italic;color:var(--gold);font-size:14px;letter-spacing:.04em}
.pf-head-l h2{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.8rem,1rem + 2.8vw,3rem);line-height:1.12;margin-top:12px}
.pf-sector{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:14px}
.pf-text{color:var(--muted);max-width:60ch;font-size:clamp(1.02rem,.97rem + .3vw,1.16rem);line-height:1.74}
.pf-text em{color:var(--ink);font-style:italic}
@media(min-width:900px){.pf-head{grid-template-columns:1.05fr .95fr;align-items:end;column-gap:clamp(44px,6vw,96px)}}
.pf-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(12px,1.6vw,20px)}
.pf-grid figure{margin:0;overflow:hidden;background:var(--paper-2)}
.pf-grid img{width:100%;height:100%;aspect-ratio:4/3;object-fit:cover;display:block;transform:scale(1.02);transition:transform 1.3s var(--ease)}
.pf-grid figure:hover img{transform:scale(1.07)}
.pf-grid figure:first-child{grid-column:1/-1}
.pf-grid figure:first-child img{aspect-ratio:16/9}
@media(max-width:600px){.pf-grid{grid-template-columns:1fr}.pf-grid figure:first-child img{aspect-ratio:4/3}}
.pf-disc{margin-top:clamp(20px,3vh,32px);font-size:12px;line-height:1.6;color:var(--muted);max-width:74ch;font-style:italic;opacity:.85}

/* portfolio block — title link + view-project link (added 2026-06-18) */
.pf-titlelink{display:inline-block;transition:color .3s var(--ease)}
.pf-titlelink:hover h2{color:var(--gold)}
.pf-textwrap{display:flex;flex-direction:column;align-items:flex-start;gap:18px}
.pf-more{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--gold);padding-bottom:4px;transition:.3s var(--ease)}
.pf-more:hover{color:var(--gold)}

/* ============ Nav "Projects" filter dropdown (added 2026-06-18) ============ */
.lnk-dd{position:relative;display:inline-flex;align-items:center}
.lnk-dd::after{content:"";position:absolute;top:100%;left:-10px;right:-10px;height:16px} /* hover bridge */
.dd{position:absolute;top:100%;left:50%;transform:translate(-50%,10px);min-width:190px;margin-top:6px;padding:10px;
  background:var(--paper);border:1px solid var(--line);border-radius:13px;
  box-shadow:0 26px 64px -26px rgba(40,32,22,.45);display:flex;flex-direction:column;gap:2px;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .32s var(--ease),transform .32s var(--ease);z-index:101}
.lnk-dd:hover .dd,.lnk-dd:focus-within .dd{opacity:1;visibility:visible;pointer-events:auto;transform:translate(-50%,4px)}
.dd a{font-size:11.5px!important;letter-spacing:.14em;text-transform:uppercase;color:var(--ink)!important;opacity:.82!important;
  padding:11px 15px;border-radius:9px;transition:background .25s var(--ease),color .25s var(--ease),opacity .25s;white-space:nowrap}
.dd a:hover,.dd a.active{background:var(--paper-2);color:var(--gold)!important;opacity:1!important}
@media(max-width:920px){
  .lnk-dd{flex-direction:column;align-items:center;gap:18px}
  .lnk-dd::after{display:none}
  .dd{position:static;transform:none;opacity:1;visibility:visible;pointer-events:auto;margin:0;padding:0;
    background:none;border:0;box-shadow:none;align-items:center;text-align:center;gap:14px}
  .dd a{color:#fff!important;font-size:14px!important;opacity:.72!important;padding:0;letter-spacing:.1em;text-align:center}
  .dd a:hover,.dd a:active,.dd a.active{background:none!important;color:var(--gold)!important}
}

/* ---------- CUSTOM CURSOR ---------- */
.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:200;opacity:0;will-change:transform}
.cursor-dot{width:6px;height:6px;margin:-3px 0 0 -3px;background:var(--gold);transition:opacity .35s var(--ease)}
.cursor-ring{width:30px;height:30px;margin:-15px 0 0 -15px;border:1px solid color-mix(in srgb,var(--gold) 58%,transparent);
  transition:width .3s var(--ease),height .3s var(--ease),margin .3s var(--ease),border-color .3s,background-color .3s,opacity .35s}
.cursor-ring.hover{width:54px;height:54px;margin:-27px 0 0 -27px;border-color:var(--gold);background-color:color-mix(in srgb,var(--gold) 12%,transparent)}
.cursor-ring.down{width:22px;height:22px;margin:-11px 0 0 -11px}
@media (hover:hover) and (pointer:fine){
  body.cursor-on{cursor:none}
  body.cursor-on a,body.cursor-on button,body.cursor-on .witem,body.cursor-on .pf-block,body.cursor-on label,body.cursor-on summary{cursor:none}
  body.cursor-on input,body.cursor-on textarea,body.cursor-on select{cursor:auto}
}
@media (hover:none),(pointer:coarse){.cursor-dot,.cursor-ring{display:none}}
@media (prefers-reduced-motion:reduce){.cursor-ring{transition:opacity .35s}}

/* ---------- BACKGROUND MUSIC TOGGLE ---------- */
.audio-toggle{position:fixed;left:clamp(16px,3vw,30px);bottom:clamp(16px,3vw,30px);z-index:130;
  width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(27,26,24,.5);backdrop-filter:blur(10px) saturate(1.2);-webkit-backdrop-filter:blur(10px) saturate(1.2);
  border:1px solid rgba(248,247,244,.22);transition:transform .4s var(--ease),background-color .4s,border-color .4s}
.audio-toggle:hover{transform:translateY(-3px);background:rgba(27,26,24,.72);border-color:var(--gold)}
.audio-toggle .eq{display:flex;align-items:center;gap:2.5px;height:16px}
.audio-toggle .eq i{width:2.5px;height:4px;background:var(--paper);border-radius:2px;opacity:.92}
.audio-toggle.playing .eq i{animation:eqBar 1s ease-in-out infinite}
.audio-toggle.playing .eq i:nth-child(1){animation-delay:-.2s}
.audio-toggle.playing .eq i:nth-child(2){animation-delay:-.55s}
.audio-toggle.playing .eq i:nth-child(3){animation-delay:-.1s}
.audio-toggle.playing .eq i:nth-child(4){animation-delay:-.7s}
@keyframes eqBar{0%,100%{height:4px}50%{height:15px}}
@media (prefers-reduced-motion:reduce){.audio-toggle.playing .eq i{animation:none;height:9px}}
/* armed = playing but muted, waiting for the first tap to unmute */
.audio-toggle.armed{animation:audioPulse 1.9s ease-in-out infinite}
.audio-toggle.armed .eq i{height:4px;opacity:.6}
@keyframes audioPulse{0%,100%{box-shadow:0 0 0 0 rgba(176,138,74,0)}50%{box-shadow:0 0 0 7px rgba(176,138,74,.14)}}
.audio-hint{position:fixed;left:calc(clamp(16px,3vw,30px) + 56px);bottom:clamp(16px,3vw,30px);z-index:130;height:46px;
  display:flex;align-items:center;padding:0 15px;border-radius:23px;font-family:var(--f-ui);font-size:10.5px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--paper);background:rgba(27,26,24,.5);
  backdrop-filter:blur(10px) saturate(1.2);-webkit-backdrop-filter:blur(10px) saturate(1.2);
  border:1px solid rgba(248,247,244,.18);white-space:nowrap;pointer-events:none;
  opacity:0;transform:translateX(-8px);transition:opacity .45s var(--ease),transform .45s var(--ease)}
.audio-hint.show{opacity:1;transform:none}
@media (max-width:560px){.audio-hint{display:none}}
@media (prefers-reduced-motion:reduce){.audio-toggle.armed{animation:none}}

/* journal inline figures + disclaimer */
.prose .body .jp-fig{margin:clamp(30px,5vh,58px) 0}
.prose .body .jp-fig img{width:100%;height:auto;display:block;border-radius:3px}
.prose .body .jp-disc{font-size:12.5px;line-height:1.6;color:var(--muted);font-style:italic;border-top:1px solid var(--line);padding-top:18px;margin-top:34px}
.prose .body .jp-duo{display:grid;grid-template-columns:1fr 1fr;gap:clamp(12px,1.6vw,22px);margin:clamp(30px,5vh,58px) 0}
.prose .body .jp-duo figure{margin:0}
.prose .body .jp-duo img{width:100%;height:100%;object-fit:cover;display:block;border-radius:3px;aspect-ratio:4/3}
.prose .body .jp-duo figcaption{font-size:12px;letter-spacing:.04em;color:var(--muted);margin-top:10px}
.prose .body .jp-list{list-style:none;margin:1.4em 0 1.7em;padding:0;max-width:64ch;display:grid;gap:.62em}
.prose .body .jp-list li{position:relative;padding-left:1.4em;color:var(--ink);opacity:.86;font-size:clamp(1.02rem,1rem + .25vw,1.14rem);line-height:1.55}
.prose .body .jp-list li::before{content:"";position:absolute;left:0;top:.6em;width:7px;height:7px;background:var(--gold);transform:rotate(45deg)}
.prose .body .jp-list li strong{color:var(--ink);opacity:1;font-weight:600}
@media(max-width:680px){.prose .body .jp-duo{grid-template-columns:1fr}}
/* projects — "selected residences" stripe */
.pf-stripe{padding:clamp(46px,8vh,92px) 0 0}
.pf-stripe .eyebrow{display:block;margin-bottom:14px}
.pf-stripe h2{font-family:var(--f-disp);font-weight:400;letter-spacing:-.01em;font-size:clamp(1.9rem,1rem + 2.8vw,3.2rem)}

/* contact — trust points */
.trust-row{display:flex;flex-wrap:wrap;gap:14px 26px;margin-top:30px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.trust-row span{position:relative;padding-left:22px}
.trust-row span::before{content:"";position:absolute;left:0;top:50%;width:7px;height:7px;border-radius:50%;background:var(--gold);transform:translateY(-50%)}
/* contact — offices */
.offices{padding:clamp(40px,7vh,80px) 0}
.office-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,4vw,56px);margin-top:28px}
.office .o-tag{font-family:var(--f-disp);font-style:italic;color:var(--gold);font-size:1.08rem;margin-bottom:12px}
.office p{color:var(--muted);line-height:1.7}
@media(max-width:760px){.office-grid{grid-template-columns:1fr;gap:28px}}
/* careers — join our team */
.join{padding:clamp(46px,8vh,96px) 0;border-top:1px solid var(--line)}
.join-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(34px,6vw,90px)}
.join-l h2{font-family:var(--f-disp);font-weight:400;font-size:clamp(1.7rem,1rem + 2.4vw,2.8rem);line-height:1.12;margin-top:16px}
.join-r p{margin-bottom:18px;line-height:1.75}
.join-vh{font-family:var(--f-disp);font-style:italic;color:var(--gold);margin-bottom:10px!important}
.join-values{list-style:none;margin:0 0 24px;padding:0;display:grid;gap:10px}
.join-values li{position:relative;padding-left:24px;color:var(--muted)}
.join-values li::before{content:"";position:absolute;left:0;top:.55em;width:7px;height:7px;border-radius:50%;background:var(--gold)}
.join-sign{font-family:var(--f-disp);color:var(--ink);margin-top:8px}
.join-sign span{display:block;font-style:italic;color:var(--muted);font-size:.95rem;margin-top:4px}
@media(max-width:820px){.join-grid{grid-template-columns:1fr;gap:22px}}

/* ---- Profile-style editorial project layout (company-profile mirror) ---- */
.pj-profile{padding:clamp(48px,8vw,116px) 0;border-top:1px solid var(--line)}
.pjp-grid{display:grid;grid-template-columns:1fr 1.04fr;gap:clamp(34px,6vw,92px);align-items:start}
.pjp-copy{position:sticky;top:104px}
.pjp-copy .eyebrow{display:block;margin-bottom:24px}
.pjp-copy h2{font-size:clamp(2rem,1rem + 3.3vw,3.5rem);line-height:1.12;letter-spacing:-.016em;color:var(--ink)}
.pjp-copy h2 em{font-style:italic;color:var(--gold)}
.pjp-meta{margin:30px 0 28px;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;flex-wrap:wrap;gap:12px 28px;align-items:center;justify-content:space-between}
.pjp-proj{font-family:var(--f-disp);font-size:1.18rem;color:var(--ink)}
.pjp-badge{font-family:var(--f-ui);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold);border-radius:100px;padding:8px 16px;white-space:nowrap}
.pjp-lead{font-family:var(--f-disp);font-size:clamp(1.12rem,.92rem+.7vw,1.5rem);font-weight:400;font-style:italic;line-height:1.42;color:var(--ink);margin-bottom:32px}
.pjp-list{list-style:none;display:flex;flex-direction:column;gap:22px}
.pjp-list li{position:relative;padding-left:28px;font-size:1rem;line-height:1.66;color:var(--muted)}
.pjp-list li::before{content:"";position:absolute;left:2px;top:.6em;width:9px;height:9px;border:1px solid var(--gold);transform:rotate(45deg)}
.pjp-list b{font-weight:600;color:var(--ink);font-family:var(--f-ui);letter-spacing:.004em}
.pjp-stack{display:flex;flex-direction:column;gap:clamp(14px,2vw,26px)}
.pjp-stack figure{overflow:hidden;background:var(--paper-2)}
.pjp-stack img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s var(--ease)}
.pjp-stack figure:hover img{transform:scale(1.045)}
.pjp-stack figure:first-child{aspect-ratio:4/5}
.pjp-stack figure:not(:first-child){aspect-ratio:3/2}
@media(max-width:860px){
  .pjp-grid{grid-template-columns:1fr;gap:36px}
  .pjp-copy{position:static}
}

/* ---- Photo-forward journal media: break images out wide of the 64ch text column ---- */
.prose .body .jp-fig,
.prose .body .jp-duo{
  position:relative;left:50%;transform:translateX(-50%);
  width:min(1120px,92vw);
}
.prose .body .jp-duo img{aspect-ratio:3/2}
@media(max-width:680px){
  .prose .body .jp-fig,.prose .body .jp-duo{width:100%;left:0;transform:none}
}
