:root { --bg:#070507; --ink:#fff6df; --muted:#cdbd9f; --gold:#f2c36b; --red:#b41f2a; --green:#5cff9d; --panel:rgba(20,12,10,.76); }
* { box-sizing: border-box; }
html, body { min-height: 100%; margin: 0; }
body { overflow: hidden; background: radial-gradient(circle at 18% 18%, rgba(180,31,42,.2), transparent 30%), radial-gradient(circle at 78% 34%, rgba(242,195,107,.15), transparent 28%), linear-gradient(135deg,#050304 0%,#12090a 42%,#030203 100%); color: var(--ink); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; }
.grain,.vignette,.projector-beam { position: fixed; inset: 0; pointer-events: none; }
.grain { opacity: .17; background-image: repeating-radial-gradient(circle at 20% 30%, rgba(255,255,255,.65) 0 1px, transparent 1px 3px), repeating-linear-gradient(0deg, rgba(255,255,255,.08) 0 1px, transparent 1px 4px); mix-blend-mode: overlay; animation: jitter 360ms steps(2) infinite; }
.vignette { box-shadow: inset 0 0 160px 55px #000; }
.projector-beam { background: conic-gradient(from 18deg at 0% 47%, transparent 0deg, rgba(255,232,176,.12) 18deg, transparent 34deg); filter: blur(2px); animation: beam 5.5s ease-in-out infinite; }
.film-strip { position: fixed; top: -8vh; width: 58px; height: 116vh; opacity: .48; background: linear-gradient(#111,#050505), repeating-linear-gradient(0deg, transparent 0 18px, rgba(255,255,255,.75) 18px 30px, transparent 30px 48px); border-inline: 1px solid rgba(255,255,255,.24); }
.film-left { left: 24px; } .film-right { right: 24px; }
.film-strip::before,.film-strip::after { content:""; position:absolute; top:0; width:13px; height:100%; background: repeating-linear-gradient(0deg,#e8dfc7 0 10px, transparent 10px 24px); }
.film-strip::before { left:8px; } .film-strip::after { right:8px; }
.cinema-shell { position:relative; z-index:1; min-height:100vh; display:grid; grid-template-rows:auto 1fr auto; place-items:center; gap:clamp(14px,2.5vh,28px); padding:clamp(18px,4vw,44px) clamp(82px,9vw,128px); }
.marquee { width:min(980px,100%); text-align:center; padding:clamp(16px,2.6vh,26px) clamp(18px,5vw,52px); border:2px solid rgba(242,195,107,.78); border-radius:18px; background:linear-gradient(180deg,rgba(50,22,16,.9),rgba(18,8,9,.88)); box-shadow:0 0 42px rgba(242,195,107,.18), inset 0 0 34px rgba(242,195,107,.08); }
.bulbs { height:10px; margin-bottom:10px; background: radial-gradient(circle,#ffe2a0 0 35%, transparent 38%) 0 0 / 32px 10px repeat-x; filter:drop-shadow(0 0 8px #f2c36b); animation:bulbs 1.7s steps(2) infinite; }
.eyebrow,.rating,label,.props strong { color:var(--gold); text-transform:uppercase; letter-spacing:.22em; font-size:.76rem; font-weight:800; }
h1 { margin:0; font-family:Georgia,serif; font-size:clamp(3.4rem,9vw,8rem); line-height:.9; text-transform:uppercase; text-shadow:0 0 24px rgba(242,195,107,.36), 3px 3px 0 rgba(180,31,42,.75); }
.subtitle { margin:10px 0 0; color:var(--muted); font-size:clamp(1rem,2vw,1.35rem); }
.screen-panel { position:relative; width:min(680px,100%); padding:clamp(24px,4vh,42px); border:1px solid rgba(255,246,223,.22); border-radius:22px; background:var(--panel); box-shadow:0 24px 80px rgba(0,0,0,.58), inset 0 0 80px rgba(0,0,0,.42); text-align:center; backdrop-filter:blur(12px); }
.countdown { display:flex; justify-content:center; gap:14px; margin-bottom:18px; }
.countdown span { width:42px; height:42px; border-radius:50%; display:grid; place-items:center; border:1px solid rgba(242,195,107,.5); color:var(--gold); font-family:Georgia,serif; font-size:1.4rem; animation:flicker 2.8s infinite; }
.clapper { display:grid; grid-template-columns:repeat(4,1fr); gap:6px; margin:0 auto 18px; width:170px; transform:rotate(-2deg); }
.clapper span { height:18px; background:linear-gradient(135deg,#fff 0 46%,#111 46% 54%,#fff 54%); border-radius:2px; }
.screen-panel h2 { margin:10px 0 8px; font-family:Georgia,serif; font-size:clamp(2rem,5vw,3.4rem); }
.hint { color:var(--muted); margin:0 0 24px; }
form { display:grid; gap:12px; margin-top:20px; }
label { text-align:left; }
input,button { width:100%; border:0; border-radius:14px; font:inherit; }
input { padding:17px 18px; color:var(--ink); background:rgba(0,0,0,.54); outline:1px solid rgba(242,195,107,.34); }
input:focus { outline-color:var(--gold); box-shadow:0 0 0 4px rgba(242,195,107,.14); }
button[type="submit"] { padding:17px 18px; cursor:pointer; color:#1b0909; font-weight:900; text-transform:uppercase; letter-spacing:.18em; background:linear-gradient(135deg,#ffe4a3,var(--gold)); box-shadow:0 12px 32px rgba(242,195,107,.22); }
button[type="submit"]:hover { filter:brightness(1.08); }
.rosebud { position:absolute; right:18px; bottom:14px; width:34px; height:34px; border-radius:50%; color:rgba(255,255,255,.28); background:transparent; cursor:help; }
.rosebud:hover { color:var(--green); text-shadow:0 0 16px var(--green); }
.message { min-height:1.4em; margin:18px 0 0; font-weight:900; letter-spacing:.16em; text-transform:uppercase; }
.message.denied { color:#ff4d5b; } .message.granted { color:var(--green); }
.screen-panel.shake { animation:shake 360ms linear; } .screen-panel.granted { animation:granted 900ms ease forwards; }
.props { width:min(980px,100%); display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.props div { padding:14px 16px; border:1px solid rgba(242,195,107,.22); background:rgba(0,0,0,.38); border-radius:14px; }
.props span { display:block; margin-top:6px; color:var(--muted); }
@keyframes jitter { to { transform:translate3d(1px,-1px,0); } } @keyframes beam { 50% { opacity:.5; transform:translateX(10px); } } @keyframes bulbs { 50% { opacity:.65; } } @keyframes flicker { 0%,100% { opacity:.95; } 45% { opacity:.45; } 52% { opacity:1; } } @keyframes shake { 20% { transform:translateX(-8px); } 40% { transform:translateX(8px); } 60% { transform:translateX(-5px); } 80% { transform:translateX(5px); } } @keyframes granted { 50% { box-shadow:0 0 80px rgba(92,255,157,.35); } 100% { opacity:.2; transform:scale(.98); } }
@media (max-width:760px) { body { overflow:auto; } .cinema-shell { padding:18px 18px 28px; } .film-strip { display:none; } .props { grid-template-columns:1fr; } }
