*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #1a82cc;--primary-dk: #1568aa;--green: #5cb840;--gray: #f0f7ff;--border: #d6e8f7;--text: #0d2b4e;--muted: #5a7a96;--radius: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#e8f2fb;color:var(--text);min-height:100vh}.navbar{background:#0d2b5e;color:#fff;padding:0 24px;height:54px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 8px #0d2b5e66;position:sticky;top:0;z-index:50}.nav-brand{font-size:17px;font-weight:700;letter-spacing:.3px}.settings-panel{position:fixed;top:54px;right:0;width:360px;background:#fff;border-left:1px solid var(--border);box-shadow:-4px 4px 16px #0000001f;z-index:40;padding:24px;transition:transform .2s}.settings-panel h3{margin-bottom:18px;font-size:15px}.settings-panel label{display:block;font-size:13px;font-weight:600;margin-bottom:4px;margin-top:14px}.settings-panel label:first-of-type{margin-top:0}.settings-panel label small{font-weight:400;color:var(--muted)}.settings-panel input{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:5px;font-size:13px}.settings-actions{display:flex;gap:8px;margin-top:18px}.container{max-width:860px;margin:28px auto;padding:0 16px 60px}.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px;box-shadow:0 1px 4px #0000000f}.field-row{display:flex;gap:16px}.field-row .field{flex:1}.field{margin-bottom:16px}.field label{display:block;font-size:13px;font-weight:600;margin-bottom:5px}.hint-text{font-weight:400;color:var(--muted)}.field input,.field textarea{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:5px;font-size:14px;font-family:inherit;transition:border-color .15s}.field input:focus,.field textarea:focus{outline:none;border-color:var(--primary)}.field textarea{resize:vertical;font-family:SFMono-Regular,Consolas,monospace;font-size:13px}.field-hint{font-size:12px;color:var(--muted);margin-top:4px;display:block}.btn-primary{background:var(--primary);color:#fff;border:none;padding:10px 24px;border-radius:5px;cursor:pointer;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:8px;text-decoration:none;transition:background .15s,transform .1s}.btn-primary:hover{background:var(--primary-dk);transform:translateY(-1px)}.btn-primary.disabled{background:#bbb;pointer-events:none;cursor:default;transform:none}.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border);padding:9px 20px;border-radius:5px;cursor:pointer;font-size:14px}.btn-ghost:hover{background:var(--gray)}.btn-icon{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.3);padding:6px 14px;border-radius:5px;cursor:pointer;font-size:13px}.btn-icon:hover{background:#ffffff40}.btn-submit{width:100%;justify-content:center;padding:12px;font-size:15px}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.hidden{display:none!important}.alert-error{background:#fdecea;border:1px solid #f5c6cb;color:#721c24;padding:12px 16px;border-radius:var(--radius);margin-bottom:16px;font-size:14px}.student-card{display:flex;align-items:center;gap:18px}.student-avatar{font-size:42px}.student-name{font-size:20px;font-weight:700;margin-bottom:4px}.student-meta{display:flex;gap:20px;font-size:13px;color:var(--muted)}.action-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:20px}.btn-cert{font-size:15px;padding:12px 28px}.disabled-msg{font-size:13px;color:#b00}.table-wrap{padding:0;overflow:hidden}#results-table{width:100%;border-collapse:collapse}#results-table thead th{background:var(--primary);color:#fff;padding:11px 14px;text-align:left;font-size:13px;font-weight:600}#results-table td{padding:10px 14px;border-bottom:1px solid var(--border);font-size:14px}#results-table tr:last-child td{border-bottom:none}#results-table tr:not(.sem-header-row):hover td{background:#fafafa}.sem-header-row td{background:#f0f0f0;font-weight:700;font-size:13px;color:#333;padding:7px 14px}.th-drag{width:28px}.td-drag{width:28px;text-align:center;cursor:grab;color:var(--muted);font-size:15px;-webkit-user-select:none;user-select:none}.td-drag:active{cursor:grabbing}.td-num{width:36px;color:var(--muted);text-align:center}.td-grade{width:70px;text-align:center;font-weight:700}.td-actions{white-space:nowrap}.course-row.dragging{opacity:.3}.course-row.drag-over-top td{border-top:2px solid var(--primary)!important}.avg-summary-row td{background:var(--gray);font-weight:700;border-top:2px solid var(--border);padding:10px 14px}.avg-label{text-align:right;font-size:14px;color:var(--text)}.avg-val{font-size:16px;color:var(--primary)}.badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:600;color:#fff}.badge.pass{background:#5cb840}.badge.fail{background:#dc3545}.badge.incomplete{background:#fd7e14}.badge.nograde{background:#6c757d}.link-btn{display:inline-block;padding:3px 10px;margin-right:4px;background:#343a40;color:#fff;border-radius:4px;text-decoration:none;font-size:12px}.link-btn:hover{background:#555}.link-btn.disabled{background:#ccc;color:#999;pointer-events:none}.course-mode-tabs{display:flex;width:fit-content;border:1px solid var(--border);border-radius:5px;overflow:hidden;margin-bottom:10px}.tab-btn{background:#fff;border:none;padding:6px 18px;font-size:13px;font-weight:600;cursor:pointer;color:var(--muted);transition:background .15s,color .15s}.tab-btn+.tab-btn{border-left:1px solid var(--border)}.tab-btn:hover{background:var(--gray)}.tab-btn.active{background:var(--primary);color:#fff}.pick-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.btn-sm{padding:6px 14px!important;font-size:13px!important}.sem-builder-row{border:1px solid var(--border);border-radius:var(--radius);padding:12px;margin-bottom:10px}.sem-builder-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sem-builder-label{font-weight:700;font-size:13px}.btn-remove-sem{background:none;border:none;color:var(--muted);cursor:pointer;font-size:13px;padding:2px 6px}.btn-remove-sem:hover{color:var(--primary)}.sem-search{width:100%;padding:8px 10px;font-size:13px;font-family:inherit;border:1px solid var(--border);border-radius:5px;margin-bottom:4px;transition:border-color .15s}.sem-search:focus{outline:none;border-color:var(--primary)}.course-dropdown{border:1px solid var(--border);border-radius:5px;max-height:160px;overflow-y:auto;background:#fff;box-shadow:0 4px 12px #0000001a;margin-bottom:6px}.course-item{padding:8px 12px;font-size:13px;cursor:pointer}.course-item:hover{background:var(--gray)}.course-item-empty{color:var(--muted);cursor:default;font-style:italic}.course-item-empty:hover{background:none}.selected-chips{display:flex;flex-wrap:wrap;gap:6px;min-height:24px;margin-top:4px}.course-chip{display:inline-flex;align-items:center;gap:4px;background:#d6edf9;color:#1568aa;border-radius:14px;padding:3px 10px;font-size:12px;font-weight:600}.course-chip button{background:none;border:none;cursor:pointer;color:#1568aa;font-size:14px;line-height:1;padding:0}.course-chip button:hover{color:var(--primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:200}.modal-box{background:#fff;border-radius:var(--radius);padding:28px 32px;width:380px;max-width:95vw;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;gap:12px}.modal-title{font-size:16px;font-weight:700;margin-bottom:4px}.modal-choices{display:flex;gap:10px}.modal-choices button{flex:1}.modal-url-row{display:flex;flex-direction:column;gap:8px}.modal-url-row input{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:5px;font-size:14px;font-family:inherit;transition:border-color .15s}.modal-url-row input:focus{outline:none;border-color:var(--primary)}.modal-cancel{align-self:flex-end;font-size:13px;padding:6px 14px}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(60px);background:#333;color:#fff;padding:10px 22px;border-radius:20px;font-size:14px;opacity:0;transition:opacity .3s,transform .3s;pointer-events:none}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}
