:root{--bg: #f1f5f9;--surface: #ffffff;--border: #e6e9ef;--border-strong: #d6dae3;--text: #0f172a;--muted: #64748b;--muted-soft: #94a3b8;--primary: #16384d;--primary-hover: #0f2a3a;--primary-soft: #e9eef2;--danger: #dc2626;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .06);--shadow-md: 0 4px 16px rgba(15, 23, 42, .08);--shadow-lg: 0 24px 48px rgba(15, 23, 42, .22);--radius: 14px}*{box-sizing:border-box}html,body{margin:0}body{font-family:Open Sans,system-ui,-apple-system,Segoe UI,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}.app-header{display:flex;align-items:center;padding:.85rem 1.75rem;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:10}.brand{display:flex;align-items:center;gap:.75rem}.brand-mark{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#1d4a63,#16384d);color:#fff;font-weight:800;font-size:.85rem;letter-spacing:.04em;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.brand-logo{height:34px;width:auto;display:block}.brand-divider{width:1px;height:28px;background:var(--border-strong);margin:0 .15rem}.brand-text{display:flex;flex-direction:column;line-height:1.15}.brand-title{font-size:1.05rem;font-weight:700}.brand-sub{font-size:.74rem;color:var(--muted-soft);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.app-nav{display:flex;gap:.4rem;margin-left:2rem}.nav-tab{padding:.45rem .95rem;border-radius:8px;font-size:.9rem;font-weight:600;color:var(--muted);text-decoration:none;transition:background .15s,color .15s}.nav-tab:hover{background:#f1f4f8;color:var(--text)}.nav-tab.router-link-exact-active{background:var(--primary);color:#fff}.app-main{padding:1.75rem;max-width:1240px;margin:0 auto}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);overflow:hidden}.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.25rem 1.4rem 1rem}.card-title{margin:0;font-size:1.15rem;font-weight:700}.card-desc{margin:.2rem 0 0;font-size:.82rem;color:var(--muted)}.card-tools{display:flex;align-items:center;gap:1rem;padding:0 1.4rem 1.1rem;flex-wrap:wrap}.search-wrap{position:relative;flex:1;min-width:240px;max-width:460px}.search-icon{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--muted-soft);pointer-events:none}.search{width:100%;padding:.6rem .85rem .6rem 2.2rem;border:1px solid var(--border-strong);border-radius:9px;font-size:.9rem;background:#fbfcfe;color:var(--text)}.search:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #16384d29}.dept-filter{width:auto;min-width:170px;padding-left:.85rem;cursor:pointer}.checkbox{display:flex;align-items:center;gap:.45rem;font-size:.85rem;color:var(--muted);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox input{accent-color:var(--primary);width:1rem;height:1rem;cursor:pointer}.btn{display:inline-flex;align-items:center;gap:.35rem;padding:.55rem .95rem;border:1px solid var(--border-strong);background:var(--surface);border-radius:9px;font-size:.88rem;font-weight:600;color:var(--text);cursor:pointer;transition:background .12s,border-color .12s,box-shadow .12s,color .12s}.btn:hover{background:#f4f6fb;border-color:var(--muted-soft)}.btn-sm{padding:.35rem .7rem;font-size:.82rem}.btn-icon{font-size:1rem;line-height:1}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.btn-primary:disabled{opacity:.6;cursor:default}.btn-danger{color:var(--danger)}.btn-danger:hover{background:#fef2f2;border-color:#fca5a5}.table-wrap{overflow-x:auto;border-top:1px solid var(--border)}.users-table{width:100%;border-collapse:collapse;font-size:.88rem}.users-table th,.users-table td{text-align:left;padding:.7rem 1.4rem;border-bottom:1px solid var(--border);white-space:nowrap;vertical-align:middle}.users-table th{background:#f8fafc;font-weight:700;color:var(--muted);text-transform:uppercase;font-size:.7rem;letter-spacing:.05em;position:sticky;top:0}.users-table tbody tr{transition:background .1s}.users-table tbody tr:hover{background:#f7f9fe}.users-table tbody tr:last-child td{border-bottom:none}.users-table .num{text-align:right;font-variant-numeric:tabular-nums}.actions-col{text-align:right}.actions-col .btn+.btn{margin-left:.35rem}.user-cell{display:flex;align-items:center;gap:.7rem}.avatar{flex:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700}.user-meta{display:flex;flex-direction:column;line-height:1.25}.user-name{font-weight:600;color:var(--text)}.user-email{font-size:.78rem;color:var(--muted);text-decoration:none}.user-email:hover{color:var(--primary);text-decoration:underline}.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.2rem .6rem;border-radius:999px;font-size:.74rem;font-weight:700}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.badge-green{background:#dcfce7;color:#15803d}.badge-grey{background:#eef1f5;color:#64748b}.badge-blue{background:#dbeafe;color:#1d4ed8}.pill{display:inline-block;padding:.2rem .6rem;border-radius:7px;font-size:.78rem;font-weight:600}.pill-0,.avatar-0{background:#eef1f5;color:#64748b}.pill-1,.avatar-1{background:#e0e7ff;color:#3730a3}.pill-2,.avatar-2{background:#fef3c7;color:#92400e}.pill-3,.avatar-3{background:#d1fae5;color:#065f46}.pill-4,.avatar-4{background:#fce7f3;color:#9d174d}.pill-5,.avatar-5{background:#cffafe;color:#155e75}.pill-6,.avatar-6{background:#ffe4e6;color:#9f1239}.pill-7,.avatar-7{background:#ede9fe;color:#5b21b6}.muted{color:var(--muted)}.center{text-align:center}.state{padding:2.5rem 1.4rem;text-align:center;font-size:.9rem}.error{color:var(--danger);font-size:.86rem}.banner{margin:0 1.4rem 1rem;padding:.7rem .9rem;background:#fef2f2;border:1px solid #fecaca;border-radius:9px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:1rem;z-index:50}.modal{background:var(--surface);border-radius:var(--radius);width:100%;max-width:520px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.4rem;border-bottom:1px solid var(--border)}.modal-head h2{margin:0;font-size:1.1rem;font-weight:700}.modal-close{border:none;background:none;font-size:1.5rem;line-height:1;color:var(--muted-soft);cursor:pointer;padding:0 .25rem}.modal-close:hover{color:var(--text)}.modal form{display:flex;flex-direction:column;gap:.9rem;padding:1.3rem 1.4rem 1.4rem}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}.modal label{display:flex;flex-direction:column;gap:.32rem;font-size:.74rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.modal input,.modal select{padding:.55rem .65rem;border:1px solid var(--border-strong);border-radius:9px;font-size:.9rem;color:var(--text);font-weight:400;text-transform:none;letter-spacing:normal;background:#fbfcfe}.modal input:focus,.modal select:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #16384d29}.leaves-box{border:1px solid var(--border);border-radius:11px;padding:.9rem 1rem 1rem;margin:0;background:#fafbfe}.leaves-box legend{font-size:.74rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;padding:0 .4rem}.hint{font-size:.78rem;color:var(--muted);margin:.7rem 0 0;line-height:1.45}.link-btn{border:none;background:none;color:var(--primary);font-weight:700;cursor:pointer;padding:0;font-size:.78rem}.link-btn:hover{text-decoration:underline}.modal-actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:.3rem}@media(max-width:540px){.grid-2{grid-template-columns:1fr}}
