[hidden] {
  opacity: 0;
  visibility: hidden;
  max-height: 0;
}

time {
  line-height: 1.5rem;

  &.time--caption {
    font-size: 0.875rem;
    line-height: 1rem;
    color: var(--ink-gray);
    white-space: nowrap;
  }

  &.time--highlight {
    display: inline-flex;
    gap: 0.25rem;
    flex-wrap: nowrap;

    .icon * {
      fill: var(--highlight-color);
    }

    &.time--highlight--morning {
      --highlight-color: var(--warning-light);
    }

    &.time--highlight--afternoon {
      --highlight-color: var(--yellow-darker);
    }

    &.time--highlight--night {
      --highlight-color: var(--blue-darker);
    }
  }

  &.skeleton {
    width: 5rem;
  }
}

.fit-content {
  width: fit-content;
}

[role="clickable"] {
  cursor: pointer;
}

.datetime-display, .time-display {
  align-items: center;
  display: flex;
  flex-wrap: nowrap;
  gap: 1rem;

  span.datetime-caret, span.time-separator, .datetime-display__start, .datetime-display__end, .time-display__start, .time-display__end  {
    display: inline-flex;
  }

  .datetime-display__start, .datetime-display__end, .time-display__start, .time-display__end {
    align-items: flex-start;
    flex-direction: column;
    gap: 0.25rem;
  }

  span.datetime-caret, span.time-separator {
    align-items: center;
  }
}

.time-display {
  gap: 0.5rem;

  .time-display__start, .time-display__end {
    gap: 0.25rem;
  }
}
