:root {
  --pure-white: #ffffff;
  --text-on-dark: rgba(255, 253, 247, 0.96);
  --warm-white: #fbf7f4;
  --soft-white: #f8f8f6;
  --ink: #080808;
  --ink-soft: #34302d;
  --stage-black: #050303;
  --stage-black-soft: #110806;
  --stage-brown: #23110c;
  --crimson: #8b0015;
  --dark-crimson: #5e000e;
  --gold: #7b5a14;
  --gold-soft: #8a6418;
  --gold-line: rgba(123, 90, 20, 0.62);
  --white-line: rgba(255, 255, 255, 0.16);
  --line: rgba(8, 8, 8, 0.12);
  --serif: "Playfair Display", Georgia, serif;
  --sans: "Jost", system-ui, sans-serif;
  --gutter: clamp(24px, 5vw, 88px);
  --maxw: 1360px;
  --ease: cubic-bezier(0.25, 1, 0.5, 1);
}

* { box-sizing: border-box; }

html {
  background: var(--stage-black);
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
  background: var(--stage-black);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  font-weight: 300;
  line-height: 1.7;
  letter-spacing: 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { color: inherit; }
h1, h2, h3, p { margin: 0; }

h1,
h2,
h3 {
  font-family: var(--serif);
  font-weight: 500;
  line-height: 1.04;
  letter-spacing: 0;
}

:focus-visible {
  outline: 2px solid #8a6418;
  outline-offset: 4px;
}

.skip {
  position: absolute;
  top: 16px;
  left: -999px;
  z-index: 300;
  padding: 16px 24px;
  background: var(--crimson);
  color: var(--text-on-dark);
}

.skip:focus { left: 16px; }

.section-shell {
  width: min(100%, var(--maxw));
  margin: 0 auto;
  padding: 0 var(--gutter);
}

.site-header {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 90;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 24px;
  min-height: 72px;
  padding: 12px var(--gutter);
  border-bottom: 1px solid rgba(123, 90, 20, 0.34);
  background-color: #050303;
  background-image: linear-gradient(180deg, rgba(5, 3, 3, 0.86), rgba(5, 3, 3, 0.46));
  color: var(--text-on-dark);
  backdrop-filter: blur(18px);
}

.brand span {
  display: block;
  color: var(--gold-soft);
  font-family: var(--serif);
  font-size: 34px;
  line-height: 0.9;
  letter-spacing: 0.02em;
}

.nav-lanes {
  display: flex;
  justify-content: center;
  gap: clamp(18px, 3vw, 48px);
}

.nav-lanes a,
.book-link {
  color: rgba(255, 255, 255, 0.78);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.04em;
  transition: color 180ms var(--ease), border-color 180ms var(--ease);
}

.nav-lanes a[aria-current="page"] {
  color: var(--gold-soft);
  border-bottom: 2px solid var(--crimson);
}

.nav-lanes a:hover,
.book-link:hover { color: var(--text-on-dark); }

.button {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  padding: 16px 32px;
  border: 1px solid transparent;
  border-radius: 0;
  cursor: pointer;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1;
  transition: background 180ms var(--ease), color 180ms var(--ease), border-color 180ms var(--ease), transform 180ms var(--ease);
}

.button:hover { transform: translateY(-1px); }
.button-primary { background: var(--crimson); color: var(--text-on-dark); }
.button-primary:hover { background: var(--dark-crimson); }
.button-secondary {
  border-color: var(--gold-line);
  background-color: #050303;
  background: rgba(5, 3, 3, 0.58);
  color: var(--text-on-dark);
}
.button-secondary:hover { border-color: var(--text-on-dark); background: rgba(255, 255, 255, 0.08); }

.label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--dark-crimson);
  font-size: 11px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.label::before {
  content: "";
  width: 40px;
  height: 1px;
  background: currentColor;
}

.label.light {
  color: var(--text-on-dark);
  padding: 8px 12px;
  background: #050303;
}

.film-title {
  position: relative;
  min-height: 100svh;
  display: grid;
  align-items: end;
  padding: 120px var(--gutter) 80px;
  background: var(--stage-black);
  background-color: #050303;
  color: var(--text-on-dark);
  isolation: isolate;
}

.film-title-media,
.film-title-vignette {
  position: absolute;
  inset: 0;
  z-index: -2;
}

.film-title-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 45% center;
  filter: contrast(1.2) saturate(1.08) brightness(1.02);
}

.film-title-vignette {
  z-index: -1;
  background:
    radial-gradient(circle at 58% 31%, rgba(244, 223, 173, 0.26), transparent 18%),
    radial-gradient(circle at 72% 44%, rgba(123, 90, 20, 0.18), transparent 22%),
    linear-gradient(90deg, rgba(5, 3, 3, 0.94) 0%, rgba(5, 3, 3, 0.5) 44%, rgba(5, 3, 3, 0.12) 100%),
    linear-gradient(180deg, rgba(5, 3, 3, 0.16) 0%, rgba(5, 3, 3, 0.42) 62%, #050303 100%);
}

.film-title::after {
  content: "";
  position: absolute;
  right: var(--gutter);
  bottom: 32px;
  left: var(--gutter);
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold-line), transparent);
}

.film-title-content {
  width: min(100%, var(--maxw));
  margin: 0 auto;
}

.scene-label {
  max-width: 720px;
  color: rgba(255, 255, 255, 0.86);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1.35;
}

.film-title h1 {
  max-width: 1080px;
  margin-top: 24px;
  font-size: clamp(64px, 8.2vw, 132px);
}

.hero-deck {
  max-width: 680px;
  margin-top: 24px;
  color: rgba(255, 255, 255, 0.78);
  font-size: clamp(18px, 1.35vw, 23px);
  line-height: 1.55;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 40px;
}

.artist-reveal {
  position: relative;
  padding: clamp(80px, 8vw, 144px) 0;
  background-color: #050303;
  background:
    radial-gradient(circle at 10% 8%, rgba(139, 0, 21, 0.22), transparent 28%),
    linear-gradient(180deg, #050303, #130806);
  color: var(--text-on-dark);
}

.artist-reveal::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px) 0 0 / 96px 96px,
    linear-gradient(180deg, transparent, rgba(123, 90, 20, 0.18));
}

.artist-reveal .label {
  color: var(--text-on-dark);
  padding: 8px 12px;
  background: #050303;
}

.artist-grid {
  position: relative;
  display: grid;
  grid-template-columns: minmax(360px, 0.82fr) minmax(520px, 1fr);
  gap: 72px;
  align-items: center;
}

.artist-still {
  border: 1px solid var(--gold-line);
  box-shadow: 0 44px 110px rgba(0, 0, 0, 0.42);
}

.artist-still img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  filter: contrast(1.1) brightness(0.72) saturate(0.82);
}

.artist-copy h2,
.proof-head h2,
.scale-card h2,
.section-heading h2,
.process-copy h2,
.visual-reel h2,
.inquiry h2 {
  margin-top: 16px;
  font-size: clamp(42px, 5.6vw, 84px);
}

.artist-copy p:not(.label) {
  max-width: 560px;
  margin-top: 24px;
  color: rgba(255, 255, 255, 0.72);
  font-size: 18px;
}

.proof-engine {
  padding: clamp(80px, 8vw, 144px) 0 0;
  background-color: #050303;
  background:
    radial-gradient(circle at 70% 10%, rgba(123, 90, 20, 0.22), transparent 24%),
    linear-gradient(180deg, #0a0404 0%, #050303 100%);
  color: var(--text-on-dark);
}

.proof-head {
  margin-bottom: 56px;
}

.crawl-lane {
  max-width: 100%;
  overflow: hidden;
  border-top: 1px solid var(--gold-line);
  border-bottom: 1px solid var(--gold-line);
  background: linear-gradient(90deg, rgba(94, 0, 14, 0.72), rgba(5, 3, 3, 0.92), rgba(123, 90, 20, 0.32));
}

.crawl-lane p {
  padding: 16px var(--gutter) 0;
  color: var(--text-on-dark);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.crawl-track {
  display: flex;
  width: max-content;
  gap: 48px;
  padding: 24px 0 32px;
  color: var(--text-on-dark);
  font-family: var(--serif);
  font-size: clamp(30px, 4vw, 64px);
  line-height: 1;
  white-space: nowrap;
  animation: proof-crawl 46s linear infinite;
}

.crawl-track span {
  display: inline-flex;
  align-items: center;
  gap: 48px;
}

.crawl-track span::after {
  content: "";
  width: 8px;
  height: 8px;
  border: 1px solid rgba(123, 90, 20, 0.72);
  transform: rotate(45deg);
}

.title-wall {
  display: grid;
  grid-template-columns: minmax(320px, 0.72fr) minmax(560px, 1fr);
  gap: 64px;
  padding-top: clamp(64px, 7vw, 120px);
  padding-bottom: clamp(64px, 7vw, 120px);
}

.title-wall article {
  position: sticky;
  top: 112px;
  align-self: start;
}

.title-wall article span,
.scale-stat span {
  color: var(--text-on-dark);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.title-wall h3 {
  margin-top: 16px;
  font-size: clamp(36px, 4.6vw, 68px);
}

.title-wall ul {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid var(--gold-line);
}

.title-wall li {
  padding: 20px 0;
  border-bottom: 1px solid var(--white-line);
  color: rgba(255, 255, 255, 0.88);
  font-family: var(--serif);
  font-size: clamp(28px, 3.8vw, 58px);
  line-height: 1.05;
}

.title-wall li:nth-child(3n + 1) { color: var(--text-on-dark); }
.title-wall li:nth-child(4n) { padding-left: 48px; }

.faces-band {
  padding: 56px 0;
  border-top: 1px solid var(--gold-line);
  background:
    radial-gradient(circle at 15% 0%, rgba(139, 0, 21, 0.24), transparent 28%),
    #050303;
  color: var(--text-on-dark);
}

.faces-grid {
  display: grid;
  grid-template-columns: minmax(240px, 0.36fr) 1fr;
  gap: 48px;
  align-items: start;
}

.faces-grid p {
  color: var(--text-on-dark);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.faces-grid div {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
}

.faces-grid span {
  display: inline-flex;
  min-height: 48px;
  align-items: center;
  padding: 8px 0;
  border-bottom: 1px solid rgba(244, 223, 173, 0.22);
  color: rgba(255, 253, 247, 0.88);
  font-family: var(--serif);
  font-size: clamp(22px, 2.5vw, 38px);
  font-weight: 500;
  letter-spacing: 0;
}

.scale-story {
  padding: 8px;
  background-color: #050303;
  background: linear-gradient(135deg, var(--stage-black), var(--dark-crimson));
  color: var(--text-on-dark);
}

.scale-grid {
  display: grid;
  grid-template-columns: minmax(420px, 1fr) minmax(320px, 0.52fr);
  gap: 0;
  padding: 0;
  border: 1px solid var(--gold-line);
  background: rgba(5, 3, 3, 0.78);
}

.scale-card,
.scale-stat {
  padding: clamp(48px, 6vw, 96px);
}

.scale-card p:not(.label) {
  max-width: 660px;
  margin-top: 24px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 18px;
}

.scale-stat {
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-left: 1px solid var(--gold-line);
  background:
    radial-gradient(circle at 50% 36%, rgba(123, 90, 20, 0.24), transparent 42%),
    rgba(255, 255, 255, 0.04);
}

.scale-stat strong {
  color: var(--text-on-dark);
  font-family: var(--serif);
  font-size: clamp(88px, 12vw, 164px);
  font-weight: 500;
  line-height: 0.9;
}

.scale-stat p {
  max-width: 320px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 18px;
}

.production-services {
  padding: clamp(80px, 8vw, 144px) 0;
  background:
    radial-gradient(circle at 82% 10%, rgba(139, 0, 21, 0.26), transparent 30%),
    linear-gradient(180deg, #050303, #120706);
  color: var(--text-on-dark);
}

.production-services .label {
  color: var(--text-on-dark);
  padding: 8px 12px;
  background: #050303;
}

.section-heading {
  display: grid;
  grid-template-columns: minmax(280px, 0.58fr) minmax(520px, 1fr);
  gap: 64px;
  align-items: end;
  margin-bottom: 40px;
}

.service-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 16px;
}

.service-card {
  display: grid;
  grid-template-columns: minmax(120px, 0.18fr) minmax(280px, 0.36fr) 1fr;
  min-height: 160px;
  align-items: center;
  gap: 32px;
  padding: 32px 0;
  border-top: 1px solid var(--gold-line);
  background: transparent;
}

.service-card-feature {
  position: relative;
  grid-column: auto;
  grid-template-columns: minmax(360px, 0.72fr) minmax(420px, 1fr);
  min-height: 420px;
  padding: 0;
  border: 1px solid var(--gold-line);
  background: var(--stage-black);
  color: var(--text-on-dark);
}

.service-card-feature img {
  width: 100%;
  height: 100%;
  min-height: 420px;
  object-fit: cover;
  filter: brightness(0.58) saturate(0.95) contrast(1.12);
}

.service-card-feature::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(90deg, transparent 0%, rgba(5, 3, 3, 0.42) 48%, rgba(5, 3, 3, 0.86));
}

.service-card-feature div {
  position: relative;
  z-index: 1;
  max-width: 560px;
  padding: 48px;
}

.service-card span,
.service-card-feature span {
  color: rgba(255, 253, 247, 0.62);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
}

.service-card h3 {
  color: var(--text-on-dark);
  font-size: clamp(30px, 3vw, 46px);
}

.service-card p {
  margin-top: 0;
  color: rgba(255, 253, 247, 0.72);
}

.service-card-feature p {
  margin-top: 16px;
  color: rgba(255, 255, 255, 0.76);
}

.process {
  padding: clamp(80px, 8vw, 144px) 0;
  background-color: #050303;
  background:
    radial-gradient(circle at 88% 0%, rgba(123, 90, 20, 0.22), transparent 24%),
    var(--stage-black);
  color: var(--text-on-dark);
}

.process-grid {
  display: grid;
  grid-template-columns: minmax(320px, 0.7fr) minmax(520px, 1fr);
  gap: 64px;
  align-items: start;
}

.process-copy h2 {
  max-width: 620px;
}

.process-list {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid var(--gold-line);
}

.process-list li {
  display: grid;
  grid-template-columns: minmax(120px, 0.28fr) 1fr;
  gap: 24px;
  align-items: start;
  padding: 24px 0;
  border-bottom: 1px solid var(--white-line);
}

.process-list strong {
  color: var(--text-on-dark);
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 500;
  line-height: 1.08;
}

.process-list p {
  color: rgba(255, 255, 255, 0.72);
}

.visual-reel {
  padding: 8px;
  background: var(--stage-black);
  background-color: #050303;
  color: var(--text-on-dark);
}

.reel-frame {
  position: relative;
  display: grid;
  min-height: 640px;
  align-items: end;
  border: 1px solid var(--gold-line);
}

.reel-frame img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: contrast(1.14) saturate(1.12) brightness(0.58);
}

.reel-frame::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(5, 3, 3, 0.86), rgba(5, 3, 3, 0.16) 62%),
    linear-gradient(180deg, transparent, rgba(5, 3, 3, 0.82));
}

.reel-frame > div {
  position: relative;
  z-index: 1;
  max-width: 760px;
  padding: clamp(48px, 6vw, 96px);
}

.reel-frame p:not(.label) {
  max-width: 620px;
  margin-top: 24px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 18px;
}

.inquiry {
  padding: clamp(80px, 8vw, 144px) 0;
  background-color: var(--dark-crimson);
  background:
    radial-gradient(circle at 10% 0%, rgba(123, 90, 20, 0.22), transparent 26%),
    linear-gradient(135deg, var(--crimson), var(--dark-crimson));
  color: var(--text-on-dark);
}

.inquiry-grid {
  display: grid;
  grid-template-columns: minmax(320px, 0.72fr) minmax(460px, 1fr);
  gap: 64px;
  align-items: start;
}

.inquiry-copy p:not(.label) {
  max-width: 440px;
  margin-top: 24px;
  color: rgba(255, 255, 255, 0.82);
}

.inquiry-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  padding: 32px;
  border: 1px solid rgba(255, 255, 255, 0.28);
  background: rgba(5, 3, 3, 0.32);
}

.inquiry-form-cinematic {
  align-self: stretch;
  min-height: 520px;
  align-content: center;
  background:
    linear-gradient(180deg, rgba(5, 3, 3, 0.58), rgba(5, 3, 3, 0.28)),
    rgba(5, 3, 3, 0.34);
}

.field-row {
  display: grid;
  gap: 8px;
}

.field-row.full {
  grid-column: 1 / -1;
}

.inquiry-form label {
  color: var(--text-on-dark);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.inquiry-form input,
.inquiry-form select,
.inquiry-form textarea {
  min-height: 48px;
  width: 100%;
  padding: 12px 16px;
  border: 1px solid rgba(255, 255, 255, 0.42);
  border-radius: 0;
  background: rgba(255, 255, 255, 0.05);
  color: var(--text-on-dark);
}

.inquiry-form option {
  color: var(--ink);
  background: var(--soft-white);
}

.inquiry-form textarea {
  resize: vertical;
}

.inquiry-form input::placeholder,
.inquiry-form textarea::placeholder {
  color: rgba(255, 255, 255, 0.64);
}

.inquiry-form button {
  grid-column: 1 / -1;
  min-height: 48px;
  border: 1px solid var(--pure-white);
  border-radius: 0;
  background: transparent;
  color: var(--text-on-dark);
  cursor: pointer;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.inquiry-form p {
  grid-column: 1 / -1;
  color: rgba(255, 255, 255, 0.74);
  font-size: 13px;
}

.site-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  padding: 48px var(--gutter);
  border-top: 1px solid rgba(123, 90, 20, 0.34);
  background: var(--stage-black);
  color: rgba(255, 255, 255, 0.7);
}

.footer-brand span {
  font-size: 28px;
}

.body-of-work {
  padding: clamp(80px, 8vw, 144px) 0 0;
  background:
    radial-gradient(circle at 18% 20%, rgba(139, 0, 21, 0.24), transparent 32%),
    linear-gradient(180deg, #050303, #0c0404 52%, #050303);
  color: var(--text-on-dark);
}

.work-stage {
  display: grid;
  grid-template-columns: minmax(360px, 0.68fr) minmax(560px, 1fr);
  gap: 80px;
  align-items: stretch;
  padding-bottom: clamp(64px, 7vw, 120px);
}

.work-copy {
  display: flex;
  min-height: 640px;
  flex-direction: column;
  justify-content: center;
}

.work-copy h2,
.artist-authority h2,
.production-services h2,
.process-cinema h2 {
  margin-top: 16px;
  font-size: clamp(48px, 6vw, 96px);
}

.work-copy p:not(.label) {
  max-width: 520px;
  margin-top: 24px;
  color: rgba(255, 253, 247, 0.72);
  font-size: 18px;
}

.work-frame {
  position: relative;
  display: grid;
  align-content: center;
  min-height: 760px;
  padding: 72px;
  border: 1px solid var(--gold-line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent 42%),
    radial-gradient(circle at 50% 18%, rgba(139, 0, 21, 0.42), transparent 32%),
    #050303;
}

.work-frame-glow {
  position: absolute;
  inset: 32px;
  border: 1px solid rgba(123, 90, 20, 0.28);
  pointer-events: none;
}

.work-frame ul {
  position: relative;
  display: grid;
  gap: 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.work-frame li {
  color: rgba(255, 253, 247, 0.9);
  font-family: var(--serif);
  font-size: clamp(42px, 5vw, 88px);
  line-height: 1.03;
}

.work-frame li:nth-child(2n) {
  color: rgba(255, 253, 247, 0.58);
  padding-left: 64px;
}

.artist-authority {
  position: relative;
  min-height: 760px;
  display: grid;
  align-items: end;
  padding: clamp(80px, 8vw, 144px) 0;
  background: #050303;
  color: var(--text-on-dark);
}

.authority-media {
  position: absolute;
  inset: 0;
}

.authority-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.52) contrast(1.12) saturate(0.88);
}

.artist-authority::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(5, 3, 3, 0.92), rgba(5, 3, 3, 0.42) 50%, rgba(5, 3, 3, 0.84)),
    linear-gradient(180deg, rgba(5, 3, 3, 0.1), #050303 100%);
}

.authority-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(420px, 0.82fr) minmax(420px, 0.62fr);
  gap: 80px;
  align-items: end;
}

.authority-copy p {
  color: rgba(255, 253, 247, 0.76);
  font-size: 22px;
}

.faces-line {
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--gold-line);
}

.faces-line span {
  display: block;
  color: rgba(255, 253, 247, 0.62);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.faces-line p {
  margin-top: 16px;
  color: rgba(255, 253, 247, 0.88);
  font-family: var(--serif);
  font-size: clamp(30px, 3.8vw, 58px);
  line-height: 1.32;
}

.scale-cinema {
  display: grid;
  grid-template-columns: minmax(360px, 0.48fr) minmax(520px, 1fr);
  border: 1px solid var(--gold-line);
  background:
    radial-gradient(circle at 18% 38%, rgba(244, 223, 173, 0.18), transparent 36%),
    rgba(5, 3, 3, 0.82);
  min-height: 680px;
}

.scale-cinema .scale-stat,
.scale-cinema .scale-card {
  padding: clamp(48px, 6vw, 96px);
}

.scale-cinema .scale-stat {
  border-right: 1px solid var(--gold-line);
  border-left: 0;
}

.scale-cinema .scale-card p:not(.label) {
  max-width: 680px;
}

.capability-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.capability-board article {
  min-height: 420px;
  padding: 40px;
  border: 1px solid var(--gold-line);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0.015)),
    rgba(5, 3, 3, 0.56);
}

.capability-board span {
  color: rgba(255, 253, 247, 0.62);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.capability-board h3 {
  margin-top: 80px;
  color: var(--text-on-dark);
  font-size: clamp(32px, 3.4vw, 52px);
}

.capability-board p {
  margin-top: 16px;
  color: rgba(255, 253, 247, 0.72);
}

.process-reel {
  position: relative;
  min-height: 760px;
  display: grid;
  align-items: end;
  padding: clamp(80px, 8vw, 144px) 0;
  background: #050303;
  color: var(--text-on-dark);
}

.process-reel > img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.48) contrast(1.18) saturate(1.08);
}

.process-reel::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(5, 3, 3, 0.9), rgba(5, 3, 3, 0.32) 54%, rgba(5, 3, 3, 0.86)),
    linear-gradient(180deg, rgba(5, 3, 3, 0.08), #050303 100%);
}

.process-cinema {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(420px, 0.78fr) minmax(460px, 0.72fr);
  gap: 80px;
  align-items: end;
}

.process-cinema ol {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid var(--gold-line);
}

.process-cinema li {
  display: grid;
  grid-template-columns: minmax(120px, 0.34fr) 1fr;
  gap: 24px;
  padding: 32px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
}

.process-cinema strong {
  color: var(--text-on-dark);
  font-family: var(--serif);
  font-size: 30px;
  font-weight: 500;
  line-height: 1.08;
}

.process-cinema span {
  color: rgba(255, 253, 247, 0.72);
}

@keyframes proof-crawl {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

@media (max-width: 1180px) {
  .nav-lanes {
    justify-content: flex-start;
    overflow-x: auto;
    padding-bottom: 8px;
    scrollbar-width: none;
  }

  .nav-lanes::-webkit-scrollbar { display: none; }

  .artist-grid,
  .title-wall,
  .scale-grid,
  .work-stage,
  .authority-grid,
  .scale-cinema,
  .process-cinema,
  .section-heading,
  .process-grid,
  .inquiry-grid {
    grid-template-columns: 1fr;
  }

  .title-wall article {
    position: static;
  }

  .scale-stat {
    border-top: 1px solid var(--gold-line);
    border-left: 0;
  }

  .scale-cinema .scale-stat {
    border-top: 0;
    border-right: 0;
    border-bottom: 1px solid var(--gold-line);
  }

  .service-grid {
    grid-template-columns: 1fr;
  }

  .service-card-feature {
    grid-column: auto;
  }
}

@media (max-width: 720px) {
  .site-header {
    grid-template-columns: auto 1fr;
    min-height: 56px;
    padding: 8px 16px;
  }

  .brand span {
    font-size: 25px;
  }

  .nav-lanes {
    grid-column: 1 / -1;
    gap: 24px;
    order: 3;
    width: calc(100vw - 32px);
  }

  .book-link {
    justify-self: end;
  }

  .film-title {
    min-height: 100svh;
    padding: 144px 20px 56px;
  }

  .film-title-media img {
    object-position: center center;
  }

  .film-title-vignette {
    background:
      radial-gradient(circle at 58% 24%, rgba(244, 223, 173, 0.2), transparent 22%),
      linear-gradient(180deg, rgba(5, 3, 3, 0.28) 0%, rgba(5, 3, 3, 0.56) 38%, #050303 100%),
      linear-gradient(90deg, rgba(5, 3, 3, 0.72), rgba(5, 3, 3, 0.16));
  }

  .scene-label {
    font-size: 10px;
    letter-spacing: 0.04em;
  }

  .film-title h1 {
    max-width: 340px;
    font-size: clamp(43px, 13vw, 64px);
    overflow-wrap: break-word;
  }

  .hero-deck {
    font-size: 16px;
  }

  .hero-actions {
    display: grid;
    gap: 8px;
  }

  .button {
    width: 100%;
    padding: 16px 20px;
  }

  .section-shell {
    padding: 0 20px;
  }

  .artist-reveal,
  .proof-engine,
  .body-of-work,
  .artist-authority,
  .production-services,
  .process-reel,
  .process,
  .inquiry {
    padding-top: 64px;
    padding-bottom: 64px;
  }

  .artist-grid,
  .title-wall,
  .work-stage,
  .authority-grid,
  .process-cinema,
  .section-heading,
  .process-grid,
  .inquiry-grid {
    gap: 32px;
  }

  .work-copy {
    min-height: auto;
  }

  .work-frame {
    min-height: auto;
    padding: 48px 24px;
  }

  .work-frame-glow {
    inset: 16px;
  }

  .work-frame li {
    font-size: 42px;
  }

  .work-frame li:nth-child(2n) {
    padding-left: 0;
  }

  .artist-authority,
  .process-reel {
    min-height: 760px;
  }

  .authority-copy p {
    font-size: 17px;
  }

  .faces-line {
    margin-top: 32px;
  }

  .faces-line p {
    font-size: 34px;
  }

  .artist-still img {
    aspect-ratio: 1 / 1.12;
  }

  .artist-copy h2,
  .proof-head h2,
  .scale-card h2,
  .section-heading h2,
  .process-copy h2,
  .visual-reel h2,
  .inquiry h2 {
    max-width: 330px;
    font-size: clamp(36px, 11vw, 52px);
    overflow-wrap: break-word;
  }

  .crawl-lane p {
    padding: 16px 20px 0;
  }

  .crawl-track {
    gap: 32px;
    padding: 24px 0 32px;
    font-size: 34px;
    animation-duration: 56s;
  }

  .crawl-track span,
  .crawl-track span::after {
    gap: 32px;
  }

  .title-wall {
    padding-top: 64px;
    padding-bottom: 64px;
  }

  .title-wall h3 {
    max-width: 330px;
    font-size: 38px;
  }

  .title-wall li {
    font-size: 32px;
  }

  .title-wall li:nth-child(4n) {
    padding-left: 0;
  }

  .faces-band {
    padding: 40px 0;
  }

  .faces-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .faces-grid span {
    min-height: 36px;
    padding: 8px 0;
    font-size: 24px;
  }

  .scale-card,
  .scale-stat {
    padding: 40px 24px;
  }

  .scale-cinema .scale-card,
  .scale-cinema .scale-stat {
    padding: 40px 24px;
  }

  .scale-stat strong {
    font-size: 104px;
  }

  .service-grid {
    grid-template-columns: 1fr;
  }

  .capability-board {
    grid-template-columns: 1fr;
  }

  .capability-board article {
    min-height: 320px;
    padding: 24px;
  }

  .capability-board h3 {
    margin-top: 48px;
  }

  .service-card,
  .service-card-feature {
    grid-template-columns: 1fr;
    grid-column: auto;
    min-height: auto;
    gap: 16px;
  }

  .service-card {
    padding: 24px 0;
  }

  .service-card-feature img {
    min-height: 280px;
  }

  .service-card-feature div {
    padding: 24px;
  }

  .service-card h3 {
    max-width: 300px;
    font-size: 32px;
    overflow-wrap: break-word;
  }

  .process-list li {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .process-cinema li {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .process-list strong,
  .process-list p {
    max-width: 320px;
    overflow-wrap: break-word;
  }

  .reel-frame {
    min-height: 520px;
  }

  .reel-frame > div {
    padding: 40px 24px;
  }

  .inquiry-form {
    grid-template-columns: 1fr;
    padding: 24px;
  }

  .inquiry-form-cinematic {
    min-height: 440px;
  }

  .site-footer {
    display: grid;
    padding: 40px 24px;
  }
}

@media (max-width: 420px) {
  .film-title {
    padding-top: 136px;
  }

  .film-title h1 {
    max-width: 320px;
    font-size: clamp(40px, 12vw, 52px);
  }

  .title-wall li {
    font-size: 29px;
  }

  .scale-stat strong {
    font-size: 92px;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition: none !important;
    animation: none !important;
  }
}
