/* App shell spacing: leave room for fixed bottom nav */
body {
  padding-bottom: var(--mbs-bottom-nav-reserve, 72px);
}

/* ----------------------------
   Kilari light/dark theme (Bootstrap 5.3)
   - Uses Bootstrap's built-in [data-bs-theme="dark"] support.
   - We override core CSS variables to match Kilari brand colors.
----------------------------- */
:root {
  /* App tokens (not tied to Bootstrap) */
  --mbs-bottom-nav-reserve: 64px;

  /* Kilari extracted palette */
  --mbs-brand-primary: #ffcb05; /* yellow */
  --mbs-brand-secondary: #07295c; /* navy */
  --mbs-brand-accent: #0b2346; /* deep navy */
  --mbs-link: #3565ad; /* supporting blue */
  --mbs-highlight: #ffd600; /* underline/focus accent */
  --mbs-neutral-500: #818181;

  /* Light surfaces */
  --mbs-bg-light: #f7f8fb;
  --mbs-surface-light: #ffffff;
  --mbs-border-light: #07295c24; /* alpha navy */
  --mbs-hover-light: #07295c24;
  --mbs-active-light: rgba(255, 203, 5, 0.28);

  /* Dark surfaces */
  --mbs-bg-dark: var(--mbs-brand-accent);
  --mbs-surface-dark: var(--mbs-brand-secondary);
  --mbs-border-dark: #07295c4a; /* alpha navy */
  --mbs-hover-dark: rgba(255, 255, 255, 0.06);
  --mbs-active-dark: rgba(255, 203, 5, 0.22);

  /* Back-compat names used below (keep semantics; update values) */
  --offliner-navy-950: #06152d;
  --offliner-navy-900: var(--mbs-bg-dark);
  --offliner-navy-850: var(--mbs-surface-dark);
  --offliner-navy-800: #0e325f;
  --offliner-slate-300: #cbd5e1;
  --offliner-slate-200: #e2e8f0;
  --offliner-slate-100: #f1f5f9;
  --offliner-border: var(--mbs-border-dark);
  --offliner-primary: var(--mbs-brand-primary);
  --offliner-primary-hover: #e4b500; /* supporting gold */
  --offliner-focus: rgba(255, 203, 5, 0.45);
}

[data-bs-theme="light"] {
  --mbs-nav-hover-bg: var(--mbs-hover-light);

  /* Core surfaces */
  --bs-body-bg: var(--mbs-bg-light);
  --bs-body-color: var(--mbs-brand-accent);
  --bs-emphasis-color: var(--mbs-brand-accent);
  --bs-secondary-color: rgba(11, 35, 70, 0.72);
  --bs-tertiary-color: rgba(11, 35, 70, 0.58);

  --bs-border-color: var(--mbs-border-light);
  --bs-border-color-translucent: var(--mbs-border-light);

  /* Elevation / panels */
  --bs-secondary-bg: var(--mbs-surface-light);
  --bs-tertiary-bg: var(--mbs-surface-light);
  --bs-card-bg: var(--mbs-surface-light);
  --bs-card-cap-bg: rgba(7, 41, 92, 0.04);

  /* Brand / actions */
  --bs-primary: var(--mbs-brand-primary);
  --bs-primary-rgb: 255, 203, 5;
  --bs-link-color: var(--mbs-link);
  --bs-link-hover-color: var(--mbs-brand-secondary);

  /* Focus */
  --bs-focus-ring-color: var(--offliner-focus);

  /* Forms */
  --bs-form-control-bg: var(--mbs-surface-light);
  --bs-form-control-border-color: rgba(7, 41, 92, 0.24);
  --bs-form-control-color: var(--mbs-brand-accent);
  --bs-form-control-placeholder-color: var(--mbs-neutral-500);

  /* Lists */
  --bs-list-group-bg: var(--mbs-surface-light);
  --bs-list-group-border-color: rgba(7, 41, 92, 0.16);

  /* Pills / nav */
  --bs-nav-pills-link-active-bg: rgba(255, 203, 5, 0.28);
  --bs-nav-pills-link-active-color: var(--mbs-brand-accent);
}

[data-bs-theme="dark"] {
  --mbs-nav-hover-bg: var(--mbs-hover-dark);

  /* Core surfaces */
  --bs-body-bg: var(--offliner-navy-900);
  --bs-body-color: #ffffff;
  --bs-emphasis-color: #ffffff;
  --bs-secondary-color: rgba(255, 255, 255, 0.78);
  --bs-tertiary-color: rgba(255, 255, 255, 0.62);

  --bs-border-color: var(--offliner-border);
  --bs-border-color-translucent: var(--offliner-border);

  /* Elevation / panels */
  --bs-secondary-bg: var(--offliner-navy-850);
  --bs-tertiary-bg: var(--offliner-navy-850);
  --bs-card-bg: var(--offliner-navy-850);
  --bs-card-cap-bg: rgba(255, 255, 255, 0.02);

  /* Brand / actions */
  --bs-primary: var(--offliner-primary);
  --bs-primary-rgb: 255, 203, 5;
  --bs-link-color: var(--mbs-brand-primary);
  --bs-link-hover-color: var(--mbs-highlight);

  /* Focus */
  --bs-focus-ring-color: var(--offliner-focus);

  /* Forms */
  --bs-form-control-bg: rgba(255, 255, 255, 0.04);
  --bs-form-control-border-color: rgba(148, 163, 184, 0.32);
  --bs-form-control-color: #ffffff;
  --bs-form-control-placeholder-color: rgba(255, 255, 255, 0.58);

  /* Lists */
  --bs-list-group-bg: rgba(255, 255, 255, 0.03);
  --bs-list-group-border-color: rgba(148, 163, 184, 0.22);

  /* Pills / nav */
  --bs-nav-pills-link-active-bg: var(--mbs-active-dark);
  --bs-nav-pills-link-active-color: #ffffff;
}

/* Dark-mode icon/button contrast tweaks (icons inherit currentColor) */
[data-bs-theme="dark"] .btn-outline-secondary {
  --bs-btn-color: rgba(226, 232, 240, 0.88);
  --bs-btn-border-color: rgba(148, 163, 184, 0.32);
  --bs-btn-hover-color: rgba(226, 232, 240, 0.96);
  --bs-btn-hover-bg: rgba(255, 255, 255, 0.06);
  --bs-btn-hover-border-color: rgba(148, 163, 184, 0.5);
  --bs-btn-active-color: rgba(226, 232, 240, 0.98);
  --bs-btn-active-bg: rgba(255, 255, 255, 0.1);
  --bs-btn-active-border-color: rgba(148, 163, 184, 0.55);
}

[data-bs-theme="dark"] .btn-outline-danger {
  --bs-btn-hover-bg: rgba(220, 53, 69, 0.16);
  --bs-btn-active-bg: rgba(220, 53, 69, 0.22);
}

/* App shell polish */
.app-header {
  background: var(--bs-tertiary-bg);
  backdrop-filter: blur(8px);
}

.bottom-nav {
  background: var(--bs-tertiary-bg);
  /* Bootstrap navbar sizing vars */
  --bs-navbar-padding-y: 0.25rem;
  --bs-navbar-padding-x: 0.5rem;
}

.bottom-nav > .container-fluid {
  padding-left: 0.5rem;
  padding-right: 0.5rem;
}

.bottom-nav .nav {
  gap: 0.25rem !important; /* override Bootstrap gap-* utilities */
}

.bottom-nav .nav-link {
  border: 1px solid transparent;
  --bs-nav-link-padding-y: 0.2rem;
  --bs-nav-link-padding-x: 0.4rem;
  line-height: 1.1;
  font-size: 0.85rem;
  white-space: nowrap;
}

/* The markup uses <span class="small fw-semibold"> — make that smaller in bottom nav only. */
.bottom-nav .nav-link .small {
  font-size: 0.78rem;
}

.bottom-nav .nav-link:hover {
  background: var(--mbs-nav-hover-bg);
}

.bottom-nav .nav-link.active {
  background: var(--bs-nav-pills-link-active-bg);
  color: var(--bs-nav-pills-link-active-color);
  border-color: rgba(255, 203, 5, 0.38);
}

/* Ensure badges used in the sync widget look good in dark mode */
[data-bs-theme="dark"] .sync-widget .badge.text-bg-light {
  background: rgba(255, 255, 255, 0.06) !important;
  color: rgba(226, 232, 240, 0.9) !important;
  border-color: rgba(148, 163, 184, 0.24) !important;
}

/* Visible, consistent focus without being loud */
:focus-visible {
  outline: none;
  box-shadow: 0 0 0 0.25rem var(--bs-focus-ring-color);
}

/* Make list rows feel clickable without changing layout */
.list-group-item {
  background-color: var(--bs-list-group-bg);
  border-color: var(--bs-list-group-border-color);
}

.list-group-item:hover {
  filter: brightness(1.05);
}

/* Minimal inline actions inside list rows */
.list-group-item .btn.btn-link {
  padding: 0.25rem 0.5rem;
  text-decoration: none;
}

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

/* Tables: make row dividers visible in dark mode */
[data-bs-theme="dark"] .table {
  --bs-table-color: var(--bs-body-color);
  --bs-table-bg: transparent;
  --bs-table-border-color: rgba(255, 255, 255, 0.14);
  --bs-table-striped-bg: rgba(255, 255, 255, 0.03);
  --bs-table-hover-bg: rgba(255, 255, 255, 0.045);
}

[data-bs-theme="dark"] .table > :not(caption) > * > * {
  border-bottom-color: var(--bs-table-border-color);
}

[data-bs-theme="dark"] .table thead th {
  border-bottom-color: rgba(255, 255, 255, 0.24);
}

/* Icon buttons */
.btn-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  line-height: 1;
}

.icon {
  width: 1em;
  height: 1em;
  fill: currentColor; /* critical: bootstrap-icons sprite paths have no fill attr */
}

/* Map Bootstrap primary buttons to Kilari brand (Bootstrap defaults hardcode colors). */
[data-bs-theme="light"] .btn-primary,
[data-bs-theme="dark"] .btn-primary {
  --bs-btn-bg: var(--mbs-brand-primary);
  --bs-btn-border-color: var(--mbs-brand-primary);
  --bs-btn-color: var(--mbs-brand-accent);
  --bs-btn-hover-bg: #e4b500;
  --bs-btn-hover-border-color: #e4b500;
  --bs-btn-hover-color: var(--mbs-brand-accent);
  --bs-btn-active-bg: #d6a900;
  --bs-btn-active-border-color: #d6a900;
  --bs-btn-active-color: var(--mbs-brand-accent);
  --bs-btn-focus-shadow-rgb: 255, 203, 5;
}

[data-bs-theme="light"] .btn-outline-primary,
[data-bs-theme="dark"] .btn-outline-primary {
  --bs-btn-color: var(--mbs-brand-primary);
  --bs-btn-border-color: rgba(255, 203, 5, 0.75);
  --bs-btn-hover-bg: rgba(255, 203, 5, 0.16);
  --bs-btn-hover-border-color: rgba(255, 203, 5, 0.85);
  --bs-btn-hover-color: #ffffff;
  --bs-btn-active-bg: rgba(255, 203, 5, 0.22);
  --bs-btn-active-border-color: rgba(255, 203, 5, 0.9);
}

[data-bs-theme="light"] .btn-outline-primary {
  --bs-btn-hover-color: var(--mbs-brand-accent);
}

[data-bs-theme="dark"] .btn-outline-primary {
  --bs-btn-hover-color: #ffffff;
}

/* Dark-mode form contrast: make borders/background clearly visible on navy surfaces. */
[data-bs-theme="dark"] {
  --bs-form-control-bg: rgba(255, 255, 255, 0.06);
  --bs-form-control-border-color: rgba(255, 255, 255, 0.24);
  --bs-form-control-focus-border-color: rgba(255, 203, 5, 0.75);
  --bs-form-control-focus-box-shadow: 0 0 0 0.25rem rgba(255, 203, 5, 0.22);

  --bs-form-select-bg: rgba(255, 255, 255, 0.06);
  --bs-form-select-border-color: rgba(255, 255, 255, 0.24);
  --bs-form-select-focus-border-color: rgba(255, 203, 5, 0.75);
  --bs-form-select-focus-box-shadow: 0 0 0 0.25rem rgba(255, 203, 5, 0.22);
}

[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] .form-select {
  background-color: var(--bs-form-control-bg);
  border-color: var(--bs-form-control-border-color);
}

[data-bs-theme="dark"] .form-control::placeholder {
  color: rgba(255, 255, 255, 0.6);
}

[data-bs-theme="dark"] .form-control:focus,
[data-bs-theme="dark"] .form-select:focus {
  border-color: var(--bs-form-control-focus-border-color);
  box-shadow: var(--bs-form-control-focus-box-shadow);
}

@media (prefers-reduced-motion: no-preference) {
  .icon.spin {
    animation: icon-spin 900ms linear infinite;
  }
}

@keyframes icon-spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* Compact baseline: denser but readable. */
body.compact {
  font-size: 0.95rem;
}

/* Compact defaults (opt-in by class hooks in markup when needed). */
.compact .card-body {
  padding: 0.75rem;
}

.compact .list-group-item {
  padding-top: 0.6rem;
  padding-bottom: 0.6rem;
}

/* Prevent awkward button text wrapping on small widths. */
.btn {
  white-space: nowrap;
}

/* Offline indicator */
.offline-indicator .badge {
  font-weight: 600;
}

/* Sync widget alignment */
.sync-widget {
  font-variant-numeric: tabular-nums;
}

/* Prevent sync widget from changing height (no layout shift). */
.sync-widget .sync-row {
  min-height: 44px; /* keep header height stable on state changes */
}

.sync-widget .sync-error {
  max-width: 40vw;
}

/* Bottom nav polish */
.bottom-nav .nav-link {
  border-radius: 999px;
}

/* Dropup menu inside fixed bottom nav */
.bottom-nav .bottom-nav-dropup-menu {
  max-width: min(92vw, 22rem);
  margin-bottom: 0.25rem; /* smaller gap between menu and pill */
}

/* Fast, subtle transitions (purposeful only). */
@media (prefers-reduced-motion: no-preference) {
  .fade-fast {
    transition: opacity 120ms ease, transform 120ms ease;
    will-change: opacity, transform;
  }
}

/* Touch target helper */
.touch-target {
  min-height: 44px;
}

/* Bottom nav: slightly denser while still tappable */
.bottom-nav .touch-target {
  min-height: 40px;
}

/* Utility */
.btn-nowrap {
  white-space: nowrap;
}

/* ----------------------------
   Datepicker (vanillajs-datepicker) theme alignment
   - We use the Bootstrap 5 stylesheet, then fine-tune dark mode to match our navy palette.
----------------------------- */
[data-bs-theme="dark"] .datepicker .datepicker-picker {
  background-color: var(--bs-tertiary-bg);
  color: var(--bs-body-color);
  border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .datepicker .datepicker-picker .datepicker-header,
[data-bs-theme="dark"] .datepicker .datepicker-picker .datepicker-footer {
  background-color: transparent;
  border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .datepicker .datepicker-picker .datepicker-cell {
  color: var(--bs-body-color);
}

[data-bs-theme="dark"] .datepicker .datepicker-picker .datepicker-cell:hover {
  background-color: rgba(255, 255, 255, 0.06);
}

[data-bs-theme="dark"] .datepicker .datepicker-picker .datepicker-cell.selected,
[data-bs-theme="dark"] .datepicker .datepicker-picker .datepicker-cell.selected:hover {
  background-color: rgba(255, 203, 5, 0.25);
  color: var(--bs-body-color);
}

[data-bs-theme="dark"] .datepicker .datepicker-picker .datepicker-cell.today:not(.selected) {
  outline: 1px solid rgba(255, 203, 5, 0.58);
  outline-offset: -2px;
}

