.image-annotation{position:relative;width:100%;border-radius:8px;overflow:hidden;background-color:#f5f5f5}.image-annotation--empty,.image-annotation--error{min-height:200px;display:flex;align-items:center;justify-content:center}.image-annotation__placeholder,.image-annotation__error{display:flex;align-items:center;justify-content:center;width:100%;height:100%;min-height:200px}.image-annotation__placeholder-text{color:#999;font-size:1rem}.image-annotation__error-text{color:#f44336;font-size:1rem}.image-annotation__image{display:block;width:100%;height:auto}.image-annotation__overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.image-annotation__item-clickable{cursor:pointer;pointer-events:all}.image-annotation__loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background-color:#fffc}.image-annotation__loading-text{color:#666;font-size:1rem}.mockup-root{min-height:100vh;padding:28px;background:radial-gradient(circle at top left,rgba(79,174,138,.18),transparent 32%),radial-gradient(circle at 80% 10%,rgba(91,155,231,.16),transparent 28%),#faf8f3;color:#3f352b;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif}.mockup-root,.mockup-root *{box-sizing:border-box}.mockup-header{max-width:1180px;width:100%;margin:0 auto 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px}.mockup-header span{color:#4fae8a;font-size:13px;font-weight:800;letter-spacing:.02em}.mockup-header h1{margin:6px 0;font-size:32px;line-height:40px;letter-spacing:0}.mockup-header p{margin:0;color:#70675c}.mock-exit{min-height:40px;padding:0 16px;border-radius:999px;background:#fff;color:#4fae8a;display:inline-flex;align-items:center;text-decoration:none;font-weight:700;box-shadow:0 4px 16px #3f352b14}.mockup-layout{max-width:1180px;width:100%;margin:0 auto;display:grid;grid-template-columns:160px 390px 1fr;gap:24px;align-items:start}.mock-page-tabs,.mock-spec-panel{position:sticky;top:24px;background:#ffffffc7;border:1px solid #e8e1d7;border-radius:20px;box-shadow:0 10px 28px #3f352b1a;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.mock-page-tabs{padding:12px;display:grid;gap:8px}.mock-page-tabs button,.mock-bottom-nav button{border:0;background:transparent;color:#70675c;border-radius:12px;font-weight:700;cursor:pointer}.mock-page-tabs button{min-height:42px;text-align:left;padding:0 12px}.mock-page-tabs button.active,.mock-bottom-nav button.active{background:#eef8f3;color:#4fae8a}.mock-phone{width:390px;min-height:844px;border-radius:42px;padding:12px;background:#24201c;box-shadow:0 24px 60px #3f352b3d}.mock-statusbar{height:34px;padding:0 22px;border-radius:30px 30px 0 0;background:#faf8f3;display:flex;align-items:center;justify-content:space-between;color:#3f352b;font-size:12px;font-weight:800}.mock-screen{min-height:738px;max-height:738px;overflow:auto;padding:14px;background:#faf8f3;scrollbar-width:none}.mock-screen::-webkit-scrollbar{display:none}.mock-bottom-nav{height:60px;padding:8px;border-radius:0 0 30px 30px;background:#fff;display:grid;grid-template-columns:repeat(4,1fr);gap:4px}.mock-topbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.mock-topbar h1{margin:2px 0 0;font-size:24px;line-height:32px}.mock-date{color:#9b9287;font-size:12px;font-weight:700}.mock-topbar button{min-height:34px;padding:0 12px;border:0;border-radius:999px;background:#eef8f3;color:#4fae8a;font-weight:800}.mock-hero,.mock-card,.mock-balance-card,.mock-passbook-total,.mock-allowance-today,.mock-note-card,.mock-accordion{background:#fff;border:1px solid #e8e1d7;border-radius:16px;padding:16px;box-shadow:0 4px 16px #3f352b14}.mock-hero{margin-bottom:12px;background:radial-gradient(circle at 90% 10%,rgba(91,155,231,.18),transparent 36%),#fff}.mock-hero span,.mock-balance-card span,.mock-passbook-total span,.mock-allowance-today span{color:#4fae8a;font-size:13px;font-weight:800}.mock-hero h2{margin:4px 0;font-size:22px;line-height:30px}.mock-hero p,.mock-card p,.mock-passbook-total p,.mock-allowance-today p{margin:0;color:#70675c;font-size:14px;line-height:21px}.mock-balance-card{margin-bottom:12px;display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center;background:linear-gradient(135deg,#eef8f3,#fff)}.mock-balance-card strong,.mock-passbook-total strong,.mock-allowance-today strong{display:block;color:#f2a23a;font-size:30px;line-height:36px}.mock-balance-card small{color:#70675c;font-size:12px}.mock-progress{height:8px;margin-top:8px;border-radius:999px;background:#eee9e1;overflow:hidden}.mock-progress-fill{display:block;height:100%;border-radius:inherit}.mock-fill-green{background:#4fae8a}.mock-fill-blue{background:#5b9be7}.mock-fill-orange{background:#f2a23a}.mock-action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px}.mock-action{min-height:92px;padding:12px;border-radius:16px;background:#fff;border:1px solid #e8e1d7;display:flex;flex-direction:column;justify-content:space-between;text-decoration:none;color:#3f352b}.mock-action-orange{background:#fff4df;border-color:#f2a23a42}.mock-action-green{background:#eef8f3;border-color:#4fae8a3d}.mock-action-blue{background:#edf5ff;border-color:#5b9be73d}.mock-action strong{font-size:15px;line-height:20px}.mock-action small,.mock-card small,.mock-wish small,.mock-module-row small,.mock-accordion small{color:#9b9287;font-size:12px}.mock-icon{width:30px;height:30px;border-radius:999px;display:inline-grid;place-items:center;background:#eef8f3;color:#4fae8a;font-size:12px;font-weight:900}.mock-icon-blue{background:#edf5ff;color:#5b9be7}.mock-icon-orange{background:#fff4df;color:#f2a23a}.mock-icon-red{background:#fff0ee;color:#e15b4f}.mock-card,.mock-passbook-total,.mock-allowance-today,.mock-note-card,.mock-accordion{margin-bottom:12px}.mock-card h3{margin:0 0 10px;font-size:16px;line-height:24px}.mock-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}.mock-card-head h3{margin:0}.mock-chip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:12px}.mock-chip-grid span,.mock-tag,.mock-status-chip{border-radius:999px;padding:6px 9px;background:#f5f1ea;color:#70675c;font-size:12px;font-weight:800}.mock-chip-grid .is-done{background:#eef8f3;color:#4fae8a}.mock-primary,.mock-secondary{min-height:46px;padding:0 16px;border:0;border-radius:12px;font-size:15px;font-weight:800}.mock-primary{background:#4fae8a;color:#fff;width:100%}.mock-secondary{background:#fff;border:1px solid #e8e1d7;color:#3f352b}.mock-orange{background:#f2a23a}.mock-passbook-total{background:linear-gradient(135deg,#eef8f3,#fff)}.mock-wish-list{display:grid;gap:10px}.mock-wish{padding:12px;border-radius:14px;background:#fffdf9;border:1px solid #e8e1d7}.mock-wish-top,.mock-module-row,.mock-list-row,.mock-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.mock-wish-top span,.mock-module-row span,.mock-list-row span,.mock-toggle-row strong,.mock-toggle-row button{color:#f2a23a;font-weight:900}.mock-wish button{width:100%;min-height:38px;margin-top:10px;border:1px solid #e8e1d7;border-radius:10px;background:#f5f1ea;color:#9b9287;font-weight:800}.mock-note-card,.mock-encourage{background:#fff4df;color:#b97713;text-align:center;font-weight:800}.mock-summary-grid,.mock-rule-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px}.mock-summary-grid div,.mock-rule-grid div{padding:14px;border-radius:16px;background:#fff;border:1px solid #e8e1d7;box-shadow:0 4px 16px #3f352b12}.mock-summary-grid div:first-child{grid-column:span 2;background:#fff4df}.mock-summary-grid span,.mock-rule-grid strong{display:block;color:#70675c;font-size:12px;font-weight:800}.mock-summary-grid strong{color:#3f352b;font-size:24px}.mock-chart{width:100%;height:auto}.mock-chart line{stroke:#eee9e1;stroke-width:1}.mock-chart polyline{fill:none;stroke-width:4;stroke-linecap:round;stroke-linejoin:round}.line-blue{stroke:#5b9be7}.line-green{stroke:#4fae8a}.line-orange{stroke:#f2a23a}.mock-module-list{display:grid;gap:12px}.mock-module-row{display:grid;grid-template-columns:74px 1fr 44px}.mock-module-row strong,.mock-module-row small{display:block}.mock-encourage{margin-bottom:12px;padding:16px;border-radius:16px}.mock-manual{background:#fff4df;border-color:#f2a23a42}.mock-time-row{display:grid;grid-template-columns:auto 1fr auto 1fr auto;gap:8px;align-items:center;margin:12px 0}.mock-time-row input,.mock-field input{min-width:0;height:42px;border:1px solid #e8e1d7;border-radius:12px;background:#fff;color:#3f352b;text-align:center;font-weight:700}.mock-field{display:grid;gap:6px;margin-bottom:10px;color:#70675c;font-size:13px;font-weight:800}.mock-accordion{display:flex;align-items:center;justify-content:space-between;background:#f5f1ea}.mock-accordion>div{display:flex;align-items:center;gap:10px}.mock-accordion strong,.mock-accordion small{display:block}.mock-allowance-today{background:linear-gradient(135deg,#fff4df,#fff)}.mock-rule-grid span{display:block;color:#f2a23a;font-size:16px;font-weight:900}.mock-list-row,.mock-toggle-row{min-height:42px;border-top:1px solid #e8e1d7;color:#70675c;font-size:13px;font-weight:700}.mock-toggle-row button{min-width:74px;min-height:30px;border:1px solid rgba(242,162,58,.3);border-radius:999px;background:#fff4df;cursor:pointer}.mock-toggle-row button.is-on{color:#fff;background:#4fae8a;border-color:#4fae8a}.mock-parent-card{background:#fff}.mock-parent-group{display:grid;gap:12px;padding:12px;border-radius:14px;background:#faf8f3}.mock-parent-subgroup{display:grid;gap:8px}.mock-parent-subgroup+.mock-parent-subgroup{padding-top:10px;border-top:1px solid #e8e1d7}.mock-parent-subgroup span{color:#3f352b;font-size:13px;font-weight:900}.mock-parent-group label{display:flex;align-items:center;gap:8px;color:#70675c;font-size:13px;font-weight:700}.mock-token-list,.mock-component-samples{display:grid;gap:10px}.mock-spec-panel{padding:18px}.mock-spec-panel section+section{margin-top:22px;padding-top:18px;border-top:1px solid #e8e1d7}.mock-spec-panel h2{margin:0 0 12px;font-size:18px}.mock-spec-panel p{color:#70675c;font-size:14px;line-height:22px}.mock-token-row{display:grid;grid-template-columns:22px 72px 1fr;align-items:center;gap:10px;font-size:13px;font-weight:700}.mock-token-row i{width:22px;height:22px;border-radius:7px;border:1px solid rgba(63,53,43,.1)}.mock-token-row code{color:#70675c;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}.mock-status-chip{display:inline-flex;width:max-content;color:#5b9be7;background:#edf5ff}.mock-status-chip.is-progress{color:#4fae8a;background:#eef8f3}.mock-status-chip.is-breakthrough{color:#b97713;background:#fff4df}@media (max-width: 980px){.mockup-root{padding:16px}.mockup-header,.mockup-layout{max-width:min(430px,100%)}.mockup-header{display:grid}.mockup-layout{grid-template-columns:1fr}.mock-page-tabs,.mock-spec-panel{position:static}.mock-page-tabs{grid-template-columns:repeat(3,1fr)}.mock-page-tabs button{text-align:center}.mock-phone{width:min(390px,100%);justify-self:center}}.app{max-width:960px;margin:0 auto;padding:1.5rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;min-height:100vh;background:linear-gradient(to bottom,#faf9f7,#f5f3f0);color:#2d2a26;line-height:1.6}.app-header{text-align:center;padding:1.25rem 0 1rem;border-bottom:2px solid #e8e4df;margin-bottom:1.5rem}.app-header h1{color:#5c4d3d;font-size:1.75rem;font-weight:600;margin:0;letter-spacing:.02em}.header-link{display:inline-flex;margin-top:.75rem;color:#6aa88e;font-weight:600;text-decoration:none}.app-main{display:flex;flex-direction:column;gap:1.5rem}.app-main>section{scroll-margin-top:96px}.daily-growth-section,.ascension-section,.ascension-showcase,.allowance-section,.dictation-entry-section,.parent-settings-section{background:#fff;border:1px solid #e8e4df;border-radius:12px;padding:1.25rem;box-shadow:0 2px 10px #5c4d3d14}.ascension-showcase{position:relative;overflow:hidden}.ascension-copy p{margin:0 0 1rem;color:#6d6256}.subsection-title{margin:1rem 0 .5rem;color:#5c4d3d;font-size:1rem;line-height:1.3}.subsection-caption{margin:.85rem 0 .35rem;color:#6d6256;font-size:.92rem;line-height:1.3}.ascension-task-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.6rem;margin:1rem 0}.ascension-task-list span{padding:.65rem .75rem;border-radius:8px;background:#f8f7f5;border:1px solid #e8e4df;color:#5c4d3d;font-weight:650}.ascension-task-list .task-complete{background:#eef8f3;border-color:#7eb8a2;color:#4d7e6b;box-shadow:inset 0 0 0 1px #7eb8a247}.ascension-auto-status{margin:1rem 0}.ascension-auto-status h3{margin:0 0 .5rem;color:#5c4d3d;font-size:1rem}.ascension-launch-button{min-height:46px;padding:.75rem 1.1rem;border:none;border-radius:999px;background:linear-gradient(135deg,#e8a84a,#d4764a);color:#fff;font-size:1rem;font-weight:800;cursor:pointer;box-shadow:0 8px 18px #d4764a38}.allowance-heading{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start;margin-bottom:1rem}.allowance-heading h2{margin:0 0 .35rem}.allowance-heading p{margin:0;color:#6d6256;line-height:1.5}.allowance-today{min-width:96px;padding:.8rem;border-radius:12px;background:#fff6df;color:#8a5f1e;text-align:center}.allowance-today span,.allowance-today small,.allowance-today strong{display:block}.allowance-today small{margin-top:.15rem;color:#9b6a20;font-size:.85rem;font-weight:800}.allowance-today strong{margin-top:.25rem;font-size:1.55rem;line-height:1}.allowance-rule-grid,.allowance-records-grid{display:grid;gap:.75rem}.allowance-rule-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-bottom:1rem}.allowance-rule-grid div{padding:.8rem;border-radius:10px;border:1px solid #eadfcb;background:#fffdf7}.allowance-rule-grid strong,.allowance-rule-grid span{display:block}.allowance-rule-grid strong{color:#5c4d3d;font-size:.92rem}.allowance-rule-grid span{margin-top:.25rem;color:#d4764a;font-weight:800}.allowance-records-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.allowance-record-card{border:1px solid #e8e4df;border-radius:10px;padding:.9rem;background:#faf9f7}.allowance-record-card h3{margin:0 0 .65rem;color:#5c4d3d;font-size:1rem}.allowance-row{display:grid;grid-template-columns:repeat(4,auto);gap:.5rem;align-items:center;justify-content:space-between;padding:.55rem 0;border-top:1px solid #e8e4df;color:#5c4d3d;font-size:.9rem}.allowance-record-card .allowance-row:first-of-type{border-top:none}.allowance-row strong{color:#d4764a}.allowance-empty{padding:.8rem;border-radius:8px;background:#fff;color:#8c8478}.ascension-stage{position:relative;height:132px;margin-top:1rem;border-radius:12px;background:radial-gradient(circle at 50% 76%,rgba(232,168,74,.24),transparent 42%),linear-gradient(180deg,#f8fbff,#eef8f3);border:1px solid #e8e4df;overflow:hidden}.ascension-hero{position:absolute;left:50%;bottom:22px;width:64px;height:64px;transform:translate(-50%);border-radius:50%;display:grid;place-items:center;background:#7eb8a2;color:#fff;font-weight:900;box-shadow:0 8px 16px #7eb8a247;transition:transform .35s ease}.ascension-showcase.is-flying .ascension-hero,.ascension-showcase.is-flying .ascension-ring,.ascension-showcase.is-flying .ascension-spark{display:none}.ascension-video-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;display:grid;place-items:center;background:#000}.ascension-fullscreen-video{width:100vw;height:100vh;object-fit:cover;background:#000}.ascension-ring,.ascension-spark{position:absolute;pointer-events:none;opacity:0}.ascension-ring{left:50%;bottom:36px;width:88px;height:28px;border:3px solid rgba(232,168,74,.72);border-radius:50%;transform:translate(-50%) scale(.5)}.ring-two{border-color:#7eb8a2b8}.ascension-spark{width:10px;height:10px;border-radius:50%;background:#e8a84a}.spark-one{left:33%;bottom:48px}.spark-two{left:61%;bottom:60px;background:#7eb8a2}.spark-three{left:49%;bottom:86px;background:#d4764a}.ascension-showcase.is-flying .ascension-hero{animation:ascendHero 1.8s ease-in-out both}.ascension-showcase.is-flying .ring-one{animation:ascendRing 1.6s ease-out both}.ascension-showcase.is-flying .ring-two{animation:ascendRing 1.6s ease-out .22s both}.ascension-showcase.is-flying .ascension-spark{animation:ascendSpark 1.5s ease-out both}@keyframes ascendHero{0%{transform:translate(-50%) translateY(0) scale(1)}35%{transform:translate(-50%) translateY(-24px) scale(1.08)}70%{transform:translate(-50%) translateY(-54px) scale(1.16)}to{transform:translate(-50%) translateY(-34px) scale(1.08)}}@keyframes ascendRing{0%{opacity:0;transform:translate(-50%) scale(.45)}35%{opacity:1}to{opacity:0;transform:translate(-50%) translateY(-56px) scale(1.55)}}@keyframes ascendSpark{0%{opacity:0;transform:translateY(0) scale(.5)}25%{opacity:1}to{opacity:0;transform:translateY(-58px) scale(1.3)}}.compact-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:.75rem;margin-bottom:1rem}.compact-form-grid label,.parent-settings-section label{display:flex;flex-direction:column;gap:.35rem;color:#5c4d3d;font-weight:600}.compact-form-grid input,.parent-settings-section input,.parent-password-input,.note-input{border:1px solid #d8d2ca;border-radius:8px;padding:.65rem .75rem;color:#2d2a26;background:#faf9f7}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin:1rem 0}.checkbox-grid label{display:flex;align-items:center;gap:.5rem;padding:.7rem .8rem;background:#faf9f7;border:1px solid #e8e4df;border-radius:8px}.classroom-feedback{border:1px solid #e8e4df;border-radius:12px;background:#fffdf9;overflow:hidden;margin:1rem 0}.classroom-feedback-header,.classroom-feedback-row{display:grid;grid-template-columns:64px repeat(3,minmax(0,1fr));gap:.5rem;align-items:center;padding:.7rem .8rem}.classroom-feedback-header{background:#f5f1ea;color:#6b6258;font-size:.82rem;font-weight:700}.classroom-feedback-header span{display:flex;flex-direction:column;gap:.1rem}.classroom-feedback-header small{color:#9b8d7e;font-size:.72rem;font-weight:600}.classroom-feedback-row+.classroom-feedback-row{border-top:1px solid #eee8df}.classroom-feedback-row strong{color:#4a4036;font-size:.95rem}.classroom-feedback-row input{width:100%;min-width:0;text-align:center}.classroom-feedback-total{display:flex;justify-content:space-between;align-items:center;gap:.75rem;padding:.7rem .8rem;border-top:1px solid #eee8df;background:#fff8e8;color:#5c4d3d;font-size:.92rem;font-weight:800}.classroom-feedback-total strong{color:#d4764a;font-size:1.05rem}.classroom-feedback-note{margin:0;padding:.6rem .8rem .75rem;color:#8a7d6e;font-size:.82rem}.parent-config-card{padding:16px;margin:16px 0;border:1px solid #e8e4df;border-radius:16px;background:#fffdf9}.parent-config-note{margin:0 0 12px;color:#6d6256;font-size:.9rem;line-height:1.5}.progress-points-settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:12px}.progress-points-settings-grid label{gap:.45rem}.score-table{border:1px solid #e8e4df;border-radius:8px;overflow:hidden;margin:1rem 0}.score-table-header,.score-table-row{display:grid;grid-template-columns:1fr repeat(3,70px);gap:.5rem;align-items:center;padding:.65rem}.score-table-header{background:#f5f3f0;color:#5c4d3d;font-weight:700}.score-table-row input{width:100%;border:1px solid #d8d2ca;border-radius:6px;padding:.45rem}.note-input{width:100%;min-height:72px;resize:vertical;margin-bottom:.85rem}.section-primary-button,.dictation-link{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:.75rem 1rem;border:none;border-radius:8px;background:#7eb8a2;color:#fff;font-weight:700;text-decoration:none;cursor:pointer}.section-message,.passbook-message{margin-top:.75rem;padding:.75rem;border-radius:8px;background:#eef8f3;color:#4d7e6b}.section-error{margin-top:.75rem;color:#d4764a;font-weight:600}.time-input-section{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#fff;border-radius:12px;border:1px solid #e8e4df;box-shadow:0 2px 8px #5c4d3d0f}.time-label{font-size:1rem;color:#5c4d3d;font-weight:500}.time-inputs{display:flex;align-items:center;gap:.5rem}.time-input{width:72px;padding:.625rem .75rem;border:2px solid #e8e4df;border-radius:8px;font-size:1.125rem;text-align:center;background:#faf9f7;color:#2d2a26;transition:border-color .2s ease,box-shadow .2s ease}.time-input:focus{border-color:#7eb8a2;outline:none;box-shadow:0 0 0 3px #7eb8a233}.time-input:disabled{background:#f5f3f0;color:#8c8478;cursor:not-allowed}.time-unit{color:#8c8478;font-size:.95rem;font-weight:400}.time-error{color:#d4764a;font-size:.875rem;margin-top:.25rem;padding-left:.25rem}.image-upload-section{position:relative}.upload-guidance{margin-bottom:1rem;padding:.85rem 1rem;background:#faf9f7;border:1px solid #e8e4df;border-radius:8px}.upload-guidance-tip{color:#5c4d3d;font-size:.85rem;font-weight:600;margin-bottom:.35rem}.upload-guidance-privacy{color:#8c8478;font-size:.8rem}.upload-area{border:2px dashed #c4b8a8;border-radius:16px;padding:2.5rem 2rem;text-align:center;cursor:pointer;transition:all .25s ease;background:#fff}.upload-area:hover{border-color:#7eb8a2;background:#f8f7f5;box-shadow:0 4px 12px #7eb8a21f}.upload-icon{font-size:2.5rem;margin-bottom:.75rem;opacity:.85}.upload-text{color:#5c4d3d;font-size:1.125rem;font-weight:500}.upload-hint{color:#8c8478;font-size:.875rem;margin-top:.5rem}.image-preview{position:relative;cursor:pointer;border-radius:16px;overflow:hidden;background:#fff;border:2px solid #e8e4df;transition:border-color .2s ease}.image-preview:hover{border-color:#7eb8a2}.preview-image{display:block;width:100%;max-width:480px;margin:0 auto;border-radius:14px}.image-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#5c4d3d8c;color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:1rem;border-radius:14px;gap:.5rem}.image-overlay-icon{font-size:1.5rem}.file-input-hidden{display:none}.grade-button{display:block;width:100%;max-width:480px;margin:0 auto;padding:1.125rem 2rem;background:linear-gradient(135deg,#7eb8a2,#6aa88e);color:#fff;border:none;border-radius:12px;font-size:1.25rem;font-weight:600;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 12px #7eb8a240;letter-spacing:.02em}.grade-button:hover:not(:disabled){background:linear-gradient(135deg,#6aa88e,#5a9a80);transform:translateY(-1px);box-shadow:0 6px 16px #7eb8a259}.grade-button:disabled{background:#d4d0c8;cursor:not-allowed;box-shadow:none;color:#8c8478}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#faf9f7f2;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000}.loading-spinner{width:48px;height:48px;border:4px solid #e8e4df;border-top-color:#7eb8a2;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{margin-top:1.25rem;color:#5c4d3d;font-size:1.125rem;font-weight:500}.loading-hint{margin-top:.5rem;color:#8c8478;font-size:.875rem}.error-message{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding:1.25rem;background:linear-gradient(135deg,#fef3ed,#fceee3);border:2px solid #d4764a;border-radius:12px;margin-bottom:1rem}.error-icon{font-size:1.5rem}.error-text{color:#d4764a;font-size:1rem;font-weight:500;flex:1;min-width:200px}.error-reset{padding:.625rem 1.25rem;background:#d4764a;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s ease}.error-reset:hover{background:#c06a40}.annotation-section{background:#fff;border-radius:16px;border:2px solid #e8e4df;padding:1rem;box-shadow:0 2px 8px #5c4d3d0f}.annotation-result-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.875rem}.annotation-result-header h3{margin:0;color:#3f3429;font-size:1.15rem;font-weight:800}.annotation-result-header p{margin:.25rem 0 0;color:#7b6a57;font-size:.95rem}.annotation-score-pill{flex:0 0 auto;border-radius:999px;background:#fff4de;color:#c96f3a;font-weight:800;padding:.6rem .9rem;border:1px solid #f0d5aa}.annotation-title{font-size:1rem;color:#5c4d3d;font-weight:500;margin:0 0 .75rem}.review-table-section{background:#fff;border-radius:16px;border:2px solid #e8e4df;padding:1.25rem;box-shadow:0 2px 8px #5c4d3d0f}.review-table-section h3{font-size:1.125rem;color:#5c4d3d;font-weight:600;margin:0 0 1rem}.review-table{border:1px solid #e8e4df;border-radius:12px;overflow:hidden}.review-table-header{display:flex;align-items:center;padding:.75rem 1rem;gap:.5rem;background:linear-gradient(to bottom,#f8f7f5,#f5f3f0);font-weight:600;color:#5c4d3d;font-size:.875rem;border-bottom:1px solid #e8e4df}.review-table-row{display:flex;align-items:center;padding:.625rem 1rem;gap:.5rem;border-bottom:1px solid #e8e4df;cursor:pointer;transition:background .15s ease}.review-table-row:last-child{border-bottom:none}.review-table-row:hover{background:#faf9f7}.row-wrong{background:linear-gradient(90deg,#fef3ed,#fff 30%);border-left:4px solid #d4764a}.row-wrong:hover{background:linear-gradient(90deg,#fceee3,#faf9f7 30%)}.row-low-confidence{background:linear-gradient(90deg,#fff8e8,#fff 30%);border-left:4px solid #e8a84a}.row-low-confidence:hover{background:linear-gradient(90deg,#fff3d8,#faf9f7 30%)}.row-wrong.row-low-confidence{background:linear-gradient(90deg,#fceee3,#fff8e8 30%);border-left:4px solid #d4764a}.row-selected{outline:2px solid #7eb8a2;outline-offset:-2px;background:#7eb8a214}.col-index{width:36px;text-align:center;color:#8c8478;font-size:.9rem}.col-question{width:88px;font-size:.95rem;color:#2d2a26;font-weight:500}.col-answer,.col-correct{width:56px;text-align:center;font-size:.875rem;color:#5c4d3d}.col-answer-input,.col-correct-input{width:56px;padding:.375rem .5rem;border:2px solid #e8e4df;border-radius:6px;font-size:.95rem;text-align:center;background:#faf9f7;color:#2d2a26;transition:border-color .15s ease}.col-answer-input:focus,.col-correct-input:focus{border-color:#7eb8a2;outline:none;background:#fff}.col-status{width:32px;text-align:center;font-size:1.125rem}.status-correct{color:#7eb8a2}.status-wrong{color:#d4764a}.col-confidence{width:56px;text-align:center;font-size:.85rem;color:#5c4d3d}.confidence-low{color:#e8a84a;font-weight:500}.col-action{flex:1;min-width:80px;text-align:right}.col-action-toggle{padding:.375rem .75rem;font-size:.85rem;background:#f5f3f0;border:1px solid #d4d0c8;border-radius:6px;cursor:pointer;transition:all .15s ease;color:#5c4d3d}.col-action-toggle:hover{background:#e8e4df;border-color:#c4b8a8}.confirm-section{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.confirm-button{padding:1rem 2.5rem;background:linear-gradient(135deg,#5a8fda,#4a80c8);color:#fff;border:none;border-radius:12px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 12px #5a8fda40}.confirm-button:hover{background:linear-gradient(135deg,#4a80c8,#3a70b8);transform:translateY(-1px);box-shadow:0 6px 16px #5a8fda59}.reset-button{padding:1rem 2rem;background:#fff;color:#5c4d3d;border:2px solid #e8e4df;border-radius:12px;font-size:1.125rem;font-weight:500;cursor:pointer;transition:all .2s ease}.reset-button:hover{background:#f5f3f0;border-color:#d4d0c8}.final-summary{background:#fff;border-radius:20px;border:2px solid #e8e4df;padding:2rem;box-shadow:0 4px 16px #5c4d3d14}.summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.summary-header h2{font-size:1.5rem;color:#5c4d3d;margin:0;font-weight:600}.progress-badge{padding:.625rem 1.25rem;border-radius:24px;color:#fff;font-weight:600;font-size:1rem;box-shadow:0 2px 8px #00000026;letter-spacing:.02em}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem;margin-bottom:1.5rem;padding:1.25rem;background:#faf9f7;border-radius:12px}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-label{font-size:.85rem;color:#8c8478;text-transform:uppercase;letter-spacing:.03em}.stat-value{font-size:1.5rem;color:#2d2a26;font-weight:600}.stat-correct{color:#7eb8a2}.stat-wrong{color:#d4764a}.summary-encouragement{background:linear-gradient(135deg,#faf9f7,#f5f3f0);border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;text-align:center;border:1px solid #e8e4df}.summary-encouragement-text{font-size:1.25rem;color:#5c4d3d;font-weight:500;line-height:1.5}.summary-baseline{display:flex;flex-wrap:wrap;gap:.75rem 1.5rem;margin-bottom:1rem;padding:1rem;background:#faf9f7;border-radius:8px;font-size:.9rem}.baseline-label{color:#8c8478}.baseline-value{color:#5c4d3d;font-weight:600}.summary-reason{font-size:.95rem;color:#5c4d3d;margin-bottom:1.5rem;padding:.75rem 1rem;background:#7eb8a214;border-radius:8px;border-left:3px solid #7eb8a2}.summary-manual{background:linear-gradient(135deg,#fff8e8,#fff3d8);border-radius:8px;padding:.75rem 1rem;font-size:.9rem;color:#e8a84a;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem;border:1px solid #e8a84a}.summary-manual-icon{font-size:1.125rem}@media (max-width: 640px){.app{padding:1rem}.app-header{padding:1rem 0 .75rem;margin-bottom:1rem}.app-header h1{font-size:1.35rem}.app-main{gap:1rem}.time-input-section{padding:.75rem 1rem;gap:.5rem}.time-input{width:60px;padding:.5rem;font-size:1rem}.upload-area{padding:2rem 1.5rem}.upload-icon{font-size:2rem}.upload-text{font-size:1rem}.preview-image{max-width:100%}.grade-button{max-width:100%;padding:1rem 1.5rem;font-size:1.125rem}.annotation-result-header{align-items:flex-start;flex-direction:column}.review-table-section{padding:1rem}.review-table-section h3{font-size:1rem}.review-table-header,.review-table-row{padding:.5rem .75rem;gap:.35rem;flex-wrap:wrap}.col-index{width:28px;font-size:.8rem}.col-question{width:72px;font-size:.85rem}.col-answer,.col-correct{width:48px;font-size:.75rem}.col-answer-input,.col-correct-input{width:48px;padding:.25rem .35rem;font-size:.85rem}.col-status{width:24px;font-size:1rem}.col-confidence{width:44px;font-size:.75rem}.col-action{order:10;width:100%;text-align:center;margin-top:.25rem}.col-action-toggle{font-size:.8rem;padding:.25rem .5rem}.confirm-section{gap:.75rem}.confirm-button,.reset-button{padding:.875rem 1.5rem;font-size:1rem;flex:1;min-width:140px}.final-summary{padding:1.25rem;border-radius:16px}.summary-header{flex-direction:column;align-items:flex-start;gap:.75rem}.summary-header h2{font-size:1.25rem}.progress-badge{font-size:.9rem;padding:.5rem 1rem}.summary-stats{grid-template-columns:repeat(3,1fr);gap:.75rem;padding:1rem}.stat-label{font-size:.75rem}.stat-value{font-size:1.25rem}.summary-encouragement{padding:1rem}.summary-encouragement-text{font-size:1rem}.summary-baseline{gap:.5rem 1rem;font-size:.85rem}}:root{--hy-bg: #faf8f3;--hy-surface: #ffffff;--hy-surface-muted: #f5f1ea;--hy-primary: #4fae8a;--hy-primary-soft: #eef8f3;--hy-secondary: #5b9be7;--hy-secondary-soft: #edf5ff;--hy-accent: #f2a23a;--hy-accent-soft: #fff4df;--hy-danger: #e15b4f;--hy-text: #3f352b;--hy-text-secondary: #70675c;--hy-text-muted: #9b9287;--hy-border: #e8e1d7;--hy-shadow: 0 4px 16px rgba(63, 53, 43, .08);--hy-float-shadow: 0 10px 28px rgba(63, 53, 43, .12)}html{background:radial-gradient(circle at top left,rgba(79,174,138,.18),transparent 32%),radial-gradient(circle at 80% 10%,rgba(91,155,231,.16),transparent 28%),var(--hy-bg)}body{margin:0;background:transparent;color:var(--hy-text)}.app,.app *{box-sizing:border-box}.app{width:min(430px,100%);max-width:430px;margin:0 auto;min-height:100vh;padding:18px 16px 84px;background:var(--hy-bg);color:var(--hy-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;line-height:1.45}.app-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:8px 0 14px;margin:0;border:0;text-align:left}.app-header:before{content:"5月24日 周日";position:absolute;margin-top:-2px;color:var(--hy-text-muted);font-size:12px;font-weight:700}.app-header h1{margin:20px 0 0;color:var(--hy-text);font-size:24px;line-height:32px;font-weight:800;letter-spacing:0}.header-link{min-height:34px;margin-top:14px;padding:0 12px;border-radius:999px;background:var(--hy-primary-soft);color:var(--hy-primary);display:inline-flex;align-items:center;font-size:13px;font-weight:800;text-decoration:none}.app-main{display:grid;gap:12px}.today-growth-hero,.hero-passbook-section,.progress-dashboard-section,.oral-arithmetic-section,.daily-growth-section,.ascension-section,.ascension-showcase,.allowance-section,.dictation-entry-section,.parent-settings-section,.time-input-section,.manual-entry-section,.photo-grading-fallback,.annotation-section,.review-table-section,.final-summary{background:var(--hy-surface);border:1px solid var(--hy-border);border-radius:16px;box-shadow:var(--hy-shadow)}.today-growth-hero{padding:16px;background:radial-gradient(circle at 92% 12%,rgba(91,155,231,.18),transparent 36%),var(--hy-surface)}.today-growth-hero span,.hero-passbook-section .balance-label,.passbook-balance>span:first-child,.allowance-today span{color:var(--hy-primary);font-size:13px;font-weight:800}.today-growth-hero h2{margin:4px 0;color:var(--hy-text);font-size:22px;line-height:30px;font-weight:800}.today-growth-hero p,.allowance-heading p,.ascension-copy p,.dashboard-heading p{margin:0;color:var(--hy-text-secondary);font-size:14px}.hero-passbook-section,.progress-dashboard-section,.oral-arithmetic-section,.allowance-section,.ascension-showcase,.dictation-entry-section,.parent-settings-section{padding:16px}.hero-passbook-section h2,.progress-dashboard-section h2,.oral-arithmetic-section h2,.allowance-heading h2,.ascension-copy h2,.dictation-entry-section h2,.parent-settings-section h2,.daily-growth-section h2,.ascension-section h2{margin:0 0 12px;color:var(--hy-text);font-size:20px;line-height:28px;font-weight:800}.passbook-balance{display:grid;grid-template-columns:auto 1fr;gap:16px;align-items:center;padding:16px;margin-bottom:12px;border:1px solid var(--hy-border);border-radius:16px;background:linear-gradient(135deg,var(--hy-primary-soft),var(--hy-surface))}.balance-value,.passbook-balance .balance-value,.allowance-today strong{color:var(--hy-accent);font-size:30px;line-height:36px;font-weight:900}.wish-form{grid-template-columns:1fr}.wish-input,.wish-points-select,.compact-form-grid input,.parent-settings-section input,.parent-password-input,.note-input,.time-input,.manual-input{min-height:42px;border:1px solid var(--hy-border);border-radius:12px;background:var(--hy-surface);color:var(--hy-text);font-weight:700}.wish-add-button,.section-primary-button,.dictation-link,.manual-confirm-button,.grade-button{min-height:46px;border:0;border-radius:12px;background:var(--hy-primary);color:#fff;font-size:15px;font-weight:800;box-shadow:none}.wish-item,.allowance-rule-grid div,.allowance-record-card,.trend-card,.module-progress-card{background:#fffdf9;border:1px solid var(--hy-border);border-radius:14px;box-shadow:none}.wish-points,.history-points,.progress-points-score,.breakthrough-value,.allowance-rule-grid span{color:var(--hy-accent);font-weight:900}.progress-bar,.mock-progress,.module-progress-track{height:8px;border-radius:999px;background:#eee9e1}.progress-fill,.module-progress-fill{background:var(--hy-primary)}.redeem-enabled{background:var(--hy-primary);color:#fff}.redeem-disabled,.wish-tier,.photo-fallback-toggle{background:var(--hy-surface-muted);color:var(--hy-text-muted);border:1px solid var(--hy-border)}.allowance-section{background:var(--hy-surface)}.allowance-heading{margin-bottom:12px}.allowance-today{background:var(--hy-accent-soft);color:#8a5f1e;border-radius:16px}.allowance-rule-grid,.allowance-records-grid,.dashboard-summary-cards,.mock-rule-grid{gap:10px}.dashboard-heading{margin-bottom:12px}.dashboard-badge{background:var(--hy-accent-soft);color:#b97713}.points-info-button{border-color:#f2a23a5c;color:#b97713}.dashboard-summary-cards{grid-template-columns:repeat(2,minmax(0,1fr))}.summary-card{min-height:78px;border:1px solid var(--hy-border);border-radius:16px;padding:14px;background:var(--hy-surface)}.total-card{grid-column:span 2;background:var(--hy-accent-soft)}.stable-card{background:var(--hy-primary-soft)}.star-card{background:var(--hy-secondary-soft)}.summary-value{color:var(--hy-primary);font-size:24px}.star-card .summary-value{color:var(--hy-secondary)}.total-card .summary-value{color:var(--hy-accent)}.trend-card,.module-progress-card{padding:16px;background:var(--hy-surface)}.progress-line-chart>line,.progress-line-chart .chart-grid{stroke:#eee9e1}.module-line-chart path.module-line-1,.module-chart-legend .module-line-1 i,.module-line-chart .chart-point.module-line-1 circle{stroke:var(--hy-secondary);fill:var(--hy-secondary);background:var(--hy-secondary)}.module-line-chart path.module-line-2,.module-chart-legend .module-line-2 i,.module-line-chart .chart-point.module-line-2 circle{stroke:var(--hy-primary);fill:var(--hy-primary);background:var(--hy-primary)}.module-line-chart path.module-line-3,.module-chart-legend .module-line-3 i,.module-line-chart .chart-point.module-line-3 circle{stroke:var(--hy-accent);fill:var(--hy-accent);background:var(--hy-accent)}.module-progress-row{grid-template-columns:74px 1fr 44px}.progress-points-row{grid-template-columns:1fr auto auto}.dashboard-encouragement,.section-message,.passbook-message{background:var(--hy-primary-soft);color:var(--hy-text);border-left:3px solid var(--hy-primary)}.ascension-task-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.ascension-task-list span{border-radius:999px;border:0;background:var(--hy-surface-muted);color:var(--hy-text-secondary);font-size:13px}.ascension-task-list .task-complete{background:var(--hy-primary-soft);color:var(--hy-primary);box-shadow:none}.ascension-launch-button{width:100%;min-height:46px;padding:0 22px;border-radius:999px;background:var(--hy-accent);box-shadow:0 8px 18px #f2a23a38}.ascension-stage{border-color:var(--hy-border);border-radius:16px;background:linear-gradient(180deg,#edf5ff,#eef8f3)}.manual-entry-section{background:var(--hy-accent-soft);border-color:#f2a23a42;box-shadow:none}.time-input-section{padding:14px 16px}.photo-grading-fallback{border:1px solid var(--hy-border);padding:0;overflow:hidden}.photo-fallback-toggle{border:0;border-radius:0}.checkbox-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.checkbox-grid label{min-height:54px;border:1px solid var(--hy-border);border-radius:12px;background:#fffdf9;color:var(--hy-text);font-weight:700}.app-top-nav{position:sticky;top:10px;z-index:100;display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin:-.55rem 0 1.1rem;padding:6px;background:#ffffffe6;border:1px solid var(--hy-border);border-radius:18px;box-shadow:0 12px 28px #5c4d3d1f;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.app-top-nav a{min-height:38px;display:grid;place-items:center;border-radius:12px;color:var(--hy-text-secondary);font-size:13px;font-weight:800;text-decoration:none}.app-top-nav a:focus-visible,.app-top-nav a:hover{background:var(--hy-primary-soft);color:var(--hy-primary)}@media (min-width: 700px){.app{margin-top:24px;margin-bottom:24px;border-radius:32px;box-shadow:var(--hy-float-shadow)}.app-top-nav{top:24px}.app-main>section{scroll-margin-top:112px}}@media (max-width: 640px){.app{padding:14px}.hero-passbook-section,.progress-dashboard-section,.oral-arithmetic-section,.daily-growth-section,.ascension-section,.ascension-showcase,.allowance-section,.dictation-entry-section,.parent-settings-section{padding:16px}.dashboard-summary-cards,.checkbox-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.module-progress-row{grid-template-columns:74px 1fr 44px}.progress-points-row{grid-template-columns:1fr auto auto}}@media (max-width: 380px){.dashboard-summary-cards,.checkbox-grid,.ascension-task-list{grid-template-columns:1fr}.total-card{grid-column:auto}}@media (max-width: 380px){.review-table-header,.review-table-row{font-size:.75rem}.col-question{width:60px;overflow:hidden;text-overflow:ellipsis}.summary-stats{grid-template-columns:repeat(2,1fr)}}button:focus-visible,input:focus-visible{outline:2px solid #7eb8a2;outline-offset:2px}@media (prefers-reduced-motion: reduce){.loading-spinner{animation:none}.grade-button,.confirm-button,.upload-area,.review-table-row{transition:none}}.hero-passbook-section{background:#fff;border-radius:16px;border:2px solid #e8e4df;padding:1.5rem;box-shadow:0 2px 8px #5c4d3d0f}.hero-passbook-section h2{font-size:1.25rem;color:#5c4d3d;margin:0 0 1rem;font-weight:600}.passbook-balance{display:flex;align-items:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,#faf9f7,#f5f3f0);border-radius:12px;margin-bottom:1.25rem}.balance-label{font-size:1rem;color:#5c4d3d;font-weight:500}.balance-value{font-size:2rem;color:#e8a84a;font-weight:700}.passbook-wishes h3{font-size:1rem;color:#5c4d3d;margin:0 0 .75rem;font-weight:500}.wish-form{display:grid;grid-template-columns:1fr minmax(140px,180px) auto;gap:.5rem;margin-bottom:.75rem}.wish-input,.wish-points-select{min-width:0;padding:.7rem .8rem;border:1px solid #d8d1c8;border-radius:8px;background:#fff;color:#2d2a26;font-size:.95rem}.wish-input:focus,.wish-points-select:focus{border-color:#7eb8a2;outline:none;box-shadow:0 0 0 3px #7eb8a22e}.wish-add-button{padding:.7rem 1rem;border:none;border-radius:8px;background:#7eb8a2;color:#fff;font-weight:700;cursor:pointer}.wish-error,.empty-wishes{padding:.7rem .8rem;margin-bottom:.75rem;border-radius:8px;font-size:.9rem}.wish-error{color:#b35d38;background:#fff1e9}.empty-wishes{color:#8c8478;background:#faf9f7;border:1px dashed #d8d1c8}.wish-item{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#faf9f7;border-radius:10px;margin-bottom:.5rem;border:1px solid #e8e4df}.wish-info{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;flex:1;min-width:140px}.wish-name{font-size:.95rem;color:#2d2a26;font-weight:500}.wish-points{font-size:.85rem;color:#e8a84a;font-weight:600}.wish-tier{font-size:.8rem;color:#8c8478;padding:.25rem .5rem;background:#f5f3f0;border-radius:4px}.wish-progress{display:flex;align-items:center;gap:.5rem;min-width:120px}.progress-bar{width:80px;height:8px;background:#e8e4df;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#7eb8a2,#6aa88e);border-radius:4px}.progress-label{font-size:.85rem;color:#5c4d3d;font-weight:500}.redeem-button{padding:.5rem 1rem;font-size:.9rem;border-radius:8px;cursor:pointer;transition:all .2s ease}.redeem-enabled{background:linear-gradient(135deg,#7eb8a2,#6aa88e);color:#fff;border:none;box-shadow:0 2px 6px #7eb8a233}.redeem-enabled:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 10px #7eb8a24d}.redeem-disabled{background:#f5f3f0;color:#8c8478;border:1px solid #d4d0c8;cursor:not-allowed}.passbook-redemption-state{padding:.75rem 1rem;background:linear-gradient(135deg,#fff8e8,#fff3d8);border-radius:8px;font-size:.9rem;color:#e8a84a;text-align:center;margin-top:1rem}.passbook-history h3{font-size:.95rem;color:#5c4d3d;margin:1rem 0 .5rem;font-weight:500}.history-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;font-size:.85rem;color:#8c8478;border-bottom:1px solid #e8e4df}.history-item:last-child{border-bottom:none}.history-name{flex:1}.history-points{color:#e8a84a}.history-date{font-size:.8rem}.progress-dashboard-section{background:#fff;border-radius:16px;border:2px solid #e8e4df;padding:1.5rem;box-shadow:0 2px 8px #5c4d3d0f}.dashboard-heading{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.dashboard-heading h2{font-size:1.25rem;color:#5c4d3d;margin:0;font-weight:600}.dashboard-heading p{margin:.25rem 0 0;color:#8c8478;font-size:.9rem}.dashboard-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .75rem;border-radius:999px;background:#fff7df;color:#c9861d;font-size:.82rem;font-weight:700;white-space:nowrap}.points-info-button{width:1.25rem;height:1.25rem;border:1px solid rgba(201,134,29,.42);border-radius:50%;background:#fff;color:#c9861d;font-size:.78rem;font-weight:900;line-height:1;cursor:help}.points-info-button:focus-visible,.points-info-button:active{outline:2px solid rgba(201,134,29,.32);outline-offset:2px}.dashboard-summary-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin-bottom:1rem}.summary-card{display:flex;flex-direction:column;gap:.25rem;padding:1rem;border-radius:12px;border:1px solid #ebe6df}.stable-card{background:linear-gradient(135deg,#eef8f4,#f8fbf9)}.star-card{background:linear-gradient(135deg,#fff5d9,#fffaf0)}.summary-label{font-size:.85rem;color:#5c4d3d;font-weight:600}.summary-value{font-size:1.8rem;color:#6ba990;font-weight:800;line-height:1}.star-card .summary-value{color:#e8a84a}.total-card{background:linear-gradient(135deg,#fef3ed,#fffaf7)}.total-card .summary-value{color:#d4764a}.summary-note{color:#8c8478;font-size:.8rem}.week-star-map{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.5rem;margin-bottom:1rem}.week-star{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:.65rem .35rem;min-width:0;border-radius:12px;background:#faf9f7;border:1px solid #ebe6df}.week-star-date{color:#8c8478;font-size:.72rem;font-weight:600}.week-star-icon{display:grid;place-items:center;width:2rem;height:2rem;border-radius:50%;color:#fff;font-size:1rem;font-weight:800}.week-star-label{color:#5c4d3d;font-size:.72rem;font-weight:600;white-space:nowrap}.status-fallback .week-star-icon,.status-fallback circle{background:#e6b17a;fill:#e6b17a}.status-stable .week-star-icon,.status-stable circle{background:#6fa8dc;fill:#6fa8dc}.status-progress .week-star-icon,.status-progress circle{background:#7eb8a2;fill:#7eb8a2}.status-breakthrough .week-star-icon,.status-breakthrough circle{background:#e8a84a;fill:#e8a84a}.trend-card,.module-progress-card{padding:1rem;border:1px solid #ebe6df;border-radius:12px;background:#fbfaf8;margin-bottom:1rem}.trend-card-header{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;margin-bottom:.5rem}.trend-card-header h3,.module-progress-card h3{margin:0;color:#5c4d3d;font-size:1rem}.trend-card-header span{color:#8c8478;font-size:.78rem;text-align:right}.progress-line-chart{width:100%;height:auto;display:block}.progress-line-chart>line{stroke:#cfc7bd;stroke-width:1.5}.progress-line-chart .chart-grid{stroke:#eee9e3;stroke-width:1}.progress-line-chart path{fill:none;stroke:#7eb8a2;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.module-line-chart path[class*=module-line-]{fill:none;stroke-width:2.5}.module-line-chart path.module-line-1,.module-chart-legend .module-line-1 i{stroke:#6fa8dc;background:#6fa8dc}.module-line-chart path.module-line-2,.module-chart-legend .module-line-2 i{stroke:#7eb8a2;background:#7eb8a2}.module-line-chart path.module-line-3,.module-chart-legend .module-line-3 i{stroke:#e8a84a;background:#e8a84a}.module-line-chart path.module-line-4,.module-chart-legend .module-line-4 i{stroke:#d4764a;background:#d4764a}.module-line-chart path.module-line-5,.module-chart-legend .module-line-5 i{stroke:#9b87c8;background:#9b87c8}.module-line-chart .empty-chart-placeholder{fill:none;stroke:var(--hy-accent);stroke-width:4;stroke-linecap:round;stroke-linejoin:round;opacity:.34}.module-line-chart .chart-point.module-line-1 circle{fill:#6fa8dc}.module-line-chart .chart-point.module-line-2 circle{fill:#7eb8a2}.module-line-chart .chart-point.module-line-3 circle{fill:#e8a84a}.module-line-chart .chart-point.module-line-4 circle{fill:#d4764a}.module-line-chart .chart-point.module-line-5 circle{fill:#9b87c8}.module-chart-legend{display:flex;flex-wrap:wrap;gap:.45rem .75rem;margin-top:.55rem}.chart-empty-copy{margin-top:-4px;color:var(--hy-text-muted);font-size:12px;line-height:18px}.module-chart-legend span{display:inline-flex;align-items:center;gap:.3rem;color:#5c4d3d;font-size:.76rem;font-weight:700}.module-chart-legend i{width:.65rem;height:.65rem;border-radius:50%}.progress-line-chart text{fill:#8c8478;font-size:10px;text-anchor:middle}.progress-line-chart g>text:first-of-type{text-anchor:end}.chart-point text{font-size:9px}.module-progress-card{display:flex;flex-direction:column;gap:.75rem}.module-progress-header,.module-progress-row{display:grid;align-items:center;gap:.75rem}.module-progress-header{grid-template-columns:1fr auto}.module-progress-header strong{color:#d4764a;font-size:1.2rem}.module-progress-row{grid-template-columns:1fr auto auto;padding:.7rem 0;border-top:1px solid #ebe6df}.module-progress-label{display:flex;flex-direction:column;gap:.2rem;min-width:0}.module-progress-label span{color:#5c4d3d;font-weight:700}.module-progress-label strong{color:#e8a84a;font-size:.85rem}.module-progress-track{height:.7rem;border-radius:999px;background:#eee9e3;overflow:hidden}.module-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#7eb8a2,#e8c36a)}.progress-points-status{padding:.28rem .55rem;border-radius:999px;color:#fff;font-size:.78rem;font-weight:800}.progress-points-status.status-fallback{background:#e6b17a}.progress-points-status.status-stable{background:#6fa8dc}.progress-points-status.status-progress{background:#7eb8a2}.progress-points-status.status-breakthrough{background:#e8a84a}.progress-points-score{color:#d4764a;white-space:nowrap}.progress-points-empty{padding:.85rem;border-radius:8px;background:#fff;color:#8c8478}.dashboard-breakthrough{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding:.75rem 1rem;background:linear-gradient(135deg,#fff8e8,#fff3d8);border-radius:8px;margin-bottom:1rem}.breakthrough-label{font-size:.9rem;color:#5c4d3d;font-weight:500}.breakthrough-value{font-size:.85rem;color:#e8a84a}.dashboard-encouragement{padding:1rem;background:#7eb8a214;border-radius:12px;font-size:1rem;color:#5c4d3d;text-align:center;border-left:3px solid #7eb8a2}.oral-arithmetic-section{background:#fff;border-radius:16px;border:2px solid #e8e4df;padding:1.5rem;box-shadow:0 2px 8px #5c4d3d0f}.oral-arithmetic-section h2{font-size:1.25rem;color:#5c4d3d;margin:0 0 1rem;font-weight:600}.oral-arithmetic-section .time-input-section,.oral-arithmetic-section .image-upload-section,.oral-arithmetic-section .grade-button{margin-bottom:1rem}.manual-entry-toggle{display:block;width:100%;max-width:480px;margin:.75rem auto 0;padding:.75rem 1.5rem;background:#fff;color:#5c4d3d;border:2px solid #e8e4df;border-radius:10px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s ease}.manual-entry-toggle:hover{background:#f5f3f0;border-color:#d4d0c8}.manual-entry-section{background:#fffaf0;border-radius:16px;border:2px solid #f1d398;padding:1.25rem;margin-top:1rem;box-shadow:0 3px 12px #bf852d1f}.manual-entry-section h3{font-size:1rem;color:#5c4d3d;margin:0 0 .75rem;font-weight:500}.manual-entry-form{display:flex;flex-direction:column;gap:.75rem}.photo-grading-fallback{margin-top:1rem;border-top:1px solid #eee7dc;padding-top:1rem}.photo-fallback-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.85rem 1rem;background:#f8f7f4;color:#6c5d4d;border:1px solid #e4ded5;border-radius:10px;font-size:.95rem;font-weight:600;cursor:pointer}.photo-fallback-toggle:hover{background:#f1eee8}.photo-fallback-panel{margin-top:1rem}.manual-input-row{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}.manual-input-row label{font-size:.95rem;color:#5c4d3d;font-weight:500;min-width:80px}.manual-input{width:100px;padding:.5rem .75rem;border:2px solid #e8e4df;border-radius:8px;font-size:1rem;text-align:center;background:#faf9f7;color:#2d2a26;transition:border-color .2s ease,box-shadow .2s ease}.manual-input:focus{border-color:#7eb8a2;outline:none;box-shadow:0 0 0 3px #7eb8a233}.manual-error{padding:.625rem 1rem;background:linear-gradient(135deg,#fef3ed,#fceee3);border:2px solid #d4764a;border-radius:8px;color:#d4764a;font-size:.9rem;font-weight:500}.manual-confirm-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,#7eb8a2,#6aa88e);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #7eb8a233;margin-top:.5rem}.manual-confirm-button:hover{background:linear-gradient(135deg,#6aa88e,#5a9a80);transform:translateY(-1px);box-shadow:0 4px 10px #7eb8a24d}@media (max-width: 640px){.hero-passbook-section,.progress-dashboard-section,.oral-arithmetic-section{padding:1rem}.balance-value{font-size:1.5rem}.wish-item{flex-direction:column;align-items:flex-start;gap:.5rem}.wish-progress{width:100%;min-width:auto}.wish-form{grid-template-columns:1fr}.progress-bar{width:100%}.redeem-button{width:100%;text-align:center}.dashboard-heading{flex-direction:column;align-items:flex-start}.dashboard-summary-cards{grid-template-columns:1fr}.week-star-map{grid-template-columns:repeat(4,minmax(0,1fr))}.week-star{padding:.55rem .25rem}.summary-value{font-size:1.25rem}.trend-card-header{flex-direction:column;align-items:flex-start}.trend-card-header span{text-align:left}.module-progress-row{grid-template-columns:1fr;gap:.35rem}.manual-entry-toggle{max-width:100%;padding:.625rem 1.25rem;font-size:.9rem}.manual-entry-section{padding:1rem;margin-top:.75rem}.manual-entry-section h3{font-size:.95rem}.manual-input-row{flex-direction:column;align-items:flex-start;gap:.25rem}.manual-input-row label{min-width:auto}.manual-input{width:100%;max-width:200px;padding:.5rem;font-size:.95rem}.manual-confirm-button{padding:.625rem 1.25rem;font-size:.95rem}}
