/*
 * Booking calendar management
 *
 * Index and show page layout for booking calendar management.
 */

.booking-calendars-page {
  display: grid;
  gap: 1rem;
}

.booking-calendars-page__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-block-end: 0.5rem;
}

.booking-calendars-page__intro {
  max-inline-size: 62rem;
}

.booking-calendars-page__eyebrow {
  margin: 0 0 0.35rem;
  color: var(--color-ink-lighter);
  font-size: var(--text-small);
  font-weight: 600;
}

.booking-calendars-page__heading {
  margin: 0;
  color: var(--color-ink);
  font-size: var(--text-x-large);
  font-weight: 700;
  line-height: 1.15;
}

.booking-calendars-page__description {
  max-inline-size: 70ch;
  margin: 0.5rem 0 0;
  color: var(--color-ink-light);
  font-size: var(--text-normal);
  line-height: 1.45;
}

.booking-calendars-page__summary {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.5rem;
  max-inline-size: 28rem;
}

.booking-calendars-page__count,
.booking-calendars-page__status {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-block-size: 2.35rem;
  border-radius: var(--radius-xl);
  padding-block: 0.45rem;
  padding-inline: 0.7rem;
  font-size: var(--text-small);
  font-weight: 700;
  line-height: 1;
}

.booking-calendars-page__count {
  border: 1px solid var(--color-border);
  background-color: var(--color-surface);
  color: var(--color-ink-light);
  box-shadow: var(--shadow-sm);
}

.booking-calendars-page__count-icon,
.booking-calendar-row__icon,
.booking-calendar-row__meta-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.booking-calendars-page__count-icon .icon {
  inline-size: 1rem;
  block-size: 1rem;
}

.booking-calendars-page__status {
  border: 1px solid transparent;
}

.booking-calendars-page__status--active {
  border-color: rgb(var(--palette-green-200));
  background-color: rgb(var(--palette-green-50));
  color: rgb(var(--palette-green-700));
}

.booking-calendars-page__status--inactive {
  border-color: var(--color-border);
  background-color: var(--color-surface-subtle);
  color: var(--color-ink-light);
}

.booking-calendars-page__status-dot,
.booking-calendar-status__dot {
  inline-size: 0.45rem;
  block-size: 0.45rem;
  border-radius: var(--radius-pill);
  background-color: currentColor;
}

.booking-calendars-table {
  overflow-x: auto;
}

.booking-calendars-table .simple-table {
  inline-size: 100%;
  min-inline-size: 62rem;
  margin-block-start: 0;
}

.booking-calendars-table .th {
  padding-block: 0.85rem;
  padding-inline: 1rem;
}

.booking-calendar-row .td {
  vertical-align: middle;
  padding-block: 0.9rem;
  padding-inline: 1rem;
}

.booking-calendar-row__main {
  inline-size: 34%;
  min-inline-size: 20rem;
}

.booking-calendar-row__availability,
.booking-calendar-row__routing {
  min-inline-size: 12rem;
}

.booking-calendar-row__url {
  max-inline-size: 18rem;
}

.booking-calendar-row__actions {
  inline-size: 4rem;
}

.booking-calendar-row__identity {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  min-inline-size: 0;
}

.booking-calendar-row__icon {
  flex: 0 0 auto;
  inline-size: 2.25rem;
  block-size: 2.25rem;
  border: 1px solid color-mix(in oklch, var(--color-info) 18%, var(--color-border));
  border-radius: var(--radius-lg);
  background-color: color-mix(in oklch, var(--color-info) 9%, var(--color-surface));
  color: var(--color-info);
}

.booking-calendar-row__icon .icon {
  inline-size: 1.1rem;
  block-size: 1.1rem;
}

.booking-calendar-row__copy {
  display: grid;
  gap: 0.3rem;
  min-inline-size: 0;
}

.booking-calendar-row__title,
.booking-calendar-row__public-link {
  color: var(--color-ink);
  text-decoration: none;
}

.booking-calendar-row__title {
  font-size: var(--text-normal);
  font-weight: 700;
  line-height: 1.25;
}

.booking-calendar-row__public-link {
  display: block;
  overflow: hidden;
  color: var(--color-link);
  font-size: var(--text-small);
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.booking-calendar-row__title:hover,
.booking-calendar-row__title:focus-visible,
.booking-calendar-row__public-link:hover,
.booking-calendar-row__public-link:focus-visible {
  color: var(--color-link);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.booking-calendar-row__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.75rem;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  font-weight: 500;
}

.booking-calendar-row__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  min-inline-size: 0;
}

.booking-calendar-row__meta-icon .icon {
  inline-size: 0.9rem;
  block-size: 0.9rem;
  color: var(--color-ink-lighter);
}

.booking-calendar-status {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  inline-size: fit-content;
  border-radius: var(--radius-pill);
  padding-block: 0.25rem;
  padding-inline: 0.55rem;
  font-size: var(--text-small);
  font-weight: 700;
  line-height: 1;
}

.booking-calendar-status--active {
  background-color: rgb(var(--palette-green-50));
  color: rgb(var(--palette-green-700));
  box-shadow: inset 0 0 0 1px rgb(var(--palette-green-200));
}

.booking-calendar-status--inactive {
  background-color: var(--color-surface-subtle);
  color: var(--color-ink-light);
  box-shadow: inset 0 0 0 1px var(--color-border);
}

.booking-calendar-row__strong,
.booking-calendar-row__detail {
  display: block;
}

.booking-calendar-row__strong {
  color: var(--color-ink);
  font-size: var(--text-normal);
  font-weight: 700;
  line-height: 1.25;
}

.booking-calendar-row__detail {
  margin-block-start: 0.4rem;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  font-weight: 500;
  line-height: 1.25;
}

.booking-calendars-table__pagination {
  display: flex;
  justify-content: flex-end;
  padding-block-start: 0.75rem;
}

.booking-calendars-empty {
  margin-block-start: 0.5rem;
}

.booking-calendar-show {
  display: grid;
  gap: 1rem;
}

.booking-calendar-show__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-block-end: 0.5rem;
}

.booking-calendar-show__identity {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  min-inline-size: 0;
}

.booking-calendar-show__icon {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  inline-size: 2.75rem;
  block-size: 2.75rem;
  border: 1px solid color-mix(in oklch, var(--color-info) 18%, var(--color-border));
  border-radius: var(--radius-lg);
  background-color: color-mix(in oklch, var(--color-info) 9%, var(--color-surface));
  color: var(--color-info);
}

.booking-calendar-show__icon .icon {
  inline-size: 1.25rem;
  block-size: 1.25rem;
}

.booking-calendar-show__intro {
  min-inline-size: 0;
  max-inline-size: 68rem;
}

.booking-calendar-show__eyebrow {
  margin: 0 0 0.35rem;
  color: var(--color-ink-lighter);
  font-size: var(--text-small);
  font-weight: 600;
}

.booking-calendar-show__heading {
  margin: 0;
  color: var(--color-ink);
  font-size: var(--text-x-large);
  font-weight: 700;
  line-height: 1.15;
}

.booking-calendar-show__description {
  max-inline-size: 72ch;
  margin: 0.5rem 0 0;
  color: var(--color-ink-light);
  font-size: var(--text-normal);
  line-height: 1.45;
}

.booking-calendar-show__actions {
  display: flex;
  flex: 0 0 auto;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
}

.booking-calendar-show__status {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-block-size: 2.35rem;
  border-radius: var(--radius-xl);
  padding-block: 0.45rem;
  padding-inline: 0.7rem;
  font-size: var(--text-small);
  font-weight: 700;
  line-height: 1;
}

.booking-calendar-show__status--active {
  border: 1px solid rgb(var(--palette-green-200));
  background-color: rgb(var(--palette-green-50));
  color: rgb(var(--palette-green-700));
}

.booking-calendar-show__status--inactive {
  border: 1px solid var(--color-border);
  background-color: var(--color-surface-subtle);
  color: var(--color-ink-light);
}

.booking-calendar-show__status-dot {
  inline-size: 0.45rem;
  block-size: 0.45rem;
  border-radius: var(--radius-pill);
  background-color: currentColor;
}

.booking-calendar-show__edit {
  white-space: nowrap;
}

.booking-calendar-show-overview {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(18rem, 24rem);
  gap: 1.25rem;
}

.booking-calendar-show-overview__main {
  display: grid;
  gap: 1rem;
  min-inline-size: 0;
}

.booking-calendar-show-overview__header h2,
.booking-calendar-show-section__header h2 {
  margin: 0;
  color: var(--color-ink);
  font-size: var(--text-large);
  font-weight: 700;
  line-height: 1.2;
}

.booking-calendar-show-overview__header p {
  max-inline-size: 72ch;
  margin: 0.4rem 0 0;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  line-height: 1.45;
}

.booking-calendar-show-details {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface);
}

.booking-calendar-show-details__item {
  display: grid;
  gap: 0.35rem;
  min-inline-size: 0;
  border-block-start: 1px solid var(--color-border);
  padding: 0.9rem 1rem;
}

.booking-calendar-show-details__item:nth-child(-n + 2) {
  border-block-start: 0;
}

.booking-calendar-show-details__item:nth-child(2n) {
  border-inline-start: 1px solid var(--color-border);
}

.booking-calendar-show-details dt {
  color: var(--color-ink-lighter);
  font-size: var(--text-small);
  font-weight: 600;
  line-height: 1.2;
}

.booking-calendar-show-details dd {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  min-inline-size: 0;
  margin: 0;
  color: var(--color-ink);
  font-size: var(--text-normal);
  font-weight: 650;
  line-height: 1.3;
}

.booking-calendar-show-details code,
.booking-calendar-show-table code {
  border-radius: var(--radius-sm);
  background-color: var(--color-surface-subtle);
  padding-block: 0.1rem;
  padding-inline: 0.35rem;
  color: var(--color-ink-light);
  font-size: 0.9em;
}

.booking-calendar-show-details__icon {
  display: inline-flex;
  flex: 0 0 auto;
  color: var(--color-ink-lighter);
}

.booking-calendar-show-details__icon .icon {
  inline-size: 0.95rem;
  block-size: 0.95rem;
}

.booking-calendar-show-details__link {
  overflow: hidden;
  color: var(--color-link);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.booking-calendar-show-details__link:hover,
.booking-calendar-show-details__link:focus-visible {
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.booking-calendar-show-metrics {
  display: grid;
  gap: 0.6rem;
  align-content: start;
}

.booking-calendar-show-metric {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.25rem 0.65rem;
  align-items: center;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface-muted);
  padding: 0.75rem;
}

.booking-calendar-show-metric__icon {
  display: inline-flex;
  grid-row: 1 / span 2;
  align-items: center;
  justify-content: center;
  inline-size: 2rem;
  block-size: 2rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background-color: var(--color-surface);
  color: var(--color-ink-light);
}

.booking-calendar-show-metric__icon .icon {
  inline-size: 1rem;
  block-size: 1rem;
}

.booking-calendar-show-metric__label {
  color: var(--color-ink-lighter);
  font-size: var(--text-small);
  font-weight: 600;
  line-height: 1.2;
}

.booking-calendar-show-metric strong {
  color: var(--color-ink);
  font-size: var(--text-normal);
  font-weight: 750;
  line-height: 1.2;
}

.booking-calendar-show-section {
  display: grid;
  gap: 1rem;
}

.booking-calendar-show-section__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.booking-calendar-show-section__eyebrow {
  margin: 0 0 0.25rem;
  color: var(--color-ink-lighter);
  font-size: var(--text-small);
  font-weight: 600;
  line-height: 1.2;
}

.booking-calendar-show-section__count {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  min-block-size: 2rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background-color: var(--color-surface-subtle);
  padding-block: 0.35rem;
  padding-inline: 0.65rem;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  font-weight: 700;
  line-height: 1;
}

.booking-calendar-show-table {
  overflow-x: auto;
}

.booking-calendar-show-table .simple-table {
  min-inline-size: 48rem;
  margin-block-start: 0;
}

.booking-calendar-show-table .th {
  padding-block: 0.85rem;
  padding-inline: 1rem;
}

.booking-calendar-show-table .td,
.booking-calendar-show-table td {
  vertical-align: middle;
  padding-block: 0.85rem;
  padding-inline: 1rem;
}

.booking-calendar-show-table__primary,
.booking-calendar-show-table__secondary {
  display: block;
}

.booking-calendar-show-table__primary {
  color: var(--color-ink);
  font-weight: 700;
  line-height: 1.25;
}

.booking-calendar-show-table__secondary {
  margin-block-start: 0.25rem;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  line-height: 1.25;
}

.booking-calendar-show-table__actions {
  inline-size: 1%;
  white-space: nowrap;
}

.booking-calendar-show-empty {
  margin: 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface-muted);
  padding: 1rem;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  font-weight: 600;
  line-height: 1.35;
}

.booking-calendar-show-form {
  margin-block-start: 0.25rem;
}

.booking-calendar-editor .admin-settings-form__body {
  display: grid;
  gap: 1rem;
}

.booking-calendar-editor__summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface);
}

.booking-calendar-editor__summary-item {
  display: grid;
  gap: 0.35rem;
  min-inline-size: 0;
  padding-block: 0.85rem;
  padding-inline: 1rem;
}

.booking-calendar-editor__summary-item + .booking-calendar-editor__summary-item {
  border-inline-start: 1px solid var(--color-border);
}

.booking-calendar-editor__summary dt {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  min-inline-size: 0;
  color: var(--color-ink-lighter);
  font-size: var(--text-small);
  font-weight: 650;
  line-height: 1.2;
}

.booking-calendar-editor__summary dd {
  display: grid;
  gap: 0.2rem;
  min-inline-size: 0;
  margin: 0;
  color: var(--color-ink);
  font-size: var(--text-normal);
  font-weight: 750;
  line-height: 1.25;
}

.booking-calendar-editor__summary code {
  display: block;
  overflow: hidden;
  max-inline-size: 100%;
  border-radius: var(--radius-sm);
  background-color: var(--color-surface-subtle);
  padding-block: 0.15rem;
  padding-inline: 0.35rem;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  font-weight: 650;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.booking-calendar-editor__summary-detail {
  display: block;
  overflow: hidden;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  font-weight: 600;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.booking-calendar-editor__summary-icon,
.booking-calendar-editor__legend-icon {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
}

.booking-calendar-editor__summary-icon {
  color: var(--color-ink-lighter);
}

.booking-calendar-editor__summary-icon .icon {
  inline-size: 0.95rem;
  block-size: 0.95rem;
}

.booking-calendar-editor__summary-item--active .booking-calendar-editor__summary-icon {
  color: rgb(var(--palette-green-700));
}

.booking-calendar-editor__summary-item--inactive .booking-calendar-editor__summary-icon,
.booking-calendar-editor__summary-item--secret .booking-calendar-editor__summary-icon {
  color: var(--color-ink-light);
}

.booking-calendar-editor__summary-item--public .booking-calendar-editor__summary-icon {
  color: var(--color-info);
}

.booking-calendar-editor__form {
  display: grid;
  gap: 1.25rem;
}

.booking-calendar-editor__fieldset {
  display: grid;
  gap: 0.35rem;
  min-inline-size: 0;
  margin: 0;
  border: 0;
  padding: 0;
}

.booking-calendar-editor__fieldset + .booking-calendar-editor__fieldset {
  border-block-start: 1px solid var(--color-border);
  padding-block-start: 1.25rem;
}

.booking-calendar-editor__legend {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  inline-size: 100%;
  margin: 0;
  padding: 0;
}

.booking-calendar-editor__legend-icon {
  inline-size: 2rem;
  block-size: 2rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background-color: var(--color-surface-muted);
  color: var(--color-ink-light);
}

.booking-calendar-editor__legend-icon .icon {
  inline-size: 1rem;
  block-size: 1rem;
}

.booking-calendar-editor__legend-title,
.booking-calendar-editor__legend-description {
  display: block;
}

.booking-calendar-editor__legend-title {
  color: var(--color-ink);
  font-size: var(--text-normal);
  font-weight: 750;
  line-height: 1.25;
}

.booking-calendar-editor__legend-description {
  max-inline-size: 62ch;
  margin-block-start: 0.2rem;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  line-height: 1.4;
}

.booking-calendar-editor__field-pair,
.booking-calendar-editor__publication-controls,
.booking-calendar-editor__schedule-controls,
.booking-calendar-editor__assignment-control,
.booking-calendar-editor__host-fields,
.booking-calendar-editor__public-copy,
.booking-calendar-editor__cover-upload,
.booking-calendar-editor__theme-control {
  margin-block-start: 0.25rem;
}

.booking-calendar-editor__public-copy {
  display: grid;
  gap: 1rem;
  max-inline-size: 44rem;
}

.booking-calendar-editor__cover-upload {
  display: grid;
  gap: 0.5rem;
  max-inline-size: 44rem;
}

.booking-calendar-editor__cover-upload .image-upload-field__preview {
  block-size: min(18rem, 48vw);
  inline-size: 100%;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface-muted);
  object-fit: cover;
}

.booking-calendar-editor__cover-upload .image-upload-field__help {
  max-inline-size: 62ch;
  margin-block: 0;
  line-height: 1.4;
}

.booking-calendar-editor__theme-control {
  display: grid;
  gap: 0.75rem;
}

.booking-calendar-editor__theme-control .admin-job-offer-theme-picker__label {
  margin-block-end: 0;
}

.booking-calendar-editor__theme-picker.admin-job-offer-theme-picker {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(8.75rem, 1fr));
  gap: 0.75rem;
}

.booking-calendar-editor__theme-picker .admin-job-offer-theme-card {
  align-items: stretch;
  min-inline-size: 0;
  background-color: var(--color-surface);
  padding: 0.6rem;
  text-align: start;
}

.booking-calendar-editor__theme-picker .admin-job-offer-theme-card:hover,
.booking-calendar-editor__theme-picker .admin-job-offer-theme-card:focus-visible {
  border-color: var(--color-border-strong);
}

.booking-calendar-editor__theme-picker .admin-job-offer-theme-card:focus-visible {
  outline: 0;
  box-shadow: var(--shadow-focus-soft);
}

.booking-calendar-editor__theme-picker .admin-job-offer-theme-card--selected {
  border-color: var(--color-info);
  box-shadow: 0 0 0 2px rgb(var(--palette-blue-200));
}

.booking-calendar-editor__theme-picker .admin-job-offer-theme-card__preview {
  inline-size: 100%;
  block-size: 4.5rem;
  margin-block-end: 0.6rem;
}

.booking-calendar-editor__theme-picker .admin-job-offer-theme-card__label {
  color: var(--color-ink);
  font-size: var(--text-small);
  font-weight: 650;
  line-height: 1.2;
}

.booking-calendar-editor__active-field {
  display: flex;
  align-items: flex-start;
}

.booking-calendar-editor__active-field .form-field--inline,
.booking-calendar-editor__required-field .form-field--inline {
  inline-size: 100%;
}

.booking-calendar-editor__assignment-control {
  max-inline-size: 34rem;
}

.booking-calendar-editor__fieldset--compact {
  border-block-start: 1px solid var(--color-border);
  padding-block-start: 1.25rem;
}

.booking-calendar-editor__host-management {
  gap: 1rem;
}

.booking-calendar-editor__host-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.booking-calendar-editor__host-title {
  margin: 0;
  color: var(--color-ink);
  font-size: var(--text-normal);
  font-weight: 750;
  line-height: 1.25;
}

.booking-calendar-editor__count {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  min-block-size: 1.75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background-color: var(--color-surface-muted);
  padding-block: 0.2rem;
  padding-inline: 0.65rem;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  font-weight: 650;
  line-height: 1.2;
}

.booking-calendar-editor__table-block {
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.booking-calendar-editor__table-block .simple-table {
  margin: 0;
}

.booking-calendar-editor__empty {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface-muted);
  padding-block: 0.9rem;
  padding-inline: 1rem;
  color: var(--color-ink-light);
}

.booking-calendar-editor__empty p {
  margin: 0;
  font-size: var(--text-small);
  font-weight: 600;
  line-height: 1.35;
}

.booking-calendar-editor__empty-icon {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  inline-size: 2rem;
  block-size: 2rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background-color: var(--color-surface);
  color: var(--color-ink-lighter);
}

.booking-calendar-editor__empty-icon .icon {
  inline-size: 1rem;
  block-size: 1rem;
}

.booking-calendar-editor__empty--compact {
  padding-block: 0.75rem;
}

.booking-calendar-editor__add-host-form {
  display: grid;
  gap: 1rem;
}

.booking-calendar-editor__question-management {
  gap: 1rem;
}

.booking-calendar-editor__reservation-management {
  gap: 1rem;
}

.booking-calendar-editor__invitation-form {
  gap: 1rem;
}

.booking-calendar-editor__invitation-fields {
  display: grid;
  gap: 1rem;
  margin-block-start: 0.25rem;
}

.booking-calendar-editor__reservations-table .th:last-child {
  inline-size: 1%;
  white-space: nowrap;
}

.booking-calendar-editor__reservation-row .td {
  vertical-align: middle;
}

.booking-calendar-editor__person,
.booking-calendar-editor__primary,
.booking-calendar-editor__secondary,
.booking-calendar-editor__source {
  display: block;
}

.booking-calendar-editor__person {
  display: grid;
  gap: 0.2rem;
  min-inline-size: 0;
}

.booking-calendar-editor__primary {
  color: var(--color-ink);
  font-weight: 750;
  line-height: 1.25;
}

.booking-calendar-editor__secondary,
.booking-calendar-editor__source {
  color: var(--color-ink-light);
  font-size: var(--text-small);
  font-weight: 600;
  line-height: 1.35;
}

.booking-calendar-editor__token {
  display: inline-block;
  overflow: hidden;
  max-inline-size: 16rem;
  border-radius: var(--radius-sm);
  background-color: var(--color-surface-subtle);
  padding-block: 0.15rem;
  padding-inline: 0.4rem;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  font-weight: 650;
  text-overflow: ellipsis;
  vertical-align: middle;
  white-space: nowrap;
}

.booking-calendar-editor__status {
  display: inline-flex;
  align-items: center;
  min-block-size: 1.65rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background-color: var(--color-surface-muted);
  padding-block: 0.15rem;
  padding-inline: 0.6rem;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
}

.booking-calendar-editor__status--confirmed,
.booking-calendar-editor__status--used {
  border-color: rgb(var(--palette-green-200));
  background-color: rgb(var(--palette-green-50));
  color: rgb(var(--palette-green-800));
}

.booking-calendar-editor__status--pending {
  border-color: rgb(var(--palette-yellow-200));
  background-color: rgb(var(--palette-yellow-50));
  color: rgb(var(--palette-yellow-900));
}

.booking-calendar-editor__status--cancelled,
.booking-calendar-editor__status--expired,
.booking-calendar-editor__status--revoked {
  border-color: rgb(var(--palette-rose-200));
  background-color: rgb(var(--palette-rose-50));
  color: rgb(var(--palette-rose-800));
}

.booking-calendar-editor__booking-link {
  color: var(--color-link);
  font-weight: 700;
  text-decoration: none;
}

.booking-calendar-editor__booking-link:hover,
.booking-calendar-editor__booking-link:focus-visible {
  text-decoration: underline;
  text-underline-offset: 0.18em;
}

.booking-calendar-editor__questions-table .th:last-child {
  inline-size: 1%;
  white-space: nowrap;
}

.booking-calendar-editor__question-row .td {
  vertical-align: middle;
}

.booking-calendar-editor__question-name,
.booking-calendar-editor__question-help,
.booking-calendar-editor__question-type,
.booking-calendar-editor__question-requirement {
  display: block;
}

.booking-calendar-editor__question-name {
  color: var(--color-ink);
  font-weight: 750;
  line-height: 1.25;
}

.booking-calendar-editor__question-help {
  max-inline-size: 56ch;
  margin-block-start: 0.25rem;
  color: var(--color-ink-light);
  font-size: var(--text-small);
  line-height: 1.35;
}

.booking-calendar-editor__question-type,
.booking-calendar-editor__question-requirement {
  color: var(--color-ink-light);
  font-size: var(--text-small);
  font-weight: 650;
  line-height: 1.25;
}

.booking-calendar-editor__table-actions {
  inline-size: 1%;
  white-space: nowrap;
}

.booking-calendar-editor__question-prompt,
.booking-calendar-editor__question-options {
  display: grid;
  gap: 1rem;
  margin-block-start: 0.25rem;
}

.booking-calendar-editor__question-behavior {
  margin-block-start: 0.25rem;
}

.booking-calendar-editor__option-row {
  grid-template-columns: minmax(0, 1fr) minmax(7rem, 0.25fr);
}

.booking-calendar-editor__required-field {
  display: flex;
  align-items: flex-start;
}

.booking-calendar-editor__preview-checkpoint {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface-muted);
  padding-block: 1rem;
  padding-inline: 1rem;
}

.booking-calendar-editor__preview-copy {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  min-inline-size: 0;
}

.booking-calendar-editor__preview-actions {
  display: flex;
  flex: 0 0 auto;
  justify-content: flex-end;
}

.booking-calendar-editor__preview-actions .btn {
  white-space: nowrap;
}

@media (max-width: 760px) {
  .booking-calendars-page__header {
    display: grid;
  }

  .booking-calendars-page__summary {
    justify-content: flex-start;
  }

  .booking-calendars-page .page-box {
    overflow: visible;
    border: 0;
    background: transparent;
    padding: 0;
    box-shadow: none;
  }

  .booking-calendars-page .page-box__body {
    padding: 0;
  }

  .booking-calendars-table {
    overflow-x: visible;
  }

  .booking-calendars-table .simple-table {
    min-inline-size: 0;
  }

  .booking-calendars-table thead {
    position: absolute;
    overflow: hidden;
    inline-size: 1px;
    block-size: 1px;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }

  .booking-calendars-table tbody {
    display: grid;
    gap: 0.875rem;
    padding: 0;
    background-color: transparent;
  }

  .booking-calendar-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background-color: var(--color-surface);
    padding: 1rem;
    box-shadow: var(--shadow-sm);
  }

  .booking-calendar-row .td {
    display: grid;
    grid-template-columns: minmax(5.75rem, 34%) minmax(0, 1fr);
    align-items: flex-start;
    gap: 0.35rem 0.75rem;
    padding: 0;
    text-align: start;
    white-space: normal;
  }

  .booking-calendars-table .table-stripped > tbody > .booking-calendar-row > .td {
    background-color: transparent;
  }

  .booking-calendar-row .td::before {
    content: attr(data-label);
    grid-row: 1 / span 3;
    grid-column: 1;
    color: var(--color-ink-lighter);
    font-size: var(--text-small);
    font-weight: 600;
    line-height: 1.2;
    text-align: start;
  }

  .booking-calendar-row .td > * {
    grid-column: 2;
    justify-self: start;
    min-inline-size: 0;
  }

  .booking-calendar-row__main {
    display: block !important;
    inline-size: 100%;
    min-inline-size: 0;
    padding-block-end: 0.75rem !important;
    border-block-end: 1px solid var(--color-border);
    text-align: start !important;
  }

  .booking-calendar-row__main::before,
  .booking-calendar-row__actions::before {
    content: none !important;
  }

  .booking-calendar-row__url {
    max-inline-size: none;
  }

  .booking-calendar-row__public-link {
    max-inline-size: 100%;
    text-align: start;
  }

  .booking-calendar-row__detail,
  .booking-calendar-row__strong {
    text-align: start;
  }

  .booking-calendar-row__actions {
    justify-content: flex-end !important;
    inline-size: 100%;
    padding-block-start: 0.25rem !important;
  }

  .booking-calendars-table tfoot,
  .booking-calendars-table tfoot tr,
  .booking-calendars-table tfoot td {
    display: block;
  }

  .booking-calendars-table__pagination {
    justify-content: center;
  }

  .booking-calendar-show__header,
  .booking-calendar-show__identity,
  .booking-calendar-show-section__header {
    display: grid;
  }

  .booking-calendar-show__actions {
    justify-content: flex-start;
  }

  .booking-calendar-show-overview {
    grid-template-columns: minmax(0, 1fr);
  }

  .booking-calendar-show-details {
    grid-template-columns: minmax(0, 1fr);
  }

  .booking-calendar-show-details__item,
  .booking-calendar-show-details__item:nth-child(-n + 2),
  .booking-calendar-show-details__item:nth-child(2n) {
    border-inline-start: 0;
    border-block-start: 1px solid var(--color-border);
  }

  .booking-calendar-show-details__item:first-child {
    border-block-start: 0;
  }

  .booking-calendar-show-table {
    overflow-x: visible;
  }

  .booking-calendar-show-table .simple-table {
    min-inline-size: 0;
  }

  .booking-calendar-show-table thead {
    position: absolute;
    overflow: hidden;
    inline-size: 1px;
    block-size: 1px;
    clip: rect(0 0 0 0);
    white-space: nowrap;
  }

  .booking-calendar-show-table tbody {
    display: grid;
    gap: 0.875rem;
    padding: 0;
    background-color: transparent;
  }

  .booking-calendar-show-table tr {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 0.75rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background-color: var(--color-surface);
    padding: 1rem;
    box-shadow: var(--shadow-sm);
  }

  .booking-calendar-show-table td,
  .booking-calendar-show-table .td {
    display: grid;
    grid-template-columns: minmax(5.75rem, 34%) minmax(0, 1fr);
    align-items: flex-start;
    gap: 0.35rem 0.75rem;
    padding: 0;
    text-align: start;
    white-space: normal;
  }

  .booking-calendar-show-table .table-stripped > tbody > tr > td,
  .booking-calendar-show-table .table-stripped > tbody > tr > .td {
    background-color: transparent;
  }

  .booking-calendar-show-table td::before,
  .booking-calendar-show-table .td::before {
    content: attr(data-label);
    grid-column: 1;
    color: var(--color-ink-lighter);
    font-size: var(--text-small);
    font-weight: 600;
    line-height: 1.2;
    text-align: start;
  }

  .booking-calendar-show-table td > *,
  .booking-calendar-show-table .td > * {
    grid-column: 2;
    min-inline-size: 0;
  }

  .booking-calendar-show-table__actions {
    inline-size: 100%;
  }

  .booking-calendar-show-form .form-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .booking-calendar-editor__summary {
    grid-template-columns: minmax(0, 1fr);
  }

  .booking-calendar-editor__summary-item + .booking-calendar-editor__summary-item {
    border-block-start: 1px solid var(--color-border);
    border-inline-start: 0;
  }

  .booking-calendar-editor__legend {
    gap: 0.6rem;
  }

  .booking-calendar-editor__legend-icon {
    inline-size: 1.85rem;
    block-size: 1.85rem;
  }

  .booking-calendar-editor__host-toolbar {
    align-items: flex-start;
  }

  .booking-calendar-editor__table-block {
    overflow: visible;
  }

  .booking-calendar-editor__table-block .simple-table {
    display: block;
  }

  .booking-calendar-editor__table-block .simple-table thead {
    display: none;
  }

  .booking-calendar-editor__table-block .simple-table tbody,
  .booking-calendar-editor__table-block .simple-table tr,
  .booking-calendar-editor__table-block .simple-table td,
  .booking-calendar-editor__table-block .simple-table .td {
    display: block;
  }

  .booking-calendar-editor__table-block .simple-table tbody {
    border: 0;
  }

  .booking-calendar-editor__table-block .simple-table tr {
    border-block-start: 1px solid var(--color-border);
    background-color: var(--color-surface);
  }

  .booking-calendar-editor__table-block .simple-table tr:first-child {
    border-block-start: 0;
  }

  .booking-calendar-editor__table-block .simple-table td,
  .booking-calendar-editor__table-block .simple-table .td {
    display: grid;
    grid-template-columns: minmax(7rem, 0.42fr) minmax(0, 1fr);
    gap: 0.75rem;
    border-block-start: 1px solid var(--color-border);
    padding-block: 0.75rem;
    padding-inline: 1rem;
    text-align: start;
  }

  .booking-calendar-editor__table-block .simple-table tr > td:first-child,
  .booking-calendar-editor__table-block .simple-table tr > .td:first-child {
    border-block-start: 0;
  }

  .booking-calendar-editor__table-block .simple-table td::before,
  .booking-calendar-editor__table-block .simple-table .td::before {
    content: attr(data-label);
    color: var(--color-ink-lighter);
    font-size: var(--text-small);
    font-weight: 600;
    line-height: 1.2;
  }

  .booking-calendar-editor__table-block .simple-table td > *,
  .booking-calendar-editor__table-block .simple-table .td > * {
    min-inline-size: 0;
  }

  .booking-calendar-editor__table-block .simple-table .td--align-right {
    justify-items: stretch;
  }

  .booking-calendar-editor__table-block .simple-table .dropdown {
    justify-self: start;
  }

  .booking-calendar-editor__option-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .booking-calendar-editor__preview-checkpoint {
    display: grid;
    align-items: stretch;
  }

  .booking-calendar-editor__preview-actions {
    justify-content: stretch;
  }

  .booking-calendar-editor__preview-actions .btn {
    inline-size: 100%;
    justify-content: center;
    white-space: normal;
  }
}
