/* ============================================================
   MORPHEUS — Architecture Studio
   ============================================================ */

:root{
  --bg:        #0b0b0c;
  --bg-2:      #111113;
  --surface:   #16161a;
  --paper:     #f3efe7;
  --ink:       #0b0b0c;
  --text:      #ece8df;
  --muted:     #8e897e;
  --faint:     #5b574f;
  --gold:      #c6a368;
  --gold-soft: #d9bd8c;
  --line:      rgba(236,232,223,.12);
  --line-soft: rgba(236,232,223,.07);

  --serif: "Fraunces", Georgia, serif;
  --sans:  "Inter", system-ui, sans-serif;

  --ease: cubic-bezier(.16,1,.3,1);
  --slow: 1.1s cubic-bezier(.16,1,.3,1);

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

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

html{ -webkit-text-size-adjust:100%; }
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }

body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

img{ display:block; width:100%; height:100%; object-fit:cover; }
a{ color:inherit; text-decoration:none; }
.italic{ font-style:italic; font-family:var(--serif); }

::selection{ background:var(--gold); color:#000; }

/* ---------- Scrollbar ---------- */
::-webkit-scrollbar{ width:9px; }
::-webkit-scrollbar-track{ background:var(--bg); }
::-webkit-scrollbar-thumb{ background:#26262a; border-radius:10px; }
::-webkit-scrollbar-thumb:hover{ background:var(--gold); }

/* ============================================================
   PRELOADER
   ============================================================ */
html:not(.js) .loader{ display:none; }
.loader{
  position:fixed; inset:0; z-index:1000;
  background:var(--bg);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  gap:18px;
}
.loader__brand{ overflow:hidden; }
.loader__word{
  display:block;
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2.6rem,9vw,7rem);
  letter-spacing:.04em;
  color:var(--text);
  transform:translateY(110%);
  animation:loadUp 1s var(--ease) .15s forwards;
}
.loader__tag{
  font-size:.72rem; letter-spacing:.5em; text-transform:uppercase;
  color:var(--gold); opacity:0;
  animation:fadeIn .8s ease .7s forwards;
}
@keyframes loadUp{ to{ transform:translateY(0); } }
@keyframes fadeIn{ to{ opacity:1; } }

.loader__count{
  position:absolute; right:var(--pad); bottom:calc(var(--pad) - 10px);
  font-family:var(--serif); font-size:clamp(3rem,14vw,11rem);
  line-height:1; color:var(--gold); display:flex; align-items:flex-start;
}
.loader__count i{ font-size:.3em; font-style:normal; margin-top:.4em; }
.loader__bar{
  position:absolute; left:0; bottom:0; height:2px; width:100%;
  background:var(--line);
}
.loader__bar span{
  display:block; height:100%; width:0%; background:var(--gold);
}
.loader.is-done{
  transform:translateY(-100%);
  transition:transform 1s var(--ease);
}

/* ============================================================
   CUSTOM CURSOR
   ============================================================ */
.cursor{ position:fixed; top:0; left:0; z-index:900; pointer-events:none; mix-blend-mode:difference; }
.cursor__dot{
  position:fixed; top:0; left:0; width:6px; height:6px; border-radius:50%;
  background:#fff; transform:translate(-50%,-50%);
}
.cursor__ring{
  position:fixed; top:0; left:0; width:38px; height:38px; border-radius:50%;
  border:1px solid rgba(255,255,255,.6); transform:translate(-50%,-50%);
  transition:width .35s var(--ease),height .35s var(--ease),background .35s var(--ease),border-color .35s var(--ease);
}
.cursor__label{
  position:fixed; top:0; left:0; transform:translate(-50%,-50%) scale(.4);
  font-size:.62rem; letter-spacing:.15em; text-transform:uppercase;
  color:#000; opacity:0; transition:opacity .3s, transform .3s var(--ease);
  mix-blend-mode:normal;
}
body.cursor-hover .cursor__ring{ width:60px; height:60px; background:rgba(255,255,255,.12); }
body.cursor-view .cursor__ring{ width:84px; height:84px; background:var(--gold); border-color:var(--gold); }
body.cursor-view .cursor__label{ opacity:1; transform:translate(-50%,-50%) scale(1); }
@media (hover:none),(pointer:coarse){ .cursor{ display:none; } }

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; width:100%; z-index:200;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--pad);
  transition:transform .5s var(--ease), background .5s var(--ease);
}
.nav.hide{ transform:translateY(-110%); }
.nav__logo{ display:flex; align-items:center; }
.nav__word{ font-family:var(--serif); font-weight:500; font-size:1.15rem; letter-spacing:.34em; color:#fff; }
.nav__links{ display:flex; gap:34px; }
.nav__links a{ font-size:.78rem; letter-spacing:.12em; color:#fff; position:relative; transition:color .4s; }
.nav__links a i{ font-style:normal; color:var(--gold); font-size:.62rem; margin-right:3px; }
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-5px; height:1px; width:0;
  background:#fff; transition:width .4s var(--ease);
}
.nav__links a:hover::after{ width:100%; }
.nav__cta{
  font-size:.74rem; letter-spacing:.1em; color:#fff;
  border:1px solid rgba(255,255,255,.4); border-radius:40px;
  padding:10px 20px; transition:background .4s,color .4s;
}
.nav__cta:hover{ background:#fff; color:#000; }

.nav__burger{ display:none; background:none; border:0; cursor:pointer; width:34px; height:20px; position:relative; }
.nav__burger span{ position:absolute; left:0; width:100%; height:1.5px; background:#fff; transition:.4s var(--ease); }
.nav__burger span:nth-child(1){ top:4px; } .nav__burger span:nth-child(2){ bottom:4px; }
body.menu-open .nav__burger span:nth-child(1){ top:9px; transform:rotate(45deg); }
body.menu-open .nav__burger span:nth-child(2){ bottom:9px; transform:rotate(-45deg); }
body.menu-open .nav__burger span{ background:#fff; }

/* ---------- Mobile menu ---------- */
.menu{
  position:fixed; inset:0; z-index:150; background:var(--bg-2);
  display:flex; flex-direction:column; justify-content:center;
  padding:var(--pad); transform:translateY(-100%);
  transition:transform .7s var(--ease); visibility:hidden;
}
body.menu-open .menu{ transform:translateY(0); visibility:visible; }
.menu__links{ display:flex; flex-direction:column; gap:6px; }
.menu__links a{ font-family:var(--serif); font-size:clamp(2.6rem,11vw,4rem); display:flex; align-items:baseline; gap:16px; }
.menu__links a span{ font-family:var(--sans); font-size:.8rem; color:var(--gold); }
.menu__foot{ margin-top:48px; display:flex; flex-direction:column; gap:6px; color:var(--muted); }

/* ============================================================
   SECTION HEAD
   ============================================================ */
.section-head{
  display:flex; align-items:center; gap:16px;
  padding:0 var(--pad);
  margin-bottom:clamp(40px,7vw,90px);
  font-size:.72rem; letter-spacing:.28em; text-transform:uppercase; color:var(--muted);
}
.section-head__num{ color:var(--gold); }
.section-head::before{ content:""; flex:0 0 40px; height:1px; background:var(--line); }

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; justify-content:space-between;
  padding:120px var(--pad) clamp(28px,5vw,52px);
  overflow:hidden;
}
.hero__bg{ position:absolute; inset:-12% 0; z-index:-2; will-change:transform; }
.hero__bg img{ filter:saturate(.9) contrast(1.02); }
.hero__veil{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(11,11,12,.55) 0%, rgba(11,11,12,.25) 30%, rgba(11,11,12,.55) 70%, rgba(11,11,12,.95) 100%),
    radial-gradient(120% 80% at 50% 10%, transparent, rgba(11,11,12,.5));
}
.hero__grain{
  position:absolute; inset:0; z-index:-1; opacity:.5; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
.hero__top{ display:flex; justify-content:space-between; font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(236,232,223,.8); }

/* centred group: logo + motto */
.hero__center{ margin:auto 0; display:flex; flex-direction:column; align-items:center; gap:clamp(20px,3.2vw,40px); }
.hero__logo img{ width:auto; height:clamp(130px,24vw,180px); filter:drop-shadow(0 14px 46px rgba(0,0,0,.55)); }
.js .hero__logo{ opacity:0; transform:translateY(26px) scale(.95); }
.hero__logo.in{ opacity:1; transform:none; transition:opacity 1s var(--ease), transform 1.2s var(--ease); }

.hero__title{
  font-family:var(--serif); font-weight:300;
  font-size:clamp(1.5rem,4.1vw,4.05rem);
  line-height:1.08; letter-spacing:-.01em;
  text-align:center;
  max-width:18ch; margin-inline:auto;
  text-wrap:balance;
}
.hero__title .line{ display:block; overflow:hidden; padding:.04em 0; }
.hero__title .word{ display:block; }
.js .hero__title .word{ transform:translateY(110%); }
.hero__title em{ font-style:italic; color:var(--gold-soft); }

.hero__bottom{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; }
.hero__actions{ display:flex; align-items:center; gap:clamp(18px,2.6vw,36px); flex-wrap:wrap; }
.hero__cta{
  display:inline-flex; align-items:center; gap:10px; white-space:nowrap;
  background:var(--gold); color:#1a1206; border-radius:40px;
  padding:14px 26px; font-size:.78rem; letter-spacing:.1em; text-transform:uppercase;
  transition:transform .4s var(--ease), background .4s;
}
.hero__cta svg{ transition:transform .4s var(--ease); }
.hero__cta:hover{ background:var(--gold-soft); transform:translateY(-2px); }
.hero__cta:hover svg{ transform:translateX(4px); }
.hero__lead{ max-width:34ch; font-size:clamp(.95rem,1.4vw,1.15rem); color:rgba(236,232,223,.86); }
.hero__scroll{ display:flex; align-items:center; gap:12px; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold); white-space:nowrap; }
.hero__scrollline{ width:46px; height:1px; background:var(--gold); position:relative; overflow:hidden; }
.hero__scrollline::after{ content:""; position:absolute; inset:0; background:var(--text); animation:scrollLine 2.2s var(--ease) infinite; }
@keyframes scrollLine{ 0%{ transform:translateX(-100%);} 60%,100%{ transform:translateX(100%);} }

/* reveal-line generic */
.reveal-line{ overflow:hidden; }
.reveal-line > span{ display:inline-block; transition:transform var(--slow); }
.js .reveal-line > span{ transform:translateY(110%); }
.js .is-in.reveal-line > span,
.js .reveal-line.is-in > span{ transform:translateY(0); }

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding:22px 0; overflow:hidden; white-space:nowrap;
  background:var(--bg-2);
}
.marquee__track{ display:inline-flex; gap:0; animation:marq 28s linear infinite; }
.marquee__track span{
  font-family:var(--serif); font-style:italic; font-size:clamp(1.6rem,4vw,3rem);
  color:var(--text); padding-right:.4em;
}
.marquee__track span i{ color:var(--gold); font-style:normal; padding:0 .35em; }
@keyframes marq{ to{ transform:translateX(-50%); } }

/* ============================================================
   ABOUT
   ============================================================ */
.about{ padding:clamp(80px,12vw,170px) 0; }
.about__grid{
  display:grid; grid-template-columns:1.1fr 1fr; gap:clamp(40px,6vw,100px);
  padding:0 var(--pad);
}
.about__statement{
  font-family:var(--serif); font-weight:300;
  font-size:clamp(2rem,4.6vw,4.2rem); line-height:1.04; letter-spacing:-.01em;
}
.about__statement span{ display:block; }
.about__body p{ color:var(--muted); font-size:clamp(1rem,1.3vw,1.15rem); margin-bottom:22px; max-width:46ch; }
.about__disciplines{ margin-top:38px; display:flex; flex-direction:column; gap:12px; border-top:1px solid var(--line); padding-top:28px; }
.about__disciplines div{ font-size:.92rem; letter-spacing:.04em; color:var(--text); }
.about__disciplines i{ color:var(--gold); font-style:normal; margin-right:10px; }

.about__media{ margin-top:clamp(50px,8vw,110px); padding:0 var(--pad); }
.about__media img{ height:clamp(320px,60vh,640px); }

/* ============================================================
   WORK
   ============================================================ */
.work{ padding:clamp(40px,7vw,90px) 0 clamp(60px,9vw,120px); }

.project{
  display:grid; grid-template-columns:0.9fr 1.4fr; gap:clamp(30px,5vw,80px);
  align-items:center;
  padding:clamp(50px,8vw,110px) var(--pad);
  border-top:1px solid var(--line);
}
.project--alt{ grid-template-columns:1.4fr 0.9fr; }
.project--alt .project__meta{ order:2; }
.project--alt .project__media{ order:1; }

.project__meta{ position:relative; }
.project__idx{
  position:absolute; top:-.6em; left:-.1em;
  font-family:var(--serif); font-size:clamp(5rem,10vw,9rem);
  color:transparent; -webkit-text-stroke:1px var(--line);
  pointer-events:none; z-index:-1;
}
.project__title{ overflow:hidden; }
.project__title span{ display:inline-block; transition:transform var(--slow); }
.js .project__title span{ transform:translateY(110%); }
.is-in .project__title span{ transform:translateY(0); }
.project__title{ font-family:var(--serif); font-weight:400; font-size:clamp(2.4rem,5vw,4.2rem); line-height:1; letter-spacing:-.01em; }
.project__sub{ color:var(--gold); font-size:.82rem; letter-spacing:.18em; text-transform:uppercase; margin-top:18px; }
.project__facts{ list-style:none; margin:30px 0; border-top:1px solid var(--line); }
.project__facts li{ display:flex; justify-content:space-between; gap:20px; padding:12px 0; border-bottom:1px solid var(--line-soft); font-size:.9rem; color:var(--text); }
.project__facts li span{ color:var(--muted); letter-spacing:.04em; }
.project__desc{ color:var(--muted); font-size:1rem; max-width:42ch; }

.project__media{ display:flex; flex-direction:column; gap:18px; }
.project__hero{ overflow:hidden; }
.project__hero img{ height:clamp(320px,52vh,600px); }
.project__thumbs{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.project__thumbs figure{ overflow:hidden; }
.project__thumbs img{ height:clamp(180px,26vh,300px); }

/* image hover zoom */
.project figure img,.grid__item img{ transition:transform 1.2s var(--ease); }
.project figure:hover img,.grid__item:hover img{ transform:scale(1.06); }

/* ---------- Interiors grid ---------- */
.work__more{ padding:clamp(60px,9vw,130px) var(--pad) 0; border-top:1px solid var(--line); margin-top:clamp(30px,5vw,70px); }
.work__more-head{ display:flex; align-items:baseline; gap:24px; margin-bottom:40px; flex-wrap:wrap; }
.work__more-head h3{ font-family:var(--serif); font-weight:400; font-size:clamp(1.8rem,3.4vw,2.8rem); }
.work__more-head p{ color:var(--muted); }
.grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; grid-auto-flow:dense; }
.grid__item{ position:relative; overflow:hidden; height:clamp(220px,30vh,320px); }
.grid__item--tall{ grid-row:span 2; height:auto; }
.grid__item figcaption{
  position:absolute; left:16px; bottom:16px; z-index:2;
  font-size:.78rem; letter-spacing:.05em; color:#fff;
  display:flex; align-items:center; gap:8px;
  opacity:0; transform:translateY(10px); transition:.5s var(--ease);
  text-shadow:0 1px 12px rgba(0,0,0,.6);
}
.grid__item figcaption span{ color:var(--gold); }
.grid__item::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg,rgba(0,0,0,.5),transparent 55%); opacity:0; transition:.5s; }
.grid__item:hover figcaption{ opacity:1; transform:translateY(0); }
.grid__item:hover::after{ opacity:1; }

/* ============================================================
   APPROACH
   ============================================================ */
.approach{ padding:clamp(80px,12vw,170px) 0; background:var(--bg-2); border-top:1px solid var(--line); }
.approach__intro{ padding:0 var(--pad); max-width:1100px; margin-bottom:clamp(50px,8vw,100px); }
.approach__intro h2{ font-family:var(--serif); font-weight:300; font-size:clamp(1.9rem,4.4vw,3.8rem); line-height:1.1; }
.approach__steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border-block:1px solid var(--line); }
.step{ background:var(--bg-2); padding:clamp(30px,3vw,46px) clamp(20px,2.4vw,38px); min-height:280px; display:flex; flex-direction:column; }
.step__num{ font-family:var(--serif); color:var(--gold); font-size:1rem; }
.step h4{ font-family:var(--serif); font-weight:400; font-size:clamp(1.4rem,2.4vw,2rem); margin:auto 0 14px; }
.step p{ color:var(--muted); font-size:.92rem; }

.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); margin-top:1px; }
.stat{ background:var(--bg-2); padding:clamp(34px,4vw,60px) var(--pad); display:flex; flex-direction:column; gap:8px; }
.stat__num{ font-family:var(--serif); font-size:clamp(2.6rem,6vw,5rem); line-height:1; color:var(--text); }
.stat__label{ font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }

/* ============================================================
   CONTACT (+ quote form)
   ============================================================ */
.contact{ background:var(--bg); color:var(--text); padding:clamp(80px,12vw,160px) 0 clamp(70px,10vw,120px); border-top:1px solid var(--line); }
.contact__inner{ padding:0 var(--pad); }
.contact__kicker{ font-family:var(--serif); font-style:italic; font-size:clamp(1.1rem,2vw,1.6rem); color:var(--muted); margin-bottom:18px; }
.contact__big{ font-family:var(--serif); font-weight:400; font-size:clamp(2.8rem,9vw,8.5rem); line-height:.95; letter-spacing:-.02em; }
.contact__big .line{ display:block; overflow:hidden; }
.contact__big .line span{ display:inline-block; transition:transform var(--slow); }
.js .contact__big .line span{ transform:translateY(110%); }
.contact__big .line span.italic{ color:var(--gold); }
.is-in .contact__big .line span,
.contact__big.is-in .line span{ transform:translateY(0); }

/* contact details (closing block, after the form) */
.contact__details{ margin-top:clamp(60px,8vw,110px); border-top:1px solid var(--line); padding-top:clamp(34px,4vw,54px); }
.contact__mail{
  display:inline-block; margin-bottom:clamp(36px,5vw,56px);
  font-size:clamp(1.2rem,3vw,2.4rem); color:var(--text);
  border-bottom:1px solid var(--line); padding-bottom:6px;
  transition:color .4s,border-color .4s;
}
.contact__mail:hover{ color:var(--gold); border-color:var(--gold); }

.contact__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.contact__col span{ display:block; font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); margin-bottom:16px; }
.contact__col a{ display:block; font-size:1.05rem; margin-bottom:6px; transition:color .3s; }
.contact__col a:hover{ color:var(--gold); }
.contact__col p{ color:var(--muted); font-size:1rem; margin-bottom:10px; }

/* ---------- Quote form (nested in contact) ---------- */
.quote{ margin-top:clamp(50px,7vw,90px); }
.quote__intro{ max-width:60ch; margin-bottom:clamp(34px,5vw,56px); }
.quote__tag{ font-size:.72rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); }
.quote__title{ font-family:var(--serif); font-weight:300; font-size:clamp(2.2rem,5vw,4rem); line-height:1.02; margin:18px 0 22px; }
.quote__lead{ color:var(--muted); max-width:38ch; }
.quote__lead i,.field i,.needs legend i{ color:var(--gold); font-style:normal; }

.quote__form{ display:grid; grid-template-columns:1fr 1fr; gap:22px 26px; }
.field{ display:flex; flex-direction:column; gap:9px; }
.field--full{ grid-column:1 / -1; }
.field label,.needs legend{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.field input,.field select,.field textarea{
  background:transparent; border:0; border-bottom:1px solid var(--line);
  color:var(--text); font-family:var(--sans); font-size:1rem; font-weight:300;
  padding:12px 2px; transition:border-color .4s var(--ease);
}
.field input::placeholder,.field textarea::placeholder{ color:var(--faint); }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold); }
.field select{ appearance:none; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23c6a368' stroke-width='1.4'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 4px center; }
.field select option{ background:var(--bg-2); color:var(--text); }
.field textarea{ resize:vertical; min-height:120px; }

.needs{ border:0; }
.needs legend{ margin-bottom:16px; }
.needs__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.check{ position:relative; }
.check input{ position:absolute; opacity:0; inset:0; cursor:pointer; }
.check span{
  display:block; padding:13px 16px; border:1px solid var(--line); border-radius:40px;
  font-size:.86rem; color:var(--muted); text-align:center; cursor:pointer;
  transition:.35s var(--ease);
}
.check input:checked + span{ background:var(--gold); border-color:var(--gold); color:#1a1206; font-weight:400; }
.check input:focus-visible + span{ border-color:var(--gold); }
.check:hover span{ border-color:var(--muted); color:var(--text); }

.g-recaptcha{
  min-height:78px; min-width:304px; max-width:304px;
  border:1px dashed var(--line); border-radius:6px;
  display:grid; place-items:center;
}
.g-recaptcha:empty::after{ content:"reCAPTCHA"; color:var(--faint); font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; }
.recaptcha-note{ margin-top:10px; font-size:.74rem; color:var(--faint); }
.recaptcha-note code{ color:var(--gold); font-size:.72rem; }

.quote__submit{ display:flex; align-items:center; gap:22px; flex-wrap:wrap; }
.btn{
  display:inline-flex; align-items:center; gap:12px; cursor:pointer;
  background:var(--gold); color:#1a1206; border:0; border-radius:40px;
  font-family:var(--sans); font-size:.86rem; letter-spacing:.1em; text-transform:uppercase;
  padding:16px 30px; transition:transform .4s var(--ease), background .4s;
}
.btn svg{ transition:transform .4s var(--ease); }
.btn:hover{ background:var(--gold-soft); transform:translateY(-2px); }
.btn:hover svg{ transform:translateX(4px); }
.btn:disabled{ opacity:.55; cursor:wait; transform:none; }
.quote__status{ font-size:.9rem; color:var(--muted); }
.quote__status.ok{ color:var(--gold-soft); }
.quote__status.err{ color:#e08a7a; }

@media (max-width:860px){
  .quote__form{ grid-template-columns:1fr; }
  .needs__grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:560px){ .needs__grid{ grid-template-columns:1fr; } }

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--bg); padding:clamp(40px,6vw,70px) var(--pad) 30px; overflow:hidden; }
.footer__big{
  font-family:var(--serif); font-weight:500; text-align:center;
  font-size:clamp(3rem,18vw,16rem); line-height:.9; letter-spacing:.02em;
  color:transparent; -webkit-text-stroke:1px var(--line);
  margin-bottom:30px; user-select:none;
}
.footer__row{ display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; border-top:1px solid var(--line); padding-top:26px; font-size:.8rem; letter-spacing:.06em; color:var(--muted); }
.footer__tag{ color:var(--gold); font-family:var(--serif); font-style:italic; }

/* ============================================================
   REVEAL UTILITIES
   ============================================================ */
.js .reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s var(--ease), transform 1.1s var(--ease); }
.js .reveal.is-in{ opacity:1; transform:none; }
.js .reveal-media{ clip-path:inset(0 0 100% 0); transition:clip-path 1.2s var(--ease); }
.js .reveal-media.is-in{ clip-path:inset(0 0 0 0); }
.about__statement.reveal span{ transition-delay:calc(var(--i,0) * .08s); }

/* stagger helper applied via JS inline delay */

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .grid{ grid-template-columns:repeat(2,1fr); }
  .approach__steps,.stats{ grid-template-columns:repeat(2,1fr); }
  .step{ min-height:230px; }
}
@media (max-width:860px){
  .nav__links,.nav__cta{ display:none; }
  .nav__burger{ display:block; }
  .about__grid{ grid-template-columns:1fr; }
  .project,.project--alt{ grid-template-columns:1fr; gap:30px; }
  .project--alt .project__meta{ order:1; }
  .project--alt .project__media{ order:2; }
  .project__idx{ position:static; display:block; -webkit-text-stroke:1px var(--line); font-size:4rem; margin-bottom:-.3em; }
  .contact__cols{ grid-template-columns:1fr; }
}
@media (max-width:560px){
  .grid{ grid-template-columns:1fr; }
  .grid__item--tall{ grid-row:auto; }
  .approach__steps,.stats{ grid-template-columns:1fr; }
  .hero__bottom{ flex-direction:column; align-items:flex-start; gap:24px; }
  .hero__top{ font-size:.62rem; }
  .footer__row{ justify-content:flex-start; }
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
  .js .reveal,.js .reveal-media,.reveal-line>span,.hero__title .word,.hero__logo,.project__title span,.contact__big .line span{ opacity:1 !important; transform:none !important; clip-path:none !important; }
}
