*{box-sizing:border-box;margin:0;padding:0}body{color:#1a1a2e;background:#f5f6fa;font-family:system-ui,sans-serif;font-size:14px}.topbar{z-index:100;background:#fff;border-bottom:1px solid #e2e4ed;justify-content:space-between;align-items:center;padding:10px 20px;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:12px;display:flex}.logo{font-size:15px;font-weight:600}.role-toggle{border:1px solid #d1d5e0;border-radius:8px;display:flex;overflow:hidden}.role-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;padding:5px 14px;font-size:13px}.role-btn.active{color:#fff;background:#2d3a7c;font-weight:500}.main{min-height:calc(100vh - 49px);display:flex}.sidebar{background:#fff;border-right:1px solid #e2e4ed;flex-shrink:0;width:190px;padding:10px 0;overflow-y:auto}.nav-item{cursor:pointer;color:#6b7280;-webkit-user-select:none;user-select:none;border-left:2px solid #0000;padding:8px 16px;font-size:13px}.nav-item:hover{color:#1a1a2e;background:#f5f6fa}.nav-item.active{color:#2d3a7c;background:#eef0f9;border-left:2px solid #2d3a7c;font-weight:500}.nav-section{text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;padding:10px 16px 3px;font-size:10px;font-weight:600}.content{background:#f5f6fa;flex:1;min-width:0;padding:20px;overflow-y:auto}.page-title{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;font-size:16px;font-weight:600;display:flex}.btn{cursor:pointer;color:#1a1a2e;background:#fff;border:1px solid #d1d5e0;border-radius:7px;align-items:center;gap:5px;padding:7px 14px;font-family:inherit;font-size:13px;display:inline-flex}.btn:hover{background:#f5f6fa}.btn-primary{color:#fff;background:#2d3a7c;border-color:#2d3a7c}.btn-primary:hover{background:#1e2857}.btn-sm{padding:4px 10px;font-size:12px}.btn-danger{color:#991b1b;background:#fee2e2;border-color:#fca5a5}.btn-success{color:#065f46;background:#d1fae5;border-color:#6ee7b7}.card{background:#fff;border:1px solid #e2e4ed;border-radius:10px;margin-bottom:12px;padding:16px}.card-click{cursor:pointer;transition:border-color .15s,box-shadow .15s}.card-click:hover{border-color:#2d3a7c;box-shadow:0 2px 8px #2d3a7c1a}.badge{border-radius:20px;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.b-open{color:#92400e;background:#fef3c7}.b-review{color:#1e40af;background:#dbeafe}.b-closed{color:#065f46;background:#d1fae5}.b-inf{color:#991b1b;background:#fee2e2}.b-admin{color:#5b21b6;background:#ede9fe}.b-covered{color:#065f46;background:#d1fae5}.b-uncovered{color:#991b1b;background:#fee2e2}.b-partial{color:#92400e;background:#fef3c7}.b-sick{color:#991b1b;background:#fee2e2}.b-pto{color:#1e40af;background:#dbeafe}.b-bereavement{color:#5b21b6;background:#ede9fe}.b-unexcused{color:#92400e;background:#fef3c7}.fg{margin-bottom:12px}.fg label{color:#6b7280;margin-bottom:4px;font-size:12px;font-weight:500;display:block}.fg input,.fg select,.fg textarea{color:#1a1a2e;background:#fff;border:1px solid #d1d5e0;border-radius:7px;width:100%;padding:7px 10px;font-family:inherit;font-size:13px}.fg textarea{resize:vertical;min-height:60px}.char-hint{text-align:right;color:#9ca3af;margin-top:3px;font-size:11px}.char-warn{color:#b45309}.char-over{color:#991b1b}.overlay{z-index:200;background:#00000073;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:#fff;border:1px solid #e2e4ed;border-radius:12px;width:100%;max-width:560px;max-height:92vh;padding:24px;overflow-y:auto}.modal-hdr{justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex}.modal-hdr h3{font-size:15px;font-weight:600}.modal-close{cursor:pointer;color:#9ca3af;background:0 0;border:none;padding:0;font-size:20px;line-height:1}.divider{background:#e2e4ed;height:1px;margin:14px 0}.dl{gap:8px;margin-bottom:5px;font-size:12px;display:flex}.dl dt{color:#6b7280;flex-shrink:0;width:110px;font-weight:500}.email-box{color:#6b7280;white-space:pre-wrap;background:#f5f6fa;border:1px solid #e2e4ed;border-radius:8px;padding:12px;font-size:12px;line-height:1.7}.email-box strong{color:#1a1a2e}.stats-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;display:grid}.stat-card{background:#fff;border:1px solid #e2e4ed;border-radius:10px;padding:14px}.stat-label{color:#6b7280;margin-bottom:4px;font-size:12px}.stat-val{font-size:26px;font-weight:600}.row-flex{border-bottom:1px solid #f0f0f5;align-items:center;gap:10px;padding:10px 0;display:flex}.row-flex:last-child{border-bottom:none}.avatar{color:#2d3a7c;background:#eef0f9;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:11px;font-weight:600;display:flex}.avatar-alert{color:#991b1b;background:#fee2e2}.empty{color:#9ca3af;text-align:center;padding:32px;font-size:13px}.expand-btn{cursor:pointer;color:#2d3a7c;background:0 0;border:none;padding:0;font-family:inherit;font-size:12px;text-decoration:underline}.student-alert{color:#991b1b;font-weight:700}.alert-tag{color:#991b1b;vertical-align:middle;background:#fee2e2;border:1px solid #fca5a5;border-radius:20px;align-items:center;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-flex}.tab-row{border-bottom:1px solid #e2e4ed;flex-wrap:wrap;margin-bottom:16px;display:flex}.tab-item{cursor:pointer;color:#6b7280;white-space:nowrap;border-bottom:2px solid #0000;margin-bottom:-1px;padding:8px 14px;font-size:13px}.tab-item.active{color:#2d3a7c;border-bottom:2px solid #2d3a7c;font-weight:500}.abs-bar-wrap{align-items:center;gap:8px;margin:4px 0;display:flex}.abs-bar-track{background:#f0f2f8;border-radius:7px;flex:1;height:14px;overflow:hidden}.abs-bar-fill{border-radius:7px;height:100%;transition:width .3s}.abs-bar-fill.purple{background:#7c3aed}.abs-bar-fill.yellow{background:#f59e0b}.abs-bar-fill.red{background:#dc2626}.abs-bar-label{text-align:right;min-width:32px;font-size:11px;font-weight:600}.abs-cat-row{flex-wrap:wrap;gap:6px;margin-top:4px;display:flex}.abs-cat-pill{border-radius:20px;padding:1px 7px;font-size:10px;font-weight:500}.period-row{border-bottom:1px solid #f0f0f5;justify-content:space-between;align-items:center;gap:8px;padding:8px 0;display:flex}.period-row:last-child{border-bottom:none}.period-info{flex:1;min-width:0}.period-time{color:#9ca3af;font-size:11px}.period-subject{font-size:13px;font-weight:500}.period-role{color:#6b7280;margin-top:1px;font-size:11px}.sub-assigned{color:#065f46;font-size:12px;font-weight:500}.analytics-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px;display:grid}.analytics-card{background:#fff;border:1px solid #e2e4ed;border-radius:10px;padding:16px}.analytics-card.full{grid-column:1/-1}.analytics-title{margin-bottom:14px;font-size:13px;font-weight:600}.analytics-filter{gap:8px;margin-bottom:16px;display:flex}.filter-btn{cursor:pointer;color:#6b7280;background:#fff;border:1px solid #d1d5e0;border-radius:20px;padding:4px 12px;font-family:inherit;font-size:12px}.filter-btn.active{color:#fff;background:#2d3a7c;border-color:#2d3a7c}.bar-wrap{flex-direction:column;gap:6px;display:flex}.bar-row{align-items:center;gap:8px;font-size:12px;display:flex}.bar-label{color:#6b7280;text-align:right;white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;width:130px;overflow:hidden}.bar-track{background:#f0f2f8;border-radius:4px;flex:1;height:18px;overflow:hidden}.bar-fill{background:#2d3a7c;border-radius:4px;height:100%}.bar-fill-red{background:#dc2626}.bar-val{flex-shrink:0;width:28px;font-size:12px;font-weight:600}.history-layout{background:#fff;border:1px solid #e2e4ed;border-radius:10px;min-height:500px;display:flex;overflow:hidden}.week-sidebar{border-right:1px solid #e2e4ed;flex-shrink:0;width:200px;max-height:560px;overflow-y:auto}.week-group-label{text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;z-index:1;background:#f9fafc;border-bottom:1px solid #f0f0f5;padding:10px 12px 4px;font-size:10px;font-weight:600;position:sticky;top:0}.week-item{cursor:pointer;color:#6b7280;border-bottom:1px solid #f5f5f8;padding:9px 12px;font-size:12px}.week-item:hover{background:#f5f6fa}.week-item.active{color:#2d3a7c;background:#eef0f9;border-left:3px solid #2d3a7c;font-weight:600}.week-item.has-data{color:#1a1a2e;font-weight:500}.week-item.future{color:#c4c8d8}.wk-dot{vertical-align:middle;background:#2d3a7c;border-radius:50%;width:6px;height:6px;margin-left:4px;display:inline-block}.week-content{flex:1;max-height:560px;padding:20px;overflow-y:auto}.week-tabs{border:1px solid #e2e4ed;border-radius:7px;width:fit-content;margin-bottom:16px;display:flex;overflow:hidden}.week-tab{cursor:pointer;color:#6b7280;background:#fff;border:none;padding:5px 14px;font-family:inherit;font-size:12px}.week-tab.active{color:#fff;background:#2d3a7c;font-weight:500}.summary-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px;display:grid}.summary-box{text-align:center;background:#f9fafc;border:1px solid #e8eaf0;border-radius:8px;padding:12px}.summary-box .val{color:#2d3a7c;font-size:22px;font-weight:700}.summary-box .lbl{color:#9ca3af;margin-top:2px;font-size:11px}select{appearance:auto}.toast{color:#fff;z-index:9999;border-radius:10px;padding:12px 18px;font-size:13px;animation:.2s slideUp;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 16px #0003}.toast.success{background:#065f46;border-left:4px solid #10b981}.toast.error{background:#991b1b;border-left:4px solid #ef4444}.toast.info{background:#1e3a8a;border-left:4px solid #3b82f6}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
