*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #4f6ef7;--primary-dark: #3b57d9;--primary-light: #eef1fe;--success: #22c55e;--danger: #ef4444;--text: #1a1a2e;--text-secondary: #6b7280;--border: #e5e7eb;--bg: #f5f6fa;--card: #ffffff;--radius: 12px;--safe-bottom: env(safe-area-inset-bottom, 0px)}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh;padding-bottom:calc(60px + var(--safe-bottom))}input,textarea,button{font-family:inherit;font-size:inherit}textarea{resize:vertical;min-height:80px}button{cursor:pointer;border:none;outline:none}.app{max-width:480px;margin:0 auto;min-height:100vh}.header{background:linear-gradient(135deg,var(--primary),#7c3aed);color:#fff;padding:20px 16px 24px;text-align:center}.header h1{font-size:1.25rem;font-weight:600}.header p{font-size:.8125rem;opacity:.85;margin-top:4px}.tab-bar{position:fixed;bottom:0;left:0;right:0;display:flex;background:var(--card);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);z-index:100}.tab-bar button{flex:1;padding:10px 0;background:none;color:var(--text-secondary);font-size:.75rem;display:flex;flex-direction:column;align-items:center;gap:2px;transition:color .2s}.tab-bar button.active{color:var(--primary)}.tab-bar .tab-icon{font-size:1.25rem}.content{padding:12px 16px 16px}.panel{animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.card-compact .field-row:last-of-type{margin-bottom:0}.card-highlight{background:linear-gradient(135deg,#f8f9ff,#fff);border:1px solid #e8ecff}.field-row{display:flex;align-items:center;width:100%;gap:8px;padding:12px 0;border:none;border-bottom:1px solid var(--border);background:none;text-align:left;cursor:pointer;transition:background .15s}.field-row:last-child{border-bottom:none}.field-row:active{background:#f9fafb}.field-row.filled .field-row-value{color:var(--text)}.field-row.required .field-row-value{color:var(--danger)}.field-row-label{flex:0 0 72px;font-size:.8125rem;color:var(--text-secondary);font-weight:500}.field-row-value{flex:1;font-size:.875rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.field-row-arrow{flex-shrink:0;color:#c4c9d4;font-size:1.125rem;line-height:1}.sheet-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;display:flex;align-items:flex-end;justify-content:center}.sheet-mask{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000073;animation:maskIn .25s ease}@keyframes maskIn{0%{opacity:0}to{opacity:1}}.sheet-panel{position:relative;width:100%;max-width:480px;max-height:78vh;background:#fff;border-radius:16px 16px 0 0;padding:8px 16px calc(16px + var(--safe-bottom));animation:sheetUp .28s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{width:36px;height:4px;background:#e0e0e0;border-radius:2px;margin:4px auto 12px}.sheet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.sheet-header h3{font-size:1rem;font-weight:600}.sheet-close{background:#f3f4f6;border:none;width:28px;height:28px;border-radius:50%;font-size:1.25rem;line-height:1;color:var(--text-secondary);cursor:pointer}.sheet-body{overflow-y:auto;flex:1;padding-bottom:8px}.sheet-input{width:100%;margin-top:12px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fafafa;font-size:.875rem}.sheet-confirm{margin-top:12px;flex-shrink:0}.student-head{display:flex;align-items:center;width:100%;gap:8px;padding:0;border:none;background:none;cursor:pointer;text-align:left}.student-name{font-weight:600;font-size:.9375rem;flex:1}.expand-icon{color:var(--text-secondary);font-size:.875rem;padding:0 4px}.student-body{margin-top:4px;padding-top:4px;border-top:1px solid var(--border)}.student-card.collapsed{padding-bottom:12px}.absent-hint{margin-top:8px;padding-top:8px;border-top:1px dashed var(--border)}.result-page .result-card{margin-top:0}.result-hint{font-size:.8125rem;color:var(--text-secondary);margin:-4px 0 12px}.field-tag{display:inline-block;margin-left:4px;padding:1px 5px;font-size:.625rem;font-weight:500;color:var(--primary);background:var(--primary-light);border-radius:4px;vertical-align:middle}.date-trigger{display:flex;align-items:center;width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fafafa;cursor:pointer;text-align:left;font-size:.9375rem}.date-trigger .placeholder{color:var(--text-secondary)}.date-trigger:active{border-color:var(--primary);background:#fff}.date-pickers{display:flex;gap:8px;margin-bottom:8px}.date-select{flex:1;padding:10px 8px;border:1px solid var(--border);border-radius:8px;background:#fafafa;font-size:.9375rem;text-align:center}.sheet-panel-sm{max-height:50vh}.date-field{margin-bottom:14px}.card{background:var(--card);border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:0 1px 3px #0000000f}.card-title{font-size:.9375rem;font-weight:600;margin-bottom:12px;display:flex;align-items:center;gap:6px}.student-section-head{display:flex;align-items:center;gap:6px;margin-bottom:8px;font-size:.8125rem;font-weight:600;color:var(--text-secondary)}.form-group{margin-bottom:14px}.form-group label{display:block;font-size:.8125rem;color:var(--text-secondary);margin-bottom:6px}.form-group label .required{color:var(--danger)}.form-group input,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fafafa;transition:border-color .2s;-webkit-appearance:none}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);background:#fff}.class-type-list{display:flex;gap:10px}.class-type-item{flex:1;padding:12px;border:2px solid var(--border);border-radius:10px;text-align:center;font-weight:600;font-size:.9375rem;cursor:pointer;background:#fafafa;transition:all .2s}.class-type-item.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.student-list{display:flex;flex-wrap:wrap;gap:8px}.student-chip{display:inline-flex;align-items:center;gap:4px;padding:6px 10px;background:var(--primary-light);border-radius:20px;font-size:.8125rem;cursor:pointer;transition:background .2s}.student-chip:active{background:#dce3fc}.student-chip .grade{color:var(--text-secondary);font-size:.75rem}.student-chip .grade:before{content:"·";margin-right:4px}.chip-remove{background:none;border:none;color:var(--text-secondary);font-size:1rem;line-height:1;padding:0 0 0 4px;cursor:pointer}.chip-remove:hover{color:var(--danger)}.btn-sm{padding:8px 14px;font-size:.8125rem;width:auto;display:inline-block}.add-row{display:flex;gap:8px}.add-row input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fafafa}.add-row .btn,.add-row .btn-sm,.add-row .btn-inline{flex:0 0 auto}.btn-inline{display:inline-flex;align-items:center;justify-content:center;width:auto;min-width:52px;padding:10px 12px;border-radius:8px;font-size:.8125rem;font-weight:600;background:#fff;color:var(--primary);border:1px solid var(--primary);white-space:nowrap;cursor:pointer}.btn-inline:active{background:var(--primary-light)}.student-chip.static{cursor:default}.chip-count{font-size:.6875rem;opacity:.75;margin-left:2px}.student-chip.active .chip-count{opacity:.9}.row-between{justify-content:space-between}.link-btn{background:none;border:none;color:var(--primary);font-size:.8125rem;cursor:pointer;padding:0}.hint-text{font-size:.8125rem;color:var(--text-secondary)}.progress-text{font-size:.75rem;color:var(--text-secondary);font-weight:400}.student-chip.active{background:var(--primary);color:#fff}.option-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.option-chip{padding:6px 10px;border:1px solid var(--border);border-radius:16px;background:#fafafa;font-size:.75rem;color:var(--text);transition:all .15s}.option-chip.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary);font-weight:600}.selected-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.selected-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:var(--primary-light);border-radius:12px;font-size:.75rem;color:var(--primary)}.selected-tag button{background:none;border:none;color:var(--text-secondary);font-size:.875rem;line-height:1;padding:0}.check-list{display:flex;flex-wrap:wrap;gap:10px}.check-item{display:flex;align-items:center;gap:6px;font-size:.875rem;cursor:pointer}.status-btns{display:flex;gap:6px}.status-btn{padding:4px 10px;border-radius:14px;border:1px solid var(--border);background:#fafafa;font-size:.75rem;color:var(--text-secondary)}.status-btn.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary);font-weight:600}.student-card.absent{opacity:.75;background:#f9f9f9}.result-card{margin-top:12px}.result-box{width:100%;min-height:160px;padding:14px;border:1px solid var(--border);border-radius:10px;font-size:.9375rem;line-height:1.8;background:#fafafa}.btn{display:block;width:100%;padding:14px;border-radius:10px;font-size:1rem;font-weight:600;text-align:center;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:active{background:var(--primary-dark)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-outline{background:#fff;color:var(--primary);border:1px solid var(--primary)}.btn-outline:active{background:var(--primary-light)}.btn-group{display:flex;gap:10px;margin-top:12px}.btn-group .btn{flex:1}.result-meta{display:none}.empty-state{text-align:center;padding:40px 20px;color:var(--text-secondary)}.empty-state .icon{font-size:2.5rem;margin-bottom:8px}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:24px}.login-card{width:100%;max-width:360px;background:var(--card);border-radius:16px;padding:32px 24px;box-shadow:0 4px 20px #00000014}.login-card h2{text-align:center;margin-bottom:8px}.login-card .subtitle{text-align:center;color:var(--text-secondary);font-size:.875rem;margin-bottom:24px}.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000bf;color:#fff;padding:12px 24px;border-radius:8px;font-size:.875rem;z-index:999;pointer-events:none;animation:fadeInOut 2s ease}@keyframes fadeInOut{0%{opacity:0}15%{opacity:1}85%{opacity:1}to{opacity:0}}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#ffffffb3;display:flex;align-items:center;justify-content:center;z-index:200}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.top-tabs{display:flex;border-bottom:1px solid var(--border);background:var(--card);position:sticky;top:0;z-index:50}.top-tabs button{flex:1;padding:12px 0;background:none;border:none;font-size:.875rem;font-weight:500;color:var(--text-secondary);cursor:pointer;position:relative;transition:color .2s}.top-tabs button.active{color:var(--primary);font-weight:600}.top-tabs button.active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:32px;height:3px;background:var(--primary);border-radius:2px}.form-row{display:flex;gap:10px}.form-row .form-group{flex:1}.time-row{display:flex;align-items:center;gap:8px}.time-row .time-sep{color:var(--text-secondary);font-size:.875rem}.time-row select{flex:1;padding:10px 8px;border:1px solid var(--border);border-radius:8px;background:#fafafa;font-size:.9375rem;text-align:center}.time-duration{font-size:.75rem;color:var(--text-secondary);margin-top:4px}.feedback-toggle{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--card);border-radius:var(--radius);margin-bottom:12px;box-shadow:0 1px 3px #0000000f;cursor:pointer;-webkit-user-select:none;user-select:none}.feedback-toggle input[type=checkbox]{width:20px;height:20px;accent-color:var(--primary);cursor:pointer}.feedback-toggle .toggle-label{font-size:.9375rem;font-weight:500;flex:1}.search-bar{margin-bottom:12px}.search-bar input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fafafa;font-size:.875rem}.filter-row{display:flex;gap:8px;margin-bottom:12px}.filter-row select{flex:1;padding:8px 6px;border:1px solid var(--border);border-radius:8px;background:#fafafa;font-size:.8125rem;text-align:center}.records-count{font-size:.8125rem;color:var(--text-secondary);margin-bottom:12px}.date-group{margin-bottom:16px}.date-group-title{font-size:.8125rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px;padding-left:4px}.record-card{background:var(--card);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;box-shadow:0 1px 3px #0000000f}.record-card-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.record-subject-icon{font-size:1.25rem}.record-student{font-weight:600;font-size:.9375rem}.record-feedback-badge{font-size:.6875rem;padding:2px 6px;border-radius:4px;background:#dcfce7;color:#16a34a;margin-left:auto}.record-meta{font-size:.8125rem;color:var(--text-secondary);line-height:1.6}.record-content-preview{font-size:.8125rem;color:var(--text);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.record-actions{display:flex;gap:12px;margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}.record-actions button{background:none;border:none;font-size:.8125rem;cursor:pointer;padding:4px 0}.record-actions .action-detail{color:var(--primary)}.record-actions .action-delete{color:var(--danger)}.record-detail{margin-top:10px;padding-top:10px;border-top:1px dashed var(--border)}.record-detail-section{margin-bottom:10px}.record-detail-section .detail-label{font-size:.75rem;color:var(--text-secondary);margin-bottom:4px;font-weight:500}.record-detail-section .detail-text{font-size:.875rem;line-height:1.6}.record-detail-section .feedback-text{font-size:.8125rem;line-height:1.8;background:#fafafa;padding:12px;border-radius:8px;white-space:pre-wrap;max-height:200px;overflow-y:auto}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.empty-state .empty-icon{font-size:3rem;margin-bottom:12px}.empty-state p{font-size:.875rem}.feedback-section{margin-top:0}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:28px}.tab-bar.three-tabs button{font-size:.6875rem}.inline-tabs{display:flex;gap:10px;margin-bottom:12px}.inline-tabs button{flex:1;padding:12px 0;border:2px solid var(--border);background:var(--card);font-size:.9375rem;font-weight:600;color:var(--text-secondary);border-radius:12px;transition:all .2s;cursor:pointer;box-shadow:0 1px 3px #0000000a}.inline-tabs button.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}.manage-card{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border)}.manage-card:last-child{border-bottom:none}.manage-card-info{flex:1;min-width:0}.manage-card-name{font-size:.9375rem;font-weight:600;margin-bottom:2px}.manage-card-meta{font-size:.75rem;color:var(--text-secondary)}.manage-card-actions{display:flex;gap:12px;flex-shrink:0;margin-left:12px}.action-link{background:none;border:none;font-size:.8125rem;cursor:pointer;color:var(--primary);padding:4px 0;white-space:nowrap}.action-link.danger{color:var(--danger)}.modal-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;display:flex;align-items:center;justify-content:center}.modal-mask{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;animation:maskIn .2s ease}.modal-box{position:relative;width:calc(100% - 48px);max-width:340px;background:#fff;border-radius:16px;padding:24px 20px 20px;animation:modalIn .25s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-title{font-size:1.0625rem;font-weight:600;text-align:center;margin-bottom:8px}.modal-message{font-size:.875rem;color:var(--text-secondary);text-align:center;line-height:1.6;margin-bottom:20px;white-space:pre-wrap}.modal-actions{display:flex;gap:10px}.modal-actions .btn{flex:1;padding:12px;font-size:.9375rem}.btn-danger{display:block;width:100%;padding:14px;border-radius:10px;font-size:1rem;font-weight:600;text-align:center;transition:all .2s;background:var(--danger);color:#fff;border:none;cursor:pointer}.btn-danger:active{background:#dc2626}.select-with-add{display:flex;gap:6px}.select-with-add input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fafafa}.select-with-add .btn-add-sm{width:42px;height:42px;border:1px solid var(--primary);border-radius:8px;background:#fff;color:var(--primary);font-size:1.25rem;font-weight:600;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}.select-with-add .btn-add-sm:active{background:var(--primary-light)}.modal-sm{max-width:300px}.session-count-row{display:flex;align-items:center;gap:8px}.session-btn{width:36px;height:36px;border:2px solid var(--primary);border-radius:50%;background:#fff;color:var(--primary);font-size:1.25rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.session-btn:active{background:var(--primary-light)}.session-count-num{font-size:1.25rem;font-weight:700;color:var(--text);min-width:28px;text-align:center}.session-label{font-size:.9375rem;color:var(--text-secondary)}.date-list{display:flex;flex-direction:column;gap:8px}.date-item{display:flex;align-items:center;gap:8px}.date-item-label{font-size:.8125rem;color:var(--text-secondary);font-weight:500;flex:0 0 42px}.date-item input[type=date]{flex:1;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:#fafafa;font-size:.875rem}.stats-card{text-align:center}.ring-chart-wrap{display:flex;justify-content:center;margin:8px 0 16px}.ring-chart{width:130px;height:130px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative}.ring-center{width:86px;height:86px;border-radius:50%;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 1px 4px #00000014}.ring-total{font-size:1.5rem;font-weight:700;color:var(--text);line-height:1}.ring-label{font-size:.6875rem;color:var(--text-secondary);margin-top:2px}.chart-legend{display:flex;justify-content:center;gap:24px;margin-bottom:14px}.legend-item{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--text-secondary)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-dot.one{background:var(--primary)}.legend-dot.class{background:#a78bfa}.subject-dist{border-top:1px solid var(--border);padding-top:12px;margin-bottom:4px}.dist-title{font-size:.75rem;color:var(--text-secondary);margin-bottom:8px}.dist-tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}.dist-tag{padding:4px 10px;background:var(--primary-light);border-radius:12px;font-size:.75rem;color:var(--primary);font-weight:500}.month-detail-list{margin-top:10px;text-align:left}.month-record-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.8125rem}.month-record-item:last-child{border-bottom:none}.mri-date{color:var(--text-secondary);flex-shrink:0}.mri-subject{flex-shrink:0}.mri-name{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mri-sessions{font-size:.6875rem;color:var(--primary);font-weight:600}.mri-fb{flex-shrink:0;font-size:.75rem}.month-nav-btn{width:32px;height:32px;border:1px solid var(--border);border-radius:50%;background:#fff;font-size:.875rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .15s}.month-nav-btn:active{background:#f3f4f6;color:var(--primary)}.month-nav-btn.disabled{opacity:.3;cursor:not-allowed}
