/* ========================================
   Wallet — billetera, depósitos, tarjetas
   v5 visual language. Mobile-first.
   ======================================== */

.wallet-page,
.topup-page,
.add-card-page,
.deposit-status {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 var(--content-pad) 2rem;
}

/* The legacy .back-link and per-page .head + .head .title rules
   lived here. Replaced by the shared ribbon (which renders the
   crumb back-link) and the .wallet-page-head primitive in
   components/_primitives.css — see Phase 5 of the boletería
   redesign. */

/* ---------- Hero balance card ---------- */
.wallet-hero {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  background: linear-gradient(135deg, var(--bg-2) 0%, rgba(78, 199, 122, 0.06) 100%);
  border: 1px solid var(--accent);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  margin-bottom: 1.5rem;
  position: relative;
  overflow: hidden;
}

@media (min-width: 720px) {
  .wallet-hero { grid-template-columns: 1.3fr 1fr; gap: 2rem; padding: 1.75rem; }
}

.wallet-hero > .balance > .amount {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  margin-top: 0.5rem;
}

.wallet-hero > .balance > .amount > .scoreboard {
  font-size: 4rem;
  color: var(--accent);
  letter-spacing: -0.02em;
  line-height: 1;
}

@media (min-width: 720px) {
  .wallet-hero > .balance > .amount > .scoreboard { font-size: 4.5rem; }
}

.wallet-hero > .balance > .amount > .unit {
  font-size: 0.875rem;
  color: var(--fg-2);
}

.wallet-hero > .balance > .equiv {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.25rem;
  font-size: 11px;
  color: var(--fg-3);
}

.wallet-hero > .balance > .actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.625rem;
  margin-top: 1.5rem;
}

.wallet-hero .btn.-disabled,
.wallet-hero .btn[disabled] {
  opacity: 0.45;
  cursor: not-allowed;
}

.wallet-hero > .stats {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  justify-content: center;
}

.wallet-hero > .stats > .col {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}

@media (min-width: 720px) {
  .wallet-hero > .stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.875rem;
  }
  .wallet-hero > .stats > .col {
    display: block;
  }
  .wallet-hero > .stats > .footnote { grid-column: 1 / -1; }
}

.wallet-hero > .stats > .col > .scoreboard { font-size: 1.75rem; }

.wallet-hero > .stats > .footnote {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding-top: 0.875rem;
  border-top: 1px solid var(--line);
  color: var(--fg-3);
}

/* ---------- Movements ---------- */
.movements > .head {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.movement-list {
  list-style: none;
  margin: 0; padding: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--card);
  overflow: hidden;
}

.movement-list > .row {
  display: grid;
  grid-template-columns: 24px 1fr auto;
  gap: 0.875rem;
  align-items: center;
  padding: 0.875rem 1rem;
  border-bottom: 1px solid var(--line);
}

.movement-list > .row:last-child { border-bottom: none; }

.movement-list > .row > .icon {
  width: 24px; height: 24px; border-radius: 5px;
  display: flex; align-items: center; justify-content: center;
}
.movement-list > .row > .icon.-in  { background: var(--accent-dim); color: var(--accent); }
.movement-list > .row > .icon.-out { background: rgba(232, 93, 93, 0.12); color: var(--roja); }

.movement-list > .row > .meta > .label { font-size: 13px; font-weight: 500; }
.movement-list > .row > .meta > .micro { margin-top: 2px; }

.movement-list > .row > .scoreboard { font-size: 1.125rem; }

/* ---------- Empty state · arco vacío ---------- */
.movements-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.75rem;
  padding: 2.5rem 1.25rem 2.25rem;
  border: 1px dashed var(--line-strong);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(ellipse at 50% 0%, rgba(78, 199, 122, 0.06), transparent 60%),
    var(--card);
}

.empty-goal {
  color: var(--accent, #4ec77a);
  opacity: 0.85;
  margin-bottom: 0.25rem;
  filter: drop-shadow(0 4px 14px rgba(78, 199, 122, 0.18));
}

.movements-empty__title {
  font-family: var(--font-scoreboard);
  font-size: 1.625rem;
  letter-spacing: 0.04em;
  color: var(--fg);
  margin: 0;
  font-weight: 400;
}

.movements-empty__lead {
  font-size: 0.875rem;
  color: var(--fg-2);
  margin: 0 0 0.375rem;
  max-width: 380px;
  line-height: 1.5;
}

.btn.-block { width: 100%; justify-content: center; }

/* ---------- Top-up page ---------- */
.topup-form > .grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 960px) {
  .topup-form > .grid { grid-template-columns: 1.2fr 1fr; gap: 2rem; }
}

.amount-card {
  padding: 1.5rem;
}

.amount-card > .amount-row {
  display: flex; align-items: baseline; gap: 0.5rem;
}
.amount-card > .amount-row > .scoreboard {
  font-size: 4rem; color: var(--fg); letter-spacing: -0.02em; line-height: 1;
}
.amount-card > .amount-row > .mono {
  font-size: 1.125rem; color: var(--fg-3);
}
.amount-card > .equiv {
  display: flex; flex-wrap: wrap; align-items: center; gap: 0.5rem;
  margin-top: 0.875rem; padding-top: 0.875rem;
  border-top: 1px solid var(--line);
}
.amount-card > .equiv > .scoreboard { font-size: 1.375rem; }

.presets-tag { margin: 1.125rem 0 0.5rem; }

.presets {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.5rem;
  margin-bottom: 1rem;
}
.presets > .preset {
  padding: 0.75rem 0.375rem;
  text-align: center;
  border: 1px solid var(--line);
  background: var(--card);
  border-radius: var(--radius-lg);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
  align-items: center;
  color: var(--fg);
}
.presets > .preset > .scoreboard { font-size: 1.25rem; }
.presets > .preset.-active {
  border-color: var(--accent);
  background: var(--accent-dim);
  color: var(--accent);
}

/* Summary card on the right */
.summary {
  position: sticky; top: 1rem;
}
.summary-card {
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.summary-card > .row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 0.5rem 0;
}
.summary-card > .row.-dashed {
  border-bottom: 1px dashed var(--line);
}
.summary-card > .row.-bold {
  font-weight: 600;
  border-bottom: 1px solid var(--line);
  padding: 0.875rem 0;
}
.summary-card > .row.-credit {
  font-weight: 600;
  padding: 0.875rem 0 0.5rem;
}
.summary-card > .resulting {
  background: var(--bg-2);
  border-radius: var(--radius);
  padding: 0.75rem 0.875rem;
  margin: 0.25rem 0 1rem;
}
.summary-card > .resulting > .scoreboard { font-size: 1.625rem; }

/* ---------- Add card page ---------- */
.add-card-form > .grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
@media (min-width: 960px) {
  .add-card-form > .grid { grid-template-columns: 1fr 380px; gap: 2rem; }
}

.add-card-form > .grid > .left > .field { margin-top: 0.875rem; }
.add-card-form > .grid > .left > .field-row {
  display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 0.75rem;
  margin-top: 0.875rem;
}

.add-card-form .primary-toggle {
  display: flex; align-items: center; gap: 0.625rem;
  margin-top: 1rem;
  padding: 0.625rem 0.875rem;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--bg-2);
}
.add-card-form .primary-toggle input { accent-color: var(--accent); }

.add-card-form .actions {
  display: flex; gap: 0.625rem; margin-top: 1.25rem;
}
.add-card-form .actions > .btn-primary { flex: 1; justify-content: center; padding: 0.75rem; }

.add-card-form .processed-by {
  display: flex; align-items: center; gap: 0.625rem;
  margin-top: 1rem; color: var(--fg-3);
}

.add-card-form .errors {
  background: rgba(230, 57, 70, 0.1);
  border: 1px solid rgba(230, 57, 70, 0.3);
  color: var(--roja);
  padding: 0.75rem 0.875rem;
  border-radius: var(--radius);
  margin-bottom: 0.75rem;
  font-size: 12px;
}

.card-preview {
  aspect-ratio: 1.6 / 1;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, #1a1f3a 0%, #2c1a4a 100%);
  padding: 1.25rem;
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line-strong);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.4);
  color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.card-preview > .brand-mark {
  font-family: var(--mono);
  font-size: 0.625rem;
  opacity: 0.6;
  letter-spacing: 0.14em;
}
.card-preview > .chip-mark {
  width: 40px; height: 28px;
  margin-top: 0.625rem;
  border-radius: 4px;
  background: linear-gradient(135deg, #d4af37, #f4e58c);
  position: relative;
}
.card-preview > .chip-mark::after {
  content: ""; position: absolute; inset: 4px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 2px;
}
.card-preview > .number { font-size: 1.375rem; letter-spacing: 0.18em; }
.card-preview > .meta {
  display: flex; justify-content: space-between;
  margin-top: 0.75rem; font-size: 0.625rem;
}
.card-preview > .meta .mono { font-size: 0.75rem; margin-top: 3px; }

/* ---------- Deposit status page ---------- */
.deposit-status {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding-top: 4rem;
}
.deposit-status > .state { max-width: 480px; }
.deposit-status > .actions {
  display: flex; gap: 0.625rem; margin-top: 1.5rem;
}
