/* ===========================================================================
   OpsTrak by ReaperNetworks — shared stylesheet
   Bootstrap 5 supplies the base; this layers platform identity, the Central
   Hub tiles, and print rules. Theming uses Bootstrap's data-bs-theme.
   =========================================================================== */

:root {
  --ems-brand: #1f4e79;
  --ems-accent: #2e75b6;
}

body {
  min-height: 100vh;
}

/* Brand color helpers */
.text-brand { color: var(--ems-brand) !important; }
.bg-brand { background-color: var(--ems-brand) !important; }
.btn-brand {
  background-color: var(--ems-brand);
  border-color: var(--ems-brand);
  color: #fff;
}
.btn-brand:hover { background-color: #173a5c; border-color: #173a5c; color: #fff; }

.navbar-logo { max-height: 36px; width: auto; }

/* ---- Central Hub module tiles -------------------------------------------- */
.hub-tile {
  display: block;
  height: 100%;
  text-decoration: none;
  transition: transform .12s ease, box-shadow .12s ease;
}
.hub-tile:hover {
  transform: translateY(-3px);
}
.hub-tile .card {
  height: 100%;
}
.hub-tile .hub-icon {
  font-size: 2.5rem;
  line-height: 1;
  color: var(--ems-accent);
}

/* ---- Welcome dashboard ---------------------------------------------------- */
.hub-hero {
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--ems-accent) 16%, var(--bs-body-bg)),
    var(--bs-body-bg) 70%);
}
.hub-stat {
  transition: transform .12s ease, box-shadow .12s ease;
}
.hub-stat:hover {
  transform: translateY(-3px);
  box-shadow: 0 .5rem 1rem rgba(0,0,0,.12) !important;
}
.hub-stat-icon {
  width: 2.75rem;
  height: 2.75rem;
  border-radius: .65rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  flex: 0 0 auto;
}
.hub-tile .hub-tile-arrow {
  opacity: 0;
  transition: opacity .12s ease, transform .12s ease;
  vertical-align: -2px;
}
.hub-tile:hover .hub-tile-arrow {
  opacity: 1;
  transform: translateX(2px);
}

/* Coming-soon preview tiles (non-clickable roadmap) */
.hub-soon { opacity: .7; }
.hub-soon .hub-icon-muted {
  font-size: 2.5rem;
  line-height: 1;
  color: var(--bs-secondary-color);
}

/* Notification + announcement accents */
.announcement-item { border-left: 4px solid var(--ems-accent); }

/* ---- Logout warning modal ------------------------------------------------- */
#idleWarningModal .modal-content { border: 2px solid var(--bs-warning); }

/* ---- Print styles --------------------------------------------------------- */
@media print {
  nav.navbar, footer, .btn, .js-print, .no-print,
  .dropdown, #idleWarningModal {
    display: none !important;
  }
  :root, html[data-bs-theme="dark"], [data-bs-theme="dark"] {
    --bs-body-bg: #ffffff !important;
    --bs-body-color: #000000 !important;
    --bs-card-bg: #ffffff !important;
    --bs-tertiary-bg: #ffffff !important;
    --bs-border-color: #cccccc !important;
    color-scheme: light !important;
  }
  html, body, main, .container, .card, .card-body, .card-header {
    background: #ffffff !important;
    color: #000000 !important;
    box-shadow: none !important;
  }
  .card { border: 0 !important; }
  * { -webkit-print-color-adjust: exact !important; print-color-adjust: exact !important; }
  .print-title { display: block !important; }
}
.print-title { display: none; }

/* ---- FleetTrak Kanban board ---------------------------------------------- */
.ft-kanban {
  display: flex;
  gap: .75rem;
  overflow-x: auto;
  padding-bottom: .5rem;
}
.ft-kan-col {
  flex: 0 0 240px;
  min-width: 240px;
  background: var(--bs-tertiary-bg);
  border-radius: .5rem;
  display: flex;
  flex-direction: column;
}
.ft-kan-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .5rem .65rem;
  border-bottom: 1px solid var(--bs-border-color);
}
.ft-kan-body {
  padding: .5rem;
  min-height: 60px;
  flex: 1 1 auto;
  transition: background .12s ease;
}
.ft-kan-body.over { background: color-mix(in srgb, var(--ems-accent) 14%, transparent); }
.ft-kan-card {
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color);
  border-radius: .45rem;
  padding: .5rem .6rem;
  margin-bottom: .5rem;
  cursor: grab;
  box-shadow: 0 1px 2px rgba(0,0,0,.05);
}
.ft-kan-card:last-child { margin-bottom: 0; }
.ft-kan-card.dragging { opacity: .5; }
.ft-kan-card[draggable="false"] { cursor: default; }

/* ---- Hub birthday banner -------------------------------------------------- */
.hub-birthday {
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--bs-warning) 18%, var(--bs-body-bg)),
    var(--bs-body-bg) 75%);
  border-left: 4px solid var(--bs-warning) !important;
}

/* ---- FacilityTrak Kanban board ------------------------------------------- */
.fac-kanban { display: flex; gap: .75rem; overflow-x: auto; padding-bottom: .5rem; }
.fac-kan-col { flex: 0 0 230px; min-width: 230px; background: var(--bs-tertiary-bg); border-radius: .5rem; display: flex; flex-direction: column; }
.fac-kan-head { display: flex; justify-content: space-between; align-items: center; padding: .5rem .65rem; border-bottom: 1px solid var(--bs-border-color); }
.fac-kan-body { padding: .5rem; min-height: 60px; flex: 1 1 auto; transition: background .12s ease; }
.fac-kan-body.over { background: color-mix(in srgb, var(--ems-accent) 14%, transparent); }
.fac-kan-card { background: var(--bs-body-bg); border: 1px solid var(--bs-border-color); border-radius: .45rem; padding: .5rem .6rem; margin-bottom: .5rem; cursor: grab; box-shadow: 0 1px 2px rgba(0,0,0,.05); }
.fac-kan-card:last-child { margin-bottom: 0; }
.fac-kan-card.dragging { opacity: .5; }
.fac-kan-card[draggable="false"] { cursor: default; }

/* ---- FacilityTrak calendar ----------------------------------------------- */
.fac-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.fac-cal-dow { text-align: center; font-size: .75rem; font-weight: 600; color: var(--bs-secondary-color); padding: 4px 0; }
.fac-cal-cell { min-height: 92px; border: 1px solid var(--bs-border-color); border-radius: .4rem; padding: 3px 4px; background: var(--bs-body-bg); overflow: hidden; }
.fac-cal-empty { background: transparent; border: none; }
.fac-cal-today { border-color: var(--ems-accent); box-shadow: inset 0 0 0 1px var(--ems-accent); }
.fac-cal-day { font-size: .8rem; font-weight: 600; color: var(--bs-secondary-color); margin-bottom: 2px; }
.fac-cal-event { display: block; font-size: .68rem; line-height: 1.2; padding: 1px 4px; border-radius: 3px; margin-bottom: 2px; text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ---- EventTrak calendar --------------------------------------------------- */
.et-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.et-cal-dow { text-align: center; font-size: .75rem; font-weight: 600; color: var(--bs-secondary-color); padding: 4px 0; }
.et-cal-cell { min-height: 96px; border: 1px solid var(--bs-border-color); border-radius: .4rem; padding: 3px 4px; background: var(--bs-body-bg); overflow: hidden; }
.et-cal-empty { background: transparent; border: none; }
.et-cal-today { border-color: var(--ems-accent); box-shadow: inset 0 0 0 1px var(--ems-accent); }
.et-cal-day { font-size: .8rem; font-weight: 600; color: var(--bs-secondary-color); margin-bottom: 2px; }
.et-cal-event { display: block; font-size: .68rem; line-height: 1.25; padding: 1px 4px; border-radius: 3px; margin-bottom: 2px; text-decoration: none; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ---------------------------------------------------------------------------
   BriefingTrak: stack wide incident tables into labeled blocks on phones.
   Applied to tables with .bt-stack-sm. Theme-aware via Bootstrap variables.
--------------------------------------------------------------------------- */
@media (max-width: 767.98px) {
  table.bt-stack-sm thead { display: none; }
  table.bt-stack-sm,
  table.bt-stack-sm tbody,
  table.bt-stack-sm tr,
  table.bt-stack-sm td { display: block; width: 100%; }
  table.bt-stack-sm tr {
    border: 1px solid var(--bs-border-color);
    border-radius: .5rem;
    padding: .5rem .75rem;
    margin-bottom: .75rem;
  }
  table.bt-stack-sm td {
    border: none !important;
    padding: .2rem 0;
  }
  table.bt-stack-sm td::before {
    content: attr(data-label);
    display: block;
    font-size: .68rem;
    text-transform: uppercase;
    letter-spacing: .03em;
    color: var(--bs-secondary-color);
    font-weight: 600;
    margin-bottom: .1rem;
  }
  /* Hide empty read-only cells (and their labels) so blank fields don't clutter. */
  table.bt-stack-sm td:empty { display: none; }
}
