@import "https://fonts.googleapis.com/css2?family=Noto+Serif+SC:wght@400;600;700&family=Fraunces:opsz,wght@9..144,400;9..144,500;9..144,600;9..144,700&family=JetBrains+Mono:wght@400;500&family=Inter:wght@400;500;600;700&display=swap";:root[data-theme=light]{--bg:#f5f1ea;--bg-elev:#fff;--bg-elev-2:#faf6ef;--ink:#1a1814;--ink-soft:#5b5448;--ink-faint:#8a8170;--line:#e3dccf;--line-strong:#c8bfae;--radical:#2563eb;--radical-soft:#dbe7ff;--hanzi-1:#2563eb;--hanzi-2:#16a34a;--hanzi-3:#d97706;--hanzi-4:#dc2626;--hanzi-5:#6b7280;--vocab:#7c3aed;--vocab-soft:#ede4ff;--apprentice:#ec4899;--guru:#a855f7;--master:#3b82f6;--enlightened:#06b6d4;--burned:#44403c;--sandhi:#0891b2;--warn:#ea580c;--shadow-card:0 1px 0 #0000000a, 0 8px 24px -12px #14100a2e;--shadow-elev:0 1px 0 #0000000a, 0 24px 48px -20px #14100a47}:root[data-theme=dark]{--bg:#14110d;--bg-elev:#1c1813;--bg-elev-2:#221d17;--ink:#f0ebe0;--ink-soft:#b3aa98;--ink-faint:#7a7263;--line:#2d2820;--line-strong:#3d362b;--radical:#60a5fa;--radical-soft:#1e3a5f;--hanzi-1:#60a5fa;--hanzi-2:#4ade80;--hanzi-3:#fbbf24;--hanzi-4:#f87171;--hanzi-5:#9ca3af;--vocab:#a78bfa;--vocab-soft:#2e1f4d;--apprentice:#f472b6;--guru:#c084fc;--master:#60a5fa;--enlightened:#22d3ee;--burned:#78716c;--sandhi:#22d3ee;--warn:#fb923c;--shadow-card:0 1px 0 #ffffff0a, 0 8px 24px -12px #0009;--shadow-elev:0 1px 0 #ffffff0a, 0 24px 48px -20px #000c}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);color:var(--ink);min-height:100vh;font-family:Inter,-apple-system,sans-serif;font-size:15px;line-height:1.55;transition:background .3s,color .3s}.zh{font-family:Noto Serif SC,serif}.display{letter-spacing:-.02em;font-family:Fraunces,serif}.mono{font-family:JetBrains Mono,monospace}.panel{background:var(--bg-elev);border:1px solid var(--line);box-shadow:var(--shadow-card);border-radius:14px;padding:24px}.panel h3{justify-content:space-between;align-items:baseline;margin-bottom:16px;font-family:Fraunces,serif;font-size:16px;font-weight:600;display:flex}.panel h3 .h-meta{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:400}.btn-primary{background:var(--ink);color:var(--bg);cursor:pointer;border:none;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:14px 20px;font-family:Inter,sans-serif;font-size:14px;font-weight:600;transition:all .15s;display:flex}.btn-primary:hover{transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{background:var(--bg-elev);color:var(--ink);border:1px solid var(--line);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:14px 20px;font-family:Inter,sans-serif;font-size:14px;font-weight:600;transition:all .15s;display:flex}.btn-ghost:hover{background:var(--bg-elev-2)}.btn-audio{background:var(--bg-elev-2);color:var(--ink);border:1px solid var(--line);cursor:pointer;border-radius:999px;flex:none;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;transition:all .15s;display:flex}.screen{max-width:1200px;margin:0 auto;padding:32px 24px 80px}.footer-note{text-align:center;color:var(--ink-faint);text-transform:uppercase;letter-spacing:.1em;margin-top:48px;font-family:JetBrains Mono,monospace;font-size:11px}.mock-bar{z-index:100;background:var(--bg-elev);border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);flex-wrap:wrap;align-items:center;gap:16px;padding:12px 24px;display:flex;position:sticky;top:0}.mock-bar .logo{letter-spacing:-.02em;color:var(--ink);align-items:baseline;gap:8px;font-family:Fraunces,serif;font-size:22px;font-weight:700;text-decoration:none;display:flex}.mock-bar .logo .zh-mark{color:var(--hanzi-3);font-family:Noto Serif SC,serif;font-size:22px;font-weight:700}.mock-bar nav{flex-wrap:wrap;gap:4px;margin-left:24px;display:flex}.mock-bar nav a{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:8px 14px;font-family:inherit;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s}.mock-bar nav a:hover{background:var(--bg-elev-2);color:var(--ink)}.mock-bar nav a.active{background:var(--ink);color:var(--bg)}.mock-bar .spacer{flex:1}.mock-bar .theme-toggle{background:var(--bg-elev-2);border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;display:flex}.mock-bar .meta{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;font-family:JetBrains Mono,monospace;font-size:11px}.forecast{align-items:flex-end;gap:3px;height:140px;margin-bottom:8px;display:flex}.forecast .bar{background:var(--line);border-radius:3px 3px 0 0;flex:1;min-height:2px;transition:background .2s;position:relative}.forecast .bar.has-reviews{background:var(--hanzi-3)}.forecast .bar.now{background:var(--vocab)}.forecast .bar:hover:after{content:attr(data-tooltip);background:var(--ink);color:var(--bg);white-space:nowrap;z-index:10;border-radius:4px;margin-bottom:4px;padding:4px 8px;font-family:JetBrains Mono,monospace;font-size:10px;position:absolute;bottom:100%;left:50%;transform:translate(-50%)}.forecast-axis{color:var(--ink-faint);justify-content:space-between;margin-top:8px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex}.stages{flex-direction:column;gap:10px;display:flex}.stage{grid-template-columns:100px 1fr 50px;align-items:center;gap:12px;font-size:13px;display:grid}.stage .name{text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);font-family:JetBrains Mono,monospace;font-size:11px}.stage .bar-track{background:var(--line);border-radius:4px;height:8px;overflow:hidden}.stage .bar-fill{border-radius:4px;height:100%;transition:width .4s}.stage .num{text-align:right;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:500}.stage.app .bar-fill{background:var(--apprentice)}.stage.gur .bar-fill{background:var(--guru)}.stage.mas .bar-fill{background:var(--master)}.stage.enl .bar-fill{background:var(--enlightened)}.stage.bur .bar-fill{background:var(--burned)}.level-strip{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.level-card{background:var(--bg-elev);border:1px solid var(--line);border-radius:12px;align-items:center;gap:16px;padding:20px;display:flex}.level-card .lvl-num{letter-spacing:-.03em;font-family:Fraunces,serif;font-size:42px;font-weight:600;line-height:1}.level-card.wk .lvl-num{color:var(--hanzi-3)}.level-card.hsk .lvl-num{color:var(--vocab)}.level-card .lvl-label{text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);margin-bottom:2px;font-family:JetBrains Mono,monospace;font-size:10px}.level-card .lvl-detail{color:var(--ink-soft);font-size:13px}.level-card .lvl-progress{background:var(--line);border-radius:3px;width:80px;height:6px;margin-left:auto;overflow:hidden}.level-card .lvl-progress-fill{background:var(--ink);border-radius:3px;height:100%}.dash-hero{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px;display:grid}.action-card{background:var(--bg-elev);border:1px solid var(--line);cursor:pointer;box-shadow:var(--shadow-card);border-radius:16px;align-items:center;gap:24px;padding:28px;transition:transform .2s,box-shadow .2s;display:flex}.action-card:hover{box-shadow:var(--shadow-elev);transform:translateY(-2px)}.action-card .count{letter-spacing:-.04em;font-family:Fraunces,serif;font-size:64px;font-weight:600;line-height:1}.action-card.lessons{border-left:4px solid var(--vocab)}.action-card.lessons .count{color:var(--vocab)}.action-card.reviews{border-left:4px solid var(--hanzi-3)}.action-card.reviews .count{color:var(--hanzi-3)}.action-card .label{margin-bottom:4px;font-family:Fraunces,serif;font-size:22px;font-weight:600}.action-card .sub{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;font-family:JetBrains Mono,monospace;font-size:12px}.action-card .arrow{color:var(--ink-faint);margin-left:auto;font-size:24px;transition:transform .2s}.action-card:hover .arrow{color:var(--ink);transform:translate(4px)}.review-breakdown{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.review-breakdown .chip{text-transform:uppercase;letter-spacing:.06em;background:var(--bg-elev-2);color:var(--ink-soft);border-radius:999px;padding:3px 8px;font-family:JetBrains Mono,monospace;font-size:10px}.review-breakdown .chip strong{color:var(--ink);font-weight:600}.dash-grid{grid-template-columns:2fr 1fr;gap:24px;display:grid}.recent-grid{flex-wrap:wrap;gap:6px;display:flex}.recent-tile{cursor:pointer;color:#fff;border-radius:8px;justify-content:center;align-items:center;width:48px;height:48px;font-family:Noto Serif SC,serif;font-size:22px;font-weight:600;transition:transform .15s;display:flex}.recent-tile:hover{transform:scale(1.1)}.recent-tile.t1{background:var(--hanzi-1)}.recent-tile.t2{background:var(--hanzi-2)}.recent-tile.t3{background:var(--hanzi-3)}.recent-tile.t4{background:var(--hanzi-4)}.recent-tile.tr{background:var(--radical)}.recent-tile.tv{background:var(--vocab)}.stat-list{flex-direction:column;gap:12px;display:flex}.stat-row{border-bottom:1px solid var(--line);justify-content:space-between;padding:10px 0;font-size:13px;display:flex}.stat-row:last-child{border-bottom:none}.stat-row .k{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.06em;font-family:JetBrains Mono,monospace;font-size:11px}.stat-row .v{color:var(--ink);font-weight:500}.stat-row .v.success{color:var(--hanzi-2)}.audio-gate{background:var(--bg-elev-2);border:1px solid var(--line);width:fit-content;color:var(--ink-soft);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;gap:12px;margin:16px auto 24px;padding:10px 20px;font-size:13px;transition:all .15s;display:flex}.audio-gate.played{background:color-mix(in srgb, var(--hanzi-2) 12%, var(--bg-elev));border-color:color-mix(in srgb, var(--hanzi-2) 40%, var(--line));color:var(--ink)}.audio-gate .gate-icon{background:var(--ink);width:28px;height:28px;color:var(--bg);border-radius:999px;justify-content:center;align-items:center;font-size:12px;display:flex}.audio-gate.played .gate-icon{background:var(--hanzi-2)}.modal-backdrop{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;padding:20px;display:none;position:fixed;inset:0}.modal-backdrop.open{display:flex}.modal{background:var(--bg-elev);width:100%;max-width:600px;box-shadow:var(--shadow-elev);border-radius:16px;padding:28px}.modal h3{margin-bottom:4px;font-family:Fraunces,serif;font-size:20px;font-weight:600}.modal .modal-sub{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;font-family:JetBrains Mono,monospace;font-size:11px}.modal textarea{background:var(--bg-elev-2);border:1px solid var(--line);width:100%;color:var(--ink);resize:vertical;border-radius:10px;min-height:120px;padding:14px;font-family:Inter,sans-serif;font-size:14px;line-height:1.6}.modal textarea:focus{border-color:var(--hanzi-3);outline:none}.modal-actions{justify-content:flex-end;gap:10px;margin-top:16px;display:flex}.modal-actions button{cursor:pointer;border:none;border-radius:8px;padding:10px 18px;font-family:Inter,sans-serif;font-size:13px;font-weight:600}.modal-actions .btn-cancel{background:var(--bg-elev-2);color:var(--ink);border:1px solid var(--line)}.modal-actions .btn-save{background:var(--ink);color:var(--bg)}.modal-meta{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;margin-top:8px;font-family:JetBrains Mono,monospace;font-size:10px}.cs-item{background:var(--bg-elev-2);border-left:3px solid var(--hanzi-3);border-radius:10px;padding:16px 18px}.cs-item .cs-zh{margin-bottom:6px;font-family:Noto Serif SC,serif;font-size:22px;line-height:1.4}.cs-item .cs-py{color:var(--ink-soft);margin-bottom:4px;font-family:JetBrains Mono,monospace;font-size:13px}.cs-item .cs-en{color:var(--ink-soft);font-size:14px;font-style:italic}.cs-item .cs-label{text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);justify-content:space-between;align-items:center;margin-bottom:6px;font-family:JetBrains Mono,monospace;font-size:10px;display:flex}.cs-item .play-mini{border:1px solid var(--line);color:var(--ink-faint);cursor:pointer;background:0 0;border-radius:999px;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;display:flex}.cs-item.long{border-left-color:var(--vocab)}.cs-item .cs-zh.long-text{font-size:19px;line-height:1.7}.cs-item.expandable .cs-zh.long-text{max-height:90px;transition:max-height .3s;position:relative;overflow:hidden}.cs-item.expandable.expanded .cs-zh.long-text{max-height:2000px}.cs-item.expandable:not(.expanded) .cs-zh.long-text:after{content:"";background:linear-gradient(transparent, var(--bg-elev-2));height:40px;position:absolute;bottom:0;left:0;right:0}.cs-item .expand-toggle{border:1px solid var(--line-strong);color:var(--vocab);cursor:pointer;text-transform:uppercase;letter-spacing:.06em;background:0 0;border-radius:8px;margin-top:10px;padding:6px 14px;font-family:JetBrains Mono,monospace;font-size:11px}.sandhi-display{background:color-mix(in srgb, var(--sandhi) 8%, var(--bg-elev-2));border-left:3px solid var(--sandhi);border-radius:8px;margin-top:8px;padding:12px 14px;font-size:13px;line-height:1.6}.sandhi-display .label{text-transform:uppercase;letter-spacing:.08em;color:var(--sandhi);margin-bottom:4px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:600}.sandhi-display .alt-pinyin{color:var(--sandhi);font-family:JetBrains Mono,monospace;font-weight:500}.lesson-shell{max-width:760px;margin:0 auto}.lesson-progress-strip{gap:4px;margin-bottom:32px;display:flex}.lesson-progress-strip .seg{background:var(--line);border-radius:2px;flex:1;height:4px}.lesson-progress-strip .seg.done{background:var(--vocab)}.lesson-progress-strip .seg.current{background:var(--hanzi-3)}.lesson-card-glyph{text-align:center;margin:32px 0 24px}.lesson-card-glyph .lc-type{color:var(--vocab);text-transform:uppercase;letter-spacing:.12em;margin-bottom:12px;font-family:JetBrains Mono,monospace;font-size:11px}.lesson-card-glyph .lc-glyph{margin-bottom:12px;font-family:Noto Serif SC,serif;font-size:128px;font-weight:600;line-height:1}.lesson-card-glyph .lc-pinyin{color:var(--ink);font-family:JetBrains Mono,monospace;font-size:24px;font-weight:500}.lesson-card-glyph .lc-meaning{color:var(--ink);margin-top:8px;font-family:Fraunces,serif;font-size:26px}.lesson-stepper{border-bottom:1px solid var(--line);gap:8px;margin-bottom:24px;display:flex}.lesson-step{cursor:pointer;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-faint);border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:12px 18px;font-family:JetBrains Mono,monospace;font-size:11px;transition:all .15s;display:flex}.lesson-step:hover{color:var(--ink-soft)}.lesson-step.active{color:var(--ink);border-bottom-color:var(--hanzi-3)}.lesson-step .step-check{background:var(--line);color:#fff;border-radius:999px;justify-content:center;align-items:center;width:12px;height:12px;font-size:9px;display:inline-flex}.lesson-step.done .step-check{background:var(--hanzi-2)}.lesson-section{background:var(--bg-elev);border:1px solid var(--line);box-shadow:var(--shadow-card);border-radius:14px;margin-bottom:16px;padding:24px}.lesson-section h4{text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);align-items:center;gap:8px;margin-bottom:14px;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.lesson-section h4 .label-num{background:var(--ink);color:var(--bg);border-radius:999px;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;font-weight:700;display:flex}.lesson-section h4 .edit-btn{border:1px solid var(--line);color:var(--ink-faint);cursor:pointer;text-transform:uppercase;letter-spacing:.06em;background:0 0;border-radius:6px;margin-left:auto;padding:4px 10px;font-family:inherit;font-size:10px;transition:all .15s}.lesson-section h4 .edit-btn:hover{color:var(--ink);border-color:var(--ink-soft)}.lesson-section .body{font-size:15px;line-height:1.7}.components{flex-wrap:wrap;gap:12px;display:flex}.component-chip{background:var(--bg-elev-2);border:1px solid var(--line);cursor:pointer;border-radius:12px;align-items:center;gap:12px;padding:12px 16px;transition:border-color .15s;display:flex}.component-chip:hover{border-color:var(--radical)}.component-chip .ch{color:var(--radical);font-family:Noto Serif SC,serif;font-size:28px;font-weight:600;line-height:1}.lesson-nav{border-top:1px solid var(--line);justify-content:space-between;margin-top:32px;padding-top:24px;display:flex}.lesson-nav .gate-warning{text-align:center;color:var(--warn);text-transform:uppercase;letter-spacing:.08em;flex:1;align-self:center;font-family:JetBrains Mono,monospace;font-size:11px}.card-stage{text-align:center;box-shadow:var(--shadow-elev);color:#fff;border-radius:20px;margin-bottom:24px;padding:56px 40px 40px;position:relative;overflow:hidden}.card-stage.tone-1{background:var(--hanzi-1)}.card-stage.tone-2{background:var(--hanzi-2)}.card-stage.tone-3{background:var(--hanzi-3)}.card-stage.tone-4{background:var(--hanzi-4)}.card-stage.tone-5{background:var(--hanzi-5)}.card-stage.radical{background:var(--radical)}.card-stage.vocab{background:var(--vocab)}.card-stage .type-pill{color:#fff;text-transform:uppercase;letter-spacing:.12em;background:#ffffff38;border-radius:999px;margin-bottom:24px;padding:5px 14px;font-family:JetBrains Mono,monospace;font-size:11px;font-weight:600;display:inline-block}.card-stage .type-pill.reading-prompt{background:#ffffff4d}.card-stage .type-pill.meaning-prompt{background:#0000002e}.card-stage .glyph{margin-bottom:16px;font-family:Noto Serif SC,serif;font-size:144px;font-weight:600;line-height:1}.card-stage .prompt{color:#ffffffd9;text-transform:uppercase;letter-spacing:.12em;font-family:JetBrains Mono,monospace;font-size:12px}.answer-input{background:var(--bg-elev);border:2px solid var(--line);width:100%;color:var(--ink);text-align:center;border-radius:12px;margin-bottom:12px;padding:18px 20px;font-family:Inter,sans-serif;font-size:22px;transition:border-color .15s}.answer-input:focus{border-color:var(--hanzi-3);outline:none}.answer-input.correct{border-color:var(--hanzi-2);background:color-mix(in srgb, var(--hanzi-2) 10%, var(--bg-elev))}.answer-input.wrong{border-color:var(--hanzi-4);background:color-mix(in srgb, var(--hanzi-4) 10%, var(--bg-elev))}.input-hint{color:var(--ink-faint);text-align:center;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;font-family:JetBrains Mono,monospace;font-size:11px}.review-shell{max-width:760px;margin:0 auto}.review-header{justify-content:space-between;align-items:center;margin-bottom:24px;padding:0 8px;display:flex}.review-header .progress{color:var(--ink-soft);font-family:JetBrains Mono,monospace;font-size:13px}.review-header .progress strong{color:var(--ink);font-weight:600}.review-header .session-stats{gap:16px;font-family:JetBrains Mono,monospace;font-size:12px;display:flex}.review-header .stat-correct{color:var(--hanzi-2)}.review-header .stat-wrong{color:var(--hanzi-4)}.progress-bar{background:var(--line);border-radius:2px;height:4px;margin-bottom:32px;overflow:hidden}.progress-bar .fill{background:var(--ink);border-radius:2px;height:100%;transition:width .4s}.result-banner{background:var(--bg-elev);border:1px solid var(--line);border-left-width:4px;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:14px 18px;display:flex}.result-banner.correct{border-left-color:var(--hanzi-2)}.result-banner.wrong{border-left-color:var(--hanzi-4)}.result-banner .res-text{color:var(--ink);font-size:14px}.result-banner .res-text strong{font-weight:600}.result-banner.correct .res-text strong{color:var(--hanzi-2)}.result-banner.wrong .res-text strong{color:var(--hanzi-4)}.undo-btn{border:1px solid var(--line);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-family:JetBrains Mono,monospace;font-size:11px;transition:all .15s;display:inline-flex}.undo-btn:hover{border-color:var(--warn);color:var(--warn)}.multi-reading-note{background:color-mix(in srgb, var(--sandhi) 12%, var(--bg-elev));border:1px solid color-mix(in srgb, var(--sandhi) 30%, var(--line));color:var(--ink-soft);border-radius:10px;align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:13px;display:flex}.multi-reading-note .icon{background:var(--sandhi);color:#fff;border-radius:999px;flex:none;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;display:flex}.reveal{background:var(--bg-elev);border:1px solid var(--line);box-shadow:var(--shadow-card);border-radius:14px;margin-bottom:16px;padding:24px 28px}.reveal h4{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.1em;align-items:center;gap:10px;margin-bottom:12px;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.reveal h4:before{content:"";background:var(--hanzi-3);border-radius:999px;width:4px;height:4px}.reveal-body{color:var(--ink);font-size:16px;line-height:1.7}.review-actions{gap:12px;margin-top:24px;display:flex}.review-actions button{flex:1}.review-actions .btn-audio{flex:none}.item-shell{max-width:880px;margin:0 auto}.item-back{color:var(--ink-soft);cursor:pointer;align-items:center;gap:6px;margin-bottom:24px;font-family:JetBrains Mono,monospace;font-size:13px;text-decoration:none;display:inline-flex}.item-back:hover{color:var(--ink)}.item-banner{color:#fff;box-shadow:var(--shadow-elev);border-radius:20px;grid-template-columns:auto 1fr auto;align-items:center;gap:40px;margin-bottom:24px;padding:48px 40px;display:grid}.item-banner .glyph{font-family:Noto Serif SC,serif;font-size:160px;font-weight:600;line-height:1}.item-banner .meta-block .type-pill{text-transform:uppercase;letter-spacing:.12em;background:#ffffff38;border-radius:999px;margin-bottom:12px;padding:4px 12px;font-family:JetBrains Mono,monospace;font-size:10px;display:inline-block}.item-banner .primary-name{letter-spacing:-.02em;margin-bottom:6px;font-family:Fraunces,serif;font-size:48px;font-weight:600;line-height:1.05}.item-banner .pinyin-readout{opacity:.95;margin-bottom:8px;font-family:JetBrains Mono,monospace;font-size:22px}.item-banner .alt-readings{background:#0000002e;border-radius:999px;align-items:center;gap:8px;margin-bottom:16px;padding:4px 12px;font-family:JetBrains Mono,monospace;font-size:12px;display:inline-flex}.item-banner .alt-readings strong{font-weight:600}.item-banner .meta-row{text-transform:uppercase;letter-spacing:.08em;opacity:.9;flex-wrap:wrap;gap:16px;font-family:JetBrains Mono,monospace;font-size:12px;display:flex}.item-banner .meta-row span{align-items:center;gap:6px;display:flex}.item-banner .meta-row span:before{content:"";background:#ffffffb3;border-radius:999px;width:4px;height:4px}.audio-btn-banner{color:#fff;cursor:pointer;background:#fff3;border:1px solid #ffffff4d;border-radius:999px;justify-content:center;align-items:center;width:64px;height:64px;font-size:28px;display:flex}.srs-pill{background:var(--bg-elev);border:1px solid var(--line);text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);border-radius:999px;align-items:center;gap:8px;margin-right:8px;padding:8px 16px;font-family:JetBrains Mono,monospace;font-size:12px;display:inline-flex}.srs-pill .dot{border-radius:999px;width:8px;height:8px}.srs-pill.reading .dot{background:var(--hanzi-3)}.srs-pill.meaning .dot{background:var(--vocab)}.srs-pill strong{color:var(--ink)}.item-grid{grid-template-columns:2fr 1fr;gap:16px;margin-bottom:16px;display:grid}.item-section{background:var(--bg-elev);border:1px solid var(--line);box-shadow:var(--shadow-card);border-radius:14px;margin-bottom:16px;padding:24px}.item-section h3{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:14px;font-family:Fraunces,serif;font-size:16px;font-weight:600;display:flex}.item-section h3 .h-sub{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.08em;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:400}.item-section h3 .edit-btn{border:1px solid var(--line);color:var(--ink-faint);cursor:pointer;text-transform:uppercase;letter-spacing:.06em;background:0 0;border-radius:6px;padding:4px 10px;font-family:JetBrains Mono,monospace;font-size:10px;transition:all .15s}.item-section h3 .edit-btn:hover{color:var(--ink);border-color:var(--ink-soft)}.item-section .body{color:var(--ink);font-size:15px;line-height:1.7}.login-shell{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--bg-elev);border:1px solid var(--line);width:100%;max-width:400px;box-shadow:var(--shadow-elev);border-radius:20px;padding:48px 40px}.login-logo{text-align:center;margin-bottom:32px}.login-logo .zh-mark{color:var(--hanzi-3);margin-right:8px;font-family:Noto Serif SC,serif;font-size:36px;font-weight:700}.login-logo .display{color:var(--ink);font-family:Fraunces,serif;font-size:36px;font-weight:700}.login-stage-label{color:var(--ink-faint);text-transform:uppercase;letter-spacing:.1em;text-align:center;margin-bottom:24px;font-family:JetBrains Mono,monospace;font-size:10px}.login-hint{color:var(--ink-soft);text-align:center;margin-bottom:16px;font-size:13px}.login-card input{background:var(--bg-elev-2);border:1px solid var(--line);width:100%;color:var(--ink);border-radius:10px;margin-bottom:12px;padding:14px 16px;font-family:Inter,sans-serif;font-size:15px;transition:border-color .15s}.login-card input:focus{border-color:var(--hanzi-3);outline:none}.login-card input.totp-input{text-align:center;letter-spacing:.3em;padding:18px;font-size:28px}.login-card .btn-primary{width:100%;margin-top:8px}.login-error{color:var(--hanzi-4);text-align:center;margin-bottom:8px;font-family:JetBrains Mono,monospace;font-size:13px}.login-back{width:100%;margin-top:8px;font-size:13px}
