:root{
  --bg:#070707;
  --sand:#f2dfb8;
  --sand-2:#d8c29a;
  --olive:#5f7a4a;
  --red:#8a1e1e;
  --card:#0e0e0e;
  --stroke:rgba(242,223,184,.18);
  --glow:rgba(242,223,184,.22);
  --shadow:rgba(0,0,0,.55);
  --radius:18px;
  --radius-sm:12px;
  --serif:"DM Serif Display", ui-serif, Georgia, serif;
  --sans:Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background: radial-gradient(1200px 700px at 50% -10%, rgba(95,122,74,.18), transparent 55%),
              radial-gradient(900px 520px at 20% 15%, rgba(138,30,30,.20), transparent 55%),
              radial-gradient(900px 520px at 85% 25%, rgba(242,223,184,.10), transparent 55%),
              var(--bg);
  color:var(--sand);
  font-family:var(--sans);
  overflow-x:hidden;
}

.wrap{
  min-height:100%;
  width:min(980px, 92vw);
  margin:0 auto;
  padding: clamp(22px, 4vw, 44px) 0 40px;
  display:flex;
  flex-direction:column;
  gap:22px;
}

.hero{
  text-align:center;
  padding-top:10px;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--stroke);
  background:rgba(14,14,14,.55);
  box-shadow: 0 0 0 1px rgba(0,0,0,.25) inset, 0 10px 30px var(--shadow);
  letter-spacing:.10em;
  text-transform:uppercase;
  font-weight:700;
  font-size:12px;
  color:var(--sand-2);
}

h1{
  margin:16px 0 10px;
  font-family:var(--serif);
  font-size:clamp(34px, 5vw, 56px);
  line-height:1.02;
  font-weight:400;
  text-shadow: 0 10px 50px rgba(242,223,184,.08);
}

.subhead{
  margin:0;
  font-size:16px;
  color:rgba(242,223,184,.80);
}

.controls{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:12px;
  margin: 4px auto 0;
  width:min(860px, 100%);
}

.pill{
  appearance:none;
  border:none;
  cursor:pointer;
  padding:14px 14px;
  border-radius:999px;
  background: linear-gradient(180deg, rgba(242,223,184,.10), rgba(242,223,184,.05));
  color:var(--sand);
  font-weight:700;
  letter-spacing:.01em;
  box-shadow:
    0 0 0 1px var(--stroke) inset,
    0 10px 30px rgba(0,0,0,.35);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, filter .18s ease;
  text-align:center;
}
.pill span{
  display:block;
  font-weight:600;
  opacity:.75;
  font-size:12px;
  margin-top:4px;
}
.pill:hover{
  transform: translateY(-1px);
  box-shadow:
    0 0 0 1px rgba(242,223,184,.30) inset,
    0 0 22px rgba(242,223,184,.10),
    0 14px 34px rgba(0,0,0,.50);
  filter: saturate(1.05);
}
.pill:active{transform: translateY(0px) scale(.99)}
.pill:focus-visible{
  outline:none;
  box-shadow:
    0 0 0 2px rgba(95,122,74,.55),
    0 0 0 1px rgba(242,223,184,.30) inset,
    0 14px 34px rgba(0,0,0,.50);
}

.pill--surprise{
  background: linear-gradient(180deg, rgba(138,30,30,.22), rgba(242,223,184,.06));
  box-shadow:
    0 0 0 1px rgba(138,30,30,.35) inset,
    0 10px 30px rgba(0,0,0,.35);
}
.pill--surprise:hover{
  box-shadow:
    0 0 0 1px rgba(242,223,184,.30) inset,
    0 0 26px rgba(138,30,30,.18),
    0 14px 34px rgba(0,0,0,.50);
}

.stage{
  width:min(860px, 100%);
  margin: 0 auto;
  position:relative;
  padding: 8px 0 0;
  scroll-margin-top: 14px;
}

.reel, .card{
  scroll-margin-top: 14px;
}

.status{
  margin: 4px auto 0;
  width: fit-content;
  padding: 10px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  border-radius:999px;
  border:1px solid var(--stroke);
  background: rgba(14,14,14,.55);
  color: rgba(242,223,184,.85);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.status__dot{
  width:10px;height:10px;border-radius:999px;
  background: rgba(95,122,74,.9);
  box-shadow: 0 0 0 4px rgba(95,122,74,.20);
}

.reel{
  display:flex;
  align-items:center;
  gap:16px;
  margin: 22px auto 0;
  width:min(760px, 100%);
  padding: 16px 18px;
  border-radius: var(--radius);
  background: rgba(14,14,14,.60);
  border:1px solid var(--stroke);
  box-shadow: 0 20px 60px rgba(0,0,0,.55);
}
.reel__icon{
  width:52px;height:52px;border-radius:999px;
  background:
    radial-gradient(circle at 50% 50%, rgba(242,223,184,.12) 0 30%, transparent 32%),
    conic-gradient(from 10deg, rgba(242,223,184,.22), rgba(95,122,74,.20), rgba(138,30,30,.18), rgba(242,223,184,.22));
  border:1px solid rgba(242,223,184,.22);
  box-shadow: 0 0 24px rgba(242,223,184,.12);
  animation: spin 1.15s linear infinite;
}
.reel__label{
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(242,223,184,.72);
}
.reel__slot{
  margin-top:4px;
  font-family:var(--serif);
  font-size:26px;
  line-height:1.1;
  color: var(--sand);
  text-shadow: 0 10px 50px rgba(242,223,184,.10);
}

@keyframes spin { to{ transform: rotate(360deg); } }

.card{
  margin: 22px auto 0;
  width:min(760px, 100%);
  border-radius: calc(var(--radius) + 4px);
  border:1px solid rgba(242,223,184,.22);
  background:
    radial-gradient(1200px 600px at 50% -10%, rgba(242,223,184,.12), transparent 50%),
    radial-gradient(900px 520px at 85% 30%, rgba(95,122,74,.16), transparent 55%),
    radial-gradient(900px 520px at 20% 20%, rgba(138,30,30,.14), transparent 55%),
    rgba(14,14,14,.80);
  box-shadow:
    0 30px 90px rgba(0,0,0,.70),
    0 0 0 1px rgba(0,0,0,.25) inset,
    0 0 70px rgba(242,223,184,.08);
  overflow:hidden;
  position:relative;
  transform: translateY(6px);
  opacity:0;
  animation: reveal .55s ease forwards;
}

@keyframes reveal{
  to{ transform: translateY(0); opacity:1; }
}

.card::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(145deg, rgba(242,223,184,.08), transparent 55%),
    linear-gradient(35deg, rgba(95,122,74,.09), transparent 60%),
    linear-gradient(0deg, transparent, rgba(0,0,0,.22));
  pointer-events:none;
  z-index:0;
}

.card__top{
  padding: 18px 20px 10px;
  position:relative;
  z-index:1;
}

.festival{
  display:inline-block;
  font-weight:800;
  font-size:12px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color: rgba(242,223,184,.75);
  padding: 8px 10px;
  border-radius:999px;
  border:1px solid rgba(242,223,184,.18);
  background: rgba(7,7,7,.35);
}

.titleRow{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin-top:12px;
}
.clapper{
  font-size:22px;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.45));
}
.movieTitle{
  margin:0;
  font-family:var(--serif);
  font-weight:400;
  font-size: clamp(30px, 4.2vw, 46px);
  line-height: 1.05;
}
.tagline{
  margin:10px 0 0;
  color: rgba(242,223,184,.82);
}

.meta{
  display:grid;
  grid-template-columns: 1fr;
  gap:8px;
  padding: 10px 20px 8px;
  position:relative;
  z-index:1;
}
.meta__row{
  display:grid;
  grid-template-columns: 140px 1fr;
  gap:12px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(242,223,184,.12);
  background: rgba(7,7,7,.30);
}
.meta__row--desc{
  grid-template-columns: 1fr;
}
.meta__row--desc dt{
  opacity:.85;
}
.meta__row--desc dd{
  font-weight:600;
  line-height:1.35;
  color: rgba(242,223,184,.88);
}
.meta dt{
  font-weight:800;
  color: rgba(242,223,184,.78);
}
.meta dd{
  margin:0;
  font-weight:700;
  color: var(--sand);
}

.actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  padding: 14px 20px 18px;
  position:relative;
  z-index:2;
}

.btn{
  cursor:pointer;
  border:none;
  border-radius: 999px;
  padding: 12px 14px;
  background: rgba(242,223,184,.10);
  color: var(--sand);
  font-weight:800;
  letter-spacing:.01em;
  box-shadow: 0 0 0 1px rgba(242,223,184,.18) inset, 0 12px 30px rgba(0,0,0,.35);
  transition: transform .16s ease, box-shadow .16s ease, background .16s ease;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width: 148px;
}
.btn:hover{
  transform: translateY(-1px);
  box-shadow:
    0 0 0 1px rgba(242,223,184,.30) inset,
    0 0 24px rgba(242,223,184,.10),
    0 14px 34px rgba(0,0,0,.50);
}
.btn:active{transform: translateY(0px) scale(.99)}
.btn:focus-visible{
  outline:none;
  box-shadow:
    0 0 0 2px rgba(95,122,74,.55),
    0 0 0 1px rgba(242,223,184,.25) inset,
    0 14px 34px rgba(0,0,0,.50);
}

.btn--primary{
  background: linear-gradient(180deg, rgba(95,122,74,.38), rgba(242,223,184,.08));
  box-shadow: 0 0 0 1px rgba(95,122,74,.40) inset, 0 12px 30px rgba(0,0,0,.35);
}
.btn--ghost{
  background: rgba(138,30,30,.16);
  box-shadow: 0 0 0 1px rgba(138,30,30,.30) inset, 0 12px 30px rgba(0,0,0,.35);
}

.note{
  margin:0 20px 18px;
  color: rgba(242,223,184,.72);
  font-size: 13px;
  position:relative;
  z-index:2;
}

.footer{
  margin-top:auto;
  text-align:center;
  opacity:.78;
}
.footer__small{
  margin: 18px 0 0;
  font-size: 12px;
  color: rgba(242,223,184,.60);
}

/* Moving film grain overlay */
.grain{
  position:fixed;
  inset:-40%;
  pointer-events:none;
  background-image:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='180' height='180' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
  opacity:.20;
  animation: grainMove 8s steps(8) infinite;
}
@keyframes grainMove{
  0%{transform: translate3d(-2%, -3%, 0) rotate(0deg)}
  100%{transform: translate3d(2%, 3%, 0) rotate(0.5deg)}
}

.vignette{
  position:fixed;
  inset:0;
  pointer-events:none;
  background: radial-gradient(circle at 50% 40%, transparent 0 55%, rgba(0,0,0,.55) 90%);
  opacity:.85;
}

/* Optional projector beam behind card */
.projector{
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    conic-gradient(from 210deg at 14% 42%,
      transparent 0 14deg,
      rgba(242,223,184,.08) 14deg 32deg,
      transparent 32deg 360deg);
  filter: blur(1px);
  opacity:.55;
  animation: beam 6s ease-in-out infinite;
}
@keyframes beam{
  0%,100%{opacity:.40; transform: translateX(0)}
  50%{opacity:.60; transform: translateX(1%)}
}

@media (max-width: 860px){
  .controls{grid-template-columns: repeat(2, minmax(0, 1fr));}
  .meta__row{grid-template-columns: 120px 1fr;}
  .btn{min-width: 0; flex: 1;}
}

@media (max-width: 440px){
  .controls{grid-template-columns: 1fr;}
  .meta__row{grid-template-columns: 1fr; gap:6px;}
  .meta dt{opacity:.85}
}

@media (prefers-reduced-motion: reduce){
  .grain, .projector, .reel__icon{animation:none}
  .pill, .btn{transition:none}
  .card{animation:none; opacity:1; transform:none}
}

