:root{--bg: #f1f5f9;--bg-soft: #f8fafc;--bg-tint: #eef6ff;--surface: #ffffff;--surface-glass: rgba(255, 255, 255, .78);--border: rgba(15, 23, 42, .08);--border-strong: rgba(15, 23, 42, .14);--text: #0f172a;--text-2: #334155;--muted: #64748b;--primary: #2563eb;--primary-2: #0284c7;--primary-3: #0ea5e9;--accent: #06b6d4;--accent-2: #6366f1;--accent-3: #8b5cf6;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--side-1: #07111f;--side-2: #0b1220;--glow-blue: rgba(37, 99, 235, .18);--glow-cyan: rgba(6, 182, 212, .16);--glow-violet: rgba(139, 92, 246, .14);--radius: 18px;--radius-sm: 12px;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04), 0 1px 3px rgba(15, 23, 42, .06);--shadow-md: 0 6px 20px rgba(15, 23, 42, .08);--shadow-lg: 0 18px 50px rgba(15, 23, 42, .14);--gradient-primary: linear-gradient(135deg, #2563eb 0%, #0ea5e9 55%, #06b6d4 100%)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.layout{display:flex;min-height:100vh}.sidebar{width:256px;flex-shrink:0;background:linear-gradient(180deg,var(--side-1) 0%,var(--side-2) 60%,#0a1830 100%);color:#cbd5e1;display:flex;flex-direction:column;position:relative;overflow:hidden}.sidebar:before{content:"";position:absolute;inset:-40% -60% auto -20%;height:320px;background:radial-gradient(closest-side,var(--glow-blue),transparent 70%),radial-gradient(closest-side,var(--glow-violet),transparent 70%);filter:blur(10px);pointer-events:none}.sidebar-brand{position:relative;padding:22px 22px 18px;display:flex;align-items:center;gap:12px}.brand-mark{width:38px;height:38px;border-radius:11px;background:var(--gradient-primary);display:grid;place-items:center;color:#fff;font-weight:800;font-size:15px;box-shadow:0 8px 20px var(--glow-blue)}.brand-text b{color:#fff;font-size:16px;letter-spacing:.4px;display:block}.brand-text span{color:#93a4bd;font-size:11px;letter-spacing:.6px}.sidebar nav{flex:1;padding:8px 12px;overflow-y:auto}.nav-group-label{color:#5e7290;font-size:10.5px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;padding:16px 12px 6px}.sidebar ul{list-style:none;margin:0;padding:0}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;margin:2px 0;border-radius:11px;color:#aebbcd;font-size:14px;font-weight:500;cursor:pointer;text-decoration:none;transition:background .15s ease,color .15s ease,box-shadow .2s ease}.nav-item:hover{background:#ffffff0f;color:#fff;text-decoration:none}.nav-item .nav-ico{width:18px;height:18px;flex-shrink:0;opacity:.9}.nav-item.active{color:#fff;background:linear-gradient(90deg,#2563eb59,#06b6d41f);box-shadow:inset 3px 0 #38bdf8,0 6px 16px var(--glow-blue)}.nav-item.soon{opacity:.55;cursor:default}.nav-item .soon-tag{margin-left:auto;font-size:9.5px;font-weight:700;letter-spacing:.5px;color:#7c8db0;border:1px solid rgba(148,163,184,.25);border-radius:6px;padding:1px 6px}.sidebar-foot{position:relative;padding:14px 20px;font-size:12px;color:#7e8ea7;border-top:1px solid rgba(255,255,255,.06)}.main{flex:1;display:flex;flex-direction:column;min-width:0}.header{height:64px;flex-shrink:0;background:var(--surface-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;padding:0 26px;position:sticky;top:0;z-index:30}.header-title{font-weight:700;font-size:16px;color:var(--text)}.header-sub{color:var(--muted);font-size:13px}.header-spacer{flex:1}.menu-toggle{display:none;background:none;border:1px solid var(--border-strong);border-radius:10px;padding:7px;cursor:pointer;color:var(--text-2)}.user-chip{display:flex;align-items:center;gap:10px;padding:5px 10px 5px 6px;border-radius:999px;border:1px solid var(--border);background:var(--surface);cursor:pointer;transition:box-shadow .2s ease,border-color .2s ease}.user-chip:hover{box-shadow:var(--shadow-sm);border-color:var(--border-strong)}.avatar{width:34px;height:34px;border-radius:50%;background:var(--gradient-primary);color:#fff;display:grid;place-items:center;font-weight:700;font-size:13px;flex-shrink:0;box-shadow:0 4px 10px var(--glow-blue)}.avatar.lg{width:60px;height:60px;font-size:22px;border-radius:18px}.user-chip-meta{display:flex;flex-direction:column;line-height:1.2;text-align:left}.user-chip-meta b{font-size:13.5px;color:var(--text);font-weight:600}.user-chip-meta span{font-size:11.5px;color:var(--muted)}.chip-caret{color:var(--muted);width:16px;height:16px}.dropdown{position:relative}.dropdown-menu{position:absolute;right:0;top:calc(100% + 10px);width:248px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);overflow:hidden;z-index:50;animation:pop .12s ease-out}@keyframes pop{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}.dropdown-head{padding:14px 16px;display:flex;gap:12px;align-items:center;border-bottom:1px solid var(--border)}.dropdown-head .user-chip-meta b{font-size:14px}.dropdown-badges{display:flex;flex-wrap:wrap;gap:6px;padding:10px 14px;border-bottom:1px solid var(--border)}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:none;padding:11px 16px;font-size:14px;color:var(--text-2);cursor:pointer}.dropdown-item:hover{background:var(--bg-soft);color:var(--text)}.dropdown-item.danger{color:var(--danger)}.dropdown-item svg{width:16px;height:16px}.content{padding:26px;max-width:1320px;width:100%;margin:0 auto}.page-head{margin-bottom:22px}.page-head h1{margin:0;font-size:24px;font-weight:750;letter-spacing:-.4px}.page-head p{margin:6px 0 0;color:var(--muted);font-size:14px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm)}.card.pad-lg{padding:28px}.card-hover{transition:transform .18s ease,box-shadow .18s ease}.card-hover:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.bento{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-6{grid-column:span 6}.col-8{grid-column:span 8}.col-12{grid-column:span 12}.card-label{font-size:12px;color:var(--muted);font-weight:600;letter-spacing:.3px;text-transform:uppercase}.card-value{font-size:26px;font-weight:750;margin-top:8px;letter-spacing:-.5px}.card-foot{margin-top:10px;font-size:13px;color:var(--text-2)}.stat-ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;margin-bottom:14px}.stat-ico svg{width:22px;height:22px}.tone-blue{background:#2563eb1a;color:var(--primary)}.tone-cyan{background:#06b6d41f;color:var(--accent)}.tone-violet{background:#8b5cf61f;color:var(--accent-3)}.tone-green{background:#10b9811f;color:var(--success)}.tone-amber{background:#f59e0b24;color:var(--warning)}.tone-slate{background:#64748b1f;color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.6}.badge-dot{width:7px;height:7px;border-radius:50%;background:currentColor}.badge-ok{background:#10b9811f;color:#047857}.badge-err{background:#ef44441f;color:#b91c1c}.badge-wait{background:#f59e0b29;color:#b45309}.badge-blue{background:#2563eb1a;color:#1d4ed8}.badge-cyan{background:#06b6d41f;color:#0e7490}.badge-violet{background:#8b5cf61f;color:#6d28d9}.badge-slate{background:#64748b1f;color:#475569}.badge-role{background:#2563eb1a;color:#1d4ed8}.badge-dept{background:#06b6d41f;color:#0e7490}.badge-row{display:flex;flex-wrap:wrap;gap:6px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid transparent;border-radius:11px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:transform .12s ease,box-shadow .15s ease,background .15s ease,opacity .15s ease;font-family:inherit}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 8px 18px var(--glow-blue)}.btn-primary:hover:not(:disabled){box-shadow:0 10px 24px var(--glow-blue)}.btn-ghost{background:var(--surface);border-color:var(--border-strong);color:var(--text-2)}.btn-ghost:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.btn-danger-ghost{background:var(--surface);border-color:#ef44444d;color:var(--danger)}.btn-danger-ghost:hover:not(:disabled){background:#ef44440f}.btn-sm{padding:6px 11px;font-size:12.5px;border-radius:9px}.btn-block{width:100%}label.field-label{display:block;font-size:13px;color:var(--text-2);font-weight:600;margin:14px 0 6px}.field-label .opt{color:var(--muted);font-weight:500}input,select,textarea{width:100%;background:var(--bg-soft);border:1px solid var(--border-strong);color:var(--text);border-radius:11px;padding:11px 13px;font-size:14px;font-family:inherit;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}input::placeholder,textarea::placeholder{color:#94a3b8}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #2563eb1f}.input-icon{position:relative}.input-icon svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--muted)}.input-icon input{padding-left:42px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 16px}.form-grid .span-2{grid-column:span 2}.alert{padding:11px 14px;border-radius:11px;font-size:13.5px;margin:14px 0 0}.alert-err{background:#ef444414;color:#b91c1c;border:1px solid rgba(239,68,68,.2)}.alert-ok{background:#10b98114;color:#047857;border:1px solid rgba(16,185,129,.2)}.alert code{background:#0f172a0f;padding:2px 6px;border-radius:6px;word-break:break-all}.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}.grid{width:100%;border-collapse:collapse;font-size:13.5px}.grid thead th{position:sticky;top:0;text-align:left;padding:12px 14px;background:var(--bg-soft);color:var(--muted);font-weight:600;font-size:12px;letter-spacing:.3px;text-transform:uppercase;border-bottom:1px solid var(--border)}.grid tbody td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text-2);vertical-align:middle}.grid tbody tr:last-child td{border-bottom:none}.grid tbody tr{transition:background .12s ease}.grid tbody tr:hover{background:var(--bg-tint)}.cell-user{display:flex;align-items:center;gap:10px}.cell-user .avatar{width:30px;height:30px;font-size:11px}.cell-user b{color:var(--text);font-weight:600}.cell-user span{color:var(--muted);font-size:12px}.muted-cell{color:var(--muted)}.kv{width:100%;border-collapse:collapse}.kv th{text-align:left;color:var(--muted);padding:9px 16px 9px 0;font-weight:500;vertical-align:top;width:130px;font-size:13.5px}.kv td{padding:9px 0;color:var(--text);border-bottom:1px solid var(--border)}.kv tr:last-child th,.kv tr:last-child td{border-bottom:none}.cap-list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:6px}.cap-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;background:var(--bg-soft);border-radius:10px;font-size:13.5px}.cap-item span{color:var(--text-2)}.empty-state{text-align:center;padding:44px 20px;color:var(--muted)}.empty-ico{width:64px;height:64px;margin:0 auto 16px;border-radius:20px;display:grid;place-items:center;background:var(--bg-tint);color:var(--primary)}.empty-ico svg{width:30px;height:30px}.empty-state h3{color:var(--text);margin:0 0 6px;font-size:17px}.empty-state p{margin:0 auto;max-width:440px;font-size:14px;line-height:1.6}.data-notice{display:flex;align-items:flex-start;gap:14px}.data-notice-ico{width:44px;height:44px;flex-shrink:0;border-radius:12px;display:grid;place-items:center;background:var(--bg-tint);color:var(--primary)}.data-notice-ico svg{width:22px;height:22px}.data-notice b{font-size:15px}.skeleton{background:linear-gradient(90deg,#eef2f7 25%,#e2e8f0 37%,#eef2f7 63%);background-size:400% 100%;animation:shimmer 1.3s ease infinite;border-radius:8px}@keyframes shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.auth-shell{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;background:radial-gradient(900px 600px at 12% 15%,var(--glow-blue),transparent 60%),radial-gradient(800px 600px at 85% 25%,var(--glow-cyan),transparent 60%),radial-gradient(700px 700px at 75% 90%,var(--glow-violet),transparent 60%),linear-gradient(160deg,#f8fafc,#eef6ff 55%,#f1f5f9)}.auth-aside{position:relative;padding:56px 60px;color:#e6edf7;background:linear-gradient(160deg,#07111f,#0b1530 55%,#131c44);display:flex;flex-direction:column;justify-content:center;overflow:hidden}.auth-aside:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(600px 380px at 80% 10%,var(--glow-blue),transparent 60%),radial-gradient(520px 420px at 10% 95%,var(--glow-violet),transparent 60%);pointer-events:none}.auth-aside .aside-inner{position:relative;max-width:440px}.aside-brand{display:flex;align-items:center;gap:13px;margin-bottom:34px}.aside-brand .brand-mark{width:44px;height:44px;font-size:17px}.aside-brand b{color:#fff;font-size:18px;display:block;letter-spacing:.4px}.aside-brand span{color:#93a4bd;font-size:12px;letter-spacing:.5px}.auth-aside h2{font-size:30px;line-height:1.2;margin:0 0 14px;color:#fff;letter-spacing:-.5px}.auth-aside .lead{color:#aab8cf;font-size:15px;line-height:1.65;margin:0 0 30px}.feature-list{display:flex;flex-direction:column;gap:13px}.feature-row{display:flex;align-items:center;gap:13px;font-size:14.5px;color:#d6dfee}.feature-row .f-ico{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;background:#ffffff12;color:#56ccf5;flex-shrink:0}.feature-row .f-ico svg{width:19px;height:19px}.aside-health{display:flex;flex-wrap:wrap;gap:8px;margin-top:34px}.health-pill{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border-radius:999px;font-size:12.5px;font-weight:600;background:#ffffff0f;color:#c7d3e6;border:1px solid rgba(255,255,255,.08)}.health-pill .badge-dot{width:7px;height:7px}.health-pill.ok{color:#6ee7b7}.health-pill.off{color:#fca5a5}.auth-main{display:flex;align-items:center;justify-content:center;padding:40px 24px}.auth-card{width:100%;max-width:400px;background:var(--surface-glass);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.7);border-radius:22px;padding:36px 34px;box-shadow:var(--shadow-lg)}.auth-card .mobile-brand{display:none}.auth-card h1{margin:0 0 4px;font-size:23px;font-weight:750;letter-spacing:-.4px}.auth-card .subtext{color:var(--muted);margin:0 0 22px;font-size:14px}.auth-card .btn{margin-top:22px}.auth-foot{font-size:13.5px;margin-top:18px;text-align:center;color:var(--muted)}.centered{min-height:100vh;display:grid;place-items:center;color:var(--muted);gap:14px}.spinner{width:34px;height:34px;border-radius:50%;border:3px solid var(--border-strong);border-top-color:var(--primary);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.note{color:var(--muted);font-size:13px;line-height:1.6}.divider{height:1px;background:var(--border);margin:22px 0;border:none}.section-title{font-size:15px;font-weight:700;margin:0 0 12px;color:var(--text);display:flex;align-items:center;gap:8px}.section-title svg{width:18px;height:18px;color:var(--primary);flex-shrink:0}.header-brand{display:flex;flex-direction:column;line-height:1.25}.overlay-scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;z-index:70;animation:fade .15s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.drawer{position:fixed;top:0;right:0;bottom:0;width:440px;max-width:94vw;z-index:80;background:var(--surface);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slidein .2s ease-out}@keyframes slidein{0%{transform:translate(30px);opacity:.6}to{transform:none;opacity:1}}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:80;width:440px;max-width:94vw;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);animation:pop .14s ease-out;display:flex;flex-direction:column;max-height:90vh}.drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border)}.drawer-body{padding:18px 20px;overflow-y:auto;flex:1}.drawer-foot{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--border)}.icon-btn{background:none;border:1px solid var(--border);border-radius:10px;padding:6px;cursor:pointer;color:var(--muted);display:grid;place-items:center}.icon-btn:hover{color:var(--text);border-color:var(--border-strong)}.icon-btn svg{width:18px;height:18px}.perm-section-title{font-size:12px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);margin-bottom:8px}.perm-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px 10px}.perm-dept{padding:12px 0;border-bottom:1px solid var(--border)}.perm-dept:last-child{border-bottom:none}.perm-dept-name{font-weight:600;font-size:13.5px;margin-bottom:8px;color:var(--text)}.check-row{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:9px;font-size:13.5px;color:var(--text-2);cursor:pointer}.check-row:hover{background:var(--bg-soft)}.cb{width:17px;height:17px;flex-shrink:0;accent-color:var(--primary);cursor:pointer}.scrim{display:none}@media (max-width: 1100px){.col-3,.col-4{grid-column:span 6}.col-8{grid-column:span 12}}@media (max-width: 960px){.auth-shell{grid-template-columns:1fr}.auth-aside{display:none}.auth-card{max-width:420px}.auth-card .mobile-brand{display:flex;align-items:center;gap:12px;justify-content:center;margin-bottom:20px}}@media (max-width: 820px){.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:60;transform:translate(-100%);transition:transform .22s ease;box-shadow:var(--shadow-lg)}.sidebar.open{transform:none}.menu-toggle{display:inline-flex}.scrim.show{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:55}.content{padding:18px}.form-grid{grid-template-columns:1fr}.form-grid .span-2{grid-column:span 1}.cap-list{grid-template-columns:1fr}.col-3,.col-4,.col-6,.col-8{grid-column:span 12}.user-chip-meta,.header-badges,.header-sub{display:none}}@media (max-width: 520px){.header{padding:0 16px}.auth-card{padding:28px 22px}}
