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

/* ── Tokens ─────────────────────────────────────── */
:root {
  --bg:       #08080f;
  --fg:       #f0ede6;
  --dim:      rgba(240,237,230,.42);
  --accent:   #c8ff00;
  --border:   rgba(255,255,255,.06);
  --ease:     cubic-bezier(.16,1,.3,1);
  --f-disp:   'Big Shoulders Display', sans-serif;
  --f-serif:  'Fraunces', serif;
  --f-body:   'Space Grotesk', sans-serif;
}

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--f-body);
  font-weight: 300;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { background: none; border: none; font: inherit; cursor: pointer; }

/* ── Noise ──────────────────────────────────────── */
#noise {
  position: fixed; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none; z-index: 9000;
  opacity: .028;
}

/* ── Spotlight ──────────────────────────────────── */
#spotlight {
  position: fixed; inset: 0;
  pointer-events: none; z-index: 1;
  background: radial-gradient(
    circle 480px at var(--mx,50%) var(--my,50%),
    rgba(200,255,0,.06) 0%,
    transparent 68%
  );
}

/* ── Dot grid on hero ───────────────────────────── */
#hero {
  background-image: radial-gradient(circle, rgba(200,255,0,.13) 1px, transparent 1px);
  background-size: 36px 36px;
}

/* ── Custom cursor (removed) ──────────────────────── */
#cursor { display: none; }

/* ── Nav ────────────────────────────────────────── */
#nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  display: flex; align-items: center; justify-content: space-between;
  padding: 2rem 4rem;
  transition: background .4s, border-color .4s, padding .4s;
  border-bottom: 1px solid transparent;
}
#nav.solid {
  background: rgba(8,8,15,.9);
  backdrop-filter: blur(18px);
  border-color: var(--border);
  padding: 1.25rem 4rem;
}
.logo {
  font-family: var(--f-disp);
  font-size: 1.8rem; font-weight: 900; letter-spacing: .04em;
}
.nav-links {
  display: flex; gap: 2.5rem;
}
.nav-links a {
  font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--dim); position: relative; transition: color .2s;
}
.nav-links a::after {
  content: ''; position: absolute; bottom: -2px; left: 0; right: 0;
  height: 1px; background: var(--accent);
  transform: scaleX(0); transform-origin: left;
  transition: transform .3s var(--ease);
}
.nav-links a:hover { color: var(--fg); }
.nav-links a:hover::after { transform: scaleX(1); }
.nav-btn {
  font-size: .65rem; letter-spacing: .14em; text-transform: uppercase; font-weight: 500;
  border: 1px solid var(--border);
  padding: .6rem 1.5rem; border-radius: 2rem;
  transition: background .25s, border-color .25s, color .25s, transform .3s var(--ease);
}
.nav-btn:hover { background: var(--accent); border-color: var(--accent); color: var(--bg); }

/* ── Hero ───────────────────────────────────────── */
#hero {
  min-height: 100vh;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 9rem 4rem 3.5rem;
  position: relative; overflow: hidden;
}

/* lens rings */
.lens {
  position: absolute; border-radius: 50%;
  border: 1px solid rgba(200,255,0,.07);
  pointer-events: none;
}
.lens-1 {
  width: 72vw; height: 72vw;
  right: -22vw; top: 50%; transform: translateY(-50%);
  animation: rotateLens 40s linear infinite;
}
.lens-2 {
  width: 52vw; height: 52vw;
  right: -14vw; top: 50%; transform: translateY(-50%);
  border-color: rgba(200,255,0,.04);
  animation: rotateLens 25s linear infinite reverse;
}
@keyframes rotateLens {
  to { transform: translateY(-50%) rotate(360deg); }
}

.hero-top {
  display: flex; gap: 2rem;
  font-size: .62rem; letter-spacing: .22em; text-transform: uppercase; color: var(--dim);
}

/* Title */
.hero-center { flex: 1; display: flex; flex-direction: column; justify-content: center; }

.ht-row { display: flex; }
.ht-right { justify-content: flex-end; }

.ht-clip { display: inline-block; overflow: hidden; }

.ht-word {
  font-family: var(--f-disp);
  font-size: clamp(4rem, 18.5vw, 22rem);
  font-weight: 900; line-height: .82;
  letter-spacing: -.03em;
  display: block;
  transform: translateY(108%);
  transition: transform 1.1s var(--ease);
}
.ht-word.visible { transform: translateY(0); }

/* Outline/stroke variant */
.ht-stroke {
  -webkit-text-stroke: clamp(1.5px, .18vw, 3px) var(--fg);
  color: transparent;
}

.ht-serif {
  margin-top: 1.8rem;
}
.ht-serif em {
  font-family: var(--f-serif);
  font-style: italic; font-weight: 300;
  font-size: clamp(1.3rem, 3vw, 3rem);
  color: var(--accent); line-height: 1;
  display: block;
  transform: translateY(108%);
  transition: transform 1.1s var(--ease) .3s;
}
.ht-serif em.visible { transform: translateY(0); }

/* Hero bottom */
.hero-bottom {
  display: flex; align-items: flex-end; justify-content: space-between;
  padding-top: 3rem;
}
.hero-disciplines {
  display: flex; align-items: center; gap: .8rem;
  font-size: .65rem; letter-spacing: .18em; text-transform: uppercase; color: var(--dim);
}
.sep { color: var(--accent); }
.hero-scroll {
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  font-size: .58rem; letter-spacing: .18em; text-transform: uppercase; color: var(--dim);
  transition: color .2s;
}
.hero-scroll:hover { color: var(--accent); }
.scroll-arrow {
  font-size: 1rem;
  animation: bounce .5s var(--ease) infinite alternate;
}
@keyframes bounce { to { transform: translateY(4px); } }

/* ── Marquee ─────────────────────────────────────── */
#marquee {
  overflow: hidden;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 1rem 0;
}
.marquee-track {
  display: flex; gap: 2.5rem; align-items: center;
  white-space: nowrap;
  font-family: var(--f-disp);
  font-size: 1rem; font-weight: 700; letter-spacing: .14em;
  animation: marquee 24s linear infinite;
}
.marquee-track b { color: var(--accent); font-weight: 400; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ── Work ────────────────────────────────────────── */
#work-section { border-top: 1px solid var(--border); }

#work-sticky { display: flex; flex-direction: column; }

.work-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 2rem 4rem 1.5rem;
  border-bottom: 1px solid var(--border);
}
.sec-label {
  font-size: .6rem; letter-spacing: .22em; text-transform: uppercase; color: var(--dim);
}
.work-progress-label {
  font-size: .6rem; letter-spacing: .18em; color: var(--dim);
  font-variant-numeric: tabular-nums;
}
#work-current { color: var(--accent); }

#work-track {
  display: flex; gap: 2.5vw;
  padding: 2.5rem 4rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--accent) transparent;
}
#work-track::-webkit-scrollbar { height: 3px; }
#work-track::-webkit-scrollbar-track { background: transparent; }
#work-track::-webkit-scrollbar-thumb { background: var(--accent); border-radius: 2px; }

/* Cards */
.wc {
  flex-shrink: 0;
  width: 62vw; height: 72vh;
  scroll-snap-align: start;
  border-radius: 8px; overflow: hidden;
  position: relative;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 2.5rem;
  cursor: pointer;
}
.wc-bg {
  position: absolute; inset: 0;
  background: linear-gradient(145deg, var(--c1), var(--c2));
  transition: transform .6s var(--ease);
}
.wc:hover .wc-bg { transform: scale(1.03); }

.wc-num {
  font-size: .62rem; letter-spacing: .22em; color: rgba(240,237,230,.3);
  position: relative; z-index: 1;
}
.wc-body { position: relative; z-index: 1; }
.wc-title {
  font-family: var(--f-disp);
  font-size: clamp(2.5rem, 5.5vw, 6rem);
  font-weight: 900; line-height: .88; letter-spacing: -.02em;
  transition: color .25s;
}
.wc:hover .wc-title { color: var(--accent); }
.wc-meta {
  display: flex; gap: 1.5rem; margin-top: 1rem;
  font-size: .65rem; letter-spacing: .16em; text-transform: uppercase; color: var(--dim);
}
.wc-play {
  position: relative; z-index: 1; align-self: flex-end;
  font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--dim);
  display: flex; align-items: center; gap: .6rem;
  border: 1px solid var(--border); padding: .6rem 1.2rem; border-radius: 2rem;
  transition: border-color .25s, color .25s;
}
.wc:hover .wc-play { border-color: var(--accent); color: var(--accent); }
.wc-play span { font-size: .55rem; }

/* Progress bar */
.work-progress-bar {
  height: 1px; background: var(--border); flex-shrink: 0;
}
#work-bar {
  height: 100%; background: var(--accent);
  width: 0%; transition: width .1s linear;
}

/* ── Mobile work fallback ────────────────────────── */
@media (max-width: 768px) {
  #work-section { height: auto !important; }
  #work-sticky { position: static; height: auto; overflow: visible; }
  #work-track {
    flex-direction: column; padding: 2rem;
    transform: none !important; gap: 1.5rem;
  }
  .wc { width: 100%; height: 60vw; min-height: 260px; }
}

/* ── About ───────────────────────────────────────── */
#about { padding: 8rem 4rem; border-top: 1px solid var(--border); }

.about-statement {
  margin-bottom: 6rem;
  border-bottom: 1px solid var(--border);
  padding-bottom: 5rem;
}
.about-statement p {
  font-family: var(--f-disp);
  font-size: clamp(1.8rem, 4vw, 4.5rem);
  font-weight: 700; line-height: 1.1;
  max-width: 900px;
}

/* word-by-word reveal */
.word-wrap { display: inline-block; overflow: hidden; vertical-align: bottom; }
.rev-word {
  display: inline-block;
  transform: translateY(105%);
  transition: transform .65s var(--ease);
}
.rev-word.in { transform: translateY(0); }

.about-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 5rem; align-items: start; }
.about-title {
  font-family: var(--f-disp);
  font-size: clamp(2.8rem, 5.5vw, 6rem);
  font-weight: 900; line-height: .88; margin-top: 1.5rem;
}
.about-title em {
  font-family: var(--f-serif);
  font-style: italic; font-weight: 300; color: var(--accent); display: block; font-size: .88em;
}
.about-body {
  font-size: .95rem; line-height: 1.85; color: var(--dim); margin-bottom: 1.5rem;
}
.about-stats {
  display: flex; gap: 2.5rem; flex-wrap: wrap;
  margin-top: 3rem; padding-top: 2.5rem; border-top: 1px solid var(--border);
}
.stat-n {
  font-family: var(--f-disp);
  font-size: clamp(3rem, 6vw, 6rem);
  font-weight: 900; line-height: 1; color: var(--accent); display: block;
}
.stat-s { font-family: var(--f-disp); font-size: 2.5rem; color: var(--accent); }
.stat-l {
  display: block; font-size: .58rem; letter-spacing: .18em;
  text-transform: uppercase; color: var(--dim); margin-top: .4rem;
}

/* ── Services ────────────────────────────────────── */
#services { padding: 6rem 4rem; border-top: 1px solid var(--border); }

.svc-header { margin-bottom: 2rem; }
.svc-row { border-bottom: 1px solid var(--border); }
.svc-trigger {
  width: 100%; display: flex; align-items: center; gap: 2rem;
  padding: 2rem 0; color: var(--fg);
  text-align: left; transition: color .25s;
}
.svc-trigger:hover, .svc-row.open .svc-trigger { color: var(--accent); }
.svc-num { font-size: .58rem; letter-spacing: .2em; color: var(--dim); width: 2.5rem; flex-shrink: 0; }
.svc-name {
  flex: 1;
  font-family: var(--f-disp);
  font-size: clamp(1.6rem, 3.5vw, 3.5rem);
  font-weight: 900; letter-spacing: -.01em;
}
.svc-plus {
  font-size: 1.6rem; font-weight: 300;
  transition: transform .4s var(--ease), color .25s;
  flex-shrink: 0;
}
.svc-row.open .svc-plus { transform: rotate(45deg); color: var(--accent); }
.svc-body {
  max-height: 0; overflow: hidden;
  transition: max-height .55s var(--ease), padding .4s var(--ease);
  padding-left: calc(2.5rem + 2rem);
}
.svc-row.open .svc-body { max-height: 200px; padding: 0 0 2rem calc(2.5rem + 2rem); }
.svc-body p { font-size: .9rem; line-height: 1.8; color: var(--dim); max-width: 500px; }

/* ── CTA ─────────────────────────────────────────── */
#cta {
  padding: 10rem 4rem;
  border-top: 1px solid var(--border);
  background: radial-gradient(ellipse at 20% 60%, rgba(200,255,0,.045) 0%, transparent 60%);
}
.cta-title {
  font-family: var(--f-disp);
  font-size: clamp(3rem, 12vw, 14rem);
  font-weight: 900; line-height: .84;
  margin: 1.5rem 0 4rem;
}
.cta-title em {
  font-family: var(--f-serif);
  font-style: italic; font-weight: 300; color: var(--accent); font-size: .85em; display: block;
}
.cta-btn {
  display: inline-flex; align-items: center; gap: .8rem;
  font-size: .7rem; letter-spacing: .16em; text-transform: uppercase; font-weight: 500;
  border: 1px solid rgba(200,255,0,.35); color: var(--accent);
  padding: 1.1rem 2.8rem; border-radius: 3rem;
  transition: background .25s, border-color .25s, color .25s, transform .3s var(--ease);
}
.cta-btn:hover { background: var(--accent); border-color: var(--accent); color: var(--bg); }
.cta-arrow { font-size: 1.1rem; }

/* ── Magnetic ─────────────────────────────────────── */
.magnetic { display: inline-flex; transition-property: transform, background, border-color, color; }

/* ── Contact ──────────────────────────────────────── */
#contact { padding: 7rem 4rem; border-top: 1px solid var(--border); }
.contact-inner { display: grid; grid-template-columns: 1fr 1.4fr; gap: 6rem; }
.contact-title {
  font-family: var(--f-disp);
  font-size: clamp(4.5rem, 9vw, 10rem);
  font-weight: 900; line-height: .84; margin: 1.5rem 0;
}
.contact-info { display: flex; flex-direction: column; gap: .5rem; margin-bottom: 2.5rem; }
.contact-info a {
  font-size: 1rem; padding-bottom: .7rem; border-bottom: 1px solid var(--border);
  transition: color .2s, border-color .2s;
}
.contact-info a:hover { color: var(--accent); border-color: var(--accent); }
.contact-social { display: flex; gap: 1.5rem; }
.contact-social a {
  font-size: .6rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--dim); font-weight: 500; transition: color .2s;
}
.contact-social a:hover { color: var(--fg); }

form { display: flex; flex-direction: column; gap: 1rem; padding-top: 1rem; }
.fg input, .fg select, .fg textarea {
  width: 100%; background: transparent;
  border: none; border-bottom: 1px solid var(--border);
  color: var(--fg); font-family: var(--f-body);
  font-weight: 300; font-size: .9rem; padding: 1rem 0; outline: none;
  transition: border-color .25s; appearance: none;
}
.fg select option { background: var(--bg); }
.fg input:focus, .fg select:focus, .fg textarea:focus { border-color: var(--accent); }
.fg input::placeholder, .fg textarea::placeholder { color: var(--dim); }
.fg select.empty { color: var(--dim); }
.fg textarea { resize: none; }

/* Select dropdown arrow */
.fg-select { position: relative; }
.fg-select::after {
  content: '↓';
  position: absolute;
  right: 0;
  bottom: 1rem;
  font-size: 0.75rem;
  color: var(--dim);
  pointer-events: none;
  transition: color .25s;
}
.fg-select:focus-within::after { color: var(--accent); }
.form-btn {
  align-self: flex-start; margin-top: .5rem;
  background: var(--fg); color: var(--bg);
  padding: 1.1rem 2.8rem;
  font-family: var(--f-body); font-size: .7rem;
  letter-spacing: .18em; text-transform: uppercase; font-weight: 500;
  border-radius: 3rem;
  transition: background .25s, color .25s, transform .3s var(--ease);
}
.form-btn:hover { background: var(--accent); }

/* ── Footer ───────────────────────────────────────── */
#footer {
  padding: 2rem 4rem;
  display: flex; align-items: center; justify-content: space-between;
  border-top: 1px solid var(--border);
  font-size: .6rem; letter-spacing: .16em; text-transform: uppercase; color: var(--dim);
}
.footer-logo {
  font-family: var(--f-disp);
  font-size: 1.1rem; font-weight: 900; color: var(--fg); letter-spacing: .1em;
}
.footer-links { display: flex; gap: 1.2rem; }
.footer-links a { transition: color .2s; }
.footer-links a:hover { color: var(--accent); }

/* ── Scroll animations ─────────────────────────────── */
.fade-up {
  opacity: 0; transform: translateY(26px);
  transition: opacity .9s var(--ease) var(--d,0s), transform .9s var(--ease) var(--d,0s);
}
.fade-up.in { opacity: 1; transform: none; }

/* ── Responsive ────────────────────────────────────── */
@media (max-width: 960px) {
  #nav, #hero, #about, #services, #cta, #contact, #footer, .work-header {
    padding-left: 2rem; padding-right: 2rem;
  }
  #nav.solid { padding-left: 2rem; padding-right: 2rem; }
  .about-grid, .contact-inner { grid-template-columns: 1fr; gap: 3rem; }
  .lens { display: none; }
}
@media (max-width: 768px) {
  /* Nav: hide links, keep logo + CTA */
  .nav-links { display: none; }
  #nav { padding: 1.4rem 2rem; }
  #nav.solid { padding: 1rem 2rem; }

  /* Hero: reduce top padding, tighten spacing */
  #hero { padding-top: 6rem; padding-bottom: 2.5rem; }
  .hero-top { flex-direction: column; gap: .5rem; }
  .hero-disciplines { flex-wrap: wrap; gap: .5rem; }
  .ht-serif em { font-size: clamp(1.1rem, 4vw, 2rem); }
  .hero-bottom { padding-top: 2rem; }

  /* Work cards */
  #work-track { padding: 1.5rem 2rem; gap: 1.2rem; }
  .wc { width: 80vw; height: 56vw; min-height: 240px; }

  /* About statement */
  .about-statement { margin-bottom: 3.5rem; padding-bottom: 3rem; }

  /* CTA */
  #cta { padding: 6rem 2rem; }

  /* Contact */
  #contact { padding: 5rem 2rem; }
}
@media (max-width: 600px) {
  .hero-bottom { flex-direction: column; align-items: flex-start; gap: 1.5rem; }
  .about-stats { gap: 1.5rem; }
  #footer { flex-direction: column; gap: .8rem; text-align: center; }
  .svc-name { font-size: clamp(1.3rem, 6vw, 2rem); }
}
