*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{-webkit-font-smoothing:antialiased;line-height:1.5}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}:root{--primary:#667eea;--primary-dark:#5568d3;--secondary:#764ba2;--success:#48bb78;--danger:#f56565;--warning:#ed8936;--text-dark:#2d3748;--text-light:#718096;--bg-light:#f7fafc;--bg-white:#fff;--border:#e2e8f0;--shadow:0 1px 3px 0 #0000001a, 0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--font-family:-apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-mono:"Courier New", Courier, monospace}body{font-family:var(--font-family);color:var(--text-dark);background-color:var(--bg-light)}#root{flex-direction:column;min-height:100vh;display:flex}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.btn{text-align:center;cursor:pointer;border:none;border-radius:.375rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;text-decoration:none;transition:all .2s;display:inline-block}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);color:#fff}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-secondary{background-color:var(--bg-white);color:var(--primary);border:2px solid var(--primary)}.btn-secondary:hover:not(:disabled){background-color:var(--primary);color:#fff}.card{background-color:var(--bg-white);box-shadow:var(--shadow);border-radius:.5rem;padding:1.5rem}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.form-group{margin-bottom:1rem}.form-label{color:var(--text-dark);margin-bottom:.5rem;font-weight:500;display:block}.form-input{border:1px solid var(--border);border-radius:.375rem;width:100%;padding:.75rem;font-size:1rem;transition:border-color .2s}.form-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #667eea1a}.form-error{color:var(--danger);margin-top:.25rem;font-size:.875rem}@media (width<=768px){.container{padding:0 .75rem}}.error-toast{z-index:9999;animation:.3s ease-out slideIn;position:fixed;top:1rem;right:1rem}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.error-toast-content{background:#fed7d7;border:1px solid #fc8181;border-radius:.5rem;align-items:center;gap:1rem;min-width:300px;max-width:500px;padding:1rem 1.5rem;display:flex;box-shadow:0 4px 12px #00000026}.error-toast-icon{flex-shrink:0;font-size:1.5rem}.error-toast-message{color:#742a2a;flex:1;font-size:.95rem;line-height:1.4}.error-toast-close{color:#742a2a;cursor:pointer;background:0 0;border:none;border-radius:.25rem;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:1.5rem;transition:background .2s;display:flex}.error-toast-close:hover{background:#742a2a1a}.error-toast-close:focus{outline-offset:2px;outline:2px solid #742a2a}@media (width<=768px){.error-toast{inset:auto 1rem 1rem}.error-toast-content{min-width:auto;max-width:none}}.navigation{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);box-shadow:var(--shadow-md);z-index:100;position:sticky;top:0}.nav-container{justify-content:space-between;align-items:center;max-width:1200px;height:64px;margin:0 auto;padding:0 1rem;display:flex}.nav-brand a{color:#fff;letter-spacing:-.5px;font-size:1.5rem;font-weight:700;text-decoration:none}.nav-links{align-items:center;gap:.5rem;display:flex}.nav-link{color:#ffffffe6;cursor:pointer;background:0 0;border:none;border-radius:.375rem;padding:.5rem 1rem;font-size:1rem;font-weight:500;text-decoration:none;transition:all .2s}.nav-link:hover{color:#fff;background-color:#ffffff1a}.nav-link.active{color:#fff;background-color:#fff3}.logout-btn{color:#fffc}.logout-btn:hover{color:#fff;background-color:#ffffff26}.nav-user{color:#fff}.username{background-color:#ffffff1a;border-radius:.375rem;padding:.5rem 1rem;font-weight:500}@media (width<=768px){.nav-container{flex-wrap:wrap;height:auto;padding:.75rem 1rem}.nav-brand{flex:1}.nav-user{order:2}.nav-links{order:3;justify-content:space-between;gap:.25rem;width:100%;margin-top:.75rem}.nav-link{text-align:center;flex:1;padding:.5rem;font-size:.875rem}.username{padding:.375rem .75rem;font-size:.875rem}}.login-container{justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.login-card{width:100%;max-width:400px}.login-card h1{text-align:center;background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .5rem;font-size:2rem}.login-subtitle{text-align:center;color:var(--text-light);margin-bottom:2rem}.login-form{flex-direction:column;gap:1rem;display:flex}.form-input.error{border-color:var(--danger)}.auth-error{border:1px solid var(--danger);color:var(--danger);background-color:#f565651a;border-radius:.375rem;padding:.75rem;font-size:.875rem}.login-form .btn{width:100%;margin-top:.5rem}.login-link{text-align:center;color:var(--text-light);margin-top:1rem}.login-link a{color:var(--primary);font-weight:500;text-decoration:none}.login-link a:hover{text-decoration:underline}.register-container{justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex}.register-card{width:100%;max-width:450px}.register-card h1{text-align:center;background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .5rem;font-size:2rem}.register-subtitle{text-align:center;color:var(--text-light);margin-bottom:2rem}.register-form{flex-direction:column;gap:1rem;display:flex}.form-success{color:var(--success);margin-top:.25rem;font-size:.875rem;display:block}.password-strength{margin-top:.5rem}.strength-bar{background-color:var(--border);border-radius:2px;height:4px;margin-bottom:.25rem;overflow:hidden}.strength-fill{height:100%;transition:width .3s,background-color .3s}.strength-bar.weak .strength-fill{background-color:var(--danger);width:33%}.strength-bar.medium .strength-fill{background-color:var(--warning);width:66%}.strength-bar.strong .strength-fill{background-color:var(--success);width:100%}.strength-text{font-size:.875rem}.strength-text.weak{color:var(--danger)}.strength-text.medium{color:var(--warning)}.strength-text.strong{color:var(--success)}.success-message{border:1px solid var(--success);color:var(--success);text-align:center;background-color:#48bb781a;border-radius:.375rem;padding:1rem;font-weight:500}.register-form .btn{width:100%;margin-top:.5rem}.register-link{text-align:center;color:var(--text-light);margin-top:1rem}.register-link a{color:var(--primary);font-weight:500;text-decoration:none}.register-link a:hover{text-decoration:underline}.dashboard-container{background-color:var(--bg-light);min-height:calc(100vh - 64px);padding:2rem 1rem}.dashboard-content{max-width:1200px;margin:0 auto}.dashboard-header{text-align:center;margin-bottom:2rem}.dashboard-header h1{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0 0 .5rem;font-size:2.5rem}.subtitle{color:var(--text-light);font-size:1.125rem}.new-game-section{text-align:center;margin-bottom:3rem}.btn-large{padding:1rem 3rem;font-size:1.125rem;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem;display:grid}.stat-card{text-align:center;padding:2rem 1.5rem;transition:transform .2s}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.stat-card.highlight{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);color:#fff}.stat-value{margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.stat-card.highlight .stat-value{color:#fff}.stat-label{color:var(--text-light);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem;font-weight:600}.stat-card.highlight .stat-label{color:#ffffffe6}.recent-games-section h2{color:var(--text-dark);margin-bottom:1rem}.game-item:hover{box-shadow:var(--shadow-md);transform:translate(4px)}.game-info{align-items:center;gap:.75rem;display:flex}.badge-win{color:var(--success);border:1px solid var(--success);background-color:#48bb781a}.badge-loss{color:var(--danger);border:1px solid var(--danger);background-color:#f565651a}.badge-draw{color:var(--warning);border:1px solid var(--warning);background-color:#ed89361a}.difficulty-badge{text-transform:uppercase;background-color:var(--bg-light);color:var(--text-light);border:1px solid var(--border);border-radius:.25rem;padding:.25rem .75rem;font-size:.75rem;font-weight:600}.game-date{color:var(--text-light);font-size:.875rem}.view-all{text-align:center;margin-top:1.5rem}.view-all a{color:var(--primary);font-weight:500;text-decoration:none;transition:color .2s}.view-all a:hover{color:var(--primary-dark);text-decoration:underline}.loading-state,.error-state{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:400px;display:flex}.loading-state p,.error-state p{color:var(--text-light);font-size:1.125rem}@media (width<=768px){.dashboard-header h1{font-size:1.75rem}.subtitle{font-size:1rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.stat-card{padding:1.5rem 1rem}.stat-value{font-size:2rem}.game-item{flex-direction:column;align-items:flex-start;gap:.75rem}.game-date{align-self:flex-end}}.game-board{background-color:var(--bg-light);border-radius:.5rem;grid-template-columns:repeat(3,1fr);gap:.75rem;max-width:400px;margin:0 auto;padding:1rem;display:grid}.cell{aspect-ratio:1;background-color:var(--bg-white);border:2px solid var(--border);cursor:pointer;border-radius:.5rem;justify-content:center;align-items:center;padding:0;font-size:3rem;font-weight:700;transition:all .2s;display:flex;position:relative}.cell:not(.occupied):not(.disabled):hover{border-color:var(--primary);box-shadow:var(--shadow-md);background-color:#667eea0d;transform:scale(1.05)}.cell:not(.occupied):not(.disabled):active{transform:scale(.95)}.cell.disabled{cursor:not-allowed;opacity:.6}.cell.occupied{cursor:not-allowed}.cell-value{transition:all .3s cubic-bezier(.68,-.55,.265,1.55);display:block}.cell-x .cell-value{color:var(--primary);animation:.3s ease-out popIn}.cell-o .cell-value{color:var(--secondary);animation:.3s ease-out popIn}.cell.winning{border-color:var(--success);background:linear-gradient(135deg,#48bb7833 0%,#48bb781a 100%);animation:1s ease-in-out infinite pulse}.cell.winning .cell-value{color:var(--success)}@keyframes popIn{0%{opacity:0;transform:scale(0)}50%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #48bb7866}50%{transform:scale(1.02);box-shadow:0 0 0 8px #48bb7800}}@media (width<=768px){.game-board{gap:.5rem;max-width:100%;padding:.75rem}.cell{border-width:2px;font-size:2.5rem}}@media (width<=480px){.game-board{gap:.375rem;padding:.5rem}.cell{font-size:2rem}}@media (hover:none){.cell:not(.occupied):not(.disabled):hover{transform:none}.cell:not(.occupied):not(.disabled):active{background-color:#667eea1a;transform:scale(.98)}}.game-container{background-color:var(--bg-light);min-height:calc(100vh - 64px);padding:2rem 1rem}.game-content{max-width:800px;margin:0 auto}.game-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.game-header h1{background:linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0}.game-status{text-align:center;background-color:var(--bg-white);box-shadow:var(--shadow);border-radius:.5rem;margin-bottom:2rem;padding:1.5rem}.game-status h2{color:var(--text-dark);margin:0;font-size:1.75rem}.game-status.game-over h2{font-size:2rem}.turn-indicator{color:var(--text-light);justify-content:center;align-items:center;gap:1rem;margin-top:1rem;font-size:1rem;display:flex}.turn-indicator span.active{color:var(--primary);font-weight:700}.turn-indicator .vs{opacity:.5}.error-message{border:1px solid var(--danger);color:var(--danger);background-color:#f565651a;border-radius:.375rem;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem 1.5rem;display:flex}.close-btn{color:var(--danger);cursor:pointer;background:0 0;border:none;width:24px;height:24px;padding:0;font-size:1.5rem;line-height:1}.game-setup{max-width:600px;margin:0 auto;padding:2rem}.game-setup h3{text-align:center;color:var(--text-dark);margin-bottom:1.5rem}.difficulty-selector{gap:1rem;margin-bottom:2rem;display:grid}.difficulty-btn{border:2px solid var(--border);background-color:var(--bg-white);cursor:pointer;text-align:left;border-radius:.5rem;padding:1rem 1.5rem;transition:all .2s}.difficulty-btn:hover{border-color:var(--primary);background-color:#667eea0d}.difficulty-btn.selected{border-color:var(--primary);background:linear-gradient(135deg,#667eea1a 0%,#764ba21a 100%)}.difficulty-name{text-transform:capitalize;color:var(--text-dark);margin-bottom:.25rem;font-size:1.125rem;font-weight:700;display:block}.difficulty-desc{color:var(--text-light);font-size:.875rem;display:block}.game-board-section{margin-bottom:2rem;position:relative}.loading-overlay{z-index:10;background-color:#fffc;border-radius:.5rem;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.game-actions{justify-content:center;gap:1rem;margin-bottom:2rem;display:flex}.game-info{text-align:center;background-color:var(--bg-white);box-shadow:var(--shadow);border-radius:.5rem;padding:1rem}.info-item{justify-content:center;gap:.5rem;font-size:1rem;display:flex}.info-item .label{color:var(--text-light)}.info-item .value{color:var(--text-dark);text-transform:capitalize;font-weight:600}@media (width<=768px){.game-header{flex-direction:column;align-items:stretch;gap:1rem}.game-header h1{text-align:center;font-size:1.75rem}.game-status h2{font-size:1.5rem}.game-actions{flex-direction:column}.game-actions button{width:100%}}.profile-container{max-width:1200px;margin:0 auto;padding:2rem}.profile-content{flex-direction:column;gap:2rem;display:flex}.profile-header{align-items:center;gap:2rem;padding:2rem;display:flex}.profile-avatar{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:100px;font-size:3rem;font-weight:700;display:flex}.profile-info h1{color:#2d3748;margin:0 0 .5rem;font-size:2rem}.profile-email{color:#718096;margin:0 0 .5rem;font-size:1rem}.profile-joined{color:#a0aec0;margin:0;font-size:.9rem}.stats-section h2{color:#2d3748;margin:0 0 1.5rem;font-size:1.5rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;display:grid}.stat-card{text-align:center;padding:1.5rem}.stat-icon{margin-bottom:.5rem;font-size:2.5rem}.stat-value{color:#2d3748;margin:.5rem 0;font-size:2.5rem;font-weight:700}.stat-label{color:#718096;text-transform:uppercase;letter-spacing:.05em;font-size:.9rem}.stat-card.highlight{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.stat-card.highlight .stat-value,.stat-card.highlight .stat-label{color:#fff}.game-history-section{margin-top:1rem}.section-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.section-header h2{color:#2d3748;margin:0;font-size:1.5rem}.game-count{color:#718096;font-size:.9rem;font-weight:500}.controls-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:2rem;margin-bottom:1.5rem;display:flex}.filter-group,.sort-group{align-items:center;gap:.75rem;display:flex}.filter-group label,.sort-group label{color:#4a5568;font-size:.9rem;font-weight:500}.filter-btn{cursor:pointer;color:#4a5568;background:#fff;border:1px solid #e2e8f0;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem;transition:all .2s}.filter-btn:hover{background:#f7fafc;border-color:#cbd5e0}.filter-btn.active{color:#fff;background:#667eea;border-color:#667eea}.sort-select{cursor:pointer;color:#4a5568;background:#fff;border:1px solid #e2e8f0;border-radius:.375rem;padding:.5rem 1rem;font-size:.875rem}.sort-select:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.games-timeline{flex-direction:column;gap:2rem;display:flex}.timeline-group{flex-direction:column;gap:1rem;display:flex}.timeline-date{color:#2d3748;border-left:3px solid #667eea;margin:0;padding-left:.5rem;font-size:1.1rem;font-weight:600}.games-list{flex-direction:column;gap:.75rem;display:flex}.game-item{justify-content:space-between;align-items:center;padding:1rem 1.5rem;transition:transform .2s,box-shadow .2s;display:flex}.game-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.game-main{align-items:center;gap:1rem;display:flex}.game-date,.game-time{color:#718096;font-size:.875rem}.result-badge{text-transform:capitalize;border-radius:.375rem;padding:.375rem .75rem;font-size:.875rem;font-weight:500}.badge-win{color:#22543d;background:#c6f6d5}.badge-loss{color:#742a2a;background:#fed7d7}.badge-draw{color:#2d3748;background:#e2e8f0}.difficulty-badge{border-radius:.375rem;padding:.375rem .75rem;font-size:.875rem;font-weight:500}.difficulty-easy{color:#2c5282;background:#bee3f8}.difficulty-medium{color:#78350f;background:#fef3c7}.difficulty-hard{color:#7f1d1d;background:#fecaca}.difficulty-impossible{color:#4c1d95;background:#ddd6fe}.empty-state{text-align:center;color:#718096;padding:3rem 2rem}.empty-state p{margin:0;font-size:1.1rem}.loading-state,.error-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:4rem 2rem;display:flex}.loading-state p,.error-state p{color:#718096;margin-top:1rem;font-size:1.1rem}@media (width<=768px){.profile-container{padding:1rem}.profile-header{text-align:center;flex-direction:column;padding:1.5rem}.profile-avatar{width:80px;height:80px;font-size:2.5rem}.profile-info h1{font-size:1.5rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.stat-icon,.stat-value{font-size:2rem}.controls-bar{flex-direction:column;align-items:stretch}.filter-group,.sort-group{flex-wrap:wrap}.section-header{flex-direction:column;align-items:flex-start;gap:.5rem}.game-item{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1rem}.timeline-date{font-size:1rem}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.filter-btn{flex:1;min-width:70px}}
