:root{--color-bg:#f6f7f8;--color-surface:#fff;--color-soft:#edf2f1;--color-text:#3d4751;--color-heading:#111827;--color-muted:#6b7280;--color-border:#dce3e4;--color-border-strong:#b9c5c9;--color-primary:#176c63;--color-primary-soft:#dcefed;--color-success:#1d8a56;--color-warning:#d58a1f;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", "Microsoft YaHei", "PingFang SC", sans-serif;color:var(--color-text);background:var(--color-bg);font:16px/1.45 var(--font-sans);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{background:var(--color-bg);min-width:320px;min-height:100%}body{overscroll-behavior-y:contain;min-width:320px;min-height:100svh;margin:0}button,input,textarea,select{font:inherit}button{cursor:pointer}#root{min-height:100svh}.app-shell{background:var(--color-bg);width:min(100%,480px);min-height:100svh;color:var(--color-text);flex-direction:column;margin:0 auto;display:flex;position:relative}.app-main{flex:1;padding:16px 16px 96px}.app-header{padding:max(16px, env(safe-area-inset-top)) 16px 12px;background:color-mix(in srgb, var(--color-bg) 92%, white);border-bottom:1px solid var(--color-border);z-index:10;position:sticky;top:0}.app-header__eyebrow{color:var(--color-muted);margin:0 0 4px;font-size:13px}.app-header__title{margin:0;font-size:21px;font-weight:750;line-height:1.22}.bottom-nav{width:min(100%,480px);padding:8px 10px calc(8px + env(safe-area-inset-bottom));border-top:1px solid var(--color-border);z-index:20;background:#fffffff5;grid-template-columns:repeat(5,1fr);gap:2px;display:grid;position:fixed;bottom:0;left:50%;transform:translate(-50%);box-shadow:0 -8px 28px #1c252e14}.bottom-nav__item{appearance:none;color:var(--color-muted);touch-action:manipulation;background:0 0;border:0;border-radius:8px;place-items:center;gap:2px;min-height:56px;font-size:12px;line-height:1;display:grid}.bottom-nav__item svg{width:21px;height:21px}.bottom-nav__item[aria-current=page]{background:var(--color-primary-soft);color:var(--color-primary);font-weight:700}.surface{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 10px 28px #222b360f}.dashboard{gap:14px;display:grid}.countdown-card{color:#fff;background:linear-gradient(135deg,#22685f,#294f8a);border:0;padding:18px}.countdown-card__label{opacity:.82;margin:0;font-size:14px}.countdown-card__number{align-items:end;gap:8px;margin:8px 0 10px;display:flex}.countdown-card__number strong{font-size:54px;line-height:.95}.countdown-card__number span{padding-bottom:7px;font-size:16px}.countdown-card__date{opacity:.86;margin:0;font-size:14px}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.metric-card{padding:14px}.metric-card__label{color:var(--color-muted);margin:0 0 8px;font-size:13px}.metric-card__value{color:var(--color-heading);margin:0;font-size:26px;font-weight:780;line-height:1}.metric-card__hint{color:var(--color-muted);margin:8px 0 0;font-size:12px}.section-block{padding:16px}.section-block+.section-block{margin-top:12px}.section-title{color:var(--color-heading);margin:0 0 12px;font-size:17px}.task-list{gap:10px;display:grid}.task-row{border-bottom:1px solid var(--color-border);align-items:center;gap:10px;padding:11px 0;display:flex}.task-row:last-child{border-bottom:0}.task-row__icon{width:34px;height:34px;color:var(--color-primary);background:var(--color-primary-soft);border-radius:8px;flex:none;place-items:center;display:grid}.task-row__content{flex:1;min-width:0}.task-row__title{color:var(--color-heading);margin:0;font-weight:700}.task-row__meta{color:var(--color-muted);margin:3px 0 0;font-size:13px}.week-strip{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.week-day{text-align:center;background:var(--color-soft);border-radius:8px;min-width:0;padding:8px 4px}.week-day__name,.week-day__date{color:var(--color-muted);margin:0;font-size:11px}.week-day__mark{background:var(--color-border);border-radius:999px;width:18px;height:18px;margin:6px auto}.week-day[data-status=done] .week-day__mark{background:var(--color-success)}.week-day[data-status=partial] .week-day__mark{background:var(--color-warning)}.placeholder-page,.professional-page{gap:14px;display:grid}.professional-overview-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.professional-stat-tile{background:var(--color-soft);border-radius:8px;min-width:0;padding:11px}.professional-stat-tile span{color:var(--color-muted);margin-bottom:7px;font-size:12px;font-weight:700;display:block}.professional-stat-tile strong{color:var(--color-heading);overflow-wrap:anywhere;font-size:17px;line-height:1.25;display:block}.professional-book-grid{gap:10px;display:grid}.professional-book-card{text-align:left;width:100%;min-width:0;color:var(--color-muted);font:inherit;border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;padding:14px;display:grid}.professional-book-card[data-selected=true]{border-color:var(--color-primary);background:var(--color-primary-soft)}.professional-book-card span{overflow-wrap:anywhere;min-width:0;font-size:12px}.book-card-title{color:var(--color-heading);grid-column:span 2;font-weight:800;font-size:18px!important}.book-card-progress{background:#fff;border-radius:999px;justify-self:start;padding:5px 8px;font-weight:800;color:var(--color-primary)!important}.chapter-list{gap:8px;display:grid}.chapter-list-item{border:1px solid var(--color-border);width:100%;min-height:52px;color:var(--color-heading);font:inherit;text-align:left;background:#fff;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:9px 11px;display:flex}.chapter-list-item span{overflow-wrap:anywhere;min-width:0;font-weight:750}.chapter-list-item small{color:var(--color-muted);flex:none}.professional-subform{margin-top:14px}.plan-toggle-row{gap:10px;margin-bottom:12px;display:grid}.plan-toggle-row label,.pause-row{color:var(--color-heading);align-items:center;gap:8px;font-weight:700;display:flex}.professional-plan-list{gap:10px;margin-bottom:12px;display:grid}.professional-plan-row{border:1px solid var(--color-border);background:#fff;border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;padding:11px;display:grid}.professional-plan-row strong,.professional-plan-row p,.professional-plan-row .pause-row{grid-column:span 2}.professional-plan-row strong{color:var(--color-heading)}.professional-plan-row p{color:var(--color-muted);margin:0;font-size:13px}.professional-plan-row label:not(.pause-row){color:var(--color-muted);gap:5px;font-size:12px;font-weight:700;display:grid}.professional-plan-row input[type=number]{box-sizing:border-box;border:1px solid var(--color-border-strong);width:100%;min-width:0;min-height:40px;color:var(--color-heading);font:inherit;border-radius:8px;padding:8px 10px}.secondary-summary{cursor:pointer;color:var(--color-heading);font-weight:800}.custom-subject-list{gap:8px;margin-top:12px;display:grid}.custom-subject-row{background:var(--color-soft);border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:10px;display:flex}.custom-subject-row span{min-width:0;color:var(--color-heading);overflow-wrap:anywhere;font-weight:750}.placeholder-hero,.state-panel{padding:18px}.placeholder-hero h2,.state-panel h2{color:var(--color-heading);margin:0 0 8px;font-size:20px}.placeholder-hero p,.state-panel p{color:var(--color-muted);margin:0}.empty-list{gap:8px;margin:12px 0 0;padding:0;list-style:none;display:grid}.empty-list li{background:var(--color-soft);color:var(--color-text);border-radius:8px;padding:10px 12px}.form-grid{gap:14px;display:grid}.field{gap:7px;display:grid}.field span{color:var(--color-heading);font-size:14px;font-weight:700}.field input{box-sizing:border-box;border:1px solid var(--color-border-strong);width:100%;min-height:46px;color:var(--color-heading);font:inherit;background:#fff;border-radius:8px;padding:10px 12px}.field textarea{box-sizing:border-box;border:1px solid var(--color-border-strong);width:100%;min-height:150px;color:var(--color-heading);font:inherit;resize:vertical;background:#fff;border-radius:8px;padding:10px 12px;line-height:1.5}.field select{box-sizing:border-box;border:1px solid var(--color-border-strong);width:100%;min-height:46px;color:var(--color-heading);font:inherit;background:#fff;border-radius:8px;padding:10px 12px}.button-row{flex-wrap:wrap;gap:10px;display:flex}.primary-button{appearance:none;background:var(--color-primary);color:#fff;min-height:46px;font:inherit;border:0;border-radius:8px;justify-content:center;align-items:center;gap:7px;padding:0 16px;font-weight:750;display:inline-flex}.primary-button:disabled{cursor:not-allowed;opacity:.62}.helper-text{color:var(--color-muted);margin:10px 0 0;font-size:13px}.secondary-button,.danger-button{appearance:none;min-height:46px;font:inherit;border-radius:8px;justify-content:center;align-items:center;gap:7px;padding:0 14px;font-weight:750;display:inline-flex}.secondary-button{border:1px solid var(--color-border-strong);color:var(--color-heading);background:#fff}.danger-button{color:#b42318;background:#fff3f3;border:1px solid #e7b9b9}.primary-button svg,.secondary-button svg,.danger-button svg{width:17px;height:17px}.words-page{gap:14px;display:grid}.word-stats-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.word-stat-card{min-width:0;padding:13px}.word-stat-card:first-child{grid-column:span 2}.word-stat-card p{color:var(--color-muted);margin:0 0 8px;font-size:13px}.word-stat-card strong{color:var(--color-heading);font-size:28px;line-height:1;display:block}.section-title-row{justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.section-title-row .section-title{margin-bottom:0}.section-title-row span{color:var(--color-muted);white-space:nowrap;font-size:13px}.review-card{gap:12px;display:grid}.review-card__word{color:var(--color-heading);overflow-wrap:anywhere;margin:0;font-size:30px;font-weight:800;line-height:1.1}.review-card__meaning{color:var(--color-muted);margin:0}.review-actions{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.review-button{color:#fff;min-width:0;min-height:46px;font:inherit;border:0;border-radius:8px;padding:0 8px;font-weight:750}.review-button--again{background:#b42318}.review-button--hard{background:#b76a00}.review-button--good{background:var(--color-success)}.search-field{border:1px solid var(--color-border-strong);background:#fff;border-radius:8px;align-items:center;gap:9px;min-height:46px;padding:0 12px;display:flex}.search-field svg{width:18px;height:18px;color:var(--color-muted);flex:none}.search-field input{width:100%;min-width:0;color:var(--color-heading);background:0 0;border:0;outline:0}.segmented-control{grid-template-columns:repeat(4,minmax(0,1fr));gap:6px;margin:12px 0;display:grid}.segmented-control button{border:1px solid var(--color-border);background:var(--color-soft);min-width:0;min-height:38px;color:var(--color-muted);border-radius:8px;font-size:13px;font-weight:700}.segmented-control button[aria-pressed=true]{border-color:var(--color-primary);background:var(--color-primary-soft);color:var(--color-primary)}.word-list{gap:8px;display:grid}.word-list-item{border:1px solid var(--color-border);text-align:left;background:#fff;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;width:100%;min-height:64px;padding:10px 12px;display:flex}.word-list-item[data-selected=true]{border-color:var(--color-primary);background:var(--color-primary-soft)}.word-list-item span{gap:3px;min-width:0;display:grid}.word-list-item strong{color:var(--color-heading);overflow-wrap:anywhere;font-size:17px}.word-list-item small{color:var(--color-muted);overflow-wrap:anywhere;font-size:13px}.word-list-item em{background:var(--color-soft);color:var(--color-primary);border-radius:999px;flex:none;padding:5px 8px;font-size:12px;font-style:normal;font-weight:750}.word-meta{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.word-meta p{background:var(--color-soft);color:var(--color-muted);border-radius:8px;margin:0;padding:9px;font-size:13px}.ocr-actions,.ocr-toolbar{flex-wrap:wrap;gap:8px;display:flex}.batch-entry-actions{margin-top:12px}.batch-results{border-top:1px solid var(--color-border);gap:12px;margin-top:14px;padding-top:14px;display:grid}.batch-results h3{color:var(--color-heading);margin:0;font-size:16px}.batch-bulk-actions{flex-wrap:wrap;gap:8px;display:flex}.batch-bulk-actions .secondary-button{min-height:38px;padding:0 10px;font-size:13px}.batch-result-list{gap:10px;display:grid}.batch-result-row{border:1px solid var(--color-border);border-left:4px solid var(--color-success);background:#fff;border-radius:8px;grid-template-columns:minmax(0,1fr) 42px;gap:10px;padding:10px;display:grid}.batch-result-row[data-invalid=true]{background:#fff8f8;border-left-color:#b42318}.batch-result-row>label:not(.batch-check){grid-column:1/-1;gap:5px;min-width:0;display:grid}.batch-check{min-height:36px;color:var(--color-heading);align-items:center;gap:8px;font-weight:750;display:inline-flex}.batch-check input{width:20px;height:20px}.batch-result-row span{color:var(--color-muted);font-size:12px;font-weight:700}.batch-result-row input[type=text],.batch-result-row input:not([type]){box-sizing:border-box;border:1px solid var(--color-border-strong);width:100%;min-width:0;min-height:40px;color:var(--color-heading);background:#fff;border-radius:8px;padding:8px 10px}.batch-candidate-meta{flex-wrap:wrap;grid-column:1/-1;gap:6px;display:flex}.batch-candidate-meta span{background:var(--color-soft);color:var(--color-muted);border-radius:999px;padding:4px 7px;font-size:11px}.batch-candidate-meta .danger-text{color:#b42318;background:#fff3f3}.batch-row-actions{flex-wrap:wrap;grid-column:1/-1;gap:8px;display:flex}.batch-row-actions .secondary-button{min-height:38px}.ocr-experimental-section{padding:0;overflow:hidden}.experimental-details{padding:0}.experimental-details>summary{cursor:pointer;padding:16px;list-style:none}.experimental-details>summary::-webkit-details-marker{display:none}.experimental-summary-row{margin-bottom:0}.experimental-details[open]{padding:0 16px 16px}.experimental-details[open]>summary{margin:0 -16px 12px}.ocr-panel{gap:12px;display:grid}.ocr-actions+.ocr-panel,.ocr-actions+.empty-panel{margin-top:12px}.privacy-note{background:var(--color-soft);color:var(--color-muted);border-radius:8px;margin:0 0 12px;padding:10px 12px;font-size:13px}.ocr-crop-stage{aspect-ratio:3/4;border:1px solid var(--color-border-strong);touch-action:none;-webkit-user-select:none;user-select:none;background:#0f172a;border-radius:8px;place-items:center;width:100%;max-height:70svh;display:grid;position:relative;overflow:hidden}.ocr-crop-stage img{object-fit:contain;pointer-events:none;width:100%;height:100%}.ocr-crop-box{color:#fff;text-shadow:0 1px 2px #000c;touch-action:none;background:#f7c94824;border:2px solid #f7c948;border-radius:8px;place-items:center;font-size:12px;font-weight:750;display:grid;position:absolute;box-shadow:0 0 0 999px #0f172a6b}.ocr-crop-handle{background:#f7c948;border:2px solid #fff;border-radius:999px;width:28px;height:28px;position:absolute;bottom:-8px;right:-8px}.ocr-separator{touch-action:none;background:#38bdf8;width:3px;position:absolute;top:0;bottom:0}.ocr-separator span{color:#fff;background:#0e7490e6;border-radius:6px;min-width:72px;padding:4px 6px;font-size:11px;position:absolute;top:10px;left:8px}.ocr-variant-tabs{grid-template-columns:repeat(2,minmax(0,1fr));margin:0}.ocr-preview{aspect-ratio:4/3;border:1px dashed var(--color-border-strong);background:var(--color-soft);border-radius:8px;place-items:center;width:100%;display:grid;overflow:hidden}.ocr-preview img{object-fit:contain;max-width:100%;max-height:100%;transition:transform .2s}.ocr-progress{gap:6px;display:grid}.ocr-progress>div{background:var(--color-soft);border-radius:999px;height:8px;overflow:hidden}.ocr-progress span{border-radius:inherit;background:var(--color-primary);height:100%;transition:width .2s;display:block}.ocr-progress[data-status=failed] span,.ocr-progress[data-status=cancelled] span{background:#b42318}.ocr-progress p{color:var(--color-muted);margin:0;font-size:13px}.ocr-results{border-top:1px solid var(--color-border);gap:12px;margin-top:14px;padding-top:14px;display:grid}.ocr-results h3{color:var(--color-heading);margin:0;font-size:16px}.ocr-debug{background:var(--color-soft);border-radius:8px;margin-top:12px;padding:10px 12px}.ocr-debug summary{color:var(--color-heading);font-weight:750}.ocr-debug pre{white-space:pre-wrap;max-height:160px;color:var(--color-text);margin:10px 0;font:12px/1.5 ui-monospace,Consolas,monospace;overflow:auto}.ocr-debug p{color:var(--color-muted);margin:4px 0;font-size:12px}.ocr-bulk-actions{flex-wrap:wrap;gap:8px;display:flex}.ocr-bulk-actions .secondary-button{min-height:38px;padding:0 10px;font-size:13px}.ocr-result-list{gap:10px;display:grid}.ocr-result-row{border:1px solid var(--color-border);background:#fff;border-radius:8px;grid-template-columns:minmax(0,1fr) minmax(0,1fr) 42px;align-items:end;gap:8px;padding:10px;display:grid}.ocr-result-row label{gap:5px;min-width:0;display:grid}.ocr-result-row span{color:var(--color-muted);font-size:12px;font-weight:700}.ocr-result-row input{border:1px solid var(--color-border-strong);width:100%;min-width:0;min-height:38px;color:var(--color-heading);background:#fff;border-radius:8px;padding:7px 9px}.icon-button{border-radius:8px;place-items:center;width:42px;height:38px;display:grid}.danger-icon-button{color:#b42318;background:#fff3f3;border:1px solid #e7b9b9}.icon-button svg{width:18px;height:18px}.ocr-result-row-v2{border:1px solid var(--color-border);background:#fff;border-left-width:4px;border-radius:8px;grid-template-columns:minmax(0,1fr) 42px;gap:10px;padding:10px;display:grid}.ocr-result-row-v2[data-status=high]{border-left-color:var(--color-success)}.ocr-result-row-v2[data-status=medium]{border-left-color:var(--color-warning)}.ocr-result-row-v2[data-status=low]{background:#fff8f8;border-left-color:#b42318}.ocr-result-row-v2>label:not(.ocr-check){grid-column:1/-1;gap:5px;min-width:0;display:grid}.ocr-check{min-height:36px;color:var(--color-heading);align-items:center;gap:8px;font-weight:750;display:inline-flex}.ocr-check input{width:20px;height:20px}.ocr-result-row-v2 span{color:var(--color-muted);font-size:12px;font-weight:700}.ocr-result-row-v2 input[type=text],.ocr-result-row-v2 input:not([type]){border:1px solid var(--color-border-strong);width:100%;min-width:0;min-height:40px;color:var(--color-heading);background:#fff;border-radius:8px;padding:8px 10px}.ocr-candidate-meta{flex-wrap:wrap;grid-column:1/-1;gap:6px;display:flex}.ocr-candidate-meta span{background:var(--color-soft);color:var(--color-muted);border-radius:999px;padding:4px 7px;font-size:11px}.ocr-candidate-meta .danger-text{color:#b42318;background:#fff3f3}.sticky-import-row{bottom:calc(76px + env(safe-area-inset-bottom));background:linear-gradient(#fff0, var(--color-surface) 30%);z-index:3;padding:8px 0 0;position:sticky}.empty-panel{text-align:center;color:var(--color-muted);place-items:center;gap:8px;padding:18px 10px;display:grid}.empty-panel svg{width:28px;height:28px;color:var(--color-primary)}.empty-panel p{color:var(--color-heading);margin:0;font-weight:750}.empty-panel span{font-size:13px}.inline-message{border-radius:8px;margin:0;padding:11px 12px;font-size:14px}.inline-message--success{color:#17683f;background:#e7f5ed}.inline-message--error{color:#b42318;background:#fff3f3}@media (width>=481px){body{background:#e9edf1}}
