@keyframes modalSpring{0%{transform:translate(-50%,-45%) scale(.92);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}:root{--primary: #F5F5F7;--primary-light: #A1A1AA;--primary-glow: rgba(245, 245, 247, .15);--accent: #FF3131;--accent-blue: #00D8FF;--accent-glow: rgba(255, 49, 49, .25);--accent-blue-glow: rgba(0, 216, 255, .25);--success: #00D8FF;--warning: #FF3131;--bg-dark: #050505;--bg-darker: #020202;--bg-card: rgba(10, 10, 10, .85);--bg-card-hover: rgba(15, 15, 15, .98);--text-white: #F5F5F7;--text-dim: #D4D4D8;--text-muted: #71717A;--font-main: "Outfit", sans-serif;--sidebar-width: 280px;--mobile-header-height: 58px;--transition: all .4s cubic-bezier(.23, 1, .32, 1);--transition-fast: all .2s cubic-bezier(.23, 1, .32, 1);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 22px;--radius-xl: 28px;--shadow-card: 0 25px 50px -12px rgba(0, 0, 0, .9);--shadow-glow: 0 0 40px rgba(255, 255, 255, .05)}*{margin:0;padding:0;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent}html{overflow:hidden;height:100%;touch-action:manipulation}body{background-color:var(--bg-darker);color:var(--text-white);font-family:var(--font-main);overflow:hidden;height:100%;position:fixed;width:100%}.top-navbar{position:fixed;top:0;left:0;width:100%;height:70px;display:flex;align-items:center;justify-content:space-between;padding:0 2.5rem;z-index:5000;pointer-events:auto;background:#02020266;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px);border-bottom:1px solid rgba(255,255,255,.05);transition:opacity .4s ease,transform .4s ease}.top-navbar.fade-out{opacity:0;pointer-events:none;transform:translateY(-20px)}.nav-brand{font-family:Bebas Neue,sans-serif;font-size:1.8rem;letter-spacing:.05em;color:var(--text-white)}.nav-brand span{color:var(--text-white)}.nav-right{display:flex;align-items:center;gap:1.5rem}.nav-icon-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;position:relative;padding:8px;transition:var(--transition-fast);display:flex;align-items:center;justify-content:center}.nav-icon-btn svg{width:20px;height:20px}.nav-icon-btn:hover{color:var(--text-white);transform:translateY(-2px)}.nav-badge{position:absolute;top:6px;right:6px;width:8px;height:8px;background:var(--accent);border-radius:50%;border:2px solid var(--bg-darker);box-shadow:0 0 10px var(--accent-glow)}.btn-login{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:var(--text-white);padding:.45rem 1rem;border-radius:50px;font-family:var(--font-main);font-weight:600;font-size:.85rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.user-profile-btn{display:flex;align-items:center;gap:.6rem}.btn-login:hover{background:var(--text-white);color:#000;transform:translateY(-2px);box-shadow:0 10px 20px #0000004d}.user-avatar-mini{width:26px;height:26px;border-radius:50%;background-size:cover;background-position:center;background-color:var(--accent);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;color:#fff;border:1.5px solid rgba(255,255,255,.2)}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:6000;background:#000000b3;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;transition:var(--transition);opacity:1}.modal-overlay.hidden{opacity:0;pointer-events:none;transform:scale(1.02)}.modal-content{background:var(--bg-card);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-xl);width:90%;max-width:420px;padding:2.5rem;position:relative;box-shadow:0 40px 80px #0009;animation:modalPop .4s cubic-bezier(.23,1,.32,1)}@keyframes modalPop{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:5px;border-radius:50%;transition:var(--transition-fast)}.modal-close:hover{color:var(--text-white);background:#ffffff0d}.modal-close svg{width:22px;height:22px}.modal-header h2{font-size:1.6rem;font-weight:700;margin-bottom:2rem;text-align:center;color:var(--text-white)}.modal-nav-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.05)}.modal-nav-header h3{font-size:1rem;color:var(--text-white);font-weight:700}.btn-icon-nav{background:none;border:none;color:var(--text-white);cursor:pointer;padding:8px;border-radius:50%;transition:var(--transition);display:flex;align-items:center;justify-content:center}.btn-icon-nav:hover{background:#ffffff1a}.btn-icon-nav svg{width:20px;height:20px}.signup-title-section{text-align:center;margin-top:1rem;margin-bottom:2rem}.signup-title-section h2{font-size:1.8rem;color:var(--text-white);font-weight:800}.modal-body.hidden{display:none}.form-group.disabled input{background:#2d374833!important;color:var(--text-muted);cursor:not-allowed;border-color:#ffffff0d}.input-with-icon{position:relative;display:flex;align-items:center}.input-with-icon input{padding-right:45px}.toggle-password{position:absolute;right:12px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center}.toggle-password:hover{color:var(--text-white)}.toggle-password svg{width:20px;height:20px}.password-check-list{margin-bottom:1.5rem;display:flex;flex-direction:column;gap:8px}.check-item{font-size:.82rem;color:var(--text-muted);display:flex;align-items:center;gap:10px;padding:8px 12px;background:#1e293b4d;border-radius:8px;transition:var(--transition)}.check-item.valid{color:#4ade80;background:#4ade800d}.check-item.valid .icon{content:"✓"}.terms-group{margin:1.5rem 0}.checkbox-container{display:flex;align-items:flex-start;gap:12px;cursor:pointer;font-size:.85rem;color:var(--text-muted);-webkit-user-select:none;user-select:none;line-height:1.5}.checkbox-container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{min-width:18px;height:18px;background-color:transparent;border:2px solid rgba(255,255,255,.2);border-radius:4px;position:relative;transition:var(--transition);margin-top:2px}.checkbox-container:hover input~.checkmark{border-color:var(--accent)}.checkbox-container input:checked~.checkmark{background-color:var(--accent);border-color:var(--accent)}.checkmark:after{content:"";position:absolute;display:none;left:5px;top:2px;width:4px;height:8px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-container input:checked~.checkmark:after{display:block}.terms-text a{color:var(--accent);text-decoration:none}.terms-text a:hover{text-decoration:underline}.user-account-preview{text-align:center;padding:1rem 0 2rem;max-width:100%;overflow:hidden}.user-avatar-large{width:80px;height:80px;border-radius:50%;margin:0 auto 1.5rem;background-size:cover;background-position:center;background-color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:800;color:#fff;border:3px solid rgba(255,255,255,.1);box-shadow:0 10px 30px #0006;flex-shrink:0}.user-account-preview h2{color:var(--text-white);font-size:1.3rem;margin-bottom:.5rem;font-weight:700;word-break:break-word;line-height:1.3}.user-account-preview p{color:var(--text-muted);word-break:break-all}.account-actions{margin-top:1rem}.btn-auth-continue.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.btn-random-username{position:absolute;right:12px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.btn-random-username:hover{color:var(--text-white);transform:rotate(45deg)}.btn-random-username svg{width:20px;height:20px}.auth-disclaimer{margin-top:2rem;font-size:.8rem;color:var(--text-muted);text-align:center;line-height:1.5}.auth-disclaimer u{color:#ef4444;text-decoration:underline}.username-field .input-with-icon input:focus{border-color:#ec4899;box-shadow:0 0 0 4px #ec48991a}.password-check-list .check-item.invalid{color:#ef4444;background:#ef44440d}#close-username-view{padding:8px;background:none;border:none;color:var(--text-white);cursor:pointer}.btn-link-back{display:block;width:100%;margin-top:1.5rem;background:none;border:none;color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:var(--transition)}.btn-link-back:hover{color:var(--text-white)}.modal-overlay.logged-in .modal-header,.modal-overlay.logged-in .btn-google-login,.modal-overlay.logged-in .auth-separator{display:none!important}.modal-overlay.logged-in .modal-nav-header h3{flex:1;text-align:center;margin-right:40px}.auth-switch{text-align:center;margin-top:1.5rem;font-size:.85rem;color:var(--text-muted)}.auth-switch button,.auth-switch a{background:none;border:none;color:var(--accent);cursor:pointer;font-weight:600;padding:0;text-decoration:none}.auth-switch button:hover,.auth-switch a:hover{text-decoration:underline}.auth-separator{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.1em}.auth-separator:before,.auth-separator:after{content:"";flex:1;height:1px;background:#ffffff0d}.modal-scroll-content{max-height:350px;overflow-y:auto;padding-right:1rem;margin-top:1rem;color:var(--text-muted);font-size:.85rem;line-height:1.6}.modal-scroll-content::-webkit-scrollbar{width:4px}.modal-scroll-content::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px}.modal-scroll-content h4{color:var(--text-white);margin:1.5rem 0 .5rem;font-size:.9rem}.text-link{background:none;border:none;color:var(--accent);padding:0;font:inherit;cursor:pointer;text-decoration:none}.text-link:hover{text-decoration:underline}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.8rem;color:var(--text-muted);margin-bottom:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.form-group input{width:100%;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);padding:1rem;color:var(--text-white);font-family:var(--font-main);font-size:1rem;transition:var(--transition-fast)}.form-group input:focus{outline:none;border-color:#ffffff4d;background:#00000080}.btn-auth-continue{width:100%;background:var(--text-white);color:#000;border:none;padding:1rem;border-radius:var(--radius-sm);font-weight:700;font-size:1rem;cursor:pointer;transition:var(--transition)}.btn-auth-continue:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0006}.btn-google-login{width:100%;background:#fff;color:#1f1f1f;border:1px solid #dadce0;padding:.85rem;border-radius:var(--radius-sm);font-weight:600;font-size:.95rem;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center;gap:.75rem;margin-bottom:.5rem}.btn-google-login:hover{background:#f8f9fa;transform:translateY(-2px);box-shadow:0 5px 15px #0003}#landing-page{position:fixed;top:0;left:0;width:100%;height:100%;z-index:2000;display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,transform .6s ease}#landing-page.fade-out{opacity:0;transform:scale(1.05);pointer-events:none}.landing-bg{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;background:var(--bg-darker)}.bg-orb{display:none}.bg-orb{position:absolute;border-radius:50%;filter:blur(80px);animation:orbFloat 8s ease-in-out infinite}.orb-1{width:400px;height:400px;background:#ffffff08;top:-10%;left:-5%;animation-delay:0s}.orb-2{width:350px;height:350px;background:#ff00000d;bottom:-10%;right:-5%;animation-delay:-3s}.orb-3{width:250px;height:250px;background:#00f2ff0a;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-5s}@keyframes orbFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,15px) scale(.95)}}.bg-grid{position:absolute;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%)}.landing-content{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;width:100%;max-width:800px;padding:2.5rem;animation:contentFadeIn 1s cubic-bezier(.2,.8,.2,1)}@keyframes contentFadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.landing-logo{text-align:center;margin-bottom:3.5rem}.logo-icon{width:80px;height:80px;margin:0 auto 1.2rem;position:relative}.logo-icon svg{width:100%;height:100%;filter:drop-shadow(0 0 15px var(--primary-glow));animation:logoFloat 4s ease-in-out infinite}@keyframes logoFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-10px) rotate(5deg)}}.landing-title{font-family:Bebas Neue,sans-serif;font-size:5rem;font-weight:400;line-height:.9;margin-bottom:.8rem;letter-spacing:.05em;color:var(--text-white);text-shadow:1px 1px 0px #d4d4d8,2px 2px 0px #a1a1aa,3px 3px 0px #71717a,4px 4px 6px rgba(0,0,0,.8);transform:perspective(500px) rotateX(10deg)}.landing-title span{color:#fff;background:none;-webkit-text-fill-color:initial;filter:none}.landing-subtitle{font-size:.85rem;color:var(--text-muted);font-weight:400;letter-spacing:.3em;text-transform:uppercase;opacity:.8}.landing-menu{width:100%;background:#000000a6;backdrop-filter:blur(25px);-webkit-backdrop-filter:blur(25px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-xl);padding:2rem;box-shadow:0 20px 50px #00000080,inset 0 0 60px #ffffff05}.menu-heading{font-size:.75rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-dim);margin-bottom:1.5rem;padding-left:.5rem;font-weight:700;display:flex;align-items:center;gap:.8rem}.menu-heading:after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(255,255,255,.1),transparent)}.game-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;max-height:400px;overflow-y:auto;padding:.5rem .8rem .5rem .5rem;perspective:1000px}.game-grid::-webkit-scrollbar{width:4px}.game-grid::-webkit-scrollbar-thumb{background:#ffffff0d;border-radius:10px}.game-grid::-webkit-scrollbar-thumb:hover{background:var(--primary-light)}.game-card{background:#14141466;border:1px solid rgba(255,255,255,.05);border-radius:var(--radius-md);padding:1.2rem;cursor:pointer;font-family:var(--font-main);color:var(--text-dim);display:flex;align-items:center;gap:1rem;transition:all .4s cubic-bezier(.23,1,.32,1);text-align:left;position:relative;overflow:hidden}.game-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#ff00001a,#00f2ff1a);opacity:0;transition:opacity .3s ease}.game-card:hover{border-color:#fff3;color:var(--text-white);transform:translateY(-5px) scale(1.02);background:#ffffff0d;box-shadow:0 15px 35px #0006,0 0 25px #ffffff0d}.game-card:hover:before{opacity:1}.game-card:active{transform:scale(.97)}.card-icon{width:52px;height:52px;display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;z-index:1;background:#ffffff08;border-radius:15px;border:1px solid rgba(255,255,255,.08);transition:all .4s cubic-bezier(.23,1,.32,1)}.game-card:hover .card-icon{background:#fff;color:#000;transform:rotate(-8deg) scale(1.1);box-shadow:0 10px 20px #0006}.game-card:hover .card-icon svg{filter:drop-shadow(0 4px 8px rgba(0,0,0,.3)) brightness(1.2);transform:scale(1.1) translateZ(5px)}.card-icon svg{width:26px;height:26px;color:var(--text-white);transition:all .4s ease}.game-card:hover .card-icon svg{color:#000}.card-info{flex:1;min-width:0;position:relative;z-index:1}.card-name{display:block;font-weight:700;font-size:1.05rem;color:var(--text-white);margin-bottom:.1rem}.card-desc{display:block;font-size:.72rem;color:var(--text-muted)}.landing-footer{margin-top:2.5rem;display:flex;align-items:center;gap:1rem}.footer-text{font-size:.7rem;color:var(--text-muted);letter-spacing:.05em}#game-view{display:flex;width:100vw;height:100vh;height:100dvh;position:relative;overflow:hidden;transition:opacity .4s ease}.game-view-hidden{opacity:0;pointer-events:none}#game-view.game-view-active{opacity:1;pointer-events:auto}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:var(--mobile-header-height);background:#000000f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.1);z-index:3500;align-items:center;justify-content:space-between;padding:0 1rem}.mobile-title{font-family:Bebas Neue,sans-serif;font-size:1.5rem;font-weight:400;letter-spacing:.05em;color:var(--text-white)}.mobile-title span{color:var(--text-white);background:none;-webkit-text-fill-color:initial}.mobile-turn-pill{background:#ffffff14;padding:.3rem .8rem;border-radius:50px;font-size:.75rem;font-weight:700;border:1px solid rgba(255,255,255,.08)}.menu-toggle{background:transparent;border:none;cursor:pointer;width:36px;height:36px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;padding:6px;border-radius:var(--radius-sm);transition:var(--transition-fast)}.menu-toggle:active{background:#ffffff0d}.menu-toggle span{display:block;width:22px;height:2px;background:var(--text-white);border-radius:2px;transition:var(--transition)}.menu-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.menu-toggle.active span:nth-child(2){opacity:0}.menu-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}.sidebar-overlay{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:29;opacity:0;transition:opacity .3s ease}.sidebar-overlay.active{opacity:1}aside{width:var(--sidebar-width);height:100%;background:#000000d9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;z-index:30;padding:2rem 1.5rem;position:relative;flex-shrink:0;margin-left:0;transition:margin-left .4s cubic-bezier(.23,1,.32,1),transform .4s cubic-bezier(.23,1,.32,1),padding .4s,width .4s}aside.desktop-collapsed{margin-left:-280px!important;padding-left:0!important;padding-right:0!important;opacity:0}.sidebar-collapse-btn{position:absolute;right:-10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:5px;transition:var(--transition-fast)}.sidebar-collapse-btn:hover{color:var(--text-white)}.sidebar-collapse-btn svg{width:20px;height:20px}.floating-sidebar-toggle{position:absolute;top:25px;left:20px;z-index:40;background:#0a0a0ad9;border:1px solid rgba(255,255,255,.1);color:var(--text-white);width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:var(--transition)}.floating-sidebar-toggle:hover{background:#191919f2;border-color:#ffffff4d;transform:translateY(-2px)}.floating-sidebar-toggle.hidden{opacity:0;pointer-events:none;transform:translate(-20px)}.floating-sidebar-toggle svg{width:24px;height:24px}aside:after{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(to bottom,transparent,var(--primary-glow),transparent)}aside header{margin-bottom:2.5rem}aside header h1{font-family:Bebas Neue,sans-serif;font-size:2.2rem;font-weight:400;letter-spacing:.05em;color:var(--text-white);margin-bottom:.4rem}aside header h1 span{color:var(--text-white);background:none;-webkit-text-fill-color:initial}aside header p{font-size:.8rem;color:var(--text-muted);font-weight:400;letter-spacing:.03em}.nav-label{text-transform:uppercase;font-size:.65rem;letter-spacing:.15em;color:var(--text-muted);margin-bottom:.8rem;font-weight:600}#game-selector{display:flex;flex-direction:column;gap:.35rem;overflow-y:auto;padding-right:.5rem;flex:1}#game-selector::-webkit-scrollbar{width:3px}#game-selector::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:10px}#game-selector::-webkit-scrollbar-thumb:hover{background:#ffffff26}.game-btn{background:transparent;border:1px solid transparent;color:var(--text-dim);padding:.7rem .9rem;border-radius:var(--radius-md);cursor:pointer;text-align:left;font-family:var(--font-main);font-weight:500;font-size:.9rem;transition:var(--transition);display:flex;align-items:center;gap:.7rem;position:relative;overflow:hidden}.game-btn:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;background:var(--primary);border-radius:0 3px 3px 0;transition:height .2s ease}.game-btn:hover{background:#ffffff0a;color:var(--text-white);transform:translate(4px)}.game-btn:hover:before{height:60%}.game-btn.active{background:#fff;color:#000;box-shadow:0 4px 20px #ffffff26;border-color:transparent}.game-btn.active:before{display:none}.game-btn:active{transform:scale(.97)}.btn-icon{font-size:1.1rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-icon svg{width:100%;height:100%}.sidebar-actions{padding:.75rem 0;border-top:1px solid rgba(255,255,255,.05);margin-top:.5rem}.btn-back{width:100%;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);color:var(--text-dim);padding:.65rem .9rem;border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-main);font-weight:500;font-size:.85rem;transition:var(--transition);display:flex;align-items:center;gap:.5rem}.btn-back:hover{background:#ffffff14;color:var(--text-white)}.sidebar-footer{margin-top:auto;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.05);display:flex;justify-content:center}.version-badge{font-size:.65rem;color:var(--text-muted);background:#ffffff08;padding:.25rem .75rem;border-radius:50px;letter-spacing:.1em}main{flex:1;position:relative;height:100%;min-width:0}#canvas-container{width:100%;height:100%;touch-action:none;-webkit-user-select:none;user-select:none}#canvas-container canvas{display:block;width:100%!important;height:100%!important;touch-action:none}.game-overlay{position:absolute;bottom:1.5rem;right:1.5rem;z-index:10;display:flex;flex-direction:column;gap:.75rem;pointer-events:none;max-width:320px}.info-card{background:var(--bg-card);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);padding:1.25rem;border-radius:var(--radius-xl);pointer-events:auto;box-shadow:var(--shadow-card);animation:slideUp .5s cubic-bezier(.2,.8,.2,1)}.info-card h2{font-size:1.15rem;margin-bottom:.2rem;font-weight:700}.info-card .game-status{font-size:.78rem;color:var(--text-dim);margin-bottom:1.25rem;display:block;line-height:1.4}.controls-group{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.btn-main{flex:1;min-width:0;padding:.65rem .9rem;border-radius:var(--radius-md);border:none;font-family:var(--font-main);font-weight:600;cursor:pointer;transition:var(--transition);font-size:.82rem;display:flex;align-items:center;justify-content:center;gap:.4rem;white-space:nowrap}.btn-main svg{flex-shrink:0}#reset-btn{background:#ffffff0f;color:var(--text-white);border:1px solid rgba(255,255,255,.08)}#reset-btn:hover{background:#ffffff1a;border-color:#ffffff26}#reset-btn:active{transform:scale(.96)}#roll-btn{background:linear-gradient(135deg,var(--accent),var(--accent-blue));color:#fff;border:none}#roll-btn:hover{box-shadow:0 0 20px var(--primary-glow);transform:translateY(-1px)}#roll-btn:active{transform:scale(.96)}.turn-pill{background:#00000059;padding:.45rem .85rem;border-radius:50px;font-size:.75rem;font-weight:700;border:1px solid rgba(255,255,255,.06);white-space:nowrap}#player-turn{margin-left:.2rem}#dice-result-card{background:var(--bg-card);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);padding:.8rem 1rem;border-radius:var(--radius-md);align-self:flex-end;display:flex;align-items:center;gap:.8rem;pointer-events:auto;font-weight:600;font-size:.85rem;animation:slideUp .3s ease}#dice-value{color:var(--primary-light);font-size:1.4rem;background:#ff31311a;width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);font-weight:800}#loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg-darker);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;transition:opacity .8s ease}.loader-container{position:relative;width:70px;height:70px}.loader-ring{position:absolute;width:100%;height:100%;border:3px solid rgba(255,255,255,.05);border-top:3px solid #FFFFFF;border-radius:50%;animation:spin 1.2s cubic-bezier(.5,0,.5,1) infinite}.loader-ring.delay{width:85%;height:85%;top:7.5%;left:7.5%;border-top-color:#71717a;animation-duration:1.8s;animation-direction:reverse}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#loading-overlay p{margin-top:1.5rem;font-size:.85rem;font-weight:300;letter-spacing:.2em;color:var(--text-dim);text-transform:uppercase}.loading-progress{width:160px;height:3px;background:#ffffff0d;border-radius:2px;margin-top:1rem;overflow:hidden}.loading-bar{width:0%;height:100%;background:linear-gradient(90deg,#fff,#71717a);border-radius:2px;transition:width .3s ease}.hidden{display:none!important}#loading-overlay.hidden{display:flex!important;opacity:0;pointer-events:none}@media (max-width: 1024px){.game-overlay{max-width:280px}.game-grid{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.top-navbar{height:60px;padding:0 1rem;padding-top:env(safe-area-inset-top,0px)}.nav-brand{font-size:1.4rem}.nav-right{gap:.8rem}.nav-icon-btn,.btn-login{padding:6px 10px;font-size:.75rem}#game-view{display:block!important}.mobile-header{display:flex;padding-top:env(safe-area-inset-top,0px)}aside{position:fixed;top:0;left:0;width:280px;height:100%;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:40;padding-top:calc(var(--mobile-header-height) + 1rem + env(safe-area-inset-top,0px))}aside.open{transform:translate(0)}aside.desktop-collapsed{margin-left:0}.floating-sidebar-toggle{display:none!important}aside header{display:none}.sidebar-overlay{display:block;pointer-events:none}.sidebar-overlay.active{pointer-events:auto}main{display:block!important;width:100vw!important;max-width:100%!important;height:calc(100vh - var(--mobile-header-height))!important;height:calc(100dvh - var(--mobile-header-height))!important;margin-top:var(--mobile-header-height)!important;flex:none!important}.game-overlay{bottom:0;right:0;left:0;max-width:100%;padding:.5rem;padding-bottom:calc(.5rem + env(safe-area-inset-bottom,0px));gap:.4rem;background:linear-gradient(to top,rgba(0,0,0,.7) 0%,rgba(0,0,0,.3) 60%,transparent 100%);pointer-events:none}.info-card{width:100%;padding:.65rem .85rem;border-radius:var(--radius-md);background:#050505e0;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08)}.info-card h2{font-size:.85rem;margin-bottom:.1rem}.info-card .game-status{font-size:.68rem;margin-bottom:.5rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.controls-group{gap:.35rem}.btn-main{padding:.5rem .65rem;font-size:.75rem;min-height:36px}.turn-pill{padding:.35rem .65rem;font-size:.68rem}#dice-result-card{align-self:stretch;justify-content:center;padding:.5rem .8rem;font-size:.78rem}#dice-value{width:32px;height:32px;font-size:1.2rem}#game-selector{gap:.25rem}.game-btn{padding:.65rem .85rem;font-size:.85rem}.landing-title{font-size:2.2rem}.landing-subtitle{font-size:.75rem}.game-grid{grid-template-columns:1fr}.landing-content{padding:1.5rem;max-width:100%;padding-top:calc(1.5rem + env(safe-area-inset-top,0px))}.landing-logo{margin-bottom:1.5rem}.logo-icon{width:48px;height:48px}.game-card{padding:.75rem .9rem}.card-icon{font-size:1.3rem;width:32px;height:32px}.landing-menu{max-height:60vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-content{max-height:85vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:1.8rem;width:94%;border-radius:var(--radius-lg)}#toast-container{top:calc(12px + env(safe-area-inset-top,0px));right:12px;left:12px}.toast{font-size:.82rem;padding:10px 16px}}@media (max-width: 380px){.info-card{padding:.55rem .7rem}.info-card h2{font-size:.78rem}.info-card .game-status{font-size:.63rem;margin-bottom:.35rem;-webkit-line-clamp:1;line-clamp:1}.controls-group{flex-wrap:wrap}.btn-main{padding:.45rem .55rem;font-size:.7rem;min-height:32px}.turn-pill{flex:1;text-align:center;font-size:.65rem;padding:.3rem .5rem}.landing-title{font-size:1.8rem}#dice-result-card{padding:.4rem .6rem;font-size:.72rem}#dice-value{width:28px;height:28px;font-size:1rem}}@media (max-height: 500px) and (orientation: landscape){.mobile-header{height:40px}.mobile-title{font-size:1.2rem}.menu-toggle{width:30px;height:30px}main{height:calc(100vh - 40px);height:calc(100dvh - 40px);margin-top:40px}.game-overlay{bottom:0;right:0;max-width:220px;left:auto;padding:.35rem;background:none}.info-card{padding:.45rem .65rem;border-radius:var(--radius-sm)}.info-card .game-status{display:none}.info-card h2{font-size:.75rem;margin-bottom:.25rem}.controls-group{gap:.25rem}.btn-main{padding:.35rem .5rem;font-size:.68rem;min-height:28px}.turn-pill{padding:.25rem .5rem;font-size:.62rem}#dice-result-card{padding:.3rem .5rem;font-size:.68rem}#dice-value{width:26px;height:26px;font-size:.95rem}aside{padding-top:calc(40px + .5rem)}}@media (max-height: 700px) and (min-height: 501px) and (orientation: landscape){.mobile-header{height:46px}main{height:calc(100vh - 46px);height:calc(100dvh - 46px);margin-top:46px}.game-overlay{bottom:0;right:0;max-width:250px;left:auto;padding:.4rem;background:none}.info-card{padding:.5rem .7rem}.info-card .game-status{font-size:.65rem;margin-bottom:.4rem;-webkit-line-clamp:1;line-clamp:1}.info-card h2{font-size:.8rem;margin-bottom:.2rem}.btn-main{padding:.4rem .55rem;font-size:.7rem;min-height:30px}.turn-pill{padding:.3rem .55rem;font-size:.65rem}}#toast-container{position:fixed;top:24px;right:24px;z-index:10000;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast{background:#0f172ae6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);color:var(--text-white);padding:12px 24px;border-radius:var(--radius-md);box-shadow:0 10px 30px #0006;display:flex;align-items:center;gap:12px;font-size:.9rem;font-weight:500;pointer-events:auto;animation:toast-slide-in .4s cubic-bezier(.16,1,.3,1),toast-fade-out .4s ease forwards 4.6s;-webkit-user-select:none;user-select:none;border-left:4px solid var(--accent)}.toast.success{border-left-color:#4ade80}.toast.error{border-left-color:#ef4444}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toast-fade-out{0%{transform:translate(0);opacity:1}to{transform:translate(20px);opacity:0}}.points-card{background:#000000b3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);padding:1.2rem;margin-bottom:1rem;min-width:180px;box-shadow:0 10px 30px #00000080;animation:slideUp .4s cubic-bezier(.2,.8,.2,1)}.points-card h3{font-size:.65rem;letter-spacing:.2em;color:var(--text-muted);margin-bottom:1rem;text-transform:uppercase;font-weight:800}.score-grid{display:flex;flex-direction:column;gap:.6rem}.score-item{display:flex;align-items:center;gap:.8rem;padding:.5rem .8rem;background:#ffffff08;border:1px solid rgba(255,255,255,.04);border-radius:10px;transition:var(--transition-fast)}.score-item:hover{background:#ffffff0f;transform:translate(4px)}.score-item .color-dot{width:10px;height:10px;border-radius:50%;box-shadow:0 0 10px currentColor}.score-item.blue .color-dot{background:#1d4ed8;color:#1d4ed880}.score-item.green .color-dot{background:#15803d;color:#15803d80}.score-item.red .color-dot{background:#b91c1c;color:#b91c1c80}.score-item.purple .color-dot{background:#6d28d9;color:#6d28d980}.score-item.white .color-dot{background:#f5f5f7;color:#f5f5f766}.score-item.black .color-dot{background:#111;color:#000c;border:1px solid rgba(255,255,255,.2)}.score-item .player-name{flex:1;font-size:.85rem;font-weight:600;color:var(--text-dim)}.score-item .score-val{font-family:Bebas Neue,sans-serif;font-size:1.4rem;color:var(--text-white);min-width:25px;text-align:right}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
