/* =============================================================
   STUDIO KAYE — Premium Interior Design
   Design system & components
   ============================================================= */

/* ---------- Fonts ---------- */
/* Fraunces (display serif) + Hanken Grotesk (body) loaded via <link> in head */

/* ---------- Tokens ---------- */
:root{
  /* palette (warm organic-modern, refined) */
  --paper:        #FBF8F2;
  --cream:        #F4EDE2;
  --cream-soft:   #EDE4D6;
  --sand:         #E4D8C6;
  --espresso:     #2A2520;
  --espresso-deep:#1B1712;
  --ink:          #322D27;
  --ink-soft:     #6F665B;
  --ink-faint:    #968B7D;
  --rose:         #CBA89B;
  --rose-soft:    #E7D4CB;
  --clay:         #B17E64;
  --clay-deep:    #9A6A50;
  --sage:         #7E8A71;
  --gold:         #B89B6E;

  --line:         rgba(42,37,32,.14);
  --line-soft:    rgba(42,37,32,.08);
  --line-on-dark: rgba(244,237,226,.16);

  /* type */
  --serif: "Fraunces", "Georgia", serif;
  --sans:  "Hanken Grotesk", "Helvetica Neue", Arial, sans-serif;

  /* spacing / layout */
  --container: 1320px;
  --gutter: clamp(22px, 5vw, 88px);
  --section: clamp(72px, 11vw, 168px);
  --radius: 4px;

  /* motion */
  --ease: cubic-bezier(.22,1,.36,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);
  --dur: .9s;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;}
*{margin:0;padding:0;}
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
  scroll-padding-top:96px;
}
body{
  font-family:var(--sans);
  font-size:clamp(16.5px,1.05vw,18px);
  line-height:1.72;
  color:var(--ink);
  background:var(--cream);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-weight:380;
  overflow-x:hidden;
  letter-spacing:.005em;
}
img{display:block;max-width:100%;height:auto;}
body{transition:opacity .42s var(--ease);}
body.leaving{opacity:0;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
ul{list-style:none;}
input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;}
::selection{background:var(--clay);color:var(--paper);}

/* ---------- Typography ---------- */
h1,h2,h3,h4,.display{
  font-family:var(--serif);
  font-weight:340;
  line-height:1.04;
  letter-spacing:-.012em;
  color:var(--espresso);
  font-optical-sizing:auto;
}
.display-xl{font-size:clamp(2.9rem,8.5vw,8.4rem);line-height:.96;font-weight:300;}
.display-lg{font-size:clamp(2.5rem,6vw,5.4rem);font-weight:320;}
.display-md{font-size:clamp(2rem,4.2vw,3.6rem);font-weight:340;}
.display-sm{font-size:clamp(1.55rem,2.6vw,2.4rem);font-weight:360;line-height:1.12;}
h1{font-size:clamp(2.4rem,5.2vw,4.6rem);}
h2{font-size:clamp(2rem,4vw,3.4rem);}
h3{font-size:clamp(1.4rem,2.2vw,2rem);}
em,.italic{font-style:italic;}

p{max-width:62ch;}
.lead{
  font-size:clamp(1.12rem,1.55vw,1.4rem);
  line-height:1.62;
  color:var(--ink);
  font-weight:380;
  max-width:48ch;
}

.eyebrow{
  font-family:var(--sans);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--clay);
  display:inline-flex;
  align-items:center;
  gap:.7em;
}
.eyebrow::before{
  content:"";
  width:30px;height:1px;
  background:var(--clay);
  display:inline-block;
  opacity:.7;
}
.eyebrow.no-rule::before{display:none;}
.eyebrow.center{justify-content:center;}

.muted{color:var(--ink-soft);}
.serif{font-family:var(--serif);}

/* ---------- Layout ---------- */
.container{
  width:100%;
  max-width:var(--container);
  margin-inline:auto;
  padding-inline:var(--gutter);
}
.container-wide{max-width:1640px;margin-inline:auto;padding-inline:var(--gutter);}
.section{padding-block:var(--section);}
.section-sm{padding-block:clamp(54px,7vw,96px);}
.grid{display:grid;gap:clamp(28px,4vw,72px);}
.center{text-align:center;}
.flow > * + *{margin-top:1.1em;}

/* ---------- Buttons ---------- */
.btn{
  position:relative;
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);
  font-size:.78rem;font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;
  padding:1.15em 2.1em;
  border-radius:999px;
  overflow:hidden;
  isolation:isolate;
  transition:color .5s var(--ease), transform .5s var(--ease);
}
.btn .ico{transition:transform .5s var(--ease);}
.btn:hover .ico{transform:translateX(5px);}
.btn::before{
  content:"";position:absolute;inset:0;z-index:-1;
  border-radius:inherit;
  transition:transform .55s var(--ease);
}
/* solid (clay) */
.btn-solid{color:var(--paper);background:var(--clay);}
.btn-solid::before{background:var(--espresso);transform:translateY(101%);}
.btn-solid:hover{color:var(--paper);}
.btn-solid:hover::before{transform:translateY(0);}
/* outline on light */
.btn-line{
  color:var(--espresso);
  border:1px solid var(--line);
}
.btn-line::before{background:var(--espresso);transform:translateY(101%);}
.btn-line:hover{color:var(--paper);border-color:var(--espresso);}
.btn-line:hover::before{transform:translateY(0);}
/* outline on dark */
.btn-ghost{
  color:var(--paper);
  border:1px solid var(--line-on-dark);
}
.btn-ghost::before{background:var(--paper);transform:translateY(101%);}
.btn-ghost:hover{color:var(--espresso);border-color:var(--paper);}
.btn-ghost:hover::before{transform:translateY(0);}

/* text link with animated underline */
.link{
  display:inline-flex;align-items:center;gap:.55em;
  font-size:.8rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  position:relative;color:var(--espresso);
}
.link::after{
  content:"";position:absolute;left:0;bottom:-5px;height:1px;width:100%;
  background:currentColor;transform:scaleX(0);transform-origin:right;
  transition:transform .5s var(--ease);
}
.link:hover::after{transform:scaleX(1);transform-origin:left;}
.link .ico{transition:transform .45s var(--ease);}
.link:hover .ico{transform:translateX(4px);}
.link.on-dark{color:var(--paper);}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding-block:clamp(16px,2vw,26px);
  transition:padding .5s var(--ease), background .5s var(--ease), backdrop-filter .5s var(--ease), box-shadow .5s var(--ease);
}
.site-header .container-wide{display:flex;align-items:center;justify-content:space-between;gap:24px;}
.site-header.scrolled{
  padding-block:12px;
  background:rgba(27,23,18,.82);
  backdrop-filter:blur(14px) saturate(1.2);
  -webkit-backdrop-filter:blur(14px) saturate(1.2);
  box-shadow:0 1px 0 var(--line-on-dark);
}
.brand{display:flex;align-items:center;gap:12px;z-index:10;}
.brand img{height:clamp(26px,3vw,34px);width:auto;transition:height .5s var(--ease);
  filter:drop-shadow(0 1px 12px rgba(0,0,0,.25));}
.scrolled .brand img{height:26px;}

.nav{display:flex;align-items:center;gap:clamp(20px,2.4vw,44px);}
.nav a{
  font-size:.78rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--paper);position:relative;padding-block:6px;opacity:.92;
  transition:opacity .4s var(--ease);
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:var(--rose);transform:scaleX(0);transform-origin:right;
  transition:transform .45s var(--ease);
}
.nav a:hover{opacity:1;}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1);transform-origin:left;}
.nav a.active{opacity:1;}
.header-cta{display:inline-flex;align-items:center;}
.header-cta .btn{padding:.85em 1.5em;font-size:.72rem;}

/* mobile toggle */
.nav-toggle{display:none;width:42px;height:42px;position:relative;z-index:300;}
.nav-toggle span{
  position:absolute;left:9px;right:9px;height:1.4px;background:var(--paper);
  transition:transform .45s var(--ease), opacity .3s var(--ease), background .4s var(--ease);
}
.nav-toggle span:nth-child(1){top:16px;}
.nav-toggle span:nth-child(2){bottom:16px;}
body.menu-open .nav-toggle span{background:var(--paper);}
body.menu-open .nav-toggle span:nth-child(1){transform:translateY(4px) rotate(45deg);top:18px;}
body.menu-open .nav-toggle span:nth-child(2){transform:translateY(-4px) rotate(-45deg);bottom:18px;}

/* mobile menu overlay */
.mobile-menu{
  position:fixed;inset:0;z-index:250;
  background:var(--espresso-deep);
  display:flex;flex-direction:column;justify-content:center;
  padding:var(--gutter);
  clip-path:circle(0% at calc(100% - 44px) 44px);
  transition:clip-path .8s var(--ease);
  pointer-events:none;
}
body.menu-open .mobile-menu{clip-path:circle(150% at calc(100% - 44px) 44px);pointer-events:auto;}
.mobile-menu a{
  font-family:var(--serif);font-size:clamp(2rem,9vw,3.4rem);font-weight:320;
  color:var(--paper);padding-block:.12em;opacity:0;transform:translateY(24px);
  transition:opacity .5s var(--ease), transform .5s var(--ease), color .3s;
  line-height:1.1;
}
.mobile-menu a:hover{color:var(--rose);}
body.menu-open .mobile-menu a{opacity:1;transform:translateY(0);}
body.menu-open .mobile-menu a:nth-child(1){transition-delay:.28s;}
body.menu-open .mobile-menu a:nth-child(2){transition-delay:.34s;}
body.menu-open .mobile-menu a:nth-child(3){transition-delay:.40s;}
body.menu-open .mobile-menu a:nth-child(4){transition-delay:.46s;}
body.menu-open .mobile-menu a:nth-child(5){transition-delay:.52s;}
body.menu-open .mobile-menu a:nth-child(6){transition-delay:.58s;}
.mobile-menu .mm-foot{margin-top:clamp(28px,5vw,52px);display:flex;gap:22px;flex-wrap:wrap;
  opacity:0;transition:opacity .6s var(--ease) .6s;}
body.menu-open .mobile-menu .mm-foot{opacity:1;}
.mobile-menu .mm-foot a{font-family:var(--sans);font-size:.78rem;letter-spacing:.16em;
  text-transform:uppercase;transform:none;opacity:1;transition:color .3s;}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  color:var(--paper);overflow:hidden;
  padding-bottom:clamp(54px,8vw,104px);padding-top:140px;
}
.hero-media{position:absolute;inset:0;z-index:-2;overflow:hidden;}
.hero-media img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.12);
  animation:kenburns 18s ease-out forwards;
}
@keyframes kenburns{to{transform:scale(1);}}
.hero::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(16,12,9,.55) 0%,rgba(16,12,9,.12) 26%,rgba(16,12,9,.42) 60%,rgba(16,12,9,.9) 100%),
    linear-gradient(90deg,rgba(16,12,9,.6) 0%,rgba(16,12,9,.05) 52%);
}
.hero-inner{width:100%;}
.hero .eyebrow,.hero h1,.hero .lead{text-shadow:0 2px 36px rgba(0,0,0,.42);}
.hero h1{color:var(--paper);}
.hero .lead{color:rgba(251,248,242,.94);}

/* generic page hero (shorter) */
.page-hero{
  position:relative;min-height:64svh;display:flex;align-items:flex-end;
  color:var(--paper);overflow:hidden;padding:160px var(--gutter) clamp(46px,6vw,80px);
}
.page-hero .ph-media{position:absolute;inset:0;z-index:-2;}
.page-hero .ph-media img{width:100%;height:100%;object-fit:cover;transform:scale(1.1);animation:kenburns 16s ease-out forwards;}
.page-hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(16,12,9,.5),rgba(16,12,9,.2) 38%,rgba(16,12,9,.78)),
    linear-gradient(90deg,rgba(16,12,9,.55),rgba(16,12,9,.05) 55%);}
.page-hero .eyebrow,.page-hero h1,.page-hero .lead{text-shadow:0 2px 34px rgba(0,0,0,.4);}
.page-hero h1{color:var(--paper);max-width:18ch;}
.page-hero .eyebrow{color:var(--rose);}
.page-hero .eyebrow::before{background:var(--rose);}

/* ---------- Marquee ---------- */
.marquee{
  overflow:hidden;white-space:nowrap;
  border-block:1px solid var(--line);
  padding-block:clamp(18px,2.4vw,30px);
  background:var(--paper);
}
.marquee.on-dark{background:var(--espresso);border-color:var(--line-on-dark);}
.marquee-track{display:inline-flex;gap:0;will-change:transform;animation:marquee 34s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.marquee-track span{
  font-family:var(--serif);font-style:italic;font-weight:320;
  font-size:clamp(1.5rem,3vw,2.6rem);
  color:var(--espresso);padding-inline:clamp(20px,3vw,48px);
  display:inline-flex;align-items:center;gap:clamp(20px,3vw,48px);
}
.marquee.on-dark .marquee-track span{color:var(--cream);}
.marquee-track span::after{content:"";width:7px;height:7px;border-radius:50%;background:var(--clay);display:inline-block;}
@keyframes marquee{to{transform:translateX(-50%);}}

/* ---------- Reveal animations ---------- */
[data-reveal]{opacity:0;transform:translateY(34px);
  transition:opacity 1s var(--ease), transform 1s var(--ease);}
[data-reveal].in{opacity:1;transform:none;}
[data-reveal][data-delay="1"]{transition-delay:.1s;}
[data-reveal][data-delay="2"]{transition-delay:.2s;}
[data-reveal][data-delay="3"]{transition-delay:.3s;}
[data-reveal][data-delay="4"]{transition-delay:.4s;}
[data-reveal][data-delay="5"]{transition-delay:.5s;}

/* image clip reveal */
.reveal-img{position:relative;overflow:hidden;}
.reveal-img img{transform:scale(1.16);transition:transform 1.5s var(--ease);will-change:transform;}
.reveal-img::after{
  content:"";position:absolute;inset:0;background:var(--cream);transform-origin:bottom;
  transform:scaleY(1);transition:transform 1.15s var(--ease);
}
.reveal-img.in img{transform:scale(1);}
.reveal-img.in::after{transform:scaleY(0);}

/* word/line split reveal for headings */
.split .word{display:inline-block;overflow:hidden;vertical-align:top;}
.split .word i{display:inline-block;font-style:inherit;transform:translateY(108%);
  transition:transform .9s var(--ease);}
.split.in .word i{transform:translateY(0);}
.split.in .word:nth-child(2) i{transition-delay:.05s;}
.split.in .word:nth-child(3) i{transition-delay:.1s;}
.split.in .word:nth-child(4) i{transition-delay:.15s;}
.split.in .word:nth-child(5) i{transition-delay:.2s;}
.split.in .word:nth-child(6) i{transition-delay:.25s;}
.split.in .word:nth-child(7) i{transition-delay:.3s;}
.split.in .word:nth-child(8) i{transition-delay:.35s;}

/* ---------- Sections / editorial blocks ---------- */
.bg-cream{background:var(--cream);}
.bg-paper{background:var(--paper);}
.bg-soft{background:var(--cream-soft);}
.bg-sand{background:var(--sand);}
.bg-espresso{background:var(--espresso);color:var(--cream);}
.bg-espresso h1,.bg-espresso h2,.bg-espresso h3{color:var(--paper);}
.bg-espresso .eyebrow{color:var(--rose);}
.bg-espresso .eyebrow::before{background:var(--rose);}
.bg-espresso .muted{color:rgba(244,237,226,.66);}

.split-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,90px);align-items:center;}
.split-2.top{align-items:start;}
.col-text{max-width:48ch;}
.media-frame{border-radius:var(--radius);overflow:hidden;}
.media-frame img{width:100%;height:100%;object-fit:cover;}
.ratio-4-5{aspect-ratio:4/5;}
.ratio-3-4{aspect-ratio:3/4;}
.ratio-1-1{aspect-ratio:1/1;}
.ratio-3-2{aspect-ratio:3/2;}
.ratio-16-9{aspect-ratio:16/9;}

/* feature index list */
.idx{border-top:1px solid var(--line);}
.idx li{
  display:grid;grid-template-columns:auto 1fr;gap:clamp(16px,3vw,48px);align-items:baseline;
  padding-block:clamp(20px,2.6vw,34px);border-bottom:1px solid var(--line);
}
.idx li .n{font-family:var(--serif);font-size:1rem;color:var(--clay);}
.idx li h3{font-weight:340;}
.idx li p{color:var(--ink-soft);margin-top:.5em;font-size:.98rem;}

/* checklist columns */
.checklist{columns:2;column-gap:clamp(28px,4vw,64px);}
.checklist li{break-inside:avoid;display:flex;gap:.7em;padding-block:.5em;
  border-bottom:1px solid var(--line-soft);color:var(--ink);font-size:.98rem;}
.checklist li::before{content:"";flex:0 0 auto;width:7px;height:7px;margin-top:.62em;
  border-radius:50%;background:var(--clay);}

/* tags */
.tags{display:flex;flex-wrap:wrap;gap:10px;}
.tag{
  font-size:.74rem;letter-spacing:.06em;font-weight:500;
  padding:.55em 1.1em;border-radius:999px;border:1px solid var(--line);
  color:var(--ink);background:rgba(255,255,255,.35);
}
.bg-espresso .tag{border-color:var(--line-on-dark);color:var(--cream);background:rgba(255,255,255,.04);}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);}
.stat .num{font-family:var(--serif);font-size:clamp(2.6rem,5vw,4.2rem);font-weight:300;
  line-height:1;color:var(--clay);}
.stat .lab{margin-top:.7em;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);}
.stat + .stat{border-left:1px solid var(--line);padding-left:clamp(20px,3vw,40px);}
.bg-espresso .stat .num{color:var(--rose);}

/* ---------- Portfolio grid ---------- */
.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(20px,2.6vw,40px);}
.work-card{position:relative;display:block;overflow:hidden;border-radius:var(--radius);}
.work-card .ph{position:relative;overflow:hidden;border-radius:var(--radius);}
.work-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease), filter 1.2s var(--ease);}
.work-card:hover .ph img{transform:scale(1.05);}
.work-card .ph::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,16,12,0) 40%,rgba(20,16,12,.62));
  opacity:.55;transition:opacity .6s var(--ease);}
.work-card:hover .ph::after{opacity:.85;}
.work-meta{position:absolute;left:0;right:0;bottom:0;padding:clamp(20px,2.4vw,34px);
  color:var(--paper);transform:translateY(8px);transition:transform .6s var(--ease);}
.work-card:hover .work-meta{transform:translateY(0);}
.work-meta .cat{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--rose);}
.work-meta h3{color:var(--paper);font-weight:340;margin-top:.35em;font-size:clamp(1.3rem,2vw,1.9rem);}
.work-meta .go{display:inline-flex;align-items:center;gap:.5em;font-size:.74rem;letter-spacing:.16em;
  text-transform:uppercase;margin-top:1em;opacity:0;transform:translateY(10px);
  transition:opacity .5s var(--ease),transform .5s var(--ease);}
.work-card:hover .work-meta .go{opacity:1;transform:translateY(0);}
.span-7{grid-column:span 7;}
.span-6{grid-column:span 6;}
.span-5{grid-column:span 5;}
.span-12{grid-column:span 12;}
.work-card.tall .ph{aspect-ratio:4/5;}
.work-card.wide .ph{aspect-ratio:3/2;}
.work-card.big .ph{aspect-ratio:16/10;}

/* ---------- Project gallery ---------- */
.proj-lead{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(30px,5vw,80px);align-items:end;}
.proj-facts{border-top:1px solid var(--line);margin-top:1.6em;}
.proj-facts div{display:flex;justify-content:space-between;gap:20px;padding-block:.85em;
  border-bottom:1px solid var(--line);font-size:.92rem;}
.proj-facts dt{color:var(--ink-soft);letter-spacing:.06em;text-transform:uppercase;font-size:.74rem;}
.proj-facts dd{text-align:right;color:var(--ink);}
.gallery{columns:2;column-gap:clamp(18px,2vw,30px);}
.gallery .g{break-inside:avoid;margin-bottom:clamp(18px,2vw,30px);border-radius:var(--radius);overflow:hidden;}
.gallery .g img{width:100%;transition:transform 1.1s var(--ease);}
.gallery .g:hover img{transform:scale(1.04);}
.gallery.cols-1{columns:1;}

/* full-bleed image band */
.band{position:relative;overflow:hidden;height:clamp(58vh,70vh,86vh);}
.band img{width:100%;height:100%;object-fit:cover;}

/* ---------- Testimonials ---------- */
.quotes{position:relative;}
.quote{display:none;}
.quote.active{display:block;animation:fadeUp .8s var(--ease);}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px);}to{opacity:1;transform:none;}}
.quote blockquote{font-family:var(--serif);font-weight:320;font-style:italic;
  font-size:clamp(1.45rem,2.9vw,2.5rem);line-height:1.32;color:var(--espresso);max-width:24ch;margin-inline:auto;}
.bg-espresso .quote blockquote{color:var(--cream);}
.quote .who{margin-top:1.6em;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--clay);}
.bg-espresso .quote .who{color:var(--rose);}
.q-nav{display:flex;gap:14px;justify-content:center;margin-top:2.6em;}
.q-dot{width:9px;height:9px;border-radius:50%;border:1px solid var(--clay);transition:background .4s,transform .4s;}
.q-dot.active{background:var(--clay);transform:scale(1.25);}
.bg-espresso .q-dot{border-color:var(--rose);}
.bg-espresso .q-dot.active{background:var(--rose);}
.q-stars{color:var(--gold);letter-spacing:.25em;font-size:1.05rem;margin-bottom:1.3em;}

/* ---------- FAQ ---------- */
.faq{border-top:1px solid var(--line);max-width:880px;margin-inline:auto;}
.faq details{border-bottom:1px solid var(--line);}
.faq summary{
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  padding-block:clamp(20px,2.4vw,30px);cursor:pointer;list-style:none;
  font-family:var(--serif);font-size:clamp(1.15rem,1.9vw,1.55rem);font-weight:340;color:var(--espresso);
}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .pm{position:relative;width:20px;height:20px;flex:0 0 auto;}
.faq summary .pm::before,.faq summary .pm::after{content:"";position:absolute;background:var(--clay);
  transition:transform .4s var(--ease),opacity .4s;}
.faq summary .pm::before{top:9px;left:0;width:20px;height:1.6px;}
.faq summary .pm::after{left:9px;top:0;width:1.6px;height:20px;}
.faq details[open] summary .pm::after{transform:scaleY(0);}
.faq .ans{overflow:hidden;color:var(--ink-soft);padding-bottom:clamp(18px,2vw,26px);max-width:74ch;}
.faq .ans p + p{margin-top:1em;}

/* ---------- AI / summary card ---------- */
.summary-card{
  border:1px solid var(--line);border-radius:8px;padding:clamp(26px,3.5vw,48px);
  background:var(--paper);position:relative;
}
.summary-card .tagi{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--clay);
  display:flex;align-items:center;gap:.7em;margin-bottom:1.1em;}
.summary-card .tagi::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--sage);}
.summary-card p{font-family:var(--serif);font-weight:330;font-size:clamp(1.15rem,1.7vw,1.5rem);
  line-height:1.5;color:var(--espresso);max-width:none;}

/* ---------- Forms ---------- */
.form{display:grid;gap:22px;}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.field{display:flex;flex-direction:column;gap:.6em;}
.field label{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);}
.field input,.field textarea,.field select{
  background:transparent;border:none;border-bottom:1px solid var(--line);
  padding:.8em 0;font-size:1.02rem;color:var(--ink);transition:border-color .4s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--clay);}
.field textarea{resize:vertical;min-height:120px;}
.form .note{font-size:.82rem;color:var(--ink-faint);}

/* process steps */
.steps{display:grid;gap:clamp(20px,2.4vw,30px);}
.step{display:grid;grid-template-columns:auto 1fr;gap:clamp(18px,3vw,40px);align-items:start;
  padding-block:clamp(22px,2.6vw,34px);border-top:1px solid var(--line);}
.step .sn{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.4rem);color:var(--clay);font-weight:300;line-height:1;}
.step h3{font-weight:340;font-size:clamp(1.25rem,1.9vw,1.65rem);}
.step p{color:var(--ink-soft);margin-top:.5em;}

/* ---------- Footer ---------- */
.site-footer{background:var(--espresso-deep);color:var(--cream);padding-top:clamp(64px,8vw,120px);}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(34px,5vw,80px);
  padding-bottom:clamp(48px,6vw,80px);border-bottom:1px solid var(--line-on-dark);}
.footer-top img.fmark{height:34px;width:auto;margin-bottom:1.4em;filter:drop-shadow(0 1px 10px rgba(0,0,0,.3));}
.footer-top h2{color:var(--paper);font-weight:320;font-size:clamp(1.7rem,3vw,2.6rem);max-width:14ch;}
.footer-col h4{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--rose);margin-bottom:1.4em;}
.footer-col a{display:block;padding-block:.42em;color:rgba(244,237,226,.78);font-size:.96rem;transition:color .35s,padding-left .35s;}
.footer-col a:hover{color:var(--paper);padding-left:6px;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;
  padding-block:clamp(26px,3vw,40px);font-size:.8rem;color:rgba(244,237,226,.55);}
.footer-bottom a{color:rgba(244,237,226,.7);transition:color .3s;}
.footer-bottom a:hover{color:var(--paper);}
.footer-legal{display:flex;gap:18px;flex-wrap:wrap;}
.footer-cta{padding-block:clamp(56px,7vw,104px);text-align:center;border-bottom:1px solid var(--line-on-dark);}
.footer-cta h2{color:var(--paper);font-weight:320;}

/* ---------- Preloader ---------- */
.preloader{position:fixed;inset:0;z-index:9999;background:var(--espresso-deep);
  display:flex;align-items:center;justify-content:center;flex-direction:column;gap:24px;
  transition:opacity .8s var(--ease), visibility .8s;}
.preloader.done{opacity:0;visibility:hidden;}
.preloader img{height:42px;width:auto;opacity:0;transform:translateY(10px);
  animation:plIn 1s var(--ease) .15s forwards;}
.pl-bar{width:160px;height:1.5px;background:var(--line-on-dark);overflow:hidden;}
.pl-bar i{display:block;height:100%;width:100%;background:var(--rose);transform:translateX(-100%);
  animation:plBar 1.4s var(--ease) .3s forwards;}
@keyframes plIn{to{opacity:1;transform:none;}}
@keyframes plBar{to{transform:translateX(0);}}

/* ---------- Cursor follower ---------- */
.cursor{position:fixed;top:0;left:0;width:34px;height:34px;border:1px solid var(--clay);
  border-radius:50%;pointer-events:none;z-index:9000;transform:translate(-50%,-50%);
  transition:width .35s var(--ease),height .35s var(--ease),background .35s,border-color .35s,opacity .3s;
  mix-blend-mode:difference;opacity:0;}
.cursor.show{opacity:1;}
.cursor.grow{width:64px;height:64px;background:rgba(203,168,155,.18);border-color:transparent;}

/* scroll cue */
.scroll-cue{position:absolute;right:var(--gutter);bottom:clamp(40px,7vw,90px);
  display:flex;flex-direction:column;align-items:center;gap:14px;color:rgba(251,248,242,.7);
  font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;writing-mode:vertical-rl;}
.scroll-cue .ln{width:1px;height:54px;background:rgba(251,248,242,.4);position:relative;overflow:hidden;}
.scroll-cue .ln::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;
  background:var(--rose);animation:cue 1.8s var(--ease) infinite;}
@keyframes cue{0%{transform:translateY(-100%);}100%{transform:translateY(280%);}}

/* ---------- Accents / misc ---------- */
.kicker-num{font-family:var(--serif);color:var(--clay);font-size:1rem;}
.rule{height:1px;background:var(--line);border:none;}
.maxw-md{max-width:760px;}
.maxw-sm{max-width:560px;}
.mx-auto{margin-inline:auto;}
.mt-1{margin-top:1rem;}.mt-2{margin-top:2rem;}.mt-3{margin-top:3rem;}
.pill-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.divider-tag{display:inline-flex;gap:.6em;align-items:center;color:var(--ink-soft);
  font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;}

/* two-up image stack */
.stack{display:grid;gap:clamp(18px,2vw,26px);}
.stack.offset > :nth-child(2){margin-top:clamp(24px,5vw,72px);}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .work-grid{grid-template-columns:repeat(6,1fr);}
  .span-7,.span-6,.span-5{grid-column:span 6;}
}
@media (max-width:860px){
  .nav,.header-cta{display:none;}
  .nav-toggle{display:block;}
  .split-2{grid-template-columns:1fr;}
  .proj-lead{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr;gap:40px;}
  .stats{grid-template-columns:1fr 1fr;gap:30px 24px;}
  .stat + .stat{border-left:none;padding-left:0;}
  .stat:nth-child(3){grid-column:1/-1;}
  .gallery{columns:1;}
  .checklist{columns:1;}
  .site-header.scrolled{background:rgba(27,23,18,.92);}
}
@media (max-width:520px){
  .form .row{grid-template-columns:1fr;}
  .stats{grid-template-columns:1fr;}
  .stat + .stat{border-left:none;padding-left:0;border-top:1px solid var(--line);padding-top:24px;}
}

/* ---------- Team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2.4vw,30px);}
.team-card .media-frame,.team-card .mono{margin-bottom:1.1em;}
.team-card .role{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);}
.team-card h3{font-weight:340;font-size:clamp(1.1rem,1.5vw,1.35rem);margin-top:.3em;}
.mono{display:flex;align-items:center;justify-content:center;background:var(--espresso);
  border-radius:var(--radius);overflow:hidden;}
.mono span{font-family:var(--serif);font-weight:300;font-size:clamp(2.4rem,4vw,3.4rem);color:var(--rose);
  letter-spacing:.04em;}
.bios{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(26px,3vw,48px);}
.bio{border-top:1px solid var(--line);padding-top:1.4em;}
.bio .role{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);display:block;margin:.4em 0 .9em;}
.bio h3{font-weight:340;font-size:clamp(1.2rem,1.6vw,1.5rem);}
.bio p{color:var(--ink-soft);font-size:.96rem;}

/* ---------- Journal ---------- */
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,44px);}
.jcard .media-frame{margin-bottom:1.2em;}
.jcard .cat{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--clay);}
.jcard h3{font-weight:340;font-size:clamp(1.3rem,1.8vw,1.7rem);margin:.4em 0 .5em;}
.jcard .link{color:var(--ink-faint);}

/* ---------- Next project ---------- */
.next-proj{display:flex;flex-direction:column;gap:.6em;align-items:flex-start;}
.next-proj .ico{display:inline-block;transition:transform .5s var(--ease);}
.next-proj:hover .ico{transform:translateX(8px);}

@media (max-width:980px){
  .team-grid{grid-template-columns:repeat(2,1fr);}
  .bios{grid-template-columns:1fr;}
  .journal-grid{grid-template-columns:1fr;}
}
@media (max-width:560px){
  .team-grid{grid-template-columns:1fr 1fr;}
}

/* QA still mode (?still=1) */
.is-still [data-reveal],.is-still .reveal-img,.is-still .split{opacity:1 !important;transform:none !important;}
.is-still .reveal-img::after{transform:scaleY(0) !important;}
.is-still .split .word i{transform:none !important;}
.is-still .preloader{display:none !important;}
.is-still .hero-media img,.is-still .page-hero .ph-media img{animation:none;transform:scale(1.03);}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important;}
  [data-reveal]{opacity:1;transform:none;}
  .reveal-img::after{display:none;}
  .reveal-img img,.hero-media img,.page-hero .ph-media img{transform:none;}
  .split .word i{transform:none;}
  .cursor{display:none;}
}
@media (hover:none){.cursor{display:none;}}
