@layer modules {
  .cp-page {
    width: 100%;
    margin-inline: auto;
    padding-inline: 1rem;
    padding-block: 2rem;

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

  .cp-profiles {
    background-color: var(--color-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    padding: 1.5rem;
    margin-bottom: 1.5rem;
  }

  .cp-profiles__title {
    font-size: var(--text-lg);
    line-height: var(--text-lg--line-height);
    font-weight: var(--font-weight-semibold);
    color: var(--color-gray-900);
    margin-bottom: 1rem;
  }

  .cp-profiles__grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: 1rem;

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

    @media (min-width: 64rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }

  .cp-profile-card {
    padding: 1rem;
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-gray-200);
    border-radius: var(--radius-lg);
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke;

    &:hover {
      background-color: var(--color-gray-50);
    }
  }

  .cp-profile-card--selected {
    border-color: var(--color-indigo-500);
    background-color: var(--color-indigo-50);
  }

  .cp-profile-card__body {
    text-align: center;
  }

  .cp-profile-card__name {
    font-weight: var(--font-weight-medium);
    color: var(--color-gray-900);
  }

  .cp-profile-card__staff {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-500);
  }

  .cp-hero {
    background-image: linear-gradient(to right, var(--color-blue-500), var(--color-indigo-600));
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    padding: 2rem;
    margin-bottom: 2rem;
    color: var(--color-white);

    @supports (background-image: linear-gradient(in lab, red, red)) {
      background-image: linear-gradient(to right in oklab, var(--color-blue-500), var(--color-indigo-600));
    }
  }

  .cp-hero__head {
    display: flex;
    align-items: center;
    margin-bottom: 1rem;
  }

  .cp-hero__icon-wrap {
    margin-right: 1rem;
  }

  .cp-hero__icon {
    height: 2.5rem;
    width: 2.5rem;
    color: var(--color-white);
    opacity: 0.8;
  }

  .cp-hero__title {
    font-size: var(--text-3xl);
    line-height: var(--text-3xl--line-height);
    font-weight: var(--font-weight-bold);
    color: var(--color-white);
    margin-bottom: 0.25rem;
  }

  .cp-hero__subtitle {
    font-size: var(--text-lg);
    line-height: var(--text-lg--line-height);
    color: var(--color-blue-100);
  }

  .cp-hero__actions {
    display: flex;
    justify-content: flex-end;
    margin-top: 0.5rem;
  }

  .cp-hero__book {
    --btn-gap: 0.25rem;
    --btn-radius: var(--radius-lg);
    --btn-bg: var(--color-white);
    --btn-color: var(--color-indigo-700);
    box-shadow: var(--shadow-md);
  }

  .cp-hero__book-icon {
    height: 1.25rem;
    width: 1.25rem;
  }

  .cp-reminder {
    background-color: var(--color-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-gray-200);
    padding-inline: 1.5rem;
    padding-block: 1rem;
    margin-top: 2rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .cp-reminder__label {
    display: flex;
    align-items: center;
    gap: 0.75rem;
  }

  .cp-reminder__icon {
    height: 1.25rem;
    width: 1.25rem;
    color: var(--color-gray-400);
  }

  .cp-reminder__text {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-700);
  }

  .cp-toggle {
    position: relative;
    display: inline-flex;
    align-items: center;
    cursor: pointer;
  }

  .cp-toggle__track {
    position: relative;
    width: 2.75rem;
    height: 1.5rem;
    background-color: var(--color-gray-200);
    border-radius: var(--radius-full);
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke;

    &::after {
      content: "";
      position: absolute;
      top: 2px;
      left: 2px;
      height: 1.25rem;
      width: 1.25rem;
      background-color: var(--color-white);
      border-radius: var(--radius-full);
      transition: var(--default-transition-duration) var(--default-transition-timing-function);
      transition-property: transform, translate, scale, rotate;
    }
  }

  .cp-toggle__input:focus-visible ~ .cp-toggle__track {
    --focus-ring-color: var(--color-indigo-300);
    outline: var(--focus-ring);
    outline-offset: var(--focus-ring-offset);
  }

  .cp-toggle__input:checked ~ .cp-toggle__track {
    background-color: var(--color-indigo-600);
  }

  .cp-toggle__input:checked ~ .cp-toggle__track::after {
    translate: 1.25rem 0;
  }

  .cp-section {
    background-color: var(--color-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    padding: 1.5rem;
    margin-top: 2rem;
  }

  .cp-section__head {
    display: flex;
    align-items: center;
    margin-bottom: 1.5rem;
  }

  .cp-section__icon {
    height: 1.5rem;
    width: 1.5rem;
    color: var(--color-indigo-600);
    margin-right: 0.75rem;
  }

  .cp-section__icon--done {
    color: var(--color-green-600);
  }

  .cp-section__title {
    font-size: var(--text-xl);
    line-height: var(--text-xl--line-height);
    font-weight: var(--font-weight-semibold);
    color: var(--color-gray-900);
  }

  .cp-form-list > :not(:last-child) {
    margin-bottom: 1rem;
  }

  .cp-completed-list > :not(:last-child) {
    margin-bottom: 0.75rem;
  }

  .cp-form-row {
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-gray-200);
    border-radius: var(--radius-lg);
    padding: 1rem;
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke;

    &:hover {
      border-color: var(--color-indigo-300);
    }
  }

  .cp-form-row__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .cp-form-row__main {
    flex: 1;
  }

  .cp-form-row__title {
    font-size: var(--text-lg);
    line-height: var(--text-lg--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-gray-900);
    margin-bottom: 0.25rem;
  }

  .cp-form-row__desc {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-600);
    margin-bottom: 0.5rem;
  }

  .cp-form-row__meta {
    display: flex;
    align-items: center;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-500);
  }

  .cp-form-row__meta > :not(:last-child) {
    margin-inline-end: 1rem;
  }

  .cp-status-pill {
    display: inline-flex;
    align-items: center;
    padding-inline: 0.625rem;
    padding-block: 0.125rem;
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    font-weight: var(--font-weight-medium);
  }

  .cp-form-row__action {
    margin-left: 1rem;
  }

  .cp-form-row__button-icon {
    height: 1rem;
    width: 1rem;
  }

  .cp-completed-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-block: 0.75rem;
    padding-inline: 1rem;
    background-color: var(--color-green-50);
    border-radius: var(--radius-lg);
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke;

    &:hover {
      background-color: var(--color-green-100);
    }
  }

  .cp-completed-row__title {
    font-weight: var(--font-weight-medium);
    color: var(--color-gray-900);
  }

  .cp-completed-row__date {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-600);
  }

  .cp-completed-row__right {
    display: flex;
    align-items: center;
    gap: 0.75rem;
  }

  .cp-completed-pill {
    display: inline-flex;
    align-items: center;
    padding-inline: 0.625rem;
    padding-block: 0.125rem;
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    font-weight: var(--font-weight-medium);
    background-color: var(--color-green-100);
    color: var(--color-green-800);
  }

  .cp-completed-pill__icon {
    height: 0.75rem;
    width: 0.75rem;
    margin-right: 0.25rem;
  }

  .cp-completed-row__chevron {
    height: 1.25rem;
    width: 1.25rem;
    color: var(--color-gray-400);
  }

  .cp-alert {
    background-color: var(--color-yellow-50);
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-yellow-200);
    border-radius: var(--radius-lg);
    padding: 1.5rem;
  }

  .cp-alert__row {
    display: flex;
  }

  .cp-alert__icon-wrap {
    flex-shrink: 0;
  }

  .cp-alert__icon {
    height: 1.25rem;
    width: 1.25rem;
    color: var(--color-yellow-400);
  }

  .cp-alert__body {
    margin-left: 0.75rem;
  }

  .cp-alert__title {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-yellow-800);
  }

  .cp-alert__text {
    margin-top: 0.5rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-yellow-700);
  }

  .cp-form-shell {
    min-height: 100vh;
    background-color: var(--color-slate-50-50);

    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-slate-50) 50%, transparent);
    }
  }

  .cp-form-container {
    width: 100%;
    margin-inline: auto;
    padding-inline: 1rem;
    padding-block: 2.5rem;

    @media (min-width: 40rem) { max-width: 40rem; }
    @media (min-width: 48rem) { max-width: 48rem; padding-block: 3.5rem; }
    @media (min-width: 64rem) { max-width: 64rem; }
    @media (min-width: 80rem) { max-width: 80rem; }
    @media (min-width: 96rem) { max-width: 96rem; }
  }

  .cp-form-inner {
    max-width: var(--container-2xl);
    margin-inline: auto;
  }

  .cp-form-back {
    margin-bottom: 2rem;
  }

  .cp-form-back__link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-slate-500);
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke;

    &:hover {
      color: var(--color-indigo-600);
    }
  }

  .cp-form-back__icon {
    width: 1rem;
    height: 1rem;
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: transform, translate, scale, rotate;

    .cp-form-back__link:hover & {
      translate: -0.125rem 0;
    }
  }

  .cp-form-header {
    margin-bottom: 2.5rem;
  }

  .cp-form-header__top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 1rem;
    margin-bottom: 0.75rem;
  }

  .cp-form-header__title {
    font-size: var(--text-2xl);
    line-height: var(--leading-tight);
    font-weight: var(--font-weight-semibold);
    color: var(--color-slate-900);
    letter-spacing: var(--tracking-tight);

    @media (min-width: 48rem) {
      font-size: var(--text-3xl);
    }
  }

  .cp-form-status {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding-inline: 0.625rem;
    padding-block: 0.25rem;
    border-radius: var(--radius-full);
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    font-weight: var(--font-weight-medium);
    flex-shrink: 0;
  }

  .cp-form-status--done {
    background-color: var(--color-green-100);
    color: var(--color-green-800);
  }

  .cp-form-status__dot {
    width: 0.375rem;
    height: 0.375rem;
    border-radius: var(--radius-full);
  }

  .cp-form-status__dot--done {
    background-color: var(--color-green-500);
  }

  .cp-form-status__dot--pending {
    background-color: currentColor;
    opacity: 0.5;
  }

  .cp-form-header__date {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-slate-500);
  }

  .cp-form-desc {
    margin-top: 1.5rem;
    padding: 1rem;
    background-color: #eef2ff80;
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-indigo-100);
    border-radius: var(--radius-xl);

    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-indigo-50) 50%, transparent);
    }
  }

  .cp-form-desc__text {
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
    color: #312c85cc;

    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-indigo-900) 80%, transparent);
    }
  }

  .cp-steps {
    margin-bottom: 2.5rem;
  }

  .cp-steps__track {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .cp-steps__connector {
    height: 0.125rem;
    flex: 1;
    min-width: 1.5rem;
    margin-inline: 0.25rem;
  }

  .cp-steps__connector--done {
    background-color: var(--color-indigo-600);
  }

  .cp-steps__connector--todo {
    background-color: var(--color-slate-200);
  }

  .cp-steps__counter {
    text-align: center;
    margin-top: 1rem;
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    color: var(--color-slate-400);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
  }

  .cp-step {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: var(--radius-full);
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-semibold);
  }

  .cp-step--current {
    background-color: var(--color-indigo-600);
    color: var(--color-white);
    box-shadow: 0 0 0 4px var(--color-indigo-100);
  }

  .cp-step--button {
    transition: all 0.2s var(--default-transition-timing-function);
    cursor: pointer;
  }

  .cp-step--completed {
    background-color: var(--color-indigo-600);
    color: var(--color-white);

    &:hover {
      box-shadow: 0 0 0 2px var(--color-indigo-200);
    }
  }

  .cp-step--todo {
    background-color: var(--color-white);
    border-width: 2px;
    border-style: solid;
    border-color: var(--color-slate-200);

    &:hover {
      border-color: var(--color-indigo-300);
      color: var(--color-indigo-600);
    }
  }

  .cp-step-section {
    margin-bottom: 2rem;
    text-align: center;
  }

  .cp-step-section__title {
    font-size: var(--text-xl);
    line-height: var(--text-xl--line-height);
    font-weight: var(--font-weight-semibold);
    color: var(--color-slate-900);
    margin-bottom: 0.5rem;
  }

  .cp-step-section__desc {
    color: var(--color-slate-500);
    max-width: var(--container-lg);
    margin-inline: auto;
    white-space: pre-line;
  }

  .cp-fields > :not(:last-child) {
    margin-bottom: 1.25rem;
  }

  .cp-actions {
    margin-top: 2.5rem;
    padding-top: 2rem;
    border-top-width: 1px;
    border-top-style: solid;
    border-top-color: var(--color-slate-200);
  }

  .cp-actions__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
  }

  .cp-actions__row--end {
    justify-content: flex-end;
    gap: 0.75rem;
  }

  .cp-actions__cluster {
    display: flex;
    align-items: center;
    gap: 0.75rem;
  }

  .cp-btn-secondary {
    --btn-radius: var(--radius-lg);
  }

  .cp-btn-text {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding-inline: 1rem;
    padding-block: 0.625rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-slate-500);
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke;

    &:hover {
      color: var(--color-slate-700);
    }
  }

  .cp-btn-primary {
    --btn-radius: var(--radius-lg);
  }

  .cp-btn-icon {
    width: 1rem;
    height: 1rem;
  }

  .cp-done-banner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75rem;
    padding-block: 1rem;
    padding-inline: 1.5rem;
    background-color: var(--color-green-50);
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-green-200);
    border-radius: var(--radius-xl);
  }

  .cp-done-banner__disc {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    background-color: var(--color-green-100);
    border-radius: var(--radius-full);
  }

  .cp-done-banner__icon {
    width: 1.25rem;
    height: 1.25rem;
    color: var(--color-green-600);
  }

  .cp-done-banner__text {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-green-800);
  }

  .cp-field {
    background-color: var(--color-white);
    border-radius: var(--radius-xl);
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-slate-200);
    overflow: hidden;
    transition: 0.2s var(--default-transition-timing-function);
    transition-property: border-color, outline, outline-offset;

    &:focus-within {
      --focus-ring-color: var(--color-indigo-500);
      border-color: var(--color-indigo-500);
      outline: var(--focus-ring);
      outline-offset: -1px;
    }
  }

  .cp-field__body {
    padding-inline: 1.25rem;
    padding-block: 1.25rem;

    @media (min-width: 40rem) {
      padding-inline: 1.5rem;
    }
  }

  .cp-field__label {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin-bottom: 0.375rem;
  }

  .cp-field__label-text {
    font-size: var(--text-base);
    line-height: var(--leading-snug);
    font-weight: var(--font-weight-medium);
    color: var(--color-slate-900);
  }

  .cp-field__required {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 0.375rem;
    height: 0.375rem;
    margin-top: 0.5rem;
    border-radius: var(--radius-full);
    background-color: var(--color-red-400);
  }

  .cp-field__desc {
    font-size: var(--text-sm);
    line-height: var(--leading-relaxed);
    color: var(--color-slate-500);
    margin-bottom: 1rem;
    white-space: pre-line;
  }

  .cp-field__spacer {
    margin-bottom: 0.75rem;
  }

  .cp-input {
    width: 100%;
    padding-inline: 1rem;
    padding-block: 0.75rem;
    color: var(--color-slate-900);
    background-color: var(--color-slate-50-50);
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-slate-200);
    border-radius: var(--radius-lg);
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: background-color, border-color, outline, outline-offset;

    &::placeholder {
      color: var(--color-slate-400);
    }

    &:focus {
      --focus-ring-color: var(--color-indigo-500);
      background-color: var(--color-white);
      border-color: var(--color-indigo-500);
    }

    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-slate-50) 50%, transparent);
    }
  }

  .cp-input--textarea {
    resize: none;
  }

  .cp-input--select {
    appearance: none;
    padding-right: 2.5rem;
    cursor: pointer;
  }

  .cp-input--signature {
    padding-inline: 1rem;
    padding-block: 1rem;
    font-size: var(--text-2xl);
    line-height: var(--text-2xl--line-height);
    border-style: dashed;
    font-family: var(--font-signature);
  }

  .cp-field__control {
    position: relative;
  }

  .cp-field__adornment {
    position: absolute;
    right: 0.75rem;
    top: 50%;
    translate: 0 -50%;
    pointer-events: none;
  }

  .cp-field__adornment-icon {
    width: 1.25rem;
    height: 1.25rem;
    color: var(--color-slate-300);
  }

  .cp-field__adornment-icon--select {
    color: var(--color-slate-400);
  }

  .cp-field__hint {
    margin-top: 0.5rem;
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    color: var(--color-slate-400);
    display: flex;
    align-items: center;
    gap: 0.375rem;
  }

  .cp-field__hint-icon {
    width: 0.875rem;
    height: 0.875rem;
  }

  .cp-options > :not(:last-child) {
    margin-bottom: 0.5rem;
  }

  .cp-option {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem;
    border-radius: var(--radius-lg);
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-slate-200);
    background-color: var(--color-slate-50-50);
    transition: all var(--default-transition-duration) var(--default-transition-timing-function);
    cursor: pointer;

    &:hover {
      background-color: var(--color-slate-50);
      border-color: var(--color-slate-300);
    }

    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-slate-50) 50%, transparent);
    }
  }

  .cp-option--checked {
    background-color: var(--color-indigo-50);
    border-color: var(--color-indigo-200);
  }

  .cp-option__control {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .cp-option__checkbox {
    width: 1.25rem;
    height: 1.25rem;
    border-radius: var(--radius-sm);
    border-color: var(--color-slate-300);
    color: var(--color-indigo-600);
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: border-color, background-color, outline, outline-offset;
    cursor: pointer;

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

  .cp-option__text {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-slate-700);
    -webkit-user-select: none;
    user-select: none;
  }

  .cp-view-steps > :not(:last-child) {
    margin-bottom: 2rem;
  }

  .cp-view-card {
    background-color: var(--color-white);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-sm);
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-slate-200);
    overflow: hidden;
  }

  .cp-view-card__header {
    padding-inline: 1.5rem;
    padding-block: 1rem;
    background-color: var(--color-slate-50);
    border-bottom-width: 1px;
    border-bottom-style: solid;
    border-bottom-color: var(--color-slate-200);
  }

  .cp-view-card__heading {
    font-weight: var(--font-weight-semibold);
    color: var(--color-slate-900);
  }

  .cp-view-card__desc {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-slate-500);
    margin-top: 0.25rem;
    white-space: pre-line;
  }

  .cp-view-card__body {
    padding: 1.5rem;
  }

  .cp-view-card__body > :not(:last-child) {
    margin-bottom: 1rem;
  }

  .cp-view-card--empty {
    overflow: visible;
    padding: 1.5rem;
  }

  .cp-view-empty {
    color: var(--color-slate-500);
    text-align: center;
  }

  .cp-billing-back {
    margin-bottom: 1.5rem;
  }

  .cp-billing-back__link {
    color: var(--color-indigo-600);
    font-weight: var(--font-weight-medium);

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

  .cp-billing-card {
    background-color: var(--color-white);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-md);
    padding: 1.5rem;
  }

  .cp-billing-inner {
    max-width: var(--container-2xl);
    margin-inline: auto;
  }

  .cp-billing-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 1.5rem;
  }

  .cp-billing-head--simple {
    justify-content: flex-start;
  }

  .cp-billing-head__title-wrap {
    display: flex;
    align-items: center;
  }

  .cp-billing-head__icon {
    height: 1.5rem;
    width: 1.5rem;
    color: var(--color-indigo-600);
    margin-right: 0.75rem;
  }

  .cp-billing-head__title {
    font-size: var(--text-2xl);
    line-height: var(--text-2xl--line-height);
    font-weight: var(--font-weight-semibold);
    color: var(--color-gray-900);
  }

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

  .cp-notice-row {
    display: flex;
  }

  .cp-notice-row__icon-wrap {
    flex-shrink: 0;
  }

  .cp-notice-row__body {
    margin-left: 0.75rem;
  }

  .cp-billing-success__icon {
    height: 1.25rem;
    width: 1.25rem;
    color: var(--color-green-400);
  }

  .cp-billing-success__text {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-green-800);
  }

  .cp-card-row {
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-gray-200);
    border-radius: var(--radius-lg);
    padding: 1rem;
    display: flex;
    align-items: center;
    justify-content: space-between;
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke;

    &:hover {
      border-color: var(--color-gray-300);
    }
  }

  .cp-card-row__info {
    display: flex;
    align-items: center;
  }

  .cp-card-row__brand {
    width: 3rem;
    height: 2rem;
    border-radius: var(--radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-right: 1rem;
    flex-shrink: 0;
  }

  .cp-card-row__number {
    font-weight: var(--font-weight-medium);
    color: var(--color-gray-900);
  }

  .cp-card-row__expiry {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-500);
  }

  .cp-card-row__remove {
    display: inline-flex;
    align-items: center;
    padding-inline: 0.75rem;
    padding-block: 0.5rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-red-600);
    border-radius: var(--radius-md);
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke;

    &:hover {
      color: var(--color-red-700);
      background-color: var(--color-red-50);
    }
  }

  .cp-card-row__remove-icon {
    height: 1rem;
    width: 1rem;
    margin-right: 0.25rem;
  }

  .cp-info-blue {
    background-color: var(--color-blue-50);
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-blue-200);
    border-radius: var(--radius-lg);
    padding: 1rem;
  }

  .cp-info-blue--spaced {
    margin-top: 1rem;
  }

  .cp-info-blue--below {
    margin-bottom: 1.5rem;
  }

  .cp-info-blue__icon {
    height: 1.25rem;
    width: 1.25rem;
    color: var(--color-blue-400);
  }

  .cp-info-blue__text {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-blue-800);
  }

  .cp-billing-empty {
    text-align: center;
    padding-block: 3rem;
  }

  .cp-billing-empty__icon {
    height: 4rem;
    width: 4rem;
    margin-inline: auto;
    color: var(--color-gray-400);
    margin-bottom: 1rem;
  }

  .cp-billing-empty__title {
    font-size: var(--text-lg);
    line-height: var(--text-lg--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-gray-900);
    margin-bottom: 0.5rem;
  }

  .cp-billing-empty__text {
    color: var(--color-gray-600);
    margin-bottom: 1rem;
  }

  .cp-billing-add {
    display: inline-flex;
    align-items: center;
    padding-inline: 1rem;
    padding-block: 0.5rem;
    background-color: var(--color-indigo-600);
    color: var(--color-white);
    font-weight: var(--font-weight-medium);
    border-radius: var(--radius-lg);
    transition: var(--default-transition-duration) var(--default-transition-timing-function);
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke;

    &:hover {
      background-color: var(--color-indigo-700);
    }
  }

  .cp-billing-add__icon {
    height: 1rem;
    width: 1rem;
    margin-right: 0.5rem;
  }

  .cp-billing-footer {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top-width: 1px;
    border-top-style: solid;
    border-top-color: var(--color-gray-200);
  }

  .cp-billing-footer__row {
    display: flex;
    align-items: flex-start;
  }

  .cp-billing-footer__icon {
    height: 1.25rem;
    width: 1.25rem;
    color: var(--color-gray-400);
    margin-right: 0.5rem;
    margin-top: 0.125rem;
    flex-shrink: 0;
  }

  .cp-billing-footer__text {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-600);
  }

  .cp-addcard-intro {
    margin-bottom: 1.5rem;
  }

  .cp-addcard-intro__text {
    color: var(--color-gray-600);
    margin-bottom: 1rem;
  }

  .cp-addcard-howicon {
    height: 1.25rem;
    width: 1.25rem;
    color: var(--color-blue-500);
    flex-shrink: 0;
    margin-right: 0.75rem;
    margin-top: 0.125rem;
  }

  .cp-addcard-howbody {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-blue-800);
  }

  .cp-addcard-howbody__lead {
    font-weight: var(--font-weight-medium);
    margin-bottom: 0.25rem;
  }

  .cp-addcard-list {
    list-style-type: disc;
    list-style-position: inside;
    color: var(--color-blue-700);
  }

  .cp-addcard-list > :not(:last-child) {
    margin-bottom: 0.25rem;
  }

  .cp-addcard-submit {
    --btn-radius: var(--radius-lg);
  }

  .cp-addcard-submit__icon {
    height: 1.25rem;
    width: 1.25rem;
  }

  .cp-addcard-powered {
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-500);
  }

  .cp-addcard-powered__label {
    margin-right: 0.5rem;
  }

  .cp-addcard-powered__logo {
    height: 1.5rem;
  }

  .cp-accept {
    display: flex;
    min-height: 100vh;
    flex-direction: column;
  }

  .cp-accept__main {
    flex: 1;
    display: flex;
    justify-content: center;
    padding-inline: 1rem;
    padding-block: 4rem;

    @media (min-width: 40rem) { padding-inline: 1.5rem; }
    @media (min-width: 64rem) { padding-inline: 2rem; }
  }

  .cp-accept__panel {
    max-width: var(--container-md);
    width: 100%;
  }

  .cp-accept__panel > :not(:last-child) {
    margin-bottom: 2rem;
  }

  .cp-accept__header {
    text-align: center;
  }

  .cp-accept__title {
    margin-top: 1.5rem;
    font-size: var(--text-3xl);
    line-height: var(--text-3xl--line-height);
    font-weight: var(--font-weight-extrabold);
    color: var(--color-gray-900);
  }

  .cp-accept__lead {
    margin-top: 1rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-600);
  }

  .cp-accept__form {
    margin-top: 2rem;
  }

  .cp-accept__form > :not(:last-child) {
    margin-bottom: 1.5rem;
  }

  .cp-accept__info {
    border-radius: var(--radius-md);
    background-color: var(--color-blue-50);
    padding: 1rem;
  }

  .cp-accept__info-row {
    display: flex;
  }

  .cp-accept__info-body {
    margin-left: 0.75rem;
  }

  .cp-accept__info-title {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-blue-800);
  }

  .cp-accept__info-text {
    margin-top: 0.5rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-blue-700);
  }

  .cp-accept__list {
    list-style-type: disc;
    padding-left: 1.25rem;
  }

  .cp-accept__list > :not(:last-child) {
    margin-bottom: 0.25rem;
  }

  .cp-cancel {
    background-color: var(--color-white);
    padding-inline: 1rem;
    padding-top: 1.25rem;
    padding-bottom: 1rem;

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

  .cp-cancel__layout {
    @media (min-width: 40rem) {
      display: flex;
      align-items: flex-start;
    }
  }

  .cp-cancel__icon-disc {
    margin-inline: auto;
    display: flex;
    height: 3rem;
    width: 3rem;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius-full);
    background-color: var(--color-red-100);

    @media (min-width: 40rem) {
      margin-inline: 0;
      height: 2.5rem;
      width: 2.5rem;
    }
  }

  .cp-cancel__icon {
    height: 1.5rem;
    width: 1.5rem;
    color: var(--color-red-600);
  }

  .cp-cancel__content {
    margin-top: 0.75rem;
    text-align: center;
    width: 100%;

    @media (min-width: 40rem) {
      margin-left: 1rem;
      margin-top: 0;
      text-align: left;
    }
  }

  .cp-cancel__title {
    font-size: var(--text-lg);
    line-height: 1.5rem;
    font-weight: var(--font-weight-semibold);
    color: var(--color-gray-900);
    margin-bottom: 1rem;
  }

  .cp-cancel__field {
    margin-bottom: 1rem;
  }

  .cp-cancel__label {
    display: block;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-gray-700);
    margin-bottom: 0.25rem;
  }

  .cp-cancel__textarea {
    width: 100%;
    padding-inline: 0.75rem;
    padding-block: 0.5rem;
    border-width: 1px;
    border-style: solid;
    border-color: var(--color-gray-300);
    border-radius: var(--radius-md);

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

  .cp-cancel__actions {
    display: flex;
    justify-content: flex-end;
    gap: 0.75rem;
    margin-top: 1.25rem;
  }

}

@layer modules {
  .card-brand-logo {
    height: 2rem;
    width: 3rem;
    object-fit: contain;
  }

  .card-brand-logo--fallback {
    color: var(--color-gray-600);
  }
}
