:root{--color-primary:#04152b;--color-primary-dark:#1a2a40;--color-primary-hover:#38485f;--color-primary-light:#505f78;--color-accent:#e9c176;--color-secondary:#545f72;--color-secondary-hover:#586377;--color-secondary-light:#75777d;--color-background:#f9f9ff;--color-surface:#fff;--color-text-primary:#0b1c31;--color-text-secondary:#44474d;--color-text-light:#75777d;--color-text-white:#fff;--color-border:#c4c6cd;--color-border-light:#eff3ff;--color-success:#1f7a4a;--color-success-light:#35a56a;--color-warning:#8a5b0f;--color-warning-light:#c88b2f;--color-error:#ba1a1a;--color-error-light:#d96b6b;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--spacing-xs:0.5rem;--spacing-sm:1rem;--spacing-md:1.5rem;--spacing-lg:2rem;--spacing-xl:3rem;--transition-base:0.3s ease;--transition-fast:0.15s ease}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--color-background);color:var(--color-text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app{background-color:var(--color-background);color:var(--color-text-primary);min-height:100vh;width:100%}.home-page.cobalt-home-page{background:#f9f9ff;min-height:100vh;position:relative;width:100%}.cobalt-overview-frame{background:#f9f9ff;border:0;display:block;height:100vh;width:100%}@media (max-width:768px){.cobalt-overview-frame{height:100dvh}}.cobalt-login-page{background:#f9f9ff;color:#0b1c31;display:flex;flex-direction:column;min-height:100vh}.cobalt-login-main{align-items:center;display:flex;flex:1 1;justify-content:center;padding:3rem 1.5rem}.cobalt-login-container{max-width:520px;width:100%}.cobalt-branding{margin-bottom:2.8rem;text-align:center}.cobalt-branding h1{color:#04152b;font-family:Newsreader,serif;font-size:2.7rem;font-weight:400;letter-spacing:-.05em;margin:0}.cobalt-brand-link{color:inherit}.cobalt-brand-link,.cobalt-brand-link:hover{text-decoration:none}.cobalt-branding p{color:#64748b;font-family:Inter,sans-serif;font-size:.85rem;letter-spacing:normal;margin:.5rem 0 0;text-transform:none!important}.cobalt-login-box{background:#fff;border:1px solid #0000000a;border-radius:4px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000003;padding:3.5rem 2.75rem}.cobalt-login-header{margin-bottom:2.5rem}.cobalt-login-header h2{color:#0b1c31;font-family:Newsreader,serif;font-size:2.2rem;font-weight:500;letter-spacing:-.01em;margin:0;text-align:center}.alert{border-radius:0;margin-bottom:1.1rem;padding:.8rem}.alert-error{border:1px solid #ffdad6;color:#ba1a1a}.cobalt-login-form{display:flex;flex-direction:column;gap:1.25rem}.cobalt-form-group{display:flex;flex-direction:column;gap:.55rem}.cobalt-form-group label{color:#475569;display:block;font-family:Inter,sans-serif;font-size:.875rem;font-weight:500;letter-spacing:normal;margin-bottom:.5rem;text-transform:none!important}.cobalt-form-group input{background-color:#fff;border:1px solid #e2e8f0;border-radius:4px;color:#1e293b;font-family:Inter,sans-serif;font-size:.95rem;padding:.85rem 1rem;transition:all .2s ease;width:100%}.cobalt-form-group input:focus{background-color:#fff;border-color:#04152b;box-shadow:0 0 0 1px #04152b;outline:none}.cobalt-form-group input:disabled{background:#eff3ff;cursor:not-allowed;opacity:.75}.cobalt-form-group input::placeholder{color:#44474d8c}.cobalt-forgot-row{display:flex;justify-content:flex-end;margin-top:.1rem}.cobalt-btn-submit{align-items:center;background:#04152b;border:none;border-radius:4px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;color:#fff;cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.95rem;font-weight:500;justify-content:center;letter-spacing:normal;margin-top:1.75rem;padding:.95rem;text-transform:none!important;transition:all .2s ease;width:100%}.cobalt-btn-submit .spinner{margin-right:.5rem}.cobalt-btn-submit:hover:not(:disabled){background:#1e293b;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-1px)}.cobalt-btn-submit:disabled{cursor:not-allowed;opacity:.5}.cobalt-link-button{background:none;border:none;color:#334155;cursor:pointer;font-family:Inter,sans-serif;font-size:.875rem;font-weight:500;letter-spacing:normal;padding:0;text-decoration:none;transition:color .2s ease}.cobalt-link-button:hover{color:#04152b;text-decoration:underline}@media (max-width:768px){.cobalt-login-main{padding:2rem 1rem}.cobalt-branding{margin-bottom:2rem}.cobalt-branding h1{font-size:2.25rem}.cobalt-login-box{padding:2rem 1.2rem}.cobalt-login-header h2{font-size:1.8rem}}@media (max-width:480px){.cobalt-login-main{align-items:flex-start;padding-top:2.8rem}.cobalt-branding h1{font-size:2rem}.cobalt-branding p{font-size:.66rem;letter-spacing:.18em}.cobalt-login-header h2{font-size:1.5rem}.cobalt-login-box{padding:1.5rem 1rem}.cobalt-form-group label{font-size:.8rem}.cobalt-form-group input{font-size:.9rem;padding:.8rem .9rem}.cobalt-btn-submit{font-size:.9rem;min-height:48px;padding:.95rem 1rem}.cobalt-link-button{font-size:.8rem}}@media (max-width:360px){.cobalt-branding h1{font-size:1.8rem}.cobalt-login-header h2{font-size:1.35rem}.cobalt-btn-submit{font-size:.85rem;min-height:50px;padding:.9rem .95rem}.cobalt-link-button{font-size:.75rem}}.cobalt-reset-page{background:#f9f9ff;color:#0b1c31;display:flex;flex-direction:column;font-family:Inter,sans-serif;min-height:100vh}.cobalt-reset-main{align-items:center;display:flex;flex:1 1;justify-content:center;padding:3rem 1.5rem}.cobalt-reset-container{max-width:520px;width:100%}.cobalt-reset-branding{margin-bottom:2.8rem;text-align:center}.cobalt-reset-branding h1{color:#04152b;font-family:Newsreader,serif;font-size:2.7rem;font-weight:700;letter-spacing:-.02em;margin:0}.cobalt-reset-logo-link{color:inherit;text-decoration:none}.cobalt-reset-logo-link:hover{text-decoration:none}.cobalt-reset-branding p{color:#44474d;font-family:Inter,sans-serif;font-size:.72rem;letter-spacing:.2em;margin:.55rem 0 0;text-transform:uppercase}.cobalt-reset-card{background:#fff;border:1px solid #c4c6cd33;border-radius:0;box-shadow:0 24px 48px #0b1c310f;padding:2.5rem 2.35rem}.cobalt-reset-header h1{color:#0b1c31;font-family:Newsreader,serif;font-size:2rem;font-weight:700;margin:0;text-align:center}.cobalt-reset-header p{color:#44474d;font-size:.9rem;line-height:1.5;margin-bottom:1.75rem;margin-top:.85rem;text-align:center}.reset-alert{border:1px solid #0000;font-size:.9rem;margin-bottom:1rem;padding:.75rem}.reset-alert-success{background-color:#15803d1f;border-color:#16653447;color:#166534}.reset-alert-error{background-color:#b91c1c1a;border-color:#ffdad6;color:#ba1a1a}.cobalt-reset-form{display:flex;flex-direction:column;gap:1.25rem}.cobalt-reset-field{display:flex;flex-direction:column;gap:.55rem}.cobalt-reset-field label{color:#0b1c31;font-family:Inter,sans-serif;font-size:.72rem;font-weight:700;letter-spacing:.09em;text-transform:uppercase}.cobalt-reset-field input{background:#0000;border:1px solid #c4c6cd8c;border-radius:0;color:#0b1c31;font-family:Inter,sans-serif;font-size:.95rem;padding:.78rem .95rem;transition:all .2s ease}.cobalt-reset-field input:focus{border-color:#04152b;box-shadow:0 0 0 1px #04152b;outline:none}.cobalt-reset-field input:disabled{background:#eff3ff;cursor:not-allowed;opacity:.75}.cobalt-reset-field input::placeholder{color:#44474d8c}.cobalt-reset-btn{align-items:center;background:#1a2a40;border:none;border-radius:0;color:#fff;cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.8rem;font-weight:700;justify-content:center;letter-spacing:.09em;margin-top:.45rem;padding:.95rem;text-transform:uppercase;transition:all .2s ease}.cobalt-reset-btn:hover:not(:disabled){filter:brightness(1.1)}.cobalt-reset-btn:disabled{cursor:not-allowed;opacity:.55}.cobalt-reset-meta{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between;margin-top:.3rem}.cobalt-reset-meta p{color:#44474d;font-size:.82rem;margin:0}.cobalt-reset-nav{margin-top:1.1rem}.cobalt-reset-link{background:none;border:none;color:#04152b;cursor:pointer;font-family:Inter,sans-serif;font-size:.77rem;font-weight:700;letter-spacing:.02em;padding:0;text-transform:uppercase;transition:color .2s ease}.cobalt-reset-link:hover:not(:disabled){color:#1a2a40;text-decoration:underline}.cobalt-reset-link:disabled{cursor:not-allowed;opacity:.6}.cobalt-reset-prism{background:#dde9ff;border-left:2px solid #e9c176;margin-top:1.4rem;padding:.85rem .85rem .85rem 1rem}.cobalt-reset-prism p{color:#44474d;font-size:.8rem;font-style:italic;margin:0}@media (max-width:640px){.cobalt-reset-main{padding:2rem 1rem}.cobalt-reset-branding{margin-bottom:2rem}.cobalt-reset-branding h1{font-size:2.25rem}.cobalt-reset-card{padding:2rem 1.2rem}.cobalt-reset-header h1{font-size:1.8rem}}@media (max-width:480px){.cobalt-reset-main{align-items:flex-start;padding-top:2.8rem}.cobalt-reset-branding h1{font-size:2rem}.cobalt-reset-branding p{font-size:.66rem;letter-spacing:.18em}.cobalt-reset-header h1{font-size:1.65rem}}.spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:14px;margin-right:8px;vertical-align:middle;width:14px}.spinner-dark{border:2px solid #0000001a;border-top:2px solid var(--color-primary)}.spinner-large{border:4px solid #1e3a8a1a;border-top:4px solid var(--color-primary);height:40px;margin:20px auto;width:40px}button.loading{align-items:center;display:inline-flex;justify-content:center;pointer-events:none;position:relative}.loading-container{color:var(--color-text-secondary);padding:60px 20px}.loading-container p{font-size:14px;margin-top:16px}.header{background:var(--color-primary);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-md);position:-webkit-sticky;position:sticky;top:0;width:100%;z-index:1000}.header-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:var(--spacing-sm) var(--spacing-lg)}.logo{color:var(--color-text-white);text-decoration:none;transition:var(--transition-base)}.logo:hover{opacity:.9}.logo h1{font-size:1.75rem;font-weight:700;letter-spacing:-.5px;margin:0}.nav{align-items:center;display:flex;gap:var(--spacing-md)}.nav-link{border-radius:var(--radius-sm);color:var(--color-text-white);font-size:.95rem;font-weight:500;opacity:.9;padding:var(--spacing-xs) var(--spacing-sm);position:relative;text-decoration:none}.nav-link,.nav-link:after{transition:var(--transition-base)}.nav-link:after{background:var(--color-text-white);bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);width:0}.nav-link:hover{background:#ffffff1a;opacity:1}.nav-link:hover:after{width:60%}@media (max-width:768px){.header-container{padding:var(--spacing-sm) var(--spacing-md)}.logo h1{font-size:1.5rem}.nav{gap:var(--spacing-sm)}.nav-link{font-size:.9rem}}@media (max-width:480px){.header-container{flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-sm)}.logo h1{font-size:1.35rem}.nav{gap:var(--spacing-sm);justify-content:center;width:100%}.nav-link{font-size:.85rem;padding:var(--spacing-xs)}}.verify-page{background-color:var(--color-background);display:flex;flex-direction:column;min-height:100vh}.verify-main{align-items:center;display:flex;flex:1 1;justify-content:center;padding:var(--spacing-lg) var(--spacing-sm)}.verify-container{max-width:480px;width:100%}.verify-box{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-xl)}.verify-box h2{color:var(--color-text-primary);font-size:1.75rem;font-weight:700;margin-bottom:var(--spacing-xs);text-align:center}.verify-subtitle{color:var(--color-text-secondary);font-size:.95rem;line-height:1.6;margin-bottom:var(--spacing-lg);text-align:center}.alert{border-radius:var(--radius-md);margin-bottom:var(--spacing-md);padding:var(--spacing-sm)}.alert-success{background-color:#15803d1a;border:1px solid var(--color-success-light);color:var(--color-success)}.alert-error{background-color:#b91c1c1a;border:1px solid var(--color-error-light);color:var(--color-error)}.verify-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group input{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:Courier New,monospace;font-size:1.5rem;letter-spacing:.5rem;padding:1rem;text-align:center;transition:var(--transition-base)}.form-group input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a8a1a}.form-group input:disabled{background-color:var(--color-background);opacity:.6}.btn-submit{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;justify-content:center;margin-top:var(--spacing-xs);padding:var(--spacing-sm);transition:var(--transition-base)}.btn-submit:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:0 8px 16px #1e3a8a40;transform:translateY(-2px)}.btn-submit:disabled{cursor:not-allowed;opacity:.5}.verify-footer{border-top:1px solid var(--color-border);margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);text-align:center}.verify-footer p{color:var(--color-text-secondary);font-size:.9rem;margin-bottom:var(--spacing-sm)}.link-button{align-items:center;background:none;border:none;color:var(--color-primary);cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;justify-content:center;padding:0;text-decoration:underline}.link-button:hover:not(:disabled){color:var(--color-primary-dark)}.link-button:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.verify-box{padding:var(--spacing-lg)}.verify-box h2{font-size:1.5rem}}@media (max-width:480px){.verify-main{padding:var(--spacing-sm) var(--spacing-xs)}.verify-box{padding:var(--spacing-md)}.form-group input,.verify-box h2{font-size:1.25rem}}.profile-container{margin:30px auto;max-width:900px;padding:0 15px}.profile-nav{border-bottom:2px solid #e9ecef;justify-content:space-between;margin-bottom:30px;padding:20px 0}.btn-back,.profile-nav{align-items:center;display:flex}.btn-back{background-color:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;gap:8px;padding:10px 16px;transition:all .2s}.btn-back:hover{background-color:#5c636a;box-shadow:0 4px 8px #6c757d4d;transform:translateY(-2px)}.profile-header{border-bottom:2px solid #e9ecef;margin-bottom:30px;padding:20px 0;text-align:center}.profile-icon{color:#666;font-size:48px;margin-bottom:15px}.profile-header h1{color:#333;font-size:28px;margin:0 0 5px}.profile-header p{color:#666;font-size:14px;margin:5px 0 0}.profile-content{animation:fadeIn .3s ease-in}.profile-card{background:linear-gradient(135deg,#fff,#f8f9fa);border:1px solid #e0e4e8;border-radius:12px;box-shadow:0 2px 16px #00000014;overflow:hidden;transition:all .3s ease}.profile-card:hover{box-shadow:0 8px 24px #0000001f}.profile-card-header{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:1px solid #e0e4e8;display:flex;gap:15px;justify-content:space-between;padding:25px 30px}.profile-card-header h2{color:#333;font-size:22px;font-weight:700;margin:0}.profile-form{padding:30px}.form-group{margin-bottom:22px}.form-group label{color:#2c3e50;display:block;font-size:13px;letter-spacing:.5px;margin-bottom:10px;text-transform:uppercase}.form-group input{background-color:#fafbfc;border:1px solid #e0e4e8;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:all .3s ease;width:100%}.form-group select{-webkit-appearance:none;appearance:none;background-color:#fafbfc;border:2px solid #e0e4e8;border:1px solid #e0e4e8;border-radius:8px;border-radius:6px;font-family:inherit;font-size:15px;font-size:14px;padding:14px 16px;padding:10px 12px;transition:all .3s ease;width:100%}.form-group input:focus{background-color:#fff;border-color:#666;box-shadow:0 0 0 3px #6666661a;outline:none}.form-group select:focus{background-color:#fff;border-color:#666;box-shadow:0 0 0 4px #6666661a;box-shadow:0 0 0 3px #6666661a;outline:none}.form-group input:disabled,.form-group select:disabled{background-color:#f0f2f5;border-color:#e0e4e8;color:#666;cursor:not-allowed}.readonly-field{background-color:#f3f4f6!important;border:1px dashed #d1d5db;color:#4b5563;cursor:not-allowed}.readonly-field:focus{border-color:#d1d5db;box-shadow:none;outline:none}.readonly-select{background-color:#f3f4f6!important;border:1px dashed #d1d5db;color:#4b5563}.readonly-select:focus{border-color:#d1d5db;box-shadow:none;outline:none}.form-group small{color:#999;display:block;font-size:12px;margin-top:6px}.form-actions{border-top:2px solid #e9ecef;gap:12px;margin-top:35px;padding-top:25px}.form-actions .btn{flex:1 1}.profile-view{padding:40px}.profile-field{border-bottom:1px solid #e9ecef;margin-bottom:28px;padding-bottom:22px}.profile-field:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.profile-field label{color:#2c3e50;display:block;font-size:11px;font-weight:700;letter-spacing:.8px;margin-bottom:10px;text-transform:uppercase}.profile-field p{color:#333;font-size:16px;margin:0;word-break:break-all}.profile-field input,.profile-field select{background-color:#fff;border:1px solid #e0e4e8;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:all .3s ease;width:100%}.profile-field input:focus,.profile-field select:focus{border-color:#666;box-shadow:0 0 0 3px #6666661a;outline:none}.profile-field .status-badge{border-radius:6px;display:inline-block;font-size:12px;font-weight:600;padding:8px 14px}.status-approved{background-color:#d4edda;color:#155724}.status-rejected{background-color:#f8d7da;color:#721c24}.btn{font-family:inherit;font-size:15px;gap:8px;padding:12px 18px;transition:all .3s ease}.btn:disabled{cursor:not-allowed;opacity:.5;transform:none!important}.btn-primary{background:linear-gradient(135deg,#495057,#3d444d)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#3d444d,#2d3238);box-shadow:0 8px 16px #4950574d;transform:translateY(-2px)}.btn-secondary{background:linear-gradient(135deg,#6c757d,#5c636a)}.btn-secondary:hover:not(:disabled){background:linear-gradient(135deg,#5c636a,#4c555a);box-shadow:0 8px 16px #6c757d4d;transform:translateY(-2px)}.alert{animation:slideIn .3s ease-in;border-left:4px solid;font-size:14px;margin-bottom:20px;padding:15px 18px}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alert-error{background-color:#ffe5e5;border-left-color:#dc3545;color:#721c24}.alert-success{background-color:#e5f5e5;border-left-color:#28a745;color:#155724}.profile-images-section{border-bottom:2px solid #e9ecef;display:flex;flex-wrap:wrap;gap:40px;justify-content:center;margin-bottom:40px;padding-bottom:35px}.profile-image-wrapper{text-align:center}.profile-image-wrapper label{color:#2c3e50;display:block;font-size:11px;font-weight:700;letter-spacing:.8px;margin-bottom:15px;text-transform:uppercase}.profile-picture-container{align-items:center;background:linear-gradient(135deg,#f0f0f0,#e0e0e0);border:3px solid #999;border-radius:50%;box-shadow:0 4px 15px #0000001a;color:#999;cursor:pointer;display:flex;font-size:50px;height:140px;justify-content:center;margin:0 auto 15px;overflow:hidden;transition:all .3s ease;width:140px}.profile-picture-container:hover{box-shadow:0 6px 20px #00000026;transform:scale(1.05)}.profile-picture-container img{height:100%;object-fit:cover;width:100%}.signature-container{align-items:center;background:linear-gradient(135deg,#fafafa,#f0f0f0);border:2px dashed #ccc;border-radius:8px;cursor:pointer;display:flex;justify-content:center;margin:0 auto 15px;max-width:280px;min-height:120px;padding:12px;transition:all .3s ease}.signature-container:hover{background:linear-gradient(135deg,#f0f0f0,#e0e0e0);border-color:#999}.signature-container img{max-height:100%;max-width:100%;object-fit:contain}.profile-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:25px}.password-change-section{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #e0e4e8;border-radius:10px;margin-bottom:25px;padding:25px}.password-change-section label{color:#2c3e50;display:block;font-size:11px;font-weight:700;letter-spacing:.8px;margin-bottom:15px;text-transform:uppercase}.password-inputs{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.password-inputs input{background-color:#fff;border:1px solid #e0e4e8;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:all .3s ease}.password-inputs input:focus{border-color:#666;box-shadow:0 0 0 3px #6666661a;outline:none}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:400px}@media (max-width:600px){.profile-container{margin:20px auto;padding:10px}.profile-card-header{align-items:flex-start;flex-direction:column;gap:15px;padding:20px}.profile-form,.profile-view{padding:20px}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.profile-images-section{flex-direction:column;gap:20px}.password-inputs,.profile-grid{grid-template-columns:1fr}}.course-form-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:var(--spacing-sm);position:fixed;right:0;top:0;z-index:1000}.course-form-container{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);font-family:Arial,Helvetica,sans-serif;letter-spacing:0;max-height:90vh;max-width:700px;overflow-y:auto;width:100%}.course-form-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.course-form-header h3{color:var(--color-text-primary);font-family:Arial,Helvetica,sans-serif;font-size:1.5rem;font-weight:700;letter-spacing:0;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;transition:var(--transition-base);width:32px}.close-btn:hover:not(:disabled){background-color:var(--color-background)}.close-btn:disabled{cursor:not-allowed;opacity:.5}.course-form{display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg)}.form-row{grid-gap:var(--spacing-sm);display:grid;gap:var(--spacing-sm);grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-group label{font-size:.9rem;font-weight:600}.form-group input,.form-group label,.form-group select{color:var(--color-text-primary);font-family:Arial,Helvetica,sans-serif;letter-spacing:0}.form-group input,.form-group select{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.95rem;padding:var(--spacing-xs);transition:var(--transition-base)}.form-group input:focus,.form-group select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a8a1a;outline:none}.form-group input:disabled,.form-group select:disabled{background-color:var(--color-background);cursor:not-allowed;opacity:.6}.form-group input::placeholder{color:var(--color-text-light)}.error-text{color:var(--color-error);display:block;font-size:.8rem;margin-top:-.25rem}.course-content-item,.error-text,.lecture-plan-item{text-align:left}.course-content-item label,.lecture-plan-item label{display:block;margin-bottom:var(--spacing-xs);text-align:left}.checkbox-label{display:flex;gap:var(--spacing-xs);-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{height:18px;width:18px}.checkbox-label span{color:var(--color-text-primary);font-size:.9rem;font-weight:500}.form-actions{align-items:center;border-top:1px solid var(--color-border);display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-sm);padding-top:var(--spacing-md)}.btn-cancel,.btn-submit{align-items:center;border:none;border-radius:var(--radius-md);box-sizing:border-box;cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;height:2.5rem;justify-content:center;padding:0 var(--spacing-md);transition:var(--transition-base);white-space:nowrap}.btn-cancel{background-color:var(--color-background);color:var(--color-text-primary)}.btn-cancel:hover:not(:disabled){background-color:var(--color-border)}.btn-submit{background:var(--color-primary);box-shadow:var(--shadow-md);color:var(--color-text-white);transform:translateY(-2px)}.btn-submit:hover:not(:disabled){background:var(--color-primary-dark)}.btn-cancel:disabled,.btn-submit:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.course-form-overlay{padding:0}.course-form-container{border-radius:0;max-height:100vh}.form-row{grid-template-columns:1fr}.course-form-header{padding:var(--spacing-sm) var(--spacing-md)}.course-form{padding:var(--spacing-md)}}@media (max-width:480px){.course-form-header h3{font-size:1.25rem}.course-form{gap:var(--spacing-sm);padding:var(--spacing-sm)}.form-actions{flex-direction:row;justify-content:space-between}.btn-cancel,.btn-submit{flex:1 1;width:auto}}.obe-toggle-section{margin:var(--spacing-md) 0}.btn-toggle-obe{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);text-align:left;transition:var(--transition-base);width:100%}.btn-toggle-obe:hover:not(:disabled){box-shadow:var(--shadow-md);transform:translateY(-2px)}.obe-fields-section{background:var(--color-background);border-radius:var(--radius-md);margin-top:var(--spacing-sm);padding:var(--spacing-md)}.obe-fields-section h4{color:var(--color-primary);font-size:1.1rem;font-weight:700;margin:0 0 var(--spacing-md) 0}.form-section{margin:var(--spacing-md) 0;padding:var(--spacing-sm) 0}.section-label{display:block;font-size:.95rem;margin-bottom:var(--spacing-xs)}.form-section h4,.section-label{color:var(--color-text-primary);font-family:Arial,Helvetica,sans-serif;font-weight:700;letter-spacing:0;text-align:left}.form-section h4{font-size:1rem;margin:0 0 var(--spacing-md) 0}.course-section-header{align-items:flex-start;display:flex;gap:var(--spacing-sm);justify-content:space-between;margin-bottom:var(--spacing-sm)}.course-section-header .section-label{flex:1 1;padding-top:2px}.course-section-header h4{color:var(--color-text-primary);flex:1 1;font-family:Arial,Helvetica,sans-serif;font-size:1rem;font-weight:700;letter-spacing:0;margin:0;padding-top:2px;text-align:left}.btn-add-small{background:var(--color-primary);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:4px 12px;transition:var(--transition-base)}.btn-add-small:hover:not(:disabled){background:var(--color-primary-dark)}.btn-remove-small{background:var(--color-error);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.85rem;padding:4px 10px;transition:var(--transition-base)}.btn-remove-small:hover:not(:disabled){background:#c53030}.array-item{align-items:flex-start;display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-xs);text-align:left}.array-item input{border:1px solid var(--color-border);border-radius:var(--radius-md);flex:1 1;font-size:.9rem;padding:var(--spacing-xs);text-align:left}.helper-text{display:block;margin-top:var(--spacing-xs);text-align:left}.form-section p{margin:0;padding:0;text-align:left}.form-section .info-text{color:#666;display:block;font-size:14px;margin-bottom:10px;text-align:left}textarea{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:Arial,Helvetica,sans-serif;font-size:.95rem;letter-spacing:0;min-height:80px;padding:var(--spacing-xs);resize:vertical;transition:var(--transition-base)}textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1e3a8a1a;outline:none}textarea:disabled{background-color:var(--color-background);cursor:not-allowed;opacity:.6}.course-outcomes-section{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);margin:var(--spacing-md) 0;padding:var(--spacing-sm)}.course-outcomes-section h4{color:var(--color-text-primary);font-size:1rem;font-weight:700;margin:0}.empty-message{color:var(--color-text-secondary);font-style:italic;padding:var(--spacing-lg);text-align:center}.co-list{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.co-item{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;transition:var(--transition-base)}.co-item.expanded{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.co-header{align-items:center;background:var(--color-background);cursor:pointer;display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm);transition:var(--transition-base)}.co-header:hover{background:var(--color-border)}.co-number{min-width:50px}.co-preview{color:var(--color-text-primary);flex:1 1;font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.co-details{background:#fff;border-top:1px solid var(--color-border);padding:var(--spacing-md)}.po-mapping-section{background:var(--color-background);border-radius:var(--radius-md);margin-top:var(--spacing-md);padding:var(--spacing-sm)}.po-mapping-section label{color:var(--color-text-primary);display:block;font-size:.9rem;font-weight:600;margin-bottom:var(--spacing-sm)}.po-mapping-grid{grid-gap:var(--spacing-sm);display:grid;gap:var(--spacing-sm);grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.po-mapping-item{align-items:center;display:flex;flex-direction:column;gap:4px}.po-label{color:var(--color-primary);cursor:help;font-size:.85rem;font-weight:600}.po-mapping-item select{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;font-size:.85rem;padding:4px;width:100%}.po-mapping-item select.mapped{background:#e3f2fd;border-color:var(--color-primary);font-weight:600}.mapping-legend{color:var(--color-text-secondary);display:flex;font-size:.8rem;gap:var(--spacing-md);margin-bottom:var(--spacing-sm)}.mapping-legend span{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px 8px}.helper-text{font-size:.85rem}.helper-text,.loading-message{color:var(--color-text-secondary);font-style:italic}.loading-message{padding:var(--spacing-md);text-align:center}.co-item.has-error{border-color:#ef5350}.co-item.has-error .co-header{background:#ffebee}.co-item.has-warning{border-color:#ffa726}.co-item.has-warning .co-header{background:#fff8e1}.error-indicator{color:#ef5350}.error-indicator,.warning-indicator{font-size:1.2rem;margin-left:auto;margin-right:var(--spacing-xs)}.warning-indicator{color:#ffa726}.validation-errors{background:#ffebee;border-left:3px solid #ef5350;border-radius:var(--radius-sm);margin-top:var(--spacing-sm);padding:var(--spacing-sm)}.error-message{color:#c62828;font-size:.85rem;margin:4px 0}.warning-message{color:#856404;font-size:.85rem;margin:4px 0}.co-summary{background:var(--color-background);border-radius:var(--radius-md);font-size:.9rem;margin-top:var(--spacing-md);padding:var(--spacing-sm)}.co-summary p{margin:4px 0}.warning-text{color:#f57c00;font-weight:600}.taxonomy-section{background:#f5f5f5;border-radius:var(--radius-md);margin-top:var(--spacing-md);padding:var(--spacing-sm)}.taxonomy-section>label{color:var(--color-text-primary);display:block;font-size:.9rem;font-weight:600;margin-bottom:var(--spacing-sm)}.taxonomy-categories{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.taxonomy-category{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--spacing-sm)}.taxonomy-category h5{color:var(--color-primary);font-size:.85rem;font-weight:600;margin:0 0 var(--spacing-xs) 0;text-transform:uppercase}.taxonomy-checkboxes{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.checkbox-label{align-items:center;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-size:.8rem;gap:4px;padding:4px 8px;transition:var(--transition-base)}.checkbox-label:hover{background:#e3f2fd;border-color:var(--color-primary)}.checkbox-label input[type=checkbox]{cursor:pointer;margin:0}.checkbox-label input[type=checkbox]:checked+span{color:var(--color-primary);font-weight:600}.checkbox-label span{-webkit-user-select:none;user-select:none}.autocomplete-suggestions{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);left:0;margin-top:2px;max-height:250px;overflow-y:auto;position:absolute;right:40px;top:100%;z-index:1000}.suggestion-item{border-bottom:1px solid #f0f0f0;cursor:pointer;font-size:.9rem;padding:10px 12px;text-align:left;transition:background-color .2s}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background-color:#f5f5f5}.suggestion-item strong{color:var(--color-primary);font-weight:600;margin-right:8px}.obe-view-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:var(--spacing-sm);position:fixed;right:0;top:0;z-index:1000}.obe-view-container{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:90vh;max-width:1200px;width:100%}.obe-view-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg)}.obe-view-header h3{color:var(--color-text-primary);font-size:1.5rem;font-weight:700;margin:0}.obe-tabs{background:var(--color-background);border-bottom:2px solid var(--color-border);display:flex}.tab-btn{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;flex:1 1;font-size:.95rem;font-weight:600;padding:var(--spacing-sm) var(--spacing-md);position:relative;transition:var(--transition-base)}.tab-btn:hover{background:#1e3a8a0d}.tab-btn.active,.tab-btn:hover{color:var(--color-primary)}.tab-btn.active:after{background:var(--color-primary);bottom:-2px;content:"";height:2px;left:0;position:absolute;right:0}.obe-content{flex:1 1;overflow-y:auto;padding:var(--spacing-lg)}.obe-overview{display:flex;flex-direction:column;gap:var(--spacing-lg)}.info-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.info-item label{color:var(--color-text-secondary);font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-item span{color:var(--color-text-primary);font-size:1rem}.badge{border-radius:var(--radius-sm);display:inline-block;font-size:.85rem;font-weight:600;padding:4px 12px}.badge-core{background:#dbeafe;color:#1e3a8a}.badge-optional{background:#fef3c7;color:#92400e}.badge-lab{background:#d1fae5;color:#065f46}.assessment-section,.cos-section,.credit-breakdown,.description-section,.prerequisites-section{background:var(--color-background);border-radius:var(--radius-md);padding:var(--spacing-md)}.assessment-section h4,.cos-section h4,.credit-breakdown h4,.description-section h4,.prerequisites-section h4{color:var(--color-primary);font-size:1rem;font-weight:700;margin:0 0 var(--spacing-md) 0}.assessment-grid,.breakdown-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(3,1fr)}.assessment-item,.breakdown-item{text-align:center}.assessment-label,.breakdown-label{color:var(--color-text-secondary);display:block;font-size:.85rem;margin-bottom:4px}.assessment-value,.breakdown-value{color:var(--color-primary);display:block;font-size:1.5rem;font-weight:700}.description-section p{color:var(--color-text-primary);line-height:1.6;margin:0}.prerequisites-list{display:flex;flex-wrap:wrap;gap:var(--spacing-xs)}.prerequisite-badge{background:var(--color-primary);border-radius:var(--radius-sm);color:#fff;font-size:.9rem;font-weight:600;padding:6px 12px}.cos-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.co-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-sm)}.co-header-inline{align-items:center;display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.co-number{color:var(--color-primary);font-size:.9rem;font-weight:700}.bloom-badge{background:#e0e7ff;border-radius:var(--radius-sm);color:#3730a3;font-size:.75rem;font-weight:600;padding:2px 8px}.co-description{color:var(--color-text-primary);line-height:1.5;margin:0}.copo-matrix-view{display:flex;flex-direction:column;gap:var(--spacing-md)}.matrix-table-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow-x:auto}.matrix-table{background:#fff;border-collapse:collapse;width:100%}.matrix-table td,.matrix-table th{border:1px solid var(--color-border);font-size:.85rem;padding:var(--spacing-xs);text-align:center}.matrix-table th{background:var(--color-primary);color:#fff;font-weight:700;position:-webkit-sticky;position:sticky;top:0;z-index:10}.co-cell{color:var(--color-primary);font-weight:700}.description-cell{max-width:300px;text-align:left}.bloom-cell{color:var(--color-text-secondary);font-size:.8rem}.mapping-cell{font-weight:600}.mapping-cell.level-0{background:#f3f4f6;color:#9ca3af}.mapping-cell.level-1{background:#dbeafe;color:#1e40af}.mapping-cell.level-2{background:#bfdbfe;color:#1e3a8a}.mapping-cell.level-3{background:#93c5fd;color:#1e3a8a;font-weight:700}.average-row,.totals-row{background:var(--color-background)}.average-cell,.total-cell{color:var(--color-primary);font-weight:700}.legend{background:var(--color-background);border-radius:var(--radius-md);padding:var(--spacing-md)}.legend h5{font-size:.9rem;font-weight:700;margin:0 0 var(--spacing-sm) 0}.legend-items{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.legend-item{align-items:center;display:flex;font-size:.85rem;gap:var(--spacing-xs)}.level-box{align-items:center;border-radius:var(--radius-sm);display:inline-block;display:flex;font-weight:700;height:30px;justify-content:center;width:30px}.validation-view{display:flex;flex-direction:column;gap:var(--spacing-md)}.validation-status{border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center}.validation-status.valid{background:#d1fae5;color:#065f46}.validation-status.invalid{background:#fee2e2;color:#991b1b}.validation-status h4{font-size:1.25rem;margin:0}.validation-section{border-radius:var(--radius-md);padding:var(--spacing-md)}.validation-section.errors{background:#fef2f2;border-left:4px solid #dc2626}.validation-section.warnings{background:#fffbeb;border-left:4px solid #f59e0b}.validation-section h5{font-size:1rem;font-weight:700;margin:0 0 var(--spacing-sm) 0}.validation-section ul{list-style:none;margin:0;padding-left:var(--spacing-md)}.error-item,.warning-item{padding:var(--spacing-xs) 0;position:relative}.error-item:before{color:#dc2626;content:"✕";font-weight:700;left:-20px;position:absolute}.warning-item:before{color:#f59e0b;content:"⚠";left:-20px;position:absolute}.success-message{background:var(--color-background);border-radius:var(--radius-md);padding:var(--spacing-lg);text-align:center}.success-message p{color:var(--color-text-primary);font-size:1rem;margin:0}.validation-details{background:var(--color-background);border-radius:var(--radius-md);padding:var(--spacing-md)}.validation-details h5{font-size:1rem;font-weight:700;margin:0 0 var(--spacing-sm) 0}.detail-item{padding:var(--spacing-xs) 0}.detail-item strong{color:var(--color-text-primary)}.detail-item span,.empty-state,.loading-spinner{color:var(--color-text-secondary)}.empty-state,.loading-spinner{font-size:1rem;padding:var(--spacing-xl);text-align:center}.section-card{background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 1px 3px #0000000d;padding:var(--spacing-lg)}.section-card.half-width{flex:1 1;min-width:300px}.section-row{display:flex;flex-wrap:wrap;gap:var(--spacing-lg)}.section-title{border-bottom:2px solid var(--color-primary-light);color:var(--color-primary);font-size:1.1rem;font-weight:600;margin:0 0 var(--spacing-md) 0;padding-bottom:var(--spacing-sm)}.info-value{color:var(--color-text-primary);font-weight:500}.info-value.highlight{color:var(--color-primary);font-size:1.1em;font-weight:700}.badges-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.badge-purple{background-color:#7c3aed;color:#fff}.badge-success{background-color:#10b981;color:#fff}.badge-info{background-color:#3b82f6}.badge-outline{background-color:initial;border:2px solid var(--color-primary);color:var(--color-primary)}.bullet-list{list-style-type:disc;margin:0;padding-left:var(--spacing-lg)}.bullet-list li{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-sm)}.numbered-list{counter-reset:item;margin:0;padding-left:var(--spacing-lg)}.numbered-list li{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-md)}.content-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.content-item{background:var(--color-background);border-left:3px solid var(--color-primary);border-radius:var(--radius-sm);padding:var(--spacing-md)}.content-name{color:var(--color-text-primary);font-size:1rem;font-weight:600;margin:0 0 var(--spacing-xs) 0}.content-description{color:var(--color-text-secondary);line-height:1.5;margin:0}.lecture-plan-table{overflow-x:auto}.lecture-plan-table table{border-collapse:collapse;width:100%}.lecture-plan-table thead{background:var(--color-primary)}.lecture-plan-table th{border-bottom:2px solid var(--color-primary);color:#fff;font-weight:600;padding:var(--spacing-sm) var(--spacing-md);text-align:left}.lecture-plan-table td{border-bottom:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-md)}.lecture-plan-table tbody tr:hover{background-color:var(--color-background)}.week-cell{color:var(--color-primary);font-weight:600;white-space:nowrap}.references-list{margin:0;padding-left:var(--spacing-lg)}.references-list li{color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-md)}.kpa-table-wrapper{overflow-x:auto}.kpa-table{border-collapse:collapse;width:100%}.kpa-table td{border:1px solid #ddd;padding:var(--spacing-md)}.kpa-grid-all{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.kpa-item{align-items:center;background:var(--color-background);border-radius:var(--radius-sm);display:flex;gap:4px;padding:4px 8px}.kpa-checked{color:#4caf50;font-size:1.2rem;font-weight:700}.kpa-unchecked{color:#ccc;font-size:1.2rem}.kpa-label{color:var(--color-text-primary);font-size:.9rem;font-weight:600}.co-table-wrapper{overflow-x:auto}.co-table{border-collapse:collapse;font-size:.9rem;width:100%}.co-table thead{background:var(--color-primary);color:#fff}.co-table th{font-weight:600;text-align:left}.co-table td,.co-table th{border:1px solid #ddd;padding:var(--spacing-sm) var(--spacing-md)}.co-table td{vertical-align:top}.co-table tbody tr:hover{background-color:#f5f5f5}.co-number-cell{color:var(--color-primary);font-weight:600;text-align:center;white-space:nowrap;width:60px}.co-statement-cell{color:var(--color-text-primary);line-height:1.6;min-width:300px}.co-pos-cell{white-space:nowrap;width:150px}.co-pos-cell,.co-taxonomy-cell{color:var(--color-text-secondary);text-align:center}.co-taxonomy-cell{width:180px}@media (max-width:768px){.obe-view-overlay{padding:0}.obe-view-container{border-radius:0;max-height:100vh}.assessment-grid,.breakdown-grid,.info-grid{grid-template-columns:1fr}.section-row{flex-direction:column}.section-card.half-width{width:100%}.matrix-table{font-size:.75rem}.matrix-table td,.matrix-table th{padding:4px}.description-cell{font-size:.75rem;max-width:150px}}.ct-obtained-table{border:1px solid #ddd;border-collapse:collapse;border-radius:8px;min-width:900px;overflow:hidden;width:100%}.ct-obtained-table td,.ct-obtained-table th{border:1px solid #ddd;padding:10px 12px;text-align:center}.ct-obtained-table th{background-color:#2980b9;color:#fff;font-weight:600}.ct-obtained-table .roll-cell{background-color:#ecf0f1;color:#2c3e50;font-weight:600;padding-left:12px;text-align:left}.ct-obtained-table .row-total{background-color:#f8f9fa;font-weight:600}.ct-obtained-table input[type=number]{border:1px solid #bdc3c7;border-radius:4px;font-size:14px;padding:6px 8px;width:80px}.attainment-container{margin:0 auto;max-width:1400px;padding:20px}.attainment-container h1{color:#2c3e50;font-size:28px;margin-bottom:30px}.attainment-container h2{border-bottom:2px solid #3498db;color:#34495e;font-size:20px;margin-bottom:15px;padding-bottom:8px}.attainment-empty,.attainment-error{font-size:18px;padding:40px;text-align:center}@keyframes attainment-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes attainment-spin-reverse{0%{transform:rotate(0deg)}to{transform:rotate(-1turn)}}.attainment-spinner{align-items:center;display:inline-flex;justify-content:center;position:relative}.attainment-spinner--lg{height:72px;width:72px}.attainment-spinner--md{height:40px;width:40px}.attainment-spinner__ring{animation:attainment-spin .9s cubic-bezier(.4,0,.2,1) infinite;border-color:#3498db #2ecc71 #0000 #0000;border-radius:50%;border-style:solid;border-width:4px;inset:0;position:absolute}.attainment-spinner--md .attainment-spinner__ring{border-width:3px}.attainment-spinner__ring--delay{animation-duration:.7s;animation-name:attainment-spin-reverse;border-bottom-color:#9b59b6;border-left-color:#e74c3c;border-top-color:#0000;inset:8px}.attainment-spinner--md .attainment-spinner__ring--delay{inset:6px}@keyframes attainment-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.attainment-page-loader{align-items:center;background:linear-gradient(135deg,#f0f4f8,#e8f4fd);display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}.attainment-page-loader__inner{align-items:center;animation:attainment-fade-in .4s ease both;display:flex;flex-direction:column;gap:20px}.attainment-page-loader__text{animation:attainment-pulse 1.6s ease-in-out infinite;color:#34495e;font-size:16px;font-weight:500;letter-spacing:.02em;margin:0}@keyframes attainment-pulse{0%,to{opacity:1}50%{opacity:.45}}.attainment-sheet-loader{align-items:center;animation:attainment-fade-in .3s ease both;display:flex;gap:14px;justify-content:center;padding:48px 24px}.attainment-sheet-loader__label{animation:attainment-pulse 1.4s ease-in-out infinite;color:#555;font-size:15px;font-weight:500}@keyframes attainment-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.attainment-skeleton-wrap{animation:attainment-fade-in .3s ease both;padding:24px 0}.attainment-skeleton-header{animation:attainment-shimmer 1.4s linear infinite;background:linear-gradient(90deg,#e8edf2 25%,#d0dae4 50%,#e8edf2 75%);background-size:800px 100%;border-radius:6px;height:28px;margin-bottom:20px;width:260px}.attainment-skeleton-table{border-collapse:collapse;width:100%}.attainment-skeleton-table td,.attainment-skeleton-table th{border:1px solid #eaecf0;padding:10px 12px}.attainment-skeleton-table thead th{background:#f0f4f8}.attainment-skeleton-cell{animation:attainment-shimmer 1.4s linear infinite;background:linear-gradient(90deg,#e8edf2 25%,#d0dae4 50%,#e8edf2 75%);background-size:800px 100%;border-radius:4px;height:14px}.attainment-skeleton-cell--th{background:linear-gradient(90deg,#d6dfe8 25%,#bfccd9 50%,#d6dfe8 75%);background-size:800px 100%;height:16px}.attainment-loading-banner{align-items:center;animation:attainment-fade-in .25s ease both;background:linear-gradient(90deg,#eaf4ff,#f0faf4);border:1px solid #bee3f8;border-radius:8px;display:flex;gap:12px;margin-bottom:16px;padding:14px 18px}.attainment-loading-banner__text{animation:attainment-pulse 1.5s ease-in-out infinite;color:#2c7be5;font-size:14px;font-weight:500;margin:0}.attainment-error{color:#e74c3c}.sheet-selector{align-items:center;display:flex;gap:10px;margin-bottom:20px}.sheet-selector label{color:#2c3e50;font-weight:600}.sheet-selector select{border:1px solid #bdc3c7;border-radius:4px;font-size:14px;min-width:200px;padding:8px 12px}.course-info-box{background:#fff3cd;border:1px solid #ffc107;border-radius:8px;margin-bottom:20px;padding:20px}.course-info-box h3{color:#856404;font-size:18px;margin-bottom:15px;margin-top:0}.course-info-box ul{list-style:none;margin:0 0 15px;padding:0}.course-info-box li{color:#856404;font-size:14px;padding:8px 0}.info-message{color:#856404;font-size:14px;font-style:italic;margin:0}section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:40px;padding:20px}.metadata-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.metadata-item{display:flex;flex-direction:column;gap:5px}.metadata-item label{color:#7f8c8d;font-size:12px;font-weight:600;text-transform:uppercase}.metadata-item span{background:#ecf0f1;border-radius:4px;color:#2c3e50;font-size:16px;padding:8px}.table-wrapper{margin-top:15px}.ct-table{border:1px solid #ddd;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.ct-table td,.ct-table th{border:1px solid #ddd;padding:10px 12px;text-align:center}.ct-table th{background-color:#2980b9;color:#fff;font-weight:600}.ct-container{align-items:flex-start;display:flex;gap:16px}.ct-side-table{border:1px solid #ddd;border-collapse:collapse;border-radius:8px;min-width:300px;overflow:hidden}.ct-side-table td,.ct-side-table th{border:1px solid #ddd;padding:8px}.ct-side-table th{background-color:#f8f9fa}.ct-side-table td:nth-child(2){text-align:center}.ct-side-table input[type=number]{box-sizing:border-box;padding:6px;width:80px}.ct-table .co-label{background-color:#ecf0f1;color:#2c3e50;font-weight:600;padding-left:12px;text-align:left}.ct-table .co-total,.ct-table .footer-label{background-color:#f8f9fa;font-weight:600}.ct-table input[type=number]{border:1px solid #bdc3c7;border-radius:4px;font-size:14px;padding:6px 8px;width:80px}.ct-section h2{border-bottom:2px solid #2980b9;padding-bottom:8px}.copo-matrix-table{border-collapse:collapse;min-width:800px;width:100%}.copo-matrix-table td,.copo-matrix-table th{border:1px solid #ddd;padding:12px;text-align:center}.copo-matrix-table th{background-color:#3498db;color:#fff;font-weight:600}.copo-matrix-table .co-label{background-color:#ecf0f1;color:#2c3e50;font-weight:600}.copo-matrix-table .matrix-value{background-color:#f8f9fa}.edit-hint{color:#7f8c8d;font-style:italic;margin-bottom:10px}.student-attainment-table{border-collapse:collapse;min-width:1000px;width:100%}.student-attainment-table td,.student-attainment-table th{border:1px solid #ddd;font-size:14px;padding:10px;text-align:center}.student-attainment-table th{background-color:#2ecc71;color:#fff;font-weight:600;position:-webkit-sticky;position:sticky;top:0;z-index:10}.student-attainment-table .roll-number{background-color:#ecf0f1;color:#2c3e50;font-weight:600;padding-left:15px;text-align:left}.student-attainment-table .po-value{background-color:#fff;position:relative}.student-attainment-table .po-value.editable{cursor:pointer;transition:background-color .2s}.student-attainment-table .po-value.editable:hover{background-color:#fff9e6}.cell-editor{align-items:center;display:flex;gap:5px;justify-content:center}.cell-editor input{border:2px solid #3498db;border-radius:4px;font-size:14px;padding:4px 8px;width:80px}.cell-editor-buttons{display:flex;gap:3px}.cell-editor-buttons button{border:none;border-radius:3px;cursor:pointer;font-size:14px;font-weight:700;padding:4px 8px;transition:background-color .2s}.cell-editor-buttons button:first-child{background-color:#2ecc71;color:#fff}.cell-editor-buttons button:first-child:hover{background-color:#27ae60}.cell-editor-buttons button:last-child{background-color:#e74c3c;color:#fff}.cell-editor-buttons button:last-child:hover{background-color:#c0392b}.cell-editor-buttons button:disabled{cursor:not-allowed;opacity:.5}.summary-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.summary-item{align-items:center;background:#f8f9fa;border-left:4px solid #9b59b6;border-radius:4px;display:flex;justify-content:space-between;padding:12px}.summary-item label{color:#2c3e50;font-weight:600}.summary-item span{color:#7f8c8d;font-size:16px}@media (max-width:768px){.attainment-container{padding:10px}.attainment-container h1{font-size:22px}.attainment-container h2{font-size:18px}.metadata-grid,.summary-grid{grid-template-columns:1fr}.table-wrapper{margin:0 -10px}}.section-a-table{border:1px solid #ddd;border-collapse:collapse;border-radius:8px;min-width:1200px;overflow:hidden;width:100%}.section-a-table td,.section-a-table th{border:1px solid #ddd;padding:10px 8px;position:relative;text-align:center}.section-a-table th{background-color:#2980b9;color:#fff;font-size:14px;font-weight:600}.section-a-table .co-label{background-color:#ecf0f1;color:#2c3e50;font-weight:600}.section-a-table .co-total{background-color:#f8f9fa;color:#2c3e50;font-weight:600}.section-a-table .footer-label{background-color:#ecf0f1;color:#2c3e50;font-weight:600;text-align:center}.section-a-table input[type=number]{border:1px solid #bdc3c7;border-radius:4px;font-size:14px;padding:6px 8px;text-align:center;width:70px}.section-a-table input[type=number]:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}.section-a-table td[style*=borderLeft],.section-a-table th[style*=borderLeft]{border-left:2px solid #d5d5d5!important}.section-a-table tfoot tr:last-child{border-top:2px solid #d5d5d5}.co-attainment-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:40px;padding:20px}.co-attainment-table{border:1px solid #ddd;border-collapse:initial;border-radius:8px;border-spacing:0;min-width:1000px;overflow:visible;width:100%}.co-attainment-table td,.co-attainment-table th{border:1px solid #ddd;padding:10px 8px;text-align:center}.co-attainment-table thead th{background-color:#3498db;color:#fff;font-size:14px;font-weight:600}.co-attainment-table thead tr:first-child th{background-color:#2980b9}.co-attainment-table thead tr:first-child th:first-child{left:0;position:-webkit-sticky;position:sticky;z-index:12}.co-attainment-table .footer-label,.co-attainment-table .roll-cell{background-color:#ecf0f1;color:#2c3e50;font-weight:600;left:0;padding-left:12px;position:-webkit-sticky;position:sticky;text-align:left;z-index:2}.co-attainment-table tfoot td{background-color:#f8f9fa;font-weight:600}.co-calc-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:30px;padding:20px}.co-calc-section h2{border-bottom:2px solid #3498db;color:#2c3e50;font-size:22px;margin-bottom:20px;padding-bottom:10px}.co-calc-table{border:1px solid #ddd;border-collapse:initial;border-radius:8px;border-spacing:0;min-width:1000px;overflow:visible;width:100%}.co-calc-table td,.co-calc-table th{border:1px solid #ddd;font-size:14px;padding:10px 12px;text-align:center}.co-calc-table thead tr:first-child th{background-color:#2980b9;color:#fff;font-size:15px;font-weight:700}.co-calc-table thead tr:nth-child(2) th,.co-calc-table thead tr:nth-child(3) th{background-color:#2980b9;color:#fff;font-weight:600}.co-calc-table thead tr:nth-child(3) th{font-size:13px}.co-calc-table .roll-cell{background-color:#ecf0f1;color:#2c3e50;font-weight:600;left:0;padding-left:12px;position:-webkit-sticky;position:sticky;text-align:left;z-index:2}.co-calc-table tbody td{background-color:#fff}.co-calc-table tbody tr:nth-child(2n) td{background-color:#f8f9fa}.co-calc-table tbody tr:hover td{background-color:#e8f4f8}.co-po-percentage-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:30px;padding:20px}.co-po-percentage-section h2{border-bottom:2px solid #3498db;color:#2c3e50;font-size:22px;margin-bottom:20px;padding-bottom:10px}.co-po-percentage-table{border:1px solid #ddd;border-collapse:initial;border-radius:8px;border-spacing:0;min-width:900px;overflow:visible;width:100%}.co-po-percentage-table td,.co-po-percentage-table th{border:1px solid #ddd;font-size:14px;padding:10px 12px;text-align:center}.co-po-percentage-table thead tr:first-child th{background-color:#2980b9;color:#fff;font-size:15px;font-weight:700}.co-po-percentage-table thead tr:nth-child(2) th,.co-po-percentage-table thead tr:nth-child(3) th{background-color:#2980b9;color:#fff;font-weight:600}.co-po-percentage-table thead tr:nth-child(3) th{font-size:13px}.co-po-percentage-table thead tr:nth-child(4) th{background-color:#2980b9;color:#fff;font-size:13px;font-weight:600}.co-po-percentage-table .roll-cell{background-color:#ecf0f1;color:#2c3e50;font-weight:600;left:0;padding-left:12px;position:-webkit-sticky;position:sticky;text-align:left;z-index:2}.co-po-percentage-table tbody td{background-color:#fff}.co-po-percentage-table tbody tr:nth-child(2n) td{background-color:#f8f9fa}.co-po-percentage-table tbody tr:hover td{background-color:#e8f4f8}.ct-assignment-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:30px;padding:20px}.ct-assignment-section h2{border-bottom:2px solid #3498db;color:#2c3e50;font-size:22px;margin-bottom:20px;padding-bottom:10px}.ct-assignment-table{border:1px solid #ddd;border-collapse:initial;border-radius:8px;border-spacing:0;min-width:1200px;overflow:visible;width:100%}.ct-assignment-table td,.ct-assignment-table th{border:1px solid #ddd;font-size:14px;padding:10px 12px;text-align:center}.ct-assignment-table thead tr:first-child th{background-color:#2980b9;color:#fff;font-size:15px;font-weight:700}.ct-assignment-table thead tr:nth-child(2) th,.ct-assignment-table thead tr:nth-child(3) th{background-color:#2980b9;color:#fff;font-weight:600}.ct-assignment-table thead tr:nth-child(3) th{font-size:13px}.ct-assignment-table thead tr:nth-child(4) th{background-color:#2980b9;color:#fff;font-size:13px;font-weight:600}.ct-assignment-table .roll-cell{background-color:#ecf0f1;color:#2c3e50;font-weight:600;left:0;padding-left:12px;position:-webkit-sticky;position:sticky;text-align:left;z-index:2}.ct-assignment-table tbody td{background-color:#fff}.ct-assignment-table tbody tr:nth-child(2n) td{background-color:#f8f9fa}.ct-assignment-table tbody tr:hover td{background-color:#e8f4f8}.co-po-combined-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:30px;padding:20px}.co-po-combined-section h2{border-bottom:2px solid #3498db;color:#2c3e50;font-size:22px;margin-bottom:20px;padding-bottom:10px}.co-po-map-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:30px;padding:20px}.co-po-map-section h3{border-bottom:2px solid #3498db;color:#2c3e50;font-size:22px;margin-bottom:20px;padding-bottom:10px}.co-po-map-table{border:1px solid #ddd;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.co-po-map-table td,.co-po-map-table th{border:1px solid #ddd;font-size:14px;padding:12px;text-align:center}.co-po-map-table th{background-color:#2980b9;color:#fff;font-weight:600;position:-webkit-sticky;position:sticky;top:0;z-index:10}.co-po-map-table tbody tr:hover{background-color:#f8f9fa}.po-calc-max-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:30px;padding:20px}.po-calc-max-section h3{border-bottom:2px solid #3498db;color:#2c3e50;font-size:22px;margin-bottom:20px;padding-bottom:10px}.po-calc-max-section h4{font-size:18px;font-weight:600}.charts-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:30px;padding:20px}.charts-section h3{border-bottom:2px solid #3498db;color:#2c3e50;font-size:22px;margin-bottom:20px;padding-bottom:10px}.charts-section h4{font-size:18px;font-weight:600}.check-po-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:30px;padding:20px}.check-po-section h3{border-bottom:2px solid #3498db;color:#2c3e50;font-size:22px;margin-bottom:20px;padding-bottom:10px}.po-calc-section{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:30px;padding:20px}.po-calc-section h3{border-bottom:2px solid #3498db;color:#2c3e50;font-size:22px;margin-bottom:20px;padding-bottom:10px}.po-calc-section h4{font-size:18px;font-weight:600}.action-buttons-container{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.save-status-badge{align-items:center;border-radius:6px;display:inline-flex;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .3s ease;white-space:nowrap}.save-status-badge.saving{background-color:#fff3cd;border:1px solid #ffeeba;color:#856404}.save-status-badge.saved{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.save-status-badge.error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.btn-professional{align-items:center;border:none;border-radius:6px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:6px;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.btn-professional:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.btn-professional:active{box-shadow:0 1px 2px #0000001a;transform:translateY(0)}.btn-professional:disabled{box-shadow:0 1px 2px #0000001a;cursor:not-allowed;opacity:.6;transform:none}.btn-save{background-color:#27ae60;color:#fff}.btn-save:hover:not(:disabled){background-color:#229954}.btn-save:disabled{background-color:#95a5a6}.btn-primary{background-color:#3498db}.btn-primary:hover:not(:disabled){background-color:#2980b9}.btn-secondary{background-color:#95a5a6}.btn-secondary:hover:not(:disabled){background-color:#7f8c8d}.btn-info{background-color:#17a2b8;color:#fff}.btn-info:hover:not(:disabled){background-color:#138496}@media screen and (max-width:768px){.action-buttons-container{flex-direction:column;justify-content:stretch}.btn-professional,.save-status-badge{justify-content:center;width:100%}}@media screen and (max-width:480px){.btn-professional{font-size:13px;padding:12px 16px}.save-status-badge{font-size:12px;padding:10px 12px}}.co-summary-tables-container{align-items:flex-start;box-sizing:border-box;display:flex;flex-direction:row;flex-wrap:wrap;gap:12px;margin:20px 0 24px;width:100%}.co-summary-table-wrap{background:#fff;border:1px solid #d0dce8;border-radius:8px;box-shadow:0 2px 6px #00000014;flex:1 1 300px;min-width:0;overflow-x:auto}.co-summary-table{border-collapse:collapse;font-size:13px;table-layout:auto;width:100%}.co-summary-table td,.co-summary-table th{border:1px solid #d0dce8;padding:7px 10px;text-align:center;white-space:nowrap}.co-summary-th-label{background-color:#2980b9;color:#fff;font-size:13px;font-weight:700;padding-left:12px!important;text-align:left;white-space:nowrap}.co-summary-table thead tr th:not(.co-summary-th-label){background-color:#3498db;color:#fff;font-weight:600}.co-summary-row-label{background-color:#eaf2fb;color:#2c3e50;font-weight:600;padding-left:12px!important;text-align:left}.co-summary-row-label--sum{background-color:#d6eaf8;color:#1a5276}.co-summary-bin{font-size:13px;font-weight:700}.co-summary-bin--1{background-color:#d4edda;color:#155724}.co-summary-bin--0{background-color:#f8d7da;color:#721c24}.co-summary-bin--sum{background-color:#fef9e7;color:#7d6608;font-weight:700}.dashboard{background-color:var(--color-background);display:flex;flex-direction:column;min-height:100vh}.dashboard-header{background-color:var(--color-surface);box-shadow:var(--shadow-sm);position:-webkit-sticky;position:sticky;top:0;z-index:100}.dashboard-header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:var(--spacing-md) var(--spacing-lg)}.dashboard-header h1{color:var(--color-text-primary);font-size:1.75rem;font-weight:700;margin:0}.user-info{align-items:center;display:flex;gap:var(--spacing-sm)}.user-name{color:var(--color-text-primary);font-size:.95rem}.user-role{background-color:var(--color-primary);border-radius:var(--radius-lg);font-size:.8rem;font-weight:600;padding:.25rem .75rem}.btn-logout,.user-role{color:var(--color-text-white)}.btn-logout{background-color:var(--color-error);border-radius:var(--radius-sm);font-size:.85rem;padding:var(--spacing-xs) var(--spacing-sm);transition:var(--transition-base)}.btn-logout:hover{background-color:var(--color-error-dark)}.dashboard-main{flex:1 1;padding:var(--spacing-lg)}.dashboard-container{margin:0 auto;max-width:1400px}.welcome-section{background:var(--color-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);color:var(--color-text-white);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg)}.welcome-section h2{font-size:2rem;font-weight:700;margin-bottom:var(--spacing-xs)}.welcome-section p{font-size:1.05rem;opacity:.95}.dashboard-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.dashboard-card{background-color:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;padding:var(--spacing-lg);transition:var(--transition-base)}.dashboard-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.dashboard-card h3{color:var(--color-text-primary);font-size:1.5rem;font-weight:600;margin-bottom:var(--spacing-xs)}.dashboard-card p{color:var(--color-text-secondary);flex:1 1;font-size:.95rem;line-height:1.6;margin-bottom:var(--spacing-md)}.card-btn{background-color:var(--color-primary);border:none;border-radius:var(--radius-md);color:var(--color-text-white);cursor:pointer;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;padding:var(--spacing-xs) var(--spacing-md);transition:var(--transition-base)}.card-btn:hover{background-color:var(--color-primary-dark)}@media (max-width:1024px){.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.dashboard-header-content{align-items:flex-start;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md)}.dashboard-header h1{font-size:1.5rem}.user-info{justify-content:space-between;width:100%}.dashboard-main,.welcome-section{padding:var(--spacing-md)}.welcome-section h2{font-size:1.5rem}.welcome-section p{font-size:.95rem}.dashboard-grid{gap:var(--spacing-sm);grid-template-columns:1fr}.dashboard-card{padding:var(--spacing-md)}}.courses-tree{gap:.5rem}.breadcrumb-nav{border-bottom:2px solid #c4c6cd;padding-bottom:1rem}.breadcrumb-btn{background-color:#eff3ff;border:1px solid #c4c6cd;border-radius:4px;color:#0b1c31;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600}.breadcrumb-btn:hover{background-color:#dde9ff;border-color:#75777d}.tree-group{gap:.5rem}.tree-subgroup{margin-left:2rem}.tree-subsubgroup{margin-left:4rem}.tree-header{background:none;border:none;border-radius:4px;color:inherit;font-family:Inter,sans-serif;font-size:1rem;font-weight:600;padding:.75rem 1rem}.tree-year-header{background-color:#e6eeff;border-left:4px solid #04152b;color:#04152b}.tree-year-header:hover{background-color:#dde9ff}.tree-sem-header{background-color:#eff3ff;border-left:4px solid #505f78;color:#38485f}.tree-sem-header:hover{background-color:#e6eeff}.tree-type-header{background-color:#fff8ea;border-left:4px solid #e9c176;color:#5d4201}.tree-type-header:hover{background-color:#fcefcf}.tree-header svg{min-width:20px;width:20px}.tree-content{animation:slideDown .2s ease;gap:.5rem;margin-top:.25rem}.course-item{align-items:center;background-color:#fff;border:1px solid #c4c6cd;border-radius:4px;display:flex;justify-content:space-between;margin-left:1rem;padding:.75rem 1rem}.course-item:hover{background-color:#eff3ff;border-color:#04152b;box-shadow:0 1px 3px #04152b1f}.course-item-header{align-items:center;display:flex;flex:1 1}.course-info{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.course-code{color:#04152b;font-size:.95rem}.course-title{color:#374151;font-size:.9rem;line-height:1.3}.course-credit{font-size:.8rem}.course-item-actions{display:flex;gap:.5rem;margin-left:1rem}@media (max-width:768px){.tree-subgroup{margin-left:1rem}.tree-subsubgroup{margin-left:2rem}.course-item{align-items:flex-start;flex-direction:column;gap:.75rem}.course-item-actions{margin-left:0;width:100%}.course-item-actions .btn{flex:1 1}}@media (max-width:480px){.dashboard-header-content{padding:var(--spacing-sm)}.user-name{font-size:.85rem}.user-role{font-size:.7rem;padding:.2rem .6rem}.btn-logout{font-size:.8rem;padding:var(--spacing-xs) var(--spacing-sm)}.dashboard-main,.welcome-section{padding:var(--spacing-sm)}.dashboard-card h3,.welcome-section h2{font-size:1.25rem}}.dashboard-layout{background-color:#f5f7fa;display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#1e3a8a,#1e40af);box-shadow:2px 0 10px #0000001a;color:#fff;display:flex;flex-direction:column;height:100vh;overflow-y:hidden;position:-webkit-sticky;position:sticky;top:0;transition:all .3s ease;width:260px}.sidebar.closed{width:70px}.sidebar-header{align-items:center;border-bottom:1px solid #ffffff1a;display:flex;flex-shrink:0;gap:.75rem;justify-content:space-between;padding:1.5rem 1rem}.sidebar.closed .sidebar-header{justify-content:center;padding:1rem}.logo-section{align-items:center;display:flex;flex:1 1;gap:.75rem}.sidebar.closed .logo-section{display:none}.logo-icon{align-items:center;display:flex;height:48px;justify-content:center;width:48px}.sidebar.closed .logo-icon{height:36px;width:36px}.logo-image{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));height:100%;object-fit:contain;width:100%}.sidebar-header h1{font-size:1.25rem;font-weight:700;margin:0;white-space:nowrap}.sidebar-toggle{align-items:center;background:#ffffff1a;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:1.2rem;height:32px;justify-content:center;transition:all .2s ease;width:32px}.sidebar-toggle:hover{background:#fff3}.sidebar-nav{flex:1 1;gap:.25rem;overflow-x:hidden;overflow-y:auto;padding:1rem 0}.nav-group,.sidebar-nav{display:flex;flex-direction:column}.nav-group-header{position:relative}.nav-chevron{font-size:.875rem;margin-left:auto;transition:transform .2s ease}.nav-submenu{animation:slideDown .2s ease;background:#0003;border-left:3px solid #fbbf244d;display:flex;flex-direction:column;margin-left:0;overflow:hidden}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:200px;opacity:1}}.nav-subitem{border-left:none!important;font-size:.9rem;padding-left:3rem!important}.nav-subitem:hover{background:#ffffff26}.nav-subitem.active{background:#fff3;color:#fff}.nav-item{align-items:center;background:none;border:none;border-left:3px solid #0000;color:#fffc;cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:.95rem;font-weight:500;gap:.75rem;padding:.875rem 1rem;position:relative;text-align:left;transition:all .2s ease}.sidebar.closed .nav-item{justify-content:center;padding:.875rem}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:#ffffff26;border-left-color:#fbbf24;color:#fff}.nav-icon{align-items:center;display:flex;font-size:1.5rem;justify-content:center;min-width:24px}.nav-label{flex:1 1;white-space:nowrap}.badge-count{background:#ef4444;font-weight:700}.badge-count,.badge-info{border-radius:12px;color:#fff;font-size:.7rem;min-width:20px;padding:.2rem .5rem;text-align:center}.badge-info{background:#fff3;font-weight:600}.sidebar-footer{border-top:1px solid #ffffff1a;display:flex;flex-direction:column;gap:.75rem;padding:1rem}.sidebar.closed .sidebar-footer{display:none}.user-profile{align-items:center;background:#ffffff1a;border-radius:8px;display:flex;gap:.75rem;padding:.5rem}.sidebar.closed .user-profile{justify-content:center;padding:.5rem}.user-avatar-small{align-items:center;background:#fbbf24;border-radius:50%;color:#1e3a8a;display:flex;flex-shrink:0;font-size:1.1rem;font-weight:700;height:40px;justify-content:center;width:40px}.user-details-small{flex:1 1;min-width:0}.user-name{color:#fff;font-size:.9rem;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#ffffffb3;font-size:.75rem;margin:0;text-transform:capitalize}.btn-logout{align-items:center;background:#ef4444e6;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;padding:.625rem 1rem;transition:all .2s ease}.sidebar.closed .btn-logout{padding:.625rem}.btn-logout:hover{background:#dc2626}.logout-icon{font-size:1.2rem}.main-content{display:flex;flex:1 1;flex-direction:column;overflow-y:auto}.content-wrapper{margin:0;max-width:1400px;padding:2rem;text-align:left;width:100%}.section-container{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden;text-align:left}.section-header{align-items:flex-start;border-bottom:1px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1.5rem 2rem}.header-content h2{color:#1f2937;font-size:1.75rem;font-weight:700;margin:0 0 .25rem}.header-subtitle{color:#6b7280;font-size:.95rem;margin:0}.section-body{padding:2rem;text-align:left}.empty-state{color:#6b7280;padding:3rem 2rem;text-align:center}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{color:#374151;font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.empty-state p{font-size:.95rem;margin:0 0 1.5rem}.loading-container{color:#6b7280;padding:3rem 2rem;text-align:center}.loading-container p{font-size:.95rem;margin-top:1rem}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:flex-start;padding:.625rem 1.25rem;transition:all .2s ease}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-primary:hover{box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover{background:#4b5563}.btn-outline{background:#fff;border:1px solid #3b82f6;color:#3b82f6}.btn-outline:hover{background:#eff6ff}.btn-sm{font-size:.85rem;padding:.5rem .875rem}.btn-approve{background:#10b981;color:#fff}.btn-approve:hover{background:#059669;transform:translateY(-1px)}.btn-reject{background:#ef4444;color:#fff}.btn-reject:hover{background:#dc2626;transform:translateY(-1px)}.alert{align-items:center;border-radius:8px;display:flex;font-size:.9rem;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem}.alert-icon{font-size:1.25rem;font-weight:700}.alert-success{background:#d1fae5;border:1px solid #a7f3d0;color:#065f46}.alert-error{background:#fee2e2;border:1px solid #fecaca;color:#991b1b}.users-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.user-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:1.25rem;transition:all .2s ease}.user-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.user-card-header{display:flex;gap:1rem;margin-bottom:1rem}.user-avatar{align-items:center;background:linear-gradient(135deg,#f0f0f0,#e0e0e0);border:2px solid #999;border-radius:50%;color:#333;display:flex;flex-shrink:0;font-size:1.5rem;font-weight:700;height:56px;justify-content:center;width:56px}.user-info h3{color:#1f2937;font-size:1.1rem;font-weight:600;margin:0 0 .25rem}.user-email{color:#6b7280;font-size:.85rem;margin:0}.user-card-body{margin-bottom:1rem}.user-meta{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem}.role-badge{border-radius:6px;font-size:.75rem;font-weight:600;padding:.3rem .75rem;text-transform:capitalize}.role-badge.teacher{background:#dbeafe;color:#1e40af}.role-badge.student{background:#fef3c7;color:#92400e}.role-badge.admin{background:#e0e7ff;color:#4338ca}.user-date{color:#9ca3af;font-size:.8rem}.user-status{margin-top:.5rem}.status-badge{border-radius:6px;padding:.3rem .75rem}.status-badge.verified{background:#d1fae5;color:#065f46}.status-badge.unverified{background:#fee2e2;color:#991b1b}.status-badge.approved{background-color:#e5f5e5;color:#155724}.status-badge.unapproved{background-color:#ffe5e5;color:#721c24}.status-badge.active{background-color:#e5f5e5;color:#155724}.status-badge.inactive{background-color:#fef3c7;color:#92400e}.users-filter-bar{align-items:center;display:flex;gap:12px;margin-bottom:16px}.users-filter-bar .filter-input{background-color:#fafbfc;border:2px solid #e0e4e8;border-radius:8px;flex:1 1;font-size:14px;padding:12px 14px}.users-filter-bar .filter-input:focus{background-color:#fff;border-color:#666;box-shadow:0 0 0 4px #6666661a;outline:none}.status-badge.published{background:#d1fae5;color:#065f46}.status-badge.draft{background:#fef3c7;color:#92400e}.user-card-actions{display:flex;gap:.5rem}.user-card-actions .btn{flex:1 1}.courses-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.course-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;display:flex;flex-direction:column;padding:1.25rem;transition:all .2s ease}.course-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.course-card-header{margin-bottom:1rem}.course-code-wrapper{align-items:center;display:flex;gap:.75rem;justify-content:space-between}.course-card-body{flex:1 1;margin-bottom:1rem}.course-title{font-size:1.1rem;line-height:1.4;margin:0 0 .875rem}.course-meta{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem}.meta-item{align-items:center;color:#6b7280;display:flex;font-size:.85rem;gap:.375rem}.meta-icon{font-size:1rem}.course-extra-info{color:#9ca3af;font-size:.8rem;margin-top:.5rem}.course-obe-indicator{border-top:1px solid #e5e7eb;margin-top:.875rem;padding-top:.875rem}.obe-badge{align-items:center;background:#0000;border:1px solid #e5e7eb;border-radius:6px;color:#6366f1;display:inline-flex;font-size:.8rem;font-weight:500;gap:.375rem;padding:.4rem .875rem}.obe-icon{font-size:1rem}.course-card-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:auto}.course-card-actions .btn{flex:1 1 auto;min-width:-webkit-fit-content;min-width:fit-content}.courses-tree{display:flex;flex-direction:column;gap:1.5rem;text-align:left}.breadcrumb-nav{display:flex;gap:.75rem;margin-bottom:1rem}.breadcrumb-btn{background:#e5e7eb;border:none;border-radius:6px;color:#374151;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s ease}.breadcrumb-btn:hover{background:#d1d5db;color:#1f2937}.tree-group{display:flex;flex-direction:column;gap:.75rem}.tree-header{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#1f2937;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:.75rem;padding:1rem 1.25rem;text-align:left;transition:all .2s ease;width:100%}.tree-header:hover{background:#f9fafb;border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a;color:#3b82f6}.tree-type-header,.tree-year-header{padding:1rem 1.25rem}.tree-header svg{font-size:1rem;transition:transform .2s ease}.tree-header span{flex:1 1}.tree-content{display:flex;flex-direction:column;gap:1rem;text-align:left}.course-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;display:block;padding:1.25rem;text-align:left;transition:all .2s ease}.course-item:hover{border-color:#3b82f6;box-shadow:0 4px 12px #0000001a}.course-item-header{margin-bottom:1rem}.course-info{display:block;text-align:left}.course-code{background:#dbeafe;border-radius:6px;color:#1e40af;display:inline-block;font-size:.85rem;font-weight:700;letter-spacing:.5px;margin-right:.5rem;padding:.4rem .875rem;vertical-align:middle}.course-credit{background:#f3f4f6;color:#6b7280;font-size:.875rem}.course-assigned,.course-credit{border-radius:4px;display:inline-block;margin-right:.5rem;padding:.25rem .75rem;vertical-align:middle}.course-assigned{background:#d1fae5;color:#059669;font-size:.8rem}.course-title{color:#1f2937;display:block;font-size:1rem;font-weight:600;margin-bottom:.5rem;margin-top:.5rem}.course-item-actions{display:block;text-align:left}.course-item-actions .btn{align-items:center;display:inline-flex;font-size:.85rem;justify-content:center;margin-bottom:.5rem;margin-right:.5rem;padding:.625rem 1rem;white-space:nowrap}.mobile-menu-btn{background:linear-gradient(135deg,#1e3a8a,#1e40af);border:none;border-radius:10px;box-shadow:0 4px 12px #00000026;color:#fff;cursor:pointer;display:none;font-size:1.5rem;height:48px;left:1rem;position:fixed;top:1rem;transition:all .3s ease;width:48px;z-index:1100}.mobile-menu-btn:hover{box-shadow:0 6px 16px #0003;transform:scale(1.05)}.mobile-menu-btn:active{transform:scale(.95)}.sidebar-overlay{animation:fadeIn .3s ease;background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:999}@media (max-width:1024px){.mobile-menu-btn{align-items:center;display:flex;justify-content:center}.sidebar-toggle{display:none}.sidebar-header{padding-top:4rem}.sidebar-overlay{display:block}.sidebar{position:fixed;transform:translateX(0);transition:transform .3s ease;z-index:1000}.sidebar.closed{transform:translateX(-100%)}.main-content{margin-left:0;width:100%}.content-wrapper{padding:5rem 1.5rem 1.5rem}}@media (max-width:768px){.sidebar{overflow-y:auto;width:280px}.content-wrapper{padding:5rem 1rem 1rem}.section-header{align-items:stretch;flex-direction:column;padding:1.25rem 1.5rem}.header-content h2{font-size:1.5rem}.section-body{padding:1.5rem}.courses-grid,.users-grid{grid-template-columns:1fr}.courses-tree{gap:1rem}.tree-header{font-size:.9rem;padding:.875rem 1rem}.course-item{gap:.75rem;padding:1rem}.course-info{gap:.5rem}.course-code{font-size:.8rem;padding:.35rem .75rem}.course-title{font-size:.95rem}.course-assigned,.course-credit{font-size:.75rem;padding:.2rem .6rem}.course-item-actions{gap:.4rem}.course-item-actions .btn{font-size:.8rem;padding:.5rem .875rem}}@media (max-width:480px){.sidebar{max-width:300px;overflow-y:auto;width:85vw}.sidebar-header{padding-top:4rem}.content-wrapper{padding:4.5rem .75rem .75rem}.section-header{padding:1rem}.header-content h2{font-size:1.25rem}.course-card,.section-body,.user-card{padding:1rem}.mobile-menu-btn{font-size:1.3rem;height:44px;width:44px}.courses-tree{gap:.75rem}.tree-header{font-size:.85rem;padding:.75rem .875rem}.breadcrumb-btn{font-size:.8rem;padding:.4rem .8rem}.course-item{gap:.65rem;padding:.875rem}.course-info{align-items:flex-start;flex-direction:column;gap:.4rem}.course-code{font-size:.75rem;padding:.3rem .65rem}.course-title{font-size:.9rem;width:100%}.course-assigned,.course-credit{font-size:.7rem;padding:.15rem .5rem}.course-item-actions{flex-direction:column;gap:.4rem}.course-item-actions .btn{font-size:.75rem;padding:.5rem .875rem;width:100%}}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.modal-content{animation:slideUp .3s ease;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow:auto;width:90%}.delete-modal .modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem}.delete-modal .modal-header h3{color:#111827;font-size:1.25rem;font-weight:600;margin:0}.delete-modal .close-btn{align-items:center;background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.delete-modal .close-btn:hover{background:#f3f4f6;color:#111827}.delete-modal .close-btn:disabled{cursor:not-allowed;opacity:.5}.delete-modal .modal-body{padding:2rem 1.5rem;text-align:center}.delete-modal .warning-icon{align-items:center;background:#fee2e2;border-radius:50%;color:#dc2626;display:flex;font-size:1.75rem;height:64px;justify-content:center;margin:0 auto 1.5rem;width:64px}.delete-modal .warning-text{color:#111827;font-size:1rem;line-height:1.6;margin-bottom:1rem}.delete-modal .warning-text strong{color:#1e40af;font-weight:600}.delete-modal .warning-subtext{color:#6b7280;font-size:.875rem;line-height:1.5;margin:0}.delete-modal .modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.btn-danger{align-items:center;background:#dc2626;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s ease}.btn-danger:hover{background:#b91c1c;box-shadow:0 4px 12px #dc26264d;transform:translateY(-1px)}.btn-danger:active{transform:translateY(0)}.assignment-modal .modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem}.assignment-modal .modal-header h3{color:#111827;font-size:1.25rem;font-weight:600;margin:0}.assignment-modal .close-btn{align-items:center;background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.assignment-modal .close-btn:hover{background:#f3f4f6;color:#111827}.assignment-modal .close-btn:disabled{cursor:not-allowed;opacity:.5}.assignment-modal .modal-body{max-height:calc(90vh - 200px);overflow-y:auto;padding:1.5rem}.assignment-modal .modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.btn-danger:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-danger.btn-sm{font-size:.875rem;padding:.5rem .875rem}.btn-icon-delete{align-items:center;background:#fee2e2;border:none;border-radius:6px;color:#dc2626;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:.7rem;height:26px;justify-content:center;padding:0;transition:background .2s ease,color .2s ease;width:26px}.btn-icon-delete:hover{background:#dc2626;color:#fff}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.proposals-grid{grid-gap:1.5rem;animation:fadeIn .5s ease-in-out;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.proposal-card{background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 2px 8px #00000014;padding:1.5rem;transition:all .3s ease}.proposal-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.proposal-header{align-items:center;display:flex;gap:.5rem;justify-content:space-between;margin-bottom:1rem}.proposal-type-badge{border-radius:20px;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.375rem .875rem;text-transform:uppercase}.proposal-type-badge.create{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.proposal-type-badge.update{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.status-badge{border-radius:20px;font-size:.75rem;font-weight:600;padding:.375rem .875rem;text-transform:uppercase}.status-badge.status-pending{background:#fef3c7;color:#92400e}.status-badge.status-approved{background:#d1fae5;color:#065f46}.status-badge.status-rejected{background:#fee2e2;color:#991b1b}.proposal-body{margin-bottom:1.5rem}.proposal-body h3{color:#1e293b;font-size:1.125rem;font-weight:600;line-height:1.4;margin-bottom:1rem}.proposal-meta{flex-direction:column;gap:.5rem;margin-bottom:1rem}.proposal-meta p{color:#64748b;font-size:.875rem;margin:0}.proposal-description{background:#f8fafc;border-left:3px solid #3b82f6;border-radius:8px;margin-top:1rem;padding:.875rem}.proposal-description strong{color:#1e293b;display:block;font-size:.875rem;margin-bottom:.5rem}.proposal-description p{color:#475569;font-size:.875rem;line-height:1.6;margin:0}.proposal-actions{border-top:1px solid #e2e8f0;display:flex;gap:.75rem;padding-top:1rem}.proposal-actions .btn{flex:1 1}.proposal-detail-modal{margin:2rem auto;max-height:90vh;max-width:700px;overflow-y:auto;padding:2rem}.proposal-info-section{background:#f8fafc;border-radius:8px;margin-bottom:1.5rem;padding:1.25rem}.info-row{align-items:center;display:flex;gap:.5rem;margin-bottom:.75rem}.info-row:last-child{margin-bottom:0}.info-row strong{color:#475569;font-size:.875rem;min-width:120px}.info-row p{color:#1e293b;font-size:.875rem;line-height:1.6;margin:.5rem 0 0;width:100%}.course-details-section{margin-bottom:1.5rem}.course-details-section h4{border-bottom:2px solid #e2e8f0;color:#1e293b;font-size:1.125rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem}.details-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item.full-width{grid-column:1/-1}.detail-item strong{color:#64748b;font-size:.875rem}.detail-item:not(.full-width){color:#1e293b;font-size:.9375rem}.review-section{border-top:2px solid #e2e8f0;margin-top:1.5rem;padding-top:1.5rem}.review-section label{color:#1e293b;display:block;font-size:.9375rem;margin-bottom:.75rem}.review-section textarea{border:2px solid #e2e8f0;border-radius:8px;font-family:inherit;font-size:.9375rem;padding:.875rem;resize:vertical;transition:all .2s ease;width:100%}.review-section textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.review-section textarea:disabled{background:#f1f5f9;cursor:not-allowed}.review-history{background:#f1f5f9;border-left:3px solid #64748b;border-radius:8px;margin-top:1.5rem;padding:1rem}.review-history strong{color:#1e293b;display:block;font-size:.9375rem;margin-bottom:.5rem}.review-history p{color:#475569;font-size:.875rem;line-height:1.6;margin:0 0 .5rem}.review-history small{color:#64748b;font-size:.8125rem}.proposal-form-modal{max-height:90vh!important;max-width:1100px!important;overflow-y:auto!important;padding:0!important;width:95%!important}.proposal-form-modal .modal-header{align-items:center!important;background:linear-gradient(135deg,#f8fafc,#f1f5f9)!important;border-bottom:2px solid #e2e8f0!important;display:flex!important;justify-content:space-between!important;margin:0!important;padding:1.5rem 2rem!important;position:-webkit-sticky!important;position:sticky!important;top:0!important;z-index:10!important}.proposal-form-modal .modal-header h3{color:#1e293b!important;font-size:1.5rem!important;font-weight:600!important;margin:0!important}.proposal-form-modal .close-btn{align-items:center!important;background:none!important;border:none!important;border-radius:6px!important;color:#64748b!important;cursor:pointer!important;display:flex!important;font-size:2rem!important;height:36px!important;justify-content:center!important;line-height:1!important;padding:0!important;transition:all .2s ease!important;width:36px!important}.proposal-form-modal .close-btn:hover{background:#e2e8f0!important;color:#1e293b!important}.proposal-form-modal .modal-body{margin:0!important;padding:2rem!important}.change-description-section{background:#f8fafc!important;border:1px solid #e2e8f0!important;border-radius:8px!important;margin-bottom:2rem!important;padding:1.5rem!important}.change-description-section label{color:#1e293b!important;display:block!important;font-size:.9375rem!important;font-weight:600!important;margin-bottom:.75rem!important}.change-description-section textarea{border:2px solid #cbd5e1!important;border-radius:8px!important;box-sizing:border-box!important;font-family:inherit!important;font-size:.9375rem!important;padding:.875rem!important;resize:vertical!important;transition:all .2s ease!important;width:100%!important}.change-description-section textarea:focus{border-color:#3b82f6!important;box-shadow:0 0 0 3px #3b82f61a!important;outline:none!important}.change-description-section textarea::placeholder{color:#94a3b8!important}.proposal-form-modal .form-section{margin-bottom:2rem}.proposal-form-modal .form-actions{border-top:2px solid #e2e8f0;margin-top:2rem;padding-top:2rem}.proposal-modal-wrapper{position:relative}.change-description-wrapper{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px 12px 0 0;left:50%;margin-top:-250px;max-width:700px;padding:0;pointer-events:none;position:fixed;top:50%;transform:translate(-50%,-50%);width:calc(100% - 2rem);z-index:1001}.modal-close-button{align-items:center;background:#ffffffe6;border:1px solid #e2e8f0;border-radius:50%;color:#64748b;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;line-height:1;padding:0;pointer-events:auto;position:absolute;right:1rem;top:1rem;transition:all .2s ease;width:32px;z-index:1002}.modal-close-button:hover{background:#ef4444;border-color:#ef4444;color:#fff;transform:rotate(90deg)}.proposal-modal-title{background:linear-gradient(180deg,#f8fafc,#fff);border-bottom:2px solid #e2e8f0;border-radius:12px 12px 0 0;color:#1e293b;font-size:1.75rem;font-weight:700;letter-spacing:-.025em;margin:0;padding:1.5rem 1.5rem 1rem;pointer-events:none;text-align:center}.change-description-wrapper .change-description-section{background:#fff!important;border-radius:0 0 12px 12px;margin:0!important;padding:1.5rem 2rem!important;pointer-events:auto}.proposal-modal-wrapper .course-form-container{margin-top:60px!important;max-width:700px!important;padding-top:180px!important}.proposal-modal-wrapper .course-form-header{display:none!important}.proposals-list{animation:fadeIn .5s ease-in-out;display:flex;flex-direction:column;gap:1.5rem}.proposals-list .proposal-card{background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;padding:0;transition:all .3s ease}.proposals-list .proposal-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.proposals-list .proposal-header{align-items:flex-start;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:2px solid #e2e8f0;display:flex;gap:1rem;justify-content:space-between;padding:1.5rem}.proposals-list .proposal-header>div:first-child{flex:1 1;min-width:0}.proposals-list .proposal-header h3{color:#1e293b;font-size:1.25rem;font-weight:600;line-height:1.4;margin:0 0 .75rem;word-break:break-word}.proposals-list .proposal-type-badge{background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:20px;color:#fff;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.375rem .875rem;text-transform:uppercase}.proposals-list .proposal-body{padding:1.5rem}.proposal-info{background:#f8fafc;border-radius:8px;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem;padding:1rem}.proposal-info span{align-items:center;color:#475569;display:flex;font-size:.875rem;gap:.25rem}.proposal-info strong{color:#1e293b;margin-right:.25rem}.proposals-list .proposal-description{background:#eff6ff;border-left:3px solid #3b82f6;border-radius:8px;margin-bottom:1.25rem;padding:1rem}.proposals-list .proposal-description strong{color:#1e293b;display:block;font-size:.875rem;margin-bottom:.5rem}.proposals-list .proposal-description,.proposals-list .proposal-description p{color:#475569;font-size:.875rem;line-height:1.6;margin:0}.proposal-meta{border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:1rem;padding-top:1rem}.proposal-meta small{align-items:center;color:#64748b;display:flex;font-size:.8125rem;gap:.375rem}.review-comments{background:#fef3c7;border-left:3px solid #f59e0b;border-radius:8px;margin-top:1.25rem;padding:1rem}.review-comments strong{color:#92400e;display:block;font-size:.875rem;margin-bottom:.5rem}.rejection-reason{background:#fee2e2;border-left:3px solid #ef4444;border-radius:8px;margin-top:1.25rem;padding:1rem}.rejection-reason strong{color:#991b1b;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.rejection-reason span{color:#7f1d1d;display:block;font-size:.875rem;line-height:1.6}.approval-comment{background:#d1fae5;border-left:3px solid #10b981;border-radius:8px;margin-top:1.25rem;padding:1rem}.approval-comment strong{color:#065f46;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.approval-comment span{color:#064e3b;display:block;font-size:.875rem;line-height:1.6}.proposals-list .proposal-actions{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}.proposals-list .proposal-actions .btn{min-width:100px}.import-section{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}.import-box{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:2rem}.import-box h3{color:#1f2937;font-size:1.25rem;margin-bottom:.5rem}.import-info{color:#6b7280;font-size:.875rem;line-height:1.5}.import-box .form-group,.import-info{margin-bottom:1.5rem}.import-box input[type=file]{border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:block;font-size:.875rem;padding:.75rem;width:100%}.import-box input[type=file]:hover{border-color:#3b82f6}.file-selected{color:#10b981;font-size:.875rem;font-weight:500;margin-top:.5rem}.export-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:2rem}.export-section h3{color:#1f2937;font-size:1.25rem;margin-bottom:.5rem}.export-section .form-group{margin-bottom:1.5rem}.export-section select{background-color:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;display:block;font-size:.875rem;padding:.75rem;width:100%}.export-section select:hover{border-color:#10b981}.export-section select:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a;outline:none}.btn-success{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.btn-success:hover:not(:disabled){box-shadow:0 4px 12px #10b9814d;transform:translateY(-2px)}.btn-success:disabled{cursor:not-allowed;opacity:.5}@media (max-width:1024px){.import-section{grid-template-columns:1fr}}.dashboard-layout{background-color:#f9f9ff}.sidebar{background:linear-gradient(180deg,#04152b,#1a2a40)}.nav-submenu{border-left-color:#e9c17673}.nav-item.active{border-left-color:#e9c176}.user-avatar-small{background:#e9c176;color:#1e1300}.btn-logout{background:#ba1a1aeb}.btn-logout:hover{background:#93000a}.section-container{box-shadow:0 1px 3px #0b1c311f}.section-header{border-bottom-color:#c4c6cd}.export-section h3,.header-content h2,.import-box h3{color:#0b1c31}.header-subtitle,.import-info{color:#44474d}.btn-primary{background:linear-gradient(135deg,#04152b,#1a2a40)}.btn-primary:hover{box-shadow:0 4px 12px #04152b47}.btn-outline{border-color:#04152b;color:#04152b}.btn-outline:hover{background:#eff3ff}.mark-entry-modal{display:flex;flex-direction:column;max-height:90vh;max-width:1000px;overflow:hidden}.mark-entry-modal .modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;justify-content:space-between;padding:20px 24px}.mark-entry-modal .modal-header h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin:0}.mark-entry-body{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:24px}.mark-entry-footer{align-items:center;background:#fff;border-top:1px solid #e5e7eb;display:flex;flex-shrink:0;justify-content:space-between;padding:16px 24px}.mark-entry-footer button{align-items:center;display:flex;gap:6px;justify-content:center}.mark-entry-modal,.mark-entry-modal button,.mark-entry-modal input,.mark-entry-modal select,.mark-entry-modal textarea{font-family:inherit}.student-info-card{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:flex;justify-content:space-between;margin-bottom:24px;padding:16px}.student-info-card h4{font-size:18px;margin:0}.student-info-card p{font-size:14px;margin:4px 0 0;opacity:.9}.student-navigation{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.student-progress{background:#fff3;border-radius:20px;font-size:20px;font-weight:600;padding:8px 16px}.student-selector{background:#fffffff2;border:2px solid #ffffff80;border-radius:6px;color:#1f2937;font-size:13px;font-weight:500;max-width:250px;padding:8px 12px;transition:all .2s}.student-selector::placeholder{color:#6b7280;font-weight:400}.student-selector:hover{background:#fff;border-color:#fffc;box-shadow:0 2px 8px #0000001a}.student-selector:focus{background:#fff;border-color:#fff;box-shadow:0 0 0 3px #ffffff4d;outline:none}.image-upload-section{background:#f9fafb;border-radius:8px;margin-bottom:24px;padding:32px;text-align:center}.image-upload-section h4{color:#1f2937;margin:0 0 20px}.upload-options{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.camera-section{margin-bottom:24px;position:relative;text-align:center}.camera-section video{background:#000;border-radius:8px;display:block;margin:0 auto;max-height:480px;max-width:640px;width:100%}.camera-controls{display:flex;gap:12px;justify-content:center;margin-top:16px}.image-preview-section{margin-bottom:24px}.image-preview-section h4{color:#1f2937;margin:0 0 12px}.image-container{display:inline-block;position:relative;width:100%}.captured-image{border:2px solid #e5e7eb;border-radius:8px;display:block;margin-bottom:12px;max-height:400px;object-fit:contain;width:100%}.processing-overlay{background:#fffffff2;border-radius:8px;bottom:0;left:0;position:absolute;right:0;top:0;z-index:10}.processing-overlay,.spinner-container{align-items:center;display:flex;justify-content:center}.spinner-container{height:120px;position:relative;width:120px}.progress-ring{animation:spin 1s linear infinite}.progress-ring-circle{stroke-linecap:round;stroke-dasharray:163;stroke-dashoffset:41}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.image-actions{display:flex;gap:12px;justify-content:center}.marks-form-section{background:#fff;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:0;overflow:hidden;padding:20px}.marks-form-section h4{color:#1f2937;font-size:18px;margin:0 0 20px}.marks-form-section button,.marks-form-section input,.marks-form-section label,.marks-form-section select,.marks-form-section textarea{font-size:inherit}.marks-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:20px;width:100%}.marks-table-container{-webkit-overflow-scrolling:touch;margin-bottom:20px;overflow-x:auto}.marks-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 1px 3px #0000001a;min-width:400px;overflow:hidden;width:100%}.marks-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.marks-table th{border:1px solid #fff3;font-size:14px;font-weight:600;padding:12px 16px;text-align:center;white-space:nowrap}.marks-table tbody tr{transition:background-color .2s}.marks-table tbody tr:hover{background-color:#f9fafb}.marks-table tbody tr:nth-child(2n){background-color:#f3f4f6}.marks-table tbody tr:nth-child(2n):hover{background-color:#e5e7eb}.marks-table td{border:1px solid #e5e7eb;padding:8px;text-align:center}.marks-table .row-label{background:#f3f4f6;color:#4b5563;font-size:15px;font-weight:600;left:0;min-width:50px;position:-webkit-sticky;position:sticky;width:60px;z-index:1}.marks-table .mark-input{-webkit-appearance:none;background:#fff;border:2px solid #d1d5db;border-radius:6px;font-size:14px;font-weight:500;max-width:80px;min-width:60px;padding:8px 12px;text-align:center;transition:all .2s;width:100%}.marks-table .mark-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.marks-table .mark-input:hover{border-color:#9ca3af}.question-marks{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;min-width:0;overflow:hidden;padding:16px}.question-marks h5{color:#1f2937;font-size:16px;font-weight:600;margin:0 0 12px}.parts-grid{display:flex;gap:10px;justify-content:space-between;width:100%}.mark-input-group{align-items:center;display:flex;flex:1 1;flex-direction:column;min-width:0}.mark-input-group label{color:#6b7280;font-size:12px;font-weight:500;margin-bottom:4px}.mark-input-group input{border:1px solid #d1d5db;border-radius:4px;box-sizing:border-box;font-size:14px;min-width:0;padding:8px;text-align:center;transition:all .2s;width:100%}.mark-input-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.total-marks{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;display:flex;font-size:18px;justify-content:space-between;padding:16px}.total-value{font-size:24px;font-weight:700}.mark-entry-footer button:disabled{cursor:not-allowed;opacity:.5}.mark-entry-footer button{white-space:nowrap}@media (max-width:768px){.mark-entry-modal{max-height:95vh;max-width:95vw}.mark-entry-modal .modal-header{align-items:flex-start;flex-direction:column;gap:12px;padding:16px 20px}.mark-entry-modal .modal-header h3{font-size:1.1rem}.mark-entry-modal .modal-header>div{width:100%}.mark-entry-modal .modal-header>div:last-child{align-items:center;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.mark-entry-modal .modal-header>div:last-child button{white-space:normal}.mark-entry-body{padding:20px}.mark-entry-footer{flex-direction:column;gap:12px;padding:12px 20px}.mark-entry-footer>div{display:flex;justify-content:center;width:100%}.mark-entry-footer button{flex:1 1;font-size:.9rem;min-width:100px;padding:10px 16px}.marks-grid{gap:16px;grid-template-columns:1fr}.question-marks{padding:12px}.marks-form-section{padding:16px}.upload-options{flex-direction:column}.upload-options button{font-size:15px;padding:12px 16px;width:100%}.image-actions{flex-direction:column}.image-actions button{font-size:15px;padding:12px 16px;width:100%}.camera-controls{flex-direction:column}.camera-controls button{font-size:15px;padding:12px 16px;width:100%}.student-info-card{flex-direction:column;gap:12px;text-align:center}.student-info-card h4{font-size:16px}.student-info-card p{font-size:13px}.student-progress{font-size:17px;padding:7px 14px}.student-selector{font-size:12px}.student-navigation{align-items:center;width:100%}.student-selector{max-width:100%;width:100%}.camera-section video{max-height:300px}.marks-form-section h4{font-size:16px}.mark-input-group input,.mark-input-group label,.marks-table .mark-input,.marks-table .row-label,.marks-table td,.marks-table th,.total-marks{font-size:.85rem}}@media (max-width:480px){.mark-entry-body{padding:16px}.mark-entry-footer{gap:10px;padding:10px 16px}.mark-entry-footer button{font-size:.82rem;padding:10px 12px}.marks-form-section{padding:12px}.marks-form-section h4{font-size:15px;margin-bottom:12px}.marks-table{font-size:13px;min-width:350px}.marks-table th{font-size:.8rem;padding:8px 10px}.marks-table td{padding:6px}.marks-table .row-label{font-size:.82rem;min-width:40px;padding:6px 8px;width:45px}.marks-table .mark-input{font-size:.8rem;max-width:65px;min-width:55px;padding:6px 8px}.mark-input-group label,.marks-form-section h4,.question-marks h5,.student-info-card h4{font-size:.9rem}.question-marks{padding:10px}.parts-grid{gap:8px}.mark-input-group input{font-size:.8rem;padding:6px}.total-marks{font-size:.88rem}.total-value{font-size:1.05rem}}@media (max-width:360px){.marks-table{font-size:12px;min-width:320px}.marks-table th{font-size:.75rem;padding:6px 8px}.marks-table .row-label{font-size:.76rem;min-width:35px;padding:5px 6px;width:38px}.marks-table .mark-input{font-size:.74rem;max-width:55px;min-width:50px;padding:5px 6px}.mark-input-group label,.marks-form-section h4,.question-marks h5,.student-info-card h4,.student-info-card p,.student-selector,.total-marks{font-size:.8rem}}.course-profile-container{margin:0 auto;max-width:1400px;padding:20px}.course-profile-container h1{color:#2c3e50;font-size:24px;margin-bottom:20px}.profile-error,.profile-loading{border-radius:4px;padding:20px;text-align:center}.profile-loading{background-color:#f8f9fa;color:#6c757d}.profile-error{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.table-wrapper{border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;overflow-x:auto}.clo-table{background-color:#fff;border-collapse:collapse;font-size:14px;width:100%}.clo-table thead{background-color:#2c3e50;color:#fff}.clo-table th{border:1px solid #dee2e6;font-weight:600;padding:12px;text-align:center}.clo-table td{border:1px solid #dee2e6;padding:8px;vertical-align:middle}.clo-table tbody tr:nth-child(2n){background-color:#f8f9fa}.clo-table tbody tr:hover{background-color:#e9ecef}.clo-number{font-weight:600;text-align:center;width:80px}.clo-description{min-width:300px}.bloom-level{text-align:center;width:60px}.clo-plo-corr,.plo-assessed{min-width:120px;text-align:center}.cell-content{cursor:default;min-height:24px;padding:4px}.cell-content.editable{cursor:pointer;transition:background-color .2s}.cell-content.editable:hover{background-color:#fff3cd;border-radius:3px}.edit-input{border:2px solid #007bff;border-radius:3px;font-family:inherit;font-size:14px;padding:4px;width:100%}.edit-input:focus{border-color:#0056b3;outline:none}.edit-instructions{background-color:#d1ecf1;border-radius:4px;color:#0c5460;font-size:13px;padding:12px;text-align:center}@media (max-width:768px){.course-profile-container{padding:10px}.clo-table{font-size:12px}.clo-table td,.clo-table th{padding:6px}.clo-description{min-width:200px}}
/*# sourceMappingURL=main.a27fb2a7.css.map*/