.tutorial-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:9999;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .3s ease-out}.tutorial-card{background:#fff;width:90%;max-width:360px;border-radius:20px;padding:30px 20px;position:relative;text-align:center;box-shadow:0 10px 30px #0003;transform:translateY(20px);animation:slideUp .3s ease-out forwards}.close-btn{position:absolute;top:10px;right:15px;background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:5px;z-index:10}.tutorial-image{font-size:60px;margin-bottom:20px;display:inline-block;animation:bounce 2s infinite}.tutorial-content h2{font-size:24px;color:#333;margin-bottom:10px}.tutorial-content p{font-size:16px;color:#666;line-height:1.5;margin-bottom:30px;white-space:pre-wrap}.tutorial-footer{display:flex;justify-content:space-between;align-items:center;margin-top:20px}.dots{display:flex;gap:8px}.dot{width:8px;height:8px;border-radius:50%;background:#eee;transition:all .3s}.dot.active{background:#9d7bff;width:20px;border-radius:4px}.next-btn{background:#9d7bff;color:#fff;border:none;padding:10px 24px;border-radius:20px;font-weight:700;font-size:16px;cursor:pointer;transition:transform .1s}.next-btn:active{transform:scale(.95)}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}@media (max-width: 480px){.tutorial-card{padding:24px 16px;border-radius:16px}.tutorial-image{font-size:48px;margin-bottom:14px}.tutorial-content h2{font-size:20px}.tutorial-content p{font-size:14px;margin-bottom:20px}.next-btn{padding:9px 20px;font-size:15px}}@media (max-height: 600px) and (orientation: landscape){.tutorial-card{padding:14px 20px;max-width:600px;width:90%;display:flex;align-items:center;gap:20px;text-align:left}.tutorial-image{font-size:40px;margin-bottom:0;flex-shrink:0}.tutorial-content{flex:1}.tutorial-content h2{font-size:18px;margin-bottom:8px}.tutorial-content p{font-size:13px;margin-bottom:14px}.tutorial-footer{margin-top:10px}.next-btn{padding:8px 18px;font-size:14px}}.tutorial-animation-container{width:100%;height:220px;display:flex;justify-content:center;align-items:center;background:#f8f9fa;border-radius:16px;margin-bottom:24px;position:relative;overflow:hidden;isolation:isolate}.mini-board{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:15px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;position:relative}.mini-tile{width:45px;height:45px;background:#eee;border-radius:10px;display:flex;justify-content:center;align-items:center;font-size:18px;font-weight:700;color:#444;-webkit-user-select:none;user-select:none;box-shadow:0 2px 4px #0000000d}.mini-tile.target{background-color:#ffe0b2}.mini-tile[data-value="1"]{background:#ff9aa2;color:#fff}.mini-tile[data-value="2"]{background:#ffb7b2;color:#fff}.mini-tile[data-value="3"]{background:#ffdac1;color:#555}.mini-tile[data-value="4"]{background:#e2f0cb;color:#555}.mini-tile[data-value="5"]{background:#b5ead7;color:#555}.mini-tile[data-value="6"]{background:#c7ceea;color:#fff}.mini-tile[data-value="7"]{background:#91a8e0;color:#fff}.mini-tile[data-value="8"]{background:#e0bbe4;color:#fff}.mini-tile[data-value="9"]{background:#957dad;color:#fff}.drag-selection-box{position:absolute;background:#ffb54733;border:2px solid #FFB547;pointer-events:none;z-index:15;box-sizing:border-box;border-radius:4px}.hand-cursor{position:absolute;font-size:36px;pointer-events:none;z-index:20;filter:drop-shadow(2px 4px 6px rgba(0,0,0,.2));top:0;left:0}.connection-line-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}.score-popup{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:36px;font-weight:900;color:gold;text-shadow:2px 2px 0 #333,0 0 10px rgba(255,215,0,.5);z-index:30;pointer-events:none}.bottom-sheet-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:2000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.bottom-sheet-panel{position:fixed;bottom:0;left:0;width:100%;max-height:90vh;background:#fff;border-top-left-radius:24px;border-top-right-radius:24px;box-shadow:0 -4px 20px #00000026;z-index:2001;padding:12px 20px 40px;display:flex;flex-direction:column;touch-action:none}.bottom-sheet-handle-container{width:100%;display:flex;justify-content:center;padding-bottom:16px;cursor:grab}.bottom-sheet-handle-container:active{cursor:grabbing}.bottom-sheet-handle{width:40px;height:5px;background-color:#d5cec2;border-radius:4px}.bottom-sheet-title{text-align:center;font-size:20px;font-weight:700;color:#1e1e22;margin-bottom:20px}.bottom-sheet-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;touch-action:pan-y}.language-switcher{position:relative}.lang-switch-button{width:40px;height:40px;border:none;background:#9d7bff1a;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:#9d7bff}.lang-switch-button:hover{background:#9d7bff33;transform:scale(1.05)}.lang-switch-button:active{transform:scale(.95)}.lang-icon{font-size:20px}.lang-switch-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;padding:6px;min-width:150px;z-index:1000;animation:langMenuFadeIn .15s ease}@keyframes langMenuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.lang-switch-option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:transparent;border-radius:6px;cursor:pointer;transition:background .2s ease;font-size:14px;color:#3a2d60}.lang-switch-option:hover{background:#9d7bff1a}.lang-switch-option.active{background:#9d7bff26;font-weight:600}.lang-code-badge{font-size:11px;font-weight:700;letter-spacing:.04em;font-family:monospace;flex-shrink:0}.lang-switch-button .lang-code-badge{font-size:13px;color:#9d7bff}.lang-switch-menu .lang-code-badge,.lang-sheet-content .lang-code-badge{min-width:24px;text-align:center;color:#9d7bff}.lang-switch-name{flex:1;text-align:left}.lang-switch-check{font-size:14px;color:#9d7bff;font-weight:700}@media (max-width: 480px){.lang-switch-button{width:36px;height:36px}.lang-icon{font-size:18px}.lang-switch-option{padding:9px 10px;font-size:13px}.lang-code-badge{font-size:10px}}@media (max-height: 500px){.lang-switch-menu{max-height:200px;overflow-y:auto}}.volume-control{position:relative;display:inline-flex;align-items:center}.volume-widget{display:flex;align-items:center;background:var(--surface-card);border:2px solid var(--border-medium);border-radius:10px;overflow:hidden;transition:all .2s ease}.volume-widget:hover{border-color:var(--border-strong)}.volume-control.muted .volume-widget{opacity:.65}.volume-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:32px;padding:0;background:transparent;border:none;cursor:pointer;font-size:15px;color:var(--text-primary);transition:background .15s;flex-shrink:0}.volume-icon-btn .icon-text{line-height:1}.volume-icon-btn:hover{background:var(--color-primary-bg)}.volume-icon-btn:active{background:var(--color-primary-bg-hover)}.volume-mini-bar{width:36px;height:4px;background:var(--border-medium);border-radius:2px;overflow:hidden;flex-shrink:0}.volume-mini-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .15s ease}.volume-control.muted .volume-mini-fill{width:0!important;background:var(--text-muted)}.volume-expand-btn{display:flex;align-items:center;justify-content:center;width:22px;height:32px;padding:0;background:transparent;border:none;border-left:1px solid var(--border-subtle);cursor:pointer;color:var(--text-tertiary);font-size:10px;transition:all .15s;flex-shrink:0}.volume-expand-btn:hover{background:var(--color-primary-bg);color:var(--text-primary)}.volume-chevron{display:inline-block;transition:transform .2s ease}.volume-chevron.open{transform:rotate(180deg)}.volume-panel{position:absolute;top:calc(100% + 8px);right:0;width:220px;background:var(--surface-modal);border:1px solid var(--border-subtle);border-radius:12px;box-shadow:var(--shadow-modal);z-index:1000;overflow:hidden;animation:volumePanelFadeIn .2s ease}@keyframes volumePanelFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.volume-panel-header{padding:10px 14px;font-size:13px;font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-subtle)}.volume-sliders{padding:12px 14px;display:flex;flex-direction:column;gap:12px}.volume-item{display:flex;flex-direction:column;gap:6px}.volume-label{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-secondary)}.volume-value{font-size:11px;font-weight:600;color:var(--color-primary);min-width:30px;text-align:right}.volume-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:3px;outline:none;cursor:pointer;transition:opacity .2s;background:linear-gradient(to right,var(--color-primary) 0%,var(--color-primary) var(--value, 50%),var(--border-medium) var(--value, 50%),var(--border-medium) 100%)}.volume-slider:disabled{opacity:.4;cursor:not-allowed}.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid var(--color-primary);box-shadow:0 1px 4px #0003;cursor:pointer;transition:transform .15s,box-shadow .15s}.volume-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 2px 8px #9d7bff4d}.volume-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:#fff;border:2px solid var(--color-primary);box-shadow:0 1px 4px #0003;cursor:pointer;transition:transform .15s}.volume-slider::-moz-range-thumb:hover{transform:scale(1.2)}@media (max-width: 768px){.volume-mini-bar{width:24px}}@media (max-width: 480px){.volume-mini-bar{display:none}.volume-expand-btn{border-left:none}}.accessibility-menu{position:relative;display:inline-block}.accessibility-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:6px;background:var(--surface-card);border:2px solid var(--border-medium);border-radius:8px;cursor:pointer;transition:all .2s ease;position:relative}.accessibility-toggle:hover{background:var(--surface-card-hover);border-color:var(--border-focus);transform:scale(1.05)}.accessibility-toggle:focus-visible{outline:3px solid var(--border-focus);outline-offset:2px}.accessibility-icon{width:20px;height:20px;color:var(--text-primary)}.eye-comfort-indicator{position:absolute;top:2px;right:2px;width:8px;height:8px;background:#d4a030;border-radius:50%;border:2px solid var(--surface-card)}.accessibility-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:250px;background:var(--surface-modal);border:1px solid var(--border-subtle);border-radius:12px;box-shadow:var(--shadow-modal);z-index:1000;overflow:hidden;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.accessibility-section{padding:16px}.accessibility-section+.accessibility-section{padding-top:0}.accessibility-section-title{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-subtle)}.theme-toggle-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:8px;cursor:pointer;transition:background .15s}.theme-toggle-btn:hover{background:var(--color-primary-bg)}.theme-toggle-icon{font-size:18px;line-height:1}.theme-toggle-label{flex:1;font-size:14px;color:var(--text-primary);text-align:left}.theme-toggle-track{position:relative;width:40px;height:22px;background:var(--border-medium);border-radius:11px;transition:background .2s;flex-shrink:0}.theme-toggle-track.dark{background:var(--color-primary)}.theme-toggle-thumb{position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px #0003}.theme-toggle-track.dark .theme-toggle-thumb{transform:translate(18px)}.comfort-track.on{background:#d4a030}.comfort-track.on .theme-toggle-thumb{transform:translate(18px)}.eye-comfort-desc{font-size:12px;color:var(--text-tertiary);line-height:1.5;margin:8px 12px 0}@media (max-width: 768px) and (min-width: 481px){.accessibility-dropdown{position:fixed;top:56px;right:12px;min-width:240px}}@media (max-width: 480px){.accessibility-dropdown{position:fixed;top:auto;bottom:0;left:0;right:0;min-width:100%;border-radius:16px 16px 0 0;max-height:70vh;overflow-y:auto}.accessibility-section{padding:20px}}.policy-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;overflow-y:auto}.policy-content{background:#fff;border-radius:16px;max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #0003;animation:policySlideUp .3s ease-out}@keyframes policySlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.policy-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:2px solid rgba(157,123,255,.2);flex-shrink:0}.policy-header h1{font-size:28px;font-weight:700;color:#3a2d60;margin:0}.policy-close-btn{width:36px;height:36px;border:none;background:#9d7bff1a;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;color:#3a2d60;transition:all .2s;flex-shrink:0}.policy-close-btn:hover{background:#9d7bff33;transform:scale(1.05)}.policy-close-btn:active{transform:scale(.95)}.policy-body{padding:32px;overflow-y:auto;flex:1}.policy-body section{margin-bottom:32px}.policy-body section:last-child{margin-bottom:0}.policy-body h2{font-size:20px;font-weight:700;color:#3a2d60;margin:0 0 16px}.policy-body p{font-size:15px;line-height:1.7;color:#444;margin:0 0 12px}.policy-body ul{margin:12px 0;padding-left:24px}.policy-body li{font-size:15px;line-height:1.7;color:#444;margin-bottom:8px}.policy-footer{padding:20px 32px;border-top:2px solid rgba(157,123,255,.2);background:#9d7bff0d;border-radius:0 0 16px 16px;flex-shrink:0}.policy-footer p{margin:0;font-size:13px;color:#666;text-align:center}@media (max-width: 768px){.policy-overlay{padding:10px}.policy-content{max-height:95vh;border-radius:12px}.policy-header{padding:20px 24px}.policy-header h1{font-size:22px}.policy-close-btn{width:32px;height:32px;font-size:18px}.policy-body{padding:24px}.policy-body h2{font-size:18px;margin-bottom:12px}.policy-body p,.policy-body li{font-size:14px}.policy-footer{padding:16px 24px}.policy-footer p{font-size:12px}}@media (max-width: 480px){.policy-header{padding:16px 20px}.policy-header h1{font-size:20px}.policy-body{padding:20px}.policy-body section{margin-bottom:24px}.policy-body h2{font-size:17px}.policy-body p,.policy-body li{font-size:13px;line-height:1.6}}.contact-email-row{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding:12px 16px;background:#9d7bff0d;border-radius:8px;flex-wrap:wrap}.contact-label{font-size:13px;color:#666;flex-shrink:0}.contact-email{font-size:14px;color:#3a2d60;font-family:monospace;word-break:break-all;-webkit-user-select:text;user-select:text}.contact-input{width:100%;padding:10px 14px;border:1px solid rgba(157,123,255,.3);border-radius:8px;font-size:14px;margin-bottom:12px;box-sizing:border-box;font-family:inherit;outline:none;color:#333}.contact-input:focus{border-color:#9d7bff99;box-shadow:0 0 0 2px #9d7bff1a}.contact-textarea{width:100%;padding:10px 14px;border:1px solid rgba(157,123,255,.3);border-radius:8px;font-size:14px;margin-bottom:16px;resize:vertical;box-sizing:border-box;font-family:inherit;outline:none;color:#333;min-height:120px}.contact-textarea:focus{border-color:#9d7bff99;box-shadow:0 0 0 2px #9d7bff1a}.contact-send-btn{width:100%;padding:12px;background:var(--accent, #9d7bff);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s;font-family:inherit}.contact-send-btn:hover{opacity:.9}.interactive-logo-wrapper{position:relative;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;transform-origin:center center}.interactive-logo-wrapper.wiggling{animation:wiggle .5s ease}@keyframes wiggle{0%,to{transform:rotate(0) scale(1)}20%{transform:rotate(-8deg) scale(1.1)}40%{transform:rotate(8deg) scale(1.1)}60%{transform:rotate(-5deg) scale(1.05)}80%{transform:rotate(5deg) scale(1.05)}}.interactive-logo-image{width:100%;height:100%;object-fit:contain;pointer-events:none}.click-counter{position:absolute;top:-8px;right:-8px;background:linear-gradient(135deg,#ff6b6b,#ff8e53);color:#fff;font-size:12px;font-weight:700;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #ff6b6b66;animation:pop-in .3s ease}@keyframes pop-in{0%{transform:scale(0);opacity:0}70%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.sparkle-effect{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.sparkle{position:absolute;font-size:20px;animation:sparkle-float 2s ease forwards}.sparkle.s1{top:-10px;left:10%;animation-delay:0s}.sparkle.s2{top:-5px;right:10%;animation-delay:.1s}.sparkle.s3{bottom:-10px;left:20%;animation-delay:.2s}.sparkle.s4{bottom:-5px;right:20%;animation-delay:.3s}@keyframes sparkle-float{0%{opacity:0;transform:translateY(0) scale(.5)}30%{opacity:1;transform:translateY(-20px) scale(1.2)}to{opacity:0;transform:translateY(-40px) scale(.8)}}.interactive-logo-wrapper.sparkle{animation:glow-pulse .5s ease infinite alternate}@keyframes glow-pulse{0%{filter:drop-shadow(0 0 5px rgba(255,215,0,.5))}to{filter:drop-shadow(0 0 15px rgba(255,215,0,.8))}}.interactive-logo-wrapper:focus-visible{outline:3px solid #4A90D9;outline-offset:4px;border-radius:8px}@media (pointer: coarse){.interactive-logo-wrapper:hover{transform:none}.interactive-logo-wrapper:active{transform:scale(.95)}}.name-input-screen{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-gradient);padding:20px;position:relative}.name-input-controls{position:absolute;top:20px;right:20px;z-index:100;display:flex;gap:8px;align-items:center}.name-input-controls .control-icon-btn{width:40px;height:40px;border:1px solid var(--border-subtle);background:var(--surface-card);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:var(--text-secondary)}.name-input-controls .control-icon-btn:hover{background:var(--surface-card-hover);transform:scale(1.05)}.name-input-controls .control-icon-btn:active{transform:scale(.95)}.name-input-controls .control-icon-btn .icon-text{font-size:20px}.name-input-container{background:var(--surface-card);border:1px solid var(--border-subtle);padding:48px 36px;border-radius:24px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);text-align:center;max-width:460px;width:100%;animation:jellyBounceIn .5s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.name-input-form{margin-top:32px}.name-input-form h2{font-size:20px;color:var(--text-secondary);margin-bottom:20px;font-weight:600}.name-input{width:100%;padding:14px 18px;font-size:17px;border:2px solid var(--border-medium);border-radius:12px;outline:none;transition:all .2s;font-weight:500;color:var(--text-primary);background:var(--surface-input);box-sizing:border-box}.name-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px #9d7bff26;background:var(--surface-card)}.name-input.error{border-color:#ff6b6b}.name-input::placeholder{color:var(--text-placeholder)}.random-nick-preview{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:10px;padding:8px 14px;background:#9d7bff14;border:1px solid rgba(157,123,255,.2);border-radius:10px;animation:fadeIn .25s ease}.random-nick-label{color:var(--text-tertiary);font-size:12px;white-space:nowrap}.random-nick-name{color:#9d7bff;font-size:15px;font-weight:700;letter-spacing:.3px}.random-nick-shuffle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--surface-subtle);border:1px solid var(--border-subtle);border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:all .2s;flex-shrink:0;padding:0}.random-nick-shuffle:hover{background:#9d7bff33;color:#9d7bff;border-color:#9d7bff66;transform:rotate(90deg)}.random-nick-shuffle:active{transform:rotate(180deg) scale(.9)}.char-hint-message{color:#e07b00;font-size:13px;margin:6px 0 0;text-align:left;font-weight:500;animation:fadeInDown .2s ease}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.error-message{color:#ff8f7e;font-size:14px;margin:8px 0 0;text-align:left;font-weight:500}.submit-name-btn{width:100%;padding:14px;margin-top:16px;font-size:17px;font-weight:700;background:var(--color-primary-gradient);color:var(--text-on-primary);border:none;border-bottom:3px solid rgba(60,140,110,.4);border-radius:50px;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 16px #9d7bff4d;position:relative;overflow:hidden}.submit-name-btn:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.3) 0%,transparent 100%);border-radius:50px 50px 0 0;pointer-events:none}.submit-name-btn:after{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);pointer-events:none}.submit-name-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 6px 20px #9d7bff66}.submit-name-btn:hover:after{animation:glossShimmer 1.5s ease}.submit-name-btn:active{animation:jellyPress .4s ease}.game-logo{display:flex;flex-direction:column;align-items:center;gap:12px}.logo-icon{width:100px;height:100px;background:linear-gradient(135deg,#9d7bff,#8b68ee);border-radius:var(--jelly-radius, 28% 28% 28% 28% / 32% 32% 32% 32%);display:flex;align-items:center;justify-content:center;font-size:52px;font-weight:900;color:#fff;box-shadow:0 8px 32px #9d7bff4d;position:relative;overflow:hidden;animation:jellyFloat 4s ease-in-out infinite}.logo-shine{position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shine 3s infinite}@keyframes shine{0%{left:-100%}50%,to{left:150%}}.game-logo h1{font-size:36px;font-weight:900;color:var(--text-primary);margin:0;letter-spacing:-1px}.google-login-section{margin-top:16px;display:flex;flex-direction:column;align-items:center;gap:12px}.or-divider{display:flex;align-items:center;gap:10px;width:100%}.or-divider-line{flex:1;height:1px;background:var(--border-subtle)}.or-divider-text{color:var(--text-muted);font-size:13px;white-space:nowrap}.google-loading-text{color:#9d7bff;font-size:14px}.auth-buttons-container{display:flex;flex-direction:column;gap:10px;width:100%;align-items:center}.google-btn-wrapper{width:100%;display:flex;justify-content:center}.discord-login-btn{display:flex;align-items:center;justify-content:center;gap:12px;background-color:#5865f2;color:#fff;border:none;border-radius:24px;padding:10px 24px;font-size:14px;font-family:inherit;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s;width:auto;min-width:220px;height:40px;box-sizing:border-box}.discord-login-btn:hover{background-color:#4752c4}.discord-login-btn:active{transform:scale(.98)}.discord-icon{width:20px;height:20px;fill:currentColor}.google-logged-in-badge{display:flex;align-items:center;gap:8px;background:#4285f426;border:1px solid rgba(66,133,244,.3);border-radius:24px;padding:6px 14px;margin-bottom:8px;font-size:13px;color:#82b1ff}.google-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover}.logout-btn{background:none;border:none;color:var(--text-tertiary);font-size:12px;cursor:pointer;padding:2px 6px;margin-left:4px;text-decoration:underline}.logout-btn:hover{color:var(--text-secondary)}.name-input-footer{margin-top:28px;padding-top:20px;border-top:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.footer-link{background:none;border:none;color:var(--text-tertiary);font-size:13px;cursor:pointer;padding:4px 8px;transition:all .2s;text-decoration:none}.footer-divider{color:var(--border-medium);font-size:13px}@media (max-width: 768px){.name-input-screen{padding:15px}.name-input-controls{top:15px;right:15px;gap:6px}.name-input-controls .control-icon-btn{width:36px;height:36px}.name-input-controls .control-icon-btn .icon-text{font-size:18px}.name-input-container{padding:36px 24px;max-width:100%}.logo-icon{width:80px;height:80px;font-size:42px}.game-logo h1{font-size:28px}.name-input-form h2{font-size:18px;margin-bottom:16px}.name-input{font-size:16px;padding:12px 14px}.submit-name-btn{font-size:16px;padding:12px}.name-input-footer{margin-top:20px;padding-top:16px}.footer-link,.footer-divider{font-size:12px}}@media (max-width: 480px){.name-input-container{padding:28px 18px;border-radius:20px}.logo-icon{width:70px;height:70px;font-size:36px;border-radius:18px}.game-logo h1{font-size:24px}.name-input-form h2{font-size:16px}.name-input{font-size:15px;padding:11px 14px}.submit-name-btn{font-size:15px;padding:11px}.footer-link{font-size:11px;padding:3px 6px}.footer-divider{font-size:11px}}@media (max-height: 600px) and (orientation: landscape) and (max-width: 1024px){.name-input-screen{padding:10px}.name-input-controls{top:10px;right:10px}.name-input-container{padding:16px 24px;max-width:600px;width:auto;display:flex;align-items:center;gap:24px;border-radius:16px}.game-logo{flex-direction:column;gap:6px;flex-shrink:0;width:120px}.logo-icon{width:60px;height:60px;font-size:32px;border-radius:16px;margin:0 auto}.game-logo h1{font-size:18px;text-align:center;white-space:nowrap}.name-input-form{margin-top:0;flex:1;min-width:220px}.name-input-form h2{font-size:15px;margin-bottom:10px}.name-input{font-size:14px;padding:10px 14px}.submit-name-btn{font-size:14px;padding:10px;margin-top:10px}.name-input-footer{position:fixed;bottom:8px;left:50%;transform:translate(-50%);margin:0;padding:4px 12px;background:var(--surface-card);border-radius:12px;border-top:none}.footer-link{font-size:9px;padding:2px 4px;opacity:.6}.footer-link:hover{opacity:1}.footer-divider{font-size:9px;opacity:.4}}.bug-report-btn{position:fixed;bottom:70px;right:20px;background:#1e1e28bf;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.2);border-radius:50px;padding:10px 20px;color:#ffffffe6;font-size:14px;cursor:pointer;transition:all .2s ease;z-index:1000;display:flex;align-items:center;gap:8px;text-decoration:none}.bug-report-btn:hover{background:#1e1e28eb;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #00000059}.bug-report-btn:active{transform:translateY(0)}.bug-icon{font-size:16px}@media (max-width: 768px){.bug-report-btn{bottom:62px;right:12px;padding:8px 14px;font-size:12px}.bug-icon{font-size:14px}}.bug-report-panel{position:fixed;bottom:70px;right:20px;width:300px;background:#141423f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:14px;padding:16px;z-index:1001;display:flex;flex-direction:column;gap:10px;box-shadow:0 8px 32px #0006;animation:bugPanelIn .15s ease}@keyframes bugPanelIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.bug-panel-header{display:flex;justify-content:space-between;align-items:center;color:#fff;font-size:14px;font-weight:600;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.bug-panel-close{background:none;border:none;color:#ffffff80;cursor:pointer;font-size:14px;padding:2px 6px;border-radius:4px;line-height:1}.bug-panel-close:hover{color:#fff;background:#ffffff1a}.bug-panel-row{display:flex;flex-direction:column;gap:3px}.bug-panel-label{font-size:10px;color:#fff6;text-transform:uppercase;letter-spacing:.05em}.bug-panel-value{font-size:12px;color:#ffffffd9;word-break:break-all;-webkit-user-select:text;user-select:text}.bug-panel-pre{white-space:pre-wrap;font-family:inherit;font-size:11px;color:#fff9;-webkit-user-select:text;user-select:text;background:#ffffff0d;border-radius:6px;padding:8px;margin:0;line-height:1.5;max-height:120px;overflow-y:auto}.bug-panel-send{background:#9d7bffb3;border:none;border-radius:8px;color:#fff;font-size:13px;padding:9px;cursor:pointer;transition:background .2s;margin-top:2px}.bug-panel-send:hover{background:#9d7bff}@media (max-width: 768px){.bug-report-panel{right:12px;bottom:62px;width:calc(100vw - 24px);max-width:320px}}@media (max-width: 480px){.bug-report-btn{bottom:60px;right:10px;padding:9px;border-radius:50%;gap:0}.bug-report-btn .bug-text{display:none}.bug-icon{font-size:16px}}.title-badge{display:inline-flex;align-items:center;gap:3px;border-radius:4px;padding:1px 5px;font-size:.7rem;font-weight:700;white-space:nowrap;vertical-align:middle;-webkit-user-select:none;user-select:none;cursor:default}.title-badge--sm{font-size:.68rem;padding:1px 4px}.title-badge--md{font-size:.78rem;padding:2px 6px}.title-badge--lg{font-size:.9rem;padding:3px 8px}.title-badge--common{background:#3a3a3a;color:#aaa;border:1px solid #555}.title-badge--rare{background:#1a2e4a;color:#4a9eff;border:1px solid #2a5080}.title-badge--epic{background:#2a1a40;color:#c084fc;border:1px solid #6B21A8;animation:epic-glow 2.5s ease-in-out infinite}@keyframes epic-glow{0%,to{box-shadow:0 0 4px #a855f74d}50%{box-shadow:0 0 10px #a855f7b3}}.title-badge--legendary{background:linear-gradient(90deg,#78350f,#92400e,#78350f);background-size:200%;color:#fcd34d;border:1px solid #F59E0B;animation:legendary-shimmer 2.2s linear infinite}@keyframes legendary-shimmer{0%{background-position:200% center}to{background-position:-200% center}}.title-badge--legendary .title-badge__icon{filter:drop-shadow(0 0 3px rgba(251,191,36,.9))}.title-badge{position:relative}.title-badge__tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);z-index:9999;display:none;flex-direction:column;align-items:center;gap:4px;min-width:130px;max-width:200px;padding:10px 12px;border-radius:10px;background:#0d0d1a;border:1px solid #333;box-shadow:0 8px 24px #000000b3;white-space:normal;text-align:center}.title-badge__tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#333}@keyframes tbt-appear{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.title-badge__tooltip--common{border-color:#555}.title-badge__tooltip--common:after{border-top-color:#555}.title-badge__tooltip--rare{border-color:#2a5080}.title-badge__tooltip--rare:after{border-top-color:#2a5080}.title-badge__tooltip--epic{border-color:#6b21a8;box-shadow:0 8px 24px #a855f74d}.title-badge__tooltip--epic:after{border-top-color:#6b21a8}.title-badge__tooltip--legendary{border-color:#f59e0b;box-shadow:0 8px 24px #fbbf244d}.title-badge__tooltip--legendary:after{border-top-color:#f59e0b}.tbt-icon{font-size:1.6rem;line-height:1}.tbt-name{font-size:.85rem;font-weight:700;color:#e0e0e0}.tbt-desc{font-size:.72rem;color:#999;line-height:1.4}.tbt-rarity{font-size:.65rem;font-weight:800;letter-spacing:.05em;margin-top:2px}.tbt-rarity--common{color:#aaa}.tbt-rarity--rare{color:#4a9eff}.tbt-rarity--epic{color:#c084fc}.tbt-rarity--legendary{color:#fcd34d}.profile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:1000;display:flex;align-items:center;justify-content:center;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:profile-fade-in .15s ease}@keyframes profile-fade-in{0%{opacity:0}to{opacity:1}}.profile-modal{position:relative;background:#fff;border-radius:16px;width:100%;max-width:480px;max-height:88vh;overflow-y:auto;padding:28px 24px 24px;box-shadow:0 20px 60px #0003;animation:profile-slide-up .2s ease}@keyframes profile-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.profile-close-btn{position:absolute;top:14px;right:16px;background:none;border:none;font-size:1.1rem;color:#aaa;cursor:pointer;padding:4px 6px;line-height:1;border-radius:4px;transition:color .15s,background .15s}.profile-close-btn:hover{color:#555;background:#f0f0f0}.profile-header{display:flex;align-items:center;gap:16px;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #f0f0f0}.profile-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;border:2px solid #9D7BFF;flex-shrink:0}.profile-avatar-placeholder{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#9d7bff,#3498db);color:#fff;font-size:1.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-identity{display:flex;flex-direction:column;gap:4px;min-width:0}.profile-name{font-size:1.25rem;font-weight:700;color:#2c3e50;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-email{font-size:.82rem;color:#aaa;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.profile-stat-card{background:#f8fbfa;border:1px solid #e8f5f1;border-radius:10px;padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:4px;text-align:center}.stat-value{font-size:1.3rem;font-weight:700;color:#2c3e50;line-height:1}.stat-label{font-size:.72rem;color:#888;line-height:1.2}.profile-section-title{font-size:.9rem;font-weight:700;color:#555;margin:0 0 10px;text-transform:uppercase;letter-spacing:.05em}.profile-match-list{display:flex;flex-direction:column;gap:5px}.profile-match-row{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;background:#f9f9f9;border:1px solid #f0f0f0;font-size:.82rem;transition:background .1s}.profile-match-row.win{background:#f5f0ff;border-color:#c3e8dc}.match-medal{font-size:1rem;width:24px;flex-shrink:0;text-align:center}.match-score{font-weight:700;color:#2c3e50;min-width:60px}.match-mode{color:#777;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.match-players{color:#aaa;flex-shrink:0;font-size:.78rem}.match-date{color:#bbb;flex-shrink:0;font-size:.75rem}.profile-no-games{text-align:center;padding:20px 0 4px;color:#aaa;font-size:.9rem}.profile-loading{text-align:center;padding:32px;color:#aaa;font-size:.9rem}@media (max-width: 400px){.profile-stats-grid{grid-template-columns:repeat(2,1fr)}.match-date{display:none}}.profile-titles-section{margin-top:20px;border-top:1px solid rgba(255,255,255,.08);padding-top:16px}.profile-titles-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.profile-title-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:8px 12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:border-color .15s,background .15s}.profile-title-card:hover{background:#ffffff1a;border-color:#ffffff4d}.profile-title-card.equipped{border-color:#9d7bff;background:#9d7bff1f}.equipped-check{font-size:.65rem;color:#9d7bff;font-weight:700}.profile-titles-hint{font-size:.72rem;color:#666;margin-top:8px}.leaderboard-marquee-container{display:flex;align-items:center;background:#0006;border:1px solid rgba(255,215,0,.3);border-radius:8px;overflow:hidden;height:40px;cursor:pointer;transition:all .2s;box-shadow:0 4px 6px #0003;flex:1;max-width:500px;min-width:250px}.leaderboard-marquee-container:hover{background:#0009;border-color:#ffd70099;transform:translateY(-2px);box-shadow:0 6px 12px #ffd7001a}.marquee-badge{background:linear-gradient(135deg,gold,#fa0);color:#333;font-weight:800;font-size:.85rem;padding:0 12px;height:100%;display:flex;align-items:center;justify-content:center;white-space:nowrap;z-index:2;box-shadow:2px 0 5px #00000080}.marquee-content-wrapper{overflow:hidden;white-space:nowrap;flex:1;display:flex;align-items:center;height:100%;position:relative;-webkit-mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent);mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent)}.marquee-content{display:inline-block;white-space:nowrap;animation:marquee-scroll 25s linear infinite;color:#fff;font-size:.95rem;font-weight:500;text-shadow:0 1px 2px rgba(0,0,0,.8)}.marquee-content span{padding-right:50px}.leaderboard-marquee-container:hover .marquee-content{animation-play-state:paused}.marquee-placeholder{color:#ffffff80;font-size:.85rem;padding:0 12px;white-space:nowrap}@keyframes marquee-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}@media (max-width: 768px){.leaderboard-marquee-container{max-width:none;width:100%}.marquee-badge{font-size:.75rem;padding:0 8px}.marquee-content{font-size:.85rem}}@media (max-width: 480px){.leaderboard-marquee-container{height:32px;min-width:0;width:100%}.marquee-badge{font-size:clamp(.65rem,2.5vw,.7rem);padding:0 6px}.marquee-content{font-size:clamp(.72rem,3vw,.78rem)}}.lobby-page{min-height:100vh;background:var(--bg-gradient);color:var(--text-primary);display:flex;flex-direction:column}.lobby-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:var(--surface-nav);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-subtle);gap:12px}.lobby-nav-left{display:flex;align-items:center;gap:12px;flex-shrink:0}.lobby-back-btn{display:flex;align-items:center;gap:4px;background:var(--surface-subtle);border:1px solid var(--border-subtle);color:var(--text-secondary);padding:6px 12px;border-radius:8px;cursor:pointer;font-size:13px;transition:all .2s}.lobby-back-btn:hover{background:var(--surface-card);color:var(--text-primary)}.lobby-nav-logo{font-family:Arial Black,Arial,sans-serif;font-size:16px;font-weight:900;color:var(--logo-color);letter-spacing:1px}.lobby-nav-center{flex:1;display:flex;justify-content:center;max-width:300px;position:relative}.lobby-nickname-input{width:100%;padding:7px 14px;background:var(--surface-input);border:1.5px solid var(--border-medium);border-radius:8px;color:var(--text-primary);font-size:14px;text-align:center;outline:none;transition:border-color .2s}.lobby-nickname-input::placeholder{color:var(--text-placeholder)}.lobby-nickname-input:focus{border-color:var(--border-focus)}.lobby-nickname-input.input-error{border-color:var(--border-error);animation:shake .3s ease}.lobby-char-hint{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:4px;padding:4px 10px;background:#fff8ee;border:1px solid #f0c060;border-radius:6px;font-size:12px;color:#a05800;font-weight:500;white-space:nowrap;z-index:10;animation:fadeInDown .2s ease;pointer-events:none}.lobby-nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.lobby-user-badge{display:flex;align-items:center;gap:6px}.lobby-user-info-btn{display:flex;align-items:center;gap:6px;background:var(--color-primary-bg);border:1px solid var(--color-primary-bg-hover);color:var(--text-accent);padding:4px 10px;border-radius:20px;cursor:pointer;font-size:13px;transition:all .2s}.lobby-user-info-btn:hover{background:var(--color-primary-bg-hover)}.lobby-user-avatar{width:22px;height:22px;border-radius:50%;object-fit:cover}.lobby-user-avatar-placeholder{width:22px;height:22px;border-radius:50%;background:var(--color-primary-bg-hover);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text-accent)}.lobby-user-name{font-weight:600}.lobby-logout-btn{background:var(--error-bg);border:1px solid var(--error-bg-hover);color:var(--text-error);padding:4px 10px;border-radius:8px;cursor:pointer;font-size:12px;transition:all .2s}.lobby-logout-btn:hover{background:var(--error-bg-hover)}.lobby-login-wrap{position:relative}.lobby-login-toggle{display:flex;align-items:center;gap:4px;background:var(--surface-subtle);border:1px solid var(--border-subtle);color:var(--text-secondary);padding:5px 10px;border-radius:8px;cursor:pointer;font-size:13px;transition:all .2s}.lobby-login-toggle:hover,.lobby-login-toggle.open{background:var(--surface-card);color:var(--text-primary)}.lobby-login-caret{font-size:10px}.lobby-login-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface-modal);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-subtle);border-radius:12px;padding:12px;min-width:220px;z-index:200;display:flex;flex-direction:column;gap:8px;animation:dropdown-appear .15s ease-out}.login-dropdown-discord{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:8px 16px;background:var(--discord-bg);border:none;border-radius:8px;color:#fff;font-size:13px;cursor:pointer;transition:opacity .2s}.login-dropdown-discord:hover{opacity:.9}.login-dropdown-discord:disabled{opacity:.5;cursor:not-allowed}.login-dropdown-divider{height:1px;background:var(--border-subtle);margin:2px 0}.login-dropdown-guest{background:none;border:1px solid var(--border-subtle);color:var(--text-tertiary);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:13px;transition:all .2s}.login-dropdown-guest:hover{background:var(--surface-subtle);color:var(--text-secondary)}.lobby-login-loading{font-size:12px;color:var(--text-tertiary);text-align:center;padding:8px}.lobby-main{flex:1;display:flex;flex-direction:column;padding:calc(var(--lobby-nav-h, 68px) + 12px) 20px 20px;max-width:1200px;width:100%;margin:0 auto}.room-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px}.room-toolbar-info{display:flex;align-items:center;gap:8px;margin-right:auto}.room-toolbar-title{font-size:18px;font-weight:700;color:var(--text-primary)}.room-count-badge{background:var(--color-primary-bg);color:var(--text-accent);padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600}.toolbar-search{position:relative;flex:0 0 200px}.toolbar-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.toolbar-search-input{width:100%;padding:7px 10px 7px 32px;background:var(--surface-input);border:1.5px solid var(--border-subtle);border-radius:8px;color:var(--text-primary);font-size:13px;outline:none;transition:border-color .2s}.toolbar-search-input::placeholder{color:var(--text-placeholder)}.toolbar-search-input:focus{border-color:var(--border-focus)}.toolbar-actions{display:flex;align-items:center;gap:8px}.toolbar-btn{display:flex;align-items:center;gap:4px;padding:7px 12px;background:var(--surface-subtle);border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap}.toolbar-btn:hover{background:var(--surface-card);color:var(--text-primary)}.toolbar-btn.active{background:var(--color-primary-bg);border-color:var(--border-focus);color:var(--text-accent)}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.filter-active-dot{width:6px;height:6px;background:var(--color-primary);border-radius:50%;flex-shrink:0}.toolbar-refresh-btn{composes:toolbar-btn;padding:7px 8px}.toolbar-refresh-icon{display:block;transition:transform .6s ease}.toolbar-refresh-icon.spinning{transform:rotate(360deg)}.toolbar-invite-section{display:flex;align-items:center;gap:4px}.toolbar-invite-wrapper{position:relative;display:flex;align-items:center}.toolbar-invite-input{width:110px;padding:7px 30px 7px 10px;background:var(--surface-input);border:1.5px solid var(--border-subtle);border-radius:8px;color:var(--text-primary);font-size:13px;font-family:Courier New,monospace;text-transform:uppercase;letter-spacing:1px;outline:none;transition:border-color .2s}.toolbar-invite-input::placeholder{color:var(--text-placeholder);letter-spacing:0;font-family:inherit}.toolbar-invite-input:focus{border-color:var(--border-focus)}.toolbar-invite-input.input-error{border-color:var(--border-error);animation:shake .3s ease}.toolbar-invite-input.invite-masked{-webkit-text-security:disc}.toolbar-invite-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.toolbar-invite-toggle:hover{color:var(--text-secondary)}.toolbar-quick-btn{display:flex;align-items:center;gap:4px;padding:7px 14px;background:var(--color-quickjoin-gradient);border:none;border-radius:8px;color:var(--text-on-primary);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;position:relative;overflow:hidden;box-shadow:var(--jelly-btn-depth-cta)}.toolbar-quick-btn:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,transparent 100%);pointer-events:none}.toolbar-quick-btn:after{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);pointer-events:none}.toolbar-quick-btn:hover{filter:brightness(1.1);transform:translateY(-2px) scale(1.03)}.toolbar-quick-btn:hover:after{animation:glossShimmer 1.5s ease}.toolbar-quick-btn:active{animation:jellyPress .35s ease}.toolbar-quick-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;filter:none;box-shadow:none}.toolbar-create-btn{display:flex;align-items:center;gap:4px;padding:7px 16px;background:var(--color-primary-gradient);border:none;border-radius:8px;color:var(--text-on-primary);font-size:13px;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;position:relative;overflow:hidden;box-shadow:var(--jelly-btn-depth-primary)}.toolbar-create-btn:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,transparent 100%);pointer-events:none}.toolbar-create-btn:hover{filter:brightness(1.1);transform:translateY(-2px) scale(1.03)}.toolbar-create-btn:active{animation:jellyPress .35s ease}.toolbar-create-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;filter:none;box-shadow:none}.room-filters{display:flex;flex-wrap:wrap;align-items:center;gap:16px;padding:14px 16px;background:var(--surface-subtle);border:1px solid var(--border-subtle);border-radius:12px;margin-bottom:14px;animation:dropdown-appear .15s ease-out}.filter-group{display:flex;align-items:center;gap:6px}.filter-label{font-size:12px;color:var(--text-muted);font-weight:600;white-space:nowrap}.filter-chip{padding:4px 10px;background:var(--surface-subtle);border:1.5px solid var(--border-subtle);border-radius:6px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .15s}.filter-chip:hover{background:var(--surface-card);color:var(--text-primary)}.filter-chip.active{background:var(--color-primary-bg);border-color:var(--border-focus);color:var(--text-accent)}.filter-toggle-label{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);cursor:pointer}.filter-toggle-label input[type=checkbox]{accent-color:var(--color-primary)}.filter-reset-btn{padding:4px 10px;background:var(--error-bg);border:1px solid var(--error-bg-hover);border-radius:6px;color:var(--text-error);font-size:12px;cursor:pointer;transition:all .15s}.filter-reset-btn:hover{background:var(--error-bg-hover)}.room-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;align-content:start;overflow-y:auto;padding-bottom:20px}.room-card{background:var(--surface-card);border:1px solid var(--border-subtle);border-bottom:2px solid var(--border-medium);border-radius:16px;padding:14px 16px;display:flex;flex-direction:column;gap:10px;transition:all .25s cubic-bezier(.34,1.56,.64,1);cursor:default;animation:fadeSlideUp .3s ease-out;position:relative;overflow:hidden}.room-card:before{content:"";position:absolute;top:0;left:0;right:0;height:40%;background:linear-gradient(180deg,rgba(255,255,255,.12) 0%,transparent 100%);border-radius:16px 16px 0 0;pointer-events:none}.room-card:hover{transform:translateY(-3px) scale(1.01);border-color:var(--border-strong);background:var(--surface-card-hover);box-shadow:var(--shadow-card),0 8px 20px #0000000a}.room-card.same-country{border-color:var(--color-primary-bg-hover);background:var(--color-primary-bg)}.room-card.same-country:hover{border-color:var(--border-focus)}.room-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.room-card-name{font-size:15px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.room-country-flag{margin-right:4px;font-size:14px}.room-card-join-btn{flex-shrink:0;padding:5px 14px;background:var(--color-primary-gradient);border:none;border-radius:8px;color:var(--text-on-primary);font-size:12px;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;box-shadow:var(--jelly-btn-depth-primary)}.room-card-join-btn:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,transparent 100%);pointer-events:none}.room-card-join-btn:hover{filter:brightness(1.1);transform:translateY(-2px) scale(1.04)}.room-card-join-btn:active{animation:jellyPress .35s ease}.room-card-join-btn:disabled{background:var(--surface-subtle);color:var(--text-muted);cursor:not-allowed;transform:none;filter:none}.room-card-badges{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.room-badge{padding:2px 8px;border-radius:8px;font-size:11px;font-weight:600;white-space:nowrap;box-shadow:0 1px 2px #0000000d}.room-badge-S{background:var(--badge-s-bg);color:var(--badge-s-color)}.room-badge-M{background:var(--badge-m-bg);color:var(--badge-m-color)}.room-badge-L{background:var(--badge-l-bg);color:var(--badge-l-color)}.room-badge-mode{background:var(--badge-mode-bg);color:var(--badge-mode-color)}.room-badge-private{background:var(--error-bg);color:var(--text-error)}.room-badge-public{background:var(--badge-default-bg);color:var(--badge-default-color)}.room-card-footer{display:flex;align-items:center;gap:10px}.room-players-info{flex:1;display:flex;flex-direction:column;gap:4px}.room-players-text{font-size:12px;color:var(--text-tertiary);font-weight:500}.room-players-text strong{color:var(--text-primary);font-weight:700}.room-players-bar{height:4px;background:var(--bar-bg);border-radius:2px;overflow:hidden}.room-players-fill{height:100%;border-radius:2px;transition:width .3s ease;background:var(--bar-normal)}.room-players-fill.nearly-full{background:var(--bar-warn)}.room-players-fill.full{background:var(--bar-full)}.room-card-skeleton{background:var(--surface-skeleton);border:1px solid var(--border-subtle);border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:10px}.skeleton-line{border-radius:6px;background:linear-gradient(90deg,var(--surface-skeleton) 25%,var(--surface-skeleton-shine) 50%,var(--surface-skeleton) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}.skeleton-title{height:18px;width:60%}.skeleton-badges{display:flex;gap:6px}.skeleton-badge{height:20px;width:44px;border-radius:6px;background:linear-gradient(90deg,var(--surface-skeleton) 25%,var(--surface-skeleton-shine) 50%,var(--surface-skeleton) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}.skeleton-bar{height:4px;width:100%}.empty-room-state{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 20px;gap:12px}.empty-state-icon{display:flex;align-items:center;justify-content:center;animation:jellyFloat 3s ease-in-out infinite}.empty-state-logo{width:90px;height:90px;object-fit:contain}.empty-state-icon--filtered .empty-state-logo{opacity:.35;filter:grayscale(60%);animation:none}.empty-state-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.empty-state-desc{font-size:14px;color:var(--text-muted);margin:0}.empty-state-actions{display:flex;gap:10px;margin-top:8px}.empty-state-cta{padding:8px 20px;background:var(--color-primary-gradient);border:none;border-radius:8px;color:var(--text-on-primary);font-size:13px;font-weight:700;cursor:pointer;transition:all .2s}.empty-state-cta:hover{filter:brightness(1.1);transform:translateY(-1px)}.empty-state-secondary{padding:8px 20px;background:var(--surface-subtle);border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s}.empty-state-secondary:hover{background:var(--surface-card);color:var(--text-primary)}.create-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--overlay-bg);backdrop-filter:var(--overlay-blur);-webkit-backdrop-filter:var(--overlay-blur);display:flex;align-items:center;justify-content:center;padding:20px}.create-modal{background:var(--surface-modal);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-subtle);border-radius:22px;padding:28px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;color:var(--text-primary);animation:jellyBounceIn .35s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--shadow-modal)}.create-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.create-modal-title{font-size:20px;font-weight:800;margin:0}.create-modal-close{background:var(--surface-subtle);border:none;color:var(--text-tertiary);width:32px;height:32px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:all .2s}.create-modal-close:hover{background:var(--surface-card);color:var(--text-primary)}.create-field{margin-bottom:20px}.create-field-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.create-name-row{display:flex;gap:8px;align-items:center}.create-name-input{flex:1;padding:10px 14px;background:var(--surface-input);border:1.5px solid var(--border-medium);border-radius:10px;color:var(--text-primary);font-size:15px;outline:none;transition:border-color .2s;box-sizing:border-box;min-width:0}.create-name-input::placeholder{color:var(--text-placeholder)}.create-name-input:focus{border-color:var(--border-focus)}.create-name-input.input-error{border-color:var(--border-error);animation:shake .3s ease}.create-name-shuffle{flex-shrink:0;width:42px;height:42px;border:1.5px solid var(--border-medium);border-radius:10px;background:var(--surface-subtle);font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0}.create-name-shuffle:hover{background:var(--color-primary-bg);border-color:var(--border-focus);transform:scale(1.05)}.create-name-shuffle:active{transform:scale(.95)}.create-mode-cards,.create-size-cards{display:grid;gap:10px}.create-mode-cards{grid-template-columns:1fr 1fr}.create-size-cards{grid-template-columns:1fr 1fr 1fr}.create-option-card{background:var(--surface-subtle);border:1.5px solid var(--border-subtle);border-radius:12px;padding:14px 10px;text-align:center;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:6px}.create-option-card:hover{background:var(--surface-card);border-color:var(--border-medium)}.create-option-card.selected{background:var(--color-primary-bg);border-color:var(--border-focus);box-shadow:0 0 12px var(--color-primary-shadow)}.create-option-icon{font-size:22px;font-weight:800;color:var(--text-tertiary);line-height:1}.create-option-card.selected .create-option-icon{color:var(--text-accent)}.create-option-name{font-size:13px;font-weight:700;color:var(--text-primary)}.create-option-card.selected .create-option-name{color:var(--text-primary)}.create-option-desc{font-size:11px;color:var(--text-muted)}.create-option-card.selected .create-option-desc{color:var(--text-tertiary)}.create-size-dots{display:grid;gap:2px;margin-bottom:4px}.create-size-dots.size-S{grid-template-columns:repeat(3,4px)}.create-size-dots.size-M{grid-template-columns:repeat(4,4px)}.create-size-dots.size-L{grid-template-columns:repeat(5,4px)}.create-size-dot{width:4px;height:4px;border-radius:1px;background:var(--border-medium)}.create-option-card.selected .create-size-dot{background:var(--color-primary-bg-hover)}.create-hint{font-size:11px;color:var(--text-muted);margin-top:6px}.player-count-selector{display:flex;align-items:center;gap:12px}.player-icons{display:flex;align-items:flex-end;gap:4px}.player-icon{position:relative;cursor:pointer;padding:2px;transition:transform .1s}.player-icon:hover{transform:translateY(-2px)}.player-icon svg{width:26px;height:26px;fill:var(--border-medium);transition:fill .15s}.player-icon.active svg{fill:var(--color-primary-bg-hover)}.player-icon.selected svg{fill:var(--color-primary)}.player-icon.disabled{cursor:default}.player-icon.disabled:not(.active):not(.selected){opacity:.3}.player-icon.disabled:hover{transform:none}.player-tooltip{position:absolute;top:-26px;left:50%;transform:translate(-50%);background:var(--color-primary);color:var(--text-on-primary);padding:2px 8px;border-radius:6px;font-size:11px;font-weight:700;white-space:nowrap;pointer-events:none;animation:fadeIn .1s ease}.player-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:var(--color-primary)}.player-count-label{font-size:15px;font-weight:700;color:var(--text-accent);min-width:32px}.create-visibility-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}.create-modal-actions{display:flex;gap:10px;margin-top:24px}.create-cancel-btn{flex:1;padding:11px;background:var(--surface-subtle);border:1px solid var(--border-subtle);border-radius:10px;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .2s}.create-cancel-btn:hover{background:var(--surface-card);color:var(--text-primary)}.create-submit-btn{flex:1.5;padding:11px;background:var(--color-primary-gradient);border:none;border-radius:10px;color:var(--text-on-primary);font-size:14px;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;box-shadow:var(--jelly-btn-depth-primary)}.create-submit-btn:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,transparent 100%);pointer-events:none}.create-submit-btn:hover{filter:brightness(1.1);transform:translateY(-2px) scale(1.02)}.create-submit-btn:active{animation:jellyPress .35s ease}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes dropdown-appear{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(4px)}75%{transform:translate(-4px)}}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.controls-row-mobile{display:none;align-items:center;gap:8px;padding-bottom:10px}@media (max-width: 768px){.lobby-nav{padding:8px 12px;gap:4px;flex-wrap:wrap}.lobby-nav-left{flex:1;min-width:0;flex-shrink:1}.lobby-nav-logo{font-size:14px;flex-shrink:0}.lobby-back-btn{padding:5px 8px;font-size:12px;flex-shrink:0}.lobby-back-btn span:last-child{display:none}.leaderboard-marquee-container{order:15;flex:0 0 100%;min-width:0;max-width:none}.lobby-nav-center{display:flex;order:10;flex:0 0 100%;max-width:none;padding-bottom:2px}.lobby-nickname-input{width:100%}.lobby-nav-right{gap:6px}.lobby-nav-right>.volume-control,.lobby-nav-right>.language-switcher,.lobby-nav-right>.accessibility-toggle{display:none}.controls-row-mobile{display:flex}.lobby-main{padding:calc(var(--lobby-nav-h, 140px) + 12px) 12px 12px}.room-toolbar{gap:6px}.room-toolbar-title{font-size:15px}.toolbar-search{flex:1 1 100%;order:10}.toolbar-invite-section{display:none}.room-grid{grid-template-columns:1fr;gap:8px}.room-filters{gap:10px;padding:10px 12px}.create-modal{padding:20px;border-radius:16px}.create-mode-cards{grid-template-columns:1fr 1fr}.create-size-cards{grid-template-columns:1fr 1fr 1fr}.player-icon svg{width:22px;height:22px}}@media (max-width: 480px){.toolbar-actions{flex-wrap:wrap}.toolbar-quick-btn span:not(:first-child){display:none}.room-card{padding:12px}.lobby-login-toggle span:nth-child(2){display:none}.lobby-user-name{display:none}}.banner-ad{width:100%;max-width:728px;height:90px;background:linear-gradient(135deg,#f5f5f5,#e8e8e8);border:1px solid rgba(0,0,0,.1);border-radius:8px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000000d}.banner-ad-content{display:flex;align-items:center;gap:12px;padding:0 16px;width:100%}.ad-badge{background:#ffb547;color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.ad-text{display:flex;flex-direction:column;gap:4px;flex:1;min-width:0}.ad-title{font-size:14px;font-weight:700;color:#333}.ad-description{font-size:12px;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 768px){.banner-ad{max-width:100%;height:80px}.ad-title{font-size:13px}.ad-description{font-size:11px}}@media (max-width: 480px){.banner-ad{height:70px}.banner-ad-content{gap:8px;padding:0 12px}.ad-title{font-size:12px}.ad-description{font-size:10px}}.qr-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:3000;padding:16px}.qr-modal{position:relative;background:linear-gradient(160deg,#2a2a35,#1a1a22);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:28px 24px 24px;width:100%;max-width:320px;display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:0 20px 60px #0009,0 0 0 1px #ffffff0d;animation:qr-pop-in .25s cubic-bezier(.175,.885,.32,1.275) forwards}@keyframes qr-pop-in{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.qr-modal-close{position:absolute;top:12px;right:14px;background:#ffffff14;border:none;color:#fff9;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:.85rem;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.qr-modal-close:hover{background:#ffffff2e;color:#fff}.qr-modal-title{font-size:1.1rem;font-weight:700;color:#fff;margin:0;text-align:center}.qr-modal-desc{font-size:.8rem;color:#ffffff8c;margin:0;text-align:center;line-height:1.4}.qr-canvas-wrapper{position:relative;width:220px;height:220px;background:#fff;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #0006}.qr-loading{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;display:flex;align-items:center;justify-content:center}.qr-loading:after{content:"";width:32px;height:32px;border:3px solid rgba(0,0,0,.1);border-top-color:#1e1e22;border-radius:50%;animation:qr-spin .7s linear infinite}@keyframes qr-spin{to{transform:rotate(360deg)}}.qr-canvas{display:block;opacity:0;transition:opacity .3s ease;border-radius:10px}.qr-canvas.ready{opacity:1}.qr-code-badge{display:flex;align-items:center;gap:8px;background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:8px 16px;width:100%;justify-content:center}.qr-code-label{font-size:.75rem;color:#ffffff80;font-weight:500}.qr-code-value{font-size:1.1rem;font-weight:800;color:gold;letter-spacing:.15em;font-family:Courier New,monospace}.qr-action-row{display:flex;gap:8px;width:100%}.qr-copy-btn{flex:1;padding:10px 14px;background:linear-gradient(135deg,#9d7bff,#7c5ce0);border:none;border-radius:10px;color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;transition:transform .15s,filter .15s,background .3s;box-shadow:0 4px 12px #9d7bff4d;white-space:nowrap}.qr-copy-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.qr-copy-btn:active{transform:translateY(0)}.qr-copy-btn.copied{background:linear-gradient(135deg,#7c5ce0,#3a9e72);box-shadow:0 4px 12px #4caf8266}.qr-share-btn{flex:1;padding:10px 14px;background:linear-gradient(135deg,#6b8eff,#4a6fe8);border:none;border-radius:10px;color:#fff;font-size:.85rem;font-weight:700;cursor:pointer;transition:transform .15s,filter .15s;box-shadow:0 4px 12px #6b8eff4d;white-space:nowrap}.qr-share-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.qr-share-btn:active{transform:translateY(0)}.emoji-picker-wrapper{position:relative;display:inline-flex;align-items:center}.emoji-picker-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border-subtle);background:var(--surface-card);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:transform .15s ease,background .15s ease;flex-shrink:0}.emoji-picker-btn:hover:not(:disabled){transform:scale(1.12);background:var(--surface-subtle)}.emoji-picker-btn:active:not(:disabled){transform:scale(.93)}.emoji-picker-btn--cooldown{opacity:.55;cursor:default}.emoji-picker-cooldown{font-size:13px;font-weight:700;color:var(--text-muted)}.emoji-picker-icon{line-height:1}.emoji-picker-popup{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);display:grid;grid-template-columns:repeat(4,1fr);gap:4px;padding:8px;background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:14px;box-shadow:0 8px 24px #0000002e;z-index:200;animation:emoji-popup-in .12s ease}@keyframes emoji-popup-in{0%{opacity:0;transform:translate(-50%) scale(.85)}to{opacity:1;transform:translate(-50%) scale(1)}}.emoji-picker-item{width:38px;height:38px;border:none;border-radius:8px;background:transparent;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .1s ease,transform .1s ease}.emoji-picker-item:hover{background:var(--surface-subtle);transform:scale(1.2)}.emoji-picker-item:active{transform:scale(.9)}.emoji-bubble{position:absolute;bottom:calc(100% + 4px);left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:2px;pointer-events:none;animation:emoji-float 3s ease forwards;z-index:50;white-space:nowrap}.emoji-bubble-icon{font-size:28px;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.25))}.emoji-bubble-name{font-size:11px;font-weight:600;color:var(--player-color, #9D7BFF);background:#00000073;padding:1px 5px;border-radius:4px;max-width:80px;overflow:hidden;text-overflow:ellipsis}@keyframes emoji-float{0%{opacity:0;transform:translate(-50%) translateY(0) scale(.5)}15%{opacity:1;transform:translate(-50%) translateY(-10px) scale(1.2)}70%{opacity:1;transform:translate(-50%) translateY(-20px) scale(1)}to{opacity:0;transform:translate(-50%) translateY(-34px) scale(.8)}}.waiting-room-container{width:100%;min-height:100vh;background:var(--bg-gradient);padding:20px 20px 40px;display:flex;flex-direction:column;position:relative;overflow-y:auto;-webkit-overflow-scrolling:touch}.waiting-room-controls{display:flex;gap:8px;align-items:center}.tutorial-icon-btn{background:none;border:none;font-size:24px;cursor:pointer;padding:4px;line-height:1}.header-actions{display:flex;align-items:center;gap:10px}.share-btn-header{background:var(--color-primary-bg);color:var(--text-primary);border:1px solid var(--border-medium);padding:8px 16px;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);display:flex;align-items:center;gap:6px}.share-btn-header:hover{background:var(--color-primary-bg-hover);transform:translateY(-2px) scale(1.02);box-shadow:0 4px 12px var(--color-primary-shadow)}.share-btn-header:active{transform:translateY(0)}.control-icon-btn{width:40px;height:40px;border:none;background:var(--surface-card);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;box-shadow:0 2px 8px #0000001a}.control-icon-btn:hover{background:var(--surface-card-hover);transform:scale(1.05);box-shadow:0 4px 12px #00000026}.control-icon-btn:active{transform:scale(.95)}.control-icon-btn .icon-text{font-size:20px}.waiting-room-header{max-width:1200px;width:100%;margin:0 auto 20px;display:flex;justify-content:space-between;align-items:center;gap:10px;padding:20px 24px;background:var(--surface-card);border-radius:16px;box-shadow:var(--shadow-card)}.room-title{display:flex;align-items:center;gap:16px;min-width:0;flex:1}.waiting-room-logo{width:60px;height:60px;flex-shrink:0}.waiting-room-logo .interactive-logo-image{width:100%;height:100%;object-fit:contain}.room-title-info{display:flex;flex-direction:column;gap:8px;min-width:0;flex:1}.room-title-container{overflow:hidden;width:100%}.room-title-slide-wrapper{display:flex;flex-wrap:nowrap}.room-title-slide{display:flex;align-items:center;flex-wrap:nowrap;flex-shrink:0}.room-title-slide.clone{display:none}.room-title h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0;white-space:nowrap;width:max-content;padding-right:2em}.room-title-container.overflow .room-title-slide.clone{display:flex}.room-title-container.overflow .room-title-slide.original{animation:infiniteAnimation1 18s linear infinite}.room-title-container.overflow .room-title-slide.clone{animation:infiniteAnimation2 18s linear infinite}@keyframes infiniteAnimation1{0%{transform:translate(0)}50%{transform:translate(-100%)}50.1%{transform:translate(100%)}to{transform:translate(0)}}@keyframes infiniteAnimation2{0%{transform:translate(0)}to{transform:translate(-200%)}}.room-info-badges{display:flex;gap:8px}.room-info-badge{padding:6px 12px;background:var(--color-primary-bg);border-radius:6px;font-size:13px;color:var(--text-primary);font-weight:500}.invite-section{max-width:1200px;width:100%;margin:0 auto 20px;background:var(--surface-card);border-radius:16px;box-shadow:var(--shadow-card);padding:16px 24px}.invite-section-content{display:flex;flex-direction:column;gap:10px}.invite-action-row{display:flex;gap:10px;flex-wrap:wrap}.invite-code-box{display:flex;flex-direction:column;gap:6px;padding:12px 16px;background:var(--color-primary-bg);border:2px solid var(--border-strong);border-radius:12px;transition:all .3s;flex:1}.invite-code-box:hover{border-color:var(--border-strong);background:var(--color-primary-bg-hover)}.invite-code-label{font-size:11px;color:var(--text-primary);font-weight:600;text-transform:uppercase;letter-spacing:.5px;opacity:.8}.invite-code-content{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.invite-code-value{font-size:18px;font-weight:700;color:var(--color-primary);font-family:Courier New,monospace;letter-spacing:2px;text-shadow:0 1px 3px var(--color-primary-shadow);min-width:90px;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;cursor:text}.invite-code-hidden{font-size:18px;font-weight:700;color:var(--text-muted);letter-spacing:3px;min-width:90px}.invite-code-actions{display:flex;gap:6px;margin-left:auto;flex-wrap:wrap}.invite-code-display{display:flex;align-items:center;gap:8px}.invite-icon-btn{min-width:34px;height:34px;padding:6px 8px;font-size:16px;background:var(--color-primary-bg-hover);color:var(--text-primary);border:none;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.invite-icon-btn--labeled{gap:6px;padding:6px 12px;font-size:13px;font-weight:600;height:auto;min-width:auto}.invite-icon-btn:hover{background:var(--color-primary-bg-hover);transform:translateY(-2px) scale(1.02)}.invite-icon-btn:active{transform:translateY(0)}.share-link-btn{padding:8px 16px;font-size:14px;font-weight:700;background:var(--color-primary-gradient);color:var(--text-on-primary);border:none;border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--jelly-btn-depth-primary);position:relative;overflow:hidden}.share-link-btn:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,transparent 100%);border-radius:8px 8px 0 0;pointer-events:none}.share-link-btn:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 4px 12px var(--color-primary-shadow-hover)}.share-link-btn:active{transform:translateY(0);animation:jellyPress .35s ease}.leave-btn{padding:10px 20px;font-size:14px;font-weight:700;background:var(--color-error, #FF6B6B);color:var(--text-on-primary);border:none;border-radius:8px;cursor:pointer;transition:transform .2s}.leave-btn:hover{transform:translateY(-2px) scale(1.02)}.waiting-room-content{max-width:1200px;width:100%;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:20px;flex:1;align-items:start;position:relative}.waiting-room-main{display:contents}.players-section{background:var(--surface-card);border-radius:16px;padding:24px;box-shadow:var(--shadow-card);border-bottom:2px solid var(--border-medium);position:relative;overflow:visible;transition:all .2s cubic-bezier(.34,1.56,.64,1)}.players-section:before{content:"";position:absolute;top:0;left:0;right:0;height:40px;background:linear-gradient(180deg,rgba(255,255,255,.12) 0%,transparent 100%);pointer-events:none;z-index:1}.players-section h2{margin:0 0 16px;font-size:20px;color:var(--text-primary);display:flex;align-items:center;gap:12px;flex-wrap:wrap}.team-hint{font-size:13px;font-weight:400;color:var(--text-secondary);background:var(--color-primary-bg);padding:4px 12px;border-radius:12px}.players-list{display:flex;flex-direction:column;gap:12px}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.player-item{display:flex;justify-content:space-between;align-items:center;padding:16px;background:var(--color-primary-bg);border:2px solid var(--border-subtle);border-radius:12px;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;animation:slideIn .3s ease-out}.player-item--emoji-host{position:relative}.player-item:hover{transform:translate(4px);box-shadow:0 2px 8px var(--color-primary-shadow)}.player-left{display:flex;align-items:center;gap:12px;flex:1}.player-color-indicator{width:32px;height:32px;border-radius:50%;border:3px solid white;box-shadow:0 2px 8px #00000026}.player-item .player-name{font-size:16px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.host-badge{padding:2px 8px;background:linear-gradient(135deg,gold,orange);color:#fff;border-radius:4px;font-size:12px;font-weight:700}.me-badge{padding:2px 8px;background:var(--color-primary-gradient);color:var(--text-on-primary);border-radius:4px;font-size:12px;font-weight:700}.team-badge{padding:2px 8px;border-radius:4px;font-size:12px;font-weight:700;color:#fff}.team-badge.team-A{background:linear-gradient(135deg,#ff8f7e,#ff6b6b)}.team-badge.team-B{background:linear-gradient(135deg,#87ceeb,#4682b4)}.player-status{font-size:14px;font-weight:600;min-width:80px;text-align:right;display:flex;align-items:center;gap:8px;justify-content:flex-end}.status-ready{color:var(--color-primary);font-weight:600;animation:slideIn .3s ease-out}.status-waiting{color:var(--text-muted);transition:color .3s ease}.status-playing{color:var(--color-primary);font-weight:600}.status-spectating{color:var(--text-muted);font-weight:600}.kick-btn{padding:4px 8px;font-size:14px;background:var(--error-bg);color:var(--color-error, #FF6B6B);border:1px solid rgba(255,107,107,.3);border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.kick-btn:hover{background:var(--error-bg-hover);border-color:var(--color-error, #FF6B6B);transform:scale(1.05)}.kick-btn:active{transform:scale(.95)}.transfer-host-btn{min-width:30px;height:28px;padding:4px 8px;font-size:16px;background:#ffd7001a;color:#b8860b;border:1px solid rgba(255,215,0,.3);border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.transfer-host-btn:hover{background:#ffd70033;border-color:#b8860b;transform:scale(1.05)}.transfer-host-btn:active{transform:scale(.95)}.settings-section{background:var(--surface-card);border-radius:16px;padding:24px;box-shadow:var(--shadow-card);border-bottom:2px solid var(--border-medium);display:flex;flex-direction:column;gap:24px;position:relative;overflow:hidden;transition:all .2s cubic-bezier(.34,1.56,.64,1)}.settings-section:before{content:"";position:absolute;top:0;left:0;right:0;height:40px;background:linear-gradient(180deg,rgba(255,255,255,.12) 0%,transparent 100%);pointer-events:none;z-index:1}.setting-group h3{margin:0 0 12px;font-size:18px;color:var(--text-primary)}.color-palette{display:grid;grid-template-columns:repeat(8,1fr);gap:8px}.color-option{width:100%;aspect-ratio:1;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .2s;position:relative;display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.color-option:hover:not(:disabled){transform:scale(1.1);box-shadow:0 4px 12px #0003}.color-option.selected{border-color:#fff;box-shadow:0 0 0 3px var(--text-primary),0 4px 12px #0003}.color-option.taken{opacity:.4;cursor:not-allowed}.color-option.locked{opacity:.45;cursor:not-allowed;filter:grayscale(40%)}.lock-mark{font-size:14px;line-height:1}.check-mark{font-weight:700}.x-mark{font-size:20px}.team-name-input{padding:6px 12px;font-size:14px;border:2px solid var(--border-medium);border-radius:6px;outline:none;transition:border-color .2s;background:#fff;color:var(--text-primary);font-weight:500;min-width:120px}.team-name-input:focus{border-color:var(--border-focus)}.team-name-input::placeholder{color:var(--text-muted)}.waiting-room-ad-section-top{margin:16px 0;display:flex;justify-content:center;width:100%;padding:0 20px}.recent-matches-sidebar{background:var(--surface-card);border-radius:16px;padding:20px;box-shadow:var(--shadow-card);border:2px solid var(--border-subtle);border-bottom:2px solid var(--border-medium);position:fixed;overflow:hidden;left:calc((100vw - 1200px)/2 - 300px);top:200px;width:280px;max-height:calc(100vh - 220px);display:flex;flex-direction:column;z-index:10}@media (max-width: 1600px){.recent-matches-sidebar{display:none}}.recent-matches-sidebar:before{content:"";position:absolute;top:0;left:0;right:0;height:40px;background:linear-gradient(180deg,rgba(255,255,255,.12) 0%,transparent 100%);pointer-events:none;z-index:1}.recent-matches-header-sidebar{margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid var(--border-subtle)}.recent-matches-header-sidebar h3{margin:0;font-size:18px;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:6px}.recent-matches-list-sidebar{display:flex;flex-direction:column;gap:12px;overflow-y:auto;padding-right:4px}.recent-matches-list-sidebar::-webkit-scrollbar{width:6px}.recent-matches-list-sidebar::-webkit-scrollbar-track{background:var(--surface-subtle);border-radius:10px}.recent-matches-list-sidebar::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:10px;transition:background .2s}.recent-matches-list-sidebar::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}.recent-matches-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;text-align:center;color:var(--text-muted);font-size:14px;gap:4px}.recent-matches-empty .empty-hint{font-size:12px;color:var(--text-muted)}.recent-match-card-sidebar{background:var(--surface-subtle);border:1px solid var(--border-subtle);border-radius:12px;padding:12px;transition:all .2s ease;display:flex;flex-direction:column;gap:10px}.recent-match-card-sidebar:hover{background:var(--color-primary-bg);border-color:var(--border-medium);transform:translate(2px);box-shadow:0 2px 8px var(--color-primary-shadow)}.match-info-sidebar{display:flex;flex-direction:column;gap:8px}.match-stat-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.match-stat-label{font-size:11px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.match-stat-value{font-size:13px;color:var(--text-primary);font-weight:700}.match-mode-badge-sidebar{font-size:12px;font-weight:700;color:var(--text-primary);background:var(--color-primary-bg-hover);padding:4px 10px;border-radius:6px}.match-top-score{color:var(--color-error, #FF6B6B);font-size:14px}.match-rank-winner{color:#8a6d00;font-size:12px;max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.match-rank-loser{color:#8c4c4c;font-size:12px;max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.replay-sidebar-btn{width:100%;padding:8px 12px;background:linear-gradient(135deg,#9d7bff,#7c5ce0);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #9d7bff33;display:flex;align-items:center;justify-content:center;gap:4px}.replay-sidebar-btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 4px 12px #9d7bff4d}.replay-sidebar-btn:active{transform:translateY(0)}.recent-matches-section{margin-top:20px;padding:16px;background:var(--surface-subtle);border:1px solid var(--border-subtle);border-radius:12px;display:none}@media (max-width: 1600px){.recent-matches-section{display:block}}.recent-matches-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.recent-matches-header h4{margin:0;font-size:16px;font-weight:700;color:var(--text-primary)}.toggle-recent-btn{background:transparent;border:none;color:var(--color-primary);font-size:14px;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s}.toggle-recent-btn:hover{background:var(--color-primary-bg)}.recent-matches-list{display:flex;flex-direction:column;gap:10px}.recent-match-card{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--surface-card);border:2px solid var(--border-subtle);border-radius:10px;transition:all .2s;gap:16px}.recent-match-card:hover{border-color:var(--border-strong);box-shadow:0 2px 8px var(--color-primary-shadow)}.match-info{flex:1;display:flex;flex-direction:column;gap:8px;max-width:70%}.recent-match-card .match-stat-row{display:flex;justify-content:flex-start;align-items:center;gap:16px}.recent-match-card .match-stat-label{font-size:11px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px;min-width:60px}.recent-match-card .match-stat-value{font-size:13px;color:var(--text-primary);font-weight:700;flex:0 0 auto}.recent-match-card .match-mode-badge{font-size:12px;font-weight:700;color:var(--text-primary);background:var(--color-primary-bg-hover);padding:4px 10px;border-radius:6px}.recent-match-card .match-top-score{color:var(--color-error, #FF6B6B);font-size:14px}.replay-small-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#9d7bff,#7c5ce0);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:16px;transition:all .2s;flex-shrink:0}.replay-small-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #9d7bff4d}.replay-small-btn:active{transform:scale(.95)}.host-only-label{font-size:12px;color:var(--text-muted);font-weight:400}.team-mode-selection{display:grid;grid-template-columns:1fr 1fr;gap:12px}.mode-btn{padding:14px;font-size:16px;font-weight:700;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);background:var(--color-primary-bg);color:var(--text-primary)}.mode-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.02);box-shadow:0 2px 8px #0000001a}.mode-btn:disabled{opacity:.5;cursor:not-allowed}.mode-btn.individual.selected{background:var(--color-primary-gradient);color:var(--text-on-primary);border-color:var(--color-primary-end)}.mode-btn.team.selected{background:linear-gradient(135deg,#ff8f7e,#ff6b6b);color:#fff;border-color:#ff6b6b}.game-settings{display:flex;flex-direction:column;gap:12px}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-primary-bg);border-radius:8px;font-size:14px;color:var(--text-primary)}.setting-value{font-weight:700;color:var(--color-primary-end);max-width:60%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:right}.setting-item-ranking-info .setting-value.ranking-category-info{font-size:.78rem;white-space:normal;text-align:right;display:flex;flex-wrap:wrap;justify-content:flex-end;gap:2px}.rank-cat{font-size:.75rem;border-radius:4px;padding:1px 5px;white-space:nowrap}.rank-cat-individual{background:#6450c833;color:#b09ae8}.rank-cat-team{background:#50966433;color:#7acca0}.setting-select{padding:6px 12px;font-size:14px;font-weight:700;color:var(--text-primary);background:var(--surface-input);border:2px solid var(--border-medium);border-radius:6px;outline:none;cursor:pointer;transition:border-color .2s;max-width:60%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.setting-select:hover{border-color:var(--color-primary)}.setting-select:focus{border-color:var(--border-focus)}[data-theme=dark] .setting-select option{background:#1e1630;color:#e6dcf5eb}.mobile-action-btn{display:none;text-align:center}.waiting-room-footer{max-width:1200px;width:100%;margin:20px auto 0;display:flex;flex-direction:column;align-items:center;gap:8px}.keyboard-shortcut-hint{font-size:12px;color:var(--text-muted);margin:0;letter-spacing:.02em}.switch-to-spectator-btn{margin-left:auto;padding:4px 10px;font-size:11px;font-weight:600;background:#9d7bff1a;color:var(--color-primary);border:1px solid rgba(157,123,255,.3);border-radius:6px;cursor:pointer;transition:all .2s;flex-shrink:0}.switch-to-spectator-btn:hover:not(:disabled){background:#9d7bff33;color:var(--color-primary)}.switch-to-spectator-btn:disabled{opacity:.3;cursor:not-allowed}.spectator-item.spectator-me{background:#ffffff0f;border-radius:8px;padding:4px 8px}.switch-to-player-btn{padding:3px 8px;font-size:11px;font-weight:600;background:#9d7bff26;color:#9d7bffe6;border:1px solid rgba(157,123,255,.3);border-radius:6px;cursor:pointer;transition:all .2s;margin-left:6px}.switch-to-player-btn:hover{background:#9d7bff47}.spectating-footer-actions{display:flex;gap:10px;align-items:center}.switch-to-player-btn-footer{padding:14px 28px;font-size:15px;font-weight:600;border:none;border-radius:12px;cursor:pointer;background:linear-gradient(135deg,#9d7bff,#8b68ee);color:#fff;transition:all .2s}.switch-to-player-btn-footer:hover{transform:translateY(-1px);box-shadow:0 4px 12px #9d7bff66}.no-spectators-hint{font-size:12px;color:var(--text-muted);margin:4px 0 0;font-style:italic}.leave-spectate-btn{padding:14px 36px;font-size:15px;font-weight:600;border:1px solid rgba(180,180,180,.3);border-radius:12px;cursor:pointer;background:#b4b4b41f;color:#ffffffb3;transition:all .2s}.leave-spectate-btn:hover{background:#b4b4b438;color:#fffffff2}.start-btn,.ready-btn{padding:16px 48px;font-size:18px;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--jelly-btn-depth-primary);position:relative;overflow:hidden}.start-btn:before,.ready-btn:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,transparent 100%);border-radius:12px 12px 0 0;pointer-events:none}.start-btn{background:var(--color-primary-gradient);color:var(--text-on-primary)}.start-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.03);box-shadow:0 6px 16px var(--color-primary-shadow-hover)}.start-btn:active:not(:disabled){animation:jellyPress .35s ease}.start-btn:disabled{background:#ccc;cursor:not-allowed;color:var(--text-secondary);box-shadow:none}.start-btn:disabled:before{display:none}.ready-btn{background:var(--color-primary-bg-hover);color:var(--text-primary);border:2px solid var(--color-primary)}.ready-btn.ready{background:var(--color-primary-gradient);color:var(--text-on-primary)}.ready-btn:hover{transform:translateY(-2px) scale(1.03)}.ready-btn:active{animation:jellyPress .35s ease}.teams-container{display:flex;flex-direction:column;gap:16px}.team-lb-info-banner{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:10px;font-size:13px;font-weight:600;background:var(--color-primary-bg);border:1.5px solid var(--border-medium);color:var(--text-secondary);margin-bottom:12px;transition:all .3s}.team-lb-info-banner.eligible{background:#5cb85c1a;border-color:#5cb85c;color:#3a7f3a}.team-lb-info-banner .team-lb-info-icon{font-size:16px;flex-shrink:0}.team-header-right{display:flex;align-items:center;gap:8px}.team-lb-badge{font-size:12px;font-weight:700;padding:3px 8px;border-radius:10px;cursor:default;transition:all .2s;white-space:nowrap}.team-lb-badge.eligible{background:#5cb85c33;color:#3a7f3a;border:1px solid #5cb85c}.team-lb-badge.ineligible{background:#0000000f;color:var(--text-secondary);border:1px solid var(--border-medium)}.player-login-badge{font-size:13px;margin-left:4px;cursor:default;opacity:.75;transition:opacity .15s;vertical-align:middle}.player-login-badge.logged-in{opacity:1}.player-login-badge.guest{opacity:.45}.team-group-box{background:var(--color-primary-bg);border:3px solid var(--border-strong);border-radius:12px;padding:12px;transition:all .2s}.team-group-box:hover{border-color:var(--color-primary);box-shadow:0 4px 16px var(--color-primary-shadow)}.team-group-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--color-primary-gradient);border-radius:8px;margin-bottom:12px}.team-group-title{font-size:16px;font-weight:700;color:var(--text-on-primary);text-shadow:1px 1px 2px rgba(0,0,0,.2)}.team-member-count{font-size:14px;font-weight:700;color:var(--text-on-primary);background:#fff3;padding:4px 10px;border-radius:12px}.team-players-list{display:flex;flex-direction:column;gap:8px}.team-name-with-join{display:flex;align-items:center;gap:6px;margin-left:auto}.join-team-btn-small{width:28px;height:28px;padding:0;font-size:14px;background:var(--color-primary-gradient);color:var(--text-on-primary);border:none;border-radius:6px;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:var(--jelly-btn-depth-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.join-team-btn-small:hover{transform:scale(1.1);box-shadow:0 3px 10px var(--color-primary-shadow-hover)}.join-team-btn-small:active{transform:scale(.95)}.force-start-warning-panel{background:var(--surface-modal);padding:40px;border-radius:22px;text-align:center;box-shadow:0 8px 32px #0003;min-width:400px;max-width:500px}.force-start-warning-panel h2{font-size:28px;color:var(--color-error, #FF6B6B);margin-bottom:20px}.warning-message{font-size:16px;color:var(--text-secondary);margin-bottom:30px;line-height:1.6}.warning-buttons{display:flex;gap:12px;justify-content:center}.cancel-btn{padding:12px 32px;font-size:16px;font-weight:600;background:#e0e0e0;color:var(--text-secondary);border:none;border-radius:12px;cursor:pointer;transition:all .2s}.cancel-btn:hover{background:#d0d0d0;transform:translateY(-2px) scale(1.02)}.force-start-btn{padding:12px 32px;font-size:16px;font-weight:600;background:linear-gradient(135deg,#ff8f7e,#ff6b6b);color:var(--text-on-primary);border:none;border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 12px #ff6b6b4d;position:relative;overflow:hidden}.force-start-btn:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,transparent 100%);border-radius:12px 12px 0 0;pointer-events:none}.force-start-btn:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 6px 16px #ff6b6b66}.force-start-btn:active{transform:translateY(0);animation:jellyPress .35s ease}@media (max-width: 900px){.waiting-room-content{display:flex;flex-direction:column}.waiting-room-main{display:flex;flex-direction:column;width:100%}.players-section{order:1}.mobile-action-btn{order:2;display:flex;justify-content:center;align-items:center;width:100%;margin:12px 0;padding:0}.settings-section{order:3}.waiting-room-footer,.recent-matches-sidebar{display:none}.recent-matches-section{display:block;order:4}.player-left{flex-wrap:wrap}.team-name-with-join{width:100%;margin-left:0;margin-top:8px}}@media (max-width: 768px){.waiting-room-container{padding:0 12px 20px;min-height:100vh}.waiting-room-header{position:sticky;top:0;z-index:100;flex-wrap:wrap;align-items:center;gap:4px;padding:8px 12px;margin:0 -12px 14px;width:calc(100% + 24px);border-radius:0}.header-actions{display:flex;align-items:center;gap:4px;flex-shrink:0;order:2}.room-title{gap:6px;flex:1;min-width:0;order:1}.waiting-room-controls{order:3;flex:0 0 100%;justify-content:center;padding-top:4px;border-top:1px solid rgba(255,255,255,.06)}.waiting-room-logo{width:28px;height:28px}.room-title h1{font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.room-info-badges{display:flex;flex-wrap:wrap;gap:4px}.room-info-badge{font-size:11px;padding:3px 8px}.control-icon-btn{width:32px;height:32px}.tutorial-icon-btn{font-size:18px}.leave-btn{padding:5px 10px;font-size:12px;white-space:nowrap}.invite-section{padding:10px 14px;margin-bottom:12px}.invite-section-content{gap:8px}.invite-code-box{padding:10px 12px}.invite-code-label{font-size:10px}.invite-code-value{font-size:16px}.invite-code-actions{gap:4px}.invite-icon-btn{padding:5px 9px;font-size:15px}.share-link-btn{width:100%;padding:8px 14px;font-size:13px}.waiting-room-content{display:flex;flex-direction:column;gap:12px}.waiting-room-main{display:flex;flex-direction:column;width:100%}.players-section{order:1;padding:14px;border-radius:12px}.settings-section{order:3;padding:14px;border-radius:12px}.players-section h2{font-size:16px;margin-bottom:12px;flex-wrap:wrap}.team-hint{font-size:12px;padding:3px 10px}.players-list{gap:8px}.player-item{padding:12px;border-radius:10px;gap:10px;flex-direction:row;align-items:center}.player-left{flex-direction:row;gap:10px;flex:1;align-items:center;min-width:0}.player-color-indicator{width:28px;height:28px;flex-shrink:0}.player-item .player-name{font-size:14px;gap:6px;flex-wrap:wrap;flex:1;min-width:0}.host-badge,.me-badge,.team-badge{font-size:11px;padding:2px 6px;white-space:nowrap}.player-status{flex-shrink:0;justify-content:flex-end;font-size:13px}.kick-btn{padding:3px 7px;font-size:13px}.setting-group h3{font-size:16px;margin-bottom:10px}.color-palette{grid-template-columns:repeat(6,1fr);gap:6px}.color-option{border-radius:10px}.team-name-input{padding:5px 10px;font-size:13px;min-width:100px}.team-mode-selection{gap:8px}.mode-btn{padding:12px;font-size:15px}.game-settings{gap:8px}.setting-item{padding:10px 14px;font-size:13px;border-radius:8px}.setting-value{font-size:13px}.setting-select{padding:5px 10px;font-size:13px}.recent-matches-section{margin-top:12px;padding:12px}.recent-matches-header h4{font-size:15px}.toggle-recent-btn{font-size:13px}.recent-match-card{padding:10px}.match-room-name{font-size:13px}.match-mode-badge{font-size:10px;padding:2px 6px}.match-details{font-size:11px}.replay-small-btn{width:32px;height:32px;font-size:14px}.mobile-action-btn{display:flex;justify-content:center;align-items:center;width:100%;margin:12px 0;padding:0;order:2}.waiting-room-footer{display:none}.start-btn,.ready-btn{width:100%;max-width:none;padding:13px 28px;font-size:15px}.force-start-warning-panel{min-width:auto;width:90%;padding:20px}.force-start-warning-panel h2{font-size:20px;margin-bottom:16px}.warning-message{font-size:14px;margin-bottom:24px}.warning-buttons{gap:10px}.cancel-btn,.force-start-btn{padding:11px 28px;font-size:15px}}@media (max-width: 480px){.waiting-room-container{padding:0 8px 16px}.waiting-room-controls{gap:4px}.control-icon-btn{width:28px;height:28px}.control-icon-btn .icon-text{font-size:16px}.waiting-room-header{padding:7px 10px;margin:0 -8px 10px;width:calc(100% + 16px);gap:4px}.waiting-room-logo{width:22px;height:22px}.header-actions{gap:3px}.room-title h1{font-size:14px}.room-info-badges{display:flex}.room-info-badge{padding:2px 6px;font-size:10px}.leave-btn-text{display:none}.leave-btn{padding:6px 8px}.invite-section{padding:9px 12px;margin-bottom:10px}.invite-code-box{padding:9px 11px}.invite-code-value{font-size:15px}.invite-icon-btn{padding:4px 8px;font-size:14px}.share-link-btn{padding:7px 12px;font-size:12px}.waiting-room-content{gap:10px}.players-section,.settings-section{padding:12px;border-radius:10px}.players-section h2{font-size:15px;margin-bottom:10px}.team-hint{font-size:11px;padding:3px 8px}.players-list{gap:6px}.player-item{padding:10px;border-radius:8px;flex-direction:row;align-items:center}.player-left{flex-direction:row;gap:8px}.player-color-indicator{width:24px;height:24px;flex-shrink:0}.player-item .player-name{font-size:13px;gap:5px}.host-badge,.me-badge,.team-badge{font-size:10px;padding:2px 5px;white-space:nowrap}.player-status{font-size:12px;flex-shrink:0}.kick-btn{padding:3px 6px;font-size:12px}.setting-group h3{font-size:15px}.color-palette{grid-template-columns:repeat(4,1fr);gap:5px}.color-option{font-size:14px}.team-name-input{font-size:12px;padding:4px 9px}.mode-btn{padding:11px;font-size:14px}.setting-item{padding:9px 12px;font-size:12px}.setting-value{font-size:12px}.setting-select{padding:4px 9px;font-size:12px}.recent-matches-section{padding:10px}.recent-matches-header h4{font-size:14px}.match-room-name{font-size:12px}.match-details{font-size:10px}.replay-small-btn{width:30px;height:30px;font-size:13px}.start-btn,.ready-btn{padding:12px 24px;font-size:14px}.force-start-warning-panel{width:92%;padding:18px}.force-start-warning-panel h2{font-size:18px}.warning-message{font-size:13px}.cancel-btn,.force-start-btn{padding:10px 24px;font-size:14px}}@media (max-height: 600px) and (orientation: landscape){.waiting-room-container{padding:10px}.waiting-room-header{padding:12px 16px;margin-bottom:12px}.room-title h1{font-size:20px}.waiting-room-content{display:grid;grid-template-columns:1fr 1fr;gap:12px}.waiting-room-main{display:contents}.players-section,.settings-section{padding:12px}.start-btn,.ready-btn{padding:10px 24px;font-size:15px}.recent-matches-sidebar{display:none}.recent-matches-section{display:block}.mobile-action-btn{display:none}.waiting-room-footer{display:flex}}.waiting-room-notification{position:fixed;top:120px;left:50%;transform:translate(-50%);background:var(--color-primary-gradient);color:var(--text-on-primary);padding:16px 32px;border-radius:12px;font-size:18px;font-weight:700;box-shadow:0 8px 24px var(--color-primary-shadow-hover);z-index:10000;animation:notificationSlideIn .3s ease-out;border:2px solid rgba(255,255,255,.3);max-width:90%;text-align:center}@keyframes notificationSlideIn{0%{transform:translate(-50%) translateY(-20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.spectators-section{margin-top:12px;padding:16px;background:var(--surface-card);border:1px solid var(--border-subtle);border-radius:12px;box-shadow:var(--shadow-card)}.spectators-header{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.spectator-eye-icon{font-size:14px;opacity:.7}.spectator-count-badge{margin-left:auto;background:var(--color-primary-bg);color:var(--color-primary);font-size:11px;font-weight:700;padding:1px 7px;border-radius:10px}.spectators-list{display:flex;flex-direction:column;gap:8px}.top-bar{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--surface-nav);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid rgba(157,123,255,.15);box-shadow:0 2px 12px #9d7bff0f;width:100%;z-index:100;transition:transform .3s ease}.top-bar.collapsed{transform:translateY(-100%)}@media (max-width: 768px) and (orientation: portrait) and (max-height: 700px){.top-bar{display:none}}.topbar-toggle-btn{display:none;position:fixed;top:0;left:50%;transform:translate(-50%);z-index:101;background:#9d7bffe6;color:#fff;border:none;padding:4px 16px;border-radius:0 0 8px 8px;cursor:pointer;font-size:12px;transition:all .3s ease;box-shadow:0 2px 8px #9d7bff4d}.topbar-toggle-btn:hover{background:#9d7bff}.topbar-toggle-btn:active{transform:translate(-50%) scale(.95)}.top-bar-left,.top-bar-right{display:flex;align-items:center;gap:8px}.logo-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #9d7bff4d;position:relative;overflow:hidden;flex-shrink:0}.logo-icon-img{width:100%;height:100%;object-fit:contain;display:block;pointer-events:none}.logo-shine{position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.45),transparent);animation:logo-shine-sweep 3s ease-in-out infinite;pointer-events:none}@keyframes logo-shine-sweep{0%{left:-100%}50%,to{left:150%}}.logo-btn{display:flex;align-items:center;gap:8px;background:none;border:none;padding:4px 6px;margin:-4px -6px;border-radius:8px;cursor:default}.logo-btn.logo-btn-clickable{cursor:pointer;transition:background .2s}.logo-btn.logo-btn-clickable:hover{background:#9d7bff1a}.exit-confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:2000;display:flex;align-items:center;justify-content:center}.exit-confirm-dialog{background:#fff;border-radius:16px;padding:28px 24px;max-width:300px;width:90%;text-align:center;box-shadow:0 8px 32px #00000040}.exit-confirm-msg{font-size:15px;color:#333;line-height:1.5;margin:0 0 20px}.exit-confirm-buttons{display:flex;gap:10px;justify-content:center}.exit-confirm-yes{padding:10px 22px;background:var(--color-primary, #9d7bff);color:#fff;border:none;border-radius:25px;font-size:14px;font-weight:700;cursor:pointer;transition:opacity .2s}.exit-confirm-yes:hover{opacity:.85}.exit-confirm-no{padding:10px 22px;background:var(--surface-subtle, #f0f0f0);color:var(--text-secondary, #555);border:none;border-radius:25px;font-size:14px;font-weight:700;cursor:pointer;transition:background .2s}.exit-confirm-no:hover{background:var(--surface-card, #e8e8e8)}.icon-button{width:32px;height:32px;border:none;background:#9d7bff1a;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:#9d7bff}.icon-button:hover{background:#9d7bff33;transform:scale(1.05)}.icon-button:active{transform:scale(.95)}.icon-button.muted{background:#ff7e6a26;color:#ff7e6a}.icon-text{font-size:14px}.language-selector{position:relative}.language-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;padding:6px;min-width:140px;z-index:1000;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.language-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;background:transparent;border-radius:6px;cursor:pointer;transition:background .2s ease;font-size:13px;color:#3a2d60}.language-option:hover{background:#9d7bff1a}.language-option.active{background:#9d7bff26;font-weight:600}.lang-flag{font-size:16px;flex-shrink:0}.lang-code-badge{font-size:11px;font-weight:700;letter-spacing:.04em;font-family:monospace;color:#ffffffd9;min-width:22px;text-align:center;flex-shrink:0}.lang-button .lang-code-badge{font-size:12px}.lang-name{flex:1;text-align:left}.lang-check{font-size:12px;color:#9d7bff;font-weight:700}@media (max-width: 768px){.top-bar{padding:4px 8px}.logo-icon{width:32px;height:32px}.icon-button{width:26px;height:26px}.icon-text{font-size:11px}}@media (max-height: 600px) and (orientation: landscape) and (max-width: 1024px){.topbar-toggle-btn{display:flex}.top-bar{position:fixed;top:0;left:0;right:0;background:#00000073;border-bottom:none;box-shadow:none;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);padding:4px 8px;z-index:110}.top-bar-left{position:fixed;left:8px;top:8px;transform:none;flex-direction:column;gap:3px}.top-bar-right{position:fixed;right:8px;top:8px;flex-direction:column;gap:3px}.logo-icon{width:32px;height:32px}.icon-button{width:28px;height:28px}.icon-text{font-size:12px}}.time-gauge-container{width:70vw;max-width:900px;margin:8px auto;padding:0 16px;transition:all .3s ease}.time-gauge-bar{height:6px;border-radius:999px;background:#0003;overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.2);box-shadow:0 1px 4px #0000001a;transition:height .3s ease,box-shadow .3s ease}.time-gauge-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#4caf50,#ffc107,#ff5722);transition:width 1s linear;position:relative;box-shadow:inset 0 1px 2px #ffffff4d}.time-gauge-labels{display:flex;justify-content:space-between;margin-top:4px;padding:0 4px}.time-current{font-size:13px;font-weight:800;color:#2e7d32;text-shadow:0 1px 2px rgba(255,255,255,.8);background:#fffc;padding:2px 8px;border-radius:6px;transition:color .3s ease,background .3s ease}.time-max{font-size:13px;font-weight:800;color:#424242;text-shadow:0 1px 2px rgba(255,255,255,.8);background:#ffffffb3;padding:2px 8px;border-radius:6px}.time-gauge-container.warning .time-gauge-bar{height:8px;animation:gauge-pulse 1s ease-in-out infinite}.time-gauge-container.warning .time-current{color:#e65100;background:#ffc864e6}.time-gauge-container.critical .time-gauge-bar{height:12px;animation:gauge-pulse .5s ease-in-out infinite;box-shadow:0 0 12px #ff500080}.time-gauge-container.critical .time-current{color:#b71c1c;background:#ff9664f2}.time-gauge-container.extreme .time-gauge-bar{height:12px;animation:gauge-pulse .25s ease-in-out infinite;box-shadow:0 0 20px #ff0000b3}.time-gauge-container.extreme .time-current{color:#fff;background:#c80000e6}@keyframes gauge-pulse{0%,to{opacity:1}50%{opacity:.6}}@media (max-width: 768px){.time-gauge-container{max-width:400px;padding:0 8px}.time-gauge-labels{font-size:10px}}@media (max-height: 600px) and (orientation: landscape) and (max-width: 1024px){.time-gauge-container{width:auto;flex:1;max-width:none;margin:0;padding:0}.time-gauge-bar{height:5px}.time-gauge-labels{display:none}}.psc-panel{display:flex;flex-direction:column;gap:6px;padding:8px;background:#1a14328c;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(157,123,255,.2);border-radius:10px;width:100%;overflow:hidden}.psc-panel .player-card{background:#ffffff14}.psc-panel .player-card.current{background:#ffb5472e}.psc-panel .player-name{color:#ffffffe6}.player-scoreboard-split{display:contents}.player-scoreboard-side{display:flex;flex-direction:column;gap:6px;padding:8px;background:#ffffff80;border-radius:8px;flex-shrink:0;width:fit-content}.player-scoreboard-side.left{align-items:flex-start;order:-1}.player-scoreboard-side.right{align-items:flex-end;order:1}.player-scoreboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:6px;padding:8px 12px;background:#ffffff80;max-width:100%}.player-card{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:6px;white-space:nowrap;background:#ffffffe6;border:1px solid rgba(157,123,255,.15);transition:all .2s ease;min-width:0;overflow:hidden}.player-card.current{background:#ffb54726;border-width:2px}.player-color-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.player-name-wrapper{display:flex;align-items:center;gap:4px;flex:1;min-width:0;overflow:hidden}.rank-badge{font-size:10px;padding:1px 4px;border-radius:4px;font-weight:700;white-space:nowrap}.rank-badge.winner{background:#ffd70033;color:#b8860b;border:1px solid rgba(255,215,0,.5)}.rank-badge.loser{background:#96969633;color:#666;border:1px solid rgba(150,150,150,.5)}.player-name{font-size:11px;font-weight:700;color:#3a2d60;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.player-score{font-size:11px;font-weight:900;padding:2px 6px;border-radius:4px;flex-shrink:0}.player-scoreboard.team-mode{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px}.team-scoreboard-group{background:#9d7bff1a;border:2px solid rgba(157,123,255,.3);border-radius:8px;padding:6px}.team-scoreboard-header{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;background:linear-gradient(135deg,#9d7bff,#8b68ee);border-radius:4px;margin-bottom:4px}.team-scoreboard-name{font-size:11px;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.2)}.team-scoreboard-total{font-size:12px;font-weight:700;color:#fff;background:#fff3;padding:2px 8px;border-radius:10px}.team-scoreboard-members{display:flex;flex-direction:column;gap:3px}.player-card-mini{display:flex;align-items:center;gap:5px;padding:3px 6px;background:#fff;border-radius:4px;border:1px solid rgba(157,123,255,.2);min-width:0}.player-card-mini.current{background:#ffb54726;border:2px solid rgba(255,181,71,.5)}.player-color-dot-mini{width:6px;height:6px;border-radius:50%;flex-shrink:0}.player-name-mini{font-size:10px;font-weight:600;color:#3a2d60;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.player-score-mini{font-size:10px;font-weight:700;color:#8b68ee;flex-shrink:0}@media (max-width: 768px){.player-scoreboard{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));padding:3px 5px;gap:3px}.player-scoreboard-side{gap:3px;padding:3px}.player-card{padding:3px 6px;gap:3px}.player-name{font-size:9px}.player-score{font-size:9px;padding:2px 4px}.player-color-dot{width:5px;height:5px}.player-scoreboard.team-mode{grid-template-columns:1fr}}.player-scoreboard-mobile{width:100%;padding:1px 2px;margin-top:-4px}.player-scoreboard-mobile .player-card{width:100%;justify-content:space-between;padding:2px 4px;background:#ffffffe6;border:1px solid;font-size:9px;box-shadow:0 1px 3px #0000001a;border-radius:3px}.player-scoreboard-mobile .player-color-dot{width:6px;height:6px;flex-shrink:0}.player-scoreboard-mobile .player-name{flex:1;font-weight:600;font-size:9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0 2px}.player-scoreboard-mobile .player-score{padding:1px 3px;border-radius:3px;font-size:10px;font-weight:800;flex-shrink:0}.player-scoreboard-mobile .team-scoreboard-group{background:#fffffff2;border-radius:6px;padding:4px;border:1px solid rgba(157,123,255,.3);box-shadow:0 1px 4px #0000001a}.player-scoreboard-mobile .team-scoreboard-header{display:flex;justify-content:space-between;gap:4px;margin-bottom:3px}.player-scoreboard-mobile .team-scoreboard-name{font-size:9px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-scoreboard-mobile .team-scoreboard-total{font-size:11px;font-weight:800;color:#ff6b6b;flex-shrink:0}.player-scoreboard-mobile .player-card-mini{display:flex;justify-content:space-between;padding:3px 4px;background:#9d7bff1a}.player-scoreboard-mobile .player-name-mini{font-weight:700;font-size:9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-scoreboard-mobile .player-score-mini{font-weight:800;font-size:10px;flex-shrink:0}.player-scoreboard-mobile .player-color-dot-mini{width:6px;height:6px}@media (max-height: 600px) and (orientation: landscape) and (max-width: 1024px){.player-scoreboard-mobile{width:32px;padding:0;margin:0}.player-scoreboard-mobile .player-card{padding:1px;margin:0;flex-direction:column;align-items:center;justify-content:center;gap:1px;font-size:8px;box-shadow:none}.player-scoreboard-mobile .player-color-dot{width:5px;height:5px;margin:0}.player-scoreboard-mobile .player-name{display:none}.player-scoreboard-mobile .player-score{padding:1px 2px;font-size:9px;margin:0}.player-scoreboard-mobile .team-scoreboard-group{display:flex;flex-direction:column;gap:1px;padding:1px;margin:0;box-shadow:none}.player-scoreboard-mobile .team-scoreboard-header{display:flex;flex-direction:column;gap:1px;text-align:center;margin:0}.player-scoreboard-mobile .team-scoreboard-name{width:100%;font-size:9px;margin:0}.player-scoreboard-mobile .team-scoreboard-total{text-align:center;font-size:11px;margin:0}.player-scoreboard-mobile .team-scoreboard-members{display:flex;flex-direction:column;gap:1px;margin:0}.player-scoreboard-mobile .player-card-mini{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;padding:1px;margin:0}.player-scoreboard-mobile .player-name-mini{display:none}.player-scoreboard-mobile .player-score-mini{text-align:center;font-size:9px;margin:0}.player-scoreboard-mobile .player-color-dot-mini{width:5px;height:5px;margin:0}}.mobile-score-bar{display:none}@media (max-width: 600px) and (orientation: portrait){.mobile-score-bar{display:flex;align-items:center;gap:8px;padding:6px 14px;background:#120d28d9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(157,123,255,.25);min-height:40px;width:100%;flex-shrink:0;z-index:100}}.msb-player-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.msb-name{flex:1;font-size:.8rem;font-weight:600;color:#ffffffe6;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.msb-score{font-size:1rem;font-weight:900;letter-spacing:-.5px;flex-shrink:0}.msb-rank{font-size:.85rem;font-weight:700;color:#ffffffe6;flex-shrink:0}.msb-total{font-size:.75rem;font-weight:500;color:#ffffff80}.game-layout{display:grid;grid-template-columns:minmax(100px,140px) 1fr minmax(100px,140px);grid-template-rows:1fr;grid-template-areas:"left board right";column-gap:10px;flex:1;min-height:0;width:100%;max-width:1400px;margin:0 auto;padding:6px 14px;align-items:center;overflow:hidden}.game-layout.game-layout-solo{grid-template-columns:1fr;grid-template-areas:"board"}.game-layout-left{grid-area:left}.game-layout-board{grid-area:board}.game-layout-right{grid-area:right}.game-layout-left,.game-layout-right{display:flex;flex-direction:column;gap:6px;align-items:stretch;max-height:100%;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(157,123,255,.3) transparent}.game-layout-board{display:flex;align-items:center;justify-content:center;min-height:0;min-width:0;height:100%}.game-layout-board .game-board-container{width:100%;max-width:900px;flex:unset}@media (max-width: 900px){.game-layout:not(.game-layout-solo){grid-template-columns:1fr minmax(90px,120px);grid-template-areas:"board right"}.game-layout-left{display:none}}@media (max-width: 600px) and (orientation: portrait){.game-layout:not(.game-layout-solo){grid-template-columns:1fr;grid-template-rows:1fr auto;grid-template-areas:"board" "minibar";padding:4px 0 0;align-items:stretch}.game-layout-left,.game-layout-right{display:none}.mobile-score-bar{grid-area:minibar}}@media (max-width: 600px) and (orientation: landscape){.game-layout:not(.game-layout-solo){grid-template-columns:1fr;grid-template-areas:"board";padding:4px 6px}.game-layout-left,.game-layout-right{display:none}}@media (max-height: 500px) and (orientation: landscape){.game-layout:not(.game-layout-solo){grid-template-columns:30px 1fr;grid-template-areas:"left board";column-gap:4px;padding:2px 6px}.game-layout-right{display:none}.game-layout-left{display:flex;overflow:hidden}}.game-board-container{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:5px 10px 10px;flex:1;order:0;max-width:900px;position:relative;overflow:visible}.game-board{display:grid;gap:3px;padding:8px;background:var(--game-board-bg);border:3px solid var(--game-board-border);border-radius:16px;position:relative;-webkit-user-select:none;user-select:none;touch-action:none;box-shadow:0 4px 20px #9d7bff1a,var(--jelly-depth-shadow);width:100%;max-width:900px;max-height:100%;height:auto;margin:0 0 8px}.tile{width:100%;height:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;min-width:0;min-height:0;touch-action:none}.tile.empty{background:transparent;cursor:default}.tile-inner{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#c4b5ff,#d8ccff);border-radius:var(--jelly-radius);box-shadow:0 4px 12px #9d7bff33,0 4px #0000000d,inset 0 2px 4px #ffffffb3;transition:all .15s cubic-bezier(.34,1.56,.64,1);animation:tileBreath 3s ease-in-out infinite}.tile:nth-child(3n) .tile-inner{animation-delay:-1s}.tile:nth-child(3n+1) .tile-inner{animation-delay:-2s}.tile:nth-child(5n) .tile-inner{animation-delay:-.5s}.tile.selected .tile-inner{background:linear-gradient(135deg,#8b68ee,#9d7bff);box-shadow:0 2px 6px #9d7bff4d,0 2px #0000000a,inset 0 3px 6px #fff9;transform:scale(.9);filter:brightness(1.15);animation:none}.tile-shine{position:absolute;top:8%;left:8%;width:45%;height:35%;border-radius:50%;background:radial-gradient(ellipse,white 0%,transparent 70%);filter:blur(2px);opacity:.6;pointer-events:none}.tile-number{position:relative;z-index:10;font-size:var(--tile-font-size, 1.2rem);font-weight:900;color:#3a2d60;text-shadow:0 2px 4px rgba(255,255,255,.9),0 0 1px rgba(58,45,96,.3);letter-spacing:-.5px;-webkit-user-select:none;user-select:none}.tile-number.two-digit{font-size:calc(var(--tile-font-size, 1.2rem) * .7);letter-spacing:-1px}.tile.success .tile-inner{animation:successFlash 80ms ease-out}@keyframes successFlash{0%{box-shadow:0 6px 16px #9d7bff59,inset 0 3px 6px #fff9}50%{box-shadow:0 0 30px #fff,0 0 50px #9d7bffcc,inset 0 0 20px #fff;background:linear-gradient(135deg,#fff,#f5f0ff);transform:scale(1.05)}to{box-shadow:0 6px 16px #9d7bff59,inset 0 3px 6px #fff9}}.tile-remove-effect{border-radius:28%/32%;pointer-events:none;z-index:1001;animation:fadeOutRemove .5s ease-out forwards}@keyframes fadeOutRemove{0%{opacity:.8;transform:scale(1)}30%{opacity:.9;transform:scale(1.15)}to{opacity:0;transform:scale(1.3)}}.sync-burst-overlay{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;z-index:1100;animation:syncBurst .6s ease-out forwards}@keyframes syncBurst{0%{background:radial-gradient(ellipse at center,#ffe65000,#ffe65000);box-shadow:0 0 #ffe65000}15%{background:radial-gradient(ellipse at center,rgba(255,230,80,.55) 0%,rgba(255,160,20,.25) 60%,transparent 100%);box-shadow:0 0 40px 12px #ffd23cb3,inset 0 0 30px #ffe65066}40%{background:radial-gradient(ellipse at center,rgba(255,255,150,.3) 0%,rgba(255,200,50,.12) 70%,transparent 100%);box-shadow:0 0 60px 20px #ffdc5066,inset 0 0 20px #ffe65033}to{background:transparent;box-shadow:none}}@media (max-width: 1024px){.game-board{gap:2px;padding:6px}.sum-display{font-size:16px;padding:6px 12px}}.game-board.mobile-vertical{width:95vw;max-width:95vw;height:auto}@media (max-width: 768px){.game-board-container{justify-content:center;padding-top:2px}.game-board{gap:3px;padding:6px;margin-top:0}.game-board.mobile-vertical{width:98vw;max-width:98vw}.sum-display{font-size:14px;padding:5px 10px}}@media (max-width: 480px){.game-board-container{gap:10px;padding:5px}.game-board{width:100%;gap:1px;padding:2px;border-width:1px;border-radius:10px}.tile{min-width:0;min-height:0}.sum-display{font-size:12px;padding:4px 8px}.tile-inner{border-radius:22%/26%}}@media (max-width: 360px){.game-board{width:100%;gap:1px;padding:3px;border-width:1px;border-radius:10px}}@media (max-height: 600px) and (orientation: landscape) and (max-width: 1024px){.game-board-container{padding:0;display:flex;justify-content:center;align-items:center;width:100%;height:100%;position:relative}.game-board{max-height:95vh;height:95vh;width:fit-content;max-width:100%}}.board-zoom-controls{position:fixed;bottom:30px;right:30px;display:flex;flex-direction:column;gap:8px;background:#ffffffe6;padding:8px;border-radius:12px;box-shadow:0 4px 15px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:3000;border:1px solid rgba(157,123,255,.3)}.zoom-btn{width:40px;height:40px;border-radius:8px;background:#fff;border:1px solid #9D7BFF;color:#3a2d60;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 5px #9d7bff33}.zoom-btn:hover:not(:disabled){background:#ede5ff;transform:translateY(-2px);box-shadow:0 4px 8px #9d7bff4d}.zoom-btn:active:not(:disabled){transform:translateY(0)}.zoom-btn:disabled{opacity:.4;cursor:not-allowed;border-color:#ccc;color:#999}.zoom-btn.zoom-reset{font-size:13px;padding:0 4px}@media (max-width: 768px){.board-zoom-controls{flex-direction:column;bottom:16px;right:16px;transform:none;padding:8px;gap:8px}.zoom-btn{width:36px;height:36px;font-size:16px}.zoom-btn.zoom-reset{width:auto;min-width:50px}}.result-screen-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.result-screen-panel{width:90%;max-width:600px;max-height:90vh;background:linear-gradient(180deg,#f8f9ff,#e8ecff);border-radius:24px;padding:24px;padding-bottom:max(24px,env(safe-area-inset-bottom));overflow-y:hidden;box-shadow:0 20px 60px #0006;overscroll-behavior:contain;display:flex;flex-direction:column}.result-content{display:flex;flex-direction:column;gap:0;overflow-y:auto;flex:1;min-height:0;-webkit-overflow-scrolling:touch}.result-content::-webkit-scrollbar{width:8px}.result-content::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}.result-content::-webkit-scrollbar-thumb{background:#9d7bff4d;border-radius:4px}.result-content::-webkit-scrollbar-thumb:hover{background:#9d7bff80}.result-card{background:#fff;border-radius:20px;padding:28px;box-shadow:0 8px 24px #0000001a;margin-bottom:16px}.score-header{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(157,123,255,.15)}.score-title{font-size:18px;font-weight:800;background:linear-gradient(135deg,#9d7bff,#7c5ce0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:.5px}.result-header{text-align:center;margin-bottom:20px}.result-subtitle{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#9d7bff1a,#7c5ce01a);border:2px solid rgba(157,123,255,.3);border-radius:12px;font-size:15px;font-weight:600;color:#9d7bff;box-shadow:0 2px 8px #9d7bff26;transition:background .15s}.result-subtitle--clickable{cursor:pointer}.result-subtitle--clickable:hover{background:linear-gradient(135deg,#9d7bff33,#7c5ce033)}.result-lb-hint{font-size:12px;text-align:center;margin-top:5px;padding:3px 10px;border-radius:6px}.result-lb-hint--register{color:#7b5cbf;background:#7b5cbf12;cursor:pointer}.result-lb-hint--register:hover{background:#7b5cbf24}.result-lb-hint--existing{color:#999;font-size:11px}.my-rank-badge{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:28px;background:#9d7bff;color:#fff;border-radius:8px;font-size:14px;font-weight:800;padding:0 8px}.my-score-badge{display:inline-flex;align-items:center;font-size:18px;font-weight:800;color:#9d7bff}.winner-highlight{background:linear-gradient(135deg,gold,orange);border-radius:16px;padding:24px;margin-bottom:20px;position:relative;overflow:hidden;animation:shimmer 3s infinite}@keyframes shimmer{0%,to{box-shadow:0 0 20px #ffd70066}50%{box-shadow:0 0 40px #ffd700cc,0 0 60px #ffd70099}}.winner-highlight:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:linear-gradient(45deg,transparent,rgba(255,255,255,.3),transparent);animation:sparkle 3s infinite}@keyframes sparkle{0%{transform:translate(-100%) translateY(-100%) rotate(45deg)}to{transform:translate(100%) translateY(100%) rotate(45deg)}}.winner-badge{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:16px;position:relative;z-index:1}.winner-rank{font-size:48px;font-weight:900;color:#1e1e22;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.winner-crown{font-size:40px;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.2))}.winner-info{text-align:center;position:relative;z-index:1}.winner-name{font-size:28px;font-weight:700;color:#1e1e22;margin-bottom:8px;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:6px}.winner-score{font-size:36px;font-weight:900;color:#1e1e22;text-shadow:1px 1px 2px rgba(0,0,0,.1)}.team-block{background:#fff;border-radius:12px;padding:16px;margin-bottom:12px;border:2px solid #E0E0E0;transition:all .3s}.team-block:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.team-block.rank-1{background:linear-gradient(135deg,gold,orange);border:3px solid #FFD700;animation:shimmer 3s infinite}.team-block.is-self{border:3px solid #9D7BFF;background:#9d7bff1a;box-shadow:0 0 0 3px #9d7bff4d}.team-block.rank-1.is-self{box-shadow:0 0 0 3px #9d7bff80,0 0 20px #ffd70066}.team-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding-bottom:12px;border-bottom:2px solid rgba(0,0,0,.1)}.team-rank{font-size:24px;font-weight:900;color:#9d7bff;min-width:40px;text-align:center}.team-block.rank-1 .team-rank{color:#1e1e22}.team-info{flex:1}.team-name{font-size:20px;font-weight:700;color:#1e1e22;margin-bottom:4px}.team-score{font-size:24px;font-weight:900;color:#9d7bff}.team-block.rank-1 .team-score{color:#1e1e22}.team-members{display:flex;flex-direction:column;gap:8px}.player-block{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-radius:10px;border:2px solid #E0E0E0;transition:all .3s}.player-block:hover{transform:translate(4px);box-shadow:0 2px 8px #0000001a}.player-block.rank-1{background:linear-gradient(135deg,gold,orange);border:3px solid #FFD700;animation:shimmer 3s infinite}.player-block.is-self{border:3px solid #9D7BFF;background:#9d7bff26;box-shadow:0 0 0 2px #9d7bff4d}.player-block.rank-1.is-self{box-shadow:0 0 0 2px #9d7bff80,0 0 20px #ffd70066}.player-rank{font-size:20px;font-weight:900;color:#9d7bff;min-width:36px;text-align:center}.player-block.rank-1 .player-rank{color:#1e1e22;font-size:24px}.player-info{flex:1;display:flex;flex-direction:column;gap:2px}.player-name{font-size:16px;font-weight:600;color:#1e1e22}.player-score{font-size:20px;font-weight:900;color:#9d7bff;text-align:right}.player-block.rank-1 .player-score{color:#1e1e22;font-size:24px}.ranking-list{display:flex;flex-direction:column;gap:12px}.ranking-section-title{font-size:20px;font-weight:700;color:#9d7bff;margin-bottom:10px;padding-bottom:6px;border-bottom:2px solid #9D7BFF}.result-brand-header{display:flex;align-items:center;justify-content:space-between;padding:0 2px 10px;border-bottom:1px solid rgba(157,123,255,.15);margin-bottom:10px}.result-brand-logo{font-size:12px;font-weight:800;letter-spacing:.14em;color:#9d7bff;font-family:monospace}.result-brand-url{font-size:10px;color:#ffffff40;letter-spacing:.04em}.rematch-vote-section{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 16px;flex-shrink:0}.rematch-vote-icons{display:flex;align-items:flex-end;gap:8px;flex-wrap:wrap;justify-content:center}.rematch-player-icon{display:flex;flex-direction:column;align-items:center;gap:3px;transition:transform .15s}.rematch-player-icon svg{width:28px;height:28px;fill:var(--border-medium, #ccc);transition:fill .2s,transform .2s}.rematch-player-icon.voted svg{fill:#5cb85c;transform:scale(1.15)}.rematch-player-name{font-size:11px;font-weight:600;color:var(--text-secondary, #888);max-width:52px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.rematch-player-icon.voted .rematch-player-name{color:#5cb85c}.rematch-vote-status{font-size:13px;font-weight:600;color:var(--text-secondary, #888)}.action-btn.next-game.voted{background:linear-gradient(135deg,#4cae4c,#3a7f3a);opacity:.75;cursor:default}.action-btn.next-game.voted:hover{transform:none;box-shadow:0 4px 12px #0000001a}.result-actions{display:flex;gap:12px;margin-top:0;flex-shrink:0}.result-share-row{display:flex;justify-content:center;margin-top:10px;flex-shrink:0}.action-btn-share{background:none;border:1.5px solid rgba(157,123,255,.4);border-radius:20px;color:#9d7bff;font-size:14px;font-weight:600;padding:8px 20px;cursor:pointer;min-height:44px;touch-action:manipulation;transition:all .2s}.action-btn-share:hover{background:#9d7bff14;border-color:#9d7bff}.action-btn{flex:1;padding:16px;border:none;border-radius:12px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #0000001a;min-height:48px;touch-action:manipulation}.action-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #00000026}.action-btn.next-game{background:linear-gradient(135deg,#5cb85c,#3d8b3d);color:#fff}.action-btn.replay{background:linear-gradient(135deg,#9d7bff,#7c5ce0);color:#fff}.action-btn.lobby{background:#fff;color:#9d7bff;border:2px solid #9D7BFF}.action-btn.menu{background:#f0f0f0;color:#666;border:none;flex:.6}@media (max-width: 480px){.result-card{padding:16px}.result-subtitle{font-size:14px}.winner-rank{font-size:36px}.winner-name{font-size:22px}.winner-score{font-size:28px}.team-name{font-size:16px}.team-score{font-size:20px}.player-name{font-size:14px}.player-score{font-size:16px}.action-btn{padding:12px;font-size:14px}}@media (min-width: 481px) and (max-width: 768px){.result-card{padding:24px}}@media (min-width: 769px){.result-card{padding:32px}.ranking-list{gap:14px}.team-block{margin-bottom:14px}}@media (max-height: 600px) and (orientation: landscape){.result-screen-panel{max-height:98vh;padding:16px}.result-card{padding:16px;margin-bottom:12px}.result-header{margin-bottom:12px}.winner-highlight{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:4px 16px;align-items:center;padding:12px;margin-bottom:16px}.winner-badge{grid-column:1 / 2;grid-row:1 / 2;margin-bottom:0;justify-content:flex-end}.winner-crown{font-size:32px}.winner-rank{font-size:36px}.winner-info{display:contents}.winner-name{grid-column:2 / 3;grid-row:1 / 2;margin-bottom:0;text-align:left;font-size:24px}.winner-score{grid-column:1 / -1;grid-row:2 / 3;text-align:center;font-size:40px;margin-top:4px}.winner-members{grid-column:1 / -1;text-align:center;font-size:12px!important}}@media (orientation: portrait) and (max-width: 768px){.result-screen-panel{width:96%;max-height:92vh;padding:16px;border-radius:20px}.result-card{padding:16px;margin-bottom:12px}.winner-highlight{display:grid;grid-template-columns:auto 1fr;gap:0 12px;align-items:center;padding:14px 16px;margin-bottom:14px}.winner-badge{grid-column:1 / 2;grid-row:1 / 2;flex-direction:column;gap:2px;margin-bottom:0;align-items:center;min-width:52px}.winner-crown{font-size:24px}.winner-rank{font-size:28px}.winner-info{grid-column:2 / 3;grid-row:1 / 2;text-align:left}.winner-name{font-size:18px;margin-bottom:4px;justify-content:flex-start}.winner-score{font-size:24px}.winner-members{font-size:12px!important;text-align:left}.ranking-list{gap:8px}.player-block{padding:10px 12px}.player-name{font-size:14px}.player-score{font-size:15px}.result-actions{flex-direction:column;gap:8px}.action-btn{min-height:52px;font-size:15px}}@media (orientation: portrait) and (max-width: 768px) and (max-height: 700px){.result-screen-panel{max-height:96vh;padding:12px;border-radius:16px}.result-card{padding:12px;margin-bottom:8px}.result-header{margin-bottom:10px}.winner-highlight{padding:10px 12px;margin-bottom:10px}.winner-crown{font-size:20px}.winner-rank{font-size:24px}.winner-name{font-size:16px}.winner-score{font-size:20px}.ranking-list{gap:6px}.player-block{padding:8px 10px}}:root{--countdown-accent: #58f1ff;--countdown-accent-soft: rgba(88, 241, 255, .2);--countdown-text-strong: #f9fbff}.countdown-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000bf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:overlay-fade-in .3s ease}@keyframes overlay-fade-in{0%{opacity:0}to{opacity:1}}.countdown-stage{position:relative;width:200px;height:200px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:radial-gradient(circle,rgba(88,241,255,.14),transparent 68%)}.countdown-circle{position:absolute;top:16px;right:16px;bottom:16px;left:16px;border-radius:50%;border:2px solid var(--countdown-accent-soft);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.countdown-number{font-size:96px;font-weight:800;color:var(--countdown-text-strong);text-shadow:0 18px 40px rgba(0,0,0,.45);opacity:0;transform:scale(.5);animation:pop 1s cubic-bezier(.24,1.27,.56,.98) forwards;z-index:2}.countdown-number.is-go{font-size:64px;color:var(--countdown-accent)}.pulse-ring{position:absolute;width:100%;height:100%;border-radius:50%;border:1px solid rgba(88,241,255,.35);animation:pulse 1s ease-out forwards;z-index:1}@keyframes pop{0%{opacity:0;transform:scale(.4)}45%{opacity:1;transform:scale(1.08)}70%{transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%{opacity:.55;transform:scale(.85)}70%{opacity:.1;transform:scale(1.25)}to{opacity:0;transform:scale(1.4)}}.countdown-stage.target-mode{width:240px;height:240px;background:radial-gradient(circle,rgba(255,215,0,.18),transparent 68%)}.countdown-stage.target-mode .countdown-circle{border-color:#ffd70040}.pulse-ring.target-pulse{border-color:#ffd70066}.countdown-number.is-target{font-size:52px;color:gold;text-shadow:0 0 30px rgba(255,215,0,.5),0 4px 20px rgba(0,0,0,.4);animation:target-reveal 1.5s cubic-bezier(.24,1.27,.56,.98) forwards;white-space:nowrap}@keyframes target-reveal{0%{opacity:0;transform:scale(.3) rotate(-5deg)}35%{opacity:1;transform:scale(1.15) rotate(2deg)}55%{transform:scale(.95) rotate(0)}70%{transform:scale(1.02)}to{opacity:1;transform:scale(1) rotate(0)}}@media (max-width: 480px){.countdown-stage{width:160px;height:160px}.countdown-stage.target-mode{width:200px;height:200px}.countdown-number{font-size:72px}.countdown-number.is-go{font-size:52px}.countdown-number.is-target{font-size:40px}}.panic-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:9000;box-shadow:inset 0 0 #f000;transition:box-shadow .5s ease}.panic-overlay.active{animation:panic-pulse 1s infinite cubic-bezier(.4,0,.6,1)}@keyframes panic-pulse{0%{box-shadow:inset 0 0 20px #ff00001a}50%{box-shadow:inset 0 0 100px #f006}to{box-shadow:inset 0 0 20px #ff00001a}}.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;overflow:hidden}.confetti{position:absolute;top:-20px;width:10px;height:20px;opacity:0;animation:confetti-fall 2.5s ease-in forwards}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(105vh) rotate(720deg);opacity:0}}.match-effect-container{position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);display:flex;justify-content:center;align-items:center}.match-text{font-family:Arial Black,sans-serif;font-weight:900;font-size:2rem;color:gold;text-shadow:0 0 10px rgba(255,215,0,.5),2px 2px 0 rgba(0,0,0,.2);animation:match-pop-up .8s cubic-bezier(.175,.885,.32,1.275) forwards;white-space:nowrap;position:absolute;z-index:2}.match-text.combo{color:#ff4500;font-size:2.5rem;text-shadow:0 0 15px rgba(255,69,0,.6),3px 3px 0 #000;animation:combo-surge 1s cubic-bezier(.22,1,.36,1) forwards}.match-ring{position:absolute;width:20px;height:20px;border:4px solid rgba(255,255,255,.8);border-radius:50%;animation:match-shockwave .5s ease-out forwards}.match-sparkle{position:absolute;width:6px;height:6px;background-color:#fff;border-radius:50%;animation:match-sparkle-burst .6s ease-out forwards}@keyframes match-pop-up{0%{transform:scale(0) translateY(0);opacity:0}50%{transform:scale(1.2) translateY(-20px);opacity:1}to{transform:scale(1) translateY(-50px);opacity:0}}@keyframes combo-surge{0%{transform:scale(.5) translateY(0) rotate(-10deg);opacity:0}40%{transform:scale(1.5) translateY(-30px) rotate(5deg);opacity:1}to{transform:scale(1.2) translateY(-80px) rotate(0);opacity:0}}@keyframes match-shockwave{0%{transform:scale(1);opacity:1;border-width:4px}to{transform:scale(8);opacity:0;border-width:0px}}@keyframes match-sparkle-burst{0%{transform:rotate(var(--angle)) translate(0) scale(1);opacity:1}to{transform:rotate(var(--angle)) translate(var(--dist)) scale(0);opacity:0}}.score-effect-wrapper{position:fixed;pointer-events:none;z-index:2000;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.score-value{font-family:Arial Black,Impact,sans-serif;font-weight:900;font-size:2rem;color:#fff;-webkit-text-stroke:2px rgba(0,0,0,.6);text-shadow:3px 3px 0px rgba(0,0,0,.7),0 0 8px rgba(255,255,255,.4);animation:score-bounce .9s cubic-bezier(.175,.885,.32,1.275) forwards;line-height:1;white-space:nowrap;letter-spacing:-.02em}.score-label{font-family:Arial Black,sans-serif;font-weight:900;font-size:.85rem;padding:3px 10px;border-radius:20px;margin-top:3px;color:#fff;background:#000000bf;animation:label-slide-up .5s ease-out .05s forwards;opacity:0;white-space:nowrap;box-shadow:0 2px 8px #00000080,inset 0 1px #ffffff26;border:1px solid rgba(255,255,255,.2);letter-spacing:.03em;text-transform:uppercase}.tier-1{color:#fff;font-size:2rem;-webkit-text-stroke:2px #333;text-shadow:3px 3px 0 #333,0 0 12px rgba(255,255,255,.8)}.tier-2{color:#0f8;font-size:2.4rem;-webkit-text-stroke:2px #006633;text-shadow:3px 3px 0 #006633,0 0 10px #00FF88,0 0 20px rgba(0,255,136,.5)}.tier-3{color:#ffe000;font-size:2.9rem;-webkit-text-stroke:2px #664400;text-shadow:3px 3px 0 #664400,0 0 12px #FFB300,0 0 25px rgba(255,200,0,.7),0 0 40px rgba(255,160,0,.3);animation:score-bounce-gold .9s cubic-bezier(.175,.885,.32,1.275) forwards}.tier-4{color:#f50;font-size:3.4rem;-webkit-text-stroke:2.5px #660000;text-shadow:3px 3px 0 #660000,0 0 15px #FF5500,0 0 30px rgba(255,80,0,.8),0 0 50px rgba(255,50,0,.4);animation:score-bounce-fire .9s cubic-bezier(.175,.885,.32,1.275) forwards}.tier-5{color:#f0c;font-size:4rem;-webkit-text-stroke:3px #550044;text-shadow:3px 3px 0 #550044,0 0 15px #FF00CC,0 0 30px #FF00CC,0 0 50px rgba(255,0,200,.8),0 0 80px rgba(255,0,200,.4);animation:score-bounce-ultra .9s cubic-bezier(.175,.885,.32,1.275) forwards}.style-clash .score-value{color:#0df;-webkit-text-stroke:2px #003366;text-shadow:3px 3px 0 #003366,0 0 12px #00DDFF,0 0 25px rgba(0,200,255,.8),0 0 45px rgba(0,150,255,.4)}.style-clash .score-label{background:linear-gradient(135deg,#08c,#04f);border:1.5px solid #00DDFF;box-shadow:0 0 10px #00c8ff99,0 2px 8px #00000080}.style-time .score-value{color:#f22;-webkit-text-stroke:2px #440000;text-shadow:3px 3px 0 #440000,0 0 12px #FF2222,0 0 25px rgba(255,50,0,.8);animation:score-bounce-fire .9s cubic-bezier(.175,.885,.32,1.275) forwards}.style-time .score-label{background:linear-gradient(135deg,#c00,#f50);border:1.5px solid #FF8888;box-shadow:0 0 10px #ff320099,0 2px 8px #00000080;animation:label-pulse .4s infinite alternate}@keyframes score-bounce{0%{transform:scale(0) rotate(-5deg);opacity:0}30%{transform:scale(1.5) rotate(3deg);opacity:1}55%{transform:scale(1.1) rotate(-1deg);opacity:1}to{transform:scale(.9) translateY(-70px);opacity:0}}@keyframes score-bounce-gold{0%{transform:scale(0) rotate(-8deg);opacity:0}25%{transform:scale(1.7) rotate(4deg);opacity:1}50%{transform:scale(1.2) rotate(-2deg);opacity:1}to{transform:scale(1) translateY(-80px);opacity:0}}@keyframes score-bounce-fire{0%{transform:scale(0) rotate(6deg);opacity:0}20%{transform:scale(1.9) rotate(-4deg);opacity:1}45%{transform:scale(1.3) rotate(2deg);opacity:1}to{transform:scale(1) translateY(-90px);opacity:0}}@keyframes score-bounce-ultra{0%{transform:scale(0) rotate(-10deg);opacity:0}20%{transform:scale(2.2) rotate(6deg);opacity:1}40%{transform:scale(1.5) rotate(-3deg);opacity:1}60%{transform:scale(1.7) rotate(2deg);opacity:1}to{transform:scale(1) translateY(-100px);opacity:0}}@keyframes label-slide-up{0%{transform:translateY(8px) scale(.8);opacity:0}60%{transform:translateY(-2px) scale(1.05);opacity:1}to{transform:translateY(0) scale(1);opacity:1}}@keyframes label-pulse{0%{transform:scale(1);filter:brightness(1)}to{transform:scale(1.12);filter:brightness(1.3)}}.clash-effect-container{position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);display:flex;justify-content:center;align-items:center;width:0;height:0}.clash-text{font-family:Arial Black,sans-serif;font-weight:900;font-size:1.5rem;text-shadow:3px 3px 0px rgba(0,0,0,.5);animation:clash-shake-drop .8s cubic-bezier(.36,.07,.19,.97) forwards;white-space:nowrap;position:absolute;z-index:2}.clash-particles{position:absolute;top:0;left:0}.clash-particle{position:absolute;width:6px;height:6px;border-radius:1px;transform-origin:center;animation:clash-shatter .6s ease-out forwards}@keyframes clash-shake-drop{0%{transform:translate(0) scale(.5) rotate(0);opacity:0}15%{transform:translate(0) scale(1.5) rotate(-5deg);opacity:1}25%{transform:translate(-5px) rotate(5deg)}35%{transform:translate(5px) rotate(-5deg)}45%{transform:translate(-3px) rotate(3deg)}60%{transform:translate(0) scale(1.2) rotate(0);opacity:1}to{transform:translateY(50px) scale(.8) rotate(10deg);opacity:0}}@keyframes clash-shatter{0%{transform:rotate(var(--angle)) translate(0) scale(1);opacity:1}60%{opacity:1}to{transform:rotate(var(--angle)) translate(60px) translateY(40px) rotate(720deg) scale(0);opacity:0}}.test-clash-container{width:100vw;height:100vh;background-color:#2a2a2a;position:relative;overflow:hidden;cursor:crosshair;-webkit-user-select:none;user-select:none}.test-controls{position:absolute;top:20px;left:50%;transform:translate(-50%);background:#000c;padding:20px;border-radius:12px;color:#fff;text-align:center;z-index:100;pointer-events:auto;box-shadow:0 4px 12px #0000004d}.test-controls h3{margin:0 0 10px;color:#ffb547}.button-group{display:flex;gap:10px;margin-top:15px;justify-content:center;flex-wrap:wrap;max-width:600px}.test-controls button{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;background:#444;color:#fff;font-weight:700;transition:all .2s}.test-controls button.active{background:#9d7bff;transform:scale(1.05)}.test-controls button.back-btn{background:#666}.test-controls button:hover{opacity:.9}.rewarded-ad-modal{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out}.rewarded-ad-content{background:#fff;border-radius:20px;padding:40px;max-width:450px;width:90%;text-align:center;box-shadow:0 10px 40px #0000004d;animation:slideUp .4s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.ad-icon{font-size:64px;margin-bottom:20px}.rewarded-ad-content h3{font-size:24px;font-weight:700;color:#3a2d60;margin-bottom:16px}.ad-description{font-size:16px;color:#5a5a5a;line-height:1.6;margin-bottom:20px}.ad-info{background:#9d7bff1a;border:1px solid rgba(157,123,255,.3);border-radius:8px;padding:10px;margin-bottom:24px}.ad-info span{font-size:14px;color:#3a2d60;font-weight:600}.ad-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.watch-ad-btn{background:linear-gradient(135deg,#9d7bff,#8b68ee);color:#fff;border:none;border-radius:12px;padding:16px 32px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #9d7bff4d}.watch-ad-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #9d7bff66}.watch-ad-btn:active{transform:translateY(0)}.skip-ad-btn{background:transparent;color:#888;border:2px solid #DDD;border-radius:12px;padding:14px 32px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.skip-ad-btn:hover{border-color:#bbb;color:#666}.ad-notice{font-size:12px;color:#999;margin-top:12px}.ad-playback{background:#fff;border-radius:16px;padding:24px;max-width:600px;width:90%;box-shadow:0 10px 40px #0000004d}.ad-video-placeholder{background:linear-gradient(135deg,#9d7bff,#7c5ce0);border-radius:12px;padding:60px 40px;margin-bottom:20px;position:relative;overflow:hidden}.ad-label{position:absolute;top:12px;left:12px;background:#00000080;color:#fff;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600}.ad-mock-content{color:#fff;text-align:center}.ad-brand{font-size:32px;font-weight:700;margin-bottom:12px}.ad-mock-content p{font-size:16px;opacity:.9}.ad-progress-container{margin-bottom:16px}.ad-progress-bar{background:#e0e0e0;border-radius:8px;height:12px;overflow:hidden;margin-bottom:8px}.ad-progress-fill{background:linear-gradient(90deg,#9d7bff,#8b68ee);height:100%;transition:width .1s linear;border-radius:8px}.ad-progress-text{text-align:center;font-size:14px;font-weight:600;color:#3a2d60}.skip-ad-btn-small{width:100%;background:transparent;color:#888;border:2px solid #DDD;border-radius:10px;padding:12px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.skip-ad-btn-small:hover{border-color:#bbb;color:#666}@media (max-width: 768px){.rewarded-ad-content{padding:30px 24px}.ad-icon{font-size:48px}.rewarded-ad-content h3{font-size:20px}.ad-description{font-size:14px}.ad-video-placeholder{padding:40px 20px}.ad-brand{font-size:24px}}.interstitial-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#000000e0;display:flex;align-items:center;justify-content:center}.interstitial-box{width:320px;border-radius:16px;overflow:hidden;box-shadow:0 8px 40px #00000080}.interstitial-ad-area{height:250px;background:#1a1a2e;display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(255,255,255,.06)}.interstitial-ad-label{font-size:13px;color:#ffffff40;letter-spacing:.05em}.interstitial-footer{background:#121220fa;padding:14px 16px;position:relative;display:flex;align-items:center;justify-content:flex-end;min-height:48px}.interstitial-progress{position:absolute;top:0;left:0;height:3px;background:#9d7bff;transition:width 1s linear;border-radius:0 2px 0 0}.interstitial-countdown{font-size:12px;color:#ffffff73;font-variant-numeric:tabular-nums}.toast-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;z-index:9999;pointer-events:none;width:100%}.toast-notification{pointer-events:auto;display:flex;align-items:center;gap:12px;padding:12px 20px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:99px;box-shadow:0 4px 15px #00000026;font-size:14px;font-weight:600;color:#1e1e22;cursor:pointer;min-width:200px;max-width:90vw;text-align:center}.toast-icon{font-size:16px}.toast-success{border-left:4px solid #9D7BFF}.toast-error{border-left:4px solid #FF6B6B}.toast-info{border-left:4px solid #5FA3C4}@media (max-width: 768px){.toast-container{bottom:30px}}.message-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;justify-content:center;align-items:center;z-index:100000;animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.message-modal-container{background:linear-gradient(135deg,#9d7bff,#7c5ce0);border-radius:24px;padding:32px;box-shadow:0 20px 60px #00000080;max-width:90%;width:500px;animation:modalSlideIn .4s cubic-bezier(.34,1.56,.64,1);border:3px solid rgba(255,255,255,.3);position:relative;overflow:hidden}.message-modal-container:before{content:"";position:absolute;top:0;left:0;right:0;height:40%;background:linear-gradient(180deg,rgba(255,255,255,.15) 0%,transparent 100%);border-radius:24px 24px 0 0;pointer-events:none}@keyframes modalSlideIn{0%{transform:translateY(-30px) scale(.9);opacity:0}60%{transform:translateY(4px) scale(1.02)}to{transform:translateY(0) scale(1);opacity:1}}.message-modal-title{font-size:24px;font-weight:800;color:#fff;margin-bottom:20px;text-align:center;text-shadow:0 2px 10px rgba(0,0,0,.3)}.message-modal-content{font-size:18px;font-weight:600;color:#fff;line-height:1.6;text-align:center;margin-bottom:24px;white-space:pre-wrap;word-break:break-word;text-shadow:0 2px 8px rgba(0,0,0,.2)}.message-modal-close-btn{width:100%;padding:14px 28px;font-size:18px;font-weight:700;color:#9d7bff;background:#fff;border:none;border-bottom:3px solid rgba(0,0,0,.1);border-radius:14px;cursor:pointer;transition:all .2s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 12px #0003;position:relative;overflow:hidden}.message-modal-close-btn:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.6) 0%,transparent 100%);pointer-events:none}.message-modal-close-btn:hover{background:#f0f0f0;transform:translateY(-2px) scale(1.02);box-shadow:0 6px 16px #0000004d}.message-modal-close-btn:active{animation:jellyPress .35s ease}@media (max-width: 768px){.message-modal-container{width:90%;padding:24px}.message-modal-title{font-size:20px;margin-bottom:16px}.message-modal-content{font-size:16px;margin-bottom:20px}.message-modal-close-btn{padding:12px 24px;font-size:16px}}@media (max-width: 480px){.message-modal-container{width:95%;padding:20px}.message-modal-title{font-size:18px;margin-bottom:12px}.message-modal-content{font-size:15px;margin-bottom:16px}.message-modal-close-btn{padding:10px 20px;font-size:15px}}@media (min-width: 1200px){.message-modal-container{width:600px;padding:40px}.message-modal-title{font-size:28px;margin-bottom:24px}.message-modal-content{font-size:20px;margin-bottom:28px}.message-modal-close-btn{padding:16px 32px;font-size:20px}}.slb-wrap{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.slb-google,.slb-discord{width:100%;display:flex;justify-content:center}.slb-loading{color:#9d7bff;font-size:13px;padding:8px 0}.slb-discord-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:260px;padding:10px 16px;background-color:#5865f2;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s,transform .1s}.slb-discord-btn:hover{background-color:#4752c4}.slb-discord-btn:active{transform:scale(.98)}.slb-discord-icon{width:20px;height:20px;flex-shrink:0}.slb-compact .slb-discord-btn{width:260px;padding:9px 14px;font-size:13px}.rank-entry-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.rank-entry-modal{background:#1e1e2e;border:1px solid #9c7ce3;border-radius:16px;padding:2rem 2.5rem;max-width:420px;width:100%;text-align:center;position:relative;box-shadow:0 8px 40px #9c7ce34d;animation:rankEntryIn .3s ease}@keyframes rankEntryIn{0%{transform:translateY(-20px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.rank-entry-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:#888;font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .2s,background .2s}.rank-entry-close:hover{color:#fff;background:#ffffff1a}.rank-entry-trophy{font-size:3rem;margin-bottom:.5rem;animation:trophyBounce .6s ease}@keyframes trophyBounce{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.rank-entry-warning-icon{font-size:2.5rem;margin-bottom:.5rem}.rank-entry-title{color:#e0d0ff;font-size:1.25rem;font-weight:700;margin:0 0 .4rem}.rank-entry-sub{color:#a89cc4;font-size:.9rem;margin:0 0 1.5rem}.rank-entry-warn-msg{color:#f4c06a;font-size:.9rem;margin:0 0 .75rem;line-height:1.5}.rank-entry-reason{color:#888;font-size:.8rem;margin:0 0 1.25rem}.rank-entry-reason em{color:#f4c06a}.rank-entry-form{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem}.rank-entry-label{color:#c4b5e8;font-size:.85rem;text-align:left}.rank-entry-input{background:#2a2a3e;border:1.5px solid #5a4a8a;border-radius:8px;color:#f0e8ff;font-size:1rem;padding:.65rem .85rem;outline:none;transition:border-color .2s}.rank-entry-input:focus{border-color:#9c7ce3}.rank-entry-input::placeholder{color:#5a5a78}.rank-entry-error{color:#ff6b8a;font-size:.8rem;margin:0;text-align:left}.rank-entry-actions{display:flex;gap:.75rem;margin-top:1rem;justify-content:center}.rank-entry-btn{flex:1;padding:.7rem 1rem;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.rank-entry-btn:active{transform:scale(.97)}.rank-entry-btn:disabled{opacity:.5;cursor:not-allowed}.rank-entry-btn-primary{background:linear-gradient(135deg,#9c7ce3,#7b5cbf);color:#fff}.rank-entry-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#ab8ef0,#8c6ed0)}.rank-entry-btn-secondary{background:#2a2a3e;color:#a89cc4;border:1px solid #444466}.rank-entry-btn-secondary:hover:not(:disabled){background:#333348;color:#c4b5e8}.rank-entry-btn-danger{background:linear-gradient(135deg,#e86060,#c04040);color:#fff}.rank-entry-btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#f07070,#d05050)}.rank-entry-rank-display{font-size:1.3rem;font-weight:700;color:gold;letter-spacing:.03em;margin:0 0 1.5rem}@media (max-width: 480px){.rank-entry-modal{padding:1.5rem 1.25rem}.rank-entry-actions{flex-direction:column}}.rank-entry-estimated{display:flex;flex-direction:column;align-items:center;gap:2px;margin:12px 0 16px;padding:16px 24px;background:#9d7bff1a;border:1px solid rgba(157,123,255,.25);border-radius:16px}.rank-entry-est-label{font-size:11px;color:#a89cc4;text-transform:uppercase;letter-spacing:.6px}.rank-entry-est-number{font-size:58px;font-weight:900;color:#c4a8ff;line-height:1;margin:4px 0 2px;text-shadow:0 2px 16px rgba(157,123,255,.5)}.rank-entry-est-sub{font-size:12px;color:#7b6da0}.rank-entry-login-section{margin:4px 0 8px;width:100%}.rank-entry-later{display:block;margin:10px auto 0;background:none;border:none;color:#5a5a78;font-size:12px;cursor:pointer;text-decoration:underline;text-underline-offset:2px;transition:color .2s}.rank-entry-later:hover{color:#a89cc4}.rank-entry-existing{background:#ffd70014;border:1px solid rgba(255,215,0,.3);border-radius:8px;padding:8px 12px;margin-bottom:12px;font-size:.82rem;color:#c9a900;text-align:center;line-height:1.5}.rank-entry-existing small{color:#ffd70099;font-size:.75rem}.lb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b8;display:flex;align-items:center;justify-content:center;z-index:1800;padding:1rem}.lb-modal{background:#1a1a2e;border:1px solid #4a3a7a;border-radius:18px;width:100%;max-width:520px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 12px 50px #643cb459;animation:lbIn .28s ease}@keyframes lbIn{0%{transform:translateY(-16px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.lb-header{display:flex;align-items:center;gap:.5rem;padding:1.25rem 1.5rem .75rem;border-bottom:1px solid #2e2e4a;flex-shrink:0}.lb-header-icon{font-size:1.5rem}.lb-title{flex:1;margin:0;font-size:1.2rem;font-weight:700;color:#e8d8ff}.lb-close{background:none;border:none;color:#666;font-size:1.1rem;cursor:pointer;padding:4px 8px;border-radius:6px;transition:color .2s,background .2s}.lb-close:hover{color:#fff;background:#ffffff14}.lb-type-tabs{display:flex;gap:0;padding:.75rem 1.5rem 0;flex-shrink:0}.lb-type-tab{flex:1;padding:.45rem .75rem;background:transparent;border:1px solid #3a3a5a;color:#9a8ab8;font-size:.85rem;cursor:pointer;transition:background .15s,color .15s}.lb-type-tab:first-child{border-radius:8px 0 0 8px}.lb-type-tab:last-child{border-radius:0 8px 8px 0;border-left:none}.lb-type-tab.active{background:#5a3a9a;border-color:#7a5ab8;color:#fff;font-weight:600}.lb-board-tabs{display:flex;gap:.4rem;padding:.75rem 1.5rem 0;flex-shrink:0}.lb-board-tab{flex:1;padding:.5rem;background:#252538;border:1.5px solid transparent;border-radius:8px;color:#8880aa;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.lb-board-tab:hover{background:#2e2e45;color:#c0b0e0}.lb-board-tab.active{background:#3a2a60;border-color:#9c7ce3;color:#e0cfff}.lb-board-max-players{display:block;font-size:.65rem;color:#8a7aaa;font-weight:400;margin-top:2px}.lb-board-tab.active .lb-board-max-players{color:#b89ee8}.lb-td-players{text-align:center;color:#9a8ab8;font-size:.82rem}.lb-period-tabs{display:flex;gap:.35rem;padding:.6rem 1.5rem;flex-shrink:0;overflow-x:auto}.lb-period-tabs::-webkit-scrollbar{display:none}.lb-period-tab{white-space:nowrap;padding:.35rem .85rem;background:none;border:1.5px solid #2e2e4a;border-radius:20px;color:#7070a0;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.lb-period-tab:hover{border-color:#5a4a8a;color:#b0a0d0}.lb-period-tab.active{background:#9c7ce32e;border-color:#9c7ce3;color:#d0c0f0}.lb-reset-info{display:flex;align-items:center;gap:.5rem;padding:.3rem 1.5rem .6rem;flex-wrap:wrap}.lb-reset-countdown{font-size:.78rem;font-weight:700;color:#9c7ce3}.lb-reset-at{font-size:.73rem;color:#6060a0}.lb-table-wrap{flex:1;overflow-y:auto;padding:0 .5rem 1rem}.lb-table-wrap::-webkit-scrollbar{width:4px}.lb-table-wrap::-webkit-scrollbar-thumb{background:#3a3a58;border-radius:4px}.lb-status{text-align:center;color:#6060a0;padding:2.5rem 1rem;font-size:.9rem}.lb-error{color:#f4a0a0}.lb-table{width:100%;border-collapse:collapse;font-size:.9rem}.lb-th{color:#6060a0;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.5rem .75rem;border-bottom:1px solid #2a2a42;text-align:left}.lb-th-rank{width:60px;text-align:center}.lb-th-score{text-align:right}.lb-row{transition:background .15s}.lb-row:hover{background:#ffffff08}.lb-row-gold{background:#ffd7000f}.lb-row-silver{background:#c0c0c00d}.lb-row-bronze{background:#cd7f320d}.lb-td{padding:.65rem .75rem;border-bottom:1px solid #22223a;color:#c8c0e0;vertical-align:middle}.lb-td-rank{text-align:center}.lb-td-score{text-align:right;font-weight:700;color:#e8d0ff}.lb-rank-badge{font-size:1.2rem}.lb-rank-num{font-weight:700;color:#6060a0;font-size:.95rem}.lb-nickname{display:inline-flex;align-items:center;gap:.35rem;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lb-nickname-masked .lb-masked-text{color:#8880aa;font-style:italic}.lb-eye-btn{background:none;border:none;cursor:pointer;font-size:.9rem;padding:1px 3px;border-radius:4px;opacity:.6;transition:opacity .2s;flex-shrink:0;position:relative}.lb-eye-btn:hover{opacity:1}.lb-mask-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#2e1a4e;border:1px solid #6040a0;border-radius:8px;padding:.5rem .75rem;font-size:.78rem;color:#d0b8ff;white-space:normal;width:220px;z-index:10;pointer-events:none;box-shadow:0 4px 16px #0006;line-height:1.5}.lb-mask-tooltip em{color:#f4c06a;font-style:normal}@media (max-width: 480px){.lb-overlay{padding:.5rem}.lb-modal{max-height:94vh;max-height:94dvh;border-radius:14px}.lb-header{padding:1rem 1.25rem .6rem}.lb-title{font-size:clamp(1rem,4vw,1.2rem)}.lb-type-tabs,.lb-board-tabs,.lb-period-tabs{padding-left:.75rem;padding-right:.75rem}.lb-table-wrap{padding:0 0 .75rem}.lb-table{font-size:clamp(.78rem,3.5vw,.9rem)}.lb-th{padding:.4rem .5rem;font-size:clamp(.65rem,2.5vw,.75rem)}.lb-td{padding:.5rem}.lb-th-rank{width:44px}.lb-nickname{max-width:50vw}}@media (max-width: 360px){.lb-table{font-size:.75rem}.lb-nickname{max-width:40vw}.lb-td{padding:.45rem .4rem}}.lb-row-mine{background:linear-gradient(90deg,#ffd70021,#ffd7000d);outline:1px solid rgba(255,215,0,.32)}.lb-me-badge{display:inline-block;background:#f5c542;color:#1a1a1a;border-radius:4px;font-size:10px;font-weight:700;padding:1px 5px;margin-left:5px;vertical-align:middle;line-height:1.4}.tnm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000c7;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.tnm-modal{background:#1a1a2e;border:1px solid #4a3a7a;border-radius:18px;width:100%;max-width:480px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 12px 50px #643cb466;animation:tnmIn .25s ease}@keyframes tnmIn{0%{transform:translateY(-12px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.tnm-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem .75rem;border-bottom:1px solid #2e2e4a;flex-shrink:0}.tnm-title{font-size:1.05rem;font-weight:700;color:#e0d0ff}.tnm-score{font-size:.85rem;color:#9c7ce3}.tnm-slots{overflow-y:auto;flex:1;padding:.75rem 1.25rem;display:flex;flex-direction:column;gap:.6rem}.tnm-slot{background:#252538;border:1.5px solid #3a3a5a;border-radius:10px;padding:.65rem .85rem;transition:border-color .15s}.tnm-slot.tnm-slot-mine{border-color:#7a5ab8}.tnm-slot.tnm-slot-confirmed{border-color:#4a8a5a;background:#1e2e28}.tnm-slot-header{display:flex;align-items:center;gap:.4rem;margin-bottom:.4rem}.tnm-slot-name{font-size:.82rem;color:#c0b0e0;font-weight:600}.tnm-slot-me{font-size:.7rem;background:#5a3a9a;color:#e0cfff;border-radius:4px;padding:1px 5px}.tnm-slot-limit{margin-left:auto;font-size:.72rem;color:#7a6a9a}.tnm-slot-input-row{display:flex;gap:.5rem;align-items:center}.tnm-input{flex:1;background:#1a1a2e;border:1px solid #5a4a8a;border-radius:7px;color:#e0d0ff;font-size:.92rem;padding:.35rem .6rem;outline:none}.tnm-input:focus{border-color:#9c7ce3}.tnm-input:disabled{opacity:.6}.tnm-confirm-btn{padding:.35rem .75rem;border-radius:7px;border:1.5px solid #5a4a8a;background:#2e2e4a;color:#c0b0e0;font-size:.82rem;cursor:pointer;white-space:nowrap;transition:all .15s}.tnm-confirm-btn.confirmed{background:#3a6a4a;border-color:#5aaa6a;color:#b0e8b0}.tnm-slot-other{display:flex;align-items:center;gap:.5rem;min-height:1.8rem}.tnm-slot-text{font-size:.9rem;color:#d0c0f0}.tnm-slot-placeholder{color:#5a5a7a;font-style:italic}.tnm-confirmed-badge{color:#5aaa6a;font-weight:700;font-size:1rem}.tnm-preview{padding:.6rem 1.25rem;background:#1e1e35;border-top:1px solid #2e2e4a;font-size:.88rem;flex-shrink:0}.tnm-preview-label{color:#7a6a9a}.tnm-preview-text{color:#e0d0ff;font-weight:600}.tnm-error{padding:.4rem 1.25rem;color:#ff7a7a;font-size:.82rem;flex-shrink:0}.tnm-footer{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.25rem;border-top:1px solid #2e2e4a;flex-shrink:0}.tnm-confirm-status{font-size:.82rem;color:#7a6a9a}.tnm-submit-btn{padding:.55rem 1.5rem;background:#5a3a9a;border:1.5px solid #7a5ab8;border-radius:10px;color:#fff;font-size:.9rem;font-weight:700;cursor:pointer;transition:all .15s}.tnm-submit-btn:hover:not(:disabled){background:#7a5ab8}.tnm-submit-btn:disabled{opacity:.4;cursor:not-allowed}.title-unlock-toast{position:fixed;top:80px;left:50%;transform:translate(-50%);z-index:9999;background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid rgba(157,123,255,.5);border-radius:16px;padding:18px 28px;text-align:center;box-shadow:0 8px 32px #0009,0 0 20px #9d7bff33;animation:tut-appear .4s cubic-bezier(.34,1.56,.64,1) both;overflow:hidden;min-width:240px}@keyframes tut-appear{0%{opacity:0;transform:translate(-50%) translateY(-20px) scale(.8)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.tut-shine{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.06) 50%,transparent 60%);background-size:200%;animation:tut-shine 1.5s ease-in-out infinite;pointer-events:none}@keyframes tut-shine{0%{background-position:200% center}to{background-position:-200% center}}.tut-content{display:flex;flex-direction:column;align-items:center;gap:10px;position:relative}.tut-label{font-size:.85rem;font-weight:700;color:#aaa;letter-spacing:.5px}.tut-sparkles{font-size:1.2rem;letter-spacing:4px;animation:sparkle-pulse .8s ease-in-out infinite alternate}@keyframes sparkle-pulse{0%{opacity:.6;transform:scale(.95)}to{opacity:1;transform:scale(1.05)}}.quickmatch-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.quickmatch-card{background:#fff;border-radius:20px;padding:40px;text-align:center;min-width:280px;box-shadow:0 8px 32px #0003}.quickmatch-spinner{width:48px;height:48px;border:4px solid rgba(168,85,247,.2);border-top:4px solid #A855F7;border-radius:50%;animation:quickmatch-spin .8s linear infinite;margin:0 auto 20px}@keyframes quickmatch-spin{to{transform:rotate(360deg)}}.quickmatch-title{font-size:18px;font-weight:700;color:#1e1e22;margin-bottom:8px;min-width:180px}.quickmatch-elapsed{font-size:14px;color:#888;margin-bottom:24px}.quickmatch-cancel-btn{padding:10px 32px;font-size:14px;font-weight:600;border:2px solid #ddd;border-radius:10px;background:#fff;color:#666;cursor:pointer;transition:all .2s}.quickmatch-cancel-btn:hover{border-color:#ff6b6b;color:#ff6b6b}.landing-screen{min-height:100vh;background:var(--bg-gradient);color:var(--text-primary);overflow-x:hidden}.landing-nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--surface-nav);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:var(--shadow-nav)}.nav-logo{font-family:Arial Black,Arial,sans-serif;font-size:18px;font-weight:900;color:var(--logo-color);letter-spacing:1px}.nav-controls{display:flex;align-items:center;gap:8px}.landing-hero{min-height:calc(100vh - 110px);min-height:calc(100dvh - 110px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 20px 40px;position:relative}.hero-content{display:flex;flex-direction:column;align-items:center;gap:20px;max-width:600px}.hero-logo{width:160px;height:160px;display:flex;align-items:center;justify-content:center}.hero-logo .landing-logo{width:100%;height:100%;transform-origin:center center}.hero-logo .landing-logo .interactive-logo-image{width:100%;height:100%;object-fit:contain}.hero-tagline{font-size:clamp(18px,4vw,26px);font-weight:700;line-height:1.5;color:var(--text-primary);margin:0}.hero-cta-group{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}.hero-cta{padding:14px 32px;border:none;border-radius:50px;font-size:16px;font-weight:700;cursor:pointer;transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;white-space:nowrap;position:relative;overflow:hidden}.hero-cta:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.3) 0%,transparent 100%);border-radius:50px 50px 0 0;pointer-events:none}.hero-cta:after{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);pointer-events:none;transition:none}.hero-cta:hover:after{animation:glossShimmer 1.5s ease}.hero-cta:active{animation:jellyPress .4s ease}.hero-cta-primary{background:var(--color-primary-gradient);color:var(--text-on-primary);box-shadow:0 4px 20px var(--color-primary-shadow),var(--jelly-btn-depth-primary)}.hero-cta-primary:hover{box-shadow:0 6px 28px var(--color-primary-shadow-hover),var(--jelly-btn-depth-primary);transform:translateY(-3px) scale(1.02)}.hero-cta-secondary{background:var(--color-secondary-gradient);color:var(--text-on-dark-btn);box-shadow:0 4px 20px var(--color-secondary-shadow),var(--jelly-btn-depth)}.hero-cta-secondary:hover{box-shadow:0 6px 28px var(--color-secondary-shadow),var(--jelly-btn-depth);transform:translateY(-3px) scale(1.02)}.hero-subtext{font-size:14px;color:var(--text-tertiary);margin:0}.hero-scroll-hint{position:absolute;bottom:24px;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:color .3s ease,transform .3s ease}.hero-scroll-hint:hover{color:var(--text-primary);transform:translateY(2px)}.hero-scroll-hint-text{font-size:11px;letter-spacing:.5px;opacity:.65}.landing-section-title{font-size:clamp(20px,4vw,28px);font-weight:800;text-align:center;margin-bottom:32px;color:var(--text-primary);cursor:pointer;transition:opacity .3s ease;-webkit-user-select:none;user-select:none}.landing-section-title:hover{opacity:.8}.landing-demo{padding:60px 20px 80px;max-width:900px;margin:0 auto}.demo-layout{display:flex;align-items:center;gap:40px}.demo-animation{flex:0 0 auto;transform:scale(1.2);transform-origin:center}.demo-text{flex:1}.demo-description{font-size:16px;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}.demo-steps{display:flex;flex-direction:column;gap:12px}.demo-step{display:flex;align-items:center;gap:12px;padding:10px 16px;border-radius:12px;background:var(--surface-subtle);color:var(--text-tertiary);font-size:14px;transition:all .3s}.demo-step.active{background:var(--color-primary-bg);color:var(--text-accent)}.demo-step-num{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;background:var(--surface-subtle);flex-shrink:0}.demo-step.active .demo-step-num{background:var(--color-primary-bg-hover)}.landing-modes{padding:60px 20px 80px;max-width:900px;margin:0 auto}.modes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.mode-card{background:var(--surface-card);border:1px solid var(--border-subtle);border-bottom:2px solid var(--border-medium);border-radius:20px;padding:28px 20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;transition:transform .25s cubic-bezier(.34,1.56,.64,1),border-color .2s,box-shadow .2s;box-shadow:var(--shadow-card);position:relative;overflow:hidden}.mode-card:before{content:"";position:absolute;top:0;left:0;right:0;height:40%;background:linear-gradient(180deg,rgba(255,255,255,.15) 0%,transparent 100%);border-radius:20px 20px 0 0;pointer-events:none}.mode-card:hover{transform:translateY(-4px) scale(1.02);border-color:var(--border-strong);box-shadow:var(--shadow-card),0 8px 24px #0000000f}.mode-icon{width:56px;height:56px;border-radius:var(--jelly-radius);display:flex;align-items:center;justify-content:center;background:var(--surface-subtle);animation:jellyFloat 4s ease-in-out infinite}.mode-card:nth-child(2) .mode-icon{animation-delay:-1.3s}.mode-card:nth-child(3) .mode-icon{animation-delay:-2.6s}.mode-title{font-size:17px;font-weight:700;margin:0;color:var(--text-primary)}.mode-desc{font-size:13px;color:var(--text-tertiary);margin:0;line-height:1.5}.mode-cta{margin-top:auto;padding:10px 24px;border:none;border-radius:25px;font-size:14px;font-weight:700;color:var(--text-on-primary);cursor:pointer;transition:transform .2s cubic-bezier(.34,1.56,.64,1),opacity .2s;position:relative;overflow:hidden;box-shadow:var(--jelly-btn-depth)}.mode-cta:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,transparent 100%);border-radius:25px 25px 0 0;pointer-events:none}.mode-cta:hover{opacity:.95;transform:scale(1.04)}.mode-cta:active{animation:jellyPress .4s ease}.landing-leaderboard{padding:60px 20px 80px;max-width:600px;margin:0 auto}.leaderboard-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.leaderboard-entry{display:flex;align-items:center;gap:16px;padding:14px 20px;border-radius:14px;background:var(--surface-card);border:1px solid var(--border-subtle)}.leaderboard-rank{font-size:22px;font-weight:900;width:32px;text-align:center;flex-shrink:0}.leaderboard-name{flex:1;font-size:15px;color:var(--text-secondary);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leaderboard-score{font-size:16px;font-weight:700;color:var(--text-accent);flex-shrink:0}.leaderboard-view-all{display:block;margin:0 auto;padding:10px 28px;background:var(--color-primary-bg);border:1px solid var(--border-strong);border-radius:25px;color:var(--text-accent);font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.leaderboard-view-all:hover{background:var(--color-primary-bg-hover)}.landing-footer{padding:40px 20px;text-align:center;border-top:1px solid var(--border-subtle)}.footer-info{font-size:13px;color:var(--text-tertiary);margin-bottom:12px}.footer-links{display:flex;justify-content:center;gap:20px;margin-bottom:12px}.footer-link{font-size:12px;color:var(--text-muted);text-decoration:none}.footer-link:hover{color:var(--text-secondary)}.footer-copy{font-size:11px;color:var(--text-muted)}@media (max-width: 768px){.hero-logo{width:120px;height:120px}.hero-cta{padding:12px 24px;font-size:15px}.demo-layout{flex-direction:column;gap:24px}.demo-animation{transform:scale(1)}.modes-grid{grid-template-columns:1fr;gap:14px}.mode-card{flex-direction:row;text-align:left;padding:20px;gap:16px}.mode-card .mode-icon{width:48px;height:48px;border-radius:14px;flex-shrink:0}.mode-card .mode-cta{margin-top:0;margin-left:auto;white-space:nowrap;flex-shrink:0}}@media (max-width: 480px){.hero-logo{width:100px;height:100px}.hero-cta-group{flex-direction:column;width:100%;max-width:280px}.hero-cta{width:100%}.landing-section-title{font-size:20px}.mode-card{flex-direction:column;text-align:center}.mode-card .mode-cta{margin-left:0;margin-top:8px}}button.footer-link{background:none;border:none;padding:0;cursor:pointer;font-family:inherit;font-size:12px;color:var(--text-muted);transition:color .2s}button.footer-link:hover{color:var(--text-secondary)}.cookie-consent{position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary, #1a1a2e);border-top:1px solid var(--border-subtle, rgba(255,255,255,.1));padding:12px 24px;display:flex;align-items:center;gap:12px;z-index:1002;flex-wrap:wrap;justify-content:center}.cookie-text{font-size:13px;color:var(--text-secondary);margin:0;flex:1;min-width:200px;text-align:left}.cookie-btn-learn{background:none;border:1px solid var(--border-subtle, rgba(255,255,255,.2));color:var(--text-muted);padding:6px 14px;border-radius:6px;cursor:pointer;font-size:12px;font-family:inherit;transition:border-color .2s;white-space:nowrap}.cookie-btn-learn:hover{border-color:var(--text-muted)}.cookie-btn-accept{background:var(--accent, #9d7bff);border:none;color:#fff;padding:6px 18px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;font-family:inherit;transition:opacity .2s;white-space:nowrap}.cookie-btn-accept:hover{opacity:.85}.queue-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#060e18eb;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.queue-card{width:380px;max-width:calc(100vw - 40px);background:#0a1624f2;border:1.5px solid rgba(157,123,255,.28);border-radius:20px;padding:40px 36px 32px;text-align:center;box-shadow:0 0 40px #9d7bff14,0 20px 60px #0009;color:#e8e8e8;animation:queueCardIn .35s cubic-bezier(.22,.61,.36,1)}@keyframes queueCardIn{0%{opacity:0;transform:translateY(24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.queue-icon-wrap{display:flex;justify-content:center;margin-bottom:24px}.queue-spinner{width:52px;height:52px;border-radius:50%;border:4px solid rgba(157,123,255,.18);border-top-color:#9d7bff;animation:queueSpin .9s linear infinite}@keyframes queueSpin{to{transform:rotate(360deg)}}.queue-title{margin:0 0 8px;font-size:1.4rem;font-weight:800;color:#9d7bff;letter-spacing:-.02em}.queue-subtitle{margin:0 0 28px;font-size:.88rem;color:#7a8a99;line-height:1.55}.queue-invite-hint{display:flex;align-items:flex-start;gap:10px;background:#9d7bff12;border:1px solid rgba(157,123,255,.22);border-radius:10px;padding:12px 16px;margin-bottom:22px;text-align:left;font-size:.84rem;color:#8ac9b5;line-height:1.5}.queue-invite-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.queue-position-block{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:20px}.queue-position-label{font-size:.75rem;color:#5a6a7a;font-weight:700;text-transform:uppercase;letter-spacing:.06em}.queue-position-number{font-size:3rem;font-weight:900;color:#c8f0e0;line-height:1;font-variant-numeric:tabular-nums;text-shadow:0 0 24px rgba(157,123,255,.35)}.queue-position-total{font-size:.82rem;color:#6a7e90}.queue-progress-bar{height:6px;background:#ffffff14;border-radius:3px;overflow:hidden;margin-bottom:16px}.queue-progress-fill{height:100%;background:linear-gradient(90deg,#7c5ce0,#9d7bff);border-radius:3px;transition:width .8s ease}.queue-elapsed{margin:0 0 28px;font-size:.82rem;color:#5a6a7a}.queue-elapsed strong{color:#99b8cc;font-variant-numeric:tabular-nums}.queue-leave-btn{padding:10px 28px;background:transparent;border:1.5px solid rgba(255,255,255,.18);border-radius:8px;color:#6a7e90;font-size:.88rem;font-weight:600;cursor:pointer;transition:border-color .2s,color .2s,background .2s}.queue-leave-btn:hover{border-color:#f4433680;color:#ef9a9a;background:#f4433614}.queue-confirm{animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.queue-confirm p{margin:0 0 16px;font-size:.88rem;color:#9ab;line-height:1.6}.queue-confirm-btns{display:flex;gap:10px;justify-content:center}.queue-confirm-yes{padding:9px 22px;background:#f443362e;border:1.5px solid rgba(244,67,54,.45);border-radius:8px;color:#ef9a9a;font-size:.88rem;font-weight:700;cursor:pointer;transition:background .2s}.queue-confirm-yes:hover{background:#f4433647}.queue-confirm-no{padding:9px 22px;background:#9d7bff1a;border:1.5px solid rgba(157,123,255,.3);border-radius:8px;color:#9d7bff;font-size:.88rem;font-weight:700;cursor:pointer;transition:background .2s}.queue-confirm-no:hover{background:#9d7bff33}@media (max-width: 380px){.queue-card{padding:28px 20px 24px;border-radius:16px}.queue-icon-wrap{margin-bottom:16px}.queue-spinner{width:40px;height:40px}.queue-title{font-size:1.2rem}.queue-subtitle{font-size:.82rem;margin-bottom:20px}.queue-position-number{font-size:2.4rem}.queue-elapsed{margin-bottom:20px}.queue-confirm-btns{flex-direction:column;gap:8px}.queue-confirm-yes,.queue-confirm-no{padding:10px 16px;width:100%}}@media (max-height: 500px) and (orientation: landscape){.queue-card{padding:20px 32px;max-height:90vh;overflow-y:auto}.queue-icon-wrap{margin-bottom:12px}.queue-subtitle{margin-bottom:16px}.queue-position-block{margin-bottom:12px}.queue-elapsed{margin-bottom:16px}}.idle-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#060e18e0;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.idle-card{width:360px;max-width:calc(100vw - 40px);background:#0a1624f7;border:1.5px solid rgba(255,193,7,.3);border-radius:20px;padding:40px 32px 32px;text-align:center;box-shadow:0 0 40px #ffc10714,0 20px 60px #0009;color:#e8e8e8;animation:idleCardIn .3s cubic-bezier(.22,.61,.36,1)}@keyframes idleCardIn{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.idle-icon{font-size:2.8rem;margin-bottom:16px;display:block}.idle-title{margin:0 0 10px;font-size:1.3rem;font-weight:800;color:#ffd54f;letter-spacing:-.02em}.idle-desc{margin:0 0 28px;font-size:.87rem;color:#7a8a99;line-height:1.6}.idle-countdown{display:flex;flex-direction:column;align-items:center;gap:4px;margin-bottom:28px;padding:16px;background:#ffc1070f;border:1px solid rgba(255,193,7,.18);border-radius:12px;transition:background .4s,border-color .4s}.idle-countdown.warning{background:#ff98001a;border-color:#ff980059}.idle-countdown.urgent{background:#f443361f;border-color:#f4433666;animation:idlePulse .8s ease-in-out infinite}@keyframes idlePulse{0%,to{box-shadow:none}50%{box-shadow:0 0 14px #f4433640}}.idle-count-num{font-size:2.8rem;font-weight:900;color:#ffd54f;line-height:1;font-variant-numeric:tabular-nums;transition:color .4s}.idle-countdown.warning .idle-count-num{color:#ffb74d}.idle-countdown.urgent .idle-count-num{color:#ef9a9a}.idle-count-unit{font-size:.8rem;color:#5a6a7a;font-weight:600}.idle-ack-btn{width:100%;padding:13px 0;background:linear-gradient(135deg,#ffc107,#ff9800);border:none;border-radius:10px;color:#1a1200;font-size:.95rem;font-weight:800;cursor:pointer;letter-spacing:.02em;transition:opacity .15s,transform .15s}.idle-ack-btn:hover{opacity:.9;transform:translateY(-1px)}.idle-ack-btn:active{opacity:1;transform:translateY(0)}.reconnecting-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0009;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.reconnecting-box{display:flex;flex-direction:column;align-items:center;gap:.75rem;background:#141428eb;border:1.5px solid rgba(156,124,227,.4);border-radius:16px;padding:2rem;width:280px;text-align:center}.reconnecting-spinner{width:40px;height:40px;border:3px solid rgba(156,124,227,.2);border-top-color:#9c7ce3;border-radius:50%;animation:reconnect-spin .9s linear infinite}@keyframes reconnect-spin{to{transform:rotate(360deg)}}.reconnecting-text{color:#c0b0e8;font-size:.9rem;font-weight:600;margin:0;min-height:1.4em}.reconnecting-progress-wrap{position:relative;width:100%;background:#ffffff14;border-radius:4px;height:5px;overflow:visible}.reconnecting-progress-bar{height:100%;background:#9c7ce3;border-radius:4px;transition:width .5s ease;max-width:100%}.reconnecting-progress-bar.last{background:#e86060}.reconnecting-attempt-label{position:absolute;right:0;top:10px;font-size:.7rem;color:#ffffff59;font-variant-numeric:tabular-nums}.reconnecting-timer{font-size:.75rem;color:#ffffff59;margin:0;font-variant-numeric:tabular-nums;letter-spacing:.02em}.reconnecting-reload-btn{padding:8px 20px;background:var(--color-primary, #9c7ce3);color:#fff;border:none;border-radius:8px;font-size:.82rem;font-weight:600;cursor:pointer;transition:opacity .15s}.reconnecting-reload-btn:hover{opacity:.85}.reconnecting-hint{font-size:.78rem;color:#ffd764a6;margin:0;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.07);width:100%;text-align:center;line-height:1.4}*{margin:0;padding:0;box-sizing:border-box}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--game-bg);min-height:100vh;font-size:clamp(14px,2vw,16px)}button{min-height:44px;min-width:44px;touch-action:manipulation}.app{height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;display:flex;flex-direction:column;align-items:stretch;overflow:hidden;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}@media (orientation: landscape){.app{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}.app-header{text-align:center;margin-bottom:30px;color:var(--game-text-dark)}.app-title{font-size:48px;font-weight:800;letter-spacing:2px;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.app-subtitle{font-size:18px;color:var(--game-text-dark);opacity:.8}.start-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;padding:20px}.main-menu{display:flex;flex-direction:column;align-items:center;gap:40px}.game-logo{display:flex;align-items:center;gap:20px}.logo-icon{width:80px;height:80px;background:var(--color-primary-gradient);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;color:#fff;position:relative;overflow:hidden;box-shadow:0 8px 24px var(--color-primary-shadow)}.logo-image{width:150px;height:150px;object-fit:contain;margin-bottom:10px}.main-menu-logo{width:150px;height:150px;margin-bottom:10px}.logo-shine{position:absolute;top:0;left:-100%;width:50%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.5),transparent);animation:logo-shine 3s infinite}@keyframes logo-shine{0%{left:-100%}50%{left:200%}to{left:200%}}.game-logo h1{font-size:72px;font-weight:900;color:var(--game-text-dark);text-shadow:2px 2px 4px rgba(0,0,0,.1)}.menu-buttons{display:flex;flex-direction:column;gap:16px}.menu-btn{padding:20px 60px;font-size:24px;font-weight:700;border:none;border-radius:16px;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);min-width:300px;position:relative;overflow:hidden}.menu-btn:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,transparent 100%);border-radius:16px 16px 0 0;pointer-events:none}.menu-btn:after{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);pointer-events:none}.menu-btn:hover:after{animation:glossShimmer 1.5s ease}.menu-btn:active{animation:jellyPress .4s ease}.menu-btn.single-play{background:var(--color-primary-gradient);color:var(--text-on-primary);box-shadow:0 6px 20px var(--color-primary-shadow),var(--jelly-btn-depth-primary)}.menu-btn.single-play:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 28px var(--color-primary-shadow-hover),var(--jelly-btn-depth-primary)}.menu-btn.multi-play{background:var(--color-secondary-gradient);color:var(--text-on-primary);box-shadow:0 6px 20px var(--color-secondary-shadow),var(--jelly-btn-depth)}.menu-btn.multi-play:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 28px var(--color-secondary-shadow),var(--jelly-btn-depth)}.start-options{background:#fff;padding:40px;border-radius:22px;box-shadow:0 8px 32px #0000001a;text-align:center;min-width:400px}.start-options h2{font-size:24px;color:var(--game-text-dark);margin-bottom:20px}.back-button{margin-top:16px;padding:12px 32px;background:var(--game-back-btn);color:var(--game-text-dark);border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.back-button:hover{background:var(--game-back-btn-hover);transform:translateY(-2px)}.size-buttons{display:flex;gap:10px;justify-content:center;margin-bottom:30px}.size-button{padding:12px 24px;border:2px solid var(--color-primary);background:#fff;color:var(--color-primary);border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.size-button:hover{background:var(--color-primary);color:var(--text-on-primary);transform:translateY(-2px)}.size-button.active{background:var(--color-primary);color:var(--text-on-primary)}.start-button{padding:16px 48px;background:var(--color-primary-gradient);color:var(--text-on-primary);border:none;border-radius:16px;font-size:20px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px var(--color-primary-shadow)}.start-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--color-primary-shadow-hover)}.start-button:active{transform:translateY(0)}.game-screen{display:flex;flex-direction:column;align-items:center;width:100%;flex:1;min-height:0;overflow:hidden;background:var(--game-bg)}.game-stats{display:flex;gap:30px;margin-bottom:20px;background:#fff;padding:20px 40px;border-radius:16px;box-shadow:0 4px 16px #0000001a}.stat{display:flex;flex-direction:column;align-items:center;gap:5px}.stat-label{font-size:14px;color:var(--game-text-dark);opacity:.7;font-weight:600}.stat-value{font-size:32px;font-weight:800;color:var(--color-primary)}.game-over-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.game-over-panel{background:#fff;padding:40px;border-radius:22px;text-align:center;box-shadow:0 8px 32px #0003;min-width:500px;max-width:850px;width:90%;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.game-over-panel h2{font-size:32px;color:var(--game-text-dark);margin-bottom:20px}.final-score{font-size:24px;color:var(--color-primary);font-weight:700;margin-bottom:30px}.result-title{font-size:32px;font-weight:700;color:var(--game-text-dark);margin-bottom:16px;text-align:center;flex-shrink:0}.winner-highlight{background:linear-gradient(135deg,gold,orange);padding:20px;border-radius:16px;margin-bottom:16px;box-shadow:0 4px 16px #ffd7004d;animation:winner-glow 2s ease-in-out infinite;display:flex;align-items:center;gap:16px;flex-shrink:0}@keyframes winner-glow{0%,to{box-shadow:0 4px 16px #ffd7004d}50%{box-shadow:0 8px 24px #ffd70099}}.winner-rank{font-size:48px;font-weight:900;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3);min-width:60px;text-align:center}.winner-info{flex:1}.winner-name{font-size:24px;font-weight:800;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3);margin-bottom:4px}.winner-badge{display:inline-block;background:#ffffff4d;padding:4px 12px;border-radius:12px;font-size:12px;color:#fff;font-weight:600}.winner-score{font-size:32px;font-weight:900;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.result-rankings{flex:1;overflow-y:auto;overflow-x:hidden;margin-bottom:16px;padding-right:8px;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.result-rankings::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:10px}.ranking-item{display:flex;align-items:center;gap:16px;padding:16px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:12px;transition:transform .2s,box-shadow .2s;border-left:4px solid var(--color-primary);min-height:56px;touch-action:manipulation;opacity:0;animation:ranking-fade-in .3s ease forwards}.ranking-item:nth-child(1){animation-delay:.1s}.ranking-item:nth-child(2){animation-delay:.2s}.ranking-item:nth-child(3){animation-delay:.3s}.ranking-item:nth-child(4){animation-delay:.4s}.ranking-item:nth-child(5){animation-delay:.5s}.ranking-item:nth-child(n+6){animation-delay:.6s}@keyframes ranking-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ranking-item:active{background:var(--color-primary-bg);transform:scale(.98)}.rank{font-size:24px;font-weight:800;color:var(--color-primary);min-width:40px;text-align:center}.player-info-result{flex:1}.player-name-result{font-size:18px;font-weight:600;color:var(--game-text-dark);margin-bottom:4px}.player-score-result{font-size:24px;font-weight:800;color:var(--color-primary)}.team-header-result{display:flex;align-items:center;gap:8px;margin-bottom:8px}.team-members-chips{display:flex;flex-wrap:wrap;gap:6px}.member-chip{padding:4px 10px;border-radius:12px;font-size:12px;border:1px solid}.member-score{font-size:10px}.result-actions{display:flex;flex-direction:column;gap:12px;padding:16px;background:#fff;flex-shrink:0}.result-actions button{width:100%;padding:14px;font-size:16px;border-radius:12px;border:none;font-weight:600;cursor:pointer;transition:all .2s ease;min-height:44px}.replay-button{background:var(--color-primary);color:var(--text-on-primary)}.replay-button:hover{background:var(--color-primary-end);transform:translateY(-2px)}.return-to-lobby-btn{background:var(--game-back-btn);color:var(--game-text-dark)}.return-to-lobby-btn:hover{background:var(--color-primary);color:var(--text-on-primary);transform:translateY(-2px)}.restart-button,.menu-button{padding:12px 32px;margin:5px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.restart-button{background:var(--color-primary);color:var(--text-on-primary)}.restart-button:hover{background:var(--color-primary-end);transform:translateY(-2px)}.menu-button{background:var(--game-back-btn);color:var(--game-text-dark)}.menu-button:hover{background:var(--color-primary);color:var(--text-on-primary);transform:translateY(-2px)}@media (max-width: 768px) and (orientation: portrait),(max-width: 768px) and (min-height: 600px){.app-title{font-size:36px}.start-options{min-width:auto;padding:30px 20px;width:90%}.size-buttons{flex-direction:column}.game-stats{gap:20px;padding:15px 30px}.stat-value{font-size:28px}.game-screen{gap:5px}.game-top-bar{width:100%;padding:4px 8px;gap:8px}.menu-btn{min-width:250px;padding:16px 40px;font-size:20px}.game-logo h1{font-size:48px}.logo-icon{width:60px;height:60px;font-size:36px}}@media (max-width: 480px){.app-title{font-size:28px}.app-subtitle{font-size:14px}.game-stats{gap:15px;padding:10px 20px}.stat-value{font-size:24px}.menu-btn{min-width:200px;padding:14px 32px;font-size:18px}.game-logo h1{font-size:36px}.logo-icon{width:50px;height:50px;font-size:30px;border-radius:14px}.game-over-panel{min-width:auto;width:95%;padding:16px;max-height:90vh}.game-over-panel h2{font-size:24px}.final-score{font-size:20px}.result-title{font-size:24px;margin-bottom:12px}.winner-highlight{padding:16px}.winner-rank{font-size:36px;min-width:50px}.winner-name{font-size:18px}.winner-score{font-size:24px}.ranking-item{padding:12px 16px;gap:12px}.rank{font-size:18px;min-width:32px}.player-name-result{font-size:14px}.player-score-result{font-size:18px}.member-chip{padding:3px 8px;font-size:11px}.result-actions button{font-size:14px;padding:12px}.result-rankings::-webkit-scrollbar{display:none}.result-rankings{scrollbar-width:none}.result-actions{position:sticky;bottom:0;box-shadow:0 -2px 10px #0000001a;padding:12px 0 0;gap:10px;background:#fff;border-top:none}}@media (max-height: 600px) and (orientation: landscape) and (max-width: 1024px){.app{min-height:100vh}.game-layout-left .player-name,.game-layout-left .player-name-mini{display:none}.game-stats{padding:8px 16px;gap:12px}.stat-value{font-size:20px}.stat-label{font-size:12px}.menu-buttons{flex-direction:row;gap:12px}.menu-btn{padding:12px 24px;font-size:16px;min-width:180px}.game-logo h1{font-size:42px}}.result-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 20px}.result-title{font-size:48px;font-weight:700;color:var(--game-text-dark);margin-bottom:20px;text-align:center;flex-shrink:0}.result-rankings{width:100%;max-width:100%;display:flex;flex-direction:column;gap:16px;overflow-y:auto;overflow-x:hidden;flex:1;margin:20px 0;padding-right:8px}.result-rankings::-webkit-scrollbar{width:8px}.result-rankings::-webkit-scrollbar-track{background:var(--scrollbar-track);border-radius:10px}.result-rankings::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:10px;transition:background .2s}.result-rankings::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}.ranking-item{display:flex;align-items:center;gap:20px;padding:20px 24px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.ranking-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.ranking-item.winner{background:linear-gradient(135deg,gold,orange);box-shadow:0 4px 16px #ffd70066;transform:scale(1.05)}.ranking-item.winner:hover{transform:scale(1.05) translateY(-2px);box-shadow:0 6px 20px #ffd70080}.rank{font-size:28px;font-weight:700;color:var(--game-text-dark);min-width:50px}.ranking-item.winner .rank{color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.player-info-result{flex:1;display:flex;align-items:center;gap:12px}.player-name-result{font-size:24px;font-weight:600;color:var(--game-text-dark)}.ranking-item.winner .player-name-result{color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.3)}.winner-badge{font-size:20px;animation:bounce 1s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.player-score-result{font-size:32px;font-weight:700;color:var(--game-text-dark)}.ranking-item.winner .player-score-result{color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.auto-return-msg{margin-top:30px;font-size:16px;color:#666;text-align:center}.replay-button{margin-top:12px;padding:14px 36px;font-size:17px;font-weight:700;background:var(--color-cta-gradient);color:var(--text-on-primary);border:none;border-radius:16px;cursor:pointer;transition:all .3s;box-shadow:0 4px 15px var(--color-cta-shadow);flex-shrink:0}.replay-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--color-cta-shadow)}.replay-button:active{transform:translateY(0)}.return-to-lobby-btn{margin-top:12px;padding:16px 48px;font-size:20px;font-weight:700;background:var(--color-primary-gradient);color:var(--text-on-primary);border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 12px var(--color-primary-shadow);transition:all .2s;flex-shrink:0}.return-to-lobby-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px var(--color-primary-shadow-hover)}.return-to-lobby-btn:active{transform:translateY(0)}.team-header-result{display:flex;align-items:center;gap:12px;margin-bottom:12px}.team-members-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.member-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 14px;border-radius:20px;font-size:14px;font-weight:600;border:2px solid;transition:all .2s;box-shadow:0 2px 8px #0000001a}.member-chip:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;filter:brightness(1.1)}.member-score{opacity:.8;font-weight:500}.ranking-item.winner .member-chip{background:#ffffff40!important;border-color:#fffc!important;color:#fff!important;text-shadow:0 1px 3px rgba(0,0,0,.3)}@media (max-width: 360px){.start-screen{padding:12px}.start-options{padding:24px 14px;border-radius:16px}.menu-btn{min-width:unset;width:100%;padding:13px 20px;font-size:17px}.main-menu-logo,.logo-image{width:110px;height:110px}.game-logo h1{font-size:28px}.game-over-panel{padding:14px;border-radius:16px}}.single-score-row{display:flex;align-items:center;width:100%;gap:8px;padding-right:16px}.single-score-row>.time-gauge-container{flex:1;max-width:none;padding-right:0}.single-score-badge{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#ffffffd9;border-radius:8px;padding:4px 12px;min-width:68px;line-height:1.2;box-shadow:0 2px 6px #0000001f;flex-shrink:0}.single-score-value{font-size:18px;font-weight:800;color:#2e7d32;letter-spacing:-.5px}.single-score-label{font-size:10px;font-weight:600;color:#757575;letter-spacing:.5px}.single-restart-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;background:#ffffffd9;box-shadow:0 2px 6px #0000001f;font-size:20px;color:#555;cursor:pointer;transition:background .15s,transform .1s;flex-shrink:0}.single-restart-btn:hover{background:#fff;transform:scale(1.08)}.single-restart-btn:active{transform:scale(.95)}@media (max-width: 768px){.single-score-badge{padding:2px 8px;min-width:52px;border-radius:6px}.single-score-value{font-size:14px}.single-score-label{font-size:9px}.single-restart-btn{width:30px;height:30px;font-size:16px;border-radius:6px}}@media (max-height: 600px) and (orientation: landscape) and (max-width: 1024px){.single-score-row,.game-top-bar{padding:2px 8px;gap:8px;min-height:0}.single-score-badge{min-width:50px;padding:2px 6px;border-radius:6px;flex-direction:row;gap:4px}.single-score-value{font-size:11px}.single-score-label{font-size:9px;color:#555}.single-restart-btn{width:28px;height:28px;font-size:15px}.target-badge{font-size:11px;padding:2px 8px}}.menu-btn.quick-play{background:var(--color-cta-gradient);color:var(--text-on-primary);box-shadow:0 6px 20px var(--color-cta-shadow),var(--jelly-btn-depth-cta)}.menu-btn.quick-play:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 8px 28px var(--color-cta-shadow),var(--jelly-btn-depth-cta)}.mode-description{font-size:13px;color:#888;margin-top:4px;text-align:center}.game-top-bar{display:flex;align-items:center;gap:12px;width:70vw;max-width:900px;margin:0 auto;padding:8px 0}.game-top-bar>.time-gauge-container{flex:1;width:auto;max-width:none;margin:0}.target-badge{display:inline-flex;align-items:center;justify-content:center;background:#ffffffd9;border-radius:8px;padding:6px 16px;font-size:15px;font-weight:800;color:#1565c0;box-shadow:0 2px 6px #0000001f;flex-shrink:0;letter-spacing:.5px;white-space:nowrap}.target-badge.target-highlight{background:linear-gradient(135deg,#fff3e0,#ffe0b2);color:#e65100;padding:8px 20px;font-size:18px;border:2px solid rgba(230,81,0,.4);box-shadow:0 2px 12px #e6510040;animation:target-pulse 2s ease-in-out infinite}@keyframes target-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.single-setup-screen{min-height:100vh;background:var(--bg-gradient);color:var(--text-primary);display:flex;flex-direction:column}.single-setup-nav{padding:12px 20px;display:flex;align-items:center;justify-content:space-between}.single-setup-controls{display:flex;align-items:center;gap:8px}.setup-back-btn{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);font-size:15px;font-weight:600;cursor:pointer;padding:8px 12px;border-radius:8px;transition:background .2s}.setup-back-btn:hover{background:var(--surface-subtle);color:var(--text-primary)}.single-setup-content{flex:1;display:flex;flex-direction:column;align-items:center;padding:20px 20px 40px;max-width:600px;margin:0 auto;width:100%;gap:28px}.single-setup-title{font-size:clamp(22px,5vw,30px);font-weight:800;color:var(--text-primary);margin:0}.setup-section{width:100%}.setup-section-label{font-size:14px;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin:0 0 12px 4px}.setup-mode-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}.setup-mode-card{background:var(--surface-subtle);border:2px solid var(--border-subtle);border-bottom:3px solid var(--border-medium);border-radius:16px;padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);color:var(--text-primary);text-align:center;position:relative;overflow:hidden}.setup-mode-card:before{content:"";position:absolute;top:0;left:0;right:0;height:40%;background:linear-gradient(180deg,rgba(255,255,255,.1) 0%,transparent 100%);pointer-events:none}.setup-mode-card:hover{border-color:var(--border-medium);background:var(--surface-card);transform:translateY(-2px) scale(1.02)}.setup-mode-card.selected{border-color:var(--border-focus);background:var(--color-primary-bg)}.setup-mode-icon{font-size:28px;font-weight:900;width:48px;height:48px;border-radius:14px;background:var(--surface-subtle);display:flex;align-items:center;justify-content:center;color:var(--text-accent)}.setup-mode-card.selected .setup-mode-icon{background:var(--color-primary-bg-hover)}.setup-mode-name{font-size:16px;font-weight:700}.setup-mode-desc{font-size:12px;color:var(--text-muted);line-height:1.4}.setup-size-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.setup-size-card{background:var(--surface-subtle);border:2px solid var(--border-subtle);border-bottom:3px solid var(--border-medium);border-radius:16px;padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;transition:all .25s cubic-bezier(.34,1.56,.64,1);color:var(--text-primary);text-align:center}.setup-size-card:hover{border-color:var(--border-medium);background:var(--surface-card);transform:translateY(-2px) scale(1.02)}.setup-size-card.selected{border-color:var(--border-focus);background:var(--color-primary-bg)}.setup-size-grid{display:grid;gap:2px;width:48px;height:36px}.setup-size-dot{background:var(--border-medium);border-radius:1px}.setup-size-card.selected .setup-size-dot{background:var(--color-primary-bg-hover)}.setup-size-label{font-size:20px;font-weight:800;color:var(--text-primary)}.setup-size-dims{font-size:11px;color:var(--text-muted)}.setup-size-rec{font-size:11px;color:var(--text-accent);font-weight:600}.setup-start-btn{width:100%;max-width:320px;padding:16px;border:none;border-radius:50px;background:var(--color-primary-gradient);color:var(--text-on-primary);font-size:18px;font-weight:700;cursor:pointer;box-shadow:0 4px 20px var(--color-primary-shadow),var(--jelly-btn-depth-primary);transition:transform .2s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;position:relative;overflow:hidden}.setup-start-btn:before{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.25) 0%,transparent 100%);border-radius:50px 50px 0 0;pointer-events:none}.setup-start-btn:after{content:"";position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);pointer-events:none}.setup-start-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 6px 28px var(--color-primary-shadow-hover),var(--jelly-btn-depth-primary)}.setup-start-btn:hover:after{animation:glossShimmer 1.5s ease}.setup-start-btn:active{animation:jellyPress .4s ease}.game-over-panel-v2{background:var(--surface-modal);border:1px solid var(--border-subtle);border-radius:24px;padding:36px 32px;text-align:center;min-width:300px;max-width:400px;width:90%;display:flex;flex-direction:column;align-items:center;gap:16px}.gameover-emoji{font-size:56px;line-height:1}.gameover-title{font-size:24px;font-weight:800;color:var(--text-primary);margin:0}.gameover-score-box{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 32px;background:var(--color-primary-bg);border:1px solid var(--color-primary-bg-hover);border-radius:16px}.gameover-score-label{font-size:13px;color:var(--text-tertiary);font-weight:600}.gameover-score-value{font-size:40px;font-weight:900;color:var(--text-accent);line-height:1}.gameover-buttons{display:flex;flex-direction:column;gap:10px;width:100%;margin-top:8px}.gameover-btn{width:100%;padding:14px;border:none;border-radius:14px;font-size:16px;font-weight:700;cursor:pointer;transition:transform .2s,opacity .2s}.gameover-btn:active{transform:scale(.97)}.gameover-btn-primary{background:var(--color-primary-gradient);color:var(--text-on-primary);box-shadow:0 4px 16px var(--color-primary-shadow)}.gameover-btn-secondary{background:var(--surface-subtle);color:var(--text-primary);border:1px solid var(--border-medium)}.gameover-btn-ghost{background:none;color:var(--text-muted);padding:10px;font-size:14px}.gameover-btn-ghost:hover{color:var(--text-secondary)}.gameover-share-row{display:flex;justify-content:center;margin-top:12px}@media (max-width: 480px){.single-setup-content{padding:10px 16px 32px;gap:20px}.setup-mode-cards{grid-template-columns:1fr}.setup-size-cards{gap:8px}.setup-size-card{padding:12px 8px}}.ingame-emoji-btn{position:fixed;bottom:80px;right:16px;z-index:120}.ingame-emoji-overlay{position:fixed;top:80px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;z-index:110;pointer-events:none}.ingame-emoji-overlay .emoji-bubble{position:relative;bottom:auto;left:auto;transform:none;animation:ingame-emoji-float 3s ease forwards}@keyframes ingame-emoji-float{0%{opacity:0;transform:scale(.6) translateY(8px)}15%{opacity:1;transform:scale(1.15) translateY(0)}70%{opacity:1;transform:scale(1) translateY(-4px)}to{opacity:0;transform:scale(.8) translateY(-12px)}}:root,[data-theme=light]{--bg-primary: #F5F2F9;--bg-secondary: #EFECF5;--bg-tertiary: #F3F0F8;--bg-gradient: linear-gradient(160deg, #F5F2F9 0%, #EFECF5 40%, #F3F0F8 100%);--surface-nav: rgba(255, 255, 255, .68);--surface-card: rgba(255, 255, 255, .75);--surface-card-hover: rgba(255, 255, 255, .85);--surface-modal: rgba(255, 255, 255, .82);--surface-input: #F0ECF5;--surface-subtle: rgba(157, 123, 255, .06);--surface-skeleton: rgba(157, 123, 255, .06);--surface-skeleton-shine: rgba(157, 123, 255, .12);--border-subtle: rgba(157, 123, 255, .1);--border-medium: rgba(157, 123, 255, .18);--border-strong: rgba(157, 123, 255, .25);--border-focus: #9D7BFF;--border-error: #C05050;--text-primary: #2E2640;--text-secondary: #5A5070;--text-tertiary: #8A80A0;--text-muted: #A098B0;--text-placeholder: #A098B0;--text-on-primary: white;--text-on-dark-btn: white;--text-accent: #7B5CC0;--text-error: #C05050;--color-primary: #9D7BFF;--color-primary-end: #8B68EE;--color-primary-gradient: linear-gradient(135deg, #9D7BFF, #8B68EE);--color-primary-bg: rgba(157, 123, 255, .1);--color-primary-bg-hover: rgba(157, 123, 255, .18);--color-primary-shadow: rgba(157, 123, 255, .2);--color-primary-shadow-hover: rgba(157, 123, 255, .35);--color-secondary: #FF708A;--color-secondary-end: #E85A73;--color-secondary-gradient: linear-gradient(135deg, #FF708A, #E85A73);--color-secondary-shadow: rgba(255, 112, 138, .25);--color-cta: #4ADE80;--color-cta-end: #38C96C;--color-cta-gradient: linear-gradient(135deg, #4ADE80, #38C96C);--color-cta-shadow: rgba(74, 222, 128, .35);--color-quickjoin: #E088A0;--color-quickjoin-end: #C87088;--color-quickjoin-gradient: linear-gradient(135deg, #E088A0, #C87088);--bar-normal: linear-gradient(90deg, #9D7BFF, #8B68EE);--bar-warn: linear-gradient(90deg, #C8A050, #B08838);--bar-full: linear-gradient(90deg, #C05050, #B04040);--bar-bg: rgba(157, 123, 255, .1);--badge-s-bg: rgba(157, 123, 255, .12);--badge-s-color: #7B5CC0;--badge-m-bg: rgba(100, 130, 180, .1);--badge-m-color: #5A7A9A;--badge-l-bg: rgba(255, 112, 138, .1);--badge-l-color: #E0608A;--badge-mode-bg: rgba(74, 222, 128, .1);--badge-mode-color: #30A060;--badge-default-bg: rgba(157, 123, 255, .1);--badge-default-color: #7B5CC0;--shadow-card: 0 4px 16px rgba(100, 80, 140, .1), 0 1px 3px rgba(100, 80, 140, .06);--shadow-nav: 0 2px 10px rgba(100, 80, 140, .05);--shadow-modal: 0 8px 32px rgba(100, 80, 140, .1);--shadow-btn-primary: 0 4px 16px rgba(157, 123, 255, .3);--jelly-shine: linear-gradient(180deg, rgba(255,255,255,.4) 0%, rgba(255,255,255,0) 50%);--jelly-depth-shadow: 0 4px 0 rgba(0,0,0,.07);--jelly-radius: 28% 28% 28% 28% / 32% 32% 32% 32%;--jelly-btn-depth: 0 3px 0 rgba(0,0,0,.1);--jelly-btn-depth-primary: 0 3px 0 rgba(120, 80, 200, .3);--jelly-btn-depth-cta: 0 3px 0 rgba(50, 180, 90, .35);--tile-text: #2E2640;--tile-shadow: 0 2px 7px rgba(0,0,0,.04), inset 0 2px 3px rgba(255,255,255,.5);--game-bg: linear-gradient(135deg, #EFECF5 0%, #9D7BFF 100%);--game-board-bg: linear-gradient(135deg, #FFFFFF 0%, #F8F5FF 100%);--game-board-border: rgba(157, 123, 255, .2);--game-text-dark: #2E2640;--game-back-btn: #EFECF5;--game-back-btn-hover: #E2DCF0;--overlay-bg: rgba(0, 0, 0, .65);--overlay-blur: blur(8px);--discord-bg: #5865F2;--error-bg: rgba(192, 80, 80, .1);--error-bg-hover: rgba(192, 80, 80, .2);--scrollbar-track: rgba(157, 123, 255, .3);--scrollbar-thumb: rgba(157, 123, 255, .5);--scrollbar-thumb-hover: rgba(157, 123, 255, .7);--logo-color: #7B5CC0}[data-theme=dark]{--bg-primary: #1A1528;--bg-secondary: #221D30;--bg-tertiary: #281F38;--bg-gradient: linear-gradient(160deg, #1A1528 0%, #221D30 40%, #281F38 100%);--surface-nav: rgba(30, 25, 48, .88);--surface-card: rgba(130, 100, 180, .06);--surface-card-hover: rgba(130, 100, 180, .12);--surface-modal: rgba(30, 25, 48, .94);--surface-input: rgba(130, 100, 180, .08);--surface-subtle: rgba(130, 100, 180, .04);--surface-skeleton: rgba(130, 100, 180, .06);--surface-skeleton-shine: rgba(130, 100, 180, .14);--border-subtle: rgba(130, 100, 180, .1);--border-medium: rgba(130, 100, 180, .18);--border-strong: rgba(130, 100, 180, .25);--border-focus: #A88BFF;--border-error: #D06060;--text-primary: rgba(230, 220, 245, .92);--text-secondary: rgba(200, 185, 220, .7);--text-tertiary: rgba(180, 165, 200, .5);--text-muted: rgba(180, 165, 200, .4);--text-placeholder: rgba(180, 165, 200, .4);--text-on-primary: white;--text-on-dark-btn: white;--text-accent: #B098E0;--text-error: #E07070;--color-primary: #A88BFF;--color-primary-end: #9578EE;--color-primary-gradient: linear-gradient(135deg, #A88BFF, #9578EE);--color-primary-bg: rgba(168, 139, 255, .1);--color-primary-bg-hover: rgba(168, 139, 255, .2);--color-primary-shadow: rgba(168, 139, 255, .15);--color-primary-shadow-hover: rgba(168, 139, 255, .3);--color-secondary: #FF8599;--color-secondary-end: #E86D82;--color-secondary-gradient: linear-gradient(135deg, #FF8599, #E86D82);--color-secondary-shadow: rgba(255, 133, 153, .2);--color-cta: #4ADE80;--color-cta-end: #38C96C;--color-cta-gradient: linear-gradient(135deg, #4ADE80, #38C96C);--color-cta-shadow: rgba(74, 222, 128, .3);--color-quickjoin: #E088A0;--color-quickjoin-end: #C87088;--color-quickjoin-gradient: linear-gradient(135deg, #E088A0, #C87088);--bar-normal: linear-gradient(90deg, #A88BFF, #9578EE);--bar-warn: linear-gradient(90deg, #C8A050, #B08838);--bar-full: linear-gradient(90deg, #D06060, #B84848);--bar-bg: rgba(130, 100, 180, .1);--badge-s-bg: rgba(168, 139, 255, .12);--badge-s-color: #B098E0;--badge-m-bg: rgba(100, 140, 180, .12);--badge-m-color: #70A0C8;--badge-l-bg: rgba(255, 133, 153, .12);--badge-l-color: #FF90A8;--badge-mode-bg: rgba(74, 222, 128, .1);--badge-mode-color: #60D090;--badge-default-bg: rgba(168, 139, 255, .1);--badge-default-color: #B098E0;--shadow-card: 0 4px 16px rgba(0, 0, 0, .25), 0 1px 3px rgba(0, 0, 0, .1);--shadow-nav: 0 2px 10px rgba(0, 0, 0, .2);--shadow-modal: 0 8px 32px rgba(0, 0, 0, .35);--shadow-btn-primary: 0 4px 16px rgba(168, 139, 255, .2);--jelly-shine: linear-gradient(180deg, rgba(255,255,255,.25) 0%, rgba(255,255,255,0) 50%);--jelly-depth-shadow: 0 4px 0 rgba(0,0,0,.15);--jelly-radius: 28% 28% 28% 28% / 32% 32% 32% 32%;--jelly-btn-depth: 0 3px 0 rgba(0,0,0,.2);--jelly-btn-depth-primary: 0 3px 0 rgba(100, 70, 190, .4);--jelly-btn-depth-cta: 0 3px 0 rgba(40, 160, 80, .4);--tile-text: #1A1528;--tile-shadow: 0 2px 7px rgba(0,0,0,.2), inset 0 2px 3px rgba(255,255,255,.4);--game-bg: linear-gradient(135deg, #1A1528 0%, #352A58 100%);--game-board-bg: linear-gradient(135deg, #F8F5FF 0%, #F0EAFC 100%);--game-board-border: rgba(168, 139, 255, .2);--game-text-dark: #1A1528;--game-back-btn: rgba(130, 100, 180, .1);--game-back-btn-hover: rgba(130, 100, 180, .2);--overlay-bg: rgba(0, 0, 0, .75);--overlay-blur: blur(8px);--discord-bg: #5865F2;--error-bg: rgba(208, 96, 96, .1);--error-bg-hover: rgba(208, 96, 96, .2);--scrollbar-track: rgba(168, 139, 255, .2);--scrollbar-thumb: rgba(168, 139, 255, .4);--scrollbar-thumb-hover: rgba(168, 139, 255, .6);--logo-color: #B098E0}[data-eye-comfort=on][data-theme=light],[data-eye-comfort=on]:root{--bg-primary: #F5F0E8;--bg-secondary: #EFE9E0;--bg-tertiary: #F3EDE4;--bg-gradient: linear-gradient(160deg, #F5F0E8 0%, #EFE9E0 40%, #F3EDE4 100%);--surface-nav: rgba(255, 252, 245, .7);--surface-card: rgba(255, 252, 245, .78);--surface-card-hover: rgba(255, 252, 245, .88);--surface-modal: rgba(255, 252, 245, .85);--surface-input: #F0EBE2;--surface-subtle: rgba(155, 133, 216, .06);--border-subtle: rgba(155, 133, 216, .1);--border-medium: rgba(155, 133, 216, .18);--text-primary: #3A3530;--text-secondary: #5A5550;--text-tertiary: #8A8580;--text-muted: #A09890;--text-accent: #7A6AAA;--color-primary: #9B85D8;--color-primary-end: #8A74C8;--color-primary-gradient: linear-gradient(135deg, #9B85D8, #8A74C8);--color-primary-bg: rgba(155, 133, 216, .1);--color-primary-bg-hover: rgba(155, 133, 216, .18);--color-primary-shadow: rgba(155, 133, 216, .2);--shadow-card: 0 4px 16px rgba(100, 85, 60, .08), 0 1px 3px rgba(100, 85, 60, .04);--shadow-nav: 0 2px 10px rgba(100, 85, 60, .04);--game-bg: linear-gradient(135deg, #EFE9E0 0%, #9B85D8 100%);--game-board-bg: linear-gradient(135deg, #FFFCF5 0%, #F8F4EC 100%);--game-board-border: rgba(155, 133, 216, .2);--scrollbar-track: rgba(155, 133, 216, .2);--scrollbar-thumb: rgba(155, 133, 216, .4);--logo-color: #7A6AAA}[data-eye-comfort=on][data-theme=dark]{--bg-primary: #1E1A14;--bg-secondary: #262018;--bg-tertiary: #2C2520;--bg-gradient: linear-gradient(160deg, #1E1A14 0%, #262018 40%, #2C2520 100%);--surface-nav: rgba(35, 30, 22, .9);--surface-card: rgba(120, 100, 70, .06);--surface-card-hover: rgba(120, 100, 70, .12);--surface-modal: rgba(35, 30, 22, .95);--surface-input: rgba(120, 100, 70, .08);--surface-subtle: rgba(120, 100, 70, .04);--border-subtle: rgba(120, 100, 70, .1);--border-medium: rgba(120, 100, 70, .18);--text-primary: rgba(235, 228, 215, .92);--text-secondary: rgba(210, 200, 185, .7);--text-tertiary: rgba(185, 175, 160, .5);--text-muted: rgba(185, 175, 160, .4);--text-accent: #B0A0C8;--color-primary: #A090D0;--color-primary-end: #9080C0;--color-primary-gradient: linear-gradient(135deg, #A090D0, #9080C0);--color-primary-bg: rgba(160, 144, 208, .1);--color-primary-bg-hover: rgba(160, 144, 208, .2);--color-primary-shadow: rgba(160, 144, 208, .15);--shadow-card: 0 4px 16px rgba(0, 0, 0, .2), 0 1px 3px rgba(0, 0, 0, .08);--game-bg: linear-gradient(135deg, #1E1A14 0%, #3A3028 100%);--game-board-bg: linear-gradient(135deg, #FFF8F0 0%, #F5EDE0 100%);--game-board-border: rgba(160, 144, 208, .2);--scrollbar-track: rgba(160, 144, 208, .15);--scrollbar-thumb: rgba(160, 144, 208, .3);--logo-color: #B0A0C8}@keyframes jellyPress{0%{transform:scale(1)}30%{transform:scale(.92,1.08)}50%{transform:scale(1.05,.95)}70%{transform:scale(.98,1.02)}to{transform:scale(1)}}@keyframes jellyBounceIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.06,.94)}70%{transform:scale(.97,1.03)}to{transform:scale(1);opacity:1}}@keyframes glossShimmer{0%{left:-100%}50%,to{left:150%}}@keyframes jellyFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-6px) scale(1.01,.99)}}@keyframes tileBreath{0%,to{transform:scale(1)}50%{transform:scale(1.008,.992)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:focus-visible{outline:3px solid #4A90D9;outline-offset:2px}.tile:focus-visible .tile-inner{outline:3px solid #FFD700;outline-offset:2px;box-shadow:0 0 10px #ffd70080}button:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid #4A90D9;outline-offset:2px;box-shadow:0 0 8px #4a90d966}:focus:not(:focus-visible){outline:none}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.skip-link{position:absolute;top:-40px;left:0;background:#000;color:#fff;padding:8px 16px;z-index:9999;transition:top .3s}.skip-link:focus{top:0}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (pointer: coarse){button,[role=button],input[type=button],input[type=submit],input[type=reset]{min-height:44px;min-width:44px}button,a,input,select,textarea{touch-action:manipulation}input[type=text],input[type=email],input[type=password],input[type=search],input[type=number],textarea{min-height:44px;font-size:16px}.icon-button,.control-icon-btn,.lang-button{min-height:44px;min-width:44px}}.scrollable,[class*=list],[class*=container]{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.game-board,.ranking-list,.room-list{will-change:scroll-position;transform:translateZ(0)}
