*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#121212;--bg-raised:#181818;--bg-input:#121212;--border:#2a2a2a;--border-hover:#555;--text:#ddd;--text-muted:#888;--text-dim:#666;--accent:#4a90d9;--accent-bg:#1a2233;--accent-hover:#5aa0e9;--error:#e57373;--canvas-grid:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='100%25'%3E%3Cline x1='50%25' y1='0' x2='50%25' y2='100%25' stroke='%23444' stroke-width='1' stroke-dasharray='6,6'/%3E%3Cline x1='0' y1='50%25' x2='100%25' y2='50%25' stroke='%23444' stroke-width='1' stroke-dasharray='6,6'/%3E%3Cline x1='0' y1='0' x2='100%25' y2='100%25' stroke='%23444' stroke-width='1' stroke-dasharray='6,6'/%3E%3Cline x1='100%25' y1='0' x2='0' y2='100%25' stroke='%23444' stroke-width='1' stroke-dasharray='6,6'/%3E%3C/svg%3E");--canvas-stroke:#eee;--canvas-outline:#333;--canvas-stroke-color:#888}[data-theme=light]{--bg:#f5f5f5;--bg-raised:#fff;--bg-input:#fff;--border:#ddd;--border-hover:#aaa;--text:#222;--text-muted:#777;--text-dim:#999;--accent:#3b7dd8;--accent-bg:#e8f0fc;--accent-hover:#2b6dc8;--error:#d32f2f;--canvas-grid:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='100%25'%3E%3Cline x1='50%25' y1='0' x2='50%25' y2='100%25' stroke='%23ccc' stroke-width='1' stroke-dasharray='6,6'/%3E%3Cline x1='0' y1='50%25' x2='100%25' y2='50%25' stroke='%23ccc' stroke-width='1' stroke-dasharray='6,6'/%3E%3Cline x1='0' y1='0' x2='100%25' y2='100%25' stroke='%23ccc' stroke-width='1' stroke-dasharray='6,6'/%3E%3Cline x1='100%25' y1='0' x2='0' y2='100%25' stroke='%23ccc' stroke-width='1' stroke-dasharray='6,6'/%3E%3C/svg%3E");--canvas-stroke:#333;--canvas-outline:#ccc;--canvas-stroke-color:#555}body{-webkit-font-smoothing:antialiased;background:var(--bg);color:var(--text);overscroll-behavior:none;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;font-family:-apple-system,system-ui,Segoe UI,Roboto,sans-serif}#root{width:100%}.loading{min-height:100svh;color:var(--text-dim);justify-content:center;align-items:center;display:flex}.user-picker{flex-direction:column;align-items:center;gap:20px;max-width:360px;margin:0 auto;padding:80px 20px;display:flex}.user-picker-header{justify-content:space-between;align-items:center;width:100%;display:flex}.user-picker h1{font-size:28px;font-weight:300}.user-picker>p{color:var(--text-muted);font-size:14px}.user-list{flex-direction:column;gap:8px;width:100%;display:flex}.user-btn{border:1px solid var(--border);background:var(--bg-raised);width:100%;color:var(--text);cursor:pointer;text-align:left;border-radius:10px;padding:14px 16px;font-size:16px;transition:border-color .15s,background .15s}.user-btn:hover{border-color:var(--accent);background:var(--accent-bg)}.user-create{gap:8px;width:100%;margin-top:8px;display:flex}.user-create input{border:1px solid var(--border);background:var(--bg-input);color:var(--text);border-radius:8px;outline:none;flex:1;padding:12px 14px;font-size:15px}.user-create input:focus{border-color:var(--accent)}.user-create button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;padding:12px 20px;font-size:15px}.user-create button:hover{background:var(--accent-hover)}.error{color:var(--error);font-size:13px}.welcome{flex-direction:column;align-items:center;gap:16px;max-width:480px;margin:0 auto;padding:60px 20px;display:flex}.welcome-header{justify-content:space-between;align-items:center;width:100%;display:flex}.welcome-header h1{font-size:24px;font-weight:300}.welcome-actions{align-items:center;gap:8px;display:flex}.icon-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;display:flex}.icon-btn:hover{border-color:var(--border-hover);color:var(--text)}.user-badge{background:var(--bg-raised);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;border-radius:20px;padding:6px 14px;font-size:13px}.user-badge:hover{border-color:var(--border-hover);color:var(--text)}.welcome>p{color:var(--text-dim);align-self:flex-start;font-size:14px}.module-list{flex-wrap:wrap;gap:12px;width:100%;margin-top:8px;display:flex}.module-card{border:1px solid var(--border);background:var(--bg-raised);cursor:pointer;color:var(--text);border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:10px;min-width:140px;padding:28px 36px;font-size:15px;transition:border-color .15s,background .15s;display:flex}.module-card:hover{border-color:var(--accent);background:var(--accent-bg)}.module-icon{font-size:40px}.empty{color:var(--text-dim)}.app-shell{width:100%}.app-header{background:var(--bg-raised);border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:10px 16px;display:flex}.back-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:14px}.back-btn:hover{color:var(--text)}.app-title{color:var(--text-muted);font-size:15px}.header-user{color:var(--text-dim);cursor:pointer;align-items:center;gap:6px;margin-left:auto;font-size:13px;display:flex}.header-user:hover{color:var(--text-muted)}.header-level{background:var(--accent-bg);color:var(--accent);border-radius:8px;padding:2px 6px;font-size:11px;font-weight:600}.sync-badge{color:#fff;background:#ff9800;border-radius:8px;margin-right:4px;padding:1px 5px;font-size:10px;font-weight:600}.offline-badge{color:#fff;background:#d32f2f;border-radius:8px;margin-right:4px;padding:1px 5px;font-size:10px;font-weight:600}.welcome-level{color:var(--accent);margin-bottom:4px;font-size:16px;font-weight:500}.settings-page{max-width:420px;margin:0 auto;padding:0 20px 40px}.settings-header{align-items:center;gap:12px;padding:16px 0;display:flex}.settings-header h2{font-size:20px;font-weight:400}.settings-section{background:var(--bg-raised);border:1px solid var(--border);border-radius:10px;margin-bottom:12px;padding:16px 20px}.settings-section h3{color:var(--text-muted);margin-bottom:10px;font-size:13px;font-weight:400}.settings-name-row{align-items:center;gap:8px;display:flex}.settings-name-row input{border:1px solid var(--border);background:var(--bg-input);color:var(--text);border-radius:8px;outline:none;flex:1;padding:10px 12px;font-size:15px}.settings-name-row input:focus{border-color:var(--accent)}.settings-saving{color:var(--text-dim);font-size:12px}.settings-options{gap:8px;display:flex}.settings-option{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;text-align:center;border-radius:8px;flex:1;padding:10px 16px;font-size:14px;transition:border-color .15s,background .15s}.settings-option:hover{border-color:var(--border-hover)}.settings-option.active{border-color:var(--accent);background:var(--accent-bg);color:var(--text)}.settings-logout{border:1px solid var(--border);width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;padding:10px;font-size:14px}.settings-logout:hover{border-color:var(--border-hover);color:var(--text)}.admin-page{width:100%;max-width:100%;margin:0 auto;padding:0 16px 40px}.admin-header{align-items:center;gap:12px;padding:16px 0;display:flex}.admin-header h2{font-size:20px;font-weight:400}.admin-tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:20px;display:flex}.admin-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 16px;font-size:14px}.admin-tab:hover{color:var(--text)}.admin-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.admin-content{min-height:200px}.admin-empty{color:var(--text-dim);text-align:center;padding:40px}.admin-table{border-collapse:collapse;width:100%;font-size:13px}.admin-table th,.admin-table td{border:1px solid var(--border);text-align:left;white-space:nowrap;padding:8px 12px}.admin-table th{background:var(--bg-raised);color:var(--text-muted);font-weight:500}.admin-table td{color:var(--text)}.admin-clickable-row{cursor:pointer}.admin-clickable-row:hover td{background:var(--accent-bg)}.admin-delete-btn,.sa-delete-btn{color:#fff;cursor:pointer;background:#c62828;border:none;border-radius:4px;padding:4px 10px;font-size:12px}.admin-delete-btn:hover,.sa-delete-btn:hover{background:#e53935}.module-toggle-list{flex-direction:column;gap:8px;display:flex}.module-toggle-row{background:var(--bg-raised);border:1px solid var(--border);border-radius:10px;align-items:center;gap:14px;padding:14px 16px;display:flex}.module-toggle-row.clickable{cursor:pointer}.module-toggle-row.clickable:hover{border-color:var(--accent)}.module-toggle-row.disabled{opacity:.5}.module-toggle-icon{font-size:28px}.module-toggle-info{flex-direction:column;flex:1;display:flex}.module-toggle-name{color:var(--text);font-size:15px}.module-toggle-zh{color:var(--text-muted);font-size:12px}.toggle-switch{flex-shrink:0;width:44px;height:24px;position:relative}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{background:var(--border);cursor:pointer;border-radius:24px;transition:background .2s;position:absolute;inset:0}.toggle-slider:before{content:"";background:var(--text);border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;bottom:3px;left:3px}.toggle-switch input:checked+.toggle-slider{background:var(--accent)}.toggle-switch input:checked+.toggle-slider:before{background:#fff;transform:translate(20px)}.sql-browser{gap:16px;min-height:400px;display:flex}.sql-sidebar{flex-direction:column;flex-shrink:0;gap:12px;width:180px;display:flex}.sql-db-select{flex-direction:column;gap:4px;display:flex}.sql-db-btn{border:1px solid var(--border);background:var(--bg-raised);color:var(--text-muted);cursor:pointer;text-align:left;border-radius:6px;padding:8px 12px;font-size:13px}.sql-db-btn.active{border-color:var(--accent);color:var(--text);background:var(--accent-bg)}.sql-tables h4{text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);margin-bottom:6px;font-size:11px;font-weight:500}.sql-table-btn{width:100%;color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:4px;padding:5px 10px;font-family:monospace;font-size:13px;display:block}.sql-table-btn:hover{background:var(--bg-raised);color:var(--text)}.sql-main{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.sql-input-row{gap:8px;display:flex}.sql-input{border:1px solid var(--border);background:var(--bg-input);color:var(--text);resize:vertical;border-radius:8px;outline:none;flex:1;padding:10px 12px;font-family:monospace;font-size:13px}.sql-input:focus{border-color:var(--accent)}.sql-run-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;align-self:flex-start;padding:10px 20px;font-size:13px}.sql-run-btn:hover{background:var(--accent-hover)}.sql-run-btn:disabled{opacity:.5}.sql-hint{color:var(--text-dim);font-size:11px}.sql-error{color:var(--error);background:var(--bg-raised);border-radius:6px;padding:8px 12px;font-family:monospace;font-size:13px}.sql-result{flex-direction:column;gap:6px;display:flex}.sql-row-count{color:var(--text-dim);font-size:12px}.sql-table-wrap{overflow-x:auto}.sql-null{color:var(--text-dim);font-style:italic}.user-detail-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.user-detail-header h3{font-size:18px;font-weight:400}.user-detail-summary{flex-wrap:wrap;gap:12px;margin-bottom:20px;display:flex}.user-detail-stat{background:var(--bg-raised);border:1px solid var(--border);border-radius:8px;flex-direction:column;align-items:center;min-width:100px;padding:12px 20px;display:flex}.user-detail-stat-value{color:var(--text);font-size:22px;font-weight:500}.user-detail-stat-label{color:var(--text-dim);margin-top:2px;font-size:11px}.user-detail-table-wrap{overflow-x:auto}.user-detail-char{font-size:20px}.ud-rank{color:var(--text-dim);font-family:monospace;font-size:12px}.ud-level{color:var(--accent);font-size:12px;font-weight:500}.ud-perfect{color:#4caf50}.ud-correct{color:#8bc34a}.ud-incorrect{color:#f44336}.ud-result{text-align:center;color:#fff;border-radius:4px;width:20px;height:20px;font-size:11px;font-weight:600;line-height:20px;display:inline-block}.ud-result.ud-perfect{background:#4caf50}.ud-result.ud-correct{background:#8bc34a}.ud-result.ud-incorrect{background:#f44336}.ud-recent{align-items:center;gap:3px;display:flex}.ud-dot{border-radius:50%;width:8px;height:8px}.ud-dot.ud-perfect{background:#4caf50}.ud-dot.ud-correct{background:#8bc34a}.ud-dot.ud-incorrect{background:#f44336}.ud-dot.ud-skip{background:var(--text,#fff);opacity:.4}.ud-mastery{background:var(--border);border-radius:4px;width:60px;height:20px;position:relative;overflow:hidden}.ud-mastery-bar{border-radius:4px;height:100%;transition:width .3s}.ud-mastery-value{color:#fff;text-shadow:0 1px 2px #00000080;justify-content:center;align-items:center;font-size:11px;font-weight:600;display:flex;position:absolute;inset:0}.ud-date{color:var(--text-dim);white-space:nowrap;font-size:12px}.sa-page-title{color:var(--text);margin-bottom:16px;font-size:22px;font-weight:400}.sa-container h3{color:var(--text);margin-bottom:16px;font-weight:400}.sa-collapsible{background:var(--bg-raised);border:1px solid var(--border);border-radius:10px;margin-bottom:12px;overflow:hidden}.sa-collapsible-header{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:14px 18px;font-size:15px;font-weight:500;display:flex}.sa-collapsible-header:hover{background:var(--bg)}.sa-collapse-arrow{color:var(--text-muted);font-size:12px;transition:transform .15s}.sa-collapse-arrow.open{transform:rotate(90deg)}.sa-collapsible-body{padding:0 18px 16px}.sa-infotip{cursor:pointer;margin-left:4px;display:inline-flex;position:relative}.sa-infotip-icon{border:1px solid var(--text-dim);width:16px;height:16px;color:var(--text-dim);border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-style:italic;font-weight:600;display:inline-flex}.sa-infotip:hover .sa-infotip-icon{border-color:var(--accent);color:var(--accent)}.sa-infotip-text{background:var(--bg-raised);border:1px solid var(--border);color:var(--text-muted);z-index:1000;pointer-events:none;border-radius:8px;width:280px;max-width:90vw;padding:8px 12px;font-size:12px;font-style:normal;font-weight:400;line-height:1.5;position:fixed;box-shadow:0 4px 12px #0000004d}.sa-formula{background:var(--bg);border:1px solid var(--border);border-radius:8px;margin-bottom:16px;padding:14px 16px;font-size:13px}.sa-formula-title{color:var(--text-muted);margin-top:10px;margin-bottom:4px;font-size:12px;font-weight:600}.sa-formula-title:first-child{margin-top:0}.sa-known-criterion{border-left:2px solid var(--border);margin:6px 0;padding-left:10px}.sa-formula code{color:var(--accent);background:var(--bg-raised);border-radius:4px;margin:4px 0;padding:6px 10px;font-size:12px;line-height:1.5;display:block}.sa-formula-detail{flex-direction:column;gap:2px;margin-top:4px;padding-left:10px;display:flex}.sa-formula-detail span{color:var(--text-dim);font-size:11px;line-height:1.5}.sa-setting-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:8px;display:flex}@media (width<=430px){.sa-setting-row{flex-direction:column;align-items:flex-start;gap:6px}.sa-setting-row input[type=range]{width:100%}.sa-setting-row label{min-width:unset}}.sa-setting-row label{color:var(--text-muted);min-width:140px;font-size:13px}.sa-setting-row input[type=range]{accent-color:var(--accent);flex:1}.sa-setting-row select{border:1px solid var(--border);background:var(--bg-raised);color:var(--text);appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border-radius:6px;outline:none;padding:6px 24px 6px 10px;font-size:13px}.sa-setting-row select:focus{border-color:var(--accent)}.sa-weight-triple{margin-bottom:12px}.sa-weight-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.sa-weight-header span:first-child{color:var(--text-muted);font-size:13px}.sa-weight-total{color:var(--text);font-size:13px;font-weight:600}.sa-weight-total.invalid{color:var(--error)}.sa-weight-bars{border-radius:4px;gap:2px;height:8px;margin-bottom:12px;display:flex;overflow:hidden}.sa-weight-bar{min-width:2px}.sa-weight-bar-fill{border-radius:4px;height:100%;display:block}.sa-weight-bar-fill.recent{background:#4a90d9}.sa-weight-bar-fill.overall{background:#8bc34a}.sa-weight-bar-fill.streak{background:#ff9800}.sa-weight-row{align-items:center;gap:12px;margin-bottom:6px;display:flex}.sa-weight-row label{color:var(--text-muted);min-width:60px;font-size:13px}.sa-weight-row label:before{content:"";border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.sa-weight-row:nth-child(3) label:before{background:#4a90d9}.sa-weight-row:nth-child(4) label:before{background:#8bc34a}.sa-weight-row:nth-child(5) label:before{background:#ff9800}.sa-weight-row input[type=range]{accent-color:var(--accent);flex:1}.sa-seed-hint{color:var(--text-dim);margin-bottom:8px;font-size:12px}.sa-seed-input{border:1px solid var(--border);background:var(--bg-input);width:100%;color:var(--text);letter-spacing:2px;resize:vertical;border-radius:8px;outline:none;padding:10px 12px;font-family:inherit;font-size:18px}.sa-seed-input:focus{border-color:var(--accent)}.sa-seed-preview{flex-wrap:wrap;gap:4px;margin-top:10px;display:flex}.sa-slot-preview{flex-wrap:wrap;align-items:center;gap:3px;font-size:16px;display:flex}.sa-slot-tag{color:#fff;border-radius:4px;margin:0 2px;padding:2px 8px;font-size:12px;font-weight:600;display:inline-block}.sa-merge-fields{flex-wrap:wrap;align-items:center;gap:6px;margin-top:10px;display:flex}.sa-merge-field{cursor:pointer;border:1px solid;border-radius:4px;padding:3px 8px;font-size:12px;font-weight:500;transition:opacity .15s;position:relative}.sa-merge-field:hover{opacity:.8}.sa-merge-field:hover:after{content:attr(title) ", ...";background:var(--bg-raised);border:1px solid var(--border);color:var(--text-muted);white-space:nowrap;z-index:10;pointer-events:none;border-radius:6px;margin-bottom:4px;padding:4px 8px;font-size:11px;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #0000004d}.sa-template-item{padding:4px 0}.sa-template-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.sa-toggle-group{gap:4px;display:flex}.sa-toggle-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:13px}.sa-toggle-btn.active{border-color:var(--accent);background:var(--accent-bg);color:var(--text)}.sa-setting-value{color:var(--text);text-align:right;min-width:30px;font-size:14px;font-weight:500}.sa-add-section{margin-bottom:16px}.sa-add-row{gap:8px;margin-bottom:8px;display:flex}.sa-input-trad{border:1px solid var(--border);background:var(--bg-input);color:var(--text);border-radius:8px;outline:none;flex:2;padding:10px 12px;font-size:16px}.sa-input-english{border:1px solid var(--border);background:var(--bg-input);color:var(--text);border-radius:8px;outline:none;flex:3;padding:10px 12px;font-size:14px}.sa-input-trad:focus,.sa-input-english:focus{border-color:var(--accent)}.sa-add-btn{background:var(--accent);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:10px 20px;font-size:14px}.sa-add-btn:hover{background:var(--accent-hover)}.sa-analysis{margin-top:8px}.sa-char-line{flex-wrap:wrap;align-items:flex-start;gap:12px;margin-bottom:6px;display:flex}.sa-char-row{flex-wrap:wrap;gap:4px;display:flex}.sa-char-item{flex-direction:column;align-items:center;gap:2px;display:flex}.sa-char{color:var(--text);font-size:20px}.level-badge{border-radius:3px;padding:1px 5px;font-size:10px;font-weight:600;line-height:1.4}.sa-stats{color:var(--text-muted);gap:12px;font-size:12px;display:flex}.sa-stats b{color:var(--text)}.sa-warn{color:var(--error)}.sa-dim{color:var(--text-dim);font-size:13px}.sa-char-summary{margin-bottom:16px}.sa-char-summary h4{color:var(--text-muted);margin-bottom:10px;font-size:13px;font-weight:500}.sa-level-group{margin-bottom:10px}.sa-level-group:last-child{margin-bottom:0}.sa-level-header{align-items:center;gap:6px;margin-bottom:6px;display:flex}.sa-level-count{color:var(--text-dim);font-size:12px}.sa-char-grid{flex-wrap:wrap;gap:6px;display:flex}.sa-char-cell{flex-direction:column;align-items:center;gap:2px;min-width:32px;display:flex}.sa-char-count{color:var(--text-dim);font-size:10px}.sa-list{flex-direction:column;gap:8px;display:flex}.sa-item{border-bottom:1px solid var(--border);padding:12px 0}.sa-item:last-child{border-bottom:none}.sa-item-header{align-items:center;gap:12px;margin-bottom:8px;display:flex}.sa-item-trad{color:var(--text);font-size:18px}.sa-item-english{color:var(--text-muted);flex:1;padding-top:6px;font-size:13px}.sa-item-actions{flex-shrink:0;gap:4px;display:flex}.sa-edit-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:4px;padding:4px 10px;font-size:12px}.sa-edit-btn:hover{border-color:var(--accent);color:var(--accent)}.sa-edit{flex-direction:column;gap:8px;display:flex}.sa-edit-actions{gap:6px;display:flex}.sa-save-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:6px 16px;font-size:13px}.sa-cancel-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:6px 16px;font-size:13px}.sa-mf-item{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.sa-mf-label{color:var(--text);min-width:70px;font-weight:500}.sa-mf-grammar{color:var(--text-muted);background:var(--bg);border-radius:4px;padding:2px 8px;font-size:12px}.sa-mf-example{flex:1;min-width:80px;font-size:12px}.sa-mf-edit-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.sa-mf-edit-row select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:6px;padding:6px 8px;font-size:13px}.sa-mf-preview{color:var(--text-muted);margin-top:6px;font-size:13px}.sa-mf-wordlist{border-top:1px solid var(--border);margin-top:8px;padding:8px 0}.sa-mf-words{flex-wrap:wrap;gap:4px;margin-bottom:8px;display:flex}.sa-mf-word-pill{color:var(--text);background:var(--bg);border:1px solid;border-radius:12px;align-items:center;gap:4px;padding:3px 8px;font-size:14px;display:inline-flex}.sa-mf-word-x{cursor:pointer;color:var(--text-muted);padding:0 2px;font-size:14px;line-height:1}.sa-mf-word-x:hover{color:#f44336}.sa-mf-word-pill{cursor:pointer}.sa-mf-word-pill.editing{background:var(--bg-raised);border-color:var(--accent)!important}.sa-mf-word-eng{color:var(--text-muted);margin-left:2px;font-size:11px}.sa-mf-eng-edit{align-items:center;gap:6px;padding:6px 0;display:flex}.sa-mf-eng-label{min-width:40px;font-size:16px;font-weight:500}.sa-mf-word-add{align-items:center;gap:6px;display:flex}.sa-template-sample{color:var(--text-muted);margin-top:4px;font-size:14px}.mastery-bar{background:#ffffff14;border-radius:2px;width:100%;height:3px;margin-top:4px;display:block;overflow:hidden}.mastery-bar-fill{height:100%;transition:width .3s,background .3s;display:block}.settings-group{background:var(--bg-raised);border:1px solid var(--border);border-radius:10px;margin-bottom:12px;overflow:hidden}.settings-group-header{width:100%;color:var(--text);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:14px 18px;font-size:15px;font-weight:500;display:flex}.settings-group-header:hover{background:var(--bg)}.settings-group-arrow{color:var(--text-muted);font-size:12px;transition:transform .15s}.settings-group-arrow.open{transform:rotate(90deg)}.settings-group-title{flex:1}.settings-group-count{color:var(--text-dim);background:var(--bg);text-align:center;border-radius:10px;min-width:24px;padding:2px 8px;font-size:12px}.settings-group-body{padding:0 18px 16px}.settings-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:8px;display:flex}@media (width<=430px){.settings-row{flex-direction:column;align-items:flex-start;gap:6px}.settings-row input[type=range]{width:100%}}.settings-row label{color:var(--text-muted);min-width:140px;font-size:13px}.settings-row input[type=range]{accent-color:var(--accent);flex:1}.settings-value{color:var(--text);text-align:right;min-width:30px;font-size:14px;font-weight:500}.settings-infotip{cursor:pointer;margin-left:4px;display:inline-flex;position:relative}.settings-infotip-icon{border:1px solid var(--text-dim);width:16px;height:16px;color:var(--text-dim);border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-style:italic;font-weight:600;display:inline-flex}.settings-infotip:hover .settings-infotip-icon{border-color:var(--accent);color:var(--accent)}.settings-infotip-text{background:var(--bg-raised);border:1px solid var(--border);color:var(--text-muted);z-index:1000;pointer-events:none;border-radius:8px;width:260px;max-width:90vw;padding:8px 12px;font-size:12px;font-style:normal;font-weight:400;line-height:1.5;position:fixed;box-shadow:0 4px 12px #0000004d}.settings-toggle-group{gap:4px;display:flex}.settings-toggle-btn{border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:13px}.settings-toggle-btn.active{border-color:var(--accent);background:var(--accent-bg);color:var(--text)}.admin-debug-toggle{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;border-radius:6px;margin-left:auto;padding:4px 10px;font-size:12px}.admin-debug-toggle.on{border-color:var(--accent);color:var(--accent)}.debug-icon{cursor:pointer;z-index:9999;background:0 0;border:none;width:30px;height:30px;padding:0;position:fixed;top:52px;left:8px}.debug-bubble{color:#fff9;background:#0006;border-radius:8px 8px 8px 2px;justify-content:center;align-items:center;width:26px;height:22px;font-family:serif;font-size:13px;font-weight:700;display:flex}.debug-overlay{color:#ffffffb3;z-index:9999;background:#00000080;border-radius:8px;flex-direction:column;gap:2px;padding:6px 10px;font-family:monospace;font-size:11px;line-height:1.4;display:flex;position:fixed;top:50px;left:8px}.debug-close{color:#ffffff80;cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:12px;position:absolute;top:2px;right:4px}.debug-line{gap:6px;display:flex}.debug-line-label{color:#fff6;min-width:40px}.sa-input{border:1px solid var(--border);background:var(--bg-input);color:var(--text);border-radius:6px;outline:none;padding:8px 10px;font-size:14px}.sa-input:focus{border-color:var(--accent)}.ws-admin-cat{border:1px solid var(--border);border-radius:8px;margin-bottom:8px;overflow:hidden}.ws-admin-cat-header{cursor:pointer;background:var(--bg-raised);align-items:center;gap:8px;padding:10px 12px;display:flex}.ws-admin-cat-header:hover{background:var(--bg-hover)}.ws-admin-cat-icon{font-size:18px}.ws-admin-cat-name{flex:1;font-size:14px;font-weight:500}.ws-admin-cat-count{color:var(--text-muted);font-size:12px}.ws-admin-cat-body{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding:12px;display:flex}.ws-admin-search{gap:6px;display:flex}.ws-admin-search-results{border:1px solid var(--border);border-radius:6px;max-height:200px;overflow-y:auto}.ws-admin-search-row{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:6px 10px;font-size:13px;display:flex}.ws-admin-search-row:last-child{border-bottom:none}.ws-admin-search-word{min-width:50px;font-size:16px}.ws-admin-search-def{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.ws-admin-search-level{color:var(--text-dim);font-size:11px}.ws-admin-manual{flex-wrap:wrap;gap:6px;display:flex}.ws-admin-words{flex-direction:column;display:flex}.ws-admin-word-row{border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:6px 0;font-size:13px;display:flex}.ws-admin-word-arrows{flex-direction:column;flex-shrink:0;gap:1px;display:flex}.ws-arrow-btn{border:1px solid var(--border);background:var(--bg-raised);color:var(--text-muted);cursor:pointer;-webkit-appearance:none;border-radius:3px;padding:1px 6px;font-size:9px;line-height:1}.ws-arrow-btn:disabled{opacity:.2;cursor:default}.ws-arrow-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.ws-admin-word-char{min-width:40px;font-size:18px}.ws-admin-word-zhuyin{color:var(--text-muted);min-width:60px;font-size:12px}.ws-admin-word-def{color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.ws-admin-word-level{color:var(--accent);flex-shrink:0;font-size:11px}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{color:var(--accent)}.my-chars-page{max-width:600px;margin:0 auto;padding:16px}.my-chars-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.my-chars-summary{gap:12px;margin-bottom:20px;display:flex}.my-chars-stat{border:1px solid var(--border);background:var(--bg-raised);border-radius:10px;flex-direction:column;flex:1;align-items:center;padding:12px;display:flex}.my-chars-stat-value{font-size:24px;font-weight:600}.my-chars-stat-label{color:var(--text-muted);font-size:12px}.my-chars-level{background:var(--accent-bg);border-color:var(--accent)}.my-chars-level-value{color:var(--accent);font-size:32px;font-weight:700}.my-chars-section{margin-bottom:20px}.my-chars-section h3{color:var(--text-muted);margin-bottom:8px;font-size:14px}.my-chars-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px;display:grid}.my-char-tile{border:1px solid var(--border);background:var(--bg-raised);cursor:pointer;touch-action:manipulation;border-radius:10px;flex-direction:column;align-items:center;gap:3px;padding:10px 4px 6px;display:flex;position:relative;overflow:hidden}.my-char-tile:active{transform:scale(.97)}.my-char-corner{border:14px solid #0000;border-width:0 14px 14px 0;width:0;height:0;position:absolute;top:0;right:0}.my-char-corner-below{border-right-color:#4a90d9}.my-char-corner-target{border-right-color:#4caf50}.my-char-corner-above{border-right-color:#f44336}.my-char-known{border-color:#4caf50}.my-char-learning{border-color:var(--border)}.my-char-big{font-size:28px}.my-char-meta{align-items:center;gap:4px;display:flex}.my-char-rank{color:var(--text-dim);background:var(--bg);border-radius:4px;padding:1px 5px;font-size:9px}.my-char-level{color:var(--accent);background:var(--accent-bg);border-radius:4px;padding:1px 5px;font-size:9px}.my-char-recent{gap:2px;display:flex}.my-char-dot{border-radius:50%;width:6px;height:6px;display:inline-block}.my-char-dot-P{background:#4caf50}.my-char-dot-C{background:#ff9800}.my-char-dot-I{background:#f44336}.my-char-dot-S{background:var(--text,#fff);opacity:.4}.ws-practice-overlay{z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.ws-practice-modal{background:var(--bg,#1a1a1a);border:1px solid var(--border,#333);border-radius:16px;flex-direction:column;align-items:center;gap:12px;width:90%;max-width:340px;padding:24px;display:flex}.ws-practice-char-display{font-size:40px;font-weight:600}.ws-practice-controls{align-items:center;gap:12px;display:flex}.ws-close-btn{border:1px solid var(--border,#444);background:var(--bg-raised,#2a2a2a);width:44px;height:44px;color:var(--text-muted,#aaa);cursor:pointer;touch-action:manipulation;border-radius:8px;justify-content:center;align-items:center;font-size:20px;display:flex}.canvas-wrapper{border:3px solid var(--border,#666);background:var(--bg,#1a1a1a);aspect-ratio:1;background-image:var(--canvas-grid);background-size:100% 100%;border-radius:4px}.canvas-wrapper canvas{max-width:100%;display:block}.quiz-status{color:var(--text-muted,#aaa);z-index:3;pointer-events:none;font-size:16px;position:absolute;bottom:8px;right:12px}.quiz-mistakes{color:var(--error,#e57373);z-index:3;pointer-events:none;font-size:14px;position:absolute;top:8px;right:12px}.sp-hint-btn,.sp-show-btn,.sp-audio-btn{border:1px solid var(--border,#444);background:var(--bg-raised,#2a2a2a);width:44px;height:44px;color:var(--text,#fff);cursor:pointer;touch-action:manipulation;border-radius:8px;justify-content:center;align-items:center;font-size:20px;display:flex}.sp-audio-btn{font-size:24px}.sp-hint-btn:disabled,.sp-show-btn:disabled{opacity:.3;cursor:default}.sp-show-btn.active{border-color:var(--accent,#4a90d9);background:var(--accent-bg,#1a2a3a)}.sp-skip-btn{border:1px solid var(--border,#444);background:var(--bg-raised,#2a2a2a);color:var(--text-muted,#aaa);cursor:pointer;touch-action:manipulation;border-radius:6px;padding:8px 16px;font-size:14px}.dict-panel{flex-direction:column;gap:12px;display:flex}.dict-list{flex-direction:column;gap:8px;display:flex}.dict-card{border:1px solid var(--border);background:var(--bg-raised);color:var(--text);cursor:pointer;text-align:left;-webkit-appearance:none;border-radius:10px;flex-direction:column;gap:4px;padding:16px;display:flex}.dict-card:hover{border-color:var(--accent)}.dict-card-name{font-size:18px;font-weight:600}.dict-card-code{color:var(--text-muted);font-size:13px}.dict-card-stats{color:var(--text-dim);gap:16px;margin-top:4px;font-size:12px;display:flex}.dict-header{align-items:center;gap:12px;display:flex}.dict-controls{flex-direction:column;gap:8px;display:flex}.dict-tabs{gap:4px;display:flex}.dict-tab{border:1px solid var(--border);background:var(--bg-raised);color:var(--text-muted);cursor:pointer;-webkit-appearance:none;border-radius:6px;padding:6px 16px;font-size:13px}.dict-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.dict-search{gap:6px;display:flex}.dict-char-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:6px;display:grid}.dict-char-cell{border:1px solid var(--border);background:var(--bg-raised);color:var(--text);cursor:pointer;-webkit-appearance:none;border-radius:8px;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;display:flex}.dict-char-cell:hover{border-color:var(--accent)}.dict-char-big{font-size:28px}.dict-char-strokes{color:var(--text-dim);font-size:10px}.dict-char-level{color:var(--text-muted);font-size:10px}.dict-word-table{flex-direction:column;display:flex}.dict-word-row{border-bottom:1px solid var(--border);align-items:baseline;gap:8px;padding:6px 0;font-size:13px;display:flex}.dict-word-text{min-width:60px;font-size:18px}.dict-word-zhuyin{color:var(--text-muted);min-width:70px;font-size:12px}.dict-word-level{color:var(--accent);min-width:40px;font-size:11px}.dict-word-grammar{color:var(--text-dim);min-width:50px;font-size:11px}.dict-word-def{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.dict-pager{color:var(--text-muted);justify-content:center;align-items:center;gap:16px;padding:8px;font-size:13px;display:flex}.dict-pager button{border:1px solid var(--border);background:var(--bg-raised);color:var(--text-muted);cursor:pointer;-webkit-appearance:none;border-radius:6px;padding:6px 14px;font-size:12px}.dict-pager button:disabled{opacity:.4;cursor:default}.dict-pager button:hover:not(:disabled){border-color:var(--accent)}.dict-detail-char{font-size:36px}.dict-char-preview{justify-content:center;gap:16px;padding:8px 0;display:flex}.dict-char-canvas{border:2px solid var(--border);background:var(--bg);border-radius:8px;width:150px;height:150px}.dict-detail{flex-direction:column;gap:12px;display:flex}.dict-detail-section{flex-direction:column;gap:4px;display:flex}.dict-detail-row{border-bottom:1px solid var(--border);gap:12px;padding:4px 0;font-size:14px;display:flex}.dict-detail-label{min-width:120px;color:var(--text-muted);font-size:12px}.dict-detail-words{flex-direction:column;display:flex}.dict-detail-word-row{border-bottom:1px solid var(--border);align-items:baseline;gap:8px;padding:4px 0;font-size:13px;display:flex}.dict-detail-word{min-width:50px;font-size:16px}.dict-detail-word-level{color:var(--accent);min-width:40px;font-size:11px}.dict-detail-word-def{color:var(--text-muted);flex:1}
