/* ============================================================
   cinepaul — site stylesheet · "Cinema Opening" v0.5
   Dark film-poster first screen built around one photograph,
   cutting to a warm-white gallery below.
   Clash Display (display) + Hanken Grotesk (text).
   Static-HTML-first, GPU motion, honors reduced-motion & no-JS.
   ============================================================ */

:root {
  /* neutrals */
  --paper:#FCFBF9; --oat:#F1ECE3; --greige:#E4DDD1; --sand:#D8CFBE;
  --cream:#F5F1E8;
  /* ink / noir */
  --ink:#1C1A16; --noir:#0D0C09; --umber:#4A443C; --slate:#7C766B;
  /* accent (muted clay) */
  --clay:#BE7F68; --clay-deep:#A5674F;
  /* 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:"Hanken Grotesk","Inter",system-ui,sans-serif;
  --display:"Clash Display","Hanken Grotesk",system-ui,sans-serif;
  --step--1:clamp(0.78rem,0.75rem + 0.15vw,0.85rem);
  --step-0:clamp(0.95rem,0.92rem + 0.2vw,1.05rem);
  --step-1:clamp(1.2rem,1.1rem + 0.5vw,1.5rem);
  --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:4px; --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}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font);
  font-size:var(--step-0);line-height:var(--leading-body);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:clip}
img{max-width:100%;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:0;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:.72rem;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:.66rem;text-transform:uppercase;letter-spacing:.18em;color:var(--slate);font-weight:600;display:inline-flex;align-items:baseline}
.lab .s-no{font-family:var(--display);font-weight:500;font-size:1.3em;letter-spacing:.02em;color:var(--clay-deep);margin-right:.7em}
/* hollow accent — the site's type signature */
em.accent,.accent-word{font-style:normal;font-weight:inherit;color:var(--clay-deep)}
@supports ((-webkit-text-stroke:1px black) or (text-stroke:1px black)){
  em.accent,.accent-word{color:transparent;-webkit-text-stroke:1.6px var(--clay-deep)}
}

/* ---- header / nav ---- */
.site-head{position:sticky;top:0;z-index:var(--z-head);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{font-family:var(--display);font-weight:400;font-size:1.3rem;letter-spacing:.01em;text-decoration:none;color:var(--ink)}
.brand b{font-weight:600;color:var(--clay-deep)}
.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:.82rem;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)}
.nav-book{background:var(--ink);color:var(--paper)!important;padding:9px 18px;border-radius:100px;font-size:.8rem;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:8px;flex-direction:column;gap:5px}
.nav-toggle span{width:22px;height:1.6px;background:var(--ink);transition:.3s var(--ease)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-6.6px) 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){
  .nav-toggle{display:flex}
  .nav-links{position:fixed;inset:var(--head-h) 0 auto 0;flex-direction:column;background:var(--paper);
    border-bottom:1px solid var(--greige);padding:20px var(--gutter) 28px;gap:18px;align-items:flex-start;
    transform:translateY(-120%);transition:transform .5s var(--ease);box-shadow:var(--shadow-2);z-index:var(--z-nav)}
  .nav-links.open{transform:none}
  .nav-links a{font-size:1rem}
  .nav-links a:not(.nav-book)::after{bottom:-3px}
  .site-head.on-dark:not(.scrolled) .nav-links a{color:var(--umber)}
  .site-head.on-dark:not(.scrolled) .nav-links .nav-book{background:var(--ink);color:var(--paper)!important}
}

/* ---- buttons ---- */
.btn{font-family:var(--font);cursor:pointer;border:none;font-size:.9rem;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:.7rem;
  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:var(--step-2);letter-spacing:-.015em;line-height:1.05}
.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.05rem,1.6vw,1.3rem);line-height:1.5;max-width:46ch;font-weight:400;text-wrap:pretty}

/* ============================================================
   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);
  min-height:100dvh;display:flex;flex-direction:column;justify-content:flex-end;
  margin-top:calc(-1 * var(--head-h));padding-top:calc(var(--head-h) + 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;
  opacity:0;animation:heroMedia 1.8s var(--ease) .1s both}
.hero-media img,.hero-media picture{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}
.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:.68rem;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)}
@supports ((-webkit-text-stroke:1px black) or (text-stroke:1px black)){
  .hero-title .hollow{color:transparent;-webkit-text-stroke:2.5px var(--clay)}
}
.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:.9rem;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:.9rem;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;border-top:1px solid rgba(245,241,232,.13);
  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:.63rem;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{opacity:0;transform:scale(1.04)}to{opacity:1;transform:none}}
@media(max-width:860px){
  .hero-cine{padding-top:calc(var(--head-h) + 1rem)}
  .hero-cine::before{display:none}
  .hero-media{width:100%;left:0}
  .hero-media img{object-position:center 18%}
  .hero-media::after{background:
    linear-gradient(180deg,rgba(13,12,9,.35) 0%,rgba(13,12,9,.1) 30%,rgba(13,12,9,.62) 62%,var(--noir) 92%)}
  .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) ---- */
.shot{position:relative;border-radius:var(--radius-3);overflow:hidden;box-shadow:var(--shadow-lift);
  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-3)}
.shot::before{content:"";position:absolute;inset:12px;border:1px solid rgba(255,255,255,.42);border-radius:9px;z-index:2;pointer-events:none}
.shot::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;border-radius:var(--radius-3);
  box-shadow:inset 0 0 130px rgba(18,16,11,.30)}
.about-layout{display:grid;grid-template-columns:.82fr 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}}
.shot .cap{position:absolute;left:22px;bottom:20px;z-index:3;font-size:.62rem;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:.6rem;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:12px;background:var(--oat);display:block;margin:0 0 14px;break-inside:avoid;box-shadow:var(--shadow-1)}
.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(18,16,11,.42));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:.58rem;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}

/* ---- rate cards ---- */
.rates-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:820px){.rates-grid{grid-template-columns:1fr}}
.rate-card{background:#fff;border:1px solid var(--greige);border-radius:var(--radius-3);padding:30px 26px;position:relative;
  display:flex;flex-direction:column;overflow:hidden;isolation:isolate;
  transition:transform var(--d) var(--ease),box-shadow var(--d) var(--ease),border-color var(--d) var(--ease)}
.rate-card::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;opacity:0;transition:opacity .45s var(--ease);
  background:radial-gradient(340px circle at var(--mx,50%) var(--my,0%),rgba(190,127,104,.16),transparent 62%)}
.rate-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lift);border-color:var(--sand)}
.rate-card:hover::before{opacity:1}
.rate-card.feature{background:linear-gradient(180deg,var(--oat),#EFE7D9);border-color:var(--clay);box-shadow:0 20px 44px -24px rgba(165,103,79,.4)}
.rate-card .badge{position:absolute;top:20px;right:20px;font-size:.54rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--paper);background:var(--clay-deep);padding:5px 11px;border-radius:100px;font-weight:600}
.rate-card .no{font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);font-weight:600}
.rate-card .name{font-family:var(--display);font-weight:500;font-size:1.55rem;letter-spacing:-.01em;margin:.5em 0 .1em;line-height:1.05}
.rate-card .dur{color:var(--slate);font-size:.78rem;letter-spacing:.03em;text-transform:uppercase;font-weight:500}
.rate-card .price{font-family:var(--display);font-weight:500;font-size:2.5rem;margin:.35rem 0 1rem;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.rate-card .price small{font-family:var(--font);font-size:.8rem;color:var(--slate);font-weight:500;vertical-align:middle;margin-left:6px;letter-spacing:0}
.rate-card .student{font-size:.72rem;color:var(--clay-deep);letter-spacing:.02em;margin:-.55rem 0 1rem;font-weight:600}
.rate-card ul{list-style:none;margin:0 0 1.5rem;padding:0;border-top:1px solid var(--greige)}
.rate-card li{padding:10px 0;border-bottom:1px solid var(--greige);font-size:.87rem;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}
.book-btn{width:100%;cursor:pointer;font-family:var(--font);font-weight:500;font-size:.86rem;padding:14px;border-radius:100px;margin-top:auto;
  border:1px 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)}
.rate-card.feature .book-btn{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.rate-card.feature .book-btn:hover{background:var(--noir);box-shadow:var(--shadow-2)}

/* ---- prose / article (content pages) ---- */
.prose{max-width:70ch;font-size:1.05rem;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.14rem,1.7vw,1.38rem);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:.92rem;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:.72rem;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);padding:1.5rem 0;display:grid;grid-template-columns:minmax(0,1fr);gap:.3rem;transition:padding-left .4s var(--ease)}
.faq-item:hover{padding-left:.6rem}
.faq-item:last-child{border-bottom:1px solid var(--greige)}
.faq-item h3{font-family:var(--display);font-weight:500;font-size:1.18rem;color:var(--ink);margin-bottom:.35em;letter-spacing:-.005em;line-height:1.25}
.faq-item p{color:var(--umber);line-height:1.62;max-width:70ch}
@media(min-width:720px){.faq-item{grid-template-columns:.9fr 1.4fr;gap:2rem;align-items:baseline}}

/* ---- 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:.9rem;margin-bottom:.6em}
.review p{color:var(--umber);line-height:1.62;font-size:.98rem;margin-bottom:1em}
.review .who{font-size:.78rem;color:var(--slate);font-weight:600;letter-spacing:.02em}

/* ---- booking footer ---- */
.invite{position:relative;padding:clamp(56px,9vw,128px) 0 40px;overflow:hidden;background:
  radial-gradient(60% 60% at 82% 4%,rgba(216,183,172,.42),transparent 60%),
  radial-gradient(55% 65% at 6% 104%,rgba(167,190,198,.36),transparent 60%),
  radial-gradient(40% 50% at 50% 60%,rgba(169,178,154,.14),transparent 70%),var(--paper)}
.invite::before{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,var(--greige),transparent)}
.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)}
@supports ((-webkit-text-stroke:1px black) or (text-stroke:1px black)){
  .invite h2 em{color:transparent;-webkit-text-stroke:1.8px var(--clay-deep)}
}
.invite .cta{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.invite .tel{font-size:.9rem;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:24px;border-top:1px solid var(--greige);display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;align-items:flex-start}
.nap{font-size:.78rem;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:.68rem}
.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:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;flex-wrap:wrap}
.foot-links a{color:var(--slate);text-decoration:none;transition:.3s}
.foot-links a:hover{color:var(--clay-deep)}
.mark{margin-top:26px;font-family:var(--display);font-weight:400;font-size:1.4rem}
.mark b{font-weight:600;color:var(--clay-deep)}

/* ---- motion (progressive; JS adds .in, sets --i for stagger) ---- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s 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{opacity:0;transform:translateY(30px) scale(.99);
  transition:opacity .75s var(--ease),transform .75s var(--ease);transition-delay:calc(var(--i,0)*70ms)}
.reveal.in .frame,.reveal.in .rate-card,.reveal.in .review{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}}

/* ---- no-JS: never hide content that JS would reveal ---- */
.no-js .reveal,.no-js .frame,.no-js .rate-card,.no-js .review{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}
  .reveal,.frame,.rate-card,.review{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}
  .scroll-cue span{animation:none!important}
  .grain{display:none}
}
