:root{
  --bg: #F5F7FB;
  --surface: rgba(255,255,255,0.86);
  --surface-2: rgba(255,255,255,0.72);
  --stroke: rgba(15, 23, 42, 0.10);
  --text: #0F172A;
  --muted: #64748B;

  --brand: #2B3A55;        /* muted navy */
  --brand-2: #1F2A3D;      /* deeper navy */
  --accent: #3B6EA8;       /* muted blue */
  --good: #2F7D6B;         /* muted green */
  --warn: #B7791F;         /* muted amber */
  --danger: #B45309;       /* muted orange */

  --shadow: 0 14px 40px rgba(15, 23, 42, 0.10);
  --shadow-sm: 0 10px 26px rgba(15, 23, 42, 0.08);
  --radius: 18px;
}

html, body {
  height: 100%;
}

body.bg-soft{
  background:
    radial-gradient(1200px 600px at 12% 10%, rgba(59,110,168,.14), transparent 55%),
    radial-gradient(900px 500px at 88% 8%, rgba(47,125,107,.10), transparent 52%),
    radial-gradient(900px 500px at 55% 95%, rgba(43,58,85,.10), transparent 55%),
    var(--bg);
  color: var(--text);
}

a { text-decoration: none; }
a:hover { text-decoration: none; }

.navbar {
  background: linear-gradient(135deg, var(--brand), var(--brand-2)) !important;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.navbar .nav-link {
  color: rgba(255,255,255,0.86) !important;
  font-weight: 600;
}
.navbar .nav-link:hover {
  color: #FFFFFF !important;
}

.brand-logo {
  height: 34px;
  width: auto;
  display: block;
}

.card-soft {
  background: var(--surface);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.card {
  border: 1px solid var(--stroke) !important;
  border-radius: var(--radius) !important;
  box-shadow: var(--shadow-sm);
  background: var(--surface);
}

.btn {
  border-radius: 14px;
  font-weight: 700;
}

.btn-primary {
  background: linear-gradient(135deg, var(--accent), #2D5D91);
  border: none;
  box-shadow: 0 10px 24px rgba(59,110,168,.22);
}
.btn-primary:hover {
  filter: brightness(0.98);
}

.btn-outline-secondary {
  border-color: rgba(100,116,139,.40);
  color: var(--text);
}
.btn-outline-secondary:hover {
  background: rgba(100,116,139,.10);
  border-color: rgba(100,116,139,.50);
}

.btn-outline-dark {
  border-color: rgba(15,23,42,.18);
}
.btn-outline-dark:hover {
  background: rgba(15,23,42,.06);
}

.badge-soft {
  background: rgba(59,110,168,.10);
  color: var(--brand);
  border: 1px solid rgba(59,110,168,.18);
  border-radius: 999px;
  padding: 0.35rem 0.6rem;
  font-weight: 700;
}

.kpi {
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 14px;
  border-radius: 16px;
  border: 1px solid var(--stroke);
  background: var(--surface-2);
}
.kpi .kpi-icon{
  width: 42px;
  height: 42px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  background: rgba(59,110,168,.12);
  border: 1px solid rgba(59,110,168,.18);
}
.kpi .kpi-title{
  font-weight: 800;
  margin: 0;
}
.kpi .kpi-sub{
  margin: 0;
  color: var(--muted);
  font-weight: 600;
  font-size: 0.92rem;
}

.table {
  --bs-table-bg: transparent;
}
.table thead th {
  color: var(--muted);
  font-weight: 800;
  letter-spacing: 0.2px;
  border-bottom: 1px solid rgba(15,23,42,.12) !important;
}
.table td {
  border-top: 1px solid rgba(15,23,42,.08) !important;
}

.form-control, .form-select, textarea {
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.14);
  background: rgba(255,255,255,.86);
}
.form-control:focus, .form-select:focus, textarea:focus {
  border-color: rgba(59,110,168,.45);
  box-shadow: 0 0 0 .2rem rgba(59,110,168,.15);
}

.icon-pill {
  display: inline-flex;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  border-radius: 16px;
  border: 1px solid var(--stroke);
  background: var(--surface-2);
}

.hr-soft {
  border: 0;
  border-top: 1px solid rgba(15,23,42,.10);
  margin: 1.25rem 0;
}
