/*
 * Bootstrap Theme Overrides
 * Loaded after bootstrap.css to customize the default theme.
 */

:root,
[data-bs-theme="light"] {
  /* ── Primary palette ──────────────────────────────────────────── */
  --bs-primary: #1e40af;
  --bs-primary-rgb: 30, 64, 175;
  --bs-primary-bg-subtle: #eff6ff;
  --bs-primary-border-subtle: #bfdbfe;
  --bs-primary-text-emphasis: #1e3a8a;

  /* ── Semantic colors ──────────────────────────────────────────── */
  --bs-info: #60a5fa;
  --bs-info-rgb: 96, 165, 250;
  --bs-info-bg-subtle: #eff6ff;

  --bs-success: #16a34a;
  --bs-success-rgb: 22, 163, 74;
  --bs-success-bg-subtle: #dcfce7;
  --bs-success-text-emphasis: #166534;
  --bs-success-border-subtle: #bbf7d0;

  --bs-warning: #d97706;
  --bs-warning-rgb: 217, 119, 6;
  --bs-warning-bg-subtle: #fef3c7;
  --bs-warning-text-emphasis: #92400e;
  --bs-warning-border-subtle: #fde68a;

  --bs-danger: #dc2626;
  --bs-danger-rgb: 220, 38, 38;
  --bs-danger-bg-subtle: #fee2e2;

  --bs-secondary: #64748b;
  --bs-secondary-rgb: 100, 116, 139;
  --bs-secondary-color: #64748b;

  /* ── Body & typography ─────────────────────────────────────────── */
  --bs-body-color: #0f172a;
  --bs-body-color-rgb: 15, 23, 42;
  --bs-body-font-family:
    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica,
    Arial, sans-serif;

  /* ── Surfaces ──────────────────────────────────────────────────── */
  --bs-light: #f8fafc;
  --bs-light-rgb: 248, 250, 252;
  --bs-tertiary-bg: #f8fafc;
  --bs-tertiary-bg-rgb: 248, 250, 252;

  /* ── Borders & radius ──────────────────────────────────────────── */
  --bs-border-color: #e2e8f0;
  --bs-border-radius: 0.625rem;
  --bs-border-radius-lg: 0.75rem;

  /* ── Links ────────────────────────────────────────────────────── */
  --bs-link-color-rgb: var(--bs-primary-rgb);
  --bs-link-hover-color-rgb: 30, 58, 138;

  /* ── Focus ring ─────────────────────────────────────────────────── */
  --bs-focus-ring-color: rgba(var(--bs-primary-rgb), 0.25);

  /* ── Shadows ───────────────────────────────────────────────────── */
  --bs-box-shadow-sm:
    0 1px 3px rgba(0, 0, 0, 0.06), 0 1px 2px rgba(0, 0, 0, 0.04);
  --bs-box-shadow:
    0 4px 12px rgba(0, 0, 0, 0.08), 0 2px 4px rgba(0, 0, 0, 0.04);
  --bs-box-shadow-lg: 0 4px 24px rgba(0, 0, 0, 0.08);
}

/* ── Font smoothing (no BS variable) ─────────────────────────────── */
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ── Component overrides ─────────────────────────────────────────── */

/*
 * Bootstrap 5.3 compiles component colors from Sass — overriding
 * --bs-primary on :root does NOT cascade into .btn-primary, etc.
 * Each component must be re-pointed to our palette explicitly.
 */

.btn-primary {
  --bs-btn-bg: var(--bs-primary);
  --bs-btn-border-color: var(--bs-primary);
  --bs-btn-hover-bg: var(--bs-primary-text-emphasis);
  --bs-btn-hover-border-color: var(--bs-primary-text-emphasis);
  --bs-btn-active-bg: var(--bs-primary-text-emphasis);
  --bs-btn-active-border-color: #172554;
  --bs-btn-disabled-bg: var(--bs-primary);
  --bs-btn-disabled-border-color: var(--bs-primary);
}

.btn-danger {
  --bs-btn-bg: var(--bs-danger);
  --bs-btn-border-color: var(--bs-danger);
  --bs-btn-hover-bg: #b91c1c;
  --bs-btn-hover-border-color: #b91c1c;
  --bs-btn-active-bg: #991b1b;
  --bs-btn-active-border-color: #991b1b;
  --bs-btn-disabled-bg: var(--bs-danger);
  --bs-btn-disabled-border-color: var(--bs-danger);
}

.btn-warning {
  --bs-btn-bg: var(--bs-warning);
  --bs-btn-border-color: var(--bs-warning);
  --bs-btn-hover-bg: #b45309;
  --bs-btn-hover-border-color: #b45309;
  --bs-btn-active-bg: var(--bs-warning-text-emphasis);
  --bs-btn-active-border-color: var(--bs-warning-text-emphasis);
  --bs-btn-disabled-bg: var(--bs-warning);
  --bs-btn-disabled-border-color: var(--bs-warning);
}

.btn-outline-primary {
  --bs-btn-color: var(--bs-primary);
  --bs-btn-border-color: var(--bs-primary);
  --bs-btn-hover-bg: var(--bs-primary);
  --bs-btn-hover-border-color: var(--bs-primary);
  --bs-btn-active-bg: var(--bs-primary);
  --bs-btn-active-border-color: var(--bs-primary);
}

.btn-outline-danger {
  --bs-btn-color: var(--bs-danger);
  --bs-btn-border-color: var(--bs-danger);
  --bs-btn-hover-bg: var(--bs-danger);
  --bs-btn-hover-border-color: var(--bs-danger);
  --bs-btn-active-bg: #b91c1c;
  --bs-btn-active-border-color: #b91c1c;
}

.btn-outline-secondary {
  --bs-btn-color: var(--bs-secondary);
  --bs-btn-border-color: var(--bs-secondary);
  --bs-btn-hover-bg: var(--bs-secondary);
  --bs-btn-hover-border-color: var(--bs-secondary);
  --bs-btn-active-bg: #475569;
  --bs-btn-active-border-color: #475569;
}

.btn-outline-warning {
  --bs-btn-color: var(--bs-warning);
  --bs-btn-border-color: var(--bs-warning);
  --bs-btn-hover-bg: var(--bs-warning);
  --bs-btn-hover-border-color: var(--bs-warning);
  --bs-btn-active-bg: #b45309;
  --bs-btn-active-border-color: #b45309;
}

.btn-link {
  --bs-btn-color: var(--bs-primary);
  --bs-btn-hover-color: var(--bs-primary-text-emphasis);
  text-decoration: none;
}

.btn-link:hover {
  text-decoration: underline;
}

/* ── Back Link ───────────────────────────────────────────────────── */
.back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.625rem;
  color: var(--bs-secondary-color);
  font-weight: 500;
  font-size: 0.95rem;
  transition: color 0.2s ease;
}

.back-link-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background-color: var(--bs-tertiary-bg);
  border: 1px solid var(--bs-border-color);
  color: var(--bs-secondary-color);
  transition: all 0.2s ease;
}

.back-link-icon i {
  font-size: 0.875rem;
  transition: color 0.2s ease;
}

.back-link:hover {
  color: var(--bs-body-color);
}

.back-link:hover .back-link-icon {
  background-color: rgba(var(--bs-primary-rgb), 0.06);
  border-color: rgba(var(--bs-primary-rgb), 0.2);
  color: var(--bs-primary);
  box-shadow: 0 2px 4px rgba(var(--bs-primary-rgb), 0.08);
}

.back-link:hover .back-link-icon i {
  color: var(--bs-primary);
}

.btn-soft-primary {
  --bs-btn-color: rgba(var(--bs-primary-rgb), 0.75);
  --bs-btn-bg: rgba(var(--bs-primary-rgb), 0.03);
  --bs-btn-border-color: rgba(var(--bs-primary-rgb), 0.1);
  --bs-btn-hover-color: rgba(var(--bs-primary-rgb), 0.9);
  --bs-btn-hover-bg: rgba(var(--bs-primary-rgb), 0.08);
  --bs-btn-hover-border-color: rgba(var(--bs-primary-rgb), 0.2);
  --bs-btn-active-color: var(--bs-primary-text-emphasis);
  --bs-btn-active-bg: rgba(var(--bs-primary-rgb), 0.12);
  --bs-btn-active-border-color: rgba(var(--bs-primary-rgb), 0.3);
}

.btn-soft-secondary {
  --bs-btn-color: rgba(var(--bs-secondary-rgb), 0.75);
  --bs-btn-bg: rgba(var(--bs-secondary-rgb), 0.03);
  --bs-btn-border-color: rgba(var(--bs-secondary-rgb), 0.12);
  --bs-btn-hover-color: var(--bs-secondary);
  --bs-btn-hover-bg: rgba(var(--bs-secondary-rgb), 0.08);
  --bs-btn-hover-border-color: rgba(var(--bs-secondary-rgb), 0.22);
  --bs-btn-active-color: var(--bs-body-color);
  --bs-btn-active-bg: rgba(var(--bs-secondary-rgb), 0.12);
  --bs-btn-active-border-color: rgba(var(--bs-secondary-rgb), 0.32);
}

.btn-soft-danger {
  --bs-btn-color: rgba(var(--bs-danger-rgb), 0.75);
  --bs-btn-bg: rgba(var(--bs-danger-rgb), 0.03);
  --bs-btn-border-color: rgba(var(--bs-danger-rgb), 0.1);
  --bs-btn-hover-color: rgba(var(--bs-danger-rgb), 0.9);
  --bs-btn-hover-bg: rgba(var(--bs-danger-rgb), 0.08);
  --bs-btn-hover-border-color: rgba(var(--bs-danger-rgb), 0.2);
  --bs-btn-active-color: #b91c1c;
  --bs-btn-active-bg: rgba(var(--bs-danger-rgb), 0.12);
  --bs-btn-active-border-color: rgba(var(--bs-danger-rgb), 0.3);
}

.text-primary {
  color: var(--bs-primary) !important;
}

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

.form-check-input:checked {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
}

.card {
  border: 1px solid var(--bs-border-color);
  border-radius: var(--bs-border-radius-lg);
  background: var(--bs-white);
  box-shadow: none;
  transition:
    box-shadow 0.2s ease,
    border-color 0.2s ease,
    transform 0.2s ease;
}

a.card:hover,
button.card:hover,
.card.hoverable:hover {
  box-shadow: var(--bs-box-shadow-sm);
  border-color: #cbd5e1;
}

.form-control:focus,
.form-select:focus {
  border-color: #3b82f6;
  box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.15);
}

/* ── Utilities ────────────────────────────────────────────────────── */
.text-muted-sm {
  color: var(--bs-secondary-color);
  font-size: 0.8rem;
}

/* ── Badge ───────────────────────────────────────────────────────── */
.badge {
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.01em;
}

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

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

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

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

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

/* ── Alert ───────────────────────────────────────────────────────── */
.alert {
  border-radius: var(--bs-border-radius);
  padding: 0.875rem 1rem;
  display: flex;
  align-items: center;
  gap: 0.625rem;
  font-weight: 500;
  font-size: 0.9rem;
  border: 1px solid transparent;
}

.alert-success {
  background-color: var(--bs-success-bg-subtle);
  color: var(--bs-success-text-emphasis);
  border-color: var(--bs-success-border-subtle);
}

.alert-warning {
  background-color: var(--bs-warning-bg-subtle);
  color: var(--bs-warning-text-emphasis);
  border-color: var(--bs-warning-border-subtle);
}

.alert-danger {
  background-color: var(--bs-danger-bg-subtle);
  color: var(--bs-danger-text-emphasis);
  border-color: var(--bs-danger-border-subtle);
}

.alert-info {
  background-color: var(--bs-info-bg-subtle);
  color: var(--bs-info-text-emphasis);
  border-color: var(--bs-info-border-subtle);
}

/* ── Dropdown ────────────────────────────────────────────────────── */
.dropdown-menu {
  border-radius: var(--bs-border-radius-lg);
  box-shadow: var(--bs-box-shadow);
  border: 1px solid var(--bs-border-color);
  padding: 0.5rem;
}

.dropdown-item {
  border-radius: var(--bs-border-radius);
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  transition:
    background-color 0.15s ease,
    color 0.15s ease;
}

.dropdown-item:hover,
.dropdown-item:focus {
  background-color: var(--bs-tertiary-bg);
}

/* ── Buttons ─────────────────────────────────────────────────────── */
.btn {
  font-weight: 500;
  transition: all 0.15s ease;
}

/* ── Forms ───────────────────────────────────────────────────────── */
.form-control {
  border-radius: var(--bs-border-radius);
  border: 1px solid var(--bs-border-color);
  padding: 0.375rem 0.75rem !important;
  font-size: 0.95rem;
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}

.form-select {
  border-radius: var(--bs-border-radius);
  border: 1px solid var(--bs-border-color);
  font-size: 0.95rem;
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}

.form-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--bs-secondary-color);
  margin-bottom: 0.375rem;
}

/* ── Typography ──────────────────────────────────────────────────── */
h1,
.h1 {
  font-weight: 700;
  letter-spacing: -0.02em;
}
h2,
.h2 {
  font-weight: 600;
  letter-spacing: -0.01em;
}
h3,
.h3 {
  font-weight: 600;
}
h4,
.h4 {
  font-weight: 600;
}
h5,
.h5 {
  font-weight: 600;
}
h6,
.h6 {
  font-weight: 600;
}

/* ── Tables ──────────────────────────────────────────────────────── */
.table {
  font-size: 0.95rem;
}

.table th {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--bs-secondary-color);
  border-bottom-width: 1px;
}

.table td {
  vertical-align: middle;
}

/* ── Utility classes ─────────────────────────────────────────────── */
.content-constrained {
  max-width: 82.5rem;
  margin-inline: auto;
}

.content-narrow {
  max-width: 62rem;
  margin-inline: auto;
}

.container-narrow {
  max-width: 48rem;
  margin-inline: auto;
}

[x-cloak] {
  display: none !important;
}

summary {
  cursor: pointer;
}

.mw-24 {
  max-width: 24rem;
}

.transition-transform {
  transition: transform 0.15s;
}

/* ── Modal spinner overlay ───────────────────────────────────────── */
.spinner-overlay {
  position: absolute;
  inset: 0;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.85);
  border-radius: var(--bs-border-radius);
}

/* ── Tabs ───────────────────────────────────────── */
.nav-tabs .nav-link {
  color: var(--bs-secondary-color);
}

.nav-tabs .nav-link.active {
  color: var(--bs-body-color);
  font-weight: 600;
}
