/* USEmbroidery OMS - Metis theme integration
   Keep this file SMALL: Metis template CSS lives in /wwwroot/metis/assets/main-*.css
*/

/* ===== USEMB Brand (Logo + Neutral Grey Accent) ===== */
:root {
  --usemb-accent: #7B7B7B;
  --usemb-accent-hover: #8B8B8B;
  --usemb-accent-active: #6B6B6B;
  --usemb-accent-rgb: 123, 123, 123;
  --usemb-accent-subtle: rgba(172, 172, 172, 0.22);
}



/* Ensure accent overrides apply in both themes (removes default purple/blue) */
html[data-bs-theme="dark"], html[data-bs-theme="light"]{
    --bs-primary: var(--usemb-accent);
    --bs-primary-rgb: var(--usemb-accent-rgb);

    /* Bootstrap 5.3 derived vars (Metis ships these precomputed in purple)
       Override them so hover/focus states never fall back to purple. */
    --bs-primary-text-emphasis: var(--usemb-accent-active);
    --bs-primary-bg-subtle: rgba(var(--usemb-accent-rgb), 0.14);
    --bs-primary-border-subtle: rgba(var(--usemb-accent-rgb), 0.28);

    --bs-link-color: var(--usemb-accent);
    --bs-link-hover-color: var(--usemb-accent-hover);
    --bs-focus-ring-color: rgba(var(--usemb-accent-rgb), .25);
}

[data-bs-theme="dark"] {
  --usemb-accent: #ACACAC;
  --usemb-accent-hover: #C0C0C0;
  --usemb-accent-active: #9A9A9A;
  --usemb-accent-rgb: 172, 172, 172;
  --usemb-accent-subtle: rgba(172, 172, 172, 0.20);
}

:root {
  --bs-primary: var(--usemb-accent);
  --bs-primary-rgb: var(--usemb-accent-rgb);
  --bs-link-color: var(--usemb-accent);
  --bs-link-hover-color: var(--usemb-accent-hover);
}

/* Primary utilities */
.bg-primary { background-color: var(--usemb-accent) !important; }
.text-primary { color: var(--usemb-accent) !important; }
.border-primary { border-color: var(--usemb-accent) !important; }
.bg-primary-subtle { background-color: var(--usemb-accent-subtle) !important; }
.text-primary-emphasis { color: var(--usemb-accent-active) !important; }

/* Buttons */
.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--usemb-accent);
  --bs-btn-border-color: var(--usemb-accent);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--usemb-accent-hover);
  --bs-btn-hover-border-color: var(--usemb-accent-hover);
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--usemb-accent-active);
  --bs-btn-active-border-color: var(--usemb-accent-active);
}

/* Extra safety: force hover/active backgrounds (some Metis rules set colors directly) */
.btn-primary{
  background-color: var(--usemb-accent) !important;
  border-color: var(--usemb-accent) !important;
}
.btn-primary:hover,
.btn-primary:focus{
  background-color: var(--usemb-accent-hover) !important;
  border-color: var(--usemb-accent-hover) !important;
}
.btn-primary:active,
.btn-primary.active,
.show > .btn-primary.dropdown-toggle{
  background-color: var(--usemb-accent-active) !important;
  border-color: var(--usemb-accent-active) !important;
}

[data-bs-theme="dark"] .btn-primary {
  --bs-btn-color: #0b1220;
  --bs-btn-hover-color: #0b1220;
  --bs-btn-active-color: #0b1220;
}

[data-bs-theme="dark"] .btn-primary,
[data-bs-theme="dark"] .btn-primary:hover,
[data-bs-theme="dark"] .btn-primary:focus,
[data-bs-theme="dark"] .btn-primary:active{
  color: #0b1220 !important;
}

.btn-outline-primary {
  --bs-btn-color: var(--usemb-accent);
  --bs-btn-border-color: var(--usemb-accent);
  --bs-btn-hover-bg: var(--usemb-accent);
  --bs-btn-hover-border-color: var(--usemb-accent);
  --bs-btn-hover-color: #fff;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus{
  background-color: var(--usemb-accent) !important;
  border-color: var(--usemb-accent) !important;
}

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

.form-check-input:checked {
  background-color: var(--usemb-accent) !important;
  border-color: var(--usemb-accent) !important;
}

.page-link {
  color: var(--usemb-accent);
}
.page-item.active .page-link {
  background-color: var(--usemb-accent);
  border-color: var(--usemb-accent);
  color: #fff;
}
[data-bs-theme="dark"] .page-item.active .page-link {
  color: #0b1220;
}

/* Badges that assume white text (dark theme uses light primary) */
[data-bs-theme="dark"] .badge.bg-primary,
[data-bs-theme="dark"] .text-bg-primary,
[data-bs-theme="dark"] .badge.text-bg-primary {
  color: #0b1220 !important;
}

/* Stats icon in cards (theme uses hard-coded purple) */
.stats-card .stats-icon.bg-primary {
  background: var(--usemb-accent-subtle) !important;
  color: var(--usemb-accent) !important;
}

/* Sidebar active items (keep subtle highlight) */
#admin-sidebar .nav-link.active {
  background: var(--usemb-accent-subtle) !important;
  color: var(--usemb-accent) !important;
}

/* Brand logo swap (light vs dark) */
.brand-logo .brand-logo-dark,
.brand-logo .brand-circle-dark { display: none; }
[data-bs-theme="dark"] .brand-logo .brand-logo-dark,
[data-bs-theme="dark"] .brand-logo .brand-circle-dark { display: inline-block; }
[data-bs-theme="dark"] .brand-logo .brand-logo-light,
[data-bs-theme="dark"] .brand-logo .brand-circle-light { display: none; }

.brand-logo-img { height: 30px; width: auto; max-width: 170px; }
.brand-circle-img { height: 34px; width: 34px; object-fit: contain; }

/* On very small screens, prefer circle logo */
@media (max-width: 576px) {
  .brand-logo-img { display: none; }
  .brand-circle-img { display: inline-block; }
}
@media (min-width: 577px) {
  .brand-circle-img { display: none; }
}

/* Auth + Print logo sizes */
.login-logo-sm { height: 40px; width: auto; max-width: 200px; }
.print-logo { height: 34px; width: auto; max-width: 240px; }



html, body { height: 100%; }

/* Map legacy custom classes to Metis/Bootstrap look so existing pages render "Metis-like" without rewriting every view */
.usemb-card{
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color-translucent);
  border-radius: 1rem;
  box-shadow: 0 .125rem .25rem rgba(0,0,0,.06);
}

.table-usemb{
  border-color: var(--bs-border-color-translucent);
}
.table-usemb thead th{
  font-weight: 600;
  color: var(--bs-body-color);
  border-bottom-width: 1px;
}
.table-usemb tbody td{
  vertical-align: middle;
}

.btn-usemb{
  /* Make it a proper Bootstrap button variant so .btn:hover doesn't override it */
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--bs-primary);
  --bs-btn-border-color: var(--bs-primary);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--bs-primary);
  --bs-btn-hover-border-color: var(--bs-primary);
  --bs-btn-focus-shadow-rgb: var(--bs-primary-rgb);
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--bs-primary);
  --bs-btn-active-border-color: var(--bs-primary);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: var(--bs-primary);
  --bs-btn-disabled-border-color: var(--bs-primary);
}
.btn-usemb:hover{
  filter: brightness(.96);
}

.badge-soft{
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .35rem .6rem;
  border-radius: 999px;
  background: rgba(var(--bs-primary-rgb), .12);
  border: 1px solid rgba(var(--bs-primary-rgb), .22);
  color: var(--bs-primary);
  font-weight: 600;
}

.badge-soft.badge-success{
  background: rgba(var(--bs-success-rgb), .12);
  border-color: rgba(var(--bs-success-rgb), .22);
  color: var(--bs-success);
}
.badge-soft.badge-warning{
  background: rgba(var(--bs-warning-rgb), .12);
  border-color: rgba(var(--bs-warning-rgb), .22);
  color: var(--bs-warning);
}
.badge-soft.badge-danger{
  background: rgba(var(--bs-danger-rgb), .12);
  border-color: rgba(var(--bs-danger-rgb), .22);
  color: var(--bs-danger);
}


.badge-soft.badge-info{
  background: rgba(var(--bs-info-rgb), .18);
  color: rgba(var(--bs-info-rgb), 1);
  border: 1px solid rgba(var(--bs-info-rgb), .25);
}
.badge-soft.badge-secondary{
  background: rgba(var(--bs-secondary-rgb), .18);
  color: rgba(var(--bs-secondary-rgb), 1);
  border: 1px solid rgba(var(--bs-secondary-rgb), .25);
}
/* DataTables: make it look closer to Metis */
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select{
  border-radius: .75rem;
}
.dataTables_wrapper .pagination .page-link{
  border-radius: .6rem;
}

/* File preview cards created by site.js */
.file-preview-card{
  border: 1px solid var(--bs-border-color-translucent);
  border-radius: 1rem;
  background: var(--bs-body-bg);
  padding: .75rem;
}


/* Search box + filter bar (Metis-like) */
.search-box{ position: relative; }
.search-box .search-icon{
  position:absolute;
  left:.75rem;
  top:50%;
  transform:translateY(-50%);
  opacity:.65;
}
.search-box input.form-control{
  padding-left: 2.25rem;
  min-width: 220px;
}

.usemb-filterbar{
  display:flex;
  align-items:center;
  gap:.6rem;
  flex-wrap:wrap;
}

/* Keep Choices.js wrappers aligned in filter bars */
.usemb-filterbar .choices{ margin: 0 !important; }
.usemb-filterbar .choices__inner{ display:flex; align-items:center; }
.usemb-filterbar .choices__list--single{ display:flex; align-items:center; }
.usemb-filterbar .form-control,
.usemb-filterbar .form-select,
.usemb-filterbar .choices__inner{
  border-radius: .9rem;
}
.usemb-filterbar .form-control{
  min-width: 220px;
}

/* Metis-thin controls for filter bars */
.usemb-filterbar .form-control,
.usemb-filterbar .form-select{
  min-height: 32px;
  padding-top: .25rem;
  padding-bottom: .25rem;
  font-size: .875rem;
}
.usemb-filterbar .choices__inner{
  min-height: 32px;
  padding-top: .15rem;
  padding-bottom: .15rem;
  font-size: .875rem;
}
.search-box input.form-control.form-control-sm{
  min-height: 32px;
}

/* Choices.js dark theme overrides */
.choices__inner{
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color-translucent);
  border-radius: .9rem;
  min-height: 38px;
  padding-top: .25rem;
  padding-bottom: .25rem;
}
.choices__list--dropdown,
.choices__list[aria-expanded]{
  background: var(--bs-body-bg);
  border: 1px solid var(--bs-border-color-translucent);
  border-radius: .9rem;
  z-index: 1065; /* above modals/backdrops */
}
.choices__item,
.choices__input{
  color: var(--bs-body-color);
}
.choices__placeholder{ opacity: .65; }
.choices__list--dropdown .choices__item--selectable.is-highlighted{
  background: rgba(var(--bs-primary-rgb), .14);
}

/* Tables: keep headers dark (avoid .table-light turning white) */
.table thead th{
  background: rgba(255,255,255,.04);
  border-bottom-color: var(--bs-border-color-translucent);
}
.table tbody tr{
  border-color: var(--bs-border-color-translucent);
}

/* Metis-like toasts */
#toastContainer{ z-index: 1095; }
.usemb-toast{
  background: rgba(18, 22, 30, .96);
  border: 1px solid var(--bs-border-color-translucent);
  border-radius: 1rem;
  box-shadow: 0 .75rem 1.5rem rgba(0,0,0,.35);
}
.usemb-toast .toast-body{ color: rgba(255,255,255,.92); font-weight: 600; }
.usemb-toast.usemb-toast-success{ border-left: 4px solid var(--bs-success); }
.usemb-toast.usemb-toast-danger{ border-left: 4px solid var(--bs-danger); }
.usemb-toast.usemb-toast-warning{ border-left: 4px solid var(--bs-warning); }
.usemb-toast.usemb-toast-info{ border-left: 4px solid var(--bs-info); }

/* Make action dots button match Metis */
.btn-soft-secondary{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
}
.btn-soft-secondary:hover{
  background: rgba(255,255,255,.10);
}


/* ===== Metis-style dropdowns inside tables (prevent clipping) ===== */
.table-responsive {
  overflow-x: auto;
  overflow-y: visible;
}
.table-responsive .dropdown-menu {
  z-index: 1085; /* above cards/table */
}

/* Action dropdown menus inside grids: show all options without an internal scrollbar */
.table-responsive .dropdown-menu.usemb-actions-menu {
  max-height: none !important;
  overflow-y: visible !important;
  overflow-x: visible !important;
}

/* When an action menu opens near the bottom of a scrollable table, add some breathing room */
.table-responsive.usemb-dropdown-pad {
  padding-bottom: 260px;
}

/* ===== Choices.js: Metis-like dropdowns (theme-aware) ===== */
.choices__list--dropdown, .choices__list[aria-expanded] {
  border-radius: 12px;
  overflow: hidden;
}

/* Default (light): use normal body colors */
[data-bs-theme="light"] .choices__list--dropdown .choices__item--selectable{
  background: transparent;
  color: var(--bs-body-color);
  padding: .55rem .75rem;
}
[data-bs-theme="light"] .choices__item.choices__placeholder,
[data-bs-theme="light"] .choices__list--dropdown .choices__placeholder{
  color: rgba(var(--bs-body-color-rgb), .6) !important;
  background: transparent !important;
}
[data-bs-theme="light"] .choices__list--dropdown .choices__item--selectable.is-selected{
  background: rgba(0,0,0,.04) !important;
  color: var(--bs-body-color) !important;
}
[data-bs-theme="light"] .choices__list--dropdown .choices__item--selectable.is-highlighted{
  background: rgba(var(--bs-primary-rgb), .14) !important;
  color: var(--bs-body-color) !important;
}

/* Dark theme: slightly brighter items */
[data-bs-theme="dark"] .choices__list--dropdown .choices__item--selectable{
  background: transparent;
  color: rgba(255,255,255,.9);
  padding: .55rem .75rem;
}
[data-bs-theme="dark"] .choices__item.choices__placeholder,
[data-bs-theme="dark"] .choices__list--dropdown .choices__placeholder{
  color: rgba(255,255,255,.55) !important;
  background: transparent !important;
}
[data-bs-theme="dark"] .choices__list--dropdown .choices__item--selectable.is-selected{
  background: rgba(255,255,255,.06) !important;
  color: rgba(255,255,255,.95) !important;
}
[data-bs-theme="dark"] .choices__list--dropdown .choices__item--selectable.is-highlighted{
  background: rgba(var(--bs-primary-rgb), .15) !important;
  color: #fff !important;
}

/* Trigger pill in filter bars: keep height aligned with inputs */
.usemb-filterbar .choices[data-type*="select-one"] .choices__inner{
  min-height: 32px;
  border-radius: 999px !important;
}
.usemb-filterbar .choices[data-type*="select-one"] .choices__list--single{
  padding: 4px 34px 4px 14px;
}


/* Global loading overlay (used on Save/Delete/AJAX) */
.loading-screen{
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.75);
  backdrop-filter: blur(2px);
  z-index: 2000;
}
.loading-screen.show{
  display: flex;
}
.loading-spinner{
  padding: 18px 22px;
  background: rgba(255,255,255,0.95);
  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 16px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.12);
}

/* Dark mode support (body.dark) */
body.dark .loading-screen{
  background: rgba(0,0,0,0.55);
}
body.dark .loading-spinner{
  background: rgba(30,30,30,0.95);
  border-color: rgba(255,255,255,0.08);
}

/* =========================
   Multi-file uploader (preview)
   ========================= */
[data-mfu-wrapper] .mfu-list{
  display: grid;
  gap: .5rem;
}

.mfu-item{
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  padding: .6rem .75rem .5rem;
  background: rgba(255,255,255,.03);
  box-shadow: 0 6px 18px rgba(0,0,0,.06);
}

[data-bs-theme="light"] .mfu-item{
  border-color: rgba(0,0,0,.08);
  background: rgba(0,0,0,.02);
}

.mfu-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .75rem;
}

.mfu-left{
  min-width: 0;
  display: grid;
  grid-template-columns: 18px 1fr auto;
  gap: .6rem;
  align-items: center;
}

.mfu-icon{ opacity: .85; }

.mfu-name{
  min-width: 0;
  font-weight: 600;
  font-size: .95rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mfu-meta{
  font-size: .8rem;
  opacity: .7;
}

.mfu-remove{
  border: 0;
  background: transparent;
  padding: .15rem .25rem;
  border-radius: 8px;
  color: rgba(255,255,255,.75);
}

[data-bs-theme="light"] .mfu-remove{ color: rgba(0,0,0,.55); }

.mfu-remove:hover{
  background: rgba(var(--bs-danger-rgb), .12);
  color: var(--bs-danger);
}

.mfu-progress{
  margin-top: .45rem;
  height: 3px;
  background: rgba(255,255,255,.08);
  border-radius: 999px;
  overflow: hidden;
}

[data-bs-theme="light"] .mfu-progress{ background: rgba(0,0,0,.08); }

.mfu-progress-bar{
  height: 100%;
  width: 0%;
  background: rgba(var(--bs-primary-rgb), .9);
  border-radius: 999px;
  animation: mfuFill 0.65s ease forwards;
}

.mfu-item.mfu-done .mfu-progress{ opacity: .35; }

@keyframes mfuFill{
  from { width: 0%; }
  to { width: 100%; }
}




/* Auth pages: center card and logo */
.auth-page-wrapper{
    min-height: 100vh;
}
.auth-page-wrapper .auth-page-content{
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}



/* Hover color for primary links (avoid default purple/blue hover) */
a.text-primary:hover,
a.link-primary:hover,
.text-primary:hover,
.link-primary:hover{
  color: var(--bs-link-hover-color) !important;
}

/* Global link colors (prevents browser default purple for visited/hover) */
a,
a:visited{
  color: var(--bs-link-color);
}
a:hover,
a:focus{
  color: var(--bs-link-hover-color);
}

