.chess-drag-layer{position:absolute;top:0;left:0;z-index:100;cursor:pointer;touch-action:none;-webkit-user-select:none;user-select:none}.drag-layer-square{position:absolute;cursor:grab}.drag-layer-square:active{cursor:grabbing}.drag-layer-square.light,.drag-layer-square.dark{background:transparent}.drag-layer-square.selected{background:#64646480!important}.legal-move-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:25%;height:25%;border-radius:50%;background:#00000026;pointer-events:none;z-index:1}.legal-move-indicator.capture{width:85%;height:85%;background:transparent;border:4px solid rgba(0,0,0,.15)}.dragged-piece{position:absolute;background-size:contain;background-repeat:no-repeat;background-position:center;pointer-events:none;z-index:1000;opacity:.9;cursor:grabbing}@media (max-width: 768px){.legal-move-indicator{width:30%;height:30%;background:#0003}.legal-move-indicator.capture{width:90%;height:90%;border-width:5px}}.side-menu-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;z-index:998}.side-menu{position:fixed;top:0;left:-280px;width:280px;height:100vh;background-color:#262421;box-shadow:2px 0 8px #0000004d;transition:left .3s ease-in-out;z-index:999;display:flex;flex-direction:column}.side-menu.open{left:0}.side-menu-content{padding:20px;display:flex;flex-direction:column;gap:10px;overflow-y:auto}.menu-item{background:none;border:none;color:#bababa;padding:12px 16px;text-align:left;font-size:16px;cursor:pointer;border-radius:4px;transition:background-color .2s,color .2s;width:100%}.menu-item:hover{background-color:#363431;color:#fff}.menu-item.logout-button{color:#ff6b6b;margin-top:5px;font-size:14px}.menu-item.logout-button:hover{background-color:#ff6b6b1a}.menu-divider{height:1px;background-color:#363431;margin:10px 0}.menu-user-info{display:flex;flex-direction:column;gap:5px;padding-bottom:10px;border-bottom:1px solid #363431;margin-bottom:10px}.menu-item-text{padding:0 16px;color:#fff;font-size:14px}.menu-group{display:flex;flex-direction:column;gap:5px;margin-top:5px}.menu-group-title{font-size:12px;text-transform:uppercase;color:#666;padding:0 16px;margin-bottom:5px;font-weight:700}.menu-item.sub-item{padding-left:32px;font-size:15px}.menu-item:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.menu-item:disabled:hover{background-color:transparent;color:#bababa}.page-container{position:fixed;top:0;left:0;right:0;bottom:0;background:#f6f8fb;z-index:900;overflow-y:auto;overflow-x:hidden;width:100%;-webkit-overflow-scrolling:touch}.page-header{background:#fff;padding:16px;border-bottom:1px solid #e0e0e0;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:10}.back-button{background:transparent;color:#2196f3;border:none;padding:8px 12px;font-size:16px;cursor:pointer;border-radius:4px}.back-button:hover{background-color:#2196f31a}.page-header h2{margin:0;font-size:20px;color:#333}.page-content{padding:20px;max-width:800px;margin:0 auto}.alert{padding:12px 16px;border-radius:6px;margin-bottom:20px;font-size:14px;line-height:1.5}.alert-error{background-color:#ffebee;color:#c62828;border:1px solid #ef9a9a}.alert-success{background-color:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7}.alert-warning{background-color:#fff3e0;color:#e65100;border:1px solid #ffcc80}.alert-info{background-color:#e3f2fd;color:#1565c0;border:1px solid #90caf9}.login-form{background:#fff;padding:32px;border-radius:8px;box-shadow:0 2px 8px #0000001a;max-width:400px;margin:40px auto 0}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500}.form-group input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:16px;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#2196f3}.form-group select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:16px;background-color:#fff;cursor:pointer;box-sizing:border-box}.success-message-container{max-width:500px;margin:40px auto}.spinner{width:40px;height:40px;margin:20px auto;border:4px solid #f3f3f3;border-top:4px solid #2196f3;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.submit-button{width:100%;padding:12px;background-color:#2196f3;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;margin-top:8px}.submit-button:hover{background-color:#1976d2}.form-footer{margin-top:20px;display:flex;justify-content:space-between}.link{color:#2196f3;text-decoration:none;font-size:14px}.link:hover{text-decoration:underline}.training-plans-container{background:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.description{color:#666;margin-bottom:24px;font-size:14px}.plan-list{display:grid;gap:16px;margin-bottom:32px}.plan-card{padding:20px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s}.plan-card:hover{border-color:#2196f3;box-shadow:0 2px 8px #2196f333}.plan-card.selected{border-color:#2196f3;background-color:#2196f30d}.plan-card h3{margin:0 0 8px;color:#333;font-size:18px}.plan-card p{margin:0;color:#666;font-size:14px}.plan-stats{border-top:1px solid #e0e0e0;padding-top:24px}.plan-stats h3{margin:0 0 16px;color:#333;font-size:18px}.stat-item{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #f0f0f0}.stat-item:last-child{border-bottom:none}.stat-item span{color:#666}.stat-item strong{color:#333;font-weight:600}.stats-container{background:#fff;padding:24px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.stats-section{margin-bottom:32px}.stats-section:last-child{margin-bottom:0}.stats-section h3{margin:0 0 16px;color:#333;font-size:18px;padding-bottom:8px;border-bottom:2px solid #2196f3}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.stat-card{background:#f6f8fb;padding:20px;border-radius:8px;text-align:center}.stat-value{font-size:32px;font-weight:700;color:#2196f3;margin-bottom:8px}.stat-label{font-size:14px;color:#666}.theme-stats{display:flex;flex-direction:column;gap:16px}.theme-stat-item{display:flex;align-items:center;gap:16px}.theme-name{min-width:80px;font-weight:500;color:#333}.theme-progress{flex:1;display:flex;align-items:center;gap:12px}.progress-bar{flex:1;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);transition:width .3s}.theme-numbers{min-width:50px;text-align:right;font-size:14px;color:#666}.rating-progress{padding:16px;background:#f6f8fb;border-radius:8px}.placeholder-text{color:#999;text-align:center;font-style:italic;margin-bottom:16px}.rating-list{display:flex;flex-direction:column;gap:8px}.rating-item{display:flex;justify-content:space-between;padding:8px 12px;background:#fff;border-radius:4px}@media (max-width: 768px){.page-content{padding:16px}.login-form{padding:24px;margin-top:20px}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:24px}.theme-stat-item{flex-direction:column;align-items:stretch;gap:8px}.theme-name{min-width:auto}}@media (max-width: 480px){.page-header{padding:12px}.page-header h2{font-size:18px}.page-content{padding:12px}.login-form,.training-plans-container,.stats-container{padding:16px}.stats-grid{grid-template-columns:1fr;gap:12px}}.section-card{background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000000d;padding:24px;margin-bottom:24px;border:1px solid #f0f0f0}.data-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:16px;font-size:14px}.data-table th{text-align:left;padding:16px;background-color:#f8f9fa;color:#5f6368;font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e0e0e0}.data-table th:first-child{border-top-left-radius:8px}.data-table th:last-child{border-top-right-radius:8px}.data-table td{padding:16px;border-bottom:1px solid #f0f0f0;color:#333;vertical-align:middle;transition:background-color .2s}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background-color:#f8faff}.status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500;line-height:1.4}.status-badge:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:6px}.status-pending{background-color:#fff8e1;color:#f57c00}.status-pending:before{background-color:#f57c00}.status-waiting{background-color:#e3f2fd;color:#1976d2}.status-waiting:before{background-color:#1976d2}.status-active{background-color:#e8f5e9;color:#2e7d32}.status-active:before{background-color:#2e7d32}.action-button{transition:all .2s cubic-bezier(.4,0,.2,1);font-weight:500;letter-spacing:.3px;box-shadow:0 2px 4px #0000001a}.action-button:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.action-button:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.action-button.danger{background-color:#fff!important;color:#d32f2f!important;border:1px solid #ffcdd2!important;box-shadow:none}.action-button.danger:hover{background-color:#ffebee!important;border-color:#d32f2f!important}.empty-state{text-align:center;padding:48px 0;color:#666;background-color:#fafafa;border-radius:8px;border:2px dashed #e0e0e0;margin-top:16px}.empty-state p:first-child{font-size:16px;font-weight:500;color:#333;margin-bottom:8px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #f0f0f0}.section-header h3{margin:0;font-size:18px;color:#202124;font-weight:600;display:flex;align-items:center;gap:8px}.message-cell{max-width:200px;font-size:13px;color:#5f6368;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.date-cell{font-size:13px;color:#5f6368;white-space:nowrap}.user-cell{font-weight:500;color:#202124}.email-cell{color:#5f6368;font-size:13px}.mistakes-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:8px 0}.mistake-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:12px;display:flex;flex-direction:column;gap:12px;transition:transform .2s,box-shadow .2s;align-items:center}.mistake-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.mistake-card-left{display:flex;flex-direction:column;gap:8px;width:100%;align-items:center}.mistake-board{width:100%;max-width:200px;aspect-ratio:1;border-radius:4px;overflow:hidden;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:center;align-items:center;background:#f0f0f0}.mistake-bottom-info{display:flex;flex-direction:column;gap:6px;font-size:13px;color:#333}.info-row{display:flex;justify-content:space-between;align-items:baseline}.theme-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.theme-tag{background:#e3f2fd;color:#1565c0;font-size:11px;padding:2px 6px;border-radius:4px}.mistake-card-right{flex:1;display:flex;flex-direction:column;gap:16px;min-width:0}.detail-block{display:flex;flex-direction:column;gap:6px}.detail-label{font-size:13px;color:#666;font-weight:600}.detail-value{font-family:SF Mono,Roboto Mono,monospace;font-size:14px;color:#333;background:#f8f9fa;padding:8px;border-radius:4px;border:1px solid #e0e0e0;word-break:break-all;line-height:1.4}.detail-value.correct{border-left:4px solid #4caf50;background-color:#f1f8e9}.detail-value.submitted{border-left:4px solid #ff9800;background-color:#fff3e0}@media (max-width: 900px){.mistakes-grid{grid-template-columns:1fr;max-width:500px;margin:0 auto}.mistake-card{flex-direction:column}.mistake-card-left{width:100%;flex-direction:row;align-items:center;gap:16px}.mistake-board{width:120px;height:120px}.mistake-bottom-info{flex:1}}@media (max-width: 480px){.mistakes-grid{gap:12px}.mistake-card{padding:12px}.mistake-card-left{flex-direction:column;align-items:flex-start}.mistake-board{width:100%;aspect-ratio:1;height:auto}}*{box-sizing:border-box}html{-webkit-text-size-adjust:100%;text-size-adjust:100%}body{background:#f6f8fb;color:#111;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;touch-action:manipulation;overflow-x:hidden;width:100%;position:relative}button{background:#2b6ef6;color:#fff;border:none;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:14px}button:disabled{opacity:.5;cursor:not-allowed}input{border:1px solid #ddd;border-radius:6px;padding:8px}.app-container{margin:0;padding:0;width:100%;height:100vh;overflow:hidden;position:relative}.region-title{font-size:16px;font-weight:600;color:#333;margin-bottom:12px;padding-left:8px;border-left:4px solid #2196F3;transition:border-color .3s ease}.region-title:hover{border-color:#1976d2}.user-status-display{display:flex;align-items:center;min-width:44px}.user-info-button{display:flex;align-items:center;gap:6px;padding:6px 12px;background-color:#e3f2fd;border-radius:20px;cursor:pointer;transition:background-color .2s;border:1px solid #2196F3}.user-info-button:hover{background-color:#bbdefb}.login-button{padding:6px 12px;background-color:transparent;color:#666;border:1px solid #ddd;border-radius:20px;cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;gap:6px;transition:all .2s}.login-button:hover{background-color:#f5f5f5;border-color:#2196f3;color:#2196f3}.menu-button:hover,.settings-button:hover{background-color:#0000000d!important;border-radius:4px}.action-buttons{display:flex;gap:8px;margin-top:16px;flex-wrap:wrap;justify-content:center;width:100%}.action-btn{padding:10px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;flex:1;min-width:100px}.action-btn:disabled{opacity:.5;cursor:not-allowed}.load-btn{background-color:#4caf50;color:#fff}.load-btn:hover:not(:disabled){background-color:#45a049}.load-id-btn{background-color:#ff9800;color:#fff}.load-id-btn:hover:not(:disabled){background-color:#fb8c00}.reload-btn{background-color:#9c27b0;color:#fff}.reload-btn:hover:not(:disabled){background-color:#8e24aa}.submit-btn{background-color:#f44336;color:#fff}.submit-btn:hover:not(:disabled){background-color:#e53935}.main-content{display:flex;flex-direction:row;gap:32px;align-items:flex-start;padding:20px 12px;flex:1;overflow-y:auto;max-width:1200px;margin:0 auto}.chessboard-container{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;max-width:90vw;width:auto}.chessboard-wrapper{width:100%;height:100%;touch-action:none;-webkit-user-select:none;user-select:none}.puzzle-info-sidebar{flex-shrink:0;width:auto;min-width:260px;max-width:320px}@media (max-width: 768px){.app-container{flex-direction:column;height:auto;min-height:100vh}.main-content{flex-direction:column;padding:12px 8px;gap:16px}.region-title{font-size:14px;margin-bottom:10px}.app-title{font-size:16px}.user-info-button span:last-child{max-width:80px}.login-button span:last-child{display:inline}.chessboard-container{width:100%;max-width:100%;align-items:center}.chessboard-wrapper{width:100%;max-width:100%}.puzzle-info-sidebar{width:100%;max-width:100%;order:2;border-right:none;padding-right:0}.action-buttons{gap:6px}.action-btn{font-size:13px;padding:8px 12px;min-width:80px}}@media (max-width: 480px){.app-container{padding:0}.top-bar{padding:6px 8px}.menu-button,.settings-button{padding:6px 8px!important;font-size:20px!important}.app-title{font-size:14px;max-width:60%;overflow:hidden;text-overflow:ellipsis}.region-title{font-size:13px;margin-bottom:8px;padding-left:6px;border-left-width:3px}.user-info-button span:last-child{max-width:60px}.login-button{padding:6px 10px;font-size:13px}.login-button span:last-child{display:none}.main-content{padding:8px 4px}.action-buttons{gap:4px;margin-top:12px}.action-btn{font-size:12px;padding:8px 10px;min-width:70px}.main-content{gap:8px;margin-top:8px}.chessboard-container{width:100%;align-items:stretch}.chessboard-wrapper{max-width:100%;width:100%}.puzzle-info-sidebar{margin-left:0;padding:0 8px}.puzzle-info-content{margin-left:0!important;max-width:100%!important}.puzzle-info-sidebar h3{font-size:16px;margin:8px 0}.puzzle-info-sidebar div{font-size:13px;line-height:1.6!important}.puzzle-info-sidebar code{font-size:10px!important;padding:4px!important}.puzzle-settings-display{padding:8px!important;margin-bottom:8px!important;font-size:12px!important}.puzzle-settings-display strong{font-size:12px!important}.puzzle-settings-display span{font-size:11px!important}}@media (max-width: 375px){.app-container{padding:2px}.control-buttons button{font-size:10px;padding:4px 6px}.puzzle-settings-display{padding:6px!important;font-size:11px!important}}.btn-primary{background-color:#2196f3}.btn-success{background-color:#4caf50}.btn-warning{background-color:#ff9800}.btn-purple{background-color:#9c27b0}.btn-danger{background-color:#f44336}.btn-disabled{background-color:#ccc;cursor:not-allowed}.message-container{margin-top:12px}@media (max-width: 480px){.message-container{margin-top:8px}}@keyframes fadeOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-70%) scale(1.5)}}@keyframes slideDown{0%{opacity:0;max-height:0;transform:translateY(-10px)}to{opacity:1;max-height:100px;transform:translateY(0)}}@keyframes shake{0%{transform:translate(1px,1px) rotate(0)}10%{transform:translate(-1px,-2px) rotate(-1deg)}20%{transform:translate(-3px) rotate(1deg)}30%{transform:translate(3px,2px) rotate(0)}40%{transform:translate(1px,-1px) rotate(1deg)}50%{transform:translate(-1px,2px) rotate(-1deg)}60%{transform:translate(-3px,1px) rotate(0)}70%{transform:translate(3px,1px) rotate(-1deg)}80%{transform:translate(-1px,-1px) rotate(1deg)}90%{transform:translate(1px,2px) rotate(0)}to{transform:translate(1px,-2px) rotate(-1deg)}}.shake-animation{animation:shake .5s;animation-iteration-count:infinite}
