:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000001a;padding:40px;width:100%;max-width:400px}.auth-card h2{margin:0 0 30px;color:#333;font-size:28px;font-weight:600;text-align:center}.form-group input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s,box-shadow .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input.error{border-color:#e74c3c}.form-group input.error:focus{border-color:#e74c3c;box-shadow:0 0 0 3px #e74c3c1a}.error-message{display:block;color:#e74c3c;font-size:12px;margin-top:6px}.global-error{margin-top:0;margin-bottom:16px;padding:12px;background-color:#fee;border:1px solid #e74c3c;border-radius:6px;font-size:14px}.auth-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:10px}.auth-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.auth-button:active{transform:translateY(0)}.auth-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-button:disabled:hover{transform:none;box-shadow:none}.auth-switch{text-align:center;margin-top:24px;color:#666;font-size:14px}.link-button{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;font-weight:600;padding:0;text-decoration:underline;transition:color .2s}.link-button:hover{color:#764ba2}@media(prefers-color-scheme:dark){.auth-card{background:#1a1a1a}.auth-card h2{color:#fff}.form-group label{color:#e0e0e0}.form-group input{background:#2a2a2a;border-color:#404040;color:#fff}.form-group input:focus{border-color:#667eea}.auth-switch{color:#b0b0b0}}.home-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column}.home-header{background:#fffffff2;padding:20px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.home-header h1{margin:0;color:#333;font-size:28px;font-weight:600}.logout-button{padding:10px 20px;background:#e74c3c;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.logout-button:hover{background:#c0392b}.home-main{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;gap:40px}.home-navigation{display:flex;gap:20px;margin-bottom:20px}.nav-button{padding:15px 40px;font-size:18px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:transform .2s,box-shadow .2s;color:#fff;min-width:150px}.courses-button{background:linear-gradient(135deg,#667eea,#764ba2)}.courses-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.puzzles-button{background:linear-gradient(135deg,#f093fb,#f5576c)}.puzzles-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f5576c66}.nav-button:active{transform:translateY(0)}.chessboard-container{background:#fff;border-radius:12px;padding:30px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;align-items:center;gap:20px}.game-controls{display:flex;flex-direction:column;align-items:center;gap:15px;width:100%}.game-status{text-align:center;color:#333}.game-status p{margin:5px 0;font-size:14px}.game-status strong{color:#667eea}@media(max-width:768px){.home-header{padding:15px 20px}.home-header h1{font-size:22px}.chessboard-container{padding:20px}.chessboard-wrapper{width:100%;max-width:100%}.chessboard-wrapper>div{width:100%!important;max-width:100%!important}}.courses-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.courses-header{background:#fffffff2;padding:20px 40px;border-radius:12px;margin-bottom:20px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.courses-header h1{margin:0;color:#333;font-size:28px;font-weight:600}.create-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.create-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.create-button:active{transform:translateY(0)}.courses-content{background:#fff;border-radius:12px;padding:30px;box-shadow:0 10px 40px #0003}.search-container{margin-bottom:20px;display:flex;flex-direction:column;gap:10px}.search-input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;width:100%;box-sizing:border-box;transition:border-color .3s,box-shadow .3s}.search-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.results-count{color:#666;font-size:14px}.table-container{overflow-x:auto;margin-bottom:20px}.courses-table{width:100%;border-collapse:collapse;font-size:14px}.courses-table thead{background:#f5f5f5}.courses-table th{padding:12px 16px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;white-space:nowrap}.courses-table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;color:#555}.courses-table tbody tr:hover{background:#f9f9f9}.courses-table tbody tr:last-child td{border-bottom:none}.no-results{text-align:center;padding:40px!important;color:#999;font-style:italic}.loading,.error-message{text-align:center;padding:40px;background:#fff;border-radius:12px;color:#333;font-size:16px}.retry-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.retry-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.pagination-container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px;padding-top:20px;border-top:1px solid #e0e0e0}.pagination-info{color:#666;font-size:14px}.pagination-buttons{display:flex;gap:10px}.pagination-button{padding:8px 16px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;color:#333;cursor:pointer;transition:background-color .2s,border-color .2s}.pagination-button:hover:not(:disabled){background:#e9e9e9;border-color:#d0d0d0}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.page-size-selector{display:flex;align-items:center;gap:8px}.page-size-selector label{color:#666;font-size:14px}.page-size-select{padding:6px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px;color:#333;cursor:pointer;background:#fff}.page-size-select option{color:#333;background:#fff}.page-size-select:focus{outline:none;border-color:#667eea}.edit-button{padding:6px 12px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.edit-button:hover{background:#5568d3}@media(max-width:768px){.courses-container{padding:10px}.courses-content{padding:15px}.courses-table{font-size:12px}.courses-table th,.courses-table td{padding:8px 12px}.pagination-container{flex-direction:column;align-items:stretch}.pagination-buttons{justify-content:center}}.new-course-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.new-course-header{background:#fffffff2;padding:20px 40px;border-radius:12px;margin-bottom:20px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.new-course-header h1{margin:0;color:#333;font-size:28px;font-weight:600}.new-course-content{background:#fff;border-radius:12px;padding:30px;box-shadow:0 10px 40px #0003;max-width:900px;margin:0 auto}.section-header-actions{display:flex;gap:10px;align-items:center}.item-row{display:grid;grid-template-columns:auto 1fr 1fr auto;gap:10px;margin-bottom:10px;align-items:end;cursor:move;-webkit-user-select:none;user-select:none;position:relative;padding:10px;border-radius:6px;transition:background-color .2s}.item-row:hover{background-color:#f9f9f9}.item-row.dragging{opacity:.5}.item-drag-handle{cursor:grab;color:#999;font-size:18px;margin-right:8px;-webkit-user-select:none;user-select:none;display:flex;align-items:center;padding:0 4px}.item-drag-handle:active{cursor:grabbing}.item-actions{display:flex;gap:8px;align-items:center}.item-field{display:flex;flex-direction:column}.item-field label{margin-bottom:6px;color:#555;font-weight:500;font-size:12px}.item-input{padding:10px 12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;transition:border-color .3s,box-shadow .3s}.item-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.edit-item-button{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.edit-item-button:hover{background:#5568d3}@media(max-width:768px){.new-course-container{padding:10px}.new-course-content{padding:20px}.form-row{grid-template-columns:1fr}.item-row{grid-template-columns:1fr;gap:15px}.item-field{width:100%}.item-actions{justify-content:flex-start}.section-header{flex-direction:column;align-items:flex-start;gap:15px}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}.puzzle-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.puzzle-header{background:#fffffff2;padding:20px 40px;border-radius:12px;margin-bottom:20px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.puzzle-header h1{margin:0;color:#333;font-size:28px;font-weight:600}.back-button{padding:10px 20px;background:#6c757d;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.back-button:hover{background:#5a6268}.puzzle-main{padding:20px}.puzzle-content{display:grid;grid-template-columns:1fr 350px;gap:20px;max-width:1400px;margin:0 auto}.puzzle-board-section{background:#fff;border-radius:12px;padding:30px;box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;align-items:center;gap:20px}.chessboard-wrapper{display:flex;justify-content:center}.chessboard-wrapper>div{width:480px!important;height:480px!important}.puzzle-container div[style*="position: fixed"] img,.puzzle-container div[style*="position: fixed"] svg,body div[style*="position: fixed"] img,body div[style*="position: fixed"] svg{width:60px!important;height:60px!important;max-width:60px!important;max-height:60px!important;min-width:60px!important;min-height:60px!important;opacity:.9!important;transform:none!important;object-fit:contain!important;box-sizing:border-box!important}.puzzle-container div[style*="position: fixed"],body div[style*="position: fixed"]{width:60px!important;height:60px!important;max-width:60px!important;max-height:60px!important}.puzzle-moves{width:100%;margin-top:20px}.puzzle-moves h3{margin:0 0 15px;color:#333;font-size:18px;font-weight:600}.moves-list{display:flex;flex-wrap:wrap;gap:8px;padding:15px;background:#f5f5f5;border-radius:8px;font-family:Courier New,monospace;font-size:14px}.move-item{padding:6px 10px;background:#fff;border-radius:4px;color:#333}.no-moves{color:#999;font-style:italic}.puzzle-info-section{display:flex;flex-direction:column}.puzzle-info-card{background:#fff;border-radius:12px;padding:30px;box-shadow:0 10px 40px #0003;position:sticky;top:20px}.puzzle-info-card h3{margin:0 0 20px;color:#333;font-size:20px;font-weight:600}.info-item{margin-bottom:20px;color:#555;font-size:14px}.info-item strong{display:block;color:#667eea;margin-bottom:5px;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.themes-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.theme-tag{padding:4px 10px;background:#e8eaf6;color:#667eea;border-radius:12px;font-size:12px;font-weight:500}.fen-display{margin-top:8px;padding:10px;background:#f5f5f5;border-radius:6px;font-family:Courier New,monospace;font-size:12px;word-break:break-all;color:#333}.reset-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.reset-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.reset-button:active{transform:translateY(0)}.loading,.error-message{text-align:center;padding:40px;background:#fff;border-radius:12px;color:#333;font-size:16px;margin:20px}.error-message{color:#e74c3c;margin-bottom:20px}@media(max-width:1024px){.puzzle-content{grid-template-columns:1fr}.puzzle-info-card{position:static}}@media(max-width:768px){.puzzle-container{padding:10px}.puzzle-header{padding:15px 20px;flex-direction:column;gap:15px;align-items:stretch}.puzzle-header h1{font-size:22px}.puzzle-board-section{padding:20px}.chessboard-wrapper>div{width:100%!important;max-width:100%!important;height:auto!important;aspect-ratio:1}.puzzle-info-card{padding:20px}}.new-lesson-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;box-sizing:border-box;overflow-x:hidden}.new-lesson-header{background:#fffffff2;padding:20px 40px;border-radius:12px;margin-bottom:20px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.new-lesson-header h1{margin:0;color:#333;font-size:28px;font-weight:600}.new-lesson-content{background:#fff;border-radius:12px;padding:30px;box-shadow:0 10px 40px #0003;max-width:100%;width:100%;margin:0 auto;box-sizing:border-box;overflow-x:hidden}.form-section{margin-bottom:40px;padding-bottom:30px;border-bottom:1px solid #e0e0e0}.form-section:last-of-type{border-bottom:none}.form-section h2{margin:0 0 20px;color:#333;font-size:20px;font-weight:600}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h2{margin:0}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500;font-size:14px}.form-group input,.form-group select{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s,box-shadow .3s;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.tags-container{display:flex;flex-wrap:wrap;gap:10px;padding:12px;border:2px solid #e0e0e0;border-radius:8px;min-height:60px}.tag-checkbox{display:flex;align-items:center;cursor:pointer;padding:6px 12px;background:#f5f5f5;border-radius:6px;transition:background-color .2s}.tag-checkbox:hover{background:#e9e9e9}.tag-checkbox input{margin-right:6px;cursor:pointer}.tag-checkbox input[type=checkbox]{width:auto;margin-right:8px}.prompt-item{display:flex;gap:10px;margin-bottom:10px;align-items:center}.prompt-input{flex:1;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s,box-shadow .3s}.prompt-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.move-card{border:2px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:20px;background:#f9f9f9}.move-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.move-header h4{margin:0;color:#333;font-size:16px;font-weight:600}.move-content{display:flex;flex-direction:column;gap:15px}.move-prompts{margin-top:10px;padding-top:15px;border-top:1px solid #e0e0e0}.prompt-item-small{display:flex;gap:8px;margin-bottom:8px;align-items:center}.prompt-input-small{flex:1;padding:8px 12px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px}.prompt-input-small:focus{outline:none;border-color:#667eea}.add-button{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.add-button:hover{background:#5568d3}.add-button-small{padding:6px 12px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .2s}.add-button-small:hover{background:#5568d3}.remove-button{padding:8px 16px;background:#e74c3c;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;white-space:nowrap}.remove-button:hover:not(:disabled){background:#c0392b}.remove-button:disabled{opacity:.5;cursor:not-allowed}.remove-button-small{padding:4px 10px;background:#e74c3c;color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:700;cursor:pointer;transition:background-color .2s;line-height:1;min-width:28px}.remove-button-small:hover{background:#c0392b}.form-actions{display:flex;justify-content:flex-end;gap:15px;padding-top:30px;border-top:1px solid #e0e0e0;margin-top:30px}.submit-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.submit-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.cancel-button{padding:12px 24px;background:#f5f5f5;color:#333;border:1px solid #e0e0e0;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.cancel-button:hover{background:#e9e9e9}.error-message{padding:12px 16px;background:#fee;border:1px solid #e74c3c;border-radius:8px;color:#e74c3c;margin-bottom:20px;font-size:14px}.loading{text-align:center;padding:40px;background:#fff;border-radius:12px;color:#333;font-size:16px}.board-setup-container{display:flex;flex-direction:row;gap:30px;padding:20px;border:2px solid #e0e0e0;border-radius:8px;background:#f9f9f9;align-items:flex-start;box-sizing:border-box;overflow-x:hidden;width:100%}.board-setup-board{flex-shrink:0;display:flex;justify-content:center;padding:20px;background:#fff;border-radius:8px}.board-setup-board>div{width:min(70vh,50vw)!important;height:min(70vh,50vw)!important;max-width:70vh!important;max-height:70vh!important}.board-setup-board [data-piece]{cursor:grab}.board-setup-board [data-piece]:active{cursor:grabbing}.new-lesson-container div[style*="position: fixed"] img,.new-lesson-container div[style*="position: fixed"] svg,body div[style*="position: fixed"] img,body div[style*="position: fixed"] svg{width:60px!important;height:60px!important;max-width:60px!important;max-height:60px!important;min-width:60px!important;min-height:60px!important;opacity:.9!important;transform:none!important;object-fit:contain!important;box-sizing:border-box!important}.new-lesson-container div[style*="position: fixed"],body div[style*="position: fixed"]{width:60px!important;height:60px!important;max-width:60px!important;max-height:60px!important}div[style*=z-index][style*="position: fixed"] img,div[style*=z-index][style*="position: fixed"] svg{width:60px!important;height:60px!important;max-width:60px!important;max-height:60px!important}.board-setup-controls{flex:1;display:flex;flex-direction:column;gap:20px;min-width:0;max-width:100%;overflow-x:hidden}.piece-selector{display:flex;flex-direction:column;gap:10px}.piece-selector label{font-weight:600;color:#333}.piece-buttons{display:flex;flex-wrap:wrap;gap:8px}.piece-button{padding:8px 16px;background:#f5f5f5;border:2px solid #e0e0e0;color:#000;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.piece-button:hover{background:#e9e9e9;border-color:#667eea}.piece-button.active{background:#667eea;color:#fff;border-color:#667eea}.color-selector{display:flex;gap:20px;align-items:center}.color-selector label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:500}.color-selector input[type=checkbox]{width:18px;height:18px;cursor:pointer}.clear-board-button{padding:10px 20px;background:#e74c3c;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s;align-self:flex-start}.clear-board-button:hover{background:#c0392b}.fen-display-section{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.fen-display-section label{font-weight:600;color:#333}.fen-input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;background:#fff;color:#333;font-family:Courier New,monospace;transition:border-color .3s,box-shadow .3s}.fen-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.fen-input-error{border-color:#e74c3c;background:#fff5f5}.fen-input-error:focus{border-color:#e74c3c;box-shadow:0 0 0 3px #e74c3c1a}.fen-error-message{color:#e74c3c;font-size:12px;margin-top:4px;font-weight:500}.add-move-section{margin-top:20px;padding:15px;background:#fff;border:2px solid #e0e0e0;border-radius:8px}.add-move-section h3{margin:0 0 15px;color:#333;font-size:16px;font-weight:600}.move-type-selector{display:flex;gap:10px;margin-bottom:15px}.move-type-button{flex:1;padding:10px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.move-type-button:hover{background:#5568d3}.move-instructions{padding:10px;background:#f5f5f5;border-radius:6px;font-size:13px;color:#555}.move-instructions p{margin:0 0 10px}.move-status{color:#667eea;font-weight:500}.add-opponent-move-button{padding:8px 16px;background:#f39c12;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s;margin-right:10px}.add-opponent-move-button:hover{background:#e67e22}.cancel-move-button{padding:8px 16px;background:#95a5a6;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s}.cancel-move-button:hover{background:#7f8c8d}.move-type-button:disabled{opacity:.5;cursor:not-allowed}.move-hint{font-size:12px;color:#666;margin-top:5px}.move-prompts-section{margin-top:15px;padding:10px;background:#f9f9f9;border-radius:6px}.move-prompts-section label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:13px}.move-prompt-input-row-small{display:flex;gap:6px;margin-bottom:6px;align-items:center}.move-prompt-input-small{flex:1;padding:6px 10px;border:1px solid #e0e0e0;border-radius:4px;font-size:12px}.move-prompt-input-small:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.add-prompt-button-small{width:24px;height:24px;background:#27ae60;color:#fff;border:none;border-radius:4px;font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;padding:0}.add-prompt-button-small:hover{background:#229954}.remove-prompt-button-small{width:24px;height:24px;background:#e74c3c;color:#fff;border:none;border-radius:4px;font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;padding:0}.remove-prompt-button-small:hover{background:#c0392b}.prompts-indicator{padding:2px 6px;background:#667eea;color:#fff;border-radius:4px;font-size:11px;font-weight:500}.move-prompts-hover{position:absolute;bottom:100%;left:0;right:0;background:#333;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;opacity:0;pointer-events:none;transition:opacity .2s;z-index:10;margin-bottom:5px}.move-item{position:relative}.move-item:hover .move-prompts-hover{opacity:1}.opponent-move-prompt{margin-top:15px;padding:15px;background:#fff9e6;border:2px solid #f39c12;border-radius:8px}.opponent-move-title{margin:0 0 10px;font-weight:600;color:#333;font-size:14px}.opponent-move-actions{display:flex;gap:10px;flex-wrap:wrap}.skip-opponent-move-button{padding:8px 16px;background:#95a5a6;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .2s}.skip-opponent-move-button:hover{background:#7f8c8d}.moves-list-section{margin-top:20px;padding:15px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;max-height:400px;overflow-y:auto}.moves-list-section h3{margin:0 0 15px;color:#333;font-size:16px;font-weight:600}.no-moves-message{color:#999;font-style:italic;text-align:center;padding:20px;margin:0}.moves-list{display:flex;flex-direction:column;gap:10px}.move-item{padding:12px;background:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px;transition:background-color .2s;cursor:move;-webkit-user-select:none;user-select:none}.move-item.dragging{opacity:.5}.move-item.editing{border:2px solid #667eea;background-color:#f0f4ff}.move-item:hover{background:#f5f5f5}.move-drag-handle{cursor:grab;color:#999;font-size:18px;margin-right:8px;-webkit-user-select:none;user-select:none}.move-drag-handle:active{cursor:grabbing}.edit-move-button{background-color:#667eea;color:#fff;border:none;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px;margin-right:8px;transition:background-color .2s}.edit-move-button:hover{background-color:#5568d3}.cancel-edit-button{background-color:#999;color:#fff;border:none;padding:4px 12px;border-radius:4px;cursor:pointer;font-size:12px;margin-right:8px;transition:background-color .2s}.cancel-edit-button:hover{background-color:#777}.move-item-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.move-number{font-weight:600;color:#333;font-size:14px}.move-type-badge{padding:2px 8px;background:#667eea;color:#fff;border-radius:4px;font-size:11px;font-weight:500;text-transform:uppercase}.remove-move-button{margin-left:auto;background:#e74c3c;color:#fff;border:none;border-radius:4px;width:24px;height:24px;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;padding:0}.remove-move-button:hover{background:#c0392b}.move-item-content{display:flex;flex-direction:column;gap:6px}.move-details{display:flex;flex-direction:column;gap:4px}.move-detail{font-size:13px;color:#555}.move-detail strong{color:#333;margin-right:6px}.move-prompts{font-size:12px;color:#666;margin-top:4px;padding-top:6px;border-top:1px solid #e0e0e0}.move-prompts strong{color:#333;margin-right:6px}.move-item-actions{margin-top:10px;padding-top:10px;border-top:1px solid #e0e0e0}.edit-prompts-button{padding:6px 12px;background:#667eea;color:#fff;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .2s}.edit-prompts-button:hover{background:#5568d3}.move-prompts-editor{margin-top:10px;padding:12px;background:#f9f9f9;border:1px solid #e0e0e0;border-radius:6px}.move-prompts-editor label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:13px}.move-prompt-input-row{display:flex;gap:8px;margin-bottom:8px;align-items:center}.move-prompt-input{flex:1;padding:8px 12px;border:1px solid #e0e0e0;border-radius:4px;font-size:13px}.move-prompt-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.remove-prompt-button{width:28px;height:28px;background:#e74c3c;color:#fff;border:none;border-radius:4px;font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;padding:0}.remove-prompt-button:hover:not(:disabled){background:#c0392b}.remove-prompt-button:disabled{opacity:.5;cursor:not-allowed}.move-prompts-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.add-prompt-button,.save-prompts-button,.cancel-prompts-button{padding:6px 12px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:background-color .2s}.add-prompt-button{background:#27ae60;color:#fff}.add-prompt-button:hover{background:#229954}.save-prompts-button{background:#667eea;color:#fff}.save-prompts-button:hover{background:#5568d3}.cancel-prompts-button{background:#95a5a6;color:#fff}.cancel-prompts-button:hover{background:#7f8c8d}@media(max-width:768px){.new-lesson-container{padding:10px}.new-lesson-content{padding:20px}.form-row{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:15px}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.board-setup-container{flex-direction:column;gap:20px}.board-setup-board{padding:10px;width:100%}.board-setup-board>div{width:100%!important;max-width:100%!important;height:auto!important;aspect-ratio:1}}#root{width:100%;min-height:100vh}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}div[style*="position: fixed"][style*=z-index] img,div[style*="position: fixed"][style*=z-index] svg,div[style*="position: fixed"] img,div[style*="position: fixed"] svg{width:60px!important;height:60px!important;max-width:60px!important;max-height:60px!important;min-width:60px!important;min-height:60px!important;opacity:.9!important;transform:none!important;object-fit:contain!important;box-sizing:border-box!important}div[style*="position: fixed"][style*=z-index]{width:60px!important;height:60px!important;max-width:60px!important;max-height:60px!important}
