/* Dashboard */
.welcome-message {
  font-size: 14px;
  color: var(--text-secondary);
}

/* Categories */
.category-list-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--border-subtle);
  transition: background 80ms;
}

.category-list-item:hover { background: var(--bg-hover); }
.category-list-item:last-child { border-bottom: none; }
.category-list-item .category-info { flex: 1; }
.category-list-item .category-name { font-weight: 500; font-size: 13px; }
.category-list-item .category-count { font-size: 12px; color: var(--text-muted); }

/* Modifiers */
.modifier-group-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 8px;
  overflow: hidden;
}

.modifier-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  cursor: pointer;
}

.modifier-group-header:hover { background: var(--bg-hover); }
.modifier-group-title { font-weight: 500; font-size: 13px; }
.modifier-group-meta { font-size: 12px; color: var(--text-muted); }

.modifier-items-list {
  border-top: 1px solid var(--border-subtle);
  display: none;
}

.modifier-items-list.expanded { display: block; }

.modifier-item-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 16px 8px 32px;
  font-size: 13px;
  border-bottom: 1px solid var(--border-subtle);
}

.modifier-item-row:last-child { border-bottom: none; }
.modifier-price { font-family: var(--font-mono); font-size: 12px; color: var(--text-secondary); }

/* Users */
.role-badge {
  display: inline-flex;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  text-transform: capitalize;
}

.role-owner { background: var(--warning-subtle); color: var(--warning); }
.role-manager { background: var(--info-subtle); color: var(--info); }
.role-supervisor { background: var(--accent-subtle); color: var(--accent); }
.role-staff { background: var(--bg-hover); color: var(--text-secondary); }
.role-till { background: var(--success-subtle); color: var(--success); }
.role-kiosk { background: var(--bg-hover); color: var(--text-muted); }

/* Settings */
.settings-section { margin-bottom: 28px; }

.settings-section-title {
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

/* Filter tabs */
.filter-tabs {
  display: flex;
  gap: 4px;
  overflow-x: auto;
}

.filter-tabs::-webkit-scrollbar { height: 0; }

.filter-tab {
  padding: 4px 12px;
  border-radius: 16px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all 120ms;
  white-space: nowrap;
  background: transparent;
  color: var(--text-muted);
  border: 1px solid var(--border);
}

.filter-tab:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}

.filter-tab.active {
  background: var(--accent);
  color: white;
  border-color: var(--accent);
}

/* Stock level */
.stock-level-cell {
  padding: 2px 6px;
  border-radius: 4px;
  margin: -2px -6px;
  transition: background 80ms;
}

.stock-level-cell:hover {
  background: var(--bg-hover);
}

/* ═══════ MENU DESIGNER ═══════ */
.md-layout {
  display: flex;
  height: calc(100vh - 160px);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  background: var(--bg-card);
}
.md-left {
  width: 260px; flex-shrink: 0;
  border-right: 1px solid var(--border);
  display: flex; flex-direction: column;
  background: var(--bg-panel);
}
.md-center {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column;
}
.md-right {
  width: 280px; flex-shrink: 0;
  border-left: 1px solid var(--border);
  display: flex; flex-direction: column;
  background: var(--bg-panel);
}
.md-menu-item {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px; border-radius: 6px;
  cursor: pointer; transition: background 0.1s;
}
.md-menu-item:hover { background: var(--bg-hover); }
.md-menu-item.active { background: var(--accent-dim); }
/* Always show the kebab — opacity:0 made it invisible at rest and
   opacity:0.45 against a dark bg on a muted-text button was still too
   faint. Give it a subtle filled background instead so it reads as a
   tap target regardless of theme. */
.md-menu-actions { opacity: 1; }
.md-menu-actions .btn.btn-ghost {
  background: var(--bg-elevated, rgba(255, 255, 255, 0.06));
  color: var(--text-primary);
  font-size: 18px;
  line-height: 1;
}
.md-menu-actions .btn.btn-ghost:hover {
  background: var(--bg-hover);
}

.md-section-tab {
  display: flex; align-items: center; gap: 6px;
  padding: 10px 16px; cursor: pointer;
  font-size: 13px; font-weight: 600;
  white-space: nowrap; border-bottom: 2px solid transparent;
  transition: all 0.15s; flex-shrink: 0;
}
.md-section-tab:hover { background: var(--bg-hover); }
.md-section-tab.active { color: var(--text-primary); }
.md-section-tab.drag-over { border-left: 2px solid var(--accent); }
.md-section-color {
  width: 10px; height: 10px; border-radius: 50%;
  flex-shrink: 0;
}

/* Layout Designer Grid Cells */
.ld-cell {
  border-radius: 8px;
  min-height: 50px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  position: relative;
  transition: all 0.12s;
  overflow: hidden;
}
.ld-cell-empty {
  border: 2px dashed var(--border);
  cursor: pointer;
  background: var(--bg-panel);
}
.ld-cell-empty:hover {
  border-color: var(--accent);
  background: var(--accent-dim);
}
.ld-cell-placeholder {
  font-size: 20px;
  color: var(--text-muted);
  opacity: 0.3;
}
.ld-cell-filled {
  cursor: grab;
  color: white;
  text-align: center;
  padding: 8px 6px;
}
.ld-cell-filled::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.08) 0%, transparent 60%);
  pointer-events: none;
}
.ld-cell-name {
  font-weight: 600; font-size: 12px; line-height: 1.2;
  z-index: 1; word-break: break-word;
}
.ld-cell-price {
  font-family: 'JetBrains Mono', monospace;
  font-weight: 700; font-size: 13px;
  color: rgba(255,255,255,0.85);
  z-index: 1;
}
.ld-cell-remove {
  position: absolute; top: 3px; right: 4px;
  width: 18px; height: 18px;
  display: none; align-items: center; justify-content: center;
  border-radius: 4px; cursor: pointer;
  font-size: 14px; color: rgba(255,255,255,0.8);
  background: rgba(0,0,0,0.3); z-index: 2;
}
.ld-cell-color {
  position: absolute; top: 3px; left: 4px;
  width: 18px; height: 18px;
  display: none; align-items: center; justify-content: center;
  border-radius: 4px; cursor: pointer;
  color: rgba(255,255,255,0.8);
  background: rgba(0,0,0,0.3); z-index: 2;
}
.ld-cell-edit {
  position: absolute; bottom: 3px; left: 4px;
  width: 18px; height: 18px;
  display: none; align-items: center; justify-content: center;
  border-radius: 4px; cursor: pointer;
  color: rgba(255,255,255,0.8);
  background: rgba(0,0,0,0.3); z-index: 2;
}
.ld-cell-edit:hover { background: rgba(0,0,0,0.5); }
.ld-cell-plu {
  font-size: 8px;
  color: rgba(255,255,255,0.4);
  z-index: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 100%;
}
.ld-cell-filled:hover .ld-cell-remove,
.ld-cell-filled:hover .ld-cell-color,
.ld-cell-filled:hover .ld-cell-edit { display: flex; }
.ld-cell-remove:hover { background: rgba(239,68,68,0.6); }
.ld-cell-color:hover { background: rgba(0,0,0,0.5); }

.drag-over {
  background: var(--accent-dim) !important;
  border-color: var(--accent) !important;
}
.ld-cell-filled.drag-over {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}

.md-palette-group { margin-bottom: 8px; }
.md-palette-cat {
  font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--text-muted); padding: 6px 8px;
}
.md-palette-item {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px; border-radius: 6px;
  cursor: grab; transition: background 0.1s;
}
.md-palette-item:hover { background: var(--bg-hover); }
.md-palette-item.dimmed { opacity: 0.35; cursor: default; }

.md-schedule-row {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 8px; border-radius: 6px;
  transition: background 0.1s;
}
.md-schedule-row:hover { background: var(--bg-hover); }

.md-context-menu {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
  min-width: 160px;
  overflow: hidden;
}
.md-ctx-item {
  padding: 10px 14px;
  font-size: 13px;
  cursor: pointer;
  transition: background 0.1s;
}
.md-ctx-item:hover { background: var(--bg-hover); }
.md-ctx-item.danger { color: var(--danger); }
.md-ctx-item.danger:hover { background: var(--danger-dim); }

/* ═══════ RECEIPT DESIGNER ═══════ */
.rd-layout {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  height: calc(100vh - 120px);
  overflow: hidden;
}
.rd-controls-scroll {
  overflow-y: auto;
  height: 100%;
  padding-right: 8px;
  min-width: 0;
}
.rd-controls-scroll::-webkit-scrollbar { width: 4px; }
.rd-controls-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.rd-preview-scroll {
  overflow-y: auto;
  height: 100%;
  padding: 0 4px 0 0;
}
.rd-preview-scroll::-webkit-scrollbar { width: 4px; }
.rd-preview-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.rd-preview-label {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.5px; color: var(--text-muted); margin-bottom: 8px;
}
.rd-sections { display:grid; gap:14px; }
.rd-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px 16px;
  display: grid;
  gap: 10px;
}
.rd-card-title { font-weight: 600; font-size: 13px; }
.rd-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.rd-toggles { display: flex; flex-wrap: wrap; gap: 6px 14px; }
.rd-toggle {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; cursor: pointer; white-space: nowrap;
}
.rd-toggle input[type="checkbox"] { margin: 0; }

/* ═══════ BOOKING MODAL DESIGNER ═══════ */
.bm-designer-layout {
  display: grid;
  grid-template-columns: minmax(380px, 1fr) minmax(420px, 1fr);
  gap: 24px;
  height: calc(100vh - 180px);
  overflow: hidden;
}
.bm-designer-controls {
  overflow-y: auto;
  height: 100%;
  padding-right: 8px;
  min-width: 0;
  display: grid;
  gap: 14px;
  align-content: start;
}
.bm-designer-controls::-webkit-scrollbar { width: 4px; }
.bm-designer-controls::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.bm-designer-preview {
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
}
.bm-designer-preview-toolbar {
  display: flex; gap: 8px; align-items: center; flex-shrink: 0;
}
.bm-designer-stage-wrap {
  flex: 1 1 auto;
  min-height: 0;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px;
}
.bm-designer-stage {
  background: #000;
  border-radius: 4px;
  overflow: hidden;
  position: relative;
  box-shadow: 0 4px 24px rgba(0,0,0,0.5);
}
.bm-designer-stage iframe {
  border: 0;
  background: #000;
  transform-origin: top left;
}
.bm-pl-row {
  display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 8px;
}

.receipt-preview {
  display: flex;
  justify-content: center;
}
.receipt-paper {
  width: 302px;
  background: white;
  padding: 20px 16px;
  font-family: 'Courier New', Courier, monospace;
  font-size: 11px;
  line-height: 1.5;
  color: #1a1a1a;
  box-shadow: 0 2px 12px rgba(0,0,0,0.1);
  overflow-x: hidden;
}
.receipt-line { min-height: 1em; padding: 0.5px 0; }
.receipt-line-lr { display: flex; justify-content: space-between; gap: 8px; padding: 0.5px 0; }
.receipt-line-spread { display: flex; justify-content: space-between; padding: 0.5px 0; }
.receipt-line-lr .rl-left { flex: 1; min-width: 0; }
.receipt-line-lr .rl-right { flex-shrink: 0; text-align: right; }
.receipt-sep { border: none; border-top: 1px solid #1a1a1a; margin: 3px 0; }
.receipt-sep-dbl { border: none; border-top: 3px double #1a1a1a; margin: 3px 0; }
.receipt-sep-dots { border: none; border-top: 1px dotted #aaa; margin: 3px 0; }
.receipt-sep-stars { text-align: center; color: #1a1a1a; letter-spacing: 1px; }
.receipt-large { font-size: 20px; line-height: 1.5; font-weight: 700; }
.receipt-medium { font-size: 16px; line-height: 1.5; font-weight: 700; }
.receipt-bold { font-weight: 700; }
.receipt-small { font-size: 9.5px; color: #555; }
.receipt-muted { font-size: 9.5px; color: #888; }
.receipt-center { text-align: center; }

/* Pulse animation for active session dot */
@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

/* ═══════════════════════════════════════════ */
/*  PRODUCT EDITOR                            */
/* ═══════════════════════════════════════════ */
.pe-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 24px;
  border-bottom: 1px solid var(--border);
  background: var(--bg-surface);
}
.pe-header-left {
  display: flex;
  align-items: center;
  gap: 12px;
}
.pe-header-right {
  display: flex;
  align-items: center;
  gap: 10px;
}
.pe-tabs {
  display: flex;
  gap: 0;
  border-bottom: 1px solid var(--border);
  padding: 0 24px;
  background: var(--bg-surface);
}
.pe-tab {
  padding: 12px 20px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: all 0.15s;
  display: flex;
  align-items: center;
  gap: 6px;
}
.pe-tab:hover { color: var(--text-primary); }
.pe-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.pe-body {
  padding: 24px;
  max-width: 1100px;
}
.pe-form-grid {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 24px;
}
.pe-form-main { min-width: 0; }
.pe-form-sidebar { min-width: 0; }

@media (max-width: 900px) {
  .pe-form-grid {
    grid-template-columns: 1fr;
  }
  .pe-form-sidebar { order: -1; }
}

/* Product row hover in list */
.product-row:hover {
  background: var(--bg-hover);
}

/* Allergen UI */
.pe-allergen-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.pe-allergen-pill {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 20px;
  border: 1px solid;
  font-size: 12px;
}
.pe-allergen-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.pe-allergen-manual-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 24px;
}
.pe-allergen-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 6px 0;
}
@media (max-width: 700px) {
  .pe-allergen-manual-grid { grid-template-columns: 1fr; }
}

/* Segmented allergen severity buttons */
.allergen-seg {
  display: inline-flex;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--border);
  flex-shrink: 0;
}
.allergen-seg-btn {
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  border: none;
  background: transparent;
  color: var(--text-muted);
  transition: all 0.15s ease;
  border-right: 1px solid var(--border);
  white-space: nowrap;
  line-height: 1.4;
}
.allergen-seg-btn:last-child { border-right: none; }
.allergen-seg-btn:hover:not(.active) { background: var(--bg-surface); }
.allergen-seg-btn.active[data-val="contains"] {
  background: var(--danger);
  color: #fff;
}
.allergen-seg-btn.active[data-val="may_contain"] {
  background: #d97706;
  color: #fff;
}
.allergen-seg-btn.active[data-val="trace"] {
  background: var(--text-muted);
  color: #fff;
}

/* Audit log table rows */
.audit-row:hover td { background: var(--bg-surface); }

/* ═══════════════════════════════════════════ */
/*  BOOKINGS DIARY GRID                        */
/* ═══════════════════════════════════════════ */
.diary-toolbar {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
  padding: 12px 16px; background: var(--bg-card);
  border-bottom: 1px solid var(--border);
}
.diary-toolbar .form-input,
.diary-toolbar .form-select { height: 32px; font-size: 13px; padding: 4px 10px; }

.diary-wrapper {
  position: relative; overflow: auto;
  background: var(--bg-page); padding: 8px;
  user-select: none; -webkit-user-select: none;
  height: calc(100vh - var(--header-height) - 120px);
}

.diary-grid {
  display: grid;
  grid-template-columns: 110px repeat(var(--diary-slots, 28), 1fr);
  gap: 1px; background: var(--border);
  border-radius: var(--radius-sm); overflow: hidden;
  font-size: 11px; min-width: max-content;
}

.diary-header-cell {
  background: var(--bg-table-header);
  font-weight: 600; padding: 4px 2px;
  text-align: center; font-size: 10px;
  color: var(--text-secondary);
  border-bottom: 2px solid var(--border);
  position: sticky; top: 0; z-index: 5;
  display: flex; align-items: center; justify-content: center;
  min-height: 28px;
}
.diary-header-cell.table-header {
  text-align: left; padding-left: 10px; justify-content: flex-start;
  position: sticky; left: 0; z-index: 6;
  background: var(--bg-table-header);
  font-size: 11px; color: var(--text-primary);
}
.diary-header-cell.time-header { font-weight: 700; color: var(--text-primary); }
.diary-header-cell.minor { color: var(--text-muted); font-weight: 400; font-size: 9px; }

.diary-cell {
  background: var(--bg-card);
  position: relative;
  min-height: 36px; min-width: 0;
  border-right: 1px solid var(--border-subtle);
}
/* Table-row cells are clickable (walk-in wizard). iOS Safari only fires
   click on non-interactive elements when cursor: pointer is set. */
.diary-cell[data-table-id] { cursor: pointer; }
.diary-cell.hour-marker { border-right: 2px solid var(--border); }
.diary-cell.half-hour-marker { border-right: 1px solid var(--border-subtle); }
.diary-cell.closed {
  background-image: repeating-linear-gradient(
    45deg,
    transparent 0,
    transparent 6px,
    rgba(0,0,0,0.025) 6px,
    rgba(0,0,0,0.025) 12px
  );
}
.diary-cell.closed.row-enquiries  { background-color: rgba(245, 158, 11, 0.03); }
.diary-cell.closed.row-unassigned { background-color: rgba(99, 91, 255, 0.02); }

.diary-row-label {
  background: var(--bg-card);
  padding: 6px 10px; font-size: 12px; font-weight: 500;
  position: sticky; left: 0; z-index: 4;
  border-right: 2px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; gap: 6px;
}
.diary-row-label .row-name {
  font-weight: 600; color: var(--text-primary);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  flex: 1; min-width: 0;
}
.diary-row-label .row-meta {
  font-size: 10px; color: var(--text-muted); white-space: nowrap;
}

.diary-cell.row-enquiries     { background: rgba(245, 158, 11, 0.06); }
.diary-cell.row-unassigned    { background: rgba(99, 91, 255, 0.04); }
.diary-row-label.row-enquiries  { background: rgba(245, 158, 11, 0.08); }
.diary-row-label.row-unassigned { background: rgba(99, 91, 255, 0.06); }

/* Section divider — thin gap row between Enquiries / Unassigned / Tables.
   Visually breaks up the three logical sections of the diary. */
.diary-section-divider {
  grid-column: 1 / -1;
  height: 8px;
  background: var(--bg-page);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

/* Section heading row — sits between dividers, identifies the
   following block of rows (e.g. "Tables"). Spans the full grid width. */
.diary-section-heading {
  grid-column: 1 / -1;
  background: var(--bg-table-header);
  padding: 6px 12px;
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.5px;
  color: var(--text-secondary);
  position: sticky; left: 0;
  border-bottom: 1px solid var(--border);
}

.diary-cell.drag-over {
  background: var(--accent-subtle) !important;
  outline: 2px dashed var(--accent);
  outline-offset: -2px;
}

.diary-block {
  position: absolute;
  left: 3px; right: 3px;
  height: 32px;
  border-radius: 4px; padding: 4px 8px;
  font-size: 13px; line-height: 1.2; color: #fff;
  background: linear-gradient(135deg, var(--accent), var(--accent-hover));
  cursor: grab; box-shadow: var(--shadow-xs);
  display: flex; align-items: center; gap: 8px;
  white-space: nowrap; overflow: hidden;
  z-index: 2; transition: transform 0.12s, box-shadow 0.12s;
}
.diary-block:hover {
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm); z-index: 3;
}
.diary-block.dragging { opacity: 0.4; cursor: grabbing; }
.diary-block.locked { cursor: not-allowed; opacity: 0.95; }

.diary-block.status-pending       { background: linear-gradient(135deg, #f59e0b, #d97706); }
.diary-block.status-confirmed     { background: linear-gradient(135deg, #635bff, #5046e5); }
.diary-block.status-arrived       { background: linear-gradient(135deg, #10b981, #059669); }
.diary-block.status-left          { background: linear-gradient(135deg, #6b7280, #4b5563); }
.diary-block.status-no_show       { background: linear-gradient(135deg, #dc2626, #991b1b); }
.diary-block.status-cancelled     { background: linear-gradient(135deg, #9ca3af, #6b7280); opacity: 0.6; }
.diary-block.status-private_event { background: linear-gradient(135deg, #2563eb, #1e40af); }

.diary-block .party {
  background: rgba(255,255,255,0.25);
  padding: 2px 8px; border-radius: 4px;
  font-weight: 700; font-size: 14px; flex-shrink: 0;
}
.diary-block .name {
  font-weight: 600; font-size: 14px;
  overflow: hidden; text-overflow: ellipsis;
  min-width: 0; flex: 0 1 auto;
}
.diary-block .type-tag {
  padding: 2px 7px; border-radius: 4px;
  font-size: 11px; font-weight: 700; flex-shrink: 0;
  text-transform: uppercase; letter-spacing: 0.4px;
}
.diary-block .dash {
  font-weight: 600; opacity: 0.6; flex-shrink: 0;
}
.diary-block .indicators {
  display: inline-flex; gap: 4px; flex-shrink: 0;
}
.diary-block .indicator {
  padding: 1px 5px; border-radius: 3px; font-size: 13px;
  background: rgba(255,255,255,0.25);
}

.diary-now-line {
  position: absolute; top: 0; bottom: 0;
  width: 2px; background: var(--danger);
  z-index: 7; pointer-events: none;
  box-shadow: 0 0 4px rgba(220, 38, 38, 0.5);
}
.diary-now-line::before {
  content: ''; position: absolute; top: -4px; left: -4px;
  width: 10px; height: 10px; background: var(--danger);
  border-radius: 50%;
}

.diary-empty {
  padding: 60px 20px; text-align: center; color: var(--text-muted);
}

/* ──────────────────────────────────────────────────────────────── */
/* Pre-Order editor — 3-pane POS layout                              */
/* Pane 1: vertical category list. Pane 2: product grid.             */
/* Pane 3: running order. Footer: totals + payment mode + send link. */
/* Visually mirrors till.html (cat-tab/product-btn/order-panel).     */
/* ──────────────────────────────────────────────────────────────── */
.po-shell {
  display: flex;
  flex-direction: column;
  height: calc(100vh - 56px); /* topbar */
  background: var(--bg-base);
  overflow: hidden;
}

/* Header card (booking summary + status banner) */
.po-summary {
  flex-shrink: 0;
  padding: 10px 16px;
  background: var(--bg-surface);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}
.po-summary-block {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.po-summary-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.po-summary-value {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
}
.po-summary-divider {
  width: 1px;
  height: 28px;
  background: var(--border);
}
.po-summary-spacer { flex: 1; }

/* Three-pane working area */
.po-panes {
  flex: 1;
  display: grid;
  grid-template-columns: 200px 1fr 400px;
  min-height: 0;
  background: var(--bg-base);
}

/* Pane 1 — Categories (vertical list) */
.po-categories {
  background: var(--bg-panel);
  border-right: 1px solid var(--border);
  overflow-y: auto;
  padding: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.po-cat-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  min-height: 48px;
  border-radius: 8px;
  border: 1px solid transparent;
  background: var(--bg-card);
  color: var(--text-secondary);
  font-weight: 600;
  font-size: 13px;
  cursor: pointer;
  user-select: none;
  transition: all 0.12s;
  text-align: left;
  line-height: 1.2;
  position: relative;
}
.po-cat-row:hover {
  background: var(--bg-hover);
  color: var(--text-primary);
}
.po-cat-row.active {
  color: #fff;
  border-color: rgba(255,255,255,0.15);
  box-shadow: 0 0 0 1px var(--border-light, var(--border)) inset;
}
.po-cat-swatch {
  width: 4px;
  align-self: stretch;
  border-radius: 2px;
  background: var(--accent);
  flex-shrink: 0;
}
.po-cat-row.active .po-cat-swatch { background: rgba(255,255,255,0.6); }
.po-cat-name { flex: 1; min-width: 0; word-break: break-word; }
.po-cat-empty {
  padding: 20px 14px;
  color: var(--text-muted);
  font-size: 12px;
  text-align: center;
}

/* Pane 2 — Product grid */
.po-products {
  background: var(--bg-card);
  overflow-y: auto;
  padding: 10px;
}
.po-product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 8px;
}
.po-product-btn {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 8px 6px;
  min-height: 92px;
  border: none;
  border-radius: 8px;
  background: linear-gradient(145deg, #6c5ce7, #5a4bd1);
  color: #fff;
  cursor: pointer;
  text-align: center;
  font-family: inherit;
  transition: transform 0.08s ease, filter 0.12s ease;
  overflow: hidden;
}
.po-product-btn::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.08) 0%, transparent 60%);
  pointer-events: none;
}
.po-product-btn:hover:not(:disabled) { filter: brightness(1.08); }
.po-product-btn:active:not(:disabled) { transform: scale(0.96); filter: brightness(0.85); }
.po-product-btn .name {
  font-size: 12px;
  font-weight: 600;
  line-height: 1.2;
  text-shadow: 0 1px 3px rgba(0,0,0,0.3);
  z-index: 1;
}
.po-product-btn .price {
  font-family: 'JetBrains Mono', monospace, sans-serif;
  font-size: 12px;
  font-weight: 700;
  opacity: 0.92;
  z-index: 1;
}
.po-product-btn.sold-out {
  filter: grayscale(1) brightness(0.45);
  cursor: not-allowed;
}
.po-product-btn:disabled { cursor: not-allowed; }
.po-products-empty {
  padding: 40px 20px;
  text-align: center;
  color: var(--text-muted);
  font-size: 13px;
}

/* Pane 3 — Order (running list) */
.po-order {
  background: var(--bg-panel);
  border-left: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  min-height: 0;
}
.po-order-header {
  flex-shrink: 0;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--bg-card);
}
.po-order-title {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.3px;
}
.po-order-count {
  font-size: 11px;
  color: var(--text-muted);
  font-weight: 600;
}
.po-order-banner-slot {
  flex-shrink: 0;
}
.po-order-banner-slot .po-banner { margin: 12px 16px 0; }
.po-order-items {
  flex: 1;
  overflow-y: auto;
  padding: 4px 0;
}
.po-order-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: var(--text-muted);
  padding: 40px 20px;
  text-align: center;
}
.po-order-empty-icon { font-size: 36px; opacity: 0.3; }
.po-order-empty-text { font-size: 13px; }
.po-item-list {
  display: flex;
  flex-direction: column;
}
.po-item {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
}
.po-item:last-child { border-bottom: none; }
.po-item-top {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.po-item-name {
  flex: 1;
  font-weight: 600;
  font-size: 13.5px;
  line-height: 1.3;
  min-width: 0;
}
.po-item-line-price {
  font-family: 'JetBrains Mono', monospace, sans-serif;
  font-weight: 700;
  font-size: 13.5px;
  color: var(--text-primary);
  min-width: 70px;
  text-align: right;
}
.po-item-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 2px;
}
.po-item-mods {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
}
.po-item-notes {
  font-size: 11px;
  font-style: italic;
  color: var(--text-secondary);
  margin-top: 2px;
}
.po-item-allergy {
  font-size: 11px;
  color: var(--warning);
  font-weight: 600;
  margin-top: 2px;
}
.po-item-actions {
  display: flex;
  gap: 4px;
}
.po-item-action {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--bg-card);
  color: var(--text-secondary);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  transition: all 0.12s;
}
.po-item-action:hover:not(:disabled) {
  background: var(--bg-hover);
  color: var(--text-primary);
}
.po-item-action.danger:hover:not(:disabled) {
  background: var(--danger-dim, rgba(239,68,68,0.15));
  color: var(--danger);
  border-color: var(--danger);
}
.po-item-action:disabled { opacity: 0.35; cursor: not-allowed; }
.po-qty {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.po-qty-btn {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  border: 1px solid var(--border);
  background: var(--bg-card);
  color: var(--text-primary);
  cursor: pointer;
  font-size: 14px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.12s;
}
.po-qty-btn:hover:not(:disabled) { background: var(--bg-hover); }
.po-qty-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.po-qty-num {
  min-width: 28px;
  text-align: center;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  font-family: 'JetBrains Mono', monospace, sans-serif;
  font-size: 13px;
}

/* Order totals + payment */
.po-totals {
  flex-shrink: 0;
  border-top: 1px solid var(--border);
  background: var(--bg-card);
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.po-totals-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 12px;
  color: var(--text-muted);
}
.po-totals-row .value {
  font-family: 'JetBrains Mono', monospace, sans-serif;
  font-weight: 600;
}
.po-totals-row.total {
  margin-top: 6px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
}
.po-totals-row.total .label {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
}
.po-totals-row.total .value {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
}

/* Footer bar */
.po-footer {
  flex-shrink: 0;
  display: grid;
  grid-template-columns: 200px 200px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 10px 14px;
  background: var(--bg-surface);
  border-top: 1px solid var(--border);
}
.po-footer-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.po-footer-field .form-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-muted);
  margin: 0;
}
.po-footer-field .form-select,
.po-footer-field .form-input {
  font-size: 13px;
  padding: 6px 10px;
  height: 34px;
}
.po-footer-field textarea.form-input {
  height: 34px;
  min-height: 34px;
  resize: none;
}
.po-footer-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}
.po-footer-actions .btn { height: 38px; padding: 0 16px; }

/* Read-only veil — disable interaction visually inside panes 1 & 2 */
.po-panes.readonly .po-cat-row,
.po-panes.readonly .po-product-btn {
  cursor: not-allowed;
  filter: grayscale(0.6) brightness(0.85);
}

/* Status banner (unchanged tones) */
.po-banner {
  padding: 10px 14px;
  border-radius: 6px;
  font-size: 13px;
  border-left: 3px solid;
}
.po-banner-info    { background: var(--accent-subtle, rgba(99,102,241,0.1));    border-left-color: var(--accent); }
.po-banner-warning { background: var(--warning-subtle, rgba(245,158,11,0.1));   border-left-color: var(--warning); color: var(--text-primary); }
.po-banner-success { background: var(--success-subtle, rgba(34,197,94,0.1));    border-left-color: var(--success); }
.po-banner-danger  { background: var(--danger-subtle, rgba(239,68,68,0.1));     border-left-color: var(--danger); }

/* Responsive — collapse to vertical stack on narrow screens */
@media (max-width: 1100px) {
  .po-panes {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto 1fr;
  }
  .po-categories {
    flex-direction: row;
    overflow-x: auto;
    overflow-y: hidden;
    border-right: none;
    border-bottom: 1px solid var(--border);
    padding: 8px;
    gap: 6px;
    max-height: 70px;
  }
  .po-cat-row {
    flex: 0 0 auto;
    min-width: 110px;
    padding: 8px 12px;
    min-height: 0;
  }
  .po-order {
    border-left: none;
    border-top: 1px solid var(--border);
    max-height: 50vh;
  }
  .po-footer {
    grid-template-columns: 1fr 1fr;
  }
  .po-footer-actions {
    grid-column: 1 / -1;
    justify-content: flex-end;
  }
}

/* Modifier modal */
.po-mod-group { margin-bottom: 16px; }
.po-mod-group-label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.po-mod-required {
  font-size: 10px;
  font-weight: 600;
  background: var(--warning);
  color: #fff;
  padding: 2px 6px;
  border-radius: 4px;
  letter-spacing: 0;
  text-transform: none;
}
.po-mod-options {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.po-mod-opt {
  padding: 7px 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg-card);
  color: var(--text-primary);
  font-size: 13px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all 0.12s;
  font-family: inherit;
}
.po-mod-opt:hover { background: var(--bg-hover); }
.po-mod-opt.selected {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.po-mod-price {
  font-size: 11px;
  opacity: 0.85;
}
