
:root{
  --paper:#f5f2ea;--ink:#1a1814;--ink2:#3a352b;--muted:#56503f;--faint:#8a8270;
  --acc:#1b3be0;--line:rgba(26,24,20,.15);--line2:rgba(26,24,20,.1);--plate:#efe9db;
  --serif:'Newsreader',Georgia,'Times New Roman',serif;
  --sans:'Archivo',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);overflow-x:hidden;position:relative;-webkit-font-smoothing:antialiased;line-height:1.5}
::selection{background:var(--acc);color:var(--paper)}
a{color:inherit;text-decoration:none}
.serif{font-family:var(--serif);font-weight:300}
.faint{color:var(--faint)}
em{font-style:italic}
/* decorative diamond motif */
.motif{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.motif-a{position:absolute;top:-180px;right:-160px;opacity:.7}
.motif-b{position:absolute;bottom:-130px;left:-120px;opacity:.7}
main{position:relative;z-index:1}
.wrap{max-width:1280px;margin:0 auto;padding-left:clamp(20px,6vw,72px);padding-right:clamp(20px,6vw,72px)}
/* nav */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:20px clamp(20px,6vw,72px);background:rgba(245,242,234,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--line2)}
.nav .brand img{display:block}
.nav-links{display:flex;align-items:center;gap:34px}
.nlink{color:var(--muted);font-size:14px;font-weight:500;border-bottom:1.5px solid transparent;padding-bottom:2px;transition:color .2s,border-color .2s}
.nlink:hover{color:var(--acc)}
.nlink.on{color:var(--acc);font-weight:600;border-color:var(--acc)}
.nlink.cta{color:var(--ink);font-weight:600;border-color:var(--ink)}
.nlink.cta:hover{color:var(--acc);border-color:var(--acc)}
.nav-toggle{display:none;background:none;border:none;color:var(--ink);font-size:26px;line-height:1;min-width:44px;min-height:44px;cursor:pointer}
.mobile-menu{display:none;position:fixed;inset:0;z-index:49;background:var(--paper);flex-direction:column;align-items:center;justify-content:center;gap:26px}
.mobile-menu a{font-family:var(--serif);font-size:30px;color:var(--ink)}
.mobile-menu a:last-child{color:var(--acc)}
body.menu-open .mobile-menu{display:flex}
/* links */
.underlink{display:inline-flex;align-items:center;gap:8px;color:var(--ink);font-size:15px;font-weight:600;border-bottom:1.5px solid var(--ink);padding-bottom:3px;transition:color .2s,border-color .2s}
.underlink:hover{color:var(--acc);border-color:var(--acc)}
/* hero */
.hero{padding-top:clamp(50px,9vw,120px);padding-bottom:clamp(40px,6vw,80px)}
.eyebrow{display:flex;align-items:center;gap:16px;margin-bottom:40px}
.eyebrow span:not(.rule){font-size:12px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--faint)}
.eyebrow .rule{flex:1;height:1px;background:var(--line)}
.hero-h1{font-size:clamp(44px,8.5vw,118px);line-height:.98;letter-spacing:-2px;max-width:13ch}
.hero-h1 em{color:var(--acc)}
.hero-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:40px;margin-top:54px;align-items:end}
.hero-lead{font-size:clamp(19px,2.4vw,26px);line-height:1.5;color:var(--ink2);max-width:30ch}
.hero-aside p{font-size:15px;line-height:1.7;color:var(--muted);max-width:34ch;margin-bottom:22px}
.hero-plate{margin-top:64px;height:clamp(220px,38vw,440px);border:1px solid var(--line);background:repeating-linear-gradient(135deg,#eae3d4 0,#ece5d6 1px,transparent 1px,transparent 11px),var(--plate);display:flex;align-items:flex-end;justify-content:space-between;padding:24px 28px}
.plate-cap{font-size:clamp(18px,2.4vw,28px);color:var(--ink)}
.plate-tag{font-size:11px;letter-spacing:1px;color:var(--faint);text-transform:uppercase}
/* marquee */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;white-space:nowrap;padding:20px 0;margin-top:20px}
.marquee-track{display:inline-block;font-style:italic;font-size:clamp(20px,2.6vw,34px);color:var(--ink);animation:ebxMarq 34s linear infinite;will-change:transform}
@keyframes ebxMarq{to{transform:translateX(-50%)}}
/* sections */
.sec{padding-top:clamp(50px,7vw,100px);padding-bottom:clamp(10px,2vw,24px)}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-bottom:36px}
.sec-head h2{font-family:var(--serif);font-weight:400;font-size:clamp(26px,3.5vw,40px)}
.sec-foot{margin-top:34px}
/* row list (services + work) */
.rows{border-top:1px solid var(--line)}
.row{display:grid;grid-template-columns:52px 1fr auto;gap:24px;align-items:baseline;padding:26px 0;border-bottom:1px solid var(--line);color:inherit;transition:padding .25s ease,background .25s}
.row:hover{padding-left:12px;background:rgba(27,59,224,.02)}
.row-num{font-family:var(--serif);font-size:15px;color:var(--faint)}
.row-body h3{font-family:var(--serif);font-weight:400;font-size:clamp(20px,2.7vw,32px);color:var(--ink);margin-bottom:8px;line-height:1.15}
.row-body p{font-size:14.5px;line-height:1.6;color:var(--muted);max-width:64ch}
.row-mark,.row-tag{color:var(--faint);white-space:nowrap;font-size:13px;letter-spacing:.5px;transition:color .2s}
.row-mark{font-size:22px}
.row:hover .row-mark,.row:hover .row-tag{color:var(--acc)}
/* about */
.about{max-width:980px}
.about-quote{font-size:clamp(24px,4vw,46px);line-height:1.3;letter-spacing:-.5px;text-align:center;color:var(--ink)}
.about-quote em{color:var(--acc)}
/* contact */
.contact h2{font-weight:300;font-size:clamp(34px,5vw,60px);line-height:1.04;letter-spacing:-1px}
.contact-lead{margin-top:20px;font-size:16px;line-height:1.7;color:var(--muted);max-width:44ch}
.contact-info{display:flex;flex-wrap:wrap;gap:36px;margin:40px 0 34px}
.ci-k{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--faint);margin-bottom:6px}
.ci-v{font-size:20px;color:var(--ink)}
a.ci-v:hover{color:var(--acc)}
.btn{display:inline-block;padding:16px 36px;background:var(--ink);color:var(--paper);font-size:15px;font-weight:600;letter-spacing:.3px;transition:background .2s}
.btn:hover{background:var(--acc)}
/* doc + prose */
.doc,.doc-head{padding-top:clamp(46px,7vw,90px)}
.doc{max-width:900px}
.crumb{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--faint);margin-bottom:26px}
.crumb a:hover{color:var(--acc)}.crumb .cur{color:var(--ink)}.crumb span{color:var(--faint)}
.doc h1,.doc-head h1{font-weight:300;font-size:clamp(34px,5.5vw,68px);line-height:1.02;letter-spacing:-1.5px;max-width:16ch}
.doc-head h1.big{font-size:clamp(40px,8vw,104px);letter-spacing:-2px}
.doc h1 em,.doc-head h1 em{color:var(--acc)}
.head-lead{font-size:clamp(18px,2.2vw,24px);line-height:1.5;color:var(--ink2);max-width:40ch;margin-top:28px}
.art-meta,.art-h1{max-width:680px}
.art-meta{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--faint);margin-bottom:20px}
.article h1.art-h1{font-size:clamp(32px,4.5vw,56px)}
.article .prose{margin-left:0;margin-right:0}
.prose{max-width:680px;margin-top:30px;color:var(--ink2);font-size:17px;line-height:1.75}
.prose>p:first-child{margin-top:0}
.prose h1,.prose h2,.prose h3,.prose h4{font-family:var(--serif);font-weight:400;color:var(--ink);line-height:1.2;letter-spacing:-.3px}
.prose h2{font-size:clamp(24px,3vw,32px);margin:1.7em 0 .5em;padding-top:.3em;border-top:1px solid var(--line)}
.prose h3{font-size:clamp(20px,2.4vw,25px);margin:1.5em 0 .45em}
.prose h4{font-size:19px;margin:1.4em 0 .4em}
.prose p{margin:0 0 1.15em}
.prose ul,.prose ol{margin:0 0 1.2em 1.3em}
.prose li{margin:.4em 0;padding-left:.2em}
.prose li::marker{color:var(--acc)}
.prose a{color:var(--acc);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.prose a:hover{text-decoration-thickness:2px}
.prose strong{font-weight:600;color:var(--ink)}
.prose img{max-width:100%;height:auto;display:block;border:1px solid var(--line);margin:1.6em 0}
.prose blockquote{border-left:2px solid var(--acc);padding:.2em 0 .2em 22px;margin:1.4em 0;font-family:var(--serif);font-style:italic;font-size:1.15em;color:var(--ink)}
.prose code{font-family:'Newsreader',ui-monospace,monospace;background:rgba(27,59,224,.07);padding:2px 6px;border-radius:3px;font-size:.92em}
.prose pre{background:#efe9db;border:1px solid var(--line);padding:16px 18px;overflow:auto;margin:1.4em 0}
.prose pre code{background:none;padding:0}
.prose hr{border:none;border-top:1px solid var(--line);margin:2em 0}
.doc-cta{margin-top:44px;padding-top:30px;border-top:1px solid var(--line);display:flex;align-items:baseline;gap:20px;flex-wrap:wrap}
.doc-cta .serif{font-size:clamp(20px,2.6vw,28px);color:var(--ink)}
/* blog grid */
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1px;background:var(--line);border:1px solid var(--line)}
.post-card{display:flex;flex-direction:column;gap:12px;background:var(--paper);padding:32px 28px;transition:background .25s}
.post-card:hover{background:#efe9db}
.post-meta{font-size:12px;letter-spacing:.8px;text-transform:uppercase;color:var(--faint);display:flex;gap:8px;align-items:center}
.post-meta .dotsep{opacity:.6}
.post-card h3{font-family:var(--serif);font-weight:400;font-size:clamp(21px,2.4vw,27px);line-height:1.2;color:var(--ink)}
.post-card p{font-size:14.5px;line-height:1.6;color:var(--muted);flex:1}
.read-more{font-size:13px;font-weight:600;color:var(--acc)}
/* footer */
.footer{position:relative;z-index:1;border-top:1px solid var(--line);background:var(--paper);color:var(--muted)}
.foot-grid{max-width:1280px;margin:0 auto;padding:56px clamp(20px,6vw,72px) 32px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:36px}
.foot-brand{max-width:300px}
.foot-brand img{display:block;margin-bottom:18px}
.foot-brand p{font-size:16px;line-height:1.6;color:var(--ink2)}
.foot-h{font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--faint);margin-bottom:16px}
.foot-col{display:flex;flex-direction:column;gap:10px;font-family:var(--serif);font-size:15px}
.foot-col a{color:var(--muted)}
.foot-col a:hover{color:var(--acc)}
.foot-base{border-top:1px solid var(--line2);max-width:1280px;margin:0 auto;padding:22px clamp(20px,6vw,72px);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:13px}
.foot-base a:hover{color:var(--acc)}
.foot-legal{display:flex;gap:24px}
/* reveal */
[data-rv]{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .85s cubic-bezier(.16,1,.3,1)}
[data-rv].in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){[data-rv]{opacity:1!important;transform:none!important}.marquee-track{animation:none}}
@media (max-width:820px){[data-desk]{display:none!important}[data-mob]{display:inline-flex!important}.nav-links{display:none}}
@media (max-width:600px){.row{grid-template-columns:36px 1fr;gap:16px}.row-tag,.row-mark{display:none}}
/* loader overlay — above everything */
#ebx-loader{position:fixed;inset:0;z-index:99999;background:var(--paper);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;transition:opacity .5s ease}
.ldr-eyebrow{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--faint);margin-bottom:30px}
.ldr-logo{height:clamp(48px,9vw,84px);width:auto;display:block}
.ldr-bar{display:flex;align-items:center;gap:18px;margin-top:42px;width:min(340px,74vw)}
.ldr-num{font-family:var(--serif);font-size:14px;letter-spacing:1px;color:var(--faint);font-variant-numeric:tabular-nums}
.ldr-end{color:var(--acc)}
.ldr-rail{flex:1;height:1px;background:rgba(26,24,20,.2);position:relative;overflow:hidden}
.ldr-fill{position:absolute;left:0;top:0;height:100%;width:0;background:var(--acc);animation:ebxFill 2.2s ease forwards}
@keyframes ebxFill{from{width:0}to{width:100%}}
@keyframes ebxLoadOut{0%,80%{opacity:1;visibility:visible}100%{opacity:0;visibility:hidden}}
@media (prefers-reduced-motion:reduce){#ebx-loader{display:none!important}}
/* page transition — warm-paper curtains meeting/parting in the middle */
#ebx-transition{position:fixed;inset:0;z-index:99998;pointer-events:none;display:none;overflow:hidden;--tr-ms:780ms}
#ebx-transition .tr-half{position:absolute;top:0;height:100%;width:50.5%;background:#f5f2ea}
#ebx-transition .tr-l{left:0;border-right:1px solid rgba(27,59,224,.25)}
#ebx-transition .tr-r{right:0}
#ebx-transition .tr-content{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}
#ebx-transition .tr-word{font-family:var(--serif);font-style:italic;font-weight:300;font-size:clamp(30px,5vw,52px);letter-spacing:-1px;color:var(--ink)}
#ebx-transition .tr-rule{width:70px;height:1px;background:rgba(26,24,20,.3)}
/* arrival (internal-nav): curtains meet, fully covering */
html.ebxnav #ebx-transition{display:block}
html.ebxnav #ebx-transition .tr-half{transform:translateX(0)}
/* reveal: covered → open, curtains part outward */
#ebx-transition.ebx-reveal .tr-l{animation:trCurtainL var(--tr-ms) cubic-bezier(.76,0,.24,1) forwards}
#ebx-transition.ebx-reveal .tr-r{animation:trCurtainR var(--tr-ms) cubic-bezier(.76,0,.24,1) forwards}
#ebx-transition.ebx-reveal .tr-content{animation:trWordOut .34s ease forwards}
/* cover: open → covered, curtains close inward */
#ebx-transition.ebx-cover .tr-l{transform:translateX(-101%);animation:trCurtainLin var(--tr-ms) cubic-bezier(.76,0,.24,1) forwards}
#ebx-transition.ebx-cover .tr-r{transform:translateX(101%);animation:trCurtainRin var(--tr-ms) cubic-bezier(.76,0,.24,1) forwards}
#ebx-transition.ebx-cover .tr-content{opacity:0;animation:trWordIn .3s ease .32s forwards}
@keyframes trCurtainL{from{transform:translateX(0)}to{transform:translateX(-101%)}}
@keyframes trCurtainR{from{transform:translateX(0)}to{transform:translateX(101%)}}
@keyframes trCurtainLin{from{transform:translateX(-101%)}to{transform:translateX(0)}}
@keyframes trCurtainRin{from{transform:translateX(101%)}to{transform:translateX(0)}}
@keyframes trWordOut{from{opacity:1}to{opacity:0}}
@keyframes trWordIn{from{opacity:0}to{opacity:1}}
@media (prefers-reduced-motion:reduce){#ebx-transition{display:none!important}}
