.breadcrumbs{margin-bottom:20px;font-size:14px}.breadcrumb-list{align-items:center;margin:0;padding:0;list-style:none;display:flex}.breadcrumb-item{color:var(--text-gray);align-items:center;display:flex}.breadcrumb-link{color:var(--text-gray);align-items:center;text-decoration:none;transition:color .2s;display:flex}.breadcrumb-link:hover{color:var(--primary)}.breadcrumb-separator{color:#d1d5db;margin:0 8px}.breadcrumb-current{color:var(--text-dark);font-weight:600}.page-header{justify-content:space-between;align-items:center;gap:24px;margin-bottom:32px;display:flex}.page-title{color:var(--text-dark,#0a1128);letter-spacing:-.02em;margin:0 0 4px;font-size:28px;font-weight:800}.page-subtitle{color:var(--text-gray,#6b7280);font-size:15px;font-weight:500}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px;display:grid}.courses-grid,.materials-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px;margin-top:28px;display:grid}.stat-card,.dash-card{border:1.5px solid var(--border-color,#f3f4f6);background:#fff;border-radius:20px;padding:24px;transition:all .2s;box-shadow:0 1px 4px #0000000d}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000014}.stat-icon{background:var(--portal-accent-soft);width:56px;height:56px;color:var(--portal-accent);border-radius:16px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.stat-info h3{color:var(--text-gray,#6b7280);text-transform:uppercase;letter-spacing:.02em;margin-bottom:4px;font-size:13px;font-weight:600}.stat-value{color:var(--text-dark,#0a1128);font-size:28px;font-weight:800;line-height:1}.dash-card{padding:32px}.card-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;width:100%;padding:16px 20px;display:flex!important}.card-header-left{flex:1;align-items:center;gap:12px;display:flex}.card-header h3{color:#0f172a;margin:0;font-size:16px;font-weight:700}.card-link{color:var(--portal-accent);background:var(--portal-accent-soft);white-space:nowrap;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:700;text-decoration:none;transition:all .2s}.card-link:hover{filter:brightness(.9);transform:translateY(-1px)}.status-pill{text-transform:uppercase;letter-spacing:.05em;border-radius:8px;padding:4px 12px;font-size:11px;font-weight:700;display:inline-flex}.status-pill.success{color:#059669;background:#e1f9eb}.status-pill.warning{color:#d97706;background:#fff7ed}.status-pill.danger{color:#ef4444;background:#fef2f2}.status-pill.info{background:var(--portal-accent-soft);color:var(--portal-accent)}.dash-label{color:#475569;margin-bottom:8px;font-size:13px;font-weight:700;display:block}.dash-input,.dash-textarea{background:#f8fafc;border:2px solid #f1f5f9;border-radius:12px;outline:none;width:100%;padding:12px 16px;font-family:inherit;font-size:14px;transition:all .2s}.dash-input:focus,.dash-textarea:focus{border-color:var(--portal-accent);box-shadow:0 0 0 4px var(--portal-accent-soft);background:#fff}.empty-mini{text-align:center;color:#64748b;background:#f8fafc;border:2px dashed #e2e8f0;border-radius:20px;flex-direction:column;justify-content:center;align-items:center;padding:48px 24px;display:flex}.empty-mini svg{opacity:.6;color:var(--portal-accent);margin-bottom:12px}.empty-mini p{max-width:240px;margin:0;font-size:14px;font-weight:600;line-height:1.5}.action-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:700;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.action-btn.primary,.action-btn.accent{background:var(--portal-accent);color:#fff;box-shadow:0 4px 12px var(--portal-accent-soft)}.action-btn:hover:not(:disabled){filter:brightness(1.05);box-shadow:0 6px 20px var(--portal-accent-soft);transform:translateY(-2px)}.action-btn.outline{color:#64748b;background:0 0;border:2px solid #f1f5f9}.action-btn.outline:hover{border-color:var(--portal-accent);color:var(--portal-accent);background:var(--portal-accent-soft)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.animate-slide-up{animation:.4s cubic-bezier(.16,1,.3,1) slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.btn-pulse{animation:2s infinite btnPulse}@keyframes btnPulse{0%{box-shadow:0 0 0 0 var(--portal-accent-soft)}70%{box-shadow:0 0 0 10px #0000}to{box-shadow:0 0 #0000}}.loader-container{flex-direction:column;justify-content:center;align-items:center;gap:16px;width:100%;display:flex}*{box-sizing:border-box}.dash-root{background:#f0f2f8;min-height:100vh;font-family:Inter,sans-serif;display:flex}.dash-sidebar{z-index:100;background:#0a1128;flex-direction:column;width:260px;min-width:260px;height:100vh;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar-closed .dash-sidebar{width:72px;min-width:72px}.dash-sidebar-header{border-bottom:1px solid #ffffff14;justify-content:space-between;align-items:center;min-height:72px;padding:20px 16px;display:flex}.dash-logo{align-items:center;gap:10px;text-decoration:none;display:flex;overflow:hidden}.dash-logo-img{object-fit:contain;flex-shrink:0;width:32px;height:32px}.dash-logo-text{color:#fff;white-space:nowrap;font-size:16px;font-weight:700}.dash-sidebar-toggle{color:#fff9;cursor:pointer;background:#ffffff14;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;transition:all .2s;display:flex}.dash-sidebar-toggle:hover{color:#fff;background:#ffffff26}.dash-role-badge{background:var(--role-color,#0d3cd8);opacity:.9;color:#fff;text-transform:uppercase;letter-spacing:.5px;border-radius:8px;align-items:center;gap:8px;margin:12px 16px;padding:8px 12px;font-size:12px;font-weight:600;display:flex}.dash-nav{flex-direction:column;flex:1;gap:4px;padding:12px 8px;display:flex;overflow-y:auto}.dash-nav-item{color:#ffffffa6;white-space:nowrap;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:12px;align-items:center;gap:12px;width:100%;padding:12px 14px;font-size:14px;font-weight:500;text-decoration:none;transition:all .25s cubic-bezier(.4,0,.2,1);display:flex;position:relative}.dash-nav-item:hover{color:#fff;background:#ffffff14;transform:translate(4px)}.dash-nav-item.active{background:var(--portal-accent-soft,#0d3cd840);color:#fff;font-weight:600}.nav-item-icon-wrap{flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.nav-badge-dot{background:#ef4444;border:2px solid #0a1128;border-radius:50%;width:8px;height:8px;position:absolute;top:-2px;right:-2px}.nav-label-group{flex:1;justify-content:space-between;align-items:center;min-width:0;display:flex}.nav-count-badge{color:#fff;background:#ef4444;border-radius:10px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:800;display:flex;box-shadow:0 2px 8px #ef444466}.active-bar{background:var(--portal-accent,#0d3cd8);border-radius:0 4px 4px 0;width:4px;height:24px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar-closed .dash-nav-item span,.sidebar-closed .dash-role-badge span,.sidebar-closed .dash-logo-text{display:none}.sidebar-closed .dash-nav-item{justify-content:center;padding:12px}.dash-sidebar-footer{border-top:1px solid #ffffff14;padding:12px 8px}.logout-btn{color:#ff6464b3}.logout-btn:hover{color:#f87171;background:#ef44441f}.system-status-indicator{color:#ffffff80;background:#ffffff08;border-radius:8px;align-items:center;gap:8px;margin-top:12px;padding:8px 12px;font-size:11px;font-weight:600;display:flex}.system-status-indicator svg.healthy{color:#10b981;filter:drop-shadow(0 0 4px #10b98166);animation:2s infinite statusPulse}.system-status-indicator svg.loading{color:#f59e0b;animation:2s linear infinite spin}.system-status-indicator svg.error{color:#ef4444}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dash-main{flex-direction:column;flex:1;min-height:100vh;margin-left:260px;transition:margin-left .3s cubic-bezier(.4,0,.2,1);display:flex}.sidebar-closed .dash-main{margin-left:72px}.dash-topbar{z-index:50;background:#fff;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;height:72px;padding:0 32px;display:flex;position:sticky;top:0;box-shadow:0 1px 4px #0000000f}.dash-topbar-left{align-items:center;gap:16px;display:flex}.dash-topbar-right{align-items:center;gap:12px;display:flex}.mobile-menu-btn{cursor:pointer;color:#374151;background:0 0;border:none;display:none}.topbar-icon-btn{cursor:pointer;color:#374151;background:#f3f4f6;border:none;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:relative}.topbar-icon-btn:hover{background:#e5e7eb}.notif-dot{background:#ef4444;border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:8px;right:8px}.user-menu-wrapper{position:relative}.user-menu-trigger{cursor:pointer;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:12px;align-items:center;gap:10px;padding:6px 12px 6px 6px;transition:all .2s;display:flex}.user-menu-trigger:hover{background:#e5e7eb}.user-avatar{background:var(--role-color,#0d3cd8);color:#fff;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex}.user-info{flex-direction:column;align-items:flex-start;display:flex}.user-name{color:#111827;font-size:13px;font-weight:600;line-height:1.2}.user-role{color:#6b7280;font-size:11px}.user-menu-trigger svg{color:#6b7280;transition:transform .2s}.user-menu-trigger svg.rotated{transform:rotate(180deg)}.user-dropdown{z-index:200;background:#fff;border:1px solid #e5e7eb;border-radius:16px;min-width:220px;padding:8px;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 20px 40px -10px #00000026}.dropdown-header{border-bottom:1px solid #f3f4f6;margin-bottom:4px;padding:10px 12px 12px}.dropdown-name{color:#111827;font-size:14px;font-weight:600}.dropdown-email{color:#6b7280;margin-top:2px;font-size:12px}.dropdown-item{color:#374151;cursor:pointer;background:0 0;border:none;border-radius:10px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-family:inherit;font-size:14px;text-decoration:none;transition:all .15s;display:flex}.dropdown-item:hover{color:#111827;background:#f9fafb}.dropdown-item.danger{color:#ef4444}.dropdown-item.danger:hover{background:#fef2f2}.topbar-notif-wrapper{position:relative}.notif-dropdown{z-index:210;background:#fff;border:1px solid #e5e7eb;border-radius:18px;width:340px;animation:.25s cubic-bezier(.16,1,.3,1) slideInDown;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 20px 40px -10px #00000026}@keyframes slideInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notif-dropdown .dropdown-header{background:#f8fafc;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.unread-total-badge{color:#fff;letter-spacing:.02em;background:#ef4444;border-radius:20px;padding:3px 8px;font-size:10px;font-weight:800}.notif-preview-item{border-bottom:1px solid #f1f5f9;align-items:center;gap:14px;padding:14px 20px;text-decoration:none;transition:all .2s;display:flex;position:relative}.notif-preview-item:hover{background:#f1f5f9}.notif-preview-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.notif-preview-icon.info{color:#0d3cd8;background:#ebf0ff}.notif-preview-icon.alert{color:#ef4444;background:#fef2f2}.notif-preview-body{flex:1;min-width:0}.notif-preview-title{color:#1e293b;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:13px;font-weight:700;overflow:hidden}.notif-preview-meta{color:#94a3b8;margin:2px 0 0;font-size:11px}.notif-preview-arrow{color:#cbd5e1;opacity:0;transition:all .2s;transform:translate(-5px)}.notif-preview-item:hover .notif-preview-arrow{opacity:1;transform:translate(0)}.notif-empty-state{text-align:center;color:#94a3b8;padding:40px 20px}.notif-empty-state p{margin-top:8px;font-size:13px;font-weight:500}.notif-dropdown-footer{color:var(--portal-accent,#0d3cd8);background:#fff;justify-content:center;align-items:center;padding:14px;font-size:13px;font-weight:700;text-decoration:none;transition:background .2s;display:flex}.notif-dropdown-footer:hover{background:#f8fafc;text-decoration:underline}@media (width<=768px){.notif-dropdown{width:calc(100vw - 32px);right:-100px}}.dash-content{flex-direction:column;flex:1;padding:32px;display:flex;overflow:hidden auto}.dash-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:90;background:#0a112866;animation:.2s fadeIn;display:none;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (width<=1024px){.dash-content{padding:24px 20px}.dash-sidebar{transform:translate(-105%);box-shadow:20px 0 50px #0000001a;width:280px!important;min-width:280px!important}.sidebar-open .dash-sidebar{transform:translate(0)}.sidebar-open .dash-overlay{display:block}.dash-main{max-width:100vw;overflow-x:hidden;margin-left:0!important}.sidebar-closed .dash-sidebar{transform:translate(-105%)}.mobile-menu-btn{display:flex}.dash-content{max-width:100%;padding:20px 16px;overflow-x:hidden}.dash-topbar{gap:8px;padding:0 16px}.dash-topbar-right{gap:8px}.user-info{display:none}.topbar-icon-btn{width:36px;height:36px}.dash-sidebar-header{padding:16px}.dash-logo-text,.dash-nav-item span,.dash-role-badge span{display:block!important}}.system-status-indicator{color:#64748b;letter-spacing:.02em;border-top:1px solid #e2e8f0;align-items:center;gap:8px;margin-top:12px;padding:12px 16px;font-size:11px;font-weight:500;display:flex}.system-status-indicator .Activity{transition:color .3s}.system-status-indicator .Activity.healthy{color:#10b981}.system-status-indicator .Activity.error{color:#ef4444;animation:2s infinite pulse-red}.system-status-indicator .Activity.loading{color:#94a3b8}@keyframes pulse-red{0%{opacity:1}50%{opacity:.5}to{opacity:1}}
