html{transition:background-color var(--transition-base)}body,html{background-color:var(--theme-bg-secondary)}body{color:var(--theme-text-primary);font-family:var(--font-family-primary);transition:background-color var(--transition-base),color var(--transition-base)}.app{transition:background-color var(--transition-base)}.app,.game-area,.main-container{background-color:var(--theme-bg-secondary)}.game-area{border-radius:12px;padding:0 20px 20px;transition:background-color var(--transition-base)}.compact-btn{background:var(--theme-bg-primary);border:1px solid var(--theme-border);color:var(--theme-text-primary);transition:all var(--transition-base)}.compact-btn:hover{background:var(--theme-bg-secondary);border-color:var(--color-primary);box-shadow:0 4px 8px #3498db33}.compact-btn.primary{background:linear-gradient(135deg,var(--color-accent-primary),var(--color-accent-secondary));border-color:var(--color-accent-primary);box-shadow:0 2px 4px var(--color-accent-primary-focus);color:var(--color-primary-base)}.compact-btn.primary:hover{background:linear-gradient(135deg,var(--color-accent-tertiary),var(--color-accent-primary));border-color:var(--color-accent-tertiary);box-shadow:0 4px 12px var(--color-accent-primary-focus)}.compact-btn.danger{background:var(--color-danger);border-color:var(--color-danger);color:var(--color-primary-base)}.compact-btn.danger:hover{background:var(--color-danger-dark);border-color:var(--color-danger-dark)}.difficulty-select{appearance:none;background:var(--theme-bg-primary);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;background-size:14px;border:1px solid var(--theme-border);border-radius:5px;color:var(--theme-text-primary);cursor:pointer;font-size:12px;font-weight:500;min-width:100px;padding:6px 28px 6px 12px;transition:all var(--transition-base)}.difficulty-select:disabled{cursor:not-allowed;opacity:.6}.controls-panel{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--theme-bg-primary);border:1px solid var(--theme-border);border-radius:12px;box-shadow:var(--shadow-lg);flex:1 1;height:fit-content;min-width:300px;padding:20px;transition:all var(--transition-slow)}.controls-panel:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-2px)}.header{align-items:center;background:var(--theme-bg-primary);border-bottom:1px solid var(--theme-border);color:var(--theme-text-primary);display:flex;justify-content:space-between;padding:15px 20px;transition:all var(--transition-base)}.header-content{flex:1 1;text-align:center}.header-controls{align-items:center;display:flex;gap:var(--spacing-3)}.settings-button{align-items:center;background:none;border:none;border-radius:var(--border-radius-sm);color:var(--theme-text-secondary);cursor:pointer;display:flex;justify-content:center;padding:8px;position:relative;transition:all .2s ease}.settings-button:hover{background-color:var(--theme-bg-tertiary);color:var(--theme-text-primary);transform:scale(1.05)}.settings-button:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.settings-button:active{transform:scale(.95)}.header h1{font-size:24px;margin:0}.logo-link{color:inherit;cursor:pointer;text-decoration:none;transition:opacity .2s ease}.logo-link:hover{opacity:.8}.section{animation:slideIn .5s ease-out;background:var(--theme-bg-secondary);border-left:4px solid #0000;border:1px solid var(--theme-border-light);border-radius:8px;margin-bottom:25px;padding:16px;transition:all var(--transition-slow)}.section:hover{background:var(--theme-bg-tertiary);border-left-color:var(--color-primary);transform:translateX(4px)}.section h3{border-bottom:2px solid var(--color-primary);color:var(--theme-text-primary);margin:0 0 15px;padding-bottom:8px;position:relative;transition:color var(--transition-base)}.section h3:after{background:linear-gradient(90deg,var(--color-accent-primary),var(--color-accent-tertiary));bottom:-2px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.section:hover h3:after{width:100%}.button-group{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:15px}.btn{background:var(--color-accent-primary);border:none;border-radius:5px;color:var(--color-primary-base);font-size:14px;padding:10px 15px}.btn:hover{background:var(--color-accent-tertiary);transform:translateY(-1px)}.btn:disabled{background:var(--color-disabled-bg);transform:none}.btn.danger{background:var(--color-danger)}.btn.danger:hover{background:var(--color-danger-dark)}.btn.success{background:#27ae60}.btn.success:hover{background:#229954}.voice-controls-enhanced{padding:16px;text-align:center}.mic-button-container{align-items:center;display:flex;flex-direction:column;gap:12px}.mic-button-wrapper{display:inline-block;position:relative}.mic-tooltip{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:var(--theme-bg-primary);border:1px solid var(--theme-border);border-radius:4px;bottom:120%;box-shadow:var(--shadow-lg);color:var(--theme-text-primary);font-size:11px;line-height:1.2;opacity:0;padding:6px 8px;transition:opacity var(--transition-base),visibility var(--transition-base);visibility:hidden;white-space:nowrap;z-index:1000}.mic-tooltip,.mic-tooltip:after{left:50%;position:absolute;transform:translateX(-50%)}.mic-tooltip:after{border:6px solid #0000;border-top:6px solid var(--theme-border);content:"";top:100%}.mic-button-wrapper:hover .mic-tooltip{opacity:1;visibility:visible}.tooltip-content{color:#ecf0f1;font-size:11px}.tooltip-hint{border-top:1px solid #fff3;color:#f39c12;font-size:10px;font-style:italic;margin-top:4px;padding-top:4px;text-align:center}.mic-button{align-items:center;background:var(--theme-bg-primary);border:3px solid;border-radius:50%;box-shadow:var(--shadow-md);cursor:pointer;display:flex;height:100px;justify-content:center;overflow:hidden;position:relative;transition:all var(--transition-base);width:100px}.mic-button:hover{box-shadow:0 6px 16px #00000026;transform:translateY(-2px)}.mic-button:active{box-shadow:0 2px 8px #0003;transform:translateY(0)}.mic-icon{align-items:center;display:flex;font-size:32px;justify-content:center;position:relative;z-index:2}.mic-icon svg{color:inherit;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.mic-indicator{border:2px solid #fff;border-radius:50%;bottom:8px;box-shadow:0 1px 3px #0003;height:16px;position:absolute;right:8px;width:16px}.mic-idle{border-color:#95a5a6;transition:all .3s ease}.mic-idle:hover{border-color:#7f8c8d;box-shadow:0 6px 20px #95a5a64d}.mic-starting{border-color:var(--color-accent-primary);box-shadow:0 0 20px var(--color-accent-primary-focus)}.mic-starting .mic-icon{animation:spin 1s linear infinite}.mic-listening{animation:pulse-ring 1.5s ease-in-out infinite;border-color:var(--color-success);box-shadow:0 0 30px #27ae6099}.mic-listening:before{animation:pulse-ring 1.5s ease-in-out infinite;border:3px solid var(--color-success);border-radius:50%;bottom:-8px;content:"";left:-8px;opacity:0;position:absolute;right:-8px;top:-8px}.mic-listening:after{animation:pulse-ring 1.5s ease-in-out .3s infinite;border:2px solid var(--color-success);border-radius:50%;bottom:-12px;content:"";left:-12px;opacity:0;position:absolute;right:-12px;top:-12px}.mic-paused{animation:glowPulse 2s ease-in-out infinite;border-color:var(--color-warning);box-shadow:0 0 15px #f39c1266}.mic-error{animation:errorShake .6s ease-in-out;border-color:var(--color-danger);box-shadow:0 0 20px #e74c3c80}.mic-status{min-height:60px;text-align:center}.status-text{color:var(--theme-text-primary);font-size:16px;font-weight:600;margin:0 0 4px}.status-description,.status-text{transition:color var(--transition-base)}.status-description{color:var(--theme-text-secondary);font-size:13px;line-height:1.3;margin:0}.permission-error{background:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:8px;margin-top:12px;opacity:.2;padding:12px;text-align:center}.permission-error p{color:var(--color-danger-dark);margin:4px 0}.voice-help{background:var(--theme-bg-tertiary);border:1px solid var(--theme-border);border-radius:8px;color:var(--theme-text-primary);padding:12px;text-align:left;transition:all var(--transition-base)}.voice-help summary{outline:none;-webkit-user-select:none;user-select:none}.voice-help summary:hover{color:var(--color-primary)}.command-list{grid-gap:12px;display:grid;gap:12px;margin-top:8px}.command-category{margin:0}.command-category strong{color:var(--theme-text-primary);font-size:13px}.command-category ul{margin:4px 0 0;padding-left:16px}.command-category li{background:var(--theme-bg-secondary);border:1px solid var(--theme-border-light);border-radius:3px;color:var(--theme-text-secondary);display:inline-block;font-family:var(--font-family-mono);font-size:12px;margin:2px 4px 4px 0;padding:2px 4px;transition:all var(--transition-base)}@keyframes pulse-ring{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.2)}}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-3px)}75%{transform:translateX(3px)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.05)}70%{transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes glowPulse{0%,to{box-shadow:0 0 5px #27ae604d}50%{box-shadow:0 0 20px #27ae6099}}@keyframes errorShake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-3px)}20%,40%,60%,80%{transform:translateX(3px)}}@keyframes successPulse{0%{background-color:#27ae60;transform:scale(1)}50%{background-color:#2ecc71;transform:scale(1.02)}to{background-color:#27ae60;transform:scale(1)}}.voice-controls{text-align:center}.voice-button{border:none;border-radius:50%;cursor:pointer;display:block;font-size:24px;height:80px;margin:0 auto;transition:all .2s ease;width:80px}.voice-button.listening{animation:pulse 1s infinite;background:#e74c3c;color:#fff}.voice-button.idle{background:var(--color-accent-primary);color:var(--color-primary-base)}.status-display{animation:fadeIn .5s ease-out;background:var(--theme-bg-primary);border:1px solid var(--theme-border);border-radius:10px;box-shadow:var(--shadow-md);color:var(--theme-text-primary);margin-bottom:15px;padding:18px;transition:all var(--transition-slow)}.status-display:hover{background:var(--theme-bg-secondary);box-shadow:var(--shadow-lg);transform:translateY(-1px)}.status-display h4{color:var(--theme-text-primary);font-size:16px;margin:0 0 12px;transition:color var(--transition-base)}.status-display:hover h4{color:var(--color-primary)}.status-item{font-size:14px;margin:8px 0;padding:2px 0;transition:all .2s ease}.status-item:hover{color:var(--color-secondary-base);padding-left:6px}.move-history{background:var(--theme-bg-tertiary);border:1px solid var(--theme-border);border-radius:5px;color:var(--theme-text-primary);font-family:var(--font-family-mono);font-size:12px;max-height:200px;overflow-y:auto;padding:10px;transition:all var(--transition-base)}.move-item{border-bottom:1px solid var(--theme-border-light);padding:2px 0}.move-item:last-child{border-bottom:none}.visual-controls{align-items:center;display:flex;gap:15px;margin-bottom:15px}.slider{flex:1 1}.slider input[type=range]{background:var(--theme-border);border-radius:5px;height:5px;outline:none;width:100%}.error-message{animation:errorShake .5s ease-out,slideIn .3s ease-out;background:linear-gradient(135deg,var(--color-danger-light),var(--color-danger));border:1px solid var(--color-danger);border-radius:8px;box-shadow:0 2px 8px #dc354533;color:var(--color-danger-dark);margin-bottom:15px;overflow:hidden;padding:12px 16px;position:relative}.error-message:before{animation:scaleIn .3s ease-out .2s both;background:var(--color-danger);content:"";height:100%;left:0;position:absolute;top:0;width:4px}.success-message{animation:bounceIn .6s ease-out;background:linear-gradient(135deg,var(--color-success-light),var(--color-success));border:1px solid var(--color-success);border-radius:8px;box-shadow:0 2px 8px #27ae6033;color:var(--color-success-dark);margin-bottom:15px;overflow:hidden;padding:12px 16px;position:relative}.success-message:before{animation:scaleIn .3s ease-out .2s both;background:var(--color-success);content:"";height:100%;left:0;position:absolute;top:0;width:4px}.input-group{display:flex;gap:10px;margin-bottom:15px}.input-group input{border:1px solid #ddd;border-radius:4px;flex:1 1;font-size:14px;padding:8px 12px}.input-group input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 2px var(--color-accent-primary-focus);outline:none}.auth-buttons{align-items:center;display:flex;gap:.75rem}.auth-button-link{border:2px solid #0000;border-radius:6px;font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .2s ease}.auth-button-link:not(.primary){background:#0000;border-color:var(--color-accent-secondary);color:var(--color-secondary-base);opacity:.8}.auth-button-link:not(.primary):hover{background:var(--color-neutral-light);border-color:var(--color-accent-secondary);opacity:1}.auth-button-link.primary{background:linear-gradient(135deg,var(--color-accent-primary) 0,var(--color-accent-secondary) 100%);color:var(--color-primary-base)}.auth-button-link.primary:hover{box-shadow:0 4px 12px var(--color-accent-primary-focus);transform:translateY(-1px)}.user-menu{position:relative}.user-menu-trigger{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;gap:.5rem;padding:.5rem;transition:background-color .2s ease}.user-menu-trigger:hover{background:#0000000d}.user-avatar{align-items:center;background:linear-gradient(135deg,var(--color-accent-primary) 0,var(--color-accent-secondary) 100%);border-radius:50%;color:var(--color-primary-base);display:flex;font-size:.875rem;font-weight:600;height:32px;justify-content:center;width:32px}.user-name{font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chevron,.user-name{color:var(--color-secondary-base)}.chevron{opacity:.6;transition:transform .2s ease}.chevron.open{transform:rotate(180deg)}.user-menu-dropdown{animation:dropdownSlide .2s ease-out;background:var(--color-primary-base);border:1px solid var(--color-accent-secondary);border-radius:8px;box-shadow:0 8px 32px #00000026;margin-top:.5rem;min-width:200px;position:absolute;right:0;top:100%;z-index:1000}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.user-info{border-bottom:1px solid var(--color-accent-secondary);padding:1rem}.user-info strong{color:var(--color-secondary-base);display:block;font-weight:600}.user-info small{color:var(--color-secondary-base);font-size:.875rem;opacity:.7}.menu-divider{background:var(--color-accent-secondary);border:none;height:1px;margin:0;opacity:.3}.menu-item{align-items:center;background:none;border:none;color:var(--color-secondary-base);cursor:pointer;display:flex;font-size:.9rem;gap:.75rem;padding:.75rem 1rem;text-align:left;text-decoration:none;transition:background-color .2s ease;width:100%}.menu-item:hover{background:var(--color-neutral-light)}.menu-item:first-of-type{border-top-left-radius:8px;border-top-right-radius:8px}.menu-item:last-of-type{border-bottom-left-radius:8px;border-bottom-right-radius:8px}.menu-item.logout{border-top:1px solid var(--color-accent-secondary);color:var(--color-danger)}.menu-item.logout:hover{background:var(--color-danger);opacity:.1}.menu-item svg{flex-shrink:0}@media (max-width:768px){.auth-buttons{gap:.5rem}.auth-button-link{font-size:.9rem;padding:.4rem .8rem}.user-name{display:none}.user-menu-dropdown{min-width:180px;right:-.5rem}}.loading-container{align-items:center;color:var(--color-secondary-base);display:flex;flex-direction:column;justify-content:center;min-height:200px;opacity:.6}.loading-spinner{border:3px solid var(--color-accent-secondary);border-top-color:var(--color-accent-primary)}.profile-page{padding:16px}.profile-header{gap:12px}.avatar-large,.profile-header{align-items:center;display:flex}.avatar-large{background:var(--theme-surface);border:1px solid var(--theme-border);border-radius:50%;font-weight:600;height:44px;justify-content:center;width:44px}.stats-overview{grid-gap:12px;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.stat-card{background:var(--theme-surface);border:1px solid var(--theme-border);border-radius:8px;gap:10px;padding:12px}.stat-card.primary{border-left:3px solid var(--color-primary)}.stat-card.success{border-left:3px solid var(--color-success)}.stat-card.info{border-left:3px solid var(--color-info)}.stat-card.warning{border-left:3px solid var(--color-warning)}.stat-icon{font-size:18px}.stat-content{line-height:1.1}.stat-value{font-weight:600}.stat-label{color:var(--theme-text-secondary);font-size:12px}.settings-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,minmax(240px,1fr))}.card{background:var(--theme-surface);border:1px solid var(--theme-border);border-radius:8px;padding:12px}.form-label{color:var(--theme-text-secondary);display:block;font-size:12px;margin-bottom:4px}.form-input{background:var(--theme-background);border:1px solid var(--theme-border);border-radius:6px;color:var(--theme-text-primary);padding:8px}.form-hint{color:var(--theme-text-secondary);font-size:12px}.auth-container{align-items:center;background:linear-gradient(135deg,var(--color-accent-primary) 0,var(--color-accent-secondary) 100%);display:flex;justify-content:center;min-height:100vh;padding:2rem}.auth-card{background:var(--color-primary-base);border-radius:12px;box-shadow:0 8px 32px #0000001a;max-width:420px;min-height:500px;padding:2.5rem;position:relative;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-title{color:var(--color-secondary-base);font-size:2rem;font-weight:700;margin-bottom:.5rem;text-align:center}.auth-subtitle{color:var(--color-supportive);font-size:.95rem;margin-bottom:2rem;text-align:center}.auth-error-container{margin-bottom:1rem;min-height:2.5rem}.auth-error{align-items:center;background:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:6px;display:flex;font-size:.9rem;justify-content:space-between;padding:.75rem;position:relative}.auth-error,.auth-error-close{color:var(--color-secondary-base)}.auth-error-close{background:none;border:none;cursor:pointer;font-size:1.2rem;font-weight:700;margin-left:1rem;opacity:.8;padding:0}.auth-error-close:hover{opacity:1}.auth-form{gap:1.5rem}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:var(--color-secondary-base);font-size:.9rem;font-weight:500}.form-group input{background:var(--color-primary-base);border:2px solid var(--color-accent-secondary);border-radius:6px;font-size:1rem;padding:.75rem;transition:border-color .2s ease}.form-group input:focus{border-color:var(--color-accent-primary);box-shadow:0 0 0 3px var(--color-accent-primary-focus);opacity:1;outline:none}.form-group input:disabled{background:var(--color-neutral-light);color:var(--color-disabled);cursor:not-allowed}.field-error{color:var(--color-danger-dark);font-size:.85rem;margin-top:.25rem}.auth-button{background:var(--color-accent-primary);border:none;border-radius:6px;color:var(--color-primary-base);cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:.75rem 1.5rem;transition:all .2s ease}.auth-button:hover:not(:disabled){background:var(--color-accent-primary-hover);box-shadow:0 4px 12px var(--color-accent-primary-focus);transform:translateY(-1px)}.auth-button:active:not(:disabled){transform:translateY(0)}.auth-button:disabled{background:var(--color-disabled-bg);box-shadow:none;color:var(--color-disabled);cursor:not-allowed;transform:none}.auth-button.secondary{background:var(--color-primary-base);border:2px solid var(--color-accent-secondary);box-sizing:border-box;color:var(--color-accent-secondary);display:inline-block;text-align:center;text-decoration:none;width:100%}.auth-button.secondary:hover{background:var(--color-neutral-light);box-shadow:0 4px 12px #48a9a633;transform:translateY(-1px)}.auth-divider{align-items:center;color:var(--color-disabled);display:flex;font-size:.9rem;margin:1.5rem 0}.auth-divider:after,.auth-divider:before{background:var(--color-accent-secondary);content:"";flex:1 1;height:1px;opacity:.3}.auth-divider span{padding:0 1rem}.auth-footer{color:var(--color-secondary-base);font-size:.9rem;margin-top:2rem;opacity:.7;text-align:center}.auth-footer p{margin:.5rem 0}.auth-link{color:var(--color-accent-secondary);font-weight:500;text-decoration:none;transition:color .2s ease}.auth-link:hover{color:var(--color-primary-dark);text-decoration:underline}@media (max-width:480px){.auth-container{padding:1rem}.auth-card{padding:2rem 1.5rem}.auth-title{font-size:1.75rem}.form-group input{font-size:16px}}.game-history{margin:0 auto;max-width:1200px;min-height:100vh;padding:2rem}.game-history-header{align-items:center;border-bottom:2px solid var(--color-accent-secondary);display:flex;justify-content:space-between;margin-bottom:2rem;opacity:.3;padding-bottom:1rem}.game-history-header h2{color:var(--color-secondary-base);font-size:1.875rem;font-weight:700;margin:0}.back-button{align-items:center;border:1px solid var(--color-gray-200);border-radius:6px;color:var(--color-supportive);cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1rem;text-decoration:none;transition:all .2s ease}.back-button,.back-button:hover{background:var(--color-neutral-light)}.back-button:hover{border-color:var(--color-accent-secondary);color:var(--color-secondary-base)}.tab-navigation{background:var(--color-neutral-light);border-radius:8px;display:flex;gap:.5rem;padding:.25rem}.tab-button{align-items:center;background:#0000;border:none;border-radius:6px;color:var(--color-secondary-base);cursor:pointer;display:flex;font-weight:500;gap:.5rem;opacity:.6;padding:.75rem 1rem;transition:all .2s ease}.tab-button:hover{background:var(--color-neutral-light)}.tab-button.active,.tab-button:hover{color:var(--color-secondary-base);opacity:1}.tab-button.active{background:var(--color-primary-base);box-shadow:0 1px 3px #0000001a}.game-list-loading,.statistics-loading{align-items:center;color:#718096;display:flex;flex-direction:column;justify-content:center;min-height:400px}.loading-spinner{border:3px solid #e2e8f0;border-radius:50%;border-top:3px solid var(--color-accent-secondary);height:32px;margin-bottom:1rem;width:32px}.loading-spinner,.mini-spinner{animation:spin 1s linear infinite}.mini-spinner{border:2px solid #e2e8f0;border-radius:50%;border-top-color:currentcolor;height:16px;width:16px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.game-list-error,.statistics-error{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px;text-align:center}.error-icon{font-size:3rem;margin-bottom:1rem}.game-list-error h3,.statistics-error h3{color:#e53e3e;margin:0 0 .5rem}.retry-button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:background .2s ease}.retry-button:hover{background:#5a67d8}.game-list-empty,.statistics-empty{align-items:center;color:#718096;display:flex;flex-direction:column;justify-content:center;min-height:400px;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem}.start-game-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:.75rem 1.5rem;transition:transform .2s ease}.start-game-button:hover{transform:translateY(-1px)}.game-list-filters{align-items:center;background:#f7fafc;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1rem}.filter-group{align-items:center;display:flex;gap:.5rem}.filter-group label{color:#4a5568;font-weight:500}.filter-group select{background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:.5rem}.results-summary{color:#718096;font-size:.875rem}.games-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));margin-bottom:2rem}.game-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000001a;cursor:pointer;padding:1.5rem;transition:all .2s ease}.game-card:hover{border-color:#cbd5e0;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.game-card.loading{cursor:wait;opacity:.7}.game-card-header{justify-content:space-between;margin-bottom:1rem}.game-card-header,.game-result{align-items:center;display:flex}.game-result{gap:.5rem}.result-icon{font-size:1.25rem}.result-text{color:var(--color-text-primary);font-weight:600}.status-badge{border-radius:12px;font-size:.75rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.status-completed{background:var(--color-success-light);color:var(--color-success-dark)}.status-in-progress{background:var(--color-warning-light);color:var(--color-warning-dark)}.status-abandoned{background:var(--color-danger-light);color:var(--color-danger-dark)}.game-card-details{margin-bottom:1rem}.game-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.difficulty{color:var(--color-accent-primary);font-weight:500}.game-meta,.move-count{color:var(--color-text-secondary);font-size:.875rem}.game-meta{align-items:center;display:flex;justify-content:space-between}.game-card-actions{display:flex;gap:.5rem}.action-button{align-items:center;background:var(--color-background);border:1px solid var(--color-border-light);border-radius:6px;color:var(--color-text-primary);cursor:pointer;display:flex;font-size:.875rem;gap:.25rem;padding:.5rem .75rem;transition:all .2s ease}.action-button:hover:not(:disabled){background:var(--color-background-hover);border-color:var(--color-border-default)}.replay-button{flex:1 1}.download-button{flex-shrink:0}.pagination{align-items:center;display:flex;gap:.5rem;justify-content:center;margin-top:2rem}.page-button{background:var(--color-background);border:1px solid var(--color-border-light);border-radius:6px;color:var(--color-text-primary);cursor:pointer;padding:.5rem .75rem;transition:all .2s ease}.page-button:hover:not(:disabled){background:var(--color-background-hover);border-color:var(--color-border-default)}.page-button:disabled{cursor:not-allowed;opacity:.5}.page-button.active{background:var(--color-accent-primary);border-color:var(--color-accent-primary);color:var(--color-background)}.page-numbers{display:flex;gap:.25rem}.replay-layout{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 400px;min-height:600px}.replay-board-container{align-items:center;display:flex;flex-direction:column}.replay-board{margin-bottom:2rem}.replay-controls{display:flex;flex-direction:column;gap:1rem;max-width:600px;width:100%}.navigation-controls{gap:.5rem}.nav-button,.navigation-controls{display:flex;justify-content:center}.nav-button{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#4a5568;cursor:pointer;height:44px;transition:all .2s ease;width:44px}.nav-button:hover:not(:disabled){background:#f7fafc;border-color:#cbd5e0}.nav-button:disabled{cursor:not-allowed;opacity:.5}.play-button{background:#667eea;border-color:#667eea;color:#fff}.play-button:hover:not(:disabled){background:#5a67d8}.play-button.playing{background:#e53e3e;border-color:#e53e3e}.playback-speed{align-items:center;display:flex;gap:.5rem;justify-content:center}.playback-speed label{color:#4a5568;font-weight:500}.playback-speed select{background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:.5rem}.download-pgn-button{align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;color:#4a5568;cursor:pointer;display:flex;gap:.5rem;justify-content:center;padding:.75rem 1rem;transition:all .2s ease}.download-pgn-button:hover{background:#edf2f7;border-color:#cbd5e0}.replay-sidebar{display:flex;flex-direction:column;gap:1.5rem}.current-move-card,.game-info-card,.move-list-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem}.game-info-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.game-info-header h3{color:#2d3748;margin:0}.info-row{align-items:center;border-bottom:1px solid #f7fafc;display:flex;justify-content:space-between;padding:.5rem 0}.info-row:last-child{border-bottom:none}.info-row .label{color:#718096;font-weight:500}.info-row .value{color:#2d3748;font-weight:500}.current-move-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.current-move-header h4{color:#2d3748;margin:0}.player-indicator{font-size:1.5rem}.player-indicator.white{color:#2d3748}.player-indicator.black{color:#4a5568}.move-notation{font-size:1.25rem;margin:1rem 0;text-align:center}.move-annotation{color:#e53e3e;font-weight:600}.move-annotation,.move-detail{margin-top:.5rem;text-align:center}.move-detail{color:#718096;font-size:.875rem}.move-list-card h4{color:#2d3748;margin:0 0 1rem}.move-list{max-height:300px;overflow-y:auto}.move-item{align-items:center;border-radius:6px;cursor:pointer;display:flex;gap:.75rem;padding:.5rem;transition:all .2s ease}.move-item:hover{background:#f7fafc}.move-item.current{background:#667eea;color:#fff}.move-item.starting-position{color:#718096;font-style:italic}.move-item.starting-position.current{background:#667eea;color:#fff}.move-number{color:#718096;font-size:.875rem;min-width:3rem}.move-item.current .move-number{color:#fffc}.move-notation{font-family:Courier New,monospace;font-weight:500}.check-indicator,.checkmate-indicator{color:#e53e3e;font-weight:600;margin-left:auto}.move-item.current .check-indicator,.move-item.current .checkmate-indicator{color:#fed7d7}.move-pair{align-items:center;border-radius:6px;display:flex;font-family:Courier New,monospace;gap:.5rem;padding:.5rem;transition:all .2s ease}.move-pair:hover{background:#f7fafc}.pair-move-number{color:#718096;font-size:.875rem;font-weight:500;min-width:2.5rem}.black-move,.white-move{border-radius:4px;cursor:pointer;font-weight:500;min-width:3rem;padding:.25rem .5rem;text-align:center;transition:all .2s ease}.black-move:hover,.white-move:hover{background:#edf2f7}.white-move.current{background:#667eea;color:#fff}.black-move.current{background:#4a5568;color:#fff}.game-statistics{margin:0 auto;max-width:1000px}.stats-overview{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;gap:1rem;padding:1.5rem}.stat-card.primary{border-left:4px solid #667eea}.stat-card.success{border-left:4px solid #48bb78}.stat-card.info{border-left:4px solid #38b2ac}.stat-card.warning{border-left:4px solid #ed8936}.stat-icon{flex-shrink:0;font-size:2rem}.stat-value{color:#2d3748;font-size:2rem;font-weight:700;line-height:1}.stat-label{color:#718096;font-weight:500;margin-top:.25rem}.stats-details{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.stat-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem}.stat-section h3{color:#2d3748;font-size:1.25rem;margin:0 0 1rem}.results-breakdown{gap:1rem}.result-item,.results-breakdown{display:flex;flex-direction:column}.result-item{gap:.5rem}.result-bar{background:#f7fafc;border-radius:4px;height:8px;overflow:hidden}.result-fill{border-radius:4px;height:100%;transition:width .3s ease}.result-fill.wins{background:#48bb78}.result-fill.losses{background:#e53e3e}.result-fill.draws{background:#718096}.result-info{align-items:center;display:flex;justify-content:space-between}.result-label{color:#4a5568;font-weight:500}.result-value{color:#2d3748;font-weight:600}.difficulty-distribution{display:flex;flex-direction:column;gap:1rem}.difficulty-item{display:flex;flex-direction:column;gap:.5rem}.difficulty-info{align-items:center;display:flex;justify-content:space-between}.difficulty-label{color:#4a5568;font-weight:500}.difficulty-value{color:#718096;font-size:.875rem}.difficulty-bar{background:#f7fafc;border-radius:3px;height:6px;overflow:hidden}.difficulty-fill{background:#667eea;border-radius:3px;height:100%;transition:width .3s ease}.openings-list{display:flex;flex-direction:column;gap:.75rem}.opening-item{background:#f7fafc;border-radius:8px;gap:.75rem;padding:.75rem}.opening-item,.opening-rank{align-items:center;display:flex}.opening-rank{background:#667eea;border-radius:50%;color:#fff;font-size:.875rem;font-weight:600;height:2rem;justify-content:center;width:2rem}.opening-name{color:#2d3748;font-weight:500}.opening-count{color:#718096;font-size:.875rem}.performance-insights{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem}.performance-insights h3{color:#2d3748;font-size:1.25rem;margin:0 0 1rem}.insights-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.insight-item{align-items:center;border-left:4px solid;border-radius:8px;display:flex;gap:.75rem;padding:1rem}.insight-item.positive{background:#f0fff4;border-left-color:#48bb78}.insight-item.neutral{background:#f7fafc;border-left-color:#718096}.insight-icon{flex-shrink:0;font-size:1.5rem}.insight-text{color:#4a5568;font-size:.875rem;line-height:1.4}@media (max-width:768px){.game-history{padding:1rem}.game-history-header{align-items:stretch;flex-direction:column;gap:1rem}.tab-navigation{justify-content:center}.games-grid,.replay-layout{gap:1rem;grid-template-columns:1fr}.replay-sidebar{order:2}.stats-overview{grid-template-columns:repeat(2,1fr)}.insights-grid,.stats-details{grid-template-columns:1fr}}.settings-overlay{animation:fadeIn .2s ease-out;background-color:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.settings-panel{animation:slideInRight .3s ease-out;background-color:var(--theme-bg-primary);box-shadow:-4px 0 20px var(--theme-shadow);display:flex;flex-direction:column;height:100%;max-width:90%;position:fixed;right:0;top:0;width:480px;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}.settings-header{align-items:center;background-color:var(--theme-bg-secondary);border-bottom:1px solid var(--theme-border);display:flex;justify-content:space-between;padding:1.5rem}.settings-header h2{color:var(--theme-text-primary);font-size:1.5rem;margin:0}.close-button{background:none;border:none;border-radius:var(--border-radius-sm);color:var(--theme-text-secondary);cursor:pointer;padding:.5rem;transition:all .2s ease}.close-button:hover{background-color:var(--theme-bg-tertiary);color:var(--theme-text-primary)}.close-button:focus{outline:2px solid var(--color-accent-primary);outline-offset:2px}.settings-body{display:flex;flex:1 1;overflow:hidden}.settings-nav{background-color:var(--theme-bg-tertiary);border-right:1px solid var(--theme-border);padding:1rem 0;width:160px}.nav-item{align-items:center;background:none;border:none;color:var(--theme-text-secondary);cursor:pointer;display:flex;font-size:var(--font-size-base);gap:.75rem;padding:.75rem 1rem;position:relative;transition:all .2s ease;width:100%}.nav-item:hover{background-color:var(--theme-bg-secondary);color:var(--theme-text-primary)}.nav-item.active{background-color:var(--theme-bg-primary);color:var(--color-accent-primary)}.nav-item.active:before{background-color:var(--color-accent-primary);bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.nav-item svg{flex-shrink:0}.settings-main{flex:1 1;overflow-y:auto;padding:2rem}.settings-content h3{color:var(--theme-text-primary);font-size:var(--font-size-lg);margin:0 0 1.5rem}.setting-item{align-items:center;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1.5rem}.setting-item label{cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:.25rem}.setting-label{color:var(--theme-text-primary);font-size:var(--font-size-base);font-weight:500}.setting-description{color:var(--theme-text-tertiary);font-size:var(--font-size-sm)}.setting-item input[type=checkbox]{appearance:none;background-color:var(--theme-bg-tertiary);border:2px solid var(--theme-border);border-radius:12px;cursor:pointer;height:24px;position:relative;transition:all .3s ease;width:44px}.setting-item input[type=checkbox]:after{background-color:var(--color-white);border-radius:50%;content:"";height:16px;left:2px;position:absolute;top:2px;transition:transform .3s ease;width:16px}.setting-item input[type=checkbox]:checked{background-color:var(--color-accent-primary);border-color:var(--color-accent-primary)}.setting-item input[type=checkbox]:checked:after{transform:translateX(20px)}.setting-item input[type=email],.setting-item input[type=text],.setting-item select{background-color:var(--theme-bg-primary);border:1px solid var(--theme-border);border-radius:var(--border-radius-sm);color:var(--theme-text-primary);font-size:var(--font-size-base);min-width:150px;padding:.5rem}.setting-item input[type=email]:focus,.setting-item input[type=text]:focus,.setting-item select:focus{outline:2px solid var(--color-accent-primary);outline-offset:2px}.setting-item input[type=range]{-webkit-appearance:none;background:var(--theme-bg-tertiary);border-radius:2px;flex:0 0 120px;height:4px;outline:none}.setting-item input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--color-accent-primary);border-radius:50%;cursor:pointer;height:16px;width:16px}.setting-item input[type=range]::-moz-range-thumb{background:var(--color-accent-primary);border:none;border-radius:50%;cursor:pointer;height:16px;width:16px}.volume-value{color:var(--theme-text-secondary);flex:0 0 50px;font-size:var(--font-size-sm);text-align:right}.settings-footer{background-color:var(--theme-bg-secondary);border-top:1px solid var(--theme-border);padding:1.5rem}.save-button{background-color:var(--color-accent-primary);border:none;border-radius:var(--border-radius-md);color:var(--color-white);cursor:pointer;font-size:var(--font-size-base);font-weight:600;padding:.75rem;transition:all .2s ease;width:100%}.save-button:hover{background-color:var(--color-accent-primary-hover);box-shadow:0 4px 12px var(--color-accent-primary-focus);transform:translateY(-1px)}.save-button:focus{outline:2px solid var(--color-accent-primary);outline-offset:2px}@media (max-width:767px){.settings-panel{animation:slideInUp .3s ease-out;max-width:100%;width:100%}@keyframes slideInUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.settings-body{flex-direction:column}.settings-nav{border-bottom:1px solid var(--theme-border);border-right:none;display:flex;overflow-x:auto;padding:.5rem;width:100%}.nav-item{flex:0 0 auto;flex-direction:column;font-size:var(--font-size-sm);padding:.5rem}.nav-item.active:before{bottom:0;height:3px;left:0;top:auto;width:100%}.settings-main{padding:1rem}.setting-item{align-items:stretch;flex-direction:column}.setting-item input[type=checkbox]{align-self:flex-end}.setting-item input[type=email],.setting-item input[type=range],.setting-item input[type=text],.setting-item select{width:100%}}@media (prefers-reduced-motion:reduce){.settings-overlay,.settings-panel{animation:none}}.close-button:focus-visible,.nav-item:focus-visible,.save-button:focus-visible{outline:2px solid var(--color-accent-primary);outline-offset:2px}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{background-color:#282c34;color:#fff;padding:20px}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.chess-game-container{display:flex;flex:1 1;flex-direction:column;max-width:100vw;overflow-x:hidden;width:100%}@media (max-width:900px){.chess-game-container{min-height:100vh;min-height:100dvh}}.difficulty-compact{align-items:center;display:flex;gap:12px;margin:10px 0}.difficulty-current{align-items:center;color:var(--color-text-primary);display:flex;font-size:1em;gap:6px}.difficulty-level-badge{background:var(--color-accent-primary);border-radius:12px;color:var(--color-background);font-size:.8em;font-weight:600;min-width:20px;padding:2px 6px;text-align:center}.difficulty-dropdown-compact{background:var(--color-background);border:1px solid var(--color-border-light);border-radius:4px;cursor:pointer;font-size:.9em;min-width:120px;padding:6px 8px;transition:border-color .2s}.difficulty-dropdown-compact:hover:not(:disabled){border-color:var(--color-accent-primary)}.difficulty-dropdown-compact:disabled{background:var(--color-background-disabled);cursor:not-allowed;opacity:.6}.moves-text{background:var(--color-background-light);border:1px solid var(--color-border-light);border-radius:6px;margin-top:15px;max-height:150px;overflow-y:auto;padding:12px}.move-text-content{word-wrap:break-word;color:var(--color-text-primary);font-family:Courier New,monospace;font-size:14px;line-height:1.6}.no-moves{color:var(--color-text-secondary);font-style:italic;margin:20px 0;text-align:center}:root{--color-primary-base:#fff;--color-primary-base-warm:#f2f5f0;--color-secondary-base:#424b54;--color-accent-primary:#48a9a6;--color-accent-secondary:#b7c9a9;--color-accent-tertiary:#2c5f5d;--color-neutral-light:#f9f9f9;--color-accent-primary-hover:#2c5f5d;--color-accent-secondary-hover:#9aac8e;--color-accent-tertiary-hover:#1f4543;--color-accent-primary-focus:#48a9a633;--color-accent-secondary-focus:#b7c9a933;--color-accent-tertiary-focus:#2c5f5d33;--color-disabled:#b7c9a980;--color-disabled-bg:#b7c9a91a;--color-primary:#48a9a6;--color-primary-dark:#3d9391;--color-primary-light:#5fc2bf;--color-secondary:#424b54;--color-secondary-dark:#2e343a;--color-secondary-light:#5a646f;--color-success:#27ae60;--color-success-dark:#229954;--color-success-light:#58d68d;--color-warning:#f39c12;--color-warning-dark:#e67e22;--color-warning-light:#f8c471;--color-danger:#e74c3c;--color-danger-dark:#c0392b;--color-danger-light:#ec7063;--color-check:var(--color-warning);--color-checkmate:var(--color-danger);--color-normal:var(--color-success);--color-speech-inactive:var(--color-supportive);--color-speech-starting:var(--color-accent-secondary);--color-speech-active:var(--color-success);--color-speech-paused:var(--color-warning);--color-speech-error:var(--color-danger);--color-info:#3498db;--color-info-dark:#2980b9;--color-info-light:#85c1e9;--color-white:#fff;--color-gray-50:#fafafa;--color-gray-100:#f5f5f5;--color-gray-200:#eee;--color-gray-300:#e0e0e0;--color-gray-400:#bdbdbd;--color-gray-500:#9e9e9e;--color-gray-600:#757575;--color-gray-700:#616161;--color-gray-800:#424242;--color-gray-900:#212121;--theme-bg-primary:var(--color-primary-base);--theme-bg-secondary:var(--color-neutral-light);--theme-bg-tertiary:var(--color-primary-base-warm);--theme-text-primary:var(--color-secondary-base);--theme-text-secondary:var(--color-gray-700);--theme-text-tertiary:var(--color-supportive);--theme-border:var(--color-gray-200);--theme-border-light:var(--color-gray-100);--theme-shadow:#0000001a;--theme-shadow-light:#0000000d;--font-family-primary:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif;--font-family-mono:"SF Mono","Monaco","Inconsolata","Roboto Mono","Courier New",monospace;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.25;--line-height-normal:1.5;--line-height-relaxed:1.75;--spacing-0:0;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--spacing-20:5rem;--spacing-24:6rem;--radius-none:0;--radius-sm:0.25rem;--radius-base:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-base: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;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--shadow-2xl:0 25px 50px -12px #00000040;--transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms ease;--transition-slower:500ms ease;--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070}html[data-theme=dark]{background-color:#212121;background-color:var(--color-gray-900)}[data-theme=dark]{--color-primary-base:var(--color-secondary-base);--color-secondary-base:#fff;--color-neutral-light:#2a2a2a;--theme-bg-primary:var(--color-secondary-base);--theme-bg-secondary:var(--color-gray-800);--theme-bg-tertiary:var(--color-gray-700);--theme-text-primary:var(--color-primary-base);--theme-text-secondary:var(--color-primary-base-warm);--theme-text-tertiary:var(--color-supportive);--theme-border:var(--color-gray-600);--theme-border-light:var(--color-gray-700);--theme-shadow:#424b544d;--theme-shadow-light:#424b5426;--color-primary:var(--color-accent-secondary);--color-primary-dark:var(--color-accent-secondary-hover);--color-supportive:#b8a5c9}.text-xs{font-size:.75rem;font-size:var(--font-size-xs)}.text-sm{font-size:.875rem;font-size:var(--font-size-sm)}.text-base{font-size:1rem;font-size:var(--font-size-base)}.text-lg{font-size:1.125rem;font-size:var(--font-size-lg)}.text-xl{font-size:1.25rem;font-size:var(--font-size-xl)}.text-2xl{font-size:1.5rem;font-size:var(--font-size-2xl)}.text-3xl{font-size:1.875rem;font-size:var(--font-size-3xl)}.text-4xl{font-size:2.25rem;font-size:var(--font-size-4xl)}.font-light{font-weight:300;font-weight:var(--font-weight-light)}.font-normal{font-weight:400;font-weight:var(--font-weight-normal)}.font-medium{font-weight:500;font-weight:var(--font-weight-medium)}.font-semibold{font-weight:600;font-weight:var(--font-weight-semibold)}.font-bold{font-weight:700;font-weight:var(--font-weight-bold)}.leading-tight{line-height:1.25;line-height:var(--line-height-tight)}.leading-normal{line-height:1.5;line-height:var(--line-height-normal)}.leading-relaxed{line-height:1.75;line-height:var(--line-height-relaxed)}.font-mono{font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,Courier New,monospace;font-family:var(--font-family-mono)}.text-primary{color:#48a9a6;color:var(--color-primary)}.text-secondary{color:#424b54;color:var(--color-secondary)}.text-success{color:#27ae60;color:var(--color-success)}.text-warning{color:#f39c12;color:var(--color-warning)}.text-danger{color:#e74c3c;color:var(--color-danger)}.text-info{color:#3498db;color:var(--color-info)}.text-gray-500{color:#9e9e9e;color:var(--color-gray-500)}.text-gray-600{color:#757575;color:var(--color-gray-600)}.text-gray-700{color:#616161;color:var(--color-gray-700)}.text-gray-800{color:#424242;color:var(--color-gray-800)}.text-gray-900{color:#212121;color:var(--color-gray-900)}.bg-primary{background-color:#48a9a6;background-color:var(--color-primary)}.bg-secondary{background-color:#424b54;background-color:var(--color-secondary)}.bg-success{background-color:#27ae60;background-color:var(--color-success)}.bg-warning{background-color:#f39c12;background-color:var(--color-warning)}.bg-danger{background-color:#e74c3c;background-color:var(--color-danger)}.bg-info{background-color:#3498db;background-color:var(--color-info)}.bg-gray-50{background-color:#fafafa;background-color:var(--color-gray-50)}.bg-gray-100{background-color:#f5f5f5;background-color:var(--color-gray-100)}.bg-gray-200{background-color:#eee;background-color:var(--color-gray-200)}.bg-white{background-color:#fff;background-color:var(--color-white)}.btn{align-items:center;border:1px solid #0000;border-radius:.5rem;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-family:var(--font-family-primary);font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);gap:.5rem;gap:var(--spacing-2);justify-content:center;line-height:1.25;line-height:var(--line-height-tight);overflow:hidden;padding:.75rem 1rem;padding:var(--spacing-3) var(--spacing-4);position:relative;text-decoration:none;transition:all .2s ease;transition:all var(--transition-base);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.btn-primary{background:#48a9a6;background:var(--color-accent-primary);border-color:#48a9a6;border-color:var(--color-accent-primary);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;color:var(--color-primary-base)}.btn-primary:hover:not(:disabled){background:#2c5f5d;background:var(--color-accent-primary-hover);border-color:#2c5f5d;border-color:var(--color-accent-primary-hover);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:focus{box-shadow:0 0 0 3px #48a9a633;box-shadow:0 0 0 3px var(--color-accent-primary-focus)}.btn-secondary{background:#fff;background:var(--color-primary-base);border-color:var(--color-supportive);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#424b54;color:var(--color-secondary-base)}.btn-secondary:hover:not(:disabled){background:#f9f9f9;background:var(--color-neutral-light);border-color:#b7c9a9;border-color:var(--color-accent-secondary);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);color:#b7c9a9;color:var(--color-accent-secondary);transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,#e74c3c,#c0392b);background:linear-gradient(135deg,var(--color-danger),var(--color-danger-dark));border-color:#e74c3c;border-color:var(--color-danger);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;color:var(--color-white)}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,#c0392b,#a93226);background:linear-gradient(135deg,var(--color-danger-dark),#a93226);border-color:#c0392b;border-color:var(--color-danger-dark);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg,#27ae60,#229954);background:linear-gradient(135deg,var(--color-success),var(--color-success-dark));border-color:#27ae60;border-color:var(--color-success);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#fff;color:var(--color-white)}.btn-success:hover:not(:disabled){background:linear-gradient(135deg,#229954,#1e8449);background:linear-gradient(135deg,var(--color-success-dark),#1e8449);border-color:#229954;border-color:var(--color-success-dark);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-sm{border-radius:.375rem;border-radius:var(--radius-base);font-size:.75rem;font-size:var(--font-size-xs);padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3)}.btn-lg{border-radius:.75rem;border-radius:var(--radius-lg);font-size:1rem;font-size:var(--font-size-base);padding:1rem 1.5rem;padding:var(--spacing-4) var(--spacing-6)}.card{background:#fff;background:var(--color-white);border:1px solid #eee;border:1px solid var(--color-gray-200);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-base);overflow:hidden;transition:all .2s ease;transition:all var(--transition-base)}.card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-header{background:#fafafa;background:var(--color-gray-50);border-bottom:1px solid #eee;border-bottom:1px solid var(--color-gray-200);padding:1rem 1.5rem;padding:var(--spacing-4) var(--spacing-6)}.card-body{padding:1.5rem;padding:var(--spacing-6)}.card-footer{background:#fafafa;background:var(--color-gray-50);border-top:1px solid #eee;border-top:1px solid var(--color-gray-200);padding:1rem 1.5rem;padding:var(--spacing-4) var(--spacing-6)}.message{border-left:4px solid;border-radius:.5rem;border-radius:var(--radius-md);margin-bottom:1rem;margin-bottom:var(--spacing-4);padding:1rem;padding:var(--spacing-4);transition:all .2s ease;transition:all var(--transition-base)}.message-success{background:#27ae601a;border-left-color:#27ae60;border-left-color:var(--color-success);color:#229954;color:var(--color-success-dark)}.message-error{background:#e74c3c1a;border-left-color:#e74c3c;border-left-color:var(--color-danger);color:#c0392b;color:var(--color-danger-dark)}.message-warning{background:#f39c121a;border-left-color:#f39c12;border-left-color:var(--color-warning);color:#e67e22;color:var(--color-warning-dark)}.message-info{background:#3498db1a;border-left-color:#3498db;border-left-color:var(--color-info);color:#2980b9;color:var(--color-info-dark)}.form-input{background:#fff;background:var(--color-white);border:1px solid #e0e0e0;border:1px solid var(--color-gray-300);border-radius:.5rem;border-radius:var(--radius-md);color:#212121;color:var(--color-gray-900);display:block;font-size:.875rem;font-size:var(--font-size-sm);line-height:1.5;line-height:var(--line-height-normal);padding:.75rem 1rem;padding:var(--spacing-3) var(--spacing-4);transition:all .15s ease;transition:all var(--transition-fast);width:100%}.form-input:focus{border-color:#48a9a6;border-color:var(--color-primary);box-shadow:0 0 0 3px #3498db1a;outline:none}.form-select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right .75rem center;background-position:right var(--spacing-3) center;background-repeat:no-repeat;background-size:16px;padding-right:2.5rem;padding-right:var(--spacing-10)}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.p-0{padding:0;padding:var(--spacing-0)}.p-1{padding:.25rem;padding:var(--spacing-1)}.p-2{padding:.5rem;padding:var(--spacing-2)}.p-3{padding:.75rem;padding:var(--spacing-3)}.p-4{padding:1rem;padding:var(--spacing-4)}.p-5{padding:1.25rem;padding:var(--spacing-5)}.p-6{padding:1.5rem;padding:var(--spacing-6)}.m-0{margin:0;margin:var(--spacing-0)}.m-1{margin:.25rem;margin:var(--spacing-1)}.m-2{margin:.5rem;margin:var(--spacing-2)}.m-3{margin:.75rem;margin:var(--spacing-3)}.m-4{margin:1rem;margin:var(--spacing-4)}.m-5{margin:1.25rem;margin:var(--spacing-5)}.m-6{margin:1.5rem;margin:var(--spacing-6)}.mb-2{margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.mb-3{margin-bottom:.75rem;margin-bottom:var(--spacing-3)}.mb-4{margin-bottom:1rem;margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:1.5rem;margin-bottom:var(--spacing-6)}.mt-2{margin-top:.5rem;margin-top:var(--spacing-2)}.mt-3{margin-top:.75rem;margin-top:var(--spacing-3)}.mt-4{margin-top:1rem;margin-top:var(--spacing-4)}.mt-6{margin-top:1.5rem;margin-top:var(--spacing-6)}.rounded-none{border-radius:0;border-radius:var(--radius-none)}.rounded-sm{border-radius:.25rem;border-radius:var(--radius-sm)}.rounded{border-radius:.375rem;border-radius:var(--radius-base)}.rounded-md{border-radius:.5rem;border-radius:var(--radius-md)}.rounded-lg{border-radius:.75rem;border-radius:var(--radius-lg)}.rounded-xl{border-radius:1rem;border-radius:var(--radius-xl)}.rounded-full{border-radius:9999px;border-radius:var(--radius-full)}.shadow-none{box-shadow:none}.shadow-sm{box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm)}.shadow{box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow-base)}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl)}.theme-toggle{align-items:center;background:#f9f9f9;background:var(--theme-bg-secondary);border:1px solid #eee;border:1px solid var(--theme-border);border-radius:.5rem;border-radius:var(--radius-md);box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);color:#424b54;color:var(--theme-text-primary);cursor:pointer;display:inline-flex;font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;font-weight:var(--font-weight-medium);gap:.5rem;gap:var(--spacing-2);padding:.5rem .75rem;padding:var(--spacing-2) var(--spacing-3);transition:all .2s ease;transition:all var(--transition-base)}.theme-toggle:hover{background:#f2f5f0;background:var(--theme-bg-tertiary);border-color:#48a9a6;border-color:var(--color-primary);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.theme-toggle:active{box-shadow:0 1px 2px 0 #0000000d;box-shadow:var(--shadow-sm);transform:translateY(0)}.theme-toggle-icon{align-items:center;display:flex;justify-content:center;transition:transform .2s ease;transition:transform var(--transition-base)}.theme-toggle:hover .theme-toggle-icon{transform:rotate(15deg)}.theme-toggle-text{color:#616161;color:var(--theme-text-secondary);font-size:.75rem;font-size:var(--font-size-xs);transition:color .2s ease;transition:color var(--transition-base)}.theme-toggle:hover .theme-toggle-text{color:#424b54;color:var(--theme-text-primary)}.theme-toggle.compact{gap:0;padding:.5rem;padding:var(--spacing-2)}.theme-toggle.compact .theme-toggle-text{display:none}@media (max-width:900px){*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}body{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;overflow-x:hidden}}.mobile-layout{background:var(--theme-bg-secondary);display:flex;flex-direction:column;gap:12px;min-height:100vh;min-height:100dvh;padding:max(8px,env(safe-area-inset-top)) max(8px,env(safe-area-inset-right)) max(8px,env(safe-area-inset-bottom)) max(8px,env(safe-area-inset-left))}.mobile-status-bar{align-items:center;background:var(--theme-bg-primary);border:1px solid var(--theme-border);border-radius:12px;box-shadow:var(--shadow-md);display:flex;justify-content:space-between;padding:12px 16px}.mobile-game-info{display:flex;flex-direction:column;gap:2px}.move-count{color:var(--theme-text-primary);font-size:14px;font-weight:600}.turn-indicator{color:var(--theme-text-secondary);font-size:12px}.mobile-mic-btn{align-items:center;background:var(--theme-bg-primary);border:2px solid var(--color-primary);border-radius:24px;box-shadow:var(--shadow-md);color:var(--color-primary);cursor:pointer;display:flex;height:48px;justify-content:center;transition:all var(--transition-slow);width:48px}.mobile-mic-btn:active{transform:scale(.95)}.mobile-mic-btn.listening{background:var(--color-primary);border-color:var(--color-primary-dark);box-shadow:var(--shadow-lg);color:var(--color-white)}.mobile-mic-btn.disabled{cursor:not-allowed;opacity:.5}.listening-pulse{animation:pulse 2s infinite;border:2px solid #3498db;border-radius:50%;height:100%;position:absolute;width:100%}.mobile-mic-btn{position:relative}.mobile-mic-hint{animation:fadeInUp .3s ease;background:var(--theme-bg-primary);border:1px solid var(--color-primary);border-radius:6px;box-shadow:var(--shadow-md);color:var(--color-primary);font-size:11px;padding:6px 8px;top:-45px;white-space:nowrap;z-index:10}.mobile-mic-hint,.mobile-mic-hint-arrow{left:50%;position:absolute;transform:translateX(-50%)}.mobile-mic-hint-arrow{border-left:5px solid #0000;border-right:5px solid #0000;border-top:5px solid var(--color-primary);bottom:-5px;height:0;width:0}@keyframes fadeInUp{0%{opacity:0;transform:translateX(-50%) translateY(5px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}@keyframes pulse{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.4)}}.mobile-message{border-radius:8px;font-size:14px;font-weight:500;padding:12px 16px}.mobile-message.success{background:#27ae601a;border:1px solid var(--color-success);color:var(--color-success-dark)}.mobile-message.error{background:#e74c3c1a;border:1px solid var(--color-danger);color:var(--color-danger-dark)}.mobile-message.info{background:#3498db1a;border:1px solid var(--color-info);color:var(--color-info-dark)}.mobile-board-container{display:flex;justify-content:center;margin:8px 0;transition:opacity .3s ease}.mobile-board-container.hidden{opacity:.1}.mobile-controls{background:var(--theme-bg-primary);border:1px solid var(--theme-border);border-radius:12px;box-shadow:var(--shadow-md);padding:8px}.mobile-controls-row{display:flex;gap:6px;justify-content:space-between;margin-bottom:6px}.mobile-controls-row:last-child{margin-bottom:0}.mobile-difficulty-container{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0}.mobile-difficulty-label{white-space:nowrap}.mobile-difficulty-label,.mobile-difficulty-select{color:var(--theme-text-primary);font-size:12px;font-weight:500}.mobile-difficulty-select{appearance:none;background:var(--theme-bg-primary);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;background-size:12px;border:1px solid var(--theme-border);border-radius:6px;cursor:pointer;flex:1 1;min-width:100px;padding:8px 24px 8px 6px}.mobile-difficulty-select:disabled{cursor:not-allowed;opacity:.5}.mobile-btn{align-items:center;background:var(--theme-bg-primary);border:1px solid var(--theme-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);color:var(--theme-text-primary);cursor:pointer;display:flex;flex:1 1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-2);justify-content:center;min-height:44px;overflow:hidden;padding:var(--spacing-3) var(--spacing-2);position:relative;touch-action:manipulation}.mobile-btn:active{transform:scale(.98)}.mobile-btn:disabled{cursor:not-allowed;opacity:.5}.mobile-btn.primary{background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));border-color:var(--color-primary);box-shadow:var(--shadow-md);color:var(--color-white)}.mobile-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-dark),var(--color-secondary));border-color:var(--color-primary-dark);transform:translateY(-1px)}.mobile-btn.danger{background:linear-gradient(135deg,var(--color-danger),var(--color-danger-dark));border-color:var(--color-danger);box-shadow:var(--shadow-md);color:var(--color-white)}.mobile-btn.danger:hover:not(:disabled){background:linear-gradient(135deg,var(--color-danger-dark),#a93226);border-color:var(--color-danger-dark);transform:translateY(-1px)}.mobile-history{background:var(--theme-bg-primary);border:1px solid var(--theme-border);border-radius:12px;box-shadow:var(--shadow-md);margin-bottom:20px;padding:12px}.mobile-history-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:8px;padding-bottom:8px}.mobile-history-header span{color:var(--theme-text-primary);font-size:14px;font-weight:600}.mobile-btn-small{align-items:center;background:#fff;border:1px solid #ddd;border-radius:6px;color:#666;cursor:pointer;display:flex;height:32px;justify-content:center;touch-action:manipulation;transition:all .2s ease;width:32px}.mobile-btn-small:active{transform:scale(.95)}.mobile-btn-small:disabled{cursor:not-allowed;opacity:.5}.mobile-history-moves{background:var(--theme-bg-tertiary);border:1px solid var(--theme-border-light);border-radius:6px;color:var(--theme-text-primary);font-family:var(--font-family-mono);font-size:13px;line-height:1.4;max-height:80px;overflow-y:auto;padding:4px 0}@media (max-width:480px){.mobile-layout{gap:8px;padding:max(6px,env(safe-area-inset-top)) max(6px,env(safe-area-inset-right)) max(6px,env(safe-area-inset-bottom)) max(6px,env(safe-area-inset-left))}.mobile-controls-row{gap:6px}.mobile-btn{font-size:12px;min-height:48px}.mobile-board-container{margin:4px 0}}@media (min-width:768px) and (max-width:1024px) and (orientation:landscape){.mobile-layout{flex-direction:row;gap:12px;padding:12px}.mobile-board-container{flex:0 0 auto;margin:0}.mobile-controls-content{display:flex;flex:1 1;flex-direction:column;gap:12px;max-width:300px}}@media (orientation:landscape) and (max-height:500px) and (max-width:767px){.mobile-layout{flex-direction:row;gap:8px;padding:6px}.mobile-board-container{flex:0 0 auto;margin:0}.mobile-controls-sidebar{display:flex;flex:1 1;flex-direction:column;gap:8px;max-width:200px}.mobile-history{margin-bottom:0}.mobile-history-moves{max-height:60px}.mobile-status-bar{height:100%;padding:8px 6px;text-orientation:mixed;width:auto;writing-mode:vertical-rl}}.mobile-speech-recognition{margin-top:8px}.mobile-speech-instructions-container{margin-bottom:8px}.mobile-permission-instructions{animation:slideIn .3s ease;background:var(--theme-bg-primary);border:1px solid var(--color-info);border-radius:8px;margin:8px 0;padding:12px}.mobile-permission-content h4{color:var(--color-info);font-size:14px;margin:0 0 8px}.mobile-permission-content p{color:var(--theme-text-secondary);font-size:12px;margin:4px 0}.mobile-permission-content .warning{color:var(--color-warning);font-weight:500}.mobile-speech-error{background:#e74c3c1a;border:1px solid var(--color-danger);border-radius:6px;margin:4px 0;padding:8px}.mobile-speech-error p{color:var(--color-danger-dark);font-size:12px;margin:4px 0}.mobile-speech-status{color:var(--theme-text-secondary);font-size:11px;margin:4px 0}.mobile-speech-browser{margin:2px 0}.mobile-speech-warning{color:var(--color-warning);margin:2px 0}.mobile-speech-tips{background:#3498db1a;border:1px solid var(--color-info);border-radius:6px;margin:4px 0;padding:8px}.mobile-speech-tips-title{color:var(--color-info-dark);font-size:12px;font-weight:500;margin:0 0 4px}.mobile-speech-tip{color:var(--theme-text-secondary);font-size:11px;margin:2px 0}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mobile-tts-hint{animation:slideInTts .3s ease;background:linear-gradient(135deg,#3498db1a,#4a90e21a);border:1px solid var(--color-info);border-radius:8px;margin:4px 0;padding:8px}.mobile-tts-hint-content{align-items:center;color:var(--color-info-dark);display:flex;font-size:12px;font-weight:500;justify-content:space-between}.mobile-tts-hint-close{background:none;border:none;border-radius:4px;color:var(--color-info);cursor:pointer;font-size:14px;padding:2px 6px;touch-action:manipulation;transition:all .2s ease}.mobile-tts-hint-close:active,.mobile-tts-hint-close:hover{background:#3498db33}@keyframes slideInTts{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mobile-board-container{-webkit-tap-highlight-color:transparent;touch-action:none;user-select:none;-webkit-user-select:none}.mobile-btn-small{min-height:44px;min-width:44px;position:relative}*{-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}.mobile-btn,.mobile-mic-btn{cursor:pointer;touch-action:manipulation;user-select:none;-webkit-user-select:none}.mobile-layout.drag-active{touch-action:none;user-select:none;-webkit-user-select:none}.mobile-layout.drag-active *{pointer-events:none}.mobile-layout.drag-active .mobile-board-container,.mobile-layout.drag-active .mobile-board-container *{pointer-events:auto}@media (-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.mobile-btn svg,.mobile-mic-btn svg{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;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}.app{display:flex;flex-direction:column;min-height:100vh}.main-container{align-items:flex-start;animation:fadeIn .5s ease-out;display:flex;flex-grow:1;gap:40px;margin:0 auto;max-width:1400px;padding:20px;width:100%}.game-area{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:16px;max-width:600px}.sidebar-panel{animation:slideIn .6s cubic-bezier(.4,0,.2,1) .3s both;display:flex;flex:0 0 350px;flex-direction:column;gap:20px}.chess-board-container{animation:scaleIn .6s cubic-bezier(.4,0,.2,1);height:605px;transition:all .4s cubic-bezier(.4,0,.2,1);width:605px}.chess-board-container.hidden{opacity:.1;transform:scale(.98)}.board-controls{align-items:center;animation:slideIn .5s cubic-bezier(.4,0,.2,1) .2s both;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:var(--theme-bg-tertiary);border:1px solid var(--theme-border);border-radius:8px;box-shadow:var(--shadow-md);display:flex;gap:10px;justify-content:space-between;padding:8px 12px;transition:all var(--transition-slow);width:605px}.board-controls:hover{background:var(--theme-bg-secondary);box-shadow:var(--shadow-lg)}.control-group{align-items:center;display:flex;gap:4px}.compact-btn.icon-only{border-radius:6px;height:36px;min-width:36px;padding:8px;width:36px}.compact-btn.icon-only svg{margin:0!important}.compact-btn{align-items:center;background:#fff;border:1px solid #ddd;border-radius:5px;color:#333;cursor:pointer;display:flex;font-size:12px;font-weight:500;justify-content:center;min-width:auto;overflow:hidden;padding:6px 12px;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1);white-space:nowrap}.compact-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.compact-btn:hover:before{left:100%}.compact-btn:hover{background:#f8f9fa;border-color:#007bff;box-shadow:0 4px 8px #007bff33;transform:translateY(-2px) scale(1.02)}.compact-btn.primary{background:linear-gradient(135deg,#007bff,#0056b3);border-color:#007bff;box-shadow:0 2px 4px #007bff4d;color:#fff}.compact-btn.primary:hover{animation:successPulse .6s ease-in-out;background:linear-gradient(135deg,#0056b3,#004085);border-color:#0056b3;box-shadow:0 4px 12px #007bff66}.compact-btn.danger{background:#dc3545;border-color:#dc3545;color:#fff}.compact-btn.danger:hover{background:#c82333;border-color:#c82333}.compact-btn:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.6;transform:none!important}.compact-btn:disabled:hover{background:inherit;border-color:inherit}@media (max-width:1200px){.main-container{gap:20px;padding:15px}.sidebar-panel{flex:0 0 300px}}
/*# sourceMappingURL=main.7469fc22.css.map*/