/*
 * On-call schedules
 *
 * Admin form guidance, show-page layout, summary facts, and roster rows.
 */

.on-call-schedule-profile {
  max-inline-size: 80rem;
  margin-inline: auto;
}

.on-call-schedule-profile__header {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1rem;
}

.on-call-schedule-profile__title,
.on-call-roster__title {
  margin: 0;
  color: var(--color-ink);
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.25;
}

.on-call-schedule-profile__subtitle {
  max-inline-size: 46rem;
  margin-block: 0.5rem 0;
  color: var(--color-ink-medium);
  font-size: 0.875rem;
  line-height: 1.5;
}

.on-call-schedule-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
}

.on-call-schedule-actions form {
  margin: 0;
}

.on-call-schedule-actions .btn {
  justify-content: center;
}

.on-call-schedule-steps {
  display: flex;
  flex-wrap: wrap;
  gap: 0.625rem;
  margin-block-end: 1.25rem;
  border-block-end: 1px solid var(--color-border-muted);
  padding-block-end: 1rem;
}

.alert--error + .on-call-schedule-steps {
  margin-block-start: 1rem;
}

.on-call-schedule-steps__link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  appearance: none;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface);
  color: var(--color-ink);
  padding: 0.625rem 0.875rem;
  cursor: pointer;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.25;
  text-decoration: none;
}

.on-call-schedule-steps__link:hover,
.on-call-schedule-steps__link[aria-selected="true"] {
  border-color: var(--color-brand);
  color: var(--color-brand-strong);
}

.on-call-schedule-steps__link[aria-selected="true"] {
  background-color: rgb(var(--palette-indigo-50));
}

.on-call-schedule-steps__number {
  display: inline-flex;
  inline-size: 1.5rem;
  block-size: 1.5rem;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-pill);
  background-color: rgb(var(--palette-indigo-50));
  color: var(--color-brand-strong);
  font-size: 0.75rem;
}

.on-call-form-help {
  display: grid;
  gap: 0.75rem;
  margin-block-start: 1.5rem;
  padding-block-start: 1rem;
  border-block-start: 1px solid var(--color-border-muted);
}

.on-call-form-help__title {
  margin: 0;
  color: var(--color-ink);
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.25;
}

.on-call-form-help__list {
  display: grid;
  gap: 0.625rem;
  margin: 0;
  padding-inline-start: 1.125rem;
  color: var(--color-ink-medium);
  font-size: 0.875rem;
  line-height: 1.45;
}

.on-call-schedule-facts {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.75rem;
  margin-block: 1.5rem 0;
  padding-block-start: 1.25rem;
  border-block-start: 1px solid var(--color-border-muted);
}

.on-call-schedule-fact {
  min-inline-size: 0;
  border-radius: var(--radius-xl);
  background-color: var(--color-surface-muted);
  padding: 0.875rem 1rem;
}

.on-call-schedule-fact__term {
  color: var(--color-ink-medium);
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1rem;
  text-transform: uppercase;
}

.on-call-schedule-fact__definition {
  overflow: hidden;
  margin-block: 0.25rem 0;
  color: var(--color-ink);
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.35;
  text-overflow: ellipsis;
}

.on-call-roster {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  max-inline-size: 80rem;
  margin-inline: auto;
}

.on-call-roster__section {
  min-inline-size: 0;
}

.on-call-roster__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-block-end: 1rem;
  padding-block-end: 0.75rem;
  border-block-end: 1px solid var(--color-border-muted);
}

.on-call-roster__title {
  font-size: 1rem;
}

.on-call-roster__count {
  display: inline-flex;
  min-inline-size: 1.75rem;
  block-size: 1.75rem;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-pill);
  background-color: rgb(var(--palette-indigo-50));
  color: var(--color-brand-strong);
  font-size: 0.75rem;
  font-weight: 700;
}

.on-call-roster__list {
  counter-reset: on-call-roster-row;
  display: grid;
  gap: 0.625rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.on-call-roster-row {
  counter-increment: on-call-roster-row;
  display: flex;
  min-inline-size: 0;
  align-items: center;
  gap: 0.75rem;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface);
  padding: 0.75rem;
}

.on-call-roster-row__drag-icon {
  inline-size: 1rem;
  block-size: 1rem;
  flex: 0 0 auto;
  opacity: 0.45;
  cursor: grab;
}

.on-call-roster-row__badge,
.on-call-roster-row__position {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-lg);
  font-size: 0.8125rem;
  font-weight: 700;
}

.on-call-roster-row__badge {
  inline-size: 2.25rem;
  block-size: 2.25rem;
  background-color: rgb(var(--palette-indigo-50));
  color: var(--color-brand-strong);
}

.on-call-roster-row__badge--office {
  background-color: rgb(var(--palette-blue-50));
  color: var(--color-info-strong);
}

.on-call-roster-row__badge--team {
  background-color: rgb(var(--palette-mint-50));
  color: rgb(var(--palette-emerald-700));
}

.on-call-roster-row__badge--employee,
.on-call-roster-row__badge--asset {
  background-color: rgb(var(--palette-amber-50));
  color: rgb(var(--palette-amber-700));
}

.on-call-roster-row__position {
  inline-size: 2rem;
  block-size: 2rem;
  background-color: var(--color-surface-muted);
  color: var(--color-ink-medium);
}

.on-call-roster-row__position::before {
  content: counter(on-call-roster-row, decimal-leading-zero);
}

.on-call-roster-row__summary {
  min-inline-size: 0;
}

.on-call-roster-row__title,
.on-call-roster-row__meta {
  overflow: hidden;
  margin: 0;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.on-call-roster-row__title {
  color: var(--color-ink);
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1.35;
}

.on-call-roster-row__meta {
  margin-block-start: 0.25rem;
  color: var(--color-ink-medium);
  font-size: 0.8125rem;
  line-height: 1.25;
}

.on-call-target-picker {
  margin: 0;
  border: 0;
  padding: 0;
}

.on-call-target-picker__list {
  display: grid;
  gap: 0.5rem;
  max-block-size: 14rem;
  overflow: auto;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface);
  padding: 0.625rem;
}

.on-call-target-picker__list--employees {
  grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
}

.on-call-target-picker__option {
  display: flex;
  min-inline-size: 0;
  align-items: center;
  gap: 0.625rem;
  border-radius: var(--radius-md);
  padding: 0.375rem 0.5rem;
  color: var(--color-ink);
  cursor: pointer;
  font-size: 0.875rem;
  line-height: 1.3;
}

.on-call-target-picker__option:hover {
  background-color: var(--color-surface-muted);
}

.on-call-target-picker__label {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.on-call-target-picker .employee-search--selection-list .employee-search__selected-list {
  display: grid;
  gap: 0.5rem;
  margin-block-start: 0.625rem;
}

.on-call-target-picker .employee-search__selected-row {
  display: flex;
  min-inline-size: 0;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  inline-size: 100%;
  border: 1px solid var(--color-border-muted);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface);
  padding: 0.625rem 0.75rem;
}

.on-call-target-picker .employee-search__selected-name {
  overflow: hidden;
  color: var(--color-ink);
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.35;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.on-call-target-picker .employee-search__selected-remove {
  display: inline-flex;
  flex: 0 0 auto;
  inline-size: 2rem;
  block-size: 2rem;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: var(--radius-md);
  background-color: transparent;
  color: var(--color-danger-strong);
  cursor: pointer;
}

.on-call-target-picker .employee-search__selected-remove:hover,
.on-call-target-picker .employee-search__selected-remove:focus-visible {
  background-color: rgb(var(--palette-red-50));
}

.on-call-target-picker .employee-search__selected-remove:focus-visible {
  outline: var(--focus-ring);
  outline-offset: var(--focus-ring-offset);
}

.on-call-target-picker .employee-search__selected-remove-icon {
  inline-size: 1rem;
  block-size: 1rem;
  pointer-events: none;
}

.on-call-conflict-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  border-radius: var(--radius-pill);
  background-color: rgb(var(--palette-amber-50));
  color: rgb(var(--palette-amber-800));
  padding: 0.25rem 0.625rem;
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1.25;
}

.on-call-conflict-badge__icon {
  inline-size: 1rem;
  block-size: 1rem;
}

.on-call-conflict-list {
  display: grid;
  gap: 0.625rem;
}

.on-call-conflict {
  display: flex;
  min-inline-size: 0;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  border: 1px solid rgb(var(--palette-amber-200));
  border-radius: var(--radius-lg);
  background-color: rgb(var(--palette-amber-50) / 0.55);
  padding: 0.75rem;
}

.on-call-conflict__body {
  min-inline-size: 0;
}

.on-call-conflict__title {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin: 0;
  color: var(--color-ink);
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.35;
}

.on-call-conflict__status {
  border-radius: var(--radius-pill);
  padding: 0.125rem 0.5rem;
  font-size: 0.6875rem;
  font-weight: 700;
  line-height: 1.25;
}

.on-call-conflict__status--warning,
.on-call-conflict__status--actionable {
  background-color: rgb(var(--palette-amber-100));
  color: rgb(var(--palette-amber-800));
}

.on-call-conflict__status--resolved {
  background-color: rgb(var(--palette-emerald-50));
  color: rgb(var(--palette-emerald-700));
}

.on-call-conflict__meta {
  margin-block: 0.25rem 0;
  color: var(--color-ink-medium);
  font-size: 0.8125rem;
  line-height: 1.35;
}

.on-call-conflict__actions {
  flex: 0 0 auto;
}

.on-call-conflict-empty {
  color: var(--color-ink-muted);
  font-size: 0.8125rem;
}

.on-call-replacement-form {
  display: grid;
  gap: 1rem;
}

@media (max-width: 639px) {
  .on-call-schedule-actions > form,
  .on-call-schedule-actions > a,
  .on-call-schedule-actions .btn {
    inline-size: 100%;
  }

  .on-call-conflict {
    display: grid;
  }
}

@media (min-width: 640px) {
  .on-call-schedule-facts {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 768px) {
  .on-call-schedule-profile__header {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
  }

  .on-call-schedule-actions {
    justify-content: flex-end;
  }
}

@media (min-width: 1024px) {
  .on-call-schedule-facts {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
