/* ==========================================================================
   99 CENT FILMS — shared cinematic stylesheet
   Used by: index.html, the-boy.html, the-building-manager.html,
            about.html, contact.html
   Display font: Chiller (if installed) -> Creepster (Google Fonts) -> cursive
   ========================================================================== */

:root{
  --bg:#0a0710;
  --bg-2:#101016;
  --panel:#15151c;
  --text:#f3eee6;
  --muted:#c3bccc;
  --accent:#e50914;
  --accent-hover:#ff1722;
  --amber:#ffc24a;
  --glow:rgba(255,170,70,.55);
  --radius:14px;
  --display:'Chiller','Creepster',cursive;
  --serif:'Fraunces',Georgia,'Times New Roman',serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --body:'ComicSans','Comic Sans MS',cursive;
}

@font-face{font-family:'Chiller';src:url('Assets/chiller.ttf') format('truetype');font-display:swap}
@font-face{font-family:'ComicSans';src:url('Assets/comicsans.ttf') format('truetype');font-display:swap}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
html.immersive{scroll-snap-type:y mandatory}        /* homepage only */
body{background:radial-gradient(125% 85% at 50% -8%,#1a1126 0%,var(--bg) 56%) no-repeat fixed,var(--bg);color:var(--text);font-family:var(--sans);-webkit-font-smoothing:antialiased;min-height:100vh}
a{color:inherit;text-decoration:none}
img,video{display:block}

/* ---------- Fixed nav + Menu dropdown ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;justify-content:flex-end;
  padding:18px clamp(16px,5vw,44px);
  background:linear-gradient(180deg,rgba(7,7,8,.85),rgba(7,7,8,0));pointer-events:none}
.nav>*{pointer-events:auto}
.nav-mark{font-family:var(--display);font-size:26px;color:#fff;letter-spacing:1px;line-height:1}
.menu{position:relative}
.menu-toggle{font-family:'Chiller',var(--sans);font-size:34px;font-weight:400;line-height:1;color:#fff;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.22);border-radius:12px;
  width:48px;height:48px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding-bottom:4px;transition:background .2s}
.menu-toggle:hover{background:rgba(255,255,255,.18)}
.menu-toggle .caret{transition:transform .2s}
.menu.open .menu-toggle .caret{transform:rotate(180deg)}
.menu-list{position:absolute;top:calc(100% + 10px);right:0;min-width:240px;list-style:none;
  background:var(--panel);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:8px;
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:all .18s ease;
  box-shadow:0 24px 60px rgba(0,0,0,.6)}
.menu.open .menu-list{opacity:1;visibility:visible;transform:none}
.menu-list li a{display:block;padding:12px 14px;border-radius:8px;font-size:15px;color:var(--text);transition:background .15s}
.menu-list li a:hover{background:rgba(255,255,255,.08)}
.menu-list li+li{margin-top:2px}
.menu-list .divider{height:1px;background:rgba(255,255,255,.1);margin:6px 4px}

/* Primary Watch button — amber, matches the homepage CTA */
.watch-ghost{display:inline-flex;align-items:center;gap:9px;cursor:pointer;font-family:var(--sans);
  font-size:clamp(15px,1.8vw,17px);font-weight:800;color:#1c1305;
  padding:14px 26px;border-radius:11px;
  background:linear-gradient(#ffd56b,#ffba3c);border:0;box-shadow:0 12px 32px rgba(255,170,60,.32);
  transition:filter .2s,transform .05s}
@media (hover:hover){.watch-ghost:hover{filter:brightness(1.06)}}  /* hover only on mouse — avoids iOS "first tap = hover" double-tap */
.watch-ghost:active{transform:scale(.98)}
.btn-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);color:#fff;font-weight:600;font-size:15px;
  padding:13px 18px;border-radius:11px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.18);
  transition:background .2s}
.btn-link:hover{background:rgba(255,255,255,.14)}
.price-pill{font-size:13px;color:#5a4410;font-weight:700;letter-spacing:.5px}

/* ---------- Interior pages (film / about / contact) ---------- */
.page{max-width:1000px;margin:0 auto;padding:120px clamp(20px,6vw,40px) 80px}
.page h1{font-family:var(--serif);font-optical-sizing:auto;font-size:clamp(32px,7vw,56px);font-weight:600;line-height:1.04;margin-bottom:8px;color:#fff;text-shadow:0 0 40px rgba(255,170,70,.18)}
.page .lead{color:var(--amber);font-size:17px;letter-spacing:.2px;margin-bottom:10px;opacity:.92;text-shadow:0 0 16px var(--glow)}
.page h3{font-family:var(--serif);font-optical-sizing:auto;font-size:21px;font-weight:600;margin:34px 0 12px;color:#fff}
.page p{color:#e3e3ea;font-size:17px;line-height:1.7;margin-bottom:14px;max-width:70ch}
.placeholder{color:#8b8b95;font-style:italic}

.film-hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;overflow:hidden}
.film-hero .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#000;z-index:0;filter:brightness(1.12) contrast(1.06) saturate(1.08)}
.film-hero .poster-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;background:#000;z-index:1;opacity:1;transition:opacity 1s ease}
.film-hero.revealed .poster-img{opacity:0}
.film-hero::before{content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,rgba(7,7,8,.3),rgba(7,7,8,.2) 40%,rgba(7,7,8,.95))}
.film-hero .inner{position:relative;z-index:3;max-width:1000px;margin:0 auto;width:100%;
  padding:0 clamp(20px,6vw,40px) clamp(28px,5vw,56px)}
.film-hero .kicker{color:var(--amber);font-size:11px;font-weight:700;letter-spacing:4px;text-transform:uppercase;margin-bottom:12px;text-shadow:0 0 14px var(--glow)}
.film-hero h1{font-size:clamp(30px,6vw,64px);font-weight:800;line-height:1.02;color:#ffd24a;text-shadow:0 4px 30px rgba(0,0,0,.75)}
.film-hero .meta{color:var(--muted);font-size:15px;margin-top:12px;display:flex;gap:16px;flex-wrap:wrap}
.film-body{max-width:1000px;margin:0 auto;padding:36px clamp(20px,6vw,40px) 90px;
  display:grid;grid-template-columns:1fr;gap:14px}
.film-body .actions{margin:6px 0 24px}
.cast{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-top:8px}
.cast .role{background:var(--panel);border:1px solid rgba(255,255,255,.07);border-radius:12px;padding:14px 16px}
.cast .role .r{color:var(--muted);font-size:13px;letter-spacing:.4px;text-transform:uppercase}
.cast .role .n{font-size:16px;font-weight:600;margin-top:4px}

.contact-card{background:var(--panel);border:1px solid rgba(255,255,255,.08);border-radius:16px;
  padding:26px;max-width:520px}
.contact-card a{color:#fff;font-weight:600;text-decoration:underline}

.back-link{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:14px;margin-bottom:20px}
.back-link:hover{color:#fff}

/* ---------- Film detail pages: Fraunces title (new brand), clean sans body ---------- */
.film-hero h1{font-family:var(--serif);font-style:italic;font-optical-sizing:auto;font-size:clamp(30px,7.5vw,52px);font-weight:500;line-height:1.03;color:#fff;text-shadow:0 4px 30px rgba(0,0,0,.85),0 0 44px rgba(0,0,0,.5)}
.film-hero .inner div{font-family:var(--sans)}
.film-body{font-family:var(--sans);font-size:15px;line-height:1.7;gap:10px;padding-top:28px}
.film-tag{font-style:italic;font-size:13.5px;color:rgba(255,255,255,.5)}
.film-logline{font-size:16px;line-height:1.6;color:rgba(255,255,255,.82);max-width:52ch;margin:2px 0}
.film-sel{font-size:10.5px;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,194,74,.6)}
.film-credits{font-size:13px;line-height:1.85;color:rgba(255,255,255,.5);margin-top:8px}
.film-credits b{color:rgba(255,255,255,.82);font-weight:600}
.film-onetap{font-size:12px;letter-spacing:.05em;color:rgba(255,255,255,.4)}

/* ---------- Premium checkout & gift modals (injected by app.js) ---------- */
.overlay{position:fixed;inset:0;z-index:90;background:#06050d;display:none;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px 14px 100px;font-family:var(--sans)}
.overlay.open{display:block}
/* modals ALWAYS read sentence-case with normal spacing — defends against any inherited text-transform/letter-spacing */
.overlay,.overlay *{text-transform:none;letter-spacing:normal}

.sheet{position:relative;width:100%;max-width:380px;margin:6vh auto 0;
  background:linear-gradient(180deg,#15131e 0%,#0c0b14 100%);
  border-radius:22px;border:1px solid rgba(255,255,255,.08);
  box-shadow:0 32px 80px rgba(0,0,0,.78), inset 0 1px 0 rgba(255,255,255,.05);
  padding:14px 18px 18px;font-family:var(--sans);
  animation:rise .38s cubic-bezier(.2,.85,.25,1)}
.sheet::before{content:"";position:absolute;left:32%;right:32%;top:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,194,74,.7),transparent)}
@keyframes rise{from{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}

/* small grabber pull-tab at top — sheet affordance */
.sheet-grabber{width:38px;height:4px;border-radius:2px;background:rgba(255,255,255,.14);margin:2px auto 10px}

/* top-right ✕ close (replaces big Cancel button) */
.sheet-close{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.75);
  font-size:15px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-family:var(--sans);transition:background .15s,color .15s;z-index:2}
.sheet-close:hover{background:rgba(255,255,255,.14);color:#fff}

/* small Chiller brand mark */
.sheet-brand{font-family:var(--display);font-size:18px;color:var(--amber);
  text-shadow:0 0 14px var(--glow);text-align:center;opacity:.9;margin:2px 0 6px}

/* film title — Fraunces italic, matches the rest of the site */
.sheet h3{font-family:var(--serif);font-style:italic;font-optical-sizing:auto;
  font-size:23px;font-weight:500;line-height:1.08;text-align:center;color:#fff;margin:0 0 4px}

/* one tight meta line */
.sheet-meta{text-align:center;color:rgba(255,255,255,.5);font-size:12.5px;margin:0 0 16px}
.sheet-price{color:var(--amber);font-weight:700}

/* wallet buttons sized consistently */
#apple-pay-button{display:none;height:50px;width:100%;border-radius:11px;background:#000;color:#fff;
  font-size:16px;font-weight:600;align-items:center;justify-content:center;cursor:pointer;margin-bottom:8px;
  -webkit-appearance:-apple-pay-button;-apple-pay-button-type:plain;-apple-pay-button-style:white-outline}
#google-pay-button{margin-bottom:8px;min-height:50px}

/* "or pay by card" divider */
.sheet-or{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,.38);font-size:11px;margin:12px 0 10px}
.sheet-or::before,.sheet-or::after{content:"";flex:1;height:1px;background:rgba(255,255,255,.08)}

/* card field — clean white input wrapped in the dark sheet (Stripe-Checkout-style intentional contrast) */
#card-container{background:#fff;border-radius:11px;overflow:hidden;border:1px solid rgba(255,255,255,.08);padding:2px 8px;box-shadow:inset 0 1px 0 rgba(0,0,0,.04)}
#card-container .sq-card-iframe-container,#card-container iframe{min-height:0!important}

/* primary CTA */
#card-button{width:100%;border:0;border-radius:11px;
  background:linear-gradient(180deg,#ffd56b,#ffba3c);color:#1c1305;
  font-family:var(--sans);font-weight:800;font-size:16px;padding:13px;margin-top:12px;cursor:pointer;
  box-shadow:0 10px 24px rgba(255,170,60,.28), inset 0 1px 0 rgba(255,255,255,.45);
  transition:filter .12s,transform .12s}
#card-button:hover{filter:brightness(1.04)}
#card-button:active{transform:scale(.99)}
#card-button:disabled{opacity:.55;cursor:default}

.pay-status{min-height:18px;text-align:center;font-size:13px;margin-top:10px;color:rgba(255,255,255,.55)}
.pay-status.err{color:#ff8585}
.pay-status.ok{color:#7ee2a8}

/* refined secure footer */
.secure{display:flex;align-items:center;justify-content:center;gap:7px;color:rgba(255,255,255,.35);
  font-size:11px;margin-top:14px}
.secure a{color:rgba(255,255,255,.55);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.18)}
.secure .lock{font-size:11px;opacity:.7}

/* ---------- Fullscreen player (injected by app.js) ---------- */
.player{position:fixed;inset:0;z-index:130;isolation:isolate;background:#000;display:none;flex-direction:column}
.player.open{display:flex}
.player .bar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;color:#fff}
.player video{flex:1;width:100%;height:100%;object-fit:contain;background:#000}
.player .x{background:rgba(255,255,255,.12);border:0;color:#fff;border-radius:8px;padding:8px 14px;cursor:pointer;font-weight:700}
#ncfPlayerTitle{font-size:15px;font-weight:600;opacity:1;transition:opacity .8s ease}
/* Faint per-purchase watermark (anchors to .player, which is position:fixed) */
#ncfWatermark{position:absolute;right:8px;top:50%;transform:translateY(-50%);z-index:5;pointer-events:none;user-select:none;
  writing-mode:vertical-rl;font:600 11px/1 ui-monospace,monospace;letter-spacing:3px;color:rgba(255,255,255,.16);
  text-shadow:0 1px 2px rgba(0,0,0,.5);transition:opacity 1.2s ease}

/* Mobile: the clips are 4:3 — scale to fit (show the whole frame) instead of cropping */
@media (max-width:640px){
  .film .bg,.film .poster-img,.film-hero .bg,.film-hero .poster-img{object-fit:contain;background:#000}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .scroll-cue{animation:none}
}
