body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Arial,sans-serif;min-height:100vh}.App{flex-direction:column}.App,.register-page{display:flex;min-height:100vh}.register-page{align-items:center;justify-content:center}.register-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff0f;border:1px solid #ffffff1f;border-radius:20px;box-shadow:0 20px 40px #0009;color:#e5e7eb;max-width:440px;padding:36px;width:100%}.register-card h2{color:#e5e7eb;margin-bottom:20px;text-align:center}.register-card input{background:#ffffffe6;border:none;border-radius:10px;font-size:1rem;margin-bottom:14px;padding:12px 14px;width:100%}.register-card button{background:#0f6;border:none;border-radius:10px;cursor:pointer;font-weight:700;padding:12px;transition:background .2s ease,transform .1s ease;width:100%}.register-card button:hover{background:#00e65c;transform:translateY(-1px)}.register-card p{color:#cbd5f5;margin-top:15px;text-align:center}.register-card a{color:#38bdf8;text-decoration:none}.register-card a:hover{text-decoration:underline}.register-card .error-message{color:#ff4b5c;margin-bottom:10px;text-align:center}.register-card .success-message{color:#0f9;margin-bottom:10px;text-align:center}.login-page{align-items:center;display:flex;justify-content:center;min-height:100vh}.login-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff0f;border:1px solid #ffffff1f;border-radius:20px;box-shadow:0 20px 40px #0009;color:#e5e7eb;max-width:460px;padding:42px;width:100%}.login-card h2{font-size:2rem;margin-bottom:24px;text-align:center}.login-card input{background:#ffffffe6;font-size:1rem;margin-bottom:16px}.login-card button,.login-card input{border:none;border-radius:10px;padding:14px;width:100%}.login-card button{background:#0f6;cursor:pointer;font-weight:700;transition:background .2s ease,transform .1s ease}.login-card button:hover{background:#00e65c;transform:translateY(-1px)}.login-card .auth-links{margin-top:22px;text-align:center}.login-card a{color:#38bdf8;font-weight:500;text-decoration:none}.login-card a:hover{text-decoration:underline}.login-card .auth-links p{color:#cbd5f5;margin-top:10px}.app-header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#13131bd9;border-bottom:1px solid #ffffff14;box-shadow:0 8px 30px #0009;padding:.4rem 0;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px}.logo{color:#0f6;font-size:1.7rem;font-weight:800;letter-spacing:.5px;text-shadow:0 0 10px #00ff6659}.logo span{color:#e5e7eb;font-weight:600}.user-controls{align-items:center;display:flex;gap:12px}.user-greeting{color:#cbd5e1;font-size:.95rem;opacity:.85}.header-btn{border:none;border-radius:10px;cursor:pointer;font-size:.85rem;font-weight:600;padding:8px 14px;transition:all .2s ease}.logout-btn{background:linear-gradient(135deg,#ff4b5c,#e11d48);color:#fff}.logout-btn:hover{box-shadow:0 6px 15px #ff4b5c66;transform:translateY(-1px)}.profile-btn{background:linear-gradient(135deg,#ffdd57,#facc15);color:#1f2933}.profile-btn:hover{box-shadow:0 6px 15px #facc1566;transform:translateY(-1px)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000d9;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}.modal-content{background:linear-gradient(145deg,#1f2933,#0f172a);border:1px solid #ffffff1f;border-radius:18px;box-shadow:0 25px 50px #000c;max-width:420px;padding:2rem;position:relative;width:90%}.modal-content h3{color:#0f6;margin-bottom:1.2rem;text-align:center}.profile-details{color:#e5e7eb;text-align:center}.profile-avatar{border:4px solid #ffdd57;border-radius:50%;margin-bottom:12px}.profile-details p{margin:6px 0}.close-btn{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:1.6rem;position:absolute;right:16px;top:14px}.close-btn:hover{color:#ff4b5c}body{background:radial-gradient(circle at top,#1f2933,#0f172a);font-family:Segoe UI,sans-serif}.lobby-page{align-items:center;display:flex;justify-content:center;min-height:90vh}.lobby-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff14;border:1px solid #ffffff26;border-radius:20px;box-shadow:0 20px 40px #0006;padding:2.5rem;width:900px}.lobby-title{color:#fff;font-size:2.4rem;text-align:center}.lobby-subtitle{color:#cbd5e1;margin-bottom:2rem;text-align:center}.lobby-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.lobby-section{background:#0f172abf;border:1px solid #ffffff14;border-radius:16px;padding:2rem}.lobby-section h3{color:#e5e7eb;margin-bottom:1rem}.lobby-section input{background:#e5e7eb;font-size:1rem;margin-bottom:1rem}.lobby-section input,.primary-btn{border:none;border-radius:10px;padding:.9rem;width:100%}.primary-btn{background:linear-gradient(135deg,#22c55e,#16a34a);color:#022c22;cursor:pointer;font-weight:700}.secondary-btn{background:#0000;border:2px solid #3b82f6;border-radius:10px;color:#3b82f6;cursor:pointer;padding:.9rem;width:100%}.primary-btn:hover,.secondary-btn:hover{transform:translateY(-2px)}.status-message{margin-bottom:1rem}@media (max-width:768px){.lobby-card{width:95%}.lobby-grid{grid-template-columns:1fr}}.game-container{flex:1 1;position:relative;width:100%}.game-layout{display:flex;gap:30px;height:calc(100vh - 70px);margin:0 auto;max-width:1200px;padding:30px}.game-left{align-items:center;display:flex;flex:0 0 65%;flex-direction:column}.game-right{display:flex;flex:0 0 35%}.game-title{color:#e5e7eb;font-size:1.8rem;margin-bottom:8px;text-align:center}.status-message{color:#38bdf8;margin-bottom:10px;text-align:center}.turn-indicator{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:999px;font-size:.95rem;font-weight:700;left:25px;padding:8px 16px;position:absolute;top:85px}.turn-indicator.your-turn{background:#00ff8826;border:2px solid #0f8;color:#0f8}.turn-indicator.opponent-turn{background:#ff4b5c26;border:2px solid #ff4b5c;color:#ff4b5c}.player-scores{background:#0f172ae6;border:1px solid #00ff9959;border-radius:14px;box-shadow:0 0 14px #0f93;display:flex;gap:18px;justify-content:space-between;margin:12px 0;padding:10px 16px}.score-item{align-items:center;display:flex;flex-direction:column;min-width:70px}.score-label{color:#9ca3af;font-size:.75rem;letter-spacing:.3px;margin-bottom:2px}.score-value{font-size:1.3rem;font-weight:700;line-height:1}.score-win .score-value{color:#0f9}.score-loss .score-value{color:#ff4b5c}.score-draw .score-value{color:gold}.board{grid-gap:8px;background:#ffffff14;border:2px solid #3b82f6;border-radius:18px;box-shadow:0 0 25px #3b82f680;display:grid;gap:8px;grid-template-columns:repeat(3,120px);grid-template-rows:repeat(3,120px);padding:12px}.cell{align-items:center;background:#ffffffe6;border-radius:14px;cursor:pointer;display:flex;font-size:3rem;font-weight:700;justify-content:center;transition:transform .15s ease,box-shadow .15s ease}.cell:hover{box-shadow:0 6px 15px #0003;transform:scale(1.05)}.cell.X{color:#3b82f6}.cell.O{color:#ef4444}.chat-container{background:#1e293bbf;border:1px solid #ffffff26;border-radius:18px;box-shadow:0 16px 35px #00000080;display:flex;flex:1 1;flex-direction:column;overflow:hidden}.chat-container h3{background:#ffffff08;color:#e5e7eb;padding:12px;text-align:center}.messages-display{background:#ffffff0a;flex:1 1;overflow-y:auto;padding:15px}.message-item{border-radius:14px;display:flex;flex-direction:column;font-size:.9rem;gap:4px;margin-bottom:10px;max-width:70%;padding:10px 14px}.message-item .timestamp{align-self:flex-end;font-size:.65rem;opacity:.6}.my-message{background:#dcf8c6;color:#111827;margin-left:auto}.opponent-message{background:#fffffff2;color:#111827}.message-input-form{background:#fff;display:flex;gap:8px;padding:10px}.message-input-form input{border:1px solid #ccc;border-radius:8px;flex:1 1;padding:10px}.message-input-form button{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;padding:10px 18px}.game-over-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000a6;display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}.game-over-modal{animation:popIn .35s ease;background:#1e293be6;border:1px solid #ffffff2e;border-radius:22px;box-shadow:0 25px 60px #000000b3;color:#e5e7eb;max-width:420px;padding:32px 36px;text-align:center;width:100%}.game-over-modal h2{font-size:2rem;margin-bottom:12px}.winner-text{color:#0f9}.loser-text,.winner-text{font-size:1.5rem;margin-bottom:10px}.loser-text{color:#ff4b5c}.draw-text{color:gold;font-size:1.5rem;margin-bottom:10px}.game-over-modal p{color:#cbd5f5;font-size:1rem;margin-top:10px}.modal-actions{display:flex;flex-direction:column;gap:14px;margin-top:22px}.rematch-btn{background:#0f6;border:none;border-radius:12px;color:#0f172a;cursor:pointer;font-size:1rem;font-weight:700;padding:12px;transition:background .2s ease,transform .1s ease}.rematch-btn:hover{background:#00e65c;transform:translateY(-1px)}.rematch-btn:disabled{cursor:not-allowed;opacity:.6}.lobby-btn{background:#38bdf8;border:none;border-radius:12px;color:#0f172a;cursor:pointer;font-size:1rem;font-weight:700;padding:12px;transition:background .2s ease,transform .1s ease}.lobby-btn:hover{background:#0ea5e9;transform:translateY(-1px)}.rematch-message{color:#94a3b8;font-size:.9rem;margin-top:14px}@keyframes popIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
/*# sourceMappingURL=main.156f81c6.css.map*/