:root{
  --bg:#0c0b0a;
  --bg-soft:#131210;
  --ink:#f4f1ea;
  --ink-dim:#a8a39a;
  --line:rgba(244,241,234,.12);
  --accent:#e8743b;
  --accent-soft:#f0a47a;
  --radius:22px;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:"Inter",system-ui,sans-serif;
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* film grain overlay */
body::before{
  content:"";
  position:fixed;inset:0;
  pointer-events:none;
  z-index:9999;
  opacity:.045;
  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)'/%3E%3C/svg%3E");
}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}
::selection{background:var(--accent);color:#0c0b0a}

.wrap{max-width:1280px;margin:0 auto;padding:0 32px}

/* ---------- nav ---------- */
header{
  position:fixed;top:0;left:0;right:0;
  z-index:1000;
  padding:22px 0;
  transition:background .4s var(--ease),padding .4s var(--ease),border-color .4s;
  border-bottom:1px solid transparent;
}
header.scrolled{
  background:rgba(12,11,10,.72);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-color:var(--line);
  padding:14px 0;
}
nav{display:flex;align-items:center;justify-content:space-between}
.logo{display:inline-flex;align-items:center;line-height:0}
.logo img{height:30px;width:auto;display:block}
@media(max-width:560px){.logo img{height:24px}}
.nav-links{display:flex;gap:34px;list-style:none}
.nav-links a{font-size:13px;letter-spacing:.04em;color:var(--ink-dim);transition:color .3s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{
  font-size:13px;padding:9px 18px;border:1px solid var(--line);
  border-radius:100px;color:var(--ink);transition:.3s var(--ease);
}
.nav-cta:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}

/* ---------- hero ---------- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:140px 0 70px;
  overflow:hidden;
}
.hero-glow{
  position:absolute;border-radius:50%;filter:blur(120px);
  opacity:.5;pointer-events:none;
}
.glow-1{width:520px;height:520px;background:#3a1d10;top:-120px;right:-80px}
.glow-2{width:420px;height:420px;background:#15233a;bottom:-100px;left:-60px;opacity:.4}

/* hero background video: muted, looped, autoplay. Sits behind all content
   with a darkening + grain overlay so text stays legible and the existing
   dark aesthetic is preserved. */
.hero-bg{
  position:absolute;inset:0;z-index:0;overflow:hidden;
  background:var(--bg);
}
.hero-bg video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;
  /* scale slightly to hide edge rounding on loop cuts */
  transform:scale(1.04);
  opacity:0;transition:opacity 1.2s var(--ease);
}
.hero-bg video.is-ready{opacity:1}
.hero-bg .hero-poster{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  opacity:1;transition:opacity 1.2s var(--ease);
}
.hero-bg.video-ready .hero-poster{opacity:0}
/* darkening + tint overlay over the video for readability + mood */
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(to top, rgba(12,11,10,.92) 0%, rgba(12,11,10,.55) 45%, rgba(12,11,10,.75) 100%),
    radial-gradient(120% 90% at 80% 10%, rgba(58,29,16,.35), transparent 60%);
  z-index:1;
}
/* keep hero content above the video layer */
.hero > .wrap{position:relative;z-index:2}

.hero-meta{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:36px;
  border-bottom:1px solid var(--line);padding-bottom:18px;
}
.hero-meta .label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim)}

.hero h1{
  font-family:"Fraunces",serif;
  font-weight:300;
  font-size:clamp(48px,11vw,168px);
  line-height:.92;
  letter-spacing:-.035em;
}
.hero h1 em{font-style:italic;font-weight:400;color:var(--accent-soft)}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line span{display:inline-block;transform:translateY(110%);animation:rise .9s var(--ease) forwards}
.hero h1 .line:nth-child(2) span{animation-delay:.12s}
.hero h1 .line:nth-child(3) span{animation-delay:.24s}
@keyframes rise{to{transform:translateY(0)}}

.hero-foot{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-top:54px;gap:40px;flex-wrap:wrap;
}
.hero-foot p{max-width:520px;color:var(--ink-dim);font-size:15px}
.scroll-hint{
  display:flex;align-items:center;gap:12px;font-size:12px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);
}
.scroll-hint .bar{width:42px;height:1px;background:var(--ink-dim);position:relative;overflow:hidden}
.scroll-hint .bar::after{content:"";position:absolute;inset:0;background:var(--ink);transform:translateX(-100%);animation:slide 2.2s var(--ease) infinite}
@keyframes slide{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}

/* ---------- marquee ---------- */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  overflow:hidden;padding:22px 0;margin-top:60px;
}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:marq 28s linear infinite;width:max-content}
.marquee span{font-family:"Fraunces",serif;font-style:italic;font-size:26px;color:var(--ink-dim)}
.marquee span b{color:var(--accent);font-style:normal;font-weight:400}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- section heads ---------- */
section{padding:130px 0;position:relative}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:60px;gap:40px;flex-wrap:wrap}
.sec-head .num{font-size:12px;letter-spacing:.18em;color:var(--ink-dim)}
.sec-head h2{font-family:"Fraunces",serif;font-weight:300;font-size:clamp(34px,5vw,64px);letter-spacing:-.02em;line-height:1}
.sec-head h2 em{font-style:italic;color:var(--accent-soft)}
.sec-head .lede{max-width:340px;color:var(--ink-dim);font-size:15px}

/* ---------- work ----------
 * Pinterest-style masonry via CSS multi-column. Each image keeps its exact
 * original aspect ratio (zero cropping) and flows into N columns that adapt
 * to screen width. break-inside:avoid keeps each card intact within a column. */
.work-grid{
  column-count:var(--cols, 3);
  column-gap:24px;
}
@media(max-width:1024px){ .work-grid{--cols:2} }
@media(max-width:620px){  .work-grid{--cols:1} }

.card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:var(--bg-soft);cursor:pointer;
  break-inside:avoid;
  -webkit-column-break-inside:avoid;
  page-break-inside:avoid;
  margin:0 0 24px;
  display:block;
}
/* media shows the image at its natural ratio; no forced aspect, no cover crop */
.card .media{position:relative;overflow:hidden}
.card .media img{
  display:block;width:100%;height:auto;
  transition:transform 1.1s var(--ease),filter .8s var(--ease);
  filter:grayscale(.25) contrast(1.05);
}
.card:hover .media img{transform:scale(1.06);filter:grayscale(0) contrast(1.08)}
.card .info{
  position:absolute;left:0;right:0;bottom:0;
  padding:24px 26px;
  background:linear-gradient(to top,rgba(8,7,6,.92),rgba(8,7,6,0));
  transform:translateY(8px);opacity:.92;transition:.5s var(--ease);
}
.card:hover .info{transform:translateY(0);opacity:1}
.card .tag{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-soft)}
.card h3{font-family:"Fraunces",serif;font-weight:400;font-size:24px;margin-top:6px;letter-spacing:-.01em}
.card .yr{position:absolute;top:22px;right:24px;font-size:12px;color:var(--ink-dim);mix-blend-mode:difference}

/* ---------- services ---------- */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.service{background:var(--bg);padding:42px 34px;transition:background .4s;position:relative}
.service:hover{background:var(--bg-soft)}
.service .ic{
  width:46px;height:46px;border-radius:12px;
  border:1px solid var(--line);display:grid;place-items:center;margin-bottom:30px;
  color:var(--accent-soft);
}
.service h3{font-family:"Fraunces",serif;font-weight:400;font-size:24px;margin-bottom:12px}
.service p{color:var(--ink-dim);font-size:14.5px}
.service .idx{position:absolute;top:24px;right:26px;font-size:12px;color:var(--ink-dim)}

/* ---------- stats ---------- */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
  padding:80px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.stat .n{font-family:"Fraunces",serif;font-weight:300;font-size:clamp(48px,7vw,96px);letter-spacing:-.03em;line-height:1}
.stat .n em{font-style:italic;color:var(--accent-soft)}
.stat .l{margin-top:10px;font-size:13px;color:var(--ink-dim);letter-spacing:.04em}

/* ---------- process ---------- */
.process{display:flex;flex-direction:column;gap:0}
.step{
  display:grid;grid-template-columns:80px 1fr 2fr;gap:30px;align-items:start;
  padding:34px 0;border-top:1px solid var(--line);transition:padding .4s;
}
.step:last-child{border-bottom:1px solid var(--line)}
.step:hover{padding-left:14px}
.step .n{font-family:"Fraunces",serif;font-size:22px;color:var(--accent-soft)}
.step h3{font-family:"Fraunces",serif;font-weight:400;font-size:26px}
.step p{color:var(--ink-dim);font-size:15px;max-width:520px}

/* ---------- contact ---------- */
.contact{padding:160px 0 90px;text-align:center;position:relative;overflow:hidden}
.contact .glow{position:absolute;width:600px;height:600px;border-radius:50%;background:#3a1d10;filter:blur(160px);opacity:.45;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}
.contact .kicker{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);position:relative}
.contact h2{
  font-family:"Fraunces",serif;font-weight:300;
  font-size:clamp(40px,9vw,140px);letter-spacing:-.035em;line-height:.95;
  margin:24px 0 50px;position:relative;
}
.contact h2 em{font-style:italic;color:var(--accent-soft)}
.contact a.mail{
  display:inline-block;font-family:"Fraunces",serif;font-size:clamp(22px,3vw,34px);
  border-bottom:1px solid var(--line);padding-bottom:6px;transition:.4s var(--ease);position:relative;
}
.contact a.mail:hover{color:var(--accent-soft);border-color:var(--accent-soft);transform:translateY(-3px)}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:34px 0}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:20px;font-size:13px;color:var(--ink-dim)}

/* ---------- project detail ---------- */
.proj-hero{padding:160px 0 60px}
.proj-hero .crumb{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);display:inline-flex;gap:8px;align-items:center}
.proj-hero .crumb a{transition:color .3s}
.proj-hero .crumb a:hover{color:var(--ink)}
.proj-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;margin-top:30px}
.proj-head h1{font-family:"Fraunces",serif;font-weight:300;font-size:clamp(44px,7vw,110px);letter-spacing:-.03em;line-height:.95}
.proj-head h1 em{font-style:italic;color:var(--accent-soft)}
.proj-meta{display:flex;flex-direction:column;gap:14px;align-items:flex-end;text-align:right}
.proj-meta .row{display:flex;gap:8px;font-size:14px}
.proj-meta .row .k{color:var(--ink-dim);text-transform:uppercase;letter-spacing:.1em;font-size:11px;align-self:center}
.proj-meta .row .v{font-family:"Fraunces",serif;font-size:18px}
.proj-summary{max-width:620px;color:var(--ink-dim);font-size:17px;margin-top:28px;line-height:1.7}

.proj-cover{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:var(--bg-soft);margin-top:50px;
}
.proj-cover img{aspect-ratio:16/9;object-fit:cover}

.proj-block{margin-top:110px}
.proj-block .blk-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:34px;gap:24px;flex-wrap:wrap}
.proj-block .blk-head h2{font-family:"Fraunces",serif;font-weight:300;font-size:clamp(28px,3.5vw,44px);letter-spacing:-.02em}
.proj-block .blk-head .ct{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim)}

.proj-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:24px}
.proj-grid .shot{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--bg-soft)}
.proj-grid .shot img{transition:transform 1.1s var(--ease)}
.proj-grid .shot:hover img{transform:scale(1.03)}
.proj-grid .shot.col-6{grid-column:span 6}
.proj-grid .shot.col-12{grid-column:span 12}
.proj-grid .shot.aspect-4-3 img{aspect-ratio:4/3;object-fit:cover}
.proj-grid .shot.aspect-16-10 img{aspect-ratio:16/10;object-fit:cover}
.proj-grid .shot.aspect-3-4 img{aspect-ratio:3/4;object-fit:cover}

.proj-video{margin-top:110px}
.proj-video .frame{position:relative;border-radius:var(--radius);overflow:hidden;background:var(--bg-soft)}
.proj-video video{display:block;width:100%;aspect-ratio:16/9;object-fit:cover;background:#000}

.proj-next{margin-top:130px;border-top:1px solid var(--line);padding-top:50px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.proj-next .lbl{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim)}
.proj-next a.back{font-family:"Fraunces",serif;font-size:clamp(24px,3vw,40px);transition:color .3s,transform .3s var(--ease)}
.proj-next a.back:hover{color:var(--accent-soft);transform:translateX(-6px)}

/* reveal */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- lightbox modal ---------- */
/* Full-screen overlay opened when a work card is clicked. Image keeps its
   natural aspect ratio, scaled to fit the viewport with a max margin. */
.lightbox{
  position:fixed;inset:0;z-index:2000;
  display:none;align-items:center;justify-content:center;
  padding:64px;
  background:rgba(8,7,6,.92);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  opacity:0;transition:opacity .35s var(--ease);
}
.lightbox.open{display:flex;opacity:1}
/* During the close flight we drop opacity via inline style; keep transition. */
.lightbox.entering{transition:none}
.lightbox .lb-stage{
  position:relative;max-width:100%;max-height:100%;
  display:flex;flex-direction:column;align-items:center;gap:18px;
  transform:translateY(12px) scale(.99);transition:transform .4s var(--ease);
}
.lightbox.open .lb-stage{transform:none}
.lightbox .lb-frame{
  position:relative;max-width:100%;max-height:78vh;
  display:flex;align-items:center;justify-content:center;
}
.lightbox .lb-frame img{
  display:block;max-width:100%;max-height:78vh;width:auto;height:auto;
  border-radius:var(--radius);box-shadow:0 30px 90px rgba(0,0,0,.6);
  object-fit:contain;
  transform-origin:0 0;
  transition:transform .5s var(--ease),opacity .35s var(--ease);
}
/* While pinning the start position we suppress the transition so the image
   snaps to the source card with no animation, then animates to target. */
.lightbox.entering .lb-frame img{transition:none}
/* loading shimmer while the full image decodes */
.lightbox.loading .lb-frame img{opacity:0}
.lightbox .lb-spin{
  position:absolute;inset:0;display:none;place-items:center;
  color:var(--ink-dim);font-size:12px;letter-spacing:.14em;text-transform:uppercase;
}
.lightbox.loading .lb-spin{display:grid}

.lightbox .lb-meta{
  display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;
  max-width:100%;text-align:center;
}
.lightbox .lb-meta .tag{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-soft)}
.lightbox .lb-meta h3{font-family:"Fraunces",serif;font-weight:400;font-size:22px;letter-spacing:-.01em}
.lightbox .lb-meta .yr{font-size:13px;color:var(--ink-dim)}
.lightbox .lb-meta .vproj{
  margin-left:10px;font-size:12px;letter-spacing:.04em;color:var(--ink);
  border-bottom:1px solid var(--line);padding-bottom:2px;transition:.3s var(--ease);
}
.lightbox .lb-meta .vproj:hover{color:var(--accent-soft);border-color:var(--accent-soft)}

/* close button */
.lightbox .lb-close{
  position:absolute;top:24px;right:28px;z-index:2;
  width:44px;height:44px;border-radius:50%;
  border:1px solid var(--line);background:rgba(8,7,6,.5);
  color:var(--ink);display:grid;place-items:center;cursor:pointer;
  transition:background .3s,transform .3s var(--ease);
}
.lightbox .lb-close:hover{background:var(--ink);color:var(--bg);transform:rotate(90deg)}
.lightbox .lb-close svg{width:18px;height:18px;stroke-width:1.6}

/* prev / next controls */
.lightbox .lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:2;
  width:46px;height:46px;border-radius:50%;
  border:1px solid var(--line);background:rgba(8,7,6,.5);
  color:var(--ink);display:grid;place-items:center;cursor:pointer;
  transition:background .3s,transform .3s var(--ease);
}
.lightbox .lb-nav:hover{background:var(--ink);color:var(--bg)}
.lightbox .lb-nav.prev{left:24px}
.lightbox .lb-nav.next{right:24px}
.lightbox .lb-nav svg{width:20px;height:20px;stroke-width:1.6}
.lightbox .lb-nav[hidden]{display:none}

/* counter bottom-left */
.lightbox .lb-count{
  position:absolute;bottom:26px;left:32px;z-index:2;
  font-size:12px;letter-spacing:.12em;color:var(--ink-dim);font-variant-numeric:tabular-nums;
}

@media(max-width:880px){
  .lightbox{padding:40px 16px}
  .lightbox .lb-nav.prev{left:8px}
  .lightbox .lb-nav.next{right:8px}
  .lightbox .lb-close{top:14px;right:14px}
  .lightbox .lb-frame img{max-height:70vh}
}

/* ---------- before/after reveal slider ---------- */
/* Two images stacked, the top (before) is clipped by width to reveal the
   bottom (after) underneath. Pointer/touch drag, keyboard, and tap-to-set. */
.reveal-slider{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:var(--bg-soft);user-select:none;-webkit-user-select:none;
  touch-action:none;cursor:ew-resize;
}
.reveal-slider .rs-layer{
  position:absolute;inset:0;
  background-size:cover;background-position:center;background-repeat:no-repeat;
}
/* before sits on top and gets clipped; after is the base layer */
.reveal-slider .rs-before{clip-path:inset(0 50% 0 0);will-change:clip-path}
.reveal-slider .rs-after{z-index:0}
.reveal-slider .rs-fallback img{display:block;width:100%;height:auto}
/* hide fallback once JS is active */
.reveal-slider.is-active .rs-fallback{display:none}

/* corner labels */
.reveal-slider .rs-label{
  position:absolute;top:18px;z-index:3;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  padding:7px 13px;border-radius:100px;
  background:rgba(8,7,6,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  color:var(--ink);pointer-events:none;
}
.reveal-slider .rs-label.before{left:18px;color:var(--ink-dim)}
.reveal-slider .rs-label.after{right:18px;color:var(--accent-soft)}

/* divider line + handle */
.reveal-slider .rs-handle{
  position:absolute;top:0;bottom:0;left:50%;z-index:2;
  width:2px;margin-left:-1px;background:var(--ink);
  transform:translateX(0);
}
.reveal-slider .rs-handle::before{
  content:"";position:absolute;left:50%;top:0;bottom:0;width:1px;
  background:rgba(255,255,255,.25);transform:translateX(-1px);
}
.reveal-slider .rs-knob{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:54px;height:54px;border-radius:50%;
  background:var(--ink);color:var(--bg);
  display:grid;place-items:center;
  box-shadow:0 8px 30px rgba(0,0,0,.5);
  transition:transform .25s var(--ease);
}
.reveal-slider:hover .rs-knob{transform:translate(-50%,-50%) scale(1.08)}
.reveal-slider .rs-knob svg{width:22px;height:22px;stroke-width:1.6}

/* progress chip bottom-center */
.reveal-slider .rs-progress{
  position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:3;
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);
  padding:7px 14px;border-radius:100px;border:1px solid var(--line);
  background:rgba(8,7,6,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  font-variant-numeric:tabular-nums;pointer-events:none;
}
.reveal-slider .rs-progress b{color:var(--ink);font-weight:500}

/* hover hint shown until first interaction */
.reveal-slider .rs-hint{
  position:absolute;bottom:18px;right:18px;z-index:3;
  font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-dim);
  transition:opacity .6s var(--ease);
}
.reveal-slider.is-touched .rs-hint{opacity:0}
@media(max-width:880px){ .reveal-slider .rs-hint{display:none} }

/* showcase section layout (homepage) */
.showcase{padding:120px 0}
.showcase-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;margin-bottom:50px}
.showcase-head h2{font-family:"Fraunces",serif;font-weight:300;font-size:clamp(34px,5vw,64px);letter-spacing:-.02em;line-height:1}
.showcase-head h2 em{font-style:italic;color:var(--accent-soft)}
.showcase-head .kicker{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:14px}
.showcase-head .lede{max-width:340px;color:var(--ink-dim);font-size:15px}
.showcase .reveal-slider{aspect-ratio:16/10}
.showcase-foot{margin-top:22px;display:flex;justify-content:flex-end}
.showcase-foot a{font-size:13px;letter-spacing:.04em;color:var(--ink-dim);border-bottom:1px solid var(--line);padding-bottom:4px;transition:.3s var(--ease)}
.showcase-foot a:hover{color:var(--accent-soft);border-color:var(--accent-soft)}

/* ---------- spotlight (full-project feature on homepage) ---------- */
.spotlight{padding:120px 0}
.spotlight-inner{
  display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;
}
.spotlight .sp-media{
  position:relative;border-radius:var(--radius);overflow:hidden;
  background:var(--bg-soft);aspect-ratio:4/3;
}
.spotlight .sp-media img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.2s var(--ease),filter .8s var(--ease);
  filter:grayscale(.2) contrast(1.05);
}
.spotlight .sp-media:hover img{transform:scale(1.04);filter:grayscale(0) contrast(1.08)}
.spotlight .sp-media .badge{
  position:absolute;top:22px;left:22px;z-index:2;
  font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  padding:7px 13px;border-radius:100px;
  background:rgba(8,7,6,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  color:var(--accent-soft);
}
.spotlight .sp-copy .num{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-dim)}
.spotlight .sp-copy h2{
  font-family:"Fraunces",serif;font-weight:300;
  font-size:clamp(34px,5vw,64px);letter-spacing:-.02em;line-height:1;
  margin:16px 0 22px;
}
.spotlight .sp-copy h2 em{font-style:italic;color:var(--accent-soft)}
.spotlight .sp-copy p{color:var(--ink-dim);font-size:16px;max-width:480px;line-height:1.7}
.spotlight .sp-meta{display:flex;gap:28px;margin:26px 0 34px;flex-wrap:wrap}
.spotlight .sp-meta .row .k{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:4px}
.spotlight .sp-meta .row .v{font-family:"Fraunces",serif;font-size:18px}
.spotlight .sp-cta{
  display:inline-flex;align-items:center;gap:12px;
  font-family:"Fraunces",serif;font-size:22px;
  border-bottom:1px solid var(--line);padding-bottom:7px;
  transition:color .3s,border-color .3s,transform .3s var(--ease);
}
.spotlight .sp-cta svg{width:18px;height:18px;transition:transform .3s var(--ease)}
.spotlight .sp-cta:hover{color:var(--accent-soft);border-color:var(--accent-soft)}
.spotlight .sp-cta:hover svg{transform:translateX(6px)}
@media(max-width:880px){
  .spotlight-inner{grid-template-columns:1fr;gap:36px}
  .spotlight .sp-media{aspect-ratio:16/10}
}

/* project-page reveal block */
.proj-reveal{margin-top:110px}
.proj-reveal .blk-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:34px;gap:24px;flex-wrap:wrap}
.proj-reveal .blk-head h2{font-family:"Fraunces",serif;font-weight:300;font-size:clamp(28px,3.5vw,44px);letter-spacing:-.02em}
.proj-reveal .blk-head .ct{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-dim)}
.proj-reveal .reveal-slider{aspect-ratio:16/10}

/* manifest-load notice */
.load-notice{padding:40px 0;color:var(--ink-dim);font-size:14px;text-align:center}

@media(max-width:880px){
  .nav-links{display:none}
  .hero-meta{flex-direction:column;align-items:flex-start;gap:14px}
  .work-grid{gap:18px;column-gap:18px}
  .card{margin-bottom:18px}
  .services{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr);gap:50px 20px}
  .step{grid-template-columns:50px 1fr;gap:18px}
  .step p{grid-column:1/-1}
  section{padding:90px 0}
  .proj-grid .shot.col-6,.proj-grid .shot.col-12{grid-column:span 12}
  .proj-head{align-items:flex-start}
  .proj-meta{align-items:flex-start;text-align:left}
  .showcase .reveal-slider,.proj-reveal .reveal-slider{aspect-ratio:4/3}
}
