@font-face{font-family:Patrick Hand;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/PatrickHand-Regular.woff2) format("woff2")}@font-face{font-family:Gaegu;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/Gaegu-Regular.woff2) format("woff2")}@font-face{font-family:Gaegu;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/Gaegu-Bold.woff2) format("woff2")}:root{--pink: #E8273A;--purple: #7B2D8E;--blue: #1A6DD4;--cyan: #0E9AA7;--green: #2D8E3C;--yellow: #F5C518;--orange: #E87D1E;--red: #D42B2B;--bg-dark: #FDF6E3;--bg-card: #FFFDF7;--border: #2B2B2B;--border-light: rgba(43,43,43,.15);--text: #2B2B2B;--text-dim: rgba(43,43,43,.55);--grid-line: rgba(26,109,212,.18);--grid-line-red: rgba(232,39,58,.25);--radius: 6px;--radius-sm: 4px;--shadow: 2px 3px 0px #2B2B2B;--border-width: 2.5px;--font: "Patrick Hand", "Comic Sans MS", cursive;--font-heading: "Gaegu", "Patrick Hand", "Comic Sans MS", cursive}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;font-family:var(--font);background:var(--bg-dark);color:var(--text);overflow:hidden;-webkit-user-select:none;user-select:none}body{position:relative}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background:linear-gradient(90deg,transparent 79px,var(--grid-line-red) 79px,var(--grid-line-red) 81px,transparent 81px),repeating-linear-gradient(180deg,transparent,transparent 27px,var(--grid-line) 31px,var(--grid-line) 32px),repeating-linear-gradient(90deg,transparent,transparent 27px,rgba(26,109,212,.08) 31px,rgba(26,109,212,.08) 32px),var(--bg-dark)}.screen{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .35s ease,transform .35s ease;transform:translateY(12px);overflow-y:auto}.screen.active{opacity:1;pointer-events:all;transform:translateY(0)}.screen.active>*{animation:slideUpFadeIn .45s ease backwards}.screen.active>*:nth-child(1){animation-delay:.04s}.screen.active>*:nth-child(2){animation-delay:.1s}.screen.active>*:nth-child(3){animation-delay:.18s}.screen.active>*:nth-child(4){animation-delay:.26s}.screen.active>*:nth-child(5){animation-delay:.34s}.screen.active>*:nth-child(6){animation-delay:.4s}.screen.active>*:nth-child(7){animation-delay:.46s}.screen.active>*:nth-child(8){animation-delay:.52s}h1{font-family:var(--font-heading);font-size:clamp(2.6rem,6vw,4.5rem);font-weight:700;letter-spacing:1px;line-height:1;color:var(--text);text-shadow:2px 2px 0px var(--blue),-1px -1px 0px var(--pink)}h2{font-family:var(--font-heading);font-size:clamp(1.4rem,3vw,2rem);font-weight:700;color:var(--text)}h3{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:2px}p{color:var(--text-dim);font-size:1rem;line-height:1.6}.tagline{font-size:clamp(1rem,2vw,1.3rem);color:var(--text-dim);margin-top:8px;font-weight:400}.game-logo{max-width:480px;width:90%;height:auto;filter:drop-shadow(3px 3px 0px rgba(43,43,43,.3));flex-shrink:0}@media(max-height:700px){.game-logo{max-width:340px;width:80%}}@media(max-height:500px){.game-logo{max-width:260px;width:70%}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUpFadeIn{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes wobble{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}@keyframes timerPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes timerGlow{0%,to{box-shadow:0 0 #d42b2b00}50%{box-shadow:0 0 20px 4px #d42b2b66}}.card{background:var(--bg-card);border:var(--border-width) solid var(--border);border-radius:var(--radius);padding:28px 32px;box-shadow:var(--shadow);width:100%;max-width:560px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;font-family:var(--font);font-size:1.05rem;font-weight:700;border:var(--border-width) solid var(--border);border-radius:var(--radius);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease;letter-spacing:.5px;position:relative;overflow:hidden}.btn:after{display:none}.btn:hover{transform:translate(-2px,-2px);box-shadow:4px 5px 0 var(--border)}.btn:active{transform:translate(2px,2px);box-shadow:0 1px 0 var(--border)}.btn-primary{background:var(--pink);color:#fff;box-shadow:3px 3px 0 var(--border)}.btn-secondary{background:var(--blue);color:#fff;box-shadow:3px 3px 0 var(--border)}.btn-success{background:var(--green);color:#fff;box-shadow:3px 3px 0 var(--border)}.btn-danger{background:var(--red);color:#fff;box-shadow:3px 3px 0 var(--border)}.btn-ghost{background:var(--bg-card);border:var(--border-width) solid var(--border);color:var(--text);box-shadow:2px 2px 0 var(--border)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important;box-shadow:2px 2px #2b2b2b4d!important}input[type=text],textarea{width:100%;padding:14px 18px;background:#fff;border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:1rem;font-weight:400;outline:none;transition:border-color .2s ease,box-shadow .2s ease;resize:none}input[type=text]:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #1a6dd433}input::placeholder,textarea::placeholder{color:var(--text-dim)}.player-list{display:flex;flex-direction:column;gap:10px;margin:12px 0}.player-entry{display:flex;align-items:center;gap:10px}.player-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}.player-name{flex:1;font-weight:700;font-size:1rem}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:8px 0;border-top:2px solid var(--border-light);margin-top:8px}.settings-row label{font-weight:700;font-size:.9rem;color:var(--text-dim)}.settings-row input[type=range]{width:130px;accent-color:var(--blue);background:none;border:none;padding:0;box-shadow:none}.settings-row .range-val,.range-val{min-width:36px;text-align:right;font-weight:700;color:var(--blue)}.avatar-picker{margin-top:12px;padding:16px;background:#2b2b2b08;border:2px solid var(--border);border-radius:var(--radius)}.avatar-picker h4{font-family:var(--font-heading);font-size:.85rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim);margin-bottom:10px}.emoji-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:14px}.emoji-option{width:100%;aspect-ratio:1;border:2px solid var(--border);border-radius:var(--radius-sm);background:#fff;font-size:1.6rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,border-color .15s,opacity .15s}.emoji-option:hover{transform:scale(1.1);border-color:var(--blue);animation:wobble .5s ease}.emoji-option.selected{border-color:var(--blue);background:#1a6dd41a;transform:scale(1.1);box-shadow:0 0 8px #1a6dd44d}.emoji-option.taken{opacity:.25;pointer-events:none}.color-grid{display:flex;gap:6px;flex-wrap:wrap}.color-option{width:30px;height:30px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s,opacity .15s}.color-option:hover{transform:scale(1.15)}.color-option.selected{border-color:var(--text);transform:scale(1.15)}.color-option.taken{opacity:.25;pointer-events:none}.avatar-confirm-row{display:flex;gap:10px;margin-top:12px;align-items:center}.avatar-preview{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0;border:2px solid var(--border);overflow:hidden}.avatar-svg{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-svg svg{width:100%;height:100%}.score-player-cell{display:flex;align-items:center;gap:6px}.chain-title .avatar-svg{vertical-align:middle}.award-winner{display:flex;align-items:center;gap:6px}#screen-prompt{gap:22px}#screen-prompt .card{max-width:580px}#prompt-instruction{font-size:1rem;color:var(--text-dim);margin-bottom:6px}#prompt-input{font-size:1.1rem;min-height:90px}#prompt-charcount{text-align:right;font-size:.8rem;color:var(--text-dim);margin-top:4px}#screen-draw{gap:14px;padding:16px}.draw-header{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:860px}.draw-prompt-box{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius);padding:10px 20px;font-weight:700;font-size:1.1rem;flex:1;text-align:center;box-shadow:2px 2px 0 var(--border)}.draw-prompt-label{font-family:var(--font-heading);font-size:.75rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--blue)}.timer-ring{width:56px;height:56px;position:relative;flex-shrink:0}.timer-ring svg{transform:rotate(-90deg)}.timer-ring circle.bg{fill:none;stroke:var(--border-light);stroke-width:4}.timer-ring circle.fg{fill:none;stroke:var(--green);stroke-width:4;stroke-linecap:round;stroke-dasharray:138;stroke-dashoffset:0;transition:stroke-dashoffset 1s linear,stroke .5s}.timer-ring .timer-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:var(--text)}.timer-ring.timer-warning{animation:timerPulse 1s ease-in-out infinite}.timer-ring.timer-critical{animation:timerPulse .5s ease-in-out infinite,timerGlow 1s ease-in-out infinite}#canvas-wrap{position:relative;background:#fff;border-radius:var(--radius);border:3px solid var(--border);box-shadow:4px 4px 0 var(--border);overflow:hidden;cursor:crosshair}#draw-canvas{display:block}.draw-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;max-width:860px;justify-content:center}.color-swatch{width:30px;height:30px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .15s,border-color .15s}.color-swatch:hover{transform:scale(1.2)}.color-swatch.active{border-color:var(--text);transform:scale(1.15)}.tool-btn{background:#fff;border:2px solid var(--border);color:var(--text);border-radius:var(--radius);padding:7px 13px;font-size:.85rem;font-family:var(--font);font-weight:700;cursor:pointer;transition:background .15s,transform .1s;box-shadow:2px 2px 0 var(--border)}.tool-btn:hover{background:#1a6dd414;transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--border)}.tool-btn.active{background:var(--blue);border-color:var(--border);color:#fff}.brush-size-wrap{display:flex;align-items:center;gap:8px;font-size:.85rem;font-weight:700;color:var(--text-dim)}.brush-size-wrap input[type=range]{width:80px;accent-color:var(--blue);background:none;border:none;padding:0;box-shadow:none}#color-picker-input{width:34px;height:34px;border:2px solid var(--border);border-radius:50%;cursor:pointer;padding:0;background:none;overflow:hidden}#screen-describe{gap:20px}#screen-describe .card{max-width:640px}#describe-image-wrap{width:100%;border-radius:var(--radius);overflow:hidden;border:2px solid var(--border);background:#fff;margin-bottom:10px}#describe-image{width:100%;display:block}#describe-input{font-size:1.05rem;min-height:70px}#screen-reveal{overflow-y:auto;justify-content:flex-start;padding:30px 20px;gap:20px}.reveal-header{text-align:center;margin-bottom:10px}.reveal-header h2{font-size:2.2rem}.chain-container{display:flex;flex-direction:column;gap:30px;width:100%;max-width:700px}.chain-block{opacity:0;animation:fadeSlideIn .5s ease forwards}.chain-title{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--orange);margin-bottom:12px;letter-spacing:1px;text-transform:uppercase}.chain-cards{display:flex;gap:12px;flex-wrap:wrap}.chain-card-wrap{perspective:900px}.chain-card{width:160px;border-radius:var(--radius);transform-style:preserve-3d;transform:rotateY(180deg);transition:transform .6s cubic-bezier(.34,1.56,.64,1);position:relative;min-height:160px}.chain-card.flipped{transform:rotateY(0)}.chain-card-front,.chain-card-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;padding:12px}.chain-card-back{background:var(--yellow);border:2px solid var(--border);box-shadow:2px 2px 0 var(--border);transform:rotateY(180deg);font-size:2.5rem}.chain-card-front{background:var(--bg-card);border:2px solid var(--border);box-shadow:2px 2px 0 var(--border);flex-direction:column;gap:6px;text-align:center}.chain-card-front .card-type{font-family:var(--font-heading);font-size:.7rem;font-weight:700;letter-spacing:2px;text-transform:uppercase}.chain-card-front .card-type.type-write{color:var(--blue)}.chain-card-front .card-type.type-draw{color:var(--pink)}.chain-card-front .card-type.type-guess{color:var(--green)}.chain-card-front .card-author{font-size:.7rem;color:var(--text-dim);font-weight:700}.chain-card-front .card-content-text{font-size:.85rem;font-weight:700;color:var(--text);line-height:1.3}.chain-card-front .card-content-image{width:100%;border-radius:var(--radius-sm);border:1px solid var(--border-light)}.reveal-nav{display:flex;gap:12px;margin-top:10px}#screen-vote{gap:20px;overflow-y:auto;justify-content:flex-start;padding:30px 20px}.vote-card{max-width:640px}.vote-section{margin-bottom:22px}.vote-section h3{font-family:var(--font-heading);font-size:.85rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:10px}.vote-section.funniest-draw h3{color:var(--pink)}.vote-section.most-accurate h3{color:var(--blue)}.vote-section.funniest-desc h3{color:var(--green)}.vote-options{display:flex;flex-direction:column;gap:10px}.vote-opt{display:flex;align-items:center;gap:12px;padding:8px 12px;text-align:left;width:100%;border-radius:var(--radius);border:2px solid var(--border);background:#fff;color:var(--text);font-family:var(--font);font-weight:700;font-size:.9rem;cursor:pointer;transition:all .2s ease;box-shadow:2px 2px 0 var(--border)}.vote-opt-thumb-wrap{flex-shrink:0;width:72px;height:72px;border:2px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;background:#fff;cursor:zoom-in;pointer-events:auto;transition:transform .15s,box-shadow .15s}.vote-opt-thumb-wrap:hover{transform:scale(1.04);box-shadow:3px 3px 0 var(--border)}.vote-opt-thumb-wrap img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.vote-opt-body{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.vote-opt-desc-text{font-size:.9rem;font-weight:700;color:var(--text);line-height:1.35;word-break:break-word}.vote-opt-author{font-size:.8rem;color:var(--text-dim);font-weight:700}.vote-opt:hover{border-color:var(--blue);background:#1a6dd40f;transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--border)}.vote-opt.selected-pink{border-color:var(--pink);background:#e8273a1f;transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--border)}.vote-opt.selected-cyan{border-color:var(--blue);background:#1a6dd41f;transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--border)}.vote-opt.selected-green{border-color:var(--green);background:#2d8e3c1f;transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--border)}.vote-opt.self-lock{opacity:.35;cursor:not-allowed}.vote-opt.self-lock .vote-opt-body{pointer-events:none}.vote-progress{font-size:.85rem;color:var(--text-dim);text-align:center;font-weight:700}#vote-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9998;background:#2b2b2bd1;display:flex;align-items:center;justify-content:center;padding:24px;cursor:pointer}#vote-lightbox.hidden{display:none}#vote-lightbox img{max-width:min(90vw,680px);max-height:80dvh;border:3px solid var(--border);border-radius:var(--radius);box-shadow:6px 6px 0 var(--border);object-fit:contain;cursor:default;background:#fff}#vote-lightbox-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;border:2.5px solid var(--border);background:var(--bg-card);color:var(--text);font-size:1.2rem;font-family:var(--font);font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:2px 2px 0 var(--border);transition:transform .15s}#vote-lightbox-close:hover{transform:scale(1.1)}@media(max-width:480px){.vote-opt-thumb-wrap{width:54px;height:54px}}#screen-score{gap:24px;overflow-y:auto;justify-content:flex-start;padding:40px 20px}.score-header{text-align:center}.score-header h2{font-size:2.4rem}.score-table{width:100%;max-width:580px;border-collapse:collapse}.score-table th{font-family:var(--font-heading);font-size:.75rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);padding:8px 12px;text-align:left;border-bottom:2px solid var(--border)}.score-table td{padding:12px;font-weight:700;font-size:1rem;border-bottom:1px solid var(--border-light)}.score-table tr.rank-1 td{color:var(--orange);font-size:1.1rem}.score-table tr.rank-2 td{color:var(--text)}.score-table tr.rank-3 td{color:var(--blue)}.score-medal{font-size:1.4rem;margin-right:6px}.award-list{width:100%;max-width:580px;display:flex;flex-direction:column;gap:10px}.award-item{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius);padding:12px 18px;display:flex;align-items:center;gap:12px;box-shadow:2px 2px 0 var(--border)}.award-emoji{font-size:1.5rem}.award-info .award-title{font-family:var(--font-heading);font-size:.75rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim)}.award-info .award-winner{font-size:1rem;font-weight:700;color:var(--text)}#confetti-canvas{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999}.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.flex{display:flex}.flex-col{flex-direction:column}.center{align-items:center;justify-content:center}.w-full{width:100%}.text-center{text-align:center}.full-width{max-width:100%!important}.mode-select{padding:8px 14px;font-family:var(--font);font-size:.95rem;font-weight:700;border:2px solid var(--border);border-radius:var(--radius);background:#fff;color:var(--text);cursor:pointer;outline:none;box-shadow:2px 2px 0 var(--border);transition:border-color .2s}.mode-select:focus{border-color:var(--blue)}.mode-desc{font-size:.85rem;color:var(--text-dim);font-weight:700;padding:4px 0;font-style:italic}.chaos-card-banner{background:var(--yellow);border:2.5px solid var(--border);border-radius:var(--radius);padding:8px 20px;text-align:center;box-shadow:3px 3px 0 var(--border);max-width:860px;width:100%;animation:slideUpFadeIn .4s ease}.chaos-card-banner #chaos-card-label{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--text);display:block;letter-spacing:1px;text-transform:uppercase}.chaos-card-banner #chaos-card-desc{font-size:.85rem;color:var(--text-dim);font-weight:700}#canvas-wrap.blind-draw #draw-canvas{opacity:0}.vote-section.imposter-vote h3{color:var(--orange)}.vote-opt.selected-orange{border-color:var(--orange);background:#e87d1e1f;transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--border)}.imposter-reveal{background:#e87d1e1a!important;border-color:var(--orange)!important}.imposter-reveal .award-title{color:var(--orange)!important}.speed-timer{display:inline-flex}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#1a6dd459;border-radius:10px}html,body{height:100dvh}*{touch-action:manipulation}.screen{padding:16px;padding-top:max(16px,env(safe-area-inset-top));padding-bottom:max(16px,env(safe-area-inset-bottom));padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.card{padding:20px;max-width:100%}.btn{min-height:48px;padding:12px 24px}.tool-btn{min-height:40px;padding:8px 12px}.emoji-grid{grid-template-columns:repeat(6,1fr);gap:4px}.chain-card{width:120px;min-height:120px}.chain-card-front .card-content-text{font-size:.75rem}.draw-toolbar{gap:6px;padding:0 8px}.score-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.color-swatch{width:26px;height:26px}.player-avatar{width:40px;height:40px;overflow:hidden}@media(min-width:640px){.screen{padding:24px}.card{padding:28px 32px;max-width:560px}.chain-card{width:140px;min-height:140px}.emoji-grid{grid-template-columns:repeat(4,1fr);gap:6px}.color-swatch{width:30px;height:30px}.draw-toolbar{gap:10px}}@media(min-width:1024px){.card{max-width:640px}.chain-card{width:160px;min-height:160px}.chain-card-front .card-content-text{font-size:.85rem}.score-table{display:table;overflow-x:visible}}@media(max-height:500px){.screen{padding:10px}h1{font-size:clamp(1.8rem,5vw,3rem)}.card{padding:14px 18px}.draw-header{margin-bottom:4px}.draw-toolbar{gap:4px}}.player-avatar{position:relative}.avatar-frame{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;pointer-events:none;z-index:1}.frame-star{box-shadow:0 0 8px 2px #f5c518,0 0 16px 4px #f5c5184d;border:2px solid #F5C518}.frame-heart{box-shadow:0 0 8px 2px #e8273a,0 0 16px 4px #e8273a4d;border:2px solid #E8273A}.frame-crown{box-shadow:0 0 10px 3px gold,0 0 20px 6px #ffd70066;border:2.5px solid #FFD700}.frame-flames{box-shadow:0 0 10px 3px #e87d1e,0 0 20px 6px #e87d1e66;border:2.5px solid #E87D1E}.frame-sparkle{border:2.5px solid #A78BFA;box-shadow:0 0 8px 2px #a78bfa,0 0 16px 4px #a78bfa4d;animation:sparkle-pulse 2s ease-in-out infinite}@keyframes sparkle-pulse{0%,to{box-shadow:0 0 8px 2px #a78bfa,0 0 16px 4px #a78bfa4d}50%{box-shadow:0 0 12px 4px #a78bfa,0 0 24px 8px #a78bfa80}}.unlock-toast{position:fixed;bottom:20px;left:50%;transform:translate(-50%) translateY(100px);background:var(--bg-card);border:2.5px solid var(--yellow);box-shadow:3px 3px 0 var(--border);border-radius:var(--radius);padding:10px 20px;font-family:var(--font);font-size:.95rem;z-index:9999;opacity:0;transition:transform .3s ease,opacity .3s ease}.unlock-toast.show{transform:translate(-50%) translateY(0);opacity:1}.shop-tabs{display:flex;gap:4px;margin-bottom:12px;border-bottom:2px solid var(--border-light);padding-bottom:0}.shop-tab{flex:1;padding:8px 4px;border:none;background:none;font-family:var(--font);font-size:.9rem;cursor:pointer;color:var(--text-dim);border-bottom:3px solid transparent;transition:color .15s,border-color .15s}.shop-tab:hover{color:var(--text)}.shop-tab.active{color:var(--blue);border-bottom-color:var(--blue);font-weight:700}.shop-panel{min-height:200px}.shop-stats{display:flex;gap:16px;justify-content:center;font-family:var(--font);font-size:.85rem;color:var(--text-dim)}.shop-stat{display:flex;align-items:center;gap:4px}.shop-stat strong{color:var(--text);font-size:1rem}.cosmetic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.cosmetic-item{border:2px solid var(--border-light);border-radius:var(--radius);padding:10px 6px;text-align:center;cursor:pointer;font-family:var(--font);transition:border-color .15s,transform .15s;background:var(--bg-card);position:relative}.cosmetic-item:hover{border-color:var(--blue);transform:translateY(-2px)}.cosmetic-item.equipped{border-color:var(--blue);background:#1a6dd414}.cosmetic-item.locked{opacity:.5;cursor:default}.cosmetic-item.locked:hover{border-color:var(--border-light);transform:none}.cosmetic-preview{width:40px;height:40px;margin:0 auto 6px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem}.cosmetic-name{font-size:.8rem;font-weight:700}.cosmetic-desc{font-size:.7rem;color:var(--text-dim);margin-top:2px}.cosmetic-badge{position:absolute;top:-6px;right:-6px;background:var(--yellow);color:var(--text);border:2px solid var(--border);border-radius:10px;font-size:.6rem;font-weight:700;padding:1px 6px;font-family:var(--font)}.cosmetic-badge.premium{background:var(--blue);color:#fff}.milestone-bar{width:100%;height:6px;background:var(--border-light);border-radius:3px;overflow:hidden;margin-top:4px}.milestone-fill{height:100%;background:var(--blue);border-radius:3px;transition:width .3s ease}#screen-landing{gap:16px;justify-content:flex-start;padding-top:max(12px,env(safe-area-inset-top));overflow-y:auto}.divider{display:flex;align-items:center;gap:10px;margin:14px 0;color:var(--text-dim);font-size:.8rem;font-weight:700;letter-spacing:1px}.divider:before,.divider:after{content:"";flex:1;height:2px;background:var(--border)}.error-msg{background:#d42b2b14;border:2px solid var(--red);border-radius:var(--radius);padding:10px 14px;font-size:.9rem;color:var(--red);font-weight:700;margin-bottom:12px}#screen-lobby{gap:20px}.code-pill{display:inline-block;background:var(--yellow);color:var(--text);padding:6px 18px;border-radius:var(--radius);border:var(--border-width) solid var(--border);font-size:1.6rem;font-weight:700;letter-spacing:5px;box-shadow:3px 3px 0 var(--border)}.player-entry{padding:10px 14px;background:#2b2b2b08;border-radius:var(--radius);border:2px solid var(--border);gap:12px}.player-name-wrap{flex:1}.player-name{font-weight:700;font-size:.95rem}.player-tag{font-family:var(--font-heading);font-size:.7rem;color:var(--text-dim);font-weight:700;letter-spacing:1px;text-transform:uppercase}.online-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 6px var(--green)}.offline-dot{width:8px;height:8px;border-radius:50%;background:var(--text-dim)}.waiting-dots{display:flex;gap:6px;justify-content:center}.waiting-dots span{width:10px;height:10px;border-radius:50%;background:var(--red);animation:dotPulse 1.2s ease-in-out infinite}.waiting-dots span:nth-child(2){animation-delay:.2s;background:var(--blue)}.waiting-dots span:nth-child(3){animation-delay:.4s;background:var(--yellow)}@keyframes dotPulse{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}#screen-waiting{gap:16px}.wait-bar-wrap{width:100%;max-width:320px;height:8px;background:var(--border-light);border-radius:var(--radius);border:1.5px solid var(--border);overflow:hidden}.wait-bar{height:100%;border-radius:var(--radius);background:var(--blue);transition:width .4s ease;width:0%}.award-list{margin-top:16px}.mute-btn{position:fixed;top:16px;right:16px;z-index:1000;width:44px;height:44px;border-radius:var(--radius);border:2px solid var(--border);background:var(--bg-card);color:var(--text);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:2px 2px 0 var(--border);transition:transform .15s,background .15s}.mute-btn:hover{transform:translate(-1px,-1px);box-shadow:3px 3px 0 var(--border);background:#1a6dd414}@media(max-height:650px){#screen-landing{gap:8px}.divider{margin:6px 0}}
