/* FILE: site/drawer.css */
/* Isolated drawer/widget styles to maintain parity and avoid drift */
:root {
  --mb-z: 2000;
  --mb-overlay: rgba(0,0,0,0.5);

  /* Panel and typography (theme-aware with safe light fallbacks) */
  --mb-panel-bg: var(--surface, #ffffff);
  --mb-text: var(--text, #0f2630);
  --mb-muted: var(--muted, #48606a);
  --mb-border: var(--divider, #e7f3ee);

  --mb-radius: var(--radius, 14px);
  --mb-shadow: var(--shadow-lg, 0 12px 34px rgba(0,0,0,0.35));
  --mb-gap: 12px;

  /* Button accents (theme-aware fallbacks) */
  --mb-primary: var(--accent, #0ea5e9);
  --mb-primary-ink: #ffffff;
  --mb-success: #22c55e;
  --mb-success-ink: #052e12;
  --mb-outline-ink: var(--mb-text);

  /* Hover surface (light fallback) */
  --mb-hover: #f4f7fb;

  /* Availability palette */
  --mb-available: #16a34a; /* green-600 */
  --mb-limited: #f59e0b;   /* amber-500 */
  --mb-booked: #dc2626;    /* red-600 */
  --mb-past: #9ca3af;      /* gray-400 */
  --mb-cal-bg: var(--surface-light, #fff);
}

/* Dark theme tokens for the drawer, scoped to your site body theme */
.theme--mint-carnival .mb-drawer {
  /* Dark surfaces */
  --surface: #0f172a;          /* panel background (slate-900) */
  --surface-light: #111827;    /* inner cards/controls (gray-900) */
  --surface-contrast: #0b1220; /* bottom bar or stronger contrast */

  /* Type and dividers */
  --text: #e5e7eb;             /* primary text (gray-200) */
  --muted: #94a3b8;            /* secondary text (slate-400) */
  --divider: #334155;          /* borders (slate-600) */

  /* Accent color */
  --accent: #22d3ee;           /* cyan-400 */

  /* Dark-friendly hover */
  --mb-hover: #1f2937;         /* gray-800 */
}

/* Prevent background scroll when drawer open (matches site convention) */
.body--no-scroll { overflow: hidden; }

/* Closed state */
.mb-drawer[aria-hidden="true"] { display: none; }
.mb-drawer {
  position: fixed;
  inset: 0;
  z-index: var(--mb-z);
  display: grid;
  grid-template-rows: 1fr;
  grid-template-columns: 1fr;
}

/* Overlay covers full viewport */
.mb-drawer__overlay {
  position: absolute;
  inset: 0;
  background: var(--mb-overlay);
  backdrop-filter: saturate(120%) blur(2px);
  -webkit-backdrop-filter: saturate(120%) blur(2px);
}

/* Panel: bottom sheet on mobile, right sheet on desktop */
.mb-drawer__panel {
  position: absolute;
  display: grid;
  grid-template-rows: auto 1fr;
  gap: var(--mb-gap);
  background: var(--mb-panel-bg);
  color: var(--mb-text);
  box-shadow: var(--mb-shadow);
  border: 1px solid var(--mb-border);
  border-radius: var(--mb-radius);
  max-height: 85vh;
  width: 100%;
  left: 0;
  right: 0;
  bottom: 0;
  /* Bottom-sheet: slide up */
  transform: translateY(100%);
  transition: transform 180ms ease;
  will-change: transform;
  outline: none;
}
.mb-drawer:not([aria-hidden="true"]) .mb-drawer__panel,
.mb-drawer.open .mb-drawer__panel {
  transform: translateY(0);
}

/* Desktop/right-side sheet */
@media (min-width: 900px) {
  .mb-drawer__panel {
    top: 0;
    bottom: 0;
    max-height: 100vh;
    height: 100%;
    width: min(520px, 92vw);
    left: auto;
    right: 0;
    border-radius: 0;
    border-left: 1px solid var(--mb-border);
    /* Slide in from right on desktop */
    transform: translateX(100%);
  }
  .mb-drawer:not([aria-hidden="true"]) .mb-drawer__panel,
  .mb-drawer.open .mb-drawer__panel {
    transform: translateX(0);
  }
}

/* Header row inside panel */
.mb-drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--mb-gap);
  padding: 12px 12px 0 12px;
}
.mb-drawer__title {
  margin: 0;
  font-weight: 800;
  font-size: 18px;
  color: var(--mb-text);
}

/* Content area */
.mb-drawer__content {
  overflow: auto;
  padding: 0 12px 12px 12px;
  color: var(--mb-text);
}

/* Close button */
.mb-drawer__close {
  border: 1px solid var(--mb-border);
  background: var(--mb-panel-bg);
  color: var(--mb-text);
  border-radius: 10px;
  padding: 6px 10px;
  cursor: pointer;
}
.mb-drawer__close:hover {
  background: var(--mb-hover);
}

/* Interior components (unified naming) */
.mb-stack { display: grid; grid-template-columns: 1fr; gap: 12px; }

/* Use surface-light for card-like sections to avoid white on dark */
.mb-section {
  background: var(--surface-light, #fff);
  border: 1px solid var(--mb-border);
  border-radius: 12px;
  padding: 12px;
}
.mb-section__title {
  margin: 0 0 6px 0;
  font-weight: 800;
  font-size: 16px;
  color: var(--mb-text);
}
.mb-section__desc {
  margin: 0 0 10px 0;
  color: var(--mb-muted);
  font-weight: 600;
  font-size: 14px;
}
.mb-divider { height: 1px; background: var(--mb-border); margin: 10px 0; }

.mb-grid-two { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 720px) { .mb-grid-two { grid-template-columns: 1fr; } }

.mb-label { display: block; font-size: 12px; color: var(--mb-muted); margin-bottom: 6px; }

/* Inputs and controls use surface-light to avoid white defaults */
.mb-input,
.mb-select,
.mb-textarea {
  width: 100%;
  border: 1px solid var(--mb-border);
  border-radius: 10px;
  padding: 10px 12px;
  background: var(--surface-light, #fff);
  color: var(--mb-text);
  box-sizing: border-box;
  max-width: 100%;
}
.mb-row { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }

.mb-item { display: flex; gap: 12px; align-items: center; }
.mb-item img {
  width: 96px;
  height: 72px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid var(--mb-border);
}
.mb-price { color: var(--mb-muted); font-weight: 700; }
.mb-right { margin-left: auto; text-align: right; }

/* Buttons */
.mb-btn {
  border-radius: 10px;
  padding: 10px 14px;
  cursor: pointer;
  font-weight: 800;
  border: 1px solid transparent;
  background: var(--surface-light, #fff);
  color: var(--mb-text);
}
.mb-btn.primary {
  background: var(--mb-primary);
  color: var(--mb-primary-ink);
  border-color: var(--mb-primary);
}
.mb-btn.primary:hover { filter: brightness(0.96); }
.mb-btn.outline {
  background: transparent;
  color: var(--mb-outline-ink);
  border-color: var(--mb-border);
}
.mb-btn.outline:hover { background: var(--mb-hover); }
.mb-btn.success {
  background: var(--mb-success);
  color: var(--mb-success-ink);
  border-color: color-mix(in srgb, var(--mb-success) 84%, #0c3b1f);
}
.mb-btn.success:hover { filter: brightness(0.96); }

/* Qty control */
.mb-qty {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--mb-border);
  border-radius: 10px;
  padding: 4px 8px;
}
.mb-qty button {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  border: 1px solid var(--mb-border);
  background: var(--surface-light, #fff);
  color: var(--mb-text);
  cursor: pointer;
}
.mb-qty button:hover { background: var(--mb-hover); }

/* Bottom bar */
.mb-darkbar {
  display: flex;
  gap: 8px;
  justify-content: space-between;
  align-items: center;
  background: var(--surface-contrast, #f6f8ff);
  border: 1px solid var(--mb-border);
  border-radius: 12px;
  padding: 10px;
  color: var(--mb-text);
}

/* Inline state message */
.mb-state { margin-top: 8px; min-height: 16px; font-size: 14px; }
.mb-state.ok { color: #0f766e; font-weight: 700; }
.mb-state.err { color: #b42318; font-weight: 700; }

/* Accessibility: focus, placeholder, autofill on dark */
.mb-drawer :where(.mb-input, .mb-select, .mb-textarea, .mb-qty button, .mb-btn, .mb-drawer__close):focus-visible {
  outline: 2px solid var(--mb-primary);
  outline-offset: 2px;
}
.mb-drawer ::placeholder {
  color: var(--mb-muted);
  opacity: 1;
}
/* Autofill fix to keep dark surface readable */
.mb-drawer input:-webkit-autofill,
.mb-drawer input:-webkit-autofill:hover,
.mb-drawer input:-webkit-autofill:focus,
.mb-drawer textarea:-webkit-autofill,
.mb-drawer select:-webkit-autofill {
  -webkit-text-fill-color: var(--mb-text);
  transition: background-color 9999s ease-in-out 0s;
  box-shadow: 0 0 0px 1000px var(--surface-light, #fff) inset;
}

/* ——————————————————————————————————————————————
   Schedule layout: side-by-side Start/End date & time that fit on mobile
   Avoid overlap by allowing shrink and using compact controls in-context
   —————————————————————————————————————————————— */

/* 1) If date/time fields live inside a .mb-row, create a tight, non-wrapping two-up row */
.theme--mint-carnival .mb-drawer .mb-row:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
}

/* Ensure each field can shrink to fit without forcing overflow */
.theme--mint-carnival .mb-drawer .mb-row:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) > .mb-field {
  flex: 1 1 0;
  min-width: 0;            /* allow flex children to shrink */
}

/* Compact the date/time inputs only in this schedule context */
.theme--mint-carnival .mb-drawer .mb-row:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) input[type="date"],
.theme--mint-carnival .mb-drawer .mb-row:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) input[type="time"] {
  font-size: 14px;
  padding: 8px 10px;
}

/* 2) If date/time fields are direct children of a section, use a 2-col grid that can actually shrink */
.theme--mint-carnival .mb-drawer .mb-section:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr)); /* minmax(0,1fr) allows shrink */
  gap: 8px;
  align-items: start;
}

/* Keep section title/desc/divider spanning full width */
.theme--mint-carnival .mb-drawer .mb-section:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) > .mb-section__title,
.theme--mint-carnival .mb-drawer .mb-section:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) > .mb-section__desc,
.theme--mint-carnival .mb-drawer .mb-section:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) > .mb-divider {
  grid-column: 1 / -1;
}

/* Ensure fields and controls don’t overflow their grid cell */
.theme--mint-carnival .mb-drawer .mb-section:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) > .mb-field {
  min-width: 0; /* let inputs shrink with the grid cell */
}
.theme--mint-carnival .mb-drawer .mb-section:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) input[type="date"],
.theme--mint-carnival .mb-drawer .mb-section:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) input[type="time"] {
  width: 100%;
  max-width: 100%;
  font-size: 14px;
  padding: 8px 10px;
  box-sizing: border-box;
}

/* 3) Micro-tweaks for tiny screens so two-up still fits down to ~320px */
@media (max-width: 360px) {
  .theme--mint-carnival .mb-drawer .mb-row:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) { gap: 6px; }
  .theme--mint-carnival .mb-drawer .mb-section:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) { gap: 6px; }

  .theme--mint-carnival .mb-drawer .mb-row:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) input[type="date"],
  .theme--mint-carnival .mb-drawer .mb-row:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) input[type="time"],
  .theme--mint-carnival .mb-drawer .mb-section:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) input[type="date"],
  .theme--mint-carnival .mb-drawer .mb-section:has(> .mb-field input[type="date"]):has(> .mb-field input[type="time"]) input[type="time"] {
    font-size: 13px;
    padding: 7px 8px;
  }

  /* Slightly tighter card padding in tiny widths */
  .theme--mint-carnival .mb-drawer .mb-section { padding: 10px; }
  .theme--mint-carnival .mb-drawer .mb-label { font-size: 11px; }
}

/* 4) WebKit date/time indicator sizing so it doesn’t force overflow */
.theme--mint-carnival .mb-drawer input[type="date"]::-webkit-calendar-picker-indicator,
.theme--mint-carnival .mb-drawer input[type="time"]::-webkit-calendar-picker-indicator {
  transform: scale(0.9);
  margin-left: -2px; /* reclaim a couple pixels on very narrow screens */
}

/* Utility: hidden */
[hidden] { display: none !important; }

/* ———————————— Availability calendar styles ———————————— */
.mb-cal {
  display: grid;
  gap: 8px;
  background: var(--mb-cal-bg);
  border: 1px dashed var(--mb-border);
  border-radius: 10px;
  padding: 8px;
}

.mb-cal__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.mb-cal__title {
  font-weight: 800;
  color: var(--mb-text);
}

.mb-cal__legend {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.mb-cal__pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 2px 8px;
  font-weight: 700;
  font-size: 12px;
  border: 1px solid var(--mb-border);
  background: var(--surface-light, #fff);
  color: var(--mb-text);
}
.mb-cal__pill.ok { background: color-mix(in srgb, var(--mb-available) 18%, transparent); color: var(--mb-text); border-color: color-mix(in srgb, var(--mb-available) 60%, var(--mb-border)); }
.mb-cal__pill.warn { background: color-mix(in srgb, var(--mb-limited) 18%, transparent); color: var(--mb-text); border-color: color-mix(in srgb, var(--mb-limited) 60%, var(--mb-border)); }
.mb-cal__pill.err { background: color-mix(in srgb, var(--mb-booked) 18%, transparent); color: var(--mb-text); border-color: color-mix(in srgb, var(--mb-booked) 60%, var(--mb-border)); }

.mb-cal__week {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.mb-cal__weekday {
  text-align: center;
  font-size: 12px;
  color: var(--mb-muted);
  font-weight: 700;
}

.mb-cal__grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}
.mb-cal__grid.is-loading {
  opacity: 0.6;
  pointer-events: none;
}

.mb-cal__day {
  position: relative;
  min-height: 56px;
  border: 1px solid var(--mb-border);
  border-radius: 10px;
  background: var(--surface-light, #fff);
  color: var(--mb-text);
  text-align: left;
  padding: 6px;
  cursor: pointer;
}
.mb-cal__day:hover { background: var(--mb-hover); }
.mb-cal__day.is-out {
  opacity: 0.55;
  background: transparent;
  cursor: not-allowed;
}
.mb-cal__day.is-past {
  color: var(--mb-muted);
  cursor: not-allowed;
}
.mb-cal__day.is-booked {
  background: color-mix(in srgb, var(--mb-booked) 12%, transparent);
  border-color: color-mix(in srgb, var(--mb-booked) 55%, var(--mb-border));
}
.mb-cal__day.is-limited {
  background: color-mix(in srgb, var(--mb-limited) 12%, transparent);
  border-color: color-mix(in srgb, var(--mb-limited) 55%, var(--mb-border));
}
.mb-cal__day.is-available {
  background: color-mix(in srgb, var(--mb-available) 10%, transparent);
  border-color: color-mix(in srgb, var(--mb-available) 55%, var(--mb-border));
}

.mb-cal__day.is-selected,
.mb-cal__day.is-inrange {
  outline: 2px solid var(--mb-primary);
  outline-offset: -2px;
}
.mb-cal__day.is-start::after,
.mb-cal__day.is-end::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 9px;
  border: 2px solid var(--mb-primary);
  pointer-events: none;
}

.mb-cal__daynum {
  font-weight: 800;
  font-size: 14px;
}
.mb-cal__hint {
  position: absolute;
  bottom: 6px;
  right: 8px;
  font-size: 12px;
  font-weight: 800;
  opacity: 0.9;
}

.mb-cal__editor {
  display: grid;
  gap: 8px;
  border: 1px solid var(--mb-border);
  border-radius: 10px;
  padding: 8px;
  background: var(--surface-light, #fff);
}
