/* Yara-inspired theme overrides for Bootstrap components */
/* Palette (approx): Yara Blue #003C71, Accent #00A0DF, Dark #00264D, Light #E6F2F8, Success #2E8540 */

:root {
  --yara-blue: #003C71;
  --yara-blue-dark: #00264D;
  --yara-accent: #00A0DF;
  --yara-accent-dark: #0089bd;
  --yara-light: #E6F2F8;
  --yara-success: #2E8540;
}

body {
  background-color: #f7fafc;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Navbar */
.navbar.bg-primary {
  background-color: var(--yara-blue) !important;
}
.navbar .navbar-brand .brand-text { font-weight: 600; letter-spacing: .2px; }

/* Primary buttons & states */
.btn-primary {
  color: #fff;
  background-color: var(--yara-blue);
  border-color: var(--yara-blue);
}
.btn-primary:hover { background-color: var(--yara-blue-dark); border-color: var(--yara-blue-dark); }
.btn-outline-primary {
  color: var(--yara-blue);
  border-color: var(--yara-blue);
}
.btn-outline-primary:hover { background-color: var(--yara-blue); color: #fff; }

/* Links */
.link-primary, a { color: var(--yara-accent); }
.link-primary:hover, a:hover { color: var(--yara-accent-dark); }

/* Text and backgrounds */
.text-primary { color: var(--yara-blue) !important; }
.bg-primary { background-color: var(--yara-blue) !important; }
.bg-light { background-color: #f4f8fb !important; }

/* Badges */
.badge.bg-primary { background-color: var(--yara-blue) !important; }
.badge.bg-info { background-color: var(--yara-accent) !important; }

/* Cards */
.card { border: 1px solid #e6eef5; border-radius: .6rem; }
.card .card-header { background-color: var(--yara-light); border-bottom-color: #dde9f1; font-weight: 600; }

/* Forms */
.form-control:focus, .form-select:focus {
  border-color: var(--yara-accent);
  box-shadow: 0 0 0 .2rem rgba(0,160,223,.15);
}
.form-label { font-weight: 600; color: #22313f; }

/* Table */
.table thead th { background-color: var(--yara-light); border-bottom-color: #dde9f1; }
.table-hover tbody tr:hover { background-color: #f0f7fb; }

/* Pagination */
.page-link { color: var(--yara-blue); }
.page-item.active .page-link { background-color: var(--yara-blue); border-color: var(--yara-blue); }

/* Alerts */
.alert-primary { background-color: #e3eef7; color: var(--yara-blue); border-color: #cfe3f1; }
.alert-success { background-color: #e6f4ea; color: var(--yara-success); border-color: #cfe8d6; }

/* Buttons: accent variant for secondary actions */
.btn-accent { background-color: var(--yara-accent); color: #fff; border-color: var(--yara-accent); }
.btn-accent:hover { background-color: var(--yara-accent-dark); border-color: var(--yara-accent-dark); }

/* Utility ribbons/badges */
.badge-soft-primary { color: var(--yara-blue); background-color: rgba(0,60,113,.1); border: 1px solid rgba(0,60,113,.18); }
.badge-soft-accent { color: var(--yara-accent); background-color: rgba(0,160,223,.12); border: 1px solid rgba(0,160,223,.22); }

/* Mobile utilities */
@media (max-width: 576px) {
  /* Larger tap targets */
  .btn,
  .form-control,
  .form-select { min-height: 44px; }
  .btn.btn-sm { min-height: 40px; }
  .input-group > .btn,
  .input-group > .form-control,
  .input-group > .form-select { min-height: 44px; }

  /* Horizontal scroll for long navs/pills */
  .nav.nav-pills,
  .nav.nav-tabs { flex-wrap: nowrap; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .nav.nav-pills .nav-item,
  .nav.nav-tabs .nav-item { white-space: nowrap; }

  /* Optional: stacked table helper for legacy tables */
  .table.table-stacked-xs thead { display: none; }
  .table.table-stacked-xs tbody tr { display: block; margin-bottom: .75rem; border: 1px solid #e6eef5; border-radius: .5rem; background: #fff; }
  .table.table-stacked-xs tbody tr td { display: flex; justify-content: space-between; gap: .75rem; padding: .5rem .75rem; border: 0; }
  .table.table-stacked-xs tbody tr td::before {
    content: attr(data-th);
    font-weight: 600;
    color: #6c757d;
  }
}
