@layer modules {
  .payments-index {
    width: 100%;
    margin-inline: auto;
    padding-inline: 1rem;
    padding-block: 2rem;
  }

  @media (min-width: 40rem) { .payments-index { max-width: 40rem; } }
  @media (min-width: 48rem) { .payments-index { max-width: 48rem; } }
  @media (min-width: 64rem) { .payments-index { max-width: 64rem; } }
  @media (min-width: 80rem) { .payments-index { max-width: 80rem; } }
  @media (min-width: 96rem) { .payments-index { max-width: 96rem; } }

  .payments-index__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.5rem;
  }

  .payments-index__title {
    font-size: var(--text-2xl);
    line-height: var(--text-2xl--line-height);
    font-weight: var(--font-weight-bold);
  }

  .payments-index__new {
    flex: 1;
    --btn-radius: var(--radius-lg);
  }

  @media (min-width: 40rem) {
    .payments-index__new { flex: none; }
  }

  .payments-revenue {
    margin-bottom: 1.5rem;
    border-radius: var(--radius-lg);
    border-style: solid;
    border-width: 1px;
    border-color: var(--color-green-200);
    background-color: var(--color-green-50);
    padding: 1.25rem;
  }

  .payments-revenue__label {
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    font-weight: var(--font-weight-medium);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
    color: var(--color-green-700);
  }

  .payments-revenue__amount {
    margin-top: 0.25rem;
    font-size: var(--text-4xl);
    line-height: var(--text-4xl--line-height);
    font-weight: var(--font-weight-bold);
    letter-spacing: var(--tracking-tight);
    color: var(--color-green-800);
    font-variant-numeric: tabular-nums;
  }

  .payments-row__confidential {
    filter: blur(var(--blur-xs));
  }

  .payments-row__edit {
    position: relative;
    z-index: 10;
    margin-right: 0.75rem;
    font-size: var(--text-xl);
    color: var(--color-blue-600);

    &:hover {
      color: var(--color-blue-900);
    }
  }

  .payments-row__delete {
    position: relative;
    z-index: 10;
    font-size: var(--text-xl);
    color: var(--color-red-600);

    &:hover {
      color: var(--color-red-900);
    }
  }

  .payment-show {
    width: 100%;
    margin-inline: auto;
    display: flex;
  }

  .payment-show__inner {
    margin-inline: auto;
  }

  .payment-show__back {
    margin-bottom: 1rem;
  }

  .payment-card {
    width: 100%;
    background-color: var(--color-white);
    box-shadow: var(--shadow-lg);
    border-radius: var(--radius-lg);
    overflow: hidden;
  }

  @media (min-width: 48rem) {
    .payment-card { width: 50rem; }
  }

  .payment-card__header {
    background-color: var(--color-blue-600);
    color: var(--color-white);
    padding-inline: 1.5rem;
    padding-block: 1rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .payment-card__title {
    font-size: var(--text-2xl);
    line-height: var(--text-2xl--line-height);
    font-weight: var(--font-weight-semibold);
  }

  .payment-card__actions {
    display: flex;

    & > :not(:last-child) {
      margin-inline-end: 1rem;
    }
  }

  .payment-card__body {
    padding: 1.5rem;
  }

  .payment-card__grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 1.5rem;
  }

  @media (min-width: 48rem) {
    .payment-card__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  }

  .payment-card__section-title {
    font-size: var(--text-lg);
    line-height: var(--text-lg--line-height);
    font-weight: var(--font-weight-semibold);
    color: var(--color-blue-800);
    margin-bottom: 1rem;
  }

  .payment-card__items {
    & > :not(:last-child) {
      margin-block-end: 0.75rem;
    }
  }

  .payment-form {
    display: contents;
  }

  .payment-form__errors {
    background-color: var(--color-red-50);
    color: var(--color-red-500);
    padding-inline: 0.75rem;
    padding-block: 0.5rem;
    font-weight: var(--font-weight-medium);
    border-radius: var(--radius-lg);
    margin-top: 0.75rem;
  }

  .payment-form__field {
    margin-block: 1.25rem;
  }

  .payment-form__label {
    display: block;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-semibold);
    color: var(--color-gray-700);
  }

  .payment-form__input {
    display: block;
    width: 100%;
    margin-top: 0.25rem;
    border-radius: var(--radius-md);
    border-color: var(--color-gray-300);
    box-shadow: var(--shadow-xs);

    &:focus {
      --focus-ring-color: var(--color-blue-500);
    }
  }

  @media (min-width: 40rem) {
    .payment-form__input {
      font-size: var(--text-sm);
      line-height: var(--text-sm--line-height);
    }
  }

  .payment-form__submit-wrap {
    display: inline;
  }

  .payment-form__back {
    margin-left: 0.5rem;
    --btn-radius: var(--radius-lg);
  }

  .payment-page {
    margin-inline: auto;
    width: 100%;
  }

  @media (min-width: 48rem) {
    .payment-page { width: 66.6667%; }
  }

  .payment-page__title {
    font-weight: var(--font-weight-bold);
    font-size: var(--text-4xl);
    line-height: var(--text-4xl--line-height);
  }

  .session-payment-form {
    background-color: var(--color-white);
    padding-inline: 1rem;
    padding-bottom: 1rem;
    padding-top: 1.25rem;
  }

  @media (min-width: 40rem) {
    .session-payment-form {
      padding: 1.5rem;
      padding-bottom: 1rem;
    }
  }

  .session-payment-form__footer {
    background-color: var(--color-gray-50);
    padding-inline: 1rem;
    padding-block: 0.75rem;
    margin-inline: -1rem;
    margin-bottom: -1rem;
  }

  @media (min-width: 40rem) {
    .session-payment-form__footer {
      display: flex;
      flex-direction: row-reverse;
      padding-inline: 1.5rem;
    }
  }

  @media (min-width: 40rem) {
    .session-payment-form__submit {
      margin-left: 0.75rem;
    }
  }

  .session-payment-form__cancel {
    margin-top: 0.75rem;
  }

  @media (min-width: 40rem) {
    .session-payment-form__cancel {
      margin-top: 0;
    }
  }

  .session-payment {
    display: block;
  }

  .session-payment__card {
    margin-top: 1rem;
    background-color: var(--color-white);
    box-shadow: var(--shadow-sm);
    border-radius: var(--radius-lg);
    padding: 1rem;
    transition: box-shadow var(--default-transition-duration) var(--default-transition-timing-function);

    &:hover {
      box-shadow: var(--shadow-md);
    }
  }

  .session-payment__row {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .session-payment__received {
    color: var(--color-gray-600);
  }

  .session-payment__amount {
    font-weight: var(--font-weight-semibold);
  }

  .session-payment__method {
    color: var(--color-gray-500);
  }

  .session-payment__date {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-500);
  }

  .session-payment__comment {
    margin-top: 0.5rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-600);
  }

  .session-payment__actions {
    margin-top: 0.75rem;
    display: flex;
    justify-content: flex-end;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);

    & > :not(:last-child) {
      margin-inline-end: 0.5rem;
    }
  }

  .session-payment__edit {
    color: var(--color-blue-600);

    &:hover {
      color: var(--color-blue-800);
    }
  }

  .session-payment__delete {
    color: var(--color-red-600);

    &:hover {
      color: var(--color-red-800);
    }
  }

  .session-payment__icon {
    width: 1.25rem;
    height: 1.25rem;
  }
}
