:root{
  --bg: #0c0c0a;
  --ink: #f4f1ea;
  --ink-soft: #d8d3c5;
  --muted: rgba(244,241,234,.5);
  --line: rgba(244,241,234,.16);
  --accent: #c9a86a;
  --accent-warm: #b89765;
  --sans: "Space Grotesk", system-ui, -apple-system, sans-serif;
  --display: "Fraunces", "Times New Roman", serif;
  --serif: "Cormorant Garamond", "EB Garamond", serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
}

*,*::before,*::after{ box-sizing:border-box; }

html, body{ margin:0; padding:0; height:100%;
  background: var(--bg); color: var(--ink);
  font-family: var(--sans); -webkit-font-smoothing:antialiased;
  font-weight: 300; }

body{ overflow: hidden; }

a{ color:inherit; text-decoration:none; }

.mono{ font-family: var(--mono); font-size: 10px; letter-spacing:.18em;
  text-transform: uppercase; font-weight: 400; }

/* ── Top nav ── */
.nav{ position: fixed; top: 0; left: 0; right: 0; z-index: 80;
  display: grid; grid-template-columns: 1fr auto; align-items: center;
  padding: 24px 36px; color: var(--ink);
  font-family: var(--mono); font-size: 10px; letter-spacing: .18em;
  text-transform: uppercase; pointer-events: none;
  font-weight: 400;}
.nav > *{ pointer-events: auto; }
.nav .brand{ display:flex; align-items: center; }
.nav .brand .it{ font-family: var(--serif); font-style: italic; font-weight: 300;
  text-transform: lowercase; color: var(--accent); }
.brand-logo{ height: 24px; width: auto; display: block; }
.brand-logo-mobile{ display: none; }
.nav .links{ display:flex; gap: 28px; justify-self: end; }
.nav .links a{ position: relative; color: var(--ink-soft);
  transition: color .25s; font-weight: 400;}
.nav .links a:hover, .nav .links a.active{ color: var(--accent); }
.nav .right{ justify-self: end; display:flex; gap: 18px; align-items:center;
  color: var(--ink-soft);}
.nav .right a:hover{ color: var(--accent); }

/* ── Reels feed ── */
.feed{ position: fixed; inset: 0; overflow-y: scroll;
  scrollbar-width: none; }
.feed::-webkit-scrollbar{ display: none; }

.reel{ position: relative; width: 100vw; height: 100vh;
  scroll-snap-align: start; scroll-snap-stop: always;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; background: var(--bg); }

/* ── Film reel: full-bleed layout ── */
.reel[data-film]{
  flex-direction: row;
  align-items: stretch;
  justify-content: flex-start; }

/* Full-bleed photo / glow — direct child of reel[data-film] */
.reel[data-film] > .media{
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  z-index: 0; }

/* Gradient: solid black on left → transparent on right */
.reel-fade{
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.45) 0%, transparent 16%),
    linear-gradient(to right,
      var(--bg)               0%,
      var(--bg)               24%,
      rgba(12,12,10,.93)      36%,
      rgba(12,12,10,.58)      52%,
      rgba(12,12,10,.15)      70%,
      transparent             86%); }

/* Content panel — transparent, sits over the gradient */
.reel-left{
  width: 46%; flex-shrink: 0;
  background: transparent;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 80px 52px;
  position: relative; z-index: 2; }

/* Film title — Fraunces display, all-caps */
.film-ttl{
  font-family: var(--display);
  font-size: clamp(72px, 8.5vw, 128px);
  font-weight: 700; font-style: normal;
  line-height: .88; letter-spacing: -.02em;
  text-transform: uppercase; color: var(--ink);
  margin: 0 0 36px; }

/* Film description */
.film-desc{
  font-family: var(--sans); font-weight: 300;
  font-size: clamp(13px, .95vw, 16px); line-height: 1.7;
  color: var(--ink-soft); max-width: 400px; margin: 0 0 44px;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; }

/* Film meta line — SHORT · 34 MIN · 2024 */
.film-meta{
  font-family: var(--mono); font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--muted); font-weight: 400;
  margin: 0 0 22px; }

/* Watch button */
.watch-btn{
  display: inline-block; width: fit-content;
  padding: 14px 36px;
  border: 1px solid var(--ink); background: transparent;
  color: var(--ink); font-family: var(--sans);
  font-size: 13px; font-weight: 300; letter-spacing: .06em;
  cursor: pointer;
  position: relative; overflow: hidden;
  transition: background .25s, color .25s, border-color .25s; }
.watch-btn:hover{
  border-color: var(--accent);
  background: transparent;
  color: var(--accent); }

/* Play ring — overlaid on the photo area */
.play-ring{
  position: absolute;
  left: 73%; top: 50%;
  transform: translate(-50%, -50%);
  width: 76px; height: 76px; border-radius: 50%;
  border: 1px solid rgba(244,241,234,.45);
  background: transparent;
  cursor: pointer; z-index: 3;
  display: flex; align-items: center; justify-content: center;
  opacity: 0;
  transition: opacity .6s ease, border-color .25s, background .25s; }
.play-ring::before{
  content: ''; width: 0; height: 0; margin-left: 5px;
  border-left: 15px solid rgba(244,241,234,.75);
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  transition: border-left-color .25s; }
.reel[data-film].in-view .play-ring{
  opacity: 1; transition-delay: .35s; }
.play-ring:hover{
  border-color: var(--accent);
  background: rgba(201,168,106,.12); }
.play-ring:hover::before{ border-left-color: var(--accent); }

/* Fade-in for split reels */
.reel[data-film] .reel-left{
  opacity: 0; transform: translateY(20px);
  transition: opacity .9s ease, transform .9s cubic-bezier(.2,.8,.2,1); }
.reel[data-film].in-view .reel-left{
  opacity: 1; transform: none; transition-delay: .1s; }

/* Legacy reel chrome (intro / about / outro) */
.reel .media{ position: absolute; inset: 0;
  background-size: cover; background-position: center; }
.reel .media::after{ content:""; position:absolute; inset:0;
  background: radial-gradient(120% 90% at 50% 50%, transparent 30%, rgba(0,0,0,.55) 100%); }
.reel .vignette{ position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.55) 0%, transparent 22%, transparent 70%, rgba(0,0,0,.7) 100%);
  pointer-events:none; }

.reel-meta{ position: absolute; top: 100px; left: 36px; right: 36px;
  display: flex; justify-content: space-between; align-items: flex-start;
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--ink-soft); pointer-events:none;
  font-weight: 400;}
.reel-meta .right{ text-align: right; }

.reel-title{ position: absolute; left: 36px; right: 36px; bottom: 96px;
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 48px; pointer-events: none; }
.reel-title .ttl{ font-family: var(--display); font-weight: 400;
  font-size: clamp(56px, 9.5vw, 168px); line-height: .94;
  letter-spacing: -.018em; margin: 0; max-width: 72%;
  font-feature-settings: "liga" 1, "dlig" 1, "kern" 1;}
.reel-title .ttl .it{ font-family: var(--serif); font-style: italic;
  font-weight: 300; letter-spacing: -.01em; }
.reel-title .ttl .accent{ color: var(--accent); font-style: italic;
  font-family: var(--serif); font-weight: 300; }
.reel-title .info{ text-align: right; max-width: 320px;
  font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(15px, 1.15vw, 18px); line-height: 1.5;
  color: var(--ink-soft); padding-bottom: 12px; }

.reel-foot{ position: absolute; left: 36px; right: 36px; bottom: 32px;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--mono); font-size: 10px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--muted); pointer-events:none;
  font-weight: 400;}
.reel-foot .center{ display:flex; align-items:center; gap: 10px; }
.reel-foot .scroll-cue{ display:inline-flex; align-items:center; gap: 10px;
  color: var(--accent); }
.reel-foot .scroll-cue .arr{ animation: bounce 2s infinite; }
@keyframes bounce{ 0%,100%{transform: translateY(0);} 50%{transform: translateY(3px);} }

/* Progress dots */
.dots{ position: fixed; right: 18px; top: 50%; transform: translateY(-50%);
  display: flex; flex-direction: column; gap: 7px; z-index: 70;
  padding: 10px 6px;}
.dots .dot{ width: 1px; height: 18px;
  background: rgba(244,241,234,.28); transition: all .4s ease; cursor: pointer; }
.dots .dot.active{ background: var(--accent); height: 32px; width: 1px; }
.dots .dot:hover{ background: var(--ink-soft); }

/* Fade-in for intro/about/outro chrome */
.reel .reel-title, .reel .reel-meta, .reel .reel-foot{
  opacity: 0; transform: translateY(14px);
  transition: opacity 1s ease, transform 1s cubic-bezier(.2,.8,.2,1);}
.reel.in-view .reel-title, .reel.in-view .reel-meta, .reel.in-view .reel-foot{
  opacity: 1; transform: none; }
.reel.in-view .reel-title{ transition-delay: .15s; }
.reel.in-view .reel-foot{ transition-delay: .3s; }

/* Video background */
.reel-video{ position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: center; z-index: 0; }

/* YouTube/Vimeo background iframe — oversized to cover + scale to clip branding */
.hero-vimeo{ position: absolute; z-index: 0; pointer-events: none;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%) scale(1.12);
  width: 177.78vh; /* 16/9 * 100vh */
  height: 56.25vw; /* 9/16 * 100vw */
  min-width: 100%; min-height: 100%; }

/* Intro reel — centred hero */
.reel.intro .ttl{ font-size: clamp(56px, 9vw, 148px); max-width: none;
  line-height: .98; letter-spacing: -.022em; text-align: center; }
.reel.intro .reel-title{
  flex-direction: column; align-items: center; gap: 24px;
  bottom: auto; top: 50%; transform: translateY(-50%);
  left: 0; right: 0; text-align: center; }
.reel.intro .info{ text-align: center; max-width: 420px; padding-bottom: 0; }

/* Outro reel */
.reel.outro{ background: var(--bg); }
.reel.outro .media::after{ background: none; }
.reel.outro .ttl{ font-size: clamp(64px, 11vw, 200px); max-width: none;
  letter-spacing: -.022em;}
.reel.outro .channels{ position: absolute; left: 36px; right: 36px; bottom: 96px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 48px;
  border-top: 1px solid var(--line); padding-top: 32px;}
.reel.outro .channels .k{ font-family: var(--mono); font-size: 10px;
  letter-spacing: .22em; text-transform: uppercase; color: var(--muted);
  margin-bottom: 14px; font-weight: 400;}
.reel.outro .channels .v{ font-family: var(--display); font-size: clamp(20px, 1.8vw, 28px);
  font-weight: 400; letter-spacing: -.005em;}
.reel.outro .channels .v.serif{ font-family: var(--serif); font-style: italic;
  font-weight: 300;}
.reel.outro .reel-title{ bottom: auto; top: 38%; transform: translateY(-50%); }

/* About reel */
.reel.about{ background: var(--bg);}
.reel.about .grid{ position: relative; z-index: 2;
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 72px;
  width: min(1280px, 88%); align-items: center;}
.reel.about .portrait{ aspect-ratio: 3/4; overflow: hidden;
  background: #18160f radial-gradient(60% 80% at 50% 30%, rgba(201,168,106,.18), transparent 65%);
  border: 1px solid var(--line);}
.reel.about h2{ font-family: var(--display); font-weight: 400;
  font-size: clamp(40px, 5.6vw, 80px); line-height: 1; margin: 0 0 32px;
  letter-spacing: -.018em;}
.reel.about h2 .it{ font-family: var(--serif); font-style: italic; font-weight: 300; }
.reel.about h2 .accent{ color: var(--accent); font-style: italic;
  font-family: var(--serif); font-weight: 300; }
.reel.about .lead{ font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(17px, 1.35vw, 21px); line-height: 1.5; color: var(--ink-soft);
  max-width: 560px; margin: 0;}
.reel.about .stats{ display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
  margin-top: 48px; padding-top: 28px; border-top: 1px solid var(--line);}
.reel.about .stats .k{ font-family: var(--mono); font-size: 9.5px; letter-spacing:.22em;
  text-transform: uppercase; color: var(--muted); margin-bottom: 10px; font-weight: 400;}
.reel.about .stats .v{ font-family: var(--display); font-size: clamp(22px, 2.1vw, 30px);
  font-weight: 400; letter-spacing: -.005em;}
.reel.about .stats .v.s{ font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(15px, 1.1vw, 18px); line-height: 1.4;}

/* Right panel typographic overlay — #4 */
.reel-overlay{
  position: absolute; inset: 0; pointer-events: none;
  display: flex; flex-direction: column;
  justify-content: flex-end; align-items: flex-start;
  padding: 40px 44px; }
.overlay-year{
  font-family: var(--display); font-weight: 700;
  font-size: clamp(96px, 13vw, 190px);
  line-height: 1; letter-spacing: -.04em;
  color: rgba(244,241,234,.065);
  margin: 0 0 14px; user-select: none; }
.overlay-tags{ display: flex; flex-direction: column; gap: 6px; }
.overlay-tag{
  font-family: var(--mono); font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: rgba(244,241,234,.18); font-weight: 400; }
.overlay-tag::before{ content: '— '; color: var(--accent); }

/* Hero CTA button — #3 */
.hero-cta{
  display: inline-block; margin-top: 40px;
  padding: 16px 44px;
  border: 1px solid rgba(244,241,234,.28); background: transparent;
  color: rgba(244,241,234,.55);
  font-family: var(--mono); font-size: 10px; letter-spacing: .18em;
  text-transform: uppercase; text-decoration: none; cursor: pointer;
  transition: border-color .25s, color .25s; pointer-events: auto; }
.hero-cta:hover{ border-color: var(--accent); color: var(--accent); }

/* ── Film stills — drop still.jpg into assets/films/<slug>/ to activate ── */
/* When a still is present it replaces the ambient glow automatically.     */
/* Uncomment the line below for each film once you have the image.         */

.reel[data-film="0"] > .media { background-image: url('../assets/films/David Guez/Frame 1.png'); }
.reel[data-film="1"] > .media { background-image: url('../assets/films/Ofer Hajayov/Frame 2.png'); }
.reel[data-film="2"] > .media { background-image: url('../assets/films/Zoe Baer/Frame 3.png'); }
.reel[data-film="3"] > .media { background-image: url('../assets/films/Ron Biton/Frame 5.png'); }
.reel[data-film="4"] > .media { background-image: url('../assets/films/Nir Ran/Frame 6.png'); }
/* .reel[data-film="5"] > .media { background-image: url('../assets/films/margin/still.jpg');              }  */
/* .reel[data-film="6"] > .media { background-image: url('../assets/films/the-rehearsal/still.jpg');       }  */
/* .reel[data-film="7"] > .media { background-image: url('../assets/films/stone-on-stone/still.jpg');      }  */
/* .reel[data-film="8"] > .media { background-image: url('../assets/films/night-arabic/still.jpg');        }  */
/* .reel[data-film="9"] > .media { background-image: url('../assets/films/first-light/still.jpg');         }  */

/* Ambient glows */
.glow-1{ background-image:
  radial-gradient(80% 80% at 30% 40%, rgba(184,151,101,.32), transparent 65%),
  linear-gradient(180deg, #1a140c, #0a0805); }
.glow-2{ background-image:
  radial-gradient(70% 70% at 70% 60%, rgba(74,84,98,.4), transparent 60%),
  linear-gradient(180deg, #0e1118, #060708); }
.glow-3{ background-image:
  radial-gradient(70% 70% at 50% 50%, rgba(176,168,148,.28), transparent 65%),
  linear-gradient(180deg, #1c1a14, #0a0907); }
.glow-4{ background-image:
  radial-gradient(80% 80% at 50% 50%, rgba(155,58,44,.32), transparent 60%),
  linear-gradient(180deg, #160808, #080404); }
.glow-5{ background-image:
  radial-gradient(60% 70% at 50% 60%, rgba(90,107,90,.36), transparent 65%),
  linear-gradient(180deg, #0c0e0b, #050706); }
.glow-6{ background-image:
  radial-gradient(70% 70% at 30% 30%, rgba(80,72,98,.36), transparent 60%),
  linear-gradient(180deg, #0d0c12, #050507); }
.glow-7{ background-image:
  radial-gradient(70% 70% at 80% 80%, rgba(120,52,42,.4), transparent 60%),
  linear-gradient(180deg, #110707, #070303); }
.glow-8{ background-image:
  radial-gradient(80% 60% at 50% 20%, rgba(168,138,90,.32), transparent 70%),
  linear-gradient(180deg, #15110a, #0a0805); }
.glow-9{ background-image:
  radial-gradient(60% 60% at 30% 80%, rgba(90,107,90,.32), transparent 65%),
  radial-gradient(60% 60% at 80% 20%, rgba(184,151,101,.22), transparent 65%),
  linear-gradient(180deg, #0c100c, #060807); }
.glow-10{ background-image:
  radial-gradient(60% 60% at 50% 30%, rgba(212,196,158,.22), transparent 70%),
  linear-gradient(180deg, #1a1610, #0a0805); }
.glow-outro{ background-image:
  radial-gradient(60% 60% at 50% 50%, rgba(201,168,106,.14), transparent 70%),
  linear-gradient(180deg, #0c0c0a, #050504); }
.glow-about{ background-image:
  radial-gradient(60% 60% at 80% 50%, rgba(201,168,106,.1), transparent 70%),
  linear-gradient(180deg, #0d0d0b, #050504); }

/* Subtle grain */
.grain{ position: fixed; inset: 0; pointer-events: none; z-index: 90;
  opacity: .055; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 1 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");}

/* ── Play pill — now a button ── */
.play-pill{ all: unset; position: absolute; left: 36px; top: 50%; transform: translateY(-50%);
  display:flex; align-items:center; gap: 14px; cursor: pointer;
  opacity: 0; transition: opacity .6s ease; z-index: 10; }
.reel.in-view .play-pill{ opacity: 1; transition-delay: .25s; }
.play-pill:hover .ring{ background: rgba(244,241,234,.1); border-color: var(--accent); }
.play-pill:hover .lbl{ color: var(--accent); }

/* ── Film modal ── */
.modal{ position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none; }
.modal.open{ pointer-events: auto; }

.modal-backdrop{ position: absolute; inset: 0;
  background: rgba(8,8,6,.88); backdrop-filter: blur(12px);
  opacity: 0; transition: opacity .4s ease; }
.modal.open .modal-backdrop{ opacity: 1; }

.modal-inner{ position: relative; z-index: 1;
  display: grid; grid-template-columns: 1fr 1fr;
  width: min(1180px, 92vw); max-height: 88vh;
  background: #121210; border: 1px solid var(--line);
  overflow: hidden;
  opacity: 0; transform: translateY(24px);
  transition: opacity .4s ease, transform .4s cubic-bezier(.2,.8,.2,1); }
.modal.open .modal-inner{ opacity: 1; transform: none; transition-delay: .06s; }

/* Close button */
.modal-close{ position: absolute; top: 16px; right: 16px; z-index: 10;
  appearance: none; border: none; background: rgba(244,241,234,.08);
  color: var(--ink-soft); width: 36px; height: 36px; border-radius: 50%;
  font-size: 14px; cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s; }
.modal-close:hover{ background: rgba(244,241,234,.15); color: var(--ink); }

/* Video side */
.modal-video-wrap{ position: relative; background: #000;
  display: flex; align-items: center; justify-content: center;
  align-self: stretch;
  background-size: cover; background-position: right center;
  background-repeat: no-repeat;
  transition: background-image .3s; }
/* Dark overlay when still is shown */
.modal-video-wrap.has-still::after{
  content: ''; position: absolute; inset: 0;
  background: rgba(0,0,0,.45); pointer-events: none; }
.vimeo-iframe{ position: absolute; inset: 0; width: 100%; height: 100%; border: none; z-index: 2; }

.modal-video-placeholder{ position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center; flex-direction: column;
  gap: 16px; color: var(--muted); }
.placeholder-inner{ display: flex; flex-direction: column; align-items: center; gap: 18px; }
.placeholder-ring{ width: 64px; height: 64px; border-radius: 50%;
  border: 1px solid rgba(244,241,234,.85);
  display: flex; align-items: center; justify-content: center; }
.placeholder-ring::before{ content:""; width:0; height:0;
  border-left: 12px solid rgba(244,241,234,1);
  border-top: 8px solid transparent; border-bottom: 8px solid transparent;
  margin-left: 4px; }
.placeholder-inner span{ font-family: var(--mono); font-size: 10px;
  letter-spacing: .2em; text-transform: uppercase; color: var(--muted); }

/* Info side */
.modal-info{ padding: 48px 44px; overflow-y: auto;
  display: flex; flex-direction: column; gap: 28px;
  scrollbar-width: thin; scrollbar-color: var(--line) transparent; }

.modal-eyebrow{ font-family: var(--mono); font-size: 10px; letter-spacing: .22em;
  text-transform: uppercase; color: var(--muted); }

.modal-title{ font-family: var(--display); font-weight: 400;
  font-size: clamp(28px, 3.2vw, 48px); line-height: 1;
  letter-spacing: -.018em; margin: 0; color: var(--ink); }

.modal-synopsis{ font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(15px, 1.15vw, 18px); line-height: 1.6;
  color: var(--ink-soft); margin: 0; }

.modal-meta-grid{ display: grid; grid-template-columns: 1fr 1fr;
  gap: 20px 32px; padding-top: 24px; border-top: 1px solid var(--line); }
.modal-meta-cell{}
.modal-meta-k{ font-family: var(--mono); font-size: 9.5px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--muted); margin-bottom: 6px; }
.modal-meta-v{ font-family: var(--serif); font-size: clamp(14px, 1vw, 16px);
  color: var(--ink-soft); font-weight: 300; }

.modal-festivals{ display: flex; flex-direction: column; gap: 10px;
  padding-top: 24px; border-top: 1px solid var(--line); }
.modal-fest-label{ font-family: var(--mono); font-size: 9.5px; letter-spacing: .2em;
  text-transform: uppercase; color: var(--muted); margin-bottom: 4px; }
.modal-fest-item{ font-family: var(--serif); font-style: italic; font-weight: 300;
  font-size: clamp(13px, .95vw, 15px); color: var(--ink-soft); line-height: 1.4; }
.modal-fest-item::before{ content: '— '; color: var(--accent); font-style: normal; }

/* ── Up button ── */
.up-btn {
  position: fixed; bottom: 32px; right: 36px; z-index: 100;
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  background: transparent;
  border: 1px solid var(--line);
  color: var(--ink-soft);
  font-family: var(--mono); font-size: 14px;
  cursor: pointer;
  appearance: none; -webkit-appearance: none;
  outline: none;
  transition: border-color .25s, color .25s, background .25s;
  opacity: 0; pointer-events: none;
  transition: opacity .3s ease, border-color .25s, color .25s;
}
.up-btn.visible { opacity: 1; pointer-events: auto; }
.up-btn:hover { border-color: var(--accent); color: var(--accent); background: rgba(201,168,106,.08); }

/* ── Burger button ── */
.nav-burger {
  display: none !important;
  appearance: none; -webkit-appearance: none;
  flex-direction: column; justify-content: center; gap: 5px;
  cursor: pointer; background: none !important; border: none !important;
  outline: none !important; box-shadow: none !important;
  padding: 4px; margin: 0;
  justify-self: end;
}
.nav-burger span {
  display: block; width: 20px; height: 1px;
  background: var(--ink-soft); transition: transform .25s, opacity .25s;
}
.nav-burger.open span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity: 0; }
.nav-burger.open span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

/* ── Mobile fullscreen menu ── */
.mobile-menu {
  position: fixed; inset: 0; z-index: 140;
  background: var(--bg);
  display: flex; flex-direction: column;
  justify-content: flex-end; padding: 0 28px 80px;
  gap: 4px;
  opacity: 0; pointer-events: none;
  transition: opacity .3s ease;
}
.mobile-menu.open { opacity: 1; pointer-events: auto; }
.mobile-menu a {
  font-family: var(--display); font-weight: 300; font-style: italic;
  font-size: clamp(44px, 14vw, 80px); line-height: 1.05;
  color: var(--ink-soft); transition: color .2s;
}
.mobile-menu a.active,
.mobile-menu a:hover { color: var(--accent); }

/* Responsive */
@media (max-width: 720px){
  /* Logo swap: hide wide logo, show stacked mobile logo */
  .brand-logo{ display: none; }
  .brand-logo-mobile{ display: block; height: 32px; width: auto; }

  /* Snap scroll on mobile (JS wheel doesn't fire on touch) */
  .feed{ scroll-snap-type: y mandatory; }
  .reel{ scroll-snap-align: start; scroll-snap-stop: always; }

  /* Pagination dots hidden on mobile */
  .dots{ display: none; }

  /* 12px side margins everywhere */
  .nav{ padding-left: 12px; padding-right: 12px; }
  .reel-meta{ left: 12px; right: 12px; }
  .reel-title{ left: 12px; right: 12px; }
  .reel-foot{ left: 12px; right: 12px; }
  .reel.outro .channels{ left: 12px; right: 12px; }

  /* Film reels: full-bleed vertical on mobile */
  .reel[data-film]{ flex-direction: column; }

  /* Mobile-specific photos */
  .reel[data-film="0"] > .media{ background-image: url('../assets/films/David Guez/1(mobile).png'); background-position: center; }
  .reel[data-film="1"] > .media{ background-image: url('../assets/films/Ofer Hajayov/2(mobile).png'); background-position: center; }
  .reel[data-film="2"] > .media{ background-image: url('../assets/films/Zoe Baer/3(mobile).png'); background-position: center; }
  .reel[data-film="3"] > .media{ background-image: url('../assets/films/Ron Biton/4(mobile).png'); background-position: center; }
  .reel[data-film="4"] > .media{ background-image: url('../assets/films/Nir Ran/5(mobile).png'); background-position: center; }

  /* Gradient: dark from bottom → transparent at top */
  .reel[data-film] .reel-fade{
    background:
      linear-gradient(to top,
        var(--bg)             0%,
        var(--bg)             28%,
        rgba(12,12,10,.88)    44%,
        rgba(12,12,10,.45)    62%,
        rgba(12,12,10,.1)     80%,
        transparent           94%); }

  /* Content pinned to bottom, full width */
  .reel-left{
    position: absolute; bottom: 0; left: 0; right: 0;
    width: 100%; padding: 0 20px 28px;
    justify-content: flex-end; background: transparent; }

  /* Play ring centered in image */
  .play-ring{ left: 50%; top: 38%; }

  .film-ttl{ font-size: clamp(44px, 13vw, 68px); margin-bottom: 14px; line-height: .9; }
  .film-desc{ font-size: 13px; margin-bottom: 24px; max-width: 100%; }

  /* Watch button full width */
  .watch-btn{ width: 100%; text-align: center; padding: 16px; font-size: 12px; }

  /* Reels */
  .nav .links{ display: none; }
  .nav-burger{ display: flex !important; }
  .reel-title{ flex-direction: column; align-items: flex-start; }
  .reel-title .info{ text-align: left; max-width: 100%; }
  .reel.about .grid{ grid-template-columns: 1fr; gap: 28px; width: calc(100% - 24px); }
  .reel.about .portrait{ aspect-ratio: 4/3; }
  /* Outro: full-height flex column pinned to bottom-left */
  .reel.outro{
    height: 100svh;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: stretch;
    padding: 72px 20px 48px 20px;
  }
  .reel.outro .reel-title{
    position: relative; z-index: 2;
    top: auto; bottom: auto; left: auto; right: auto;
    transform: none;
    flex-shrink: 0;
    margin-bottom: 28px;
  }
  .reel.outro .ttl{ font-size: clamp(52px, 14vw, 80px); }
  .reel.outro .channels{
    position: relative; z-index: 2;
    top: auto; bottom: auto; left: auto; right: auto;
    grid-template-columns: 1fr; gap: 14px;
    border-top: 1px solid var(--line); padding-top: 24px;
    flex-shrink: 0;
  }
  .reel.outro .channels .v{ font-size: clamp(16px, 4.5vw, 22px); }
  .reel.outro .reel-foot{
    position: relative; z-index: 2;
    top: auto; bottom: auto; left: auto; right: auto;
    margin-top: 24px;
  }

  /* Intro hero */
  .reel.intro .reel-title{ left: 12px; right: 12px; text-align: center; }
  .reel.intro .info{ text-align: center; }

  /* Play pill — centred between meta (top) and title (bottom) */
  .play-pill{
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    flex-direction: column;
    align-items: center;
    gap: 10px;
  }
  .reel.in-view .play-pill{ opacity: 1; }

  /* Modal */
  .modal-inner{ grid-template-columns: 1fr; max-height: 95vh; }
  .modal-video-wrap{ min-height: 220px; }
  .modal-info{ padding: 28px 12px; }
  .modal-meta-grid{ grid-template-columns: 1fr; }

  /* Up button — higher on mobile */
  .up-btn{ bottom: 72px !important; right: 20px !important; }
}
