/* ====================================================================
   Shortages – ATC Pack Movements Offcanvas
   Matches the dark glass look of .settings-drawer / .custom-offcanvas
   ==================================================================== */

/* Shell -------------------------------------------------------------- */
#sh_mov-atc-drawer.offcanvas {
  --bs-offcanvas-width: min(92vw, 420px);

  width: var(--bs-offcanvas-width) !important;   /* override inline width */
  max-width: var(--bs-offcanvas-width) !important;

  background: rgba(16, 38, 79, 0.90);
  -webkit-backdrop-filter: blur(18px) saturate(115%);
  backdrop-filter: blur(18px) saturate(115%);

  color: var(--text-strong);
  border-left: 1px solid var(--border-glass);
  border-radius: var(--radius-lg) 0 0 var(--radius-lg);
  box-shadow: var(--elev-3);

  height: 100vh;
  height: 100dvh;
  max-height: 100dvh;
  overflow: hidden;
  padding: 0;
}

@media (max-width: 576px) {
  #sh_mov-atc-drawer.offcanvas {
    border-radius: 0;
  }
}

/* Header ------------------------------------------------------------- */
#sh_mov-atc-drawer .offcanvas-header {
  padding: 0.85rem 1.25rem;
  border-bottom: 1px solid var(--divider-glass);
}

#sh_mov-atc-drawer .offcanvas-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 600;
  font-size: 1.1rem;
  letter-spacing: 0.2px;
}

#sh_mov-atc-drawer .btn-close {
  filter: invert(1) opacity(0.75);
}
#sh_mov-atc-drawer .btn-close:hover {
  opacity: 1;
}

/* Body layout -------------------------------------------------------- */
#sh_mov-atc-drawer .offcanvas-body {
  padding: 0.9rem 1.25rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* Make muted text use the glass palette */
#sh_mov-atc-drawer .text-muted {
  color: var(--text-muted) !important;
}

/* Cards & accordion container ---------------------------------------- */
#sh_mov-atc-drawer .card {
  background: var(--surface-glass-weak);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--text-strong);
}

#sh_mov-atc-drawer .card-header {
  background: transparent;
  border-bottom: 1px solid var(--divider-glass);
}

/* Accordion buttons (Into / Out of sections) ------------------------- */
#sh_mov-atc-drawer .accordion-button {
  background: transparent;
  color: var(--text-strong);
  box-shadow: none;
}
#sh_mov-atc-drawer .accordion-button:not(.collapsed) {
  background: rgba(255, 255, 255, 0.06);
  box-shadow: inset 0 0 0 1px var(--border-glass);
}
#sh_mov-atc-drawer .accordion-button::after {
  filter: invert(1) opacity(0.85);
}

#sh_mov-atc-drawer .accordion-item {
  background: transparent;
  border-color: var(--divider-glass);
}

#sh_mov-atc-drawer .accordion-body {
  padding: 0.5rem 0.75rem 0.75rem;
}

/* Pack list bullets --------------------------------------------------- */
#sh_mov-atc-drawer ul {
  margin-bottom: 0;
  padding-left: 1.15rem;
}
#sh_mov-atc-drawer li {
  color: var(--text-strong);
}
#sh_mov-atc-drawer li .text-muted {
  color: var(--text-muted) !important;
}
/* =====================================================================
   Shortages – soften red/green severity chips in ATC drawer
   ===================================================================== */

/* Top summary chips: "Into full shortage 0" / "Out of full shortage 2" */
#sh_mov-atc-drawer
  .d-flex.align-items-center.gap-2.flex-wrap.mb-2
  > span:not(.me-1) {
  /* Override inline styles from the _chip helper */
  color: rgba(226, 232, 240, 0.96) !important;         /* near‑white text */
  background-color: rgba(15, 23, 42, 0.65) !important; /* neutral navy chip */
  border-color: rgba(148, 163, 184, 0.70) !important;  /* soft slate border */
}

/* Small count badges in the accordion headers ("0", "5") */
#sh_mov-atc-drawer .accordion-button .badge.rounded-pill {
  color: rgba(226, 232, 240, 0.96) !important;
  background-color: rgba(15, 23, 42, 0.65) !important;
  border-color: rgba(148, 163, 184, 0.70) !important;
}
/* =======================================================================
   Shortages – Filters offcanvas
   Scope: .offcanvas.filters-panel (shortages_historical Filters panel)
   Matches Settings / Excel drawers
   ======================================================================= */

/* Fallback if blur isn't supported */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .offcanvas.filters-panel {
    background: #0f274b !important;
  }
}

/* Shell --------------------------------------------------------------- */
.offcanvas.filters-panel {
  --bs-offcanvas-width: min(92vw, 460px);

  width: var(--bs-offcanvas-width) !important;
  max-width: var(--bs-offcanvas-width) !important;

  background:
    radial-gradient(140% 180% at 20% 0%, rgba(70, 124, 230, 0.40) 0, transparent 55%),
    radial-gradient(180% 160% at 85% 100%, rgba(33, 210, 204, 0.25) 0, transparent 55%),
    var(--surface-glass);
  color: var(--text-strong);

  border-radius: var(--radius-lg) 0 0 var(--radius-lg);
  border: 1px solid var(--border-glass);
  box-shadow: var(--elev-3);

  -webkit-backdrop-filter: blur(18px) saturate(115%);
  backdrop-filter: blur(18px) saturate(115%);

  height: 100vh;
  height: 100dvh;
  max-height: 100dvh;
  overflow: hidden;
  padding: 0;
}

@media (max-width: 576px) {
  .offcanvas.filters-panel {
    border-radius: 0;
  }
}

/* Header -------------------------------------------------------------- */
.offcanvas.filters-panel .offcanvas-header {
  padding: 0.85rem 1.4rem;
  border-bottom: 1px solid var(--divider-glass);
}

.offcanvas.filters-panel .offcanvas-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-weight: 600;
  font-size: 1.1rem;
  letter-spacing: 0.2px;
  color: var(--text-strong);
}

.offcanvas.filters-panel .btn-close {
  filter: invert(1) opacity(0.8);
}
.offcanvas.filters-panel .btn-close:hover {
  opacity: 1;
}

/* Body layout --------------------------------------------------------- */
.offcanvas.filters-panel .offcanvas-body {
  padding: 0.9rem 1.5rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* Accordion ----------------------------------------------------------- */
.offcanvas.filters-panel .accordion-item {
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  background: rgba(15, 23, 42, 0.55);
  overflow: hidden;
}

.offcanvas.filters-panel .accordion-item + .accordion-item {
  margin-top: 0.5rem;
}

.offcanvas.filters-panel .accordion-button {
  background: rgba(15, 23, 42, 0.9);
  color: var(--text-strong);
  font-weight: 500;
  padding: 0.65rem 1rem;
}
.offcanvas.filters-panel .accordion-button:not(.collapsed) {
  box-shadow: inset 0 0 0 1px var(--border-glass);
}
.offcanvas.filters-panel .accordion-button::after {
  filter: invert(1) opacity(0.85);
}

.offcanvas.filters-panel .accordion-body {
  background: transparent;
  padding: 0.75rem 1rem 0.9rem;
}

/* Labels + dropdowns -------------------------------------------------- */
.offcanvas.filters-panel .form-label {
  color: var(--text-muted);
  font-size: 0.85rem;
}

/* Dash dropdowns (dcc.Dropdown) – compact, dark control */
.offcanvas.filters-panel .dd-compact,
.offcanvas.filters-panel .dd-compact .Select__control,
.offcanvas.filters-panel .dd-compact .Select-control {
  background: rgba(3, 17, 47, 0.95);
  border-radius: 10px;
  border: 1px solid rgba(148, 163, 184, 0.55);
  color: var(--text-strong);
  min-height: 36px;
}

.offcanvas.filters-panel .dd-compact .Select__placeholder,
.offcanvas.filters-panel .dd-compact .Select-placeholder {
  color: var(--text-muted);
}

/* Footer / actions row ------------------------------------------------ */
.offcanvas.filters-panel .border-top {
  border-color: var(--divider-glass) !important;
  background:
    linear-gradient(180deg, rgba(5, 18, 46, 0.96), rgba(2, 8, 26, 1));
  padding-top: 0.75rem;
}

.offcanvas.filters-panel .btn-apply {
  background-color: var(--brand-accent);
  border-color: var(--brand-accent);
  font-weight: 600;
  height: 40px;
  border-radius: 12px;
  padding: 0.45rem 0.9rem;
}
.offcanvas.filters-panel .btn-apply:hover {
  filter: brightness(1.03);
}
.offcanvas.filters-panel .btn-apply:active {
  filter: brightness(0.97);
}

.offcanvas.filters-panel .btn-link {
  color: var(--text-muted);
  text-decoration: none;
}
.offcanvas.filters-panel .btn-link:hover {
  color: var(--text-strong);
  text-decoration: underline;
}
