*{box-sizing:border-box}body{color:#333;-webkit-font-smoothing:antialiased;background:#f5f6f8;margin:0;font-family:system-ui,Segoe UI,Roboto,sans-serif;font-size:16px}#root{flex-direction:column;min-height:100vh;display:flex}.app-header{color:#fff;background:#2f5496;justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.app-title{font-size:18px;font-weight:600}.header-right{align-items:center;gap:16px;display:flex}.username{opacity:.8;font-size:14px}.logout-btn{color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #ffffff4d;border-radius:4px;padding:6px 14px;font-size:14px}.logout-btn:hover{background:#ffffff40}.app-main{box-sizing:border-box;width:100%;max-width:1200px;margin:0 auto;padding:24px}.login-container{justify-content:center;align-items:center;min-height:60vh;display:flex}.login-card{background:#fff;border:1px solid #e5e4e7;border-radius:8px;width:360px;padding:40px;box-shadow:0 2px 8px #00000014}.login-card h1{text-align:center;margin:0 0 24px;font-size:24px}.login-card form{flex-direction:column;gap:16px;display:flex}.login-card label{color:#333;text-align:left;flex-direction:column;gap:4px;font-size:14px;font-weight:500;display:flex}.login-card input{border:1px solid #ddd;border-radius:4px;padding:10px 12px;font-size:16px}.login-card input:focus{border-color:#0000;outline:2px solid #2f5496}.login-card button{color:#fff;cursor:pointer;background:#2f5496;border:none;border-radius:4px;margin-top:8px;padding:12px;font-size:16px}.login-card button:hover{background:#1e3a6e}.login-card button:disabled{opacity:.6;cursor:not-allowed}.error{color:#c00;background:#ffc7ce;border-radius:4px;padding:8px 12px;font-size:14px}.loading{text-align:center;color:#666;padding:40px}.dashboard{text-align:left}.dashboard h1{margin:0 0 8px;font-size:28px}.form-group{margin:16px 0}.form-group label{color:#333;margin-bottom:6px;font-size:14px;font-weight:500;display:block}.form-group select{background:#fff;border:1px solid #ddd;border-radius:4px;width:100%;max-width:500px;padding:10px 12px;font-size:15px}.primary-btn{color:#fff;cursor:pointer;background:#2f5496;border:none;border-radius:4px;margin-top:8px;padding:12px 24px;font-size:16px}.primary-btn:hover{background:#1e3a6e}.report-history{margin-top:32px}.report-history h2{margin:0 0 12px;font-size:18px}.report-history table{max-width:600px}.report-history button{color:#2f5496;cursor:pointer;background:#fff;border:1px solid #2f5496;border-radius:4px;padding:4px 12px;font-size:13px}.report-history button:hover{color:#fff;background:#2f5496}.progress-container{background:#f8f9fa;border:1px solid #e5e4e7;border-radius:8px;margin-top:16px;padding:24px}.progress-stage{margin-bottom:12px;font-weight:500}.progress-bar-wrapper{background:#e5e4e7;border-radius:4px;height:24px;position:relative;overflow:hidden}.progress-bar{background:#2f5496;border-radius:4px;height:100%;transition:width .3s}.progress-pct{color:#333;font-size:13px;font-weight:600;position:absolute;top:2px;right:8px}.progress-detail{color:#666;margin-top:8px;font-size:14px}.report-page{text-align:left}.report-header{align-items:center;gap:16px;margin-bottom:16px;display:flex}.report-header h1{flex:1;margin:0;font-size:22px}.report-header button{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:4px;padding:8px 16px;font-size:14px}.report-header .primary-btn{color:#fff;background:#2f5496;border:none}.tab-bar{border-bottom:2px solid #e5e4e7;gap:0;margin-bottom:16px;display:flex}.tab-bar button{cursor:pointer;color:#666;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 20px;font-size:15px}.tab-bar button.active{color:#2f5496;border-bottom-color:#2f5496;font-weight:600}.student-table-container{overflow-x:auto}.student-table-container h2{margin:0 0 12px;font-size:18px}.table-controls{gap:12px;margin-bottom:12px;display:flex}.table-controls input{border:1px solid #ddd;border-radius:4px;flex:1;max-width:300px;padding:8px 12px;font-size:14px}.table-controls select{border:1px solid #ddd;border-radius:4px;padding:8px 12px;font-size:14px}table{border-collapse:collapse;width:100%;font-size:14px}th,td{text-align:left;border:1px solid #e5e4e7;padding:8px 10px}th{white-space:nowrap;background:#d9e1f2;font-weight:600}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}th.sortable:hover{background:#c5d0e8}tr.expandable{cursor:pointer}tr.expandable:hover{background:#f8f9fa}tr.expanded-row td{background:#f0f4fa;padding:12px}.course-list{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.course-tag{white-space:nowrap;background:#fce4d6;border-radius:4px;padding:4px 8px;font-size:13px;display:inline-block}.bottleneck-container h2{margin:0 0 12px;font-size:18px}.severity-legend{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.legend-item{border-radius:4px;padding:4px 10px;font-size:13px;font-weight:600}.bottleneck-grid{grid-template-columns:100px repeat(4,1fr);gap:2px;display:grid}.grid-corner{background:#2f5496;border-radius:4px 0 0}.grid-lp-header{color:#fff;text-align:center;white-space:pre-line;background:#4472c4;padding:10px;font-size:13px;font-weight:600}.grid-ak-header{color:#fff;text-align:center;background:#2f5496;justify-content:center;align-items:center;padding:10px;font-size:13px;font-weight:600;display:flex}.grid-cell{background:#fafafa;border:1px solid #e5e4e7;flex-direction:column;gap:4px;min-height:60px;padding:6px;display:flex}.course-card{text-align:center;border-radius:4px;padding:8px;font-size:12px}.course-card-code{font-weight:700}.course-card-count{font-size:13px;font-weight:600}.course-card-name{opacity:.9;font-size:11px}.course-card-hp{opacity:.8;font-size:11px}.unmapped-courses{margin-top:20px}.unmapped-courses h3{margin:0 0 8px;font-size:15px}.unmapped-courses .course-tag{margin:4px}
