/* ============================================================
   cinepaul — site stylesheet · "Night Screening" v0.7
   The whole site plays on noir — one continuous dark canvas
   from Paul's portrait to the credits, on every page.
   (Light components remain as the base layer; body.noir is
   the scope that turns the lights off.)
   Play (display, geometric sans) + Hanken Grotesk (text).
   Static-HTML-first, GPU motion, honors reduced-motion & no-JS.
   ============================================================ */

/* self-hosted fonts (render-blocking CDN stylesheets killed mobile FCP) */
@font-face{font-family:'Italiana';src:url('/fonts/italiana-400.woff2') format('woff2');font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:'Thasadith';src:url('/fonts/thasadith-400.woff2') format('woff2');font-weight:100 500;font-style:normal;font-display:swap}
@font-face{font-family:'Thasadith';src:url('/fonts/thasadith-700.woff2') format('woff2');font-weight:600 900;font-style:normal;font-display:swap}

:root {
  /* neutrals */
  --paper:#FCFBF9; --oat:#F1ECE3; --greige:#E4DDD1; --sand:#D8CFBE;
  --cream:#F5F1E8;
  /* ink / noir */
  --ink:#1C1A16; --noir:#000000; --umber:#4A443C; --slate:#7C766B;
  /* accent (muted khaki) */
  --clay:#B0A56A; --clay-deep:#8F844F;
  /* pastel washes */
  --sage:#A9B29A; --sky:#A7BEC6; --blush:#D8B7AC;
  /* semantic */
  --bg:var(--paper); --surface:var(--oat); --text:var(--ink);
  --text-2:var(--umber); --text-muted:var(--slate); --line:var(--greige);
  --accent:var(--clay); --focus-ring:var(--clay-deep);
  /* type */
  --font:"Thasadith","Trebuchet MS",system-ui,sans-serif;
  --display:"Italiana","Didot","Bodoni MT",serif;
  --step--1:clamp(0.78rem,0.75rem + 0.15vw,0.85rem);
  --step-0:clamp(1.14rem,1.1rem + 0.24vw,1.26rem);
  --step-1:clamp(1.44rem,1.32rem + 0.6vw,1.8rem);
  --step-2:clamp(1.6rem,1.3rem + 1.5vw,2.5rem);
  --step-3:clamp(2.2rem,1.7rem + 2.8vw,3.7rem);
  --step-4:clamp(2.7rem,1.8rem + 4.6vw,5.4rem);
  --tracking-label:0.18em; --tracking-tight:-0.02em;
  --leading-tight:1.02; --leading-body:1.6;
  /* space */
  --sp-1:.25rem; --sp-2:.5rem; --sp-3:.75rem; --sp-4:1rem; --sp-6:1.5rem;
  --sp-8:2rem; --sp-12:3rem; --sp-16:4rem; --sp-24:6rem; --sp-32:8rem;
  /* radius / shadow — warm-tinted, single light source (top) */
  --radius-1:3px; --radius-2:12px; --radius-3:16px;
  --shadow-1:0 1px 3px rgba(28,26,22,.06);
  --shadow-2:0 24px 60px -18px rgba(28,26,22,.22);
  --shadow-lift:0 34px 70px -26px rgba(43,32,24,.30);
  /* motion */
  --ease:cubic-bezier(.16,1,.3,1); --ease-soft:cubic-bezier(.4,0,.2,1);
  --spring:cubic-bezier(.34,1.3,.5,1);
  --d-fast:200ms; --d:420ms; --d-slow:780ms;
  /* geometry */
  --aspect-portrait:4/5; --maxw:1300px; --gutter:clamp(1.15rem,4vw,3.5rem);
  --head-h:68px;
  /* z-scale */
  --z-grain:9; --z-head:50; --z-nav:55; --z-progress:60;
}

/* ---- reset / base ---- */
*{margin:0;box-sizing:border-box}
/* clip sideways overflow at the root — iOS pans the root scroller, so
   body's clip alone doesn't stop horizontal drag past the edges */
html{scroll-behavior:smooth;overflow-x:hidden;overflow-x:clip}
body{background:var(--bg);color:var(--text);font-family:var(--font);
  font-size:var(--step-0);font-weight:300;line-height:var(--leading-body);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:clip}
img{max-width:100%;height:auto;display:block}
a{color:inherit}
::selection{background:var(--blush);color:var(--noir)}
:focus-visible{outline:2px solid var(--focus-ring);outline-offset:3px;border-radius:2px}
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:var(--paper);padding:10px 16px;border-radius:0 0 8px 0;z-index:100}
.skip:focus{left:0}

/* filmic grain — fixed, static, non-interactive */
.grain{position:fixed;inset:0;z-index:var(--z-grain);pointer-events:none;opacity:.05;
  mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:140px}

/* scroll progress — driven by --p in app.js */
.scroll-progress{position:fixed;top:env(safe-area-inset-top,0px);left:0;right:0;height:2px;z-index:var(--z-progress);
  pointer-events:none;transform:scaleX(var(--p,0));transform-origin:0 50%;
  background:linear-gradient(90deg,var(--clay),var(--clay-deep));
  transition:transform .12s linear;opacity:.9}

/* ---- shared type helpers ---- */
.eyebrow{text-transform:uppercase;letter-spacing:.2em;font-size:.86rem;color:var(--clay-deep);font-weight:600;display:inline-block}
.eyebrow::before{content:"";display:inline-block;width:26px;height:1px;background:var(--clay);vertical-align:middle;margin-right:12px}
.lab{font-size:.79rem;text-transform:uppercase;letter-spacing:.18em;color:var(--slate);font-weight:600;display:inline-flex;align-items:baseline}
/* solid clay accent — the site's type signature */
em.accent,.accent-word{font-style:normal;font-weight:inherit;color:var(--clay-deep)}

/* ---- header / nav ---- */
.site-head{position:sticky;top:0;z-index:var(--z-head);padding-top:env(safe-area-inset-top,0px);background:rgba(252,251,249,.72);
  backdrop-filter:saturate(1.2) blur(14px);-webkit-backdrop-filter:saturate(1.2) blur(14px);
  border-bottom:1px solid transparent;
  transition:transform .45s var(--ease),border-color .3s,background .3s}
.site-head.scrolled{border-color:var(--greige);background:rgba(252,251,249,.85)}
.site-head.hidden{transform:translateY(-101%)}
.nav{display:flex;align-items:center;justify-content:space-between;height:var(--head-h)}
.brand{display:inline-flex;align-items:center;text-decoration:none;color:var(--ink)}
.brand-logo{height:24px;width:auto;display:block}
.book-m{display:none}
.nav-links{display:flex;gap:clamp(14px,2vw,30px);align-items:center;list-style:none}
.nav-links a{text-decoration:none;color:var(--umber);font-size:.98rem;font-weight:500;letter-spacing:.01em;transition:color .3s;position:relative}
.nav-links a:not(.nav-book)::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1.5px;background:var(--clay);transform:scaleX(0);transform-origin:right;transition:transform .4s var(--ease)}
.nav-links a:not(.nav-book):hover::after,.nav-links a[aria-current="page"]:not(.nav-book)::after{transform:scaleX(1);transform-origin:left}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--ink)}
.m-home,.nav-ig{display:none} /* mobile-menu-only items */
.nav-book{background:var(--ink);color:var(--paper)!important;padding:9px 18px;border-radius:100px;font-size:.96rem;transition:background .3s,transform var(--d) var(--ease),box-shadow var(--d)}
.nav-book:hover{background:var(--noir);transform:translateY(-1px);box-shadow:var(--shadow-2)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:10px;flex-direction:column;gap:6px}
.nav-toggle span{width:28px;height:2.5px;border-radius:99px;background:var(--ink);transition:.3s var(--ease)}
.nav-toggle span:nth-child(2){display:none}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(4.25px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-4.25px) rotate(-45deg)}
/* dark variant — sits over the cinema hero until scrolled */
.site-head.on-dark:not(.scrolled){background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}
.site-head.on-dark:not(.scrolled) .brand{color:var(--cream)}
.site-head.on-dark:not(.scrolled) .brand b{color:var(--clay)}
.site-head.on-dark:not(.scrolled) .nav-links a{color:rgba(245,241,232,.72)}
.site-head.on-dark:not(.scrolled) .nav-links a:hover,
.site-head.on-dark:not(.scrolled) .nav-links a[aria-current="page"]{color:var(--cream)}
.site-head.on-dark:not(.scrolled) .nav-book{background:var(--cream);color:var(--noir)!important}
.site-head.on-dark:not(.scrolled) .nav-toggle span{background:var(--cream)}
@media(max-width:860px){
  :root{--head-h:42px}
  .brand-logo{height:17px}
  .nav{position:relative}
  .nav-toggle{display:flex;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);margin:0}
  .book-m,.site-head.on-dark:not(.scrolled) .nav-book.book-m,.noir .site-head .nav-book.book-m{
    display:inline-flex;align-items:center;gap:8px;padding:9px 14px;font-size:.74rem;
    background:var(--clay);color:var(--noir)!important;font-weight:700;text-decoration:none;
    -webkit-text-stroke:.4px currentColor;
    text-transform:uppercase;letter-spacing:.04em;line-height:1}
  .book-m::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--noir);flex:none}
  .book-m:hover{background:var(--clay-deep)}
  /* full-screen menu — black canvas, thin centered caps, IG mark at the foot */
  /* while open: the header's backdrop-filter would otherwise become the
     containing block for the fixed overlay (pinning it to the bar, not the
     screen), and the body gets position-locked by app.js — so the header
     re-anchors to the viewport itself. Doubled class outguns noir rules. */
  .site-head.site-head:has(.nav-links.open){position:fixed;top:0;left:0;right:0;transform:none;
    background:transparent;border-color:transparent;
    backdrop-filter:none;-webkit-backdrop-filter:none}
  .brand{position:relative;z-index:calc(var(--z-nav) + 1)}
  .nav-toggle[aria-expanded="true"]{left:auto;right:calc(var(--gutter) - 10px);transform:translateY(-50%);z-index:calc(var(--z-nav) + 1)}
  .nav-toggle[aria-expanded="true"] span{background:var(--cream)}
  .nav-toggle[aria-expanded="true"]~.book-m{display:none}
  .nav-links{position:fixed;inset:0;flex-direction:column;align-items:center;justify-content:center;
    gap:clamp(22px,4.2vh,40px);background:var(--noir);
    padding:calc(var(--head-h) + env(safe-area-inset-top,0px)) var(--gutter) 14vh;
    transform:translateY(-102%);visibility:hidden;
    transition:transform .7s var(--ease),visibility .7s;z-index:var(--z-nav)}
  .nav-links.open{transform:none;visibility:visible}
  /* instant close on bfcache restore (app.js pageshow handler) */
  .nav-links.no-anim,.nav-links.no-anim li{transition:none!important}
  /* items flex in slowly after the curtain lands — same feel as the
     booking page reveals — and reset fast on close for the next open */
  .nav-links li{opacity:0;transform:translateY(26px) scale(.985);transition:opacity .3s,transform .3s}
  .nav-links.open li{opacity:1;transform:none;transition:opacity 1.2s var(--ease),transform 1.2s var(--ease)}
  .nav-links.open li:nth-child(1){transition-delay:.06s}
  .nav-links.open li:nth-child(2){transition-delay:.11s}
  .nav-links.open li:nth-child(3){transition-delay:.16s}
  .nav-links.open li:nth-child(4){transition-delay:.21s}
  .nav-links.open li:nth-child(5){transition-delay:.26s}
  .nav-links.open li:nth-child(6){transition-delay:.31s}
  .nav-links.open li:nth-child(7){transition-delay:.36s}
  .nav-links.open li:nth-child(8){transition-delay:.44s}
  .nav-links a{font-size:clamp(1.65rem,7vw,2.3rem);font-weight:300;letter-spacing:.06em;text-transform:uppercase;
    line-height:1;color:var(--cream)!important}
  .nav-links a::after{display:none}
  .nav-links .nav-book{background:none!important;padding:0;border-radius:0}
  .m-home{display:block}
  .nav-ig{display:flex;position:absolute;left:0;right:0;bottom:calc(7vh + env(safe-area-inset-bottom,0px));justify-content:center}
  .nav-ig svg{display:block}
}

/* ---- buttons ---- */
.btn{font-family:var(--font);cursor:pointer;border:none;font-size:1.08rem;font-weight:500;
  padding:15px 30px;border-radius:100px;transition:transform var(--d) var(--spring),box-shadow var(--d) var(--ease),background var(--d) var(--ease),border-color var(--d) var(--ease),color var(--d) var(--ease);
  text-decoration:none;display:inline-block;line-height:1;will-change:transform}
.btn:active{transform:translateY(0) scale(.97)}
.btn-p{background:var(--ink);color:var(--paper);position:relative;overflow:hidden}
.btn-p::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.16),transparent 70%);transform:translateX(-130%);transition:transform .7s var(--ease)}
.btn-p:hover{transform:translateY(-3px);box-shadow:var(--shadow-lift);background:var(--noir)}
.btn-p:hover::after{transform:translateX(130%)}
.btn-s{background:transparent;color:var(--ink);border:1px solid var(--sand)}
.btn-s:hover{border-color:var(--ink);transform:translateY(-3px)}
.btn-a{background:transparent;color:var(--clay-deep);position:relative;padding:14px 6px;border-radius:0}
.btn-a::after{content:"";position:absolute;left:6px;right:6px;bottom:8px;height:1.5px;background:var(--clay);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.btn-a:hover::after{transform:scaleX(1)}
.btn-a:hover{transform:none}
.tag{background:var(--oat);border:1px solid var(--greige);color:var(--slate);font-size:.84rem;
  letter-spacing:.08em;text-transform:uppercase;padding:9px 15px;border-radius:100px;text-decoration:none;display:inline-block;transition:.3s var(--ease)}
.tag:hover{border-color:var(--clay);color:var(--clay-deep)}

/* ---- section rhythm ---- */
section{padding-block:clamp(3.5rem,8vw,7rem)}
.section-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:12px;margin-bottom:2.4rem}
h1,h2,h3{letter-spacing:var(--tracking-tight);line-height:1.05;text-wrap:balance}
.h-display{font-family:var(--display);font-weight:500;font-size:var(--step-4);line-height:1;letter-spacing:-.02em}
.h-2{font-family:var(--display);font-weight:500;font-size:clamp(2rem,4.2vw,3.6rem);letter-spacing:-.015em;line-height:1.02}
.h-2 em{font-style:normal;color:var(--clay-deep);font-weight:500}
.h-3{font-weight:500;font-size:var(--step-1);letter-spacing:-.01em}
.lead{color:var(--umber);font-size:clamp(1.26rem,1.92vw,1.56rem);line-height:1.5;max-width:46ch;font-weight:400;text-wrap:pretty}
/* numbered section head — film-reel numbers, footer-scale titles */
.sec-head{display:flex;align-items:flex-end;gap:clamp(16px,2.6vw,36px);flex-wrap:wrap;margin-bottom:clamp(2.4rem,5vw,3.6rem)}
.sec-no{font-family:var(--display);font-weight:600;font-size:clamp(3.2rem,6.4vw,5.4rem);line-height:.78;
  letter-spacing:-.02em;color:var(--sand);flex:0 0 auto}
@supports ((-webkit-text-stroke:1px black) or (text-stroke:1px black)){
  .sec-no{color:transparent;-webkit-text-stroke:1.5px var(--sand)}
}
.sec-main{display:flex;flex-direction:column;gap:.55rem}
.sec-main .lab{line-height:1}
.sec-head .btn-a{margin-left:auto;white-space:nowrap}
@media(max-width:560px){.sec-head .btn-a{margin-left:0;flex-basis:100%;padding-top:0}}

/* ============================================================
   HERO — cinema opening: Paul emerges from black, then the
   site cuts to daylight. Built around one photograph.
   ============================================================ */
.hero-cine{position:relative;background:var(--noir);color:var(--cream);
  /* svh, not dvh: dvh grows when the phone URL bar collapses mid-scroll,
     re-flowing the whole page under the user's finger */
  min-height:100vh;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;
  margin-top:calc(-1 * (var(--head-h) + env(safe-area-inset-top,0px)));
  padding-top:calc(var(--head-h) + env(safe-area-inset-top,0px) + 1.5rem);
  overflow:hidden}
/* the photo — background is true black, so it has no edges here */
.hero-media{position:absolute;top:0;right:0;bottom:0;width:min(58vw,940px);z-index:0;
  animation:heroMedia 1.8s var(--ease) .1s both}
/* the photo paints at once (it's the LCP element); the "emerge from
   black" fade lives on this veil above it, not on the image itself */
.hero-media::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:var(--noir);animation:heroVeil 1.4s var(--ease) .1s both}
.hero-media img,.hero-media picture,.hero-media video{width:100%;height:100%;object-fit:cover;object-position:center 22%;display:block}
.hero-media picture img{height:100%}
.hero-media::after{content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg,var(--noir) 0%,rgba(13,12,9,0) 34%),
    linear-gradient(0deg,var(--noir) 0%,rgba(13,12,9,0) 22%),
    linear-gradient(180deg,rgba(13,12,9,.5) 0%,rgba(13,12,9,0) 20%)}
/* light-beam motif — echoes the streak across Paul's face */
.hero-cine::before{content:"";position:absolute;left:clamp(20px,6vw,110px);top:0;bottom:0;width:1px;
  z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent 4%,rgba(190,127,104,.5) 34%,rgba(190,127,104,.12) 72%,transparent 96%);
  opacity:0;animation:rise 1.6s var(--ease) 1.1s both}
/* brand mark, dead-center over the video. On intro visits the pop runs
   early, hidden behind the loader — the intro logo grows to this exact
   size during the whiteout, so the reveal is one continuous mark. On
   direct visits (no intro) the pop is the entrance. */
.hero-logo{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;
  width:min(80vw,480px);height:auto;pointer-events:none;
  filter:drop-shadow(0 2px 26px rgba(0,0,0,.5));
  opacity:0;animation:heroLogoIn .55s var(--ease) .12s both}
@keyframes heroLogoIn{
  from{opacity:0;transform:translate(-50%,-50%) scale(.5)}
  to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
.hero-stage{position:relative;z-index:2;width:100%;margin-bottom:clamp(2rem,6vh,4rem)}
.hero-kicker{display:flex;align-items:center;gap:12px;font-size:.82rem;letter-spacing:.26em;
  text-transform:uppercase;font-weight:600;color:rgba(245,241,232,.6);
  opacity:0;animation:rise .8s var(--ease) .25s both}
.hero-kicker .dot{width:7px;height:7px;border-radius:50%;background:var(--clay);flex:0 0 auto;
  box-shadow:0 0 14px rgba(190,127,104,.9)}
.hero-title{font-family:var(--display);font-weight:600;text-transform:uppercase;
  font-size:clamp(3rem,7.8vw,9rem);line-height:.9;letter-spacing:-.015em;
  margin:.22em 0 .3em;color:var(--cream)}
.hero-title .ln{display:block;overflow:hidden;padding-bottom:.04em;margin-bottom:-.04em}
.hero-title .ln>span{display:inline-block;transform:translateY(115%);animation:lineUp 1s var(--ease) both}
.hero-title .ln:nth-child(1)>span{animation-delay:.3s}
.hero-title .ln:nth-child(2)>span{animation-delay:.42s}
.hero-title .ln:nth-child(3)>span{animation-delay:.54s}
.hero-title .hollow{color:var(--clay);font-family:var(--display);font-weight:700}
.hero-stage .cta{display:flex;gap:22px;align-items:center;flex-wrap:wrap;margin-top:1.6rem;
  opacity:0;animation:rise .9s var(--ease) .8s both}
.btn-hero{font-family:var(--font);cursor:pointer;border:none;font-size:1.08rem;font-weight:600;
  padding:16px 32px;border-radius:100px;background:var(--cream);color:var(--noir);
  text-decoration:none;display:inline-block;line-height:1;white-space:nowrap;
  transition:transform var(--d) var(--spring),box-shadow var(--d) var(--ease),background var(--d)}
.btn-hero:hover{transform:translateY(-3px);background:#fff;box-shadow:0 22px 50px -14px rgba(0,0,0,.55)}
.btn-hero:active{transform:scale(.97)}
.link-hero{color:rgba(245,241,232,.85);text-decoration:none;font-size:1.08rem;font-weight:500;
  border-bottom:1px solid rgba(245,241,232,.3);padding-bottom:4px;transition:.3s;white-space:nowrap}
.link-hero:hover{color:var(--cream);border-color:var(--clay)}
.hero-credits{position:relative;z-index:2;
  opacity:0;animation:rise .9s var(--ease) 1s both}
.credits-in{display:flex;align-items:center;gap:clamp(16px,3vw,44px);padding-block:17px}
.credits-in>span{font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  color:rgba(245,241,232,.48);white-space:nowrap}
.scroll-cue{margin-left:auto;width:30px;height:48px;border:1px solid rgba(245,241,232,.26);
  border-radius:100px;position:relative;flex:0 0 auto;transition:border-color .3s}
.scroll-cue span{position:absolute;left:50%;top:9px;width:4px;height:8px;margin-left:-2px;
  border-radius:4px;background:var(--clay);animation:cueDrop 2.2s var(--ease-soft) infinite}
.scroll-cue:hover{border-color:var(--clay)}
@keyframes cueDrop{0%{transform:translateY(0);opacity:0}25%{opacity:1}65%{opacity:1}100%{transform:translateY(20px);opacity:0}}
@keyframes heroMedia{from{transform:scale(1.04)}to{transform:none}}
@keyframes heroVeil{from{opacity:1}to{opacity:0}}
@media(max-width:860px){
  .hero-cine{padding-top:calc(var(--head-h) + env(safe-area-inset-top,0px) + 1rem)}
  .hero-cine::before{display:none}
  .hero-media{width:100%;left:0}
  .hero-media img{object-position:center 18%}
  .hero-media video{object-position:center 30%}
  /* keep the vertical video visible across the whole screen; scrim only the
     top (for the header) and the bottom band (behind the hero text) */
  .hero-media::after{background:
    linear-gradient(180deg,rgba(13,12,9,.42) 0%,rgba(13,12,9,0) 15%,rgba(13,12,9,0) 40%,rgba(13,12,9,.32) 60%,rgba(13,12,9,.8) 84%,rgba(13,12,9,.94) 100%)}
  .hero-title{font-size:clamp(2.4rem,10.6vw,5.4rem)}
  .hero-stage{margin-bottom:1.7rem}
  .hc-opt{display:none}
}

/* image placeholder (used until real photos land) */
.ph{position:absolute;inset:0;background:
  radial-gradient(70% 55% at 52% 30%,rgba(216,183,172,.55),transparent 60%),
  radial-gradient(60% 50% at 40% 92%,rgba(167,190,198,.5),transparent 60%),
  linear-gradient(160deg,#EDE7DC,#E3D8C9)}
.ph.v2{background:radial-gradient(70% 58% at 50% 34%,rgba(167,190,198,.6),transparent 62%),linear-gradient(160deg,#E4E0D5,#D6CFC0)}
.ph.v3{background:radial-gradient(70% 58% at 50% 32%,rgba(169,178,154,.55),transparent 62%),linear-gradient(160deg,#E6E2D4,#D8D1BF)}
.ph.v4{background:radial-gradient(70% 55% at 50% 32%,rgba(190,127,104,.42),transparent 64%),linear-gradient(160deg,#EBE1D2,#DCCFBB)}

/* ---- about page portrait (framed shot) ---- */
/* flat photo (design-system rule 5): radius-1, no border, no shadow; only a
   bottom gradient so the caption stays legible over the image */
.shot{position:relative;border-radius:var(--radius-1);overflow:hidden;
  opacity:0;animation:shotIn 1.1s var(--ease) .1s both;margin:0}
.shot>picture,.shot>img,.shot>.img{display:block;width:100%;height:auto;border-radius:var(--radius-1)}
.shot::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;border-radius:var(--radius-1);
  background:linear-gradient(180deg,transparent 62%,rgba(13,12,9,.42))}
.about-layout{display:grid;grid-template-columns:minmax(0,420px) 1fr;gap:clamp(24px,5vw,64px);align-items:start;margin-top:.5rem}
.about-layout .shot{position:sticky;top:92px}
@media(max-width:820px){.about-layout{grid-template-columns:1fr}.about-layout .shot{position:relative;max-width:440px}}
/* home "actor behind the camera" split — portrait beside the intro copy.
   photo has no frame: sharp left edge, right edge dissolves into the noir bg */
.about-home{display:grid;grid-template-columns:minmax(0,400px) 1fr;gap:clamp(28px,5vw,72px);align-items:center}
.about-home .prose{max-width:56ch}
.ah-shot{margin:0}
.ah-copy .lede{margin-bottom:.7em;font-size:clamp(1.1rem,1.63vw,1.33rem)}
.ah-shot img{display:block;width:100%;height:auto;
  -webkit-mask-image:linear-gradient(90deg,#000 48%,transparent 100%);
  mask-image:linear-gradient(90deg,#000 48%,transparent 100%)}
@media(max-width:820px){
  .about-home{grid-template-columns:1fr;gap:0}
  /* copy rides up over the dark lower-left of the portrait */
  .about-home .ah-copy{position:relative;z-index:2;margin-top:-30%}
}
.shot .cap{position:absolute;left:22px;bottom:20px;z-index:3;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paper);font-weight:600;mix-blend-mode:difference}
.shot .meta-tr{position:absolute;top:22px;right:24px;z-index:3;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--paper);font-weight:600;mix-blend-mode:difference}

/* ---- gallery / contact sheet ---- */
/* masonry — full images, never cropped */
.sheet{columns:4;column-gap:14px}
.sheet.cols-3{columns:3}
@media(max-width:980px){.sheet,.sheet.cols-3{columns:3}}
@media(max-width:720px){.sheet,.sheet.cols-3{columns:2}}
.frame{position:relative;overflow:hidden;border-radius:3px;background:var(--oat);display:block;margin:0 0 14px;break-inside:avoid}
.frame .img,.frame picture,.frame img{display:block;width:100%;height:auto;
  transition:transform 1s var(--ease),filter .8s var(--ease)}
.frame::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent 55%,rgba(13,12,9,.45));opacity:0;transition:opacity .5s var(--ease)}
.frame:hover .img,.frame:hover img{transform:scale(1.05)}
.frame:hover::before{opacity:1}
.frame::after{content:attr(data-cap);position:absolute;left:14px;bottom:12px;z-index:2;font-size:.7rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--paper);font-weight:600;opacity:0;transform:translateY(8px);transition:.45s var(--ease)}
.frame:hover::after{opacity:1;transform:none}
/* staggered home gallery — 4 columns of 2, even columns dropped */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(7px,0.95vw,12px);align-items:start}
.gallery .gcol{display:flex;flex-direction:column;gap:clamp(7px,0.95vw,12px);will-change:transform}
/* balanced stagger: right column highest, 2nd lowest, left & 3rd between */
.gallery .gcol:nth-child(1){margin-top:clamp(26px,6.5vw,78px)}
.gallery .gcol:nth-child(2){margin-top:clamp(46px,13vw,155px)}
.gallery .gcol:nth-child(3){margin-top:clamp(30px,7.4vw,90px)}
.gallery .gcol:nth-child(4){margin-top:0}
.gallery .frame{margin:0;border-radius:0}
.gallery .frame .img,.gallery .frame picture,.gallery .frame img{border-radius:0}
/* per-image scroll reveal: each pops in as it enters view (set by app.js) */
.gallery .g-item{opacity:0;transform:translateY(22px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.gallery .g-item.shown{opacity:1;transform:none}
@media(max-width:720px){
  .gallery .gcol{will-change:auto}   /* keep 4 columns on phone; offsets scale via vw */
}

/* ---- rate cards — boxless editorial price columns ---- */
.rates-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,44px)}
@media(max-width:820px){.rates-grid{grid-template-columns:1fr;gap:32px}}
.tier-list{list-style:none;margin:0;padding:0}
.tier{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr) auto;gap:12px 20px;align-items:baseline;padding:24px 0;border-top:1px solid var(--line)}
.tier:last-child{border-bottom:1px solid var(--line)}
.tier-name{font-family:var(--display);font-weight:500;font-size:clamp(1.5rem,2.4vw,2rem);letter-spacing:.01em}
.tier-badge{font-family:var(--font);font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--clay-deep);margin-left:12px;vertical-align:middle;white-space:nowrap}
.tier-meta{color:var(--slate);font-size:1.02rem}
.tier-price{font-family:var(--display);font-weight:500;font-size:clamp(1.5rem,2.4vw,2rem);justify-self:end;font-variant-numeric:tabular-nums}
.tier-cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
@media(max-width:640px){
  .tier{grid-template-columns:1fr auto}
  .tier-name{grid-column:1;grid-row:1}
  .tier-price{grid-column:2;grid-row:1}
  .tier-meta{grid-column:1/-1;grid-row:2;margin-top:-6px}
}
.rate-card{background:transparent;border-top:1px solid var(--ink);padding:24px 0 0;position:relative;
  display:flex;flex-direction:column;
  transition:border-color var(--d) var(--ease)}
.rate-card:hover{border-color:var(--clay-deep)}
.rate-card.feature{border-top:3px solid var(--clay-deep)}
.rate-card .rate-img{margin:0 0 1.3rem;overflow:hidden;aspect-ratio:1/1}
.rate-card .rate-img img{width:100%;height:100%;object-fit:cover;display:block;
  transition:transform 1.2s var(--ease)}
.rate-card:hover .rate-img img{transform:scale(1.035)}
.rate-card .badge{display:inline-block;vertical-align:middle;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;
  font-family:var(--font);color:var(--paper);background:var(--clay-deep);padding:5px 11px;border-radius:100px;font-weight:600;
  margin-left:10px;transform:translateY(-3px)}
.rate-card .rate-body{display:flex;flex-direction:column;flex:1;border:1px solid var(--greige);padding:22px 18px 24px;margin-bottom:1.2rem}
.rate-card .no{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);font-weight:600;text-align:center}
.rate-card .name{font-family:var(--display);font-weight:500;font-size:clamp(2.5rem,1.9rem + 1.4vw,2.9rem);letter-spacing:-.01em;margin:.35em 0 .55em;line-height:1.05;text-align:center}
.rate-card .dur{color:var(--slate);font-size:.94rem;letter-spacing:.03em;text-transform:uppercase;font-weight:500}
.rate-card .price{font-family:var(--display);font-weight:600;font-size:clamp(2.9rem,2.3rem + 1.4vw,3.4rem);margin:auto 0 0;padding-top:1.2rem;letter-spacing:-.02em;font-variant-numeric:tabular-nums;text-align:center}
.rate-card .student{font-size:.86rem;color:var(--slate);letter-spacing:.02em;margin:-.35rem 0 0;font-weight:500;text-align:center}
.rate-card ul{list-style:none;margin:0;padding:0}
.rate-card li{padding:10px 0;border-bottom:1px solid var(--greige);font-size:1.04rem;color:var(--umber);display:flex;gap:11px;align-items:flex-start}
.rate-card li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--clay);margin-top:7px;flex:0 0 auto}
/* learn-more buttons + session detail popups (rates) — style ported from the old cinepaul.com/rates lightboxes */
.learn-btn{align-self:center;margin:1.6rem 0 .2rem;padding:0 18px 3px;background:none;border:none;border-bottom:1px solid var(--clay);
  color:var(--clay);font-family:var(--font);font-weight:600;font-size:18px;letter-spacing:.04em;cursor:pointer;transition:all .3s ease}
.learn-btn:hover{color:var(--cream);border-bottom-color:var(--cream)}
/* while a session popup is open the body is pinned and scrollY clamps to 0 —
   without this the header un-hides and flashes before the popup fades in */
body.pop-open .site-head{transform:translateY(-101%)!important;transition:none!important}
.rate-pop{position:fixed;inset:0;background:rgba(5,4,3,.9);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;
  opacity:0;visibility:hidden;transform:translateY(-50px);transition:all .7s cubic-bezier(.4,0,.2,1);
  z-index:9999;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:100px 25px 120px;pointer-events:none}
.rate-pop.visible{opacity:1;visibility:visible;transform:none;pointer-events:auto}
.pop-close{position:fixed;top:24px;left:24px;width:42px;height:42px;background:#000;border:1px solid #333;border-radius:2px;cursor:pointer;z-index:10000;padding:0;
  transition:background .3s ease,transform .3s ease}
.pop-close:hover{background:#1a1a1a;transform:scale(1.05)}
.pop-close::before,.pop-close::after{content:"";position:absolute;top:50%;left:50%;width:18px;height:2px;background:#fff;margin:-1px 0 0 -9px}
.pop-close::before{transform:rotate(45deg)}
.pop-close::after{transform:rotate(-45deg)}
@media(max-width:768px){.pop-close{top:16px;left:14px;width:38px;height:38px}}
.pop-body{max-width:750px;margin:0 auto;width:100%;line-height:1.6}
.pop-body h2{font-size:clamp(24px,14px + 2.4vw,34px);font-weight:600;letter-spacing:.5px;text-align:center;color:#fff;margin:0;text-shadow:0 0 5px rgba(0,0,0,.5)}
.pop-body h3{color:var(--clay);font-size:20px;letter-spacing:1px;margin:30px 0 0;text-transform:uppercase;font-weight:700;line-height:1.3}
.pop-body p{font-size:15px;color:#ddd;margin:10px 0 0}
.pop-body .sec{margin-bottom:30px}
.pop-body h4{color:#fff;font-size:34px;font-weight:600;margin:40px 0 0;border-top:1px solid #333;padding-top:30px}
/* popup text flexes in with the same slow stagger as the menu links */
.rate-pop .pop-body>*{opacity:0;transform:translateY(26px) scale(.985);transition:opacity .3s,transform .3s}
.rate-pop.visible .pop-body>*{opacity:1;transform:none;transition:opacity 1.2s var(--ease),transform 1.2s var(--ease)}
.rate-pop.visible .pop-body>:nth-child(1){transition-delay:.06s}
.rate-pop.visible .pop-body>:nth-child(2){transition-delay:.11s}
.rate-pop.visible .pop-body>:nth-child(3){transition-delay:.16s}
.rate-pop.visible .pop-body>:nth-child(4){transition-delay:.21s}
.rate-pop.visible .pop-body>:nth-child(5){transition-delay:.26s}
.rate-pop.visible .pop-body>:nth-child(6){transition-delay:.31s}
.rate-pop.visible .pop-body>:nth-child(7){transition-delay:.36s}
.rate-pop.visible .pop-body>:nth-child(8){transition-delay:.41s}
.rate-pop.visible .pop-body>:nth-child(9){transition-delay:.46s}
.rate-pop.visible .pop-body>:nth-child(10){transition-delay:.51s}
.book-btn{width:100%;cursor:pointer;font-family:var(--font);font-weight:600;font-size:1.04rem;letter-spacing:.02em;padding:5px 16px;border-radius:100px;margin-top:auto;
  border:1.5px solid var(--sand);background:transparent;color:var(--ink);transition:all var(--d) var(--ease);text-decoration:none;display:block;text-align:center}
.book-btn:hover{border-color:var(--ink);transform:translateY(-2px);box-shadow:var(--shadow-1)}

/* ---- prose / article (content pages) ---- */
.prose{max-width:70ch;font-size:1.26rem;color:var(--umber);line-height:1.68}
.prose h2{font-family:var(--display);font-weight:500;font-size:var(--step-2);color:var(--ink);margin:2.2em 0 .55em;letter-spacing:-.015em;line-height:1.08}
.prose h3{font-weight:600;font-size:var(--step-1);color:var(--ink);margin:1.6em 0 .4em}
.prose p{margin:0 0 1.1em;text-wrap:pretty}
.prose a{color:var(--clay-deep);text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--sand);transition:text-decoration-color .3s}
.prose a:hover{text-decoration-color:var(--clay)}
/* buttons inside prose must not inherit the underlined text-link look */
.prose a.btn{text-decoration:none}
.prose a.btn-p{display:block;width:-moz-fit-content;width:fit-content;color:var(--paper);margin:1.5rem 0 .2rem}
.prose a.btn-p:hover{color:var(--paper)}
.prose a.btn-a{color:var(--clay-deep);display:inline-block}
.prose a.btn-s{color:var(--ink)}
.prose strong{color:var(--ink);font-weight:600}
.prose ul,.prose ol{margin:0 0 1.2em 1.1em;padding:0}
.prose li{margin:.35em 0}
.lede{font-size:clamp(1.37rem,2.04vw,1.66rem);color:var(--ink);line-height:1.5;font-weight:400;max-width:60ch;margin-bottom:1.4em;text-wrap:pretty}

/* ---- comparison / spec table ---- */
.table-wrap{overflow-x:auto;border:1px solid var(--greige);border-radius:12px;margin:1.5em 0}
table.compare{width:100%;border-collapse:collapse;font-size:1.1rem;min-width:520px}
table.compare th,table.compare td{text-align:left;padding:14px 18px;border-bottom:1px solid var(--greige);vertical-align:top}
table.compare thead th{background:var(--oat);font-weight:600;color:var(--ink);font-size:.86rem;text-transform:uppercase;letter-spacing:.08em}
table.compare tbody th{font-weight:600;color:var(--ink)}
table.compare td{color:var(--umber)}
table.compare tbody tr{transition:background .25s var(--ease)}
table.compare tbody tr:hover{background:rgba(241,236,227,.6)}
table.compare tr:last-child td,table.compare tr:last-child th{border-bottom:none}

/* ---- FAQ ---- */
.faq-list{max-width:820px}
.faq-item{border-top:1px solid var(--greige);transition:padding-left .4s var(--ease)}
@media(hover:hover){.faq-item:hover{padding-left:.6rem}}
.faq-item:last-child{border-bottom:1px solid var(--greige)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding:1.35rem 0}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item h3{font-family:var(--display);font-weight:500;font-size:1.18rem;color:var(--ink);letter-spacing:-.005em;line-height:1.25;-webkit-text-stroke:.5px currentColor}
.faq-item summary::after{content:"+";flex:none;width:32px;height:32px;border:1px solid var(--sand);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:300;line-height:1;
  color:var(--clay-deep);transition:transform .35s var(--ease),background .3s,color .3s}
.faq-item[open] summary::after{transform:rotate(45deg);background:var(--clay);border-color:var(--clay);color:var(--noir)}
.faq-item p{color:var(--umber);line-height:1.62;max-width:70ch;padding-bottom:1.4rem}
.faq-item[open] p{animation:faq-in .45s var(--ease)}
@keyframes faq-in{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.faq-item[open] p{animation:none}}

/* ---- reviews ---- */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.review{background:#fff;border:1px solid var(--greige);border-radius:var(--radius-3);padding:26px;transition:transform var(--d) var(--ease),box-shadow var(--d) var(--ease)}
.review:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.review .stars{color:var(--clay);letter-spacing:2px;font-size:1.08rem;margin-bottom:.6em}
.review p{color:var(--umber);line-height:1.62;font-size:1.18rem;margin-bottom:1em}
.review .who{font-size:.94rem;color:var(--slate);font-weight:600;letter-spacing:.02em}

/* ---- booking footer ---- */
.invite{position:relative;padding:clamp(56px,9vw,128px) 0 calc(40px + env(safe-area-inset-bottom,0px));overflow:hidden;background:var(--paper)}
.invite h2{font-family:var(--display);font-weight:500;font-size:clamp(2.3rem,6.4vw,4.8rem);line-height:1;letter-spacing:-.02em;margin:.3em 0 .6em;max-width:18ch}
.invite h2 em{font-style:normal;font-weight:500;color:var(--clay-deep)}
/* staggered crescendo — each line steps right and grows */
.invite h2.invite-lines{display:flex;flex-direction:column;gap:.16em;max-width:none;margin:.1em 0 .75em}
.invite-lines .il{display:block;line-height:1.04}
.invite-lines .il-1{display:flex;align-items:center;gap:18px;font-size:clamp(1.05rem,2.1vw,1.55rem);letter-spacing:.14em;color:var(--umber)}
.invite-lines .il-1::before{content:"";width:46px;height:1px;background:currentColor;opacity:.55;flex:none}
.invite-lines .il-2{margin-left:clamp(1.4rem,7vw,6rem);font-size:clamp(2.1rem,5.6vw,4.4rem)}
.invite-lines .il-3{margin-left:clamp(2.8rem,14vw,12rem);font-size:clamp(2.5rem,7vw,5.6rem)}
.invite .cta-stag{margin-left:clamp(2.8rem,14vw,12rem)}
.invite .cta{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.invite .tel{font-size:1.08rem;color:var(--umber);text-decoration:none;border-bottom:1px solid var(--sand);padding-bottom:3px;transition:.3s;font-weight:500}
.invite .tel:hover{border-color:var(--clay);color:var(--clay-deep)}
.foot{margin-top:clamp(48px,8vw,96px);padding-top:36px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px}
.nap{font-size:.94rem;color:var(--umber);line-height:1.9;font-weight:400;font-style:normal}
.nap b{color:var(--ink);font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:.82rem}
.nap a{color:var(--umber);text-decoration:none;transition:color .3s}
.nap a:hover{color:var(--clay-deep)}
.foot-links{display:flex;gap:24px;font-size:.84rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;flex-wrap:wrap;justify-content:center}
.foot-links a{color:var(--slate);text-decoration:none;transition:.3s}
.foot-links a:hover{color:var(--clay-deep)}
.foot-ig{font-size:.94rem;color:var(--umber);text-decoration:none;transition:color .3s}
.foot-ig:hover{color:var(--clay-deep)}
.foot-home{display:block;margin-top:12px}
.foot-logo{display:block;width:min(74vw,460px);height:auto}
@media(max-width:640px){
  /* phone: the mark goes full-bleed — letters kiss both edges and the page bottom */
  .invite{padding-bottom:0}
  .foot-home{width:100vw;margin-top:18px}
  .foot-logo{width:100%}
}
.mark{margin-top:26px;font-family:var(--display);font-weight:400;font-size:1.4rem}
.mark b{font-weight:600;color:var(--clay-deep)}

/* ============================================================
   NIGHT SCREENING v0.7 — site-wide noir scope (body.noir).
   Every page sits on the same #0D0C09 the hero photo melts
   into; text steps down in warm cream tones.
   ============================================================ */
body.noir{background:var(--noir);color:rgba(245,241,232,.88)}
.noir ::selection{background:var(--clay);color:var(--noir)}
.noir :focus-visible{outline-color:var(--clay)}
.noir .grain{mix-blend-mode:screen;opacity:.04}
/* header — stays noir when scrolled instead of cutting to paper */
.noir .site-head.scrolled{background:rgba(13,12,9,.82);border-color:rgba(245,241,232,.09)}
.noir .site-head .brand{color:var(--cream)}
.noir .site-head .brand b{color:var(--clay)}
.noir .site-head .nav-links a{color:rgba(245,241,232,.72)}
.noir .site-head .nav-links a:hover,
.noir .site-head .nav-links a[aria-current="page"]{color:var(--cream)}
.noir .site-head .nav-book{background:var(--cream);color:var(--noir)!important}
.noir .site-head .nav-toggle span{background:var(--cream)}
@media(max-width:860px){
  .noir .site-head .nav-links{background:var(--noir)}
  .noir .site-head .nav-links .nav-book{background:none!important;color:var(--cream)!important}
}
/* type helpers on noir */
.noir .lab{color:rgba(245,241,232,.5)}
.noir .eyebrow{color:var(--clay)}
.noir .h-2,.noir .h-display,.noir .h-3{color:var(--cream)}
.noir .h-2 em{color:var(--clay)}
.noir em.accent,.noir .accent-word{color:var(--clay)}
@supports ((-webkit-text-stroke:1px black) or (text-stroke:1px black)){
  .noir .sec-no{color:transparent;-webkit-text-stroke:1.5px rgba(216,207,190,.32)}
}
.noir .sec-no{color:rgba(216,207,190,.3)}
.noir .btn-a{color:var(--clay)}
.noir .btn-s{color:var(--cream);border-color:rgba(245,241,232,.3)}
.noir .btn-s:hover{border-color:var(--cream)}
.noir .tag{background:#1A1712;border-color:rgba(245,241,232,.14);color:rgba(245,241,232,.6)}
.noir .tag:hover{border-color:var(--clay);color:var(--clay)}
.noir .lead{color:rgba(245,241,232,.85)}
.noir .lede{color:rgba(245,241,232,.88)}
.noir .prose{color:rgba(245,241,232,.82)}
.noir .prose h2,.noir .prose h3,.noir .prose strong{color:var(--cream)}
.noir .prose a{color:var(--clay);text-decoration-color:rgba(190,127,104,.4)}
.noir .prose a:hover{text-decoration-color:var(--clay)}
.noir .prose a.btn-p,.noir .prose a.btn-p:hover{color:var(--noir)}
.noir .frame{background:#16130E}
/* comparison table on noir */
.noir .table-wrap{border-color:rgba(245,241,232,.14)}
.noir table.compare th,.noir table.compare td{border-bottom-color:rgba(245,241,232,.1)}
.noir table.compare thead th{background:#1A1712;color:var(--cream)}
.noir table.compare tbody th{color:var(--cream)}
.noir table.compare td{color:rgba(245,241,232,.7)}
.noir table.compare tbody tr:hover{background:rgba(245,241,232,.04)}
/* review cards on noir */
.noir .review{background:#16130E;border-color:rgba(245,241,232,.12)}
.noir .review p{color:rgba(245,241,232,.84)}
.noir .review .who{color:rgba(245,241,232,.5)}
.noir .review a{color:var(--clay)}
/* pricing columns on noir — same boxless system, cream rules */
.noir .tier{border-color:rgba(245,241,232,.14)}
.noir .tier-name,.noir .tier-price{color:var(--cream)}
.noir .tier-meta{color:rgba(245,241,232,.66)}
.noir .tier-badge{color:var(--clay)}
.noir .rate-card{border-top-color:rgba(245,241,232,.28)}
.noir .rate-card:hover{border-color:var(--clay)}
.noir .rate-card.feature{border-top-color:var(--clay)}
.noir .rate-card .rate-body{border-color:rgba(245,241,232,.16)}
.noir .rate-card .no{color:rgba(245,241,232,.5)}
.noir .rate-card .name,.noir .rate-card .price{color:var(--cream)}
.noir .rate-card .student{color:rgba(245,241,232,.5)}
.noir .rate-card li{color:rgba(245,241,232,.84);border-bottom-color:rgba(245,241,232,.1)}
.noir .book-btn{border-color:rgba(245,241,232,.45);color:var(--cream)}
.noir .book-btn:hover{border-color:var(--cream)}
/* FAQ strip on noir */
.noir .faq-item{border-top-color:rgba(245,241,232,.12)}
.noir .faq-item:last-child{border-bottom-color:rgba(245,241,232,.12)}
.noir .faq-item h3{color:var(--cream)}
.noir .faq-item p{color:rgba(245,241,232,.8)}
.noir .faq-item summary::after{border-color:rgba(245,241,232,.25);color:var(--clay)}
.noir .faq-item[open] summary::after{background:var(--clay);border-color:var(--clay);color:var(--noir)}
/* the invitation — credits roll on black */
.noir .invite{background:var(--noir)}
.noir .invite h2{color:var(--cream)}
.noir .invite h2 em{color:var(--clay)}
.noir .invite-lines .il-1{color:rgba(245,241,232,.62)}
.noir .btn-p{background:var(--cream);color:var(--noir)}
.noir .btn-p:hover{background:#fff;box-shadow:0 22px 50px -14px rgba(0,0,0,.55)}
.noir .invite .tel{color:rgba(245,241,232,.75);border-bottom-color:rgba(245,241,232,.3)}
.noir .invite .tel:hover{color:var(--clay);border-color:var(--clay)}
.noir .nap{color:rgba(245,241,232,.6)}
.noir .nap b{color:var(--cream)}
.noir .nap a{color:rgba(245,241,232,.7)}
.noir .nap a:hover{color:var(--clay)}
.noir .foot-links a{color:rgba(245,241,232,.5)}
.noir .foot-links a:hover{color:var(--clay)}
.noir .foot-ig{color:rgba(245,241,232,.7)}
.noir .foot-ig:hover{color:var(--clay)}
.noir .mark{color:var(--cream)}
.noir .mark b{color:var(--clay)}

/* ---- statement — the answer in one take (interlude after hero) ---- */
/* the hero headline, relocated just below the full-screen video */
.statement{padding-block:clamp(4.5rem,11vw,9rem)}
/* line-by-line masked rise (ref: yellowbellyphoto.com) — every visual
   line sits in its own mask and rises straight up into place, cascading
   top to bottom. The section-level fade is disabled; lines carry it. */
.statement.reveal{opacity:1;transform:none}
.st-line .st-l{display:block;overflow:hidden}
.st-line .st-gap{margin-top:.22em}
.st-line .st-in{display:block;transform:translateY(110%);transition:transform 1s cubic-bezier(.23,1,.32,1)}
.st-line .st-l:nth-of-type(2) .st-in{transition-delay:.13s}
.st-line .st-l:nth-of-type(3) .st-in{transition-delay:.26s}
.st-line .st-l:nth-of-type(4) .st-in{transition-delay:.39s}
.statement.lines-in .st-in{transform:none}
.no-js .st-line .st-in{transform:none}
@media(prefers-reduced-motion:reduce){.st-line .st-in{transition:none;transform:none}}
.st-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:clamp(28px,5vw,80px);align-items:end}
.st-line{font-family:var(--display);font-weight:500;font-size:clamp(2.2rem,4.8vw,4.4rem);
  line-height:1.02;letter-spacing:-.02em;color:var(--cream);text-wrap:balance;
  -webkit-text-stroke:.5px currentColor}
.st-line em{font-style:normal;font-weight:500;color:var(--clay)}
.st-answer{color:rgba(245,241,232,.82);font-size:clamp(1.18rem,1.5vw,1.3rem);line-height:1.78;max-width:54ch}
.st-answer strong{color:var(--cream);font-weight:600}
.st-answer a{color:var(--clay);text-decoration:underline;text-underline-offset:3px;
  text-decoration-color:rgba(190,127,104,.4);transition:text-decoration-color .3s}
.st-answer a:hover{text-decoration-color:var(--clay)}
@media(max-width:820px){.st-grid{grid-template-columns:1fr;gap:22px;align-items:start}}

/* ---- looks — headshots / portraits, two doors in ---- */
.looks{display:grid;grid-template-columns:1fr 1fr;gap:clamp(16px,2.6vw,36px)}
.look{display:block;text-decoration:none;color:inherit}
.lk-media{position:relative;overflow:hidden;border-radius:3px;background:#16130E;aspect-ratio:4/3}
.lk-media picture,.lk-media img{width:100%;height:100%;object-fit:cover;object-position:center 24%;
  transition:transform 1.2s var(--ease)}
.look:hover .lk-media img{transform:scale(1.045)}
.lk-name{display:flex;align-items:baseline;justify-content:space-between;margin-top:16px;gap:12px}
.lk-name h3{font-family:var(--display);font-weight:500;font-size:clamp(1.3rem,2vw,1.7rem);
  letter-spacing:-.01em;color:var(--cream)}
.lk-name .arrow{color:var(--clay);font-size:1.32rem;transition:transform .45s var(--ease)}
.look:hover .arrow{transform:translateX(8px)}
.lk-desc{color:rgba(245,241,232,.76);font-size:1.08rem;line-height:1.6;max-width:44ch;margin-top:6px}
/* cards stay side by side on phones too */
@media(max-width:720px){
  .looks{gap:14px}
  .lk-media{aspect-ratio:4/5}
  .lk-name{margin-top:10px}
  .lk-name h3{font-size:1.05rem}
  .lk-name .arrow{font-size:1.14rem}
  .lk-desc{font-size:.94rem;line-height:1.5}
}

/* ---- process — five takes, hello → casting ---- */
.steps{list-style:none;margin:0;padding:0;position:relative;
  display:grid;grid-template-columns:repeat(5,1fr);gap:clamp(18px,2.4vw,32px)}
.steps::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:rgba(245,241,232,.14)}
.step{position:relative;padding-top:1.35rem}
.step::before{content:"";position:absolute;top:-1px;left:0;width:30px;height:3px;background:var(--clay)}
.st-no{display:block;font-family:var(--display);font-weight:700;line-height:1;
  font-size:clamp(2.6rem,4.6vw,4rem);color:rgba(245,241,232,.22);
  transition:color .45s var(--ease),-webkit-text-stroke-color .45s var(--ease)}
@supports ((-webkit-text-stroke:1px black) or (text-stroke:1px black)){
  .st-no{color:transparent;-webkit-text-stroke:1.3px rgba(245,241,232,.3)}
}
.step:hover .st-no{color:var(--clay);-webkit-text-stroke-color:var(--clay)}
@supports ((-webkit-text-stroke:1px black) or (text-stroke:1px black)){
  .step:hover .st-no{color:transparent}
}
.step h3{font-family:var(--display);font-weight:500;font-size:clamp(1.15rem,1.6vw,1.45rem);
  letter-spacing:-.01em;color:var(--cream);margin-top:.55rem}
.step p{color:rgba(245,241,232,.72);font-size:1.01rem;line-height:1.55;margin-top:.35rem;max-width:26ch}
/* phones: the takes stack as a numbered call-sheet */
@media(max-width:720px){
  .steps{grid-template-columns:1fr;gap:0}
  .steps::before{display:none}
  .step{display:grid;grid-template-columns:76px 1fr;column-gap:18px;align-items:start;
    padding:1.05rem 0;border-top:1px solid rgba(245,241,232,.13)}
  .step::before{display:none}
  .step:last-child{border-bottom:1px solid rgba(245,241,232,.13)}
  .st-no{grid-row:1/3;font-size:2.3rem;line-height:.95}
  .step h3{grid-column:2;margin-top:0;font-size:1.15rem}
  .step p{grid-column:2}
}

/* filmstrip mode — vertical scroll scrubs the takes left → right.
   Without JS (or with reduced motion) the section stays the static
   grid/call-sheet above, with the canvas texture as a plain backdrop. */
.proc-scene{position:relative}
.proc-pin{position:relative}
.proc-bg{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:#0B0A08 url('/img/process-bg-2000.jpg') center/cover;opacity:.9}
.proc-in{position:relative;z-index:1}
@media (prefers-reduced-motion:no-preference){
  .js .proc-scene{height:260vh;padding-block:0} /* padding would offset the pin's rest position and pre-scrub the row */
  .js .proc-pin{position:sticky;top:0;height:100svh;min-height:480px;overflow:hidden;
    display:flex;flex-direction:column;justify-content:center}
  .js .proc-bg{inset:0 auto 0 0;width:170%;will-change:transform}
  .js .proc-in{width:100%} /* flex item: without this .wrap shrink-wraps to its max-width */
  .js .proc-scene .sec-head{margin-bottom:clamp(2.2rem,7vh,4.5rem)}
  .js .proc-scene .steps{display:flex;width:max-content;gap:clamp(38px,7vw,90px);will-change:transform}
  .js .proc-scene .steps::before{display:block}
  .js .proc-scene .step{display:block;flex:0 0 auto;width:min(70vw,380px);
    border:0;padding:1.35rem 0 0}
  .js .proc-scene .step::before{display:block}
  .js .proc-scene .st-no{font-size:clamp(2.6rem,4.6vw,4rem);line-height:1}
  .js .proc-scene .step h3{margin-top:.55rem;font-size:clamp(1.15rem,1.6vw,1.45rem)}
  .js .proc-scene .step p{font-size:1.01rem;line-height:1.55}
}
/* phones: the filmstrip is a centered stripe, the ride is shorter/faster,
   and take 01 starts comfortably inset from the left edge */
@media (prefers-reduced-motion:no-preference) and (max-width:720px){
  /* no pin on phones: the stripe keeps its size but scrolls through like a
     normal section — the whole ride plays while it crosses the screen, and
     the neighbors stay right against it (no runway, no parked hold) */
  .js .proc-scene{height:auto;
    background:#0B0A08 url('/img/process-bg-2000.jpg') center/cover}
  .js .proc-pin{height:52svh;min-height:340px;top:0}
  .js .proc-scene .sec-head{margin-bottom:1.5rem}
  .js .proc-scene .step:first-child{margin-left:10vw}
  .js .proc-scene .step:last-child{margin-right:14vw}
}

/* display headings run in caps (Play) */
.h-display,.h-2,.st-line,.invite h2,.lk-name h3,.step h3,.rate-card .name,.prose h2{
  text-transform:uppercase;letter-spacing:.015em}

/* ---- motion (progressive; JS adds .in, sets --i for stagger) ---- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .45s var(--ease),transform .45s var(--ease)}
.reveal.in{opacity:1;transform:none}
/* staggered children inside a reveal (index set by app.js) */
.reveal .frame,.reveal .rate-card,.reveal .review,.reveal .look,.reveal .faq-item,.reveal .step{opacity:0;transform:translateY(16px);
  transition:opacity .5s var(--ease),transform .5s var(--ease);transition-delay:calc(var(--i,0)*55ms)}
.reveal.in .frame,.reveal.in .rate-card,.reveal.in .review,.reveal.in .look,.reveal.in .faq-item,.reveal.in .step{opacity:1;transform:none}
@keyframes rise{to{opacity:1;transform:none}}
@keyframes lineUp{to{transform:none}}
@keyframes shotIn{from{opacity:0;transform:translateY(28px) scale(1.03)}to{opacity:1;transform:none}}

/* ---- stacked scenes (home) — each section pins, the next slides over ----
   app.js sets --pin once (0 for short sections; negative for taller-than-
   viewport ones so they scroll through fully before pinning). All per-frame
   motion (drift + veil) is written inline as transform/opacity — compositor-
   only properties; nothing here changes layout while scrolling. */
/* scroll anchoring feedback-loops with the pinned sections (the browser
   "compensates" for their sticky shifts and the page drifts on its own) */
.js .stack{overflow-anchor:none}
/* The short linear transform transition runs on the compositor and
   bridges main-thread frame drops (phones), so the drift flows instead
   of stepping. No will-change: force-promoting every full-width scene
   costs 100MB+ of GPU textures at phone pixel density. */
/* transform-origin 50% 0: the incoming-scale (app.js) grows each scene from
   its top edge, so scaling never moves the top the cover math reads */
.js .stack>section{position:sticky;top:var(--pin,0px);transform-origin:50% 0;transition:transform .08s linear}
/* section-level reveals animate opacity only — a slow eased transform
   transition here would lag the per-frame drift app.js applies inline */
.js .stack>section.reveal{transform:none;transition:opacity .45s var(--ease),transform .08s linear}
/* full-bleed opaque backdrop + top hairline on the incoming scene
   (the .wrap sections are only 1300px wide — this spans the viewport).
   Pre-stretched 58vh past the section bottom (max drift is 54vh: 19vh
   rest-gap creep + 35vh cover drift) so the drift never opens a gap
   showing the pinned scene behind it; the overhang hides under the
   next section, which always paints above. */
.js .stack>section:not(.hero-cine)::before{content:"";position:absolute;top:0;bottom:-58vh;left:50%;width:100vw;margin-left:-50vw;z-index:-1;
  background:var(--noir);border-top:1px solid rgba(245,241,232,.08)}
/* dim veil over the pinned scene while the next covers it — a real div
   (injected by app.js) so its opacity is set inline per frame */
.js .stack>section .scene-veil{position:absolute;top:0;bottom:0;left:50%;width:100vw;margin-left:-50vw;z-index:7;pointer-events:none;
  background:#000;opacity:0;transition:opacity .12s linear}
/* gallery fly-in/out (app.js writes scroll-linked inline transforms):
   the short linear transform transition glides between main-thread
   updates on the compositor — liquid on phones */
.js .stack .gallery .g-item{transform:none;transition:opacity .4s var(--ease),transform .18s linear}

/* ============================================================
   BOOKING PAGE — /book/. Ticker + pill form after the original
   cinepaul.com booking design: Italiana "Contact me" marquee,
   light pill fields on the noir canvas, boxy send button.
   ============================================================ */
.cm-marquee{overflow:hidden;white-space:nowrap;padding:1.3rem 0 1.5rem;font-family:var(--display);
  font-size:clamp(1.2rem, 1.1rem + .4vw, 1.37rem);color:var(--cream);line-height:1}
.cm-track{display:inline-block}
.js .cm-track{animation:cmScroll 60s linear infinite}
.cm-track span{margin:0 .55em}
.cm-track b{font-weight:400;font-size:.5em;vertical-align:.28em}
@keyframes cmScroll{to{transform:translateX(-50%)}}
.book-scene{padding-top:clamp(1.2rem,3vw,2.6rem)}
.book-grid{display:grid;grid-template-columns:minmax(0,10fr) minmax(0,12fr);gap:clamp(2.5rem,6vw,6rem);align-items:start}
@media(max-width:900px){.book-grid{grid-template-columns:1fr;gap:3.8rem}}
.book-intro{text-align:center;padding-top:clamp(2.75rem,8vw,6rem)}
.bk-title{font-family:var(--display);font-weight:400;color:var(--cream);
  -webkit-text-stroke:.5px currentColor;
  font-size:clamp(1.25rem, 1rem + 1.2vw, 1.7rem);line-height:1.2;letter-spacing:.005em;margin:0 0 1.1em}
.bk-sub{font-size:1.1rem;line-height:1.75;font-weight:700;color:rgba(245,241,232,.95);max-width:29em;margin:0 auto}
.book-form{display:grid;gap:1rem;justify-items:start}
.book-form[hidden]{display:none}
.ff-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.25rem;width:100%}
.ff{display:flex;flex-direction:column;gap:.3rem;width:100%}
.ff label,.ff-checks legend{font-size:1.02rem;color:rgba(245,241,232,.92)}
.ff label span{color:rgba(245,241,232,.55);font-size:.9em}
.ff input,.ff textarea{font-family:var(--font);font-size:1.05rem;color:var(--ink);
  background:#D6D5D3;border:0;border-radius:999px;padding:.52em 1.35em;width:100%;
  appearance:none;-webkit-appearance:none;color-scheme:light;text-align:left}
.ff input::placeholder,.ff textarea::placeholder{color:rgba(28,26,22,.5)}
.ff input:-webkit-autofill{-webkit-text-fill-color:var(--ink);box-shadow:0 0 0 50px #D6D5D3 inset}
.ff textarea{border-radius:22px;min-height:6.5em;resize:vertical;line-height:1.55}
.ff-date{position:relative;width:min(62%,280px)}
.ff-date input{padding-right:3em;min-height:2.3em;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' fill='none' stroke='%231C1A16' stroke-width='1.7'%3E%3Crect x='3.5' y='5' width='17' height='16' rx='2'/%3E%3Cpath d='M3.5 9.5h17M8 2.8v4M16 2.8v4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 1.25em center;background-size:19px}
.ff-date input::-webkit-calendar-picker-indicator{opacity:0;position:absolute;inset:0;width:auto;height:auto;cursor:pointer}
.ff-checks{border:0;padding:0;margin:0;width:100%}
.ff-checks legend{padding:0;margin-bottom:.65rem}
.ff-checks .checks{display:flex;flex-wrap:wrap;gap:.7rem}
.check{position:relative}
.check input{position:absolute;inset:0;opacity:0;cursor:pointer;margin:0}
.check span{display:inline-block;padding:.4em 1.05em;border:1px solid rgba(245,241,232,.8);border-radius:999px;
  color:var(--cream);font-size:1.02rem;transition:background .25s,color .25s,border-color .25s}
.check input:checked+span{background:#D6D5D3;border-color:#D6D5D3;color:var(--ink)}
.check input:focus-visible+span{outline:2px solid var(--clay);outline-offset:2px}
.bk-send{font-family:var(--font);cursor:pointer;background:transparent;border:1px solid var(--cream);
  color:var(--cream);text-transform:uppercase;letter-spacing:.06em;font-size:1.18rem;
  padding:1.05em 2.15em;border-radius:2px;margin-top:.5rem;justify-self:center;transition:background .3s,color .3s}
.bk-send:hover{background:var(--cream);color:var(--noir)}
.bk-send:disabled{opacity:.55;cursor:default}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.form-err{color:var(--blush);font-size:1.02rem;margin:0}
.form-err a{color:var(--blush);text-decoration:underline;text-underline-offset:3px}
.form-done h2{font-family:var(--display);font-weight:500;font-size:var(--step-2);letter-spacing:-.015em;line-height:1.08;margin:0 0 .5em;color:var(--cream)}
.form-done p{font-size:1.15rem;line-height:var(--leading-body);margin:0 0 .8em;max-width:46ch;color:rgba(245,241,232,.84)}
.form-done:focus{outline:none}
.book-pay{text-align:center;font-size:1.18rem;line-height:1.7;color:rgba(245,241,232,.9);margin:clamp(3rem,7vw,5rem) auto 0;max-width:34em}

/* entrance + scroll reveals — the gentle Squarespace-flex feel:
   elements wait offscreen, then ease up slowly as they enter view */
@keyframes bkFade{from{opacity:0}to{opacity:1}}
.js .cm-marquee{animation:bkFade 1s var(--ease) both}
.js .bk-pre{opacity:0;transform:translateY(28px) scale(.985);
  transition:opacity 1.2s var(--ease),transform 1.2s var(--ease)}
.js .bk-pre.bk-in{opacity:1;transform:none}
/* home reuses the booking reveal, a touch slower (.stack is home-only) */
.js .stack .bk-pre,.js .stack~.invite .bk-pre{transition-duration:1.5s}
@media(prefers-reduced-motion:reduce){
  .js .cm-marquee{animation:none!important}
  .js .bk-pre{opacity:1!important;transform:none!important;transition:none!important}
}

/* ---- no-JS: never hide content that JS would reveal ---- */
.no-js .reveal,.no-js .frame,.no-js .rate-card,.no-js .review,.no-js .look,.no-js .faq-item{opacity:1;transform:none}
.no-js .scroll-progress,.no-js .grain{display:none}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .nav-links li{transition-delay:0s!important}
  .reveal,.frame,.rate-card,.review,.look,.faq-item{opacity:1!important;transform:none!important}
  .hero-kicker,.hero-stage .cta,.hero-credits,.hero-media,.hero-cine::before,.hero-title .ln>span,.shot{opacity:1!important;transform:none!important;animation:none!important}
  /* keep the centering transform — only kill the motion */
  .hero-logo{opacity:1!important;animation:none!important;transform:translate(-50%,-50%)!important}
  .hero-media::before{display:none}
  .scroll-cue span{animation:none!important}
  .grain{display:none}
  .stack>section{position:static!important;transform:none!important}
  .stack>section::before,.stack>section .scene-veil{display:none!important}
}
