.page-salary {
  background: linear-gradient(180deg, #eef5ff 0%, var(--app-bg) 36%);
}

.subpage-topbar--blue {
  background: linear-gradient(165deg, #0c4db8 0%, #0052d9 100%);
  color: #fff;
  border-bottom: 0;
}

.subpage-topbar--blue .back-button {
  color: #fff;
}

.subpage-topbar--blue h1 {
  color: #fff;
}

.salary-main {
  padding: 14px 16px calc(28px + env(safe-area-inset-bottom, 0px));
}

.salary-hero {
  padding: 22px 18px 18px;
  border-radius: 14px;
  background: linear-gradient(135deg, #0c4db8 0%, #0052d9 55%, #004098 100%);
  color: #fff;
  box-shadow: 0 10px 24px rgba(0, 82, 217, 0.28);
  margin-bottom: 12px;
}

.salary-hero__label {
  margin: 0;
  font-size: 13px;
  opacity: 0.92;
}

.salary-hero__amt {
  display: block;
  margin: 10px 0 8px;
  font-size: 36px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.1;
}

.salary-hero__hint {
  margin: 0 0 14px;
  font-size: 12px;
  opacity: 0.88;
  line-height: 1.45;
}

.salary-hero__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.18);
}

.salary-hero__promo {
  font-size: 13px;
  opacity: 0.92;
}

.salary-hero__promo b {
  font-weight: 700;
}

.salary-hero .promo-level-badge {
  font-size: 11px;
  padding: 3px 8px;
}

.salary-monthly {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--card-shadow);
  padding: 14px 14px 12px;
  margin-bottom: 12px;
}

.salary-monthly__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.salary-monthly__head h2 {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
}

.salary-monthly__head a {
  font-size: 12px;
  color: var(--gov-blue);
  text-decoration: none;
}

.salary-monthly__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 10px;
}

.salary-monthly__item {
  padding: 12px;
  border-radius: 10px;
  background: #f6f8fc;
}

.salary-monthly__headrow {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

.salary-monthly__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}

.salary-monthly__icon--blue {
  background: var(--gov-blue);
}

.salary-monthly__icon--orange {
  background: var(--gov-orange);
}

.salary-monthly__label {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.3;
}

.salary-monthly__value {
  display: block;
  font-size: 20px;
  font-weight: 700;
  color: var(--gov-blue);
  line-height: 1.2;
}

.salary-monthly__value--orange {
  color: var(--gov-orange);
}

.salary-monthly__total {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 12px;
  border-radius: 10px;
  background: linear-gradient(90deg, #eef5ff, #f8fbff);
  font-size: 13px;
  color: var(--muted);
}

.salary-monthly__total strong {
  font-size: 18px;
  color: var(--gov-blue);
}

.salary-recent {
  margin-bottom: 12px;
  padding: 14px 0 4px;
}

.salary-recent__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 14px 10px;
}

.salary-recent__head h2 {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
}

.salary-recent__head a {
  font-size: 12px;
  color: var(--gov-blue);
  text-decoration: none;
}

.salary-recent__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.salary-recent__list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  border-top: 1px solid #f0f2f5;
}

.salary-recent__list li:first-child {
  border-top: 0;
}

.salary-recent__info strong {
  display: block;
  font-size: 14px;
  margin-bottom: 2px;
}

.salary-recent__info small {
  font-size: 12px;
  color: var(--muted);
}

.salary-recent__amt {
  font-size: 15px;
  font-weight: 700;
  color: var(--gov-green);
  white-space: nowrap;
}

.salary-recent__empty,
.ledger-row--empty {
  justify-content: center !important;
  color: var(--muted);
  font-size: 13px;
}

.salary-recent__list .ledger-row--salary {
  display: block;
  padding: 0;
  border-top: 1px solid #f0f2f5;
}

.salary-recent__list .ledger-row--salary:first-child {
  border-top: 0;
}

.salary-recent__list .ledger-row--salary > a,
.salary-recent__list .ledger-row--salary:not(.ledger-row--link) {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  color: inherit;
  text-decoration: none;
}

.salary-recent__list .ledger-row--link > a {
  position: relative;
  padding-right: 26px;
}

.salary-recent__list .ledger-row--link > a:active {
  background: #f8f9fc;
}

.salary-recent__list .ledger-row__chev {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: #c0c4cc;
  font-size: 16px;
}

.salary-recent__list .ledger-row__amt.in {
  color: var(--gov-green);
}

.salary-recent__list .ledger-row__amt.out {
  color: var(--gov-red);
}

.salary-links {
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--card-shadow);
  overflow: hidden;
  margin-bottom: 12px;
}

.salary-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  text-decoration: none;
  color: inherit;
  border-bottom: 1px solid #f0f2f5;
}

.salary-link:last-child {
  border-bottom: 0;
}

.salary-link:active {
  background: #f8f9fc;
}

.salary-link__icon {
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}

.salary-link__icon.mi--purple {
  background: linear-gradient(145deg, #8b7ce8, var(--gov-purple));
}

.salary-link__icon.mi--red {
  background: linear-gradient(145deg, #e84a4e, var(--gov-red));
}

.salary-link__icon.mi--green {
  background: linear-gradient(145deg, #4cb88a, var(--gov-green));
}

.salary-link__text {
  flex: 1;
  min-width: 0;
}

.salary-link__text strong {
  display: block;
  font-size: 14px;
  margin-bottom: 2px;
}

.salary-link__text small {
  font-size: 12px;
  color: var(--muted);
}

.salary-link__arrow {
  color: var(--muted);
  font-size: 20px;
}

.salary-tip {
  margin: 0;
  padding: 0 4px;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.55;
}

/* 复用宣传页等级徽章 */
.promo-level-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  line-height: 1.4;
}

.promo-level-badge--blue {
  background: rgba(0, 82, 217, 0.15);
  color: #0052d9;
}

.promo-level-badge--purple {
  background: rgba(91, 79, 199, 0.15);
  color: #5b4fc7;
}

.promo-level-badge--gold {
  background: rgba(198, 145, 0, 0.18);
  color: #9a6b00;
}

.salary-hero .promo-level-badge--blue {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

.salary-hero .promo-level-badge--purple {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

.salary-hero .promo-level-badge--gold {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

.salary-payout-status {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px;
  margin-bottom: 12px;
  background: #fff;
  border-radius: var(--radius-lg);
  box-shadow: var(--card-shadow);
  border-left: 4px solid var(--gov-blue);
}

.salary-payout-status.is-paid {
  border-left-color: var(--gov-green);
}

.salary-payout-status.is-today {
  border-left-color: var(--gov-orange);
  background: linear-gradient(90deg, #fffaf5, #fff);
}

.salary-payout-status__icon {
  font-size: 18px;
  line-height: 1.2;
  flex-shrink: 0;
}

.salary-payout-status.is-paid .salary-payout-status__icon {
  color: var(--gov-green);
}

.salary-payout-status__body {
  flex: 1;
  min-width: 0;
}

.salary-payout-status__main {
  margin: 0;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.55;
  color: var(--text, #1a1a1a);
}

.salary-payout-status.is-paid .salary-payout-status__main {
  color: var(--gov-green);
}

.salary-payout-status__sub {
  margin: 4px 0 0;
  font-size: 12px;
  color: var(--muted);
  line-height: 1.55;
}

.salary-payout-status.is-today .salary-payout-status__main {
  color: var(--gov-orange);
}
