/* Huzzah! — Room Viewer (spectator / TV) styles. All scoped under .vw so nothing leaks into
   the game screens. Tokens (--bg, --blue-dark, --yellow, --border, --shadow-*, --r-*, fonts)
   come from css/style.css. Keyframes are vw-prefixed to avoid clashing with game animations.
   The whole viewer is laid out by js/viewer.js (carousel arc/ring, fly animations, etc.). */

#screen-viewer{padding:0;overflow:hidden;}
.vw{position:absolute;inset:0;overflow:hidden;display:flex;flex-direction:column;
    background:var(--bg);
    background-image:radial-gradient(circle at 18% -5%,#fff4cf 0,transparent 42%),
                     radial-gradient(circle at 92% 105%,#ffe9c2 0,transparent 42%);
    --vs:1;}   /* --vs = UI scale multiplier (settings) */

/* ── Play-style + genre indicators: top-left, drop down from the top (like the game) ── */
.vw .v-indicators{position:absolute;top:0;left:18px;z-index:150;display:flex;flex-direction:column;gap:0;align-items:stretch;width:calc(264px * var(--vs));perspective:400px;}
.vw .v-ind{transform-origin:top center;opacity:0;transform:rotateX(-80deg);width:100%;
       display:flex;align-items:center;justify-content:center;gap:10px;border:var(--border);border-top:none;
       box-shadow:var(--shadow-md);padding:calc(9px * var(--vs)) 18px;font-family:var(--font-title);}
.vw .v-ind.show{opacity:1;transform:rotateX(0);animation:vw-swing 1s ease-in both;}
.vw .v-ind.style{background:var(--blue);color:#fff;font-size:calc(28px * var(--vs));}
.vw .v-ind.style img{width:calc(42px * var(--vs));height:calc(42px * var(--vs));}
.vw .v-ind.genre{background:var(--yellow);color:var(--black);font-size:calc(23px * var(--vs));border-radius:0 0 var(--r-md) var(--r-md);}
@keyframes vw-swing{
  0%{transform:rotateX(-80deg);opacity:0;} 15%{transform:rotateX(-80deg);opacity:0;}
  18%{transform:rotateX(-80deg);opacity:1;} 40%{transform:rotateX(45deg);}
  70%{transform:rotateX(-45deg);} 100%{transform:rotateX(0);}
}

/* ── Options gear (top-right) ── */
.vw .v-opts{position:absolute;top:7px;right:7px;z-index:150;background:var(--yellow);border:var(--border);border-radius:var(--r-sm);
        box-shadow:var(--shadow-sm);font-size:22px;padding:6px 11px;cursor:pointer;}
.vw .v-opts:active{transform:translate(2px,2px);box-shadow:none;}

/* ── Carousel of player panels ── */
.vw .v-carousel{flex:0 0 40%;position:relative;overflow:visible;z-index:2;}
.vw .v-panel{position:absolute;left:50%;top:0;width:150px;transform-origin:50% 0;
         background:var(--white);border:var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-sm);
         padding:9px 8px 10px;display:flex;flex-direction:column;align-items:center;gap:4px;
         transition:transform .55s cubic-bezier(.25,.85,.3,1),opacity .55s ease,box-shadow .3s ease;
         will-change:transform,opacity;}
.vw .v-panel.is-it{background:#FFFDF4;box-shadow:0 0 0 5px var(--orange),var(--shadow-md);}
.vw .v-avatar{width:calc(46px * var(--vs));height:calc(46px * var(--vs));border-radius:50%;border:var(--border);display:flex;align-items:center;justify-content:center;
          font-family:var(--font-title);font-size:calc(22px * var(--vs));color:#fff;flex-shrink:0;}
.vw .v-pname{font-family:var(--font-title);font-size:calc(16px * var(--vs));line-height:1;text-align:center;max-width:100%;
         overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.vw .v-hand{display:flex;align-items:flex-end;gap:6px;}
.vw .v-fan{position:relative;height:calc(30px * var(--vs));flex:1 1 auto;min-width:calc(40px * var(--vs));}
.vw .v-fan.big{height:calc(46px * var(--vs));}
.vw .v-handnum{font-family:var(--font-title);font-size:calc(15px * var(--vs));color:var(--blue-dark);flex-shrink:0;}
.vw .v-burns{font-size:calc(11px * var(--vs));font-weight:800;color:var(--red-dark);min-height:14px;}

/* ── Real Huzzah card back (navy + yellow HUZZAH, lengthwise) ── */
.vw .hz-mini{position:absolute;left:50%;bottom:0;width:calc(20px * var(--vs));height:calc(29px * var(--vs));background:var(--blue-dark);
         border:2px solid #1A1A1A;border-radius:3px;box-shadow:1px 1px 0 #1A1A1A;color:var(--yellow);
         display:flex;align-items:center;justify-content:center;text-align:center;padding:1px;transform-origin:bottom center;
         transition:transform .4s cubic-bezier(.3,.9,.3,1);}
.vw .hz-mini.big{width:calc(28px * var(--vs));height:calc(41px * var(--vs));border-width:2.5px;}
.vw .hz-mini .hz{font-family:var(--font-title);font-size:calc(5px * var(--vs));line-height:1;letter-spacing:.1px;transform:rotate(-90deg);white-space:nowrap;}
.vw .hz-mini.big .hz{font-size:calc(7px * var(--vs));}

/* ── Stage (HUZZAH backdrop + roll / clue on top) ── */
.vw .v-stage{flex:1 1 auto;position:relative;margin:0 18px;min-height:0;}
.vw .v-backdrop{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;transition:transform .4s ease;}
.vw.ring .v-backdrop{transform:translateY(-180px);}   /* ring mode: lift HUZZAH above the active player */
.vw .v-backdrop .logo{position:relative;animation:vw-bob 2.5s ease-in-out infinite;}
.vw .v-backdrop .star{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:200px;color:var(--yellow);
                  opacity:.28;animation:vw-spin 25s linear infinite;}
.vw .v-backdrop .word{position:relative;font-family:var(--font-title);font-size:clamp(40px,8vw,86px);color:var(--red);
                  -webkit-text-stroke:3px var(--black);text-shadow:6px 6px 0 var(--black);letter-spacing:-2px;opacity:.9;}
@keyframes vw-bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes vw-spin{to{transform:translate(-50%,-50%) rotate(360deg)}}

/* die that rolls from the active player's tile onto the stage */
.vw-fly-die{position:fixed;z-index:300;font-size:88px;pointer-events:none;filter:drop-shadow(3px 4px 0 rgba(0,0,0,.4));
         animation:vw-diespin .25s linear infinite;transition:left .7s cubic-bezier(.25,.46,.45,.94),top .7s cubic-bezier(.25,.46,.45,.94),opacity .3s ease;}
@keyframes vw-diespin{to{transform:rotate(360deg)}}

/* word-clue popup */
.vw .v-wordpop{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(0);
           background:var(--white);border:5px solid #1A1A1A;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
           padding:22px 36px;max-width:78%;text-align:center;z-index:60;display:none;}
.vw .v-wordpop.show{display:block;animation:vw-pop .55s cubic-bezier(.2,1.3,.4,1) forwards;}
.vw .v-wordpop .txt{font-family:var(--font-title);font-size:calc(32px * var(--vs));line-height:1.15;color:var(--black);word-break:break-word;}
.vw .v-wordpop .spark{position:absolute;font-size:24px;animation:vw-spark 1.4s ease-in-out infinite;}
.vw .v-wordpop .s1{top:-16px;left:-12px}.vw .v-wordpop .s2{top:-14px;right:-10px;animation-delay:.5s}
.vw .v-wordpop .s3{bottom:-16px;left:10px;animation-delay:.9s}.vw .v-wordpop .s4{bottom:-14px;right:-8px;animation-delay:.3s}
@keyframes vw-pop{0%{transform:translate(-50%,-50%) scale(0) rotate(-8deg)}
  70%{transform:translate(-50%,-50%) scale(1.08) rotate(2deg)}100%{transform:translate(-50%,-50%) scale(1) rotate(0)}}
@keyframes vw-spark{0%,100%{transform:scale(.7) rotate(0);opacity:.5}50%{transform:scale(1.2) rotate(20deg);opacity:1}}

/* whiteboard: portrait window matching the drawer's drawing area; overlaps tiles, reaches near top */
.vw .v-board{position:absolute;top:8px;bottom:104px;left:50%;transform:translateX(-50%) scale(.92);aspect-ratio:var(--drawer-ar,0.66);
         background:#fff;border:var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);overflow:hidden;
         opacity:0;pointer-events:none;z-index:110;transition:opacity .3s ease,transform .35s cubic-bezier(.2,.8,.3,1);}
.vw .v-board.show{opacity:1;transform:translateX(-50%) scale(1);pointer-events:auto;}
.vw .v-board canvas{position:absolute;inset:0;width:100%;height:100%;}
.vw .v-board .tag{position:absolute;top:8px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.45);color:#fff;
              font-size:11px;font-weight:800;padding:4px 12px;border-radius:999px;pointer-events:none;z-index:2;white-space:nowrap;}

/* ── Bottom row ── arc: spread (deck · GotIt · timer · Failed · Burned); ring: deck+timer left, piles right ── */
.vw .v-bottom{flex:0 0 auto;display:flex;align-items:flex-end;justify-content:space-between;gap:30px;padding:6px 26px 14px;}
.vw.ring .v-bottom{justify-content:flex-start;}
.vw.ring #vb-deck{order:1;} .vw.ring #vb-timer{order:2;margin-right:auto;}
.vw.ring #v-stat-success{order:3;} .vw.ring #v-stat-fail{order:4;} .vw.ring #v-stat-burn{order:5;}
.vw .v-stat{display:flex;flex-direction:column;align-items:center;gap:2px;}
.vw .v-stat .iconwrap{position:relative;font-size:calc(24px * var(--vs));line-height:1;}
.vw .v-stat .num{font-family:var(--font-title);font-size:calc(26px * var(--vs));line-height:1;}
.vw .v-stat .lbl{font-size:calc(10px * var(--vs));font-weight:900;text-transform:uppercase;letter-spacing:.6px;opacity:.6;}
.vw .num-success{color:var(--green);} .vw .num-fail{color:var(--red);} .vw .num-burn{color:var(--orange);}
.vw .v-stat.pop .num{animation:vw-statpop .5s ease;}
.vw .v-stat.pop .chip-ring{animation:vw-ring .6s ease forwards;}
.vw .chip-ring{position:absolute;inset:-7px;border-radius:50%;border:3px solid currentColor;opacity:0;pointer-events:none;}
@keyframes vw-statpop{0%{transform:scale(1)}40%{transform:scale(1.55)}100%{transform:scale(1)}}
@keyframes vw-ring{0%{opacity:.8;transform:scale(.55)}100%{opacity:0;transform:scale(1.8)}}

/* 3D draw stack */
.vw .v-deck{display:flex;flex-direction:column;align-items:center;gap:3px;}
.vw .v-stack{position:relative;width:calc(118px * var(--vs));height:calc(100px * var(--vs));}
.vw .v-stack .layer{position:absolute;left:50%;width:calc(102px * var(--vs));height:calc(70px * var(--vs));margin-left:calc(-51px * var(--vs));border:3px solid #1A1A1A;border-radius:6px;
                background:var(--blue-dark);box-shadow:1.5px 1.5px 0 #1A1A1A;}
.vw .v-stack .layer .mark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:var(--yellow);}
.vw .v-stack .layer .mark .hz{font-family:var(--font-title);font-size:calc(15px * var(--vs));letter-spacing:.5px;}
.vw .v-deck .num{font-family:var(--font-title);font-size:calc(20px * var(--vs));color:var(--blue-dark);}

/* big center timer — round red button like the in-game timer */
.vw .v-timer{font-family:var(--font-title);font-size:calc(40px * var(--vs));width:calc(118px * var(--vs));height:calc(118px * var(--vs));border-radius:50%;background:var(--red);color:#fff;
         border:4px solid #1A1A1A;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;letter-spacing:1px;}
.vw .v-timer.warn{background:var(--orange);color:var(--black);}
.vw .v-timer.crit{background:var(--red-dark);animation:vw-crit .8s ease-in-out infinite;}
.vw .v-timer.paused{filter:grayscale(.5) brightness(.92);}
@keyframes vw-crit{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}

/* flying card clones */
.vw-fly-card{position:fixed;z-index:300;width:42px;height:60px;border:2.5px solid #1A1A1A;border-radius:5px;
          background:var(--blue-dark);box-shadow:2px 3px 0 #1A1A1A;color:var(--yellow);
          display:flex;align-items:center;justify-content:center;text-align:center;padding:2px;pointer-events:none;
          transition:transform .6s cubic-bezier(.4,0,.2,1),opacity .6s ease;}
.vw-fly-card .hz{font-family:var(--font-title);font-size:8px;line-height:1;transform:rotate(-90deg);white-space:nowrap;}

/* ── Lobby view ── */
.vw .v-lobby{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:24px;background:var(--bg);z-index:200;}
.vw .v-lobby.show{display:flex;}
.vw .v-lobby .codelbl{font-size:13px;font-weight:900;letter-spacing:3px;text-transform:uppercase;opacity:.55;}
.vw .v-lobby .code{font-family:var(--font-title);font-size:64px;letter-spacing:6px;color:var(--blue-dark);
               background:#fff;border:var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);padding:10px 30px;}
.vw .v-lobby .lob-players{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;max-width:90%;}
.vw .v-lobby .lob-p{display:flex;flex-direction:column;align-items:center;gap:4px;}
.vw .v-lobby .wait{font-family:var(--font-title);font-size:18px;color:var(--red);animation:vw-bob 2s ease-in-out infinite;}

/* ── End (won / lost / ended) banner ── */
.vw .v-end{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:210;
       background:rgba(0,0,0,.45);}
.vw .v-end.show{display:flex;}
.vw .v-end .big{font-family:var(--font-title);font-size:clamp(48px,11vw,120px);color:#fff;-webkit-text-stroke:3px var(--black);text-shadow:6px 6px 0 var(--black);}
.vw .v-end .stats{display:flex;gap:30px;color:#fff;font-family:var(--font-title);font-size:26px;}

/* ── Demo/test floating toolbar (only shown in demo mode) ── */
.vw .v-demobar{position:absolute;left:50%;top:8px;transform:translateX(-50%);z-index:400;display:none;flex-wrap:wrap;gap:6px;justify-content:center;
           background:rgba(26,26,26,.82);padding:8px 10px;border-radius:12px;max-width:94%;}
.vw .v-demobar.show{display:flex;}
.vw .v-demobar button{font-family:var(--font-title);font-size:12px;padding:7px 10px;border:2px solid #000;border-radius:8px;background:#eee;cursor:pointer;white-space:nowrap;}
.vw .v-demobar button.on{outline:2px solid var(--yellow);}
.vw .v-demobar .lbl2{color:#fff;font-size:11px;font-weight:800;align-self:center;padding:0 4px;}

/* Viewer-options overlay (outside .vw) — active formation button */
#overlay-viewer .vform-btn.active{background:var(--blue);color:#fff;}
#viewer-pick-list .vp-room{display:flex;justify-content:space-between;gap:10px;padding:8px 10px;border:2px solid var(--black);border-radius:var(--r-sm);margin-bottom:6px;cursor:pointer;font-weight:700;background:#fff;}
#viewer-pick-list .vp-room:active{transform:translate(2px,2px);}
#viewer-pick-list .vp-empty{opacity:.5;text-align:center;padding:10px;font-weight:700;}
