/* /wallet · v1.1.4.016 compact redesign
 * "Наш стиль" matching /vip, /lucky-day.
 */

.kp-wallet-page {
  max-width: 760px;
  margin: 0 auto;
  padding: 8px 12px 60px;
}

.kp-wallet-page .kp-alert {
  border-radius: 10px;
  margin-bottom: 12px;
  text-align: center;
}

/* ──────────────────────────────────────────────────────────────────
 * HERO — title + 4 balance cards
 * ────────────────────────────────────────────────────────────────── */
.kp-wlt-hero {
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--n-gold, #c9881e) 12%, var(--panel)),
    var(--panel));
  border: 1px solid color-mix(in srgb, var(--n-gold, #c9881e) 30%, var(--border));
  border-radius: 14px;
  padding: 14px 16px;
  margin-bottom: 12px;
  box-shadow: 0 4px 18px color-mix(in srgb, var(--n-gold, #c9881e) 16%, transparent);
}
.kp-wlt-hero__head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.kp-wlt-hero__icon {
  font-size: 1.9rem;
  filter: drop-shadow(0 3px 10px color-mix(in srgb, var(--n-gold, #c9881e) 60%, transparent));
  flex-shrink: 0;
}
.kp-wlt-hero__title-block { flex: 1; min-width: 0; }
.kp-wlt-hero__title {
  margin: 0;
  font-size: 1.25rem;
  font-weight: 900;
  color: var(--n-gold, #c9881e);
  font-family: var(--n-font-mono, monospace);
  letter-spacing: 0.02em;
}
.kp-wlt-hero__sub {
  font-size: 0.74rem;
  color: var(--n-text-mute, #888);
  margin-top: 2px;
  line-height: 1.3;
}

/* Balance cards grid */
.kp-wlt-balances {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
@media (min-width: 540px) {
  .kp-wlt-balances { grid-template-columns: 1fr 1fr 1fr 1fr; }
}
.kp-wlt-bal {
  padding: 10px 12px;
  background: var(--n-bg-soft);
  border: 1px solid var(--n-line);
  border-radius: 10px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.kp-wlt-bal__icon { font-size: 1.4rem; line-height: 1; margin-bottom: 2px; }
.kp-wlt-bal__name {
  font-size: 0.66rem;
  color: var(--n-text-mute);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 700;
}
.kp-wlt-bal__amount {
  font-family: var(--n-font-mono, monospace);
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--n-text);
  margin-top: 2px;
  letter-spacing: 0.01em;
}
.kp-wlt-bal__reserved {
  font-size: 0.62rem;
  color: var(--n-text-mute);
  margin-top: 2px;
  font-family: var(--n-font-mono, monospace);
}
.kp-wlt-bal--gold .kp-wlt-bal__amount { color: #fbbf24; }
.kp-wlt-bal--crystal .kp-wlt-bal__amount { color: #22d3ee; }
.kp-wlt-bal--ducat .kp-wlt-bal__amount { color: #a855f7; }
.kp-wlt-bal--feather .kp-wlt-bal__amount { color: #14b8a6; }

/* ──────────────────────────────────────────────────────────────────
 * BLOCK — generic section
 * ────────────────────────────────────────────────────────────────── */
.kp-wlt-block {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 14px;
  margin-bottom: 12px;
}
.kp-wlt-block__title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--n-text);
  margin: 0 0 10px;
  letter-spacing: 0.01em;
}
.kp-wlt-block__title [aria-hidden="true"] { font-size: 1rem; }

.kp-wlt-empty {
  padding: 14px;
  text-align: center;
  color: var(--n-text-mute);
  font-size: 0.78rem;
}

/* ──────────────────────────────────────────────────────────────────
 * STATS — Earned / Spent / Net cards
 * ────────────────────────────────────────────────────────────────── */
.kp-wlt-stats-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
@media (min-width: 540px) {
  .kp-wlt-stats-grid { grid-template-columns: 1fr 1fr; }
}
.kp-wlt-stat-card {
  padding: 10px 12px;
  background: var(--n-bg-soft);
  border: 1px solid var(--n-line);
  border-radius: 9px;
}
.kp-wlt-stat-card__period {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--n-text-mute);
  margin-bottom: 8px;
  font-family: var(--n-font-mono, monospace);
}
.kp-wlt-stat-card__row {
  display: grid;
  grid-template-columns: auto 1fr 1fr 1fr;
  gap: 6px;
  align-items: center;
}
.kp-wlt-stat-card__row + .kp-wlt-stat-card__row { margin-top: 6px; }
.kp-wlt-stat-card__col--cur {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 2px;
}
.kp-wlt-stat-card__col {
  text-align: center;
  padding: 6px 4px;
  border-radius: 6px;
}
.kp-wlt-stat-card__col-lbl {
  font-size: 0.62rem;
  color: var(--n-text-mute);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 600;
  margin-bottom: 3px;
}
.kp-wlt-stat-card__col-val {
  font-family: var(--n-font-mono, monospace);
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: 0.01em;
}
.kp-wlt-stat-card__col--in {
  background: color-mix(in srgb, var(--n-ok, #22c55e) 8%, transparent);
}
.kp-wlt-stat-card__col--in .kp-wlt-stat-card__col-val {
  color: var(--n-ok, #22c55e);
}
.kp-wlt-stat-card__col--out {
  background: color-mix(in srgb, var(--n-danger, #ef4444) 8%, transparent);
}
.kp-wlt-stat-card__col--out .kp-wlt-stat-card__col-val {
  color: var(--n-danger, #ef4444);
}
.kp-wlt-stat-card__col--net.kp-wlt-stat-card__col--pos { background: color-mix(in srgb, var(--n-ok, #22c55e) 14%, transparent); }
.kp-wlt-stat-card__col--net.kp-wlt-stat-card__col--pos .kp-wlt-stat-card__col-val { color: var(--n-ok, #22c55e); }
.kp-wlt-stat-card__col--net.kp-wlt-stat-card__col--neg { background: color-mix(in srgb, var(--n-danger, #ef4444) 14%, transparent); }
.kp-wlt-stat-card__col--net.kp-wlt-stat-card__col--neg .kp-wlt-stat-card__col-val { color: var(--n-danger, #ef4444); }
.kp-wlt-stat-card__col--net.kp-wlt-stat-card__col--zero { background: var(--n-bg-2); }
.kp-wlt-stat-card__col--net.kp-wlt-stat-card__col--zero .kp-wlt-stat-card__col-val { color: var(--n-text-mute); }

/* ──────────────────────────────────────────────────────────────────
 * SOURCE BREAKDOWN — top 5 in/out
 * ────────────────────────────────────────────────────────────────── */
.kp-wlt-sources {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.kp-wlt-source {
  padding: 7px 10px;
  background: var(--n-bg-soft);
  border-radius: 7px;
  border-left: 3px solid transparent;
}
.kp-wlt-source--in { border-left-color: var(--n-ok, #22c55e); }
.kp-wlt-source--out { border-left-color: var(--n-danger, #ef4444); }
.kp-wlt-source__head {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 4px;
  font-size: 0.78rem;
}
.kp-wlt-source__icon { font-size: 0.95rem; flex-shrink: 0; }
.kp-wlt-source__label { flex: 1; color: var(--n-text); font-weight: 600; }
.kp-wlt-source__amount {
  font-family: var(--n-font-mono, monospace);
  font-weight: 800;
  font-size: 0.78rem;
  white-space: nowrap;
}
.kp-wlt-source--in .kp-wlt-source__amount { color: var(--n-ok, #22c55e); }
.kp-wlt-source--out .kp-wlt-source__amount { color: var(--n-danger, #ef4444); }
.kp-wlt-source__bar {
  height: 4px;
  background: var(--n-bg-2);
  border-radius: 999px;
  overflow: hidden;
}
.kp-wlt-source__bar-fill {
  height: 100%;
  border-radius: inherit;
  transition: width .3s;
}
.kp-wlt-source--in .kp-wlt-source__bar-fill {
  background: linear-gradient(90deg, var(--n-ok, #22c55e), color-mix(in srgb, var(--n-ok, #22c55e) 60%, transparent));
}
.kp-wlt-source--out .kp-wlt-source__bar-fill {
  background: linear-gradient(90deg, var(--n-danger, #ef4444), color-mix(in srgb, var(--n-danger, #ef4444) 60%, transparent));
}

/* ──────────────────────────────────────────────────────────────────
 * FILTERS bar
 * ────────────────────────────────────────────────────────────────── */
.kp-wlt-filters {
  display: flex;
  gap: 6px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.kp-wlt-filters select {
  flex: 1;
  min-width: 100px;
  padding: 6px 8px;
  background: var(--n-bg-soft);
  border: 1px solid var(--n-line);
  border-radius: 6px;
  color: var(--n-text);
  font-family: var(--n-font, sans-serif);
  font-size: 0.78rem;
}
.kp-wlt-filters select:focus {
  outline: none;
  border-color: var(--n-accent, #ef6443);
}

/* ──────────────────────────────────────────────────────────────────
 * TRANSACTIONS list
 * ────────────────────────────────────────────────────────────────── */
.kp-wlt-tx-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.kp-wlt-tx {
  display: grid;
  grid-template-columns: 32px 1fr auto;
  gap: 8px;
  align-items: center;
  padding: 7px 10px;
  border-radius: 8px;
  border-left: 3px solid transparent;
  background: var(--n-bg-soft);
  transition: background .15s;
}
.kp-wlt-tx:hover {
  background: color-mix(in srgb, var(--n-text) 4%, var(--n-bg-soft));
}
.kp-wlt-tx__icon {
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  background: var(--n-bg-2);
  border-radius: 7px;
  font-size: 1rem;
  flex-shrink: 0;
}
.kp-wlt-tx__body {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.kp-wlt-tx__main {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--n-text);
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.kp-wlt-tx__meta {
  font-size: 0.66rem;
  color: var(--n-text-mute);
  font-family: var(--n-font-mono, monospace);
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.kp-wlt-tx__sep { opacity: 0.5; }
.kp-wlt-tx__amount {
  font-family: var(--n-font-mono, monospace);
  font-weight: 800;
  font-size: 0.92rem;
  letter-spacing: 0.01em;
  white-space: nowrap;
  text-align: right;
  display: flex;
  align-items: center;
  gap: 4px;
}
.kp-wlt-tx__cur { font-size: 0.85rem; }

/* Load more */
.kp-wlt-load-more {
  text-align: center;
  margin-top: 10px;
}
.kp-wlt-load-more__btn {
  display: inline-block;
  padding: 8px 18px;
  background: var(--n-accent, #ef6443);
  color: #fff;
  text-decoration: none;
  border-radius: 8px;
  font-family: var(--n-font-mono, monospace);
  font-weight: 700;
  font-size: 0.8rem;
  transition: filter .15s;
}
.kp-wlt-load-more__btn:hover { filter: brightness(1.1); }

/* Mobile tweaks */
@media (max-width: 480px) {
  .kp-wallet-page { padding: 6px 10px 60px; }
  .kp-wlt-hero { padding: 12px; }
  .kp-wlt-hero__title { font-size: 1.1rem; }
  .kp-wlt-block { padding: 10px 12px; }
  .kp-wlt-bal { padding: 8px 6px; }
  .kp-wlt-bal__icon { font-size: 1.2rem; }
  .kp-wlt-bal__amount { font-size: 0.92rem; }
  .kp-wlt-stat-card__col-val { font-size: 0.82rem; }
}
