@font-face{font-family:Inter;src:local("Inter"),local("Segoe UI"),local("Arial")}
:root{--bg:#f6f8f9;--fg:#1f2933;--muted:#68737d;--primary:#5f8890;--primary-600:#52767d;--primary-700:#446167;--white:#fff;--card:#ffffff;--border:#e5e7eb;--accent:#3fb6a8;--danger:#e11d48;--sidebar-w:220px}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--fg)}
.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,var(--primary),#3e5a60);color:var(--white);padding:16px 8px;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:8px;padding:8px 12px;font-weight:700}
.logo{width:28px;height:28px;border-radius:4px;background:#d9e4e6;object-fit:contain}
.menu{display:flex;flex-direction:column;padding:8px}
.menu-item{color:var(--white);text-decoration:none;padding:10px 12px;border-radius:8px;display:flex;align-items:center;gap:10px}
.menu-item .icon{width:20px;display:inline-flex;justify-content:center}
.menu-item:hover{background:rgba(255,255,255,.12)}
.sb-compact{--sidebar-w:72px}
.sb-compact .brand span{display:none}
.sb-compact .menu-item .label{display:none}
.sb-compact .menu-item{justify-content:center}
.content{display:flex;flex-direction:column;overflow-x:auto}
.topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border);background:var(--white);position:sticky;top:0;z-index:3;flex-wrap:wrap;overflow-x:hidden}
.top-left{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.top-right{display:flex;align-items:center;gap:8px;flex:0 0 auto}
.top-title{font-weight:600;flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.top-user{display:flex;align-items:center;gap:10px}
.avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid var(--border)}
.avatar-letter{width:28px;height:28px;border-radius:50%;display:inline-grid;place-items:center;background:var(--primary);color:#fff;font-weight:700;border:1px solid var(--border)}
.cards,.card,.card-body{min-width:0}
.table-wrap{width:100%}
.role{margin-left:8px;font-size:12px;color:var(--muted)}
.icon-btn{border:0;background:var(--primary);color:var(--white);padding:8px 10px;border-radius:8px;cursor:pointer}
.cards{display:grid;gap:16px;padding:16px}
.card{background:var(--card);border:1px solid var(--border);border-radius:16px;margin:16px;box-shadow:0 10px 18px rgba(31,41,55,.08)}
.card:hover{box-shadow:0 14px 24px rgba(31,41,55,.12)}
.card-title{padding:12px 16px;border-bottom:1px solid var(--border);font-weight:600}
.card-body{padding:16px}
.grid.two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form{display:grid;gap:12px}
.row{display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr))}
.col{display:flex;flex-direction:column;gap:6px}
label{font-size:12px;color:#000}
input,select,button,textarea{font:inherit}
input,select,textarea{padding:10px;border:1px solid var(--border);border-radius:10px;background:#fafafa}
input:focus,select:focus,textarea:focus{outline:2px solid var(--accent);border-color:transparent;background:#fff}
.btn{padding:10px 14px;border-radius:10px;border:1px solid var(--border);background:#fff;cursor:pointer;transition:all .15s}
.btn:hover{transform:translateY(-1px)}
.btn-sm{padding:6px 10px;font-size:12px;border-radius:8px}
.btn-outline-primary{background:#fff;border-color:var(--primary-600);color:var(--primary-700)}
.btn-outline-primary:hover{background:var(--primary);color:#fff;border-color:var(--primary-700)}
.btn-outline-danger{background:#fff;border-color:#fecaca;color:#b91c1c}
.btn-outline-danger:hover{background:#b91c1c;color:#fff;border-color:#991b1b}
.me-1{margin-right:6px}
.btn-primary{background:var(--primary);border-color:var(--primary-600);color:#fff}
.btn-primary:hover{background:var(--primary-700)}
.msg{min-height:22px;font-size:14px;color:var(--muted)}
.toast{display:inline-block;min-width:140px;max-width:42vw;padding:8px 12px;border-radius:10px;margin-left:8px;font-size:14px;line-height:1.2;background:#f3f4f6;color:#111;border:1px solid var(--border);opacity:0;transition:opacity .2s ease}
.toast.ok{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}
.toast.err{background:#fef2f2;color:#991b1b;border-color:#fecaca}
.alert-zone{padding:12px 16px}
.alert{border-radius:10px;border:none;box-shadow:0 2px 10px rgba(0,0,0,.1);--bs-alert-bg:transparent;--bs-alert-padding-x:1rem;--bs-alert-padding-y:1rem;--bs-alert-margin-bottom:1rem;--bs-alert-color:inherit;--bs-alert-border-color:transparent;--bs-alert-border:1px solid var(--bs-alert-border-color);--bs-alert-border-radius:10px;--bs-alert-link-color:inherit;position:relative;padding:var(--bs-alert-padding-y) var(--bs-alert-padding-x);margin-bottom:var(--bs-alert-margin-bottom);color:var(--bs-alert-color);background-color:var(--bs-alert-bg);border:var(--bs-alert-border);border-radius:var(--bs-alert-border-radius)}
.alert-success{--bs-alert-color:#065f46;--bs-alert-bg:#ecfdf5;--bs-alert-border-color:#a7f3d0}
.alert-danger{--bs-alert-color:#991b1b;--bs-alert-bg:#fef2f2;--bs-alert-border-color:#fecaca}
.alert-dismissible{padding-right:3rem}
.btn-close{background:transparent;border:0;position:absolute;top:10px;right:10px;cursor:pointer;font-size:16px;opacity:.6}
.btn-close:hover{opacity:1}
.fade{transition:opacity .2s}
.fade.show{opacity:1}
.table-wrap{overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--border);border-radius:12px;overflow:hidden}
thead th{background:#f3f6f7;font-weight:600;color:#4b5563}
th,td{border-bottom:1px solid var(--border);padding:12px;text-align:left}
tbody tr:nth-child(odd){background:#fafcfc}
.table th:last-child,.table td:last-child, table th:last-child, table td:last-child{text-align:right;white-space:nowrap}
.table.wide{min-width:1280px}
.diag-clip td:nth-child(7), .diag-clip th:nth-child(7){max-width:160px;width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.table th.actions-col, .table td.actions-col{position:sticky;right:0}
.table th.actions-col{z-index:2;background:#f3f6f7}
.table td.actions-col{background:#fff}
.table td.actions-col{z-index:1}
.stat{display:flex;flex-direction:column;gap:4px}
.stat span{font-size:28px;font-weight:800}
.filters{display:flex;gap:8px;margin-bottom:10px}
.filters#uPager,.filters#tarPager{justify-content:flex-end}
.page-bar{display:flex;justify-content:flex-end;gap:8px;padding:12px 16px}
.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:1000}
.modal.show{display:flex}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.35);z-index:1001}
.modal-dialog{position:relative;z-index:1002;background:#fff;border:1px solid var(--border);border-radius:16px;width:min(600px,96vw);max-height:88vh;overflow:auto;box-shadow:0 18px 40px rgba(0,0,0,.16);display:flex;flex-direction:column}
.modal-header,.modal-footer{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-footer{border-top:1px solid var(--border);border-bottom:0}
.modal-body{padding:16px}
.modal .row{grid-template-columns:repeat(2,minmax(0,1fr))}
@media (max-width:640px){.modal .row{grid-template-columns:1fr}}
.form input,.form select,.form textarea{width:100%}
.input-lg{height:42px;font-size:16px}
.login-body{display:grid;place-items:center;height:100vh;background:linear-gradient(180deg,#e8eff2,transparent) var(--bg)}
.login-card{width:100%;max-width:420px;background:var(--white);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 6px 18px rgba(0,0,0,.06)}
.login-brand{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:8px}
.logo-lg{width:80px;height:80px;border-radius:12px;background:#d9e4e6;object-fit:contain}
@media (max-width:960px){.app{grid-template-columns:1fr}.sidebar{position:fixed;left:-260px;transition:left .2s}.sidebar.open{left:0}.content{padding-left:0}.grid.two{grid-template-columns:1fr}.row{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (min-width:961px){#sidebarToggle{display:none}}
