@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--navy:#1b2a3b;--navy-light:#22334a;--navy-mid:#243447;--cyan:#00d4b8;--cyan-dim:#00d4b81f;--cyan-hover:#00d4b833;--cyan-border:#00d4b859;--text:#edf2f7;--text-muted:#edf2f79e;--text-dim:#edf2f759;--border:#ffffff14;--border-strong:#ffffff26;--surface:#ffffff0d;--surface2:#ffffff17;--surface3:#ffffff21;--danger:#ff6b6b;--warning:#ffb432;--success:#00d4b8;--purple:#9090ff;--radius:10px;--radius-sm:6px;--radius-lg:14px;--shadow:0 4px 20px #0000004d;--shadow-sm:0 2px 8px #0003}html,body,#root{background:var(--navy);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.5}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}.app-shell{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-body{flex:1;display:flex;overflow:hidden}.main-content{flex:1;padding:28px 32px;overflow-y:auto}.topbar{background:var(--navy);border-bottom:1px solid var(--border);z-index:50;flex-shrink:0;justify-content:space-between;align-items:center;height:58px;padding:0 24px;display:flex}.topbar-logo{align-items:center;gap:12px;text-decoration:none;display:flex}.topbar-logo img{height:28px}.topbar-divider{background:var(--border-strong);width:1px;height:20px}.topbar-label{color:var(--text-muted);letter-spacing:.04em;font-size:12px;font-weight:500}.topbar-right{align-items:center;gap:12px;display:flex}.view-toggle{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);display:flex;overflow:hidden}.view-btn{cursor:pointer;color:var(--text-muted);background:0 0;border:none;padding:6px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.view-btn.active{background:var(--cyan);color:var(--navy)}.avatar-btn{background:var(--cyan);width:34px;height:34px;color:var(--navy);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.sidebar{background:var(--navy-mid);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:2px;width:210px;padding:16px 10px;display:flex;overflow-y:auto}.nav-group-label{color:var(--text-dim);letter-spacing:.1em;text-transform:uppercase;padding:14px 10px 5px;font-size:10px;font-weight:600}.nav-item{border-radius:var(--radius-sm);cursor:pointer;color:var(--text-muted);text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:9px 10px;font-family:inherit;font-size:13px;text-decoration:none;transition:all .15s;display:flex}.nav-item svg{opacity:.7;flex-shrink:0}.nav-item:hover{background:var(--surface);color:var(--text)}.nav-item:hover svg{opacity:1}.nav-item.active{background:var(--cyan-dim);color:var(--cyan)}.nav-item.active svg{opacity:1;color:var(--cyan)}.nav-badge{background:var(--danger);color:#fff;text-align:center;border-radius:10px;min-width:18px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:600}.page-header{justify-content:space-between;align-items:flex-start;margin-bottom:24px;display:flex}.page-title{margin-bottom:3px;font-size:20px;font-weight:600}.page-sub{color:var(--text-muted);font-size:13px}.page-actions{align-items:center;gap:10px;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:7px;padding:9px 18px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--cyan);color:var(--navy)}.btn-primary:hover{opacity:.88;transform:translateY(-1px)}.btn-ghost{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted)}.btn-ghost:hover{color:var(--text);border-color:var(--border-strong);background:var(--surface3)}.btn-danger{color:var(--danger);background:#ff6b6b26;border:1px solid #ff6b6b4d}.btn-danger:hover{background:#ff6b6b40}.btn-sm{padding:6px 12px;font-size:12px}.btn-icon{padding:8px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.stats-grid{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px}.stat-label{color:var(--text-dim);letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;font-size:11px;font-weight:600}.stat-value{margin-bottom:6px;font-size:30px;font-weight:600;line-height:1}.stat-sub{color:var(--text-dim);font-size:11px}.stat-sub.positive{color:var(--cyan)}.stat-sub.negative{color:var(--danger)}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}table{border-collapse:collapse;width:100%}thead th{color:var(--text-dim);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;padding:12px 18px;font-size:11px;font-weight:600}tbody td{border-bottom:1px solid var(--border);color:var(--text-muted);vertical-align:middle;padding:14px 18px;font-size:13px}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--surface2);color:var(--text)}.badge{white-space:nowrap;border-radius:20px;padding:3px 9px;font-size:11px;font-weight:500;display:inline-block}.badge-it{color:var(--cyan);background:#00d4b824}.badge-comp{color:var(--warning);background:#ffb43224}.badge-soft{color:var(--purple);background:#8282ff24}.badge-completed{color:var(--cyan);background:#00d4b824}.badge-in_progress{color:var(--warning);background:#ffb43224}.badge-not_started{background:var(--surface2);color:var(--text-dim)}.badge-overdue{color:var(--danger);background:#ff6b6b24}.avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:11px;font-weight:600;display:flex}.staff-name-cell{align-items:center;gap:10px;display:flex}.staff-name-cell strong{color:var(--text);font-size:13px;font-weight:500;display:block}.staff-name-cell span{color:var(--text-dim);font-size:11px}.prog-bar{background:var(--surface3);border-radius:2px;height:4px;overflow:hidden}.prog-fill{background:var(--cyan);border-radius:2px;height:100%;transition:width .4s}.prog-row{align-items:center;gap:10px;display:flex}.prog-pct{color:var(--text-muted);min-width:34px;font-size:12px}.modules-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.module-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;padding:18px;transition:all .18s;display:flex}.module-card:hover{border-color:var(--cyan-border);background:var(--cyan-dim);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.module-card-name{color:var(--text);margin-bottom:8px;font-size:14px;font-weight:500;line-height:1.4}.module-card-desc{color:var(--text-dim);flex:1;font-size:12px;line-height:1.6}.module-card-meta{color:var(--text-dim);align-items:center;gap:14px;margin-top:14px;font-size:11px;display:flex}.search-row{align-items:center;gap:10px;margin-bottom:16px;display:flex}.search-input{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);flex:1;align-items:center;gap:8px;padding:9px 12px;display:flex}.search-input input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:13px}.search-input input::placeholder{color:var(--text-dim)}.filter-chips{flex-wrap:wrap;gap:8px;margin-bottom:18px;display:flex}.chip{cursor:pointer;border:1px solid var(--border);color:var(--text-muted);background:0 0;border-radius:20px;padding:5px 14px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.chip.active{background:var(--cyan-dim);border-color:var(--cyan-border);color:var(--cyan)}.modal-overlay{z-index:200;background:#000000a6;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--navy-light);border:1px solid var(--border-strong);border-radius:var(--radius-lg);width:480px;max-width:100%;max-height:90vh;box-shadow:var(--shadow);overflow-y:auto}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:22px 22px 18px;display:flex}.modal-title{font-size:16px;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;padding:4px;transition:all .15s}.modal-close:hover{background:var(--surface2);color:var(--text)}.modal-body{padding:22px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 22px;display:flex}.form-group{margin-bottom:18px}.form-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px;font-size:11px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);outline:none;padding:10px 12px;font-family:inherit;font-size:13px;transition:border-color .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--cyan-border)}.form-textarea{resize:vertical;min-height:80px;line-height:1.6}.form-select option{background:var(--navy-mid)}.form-hint{color:var(--text-dim);margin-top:5px;font-size:11px}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.toast{z-index:999;border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:10px;padding:12px 20px;font-size:13px;font-weight:500;animation:.25s slide-up;display:flex;position:fixed;bottom:24px;right:24px}.toast-success{background:var(--navy-light);border:1px solid var(--cyan-border);color:var(--cyan)}.toast-error{background:var(--navy-light);color:var(--danger);border:1px solid #ff6b6b66}@keyframes slide-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.plan-step{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:flex-start;gap:14px;margin-bottom:10px;padding:14px 16px;display:flex}.step-num{background:var(--cyan-dim);border:1px solid var(--cyan-border);width:30px;height:30px;color:var(--cyan);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex}.step-num.done{background:var(--cyan);color:var(--navy);border-color:var(--cyan)}.step-info{flex:1}.step-title{margin-bottom:3px;font-size:14px;font-weight:500}.step-meta{color:var(--text-dim);font-size:11px}.step-action{margin-left:auto}.learner-banner{background:var(--navy-light);border:1px solid var(--border);border-radius:var(--radius-lg);align-items:center;gap:18px;margin-bottom:24px;padding:22px 24px;display:flex}.learner-av{background:var(--cyan);width:54px;height:54px;color:var(--navy);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;font-weight:600;display:flex}.learner-info h2{margin-bottom:3px;font-size:16px;font-weight:600}.learner-info p{color:var(--text-muted);font-size:12px}.learner-progress{text-align:right;margin-left:auto}.big-pct{color:var(--cyan);margin-bottom:4px;font-size:36px;font-weight:600;line-height:1}.big-pct-label{color:var(--text-dim);font-size:11px}.section-title{color:var(--text-dim);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px;font-size:12px;font-weight:600}.empty-state{text-align:center;color:var(--text-dim);padding:60px 20px}.empty-state svg{opacity:.3;margin-bottom:14px}.empty-state p{font-size:14px}.check-list{flex-direction:column;gap:8px;max-height:220px;display:flex;overflow-y:auto}.check-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;align-items:center;gap:10px;padding:10px 12px;transition:all .15s;display:flex}.check-item:hover{border-color:var(--border-strong)}.check-item.selected{background:var(--cyan-dim);border-color:var(--cyan-border)}.check-item input[type=checkbox]{accent-color:var(--cyan);cursor:pointer;width:15px;height:15px}@media (width<=900px){.stats-grid,.modules-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=640px){.sidebar{display:none}.main-content{padding:16px}.modules-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}}
