/* ===================================================================
   LMB PRESENTS — Film & TV streaming-archive landing
   2026 award-tier MERIDIAN skin. Box-art cards, cinematic motion, film
   grain, parallax hero. Tokens/fonts/.btn inherited from styles.css.
   Data-driven from lmb-presents-slate.json. Her Soul-ID plates.
   =================================================================== */
:root {
  --gold: rgba(194,178,157,0.95); --gold-dim: rgba(194,178,157,0.55);
  --spring: cubic-bezier(0.32,0.72,0,1); --ease2: cubic-bezier(0.22,1,0.36,1);
}

.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; }
.sr-only:focus,.sr-only:focus-visible { position:fixed;top:8px;left:8px;width:auto;height:auto;clip:auto;margin:0;padding:10px 16px;z-index:300;background:var(--coal);color:var(--bone);outline:2px solid var(--gold); }

html { scroll-behavior: smooth; }
body.presents { background: var(--black); color: var(--bone); overflow-x: hidden; }

/* fixed film-grain layer (premium texture, never on scroll containers) */
.pr-grain {
  position: fixed; inset: 0; z-index: 90; pointer-events: none; opacity: 0.05;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------------- SCROLL-REVEAL ---------------- */
[data-rv] { opacity: 0; transform: translateY(22px); filter: blur(6px);
  transition: opacity .9s var(--ease2), transform .9s var(--ease2), filter .9s var(--ease2); }
[data-rv].rv-in { opacity: 1; transform: none; filter: none; }

/* ---------------- TOP BAR ---------------- */
.pr-topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  padding: 22px clamp(18px,2.4vw,36px) 22px clamp(24px,5vw,80px);
  transition: background-color .4s var(--ease2), backdrop-filter .4s var(--ease2), border-color .4s var(--ease2), padding .4s var(--ease2);
  border-bottom: 0.5px solid transparent;
}
.pr-topbar.scrolled { background: rgba(12,12,14,0.72); backdrop-filter: blur(16px) saturate(1.1); -webkit-backdrop-filter: blur(16px) saturate(1.1); border-bottom-color: var(--hairline); padding-top: 14px; padding-bottom: 14px; }
.pr-brand { display: inline-flex; align-items: center; gap: 12px; }
.pr-brand .mark { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 500; font-size: 26px; letter-spacing: 0.18em; color: var(--bone); }
.pr-brand .tick { width: 1px; height: 18px; background: var(--gold); opacity: 0.7; }
.pr-brand .label { color: var(--gold); }
.pr-nav { display: flex; align-items: center; gap: clamp(16px,2vw,36px); }
.pr-nav a { font-family: 'Archivo', sans-serif; font-weight: 500; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bone-dim); position: relative; padding: 6px 0; transition: color .25s var(--ease2); }
.pr-nav a:hover, .pr-nav a[aria-current="page"] { color: var(--bone); }
.pr-nav a[aria-current="page"]::after { content:""; position:absolute; left:0; right:0; bottom:-3px; height:1px; background: var(--gold); }
.pr-actions { display: flex; align-items: center; gap: 14px; }
.pr-icon { width: 38px; height: 38px; border-radius: 50%; border: 0.5px solid var(--hairline); background: none; color: var(--bone-dim); display: grid; place-items: center; cursor: default; transition: color .25s,border-color .25s; }
.pr-icon svg { width: 17px; height: 17px; }
.pr-icon[disabled] { opacity: 0.5; }
.pr-book-pill { font-family: 'Archivo', sans-serif; font-weight: 500; font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; background: var(--signal); color: var(--bone); border: 0; cursor: pointer; padding: 12px 24px; border-radius: 999px; transition: background-color .2s var(--ease2), transform .2s var(--spring); }
.pr-book-pill:hover { background: #e11533; transform: translateY(-1px) scale(1.02); }
.pr-book-pill:active { transform: scale(0.98); }

/* ---------------- HERO ---------------- */
.pr-hero { position: relative; width: 100%; height: 100vh; min-height: 700px; overflow: hidden; background: var(--black); }
.pr-hero-bg { position: absolute; inset: -6%; z-index: 0; will-change: transform; }
.pr-stage { position: relative; z-index: 3; height: 100%; display: flex; flex-direction: column; }
.pr-stage-foot { flex: 0 0 auto; }
.pr-bd { position: absolute; inset: 0; opacity: 0; transition: opacity .6s var(--ease2); }
.pr-bd.is-front { opacity: 1; }
.pr-bd img { width: 100%; height: 100%; object-fit: cover; object-position: 74% 40%; transform: scale(1.04); transition: transform 1.6s var(--ease2); }
.pr-hero-bg::after { content:""; position:absolute; inset:0; pointer-events:none; background: radial-gradient(120% 120% at 74% 36%, rgba(255,205,140,0.10), transparent 46%); mix-blend-mode: screen; }
.pr-scrim { position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background:
    linear-gradient(102deg, var(--black) 0%, rgba(10,10,11,0.9) 38%, rgba(10,10,11,0.4) 60%, transparent 80%),
    linear-gradient(0deg, var(--black) 0%, rgba(10,10,11,0.95) 22%, rgba(10,10,11,0.4) 42%, transparent 58%); }
.pr-well { position: relative; z-index: 3; max-width: clamp(420px,48%,640px); padding: clamp(84px,10vh,116px) clamp(24px,5vw,80px) clamp(14px,2vh,26px); flex: 1 1 auto; min-height: 0; display: flex; flex-direction: column; justify-content: flex-start; overflow: hidden; }
.pr-kicker { margin-bottom: 12px; color: var(--gold); display: flex; align-items: center; gap: 10px; }
.pr-kicker .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--signal); }
.pr-title { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 500; font-size: clamp(34px,3.9vw,58px); line-height: 0.99; letter-spacing: 0.004em; color: var(--bone); margin-bottom: 13px; max-width: 100%; overflow-wrap: break-word; }
.pr-title em { font-style: italic; color: var(--signal); }
.pr-meta { display: flex; flex-wrap: wrap; align-items: center; gap: 8px 0; margin-bottom: 16px; }
.pr-meta .chip { font-family: 'Archivo', sans-serif; font-weight: 500; font-size: 12.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bone); display: inline-flex; align-items: center; }
.pr-meta .chip:not(:last-child)::after { content:"•"; color: var(--gold); margin: 0 13px; }
.pr-meta .chip.lead { color: var(--bone); border: 0.5px solid rgba(200,16,46,0.6); border-radius: 999px; padding: 5px 14px; background: rgba(200,16,46,0.08); }
.pr-meta .chip.lead::after { margin-left: 14px; }
.pr-logline { font-family: 'Archivo', sans-serif; font-weight: 300; font-size: clamp(15px,1.3vw,17px); line-height: 1.6; color: var(--bone-dim); max-width: 50ch; margin-bottom: 8px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.pr-desc { font-family: 'Archivo', sans-serif; font-weight: 300; font-size: 15px; line-height: 1.65; color: var(--bone-dim); max-width: 52ch; max-height: 0; overflow: hidden; opacity: 0; transition: max-height .4s var(--ease2), opacity .4s var(--ease2), margin .4s var(--ease2); }
.pr-desc.open { max-height: 340px; opacity: 1; margin-top: 12px; }
.pr-seemore { background: none; border: 0; cursor: pointer; padding: 6px 0; color: var(--gold); font-family: 'Archivo', sans-serif; font-weight: 500; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 26px; align-self: flex-start; display: inline-flex; align-items: center; gap: 8px; transition: color .2s var(--ease2); }
.pr-seemore::after { content: ""; width: 5px; height: 5px; border-right: 1px solid currentColor; border-bottom: 1px solid currentColor; transform: rotate(45deg) translateY(-1px); transition: transform .3s var(--ease2); }
.pr-seemore[aria-expanded="true"]::after { transform: rotate(-135deg) translateY(1px); }
.pr-seemore:hover { color: var(--bone); }
.pr-ctas { display: flex; flex-wrap: nowrap; align-items: center; gap: 12px; margin-bottom: 30px; }
.pr-ctas .btn { white-space: nowrap; flex: 0 1 auto; min-width: 0; padding: 14px 24px; }
.btn.is-soon { opacity: 0.5; cursor: default; pointer-events: none; }

/* button-in-button: nested circular trailing icon */
.btn .ico { display: inline-grid; place-items: center; width: 26px; height: 26px; margin-left: 4px; margin-right: -8px; border-radius: 50%; background: rgba(244,241,236,0.16); font-size: 13px; transition: transform .25s var(--spring), background-color .25s; }
.btn-solid .ico { background: rgba(0,0,0,0.18); }
.btn:hover .ico { transform: translate(2px,-1px) scale(1.06); }
.btn .ico-l { font-size: 9px; margin-right: 4px; opacity: 0.85; }
.btn:active { transform: scale(0.985); }

.pr-arrows { display: none; }   /* redundant with the always-visible rail; keyboard ←/→ still works */
.pr-arrow { width: 48px; height: 48px; border-radius: 50%; background: rgba(10,10,11,0.4); border: 0.5px solid var(--hairline); color: var(--bone); cursor: pointer; display: grid; place-items: center; font-size: 19px; transition: background-color .2s var(--ease2), border-color .2s, transform .2s var(--spring); }
.pr-arrow:hover { background: rgba(244,241,236,0.08); border-color: var(--gold-dim); transform: scale(1.06); }
.pr-arrow:focus-visible, .pr-book-pill:focus-visible, .pr-nav a:focus-visible, .pr-card:focus-visible, .pr-seemore:focus-visible, .pr-icon:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; }

.pr-scrollcue { position: absolute; left: 50%; bottom: 26px; transform: translateX(-50%); z-index: 4; display: flex; flex-direction: column; align-items: center; gap: 10px; color: var(--bone-dim); font-family:'Archivo',sans-serif; font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; }
.pr-scrollcue .line { width: 1px; height: 40px; background: linear-gradient(var(--gold), transparent); }

/* ---------------- NETWORK BAR ---------------- */
.pr-networks { position: relative; z-index: 5; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 7px 22px; padding: 12px clamp(24px,5vw,80px); border-top: 0.5px solid var(--hairline); background: linear-gradient(0deg, rgba(10,10,11,0.6), transparent); }
.pr-networks .nlabel { font-family:'Archivo',sans-serif; font-weight: 500; font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--gold); margin-right: 8px; }
.pr-networks .net { font-family:'Cormorant Garamond', Georgia, serif; font-weight: 500; font-size: 17px; letter-spacing: 0.04em; color: var(--bone-dim); }

/* ---------------- POSTER RAIL (BOX ART) ---------------- */
.pr-rail-wrap { position: relative; z-index: 6; padding: 12px clamp(24px,5vw,80px) clamp(14px,2.2vh,24px); }
.pr-rail-head { margin-bottom: 10px; display: flex; align-items: baseline; gap: 14px; }
.pr-rail-head .pr-rail-eyebrow { color: var(--gold); }
.pr-rail-head .ttl { font-family:'Cormorant Garamond', Georgia, serif; font-weight: 500; font-size: clamp(20px,2.2vw,28px); color: var(--bone); line-height: 1; }
.pr-rail { display: flex; gap: 16px; overflow-x: auto; scroll-snap-type: x proximity; scrollbar-width: none; padding: 8px 2px 10px; }
.pr-rail::-webkit-scrollbar { display: none; }

/* card = double-bezel box art */
.pr-card { flex: 0 0 auto; width: clamp(116px,8.8vw,148px); background: none; border: 0; padding: 0; cursor: pointer; scroll-snap-align: start; transition: transform .5s var(--spring); }
.pr-card-shell { display: block; padding: 6px; border-radius: 18px; background: rgba(244,241,236,0.04); border: 0.5px solid rgba(244,241,236,0.08); transition: border-color .4s var(--ease2), background-color .4s var(--ease2), box-shadow .4s var(--ease2); }
.pr-card-core { position: relative; display: block; aspect-ratio: 2/3; border-radius: 12px; overflow: hidden; background: var(--coal); box-shadow: inset 0 1px 1px rgba(255,255,255,0.08); }
.pr-card-core img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .7s var(--ease2); }
.pr-card-art { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: space-between; padding: 12px; background: linear-gradient(0deg, rgba(10,10,11,0.92) 0%, rgba(10,10,11,0.15) 42%, transparent 64%); }
.pr-card-genre { align-self: flex-start; font-family:'Archivo',sans-serif; font-weight: 500; font-size: 8px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold); background: rgba(10,10,11,0.6); border: 0.5px solid var(--gold-dim); border-radius: 999px; padding: 4px 9px; }
.pr-card-bottom { display: block; }
.pr-card-idx { font-family:'Cormorant Garamond', serif; font-size: 13px; color: var(--gold); display: block; }
.pr-card-title { font-family:'Cormorant Garamond', Georgia, serif; font-weight: 500; font-size: clamp(19px,1.5vw,23px); line-height: 1.02; color: var(--bone); display: block; margin-top: 2px; }
.pr-card-tag { font-family:'Archivo',sans-serif; font-weight: 300; font-size: 11px; line-height: 1.4; color: var(--bone-dim); display: block; margin-top: 6px; max-height: 0; opacity: 0; overflow: hidden; transition: max-height .5s var(--ease2), opacity .5s var(--ease2); }

.pr-card:hover { transform: translateY(-10px); }
.pr-card:hover .pr-card-shell { border-color: var(--gold-dim); background: rgba(244,241,236,0.06); box-shadow: 0 30px 60px -30px rgba(0,0,0,0.8); }
.pr-card:hover .pr-card-core img { transform: scale(1.06); }
.pr-card:hover .pr-card-tag { max-height: 70px; opacity: 1; }

.pr-card.is-active .pr-card-genre { display: none; }
.pr-card.is-active { transform: translateY(-8px) scale(1.04); }
.pr-card.is-active .pr-card-shell { border-color: var(--gold); box-shadow: 0 0 0 1px var(--gold), 0 0 34px -6px rgba(194,178,157,0.5), 0 34px 64px -28px rgba(0,0,0,0.9); }
.pr-card.is-active .pr-card-core::after { content:"Now Playing"; position: absolute; top: 12px; right: 12px; z-index: 3; font-family:'Archivo',sans-serif; font-weight: 500; font-size: 8px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--black); background: var(--gold); padding: 4px 9px; border-radius: 999px; }
.pr-card.is-active .pr-card-core::before { content:""; position: absolute; left: 0; right: 0; bottom: 0; height: 3px; background: var(--signal); z-index: 3; }

/* coming-soon card (G7) — non-interactive */
.pr-card.is-soon-card { cursor: default; }
.pr-card.is-soon-card .pr-card-core img { filter: grayscale(0.3) brightness(0.7); }
.pr-card.is-soon-card .pr-card-core::after { content:"Coming Soon"; position: absolute; top: 12px; right: 12px; z-index: 3; font-family:'Archivo',sans-serif; font-weight: 500; font-size: 8px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--bone); background: rgba(200,16,46,0.85); padding: 4px 9px; border-radius: 999px; }
.pr-card.is-soon-card:hover { transform: translateY(-4px); }

/* ---------------- FOOTER ---------------- */
.pr-footer { border-top: 0.5px solid var(--hairline); padding: 44px clamp(24px,5vw,80px); }
.pr-foot-genres { display: flex; flex-wrap: wrap; gap: 10px 28px; justify-content: center; margin-bottom: 28px; }
.pr-foot-genres span { font-family:'Archivo',sans-serif; font-weight: 500; font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold-dim); }
.pr-foot-row { display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 18px; }
.pr-switch { display: inline-flex; border: 0.5px solid var(--hairline); border-radius: 999px; overflow: hidden; }
.pr-switch a { padding: 10px 20px; font-family:'Archivo',sans-serif; font-weight: 500; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bone-dim); transition: background-color .25s,color .25s; }
.pr-switch a:hover { color: var(--bone); }
.pr-switch a.cur { background: var(--coal); color: var(--bone); }
.pr-foot-note { font-family:'Archivo',sans-serif; font-size: 11px; letter-spacing: 0.06em; color: var(--bone-dim); }

/* ---------------- BOOKING SHEET ---------------- */
.pr-sheet-veil { position: fixed; inset: 0; z-index: 200; background: rgba(5,5,6,0.72); backdrop-filter: blur(5px); opacity: 0; visibility: hidden; transition: opacity .35s var(--ease2), visibility 0s linear .35s; }
.pr-sheet-veil.open { opacity: 1; visibility: visible; transition: opacity .35s var(--ease2); }
.pr-sheet { position: fixed; z-index: 201; right: 0; top: 0; bottom: 0; width: min(500px,100%); background: var(--coal); border-left: 0.5px solid var(--hairline); transform: translateX(100%); transition: transform .45s var(--spring); display: flex; flex-direction: column; padding: clamp(32px,5vh,60px) clamp(26px,4vw,48px); overflow-y: auto; }
.pr-sheet-veil.open .pr-sheet { transform: translateX(0); }
.pr-sheet h2 { font-family:'Cormorant Garamond', serif; font-weight: 500; font-size: 34px; color: var(--bone); margin-bottom: 6px; }
.pr-sheet .sub { color: var(--bone-dim); font-size: 14px; margin-bottom: 26px; }
.pr-sheet label { display: block; margin-bottom: 16px; }
.pr-sheet label .lt { display: block; font-family:'Archivo',sans-serif; font-weight: 500; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bone-dim); margin-bottom: 6px; }
.pr-sheet input, .pr-sheet select, .pr-sheet textarea { width: 100%; background: var(--black); border: 0.5px solid var(--hairline); color: var(--bone); padding: 12px 14px; font-family:'Archivo',sans-serif; font-size: 14px; border-radius: 4px; }
.pr-sheet textarea { min-height: 84px; resize: vertical; }
.pr-sheet input:focus, .pr-sheet select:focus, .pr-sheet textarea:focus { outline: none; border-color: var(--gold-dim); }
.pr-sheet .row { display: flex; gap: 14px; } .pr-sheet .row label { flex: 1; }
.pr-sheet-close { position: absolute; top: 18px; right: 18px; background: none; border: 0; color: var(--bone-dim); font-size: 24px; cursor: pointer; line-height: 1; }
.pr-sheet-close:hover { color: var(--bone); }
.pr-sheet .submit { margin-top: 8px; width: 100%; justify-content: center; border-radius: 999px; }
.pr-sheet .stub-note { color: var(--gold); font-size: 11px; margin-top: 14px; text-align: center; }
.pr-sheet .thanks { color: var(--bone); font-size: 15px; line-height: 1.6; }

/* ---------------- RESPONSIVE ---------------- */
@media (max-width: 1023px) { .pr-well { max-width: 64%; } .pr-nav { gap: 16px; } }
@media (max-width: 760px) {
  .pr-nav { display: none; }
  .pr-topbar { padding: 14px 10px 14px 16px; gap: 10px; }
  .pr-arrows { display: none; }
  .pr-brand .tick, .pr-brand .label { display: none; }
  .pr-icon { display: none; }
  .pr-book-pill { padding: 9px 14px; font-size: 10px; }
  .pr-hero { height: auto; min-height: auto; }
  .pr-stage { height: auto; }
  .pr-bd img { object-position: 78% 26%; }
  .pr-well { max-width: 100%; min-height: 90vh; padding-top: 90px; justify-content: flex-end; padding-bottom: 40px; }
  .pr-scrim { background: linear-gradient(0deg, var(--black) 0%, rgba(10,10,11,0.78) 30%, rgba(10,10,11,0.2) 62%, transparent 86%); }
  .pr-ctas { gap: 12px; }
  .pr-ctas > *:nth-child(n+2) { display: none; }   /* mobile: one clean CTA (Book lives in the top bar) */
  .pr-networks { padding: 16px; gap: 8px 16px; } .pr-networks .net { font-size: 13px; }
  .pr-rail-wrap { padding-top: 24px; }
  .pr-rail-head { margin-bottom: 14px; }
  .pr-title { font-size: clamp(34px,9vw,52px); margin-bottom: 10px; }
  .pr-kicker { margin-bottom: 10px; }
  .pr-meta { margin-bottom: 12px; gap: 6px 0; }
  .pr-meta .chip { font-size: 12px; }
  .pr-logline { margin-bottom: 4px; }
  .pr-seemore { display: none; }
  .pr-desc { display: none; }
  .pr-card { width: 150px; }
  .pr-sheet { width: 100%; }
  .pr-foot-row { flex-direction: column; align-items: flex-start; }
}

/* ---------------- REDUCED MOTION ---------------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  [data-rv] { opacity: 1; transform: none; filter: none; transition: none; }
  .pr-bd, .pr-bd img, .pr-desc, .pr-sheet, .pr-sheet-veil, .pr-card, .pr-card-core img { transition-duration: 1ms !important; }
  .pr-hero-bg::after, .pr-grain { display: none; }
  .pr-bd img { transform: none; }
}
