body {
  min-height: 100vh;
  background: #f8f9fa;
}

.sidebar {
  width: 260px;
  min-height: 100vh;
}
.sidebar .nav-link {
  color: #adb5bd;
  border-radius: .5rem;
}
.sidebar .nav-link:hover,
.sidebar .nav-link.active {
  color: #fff;
  background: rgba(255, 255, 255, .12);
}

@media (max-width: 991.98px) {
  .sidebar {
    width: 100%;
    min-height: auto;
  }
}
.main-content {
  min-height: 100vh;
}

.loader-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .55);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.loader-hourglass {
  font-size: 4rem;
  display: inline-block;
  animation: loader-hourglass-spin 1s linear infinite;
}

@keyframes loader-hourglass-spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}
.icon-card {
  transition: transform .15s ease, box-shadow .15s ease;
}
.icon-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 .5rem 1rem rgba(0, 0, 0, .10) !important;
}

@media (max-width: 575.98px) {
  .responsive-card-table {
    border-collapse: separate;
    border-spacing: 0 .75rem;
  }
  .responsive-card-table thead {
    display: none;
  }
  .responsive-card-table,
  .responsive-card-table tbody,
  .responsive-card-table tr,
  .responsive-card-table td {
    display: block;
    width: 100%;
  }
  .responsive-card-table tr {
    background: #fff;
    border: 1px solid var(--bs-border-color);
    border-radius: var(--bs-border-radius-lg);
    box-shadow: 0 .125rem .25rem rgba(0, 0, 0, .075);
    overflow: hidden;
    padding: .5rem .75rem;
  }
  .responsive-card-table td {
    border: 0;
    border-bottom: 1px solid var(--bs-border-color-translucent);
    padding: .65rem 0;
  }
  .responsive-card-table td::before {
    content: attr(data-label);
    display: block;
    color: var(--bs-secondary-color);
    font-size: .75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    margin-bottom: .2rem;
  }
  .responsive-card-table td:last-child {
    border-bottom: 0;
  }
  .responsive-card-table td[data-label="Actions"] {
    text-align: left !important;
  }
  .responsive-card-table td[data-label="Actions"] .btn {
    margin-right: .25rem;
  }
  .responsive-card-table .responsive-card-table-empty {
    box-shadow: none;
    padding: 0;
  }
  .responsive-card-table .responsive-card-table-empty td::before {
    content: "";
    display: none;
  }
}
.login-page {
  min-height: 100vh;
  background: #f8f9fa;
}

.login-card {
  width: 100%;
  max-width: 420px;
}

.master-detail-table tbody tr {
  cursor: pointer;
}

@media (max-width: 767.98px) {
  .responsive-card-table td[data-label="Actions"] .btn,
  .responsive-card-table td[data-label="Actions"] form {
    margin-top: .25rem;
  }
}
.menu-builder .nav-pills{padding-bottom:.25rem}.draggable-product{cursor:grab}.draggable-product.is-dragging{opacity:.55}.menu-drop-card{transition:border-color .15s ease,box-shadow .15s ease,transform .15s ease}.menu-drop-card.is-drag-over{border:2px dashed var(--bs-primary)!important;box-shadow:0 .5rem 1.25rem rgba(13,110,253,.2)!important;transform:translateY(-2px)}@media (max-width:575.98px){.product-source-table .draggable-product{cursor:default}.menu-builder .nav-pills .nav-link{white-space:nowrap}}

.menu-sortable-row {
  cursor: grab;
}

.menu-sortable-row.is-dragging {
  opacity: .55;
  cursor: grabbing;
}

.menu-drag-handle {
  cursor: grab;
}


.log-viewer-output {
  min-height: 480px;
  max-height: 70vh;
  overflow: auto;
  white-space: pre-wrap;
  word-break: break-word;
}

/* Admin mobile sidebar menu */
.sidebar .navbar-toggler {
  line-height: 1;
}

@media (max-width: 991.98px) {
  .sidebar .nav.collapse:not(.show) {
    display: none !important;
  }

  .sidebar .nav.collapse.show {
    display: flex !important;
  }
}

/* Dark environment visibility fixes */
@media (prefers-color-scheme: dark) {
  html:not([data-bs-theme="light"]) body,
  html[data-bs-theme="dark"] body {
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
  }

  html[data-bs-theme="dark"] .login-page,
  html:not([data-bs-theme="light"]) .login-page {
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
  }

  html[data-bs-theme="dark"] .login-card,
  html:not([data-bs-theme="light"]) .login-card {
    background: var(--bs-tertiary-bg);
    color: var(--bs-body-color);
    border: 1px solid var(--bs-border-color) !important;
  }

  html[data-bs-theme="dark"] .btn-outline-dark,
  html:not([data-bs-theme="light"]) .btn-outline-dark {
    color: var(--bs-body-color);
    border-color: var(--bs-border-color);
    background-color: transparent;
  }

  html[data-bs-theme="dark"] .btn-outline-dark:hover,
  html:not([data-bs-theme="light"]) .btn-outline-dark:hover {
    color: var(--bs-dark);
    background-color: var(--bs-light);
    border-color: var(--bs-light);
  }

  html[data-bs-theme="dark"] .card-header.bg-white,
  html:not([data-bs-theme="light"]) .card-header.bg-white {
    background-color: var(--bs-tertiary-bg) !important;
    color: var(--bs-body-color);
  }

  html[data-bs-theme="dark"] .table-light,
  html:not([data-bs-theme="light"]) .table-light,
  html[data-bs-theme="dark"] .clicktv-billing-table thead th,
  html:not([data-bs-theme="light"]) .clicktv-billing-table thead th {
    --bs-table-bg: var(--bs-tertiary-bg);
    --bs-table-color: var(--bs-body-color);
    background: var(--bs-tertiary-bg);
    color: var(--bs-body-color);
  }

  html[data-bs-theme="dark"] .responsive-card-table tr,
  html:not([data-bs-theme="light"]) .responsive-card-table tr {
    background: var(--bs-tertiary-bg);
    color: var(--bs-body-color);
  }
}


/* Stage 12C: keep table headers readable in dark environments */
html[data-bs-theme="dark"] .table thead th,
html:not([data-bs-theme="light"]) .table thead th,
html[data-bs-theme="dark"] .table-light th,
html:not([data-bs-theme="light"]) .table-light th {
  background-color: var(--bs-tertiary-bg) !important;
  color: var(--bs-body-color) !important;
  border-color: var(--bs-border-color) !important;
}

html[data-bs-theme="dark"] .table thead th a,
html:not([data-bs-theme="light"]) .table thead th a {
  color: var(--bs-body-color) !important;
}

/* Docas order screens */
.docas-orders-scroll { max-height: calc(100vh - 330px); overflow: auto; }
.docas-order-products-scroll { max-height: calc(100vh - 360px); overflow: auto; }
.docas-order-items-scroll { max-height: calc(100vh - 410px); overflow: auto; }
.docas-order-products-scroll thead th,
.docas-order-items-scroll thead th,
.docas-orders-scroll thead th { position: sticky; top: 0; background: var(--bs-body-bg); z-index: 2; }

/* Docas Stage 18 table fit/sticky headers */
.docas-table-scroll { max-height: calc(100vh - 310px); overflow: auto; }
.docas-dialog-table-scroll { max-height: 60vh; overflow: auto; }
.docas-table-scroll thead th,
.docas-dialog-table-scroll thead th { position: sticky; top: 0; background: var(--bs-body-bg); z-index: 3; box-shadow: inset 0 -1px 0 var(--bs-border-color); }
.docas-table-scroll .collapse td { background: var(--bs-body-bg); }
@media (max-width: 767.98px) {
  .docas-table-scroll { max-height: calc(100vh - 260px); }
}
