:root{
  --bg:#0F0F0F;
  --bg-2:#0a0a0a;
  --panel:#111111;
  --bone:#F5F5F0;
  --muted:#9a9a9a;
  --muted-2:#6f6f6f;
  --line:rgba(255,255,255,0.08);
  --line-2:rgba(255,255,255,0.12);
  --accent:#D4AF37;
  --max:1200px;
  --pad:32px;
  --serif:'Cormorant Garamond', serif;
  --sans:'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--sans);
  background:var(--bg);
  color:var(--bone);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button,input,textarea{font:inherit; color:inherit}
::selection{background:rgba(212,175,55,0.25); color:var(--bone);}

.container{max-width:var(--max); margin:0 auto; padding:0 var(--pad);}
.section{padding:128px 0;}
.section--tight{padding:88px 0;}
.section--panel{background:var(--panel);}
.section--dark{background:var(--bg-2);}
.hr{height:1px; background:var(--line); border:0; margin:0;}
.mono{letter-spacing:0.22em; text-transform:uppercase; font-size:10px; color:var(--muted);}
.serif{font-family:var(--serif);}
.small{font-size:13px; line-height:1.7; color:var(--muted);}
.lead{font-size:14px; line-height:1.9; color:rgba(245,245,240,0.75); font-weight:300;}
.h1{
  font-family:var(--serif);
  font-weight:300;
  line-height:0.9;
  margin:0 0 28px;
  font-size:clamp(44px, 7vw, 120px);
}
.h2{
  font-family:var(--serif);
  font-weight:400;
  line-height:1.05;
  margin:0 0 18px;
  font-size:clamp(34px, 4vw, 56px);
}
.h3{
  font-family:var(--serif);
  font-weight:400;
  margin:0 0 10px;
  font-size:26px;
}
.italic{font-style:italic;}
.grid{display:grid; gap:32px;}
.grid-2{grid-template-columns:1fr;}
.grid-3{grid-template-columns:1fr;}
@media (min-width: 900px){
  .grid-2{grid-template-columns:1fr 1fr;}
  .grid-3{grid-template-columns:repeat(3, 1fr);}
}

.btn{
  border:1px solid rgba(245,245,240,0.2);
  background:transparent;
  padding:10px 18px;
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  cursor:pointer;
  transition:background .2s ease,color .2s ease,border-color .2s ease;
}
.btn:hover{background:var(--bone); color:#000; border-color:var(--bone);}
.btn--link{
  border:0;
  padding:0;
  text-transform:uppercase;
  font-size:10px;
  letter-spacing:0.22em;
  border-bottom:1px solid rgba(245,245,240,0.2);
  padding-bottom:6px;
}
.btn--link:hover{border-bottom-color:rgba(245,245,240,0.6);}

.arch-glass{
  backdrop-filter:blur(10px);
  background:rgba(15,15,15,0.65);
  border-bottom:1px solid var(--line);
}
.nav{
  position:fixed; top:0; left:0; right:0;
  z-index:50;
  transition:padding .3s ease, background .3s ease, border-color .3s ease;
  padding:26px 0;
}
.nav--scrolled{padding:14px 0;}
.nav__row{display:flex; align-items:center; justify-content:space-between; gap:16px;}
.brand{display:flex; flex-direction:column; cursor:pointer;}
.brand__name{font-size:22px; letter-spacing:0.3em; font-weight:300;}
.brand__sub{font-size:10px; letter-spacing:0.5em; color:var(--muted-2); margin-top:6px; text-transform:uppercase;}
.nav__links{display:none; gap:28px; align-items:center;}
.nav__links a{
  font-size:11px; letter-spacing:0.2em; text-transform:uppercase;
  color:rgba(245,245,240,0.6);
  transition:color .2s ease;
}
.nav__links a:hover,.nav__links a[aria-current="page"]{color:var(--bone);}
.nav__actions{display:flex; align-items:center; gap:12px;}
.burger{
  width:44px; height:44px;
  border:1px solid rgba(245,245,240,0.12);
  background:transparent; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
}
.burger span{width:18px; height:1px; background:var(--bone); position:relative; display:block;}
.burger span::before,.burger span::after{
  content:""; position:absolute; left:0; width:18px; height:1px; background:var(--bone);
}
.burger span::before{top:-6px;}
.burger span::after{top:6px;}

@media(min-width: 900px){
  .nav__links{display:flex;}
  .burger{display:none;}
}

.mobile{
  position:fixed; inset:0;
  background:var(--bg);
  z-index:60;
  display:none;
  padding:56px 32px;
}
.mobile[aria-hidden="false"]{display:flex;}
.mobile__inner{margin:auto; display:flex; flex-direction:column; align-items:center; gap:22px;}
.mobile__inner a{font-family:var(--serif); font-size:40px; font-weight:300;}
.mobile__close{
  position:absolute; top:18px; right:18px;
  width:52px; height:52px;
  border:1px solid rgba(245,245,240,0.12);
  background:transparent; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
}
.mobile__close::before,.mobile__close::after{
  content:""; width:22px; height:1px; background:var(--bone); position:absolute;
}
.mobile__close::before{transform:rotate(45deg);}
.mobile__close::after{transform:rotate(-45deg);}

.hero{
  min-height:100vh;
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
  padding-top:88px; /* nav offset */
}
.hero__grid{
  position:absolute; top:0; right:0; width:50%; height:100%;
  opacity:0.2; pointer-events:none;
}
.hero__grid .vline{position:absolute; inset:0; border-left:1px solid rgba(245,245,240,0.06);}
.hero__grid .hline{position:absolute; left:0; width:100%; height:1px; background:rgba(245,245,240,0.06);}
.hero__grid .h1{top:25%;}
.hero__grid .h2{top:50%;}
.hero__grid .h3{top:75%;}
.hero__bottom{
  display:flex; flex-direction:column; gap:24px; align-items:flex-start; justify-content:space-between;
}
@media(min-width: 900px){
  .hero__bottom{flex-direction:row; align-items:flex-end;}
}
.scrollhint{display:flex; gap:14px; align-items:center;}
.scrollhint__line{width:48px; height:1px; background:rgba(245,245,240,0.22);}
.scrollhint__text{font-size:10px; letter-spacing:0.3em; text-transform:uppercase; color:var(--muted);}

.panel{
  border:1px solid rgba(245,245,240,0.06);
  padding:48px;
  position:relative;
  overflow:hidden;
}
@media(min-width: 900px){
  .panel{padding:80px;}
}
.panel__corner{
  position:absolute; top:0; right:0; padding:24px;
  opacity:0.08;
  font-family:var(--serif);
  font-size:72px;
  line-height:1;
}

.formrow{display:flex; gap:14px; align-items:center;}
.input{
  width:100%;
  background:transparent;
  border:0;
  border-bottom:1px solid rgba(245,245,240,0.12);
  padding:14px 2px;
  outline:none;
  font-family:var(--serif);
  font-size:22px;
  transition:border-color .2s ease;
}
.input:focus{border-bottom-color:rgba(245,245,240,0.4);}
.input::placeholder{color:rgba(245,245,240,0.18);}
.note{margin-top:18px; border-left:1px solid rgba(245,245,240,0.12); padding-left:18px; color:rgba(245,245,240,0.7); font-size:13px; line-height:2; font-weight:300; white-space:pre-wrap;}

.cards{display:grid; gap:22px;}
@media(min-width: 900px){ .cards{grid-template-columns:repeat(3, 1fr);} }

.project{
  position:relative;
  aspect-ratio:3/4;
  overflow:hidden;
  background:#1a1a1a;
  cursor:crosshair;
}
.project img{
  width:100%; height:100%;
  object-fit:cover;
  filter:none;          /* remove black & white */
  opacity:1;            /* full color visibility */
  transform:scale(1);
  transition:transform 1s ease;
}


.project:hover img{
  filter:grayscale(0);
  opacity:1;
  transform:scale(1.05);
}
.project__overlay{
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,0.8), transparent 55%);
  opacity:0;
  transition:opacity .35s ease;
  padding:28px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}
.project:hover .project__overlay{opacity:1;}
.project__cat{font-size:10px; letter-spacing:0.3em; text-transform:uppercase; color:rgba(245,245,240,0.55); margin-bottom:8px;}
.project__title{font-family:var(--serif); font-size:28px; margin:0;}

.split{
  display:grid;
  grid-template-columns:1fr;
  gap:56px;
  align-items:center;
}
@media(min-width: 900px){
  .split{grid-template-columns:1fr 1fr; gap:96px;}
}
.square{aspect-ratio:1/1; overflow:hidden; background:#141414; border:1px solid rgba(245,245,240,0.04);}
.square img{width:200%; height:75%; object-fit:cover; filter:none; opacity:1;}
.stats{display:grid; grid-template-columns:repeat(2, 1fr); gap:40px; margin-top:24px;}
.stat__num{font-weight:700; color:var(--bone); margin:0 0 6px;}
.stat__lbl{font-size:11px; letter-spacing:0.22em; text-transform:uppercase; color:rgba(245,245,240,0.45); margin:0;}

.footer{
  padding:88px 0 44px;
  border-top:1px solid rgba(245,245,240,0.06);
}
.footer__grid{display:grid; gap:44px;}
@media(min-width: 900px){ .footer__grid{grid-template-columns:2fr 1fr 1fr; gap:56px;} }
.footer p,.footer a,.footer input{color:rgba(245,245,240,0.45);}
.footer a:hover{color:var(--bone);}
.footer__bottom{margin-top:56px; padding-top:18px; border-top:1px solid rgba(245,245,240,0.06); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;}
.footer__bottom span{font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:rgba(245,245,240,0.32);}

.field{display:flex; flex-direction:column; gap:8px;}
.label{font-size:10px; letter-spacing:0.22em; text-transform:uppercase; color:rgba(245,245,240,0.55);}
.textarea{
  width:100%;
  background:transparent;
  border:1px solid rgba(245,245,240,0.12);
  padding:14px;
  min-height:140px;
  outline:none;
  font-size:14px;
  line-height:1.7;
  color:rgba(245,245,240,0.82);
}
.textarea:focus{border-color:rgba(245,245,240,0.35);}

.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  border:1px solid rgba(245,245,240,0.12);
  padding:10px 12px;
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:rgba(245,245,240,0.65);
}

a.skip{
  position:absolute; left:-999px; top:auto; width:1px; height:1px; overflow:hidden;
}
a.skip:focus{
  left:18px; top:18px; width:auto; height:auto; padding:10px 12px;
  background:rgba(0,0,0,0.8); border:1px solid rgba(245,245,240,0.18);
  z-index:100;
}
