/*
 * This is a manifest file that'll be compiled into application.css.
 *
 * With Propshaft, assets are served efficiently without preprocessing steps. You can still include
 * application-wide styles in this file, but keep in mind that CSS precedence will follow the standard
 * cascading order, meaning styles declared later in the document or manifest will override earlier ones,
 * depending on specificity.
 *
 * Consider organizing styles into separate files for maintainability.
 */

/* Spool form modal */
.spool-modal {
  border: none;
  border-radius: 0.75rem;
  padding: 0;
  max-width: 640px;
  width: 90vw;
  max-height: calc(100vh - 2rem);
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.25);
  overflow: visible;
  background-color: var(--modal-surface-bg, var(--bs-body-bg));
  color: var(--bs-body-color);
}

.spool-modal::backdrop {
  background: rgba(0, 0, 0, 0.5);
}

.modal-backdrop {
  --bs-backdrop-opacity: 0.5;
  background-color: #000;
}

.modal-content,
.spool-modal-content {
  background-color: var(--modal-surface-bg, var(--bs-body-bg));
  color: var(--bs-body-color);
  border: 1px solid var(--bs-border-color);
  border-radius: 0.75rem;
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.25);
  overflow: hidden;
}

.modal.fade .modal-dialog {
  transform: translateY(12px) scale(0.985);
  transition: transform 0.18s ease, opacity 0.18s ease;
}

.modal.show .modal-dialog {
  transform: translateY(0) scale(1);
}

.spool-modal {
  opacity: 0;
  transform: translateY(12px) scale(0.985);
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.spool-modal.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.modal-content form,
.spool-modal-content,
.spool-modal-content turbo-frame,
.spool-modal-content form {
  display: flex;
  flex-direction: column;
  min-height: 0;
  max-height: calc(100vh - 2rem);
  background-color: var(--modal-surface-bg, var(--bs-body-bg));
  color: var(--bs-body-color);
}

.modal-dialog-scrollable .modal-content {
  max-height: calc(100vh - 2rem);
}

.modal-header,
.spool-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.5rem;
  background-color: var(--modal-chrome-bg, var(--bs-tertiary-bg));
  border-bottom: 1px solid var(--bs-border-color);
  flex-shrink: 0;
}

.modal-body,
.spool-modal-body {
  padding: 1.5rem;
  overflow-y: auto;
  flex: 0 1 auto;
  background-color: var(--modal-surface-bg, var(--bs-body-bg));
  color: var(--bs-body-color);
}

.spool-modal-content {
  max-height: calc(100vh - 2rem);
}

.spool-modal-content .spool-modal-body {
  overflow-y: auto;
  flex: 1 1 auto;
  min-height: 0;
}

.modal-content .modal-body {
  flex: 1 1 auto;
  min-height: 0;
}

.modal-footer,
.spool-modal-footer {
  display: flex;
  gap: 0.5rem;
  justify-content: flex-end;
  padding: 1rem 1.5rem;
  background-color: var(--modal-chrome-bg, var(--bs-tertiary-bg));
  border-top: 1px solid var(--bs-border-color);
  flex-shrink: 0;
}

/* Color dropdown */
.color-swatch-sm {
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 1px solid rgba(0, 0, 0, 0.15);
  flex-shrink: 0;
}

.color-dropdown-menu {
  max-height: 250px;
  overflow-y: auto;
}

/* Toast - fix iOS scroll paint artifacts */
.toast-container {
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}

/* Bulk select mode */
.bulk-checkbox {
  display: none;
}

.bulk-select-active .bulk-checkbox {
  display: block;
}

td.bulk-checkbox,
th.bulk-checkbox {
  display: none;
}

.bulk-select-active td.bulk-checkbox,
.bulk-select-active th.bulk-checkbox {
  display: table-cell;
}

.bulk-select-active .bulk-checkbox .form-check-input {
  cursor: pointer;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

/* Dark mode overrides */
[data-bs-theme="dark"] {
  --bs-body-bg: #1a1d21;
  --bs-tertiary-bg: #2b2f35;
  --modal-surface-bg: #1f242a;
  --modal-chrome-bg: #242930;
}

[data-bs-theme="dark"] .card {
  --bs-card-bg: #2b2f35;
  --bs-card-border-color: #373b42;
  border: 1px solid var(--bs-card-border-color) !important;
}

[data-bs-theme="dark"] .table {
  --bs-table-bg: #2b2f35;
  --bs-table-border-color: #373b42;
}

[data-bs-theme="dark"] .table-responsive.rounded {
  border-color: #373b42 !important;
}

[data-bs-theme="dark"] .bg-body-tertiary {
  background-color: #2b2f35 !important;
}

.inventory-table thead th {
  white-space: nowrap;
  background-color: var(--bs-tertiary-bg);
}

.sort-header-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: inherit;
  text-decoration: none;
  font-weight: 600;
}

.sort-header-link:hover {
  color: inherit;
}

.sort-arrow {
  opacity: 0;
  transform: rotate(0deg);
  transition: opacity 0.18s ease, transform 0.18s ease;
  font-size: 0.75rem;
}

.sort-arrow.is-active {
  opacity: 1;
}

.sort-arrow.is-desc {
  transform: rotate(180deg);
}

.brand-chip {
  min-width: 1.5rem;
  height: 1.5rem;
  padding: 0 0.35rem;
  border-radius: 999px;
  background-color: var(--bs-tertiary-bg);
  color: var(--bs-body-color);
  border: 1px solid var(--bs-border-color);
  font-size: 0.65rem;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
}

@media (max-width: 767.98px) {
  .inventory-color-header-offset {
    display: inline-block;
    padding-left: 2.25rem;
  }
}

.spool-group-toggle {
  border: 0;
  background: none;
}

.group-details-wrap {
  padding: 0.125rem 0 0;
}

.scan-review-card {
  background-color: var(--modal-surface-bg, var(--bs-body-bg));
}

.scan-review-card .form-check-input {
  margin-top: 0.15rem;
}

.favorite-color-toggle {
  width: 16px;
  height: 16px;
  text-decoration: none;
}

.favorite-color-toggle:hover {
  text-decoration: none;
}

.scan-pending-state .spinner-border {
  flex-shrink: 0;
}

@media (max-width: 767.98px) {
  #scanSpoolsModal .modal-dialog {
    margin: 0.5rem;
  }

  #scanSpoolsModal .modal-body {
    padding: 1rem;
  }

  #scanSpoolsModal .modal-footer {
    padding: 1rem;
    gap: 0.75rem;
  }

  #scanSpoolsModal .modal-footer .btn {
    width: 100%;
  }

  .scan-pending-state {
    align-items: flex-start !important;
  }

  .scan-pending-state .spinner-border {
    margin-top: 0.1rem;
  }
}

.group-details-inner {
  padding: 0.125rem 0 0.25rem;
}

.is-expanded .group-summary-dim {
  opacity: 0.4;
  transition: opacity 0.18s ease;
}

.is-expanded .group-summary-dim .btn,
.is-expanded .group-summary-dim .form-check-input {
  pointer-events: none;
}

.rotate-180 {
  transform: rotate(180deg);
  transition: transform 0.18s ease;
}
