/* ============================================================
   THE PRIMAL ORACLE — the cinematic reveal
   Eastern panel rises, Western panel rises, they collide,
   particle burst, then the Primal Animal blooms.
   ============================================================ */

#cinema{
  position:fixed; inset:0; z-index:200; display:none;
  background:radial-gradient(1200px 800px at 50% 50%, #14152b 0%, #05060c 70%, #000 100%);
  overflow:hidden;
}
#cinema.on{display:block}
#cinema .cv{position:absolute; inset:0; z-index:3; pointer-events:none}
#cinema .skip{position:absolute; top:18px; right:20px; z-index:9; background:transparent;
  border:1px solid rgba(255,255,255,.2); color:#cbb; border-radius:999px; padding:8px 16px;
  font:600 .8rem/1 var(--sans); cursor:pointer; letter-spacing:.04em}
#cinema .skip:hover{border-color:#fff; color:#fff}

/* the two halves */
.half{position:absolute; top:50%; width:46%; max-width:440px; transform:translateY(-50%);
  text-align:center; opacity:0; z-index:4}
.half .ph{font:600 .72rem/1 var(--sans); letter-spacing:.34em; text-transform:uppercase; margin-bottom:14px}
.half .mark{width:200px; height:200px; margin:0 auto; border-radius:50%; display:grid; place-items:center;
  font-family:var(--serif); position:relative}
.half .mark::before{content:""; position:absolute; inset:-14px; border-radius:50%; opacity:.5}
.half .nm{font-family:var(--serif); font-size:1.9rem; margin-top:16px}
.half .sub{font:500 .8rem/1.4 var(--sans); letter-spacing:.16em; text-transform:uppercase; margin-top:4px}

/* Eastern: cinnabar + gold ink */
.east{left:3%}
.east .ph{color:#f0b46a}
.east .mark{font-size:8rem; color:#ffd98a;
  background:radial-gradient(circle at 50% 45%, #7d1a16, #3a0c0a 70%);
  box-shadow:0 0 70px rgba(214,58,40,.5), inset 0 0 40px rgba(0,0,0,.5);
  border:2px solid rgba(240,180,106,.6)}
.east .mark::before{border:1px solid rgba(240,180,106,.5)}
.east .nm{color:#ffe6c0} .east .sub{color:#e0975a}

/* Western: midnight + silver constellation */
.west{right:3%}
.west .ph{color:#aab8ff}
.west .mark{font-size:7rem; color:#e8edff;
  background:radial-gradient(circle at 50% 45%, #1c2552, #0a1030 70%);
  box-shadow:0 0 70px rgba(108,124,220,.5), inset 0 0 40px rgba(0,0,0,.5);
  border:2px solid rgba(170,184,255,.55)}
.west .mark::before{border:1px solid rgba(170,184,255,.45)}
.west .nm{color:#eaf0ff} .west .sub{color:#9fb0ee}

/* entrance animations */
.east.in{animation:eastIn .9s cubic-bezier(.2,.7,.2,1) forwards}
.west.in{animation:westIn .9s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes eastIn{from{opacity:0; transform:translate(-90px,-50%) scale(.8) rotate(-8deg)} to{opacity:1; transform:translate(0,-50%) scale(1) rotate(0)}}
@keyframes westIn{from{opacity:0; transform:translate(90px,-50%) scale(.8) rotate(8deg)} to{opacity:1; transform:translate(0,-50%) scale(1) rotate(0)}}

/* collision: both rush to center */
.east.rush{animation:eastRush .5s ease-in forwards}
.west.rush{animation:westRush .5s ease-in forwards}
@keyframes eastRush{to{opacity:.0; left:50%; transform:translate(-50%,-50%) scale(.35)}}
@keyframes westRush{to{opacity:.0; right:50%; transform:translate(50%,-50%) scale(.35)}}

/* white flash */
.flash{position:absolute; inset:0; z-index:6; background:#fff; opacity:0; pointer-events:none}
.flash.go{animation:flash .7s ease-out forwards}
@keyframes flash{0%{opacity:0} 12%{opacity:.95} 100%{opacity:0}}

/* the bloom: primal animal name */
.bloom{position:absolute; inset:0; z-index:7; display:grid; place-content:center; text-align:center; opacity:0}
.bloom.go{animation:bloomIn 1.1s cubic-bezier(.16,1,.3,1) forwards}
.bloom .cross{display:flex; gap:10px; justify-content:center; align-items:center; color:#caa; font:600 .74rem/1 var(--sans); letter-spacing:.22em; text-transform:uppercase; margin-bottom:10px}
.bloom .cross b{color:#f0b46a}
.bloom h2{font-family:var(--serif); font-size:clamp(3.4rem,13vw,9rem); color:#fff; line-height:1;
  text-shadow:0 0 60px rgba(245,236,210,.6), 0 0 120px rgba(214,58,40,.3)}
.bloom .ess{font-family:var(--serif); font-style:italic; font-size:clamp(1.1rem,3vw,1.7rem); color:#ffd98a; margin-top:14px}
.bloom .rays{position:absolute; inset:0; z-index:-1; background:
  conic-gradient(from 0deg, transparent 0 8deg, rgba(245,236,210,.07) 8deg 9deg, transparent 9deg 20deg);
  animation:spinRays 14s linear infinite; opacity:.6}
@keyframes bloomIn{0%{opacity:0; transform:scale(.6)} 40%{opacity:1} 100%{opacity:1; transform:scale(1)}}
@keyframes spinRays{to{transform:rotate(360deg)}}

.cinema-cta{position:absolute; left:50%; bottom:8%; transform:translateX(-50%); z-index:8; opacity:0}
.cinema-cta.go{animation:fadeUp .7s ease .2s forwards}
@keyframes fadeUp{from{opacity:0; transform:translateX(-50%) translateY(16px)} to{opacity:1; transform:translateX(-50%) translateY(0)}}

@media(max-width:680px){
  .half{width:90%; max-width:340px; left:50%!important; right:auto!important; transform:translate(-50%,-50%)}
  .east{top:32%} .west{top:68%}
  @keyframes eastIn{from{opacity:0; transform:translate(-50%,-50%) scale(.8)} to{opacity:1; transform:translate(-50%,-50%) scale(1)}}
  @keyframes westIn{from{opacity:0; transform:translate(-50%,-50%) scale(.8)} to{opacity:1; transform:translate(-50%,-50%) scale(1)}}
  @keyframes eastRush{to{opacity:0; top:50%; transform:translate(-50%,-50%) scale(.3)}}
  @keyframes westRush{to{opacity:0; top:50%; transform:translate(-50%,-50%) scale(.3)}}
  .half .mark{width:150px; height:150px; font-size:5.5rem}
}
.sound-toggle{position:absolute; top:18px; left:20px; z-index:9; background:transparent; border:1px solid rgba(255,255,255,.2);
  color:#cbb; border-radius:999px; padding:8px 14px; font:600 .76rem/1 var(--sans); cursor:pointer}
