*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f8f9fc;--surface: #ffffff;--surface-hover: #f0f2f8;--text: #1a1a2e;--text-dim: #6b7280;--accent: #6366f1;--accent-hover: #4f46e5;--accent-text: #ffffff;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--border: #e5e7eb;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.06);--shadow-lg: 0 4px 12px rgba(0,0,0,.1);--font: system-ui, -apple-system, sans-serif;--font-mono: ui-monospace, "SF Mono", monospace;--cat-math: #6366f1;--cat-logic: #8b5cf6;--cat-spatial: #ec4899;--cat-language: #14b8a6;--cat-coding: #f97316;--cat-science: #22c55e;--cat-music: #e11d48}html,body{height:100%;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-tap-highlight-color:transparent;overflow:hidden}#app{height:100%;display:flex;flex-direction:column}.header{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;min-height:52px}.header-back{background:none;border:none;font-size:20px;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);color:var(--text);line-height:1}.header-back:hover{background:var(--surface-hover)}.header-title{font-size:18px;font-weight:600;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header-progress{font-size:13px;color:var(--text-dim);white-space:nowrap}.header-about{font-size:13px;color:var(--text-dim);text-decoration:none;padding:4px 8px;border-radius:var(--radius-sm)}.header-about:hover{background:var(--surface-hover);color:var(--text)}.header-hint{background:none;border:1.5px solid var(--border);width:28px;height:28px;border-radius:50%;font-size:15px;font-weight:700;cursor:pointer;color:var(--text-dim);display:flex;align-items:center;justify-content:center;flex-shrink:0}.header-hint:hover{background:var(--surface-hover);color:var(--text);border-color:var(--text-dim)}.rules-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.rules-card{background:var(--surface);border-radius:var(--radius-lg, 12px);padding:24px;max-width:400px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.about-page{max-width:520px;margin:0 auto;padding:24px 16px;line-height:1.6;color:var(--text)}.about-page h2{font-size:22px;margin-bottom:16px}.about-page h3{font-size:16px;margin:20px 0 8px}.about-page p{margin:0 0 12px;font-size:15px;color:var(--text-dim)}.content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.home-title{font-size:28px;font-weight:700;padding:24px 16px 8px}.home-subtitle{font-size:14px;color:var(--text-dim);padding:0 16px 16px}.search-input{display:block;width:calc(100% - 32px);max-width:400px;margin:0 16px 12px;padding:10px 14px;font-size:15px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);outline:none}.search-input:focus{border-color:var(--primary, #6366f1);box-shadow:0 0 0 2px #6366f126}.recent-section{padding:0 16px}.recent-title{font-size:16px;font-weight:700;margin-bottom:10px;color:var(--text)}.recent-scroll{display:flex;gap:10px;overflow-x:auto;padding-bottom:16px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.recent-scroll::-webkit-scrollbar{height:4px}.recent-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.recent-card{flex-shrink:0;width:120px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px;text-decoration:none;color:inherit;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;transition:transform .15s,box-shadow .15s;scroll-snap-align:start;position:relative}.recent-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.recent-card-icon{font-size:28px;line-height:1}.recent-card-name{font-size:13px;font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.recent-card-progress{font-size:11px;color:#166534;background:#dcfce7;padding:1px 8px;border-radius:10px;font-weight:500}.star-btn{position:absolute;top:4px;right:4px;background:none;border:none;font-size:18px;cursor:pointer;color:var(--border);padding:2px;line-height:1;transition:color .15s,transform .15s;z-index:1}.star-btn:hover{color:var(--warning);transform:scale(1.2)}.star-btn.starred{color:var(--warning)}.star-btn-grid{position:static;font-size:16px;margin-left:auto;flex-shrink:0}.puzzle-card-top{display:flex;align-items:flex-start;gap:8px}.filter-bar{display:flex;gap:8px;padding:0 16px 16px;overflow-x:auto;flex-wrap:nowrap}.filter-chip{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:var(--surface);font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;color:var(--text);transition:all .15s}.filter-chip:hover{border-color:var(--accent);color:var(--accent)}.filter-chip.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.puzzle-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;padding:0 16px 24px}.puzzle-category-section{margin-bottom:24px}.puzzle-category-header{padding:20px 16px 6px;font-size:22px;font-weight:800;color:var(--text, #222);letter-spacing:-.01em}.puzzle-group-section{margin-bottom:8px}.puzzle-group-header{display:flex;align-items:center;gap:8px;padding:12px 16px 8px;font-size:13px;font-weight:700;color:var(--text-secondary, #666);letter-spacing:.04em;text-transform:uppercase}.puzzle-group-section .puzzle-grid{padding-top:0}.puzzle-group-icon{font-size:16px;line-height:1}.puzzle-group-label{flex:1}.puzzle-group-count{background:var(--border, #e0e0e0);color:var(--text-secondary, #888);border-radius:10px;padding:1px 7px;font-size:11px;font-weight:600}.puzzle-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;cursor:pointer;transition:transform .15s,box-shadow .15s;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:8px}.puzzle-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.puzzle-card-disabled{opacity:.45;cursor:default;filter:grayscale(.6)}.puzzle-card-disabled:hover{transform:none;box-shadow:var(--shadow)}.puzzle-card-icon{font-size:32px;line-height:1}.puzzle-card-name{font-size:15px;font-weight:600}.puzzle-card-desc{font-size:12px;color:var(--text-dim);line-height:1.4}.puzzle-card-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto}.tag{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:500}.tag-category{color:#fff}.tag-category.math{background:var(--cat-math)}.tag-category.logic{background:var(--cat-logic)}.tag-category.spatial{background:var(--cat-spatial)}.tag-category.language{background:var(--cat-language)}.tag-category.coding{background:var(--cat-coding)}.tag-category.science{background:var(--cat-science)}.tag-category.music{background:var(--cat-music)}.tag-status-coming-soon{background:var(--border);color:var(--text-dim);font-style:italic}.tag-status-testing{background:#fef3c7;color:#92400e}.tag-status-available{background:#dcfce7;color:#166534}.tag-grade{background:var(--surface-hover);color:var(--text-dim)}.tag-progress{background:#dcfce7;color:#166534}.tutorial-section{max-width:420px;margin:0 auto 8px;padding:16px 16px 0}.tutorial-video{width:100%;max-height:260px;border-radius:var(--radius, 8px);background:#000;margin-bottom:12px}.tutorial-text{font-size:14px;line-height:1.5;color:var(--text-secondary, #555)}.tutorial-text p{margin:0 0 8px}.tutorial-text p:last-child{margin-bottom:0}.packs-container{padding:16px;display:flex;flex-direction:column;gap:16px;align-items:center;justify-content:center;min-height:100%}.tutorial-section+.packs-container{justify-content:flex-start;min-height:auto}.pack-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.pack-name{font-size:16px;font-weight:600;margin-bottom:12px}.level-dots{display:flex;gap:8px;flex-wrap:wrap}.level-dot{width:40px;height:40px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;cursor:pointer;transition:all .15s;background:var(--surface);color:var(--text)}.level-dot:hover{border-color:var(--accent);color:var(--accent)}.level-dot.completed{background:var(--success);border-color:var(--success);color:#fff}.level-dot.current{border-color:var(--accent);color:var(--accent)}.puzzle-viewport{flex:1;display:flex;flex-direction:column;align-items:center;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px}.puzzle-viewport:before,.puzzle-viewport:after{content:"";flex:1}.celebration-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#0006;z-index:1000;animation:fadeIn .3s}.celebration-card{background:var(--surface);border-radius:var(--radius);padding:32px 40px;text-align:center;box-shadow:var(--shadow-lg);animation:popIn .4s cubic-bezier(.34,1.56,.64,1)}.celebration-emoji{font-size:48px;margin-bottom:12px}.celebration-title{font-size:24px;font-weight:700;margin-bottom:8px}.celebration-text{color:var(--text-dim);margin-bottom:20px}.celebration-btn{padding:10px 28px;border-radius:var(--radius-sm);border:none;background:var(--accent);color:var(--accent-text);font-size:15px;font-weight:600;cursor:pointer}.celebration-btn:hover{background:var(--accent-hover)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.grid-puzzle{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:400px;user-select:none;-webkit-user-select:none}.grid-puzzle table{border-collapse:collapse;user-select:none;-webkit-user-select:none}.grid-puzzle td{width:52px;height:52px;border:1px solid var(--border);text-align:center;font-size:22px;font-weight:600;cursor:pointer;transition:background .1s;position:relative}.grid-puzzle td:hover{background:var(--surface-hover)}.grid-puzzle td.selected{background:#e0e7ff}.grid-puzzle td.fixed{color:var(--text);cursor:default}.grid-puzzle td.user{color:var(--accent)}.grid-puzzle td.error{color:var(--error);background:#fef2f2}.grid-puzzle td.correct{color:var(--success)}.grid-puzzle .hint-text{font-size:13px;color:var(--text-dim);text-align:center}.sudoku-box-top{border-top:2.5px solid var(--text)!important}.sudoku-box-left{border-left:2.5px solid var(--text)!important}.futoshiki-grid{user-select:none;-webkit-user-select:none}.futoshiki-cell{width:48px;height:48px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:600;cursor:pointer;transition:background .1s;border-radius:4px}.futoshiki-cell:hover{background:var(--surface-hover)}.futoshiki-cell.selected{background:#e0e7ff}.futoshiki-cell.fixed{color:var(--text);cursor:default}.futoshiki-cell.user{color:var(--accent)}.futoshiki-h-con{display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--text-dim)}.futoshiki-v-con{display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--text-dim);height:16px}.futoshiki-gap{height:16px}.numpad{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.numpad-btn{width:44px;height:44px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface);font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s;color:var(--text)}.numpad-btn:hover{border-color:var(--accent);color:var(--accent)}.numpad-btn:active{background:var(--accent);color:var(--accent-text)}.puzzle-actions{display:flex;gap:12px;justify-content:center;margin-top:16px}.submit-btn{padding:10px 28px;border-radius:20px;border:none;background:var(--accent);color:var(--accent-text);font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}.submit-btn:hover{background:var(--accent-hover)}.reset-btn{padding:10px 28px;border-radius:20px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:15px;font-weight:500;cursor:pointer;transition:all .15s}.reset-btn:hover{border-color:var(--error);color:var(--error)}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.shake{animation:shake .4s ease-in-out}.wordsearch{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:400px}.wordsearch-grid{display:grid;gap:0;user-select:none;-webkit-user-select:none}.wordsearch-cell{width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;font-family:var(--font-mono);cursor:pointer;border-radius:4px;transition:background .1s}.wordsearch-cell:hover{background:var(--surface-hover)}.wordsearch-cell.selecting{background:#e0e7ff}.wordsearch-cell.found{background:#dcfce7;color:#166534}.wordsearch-wordlist{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.wordsearch-word{font-size:14px;font-weight:500;padding:4px 10px;border-radius:var(--radius-sm);background:var(--surface-hover)}.wordsearch-word.found{text-decoration:line-through;opacity:.5}.pyramid{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:400px}.pyramid-row{display:flex;gap:4px;justify-content:center}.pyramid-cell{width:52px;height:52px;border:2px solid var(--border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;cursor:pointer;transition:all .15s;background:var(--surface)}.pyramid-cell.fixed{background:var(--surface-hover);cursor:default;color:var(--text)}.pyramid-cell.user{color:var(--accent);border-color:var(--accent)}.pyramid-cell.selected{border-color:var(--accent);box-shadow:0 0 0 2px #6366f14d}.pyramid-cell.error{border-color:var(--error);color:var(--error)}.pyramid-cell.correct{border-color:var(--success);color:var(--success)}.nonogram-table{border-collapse:collapse;-webkit-user-select:none;user-select:none;table-layout:fixed}.nonogram-table td{width:auto;height:auto;font-size:inherit;border:none}.nono-clue-empty{width:24px;height:24px;border:none}.nono-col-clue{width:28px;min-width:28px;max-width:28px;height:24px;text-align:center;font-size:13px;font-weight:600;color:var(--text-dim);vertical-align:bottom;padding:0;position:relative}.nono-row-clue{width:24px;height:28px;text-align:right;font-size:13px;font-weight:600;color:var(--text-dim);padding:0 4px 0 0;position:relative}.grid-puzzle .nono-cell{width:28px;height:28px;min-width:28px;min-height:28px;max-width:28px;max-height:28px;aspect-ratio:1;padding:0;box-sizing:border-box;border:1px solid var(--border);cursor:pointer;transition:background .1s;background:var(--surface);overflow:hidden}.grid-puzzle .nono-cell:hover{background:var(--surface-hover)}.grid-puzzle .nono-cell.filled,.grid-puzzle .nono-cell.filled:hover{background:var(--text)}.grid-puzzle .nono-cell.nono-row5{border-top:2px solid var(--text-dim)}.grid-puzzle .nono-cell.nono-col5{border-left:2px solid var(--text-dim)}.grid-puzzle .nono-cell.nono-dot{background:var(--surface);position:relative}.grid-puzzle .nono-cell.nono-dot:after{content:"";position:absolute;top:50%;left:50%;width:8px;height:8px;border-radius:50%;background:var(--text-dim);transform:translate(-50%,-50%)}.nono-crossed{opacity:.35;position:relative}.nono-crossed:after{content:"✕";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:16px;font-weight:700;opacity:.7;color:var(--text);pointer-events:none}.nono-col-clue[data-clue],.nono-row-clue[data-clue]{cursor:pointer}.nono-palette{display:flex;gap:8px;justify-content:center;align-items:center;margin:12px 0 4px;flex-wrap:wrap}.nono-palette-swatch{width:36px;height:36px;border-radius:50%;border:3px solid var(--border);cursor:pointer;transition:transform .15s,border-color .15s}.nono-palette-swatch:hover{transform:scale(1.1)}.nono-palette-swatch.selected{border-color:var(--text);transform:scale(1.15);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--text)}.nono-eraser{background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--text-dim)}.drag-ghost{position:fixed;pointer-events:none;z-index:2000;width:44px;height:44px;border-radius:var(--radius-sm);background:var(--accent);color:var(--accent-text);font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;transform:translate(-50%,-50%) scale(1.15);box-shadow:var(--shadow-lg);opacity:.92}.lang-puzzle{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:440px}.letter-tile{width:40px;height:40px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);font-size:20px;font-weight:700;font-family:var(--font-mono);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;user-select:none;-webkit-user-select:none;text-transform:uppercase}.letter-tile:hover{border-color:var(--accent)}.letter-tile.selected{border-color:var(--accent);box-shadow:0 0 0 2px #6366f14d}.letter-tile.placed{opacity:.35;pointer-events:none}.letter-tile.correct{border-color:var(--success);color:var(--success)}.letter-tile.error{border-color:var(--error);color:var(--error)}.letter-slot{width:40px;height:40px;border-radius:var(--radius-sm);border:2px dashed var(--border);background:var(--surface);font-size:20px;font-weight:700;font-family:var(--font-mono);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;text-transform:uppercase}.letter-slot.filled{border-style:solid;color:var(--accent)}.letter-slot.selected{border-color:var(--accent);background:#e0e7ff}.letter-slot.correct{border-color:var(--success);color:var(--success)}.letter-kbd{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;max-width:340px}.letter-kbd-btn{width:32px;height:38px;border-radius:6px;border:1px solid var(--border);background:var(--surface);font-size:15px;font-weight:600;font-family:var(--font-mono);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .1s;color:var(--text);text-transform:uppercase}.letter-kbd-btn:hover{border-color:var(--accent);color:var(--accent)}.letter-kbd-btn:active{background:var(--accent);color:var(--accent-text)}.letter-kbd-btn.used{opacity:.3}.letter-kbd-btn.correct{background:var(--success);color:#fff;border-color:var(--success)}.letter-kbd-btn.wrong{background:var(--error);color:#fff;border-color:var(--error);opacity:.5}.clue-panel{width:100%;background:var(--surface-hover);border-radius:var(--radius-sm);padding:12px 16px;font-size:14px;line-height:1.5;color:var(--text)}.clue-panel .clue-label{font-weight:600;color:var(--text-dim);font-size:12px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.answer-input{padding:10px 16px;border-radius:var(--radius-sm);border:2px solid var(--border);font-size:18px;font-weight:600;font-family:var(--font-mono);text-align:center;text-transform:uppercase;width:100%;max-width:300px;outline:none;transition:border-color .15s}.answer-input:focus{border-color:var(--accent)}.word-row{display:flex;gap:4px;justify-content:center}.crossword-grid{display:grid;gap:0;user-select:none;-webkit-user-select:none}.crossword-cell{width:36px;height:36px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;font-family:var(--font-mono);cursor:pointer;position:relative;background:var(--surface);text-transform:uppercase}.crossword-cell.black{background:var(--text);cursor:default}.crossword-cell.selected{background:#e0e7ff}.crossword-cell.highlighted{background:#f0f2f8}.crossword-cell .cell-number{position:absolute;top:1px;left:2px;font-size:9px;font-weight:500;color:var(--text-dim);font-family:var(--font)}.crossword-cell.fixed{color:var(--text)}.crossword-cell.user{color:var(--accent)}.hangman-figure{width:160px;height:180px}.hangman-figure line,.hangman-figure circle{stroke:var(--text);fill:none;stroke-width:3;stroke-linecap:round}.match-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.match-tile{padding:8px 16px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);font-size:16px;font-weight:600;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.match-tile:hover{border-color:var(--accent)}.match-tile.selected{border-color:var(--accent);background:#e0e7ff}.match-tile.matched{border-color:var(--success);background:#dcfce7;color:#166534;pointer-events:none}.choices{display:flex;flex-direction:column;gap:8px;width:100%}.choice-btn{padding:12px 16px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);font-size:15px;font-weight:500;cursor:pointer;text-align:left;transition:all .15s;color:var(--text)}.choice-btn:hover{border-color:var(--accent);background:var(--surface-hover)}.choice-btn.selected{border-color:var(--accent);background:#e0e7ff}.choice-btn.correct{border-color:var(--success);background:#dcfce7}.choice-btn.wrong{border-color:var(--error);background:#fef2f2}.hw-text{font-size:16px;line-height:1.8;word-spacing:2px}.hw-char{cursor:pointer;padding:2px 0;border-radius:2px;transition:background .1s}.hw-char:hover{background:var(--surface-hover)}.hw-char.selecting{background:#e0e7ff}.hw-char.found{background:#dcfce7;color:#166534;font-weight:600}.hw-space{display:inline;width:6px}.hw-progress{font-size:14px;color:var(--text-dim)}.hw-clue{font-size:15px;font-weight:600}.hw-sentence{font-size:20px;line-height:2;letter-spacing:1px;user-select:none;-webkit-user-select:none}.hw-selected{background:#e0e7ff!important}.hw-found-char{background:#dcfce7;color:#166534;font-weight:600}.hw-found{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.hw-found-tag{padding:4px 12px;border-radius:999px;background:var(--surface-hover);font-size:14px;font-weight:500}.hw-found-tag.hw-found-yes{background:#dcfce7;color:#166534}.crypto-message{display:flex;flex-wrap:wrap;gap:12px 20px;justify-content:center;-webkit-user-select:none;user-select:none}.crypto-word{display:flex;gap:2px}.crypto-cell{display:flex;flex-direction:column;align-items:center;width:32px;cursor:pointer;padding:2px 0;border-radius:4px}.crypto-cell.selected{background:#e0e7ff}.crypto-cell.hint{opacity:.6;cursor:default}.crypto-cell.filled .decoded-letter{color:var(--accent)}.crypto-cell.punct{justify-content:flex-end;font-size:16px;font-weight:600;cursor:default}.cipher-letter{font-size:16px;font-weight:700;font-family:var(--font-mono);color:var(--text)}.decoded-letter{font-size:14px;font-weight:600;font-family:var(--font-mono);color:var(--text-dim);min-height:18px;border-top:2px solid var(--border);width:100%;text-align:center;margin-top:2px}.crypto-keyboard{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;max-width:340px}.crypto-key{width:32px;height:38px;border-radius:6px;border:1px solid var(--border);background:var(--surface);font-size:15px;font-weight:600;font-family:var(--font-mono);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text)}.crypto-key:hover{border-color:var(--accent);color:var(--accent)}.crypto-key:active{background:var(--accent);color:var(--accent-text)}.crypto-key.clear-key{width:40px}.crypto-submit{padding:10px 32px;border-radius:8px;border:none;background:var(--accent);color:var(--accent-text);font-size:16px;font-weight:600;cursor:pointer}.match-col{display:flex;flex-direction:column;gap:8px}.tile{padding:10px 20px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);font-size:16px;font-weight:600;cursor:pointer;transition:all .15s}.tile:hover{border-color:var(--accent)}.tile.selected{border-color:var(--accent);background:#e0e7ff}.tile.matched{border-color:var(--success);background:#dcfce7;color:#166534;pointer-events:none}.matched-words{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;min-height:32px}.matched-tag{padding:4px 12px;border-radius:999px;background:#dcfce7;color:#166534;font-size:14px;font-weight:600}.keyboard{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;max-width:340px}.key{width:32px;height:38px;border-radius:6px;border:1px solid var(--border);background:var(--surface);font-size:15px;font-weight:600;font-family:var(--font-mono);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text)}.key:hover{border-color:var(--accent);color:var(--accent)}.key:active{background:var(--accent);color:var(--accent-text)}.key-wide{width:48px}.key-submit{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.key-submit:hover{opacity:.9}.slots-row,.tiles-row{display:flex;gap:4px;justify-content:center}.acrostic-board{display:flex;flex-direction:column;gap:6px;width:100%}.acrostic-row{display:flex;gap:4px;align-items:center}.acrostic-slots{display:flex;gap:2px}.acrostic-vtile{width:36px;height:40px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;font-family:var(--font-mono);border-radius:4px;border:2px solid var(--border);background:var(--surface);text-transform:uppercase}.acrostic-vtile--filled{border-color:var(--accent);color:var(--accent)}.acrostic-slot{width:36px;height:40px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;font-family:var(--font-mono);border:2px dashed var(--border);border-radius:4px;cursor:pointer;text-transform:uppercase;background:var(--surface)}.acrostic-slot--accent{border-color:var(--accent);background:#e0e7ff}.acrostic-slot--selected{border-color:var(--accent);background:#c7d2fe;box-shadow:0 0 0 2px #6366f14d}.acrostic-clue{font-size:14px;color:var(--text-dim);margin-left:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.acrostic-keyboard{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;max-width:340px}.acrostic-key{width:32px;height:38px;border-radius:6px;border:1px solid var(--border);background:var(--surface);font-size:15px;font-weight:600;font-family:var(--font-mono);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text)}.acrostic-key:hover{border-color:var(--accent);color:var(--accent)}.acrostic-key:active{background:var(--accent);color:var(--accent-text)}.acrostic-key--wide{width:48px}.sp-words{display:flex;flex-direction:column;gap:16px;width:100%}.sp-word-row{display:flex;flex-direction:column;gap:4px;align-items:center}.sp-letters{display:flex;gap:4px;justify-content:center}.sp-clue{font-size:13px;color:var(--text-dim)}.sp-keyboard{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;max-width:340px}.sp-key{width:32px;height:38px;border-radius:6px;border:1px solid var(--border);background:var(--surface);font-size:15px;font-weight:600;font-family:var(--font-mono);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text)}.sp-key:hover{border-color:var(--accent);color:var(--accent)}.sp-key:active{background:var(--accent);color:var(--accent-text)}.sp-submit{padding:10px 32px;border-radius:8px;border:none;background:var(--accent);color:var(--accent-text);font-size:16px;font-weight:600;cursor:pointer}.word-display{display:flex;gap:6px;justify-content:center;flex-wrap:wrap}.word-bank{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.mirror-hint{font-size:13px;color:var(--text-dim);font-style:italic}.submit-btn{padding:10px 32px;border-radius:8px;border:2px solid var(--accent);background:var(--accent);color:var(--accent-text);font-size:16px;font-weight:600;cursor:pointer}.submit-btn:hover{opacity:.9}.crossword-clue-display{width:100%;padding:8px 12px;background:var(--surface-hover);border-radius:var(--radius-sm);font-size:14px;min-height:36px}.crossword-dir-toggle{padding:6px 16px;border-radius:6px;border:1px solid var(--border);background:var(--surface);font-size:13px;cursor:pointer}.crossword-clues{display:flex;gap:16px;width:100%}.crossword-clue-list{flex:1;font-size:13px}.crossword-clue-heading{font-weight:700;margin-bottom:4px}.crossword-clue-item{padding:2px 0;color:var(--text-dim)}.crossword-clue-item.active{color:var(--accent);font-weight:600}.crossword-submit{padding:10px 32px;border-radius:8px;border:none;background:var(--accent);color:var(--accent-text);font-size:16px;font-weight:600;cursor:pointer}.analogy-progress{font-size:14px;color:var(--text-dim)}.analogy-hint{font-size:13px;color:var(--text-dim);font-style:italic}.analogy-prompt{font-size:18px;font-weight:600;text-align:center}.analogy-options{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.analogy-feedback{font-size:14px;text-align:center;min-height:20px}.analogy-feedback.correct{color:var(--success)}.analogy-feedback.wrong{color:var(--error)}.letter-tile.used{opacity:.3;pointer-events:none}.letter-tile.fixed{background:var(--surface-hover);cursor:default}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.shake{animation:shake .3s}.deduction-puzzle{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:500px}.tri-cell{width:32px;height:32px;border:1px solid var(--border);text-align:center;vertical-align:middle;font-size:16px;cursor:pointer;transition:background .1s;user-select:none;-webkit-user-select:none}.tri-cell:hover{background:var(--surface-hover)}.tri-cell.yes{background:#dcfce7;color:#166534}.tri-cell.no{background:#fef2f2;color:#ef4444}.elim-matrix{border-collapse:collapse;user-select:none;-webkit-user-select:none}.elim-matrix th{font-size:11px;font-weight:600;color:var(--text-dim);padding:4px 6px;white-space:nowrap}.elim-matrix th.rotate{writing-mode:vertical-lr;transform:rotate(180deg);text-align:left;height:60px;padding:6px 2px}.elim-matrix .cat-divider-right{border-right:2px solid var(--text)}.elim-matrix .cat-divider-bottom{border-bottom:2px solid var(--text)}.statement-list{width:100%;display:flex;flex-direction:column;gap:8px}.statement-item{padding:10px 14px;border-radius:var(--radius-sm);background:var(--surface-hover);font-size:14px;line-height:1.5;color:var(--text)}.statement-item .statement-number{font-weight:700;color:var(--accent);margin-right:6px}.class-btn-group{display:flex;gap:6px}.class-btn{padding:6px 14px;border-radius:16px;border:2px solid var(--border);background:var(--surface);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;color:var(--text)}.class-btn:hover{border-color:var(--accent)}.class-btn.active{border-color:var(--accent);background:var(--accent);color:var(--accent-text)}.class-btn.correct{border-color:var(--success);background:var(--success);color:#fff}.class-btn.wrong{border-color:var(--error);background:var(--error);color:#fff}.char-card{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);width:100%}.char-icon{font-size:28px;flex-shrink:0}.char-info{flex:1;min-width:0}.char-name{font-weight:600;font-size:15px;margin-bottom:2px}.char-speech{font-size:13px;color:var(--text-dim);font-style:italic}.mm-board{display:flex;flex-direction:column;gap:8px;width:100%}.mm-row{display:flex;align-items:center;gap:8px}.mm-peg{width:40px;height:40px;border-radius:50%;border:2px solid var(--border);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;font-size:18px}.mm-peg:hover{border-color:var(--accent)}.mm-peg.selected{border-color:var(--accent);box-shadow:0 0 0 2px #6366f14d}.mm-feedback{display:flex;gap:4px;margin-left:auto}.mm-fb-peg{width:14px;height:14px;border-radius:50%;border:1px solid var(--border)}.mm-fb-peg.black{background:var(--text);border-color:var(--text)}.mm-fb-peg.white{background:var(--surface);border-color:var(--text)}.mm-palette{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.mm-color-btn{width:36px;height:36px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:all .15s}.mm-color-btn:hover{transform:scale(1.15)}.mm-color-btn.active{border-color:var(--text);box-shadow:0 0 0 2px #0003}.venn-container{position:relative;width:320px;height:240px;margin:0 auto}.venn-circle{position:absolute;border-radius:50%;border:3px solid;opacity:.25}.venn-label{position:absolute;font-size:12px;font-weight:600;color:var(--text-dim);text-align:center}.venn-region{position:absolute;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background .15s}.venn-region:hover{background:#6366f11a}.venn-region.drop-target{background:#6366f133}.drag-items{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.drag-item{padding:6px 14px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);font-size:14px;font-weight:500;cursor:grab;transition:all .15s;-webkit-user-select:none;user-select:none}.drag-item:hover{border-color:var(--accent)}.drag-item.placed{opacity:.35;pointer-events:none}.slide-cell{display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;border-radius:var(--radius-sm);background:var(--accent);color:var(--accent-text);cursor:pointer;transition:all .15s;user-select:none;-webkit-user-select:none;aspect-ratio:1}.slide-cell:hover{background:var(--accent-hover)}.slide-cell.slide-empty{background:transparent;cursor:default}.mental-rotation-puzzle{display:flex;flex-direction:column;align-items:center;gap:12px;padding:8px}.mr-reference{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 20px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}.mr-label{font-size:12px;font-weight:700;letter-spacing:.08em;color:var(--text-dim)}.mr-shape{fill:var(--accent);stroke:var(--accent);stroke-width:.8;stroke-linejoin:round}.mr-ref-svg,.mr-opt-svg{display:block}.mr-options{display:grid;gap:10px;width:100%;max-width:360px}.mr-option-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 8px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:var(--surface);transition:border-color .15s,background .15s}.mr-option-card:hover{border-color:var(--accent)}.mr-option-card.selected{border-color:var(--accent);border-width:3px;background:#e0e7ff;padding:9px 7px}.mr-option-label{font-size:13px;font-weight:700;color:var(--text-dim)}@media(max-width:480px){.mr-options{max-width:300px;gap:8px}.mr-reference{padding:8px 14px}}.mr3d-puzzle{display:flex;flex-direction:column;align-items:center;gap:12px;padding:8px}.mr3d-reference{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 16px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}.mr3d-label{font-size:12px;font-weight:700;letter-spacing:.08em;color:var(--text-dim)}.mr3d-ref-svg{display:flex;justify-content:center;min-height:80px}.mr3d-rotate-row{display:flex;gap:10px;margin-top:4px}.mr3d-rotate-btn{padding:4px 12px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--surface);cursor:pointer;font-size:14px}.mr3d-rotate-btn:hover{border-color:var(--accent)}.mr3d-options{display:grid;gap:10px;width:100%;max-width:400px}.mr3d-option-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 6px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:var(--surface);transition:border-color .15s,background .15s}.mr3d-option-card:hover{border-color:var(--accent)}.mr3d-option-card.selected{border-color:var(--accent);border-width:3px;background:#e0e7ff;padding:7px 5px}.mr3d-option-header{display:flex;align-items:center;gap:6px}.mr3d-option-label{font-size:13px;font-weight:700;color:var(--text-dim)}.mr3d-checkbox{width:18px;height:18px;border:2px solid var(--border);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;background:var(--surface);transition:background .15s,border-color .15s}.mr3d-checkbox.checked{background:var(--accent);border-color:var(--accent)}.mr3d-opt-svg{display:flex;justify-content:center;min-height:60px}@media(max-width:480px){.mr3d-options{max-width:320px;gap:8px}.mr3d-reference{padding:8px 10px}}.grid-puzzle td.drag-hover-valid{background:#22c55e4d!important;box-shadow:inset 0 0 0 2px #22c55e99}.grid-puzzle td.drag-hover-invalid{background:#ef444433!important;box-shadow:inset 0 0 0 2px #ef444480}.piece-ghost{position:fixed;pointer-events:none;z-index:2000;opacity:.75}.science-puzzle{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%;max-width:500px}.reorder-list{display:flex;flex-direction:column;gap:6px;width:100%}.reorder-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);font-size:14px;font-weight:500;cursor:grab;transition:all .15s;user-select:none;-webkit-user-select:none}.reorder-item:hover{border-color:var(--accent)}.reorder-item.selected{border-color:var(--accent);background:#e0e7ff}.reorder-item .reorder-num{width:24px;height:24px;border-radius:50%;background:var(--surface-hover);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--text-dim);flex-shrink:0}.reorder-item .reorder-icon{font-size:20px;flex-shrink:0}.category-zones{display:flex;gap:8px;width:100%;flex-wrap:wrap;justify-content:center}.category-zone{flex:1;min-width:120px;padding:10px;border-radius:var(--radius-sm);border:2px dashed var(--border);min-height:80px;text-align:center;transition:all .15s}.category-zone.drop-active{border-color:var(--accent);background:#6366f10d}.category-zone .zone-label{font-size:12px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.category-zone .zone-items{display:flex;flex-wrap:wrap;gap:4px;justify-content:center}.match-columns{display:flex;gap:24px;justify-content:center;width:100%}.match-column{display:flex;flex-direction:column;gap:8px;flex:1}.match-column-label{font-size:12px;font-weight:700;color:var(--text-dim);text-transform:uppercase;text-align:center;margin-bottom:4px}.label-bank{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.label-tag{padding:6px 12px;border-radius:16px;border:2px solid var(--border);background:var(--surface);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.label-tag:hover{border-color:var(--accent)}.label-tag.selected{border-color:var(--accent);background:#e0e7ff}.label-tag.placed{opacity:.35;pointer-events:none}.diagram-spot{padding:4px 10px;border-radius:12px;border:2px dashed var(--border);font-size:12px;font-weight:600;cursor:pointer;min-width:60px;text-align:center;transition:all .15s;background:var(--surface)}.diagram-spot.active{border-color:var(--accent);border-style:solid}.diagram-spot.filled{border-style:solid;color:var(--accent);border-color:var(--accent)}.map-region{cursor:pointer;transition:opacity .15s;stroke:var(--text);stroke-width:2}.map-region:hover{opacity:.8}.gear-svg{-webkit-user-select:none;user-select:none}.circuit-grid{display:grid;gap:0;-webkit-user-select:none;user-select:none;background:#f8f9fa;border:2px solid var(--border);border-radius:var(--radius-sm);padding:4px;margin:0 auto;width:fit-content}.circuit-cell{width:52px;height:52px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:22px;cursor:pointer;transition:background .1s;background:var(--surface)}.circuit-cell:hover{background:var(--surface-hover)}.circuit-cell.selected{background:#e0e7ff}.circuit-cell.wire{background:#fef9c3}.circuit-cell.component{background:#dbeafe}.step-indicator{display:flex;gap:8px;justify-content:center}.step-dot{width:10px;height:10px;border-radius:50%;background:var(--border)}.step-dot.active{background:var(--accent)}.step-dot.done{background:var(--success)}@media(max-width:480px){.puzzle-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.grid-puzzle td{width:44px;height:44px;font-size:18px}.numpad-btn{width:38px;height:38px;font-size:16px}.wordsearch-cell{width:32px;height:32px;font-size:14px}.pyramid-cell{width:44px;height:44px;font-size:17px}}.feedback-fab{position:fixed;bottom:20px;right:20px;width:52px;height:52px;border-radius:50%;background:var(--accent);color:var(--accent-text);border:none;font-size:22px;cursor:pointer;box-shadow:var(--shadow-lg);z-index:9999;transition:transform .2s,background .2s;display:flex;align-items:center;justify-content:center}.feedback-fab:hover{transform:scale(1.1)}.feedback-fab.open{background:var(--text-dim);transform:rotate(90deg) scale(1.1)}.feedback-panel{position:fixed;bottom:82px;right:20px;width:340px;max-height:calc(100vh - 120px);background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:9998;display:flex;flex-direction:column;gap:10px;padding:14px;overflow-y:auto;opacity:0;pointer-events:none;transform:translateY(12px);transition:opacity .2s,transform .2s}.feedback-panel.open{opacity:1;pointer-events:auto;transform:translateY(0)}.feedback-panel-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:15px}.feedback-close{background:none;border:none;font-size:22px;cursor:pointer;color:var(--text-dim);padding:0 4px;line-height:1}.feedback-textarea{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;font-family:var(--font);font-size:14px;resize:vertical;min-height:72px;outline:none}.feedback-textarea:focus{border-color:var(--accent)}.feedback-section{display:flex;flex-direction:column;gap:6px}.feedback-btn{padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;font-size:13px;font-family:var(--font);text-align:left;transition:background .15s}.feedback-btn:hover{background:var(--surface-hover)}.feedback-btn-record.recording{background:var(--error);color:#fff;border-color:var(--error);animation:pulse-record 1.2s infinite}@keyframes pulse-record{0%,to{opacity:1}50%{opacity:.7}}.feedback-btn-submit{background:var(--accent);color:var(--accent-text);border-color:var(--accent);text-align:center;font-weight:600}.feedback-btn-submit:hover{background:var(--accent-hover)}.feedback-audio-status{font-size:12px;color:var(--text-dim)}.feedback-screenshot-preview{margin-top:4px}.feedback-thumb{width:100%;border-radius:var(--radius-sm);border:1px solid var(--border)}.feedback-draw-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:#000000e0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:12px}.feedback-draw-toolbar{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#ffffff1f;border-radius:24px;flex-wrap:wrap;justify-content:center}.feedback-color-btn{width:28px;height:28px;border-radius:50%;border:2px solid rgba(255,255,255,.3);cursor:pointer;transition:transform .15s}.feedback-color-btn.active{border-color:#fff;transform:scale(1.2)}.feedback-size-btn{width:32px;height:32px;border-radius:50%;border:none;background:#ffffff14;cursor:pointer;display:flex;align-items:center;justify-content:center}.feedback-size-btn.active{background:#ffffff40}.feedback-size-dot{display:block;border-radius:50%;background:#fff}.feedback-toolbar-sep{width:1px;height:20px;background:#fff3;margin:0 4px}.feedback-draw-canvas{border-radius:var(--radius-sm);cursor:crosshair;max-width:calc(100vw - 32px);max-height:calc(100vh - 140px)}.feedback-draw-bottom{display:flex;gap:10px}.feedback-draw-action{padding:10px 20px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-size:14px;font-family:var(--font);background:#ffffff26;color:#fff}.feedback-draw-action:hover{background:#ffffff40}.feedback-draw-action.feedback-btn-submit{background:var(--accent);color:var(--accent-text)}@media(max-width:480px){.feedback-panel{right:8px;left:8px;width:auto;bottom:76px}.feedback-fab{bottom:14px;right:14px;width:46px;height:46px;font-size:20px}}.river-crossing-puzzle{padding:8px}.river-hint{text-align:center;font-size:14px;color:var(--text-dim);margin-bottom:4px}.river-move-counter{text-align:center;font-size:13px;color:var(--text-dim);margin-bottom:10px}.river-scene{display:flex;gap:0;justify-content:center;align-items:stretch;min-height:200px;border-radius:10px;overflow:hidden;margin-bottom:10px}.river-bank{flex:1;min-width:90px;padding:10px 6px;display:flex;flex-direction:column;align-items:center;gap:6px;background:linear-gradient(180deg,#86efac,#4ade80);border:2px solid #22c55e}.river-bank--left{border-radius:10px 0 0 10px;border-right:none}.river-bank--right{border-radius:0 10px 10px 0;border-left:none}.river-bank--farmer{box-shadow:inset 0 0 0 2px #fbbf24}.river-bank__label{font-size:11px;font-weight:700;color:#166534;text-transform:uppercase;letter-spacing:.5px}.river-bank__farmer{font-size:28px}.river-bank__items{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.river-item{font-size:28px;width:44px;height:44px;border:2px solid rgba(0,0,0,.15);border-radius:10px;background:#ffffffb3;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s}.river-item:not(:disabled):hover{transform:scale(1.1);box-shadow:0 2px 8px #00000026}.river-item:disabled{opacity:.5;cursor:default}.river-water{width:100px;background:linear-gradient(180deg,#93c5fd,#3b82f6,#2563eb);display:flex;align-items:center;position:relative;transition:justify-content .3s}.river-water--boat-left{justify-content:flex-start}.river-water--boat-right{justify-content:flex-end}.river-boat{background:#92400e;border-radius:4px 4px 12px 12px;padding:6px 8px 10px;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:72px;box-shadow:0 3px 8px #0000004d;transition:transform .4s ease}.river-water--boat-left .river-boat{transform:translate(4px)}.river-water--boat-right .river-boat{transform:translate(-4px)}.river-boat__icon{font-size:22px;line-height:1}.river-boat__label{font-size:10px;color:#fef3c7;font-weight:600}.river-boat__cargo{display:flex;gap:4px;min-height:36px;align-items:center}.river-item--in-boat{background:#ffffffd9;font-size:24px;width:36px;height:36px}.river-cross-btn{font-size:12px;font-weight:700;padding:4px 10px;border:none;border-radius:6px;background:#fbbf24;color:#78350f;cursor:pointer;transition:background .15s}.river-cross-btn:hover{background:#f59e0b}.river-cross-btn:disabled{opacity:.4;cursor:default}.river-message{text-align:center;font-size:13px;padding:6px 12px;border-radius:6px;margin-bottom:8px}.river-message--warn{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.river-message--win{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.dot-to-dot-svg{display:block;width:100%;max-width:340px;margin:0 auto 12px;border-radius:var(--radius-sm, 8px);background:var(--surface, #fff);border:1px solid var(--border, #e0e0e0)}.dot-to-dot-decoration{opacity:.45;pointer-events:none}.dot-to-dot-line-done{opacity:.9}@media(max-width:480px){.dot-to-dot-svg{max-width:100%}}.island-ferry-puzzle{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%}.island-ferry-status{text-align:center;font-size:14px;font-weight:600;color:var(--text-dim)}.island-ferry-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;width:100%;max-width:400px}.island-ferry-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.island-ferry-panel-name{font-weight:700;font-size:15px}.island-ferry-panel-status{font-size:12px;color:var(--text-dim);font-weight:600}.island-ferry-done{color:#22c55e}.island-ferry-target{display:flex;align-items:center;gap:6px;margin-bottom:6px;flex-wrap:wrap}.island-ferry-target-piece{background:#6366f11f;border-radius:4px;padding:2px 6px;font-size:14px}.island-ferry-label{font-size:12px;color:var(--text-dim);font-weight:600}.island-ferry-pieces{display:flex;align-items:center;gap:4px;flex-wrap:wrap}.island-ferry-piece-btn{font-size:22px;width:38px;height:38px;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--surface);cursor:default;display:flex;align-items:center;justify-content:center;transition:transform .15s,border-color .15s}.island-ferry-piece-loadable{cursor:pointer;border-color:#6366f1;background:#6366f10f}.island-ferry-piece-loadable:hover{transform:scale(1.12);border-color:#4f46e5}.island-ferry-piece-unloadable{cursor:pointer;border-color:#f59e0b;background:#f59e0b14}.island-ferry-piece-unloadable:hover{transform:scale(1.12);border-color:#d97706}.island-ferry-boat-panel{display:flex;align-items:center;gap:6px;flex-wrap:wrap;background:#f59e0b14;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-sm);padding:8px 14px;width:100%;max-width:400px}@media(max-width:480px){.island-ferry-piece-btn{width:34px;height:34px;font-size:18px}}.numberlink svg{border-radius:8px;background:#fafafa}.mondrian-grid{border:2px solid #333;background:#fafafa;border-radius:4px;user-select:none;-webkit-user-select:none;touch-action:none}.mondrian-cell{position:absolute;box-sizing:border-box;border:1px solid #ddd}.mondrian-rect{position:absolute;box-sizing:border-box;border:2px solid #333;border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#333;cursor:pointer;z-index:2;transition:opacity .15s}.mondrian-rect.locked{opacity:1;cursor:default;background:#333!important;color:#fff}.mondrian-rect.preview{border:2px dashed #4f46e5;background:#4f46e526;pointer-events:none;z-index:3}.mondrian-rect.preview.invalid{border-color:#e53e3e;background:#e53e3e26}.mondrian-rect.selected{border:3px solid #e53e3e;z-index:4}.mondrian-delete-btn{position:absolute;top:-10px;right:-10px;width:24px;height:24px;border-radius:50%;border:2px solid #fff;background:#e53e3e;color:#fff;font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;z-index:5;line-height:1}.mondrian-status{text-align:center;margin:8px 0;font-size:14px;color:var(--text-secondary, #666)}.picasso-grid{border:2px solid #333;background:#fafafa;border-radius:4px;user-select:none;-webkit-user-select:none;touch-action:none}.picasso-cell{position:absolute;box-sizing:border-box;border:1px solid #ddd;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:500;color:#888;cursor:pointer;z-index:1;transition:background .1s}.picasso-cell.occupied{color:#fff;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.3);z-index:2;border-radius:2px}.picasso-cell.valid-next{background:#48bb7840;border-color:#48bb7880}.picasso-cell.path-end{box-shadow:inset 0 0 0 2px #333}.picasso-line{position:absolute;z-index:1;border-radius:2px;pointer-events:none;opacity:.5}.picasso-status{text-align:center;margin:8px 0;font-size:14px;color:var(--text-secondary, #666)}.picasso-path-actions{display:flex;justify-content:center;gap:8px;margin:4px 0}.picasso-finish-btn,.picasso-undo-btn{padding:6px 14px;border-radius:6px;border:1px solid var(--border, #ddd);background:var(--bg-secondary, #f5f5f5);font-size:13px;cursor:pointer}@media(max-width:480px){.picasso-cell{font-size:10px}}.diversity-grid{border:2px solid #333;background:#fafafa;border-radius:4px;user-select:none;-webkit-user-select:none;touch-action:none}.diversity-cell{position:absolute;box-sizing:border-box;border:1px solid #ddd}.diversity-rect{position:absolute;box-sizing:border-box;border:2px solid #333;border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#333;cursor:pointer;z-index:2}.diversity-rect.preview{border:2px dashed #4f46e5;background:#4f46e526;pointer-events:none;z-index:3}.diversity-rect.preview.invalid{border-color:#e53e3e;background:#e53e3e26}.diversity-status{text-align:center;margin:8px 0;font-size:14px;color:var(--text-secondary, #666)}.color-jigsaw{display:flex;flex-direction:column;align-items:center;gap:16px}.cj-board{border-radius:var(--radius-sm);user-select:none;-webkit-user-select:none}.cj-cell{border-radius:4px;transition:background .15s ease;position:relative;border:2px solid transparent}.cj-cell.cj-empty{border:2px dashed var(--border)}.cj-cell.cj-anchor{border:2px solid rgba(0,0,0,.3);box-shadow:inset 0 0 0 1px #ffffff4d}.cj-pin{position:absolute;top:3px;right:3px;width:8px;height:8px;border-radius:50%;background:#fff9;border:1px solid rgba(0,0,0,.2)}.cj-cell.drag-hover-valid{outline:3px solid #22c55e;outline-offset:-1px}.cj-palette{justify-content:center;padding:8px}.cj-tile{border-radius:6px;border:2px solid var(--border);transition:opacity .2s,transform .15s,border-color .15s;cursor:pointer}.cj-tile.selected{border-color:#1a1a2e;transform:scale(1.15);box-shadow:0 2px 8px #00000040}.cj-ghost{position:fixed;width:44px;height:44px;border-radius:8px;opacity:.85;pointer-events:none;z-index:9999;box-shadow:0 4px 12px #0000004d}@media(max-width:480px){.cj-palette{max-width:300px}}
