:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@font-face{font-family:Aggravo Light;src:url(https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2108@1.1/SBAggroL.woff) format("woff");font-weight:300;font-display:swap}@font-face{font-family:Aggravo Medium;src:url(https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2108@1.1/SBAggroM.woff) format("woff");font-weight:500;font-display:swap}@font-face{font-family:Aggravo Bold;src:url(https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2108@1.1/SBAggroB.woff) format("woff");font-weight:700;font-display:swap}html,body{margin:0;padding:0;height:100%;overflow:hidden}body{font-family:Aggravo Medium;-webkit-user-select:none;user-select:none;padding-bottom:env(safe-area-inset-bottom)}#root{height:100%;overflow:hidden}@keyframes ui-progress-background{0%{background-position:0 0}to{background-position:24px 0}}.reconnecting-indicator{position:fixed;top:20px;left:50%;transform:translate(-50%);z-index:9999;display:flex;flex-direction:column;align-items:center;gap:12px;padding:16px 24px;animation:reconnectFadeIn .3s ease-out}@keyframes reconnectFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.reconnecting-spinner{width:40px;height:40px;display:flex;align-items:center;justify-content:center}.reconnecting-spinner-svg{width:100%;height:100%;color:#667eea}.reconnecting-spinner-circle{stroke-dasharray:90,150;stroke-dashoffset:0;animation:reconnectSpin 1.5s linear infinite;transform-origin:center}@keyframes reconnectSpin{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.reconnecting-text{color:#000;font-size:14px;font-weight:500;text-align:center;white-space:nowrap}.game-app{position:relative;height:100vh;height:100dvh;display:flex;flex-direction:column;gap:1rem;isolation:isolate;overflow:hidden;padding-bottom:env(safe-area-inset-bottom);box-sizing:border-box}.game-app-glow{position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(79,70,229,.4),transparent 60%),radial-gradient(circle at 80% 10%,rgba(14,165,233,.35),transparent 55%);filter:blur(40px);opacity:.6;z-index:-2}.game-stage{flex:1;background:#040614d1;display:flex;overflow:hidden}.game-stage--flat{padding:0}.page{flex:1;width:100%;height:100%;display:flex;gap:1rem;overflow:hidden}.panel{border-radius:24px;border:1px solid rgba(255,255,255,.08);background:#060815d9;padding:clamp(1.25rem,3vw,1.75rem);box-shadow:inset 0 0 0 1px #ffffff08;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.main-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:2rem;width:100%;background:linear-gradient(135deg,#f5f7fa,#fff);min-height:100vh;min-height:100dvh;padding-bottom:env(safe-area-inset-bottom);box-sizing:border-box;position:relative}.main-screen-content{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1rem;width:100%;min-height:100%;padding:2rem;padding-bottom:calc(2rem + env(safe-area-inset-bottom) + 60px);box-sizing:border-box;position:relative}.main-online-badge{position:absolute;top:1rem;left:1rem;display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e0e0e0;border-radius:20px;padding:.5rem .75rem;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffffe6;z-index:10}.main-online-badge svg{color:#4a5568}.main-online-indicator{width:8px;height:8px;border-radius:50%;display:inline-block;transition:background-color .3s ease,box-shadow .3s ease}.main-online-indicator-connected{background-color:#10b981;box-shadow:0 0 4px #10b98199;animation:onlinePulse 2s ease-in-out infinite}.main-online-indicator-disconnected{background-color:#9ca3af;box-shadow:0 0 4px #9ca3af66;animation:none}@keyframes onlinePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.main-online-count{font-size:.875rem;font-weight:600;color:#2d3748;font-family:Aggravo Medium,sans-serif}.main-logo-container{display:flex;justify-content:center;align-items:center;margin-bottom:.5rem}.main-logo{width:200px;height:200px;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.main-title{margin:0;font-size:clamp(2rem,5vw,3rem);font-weight:700;color:#1a1a1a;text-align:center;letter-spacing:.05em;text-shadow:0 2px 4px rgba(0,0,0,.05)}.main-btn-play{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#fff,#f8f9fa);color:#4a5568;border:2px solid #e0e0e0;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);text-decoration:none;display:flex;justify-content:center;align-items:center;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffffe6;margin:.5rem 0}.main-btn-play:hover{background:linear-gradient(135deg,#f5f5f5,#eee);border-color:#d0d0d0;transform:translateY(-3px) scale(1.02);box-shadow:0 4px 12px #00000026,inset 0 1px #ffffffe6;color:#2d3748}.main-btn-play:active{transform:translateY(-1px) scale(1);box-shadow:0 2px 8px #0000001a}.main-btn-play svg{margin-left:4px}.main-actions-bottom{display:flex;gap:1rem;justify-content:center;align-items:center;margin-top:.25rem}.main-btn-icon{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#fff,#f8f9fa);color:#4a5568;border:2px solid #e0e0e0;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;justify-content:center;align-items:center;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffffe6;padding:0}.main-btn-icon:hover{background:linear-gradient(135deg,#f5f5f5,#eee);border-color:#d0d0d0;transform:translateY(-3px) scale(1.02);box-shadow:0 4px 12px #00000026,inset 0 1px #ffffffe6;color:#2d3748}.main-btn-icon:active{transform:translateY(-1px) scale(1);box-shadow:0 2px 8px #0000001a}.main-btn-icon svg{width:24px;height:24px}.main-settings-modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.main-settings-modal{background:linear-gradient(135deg,#fff,#f8f9fa);border:3px solid #e0e0e0;border-radius:24px;padding:2.5rem 2rem;min-width:320px;max-width:90vw;display:flex;flex-direction:column;gap:1.5rem;box-shadow:0 12px 40px #00000026,0 0 0 1px #667eea1a,inset 0 1px #ffffffe6;position:relative;overflow:hidden;animation:pauseModalAppear .3s cubic-bezier(.4,0,.2,1)}.main-settings-title{margin:0;font-size:2rem;font-weight:800;color:#1a1a1a;text-align:center;letter-spacing:-.02em;text-shadow:0 2px 4px rgba(0,0,0,.05)}.main-settings-content{display:flex;flex-direction:column;gap:1rem}.main-settings-vibration-toggle{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:linear-gradient(135deg,#f8f9ff,#f0f4ff);border:2px solid #e0e8ff;border-radius:12px}.main-settings-vibration-text{color:#2d3748;font-size:1rem;font-weight:600;-webkit-user-select:none;user-select:none}.main-settings-vibration-switch{position:relative;display:inline-block;width:64px;height:32px;cursor:pointer}.main-settings-vibration-checkbox{opacity:0;width:0;height:0}.main-settings-vibration-slider{position:absolute;inset:0;background-color:#ccc;border-radius:32px;transition:.3s;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 2px 4px #0000001a}.main-settings-vibration-slider-text{font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);transition:.3s;pointer-events:none}.main-settings-vibration-checkbox:checked+.main-settings-vibration-slider{background-color:#667eea}.main-settings-vibration-checkbox:checked+.main-settings-vibration-slider .main-settings-vibration-slider-text{transform:translate(8px)}.main-settings-vibration-checkbox:not(:checked)+.main-settings-vibration-slider .main-settings-vibration-slider-text{transform:translate(-8px)}.main-settings-vibration-switch:hover .main-settings-vibration-slider{box-shadow:0 0 8px #667eea66}.main-settings-close{pointer-events:auto;display:flex;align-items:center;justify-content:center;padding:0;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e0e0e0;border-radius:50%;color:#4a5568;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1);cursor:pointer;width:48px;height:48px;flex-shrink:0;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffffe6;margin:0 auto}.main-settings-close:hover{background:linear-gradient(135deg,#f5f5f5,#eee);border-color:#d0d0d0;transform:translateY(-3px) scale(1.02);box-shadow:0 4px 12px #00000026,inset 0 1px #ffffffe6;color:#2d3748}.main-settings-close:active{transform:translateY(-1px) scale(1)}.main-ranking-modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.main-ranking-modal{background:linear-gradient(135deg,#fff,#f8f9fa);border:3px solid #e0e0e0;border-radius:24px;padding:2.5rem 2rem;min-width:320px;max-width:90vw;display:flex;flex-direction:column;gap:1.5rem;box-shadow:0 12px 40px #00000026,0 0 0 1px #667eea1a,inset 0 1px #ffffffe6;position:relative;overflow:hidden;animation:pauseModalAppear .3s cubic-bezier(.4,0,.2,1)}.main-ranking-title{margin:0;font-size:2rem;font-weight:800;color:#1a1a1a;text-align:center;letter-spacing:-.02em;text-shadow:0 2px 4px rgba(0,0,0,.05)}.main-ranking-close{pointer-events:auto;display:flex;align-items:center;justify-content:center;padding:0;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e0e0e0;border-radius:50%;color:#4a5568;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1);cursor:pointer;width:48px;height:48px;flex-shrink:0;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffffe6;margin:0 auto;border:none}.main-ranking-close:hover{background:linear-gradient(135deg,#f5f5f5,#eee);border-color:#d0d0d0;transform:translateY(-3px) scale(1.02);box-shadow:0 4px 12px #00000026,inset 0 1px #ffffffe6;color:#2d3748}.main-ranking-close:active{transform:translateY(-1px) scale(1)}.ranking-board{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:1rem;max-height:60vh;overflow-y:auto}.ranking-board-content{display:flex;flex-direction:column;align-items:stretch;gap:1.5rem;width:100%;max-width:400px;height:100%;min-height:0}.ranking-board-title{margin:0;font-size:1.75rem;font-weight:800;color:#1a1a1a;text-align:center;font-family:Aggravo Bold,sans-serif}.ranking-loading,.ranking-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem}.ranking-empty-icon{color:#d0d0d0}.ranking-empty-message{margin:0;font-size:1rem;color:#666;text-align:center}.ranking-list-container{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.ranking-list{display:flex;flex-direction:column;gap:.5rem;width:100%;max-height:400px;overflow-y:auto;padding-right:.5rem}.ranking-list::-webkit-scrollbar{width:6px}.ranking-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.ranking-list::-webkit-scrollbar-thumb{background:silver;border-radius:3px}.ranking-list::-webkit-scrollbar-thumb:hover{background:#a0a0a0}.ranking-my-record-section{display:flex;flex-direction:column;gap:.5rem;margin-top:auto;padding-top:1rem;border-top:2px solid #e0e0e0}.ranking-my-record-label{font-size:.875rem;font-weight:600;color:#667eea;padding:0 .5rem}.ranking-item-my{margin-top:0}.ranking-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e0e0e0;border-radius:12px;transition:all .2s ease}.ranking-item:hover{border-color:#d0d0d0;box-shadow:0 2px 8px #0000001a}.ranking-item-current{background:linear-gradient(135deg,#f0f4ff,#e8f0ff);border-color:#667eea}.ranking-item-top-1{background:linear-gradient(135deg,#fff9e6,#fff4d6);border-color:gold;border-width:3px;box-shadow:0 4px 12px #ffd70033}.ranking-item-top-2{background:linear-gradient(135deg,#f5f5f5,#eee);border-color:silver;border-width:3px;box-shadow:0 4px 12px #c0c0c033}.ranking-item-top-3{background:linear-gradient(135deg,#fff4e6,#ffe8d6);border-color:#cd7f32;border-width:3px;box-shadow:0 4px 12px #cd7f3233}.ranking-rank{display:flex;align-items:center;justify-content:center;min-width:40px;font-size:1.25rem;font-weight:700}.ranking-medal{font-size:1.75rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.ranking-medal-gold{color:gold;animation:medalShine 2s ease-in-out infinite}.ranking-medal-silver{color:silver}.ranking-medal-bronze{color:#cd7f32}@keyframes medalShine{0%,to{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}50%{filter:drop-shadow(0 2px 8px rgba(255,215,0,.6))}}.ranking-number{font-size:1.25rem;font-weight:600;color:#4a5568}.ranking-info{flex:1;display:flex;align-items:center;gap:.5rem;min-width:0}.ranking-name{font-size:1rem;font-weight:600;color:#2d3748;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ranking-badge{display:inline-block;padding:.125rem .5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.75rem;font-weight:700;border-radius:8px;flex-shrink:0}.ranking-score{font-size:1rem;font-weight:700;color:#1a1a1a;font-family:Aggravo Bold,sans-serif;white-space:nowrap}.chat-container{position:fixed;bottom:0;left:0;width:100%;max-width:480px;background:transparent;z-index:100;display:flex;flex-direction:column;transition:all .3s ease;padding-bottom:env(safe-area-inset-bottom);pointer-events:none}.chat-container>*{pointer-events:auto}.chat-toggle{position:absolute;top:0;right:.75rem;display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;background:transparent;border:none;color:#4a5568;cursor:pointer;border-radius:50%;transition:all .2s ease;z-index:10}.chat-toggle:hover{background:#f0f0f0;color:#2d3748}.chat-messages-container{overflow:hidden;transition:max-height .3s ease}.chat-collapsed .chat-messages-container{max-height:1.5rem;overflow:hidden}.chat-expanded .chat-messages-container{max-height:12rem;overflow-y:auto}.chat-messages{padding:0;display:flex;flex-direction:column;gap:.25rem;min-height:0;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.5);-webkit-text-stroke:.5px rgba(0,0,0,.5)}.chat-collapsed .chat-messages{max-height:1.5rem;overflow:hidden}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.chat-messages::-webkit-scrollbar-thumb{background:silver;border-radius:2px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#a0a0a0}.chat-empty{font-size:.875rem;text-align:center;padding:.5rem 0}.chat-message{font-size:.875rem;line-height:1.4;word-wrap:break-word;display:flex;gap:.25rem}.chat-message-username{font-weight:600;flex-shrink:0}.chat-message-content{flex:1}.chat-input-form{display:flex;align-items:center;gap:.5rem;padding:0;border-top:none;background:transparent}.chat-collapsed .chat-input-form{display:none}.chat-input{flex:1;padding:.5rem .75rem;border:2px solid #e0e0e0;border-radius:20px;font-size:.875rem;font-family:Aggravo Medium,sans-serif;color:#2d3748;background:#f8f9fa;transition:all .2s ease}@media(max-width:768px){.chat-input{font-size:16px}}.chat-input:focus{outline:none;border-color:#667eea;background:#fff}.chat-input::placeholder{color:#999}.chat-send-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;color:#fff;cursor:pointer;transition:all .2s ease;flex-shrink:0}.chat-send-button:hover{transform:scale(1.1);box-shadow:0 2px 8px #667eea4d}.chat-send-button:active{transform:scale(1)}.loading-screen{position:fixed;inset:0;background:linear-gradient(135deg,#f5f7fa,#fff);display:flex;align-items:center;justify-content:center;z-index:9999;padding-bottom:env(safe-area-inset-bottom)}.loading-screen-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem;width:100%;max-width:400px;padding:2rem}.loading-logo-container{display:flex;justify-content:center;align-items:center;animation:loadingLogoPulse 2s ease-in-out infinite}@keyframes loadingLogoPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.05);opacity:.9}}.loading-logo{width:150px;height:150px;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.1))}.loading-progress-container{width:100%;display:flex;flex-direction:column;gap:.75rem}.loading-progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a}.loading-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease-out;box-shadow:0 2px 4px #667eea4d}.deadline-countdown{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:30;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;animation:deadlineCountdownPulse .5s ease-in-out infinite}.deadline-countdown-text{font-size:64px;font-weight:900;color:#f44;text-shadow:0 0 10px rgba(255,68,68,.8),0 0 20px rgba(255,68,68,.6),0 4px 8px rgba(0,0,0,.5);line-height:1;font-family:Aggravo Bold,sans-serif}@keyframes deadlineCountdownPulse{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.05)}}.game-over-overlay{position:absolute;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:gameOverFadeIn .3s ease-out}@keyframes gameOverFadeIn{0%{opacity:0}to{opacity:1}}.game-over-modal{background:linear-gradient(135deg,#fff,#f8f9fa);border:3px solid #e0e0e0;border-radius:24px;padding:3rem 2.5rem;min-width:320px;max-width:90vw;display:flex;flex-direction:column;gap:1.5rem;box-shadow:0 12px 40px #0000004d,0 0 0 1px #667eea1a,inset 0 1px #ffffffe6;position:relative;overflow:hidden;animation:gameOverModalAppear .4s cubic-bezier(.4,0,.2,1)}@keyframes gameOverModalAppear{0%{opacity:0;transform:scale(.8) translateY(-30px)}to{opacity:1;transform:scale(1) translateY(0)}}.game-over-title{margin:0;font-size:2.5rem;font-weight:900;color:#f44;text-align:center;letter-spacing:-.02em;text-shadow:0 2px 4px rgba(0,0,0,.1);font-family:Aggravo Bold,sans-serif}.game-over-score{font-size:1.5rem;font-weight:700;color:#2d3748;text-align:center;padding:1rem;background:linear-gradient(135deg,#f8f9ff,#f0f4ff);border:2px solid #e0e8ff;border-radius:12px;font-family:Aggravo Medium,sans-serif}.game-over-actions{display:flex;flex-direction:row;gap:1rem;justify-content:center;align-items:center}.game-over-button{pointer-events:auto;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:0;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e0e0e0;border-radius:50%;color:#4a5568;touch-action:manipulation;-webkit-tap-highlight-color:transparent;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1);cursor:pointer;width:48px;height:48px;flex-shrink:0;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffffe6;font-family:Aggravo Medium,sans-serif}.game-over-button span{display:none}.game-over-button:hover{background:linear-gradient(135deg,#f5f5f5,#eee);border-color:#d0d0d0;transform:translateY(-3px) scale(1.02);box-shadow:0 4px 12px #00000026,inset 0 1px #ffffffe6;color:#2d3748}.game-over-button:active{transform:translateY(-1px) scale(1)}.hero-card{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;text-align:center;width:min(520px,100%);min-height:clamp(320px,60vh,520px)}.hero-title{margin:0;font-size:clamp(2.2rem,5vw,3.4rem);text-transform:uppercase;letter-spacing:.12em}.hero-copy{margin:0;color:#c5d1ff;max-width:42ch}.hero-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem;width:100%}.hero-metrics{display:flex;gap:1rem;flex-wrap:wrap}.hero-metrics div{min-width:110px}.metric-label{margin:0;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;color:#9da9d9}.metric-value{margin:.15rem 0 0;font-size:1.3rem;font-weight:600}.status-board{display:flex;flex-direction:column;gap:1rem}.stat-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.85rem}.stat-list li{display:flex;justify-content:space-between;font-weight:500;color:#cfd5ff}.mini-feed{border-radius:18px;padding:1rem;background:#0a0f20b3;border:1px solid rgba(255,255,255,.05)}.mini-feed-title{margin:0 0 .5rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#bcd2ff}.mini-feed-line{margin:.1rem 0;color:#93a4dd}.mini-feed-line.accent{color:#5eead4}.game-screen,.canvas-panel{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.canvas-frame{border-radius:0;overflow:hidden;background:#000;position:relative;box-shadow:0 20px 40px #00000059}.game-canvas{width:100%;height:100%;display:block}@keyframes ui-progress-background{0%{background-position:0 0}to{background-position:24px 24px}}.canvas-overlay{position:absolute;top:.75rem;right:.75rem;left:auto;display:flex;justify-content:flex-end;z-index:2;pointer-events:none}.pause-toggle{pointer-events:auto;border:2px solid rgba(0,0,0,.1);background:linear-gradient(135deg,#fff,#f8f9fa);color:#4a5568;padding:0;border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .25s ease;box-shadow:0 2px 8px #0000001a}.pause-toggle:hover{background:linear-gradient(135deg,#f0f4ff,#e8f0ff);border-color:#667eea4d;transform:scale(1.1);box-shadow:0 4px 12px #667eea33}.pause-modal-backdrop{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.pause-modal{background:linear-gradient(135deg,#fff,#f8f9fa);border:3px solid #e0e0e0;border-radius:24px;padding:2.5rem 2rem;min-width:320px;max-width:90vw;display:flex;flex-direction:column;gap:1.5rem;box-shadow:0 12px 40px #00000026,0 0 0 1px #667eea1a,inset 0 1px #ffffffe6;position:relative;overflow:hidden;animation:pauseModalAppear .3s cubic-bezier(.4,0,.2,1)}@keyframes pauseModalAppear{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.pause-title{margin:0;font-size:2rem;font-weight:800;color:#1a1a1a;text-align:center;letter-spacing:-.02em;text-shadow:0 2px 4px rgba(0,0,0,.05)}.pause-vibration-toggle{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:linear-gradient(135deg,#f8f9ff,#f0f4ff);border:2px solid #e0e8ff;border-radius:12px;margin-bottom:.5rem}.pause-vibration-text{color:#2d3748;font-size:1rem;font-weight:600;-webkit-user-select:none;user-select:none}.pause-vibration-switch{position:relative;display:inline-block;width:64px;height:32px;cursor:pointer}.pause-vibration-checkbox{opacity:0;width:0;height:0}.pause-vibration-slider{position:absolute;inset:0;background-color:#ccc;border-radius:32px;transition:.3s;display:flex;align-items:center;justify-content:center;box-shadow:inset 0 2px 4px #0000001a}.pause-vibration-slider-text{font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);transition:.3s;pointer-events:none}.pause-vibration-checkbox:checked+.pause-vibration-slider{background-color:#667eea}.pause-vibration-checkbox:checked+.pause-vibration-slider .pause-vibration-slider-text{transform:translate(8px)}.pause-vibration-checkbox:not(:checked)+.pause-vibration-slider .pause-vibration-slider-text{transform:translate(-8px)}.pause-vibration-switch:hover .pause-vibration-slider{box-shadow:0 0 8px #667eea66}.pause-actions{display:flex;flex-direction:row;gap:.75rem;justify-content:center;align-items:center}.pause-link{pointer-events:auto;display:flex;align-items:center;justify-content:center;padding:0;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e0e0e0;border-radius:50%;color:#4a5568;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1);cursor:pointer;width:48px;height:48px;flex-shrink:0;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffffe6}.pause-link:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);transition:left .5s ease}.pause-link:hover{background:linear-gradient(135deg,#f5f5f5,#eee);border-color:#d0d0d0;transform:translateY(-3px) scale(1.02);box-shadow:0 4px 12px #00000026,inset 0 1px #ffffffe6;color:#2d3748}.pause-link:hover:before{left:100%}.pause-link:active{transform:translateY(-1px) scale(1)}.pause-resume{background:linear-gradient(135deg,#fff,#f8f9fa);border-color:#e0e0e0;color:#4a5568;box-shadow:0 2px 8px #0000001a,inset 0 1px #ffffffe6}.pause-resume:hover{background:linear-gradient(135deg,#f5f5f5,#eee);border-color:#d0d0d0;box-shadow:0 4px 12px #00000026,inset 0 1px #ffffffe6;color:#2d3748}.btn{border:none;border-radius:999px;padding:.75rem 1.5rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#1f8ef1,#845efc);color:#fff;box-shadow:0 10px 24px #4f46e559}.btn-primary:hover{transform:translateY(-1px)}.btn-secondary{border:1px solid rgba(255,255,255,.25);color:#dfe4ff;background:transparent}.btn-ghost{border:1px solid rgba(255,255,255,.12);background:#ffffff0d;color:#dfe4ff}.eyebrow{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:#8ab4ff;margin:0}.not-found-screen{align-items:center;justify-content:center;text-align:center}.not-found-card{display:flex;flex-direction:column;gap:.5rem;align-items:center}@media(max-width:900px){.main-screen{grid-template-columns:1fr}}@media(max-width:600px){.hero-actions{flex-direction:column}.btn{width:100%}}.main-profile-modal-backdrop{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.main-profile-modal{background:linear-gradient(135deg,#fff,#f8f9fa);border:3px solid #e0e0e0;border-radius:24px;padding:2rem;min-width:320px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 12px 40px #00000026,0 0 0 1px #667eea1a,inset 0 1px #ffffffe6;position:relative;overflow-y:auto;animation:pauseModalAppear .3s cubic-bezier(.4,0,.2,1)}.profile-loading{display:flex;justify-content:center;align-items:center;height:100%;font-size:1.2rem;color:#4a5568}.profile-container{width:100%;display:flex;flex-direction:column;gap:2rem}.profile-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;position:relative}.profile-close-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:none;background:linear-gradient(135deg,#fff,#f8f9fa);color:#4a5568;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000001a;flex-shrink:0}.profile-close-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;background:linear-gradient(135deg,#f5f5f5,#eee)}.profile-close-button:active{transform:translateY(0)}.profile-title{font-size:2rem;font-weight:700;color:#2d3748;margin:0}.profile-content{display:flex;flex-direction:column;gap:2rem;background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:24px;padding:2rem;box-shadow:0 4px 20px #00000014}.profile-field{display:flex;flex-direction:column;gap:.75rem}.profile-label{font-size:.9rem;font-weight:600;color:#4a5568;text-transform:uppercase;letter-spacing:.05em}.profile-userid-group{display:flex;gap:.5rem;align-items:center}.profile-readonly-value{flex:1;padding:.75rem 1rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;color:#718096;font-size:.95rem;font-family:monospace;word-break:break-all}.profile-copy-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:2px solid #e2e8f0;border-radius:12px;background:linear-gradient(135deg,#fff,#f8f9fa);color:#4a5568;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000001a;flex-shrink:0}.profile-copy-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;background:linear-gradient(135deg,#f5f5f5,#eee);border-color:#d0d0d0;color:#2d3748}.profile-copy-button:active{transform:translateY(0)}.profile-copy-button svg{pointer-events:none}.profile-input-group{display:flex;gap:.75rem;align-items:flex-start;width:100%}.profile-input{flex:1;width:100%;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;color:#2d3748;background:#fff;transition:all .2s ease;box-sizing:border-box}.profile-input:focus{outline:none;border-color:#1f8ef1;box-shadow:0 0 0 3px #1f8ef11a}.profile-input:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.profile-check-button{padding:.75rem 1.5rem;border:none;border-radius:12px;background:linear-gradient(135deg,#fff,#f8f9fa);color:#4a5568;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 2px 8px #0000001a}.profile-check-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #00000026;background:linear-gradient(135deg,#f5f5f5,#eee);color:#2d3748}.profile-check-button:active:not(:disabled){transform:translateY(0)}.profile-check-button:disabled{opacity:.5;cursor:not-allowed}.profile-check-result{display:flex;align-items:center;gap:.5rem;font-size:.85rem;padding:.5rem .75rem;border-radius:8px;margin-top:.25rem}.profile-check-result-success{background:#f0fdf4;color:#166534}.profile-check-result-error{background:#fef2f2;color:#991b1b}.profile-error-message{color:#dc2626;font-size:.85rem;margin-top:.25rem;padding:.5rem .75rem;background:#fef2f2;border-radius:8px}.profile-success-message{color:#166534;font-size:.85rem;margin-top:.25rem;padding:.5rem .75rem;background:#f0fdf4;border-radius:8px}.profile-update-button{padding:1rem 2rem;border:none;border-radius:12px;background:linear-gradient(135deg,#fff,#f8f9fa);color:#4a5568;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000001a;margin-top:1rem}.profile-update-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #00000026;background:linear-gradient(135deg,#f5f5f5,#eee);color:#2d3748}.profile-update-button:active:not(:disabled){transform:translateY(0)}.profile-update-button:disabled{opacity:.5;cursor:not-allowed;transform:none}@media(max-width:600px){.profile-container{padding:0}.profile-content{padding:1.5rem}.profile-input-group{flex-direction:column}.profile-check-button,.profile-update-button{width:100%}}
