.codepad-overlay{z-index:1000;box-sizing:border-box;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.codepad-modal{color:#1c1c1e;border-radius:var(--radius-lg);box-sizing:border-box;background:#fff;border:1px solid #e2e2e7;width:100%;max-width:320px;padding:20px;box-shadow:0 20px 50px #0009}.codepad-modal h3{color:#1c1c1e;text-align:center;margin:0 0 16px}.codepad-entry{align-items:center;gap:10px;margin:0 0 20px;display:flex}.codepad-slots{flex:1;justify-content:center;gap:10px;display:flex}.codepad-slot{border-radius:var(--radius);box-sizing:border-box;color:#1c1c1e;background:#f5f5f7;border:2px solid #d1d1d6;justify-content:center;align-items:center;width:44px;height:52px;font-size:24px;font-weight:700;line-height:1;transition:border-color .12s,background .12s;display:flex}.codepad-slot:before{content:"_";color:#c7c7cc}.codepad-slot--filled{background:#fff;border-color:#1c1c1e}.codepad-slot--filled:before{content:none}.codepad-backspace{appearance:none;color:#1c1c1e;border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;background:#f5f5f7;border:1px solid #d1d1d6;flex:none;justify-content:center;align-items:center;width:52px;height:52px;font-size:22px;line-height:1;transition:background 80ms,transform 80ms,border-color 80ms;display:flex}.codepad-backspace:hover:not(:disabled){border-color:#1c1c1e}.codepad-backspace:active:not(:disabled){background:#ececf0;transform:scale(.96)}.codepad-backspace:disabled{opacity:.4;cursor:default}.codepad-backspace:focus-visible{outline-offset:2px;outline:3px solid #1c1c1e}.codepad-grid{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.codepad-key{appearance:none;color:#1c1c1e;border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;background:#f5f5f7;border:1px solid #d1d1d6;padding:16px 0;font-size:22px;font-weight:700;line-height:1;transition:background 80ms,transform 80ms,border-color 80ms}.codepad-key:hover{border-color:#1c1c1e}.codepad-key:active{background:#ececf0;transform:scale(.96)}.codepad-key:focus-visible{outline-offset:2px;outline:3px solid #1c1c1e}.codepad-cancel{appearance:none;color:#1c1c1e;border-radius:var(--radius);cursor:pointer;background:#f5f5f7;border:1px solid #d1d1d6;width:100%;margin-top:16px;padding:11px;font-size:15px;font-weight:600;transition:background 80ms,border-color 80ms}.codepad-cancel:hover{border-color:#1c1c1e}.codepad-cancel:active{background:#ececf0}.codepad-cancel:focus-visible{outline-offset:2px;outline:3px solid #1c1c1e}.codepad-result{border-radius:var(--radius-lg);box-sizing:border-box;text-align:center;cursor:pointer;background:#fff;border:1px solid #e2e2e7;width:100%;max-width:320px;padding:28px 24px;animation:.16s codepad-pop;box-shadow:0 20px 50px #0009}.codepad-result__emoji{margin-bottom:12px;font-size:48px;line-height:1}.codepad-result__msg{color:#1c1c1e;margin:0;font-size:17px;font-weight:600}@keyframes codepad-pop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion:reduce){.codepad-slot,.codepad-backspace,.codepad-key{transition:none}.codepad-result{animation:none}}*{box-sizing:border-box;margin:0;padding:0}:root{--paper:#f3eee2;--paper-raised:#fbf8f0;--paper-sunken:#ece5d5;--ink:#1c1a17;--ink-soft:#56514a;--ink-faint:#8a8377;--seal:#c0392b;--seal-deep:#97271c;--seal-wash:#f3e0db;--rule:#dad2c2;--rule-strong:#c7bca6;--bg:var(--paper);--bg-raised:var(--paper-raised);--bg-raised-2:var(--paper-sunken);--bg-input:#fff;--border:var(--rule);--border-hover:var(--ink-faint);--tile-edge:#1c1a171a;--chip-upcoming:var(--ink-soft);--chip-skip:var(--ink-faint);--chip-above:var(--seal);--text:var(--ink);--text-muted:var(--ink-soft);--text-dim:var(--ink-faint);--accent:var(--seal);--accent-bg:var(--seal-wash);--accent-hover:var(--seal-deep);--error:#b23b30;--success:#4f7a3a;--warning:#b5701c;--danger:var(--seal);--wood:#c7bca6;--wood-dark:#a89c84;--wood-light:#dad2c2;--panel-bg:var(--paper-raised);--panel-border:var(--rule);--gold:var(--ink);--gold-dark:#000;--pink:#9c5560;--pink-dark:#7a3e48;--teal:#4e7c76;--teal-dark:#3b5f5a;--orange:#b5701c;--orange-dark:#8c540f;--green-bright:#4f7a3a;--green-bright-dark:#3a5a2a;--purple:#5e5670;--purple-dark:#463f54;--blue:#4a5a7a;--blue-dark:#353f58;--bg-card:var(--paper-raised);--bg-card2:var(--paper-sunken);--green:var(--green-bright);--green-dark:var(--green-bright-dark);--red:var(--seal);--red-dark:var(--seal-deep);--key-edge:var(--rule-strong);--shadow3d:0 1px 0;--screen-bg:var(--paper);--screen-bg-dark:#e7e0d1;--screen-accent:var(--seal);--grad-primary:var(--ink);--grad-fluency:linear-gradient(135deg, #4e7c76 0%, #3b5f5a 100%);--grad-success:linear-gradient(135deg, #4f7a3a 0%, #3a5a2a 100%);--shadow-sm:0 1px 2px #1c1a171a;--shadow-md:0 18px 40px -24px #1c1a1773;--shadow-glow:0 1px 0 var(--rule), 0 12px 28px -20px #1c1a1766;--shadow-glow-success:0 0 0 1px #4f7a3a4d;--radius:12px;--radius-sm:10px;--radius-lg:16px;--transition:.18s cubic-bezier(.4, 0, .2, 1);--font:"SF Pro Rounded", "Nunito", -apple-system, system-ui, "Segoe UI", sans-serif;--font-serif:"Iowan Old Style", "Palatino", "Palatino Linotype", Georgia, "Songti TC", serif;--font-han:"Songti TC", "Kaiti TC", "STKaiti", "Noto Serif TC", serif;--font-display:var(--font);--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-home{--screen-accent:#c0392b}.screen-writing{--screen-accent:#4e7c76}.screen-wordsets{--screen-accent:#9c5560}.screen-mychars{--screen-accent:#4a5a7a}.screen-settings{--screen-accent:#8c540f}.screen-writing,.screen-wordsets,.screen-mychars,.screen-settings{background:var(--screen-bg);min-height:100svh}body{font-family:var(--font);-webkit-font-smoothing:antialiased;background:var(--screen-bg,#f3eee2);color:var(--text);overscroll-behavior:none;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;background-attachment:fixed}#root{width:100%;padding-top:env(safe-area-inset-top,0px)}.loading{min-height:100svh;color:var(--text-dim);justify-content:center;align-items:center;display:flex}.loading--download{flex-direction:column;padding:0 24px}.dl-progress{flex-direction:column;gap:10px;width:100%;max-width:320px;display:flex}.dl-progress__track{background:var(--paper-sunken);border:1px solid var(--rule);border-radius:999px;height:10px;position:relative;overflow:hidden}.dl-progress__fill{background:var(--seal);border-radius:999px;width:0;height:100%;transition:width .25s}.dl-progress__track--indeterminate .dl-progress__fill{width:40%;animation:1.2s ease-in-out infinite dl-indeterminate;position:absolute;left:0}.dl-progress__label{text-align:center;color:var(--ink-soft);letter-spacing:.02em;font-size:14px}@keyframes dl-indeterminate{0%{transform:translate(-110%)}to{transform:translate(260%)}}@media (prefers-reduced-motion:reduce){.dl-progress__fill{transition:none}.dl-progress__track--indeterminate .dl-progress__fill{width:40%;animation:none;left:30%}}.user-picker{min-height:100svh;padding:12px 24px max(24px, env(safe-area-inset-bottom));flex-direction:column;align-items:center;gap:0;max-width:460px;margin:0 auto;display:flex}.user-picker-bar{justify-content:flex-end;align-items:center;width:100%;min-height:40px;display:flex}.user-picker-hero{text-align:center;flex-direction:column;align-items:center;gap:8px;margin-top:clamp(28px,9vh,72px);margin-bottom:clamp(28px,7vh,56px);display:flex}.user-picker h1{letter-spacing:-.01em;font-size:clamp(34px,10vw,48px);font-weight:800;line-height:1.05}.user-picker-body{flex-direction:column;gap:10px;width:100%;display:flex}.user-picker-prompt{letter-spacing:.04em;text-transform:uppercase;opacity:.85;margin:0 2px 2px;font-size:13px;font-weight:700}.made-for{letter-spacing:.02em;text-align:center;margin-top:auto;padding-top:28px;font-size:12px}.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:14px;align-items:center;gap:10px;padding:15px 18px;font-size:17px;transition:border-color .15s,background .15s,transform .12s;display:flex}.user-btn__name{font-weight:600}.user-btn__chevron{opacity:.5;margin-left:auto;font-size:22px;line-height:1}.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:48px;height:48px;color:var(--text-muted);cursor:pointer;border-radius:14px;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:6px;display:flex}.user-create input{border:1px solid var(--border);background:var(--bg-input);color:var(--text);border-radius:14px;outline:none;flex:1;padding:14px 16px;font-size:16px}.user-create input:focus{border-color:var(--accent)}.user-create button{background:var(--success);color:#fff;cursor:pointer;transition:transform var(--transition), background var(--transition), opacity var(--transition);border:none;border-radius:14px;flex:none;padding:14px 22px;font-size:16px;font-weight:700}.user-create button:hover{background:var(--green-dark)}.user-create button:active{transform:scale(.97)}.user-create button:disabled{opacity:.4}.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}.user-badge{background:var(--paper-raised);border:1px solid var(--rule-strong);color:var(--ink-soft);cursor:pointer;white-space:nowrap;height:40px;box-shadow:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;padding:0 18px;font-size:14px;font-weight:600;transition:border-color .16s,color .16s,transform .1s;display:inline-flex}.user-badge:active{transform:translateY(1px)}@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-list--list{flex-flow:column}.module-list--list .module-card{flex-direction:row;justify-content:flex-start;gap:18px;width:100%;padding:18px 22px}.module-list--list .module-icon{width:56px;height:56px;font-size:28px}.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}@media (hover:hover){.module-card:hover{box-shadow:var(--shadow-glow);border-color:#0000;transform:translateY(-4px)}}.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;transition:transform .2s cubic-bezier(.34,1.56,.64,1);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:var(--ink);background:var(--paper-raised);border:1px solid var(--rule);border-left:3px solid var(--seal);border-radius:var(--radius);box-shadow:var(--shadow-sm);letter-spacing:.01em;align-self:stretch;margin-bottom:4px;padding:15px 18px;font-size:16px;font-weight:600;transition:border-color .16s,box-shadow .16s}.welcome-level:active{transform:translateY(1px)}@keyframes lc-fade-in{0%{opacity:0}to{opacity:1}}.welcome-level,.module-card{animation:.4s both lc-fade-in}@media (prefers-reduced-motion:reduce){.welcome-level,.module-card{animation:none}}.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}.voice-select-row{align-items:stretch;gap:10px;display:flex}.voice-dd{flex:1;min-width:0;position:relative}.voice-dd-trigger{text-align:left;border-radius:var(--radius,14px);border:2px solid var(--border,#5a1a96);background:var(--bg-input,#fffdf7);width:100%;min-height:46px;color:var(--text,#2d1b00);cursor:pointer;align-items:center;gap:8px;padding:10px 12px;font-size:15px;display:flex}.voice-dd-trigger:focus-visible{border-color:var(--accent,#c44f00);outline:none}.voice-dd-current{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.voice-dd-caret{color:var(--text-muted,#6b4c20);flex:none;transition:transform .15s}.voice-dd-caret.open{transform:rotate(180deg)}.voice-dd-list{z-index:1000;border-radius:var(--radius,14px);border:2px solid var(--border,#5a1a96);background:var(--bg-raised,#fff8e0);-webkit-overflow-scrolling:touch;max-height:50vh;margin:0;padding:6px;list-style:none;position:fixed;overflow-y:auto;box-shadow:0 8px 24px #2d1b0047}.voice-dd-list li{margin:0}.voice-dd-opt{text-align:left;width:100%;min-height:44px;color:var(--text,#2d1b00);cursor:pointer;background:0 0;border:none;border-radius:10px;align-items:center;gap:8px;padding:10px;font-size:15px;display:flex}.voice-dd-opt:hover,.voice-dd-opt:focus-visible{background:var(--gold,gold);color:var(--text,#2d1b00);outline:none}.voice-dd-opt.selected{background:var(--accent-bg,#ffe8c9);color:var(--accent,#c44f00);font-weight:700}.voice-dd-opt.selected:hover{background:var(--gold,gold)}.voice-dd-check{text-align:center;width:16px;color:var(--teal-dark,#008f82);flex:none;font-weight:700}.voice-dd-opt.selected .voice-dd-check{color:var(--accent,#c44f00)}.voice-dd-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.voice-dd-badge{opacity:.85;flex:none;margin-left:6px;font-size:13px}.voice-preview{border:2px solid var(--border,#5a1a96);background:var(--bg-raised,#fff8e0);color:var(--text,#2d1b00);border-radius:var(--radius,14px);cursor:pointer;flex:none;padding:0 14px;font-size:20px}.voice-preview:active{transform:translateY(1px)}.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}.sba{flex-direction:column;gap:0;display:flex}.sba-summary{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:16px 24px;margin-bottom:4px;padding:14px 0 12px;display:flex}.sba-stat{flex-direction:column;align-items:center;min-width:60px;display:flex}.sba-stat-n{font-variant-numeric:tabular-nums;font-size:22px;font-weight:700;line-height:1.1}.sba-stat-l{color:var(--text-dim);margin-top:2px;font-size:11px}.sba-target-row{align-items:center;gap:8px;margin-left:auto;display:flex}.sba-target-row label{color:var(--text-muted);white-space:nowrap;font-size:13px}.sba-target-val{min-width:28px;font-size:13px;font-weight:700}.sba-refresh-btn{border:1px solid var(--border);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:6px;padding:4px 10px;font-size:16px;transition:color .1s}.sba-refresh-btn:hover{color:var(--text)}.sba-viewall-btn{border:1px solid var(--border);cursor:pointer;color:var(--text-muted);white-space:nowrap;background:0 0;border-radius:6px;padding:5px 12px;font-size:13px;font-weight:600;transition:color .1s,border-color .1s}.sba-viewall-btn:hover{color:var(--text);border-color:var(--text-muted)}.sba-muted{color:var(--text-dim);font-size:12px}.sba-summary-view{flex-direction:column;gap:10px;padding:14px 0;display:flex}.sba-health-card{border-radius:var(--radius);border:1px solid #0000;overflow:hidden}.sba-health-title{letter-spacing:.06em;text-transform:uppercase;color:#fff;padding:7px 14px;font-size:12px;font-weight:800}.sba-card--good{border-color:#2e7d32}.sba-card--good .sba-health-title{background:#2e7d32}.sba-card--neutral{border-color:#e65100}.sba-card--neutral .sba-health-title{background:#e65100}.sba-card--bad{border-color:#b71c1c}.sba-card--bad .sba-health-title{background:#b71c1c}.sba-health-item{border-bottom:1px solid var(--border);flex-direction:column;gap:4px;padding:8px 14px;display:flex}.sba-health-item:last-child{border-bottom:none}.sba-health-text{font-size:13px;font-weight:600}.sba-health-sub{color:var(--text-dim);font-size:11px}.sba-health-chars{flex-wrap:wrap;gap:5px;margin-top:4px;display:flex}.sba-health-chip{background:var(--bg-raised);cursor:pointer;border:1.5px solid;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;transition:opacity .1s;display:inline-flex}.sba-health-chip:hover{opacity:.75}.sba-bands{flex-direction:column;gap:10px;padding:16px 0;display:flex}.sba-band{grid-template-columns:120px 1fr 140px;align-items:center;gap:12px;display:grid}.sba-band-label{color:var(--text-muted);white-space:nowrap;font-size:12px;font-weight:600}.sba-band-bar{background:var(--border);border-radius:7px;height:14px;display:flex;overflow:hidden}.sba-bar-at{background:#43a047;height:100%;transition:width .4s}.sba-bar-partial{background:#f9a825;height:100%;transition:width .4s}.sba-band-info{align-items:baseline;gap:10px;display:flex}.sba-band-at{font-variant-numeric:tabular-nums;color:#43a047;font-size:13px;font-weight:700}.sba-toolbar{flex-wrap:wrap;align-items:center;gap:8px 16px;padding:12px 0 8px;display:flex}.sba-band-filter{flex-wrap:wrap;gap:4px;display:flex}.sba-filter-btn{border:1px solid var(--border);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:999px;padding:3px 10px;font-size:12px;transition:background .1s,color .1s}.sba-filter-btn:hover{background:var(--bg-raised);color:var(--text)}.sba-filter-btn.active{background:var(--border);color:var(--text);font-weight:600}.sba-legend{flex-wrap:wrap;gap:8px;margin-left:auto;display:flex}.sba-legend-item{color:var(--text-muted);align-items:center;gap:4px;font-size:11px;display:flex}.sba-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.sba-grid{flex-wrap:wrap;gap:3px;padding:8px 0 16px;display:flex}.sba-cell{color:#fff;cursor:pointer;opacity:.88;border:none;border-radius:4px;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;transition:opacity .1s,transform .1s,outline .1s;display:flex}.sba-cell:hover{opacity:1;z-index:1;position:relative;transform:scale(1.15)}.sba-cell--selected{outline:2px solid var(--text);outline-offset:1px;opacity:1;z-index:1;position:relative;transform:scale(1.1)}.sba-gaps-view{padding-top:8px}.sba-char-big{font-size:20px;font-weight:700}.sba-inline-bar{background:var(--border);vertical-align:middle;border-radius:3px;width:60px;height:6px;margin-right:6px;display:inline-block;overflow:hidden}.sba-inline-fill{border-radius:3px;height:100%;transition:width .3s}.sba-row-active td{background:#0000000a}.sba-grid-backdrop{z-index:50;background:#0006;animation:.12s sba-fade-in;position:fixed;inset:0}@keyframes sba-fade-in{0%{opacity:0}to{opacity:1}}.sba-detail--popup{z-index:51;width:min(520px,92vw);max-height:75vh;animation:.15s cubic-bezier(.34,1.4,.64,1) sba-popup-in;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%);box-shadow:0 24px 64px #00000080}@keyframes sba-popup-in{0%{opacity:0;transform:translate(-50%,-48%)scale(.95)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}.sba-detail{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-raised);margin-top:16px;overflow:hidden}.sba-detail-head{border-bottom:1px solid var(--border);background:var(--bg);align-items:center;gap:12px;padding:10px 14px;display:flex}.sba-detail-char{font-size:36px;line-height:1}.sba-detail-meta{color:var(--text-muted);flex-wrap:wrap;flex:1;gap:6px 14px;font-size:12px;display:flex}.sba-close-btn{cursor:pointer;color:var(--text-dim);background:0 0;border:none;flex-shrink:0;margin-left:auto;padding:4px 8px;font-size:16px}.sba-close-btn:hover{color:var(--text)}.sba-sentence-list{flex-direction:column;gap:0;max-height:300px;display:flex;overflow-y:auto}.sba-sentence{border-bottom:1px solid var(--border);flex-direction:column;gap:2px;padding:8px 14px;display:flex}.sba-sentence:last-child{border-bottom:none}.sba-sent-zh{font-size:15px;font-weight:500}.sba-sent-en{color:var(--text-muted);font-size:12px}.sba-prompt-view{flex-direction:column;gap:16px;padding:14px 0;display:flex}.sba-prompt-controls{flex-wrap:wrap;align-items:flex-end;gap:12px 32px;display:flex}.sba-prompt-control{align-items:center;gap:10px;display:flex}.sba-prompt-control label{color:var(--text-muted);white-space:nowrap;font-size:13px}.sba-select{border:1px solid var(--border);background:var(--bg-raised);color:var(--text);cursor:pointer;border-radius:6px;padding:4px 8px;font-size:13px}.sba-prompt-targets{flex-direction:column;gap:8px;display:flex}.sba-prompt-targets-title{color:var(--text-muted);margin:0;font-size:12px;font-weight:600}.sba-target-chips{flex-wrap:wrap;gap:6px;display:flex}.sba-target-chip{background:var(--bg-raised);border:1.5px solid;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;display:flex}.sba-chip-char{font-size:18px;line-height:1}.sba-chip-meta{color:var(--text-muted);white-space:nowrap;font-size:11px}.sba-prompt-box{border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:0;display:flex;overflow:hidden}.sba-prompt-box-header{background:var(--bg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.sba-copy-btn{border:1px solid var(--border);background:var(--bg-raised);color:var(--text);cursor:pointer;border-radius:6px;padding:4px 14px;font-size:13px;font-weight:600;transition:background .1s}.sba-copy-btn:hover{background:var(--border)}.sba-prompt-textarea{box-sizing:border-box;resize:vertical;background:var(--bg-raised);width:100%;min-height:340px;color:var(--text);border:none;outline:none;padding:12px;font-family:ui-monospace,monospace;font-size:12px;line-height:1.6}.sba-green{color:#43a047}.sba-warn{color:#ef6c00}.sba-import-view{flex-direction:column;gap:12px;padding:14px 0;display:flex}.sba-import-hint{color:var(--text-muted);margin:0;font-size:13px}.sba-import-hint code{background:var(--bg);border-radius:4px;padding:1px 5px;font-size:12px}.sba-import-textarea{box-sizing:border-box;resize:vertical;background:var(--bg-raised);width:100%;min-height:220px;color:var(--text);border:1px solid var(--border);border-radius:var(--radius);outline:none;padding:10px 12px;font-family:ui-monospace,monospace;font-size:12px;line-height:1.6}.sba-import-textarea:focus{border-color:var(--accent)}.sba-import-preview{background:var(--bg-raised);border-radius:var(--radius);border:1px solid var(--border);flex-wrap:wrap;gap:6px 16px;padding:8px 12px;font-size:13px;display:flex}.sba-import-btn{border-radius:var(--radius);background:var(--accent);color:#fff;font-family:var(--font-display);cursor:pointer;box-shadow:0 4px 0 var(--orange-dark,#c44f00);border:none;align-self:flex-start;padding:9px 22px;font-size:15px;font-weight:800;transition:opacity .1s}.sba-import-btn:hover:not(:disabled){opacity:.9}.sba-import-btn:active:not(:disabled){box-shadow:0 1px 0 var(--orange-dark,#c44f00);transform:translateY(3px)}.sba-import-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}.sba-import-report{border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-raised);flex-direction:column;gap:12px;padding:14px 16px;display:flex}.sba-report-title{font-size:14px;font-weight:700}.sba-report-grid{grid-template-columns:1fr auto;gap:4px 0;max-width:320px;display:grid}.sba-report-label{color:var(--text-muted);font-size:13px}.sba-report-val{text-align:right;font-variant-numeric:tabular-nums;font-size:13px;font-weight:700}.sba-report-divider{background:var(--border);grid-column:span 1;height:1px;margin:6px 0}.sba-clear-btn{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:6px;align-self:flex-start;padding:5px 14px;font-size:13px}.sba-clear-btn:hover{color:var(--text);background:var(--bg)}.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)}.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}.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;position:relative}.placement-gear{top:max(16px, env(safe-area-inset-top));z-index:2;position:absolute;right:16px}.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}.placement-writer{flex-direction:column;align-items:center;gap:14px;width:100%;max-width:340px;display:flex}.placement-cue{border-radius:var(--radius);letter-spacing:3px;min-height:44px;color:var(--ink);background:var(--paper-raised);border:1px solid var(--rule-strong);box-shadow:var(--shadow-sm);cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;padding:8px 20px;font-size:30px;font-weight:700}.placement-cue-noz{letter-spacing:0}.placement-canvas-frame{width:100%;max-width:320px}.placement-write-controls{justify-content:center;gap:12px;display:flex}.placement-page:has(.sp-assessment){justify-content:flex-start;min-height:auto}.placement-page .sp-practice-settings{display:none}h1,h2,h3{font-family:var(--font-serif);color:var(--ink)}.welcome-header h1{color:var(--ink);font-family:var(--font-serif);letter-spacing:.01em;text-shadow:none;font-size:clamp(28px,7vw,40px);font-weight:600}.user-picker h1{color:var(--ink);font-family:var(--font-serif);letter-spacing:.01em;text-shadow:none;font-weight:600}.welcome-header>p,.welcome-subtitle{color:var(--ink-soft)}.user-picker .welcome-subtitle{color:var(--ink-soft);font-size:15px;font-weight:500}.user-picker-prompt,.made-for{color:var(--ink-faint)}.user-picker-prompt{letter-spacing:.18em;text-transform:uppercase;font-size:12px;font-weight:700}body[data-screen=profile]:not([data-theme]) .user-btn{border:1px solid var(--rule);box-shadow:var(--shadow-sm)}.settings-header h2{color:var(--ink);font-family:var(--font-serif);font-weight:600}.settings-header .back-btn,.icon-btn,.settings-page>.settings-hint,.placement-progress{color:var(--ink-soft)}.placement-prompt{color:var(--ink);font-family:var(--font-serif);text-shadow:none}.settings-section,.placement-card,.restore-modal{background:var(--paper-raised);border:1px solid var(--rule);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.settings-section{padding:18px 20px;overflow:hidden}.settings-section h3{color:var(--ink-faint);font-family:var(--font);letter-spacing:.14em;text-transform:uppercase;border-bottom:1px solid var(--rule);background:0 0;margin:0 0 14px;padding:0 0 10px;font-size:12px;font-weight:700}.settings-section h3:before{display:none}.user-btn{background:var(--paper-raised);color:var(--ink);border:1px solid var(--rule);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:border-color .16s,box-shadow .16s,transform .12s}.user-btn:hover{border-color:var(--ink-faint);box-shadow:var(--shadow-md)}.user-btn:active{transform:scale(.99)}.user-btn__chevron{color:var(--seal);opacity:.85}.user-delete-btn{background:var(--paper-raised);border:1px solid var(--rule);color:var(--error);box-shadow:var(--shadow-sm)}.icon-btn{border-color:var(--rule-strong)}.user-create input,.tpl-input,.settings-name-row input,.merge-field__edit textarea,.lever-range input[type=range]{color:var(--ink);border:1px solid var(--rule-strong);background:#fff}.tpl-chip{border:1px solid var(--rule-strong);color:var(--ink-soft);background:#fff;font-weight:600}.settings-option,.lever-pill,.lever-reset-all,.lever-link{font-family:var(--font);font-weight:600}.settings-option,.lever-pill,.lever-reset-all{border-radius:var(--radius);background:var(--paper-raised);color:var(--ink-soft);border:1px solid var(--rule-strong);box-shadow:none;transition:border-color .16s,color .16s,background .16s,transform .1s;position:relative}.settings-option:active:not(:disabled),.lever-pill:active:not(:disabled),.lever-reset-all:active:not(:disabled){transform:translateY(1px)}@media (hover:hover){.settings-option:hover:not(:disabled),.lever-pill:hover:not(:disabled),.lever-reset-all:hover:not(:disabled){border-color:var(--ink);color:var(--ink)}}.settings-option:disabled,.lever-reset-all:disabled{opacity:.45}.settings-option.active,.lever-pill.active{background:var(--ink);color:var(--paper);border:1px solid var(--ink);border-radius:var(--radius);box-shadow:none;font-weight:700;position:relative}.settings-option.active:active:not(:disabled),.lever-pill.active:active:not(:disabled){transform:translateY(1px)}.module-card{border:1px solid var(--rule);border-radius:var(--radius-lg);color:var(--ink);background:var(--paper-raised);box-shadow:var(--shadow-sm);transition:border-color .16s,box-shadow .16s,transform .16s;position:relative;overflow:hidden}.module-card *{color:var(--ink)}.module-card:before{content:"";background:var(--mod-accent,var(--seal));height:3px;position:absolute;top:0;left:0;right:0}.module-card--writing-challenge{--mod-accent:var(--teal)}.module-card--word-sets{--mod-accent:var(--pink)}.module-card--practice-english{--mod-accent:var(--blue)}.module-card--copybook{--mod-accent:var(--orange)}.module-card .module-icon{background:color-mix(in srgb, var(--mod-accent,var(--seal)) 12%, var(--paper));border:1px solid color-mix(in srgb, var(--mod-accent,var(--seal)) 35%, var(--rule));box-shadow:none;color:var(--ink)}@media (hover:hover){.module-card:hover{box-shadow:var(--shadow-md);border-color:color-mix(in srgb, var(--mod-accent,var(--seal)) 55%, var(--rule));transform:translateY(-3px)}.module-card:hover .module-icon{transform:scale(1.06)}}.module-card:active{transform:translateY(0)}.module-card:active .module-icon{transform:scale(.97)}@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,.module-card .module-icon,.module-card:hover .module-icon,.module-card:active .module-icon{transform:none}}.btn-3d{border-radius:var(--radius);font-family:var(--font);cursor:pointer;border:none;justify-content:center;align-items:center;padding:14px 28px;font-size:16px;font-weight:700;transition:background .16s,transform .1s;display:inline-flex;position:relative}.btn-3d:active{transform:translateY(1px)}.btn-primary{background:var(--ink);color:var(--paper)}.btn-primary:active{transform:translateY(1px)}.welcome-popup-overlay{justify-content:center;align-items:center;min-height:100svh;padding:20px;display:flex;position:relative}.welcome-popup-gear{top:max(16px, env(safe-area-inset-top));z-index:2;position:absolute;right:16px}.welcome-popup{background:var(--paper-raised);border:1px solid var(--rule);border-radius:var(--radius-lg);text-align:center;flex-direction:column;align-items:center;gap:18px;width:100%;max-width:380px;padding:32px 26px 24px;display:flex;box-shadow:0 24px 64px -32px #1c1a1780}.welcome-popup-hero{flex-direction:column;gap:6px;display:flex}.welcome-popup h1{font-family:var(--font-serif);letter-spacing:.01em;color:var(--ink);font-size:clamp(28px,8vw,34px);font-weight:600}.welcome-popup-tagline{color:var(--text-muted);font-size:14px;line-height:1.4}.welcome-popup-langs{gap:8px;width:100%;display:flex}.seg-btn{cursor:pointer;font-family:var(--font-display);color:var(--text-muted);background:#0000000a;border:1px solid #00000014;border-radius:12px;flex:1;padding:10px 12px;font-size:14px;font-weight:600;transition:background .12s,color .12s,border-color .12s}.seg-btn:hover{background:#0000000f}.seg-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:700}.welcome-popup-field{text-align:left;flex-direction:column;gap:7px;width:100%;display:flex}.welcome-popup-label{color:var(--text-muted);padding-left:2px;font-size:13px;font-weight:600}.welcome-popup-input{box-sizing:border-box;width:100%;color:var(--text);background:#fff;border:1px solid #0000001f;border-radius:14px;outline:none;padding:14px 16px;font-size:17px;font-weight:500;transition:border-color .12s}.welcome-popup-input:focus{border-color:var(--accent)}.welcome-popup-start{width:100%;font-family:var(--font-display);background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:14px;padding:15px;font-size:17px;font-weight:700;transition:transform .12s,background .12s,opacity .12s}.welcome-popup-start:hover:not(:disabled){background:var(--accent-hover)}.welcome-popup-start:disabled{opacity:.4}.welcome-popup-start:active:not(:disabled){transform:scale(.98)}.made-for--popup{color:var(--text-dim);margin-top:2px;padding-top:0}@media (prefers-reduced-motion:reduce){.welcome-popup-start{transition:none}.welcome-popup-start:active{transform:none}}.app-shell .module-back{z-index:20;background:var(--paper-raised);border:1px solid var(--rule-strong);box-shadow:none;color:var(--ink-soft);font-family:var(--font);letter-spacing:.01em;cursor:pointer;border-radius:999px;align-items:center;gap:7px;margin:14px 0 4px 16px;padding:8px 16px 8px 13px;font-size:14px;font-weight:600;transition:border-color .16s,color .16s,background .16s;display:inline-flex;position:relative}@media (hover:hover){.app-shell .module-back:hover{border-color:var(--ink);color:var(--ink)}}.app-shell .module-back:active{background:var(--paper-sunken)}.app-shell .module-back:focus-visible{outline:2px solid var(--seal);outline-offset:2px}@media (prefers-reduced-motion:reduce){.app-shell .module-back{transition:none}}.app-shell{position:relative}.app-shell .module-tile{box-sizing:border-box;background:var(--paper-raised);border:1px solid var(--rule);border-radius:var(--radius-lg);width:100%;max-width:600px;box-shadow:var(--shadow-md);margin:10px auto 24px;padding:30px 24px}.app-shell .module-tile-title{font-family:var(--font-serif);color:var(--ink);text-align:center;letter-spacing:.01em;text-shadow:none;margin:0 0 4px;font-size:32px;font-weight:600}.app-shell .module-tile-title:after{content:"";background:var(--screen-accent,var(--seal));width:34px;height:2px;margin:12px auto 0;display:block}body[data-screen]{--screen-bg:var(--paper);--screen-bg-dark:#e7e0d1}body[data-screen=home]{--screen-accent:#c0392b}body[data-screen=settings]{--screen-accent:#8c540f}body[data-screen=placement],body[data-screen=profile]{--screen-accent:#c0392b}body[data-screen=writing]{--screen-accent:#4e7c76}body[data-screen=wordsets]{--screen-accent:#9c5560}body[data-screen=mychars]{--screen-accent:#4a5a7a}body[data-screen=result]{--screen-accent:#4f7a3a}.settings-section>.settings-option,.settings-section>.settings-logout{width:100%;display:block}.settings-section>.settings-logout{font-family:var(--font);background:var(--paper-raised);color:var(--ink-soft);border:1px solid var(--rule-strong);border-radius:var(--radius);box-shadow:none;cursor:pointer;padding:12px 16px;font-weight:600;transition:border-color .16s,color .16s,transform .1s;position:relative}.settings-section>.settings-logout:hover{border-color:var(--ink);color:var(--ink)}.settings-section>.settings-logout:active{transform:translateY(1px)}@media (prefers-reduced-motion:reduce){.settings-section>.settings-logout{transition:none}.settings-section>.settings-logout:active{transform:none}}.icon-btn{background:var(--paper-raised);color:var(--ink-soft);border:1px solid var(--rule-strong);box-shadow:none;border-radius:999px;width:40px;height:40px;font-size:18px;transition:border-color .16s,color .16s,transform .1s}.icon-btn:hover{border-color:var(--ink);color:var(--ink)}.icon-btn:active{transform:translateY(1px)}@media (prefers-reduced-motion:reduce){.icon-btn{transition:none}.icon-btn:active{transform:none}}.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:var(--rule)}.lp{--char:#073464;--char-deep:#04223f;--char-raised:#0c4276;--cream:#f4efe4;--cream-soft:#cfc8b8;--cream-dim:#8c867a;--tan:#c9a36a;--tan-deep:#a8854e;--blaze:#e9b949;--rule:#f4efe424;--rule-strong:#f4efe447;--lp-display:"Helvetica Neue", "Arial Narrow", "Inter", Arial, sans-serif;--lp-script:"Snell Roundhand", "Apple Chancery", "Brush Script MT", "Segoe Script", cursive;--lp-han:"Songti TC", "Kaiti TC", "STKaiti", "Noto Serif TC", serif;--lp-han-brush:"LXGW WenKai TC", "Kaiti TC", "STKaiti", "BiauKai", "DFKai-SB", "KaiTi", cursive;--lp-bar-h:56px;background:var(--char);min-height:100svh;color:var(--cream);font-family:var(--font);padding:var(--lp-bar-h) 24px 0;-webkit-font-smoothing:antialiased;overflow-x:hidden}@media (width<=480px){.lp{--lp-bar-h:50px}}.lp>:not(.lp-band):not(.lp-bar){max-width:760px;margin-left:auto;margin-right:auto}.lp-bar{z-index:50;min-height:var(--lp-bar-h);background:0 0;border-bottom:1px solid #0000;align-items:stretch;transition:background .28s,border-color .28s,box-shadow .28s;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 0 #0000}.lp-bar.is-scrolled{background:color-mix(in srgb, var(--char) 92%, transparent);-webkit-backdrop-filter:saturate(1.1)blur(8px);backdrop-filter:saturate(1.1)blur(8px);border-bottom-color:var(--rule-strong);box-shadow:0 6px 20px -10px #000000b3}@supports not (background:color-mix(in srgb, red, blue)){.lp-bar.is-scrolled{background:var(--char)}}@media (prefers-reduced-motion:reduce){.lp-bar{transition:none}}.lp-bar-inner{flex:1;justify-content:space-between;align-items:center;gap:14px;width:100%;max-width:760px;margin:0 auto;padding:0 24px;display:flex}.lp-burger{width:38px;height:38px;color:var(--cream);cursor:pointer;background:0 0;border:none;border-radius:10px;flex:none;justify-content:center;align-items:center;margin-left:-8px;padding:0;transition:color .15s,background .15s;display:inline-flex}.lp-burger:hover{color:var(--tan);background:var(--rule)}.lp-burger:active{transform:translateY(1px)}.lp-burger:focus-visible{outline:2px solid var(--tan);outline-offset:2px}.lp-burger-ico{display:block}.lp-mark{font-family:var(--lp-han);letter-spacing:.06em;color:var(--cream);white-space:nowrap;margin-left:4px;margin-right:auto;font-size:19px;font-weight:600}.lp-bar-right{align-items:center;gap:14px;display:inline-flex}.lp-bar-region{letter-spacing:.18em;text-transform:uppercase;color:var(--tan);font-size:11px;font-weight:800}@media (width<=480px){.lp-bar-region{display:none}}.lp-langtoggle{gap:0;display:inline-flex}.lp-lang-btn{border:1px solid var(--rule-strong);cursor:pointer;color:var(--cream-soft);font-family:var(--lp-display);letter-spacing:.02em;background:0 0;min-width:42px;height:34px;font-size:13px;font-weight:800;transition:color .15s,border-color .15s,background .15s}.lp-lang-btn:first-child{border-radius:999px 0 0 999px;padding-left:4px}.lp-lang-btn:last-child{border-radius:0 999px 999px 0;margin-left:-1px;padding-right:4px}.lp-lang-btn.active{background:var(--cream);border-color:var(--cream);color:var(--char)}.lp-lang-btn:focus-visible{outline:2px solid var(--tan);outline-offset:2px;z-index:1}@media (width<=480px){.lp-bar-inner{gap:8px;padding:0 16px}.lp-burger{width:34px;height:34px;margin-left:-6px}.lp-mark{font-size:18px}.lp-bar-right{gap:0}.lp-lang-btn{min-width:38px;height:32px}}.lp-hero{grid-template-columns:1fr auto;align-items:center;gap:40px;padding:48px 0 12px;display:grid}@media (width<=720px){.lp-hero{grid-template-columns:1fr;gap:28px;padding-top:36px}}.lp-title{flex-direction:column;margin:0;display:flex}.lp-title-script{font-family:var(--lp-script);color:var(--cream);white-space:nowrap;margin-bottom:-.02em;margin-left:-.03em;font-size:clamp(40px,10vw,80px);font-style:italic;font-weight:500;line-height:.95;display:inline-block}.lp:lang(zh-TW) .lp-title-script{font-family:var(--lp-han);color:var(--tan);margin-left:0;font-size:clamp(56px,16vw,120px);font-style:normal;font-weight:600}.lp-title-big{font-family:var(--lp-display);text-transform:uppercase;letter-spacing:-.03em;color:var(--tan);overflow-wrap:break-word;font-size:clamp(44px,13.2vw,116px);font-weight:800;line-height:.86}.lp:lang(zh-TW) .lp-title-big{font-family:var(--lp-han);text-transform:none;letter-spacing:.02em;color:var(--cream);font-size:clamp(52px,15vw,108px);font-weight:600;line-height:.95}.lp-title-big-lead{white-space:nowrap}.lp-cells{flex:none;justify-self:center;gap:14px;display:flex}@media (width<=720px){.lp-cells{justify-self:start}}.lp-cell{background:var(--char-deep);border:2px solid var(--tan);flex:none;width:150px;height:150px;position:relative;box-shadow:0 28px 60px -30px #000c}.lp:lang(zh-TW) .lp-cell{border-color:var(--cream)}@media (width<=720px){.lp-cell{width:128px;height:128px}}@media (width<=360px){.lp-cells{gap:10px}.lp-cell{width:112px;height:112px}}.lp-cell-grid{width:100%;height:100%;position:absolute;inset:0}.lp-cell-grid line{stroke:var(--tan);stroke-width:.8px;stroke-dasharray:4 5;opacity:.5}.lp-cell-glyph{font-family:var(--lp-han);color:var(--cream);justify-content:center;align-items:center;padding-bottom:4px;font-size:96px;font-weight:600;line-height:1;display:flex;position:absolute;inset:0}.lp:lang(zh-TW) .lp-cell-glyph{color:var(--tan)}@media (width<=720px){.lp-cell-glyph{font-size:82px}}@media (width<=360px){.lp-cell-glyph{font-size:70px}}.lp-leadrow{border-bottom:1px solid var(--rule);grid-template-columns:minmax(0,1.3fr) minmax(0,auto);align-items:end;gap:36px;padding:12px 0 40px;display:grid}@media (width<=720px){.lp-leadrow{grid-template-columns:1fr;align-items:stretch;gap:24px}}.lp-sub{color:var(--cream-soft);max-width:42ch;margin:0;font-size:18px;line-height:1.6}.lp-hero-cta{flex-direction:column;align-items:flex-start;gap:12px;display:flex}@media (width<=720px){.lp-hero-cta{align-items:stretch}}.lp-cta{cursor:pointer;font-family:var(--lp-display);background:var(--cream);color:var(--char);letter-spacing:.01em;text-transform:uppercase;border:none;border-radius:999px;justify-content:center;align-items:center;gap:12px;padding:16px 28px;font-size:16px;font-weight:800;transition:background .16s,transform .1s,box-shadow .16s;display:inline-flex}.lp-cta-arrow{color:var(--tan-deep);font-weight:800;transition:transform .16s}.lp-cta:hover{background:#fff;box-shadow:0 10px 30px -12px #000000b3}.lp-cta:hover .lp-cta-arrow{transform:translate(4px)}.lp-cta:active{transform:translateY(1px)}.lp-cta:focus-visible{outline:2px solid var(--tan);outline-offset:3px}.lp-cta-block{width:100%;display:flex}.lp-cta-light{background:var(--char);color:var(--cream)}.lp-cta-light .lp-cta-arrow{color:var(--blaze)}.lp-cta-light:hover{background:#000}.lp-cta-hint{color:var(--cream-dim);letter-spacing:.1em;text-transform:uppercase;font-size:12px;font-weight:800}.lp-band{background:var(--blaze);color:var(--char);margin:0 -24px;padding:18px 24px}.lp-band-inner{text-align:center;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;max-width:760px;margin:0 auto;display:flex}.lp-band-text{font-family:var(--lp-display);text-transform:uppercase;letter-spacing:.02em;font-size:clamp(14px,3.6vw,22px);font-weight:800}.lp:lang(zh-TW) .lp-band-text{font-family:var(--lp-han);text-transform:none;letter-spacing:.04em;font-weight:600}.lp-madefor{color:var(--cream-soft);letter-spacing:.04em;text-transform:uppercase;align-items:center;gap:9px;font-size:13px;font-weight:800;display:inline-flex}.lp:lang(zh-TW) .lp-madefor{text-transform:none}.lp-devices-ico{color:var(--cream);flex:none}.lp-madefor-install{justify-content:center;width:100%;margin-bottom:14px}.lp-section{margin-top:88px}.lp-eyebrow{font-family:var(--lp-display);letter-spacing:.16em;text-transform:uppercase;color:var(--tan);align-items:center;gap:16px;margin:0 0 28px;font-size:13px;font-weight:800;display:flex}.lp:lang(zh-TW) .lp-eyebrow{letter-spacing:.12em;text-transform:none}.lp-eyebrow:after{content:"";background:var(--rule);flex:1;height:1px}.lp-pitch-section{margin-top:64px}.lp-pitch{max-width:600px}.lp-pitch-a{color:var(--cream-dim);margin:0;font-size:17px;line-height:1.5}.lp-pitch-b{font-family:var(--lp-display);text-transform:uppercase;letter-spacing:-.02em;color:var(--cream);margin:14px 0 26px;font-size:clamp(26px,6vw,44px);font-weight:800;line-height:1.04}.lp:lang(zh-TW) .lp-pitch-b{font-family:var(--lp-han);text-transform:none;letter-spacing:.01em;font-weight:600;line-height:1.18}.lp-pitch-lead{color:var(--cream);margin:0 0 8px;font-size:16px;font-weight:800}.lp-pitch-body{color:var(--cream-soft);margin:0;font-size:15.5px;line-height:1.62}.lp-miles{grid-template-columns:repeat(3,1fr);gap:0;display:grid}@media (width<=560px){.lp-miles{grid-template-columns:1fr}}.lp-mile{border-right:1px solid var(--rule);flex-direction:column;min-width:0;padding:4px 24px 4px 0;display:flex}.lp-mile+.lp-mile{padding-left:24px}.lp-mile:last-child{border-right:none;padding-right:0}@media (width<=560px){.lp-mile{border-right:none;border-bottom:1px solid var(--rule);padding:0 0 26px}.lp-mile+.lp-mile{padding:26px 0}.lp-mile:last-child{border-bottom:none;padding-bottom:0}}.lp-mile-num{font-family:var(--lp-display);letter-spacing:-.04em;color:var(--cream);font-size:clamp(56px,11vw,84px);font-weight:800;line-height:.86}@media (width<=560px){.lp-mile-num{font-size:clamp(72px,22vw,104px)}}.lp-mile-label{font-family:var(--lp-display);letter-spacing:.06em;text-transform:uppercase;color:var(--cream-soft);margin-top:8px;font-size:13px;font-weight:800}.lp:lang(zh-TW) .lp-mile-label{text-transform:none;letter-spacing:.04em}.lp-mile-when{letter-spacing:.1em;text-transform:uppercase;color:var(--tan);margin:12px 0 14px;font-size:12px;font-weight:800}.lp:lang(zh-TW) .lp-mile-when{text-transform:none;letter-spacing:.06em}.lp-mile-desc{color:var(--cream-soft);font-size:14.5px;line-height:1.55}.lp-foot{color:var(--cream);max-width:600px;margin-top:34px;font-size:16px;font-weight:500;line-height:1.6}.lp-proof{gap:0;margin:0;display:grid}.lp-proof-item{border-top:1px solid var(--rule);grid-template-columns:160px 1fr;align-items:baseline;gap:20px;padding:22px 0;display:grid}.lp-proof-item:last-child{border-bottom:1px solid var(--rule)}@media (width<=520px){.lp-proof-item{grid-template-columns:1fr;gap:6px}}.lp-proof-num{font-family:var(--lp-display);letter-spacing:.02em;text-transform:uppercase;color:var(--cream);font-size:19px;font-weight:800}.lp:lang(zh-TW) .lp-proof-num{text-transform:none}.lp-proof-desc{color:var(--cream-soft);margin:0;font-size:15px;line-height:1.55}.lp-steps{grid-template-columns:repeat(3,1fr);gap:32px;margin:0;padding:0;list-style:none;display:grid}@media (width<=640px){.lp-steps{grid-template-columns:1fr;gap:0}.lp-step{border-top:1px solid var(--rule);padding:22px 0}.lp-step:last-child{border-bottom:1px solid var(--rule)}}.lp-step-num{font-family:var(--lp-display);letter-spacing:-.02em;color:var(--tan);border-bottom:2px solid var(--rule-strong);margin-bottom:14px;padding-bottom:14px;font-size:40px;font-weight:800;display:block}@media (width<=640px){.lp-step-num{margin-bottom:10px;padding-bottom:10px;font-size:32px}}.lp-step-title{color:var(--cream);margin:0 0 8px;font-size:18px;font-weight:800}.lp-step-body{color:var(--cream-soft);margin:0;font-size:14.5px;line-height:1.55}.lp-features{grid-template-columns:1fr 1fr;gap:14px 32px;margin:0;padding:0;list-style:none;display:grid}@media (width<=480px){.lp-features{grid-template-columns:1fr}}.lp-feat{color:var(--cream);padding-left:28px;font-size:15px;font-weight:600;line-height:1.4;position:relative}.lp-feat:before{content:"";border-left:2.4px solid var(--tan);border-bottom:2.4px solid var(--tan);width:13px;height:7px;position:absolute;top:4px;left:0;transform:rotate(-45deg)}.lp-final-section{margin-bottom:0}.lp-install{background:var(--char-raised);border:1px solid var(--rule-strong);border-radius:20px;padding:34px 28px;box-shadow:0 30px 60px -34px #000c}.lp-install-final{font-family:var(--lp-display);text-transform:uppercase;letter-spacing:-.02em;color:var(--cream);text-align:center;margin:0 0 22px;font-size:clamp(22px,5vw,32px);font-weight:800;line-height:1.06}.lp:lang(zh-TW) .lp-install-final{font-family:var(--lp-han);text-transform:none;letter-spacing:.01em;font-weight:600;line-height:1.3}.lp-install-intro{color:var(--cream-soft);margin:26px 0 20px;font-size:15px;line-height:1.55}.lp-install-steps{flex-direction:column;gap:16px;margin:0;padding:0;list-style:none;display:flex}.lp-install-steps li{color:var(--cream);align-items:flex-start;gap:12px;font-size:15px;line-height:1.45;display:flex}.lp-dot{background:var(--tan);width:26px;height:26px;color:var(--char);font-size:13px;font-weight:800;font-family:var(--lp-display);border-radius:999px;flex:none;justify-content:center;align-items:center;margin-top:1px;display:flex}.lp-share-ico{vertical-align:-3px;color:var(--tan);margin:0 2px}.lp-footer{text-align:center;color:var(--cream-dim);letter-spacing:.12em;text-transform:uppercase;padding-bottom:max(40px, calc(32px + env(safe-area-inset-bottom)));margin-top:88px;font-size:12px;font-weight:800}.lp-book-section{margin-top:64px}.lp-read-head{font-family:var(--lp-display);text-transform:uppercase;letter-spacing:-.03em;color:var(--cream);margin:0 0 14px;font-size:clamp(30px,7vw,56px);font-weight:800;line-height:.92}.lp:lang(zh-TW) .lp-read-head{font-family:var(--lp-han);text-transform:none;letter-spacing:.01em;font-weight:600;line-height:1.05}.lp-read-lede{color:var(--cream-soft);max-width:52ch;margin:0 0 36px;font-size:16px;line-height:1.55}.lp-note{--ink:#2a2620;--ink-soft:#5a5141;--ink-dim:#948a76;--ink-rule:#50402633;--line:#50402621;--lp-ink:1;background:linear-gradient(#fcf9f1 0%,#f4ecdb 100%);border-radius:4px;position:relative;box-shadow:2px 3px 0 -1px #efe6d2,4px 6px 0 -2px #e7dcc4,0 40px 70px -34px #000000b3,inset 0 1px #ffffffb3}.lp-note-head{border-bottom:1px solid var(--ink-rule);justify-content:space-between;align-items:flex-end;gap:16px;padding:22px 28px 16px;display:flex;position:relative}@media (width<=480px){.lp-note-head{gap:12px;padding:20px 20px 14px}}.lp-note-title{font-family:var(--lp-display);letter-spacing:.16em;text-transform:uppercase;color:var(--tan-deep);padding-bottom:6px;font-size:12px;font-weight:800}.lp:lang(zh-TW) .lp-note-title{font-family:var(--lp-han);letter-spacing:.08em;text-transform:none;font-weight:600}.lp-note-stats{align-items:flex-end;gap:22px;display:inline-flex}@media (width<=480px){.lp-note-stats{gap:16px}}.lp-note-stat{align-items:baseline;gap:5px;display:inline-flex}.lp-note-stat-pre{font-family:var(--lp-han);color:var(--ink-soft);align-self:center;font-size:13px;font-weight:600}.lp-note-stat-num{font-family:var(--lp-display);letter-spacing:-.04em;color:var(--ink);font-size:clamp(26px,6vw,38px);font-weight:800;line-height:.86;transition:color .2s}.lp-note-stat-pct .lp-note-stat-num{color:var(--tan-deep)}.lp-note-stat-unit{font-family:var(--lp-display);text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-size:11px;font-weight:800}.lp:lang(zh-TW) .lp-note-stat-unit{font-family:var(--lp-han);text-transform:none;letter-spacing:.04em;font-weight:600}.lp-note-body{color:var(--ink);padding:26px 28px 30px;position:relative}@media (width<=480px){.lp-note-body{padding:22px 20px 26px}}.lp-book-tie{text-align:center;max-width:40ch;font-family:var(--lp-display);text-transform:uppercase;letter-spacing:-.01em;color:var(--cream);margin:28px auto 0;font-size:clamp(16px,3.4vw,22px);font-weight:800;line-height:1.2}.lp:lang(zh-TW) .lp-book-tie{font-family:var(--lp-han);text-transform:none;letter-spacing:.02em;font-weight:600;line-height:1.4}.lp-read-para{--lh:44px;--fs:30px;font-family:var(--lp-han-brush);font-size:var(--fs);line-height:var(--lh);letter-spacing:.02em;color:var(--ink);word-break:break-word;background-image:repeating-linear-gradient(180deg, transparent 0, transparent calc(var(--lh) - 1px), var(--line) calc(var(--lh) - 1px), var(--line) var(--lh));background-position:0 calc((var(--fs) - var(--lh)) / 2 - 2px);margin:0 0 22px}@media (width<=480px){.lp-read-para{--lh:38px;--fs:25px}}@media (width<=360px){.lp-read-para{--lh:35px;--fs:23px}}.lp-read-para[data-fontready=false]{visibility:hidden;background-image:none}.lp-read-char{--w:clamp(0, calc((var(--lp-ink) * var(--lp-han-count) - var(--lp-i)) / 3 + .5), 1);opacity:var(--w);transform:translateY(calc((1 - var(--w)) * -6px));filter:blur(calc((1 - var(--w)) * 4px));transition:color .25s,text-shadow .25s,opacity .12s linear,filter .12s linear,transform .12s linear;display:inline-block}.lp-read-char.is-lit{color:var(--ink);text-shadow:0 0 14px rgba(201,163,106,calc(.45 * var(--w)))}.lp-read-char.is-dim{color:var(--ink-dim);opacity:calc(var(--w) * .4);filter:blur(calc((1 - var(--w)) * 4px + 1.1px));text-shadow:none}.lp-read-punct{color:var(--ink-dim);--w:clamp(0, calc((var(--lp-ink) * var(--lp-han-count) - var(--lp-i)) / 3 + .5), 1);opacity:calc(.7 * var(--w));transform:translateY(calc((1 - var(--w)) * -6px));filter:blur(calc((1 - var(--w)) * 4px));transition:opacity .12s linear,filter .12s linear,transform .12s linear;display:inline-block}.lp-read-tabs{-webkit-overflow-scrolling:touch;flex-wrap:wrap;gap:8px;max-width:100%;margin:0 0 18px;display:flex}.lp-read-tab{font-family:var(--lp-display);letter-spacing:.06em;cursor:pointer;color:var(--ink-soft);border:1.5px solid var(--ink-rule);background:#ffffff73;border-radius:999px;flex:none;padding:8px 13px;font-size:12px;font-weight:800;line-height:1;transition:background .16s,color .16s,border-color .16s}.lp:lang(zh-TW) .lp-read-tab{font-family:var(--lp-han);letter-spacing:.04em;font-weight:600}.lp-read-tab:hover{color:var(--ink);border-color:#a8854e99}.lp-read-tab.is-active{background:var(--tan-deep);color:#fbf7ee;border-color:var(--tan-deep)}.lp-read-tab:focus-visible{outline:2px solid var(--tan-deep);outline-offset:2px}@media (width<=480px){.lp-read-tabs{flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}}.lp-read-custom-input{box-sizing:border-box;width:100%;font-family:var(--lp-han);color:var(--ink);resize:vertical;border:1.5px solid var(--ink-rule);background:#fff9;border-radius:8px;min-height:76px;margin:0 0 18px;padding:12px 14px;font-size:16px;line-height:1.55;display:block}.lp-read-custom-input::placeholder{color:var(--ink-dim);opacity:.9}.lp-read-custom-input:focus-visible{outline:2px solid var(--tan-deep);outline-offset:1px;border-color:#0000}.lp-read-empty{font-family:var(--lp-han);color:var(--ink-dim);min-height:1.55em;margin:0 0 24px;font-size:16px;line-height:1.55}.lp-read-control{border-bottom:1px solid var(--ink-rule);margin:4px 0 18px;padding-bottom:20px}.lp-read-slider-wrap{position:relative}.lp-read-sliderlabel{font-family:var(--lp-display);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:12px;font-size:12px;font-weight:800;display:flex}.lp:lang(zh-TW) .lp-read-sliderlabel{text-transform:none;letter-spacing:.04em}.lp-read-knownval{font-family:var(--lp-display);letter-spacing:0;color:var(--tan-deep);text-transform:none;font-size:17px;font-weight:800}.lp-read-slider{appearance:none;cursor:pointer;outline-offset:4px;--lp-fill:.25;--lp-fill-x:calc(13px + var(--lp-fill) * (100% - 26px));background:linear-gradient(90deg, var(--tan-deep) 0, var(--tan-deep) var(--lp-fill-x), var(--ink-rule) var(--lp-fill-x), var(--ink-rule) 100%);border-radius:999px;width:100%;height:4px;margin:0}.lp-read-slider::-webkit-slider-thumb{appearance:none;border:3px solid var(--tan-deep);cursor:pointer;background:#fff;border-radius:999px;width:26px;height:26px;transition:transform .12s,box-shadow .16s;box-shadow:0 4px 10px -4px #50402699}.lp-read-slider::-moz-range-thumb{border:3px solid var(--tan-deep);cursor:pointer;background:#fff;border-radius:999px;width:26px;height:26px;box-shadow:0 4px 10px -4px #50402699}.lp-read-slider::-moz-range-track{background:linear-gradient(90deg, var(--tan-deep) 0, var(--tan-deep) var(--lp-fill-x), var(--ink-rule) var(--lp-fill-x), var(--ink-rule) 100%);border-radius:999px;height:4px}.lp-read-slider:hover::-webkit-slider-thumb{transform:scale(1.08)}.lp-read-slider:active::-webkit-slider-thumb{box-shadow:0 0 0 8px #a8854e38}.lp-read-slider:focus-visible{outline:2px solid var(--tan-deep)}.lp-read-slider:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 8px #a8854e42}.lp-read-slider:focus-visible::-moz-range-thumb{box-shadow:0 0 0 8px #a8854e42}.lp-read-scale{min-height:44px;font-family:var(--lp-display);letter-spacing:.06em;color:var(--ink-dim);pointer-events:none;margin-top:10px;font-size:11px;font-weight:800;position:relative}.lp-read-scale>.lp-read-tick-label{white-space:nowrap;position:absolute;top:0;transform:translate(-50%)}.lp-read-tick{flex-direction:column;align-items:center;gap:4px;display:flex;position:absolute;top:-10px;transform:translate(-50%)}.lp-read-tick-mark{background:var(--ink-rule);border-radius:1px;width:2px;height:9px}.lp-read-tick .lp-read-tick-label{white-space:nowrap;position:static;transform:none}.lp-read-tick-minor .lp-read-tick-mark{background:var(--ink-dim);opacity:.55}.lp-read-tick-minor .lp-read-tick-label{color:var(--ink-dim);opacity:.85}.lp-read-tick-hero{z-index:1}.lp-read-tick-hero .lp-read-tick-mark{background:var(--tan-deep);opacity:1;width:3px;height:13px}.lp-read-tick-badge{font-family:var(--lp-display);letter-spacing:.04em;text-align:center;white-space:nowrap;color:#fbf7ee;background:var(--tan-deep);border-radius:999px;padding:4px 11px;font-size:11px;font-weight:800;line-height:1.1;box-shadow:0 4px 12px -5px #504026b3}.lp:lang(zh-TW) .lp-read-tick-badge{font-family:var(--lp-han);letter-spacing:.06em;font-weight:600}@media (width<=480px){.lp-read-tick-badge{padding:4px 9px;font-size:10px}}@media (width<=360px){.lp-read-tick-badge{white-space:normal;max-width:14ch}}.lp-reveal{opacity:0;will-change:opacity, transform;transition:opacity .64s cubic-bezier(.16,.84,.3,1),transform .64s cubic-bezier(.16,.84,.3,1);transform:translateY(34px)}.lp-reveal.lp-in{opacity:1;will-change:auto;transform:none}.lp-reveal-stagger.lp-in>:first-child{transition-delay:0s}.lp-reveal-stagger.lp-in>:nth-child(2){transition-delay:.11s}.lp-reveal-stagger.lp-in>:nth-child(3){transition-delay:.22s}.lp-reveal-stagger>*{opacity:0;transition:opacity .58s cubic-bezier(.16,.84,.3,1),transform .58s cubic-bezier(.16,.84,.3,1);transform:translateY(26px)}.lp-reveal-stagger.lp-in>*{opacity:1;transform:none}@media (prefers-reduced-motion:reduce){.lp-cta,.lp-cta-arrow,.lp-lang-btn{transition:none}.lp-cta:hover .lp-cta-arrow{transform:none}.lp-reveal,.lp-reveal-stagger>*{opacity:1;will-change:auto;transition:none;transform:none}.lp-read-char,.lp-read-punct{--w:1;opacity:1;filter:none;transition:none;transform:none}.lp-read-char.is-dim{opacity:.4;filter:blur(1.1px)}.lp-read-char.is-lit{text-shadow:0 0 14px #c9a36a73}.lp-read-punct{opacity:.7}.lp-note-stat-num,.lp-read-tab{transition:none}.lp-read-slider::-webkit-slider-thumb{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(--ink,#1c1a17);color:var(--paper,#f3eee2);font-weight:600;font-family:var(--font,inherit);align-items:center;gap:12px;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 6px 18px -8px #1c1a1780}.update-banner-msg{flex:1;min-width:0}.update-banner-update{background:var(--paper,#f3eee2);color:var(--ink,#1c1a17);cursor:pointer;white-space:nowrap;border:none;border-radius:999px;padding:7px 18px;font-weight:700}.update-banner-later{color:#f3eee2cc;cursor:pointer;white-space:nowrap;background:0 0;border:none;font-weight:500;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}.sba-gemini-section{flex-direction:column;gap:12px;margin-top:8px;display:flex}.sba-gemini-btn{color:#fff;cursor:pointer;letter-spacing:.02em;background:linear-gradient(135deg,#4f46e5,#7c3aed);border:none;border-radius:8px;align-self:flex-start;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .15s,transform .1s}.sba-gemini-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.sba-gemini-btn:active:not(:disabled){transform:translateY(0)}.sba-gemini-btn:disabled{opacity:.45;cursor:not-allowed}.sba-gen-error{color:#c62828;background:#fff0f0;border:1px solid #f9a8a8;border-radius:6px;padding:10px 14px;font-size:13px}.sba-gen-output{flex-direction:column;gap:6px;display:flex}.sba-gen-textarea{min-height:320px}body[data-theme=gold]{--foil:linear-gradient(135deg, #fff3b0 0%, gold 28%, #b8860b 52%, #ffe680 74%, #c9971c 100%);--foil-edge:#8a6a0a;--foil-glow:0 0 18px #ffc83c73;--foil-ink:#3a2a00;--foil-halo:#ffd25a38;--foil-edge-shadow:#78500038;--foil-text-shadow:#78500073;--band-emblem:"👑";--title-sweep:linear-gradient(100deg, #fff6c8 0%, gold 25%, #fffbe6 42%, #e0a815 60%, gold 80%, #fff6c8 100%);--paper:#14224b;--paper-raised:#1b2c5c;--paper-sunken:#101c40;--ink:#f6eccb;--ink-soft:#d8c89a;--ink-faint:#a99b6e;--rule:#2e3f6e;--rule-strong:#41538a;--bg-input:#0e1838;--seal:#e7b53c;--seal-deep:#c8971c;--seal-wash:#e7b53c29;--gold:#e7b53c;--gold-dark:#b8860b;--grad-primary:var(--foil);--screen-bg:#0b1437;--screen-bg-dark:#0a1230;--font-display:var(--font);--text-weight:700}body[data-theme=silver]{--foil:linear-gradient(135deg, #fff 0%, #d7dde6 26%, #9aa4b2 52%, #eef2f7 74%, #aeb7c4 100%);--foil-edge:#5b6573;--foil-glow:0 0 18px #c8d7eb80;--foil-ink:#2a3340;--foil-halo:#d2e0f042;--foil-edge-shadow:#3c485a38;--foil-text-shadow:#3c485a73;--band-emblem:"♔";--title-sweep:linear-gradient(100deg, #fff 0%, #d7dde6 25%, #fff 42%, #93a0b2 60%, #d7dde6 80%, #fff 100%);--paper:#122a33;--paper-raised:#1a363f;--paper-sunken:#0e2229;--ink:#edf2f7;--ink-soft:#c3cfd9;--ink-faint:#8e9ca8;--rule:#294049;--rule-strong:#3c5560;--bg-input:#0b1d23;--seal:#9fb3c2;--seal-deep:#74899a;--seal-wash:#9fb3c229;--gold:#c2cdd8;--gold-dark:#93a0b2;--grad-primary:var(--foil);--screen-bg:#0e2a33;--screen-bg-dark:#0c242c;--font-display:var(--font);--text-weight:700}body[data-theme=gold],body[data-theme=silver]{font-weight:var(--text-weight,400);background:radial-gradient(120% 80% at 50% -8%, var(--foil-halo) 0%, transparent 55%), var(--screen-bg);background-attachment:fixed}body[data-theme=gold]:before,body[data-theme=silver]:before{content:"";height:env(safe-area-inset-top,0px);background:var(--foil);box-shadow:0 2px 0 var(--foil-edge), 0 3px 12px var(--foil-edge-shadow);z-index:1000;pointer-events:none;position:fixed;top:0;left:0;right:0}body[data-theme=gold]:after,body[data-theme=silver]:after{content:var(--band-emblem);height:env(safe-area-inset-top,0px);text-shadow:0 1px 2px var(--foil-text-shadow);box-shadow:inset 0 0 0 2px transparent, inset 0 0 0 3px var(--foil-edge);z-index:1001;pointer-events:none;justify-content:center;align-items:center;font-size:.62em;line-height:1;display:flex;position:fixed;top:0;left:0;right:0;overflow:hidden}@keyframes premium-band-sheen{0%{background-position:-150% 0}to{background-position:250% 0}}body[data-theme=gold]:before,body[data-theme=silver]:before{background-image:linear-gradient(105deg, transparent 35%, #ffffffbf 50%, transparent 65%), var(--foil);background-repeat:no-repeat;background-size:220% 100%,100% 100%;animation:6s linear infinite premium-band-sheen}@keyframes premium-shimmer{0%{background-position:0%}to{background-position:200%}}body[data-theme=gold] .welcome-header h1,body[data-theme=gold] .user-picker h1,body[data-theme=silver] .welcome-header h1,body[data-theme=silver] .user-picker h1{background:var(--title-sweep);color:#0000;-webkit-text-fill-color:transparent;text-shadow:0 2px 10px var(--foil-text-shadow);background-size:200%;-webkit-background-clip:text;background-clip:text;animation:5.5s linear infinite premium-shimmer}body[data-theme=gold] .welcome-header h1:after,body[data-theme=silver] .welcome-header h1:after,body[data-theme=gold] .user-picker h1:after,body[data-theme=silver] .user-picker h1:after{content:" " var(--band-emblem);-webkit-text-fill-color:initial;-webkit-background-clip:initial;background-clip:initial}.user-list .user-btn__crown{text-shadow:0 1px 3px #00000040;font-size:1.3em;line-height:1}body[data-theme=gold] .module-card,body[data-theme=silver] .module-card{background:var(--bg-raised) padding-box, var(--foil) border-box;border:3px solid #0000}body[data-theme=gold] .module-card--writing-challenge,body[data-theme=silver] .module-card--writing-challenge{background:var(--teal) padding-box, var(--foil) border-box;box-shadow:0 6px 0 var(--teal-dark), var(--foil-glow)}body[data-theme=gold] .module-card--word-sets,body[data-theme=silver] .module-card--word-sets{background:var(--pink) padding-box, var(--foil) border-box;box-shadow:0 6px 0 var(--pink-dark), var(--foil-glow)}body[data-theme=gold] .module-card--practice-english,body[data-theme=silver] .module-card--practice-english{background:var(--blue) padding-box, var(--foil) border-box;box-shadow:0 6px 0 var(--blue-dark), var(--foil-glow)}body[data-theme=gold] .module-card--copybook,body[data-theme=silver] .module-card--copybook{background:#ff8a3d padding-box, var(--foil) border-box;box-shadow:0 6px 0 #c75e1a, var(--foil-glow)}body[data-theme=gold] .module-card .module-icon,body[data-theme=silver] .module-card .module-icon{background:var(--foil);box-shadow:0 3px 0 var(--foil-edge), inset 0 2px 3px #ffffffb3, inset 0 -2px 4px var(--foil-edge-shadow)}@media (hover:hover){body[data-theme=gold] .module-card:hover,body[data-theme=silver] .module-card:hover{box-shadow:0 11px 0 var(--foil-edge-shadow), 0 18px 36px var(--foil-glow)}}body[data-theme=gold] .welcome-level,body[data-theme=silver] .welcome-level{background:var(--foil);color:var(--foil-ink);border:2px solid var(--foil-edge);box-shadow:0 4px 0 var(--foil-edge), var(--foil-glow);font-weight:800}body[data-theme=gold] .welcome-level:before,body[data-theme=silver] .welcome-level:before{content:var(--band-emblem) " "}body[data-theme=gold] .user-create button,body[data-theme=silver] .user-create button{background:var(--foil);color:var(--foil-ink);box-shadow:var(--foil-glow)}body[data-theme=gold] .settings-option.active,body[data-theme=silver] .settings-option.active{color:var(--foil-ink);text-shadow:none}body[data-theme=gold] .app-shell .ui-btn--primary,body[data-theme=silver] .app-shell .ui-btn--primary{background:var(--foil);color:var(--foil-ink);box-shadow:0 2px 0 var(--foil-edge), var(--foil-glow)}body[data-theme=gold] .app-shell .char-tile,body[data-theme=silver] .app-shell .char-tile{--ct-face:var(--paper-raised);--ct-line:var(--rule);--ct-ink:var(--ink);--ct-ink-soft:var(--ink-faint)}body[data-theme=gold][data-screen=mychars] .char-tile,body[data-theme=silver][data-screen=mychars] .char-tile{background:linear-gradient(155deg, #ffffff4d, #ffffff24) padding-box, var(--foil) border-box;box-shadow:inset 0 1px 0 #ffffff80, 0 4px 14px var(--foil-edge-shadow), var(--foil-glow);border:2px solid #0000}@supports not ((-webkit-backdrop-filter:blur(2px)) or (backdrop-filter:blur(2px))){body[data-theme=gold][data-screen=mychars] .char-tile,body[data-theme=silver][data-screen=mychars] .char-tile{background:#ffffffdb padding-box, var(--foil) border-box}}body[data-theme=gold][data-screen=mychars] .char-tile--known,body[data-theme=silver][data-screen=mychars] .char-tile--known{box-shadow:inset 0 1px 0 #ffffff8c, 0 4px 14px var(--foil-edge-shadow), var(--foil-glow), 0 0 14px color-mix(in srgb, var(--success) 35%, transparent)}body[data-theme=gold][data-screen=mychars] .char-tile-glyph,body[data-theme=silver][data-screen=mychars] .char-tile-glyph{color:var(--foil-ink);text-shadow:0 1px 1px #ffffff80}body[data-theme=gold][data-screen=mychars] .char-tile-rank,body[data-theme=silver][data-screen=mychars] .char-tile-rank{color:var(--foil-ink);border-color:var(--foil-edge)}body[data-theme=gold][data-screen=mychars] .char-tile-level,body[data-theme=silver][data-screen=mychars] .char-tile-level{color:var(--foil-ink);background:var(--foil);border-color:var(--foil-edge);text-shadow:0 1px 1px #fff6}@media (hover:hover){body[data-theme=gold][data-screen=mychars] .char-tile--tappable:hover,body[data-theme=silver][data-screen=mychars] .char-tile--tappable:hover{box-shadow:inset 0 1px 0 #fff9, 0 8px 22px var(--foil-edge-shadow), var(--foil-glow)}}@media (prefers-reduced-motion:reduce){body[data-theme=gold] .welcome-header h1,body[data-theme=gold] .user-picker h1,body[data-theme=silver] .welcome-header h1,body[data-theme=silver] .user-picker h1,body[data-theme=gold]:before,body[data-theme=silver]:before{animation:none}}.app-shell .ui-btn{border-radius:var(--radius);min-height:44px;font-family:var(--font);color:var(--text);cursor:pointer;touch-action:manipulation;-webkit-appearance:none;border:none;justify-content:center;align-items:center;gap:10px;padding:15px 28px;font-size:17px;font-weight:700;line-height:1;transition:background .16s,transform .1s,border-color .16s,color .16s;display:inline-flex;position:relative}.app-shell .ui-btn:disabled{opacity:.45;box-shadow:none;cursor:default}.app-shell .ui-btn--primary{background:var(--ink);color:var(--paper)}.app-shell .ui-btn--primary:active:not(:disabled){transform:translateY(1px)}.app-shell .ui-btn--secondary{background:var(--paper-raised);color:var(--ink);border:1px solid var(--rule-strong)}.app-shell .ui-btn--secondary:active:not(:disabled){transform:translateY(1px)}.app-shell .ui-btn--ghost{color:var(--ink-soft);background:0 0;border:1px solid #0000;padding:10px 18px;font-size:14px;font-weight:700}.app-shell .ui-btn--ghost:active:not(:disabled){transform:translateY(1px)}@media (hover:hover){.app-shell .ui-btn--primary:hover:not(:disabled){background:#000}.app-shell .ui-btn--secondary:hover:not(:disabled){border-color:var(--ink)}.app-shell .ui-btn--ghost:hover:not(:disabled){color:var(--ink);border-color:var(--rule)}}.app-shell .ui-btn:focus-visible{outline:2px solid var(--seal);outline-offset:3px;z-index:1}@media (prefers-reduced-motion:reduce){.app-shell .ui-btn{transition:none}.app-shell .ui-btn:active:not(:disabled),.app-shell .ui-btn:hover:not(:disabled){transform:none}}.app-shell .ui-screen{box-sizing:border-box;width:100%;padding:16px 16px calc(16px + env(safe-area-inset-bottom,0px));flex-direction:column;align-items:center;display:flex}.app-shell .ui-screen-card{flex-direction:column;align-items:center;gap:22px;display:flex}.app-shell .ui-screen>.module-back{align-self:flex-start;margin-top:0;margin-bottom:16px;margin-left:0}.app-shell .module-back--sm{margin:0}.app-shell .ui-screen>.module-tile{margin-top:0;margin-bottom:24px}.app-shell .module-tile.ui-screen-card--wide{max-width:600px}.app-shell .char-tile{--ct-ink:var(--ink);--ct-ink-soft:var(--ink-faint);--ct-line:var(--rule);--ct-face:var(--paper-raised);box-sizing:border-box;aspect-ratio:1;border:1px solid var(--ct-line);border-radius:var(--radius-sm);background:var(--ct-face);color:var(--ct-ink);box-shadow:var(--shadow-sm);flex-direction:column;align-items:stretch;display:flex;position:relative;overflow:hidden}.app-shell .char-tile:before{content:"";pointer-events:none;background:linear-gradient(to right, transparent calc(50% - .5px), var(--ct-line) calc(50% - .5px), var(--ct-line) calc(50% + .5px), transparent calc(50% + .5px)), linear-gradient(to bottom, transparent calc(50% - .5px), var(--ct-line) calc(50% - .5px), var(--ct-line) calc(50% + .5px), transparent calc(50% + .5px));opacity:.5;position:absolute;inset:0}.app-shell .char-tile--lg{padding:9px 9px 0}.app-shell .char-tile--lg .char-tile-glyph{font-size:34px}.app-shell .char-tile--sm{min-width:54px;padding:6px 6px 0}.app-shell .char-tile--sm .char-tile-glyph{font-size:26px}.app-shell .char-tile--sm .char-tile-top{font-size:9px}.app-shell .char-tile--sm:before{display:none}.app-shell .char-tile--known{--ct-face:linear-gradient(155deg, #4f7a3a1f, #4f7a3a0a);border-color:color-mix(in srgb, var(--success) 50%, var(--rule))}.app-shell .char-tile--tappable{cursor:pointer;touch-action:manipulation;transition:transform var(--transition), border-color var(--transition), box-shadow var(--transition)}.app-shell .char-tile--tappable:active{transform:scale(.96)}.app-shell .char-tile--tappable:focus-visible{outline:2px solid var(--seal);outline-offset:2px;z-index:1}@media (hover:hover){.app-shell .char-tile--tappable:hover{border-color:var(--ct-ink-soft);box-shadow:var(--shadow-md)}}@media (prefers-reduced-motion:reduce){.app-shell .char-tile--tappable{transition:none}.app-shell .char-tile--tappable:active{transform:none}}.app-shell .char-tile-top{z-index:1;box-sizing:border-box;justify-content:space-between;align-items:center;gap:6px;width:100%;padding:0 2px;font-size:10px;line-height:1;display:flex;position:relative}.app-shell .char-tile-rank{font-variant-numeric:tabular-nums;letter-spacing:-.2px;color:var(--ct-ink-soft);align-items:center;gap:3px;min-width:0;font-weight:600;display:inline-flex}.app-shell .char-tile-pip{background:var(--rule-strong);border-radius:50%;flex:none;width:6px;height:6px}.app-shell .char-tile-pip--below{background:var(--seal)}.app-shell .char-tile-pip--target{background:var(--success)}.app-shell .char-tile-pip--above{background:var(--warning)}.app-shell .char-tile-level{box-sizing:border-box;font-variant-numeric:tabular-nums;color:var(--seal);border:1px solid color-mix(in srgb, var(--seal) 45%, transparent);white-space:nowrap;background:0 0;border-radius:5px;flex:none;padding:1px 5px;font-weight:700}.app-shell .char-tile-glyph{z-index:1;font-family:var(--font-han);color:var(--ct-ink);flex:auto;justify-content:center;align-items:center;font-weight:500;line-height:1;display:flex;position:relative}.app-shell .char-tile-foot{z-index:1;justify-content:center;align-items:center;min-height:8px;margin-bottom:8px;display:flex;position:relative}.app-shell .char-tile--sm .char-tile-foot{margin-bottom:7px}.app-shell .char-tile-dots{gap:3px;display:flex}.app-shell .char-tile-dot{border-radius:50%;width:6px;height:6px;display:inline-block}.app-shell .char-tile-dot--P{background:var(--success)}.app-shell .char-tile-dot--C{background:var(--warning)}.app-shell .char-tile-dot--I{background:var(--seal)}.app-shell .char-tile-dot--S{background:var(--ct-ink);opacity:.3}.app-shell .char-tile-bar{z-index:1;background:var(--rule);border-radius:999px;height:3px;margin:0 1px 1px;display:block;position:relative;overflow:hidden}.app-shell .char-tile-bar-fill{border-radius:999px;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1),background .3s;display:block}@media (prefers-reduced-motion:reduce){.app-shell .char-tile-bar-fill{transition:none}}
