*{box-sizing:border-box;margin:0;padding:0}.back-button{padding:10px 20px;background-color:#5865f2;color:#fff;text-decoration:none;border-radius:8px;font-weight:600;transition:background-color .2s}.back-button:hover{background-color:#4752c4}.shapes-list-container{padding:20px;max-width:1200px;margin:0 auto}.shapes-size-group{margin-bottom:40px}.shapes-size-title{font-size:24px;color:#2a3847;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #e0e0e0}.shapes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:20px}.shape-card{background:#fff;border-radius:12px;padding:15px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;align-items:center;gap:10px;transition:transform .2s,box-shadow .2s}.shape-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.shape-id{font-family:Courier New,monospace;font-weight:600;color:#5865f2;font-size:14px}.shape-preview{display:flex;align-items:center;justify-content:center;min-height:80px}.shape-info{font-size:12px;color:#666}.shapes-summary{text-align:center;padding:30px;background:#f5f5f5;border-radius:12px;margin:20px}.shapes-summary h3{color:#2a3847;margin-bottom:10px}.shapes-summary p{color:#666}.app{max-width:600px;width:100%;margin:0 auto;display:flex;flex-direction:column;gap:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:pan-y pinch-zoom}.game-header{background:transparent;padding:20px;border-radius:12px;display:flex;justify-content:space-between;align-items:center}.game-header h1{font-size:32px;color:#2a3847;font-weight:700;margin:0}.score-container{display:flex;gap:20px;align-items:center;flex-wrap:wrap;justify-content:center}.score,.combo,.streak{display:flex;flex-direction:column;align-items:flex-end}.score-label,.combo-label,.streak-label{font-size:12px;color:#2a3847b3;text-transform:uppercase;letter-spacing:1px}.score-value,.combo-value,.streak-value{font-size:24px;font-weight:700;color:#2a3847}.combo-value{color:gold}.streak-value{color:#ff6b6b;display:flex;align-items:center;gap:8px}.streak-heart{display:inline-block;animation:heartbeat 1.2s ease-in-out infinite}@keyframes heartbeat{0%{transform:scale(1)}14%{transform:scale(1.3)}28%{transform:scale(1)}42%{transform:scale(1.3)}70%{transform:scale(1)}}.game-container{display:flex;flex-direction:column;gap:20px}.board-container{background:#1a233299;padding:20px;border-radius:12px;box-shadow:0 8px 32px #0000004d;display:flex;justify-content:center;align-items:center;min-height:380px}.board{display:inline-flex;flex-direction:column;gap:2px;background:#1a2332;padding:2px;border-radius:8px}.board-row{display:flex;gap:2px}.board-cell{width:40px;height:40px;border-radius:4px;transition:all .15s ease;cursor:pointer}.board-cell.empty{background:#2a3847}.board-cell.filled{background:linear-gradient(180deg,#667eea,#764ba2);box-shadow:inset 0 2px 4px #0000004d}.board-cell.preview-valid{background:#4caf5080;box-shadow:0 0 8px #4caf5080}.board-cell.preview-invalid{background:#ff525280;box-shadow:0 0 8px #ff525280}.tray{background:#1a233299;padding:20px;border-radius:12px;box-shadow:0 8px 32px #0000004d;touch-action:none}.tray-content{display:flex;justify-content:space-around;gap:20px;min-height:120px}.tray-slot{flex:1;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:8px;padding:20px;transition:all .2s ease}.tray-slot:hover{background:#ffffff0d;transform:translateY(-2px)}.tile{position:relative;cursor:grab;user-select:none;-webkit-user-select:none;transition:transform .2s ease;touch-action:none}.tile:hover{transform:scale(1.05)}.tile:active{cursor:grabbing}.tile.disabled{opacity:.5;cursor:not-allowed}.tile-cell{position:absolute;transition:all .2s ease;pointer-events:none}.dragging-tile{transform:scale(1.1)}.game-over-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.game-over-modal{background:#fff;padding:40px;border-radius:16px;box-shadow:0 16px 64px #0000004d;text-align:center;max-width:400px;width:90%;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.game-over-modal h2{font-size:36px;color:#3d5a80;margin-bottom:20px}.final-score{font-size:24px;color:#2a3847;margin-bottom:30px;font-weight:600}.restart-button{background:#3d5a80;color:#fff;border:none;padding:16px 40px;font-size:18px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #3d5a8066}.restart-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea99}.restart-button:active{transform:translateY(0)}.fake-score-button{background:linear-gradient(135deg,#ff6b6b,#ffa07a);color:#fff;border:none;padding:12px 24px;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #ff6b6b66}.fake-score-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ff6b6b99}.fake-score-button:active{transform:translateY(0)}.diagnose-button{background:linear-gradient(135deg,#9b59b6,#8e44ad);color:#fff;border:none;padding:12px 24px;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #9b59b666}.diagnose-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #9b59b699}.diagnose-button:active{transform:translateY(0)}.load-snapshot-button{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:12px 24px;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #3498db66}.load-snapshot-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #3498db99}.load-snapshot-button:active{transform:translateY(0)}.snapshot-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease}.snapshot-modal{background:#fff;padding:30px;border-radius:16px;box-shadow:0 16px 64px #0000004d;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;animation:slideUp .3s ease}.snapshot-modal h2{font-size:24px;color:#2a3847;margin-bottom:15px}.snapshot-instructions{font-size:14px;color:#666;margin-bottom:15px;line-height:1.5}.snapshot-textarea{width:100%;min-height:200px;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-family:Courier New,monospace;font-size:12px;resize:vertical;margin-bottom:10px}.snapshot-textarea:focus{outline:none;border-color:#3498db}.snapshot-error{color:#e74c3c;font-size:14px;margin-bottom:10px;padding:10px;background:#fde8e8;border-radius:6px}.snapshot-modal-buttons{display:flex;justify-content:flex-end;gap:12px;margin-top:15px}.snapshot-cancel-button{background:#95a5a6;color:#fff;border:none;padding:12px 24px;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease}.snapshot-cancel-button:hover{background:#7f8c8d}.snapshot-load-button{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:12px 24px;font-size:14px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #3498db66}.snapshot-load-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #3498db99}.snapshot-load-button:disabled{opacity:.5;cursor:not-allowed}.bottom-buttons-container{display:flex;justify-content:center;gap:12px;padding:10px 0;flex-wrap:wrap}.finish-button{background:linear-gradient(135deg,#4caf50,#8bc34a);color:#fff;border:none;padding:12px 24px;font-size:16px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #4caf5066;animation:pulse-finish 2s infinite}.finish-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4caf5099}.finish-button:active{transform:translateY(0)}@keyframes pulse-finish{0%,to{box-shadow:0 4px 12px #4caf5066}50%{box-shadow:0 4px 20px #4caf50cc}}.particles-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1500;overflow:hidden}.particle{position:fixed;border-radius:50%;animation:explode .6s ease-out forwards;box-shadow:0 0 8px currentColor}@keyframes explode{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(calc(cos(var(--angle)) * var(--velocity) * 1px),calc(sin(var(--angle)) * var(--velocity) * 1px)) scale(.2);opacity:0}}.board-cell.clearing{animation:flashClear .3s ease-out}@keyframes flashClear{0%,to{background:linear-gradient(180deg,#667eea,#764ba2)}50%{background:linear-gradient(180deg,gold,orange);box-shadow:0 0 20px #ffd700cc;transform:scale(1.1)}}@media(max-width:640px){.game-header{flex-direction:column;gap:15px;text-align:center}.game-header h1{font-size:24px}.score-container{flex-direction:row;justify-content:center}.board-cell{width:30px;height:30px}.tray-content{flex-direction:row;gap:10px;min-height:auto}.tray-slot{padding:10px}}.handwriting-canvas{width:100%;display:flex;flex-direction:column;align-items:center}.canvas-wrapper{position:relative;display:inline-block}.drawing-canvas{display:block;width:256px;height:286px;border-radius:8px;cursor:crosshair;touch-action:none;user-select:none;-webkit-user-select:none;background:#fafafa}.drawing-canvas:active{cursor:grabbing}.no-character{padding:40px;text-align:center;color:#6b7280;font-size:14px}@media(max-width:480px)and (orientation:portrait){.drawing-canvas{width:100%;max-width:256px;aspect-ratio:256 / 286;height:unset}.reset-button{width:40px;height:40px}.reset-button svg{width:16px;height:16px}}.canvas-wrapper{touch-action:none}@media(max-height:800px)and (orientation:landscape){.drawing-canvas{width:min(256px,calc((100vh - 200px) * 256 / 286));height:min(286px,calc(100vh - 200px));aspect-ratio:256 / 286}.reset-button{width:36px;height:36px}.reset-button svg{width:14px;height:14px}}.app-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:#f9fafb;padding:20px}.app-card{background-color:#fff;border-radius:16px;padding:48px;width:100%;max-width:672px;box-shadow:0 1px 3px #0000001a}.app-header{text-align:center;margin-bottom:32px}.app-title{font-size:36px;font-weight:700;color:#111827;margin:0 0 8px;line-height:40px}.app-subtitle{font-size:18px;font-weight:400;color:#4b5563;margin:0;line-height:28px}.progress-section{margin-bottom:40px}.progress-bar{width:100%;height:10px;background-color:#e5e7eb;border-radius:9999px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background-color:#667eea;border-radius:9999px;transition:width .3s ease}.checkpoint-text{font-size:14px;font-weight:400;color:#6b7280;text-align:center;margin:0;line-height:20px}.canvas-section{margin-bottom:48px}.character-display{text-align:center;margin-bottom:32px}.character-large{font-size:96px;font-weight:700;color:#667eea;margin:0;line-height:normal}.app-footer{text-align:center}.footer-buttons{display:flex;gap:12px;justify-content:center;align-items:center}.reset-button{width:48px;height:48px;background-color:#fff;border:2px solid #d1d5db;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#6b7280;box-shadow:0 1px 3px #0000001a}.reset-button:hover{background-color:#f9fafb;border-color:#9ca3af;color:#374151;box-shadow:0 2px 4px #00000026}.reset-button:active{transform:scale(.95)}.diagnose-button{background-color:#ef4444;color:#fff;font-size:14px;font-weight:600;padding:12px 20px;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s;box-shadow:0 1px 3px #0000001a}.diagnose-button:hover{background-color:#dc2626}.diagnose-button:active{transform:scale(.95)}.fake-completion-button{background-color:#f97316;color:#fff;font-size:16px;font-weight:700;padding:14px 24px;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s}.fake-completion-button:hover{background-color:#ea580c}.dev-note{font-size:12px;font-weight:400;color:#9ca3af;margin:12px 0 0;line-height:16px}@media(max-width:768px){.app-card{padding:24px}.app-title{font-size:28px;line-height:32px}.app-subtitle{font-size:16px;line-height:24px}.character-large{font-size:72px}}@media(max-width:480px){.app-card{padding:16px}.app-title{font-size:24px;line-height:28px}.app-subtitle{font-size:14px;line-height:20px}.character-large{font-size:56px}}@media(max-height:800px)and (orientation:landscape){.app-container{min-height:auto;padding:10px;align-items:flex-start}.app-card{padding:16px;max-width:none;width:100%}.app-header{margin-bottom:12px}.app-title{font-size:20px;line-height:24px}.app-subtitle{font-size:12px;line-height:16px}.progress-section{margin-bottom:12px}.progress-bar{height:6px;margin-bottom:4px}.checkpoint-text{font-size:11px}.canvas-section{margin-bottom:12px;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:24px}.character-display{margin-bottom:0}.character-large{font-size:48px}.app-footer{margin-top:8px}}.shape-canvas{display:flex;justify-content:center;touch-action:none}.shape-canvas__surface{width:280px;height:280px;background:#fafafa;border:2px solid #cfd8dc;border-radius:12px;touch-action:none;user-select:none;-webkit-user-select:none;cursor:crosshair}.shape-canvas__surface.is-active{border-color:#4caf50;box-shadow:0 0 0 3px #4caf5033}@media(max-width:720px){.shape-canvas__surface{width:90vw;max-width:280px;height:auto;aspect-ratio:1}}@media(orientation:landscape)and (max-height:500px){.shape-canvas__surface{width:min(46vw,calc(100vh - 130px));max-width:280px;height:auto;aspect-ratio:1}}.shape-selector{display:flex;gap:6px;justify-content:center;margin-bottom:12px}.shape-selector__btn{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #cfd8dc;border-radius:6px;background:#fff;color:#455a64;cursor:pointer;padding:0;transition:border-color .15s ease,background-color .15s ease,color .15s ease}.shape-selector__btn:hover{border-color:#90a4ae}.shape-selector__btn.is-selected{background:#2196f3;border-color:#1976d2;color:#fff}.dwth-app{max-width:760px;margin:0 auto;padding:24px;background:#fff;border-radius:16px;box-shadow:0 6px 24px #00000014;touch-action:none}.dwth-header{text-align:center;margin-bottom:16px}.dwth-title{font-size:24px;font-weight:700;margin:0 0 4px;color:#1f2937}.dwth-subtitle{font-size:14px;color:#475569;margin:0}.dwth-status{font-size:14px;margin:8px 0 0;color:#2563eb;min-height:20px}.dwth-board{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:flex-start}.dwth-side{display:flex;flex-direction:column;align-items:center}.dwth-progress{font-size:14px;margin:8px 0 0;color:#475569}.dwth-footer{text-align:center;margin-top:16px}.dwth-new,.dwth-continue{background:#2563eb;color:#fff;border:none;padding:10px 22px;font-size:15px;font-weight:600;border-radius:6px;cursor:pointer}.dwth-new:hover,.dwth-continue:hover{background:#1d4ed8}.dwth-pair-counter{font-size:14px;color:#2563eb;margin:6px 0 0;font-weight:600}.dwth-dev-controls{text-align:center;margin-top:12px}.dwth-fake-pair-button{background:#f97316;color:#fff;border:none;padding:6px 14px;font-size:13px;font-weight:600;border-radius:6px;cursor:pointer}@media(max-width:640px){.dwth-board{grid-template-columns:1fr}}@media(orientation:landscape)and (max-height:500px){.dwth-app{padding:8px;max-width:none}.dwth-title{font-size:16px}.dwth-subtitle{font-size:11px;margin:0}.dwth-status,.dwth-pair-counter{font-size:11px;margin-top:2px}.dwth-header{margin-bottom:4px}.dwth-board{grid-template-columns:1fr 1fr;gap:8px}.dwth-progress{margin-top:2px;font-size:11px}.dwth-footer{margin-top:4px}}.wisdom-learning{width:100%;max-width:100%}.wisdom-loading,.wisdom-error{text-align:center;padding:3rem 0}.wisdom-game{display:flex;flex-direction:column;gap:1.5rem}.progress-indicator{display:flex;justify-content:center;align-items:center;margin-bottom:1rem}.drop-zone{border:2px solid;border-radius:.5rem;padding:1.5rem;min-height:100px;display:flex;flex-wrap:nowrap;gap:.5rem;transition:all .2s ease;background-color:#f8f9fa;overflow-x:auto;align-items:center}.drop-zone.answer-area{border-color:#0d6efd;display:flex!important;flex-wrap:wrap!important;flex-direction:row!important;gap:.5rem!important}.word-bank{border-color:#6c757d;flex-wrap:wrap}.drop-zone.drag-over{background-color:#e7f3ff!important;border-color:#0d6efd!important;border-width:3px!important;box-shadow:0 0 10px #0d6efd4d}.empty-placeholder{color:#6c757d;font-style:italic;width:100%;text-align:center}.word-button{border:2px solid #343a40;border-radius:.5rem;padding:.75rem 1.5rem;font-size:1.25rem;font-weight:500;background-color:#fff;cursor:move;user-select:none;-webkit-user-select:none;touch-action:none;transition:all .2s ease;flex-shrink:0}.word-button:hover:not(:disabled){background-color:#e9ecef;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.word-button:active:not(:disabled){cursor:grabbing;transform:translateY(0)}.word-button:disabled{opacity:.6;cursor:not-allowed}.word-button.hint-word{border-color:#198754;border-width:3px;background-color:#d1e7dd;cursor:not-allowed}.insertion-cursor{position:absolute;width:3px;height:100%;background-color:#0d6efd;z-index:1000;pointer-events:none;margin-left:-1.5px}@keyframes pulse{0%{opacity:.5}to{opacity:.9}}.action-buttons{display:flex;justify-content:space-between;align-items:center;gap:1rem}.btn{padding:.5rem 1.5rem;font-size:1rem;border-radius:.375rem;border:1px solid transparent;cursor:pointer;transition:all .2s ease;font-weight:500}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-outline-secondary{color:#6c757d;border-color:#6c757d;background-color:#fff}.btn-outline-secondary:hover:not(:disabled){background-color:#6c757d;color:#fff}.btn-primary{background-color:#0d6efd;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0b5ed7}.result-message{padding:1rem;border-radius:.375rem;margin-top:1rem}.alert-success{background-color:#d1e7dd;border:1px solid #badbcc;color:#0f5132}.alert-danger{background-color:#f8d7da;border:1px solid #f5c2c7;color:#842029}.completion-panel{text-align:center;padding:3rem 0}.completion-icon{font-size:4rem;margin-bottom:1rem}.completion-title{font-size:2rem;margin-bottom:1rem;color:#212529}.completion-message{font-size:1.125rem;margin-bottom:2rem;color:#495057}.completion-score{color:#0d6efd;font-weight:700;font-size:1.5rem}.btn-success{background-color:#198754;color:#fff;border:none}.btn-success:hover{background-color:#157347}.btn-lg{padding:.75rem 2rem;font-size:1.25rem}.completion-button{margin-top:1rem}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.shake{animation:shake .5s}@media(max-width:768px){.word-button{font-size:1rem;padding:.5rem 1rem}.action-buttons{flex-direction:column}.btn{width:100%}}
