/* Matches homepage #films .film-panel */
.films-visual-col,.hero-kj .films-visual-col{display:flex;align-items:center;justify-content:center;width:100%;max-width:min(560px,92vw);margin:0 auto}
.hero-kj .film-panel,.films-visual-col .film-panel,.hero-kj .viz-panel.film-panel{
  width:100%;max-width:min(520px,92vw);margin:0 auto;padding:14px 16px 12px;border-radius:22px;
  border:1px solid rgba(156,199,255,.22);
  background:linear-gradient(180deg,rgba(6,10,22,.94),rgba(0,0,0,.58));
  box-shadow:0 0 48px rgba(156,199,255,.1),inset 0 1px 0 rgba(255,255,255,.06);
  min-height:0;display:flex;flex-direction:column;justify-content:center;opacity:1;visibility:visible
}
#homeFilmViz,#heroViz,.film-panel canvas{width:100%;height:min(200px,28vh);min-height:150px;max-height:220px;display:block;border-radius:12px;background:radial-gradient(circle at 50% 50%,var(--viz-radial),rgba(0,0,0,.72) 70%);flex:0 0 auto}
.film-meta,.viz-panel.film-panel .viz-meta{display:flex;justify-content:space-between;margin-top:8px;font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);gap:12px;flex-wrap:wrap}
.film-focus,.viz-focus.film-focus{color:var(--accent);transition:color .3s}
.film-focus.hot,.viz-focus.film-focus.hot{color:#fff}
.section.hero-films{min-height:auto;padding-top:10vh;padding-bottom:4vh;justify-content:flex-start}
.hero-films.hero-kj{padding-top:2vh;padding-bottom:3vh}
@media(max-width:767px){.hero-films.hero-kj,.section.hero-films{padding-top:max(80px,12vh)}}
.hero-films>.title{margin-top:0;margin-bottom:.65rem;font-size:clamp(1.85rem,5vw,3.5rem)}
.hero-films>.title+.hero-tag{margin:0 auto .75rem;padding:0 3vw;max-width:min(900px,94vw);width:100%}
.hero-films>.hero-tag+.sub{margin-top:0;margin-bottom:1.35rem;font-size:.98rem;line-height:1.65;max-width:640px}
.hero-films>.sub+.film-panel{margin:0 auto 1.25rem}
.hero-films>.chips{margin-top:1rem;gap:8px}
.hero-films>.btn-row{margin-top:1.25rem}
.hero-films .chip{padding:8px 14px;font-size:9px}
#films .film-panel{min-height:420px;padding:22px 22px 16px;border-radius:28px;max-width:100%}
#films #homeFilmViz{height:min(320px,40vw);min-height:240px;max-height:none}

/* Films slate — production in progress */
.film-slate-stage{position:relative;width:100%;max-width:720px;margin:clamp(32px,5vw,48px) auto 0;perspective:1200px}
.film-slate-sweep{position:absolute;inset:-10% -20%;pointer-events:none;z-index:3;background:linear-gradient(105deg,transparent 0%,rgba(156,199,255,.03) 42%,rgba(255,255,255,.14) 50%,rgba(156,199,255,.03) 58%,transparent 100%);mix-blend-mode:screen;opacity:0}
.film-slate-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,28px);width:100%;position:relative;z-index:2;perspective:1000px}
.film-slate{position:relative;display:flex;flex-direction:column;border-radius:24px;border:1px solid rgba(255,255,255,.1);background:linear-gradient(165deg,var(--panel-bg-top),var(--panel-bg-bottom));overflow:hidden;transform-style:preserve-3d;will-change:transform,opacity}
.film-slate::before{content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:4;opacity:0;transition:opacity .35s;background:linear-gradient(135deg,rgba(156,199,255,.12),transparent 55%);mix-blend-mode:screen}
.film-slate:hover{border-color:var(--theme-border);box-shadow:0 16px 48px rgba(0,0,0,.4),0 0 40px var(--glass-pulse)}
.film-slate:hover::before{opacity:1}
.film-slate-frame{position:relative;padding:10px 10px 0;background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border-bottom:1px solid rgba(255,255,255,.06)}
.film-slate-perfs{height:8px;margin-bottom:8px;background:repeating-linear-gradient(90deg,rgba(0,0,0,.55) 0 6px,transparent 6px 14px);border-radius:2px;opacity:.85;mask-image:linear-gradient(90deg,transparent,black 8%,black 92%,transparent)}
.film-slate-reel{position:absolute;top:12px;right:12px;z-index:6;padding:6px 11px;border-radius:999px;font-size:8px;letter-spacing:.2em;font-weight:800;color:#0c1424;background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(232,242,255,.94));border:1px solid rgba(255,255,255,.85);box-shadow:0 4px 18px rgba(0,0,0,.28),0 0 22px rgba(156,199,255,.5);font-variant-numeric:tabular-nums;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);mix-blend-mode:normal}
.film-slate-poster{position:relative;aspect-ratio:2/3;overflow:hidden;background:#0a0c12;border-radius:4px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}
.film-slate-poster img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;transform:scale(1.06);will-change:transform,filter}
.film-slate-shutter{position:absolute;inset:0;z-index:3;pointer-events:none;background:repeating-linear-gradient(180deg,#000 0 3px,rgba(20,20,20,.95) 3px 6px);transform-origin:50% 0%;box-shadow:inset 0 0 40px rgba(0,0,0,.8)}
.film-slate-flare{position:absolute;inset:-20% -40%;z-index:2;pointer-events:none;background:linear-gradient(105deg,transparent 35%,rgba(255,255,255,.35) 50%,transparent 65%);mix-blend-mode:overlay;opacity:0}
.film-slate-poster::after{content:'';position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.22;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.95' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");animation:filmSlateGrain 1.8s steps(2) infinite}
@keyframes filmSlateGrain{0%,100%{transform:translate(0,0)}50%{transform:translate(-2%,1%)}}
.film-slate-badge{position:absolute;top:12px;left:12px;z-index:4;padding:6px 10px;border-radius:999px;font-size:8px;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:#fff;background:rgba(0,0,0,.62);border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:filmBadgePulse 3s ease-in-out infinite}
@keyframes filmBadgePulse{0%,100%{box-shadow:0 0 0 rgba(156,199,255,0)}50%{box-shadow:0 0 14px rgba(156,199,255,.25)}}
.film-slate-copy{padding:18px 18px 22px;display:flex;flex-direction:column;gap:8px;flex:1}
.film-slate-copy h3{font-size:1.35rem;font-weight:800;letter-spacing:-.02em;line-height:1.1}
.film-slate-tag{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);line-height:1.5}
.film-slate-desc{color:var(--silver);font-size:.88rem;line-height:1.65;text-align:justify;text-justify:inter-word;margin:0}
.film-slate-meta{margin-top:auto;padding-top:6px;font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.section-film-slate{padding-top:4vh;padding-bottom:6vh}
@media(max-width:1000px){.film-slate-grid{grid-template-columns:1fr;max-width:360px;margin-left:auto;margin-right:auto}.film-slate-stage{max-width:360px}}
@media(prefers-reduced-motion:reduce){.film-slate-poster::after,.film-slate-badge{animation:none}.film-slate-shutter{display:none}}
