:root{--accent: #1e3a5f;--accent-hover: #16304f;--accent-soft: rgba(30, 58, 95, .08);--accent-line: rgba(30, 58, 95, .18);--sidebar-bg: #15273f;--sidebar-bg-2: #11202f;--bg: #f4f4f2;--surface: #ffffff;--surface-2: #fafafa;--border: #e4e3df;--border-strong: #d3d2cd;--text: #1b1b18;--text-muted: #6d6d66;--text-faint: #97968e;--ok: #1f6f54;--ok-soft: rgba(31, 111, 84, .1);--warn: #a86a1e;--warn-soft: rgba(168, 106, 30, .12);--danger: #9a3030;--danger-soft: rgba(154, 48, 48, .1);--radius: 10px;--radius-sm: 7px;--shadow-sm: 0 1px 2px rgba(20, 25, 35, .05), 0 1px 1px rgba(20, 25, 35, .04);--shadow-md: 0 4px 16px rgba(20, 25, 35, .08), 0 1px 3px rgba(20, 25, 35, .06);--shadow-lg: 0 18px 48px rgba(15, 23, 40, .22);--pad: 28px;--row-h: 52px;--gap: 18px;--sans: "Public Sans", system-ui, -apple-system, "Segoe UI", sans-serif;--mono: "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace}[data-density=compacto]{--pad: 18px;--row-h: 42px;--gap: 12px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--sans);background:var(--bg);color:var(--text);font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}a{color:inherit;text-decoration:none}.mono{font-family:var(--mono);font-feature-settings:"tnum" 1}.wordmark{display:flex;align-items:center;gap:11px}.wordmark .mark{width:38px;height:38px;flex:0 0 38px;border-radius:9px;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:800;font-size:15px;letter-spacing:.5px;position:relative;overflow:hidden}.wordmark .mark:after{content:"";position:absolute;right:0;top:0;bottom:0;width:6px;background:#ffffff29}.wordmark .wm-text{line-height:1.1}.wordmark .wm-name{font-weight:800;font-size:16px;letter-spacing:-.2px}.wordmark .wm-sub{font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--text-faint);font-weight:600}.wordmark.on-dark .mark{background:#fff;color:var(--accent)}.wordmark.on-dark .wm-name{color:#fff}.wordmark.on-dark .wm-sub{color:#ffffff80}.login-wrap{display:grid;grid-template-columns:1.05fr 1fr;height:100%}.login-aside{background:linear-gradient(160deg,var(--sidebar-bg) 0%,var(--sidebar-bg-2) 100%);color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.login-aside:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:44px 44px;opacity:.6;-webkit-mask-image:radial-gradient(120% 100% at 80% 10%,#000,transparent 75%);mask-image:radial-gradient(120% 100% at 80% 10%,#000,transparent 75%)}.login-aside>*{position:relative;z-index:1}.login-aside .headline{font-size:32px;line-height:1.18;font-weight:800;letter-spacing:-.6px;max-width:13ch}.login-aside .lede{margin-top:16px;color:#ffffff9e;font-size:15px;max-width:36ch}.login-aside .pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:28px}.login-aside .pills span{font-size:12px;padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.18);color:#ffffffc7}.login-aside .foot{font-size:12px;color:#fff6}.login-main{display:grid;place-items:center;padding:40px;background:var(--surface)}.login-card{width:100%;max-width:380px}.login-card h1{font-size:23px;font-weight:800;letter-spacing:-.4px}.login-card .sub{color:var(--text-muted);margin-top:6px;font-size:14px}.login-form{margin-top:28px;display:flex;flex-direction:column;gap:16px}.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--text)}.field .ctrl{width:100%;height:44px;padding:0 13px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface);outline:none;transition:border-color .15s,box-shadow .15s}textarea.ctrl{height:auto;padding:10px 13px;resize:vertical;min-height:64px;line-height:1.4}.field .ctrl:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.field.invalid .ctrl{border-color:var(--danger)}.field .pw{position:relative}.field .pw .toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:0;color:var(--text-faint);font-size:12px;font-weight:600;padding:6px 8px;border-radius:6px}.field .pw .toggle:hover{color:var(--accent);background:var(--accent-soft)}.login-error{font-size:13px;color:var(--danger);background:var(--danger-soft);border:1px solid rgba(154,48,48,.2);padding:9px 12px;border-radius:var(--radius-sm);display:flex;align-items:center;gap:8px}.btn{height:44px;border:1px solid transparent;border-radius:var(--radius-sm);font-weight:600;font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 18px;transition:background .15s,border-color .15s,color .15s,transform .05s}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-ghost{background:transparent;border-color:var(--border-strong);color:var(--text)}.btn-ghost:hover{background:var(--surface-2);border-color:var(--text-faint)}.btn-subtle{background:var(--accent-soft);color:var(--accent)}.btn-subtle:hover{background:var(--accent-line)}.btn-danger{background:transparent;border-color:#9a30304d;color:var(--danger)}.btn-danger:hover{background:var(--danger-soft)}.btn-block{width:100%}.btn-sm{height:36px;font-size:13px;padding:0 13px}.btn:disabled{opacity:.55;cursor:not-allowed}.demo-block{margin-top:26px;border-top:1px solid var(--border);padding-top:18px}.demo-block .dl{font-size:12px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--text-faint);margin-bottom:10px}.demo-grid{display:grid;gap:8px}.demo-acc{display:flex;align-items:center;gap:11px;text-align:left;border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);padding:9px 11px;transition:border-color .15s,background .15s}.demo-acc:hover{border-color:var(--accent);background:var(--accent-soft)}.demo-acc .da-name{font-weight:600;font-size:13.5px}.demo-acc .da-role{font-size:12px;color:var(--text-muted)}.demo-acc .da-arrow{margin-left:auto;color:var(--text-faint)}.shell{display:grid;grid-template-columns:256px 1fr;height:100%}[data-density=compacto] .shell{grid-template-columns:230px 1fr}.sidebar{background:linear-gradient(180deg,var(--sidebar-bg) 0%,var(--sidebar-bg-2) 100%);color:#fff;display:flex;flex-direction:column;padding:20px 14px}.sidebar .sb-head{padding:6px 8px 18px}.sb-group-label{font-size:11px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:#ffffff5c;padding:0 12px;margin:16px 0 7px}.nav{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border-radius:8px;border:0;background:transparent;color:#ffffffbd;font-size:14px;font-weight:500;text-align:left;transition:background .14s,color .14s;position:relative}.nav-item:hover{background:#ffffff12;color:#fff}.nav-item.active{background:#ffffff1f;color:#fff;font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-14px;top:8px;bottom:8px;width:3px;background:#fff;border-radius:0 3px 3px 0}.nav-item .ni-icon{flex:0 0 18px;display:grid;place-items:center;opacity:.92}.nav-item .ext{margin-left:auto;opacity:.5}.nav-item .lock{margin-left:auto;opacity:.4;font-size:11px}.sb-user{margin-top:auto;display:flex;align-items:center;gap:11px;padding:11px 10px;border-radius:9px;background:#00000038;border:1px solid rgba(255,255,255,.07)}.sb-user .su-text{line-height:1.2;min-width:0}.sb-user .su-name{font-size:13.5px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-user .su-role{font-size:11.5px;color:#ffffff80}.sb-user .su-logout{margin-left:auto;background:none;border:0;color:#ffffff8c;padding:6px;border-radius:7px;display:grid;place-items:center}.sb-user .su-logout:hover{color:#fff;background:#ffffff1a}.avatar{border-radius:999px;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:700;flex:0 0 auto}.avatar.lg{width:38px;height:38px;font-size:14px}.avatar.md{width:32px;height:32px;font-size:12.5px}.avatar.sm{width:26px;height:26px;font-size:11px}.avatar.on-dark{background:#ffffff24}.av-c0{background:#1e3a5f}.av-c1{background:#1f6f54}.av-c2{background:#7a3e8f}.av-c3{background:#a8632a}.av-c4{background:#2d6478}.av-c5{background:#8f3a52}.main{display:flex;flex-direction:column;min-width:0;overflow:hidden}.topbar{height:64px;flex:0 0 64px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 var(--pad)}.topbar .tb-title{font-size:17px;font-weight:700;letter-spacing:-.2px}.topbar .tb-crumb{font-size:13px;color:var(--text-faint)}.topbar .tb-spacer{flex:1}.search{display:flex;align-items:center;gap:8px;height:38px;padding:0 12px;border:1px solid var(--border-strong);border-radius:999px;background:var(--surface-2);color:var(--text-muted);min-width:240px;transition:border-color .15s,box-shadow .15s}.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface)}.search input{border:0;background:transparent;outline:none;width:100%;color:var(--text)}.content{flex:1;overflow-y:auto;padding:var(--pad)}.content-inner{max-width:1160px;margin:0 auto}.greeting{margin-bottom:6px}.greeting h2{font-size:25px;font-weight:800;letter-spacing:-.5px}.greeting p{color:var(--text-muted);margin-top:4px}.section-head{display:flex;align-items:baseline;gap:12px;margin:30px 0 14px}.section-head h3{font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint)}.section-head .hr{flex:1;height:1px;background:var(--border)}.module-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:var(--gap)}.module-card{display:flex;flex-direction:column;gap:14px;text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);transition:border-color .16s,box-shadow .16s,transform .16s;position:relative;width:100%}.module-card:not(.locked):hover{border-color:var(--accent-line);box-shadow:var(--shadow-md);transform:translateY(-2px)}.module-card .mc-top{display:flex;align-items:flex-start;justify-content:space-between}.module-card .mc-icon{width:46px;height:46px;border-radius:11px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent)}.module-card .mc-ext{color:var(--text-faint)}.module-card .mc-name{font-size:16.5px;font-weight:700;letter-spacing:-.2px}.module-card .mc-desc{font-size:13px;color:var(--text-muted);margin-top:3px;line-height:1.4}.module-card .mc-foot{margin-top:4px;font-size:12.5px;font-weight:600;color:var(--accent);display:flex;align-items:center;gap:6px}.module-card.locked{opacity:.6}.module-card.locked .mc-icon{background:var(--surface-2);color:var(--text-faint)}.module-card.locked .mc-foot{color:var(--text-faint)}.stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--gap);margin-bottom:8px}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow-sm)}.stat .s-label{font-size:12.5px;color:var(--text-muted);font-weight:600}.stat .s-value{font-size:26px;font-weight:800;letter-spacing:-.6px;margin-top:4px}.stat .s-value small{font-size:14px;font-weight:600;color:var(--text-faint)}.stat .s-meta{font-size:12px;color:var(--text-faint);margin-top:2px}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px;white-space:nowrap}.badge .dot{width:6px;height:6px;border-radius:999px;background:currentColor}.badge.ok{color:var(--ok);background:var(--ok-soft)}.badge.warn{color:var(--warn);background:var(--warn-soft)}.badge.danger{color:var(--danger);background:var(--danger-soft)}.badge.neutral{color:var(--text-muted);background:var(--surface-2);border:1px solid var(--border)}.badge.accent{color:var(--accent);background:var(--accent-soft)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.panel-head{display:flex;align-items:center;gap:14px;padding:16px var(--pad);border-bottom:1px solid var(--border);flex-wrap:wrap}.panel-head .ph-title{font-weight:700;font-size:15px}.panel-head .ph-count{font-size:12.5px;color:var(--text-faint);font-weight:600}.panel-head .spacer{flex:1}.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.select-chip{height:36px;padding:0 32px 0 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%236d6d66' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 11px center;font-size:13.5px;font-weight:500;-webkit-appearance:none;-moz-appearance:none;appearance:none;color:var(--text)}.select-chip:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.tbl{width:100%;border-collapse:collapse}.tbl th{text-align:left;font-size:11.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text-faint);padding:11px var(--pad);border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap}.tbl td{padding:0 var(--pad);height:var(--row-h);border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}.tbl tbody tr{transition:background .12s}.tbl tbody tr:hover{background:var(--accent-soft);cursor:pointer}.tbl tbody tr:last-child td{border-bottom:0}.tbl .t-primary{font-weight:600}.tbl .t-sub{font-size:12.5px;color:var(--text-faint)}.cell-name{display:flex;align-items:center;gap:11px}.cell-actions{display:flex;gap:4px;justify-content:flex-end}.icon-btn{background:none;border:0;color:var(--text-faint);padding:7px;border-radius:7px;display:grid;place-items:center}.icon-btn:hover{color:var(--accent);background:var(--accent-soft)}.icon-btn.danger:hover{color:var(--danger);background:var(--danger-soft)}.empty{padding:56px 20px;text-align:center;color:var(--text-muted)}.empty .e-icon{color:var(--text-faint);margin-bottom:12px}.empty .e-title{font-weight:700;color:var(--text);margin-bottom:4px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f162666;z-index:40;opacity:0;animation:fade .18s forwards}@keyframes fade{to{opacity:1}}.drawer{position:fixed;top:0;right:0;bottom:0;width:min(560px,100vw);z-index:41;background:var(--surface);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;transform:translate(100%);animation:slidein .26s cubic-bezier(.22,.61,.36,1) forwards}@keyframes slidein{to{transform:translate(0)}}.drawer-head{display:flex;align-items:flex-start;gap:12px;padding:22px var(--pad);border-bottom:1px solid var(--border)}.drawer-head .dh-title{font-size:18px;font-weight:800;letter-spacing:-.3px}.drawer-head .dh-sub{font-size:13px;color:var(--text-muted);margin-top:2px}.drawer-head .dh-close{margin-left:auto}.drawer-body{flex:1;overflow-y:auto;padding:var(--pad)}.drawer-foot{padding:16px var(--pad);border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end;background:var(--surface-2)}.drawer-foot .spacer{flex:1}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid .full{grid-column:1 / -1}.form-section-title{grid-column:1 / -1;font-size:12px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:var(--accent);margin-top:8px;padding-bottom:6px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}.hint{font-size:12px;color:var(--text-faint);margin-top:4px}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip-toggle{font-size:13px;font-weight:600;padding:7px 13px;border-radius:999px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text-muted);transition:all .14s}.chip-toggle.on{background:var(--accent);border-color:var(--accent);color:#fff}.chip-toggle:not(.on):hover{border-color:var(--accent);color:var(--accent)}.role-pick{display:grid;gap:8px}.role-opt{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:12px 14px;transition:all .14s}.role-opt.on{border-color:var(--accent);background:var(--accent-soft)}.role-opt:hover{border-color:var(--accent)}.role-opt .ro-radio{width:18px;height:18px;border-radius:999px;border:2px solid var(--border-strong);margin-top:1px;flex:0 0 auto;display:grid;place-items:center}.role-opt.on .ro-radio{border-color:var(--accent)}.role-opt.on .ro-radio:after{content:"";width:9px;height:9px;border-radius:999px;background:var(--accent)}.role-opt .ro-name{font-weight:600}.role-opt .ro-desc{font-size:12.5px;color:var(--text-muted);margin-top:2px}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:60;background:var(--text);color:#fff;padding:11px 18px;border-radius:999px;font-size:13.5px;font-weight:600;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:9px;animation:toastin .25s ease}.toast .tk{color:#6fe0b0}@keyframes toastin{0%{opacity:0;transform:translate(-50%,12px)}}.kv{display:flex;flex-direction:column;gap:3px}.kv .k{font-size:11.5px;color:var(--text-faint);font-weight:600;text-transform:uppercase;letter-spacing:.4px}.kv .v{font-size:14px}@media (max-width: 880px){.login-wrap{grid-template-columns:1fr}.login-aside{display:none}.shell{grid-template-columns:1fr}.sidebar{display:none}.search{min-width:0;width:150px}.form-grid{grid-template-columns:1fr}}
