:root{--primary-color: #4299e1;--primary-hover: #3182ce;--text-dark: #2d3748;--text-light: #718096;--bg-light: #f5f7fa;--bg-white: #ffffff;--border-color: #e2e8f0;--color-l1: #d9534f;--color-l2: #f0ad4e;--color-l3: #808080;--color-l4: #95c195;--color-l5: #5cb85c;--color-attainment-pass: #4299e1;--color-attainment-fail: #f5a623;--color-radar-actual: #4299e1;--color-radar-target: #f5a623;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg-light);color:var(--text-dark);line-height:1.6;margin:0;min-height:100vh}h1,h2,h3,h4,h5,h6{color:var(--text-dark);font-weight:600;line-height:1.2}p{color:var(--text-light);line-height:1.5}a{color:var(--primary-color);text-decoration:none;transition:color .2s}a:hover{color:var(--primary-hover)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-light)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-light)}.search-input-container{position:relative;width:100%}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input{width:100%;padding:.5rem 1rem .5rem 2.5rem;font-size:14px;border-radius:.5rem;border:1px solid var(--border-color);background:var(--bg-white);transition:border-color .2s,box-shadow .2s}.search-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4299e11a}.search-icon{position:absolute;left:.75rem;color:var(--text-light);pointer-events:none;z-index:1}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--bg-white);border:1px solid var(--border-color);border-top:none;border-radius:0 0 .5rem .5rem;box-shadow:0 4px 8px #0000001a;max-height:300px;overflow-y:auto;z-index:1002}.search-suggestion-item{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid #f7fafc;transition:background-color .2s}.search-suggestion-item:hover{background-color:#f7fafc}.search-suggestion-item:last-child{border-bottom:none}.header{background:var(--bg-white);box-shadow:0 1px 3px #0000001a;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;position:fixed;top:0;left:0;right:0;z-index:1001;height:80px}.logo{display:flex;align-items:center}.logo-fallback{font-size:2.2rem;font-weight:700;font-family:Segoe UI,Arial,sans-serif;letter-spacing:-2px}.logo-in{color:#0a3556}.logo-pods{color:#f45b2a}.logo-dot,.logo-ai{color:#0a3556}.user-info{display:flex;align-items:center;gap:1.5rem}.student-search{width:250px}.notification-button{background:none;border:none;cursor:pointer;padding:.5rem;border-radius:.25rem;color:var(--text-light);transition:color .2s,background-color .2s;display:flex;align-items:center;justify-content:center}.notification-button:hover{color:var(--text-dark);background-color:#f7fafc}.user-avatar{width:40px;height:40px;background:var(--primary-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;cursor:pointer;transition:background-color .2s}.user-avatar:hover{background:var(--primary-hover)}.sidebar{background-color:var(--bg-sidebar, #f8f9fa);width:250px;height:100%;border-right:1px solid var(--border-color, #e2e8f0);padding:1rem 0}.nav-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;cursor:pointer;color:var(--text-dark, #2d3748);font-weight:500;transition:background-color .2s}.nav-item:hover{background-color:var(--bg-hover, #edf2f7)}.nav-item.active{background-color:var(--primary-light, #ebf8ff);color:var(--primary-color, #4299e1);border-left:3px solid var(--primary-color, #4299e1)}.nav-item .chevron{transition:transform .2s;color:inherit}.sub-nav-list{list-style:none;padding-left:1.5rem;max-height:0;overflow:hidden;transition:max-height .3s ease-in-out;margin:0}.sub-nav-list.open{max-height:500px}.sub-nav-item{padding:.6rem 1rem;margin-left:.5rem;border-left:2px solid var(--border-color);cursor:pointer;font-weight:500;color:var(--text-light);transition:all .2s;border-radius:0 .25rem .25rem 0}.sub-nav-item:hover{color:var(--text-dark);border-left-color:var(--primary-color);background:#f7fafc}.sub-nav-item.active{color:var(--primary-color);font-weight:600;border-left-color:var(--primary-color);background:#4299e11a}.app-container{display:flex;flex-direction:column;min-height:100vh}.main-content{display:flex;width:100%;margin-top:80px;flex:1}.content-area{flex:1;padding:2rem;overflow-y:auto;background:var(--bg-light);min-height:calc(100vh - 80px)}@media (max-width: 768px){.main-content{flex-direction:column}.sidebar{width:100%;height:auto;border-right:none;border-bottom:1px solid var(--border-color)}.content-area{padding:1rem}}.btn{padding:.75rem 1.5rem;border:none;border-radius:.5rem;cursor:pointer;font-weight:500;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;font-size:.875rem;line-height:1.25rem;text-decoration:none;position:relative}.btn:focus{outline:2px solid var(--primary-color);outline-offset:2px}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-secondary{background:var(--border-color);color:#4a5568}.btn-secondary:hover:not(:disabled){background:#cbd5e0}.btn-danger{background:#e53e3e;color:#fff}.btn-danger:hover:not(:disabled){background:#c53030}.btn-small{padding:.5rem 1rem;font-size:.75rem}.btn-medium{padding:.75rem 1.5rem;font-size:.875rem}.btn-large{padding:1rem 2rem;font-size:1rem}.btn-loading{color:transparent}.btn-spinner{position:absolute;width:1rem;height:1rem;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:1rem}.login-card{background:var(--bg-white);border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;padding:2rem;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-header .logo{margin-bottom:1.5rem}.login-header .logo-fallback{font-size:3rem;font-weight:700;font-family:Segoe UI,Arial,sans-serif;letter-spacing:-2px}.login-header h1{font-size:1.875rem;font-weight:700;color:var(--text-dark);margin-bottom:.5rem}.login-header p{color:var(--text-light);font-size:.875rem}.login-form{space-y:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:var(--text-dark);margin-bottom:.5rem}.form-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4299e11a}.form-input:disabled{background-color:#f7fafc;cursor:not-allowed}.login-button{width:100%;margin-top:1rem}.error-message{background-color:#fed7d7;border:1px solid #feb2b2;color:#c53030;padding:.75rem 1rem;border-radius:.5rem;font-size:.875rem;margin-bottom:1rem}.login-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.demo-credentials{text-align:center}.demo-credentials h3{font-size:.875rem;font-weight:600;color:var(--text-dark);margin-bottom:.5rem}.demo-credentials p{font-size:.75rem;color:var(--text-light);margin-bottom:.25rem}.demo-credentials strong{color:var(--text-dark)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1rem}.card{background:var(--bg-white, #ffffff);border-radius:.5rem;padding:1.5rem;box-shadow:0 2px 4px #0000000d;cursor:pointer;transition:all .2s}.card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.card h3{margin-bottom:.5rem;font-size:1.1rem}.card p{color:var(--text-light, #666);margin-bottom:1rem}.attainment-container{margin-top:1rem}.attainment-header{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.9rem;color:var(--text-light, #666)}.attainment-bar{height:6px;background-color:var(--border-color, #eee);border-radius:3px;overflow:hidden}.attainment-fill{height:100%;border-radius:3px}.selection-header{margin-bottom:1.5rem}.selection-header h1{font-size:1.5rem;font-weight:600;color:var(--text-dark, #333)}.programs-view{animation:fadeIn .3s ease-in}.selection-header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem}.view-description{color:var(--text-light);font-size:.875rem;line-height:1.5;margin:0}.program-card{position:relative}.card-select-area{position:absolute;top:1rem;right:1rem;padding:.25rem;cursor:pointer}.card-select-area input[type=checkbox]{width:16px;height:16px;cursor:pointer}.empty-state h3{font-size:1.25rem;font-weight:600;color:var(--text-dark);margin-bottom:.5rem}.empty-state p{font-size:.875rem}.back-button{background:none;border:none;color:var(--primary-color, #4299e1);cursor:pointer;padding:0;font-size:.9rem;margin-bottom:.5rem;display:inline-block}.back-button:hover{text-decoration:underline}.card-checkbox{position:absolute;top:1rem;right:1rem;width:18px;height:18px}.card.selected{border:2px solid var(--primary-color, #4299e1)}.btn{padding:.5rem 1rem;border-radius:.25rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background-color:var(--primary-color, #4299e1);color:#fff;border:none}.btn-primary:hover{background-color:var(--primary-dark, #3182ce)}.btn-primary:disabled{background-color:var(--disabled-color, #cbd5e0);cursor:not-allowed}.btn-secondary{background-color:#fff;color:var(--primary-color, #4299e1);border:1px solid var(--primary-color, #4299e1)}.btn-secondary:hover{background-color:var(--bg-light, #f7fafc)}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:1000;justify-content:center;align-items:center}.modal.active{display:flex}.modal-content{background-color:#fff;padding:2rem;border-radius:.5rem;width:100%;max-width:500px;box-shadow:0 4px 6px #0000001a}.modal-header{margin-bottom:1rem}.modal-title{font-size:1.25rem;font-weight:600;margin:0}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.courses-view{animation:fadeIn .3s ease-in}.course-card h3{color:var(--text-dark);margin-bottom:.5rem}.course-card p{color:var(--text-light);font-size:.875rem;margin-bottom:1rem}.course-details{margin-bottom:1rem}.course-term{font-size:.75rem;font-weight:600;color:var(--primary-color);background:#4299e11a;padding:.25rem .5rem;border-radius:.25rem;display:inline-block;margin-bottom:.5rem}.course-sections{font-size:.75rem;color:var(--text-light)}.courses-filters{display:flex;gap:1.5rem;margin-bottom:1.5rem;background-color:var(--bg-white);padding:1rem;border-radius:.5rem;box-shadow:0 1px 2px #0000000d}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-size:.875rem;font-weight:500;color:var(--text-light)}.filter-group .filter-select{padding:.5rem;border-radius:.25rem;border:1px solid var(--border-color);min-width:200px;background-color:var(--bg-white)}.systems-view{animation:fadeIn .3s ease-in}.selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.selection-header h1{font-size:2rem;font-weight:700;color:var(--text-dark);margin:0}.select-all-container{margin-bottom:1.5rem}.select-all-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-dark);cursor:pointer}.select-all-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.system-card h3{color:var(--text-dark);margin-bottom:.5rem}.system-card p{color:var(--text-light);font-size:.875rem;margin-bottom:1rem;line-height:1.5}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem;justify-content:center}.analytics-view{padding:2rem;margin:0 auto}.analytics-header{margin-bottom:2rem;justify-content:flex-start;align-items:flex-start;gap:2rem}.analytics-header h1{font-size:2rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.analytics-description{color:var(--text-secondary);font-size:1.1rem;line-height:1.5}.back-button{display:inline-flex;align-items:center;padding:.5rem 1rem;font-size:.95rem;color:var(--text-primary);background:transparent;border:1px solid var(--border-color);border-radius:4px;cursor:pointer;margin-bottom:2rem;transition:all .2s ease}.back-button:hover{background:var(--bg-light);border-color:var(--primary-color);color:var(--primary-color)}.analytics-content{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 1px 3px #0000001a}.chart-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.chart-description{color:#666;margin-bottom:20px}.placeholder-chart{background-color:#f9f9f9;border:1px dashed #ccc;border-radius:4px;padding:40px;text-align:center;color:#666}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px}.loading-spinner{border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;width:40px;height:40px;animation:spin 2s linear infinite;margin-bottom:20px}.empty-state{text-align:center;padding:40px}.scope-description{font-style:italic;color:#666;font-size:larger;font-weight:600}.legend{margin-top:20px}.legend-items{display:flex;flex-wrap:wrap;gap:15px}.legend-item{display:flex;align-items:center;gap:5px}.legend-color{width:15px;height:15px;border-radius:3px}.system-perf-row{display:grid;grid-template-columns:250px 1fr 50px;align-items:center;margin-bottom:10px}.system-perf-bar-container{position:relative;height:20px;background-color:#f0f0f0;border-radius:4px;overflow:visible;margin-top:20px}.system-perf-bar{height:100%;background-color:#4caf50}.system-perf-threshold{position:absolute;top:0;height:100%;width:2px;background-color:#8d8d8d}.co-threshold-controls{display:flex;align-items:center;gap:10px;margin-bottom:20px}:root{--color-attainment-pass: #4CAF50;--color-attainment-fail: #F44336;--color-radar-actual: rgba(65, 105, 225, .7);--color-radar-target: rgba(255, 165, 0, .5)}.analytics-view{animation:fadeIn .3s ease-in}.back-button{margin-bottom:1.5rem;display:inline-flex;align-items:center;gap:.5rem}.analytics-title{font-size:2rem;font-weight:700;color:var(--text-dark);margin-bottom:2rem}.analytics-grid{display:block}.chart-placeholder{background:#f7fafc;border:2px dashed var(--border-color);border-radius:.5rem;padding:3rem 2rem;text-align:center;color:var(--text-light);min-height:300px;display:flex;flex-direction:column;align-items:center;justify-content:center}.chart-placeholder p:first-child{font-size:2rem;margin-bottom:.5rem}.chart-placeholder p:last-child{font-size:.875rem;font-style:italic}.summary-stats{background:var(--bg-white);padding:2rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.summary-stats h2{font-size:1.5rem;font-weight:600;color:var(--text-dark);margin-bottom:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-card{background:#f7fafc;padding:1.5rem;border-radius:.5rem;text-align:center;border:1px solid var(--border-color)}.stat-card h3{font-size:.875rem;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;color:var(--primary-color);margin:0}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-light)}.empty-state h2{font-size:1.5rem;font-weight:600;color:var(--text-dark);margin-bottom:1rem}.empty-state p{font-size:.875rem;margin-bottom:2rem}.assessment-sub-nav{display:flex;border-bottom:1px solid #ddd;margin-bottom:15px}.assessment-sub-nav-item{padding:8px 15px;cursor:pointer;border-bottom:2px solid transparent}.assessment-sub-nav-item.active{border-bottom:2px solid var(--color-primary);font-weight:700}.pie-chart-container{display:none;height:250px}.pie-chart-container.active{display:block}.assessment-card{border:1px solid #ddd;border-radius:4px;margin-bottom:20px;overflow:hidden}.assessment-card-header{background-color:#f5f5f5;padding:10px 15px;font-weight:700;border-bottom:1px solid #ddd}.assessment-card-body{padding:15px}.student-report-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#fff;z-index:1000;overflow-y:auto;padding:2rem}.analytics-header .student-search{margin:0}.report-controls{margin-bottom:1.5rem;font-size:.9em;display:flex;align-items:center;gap:2rem;flex-wrap:wrap}.report-controls label{font-weight:500;color:var(--text-primary);white-space:nowrap}.report-controls select.student-search{min-width:200px;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.report-controls select.section,.section-filter{min-width:160px;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.outliers-view{animation:fadeIn .3s ease-in}.outliers-view h1{font-size:2rem;font-weight:700;color:var(--text-dark);margin-bottom:1rem}.report-container{background:var(--bg-white);padding:2rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.report-container h2{font-size:1.5rem;font-weight:600;color:var(--text-dark);margin-bottom:.5rem}.report-description{color:var(--text-light);font-size:.875rem;margin-bottom:1.5rem;line-height:1.5}.outlier-table-container{overflow-x:auto}.student-name{font-weight:600;color:var(--text-dark)}.score{font-weight:600;font-family:Courier New,monospace}.performance-badge,.risk-badge,.excellence-badge{padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:inline-block}.empty-state{text-align:center;padding:2rem;color:var(--text-light);background:#f7fafc;border-radius:.5rem;border:1px solid var(--border-color)}.empty-state p{font-size:.875rem;margin:0}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem}@media (max-width: 768px){.data-table{font-size:.75rem}.data-table th,.data-table td{padding:.5rem .25rem}.performance-badge,.risk-badge,.excellence-badge{font-size:.625rem;padding:.125rem .25rem}}.outcomes-framework-view{animation:fadeIn .3s ease-in}.outcomes-framework-view h1{font-size:2rem;font-weight:700;color:var(--text-dark);margin-bottom:1rem}.outcomes-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:2rem;border-bottom:1px solid var(--border-color);padding-bottom:1rem}.tab-button{padding:.5rem 1rem;border:1px solid var(--border-color);background:var(--bg-white);color:var(--text-dark);border-radius:.25rem;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.tab-button:hover{background:#f7fafc;border-color:var(--primary-color)}.tab-button.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.outcomes-content-container{background:var(--bg-white);border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:2rem}.outcomes-content h2{font-size:1.5rem;font-weight:600;color:var(--text-dark);margin-bottom:.5rem}.content-description{color:var(--text-light);font-size:.875rem;margin-bottom:2rem;line-height:1.5}.program-section,.course-section{margin-bottom:2rem}.program-section h3,.course-section h3{font-size:1.25rem;font-weight:600;color:var(--text-dark);margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid var(--border-color)}.outcomes-list{display:grid;gap:1rem}.outcome-card,.competency-card{border:1px solid var(--border-color);border-radius:.5rem;padding:1rem;background:#f7fafc}.outcome-header,.competency-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.outcome-code,.competency-code{background:var(--primary-color);color:#fff;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600}.outcome-threshold{background:#f5a623;color:#fff;padding:.25rem .5rem;border-radius:.25rem;font-size:.75rem;font-weight:600}.outcome-description,.competency-description{color:var(--text-dark);font-size:.875rem;line-height:1.5;margin:0}.competencies-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.mapping-section{margin-bottom:2rem}.mapping-section h3{font-size:1.125rem;font-weight:600;color:var(--text-dark);margin-bottom:1rem}.mapping-item{padding:.75rem;background:#f7fafc;border:1px solid var(--border-color);border-radius:.25rem;margin-bottom:.5rem;font-size:.875rem}.mapping-item strong{color:var(--primary-color)}.levels-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.level-card{background:var(--primary-color);color:#fff;padding:1.5rem;border-radius:.5rem;text-align:center}.level-number{font-size:2rem;font-weight:700;margin-bottom:.5rem}.level-name{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.assessment-placeholder,.content-placeholder{background:#f7fafc;border:2px dashed var(--border-color);border-radius:.5rem;padding:3rem 2rem;text-align:center;color:var(--text-light)}.assessment-placeholder p:first-child,.content-placeholder p:first-child{font-size:1.5rem;margin-bottom:.5rem}.assessment-placeholder p:last-child,.content-placeholder p:last-child{font-size:.875rem;font-style:italic}@media (max-width: 768px){.outcomes-tabs{flex-direction:column}.tab-button{width:100%;text-align:center}.competencies-grid{grid-template-columns:1fr}.levels-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.outcome-header,.competency-header{flex-direction:column;align-items:flex-start;gap:.5rem}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.course-section{margin-bottom:2rem;padding:1.5rem;background-color:var(--bg-light);border-radius:8px;box-shadow:0 2px 4px #0000001a}.course-section h3{color:var(--text-primary);margin-bottom:1.5rem;padding-bottom:.5rem;border-bottom:2px solid var(--border-color)}.content-areas-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.topic-section{background-color:#fff;padding:1.5rem;border-radius:6px;box-shadow:0 1px 3px #0000001a}.topic-section h4{color:var(--text-primary);margin-bottom:1rem;font-size:1.1rem;font-weight:600}.subtopics-list{list-style:none;padding-left:0;margin:0}.subtopics-list li{padding:.5rem 0;color:var(--text-secondary);font-size:.95rem;border-bottom:1px solid var(--border-light)}.subtopics-list li:last-child{border-bottom:none}.content-description{color:var(--text-secondary);margin-bottom:2rem;font-size:1rem;line-height:1.5}@media (max-width: 768px){.content-areas-list{grid-template-columns:1fr}.outcomes-content{padding:1rem}}.mapping-list{display:flex;flex-direction:column;gap:1.5rem}.mapping-item{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.mapping-item h4{color:var(--text-primary);margin-bottom:1rem;font-size:1.1rem;font-weight:600;padding-bottom:.5rem;border-bottom:1px solid var(--border-light)}.mapping-item.warning{background-color:#fff8e6;border:1px solid #ffd77a}.mapping-item.warning h4{color:#b45309}.mapped-outcomes{display:flex;flex-direction:column;gap:.75rem}.outcome-item{display:flex;align-items:baseline;gap:1rem;padding:.5rem;background:var(--bg-light);border-radius:4px}.outcome-code{flex-shrink:0;font-weight:600;color:var(--primary-color);font-size:.9rem;padding:.25rem .5rem;background:var(--primary-color-light);border-radius:4px}.outcome-description{color:var(--text-secondary);font-size:.95rem;line-height:1.4}@media (max-width: 768px){.outcome-item{flex-direction:column;gap:.5rem}.outcome-code{align-self:flex-start}}.outcome-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;flex-wrap:wrap;gap:.5rem}.outcome-attainment{font-size:.9rem;padding:.25rem .5rem;border-radius:4px;background:#e9e9e9}.outcome-stats{display:flex;gap:1rem;margin-top:.75rem;font-size:.85rem;color:var(--text-secondary);flex-wrap:wrap}.attainment-status{padding:.25rem .5rem;border-radius:4px;font-weight:500}.attainment-status.achieved{background:#dcfce7;color:#166534}.attainment-status.not-achieved{background:#fef2f2;color:#dc2626}@media (max-width: 768px){.outcome-header{flex-direction:column;align-items:flex-start}.outcome-stats{flex-direction:column;gap:.5rem}}.hierarchy-filter{margin-bottom:1.5rem;padding:1rem;background:var(--bg-light);border-radius:8px;border:1px solid var(--border-color)}.filter-row{display:flex;gap:1rem;align-items:end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.filter-group label{font-weight:500;color:var(--text-primary);font-size:.9rem}.filter-select{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;background:#fff;min-width:200px}.filter-select:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.filter-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f61a}@media (max-width: 768px){.filter-row{flex-direction:column;align-items:stretch}.filter-group,.filter-select{min-width:auto}}.assessment-card{background:var(--bg-white);border:1px solid var(--border-color);border-radius:.5rem;margin-bottom:1.5rem}.assessment-card-header{font-size:1.1rem;font-weight:600;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.assessment-card-body{padding:1.5rem}:root{--primary-color: #4299e1;--primary-hover: #3182ce;--text-dark: #2d3748;--text-light: #718096;--bg-light: #f5f7fa;--bg-white: #ffffff;--border-color: #e2e8f0;--color-l1: #d9534f;--color-l2: #f0ad4e;--color-l3: #808080;--color-l4: #95c195;--color-l5: #5cb85c;--color-attainment-pass: #4299e1;--color-attainment-fail: #f5a623;--color-radar-actual: #4299e1;--color-radar-target: #f5a623}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-light)}.loading-spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:var(--text-light);font-size:.875rem}.chart-container{background:var(--bg-white);padding:2rem;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:2rem}.chart-container h2{font-size:1.5rem;font-weight:600;color:var(--text-dark);margin-bottom:1rem}.chart-description{color:var(--text-light);margin-bottom:1.5rem;border-left:3px solid var(--border-color);padding-left:1rem;font-size:.9em;line-height:1.5}.legend{display:flex;justify-content:center;flex-wrap:wrap;gap:20px;margin-top:1.5rem}.legend-item{display:flex;align-items:center;font-size:.875rem}.legend-color{width:15px;height:15px;margin-right:8px;border-radius:3px}.data-table{width:100%;border-collapse:collapse;background:var(--bg-white);margin-top:1rem}.data-table th,.data-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border-color);font-size:.9em}.data-table th{background:#f7fafc;font-size:.875rem;text-transform:uppercase;color:var(--text-light);font-weight:600}@media (max-width: 768px){.chart-container{padding:1rem}.legend{gap:10px}.legend-item{font-size:.75rem}.data-table th,.data-table td{padding:.5rem;font-size:.8em}}.accreditation-view{padding:2rem}.accreditation-tabs{display:flex;gap:.5rem;margin:2rem 0;border-bottom:1px solid var(--border-color)}.tab-button{padding:.75rem 1.5rem;border:none;background:transparent;color:var(--text-light);font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.tab-button:hover{color:var(--text-dark)}.tab-button.active{color:#fff;background:#007bff;border-bottom-color:var(--primary-color)}.accreditation-content-container{margin-top:2rem}.course-section{margin-bottom:2rem;padding:1.5rem;background:var(--bg-white);border:1px solid var(--border-color);border-radius:.5rem}.course-section h3{color:var(--text-dark);margin-bottom:1rem;font-size:1.125rem}.co-list{display:flex;flex-direction:column;gap:.75rem}.co-item{display:flex;gap:1rem;padding:.75rem;background:#f7fafc;border-radius:.25rem}.co-code{font-weight:600;color:var(--primary-color);min-width:80px}.co-description{color:var(--text-dark);flex:1}.attainment-table-container{overflow-x:auto;margin-top:1rem}.attainment-table{width:100%;border-collapse:collapse;background:var(--bg-white);border:1px solid var(--border-color);border-radius:.5rem}.attainment-table th,.attainment-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border-color)}.attainment-table th{background:#f7fafc;font-weight:600;color:var(--text-dark)}.attainment-table tbody tr:hover{background:#f7fafc}.loading{text-align:center;padding:2rem;color:var(--text-light)}.framework-semester-block{margin-bottom:32px}.framework-header{background-color:#f3f4f6;border:2px solid #000;padding:12px 16px;text-align:center;font-weight:700;font-size:16px}.framework-table-container{border:2px solid #000;border-top:none}.framework-table{width:100%;border-collapse:collapse}.framework-table td{border-bottom:1px solid #000;padding:12px 16px;vertical-align:top}.framework-table tr:last-child td{border-bottom:none}.framework-co-name-cell{width:100px;border-right:2px solid #000;background-color:#f9fafb;font-weight:700;font-size:14px;text-align:center}.framework-co-desc-cell{font-size:14px;line-height:1.5}.criteria3-view{padding:20px}.tabs{margin-bottom:20px}.tab-button{padding:8px 16px;margin-right:8px;border:none;background:#f0f0f0;cursor:pointer}.tab-button.active{background:#007bff;color:#fff}.criteria3-content{padding:20px;background:#fff;border-radius:4px;box-shadow:0 1px 3px #0000001a}.po-data-table-container{overflow-x:auto;margin-top:1rem}.po-data-table{width:100%;border-collapse:collapse;background:var(--bg-white);border:1px solid var(--border-color);border-radius:.5rem}.po-data-table th,.po-data-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border-color)}.po-data-table th{background:#f7fafc;font-weight:600;color:var(--text-dark)}.po-data-table tbody tr:hover{background:#f7fafc}.po-data-table th:first-child,.po-data-table td:first-child{width:80px;text-align:center}.po-data-table th:nth-child(2),.po-data-table td:nth-child(2){width:200px;font-weight:500}.po-data-table th:nth-child(3),.po-data-table td:nth-child(3){width:auto}.co-po-affinity-table-container{margin-bottom:2rem}.co-po-table-header{background-color:#f3f4f6;border:2px solid #000;padding:12px 16px;text-align:center;font-weight:700;font-size:16px;margin-bottom:0}.co-po-affinity-table{width:100%;border-collapse:collapse;border:2px solid #000;border-top:none;background:var(--bg-white)}.co-po-affinity-table th,.co-po-affinity-table td{border:1px solid #000;padding:8px 12px;text-align:center;vertical-align:middle}.co-po-affinity-table th{background-color:#f9fafb;font-weight:700;font-size:14px}.co-po-affinity-table th:first-child{background-color:#f3f4f6;width:100px}.co-po-affinity-table .co-name-cell{background-color:#f9fafb;font-weight:700;font-size:14px;text-align:center;width:100px}.co-po-affinity-table .affinity-cell{font-size:14px;min-width:60px}.co-po-affinity-table tbody tr:hover{background-color:#f0f9ff}.co-po-affinity-table tbody tr:hover .co-name-cell{background-color:#e0f2fe}.scrollable-table::-webkit-scrollbar{height:12px}.scrollable-table::-webkit-scrollbar-track{background-color:#e0e0e0;border-radius:10px}.scrollable-table::-webkit-scrollbar-thumb{background-color:#6b6b6b;border-radius:10px;border:3px solid #e0e0e0}.scrollable-table::-webkit-scrollbar-thumb:hover{background-color:#555}
