/* =========================================================
   DARCHITERIORS — "The Atelier Index"
   Luxury editorial interior-design system
   ========================================================= */

/* ---------- Tokens ---------- */
:root{
  --ink:#14110E;
  --ink-2:#1d1812;
  --ink-3:#272019;
  --plaster:#EFE9DF;
  --plaster-2:#e3dccd;
  --brass:#B08D57;
  --brass-lite:#caa86f;
  --clay:#9C6B4A;
  --stone:#8A8378;
  --line:rgba(239,233,223,.14);
  --line-dark:rgba(20,17,14,.14);

  --bg:var(--ink);
  --fg:var(--plaster);

  --serif:"Fraunces",Georgia,serif;
  --sans:"Inter",system-ui,sans-serif;
  --mono:"Space Mono","Courier New",monospace;

  --pad:clamp(20px,5vw,90px);
  --maxw:1560px;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-2:cubic-bezier(.65,.05,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--fg);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.lock{overflow:hidden;height:100vh}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--brass);color:var(--ink)}

/* lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}

/* ---------- Type scale ---------- */
.display{
  font-family:var(--serif);
  font-weight:340;
  line-height:.92;
  letter-spacing:-.02em;
  font-optical-sizing:auto;
}
.eyebrow{
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--brass);
}
.lead{
  font-size:clamp(17px,1.6vw,21px);
  line-height:1.65;
  color:color-mix(in srgb,var(--fg) 78%,transparent);
  font-weight:300;
}

/* ============ LOADER ============ */
.loader{
  position:fixed;inset:0;z-index:9999;
  background:var(--ink);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:34px;
}
.loader__count{
  position:absolute;right:var(--pad);bottom:38px;
  font-family:var(--mono);font-size:clamp(48px,11vw,150px);
  color:var(--ink-3);line-height:1;letter-spacing:-.03em;
}
.loader__mark{
  overflow:hidden;
}
.loader__mark span{
  display:inline-block;
  font-family:var(--serif);font-weight:330;
  font-size:clamp(34px,7vw,86px);
  letter-spacing:.04em;
  color:var(--plaster);
  transform:translateY(110%);
}
.loader__sub{
  overflow:hidden;
}
.loader__sub p{
  font-family:var(--mono);font-size:11px;letter-spacing:.34em;
  text-transform:uppercase;color:var(--brass);
  transform:translateY(110%);
}
.loader__bar{
  position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--brass);
}
.curtain{
  position:fixed;inset:0;z-index:9998;pointer-events:none;
  background:var(--ink);transform:translateY(0);
}

/* ============ PROGRESS / CURSOR ============ */
.scroll-prog{
  position:fixed;top:0;left:0;height:2px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--brass),var(--brass-lite));
}
.cursor{
  position:fixed;top:0;left:0;width:9px;height:9px;border-radius:50%;
  background:var(--brass);z-index:9000;pointer-events:none;
  transform:translate(-50%,-50%);mix-blend-mode:difference;
  transition:width .3s var(--ease),height .3s var(--ease),background .3s;
}
.cursor.is-hover{width:46px;height:46px;background:transparent;border:1px solid var(--brass)}
@media (hover:none){.cursor{display:none}}

/* ============ NAV ============ */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:300;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--pad);
  transition:padding .4s var(--ease),background .4s var(--ease);
}
.nav.scrolled{
  padding:14px var(--pad);
  background:color-mix(in srgb,var(--ink) 72%,transparent);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  border-bottom:1px solid var(--line);
}
.nav__brand{
  font-family:var(--serif);font-size:22px;letter-spacing:.02em;
  font-weight:400;display:flex;align-items:center;gap:10px;
}
.nav__brand b{color:var(--brass);font-weight:400}
.nav__links{display:flex;gap:32px;align-items:center}
.nav__links a{
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;position:relative;padding:4px 0;
  color:color-mix(in srgb,var(--fg) 80%,transparent);
  transition:color .3s;
}
.nav__links a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:0;
  background:var(--brass);transition:width .4s var(--ease);
}
.nav__links a:hover,.nav__links a.active{color:var(--fg)}
.nav__links a:hover::after,.nav__links a.active::after{width:100%}
.nav__cta{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;border:1px solid var(--line);
  padding:11px 20px;border-radius:40px;transition:.4s var(--ease);
}
.nav__cta:hover{background:var(--brass);border-color:var(--brass);color:var(--ink)}
.burger{display:none;width:30px;height:18px;position:relative}
.burger span{
  position:absolute;left:0;height:1.5px;width:100%;background:var(--fg);
  transition:.4s var(--ease);
}
.burger span:nth-child(1){top:0}
.burger span:nth-child(2){top:50%;transform:translateY(-50%)}
.burger span:nth-child(3){bottom:0}
.burger.open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}

/* mobile menu */
.menu{
  position:fixed;inset:0;z-index:250;background:var(--ink-2);
  display:flex;flex-direction:column;justify-content:center;
  padding:0 var(--pad);
  clip-path:inset(0 0 100% 0);transition:clip-path .7s var(--ease);
  pointer-events:none;
}
.menu.open{clip-path:inset(0 0 0% 0);pointer-events:auto}
.menu a{
  font-family:var(--serif);font-size:clamp(36px,9vw,72px);
  font-weight:330;line-height:1.05;padding:6px 0;
  border-bottom:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:baseline;
}
.menu a span{font-family:var(--mono);font-size:12px;color:var(--brass)}
.menu__foot{margin-top:42px;display:flex;gap:26px;flex-wrap:wrap;
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--stone)}

/* ============ INDEX RAIL ============ */
.rail{
  position:fixed;left:0;top:0;height:100vh;width:var(--pad);z-index:120;
  display:flex;align-items:center;justify-content:center;pointer-events:none;
}
.rail__line{writing-mode:vertical-rl;font-family:var(--mono);font-size:10px;
  letter-spacing:.34em;text-transform:uppercase;color:var(--stone);
  transform:rotate(180deg)}
@media (max-width:980px){.rail{display:none}}

/* ============ LAYOUT ============ */
.section{padding:clamp(80px,11vh,150px) var(--pad);position:relative}
.wrap{max-width:var(--maxw);margin:0 auto}
.shead{display:flex;align-items:baseline;gap:18px;margin-bottom:54px;flex-wrap:wrap}
.shead .num{font-family:var(--mono);font-size:12px;color:var(--brass)}
.shead h2{font-family:var(--serif);font-weight:330;font-size:clamp(30px,5vw,64px);
  line-height:1;letter-spacing:-.02em;flex:1;min-width:280px}

/* reveal helpers (JS toggles via gsap; CSS fallback shows) */
.r-line{overflow:hidden;display:block}
.r-line > *{display:block}

/* ============ HERO ============ */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding:0 var(--pad) clamp(40px,8vh,90px);overflow:hidden;
}
.hero__media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.hero__media img{width:100%;height:120%;object-fit:cover;object-position:center;
  filter:brightness(.55) saturate(.9)}
.hero__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,17,14,.45),rgba(20,17,14,.2) 40%,var(--ink) 100%)}
.hero__inner{max-width:var(--maxw);margin:0 auto;width:100%}
.hero__eyebrow{margin-bottom:26px}
.hero h1{
  font-family:var(--serif);font-weight:300;line-height:.94;
  font-size:clamp(44px,8.4vw,140px);letter-spacing:-.03em;max-width:14ch;
}
.hero h1 em{font-style:italic;color:var(--brass-lite)}
.hero__row{display:flex;justify-content:space-between;align-items:flex-end;
  gap:40px;margin-top:38px;flex-wrap:wrap}
.hero__row p{max-width:42ch}
.scroll-cue{font-family:var(--mono);font-size:10px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--stone);display:flex;align-items:center;gap:12px}
.scroll-cue i{width:1px;height:46px;background:var(--brass);display:block;
  transform-origin:top;animation:cue 2.4s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0)}40%{transform:scaleY(1)}100%{transform:scaleY(0);transform-origin:bottom}}

/* ============ BUTTONS ============ */
.btn{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  padding:16px 28px;border-radius:48px;border:1px solid var(--brass);
  color:var(--plaster);position:relative;overflow:hidden;transition:color .4s var(--ease);
}
.btn::before{content:"";position:absolute;inset:0;background:var(--brass);
  transform:translateY(101%);transition:transform .5s var(--ease);z-index:-1}
.btn:hover{color:var(--ink)}
.btn:hover::before{transform:translateY(0)}
.btn--solid{background:var(--brass);color:var(--ink)}
.btn--solid::before{background:var(--plaster)}
.btn .dot{width:6px;height:6px;border-radius:50%;background:currentColor}

/* ============ MARQUEE ============ */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:26px 0;overflow:hidden;white-space:nowrap}
.marquee__track{display:inline-flex;gap:60px;will-change:transform}
.marquee__track span{font-family:var(--serif);font-size:clamp(26px,4vw,52px);
  font-weight:330;color:color-mix(in srgb,var(--fg) 30%,transparent);
  display:inline-flex;align-items:center;gap:60px}
.marquee__track span::after{content:"✦";color:var(--brass);font-size:.5em}

/* ============ INTRO SPLIT ============ */
.intro{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,6vw,90px);align-items:center}
.intro__text p{margin-top:24px}
.intro__media{position:relative;aspect-ratio:4/5;overflow:hidden;border-radius:2px}
.intro__media img{width:100%;height:100%;object-fit:cover;will-change:transform}
.intro__badge{position:absolute;left:24px;bottom:24px;
  background:color-mix(in srgb,var(--ink) 60%,transparent);
  backdrop-filter:blur(12px);border:1px solid var(--line);
  padding:18px 22px;border-radius:4px}
.intro__badge b{font-family:var(--serif);font-size:34px;display:block;font-weight:330}
.intro__badge small{font-family:var(--mono);font-size:10px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--stone)}
@media (max-width:840px){.intro{grid-template-columns:1fr}}

/* ============ SERVICE CARDS ============ */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.card{
  position:relative;overflow:hidden;border-radius:3px;
  aspect-ratio:3/4;display:flex;align-items:flex-end;
  border:1px solid var(--line);
}
.card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:brightness(.7);transition:transform .9s var(--ease),filter .6s}
.card::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 30%,rgba(20,17,14,.85))}
.card__body{position:relative;z-index:2;padding:26px;width:100%}
.card__body h3{font-family:var(--serif);font-weight:340;font-size:24px;margin-bottom:8px}
.card__body p{font-size:13px;color:color-mix(in srgb,var(--fg) 70%,transparent);margin-bottom:16px}
.card__body .lnk{font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--brass);display:inline-flex;gap:8px;align-items:center}
.card__n{position:absolute;top:22px;left:26px;z-index:2;font-family:var(--mono);
  font-size:12px;color:var(--brass)}
.card:hover img{transform:scale(1.07);filter:brightness(.82)}
@media (max-width:1100px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.cards{grid-template-columns:1fr}}

/* ============ STATS ============ */
.stats{display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line)}
.stat{padding:40px 26px;border-bottom:1px solid var(--line)}
.stat:not(:last-child){border-right:1px solid var(--line)}
.stat b{font-family:var(--serif);font-weight:330;font-size:clamp(38px,5vw,64px);
  display:block;line-height:1}
.stat span{font-family:var(--mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--stone);margin-top:14px;display:block}
@media (max-width:760px){.stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(odd){border-right:1px solid var(--line)}
  .stat:nth-child(even){border-right:none}}

/* ============ HORIZONTAL PROJECTS ============ */
.hsection{position:relative;background:var(--ink-2)}
.hpin{height:100vh;display:flex;align-items:center;overflow:hidden}
.htrack{display:flex;gap:28px;padding:0 var(--pad);will-change:transform}
.pcard{position:relative;flex:0 0 min(72vw,640px);height:74vh;
  border-radius:3px;overflow:hidden;border:1px solid var(--line)}
.pcard img{width:100%;height:100%;object-fit:cover;filter:brightness(.82);
  transition:transform 1s var(--ease)}
.pcard:hover img{transform:scale(1.05)}
.pcard__meta{position:absolute;left:0;bottom:0;width:100%;padding:30px;
  background:linear-gradient(180deg,transparent,rgba(20,17,14,.86));z-index:2}
.pcard__meta h3{font-family:var(--serif);font-weight:340;font-size:clamp(22px,3vw,34px)}
.pcard__meta span{font-family:var(--mono);font-size:11px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--brass)}
.pcard__n{position:absolute;top:26px;right:30px;z-index:2;font-family:var(--mono);
  font-size:13px;color:var(--plaster);opacity:.7}
.hintro{padding:clamp(80px,11vh,140px) var(--pad) 0}

/* ============ APPROACH / PROCESS ============ */
.steps{display:grid;gap:0;border-top:1px solid var(--line)}
.step{display:grid;grid-template-columns:120px 1fr 1.2fr;gap:30px;
  padding:42px 0;border-bottom:1px solid var(--line);align-items:start;
  transition:background .5s}
.step:hover{background:var(--ink-2)}
.step .s-n{font-family:var(--mono);font-size:12px;color:var(--brass)}
.step h3{font-family:var(--serif);font-weight:340;font-size:clamp(24px,3.2vw,40px)}
.step p{color:color-mix(in srgb,var(--fg) 72%,transparent);max-width:52ch}
@media (max-width:760px){.step{grid-template-columns:1fr;gap:14px}}

/* ============ TESTIMONIALS ============ */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.quote{border:1px solid var(--line);border-radius:4px;padding:32px;
  background:var(--ink-2);transition:transform .5s var(--ease),border-color .5s}
.quote:hover{transform:translateY(-6px);border-color:var(--brass)}
.quote .stars{color:var(--brass);letter-spacing:3px;font-size:13px;margin-bottom:18px}
.quote p{font-family:var(--serif);font-size:18px;font-weight:330;line-height:1.5;
  color:color-mix(in srgb,var(--fg) 90%,transparent)}
.quote__by{display:flex;align-items:center;gap:14px;margin-top:24px;
  padding-top:20px;border-top:1px solid var(--line)}
.quote__by img{width:42px;height:42px;border-radius:50%;object-fit:cover}
.quote__by b{font-weight:500;font-size:14px;display:block}
.quote__by small{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--stone)}
@media (max-width:980px){.quotes{grid-template-columns:1fr}}

/* ============ PARTNERS ============ */
.partners{display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:center}
.partners img{height:34px;width:auto;filter:grayscale(1) brightness(0) invert(.7);
  opacity:.6;transition:.4s}
.partners img:hover{opacity:1;filter:grayscale(0) brightness(1) invert(0)}

/* ============ FAQ ============ */
.faq{border-top:1px solid var(--line)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__q{width:100%;text-align:left;display:flex;justify-content:space-between;
  gap:20px;align-items:center;padding:30px 0;font-family:var(--serif);
  font-weight:340;font-size:clamp(19px,2.4vw,28px)}
.faq__q .ic{font-family:var(--mono);color:var(--brass);font-size:22px;transition:transform .4s}
.faq__item.open .faq__q .ic{transform:rotate(45deg)}
.faq__a{max-height:0;overflow:hidden;transition:max-height .6s var(--ease)}
.faq__a p{padding:0 0 30px;max-width:80ch;color:color-mix(in srgb,var(--fg) 72%,transparent)}

/* ============ CTA BAND ============ */
.ctaband{position:relative;overflow:hidden;text-align:center;
  padding:clamp(90px,16vh,180px) var(--pad)}
.ctaband img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:brightness(.32);z-index:-1}
.ctaband h2{font-family:var(--serif);font-weight:300;font-size:clamp(40px,7vw,108px);
  line-height:.96;letter-spacing:-.02em;margin-bottom:34px}
.ctaband h2 em{font-style:italic;color:var(--brass-lite)}

/* ============ FOOTER ============ */
.footer{background:var(--ink);border-top:1px solid var(--line);padding:var(--pad)}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;
  padding:clamp(50px,8vh,90px) 0;border-bottom:1px solid var(--line)}
.footer__brand .b{font-family:var(--serif);font-size:30px;font-weight:330;margin-bottom:18px}
.footer__brand p{max-width:34ch;color:color-mix(in srgb,var(--fg) 65%,transparent);font-size:14px}
.footer__col h4{font-family:var(--mono);font-size:10px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--brass);margin-bottom:20px}
.footer__col a,.footer__col p{display:block;font-size:14px;padding:6px 0;
  color:color-mix(in srgb,var(--fg) 70%,transparent);transition:color .3s}
.footer__col a:hover{color:var(--fg)}
.footer__socials{display:flex;gap:18px;margin-top:14px;flex-wrap:wrap}
.footer__socials a{font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;border:1px solid var(--line);padding:8px 14px;border-radius:30px}
.footer__socials a:hover{background:var(--brass);color:var(--ink);border-color:var(--brass)}
.footer__bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  padding:26px 0;font-family:var(--mono);font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--stone)}
.footer__big{font-family:var(--serif);font-size:clamp(48px,15vw,220px);line-height:.8;
  font-weight:300;letter-spacing:-.03em;padding:30px 0;
  color:var(--ink-3);text-align:center;overflow:hidden}
@media (max-width:900px){.footer__top{grid-template-columns:1fr 1fr}}
@media (max-width:540px){.footer__top{grid-template-columns:1fr}}

/* ============ PAGE HEADER (inner pages) ============ */
.phead{min-height:62vh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 var(--pad) clamp(40px,7vh,80px);position:relative;overflow:hidden}
.phead__media{position:absolute;inset:0;z-index:-1}
.phead__media img{width:100%;height:115%;object-fit:cover;filter:brightness(.45)}
.phead__media::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,17,14,.4),var(--ink))}
.phead h1{font-family:var(--serif);font-weight:300;font-size:clamp(46px,9vw,150px);
  line-height:.92;letter-spacing:-.03em}
.phead__crumb{font-family:var(--mono);font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--brass);margin-bottom:26px}

/* ============ GALLERY GRID ============ */
.gallery{columns:3;column-gap:18px}
.gallery figure{break-inside:avoid;margin-bottom:18px;overflow:hidden;border-radius:3px;
  position:relative}
.gallery img{width:100%;transition:transform 1s var(--ease);filter:brightness(.92)}
.gallery figure:hover img{transform:scale(1.06)}
.gallery figcaption{position:absolute;left:0;bottom:0;width:100%;padding:18px;
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  background:linear-gradient(transparent,rgba(20,17,14,.85));opacity:0;transition:.4s;
  transform:translateY(8px)}
.gallery figure:hover figcaption{opacity:1;transform:translateY(0)}
@media (max-width:980px){.gallery{columns:2}}
@media (max-width:560px){.gallery{columns:1}}

/* ============ PROJECT INDEX (projects page) ============ */
.pindex{border-top:1px solid var(--line)}
.prow{display:grid;grid-template-columns:80px 2fr 1fr 1fr 60px;gap:24px;
  align-items:center;padding:30px 0;border-bottom:1px solid var(--line);
  position:relative;transition:padding .5s var(--ease)}
.prow:hover{padding-left:18px}
.prow .pn{font-family:var(--mono);font-size:12px;color:var(--brass)}
.prow h3{font-family:var(--serif);font-weight:340;font-size:clamp(22px,3vw,38px)}
.prow .meta{font-family:var(--mono);font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--stone)}
.prow .go{font-family:var(--mono);font-size:18px;color:var(--brass);
  justify-self:end;transition:transform .4s}
.prow:hover .go{transform:translate(6px,-6px)}
.prow__preview{position:fixed;width:300px;height:380px;pointer-events:none;
  z-index:140;opacity:0;border-radius:4px;overflow:hidden;
  transform:translate(-50%,-50%) scale(.9);transition:opacity .3s,transform .3s}
.prow__preview img{width:100%;height:100%;object-fit:cover}
@media (max-width:760px){.prow{grid-template-columns:50px 1fr 50px}
  .prow .meta:nth-of-type(2){display:none}.prow__preview{display:none}}

/* ============ CONTACT ============ */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,7vw,100px)}
.contact__info h3{font-family:var(--serif);font-weight:330;font-size:clamp(28px,4vw,46px);
  margin-bottom:30px;line-height:1.05}
.cline{display:block;padding:20px 0;border-bottom:1px solid var(--line)}
.cline small{font-family:var(--mono);font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--brass);display:block;margin-bottom:8px}
.cline b{font-family:var(--serif);font-weight:330;font-size:clamp(18px,2.2vw,26px)}
.form{display:grid;gap:0}
.field{position:relative;border-bottom:1px solid var(--line);padding-top:26px}
.field input,.field textarea{width:100%;background:none;border:none;outline:none;
  color:var(--fg);font-family:var(--sans);font-size:17px;padding:8px 0 18px;resize:none}
.field label{position:absolute;top:32px;left:0;font-family:var(--mono);font-size:12px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--stone);
  transition:.3s var(--ease);pointer-events:none}
.field input:focus~label,.field input:valid~label,
.field textarea:focus~label,.field textarea:valid~label{
  top:6px;font-size:10px;color:var(--brass)}
.form .btn{margin-top:34px;justify-self:start}
@media (max-width:840px){.contact{grid-template-columns:1fr}}

/* ============ TEAM ============ */
.team{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tmember{position:relative;overflow:hidden;border-radius:3px;aspect-ratio:4/5;
  border:1px solid var(--line)}
.tmember img{width:100%;height:100%;object-fit:cover;filter:grayscale(.4) brightness(.85);
  transition:.7s var(--ease)}
.tmember:hover img{filter:grayscale(0) brightness(1);transform:scale(1.05)}
.tmember__b{position:absolute;left:0;bottom:0;width:100%;padding:24px;z-index:2;
  background:linear-gradient(transparent,rgba(20,17,14,.9))}
.tmember__b b{font-family:var(--serif);font-size:22px;font-weight:340;display:block}
.tmember__b small{font-family:var(--mono);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--brass)}
@media (max-width:900px){.team{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.team{grid-template-columns:1fr}}

/* ============ RESPONSIVE NAV ============ */
@media (max-width:980px){
  .nav__links,.nav__cta{display:none}
  .burger{display:block}
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .scroll-cue i{animation:none}
}

/* focus */
:focus-visible{outline:2px solid var(--brass);outline-offset:3px}
