*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #2563eb;--primary-h: #1d4ed8;--danger: #dc2626;--success: #16a34a;--bg: #f8fafc;--surface: #ffffff;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--radius: 8px}body{font-family:Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);line-height:1.6}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}input,select,textarea{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;outline:none;transition:border-color .2s;background:var(--surface)}input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb26}button{cursor:pointer;font-size:14px;font-weight:500;border:none;border-radius:var(--radius);padding:10px 20px;transition:background .2s,opacity .2s}button:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;width:100%;padding:12px}.btn-primary:hover:not(:disabled){background:var(--primary-h)}.error-msg{color:var(--danger);font-size:13px;margin-top:4px}.success-msg{color:var(--success);font-size:13px;margin-top:4px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eff6ff,#dbeafe)}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:40px;width:100%;max-width:420px;box-shadow:0 4px 24px #00000014}.auth-card h1{font-size:24px;font-weight:700;margin-bottom:4px}.auth-card p.subtitle{color:var(--muted);font-size:14px;margin-bottom:24px}.auth-card form{display:flex;flex-direction:column;gap:14px}.sso-badge{background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:10px 14px;font-size:13px;color:#1e40af;margin-bottom:16px}.navbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}.navbar .logo{font-weight:700;font-size:18px;color:var(--primary)}.navbar .nav-actions{display:flex;align-items:center;gap:16px}.navbar .user-info{font-size:13px;color:var(--muted)}.navbar button.logout-btn{background:transparent;color:var(--danger);border:1px solid var(--danger);padding:6px 14px;font-size:13px}.dashboard{max-width:1100px;margin:0 auto;padding:32px 24px}.dashboard h2{font-size:20px;font-weight:600;margin-bottom:16px}.section{margin-bottom:40px}.partner-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.partner-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.partner-card img{width:48px;height:48px;object-fit:contain}.partner-card h3{font-size:15px;font-weight:600}.partner-card button{background:var(--primary);color:#fff;padding:8px 20px;border-radius:6px;font-size:13px}.course-list{display:flex;flex-wrap:wrap;gap:8px}.course-badge{background:#eff6ff;color:#1e40af;border:1px solid #bfdbfe;border-radius:20px;padding:4px 14px;font-size:12px;font-weight:500}.spinner-wrap{display:flex;justify-content:center;padding:60px}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th,.data-table td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--border)}.data-table th{font-weight:600;color:var(--muted);background:var(--bg)}.data-table tr:hover td{background:#f8fafc}.role-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.role-student{background:#dcfce7;color:#15803d}.role-instructor{background:#fef9c3;color:#854d0e}.role-admin{background:#fce7f3;color:#9d174d}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.admin-header h2{margin-bottom:2px}.admin-subtitle{color:var(--muted);font-size:14px;margin-bottom:0}.admin-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:2px solid var(--border);padding-bottom:0}.admin-tab{background:transparent;color:var(--muted);border:none;padding:10px 20px;border-radius:8px 8px 0 0;font-size:14px;font-weight:500;position:relative;transition:all .2s}.admin-tab:hover{color:var(--text);background:#2563eb0a}.admin-tab--active{color:var(--primary);background:#2563eb0f}.admin-tab--active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:2px;background:var(--primary);border-radius:2px 2px 0 0}.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;font-size:11px;font-weight:600;margin-left:6px;background:var(--border);color:var(--muted)}.admin-tab--active .tab-count{background:var(--primary);color:#fff}.admin-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 1px 3px #0000000a}.card-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border)}.card-header h3{font-size:16px;font-weight:600}.badge-count{font-size:12px;color:var(--muted);background:var(--bg);padding:4px 12px;border-radius:12px;border:1px solid var(--border)}.table-wrap{overflow-x:auto}.text-muted{color:var(--muted)}.text-sm{font-size:12px}.empty-row{text-align:center;color:var(--muted);padding:40px!important}.action-code{background:#f1f5f9;padding:2px 8px;border-radius:4px;font-size:11px;color:#334155}.btn-add{background:linear-gradient(135deg,var(--primary),#3b82f6);color:#fff;padding:10px 20px;border-radius:8px;font-weight:500;display:inline-flex;align-items:center;gap:6px;font-size:13px;transition:all .2s;box-shadow:0 2px 8px #2563eb40}.btn-add:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2563eb59}.btn-add-icon{font-size:18px;font-weight:700;line-height:1}.empty-state{text-align:center;padding:60px 24px;color:var(--muted)}.empty-icon{font-size:48px;margin-bottom:12px}.empty-state h4{font-size:18px;color:var(--text);margin-bottom:8px}.empty-state p{font-size:14px;margin-bottom:20px}.empty-state .btn-add{margin:0 auto}.sp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px;padding:20px}.sp-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:all .2s;display:flex;flex-direction:column}.sp-card:hover{border-color:#bfdbfe;box-shadow:0 4px 16px #2563eb14;transform:translateY(-2px)}.sp-card-header{display:flex;align-items:center;gap:14px;padding:20px 20px 12px}.sp-card-icon img{width:44px;height:44px;border-radius:10px;object-fit:contain;border:1px solid var(--border)}.sp-icon-placeholder{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,#eff6ff,#dbeafe);color:var(--primary);font-weight:700;font-size:18px}.sp-card-info h4{font-size:15px;font-weight:600;margin-bottom:4px}.status-dot{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px}.status-dot:before{content:"";width:7px;height:7px;border-radius:50%}.status-active{color:#16a34a}.status-active:before{background:#16a34a;box-shadow:0 0 6px #16a34a66}.status-inactive{color:#dc2626}.status-inactive:before{background:#dc2626}.sp-card-details{padding:0 20px 16px;flex:1}.sp-detail-row{display:flex;justify-content:space-between;align-items:flex-start;padding:6px 0;gap:12px;border-bottom:1px solid #f1f5f9}.sp-detail-row:last-child{border-bottom:none}.sp-label{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;min-width:80px}.sp-value{font-size:12px;color:var(--text);text-align:right;word-break:break-all}.sp-value--truncate{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}code.sp-value{background:#f1f5f9;padding:1px 6px;border-radius:4px;font-size:12px}.sp-roles{display:flex;flex-wrap:wrap;gap:4px;justify-content:flex-end}.sp-card-actions{display:flex;gap:8px;padding:12px 20px;border-top:1px solid var(--border);background:#fafbfc}.btn-view,.btn-edit,.btn-delete,.btn-cancel,.btn-danger{padding:7px 16px;border-radius:6px;font-size:12px;font-weight:500;transition:all .15s}.btn-view{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}.btn-view:hover{background:#dbeafe}.btn-edit{background:#fefce8;color:#854d0e;border:1px solid #fde68a}.btn-edit:hover{background:#fef9c3}.btn-delete{background:#fff;color:var(--danger);border:1px solid #fecaca;margin-left:auto}.btn-delete:hover{background:#fef2f2}.btn-cancel{background:var(--bg);color:var(--muted);border:1px solid var(--border)}.btn-cancel:hover{background:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fadeIn .2s ease}.modal{background:var(--surface);border-radius:16px;width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026;animation:slideUp .25s ease}.modal--sm{max-width:560px}.modal--xs{max-width:420px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);z-index:1;border-radius:16px 16px 0 0}.modal-header h3{font-size:18px;font-weight:600}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg);border:1px solid var(--border);border-radius:8px;font-size:16px;color:var(--muted);padding:0;cursor:pointer;transition:all .15s}.modal-close:hover{background:#fee2e2;color:var(--danger);border-color:#fecaca}.modal-form{padding:24px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group--full{grid-column:1 / -1}.form-group label{font-size:13px;font-weight:600;color:var(--text)}.form-hint{font-size:11px;color:var(--muted);line-height:1.4}.form-hint--warn{color:#d97706}.checkbox-group{display:flex;gap:12px;flex-wrap:wrap}.checkbox-label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13px}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.toggle-row{display:flex;gap:24px;flex-wrap:wrap;padding:12px 0}.toggle-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:500;color:var(--text);cursor:pointer}.toggle-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding:20px 24px;border-top:1px solid var(--border);background:#fafbfc;border-radius:0 0 16px 16px}.modal-actions .btn-primary{width:auto;padding:10px 28px}.detail-grid{padding:20px 24px}.detail-item{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 0;border-bottom:1px solid #f1f5f9;gap:16px}.detail-item:last-child{border-bottom:none}.detail-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;min-width:120px}.detail-value{font-size:13px;color:var(--text);text-align:right;word-break:break-all}code.detail-value{background:#f1f5f9;padding:2px 8px;border-radius:4px;font-size:12px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:slideUp .3s ease}@media (max-width: 768px){.sp-grid,.form-grid{grid-template-columns:1fr}.form-group--full{grid-column:1}.admin-tabs{overflow-x:auto}.modal{margin:10px;max-height:95vh}.toggle-row{flex-direction:column;gap:12px}.card-header{flex-direction:column;gap:12px;align-items:flex-start}}
