:root{color:#1f2937;background:#f5f2ea;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button{color:inherit;font:inherit}.app-shell{display:grid;grid-template-rows:auto 1fr;min-height:100vh}.app-shell>.admin-area{min-height:0}.sign-in-page{display:grid;min-height:100vh;padding:24px;background:#f5f2ea;place-items:center}.sign-in-panel{display:grid;gap:22px;width:min(100%,460px);padding:28px;border:1px solid #d8c9b7;border-radius:8px;background:#fff;box-shadow:0 18px 48px #1f29371f}.sign-in-brand h1{color:#243b53;font-size:2.2rem}.sign-in-copy{margin-bottom:0;color:#52616f;font-weight:700;line-height:1.5}.google-sign-in-button{min-height:52px;border:0;border-radius:8px;background:#243b53;color:#fff;cursor:pointer;font-weight:900;padding:0 18px}.google-sign-in-button:disabled{cursor:wait;opacity:.72}.app-header{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:18px;padding:14px 24px;border-bottom:1px solid rgba(255,255,255,.12);background:#243b53;color:#f8fafc;box-shadow:0 8px 24px #1f293729}.app-brand{display:grid;flex:0 0 auto;gap:1px}.app-brand h1{margin:0;color:#f8fafc;font-size:1.35rem;line-height:1}.app-brand span{color:#e9b872;font-family:PingFang TC,Noto Sans TC,Microsoft JhengHei,serif;font-size:1rem;font-weight:900;line-height:1.1}.app-header-controls{display:flex;flex:1 1 auto;align-items:center;justify-content:flex-end;gap:12px;min-width:0}.app-mode-group{display:flex;align-items:center;gap:10px;min-width:0;padding:6px;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#ffffff1a;box-shadow:0 8px 22px #0c182629}.eyebrow{margin:0 0 8px;color:#d49b54;font-size:.8rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}h1,h2,p{margin-top:0}h1{margin-bottom:0;font-size:clamp(1.8rem,3vw,2.6rem);line-height:1.05}h2{margin-bottom:10px;font-size:1.4rem}.character-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.page-nav{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;width:210px;padding:3px;border-radius:8px;background:#ffffff1f}.page-nav button{min-height:40px;border:0;border-radius:6px;background:transparent;color:#f8fafc;cursor:pointer;font-weight:900}.page-nav button.active{background:#e9b872;color:#1f2937;box-shadow:0 6px 14px #9b4d2d29}.profile-menu{position:relative;display:inline-flex;margin-left:auto}.profile-menu-item{display:inline-flex;align-items:center;justify-content:center;width:44px;min-height:44px;border:1px solid rgba(255,255,255,.22);border-radius:8px;background:#ffffff1a;color:#f8fafc;cursor:pointer;font:inherit;font-weight:900;text-align:center;padding:0}.profile-menu-item.active{border-color:#e9b872;background:#e9b872;color:#1f2937;box-shadow:0 6px 14px #9b4d2d29}.profile-switcher-menu{position:absolute;top:calc(100% + 10px);right:0;z-index:20;display:grid;gap:8px;width:min(300px,calc(100vw - 32px));padding:10px;border:1px solid #d8c9b7;border-radius:8px;background:#fff;color:#1f2937;box-shadow:0 18px 42px #0c182638}.profile-switcher-list,.profile-switcher-actions{display:grid;gap:2px}.profile-switcher-list{max-height:260px;overflow:auto}.profile-switcher-actions{padding-top:8px;border-top:1px solid #eadfce}.profile-switcher-item,.profile-switcher-actions button{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;min-height:44px;width:100%;border:0;border-radius:6px;background:transparent;color:#243b53;cursor:pointer;font:inherit;font-weight:900;padding:8px;text-align:left}.profile-switcher-item:hover,.profile-switcher-actions button:hover,.profile-switcher-item.active{background:#fff4df}.profile-switcher-avatar{display:grid;place-items:center;width:30px;height:30px;border-radius:8px;background:#243b53;color:#f8fafc;font-size:.9rem;line-height:1}.lesson-selector{display:grid;width:min(260px,34vw)}.lesson-selector span{color:#e9b872;font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.lesson-selector select{width:100%;min-height:40px;border:0;border-radius:6px;background:#fff;color:#1f2937;font:inherit;font-weight:800;padding:0 8px}.profile-header-summary{display:flex;align-items:center;flex-wrap:wrap;gap:8px 12px;min-height:46px;color:#d8e2ec;font-weight:800;padding:0 8px}.character-tile,.quiz-choice,.icon-button{border:0;cursor:pointer}.character-tile{aspect-ratio:1;border-radius:8px;background:#ffffff1f;color:#fff;font-family:PingFang TC,Noto Sans TC,Microsoft JhengHei,serif;font-size:3rem;transition:transform .16s ease,background .16s ease}.character-tile:hover,.character-tile.active{background:#e9b872;color:#1f2937;transform:translateY(-2px)}.study-area{display:grid;grid-template-rows:auto auto minmax(460px,1fr) auto;gap:20px;padding:28px}.reading-area,.profile-area{display:grid;align-content:start;gap:20px;padding:28px}.admin-area{display:grid;grid-template-rows:auto minmax(0,1fr);align-content:start;gap:20px;min-height:0;padding:28px}.admin-heading{display:flex;align-items:end;justify-content:space-between;gap:16px}.admin-heading h2,.admin-heading p{margin-bottom:0}.admin-heading>p{color:#52616f;font-weight:800}.admin-shell{display:grid;grid-template-columns:minmax(240px,320px) 1fr;gap:18px;min-height:0}.admin-shell.sidebar-collapsed{grid-template-columns:64px 1fr}.admin-sidebar,.admin-editor{display:grid;align-content:start;gap:14px;min-width:0;min-height:0;padding:16px;border:1px solid #d8c9b7;border-radius:8px;background:#fff;box-shadow:0 10px 28px #1f29370f}.admin-sidebar-header{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:44px}.admin-sidebar-header span{color:#52616f;font-size:.78rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.sidebar-collapsed .admin-sidebar{justify-items:center;padding:10px}.sidebar-collapsed .admin-sidebar-header{justify-content:center}.admin-field{display:grid;gap:8px}.admin-field span{color:#52616f;font-size:.78rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.admin-field select,.admin-field input{min-height:44px;border:1px solid #d8c9b7;border-radius:8px;background:#fff;color:#1f2937;font:inherit;font-weight:800;padding:0 10px}.admin-field input{width:100%}.admin-image-field{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}.admin-upload-button{min-height:44px}.admin-upload-button input{display:none}.admin-upload-button.disabled{cursor:not-allowed;opacity:.65}.admin-material-list{display:grid;gap:8px;max-height:none;min-height:0;overflow:auto}.admin-material-list button{display:grid;gap:4px;width:100%;min-height:54px;border:1px solid #eadfce;border-radius:8px;background:#fffdf8;color:#243b53;cursor:pointer;font:inherit;padding:10px;text-align:left}.admin-material-list button.active{border-color:#e9b872;background:#fff4df}.admin-material-list span{font-weight:900}.admin-material-list small{color:#52616f;font-weight:800}.admin-editor{grid-template-rows:auto minmax(0,1fr) auto}.admin-editor-toolbar,.admin-editor-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-editor-actions{justify-content:flex-end}.admin-json-editor{width:100%;height:100%;min-height:0;resize:vertical;border:1px solid #d8c9b7;border-radius:8px;background:#fffdf8;color:#1f2937;font:.95rem/1.5 ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;padding:14px;-moz-tab-size:2;tab-size:2}.admin-reading-editor{display:grid;grid-template-rows:auto minmax(0,1fr);gap:14px;min-height:0}.admin-reading-tabs{display:flex;align-items:end;gap:2px;width:100%;height:46px;border-bottom:1px solid #d8c9b7}.admin-reading-tabs button{display:flex;align-items:center;justify-content:center;gap:8px;width:140px;height:46px;min-width:0;border:1px solid transparent;border-bottom:0;border-radius:8px 8px 0 0;background:#f6efe4;color:#52616f;cursor:pointer;font:inherit;font-weight:900;line-height:1;padding:0 12px}.admin-reading-tabs button.active{position:relative;bottom:-1px;border-color:#d8c9b7;background:#fff;color:#1f2937}.admin-reading-tab-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-reading-tab-count{display:inline-grid;place-items:center;width:22px;min-width:22px;height:20px;border-radius:999px;background:#9f2f2f;color:#fff;font-size:.78rem;line-height:1}.admin-reading-tab-count:empty{visibility:hidden}.admin-reading-tab-panel{min-width:0;min-height:0}.admin-reading-fields{display:grid;grid-template-columns:minmax(140px,1fr) minmax(140px,1fr) minmax(90px,.5fr);gap:12px}.admin-field-wide{grid-column:span 2}.admin-reading-text-editor{width:100%;height:100%;min-height:0;resize:vertical;border:1px solid #d8c9b7;border-radius:8px;background:#fffdf8;color:#1f2937;font:1.35rem/2.1 PingFang TC,Noto Sans TC,Microsoft JhengHei,serif;padding:18px}.admin-reading-image-preview{width:100%;border:1px solid #d8c9b7;border-radius:8px;height:auto}.admin-token-review{display:grid;grid-template-rows:auto minmax(0,1fr);gap:10px}.admin-token-review-heading{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-token-review-heading p{margin-bottom:0}.admin-token-review-heading span{color:#52616f;font-weight:800}.admin-token-table{display:grid;max-height:none;min-height:0;overflow:auto;border:1px solid #d8c9b7;border-radius:8px;background:#fff}.admin-token-row{display:grid;grid-template-columns:minmax(76px,.5fr) minmax(130px,1fr) minmax(220px,1.7fr);gap:10px;align-items:center;min-height:48px;padding:8px 10px;border-bottom:1px solid #eadfce}.admin-token-row:last-child{border-bottom:0}.admin-token-header{position:sticky;top:0;z-index:1;min-height:40px;background:#f5ead8;color:#52616f;font-size:.78rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.admin-token-row strong{color:#1f2937;font-family:PingFang TC,Noto Sans TC,Microsoft JhengHei,serif;font-size:1.4rem}.admin-token-row input{width:100%;min-height:36px;border:1px solid #d8c9b7;border-radius:8px;background:#fffdf8;color:#1f2937;font:inherit;padding:0 10px}.admin-token-row input:disabled{background:#f3efe8;color:#8a7b6f}.admin-token-line-break{min-height:36px;background:#fbf5ec;color:#8a7b6f;font-weight:800}.admin-status{display:grid;gap:6px;color:#52616f;font-weight:800}.admin-status strong{color:#9f2f2f}.profile-heading h2{margin-bottom:0}.account-panel{display:grid;gap:14px;max-width:720px;padding:18px;border:1px solid #d8c9b7;border-radius:8px;background:#fff;box-shadow:0 10px 28px #1f29370f}.account-panel h2,.account-error{margin-bottom:0}.account-actions{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.account-identity{color:#243b53;font-weight:900}.account-error{color:#9f2f2f;font-weight:800}.profile-manager{display:flex;align-items:end;flex-wrap:wrap;gap:12px;max-width:720px}.profile-learner-picker{display:grid;flex:1 1 280px;gap:8px}.profile-name-field{display:grid;gap:8px;max-width:420px}.profile-learner-picker span,.profile-name-field span{color:#52616f;font-size:.8rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.profile-learner-picker select,.profile-name-field input{min-height:48px;border:1px solid #d8c9b7;border-radius:8px;background:#fff;color:#1f2937;font:inherit;font-weight:800;padding:0 12px}.profile-manager-actions{display:flex;gap:8px}.profile-action-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:48px;border:1px solid #d8c9b7;border-radius:8px;background:#fff;color:#243b53;cursor:pointer;font-weight:900;padding:0 14px}.profile-action-button:hover{border-color:#e9b872;background:#fff8ed}.profile-action-button.dirty{border-color:#d49b54;background:#d49b54;color:#1f2937}.profile-action-button.dirty:hover{border-color:#bf8133;background:#e9b872}.profile-action-button.danger{color:#9f2f2f}.profile-action-button.danger:hover{border-color:#d89a9a;background:#fff1f1}.profile-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.profile-stat{display:grid;gap:10px;min-height:112px;padding:18px;border:1px solid #d8c9b7;border-radius:8px;background:#fff;box-shadow:0 10px 28px #1f29370f}.profile-stat span,.profile-details dt{color:#52616f;font-size:.82rem;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.profile-stat strong{color:#243b53;font-size:2.6rem;line-height:1}.profile-details{display:grid;gap:12px;max-width:620px;margin:0}.profile-details div{display:grid;grid-template-columns:160px 1fr;gap:12px;align-items:center;padding:14px 0;border-bottom:1px solid #d8c9b7}.profile-details dd{margin:0;color:#1f2937;font-weight:800}.profile-details dd:has(.cloud-sync-status){display:grid;gap:8px}.cloud-sync-status{width:fit-content;min-width:96px;padding:6px 10px;border-radius:8px;background:#fff8ed;color:#9b4d2d;text-align:center}.cloud-sync-status.saved,.cloud-sync-status.ready{background:#e4f3de;color:#3f6f33}.cloud-sync-status.signed-out{background:#eef2f6;color:#52616f}.cloud-sync-status.unavailable{background:#fff1f1;color:#9f2f2f}.cloud-sync-error{color:#9f2f2f;font-size:.9rem;font-weight:700;line-height:1.35}.profile-reading-times,.profile-practiced-characters{display:grid;gap:16px}.profile-reading-times h2,.profile-practiced-characters h2{margin-bottom:0}.profile-reading-list{display:grid;gap:10px;max-width:620px}.profile-reading-item{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:58px;padding:12px 14px;border:1px solid #d8c9b7;border-radius:8px;background:#fff;box-shadow:0 8px 22px #1f29370d}.profile-reading-item span{color:#243b53;font-weight:900}.profile-reading-item strong{color:#2f80a3;font-size:1.05rem}.profile-character-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}.profile-character-item{display:flex;align-items:center;justify-content:space-between;min-height:72px;padding:12px;border:1px solid #d8c9b7;border-radius:8px;background:#fff;box-shadow:0 8px 22px #1f29370d}.profile-character-item span{font-family:PingFang TC,Noto Sans TC,Microsoft JhengHei,serif;font-size:2rem;font-weight:800;line-height:1}.profile-character-item strong{display:grid;place-items:center;min-width:34px;height:34px;border-radius:8px;background:#e9b872;color:#1f2937;font-size:.95rem;line-height:1}.profile-empty-state{margin:0;color:#52616f;font-weight:800}.reading-page-heading h2{margin-bottom:0}.top-bar{display:flex;align-items:center;justify-content:flex-end;gap:14px;color:#52616f;font-weight:800}.icon-button{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:8px;background:#fff;box-shadow:0 8px 22px #1f293714}.icon-button.active{background:#e9b872;color:#1f2937;box-shadow:0 10px 24px #9b4d2d2e}.learning-card{display:grid;grid-template-columns:minmax(210px,280px) 1fr;gap:28px;align-items:center}.character-display{display:grid;place-items:center;aspect-ratio:1;border:1px solid #ddcab2;border-radius:8px;background:#fffaf1;color:#17202a;font-family:PingFang TC,Noto Sans TC,Microsoft JhengHei,serif;font-size:clamp(8rem,18vw,13rem);line-height:1}.character-details{max-width:520px}.sound{margin-bottom:6px;color:#2f80a3;font-size:2rem;font-weight:900}.example-list{display:grid;gap:10px;margin-top:20px}.example-item{display:grid;grid-template-columns:minmax(82px,auto) 1fr;gap:14px;align-items:center}.example-word{margin:0;color:#243b53;font-family:PingFang TC,Noto Sans TC,Microsoft JhengHei,serif;font-size:2.1rem;font-weight:800;line-height:1}.word-sound{margin-bottom:2px;color:#52616f;font-size:1.1rem;font-weight:800}.word-meaning{margin-bottom:0;color:#52616f}.practice-stack{display:grid;gap:14px}.practice-panel{position:relative;overflow:hidden;height:clamp(420px,52vh,560px);min-height:460px;border:1px solid #d8c9b7;border-radius:8px;background:linear-gradient(to right,transparent 49.8%,rgba(36,59,83,.18) 50%,transparent 50.2%),linear-gradient(to bottom,transparent 49.8%,rgba(36,59,83,.18) 50%,transparent 50.2%),#fffdf8;touch-action:none}.stroke-writer-target{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1}.free-practice-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;width:100%;height:100%;pointer-events:none;touch-action:none}.free-practice-active .free-practice-canvas{pointer-events:auto}.free-practice-canvas polyline{fill:none;stroke:#243b53;stroke-linecap:round;stroke-linejoin:round;stroke-width:24}.practice-toolbar{position:absolute;top:16px;right:16px;z-index:4;display:flex;gap:10px}.practice-status{position:absolute;left:18px;bottom:14px;z-index:4;margin:0;color:#52616f;font-size:.95rem;font-weight:800}.mini-stroke-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));grid-auto-rows:1fr;gap:12px}.mini-stroke-writer{position:relative;overflow:hidden;aspect-ratio:1;min-width:0;border:1px solid #d8c9b7;border-radius:8px;background:linear-gradient(to right,transparent 49.5%,rgba(36,59,83,.12) 50%,transparent 50.5%),linear-gradient(to bottom,transparent 49.5%,rgba(36,59,83,.12) 50%,transparent 50.5%),#fffdf8;touch-action:none}.mini-stroke-writer svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.reading-panel{position:relative;isolation:isolate;overflow:hidden;display:grid;gap:18px;padding:22px;border:1px solid #d8c9b7;border-radius:8px;background:#fff;box-shadow:0 10px 28px #1f29370f}.reading-panel.with-background:before{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;background-image:var(--reading-image);background-position:center;background-repeat:no-repeat;background-size:cover;content:"";opacity:.18}.reading-header{display:grid;gap:20px;align-items:end}.reading-header h2{margin-bottom:0}.reading-content{display:flow-root}.reading-line{display:flex;flex-wrap:wrap;gap:10px 8px;align-items:flex-end}.reading-line-break{flex-basis:100%;height:0}.reading-token{display:grid;min-width:58px;min-height:76px;padding:8px 8px 7px;border:2px solid #d8c9b7;border-radius:8px;background:#fffaf1;color:#1f2937;cursor:pointer;text-align:center}.reading-token.active{border-color:#9b4d2d;background:#e9b872}.reading-character{font-family:PingFang TC,Noto Sans TC,Microsoft JhengHei,serif;font-size:2.25rem;font-weight:800;line-height:1}.reading-yale{color:#2f80a3;font-size:.95rem;font-weight:900;line-height:1.15}.reading-punctuation{padding-bottom:18px;color:#52616f;font-family:PingFang TC,Noto Sans TC,Microsoft JhengHei,serif;font-size:2.25rem;font-weight:800}.reading-meaning{min-height:24px;margin:0;color:#52616f;font-weight:800}.quiz-panel{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;padding:20px;border-radius:8px;background:#fff;box-shadow:0 10px 28px #1f293714}.quiz-panel h2{margin-bottom:0}.quiz-options{display:grid;grid-template-columns:repeat(4,74px);gap:10px}.quiz-choice{display:flex;align-items:center;justify-content:center;gap:4px;height:74px;border:2px solid #d8c9b7;border-radius:8px;background:#fffaf1;font-family:PingFang TC,Noto Sans TC,Microsoft JhengHei,serif;font-size:2.4rem;font-weight:800}.quiz-choice.selected{border-color:#9b4d2d}.quiz-choice.correct{background:#e4f3de;border-color:#5b8f4d}@media (max-width: 820px){.app-shell{grid-template-columns:1fr}.app-header{position:static;align-items:stretch;flex-wrap:wrap;padding:20px}.app-header-controls{align-items:stretch;justify-content:space-between;flex-wrap:wrap}.app-mode-group{flex:1 1 520px}.page-nav{width:220px}.lesson-selector{flex:1 1 260px;width:auto}.character-grid{grid-template-columns:repeat(5,minmax(54px,1fr))}.character-tile{font-size:2rem}.study-area{padding:20px;grid-template-rows:auto auto minmax(420px,1fr) auto}.practice-panel{height:420px;min-height:420px}.quiz-panel,.profile-stats,.profile-details div{grid-template-columns:1fr}.reading-panel.with-background:before{opacity:.12}.learning-card{grid-template-columns:220px 1fr;gap:20px}.character-display{width:min(100%,220px);font-size:7rem}.quiz-options{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (max-width: 560px){.app-header-controls,.app-mode-group{display:grid}.page-nav,.lesson-selector{width:100%}.profile-menu{justify-self:end}.learning-card{grid-template-columns:1fr}}
