/*
 * zimun-schedule.css
 *
 * Page-scoped styles for the schedule dashboard.
 * Loaded only by templates whose <body> carries `page-schedule`.
 *
 * Note: shared appointment-modal, slot-picker, schedule-overlay,
 * schedule-calendar and schedule-inline-action rules stay in
 * zimun.css core because they are reused by other dashboard
 * surfaces (dashboard.html, dashboard_waitlist.html).
 */

.page-schedule .schedule-container {
  padding: 28px 0 72px;
  display: grid;
  gap: 18px;
}

.page-schedule .schedule-page-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: start;
}

.page-schedule .schedule-page-side {
  display: inline-grid;
  grid-template-columns: minmax(220px, 240px);
  gap: 12px;
  align-items: stretch;
}

.page-schedule .schedule-page-heading {
  display: grid;
  gap: 10px;
}

.page-schedule .schedule-page-title {
  margin: 0;
  font: 600 24px/1.08 "Source Serif 4", Georgia, serif;
  color: var(--primary-700);
}

.page-schedule .schedule-view-summary {
  margin: 0;
  font-size: 13px;
  color: var(--ink-3, var(--muted));
  display: flex;
  flex-wrap: wrap;
  gap: 4px 12px;
}

.page-schedule .schedule-view-summary .sep {
  color: var(--line, var(--border));
}

.page-schedule .schedule-page-scope-wrap {
  min-width: 0;
}

.page-schedule .schedule-page-scope {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.page-schedule .schedule-location-filter {
  margin: 0;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.page-schedule .schedule-location-filter label,
.page-schedule .location-scope-copy {
  margin: 0;
  align-self: center;
}

.page-schedule .schedule-create-panel {
  display: grid;
  gap: 6px;
  justify-items: stretch;
  align-content: start;
}

.page-schedule .schedule-create-launch {
  min-width: 220px;
  justify-content: center;
}

.page-schedule .schedule-create-launch-blocked:not(:disabled) {
  cursor: pointer;
}

.page-schedule .schedule-create-helper {
  margin: 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.page-schedule .schedule-surface {
  display: grid;
  grid-template-rows: auto auto 1fr auto auto auto;
  padding: 0;
  overflow: hidden;
}

.page-schedule .schedule-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 16px;
  border-bottom: 1px solid var(--line, var(--border));
  background: var(--bone, #f8fafc);
  font-size: 12px;
}

.page-schedule .schedule-card-tag {
  display: inline-flex;
  align-items: center;
  padding: 2px 9px;
  border-radius: 999px;
  background: rgba(184, 137, 58, 0.14);
  color: var(--brass, #b8893a);
  font-weight: 700;
  font-size: 10px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  line-height: 1.4;
}

.page-schedule .schedule-card-path {
  color: var(--ink-3, var(--muted));
  font-size: 12px;
  line-height: 1.35;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.page-schedule .schedule-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  padding: 12px 16px;
  border-top: 1px solid var(--line-2, var(--border));
  background: var(--bone, #f8fafc);
}

.page-schedule .schedule-nav-bar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--bone, #f8fafc);
}

.page-schedule .schedule-nav-bar--top {
  border-bottom: 1px solid var(--line, var(--border));
}

.page-schedule .schedule-footer,
.page-schedule .schedule-nav-bar--bottom {
  border-top: 1px solid var(--line, var(--border));
}

.page-schedule .schedule-title {
  margin: 0;
  font: 600 16px/1.25 "Source Serif 4", Georgia, serif;
  color: var(--primary-700);
  text-align: center;
}

.page-schedule .schedule-nav {
  display: inline-flex;
  gap: 6px;
  align-items: center;
}

.page-schedule .schedule-nav .btn {
  min-width: 36px;
  min-height: 34px;
  padding: 7px 10px;
  font-size: 12px;
  justify-content: center;
}

.page-schedule .schedule-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.page-schedule .schedule-calendar {
  padding: 12px 20px 20px 20px;
}

.page-schedule .schedule-state-legend,
.page-schedule .holiday-inline-list {
  padding-left: 20px;
  padding-right: 20px;
}

.page-schedule .holiday-inline-list {
  padding-bottom: 12px;
}

.page-schedule .view-btn {
  padding: 7px 12px;
  font-size: 12px;
  min-height: 34px;
}

@media (max-width: 768px) {
  .page-schedule .schedule-week-view-btn {
    display: none;
  }
  .page-schedule .schedule-page-header {
    grid-template-columns: 1fr;
  }
  .page-schedule .schedule-page-side {
    order: unset;
    grid-template-columns: 1fr;
  }
  .page-schedule .schedule-page-title {
    font-size: 22px;
  }
  .page-schedule .schedule-page-scope {
    display: grid;
    grid-template-columns: 1fr;
  }
  .page-schedule .schedule-toolbar {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .page-schedule .schedule-nav-bar {
    grid-template-columns: 1fr;
    gap: 10px;
    text-align: center;
  }
  .page-schedule .schedule-nav-bar .schedule-nav {
    justify-content: center;
  }
  .page-schedule .schedule-nav-bar .schedule-title {
    text-align: center;
    order: -1;
  }
  .page-schedule .schedule-nav-bar .schedule-actions {
    justify-content: center;
  }
  .page-schedule .schedule-calendar {
    padding: 12px;
  }
  .page-schedule .schedule-state-legend,
  .page-schedule .holiday-inline-list {
    padding-left: 12px;
    padding-right: 12px;
  }
}

@media (max-width: 880px) {
  .page-schedule .schedule-container {
    padding-top: 84px;
  }
}

/* Resource reschedule modal: widen so the day-row chips and the
 * side-by-side start/end time inputs have room without wrapping. */
.page-schedule .resource-reschedule-card {
  width: min(720px, 100%);
}
.page-schedule .resource-reschedule-card .event-modal-body {
  overflow-y: auto;
}
.page-schedule .resource-reschedule-card .bp-time-narrow__form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: start;
}
.page-schedule .resource-reschedule-card .bp-time-narrow__form .field {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.page-schedule .resource-reschedule-card .bp-time-narrow__form .bp-time-narrow__duration,
.page-schedule .resource-reschedule-card .bp-time-narrow__form .bp-time-narrow__validation,
.page-schedule .resource-reschedule-card .bp-time-narrow__form .bp-time-narrow__actions {
  grid-column: 1 / -1;
}
.page-schedule .resource-reschedule-card .bp-time-narrow__form .input {
  width: 100%;
  box-sizing: border-box;
}
@media (max-width: 520px) {
  .page-schedule .resource-reschedule-card .bp-time-narrow__form {
    grid-template-columns: 1fr;
  }
}
