:root {
  --cr-primary: #17a2b8;
  --cr-dark: #343a40;
  --cr-light: #f8f9fa;
}

html[data-bs-theme="dark"] {
  color-scheme: dark;
}

.loading-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--bs-body-bg, rgba(255, 255, 255, 0.95));
  z-index: 1050;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  transition: background 0.3s;
}

.loading-overlay .spinner-border {
  color: var(--cr-primary) !important;
}

.loading-overlay p {
  color: var(--bs-body-color, #343a40);
}

.card {
  transition: transform 0.2s, box-shadow 0.2s;
  border-radius: 12px;
  overflow: hidden;
}

.card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.3) !important;
}

.member-card a,
.low-points-table a,
.warning-table a,
.card a {
  text-decoration: none;
  color: inherit !important;
}

.card:hover a,
.member-card:hover a,
.low-points-table a:hover,
.warning-table a:hover {
  color: var(--bs-primary) !important;
}

.card-header {
  padding: 0.75rem 1rem;
  font-size: 0.95rem;
}

.card-danger-border {
  border: 2px solid var(--bs-danger);
}

.card-success-border {
  border: 2px solid var(--bs-success);
}

.card-war-active {
  border: 2px solid var(--cr-primary);
}

.card-war-active .card-header {
  background-color: var(--cr-primary) !important;
  color: white !important;
}

.card-war-inactive {
  opacity: 0.85;
  border: 1px solid var(--bs-secondary-bg);
}

.card-war-inactive .card-header {
  background-color: var(--bs-secondary-bg);
  color: var(--bs-body-color);
}

[data-bs-theme="dark"] .card-war-inactive {
  border-color: #333;
}
[data-bs-theme="dark"] .card-war-inactive .card-header {
  background-color: #222;
  color: var(--bs-body-color);
}

.detail-card {
  border-radius: 12px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  transition: box-shadow 0.3s;
  background-color: var(--bs-body-bg, #ffffff);
  border: 1px solid var(--bs-border-color);
}

.detail-card:hover {
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2);
}

[data-bs-theme="dark"] .detail-card,
[data-bs-theme="dark"] .member-history-card {
  background-color: var(--bs-table-bg);
  border-color: var(--bs-table-border-color);
}

.stat-large {
  font-size: 3rem;
  font-weight: 900;
  line-height: 1.2;
}

.war-warning {
  color: var(--bs-danger);
}
.war-success {
  color: var(--bs-success);
}

.history-table thead th {
  border-bottom: 3px solid var(--cr-primary);
}

.low-points-table thead th {
  border-bottom: 2px solid var(--cr-primary);
  padding-bottom: 0.5rem;
  font-size: 0.85rem;
  text-transform: uppercase;
}

.low-points-table tbody tr td {
  border: none;
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}

.low-points-table tbody tr:last-child td {
  border-bottom: none;
}

[data-bs-theme="dark"] #rezagados-summary {
  background-color: var(--bs-table-bg) !important;
  border: 1px solid var(--bs-table-border-color);
}

.bg-danger-subtle {
  background-color: var(--bs-danger-bg-subtle) !important;
}

.badge.bg-primary-subtle {
  background-color: var(--bs-primary-bg-subtle) !important;
  color: var(--bs-primary) !important;
}

.badge.bg-warning-subtle {
  background-color: var(--bs-warning-bg-subtle) !important;
  color: var(--bs-warning) !important;
}

.badge.bg-danger-subtle {
  background-color: var(--bs-danger-bg-subtle) !important;
  color: var(--bs-danger) !important;
}

.accordion-button:not(.collapsed) {
  background-color: var(--bs-primary-bg-subtle) !important;
  color: var(--bs-primary) !important;
  border-bottom: 1px solid var(--bs-primary-border-subtle) !important;
}

.accordion-collapse {
  border: none;
}
.accordion-body {
  background-color: var(--bs-body-bg) !important;
}

.history-entry-card {
  transition: transform 0.2s, box-shadow 0.2s;
}

.history-entry-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important;
}

.card.border-success {
  border-color: var(--bs-success) !important;
}
.card.border-warning {
  border-color: var(--bs-warning) !important;
}
.card.border-danger {
  border-color: var(--bs-danger) !important;
}

.history-entry-card .card-header {
  background-color: transparent !important;
  border-bottom: 1px solid var(--bs-border-color-translucent);
}
