:root {
  --dfic-green:       #145a32;
  --dfic-green-dark:  #0e4024;
  --dfic-gold:        #c9a04a;
}

.bg-dficGreen { background-color: var(--dfic-green) !important; }
.bg-dficGold  { background-color: var(--dfic-gold) !important; }
.text-dficGreen { color: var(--dfic-green) !important; }
.text-dficGold { color: var(--dfic-gold) !important; }

.btn-dfic {
  background-color: var(--dfic-green);
  color: #fff;
  border: none;
}
.btn-dfic:hover {
  background-color: var(--dfic-green-dark);
  color: #fff;
}

.card-metric {
  border: none;
  border-left: 4px solid var(--dfic-green);
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.card-metric .metric-value { font-size: 2rem; font-weight: 600; line-height: 1; }
.card-metric .metric-label { color: #6c757d; font-size: .85rem; text-transform: uppercase; letter-spacing: .04em; }

.login-card {
  max-width: 400px;
  margin: 8vh auto;
  border: none;
  box-shadow: 0 6px 24px rgba(0,0,0,.08);
}
.login-card .login-header {
  background: var(--dfic-green);
  color: #fff;
  padding: 2rem 1rem;
  text-align: center;
  border-radius: .5rem .5rem 0 0;
}

table.compact td, table.compact th { padding: .4rem .6rem; }

.attendance-row .form-check { margin-right: .75rem; }
.attendance-row .form-check-label { padding-right: 1rem; }

.status-present { color: #198754; font-weight: 600; }
.status-absent  { color: #dc3545; font-weight: 600; }
.status-late    { color: #fd7e14; font-weight: 600; }
.status-excused { color: #6f42c1; font-weight: 600; }

.role-admin   { background: #145a32; }
.role-teacher { background: #1f6feb; }
.role-parent  { background: #6f42c1; }

.quality-stars { color: var(--dfic-gold); }
