@font-face{font-family:"Cormorant";src:url("/fonts/cormorant-garamond-500.woff2") format("woff2");font-weight:500;font-display:swap}
@font-face{font-family:"Cormorant";src:url("/fonts/cormorant-garamond-600.woff2") format("woff2");font-weight:600;font-display:swap}
:root{
  --ink:#16140f;--muted:#7a746a;--line:#e7e2d9;--bg:#fbfaf7;--paper:#ffffff;
  --serif:"Cormorant",Georgia,serif;--sans:-apple-system,BlinkMacSystemFont,"Helvetica Neue",Arial,sans-serif;
  --gap:clamp(10px,1.3vw,16px);
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.75;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:1320px;margin:0 auto;padding:0 clamp(20px,5vw,64px)}
.eyebrow{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted)}

/* header — solid by default (interior pages), transparent over hero on home */
header{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px clamp(20px,5vw,64px);background:rgba(251,250,247,.92);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line);color:var(--ink)}
.brand{font-size:15px;letter-spacing:.42em;text-transform:uppercase;font-weight:500;white-space:nowrap}
nav{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:clamp(12px,1.6vw,26px)}
nav a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;opacity:.65;transition:opacity .2s;white-space:nowrap}
nav a:hover,nav a[aria-current=page]{opacity:1}
.nav-toggle{display:none;background:none;border:1px solid currentColor;border-radius:2px;color:inherit;font:inherit;font-size:11px;letter-spacing:.16em;text-transform:uppercase;padding:7px 12px;cursor:pointer}
body.home header{position:absolute;left:0;right:0;background:transparent;backdrop-filter:none;border-bottom:none;color:#ffffff;text-shadow:0 1px 10px rgba(0,0,0,.45)}
body.home nav a{opacity:.9}
body.home nav a:hover,body.home nav a[aria-current=page]{opacity:1}

/* hero */
.hero{position:relative;height:100vh;min-height:620px;color:#fff;display:grid;place-items:center;text-align:center;overflow:hidden;background:#16140f}
.hero picture{position:absolute;inset:0;z-index:0;display:block}
.hero img{width:100%;height:100%;object-fit:cover;object-position:center 42%;opacity:.92}
.hero::after{content:"";position:absolute;inset:0;background:transparent}
.hero-c{position:relative;z-index:2;padding:24px}
.hero-c .eyebrow{color:#ffffff;margin-bottom:22px;text-shadow:0 1px 9px rgba(0,0,0,.42)}
.hero-c h1{font-family:var(--sans);font-weight:500;font-size:clamp(2.5rem,7.2vw,5.8rem);line-height:1;letter-spacing:.05em;text-transform:uppercase;color:#ffffff;text-shadow:0 1px 24px rgba(0,0,0,.4)}
.hero-c .sub{margin-top:20px;font-size:clamp(.72rem,1.5vw,.95rem);letter-spacing:.32em;text-transform:uppercase;color:#ffffff;text-shadow:0 1px 9px rgba(0,0,0,.42)}
.scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:2;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:#ffffff;text-shadow:0 1px 9px rgba(0,0,0,.42)}

/* section intro */
.lead{text-align:center;max-width:720px;margin:clamp(70px,10vw,120px) auto clamp(40px,6vw,70px)}
.lead h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.7rem,3.4vw,2.5rem);line-height:1.32}

/* discipline grid */
.disciplines{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(10px,1.4vw,18px);padding-bottom:clamp(60px,8vw,100px)}
.disc{position:relative;aspect-ratio:4/5;overflow:hidden;background:#ddd}
.disc.wide{grid-column:span 2;aspect-ratio:16/7}
.disc.wide img{object-position:center}
.disc.wide::after{background:none}
.disc.wide .disc-label{text-shadow:0 1px 16px rgba(0,0,0,.55)}
.disc img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .9s cubic-bezier(.2,.7,.2,1);filter:saturate(.97)}
.disc:hover img{transform:scale(1.05)}
.disc::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.5))}
.disc-label{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:28px;color:#fff}
.disc-label .eyebrow{color:rgba(255,255,255,.75)}
.disc-label h3{font-family:var(--serif);font-weight:500;font-size:clamp(1.8rem,3vw,2.8rem);line-height:1;margin-top:6px}

/* interior page head */
.page-head{text-align:center;max-width:860px;margin:0 auto;padding:clamp(64px,9vw,110px) clamp(20px,5vw,64px) clamp(28px,4vw,46px)}
.page-head .eyebrow{margin-bottom:16px}
.page-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,6vw,4.4rem);line-height:1.03}
.page-head p{margin:18px auto 0;color:#4a443b;font-size:clamp(1rem,1.5vw,1.12rem);max-width:680px}

/* gallery */
.gallery{columns:3;column-gap:var(--gap);padding-bottom:clamp(50px,7vw,90px)}
.gtile{display:block;margin:0 0 var(--gap);break-inside:avoid;overflow:hidden;background:#efece6;cursor:zoom-in}
.gtile img{width:100%;height:auto;transition:transform .7s cubic-bezier(.2,.7,.2,1),filter .4s;filter:saturate(.97)}
.gtile:hover img{transform:scale(1.04);filter:saturate(1.04)}

/* bio */
.bio{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.bio-in{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:center;padding:clamp(60px,8vw,110px) clamp(20px,5vw,64px);max-width:1320px;margin:0 auto}
.bio-img{aspect-ratio:4/5;overflow:hidden}
.bio-img img{width:100%;height:100%;object-fit:cover}
.bio h2{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,4vw,3.2rem);line-height:1.05;margin:14px 0 22px}
.bio p{color:#3b362e;margin-bottom:1.2em}
.clients{margin-top:28px;padding-top:24px;border-top:1px solid var(--line)}
.clients .eyebrow{margin-bottom:12px}
.clients .names{font-family:var(--serif);font-size:clamp(1rem,1.6vw,1.25rem);line-height:1.7;color:#2a2620}

/* about / contact text pages */
.prose{max-width:760px;margin:0 auto;padding-bottom:clamp(50px,7vw,90px)}
.prose p{margin-bottom:1.3em;color:#3b362e}
.contact-block{text-align:center;max-width:620px;margin:0 auto;padding-bottom:clamp(50px,7vw,90px)}
.btn{display:inline-block;font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:15px 34px;border:1px solid var(--ink);border-radius:2px;transition:background .25s,color .25s}
.btn:hover{background:var(--ink);color:#fff}
.contact-meta{list-style:none;margin:36px auto 0;max-width:520px;text-align:left}
.contact-meta li{display:flex;gap:18px;padding:16px 0;border-top:1px solid var(--line)}
.contact-meta li strong{flex:0 0 120px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:500;padding-top:3px}
.contact-meta a{border-bottom:1px solid var(--line)}
.contact-meta a:hover{border-color:var(--ink)}

/* press quote */
.press{text-align:center;padding:clamp(70px,10vw,130px) clamp(20px,5vw,64px);max-width:980px;margin:0 auto}
.press blockquote{font-family:var(--serif);font-weight:500;font-size:clamp(1.6rem,3.4vw,2.6rem);line-height:1.3;font-style:italic}
.press .cite{margin-top:24px;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}

/* footer */
footer{background:#16140f;color:#cfc8bc;text-align:center;padding:clamp(60px,8vw,96px) 24px}
footer .fbrand{font-family:var(--serif);font-size:clamp(2rem,4vw,3rem);color:#fff;font-weight:500}
footer .meta{margin-top:18px;font-size:12px;letter-spacing:.24em;text-transform:uppercase}
footer a.mail{color:#fff;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:2px}
footer .loc{margin-top:14px;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:#8c857a}
footer .fnav{margin-top:26px;display:flex;gap:20px;justify-content:center;flex-wrap:wrap}
footer .fnav a{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#9a9286}
footer .fnav a:hover{color:#fff}
footer .net{margin-top:24px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#6f685d}

/* lightbox */
.lb{position:fixed;inset:0;z-index:100;background:rgba(14,12,9,.95);display:none;place-items:center;padding:3vmin}
.lb.open{display:grid}
.lb img{max-width:94vw;max-height:90vh;width:auto;height:auto}
.lb-btn{position:absolute;background:none;border:none;color:#fff;cursor:pointer;opacity:.8;transition:opacity .2s;line-height:1}
.lb-btn:hover{opacity:1}
.lb-close{top:20px;right:26px;font-size:34px}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);font-size:46px;padding:10px 18px}
.lb-prev{left:8px}.lb-next{right:8px}

@media(max-width:980px){.gallery{columns:2}}
@media(max-width:760px){
  .nav-toggle{display:block}
  nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;gap:0;background:var(--bg);border-bottom:1px solid var(--line)}
  body.home header{background:rgba(251,250,247,.96);backdrop-filter:saturate(180%) blur(10px);position:sticky;color:var(--ink);border-bottom:1px solid var(--line)}
  nav.open{display:flex}
  nav a{padding:14px clamp(20px,5vw,64px);border-bottom:1px solid var(--line);opacity:.8}
  body.home nav a{opacity:.8}
  .hero-c h1{font-size:clamp(1.9rem,9.2vw,2.9rem);letter-spacing:.02em}
  .hero-c .eyebrow{font-size:10px;letter-spacing:.14em}
  .hero-c .sub{font-size:10.5px;letter-spacing:.13em}
  .disciplines{grid-template-columns:1fr}
  .disc.wide{grid-column:span 1;aspect-ratio:4/5}
  .bio-in{grid-template-columns:1fr}
  .bio-img{order:-1;max-height:60vh}
  .gallery{columns:1}
  .contact-meta li{flex-direction:column;gap:4px}
  .contact-meta li strong{flex:none}
}
