:root{
  --ink:#111111;
  --paper:#FAF8F5;
  --sand:#C9BCA8;
  --tint:#ECE6DB;
  --stone:#7A736A;
  --serif:"Playfair Display", Didot, "Times New Roman", serif;
  --sans:"Jost", Futura, "Century Gothic", sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:860px;margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

.label{
  font-family:var(--sans);font-weight:400;
  text-transform:uppercase;letter-spacing:.36em;
  font-size:12px;color:var(--stone);
}
.caption{
  font-family:var(--sans);font-weight:400;
  text-transform:uppercase;letter-spacing:.26em;
  font-size:10.5px;color:var(--stone);
}
.caption .dot{color:var(--sand)}

/* ---------- NAV ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 28px;
  background:rgba(250,248,245,0);
  transition:background .4s ease, padding .4s ease, border-color .4s ease;
  border-bottom:1px solid transparent;
}
nav.scrolled{
  background:rgba(250,248,245,.93);
  backdrop-filter:blur(10px);
  padding:11px 28px;
  border-bottom:1px solid var(--tint);
}
.brand{display:flex;align-items:center;gap:12px}
.brand-tx{display:flex;flex-direction:column;line-height:1.05;opacity:0;transition:opacity .4s ease}
nav.scrolled .brand-tx{opacity:1}
.brand-name{font-family:var(--serif);font-size:20px;letter-spacing:.03em}
.brand-sub{font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--stone);margin-top:3px}
/* arch mark */
.arch{display:block}
.arch-line{fill:none;stroke:var(--ink);stroke-width:6;stroke-linecap:butt;stroke-linejoin:round}
.arch-dot{fill:var(--sand)}
.arch-sm{height:34px;width:auto;transition:filter .4s ease}
nav:not(.scrolled) .arch-sm .arch-line{stroke:#fff}
.arch-cover{height:46px;width:auto;margin:0 auto 22px;opacity:0;animation:rise 1s ease .1s forwards}
.arch-cover .arch-line{stroke:#fff}
.arch-foot{height:48px;width:auto;margin-bottom:6px}
.arch-foot .arch-line{stroke:var(--paper)}
.arch-foot .arch-dot{fill:var(--sand)}
.nav-right{display:flex;gap:26px;align-items:center}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#fff;opacity:.82;transition:opacity .3s,color .4s}
nav.scrolled .nav-links a{color:var(--ink);opacity:.7}
.nav-links a:hover{opacity:1}
.lang{display:flex;gap:2px;align-items:center;border:1px solid rgba(255,255,255,.5);border-radius:2px;overflow:hidden;transition:border-color .4s}
nav.scrolled .lang{border-color:var(--sand)}
.lang-btn{
  font-family:var(--sans);background:transparent;border:0;cursor:pointer;
  font-size:11px;letter-spacing:.12em;padding:6px 10px;color:#fff;opacity:.8;transition:all .25s;
}
nav.scrolled .lang-btn{color:var(--stone);opacity:1}
.lang-btn.on{background:#fff;color:var(--ink);opacity:1}
nav.scrolled .lang-btn.on{background:var(--ink);color:var(--paper)}
@media(max-width:820px){.nav-links{display:none}}

/* ---------- COVER ---------- */
.cover{
  position:relative;min-height:100svh;overflow:hidden;
  display:flex;flex-direction:column;color:#fff;
}
.cover-media{position:absolute;inset:0;z-index:0}
.cover-media img{width:100%;height:100%;object-fit:cover;object-position:center 28%}
.cover-scrim{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(to bottom, rgba(17,17,17,.58) 0%, rgba(17,17,17,.14) 26%, rgba(17,17,17,.10) 52%, rgba(17,17,17,.78) 100%);
}
.cover-inner{
  position:relative;z-index:2;flex:1;
  display:flex;flex-direction:column;text-align:center;align-items:center;
  padding:clamp(92px,12vh,150px) clamp(22px,5vw,60px) clamp(46px,8vh,86px);
}
.cover-issue{
  font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.85);
  opacity:0;animation:rise 1s ease .15s forwards;
  display:flex;align-items:center;gap:16px;
}
.cover-issue::before,.cover-issue::after{content:'';width:34px;height:1px;background:rgba(255,255,255,.5)}
.cover-masthead{
  font-family:var(--serif);font-weight:600;text-transform:uppercase;
  font-size:clamp(44px,13.2vw,188px);line-height:.92;letter-spacing:.015em;
  margin:auto 0 0;color:#fff;text-shadow:0 2px 40px rgba(0,0,0,.28);
  opacity:0;animation:rise 1.1s ease .3s forwards;
}
.cover-strap{
  font-size:clamp(11px,1.5vw,15px);letter-spacing:.52em;text-transform:uppercase;
  color:rgba(255,255,255,.92);margin-top:20px;
  opacity:0;animation:rise 1s ease .5s forwards;
}
.cover-rule{width:54px;height:1px;background:var(--sand);margin:26px auto 0;opacity:0;animation:fade 1s ease .65s forwards}
.cover-lines{margin-top:auto;padding-top:34px;opacity:0;animation:rise 1s ease .75s forwards}
.coverline-main{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(18px,2.7vw,29px);line-height:1.4;max-width:720px;margin:0 auto 16px;
  color:#fff;text-shadow:0 1px 24px rgba(0,0,0,.35);
}
.coverline-sub{color:rgba(255,255,255,.86)}
.scroll-hint{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:3;opacity:0;animation:fade 1.2s ease 1.4s forwards}
.scroll-hint span{display:block;width:1px;height:44px;background:var(--sand);margin:0 auto;animation:pulse 2.4s ease infinite}
@keyframes rise{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes fade{to{opacity:1}}
@keyframes pulse{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ---------- GENERAL SECTION ---------- */
section{padding:clamp(72px,11vh,128px) 0}
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}
.divider{width:58px;height:1px;background:var(--sand);margin:0 0 24px}
.divider.center{margin:0 auto 24px}
.kicker{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;max-width:680px;margin:0 auto clamp(46px,7vh,78px)}
.kicker h2{font-family:var(--serif);font-weight:500;font-size:clamp(30px,5vw,56px);line-height:1.08}
.kicker p{color:var(--stone);font-size:16px;max-width:560px}
.folio-tag{font-family:var(--serif);font-style:italic;font-size:15px;color:var(--sand);letter-spacing:.05em}

/* ---------- ABOUT / THE ARCHITECT ---------- */
.about{background:var(--paper)}
.about-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(34px,5vw,72px);align-items:center}
@media(max-width:880px){.about-grid{grid-template-columns:1fr;gap:34px}}
.plate{position:relative;overflow:hidden;background:var(--tint)}
.plate::before{
  content:'';position:absolute;inset:0;z-index:0;opacity:.26;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 120'%3E%3Cpath d='M16 116 V56 a34 34 0 0 1 68 0 V116' fill='none' stroke='%237A736A' stroke-width='2.5'/%3E%3Cline x1='50' y1='22' x2='50' y2='116' stroke='%237A736A' stroke-width='1'/%3E%3C/svg%3E") center/34% no-repeat;
}
.plate img{position:relative;z-index:1;width:100%;height:100%;object-fit:cover}
.about-plate{aspect-ratio:4/5}
.about-figure figcaption{margin-top:12px}
.about-tx .label{display:block;margin-bottom:6px}
.about-tx h2{font-family:var(--serif);font-weight:500;font-size:clamp(28px,4.2vw,48px);line-height:1.1;margin-top:6px}
.about-body{margin-top:22px}
.about-body p{color:var(--stone);font-size:17px;margin-bottom:16px}
.about-body p:first-of-type::first-letter{
  font-family:var(--serif);font-weight:500;float:left;font-size:62px;line-height:.78;
  padding:6px 12px 0 0;color:var(--ink);
}
.about-body p strong{color:var(--ink);font-weight:400}
.pull{font-family:var(--serif);font-style:italic;color:var(--ink);font-size:20px;line-height:1.4;border-top:1px solid var(--tint);padding-top:20px;margin-top:6px}

/* ---------- FEATURE OPENER (full-bleed) ---------- */
.feature{position:relative;height:clamp(440px,92vh,920px);overflow:hidden;background:var(--ink)}
.feature img{width:100%;height:100%;object-fit:cover;opacity:.94}
.feature-cap{
  position:absolute;left:0;right:0;bottom:0;z-index:2;color:#fff;
  padding:clamp(28px,6vw,86px) clamp(24px,6vw,86px) clamp(30px,5vw,68px);
  background:linear-gradient(to top, rgba(17,17,17,.74), rgba(17,17,17,.12) 70%, transparent);
}
.feature-cap .label{color:rgba(255,255,255,.8)}
.feature-cap h2{font-family:var(--serif);font-weight:500;font-size:clamp(32px,6.6vw,86px);line-height:1.02;margin:12px 0 14px;max-width:14ch}
.feature-cap p{font-family:var(--serif);font-style:italic;font-size:clamp(16px,2vw,23px);color:rgba(255,255,255,.92);max-width:640px;line-height:1.45}

/* ---------- SPREADS (alternating half-bleed) ---------- */
.spread{display:grid;grid-template-columns:1.02fr .98fr;align-items:stretch;background:var(--paper)}
.spread .plate{min-height:clamp(420px,84vh,860px)}
.spread .readout{
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(40px,6.5vw,104px);
}
.spread .readout .rn{font-family:var(--serif);font-style:italic;font-size:clamp(34px,4vw,52px);color:var(--sand);line-height:1;margin-bottom:18px}
.spread .readout h3{font-family:var(--serif);font-weight:500;font-size:clamp(26px,3.4vw,42px);line-height:1.1;margin-bottom:18px}
.spread .readout p{color:var(--stone);font-size:17px;max-width:46ch}
.spread .readout .caption{margin-top:26px}
.spread.flip .plate{order:2}
.spread.flip .readout{order:1}
@media(max-width:880px){
  .spread{grid-template-columns:1fr}
  .spread .plate{min-height:64vh}
  .spread.flip .plate{order:0}
  .spread.flip .readout{order:0}
}

/* ---------- THE FACTS (credentials) ---------- */
.creds{background:var(--ink);color:var(--paper)}
.creds .topline{display:flex;align-items:center;gap:18px;justify-content:center;margin-bottom:46px}
.creds .topline::before,.creds .topline::after{content:'';width:40px;height:1px;background:rgba(255,255,255,.3)}
.creds .topline .label{color:var(--sand)}
.creds .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
@media(max-width:780px){.creds .grid{grid-template-columns:repeat(2,1fr);gap:46px 20px}}
.cred .n{font-family:var(--serif);font-size:clamp(28px,3.6vw,44px);font-weight:500;margin-bottom:10px}
.cred .t{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--sand)}

/* ---------- THE METHOD (approach) ---------- */
.approach{background:var(--tint)}
.method-grid{border-top:1px solid rgba(17,17,17,.18);display:grid;grid-template-columns:repeat(3,1fr)}
.method{padding:clamp(34px,3vw,50px) clamp(26px,2.4vw,38px) clamp(34px,3vw,46px);border-right:1px solid rgba(17,17,17,.12)}
.method:last-child{border-right:0}
.method .rn{font-family:var(--serif);font-style:italic;font-size:40px;color:var(--sand);line-height:1;margin-bottom:18px}
.method h3{font-family:var(--serif);font-weight:500;font-size:23px;margin-bottom:12px}
.method p{color:var(--stone);font-size:15.5px}
@media(max-width:780px){
  .method-grid{grid-template-columns:1fr}
  .method{border-right:0;border-bottom:1px solid rgba(17,17,17,.12)}
  .method:last-child{border-bottom:0}
}

/* ---------- ENQUIRIES (contact) ---------- */
.contact{text-align:center;background:var(--paper)}
.contact h2{font-family:var(--serif);font-weight:500;font-style:italic;font-size:clamp(32px,5.6vw,64px);margin-bottom:22px;line-height:1.05}
.contact p{color:var(--stone);max-width:560px;margin:0 auto 16px;font-size:17px}
.phone-line{font-family:var(--serif);font-size:clamp(24px,3.2vw,34px);margin:10px auto 36px;letter-spacing:.02em}
.phone-line a:hover{color:var(--stone)}
.socials{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn{
  font-family:var(--sans);font-weight:400;text-transform:uppercase;letter-spacing:.22em;font-size:12px;
  padding:15px 30px;border:1px solid var(--ink);transition:all .35s ease;cursor:pointer;display:inline-block;
}
.btn:hover{background:var(--ink);color:var(--paper)}
.btn.ghost{border-color:var(--sand);color:var(--stone)}
.btn.ghost:hover{background:var(--sand);color:var(--ink);border-color:var(--sand)}

/* ---------- FOOTER / COLOPHON ---------- */
footer{background:var(--ink);color:var(--paper);padding:64px 0 42px}
footer .wrap{display:flex;flex-direction:column;align-items:center;text-align:center;gap:15px}
footer .fbrand{font-family:var(--serif);font-size:22px;letter-spacing:.03em}
footer .fsub{font-size:9px;letter-spacing:.34em;text-transform:uppercase;color:var(--sand);margin-top:-7px}
footer .fsoc{display:flex;gap:22px;margin-top:6px;flex-wrap:wrap;justify-content:center}
footer .fsoc a{font-size:11px;letter-spacing:.22em;text-transform:uppercase;opacity:.72;transition:opacity .3s}
footer .fsoc a:hover{opacity:1}
footer .fphone{font-size:13px;letter-spacing:.06em;color:var(--paper);opacity:.9}
footer .disc{font-size:11px;color:var(--sand);max-width:600px;line-height:1.8;opacity:.85}
footer .copy{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--stone);margin-top:4px}

/* ============ MULTI-PAGE ADDITIONS ============ */
/* inner (non-home) pages: nav is solid from the top */
body.inner nav{background:rgba(250,248,245,.96);backdrop-filter:blur(10px);padding:11px 28px;border-bottom:1px solid var(--tint)}
body.inner .brand-tx{opacity:1}
body.inner .arch-sm .arch-line{stroke:var(--ink)}
body.inner .nav-links a{color:var(--ink);opacity:.7}
body.inner .nav-links a:hover{opacity:1}
body.inner .nav-links a.current{opacity:1;border-bottom:1px solid var(--sand);padding-bottom:3px}
body.inner .lang{border-color:var(--sand)}
body.inner .lang-btn{color:var(--stone);opacity:1}
body.inner .lang-btn.on{background:var(--ink);color:var(--paper)}

/* sub-page header */
.page-hero{padding:clamp(124px,19vh,188px) 0 clamp(36px,6vh,64px);background:var(--paper);text-align:center}
.page-hero .label{display:block;margin-bottom:14px}
.page-hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(38px,7vw,82px);line-height:1.03}
.page-hero p{color:var(--stone);max-width:600px;margin:18px auto 0;font-size:17px}
.page-hero .divider{margin:24px auto 0}

/* home intro */
.intro{background:var(--paper);text-align:center}
.intro .lede{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(22px,3.5vw,40px);line-height:1.3;max-width:20ch;margin:0 auto;color:var(--ink)}
.intro .sub{color:var(--stone);max-width:540px;margin:22px auto 0;font-size:16px}

/* home teasers */
.teasers{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--tint)}
@media(max-width:820px){.teasers{grid-template-columns:1fr}}
.teaser{position:relative;display:block;min-height:clamp(330px,48vh,500px);overflow:hidden;background:var(--ink)}
.teaser img{width:100%;height:100%;object-fit:cover;opacity:.84;transition:transform .9s ease,opacity .5s}
.teaser:hover img{transform:scale(1.05);opacity:.66}
.teaser .tcap{position:absolute;left:0;right:0;bottom:0;padding:30px;color:#fff;z-index:2;background:linear-gradient(to top,rgba(17,17,17,.82),rgba(17,17,17,.05) 78%,transparent)}
.teaser .tcap span{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--sand)}
.teaser .tcap h3{font-family:var(--serif);font-weight:500;font-size:clamp(22px,2.4vw,28px);margin-top:8px}
.teaser .tcap .arrow{margin-top:10px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;opacity:.86}

/* journal / blog */
.blog-list{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(26px,4vw,56px)}
@media(max-width:780px){.blog-list{grid-template-columns:1fr}}
.post-card{display:flex;flex-direction:column}
.post-card .pimg{aspect-ratio:3/2;overflow:hidden;background:var(--tint);margin-bottom:20px}
.post-card .pimg img{width:100%;height:100%;object-fit:cover;transition:transform .9s}
.post-card:hover .pimg img{transform:scale(1.04)}
.post-card .pmeta{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--sand);margin-bottom:10px}
.post-card h3{font-family:var(--serif);font-weight:500;font-size:clamp(22px,2.6vw,31px);line-height:1.16;margin-bottom:10px}
.post-card p{color:var(--stone);font-size:16px}
.post-card .more{margin-top:15px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--sand);padding-bottom:3px;align-self:flex-start;transition:color .3s,border-color .3s}
.post-card .more:hover{color:var(--stone)}

/* contact page block */
.contact-block{text-align:center}
.contact-block .phone-line{font-family:var(--serif);font-size:clamp(26px,3.4vw,38px);margin:14px auto 30px}
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;text-align:center;margin-top:46px;border-top:1px solid var(--tint);padding-top:40px}
@media(max-width:760px){.contact-grid{grid-template-columns:1fr;gap:30px}}
.contact-grid .ci .label{display:block;margin-bottom:8px}
.contact-grid .ci a,.contact-grid .ci span{color:var(--ink);font-size:16px}

