.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}.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}.app-main{display:flex;flex-direction:column;gap:1.5rem}.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-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-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}.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}}@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{padding:.45rem .75rem;border-radius:999px;background:#fff7df;color:#c9861d;font-size:.82rem;font-weight:700;white-space:nowrap}.dashboard-summary-cards{display:grid;grid-template-columns:repeat(2,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}.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}.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-row{display:grid;grid-template-columns:90px 1fr;align-items:center;gap:.75rem}.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)}.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:#fff;border-radius:16px;border:2px solid #e8e4df;padding:1.25rem;margin-top:1rem;box-shadow:0 2px 8px #5c4d3d0f}.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}.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}}
