*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0c3a42;--bg-raised:#fff8e0;--bg-raised-2:#f0e4be;--bg-input:#fffdf7;--border:#5a1a96;--border-hover:#9b55d6;--tile-edge:#0000001f;--chip-upcoming:#00c4b4;--chip-skip:#b9a98c;--chip-above:#ff3e3e;--text:#2d1b00;--text-muted:#6b4c20;--text-dim:#9c8a6a;--accent:#c44f00;--accent-bg:#ffe8c9;--accent-hover:#ff7820;--error:#d32f2f;--success:#4a9a00;--warning:#c44f00;--danger:#d32f2f;--wood:#7a4e28;--wood-dark:#4e3018;--wood-light:#a06c3a;--panel-bg:#fff8e0;--panel-border:#e8c940;--gold:gold;--gold-dark:#b8960c;--pink:#ff4d9e;--pink-dark:#cc2070;--teal:#00c4b4;--teal-dark:#008f82;--orange:#ff7820;--orange-dark:#c44f00;--green-bright:#5cb800;--green-bright-dark:#3a7a00;--purple:#7b2fbe;--purple-dark:#5a1a96;--blue:#3949ab;--blue-dark:#1e2a7a;--screen-bg:#41306e;--screen-bg-dark:#2c2150;--grad-primary:linear-gradient(180deg, #ffe07a 0%, #ffc400 100%);--grad-fluency:linear-gradient(135deg, #2dd4bf 0%, #34d399 100%);--grad-success:linear-gradient(135deg, #4ade80 0%, #16a34a 100%);--shadow-sm:0 1px 2px #0006;--shadow-md:0 8px 24px #00000080;--shadow-glow:0 2px 10px #f2a93e47;--shadow-glow-success:0 2px 10px #4ade803d;--radius:14px;--radius-lg:20px;--transition:.18s cubic-bezier(.4, 0, .2, 1);--font-display:"SF Pro Rounded", "Nunito", -apple-system, system-ui, sans-serif;--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}.screen-profile{--screen-bg:#ff4d9e;--screen-bg-dark:#cc2070}.screen-home{--screen-bg:#7b2fbe;--screen-bg-dark:#5a1a96}.screen-writing{--screen-bg:#00acc1;--screen-bg-dark:#007b8f}.screen-wordsets{--screen-bg:#ff7820;--screen-bg-dark:#c44f00}.screen-mychars{--screen-bg:#3949ab;--screen-bg-dark:#1e2a7a}.screen-settings{--screen-bg:#6a1b9a;--screen-bg-dark:#4a0e70}[class*=screen-]{background:radial-gradient(circle, #ffffff12 1px, transparent 1px) 0 0 / 22px 22px, var(--screen-bg);min-height:100svh}body{font-family:var(--font-display);-webkit-font-smoothing:antialiased;background:radial-gradient(circle, #ffffff0d 1px, transparent 1px) 0 0 / 24px 24px, var(--screen-bg,#41306e);color:var(--text);overscroll-behavior:none;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;background-attachment:fixed}#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-btn-row{align-items:center;gap:8px;width:100%;display:flex}.user-btn-row .user-btn{flex:1}.user-delete-btn{border:1px solid var(--border);background:var(--bg-raised);width:44px;height:44px;color:var(--text-muted);cursor:pointer;border-radius:10px;flex:none;font-size:16px}.user-delete-btn:hover{border-color:var(--error,#d32f2f);color:var(--error,#d32f2f)}.user-delete-btn.confirm{background:var(--error,#d32f2f);border-color:var(--error,#d32f2f);color:#fff;box-shadow:0 0 0 3px color-mix(in srgb, var(--error,#d32f2f) 30%, transparent);font-weight:800}.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(--grad-primary);color:#fff;border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow-glow);transition:transform var(--transition), box-shadow var(--transition);border:none;padding:12px 22px;font-size:15px;font-weight:700}.user-create button:hover{transform:translateY(-2px)}.user-create button:active{transform:translateY(0)scale(.98)}.user-create button:disabled{opacity:.5;box-shadow:none}.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:2px solid var(--border);color:var(--text);cursor:pointer;white-space:nowrap;height:40px;box-shadow:0 3px 0 var(--border);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:0 18px;font-size:14px;font-weight:800;transition:transform 90ms,box-shadow 90ms;display:inline-flex}.user-badge:active{box-shadow:0 1px 0 var(--border);transform:translateY(2px)}@media (prefers-reduced-motion:reduce){.user-badge{transition:none}.user-badge:active{transform:none}}.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);border-radius:var(--radius-lg);cursor:pointer;color:var(--text);min-width:140px;box-shadow:var(--shadow-sm);transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);flex-direction:column;flex:1;align-items:center;gap:14px;padding:30px 24px;font-size:16px;font-weight:600;display:flex}.module-card:hover{box-shadow:var(--shadow-glow);border-color:#0000;transform:translateY(-4px)}.module-card:active{transform:translateY(-1px)scale(.99)}.module-icon{background:var(--grad-primary);width:76px;height:76px;box-shadow:var(--shadow-glow);border-radius:50%;justify-content:center;align-items:center;font-size:38px;display:flex}.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:#fff;background:var(--grad-fluency);border-radius:var(--radius);letter-spacing:.2px;align-self:stretch;margin-bottom:4px;padding:16px 20px;font-size:16px;font-weight:700;transition:transform 90ms,box-shadow 90ms;box-shadow:0 5px #0a8f6e}.welcome-level:active{transform:translateY(4px);box-shadow:0 1px #0a8f6e}@keyframes lc-fade-in{0%{opacity:0}to{opacity:1}}.welcome-level,.module-card,.my-chars-summary{animation:.4s both lc-fade-in}.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-hint{color:var(--text-muted);margin:8px 0 0;font-size:12px}.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{background:var(--grad-primary);color:#fff;box-shadow:var(--shadow-glow);border-color:#0000;font-weight:700}.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:#8c96aa2e;border-radius:3px;width:100%;height:5px;margin-top:5px;display:block;overflow:hidden}.mastery-bar-fill{border-radius:3px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1),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-header h2{flex:1}.stats-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.stats-table{border-collapse:collapse;width:100%;font-size:13px}.stats-table th,.stats-table td{text-align:center;white-space:nowrap;border-bottom:1px solid var(--border);padding:6px 8px}.stats-table th{color:var(--text-muted);background:var(--bg);font-weight:600;position:sticky;top:0}.stats-table tbody tr{cursor:pointer}.stats-table tbody tr:hover{background:var(--bg-raised)}.stats-char{font-size:18px;font-weight:600}.stats-recent{justify-content:center;gap:2px;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);border-radius:var(--radius);background:var(--bg-raised);box-shadow:var(--shadow-sm);cursor:pointer;touch-action:manipulation;transition:transform var(--transition), box-shadow var(--transition);flex-direction:column;align-items:center;gap:3px;padding:12px 4px 8px;display:flex;position:relative;overflow:hidden}.my-char-tile:active{transform:scale(.95)}.my-char-corner{border:16px solid #0000;border-width:0 16px 16px 0;width:0;height:0;position:absolute;top:0;right:0}.my-char-corner-below{border-right-color:var(--accent)}.my-char-corner-target{border-right-color:var(--success)}.my-char-corner-above{border-right-color:var(--danger)}.my-char-known{background:linear-gradient(160deg, color-mix(in srgb, var(--success) 14%, var(--bg-raised)), var(--bg-raised));box-shadow:var(--shadow-glow-success);border-color:#0000}.my-char-learning{border-color:var(--border)}.my-char-big{font-size:30px;font-weight:600}.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-raised,#1a1a1a);border-radius:var(--radius-lg,20px);border:1px solid var(--border,#333);box-shadow:var(--shadow-md);flex-direction:column;align-items:center;gap:12px;width:90%;max-width:340px;padding:28px 24px;display:flex}.ws-practice-char-display{font-family:var(--font-display);background:var(--grad-fluency);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:52px;font-weight:700}.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:9px solid var(--wood,#7a4e28);background:var(--bg,#0c3a42);aspect-ratio:1;background-image:var(--canvas-grid);background-size:100% 100%;border-radius:18px;overflow:hidden;box-shadow:0 10px 28px #0000008c,inset 0 0 0 1px #0006,inset 0 2px 2px #ffdcaa38}.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(--tile-edge,#ffffff24);background:var(--bg-raised,#2a2a2a);width:54px;height:54px;color:var(--text,#fff);cursor:pointer;touch-action:manipulation;transition:transform var(--transition,.18s), box-shadow var(--transition,.18s);border-radius:16px;justify-content:center;align-items:center;font-size:22px;display:flex;box-shadow:0 4px 10px #00000080,inset 0 1px #ffffff1f}.sp-hint-btn:active,.sp-show-btn:active,.sp-audio-btn:active{transform:scale(.9)}.sp-audio-btn{font-size:26px}.sp-hint-btn:disabled,.sp-show-btn:disabled{opacity:.3;cursor:default}.sp-show-btn.active{background:var(--grad-primary,#4a90d9);color:#fff;box-shadow:var(--shadow-glow,0 6px 22px #5b8cff59)}.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}.settings-option:disabled{opacity:.45;cursor:not-allowed}.lever-link{color:var(--accent);font:inherit;cursor:pointer;background:0 0;border:none;padding:0;text-decoration:underline}.lever-summary{justify-content:space-between;align-items:center;gap:12px;display:flex}.lever-reset-all{background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;padding:8px 14px;font-size:14px}.lever-reset-all:disabled{opacity:.4;cursor:default}.lever-row{border-top:1px solid var(--border);padding:12px 0}.lever-row:first-of-type{border-top:none}.lever-row__head{justify-content:space-between;align-items:center;gap:8px;display:flex}.lever-row__label{color:var(--text);flex-wrap:wrap;align-items:center;gap:8px;font-size:14px;display:flex}.lever-badge{color:var(--accent);border:1px solid var(--accent);border-radius:999px;padding:1px 8px;font-size:11px;font-weight:600}.lever-row__hint{color:var(--text-muted);margin:4px 0 0;font-size:12px}.lever-reset{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:8px;flex:none;width:30px;height:30px;font-size:16px;line-height:1}.lever-reset:hover{color:var(--accent);border-color:var(--accent)}.lever-range{align-items:center;gap:12px;margin-top:8px;display:flex}.lever-range input[type=range]{accent-color:var(--accent);flex:1}.lever-range__val{text-align:right;font-variant-numeric:tabular-nums;min-width:52px;color:var(--text);font-size:14px;font-weight:700}.lever-pills{gap:8px;margin-top:8px;display:flex}.lever-pill{background:var(--bg-input);color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;flex:1;padding:9px 10px;font-size:14px}.lever-pill.active{background:var(--grad-primary);color:#2a1a02;border-color:#0000;font-weight:700}.merge-field{border-top:1px solid var(--border);padding:12px 0}.merge-field:first-of-type{border-top:none}.merge-field__head{cursor:pointer;align-items:center;gap:10px;display:flex}.merge-field__dot{border-radius:50%;flex:none;width:12px;height:12px;box-shadow:inset 0 0 0 1px #fff3}.merge-field__name{color:var(--text);font-weight:700}.merge-field__count{color:var(--text-muted);margin-left:auto;font-size:13px}.merge-field__chev{color:var(--text-muted);font-size:13px}.merge-field__edit{margin-top:10px}.merge-field__edit textarea{resize:vertical;box-sizing:border-box;background:var(--bg-input);width:100%;min-height:150px;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;font-size:16px;line-height:1.7}.merge-field__actions{align-items:center;gap:8px;margin-top:10px;display:flex}.tpl-fieldchips{flex-wrap:wrap;gap:6px;display:flex}.tpl-chip{background:var(--bg-input);border:1px solid var(--border);color:var(--text-muted);border-radius:999px;padding:3px 10px;font-size:13px}.tpl-editor{flex-direction:column;gap:8px;display:flex}.tpl-input{box-sizing:border-box;background:var(--bg-input);width:100%;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;font-size:16px}.tpl-warn{color:var(--chip-above,#bb4a41);margin:0;font-size:12px}.tpl-row{align-items:center;gap:8px;display:flex}.tpl-row__text{flex:1;min-width:0}.tpl-pattern{color:var(--text);word-break:break-word;font-size:16px;font-weight:600}.tpl-english{color:var(--text-muted);margin-top:2px;font-size:13px}.lever-reset.confirm{background:var(--error,#d32f2f);border-color:var(--error,#d32f2f);color:#fff}.restore-overlay{z-index:1000;box-sizing:border-box;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.restore-modal{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:420px;max-height:80vh;padding:20px;overflow-y:auto;box-shadow:0 20px 50px #0009}.restore-modal h3{color:var(--text);margin:0 0 4px}.restore-row{border-top:1px solid var(--border);cursor:pointer;color:var(--text);align-items:center;gap:10px;padding:11px 0;display:flex}.restore-row--all{border-top:none;font-weight:700}.restore-row input{width:18px;height:18px;accent-color:var(--accent);flex:none}.restore-row__name{font-weight:600}.restore-row__count{color:var(--text-muted);margin-left:auto;font-size:13px}.restore-actions{gap:8px;margin-top:14px;display:flex}.restore-actions .lever-pill{flex:1;padding:11px}.placement-page{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:100vh;padding:16px;display:flex}.placement-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);max-width:360px;padding:28px 24px;box-shadow:0 10px 30px #0006}.placement-emoji{font-size:40px}.placement-card h2{color:var(--text);margin:10px 0}.placement-intro{color:var(--text-muted);line-height:1.6}.placement-actions{flex-direction:column;gap:10px;margin-top:18px;display:flex}.placement-actions .lever-pill{padding:12px}.placement-progress{color:var(--text-muted);font-size:14px;font-weight:600}.placement-prompt{color:var(--accent);letter-spacing:2px;min-height:48px;font-size:40px;font-weight:800}.placement-dontknow{max-width:280px;margin-top:14px}:root{--gold:gold;--gold-dark:#b8960c}h1,h2,h3{font-family:var(--font-display)}.user-picker h1,.welcome-header h1{color:#fff;text-shadow:0 3px 0 var(--purple-dark,#5a1a96), 0 2px 10px #0000004d;font-size:clamp(28px,7vw,40px);font-weight:900}.user-picker>p,.welcome-header>p,.welcome-subtitle{color:#ffffffeb}.settings-header h2{color:#fff;font-weight:900}.settings-header .back-btn,.icon-btn{color:#fff}.settings-page>.settings-hint,.placement-progress{color:#ffffffeb}.placement-prompt{color:#fff;text-shadow:0 3px 0 var(--purple-dark,#5a1a96)}.settings-section,.placement-card,.restore-modal{background:var(--bg-raised);border:4px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 6px #0000002e}.settings-section{padding:16px 18px;overflow:hidden}.settings-section h3{background:var(--border);color:#fff;margin:-16px -18px 16px;padding:11px 18px;font-size:15px;font-weight:800}.settings-section h3:before{display:none}.user-btn{color:var(--text);border:3px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 0 var(--border);background:#fff;font-weight:800;transition:transform 90ms,box-shadow 90ms}.user-btn:hover{background:var(--accent-bg);border-color:var(--border)}.user-btn:active{box-shadow:0 1px 0 var(--border);transform:translateY(3px)}.user-delete-btn{border:3px solid var(--border);color:var(--error);background:#fff}.icon-btn{border-color:#ffffff80}.user-create input,.tpl-input,.settings-name-row input,.merge-field__edit textarea,.lever-range input[type=range]{color:var(--text);border:2px solid var(--border);background:#fff}.tpl-chip{border:2px solid var(--border);color:var(--text);background:#fff;font-weight:700}.settings-option,.lever-pill,.lever-reset-all,.user-create button,.lever-link{font-family:var(--font-display);font-weight:800}.settings-option,.lever-pill,.lever-reset-all{border-radius:var(--radius);color:var(--text);border:2px solid var(--border);box-shadow:0 4px 0 var(--border);background:#fff;transition:transform 90ms,box-shadow 90ms,background .12s;position:relative}.settings-option:active:not(:disabled),.lever-pill:active:not(:disabled),.lever-reset-all:active:not(:disabled){box-shadow:0 1px 0 var(--border);transform:translateY(3px)}.settings-option:disabled,.lever-reset-all:disabled{opacity:.5;box-shadow:0 4px 0 var(--border)}.settings-option.active,.lever-pill.active,.user-create button{background:var(--gold);color:var(--text);border-radius:var(--radius);box-shadow:0 5px 0 var(--gold-dark);border:none;font-weight:900;transition:transform 90ms,box-shadow 90ms;position:relative}.settings-option.active:active:not(:disabled),.lever-pill.active:active:not(:disabled),.user-create button:active:not(:disabled){box-shadow:0 1px 0 var(--gold-dark);transform:translateY(4px)}.module-card{border-radius:var(--radius-lg);color:#fff;background:var(--teal);box-shadow:0 6px 0 var(--teal-dark);border:none;transition:transform .1s,box-shadow .1s}.module-card *{color:#fff}.module-card:nth-child(2n){background:var(--pink);box-shadow:0 6px 0 var(--pink-dark)}.module-card:nth-child(3n){background:var(--orange);box-shadow:0 6px 0 var(--orange-dark)}.module-card:nth-child(4n){background:var(--green-bright);box-shadow:0 6px 0 var(--green-bright-dark)}.module-card:active{transform:translateY(5px);box-shadow:0 1px #0000004d}@media (prefers-reduced-motion:reduce){.settings-option,.lever-pill,.lever-reset-all,.user-create button,.module-card,.user-btn{transition:none}.settings-option:active,.lever-pill:active,.lever-reset-all:active,.user-create button:active,.module-card:active,.user-btn:active{transform:none}}.welcome-popup-overlay{justify-content:center;align-items:center;min-height:100svh;padding:20px;display:flex}.welcome-popup{background:var(--bg-raised);border:4px solid var(--border);border-radius:var(--radius-lg);text-align:center;flex-direction:column;align-items:center;gap:14px;width:100%;max-width:380px;padding:32px 24px;display:flex;box-shadow:0 10px #0000002e}.welcome-popup-emoji{font-size:44px}.welcome-popup h1{font-family:var(--font-display);color:var(--text);font-size:24px;font-weight:900}.welcome-popup p{color:var(--text-muted);line-height:1.5}.welcome-popup-langs{gap:8px;width:100%;display:flex}.welcome-popup-langs .lever-pill{flex:1}.welcome-popup-input{box-sizing:border-box;width:100%;color:var(--text);border:2px solid var(--border);border-radius:var(--radius);text-align:center;background:#fff;padding:12px 14px;font-size:17px;font-weight:700}.welcome-popup-start{width:100%;font-family:var(--font-display);background:var(--gold);color:var(--text);border-radius:var(--radius);box-shadow:0 5px 0 var(--gold-dark);cursor:pointer;border:none;padding:14px;font-size:17px;font-weight:900;transition:transform 90ms,box-shadow 90ms}.welcome-popup-start:disabled{opacity:.5}.welcome-popup-start:active:not(:disabled){box-shadow:0 1px 0 var(--gold-dark);transform:translateY(4px)}@media (prefers-reduced-motion:reduce){.welcome-popup-start{transition:none}.welcome-popup-start:active{transform:none}}.module-back{color:#fff;font-family:var(--font-display);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin:14px 0 4px 16px;padding:6px 4px;font-size:17px;font-weight:800;display:inline-flex}.module-back:active{opacity:.65}.app-shell{position:relative}.app-shell--writing-challenge .module-back{z-index:5;margin:0;position:absolute;top:16px;left:16px}body[data-screen=home],body[data-screen=settings]{--screen-bg:#41306e}body[data-screen=profile]{--screen-bg:#ff4d9e}body[data-screen=writing]{--screen-bg:#00acc1}body[data-screen=wordsets]{--screen-bg:#ff7820}body[data-screen=mychars]{--screen-bg:#3949ab}body[data-screen=result]{--screen-bg:#5cb800}.settings-section>.settings-option,.settings-section>.settings-logout{width:100%;display:block}.settings-section>.settings-logout{font-family:var(--font-display);color:var(--text);border:2px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 0 var(--border);cursor:pointer;background:#fff;padding:12px 16px;font-weight:800;transition:transform 90ms,box-shadow 90ms;position:relative}.settings-section>.settings-logout:active{box-shadow:0 1px 0 var(--border);transform:translateY(3px)}@media (prefers-reduced-motion:reduce){.settings-section>.settings-logout{transition:none}.settings-section>.settings-logout:active{transform:none}}.icon-btn{background:var(--bg-raised);color:var(--text);border:2px solid var(--border);box-shadow:0 3px 0 var(--border);border-radius:999px;width:40px;height:40px;font-size:20px;transition:transform 90ms,box-shadow 90ms}.icon-btn:active{box-shadow:0 1px 0 var(--border);transform:translateY(2px)}@media (prefers-reduced-motion:reduce){.icon-btn{transition:none}.icon-btn:active{transform:none}}.my-chars-header h2{color:#fff;font-weight:900}.my-chars-header .back-btn{color:#fff}.my-chars-section h3{color:#ffffffd9}.admin-table th{background:var(--bg-raised-2);color:var(--text-muted)}.admin-table td{background:var(--bg-raised);color:var(--text)}.admin-table th,.admin-table td{border-color:#0000001f}.landing{background:radial-gradient(circle, #ffffff0d 1px, transparent 1px) 0 0 / 24px 24px, var(--screen-bg,#41306e);color:#fff;min-height:100svh;font-family:var(--font-display);background-attachment:fixed;padding:0 20px 64px;overflow-x:hidden}.landing>*{max-width:760px;margin-left:auto;margin-right:auto}.landing-top{justify-content:flex-end;padding-top:16px;display:flex}.landing-langtoggle{background:#ffffff1f;border:2px solid #fff3;border-radius:999px;gap:4px;padding:4px;display:inline-flex}.landing-lang-btn{cursor:pointer;color:#fffc;font-family:var(--font-display);background:0 0;border:none;border-radius:999px;min-width:38px;height:30px;font-size:14px;font-weight:800}.landing-lang-btn.active{background:var(--gold,gold);color:#2d1b00}.landing-hero{text-align:center;padding:28px 0 24px}.landing-badge{background:var(--gold,gold);color:#2d1b00;letter-spacing:.1em;text-transform:uppercase;box-shadow:0 4px 0 var(--gold-dark,#b8960c);border-radius:999px;margin-bottom:22px;padding:7px 18px;font-size:12px;font-weight:900;display:inline-block}.landing-title{text-shadow:0 4px 0 var(--purple-dark,#5a1a96), 0 6px 18px #00000059;margin-bottom:16px;font-size:clamp(40px,11vw,72px);font-weight:900;line-height:1.02}.landing-title-zh{color:var(--gold,gold)}.landing-sub{color:#ffffffe6;max-width:460px;margin:0 auto 18px;font-size:17px;line-height:1.6}.landing-stars{color:var(--gold,gold);letter-spacing:4px;text-shadow:0 2px 6px #0000004d;margin-bottom:22px;font-size:24px}.landing-demo{justify-content:center;gap:14px;margin-bottom:30px;display:flex}.landing-demo-tile{color:#fff;border-radius:18px;justify-content:center;align-items:center;width:76px;height:84px;font-size:42px;font-weight:900;animation:3s ease-in-out infinite landing-float;display:flex}.landing-demo-tile.t-teal{background:var(--teal,#00c4b4);box-shadow:0 7px 0 var(--teal-dark,#008f82)}.landing-demo-tile.t-gold{background:var(--gold,gold);color:#2d1b00;box-shadow:0 7px 0 var(--gold-dark,#b8960c);animation-delay:.2s}.landing-demo-tile.t-pink{background:var(--pink,#ff4d9e);box-shadow:0 7px 0 var(--pink-dark,#cc2070);animation-delay:.4s}@keyframes landing-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.landing-cta{background:var(--gold,gold);color:#2d1b00;box-shadow:0 6px 0 var(--gold-dark,#b8960c);border-radius:16px;padding:16px 40px;font-size:18px;font-weight:900;text-decoration:none;transition:transform .1s,box-shadow .1s;display:inline-block}.landing-cta:active{box-shadow:0 2px 0 var(--gold-dark,#b8960c);transform:translateY(4px)}.landing-section{margin-top:44px}.landing-eyebrow{text-align:center;letter-spacing:.14em;text-transform:uppercase;color:var(--gold,gold);text-shadow:0 2px 4px #0000004d;margin-bottom:18px;font-size:13px;font-weight:900}.landing-steps{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}@media (width<=640px){.landing-steps{grid-template-columns:1fr}}.landing-step{background:var(--bg-raised,#fff8e0);color:var(--text,#2d1b00);border:4px solid var(--purple-dark,#5a1a96);text-align:center;border-radius:20px;padding:26px 18px 20px;position:relative;box-shadow:0 7px #0003}.landing-step.s-teal{border-color:var(--teal-dark,#008f82)}.landing-step.s-pink{border-color:var(--pink-dark,#cc2070)}.landing-step.s-orange{border-color:var(--orange-dark,#c44f00)}.landing-step-num{color:#fff;border-radius:999px;justify-content:center;align-items:center;width:34px;height:34px;font-weight:900;display:flex;position:absolute;top:-16px;left:50%;transform:translate(-50%);box-shadow:0 3px #00000040}.s-teal .landing-step-num{background:var(--teal,#00c4b4)}.s-pink .landing-step-num{background:var(--pink,#ff4d9e)}.s-orange .landing-step-num{background:var(--orange,#ff7820)}.landing-step-emoji{margin:6px 0 10px;font-size:40px;display:block}.landing-step h3{margin-bottom:6px;font-size:19px;font-weight:900}.landing-step p{color:var(--text-muted,#6b4c20);font-size:14px;line-height:1.5}.landing-features{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}@media (width<=480px){.landing-features{grid-template-columns:1fr}}.landing-feat{color:#fff;background:#ffffff1a;border:2px solid #ffffff2e;border-radius:14px;align-items:center;gap:10px;padding:14px 16px;font-weight:700;display:flex}.landing-feat-emoji{font-size:22px}.landing-install{background:var(--bg-raised,#fff8e0);border:4px solid var(--gold,gold);border-radius:22px;overflow:hidden;box-shadow:0 8px #0003}.landing-install-bar{background:var(--gold,gold);color:#2d1b00;padding:14px 20px;font-size:18px;font-weight:900}.landing-install-body{padding:20px}.landing-install-intro{color:var(--text-muted,#6b4c20);margin-bottom:16px;line-height:1.5}.landing-install-steps{flex-direction:column;gap:14px;list-style:none;display:flex}.landing-install-steps li{color:var(--text,#2d1b00);align-items:center;gap:12px;font-size:15px;line-height:1.4;display:flex}.landing-install-steps strong{font-weight:900}.landing-dot{background:var(--purple,#7b2fbe);color:#fff;border-radius:999px;flex:none;justify-content:center;align-items:center;width:28px;height:28px;font-weight:900;display:flex}.landing-share-ico{vertical-align:middle;color:var(--purple,#7b2fbe);margin:0 2px}.landing-footer{text-align:center;color:#fff9;margin-top:44px;font-weight:700}@media (prefers-reduced-motion:reduce){.landing-demo-tile{animation:none}.landing-cta{transition:none}}.admin-console{--bg:#ebeef3;--bg-raised:#fff;--bg-raised-2:#1f2937;--bg-input:#fff;--bg-hover:#eef2fb;--border:#cbd2dc;--border-hover:#9aa4b2;--text:#111827;--text-muted:#475467;--text-dim:#667085;--accent:#2563eb;--accent-bg:#e6eefe;--accent-hover:#1d4ed8;min-height:100svh;color:var(--text);background:radial-gradient(circle,#0f172a09 1px,#0000 1px) 0 0/22px 22px,#f4f6fa;padding-bottom:56px}.admin-console .admin-header{padding:18px 0 10px}.admin-console .admin-header h2{letter-spacing:.2px;color:var(--text);font-size:22px;font-weight:700}.admin-console .back-btn{color:var(--accent);border-radius:6px;font-weight:600}.admin-console .back-btn:hover{color:var(--accent-hover);background:var(--accent-bg)}.admin-console .admin-debug-toggle{border:1px solid var(--border);color:var(--text-muted);background:#fff;font-weight:600}.admin-console .admin-debug-toggle.on{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}.admin-console .admin-tabs{border:1px solid var(--border);background:#fff;border-radius:10px;gap:2px;margin-bottom:20px;padding:4px}.admin-console .admin-tab{color:var(--text-muted);border-bottom:none;border-radius:7px;flex:1;margin-bottom:0;padding:9px 14px;font-weight:600;transition:background .12s,color .12s}.admin-console .admin-tab:hover{color:var(--text);background:var(--bg-hover)}.admin-console .admin-tab.active{background:var(--accent);color:#fff;border-bottom:none}.admin-console .admin-tab.active:hover{background:var(--accent-hover);color:#fff}.admin-console .admin-table{border:1px solid var(--border);background:#fff;border-radius:8px;overflow:hidden}.admin-console .admin-table th,.admin-console .admin-table td{border:1px solid var(--border);padding:9px 12px}.admin-console .admin-table th{background:var(--bg-raised-2);color:#f9fafb;letter-spacing:.2px;font-weight:600}.admin-console .admin-table td{color:var(--text);background:#fff}.admin-console .admin-table tbody tr:nth-child(2n) td{background:#f7f9fc}.admin-console .admin-clickable-row:hover td{background:var(--accent-bg)}.admin-console .ud-rank{color:var(--text-muted)}.admin-console .ud-level{color:var(--accent);font-weight:600}.admin-console .ud-date{color:var(--text-muted)}.admin-console .ud-perfect{color:#1b873f}.admin-console .ud-correct{color:#4e9a06}.admin-console .ud-incorrect{color:#d32029}.admin-console .ud-mastery{border:1px solid var(--border);background:#e4e8ef}.admin-console .ud-dot.ud-skip{opacity:1;background:#98a2b3}.admin-console .sa-page-title,.admin-console .sa-container h3{color:var(--text);font-weight:700}.admin-console .sa-collapsible{border:1px solid var(--border);background:#fff;box-shadow:0 1px 2px #1018280d}.admin-console .sa-collapsible-header{color:var(--text);font-weight:600}.admin-console .sa-collapsible-header:hover{background:var(--bg-hover)}.admin-console .sa-collapse-arrow{color:var(--text-muted)}.admin-console .sa-formula{border-color:var(--border);background:#f7f9fc}.admin-console .sa-formula code{border:1px solid var(--border);color:var(--accent);background:#fff}.admin-console input[type=text],.admin-console input:not([type]),.admin-console textarea,.admin-console .sa-setting-row select,.admin-console .sa-seed-input,.admin-console .sa-input,.admin-console .sa-input-trad,.admin-console .sa-input-english{border:1px solid var(--border);color:var(--text);background:#fff}.admin-console input:focus,.admin-console textarea:focus,.admin-console select:focus{border-color:var(--accent);outline:none}.admin-console .ws-admin-cat,.admin-console .ws-admin-search,.admin-console .ws-admin-manual{border-color:var(--border)}.admin-console .ws-admin-cat-header:hover{background:var(--bg-hover)}.admin-console .admin-empty{color:var(--text-dim)}.update-banner{z-index:9999;padding:10px 16px;padding-top:max(10px, env(safe-area-inset-top));background:var(--gold,gold);color:var(--text,#2d1b00);font-weight:800;font-family:var(--font-display,inherit);align-items:center;gap:12px;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 4px 14px #00000047}.update-banner-msg{flex:1;min-width:0}.update-banner-update{background:var(--text,#2d1b00);color:var(--gold,gold);cursor:pointer;white-space:nowrap;border:none;border-radius:999px;padding:7px 18px;font-weight:800}.update-banner-later{color:var(--text,#2d1b00);cursor:pointer;white-space:nowrap;background:0 0;border:none;font-weight:600;text-decoration:underline}.bank-grid-overlay{z-index:1000;background:#0f172a8c;justify-content:center;align-items:center;padding:2vh 2vw;display:flex;position:fixed;inset:0}.bank-grid-modal{color:#111827;background:#fff;border-radius:12px;flex-direction:column;width:96vw;max-width:1400px;height:94vh;display:flex;overflow:hidden;box-shadow:0 20px 60px #0006}.bank-grid-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:12px 18px;font-size:16px;display:flex}.bank-grid-close{cursor:pointer;color:#555;background:0 0;border:none;border-radius:8px;width:36px;height:36px;font-size:20px;line-height:1}.bank-grid-close:hover{background:#f1f5f9}.bank-grid-toolbar{border-bottom:1px solid #eee;flex-wrap:wrap;align-items:center;gap:10px;padding:10px 18px;display:flex}.bank-grid-scroll{flex:1;padding:0 18px 18px;overflow:auto}
