/* ============================================================
   OPALOOK STUDIO — Cinematic design system
   Shared stylesheet for all pages.
   ============================================================ */

/* ------------ Design tokens ------------ */
:root{
  /* Core dark palette */
  --void: #070605;
  --black: #0a0807;
  --dark: #13100d;
  --dark-2: #1e1915;
  --dark-3: #2a221c;

  /* Cream & paper tones */
  --cream: #f6f1ea;
  --cream-soft: #e8e1d4;
  --cream-muted: rgba(246,241,234,.72);
  --cream-faint: rgba(246,241,234,.5);

  /* Warm opal accents */
  --amber: #d4a574;
  --amber-glow: #f0c898;
  --amber-deep: #8a5a2b;
  --opal-pink: #e8b8a0;
  --opal-cool: #a8b8c8;

  /* UI */
  --hairline: rgba(246,241,234,.1);
  --hairline-strong: rgba(246,241,234,.18);
  --overlay: rgba(10,8,7,.5);

  --radius-sm: 8px;
  --radius: 12px;
  --radius-lg: 20px;

  --serif: "Fraunces", "Iowan Old Style", Georgia, "Times New Roman", serif;
  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --ease-out: cubic-bezier(.2, .8, .2, 1);
  --ease-out-slow: cubic-bezier(.77, 0, .175, 1);
}

/* ------------ Reset & base ------------ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; }
body{
  background: var(--black);
  color: var(--cream);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  font-weight: 400;
}
a { color: var(--cream); text-decoration: none; transition: color .25s ease; }
a:hover { color: var(--amber-glow); }
img, video { max-width: 100%; display: block; }
button { font-family: inherit; border: none; cursor: pointer; }

::selection { background: var(--amber); color: var(--dark); }

.wrap { max-width: 1280px; margin: 0 auto; padding: 0 32px; position: relative; }

/* ------------ Global film grain ------------ */
.grain{
  pointer-events: none;
  position: fixed; inset: 0;
  z-index: 9999;
  opacity: .08;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0'/></filter><rect width='180' height='180' filter='url(%23n)' opacity='0.85'/></svg>");
  animation: grain 1.6s steps(6) infinite;
}
@keyframes grain{
  0%, 100% { transform: translate(0, 0); }
  20% { transform: translate(-2%, 2%); }
  40% { transform: translate(2%, -3%); }
  60% { transform: translate(-3%, 1%); }
  80% { transform: translate(1%, 3%); }
}

/* ------------ Light leak (subtle warm glow pulsing from edges) ------------ */
.light-leak{
  pointer-events: none;
  position: fixed; inset: 0;
  z-index: 1;
  opacity: .35;
  background:
    radial-gradient(ellipse 60% 40% at 0% 10%, rgba(240,200,152,.12), transparent 60%),
    radial-gradient(ellipse 50% 40% at 100% 90%, rgba(212,165,116,.10), transparent 60%);
  animation: leak 14s ease-in-out infinite alternate;
}
@keyframes leak{
  0% { opacity: .25; transform: translate(0, 0); }
  100% { opacity: .45; transform: translate(1%, -1%); }
}

/* ------------ Header ------------ */
header.site{
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 24px 0;
  transition: background .35s ease, padding .35s ease, box-shadow .35s ease, border-color .35s ease;
  border-bottom: 1px solid transparent;
}
header.site.scrolled{
  background: rgba(10,8,7,.82);
  backdrop-filter: saturate(140%) blur(16px);
  -webkit-backdrop-filter: saturate(140%) blur(16px);
  padding: 14px 0;
  border-bottom-color: var(--hairline);
}
.nav { display: flex; align-items: center; justify-content: space-between; gap: 32px; }
.brand{
  font-family: var(--serif); font-weight: 400; font-size: 22px;
  letter-spacing: -0.01em; color: var(--cream);
  display: inline-flex; align-items: center; gap: 10px;
}
.brand-mark{
  display: inline-block; width: 10px; height: 10px; border-radius: 999px;
  background: linear-gradient(135deg, var(--amber-glow), var(--amber), var(--opal-pink));
  box-shadow: 0 0 12px rgba(240,200,152,.5);
  animation: pulseOpal 3s ease-in-out infinite;
}
@keyframes pulseOpal{
  0%, 100% { box-shadow: 0 0 12px rgba(240,200,152,.5); }
  50% { box-shadow: 0 0 20px rgba(240,200,152,.8); }
}
.nav ul { list-style: none; display: flex; gap: 34px; margin: 0; padding: 0; }
.nav a{
  font-size: 13px; color: var(--cream-muted); font-weight: 500;
  letter-spacing: .04em; text-transform: uppercase;
  position: relative; padding: 4px 0;
}
.nav a::after{
  content: ""; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 1px; background: var(--amber-glow);
  transform: scaleX(0); transform-origin: right;
  transition: transform .3s var(--ease-out);
}
.nav a:hover, .nav a.active { color: var(--cream); }
.nav a:hover::after, .nav a.active::after { transform: scaleX(1); transform-origin: left; }

/* CTA Button */
.cta-btn{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 13px 24px; border-radius: 999px;
  background: var(--amber); color: var(--dark) !important;
  font-weight: 500; font-size: 13px; letter-spacing: .04em;
  text-transform: uppercase;
  transition: transform .25s var(--ease-out), background .25s ease, box-shadow .25s ease;
  box-shadow: 0 1px 0 rgba(0,0,0,.08), 0 10px 30px -12px rgba(212,165,116,.4);
  border: 1px solid transparent;
  white-space: nowrap;
}
.cta-btn:hover{
  background: var(--amber-glow);
  transform: translateY(-2px);
  box-shadow: 0 1px 0 rgba(0,0,0,.08), 0 16px 40px -10px rgba(240,200,152,.55);
  color: var(--dark) !important;
}
.cta-btn.ghost{
  background: transparent; color: var(--cream) !important;
  border-color: var(--hairline-strong);
  box-shadow: none;
}
.cta-btn.ghost:hover{
  background: var(--cream); color: var(--dark) !important;
  border-color: var(--cream);
}
.cta-btn .arrow{ display: inline-block; transition: transform .25s var(--ease-out); }
.cta-btn:hover .arrow{ transform: translateX(4px); }

.mobile-toggle{
  display: none; background: transparent; color: var(--cream);
  width: 40px; height: 40px; border-radius: 8px;
  align-items: center; justify-content: center;
}
.mobile-toggle svg { width: 22px; height: 22px; transition: transform .3s var(--ease-out); }
.mobile-toggle.open svg { transform: rotate(90deg); }

/* ------------ MOBILE MENU PANEL ------------ */
#mobile-menu{
  position: fixed; inset: 0; z-index: 90;
  background: rgba(10,8,7,0.96);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
  opacity: 0; pointer-events: none;
  transition: opacity .35s var(--ease-out);
  display: flex; align-items: center; justify-content: center;
  overflow-y: auto;
}
#mobile-menu.open{ opacity: 1; pointer-events: auto; }
#mobile-menu .mobile-menu-inner{
  display: flex; flex-direction: column; align-items: center;
  gap: 28px; padding: 100px 24px 60px;
  width: 100%; max-width: 460px; text-align: center;
}
#mobile-menu .mobile-menu-list{
  list-style: none; margin: 0; padding: 0;
  display: flex; flex-direction: column; gap: 22px;
  width: 100%;
}
#mobile-menu .mobile-menu-list li{ list-style: none; }
#mobile-menu .mobile-menu-list a{
  font-family: var(--serif, Fraunces, serif);
  font-size: 30px; line-height: 1.15; letter-spacing: -0.005em;
  color: var(--cream); text-decoration: none;
  display: inline-block; padding: 8px 4px;
  transition: color .2s var(--ease-out);
}
#mobile-menu .mobile-menu-list a:hover,
#mobile-menu .mobile-menu-list a.active{ color: var(--amber); }
#mobile-menu .mobile-menu-cta{
  margin-top: 12px; font-size: 14px; padding: 14px 28px;
}
.mobile-toggle.open{ background: rgba(255,255,255,0.06); }

/* ------------ STEP 1 RUNNING TOTAL ------------ */
.step1-total{
  font-family: var(--serif, Fraunces, serif);
  font-size: 22px; line-height: 1.2;
  color: var(--cream); letter-spacing: .005em;
  margin: 6px 0 24px;
}
.step1-total strong{ color: var(--amber); font-weight: 500; }

/* ------------ HERO ------------ */
.hero{
  position: relative; min-height: 100vh;
  display: flex; align-items: center;
  color: var(--cream); overflow: hidden;
  padding: 140px 0 120px;
  background: var(--black);
}
.hero-bg{
  position: absolute; inset: 0; z-index: 0; overflow: hidden;
}
.hero-bg video,
.hero-bg .bg-placeholder{
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
}
/* Placeholder gradient if no video is swapped in */
.hero-bg .bg-placeholder{
  background:
    radial-gradient(ellipse at 25% 30%, rgba(240,200,152,.35), transparent 55%),
    radial-gradient(ellipse at 75% 70%, rgba(212,165,116,.22), transparent 60%),
    radial-gradient(ellipse at 50% 90%, rgba(70,40,20,.45), transparent 60%),
    linear-gradient(180deg, #0a0807 0%, #13100d 50%, #1e1915 100%);
  animation: heroShift 22s ease-in-out infinite alternate;
  filter: saturate(1.1);
}
@keyframes heroShift{
  0% { transform: scale(1) translate(0, 0); }
  50% { transform: scale(1.08) translate(-1.5%, 1%); }
  100% { transform: scale(1.04) translate(1%, -1.5%); }
}
.hero-bg::after{
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(10,8,7,.3) 0%, rgba(10,8,7,.55) 60%, rgba(10,8,7,.85) 100%),
    radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,.4) 100%);
  pointer-events: none; z-index: 1;
}
/* Scan-line filmic effect */
.hero-scan{
  position: absolute; inset: 0; z-index: 2; pointer-events: none; opacity: .06;
  background: repeating-linear-gradient(
    to bottom,
    rgba(255,255,255,0) 0px, rgba(255,255,255,0) 2px,
    rgba(255,255,255,.5) 3px, rgba(255,255,255,0) 4px
  );
}
/* Letterbox bars (cinematic 21:9 feel) */
.letterbox{
  position: absolute; left: 0; right: 0;
  background: var(--black); z-index: 3; pointer-events: none;
  transition: transform 1.2s var(--ease-out-slow);
}
.letterbox-top{ top: 0; height: 48px; transform: translateY(-100%); }
.letterbox-bot{ bottom: 0; height: 48px; transform: translateY(100%); }
body.loaded .letterbox-top{ transform: translateY(0); }
body.loaded .letterbox-bot{ transform: translateY(0); }
@media (max-width:860px){
  .letterbox-top, .letterbox-bot { height: 28px; }
}

.hero .wrap { position: relative; z-index: 4; }

.eyebrow{
  font-size: 12px; letter-spacing: .3em; text-transform: uppercase;
  color: var(--amber-glow); font-weight: 500;
  margin-bottom: 32px; display: inline-flex; align-items: center; gap: 14px;
  opacity: 0; transform: translateY(10px);
  animation: fadeUp .9s .3s both;
}
.eyebrow::before, .eyebrow::after{
  content: ""; display: inline-block; width: 34px; height: 1px;
  background: var(--amber-glow);
}
.eyebrow.solo::after { display: none; }

h1.hero-title{
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(48px, 8vw, 120px);
  line-height: 1.02;
  letter-spacing: -0.03em;
  margin: 0 0 32px;
  font-variation-settings: "opsz" 144;
  max-width: 15ch;
}
h1.hero-title .word{
  display: inline-block;
  opacity: 0;
  transform: translateY(48px) rotate(2deg);
  filter: blur(8px);
  animation: wordUp 1.1s var(--ease-out) both;
}
h1.hero-title .word.italic{
  font-style: italic;
  color: var(--amber-glow);
  font-weight: 400;
}
@keyframes wordUp{
  to { opacity: 1; transform: translateY(0) rotate(0); filter: blur(0); }
}

.lead{
  font-size: clamp(16px, 1.4vw, 19px);
  color: var(--cream-muted);
  max-width: 560px;
  margin: 0 0 44px;
  line-height: 1.65;
  opacity: 0; transform: translateY(14px);
  animation: fadeUp 1s 1.6s both;
}
@keyframes fadeUp{ to { opacity: 1; transform: translateY(0); } }

.hero-ctas{
  display: flex; gap: 14px; flex-wrap: wrap;
  opacity: 0; transform: translateY(14px);
  animation: fadeUp 1s 1.8s both;
}

.scroll-hint{
  position: absolute; bottom: 80px; left: 50%;
  transform: translateX(-50%); z-index: 4;
  color: var(--cream-faint); font-size: 10px;
  letter-spacing: .3em; text-transform: uppercase;
  display: flex; flex-direction: column; align-items: center; gap: 16px;
  opacity: 0; animation: fadeUp 1s 2.2s both;
}
.scroll-line{
  display: block; width: 1px; height: 60px;
  background: linear-gradient(to bottom, var(--cream-faint), transparent);
  position: relative; overflow: hidden;
}
.scroll-line::after{
  content: ""; position: absolute; top: 0; left: 0; right: 0;
  height: 20px; background: var(--amber-glow);
  animation: scrollDot 2.4s var(--ease-out) infinite;
}
@keyframes scrollDot{
  0% { transform: translateY(-110%); }
  60% { transform: translateY(220%); }
  100% { transform: translateY(220%); }
}
@media (max-width:860px){ .scroll-hint{ bottom: 52px; } .scroll-line{ height: 40px; } }

/* ------------ Marquee ------------ */
.marquee{
  background: var(--dark-2);
  color: var(--cream-muted);
  padding: 24px 0;
  overflow: hidden;
  white-space: nowrap;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
}
.marquee-track{
  display: inline-flex; gap: 72px; padding-left: 72px;
  animation: marquee 42s linear infinite;
  align-items: center;
}
.marquee-item{
  font-family: var(--serif); font-style: italic;
  font-size: 19px; color: var(--cream-muted);
}
.marquee-item.star{
  color: var(--amber-glow); font-family: var(--sans);
  font-style: normal; font-size: 10px;
  letter-spacing: .3em; text-transform: uppercase;
  font-weight: 500;
}
@keyframes marquee{ from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ------------ Reveal animations ------------ */
.reveal{
  opacity: 0; transform: translateY(36px);
  transition: opacity 1s var(--ease-out), transform 1s var(--ease-out);
}
.reveal.in{ opacity: 1; transform: translateY(0); }
.reveal-delay-1{ transition-delay: .1s; }
.reveal-delay-2{ transition-delay: .2s; }
.reveal-delay-3{ transition-delay: .3s; }
.reveal-delay-4{ transition-delay: .4s; }
.reveal-delay-5{ transition-delay: .5s; }

/* ------------ Sections ------------ */
main section{
  padding: 140px 0;
  position: relative;
}
.section-head{ max-width: 780px; margin: 0 0 72px; }

h2{
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(36px, 5.5vw, 64px);
  line-height: 1.08; letter-spacing: -0.025em;
  margin: 0 0 20px;
  font-variation-settings: "opsz" 144;
  color: var(--cream);
}
h2 em{ font-style: italic; color: var(--amber-glow); font-weight: 400; }
h3{
  font-family: var(--serif); font-weight: 500; font-size: 24px;
  margin: 0 0 12px; letter-spacing: -0.01em; color: var(--cream);
}
p{ color: var(--cream-muted); }

.section-eyebrow{
  font-size: 11px; letter-spacing: .3em; text-transform: uppercase;
  color: var(--amber); font-weight: 600;
  margin-bottom: 24px; display: inline-flex; align-items: center; gap: 12px;
}
.section-eyebrow::before{
  content: ""; display: inline-block; width: 24px; height: 1px;
  background: var(--amber);
}
.section-head p{ color: var(--cream-muted); font-size: 19px; max-width: 60ch; }

/* ------------ Featured projects grid (Home) ------------ */
.projects-grid{
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 18px;
}
.project-card{
  position: relative; overflow: hidden;
  border-radius: var(--radius);
  background: var(--dark-2);
  cursor: pointer;
  transition: transform .6s var(--ease-out);
}
.project-card.span-5 { grid-column: span 5; }
.project-card.span-7 { grid-column: span 7; }
.project-card.span-6 { grid-column: span 6; }
.project-card.span-4 { grid-column: span 4; }
.project-card.span-8 { grid-column: span 8; }
.project-card.span-12{ grid-column: span 12; }
.project-card.ratio-wide { aspect-ratio: 16/9; }
.project-card.ratio-portrait { aspect-ratio: 3/4; }
.project-card.ratio-square { aspect-ratio: 1/1; }
.project-card.ratio-cinema { aspect-ratio: 21/9; }

.project-visual{
  position: absolute; inset: 0;
  transition: transform 1.4s var(--ease-out);
}
.project-card:hover .project-visual{ transform: scale(1.06); }
.project-card::after{
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(10,8,7,.8) 100%);
  z-index: 1; transition: opacity .5s;
}
.project-card:hover::after{ opacity: .6; }

.project-meta{
  position: absolute; left: 28px; right: 28px; bottom: 24px;
  z-index: 2; color: var(--cream);
  transform: translateY(8px);
  transition: transform .5s var(--ease-out);
}
.project-card:hover .project-meta{ transform: translateY(0); }
.project-meta .cat{
  font-size: 10px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--amber-glow); font-weight: 500; margin-bottom: 8px;
}
.project-meta h3{
  font-size: clamp(22px, 2.2vw, 28px);
  font-weight: 400; color: var(--cream);
  margin: 0 0 4px;
}
.project-meta .location{
  font-family: var(--serif); font-style: italic;
  color: var(--cream-muted); font-size: 15px;
}
.project-play{
  position: absolute; top: 20px; right: 20px; z-index: 2;
  width: 48px; height: 48px; border-radius: 999px;
  background: rgba(10,8,7,.5); backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--hairline-strong);
  display: flex; align-items: center; justify-content: center;
  transition: background .3s, transform .3s var(--ease-out);
}
.project-card:hover .project-play{ background: var(--amber); transform: scale(1.08); }
.project-play::before{
  content: ""; display: block;
  border-left: 11px solid var(--cream);
  border-top: 7px solid transparent; border-bottom: 7px solid transparent;
  margin-left: 3px;
  transition: border-left-color .3s;
}
.project-card:hover .project-play::before{ border-left-color: var(--dark); }

/* Visual placeholders (swap with imagery) */
.pv-1{ background: radial-gradient(ellipse at 30% 30%, rgba(240,200,152,.55), transparent 55%), linear-gradient(135deg, #3a281a 0%, #13100d 100%); }
.pv-2{ background: radial-gradient(ellipse at 60% 50%, rgba(232,184,160,.5), transparent 60%), linear-gradient(160deg, #4a2e22 0%, #1a1310 100%); }
.pv-3{ background: radial-gradient(ellipse at 50% 30%, rgba(246,241,234,.45), transparent 60%), linear-gradient(180deg, #8a6e58 0%, #2a1f18 100%); }
.pv-4{ background: radial-gradient(ellipse at 40% 60%, rgba(212,165,116,.6), transparent 60%), linear-gradient(120deg, #2a1a12 0%, #0a0807 100%); }
.pv-5{ background: radial-gradient(ellipse at 70% 40%, rgba(168,184,200,.35), transparent 55%), linear-gradient(140deg, #3a2e28 0%, #1a1310 100%); }
.pv-6{ background: radial-gradient(ellipse at 50% 50%, rgba(240,200,152,.4), transparent 60%), linear-gradient(160deg, #d6c5b3 0%, #3a2a20 100%); }
.pv-7{ background: radial-gradient(ellipse at 20% 80%, rgba(232,184,160,.5), transparent 55%), linear-gradient(135deg, #5a3d2a 0%, #13100d 100%); }
.pv-8{ background: radial-gradient(ellipse at 60% 40%, rgba(240,200,152,.35), transparent 60%), linear-gradient(180deg, #4c342a 0%, #0a0807 100%); }

/* ------------ Signature reel ------------ */
.reel-wrap{
  position: relative; border-radius: var(--radius-lg); overflow: hidden;
  background: #000; aspect-ratio: 21/9;
  box-shadow: 0 40px 100px -40px rgba(0,0,0,.7);
}
.reel-poster{
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse at 30% 40%, rgba(240,200,152,.55), transparent 55%),
    radial-gradient(ellipse at 70% 60%, rgba(212,165,116,.4), transparent 65%),
    linear-gradient(135deg, #2a1f18 0%, #0a0807 100%);
  transition: transform .8s var(--ease-out), filter .6s;
}
.reel-poster::after{
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,.55) 100%);
}
.reel-wrap:hover .reel-poster{ transform: scale(1.03); filter: brightness(1.08); }

.reel-meta{
  position: absolute; left: 36px; bottom: 32px; right: 36px; z-index: 3;
  color: var(--cream);
  display: flex; align-items: flex-end; justify-content: space-between; gap: 24px;
}
.reel-meta h3{ font-size: clamp(24px, 2.6vw, 34px); color: var(--cream); margin: 0 0 4px; font-weight: 400; }
.reel-meta p{ font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--cream-faint); margin: 0; }
.reel-meta .duration{ font-family: var(--serif); font-style: italic; font-size: 17px; color: var(--cream-muted); }
.play-btn{
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%); z-index: 3;
  width: 104px; height: 104px; border-radius: 999px;
  background: rgba(246,241,234,.08);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(246,241,234,.3);
  display: flex; align-items: center; justify-content: center;
  transition: transform .35s var(--ease-out), background .3s, border-color .3s;
}
.play-btn::before{
  content: ""; display: block;
  border-left: 22px solid var(--cream);
  border-top: 14px solid transparent; border-bottom: 14px solid transparent;
  margin-left: 7px; transition: border-left-color .3s;
}
.reel-wrap:hover .play-btn{
  transform: translate(-50%, -50%) scale(1.1);
  background: var(--amber); border-color: var(--amber);
}
.reel-wrap:hover .play-btn::before{ border-left-color: var(--dark); }
.reel-ring{
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 104px; height: 104px; border-radius: 999px;
  border: 1px solid rgba(246,241,234,.35);
  animation: ring 3s ease-out infinite;
  pointer-events: none; z-index: 2;
}
@keyframes ring{
  0% { transform: translate(-50%, -50%) scale(1); opacity: .55; }
  100% { transform: translate(-50%, -50%) scale(2); opacity: 0; }
}

/* ------------ Brand story (two-col) ------------ */
.story-wrap{ display: grid; grid-template-columns: 1fr 1.2fr; gap: 96px; align-items: start; }
.story-visual{
  position: relative; aspect-ratio: 3/4; border-radius: var(--radius);
  overflow: hidden;
  background:
    radial-gradient(ellipse at 40% 30%, rgba(240,200,152,.5), transparent 60%),
    radial-gradient(ellipse at 70% 80%, rgba(212,165,116,.35), transparent 65%),
    linear-gradient(160deg, #3a281a 0%, #13100d 100%);
}
.story-visual::after{
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, transparent 35%, rgba(0,0,0,.4) 100%);
}
.story-badge{
  position: absolute; bottom: 24px; left: 24px; z-index: 1;
  padding: 12px 18px; border-radius: 999px;
  background: rgba(10,8,7,.7); backdrop-filter: blur(10px);
  color: var(--cream); font-size: 11px; letter-spacing: .22em;
  text-transform: uppercase; font-weight: 500;
  border: 1px solid var(--hairline-strong);
}
.story-prose{ padding-top: 40px; }
.story-prose p{
  font-size: 18px; line-height: 1.75; color: var(--cream-muted);
  margin: 0 0 22px;
}
.story-prose p.lead-para{
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(22px, 2.2vw, 28px); color: var(--cream);
  line-height: 1.4; letter-spacing: -0.01em;
  font-variation-settings: "opsz" 144;
  margin-bottom: 28px;
}
.story-prose p.lead-para em{ font-style: italic; color: var(--amber-glow); }
.story-signature{
  margin-top: 32px; font-family: var(--serif); font-style: italic;
  font-size: 20px; color: var(--cream);
}
.story-signature .role{
  display: block; font-style: normal; font-family: var(--sans);
  font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--cream-faint); margin-top: 4px; font-weight: 500;
}

/* ------------ Stats ------------ */
.stats-row{
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px;
  padding: 48px 0;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
}
.stat-item{ text-align: left; }
.stat-item .n{
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(44px, 5vw, 72px); line-height: 1;
  color: var(--cream); letter-spacing: -0.03em;
  font-variation-settings: "opsz" 144;
  display: block; margin-bottom: 12px;
}
.stat-item .n em{ font-style: italic; color: var(--amber-glow); font-weight: 400; }
.stat-item .l{
  font-size: 12px; letter-spacing: .2em; text-transform: uppercase;
  color: var(--cream-faint); font-weight: 500;
}

/* ------------ Testimonials ------------ */
.testi-section{ background: var(--dark); padding: 160px 0; overflow: hidden; position: relative; }
.testi-section::before{
  content: ""; position: absolute; inset: -10%;
  background:
    radial-gradient(ellipse at 25% 50%, rgba(212,165,116,.15), transparent 55%),
    radial-gradient(ellipse at 75% 50%, rgba(240,200,152,.1), transparent 60%);
  animation: heroShift 28s ease-in-out infinite alternate;
  pointer-events: none;
}
.testi-section .wrap{ position: relative; z-index: 1; }
.testi-grid{ display: grid; grid-template-columns: 1fr 1fr; gap: 56px; }
.testi-card{
  padding: 48px 40px; border-radius: var(--radius);
  background: rgba(246,241,234,.03);
  border: 1px solid var(--hairline);
  transition: transform .5s var(--ease-out), border-color .3s, background .3s;
}
.testi-card:hover{ transform: translateY(-4px); border-color: var(--hairline-strong); background: rgba(246,241,234,.05); }
.testi-quote-mark{
  font-family: var(--serif); font-style: italic;
  font-size: 60px; line-height: .5;
  color: var(--amber-glow); opacity: .5;
  margin-bottom: 24px; display: block;
}
.testi-card p{
  font-family: var(--serif); font-weight: 300;
  font-size: 22px; line-height: 1.5; color: var(--cream);
  margin: 0 0 28px; letter-spacing: -0.01em;
}
.testi-attr{ font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--cream-faint); font-weight: 500; }
.testi-attr::before{
  content: ""; display: inline-block; width: 28px; height: 1px;
  background: var(--amber-glow); vertical-align: middle;
  margin-right: 12px; transform: translateY(-2px);
}

/* ------------ CTA band ------------ */
.cta-section{ padding: 140px 0; }
.cta-band{
  background: var(--dark); color: var(--cream);
  border-radius: var(--radius-lg); padding: 96px 72px;
  text-align: center; position: relative; overflow: hidden;
  box-shadow: 0 50px 100px -40px rgba(0,0,0,.6);
  border: 1px solid var(--hairline);
}
.cta-band::before{
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 30%, rgba(212,165,116,.35), transparent 45%),
    radial-gradient(circle at 80% 70%, rgba(240,200,152,.22), transparent 50%);
  animation: heroShift 18s ease-in-out infinite alternate;
}
.cta-band > *{ position: relative; z-index: 1; }
.cta-band h2{ color: var(--cream); margin-bottom: 20px; }
.cta-band p{
  color: var(--cream-muted); max-width: 600px;
  margin: 0 auto 36px; font-size: 19px; line-height: 1.55;
}

/* ------------ Footer ------------ */
footer.site{
  background: var(--black); color: var(--cream-muted);
  padding: 96px 0 48px; border-top: 1px solid var(--hairline);
}
.foot{ display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 56px; }
.foot h4{
  font-family: var(--sans); text-transform: uppercase;
  font-size: 11px; letter-spacing: .25em;
  color: var(--cream-faint); margin: 0 0 22px; font-weight: 600;
}
.foot ul{ list-style: none; padding: 0; margin: 0; }
.foot li{ margin-bottom: 14px; }
.foot a{ color: var(--cream-muted); font-size: 15px; }
.foot a:hover{ color: var(--amber-glow); }
.foot .brand{ font-size: 24px; color: var(--cream); }
.foot .tag{
  color: var(--cream-faint); font-size: 15px;
  margin-top: 16px; max-width: 320px; line-height: 1.65;
}
.legal{
  border-top: 1px solid var(--hairline); margin-top: 64px; padding-top: 28px;
  display: flex; justify-content: space-between;
  color: var(--cream-faint); font-size: 12px; letter-spacing: .04em;
}
.legal a{ color: var(--cream-faint); }

/* ============================================================
   PORTFOLIO PAGE SPECIFIC
   ============================================================ */
.page-top{ padding: 200px 0 80px; background: var(--black); position: relative; overflow: hidden; }
.page-top::before{
  content: ""; position: absolute; inset: -10%;
  background:
    radial-gradient(ellipse at 20% 30%, rgba(240,200,152,.12), transparent 55%),
    radial-gradient(ellipse at 80% 70%, rgba(212,165,116,.08), transparent 60%);
  animation: heroShift 24s ease-in-out infinite alternate;
  pointer-events: none;
}
.page-top .wrap{ position: relative; z-index: 1; }
.page-top h1{
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(48px, 8vw, 104px);
  line-height: 1.02; letter-spacing: -0.03em;
  margin: 0 0 24px; max-width: 15ch;
  font-variation-settings: "opsz" 144;
}
.page-top h1 em{ font-style: italic; color: var(--amber-glow); font-weight: 400; }
.page-top .lead{ animation: none; opacity: 1; transform: none; max-width: 640px; font-size: 20px; }

.portfolio-filters{
  display: flex; flex-wrap: wrap; gap: 10px;
  margin: 48px 0 64px;
  padding-top: 32px;
  border-top: 1px solid var(--hairline);
}
.filter-btn{
  padding: 10px 22px; border-radius: 999px;
  background: transparent; color: var(--cream-muted);
  border: 1px solid var(--hairline);
  font-size: 13px; letter-spacing: .06em;
  cursor: pointer;
  transition: background .25s, color .25s, border-color .25s, transform .2s var(--ease-out);
}
.filter-btn:hover{ color: var(--cream); border-color: var(--hairline-strong); transform: translateY(-2px); }
.filter-btn.active{ background: var(--amber); color: var(--dark); border-color: var(--amber); }

.portfolio-grid{
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 18px;
}
.portfolio-grid .project-card{
  animation: fadeIn .6s var(--ease-out) both;
}
.portfolio-grid .project-card.hidden{ display: none; }
@keyframes fadeIn{ from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }

/* ------------ Video modal ------------ */
.video-modal{
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(7,6,5,.92); backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  display: none; align-items: center; justify-content: center;
  padding: 40px;
  opacity: 0; transition: opacity .4s ease;
}
.video-modal.open{ display: flex; }
.video-modal.visible{ opacity: 1; }
.video-modal-inner{
  position: relative; width: 100%; max-width: 1200px;
  aspect-ratio: 16/9; background: #000;
  border-radius: var(--radius); overflow: hidden;
  transform: scale(.95); transition: transform .5s var(--ease-out);
  box-shadow: 0 60px 120px -40px rgba(0,0,0,.8);
}
.video-modal.visible .video-modal-inner{ transform: scale(1); }
.video-modal-inner iframe{
  position: absolute; inset: 0; width: 100%; height: 100%; border: 0;
}
.video-modal-placeholder{
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  color: var(--cream-muted); gap: 16px;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(240,200,152,.3), transparent 60%),
    linear-gradient(135deg, #2a1f18 0%, #0a0807 100%);
}
.video-modal-placeholder .play-btn{ position: static; transform: none; }
.video-modal-placeholder p{ font-family: var(--serif); font-style: italic; font-size: 18px; margin: 0; }
.video-modal-close{
  position: absolute; top: 24px; right: 24px; z-index: 2;
  width: 48px; height: 48px; border-radius: 999px;
  background: rgba(246,241,234,.1); color: var(--cream);
  backdrop-filter: blur(10px); border: 1px solid var(--hairline-strong);
  display: flex; align-items: center; justify-content: center; font-size: 20px;
  transition: background .3s, transform .3s;
}
.video-modal-close:hover{ background: var(--amber); color: var(--dark); transform: rotate(90deg); }

/* ============================================================
   ORDER PAGE SPECIFIC
   ============================================================ */
.order-shell{ background: var(--black); padding: 180px 0 140px; position: relative; overflow: hidden; }
.order-shell::before{
  content: ""; position: absolute; inset: -10%;
  background:
    radial-gradient(ellipse at 10% 20%, rgba(240,200,152,.08), transparent 55%),
    radial-gradient(ellipse at 90% 80%, rgba(212,165,116,.06), transparent 60%);
  pointer-events: none;
}
.order-shell .wrap{ position: relative; z-index: 1; }
.order-shell h1{
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(44px, 7vw, 88px); line-height: 1.04;
  letter-spacing: -0.025em; margin: 0 0 20px;
  font-variation-settings: "opsz" 144;
}
.order-shell h1 em{ font-style: italic; color: var(--amber-glow); font-weight: 400; }

/* Step indicator */
.steps{
  display: flex; gap: 0; margin: 56px 0 64px;
  border-top: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  padding: 28px 0;
}
.step-item{
  flex: 1; display: flex; align-items: center; gap: 14px;
  color: var(--cream-faint); transition: color .3s;
  position: relative;
}
.step-item:not(:last-child)::after{
  content: ""; display: block; flex: 1; height: 1px;
  background: var(--hairline); margin: 0 14px;
}
.step-item.active, .step-item.done{ color: var(--cream); }
.step-num{
  width: 36px; height: 36px; border-radius: 999px;
  background: transparent; border: 1px solid var(--hairline);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 15px; color: var(--cream-faint);
  transition: all .35s var(--ease-out);
  flex-shrink: 0;
}
.step-item.active .step-num{ background: var(--amber); color: var(--dark); border-color: var(--amber); }
.step-item.done .step-num{ background: var(--amber-deep); color: var(--cream); border-color: var(--amber-deep); }
.step-label{ font-size: 12px; letter-spacing: .2em; text-transform: uppercase; font-weight: 500; }

/* Panels (each step) */
.order-panel{ display: none; animation: panelIn .6s var(--ease-out) both; }
.order-panel.active{ display: block; }
@keyframes panelIn{ from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }

/* Video type grid */
.video-types{
  display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px; margin-top: 40px;
}
.vtype-card{
  position: relative; padding: 28px;
  border-radius: var(--radius);
  background: rgba(246,241,234,.025);
  border: 1px solid var(--hairline);
  cursor: pointer;
  transition: all .35s var(--ease-out);
  text-align: left;
  color: var(--cream); display: block;
}
.vtype-card:hover{
  background: rgba(246,241,234,.05);
  border-color: var(--hairline-strong);
  transform: translateY(-3px);
  box-shadow: 0 20px 40px -20px rgba(0,0,0,.5);
}
.vtype-card.selected{
  background: rgba(212,165,116,.08);
  border-color: var(--amber);
  box-shadow: 0 0 0 1px var(--amber), 0 24px 60px -20px rgba(212,165,116,.25);
}
.vtype-card input[type="radio"]{
  position: absolute; opacity: 0; pointer-events: none;
}
.vtype-badge{
  display: inline-block; padding: 5px 12px; border-radius: 999px;
  background: rgba(212,165,116,.15); color: var(--amber-glow);
  font-size: 10px; letter-spacing: .22em; text-transform: uppercase;
  font-weight: 500; margin-bottom: 18px;
}
.vtype-card h3{
  font-size: 22px; font-weight: 400; margin: 0 0 6px;
  letter-spacing: -0.01em; color: var(--cream);
}
.vtype-duration{
  font-family: var(--serif); font-style: italic;
  color: var(--amber-glow); font-size: 15px; margin-bottom: 14px;
}
.vtype-desc{
  font-size: 14px; color: var(--cream-muted);
  line-height: 1.6; margin: 0 0 20px;
}
.vtype-meta{
  display: flex; justify-content: space-between; align-items: flex-end;
  padding-top: 18px; border-top: 1px solid var(--hairline);
}
.vtype-price{
  font-family: var(--serif); font-size: 26px; font-weight: 400;
  color: var(--cream); letter-spacing: -0.01em;
  font-variation-settings: "opsz" 144;
}
.vtype-price .from{
  font-size: 10px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--cream-faint); display: block; margin-bottom: 2px;
  font-family: var(--sans); font-weight: 500;
}
.vtype-delivery{
  font-size: 12px; letter-spacing: .1em;
  color: var(--cream-faint); text-align: right;
}
.vtype-delivery .d-label{
  display: block; font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; margin-bottom: 4px; font-weight: 500;
}
.vtype-check{
  position: absolute; top: 20px; right: 20px;
  width: 28px; height: 28px; border-radius: 999px;
  border: 1px solid var(--hairline-strong);
  display: flex; align-items: center; justify-content: center;
  transition: all .3s;
}
.vtype-card.selected .vtype-check{
  background: var(--amber); border-color: var(--amber);
}
.vtype-check::after{
  content: ""; width: 10px; height: 6px;
  border-left: 2px solid var(--dark); border-bottom: 2px solid var(--dark);
  transform: rotate(-45deg) translate(1px, -1px) scale(0);
  transition: transform .3s var(--ease-out);
}
.vtype-card.selected .vtype-check::after{
  transform: rotate(-45deg) translate(1px, -1px) scale(1);
}

/* Step nav buttons */
.step-nav{
  display: flex; justify-content: space-between; align-items: center;
  gap: 18px; margin-top: 48px; padding-top: 32px;
  border-top: 1px solid var(--hairline);
}
.step-nav .btn-back{
  background: transparent; color: var(--cream-muted);
  padding: 12px 22px; border: 1px solid var(--hairline-strong);
  border-radius: 999px; font-size: 13px; letter-spacing: .06em;
  cursor: pointer; transition: all .25s;
}
.step-nav .btn-back:hover{ background: rgba(246,241,234,.05); color: var(--cream); border-color: var(--cream-faint); }

/* Order form */
.order-form{ display: flex; flex-direction: column; gap: 56px; margin-top: 40px; }

.form-section{
  padding: 32px 0 0;
  border-top: 1px solid var(--hairline);
}
.form-section:first-child{ border-top: none; padding-top: 0; }
.form-section-title{
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(22px, 2.4vw, 28px);
  color: var(--cream); margin: 12px 0 10px;
  letter-spacing: -0.01em;
  font-variation-settings: "opsz" 144;
}
.form-section-desc{
  font-size: 14px; color: var(--cream-muted);
  margin: 0 0 26px; max-width: 60ch; line-height: 1.6;
}

.form-grid{
  display: grid; grid-template-columns: 1fr 1fr; gap: 20px;
}
.form-grid .form-field.full{ grid-column: span 2; }

.form-field{ display: flex; flex-direction: column; }
.form-field.full{ grid-column: span 2; }
.form-field label{
  font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--cream-faint); font-weight: 600; margin-bottom: 10px;
}
.form-field label .req{ color: var(--amber-glow); margin-left: 2px; }
.form-field input[type="text"],
.form-field input[type="email"],
.form-field input[type="tel"],
.form-field input[type="date"],
.form-field input[type="file"],
.form-field select,
.form-field textarea{
  font-family: var(--sans); font-size: 15px;
  padding: 15px 18px; border-radius: var(--radius-sm);
  background: rgba(246,241,234,.04);
  border: 1px solid var(--hairline);
  color: var(--cream);
  transition: border-color .25s, background .25s, box-shadow .25s;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline: none; border-color: var(--amber);
  background: rgba(246,241,234,.06);
  box-shadow: 0 0 0 3px rgba(212,165,116,.15);
}
.form-field textarea{ min-height: 130px; resize: vertical; line-height: 1.55; }
.form-field input::placeholder,
.form-field textarea::placeholder{ color: rgba(246,241,234,.3); }
.form-field select{ appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path d='M1 1l5 5 5-5' stroke='%23d4a574' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>"); background-repeat: no-repeat; background-position: right 18px center; padding-right: 44px; cursor: pointer; }
.form-field select option{ background: var(--dark); color: var(--cream); }
.form-field input[type="file"]{
  padding: 14px 18px; cursor: pointer;
  font-family: var(--sans); color: var(--cream-muted);
}
.form-field input[type="file"]::file-selector-button{
  background: var(--amber); color: var(--dark);
  border: none; padding: 8px 16px; border-radius: 999px;
  font-size: 12px; letter-spacing: .06em; font-weight: 500;
  cursor: pointer; margin-right: 14px;
  transition: background .25s;
}
.form-field input[type="file"]::file-selector-button:hover{ background: var(--amber-glow); }

.style-chips{ display: flex; flex-wrap: wrap; gap: 10px; }
.style-chip{
  padding: 9px 18px; border-radius: 999px;
  background: transparent; color: var(--cream-muted);
  border: 1px solid var(--hairline);
  font-size: 13px; cursor: pointer;
  transition: all .25s;
}
.style-chip:hover{ color: var(--cream); border-color: var(--hairline-strong); }
.style-chip input{ display: none; }
.style-chip.active{
  background: rgba(212,165,116,.15); color: var(--amber-glow);
  border-color: var(--amber);
}

/* Order summary */
.order-summary{
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 32px; margin-top: 40px;
}
.summary-details{
  background: rgba(246,241,234,.03); border: 1px solid var(--hairline);
  border-radius: var(--radius); padding: 36px;
}
.summary-section{ padding: 20px 0; border-bottom: 1px solid var(--hairline); }
.summary-section:last-child{ border-bottom: none; }
.summary-section h4{
  font-family: var(--sans); font-size: 10px; letter-spacing: .28em;
  text-transform: uppercase; color: var(--cream-faint);
  margin: 0 0 14px; font-weight: 600;
}
.summary-row{ display: flex; justify-content: space-between; gap: 24px; padding: 6px 0; font-size: 15px; }
.summary-row .k{ color: var(--cream-faint); }
.summary-row .v{ color: var(--cream); font-weight: 500; text-align: right; max-width: 70%; }

.summary-price{
  background: var(--dark); border: 1px solid var(--hairline);
  border-radius: var(--radius); padding: 32px; height: fit-content;
  position: sticky; top: 100px;
}
.price-breakdown-row{
  display: flex; justify-content: space-between; padding: 10px 0;
  color: var(--cream-muted); font-size: 15px;
}
.price-total{
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 22px 0; margin-top: 16px;
  border-top: 1px solid var(--hairline-strong);
  border-bottom: 1px solid var(--hairline-strong);
}
.price-total .label{ font-size: 12px; letter-spacing: .22em; text-transform: uppercase; color: var(--cream-faint); font-weight: 500; }
.price-total .amount{
  font-family: var(--serif); font-weight: 300;
  font-size: 44px; color: var(--cream);
  letter-spacing: -0.025em;
  font-variation-settings: "opsz" 144;
}
.pay-options{ margin-top: 28px; display: flex; flex-direction: column; gap: 10px; }
.pay-option{
  display: flex; align-items: center; gap: 14px;
  padding: 16px 18px; border-radius: var(--radius-sm);
  background: rgba(246,241,234,.03);
  border: 1px solid var(--hairline);
  cursor: pointer; transition: all .25s;
}
.pay-option:hover{ border-color: var(--hairline-strong); background: rgba(246,241,234,.05); }
.pay-option.active{ background: rgba(212,165,116,.08); border-color: var(--amber); }
.pay-option input{ display: none; }
.pay-radio{
  width: 20px; height: 20px; border-radius: 999px;
  border: 1px solid var(--hairline-strong);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: border-color .2s;
}
.pay-option.active .pay-radio{ border-color: var(--amber); }
.pay-radio::after{
  content: ""; width: 10px; height: 10px; border-radius: 999px;
  background: var(--amber); transform: scale(0); transition: transform .25s var(--ease-out);
}
.pay-option.active .pay-radio::after{ transform: scale(1); }
.pay-option-content{ flex: 1; }
.pay-option-content .t{ font-size: 14px; color: var(--cream); font-weight: 500; }
.pay-option-content .s{ font-size: 12px; color: var(--cream-faint); margin-top: 2px; }
.pay-amount{ font-family: var(--serif); font-size: 18px; color: var(--cream); font-variation-settings: "opsz" 144; }

/* --- Add-on (rush turnaround) --- */
.addons{ margin-top: 28px; padding-top: 24px; border-top: 1px dashed var(--hairline); }
.addons-head{ margin-bottom: 14px; }
.addons-head .section-eyebrow{ display: inline-block; }
.addons-title{
  font-family: var(--serif); font-weight: 400;
  font-size: 18px; color: var(--cream);
  margin: 6px 0 0; letter-spacing: -0.01em;
  font-variation-settings: "opsz" 144;
}
.addon-toggle{
  display: flex; align-items: flex-start; gap: 14px;
  padding: 16px 18px; border-radius: var(--radius-sm);
  background: rgba(246,241,234,.03);
  border: 1px solid var(--hairline);
  cursor: pointer; transition: all .25s;
  position: relative;
}
.addon-toggle:hover{ border-color: var(--hairline-strong); background: rgba(246,241,234,.05); }
.addon-toggle.active{ background: rgba(212,165,116,.08); border-color: var(--amber); }
.addon-toggle input{ position: absolute; opacity: 0; width: 0; height: 0; }
.addon-check{
  width: 20px; height: 20px; border-radius: 6px;
  border: 1px solid var(--hairline-strong);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: all .2s;
  margin-top: 2px;
}
.addon-toggle.active .addon-check{ border-color: var(--amber); background: var(--amber); }
.addon-check::after{
  content: ""; width: 10px; height: 6px;
  border-left: 2px solid var(--dark);
  border-bottom: 2px solid var(--dark);
  transform: rotate(-45deg) scale(0);
  transition: transform .25s var(--ease-out);
  margin-top: -2px;
}
.addon-toggle.active .addon-check::after{ transform: rotate(-45deg) scale(1); }
.addon-body{ flex: 1; }
.addon-body .addon-t{ font-size: 14px; color: var(--cream); font-weight: 500; }
.addon-body .addon-s{ font-size: 12px; color: var(--cream-faint); margin-top: 4px; line-height: 1.55; }
.addon-price{
  font-family: var(--serif); font-size: 18px; color: var(--cream);
  font-variation-settings: "opsz" 144; white-space: nowrap;
  flex-shrink: 0;
}

.checkout-btn{
  width: 100%; margin-top: 24px;
  padding: 18px 24px; border-radius: var(--radius-sm);
  background: var(--amber); color: var(--dark);
  font-family: var(--sans); font-weight: 600;
  font-size: 14px; letter-spacing: .12em; text-transform: uppercase;
  cursor: pointer; border: none;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  transition: all .25s var(--ease-out);
  box-shadow: 0 20px 40px -16px rgba(212,165,116,.4);
}
.checkout-btn:hover{ background: var(--amber-glow); transform: translateY(-2px); box-shadow: 0 24px 48px -14px rgba(240,200,152,.55); }
.checkout-btn .arrow{ display: inline-block; transition: transform .25s var(--ease-out); }
.checkout-btn:hover .arrow{ transform: translateX(4px); }
.secure-note{
  margin-top: 18px; text-align: center;
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase;
  color: var(--cream-faint);
}
.secure-note .lock{ display: inline-block; margin-right: 6px; }

/* ============================================================
   FAQ PAGE
   ============================================================ */
.faq-layout{
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 72px;
  margin-top: 72px;
  align-items: start;
}
.faq-toc{
  position: sticky; top: 120px;
  padding-right: 20px;
  border-right: 1px solid var(--hairline);
}
.faq-toc .section-eyebrow{ margin-bottom: 20px; }
.faq-toc ul{ list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.faq-toc a{
  display: block; font-size: 13px; color: var(--cream-muted);
  letter-spacing: .02em; line-height: 1.5;
  transition: color .2s; padding: 4px 0;
}
.faq-toc a:hover{ color: var(--cream); }
.faq-toc a.active{ color: var(--amber); }

.faq-groups{ display: flex; flex-direction: column; gap: 80px; }
.faq-group h2{
  font-family: var(--serif); font-weight: 300;
  font-size: clamp(28px, 3.2vw, 40px);
  color: var(--cream);
  margin: 0 0 16px; letter-spacing: -0.02em;
  font-variation-settings: "opsz" 144;
  scroll-margin-top: 120px;
}
.faq-group h2 em{ font-style: italic; color: var(--amber); font-weight: 300; }
.faq-group-desc{
  font-size: 15px; color: var(--cream-muted);
  line-height: 1.7; margin: 0 0 28px;
  max-width: 62ch;
}

.faq-list{ display: flex; flex-direction: column; gap: 14px; }
.faq-item{
  background: rgba(246,241,234,.03);
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  overflow: hidden;
  transition: border-color .25s, background .25s;
}
.faq-item:hover{ border-color: var(--hairline-strong); }
.faq-item[open]{ border-color: var(--amber); background: rgba(212,165,116,.04); }

.faq-item summary{
  list-style: none;
  cursor: pointer;
  padding: 24px 28px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(16px, 1.6vw, 19px);
  color: var(--cream);
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px;
  letter-spacing: -0.005em;
  font-variation-settings: "opsz" 144;
}
.faq-item summary::-webkit-details-marker{ display: none; }
.faq-item summary::marker{ content: ''; }
.faq-item .faq-q{ flex: 1; }
.faq-item .faq-ind{
  width: 26px; height: 26px; flex-shrink: 0;
  border: 1px solid var(--hairline-strong);
  border-radius: 999px;
  display: flex; align-items: center; justify-content: center;
  color: var(--amber); font-size: 16px; line-height: 1;
  font-weight: 300;
  transition: transform .3s var(--ease-out), border-color .2s, background .2s, color .2s;
}
.faq-item:hover .faq-ind{ border-color: var(--amber); }
.faq-item[open] .faq-ind{
  transform: rotate(45deg);
  border-color: var(--amber);
  background: var(--amber);
  color: var(--dark);
}

.faq-a{
  padding: 0 28px 28px;
  color: var(--cream-muted);
  line-height: 1.75;
  font-size: 15px;
  font-family: var(--sans);
}
.faq-a p{ margin: 0 0 14px; }
.faq-a p:last-child{ margin-bottom: 0; }
.faq-a strong{ color: var(--cream); font-weight: 500; }
.faq-a a{ color: var(--amber); border-bottom: 1px solid rgba(212,165,116,.3); transition: border-color .2s; }
.faq-a a:hover{ border-color: var(--amber); }
.faq-a ul{ padding-left: 20px; margin: 0 0 14px; }
.faq-a ul li{ margin-bottom: 6px; }
.faq-a ul li:last-child{ margin-bottom: 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px){
  .projects-grid .project-card.span-5,
  .projects-grid .project-card.span-7,
  .projects-grid .project-card.span-6,
  .projects-grid .project-card.span-4,
  .projects-grid .project-card.span-8 { grid-column: span 6; }
  .story-wrap { grid-template-columns: 1fr; gap: 48px; }
  .story-visual { max-width: 480px; }
  .stats-row { grid-template-columns: repeat(2, 1fr); }
  .order-summary { grid-template-columns: 1fr; }
  .summary-price { position: static; }
}
@media (max-width: 860px){
  .wrap { padding: 0 22px; }
  main section { padding: 80px 0; }
  .nav ul { display: none; }
  .mobile-toggle { display: inline-flex; }
  .cta-btn.hero-cta-mobile-hide { display: none; }
  .nav > .cta-btn { display: none; }

  .projects-grid,
  .portfolio-grid { grid-template-columns: 1fr !important; }
  .projects-grid .project-card,
  .portfolio-grid .project-card { grid-column: span 1 !important; }
  .project-card.ratio-cinema,
  .project-card.ratio-wide { aspect-ratio: 4/3; }

  .testi-grid { grid-template-columns: 1fr; gap: 24px; }
  .cta-band { padding: 56px 28px; }
  .cta-section { padding: 80px 0; }
  .foot { grid-template-columns: 1fr 1fr; gap: 40px; }
  .legal { flex-direction: column; gap: 12px; }

  .order-form { gap: 40px; }
  .form-grid { grid-template-columns: 1fr; }
  .form-grid .form-field.full { grid-column: span 1; }
  .form-field.full { grid-column: span 1; }
  .order-shell { padding: 130px 0 80px; }
  .page-top { padding: 130px 0 60px; }

  .steps { flex-direction: column; gap: 14px; border: none; padding: 12px 0; }
  .step-item:not(:last-child)::after { display: none; }

  .faq-layout { grid-template-columns: 1fr; gap: 40px; margin-top: 48px; }
  .faq-toc { position: static; padding: 0 0 24px; border-right: none; border-bottom: 1px solid var(--hairline); }
  .faq-toc ul { flex-direction: row; flex-wrap: wrap; gap: 10px 22px; }
  .faq-groups { gap: 56px; }
  .faq-item summary { padding: 20px 22px; gap: 16px; }
  .faq-a { padding: 0 22px 22px; }

  .reel-meta { left: 20px; right: 20px; bottom: 20px; flex-direction: column; align-items: flex-start; gap: 8px; }
  .play-btn, .reel-ring { width: 72px; height: 72px; }
  .play-btn::before { border-left-width: 16px; border-top-width: 10px; border-bottom-width: 10px; }

  .testi-section { padding: 90px 0; }
  .order-shell h1, .page-top h1 { font-size: clamp(40px, 10vw, 72px); }
  .stats-row { grid-template-columns: 1fr 1fr; gap: 20px; padding: 32px 0; }
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .01ms !important;
    scroll-behavior: auto !important;
  }
  .reveal { opacity: 1; transform: none; }
  h1.hero-title .word { opacity: 1; transform: none; filter: none; }
  .letterbox-top, .letterbox-bot { display: none; }
}
