/* ============================================================
   cinepaul — site stylesheet · "Cinematic Editorial" v0.3
   Warm editorial base + film-title motion, serif/sans pairing,
   filmic grain, spotlight surfaces. Static-HTML-first, GPU motion,
   fully honors prefers-reduced-motion and no-JS.
   ============================================================ */

:root {
  /* neutrals */
  --paper:#FAF8F4; --oat:#F1ECE3; --greige:#E4DDD1; --sand:#D8CFBE;
  /* ink */
  --ink:#1C1A16; --noir:#141109; --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;
  --serif:"Fraunces","Hanken Grotesk",Georgia,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.7rem,1.35rem + 1.6vw,2.7rem);
  --step-3:clamp(2.3rem,1.7rem + 3vw,3.9rem);
  --step-4:clamp(3rem,1.9rem + 5.6vw,6.6rem);
  --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);
  /* 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(--serif);font-style:italic;font-weight:400;font-size:1.35em;letter-spacing:0;color:var(--clay-deep);margin-right:.7em;-webkit-text-fill-color:currentColor}
em.accent,.accent-word{font-style:italic;font-weight:400;color:var(--clay-deep);font-family:var(--serif)}

/* ---- header / nav ---- */
.site-head{position:sticky;top:0;z-index:var(--z-head);background:rgba(250,248,244,.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(250,248,244,.85)}
.site-head.hidden{transform:translateY(-101%)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{font-weight:300;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)}
@media(max-width:860px){
  .nav-toggle{display:flex}
  .nav-links{position:fixed;inset:68px 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}
}

/* ---- 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(--serif);font-weight:300;font-size:var(--step-4);line-height:.98;letter-spacing:-.025em}
.h-2{font-family:var(--serif);font-weight:300;font-size:var(--step-2);letter-spacing:-.02em;line-height:1.02}
.h-2 em{font-style:italic;color:var(--clay-deep);font-weight:400}
.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 ---- */
.hero{position:relative;min-height:min(92vh,780px);display:grid;grid-template-columns:1.05fr .95fr;
  align-items:center;gap:clamp(24px,5vw,72px);padding-block:clamp(2rem,5vw,3.5rem)}
.hero .copy{max-width:660px}
.hero-title{font-family:var(--serif);font-weight:300;font-size:clamp(3rem,8.8vw,6.8rem);line-height:.96;letter-spacing:-.03em;margin:.3em 0 .38em}
.hero-title em{font-style:italic;font-weight:400;color:var(--clay-deep)}
.hero-title .ln{display:block;overflow:hidden;padding-bottom:.06em}
.hero-title .ln>span{display:block;transform:translateY(112%);animation:lineUp .95s var(--ease) both}
.hero-title .ln:nth-child(1)>span{animation-delay:.28s}
.hero-title .ln:nth-child(2)>span{animation-delay:.42s}
.hero .sub{max-width:48ch;color:var(--umber);line-height:1.6;font-size:clamp(1rem,1.4vw,1.14rem);text-wrap:pretty}
.hero .cta{display:flex;gap:16px;margin-top:2.2rem;flex-wrap:wrap;align-items:center}
.hero-meta{list-style:none;display:flex;flex-wrap:wrap;gap:14px 22px;margin-top:2.4rem;padding-top:1.4rem;border-top:1px solid var(--greige)}
.hero-meta li{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slate);font-weight:600;position:relative;padding-left:16px}
.hero-meta li::before{content:"";position:absolute;left:0;top:.42em;width:5px;height:5px;border-radius:50%;background:var(--clay)}
/* hero on-load fades */
.hero .eyebrow,.hero .sub,.hero .cta,.hero-meta{opacity:0;animation:rise .9s var(--ease) both}
.hero .eyebrow{animation-delay:.15s}
.hero .sub{animation-delay:.6s}
.hero .cta{animation-delay:.72s}
.hero-meta{animation-delay:.84s}

.shot{position:relative;border-radius:var(--radius-3);overflow:hidden;box-shadow:var(--shadow-lift);
  opacity:0;animation:shotIn 1.1s var(--ease) .2s 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(20,17,9,.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;animation-delay:.05s}
@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}
@media(max-width:860px){.hero{grid-template-columns:1fr;min-height:auto}.shot{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)}

/* ---- marquee ticker ---- */
.marquee{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:20px 0;margin-block:clamp(.5rem,3vw,1.5rem);
  -webkit-mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee-track{display:flex;width:max-content;animation:marquee 36s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.marquee .mq{display:flex;align-items:center;flex:0 0 auto}
.marquee .mq span{font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(1.15rem,2.6vw,1.9rem);color:var(--umber);white-space:nowrap;padding:0 1.3rem}
.marquee .mq .star{font-style:normal;color:var(--clay);font-size:.62em;padding:0 .3rem;transform:translateY(-.12em)}

/* ---- 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(20,17,9,.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(--serif);font-weight:400;font-size:1.65rem;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(--serif);font-weight:300;font-size:2.7rem;margin:.35rem 0 1rem;letter-spacing:-.02em;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(--serif);font-weight:400;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-family:var(--serif);font-size:clamp(1.2rem,1.9vw,1.5rem);color:var(--ink);line-height:1.42;font-weight:300;max-width:60ch;margin-bottom:1.4em;text-wrap:pretty;letter-spacing:-.01em}

/* ---- 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(--serif);font-weight:400;font-size:1.28rem;color:var(--ink);margin-bottom:.35em;letter-spacing:-.01em;line-height:1.2}
.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:1rem;margin-bottom:1em;font-family:var(--serif);font-weight:300;font-style:italic}
.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(--serif);font-weight:300;font-size:clamp(2.5rem,7vw,5.2rem);line-height:1;letter-spacing:-.03em;margin:.3em 0 .6em;max-width:16ch}
.invite h2 em{font-style:italic;font-weight:400;color: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(--serif);font-weight:300;font-size:1.4rem}
.mark b{font-weight:500;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}}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---- 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 .eyebrow,.hero .sub,.hero .cta,.hero-meta,.hero-title .ln>span,.shot{opacity:1!important;transform:none!important;animation:none!important}
  .marquee-track{animation:none!important}
  .grain{display:none}
}
