:root {
  --bg: #0b0b0a;
  --panel: #14120f;
  --text: #f1eadf;
  --muted: #a49a8b;
  --line: rgba(241, 234, 223, 0.16);
  --accent: #ff6a2a;
  --accent-2: #d7a658;
  --shadow: rgba(0, 0, 0, 0.55);
  --serif: "Cormorant Garamond", Georgia, serif;
  --display: "Unbounded", "Manrope", sans-serif;
  --sans: "Manrope", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--sans);
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 18% 12%, rgba(255,106,42,.22), transparent 28rem),
    radial-gradient(circle at 82% 30%, rgba(215,166,88,.12), transparent 24rem),
    linear-gradient(115deg, rgba(255,255,255,.035), transparent 44%);
  z-index: -3;
}

a { color: inherit; text-decoration: none; }
img, video { max-width: 100%; display: block; }
button { font: inherit; }

.grain {
  position: fixed;
  inset: 0;
  z-index: 50;
  pointer-events: none;
  opacity: .16;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
}
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 40;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem clamp(1rem, 3vw, 2.5rem);
  color: var(--text);
  background: linear-gradient(to bottom, rgba(11,11,10,.78), rgba(11,11,10,.16), transparent);
  backdrop-filter: blur(10px);
}
.brand { font-family: var(--display); font-weight: 800; letter-spacing: -.065em; font-size: 1.04rem; text-transform: lowercase; }
.brand-mark { color: var(--accent); }
.nav { display: flex; gap: clamp(1rem, 3vw, 2.4rem); font-size: .72rem; text-transform: uppercase; letter-spacing: .18em; font-weight: 800; color: rgba(241,234,223,.82); }
.nav a { transition: color .25s ease; }
.nav a:hover { color: var(--accent); }
.lang-switch { justify-self: end; display: flex; border: 1px solid var(--line); border-radius: 999px; padding: .22rem; background: rgba(11,11,10,.42); }
.lang-switch button {
  border: 0;
  border-radius: 999px;
  padding: .42rem .62rem;
  color: var(--muted);
  background: transparent;
  cursor: pointer;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .08em;
}
.lang-switch button.active { background: var(--text); color: var(--bg); }

.hero {
  min-height: 100svh;
  position: relative;
  display: grid;
  align-items: end;
  padding: 7rem clamp(1rem, 5vw, 5rem) 2.4rem;
  overflow: hidden;
}
.hero-video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .62;
  filter: saturate(.86) contrast(1.12) brightness(.72);
  z-index: -3;
}
.hero-shade {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(11,11,10,.92), rgba(11,11,10,.42) 48%, rgba(11,11,10,.72)),
    linear-gradient(to top, var(--bg) 0%, transparent 38%, rgba(11,11,10,.38));
  z-index: -2;
}
.hero-frame {
  position: absolute;
  inset: 5.6rem clamp(1rem, 3vw, 2.5rem) 1.6rem;
  border: 1px solid var(--line);
  pointer-events: none;
}
.hero-content { max-width: 65rem; position: relative; z-index: 1; }
.eyebrow, .section-kicker {
  margin: 0 0 1rem;
  color: var(--accent-2);
  text-transform: uppercase;
  letter-spacing: .22em;
  font-size: .7rem;
  font-weight: 900;
}
h1, h2, h3, p { margin-top: 0; }
h1 {
  font-family: var(--display);
  font-size: clamp(2.85rem, 8.7vw, 8.7rem);
  line-height: .92;
  letter-spacing: -.075em;
  font-weight: 900;
  text-transform: uppercase;
  margin-bottom: 1.4rem;
}
h1 em {
  display: block;
  font-family: var(--serif);
  font-size: .54em;
  line-height: .98;
  letter-spacing: -.045em;
  text-transform: none;
  color: rgba(241,234,223,.92);
  font-weight: 600;
  font-style: italic;
  text-shadow: 0 0 32px rgba(255,106,42,.14);
}
.hero-copy {
  max-width: 42rem;
  color: rgba(241,234,223,.78);
  font-size: clamp(1rem, 2vw, 1.18rem);
  line-height: 1.75;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-top: 2rem; }
.button {
  appearance: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.2rem;
  padding: .85rem 1.15rem;
  border: 1px solid var(--line);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .74rem;
  font-weight: 900;
  transition: transform .25s ease, background .25s ease, border-color .25s ease;
}
.button:hover { transform: translateY(-2px); border-color: rgba(255,106,42,.6); }
.button.primary { color: #120d09; background: var(--accent); border-color: var(--accent); }
.button.ghost { background: rgba(241,234,223,.05); backdrop-filter: blur(12px); }
.hero-meta {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1rem;
  border-top: 1px solid var(--line);
  margin-top: 4rem;
  padding-top: 1rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-size: .72rem;
}

.marquee {
  overflow: hidden;
  width: 100%;
  border-block: 1px solid var(--line);
  background: rgba(241,234,223,.035);
}
.marquee-track {
  display: flex;
  width: max-content;
  min-width: 100%;
  animation: marquee 28s linear infinite;
  will-change: transform;
}
.marquee-group {
  display: flex;
  flex: 0 0 auto;
  min-width: 100vw;
  justify-content: space-around;
}
.marquee span {
  padding: 1rem clamp(1.2rem, 3vw, 2.5rem);
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: -.04em;
  color: rgba(241,234,223,.86);
  white-space: nowrap;
}
@keyframes marquee { to { transform: translateX(-33.333%); } }

.section { padding: clamp(4rem, 10vw, 9rem) clamp(1rem, 5vw, 5rem); }
.intro { max-width: 86rem; }
.intro p {
  font-family: var(--serif);
  font-size: clamp(2.15rem, 6.2vw, 6rem);
  line-height: 1.02;
  letter-spacing: -.045em;
  font-weight: 600;
  color: var(--text);
}
.section-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(16rem, 28rem);
  gap: 2rem;
  align-items: end;
  margin-bottom: 2rem;
}
h2 {
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: -.07em;
  font-size: clamp(2rem, 5.2vw, 5rem);
  line-height: .98;
  font-weight: 850;
  margin-bottom: 0;
}
.section-head p:last-child { color: var(--muted); line-height: 1.7; }

.work-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: .85rem;
}
.work-card {
  position: relative;
  min-height: 34rem;
  overflow: hidden;
  background: var(--panel);
  border: 1px solid var(--line);
  box-shadow: 0 1.5rem 5rem var(--shadow);
}
.work-card.large { grid-column: span 2; grid-row: span 2; min-height: 48rem; }
.work-card.wide { grid-column: span 2; }
.work-card video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
  opacity: .86;
  filter: saturate(.9) contrast(1.08);
  transition: transform .7s ease, opacity .4s ease;
}
.work-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(11,11,10,.9), transparent 52%);
}
.work-card:hover video { transform: scale(1.045); opacity: 1; }
.work-info {
  position: absolute;
  z-index: 2;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
}
.work-info span { display: block; margin-bottom: .5rem; color: var(--accent-2); font-size: .72rem; text-transform: uppercase; letter-spacing: .13em; font-weight: 900; }
.work-info h3 { font-family: var(--serif); font-size: clamp(1.65rem, 3.4vw, 3.05rem); line-height: .92; letter-spacing: -.045em; font-weight: 700; margin: 0; }

.about {
  display: grid;
  grid-template-columns: minmax(18rem, 31rem) minmax(0, 1fr);
  gap: clamp(2rem, 7vw, 7rem);
  align-items: center;
}
.portrait-card {
  position: relative;
  min-height: 43rem;
  border: 1px solid var(--line);
  overflow: hidden;
  transform: rotate(-1.5deg);
  background: var(--panel);
}
.portrait-card video { width: 100%; height: 100%; object-fit: cover; position: absolute; inset: 0; filter: grayscale(.2) contrast(1.12); }
.portrait-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(0,0,0,.72), transparent); }
.portrait-label { position: absolute; left: 1rem; bottom: 1rem; z-index: 2; text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; color: var(--muted); }
.about-copy p { color: var(--muted); line-height: 1.85; font-size: 1.02rem; }
.about-copy h2 { margin-bottom: 1.5rem; }
.stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: .8rem; margin-top: 2rem; }
.stats div { border-top: 1px solid var(--line); padding-top: 1rem; }
.stats strong { display: block; color: var(--accent); font-family: var(--display); font-size: clamp(1.8rem, 3.4vw, 3rem); letter-spacing: -.075em; }
.stats span { color: var(--muted); font-size: .86rem; }

.service-list { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); }
.service { min-height: 22rem; padding: 1.2rem; border-right: 1px solid var(--line); background: rgba(241,234,223,.025); transition: background .25s ease, transform .25s ease; }
.service:last-child { border-right: 0; }
.service:hover { background: rgba(255,106,42,.08); transform: translateY(-4px); }
.service span { color: var(--accent-2); font-weight: 900; }
.service h3 { margin-top: 5rem; font-family: var(--display); font-size: 1.48rem; letter-spacing: -.055em; text-transform: uppercase; line-height: 1.05; }
.service p { color: var(--muted); line-height: 1.65; }

.process { padding-top: 0; }
.process-line { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--line); }
.process-line div { padding: 1.3rem; border-right: 1px solid var(--line); min-height: 10rem; }
.process-line div:last-child { border-right: 0; }
.process-line span { display: block; font-family: var(--serif); font-size: 2.25rem; margin-bottom: 1.5rem; font-weight: 600; font-style: italic; }
.process-line p { color: var(--muted); margin: 0; }

.contact { padding: clamp(5rem, 12vw, 10rem) clamp(1rem, 5vw, 5rem); }
.contact-inner {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  padding: clamp(1.5rem, 6vw, 5rem);
  background:
    linear-gradient(135deg, rgba(255,106,42,.14), transparent 45%),
    rgba(241,234,223,.035);
}
.contact-inner::after {
  content: "KINOSNIMAEMM";
  position: absolute;
  right: -1rem;
  bottom: -1.8rem;
  font-family: var(--display);
  font-size: clamp(2.5rem, 9vw, 8.5rem);
  letter-spacing: -.08em;
  color: rgba(241,234,223,.035);
}
.contact h2 { max-width: 58rem; margin-bottom: 1.2rem; }
.contact p { color: var(--muted); max-width: 42rem; line-height: 1.75; }
.contact-links { display: flex; flex-wrap: wrap; gap: .7rem; margin-top: 2rem; position: relative; z-index: 2; }
.contact-links a { border: 1px solid var(--line); padding: .8rem 1rem; color: var(--text); background: rgba(11,11,10,.36); }
.contact-links a[aria-disabled="true"] { color: var(--muted); }

.footer { display: flex; justify-content: space-between; gap: 1rem; padding: 1.2rem clamp(1rem, 5vw, 5rem); color: var(--muted); border-top: 1px solid var(--line); font-size: .78rem; }

.reveal { opacity: 0; transform: translateY(28px); transition: opacity .8s ease, transform .8s ease; }
.reveal.visible { opacity: 1; transform: none; }
.delay-1 { transition-delay: .12s; }
.delay-2 { transition-delay: .22s; }
.delay-3 { transition-delay: .32s; }

@media (max-width: 980px) {
  .site-header { grid-template-columns: 1fr auto; }
  .nav { display: none; }
  .section-head, .about { grid-template-columns: 1fr; }
  .work-grid { grid-template-columns: repeat(2, 1fr); }
  .work-card, .work-card.large, .work-card.wide { grid-column: span 1; min-height: 34rem; }
  .service-list, .process-line { grid-template-columns: repeat(2, 1fr); }
  .service:nth-child(2) { border-right: 0; }
  .service { border-bottom: 1px solid var(--line); }
}

@media (max-width: 640px) {
  .site-header { padding: .8rem; }
  .brand { font-size: .92rem; }
  .hero { padding: 6rem 1rem 1.2rem; }
  h1 { font-size: clamp(2.45rem, 14vw, 4.9rem); line-height: .98; }
  .hero-frame { inset: 4.8rem .7rem 1rem; }
  .hero-meta { grid-template-columns: 1fr; }
  .work-grid, .service-list, .process-line, .stats { grid-template-columns: 1fr; }
  .work-card, .work-card.large, .work-card.wide { min-height: 30rem; }
  .portrait-card { min-height: 32rem; }
  .service { min-height: auto; border-right: 0; }
  .service h3 { margin-top: 3rem; }
  .process-line div { border-right: 0; border-bottom: 1px solid var(--line); }
  .footer { flex-direction: column; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; scroll-behavior: auto !important; transition-duration: .01ms !important; }
}

.category-block {
  border-top: 1px solid var(--line);
  padding: clamp(1.6rem, 4vw, 3rem) 0;
}
.category-block:last-child { border-bottom: 1px solid var(--line); }
.category-header {
  display: grid;
  grid-template-columns: 4rem minmax(12rem, 24rem) minmax(0, 32rem);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: start;
  margin-bottom: 1rem;
}
.category-header > span {
  color: var(--accent);
  font-family: var(--display);
  font-size: .92rem;
  letter-spacing: -.04em;
}
.category-header h3 {
  margin: 0;
  font-family: var(--display);
  text-transform: uppercase;
  font-size: clamp(1.4rem, 3vw, 2.55rem);
  line-height: 1;
  letter-spacing: -.065em;
}
.category-header p {
  color: var(--muted);
  line-height: 1.75;
  margin: 0;
}
.portfolio-deck {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .85rem;
}
.portfolio-deck.two { grid-template-columns: 1.15fr .85fr; }
.portfolio-deck.three { grid-template-columns: 1.45fr 1fr 1fr; }
.clip-card {
  position: relative;
  min-height: clamp(24rem, 42vw, 38rem);
  overflow: hidden;
  border: 1px solid var(--line);
  background: #090807;
  box-shadow: 0 1.3rem 4rem var(--shadow);
}
.clip-card.tall { min-height: clamp(33rem, 54vw, 54rem); }
.clip-card.wide { grid-column: span 2; }
.portfolio-deck.three .clip-card.wide { grid-column: span 1; }
.clip-card video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .88;
  filter: saturate(.92) contrast(1.1) brightness(.86);
  transition: transform .7s ease, opacity .35s ease, filter .35s ease;
}
.clip-card::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(to top, rgba(11,11,10,.9), rgba(11,11,10,.15) 45%, transparent),
    linear-gradient(135deg, rgba(255,106,42,.12), transparent 36%);
}
.clip-card:hover video {
  transform: scale(1.045);
  opacity: 1;
  filter: saturate(1.02) contrast(1.14) brightness(.95);
}
.clip-card div {
  position: absolute;
  z-index: 2;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
}
.clip-card span {
  display: block;
  margin-bottom: .48rem;
  color: var(--accent-2);
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: .16em;
  font-weight: 900;
}
.clip-card strong {
  display: block;
  max-width: 15rem;
  font-family: var(--serif);
  color: var(--text);
  font-size: clamp(1.55rem, 2.8vw, 2.75rem);
  line-height: .92;
  letter-spacing: -.045em;
}

@media (max-width: 980px) {
  .category-header { grid-template-columns: 3rem 1fr; }
  .category-header p { grid-column: 2; }
  .portfolio-deck,
  .portfolio-deck.two,
  .portfolio-deck.three { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .clip-card.wide,
  .portfolio-deck.three .clip-card.wide { grid-column: span 2; }
}

@media (max-width: 640px) {
  .category-header { grid-template-columns: 1fr; }
  .category-header p { grid-column: auto; }
  .portfolio-deck,
  .portfolio-deck.two,
  .portfolio-deck.three { grid-template-columns: 1fr; }
  .clip-card,
  .clip-card.tall { min-height: 30rem; }
  .clip-card.wide,
  .portfolio-deck.three .clip-card.wide { grid-column: span 1; }
}

/* Portfolio refinement: structured categories + clear hover-to-play affordance. */
.portfolio-deck.five { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.portfolio-deck.product-deck { grid-template-columns: minmax(18rem, 1.05fr) minmax(12rem, .95fr); }
.portfolio-deck.product-deck .clip-card { min-height: clamp(25rem, 36vw, 36rem); }
.portfolio-deck.ai-deck { grid-template-columns: 1.35fr .85fr; }
.adv-deck .clip-card.wide { grid-column: span 2; }
.category-block {
  position: relative;
}
.category-block::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: clamp(5rem, 16vw, 15rem);
  height: 1px;
  background: linear-gradient(90deg, var(--accent), transparent);
}
.clip-card {
  cursor: pointer;
  isolation: isolate;
}
.clip-card::after {
  content: attr(data-hover);
  position: absolute;
  z-index: 3;
  top: .82rem;
  right: .82rem;
  padding: .44rem .58rem .42rem;
  border: 1px solid rgba(241,234,223,.24);
  border-radius: 999px;
  color: rgba(241,234,223,.76);
  background: rgba(11,11,10,.48);
  backdrop-filter: blur(12px);
  font-size: .58rem;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
  transition: opacity .28s ease, transform .28s ease, background .28s ease, color .28s ease;
}
.clip-card.is-playing::after {
  content: "playing";
  color: #140d08;
  background: var(--accent);
  border-color: var(--accent);
  transform: translateY(-2px);
}
.clip-card.is-playing video {
  opacity: 1;
  filter: saturate(1.05) contrast(1.16) brightness(.98);
}
.clip-card.is-playing div {
  transform: translateY(-.18rem);
}
.clip-card div {
  transition: transform .28s ease;
}
.clip-card div::before {
  content: "";
  display: block;
  width: 2.2rem;
  height: 2px;
  margin-bottom: .8rem;
  background: var(--accent);
  transform-origin: left;
  transform: scaleX(.62);
  transition: transform .28s ease;
}
.clip-card:hover div::before,
.clip-card.is-playing div::before { transform: scaleX(1); }
.category-header h3::selection,
.clip-card strong::selection,
h1::selection,
h2::selection { background: var(--accent); color: #130d08; }

@media (max-width: 1180px) {
  .portfolio-deck.five { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .adv-deck .clip-card.wide { grid-column: span 2; }
}

@media (max-width: 980px) {
  .portfolio-deck.five,
  .portfolio-deck.product-deck,
  .portfolio-deck.ai-deck { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .portfolio-deck.ai-deck .clip-card.wide { grid-column: span 2; }
}

@media (max-width: 640px) {
  .clip-card { cursor: pointer; }
  .portfolio-deck.five,
  .portfolio-deck.product-deck,
  .portfolio-deck.ai-deck { grid-template-columns: 1fr; }
  .portfolio-deck.ai-deck .clip-card.wide,
  .adv-deck .clip-card.wide { grid-column: span 1; }
  .clip-card::after { content: "tap / play"; }
  .clip-card.is-playing::after { content: "playing"; }
}
.portfolio-deck.ai-deck .clip-card.wide { grid-column: span 1; }
@media (max-width: 980px) {
  .portfolio-deck.ai-deck .clip-card.wide { grid-column: span 2; }
}
@media (max-width: 640px) {
  .portfolio-deck.ai-deck .clip-card.wide { grid-column: span 1; }
}

/* Minimal-crop video presentation: keep the full frame visible inside portfolio cards. */
.clip-card {
  background:
    radial-gradient(circle at 50% 38%, rgba(255,106,42,.1), transparent 32rem),
    linear-gradient(145deg, #17130f, #050504 72%);
}
.clip-card video {
  object-fit: contain;
  object-position: center;
  width: calc(100% - 1.2rem);
  height: calc(100% - 1.2rem);
  inset: .6rem;
  border-radius: .12rem;
}
.clip-card::before {
  background:
    linear-gradient(to top, rgba(11,11,10,.92), rgba(11,11,10,.18) 34%, transparent 68%),
    linear-gradient(135deg, rgba(255,106,42,.1), transparent 36%);
}
.clip-card:hover video,
.clip-card.is-playing video {
  transform: scale(1.015);
}
.clip-card.tall video,
.portfolio-deck.five .clip-card video,
.adv-deck .clip-card video {
  object-fit: contain;
}
.clip-card.wide video {
  object-fit: contain;
}
.hero-video {
  object-position: center center;
}

/* Final portfolio framing: vertical 9:16 cards, no ugly inner matte, only a small cinematic crop. */
.clip-card,
.clip-card.tall,
.portfolio-deck.product-deck .clip-card {
  aspect-ratio: 9 / 16;
  min-height: auto;
  background: #080706;
}
.clip-card.wide {
  aspect-ratio: 18 / 16;
}
.portfolio-deck.ai-deck .clip-card.wide,
.portfolio-deck.product-deck .clip-card.wide {
  aspect-ratio: 9 / 16;
}
.clip-card video,
.clip-card.tall video,
.portfolio-deck.five .clip-card video,
.adv-deck .clip-card video,
.clip-card.wide video {
  inset: 0;
  width: 100%;
  height: 100%;
  border-radius: 0;
  object-fit: cover;
  object-position: center center;
  transform: scale(1.035);
}
.clip-card:hover video,
.clip-card.is-playing video {
  transform: scale(1.065);
}
.clip-card::before {
  background:
    linear-gradient(to top, rgba(11,11,10,.9), rgba(11,11,10,.22) 38%, transparent 72%),
    linear-gradient(135deg, rgba(255,106,42,.08), transparent 38%);
}
.portfolio-deck.five {
  align-items: start;
}
.clip-card {
  border-color: rgba(241,234,223,.18);
}

@media (max-width: 980px) {
  .clip-card.wide,
  .portfolio-deck.ai-deck .clip-card.wide,
  .portfolio-deck.product-deck .clip-card.wide {
    aspect-ratio: 9 / 16;
  }
}

/* Client route + rebuilt portfolio rhythm. */
.journey-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: .7rem;
  margin: -1rem 0 clamp(3rem, 7vw, 6rem);
}
.journey-grid a {
  min-height: 12.5rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  border: 1px solid var(--line);
  padding: 1rem;
  background:
    linear-gradient(145deg, rgba(255,106,42,.09), transparent 48%),
    rgba(241,234,223,.028);
  transition: transform .28s ease, border-color .28s ease, background .28s ease;
}
.journey-grid a:hover {
  transform: translateY(-5px);
  border-color: rgba(255,106,42,.58);
  background:
    linear-gradient(145deg, rgba(255,106,42,.18), transparent 54%),
    rgba(241,234,223,.045);
}
.journey-grid span {
  color: var(--accent);
  font-family: var(--display);
  font-size: .74rem;
}
.journey-grid strong {
  display: block;
  margin-top: 2rem;
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: -.06em;
  line-height: 1.02;
  font-size: clamp(1rem, 1.45vw, 1.55rem);
}
.journey-grid em {
  display: block;
  margin-top: .8rem;
  color: var(--muted);
  font-style: normal;
  font-size: .78rem;
  line-height: 1.45;
}

.category-block {
  scroll-margin-top: 6rem;
  padding-block: clamp(2.2rem, 6vw, 5.4rem);
}
.category-header {
  margin-bottom: clamp(1.1rem, 3vw, 2.2rem);
}
.category-header h3 {
  max-width: 10ch;
}
.category-header p {
  max-width: 45rem;
}
.portfolio-deck,
.portfolio-deck.five,
.portfolio-deck.two,
.portfolio-deck.three,
.portfolio-deck.ai-deck,
.portfolio-deck.product-deck {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .82rem;
  align-items: start;
}
.feature-deck,
.barber-deck,
.business-deck {
  grid-template-columns: 1.18fr repeat(3, minmax(0, 1fr));
}
.feature-deck .clip-card.tall,
.barber-deck .clip-card.tall {
  grid-row: span 2;
}
.beauty-deck,
.ai-deck {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.events-deck {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.clip-card,
.clip-card.tall,
.portfolio-deck.product-deck .clip-card,
.portfolio-deck.ai-deck .clip-card.wide,
.portfolio-deck.product-deck .clip-card.wide {
  aspect-ratio: 9 / 16;
  min-height: auto;
  border-color: rgba(241,234,223,.18);
  background: #070605;
}
.clip-card.landscape,
.clip-card.wide.landscape {
  aspect-ratio: 16 / 9;
  grid-column: span 2;
}
.clip-card video,
.clip-card.tall video,
.portfolio-deck.five .clip-card video,
.adv-deck .clip-card video,
.clip-card.wide video,
.clip-card.landscape video {
  inset: 0;
  width: 100%;
  height: 100%;
  border-radius: 0;
  object-fit: cover;
  object-position: center center;
  transform: scale(1.025);
}
.clip-card:hover video,
.clip-card.is-playing video {
  transform: scale(1.055);
}
.clip-card strong {
  max-width: 17rem;
}
.clip-card.landscape strong {
  max-width: 22rem;
}
.clip-card.landscape div {
  max-width: 80%;
}

@media (max-width: 1180px) {
  .journey-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .portfolio-deck,
  .portfolio-deck.five,
  .portfolio-deck.two,
  .portfolio-deck.three,
  .portfolio-deck.ai-deck,
  .portfolio-deck.product-deck,
  .feature-deck,
  .barber-deck,
  .business-deck,
  .events-deck { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .feature-deck .clip-card.tall,
  .barber-deck .clip-card.tall { grid-row: span 1; }
  .clip-card.landscape { grid-column: span 2; }
}

@media (max-width: 820px) {
  .journey-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .portfolio-deck,
  .portfolio-deck.five,
  .portfolio-deck.two,
  .portfolio-deck.three,
  .portfolio-deck.ai-deck,
  .portfolio-deck.product-deck,
  .feature-deck,
  .barber-deck,
  .business-deck,
  .beauty-deck,
  .ai-deck,
  .events-deck { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .clip-card.landscape { grid-column: span 2; }
}

@media (max-width: 640px) {
  .journey-grid,
  .portfolio-deck,
  .portfolio-deck.five,
  .portfolio-deck.two,
  .portfolio-deck.three,
  .portfolio-deck.ai-deck,
  .portfolio-deck.product-deck,
  .feature-deck,
  .barber-deck,
  .business-deck,
  .beauty-deck,
  .ai-deck,
  .events-deck { grid-template-columns: 1fr; }
  .journey-grid a { min-height: 9rem; }
  .clip-card.landscape { grid-column: span 1; aspect-ratio: 9 / 16; }
}
.service-list-six { grid-template-columns: repeat(6, 1fr); }
.service-list-six .service { min-height: 20rem; }
.service-list-six .service h3 { font-size: clamp(1.05rem, 1.45vw, 1.42rem); }
@media (max-width: 1180px) { .service-list-six { grid-template-columns: repeat(3, 1fr); } .service-list-six .service { border-bottom: 1px solid var(--line); } }
@media (max-width: 760px) { .service-list-six { grid-template-columns: 1fr; } .service-list-six .service { border-right: 0; } }

/* Scroll polish: each portfolio chapter feels like a new scene. */
.category-block {
  background:
    linear-gradient(180deg, rgba(241,234,223,.018), transparent 18rem),
    linear-gradient(90deg, rgba(255,106,42,.035), transparent 28rem);
}
.category-block:nth-of-type(even) {
  background:
    linear-gradient(180deg, rgba(241,234,223,.012), transparent 18rem),
    linear-gradient(270deg, rgba(215,166,88,.04), transparent 28rem);
}
.clip-card {
  transition: transform .34s ease, border-color .34s ease, box-shadow .34s ease, opacity .8s ease;
}
.clip-card:hover,
.clip-card.is-playing {
  border-color: rgba(255,106,42,.58);
  box-shadow: 0 1.8rem 5.8rem rgba(0,0,0,.62), 0 0 0 1px rgba(255,106,42,.12) inset;
}
.clip-card.reveal.visible:nth-child(2n) { transition-delay: .08s; }
.clip-card.reveal.visible:nth-child(3n) { transition-delay: .14s; }
.clip-card.reveal.visible:nth-child(4n) { transition-delay: .2s; }

/* Final clean portfolio system: no scattered masonry, just elegant rows. */
.works {
  padding-top: clamp(4rem, 8vw, 7rem);
}
.journey-grid {
  perspective: 1200px;
}
.journey-grid a {
  position: relative;
  overflow: hidden;
}
.journey-grid a::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 3px;
  background: linear-gradient(90deg, var(--accent), var(--accent-2));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .38s ease;
}
.journey-grid a:hover::after { transform: scaleX(1); }
.category-block {
  margin-top: clamp(2rem, 5vw, 4rem);
  padding: clamp(2rem, 5vw, 4.5rem) 0;
  border-top: 1px solid rgba(241,234,223,.16);
}
.category-header {
  grid-template-columns: 4rem minmax(12rem, 27rem) minmax(0, 42rem);
  align-items: end;
}
.category-header > span {
  font-size: 1rem;
  color: var(--accent);
}
.category-header h3 {
  max-width: none;
  font-size: clamp(1.75rem, 3.7vw, 4rem);
}
.category-header p {
  color: rgba(241,234,223,.68);
}
.portfolio-deck,
.portfolio-deck.five,
.portfolio-deck.two,
.portfolio-deck.three,
.portfolio-deck.ai-deck,
.portfolio-deck.product-deck,
.feature-deck,
.barber-deck,
.business-deck,
.beauty-deck,
.events-deck {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  grid-auto-flow: row !important;
  gap: clamp(.75rem, 1.2vw, 1.1rem) !important;
  align-items: stretch !important;
}
.clip-card,
.clip-card.tall,
.portfolio-deck.product-deck .clip-card,
.portfolio-deck.ai-deck .clip-card.wide,
.portfolio-deck.product-deck .clip-card.wide {
  grid-column: auto !important;
  grid-row: auto !important;
  width: 100%;
  aspect-ratio: 9 / 15.8 !important;
  min-height: 0 !important;
  border-radius: 0;
  overflow: hidden;
  transform: translateZ(0);
}
.clip-card.landscape,
.clip-card.wide.landscape {
  grid-column: span 2 !important;
  aspect-ratio: 16 / 9 !important;
}
.clip-card video,
.clip-card.tall video,
.portfolio-deck.five .clip-card video,
.adv-deck .clip-card video,
.clip-card.wide video,
.clip-card.landscape video {
  object-fit: cover;
  object-position: center center;
  transform: scale(1.025);
}
.clip-card:hover video,
.clip-card.is-playing video {
  transform: scale(1.055);
}
.clip-card::before {
  background:
    linear-gradient(to top, rgba(8,7,6,.94), rgba(8,7,6,.48) 27%, rgba(8,7,6,.08) 64%, transparent),
    linear-gradient(145deg, rgba(255,106,42,.09), transparent 42%);
}
.clip-card::after {
  top: .72rem;
  right: .72rem;
}
.clip-card span {
  color: var(--accent-2);
}
.clip-card strong {
  max-width: 19rem;
  font-size: clamp(1.38rem, 2vw, 2.3rem);
}
.clip-card.landscape strong {
  max-width: 25rem;
}
.clip-card.landscape div {
  max-width: none;
}
.category-block:nth-child(odd) .clip-card:nth-child(4n+1) {
  transform: translateY(.35rem);
}
.category-block:nth-child(even) .clip-card:nth-child(4n+3) {
  transform: translateY(.35rem);
}
.category-block .clip-card:hover,
.category-block .clip-card.is-playing {
  transform: translateY(-.35rem);
}
.category-block:nth-child(odd) .clip-card:nth-child(4n+1):hover,
.category-block:nth-child(even) .clip-card:nth-child(4n+3):hover,
.category-block:nth-child(odd) .clip-card:nth-child(4n+1).is-playing,
.category-block:nth-child(even) .clip-card:nth-child(4n+3).is-playing {
  transform: translateY(-.35rem);
}

@media (max-width: 1180px) {
  .portfolio-deck,
  .portfolio-deck.five,
  .portfolio-deck.two,
  .portfolio-deck.three,
  .portfolio-deck.ai-deck,
  .portfolio-deck.product-deck,
  .feature-deck,
  .barber-deck,
  .business-deck,
  .beauty-deck,
  .events-deck {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
  .clip-card.landscape,
  .clip-card.wide.landscape { grid-column: span 2 !important; }
}
@media (max-width: 820px) {
  .category-header { grid-template-columns: 3rem 1fr; }
  .category-header p { grid-column: 2; }
  .portfolio-deck,
  .portfolio-deck.five,
  .portfolio-deck.two,
  .portfolio-deck.three,
  .portfolio-deck.ai-deck,
  .portfolio-deck.product-deck,
  .feature-deck,
  .barber-deck,
  .business-deck,
  .beauty-deck,
  .events-deck {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 640px) {
  .category-header { grid-template-columns: 1fr; }
  .category-header p { grid-column: auto; }
  .portfolio-deck,
  .portfolio-deck.five,
  .portfolio-deck.two,
  .portfolio-deck.three,
  .portfolio-deck.ai-deck,
  .portfolio-deck.product-deck,
  .feature-deck,
  .barber-deck,
  .business-deck,
  .beauty-deck,
  .events-deck {
    grid-template-columns: 1fr !important;
  }
  .clip-card.landscape,
  .clip-card.wide.landscape {
    grid-column: span 1 !important;
    aspect-ratio: 16 / 9 !important;
  }
  .category-block:nth-child(odd) .clip-card:nth-child(4n+1),
  .category-block:nth-child(even) .clip-card:nth-child(4n+3) {
    transform: none;
  }
}

/* More cinematic motion without breaking the clean rows. */
.category-block {
  overflow: clip;
}
.category-block::after {
  content: "";
  position: absolute;
  width: 22rem;
  height: 22rem;
  right: -12rem;
  top: 10%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,106,42,.12), transparent 68%);
  filter: blur(10px);
  opacity: 0;
  transform: translateX(3rem) scale(.9);
  transition: opacity .9s ease, transform .9s ease;
  pointer-events: none;
}
.category-block.visible::after {
  opacity: 1;
  transform: translateX(0) scale(1);
}
.category-header > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.6rem;
  height: 2.6rem;
  border: 1px solid rgba(255,106,42,.42);
  border-radius: 999px;
  background: rgba(255,106,42,.08);
}
.category-header h3 {
  text-wrap: balance;
}
.category-header p {
  text-wrap: pretty;
}
.clip-card {
  clip-path: inset(0 0 0 0);
}
.clip-card.reveal {
  transform: translateY(34px) scale(.985);
}
.clip-card.reveal.visible {
  transform: translateY(0) scale(1);
}
.category-block:nth-child(odd) .clip-card.reveal.visible:nth-child(4n+1),
.category-block:nth-child(even) .clip-card.reveal.visible:nth-child(4n+3) {
  transform: translateY(.35rem) scale(1);
}
.clip-card.reveal.visible:hover,
.clip-card.reveal.visible.is-playing,
.category-block:nth-child(odd) .clip-card.reveal.visible:nth-child(4n+1):hover,
.category-block:nth-child(even) .clip-card.reveal.visible:nth-child(4n+3):hover,
.category-block:nth-child(odd) .clip-card.reveal.visible:nth-child(4n+1).is-playing,
.category-block:nth-child(even) .clip-card.reveal.visible:nth-child(4n+3).is-playing {
  transform: translateY(-.35rem) scale(1);
}
.clip-card video {
  transition: transform .7s cubic-bezier(.2,.8,.2,1), filter .45s ease, opacity .45s ease;
}
.clip-card div {
  transition: transform .38s ease, opacity .38s ease;
}
.clip-card:hover div,
.clip-card.is-playing div {
  transform: translateY(-.28rem);
}
.journey-grid a strong,
.journey-grid a em,
.journey-grid a span {
  position: relative;
  z-index: 2;
}
.journey-grid a::before {
  content: "";
  position: absolute;
  width: 9rem;
  height: 9rem;
  right: -5rem;
  top: -5rem;
  border-radius: 50%;
  background: rgba(255,106,42,.16);
  transform: scale(.4);
  opacity: 0;
  transition: transform .45s ease, opacity .45s ease;
}
.journey-grid a:hover::before {
  transform: scale(1);
  opacity: 1;
}

/* Horizontal videos become cinematic scroll interludes instead of ordinary tiles. */
.cinema-interlude {
  position: relative;
  min-height: clamp(24rem, 62vw, 48rem);
  margin: clamp(2.5rem, 7vw, 6rem) calc(clamp(1rem, 5vw, 5rem) * -1);
  overflow: hidden;
  border-block: 1px solid rgba(241,234,223,.16);
  background: #050504;
  isolation: isolate;
}
.cinema-interlude::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 4;
  pointer-events: none;
  opacity: .2;
  mix-blend-mode: screen;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23g)' opacity='.48'/%3E%3C/svg%3E");
}
.cinema-interlude::after {
  content: "";
  position: absolute;
  inset: 1.1rem;
  z-index: 5;
  border: 1px solid rgba(241,234,223,.18);
  pointer-events: none;
}
.ambient-video,
.ambient-stack {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.ambient-video {
  object-fit: cover;
  object-position: center;
  opacity: .78;
  filter: saturate(.95) contrast(1.12) brightness(.72);
  transform: scale(1.06);
  transition: transform 1.4s cubic-bezier(.2,.8,.2,1), opacity .8s ease, filter .8s ease;
}
.cinema-interlude.visible .ambient-video {
  transform: scale(1.01);
  opacity: .9;
  filter: saturate(1.05) contrast(1.16) brightness(.82);
}
.interlude-overlay {
  position: absolute;
  inset: 0;
  z-index: 2;
  background:
    radial-gradient(circle at 18% 32%, rgba(255,106,42,.18), transparent 32rem),
    linear-gradient(90deg, rgba(5,5,4,.9), rgba(5,5,4,.36) 48%, rgba(5,5,4,.9)),
    linear-gradient(to top, rgba(5,5,4,.92), transparent 44%, rgba(5,5,4,.58));
}
.interlude-copy {
  position: absolute;
  z-index: 6;
  left: clamp(1.5rem, 7vw, 7rem);
  bottom: clamp(1.5rem, 7vw, 6rem);
  width: min(48rem, calc(100% - 3rem));
}
.interlude-copy.align-right {
  left: auto;
  right: clamp(1.5rem, 7vw, 7rem);
  text-align: right;
}
.interlude-copy span {
  display: block;
  margin-bottom: 1rem;
  color: var(--accent-2);
  text-transform: uppercase;
  letter-spacing: .2em;
  font-size: .68rem;
  font-weight: 900;
}
.interlude-copy h3 {
  margin: 0;
  font-family: var(--serif);
  font-size: clamp(2.35rem, 6vw, 6.2rem);
  line-height: .9;
  letter-spacing: -.055em;
  font-weight: 700;
  color: rgba(241,234,223,.96);
  text-shadow: 0 1.5rem 4rem rgba(0,0,0,.75);
}
.ambient-stack {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .65rem;
  padding: clamp(.8rem, 2vw, 1.35rem);
  transform: rotate(-1deg) scale(1.04);
}
.ambient-stack .ambient-video {
  position: relative;
  inset: auto;
  height: 100%;
  min-width: 0;
  border: 1px solid rgba(241,234,223,.14);
  object-fit: cover;
  opacity: .72;
  transform: scale(1.08);
}
.interlude-triptych.visible .ambient-stack .ambient-video:nth-child(1) { transform: scale(1.02) translateY(-.6rem); }
.interlude-triptych.visible .ambient-stack .ambient-video:nth-child(2) { transform: scale(1.02) translateY(.9rem); }
.interlude-triptych.visible .ambient-stack .ambient-video:nth-child(3) { transform: scale(1.02) translateY(-.2rem); }
.thin-interlude {
  min-height: clamp(18rem, 42vw, 34rem);
}
.thin-interlude .interlude-copy h3 {
  font-size: clamp(2rem, 4.8vw, 4.8rem);
}

@media (max-width: 820px) {
  .cinema-interlude { min-height: 28rem; }
  .ambient-stack { grid-template-columns: 1fr; transform: none; }
  .ambient-stack .ambient-video:nth-child(n+2) { display: none; }
  .interlude-copy.align-right { left: clamp(1.5rem, 7vw, 7rem); right: auto; text-align: left; }
}

/* Stronger final conversion block. */
.brief-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .55rem;
  margin: 2rem 0 1.2rem;
  max-width: 48rem;
  position: relative;
  z-index: 2;
}
.brief-strip span {
  border: 1px solid rgba(241,234,223,.16);
  padding: .8rem .75rem;
  color: rgba(241,234,223,.78);
  background: rgba(11,11,10,.28);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .68rem;
  font-weight: 900;
}
.contact-links .contact-main {
  background: var(--accent);
  color: #160d08;
  border-color: var(--accent);
  font-weight: 900;
}
.contact-links a:hover {
  border-color: rgba(255,106,42,.72);
  transform: translateY(-2px);
}
.contact-links a {
  transition: transform .24s ease, border-color .24s ease, background .24s ease;
}
@media (max-width: 640px) {
  .brief-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* Creator-site polish: denser editorial rhythm + fixed cinematic HUD. */
:root {
  --page-progress: 0;
  --scene-progress: 0;
}
.scroll-progress {
  position: fixed;
  z-index: 80;
  left: 0;
  right: 0;
  top: 0;
  height: 3px;
  background: rgba(241,234,223,.08);
  pointer-events: none;
}
.scroll-progress span {
  display: block;
  height: 100%;
  width: 100%;
  transform-origin: left;
  transform: scaleX(var(--page-progress));
  background: linear-gradient(90deg, var(--accent), var(--accent-2), rgba(241,234,223,.88));
  box-shadow: 0 0 26px rgba(255,106,42,.45);
}
.film-hud {
  position: fixed;
  z-index: 45;
  left: clamp(1rem, 2vw, 1.8rem);
  bottom: clamp(1rem, 2vw, 1.6rem);
  display: grid;
  grid-template-columns: auto auto;
  gap: .65rem;
  align-items: center;
  color: rgba(241,234,223,.7);
  pointer-events: none;
  mix-blend-mode: difference;
}
.hud-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  border: 1px solid rgba(241,234,223,.32);
  border-radius: 999px;
  color: var(--accent);
  font-family: var(--display);
  font-size: .68rem;
}
.hud-label {
  max-width: 15rem;
  text-transform: uppercase;
  letter-spacing: .18em;
  font-size: .62rem;
  font-weight: 900;
  line-height: 1.25;
}
.scroll-wordmark {
  position: fixed;
  z-index: -1;
  left: -5vw;
  bottom: 3vh;
  color: rgba(241,234,223,.028);
  font-family: var(--display);
  font-size: clamp(4rem, 18vw, 18rem);
  letter-spacing: -.09em;
  white-space: nowrap;
  pointer-events: none;
  transform: translateX(calc(var(--page-progress) * -18vw));
}
.section {
  padding-top: clamp(3.4rem, 7vw, 6.4rem);
  padding-bottom: clamp(3.4rem, 7vw, 6.4rem);
}
.works {
  padding-top: clamp(3rem, 6vw, 5.2rem);
}
.section-head {
  margin-bottom: clamp(1.2rem, 3vw, 2rem);
}
.journey-grid {
  gap: .55rem;
  margin-bottom: clamp(2.2rem, 5vw, 4.4rem);
}
.journey-grid a {
  min-height: 10.4rem;
  padding: .9rem;
}
.category-block {
  margin-top: clamp(1.4rem, 3.5vw, 3.2rem);
  padding-top: clamp(1.8rem, 4.2vw, 3.8rem);
  padding-bottom: clamp(1.8rem, 4.2vw, 3.8rem);
}
.category-header {
  margin-bottom: clamp(.9rem, 2vw, 1.5rem);
}
.feature-deck,
.barber-deck,
.business-deck {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
}
.beauty-deck,
.ai-deck {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  max-width: min(56rem, 100%);
}
.events-deck {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  max-width: min(56rem, 100%);
}
.clip-card,
.clip-card.tall,
.portfolio-deck.product-deck .clip-card,
.portfolio-deck.ai-deck .clip-card.wide,
.portfolio-deck.product-deck .clip-card.wide {
  aspect-ratio: 9 / 14.65 !important;
}
.clip-card strong {
  font-size: clamp(1.22rem, 1.72vw, 2.05rem);
}
.clip-card span {
  font-size: .6rem;
}
.cinema-interlude {
  margin-top: clamp(1.8rem, 4vw, 3.6rem);
  margin-bottom: clamp(1.8rem, 4vw, 3.6rem);
}
@media (min-width: 1380px) {
  .business-deck { grid-template-columns: repeat(6, minmax(0, 1fr)) !important; }
}
@media (max-width: 1180px) {
  .feature-deck,
  .barber-deck,
  .business-deck { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
}
@media (max-width: 820px) {
  .film-hud { display: none; }
  .feature-deck,
  .barber-deck,
  .business-deck,
  .beauty-deck,
  .ai-deck,
  .events-deck { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}
@media (max-width: 640px) {
  .feature-deck,
  .barber-deck,
  .business-deck,
  .beauty-deck,
  .ai-deck,
  .events-deck { grid-template-columns: 1fr !important; }
}

/* Scroll magic details: parallax interludes, spotlight cards, kinetic reveals. */
.reveal {
  filter: blur(10px);
  transform: translateY(34px) scale(.985);
  transition: opacity .9s cubic-bezier(.2,.8,.2,1), transform .9s cubic-bezier(.2,.8,.2,1), filter .9s ease;
}
.reveal.visible {
  filter: blur(0);
  transform: translateY(0) scale(1);
}
.category-block.visible .category-header h3 {
  animation: chapterPunch .95s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes chapterPunch {
  0% { letter-spacing: -.11em; opacity: .35; transform: translateY(.8rem); }
  100% { letter-spacing: -.065em; opacity: 1; transform: translateY(0); }
}
.clip-card::before {
  background:
    linear-gradient(to top, rgba(8,7,6,.94), rgba(8,7,6,.48) 27%, rgba(8,7,6,.08) 64%, transparent),
    linear-gradient(145deg, rgba(255,106,42,.09), transparent 42%);
}
.clip-card:hover,
.clip-card.is-playing {
  transform: translateY(-.52rem) scale(1.012) !important;
}
.clip-card:hover::after,
.clip-card.is-playing::after {
  letter-spacing: .2em;
}
.cinema-interlude {
  --scene-progress: 0;
}
.cinema-interlude .ambient-video {
  transform: translate3d(0, calc((var(--scene-progress) - .5) * -9rem), 0) scale(1.08);
}
.cinema-interlude.visible .ambient-video {
  transform: translate3d(0, calc((var(--scene-progress) - .5) * -5rem), 0) scale(1.025);
}
.interlude-copy {
  transform: translate3d(0, calc((var(--scene-progress) - .5) * 4rem), 0);
}
.interlude-copy h3 {
  background: linear-gradient(90deg, rgba(241,234,223,1), rgba(215,166,88,.92), rgba(241,234,223,.82));
  -webkit-background-clip: text;
  color: transparent;
}
.interlude-copy span::before {
  content: "";
  display: inline-block;
  width: 2.6rem;
  height: 1px;
  margin-right: .75rem;
  vertical-align: middle;
  background: var(--accent);
  transform: scaleX(calc(.25 + var(--scene-progress) * .75));
  transform-origin: left;
}
.ambient-stack {
  transform: rotate(calc(-1deg + var(--scene-progress) * 2deg)) scale(1.045);
}
.ambient-stack .ambient-video:nth-child(1) { transition-delay: .05s; }
.ambient-stack .ambient-video:nth-child(2) { transition-delay: .14s; }
.ambient-stack .ambient-video:nth-child(3) { transition-delay: .23s; }
.contact-inner {
  box-shadow: 0 2rem 8rem rgba(0,0,0,.42), 0 0 0 1px rgba(255,106,42,.08) inset;
}
@media (prefers-reduced-motion: reduce) {
  .reveal { filter: none; }
  .cinema-interlude .ambient-video,
  .cinema-interlude.visible .ambient-video,
  .interlude-copy { transform: none; }
}

/* Business-card restructure: two clear disciplines, minimal video labels. */
.direction-panel {
  position: relative;
  border-top: 1px solid rgba(241,234,223,.18);
  padding: clamp(2rem, 5vw, 4.6rem) 0;
}
.direction-panel::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 0;
  width: min(22rem, 55vw);
  height: 1px;
  background: linear-gradient(90deg, var(--accent), transparent);
}
.direction-head {
  display: grid;
  grid-template-columns: 4rem minmax(0, 1fr) minmax(12rem, 22rem);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: end;
  margin-bottom: clamp(1.1rem, 3vw, 2rem);
}
.direction-head > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.8rem;
  height: 2.8rem;
  border: 1px solid rgba(255,106,42,.48);
  border-radius: 999px;
  color: var(--accent);
  background: rgba(255,106,42,.08);
  font-family: var(--display);
  font-size: .78rem;
}
.direction-head h3 {
  margin: 0 0 .8rem;
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: -.075em;
  line-height: .95;
  font-size: clamp(2.4rem, 7vw, 7.2rem);
}
.direction-head p {
  max-width: 52rem;
  margin: 0;
  color: rgba(241,234,223,.72);
  line-height: 1.7;
}
.direction-head em {
  color: var(--accent-2);
  font-family: var(--serif);
  font-size: clamp(1.5rem, 2.3vw, 2.4rem);
  line-height: 1;
  text-align: right;
}
.production-chapter {
  display: grid;
  grid-template-columns: minmax(11rem, 18rem) minmax(0, 1fr);
  gap: clamp(1rem, 2vw, 1.4rem);
  align-items: start;
  padding: clamp(1rem, 2.5vw, 1.8rem) 0;
  border-top: 1px solid rgba(241,234,223,.1);
}
.chapter-label {
  position: sticky;
  top: 6.2rem;
}
.chapter-label span {
  display: block;
  color: var(--text);
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: -.06em;
  line-height: 1;
  font-size: clamp(1.15rem, 2vw, 2rem);
}
.chapter-label p {
  margin: .7rem 0 0;
  color: var(--muted);
  font-size: .78rem;
  line-height: 1.45;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.portfolio-row {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: clamp(.55rem, .9vw, .85rem);
  align-items: stretch;
}
.editing-row { grid-template-columns: repeat(6, minmax(0, 1fr)); }
.compact-row { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.beauty-row { grid-template-columns: repeat(2, minmax(0, 16rem)); }
.portfolio-row .clip-card {
  aspect-ratio: 9 / 14.2 !important;
}
.portfolio-row .clip-card div {
  bottom: .8rem;
}
.portfolio-row .clip-card div::before {
  width: 1.4rem;
  margin-bottom: .5rem;
}
.portfolio-row .clip-card span {
  display: inline-flex;
  width: auto;
  padding: .26rem .38rem;
  border: 1px solid rgba(215,166,88,.32);
  background: rgba(8,7,6,.42);
  color: rgba(241,234,223,.86);
  font-size: .55rem;
  letter-spacing: .14em;
}
.portfolio-row .clip-card strong { display: none; }
.direction-panel .cinema-interlude {
  margin-left: 0;
  margin-right: 0;
  min-height: clamp(22rem, 48vw, 38rem);
}
.clean-contact { margin-top: 2rem; }
.brief-strip { display: none; }
@media (max-width: 1180px) {
  .portfolio-row,
  .editing-row { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .compact-row { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 820px) {
  .direction-head { grid-template-columns: 3rem 1fr; }
  .direction-head em { grid-column: 2; text-align: left; }
  .production-chapter { grid-template-columns: 1fr; }
  .chapter-label { position: static; }
  .portfolio-row,
  .editing-row,
  .compact-row,
  .beauty-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .portfolio-row,
  .editing-row,
  .compact-row,
  .beauty-row { grid-template-columns: 1fr; }
  .direction-head { grid-template-columns: 1fr; }
  .direction-head em { grid-column: auto; }
}

/* Hero title hover: local orange text reveal around the pointer. */
.hero-title {
  position: relative;
  width: fit-content;
  max-width: 100%;
  cursor: crosshair;
  isolation: isolate;
  --title-mask-size: clamp(8.5rem, 18vw, 15rem);
}
.about-intro {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(18rem, .58fr);
  align-items: end;
  gap: clamp(1.25rem, 4vw, 4.5rem);
  padding-top: clamp(2.4rem, 5vw, 4.2rem);
  padding-bottom: clamp(2.2rem, 4.5vw, 3.8rem);
}
.about-copy {
  display: grid;
  gap: 1.2rem;
  align-self: center;
}
.about-copy > p {
  max-width: 72rem;
  font-family: var(--serif);
  font-size: clamp(1.85rem, 4.1vw, 4.15rem);
  line-height: 1.02;
  letter-spacing: -.045em;
  font-weight: 600;
  color: rgba(241,234,223,.94);
}
.intro-facts {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .6rem;
  max-width: 78rem;
}
.intro-facts span {
  border-top: 1px solid rgba(241,234,223,.16);
  padding-top: .8rem;
  color: rgba(241,234,223,.66);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .68rem;
  font-weight: 900;
}
.about-portrait {
  position: relative;
  min-height: clamp(28rem, 43vw, 43rem);
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(241,234,223,.16);
  background:
    linear-gradient(135deg, rgba(255,106,42,.16), transparent 42%),
    rgba(241,234,223,.035);
  box-shadow: 0 2.4rem 5rem rgba(0,0,0,.28);
  isolation: isolate;
}
.about-portrait::before {
  content: "";
  position: absolute;
  inset: .72rem;
  border: 1px solid rgba(241,234,223,.13);
  z-index: 2;
  pointer-events: none;
}
.about-portrait::after {
  content: "";
  position: absolute;
  width: 48%;
  height: 42%;
  right: -18%;
  bottom: -14%;
  background: radial-gradient(circle, rgba(255,106,42,.36), transparent 68%);
  filter: blur(18px);
  z-index: 1;
  pointer-events: none;
}
.about-photo-frame {
  position: absolute;
  inset: 0;
  overflow: hidden;
}
.about-photo-frame::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(11,11,10,.08), transparent 38%, rgba(11,11,10,.82)),
    linear-gradient(90deg, rgba(255,106,42,.12), transparent 36%);
}
.about-photo-frame img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 50% 30%;
  filter: saturate(.96) contrast(1.05);
  transform: scale(1.015);
}
.about-portrait figcaption {
  position: absolute;
  left: clamp(1.1rem, 2vw, 1.45rem);
  right: clamp(1.1rem, 2vw, 1.45rem);
  bottom: clamp(1.1rem, 2vw, 1.45rem);
  z-index: 3;
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  padding-top: .8rem;
  border-top: 1px solid rgba(241,234,223,.24);
  text-transform: uppercase;
}
.about-portrait figcaption span {
  color: var(--accent-2);
  font-size: .62rem;
  font-weight: 900;
  letter-spacing: .16em;
}
.about-portrait figcaption strong {
  max-width: 11rem;
  color: rgba(241,234,223,.88);
  font-family: var(--display);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .12em;
  line-height: 1.35;
  text-align: right;
}
@media (max-width: 760px) {
  .about-intro {
    grid-template-columns: 1fr;
    padding-top: 2.25rem;
    padding-bottom: 2.5rem;
  }
  .about-copy > p {
    font-size: clamp(1.9rem, 8.4vw, 2.55rem);
    line-height: 1.04;
  }
  .about-portrait {
    min-height: clamp(30rem, 132vw, 38rem);
    order: -1;
  }
  .about-portrait figcaption {
    align-items: flex-start;
    flex-direction: column;
  }
  .about-portrait figcaption strong {
    text-align: left;
  }
  .intro-facts { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px) {
  .intro-facts { grid-template-columns: 1fr; }
}

.hero-title > span,
.hero-title > em {
  position: relative;
  z-index: 1;
  transition: text-shadow .28s ease;
}
.hero-title > span {
  display: block;
}
.title-base {
  position: relative;
  z-index: 1;
}
.hero-title:hover > span,
.hero-title:hover > em {
  text-shadow:
    0 0 18px rgba(255,106,42,.18),
    0 0 42px rgba(255,106,42,.10);
}
.title-base,
.title-accent {
  display: block;
}
.title-accent {
  position: absolute;
  inset: 0;
  z-index: 2;
  color: #ff7436;
  opacity: 0;
  pointer-events: none;
  transform: translateZ(0);
  text-shadow:
    0 0 8px rgba(255,116,54,.28),
    0 0 26px rgba(255,106,42,.18);
  -webkit-mask-image: radial-gradient(circle var(--title-mask-size) at var(--title-local-x, 50%) var(--title-local-y, 50%), #000 0 30%, rgba(0,0,0,.66) 48%, transparent 72%);
  mask-image: radial-gradient(circle var(--title-mask-size) at var(--title-local-x, 50%) var(--title-local-y, 50%), #000 0 30%, rgba(0,0,0,.66) 48%, transparent 72%);
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: 100% 100%;
  mask-size: 100% 100%;
  transition: opacity .18s ease;
}
.hero-title:hover .title-accent {
  opacity: 1;
}

.trust-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  border-bottom: 1px solid rgba(241,234,223,.14);
  background: rgba(241,234,223,.035);
}
.trust-strip div {
  position: relative;
  min-height: 9.5rem;
  padding: clamp(1.1rem, 2.4vw, 2rem);
  border-right: 1px solid rgba(241,234,223,.12);
  background:
    linear-gradient(135deg, rgba(255,106,42,.08), transparent 44%),
    rgba(11,11,10,.16);
}
.trust-strip div::after {
  content: "";
  position: absolute;
  left: clamp(1.1rem, 2.4vw, 2rem);
  right: clamp(1.1rem, 2.4vw, 2rem);
  bottom: 1.2rem;
  height: 1px;
  background: linear-gradient(90deg, rgba(255,106,42,.55), transparent);
  opacity: .42;
}
.trust-strip div:last-child {
  border-right: 0;
}
.trust-strip span,
.path-steps span {
  display: block;
  color: var(--accent-2);
  font-size: .62rem;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.trust-strip strong {
  display: block;
  max-width: 18rem;
  margin: 1rem 0 .55rem;
  font-family: var(--display);
  font-size: clamp(1.05rem, 1.55vw, 1.42rem);
  font-weight: 850;
  letter-spacing: -.06em;
  line-height: 1.04;
  text-transform: uppercase;
}
.trust-strip p {
  margin: 0;
  max-width: 20rem;
  color: rgba(241,234,223,.70);
  font-size: clamp(.82rem, .92vw, .92rem);
  line-height: 1.5;
}

/* Client-first portfolio pass: selected works, cleaner proof, accessible viewing. */
body.modal-open {
  overflow: hidden;
}
body.modal-open .quick-contact {
  opacity: 0;
  pointer-events: none;
  transform: translateY(8px);
}

.quick-contact {
  position: fixed;
  right: clamp(1rem, 2vw, 1.6rem);
  bottom: clamp(1rem, 2vw, 1.4rem);
  z-index: 60;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.8rem;
  padding: .72rem 1rem;
  border: 1px solid rgba(255,106,42,.55);
  background: rgba(255,106,42,.88);
  color: #120d09;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  box-shadow: 0 18px 52px rgba(255,106,42,.22);
  transition: opacity .24s ease, transform .24s ease, background .24s ease;
}
.quick-contact:hover {
  transform: translateY(-2px);
  background: #ff7436;
}

.hero-proof {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin-top: 1.2rem;
  max-width: 44rem;
}
.hero-proof span {
  border: 1px solid rgba(241,234,223,.16);
  background: rgba(11,11,10,.42);
  padding: .52rem .72rem;
  color: rgba(241,234,223,.76);
  font-size: .66rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.selected-works {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: clamp(.55rem, 1vw, .9rem);
  margin: clamp(2rem, 4vw, 4rem) 0 clamp(1.4rem, 3vw, 3rem);
}
.work-filters {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: clamp(1.2rem, 2vw, 1.8rem);
}
.work-filters button {
  min-height: 2.35rem;
  border: 1px solid rgba(241,234,223,.14);
  background: rgba(241,234,223,.045);
  color: rgba(241,234,223,.68);
  padding: .58rem .82rem;
  cursor: pointer;
  font-size: .62rem;
  font-weight: 900;
  letter-spacing: .12em;
  line-height: 1;
  text-transform: uppercase;
  transition: color .22s ease, border-color .22s ease, background .22s ease, transform .22s ease;
}
.work-filters button:hover,
.work-filters button.active {
  border-color: rgba(255,106,42,.64);
  background: rgba(255,106,42,.14);
  color: var(--text);
}
.work-filters button:hover {
  transform: translateY(-1px);
}
.selected-works .feature-card {
  grid-column: span 2;
  min-height: clamp(28rem, 42vw, 42rem);
}
.selected-works .feature-card:first-child,
.selected-works .feature-card:nth-child(2) {
  grid-column: span 3;
  min-height: clamp(34rem, 48vw, 50rem);
}
.feature-card::after,
.clip-card::after {
  content: attr(data-hover);
}
.clip-card {
  outline: none;
}
.clip-card[hidden] {
  display: none;
}
.clip-card:focus-visible {
  border-color: rgba(255,106,42,.86);
  box-shadow: 0 0 0 3px rgba(255,106,42,.22), 0 24px 70px rgba(0,0,0,.42);
}
.clip-card div {
  gap: .35rem;
}
.clip-card strong,
.portfolio-row .clip-card strong {
  display: block;
  max-width: 15rem;
  color: rgba(241,234,223,.62);
  font-family: var(--sans);
  font-size: .62rem;
  font-weight: 800;
  letter-spacing: .12em;
  line-height: 1.35;
  text-transform: uppercase;
}
.portfolio-row .clip-card div {
  min-height: 5.1rem;
}

.portfolio-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin: 0 0 clamp(2.4rem, 5vw, 5rem);
  padding: 1rem 0;
  border-block: 1px solid rgba(241,234,223,.16);
  color: rgba(241,234,223,.72);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.portfolio-cta a {
  color: var(--accent);
}

.works {
  padding-top: clamp(3.2rem, 7vw, 6rem);
}
.about-intro {
  border-top: 1px solid rgba(241,234,223,.14);
}
.cinema-interlude {
  min-height: clamp(24rem, 54vw, 38rem);
}
.direction-panel .cinema-interlude {
  margin-block: clamp(2.5rem, 5vw, 4rem);
}
.scroll-wordmark {
  opacity: .08;
}

.client-path {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 36rem);
  gap: clamp(1.2rem, 4vw, 4rem);
  padding: clamp(2.8rem, 6vw, 5rem) clamp(1rem, 5vw, 5rem);
  border-top: 1px solid rgba(241,234,223,.14);
  border-bottom: 1px solid rgba(241,234,223,.14);
  background:
    linear-gradient(90deg, rgba(255,106,42,.08), transparent 48%),
    rgba(241,234,223,.025);
}
.client-path-copy h2 {
  max-width: 58rem;
}
.client-path-copy p:last-child {
  max-width: 42rem;
  color: rgba(241,234,223,.66);
  line-height: 1.75;
}
.path-steps {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  border: 1px solid rgba(241,234,223,.14);
}
.path-steps div {
  min-height: 8.8rem;
  padding: 1rem;
  border-right: 1px solid rgba(241,234,223,.12);
  border-bottom: 1px solid rgba(241,234,223,.12);
  background: rgba(11,11,10,.24);
}
.path-steps div:nth-child(2n) {
  border-right: 0;
}
.path-steps div:nth-last-child(-n+2) {
  border-bottom: 0;
}
.path-steps strong {
  display: block;
  margin: 1.15rem 0 .4rem;
  font-family: var(--display);
  font-size: 1.05rem;
  letter-spacing: -.045em;
  text-transform: uppercase;
}
.path-steps p {
  margin: 0;
  color: rgba(241,234,223,.62);
  font-size: .78rem;
  line-height: 1.55;
}
.availability-line {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .6rem;
}
.availability-line span {
  border-top: 1px solid rgba(255,106,42,.42);
  padding-top: .75rem;
  color: rgba(241,234,223,.72);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.video-modal {
  width: min(94vw, 82rem);
  max-width: 82rem;
  padding: 0;
  border: 1px solid rgba(241,234,223,.18);
  background: rgba(8,8,7,.96);
  color: var(--text);
  box-shadow: 0 30px 120px rgba(0,0,0,.76);
  overflow: hidden;
}
.video-modal::backdrop {
  background: rgba(3,3,3,.78);
  backdrop-filter: blur(14px);
}
.modal-close {
  position: absolute;
  top: .8rem;
  right: .8rem;
  z-index: 3;
  width: 2.4rem;
  height: 2.4rem;
  border: 1px solid rgba(241,234,223,.2);
  border-radius: 50%;
  background: rgba(11,11,10,.72);
  color: var(--text);
  cursor: pointer;
  font-size: 1.3rem;
  line-height: 1;
}
.modal-topline {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  padding: .82rem 4rem .82rem 1rem;
  border-bottom: 1px solid rgba(241,234,223,.12);
  color: rgba(241,234,223,.62);
  font-size: .62rem;
  font-weight: 900;
  letter-spacing: .15em;
  text-transform: uppercase;
}
.modal-sound {
  color: var(--accent-2);
}
.modal-frame {
  position: relative;
  background: #050504;
}
.modal-video {
  display: block;
  width: 100%;
  max-height: 76vh;
  background: #050504;
}
.modal-caption {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .4rem 1rem;
  align-items: end;
  padding: 1rem clamp(1rem, 2vw, 1.4rem) 1.15rem;
  border-top: 1px solid rgba(241,234,223,.12);
}
.modal-nav {
  position: absolute;
  top: 50%;
  z-index: 4;
  min-width: 4.3rem;
  min-height: 2.35rem;
  border: 1px solid rgba(241,234,223,.18);
  background: rgba(11,11,10,.64);
  color: rgba(241,234,223,.82);
  cursor: pointer;
  font-size: .62rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  transform: translateY(-50%);
  transition: background .2s ease, border-color .2s ease, color .2s ease;
}
.modal-nav:hover {
  border-color: rgba(255,106,42,.72);
  background: rgba(255,106,42,.86);
  color: #120d09;
}
.modal-prev {
  left: .8rem;
}
.modal-next {
  right: .8rem;
}
.modal-cta {
  justify-self: end;
  align-self: center;
  border: 1px solid rgba(255,106,42,.48);
  background: rgba(255,106,42,.12);
  color: var(--accent);
  padding: .68rem .78rem;
  font-size: .62rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  transition: background .22s ease, color .22s ease;
}
.modal-cta:hover {
  background: var(--accent);
  color: #120d09;
}
.modal-end-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .9rem clamp(1rem, 2vw, 1.4rem) 1rem;
  border-top: 1px solid rgba(241,234,223,.12);
  background: rgba(255,106,42,.08);
  color: rgba(241,234,223,.82);
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.modal-end-cta[hidden] {
  display: none;
}
.modal-end-cta a {
  color: var(--accent);
}
.modal-kicker {
  grid-column: 1 / -1;
  color: var(--accent);
  font-size: .62rem;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.modal-caption h3 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(1.2rem, 2.4vw, 2.2rem);
  letter-spacing: -.055em;
  line-height: 1;
  text-transform: uppercase;
}
.modal-caption p {
  margin: 0;
  max-width: 30rem;
  color: rgba(241,234,223,.62);
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .12em;
  line-height: 1.35;
  text-align: right;
  text-transform: uppercase;
}

@media (max-width: 1020px) {
  .trust-strip {
    grid-template-columns: 1fr;
  }
  .trust-strip div {
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid rgba(241,234,223,.12);
  }
  .trust-strip div:last-child {
    border-bottom: 0;
  }
  .selected-works { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .selected-works .feature-card,
  .selected-works .feature-card:first-child,
  .selected-works .feature-card:nth-child(2) {
    grid-column: span 1;
    min-height: clamp(28rem, 68vw, 40rem);
  }
  .client-path {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  h1 {
    font-size: clamp(2.35rem, 10.8vw, 2.9rem);
    letter-spacing: -.055em;
  }
  .quick-contact {
    right: .85rem;
    bottom: max(.75rem, env(safe-area-inset-bottom));
    width: 3.1rem;
    height: 3.1rem;
    min-height: 3.1rem;
    padding: 0;
    border-radius: 50%;
    font-size: 0;
    letter-spacing: 0;
  }
  .quick-contact::before {
    content: "TG";
    font-size: .7rem;
    font-weight: 900;
    letter-spacing: .08em;
  }
  .film-hud {
    display: none;
  }
  .hero-proof span {
    flex: 1 1 100%;
  }
  .selected-works {
    grid-template-columns: 1fr;
  }
  .selected-works .feature-card,
  .selected-works .feature-card:first-child,
  .selected-works .feature-card:nth-child(2) {
    min-height: 30rem;
  }
  .portfolio-cta {
    align-items: flex-start;
    flex-direction: column;
  }
  .path-steps,
  .availability-line {
    grid-template-columns: 1fr;
  }
  .path-steps div,
  .path-steps div:nth-child(2n),
  .path-steps div:nth-last-child(-n+2) {
    border-right: 0;
    border-bottom: 1px solid rgba(241,234,223,.12);
  }
  .path-steps div:last-child {
    border-bottom: 0;
  }
  .work-filters {
    flex-wrap: nowrap;
    margin-inline: -1rem;
    overflow-x: auto;
    padding: 0 1rem .25rem;
    scrollbar-width: none;
  }
  .work-filters::-webkit-scrollbar {
    display: none;
  }
  .work-filters button {
    flex: 0 0 auto;
  }
  .clip-card::after,
  .feature-card::after {
    content: "tap / sound";
  }
  .video-modal {
    width: 100vw;
    max-width: 100vw;
    height: 100dvh;
    max-height: 100dvh;
    margin: 0;
    border: 0;
  }
  .modal-close {
    top: max(.6rem, env(safe-area-inset-top));
    right: .75rem;
  }
  .modal-topline {
    padding-top: max(.85rem, env(safe-area-inset-top));
    padding-right: 3.6rem;
  }
  .modal-video {
    max-height: 68dvh;
  }
  .modal-nav {
    top: auto;
    bottom: .7rem;
    min-width: 3.8rem;
    min-height: 2.1rem;
    transform: none;
  }
  .modal-prev {
    left: .7rem;
  }
  .modal-next {
    right: .7rem;
  }
  .modal-caption {
    grid-template-columns: 1fr;
  }
  .modal-caption p {
    text-align: left;
  }
  .modal-cta {
    justify-self: start;
  }
  .modal-end-cta {
    align-items: flex-start;
    flex-direction: column;
  }
  .footer {
    padding-bottom: 5rem;
  }
}

/* Final layer cleanup: keep motion crisp so work is readable immediately. */
.reveal,
.clip-card.reveal {
  filter: none !important;
  transform: translateY(18px);
  transition:
    opacity .48s cubic-bezier(.2,.8,.2,1),
    transform .48s cubic-bezier(.2,.8,.2,1);
}
.reveal.visible,
.clip-card.reveal.visible {
  filter: none !important;
  transform: translateY(0);
}
