/* ============================================================
   RALLY ATELIER — Custom Homes & Design-Build, Charlotte NC
   A Rally Media showcase build. Pure CSS, no frameworks.
   Fonts: Fraunces (display) + Manrope (text)
   ============================================================ */

:root{
  --ink:#0c0a07;
  --ink-2:#14110c;
  --ink-3:#1d1912;
  --bone:#ede6d8;
  --bone-2:#cfc6b4;
  --muted:#988e7c;
  --line:rgba(237,230,216,.14);
  --line-soft:rgba(237,230,216,.08);
  --gold-1:#8a6a35;
  --gold-2:#d6b36a;
  --gold-3:#f4e6bc;
  --gold-4:#c39b52;
  --grad-gold:linear-gradient(115deg,#8a6a35 0%,#d6b36a 30%,#f4e6bc 52%,#c39b52 74%,#8a6a35 100%);
  --grad-gold-soft:linear-gradient(115deg,rgba(214,179,106,.35),rgba(244,230,188,.18),rgba(195,155,82,.35));
  --font-d:"Fraunces",Georgia,serif;
  --font-b:"Manrope",-apple-system,"Segoe UI",sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-slow:cubic-bezier(.16,1,.3,1);
  --head-h:84px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--font-b);
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--gold-2);color:var(--ink)}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
ul{list-style:none}

/* Film grain over everything — tactile texture */
body::after{
  content:"";
  position:fixed;
  inset:-50%;
  width:200%;
  height:200%;
  pointer-events:none;
  z-index:2000;
  opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='0.6'/%3E%3C/svg%3E");
  animation:grain 9s steps(8) infinite;
}
@keyframes grain{
  0%,100%{transform:translate(0,0)}
  12%{transform:translate(-2%,1%)}
  25%{transform:translate(1%,-2%)}
  37%{transform:translate(-1%,2%)}
  50%{transform:translate(2%,1%)}
  62%{transform:translate(-2%,-1%)}
  75%{transform:translate(1%,2%)}
  87%{transform:translate(-1%,-2%)}
}
@media (prefers-reduced-motion:reduce){
  body::after{animation:none}
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* Scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:#3a3225;border-radius:5px}
::-webkit-scrollbar-thumb:hover{background:var(--gold-1)}

/* Scroll progress hairline */
.scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:100%;
  transform-origin:0 50%;transform:scaleX(0);
  background:var(--grad-gold);z-index:1200;pointer-events:none;
}

/* ---------- Type scale ---------- */
.display-xl{
  font-family:var(--font-d);
  font-weight:560;
  font-size:clamp(3.2rem,11vw,10.5rem);
  line-height:.94;
  letter-spacing:-.02em;
}
.display-l{
  font-family:var(--font-d);
  font-weight:540;
  font-size:clamp(2.6rem,6.5vw,5.6rem);
  line-height:1.02;
  letter-spacing:-.015em;
}
.display-m{
  font-family:var(--font-d);
  font-weight:520;
  font-size:clamp(1.9rem,4vw,3.2rem);
  line-height:1.08;
  letter-spacing:-.01em;
}
.display-s{
  font-family:var(--font-d);
  font-weight:520;
  font-size:clamp(1.4rem,2.4vw,1.9rem);
  line-height:1.2;
}
.ital{font-style:italic;font-weight:420}
.gold-text{
  background:var(--grad-gold);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  background-size:200% auto;
  animation:goldShift 7s linear infinite;
}
@keyframes goldShift{to{background-position:200% center}}
.outline-text{
  color:transparent;
  -webkit-text-stroke:1.5px rgba(237,230,216,.55);
}
.lead{
  font-size:clamp(1.05rem,1.4vw,1.3rem);
  line-height:1.75;
  color:var(--bone-2);
  max-width:38em;
}
.body-copy{color:var(--bone-2);max-width:36em}
.body-copy + .body-copy{margin-top:1.2em}
.small{font-size:.85rem;color:var(--muted)}

.eyebrow{
  display:inline-flex;align-items:center;gap:14px;
  font-size:.72rem;font-weight:700;
  letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold-2);
  margin-bottom:1.6rem;
}
.eyebrow::before{
  content:"";width:42px;height:1px;
  background:var(--grad-gold);flex:none;
}
.chapter-no{
  font-family:var(--font-d);font-style:italic;font-weight:400;
  font-size:clamp(4rem,9vw,8rem);line-height:1;
  color:transparent;-webkit-text-stroke:1px rgba(214,179,106,.4);
  user-select:none;
}

/* ---------- Layout ---------- */
.container{width:min(1480px,92vw);margin-inline:auto}
.container-wide{width:min(1720px,96vw);margin-inline:auto}
.section{padding:clamp(5rem,10vw,9.5rem) 0}
.section-tight{padding:clamp(3.5rem,6vw,6rem) 0}
.grid-12{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1rem,2.4vw,2.4rem)}
.hairline{height:1px;background:var(--line);border:0}
.hairline-gold{height:1px;background:var(--grad-gold);opacity:.5;border:0}

/* ---------- Buttons ---------- */
.btn{
  position:relative;
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 34px;
  font-size:.78rem;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  border:1px solid rgba(214,179,106,.5);
  color:var(--bone);
  overflow:hidden;
  transition:color .45s var(--ease),border-color .45s var(--ease);
  isolation:isolate;
  white-space:nowrap;
}
.btn::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:var(--grad-gold);
  transform:translateY(101%);
  transition:transform .5s var(--ease);
}
.btn:hover{color:var(--ink);border-color:var(--gold-3)}
.btn:hover::before{transform:translateY(0)}
.btn .btn-arrow{transition:transform .45s var(--ease)}
.btn:hover .btn-arrow{transform:translateX(6px)}
.btn-gold{
  background:var(--grad-gold);
  background-size:200% auto;
  color:var(--ink);
  border-color:transparent;
  animation:goldShift 7s linear infinite;
}
.btn-gold::before{background:var(--bone)}
.btn-gold:hover{color:var(--ink)}
.btn-ghost{border-color:var(--line)}
.text-link{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold-2);position:relative;padding-bottom:6px;
}
.text-link::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:var(--grad-gold);
  transform:scaleX(.32);transform-origin:0 50%;
  transition:transform .45s var(--ease);
}
.text-link:hover::after{transform:scaleX(1)}
[data-magnetic]{will-change:transform;transition:transform .25s var(--ease)}

/* ---------- Header ---------- */
.site-head{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:transform .45s var(--ease),background .45s,border-color .45s;
  border-bottom:1px solid transparent;
}
.site-head.scrolled{
  background:rgba(12,10,7,.86);
  backdrop-filter:blur(14px);
  border-bottom-color:var(--line-soft);
}
.site-head.hidden{transform:translateY(-100%)}
.head-inner{
  width:min(1720px,96vw);margin-inline:auto;
  height:var(--head-h);
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
}
.brand{display:flex;align-items:center;flex:none}
.brand svg{display:block;height:44px;width:auto}
.head-nav{display:flex;align-items:center;gap:2.4rem}
.head-nav > a,.nav-drop-btn{
  font-size:.74rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--bone-2);position:relative;padding:8px 0;
  display:inline-flex;align-items:center;gap:7px;
  transition:color .3s;
}
.head-nav > a::after,.nav-drop-btn::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:var(--grad-gold);transform:scaleX(0);transform-origin:0 50%;
  transition:transform .4s var(--ease);
}
.head-nav > a:hover,.head-nav > a.active,.nav-drop:hover .nav-drop-btn{color:var(--bone)}
.head-nav > a:hover::after,.head-nav > a.active::after,.nav-drop:hover .nav-drop-btn::after{transform:scaleX(1)}
.nav-drop{position:relative}
.nav-drop-btn svg{transition:transform .3s var(--ease)}
.nav-drop:hover .nav-drop-btn svg{transform:rotate(180deg)}
.nav-drop-menu{
  position:absolute;top:100%;left:50%;translate:-50% 0;
  min-width:280px;padding:14px 0;
  background:rgba(20,17,12,.97);
  border:1px solid var(--line-soft);
  opacity:0;visibility:hidden;transform:translateY(12px);
  transition:opacity .3s var(--ease),transform .3s var(--ease),visibility .3s;
}
.nav-drop:hover .nav-drop-menu,.nav-drop:focus-within .nav-drop-menu{
  opacity:1;visibility:visible;transform:translateY(0);
}
.nav-drop-menu a{
  display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
  padding:12px 26px;
  font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--bone-2);transition:color .25s,background .25s,padding-left .25s;
}
.nav-drop-menu a em{font-family:var(--font-d);font-size:.72rem;color:var(--gold-1);font-weight:400}
.nav-drop-menu a:hover{color:var(--gold-2);background:rgba(214,179,106,.06);padding-left:32px}
.head-actions{display:flex;align-items:center;gap:1.4rem}
.head-cta{padding:14px 26px}
.menu-btn{
  display:none;flex-direction:column;justify-content:center;gap:7px;
  width:44px;height:44px;align-items:center;z-index:1101;
}
.menu-btn span{
  display:block;width:26px;height:1.5px;background:var(--bone);
  transition:transform .4s var(--ease),opacity .3s;
}
.menu-btn.open span:nth-child(1){transform:translateY(4.25px) rotate(45deg)}
.menu-btn.open span:nth-child(2){transform:translateY(-4.25px) rotate(-45deg)}

/* Mobile overlay menu */
.menu-overlay{
  position:fixed;inset:0;z-index:1100;
  background:var(--ink);
  display:flex;flex-direction:column;justify-content:center;
  padding:calc(var(--head-h) + 2rem) 7vw 3rem;
  clip-path:inset(0 0 100% 0);
  transition:clip-path .65s var(--ease-slow);
}
.menu-overlay.open{clip-path:inset(0 0 0% 0)}
.menu-overlay nav{display:flex;flex-direction:column;gap:.2rem}
.menu-overlay nav a{
  font-family:var(--font-d);font-weight:520;
  font-size:clamp(2rem,8vw,3.4rem);line-height:1.25;
  color:var(--bone);display:flex;align-items:baseline;gap:1.2rem;
  opacity:0;transform:translateY(26px);
  transition:opacity .5s var(--ease),transform .5s var(--ease),color .3s;
}
.menu-overlay.open nav a{opacity:1;transform:translateY(0)}
.menu-overlay nav a:hover{color:var(--gold-2)}
.menu-overlay nav a i{
  font-family:var(--font-d);font-style:italic;font-weight:400;
  font-size:.95rem;color:var(--gold-1);letter-spacing:.06em;
}
.menu-overlay .menu-foot{
  margin-top:auto;padding-top:2rem;border-top:1px solid var(--line-soft);
  display:flex;flex-wrap:wrap;gap:1rem 3rem;
  font-size:.8rem;color:var(--muted);letter-spacing:.08em;
}
.menu-overlay .menu-foot a{color:var(--gold-2)}
body.menu-locked{overflow:hidden}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:flex-end;
  overflow:hidden;
  padding-bottom:clamp(2.5rem,5vh,4.5rem);
}
.hero-media{position:absolute;inset:0;z-index:-2;overflow:hidden}
.hero-media img{
  width:100%;height:118%;object-fit:cover;
  filter:saturate(.82) contrast(1.04) brightness(.7);
  will-change:transform;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    linear-gradient(180deg,rgba(12,10,7,.55) 0%,rgba(12,10,7,.12) 38%,rgba(12,10,7,.4) 68%,rgba(12,10,7,.94) 100%),
    radial-gradient(110% 70% at 80% 20%,transparent 40%,rgba(12,10,7,.5) 100%);
}
.hero-meta{
  display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;
  font-size:.72rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;
  color:var(--bone-2);
  margin-bottom:clamp(1.6rem,3vh,3rem);
}
.hero-meta .gold-text{animation:none}
.hero-title{margin-bottom:clamp(1.8rem,3.5vh,3rem)}
.hero-sub{
  display:flex;flex-wrap:wrap;align-items:center;gap:1.6rem 3rem;
  justify-content:space-between;
}
.hero-sub .lead{max-width:30em}
.hero-cta-row{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap}
.scroll-cue{
  position:absolute;right:4vw;bottom:11rem;
  display:flex;flex-direction:column;align-items:center;gap:14px;
  font-size:.62rem;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);
  writing-mode:vertical-rl;
}
.scroll-cue::after{
  content:"";width:1px;height:64px;
  background:linear-gradient(var(--gold-2),transparent);
  animation:cueDrop 2.2s var(--ease) infinite;
}
@keyframes cueDrop{
  0%{transform:scaleY(0);transform-origin:top}
  45%{transform:scaleY(1);transform-origin:top}
  55%{transform:scaleY(1);transform-origin:bottom}
  100%{transform:scaleY(0);transform-origin:bottom}
}

/* Kinetic line reveal (masked rise) */
.k-line{display:block;overflow:hidden;padding-bottom:.06em;margin-bottom:-.06em}
.k-line > span{
  display:inline-block;
  transform:translateY(112%) rotate(.6deg);
  transition:transform 1.1s var(--ease-slow);
  will-change:transform;
}
.is-loaded .k-line > span{transform:translateY(0) rotate(0)}
.is-loaded .k-line:nth-child(1) > span{transition-delay:.1s}
.is-loaded .k-line:nth-child(2) > span{transition-delay:.22s}
.is-loaded .k-line:nth-child(3) > span{transition-delay:.34s}
.is-loaded .k-line:nth-child(4) > span{transition-delay:.46s}
.hero .fade-late{opacity:0;transform:translateY(18px);transition:opacity .9s var(--ease) .85s,transform .9s var(--ease) .85s}
.is-loaded .hero .fade-late{opacity:1;transform:translateY(0)}

/* Page hero (interior pages) */
.page-hero{
  position:relative;
  padding:calc(var(--head-h) + clamp(4rem,9vh,7rem)) 0 clamp(3rem,6vh,5rem);
  overflow:hidden;
}
.page-hero-split{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1.5rem,3vw,3rem);align-items:end}
.page-hero-copy{grid-column:1/8}
.page-hero-fig{grid-column:8/13;position:relative}
.page-hero-fig .img-frame{aspect-ratio:4/5}

/* ---------- Marquee ticker ---------- */
.marquee{
  overflow:hidden;white-space:nowrap;
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  padding:1.3rem 0;
  position:relative;
  background:var(--ink-2);
}
.marquee-track{
  display:inline-flex;align-items:center;gap:3.4rem;
  padding-right:3.4rem;
  animation:marquee 30s linear infinite;
  will-change:transform;
}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
.marquee-item{
  display:inline-flex;align-items:center;gap:3.4rem;
  font-family:var(--font-d);font-weight:480;
  font-size:clamp(1.2rem,2.4vw,2rem);
  letter-spacing:.04em;color:var(--bone-2);
}
.marquee-item em{font-style:italic;color:var(--gold-2)}
.marquee-item .tick{
  width:9px;height:9px;flex:none;transform:rotate(45deg);
  background:var(--grad-gold);
}
.marquee-big .marquee-item{
  font-size:clamp(2.6rem,7vw,6rem);
  color:transparent;-webkit-text-stroke:1px rgba(237,230,216,.35);
}
.marquee-big .marquee-item em{
  -webkit-text-stroke:0;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.marquee-big{border:0;background:transparent;padding:.4rem 0}

/* ---------- Images ---------- */
.img-frame{
  position:relative;overflow:hidden;background:var(--ink-3);
}
.img-frame img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.85) contrast(1.03);
  transition:transform 1.1s var(--ease),filter .8s;
  will-change:transform;
}
.img-frame:hover img{transform:scale(1.045);filter:saturate(1) contrast(1.05)}
.img-frame .frame-cap{
  position:absolute;left:0;right:0;bottom:0;
  padding:2.4rem 1.6rem 1.3rem;
  background:linear-gradient(transparent,rgba(12,10,7,.82));
  display:flex;justify-content:space-between;align-items:baseline;gap:1rem;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--bone-2);
  transform:translateY(8px);opacity:0;
  transition:opacity .5s var(--ease),transform .5s var(--ease);
}
.img-frame:hover .frame-cap{opacity:1;transform:translateY(0)}
.img-frame .frame-cap em{font-family:var(--font-d);font-style:italic;text-transform:none;letter-spacing:.04em;color:var(--gold-2);font-size:.9rem}
.gold-frame{position:relative}
.gold-frame::before{
  content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  border:1px solid rgba(214,179,106,.35);
  translate:14px 14px;
  transition:translate .5s var(--ease);
}
.gold-frame:hover::before{translate:8px 8px}
[data-parallax]{overflow:hidden}
[data-parallax] img{transform:translateY(var(--py,0)) scale(1.14)}

/* ---------- Reveal engine ---------- */
[data-reveal]{
  opacity:0;transform:translateY(34px);
  transition:opacity .95s var(--ease),transform .95s var(--ease);
  transition-delay:var(--rd,0s);
  will-change:opacity,transform;
}
[data-reveal="left"]{transform:translateX(-44px)}
[data-reveal="right"]{transform:translateX(44px)}
[data-reveal="zoom"]{transform:scale(.94)}
[data-reveal].revealed{opacity:1;transform:none}
[data-reveal-group] > *{
  opacity:0;transform:translateY(30px);
  transition:opacity .85s var(--ease),transform .85s var(--ease);
}
[data-reveal-group].revealed > *{opacity:1;transform:none}
[data-reveal-group].revealed > *:nth-child(1){transition-delay:.05s}
[data-reveal-group].revealed > *:nth-child(2){transition-delay:.15s}
[data-reveal-group].revealed > *:nth-child(3){transition-delay:.25s}
[data-reveal-group].revealed > *:nth-child(4){transition-delay:.35s}
[data-reveal-group].revealed > *:nth-child(5){transition-delay:.45s}
[data-reveal-group].revealed > *:nth-child(6){transition-delay:.55s}
[data-reveal-group].revealed > *:nth-child(7){transition-delay:.65s}
[data-reveal-group].revealed > *:nth-child(8){transition-delay:.75s}

/* ---------- Manifesto ---------- */
.manifesto{position:relative}
.manifesto .display-l{max-width:18em}
.manifesto-fig{
  position:absolute;right:4%;top:-14%;width:clamp(180px,20vw,300px);
  aspect-ratio:3/4;z-index:-1;opacity:.85;
}
.manifesto-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1.5rem,3vw,3rem);margin-top:clamp(2.5rem,5vw,4.5rem)}
.manifesto-grid .lead{grid-column:6/11}

/* ---------- Editorial work grid (index) ---------- */
.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1.2rem,2.4vw,2.4rem);align-items:start}
.work-a{grid-column:1/8}
.work-a .img-frame{aspect-ratio:4/3}
.work-b{grid-column:8/13;margin-top:clamp(4rem,9vw,9rem)}
.work-b .img-frame{aspect-ratio:3/4}
.work-c{grid-column:3/9;margin-top:clamp(-3rem,-2vw,-1rem)}
.work-c .img-frame{aspect-ratio:16/10}
.work-side-note{
  grid-column:9/13;align-self:end;padding-bottom:1rem;
}
.work-item{position:relative;display:block}
.work-item .work-meta{
  display:flex;justify-content:space-between;align-items:baseline;gap:1rem;
  padding-top:1.1rem;
}
.work-item .work-meta h3{
  font-family:var(--font-d);font-weight:520;font-size:1.35rem;letter-spacing:.01em;
}
.work-item .work-meta span{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}
.work-item .work-index{
  position:absolute;top:-1.2em;left:-.35em;z-index:3;
  font-family:var(--font-d);font-style:italic;font-weight:400;
  font-size:clamp(3.4rem,6vw,5.4rem);line-height:1;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;
  pointer-events:none;
}

/* ---------- Horizontal gallery ---------- */
.h-gallery{
  display:flex;gap:clamp(1rem,2vw,1.8rem);
  overflow-x:auto;
  padding:0 4vw 1.6rem;
  scroll-snap-type:x proximity;
  cursor:grab;
  scrollbar-width:none;
}
.h-gallery::-webkit-scrollbar{display:none}
.h-gallery.dragging{cursor:grabbing;scroll-snap-type:none}
.h-gallery .h-cell{
  flex:none;scroll-snap-align:center;
  width:clamp(260px,32vw,520px);
}
.h-gallery .h-cell:nth-child(even){margin-top:clamp(1.5rem,3vw,3.5rem)}
.h-gallery .h-cell .img-frame{aspect-ratio:4/5}
.h-gallery .h-cell:nth-child(3n) .img-frame{aspect-ratio:1/1}
.h-cell figcaption{
  display:flex;justify-content:space-between;gap:1rem;
  padding-top:.8rem;
  font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);
}
.h-gallery-head{
  display:flex;justify-content:space-between;align-items:end;gap:2rem;flex-wrap:wrap;
  margin-bottom:clamp(2rem,4vw,3.4rem);
}
.drag-hint{display:inline-flex;align-items:center;gap:12px;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted)}
.drag-hint svg{animation:nudge 2.4s var(--ease) infinite}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(10px)}}

/* ---------- Service index list (hover image reveal) ---------- */
.svc-list{border-top:1px solid var(--line)}
.svc-row{
  display:grid;grid-template-columns:auto 1fr auto auto;gap:clamp(1rem,3vw,3.5rem);
  align-items:center;
  padding:clamp(1.6rem,3vw,2.6rem) .5rem;
  border-bottom:1px solid var(--line);
  position:relative;
  transition:padding-left .5s var(--ease),background .5s;
}
.svc-row:hover{padding-left:clamp(1rem,2vw,2rem);background:rgba(214,179,106,.03)}
.svc-row .svc-no{
  font-family:var(--font-d);font-style:italic;font-size:1rem;color:var(--gold-1);
  width:3ch;
}
.svc-row h3{
  font-family:var(--font-d);font-weight:520;
  font-size:clamp(1.7rem,4.2vw,3.4rem);line-height:1.05;letter-spacing:-.01em;
  transition:color .4s;
}
.svc-row:hover h3{
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.svc-row .svc-tag{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);text-align:right}
.svc-row .svc-arrow{
  width:52px;height:52px;border:1px solid var(--line);border-radius:50%;
  display:grid;place-items:center;flex:none;
  transition:background .45s,border-color .45s,transform .45s var(--ease);
}
.svc-row .svc-arrow svg{transition:transform .45s var(--ease)}
.svc-row:hover .svc-arrow{background:var(--grad-gold);border-color:transparent;transform:rotate(-45deg)}
.svc-row:hover .svc-arrow svg{stroke:var(--ink)}
.hover-float{
  position:fixed;z-index:900;pointer-events:none;
  width:300px;aspect-ratio:4/5;
  opacity:0;transform:scale(.86) rotate(2deg);
  transition:opacity .35s var(--ease),transform .45s var(--ease);
  overflow:hidden;
}
.hover-float img{width:100%;height:100%;object-fit:cover;filter:saturate(.9)}
.hover-float.on{opacity:1;transform:scale(1) rotate(0)}

/* ---------- Stats ---------- */
.stats-band{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:var(--ink-2);
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{
  padding:clamp(2.4rem,4vw,4rem) clamp(1.2rem,2.4vw,2.6rem);
  border-left:1px solid var(--line-soft);
}
.stat:first-child{border-left:0}
.stat-num{
  font-family:var(--font-d);font-weight:500;
  font-size:clamp(2.8rem,5.4vw,4.8rem);line-height:1;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;
  display:flex;align-items:baseline;gap:.06em;
}
.stat-num sup{font-size:.45em;font-style:italic}
.stat-label{margin-top:.9rem;font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}

/* ---------- Process steps ---------- */
.steps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1.4rem,2.6vw,2.6rem)}
.step{
  border-top:1px solid var(--line);
  padding-top:1.6rem;position:relative;
}
.step::before{
  content:"";position:absolute;top:-1px;left:0;height:1px;width:0;
  background:var(--grad-gold);transition:width .8s var(--ease);
}
.step:hover::before{width:100%}
.step .step-no{
  font-family:var(--font-d);font-style:italic;font-weight:400;
  font-size:2.2rem;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.step h3{font-family:var(--font-d);font-weight:540;font-size:1.3rem;margin:1rem 0 .7rem}
.step p{font-size:.95rem;color:var(--muted);line-height:1.7}

/* ---------- Quote / testimonial ---------- */
.pull-quote{
  font-family:var(--font-d);font-weight:460;
  font-size:clamp(1.7rem,3.6vw,3rem);line-height:1.3;letter-spacing:-.01em;
  max-width:24em;
}
.pull-quote em{font-style:italic;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent}
.quote-attr{
  margin-top:2.2rem;display:flex;align-items:center;gap:1.2rem;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
}
.quote-attr::before{content:"";width:48px;height:1px;background:var(--grad-gold)}
.quote-mark{
  font-family:var(--font-d);font-size:7rem;line-height:.6;font-style:italic;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;
  display:block;margin-bottom:1.6rem;
}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;text-align:center}
.cta-band .cta-media{position:absolute;inset:0;z-index:-2}
.cta-band .cta-media img{width:100%;height:118%;object-fit:cover;filter:saturate(.8) brightness(.42)}
.cta-band::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(90% 90% at 50% 50%,rgba(12,10,7,.25),rgba(12,10,7,.85));
}
.cta-band-inner{padding:clamp(6rem,13vw,11rem) 0;display:flex;flex-direction:column;align-items:center;gap:2.4rem}
.cta-band .display-l{max-width:13em}
.response-promise{
  display:inline-flex;align-items:center;gap:12px;
  font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--bone-2);
}
.response-promise .dot{
  width:8px;height:8px;border-radius:50%;background:var(--gold-2);
  box-shadow:0 0 0 0 rgba(214,179,106,.5);animation:pulse 2.2s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(214,179,106,.45)}
  70%{box-shadow:0 0 0 12px rgba(214,179,106,0)}
  100%{box-shadow:0 0 0 0 rgba(214,179,106,0)}
}

/* ---------- Footer ---------- */
.site-foot{border-top:1px solid var(--line);background:var(--ink-2);position:relative;overflow:hidden}
.foot-cta{
  padding:clamp(4rem,8vw,7rem) 0 clamp(3rem,6vw,5rem);
  display:flex;flex-wrap:wrap;align-items:end;justify-content:space-between;gap:2.5rem;
}
.foot-cta .display-l{max-width:11em}
.foot-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:clamp(2rem,4vw,4rem);
  padding:clamp(2.5rem,5vw,4rem) 0;
  border-top:1px solid var(--line-soft);
}
.foot-col h4{
  font-size:.7rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold-2);margin-bottom:1.3rem;
}
.foot-col ul{display:flex;flex-direction:column;gap:.65rem}
.foot-col a{color:var(--bone-2);font-size:.92rem;transition:color .3s;position:relative}
.foot-col a:hover{color:var(--gold-2)}
.foot-brand p{color:var(--muted);font-size:.92rem;max-width:30em;margin-top:1.4rem}
.foot-brand svg{height:52px;width:auto}
.foot-contact li{color:var(--bone-2);font-size:.92rem;line-height:1.8}
.foot-contact strong{color:var(--bone);font-weight:600}
.foot-bottom{
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;
  padding:1.6rem 0 2rem;
  border-top:1px solid var(--line-soft);
  font-size:.74rem;letter-spacing:.06em;color:var(--muted);
}
.foot-bottom a{color:var(--gold-2)}
.foot-watermark{
  position:absolute;left:50%;bottom:-.22em;translate:-50% 0;
  font-family:var(--font-d);font-weight:600;font-size:clamp(6rem,18vw,17rem);
  line-height:1;letter-spacing:.02em;white-space:nowrap;
  color:transparent;-webkit-text-stroke:1px rgba(237,230,216,.05);
  pointer-events:none;user-select:none;
}

/* ---------- Forms ---------- */
.form-shell{display:grid;grid-template-columns:7fr 5fr;gap:clamp(2.5rem,5vw,5rem);align-items:start}
.inquiry-form{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem 1.8rem}
.field{display:flex;flex-direction:column;gap:.55rem}
.field.full{grid-column:1/-1}
.field label{
  font-size:.7rem;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--bone-2);
}
.field label .req{color:var(--gold-2)}
.field label .opt{color:var(--muted);font-weight:500;letter-spacing:.12em;text-transform:none}
.field input,.field select,.field textarea{
  background:transparent;
  border:0;border-bottom:1px solid var(--line);
  padding:.85rem .2rem;
  color:var(--bone);font:inherit;font-size:1rem;
  transition:border-color .35s;
  border-radius:0;
  appearance:none;-webkit-appearance:none;
}
.field select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23d6b36a' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .4rem center;
  padding-right:2rem;cursor:pointer;
}
.field select option{background:var(--ink-2);color:var(--bone)}
.field textarea{resize:vertical;min-height:140px;line-height:1.7}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-bottom-color:var(--gold-2);
}
.field input::placeholder,.field textarea::placeholder{color:#5f5749}
.field.invalid input{border-bottom-color:#b3543e}
.field .err{display:none;font-size:.74rem;color:#cf7d5f;letter-spacing:.04em}
.field.invalid .err{display:block}
.form-actions{grid-column:1/-1;display:flex;align-items:center;gap:1.8rem;flex-wrap:wrap;margin-top:.6rem}
.form-note{font-size:.8rem;color:var(--muted);max-width:26em}
.form-status{grid-column:1/-1;font-size:.9rem;color:var(--gold-2);display:none}
.form-status.show{display:block}
.aside-panel{
  border:1px solid var(--line);padding:clamp(1.8rem,3vw,2.8rem);
  background:var(--ink-2);position:sticky;top:calc(var(--head-h) + 2rem);
}
.aside-panel .hairline-gold{margin:1.6rem 0}
.aside-steps{display:flex;flex-direction:column;gap:1.4rem;counter-reset:astep}
.aside-steps li{display:flex;gap:1.1rem;align-items:flex-start;counter-increment:astep}
.aside-steps li::before{
  content:"0" counter(astep);
  font-family:var(--font-d);font-style:italic;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;color:transparent;
  font-size:1.2rem;flex:none;line-height:1.4;
}
.aside-steps p{font-size:.92rem;color:var(--bone-2);line-height:1.65}
.aside-steps strong{display:block;color:var(--bone);font-family:var(--font-d);font-weight:540;font-size:1.05rem;letter-spacing:.01em}

/* ---------- Portfolio grid ---------- */
.pf-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1.2rem,2.4vw,2.6rem)}
.pf-item{position:relative}
.pf-item .img-frame{width:100%}
.pf-item.span-7{grid-column:span 7}
.pf-item.span-5{grid-column:span 5}
.pf-item.span-6{grid-column:span 6}
.pf-item.span-4{grid-column:span 4}
.pf-item.span-8{grid-column:span 8}
.pf-item.offset-down{margin-top:clamp(2.5rem,6vw,6rem)}
.pf-item.offset-up{margin-top:clamp(-4rem,-3vw,-1.5rem)}
.pf-item .img-frame.r-43{aspect-ratio:4/3}
.pf-item .img-frame.r-34{aspect-ratio:3/4}
.pf-item .img-frame.r-11{aspect-ratio:1/1}
.pf-item .img-frame.r-169{aspect-ratio:16/9}
.pf-meta{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;padding-top:1rem}
.pf-meta h3{font-family:var(--font-d);font-weight:530;font-size:1.3rem}
.pf-meta .pf-tags{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);text-align:right}

/* ---------- Service page bits ---------- */
.spec-rows{border-top:1px solid var(--line)}
.spec-row{
  display:grid;grid-template-columns:1fr 2fr;gap:clamp(1rem,4vw,4rem);
  padding:clamp(1.4rem,2.6vw,2.2rem) 0;border-bottom:1px solid var(--line);
}
.spec-row h3{font-family:var(--font-d);font-weight:540;font-size:1.25rem;display:flex;gap:1rem;align-items:baseline}
.spec-row h3 i{font-style:italic;font-weight:400;font-size:.85rem;color:var(--gold-1)}
.spec-row p{color:var(--bone-2);max-width:42em}
.two-col-copy{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1.5rem,3vw,3rem)}
.two-col-copy .col-a{grid-column:1/6}
.two-col-copy .col-b{grid-column:7/12}
.editorial-pair{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(1.2rem,2.4vw,2.4rem);align-items:center}
.editorial-pair .ep-big{grid-column:1/8}
.editorial-pair .ep-big .img-frame{aspect-ratio:4/3}
.editorial-pair .ep-small{grid-column:9/13;margin-top:clamp(3rem,8vw,8rem)}
.editorial-pair .ep-small .img-frame{aspect-ratio:3/4}
.editorial-pair.flip .ep-big{grid-column:6/13;order:2}
.editorial-pair.flip .ep-small{grid-column:1/5;order:1;margin-top:clamp(-6rem,-4vw,-2rem)}

/* ---------- Team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,3vw,3rem)}
.team-card .img-frame{aspect-ratio:3/4}
.team-card h3{font-family:var(--font-d);font-weight:540;font-size:1.4rem;margin-top:1.2rem}
.team-card .role{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold-2);margin:.4rem 0 .8rem}
.team-card p{font-size:.92rem;color:var(--muted)}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:5fr 7fr;gap:clamp(2.5rem,5vw,5rem)}
.contact-list{display:flex;flex-direction:column}
.contact-list .c-row{
  display:flex;justify-content:space-between;align-items:baseline;gap:2rem;
  padding:1.5rem 0;border-bottom:1px solid var(--line);
}
.contact-list .c-row span{font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);flex:none}
.contact-list .c-row a,.contact-list .c-row p{
  font-family:var(--font-d);font-size:clamp(1.1rem,2vw,1.5rem);font-weight:480;
  text-align:right;transition:color .3s;
}
.contact-list .c-row a:hover{color:var(--gold-2)}

/* ---------- Thank you ---------- */
.ty-wrap{
  min-height:100svh;display:flex;flex-direction:column;justify-content:center;
  padding:calc(var(--head-h) + 3rem) 0 4rem;position:relative;overflow:hidden;
}
.ty-mark{
  width:84px;height:84px;border-radius:50%;
  border:1px solid rgba(214,179,106,.5);
  display:grid;place-items:center;margin-bottom:2.4rem;
  position:relative;
}
.ty-mark::before{
  content:"";position:absolute;inset:-10px;border-radius:50%;
  border:1px solid rgba(214,179,106,.18);
  animation:pulse 2.6s infinite;
}

/* ---------- Utility ---------- */
.center{text-align:center}
.center .eyebrow{justify-content:center}
.mt-1{margin-top:1rem}.mt-2{margin-top:2rem}.mt-3{margin-top:3rem}
.mt-4{margin-top:clamp(2.5rem,5vw,4.5rem)}
.mb-2{margin-bottom:2rem}
.mb-4{margin-bottom:clamp(2.5rem,5vw,4.5rem)}
.flex-between{display:flex;justify-content:space-between;align-items:end;gap:2rem;flex-wrap:wrap}
.bg-2{background:var(--ink-2)}
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:2000;
  background:var(--gold-2);color:var(--ink);padding:1rem 2rem;font-weight:700;
}
.skip-link:focus{left:0}

/* ---------- Responsive ---------- */
@media (max-width:1180px){
  .head-nav{display:none}
  .menu-btn{display:flex}
  .head-cta{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(odd){border-left:0}
  .stat{border-top:1px solid var(--line-soft)}
  .steps-grid{grid-template-columns:repeat(2,1fr)}
  .page-hero-copy{grid-column:1/13}
  .page-hero-fig{grid-column:1/13;margin-top:2rem}
  .page-hero-fig .img-frame{aspect-ratio:16/9}
}
@media (max-width:900px){
  :root{--head-h:72px}
  .brand svg{height:38px}
  .work-a,.work-b,.work-c{grid-column:1/13;margin-top:0}
  .work-b{margin-top:1.5rem}
  .work-c{margin-top:1.5rem}
  .work-side-note{grid-column:1/13;padding:2rem 0 0}
  .manifesto-grid .lead{grid-column:1/13}
  .manifesto-fig{display:none}
  .form-shell{grid-template-columns:1fr}
  .aside-panel{position:static}
  .contact-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr}
  .two-col-copy .col-a,.two-col-copy .col-b{grid-column:1/13}
  .editorial-pair .ep-big,.editorial-pair.flip .ep-big{grid-column:1/13;order:0}
  .editorial-pair .ep-small,.editorial-pair.flip .ep-small{grid-column:2/12;order:0;margin-top:1.5rem}
  .pf-item.span-7,.pf-item.span-5,.pf-item.span-6,.pf-item.span-4,.pf-item.span-8{grid-column:1/13}
  .pf-item.offset-down,.pf-item.offset-up{margin-top:0}
  .pf-grid{gap:2.2rem}
  .svc-row{grid-template-columns:auto 1fr auto;gap:1rem}
  .svc-row .svc-tag{display:none}
  .spec-row{grid-template-columns:1fr}
  .hover-float{display:none}
  .scroll-cue{display:none}
  .inquiry-form{grid-template-columns:1fr}
  .field{grid-column:1/-1}
}
@media (max-width:560px){
  .steps-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .foot-grid{grid-template-columns:1fr}
  .hero-meta{flex-direction:column;align-items:flex-start;gap:.5rem}
}
