.user-info-container{position:fixed;z-index:999}.user-info-button{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(102,126,234,.3);border-radius:24px;cursor:pointer;box-shadow:0 4px 12px #0000001a;transition:all .3s ease}.user-info-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;padding:8px;min-width:180px;animation:fadeIn .2s ease-out}.user-info-modal{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:10000}.user-info-modal-content{background:#fff;border-radius:20px;padding:32px;max-width:400px;width:90%;box-shadow:0 20px 60px #0000004d}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.user-info-container[style*="top: 20px"]{top:12px!important}.user-info-container[style*="right: 20px"]{right:12px!important}.user-info-container[style*="left: 20px"]{left:12px!important}.user-info-button{padding:6px 12px;gap:6px}.user-info-button img,.user-info-button>div:first-child{width:28px!important;height:28px!important;font-size:12px!important}.user-info-button>span:nth-child(2){font-size:13px!important;max-width:100px!important}.user-info-dropdown{min-width:160px;margin-top:6px}.user-info-dropdown>div:first-child{padding:10px 14px!important}.user-info-dropdown>div:first-child>div:nth-child(2){font-size:13px!important}.user-info-dropdown>div:first-child>div:nth-child(3){font-size:11px!important}.user-info-dropdown button{padding:8px 14px!important;font-size:13px!important}.user-info-modal-content{padding:28px 24px;width:92%}.user-info-modal-content h3{font-size:18px!important}.user-info-modal-content p{font-size:12px!important}.user-info-modal-content input{padding:12px 14px!important;font-size:14px!important}.user-info-modal-content>div:last-child button{padding:12px!important;font-size:13px!important}}@media(max-width:600px){.user-info-container[style*="top: 20px"]{top:10px!important}.user-info-container[style*="right: 20px"]{right:10px!important}.user-info-container[style*="left: 20px"]{left:10px!important}.user-info-button{padding:6px 10px;gap:6px}.user-info-button img,.user-info-button>div:first-child{width:26px!important;height:26px!important}.user-info-button>span:nth-child(2){font-size:12px!important;max-width:80px!important}.user-info-button>span:last-child{display:none}.user-info-dropdown{min-width:150px;right:-8px!important}.user-info-modal-content{padding:24px 20px;width:94%}}@media(max-width:480px){.user-info-button>span:nth-child(2){display:none}.user-info-button{padding:6px;border-radius:50%;width:40px;height:40px;justify-content:center}.user-info-dropdown{min-width:140px}.user-info-modal-content{padding:20px 18px}.user-info-modal-content h3{font-size:17px!important}.user-info-modal-content>div:last-child{flex-direction:column!important}.user-info-modal-content>div:last-child button{width:100%!important}}@media(max-width:900px)and (max-height:500px){.user-info-container[style*="top: 20px"]{top:8px!important}.user-info-button{padding:5px 10px;gap:5px}.user-info-button img,.user-info-button>div:first-child{width:24px!important;height:24px!important}.user-info-button>span:nth-child(2){font-size:12px!important}.user-info-dropdown{margin-top:4px}.user-info-dropdown>div:first-child{padding:8px 12px!important}.user-info-dropdown button{padding:6px 12px!important;font-size:12px!important}.user-info-modal{padding:10px}.user-info-modal-content{padding:20px;max-width:360px}}@media(hover:none)and (pointer:coarse){.user-info-button{min-width:44px;min-height:44px;-webkit-tap-highlight-color:transparent}.user-info-button:hover{transform:none}.user-info-button:active{transform:scale(.95);opacity:.9}.user-info-dropdown button{min-height:40px;-webkit-tap-highlight-color:transparent}.user-info-dropdown button:hover{background:transparent!important}.user-info-dropdown button:active{background:#f3f4f6!important}.user-info-modal-content input{font-size:16px!important}.user-info-modal-content button{min-height:44px;-webkit-tap-highlight-color:transparent}}.welcome-container{width:100vw;height:100vh;display:flex;justify-content:center;align-items:center;padding:20px;position:relative;overflow:hidden}.welcome-container:before{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(139,92,246,.2) 0%,transparent 70%);border-radius:50%;top:-250px;left:-250px;animation:float 20s ease-in-out infinite}.welcome-container:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(236,72,153,.2) 0%,transparent 70%);border-radius:50%;bottom:-200px;right:-200px;animation:float 15s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translate(0) scale(1)}50%{transform:translate(50px,50px) scale(1.1)}}.welcome-content{position:relative;z-index:10;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:60px 50px;box-shadow:0 20px 60px #0003,0 0 0 1px #ffffff80 inset;max-width:500px;width:100%;margin:0 auto;animation:slideUp .8s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.welcome-header{text-align:center;margin-bottom:48px}.welcome-title{font-size:48px;font-weight:800;margin-bottom:12px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-1px;animation:fadeInDown .8s ease-out .2s both}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.welcome-subtitle{font-size:16px;color:#6b7280;font-weight:500;animation:fadeInDown .8s ease-out .4s both}.welcome-buttons{display:flex;flex-direction:column;gap:16px;align-items:center;width:100%}.welcome-btn{width:100%;max-width:400px;position:relative;display:flex;align-items:center;justify-content:center;gap:12px;padding:20px 32px;font-size:18px;font-weight:600;border:none;border-radius:16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0000001a;overflow:hidden}.welcome-btn:nth-child(1){animation:fadeInUp .8s ease-out .5s both}.welcome-btn:nth-child(2){animation:fadeInUp .8s ease-out .6s both}.welcome-btn:nth-child(3){animation:fadeInUp .8s ease-out .7s both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.welcome-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.welcome-btn:hover:before{width:400px;height:400px}.welcome-btn:hover{transform:translateY(-3px);box-shadow:0 8px 24px #00000026}.welcome-btn:active{transform:translateY(-1px)}.btn-icon{font-size:24px;display:flex;align-items:center;justify-content:center}.btn-text{position:relative;z-index:1}.welcome-btn.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.welcome-btn.btn-secondary{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.welcome-btn.btn-success{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease-out}.modal-content{background:#fff;border-radius:24px;padding:40px;max-width:480px;width:90%;box-shadow:0 20px 60px #0000004d;animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1);position:relative}.modal-content h2{font-size:28px;font-weight:700;margin-bottom:12px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-align:center}.modal-description{text-align:center;color:#6b7280;margin-bottom:32px;font-size:14px}.modal-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:#374151}.form-group input{width:100%;padding:14px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:15px;transition:all .3s ease}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.form-group input::placeholder{color:#9ca3af}.modal-buttons{display:flex;gap:12px;margin-top:12px}.modal-btn{flex:1;padding:14px 24px;border:none;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.modal-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.modal-btn:hover:before{width:300px;height:300px}.modal-btn.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.modal-btn.btn-secondary{background:#fff;color:#667eea;border:2px solid #667eea}.modal-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.modal-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.modal-close{width:100%;margin-top:16px;padding:12px;background:transparent;border:none;color:#6b7280;font-size:14px;cursor:pointer;border-radius:8px;transition:all .3s ease}.modal-close:hover{background:#f3f4f6;color:#374151}.error-message{padding:12px 16px;background:#fee2e2;color:#dc2626;border-radius:10px;font-size:14px;font-weight:500;text-align:center;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}@media(max-width:768px){.welcome-container{padding:80px 16px 16px;align-items:flex-start}.welcome-content{padding:36px 28px;max-width:100%}.welcome-title{font-size:38px}.welcome-subtitle{font-size:15px}.welcome-btn{padding:18px 28px;font-size:17px}.btn-icon{font-size:22px}.modal-content{padding:32px 26px;max-width:92%}.modal-content h2{font-size:26px}.form-group input{padding:16px 18px;font-size:16px}}@media(max-width:480px){.welcome-container{padding:70px 12px 12px}.welcome-content{padding:32px 24px;border-radius:20px}.welcome-title{font-size:34px;margin-bottom:10px}.welcome-subtitle{font-size:14px}.welcome-buttons{gap:14px}.welcome-btn{padding:20px 24px;font-size:16px;border-radius:14px}.btn-icon{font-size:24px}.modal-content{padding:28px 22px;border-radius:20px}.modal-content h2{font-size:24px}.modal-description{font-size:13px;margin-bottom:24px}.modal-buttons{flex-direction:column}.modal-btn{width:100%;padding:16px 24px;font-size:16px}.form-group label{font-size:15px}.form-group input{padding:16px 18px;font-size:16px}}@media(max-width:375px){.welcome-content{padding:28px 20px}.welcome-title{font-size:30px}.welcome-btn{padding:18px 20px;font-size:15px}.modal-content{padding:24px 20px}}@media(max-width:900px)and (max-height:500px){.welcome-container{padding-top:20px;padding-bottom:20px;overflow-y:auto}.welcome-content{padding:24px 28px}.welcome-title{font-size:28px;margin-bottom:8px}.welcome-subtitle{font-size:13px}.welcome-buttons{gap:10px}.welcome-btn{padding:14px 24px;font-size:15px}}@media(hover:none)and (pointer:coarse){.welcome-btn,.modal-btn{min-height:48px}.welcome-btn:hover,.modal-btn:hover{transform:none}.welcome-btn:active,.modal-btn:active{transform:scale(.98);opacity:.9}}.game-container{width:100vw;min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:40px 20px;position:relative;overflow-y:auto}.game-header{text-align:center;margin-bottom:32px;animation:fadeInDown .8s ease-out;position:relative}.game-title{font-size:42px;font-weight:800;margin-bottom:16px;color:#fff;text-shadow:0 3px 8px rgba(0,0,0,.6),0 6px 20px rgba(0,0,0,.4);letter-spacing:-1px;background:linear-gradient(135deg,#fff,#f0f0f0);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.back-to-home-btn{margin-top:16px;padding:12px 32px;font-size:15px;font-weight:600;background:#fffffff2;color:#667eea;border:2px solid rgba(102,126,234,.3);border-radius:24px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000001a;display:inline-flex;align-items:center;gap:8px;position:relative;overflow:hidden}.back-to-home-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#667eea1a;transform:translate(-50%,-50%);transition:width .6s,height .6s}.back-to-home-btn:hover:before{width:300px;height:300px}.back-to-home-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea4d;border-color:#667eea}.back-to-home-btn:active{transform:translateY(0)}.room-info-panel{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-bottom:24px;animation:fadeInDown .8s ease-out .2s both}.game-settings-display{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:20px;animation:fadeInDown .8s ease-out .3s both}.setting-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;background:#667eea1a;border:2px solid rgba(102,126,234,.3);border-radius:20px;font-size:14px;font-weight:600;color:#667eea;box-shadow:0 4px 12px #667eea26;animation:scaleIn .5s ease-out}.setting-badge .setting-icon{font-size:18px}.setting-badge .setting-text{letter-spacing:.3px}.room-info-item{padding:12px 24px;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;box-shadow:0 4px 12px #0000001a;display:inline-flex;align-items:center;gap:8px;animation:scaleIn .5s ease-out}.room-info-item strong{color:#374151;font-weight:600;font-size:14px}.room-info-value{font-size:16px;font-weight:700;font-family:Courier New,monospace;letter-spacing:1px}.room-id{color:#667eea;font-size:18px}.room-password{color:#f5576c}.room-role-host{color:#10b981}.room-role-player{color:#3b82f6}.start-game-section{text-align:center;margin-bottom:24px;animation:fadeInUp .8s ease-out .4s both}.start-game-btn{padding:16px 40px;font-size:18px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:16px;cursor:pointer;box-shadow:0 6px 20px #667eea66;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.start-game-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.start-game-btn:hover:before{width:400px;height:400px}.start-game-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 30px #667eea80}.start-game-btn:disabled{opacity:.5;cursor:not-allowed;filter:grayscale(50%)}.start-game-btn:disabled:before{display:none}.start-game-hint{margin-top:12px;font-size:13px;color:#fffc;font-weight:500}.waiting-message{text-align:center;margin-bottom:24px;padding:20px 32px;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;box-shadow:0 4px 12px #0000001a;animation:pulse 2s ease-in-out infinite}.waiting-message-text{font-size:16px;color:#6b7280;font-weight:600}.game-main{display:flex;gap:24px;align-items:flex-start;justify-content:center;width:100%;max-width:1200px;animation:fadeInUp .8s ease-out .6s both;height:calc(100vh - 180px);min-height:600px}.game-board-section{display:flex;flex-direction:column;align-items:center;gap:16px;flex:1;max-width:500px}.player-section{display:flex;flex-direction:column;align-items:center;gap:20px}.player-label{font-size:24px;font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.3);display:flex;align-items:center;gap:12px}.online-status{display:inline-flex;align-items:center;gap:6px;font-size:14px;padding:6px 12px;border-radius:20px;font-weight:600}.online-status.online{background:#10b98133;color:#10b981}.online-status.offline{background:#ef444433;color:#ef4444}.status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s ease-in-out infinite}.status-dot.online{background:#10b981;box-shadow:0 0 8px #10b981}.status-dot.offline{background:#ef4444}.game-board-wrapper{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:24px;box-shadow:0 20px 60px #0003;transition:all .3s ease}.game-board-wrapper:hover{transform:translateY(-4px);box-shadow:0 24px 70px #00000040}.game-controls-wrapper{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;padding:16px;box-shadow:0 8px 24px #00000026;width:140px;display:flex;flex-direction:column;align-items:stretch;gap:12px;flex-shrink:0}.score-display{text-align:center;padding:12px 8px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 12px #667eea4d;width:100%}.score-label{font-size:12px;color:#ffffffe6;font-weight:600;margin-bottom:4px}.score-value{font-size:24px;font-weight:800;color:#fff;font-family:Courier New,monospace;text-shadow:0 2px 4px rgba(0,0,0,.2)}.game-action-buttons{display:flex;flex-direction:column;gap:12px;width:100%}.game-btn{padding:12px 8px;font-size:13px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000001a;position:relative;overflow:hidden;white-space:nowrap}.game-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.game-btn:hover:before{width:300px;height:300px}.game-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0003}.game-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.game-btn-secondary{background:#fff;color:#667eea;border:2px solid #667eea}.game-btn-danger{background:linear-gradient(135deg,#f5576c,#f093fb);color:#fff}.game-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.direction-controls{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:16px;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;width:100%;box-shadow:0 4px 12px #0000001a}.direction-btn{width:100%;height:64px;font-size:28px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;border:none;border-radius:12px;cursor:pointer;box-shadow:0 4px 12px #4facfe4d;transition:all .2s ease;-webkit-user-select:none;user-select:none}.direction-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.05);box-shadow:0 6px 16px #4facfe66}.direction-btn:active:not(:disabled){transform:translateY(0) scale(.95)}.direction-btn:disabled{opacity:.4;cursor:not-allowed;background:linear-gradient(135deg,#9ca3af,#6b7280)}.direction-controls.paused{opacity:.6}.pause-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;justify-content:center;align-items:center;z-index:2000;animation:fadeIn .3s ease-out;cursor:pointer}.pause-content{background:#fff;border-radius:24px;padding:48px 60px;text-align:center;box-shadow:0 20px 60px #0006;animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1);cursor:default}.pause-icon{font-size:80px;margin-bottom:20px;animation:pulse 2s ease-in-out infinite}.pause-title{font-size:32px;font-weight:700;margin-bottom:16px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.pause-hint{font-size:16px;color:#6b7280;margin-bottom:32px;line-height:1.6}.pause-hint-desktop{display:block}.pause-hint-mobile{display:none}.pause-content .game-btn{min-width:200px}.game-over-message{position:fixed;top:24px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:20px 40px;border-radius:16px;box-shadow:0 10px 40px #10b98166;z-index:1000;font-size:18px;font-weight:700;animation:slideDown .5s ease-out,fadeOut .5s ease-out 2.5s forwards;text-align:center}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-100px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes fadeOut{to{opacity:0;transform:translate(-50%) translateY(-20px)}}.password-modal{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease-out}.password-modal-content{background:#fff;border-radius:24px;padding:40px;max-width:480px;width:90%;box-shadow:0 20px 60px #0000004d;animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1)}.password-modal h3{font-size:24px;font-weight:700;margin-bottom:20px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.password-modal input{width:100%;padding:14px 18px;border:2px solid #e5e7eb;border-radius:12px;font-size:15px;margin-bottom:16px;transition:all .3s ease}.password-modal input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 4px #667eea1a}.password-modal-error{color:#ef4444;margin-bottom:16px;padding:12px;background:#fee2e2;border-radius:8px;font-size:14px}.password-modal-buttons{display:flex;gap:12px}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@media(max-width:1200px){.game-main{gap:30px}.game-controls-wrapper{min-width:180px}}@media(max-width:900px){.game-container{padding:20px 16px}.game-title{font-size:28px}.game-main{flex-direction:row;gap:12px;height:calc(100vh - 160px);min-height:500px}.game-board-section{flex:1;max-width:none}.game-controls-wrapper{width:70px;min-width:70px;padding:8px;gap:8px;display:flex;flex-direction:column;align-items:center}.score-display{padding:6px 4px;border-radius:8px}.score-label{font-size:9px;margin-bottom:2px}.score-value{font-size:16px}.upcoming{width:100%;padding:1px;gap:2px}.upcoming .cell{width:3px;border-width:1px;border-radius:2px}.game-btn{padding:6px 4px;font-size:9px;border-radius:6px}.direction-controls{gap:10px;padding:12px}.direction-btn{height:56px;font-size:24px}}@media(max-width:768px){.pause-content{padding:36px 40px;max-width:90%}.pause-icon{font-size:64px}.pause-title{font-size:28px}.pause-hint{font-size:14px}.pause-hint-desktop{display:none}.pause-hint-mobile{display:block}.game-settings-display{gap:10px;margin-bottom:16px;padding:0 12px}.setting-badge{padding:8px 14px;font-size:12px}.setting-badge .setting-icon{font-size:16px}.game-container{padding:12px 0;overflow-x:hidden}.game-header{margin-bottom:16px;padding:0 12px}.game-title{font-size:24px;margin-bottom:10px}.back-to-home-btn{padding:8px 20px;font-size:13px}.room-info-panel{gap:10px;padding:0 12px}.room-info-item{padding:10px 18px;font-size:13px}.room-info-item strong{font-size:13px}.room-info-value{font-size:15px}.player-label{font-size:20px}.game-main{flex-direction:row;gap:8px;height:auto;min-height:auto;padding:0 12px;max-width:100%;width:100%}.game-board-section{flex:1;min-width:0}.game-board-wrapper{padding:10px;border-radius:14px;width:100%}.game-controls-wrapper{width:70px;min-width:70px;padding:8px;gap:6px;flex-shrink:0}.score-display{padding:6px 4px}.score-label{font-size:9px;margin-bottom:2px}.score-value{font-size:16px}.upcoming{width:100%;padding:1px;gap:2px}.upcoming .cell{width:3px;border-width:1px;border-radius:2px}.game-btn{padding:6px 4px;font-size:9px;border-radius:6px}.direction-controls{position:fixed;bottom:0;left:0;right:0;gap:8px;padding:12px;margin:0;width:100vw;max-width:100vw;border-radius:0;box-shadow:0 -4px 12px #00000026;background:#fffffffa;z-index:100}.direction-btn{height:60px;font-size:26px}.game-board-section{margin-bottom:100px}.game-main:has(.opponent-section){flex-direction:column;gap:16px;padding:0 8px}.opponent-section{display:flex;flex-direction:row;gap:8px;width:100%;align-items:center;padding:12px;background:#ffffffb3;border-radius:16px;box-shadow:0 4px 12px #0000001a}.opponent-section .player-label{position:absolute;top:-8px;left:50%;transform:translate(-50%);background:#fffffff2;padding:6px 16px;border-radius:12px;font-size:14px;box-shadow:0 2px 8px #0000001a}.opponent-section{position:relative;padding-top:24px}.opponent-section .game-board-wrapper{transform:scale(.55);transform-origin:center;flex:1;margin:-20px 0}.opponent-section .game-controls-wrapper{width:60px;min-width:60px;padding:6px;gap:6px;flex-shrink:0}.opponent-section .score-display{padding:6px 4px}.opponent-section .score-label{font-size:9px}.opponent-section .score-value{font-size:14px}.player-section:not(.opponent-section){flex-direction:row;width:100%;gap:8px}.player-section:not(.opponent-section) .player-label{position:absolute;top:-8px;left:50%;transform:translate(-50%);background:#fffffff2;padding:6px 16px;border-radius:12px;font-size:16px;box-shadow:0 2px 8px #0000001a;z-index:10}.player-section:not(.opponent-section){position:relative;background:#ffffffb3;border-radius:16px;padding:24px 12px 12px;box-shadow:0 4px 12px #0000001a}.player-section:not(.opponent-section) .game-board-wrapper{flex:1}.start-game-btn{padding:14px 32px;font-size:16px}.waiting-message{padding:16px 24px;margin:0 12px 16px}.waiting-message-text{font-size:15px}}@media(max-width:600px){.pause-content{padding:28px 32px;border-radius:20px}.pause-icon{font-size:56px;margin-bottom:16px}.pause-title{font-size:24px;margin-bottom:12px}.pause-hint{font-size:13px;margin-bottom:24px}.pause-content .game-btn{min-width:160px;padding:14px 24px;font-size:15px}.game-container{padding:8px 0;overflow-x:hidden}.game-header{margin-bottom:10px;padding:0 8px}.game-title{font-size:20px;margin-bottom:6px}.back-to-home-btn{padding:6px 14px;font-size:11px;margin-top:6px}.room-info-panel{gap:8px;flex-direction:column;width:100%;padding:0 8px}.room-info-item{padding:10px 16px;font-size:12px;width:100%;justify-content:center}.room-info-value{font-size:14px}.player-label{font-size:16px}.online-status{font-size:11px;padding:4px 8px}.game-main{flex-direction:row;gap:6px;height:auto;min-height:auto;padding:0 8px;max-width:100%;width:100%}.game-board-section{flex:1;min-width:0;margin-bottom:100px}.game-board-wrapper{padding:8px;border-radius:10px;width:100%}.game-controls-wrapper{width:70px;min-width:70px;padding:8px;gap:6px;flex-shrink:0}.score-display{padding:6px 4px}.score-label{font-size:9px;margin-bottom:2px}.score-value{font-size:16px}.upcoming{width:100%;padding:1px;gap:2px}.upcoming .cell{width:3px;border-width:1px;border-radius:2px}.game-btn{padding:6px 4px;font-size:9px;border-radius:6px}.direction-controls{position:fixed;bottom:0;left:0;right:0;gap:8px;padding:10px;margin:0;grid-template-columns:repeat(4,1fr);width:100vw;max-width:100vw;border-radius:0;box-shadow:0 -4px 12px #00000026;background:#fffffffa;z-index:100}.direction-btn{height:56px;font-size:24px}.game-main:has(.opponent-section){flex-direction:column;gap:12px;padding:0 8px}.opponent-section{padding:20px 8px 8px}.opponent-section .player-label{font-size:13px;padding:5px 12px}.opponent-section .game-board-wrapper{transform:scale(.5);margin:-25px 0}.opponent-section .game-controls-wrapper{width:55px;min-width:55px;padding:5px;gap:5px}.opponent-section .score-display{padding:5px 3px}.opponent-section .score-label{font-size:8px}.opponent-section .score-value{font-size:13px}.player-section:not(.opponent-section){padding:20px 8px 8px}.player-section:not(.opponent-section) .player-label{font-size:15px;padding:5px 14px}.start-game-btn{padding:12px 28px;font-size:15px}.start-game-hint{font-size:12px}.waiting-message{padding:14px 20px;margin:0 8px 12px}.waiting-message-text{font-size:14px}.game-over-message{top:16px;padding:16px 28px;font-size:16px;left:10px;right:10px;transform:translate(0)}.password-modal-content{padding:32px 24px}.password-modal h3{font-size:22px}.password-modal input{padding:12px 16px;font-size:16px}}@media(max-width:375px){.pause-content{padding:24px 28px}.pause-icon{font-size:48px}.pause-title{font-size:22px}.pause-hint{font-size:12px}.pause-content .game-btn{min-width:140px;font-size:14px}.game-container{padding:6px 0;overflow-x:hidden}.game-header{padding:0 6px}.game-title{font-size:18px}.back-to-home-btn{padding:6px 12px;font-size:10px}.game-main{flex-direction:row;gap:5px;height:auto;min-height:auto;padding:0 6px;max-width:100%;width:100%}.game-board-section{flex:1;min-width:0;margin-bottom:90px}.game-board-wrapper{padding:6px;width:100%}.game-controls-wrapper{width:70px;min-width:70px;padding:8px;gap:6px;flex-shrink:0}.score-display{padding:6px 4px}.score-value{font-size:16px}.score-label{font-size:9px}.upcoming{width:100%;padding:1px;gap:2px}.upcoming .cell{width:3px;border-width:1px;border-radius:2px}.game-btn{padding:6px 4px;font-size:9px;border-radius:6px}.direction-controls{position:fixed;bottom:0;left:0;right:0;gap:6px;padding:8px;margin:0;grid-template-columns:repeat(4,1fr);width:100vw;max-width:100vw;border-radius:0;box-shadow:0 -4px 12px #00000026;background:#fffffffa;z-index:100}.direction-btn{height:50px;font-size:22px}.game-main:has(.opponent-section){flex-direction:column;gap:10px;padding:0 6px}.opponent-section{padding:18px 6px 6px}.opponent-section .player-label{font-size:12px;padding:4px 10px}.opponent-section .game-board-wrapper{transform:scale(.45);margin:-30px 0}.opponent-section .game-controls-wrapper{width:50px;min-width:50px;padding:4px;gap:4px}.opponent-section .score-display{padding:4px 2px}.opponent-section .score-label{font-size:7px}.opponent-section .score-value{font-size:12px}.player-section:not(.opponent-section){padding:18px 6px 6px}.player-section:not(.opponent-section) .player-label{font-size:14px;padding:4px 12px}.room-info-panel{gap:6px;margin-bottom:8px}.room-info-item{padding:8px 14px;font-size:11px}.room-info-value{font-size:13px}.start-game-btn{padding:10px 24px;font-size:14px}.start-game-hint{font-size:11px}.waiting-message{padding:12px 18px;margin:0 6px 10px}.waiting-message-text{font-size:13px}}@media(max-width:900px)and (max-height:500px){.game-container{padding:12px 10px}.game-header{margin-bottom:16px}.game-title{font-size:20px;margin-bottom:8px}.back-to-home-btn{padding:8px 16px;font-size:12px;margin-top:8px}.game-main{gap:16px;flex-direction:row;flex-wrap:wrap;justify-content:center}.player-section{gap:12px}.player-label{font-size:16px}.game-board-wrapper{padding:10px}.game-controls-wrapper{padding:12px;min-width:200px}.score-display{padding:10px}.score-value{font-size:20px}.direction-controls{padding:10px;gap:8px;margin-top:10px}.direction-btn{width:48px;height:48px;font-size:20px}.game-btn{padding:10px 16px;font-size:12px}}@media(hover:none)and (pointer:coarse){.game-btn,.direction-btn,.start-game-btn,.back-to-home-btn{min-height:48px;-webkit-tap-highlight-color:transparent}.game-btn:hover,.direction-btn:hover,.start-game-btn:hover,.back-to-home-btn:hover{transform:none}.game-btn:active,.start-game-btn:active,.back-to-home-btn:active{transform:scale(.98);opacity:.9}.direction-btn:active{transform:scale(.95);opacity:.9}.direction-btn:active{background:linear-gradient(135deg,#00d4ff,#0096ff)}}.high-scores-container{min-height:100vh;display:flex;justify-content:center;align-items:center;padding:20px}.high-scores-content{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:40px;max-width:600px;width:100%;box-shadow:0 20px 60px #0003;text-align:center}@media(max-width:768px){.high-scores-container{padding:80px 16px 16px;align-items:flex-start}.high-scores-content{padding:32px 24px;border-radius:20px}.high-scores-content h1{font-size:30px!important;margin-bottom:24px!important}.high-scores-content ol li{padding:14px!important;margin:6px 0!important;font-size:16px!important;flex-wrap:wrap}.high-scores-content button{padding:12px 28px!important;font-size:15px!important;width:100%;max-width:300px}}@media(max-width:600px){.high-scores-container{padding:70px 12px 12px}.high-scores-content{padding:28px 20px;border-radius:18px}.high-scores-content h1{font-size:26px!important;margin-bottom:20px!important}.high-scores-content ol{margin-bottom:24px!important}.high-scores-content ol li{padding:12px!important;font-size:15px!important;border-radius:10px}.high-scores-content ol li span:first-child{min-width:35px!important;font-size:18px}.high-scores-content button{padding:14px 24px!important;font-size:14px!important;width:100%}}@media(max-width:480px){.high-scores-container{padding:60px 10px 10px}.high-scores-content{padding:24px 18px}.high-scores-content h1{font-size:24px!important}.high-scores-content p{font-size:14px!important}.high-scores-content ol li{padding:10px!important;font-size:14px!important}}@media(max-width:900px)and (max-height:500px){.high-scores-container{padding:20px 16px;overflow-y:auto}.high-scores-content{padding:24px 28px}.high-scores-content h1{font-size:24px!important;margin-bottom:16px!important}.high-scores-content ol{max-height:300px;overflow-y:auto;margin-bottom:20px!important}.high-scores-content ol li{padding:10px!important;font-size:14px!important}}@media(hover:none)and (pointer:coarse){.high-scores-content button{min-height:48px;-webkit-tap-highlight-color:transparent}.high-scores-content button:hover{transform:none}.high-scores-content button:active{transform:scale(.98);opacity:.9}}.game-settings-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:3000;animation:fadeIn .3s ease-out;padding:20px}.game-settings-modal{background:#fff;border-radius:24px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0006;animation:slideUp .3s cubic-bezier(.34,1.56,.64,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.game-settings-header{padding:32px 32px 24px;border-bottom:2px solid #f3f4f6;text-align:center}.game-settings-header h2{font-size:28px;font-weight:700;margin:0 0 8px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.game-settings-subtitle{color:#6b7280;font-size:14px;margin:0}.game-settings-content{padding:24px 32px}.setting-item{display:flex;align-items:center;justify-content:space-between;padding:20px;background:#f9fafb;border-radius:16px;margin-bottom:20px;transition:all .3s ease}.setting-item:hover{background:#f3f4f6;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.setting-header{display:flex;align-items:center;gap:16px;flex:1}.setting-icon{font-size:32px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.setting-info h3{font-size:18px;font-weight:600;margin:0 0 4px;color:#1f2937}.setting-info p{font-size:13px;color:#6b7280;margin:0;line-height:1.4}.toggle-switch{position:relative;display:inline-block;width:56px;height:32px;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background-color:#d1d5db;border-radius:32px;transition:all .3s ease;box-shadow:inset 0 2px 4px #0000001a}.toggle-slider:before{content:"";position:absolute;height:24px;width:24px;left:4px;bottom:4px;background-color:#fff;border-radius:50%;transition:all .3s ease;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background:linear-gradient(135deg,#667eea,#764ba2)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.block-selector{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px;margin-top:16px}.block-option{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .3s ease}.block-option:hover{border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 20px #667eea33}.block-option.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea1a,#764ba21a);box-shadow:0 4px 12px #667eea4d}.block-preview{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;color:#fff;box-shadow:0 4px 12px #0003,inset 0 -2px #0003;transition:all .3s ease}.block-preview.no-disable{background:linear-gradient(135deg,#10b981,#059669);font-size:32px}.block-option:hover .block-preview{transform:scale(1.1) rotate(5deg)}.block-option.selected .block-preview{transform:scale(1.05)}.block-letter{text-shadow:0 2px 4px rgba(0,0,0,.3)}.block-name{font-size:12px;font-weight:600;color:#374151;text-align:center;line-height:1.3}.settings-tips{margin-top:24px;padding:16px;background:#fffbeb;border:1px solid #fef3c7;border-radius:12px}.tip-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:8px}.tip-item:last-child{margin-bottom:0}.tip-icon{font-size:18px;flex-shrink:0}.tip-text{font-size:13px;color:#92400e;line-height:1.5}.game-settings-actions{display:flex;gap:12px;padding:24px 32px 32px;border-top:2px solid #f3f4f6}.settings-btn{flex:1;padding:14px 24px;font-size:16px;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.settings-btn:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.settings-btn:hover:before{width:300px;height:300px}.settings-btn-cancel{background:#f3f4f6;color:#6b7280}.settings-btn-cancel:hover{background:#e5e7eb;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.settings-btn-confirm{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.settings-btn-confirm:hover{transform:translateY(-2px);box-shadow:0 8px 20px #667eea66}@media(max-width:768px){.game-settings-modal{max-height:95vh;border-radius:20px}.game-settings-header{padding:24px 24px 20px}.game-settings-header h2{font-size:24px}.game-settings-content{padding:20px 24px}.setting-item{padding:16px}.setting-icon{font-size:28px;width:44px;height:44px}.setting-info h3{font-size:16px}.setting-info p{font-size:12px}.block-selector{grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:10px}.block-option{padding:12px 8px}.block-preview{width:50px;height:50px;font-size:24px}.block-name{font-size:11px}.game-settings-actions{padding:20px 24px 24px}.settings-btn{padding:12px 20px;font-size:15px}}@media(max-width:600px){.game-settings-modal-overlay{padding:12px}.game-settings-header{padding:20px 20px 16px}.game-settings-header h2{font-size:22px}.game-settings-subtitle{font-size:13px}.game-settings-content{padding:16px 20px}.setting-item{padding:14px;flex-direction:column;gap:12px}.toggle-switch{align-self:stretch;width:100%;height:40px}.toggle-slider:before{height:32px;width:32px}.toggle-switch input:checked+.toggle-slider:before{transform:translate(calc(100% - 40px))}.block-selector{grid-template-columns:repeat(3,1fr);gap:8px}.block-option{padding:10px 6px}.block-preview{width:48px;height:48px;font-size:22px}.block-name{font-size:10px}.settings-tips{padding:12px}.tip-text{font-size:12px}.game-settings-actions{flex-direction:column;padding:16px 20px 20px}.settings-btn{padding:14px 20px}}@media(hover:none)and (pointer:coarse){.settings-btn:hover,.block-option:hover,.setting-item:hover{transform:none}.settings-btn:active{transform:scale(.98)}.block-option:active{transform:scale(.95)}}.game-history-container{min-height:100vh;padding:80px 20px 40px;position:relative}.game-history-content{max-width:1200px;margin:0 auto}.game-history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.game-card{background:#fffffff2;border-radius:16px;padding:20px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000001a;border:2px solid transparent}.game-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026;border-color:#667eea}.game-card-preview{display:block}.game-detail-modal{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.game-detail-content{background:#fff;border-radius:24px;padding:40px;max-width:900px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 20px 60px #0000004d}@media(max-width:768px){.game-history-container{padding:70px 16px 32px}.game-history-content h1{font-size:30px!important;margin-bottom:24px!important}.game-history-grid{grid-template-columns:1fr;gap:16px}.game-card{padding:18px;border-radius:14px}.game-card-preview{display:none}.game-detail-modal{padding:16px}.game-detail-content{padding:32px 24px;border-radius:20px;max-height:85vh}.game-detail-content h2{font-size:24px!important;margin-bottom:20px!important}.game-detail-content>div:nth-child(2){grid-template-columns:1fr!important;gap:12px!important}.game-detail-content>div:last-of-type{flex-direction:column!important;gap:24px!important}.game-detail-content button{padding:12px 28px!important;font-size:15px!important}}@media(max-width:600px){.game-history-container{padding:60px 12px 28px}.game-history-content h1{font-size:26px!important;margin-bottom:20px!important}.game-card{padding:16px}.game-card>div:first-child{flex-direction:column;align-items:flex-start!important;gap:8px}.game-card>div:first-child span:first-child{font-size:18px!important}.game-card>div:last-child{transform:scale(.35)!important;height:280px!important;width:112px!important}.game-detail-content{padding:28px 20px}.game-detail-content h2{font-size:22px!important}.game-detail-content>div:nth-child(2)>div{padding:12px!important}.game-detail-content>div:last-of-type>div{transform:scale(.6)!important}.game-detail-content button{padding:12px 24px!important;font-size:14px!important;width:100%}.game-history-content>div:nth-child(2){padding:48px 24px!important}.game-history-content>div:nth-child(2)>div:first-child{font-size:48px!important}.game-history-content>div:nth-child(2) h2{font-size:20px!important}.game-history-content>div:nth-child(2) p{font-size:14px!important}.game-history-content>div:nth-child(2) button{padding:12px 28px!important;font-size:15px!important}.game-history-content>div:last-child button{width:100%;max-width:300px}}@media(max-width:480px){.game-history-container{padding:55px 10px 24px}.game-history-content h1{font-size:24px!important}.game-card{padding:14px}.game-detail-content{padding:24px 18px}}@media(max-width:900px)and (max-height:500px){.game-history-container{padding:40px 16px 24px}.game-history-content h1{font-size:24px!important;margin-bottom:16px!important}.game-history-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px}.game-card{padding:14px}.game-card>div:last-child{display:none}.game-detail-modal{padding:12px}.game-detail-content{padding:24px 20px;max-height:88vh}.game-detail-content h2{font-size:20px!important;margin-bottom:16px!important}.game-detail-content>div:last-of-type{flex-direction:row!important;gap:16px!important}.game-detail-content>div:last-of-type>div{transform:scale(.5)!important}}@media(hover:none)and (pointer:coarse){.game-card{-webkit-tap-highlight-color:transparent}.game-card:hover{transform:none}.game-card:active{transform:scale(.98);opacity:.9}.game-detail-content button{min-height:48px;-webkit-tap-highlight-color:transparent}.game-detail-content button:hover{background:#e5e7eb!important}.game-detail-content button:active{transform:scale(.98);background:#d1d5db!important}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-color: #6d28d9;--primary-light: #8b5cf6;--primary-dark: #5b21b6;--secondary-color: #f5f3ff;--accent-color: #7c3aed;--accent-light: #a78bfa;--text-color: #1f2937;--text-light: #6b7280;--border-color: #e5e7eb;--success-color: #10b981;--warning-color: #f59e0b;--danger-color: #ef4444;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .15);--shadow-xl: 0 20px 40px rgba(0, 0, 0, .2);--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-secondary: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--gradient-success: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%)}html,body{width:100%;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);background-attachment:fixed;min-height:100vh;color:var(--text-color)}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 50%,rgba(120,119,198,.3),transparent 50%),radial-gradient(circle at 80% 80%,rgba(138,43,226,.3),transparent 50%);pointer-events:none;z-index:0}#root{min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:1}button{font-family:inherit;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;border-radius:12px;font-size:14px;font-weight:600;position:relative;overflow:hidden;letter-spacing:.5px}button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#ffffff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}button:hover:before{width:300px;height:300px}button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}button:active{transform:translateY(0);box-shadow:var(--shadow)}button:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{background:var(--gradient-primary);color:#fff;padding:14px 32px;box-shadow:var(--shadow-md)}.btn-primary:hover{box-shadow:var(--shadow-xl)}.btn-secondary{background:#fff;color:var(--primary-color);padding:14px 32px;border:2px solid var(--primary-color);box-shadow:var(--shadow)}.btn-secondary:hover{background:var(--primary-color);color:#fff}.btn-success{background:var(--gradient-success);color:#fff;padding:14px 32px;box-shadow:var(--shadow-md)}input,textarea{font-family:inherit;background:#fff;border:2px solid var(--border-color);border-radius:12px;padding:14px 18px;color:var(--text-color);transition:all .3s ease;font-size:14px}input:focus,textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #6d28d926;transform:translateY(-1px)}input::placeholder,textarea::placeholder{color:var(--text-light);opacity:.6}.card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:32px;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.3);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,transparent 50%);pointer-events:none}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.card-glass{background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a}h1,h2,h3{color:var(--text-color);font-weight:700;line-height:1.2}h1{font-size:42px;margin-bottom:24px;letter-spacing:-1px;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:32px;margin-bottom:18px;letter-spacing:-.5px}h3{font-size:22px;margin-bottom:12px}p{color:var(--text-light);line-height:1.7;margin-bottom:12px}main{flex:1;padding:48px 24px;max-width:1400px;margin:0 auto;width:100%}.grid{display:grid;gap:28px}.grid-2{grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}.loading{animation:shimmer 2s infinite;background:linear-gradient(to right,#f0f0f0 4%,#f8f8f8 25%,#f0f0f0 36%);background-size:1000px 100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .6s ease-out}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.badge{display:inline-flex;align-items:center;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.5px}.badge-primary{background:var(--gradient-primary);color:#fff}.badge-success{background:var(--success-color);color:#fff}.badge-warning{background:var(--warning-color);color:#fff}.divider{height:1px;background:linear-gradient(to right,transparent,var(--border-color),transparent);margin:24px 0}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#0000001a;border-radius:5px}::-webkit-scrollbar-thumb{background:var(--gradient-primary);border-radius:5px;transition:background .3s}::-webkit-scrollbar-thumb:hover{background:var(--primary-dark)}@media(max-width:768px){h1{font-size:32px;margin-bottom:16px}h2{font-size:24px;margin-bottom:12px}h3{font-size:18px}button{padding:12px 24px;font-size:14px;min-height:44px}.btn-primary,.btn-secondary,.btn-success{padding:16px 28px}.card{padding:24px;border-radius:12px}main{padding:32px 16px}.grid{gap:20px}.grid-2{grid-template-columns:1fr}input,textarea{padding:16px 18px;font-size:16px}}@media(max-width:480px){h1{font-size:28px;margin-bottom:12px}h2{font-size:22px;margin-bottom:10px}h3{font-size:16px}button{padding:12px 20px;font-size:13px}.btn-primary,.btn-secondary,.btn-success{padding:14px 24px;font-size:15px}.card{padding:20px;border-radius:12px}main{padding:24px 12px}.grid{gap:16px}input,textarea{padding:14px 16px;font-size:16px}.badge{padding:5px 12px;font-size:11px}}@media(max-width:375px){h1{font-size:26px}h2{font-size:20px}.card{padding:18px}main{padding:20px 10px}button{padding:10px 18px;font-size:12px}}@media(max-width:900px)and (max-height:500px){body,#root{min-height:auto}main{padding:20px 16px}h1{font-size:24px;margin-bottom:12px}h2{font-size:20px;margin-bottom:10px}.card{padding:16px}}@media(hover:none)and (pointer:coarse){button,input,textarea,select,a{min-height:44px;-webkit-tap-highlight-color:transparent}button:hover,.card:hover{transform:none}button:active{transform:scale(.98);opacity:.9}.card:active{transform:scale(.99)}input:focus,textarea:focus{transform:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:root{--primary-color: #2563eb;--border-color: #1f2937;--background-color: #f3f4f6;--shadow-color: rgba(0, 0, 0, .1)}*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:#1a1a1a;font-family:system-ui,-apple-system,sans-serif;margin:0;padding:20px;touch-action:manipulation;-webkit-overflow-scrolling:touch;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}input,textarea{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}.app{display:grid;grid-template-areas:"left title right" "left game controls";grid-template-columns:1fr 400px 192px;max-width:800px;margin:0 auto;justify-content:center;gap:20px}.controls{grid-area:controls;width:192px;padding:0;display:flex;flex-direction:column;gap:16px}.board{justify-self:center;margin:0}h1{text-align:center;grid-area:title;font-size:2.5rem;margin:1rem 0;color:#fff}h2{font-size:1.5rem;margin:1rem 0;color:#fff}button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;background-color:var(--primary-color);color:#fff;border:none;border-radius:6px;cursor:pointer;box-shadow:0 2px 4px var(--shadow-color)}button:hover{background-color:#1d4ed8;transform:translateY(-1px)}button:active{transform:translateY(0)}.game-buttons{display:flex;gap:12px;justify-content:center;margin-top:12px;flex-wrap:wrap;background:#0000000f;padding:6px 8px;border-radius:10px}.game-buttons button{padding:.5rem .75rem;font-size:1.125rem;width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px}.game-area{grid-area:game;display:flex;flex-direction:column;align-items:center}.board{border:3px solid var(--border-color);border-radius:12px;-webkit-user-select:none;user-select:none;margin:auto;background-color:#1a1a1a;box-shadow:0 8px 16px var(--shadow-color),inset 0 2px 4px #ffffff1a;padding:16px;position:relative}.board:before{content:"";position:absolute;inset:0;background:linear-gradient(45deg,transparent,rgba(255,255,255,.03));pointer-events:none;border-radius:8px}.board.game-over:after{content:"Game Over";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2.5rem;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.5);z-index:10}.board.game-over:before{content:"";position:absolute;inset:0;background:#000000b3;z-index:5}.controls{grid-area:controls;padding:0 32px;display:flex;flex-direction:column;gap:16px}.row{display:flex}.upcoming{width:100%;display:flex;flex-direction:column;gap:20px;padding:14px;background:#00000008;border-radius:12px}.upcoming>div{display:flex;flex-direction:column;align-items:center}.upcoming .row{justify-content:center}.cell{width:36px;aspect-ratio:1;border:2px solid rgba(255,255,255,.1);border-radius:4px;position:relative;overflow:hidden;will-change:transform,opacity}.cell:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.1));pointer-events:none}.cell.hidden{visibility:hidden}.cell.Empty{background-color:#ffffff0d;border-color:#ffffff14}.cell.Ghost{background:linear-gradient(135deg,#ffffff1f,#ffffff14,#ffffff1f);border:2px dashed rgba(255,255,255,.35);box-shadow:inset 0 0 10px #ffffff26,0 0 8px #ffffff1a;animation:ghost-pulse 1.8s ease-in-out infinite;position:relative;overflow:visible}.cell.Ghost:before{content:"";position:absolute;top:50%;left:50%;width:4px;height:4px;background:#fff6;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 6px #fff9}@keyframes ghost-pulse{0%,to{opacity:.4;border-color:#ffffff4d;box-shadow:inset 0 0 10px #ffffff26,0 0 6px #ffffff14}50%{opacity:.7;border-color:#ffffff80;box-shadow:inset 0 0 12px #fff3,0 0 10px #ffffff26}}.cell.I{background-color:#06b6d4;box-shadow:0 0 12px #06b6d44d,inset 0 -2px #0003}.cell.J{background-color:#2563eb;box-shadow:0 0 12px #2563eb4d,inset 0 -2px #0003}.cell.L{background-color:#ea580c;box-shadow:0 0 12px #ea580c4d,inset 0 -2px #0003}.cell.O{background-color:#eab308;box-shadow:0 0 12px #eab3084d,inset 0 -2px #0003}.cell.S{background-color:#16a34a;box-shadow:0 0 12px #16a34a4d,inset 0 -2px #0003}.cell.T{background-color:#ec4899;box-shadow:0 0 12px #ec489966,inset 0 -2px #0003}.cell.Z{background-color:#dc2626;box-shadow:0 0 12px #dc26264d,inset 0 -2px #0003}.high-scores{width:160px;margin-top:24px;padding:16px;background:#ffffff0d;border-radius:8px;box-shadow:0 4px 6px var(--shadow-color);color:#fff}.high-scores h2{color:#fff;margin-top:0;margin-bottom:16px;text-align:center}.high-scores p{color:#fff;text-align:center;opacity:.7}.high-scores-list{list-style-position:inside;padding:0;margin:0}.high-score-item{padding:8px;margin:4px 0;background:#ffffff08;border-radius:4px;text-align:center}.error{color:#ff6b6b;margin-top:10px;text-align:center}@media(max-width:768px){body{padding:12px}.app{grid-template-columns:1fr;grid-template-areas:"title" "game" "controls";padding:12px;gap:16px}h1{font-size:2rem;margin:.75rem 0}h2{font-size:1.25rem;margin:.75rem 0}button{padding:.625rem 1.25rem;font-size:.9375rem;min-height:44px}.board{padding:12px}.cell{width:30px}.controls{width:100%;padding:0}.upcoming{width:100%;padding:10px;gap:14px}.upcoming .cell{width:18px}.high-scores{width:140px;margin-top:20px;padding:12px}}@media(max-width:600px){body{padding:10px}.app{padding:10px;gap:12px}h1{font-size:1.75rem}button{font-size:.875rem}.board{padding:10px}.cell{width:26px}.upcoming{width:100%;gap:12px;padding:8px}.upcoming .cell{width:16px}.high-scores{width:130px}}.controls{padding-bottom:24px}@media(max-width:720px){.game-buttons{margin:16px auto;background:#0000001f;flex-wrap:wrap}.game-buttons button{width:64px;height:64px;font-size:1.25rem;border-radius:12px;padding:0;min-height:64px}}@media(max-width:480px){body,.app{padding:8px}h1{font-size:1.5rem;margin:.5rem 0}.board{padding:8px}.cell{width:24px;border-width:1px}.game-buttons button{width:56px;height:56px;font-size:1.125rem;min-height:56px}.upcoming{width:120px;gap:16px;padding:10px}.high-scores{width:120px;padding:10px}}@media(max-width:900px)and (max-height:500px){body{padding:8px}.app{padding:8px;gap:12px}h1{font-size:1.5rem;margin:.5rem 0}.board{padding:8px}.cell{width:22px}.controls{padding-bottom:12px}.game-buttons button{width:48px;height:48px;font-size:1rem;min-height:48px}}@media(hover:none)and (pointer:coarse){button{-webkit-tap-highlight-color:transparent}button:hover{background-color:var(--primary-color);transform:none}button:active{background-color:#1e40af;transform:scale(.98)}.game-buttons button:active{transform:scale(.95);opacity:.9}.cell{will-change:auto}}
