:root{
  --ink:#070d12;
  --ink-2:#0c151c;
  --panel:#101d26;
  --line:rgba(150,190,210,.16);
  --line-soft:rgba(150,190,210,.09);
  --paper:#eef4f6;
  --paper-dim:#9fb4bf;
  --paper-faint:#637884;
  --beam:#6fd4d0;
  --beam-soft:rgba(111,212,208,.16);
  --sea:#3b7e94;
  --display:"Fraunces",Georgia,serif;
  --body:"Hanken Grotesk",system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--ink);
  background-image:
    radial-gradient(140% 80% at 75% -10%,rgba(59,126,148,.18),transparent 55%),
    radial-gradient(120% 90% at 10% 110%,rgba(16,40,52,.6),transparent 50%);
  background-attachment:fixed;
  color:var(--paper);
  font-family:var(--body);
  font-weight:400;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--beam);color:var(--ink)}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}

.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.wrap-narrow{max-width:920px;margin:0 auto;padding:0 32px}
@media(max-width:640px){.wrap,.wrap-narrow{padding:0 20px}}

.eyebrow{
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--paper-faint);font-weight:600;
}

/* NAV */
header.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;
  background:linear-gradient(to bottom,rgba(7,13,18,.92),rgba(7,13,18,0));
  backdrop-filter:blur(2px);
  transition:background .4s ease,border-color .4s ease;
  border-bottom:1px solid transparent;
}
header.nav.solid{
  background:rgba(7,13,18,.95);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:38px;height:38px;object-fit:contain;border-radius:3px}
.brand-name{
  font-family:var(--display);font-weight:500;font-size:16px;
  letter-spacing:.04em;line-height:1.05;
}
.brand-name small{display:block;font-size:9px;letter-spacing:.34em;color:var(--paper-faint);font-family:var(--body);font-weight:600;margin-top:2px}
nav.links{display:flex;gap:34px;align-items:center}
nav.links a{font-size:13px;letter-spacing:.04em;color:var(--paper-dim);transition:color .25s}
nav.links a:hover,nav.links a.active{color:var(--paper)}
nav.links a.cta{
  color:var(--ink);background:var(--paper);padding:9px 18px;border-radius:2px;font-weight:600;
  transition:transform .25s,background .25s;
}
nav.links a.cta:hover{transform:translateY(-1px);background:var(--beam)}
@media(max-width:780px){nav.links a:not(.cta){display:none}}

/* HOMEPAGE HERO */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:flex-end;
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{filter:saturate(.7) contrast(1.1) brightness(.55) hue-rotate(-8deg);transform:scale(1.04);animation:slowzoom 24s ease-out forwards}
@keyframes slowzoom{to{transform:scale(1.12)}}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 80% 10%,var(--beam-soft),transparent 55%),
    linear-gradient(to top,var(--ink) 4%,rgba(7,13,18,.55) 45%,rgba(7,13,18,.35) 100%);
}
.beam{
  position:absolute;top:-10%;left:-20%;width:70%;height:130%;z-index:1;
  background:linear-gradient(100deg,transparent 40%,var(--beam-soft) 50%,transparent 60%);
  mix-blend-mode:screen;opacity:.6;
  animation:sweep 11s ease-in-out infinite;
  pointer-events:none;
}
@keyframes sweep{
  0%,100%{transform:translateX(-10%) rotate(8deg);opacity:.25}
  50%{transform:translateX(60%) rotate(8deg);opacity:.65}
}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:64px}
.hero h1{
  font-family:var(--display);
  font-weight:300;
  font-size:clamp(40px,7vw,92px);
  line-height:.98;
  letter-spacing:-.02em;
  max-width:16ch;
  margin:22px 0 26px;
}
.hero h1 em{font-style:italic;color:var(--beam);font-weight:400}
.hero-lede{
  font-size:clamp(16px,1.5vw,19px);
  color:var(--paper-dim);
  max-width:54ch;line-height:1.6;
}
.hero-meta{
  display:flex;flex-wrap:wrap;gap:28px;margin-top:34px;
  padding-top:26px;border-top:1px solid var(--line);
}
.hero-meta div{display:flex;flex-direction:column;gap:3px}
.hero-meta .k{font-family:var(--display);font-size:24px;font-weight:500;line-height:1}
.hero-meta .l{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--paper-faint)}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.05s}.d2{transition-delay:.15s}.d3{transition-delay:.25s}.d4{transition-delay:.35s}

/* MARQUEE */
.strip{
  border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  background:var(--ink-2);overflow:hidden;padding:18px 0;
}
.marquee{display:flex;gap:56px;white-space:nowrap;animation:scroll 38s linear infinite;width:max-content}
.marquee span{font-family:var(--display);font-style:italic;font-size:18px;color:var(--paper-faint);font-weight:400;display:flex;align-items:center;gap:56px}
.marquee span::after{content:"✦";color:var(--beam);font-style:normal;font-size:11px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* SECTION SHELL */
section.block{padding:120px 0}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:24px;margin-bottom:54px;flex-wrap:wrap}
.sec-head h2{font-family:var(--display);font-weight:400;font-size:clamp(28px,3.4vw,44px);letter-spacing:-.01em;line-height:1}
.sec-head p{color:var(--paper-dim);max-width:40ch;font-size:15px}

/* WORK SLATE */
.slate{display:flex;flex-direction:column;gap:0}
.phase{margin-bottom:64px}
.phase:last-child{margin-bottom:0}
.phase-label{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.phase-label .dot{width:8px;height:8px;border-radius:50%;background:var(--beam)}
.phase-label .dot.prod{background:var(--sea)}
.phase-label .dot.dev{background:var(--paper-faint)}
.phase-label span{font-size:12px;letter-spacing:.26em;text-transform:uppercase;font-weight:600;color:var(--paper-dim)}
.phase-label .rule{flex:1;height:1px;background:var(--line-soft)}

.films{display:grid;gap:26px}
.films.feature{grid-template-columns:repeat(2,1fr)}
.films.three{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.films.feature,.films.three{grid-template-columns:1fr}}

.film{
  position:relative;display:block;border:1px solid var(--line-soft);
  background:var(--panel);overflow:hidden;border-radius:3px;
  transition:border-color .4s,transform .4s;
}
.film:hover{border-color:var(--line);transform:translateY(-3px)}
.film .frame{position:relative;aspect-ratio:16/9;overflow:hidden}
.film .frame img{transition:transform .9s cubic-bezier(.2,.7,.2,1);filter:brightness(.82) saturate(.9)}
.film:hover .frame img{transform:scale(1.06);filter:brightness(.95) saturate(1)}
.film .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(7,13,18,.85),transparent 60%)}
.film .tag{
  position:absolute;top:14px;left:14px;z-index:2;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  background:rgba(7,13,18,.7);border:1px solid var(--line);
  padding:5px 10px;border-radius:2px;backdrop-filter:blur(6px);
}
.film .meta{position:absolute;left:20px;right:20px;bottom:18px;z-index:2}
.film .meta h3{font-family:var(--display);font-weight:500;font-size:clamp(22px,2.4vw,30px);line-height:1;letter-spacing:-.01em}
.film .meta .sub{font-size:13px;color:var(--paper-dim);margin-top:7px;letter-spacing:.02em}
.film .meta .desc{font-size:13.5px;color:var(--paper-dim);margin-top:10px;max-width:50ch;line-height:1.55;opacity:0;max-height:0;transition:opacity .45s,max-height .45s}
.film.feature-card:hover .meta .desc{opacity:1;max-height:120px}

/* Pull quote on project pages */
.synopsis blockquote.pullquote{
  font-family:var(--display);font-style:italic;font-weight:400;
  font-size:clamp(19px,1.7vw,24px);line-height:1.45;
  color:rgba(238,244,246,.92);
  border-left:2px solid var(--beam);
  padding:8px 0 8px 22px;margin:34px 0 12px;
  max-width:680px;
  quotes:"\\201C" "\\201D";
}
.synopsis blockquote.pullquote::before{content:open-quote;color:var(--beam);margin-right:2px}
.synopsis blockquote.pullquote::after{content:close-quote;color:var(--beam);margin-left:2px}

/* Press / In the News grid */
.press{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:900px){.press{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.press{grid-template-columns:1fr}}
.press-item{
  display:flex;flex-direction:column;gap:8px;
  padding:22px 22px 24px;
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,0));
  border:1px solid rgba(255,255,255,.07);
  border-radius:10px;
  text-decoration:none;color:inherit;
  transition:transform .35s ease,border-color .35s ease,background .35s ease;
}
.press-item:hover{
  transform:translateY(-2px);
  border-color:rgba(111,212,208,.35);
  background:linear-gradient(180deg,rgba(111,212,208,.04),rgba(255,255,255,0));
}
.press-item .outlet{
  font-family:var(--ui);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--beam);font-weight:600;
}
.press-item .date{
  font-family:var(--ui);font-size:12px;color:rgba(238,244,246,.55);
  margin-top:-4px;
}
.press-item .head{
  font-family:var(--display);font-weight:500;
  font-size:clamp(17px,1.4vw,20px);line-height:1.3;
  color:var(--paper);margin-top:6px;
}
.press-item .note{
  font-size:13px;line-height:1.5;color:rgba(238,244,246,.65);
  margin-top:auto;padding-top:10px;
}
.press-item .arrow{
  font-family:var(--ui);font-size:12px;color:var(--beam);
  margin-top:8px;opacity:0;transform:translateX(-4px);
  transition:opacity .35s ease,transform .35s ease;
}
.press-item:hover .arrow{opacity:1;transform:translateX(0)}

/* 4-up poster grid responsive */
@media(max-width:1100px){
  .films[style*="grid-template-columns:repeat(4"]{grid-template-columns:repeat(2,1fr) !important}
}
@media(max-width:600px){
  .films[style*="grid-template-columns:repeat(4"]{grid-template-columns:1fr !important}
}

/* PORTRAIT POSTER CARDS - for full poster artwork */
.film.poster .frame{aspect-ratio:2/3}
.film.poster .frame img{filter:saturate(1) brightness(1);object-fit:cover}
.film.poster:hover .frame img{filter:saturate(1.05) brightness(1.02)}
.film.poster .frame::after{
  background:linear-gradient(to top,rgba(7,13,18,.92) 0%,rgba(7,13,18,.4) 30%,transparent 55%);
}
.film.poster .meta{bottom:22px}
.film.poster .meta h3{font-size:clamp(20px,2vw,26px)}
.film.poster .meta .desc{font-size:13px}

/* DUO BLOCKS (VR callouts) */
.duo{display:grid;grid-template-columns:1.05fr .95fr;gap:0;border:1px solid var(--line-soft);border-radius:3px;overflow:hidden}
@media(max-width:860px){.duo{grid-template-columns:1fr}}
.duo .copy{padding:54px;display:flex;flex-direction:column;justify-content:center;background:var(--ink-2)}
.duo .copy h2{font-family:var(--display);font-weight:400;font-size:clamp(26px,3vw,38px);line-height:1.05;margin-bottom:18px}
.duo .copy p{color:var(--paper-dim);font-size:15px;line-height:1.65;margin-bottom:14px}
.duo .copy .credits{font-size:13px;color:var(--paper-faint);margin-top:8px;line-height:1.7}
.duo .copy .credits b{color:var(--paper);font-weight:500}
.duo .visual{position:relative;min-height:340px}
.duo .visual img{filter:brightness(.8) saturate(.95)}
.duo .visual::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 80% at 30% 30%,transparent,rgba(7,13,18,.5))}

/* AWARDS */
.awards{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:860px){.awards{grid-template-columns:repeat(2,1fr)}}
.award{padding:28px 24px;border:1px solid var(--line-soft);border-radius:3px;background:var(--ink-2);transition:border-color .35s,transform .35s}
.award:hover{border-color:var(--line);transform:translateY(-2px)}
.award .where{font-family:var(--display);font-style:italic;font-size:15px;color:var(--beam);margin-bottom:12px}
.award .what{font-size:14px;color:var(--paper-dim);line-height:1.55}
.award .what b{color:var(--paper);font-weight:500;display:block;margin-bottom:3px;font-family:var(--display)}

/* DIRECTOR */
.director{display:grid;grid-template-columns:1fr 1.3fr;gap:60px;align-items:center}
@media(max-width:860px){.director{grid-template-columns:1fr;gap:32px}}
.director .portrait{aspect-ratio:4/5;border-radius:3px;overflow:hidden;border:1px solid var(--line-soft)}
.director .portrait img{filter:grayscale(.3) brightness(.85)}
.director h2{font-family:var(--display);font-weight:300;font-size:clamp(28px,3.6vw,46px);line-height:1.02;letter-spacing:-.01em;margin-bottom:24px}
.director h2 em{font-style:italic;color:var(--beam)}
.director p{color:var(--paper-dim);font-size:15.5px;line-height:1.7;margin-bottom:16px;max-width:56ch}
.director .sig{font-family:var(--display);font-style:italic;font-size:18px;color:var(--paper);margin-top:8px}
.creds{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line-soft);border:1px solid var(--line-soft);border-radius:3px;overflow:hidden;margin:22px 0 8px}
.creds div{background:var(--ink-2);padding:16px 18px}
.creds .ck{display:block;font-family:var(--display);font-size:14px;color:var(--paper);margin-bottom:5px}
.creds .cl{display:block;font-size:12px;color:var(--paper-faint);letter-spacing:.01em;line-height:1.5}
@media(max-width:520px){.creds{grid-template-columns:1fr}}

/* CONTACT */
.contact{text-align:center;padding:130px 0}
.contact .eyebrow{margin-bottom:24px}
.contact h2{font-family:var(--display);font-weight:300;font-size:clamp(34px,6vw,76px);line-height:1.0;letter-spacing:-.02em;margin-bottom:30px}
.contact h2 em{font-style:italic;color:var(--beam)}
.contact .mail{
  display:inline-block;font-family:var(--display);font-size:clamp(20px,2.6vw,30px);
  border-bottom:1px solid var(--line);padding-bottom:6px;transition:border-color .3s,color .3s;
}
.contact .mail:hover{border-color:var(--beam);color:var(--beam)}

/* FOOTER */
footer{border-top:1px solid var(--line-soft);padding:48px 0 40px}
.foot{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;flex-wrap:wrap}
.foot .fbrand{display:flex;align-items:center;gap:12px}
.foot .fbrand img{width:42px;height:42px;object-fit:contain}
.foot .fbrand div{font-family:var(--display);font-size:15px;letter-spacing:.03em}
.foot .fbrand small{display:block;font-family:var(--body);font-size:10px;letter-spacing:.3em;color:var(--paper-faint);margin-top:3px}
.foot nav{display:flex;gap:26px;flex-wrap:wrap}
.foot nav a{font-size:13px;color:var(--paper-dim);transition:color .25s}
.foot nav a:hover{color:var(--paper)}
.foot .copy{font-size:12px;color:var(--paper-faint);width:100%;margin-top:8px}

/* ========================= PROJECT PAGE STYLES ========================= */

/* FILM HERO (taller, image-led) */
.film-hero{
  position:relative;min-height:96vh;display:flex;align-items:flex-end;overflow:hidden;
}
.film-hero .bg{position:absolute;inset:0;z-index:0}
.film-hero .bg img{filter:saturate(.85) contrast(1.05) brightness(.55);transform:scale(1.04);animation:slowzoom 24s ease-out forwards}
.film-hero .bg img[src*="planet-sun-poster"]{object-position:center 38%}
.film-hero .bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(to top,var(--ink) 2%,rgba(7,13,18,.6) 45%,rgba(7,13,18,.1) 100%);
}
.film-hero .inner{position:relative;z-index:2;width:100%;padding-bottom:80px}
.film-hero .crumb{
  display:inline-flex;align-items:center;gap:8px;font-size:11px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--paper-faint);font-weight:600;margin-bottom:18px;
  transition:color .3s;
}
.film-hero .crumb:hover{color:var(--paper)}
.film-hero .crumb::before{content:"←";font-size:14px}
.film-hero h1{
  font-family:var(--display);font-weight:300;
  font-size:clamp(54px,9vw,140px);line-height:.92;letter-spacing:-.025em;
  margin:6px 0 18px;
}
.film-hero h1 em{font-style:italic;color:var(--beam);font-weight:400}
.film-hero .tag-line{
  font-family:var(--display);font-style:italic;font-size:clamp(18px,2vw,24px);
  color:var(--paper-dim);max-width:42ch;line-height:1.4;
}
.film-hero .stats{
  display:flex;flex-wrap:wrap;gap:14px 28px;margin-top:36px;
  padding-top:24px;border-top:1px solid var(--line);
}
.film-hero .stats div{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--paper-faint);font-weight:600}
.film-hero .stats div b{color:var(--paper);font-weight:600}

/* PROJECT BODY SECTIONS */
.body-section{padding:100px 0}
.body-section + .body-section{padding-top:0}
.body-section h2{
  font-family:var(--display);font-weight:400;font-size:clamp(28px,3.4vw,42px);
  letter-spacing:-.01em;line-height:1.05;margin-bottom:28px;
}
.body-section h2 em{font-style:italic;color:var(--beam)}
.body-section p{
  font-size:17px;line-height:1.75;color:var(--paper);
  margin-bottom:20px;max-width:64ch;
}
.body-section p.dim{color:var(--paper-dim);font-size:15.5px;line-height:1.7}
.body-section .lede{
  font-family:var(--display);font-weight:300;font-style:italic;
  font-size:clamp(22px,2.6vw,30px);line-height:1.35;color:var(--paper);
  max-width:30ch;margin-bottom:32px;
}
.body-section .lede em{color:var(--beam)}

.split{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:32px}}
.split .label{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--paper-faint);font-weight:600;padding-top:8px}

/* CREDITS TABLE */
.credits-table{
  border-top:1px solid var(--line-soft);
  margin-top:24px;
}
.credits-table .row{
  display:grid;grid-template-columns:200px 1fr;gap:32px;
  padding:18px 0;border-bottom:1px solid var(--line-soft);
}
@media(max-width:640px){.credits-table .row{grid-template-columns:1fr;gap:4px;padding:16px 0}}
.credits-table .row .role{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--paper-faint);font-weight:600;padding-top:3px;
}
.credits-table .row .name{font-family:var(--display);font-size:18px;color:var(--paper)}
.credits-table .row .name span{display:block;font-family:var(--body);font-size:13px;color:var(--paper-dim);margin-top:3px}

/* FESTIVAL LIST */
.fests{
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border-top:1px solid var(--line-soft);
}
@media(max-width:640px){.fests{grid-template-columns:1fr}}
.fest{padding:22px 0;border-bottom:1px solid var(--line-soft);padding-right:24px}
.fest .name{font-family:var(--display);font-size:18px;color:var(--paper);line-height:1.2}
.fest .where{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--beam);margin-top:5px;font-weight:600}
.fest .year{font-size:13px;color:var(--paper-faint);margin-top:5px}

/* TRAILER / VIDEO EMBED */
.video-frame{
  position:relative;aspect-ratio:16/9;width:100%;
  background:var(--panel);border:1px solid var(--line-soft);border-radius:3px;overflow:hidden;
}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-frame .placeholder{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:14px;color:var(--paper-dim);
}
.video-frame .placeholder a{
  font-family:var(--display);font-size:20px;color:var(--paper);
  border-bottom:1px solid var(--line);padding-bottom:4px;
  transition:color .3s,border-color .3s;
}
.video-frame .placeholder a:hover{color:var(--beam);border-color:var(--beam)}

/* GALLERY */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media(max-width:720px){.gallery{grid-template-columns:repeat(2,1fr)}}
.gallery .shot{
  aspect-ratio:4/3;overflow:hidden;border-radius:2px;background:var(--panel);
  border:1px solid var(--line-soft);
}
.gallery .shot img{transition:transform .8s ease;filter:saturate(.9) brightness(.9)}
.gallery .shot:hover img{transform:scale(1.05);filter:saturate(1) brightness(1)}
.gallery .shot.span-2{grid-column:span 2;aspect-ratio:8/3}

/* NEXT / RELATED */
.next-film{
  display:block;position:relative;height:280px;border-radius:3px;overflow:hidden;
  border:1px solid var(--line-soft);
}
.next-film img{filter:brightness(.55) saturate(.9);transition:transform .8s ease,filter .5s ease}
.next-film:hover img{transform:scale(1.05);filter:brightness(.7) saturate(1)}
.next-film .nf-inner{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;
  padding:0 48px;z-index:2;
}
.next-film .nf-label{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--beam);font-weight:600;margin-bottom:10px}
.next-film h3{font-family:var(--display);font-weight:400;font-size:clamp(28px,4vw,46px);line-height:1;letter-spacing:-.01em}
.next-film .arrow{position:absolute;right:32px;top:50%;transform:translateY(-50%);font-size:24px;color:var(--paper);opacity:.5;transition:opacity .3s,right .3s}
.next-film:hover .arrow{opacity:1;right:24px}
