/* =========================================================================
   STUDIO HIGH DESIGN — Core stylesheet
   Theme: quiet-luxury black & gold. Editorial serif + humanist grotesque.
   Brand gold sampled from logo: #BE9D63
   ========================================================================= */

:root{
  /* Ink / surfaces */
  --ink:        #0A0A0B;
  --ink-2:      #0D0D0F;
  --ink-3:      #131318;
  --ink-card:   #111016;
  --line:       rgba(190,157,99,.16);
  --line-soft:  rgba(243,238,227,.08);

  /* Gold */
  --gold:       #BE9D63;
  --gold-2:     #E8CD8E;   /* champagne highlight */
  --gold-3:     #9A7C42;   /* deep gold */
  --gold-grad:  linear-gradient(160deg, var(--gold-2) 0%, var(--gold) 46%, var(--gold-3) 100%);
  --gold-text:  linear-gradient(180deg, #F1DCAC 0%, var(--gold) 55%, var(--gold-3) 100%);
  --gold-glow:  rgba(190,157,99,.28);

  /* Type */
  --cream:      #F4EFE4;
  --muted:      #9D988C;
  --muted-2:    #6C685F;

  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-sans:    "Hanken Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;

  --wrap: 1320px;
  --gutter: clamp(1.25rem, 5vw, 4.5rem);

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-soft: cubic-bezier(.4,0,.2,1);
  --radius: 2px;

  --nav-h: 86px;
}

/* ----------------------------------------------------------------- reset */
*,*::before,*::after{ box-sizing:border-box; }
*{ margin:0; padding:0; }
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
}
html.lenis,html.lenis body{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-smooth [data-lenis-prevent]{ overscroll-behavior:contain; }
.lenis.lenis-stopped{ overflow:hidden; }

body{
  background:var(--ink);
  color:var(--cream);
  font-family:var(--font-sans);
  font-weight:400;
  font-size:clamp(1rem, .96rem + .2vw, 1.12rem);
  line-height:1.62;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,svg,video{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
ul{ list-style:none; }
::selection{ background:var(--gold); color:#1a1408; }

/* hide native cursor when custom cursor active (desktop only, set by JS) */
body.has-cursor, body.has-cursor a, body.has-cursor button{ cursor:none; }

/* ----------------------------------------------------------- typography */
h1,h2,h3,h4{
  font-family:var(--font-display);
  font-weight:430;
  font-optical-sizing:auto;
  line-height:1.02;
  letter-spacing:-.018em;
  color:var(--cream);
}
.display{
  font-size:clamp(2.9rem, 1.6rem + 6.4vw, 8.4rem);
  line-height:.94;
  letter-spacing:-.03em;
  font-weight:380;
}
h2,.h2{ font-size:clamp(2rem, 1.2rem + 3.4vw, 4.4rem); }
h3,.h3{ font-size:clamp(1.35rem, 1.05rem + 1.2vw, 2.05rem); font-weight:460; }
.lead{
  font-size:clamp(1.1rem, 1rem + .55vw, 1.5rem);
  line-height:1.5;
  color:#E4DECF;
  font-weight:380;
}
em,.it{ font-style:italic; }
.serif{ font-family:var(--font-display); }
.gold{ color:var(--gold); }
.gold-grad-text{
  background:var(--gold-text);
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
}
strong{ font-weight:600; color:var(--cream); }

.eyebrow{
  display:inline-flex; align-items:center; gap:.7rem;
  font-family:var(--font-sans);
  font-size:.72rem; font-weight:600;
  text-transform:uppercase; letter-spacing:.26em;
  color:var(--gold);
}
.eyebrow::before{
  content:""; width:30px; height:1px;
  background:var(--gold-grad); opacity:.85;
}
.eyebrow.center::after{
  content:""; width:30px; height:1px; background:var(--gold-grad); opacity:.85;
}
.muted{ color:var(--muted); }

/* --------------------------------------------------------------- layout */
.wrap{ width:100%; max-width:var(--wrap); margin-inline:auto; padding-inline:var(--gutter); }
.wrap-wide{ max-width:1560px; }
.section{ position:relative; padding-block:clamp(4.5rem, 3rem + 7vw, 9rem); }
.section--tight{ padding-block:clamp(3rem,2rem+4vw,5.5rem); }
.section--flush-top{ padding-top:0; }
.rule{ height:1px; background:var(--line); border:0; }
.rule-soft{ height:1px; background:var(--line-soft); border:0; }

.section-head{ max-width:760px; }
.section-head.center{ margin-inline:auto; text-align:center; }
.section-head .eyebrow{ margin-bottom:1.4rem; }
.section-head p{ color:var(--muted); margin-top:1.2rem; max-width:58ch; }
.section-head.center p{ margin-inline:auto; }

.grid{ display:grid; gap:clamp(1.5rem,3vw,2.5rem); }
.cols-2{ grid-template-columns:repeat(2,1fr); }
.cols-3{ grid-template-columns:repeat(3,1fr); }
.cols-4{ grid-template-columns:repeat(4,1fr); }

/* index marker */
.idx{
  font-family:var(--font-display); font-style:italic;
  color:var(--gold-3); font-size:1rem; letter-spacing:0;
}

/* ----------------------------------------------------- atmosphere/grain */
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none;
  opacity:.05; mix-blend-mode:screen;
  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.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.orb{
  position:absolute; border-radius:50%; pointer-events:none; z-index:0;
  background:radial-gradient(circle at 50% 40%, var(--gold-glow), transparent 65%);
  filter:blur(40px); opacity:.6;
}

/* --------------------------------------------------------------- header */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:120;
  height:var(--nav-h);
  display:flex; align-items:center;
  transition:background .5s var(--ease), backdrop-filter .5s var(--ease), border-color .5s, height .4s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(10,10,11,.72);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom-color:var(--line);
  height:70px;
}
.nav{ width:100%; max-width:1560px; margin-inline:auto; padding-inline:var(--gutter);
  display:flex; align-items:center; justify-content:space-between; gap:2rem; }
.brand{ display:flex; align-items:center; gap:.7rem; z-index:130; }
.brand img{ height:34px; width:auto; transition:transform .5s var(--ease); }
.brand:hover img{ transform:translateY(-1px) scale(1.03); }
.brand .brand-word{
  font-family:var(--font-display); font-size:.95rem; letter-spacing:.32em;
  text-transform:uppercase; color:var(--cream); padding-top:3px;
}
.nav-links{ display:flex; align-items:center; gap:2.4rem; }
.nav-links a{
  position:relative; font-size:.84rem; font-weight:500;
  letter-spacing:.04em; color:#D9D3C6; padding:.4rem 0;
  transition:color .35s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1px; width:100%;
  background:var(--gold-grad); transform:scaleX(0); transform-origin:right;
  transition:transform .45s var(--ease);
}
.nav-links a:hover,.nav-links a[aria-current="page"]{ color:var(--cream); }
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{ transform:scaleX(1); transform-origin:left; }

.nav-cta{ display:flex; align-items:center; gap:1.3rem; }

/* buttons */
.btn{
  --bg:var(--gold-grad);
  position:relative; display:inline-flex; align-items:center; gap:.7rem;
  font-family:var(--font-sans); font-size:.82rem; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase;
  padding:1rem 1.7rem; border-radius:999px; overflow:hidden;
  color:#160F03; background:var(--gold-grad);
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), color .4s;
  will-change:transform;
}
.btn span{ position:relative; z-index:2; }
.btn .arr{ transition:transform .5s var(--ease); }
.btn:hover{ box-shadow:0 12px 40px -10px var(--gold-glow); transform:translateY(-2px); }
.btn:hover .arr{ transform:translate(4px,-1px); }
.btn::after{
  content:""; position:absolute; inset:0; z-index:1;
  background:linear-gradient(160deg,#F6E6BC,#D9B873); opacity:0;
  transition:opacity .5s var(--ease);
}
.btn:hover::after{ opacity:1; }

.btn-ghost{
  background:transparent; color:var(--cream);
  border:1px solid var(--line); border-radius:999px;
  padding:.95rem 1.6rem; font-size:.82rem; font-weight:600;
  letter-spacing:.06em; text-transform:uppercase;
  display:inline-flex; align-items:center; gap:.7rem;
  transition:border-color .4s, background .4s, transform .5s var(--ease), color .4s;
}
.btn-ghost::after{ display:none; }
.btn-ghost:hover{ border-color:var(--gold); background:rgba(190,157,99,.06); transform:translateY(-2px); }
.btn-ghost:hover .arr{ transform:translate(4px,-1px); }
.btn-ghost .arr{ transition:transform .5s var(--ease); }

.link-underline{
  position:relative; display:inline-flex; align-items:center; gap:.55rem;
  font-weight:600; font-size:.85rem; letter-spacing:.05em;
  text-transform:uppercase; color:var(--gold);
}
.link-underline::after{
  content:""; position:absolute; left:0; bottom:-3px; height:1px; width:100%;
  background:var(--gold-grad); transform:scaleX(0); transform-origin:right;
  transition:transform .45s var(--ease);
}
.link-underline:hover::after{ transform:scaleX(1); transform-origin:left; }
.link-underline:hover .arr{ transform:translate(4px,-1px); }
.link-underline .arr{ transition:transform .45s var(--ease); }

/* burger */
.burger{ display:none; width:42px; height:42px; position:relative; z-index:130; }
.burger span{
  position:absolute; left:9px; right:9px; height:1.5px; background:var(--cream);
  transition:transform .45s var(--ease), opacity .3s;
}
.burger span:nth-child(1){ top:16px; }
.burger span:nth-child(2){ bottom:16px; }
body.menu-open .burger span:nth-child(1){ transform:translateY(5px) rotate(45deg); }
body.menu-open .burger span:nth-child(2){ transform:translateY(-5px) rotate(-45deg); }

/* mobile menu overlay */
.mobile-menu{
  position:fixed; inset:0; z-index:115;
  background:var(--ink-2);
  display:flex; flex-direction:column; justify-content:center;
  padding:var(--gutter);
  clip-path:inset(0 0 100% 0);
  transition:clip-path .8s var(--ease);
  pointer-events:none;
}
body.menu-open .mobile-menu{ clip-path:inset(0 0 0% 0); pointer-events:auto; }
.mobile-menu .mm-links{ display:flex; flex-direction:column; gap:.4rem; }
.mobile-menu .mm-links a{
  font-family:var(--font-display); font-size:clamp(2.4rem,11vw,4rem);
  line-height:1.08; color:var(--cream); font-weight:380;
  display:flex; align-items:baseline; gap:1rem;
  opacity:0; transform:translateY(120%);
}
.mobile-menu .mm-links a .mm-i{ font-size:.9rem; color:var(--gold-3); font-style:italic; }
.mobile-menu .mm-links a:active{ color:var(--gold); }
.mobile-menu .mm-foot{ margin-top:auto; padding-top:2.5rem; border-top:1px solid var(--line);
  display:flex; flex-wrap:wrap; gap:.4rem 2rem; color:var(--muted); font-size:.95rem; }
.mobile-menu .mm-foot a{ color:var(--cream); }

/* ------------------------------------------------------------ preloader */
.preloader{
  position:fixed; inset:0; z-index:300; background:var(--ink);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:1.6rem;
  animation:pl-failsafe .6s ease 3.4s forwards; /* backstop if JS fails */
}
.preloader.done{ pointer-events:none; }
.pl-logo{ width:78px; opacity:0; animation:pl-logo-in 1s var(--ease) .1s forwards; }
.pl-bar{ width:min(220px,46vw); height:1px; background:var(--line); overflow:hidden; position:relative; }
.pl-bar i{ position:absolute; inset:0; transform-origin:left; transform:scaleX(0);
  background:var(--gold-grad); animation:pl-bar .9s var(--ease) .25s forwards; }
.pl-count{ font-family:var(--font-display); font-style:italic; color:var(--muted); font-size:.95rem; letter-spacing:.02em; }
@keyframes pl-logo-in{ to{ opacity:1; transform:translateY(0);} }
@keyframes pl-bar{ to{ transform:scaleX(1);} }
@keyframes pl-failsafe{ to{ opacity:0; visibility:hidden;} }

/* --------------------------------------------------------- page curtain */
.curtain{
  position:fixed; inset:0; z-index:280; background:var(--ink-2);
  transform:translateY(100%); pointer-events:none;
  display:flex; align-items:center; justify-content:center;
  border-top:1px solid var(--gold);
}
.curtain img{ width:60px; opacity:0; }

/* ------------------------------------------------------- custom cursor */
.cursor{ position:fixed; top:0; left:0; z-index:400; pointer-events:none;
  transform:translate(-50%,-50%); will-change:transform; display:none; }
.cursor-dot{ width:6px; height:6px; border-radius:50%; background:var(--gold); }
.cursor-ring{ position:fixed; top:0; left:0; z-index:399; pointer-events:none;
  width:40px; height:40px; border:1px solid var(--gold); border-radius:50%;
  transform:translate(-50%,-50%); will-change:transform;
  transition:width .3s var(--ease), height .3s var(--ease), background .3s, opacity .3s, border-color .3s;
  display:none; }
.cursor-ring.hover{ width:64px; height:64px; background:rgba(190,157,99,.10); }
.cursor-ring.view{ width:88px; height:88px; background:var(--gold); border-color:var(--gold); }
.cursor-ring .cr-label{ font-size:.62rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase;
  color:#160F03; opacity:0; transition:opacity .25s; display:flex; align-items:center; justify-content:center;
  width:100%; height:100%; }
.cursor-ring.view .cr-label{ opacity:1; }

/* ----------------------------------------------------------------- hero */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end;
  padding-top:var(--nav-h); padding-bottom:clamp(2.5rem,5vw,4.5rem); overflow:hidden; }
.hero .orb-1{ width:680px; height:680px; top:-160px; right:-120px; opacity:.5; }
.hero-inner{ position:relative; z-index:3; width:100%; }
.hero-top{ display:flex; justify-content:space-between; align-items:flex-end; flex-wrap:wrap; gap:1.5rem;
  margin-bottom:clamp(1.4rem,3vw,2.4rem); }
.hero-eyebrow-line{ display:flex; align-items:center; gap:.9rem; color:var(--muted); font-size:.78rem;
  letter-spacing:.16em; text-transform:uppercase; }
.hero-eyebrow-line .dot{ width:5px; height:5px; border-radius:50%; background:var(--gold); }
.hero h1{ margin-bottom:clamp(1.6rem,3vw,2.4rem); }
.hero h1 .line{ display:block; overflow:hidden; }
.hero h1 .line > span{ display:block; }
.hero-sub{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(1.5rem,4vw,4rem); align-items:end; }
.hero-sub .lead{ max-width:46ch; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:1rem; align-items:center; }
.scroll-cue{ display:flex; align-items:center; gap:.7rem; color:var(--muted-2); font-size:.72rem;
  letter-spacing:.2em; text-transform:uppercase; margin-top:2.6rem; }
.scroll-cue .sc-line{ width:1px; height:46px; background:linear-gradient(var(--gold),transparent); position:relative; overflow:hidden; }
.scroll-cue .sc-line::after{ content:""; position:absolute; left:0; top:0; width:100%; height:40%;
  background:var(--gold); animation:scrolldrop 1.8s var(--ease) infinite; }
@keyframes scrolldrop{ 0%{ transform:translateY(-100%);} 60%,100%{ transform:translateY(260%);} }

/* word/line reveal helpers (states applied by JS only) */
.reveal-line{ display:block; overflow:hidden; }
.word{ display:inline-block; }
.char{ display:inline-block; }

/* ------------------------------------------------------------- marquee */
.marquee{ position:relative; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  padding-block:1.4rem; overflow:hidden; background:var(--ink-2); }
.marquee-track{ display:flex; gap:0; width:max-content; will-change:transform; }
.marquee-track .mi{ display:inline-flex; align-items:center; font-family:var(--font-display);
  font-size:clamp(1.2rem,2.6vw,2.1rem); color:var(--cream); font-weight:380; white-space:nowrap; padding-inline:1.6rem; }
.marquee-track .mi.alt{ color:transparent; -webkit-text-stroke:1px var(--gold-3); }
.marquee-track .sep{ color:var(--gold); padding-inline:1.6rem; font-size:1rem; align-self:center; }

/* ----------------------------------------------------------- statement */
.statement{ }
.statement .big{
  font-family:var(--font-display); font-weight:360;
  font-size:clamp(1.7rem, 1.1rem + 3vw, 3.7rem); line-height:1.16; letter-spacing:-.02em;
  max-width:20ch;
}
.statement .big .dim{ color:var(--muted-2); }
.statement-grid{ display:grid; grid-template-columns:1fr; gap:clamp(2rem,5vw,4rem); }
.statement-aside{ display:flex; flex-direction:column; gap:1.3rem; align-self:end; max-width:42ch; }
.statement-aside p{ color:var(--muted); }

/* ------------------------------------------------------------ services */
.svc-list{ border-top:1px solid var(--line); }
.svc{ display:grid; grid-template-columns:auto 1fr auto; gap:clamp(1rem,4vw,3rem);
  align-items:center; padding-block:clamp(1.8rem,3vw,2.8rem); border-bottom:1px solid var(--line);
  position:relative; transition:padding-left .5s var(--ease); }
.svc .svc-i{ font-family:var(--font-display); font-style:italic; color:var(--gold-3); font-size:1.05rem; min-width:2.4rem; }
.svc .svc-main h3{ transition:color .4s; }
.svc .svc-main p{ color:var(--muted); margin-top:.6rem; max-width:54ch; }
.svc .svc-tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1rem; }
.svc .tag{ font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted-2);
  border:1px solid var(--line); border-radius:999px; padding:.32rem .8rem; }
.svc .svc-go{ width:54px; height:54px; border:1px solid var(--line); border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:var(--gold);
  transition:background .4s, transform .5s var(--ease), border-color .4s; flex-shrink:0; }
.svc::before{ content:""; position:absolute; left:0; top:0; bottom:0; width:0;
  background:linear-gradient(90deg, rgba(190,157,99,.06), transparent); transition:width .5s var(--ease); }
.svc:hover::before{ width:100%; }
.svc:hover{ padding-left:1.4rem; }
.svc:hover .svc-main h3{ color:var(--gold-2); }
.svc:hover .svc-go{ background:var(--gold-grad); color:#160F03; border-color:transparent; transform:rotate(-45deg); }

/* feature cards (about / why) */
.feature{ background:var(--ink-card); border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(1.6rem,3vw,2.4rem); position:relative; overflow:hidden;
  transition:border-color .5s, transform .6s var(--ease), background .5s; height:100%; }
.feature::after{ content:""; position:absolute; left:0; top:0; width:0; height:1px; background:var(--gold-grad); transition:width .6s var(--ease); }
.feature:hover{ transform:translateY(-5px); border-color:rgba(190,157,99,.34); }
.feature:hover::after{ width:100%; }
.feature .f-i{ font-family:var(--font-display); font-style:italic; color:var(--gold-3); margin-bottom:1.4rem; font-size:1rem; }
.feature h3{ margin-bottom:.7rem; font-size:1.3rem; }
.feature p{ color:var(--muted); font-size:1rem; }

/* --------------------------------------------------------- work showcase */
.showcase{ position:relative; }
.showcase-track{ display:flex; gap:clamp(1.2rem,2.4vw,2.2rem); }
.work-card{ flex:0 0 auto; width:min(78vw,520px); }
.work-card .wc-media{ position:relative; aspect-ratio:4/3; border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--line); background:var(--ink-3); }
.work-card .wc-media .ph{ position:absolute; inset:0; }
.work-card .wc-media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.04);
  transition:transform 1.1s var(--ease); }
.work-card:hover .wc-media img{ transform:scale(1.0); }
.work-card .wc-reveal{ position:absolute; inset:0; background:var(--ink-2); transform-origin:bottom; }
.work-card .wc-meta{ display:flex; justify-content:space-between; align-items:baseline; margin-top:1.1rem; gap:1rem; }
.work-card .wc-meta h3{ font-size:1.4rem; }
.work-card .wc-cat{ font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); }
.work-card .wc-year{ color:var(--muted-2); font-size:.85rem; font-family:var(--font-display); font-style:italic; }
.showcase-hint{ display:flex; align-items:center; gap:.7rem; color:var(--muted-2);
  font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; margin-top:1.6rem; }

/* placeholder media (when no image yet) */
.ph{ background:
    radial-gradient(120% 120% at 20% 0%, rgba(232,205,142,.16), transparent 50%),
    linear-gradient(155deg, #17150F 0%, #100F0C 60%, #0C0B09 100%);
  display:flex; align-items:flex-end; padding:1.4rem; }
.ph .ph-mono{ font-family:var(--font-display); font-style:italic; color:rgba(190,157,99,.5);
  font-size:1.05rem; letter-spacing:.02em; }
.ph::before{ content:""; position:absolute; inset:0;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:42px 42px; opacity:.25; mask:radial-gradient(120% 100% at 50% 0%,#000,transparent 75%); }
.ph .ph-init{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family:var(--font-display); font-size:clamp(2.4rem,6vw,4.5rem); color:rgba(190,157,99,.16); font-weight:400; letter-spacing:.04em; }

/* ------------------------------------------------------------- process */
.process{ }
.step{ display:grid; grid-template-columns:120px 1fr; gap:clamp(1rem,4vw,3rem);
  padding-block:clamp(1.8rem,3vw,2.6rem); border-top:1px solid var(--line); align-items:start; }
.step:last-child{ border-bottom:1px solid var(--line); }
.step .step-n{ font-family:var(--font-display); font-size:clamp(2.4rem,4vw,3.6rem); line-height:1;
  background:var(--gold-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.step h3{ font-size:1.5rem; margin-bottom:.6rem; }
.step p{ color:var(--muted); max-width:60ch; }

/* --------------------------------------------------------------- stats */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1.5rem,3vw,2rem);
  border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding-block:clamp(2.5rem,4vw,4rem); }
.stat{ text-align:center; }
.stat .s-num{ font-family:var(--font-display); font-size:clamp(2.6rem,6vw,5rem); line-height:1; font-weight:380;
  background:var(--gold-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.stat .s-num .suf{ -webkit-text-fill-color:var(--gold); }
.stat .s-label{ margin-top:.8rem; color:var(--muted); font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; }

/* ---------------------------------------------------------- testimonials */
.tcard{ background:var(--ink-card); border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(1.8rem,3vw,2.6rem); height:100%; display:flex; flex-direction:column; gap:1.6rem;
  transition:border-color .5s, transform .6s var(--ease); }
.tcard:hover{ border-color:rgba(190,157,99,.32); transform:translateY(-4px); }
.tcard .quote-mark{ font-family:var(--font-display); font-size:3rem; line-height:.5; color:var(--gold-3); height:1rem; }
.tcard blockquote{ font-family:var(--font-display); font-size:clamp(1.05rem,1.5vw,1.32rem);
  line-height:1.45; color:#E9E3D4; font-weight:380; font-style:italic; }
.tcard .t-by{ margin-top:auto; display:flex; align-items:center; gap:.9rem; }
.tcard .t-dot{ width:36px; height:36px; border-radius:50%; background:var(--gold-grad); flex-shrink:0;
  display:flex; align-items:center; justify-content:center; color:#160F03; font-weight:700; font-size:.85rem; font-family:var(--font-sans); }
.tcard .t-name{ font-weight:600; font-size:.95rem; }
.tcard .t-role{ color:var(--muted-2); font-size:.82rem; }

/* --------------------------------------------------------------- pricing */
.price-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.2rem,2.4vw,1.8rem); align-items:stretch; }
.price{ background:var(--ink-card); border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(1.8rem,3vw,2.4rem); display:flex; flex-direction:column; position:relative; overflow:hidden;
  transition:border-color .5s, transform .6s var(--ease); }
.price:hover{ transform:translateY(-5px); border-color:rgba(190,157,99,.3); }
.price.feat{ border-color:var(--gold); background:linear-gradient(180deg, rgba(190,157,99,.07), var(--ink-card) 40%); }
.price .p-flag{ position:absolute; top:1.2rem; right:1.2rem; font-size:.66rem; letter-spacing:.16em;
  text-transform:uppercase; color:#160F03; background:var(--gold-grad); padding:.32rem .7rem; border-radius:999px; }
.price .p-name{ font-family:var(--font-display); font-size:1.5rem; margin-bottom:.4rem; }
.price .p-for{ color:var(--muted-2); font-size:.85rem; margin-bottom:1.6rem; }
.price .p-amt{ display:flex; align-items:baseline; gap:.4rem; margin-bottom:.4rem; }
.price .p-amt .from{ color:var(--muted); font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; }
.price .p-amt .num{ font-family:var(--font-display); font-size:clamp(2.4rem,4vw,3.2rem); line-height:1;
  background:var(--gold-text); -webkit-background-clip:text; background-clip:text; color:transparent; }
.price .p-note{ color:var(--muted-2); font-size:.82rem; margin-bottom:1.8rem; }
.price ul.p-feats{ display:flex; flex-direction:column; gap:.85rem; margin-bottom:2rem; }
.price ul.p-feats li{ display:flex; gap:.7rem; align-items:flex-start; color:#D9D3C6; font-size:.95rem; }
.price ul.p-feats li::before{ content:""; flex-shrink:0; width:16px; height:16px; margin-top:.22rem;
  background:var(--gold); -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 6 9 17l-5-5' fill='none' stroke='%23000' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M20 6 9 17l-5-5' fill='none' stroke='%23000' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat; }
.price .btn,.price .btn-ghost{ margin-top:auto; justify-content:center; }
.price-foot{ margin-top:2rem; text-align:center; color:var(--muted); }
.price-foot a{ color:var(--gold); }

/* ------------------------------------------------------- work page grid */
.filters{ display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom:clamp(2rem,4vw,3rem); }
.filter{ font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted);
  border:1px solid var(--line); border-radius:999px; padding:.55rem 1.1rem; transition:all .35s; font-weight:600; }
.filter:hover{ color:var(--cream); border-color:var(--gold-3); }
.filter.active{ background:var(--gold-grad); color:#160F03; border-color:transparent; }

.work-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(1.4rem,3vw,2.4rem); }
.pc{ cursor:pointer; }
.pc .pc-media{ position:relative; aspect-ratio:16/11; border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--line); background:var(--ink-3); }
.pc .pc-media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.05); transition:transform 1.2s var(--ease); }
.pc:hover .pc-media img{ transform:scale(1.0); }
.pc .pc-over{ position:absolute; inset:0; background:linear-gradient(to top, rgba(8,8,9,.85), transparent 55%);
  opacity:0; transition:opacity .5s var(--ease); display:flex; align-items:flex-end; padding:1.4rem; }
.pc:hover .pc-over{ opacity:1; }
.pc .pc-over .view-pill{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold);
  border:1px solid var(--gold); border-radius:999px; padding:.5rem 1rem; }
.pc .pc-meta{ display:flex; justify-content:space-between; align-items:baseline; margin-top:1rem; gap:1rem; }
.pc .pc-meta h3{ font-size:1.3rem; }
.pc .pc-cat{ font-size:.7rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); }
.pc .pc-loc{ color:var(--muted-2); font-size:.85rem; font-family:var(--font-display); font-style:italic; }
.pc.hidden{ display:none; }

/* project modal */
.modal{ position:fixed; inset:0; z-index:200; display:none; align-items:center; justify-content:center; padding:var(--gutter); }
.modal.open{ display:flex; }
.modal-bg{ position:absolute; inset:0; background:rgba(6,6,7,.82); backdrop-filter:blur(8px); opacity:0; transition:opacity .4s; }
.modal.open .modal-bg{ opacity:1; }
.modal-card{ position:relative; z-index:2; width:min(960px,100%); max-height:86vh; overflow:auto;
  background:var(--ink-2); border:1px solid var(--line); border-radius:var(--radius);
  transform:translateY(24px); opacity:0; transition:transform .5s var(--ease), opacity .5s; }
.modal.open .modal-card{ transform:translateY(0); opacity:1; }
.modal-card .m-media{ aspect-ratio:16/9; position:relative; overflow:hidden; border-bottom:1px solid var(--line); background:var(--ink-3); }
.modal-card .m-media img{ width:100%; height:100%; object-fit:cover; }
.modal-card .m-body{ padding:clamp(1.6rem,3vw,2.6rem); }
.modal-card .m-head{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; align-items:baseline; }
.modal-card .m-cat{ font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--gold); margin-bottom:.6rem; }
.modal-card h3{ font-size:clamp(1.6rem,3vw,2.4rem); }
.modal-card .m-loc{ color:var(--muted-2); font-family:var(--font-display); font-style:italic; }
.modal-card .m-desc{ color:var(--muted); margin-top:1.2rem; max-width:64ch; }
.modal-card .m-tags{ display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1.6rem; }
.modal-card .m-tags .tag{ font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color:var(--muted-2);
  border:1px solid var(--line); border-radius:999px; padding:.32rem .8rem; }
.modal-card .m-actions{ margin-top:2rem; display:flex; gap:1rem; flex-wrap:wrap; }
.modal-close{ position:absolute; top:1rem; right:1rem; z-index:5; width:44px; height:44px; border-radius:50%;
  background:rgba(10,10,11,.6); border:1px solid var(--line); display:flex; align-items:center; justify-content:center;
  color:var(--cream); transition:background .3s, transform .4s var(--ease); }
.modal-close:hover{ background:var(--gold); color:#160F03; transform:rotate(90deg); }

/* ------------------------------------------------------------- contact */
.contact-grid{ display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(2rem,5vw,5rem); align-items:start; }
.form{ display:grid; gap:1.3rem; }
.form .row{ display:grid; grid-template-columns:1fr 1fr; gap:1.3rem; }
.field{ display:flex; flex-direction:column; gap:.55rem; }
.field label{ font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.field label .req{ color:var(--gold); }
.field input,.field textarea,.field select{
  background:var(--ink-2); border:1px solid var(--line); border-radius:var(--radius);
  padding:1rem 1.1rem; color:var(--cream); font-family:var(--font-sans); font-size:1rem;
  transition:border-color .35s, background .35s; width:100%;
}
.field textarea{ resize:vertical; min-height:140px; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--gold); background:var(--ink-3); }
.field input::placeholder,.field textarea::placeholder{ color:var(--muted-2); }
.hp{ position:absolute; left:-9999px; opacity:0; height:0; width:0; overflow:hidden; }
.form-actions{ display:flex; align-items:center; gap:1.4rem; flex-wrap:wrap; }
.form-status{ font-size:.92rem; }
.form-status.ok{ color:var(--gold-2); }
.form-status.err{ color:#E0857A; }
.form-status.sending{ color:var(--muted); }

.contact-side{ display:flex; flex-direction:column; gap:1.6rem; }
.cinfo{ border:1px solid var(--line); border-radius:var(--radius); background:var(--ink-card);
  padding:clamp(1.4rem,2.5vw,1.9rem); display:flex; flex-direction:column; gap:1.4rem; }
.cinfo .ci-row{ display:flex; flex-direction:column; gap:.3rem; }
.cinfo .ci-k{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); }
.cinfo .ci-v{ font-size:1.12rem; color:var(--cream); font-family:var(--font-display); font-weight:380; }
.cinfo .ci-v a{ transition:color .3s; }
.cinfo .ci-v a:hover{ color:var(--gold); }
.cinfo .ci-sub{ color:var(--muted-2); font-size:.9rem; }

/* --------------------------------------------------------------- footer */
.site-footer{ position:relative; border-top:1px solid var(--line); background:var(--ink-2); padding-top:clamp(3.5rem,6vw,6rem); overflow:hidden; }
.footer-cta{ text-align:center; padding-bottom:clamp(3rem,6vw,5rem); border-bottom:1px solid var(--line); position:relative; z-index:2; }
.footer-cta .eyebrow{ margin-bottom:1.6rem; }
.footer-cta h2{ font-size:clamp(2.2rem,1.2rem+4vw,5.2rem); margin-bottom:2rem; line-height:1; }
.footer-mark{ position:absolute; left:50%; bottom:-4%; transform:translateX(-50%); z-index:0;
  font-family:var(--font-display); font-size:clamp(7rem,26vw,24rem); line-height:.8; color:rgba(190,157,99,.04);
  pointer-events:none; white-space:nowrap; font-weight:400; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:clamp(1.5rem,3vw,2.5rem);
  padding-block:clamp(2.5rem,4vw,3.5rem); position:relative; z-index:2; }
.footer-grid .fcol h4{ font-family:var(--font-sans); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--gold); margin-bottom:1.2rem; font-weight:600; }
.footer-grid .fcol a{ display:block; color:var(--muted); padding:.3rem 0; transition:color .3s; font-size:.96rem; }
.footer-grid .fcol a:hover{ color:var(--cream); }
.footer-brand img{ height:auto; width:120px; margin-bottom:1.2rem; }
.footer-brand p{ color:var(--muted); max-width:32ch; font-size:.95rem; }
.footer-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; align-items:center;
  padding-block:1.8rem; border-top:1px solid var(--line); color:var(--muted-2); font-size:.84rem; position:relative; z-index:2; }
.footer-bottom .fb-credit a{ color:var(--gold); }

/* --------------------------------------------------------------- page hero (inner pages) */
.page-hero{ position:relative; padding-top:calc(var(--nav-h) + clamp(2.5rem,6vw,5rem));
  padding-bottom:clamp(2.5rem,5vw,4rem); overflow:hidden; }
.page-hero .orb-1{ width:560px; height:560px; top:-180px; left:-100px; opacity:.4; }
.page-hero .ph-eyebrow{ margin-bottom:1.6rem; }
.page-hero h1{ font-size:clamp(2.8rem,1.5rem+6vw,7rem); line-height:.96; max-width:16ch; }
.page-hero .ph-sub{ margin-top:1.8rem; max-width:54ch; color:var(--muted); }
.page-hero .ph-line{ display:block; overflow:hidden; }

/* breadcrumb */
.crumbs{ display:flex; gap:.6rem; align-items:center; color:var(--muted-2); font-size:.78rem;
  letter-spacing:.06em; text-transform:uppercase; margin-bottom:1.6rem; }
.crumbs a:hover{ color:var(--gold); }
.crumbs .sep{ color:var(--gold-3); }

/* split content blocks */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.split.media-left .s-media{ order:-1; }
.s-media{ aspect-ratio:4/5; border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); position:relative; background:var(--ink-3); }
.s-media img{ width:100%; height:100%; object-fit:cover; }
.s-body .eyebrow{ margin-bottom:1.3rem; }
.s-body h2{ margin-bottom:1.3rem; }
.s-body p{ color:var(--muted); margin-bottom:1.1rem; }
.s-body p:last-of-type{ margin-bottom:0; }
.s-list{ display:flex; flex-direction:column; gap:1rem; margin-top:1.6rem; }
.s-list li{ display:flex; gap:.9rem; align-items:flex-start; color:#D9D3C6; }
.s-list li .si{ font-family:var(--font-display); font-style:italic; color:var(--gold-3); font-size:.9rem; min-width:1.6rem; }

/* faq */
.faq{ border-top:1px solid var(--line); }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; display:flex; justify-content:space-between; align-items:center; gap:1rem;
  padding-block:1.5rem; text-align:left; font-family:var(--font-display); font-size:clamp(1.15rem,2vw,1.5rem); font-weight:430; color:var(--cream); }
.faq-q .fq-ic{ width:36px; height:36px; border:1px solid var(--line); border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; color:var(--gold); transition:transform .45s var(--ease), background .4s; position:relative; }
.faq-q .fq-ic::before,.faq-q .fq-ic::after{ content:""; position:absolute; background:var(--gold); transition:opacity .3s, background .3s; }
.faq-q .fq-ic::before{ width:13px; height:1.5px; }
.faq-q .fq-ic::after{ width:1.5px; height:13px; }
.faq-item.open .fq-ic{ background:var(--gold-grad); }
.faq-item.open .fq-ic::before,.faq-item.open .fq-ic::after{ background:#160F03; }
.faq-item.open .fq-ic::after{ opacity:0; }
.faq-a{ overflow:hidden; height:0; }
.faq-a-inner{ padding-bottom:1.6rem; color:var(--muted); max-width:68ch; }

/* generic CTA band */
.cta-band{ text-align:center; }
.cta-band h2{ margin-bottom:1.4rem; }
.cta-band p{ color:var(--muted); max-width:52ch; margin:0 auto 2.2rem; }
.cta-actions{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

/* utility */
.center{ text-align:center; }
.mt-s{ margin-top:1rem; } .mt-m{ margin-top:2rem; } .mt-l{ margin-top:3.5rem; }
.maxw-sm{ max-width:560px; } .maxw-md{ max-width:760px; }
.skip{ position:absolute; left:-9999px; top:0; background:var(--gold); color:#160F03; padding:.8rem 1.2rem; z-index:500; border-radius:0 0 4px 0; }
.skip:focus{ left:0; }

/* focus visibility */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,.faq-q:focus-visible{
  outline:2px solid var(--gold); outline-offset:3px; border-radius:2px;
}

/* ============================================== NO-JS / FALLBACK SAFETY */
/* If JS never loads, .js is never added — keep all content visible. */
html:not(.js) .faq-a{ height:auto !important; }
html:not(.js) .preloader{ display:none; }
html:not(.js) .mobile-menu .mm-links a{ opacity:1; transform:none; }

/* ========================================================== RESPONSIVE */
@media (max-width:1080px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .footer-brand{ grid-column:1 / -1; }
  .stats{ grid-template-columns:repeat(2,1fr); gap:2.5rem 1.5rem; }
}
@media (max-width:900px){
  :root{ --nav-h:74px; }
  .nav-links{ display:none; }
  .nav-cta .btn{ display:none; }
  .burger{ display:block; }
  .cols-3,.cols-4{ grid-template-columns:1fr 1fr; }
  .price-grid{ grid-template-columns:1fr; max-width:480px; margin-inline:auto; }
  .price.feat{ order:-1; }
  .contact-grid{ grid-template-columns:1fr; }
  .split{ grid-template-columns:1fr; gap:2rem; }
  .split.media-left .s-media{ order:0; }
  .s-media{ aspect-ratio:16/11; }
  .hero-sub{ grid-template-columns:1fr; gap:1.6rem; }
  .work-grid{ grid-template-columns:1fr; }
  .statement-grid{ grid-template-columns:1fr; }
  .svc{ grid-template-columns:auto 1fr; }
  .svc .svc-go{ display:none; }
  .step{ grid-template-columns:64px 1fr; gap:1.2rem; }
  /* showcase becomes a native horizontal scroller (pin is disabled on mobile) */
  .showcase{ overflow:visible; }
  .showcase-scroller{ overflow-x:auto; -webkit-overflow-scrolling:touch; scroll-snap-type:x proximity;
    margin-inline:calc(var(--gutter) * -1); padding-inline:var(--gutter); scrollbar-width:none; }
  .showcase-scroller::-webkit-scrollbar{ display:none; }
  .showcase-track{ padding-right:var(--gutter); }
  .work-card{ scroll-snap-align:start; }
}
@media (max-width:560px){
  .cols-2,.cols-3,.cols-4{ grid-template-columns:1fr; }
  .form .row{ grid-template-columns:1fr; }
  .stats{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; align-items:flex-start; }
  .work-card{ width:82vw; }
  .btn,.btn-ghost{ width:100%; justify-content:center; }
  .hero-actions .btn,.hero-actions .btn-ghost{ width:auto; }
}

/* touch: no custom cursor, no hover-only reliance handled in JS */
@media (hover:none){
  .work-card .wc-reveal{ display:none; }
}

/* ===================================================== REDUCED MOTION */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .preloader{ display:none !important; }
  .marquee-track{ transform:none !important; }
  .scroll-cue .sc-line::after{ display:none; }
}
