*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.block{display:block}.inline{display:inline}.hidden{display:none}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--color-bg:#f7fbff;--color-surface:#fff;--color-surface-blue:#eaf5ff;--color-text:#1f2a37;--color-muted:#64748b;--color-border:#d7e2ea;--color-primary:#147c72;--color-primary-strong:#0f5f57;--color-primary-soft:#dff5f0;--color-coral:#e85d5a;--color-coral-soft:#ffe8e4;--color-yellow:#f2b84b;--color-yellow-soft:#fff4d8;--color-blue:#3f73d8;--color-blue-soft:#e9efff;--shadow-soft:0 18px 42px #1f2a371a;--font-ui:system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Noto Sans SC", "Noto Sans CJK SC", "Source Han Sans SC", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-character:"Noto Sans SC", "Noto Sans CJK SC", "Source Han Sans SC", "HarmonyOS Sans SC", "MiSans", "OPPO Sans", "Droid Sans Fallback", "PingFang SC", "Microsoft YaHei", sans-serif;font-family:var(--font-ui)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{background:var(--color-bg);color:var(--color-text);margin:0}button,textarea{font:inherit}button{-webkit-tap-highlight-color:transparent}.app-shell{min-height:100dvh;padding:max(16px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(18px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left))}.setup-page,.result-page{align-content:center;gap:18px;width:min(100%,1080px);min-height:calc(100dvh - 34px);margin:0 auto;display:grid}.setup-hero,.result-header{align-items:center;gap:14px;display:flex}.brand-mark,.result-mark{border:2px solid var(--color-primary);background:var(--color-primary-soft);width:64px;height:64px;color:var(--color-primary-strong);font-family:var(--font-character);border-radius:8px;flex:none;place-items:center;font-size:34px;font-weight:800;display:grid}.result-mark{background:var(--color-yellow-soft);border-color:var(--color-yellow);color:#8a5b00}h1,h2,p{margin:0}h1{font-size:1.8rem;line-height:1.15}h2{font-size:1.05rem}.setup-hero p,.result-header p,.source-line{color:var(--color-muted)}.setup-grid{gap:14px;display:grid}.input-panel,.settings-panel,.character-list-panel{border:1px solid var(--color-border);background:var(--color-surface);box-shadow:var(--shadow-soft);border-radius:8px}.input-panel,.settings-panel{gap:14px;padding:14px;display:grid}.field-label{color:var(--color-text);font-size:.92rem;font-weight:750}.character-input{resize:vertical;border:2px solid var(--color-border);width:100%;min-height:144px;color:var(--color-text);background:#fbfdff;border-radius:8px;outline:none;padding:14px;font-size:1.15rem;line-height:1.7}.character-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #147c7221}.preview-row{flex-wrap:wrap;align-items:flex-start;gap:8px;min-height:48px;display:flex}.character-chip{border:1px solid var(--color-border);background:var(--color-surface-blue);border-radius:8px;gap:4px;min-width:46px;min-height:56px;padding:6px;display:grid}.character-chip[data-polyphonic=true]{background:#fffaf0;border-color:#f0cf7c;min-width:min(100%,212px)}.character-chip-main{place-items:center;gap:1px;display:grid}.character-chip-pinyin{min-height:16px;color:var(--color-primary-strong);font-size:.72rem;font-weight:780;line-height:1}.character-chip-char{font-family:var(--font-character);font-size:1.35rem;font-weight:800;line-height:1.08}.pinyin-choice-row{flex-wrap:wrap;gap:5px;display:flex}.pinyin-choice{color:#7a4b00;cursor:pointer;background:#fff;border:1px solid #e0ba56;border-radius:8px;min-width:54px;min-height:34px;padding:0 8px;font-size:.9rem;font-weight:820}.pinyin-choice[data-selected=true]{border-color:var(--color-primary);background:var(--color-primary);color:#fff;box-shadow:0 0 0 3px #147c7229}.empty-preview,.empty-recent{color:var(--color-muted)}.input-actions{grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:10px;display:grid}.share-status{min-height:22px;color:var(--color-primary-strong);text-align:center;font-size:.9rem;font-weight:760}.segmented-field,.toggle-group,.recent-panel{gap:10px;display:grid}.segmented-control{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.segment,.recent-item,.ui-button,.icon-button,.find-option{cursor:pointer;border:0}.segment{border:1px solid var(--color-border);min-height:56px;color:var(--color-text);background:#f9fbfd;border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:760;display:flex}.segment[data-selected=true]{border-color:var(--color-primary);background:var(--color-primary-soft);color:var(--color-primary-strong)}.toggle-row{border:1px solid var(--color-border);background:#f9fbfd;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;min-height:56px;padding:0 12px;display:flex}.toggle-label{align-items:center;gap:8px;font-weight:730;display:flex}.toggle-root{background:#b7c6d6;border:0;border-radius:999px;width:52px;height:32px;position:relative}.toggle-root[data-state=checked]{background:var(--color-primary)}.toggle-thumb{background:#fff;border-radius:50%;width:26px;height:26px;transition:transform .16s;display:block;transform:translate(3px);box-shadow:0 2px 8px #1f2a3733}.toggle-root[data-state=checked] .toggle-thumb{transform:translate(23px)}.section-heading{align-items:center;gap:8px;font-weight:800;display:flex}.recent-list{gap:8px;display:grid}.recent-item{border:1px solid var(--color-border);min-height:48px;color:var(--color-text);background:#fff;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;padding:6px;display:grid}.recent-item[data-editing=true]{border-color:var(--color-primary);background:var(--color-primary-soft)}.recent-main-action{min-width:0;min-height:44px;color:var(--color-text);text-align:left;cursor:pointer;background:0 0;border:0;border-radius:8px;align-items:center;gap:8px;padding:6px 8px;display:flex}.recent-main-action>span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.recent-row-actions{align-items:center;gap:4px;display:flex}.recent-icon-action{background:var(--color-blue-soft);color:#244a9c;cursor:pointer;border:1px solid #0000;border-radius:8px;place-items:center;width:40px;height:40px;display:inline-grid}.recent-icon-action--danger{background:var(--color-coral-soft);color:#9c3330}.ui-button:focus-visible,.icon-button:focus-visible,.segment:focus-visible,.toggle-root:focus-visible,.pinyin-choice:focus-visible,.recent-main-action:focus-visible,.recent-icon-action:focus-visible{outline-offset:3px;outline:3px solid #0f6f66;box-shadow:0 0 0 6px #147c722e}.empty-recent{border:1px dashed var(--color-border);border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:62px;display:flex}.ui-button{border:2px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:9px;min-height:52px;padding:0 18px;font-weight:850;transition:transform .12s,opacity .12s,background-color .12s,border-color .12s,box-shadow .12s;display:inline-flex}.ui-button:active,.icon-button:active,.segment:active,.find-option:active,.recent-main-action:active,.recent-icon-action:active{transform:scale(.98)}.ui-button:disabled,.icon-button:disabled{cursor:not-allowed;opacity:.45}.ui-button--large{min-height:60px;font-size:1.05rem}.ui-button--primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.ui-button--primary:hover{background:var(--color-primary-strong)}.ui-button--secondary{background:var(--color-yellow-soft);color:#7a5200;border-color:#f0cf7a}.ui-button--quiet{background:var(--color-blue-soft);color:#244a9c;border-color:#c9d7ff}.ui-button--danger{background:var(--color-coral-soft);color:#9c3330;border-color:#f1aca6}.ui-button[data-selected=true]{font-weight:900}.ui-button--primary[data-selected=true]{border-color:var(--color-primary-strong);box-shadow:inset 0 0 0 2px #ffffff8c,0 0 0 4px #147c7238}.ui-button--secondary[data-selected=true]{background:#ffe7aa;border-color:#c88d13;box-shadow:inset 0 0 0 2px #ffffffa6,0 0 0 4px #f2b84b47}.ui-button--danger[data-selected=true]{background:#ffd6d0;border-color:#be3f39;box-shadow:inset 0 0 0 2px #ffffffa6,0 0 0 4px #e85d5a3d}.icon-button{width:56px;height:56px;color:var(--color-text);border:1px solid var(--color-border);background:#fff;border-radius:8px;place-items:center;display:inline-grid}.icon-button--quiet{background:0 0}.icon-button--danger{background:var(--color-coral-soft);color:#a53530}.practice-page{grid-template-rows:auto auto minmax(0,1fr);gap:10px;width:min(100%,1180px);min-height:calc(100dvh - 34px);margin:0 auto;display:grid}.practice-header{grid-template-columns:56px minmax(0,1fr) 56px;align-items:center;gap:10px;min-height:58px;display:grid}.practice-meta{justify-content:center;align-items:baseline;gap:10px;min-width:0;font-weight:760;display:flex}.practice-meta span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.practice-meta strong{color:var(--color-primary-strong)}.progress-dots{justify-content:center;align-items:center;gap:5px;min-height:14px;display:flex;overflow:hidden}.progress-dot{background:#c6d2dd;border-radius:999px;flex:none;width:8px;height:8px;transition:width .14s,background-color .14s,box-shadow .14s}.progress-dot[data-done=true]{background:#9fb0bf}.progress-dot[data-active=true]{background:var(--color-blue);width:22px;box-shadow:0 0 0 3px #3f73d82e}.progress-dot[data-result=unknown]{background:var(--color-coral)}.progress-dot[data-result=review]{background:var(--color-yellow)}.progress-dot[data-result=known]{background:var(--color-primary)}.progress-dot[data-active=true][data-result=unknown]{box-shadow:0 0 0 3px #e85d5a33}.progress-dot[data-active=true][data-result=review]{box-shadow:0 0 0 3px #f2b84b42}.progress-dot[data-active=true][data-result=known]{box-shadow:0 0 0 3px #147c7238}.practice-layout{grid-template-rows:minmax(0,1fr) auto;gap:12px;min-height:0;display:grid}.character-card{border:1px solid var(--color-border);min-height:0;box-shadow:var(--shadow-soft);background:#fff;border-radius:8px;grid-template-rows:auto minmax(0,1fr);display:grid;overflow:hidden}.character-card-top{border-bottom:1px solid var(--color-border);background:#fbfdff;justify-content:space-between;align-items:center;gap:10px;min-height:58px;padding:8px 10px 8px 12px;display:flex}.character-card-action{justify-content:flex-end;min-width:56px;display:flex}.character-stage{background:#fff;place-items:center;min-height:0;padding:14px 16px 18px;display:grid}.character-stack{place-items:center;gap:8px;width:100%;min-height:0;display:grid}.character-reading{place-items:center;display:grid}.character-glyph-field{place-items:center;width:100%;min-height:0;display:grid;position:relative}.character-glyph-field:before,.character-glyph-field:after{content:"";pointer-events:none;opacity:.7;position:absolute}.character-glyph-field:before{border-top:1px dashed #d9e5ee;width:min(76%,460px)}.character-glyph-field:after{border-left:1px dashed #d9e5ee;height:min(76%,460px)}.character-label{background:var(--color-coral-soft);color:#9a3330;border-radius:8px;place-items:center;min-width:44px;height:36px;font-weight:850;display:inline-grid}.character-glyph{z-index:1;font-family:var(--font-character);color:var(--color-text);align-self:center;font-size:clamp(7.8rem,31dvh,17rem);font-weight:900;line-height:.9;position:relative}.character-pinyin{min-height:40px;color:var(--color-muted);letter-spacing:0;font-size:clamp(1.9rem,4dvh,2.5rem);font-weight:800;line-height:1.2}.practice-controls{gap:10px;display:grid}.answer-actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.answer-actions .ui-button{gap:6px;min-width:0;padding:0 8px}.answer-actions .ui-button span{white-space:nowrap;min-width:0}.step-actions{grid-template-columns:repeat(2,56px);justify-content:center;gap:10px;display:grid}.find-controls{align-content:start}.find-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.find-option{aspect-ratio:1;border:2px solid var(--color-border);color:var(--color-text);font-family:var(--font-character);background:#fff;border-radius:8px;place-items:center;font-size:2.6rem;font-weight:900;display:grid}.find-option[data-correct=true]{border-color:var(--color-primary);background:var(--color-primary-soft);color:var(--color-primary-strong)}.find-option[data-wrong=true]{border-color:var(--color-coral);background:var(--color-coral-soft);color:#9a3330}.result-page{max-width:760px}.result-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.result-badge{border:1px solid var(--color-border);background:#fff;border-radius:8px;align-items:center;gap:12px;min-height:94px;padding:12px;display:flex}.result-badge[data-tone=green]{background:var(--color-primary-soft);color:var(--color-primary-strong)}.result-badge[data-tone=yellow]{background:var(--color-yellow-soft);color:#7a5200}.result-badge[data-tone=blue]{background:var(--color-blue-soft);color:#244a9c}.result-value{font-size:1.55rem;font-weight:900;line-height:1}.result-label{margin-top:4px;font-size:.88rem;font-weight:760}.result-lists,.result-actions{gap:10px;display:grid}.character-list-panel{padding:14px}.character-list-panel h2{margin-bottom:10px}.source-line{text-align:center;word-break:break-all}@media (width>=760px){.setup-grid{grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);align-items:start}.result-actions{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (orientation:landscape){.practice-layout{grid-template-rows:minmax(0,1fr);grid-template-columns:minmax(0,1fr) minmax(292px,360px)}.character-glyph{font-size:clamp(7.6rem,46dvh,15.5rem)}.character-pinyin{min-height:30px;font-size:clamp(1.35rem,5.8dvh,1.95rem)}.practice-controls{align-content:center}}@media (width<=520px){.app-shell{padding:max(12px, env(safe-area-inset-top)) max(12px, env(safe-area-inset-right)) max(14px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left))}.setup-page,.result-page{align-content:start;min-height:calc(100dvh - 26px)}.result-grid{grid-template-columns:1fr}.result-badge{min-height:76px}}@media (height<=460px) and (orientation:landscape){.app-shell{padding:max(8px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left))}.practice-page{gap:6px;height:calc(100dvh - 16px);min-height:calc(100dvh - 16px)}.practice-layout{grid-template-columns:minmax(0,1fr) minmax(260px,300px)}.practice-header{min-height:48px}.icon-button{width:50px;height:50px}.character-card-top{min-height:46px;padding:5px 8px 5px 10px}.character-stage{padding:8px 10px 10px}.character-glyph{font-size:clamp(6.6rem,42dvh,13rem)}.character-label{min-width:38px;height:32px}.character-stack{gap:4px}.character-pinyin{min-height:24px;font-size:1.25rem}.find-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.find-option{font-size:2rem}.ui-button--large{min-height:52px}}
