/*
 * Payroll
 *
 * Employee-facing payroll period index and detail views.
 */

.payroll-page__header {
  padding: 1rem 1.5rem;
  border-block-end: 1px solid var(--color-border);
}

.payroll-page__title {
  color: var(--color-ink);
  font-size: 1.5rem;
  line-height: 2rem;
  font-weight: 600;
}


.payroll-page__section {
  padding: 1.5rem;
}

.payroll-page__section--divided {
  border-block-end: 1px solid var(--color-border);
}

.payroll-summary-card {
  padding: 1.25rem;
}

.payroll-summary-card--total {
  border: 2px solid rgb(var(--palette-indigo-200));
}

.payroll-summary-card__content {
  display: flex;
  align-items: center;
}

.payroll-summary-card__icon {
  flex-shrink: 0;
  inline-size: 1.5rem;
  block-size: 1.5rem;
  color: var(--color-ink-medium);
}

.payroll-summary-card__icon--accent {
  color: rgb(var(--palette-indigo-400));
}

.payroll-summary-card__body {
  min-inline-size: 0;
  flex: 1 1 0%;
  margin-inline-start: 1.25rem;
}

.payroll-summary-card__label {
  overflow: hidden;
  color: var(--color-ink-lighter);
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 500;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.payroll-summary-card__value {
  color: var(--color-ink);
  font-size: 1.125rem;
  line-height: 1.75rem;
  font-weight: 600;
}

.payroll-summary-card__value--accent {
  color: var(--color-brand-strong);
}

.payroll-table-card {
  overflow-x: auto;
  overflow-y: hidden;
  border-radius: var(--radius-lg);
  box-shadow:
    var(--shadow-panel),
    var(--shadow-ring-subtle);
}

.payroll-table {
  min-width: 100%;
  border-collapse: collapse;
}

.payroll-table__head {
  background-color: var(--color-surface-muted);
}

.payroll-table__body,
.payroll-table__footer {
  background-color: var(--color-surface);
}

.payroll-table__body tr + tr {
  border-block-start: 1px solid var(--color-border);
}

.payroll-table__row:hover {
  background-color: var(--color-surface-muted);
}

.payroll-table__footer {
  border-block-start: 1px solid var(--color-border-medium);
}

.payroll-table__header,
.payroll-table__cell {
  white-space: nowrap;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.payroll-table__header {
  padding-block: 0.875rem;
  padding-inline: 0.75rem;
  color: var(--color-ink);
  font-weight: 600;
  text-align: start;
}

.payroll-table__header:first-child,
.payroll-table__cell:first-child,
.payroll-table__footer-cell:first-child {
  padding-inline-start: 1rem;
}

.payroll-table__cell {
  padding-block: 1rem;
  padding-inline: 0.75rem;
  color: var(--color-ink-lighter);
}

.payroll-table__cell--primary {
  color: var(--color-ink);
  font-weight: 500;
}

.payroll-table__cell--right,
.payroll-table__header--right,
.payroll-table__footer-cell--right {
  text-align: end;
}

.payroll-table__footer-cell {
  padding-block: 0.875rem;
  padding-inline: 0.75rem;
  color: var(--color-ink);
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 600;
  white-space: nowrap;
}

.payroll-table__footer-cell--accent {
  color: var(--color-brand-strong);
}

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

.payroll-empty__icon {
  inline-size: 3rem;
  block-size: 3rem;
  margin-inline: auto;
  color: var(--color-ink-medium);
}

.payroll-empty__title {
  margin-block-start: 0.5rem;
  color: var(--color-ink);
  font-size: 0.875rem;
  line-height: 1.25rem;
  font-weight: 500;
}

.payroll-link {
  color: var(--color-brand-strong);
  font-weight: 500;
}

.payroll-link:hover {
  color: rgb(var(--palette-indigo-700));
}

@media (min-width: 640px) {
  .payroll-summary-layout {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* Admin payroll period settings */

.payroll-period-filter {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.75rem;
  margin-block-end: 1rem;
}

.payroll-period-filter__field {
  min-inline-size: 12rem;
}

.payroll-period-filter__field .input {
  margin-block-start: 0.25rem;
}

.payroll-period-filter__submit {
  align-self: flex-end;
}

.payroll-period-detail__header,
.payroll-period-detail__body {
  padding-block: 1.25rem;
  padding-inline: 1rem;
}

.payroll-period-detail__header-row {
  justify-content: space-between;
}

.payroll-period-detail__actions {
  flex-wrap: wrap;
  justify-content: flex-end;
}

.payroll-status-badge {
  padding-inline: 0.75rem;
}

.payroll-period-action {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  border: 0;
  border-radius: var(--radius-md);
  padding-block: 0.375rem;
  padding-inline: 0.75rem;
  color: var(--color-ink-inverted);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.25rem;
}

.payroll-period-action--submit {
  background-color: var(--color-warning);
}

.payroll-period-action--submit:hover {
  background-color: rgb(var(--palette-yellow-600));
}

.payroll-period-action--approve {
  background-color: var(--color-success);
}

.payroll-period-action--approve:hover {
  background-color: var(--color-success-strong);
}

.payroll-period-action--export {
  background-color: var(--color-info);
}

.payroll-period-action--export:hover {
  background-color: var(--color-info-strong);
}

.payroll-period-action__icon {
  inline-size: 1rem;
  block-size: 1rem;
}

.payroll-period-detail__meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1rem;
  margin-block-start: 1rem;
}



.payroll-period-detail__tabs,
.payroll-period-detail__body {
  border-block-start: 1px solid var(--color-border);
}

.payroll-period-detail__tabs {
  padding-block: 1rem;
  padding-inline: 1rem;
}

.payroll-period-tabs {
  display: flex;
  gap: 0.25rem;
}

.payroll-period-tabs__link {
  border-radius: var(--radius-md);
  padding-block: 0.5rem;
  padding-inline: 1rem;
  color: var(--color-ink-light);
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1.25rem;
}

.payroll-period-tabs__link:hover {
  background-color: var(--color-surface-subtle);
}

.payroll-period-tabs__link--active,
.payroll-period-tabs__link--active:hover {
  background-color: var(--color-brand-strong);
  color: var(--color-ink-inverted);
}

.payroll-report-table-wrap {
  overflow-x: auto;
}

.payroll-report-table {
  min-inline-size: 100%;
  border-collapse: collapse;
}

.payroll-report-table__head {
  background-color: var(--color-surface-muted);
}

.payroll-report-table__body {
  background-color: var(--color-surface);
}

.payroll-report-table__cell--sticky {
  background-color: var(--color-surface);
}

.payroll-report-table__body tr + tr {
  border-block-start: 1px solid var(--color-border);
}

.payroll-report-table__row--alternate,
.payroll-report-table__row--alternate .payroll-report-table__cell--sticky {
  background-color: var(--color-surface-muted);
}

.payroll-report-table__header,
.payroll-report-table__cell,
.payroll-report-table__footer-cell {
  padding-block: 0.75rem;
  padding-inline: 1rem;
  white-space: nowrap;
}

.payroll-report-table__header {
  color: var(--color-ink-lighter);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1rem;
  text-align: left;
  text-transform: uppercase;
}

.payroll-report-table__cell--primary,
.payroll-report-table__cell--strong,
.payroll-report-table__footer-cell--strong {
  color: var(--color-ink);
  font-weight: 600;
}

.payroll-report-table__header--right,
.payroll-report-table__cell--right,
.payroll-report-table__footer-cell--right {
  text-align: right;
}

.payroll-report-table__header--sticky,
.payroll-report-table__cell--sticky,
.payroll-report-table__footer-cell--sticky {
  position: sticky;
  inset-inline-start: 0;
  z-index: 1;
}

.payroll-report-table__footer-cell--sticky {
  background-color: var(--color-surface-subtle);
}

.payroll-report-table__foot {
  background-color: var(--color-surface-subtle);
}

.payroll-report-table__empty-value {
  color: var(--color-ink-medium);
}

.payroll-line-item-card {
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background-color: var(--color-surface);
}

.payroll-line-item-card__body {
  padding: 1rem;
}

.payroll-line-item-card__title {
  color: var(--color-ink);
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.25rem;
}

.payroll-line-item-card__total {
  margin-block-start: 0.125rem;
  color: var(--color-ink-lighter);
  font-size: 0.75rem;
  line-height: 1rem;
}

.payroll-line-item-card__total-value {
  color: var(--color-ink-light);
  font-weight: 500;
}

.payroll-line-item-card__toggle {
  border: 0;
  background: transparent;
  color: var(--color-brand-strong);
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1rem;
}

.payroll-line-item-card__toggle:hover {
  color: rgb(var(--palette-indigo-800));
}

.payroll-line-item-card__section {
  margin-block-start: 0.75rem;
}

.payroll-line-item-card__section-title {
  margin-block-end: 0.25rem;
  color: var(--color-ink-lighter);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1rem;
  text-transform: uppercase;
}

.payroll-line-item-card__empty {
  margin-block-start: 0.5rem;
  color: var(--color-ink-medium);
  font-size: 0.75rem;
  font-style: italic;
  line-height: 1rem;
}

.payroll-line-item-card__drawer {
  border-block-start: 1px solid var(--color-border-muted);
  background-color: var(--color-surface-muted);
  padding-block: 0.75rem;
  padding-inline: 1rem;
}

.payroll-line-item-table {
  min-inline-size: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.payroll-line-item-table__row {
  border-block-start: 1px solid var(--color-border-muted);
}

.payroll-line-item-table__cell {
  padding-block: 0.375rem;
  color: var(--color-ink-lighter);
}

.payroll-line-item-table__cell--right {
  color: var(--color-ink-light);
  font-weight: 500;
  text-align: right;
}

.payroll-line-item-table__cell--strong {
  color: var(--color-ink-light);
}

.payroll-line-item-table__cell--emphasis {
  color: var(--color-ink);
}

.payroll-line-item-form {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 0.75rem;
}

.payroll-line-item-form__concept {
  flex: 1 1 11.25rem;
}

.payroll-line-item-form__amount {
  inline-size: 8rem;
}

.payroll-line-item-form__label {
  display: block;
  margin-block-end: 0.25rem;
  color: var(--color-ink-light);
  font-size: 0.75rem;
  font-weight: 500;
  line-height: 1rem;
}

.payroll-flash {
  padding-block: 0.25rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
}

.payroll-flash--error {
  color: var(--color-danger-strong);
}

.payroll-flash--success {
  color: var(--color-success-strong);
}

@media (min-width: 640px) {
  .payroll-period-detail__header,
  .payroll-period-detail__tabs,
  .payroll-period-detail__body {
    padding-inline: 1.5rem;
  }

  .payroll-period-detail__meta {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
