:root {
  --fm-blue: #0D47A1;
  --fm-green: #22C55E;
  --fm-white: #FFFFFF;
  --fm-gray: #E6EAF1;
  --fm-black: #121826;
}

body {
  background-color: var(--fm-gray);
  font-family: "Segoe UI", Roboto, Arial, sans-serif;
}

/* Sidebar */
.fm-sidebar {
  background-color: var(--fm-black);
  min-height: 100vh;
  color: var(--fm-white);
}

.fm-sidebar .fm-brand {
  color: var(--fm-white);
  font-weight: 800;
  letter-spacing: .5px;
}

.fm-sidebar .fm-brand span {
  color: var(--fm-green);
}

.fm-sidebar .nav-link {
  color: rgba(255, 255, 255, .75);
  border-radius: .6rem;
  margin-bottom: .25rem;
  font-weight: 500;
}

.fm-sidebar .nav-link i {
  width: 1.5rem;
}

.fm-sidebar .nav-link.active,
.fm-sidebar .nav-link:hover {
  background-color: var(--fm-blue);
  color: var(--fm-white);
}

/* Topbar */
.fm-topbar {
  background-color: var(--fm-white);
  border-bottom: 1px solid #dee3ee;
}

/* Cards */
.fm-card {
  background: var(--fm-white);
  border: none;
  border-radius: 1rem;
  box-shadow: 0 2px 10px rgba(18, 24, 38, .06);
}

.fm-kpi .fm-kpi-icon {
  width: 48px;
  height: 48px;
  border-radius: .8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  color: var(--fm-white);
}

.fm-kpi-icon.bg-blue { background-color: var(--fm-blue); }
.fm-kpi-icon.bg-green { background-color: var(--fm-green); }
.fm-kpi-icon.bg-black { background-color: var(--fm-black); }

/* Buttons */
.btn-fm-primary {
  background-color: var(--fm-blue);
  border-color: var(--fm-blue);
  color: var(--fm-white);
  border-radius: .8rem;
  font-weight: 600;
}

.btn-fm-primary:hover {
  background-color: #0a3a82;
  color: var(--fm-white);
}

.btn-fm-success {
  background-color: var(--fm-green);
  border-color: var(--fm-green);
  color: var(--fm-white);
  border-radius: .8rem;
  font-weight: 600;
}

.btn-fm-success:hover {
  background-color: #1ba750;
  color: var(--fm-white);
}

.rounded-fm {
  border-radius: .8rem !important;
}

.badge-status-pendente { background-color: #f59e0b; }
.badge-status-aprovado { background-color: var(--fm-green); }
.badge-status-bloqueado { background-color: #dc2626; }

.table thead th {
  border-bottom-width: 1px;
  color: #5b6472;
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.login-card {
  max-width: 420px;
  margin: 8vh auto;
}
