*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#0a0a0a;--primary-hover:#1f1f1f;--primary-light:#f0f0f0;--accent:#e63027;--accent-hover:#c5251c;--accent-light:#fdecea;--gold:#f5a623;--gold-light:#fff8ec;--success:#1a7a3c;--success-light:#e8f5ee;--warning:#b45309;--warning-light:#fffbeb;--danger:#c62828;--danger-light:#fce4ec;--info:#1565c0;--info-light:#e3f2fd;--text:#111;--text-secondary:#555;--text-muted:#888;--border:#e2e2e2;--border-dark:#ccc;--bg:#f7f7f8;--bg-card:#fff;--radius:10px;--radius-sm:6px;--shadow:0 1px 4px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.06);--shadow-lg:0 8px 32px rgba(0,0,0,.14)}body{background:var(--bg);color:var(--text);font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5}.navbar{background:var(--primary);color:#fff;z-index:100;border-bottom:2px solid var(--accent);align-items:center;gap:8px;height:64px;padding:0 28px;display:flex;position:sticky;top:0;box-shadow:0 2px 12px rgba(0,0,0,.4)}.navbar-brand a{color:#fff;letter-spacing:.2px;white-space:nowrap;align-items:center;gap:12px;margin-right:12px;font-size:15px;font-weight:700;text-decoration:none;display:flex}.navbar-brand a:hover{color:#e0e0e0}.navbar-logo{width:auto;height:38px}.navbar-brand-text{flex-direction:column;line-height:1.2;display:flex}.navbar-brand-text span:first-child{letter-spacing:.5px;font-size:14px;font-weight:800}.navbar-brand-text span:last-child{color:rgba(255,255,255,.6);letter-spacing:.3px;font-size:10px;font-weight:400}.navbar-divider{background:rgba(255,255,255,.15);width:1px;height:32px;margin:0 8px}.navbar-links{flex:1;gap:2px;display:flex}.nav-link{color:rgba(255,255,255,.8);border-radius:6px;align-items:center;gap:6px;padding:6px 13px;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.nav-link:hover{color:#fff;background:rgba(255,255,255,.12)}.nav-link.active{background:var(--accent);color:#fff}.navbar-user{align-items:center;gap:10px;margin-left:auto;display:flex}.user-avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.user-info{flex-direction:row;align-items:center;gap:7px;display:flex}.user-info svg{color:rgba(255,255,255,.5);flex-shrink:0}.user-info-text{flex-direction:column;line-height:1.2;display:flex}.user-name{color:#fff;font-size:13px;font-weight:600}.user-role{color:rgba(255,255,255,.6);text-transform:capitalize;font-size:11px}.btn-logout,.logout-btn{color:#fff;cursor:pointer;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:6px;align-items:center;gap:5px;padding:6px 12px;font-size:12px;transition:all .15s;display:flex}.btn-logout:hover,.logout-btn:hover{background:rgba(255,255,255,.2)}.main-content{min-height:calc(100vh - 64px);padding:28px}.page{max-width:1240px;margin:0 auto}.page-narrow{max-width:760px;margin:0 auto}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:26px;display:flex}.page-header-left h1{color:var(--text);margin-bottom:3px;font-size:22px;font-weight:800}.page-header-left p{color:var(--text-muted);font-size:13px}.page-header h1{color:var(--text);margin-bottom:3px;font-size:22px;font-weight:800}.page-header p{color:var(--text-muted);font-size:13px}.card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:20px;padding:22px}.card-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.card-header h2{font-size:16px;font-weight:700}.auth-page{background:var(--primary);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative;overflow:hidden}.auth-page:before{content:"";background:repeating-linear-gradient(45deg,transparent,transparent 60px,rgba(230,48,39,.04) 60px,rgba(230,48,39,.04) 61px);position:absolute;top:0;bottom:0;left:0;right:0}.auth-card{width:100%;max-width:440px;box-shadow:var(--shadow-lg);z-index:1;background:#fff;border-radius:16px;padding:44px 40px;position:relative}.auth-header{border-bottom:1px solid var(--border);text-align:center;flex-direction:column;align-items:center;margin-bottom:28px;padding-bottom:24px;display:flex}.auth-logo{border-radius:6px;width:200px;height:auto;margin-bottom:6px}.auth-header h1{color:var(--primary);margin-top:10px;font-size:17px;font-weight:800}.auth-header p{color:var(--text-muted);margin-top:3px;font-size:12px}.auth-logo-bar{border-bottom:1px solid var(--border);flex-direction:column;align-items:center;margin-bottom:30px;padding-bottom:24px;display:flex}.auth-logo-icon{background:var(--primary);color:#fff;border-radius:12px;justify-content:center;align-items:center;width:54px;height:54px;margin-bottom:12px;display:flex}.auth-logo-bar h1{color:var(--primary);text-align:center;font-size:17px;font-weight:800}.auth-logo-bar p{color:var(--text-muted);text-align:center;margin-top:3px;font-size:12px}.auth-card h2{margin-bottom:22px;font-size:20px;font-weight:700}.auth-footer{text-align:center;color:var(--text-muted);margin-top:18px;font-size:13px}.auth-footer a{color:var(--accent);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.form-group{margin-bottom:18px}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;align-items:center;gap:5px;margin-bottom:6px;font-size:12px;font-weight:600;display:flex}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:#fff;padding:10px 12px;font-size:14px;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px rgba(10,10,10,.08)}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-row-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.date-sel-wrap{gap:8px;display:flex}.date-sel{border:1.5px solid var(--border);border-radius:var(--radius-sm);min-width:0;color:var(--text);cursor:pointer;-webkit-appearance:auto;appearance:auto;background:#fff;flex:1;padding:10px 8px;font-size:14px}.date-sel:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px rgba(10,10,10,.08)}.date-sel.input-error{border-color:var(--danger)!important;background:#fff8f8!important}@media (max-width:400px){.date-sel{padding:10px 4px;font-size:13px}}.error{color:var(--danger);align-items:center;gap:4px;margin-top:4px;font-size:12px;display:flex}.checkbox-label{cursor:pointer;align-items:center;gap:8px;font-size:13px;font-weight:500;display:flex}.checkbox-label input{width:auto;accent-color:var(--primary)}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:7px;padding:9px 18px;font-size:13px;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.2)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.btn-accent{background:var(--accent);color:#fff}.btn-accent:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-outline{color:var(--primary);border:1.5px solid var(--border-dark);background:#fff}.btn-outline:hover{background:var(--primary-light);border-color:var(--primary)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{filter:brightness(.9)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{filter:brightness(.9)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--primary-light);color:var(--text)}.btn-sm{border-radius:5px;padding:5px 11px;font-size:12px}.btn-full{justify-content:center;width:100%;padding:11px;font-size:14px}.table{border-collapse:collapse;width:100%}.table th{background:var(--primary);color:rgba(255,255,255,.9);text-align:left;text-transform:uppercase;letter-spacing:.6px;padding:11px 14px;font-size:11px;font-weight:700}.table th:first-child{border-radius:0}.table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:11px 14px}.table tbody tr:hover td{background:#fafafa}.table tbody tr:last-child td{border-bottom:none}.table td.empty{text-align:center;color:var(--text-muted);padding:48px;font-size:13px}.table td small{color:var(--text-muted);margin-top:1px;font-size:12px;display:block}.actions-cell{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.badge{text-transform:capitalize;letter-spacing:.2px;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-flex}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:var(--info-light);color:var(--info)}.badge-secondary{color:#555;background:#f0f0f0}.badge-gold{background:var(--gold-light);color:#92600a}.badge-dark{background:var(--primary);color:#fff}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:16px;margin-bottom:26px;display:grid}.stat-card{border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;padding:20px;position:relative;overflow:hidden}.stat-card:before{content:"";background:var(--primary);width:4px;height:100%;position:absolute;top:0;left:0}.stat-card.accent:before{background:var(--accent)}.stat-card.success:before{background:var(--success)}.stat-card.warning:before{background:var(--gold)}.stat-card.info:before{background:var(--info)}.stat-icon{color:var(--primary);margin-bottom:10px}.stat-card.accent .stat-icon{color:var(--accent)}.stat-card.success .stat-icon{color:var(--success)}.stat-card.warning .stat-icon{color:var(--gold)}.stat-card.info .stat-icon{color:var(--info)}.stat-value{color:var(--text);margin-bottom:4px;font-size:30px;font-weight:800;line-height:1}.stat-label{color:var(--text-muted);font-size:12px;font-weight:500}.stat-link{color:var(--accent);align-items:center;gap:3px;margin-top:8px;font-size:12px;font-weight:600;text-decoration:none;display:inline-flex}.stat-link:hover{text-decoration:underline}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;display:grid}.course-card{border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);background:#fff;flex-direction:column;gap:12px;padding:22px;transition:transform .2s,box-shadow .2s;display:flex}.course-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.course-card-header{justify-content:space-between;align-items:flex-start;display:flex}.dept-badge{background:var(--primary);color:#fff;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700}.course-code{color:var(--text-muted);background:var(--primary-light);border-radius:4px;padding:2px 7px;font-family:monospace;font-size:11px}.course-card h3{color:var(--text);font-size:15px;font-weight:700;line-height:1.3}.dept-name{color:var(--text-secondary);align-items:center;gap:5px;font-size:13px;display:flex}.course-desc{color:var(--text-muted);flex:1;font-size:13px;line-height:1.5}.course-costs{background:var(--primary-light);border-radius:8px;flex-direction:column;gap:8px;padding:14px;display:flex}.cost-item{justify-content:space-between;align-items:center;font-size:13px;display:flex}.cost-label{color:var(--text-secondary);align-items:center;gap:5px;display:flex}.cost-value{color:var(--text);font-weight:700}.cost-value.highlight{color:var(--primary)}.cost-value.total{color:var(--accent);font-size:15px}.course-preview{background:var(--primary-light);border-radius:var(--radius-sm);border-left:3px solid var(--primary);margin-bottom:16px;padding:16px}.course-preview h3{color:var(--primary);margin-bottom:4px;font-size:15px;font-weight:700}.cost-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-top:14px;display:grid}.cost-grid div{text-align:center;border:1px solid var(--border);background:#fff;border-radius:6px;padding:10px}.cost-grid div span{color:var(--text-muted);text-transform:uppercase;margin-bottom:4px;font-size:11px;font-weight:600;display:block}.cost-grid div strong{color:var(--primary);font-size:14px;font-weight:800}.course-info{background:var(--primary-light);border-radius:var(--radius-sm);border-left:3px solid var(--primary);padding:16px}.course-costs-inline{flex-wrap:wrap;gap:20px;margin-top:8px;font-size:13px;display:flex}.course-costs-inline span strong{color:var(--primary)}.courses-public-wrap{box-sizing:border-box;width:100%;padding:0 32px 60px}.courses-hero{text-align:center;padding:48px 24px 40px}.courses-hero-icon{background:var(--primary-light);width:68px;height:68px;color:var(--primary);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 18px;display:flex}.courses-hero h1{color:var(--text);margin-bottom:10px;font-size:36px;font-weight:900}.courses-hero p{color:var(--text-secondary);margin-bottom:28px;font-size:15px}.courses-filters{flex-wrap:wrap;gap:12px;margin-bottom:12px;display:flex}.filter-select{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);cursor:pointer;background:#fff;padding:8px 14px;font-size:13px}.filter-select:focus{border-color:var(--primary);outline:none}.courses-count{color:var(--text-muted);margin-bottom:28px;font-size:13px}.faculty-section{margin-bottom:40px}.faculty-heading{color:var(--primary);border-bottom:2px solid var(--primary-light);align-items:center;gap:10px;margin-bottom:16px;padding-bottom:10px;font-size:15px;font-weight:800;display:flex}.faculty-count{color:var(--text-muted);margin-left:auto;font-size:12px;font-weight:500}.course-name{color:var(--text);font-size:14px;font-weight:700;line-height:1.35}.course-dept{color:var(--text-muted);font-size:12px}.course-meta{flex-direction:column;gap:5px;margin-top:4px;display:flex}.course-meta-item{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;display:flex}.ncqf-badge{border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700}.ncqf-badge.level-6{color:#2e7d32;background:#e8f5e9}.ncqf-badge.level-7{color:#1565c0;background:#e3f2fd}.ncqf-badge.level-8{color:#6a1b9a;background:#f3e5f5}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:14px;padding:60px 20px;display:flex}.steps{border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:26px;display:flex;overflow:hidden}.step{border:1px solid var(--border);color:var(--text-muted);background:#fff;border-right:none;flex:1;align-items:center;gap:10px;padding:14px 18px;font-size:13px;transition:all .2s;display:flex}.step:last-child{border-right:1px solid var(--border)}.step.active{background:var(--primary);color:#fff;border-color:var(--primary)}.step.done{background:var(--success-light);color:var(--success);border-color:#b2dfcc}.step-num{border:2px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;font-weight:800;display:flex}.step.active .step-num{color:var(--primary);background:#fff;border-color:#fff}.step.done .step-num{background:var(--success);color:#fff;border-color:var(--success)}.step-label{font-size:13px;font-weight:600}.step-actions{justify-content:flex-end;gap:12px;margin-top:20px;display:flex}.doc-upload{flex-direction:column;gap:10px;display:flex}.doc-item{background:var(--primary-light);border-radius:var(--radius-sm);border:1px solid var(--border);align-items:center;gap:10px;padding:10px 14px;display:flex}.doc-item-icon{color:var(--accent);flex-shrink:0}.doc-item span{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:13px;font-weight:500;overflow:hidden}.file-upload-btn{border:2px dashed var(--border-dark);border-radius:var(--radius-sm);cursor:pointer;color:var(--primary);background:#fff;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.file-upload-btn:hover{border-color:var(--primary);background:var(--primary-light)}.review-section{border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:0;margin-bottom:20px;display:flex;overflow:hidden}.review-item{background:#fff;gap:16px;padding:12px 16px;font-size:14px;display:flex}.review-item:nth-child(2n){background:#fafafa}.review-item strong{min-width:170px;color:var(--text-muted);align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.info-banner{background:var(--primary-light);border-left:4px solid var(--primary);color:var(--text);border-radius:var(--radius-sm);align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:13px;display:flex}.info-banner.success{background:var(--success-light);border-left-color:var(--success);color:var(--success)}.info-banner.warning{background:var(--warning-light);border-left-color:var(--gold);color:var(--warning)}.info-banner.danger{background:var(--danger-light);border-left-color:var(--danger);color:var(--danger)}.quick-actions{margin-top:4px}.quick-actions h2{align-items:center;gap:8px;margin-bottom:14px;font-size:15px;font-weight:700;display:flex}.actions-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:14px;display:grid}.action-card{border-radius:var(--radius);color:var(--text);box-shadow:var(--shadow);border:1.5px solid var(--border);text-align:center;background:#fff;flex-direction:column;align-items:center;gap:10px;padding:20px 16px;text-decoration:none;transition:all .2s;display:flex}.action-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary);transform:translateY(-3px)}.action-card:hover .action-icon{color:var(--accent)}.action-icon{color:var(--primary);transition:color .2s}.action-label{color:var(--text);font-size:13px;font-weight:600}.modal-overlay{z-index:200;backdrop-filter:blur(2px);background:rgba(0,0,0,.6);justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.modal{width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-lg);background:#fff;border-radius:14px;padding:30px;overflow-y:auto}.modal-lg{max-width:720px}.modal-xl{max-width:960px}.modal-header{align-items:center;gap:10px;margin-bottom:20px;display:flex}.modal-header h2{flex:1;font-size:18px;font-weight:800}.modal-close{background:var(--primary-light);cursor:pointer;width:30px;height:30px;color:var(--text-secondary);border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .15s;display:flex}.modal-close:hover{background:var(--border)}.modal h2{margin-bottom:20px;font-size:18px;font-weight:800}.modal-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:24px;padding-top:16px;display:flex}.modal-body{padding-top:4px}.detail-section-heading{text-transform:uppercase;letter-spacing:.07em;color:var(--primary);border-bottom:2px solid var(--primary-light);margin:20px 0 8px;padding-bottom:6px;font-size:12px;font-weight:700}.info-table{border-collapse:collapse;width:100%;margin-bottom:4px;font-size:13px}.info-table tr{border-bottom:1px solid var(--border)}.info-table tr:last-child{border-bottom:none}.info-label{width:40%;color:var(--text-secondary);vertical-align:top;white-space:nowrap;padding:6px 10px 6px 0;font-weight:500}.info-value{color:var(--text-primary);word-break:break-word;padding:6px 0;font-weight:600}.doc-list{flex-direction:column;gap:8px;margin-bottom:4px;display:flex}.doc-item{border:1px solid var(--border);color:var(--text-primary);background:var(--bg);border-radius:8px;align-items:center;gap:10px;padding:10px 14px;text-decoration:none;transition:background .15s;display:flex}.doc-item:hover{background:var(--primary-light)}.doc-item span{flex:1;font-size:13px;font-weight:600}.doc-item small{color:var(--text-secondary);font-size:11px}.signatures-view{flex-wrap:wrap;gap:16px;margin-bottom:4px;display:flex}.sig-view-box{border:1px solid var(--border);background:#fafafa;border-radius:8px;padding:10px}.sig-view-label{color:var(--text-secondary);text-transform:uppercase;margin-bottom:6px;font-size:11px;font-weight:600}.sig-view-img{background:#fff;border-radius:4px;max-width:260px;max-height:100px;display:block}.toolbar{border:1px solid var(--border);border-radius:var(--radius);background:#fff;flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;display:flex;box-shadow:0 1px 3px rgba(0,0,0,.04)}.search-wrapper{flex:220px;position:relative}.search-icon{color:#9ca3af;pointer-events:none;position:absolute;top:50%;left:11px;transform:translateY(-50%)}.search-input,.filter-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:#f9fafb;padding:9px 12px 9px 36px;font-size:13px;transition:border-color .15s,background .15s,box-shadow .15s}.search-input:focus,.filter-input:focus{border-color:var(--primary);background:#fff;outline:none;box-shadow:0 0 0 3px rgba(37,99,235,.08)}.search-input::placeholder,.filter-input::placeholder{color:#9ca3af}.filter-select{border:1.5px solid var(--border);border-radius:var(--radius-sm);-webkit-appearance:none;appearance:none;color:var(--text);cursor:pointer;background:#f9fafb url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") right 10px center no-repeat;padding:9px 32px 9px 12px;font-size:13px;transition:border-color .15s,background .15s,box-shadow .15s}.filter-select:focus{border-color:var(--primary);background-color:#fff;outline:none;box-shadow:0 0 0 3px rgba(37,99,235,.08)}.toolbar-count{color:var(--text-secondary);background:var(--bg-secondary,#f1f5f9);border:1px solid var(--border);white-space:nowrap;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.header-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.empty-state{text-align:center;color:var(--text-muted);padding:56px 20px}.empty-state-icon{color:var(--border-dark);margin-bottom:14px}.empty-state p{color:var(--text-secondary);margin-bottom:6px;font-size:15px;font-weight:600}.empty-state small{font-size:13px}.empty-state .btn{margin-top:16px}.loading{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:80px;display:flex}.loading-spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:.8s linear infinite spin;display:inline-flex}.hint{color:var(--text-muted);align-items:flex-start;gap:6px;margin-bottom:14px;font-size:13px;display:flex}code{background:var(--primary-light);color:var(--primary);border-radius:4px;padding:2px 6px;font-family:monospace;font-size:12px;font-weight:700}.divider{border:none;border-top:1px solid var(--border);margin:20px 0}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.navbar-hamburger{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:6px;margin-left:auto;padding:6px;transition:background .15s;display:none}.navbar-hamburger:hover{background:rgba(255,255,255,.12)}.mobile-drawer-overlay{z-index:150;backdrop-filter:blur(2px);background:rgba(0,0,0,.55);display:none;position:fixed;top:0;bottom:0;left:0;right:0}.mobile-drawer{background:var(--primary);flex-direction:column;width:300px;height:100%;display:flex;position:absolute;top:0;right:0;overflow-y:auto;box-shadow:-4px 0 24px rgba(0,0,0,.4)}.mobile-drawer-user{border-bottom:1px solid rgba(255,255,255,.1);align-items:center;gap:12px;padding:20px 18px 16px;display:flex}.mobile-drawer-user .user-name{color:#fff;font-size:14px;font-weight:700}.mobile-drawer-user .user-role{color:rgba(255,255,255,.55);text-transform:capitalize;font-size:12px}.mobile-drawer-links{flex-direction:column;flex:1;gap:2px;padding:10px;display:flex}.mobile-nav-link{color:rgba(255,255,255,.8);border-radius:8px;align-items:center;gap:12px;padding:11px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.mobile-nav-link:hover{color:#fff;background:rgba(255,255,255,.1)}.mobile-nav-link.active{background:var(--accent);color:#fff}.mobile-drawer-footer{border-top:1px solid rgba(255,255,255,.1);padding:14px 14px 24px}.mobile-drawer-footer .btn-outline{color:#fff;background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.25)}.mobile-drawer-footer .btn-outline:hover{background:rgba(255,255,255,.15)}@media (max-width:1024px){.navbar{padding:0 16px}.navbar-links,.navbar-user-desktop{display:none}.navbar-hamburger{display:flex}.mobile-drawer-overlay{display:block}}@media (max-width:768px){.main-content{padding:14px}.page-header{flex-direction:column;align-items:stretch;gap:12px}.page-header .btn{justify-content:center;width:100%}.page-header-left h1{font-size:18px}.card{padding:16px}.form-row,.form-row-3{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat-value{font-size:24px}.card{-webkit-overflow-scrolling:touch;overflow-x:auto}.table{min-width:520px}.modal-overlay{align-items:flex-end;padding:0}.modal{border-radius:18px 18px 0 0;width:100%;max-width:100%;max-height:92vh;padding:20px 18px 28px}.modal-lg,.modal-xl{width:100%;max-width:100%}.auth-card{padding:28px 20px}.steps{border-radius:var(--radius);flex-direction:column}.step{border-right:1px solid var(--border);border-bottom:none}.step:last-child{border-bottom:1px solid var(--border)}.signatures-row{grid-template-columns:1fr;gap:16px}.signature-canvas{height:110px}.cost-grid{grid-template-columns:1fr}.toolbar{flex-direction:column;align-items:stretch;gap:8px}.search-wrapper{flex:none}.toolbar-count{text-align:center}.actions-cell{flex-wrap:wrap;gap:4px}.header-actions{flex-direction:column;gap:6px}.header-actions .btn{justify-content:center;width:100%}.courses-grid{grid-template-columns:1fr}.file-row{flex-direction:column;align-items:flex-start}.landing-hero{grid-template-columns:1fr;gap:40px;padding:40px 16px}.landing-hero-visual{display:none}.landing-title{font-size:30px}.landing-how-grid{grid-template-columns:1fr;gap:24px}.landing-actions{flex-direction:column}.landing-actions .btn{justify-content:center;width:100%}.track-input-group{flex-direction:column}.track-card{padding:28px 18px}.public-page-header{padding:12px 16px}.review-item{flex-direction:column;gap:4px}.review-item strong{min-width:auto}.modal-actions{flex-direction:column-reverse;gap:8px}.modal-actions .btn{justify-content:center;width:100%}.step-actions{flex-direction:column-reverse}.step-actions .btn{justify-content:center;width:100%}.actions-grid{grid-template-columns:repeat(2,1fr)}}.bulk-email-grid{grid-template-columns:1fr 1fr;align-items:start;gap:24px;display:grid}.two-col-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}@media (max-width:768px){.bulk-email-grid,.two-col-grid{grid-template-columns:1fr}}@media (max-width:400px){.stats-grid,.actions-grid{grid-template-columns:1fr}.date-sel{padding:10px 4px;font-size:13px}.navbar-logo{height:30px}}.apply-header{border-left:4px solid var(--accent);margin-bottom:22px;padding-left:14px}.apply-header h1{color:var(--primary);font-size:20px;font-weight:800}.apply-header p{color:var(--text-muted);margin-top:2px;font-size:13px}.apply-card{padding:28px}.form-section{flex-direction:column;gap:18px;display:flex}.section-heading{text-transform:uppercase;letter-spacing:.06em;color:#fff;background:var(--primary);border-radius:var(--radius-sm);margin-bottom:4px;padding:8px 14px;font-size:13px;font-weight:800}.section-sub-heading{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:2px solid var(--border);margin-top:4px;padding-bottom:5px;font-size:12px;font-weight:700}.section-note{color:var(--text-muted);margin-top:-10px;font-size:13px}.step-text{flex-direction:column;display:flex}.step-sub{opacity:.75;font-size:11px;font-weight:400}.checkbox-group{flex-wrap:wrap;gap:8px;display:flex}.checkbox-group.wrap{max-width:100%}.check-option{border:1.5px solid var(--border);cursor:pointer;user-select:none;background:#fff;border-radius:20px;align-items:center;gap:6px;padding:7px 14px;font-size:13px;font-weight:500;transition:all .15s;display:flex}.check-option input[type=radio]{display:none}.check-option:hover{border-color:var(--primary)}.check-option.selected{background:var(--primary);color:#fff;border-color:var(--primary)}.course-preview-mini{background:var(--primary-light);border-left:3px solid var(--primary);border-radius:var(--radius-sm);color:var(--text-secondary);margin-top:6px;padding:8px 12px;font-size:13px}.qual-row{border:1px solid var(--border);border-radius:var(--radius-sm);background:#fafafa;flex-direction:column;gap:12px;padding:16px;display:flex}.qual-row-header{color:var(--text-secondary);justify-content:space-between;align-items:center;font-size:13px;font-weight:700;display:flex}.doc-uploads{flex-direction:column;gap:12px;display:flex}.file-row{border:1px solid var(--border);border-radius:var(--radius-sm);background:#fafafa;flex-wrap:wrap;align-items:center;gap:14px;padding:12px 16px;display:flex}.file-row-label{flex-direction:column;flex:1;gap:2px;min-width:200px;font-size:13px;font-weight:600;display:flex}.field-hint{color:var(--text-muted);font-size:11px;font-weight:400}.required-star{color:var(--accent);font-size:13px}.file-chosen{align-items:center;gap:8px;display:flex}.file-name{color:var(--success);text-overflow:ellipsis;white-space:nowrap;max-width:200px;font-size:12px;font-weight:600;overflow:hidden}.declaration-box{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);background:#fafafa;padding:16px;font-size:13px;font-style:italic;line-height:1.7}.signatures-row{grid-template-columns:1fr 1fr;gap:24px;margin-top:16px;display:grid}.signature-wrap{flex-direction:column;gap:4px;display:flex}.signature-label{color:var(--text);margin-bottom:4px;font-size:13px;font-weight:600}.signature-canvas-wrap{position:relative}.signature-canvas{border:2px solid var(--border-dark);border-radius:var(--radius-sm);cursor:crosshair;touch-action:none;background:#fff;width:100%;height:140px;display:block}.signature-canvas.has-sig{border-color:var(--primary)}.signature-hint{color:var(--text-muted);pointer-events:none;user-select:none;font-size:13px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.input-error{border-color:var(--danger)!important;background:#fff8f8!important}.field-error{color:var(--danger);margin-top:3px;font-size:11px;font-weight:500;display:block}.public-page{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.public-page-header{border-bottom:1px solid var(--border);background:#fff;align-items:center;gap:16px;padding:14px 32px;display:flex}.public-brand{color:var(--primary);flex:1;align-items:center;gap:8px;font-size:14px;font-weight:700;display:flex}.topbar-logo{border-radius:4px;width:auto;height:36px}.hero-logo{border-radius:12px;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.6)}.landing{color:#fff;background:#0a0a0a;flex-direction:column;min-height:100vh;display:flex}.landing-topbar{background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.08)}.landing-topbar-inner{justify-content:space-between;align-items:center;max-width:1100px;margin:0 auto;padding:14px 24px;display:flex}.landing-brand{color:#fff;align-items:center;gap:10px;font-size:15px;font-weight:800;display:flex}.landing-topbar .btn-outline{color:rgba(255,255,255,.7);background:0 0;border-color:rgba(255,255,255,.2)}.landing-topbar .btn-outline:hover{color:#fff;background:rgba(255,255,255,.08)}.landing-hero{grid-template-columns:1fr 1fr;align-items:center;gap:60px;max-width:1100px;margin:0 auto;padding:80px 24px 60px;display:grid}.landing-badge{background:var(--accent);color:#fff;text-transform:uppercase;letter-spacing:.1em;border-radius:20px;margin-bottom:20px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-block}.landing-title{margin-bottom:20px;font-size:48px;font-weight:900;line-height:1.1}.landing-title-highlight{color:var(--accent)}.landing-subtitle{color:rgba(255,255,255,.65);margin-bottom:36px;font-size:16px;line-height:1.7}.landing-actions{flex-wrap:wrap;gap:14px;display:flex}.btn-lg{padding:14px 28px;font-size:15px}.landing-actions .btn-primary{background:var(--accent)}.landing-actions .btn-primary:hover{background:var(--accent-hover)}.landing-actions .btn-outline{color:#fff;background:0 0;border-color:rgba(255,255,255,.3)}.landing-actions .btn-outline:hover{color:#fff;background:rgba(255,255,255,.08)}.hero-card-stack{flex-direction:column;gap:14px;display:flex}.hero-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:14px;align-items:center;gap:16px;padding:18px 20px;display:flex}.hero-card-1{transform:translate(0)}.hero-card-2{transform:translate(24px)}.hero-card-3{transform:translate(12px)}.hero-card-icon{font-size:28px}.hero-card-text{flex-direction:column;gap:2px;display:flex}.hero-card-text strong{font-size:14px;font-weight:700}.hero-card-text span{color:rgba(255,255,255,.55);font-size:12px}.landing-steps-section{color:#111;background:#fff;padding:64px 24px}.landing-section-title{text-align:center;margin-bottom:48px;font-size:28px;font-weight:800}.landing-how-grid{grid-template-columns:repeat(3,1fr);gap:32px;max-width:900px;margin:0 auto;display:grid}.landing-how-step{text-align:center}.landing-step-num{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 16px;font-size:20px;font-weight:900;display:flex}.landing-how-step h3{margin-bottom:10px;font-size:16px;font-weight:700}.landing-how-step p{color:var(--text-secondary);font-size:14px;line-height:1.6}.landing-footer{text-align:center;color:rgba(255,255,255,.4);background:rgba(255,255,255,.03);border-top:1px solid rgba(255,255,255,.08);margin-top:auto;padding:24px;font-size:13px}.track-container{flex:1;justify-content:center;align-items:flex-start;padding:48px 16px;display:flex}.track-card{width:100%;max-width:600px;box-shadow:var(--shadow-lg);background:#fff;border-radius:16px;padding:40px}.track-title{margin-bottom:8px;font-size:22px;font-weight:800}.track-subtitle{color:var(--text-secondary);margin-bottom:28px;font-size:14px;line-height:1.6}.track-form{margin-bottom:20px}.track-input-group{gap:10px;display:flex}.track-input{border:1.5px solid var(--border);border-radius:var(--radius-sm);flex:1;padding:12px 16px;font-size:14px}.track-input:focus{border-color:var(--primary);outline:none}.track-error{color:var(--danger);background:var(--danger-light);border-radius:8px;align-items:center;gap:8px;padding:12px 14px;font-size:13px;display:flex}.track-result{border-top:1px solid var(--border);margin-top:24px;padding-top:24px}.track-result-name{align-items:center;gap:8px;margin-bottom:16px;font-size:16px;font-weight:700;display:flex}.track-app-card{border:1px solid var(--border);border-radius:10px;margin-bottom:14px;overflow:hidden}.track-app-header{background:var(--bg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.track-ref{color:var(--text-secondary);font-family:monospace;font-size:12px;font-weight:700}.track-status{border-radius:20px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:700;display:flex}.track-status-pending{background:var(--warning-light);color:var(--warning)}.track-status-approved{background:var(--success-light);color:var(--success)}.track-status-rejected{background:var(--danger-light);color:var(--danger)}.track-status-waitlisted{background:var(--info-light);color:var(--info)}.track-app-body{flex-direction:column;gap:8px;padding:16px;display:flex}.track-detail{gap:8px;font-size:13px;display:flex}.track-detail-label{color:var(--text-secondary);min-width:90px;font-weight:600}.track-approved-msg{background:var(--success-light);color:var(--success);border-radius:8px;align-items:flex-start;gap:8px;margin-top:6px;padding:10px 12px;font-size:13px;display:flex}.track-rejected-msg{background:var(--danger-light);color:var(--danger);border-radius:8px;align-items:flex-start;gap:8px;margin-top:6px;padding:10px 12px;font-size:13px;display:flex}.track-waitlist-msg{background:var(--info-light);color:var(--info);border-radius:8px;align-items:flex-start;gap:8px;margin-top:6px;padding:10px 12px;font-size:13px;display:flex}.submit-success-wrap{flex:1;justify-content:center;align-items:flex-start;padding:48px 16px;display:flex}.submit-success-card{width:100%;max-width:520px;box-shadow:var(--shadow-lg);text-align:center;background:#fff;border-radius:16px;padding:48px 40px}.submit-success-icon{color:var(--success);justify-content:center;margin-bottom:20px;display:flex}.submit-success-card h2{margin-bottom:12px;font-size:24px;font-weight:800}.submit-success-card p{color:var(--text-secondary);margin-bottom:24px;font-size:14px;line-height:1.6}.submit-ref-box{background:var(--bg);border:2px dashed var(--border-dark);border-radius:10px;margin-bottom:20px;padding:20px}.submit-ref-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-bottom:8px;font-size:11px;font-weight:700;display:block}.submit-ref-num{color:var(--primary);font-family:monospace;font-size:22px;font-weight:900}.submit-track-hint{color:var(--text-secondary);margin-bottom:28px;font-size:13px}@media (max-width:768px){.landing-hero{grid-template-columns:1fr;gap:40px;padding:48px 20px 40px}.landing-hero-visual{display:none}.landing-title{font-size:32px}.landing-how-grid{grid-template-columns:1fr;gap:24px}.track-input-group{flex-direction:column}.public-page-header{padding:12px 16px}}
