:root{--colour-primary:#005eb8;--colour-primary-dark:#004a92;--colour-primary-light:#e8f1fb;--colour-accent:#00a9ce;--colour-danger:#c62828;--colour-danger-bg:#ffebee;--colour-warning:#e65100;--colour-warning-bg:#fff3e0;--colour-success:#2e7d32;--colour-success-bg:#e8f5e9;--colour-bg:#f4f6f9;--colour-surface:#fff;--colour-border:#dee2e6;--colour-text:#212529;--colour-text-muted:#6c757d;--font-family:"Segoe UI", Tahoma, Geneva, Verdana, sans-serif;--font-mono:"Courier New", Courier, monospace;--font-size-base:14px;--line-height-base:1.5;--space-xs:10px;--space-sm:12px;--space-md:16px;--space-lg:24px;--space-xl:32px;--border-radius:4px;--border-radius-lg:8px;--shadow-sm:0 1px 3px #0000001a;--shadow-md:0 4px 8px #0000001f;--shadow-lg:0 8px 24px #00000026}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--colour-text);background:var(--colour-bg);min-height:100vh}h1,h2,h3,h4{font-weight:600;line-height:1.25}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.1rem}h4{font-size:1rem}a{color:var(--colour-primary);text-decoration:none}a:hover{text-decoration:underline}#root{flex-direction:column;min-height:100vh;display:flex}.app-main{padding:var(--space-md);flex:1;max-width:100%;overflow-x:hidden}.login-page{background:var(--colour-primary);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--colour-surface);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);padding:var(--space-xl);width:100%;max-width:400px}.login-card__logo{max-width:160px;margin:0 auto var(--space-md);display:block}.login-card h1{text-align:center;color:var(--colour-primary);margin-bottom:var(--space-lg);font-size:1.2rem}.login-card .error-banner{background:var(--colour-danger-bg);color:var(--colour-danger);border:1px solid var(--colour-danger);border-radius:var(--border-radius);padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-md);font-size:13px}.site-header{background:var(--colour-primary);color:#fff;padding:0 var(--space-md);align-items:center;gap:var(--space-md);height:52px;box-shadow:var(--shadow-sm);z-index:100;display:flex;position:sticky;top:0}.site-header__logo{width:auto;height:36px}.site-header__title{color:#fff;flex:1;font-size:1rem;font-weight:700}.site-header__nav{gap:var(--space-sm);align-items:center;display:flex}.site-header__nav a,.site-header__nav button{color:#ffffffd9;cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--border-radius);font-size:13px;font-family:var(--font-family);background:0 0;border:none;text-decoration:none;transition:background .15s}.site-header__nav a:hover,.site-header__nav button:hover{color:#fff;background:#ffffff26;text-decoration:none}.site-header__nav .nav-active{color:#fff;background:#fff3}.site-header__user{color:#ffffffbf;padding-left:var(--space-sm);margin-left:var(--space-xs);border-left:1px solid #ffffff40;font-size:12px}.form-group{margin-bottom:var(--space-md)}.form-group label{margin-bottom:var(--space-xs);font-size:13px;font-weight:600;display:block}input[type=text],input[type=email],input[type=password],input[type=number],input:not([type]),select,textarea{width:100%;padding:14px var(--space-lg);border:1px solid var(--colour-border);border-radius:var(--border-radius-lg);font-size:14px;font-family:var(--font-family);color:var(--colour-text);background:var(--colour-surface);transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:var(--colour-primary);box-shadow:0 0 0 2px var(--colour-primary-light);outline:none}.btn{align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);border-radius:var(--border-radius);font-size:13px;font-family:var(--font-family);cursor:pointer;border:none;font-weight:600;text-decoration:none;transition:background .15s,opacity .15s;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn--primary{background:var(--colour-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--colour-primary-dark)}.btn--danger{background:var(--colour-danger);color:#fff}.btn--danger:hover:not(:disabled){background:#b71c1c}.btn--secondary{background:var(--colour-border);color:var(--colour-text)}.btn--secondary:hover:not(:disabled){background:#ccc}.btn--warning{background:var(--colour-warning);color:#fff}.btn--warning:hover:not(:disabled){background:#bf360c}.btn--sm{padding:2px var(--space-sm);font-size:12px}.btn--icon{border:1px solid var(--colour-border);color:var(--colour-text-muted);background:0 0;padding:4px 6px;font-size:14px}.btn--icon:hover{background:var(--colour-bg);color:var(--colour-text)}.selector-bar{gap:var(--space-md);padding:var(--space-md);background:var(--colour-surface);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--space-md);flex-wrap:wrap;align-items:flex-end;display:flex}.selector-bar .form-group{min-width:200px;margin-bottom:0}.grade-grid-wrap{background:var(--colour-surface);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);overflow-x:auto}.grade-grid{border-collapse:collapse;width:100%;min-width:800px;font-size:12px}.grade-grid th,.grade-grid td{border:1px solid var(--colour-border);padding:var(--space-xs) var(--space-sm);white-space:nowrap;vertical-align:middle}.grade-grid th{background:var(--colour-primary);color:#fff;text-align:center;z-index:5;font-weight:600;position:sticky;top:0}.grade-grid th.col-sticky{z-index:10}.grade-grid tbody tr:hover td{background:var(--colour-primary-light)}.col-sticky-0{z-index:4;background:var(--colour-surface);position:sticky;left:0}.col-sticky-1{z-index:4;background:var(--colour-surface);position:sticky;left:80px}.col-sticky-2{z-index:4;background:var(--colour-surface);position:sticky;left:155px}.grade-grid tbody tr:hover .col-sticky-0,.grade-grid tbody tr:hover .col-sticky-1,.grade-grid tbody tr:hover .col-sticky-2{background:var(--colour-primary-light)}.grade-grid th.col-sticky-0{background:var(--colour-primary);left:0}.grade-grid th.col-sticky-1{background:var(--colour-primary);left:80px}.grade-grid th.col-sticky-2{background:var(--colour-primary);left:155px}.col-cis{width:80px;min-width:80px}.col-name{width:75px;min-width:75px}.col-concern{text-align:center;width:90px}.col-calc{text-align:center;width:50px;font-weight:700}.col-overall{text-align:center;width:60px;font-weight:700}.col-unit{text-align:center;width:52px}.cis-link{color:var(--colour-primary);cursor:pointer;font-family:var(--font-mono);font-size:11px}.cis-link:hover{text-decoration:underline}.grade-cell{text-align:center;padding:2px}.grade-cell span,.grade-cell select{border-radius:var(--border-radius);text-align:center;cursor:pointer;min-width:36px;padding:2px 4px;font-size:12px;font-weight:700;display:inline-block}.grade-cell select{cursor:pointer;border:1px solid var(--colour-border)}.grade--ns{color:#9e9e9e;background:#f0f0f0}.grade--ou{color:#fff;background:#b71c1c}.grade--u{color:#c62828;background:#ffcdd2}.grade--np{color:#bf360c;background:#ffe0b2}.grade--p{color:#fff;background:#2e7d32}.grade--m{color:#5d4037;background:#ffe082}.grade--d{color:#fff;background:#f9a825}.grade--dstar{color:#fff;background:#e65100}option.grade--ns{color:#9e9e9e;background:#f0f0f0}option.grade--ou{color:#fff;background:#b71c1c}option.grade--u{color:#c62828;background:#ffcdd2}option.grade--np{color:#bf360c;background:#ffe0b2}option.grade--p{color:#fff;background:#2e7d32}option.grade--m{color:#5d4037;background:#ffe082}option.grade--d{color:#fff;background:#f9a825}.grade-cell--saving span{opacity:.5}.grade-cell--error span{outline:2px solid var(--colour-danger)}.grade-cell--btec-external .mark-input{text-align:center;border:1px solid var(--colour-border);border-radius:var(--border-radius);width:52px;padding:2px 4px;font-size:12px;font-weight:700}.grade-cell--has-criteria{cursor:pointer;position:relative}.grade-cell--has-criteria:after{content:"▾";opacity:.45;pointer-events:none;font-size:8px;line-height:1;position:absolute;top:1px;right:2px}td.grade-cell--has-criteria>span{cursor:pointer}.row--at-risk td{background:#fff8f8}.row--at-risk td:first-child{border-left:3px solid var(--colour-danger)}.row--at-risk:hover td{background:#ffebee}td.col-overall--at-risk{background:#ffcdd2}td.col-overall--ok{background:#c8e6c9}.row--at-risk:hover td.col-overall--at-risk{background:#ef9a9a}.row--at-risk:hover td.col-overall--ok{background:#a5d6a7}.concern-badge{white-space:nowrap;border-radius:999px;padding:1px 6px;font-size:11px;font-weight:600;display:inline-block}.concern--none{color:#2e7d32;background:#e8f5e9}.concern--attendance{color:#c62828;background:#ffcdd2}.concern--engagement{color:#e65100;background:#ffe0b2}.concern--late{color:#f57f17;background:#fff9c4}.concern--borderline{color:#1565c0;background:#e3f2fd}.concern--personal{color:#6a1b9a;background:#f3e5f5}.concern--default{background:var(--colour-border);color:var(--colour-text-muted)}.prediction-table{border-collapse:collapse;width:100%;margin-top:var(--space-sm);font-size:13px}.prediction-table th,.prediction-table td{border:1px solid var(--colour-border);padding:var(--space-xs) var(--space-sm)}.prediction-table th{background:var(--colour-bg);text-align:left;font-weight:600}.prediction-table .row--submitted{opacity:.55}.prediction-table .row--unachievable{background:var(--colour-warning-bg);color:var(--colour-warning)}.prediction-summary{margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);border-radius:var(--border-radius);font-size:13px;font-weight:600}.prediction-summary--ok{background:var(--colour-success-bg);color:var(--colour-success)}.prediction-summary--fail{background:var(--colour-warning-bg);color:var(--colour-warning)}.prediction-target-bar{align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);display:flex}.objectives-modal-meta{align-items:center;gap:var(--space-md);padding:var(--space-sm) 0 var(--space-md);border-bottom:1px solid var(--colour-border);margin-bottom:var(--space-md);display:flex}.objectives-modal-meta .section-type-badge{border-radius:var(--border-radius);background:var(--colour-primary-light);color:var(--colour-primary-dark);letter-spacing:.03em;text-transform:uppercase;padding:2px 8px;font-size:11px;font-weight:600}.objectives-derived-bar{align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--colour-bg);border:1px solid var(--colour-border);border-radius:var(--border-radius);margin-bottom:var(--space-md);display:flex}.objectives-derived-bar .label{color:var(--colour-text-muted);flex:1;font-size:12px}.criteria-section{border:1px solid var(--colour-border);border-radius:var(--border-radius);margin-bottom:var(--space-sm);overflow:hidden}.criteria-section--complete{border-left:4px solid var(--colour-success)}.criteria-section__header{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--colour-bg);border-bottom:1px solid var(--colour-border);display:flex}.criteria-section__header .band-label{text-align:center;border-radius:var(--border-radius);width:28px;padding:2px 4px;font-size:13px;font-weight:700}.band-label--P{border:1px solid var(--colour-border);color:#212529;background:#fff}.band-label--M{color:#2e7d32;background:#e8f5e9}.band-label--D{color:#1b5e20;background:#c8e6c9}.band-label--LO{background:var(--colour-primary-light);color:var(--colour-primary-dark)}.criteria-section__progress{color:var(--colour-text-muted);margin-left:auto;font-size:11px}.criteria-section__warning{color:var(--colour-warning);padding:var(--space-xs) var(--space-md);background:var(--colour-warning-bg);border-bottom:1px solid var(--colour-border);font-size:11px}.criteria-list{margin:0;padding:0;list-style:none}.criteria-row{align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--colour-border);display:flex}.criteria-row:last-child{border-bottom:none}.criteria-row--achieved{background:var(--colour-success-bg)}.criteria-row input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--colour-primary);flex-shrink:0;margin-top:2px}.criteria-row input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.criteria-code{font-family:var(--font-mono);color:var(--colour-primary-dark);flex-shrink:0;width:32px;font-size:12px;font-weight:700}.criteria-desc{color:var(--colour-text);flex:1;font-size:13px}.criteria-meta-toggle{color:var(--colour-text-muted);cursor:pointer;padding:0 var(--space-xs);background:0 0;border:none;flex-shrink:0;font-size:11px;text-decoration:underline}.criteria-meta-fields{gap:var(--space-sm);padding:var(--space-xs) var(--space-md) var(--space-xs) calc(var(--space-md) + 16px + var(--space-sm) + 32px + var(--space-sm));background:var(--colour-primary-light);border-bottom:1px solid var(--colour-border);display:flex}.criteria-meta-fields input{border:1px solid var(--colour-border);border-radius:var(--border-radius);width:120px;padding:2px 6px;font-size:12px}.objectives-manager{gap:var(--space-md);grid-template-columns:220px 1fr;height:100%;min-height:400px;display:grid}.objectives-manager__unit-list{border:1px solid var(--colour-border);border-radius:var(--border-radius);max-height:600px;overflow-y:auto}.objectives-manager__unit-item{padding:var(--space-sm) var(--space-md);cursor:pointer;border-bottom:1px solid var(--colour-border);align-items:center;gap:var(--space-sm);font-size:13px;display:flex}.objectives-manager__unit-item:last-child{border-bottom:none}.objectives-manager__unit-item--selected{background:var(--colour-primary-light);color:var(--colour-primary-dark);font-weight:600}.objectives-manager__unit-item .configured-dot{background:var(--colour-success);border-radius:50%;flex-shrink:0;width:8px;height:8px}.objectives-manager__unit-item .unconfigured-dot{background:var(--colour-border);border-radius:50%;flex-shrink:0;width:8px;height:8px}.admin-panel{padding:var(--space-md)}.admin-panel h1{margin-bottom:var(--space-md)}.tab-bar{border-bottom:2px solid var(--colour-border);margin-bottom:var(--space-md);flex-wrap:wrap;gap:2px;display:flex}.tab-btn{padding:var(--space-sm) var(--space-md);font-size:13px;font-family:var(--font-family);cursor:pointer;color:var(--colour-text-muted);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;font-weight:600;transition:color .15s,border-color .15s}.tab-btn:hover{color:var(--colour-primary)}.tab-btn--active{color:var(--colour-primary);border-bottom-color:var(--colour-primary)}.manager-section{padding:var(--space-sm) 0}.manager-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th,.data-table td{border:1px solid var(--colour-border);padding:var(--space-xs) var(--space-sm);text-align:left;vertical-align:middle}.data-table th{background:var(--colour-bg);font-weight:600}.data-table tbody tr:hover td{background:var(--colour-primary-light)}.data-table .col-actions{text-align:center;white-space:nowrap;width:80px}.data-table .action-btns{justify-content:center;gap:4px;display:flex}.manager-header-actions{gap:var(--space-sm);display:flex}.manager-filter{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);display:flex}.manager-filter__input-wrap{width:100%;max-width:320px;position:relative}.manager-filter__input-wrap input{width:100%;margin-bottom:0;padding-right:32px}.manager-filter__clear{background:var(--colour-text-muted);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;padding:0;font-size:11px;line-height:1;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.manager-filter__clear:hover{background:var(--colour-text)}.manager-filter__count{color:var(--colour-text-muted);white-space:nowrap;font-size:12px}.import-modal{gap:var(--space-md);flex-direction:column;display:flex}.import-selectors{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.import-hint{color:var(--colour-text-muted);margin:0 0 var(--space-xs);font-size:12px;line-height:1.5}.import-hint code{background:var(--colour-bg);font-family:var(--font-mono);border-radius:3px;padding:1px 4px}.import-file-input{width:100%;font-size:13px;display:block}.import-warnings{padding:var(--space-sm);background:#fff8e1;border:1px solid #ffe082;border-radius:4px}.import-warnings p{color:#795548;margin:0;font-size:12px}.import-preview-count{margin:0 0 var(--space-xs);font-size:13px}.import-preview-table{margin-top:0}.import-missing{color:var(--colour-danger);font-size:11px;font-style:italic}.import-result{padding:var(--space-sm) var(--space-md);background:#e8f5e9;border:1px solid #a5d6a7;border-radius:4px}.import-result-summary{margin:0 0 var(--space-xs);font-size:13px}.import-result-errors{color:var(--colour-danger)}.import-error-list{margin:var(--space-xs) 0 0;padding-left:var(--space-lg);color:var(--colour-danger);font-size:12px}.import-error-list li{margin-bottom:2px}.modal-overlay{z-index:200;padding:var(--space-md);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-panel{background:var(--colour-surface);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);flex-direction:column;width:100%;max-width:560px;max-height:90vh;display:flex}.modal-panel--wide{max-width:800px}.modal-header{padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--colour-border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.modal-header h2{margin:0;font-size:1rem}.modal-close{cursor:pointer;color:var(--colour-text-muted);background:0 0;border:none;padding:0 4px;font-size:1.2rem;line-height:1}.modal-close:hover{color:var(--colour-text)}.modal-body{padding:var(--space-md) var(--space-lg);flex:1;overflow-y:auto}.modal-footer{gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--colour-border);flex-shrink:0;justify-content:flex-end;display:flex}.loading-spinner-wrap{padding:var(--space-xl);justify-content:center;align-items:center;display:flex}.loading-spinner{border:3px solid var(--colour-border);border-top-color:var(--colour-primary);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}.loading-spinner--sm{border-width:2px;width:16px;height:16px;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.inline-error{color:var(--colour-danger);margin-top:var(--space-xs);font-size:12px}.page-error{background:var(--colour-danger-bg);color:var(--colour-danger);border:1px solid var(--colour-danger);border-radius:var(--border-radius);padding:var(--space-sm) var(--space-md);margin:var(--space-md) 0;font-size:13px}@media (width<=768px){.selector-bar{flex-direction:column;align-items:stretch}.objectives-manager{grid-template-columns:1fr}.admin-panel{padding:var(--space-sm)}}.toast-container{top:var(--space-md);right:var(--space-md);z-index:9000;gap:var(--space-sm);pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast{border-radius:var(--radius);min-width:280px;max-width:420px;padding:14px 20px;font-size:16px;font-weight:600;animation:.25s ease-out toast-in;box-shadow:0 6px 20px #00000040}.toast--success{background:var(--colour-success-bg);color:var(--colour-success);border-left:6px solid var(--colour-success)}.toast--error{background:var(--colour-danger-bg);color:var(--colour-danger);border-left:6px solid var(--colour-danger)}@keyframes toast-in{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}
