*,:before,:after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 transparent;--tw-ring-shadow:0 0 transparent;--tw-shadow:0 0 transparent;--tw-shadow-colored:0 0 transparent;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::-ms-backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 transparent;--tw-ring-shadow:0 0 transparent;--tw-shadow:0 0 transparent;--tw-shadow-colored:0 0 transparent;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 transparent;--tw-ring-shadow:0 0 transparent;--tw-shadow:0 0 transparent;--tw-shadow-colored:0 0 transparent;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans,Ubuntu,Cantarell,Helvetica Neue,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button{-webkit-appearance:button;background-color:transparent;background-image:none}input:where([type=button]){-webkit-appearance:button;background-color:transparent;background-image:none}input:where([type=reset]){-webkit-appearance:button;background-color:transparent;background-image:none}input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::-webkit-input-placeholder{opacity:1;color:#9ca3af}input::-moz-placeholder{opacity:1;color:#9ca3af}input::-ms-input-placeholder{opacity:1;color:#9ca3af}input::placeholder{opacity:1;color:#9ca3af}textarea::-webkit-input-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-ms-input-placeholder{opacity:1;color:#9ca3af}textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.mt-2{margin-top:.5rem}.flex{display:flex}.table{display:table}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.border-slate-200{--tw-border-opacity:1;border-color:rgba(226,232,240,var(--tw-border-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgba(255,255,255,var(--tw-bg-opacity,1))}.p-6{padding:1.5rem}.text-sm{font-size:.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-semibold{font-weight:600}.text-slate-600{--tw-text-opacity:1;color:rgba(71,85,105,var(--tw-text-opacity,1))}.text-slate-900{--tw-text-opacity:1;color:rgba(15,23,42,var(--tw-text-opacity,1))}.shadow-sm{--tw-shadow:0 1px 2px 0 rgba(0,0,0,.05);--tw-shadow-colored:0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 transparent), var(--tw-ring-shadow,0 0 transparent), var(--tw-shadow)}.filter{-webkit-filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--blue:#004589;--blue-600:#003a73;--blue-50:#eaf2fb;--orange:#e84b2a;--orange-tint:rgba(232,75,42,.12);--sidebar:#0d1b2a;--sidebar-hover:#16263b;--sidebar-muted:#94a3b8;--page:#f8fafc;--border:#e2e8f0;--border-strong:#cbd5e1;--ink:#0f172a;--ink-2:#334155;--ink-3:#64748b;--ink-4:#94a3b8;--green:#16a34a;--green-bg:#dcfce7;--amber:#d97706;--amber-bg:#fef3c7;--red:#dc2626;--red-bg:#fee2e2;--teal:#0f8c8c;--purple:#7c3aed;--purple-bg:#ede9fe;--shadow:0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.04);--shadow-md:0 4px 12px rgba(15,23,42,.06), 0 2px 4px rgba(15,23,42,.04)}body{background:var(--page);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.45}.app{min-height:100vh;display:flex}.sidebar{background:var(--sidebar);color:#e2e8f0;z-index:40;border-right:1px solid #0a1421;flex-direction:column;flex-shrink:0;width:240px;display:flex;position:fixed;top:0;bottom:0;left:0}.main{flex-direction:column;flex:1;min-width:0;margin-left:240px;display:flex}.logo-wrap{border-bottom:1px solid rgba(255,255,255,.06);flex-direction:column;gap:6px;padding:16px 16px 14px;display:flex}.logo-plate{background:#fff;border-radius:8px;justify-content:flex-start;align-items:center;height:50px;padding:8px 12px;display:flex}.logo-plate img{-o-object-fit:contain;object-fit:contain;width:auto;max-height:32px;display:block}.logo-sub{color:var(--sidebar-muted);letter-spacing:.06em;padding-left:2px;font-size:10.5px;font-weight:500}.nav{scrollbar-width:thin;scrollbar-color:#2a3a52 transparent;flex:1;padding:14px 10px 10px;overflow-y:auto}.nav::-webkit-scrollbar{width:6px}.nav::-webkit-scrollbar-thumb{background:#2a3a52;border-radius:3px}.section-label{color:#64748b;letter-spacing:.12em;text-transform:uppercase;padding:14px 12px 6px;font-size:10px;font-weight:600}.nav-item{color:#cbd5e1;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border-left:3px solid transparent;border-radius:6px;align-items:center;gap:11px;margin-left:-3px;padding:9px 12px;font-size:13.5px;font-weight:500;text-decoration:none;transition:background .12s,color .12s;display:flex;position:relative}.nav-item svg{color:#94a3b8;flex-shrink:0;width:18px;height:18px}.nav-item:hover{background:var(--sidebar-hover);color:#fff}.nav-item:hover svg{color:#cbd5e1}.nav-item .label{flex:1}.nav-item.active{background:var(--orange-tint);color:#fff;border-left-color:var(--orange)}.nav-item.active svg{color:var(--orange)}.badge-dot{background:var(--orange);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 6px;font-size:10.5px;font-weight:700;line-height:1;display:inline-flex}.profile{cursor:pointer;border-top:1px solid rgba(255,255,255,.06);align-items:center;gap:10px;padding:12px;transition:background .12s;display:flex}.profile:hover{background:var(--sidebar-hover)}.avatar{color:#fff;background:linear-gradient(135deg,#2563eb,#004589);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:700;display:flex}.profile .pname{color:#fff;font-size:13px;font-weight:600;line-height:1.2}.profile .prole{color:var(--sidebar-muted);margin-top:2px;font-size:11px;line-height:1.3}.profile .pmeta{flex:1;min-width:0;overflow:hidden}.profile .pmeta .pname,.profile .pmeta .prole{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.profile svg{color:var(--sidebar-muted);width:16px;height:16px}.header{border-bottom:1px solid var(--border);z-index:50;background:#fff;align-items:center;gap:24px;height:64px;padding:0 28px;display:flex;position:-webkit-sticky;position:sticky;top:0}.header-title h1{color:var(--ink);margin:0;font-size:18px;font-weight:700;line-height:1.1}.breadcrumb{color:var(--ink-3);align-items:center;gap:5px;margin-top:3px;font-size:12px;display:flex}.breadcrumb .crumb-sep{color:var(--ink-4);display:inline-flex}.breadcrumb .crumb-sep svg{width:12px;height:12px}.breadcrumb .crumb-current{color:var(--ink-2);font-weight:500}.search{flex:1;max-width:480px;margin:0 auto;position:relative}.search input{border:1px solid var(--border);background:var(--page);width:100%;height:38px;color:var(--ink);border-radius:8px;outline:none;padding:0 14px 0 40px;font-family:inherit;font-size:13px;transition:border-color .15s,background .15s}.search input:focus{border-color:var(--blue);background:#fff;box-shadow:0 0 0 3px rgba(0,69,137,.08)}.search>svg{color:var(--ink-4);width:17px;height:17px;position:absolute;top:50%;left:13px;transform:translateY(-50%)}.search kbd{color:var(--ink-3);border:1px solid var(--border);background:#fff;border-radius:4px;padding:2px 6px;font-family:inherit;font-size:10.5px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.header-actions{align-items:center;gap:8px;display:flex}.icon-btn{border:1px solid var(--border);cursor:pointer;width:38px;height:38px;color:var(--ink-2);background:#fff;border-radius:8px;justify-content:center;align-items:center;transition:background .12s,border-color .12s;display:flex;position:relative}.icon-btn:hover{background:var(--page);border-color:var(--border-strong)}.icon-btn svg{width:19px;height:19px}.icon-btn .dot-badge{background:var(--orange);color:#fff;border:2px solid #fff;border-radius:9px;justify-content:center;align-items:center;min-width:17px;height:17px;padding:0 5px;font-size:10px;font-weight:700;line-height:1;display:flex;position:absolute;top:-3px;right:-3px}.header-avatar{color:#fff;cursor:pointer;width:38px;height:38px;box-shadow:0 0 0 1px var(--border);background:linear-gradient(135deg,#e84b2a,#c03a1f);border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.notif-wrap{position:relative}.notif-dropdown{border:1px solid var(--border);z-index:100;opacity:0;pointer-events:none;background:#fff;border-radius:10px;width:360px;transition:opacity .15s,transform .15s;position:absolute;top:50px;right:0;transform:translateY(-6px);box-shadow:0 12px 40px rgba(15,23,42,.12),0 4px 12px rgba(15,23,42,.06)}.notif-dropdown.open{opacity:1;pointer-events:auto;transform:translateY(0)}.notif-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.notif-head .title{color:var(--ink);font-size:14px;font-weight:700}.notif-head .link{color:var(--blue);cursor:pointer;font-size:12px}.notif-item{border-bottom:1px solid var(--border);cursor:pointer;gap:12px;padding:12px 16px;display:flex}.notif-item:hover{background:var(--page)}.notif-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.notif-icon svg{width:16px;height:16px}.notif-icon.green{background:var(--green-bg);color:var(--green)}.notif-icon.amber{background:var(--amber-bg);color:var(--amber)}.notif-icon.red{background:var(--red-bg);color:var(--red)}.notif-icon.blue{background:var(--blue-50);color:var(--blue)}.notif-text{flex:1;min-width:0}.notif-text .nt-title{color:var(--ink);font-size:13px;font-weight:600;line-height:1.3}.notif-text .nt-desc{color:var(--ink-3);margin-top:2px;font-size:12px}.notif-text .nt-time{color:var(--ink-4);margin-top:4px;font-size:11px}.notif-foot{text-align:center;padding:10px 16px}.notif-foot a{color:var(--blue);font-size:12px;font-weight:500;text-decoration:none}.content{padding:24px 28px}.content-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:18px;display:flex}.content-head .hello{color:var(--ink-3);font-size:13px}.content-head .hello b{color:var(--ink);font-weight:600}.filter-bar{gap:8px;display:flex}.filter-chip{border:1px solid var(--border);height:34px;color:var(--ink-2);cursor:pointer;background:#fff;border-radius:8px;align-items:center;gap:6px;padding:0 14px;font-family:inherit;font-size:12.5px;font-weight:500;transition:background .12s,border-color .12s;display:flex}.filter-chip:hover{border-color:var(--border-strong)}.filter-chip.primary{background:var(--blue);color:#fff;border-color:var(--blue)}.filter-chip.primary:hover{background:var(--blue-600)}.filter-chip svg{width:15px;height:15px}.kpi-row{grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:22px;display:grid}.kpi-card{border:1px solid var(--border);box-shadow:var(--shadow);cursor:pointer;background:#fff;border-radius:10px;padding:18px;transition:transform .15s,box-shadow .15s,border-color .15s;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-2px)}.kpi-card .kpi-top{justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex}.kpi-label{color:var(--ink-3);font-size:12.5px;font-weight:500}.kpi-icon{border-radius:9px;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.kpi-icon svg{width:20px;height:20px}.kpi-icon.blue{background:var(--blue-50);color:var(--blue)}.kpi-icon.orange{color:var(--orange);background:rgba(232,75,42,.1)}.kpi-icon.green{background:var(--green-bg);color:var(--green)}.kpi-icon.purple{background:var(--purple-bg);color:var(--purple)}.kpi-value{color:var(--ink);letter-spacing:-.02em;font-size:26px;font-weight:700;line-height:1.1}.kpi-trend{color:var(--ink-3);align-items:center;gap:6px;margin-top:8px;font-size:12px;display:flex}.kpi-trend .tag{background:var(--green-bg);color:var(--green);border-radius:5px;align-items:center;gap:2px;padding:2px 7px;font-size:11.5px;font-weight:600;display:inline-flex}.kpi-trend .tag svg{width:13px;height:13px}.row-2{gap:18px;margin-bottom:22px;display:grid}.row-2.r2-60{grid-template-columns:6fr 4fr}.row-2.r2-55{grid-template-columns:55fr 45fr}.card{border:1px solid var(--border);box-shadow:var(--shadow);background:#fff;border-radius:10px;flex-direction:column;display:flex;overflow:hidden}.card-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.card-head .title{color:var(--ink);font-size:14.5px;font-weight:700}.card-head .subtitle{color:var(--ink-3);margin-top:2px;font-size:12px}.card-head .actions{gap:6px;display:flex}.small-btn{border:1px solid var(--border);height:30px;color:var(--ink-2);cursor:pointer;background:#fff;border-radius:6px;align-items:center;gap:5px;padding:0 10px;font-family:inherit;font-size:12px;font-weight:500;transition:background .12s,border-color .12s;display:inline-flex}.small-btn:hover{background:var(--page)}.small-btn svg{width:14px;height:14px}.small-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}.card-body{flex:1;padding:18px}.chart-legend{flex-wrap:wrap;gap:14px;margin-bottom:14px;display:flex}.legend-item{color:var(--ink-2);align-items:center;gap:7px;font-size:12px;font-weight:500;display:flex}.legend-swatch{border-radius:3px;width:11px;height:11px}.chart{grid-template-columns:36px 1fr;gap:10px;height:260px;display:grid}.chart-yaxis{color:var(--ink-4);text-align:right;flex-direction:column;justify-content:space-between;padding-top:4px;padding-bottom:26px;font-size:10.5px;display:flex}.chart-plot{border-left:1px solid var(--border);border-bottom:1px solid var(--border);padding:4px 4px 0;position:relative}.chart-gridlines{pointer-events:none;flex-direction:column;justify-content:space-between;display:flex;position:absolute;top:0;bottom:26px;left:0;right:0}.chart-gridlines div{border-top:1px dashed #eef2f7;height:1px}.chart-bars{justify-content:space-around;align-items:flex-end;gap:16px;display:flex;position:absolute;top:4px;bottom:26px;left:4px;right:4px}.bar-group{flex:1;justify-content:center;align-items:flex-end;gap:4px;height:100%;display:flex;position:relative}.bar-group:hover .bar-tooltip{opacity:1;transform:translate(-50%,-8px)}.bar{border-radius:3px 3px 0 0;width:14px;transition:height .9s cubic-bezier(.2,.8,.2,1)}.bar.b-training{background:var(--blue)}.bar.b-audit{background:var(--orange)}.bar.b-consultancy{background:var(--teal)}.bar:hover{-webkit-filter:brightness(1.1);filter:brightness(1.1)}.bar-tooltip{background:var(--ink);color:#fff;white-space:nowrap;opacity:0;pointer-events:none;z-index:5;border-radius:6px;min-width:140px;padding:6px 9px;font-size:11px;transition:opacity .15s,transform .15s;position:absolute;bottom:100%;left:50%;transform:translate(-50%);box-shadow:0 4px 12px rgba(0,0,0,.15)}.bar-tooltip:after{content:"";border:4px solid transparent;border-top-color:var(--ink);position:absolute;top:100%;left:50%;transform:translate(-50%)}.bar-tooltip .tt-title{margin-bottom:4px;font-weight:700}.bar-tooltip .tt-row{align-items:center;gap:6px;line-height:1.5;display:flex}.bar-tooltip .tt-row .sw{border-radius:2px;flex-shrink:0;width:8px;height:8px}.bar-tooltip .tt-row .name{text-transform:capitalize;flex:1}.bar-tooltip .tt-row .val{font-weight:600}.chart-xaxis{height:22px;color:var(--ink-3);justify-content:space-around;align-items:center;gap:16px;font-size:11px;font-weight:500;display:flex;position:absolute;bottom:0;left:4px;right:4px}.chart-xaxis div{text-align:center;flex:1}table.intakes{border-collapse:collapse;width:100%}.intakes th,.intakes td{text-align:left;border-bottom:1px solid #f1f5f9;padding:11px 14px;font-size:12.5px}.intakes th{color:var(--ink-3);letter-spacing:.04em;text-transform:uppercase;border-bottom:1px solid var(--border);background:#f8fafc;font-size:11px;font-weight:600}.intakes tbody tr{cursor:pointer;transition:background .1s}.intakes tbody tr:hover{background:#f8fafc}.intakes tbody tr:last-child td{border-bottom:none}.intakes .course-name{color:var(--ink);font-weight:600}.intakes .cohort{color:var(--ink-3);font-family:JetBrains Mono,ui-monospace,monospace;font-size:11.5px}.status-pill{border-radius:6px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.status-pill.open{background:var(--green-bg);color:#166534}.status-pill.full{background:var(--red-bg);color:#991b1b}.status-pill.filling{background:var(--amber-bg);color:#92400e}.mode-tag{color:var(--ink-3);font-size:11.5px}.enroll-list{flex-direction:column;display:flex}.enroll-item{border-bottom:1px solid #f1f5f9;grid-template-columns:36px 1fr auto auto;align-items:center;gap:12px;padding:12px 18px;transition:background .12s;display:grid}.enroll-item:last-child{border-bottom:none}.enroll-item:hover{background:var(--page)}.enroll-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:12px;font-weight:600;display:flex}.enroll-info .name{color:var(--ink);font-size:13px;font-weight:600;line-height:1.2}.enroll-info .course{color:var(--ink-3);margin-top:2px;font-size:11.5px;line-height:1.3}.enroll-date{color:var(--ink-3);white-space:nowrap;font-size:11.5px}.pay-pill{border-radius:6px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.pay-pill.paid{background:var(--green-bg);color:#166534}.pay-pill.pending{background:var(--amber-bg);color:#92400e}.pay-pill.overdue{background:var(--red-bg);color:#991b1b}.cert-list{padding:6px}.cert-item{background:#fef2f2;border:1px solid #fee2e2;border-radius:8px;align-items:center;gap:12px;margin-bottom:6px;padding:12px;transition:background .12s;display:flex}.cert-item.warn{background:#fffbeb;border-color:#fef3c7}.cert-icon{background:#fff;border:1px solid rgba(220,38,38,.18);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex}.cert-item.warn .cert-icon{border-color:rgba(217,119,6,.2)}.cert-icon svg{width:18px;height:18px;color:var(--red)}.cert-item.warn .cert-icon svg{color:var(--amber)}.cert-info{flex:1;min-width:0}.cert-info .learner{color:var(--ink);font-size:13px;font-weight:600;line-height:1.2}.cert-info .cert-name{color:var(--ink-2);margin-top:2px;font-size:11.5px;line-height:1.3}.cert-info .expiry{color:var(--red);align-items:center;gap:4px;margin-top:4px;font-size:11px;font-weight:600;display:flex}.cert-item.warn .cert-info .expiry{color:var(--amber)}.cert-info .expiry svg{width:13px;height:13px}.remind-btn{border:1px solid var(--border);color:var(--ink);cursor:pointer;white-space:nowrap;background:#fff;border-radius:6px;align-items:center;gap:4px;padding:6px 10px;font-family:inherit;font-size:11.5px;font-weight:600;transition:all .12s;display:inline-flex}.remind-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}.remind-btn svg{width:13px;height:13px}.cert-foot{text-align:center;padding:10px 16px 14px}.cert-foot a{color:var(--blue);font-size:12.5px;font-weight:500;text-decoration:none}.av-1{background:linear-gradient(135deg,#6366f1,#4338ca)}.av-2{background:linear-gradient(135deg,#10b981,#047857)}.av-3{background:linear-gradient(135deg,#f59e0b,#b45309)}.av-4{background:linear-gradient(135deg,#ec4899,#be185d)}.av-5{background:linear-gradient(135deg,#06b6d4,#0e7490)}.av-6{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}*{box-sizing:border-box;touch-action:manipulation;margin:0;padding:0}html,body{min-width:100%;height:100%;min-height:100vh;min-height:100dvh;margin:0;padding:0}#root{height:100%;min-height:100vh}:root{--font-primary:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica Neue", "Noto Sans", sans-serif}html,body{font-family:var(--font-primary)}
