/*
  Claims: the session-page claim section (with its per-state panels), the
  full-page claim form, claim detail (summary / service-line table / diagnosis
  codes), and the new/show/replacement page chrome. Status pills come from the
  status_badge helper (.badge) and are left untouched.
*/

@layer modules {
  .claim-section {
    margin-top: 1.5rem;
    background-color: var(--color-white);
    box-shadow: var(--shadow-lg);
    border-radius: var(--radius-lg);
    overflow: hidden;
    width: 100%;
  }

  @media (min-width: 48rem) {
    .claim-section { width: 50rem; }
  }

  .claim-section__header {
    background-color: var(--color-indigo-600);
    color: var(--color-white);
    padding-inline: 1.5rem;
    padding-block: 0.75rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .claim-section__header-left {
    display: flex;
    align-items: center;
    gap: 0.75rem;
  }

  .claim-section__title {
    font-size: var(--text-lg);
    line-height: var(--text-lg--line-height);
    font-weight: var(--font-weight-semibold);
  }

  .claim-section__learn {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-indigo-100);
    text-decoration-line: underline;

    &:hover {
      color: var(--color-white);
    }
  }

  .claim-section__body {
    padding: 1.5rem;
  }

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

  .claim-state__status-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }

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

  /* Standalone state pills not from status_badge (headless / voided) */
  .claim-state__pill {
    display: inline-flex;
    align-items: center;
    padding-inline: 0.5rem;
    padding-block: 0.125rem;
    border-radius: var(--radius-md);
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    font-weight: var(--font-weight-medium);
  }

  .claim-state__pill--amber {
    background-color: var(--color-amber-100);
    color: var(--color-amber-800);
  }

  .claim-state__pill--gray {
    background-color: var(--color-gray-100);
    color: var(--color-gray-700);
  }

  .claim-state__details {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-600);

    & > :not(:last-child) {
      margin-block-end: 0.25rem;
    }
  }

  .claim-state__detail-label {
    font-weight: var(--font-weight-medium);
  }

  .claim-state__message {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    padding: 0.75rem;
    border-radius: var(--radius-md);
  }

  .claim-state__message--red {
    color: var(--color-red-700);
    background-color: var(--color-red-50);
  }

  .claim-state__message--amber {
    color: var(--color-amber-800);
    background-color: var(--color-amber-50);
  }

  .claim-state__note {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-600);
  }

  .claim-state__small-note {
    font-size: var(--text-xs);
    line-height: 1.25rem;
    color: var(--color-gray-500);
  }

  .claim-state__actions {
    display: flex;
    gap: 0.75rem;
  }

  .claim-state__actions--wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
  }

  .claim-action {
    display: inline-flex;
    align-items: center;
    padding-inline: 0.75rem;
    padding-block: 0.375rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-medium);
    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;
  }

  .claim-action--soft {
    color: var(--color-indigo-700);
    background-color: var(--color-indigo-50);

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

  .claim-action--neutral {
    color: var(--color-gray-700);
    background-color: var(--color-gray-50);

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

  .claim-action--danger {
    color: var(--color-red-700);
    background-color: var(--color-red-50);

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

  .claim-action--disabled {
    color: var(--color-gray-500);
    background-color: var(--color-gray-100);
    cursor: not-allowed;
  }

  .claim-state__link {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-indigo-600);
    font-weight: var(--font-weight-medium);

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

  .claim-pending {
    display: flex;
    align-items: center;
    gap: 0.75rem;
  }

  .claim-pending__icon {
    animation: var(--animate-spin);
    height: 1.25rem;
    width: 1.25rem;
    color: var(--color-indigo-600);
  }

  .claim-pending__label {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-600);
  }

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

  .claim-empty__warning {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-amber-700);
    background-color: var(--color-amber-50);
    padding: 0.75rem;
    border-radius: var(--radius-md);
  }

  .claim-empty__warning-link {
    text-decoration-line: underline;
    font-weight: var(--font-weight-medium);
  }

  .claim-notice {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-amber-800);
    background-color: var(--color-amber-50);
    border: 1px solid var(--color-amber-200);
    padding: 0.75rem;
    border-radius: var(--radius-md);

    & > :not(:last-child) {
      margin-block-end: 0.25rem;
    }
  }

  .claim-notice__lead {
    font-weight: var(--font-weight-medium);
  }

  .claim-page {
    margin-inline: auto;
    width: 100%;
    display: flex;
  }

  .claim-page__inner {
    margin-inline: auto;
    width: 100%;
  }

  @media (min-width: 48rem) {
    .claim-page__inner { width: 50rem; }
  }

  .claim-page__back {
    margin-bottom: 1rem;
  }

  .claim-page__card {
    background-color: var(--color-white);
    box-shadow: var(--shadow-lg);
    border-radius: var(--radius-lg);
    overflow: hidden;
  }

  .claim-page__header {
    background-color: var(--color-indigo-600);
    color: var(--color-white);
    padding-inline: 1.5rem;
    padding-block: 1rem;
  }

  .claim-page__header--with-badge {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

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

  .claim-page__subtitle {
    color: var(--color-indigo-100);
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    margin-top: 0.25rem;
  }

  .claim-page__body {
    padding: 1.5rem;
  }

  .claim-show {
    & > :not(:last-child) {
      margin-block-end: 1.5rem;
    }
  }

  .claim-show__rejected-note {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-600);
    background-color: var(--color-gray-50);
    border: 1px solid var(--color-gray-200);
    padding: 0.75rem;
    border-radius: var(--radius-md);
  }

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

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

  .claim-summary__col {
    & > :not(:last-child) {
      margin-block-end: 0.5rem;
    }
  }

  .claim-summary__row {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
  }

  .claim-summary__label {
    font-weight: var(--font-weight-medium);
    color: var(--color-gray-500);
  }

  .claim-summary__value {
    color: var(--color-gray-900);
  }

  .claim-summary__value--mono {
    color: var(--color-gray-900);
    font-family: var(--font-mono);
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
  }

  .claim-summary__value--strong {
    color: var(--color-gray-900);
    font-weight: var(--font-weight-semibold);
  }

  .claim-summary__note {
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    color: var(--color-gray-500);
  }

  .claim-dx__heading {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-semibold);
    color: var(--color-gray-800);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
    margin-bottom: 0.5rem;
  }

  .claim-dx__list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
  }

  .claim-dx__chip {
    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-gray-100);
    color: var(--color-gray-800);
  }

  .claim-lines__heading {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-semibold);
    color: var(--color-gray-800);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
    margin-bottom: 0.5rem;
  }

  .claim-lines__scroll {
    overflow-x: auto;
  }

  .claim-lines__table {
    min-width: 100%;
    border-collapse: collapse;

    & > :not(:last-child) {
      border-bottom: 1px solid var(--color-gray-200);
    }
  }

  .claim-lines__thead {
    background-color: var(--color-gray-50);
  }

  .claim-lines__th {
    padding-inline: 1rem;
    padding-block: 0.5rem;
    text-align: left;
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-gray-500);
    text-transform: uppercase;
  }

  .claim-lines__tbody {
    background-color: var(--color-white);

    & > tr:not(:last-child) {
      border-bottom: 1px solid var(--color-gray-200);
    }
  }

  .claim-lines__td {
    padding-inline: 1rem;
    padding-block: 0.5rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-600);
  }

  .claim-lines__td--code {
    color: var(--color-gray-900);
    font-family: var(--font-mono);
  }

  .claim-lines__td--strong {
    color: var(--color-gray-900);
  }

  .claim-error {
    background-color: var(--color-red-50);
    border: 1px solid var(--color-red-200);
    border-radius: var(--radius-md);
    padding: 1rem;
  }

  .claim-error__title {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-red-800);
  }

  .claim-error__text {
    margin-top: 0.25rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-red-700);
  }

  .claim-form-errors {
    margin-bottom: 1.5rem;
    background-color: var(--color-red-50);
    border: 1px solid var(--color-red-200);
    border-radius: var(--radius-md);
    padding: 1rem;
  }

  .claim-form-errors__title {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-red-800);
  }

  .claim-form-errors__list {
    margin-top: 0.5rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-red-700);
    list-style-type: disc;
    list-style-position: inside;
  }

  .claim-form-section {
    margin-bottom: 1.5rem;
  }

  .claim-form-section__title {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-semibold);
    color: var(--color-gray-800);
    text-transform: uppercase;
    letter-spacing: var(--tracking-wide);
    margin-bottom: 0.75rem;
  }

  .claim-form-section__description {
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    color: var(--color-gray-500);
    margin-bottom: 0.5rem;
  }

  .claim-form__locked-name {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-900);
  }

  .claim-form__locked-note {
    margin-top: 0.25rem;
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    color: var(--color-gray-500);
  }

  .claim-form__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;
  }

  .claim-form__select {
    display: block;
    width: 100%;
    border-radius: var(--radius-md);
    border-color: var(--color-gray-300);
    box-shadow: var(--shadow-xs);

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

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

  .claim-form__select--narrow {
    display: block;
    width: 16rem;
    border-radius: var(--radius-md);
    border-color: var(--color-gray-300);
    box-shadow: var(--shadow-xs);

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

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

  .claim-form__payer-warning {
    margin-top: 0.5rem;
    border-radius: var(--radius-md);
    background-color: var(--color-amber-50);
    border: 1px solid var(--color-amber-200);
    padding: 0.75rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-amber-800);
  }

  .claim-form__dx-list {
    & > :not(:last-child) {
      margin-block-end: 0.5rem;
    }
  }

  .claim-form__dx-row {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }

  .claim-form__dx-index {
    font-size: var(--text-xs);
    line-height: var(--text-xs--line-height);
    color: var(--color-gray-400);
    width: 1.25rem;
    text-align: right;
  }

  .claim-form__dx-input {
    display: block;
    width: 12rem;
    border-radius: var(--radius-md);
    border-color: var(--color-gray-300);
    box-shadow: var(--shadow-xs);

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

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

  .claim-form__remove {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-red-600);
    font-weight: var(--font-weight-medium);

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

  .claim-form__add {
    margin-top: 0.75rem;
    display: inline-flex;
    align-items: center;
    padding-inline: 0.75rem;
    padding-block: 0.375rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    font-weight: var(--font-weight-medium);
    color: var(--color-indigo-600);
    background-color: var(--color-indigo-50);
    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 {
      background-color: var(--color-indigo-100);
    }
  }

  .claim-form__footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 1.5rem;
    border-top: 1px solid var(--color-gray-200);
  }

  .claim-form__cancel {
    color: var(--color-gray-600);
    font-weight: var(--font-weight-medium);
    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-gray-800);
    }
  }

  .claim-form__submit {
    &:disabled {
      --btn-bg: var(--color-gray-400);
      cursor: not-allowed;
    }
  }

  .claim-line {
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    padding: 1rem;
    margin-bottom: 0.75rem;
  }

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

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

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

  .claim-line__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;
  }

  .claim-line__input {
    display: block;
    width: 100%;
    border-radius: var(--radius-md);
    border-color: var(--color-gray-300);
    box-shadow: var(--shadow-xs);

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

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

  .claim-line__pointers-list {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.25rem;
  }

  .claim-line__pointer {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-600);
  }

  .claim-line__pointer-check {
    border-radius: var(--radius-sm);
    border-color: var(--color-gray-300);
    color: var(--color-indigo-600);

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

  .claim-line__pointers-empty {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-gray-400);
    margin-top: 0.25rem;
  }

  .claim-line__remove-wrap {
    margin-top: 0.75rem;
    text-align: right;
  }

  .claim-line__remove {
    font-size: var(--text-sm);
    line-height: var(--text-sm--line-height);
    color: var(--color-red-600);
    font-weight: var(--font-weight-medium);

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