/* ============================================================
   BAR KEEP
   Modern CSS optimizations: color-scheme, accent-color,
   scrollbar-gutter, scroll-margin-top, text-underline-offset,
   text-wrap: balance/pretty, aspect-ratio, logical properties,
   native nesting, color-mix(), inline-flex buttons,
   outline-offset focus-visible, WCAG 2.5.5 touch targets
   ============================================================ */

:root {
  --border-radius: 5px;
  --border-radius-lg: 8px;
  --transition-speed: 0.15s ease-in-out;
  color-scheme: dark light;
}

html {
  scrollbar-gutter: stable;
}

/* ── Dark Theme ─────────────────────────────────────────── */
[data-bs-theme="dark"] {
  --bs-body-bg: #1a1a1a;
  --bs-body-color: #e0e0e0;
  --bs-emphasis-color: #f0f0f0;
  --bs-secondary-bg: #2c2c2c;
  --bs-tertiary-bg: #3c3c3c;
  --bs-border-color: #444;
  --bs-link-color: #6ea8fe;
  --bs-link-hover-color: #9ec5fe;
  --navbar-bg: #2c2c2c;
  --card-bg: #2c2c2c;
  --metadata-bg: rgba(255, 255, 255, 0.05);
  --stripe-bg: rgba(255, 255, 255, 0.02);
  --card-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
  --text-muted: #9a9a9a;
  --dropdown-bg: var(--bs-secondary-bg);
  --dropdown-hover-bg: var(--metadata-bg);
  --toggler-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.85%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
  --bs-navbar-color: rgba(255, 255, 255, 0.85);
  --bs-navbar-hover-color: rgba(255, 255, 255, 1);
  --bs-navbar-disabled-color: rgba(255, 255, 255, 0.5);
  --bs-navbar-active-color: #fff;
  --bs-navbar-brand-color: #fff;
  --bs-navbar-brand-hover-color: #fff;
  --bs-navbar-toggler-border-color: rgba(255, 255, 255, 0.1);
  color-scheme: dark;
  accent-color: var(--bs-link-color);
}

/* ── Light Theme ────────────────────────────────────────── */
[data-bs-theme="light"] {
  --bs-body-bg: #e8e8e8;
  --bs-body-color: #1e2832;
  --bs-emphasis-color: #0d1117;
  --bs-secondary-bg: #dcdcdc;
  --bs-tertiary-bg: #d0d0d0;
  --bs-border-color: #b8b8b8;
  --bs-link-color: #0056d2;
  --bs-link-hover-color: #0045a8;
  --navbar-bg: #dedede;
  --card-bg: #efefef;
  --metadata-bg: rgba(0, 0, 0, 0.08);
  --stripe-bg: rgba(0, 0, 0, 0.04);
  --card-shadow: 0 1px 3px rgba(0, 0, 0, 0.12), 0 1px 2px rgba(0, 0, 0, 0.08);
  --text-muted: #555f70;
  --dropdown-bg: #f5f5f5;
  --dropdown-hover-bg: #e0e0e0;
  --toggler-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%280, 0, 0, 0.65%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
  --bs-navbar-color: rgba(0, 0, 0, 0.65);
  --bs-navbar-hover-color: rgba(0, 0, 0, 0.8);
  --bs-navbar-disabled-color: rgba(0, 0, 0, 0.3);
  --bs-navbar-active-color: rgba(0, 0, 0, 0.9);
  --bs-navbar-brand-color: rgba(0, 0, 0, 0.9);
  --bs-navbar-brand-hover-color: rgba(0, 0, 0, 0.9);
  --bs-navbar-toggler-border-color: rgba(0, 0, 0, 0.1);
  color-scheme: light;
  accent-color: var(--bs-link-color);
}

/* ── Safe area ──────────────────────────────────────────── */
@supports (padding: max(0px)) {
  body {
    padding-top: env(safe-area-inset-top);
    padding-inline: env(safe-area-inset-left) env(safe-area-inset-right);
  }
}

/* ── Base ────────────────────────────────────────────────── */
body { overscroll-behavior-y: auto; }

h1, h2, h3, h4, h5, h6 { text-wrap: balance; }

p { text-wrap: pretty; }

[id] { scroll-margin-top: 1rem; }

main {
  overscroll-behavior-y: auto;
  -webkit-overflow-scrolling: touch;
}

.container-fluid { overscroll-behavior-y: auto; }

/* ── Links ───────────────────────────────────────────────── */
a {
  color: var(--bs-link-color);

  &:hover { color: var(--bs-link-hover-color); }
}

a:not([class]) { text-underline-offset: 0.25em; }

.text-decoration-none { color: var(--bs-body-color) !important; }
.text-muted { color: var(--text-muted) !important; }

/* ── Collapse chevron ──────────────────────────────────── */
[data-bs-toggle="collapse"] {
  .bi-chevron-down { transition: transform 0.2s ease-in-out; }

  &[aria-expanded="true"] .bi-chevron-down { transform: rotate(180deg); }
  &:hover { opacity: 0.8; }
}

/* ── Buttons ─────────────────────────────────────────────── */
/* inline-flex centers content; min-height satisfies WCAG 2.5.5 touch targets */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1.1;
  min-height: 44px;
  touch-action: manipulation;
  user-select: none;
  -webkit-tap-highlight-color: transparent;

  &:focus-visible {
    outline: 2px solid var(--bs-link-color);
    outline-offset: 2px;
    box-shadow: none;
  }
}

.btn-sm { min-height: unset; }

/* Touch/coarse pointer adjustments */
@media (hover: none) and (pointer: coarse) {
  .btn {
    &:focus { outline: none; box-shadow: none; }
  }
}

@media (max-width: 767px) {
  .btn {
    &:focus,
    &:active:focus,
    &.active:focus,
    &.focus,
    &:active.focus,
    &.active.focus {
      outline: none !important;
      box-shadow: none !important;
    }
  }

  .btn-outline-danger:focus {
    outline: none !important;
    box-shadow: none !important;
  }

  .btn-danger {
    background-color: #dc3545 !important;
    border-color: #dc3545 !important;
    color: white !important;
  }

  .btn-outline-danger {
    background-color: transparent !important;
    border-color: #dc3545 !important;
    color: #dc3545 !important;
  }
}

/* ── Navbar ─────────────────────────────────────────────── */
.navbar { background-color: var(--navbar-bg) !important; }

[data-bs-theme="light"] .navbar {
  border-block-end: 1px solid var(--bs-border-color);
}

.navbar-toggler-icon { background-image: var(--toggler-icon); }

/* ── Dropdown ──────────────────────────────────────────── */
.dropdown-menu {
  --bs-dropdown-bg: var(--dropdown-bg);
  --bs-dropdown-link-color: var(--bs-body-color);
  --bs-dropdown-link-hover-color: var(--bs-emphasis-color);
  --bs-dropdown-link-hover-bg: var(--dropdown-hover-bg);
  --bs-dropdown-divider-bg: var(--bs-border-color);

  form { margin: 0; }

  form button.dropdown-item {
    width: 100%;
    text-align: left;
    border: none;
    background: none;
    padding: 0.25rem 1rem;
    color: var(--bs-dropdown-link-color);
    transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out;

    &:hover {
      background-color: var(--bs-dropdown-link-hover-bg);
      color: var(--bs-dropdown-link-hover-color);
    }
  }
}

[data-bs-theme="light"] .dropdown-menu {
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.12), 0 1px 3px rgba(0, 0, 0, 0.08);
}

/* ── Cards ───────────────────────────────────────────────── */
.card, .mobile-item-card {
  background-color: var(--card-bg);
  border-color: var(--bs-border-color);
}

[data-bs-theme="light"] .card,
[data-bs-theme="light"] .mobile-item-card {
  box-shadow: var(--card-shadow);
  border: 1px solid rgba(0, 0, 0, 0.12);
}

[data-bs-theme="dark"] .card { box-shadow: var(--card-shadow); }

/* ── Theme toggle ──────────────────────────────────────── */
.theme-toggle {
  background: none;
  border: none;
  color: var(--bs-body-color);
  cursor: pointer;
  padding: 0.375rem 0.75rem;
  border-radius: 0.25rem;
  transition: background-color var(--transition-speed);

  &:hover { background-color: var(--metadata-bg); }
}

/* ── Responsive button text ────────────────────────────── */
.responsive-btn {
  .btn-text-mobile { display: none; }
  .btn-text-desktop { display: inline; }

  @media (max-width: 767px) {
    font-size: 14px;
    padding: 6px 12px;
    .btn-text-mobile { display: inline; }
    .btn-text-desktop { display: none; }
  }
}

/* ── Images ────────────────────────────────────────────── */
img { max-width: 100%; height: auto; }

.item-thumbnail {
  width: 120px;
  aspect-ratio: 1;
  object-fit: contain;
  border-radius: var(--border-radius);
  background-color: transparent;

  span { font-size: 36px; }
}

.item-image {
  max-width: 200px;
  max-height: 200px;
  object-fit: contain;
  border-radius: 10px;
  background-color: transparent;
}

/* ── Metadata / filters ─────────────────────────────────── */
.metadata-item, .category-filters {
  background-color: var(--metadata-bg);
  padding: 10px;
  border-radius: var(--border-radius);
}

.metadata-item { margin-block-end: 10px; }
.category-filters { border: 1px solid var(--bs-border-color); }

/* ── Quantity controls ─────────────────────────────────── */
.quantity-controls, .mobile-quantity-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}

.mobile-quantity-controls {
  gap: 10px;

  form { display: inline-block; margin: 0; }

  .btn {
    padding: 6px 12px;
    font-size: 16px;
    min-width: 44px;
    min-height: 44px;
  }
}

/* ── Stock status ───────────────────────────────────────── */
/* color-mix() replaces hardcoded rgba() */
.out-of-stock, .out-of-stock td {
  background-color: color-mix(in srgb, #dc3545 10%, transparent) !important;
}

.low-stock, .low-stock td {
  background-color: color-mix(in srgb, #ffc107 10%, transparent) !important;
}

/* ── Table ─────────────────────────────────────────────── */
.table {
  table-layout: auto;
  --bs-table-border-color: var(--bs-border-color);
}

[data-bs-theme="light"] .table { --bs-table-border-color: rgba(0, 0, 0, 0.12); }

.table-striped > tbody > tr:nth-of-type(odd) > * { background-color: var(--stripe-bg); }

[data-bs-theme="light"] .table-hover > tbody > tr:hover > * { background-color: rgba(0, 0, 0, 0.04); }

.table th:last-child, .table td:last-child {
  white-space: nowrap;
  min-width: 120px;
}

.table td:last-child .d-flex { flex-wrap: nowrap !important; }
.table td:last-child .btn { white-space: nowrap; }

/* ── Mobile item card ──────────────────────────────────── */
.mobile-item-card {
  border-radius: var(--border-radius-lg);
  padding: 12px;
  margin-block-end: 12px;
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* ── Sticky sidebar ────────────────────────────────────── */
@media (min-width: 768px) {
  .col-md-3 .card {
    position: sticky;
    top: 20px;
    z-index: 100;
  }
}

/* ── Tablet ─────────────────────────────────────────────── */
@media (max-width: 991px) and (min-width: 768px) {
  .item-thumbnail {
    width: 100px !important;
    aspect-ratio: 1 !important;
    max-width: 100px !important;
  }

  .item-image { max-width: 150px !important; max-height: 150px !important; }

  .table td { padding: 0.5rem; vertical-align: middle; }
}

/* ── Mobile general ─────────────────────────────────────── */
@media (max-width: 767px) {
  .container-fluid { padding-inline: 10px !important; }

  h1 { font-size: 24px; }
  .card-body h5 { font-size: 18px; }

  .col-lg-9 {
    h1 { font-size: 28px; margin-block-end: 1rem; }
    .d-flex { flex-wrap: wrap; gap: 0.5rem; }
    .btn { font-size: 14px; padding: 8px 16px; }
  }

  .category-filters { max-height: 150px !important; }

  .item-image {
    max-width: 100%;
    max-height: 200px;
    margin: 0 auto;
    display: block;
  }

  .quantity-controls {
    justify-content: center;

    .btn { padding: 8px 16px; font-size: 16px; min-width: 44px; }
  }
}

@media (max-width: 576px) {
  .row > * { padding-inline: 10px; }
  [class*="col-"] { width: 100%; }
}

@media (max-width: 375px) {
  .mobile-item-image { width: 60px; height: 60px; }
  .mobile-item-name { font-size: 14px; }
}

/* ── Desktop item list ──────────────────────────────────── */
.items-list { display: block; }

@media (min-width: 768px) {
  .items-list {
    border: none;
    border-radius: 0;
    overflow: visible;
  }

  .items-header {
    display: grid !important;
    grid-template-columns: 120px minmax(200px, 1fr) minmax(150px, 250px) 100px 120px 240px;
    background-color: transparent;
    border-block-end: 2px solid var(--bs-border-color);
    font-weight: 600;

    > div { padding: 0.75rem; }
    > div:last-child { text-align: left; }
  }

  .guest-view .items-header {
    grid-template-columns: 100px minmax(150px, 1fr) 120px minmax(120px, 200px) 80px 100px 180px;
  }

  .item-row {
    display: grid;
    grid-template-columns: 120px minmax(200px, 1fr) minmax(150px, 250px) 100px 120px 240px;
    border-block-end: 1px solid var(--bs-border-color);

    &:last-child { border-block-end: none; }

    > div {
      padding: 0.75rem;
      display: flex;
      align-items: center;
      background-color: transparent;
    }

    &:nth-child(odd) { background-color: var(--bs-body-bg); }
    &:nth-child(even) { background-color: var(--stripe-bg); }

    &.out-of-stock { background-color: color-mix(in srgb, #dc3545 10%, transparent) !important; }
    &.low-stock { background-color: color-mix(in srgb, #ffc107 10%, transparent) !important; }
  }

  .guest-view .item-row {
    grid-template-columns: 100px minmax(150px, 1fr) 120px minmax(120px, 200px) 80px 100px 180px;
  }

  .item-image-cell {
    justify-content: center;

    .item-thumbnail { width: 100px; aspect-ratio: 1; }
  }

  .item-categories-cell { flex-wrap: wrap; gap: 4px; }

  .item-actions-cell {
    justify-content: flex-start;

    .action-buttons { display: flex; gap: 0.5rem; white-space: nowrap; }
  }

  .item-quantity-cell .quantity-controls { justify-content: flex-start; }
}

/* ── Mobile item row (card layout) ─────────────────────── */
@media (max-width: 767px) {
  .items-list { gap: 24px; background-color: transparent; border: none; }

  .item-row {
    display: grid;
    grid-template-areas:
      "image name name"
      "image categories categories"
      "type type type"
      "quantity quantity actions";
    grid-template-columns: 80px 1fr auto;
    gap: 8px;
    padding: 16px;
    background-color: var(--card-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: var(--border-radius-lg);
    margin-block-end: 15px;

    &:last-child { margin-block-end: 0; }
  }

  .guest-view .item-row {
    grid-template-areas:
      "image name name"
      "image categories categories"
      "owner owner owner"
      "type type type"
      "quantity quantity actions";
  }

  .item-image-cell {
    grid-area: image;
    align-self: start;

    .item-thumbnail { width: 80px; aspect-ratio: 1; }
  }

  .item-name-cell {
    grid-area: name;
    font-size: 18px;
    font-weight: 600;
    align-self: center;
    line-height: 1.2;
  }

  .item-categories-cell {
    grid-area: categories;
    padding-block-start: 0;
    align-self: start;

    .badge { font-size: 11px; padding: 3px 8px; margin-block-end: 4px; }
  }

  .item-type-cell {
    grid-area: type;
    font-size: 14px;
    color: var(--text-muted);
    padding-block-start: 8px;
    border-block-start: 1px solid var(--bs-border-color);
  }

  .item-owner-cell {
    grid-area: owner;
    font-size: 14px;
    color: var(--text-muted);
    padding-block-start: 8px;
    border-block-start: 1px solid var(--bs-border-color);
  }

  .item-quantity-cell {
    grid-area: quantity;
    justify-content: flex-start;
    padding-block-start: 8px;

    .quantity-controls { gap: 8px; }
    .btn { padding: 6px 12px; font-size: 16px; min-width: 44px; min-height: 44px; }
  }

  .item-actions-cell {
    grid-area: actions;
    justify-self: end;
    padding-block-start: 8px;

    .action-buttons { display: flex; gap: 6px; }
    .btn { padding: 8px 14px; font-size: 14px; min-height: 44px; }
  }
}
