/* =====================================================================
   OZO WEDDING - DESIGN 1 · "CINEMATIC NOIR"
   A24 title-sequence energy for a luxury wedding film studio.
   Accent: champagne gold #c9a96a.  Type: Cormorant Garamond / Space Mono / Archivo.
   ===================================================================== */

/* ---------- TOKENS ---------- */
:root {
  --black:       #0a0a0b;
  --black-2:     #111113;
  --black-3:     #16161a;
  --ink:         #1c1c20;
  --film-white:  #f4efe6;   /* warm film-grain white */
  --muted:       #9a958c;
  --muted-2:     #6c6962;
  --gold:        #c9a96a;
  --gold-bright: #e3c98e;
  --gold-deep:   #8c7240;
  --line:        rgba(201,169,106,0.16);
  --line-soft:   rgba(244,239,230,0.08);

  --serif: "Cormorant Garamond", "Cormorant", Georgia, serif;
  --mono:  "Space Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
  --ui:    "Archivo", "Inter", system-ui, sans-serif;

  --maxw: 1480px;
  --gutter: clamp(20px, 5vw, 96px);
  --header-h: 84px;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-io: cubic-bezier(0.65, 0.05, 0.36, 1);
}

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

/* --- Lenis smooth-scroll resets (only active when Lenis attaches html.lenis) --- */
html.lenis, html.lenis body { height: auto; }
html.lenis { scroll-behavior: auto !important; } /* let Lenis own the scroll, no native fight */
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: hidden; }
.lenis.lenis-smooth iframe { pointer-events: none; }

body {
  margin: 0;
  background: var(--black);
  color: var(--film-white);
  font-family: var(--ui);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  /* `clip` prevents horizontal overflow WITHOUT turning body into a scroll
     container (which `hidden` does by forcing overflow-y:auto, breaking Lenis). */
  overflow-x: clip;
}
img, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
ul { list-style: none; margin: 0; padding: 0; }
h1, h2, h3, h4, p { margin: 0; }
:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }
::selection { background: var(--gold); color: var(--black); }

/* ---------- FILM GRAIN + VIGNETTE OVERLAY ---------- */
.grain {
  position: fixed; inset: 0; z-index: 9000; pointer-events: none;
  opacity: 0.05; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation: grainShift 0.6s steps(2) infinite;
}
.vignette {
  position: fixed; inset: 0; z-index: 8999; pointer-events: none;
  box-shadow: inset 0 0 220px 60px rgba(0,0,0,0.55);
}
@keyframes grainShift {
  0%{transform:translate(0,0)} 50%{transform:translate(-4%,3%)} 100%{transform:translate(3%,-2%)}
}
@media (prefers-reduced-motion: reduce) { .grain { animation: none; } }

/* ---------- CUSTOM CURSOR ---------- */
.cursor, .cursor-dot { display: none; }
@media (hover: hover) and (pointer: fine) {
  body.has-cursor { cursor: none; }
  body.has-cursor a, body.has-cursor button { cursor: none; }
  .cursor {
    display: block; position: fixed; top: 0; left: 0; z-index: 9500;
    width: 44px; height: 44px; margin: -22px 0 0 -22px; border-radius: 50%;
    border: 1px solid var(--gold); pointer-events: none;
    transition: width .35s var(--ease), height .35s var(--ease), margin .35s var(--ease), border-color .35s, background-color .35s;
    mix-blend-mode: difference;
  }
  .cursor-dot {
    display: block; position: fixed; top: 0; left: 0; z-index: 9501;
    width: 5px; height: 5px; margin: -2.5px 0 0 -2.5px; border-radius: 50%;
    background: var(--gold-bright); pointer-events: none;
  }
  .cursor.is-hover { width: 70px; height: 70px; margin: -35px 0 0 -35px; background: rgba(201,169,106,0.12); }
  .cursor.is-media {
    width: 92px; height: 92px; margin: -46px 0 0 -46px; background: rgba(201,169,106,0.16);
  }
  .cursor.is-media::after { content: "VIEW"; font-family: var(--mono); font-size: 10px; letter-spacing: .18em; color: var(--gold-bright); }
}

/* ---------- LAYOUT ---------- */
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }
.section { position: relative; padding: clamp(80px, 12vh, 160px) 0; }
.section--tight { padding: clamp(56px, 8vh, 110px) 0; }

/* ---------- TYPOGRAPHY UTILS ---------- */
.display {
  font-family: var(--serif); font-weight: 500; line-height: 0.92;
  letter-spacing: -0.01em; color: var(--film-white);
}
.display--xl { font-size: clamp(3.4rem, 12vw, 11rem); }
.display--lg { font-size: clamp(2.8rem, 8vw, 6.5rem); }
.display--md { font-size: clamp(2.2rem, 5vw, 4rem); }
.italic { font-style: italic; }
.gold { color: var(--gold); }
.gold-grad {
  background: linear-gradient(100deg, var(--gold-deep), var(--gold-bright) 45%, var(--gold) 80%);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent;
}

.eyebrow {
  font-family: var(--mono); font-size: clamp(0.62rem, 1vw, 0.74rem);
  letter-spacing: 0.36em; text-transform: uppercase; color: var(--gold);
  display: inline-flex; align-items: center; gap: 12px;
}
.eyebrow::before {
  content: ""; width: 34px; height: 1px; background: var(--gold); opacity: 0.6;
}
.eyebrow--center { justify-content: center; }
.lede {
  font-family: var(--serif); font-weight: 300; font-style: italic;
  font-size: clamp(1.3rem, 2.6vw, 2rem); line-height: 1.5; color: var(--muted);
}
.body { color: var(--muted); font-size: clamp(0.98rem, 1.4vw, 1.08rem); line-height: 1.8; max-width: 56ch; }

.timecode {
  font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.18em;
  color: var(--muted-2); text-transform: uppercase;
}

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase;
  padding: 18px 30px; border: 1px solid var(--line); color: var(--film-white);
  position: relative; overflow: hidden; transition: color .5s var(--ease), border-color .5s;
  background: transparent;
}
.btn .btn__arrow { transition: transform .5s var(--ease); }
.btn::before {
  content: ""; position: absolute; inset: 0; background: var(--gold);
  transform: translateY(101%); transition: transform .55s var(--ease); z-index: -1;
}
.btn:hover { color: var(--black); border-color: var(--gold); }
.btn:hover::before { transform: translateY(0); }
.btn:hover .btn__arrow { transform: translateX(6px); }
.btn--solid { background: var(--gold); color: var(--black); border-color: var(--gold); }
.btn--solid::before { background: var(--film-white); }
.btn--solid:hover { color: var(--black); }
.btn--ghost { border-color: var(--line-soft); }

.link-underline {
  font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.2em; text-transform: uppercase;
  position: relative; padding-bottom: 4px; color: var(--gold);
}
.link-underline::after {
  content: ""; position: absolute; left: 0; bottom: 0; width: 100%; height: 1px;
  background: var(--gold); transform: scaleX(0.18); transform-origin: left; transition: transform .5s var(--ease);
}
.link-underline:hover::after { transform: scaleX(1); }

/* =====================================================================
   HEADER / NAV
   ===================================================================== */
.header {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000; height: var(--header-h);
  display: flex; align-items: center;
  transition: transform .5s var(--ease), background-color .5s, backdrop-filter .5s, border-color .5s;
  border-bottom: 1px solid transparent;
}
.header.scrolled {
  background: rgba(10,10,11,0.72); backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--line-soft);
}
.header.hidden { transform: translateY(-100%); }
.header__inner { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter);
  display: flex; align-items: center; justify-content: space-between; }

.brand { display: flex; align-items: center; gap: 14px; }
.brand__logo { height: 30px; width: auto; filter: drop-shadow(0 2px 8px rgba(0,0,0,.5)); }
.brand__name {
  font-family: var(--serif); font-size: 1.35rem; letter-spacing: 0.06em; line-height: 1;
}
.brand__rec {
  display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono);
  font-size: 0.56rem; letter-spacing: 0.2em; color: var(--muted-2); margin-left: 4px;
}
.brand__rec .dot { width: 7px; height: 7px; border-radius: 50%; background: #d4453d; animation: rec 1.4s ease-in-out infinite; }
@keyframes rec { 0%,100%{opacity:1} 50%{opacity:.25} }
@media (prefers-reduced-motion: reduce){ .brand__rec .dot{animation:none} }

.nav { display: flex; align-items: center; gap: 38px; }
.nav__list { display: flex; gap: 34px; align-items: center; }
.nav__link {
  font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--muted); position: relative; padding: 6px 0; transition: color .4s;
}
.nav__link::before {
  content: counter(navc, decimal-leading-zero) " "; counter-increment: navc;
  color: var(--gold-deep); margin-right: 6px; font-size: 0.62rem;
}
.nav__list { counter-reset: navc; }
.nav__link::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 1px; width: 100%;
  background: var(--gold); transform: scaleX(0); transform-origin: right; transition: transform .45s var(--ease);
}
.nav__link:hover { color: var(--film-white); }
.nav__link:hover::after { transform: scaleX(1); transform-origin: left; }
.nav__link[aria-current="page"] { color: var(--gold); }
.nav__link[aria-current="page"]::after { transform: scaleX(1); }

.nav__cta { display: inline-flex; }

.burger { display: none; width: 44px; height: 44px; position: relative; z-index: 1100; }
.burger span { position: absolute; left: 10px; right: 10px; height: 1.5px; background: var(--film-white); transition: transform .45s var(--ease), opacity .3s; }
.burger span:nth-child(1){ top: 16px; } .burger span:nth-child(2){ top: 22px; } .burger span:nth-child(3){ top: 28px; }
.burger.open span:nth-child(1){ transform: translateY(6px) rotate(45deg); }
.burger.open span:nth-child(2){ opacity: 0; }
.burger.open span:nth-child(3){ transform: translateY(-6px) rotate(-45deg); }

/* Mobile menu overlay */
.mobile-menu {
  position: fixed; inset: 0; z-index: 1050; background: var(--black);
  display: flex; flex-direction: column; justify-content: center; padding: var(--gutter);
  transform: translateY(-100%); transition: transform .6s var(--ease); visibility: hidden;
}
.mobile-menu.open { transform: translateY(0); visibility: visible; }
.mobile-menu__list { display: flex; flex-direction: column; gap: 4px; }
.mobile-menu__link {
  font-family: var(--serif); font-size: clamp(2.6rem, 12vw, 4.5rem); line-height: 1.1; color: var(--film-white);
  display: flex; align-items: baseline; gap: 16px;
}
.mobile-menu__link .num { font-family: var(--mono); font-size: 0.8rem; color: var(--gold); letter-spacing: .1em; }
.mobile-menu__link[aria-current="page"] { color: var(--gold); font-style: italic; }
.mobile-menu__foot { margin-top: auto; padding-top: 40px; display: flex; gap: 24px; flex-wrap: wrap; }

/* =====================================================================
   HERO (home)
   ===================================================================== */
.hero { position: relative; height: 100svh; min-height: 640px; overflow: hidden; }
.hero__media { position: absolute; inset: 0; }
.hero__media video, .hero__media img {
  width: 100%; height: 100%; object-fit: cover; object-position: center 30%;
  filter: saturate(0.86) contrast(1.04) brightness(0.62);
  transform: scale(1.08);
}
.hero__scrim {
  position: absolute; inset: 0;
  background:
    radial-gradient(120% 90% at 50% 25%, transparent 35%, rgba(10,10,11,0.55) 100%),
    linear-gradient(180deg, rgba(10,10,11,0.55) 0%, transparent 28%, transparent 55%, rgba(10,10,11,0.92) 100%);
}
/* Letterbox bars that animate open */
.letterbox { position: absolute; left: 0; right: 0; background: var(--black); z-index: 5; pointer-events: none; }
.letterbox--top { top: 0; height: 50%; }
.letterbox--bottom { bottom: 0; height: 50%; }
.hero.loaded .letterbox--top { transform: translateY(-100%); transition: transform 1.4s var(--ease-io) .25s; }
.hero.loaded .letterbox--bottom { transform: translateY(100%); transition: transform 1.4s var(--ease-io) .25s; }
/* keep thin cinematic bars after open */
.bar { position: absolute; left: 0; right: 0; height: clamp(28px, 6vh, 64px); background: var(--black); z-index: 6; pointer-events: none; }
.bar--top { top: 0; } .bar--bottom { bottom: 0; }
.bar__hud {
  position: absolute; display: flex; align-items: center; gap: 14px;
  font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.2em; color: var(--muted-2); text-transform: uppercase;
}
.bar--top .bar__hud { top: 50%; transform: translateY(-50%); left: var(--gutter); }
.bar--top .bar__hud.right { left: auto; right: var(--gutter); }
.bar--bottom .bar__hud { bottom: 50%; transform: translateY(50%); left: var(--gutter); }
.bar--bottom .bar__hud.right { left: auto; right: var(--gutter); }

.hero__content {
  position: absolute; inset: 0; z-index: 7; display: flex; flex-direction: column; justify-content: center;
}
.hero__content .wrap { width: 100%; }
.hero__kicker { margin-bottom: 26px; }
.hero__title { max-width: 16ch; }
.hero__title .line { display: block; overflow: hidden; }
.hero__title .line > span { display: block; }
.hero__sub {
  margin-top: 30px; max-width: 46ch;
  font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(1.15rem, 2.2vw, 1.7rem); color: var(--muted); line-height: 1.5;
}
.hero__actions { margin-top: 44px; display: flex; gap: 18px; flex-wrap: wrap; }

.hero__scrollcue {
  position: absolute; bottom: calc(clamp(28px, 6vh, 64px) + 24px); left: 50%; transform: translateX(-50%); z-index: 7;
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.28em; color: var(--muted-2); text-transform: uppercase;
}
.hero__scrollcue .rail { width: 1px; height: 54px; background: var(--line-soft); overflow: hidden; position: relative; }
.hero__scrollcue .rail::after { content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background: var(--gold); animation: scrollRail 2.2s var(--ease-io) infinite; }
@keyframes scrollRail { 0%{transform:translateY(-100%)} 60%,100%{transform:translateY(300%)} }
@media (prefers-reduced-motion: reduce){ .hero__scrollcue .rail::after{animation:none} }

/* =====================================================================
   MANIFESTO
   ===================================================================== */
.manifesto { text-align: center; }
.manifesto__statement {
  font-family: var(--serif); font-weight: 300; line-height: 1.18;
  font-size: clamp(2rem, 5.2vw, 4.6rem); letter-spacing: -0.01em; max-width: 18ch; margin: 28px auto 0;
}
.manifesto__statement .word { display: inline-block; }
.manifesto__foot { margin-top: 48px; display: flex; gap: clamp(24px,5vw,72px); justify-content: center; flex-wrap: wrap; }
.manifesto__stat { text-align: left; }
.manifesto__stat .n { font-family: var(--serif); font-size: clamp(2rem,4vw,3.2rem); color: var(--gold); line-height: 1; }
.manifesto__stat .l { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted-2); margin-top: 10px; }

/* =====================================================================
   VALUES (Emotion · Storytelling · Cinematic Craft)
   ===================================================================== */
.values__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 32px; flex-wrap: wrap; margin-bottom: 64px; }
.values__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--line); }
.value {
  padding: 48px 36px 44px; border-bottom: 1px solid var(--line); border-right: 1px solid var(--line);
  position: relative; overflow: hidden; transition: background-color .6s var(--ease);
}
.value:nth-child(3n) { border-right: 0; }
.value::after { content:""; position:absolute; left:0; bottom:0; width:100%; height:1px; background: var(--gold); transform: scaleX(0); transform-origin:left; transition: transform .6s var(--ease); }
.value:hover { background: var(--black-2); }
.value:hover::after { transform: scaleX(1); }
.value__num { font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.2em; color: var(--gold-deep); }
.value__title { font-family: var(--serif); font-size: clamp(1.8rem, 3vw, 2.6rem); margin: 22px 0 16px; line-height: 1.05; }
.value__title .italic { color: var(--gold); }
.value__body { color: var(--muted); font-size: 0.98rem; line-height: 1.75; }

/* =====================================================================
   PREVIEW REEL (cinematic film section)
   ===================================================================== */
.reel { position: relative; }
.reel__stage {
  position: relative; aspect-ratio: 2.39 / 1; width: 100%; overflow: hidden; background: var(--black-2);
  border: 1px solid var(--line);
}
.reel__stage video { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.9) contrast(1.05) brightness(0.7); }
.reel__poster { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: opacity .6s; filter: saturate(0.9) brightness(0.6); }
.reel__stage.playing .reel__poster { opacity: 0; pointer-events: none; }
.reel__scrim { position: absolute; inset: 0; background: linear-gradient(0deg, rgba(10,10,11,0.8), transparent 50%); pointer-events: none; }
.reel__play {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; z-index: 3;
}
.reel__playbtn {
  width: clamp(78px, 9vw, 116px); height: clamp(78px, 9vw, 116px); border-radius: 50%;
  border: 1px solid var(--gold); display: grid; place-items: center; color: var(--gold);
  background: rgba(10,10,11,0.35); backdrop-filter: blur(3px); transition: transform .5s var(--ease), background-color .5s;
}
.reel__playbtn svg { width: 26px; height: 26px; margin-left: 4px; }
.reel__playbtn:hover { transform: scale(1.08); background: rgba(201,169,106,0.18); }
.reel__stage.playing .reel__play { opacity: 0; pointer-events: none; transition: opacity .4s; }
.reel__hud { position: absolute; z-index: 3; font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.2em; color: var(--muted); text-transform: uppercase; display:flex; align-items:center; gap:10px; pointer-events:none; }
.reel__hud--tl { top: 18px; left: 18px; }
.reel__hud--tr { top: 18px; right: 18px; }
.reel__hud--bl { bottom: 18px; left: 18px; }
.reel__hud--br { bottom: 18px; right: 18px; color: var(--gold); }
.reel__hud .rdot { width: 7px; height: 7px; border-radius: 50%; background: #d4453d; animation: rec 1.4s infinite; }
.reel__tracks { display: flex; gap: 0; margin-top: 28px; border-top: 1px solid var(--line); }
.reel__track {
  flex: 1; text-align: left; padding: 22px 20px; border-right: 1px solid var(--line);
  font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--muted-2);
  transition: color .4s, background-color .4s; position: relative;
}
.reel__track:last-child { border-right: 0; }
.reel__track .ttitle { color: var(--film-white); font-size: 0.78rem; margin-bottom: 6px; transition: color .4s; }
.reel__track:hover, .reel__track.active { background: var(--black-2); color: var(--gold); }
.reel__track.active .ttitle { color: var(--gold); }
.reel__track::before { content:""; position:absolute; top:0; left:0; width:100%; height:2px; background: var(--gold); transform: scaleX(0); transform-origin:left; transition: transform .4s var(--ease); }
.reel__track.active::before { transform: scaleX(1); }

/* =====================================================================
   PORTFOLIO TEASER GRID (home)
   ===================================================================== */
.teaser__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 32px; flex-wrap: wrap; margin-bottom: 54px; }
/* Fixed-row mosaic: row+col spans pack cleanly with NO aspect-ratio gaps,
   and never reflow as lazy images load. */
.teaser-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: clamp(150px, 15vw, 230px); gap: clamp(10px, 1.4vw, 20px); grid-auto-flow: dense; }
.tcard { position: relative; overflow: hidden; background: var(--black-2); grid-row: span 1; grid-column: span 1; }
.tcard img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.1s var(--ease), filter .6s; filter: grayscale(0.35) brightness(0.82); }
.tcard:hover img { transform: scale(1.06); filter: grayscale(0) brightness(0.95); }
.tcard::after { content:""; position:absolute; inset:0; background: linear-gradient(0deg, rgba(10,10,11,0.72), transparent 55%); opacity: 0; transition: opacity .5s; }
.tcard:hover::after { opacity: 1; }
.tcard__meta { position: absolute; left: 16px; bottom: 14px; z-index: 2; opacity: 0; transform: translateY(8px); transition: opacity .5s, transform .5s; }
.tcard:hover .tcard__meta { opacity: 1; transform: translateY(0); }
.tcard__meta .frame { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.18em; color: var(--gold); }
.tcard__meta .cap { font-family: var(--serif); font-size: 1.1rem; font-style: italic; }
/* spans */
/* span classes map to the 4-col fixed-row mosaic (no aspect-ratio) */
.tcard.s-a { grid-column: span 2; grid-row: span 2; }
.tcard.s-b { grid-column: span 1; grid-row: span 2; }
.tcard.s-c { grid-column: span 1; grid-row: span 1; }
.tcard.s-d { grid-column: span 2; grid-row: span 1; }
.tcard.s-e { grid-column: span 2; grid-row: span 2; }
.tcard.s-f { grid-column: span 2; grid-row: span 1; }

/* =====================================================================
   FILM STRIP (horizontal stills)
   ===================================================================== */
.filmstrip { overflow: hidden; padding: clamp(48px,7vh,90px) 0; border-block: 1px solid var(--line); background: var(--black-2); }
.filmstrip__head { padding: 0 var(--gutter); margin-bottom: 36px; display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap; }
.filmstrip__track { display: flex; gap: 14px; width: max-content; will-change: transform; }
.fs-frame {
  position: relative; flex: 0 0 auto; width: clamp(220px, 26vw, 360px); aspect-ratio: 3/2;
  background: var(--black-3); overflow: hidden;
  border-top: 14px solid var(--black-3); border-bottom: 14px solid var(--black-3);
}
.fs-frame::before, .fs-frame::after {
  content: ""; position: absolute; left: 0; right: 0; height: 14px; z-index: 2;
  background-image: repeating-linear-gradient(90deg, var(--black) 0 8px, transparent 8px 22px);
  background-size: 22px 8px; background-position: center;
}
.fs-frame::before { top: -14px; } .fs-frame::after { bottom: -14px; }
.fs-frame img { width: 100%; height: 100%; object-fit: cover; filter: sepia(0.18) saturate(0.85) brightness(0.8); transition: filter .6s, transform .8s var(--ease); }
.fs-frame:hover img { filter: sepia(0) saturate(1) brightness(0.95); transform: scale(1.04); }
.fs-frame .fnum { position: absolute; top: 8px; left: 8px; font-family: var(--mono); font-size: 0.56rem; letter-spacing: 0.14em; color: var(--gold); z-index: 3; }

/* =====================================================================
   PACKAGES PREVIEW + FULL PACKAGES
   ===================================================================== */
.pkg-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(14px, 1.6vw, 24px); align-items: stretch; }
.pkg {
  position: relative; display: flex; flex-direction: column; padding: 40px 34px 36px;
  border: 1px solid var(--line); background: var(--black-2); overflow: hidden;
  transition: transform .6s var(--ease), border-color .6s, background-color .6s;
}
.pkg::before { content:""; position:absolute; top:0; left:0; right:0; height:1px; background: linear-gradient(90deg, transparent, var(--gold), transparent); opacity:0; transition: opacity .6s; }
.pkg:hover { transform: translateY(-8px); border-color: var(--gold); background: var(--black-3); }
.pkg:hover::before { opacity: 1; }
.pkg.popular { border-color: var(--gold); background: linear-gradient(180deg, rgba(201,169,106,0.07), var(--black-2)); }
.pkg__badge {
  position: absolute; top: 0; right: 0; font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--black); background: var(--gold); padding: 7px 14px;
}
.pkg__kicker { font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); }
.pkg__name { font-family: var(--serif); font-size: clamp(2rem, 3vw, 2.8rem); line-height: 1; margin: 16px 0 6px; }
.pkg__price { font-family: var(--serif); font-size: clamp(1.7rem, 2.4vw, 2.2rem); color: var(--gold); margin-bottom: 8px; }
.pkg__price .per { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.16em; color: var(--muted-2); text-transform: uppercase; margin-left: 8px; }
.pkg__rule { height: 1px; background: var(--line); margin: 22px 0; }
.pkg__features { display: flex; flex-direction: column; gap: 14px; flex: 1; }
.pkg__feature { display: flex; gap: 14px; font-size: 0.92rem; line-height: 1.5; color: var(--muted); }
.pkg__feature .tick { flex: 0 0 auto; margin-top: 4px; color: var(--gold); }
.pkg__cta { margin-top: 32px; }
.pkg__cta .btn { width: 100%; justify-content: center; }

/* full packages page */
.collection { margin-bottom: clamp(72px, 12vh, 140px); }
.collection__head { display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: end; margin-bottom: 52px; padding-bottom: 28px; border-bottom: 1px solid var(--line); }
.collection__title { font-family: var(--serif); font-size: clamp(2.4rem, 6vw, 5rem); line-height: 0.95; }
.collection__blurb { max-width: 40ch; color: var(--muted); }
.enhancements { margin-top: 44px; }
.enhancements__label { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted-2); margin-bottom: 20px; }
.enh-list { display: flex; flex-wrap: wrap; gap: 12px; }
.enh-chip {
  font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted);
  border: 1px solid var(--line); padding: 11px 18px; transition: border-color .4s, color .4s, background-color .4s;
}
.enh-chip:hover { border-color: var(--gold); color: var(--gold); background: rgba(201,169,106,0.06); }
.coverage-note {
  margin-top: 18px; font-family: var(--serif); font-style: italic; font-size: 1.05rem; color: var(--muted);
}

/* =====================================================================
   TESTIMONIALS
   ===================================================================== */
.testi { position: relative; }
.testi__viewport { position: relative; min-height: 320px; }
.testi__slide {
  position: absolute; inset: 0; opacity: 0; transform: translateY(20px); transition: opacity .8s var(--ease), transform .8s var(--ease);
  text-align: center; pointer-events: none; display: flex; flex-direction: column; align-items: center; justify-content: center;
}
.testi__slide.active { opacity: 1; transform: translateY(0); pointer-events: auto; position: relative; }
.testi__quote { font-family: var(--serif); font-weight: 300; font-style: italic; font-size: clamp(1.7rem, 4vw, 3.2rem); line-height: 1.3; max-width: 22ch; }
.testi__mark { font-family: var(--serif); font-size: 5rem; color: var(--gold-deep); line-height: 0.4; opacity: 0.5; }
.testi__couple { font-family: var(--mono); font-size: 0.74rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); margin-top: 34px; }
.testi__loc { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.18em; color: var(--muted-2); margin-top: 8px; text-transform: uppercase; }
.testi__dots { display: flex; gap: 12px; justify-content: center; margin-top: 48px; }
.testi__dot { width: 40px; height: 2px; background: var(--line); position: relative; overflow: hidden; }
.testi__dot.active { background: var(--gold-deep); }
.testi__dot.active::after { content:""; position:absolute; inset:0; background: var(--gold); transform-origin:left; animation: testiBar 6s linear; }
@keyframes testiBar { from{transform:scaleX(0)} to{transform:scaleX(1)} }
@media (prefers-reduced-motion: reduce){ .testi__dot.active::after{animation:none; transform:scaleX(1)} }

/* =====================================================================
   CLOSING CTA
   ===================================================================== */
.cta-band { position: relative; overflow: hidden; text-align: center; }
.cta-band__bg { position: absolute; inset: 0; z-index: 0; }
.cta-band__bg img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.4) brightness(0.32) contrast(1.05); transform: scale(1.1); }
.cta-band__scrim { position: absolute; inset: 0; background: radial-gradient(80% 80% at 50% 50%, rgba(10,10,11,0.55), rgba(10,10,11,0.92)); z-index: 1; }
.cta-band__inner { position: relative; z-index: 2; }
.cta-band__title { font-family: var(--serif); font-size: clamp(2.6rem, 8vw, 7rem); line-height: 0.98; margin: 22px 0 14px; }
.cta-band__sub { font-family: var(--serif); font-style: italic; font-size: clamp(1.15rem, 2vw, 1.6rem); color: var(--muted); max-width: 40ch; margin: 0 auto 42px; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer { border-top: 1px solid var(--line); padding-top: clamp(64px, 9vh, 110px); position: relative; overflow: hidden; }
.footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.1fr; gap: 48px; }
.footer__brand .brand__name { font-size: 2rem; }
.footer__tag { font-family: var(--serif); font-style: italic; font-size: 1.3rem; color: var(--muted); margin-top: 18px; max-width: 28ch; }
.footer__col h4 { font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--muted-2); margin-bottom: 22px; }
.footer__col ul { display: flex; flex-direction: column; gap: 13px; }
.footer__col a { color: var(--muted); font-size: 0.95rem; transition: color .4s; position: relative; }
.footer__col a:hover { color: var(--gold); }
.footer__bignav { padding: clamp(48px,7vh,90px) 0 clamp(40px,5vh,64px); }
.footer__wordmark {
  font-family: var(--serif); font-size: clamp(3.4rem, 18vw, 16rem); line-height: 0.8; color: var(--black-2);
  -webkit-text-stroke: 1px rgba(201,169,106,0.18); text-stroke: 1px rgba(201,169,106,0.18);
  letter-spacing: 0.02em; user-select: none; white-space: nowrap; overflow: hidden;
}
.footer__bottom {
  display: flex; justify-content: space-between; align-items: center; gap: 24px; flex-wrap: wrap;
  padding: 28px 0 40px; border-top: 1px solid var(--line);
}
.footer__copy { font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.12em; color: var(--muted-2); }
.footer__socials { display: flex; gap: 22px; }
.footer__socials a { font-family: var(--mono); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; }

/* =====================================================================
   PAGE HERO (interior pages)
   ===================================================================== */
.page-hero { position: relative; padding: calc(var(--header-h) + clamp(60px,12vh,140px)) 0 clamp(50px,8vh,90px); overflow: hidden; }
.page-hero__bg { position: absolute; inset: 0; z-index: 0; }
.page-hero__bg img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.5) brightness(0.34); transform: scale(1.1); }
.page-hero__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(10,10,11,0.6), rgba(10,10,11,0.95)); z-index: 1; }
.page-hero__inner { position: relative; z-index: 2; }
.page-hero__title { font-family: var(--serif); font-size: clamp(3rem, 11vw, 9rem); line-height: 0.92; margin: 22px 0 0; }
.page-hero__sub { font-family: var(--serif); font-style: italic; font-size: clamp(1.2rem, 2.6vw, 2rem); color: var(--muted); margin-top: 22px; max-width: 44ch; }
.page-hero__meta { display: flex; gap: 28px; margin-top: 40px; flex-wrap: wrap; }
.page-hero__meta .m { font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-2); }
.page-hero__meta .m b { color: var(--gold); font-weight: 400; }

/* =====================================================================
   PORTFOLIO - FILTER + GALLERY + FILMS
   ===================================================================== */
.filters { display: flex; gap: 8px; flex-wrap: wrap; padding-bottom: 40px; border-bottom: 1px solid var(--line); margin-bottom: 48px; }
.filter {
  font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted);
  padding: 12px 22px; border: 1px solid var(--line); transition: all .4s var(--ease); position: relative; background: transparent;
}
.filter[aria-pressed="true"], .filter.active { background: var(--gold); color: var(--black); border-color: var(--gold); }
.filter:hover:not(.active) { border-color: var(--gold); color: var(--gold); }
.filter .count { font-size: 0.6rem; opacity: 0.7; margin-left: 7px; }

/* Stable CSS-grid MOSAIC (replaces fragile `columns` masonry).
   Fixed tile sizes via row/col spans + object-fit:cover means the layout
   NEVER reflows as lazy images load - so the document height stays constant
   and smooth-scroll / ScrollTrigger measurements remain correct. */
.gallery {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-auto-rows: clamp(150px, 15.5vw, 240px);
  grid-auto-flow: dense;
  gap: clamp(10px, 1.4vw, 18px);
}
.gallery .gitem {
  position: relative; overflow: hidden; background: var(--black-2);
  display: block; width: 100%; height: 100%;
  grid-row: span 1; grid-column: span 1;
}
.gallery .gitem.tall { grid-row: span 2; }
.gallery .gitem.wide { grid-column: span 2; }
.gallery .gitem.big  { grid-row: span 2; grid-column: span 2; }
.gallery .gitem img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 1s var(--ease), filter .6s; filter: grayscale(0.3) brightness(0.85); }
@media (max-width: 1024px) { .gallery { grid-template-columns: repeat(3, 1fr); grid-auto-rows: clamp(140px, 20vw, 200px); } }
/* MOBILE MOSAIC: a curated 2-col magazine grid (see mobile-polish block below
   for the full span remap). Base 600px rule keeps 2 columns + a tighter row unit. */
@media (max-width: 600px)  {
  .gallery { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 42vw; }
  .gallery .gitem.big  { grid-column: span 2; grid-row: span 2; }
  .gallery .gitem.wide { grid-column: span 2; grid-row: span 1; }
  .gallery .gitem.tall { grid-column: span 1; grid-row: span 2; }
}
.gallery .gitem:hover img { transform: scale(1.05); filter: grayscale(0) brightness(1); }
.gallery .gitem::after { content:""; position:absolute; inset:0; background: linear-gradient(0deg, rgba(10,10,11,0.7), transparent 50%); opacity: 0; transition: opacity .5s; }
.gallery .gitem:hover::after { opacity: 1; }
.gallery .gitem__hud { position: absolute; left: 14px; bottom: 12px; right: 14px; z-index: 2; display: flex; justify-content: space-between; align-items: flex-end; opacity: 0; transform: translateY(8px); transition: opacity .5s, transform .5s; }
.gallery .gitem:hover .gitem__hud { opacity: 1; transform: translateY(0); }
.gitem__cat { font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--gold); }
.gitem__frame { font-family: var(--mono); font-size: 0.58rem; color: var(--muted); }
.gitem.hide { display: none; }
.gallery .gitem .corner { position: absolute; top: 10px; right: 10px; z-index: 2; width: 14px; height: 14px; border-top: 1px solid var(--gold); border-right: 1px solid var(--gold); opacity: 0; transition: opacity .4s; }
.gallery .gitem:hover .corner { opacity: 0.8; }

/* films grid on portfolio */
.films-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(14px, 1.8vw, 28px); }
.filmcard { position: relative; aspect-ratio: 16/9; overflow: hidden; background: var(--black-2); border: 1px solid var(--line); }
.filmcard.feature { grid-column: span 2; aspect-ratio: 2.39/1; }
.filmcard video { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.9) brightness(0.7); }
.filmcard__poster { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: grayscale(0.3) brightness(0.55); transition: opacity .6s; }
.filmcard.playing .filmcard__poster { opacity: 0; }
.filmcard__overlay { position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column; justify-content: flex-end; padding: 26px; background: linear-gradient(0deg, rgba(10,10,11,0.7), transparent 55%); transition: opacity .5s; }
.filmcard.playing .filmcard__overlay { opacity: 0; pointer-events: none; }
.filmcard__title { font-family: var(--serif); font-size: clamp(1.5rem, 2.6vw, 2.4rem); line-height: 1; }
.filmcard__cat { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); margin-bottom: 12px; }
.filmcard__play { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 3; width: 70px; height: 70px; border-radius: 50%; border: 1px solid var(--gold); display: grid; place-items: center; color: var(--gold); background: rgba(10,10,11,0.4); transition: transform .5s var(--ease), background-color .5s; }
.filmcard__play svg { width: 22px; height: 22px; margin-left: 3px; }
.filmcard:hover .filmcard__play { transform: translate(-50%,-50%) scale(1.1); background: rgba(201,169,106,0.2); }
.filmcard.playing .filmcard__play { opacity: 0; pointer-events: none; }

/* =====================================================================
   LIGHTBOX
   ===================================================================== */
.lightbox {
  position: fixed; inset: 0; z-index: 9700; background: rgba(7,7,8,0.96); backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center; padding: clamp(20px, 5vw, 80px);
  opacity: 0; visibility: hidden; transition: opacity .4s var(--ease), visibility .4s;
}
.lightbox.open { opacity: 1; visibility: visible; }
.lightbox__bars { position: absolute; left: 0; right: 0; height: clamp(30px,7vh,72px); background: var(--black); z-index: 1; }
.lightbox__bars.top { top: 0; } .lightbox__bars.bottom { bottom: 0; }
.lightbox__stage { position: relative; max-width: 100%; max-height: 100%; z-index: 2; }
.lightbox__img { max-width: 100%; max-height: 80svh; object-fit: contain; box-shadow: 0 30px 90px rgba(0,0,0,0.6); }
.lightbox__hud { position: absolute; left: 0; right: 0; bottom: -42px; display: flex; justify-content: space-between; font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); }
.lightbox__hud .gold { color: var(--gold); }
.lb-btn {
  position: absolute; z-index: 3; top: 50%; transform: translateY(-50%);
  width: 58px; height: 58px; border: 1px solid var(--line); display: grid; place-items: center; color: var(--film-white);
  background: rgba(10,10,11,0.5); transition: all .4s var(--ease);
}
.lb-btn:hover { border-color: var(--gold); color: var(--gold); background: rgba(201,169,106,0.12); }
.lb-prev { left: clamp(12px,3vw,40px); } .lb-next { right: clamp(12px,3vw,40px); }
.lb-close { position: absolute; top: clamp(16px,4vh,40px); right: clamp(16px,4vw,40px); z-index: 4; width: 52px; height: 52px; border: 1px solid var(--line); display: grid; place-items: center; color: var(--film-white); background: rgba(10,10,11,0.5); transition: all .4s; }
.lb-close:hover { border-color: var(--gold); color: var(--gold); transform: rotate(90deg); }
.lb-btn svg, .lb-close svg { width: 20px; height: 20px; }

/* =====================================================================
   CONTACT
   ===================================================================== */
.contact-layout { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 110px); align-items: start; }
.consult { position: sticky; top: calc(var(--header-h) + 40px); }
.consult__title { font-family: var(--serif); font-size: clamp(2rem,3vw,3rem); line-height: 1; margin: 18px 0 28px; }
.consult__list { display: flex; flex-direction: column; gap: 0; border-top: 1px solid var(--line); }
.consult__item { display: flex; gap: 22px; align-items: flex-start; padding: 24px 0; border-bottom: 1px solid var(--line); }
.consult__item .n { font-family: var(--mono); font-size: 0.7rem; color: var(--gold); letter-spacing: 0.16em; flex: 0 0 auto; padding-top: 4px; }
.consult__item p { font-family: var(--serif); font-size: 1.4rem; line-height: 1.3; color: var(--film-white); }
.consult__meta { margin-top: 40px; display: grid; gap: 22px; }
.consult__meta .lab { font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted-2); margin-bottom: 8px; }
.consult__meta .val { font-family: var(--serif); font-size: 1.2rem; }
.consult__socials { display: flex; gap: 20px; }

.form { display: grid; gap: 26px; }
.field { position: relative; }
.field label { font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted-2); display: block; margin-bottom: 12px; }
.field label .req { color: var(--gold); }
.field input, .field select, .field textarea {
  width: 100%; background: transparent; border: 0; border-bottom: 1px solid var(--line);
  color: var(--film-white); font-family: var(--serif); font-size: 1.25rem; padding: 12px 0; transition: border-color .4s;
}
.field input::placeholder, .field textarea::placeholder { color: var(--muted-2); font-style: italic; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--gold); }
.field select { appearance: none; cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='9' fill='none'%3E%3Cpath d='M1 1l6 6 6-6' stroke='%23c9a96a' stroke-width='1.5'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right center; }
.field select option { background: var(--black-2); color: var(--film-white); }
.field textarea { resize: vertical; min-height: 90px; line-height: 1.5; }
.field.invalid input, .field.invalid select, .field.invalid textarea { border-color: #d4453d; }
.field__error { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.1em; color: #d4453d; margin-top: 8px; opacity: 0; height: 0; transition: opacity .3s; }
.field.invalid .field__error { opacity: 1; height: auto; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; }
.form__submit { margin-top: 8px; }
.form__submit .btn { width: 100%; justify-content: center; }

.form-success {
  display: none; text-align: center; padding: clamp(40px,8vh,80px) 20px;
  border: 1px solid var(--line); background: var(--black-2);
}
.form-success.show { display: block; animation: fadeUp .7s var(--ease); }
.form-success__icon { width: 72px; height: 72px; border-radius: 50%; border: 1px solid var(--gold); display: grid; place-items: center; margin: 0 auto 28px; color: var(--gold); }
.form-success__icon svg { width: 30px; height: 30px; }
.form-success h3 { font-family: var(--serif); font-size: clamp(2rem,4vw,3rem); line-height: 1; margin-bottom: 16px; }
.form-success p { color: var(--muted); max-width: 38ch; margin: 0 auto; }
@keyframes fadeUp { from{opacity:0; transform:translateY(20px)} to{opacity:1; transform:translateY(0)} }

/* =====================================================================
   SCROLL REVEAL (JS adds .in)
   ===================================================================== */
[data-reveal] { opacity: 0; transform: translateY(34px); transition: opacity 1s var(--ease), transform 1s var(--ease); }
[data-reveal].in { opacity: 1; transform: none; }
[data-reveal-delay="1"] { transition-delay: .08s; }
[data-reveal-delay="2"] { transition-delay: .16s; }
[data-reveal-delay="3"] { transition-delay: .24s; }
[data-reveal-delay="4"] { transition-delay: .32s; }
[data-reveal-delay="5"] { transition-delay: .40s; }
/* hero line reveal */
.line > span { display: block; transform: translateY(110%); }
.hero.loaded .line > span { transform: translateY(0); transition: transform 1.1s var(--ease-io); }
.hero.loaded .line:nth-child(1) > span { transition-delay: .7s; }
.hero.loaded .line:nth-child(2) > span { transition-delay: .82s; }
.hero.loaded .line:nth-child(3) > span { transition-delay: .94s; }
.hero__kicker, .hero__sub, .hero__actions { opacity: 0; transform: translateY(20px); }
.hero.loaded .hero__kicker { opacity: 1; transform: none; transition: all 1s var(--ease) .55s; }
.hero.loaded .hero__sub { opacity: 1; transform: none; transition: all 1s var(--ease) 1.1s; }
.hero.loaded .hero__actions { opacity: 1; transform: none; transition: all 1s var(--ease) 1.25s; }

@media (prefers-reduced-motion: reduce) {
  [data-reveal], .hero__kicker, .hero__sub, .hero__actions { opacity: 1 !important; transform: none !important; }
  .line > span { transform: none !important; }
  .hero__media video, .hero__media img { transform: none; }
  .letterbox { display: none; }
}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 1100px) {
  .gallery { grid-template-columns: repeat(3, 1fr); grid-auto-rows: clamp(140px, 20vw, 200px); }
  .footer__top { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 900px) {
  :root { --header-h: 72px; }
  .nav__list, .nav__cta { display: none; }
  .burger { display: block; }
  .values__grid { grid-template-columns: 1fr; }
  .value { border-right: 0 !important; }
  .pkg-grid { grid-template-columns: 1fr; }
  .teaser-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 40vw; }
  .tcard.s-a, .tcard.s-d, .tcard.s-e, .tcard.s-f { grid-column: span 2; grid-row: span 1; }
  .tcard.s-b, .tcard.s-c { grid-column: span 1; grid-row: span 1; }
  .reel__tracks { flex-wrap: wrap; }
  .reel__track { flex: 1 1 50%; border-bottom: 1px solid var(--line); }
  .contact-layout { grid-template-columns: 1fr; }
  .consult { position: static; }
  .collection__head { grid-template-columns: 1fr; }
  .films-grid { grid-template-columns: 1fr; }
  .filmcard.feature { grid-column: span 1; }
}
@media (max-width: 640px) {
  .field-row { grid-template-columns: 1fr; }
  .footer__top { grid-template-columns: 1fr; }
  .footer__bottom { flex-direction: column; align-items: flex-start; }
  .manifesto__statement { font-size: clamp(1.7rem, 8vw, 2.6rem); }
}

/* =====================================================================
   MOBILE POLISH  (≤768px / ≤480px / ≤380px)  - does not touch desktop rules
   Goal: make small screens feel like a premium native app, not a shrunk site.
   ===================================================================== */
@media (max-width: 768px) {
  /* generous, even side padding everywhere */
  :root { --gutter: 22px; }

  /* tighter but still deliberate vertical rhythm (desktop is 80-160px) */
  .section { padding: clamp(64px, 9vh, 96px) 0; }
  .section--tight { padding: clamp(52px, 7vh, 78px) 0; }

  /* HEADER: keep it to logo-left, hamburger-right.
     The "REC · 24FPS" garnish next to the logo eats space and can crowd
     the hamburger, so retire it on small screens. Nudge the burger so its
     44px hit-area doesn't push its glyph past the gutter edge. */
  .brand__rec { display: none; }
  .burger { margin-right: -8px; }

  /* HERO cinematic top/bottom bars: drop the HUD captions so the
     "OZO · WEDDING PRODUCTION" / "2.39 : 1 · CINEMASCOPE" text can never
     overlap the logo or hamburger or run past the edge. Keep the thin bars. */
  .bar__hud { display: none; }
  /* shrink the bars a touch so they don't crowd hero copy */
  .bar { height: 26px; }

  /* HERO copy legibility on small screens. The body sits over a bright
     stretch of footage (faces / skin), so we (a) darken the scrim under the
     text and (b) lift the copy toward warm film-white with a soft shadow. */
  .hero__content { justify-content: flex-end; padding-bottom: clamp(74px, 15vh, 120px); }
  .hero__title { max-width: 12ch; }
  .hero__sub {
    margin-top: 22px; max-width: 34ch;
    font-size: clamp(1.05rem, 4.4vw, 1.3rem); line-height: 1.55;
    color: #d9d2c6; /* brighter than --muted so it reads over video */
    text-shadow: 0 1px 22px rgba(10,10,11,0.85), 0 1px 3px rgba(10,10,11,0.9);
  }
  .hero__kicker { text-shadow: 0 1px 14px rgba(10,10,11,0.8); }
  .hero__actions { margin-top: 30px; gap: 14px; }
  .hero__actions .btn { width: 100%; justify-content: center; }
  /* Stronger, bottom-anchored scrim: dark base everywhere + a heavy floor
     under the headline/body so light footage can never wash the type out. */
  /* Keep the hero VIDEO bright and visible: clear at the top, darkening only
     toward the bottom behind the copy so the footage still reads as the hero. */
  .hero__scrim {
    background:
      linear-gradient(180deg,
        rgba(10,10,11,0.28) 0%,
        rgba(10,10,11,0.10) 30%,
        rgba(10,10,11,0.35) 58%,
        rgba(10,10,11,0.82) 82%,
        rgba(10,10,11,0.95) 100%);
  }

  /* SCROLL cue collides with the stacked buttons - retire it on mobile */
  .hero__scrollcue { display: none; }

  /* comfortable tap targets (>=44px) */
  .btn { padding: 17px 26px; }
  .nav__link, .footer__col a, .link-underline { padding-top: 10px; padding-bottom: 10px; display: inline-block; }
  .filter { padding: 14px 20px; }
  .enh-chip { padding: 13px 18px; }

  /* TYPE: keep big display type confident but never cramped at edges */
  .display--xl { font-size: clamp(3rem, 15vw, 5rem); }
  .display--lg { font-size: clamp(2.4rem, 11vw, 3.6rem); }
  .body { max-width: none; }

  /* MANIFESTO: pull the giant statement in a touch */
  .manifesto__statement { margin-top: 22px; }
  .manifesto__foot { margin-top: 36px; gap: 28px 40px; }

  /* VALUES already single-column at 900; tighten padding + rhythm */
  .values__head { margin-bottom: 40px; }
  .value { padding: 34px 24px; }

  /* REEL: tracks stack to a readable 2-up, comfortable padding */
  .reel__track { padding: 18px 16px; }
  .reel__tracks { margin-top: 20px; }

  /* PACKAGES cards: comfortable inner padding, clear popular marker */
  .pkg { padding: 32px 24px 30px; }
  .pkg-grid { gap: 18px; }
  .collection__head { margin-bottom: 34px; padding-bottom: 22px; }
  .enhancements { margin-top: 34px; }

  /* FILMSTRIP: smaller frames, keep within edges */
  .fs-frame { width: clamp(180px, 62vw, 260px); }
  .filmstrip__head { margin-bottom: 26px; }

  /* TESTIMONIALS: don't let tall quotes get clipped */
  .testi__viewport { min-height: 340px; }
  .testi__quote { font-size: clamp(1.5rem, 6.4vw, 2.1rem); }
  .testi__dots { margin-top: 36px; }

  /* CONTACT: form already single column; tighten consult spacing */
  .consult__title { margin: 14px 0 22px; }
  .consult__item p { font-size: 1.2rem; }
  .consult__item { padding: 20px 0; gap: 16px; }
  .consult__meta { margin-top: 32px; }
  .form { gap: 24px; }

  /* PAGE-HERO: reduce the big interior-page top padding */
  .page-hero { padding: calc(var(--header-h) + clamp(48px,10vh,96px)) 0 clamp(40px,6vh,64px); }
  .page-hero__sub { margin-top: 18px; }
  .page-hero__meta { margin-top: 30px; gap: 18px 26px; }

  /* LIGHTBOX: keep nav controls reachable + comfortably tappable (>=46px) */
  .lb-btn { width: 48px; height: 48px; }
  .lb-prev { left: 12px; } .lb-next { right: 12px; }
  .lb-close { width: 48px; height: 48px; top: 14px; right: 14px; }
  .lightbox__hud { bottom: -34px; font-size: 0.58rem; }

  /* FOOTER wordmark: keep the giant word from forcing horizontal scroll */
  .footer__wordmark { font-size: clamp(2.8rem, 22vw, 6rem); }

  /* ---------------------------------------------------------------
     2-COLUMN EDITORIAL MOSAIC (teaser + gallery)
     Fixed row unit + varied row/col spans = a curated magazine spread
     that never reflows on lazy image load. Feature tiles go full-width.
     --------------------------------------------------------------- */
  .teaser-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 30vw;
    gap: 10px;
  }
  /* s-a / s-e: hero feature tiles → full-width + tall */
  .tcard.s-a, .tcard.s-e { grid-column: span 2; grid-row: span 2; }
  /* s-d / s-f: wide banner tiles → full-width, single row */
  .tcard.s-d, .tcard.s-f { grid-column: span 2; grid-row: span 1; }
  /* s-b: tall portrait tile → 1 col, 2 rows */
  .tcard.s-b { grid-column: span 1; grid-row: span 2; }
  /* s-c: regular square tile */
  .tcard.s-c { grid-column: span 1; grid-row: span 1; }
  /* keep captions readable at this size */
  .tcard__meta { left: 14px; bottom: 12px; }
  .tcard__meta .cap { font-size: 1rem; }

  .gallery {
    grid-template-columns: repeat(2, 1fr);
    grid-auto-rows: 30vw;
    gap: 10px;
  }
  /* big feature tile: full-width + tall for a proper focal point */
  .gallery .gitem.big  { grid-column: span 2; grid-row: span 2; }
  /* wide banner: full-width single row */
  .gallery .gitem.wide { grid-column: span 2; grid-row: span 1; }
  /* tall portrait: 1 col, 2 rows */
  .gallery .gitem.tall { grid-column: span 1; grid-row: span 2; }
  /* the hover HUD is unreachable on touch - always show it lightly */
  .gallery .gitem__hud { opacity: 1; transform: none; }
  .gallery .gitem::after { opacity: 0.55; }
}

@media (max-width: 480px) {
  /* REEL tracks to a single comfortable column */
  .reel__track { flex: 1 1 100%; border-right: 0; }
  /* hide the decorative reel corner HUDs that can crowd small frames */
  .reel__hud--bl, .reel__hud--br { display: none; }
  /* keep the popular package badge from hugging text */
  .pkg__badge { font-size: 0.55rem; padding: 6px 12px; }
}

@media (max-width: 380px) {
  :root { --gutter: 20px; }
  /* narrowest phones: keep the mosaic 2-up (never a boring single stack),
     just give tiles slightly more height so portraits breathe. */
  .teaser-grid, .gallery { grid-auto-rows: 33vw; gap: 9px; }
  .display--xl { font-size: clamp(2.9rem, 16vw, 4.4rem); }
  .hero__title { max-width: 11ch; }
}
