:root{--brand-navy:#0E2A3F;--brand-navy-700:#163952;--brand-navy-500:#2C5577;--brand-blue:#1E7BFF;--brand-green:#1FB68A;--brand-gradient:linear-gradient(135deg,#1E7BFF,#1FB68A);--bg:#F4F1E9;--surface-1:#FBF8F1;--surface-2:#FFFFFF;--surface-3:#EFEBE0;--surface-inverse:#0E2A3F;--border-subtle:#E6E0D2;--border-default:#D8D1BF;--border-strong:#B5AC95;--border-focus:#0E2A3F;--text-primary:#0E2A3F;--text-secondary:#4E5C6B;--text-tertiary:#7A8693;--text-disabled:#B0B6BD;--text-inverse:#FBF8F1;--text-link:#1257B8;--success:#1FB68A;--success-subtle:#DEF3EA;--success-text:#0A6B4F;--warning:#D89B2A;--warning-subtle:#F7EBD0;--warning-text:#7A5810;--danger:#C5462B;--danger-subtle:#F4DCD4;--danger-text:#7A2913;--info:#1E7BFF;--info-subtle:#DCE9FB;--info-text:#0E3D85;--sev-critical:#9A1B1B;--sev-high:#C5462B;--sev-medium:#D89B2A;--sev-low:#7A8693;--s-1:4px;--s-2:8px;--s-3:12px;--s-4:16px;--s-5:20px;--s-6:24px;--s-7:32px;--s-8:40px;--s-9:48px;--s-10:64px;--s-11:80px;--s-12:96px;--r-1:4px;--r-2:6px;--r-3:8px;--r-4:10px;--r-5:14px;--r-pill:999px;--font-display:"Instrument Serif","Times New Roman",serif;--font-sans:"Inter Tight","Helvetica Neue",Helvetica,Arial,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;--t-display:44px;--t-h1:28px;--t-h2:22px;--t-h3:17px;--t-h4:15px;--t-body-lg:16px;--t-body:14px;--t-body-sm:13px;--t-label:12px;--t-caption:12px;--t-overline:11px;--t-mono:12.5px;--shadow-overlay:0 12px 32px -8px rgba(14,42,63,0.18),0 4px 8px -2px rgba(14,42,63,0.08);--shadow-pop:0 6px 18px -6px rgba(14,42,63,0.14);--ease-out:cubic-bezier(0.2,0.7,0.2,1);--dur-fast:120ms;--dur-mid:200ms}*,:after,:before{box-sizing:border-box}body{font-family:var(--font-sans);font-size:var(--t-body);line-height:1.5;-moz-osx-font-smoothing:grayscale}button{font-family:inherit}a{color:var(--text-link)}a:hover{text-decoration:underline;text-underline-offset:2px}::selection{background:var(--brand-navy);color:var(--text-inverse)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:var(--r-pill);border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}[data-theme=light]{--bg:#F4F5F7;--surface-1:#FAFBFC;--surface-2:#FFFFFF;--surface-3:#ECEEF1;--border-subtle:#E4E7EC;--border-default:#D5D9DF;--border-strong:#ADB3BC}[data-theme=dark]{--bg:#0B2335;--surface-1:#0E2A3F;--surface-2:#163952;--surface-3:#1F4A66;--surface-inverse:#F5F1E8;--border-subtle:#1F4A66;--border-default:#2C5577;--border-strong:#3D6F95;--border-focus:#1FB68A;--text-primary:#F5F1E8;--text-secondary:#C2D2DD;--text-tertiary:#7A98AE;--text-disabled:#4E6B83;--text-inverse:#0E2A3F;--text-link:#6FB1FF;--brand-navy:#1FB68A;--brand-navy-700:#1AA079;--brand-navy-500:#2C5577;--success-subtle:#143E33;--success-text:#6FE5BC;--warning-subtle:#3D2F12;--warning-text:#F0C173;--danger-subtle:#3D1A12;--danger-text:#F2A48F;--info-subtle:#142F5C;--info-text:#8CBAF7}[data-density=compact] table.data tbody td,[data-density=compact] table.data thead th{padding:8px 14px}[data-density=compact] .nav-item{padding:5px 10px}[data-density=compact] .card{padding:14px}[data-density=compact] .card__head{padding:10px 14px}[data-density=compact] .card__body{padding:12px}[data-density=compact] .stat{padding:14px 14px 12px;gap:8px}[data-density=compact] .content{padding:20px 24px 64px}[data-motion=reduced] *,[data-motion=reduced] :after,[data-motion=reduced] :before{animation-duration:1ms!important;transition-duration:1ms!important}.display{font-family:var(--font-display);font-size:var(--t-display);line-height:1.02;font-weight:400;letter-spacing:-.01em}.h1{font-size:var(--t-h1);line-height:1.18;letter-spacing:-.015em}.h1,.h2{font-weight:600}.h2{font-size:var(--t-h2);line-height:1.25;letter-spacing:-.012em}.h3{font-size:var(--t-h3);line-height:1.35;letter-spacing:-.005em}.h3,.h4{font-weight:600}.h4{font-size:var(--t-h4);line-height:1.4}.body-lg{font-size:var(--t-body-lg);line-height:1.55}.body{font-size:var(--t-body);line-height:1.5}.body-sm{font-size:var(--t-body-sm);line-height:1.45}.label{font-size:var(--t-label);line-height:1.3;font-weight:500}.caption{font-size:var(--t-caption)}.caption,.overline{color:var(--text-tertiary)}.overline{font-size:var(--t-overline);letter-spacing:.12em;text-transform:uppercase;font-weight:500}.mono,.overline{font-family:var(--font-mono)}.mono{font-size:var(--t-mono)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-primary{color:var(--text-primary)}.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}.sidebar{background:var(--surface-1);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar__brand{padding:18px 14px 16px 18px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:10px;min-width:0}.sidebar__brand-mark{width:30px;height:30px;background-image:none;background-size:contain;background-position:50%;background-repeat:no-repeat;flex-shrink:0}.sidebar__brand-text{display:flex;flex-direction:column;line-height:1.1;min-width:0;flex:1 1;overflow:hidden}.sidebar__brand-product{font-size:15px;font-weight:600;color:var(--text-primary);letter-spacing:-.01em}.sidebar__brand-product,.sidebar__brand-suite{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar__brand-suite{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-tertiary);margin-top:3px}.sidebar__switcher{flex-shrink:0;width:28px;height:28px;display:grid;place-items:center;color:var(--text-tertiary);border-radius:var(--r-2);border:1px solid transparent;background:transparent;cursor:pointer;padding:0;transition:all var(--dur-fast) var(--ease-out)}.sidebar__switcher:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--border-subtle)}.sidebar__switcher svg{transition:transform var(--dur-mid) var(--ease-out)}.app.is-collapsed{grid-template-columns:68px 1fr}.app.is-collapsed .sidebar__brand{padding:18px 10px 16px;justify-content:center}.app.is-collapsed .sidebar__brand-text{display:none}.app.is-collapsed .sidebar__switcher{position:absolute;top:22px;right:-14px;background:var(--surface-1);border:1px solid var(--border-subtle);width:24px;height:24px;z-index:11;box-shadow:0 2px 6px -2px rgba(14,42,63,.12)}.app.is-collapsed .sidebar__switcher:hover{background:var(--surface-2)}.app.is-collapsed .sidebar__switcher svg{transform:rotate(180deg)}.app.is-collapsed .sidebar__nav{padding:14px 8px 12px}.app.is-collapsed .sidebar__group+.sidebar__group{padding-top:10px;margin-top:6px}.app.is-collapsed .sidebar__group-label{padding:0 4px 6px;justify-content:center}.app.is-collapsed .sidebar__group-label>span:first-child{font-size:0}.app.is-collapsed .sidebar__group-label>span:first-child:before{content:"";display:block;width:18px;height:1px;background:var(--border-default);margin:0 auto}.app.is-collapsed .sidebar__group-label .count{display:none}.app.is-collapsed .nav-item{padding:9px 0;justify-content:center;position:relative}.app.is-collapsed .nav-item__label{display:none}.app.is-collapsed .nav-item__badge{position:absolute;top:2px;right:6px;font-size:8.5px;padding:0 4px;min-width:14px;background:var(--brand-navy);color:var(--text-inverse)}.app.is-collapsed .sidebar__footer{padding:12px 8px;justify-content:center}.app.is-collapsed .sidebar__footer>.icon-btn,.app.is-collapsed .sidebar__footer>div{display:none}.app.is-collapsed .sidebar__footer .avatar{margin:0}.app.is-collapsed .nav-item:after{content:attr(data-label);position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);background:var(--brand-navy);color:var(--text-inverse);font-size:12px;font-weight:500;padding:5px 10px;border-radius:var(--r-2);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--dur-fast) var(--ease-out);z-index:20;box-shadow:var(--shadow-pop)}.app.is-collapsed .nav-item:hover:after{opacity:1}.sidebar{position:relative}.sidebar__nav{flex:1 1;overflow-y:auto;padding:14px 10px 12px}.sidebar__group{padding:10px 0}.sidebar__group+.sidebar__group{border-top:1px solid var(--border-subtle);margin-top:4px;padding-top:14px}.sidebar__group-label{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-tertiary);padding:0 10px 8px;display:flex;align-items:center;justify-content:space-between}.sidebar__group-label .count{font-size:10px;color:var(--text-tertiary);background:var(--surface-3);padding:1px 6px;border-radius:var(--r-pill)}.nav-item{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--r-2);color:var(--text-secondary);font-size:13.5px;cursor:pointer;position:relative;border-left:2px solid transparent;margin-left:-2px;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out)}.nav-item:hover{background:var(--surface-3);color:var(--text-primary)}.nav-item__icon{width:16px;height:16px;flex-shrink:0;color:currentColor}.nav-item__label{flex:1 1;min-width:0}.nav-item__badge{font-family:var(--font-mono);font-size:10px;background:var(--surface-3);color:var(--text-secondary);padding:1px 6px;border-radius:var(--r-pill)}.nav-item.is-active{background:var(--surface-2);color:var(--text-primary);font-weight:500;border-left-color:var(--brand-navy)}.nav-item.is-active .nav-item__icon{color:var(--brand-navy)}.sidebar__footer{border-top:1px solid var(--border-subtle);padding:12px;display:flex;align-items:center;gap:10px}.role-chip{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-secondary)}.role-chip__dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--brand-green);margin-right:6px;vertical-align:1px}.topbar{gap:12px;height:56px;padding:0 24px;background:var(--bg);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:10}.topbar,.topbar__crumbs{display:flex;align-items:center}.topbar__crumbs{gap:6px;font-size:13px}.topbar__crumbs,.topbar__crumbs a{color:var(--text-tertiary)}.topbar__crumbs a:hover{color:var(--text-primary);text-decoration:none}.topbar__crumbs .sep{color:var(--border-strong)}.topbar__crumbs .current{color:var(--text-primary);font-weight:500}.topbar__actions{margin-left:auto;display:flex;align-items:center;gap:4px}.topbar__divider{width:1px;height:22px;background:var(--border-subtle);margin:0 6px}.icon-btn{width:32px;height:32px;display:grid;place-items:center;background:transparent;border:1px solid transparent;border-radius:var(--r-2);color:var(--text-secondary);cursor:pointer;position:relative;transition:all var(--dur-fast) var(--ease-out)}.icon-btn:hover{background:var(--surface-3);color:var(--text-primary);border-color:var(--border-subtle)}.icon-btn .dot{position:absolute;top:6px;right:7px;width:7px;height:7px;border-radius:50%;background:var(--brand-blue);border:1.5px solid var(--bg)}.avatar{width:28px;height:28px;border-radius:50%;background:var(--brand-navy);color:var(--text-inverse);display:grid;place-items:center;font-size:11px;font-weight:600;letter-spacing:.04em}.avatar.lg{width:36px;height:36px;font-size:13px}.avatar.sm{width:22px;height:22px;font-size:9.5px}.user-pill{display:flex;align-items:center;gap:8px;padding:4px 10px 4px 4px;border-radius:var(--r-pill);border:1px solid transparent;cursor:pointer}.user-pill:hover{background:var(--surface-1);border-color:var(--border-subtle)}.user-pill__name{font-size:13px;font-weight:500}.user-pill__caret{color:var(--text-tertiary)}.content{padding:28px 32px 80px;max-width:1280px}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:28px;padding-bottom:22px;border-bottom:1px solid var(--border-subtle)}.page-head__title{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}.page-head__subtitle{font-size:13.5px;color:var(--text-secondary);margin-top:8px;max-width:56ch}.page-head__actions{display:flex;gap:8px;align-items:center}.btn{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 14px;border-radius:var(--r-2);font-size:13.5px;font-weight:500;border:1px solid transparent;cursor:pointer;background:transparent;color:var(--text-primary);transition:all var(--dur-fast) var(--ease-out);white-space:nowrap}.btn:focus-visible{outline:2px solid var(--border-focus);outline-offset:2px}.btn .icon{width:14px;height:14px}.btn--primary{background:var(--brand-navy);color:var(--text-inverse);border-color:var(--brand-navy)}.btn--primary:hover{background:#1A3A52;border-color:#1A3A52}.btn--primary:active{background:#08202F}.btn--primary:disabled{background:var(--text-disabled);border-color:var(--text-disabled);cursor:not-allowed}.btn--secondary{background:var(--surface-2);color:var(--text-primary);border-color:var(--border-default)}.btn--secondary:hover{background:var(--surface-1);border-color:var(--border-strong)}.btn--ghost{color:var(--text-secondary)}.btn--ghost:hover{background:var(--surface-3);color:var(--text-primary)}.btn--destructive{background:var(--surface-2);color:var(--danger-text);border-color:var(--border-default)}.btn--destructive:hover{background:var(--danger-subtle);border-color:var(--danger);color:var(--danger-text)}.btn--sm{height:28px;padding:0 10px;font-size:12.5px;border-radius:var(--r-1)}.btn--lg{height:40px;padding:0 18px;font-size:14px}.btn-group{display:inline-flex;border:1px solid var(--border-default);border-radius:var(--r-2);background:var(--surface-2);overflow:hidden}.btn-group .btn{border-radius:0;border:none;height:32px;border-right:1px solid var(--border-subtle)}.btn-group .btn:last-child{border-right:none}.btn-group .btn.is-active{background:var(--surface-3);color:var(--text-primary);font-weight:500}.field{display:flex;flex-direction:column;gap:6px}.field__label{font-size:12.5px;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:6px}.field__label .req{color:var(--danger)}.field__helper{font-size:12px;color:var(--text-tertiary)}.field__error{font-size:12px;color:var(--danger-text);display:flex;gap:4px;align-items:center}.input,.select,.textarea{width:100%;height:36px;padding:0 12px;font-family:inherit;font-size:13.5px;color:var(--text-primary);background:var(--surface-2);border:1px solid var(--border-default);border-radius:var(--r-2);transition:border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out)}.input::placeholder,.textarea::placeholder{color:var(--text-tertiary)}.input:hover,.select:hover,.textarea:hover{border-color:var(--border-strong)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--brand-navy);box-shadow:0 0 0 3px rgba(14,42,63,.12)}.input.is-error{border-color:var(--danger)}.input.is-error:focus{box-shadow:0 0 0 3px rgba(197,70,43,.18)}.input:disabled,.textarea:disabled{background:var(--surface-3);color:var(--text-disabled);cursor:not-allowed}.textarea{height:auto;padding:10px 12px;min-height:80px;resize:vertical;line-height:1.5}.select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M3 4.5L6 7.5L9 4.5' stroke='%237A8693' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.input-group{position:relative}.input-group .input{padding-left:34px}.input-group__icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:14px;height:14px;color:var(--text-tertiary);pointer-events:none}.checkbox{appearance:none;width:16px;height:16px;border:1.5px solid var(--border-strong);border-radius:var(--r-1);background:var(--surface-2);cursor:pointer;display:inline-grid;place-content:center;position:relative;flex-shrink:0}.checkbox:checked,.checkbox:hover{border-color:var(--brand-navy)}.checkbox:checked{background:var(--brand-navy)}.checkbox:checked:after{content:"";width:9px;height:5px;border-left:1.75px solid var(--text-inverse);border-bottom:1.75px solid var(--text-inverse);transform:rotate(-45deg) translate(1px,-1px)}.checkbox:indeterminate{background:var(--brand-navy);border-color:var(--brand-navy)}.checkbox:indeterminate:after{content:"";width:8px;height:1.75px;background:var(--text-inverse)}.radio{appearance:none;width:16px;height:16px;border:1.5px solid var(--border-strong);border-radius:50%;background:var(--surface-2);cursor:pointer;display:inline-grid;place-content:center;flex-shrink:0}.radio:checked{border-color:var(--brand-navy);border-width:5px}.toggle{appearance:none;width:32px;height:18px;background:var(--border-strong);border-radius:var(--r-pill);position:relative;cursor:pointer;transition:background var(--dur-fast) var(--ease-out)}.toggle:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform var(--dur-fast) var(--ease-out);box-shadow:0 1px 2px rgba(0,0,0,.18)}.toggle:checked{background:var(--brand-navy)}.toggle:checked:after{transform:translateX(14px)}.choice-row{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--r-2);cursor:pointer}.choice-row:hover{background:var(--surface-3)}.choice-row__text{display:flex;flex-direction:column;gap:2px}.choice-row__title{font-size:13.5px;font-weight:500}.choice-row__sub{font-size:12.5px;color:var(--text-tertiary)}.dropzone{border:1.5px dashed var(--border-default);border-radius:var(--r-3);padding:28px;text-align:center;background:var(--surface-1);cursor:pointer;transition:all var(--dur-fast) var(--ease-out)}.dropzone:hover{border-color:var(--brand-navy);background:var(--surface-2)}.dropzone__icon{width:36px;height:36px;margin:0 auto 10px;border-radius:50%;background:var(--surface-3);display:grid;place-items:center;color:var(--text-secondary)}.table-shell{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--r-3);overflow:hidden}.table-toolbar{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--border-subtle)}.table-toolbar__search{flex:0 0 280px;max-width:320px}.table-toolbar__spacer{flex:1 1}.table-toolbar__count{font-size:12.5px;color:var(--text-tertiary)}table.data{width:100%;border-collapse:collapse;font-size:13.5px}table.data thead th{text-align:left;font-size:11px;font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);font-weight:500;padding:10px 14px;background:var(--surface-3);border-bottom:1px solid var(--border-subtle);white-space:nowrap;-webkit-user-select:none;user-select:none}table.data thead th.sortable{cursor:pointer}table.data thead th .sort-i{display:inline-block;margin-left:4px;color:var(--text-tertiary);vertical-align:-1px}table.data thead th.sorted .sort-i{color:var(--text-primary)}table.data tbody tr{border-bottom:1px solid var(--border-subtle)}table.data tbody tr:last-child{border-bottom:0}table.data tbody td{padding:12px 14px;vertical-align:middle;color:var(--text-primary)}table.data tbody tr:hover{background:var(--surface-1)}table.data tbody tr.is-selected{background:rgba(30,123,255,.06)}table.data .col-check{width:36px;padding-right:0}table.data .col-actions{width:1%;white-space:nowrap;text-align:right}table.data .row-actions{display:flex;gap:2px;justify-content:flex-end;opacity:0;transition:opacity var(--dur-fast) var(--ease-out)}table.data tbody tr:hover .row-actions{opacity:1}.cell-user{display:flex;align-items:center;gap:10px}.cell-user__name{font-weight:500}.cell-user__email{font-size:12px;color:var(--text-tertiary)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid var(--border-subtle);font-size:12.5px;color:var(--text-secondary)}.pagination__pages{display:flex;gap:2px}.page-btn{min-width:28px;height:28px;padding:0 8px;display:inline-grid;place-items:center;border-radius:var(--r-1);font-size:12.5px;font-family:var(--font-mono);color:var(--text-secondary);cursor:pointer;border:1px solid transparent;background:transparent}.page-btn:hover{background:var(--surface-3);color:var(--text-primary)}.page-btn.is-active{background:var(--brand-navy);color:var(--text-inverse)}.skel{display:inline-block;background:linear-gradient(90deg,var(--surface-3) 0,var(--border-subtle) 50%,var(--surface-3) 100%);background-size:200% 100%;animation:skel 1.4s linear infinite;border-radius:var(--r-1);height:12px;width:100%}@keyframes skel{0%{background-position:200% 0}to{background-position:-200% 0}}.badge{display:inline-flex;align-items:center;gap:5px;height:22px;padding:0 8px;border-radius:var(--r-pill);font-size:11.5px;font-weight:500;white-space:nowrap;border:1px solid transparent}.badge .dot{width:6px;height:6px;border-radius:50%}.badge--neutral{background:var(--surface-3);color:var(--text-secondary)}.badge--neutral .dot{background:var(--text-tertiary)}.badge--success{background:var(--success-subtle);color:var(--success-text)}.badge--success .dot{background:var(--success)}.badge--warning{background:var(--warning-subtle);color:var(--warning-text)}.badge--warning .dot{background:var(--warning)}.badge--danger{background:var(--danger-subtle);color:var(--danger-text)}.badge--danger .dot{background:var(--danger)}.badge--info{background:var(--info-subtle);color:var(--info-text)}.badge--info .dot{background:var(--info)}.badge--outline{background:transparent;border-color:var(--border-default);color:var(--text-secondary)}.role-badge{display:inline-flex;align-items:center;gap:5px;height:22px;padding:0 8px 0 7px;border-radius:var(--r-2);font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;font-weight:500;background:var(--surface-3);color:var(--text-secondary);border:1px solid var(--border-subtle)}.role-badge .pip{width:5px;height:5px;border-radius:1px;background:var(--text-tertiary)}.role-badge--super{background:#1A3A52;color:#F5F1E8;border-color:#1A3A52}.role-badge--super .pip{background:var(--brand-green);border-radius:50%}.role-badge--school{background:#DCE9FB;color:#0E3D85;border-color:#C6DBF7}.role-badge--school .pip{background:var(--brand-blue)}.role-badge--module{background:#DEF3EA;color:#0A6B4F;border-color:#C9EBDC}.role-badge--module .pip{background:var(--brand-green)}.role-badge--teacher{background:var(--surface-3);color:var(--text-secondary);border-color:var(--border-subtle)}.sev{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:500}.sev__bar{width:3px;height:14px;border-radius:1.5px}.sev--critical .sev__bar{background:var(--sev-critical)}.sev--high .sev__bar{background:var(--sev-high)}.sev--medium .sev__bar{background:var(--sev-medium)}.sev--low .sev__bar{background:var(--sev-low)}.sev--critical{color:var(--sev-critical)}.sev--high{color:var(--sev-high)}.sev--medium{color:var(--warning-text)}.sev--low{color:var(--text-secondary)}.progress{height:6px;background:var(--surface-3);border-radius:var(--r-pill);overflow:hidden}.progress__bar{height:100%;background:var(--brand-navy);border-radius:inherit}.progress--success .progress__bar{background:var(--brand-green)}.progress--warning .progress__bar{background:var(--warning)}.card{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--r-3);padding:18px}.card--flush{padding:0;overflow:hidden}.card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border-subtle)}.card__title{font-size:14.5px;font-weight:600}.card__body{padding:16px}.card__foot{padding:12px 16px;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end;gap:8px}.stat{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--r-3);padding:18px 18px 16px;display:flex;flex-direction:column;gap:12px;position:relative}.stat__label{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-tertiary)}.stat__value{font-family:var(--font-display);font-size:40px;line-height:1;font-weight:400;color:var(--text-primary);display:flex;align-items:baseline;gap:6px}.stat__value sub{font-family:var(--font-sans);font-size:13px;font-weight:500;color:var(--text-tertiary);vertical-align:baseline}.stat__delta{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500}.stat__delta--up{color:var(--success-text)}.stat__delta--down{color:var(--danger-text)}.stat__delta--flat{color:var(--text-tertiary)}.callout{display:flex;gap:12px;padding:12px 14px;border-radius:var(--r-3);border:1px solid;font-size:13px}.callout__icon{width:18px;height:18px;flex-shrink:0;margin-top:1px}.callout__title{font-weight:600;margin-bottom:2px}.callout--info{background:var(--info-subtle);border-color:#C6DBF7;color:var(--info-text)}.callout--success{background:var(--success-subtle);border-color:#C9EBDC;color:var(--success-text)}.callout--warning{background:var(--warning-subtle);border-color:#ECDBA8;color:var(--warning-text)}.callout--danger{background:var(--danger-subtle);border-color:#ECC4B7;color:var(--danger-text)}.banner{display:flex;align-items:center;gap:10px;padding:8px 16px;background:#1A3A52;color:#F5F1E8;font-size:13px;border-bottom:1px solid #08202f}.banner__dot{width:6px;height:6px;border-radius:50%;background:var(--warning);flex-shrink:0}.banner__action{margin-left:auto;display:flex;gap:8px}.banner a{color:#F5F1E8;text-decoration:underline;text-underline-offset:2px}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border-subtle);margin-bottom:20px}.tab{padding:10px 14px;font-size:13.5px;color:var(--text-secondary);border-bottom:2px solid transparent;cursor:pointer;margin-bottom:-1px;display:inline-flex;align-items:center;gap:6px}.tab.is-active,.tab:hover{color:var(--text-primary)}.tab.is-active{border-bottom-color:var(--brand-navy);font-weight:500}.tab__count{font-family:var(--font-mono);font-size:10.5px;padding:1px 6px;border-radius:var(--r-pill);background:var(--surface-3);color:var(--text-tertiary)}.chip{display:inline-flex;align-items:center;gap:5px;height:26px;padding:0 8px 0 10px;background:var(--surface-2);border:1px solid var(--border-default);border-radius:var(--r-pill);font-size:12.5px;color:var(--text-secondary);cursor:pointer}.chip:hover{background:var(--surface-1)}.chip.is-active{background:var(--brand-navy);color:var(--text-inverse);border-color:var(--brand-navy)}.chip__x{width:12px;height:12px;opacity:.6}.overlay{position:fixed;inset:0;background:rgba(14,42,63,.32);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:50;padding:24px}.modal{background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--r-4);width:100%;max-width:480px;box-shadow:var(--shadow-overlay);overflow:hidden}.modal__head{padding:18px 20px 14px;display:flex;align-items:flex-start;gap:14px}.modal__icon{width:36px;height:36px;display:grid;place-items:center;border-radius:var(--r-3);flex-shrink:0}.modal__icon--danger{background:var(--danger-subtle);color:var(--danger)}.modal__title{font-size:16px;font-weight:600;line-height:1.3}.modal__sub{font-size:13px;color:var(--text-secondary);margin-top:4px}.modal__body{padding:0 20px 4px}.modal__foot{padding:16px 20px 18px;display:flex;justify-content:flex-end;gap:8px}.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:92vw;background:var(--surface-2);border-left:1px solid var(--border-subtle);box-shadow:var(--shadow-overlay);display:flex;flex-direction:column}.drawer__head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border-subtle)}.drawer__body{padding:18px;flex:1 1;overflow-y:auto}.drawer__foot{padding:12px 18px;border-top:1px solid var(--border-subtle);display:flex;justify-content:flex-end;gap:8px}.menu{position:absolute;background:var(--surface-2);border:1px solid var(--border-subtle);border-radius:var(--r-3);box-shadow:var(--shadow-overlay);min-width:220px;padding:6px;z-index:100;opacity:0;pointer-events:none;transform:translateY(-4px);transition:opacity var(--dur-fast) var(--ease-out),transform var(--dur-fast) var(--ease-out)}.menu.is-open{opacity:1;pointer-events:auto;transform:translateY(0)}.menu__header{padding:10px 10px 12px;border-bottom:1px solid var(--border-subtle);margin:-6px -6px 6px;background:var(--surface-1);border-radius:var(--r-3) var(--r-3) 0 0;display:flex;align-items:center;gap:10px}.menu__header-name{font-size:13.5px;font-weight:600;line-height:1.2}.menu__header-email{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);margin-top:2px}.menu__group{padding:4px 0}.menu__group+.menu__group{border-top:1px solid var(--border-subtle);margin-top:4px;padding-top:6px}.menu__label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-tertiary);padding:6px 10px 4px}.menu__item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--r-2);font-size:13px;color:var(--text-primary);cursor:pointer;background:transparent;border:none;width:100%;text-align:left;font-family:inherit}.menu__item:hover{background:var(--surface-3)}.menu__item svg{width:14px;height:14px;color:var(--text-tertiary);flex-shrink:0}.menu__item:hover svg{color:var(--text-primary)}.menu__item .meta{margin-left:auto;font-family:var(--font-mono);font-size:10.5px;color:var(--text-tertiary)}.menu__item.is-danger{color:var(--danger-text)}.menu__item.is-danger:hover{background:var(--danger-subtle)}.menu__item.is-danger svg{color:var(--danger-text)}.menu__divider{height:1px;background:var(--border-subtle);margin:4px 0}.menu--top-right{transform-origin:top right}.menu--top-left{transform-origin:top left}.menu--bottom-right{transform-origin:bottom right;transform:translateY(4px)}.menu--bottom-right.is-open{transform:translateY(0)}.user-pill.is-open{background:var(--surface-1);border-color:var(--border-subtle)}.sidebar__footer.is-open{background:var(--surface-3)}.menu__item--expandable .menu__chev{margin-left:auto;color:var(--text-tertiary);transition:transform var(--dur-fast) var(--ease-out);display:inline-flex}.menu__item--expandable.is-expanded .menu__chev{transform:rotate(180deg)}.menu__item--expandable.is-expanded{background:var(--surface-3)}.menu__panel{padding:6px 4px 8px;display:none}.menu__panel.is-open{display:block}.theme-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:4px 6px 6px}.theme-sw{border:1px solid var(--border-subtle);background:transparent;border-radius:var(--r-2);padding:6px;cursor:pointer;display:flex;flex-direction:column;align-items:stretch;gap:6px;font-family:inherit;text-align:left;transition:border-color var(--dur-fast) var(--ease-out)}.theme-sw:hover{border-color:var(--border-default)}.theme-sw.is-active{border-color:var(--brand-navy);box-shadow:0 0 0 2px rgba(14,42,63,.1)}.theme-sw__preview{height:36px;border-radius:var(--r-1);border:1px solid var(--border-subtle);position:relative;overflow:hidden}.theme-sw__preview:after,.theme-sw__preview:before{content:"";position:absolute;left:5px;right:5px;height:2px;border-radius:1px}.theme-sw__preview:before{top:6px;width:60%}.theme-sw__preview:after{top:12px;width:40%}.theme-sw__preview-bar{position:absolute;left:5px;bottom:5px;right:5px;height:10px;border-radius:1px}.theme-sw[data-theme=sepia] .theme-sw__preview{background:#F4F1E9}.theme-sw[data-theme=sepia] .theme-sw__preview:before{background:#0E2A3F}.theme-sw[data-theme=sepia] .theme-sw__preview:after{background:#7A8693}.theme-sw[data-theme=sepia] .theme-sw__preview-bar{background:#FBF8F1;border:1px solid #e6e0d2}.theme-sw[data-theme=light] .theme-sw__preview{background:#F4F5F7}.theme-sw[data-theme=light] .theme-sw__preview:before{background:#0E2A3F}.theme-sw[data-theme=light] .theme-sw__preview:after{background:#7A8693}.theme-sw[data-theme=light] .theme-sw__preview-bar{background:#FFFFFF;border:1px solid #e4e7ec}.theme-sw[data-theme=dark] .theme-sw__preview{background:#0B2335}.theme-sw[data-theme=dark] .theme-sw__preview:before{background:#F5F1E8}.theme-sw[data-theme=dark] .theme-sw__preview:after{background:#7A98AE}.theme-sw[data-theme=dark] .theme-sw__preview-bar{background:#163952;border:1px solid #1f4a66}.theme-sw__label{font-size:11px;font-weight:500;color:var(--text-secondary);display:flex;align-items:center;justify-content:space-between}.theme-sw.is-active .theme-sw__label{color:var(--text-primary)}.theme-sw__check{width:12px;height:12px;border-radius:50%;background:var(--brand-navy);display:none;align-items:center;justify-content:center;color:var(--text-inverse)}.theme-sw.is-active .theme-sw__check{display:inline-flex}.theme-sw__check svg{width:8px;height:8px}.menu__seg{display:grid;grid-template-columns:1fr 1fr;background:var(--surface-3);border-radius:var(--r-2);padding:2px;margin:4px 6px 6px;gap:2px}.menu__seg button{background:transparent;border:none;padding:6px 8px;font-size:12px;font-weight:500;color:var(--text-secondary);border-radius:var(--r-1);cursor:pointer;font-family:inherit}.menu__seg button.is-active{background:var(--surface-2);color:var(--text-primary);box-shadow:0 1px 2px rgba(14,42,63,.06)}.menu__seg button:hover:not(.is-active){color:var(--text-primary)}.menu__toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:var(--r-2);font-size:13px;cursor:pointer;gap:10px}.menu__toggle-row:hover{background:var(--surface-3)}.menu__toggle-row svg{width:14px;height:14px;color:var(--text-tertiary);flex-shrink:0}.menu__toggle-row>span{flex:1 1}.toast-stack{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column-reverse;gap:8px;z-index:60}.toast{display:flex;align-items:flex-start;gap:10px;background:var(--brand-navy);color:var(--text-inverse);padding:12px 14px;border-radius:var(--r-3);min-width:280px;max-width:380px;box-shadow:var(--shadow-overlay);font-size:13px}.toast__icon{width:16px;height:16px;flex-shrink:0;margin-top:2px}.toast__body{flex:1 1}.toast__title{font-weight:600;margin-bottom:2px}.toast__close{background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer}.toast--success .toast__icon{color:var(--brand-green)}.toast--danger .toast__icon{color:#FF8A6F}.toast--warning .toast__icon{color:var(--warning)}.empty{text-align:center;padding:56px 24px;max-width:440px;margin:0 auto}.empty__art{width:96px;height:96px;margin:0 auto 18px;border-radius:50%;background:var(--surface-1);border:1px dashed var(--border-default);display:grid;place-items:center;color:var(--text-tertiary)}.empty__title{font-family:var(--font-display);font-size:26px;line-height:1.1}.empty__sub{font-size:13.5px;color:var(--text-secondary);margin:8px 0 18px;line-height:1.55}.searchbar{gap:8px;flex-wrap:wrap}.row,.searchbar{display:flex;align-items:center}.row{gap:var(--s-3)}.row.gap-2{gap:var(--s-2)}.row.gap-4{gap:var(--s-4)}.row.gap-6{gap:var(--s-6)}.col{display:flex;flex-direction:column;gap:var(--s-3)}.spacer{flex:1 1}.grid{display:grid;gap:var(--s-4)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-2{grid-template-columns:repeat(2,1fr)}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mt-8{margin-top:32px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mb-8{margin-bottom:32px}.hr{height:1px;background:var(--border-subtle);border:none;margin:16px 0}@media (max-width:900px){.app{grid-template-columns:1fr}.sidebar{display:none}.content{padding:16px}.grid-4{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr}}.nav-item:focus-visible{outline:2px solid var(--brand-green,#1e7bff);outline-offset:-2px;border-radius:6px}@import url("https://fonts.googleapis.com/css2?family=Inter+Tight:wght@400;500;600;700&family=Instrument+Serif:ital@0;1&family=JetBrains+Mono:wght@400;500&display=swap");*{box-sizing:border-box}body,html{margin:0;padding:0}body{background:var(--bg);color:var(--text-primary);font-family:var(--font-sans,"Inter Tight"),system-ui,sans-serif;font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}