*,*: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-timer{font-size:12px;font-variant-numeric:tabular-nums;color:var(--text-dim);padding:3px 8px;border-radius:999px;background:var(--surface-hover);white-space:nowrap}.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)}.about-page .about-version{margin-top:24px;font-size:12px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--text-dim);opacity:.7;border-top:1px solid var(--border);padding-top:12px}.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}.home-stats{margin:0 16px 16px;padding:12px 14px;border-radius:10px;background:var(--surface);border:1px solid var(--border);display:flex;flex-wrap:wrap;gap:10px 18px;align-items:stretch}.home-stat{display:flex;flex-direction:column;align-items:flex-start;min-width:72px}.home-stat-num{font-size:22px;font-weight:700;line-height:1.1;font-variant-numeric:tabular-nums;color:var(--accent, #2563eb)}.home-stat-label{font-size:12px;color:var(--text-dim);margin-top:2px}.home-stats-empty{font-size:13px;color:var(--text-dim);align-self:center}.screen-time-notice{margin:0 16px 16px;padding:10px 14px;border-radius:10px;background:#fff8e6;border:1px solid #fde68a;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:6px 12px;font-size:13px;line-height:1.45;color:#78350f}.screen-time-text{flex:1 1 240px}.screen-time-counter{flex:0 0 auto;font-weight:600;white-space:nowrap}.screen-time-amount{font-variant-numeric:tabular-nums}.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}.tag-multiplayer{background:#ede9fe;color:#6d28d9}.tag-date{background:#e0e7ff;color:#3730a3;font-variant-numeric:tabular-nums;cursor:help}.theme-grid-section{padding:0 0 24px}.theme-section-title{padding:16px 16px 10px;font-size:18px;font-weight:700;color:var(--text)}.theme-section-hint{font-weight:400;color:var(--text-dim);font-size:14px}.theme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;padding:0 16px}.theme-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:20px 12px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);text-decoration:none;color:inherit;text-align:center;transition:transform .15s,box-shadow .15s;min-height:120px}.theme-tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.theme-tile-icon{font-size:36px;line-height:1}.theme-tile-label{font-size:14px;font-weight:600;line-height:1.25}.theme-tile-count{font-size:11px;color:var(--text-dim);background:var(--surface-hover);border-radius:10px;padding:2px 8px}.theme-tile-empty{opacity:.55}.theme-tile-empty .theme-tile-count{font-style:italic}.theme-page-header{display:flex;align-items:center;gap:14px;padding:20px 16px 8px}.theme-page-icon{font-size:40px;line-height:1}.theme-page-title{font-size:24px;font-weight:700;flex:1}.theme-page-count{font-size:12px;color:var(--text-dim);background:var(--surface-hover);border-radius:10px;padding:3px 10px;white-space:nowrap}.theme-drills-section,.theme-puzzles-section{padding-bottom:16px}.drill-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px;padding:0 16px 16px}.drill-card{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--surface);border-radius:var(--radius-sm);box-shadow:var(--shadow);text-decoration:none;color:inherit;transition:transform .15s,box-shadow .15s}.drill-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.drill-card-disabled{opacity:.45;cursor:default;filter:grayscale(.6)}.drill-card-disabled:hover{transform:none;box-shadow:var(--shadow)}.drill-card-icon{font-size:26px;line-height:1;flex-shrink:0}.drill-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.drill-card-name{font-size:14px;font-weight:600;line-height:1.2}.drill-card-desc{font-size:11px;color:var(--text-dim);line-height:1.35;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.drill-card-meta{display:flex;gap:4px;flex-wrap:wrap;margin-top:2px}.empty-msg{padding:16px;color:var(--text-dim);font-size:14px;text-align:center}.tag-kind{font-style:italic;background:var(--surface-hover);color:var(--text-dim)}.tag-kind-drill{background:#e0e7ff;color:#3730a3}.tag-kind-puzzle{background:#ede9fe;color:#5b21b6}.dev-browser-section{border-top:1px dashed var(--border);margin-top:16px;padding-top:8px}.dev-banner{display:flex;align-items:center;gap:8px;padding:6px 12px;margin:0 auto 8px;max-width:max-content;background:#fef3c7;color:#92400e;border:1px dashed #d97706;border-radius:6px;font-size:12px}.dev-banner:empty{display:none}.dev-banner-label{font-weight:600;letter-spacing:.02em}.dev-banner-disable{background:transparent;border:none;color:#92400e;text-decoration:underline;cursor:pointer;font-size:12px;padding:0}.dev-sort-bar:empty{display:none}.about-link{color:var(--accent);text-decoration:underline}.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}.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-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}.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}.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}.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}}.eas-puzzle{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%;max-width:480px;user-select:none;-webkit-user-select:none}.eas-status{font-size:14px;color:var(--text-dim);font-weight:500;min-height:18px}.eas-canvas{background:var(--surface);border:1px solid var(--border);border-radius:12px;touch-action:none}.eas-edge{stroke:#94a3b8;stroke-width:2.5;stroke-linecap:round;pointer-events:none}.eas-edge-conflict{stroke:#ef4444;stroke-width:4;animation:eas-pulse .6s ease-in-out infinite}@keyframes eas-pulse{0%,to{opacity:1}50%{opacity:.5}}.eas-edge-label-bg{fill:#fff;stroke:#94a3b8;stroke-width:1.5;pointer-events:none}.eas-edge-label-bg-conflict{stroke:#ef4444;fill:#fee2e2}.eas-edge-label{fill:#475569;font-size:13px;font-weight:700;pointer-events:none;font-family:system-ui,sans-serif}.eas-edge-label-conflict{fill:#b91c1c}.eas-node-group{cursor:grab}.eas-node-group:active{cursor:grabbing}.eas-node{stroke-width:3;transition:fill .15s,stroke .15s}.eas-node-empty{fill:#f1f5f9;stroke:#94a3b8;stroke-dasharray:4 3}.eas-node-filled{fill:#3b82f6;stroke:#1e3a8a}.eas-node-text{fill:#fff;font-size:22px;font-weight:700;pointer-events:none;font-family:system-ui,sans-serif}.eas-tray{display:flex;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center;padding:10px 12px;border:1px dashed var(--border);border-radius:12px;background:var(--surface);width:100%;max-width:360px;min-height:56px}.eas-tray-label{font-size:12px;color:var(--text-dim);font-weight:500;width:100%;text-align:center;margin-bottom:2px}.eas-tray-tile{width:44px;height:44px;border-radius:50%;background:#3b82f6;color:#fff;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:grab;border:3px solid #1e3a8a;box-shadow:0 1px 3px #00000026;transition:transform .1s,opacity .1s;touch-action:none}.eas-tray-tile:active{cursor:grabbing;transform:scale(1.05)}.eas-tray-tile-placed{background:#e2e8f0;border-color:#cbd5e1;color:#94a3b8;cursor:default;box-shadow:none}.eas-tray-tile-placed:active{transform:none}.eas-tray-tile-dragging{opacity:.3}@media(max-width:480px){.eas-tray-tile{width:38px;height:38px;font-size:16px;border-width:2px}}.mp-switch{position:fixed;top:12px;right:14px;z-index:9100;display:inline-flex;align-items:stretch;padding:3px;gap:3px;border-radius:999px;background:var(--surface, #ffffff);box-shadow:var(--shadow-lg)}.mp-seg{border:none;border-radius:999px;padding:6px 14px;background:transparent;color:var(--text, #1f2440);font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s,transform .15s}.mp-seg:hover{transform:scale(1.04)}.mp-seg.active{color:var(--accent-text);background:var(--accent);cursor:default}.mp-seg[data-mode=multi].active{background:var(--success)}.mp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;background:#0f11208c;display:flex;align-items:center;justify-content:center;padding:16px}.mp-card{position:relative;width:min(92vw,380px);background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:22px 20px 20px;display:flex;flex-direction:column;gap:10px}.mp-title{margin:0;font-size:19px;color:var(--text)}.mp-sub{margin:0;font-size:13px;color:var(--text-dim);line-height:1.4}.mp-label{font-size:12px;font-weight:600;color:var(--text-dim);margin-top:4px}.mp-input{width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:15px;background:var(--bg);color:var(--text)}.mp-code-input{text-transform:uppercase;letter-spacing:.35em;text-align:center;font-weight:700;font-size:20px}.mp-tabs{display:flex;gap:6px;margin-top:6px}.mp-tab{flex:1;padding:8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-dim);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer}.mp-tab.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.mp-variants{display:flex;gap:6px}.mp-variant{flex:1;padding:8px 4px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text-dim);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer}.mp-variant.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.mp-panel{display:flex;flex-direction:column;gap:10px;margin-top:4px}.mp-panel.hidden{display:none}.mp-hint{font-size:12px;color:var(--text-dim)}.mp-code{font-family:var(--font-mono);font-size:30px;font-weight:700;letter-spacing:.3em;text-align:center;color:var(--accent);background:var(--bg);border-radius:var(--radius-sm);padding:12px;-webkit-user-select:all;user-select:all}.mp-warn{margin:0;font-size:12.5px;line-height:1.4;color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:var(--radius-sm);padding:8px 10px}.mp-copy{padding:9px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg);color:var(--text, #1f2440);font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer}.mp-copy:hover{filter:brightness(.97)}.mp-copy.copied{background:#dcfce7;color:#166534;border-color:#bbf7d0}.mp-primary,.mp-secondary{padding:11px;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:15px;font-weight:700;cursor:pointer}.mp-primary{background:var(--accent);color:var(--accent-text)}.mp-primary:hover{background:var(--accent-hover)}.mp-secondary{background:var(--bg);color:var(--error);border:1px solid var(--border)}.mp-close{position:absolute;top:8px;right:10px;border:none;background:none;font-size:22px;line-height:1;color:var(--text-dim);cursor:pointer}.mp-shake{animation:shake .4s}.mp-connecting{align-items:center;text-align:center}.mp-spinner{width:38px;height:38px;margin:8px auto 2px;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:mp-spin .8s linear infinite}@keyframes mp-spin{to{transform:rotate(360deg)}}.mp-status{font-size:13px;color:var(--text-dim);line-height:1.4}@media(max-width:480px){.mp-switch{top:8px;right:8px}.mp-seg{font-size:12px;padding:6px 10px}}
