:root{--teal: #0ea5e9;--teal-dark: #0369a1;--teal-tint: #e0f2fe;--amber: #f59e0b;--bg: #f1f5f9;--surface: #ffffff;--ink: #0f172a;--muted: #64748b;--line: #e2e8f0;--danger: #dc2626;--radius: 14px;--shadow: 0 1px 3px rgba(15, 23, 42, .08), 0 1px 2px rgba(15, 23, 42, .06);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,SF Arabic,Segoe UI,Tahoma,Noto Naskh Arabic,system-ui,sans-serif}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);-webkit-tap-highlight-color:transparent}#root{min-height:100vh}.app{max-width:640px;margin:0 auto;min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.header{position:sticky;top:0;z-index:10;background:var(--teal);color:#fff;padding:14px 18px;display:flex;align-items:center;gap:12px;box-shadow:var(--shadow)}.header .title{font-size:1.15rem;font-weight:700;margin:0}.header-right{margin-inline-start:auto;display:flex;align-items:center;gap:10px}.header .teacher-name{font-size:.9rem;opacity:.9;display:flex;align-items:center;gap:6px}.header .logout{background:#ffffff26;border:none;color:#fff;padding:6px 12px;border-radius:10px;font-size:.82rem;font-weight:600;font-family:inherit;cursor:pointer}.header .logout:active{background:#ffffff47}.sync-pill{border:none;border-radius:999px;padding:4px 11px;font-size:.76rem;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap}.sync-ok{background:#ffffffe6;color:#0369a1}.sync-pending{background:var(--amber);color:#422006}.sync-busy{background:#ffffffe6;color:var(--muted)}.sync-off{background:#ffffff38;color:#fff}.info-box{background:#fffbeb;border:1px solid #fde68a;color:#78350f;border-radius:12px;padding:12px 14px;font-size:.86rem;line-height:1.7;text-align:start;margin-bottom:12px}.welcome-card code{background:#f1f5f9;border-radius:6px;padding:1px 5px;font-size:.85em}.header .back{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;border-radius:10px;font-size:1.2rem;cursor:pointer;display:grid;place-items:center}.header .back:active{background:#ffffff47}.content{padding:18px;flex:1}.breadcrumb{font-size:.85rem;color:var(--muted);margin-bottom:14px}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px;margin-bottom:14px}.section-title{display:flex;align-items:center;justify-content:space-between;margin:4px 0 12px}.section-title h2{font-size:1.05rem;margin:0}.list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.list-item{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer;border:1px solid transparent;transition:border-color .15s}.list-item:active{border-color:var(--teal-tint)}.list-item .primary{font-weight:600}.list-item .secondary{font-size:.85rem;color:var(--muted);margin-top:2px}.list-item .chevron{margin-inline-start:auto;color:var(--muted);font-size:1.1rem}.roster-badge{min-width:34px;height:34px;padding:0 6px;border-radius:10px;background:var(--teal-tint);color:var(--teal-dark);font-weight:700;display:grid;place-items:center;font-size:.9rem}.pill{display:inline-block;padding:2px 10px;border-radius:999px;background:var(--teal-tint);color:var(--teal-dark);font-size:.78rem;font-weight:600}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;border-radius:12px;padding:12px 18px;font-size:.98rem;font-weight:600;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:var(--teal);color:#fff}.btn-primary:active{background:var(--teal-dark)}.btn-primary:disabled{background:#94a3b8;cursor:not-allowed}.btn-ghost{background:var(--surface);color:var(--teal-dark);border:1px solid var(--line)}.btn-block{width:100%}.btn-danger{background:transparent;color:var(--danger);border:1px solid #fecaca}.btn-sm{padding:8px 12px;font-size:.85rem;border-radius:10px}.field{margin-bottom:14px}.field label{display:block;font-size:.9rem;font-weight:600;margin-bottom:6px;color:var(--ink)}.input,.textarea,.select{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:12px;font-size:1rem;font-family:inherit;background:var(--surface);color:var(--ink)}.input:focus,.textarea:focus,.select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-tint)}.textarea{min-height:180px;resize:vertical;line-height:1.9}.hint{font-size:.82rem;color:var(--muted);margin-top:6px}.error{color:var(--danger);font-size:.85rem;margin-top:6px}.empty{text-align:center;padding:40px 20px;color:var(--muted)}.empty .emoji{font-size:2.4rem;margin-bottom:10px}.review-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--line)}.review-row:last-child{border-bottom:none}.review-row .num{min-width:28px;color:var(--muted);font-size:.85rem;text-align:center}.review-row .input{flex:1;padding:8px 12px}.review-row .remove{background:transparent;border:none;color:var(--danger);font-size:1.3rem;cursor:pointer;width:34px;height:34px;border-radius:8px}.review-row .remove:active{background:#fee2e2}.update-banner{position:fixed;top:0;inset-inline:0;z-index:100;background:var(--teal-dark);color:#fff;display:flex;align-items:center;justify-content:center;gap:14px;padding:calc(10px + env(safe-area-inset-top,0px)) 16px 10px;font-size:.9rem;font-weight:600;box-shadow:0 2px 10px #0f172a40;animation:sheet-up .2s ease-out}.update-banner-dismiss{background:transparent;color:#fff;border:none;font-size:1rem;line-height:1;padding:6px 8px;cursor:pointer;opacity:.8;font-family:inherit}.update-banner-dismiss:active{opacity:1}.update-banner-btn{background:#fff;color:var(--teal-dark);border:none;border-radius:999px;padding:6px 16px;font-size:.85rem;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap}.update-banner-btn:active{background:var(--teal-tint)}.version-stamp{margin-top:auto;padding:14px 18px 18px;text-align:center;color:var(--muted);font-size:.72rem;opacity:.7;letter-spacing:.02em}.version-sha{font-family:ui-monospace,SF Mono,Menlo,Consolas,monospace;display:inline-block}.version-stamp-btn{background:transparent;border:none;color:inherit;font:inherit;letter-spacing:inherit;padding:4px 8px;cursor:pointer;border-radius:8px}.version-stamp-btn:active{background:var(--teal-tint)}.version-check-msg{margin-top:6px;font-size:.72rem;color:var(--teal-dark);opacity:.95}.action-bar{display:flex;gap:10px;margin-top:16px}.action-bar .btn{flex:1}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;display:flex;align-items:flex-end;justify-content:center;z-index:50;padding:0}.modal{background:var(--surface);width:100%;max-width:640px;border-radius:20px 20px 0 0;padding:20px;max-height:90vh;overflow-y:auto;animation:sheet-up .2s ease-out}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal h3{margin:0 0 16px;font-size:1.1rem}.welcome{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(160deg,var(--teal) 0%,var(--teal-dark) 100%)}.welcome-card{background:var(--surface);border-radius:20px;padding:28px 24px;width:100%;max-width:400px;box-shadow:0 10px 40px #0003;text-align:center}.welcome-card .logo{font-size:3rem;margin-bottom:8px}.welcome-card h1{margin:0 0 4px;font-size:1.5rem;color:var(--teal-dark)}.welcome-card p{color:var(--muted);margin:0 0 22px;font-size:.95rem}.grade-input{width:90px;text-align:center}.grade-value{font-weight:700;color:var(--teal-dark)}.grade-max{color:var(--muted);font-size:.85rem}.scanner-frame{position:relative;width:100%;aspect-ratio:1 / 1;max-height:70vh;background:#0f172a;border-radius:var(--radius);overflow:hidden;display:grid;place-items:center}.scanner-video{width:100%;height:100%;object-fit:cover;display:block}.scanner-reticle{position:absolute;top:18%;right:18%;bottom:18%;left:18%;border:3px solid rgba(255,255,255,.9);border-radius:18px;box-shadow:0 0 0 100vmax #0f172a59;pointer-events:none}.scanner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-content:center;gap:8px;text-align:center;padding:24px;color:#fff;background:#0f172ab8;font-size:.95rem;line-height:1.7}.scanner-overlay p{margin:0;max-width:320px}.scanner-overlay .emoji{font-size:2.4rem}.scanner-overlay-error{color:#fecaca}.scanner-overlay-error .emoji{color:#fff}.result-accept{background:linear-gradient(160deg,var(--teal) 0%,var(--teal-dark) 100%);color:#fff;text-align:center}.composite-hero{padding:12px 8px}.composite-label{font-size:.95rem;opacity:.9}.composite-value{font-size:4rem;font-weight:800;line-height:1.1;margin:4px 0}.composite-formula{font-size:.9rem;opacity:.85;direction:ltr}.detail-list{margin:0;padding:0}.detail-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 2px;border-bottom:1px solid var(--line)}.detail-row:last-child{border-bottom:none}.detail-row dt{color:var(--muted);font-size:.9rem}.detail-row dd{margin:0;font-weight:700;color:var(--ink);text-align:end;word-break:break-word}.scan-classbar{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--teal-tint);color:var(--teal-dark);border-radius:12px;padding:8px 12px;font-size:.88rem;margin-bottom:12px}.scan-classbar strong{font-weight:700}.scan-progress{background:var(--surface);border-radius:12px;box-shadow:var(--shadow);padding:10px 14px;margin-bottom:12px}.scan-progress-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.scan-progress-count{font-size:1rem;color:var(--muted)}.scan-progress-count strong{font-size:1.5rem;font-weight:800;color:var(--teal-dark)}.scan-progress-label{font-size:.85rem;color:var(--muted)}.scan-progress-head .btn{margin-inline-start:auto}.scan-progress-unscanned{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}.scan-unscanned-chip{display:inline-flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:4px 12px;font-size:.85rem;color:var(--ink)}.scan-unscanned-chip .roster{background:var(--teal-tint);color:var(--teal-dark);font-weight:700;border-radius:999px;padding:1px 8px;font-size:.78rem}.scan-confirm{border-radius:var(--radius);padding:16px;margin-top:12px;box-shadow:var(--shadow);animation:sheet-up .16s ease-out}.scan-confirm-idle{background:var(--surface);color:var(--muted);text-align:center;font-size:.9rem}.scan-confirm-idle p{margin:0}.scan-confirm-ok{background:linear-gradient(160deg,#16a34a,#15803d);color:#fff}.scan-confirm-ok.is-updated{background:linear-gradient(160deg,var(--teal) 0%,var(--teal-dark) 100%)}.scan-confirm-top{display:flex;align-items:center;gap:12px}.scan-confirm-roster{min-width:46px;height:46px;padding:0 8px;border-radius:12px;background:#ffffff38;color:#fff;font-weight:800;font-size:1.15rem;display:grid;place-items:center}.scan-confirm-name{flex:1;font-size:1.5rem;font-weight:800;line-height:1.25}.scan-confirm-status{align-self:flex-start;background:#ffffff38;border-radius:999px;padding:4px 12px;font-size:.85rem;font-weight:700;white-space:nowrap}.scan-confirm-score{display:flex;align-items:baseline;gap:12px;margin-top:14px}.scan-confirm-composite{font-size:3.4rem;font-weight:800;line-height:1}.scan-confirm-cm{font-size:1rem;font-weight:600;opacity:.9}.scan-confirm-la{margin-top:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,.25);font-size:.95rem;font-weight:600;opacity:.92}.scan-confirm-error{background:#fef2f2;border:1px solid #fecaca;text-align:center}.scan-confirm-error-icon{font-size:2.4rem;line-height:1}.scan-confirm-error-text{font-size:1.3rem;font-weight:800;color:#b91c1c;margin-top:6px}.scan-confirm-error .hint{margin-top:6px}.scan-confirm-error .btn{margin-top:12px}.scan-decision{margin-top:12px;border:2px solid var(--amber)}.scan-decision h3{margin:0 0 8px;font-size:1.02rem}.scan-warn-line{background:#fffbeb;border:1px solid #fde68a;color:#92400e;border-radius:10px;padding:10px 12px;margin:0 0 12px;font-size:.88rem;line-height:1.7}.scan-decision-danger{border-color:var(--danger)}.scan-decision-danger h3{color:var(--danger)}.scan-warn-line-danger{background:#fef2f2;border-color:#fecaca;color:#b91c1c}.scan-composite-badge{min-width:42px;padding:4px 10px;border-radius:999px;background:var(--teal);color:#fff;font-weight:800;font-size:.95rem;text-align:center}.scan-updated-tag{color:var(--amber);font-size:.8rem;font-weight:700}.record-summary{display:flex;gap:10px;margin-bottom:14px}.record-stat{flex:1;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:12px 8px;text-align:center;display:flex;flex-direction:column;gap:2px}.record-stat-num{font-size:1.5rem;font-weight:800;color:var(--teal-dark);line-height:1.1}.record-stat-ok{color:#166534}.record-stat-muted{color:var(--muted)}.record-stat-label{font-size:.8rem;color:var(--muted)}.record-table-wrap{padding:4px;overflow-x:auto}.record-table{width:100%;border-collapse:collapse;font-size:.9rem}.record-table th,.record-table td{padding:10px 8px;text-align:start;border-bottom:1px solid var(--line);white-space:nowrap}.record-table thead th{color:var(--muted);font-size:.8rem;font-weight:700;position:sticky;top:0;background:var(--surface)}.record-table tbody tr{cursor:pointer}.record-table tbody tr:last-child td{border-bottom:none}.record-table tbody tr.is-selected,.record-table tbody tr:active{background:var(--teal-tint)}.record-table .col-roster{width:34px;color:var(--muted);text-align:center}.record-table .col-name{font-weight:600;white-space:normal;min-width:90px}.record-table .col-score{text-align:center}.record-table .col-lesson{color:var(--ink)}.record-table .col-scan{color:var(--muted);font-size:.82rem}.record-score-badge{display:inline-block;min-width:36px;padding:3px 9px;border-radius:999px;background:var(--teal);color:#fff;font-weight:800;font-size:.88rem;text-align:center}.record-dash{color:#cbd5e1;font-weight:700}.result-reject{text-align:center}.result-reject .result-icon{font-size:2.8rem;margin-bottom:6px}.result-reject h3{margin:0 0 8px;color:var(--danger)}.result-reason{color:var(--ink);background:#fef2f2;border:1px solid #fecaca;border-radius:12px;padding:12px 14px;margin:0 0 16px;font-size:.95rem;line-height:1.7}
