@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;600;700;900&display=swap');
:root{--bg:#f8f9fc;--card:#fff;--text:#1a202c;--text-muted:#718096;--border:#e2e8f0;--primary:#4f46e5;--primary-hover:#4338ca;--success:#10b981;--danger:#ef4444;--shadow:0 1px 3px rgba(0,0,0,.05);--orange-dark:#ea580c;--orange-mid:#fb923c;--orange-light:#fdba74;--green-dark:#059669;--green-mid:#10b981;--green-light:#6ee7b7;--table-header:#475569}
*{box-sizing:border-box;margin:0;padding:0}body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);line-height:1.6}
.container-narrow{max-width:1200px;margin:0 auto;padding:0 16px}.main-pad{padding:24px 0}
.navbar{background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow);position:sticky;top:0;z-index:100}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;max-width:1200px;margin:0 auto}
.navbar-brand{font-weight:900;font-size:20px;color:var(--primary);text-decoration:none}
.navbar-toggler{display:none;background:transparent;border:2px solid var(--border);border-radius:8px;padding:8px 12px;cursor:pointer;font-size:18px}
.navbar-nav{display:flex;gap:4px;align-items:center;list-style:none}
.nav-link{text-decoration:none;color:var(--text);font-weight:600;font-size:14px;padding:8px 14px;border-radius:8px;transition:all .2s;white-space:nowrap}
.nav-link:hover{background:rgba(79,70,229,.1);color:var(--primary)}.nav-link.active{background:var(--primary);color:#fff}
@media (max-width:991px){.navbar-toggler{display:block}.navbar-collapse{position:absolute;top:100%;left:0;right:0;background:#fff;border-top:1px solid var(--border);box-shadow:0 4px 6px rgba(0,0,0,.08);display:none;padding:12px}.navbar-collapse.show{display:block}.navbar-nav{flex-direction:column;align-items:stretch;gap:4px}.nav-link{text-align:center;padding:12px}}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:20px;margin-bottom:24px}
.btn{border:none;padding:10px 18px;border-radius:8px;font-weight:700;font-size:14px;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}
.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}
.btn-danger{background:var(--danger);color:#fff}.btn-outline-secondary{background:transparent;border:2px solid var(--border);color:var(--text-muted)}
.btn-sm{padding:6px 12px;font-size:13px}
.kpi-box{border-radius:12px;padding:20px;color:#fff;box-shadow:var(--shadow)}
.kpi-label{font-size:11px;text-transform:uppercase;opacity:.95;margin-bottom:6px;letter-spacing:.5px}
.kpi-value{font-size:28px;font-weight:900}
.kpi-orange-dark{background:linear-gradient(135deg,#ea580c 0%,#dc2626 100%)}
.kpi-orange-mid{background:linear-gradient(135deg,#fb923c 0%,#f97316 100%)}
.kpi-orange-light{background:linear-gradient(135deg,#fdba74 0%,#fb923c 100%)}
.kpi-green-dark{background:linear-gradient(135deg,#059669 0%,#047857 100%)}
.kpi-green-mid{background:linear-gradient(135deg,#10b981 0%,#059669 100%)}
.kpi-green-light{background:linear-gradient(135deg,#6ee7b7 0%,#34d399 100%)}
.table-responsive{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:14px}
.table thead th{background:var(--table-header);color:#fff;font-weight:700;padding:12px;text-align:left;font-size:13px;text-transform:uppercase;letter-spacing:.5px}
.table tbody td{padding:12px;border-bottom:1px solid var(--border)}
.badge-status{font-weight:800;padding:4px 10px;border-radius:12px;font-size:11px;text-transform:uppercase}
.badge-np{background:#fee2e2;color:#991b1b}.badge-pp{background:#fef3c7;color:#92400e}.badge-p{background:#d1fae5;color:#065f46}
.badge-super{background:linear-gradient(135deg,#4f46e5,#7c3aed);color:#fff;padding:3px 8px;border-radius:6px;font-size:10px;font-weight:900;margin-left:8px}
.form-label{font-weight:600;font-size:13px;margin-bottom:6px;display:block}
.form-control,.form-select{border:2px solid var(--border);border-radius:8px;padding:10px 14px;font-size:14px;width:100%;font-family:inherit}
.filter-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center}.filter-bar input,.filter-bar select{flex:1;min-width:200px}
.pagination{display:flex;gap:8px;justify-content:center;margin-top:20px;flex-wrap:wrap}
.pagination button{padding:8px 12px;border:1px solid var(--border);background:#fff;border-radius:6px;cursor:pointer;font-weight:700}
.pagination button.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.modal{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.modal.show{display:flex}.modal-dialog{max-width:520px;width:100%}.modal-content{background:#fff;border-radius:12px}
.modal-header{padding:20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.modal-title{font-size:18px;font-weight:900}.btn-close{background:transparent;border:none;font-size:28px;cursor:pointer;color:var(--text-muted)}
.modal-body{padding:20px}.modal-footer{padding:20px;border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}
.alert{padding:14px 18px;border-radius:8px;margin-bottom:16px;font-size:14px;font-weight:800}
.alert-danger{background:#fee2e2;color:#991b1b}.alert-success{background:#d1fae5;color:#065f46}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),#6366f1);padding:20px}
.login-card{background:#fff;border-radius:16px;padding:40px;max-width:420px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.login-card h1{font-size:28px;font-weight:900;margin-bottom:8px;color:var(--primary)}
.login-card .subtitle{color:var(--text-muted);margin-bottom:32px;font-size:14px}
.top10-box{background:#f9fafb;border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:16px}
.top10-box h4{font-size:14px;font-weight:900;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}
.top10-item{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}
.top10-item:last-child{border-bottom:none}.top10-name{font-weight:700;font-size:13px}.top10-amount{font-weight:900;color:var(--danger);font-size:14px}
/* Fix select texte invisible */
.form-select, .form-control {
  background: #fff;
  color: var(--text);
}

select option {
  color: var(--text);
  background: #fff;
}
/* ===== Sophisticated dialogs + toasts ===== */
.ui-backdrop{
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.55);
  backdrop-filter: blur(2px);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 99999;
  padding: 16px;
}

.ui-backdrop.show{ display: flex; }

.ui-dialog{
  width: min(520px, 96vw);
  background: #fff;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 20px 70px rgba(0,0,0,0.25);
  overflow: hidden;
  transform: translateY(8px);
  opacity: 0;
  animation: uiPop 140ms ease-out forwards;
}

@keyframes uiPop{
  to { transform: translateY(0); opacity: 1; }
}

.ui-dialog-header{
  padding: 14px 16px;
  display:flex;
  justify-content: space-between;
  align-items:center;
  border-bottom: 1px solid rgba(0,0,0,0.06);
  background: #f8fafc;
}

.ui-dialog-title{
  font-weight: 900;
  font-size: 15px;
  color: #0f172a;
}

.ui-dialog-close{
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  padding: 6px 10px;
  border-radius: 10px;
}
.ui-dialog-close:hover{ background: rgba(0,0,0,0.06); }

.ui-dialog-body{
  padding: 14px 16px;
  color: #0f172a;
  font-size: 14px;
  line-height: 1.4;
}

.ui-dialog-footer{
  padding: 14px 16px;
  display:flex;
  gap:10px;
  justify-content: flex-end;
  border-top: 1px solid rgba(0,0,0,0.06);
  background: #fff;
}

/* Toast center top */
.ui-toasts{
  position: fixed;
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100000;
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: min(520px, 94vw);
  pointer-events: none;
}

.ui-toast{
  pointer-events: auto;
  border-radius: 14px;
  padding: 12px 14px;
  border: 1px solid rgba(0,0,0,0.08);
  box-shadow: 0 10px 28px rgba(0,0,0,0.18);
  background: #fff;
  display:flex;
  gap: 10px;
  align-items: flex-start;
  animation: uiSlide 160ms ease-out;
}

@keyframes uiSlide{
  from { transform: translateY(-8px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}

.ui-toast .t-title{ font-weight: 900; font-size: 13px; margin-bottom: 2px; }
.ui-toast .t-msg{ font-size: 13px; color:#0f172a; }
.ui-toast.success{ border-left: 5px solid #16a34a; }
.ui-toast.danger{ border-left: 5px solid #dc2626; }
.ui-toast.info{ border-left: 5px solid #2563eb; }
.ui-toast.warning{ border-left: 5px solid #f59e0b; }
