:root {
  --navy:       #1B3A6E;
  --navy-dark:  #122b55;
  --navy-light: #2a527a;
  --gold:       #C9A227;
  --gold-dark:  #a07d18;
  --bg:         #F0F2F5;
  --sidebar-w:  265px;
}

/* ── Base ── */
*, body { font-family: 'Cairo', sans-serif; }
body { background: var(--bg); color: #2c3e50; padding-top: 60px; }

/* ── Navbar ── */
#main-navbar {
  background: linear-gradient(90deg, var(--navy-dark) 0%, var(--navy) 60%, var(--navy-light) 100%);
  height: 60px;
  z-index: 1100;
  box-shadow: 0 2px 10px rgba(0,0,0,0.3);
}
.badge-role { background: var(--gold); color: #fff; font-size: .7rem; }

/* ── Sidebar ── */
#sidebar-wrapper {
  position: fixed;
  right: 0; top: 0;
  width: var(--sidebar-w);
  height: 100vh;
  background: linear-gradient(180deg, var(--navy-dark) 0%, var(--navy) 100%);
  z-index: 1050;
  overflow-y: auto;
  padding-top: 60px;
  transition: transform .3s ease;
  box-shadow: -3px 0 15px rgba(0,0,0,0.2);
}
.sidebar-heading {
  border-bottom: 1px solid rgba(255,255,255,.12);
}
.sidebar-item {
  color: rgba(255,255,255,.75) !important;
  background: transparent !important;
  border: none !important;
  border-right: 3px solid transparent !important;
  padding: 11px 18px;
  font-size: .92rem;
  transition: all .2s;
}
.sidebar-item:hover {
  color: #fff !important;
  background: rgba(255,255,255,.08) !important;
  border-right-color: var(--gold) !important;
}
.sidebar-item.active {
  color: #fff !important;
  background: rgba(201,162,39,.18) !important;
  border-right-color: var(--gold) !important;
  font-weight: 700;
}

/* ── Overlay ── */
#sidebar-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 1040;
}

/* ── Page content ── */
#page-content-wrapper {
  margin-right: var(--sidebar-w);
  min-height: calc(100vh - 60px);
  transition: margin-right .3s ease;
}

/* ── Page title ── */
.page-title { color: var(--navy); font-weight: 700; }
.text-navy  { color: var(--navy); }
.text-gold  { color: var(--gold); }

/* ── Cards ── */
.card {
  border: none;
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(0,0,0,.07);
}
.card-header-navy {
  background: linear-gradient(90deg, var(--navy-dark), var(--navy));
  color: #fff;
  border-radius: 12px 12px 0 0 !important;
  font-weight: 600;
  padding: 14px 18px;
}

/* ── Stat cards ── */
.stat-card {
  border-radius: 14px;
  padding: 22px 20px;
  color: #fff;
  position: relative;
  overflow: hidden;
  min-height: 110px;
  box-shadow: 0 4px 18px rgba(0,0,0,.15);
}
.stat-card .stat-number { font-size: 2rem; font-weight: 800; line-height: 1.1; }
.stat-card .stat-label  { font-size: .85rem; opacity: .9; margin-top: 4px; }
.stat-card .stat-icon {
  position: absolute; left: 18px; top: 50%;
  transform: translateY(-50%);
  font-size: 3rem; opacity: .18;
}
.stat-card-navy  { background: linear-gradient(135deg, var(--navy-dark), var(--navy-light)); }
.stat-card-gold  { background: linear-gradient(135deg, var(--gold-dark), var(--gold)); }
.stat-card-green { background: linear-gradient(135deg, #1a5e36, #198754); }
.stat-card-red   { background: linear-gradient(135deg, #7b0a0a, #dc3545); }
.stat-card-teal  { background: linear-gradient(135deg, #0d5c63, #0dcaf0); color: #fff; }

/* ── Tables ── */
.table-custom thead th {
  background: var(--navy);
  color: #fff;
  font-weight: 600;
  white-space: nowrap;
  border: none;
  font-size: .88rem;
}
.table-hover tbody tr:hover { background: #eef2ff; }

/* ── Buttons ── */
.btn-navy { background: var(--navy); color: #fff; border: none; }
.btn-navy:hover { background: var(--navy-dark); color: #fff; }
.btn-gold { background: var(--gold); color: #fff; border: none; }
.btn-gold:hover { background: var(--gold-dark); color: #fff; }

/* ── Source badges ── */
.src-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 30px;
  font-size: .78rem;
  font-weight: 600;
}
.src-family         { background: #d9e4f5; color: var(--navy); }
.src-neighborhood   { background: #fdf3d4; color: #7a5e00; }
.src-administration { background: #d4edda; color: #155724; }

/* ── Progress bars ── */
.progress-navy .progress-bar { background: var(--navy); }
.progress-gold .progress-bar { background: var(--gold); }

/* ── Login page ── */
.login-bg {
  min-height: 100vh;
  background: linear-gradient(135deg, var(--navy-dark) 0%, var(--navy) 50%, var(--navy-light) 100%);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.login-card { width: 100%; max-width: 420px; border-radius: 18px; overflow: hidden; }
.login-card .card-header-login {
  background: rgba(0,0,0,.25);
  padding: 30px 30px 20px;
  text-align: center;
  color: #fff;
}
.login-card .card-body { background: #fff; padding: 30px; }
.login-card .form-control {
  border-radius: 8px;
  padding: 10px 14px;
  font-family: 'Cairo', sans-serif;
}
.login-card .form-control:focus { border-color: var(--navy); box-shadow: 0 0 0 .2rem rgba(27,58,110,.2); }

/* ── Forms & inputs ── */
.form-control, .form-select {
  font-family: 'Cairo', sans-serif;
  border-radius: 8px;
}
.form-control:focus, .form-select:focus {
  border-color: var(--navy);
  box-shadow: 0 0 0 .2rem rgba(27,58,110,.15);
}
.form-label { font-weight: 600; color: #444; font-size: .9rem; }

/* ── Modal ── */
.modal { padding-top: 0 !important; }
.modal-dialog { margin-top: 70px; }
.modal-header { background: var(--navy); color: #fff; }
.modal-header .btn-close { filter: invert(1); }
.modal-title { font-weight: 700; }

/* ── Responsive ── */
@media (max-width: 991.98px) {
  #sidebar-wrapper { transform: translateX(100%); }
  #sidebar-wrapper.open { transform: translateX(0); }
  #sidebar-overlay.show { display: block; }
  #page-content-wrapper { margin-right: 0; }
}

/* ── Mobile table: hide secondary columns ── */
@media (max-width: 767.98px) {
  .col-hide-mobile { display: none !important; }

  /* Make stat cards smaller */
  .stat-card { padding: 14px 12px; min-height: 80px; }
  .stat-card .stat-number { font-size: 1.4rem; }
  .stat-card .stat-icon { font-size: 2rem; }

  /* Compact table cells */
  .table td, .table th { padding: 8px 6px; font-size: .82rem; }
  .table-custom thead th { font-size: .78rem; }

  /* Card full width */
  .card { border-radius: 8px; }

  /* Page title smaller */
  .page-title { font-size: 1rem; }

  /* Container padding */
  #page-content-wrapper .container-fluid { padding: 12px !important; }

  /* Buttons in table smaller */
  .table .btn-sm { padding: 3px 7px; font-size: .75rem; }
}

/* ── Responsive table card layout for very small screens ── */
@media (max-width: 575.98px) {
  .stat-card .stat-number { font-size: 1.2rem; }
}
