.pg-button{font-family:Bangers,cursive;font-size:clamp(16px,2vw,28px);font-weight:400;letter-spacing:2px;text-transform:uppercase;line-height:1;position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:28px;cursor:pointer;transform:translateZ(0);transition:transform .2s cubic-bezier(.22,1,.36,1),box-shadow .2s cubic-bezier(.22,1,.36,1);overflow:hidden;white-space:nowrap;color:#fff;-webkit-tap-highlight-color:transparent}.pg-button:hover:not(:disabled){transform:translate3d(0,-3px,0) scale(1.03)}.pg-button:active:not(:disabled){transform:translateZ(0) scale(.98)}.pg-button:disabled{opacity:.5;cursor:not-allowed}.pg-button:focus-visible{outline:2px solid #18dcff;outline-offset:3px}.pg-button--play{background:linear-gradient(180deg,#2ed573,#10b981);box-shadow:0 0 30px #2ed5734d}.pg-button--play:hover:not(:disabled){box-shadow:0 0 40px #2ed57380}.pg-button--primary{background:linear-gradient(180deg,#ff8c42,#ff4757);box-shadow:0 4px 16px #ff475740}.pg-button--primary:hover:not(:disabled){box-shadow:0 8px 24px #ff475759}.pg-button--ghost{background:#ffffff0f;border:1px solid rgba(255,255,255,.06)}.pg-button--ghost:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff26}.pg-button--sm{font-size:16px;padding:12px 28px}.pg-button--md{font-size:22px;padding:16px 40px}.pg-button--lg{font-size:28px;padding:20px 56px}.pg-button--loading{pointer-events:none}.pg-button__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.pg-button__label{position:relative;z-index:1}.pg-button__shine{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);animation:btnShine 3s ease-in-out infinite;pointer-events:none}.pg-card{background:#151d6b;border-radius:20px;border:1px solid rgba(255,255,255,.06);overflow:hidden;contain:layout style paint;transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .25s cubic-bezier(.22,1,.36,1),border-color .25s ease}.pg-card--clickable{cursor:pointer}.pg-card--clickable:hover{transform:translate3d(0,-8px,0) rotate(-.5deg);box-shadow:0 16px 40px #0000004d;border-color:#ffffff1f}.pg-card--clickable:hover .pg-card__emoji{transform:scale(1.15) rotate(5deg)}.pg-card--clickable:focus-visible{outline:2px solid #18dcff;outline-offset:3px}.pg-card__visual{position:relative;height:200px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(255,255,255,.04) 0%,transparent 60%)}.pg-card__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--card-accent, transparent) 0%,transparent 60%);opacity:.15;pointer-events:none}.pg-card__emoji{font-size:72px;line-height:1;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3));transition:transform .25s cubic-bezier(.34,1.56,.64,1);-webkit-user-select:none;user-select:none}.pg-card__tag{position:absolute;top:12px;right:12px;padding:4px 12px;border-radius:999px;font-family:Bangers,cursive;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:#fff;z-index:1}.pg-card__tag--live{background:#ff4757;animation:pulse 2s ease-in-out infinite}.pg-card__tag--new{background:#2ed573}.pg-card__tag--soon{background:#a855f7}.pg-card__body{padding:16px 24px 24px}.pg-card__heading{font-family:Bangers,cursive;font-size:clamp(26px,3vw,30px);font-weight:400;letter-spacing:2px;text-transform:uppercase;line-height:1.2;color:#fff;margin:0 0 8px}.pg-card__description{font-family:Nunito,sans-serif;font-size:14px;font-weight:600;letter-spacing:0;line-height:1.5;color:#ffffffb3;margin:0 0 12px}.pg-card__meta{display:flex;flex-wrap:wrap;gap:16px}.pg-card__meta-item{font-family:Nunito,sans-serif;font-size:13px;font-weight:700;letter-spacing:.5px;line-height:1.4;color:#fff6;display:inline-flex;align-items:center;gap:4px}.pg-card__meta-icon{display:flex;align-items:center}.pg-avatar{position:relative;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#1a2278;overflow:hidden;flex-shrink:0;animation:popIn .35s cubic-bezier(.34,1.56,.64,1) both}.pg-avatar__img{width:100%;height:100%;object-fit:cover;border-radius:999px}.pg-avatar__fallback{color:#fff;-webkit-user-select:none;user-select:none}.pg-avatar--sm .pg-avatar__fallback{font-size:14px}.pg-avatar--md .pg-avatar__fallback{font-size:20px}.pg-avatar--lg .pg-avatar__fallback{font-size:32px}.pg-avatar__status{position:absolute;bottom:0;right:0;width:25%;height:25%;min-width:8px;min-height:8px;border-radius:999px;border:2px solid #080e3a}.pg-avatar__status--online{background:#2ed573}.pg-avatar__status--offline{background:#fff6}.pg-emoji{display:inline-block;vertical-align:middle;-webkit-user-select:none;user-select:none;pointer-events:none}.pg-timer{display:inline-flex;align-items:center;gap:12px}.pg-timer--text .pg-timer__value{font-family:Bangers,cursive;font-size:clamp(24px,5vw,64px);font-weight:400;letter-spacing:3px;text-transform:uppercase;line-height:1;color:#ffd43b;text-shadow:0 0 20px rgba(255,212,59,.4)}.pg-timer--bar{flex-direction:column;gap:8px;width:100%}.pg-timer--bar .pg-timer__value--bar{font-family:Bangers,cursive;font-size:clamp(26px,3vw,30px);font-weight:400;letter-spacing:2px;text-transform:uppercase;line-height:1.2;color:#ffd43b}.pg-timer--circle .pg-timer__circle{position:relative;width:100px;height:100px}.pg-timer--circle .pg-timer__value--circle{font-family:Bangers,cursive;font-size:clamp(24px,5vw,64px);font-weight:400;letter-spacing:3px;text-transform:uppercase;line-height:1;position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#ffd43b}.pg-timer__track{width:100%;height:8px;background:#ffffff0f;border-radius:999px;overflow:hidden}.pg-timer__fill{height:100%;background:linear-gradient(135deg,#ff4757,#ff8c42,#ffd43b);border-radius:999px;transition:width .3s linear}.pg-timer__svg{width:100%;height:100%;transform:rotate(-90deg)}.pg-timer__circle-track{fill:none;stroke:#ffffff0f;stroke-width:6}.pg-timer__circle-fill{fill:none;stroke:#ffd43b;stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset .3s linear}.pg-timer--urgent .pg-timer__value{color:#ff4757;text-shadow:0 0 20px rgba(255,71,87,.5);animation:pulse 1s ease-in-out infinite}.pg-timer--urgent .pg-timer__fill{background:#ff4757}.pg-timer--urgent .pg-timer__circle-fill{stroke:#ff4757}.pg-scoreboard{background:#151d6b;border-radius:20px;border:1px solid rgba(255,255,255,.06);overflow:hidden}.pg-scoreboard__podium{display:flex;justify-content:center;align-items:flex-end;gap:16px;padding:24px 16px 16px}.pg-scoreboard__podium-slot{display:flex;flex-direction:column;align-items:center;gap:8px;min-width:80px}.pg-scoreboard__podium-slot .pg-scoreboard__name{font-family:Nunito,sans-serif;font-size:13px;font-weight:700;letter-spacing:.5px;line-height:1.4;color:#ffffffb3}.pg-scoreboard__podium-slot .pg-scoreboard__score{font-family:Bangers,cursive;font-size:clamp(24px,5vw,64px);font-weight:400;letter-spacing:3px;text-transform:uppercase;line-height:1;font-size:clamp(28px,4vw,48px);color:#ffd43b}.pg-scoreboard__podium-slot--1{order:2}.pg-scoreboard__podium-slot--1 .pg-scoreboard__score{font-size:clamp(36px,5vw,56px)}.pg-scoreboard__podium-slot--2{order:1}.pg-scoreboard__podium-slot--3{order:3}.pg-scoreboard__podium-emoji{font-size:32px;line-height:1}.pg-scoreboard__list{display:flex;flex-direction:column}.pg-scoreboard__row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-top:1px solid rgba(255,255,255,.06)}.pg-scoreboard__row:first-child{border-top:none}.pg-scoreboard__row--highlight{background:#ffd43b14}.pg-scoreboard__rank{font-family:Bangers,cursive;font-size:clamp(24px,5vw,64px);font-weight:400;letter-spacing:3px;text-transform:uppercase;line-height:1;font-size:20px;color:#fff6;min-width:28px;text-align:center}.pg-scoreboard__name{font-family:Nunito,sans-serif;font-size:16px;font-weight:600;letter-spacing:0;line-height:1.6;color:#ffffffb3;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pg-scoreboard__score{font-family:Bangers,cursive;font-size:clamp(24px,5vw,64px);font-weight:400;letter-spacing:3px;text-transform:uppercase;line-height:1;font-size:24px;color:#ffd43b}.pg-scoreboard__avatar{border-radius:999px;object-fit:cover;flex-shrink:0}.pg-scoreboard__avatar--sm{width:32px;height:32px}.pg-room-code{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px;background:#151d6b;border-radius:20px;border:1px solid rgba(255,255,255,.06)}.pg-room-code__qr{padding:16px;background:#ffffff0f;border-radius:14px}.pg-room-code__label{font-family:Nunito,sans-serif;font-size:12px;font-weight:800;letter-spacing:3px;text-transform:uppercase;color:#fff6}.pg-room-code__url{font-family:Bangers,cursive;font-size:clamp(24px,5vw,64px);font-weight:400;letter-spacing:3px;text-transform:uppercase;line-height:1;color:#ffd43b;text-shadow:0 0 20px rgba(255,212,59,.3);word-break:break-all;text-align:center}.pg-room-code--sm{padding:16px}.pg-room-code--sm .pg-room-code__url{font-size:clamp(18px,3vw,28px)}.pg-room-code--lg{padding:32px}.pg-room-code--lg .pg-room-code__url{font-size:clamp(32px,6vw,56px)}.pg-toast{display:inline-flex;align-items:center;gap:12px;padding:12px 20px;background:#1a2278;border-radius:20px;border:1px solid rgba(255,255,255,.06);animation:popIn .4s cubic-bezier(.34,1.56,.64,1) both;transform-origin:top right}.pg-toast--exiting{animation:toastExit .3s ease-out both}.pg-toast--info{border-left:4px solid #18dcff}.pg-toast--success{border-left:4px solid #2ed573}.pg-toast--error{border-left:4px solid #ff4757}.pg-toast__emoji{font-size:20px;line-height:1;flex-shrink:0}.pg-toast__message{font-family:Nunito,sans-serif;font-size:16px;font-weight:600;letter-spacing:0;line-height:1.6;color:#ffffffb3}@keyframes toastExit{0%{opacity:1;transform:translateZ(0) scale(1)}to{opacity:0;transform:translate3d(20px,0,0) scale(.95)}}.pg-reaction-bar{display:inline-flex;align-items:center;gap:12px;padding:8px 16px;background:#1a2278;border-radius:999px;border:1px solid rgba(255,255,255,.06)}.pg-reaction-bar__btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;font-size:24px;line-height:1;border:none;background:transparent;border-radius:999px;cursor:pointer;transform:translateZ(0);transition:transform .2s cubic-bezier(.22,1,.36,1);-webkit-tap-highlight-color:transparent}.pg-reaction-bar__btn:hover:not(:disabled){transform:translate3d(0,-2px,0) scale(1.15);background:#ffffff0f}.pg-reaction-bar__btn:active:not(:disabled){transform:scale(.9)}.pg-reaction-bar__btn:disabled{opacity:.4;cursor:not-allowed}.pg-reaction-bar__btn:focus-visible{outline:2px solid #18dcff;outline-offset:2px}.pg-reaction-bar__btn--tapped{animation:reaction-tap .3s ease-out}@keyframes reaction-tap{0%{transform:scale(1)}30%{transform:scale(1.4)}to{transform:scale(1)}}.pg-reaction-bubble{position:absolute;pointer-events:none;animation:reactionFloat 2s cubic-bezier(.22,1,.36,1) both;will-change:transform,opacity}.pg-reaction-bubble__emoji{display:block;font-size:36px;line-height:1}@keyframes reactionFloat{0%{opacity:1;transform:translateZ(0) scale(1)}60%{opacity:1}to{opacity:0;transform:translate3d(0,-120px,0) scale(1.3)}}.living-bg{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden;contain:strict}.living-bg__gradients{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 60% 50% at 20% 30%,rgba(168,85,247,.12) 0%,transparent 70%),radial-gradient(ellipse 50% 60% at 80% 70%,rgba(255,107,157,.1) 0%,transparent 70%),radial-gradient(ellipse 55% 45% at 50% 50%,rgba(24,220,255,.08) 0%,transparent 70%);animation:living-bg-gradients-drift 25s ease-in-out infinite alternate;will-change:transform;transform:translateZ(0)}@keyframes living-bg-gradients-drift{0%{transform:translateZ(0) scale(1)}to{transform:translate3d(30px,-20px,0) scale(1.05)}}.living-bg__blobs{position:absolute;top:0;right:0;bottom:0;left:0}.living-bg__blob{position:absolute;border-radius:50%;filter:blur(70px);will-change:transform;transform:translateZ(0)}.living-bg__blob--pink{width:400px;height:400px;background:#ff6b9d1a;top:10%;left:15%;animation:living-bg-blob-drift-1 18s ease-in-out infinite alternate}.living-bg__blob--cyan{width:350px;height:350px;background:#18dcff14;top:60%;right:10%;animation:living-bg-blob-drift-2 20s ease-in-out infinite alternate}.living-bg__blob--purple{width:500px;height:500px;background:#a855f70f;bottom:5%;left:40%;animation:living-bg-blob-drift-3 16s ease-in-out infinite alternate}.living-bg__blob--yellow{width:300px;height:300px;background:#ffd43b14;top:30%;right:30%;animation:living-bg-blob-drift-4 22s ease-in-out infinite alternate}@keyframes living-bg-blob-drift-1{0%{transform:translateZ(0)}to{transform:translate3d(40px,-30px,0)}}@keyframes living-bg-blob-drift-2{0%{transform:translateZ(0)}to{transform:translate3d(-35px,25px,0)}}@keyframes living-bg-blob-drift-3{0%{transform:translateZ(0)}to{transform:translate3d(25px,-40px,0)}}@keyframes living-bg-blob-drift-4{0%{transform:translateZ(0)}to{transform:translate3d(-30px,35px,0)}}.living-bg__particles{position:absolute;top:0;right:0;bottom:0;left:0;contain:strict}.living-bg__particle{position:absolute;bottom:-10px;border-radius:50%;will-change:transform;opacity:0}.living-bg__particle--0{width:3px;height:3px;background:#ff6b9db3;left:10%;animation:living-bg-rise-0 12s linear infinite;animation-delay:0s}@keyframes living-bg-rise-0{0%{transform:translateZ(0);opacity:0}10%{opacity:.7}90%{opacity:.7}to{transform:translate3d(-10px,-100vh,0);opacity:0}}.living-bg__particle--1{width:4px;height:4px;background:#18dcffb3;left:25%;animation:living-bg-rise-1 14s linear infinite;animation-delay:2s}@keyframes living-bg-rise-1{0%{transform:translateZ(0);opacity:0}10%{opacity:.7}90%{opacity:.7}to{transform:translate3d(-6px,-100vh,0);opacity:0}}.living-bg__particle--2{width:3px;height:3px;background:#a855f7b3;left:45%;animation:living-bg-rise-2 10s linear infinite;animation-delay:4s}@keyframes living-bg-rise-2{0%{transform:translateZ(0);opacity:0}10%{opacity:.7}90%{opacity:.7}to{transform:translate3d(-2px,-100vh,0);opacity:0}}.living-bg__particle--3{width:5px;height:5px;background:#ffd43bb3;left:60%;animation:living-bg-rise-3 17s linear infinite;animation-delay:1s}@keyframes living-bg-rise-3{0%{transform:translateZ(0);opacity:0}10%{opacity:.7}90%{opacity:.7}to{transform:translate3d(2px,-100vh,0);opacity:0}}.living-bg__particle--4{width:4px;height:4px;background:#2ed573b3;left:75%;animation:living-bg-rise-4 13s linear infinite;animation-delay:3s}@keyframes living-bg-rise-4{0%{transform:translateZ(0);opacity:0}10%{opacity:.7}90%{opacity:.7}to{transform:translate3d(6px,-100vh,0);opacity:0}}.living-bg__particle--5{width:3px;height:3px;background:#ff8c42b3;left:90%;animation:living-bg-rise-5 15s linear infinite;animation-delay:5s}@keyframes living-bg-rise-5{0%{transform:translateZ(0);opacity:0}10%{opacity:.7}90%{opacity:.7}to{transform:translate3d(10px,-100vh,0);opacity:0}}@media(prefers-reduced-motion:reduce){.living-bg__gradients,.living-bg__blob,.living-bg__particle{animation:none!important}.living-bg__gradients{transform:none}.living-bg__particles{display:none}}.pg-projector-frame{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:var(--radius-lg, 20px);background:var(--bg-primary, #0d1450)}.pg-projector-frame__content{position:relative;z-index:1;width:100%;height:100%}.pg-projector-frame__scanlines{position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;background:repeating-linear-gradient(to bottom,transparent 0px,transparent 2px,rgba(255,255,255,.02) 2px,rgba(255,255,255,.02) 4px)}.pg-projector-frame__vignette{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;pointer-events:none;background:radial-gradient(ellipse 70% 70% at 50% 50%,transparent 50%,rgba(0,0,0,.5) 100%)}.pg-projector-frame__glow-effect{position:absolute;bottom:-40px;left:10%;right:10%;height:80px;z-index:0;pointer-events:none;background:radial-gradient(ellipse 80% 100% at 50% 0%,rgba(24,220,255,.25) 0%,transparent 70%);filter:blur(20px)}.pg-marquee{overflow:hidden;white-space:nowrap;contain:layout style paint;width:100%}.pg-marquee__track{display:inline-flex;animation:pg-marquee-scroll linear infinite;will-change:transform}@keyframes pg-marquee-scroll{0%{transform:translateZ(0)}to{transform:translate3d(-50%,0,0)}}.pg-marquee__segment{display:inline-flex;flex-shrink:0}.pg-marquee__item{display:inline-flex;align-items:center;gap:var(--space-2, 8px);padding:0 var(--space-6, 24px);font-family:var(--font-body, "Nunito", sans-serif);font-weight:600;font-size:.875rem;color:var(--text-secondary, rgba(255, 255, 255, .7));text-transform:uppercase;letter-spacing:.05em}.pg-marquee__emoji{font-size:1.1em}@media(prefers-reduced-motion:reduce){.pg-marquee__track{animation-play-state:paused}}.landing{position:relative;display:flex;justify-content:center;align-items:center;min-height:100vh;min-height:100dvh;background:var(--bg-deep);overflow:hidden}.landing__content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;width:100%;max-width:400px;padding:var(--space-6)}.landing__title{font-family:var(--font-display);font-size:clamp(48px,10vw,80px);color:var(--accent-yellow);text-transform:uppercase;letter-spacing:6px;text-align:center;line-height:1;margin:0 0 var(--space-2) 0;text-shadow:4px 4px 0 var(--accent-orange),8px 8px 0 var(--accent-red),0 0 60px rgba(255,140,66,.3)}.landing__tagline{font-family:var(--font-body);font-size:1.25rem;font-weight:600;color:var(--text-secondary);letter-spacing:4px;text-transform:uppercase;margin:0 0 var(--space-8) 0}.landing__form{display:flex;flex-direction:column;gap:var(--space-4);width:100%}.landing__field{display:flex;flex-direction:column;gap:var(--space-2)}.landing__label{font-family:var(--font-body);font-size:.875rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.landing__input{background:var(--bg-primary);border:2px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--text-primary);outline:none;transition:border-color .2s ease,box-shadow .2s ease}.landing__input::placeholder{color:var(--text-primary);opacity:.4}.landing__input:focus{border-color:var(--accent-cyan);box-shadow:0 0 0 3px #18dcff40}.landing__input:disabled{opacity:.5;cursor:not-allowed}.landing__error{font-family:var(--font-body);font-size:.875rem;font-weight:600;color:var(--accent-red);margin:0;text-align:center}.landing__submit{margin-top:var(--space-2);align-self:center}.player-lobby{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.player-lobby__content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);gap:var(--space-6)}.player-lobby__title{font-family:var(--font-display);font-size:clamp(28px,8vw,48px);color:var(--accent-yellow);text-transform:uppercase;letter-spacing:4px;text-align:center;line-height:1;margin:0;text-shadow:3px 3px 0 var(--accent-orange),6px 6px 0 var(--accent-red)}.player-lobby__greeting{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.player-lobby__name{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--text-secondary);margin:0}.player-lobby__name strong{color:var(--text-primary)}.player-lobby__badge{display:flex;align-items:center;gap:var(--space-2);background:#ffffff14;padding:var(--space-2) var(--space-4);border-radius:var(--radius-full)}.player-lobby__badge-emoji{font-size:1.25rem}.player-lobby__badge-count{font-family:var(--font-body);font-size:.8125rem;font-weight:800;color:var(--accent-yellow);letter-spacing:1px}.player-lobby__stats{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.player-lobby__rank{font-family:var(--font-body);font-size:1rem;font-weight:700;color:var(--accent-yellow);margin:0}.player-lobby__score{font-family:var(--font-body);font-size:.875rem;font-weight:600;color:var(--text-secondary);margin:0}.player-lobby__status{font-family:var(--font-body);font-size:.875rem;font-weight:600;color:var(--text-muted);margin:0;letter-spacing:1px;text-transform:uppercase;animation:pulse-opacity 2s ease-in-out infinite}.player-lobby__reactions{padding:var(--space-3) var(--space-4);padding-bottom:env(safe-area-inset-bottom,var(--space-3))}@keyframes pulse-opacity{0%,to{opacity:.6}50%{opacity:1}}.player-voting{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;padding:var(--space-6) var(--space-4);gap:var(--space-6)}.player-voting__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.player-voting__title{font-family:var(--font-display);font-size:clamp(24px,7vw,36px);color:var(--accent-yellow);text-transform:uppercase;letter-spacing:3px;margin:0;line-height:1}.player-voting__cards{display:flex;flex-direction:column;gap:var(--space-3);overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}.vote-card{display:flex;align-items:center;gap:var(--space-4);background:var(--bg-primary);border:2px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .15s ease;text-align:left;color:var(--text-primary);font-family:var(--font-body);min-height:80px;position:relative;contain:layout style paint}.vote-card:active:not(:disabled){transform:scale(.98)}.vote-card--selected{border-color:var(--vote-accent, var(--accent-cyan));box-shadow:0 0 20px color-mix(in srgb,var(--vote-accent, var(--accent-cyan)) 25%,transparent)}.vote-card--disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.6)}.vote-card__emoji{font-size:48px;line-height:1;flex-shrink:0}.vote-card__info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.vote-card__name{font-family:var(--font-display);font-size:clamp(16px,4vw,22px);text-transform:uppercase;letter-spacing:2px;line-height:1.1}.vote-card__desc{font-size:.8125rem;font-weight:600;color:var(--text-secondary)}.vote-card__meta{font-size:.75rem;font-weight:700;color:var(--text-muted);letter-spacing:.5px}.vote-card__check{position:absolute;top:var(--space-2);right:var(--space-3);font-size:1.25rem;font-weight:800;color:var(--accent-green)}.player-countdown{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:var(--space-6)}.player-countdown__content{display:flex;flex-direction:column;align-items:center;gap:var(--space-8);text-align:center}.player-countdown__game{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.player-countdown__emoji{font-size:64px;line-height:1}.player-countdown__title{font-family:var(--font-display);font-size:clamp(28px,8vw,48px);color:var(--text-primary);text-transform:uppercase;letter-spacing:4px;margin:0;line-height:1}.player-countdown__timer{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.player-countdown__label{font-family:var(--font-body);font-size:.875rem;font-weight:800;color:var(--text-muted);letter-spacing:2px;margin:0}.player-countdown__clock{font-size:clamp(48px,12vw,80px)}.player-countdown__actions{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);width:100%;max-width:280px}.player-countdown__joined{font-family:var(--font-body);font-size:1.125rem;font-weight:700;color:var(--accent-green);margin:0}.player-countdown__count{font-family:var(--font-body);font-size:.8125rem;font-weight:700;color:var(--text-muted);margin:0;letter-spacing:.5px}.mid-game-join{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.mid-game-join__content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);gap:var(--space-6);text-align:center}.mid-game-join__heading{font-family:var(--font-display);font-size:clamp(24px,7vw,40px);color:var(--accent-yellow);text-transform:uppercase;letter-spacing:4px;margin:0;line-height:1}.mid-game-join__game{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.mid-game-join__emoji{font-size:64px;line-height:1}.mid-game-join__game-name{font-family:var(--font-display);font-size:clamp(20px,5vw,32px);color:var(--text-primary);text-transform:uppercase;letter-spacing:3px;margin:0}.mid-game-join__info{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--text-secondary);margin:0}.mid-game-join__reactions{padding:var(--space-3) var(--space-4);padding-bottom:env(safe-area-inset-bottom,var(--space-3))}.player-scoreboard{display:flex;flex-direction:column;align-items:center;padding:var(--space-5) var(--space-4);gap:var(--space-5);min-height:100dvh}@keyframes scoreReveal{0%{opacity:0;transform:translate3d(0,20px,0)}to{opacity:1;transform:translateZ(0)}}@keyframes scorePopIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.player-scoreboard__title{font-family:var(--font-display);font-size:36px;color:var(--accent-yellow);text-transform:uppercase;letter-spacing:4px;margin:0;text-shadow:2px 2px 0 var(--accent-orange),0 0 20px rgba(255,215,0,.3);animation:scoreReveal .5s var(--ease-smooth-out, ease-out) .2s both}.player-scoreboard__you{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:linear-gradient(135deg,#00e6ff1a,#00e6ff0d);border:2px solid rgba(0,230,255,.3);border-radius:var(--radius-lg);width:100%;max-width:360px;animation:scorePopIn .5s var(--ease-overshoot, ease-out) .4s both}.player-scoreboard__you-info{display:flex;flex-direction:column;gap:var(--space-1)}.player-scoreboard__you-rank{font-family:var(--font-display);font-size:32px;color:var(--accent-yellow);margin:0;line-height:1.1}.player-scoreboard__you-score{font-family:var(--font-display);font-size:20px;color:var(--accent-cyan);margin:0;letter-spacing:1px;text-shadow:0 0 12px rgba(0,230,255,.3)}.player-scoreboard__top3{display:flex;flex-direction:column;gap:var(--space-2);width:100%;max-width:360px}.player-scoreboard__entry{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:#ffffff0a;border-radius:var(--radius-md);border:1px solid transparent;animation:scoreReveal .4s var(--ease-smooth-out, ease-out) both}.player-scoreboard__entry:nth-child(1){animation-delay:.6s}.player-scoreboard__entry:nth-child(2){animation-delay:.7s}.player-scoreboard__entry:nth-child(3){animation-delay:.8s}.player-scoreboard__entry--highlight{background:#00e6ff14;border-color:#00e6ff33}.player-scoreboard__entry-medal{font-size:24px;flex-shrink:0;width:32px;text-align:center}.player-scoreboard__entry-name{font-family:var(--font-body);font-size:16px;font-weight:600;color:var(--text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-scoreboard__entry-score{font-family:var(--font-display);font-size:18px;color:var(--accent-cyan);flex-shrink:0}.player-scoreboard__countdown{font-family:var(--font-body);font-size:14px;font-weight:700;color:var(--text-secondary);letter-spacing:1px;text-transform:uppercase;margin:0;animation:scoreReveal .4s var(--ease-smooth-out, ease-out) 1s both}@media(prefers-reduced-motion:reduce){.player-scoreboard__title,.player-scoreboard__you,.player-scoreboard__entry,.player-scoreboard__countdown{animation:none}}.game-shell{display:flex;flex-direction:column;height:100%;min-height:100dvh;background:#080e3a;color:#fff}.game-shell__header{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#0d1450;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}.game-shell__game-name{font-family:Bangers,cursive;font-size:clamp(16px,2vw,28px);font-weight:400;text-transform:uppercase;line-height:1;font-size:16px;letter-spacing:2px;color:var(--game-accent, #18dcff)}.game-shell__content{flex:1;overflow:auto;position:relative}.game-shell__reactions{flex-shrink:0;display:flex;justify-content:center;padding:8px 16px 12px;background:#0d1450;border-top:1px solid rgba(255,255,255,.06)}.game-shell__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:200px;gap:16px}.game-shell__spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.06);border-top-color:#18dcff;border-radius:999px;animation:game-shell-spin .8s linear infinite}@keyframes game-shell-spin{to{transform:rotate(360deg)}}.game-shell__loading-text{font-family:Nunito,sans-serif;font-size:16px;font-weight:600;letter-spacing:0;line-height:1.6;color:#ffffffb3}.game-shell__error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:200px;gap:16px}.game-shell__error-text{font-family:Nunito,sans-serif;font-size:16px;font-weight:600;letter-spacing:0;line-height:1.6;color:#ffffffb3}@media(prefers-reduced-motion:reduce){.game-shell__spinner{animation-duration:1.6s}}.play--connecting{position:relative;display:flex;justify-content:center;align-items:center;min-height:100vh;min-height:100dvh;background:var(--bg-deep);overflow:hidden}.play__connecting-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.play__spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--accent-cyan);border-radius:50%;animation:spin .8s linear infinite}.play__status{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--text-secondary);margin:0}.play__error{font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--accent-red);margin:0;text-align:center}@keyframes spin{to{transform:rotate(360deg)}}.play__phase-wrapper{position:relative;min-height:100vh;min-height:100dvh;background:var(--bg-deep);overflow:hidden}.play__view-enter{position:relative;z-index:1;animation:viewEnter .4s var(--ease-smooth-out, cubic-bezier(.22, 1, .36, 1)) both}@keyframes viewEnter{0%{opacity:0;transform:translate3d(0,20px,0)}to{opacity:1;transform:translateZ(0)}}@media(prefers-reduced-motion:reduce){.play__view-enter{animation:none}}.host-idle{position:relative;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);gap:var(--space-5);overflow:hidden}.host-idle__emojis{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}.host-idle__emoji{position:absolute;font-size:2.5rem;opacity:.4;animation:emoji-orbit 16s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}@media(prefers-reduced-motion:reduce){.host-idle__emoji{animation:none;opacity:.25}}.host-idle__emoji--0{top:8%;left:10%;animation-delay:0s;animation-duration:14s}.host-idle__emoji--1{top:12%;right:12%;animation-delay:-3s;animation-duration:18s}.host-idle__emoji--2{top:35%;left:5%;animation-delay:-6s;animation-duration:15s}.host-idle__emoji--3{top:40%;right:6%;animation-delay:-9s;animation-duration:20s}.host-idle__emoji--4{bottom:20%;left:8%;animation-delay:-12s;animation-duration:17s}.host-idle__emoji--5{bottom:15%;right:10%;animation-delay:-2s;animation-duration:22s}@keyframes emoji-orbit{0%,to{transform:translate(0) rotate(0) scale(1)}25%{transform:translate(15px,-20px) rotate(8deg) scale(1.1)}50%{transform:translate(-10px,10px) rotate(-5deg) scale(.95)}75%{transform:translate(8px,15px) rotate(3deg) scale(1.05)}}.host-idle__title{position:relative;z-index:1;font-family:var(--font-display);font-size:clamp(60px,8vw,96px);color:var(--accent-yellow);text-transform:uppercase;letter-spacing:6px;text-align:center;line-height:1;margin:0;text-shadow:3px 3px 0 var(--accent-orange),6px 6px 0 var(--accent-red),0 0 40px rgba(255,215,0,.3)}.host-idle__main{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:var(--space-8);width:100%;max-width:1100px}.host-idle__qr-section{flex-shrink:0}.host-idle__info-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-5)}.host-idle__player-count{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.host-idle__count-number{font-family:var(--font-display);font-size:clamp(48px,6vw,80px);color:var(--accent-yellow);line-height:1;text-shadow:2px 2px 0 var(--accent-orange)}.host-idle__count-label{font-family:var(--font-body);font-size:clamp(14px,2vw,20px);font-weight:800;color:var(--text-secondary);letter-spacing:3px;text-transform:uppercase}.host-idle__avatar-wall{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2);max-width:480px}.host-idle__avatar{animation:avatar-pop-in .4s cubic-bezier(.34,1.56,.64,1) both}.host-idle__avatar-overflow{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:#ffffff1a;font-family:var(--font-body);font-size:.875rem;font-weight:800;color:var(--text-secondary)}@keyframes avatar-pop-in{0%{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}.host-idle__leaderboard{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-3);width:100%;max-width:500px}.host-idle__leaderboard-title{font-family:var(--font-display);font-size:clamp(24px,3vw,36px);color:var(--accent-cyan);text-transform:uppercase;letter-spacing:3px;margin:0;text-shadow:1px 1px 0 rgba(0,0,0,.4)}.host-idle__marquee{position:absolute;bottom:0;left:0;right:0;z-index:1;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.host-voting{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);gap:var(--space-6)}.host-voting__title{font-family:var(--font-display);font-size:clamp(60px,8vw,96px);color:var(--accent-cyan);text-transform:uppercase;letter-spacing:6px;margin:0;text-shadow:3px 3px 0 rgba(0,230,255,.4),0 0 40px rgba(0,230,255,.3)}.host-voting__cards{display:flex;gap:var(--space-5);justify-content:center;flex-wrap:wrap;max-width:1100px;width:100%}.host-vote-card{flex:1 1 240px;max-width:280px;display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-5);background:#ffffff0f;border:2px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);transition:transform .3s,box-shadow .3s;contain:layout style paint}.host-vote-card--cooled{opacity:.4;filter:grayscale(.6)}.host-vote-card__header{display:flex;align-items:center;gap:var(--space-3)}.host-vote-card__emoji{font-size:2.5rem;flex-shrink:0}.host-vote-card__name{font-family:var(--font-display);font-size:clamp(24px,3vw,36px);color:var(--text-primary);text-transform:uppercase;letter-spacing:2px;line-height:1.1}.host-vote-card__bar-track{width:100%;height:16px;background:#ffffff14;border-radius:var(--radius-full);overflow:hidden}.host-vote-card__bar-fill{height:100%;background:var(--vote-accent, var(--accent-cyan));border-radius:var(--radius-full);transition:width .5s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 12px color-mix(in srgb,var(--vote-accent, var(--accent-cyan)) 50%,transparent)}.host-vote-card__meta{display:flex;justify-content:space-between;align-items:center}.host-vote-card__votes{font-family:var(--font-display);font-size:clamp(20px,2.5vw,28px);color:var(--vote-accent, var(--accent-cyan));letter-spacing:1px}.host-vote-card__range{font-family:var(--font-body);font-size:.875rem;font-weight:700;color:var(--text-muted)}.host-voting__footer{display:flex;align-items:center;gap:var(--space-6);width:100%;max-width:900px}.host-voting__timer{flex:1}.host-voting__player-count{font-family:var(--font-body);font-size:clamp(16px,2vw,24px);font-weight:800;color:var(--text-secondary);white-space:nowrap}.host-countdown{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);gap:var(--space-6)}.host-countdown__game{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.host-countdown__game-emoji{font-size:clamp(64px,10vw,120px);filter:drop-shadow(0 4px 12px rgba(0,0,0,.4))}.host-countdown__game-title{font-family:var(--font-display);font-size:clamp(48px,7vw,80px);color:var(--accent-yellow);text-transform:uppercase;letter-spacing:4px;text-align:center;margin:0;text-shadow:3px 3px 0 var(--accent-orange),0 0 40px rgba(255,215,0,.4)}.host-countdown__timer{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.host-countdown__label{font-family:var(--font-body);font-size:clamp(18px,2.5vw,28px);font-weight:800;color:var(--text-secondary);letter-spacing:4px;text-transform:uppercase;margin:0}.host-countdown__number{font-family:var(--font-display);font-size:clamp(80px,15vw,160px);color:var(--accent-cyan);line-height:1;text-shadow:0 0 30px rgba(0,230,255,.5),0 0 60px rgba(0,230,255,.2);animation:countdown-pulse 1s ease-in-out infinite}@keyframes countdown-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.host-countdown__joiners{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2);max-width:600px}.host-countdown__joiner{animation:joiner-pop .35s cubic-bezier(.34,1.56,.64,1) both}@keyframes joiner-pop{0%{opacity:0;transform:scale(0) rotate(-10deg)}to{opacity:1;transform:scale(1) rotate(0)}}.host-countdown__progress{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);width:100%;max-width:500px}.host-countdown__progress-bar{width:100%;height:12px;background:#ffffff14;border-radius:var(--radius-full);overflow:hidden}.host-countdown__progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-cyan),var(--accent-green, #00ff88));border-radius:var(--radius-full);transition:width .4s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 12px #00e6ff66}.host-countdown__progress-text{font-family:var(--font-display);font-size:clamp(16px,2vw,24px);color:var(--text-secondary);letter-spacing:2px}.host-scoreboard{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);gap:var(--space-5);position:relative;overflow:hidden}.host-scoreboard__title{font-family:var(--font-display);font-size:clamp(60px,10vw,120px);color:var(--accent-yellow);text-transform:uppercase;letter-spacing:8px;margin:0;text-shadow:4px 4px 0 var(--accent-orange),0 0 40px rgba(255,215,0,.5),0 0 80px rgba(255,215,0,.2);opacity:0}.host-scoreboard__podium{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);width:100%;max-width:800px}.host-scoreboard__podium-row{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);width:100%;opacity:0}.host-scoreboard__podium-row--first{background:linear-gradient(135deg,#ffd70033,#ffa50026);border:2px solid rgba(255,215,0,.4);box-shadow:0 0 30px #ffd70033;transform:scale(1.05)}.host-scoreboard__podium-row--second{background:linear-gradient(135deg,#c0c0c026,#9696961a);border:2px solid rgba(192,192,192,.3)}.host-scoreboard__podium-row--third{background:linear-gradient(135deg,#cd7f3226,#b4641e1a);border:2px solid rgba(205,127,50,.3)}.host-scoreboard__medal{font-size:clamp(36px,5vw,56px);flex-shrink:0}.host-scoreboard__player-info{position:relative;flex-shrink:0}.host-scoreboard__crown{position:absolute;top:-16px;left:50%;transform:translate(-50%);font-size:28px;opacity:0;z-index:1;filter:drop-shadow(0 2px 6px rgba(255,215,0,.6))}.host-scoreboard__name{font-family:var(--font-display);font-size:clamp(24px,4vw,40px);color:var(--text-primary);text-transform:uppercase;letter-spacing:2px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.host-scoreboard__score{font-family:var(--font-display);font-size:clamp(28px,4.5vw,48px);color:var(--accent-cyan);letter-spacing:2px;flex-shrink:0;text-shadow:0 0 20px rgba(0,230,255,.4)}.host-scoreboard__full-list{display:flex;flex-direction:column;gap:var(--space-2);width:100%;max-width:600px;max-height:200px;overflow-y:auto;opacity:0}.host-scoreboard__list-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:#ffffff0a;border-radius:var(--radius-md)}.host-scoreboard__list-rank{font-family:var(--font-display);font-size:clamp(16px,2vw,22px);color:var(--text-secondary);width:36px;text-align:center;flex-shrink:0}.host-scoreboard__list-name{font-family:var(--font-body);font-size:clamp(14px,1.8vw,20px);font-weight:600;color:var(--text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.host-scoreboard__list-score{font-family:var(--font-display);font-size:clamp(14px,1.8vw,20px);color:var(--accent-cyan);flex-shrink:0}.host-scoreboard__countdown{font-family:var(--font-body);font-size:clamp(16px,2vw,24px);font-weight:700;color:var(--text-secondary);letter-spacing:2px;text-transform:uppercase;margin:0}.host-scoreboard__confetti{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;opacity:0;z-index:0}.host-scoreboard__confetti-piece{position:absolute;top:-10px;width:10px;height:10px;border-radius:2px;animation:confetti-fall linear infinite;opacity:.8}.host-scoreboard__confetti-piece:nth-child(5n){background:var(--accent-cyan);width:8px;height:12px}.host-scoreboard__confetti-piece:nth-child(5n+1){background:var(--accent-yellow);width:6px;height:14px}.host-scoreboard__confetti-piece:nth-child(5n+2){background:var(--accent-orange);width:10px;height:8px}.host-scoreboard__confetti-piece:nth-child(5n+3){background:var(--accent-pink, #ff6b9d);width:7px;height:11px}.host-scoreboard__confetti-piece:nth-child(5n+4){background:var(--accent-green, #2ed573);width:9px;height:9px}.host-scoreboard__confetti-piece:nth-child(odd){animation-name:confetti-fall-spin}@keyframes confetti-fall{0%{transform:translateZ(0) rotate(0);opacity:.9}to{transform:translate3d(0,100vh,0) rotate(360deg);opacity:0}}@keyframes confetti-fall-spin{0%{transform:translateZ(0) rotate(0) scale(1);opacity:.9}50%{transform:translate3d(0,50vh,0) rotate(180deg) scale(1.3);opacity:.7}to{transform:translate3d(0,100vh,0) rotate(540deg) scale(.5);opacity:0}}@media(prefers-reduced-motion:reduce){.host-scoreboard__title,.host-scoreboard__podium-row,.host-scoreboard__crown,.host-scoreboard__full-list,.host-scoreboard__confetti{opacity:1!important;transform:none!important}.host-scoreboard__confetti-piece{animation:none}}.reaction-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:50;overflow:hidden}.reaction-overlay__bubble{position:absolute;bottom:10%;animation:reaction-float 3s ease-out forwards}@media(prefers-reduced-motion:reduce){.reaction-overlay__bubble{animation-duration:.5s}}@keyframes reaction-float{0%{opacity:1;transform:translateY(0) translate(0) scale(1)}70%{opacity:.8;transform:translateY(-50vh) translate(calc((var(--drift, 0) - .5) * 60px)) scale(1.1)}to{opacity:0;transform:translateY(-70vh) translate(calc((var(--drift, 0) - .5) * 80px)) scale(.8)}}.host{position:relative;width:100vw;height:100vh;overflow:hidden;background:var(--bg-deep)}.host--gate{display:flex;justify-content:center;align-items:center}.host__gate-card{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-5);padding:var(--space-8);background:#ffffff0f;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.host__gate-title{font-family:var(--font-display);font-size:2.5rem;color:var(--accent-cyan);text-transform:uppercase;letter-spacing:4px;margin:0;text-shadow:2px 2px 0 rgba(0,0,0,.4)}.host__gate-input{width:280px;padding:var(--space-3) var(--space-4);font-family:var(--font-body);font-size:1rem;font-weight:600;color:var(--text-primary);background:var(--bg-navy);border:2px solid rgba(255,255,255,.12);border-radius:var(--radius-md);outline:none;transition:border-color .2s}.host__gate-input:focus{border-color:var(--accent-cyan);box-shadow:0 0 0 3px #00e6ff26}.host__gate-input::placeholder{color:var(--text-muted);font-weight:400}.host__gate-btn{padding:var(--space-3) var(--space-6);font-family:var(--font-display);font-size:1.25rem;letter-spacing:2px;color:var(--bg-deep);background:var(--accent-cyan);border:none;border-radius:var(--radius-md);cursor:pointer;transition:transform .15s,box-shadow .15s}.host__gate-btn:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00e6ff4d}.host__gate-btn:active{transform:translateY(0)}.host__gate-error{font-family:var(--font-body);font-size:.875rem;font-weight:600;color:var(--accent-red);margin:0}.host--connecting{display:flex;justify-content:center;align-items:center}.host__connecting-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:var(--space-4)}.host__spinner{width:48px;height:48px;border:3px solid rgba(255,255,255,.15);border-top-color:var(--accent-cyan);border-radius:50%;animation:host-spin .8s linear infinite}.host__status{font-family:var(--font-body);font-size:1.25rem;font-weight:600;color:var(--text-secondary);margin:0}.host__error{font-family:var(--font-body);font-size:1.25rem;font-weight:600;color:var(--accent-red);margin:0}.host__views{position:relative;z-index:1;width:100%;height:100%;display:flex;justify-content:center;align-items:center}.host__transitioning{display:flex;justify-content:center;align-items:center;width:100%;height:100%}.host__transitioning-text{font-family:var(--font-display);font-size:clamp(36px,6vw,72px);color:var(--accent-yellow);text-transform:uppercase;letter-spacing:4px;margin:0;text-shadow:2px 2px 0 rgba(0,0,0,.4);animation:host-pulse 1s ease-in-out infinite}@keyframes host-pulse{0%,to{opacity:1}50%{opacity:.5}}.host__fullscreen-btn{position:fixed;bottom:var(--space-4);right:var(--space-4);z-index:100;width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--text-secondary);background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-md);cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:.5;transition:opacity .2s}.host__fullscreen-btn:hover{opacity:1}@keyframes host-spin{to{transform:rotate(360deg)}}@keyframes heroIn{0%{opacity:0;transform:translate3d(0,40px,0) scale(.95)}to{opacity:1;transform:translateZ(0) scale(1)}}@keyframes popIn{0%{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}@keyframes emojiFloat{0%,to{transform:translateZ(0) rotate(0)}25%{transform:translate3d(0,-15px,0) rotate(5deg)}75%{transform:translate3d(0,10px,0) rotate(-3deg)}}@keyframes btnShine{0%,to{transform:translate3d(-100%,0,0)}50%{transform:translate3d(350%,0,0)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}@keyframes bounce{0%,to{transform:translateZ(0)}50%{transform:translate3d(0,-16px,0)}}@keyframes particleFloat{0%{transform:translateZ(0);opacity:0}10%{opacity:.6}90%{opacity:.6}to{transform:translate3d(40px,-105vh,0);opacity:0}}@keyframes marqueeScroll{0%{transform:translateZ(0)}to{transform:translate3d(-50%,0,0)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-deep: #080e3a;--bg-primary: #0d1450;--bg-card: #151d6b;--bg-card-hover: #1c2580;--bg-surface: #1a2278;--accent-yellow: #ffd43b;--accent-orange: #ff8c42;--accent-red: #ff4757;--accent-pink: #ff6b9d;--accent-green: #2ed573;--accent-cyan: #18dcff;--accent-purple: #a855f7;--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--text-muted: rgba(255, 255, 255, .4);--glass-bg: rgba(255, 255, 255, .06);--border-subtle: rgba(255, 255, 255, .06);--gradient-fire: linear-gradient(135deg, #ff4757, #ff8c42, #ffd43b);--gradient-party: linear-gradient(135deg, #ff6b9d, #a855f7, #18dcff);--gradient-success: linear-gradient(135deg, #2ed573, #18dcff);--gradient-btn-primary: linear-gradient(180deg, #ff8c42, #ff4757);--gradient-btn-play: linear-gradient(180deg, #2ed573, #10b981);--gradient-btn-secondary: linear-gradient(180deg, #a855f7, #7c3aed);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--radius-sm: 8px;--radius-md: 14px;--radius-lg: 20px;--radius-xl: 28px;--radius-full: 999px;--radius-pill: 999px;--font-display: "Bangers", cursive;--font-body: "Nunito", sans-serif;--ease-smooth-out: cubic-bezier(.22, 1, .36, 1);--ease-overshoot: cubic-bezier(.34, 1.56, .64, 1);--ease-linear: linear;--ease-in-out: ease-in-out;--ease-out: ease-out}
