/* Pakstoor :: wallet.css :: v1.0-000004 :: 2026-05-13 */

/* ============================================================
   /wallet — page-specific styles. Reuses .acct shell from
   account.css for the page frame + crumbs + header.
   ============================================================ */

.wallet-state {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-5) var(--s-4);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  background: var(--bg-2);
  color: var(--ink-muted);
  font-size: var(--fs-13);
}
.wallet-state-error {
  align-items: flex-start;
  border-color: rgba(216, 81, 69, 0.4);
  background: linear-gradient(rgba(216, 81, 69, 0.08), rgba(216, 81, 69, 0.08)), var(--bg-2);
  color: var(--ink);
}
.wallet-state-error svg { color: var(--danger); flex-shrink: 0; margin-top: 2px; }
.wallet-state-error strong { display: block; color: var(--ink); margin-bottom: 4px; }
.wallet-state-error p { margin: 0; color: var(--ink-muted); font-size: var(--fs-12); line-height: 1.5; }

.wallet-spinner {
  width: 18px; height: 18px;
  border: 2px solid var(--line-2);
  border-top-color: var(--gold);
  border-radius: 50%;
  animation: wallet-spin 700ms linear infinite;
  flex-shrink: 0;
}
@keyframes wallet-spin { to { transform: rotate(360deg); } }

.wallet-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--s-3);
  padding: var(--s-8) var(--s-5);
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  background: var(--bg-2);
}
.wallet-empty-icon {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: rgba(217, 166, 37, 0.12);
  color: var(--gold);
}
.wallet-empty h2 {
  font-family: var(--font-display);
  font-size: var(--fs-20);
  font-weight: var(--fw-700);
  color: var(--ink);
  margin: 0;
}
.wallet-empty p {
  margin: 0;
  max-width: 460px;
  color: var(--ink-muted);
  font-size: var(--fs-13);
  line-height: var(--lh-relaxed);
}

/* ────────────────────────────────────────────────────────────
   READY layout — 2-column on desktop, stacked on mobile
   ──────────────────────────────────────────────────────────── */
.wallet-grid {
  display: grid;
  grid-template-columns: minmax(0, 360px) minmax(0, 1fr);
  gap: var(--s-4);
  align-items: start;
}
.wallet-grid > .wallet-payfrom-card { grid-column: 1 / -1; }
@media (max-width: 720px) {
  .wallet-grid { grid-template-columns: 1fr; }
}

.wallet-card {
  border: 1px solid var(--line);
  border-radius: var(--r-3);
  background: var(--bg-2);
  padding: var(--s-5);
}
.wallet-card-title {
  font-family: var(--font-display);
  font-size: var(--fs-16);
  font-weight: var(--fw-700);
  color: var(--ink);
  letter-spacing: var(--tracking-tight);
  margin: 0 0 var(--s-3);
}
.wallet-card-label {
  font-family: var(--font-mono);
  font-size: var(--fs-10);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--ink-dim);
  font-weight: var(--fw-600);
  margin-bottom: var(--s-2);
}

/* ── Balance card — the hero number ── */
.wallet-balance-card {
  background: linear-gradient(135deg, var(--bg-3) 0%, var(--bg-2) 100%);
  border-color: var(--line-bright);
}
.wallet-balance-value {
  font-family: var(--font-display);
  font-size: clamp(36px, 4.6vw, 52px);
  font-weight: var(--fw-700);
  letter-spacing: -0.01em;
  line-height: 1;
  color: var(--ink);
  margin: 0;
  font-variant-numeric: tabular-nums;
}
.wallet-balance-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: var(--s-3);
  padding: 4px 10px;
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size: var(--fs-10);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  font-weight: var(--fw-600);
}
.wallet-balance-status.is-ready {
  background: rgba(94, 168, 114, 0.12);
  color: var(--success);
  border: 1px solid rgba(94, 168, 114, 0.32);
}
.wallet-balance-status.is-pending {
  background: rgba(217, 166, 37, 0.12);
  color: var(--gold);
  border: 1px solid rgba(217, 166, 37, 0.32);
}
.wallet-balance-status.is-incomplete {
  background: rgba(216, 81, 69, 0.10);
  color: var(--danger);
  border: 1px solid rgba(216, 81, 69, 0.32);
}

/* ── Withdraw card ── */
.wallet-bank-row {
  display: flex;
  align-items: baseline;
  gap: var(--s-3);
  padding: var(--s-2) var(--s-3);
  margin-bottom: var(--s-4);
  border-radius: var(--r-2);
  background: var(--bg-1);
  border: 1px solid var(--line-2);
}
.wallet-bank-label {
  font-family: var(--font-mono);
  font-size: var(--fs-10);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--ink-dim);
  font-weight: var(--fw-600);
}
.wallet-bank-value {
  font-family: var(--font-mono);
  font-size: var(--fs-12);
  color: var(--ink);
  letter-spacing: var(--tracking-wide);
}

.wallet-field { display: flex; flex-direction: column; gap: 8px; margin-bottom: var(--s-4); }
.wallet-field-row { margin-bottom: var(--s-5); }
.wallet-label {
  font-family: var(--font-mono);
  font-size: var(--fs-10);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--ink-dim);
  font-weight: var(--fw-600);
}

.wallet-amount-input {
  display: flex;
  align-items: stretch;
  border: 1px solid var(--line-2);
  border-radius:var(--r-4);
  background: var(--bg-1);
  overflow: hidden;
  transition: border-color var(--dur-1) var(--ease-standard),
              box-shadow var(--dur-1) var(--ease-standard);
}
.wallet-amount-input:focus-within {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(217, 166, 37, 0.10);
}
.wallet-amount-prefix {
  padding: 9px 14px;
  background: var(--bg-3);
  font-family: var(--font-mono);
  font-size: var(--fs-13);
  font-weight: var(--fw-600);
  color: var(--ink);
  border-right: 1px solid var(--line-2);
  display: flex;
  align-items: center;
}
.wallet-amount-input input {
  flex: 1;
  height: 40px;
  padding: 0 14px;
  background: transparent;
  border: none;
  font-family: var(--font-display);
  font-size: var(--fs-16);
  font-variant-numeric: tabular-nums;
  color: var(--ink);
  outline: none;
}
.wallet-amount-input input::placeholder { color: var(--ink-faint); }

/* Quick-amount preset chips — mirror admin-payouts. Sit between the
   amount input and the help text. Max is gold-tinted to draw the eye. */
.wallet-presets {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 6px;
}
.wallet-preset-btn {
  font-family: var(--font-mono);
  font-size:var(--fs-11);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  padding: 7px 12px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: var(--ink-muted);
  cursor: pointer;
  transition: color var(--dur-1) var(--ease-standard),
              border-color var(--dur-1) var(--ease-standard),
              background var(--dur-1) var(--ease-standard);
}
.wallet-preset-btn:hover {
  color: var(--ink);
  border-color: rgba(217, 166, 37, 0.40);
  background: rgba(217, 166, 37, 0.06);
}
.wallet-preset-max {
  color: var(--gold);
  border-color: rgba(217, 166, 37, 0.30);
}
.wallet-preset-max:hover {
  background: rgba(217, 166, 37, 0.12);
}

.wallet-amount-help { font-size:var(--fs-11); color: var(--ink-dim); margin-top: 4px; }
.wallet-amount-error {
  font-size:var(--fs-12);
  color: var(--danger);
  display: flex;
  align-items: center;
  gap: 6px;
}

/* ── RTC toggle ── */
.wallet-toggle {
  display: flex;
  align-items: flex-start;
  gap: var(--s-3);
  padding: var(--s-3);
  border: 1px solid var(--line-2);
  border-radius: var(--r-2);
  background: var(--bg-1);
  cursor: pointer;
  transition: border-color var(--dur-1) var(--ease-standard),
              background var(--dur-1) var(--ease-standard);
}
.wallet-toggle:hover { border-color: var(--line-bright); background: var(--bg-2); }
.wallet-toggle input { position: absolute; opacity: 0; pointer-events: none; }
.wallet-toggle-track {
  flex-shrink: 0;
  position: relative;
  width: 36px; height: 20px;
  background: var(--bg-4);
  border: 1px solid var(--line-2);
  border-radius: var(--r-pill);
  transition: background var(--dur-1) var(--ease-standard),
              border-color var(--dur-1) var(--ease-standard);
}
.wallet-toggle-track::after {
  content: '';
  position: absolute;
  top: 1px; left: 1px;
  width: 16px; height: 16px;
  background: var(--ink);
  border-radius: 50%;
  transition: transform var(--dur-1) var(--ease-standard);
}
.wallet-toggle input:checked + .wallet-toggle-track {
  background: var(--gold);
  border-color: var(--gold);
}
.wallet-toggle input:checked + .wallet-toggle-track::after {
  transform: translateX(16px);
  background: var(--gold-ink);
}
.wallet-toggle-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.wallet-toggle-label {
  font-size: var(--fs-13);
  font-weight: var(--fw-600);
  color: var(--ink);
}
.wallet-toggle-desc {
  font-size: var(--fs-11);
  color: var(--ink-muted);
  line-height: 1.45;
}

/* ── Action row — Withdraw + Withdraw all ── */
.wallet-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
}
.wallet-actions .btn { padding: 11px 22px; font-size: var(--fs-13); }
.wallet-actions .btn:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  transform: none !important;
}

/* ── Balance hint ── */
.wallet-balance-hint {
  margin-top: 4px;
  font-size: var(--fs-11);
  color: var(--ink-muted);
  font-family: var(--font-sans);
  letter-spacing: 0;
  text-transform: none;
  font-weight: var(--fw-400);
}

/* ── Pending-in-escrow card ── */
.wallet-pending-card { grid-column: 1 / -1; }
.wallet-pending-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--s-4);
  margin-bottom: var(--s-2);
}
.wallet-pending-value {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.4vw, 36px);
  font-weight: var(--fw-700);
  line-height: 1.05;
  margin-top: 2px;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.wallet-pending-pill {
  flex-shrink: 0;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  background: rgba(217, 166, 37, 0.10);
  border: 1px solid rgba(217, 166, 37, 0.32);
  font-family: var(--font-mono);
  font-size: var(--fs-10);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  font-weight: var(--fw-700);
  color: var(--gold);
}
.wallet-pending-hint {
  margin-bottom: var(--s-3);
  font-size: var(--fs-12);
  line-height: 1.5;
  color: var(--ink-muted);
}
.wallet-pending-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
  border: 1px solid var(--line-2);
  border-radius: var(--r-2);
  background: var(--bg-1);
  overflow: hidden;
}
.wallet-pending-item {
  display: flex;
  align-items: center;
  gap: var(--s-3);
  padding: var(--s-3) var(--s-4);
  background: var(--bg-2);
}
.wallet-pending-item + .wallet-pending-item { border-top: 1px solid var(--line-2); }
.wallet-pending-link {
  flex: 1;
  display: flex;
  align-items: center;
  gap: var(--s-3);
  text-decoration: none;
  min-width: 0;
}
.wallet-pending-title {
  flex: 1;
  font-size: var(--fs-13);
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wallet-pending-link:hover .wallet-pending-title { color: var(--gold); }
.wallet-pending-status {
  flex-shrink: 0;
  padding: 2px 8px;
  border-radius: var(--r-pill);
  font-family: var(--font-mono);
  font-size:var(--fs-10);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  font-weight: var(--fw-700);
  color: var(--ink-dim);
  background: var(--bg-3);
}
.wallet-pending-status-paid       { color: var(--gold);    background: rgba(217,166,37,0.10); }
.wallet-pending-status-in_transit { color: #6FB7FF;        background: rgba(111,183,255,0.10); }
.wallet-pending-status-delivered  { color: var(--success); background: rgba(94,168,114,0.10); }
.wallet-pending-amount {
  flex-shrink: 0;
  font-family: var(--font-display);
  font-size: var(--fs-14);
  font-weight: var(--fw-700);
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}

/* ── Pay-from-wallet stub ── */
.wallet-payfrom-card {
  background: linear-gradient(rgba(217, 166, 37, 0.04), rgba(217, 166, 37, 0.04)), var(--bg-2);
  border-color: rgba(217, 166, 37, 0.28);
}
.wallet-payfrom-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-3);
  margin-bottom: var(--s-3);
  flex-wrap: wrap;
}
.wallet-payfrom-head .wallet-card-title { margin: 0; }
.wallet-soon-pill {
  font-family: var(--font-mono);
  font-size: var(--fs-10);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--gold);
  font-weight: var(--fw-700);
  padding: 3px 8px;
  border: 1px solid rgba(217, 166, 37, 0.4);
  border-radius: var(--r-pill);
}
.wallet-payfrom-body {
  margin: 0;
  font-size: var(--fs-13);
  line-height: var(--lh-relaxed);
  color: var(--ink-muted);
  max-width: 640px;
}

@media (max-width: 480px) {
  .wallet-card { padding: var(--s-4); }
  .wallet-actions { flex-direction: column-reverse; align-items: stretch; }
  .wallet-actions .btn { width: 100%; }
}

/* Ultra-narrow phones — tighten preset chips so 4 fit on one row
   without overflowing or wrapping unevenly. Pending-list columns
   become shrinkable so a long deal title doesn't push the status
   pill + amount off the right edge. */
@media (max-width: 360px) {
  .wallet-preset-btn { padding: 6px 9px; font-size:var(--fs-10); letter-spacing: 0.03em; }
  .wallet-presets { gap: 4px; }
}
.wallet-pending-status { flex-shrink: 1; min-width: 0; }
.wallet-pending-amount { flex-shrink: 0; }
