/* ═══════════════════════════════════════════════════════════════════════════
   Profile page — Handium — Mockup port
   ═══════════════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;600&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { overflow: hidden; height: 100%; }
body { font-family:var(--font); background:var(--bg); color:var(--ink); height:100%; overflow:hidden; display:flex; flex-direction:column; font-size:15px; line-height:1.6; }

/* Layout */
.layout { display:flex; flex:1; min-height:0; overflow:hidden; }

/* Only .main scrolls — page body and sidebar are locked */
.main { overflow-y: auto; }

/* Sidebar */
.sidebar { width:220px; flex-shrink:0; background:var(--surface); border-right:1px solid var(--border); display:flex; flex-direction:column; padding:28px 14px 16px; position:sticky; top:var(--header-height); height:calc(100vh - var(--header-height)); overflow:hidden; }
.sidebar-user { text-align:center; padding:14px; margin-bottom:20px; }
.sidebar-avatar { width:60px; height:60px; border-radius:50%; background:var(--accent); display:flex; align-items:center; justify-content:center; font-size:20px; font-weight:600; color:#fff; margin:0 auto 10px; }
.sidebar-name { font-size:15px; font-weight:600; color:var(--ink); }
.sidebar-email { font-size:12px; color:var(--ink-3); margin-top:2px; }
.nav-section { font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:0.8px; color:var(--ink-4); padding:0 8px; margin:10px 0 4px; }
#profileTabs { display:flex; flex-direction:column; gap:2px; }
.nav-item { display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius:var(--r-md); font-size:14px; font-weight:500; color:var(--ink-3); cursor:pointer; transition:background var(--t-fast),color var(--t-fast); text-decoration:none; }
.nav-item:hover { background:var(--surface-2); color:var(--ink); }
.nav-item.active { background:var(--surface-2); color:var(--ink); }
.nav-item svg { flex-shrink:0; }
.nav-dot { width:6px; height:6px; border-radius:50%; background:transparent; margin-left:auto; flex-shrink:0; transition:background var(--t-fast); }
.nav-item.active .nav-dot { background:var(--accent); }
.sidebar-bottom { margin-top:auto; padding-top:12px; border-top:1px solid var(--border-soft); display:flex; flex-direction:column; gap:2px; }
a.sidebar-link, .sidebar-link { display:flex !important; align-items:center; gap:8px; padding:7px 10px; border-radius:var(--r-md); font-size:13px; font-weight:500; color:var(--ink-3); cursor:pointer; text-decoration:none; }
a.sidebar-link:hover, .sidebar-link:hover { background:var(--surface-2); color:var(--ink-2); }

/* Main */
.main { flex:1; min-width:0; overflow-x:hidden; }
.main-inner { max-width:860px; padding:44px 44px 94px; }
.page-header { margin-bottom:0; }
.page-header .page-title { font-size:24px; font-weight:700; color:var(--ink); letter-spacing:-0.5px; margin-bottom:4px; }
.page-sub { font-size:14px; color:var(--ink-3); margin-bottom:28px; }

/* ── Typography utilities ────────────────────────────────────────────────── */
.t-h1 { font-size:34px; font-weight:700; color:var(--ink); letter-spacing:-1px; line-height:1.1; }
.t-h2 { font-size:22px; font-weight:600; color:var(--ink); letter-spacing:-0.5px; }
.t-h3 { font-size:16px; font-weight:600; color:var(--ink); }
.t-body { font-size:15px; font-weight:400; color:var(--ink-2); line-height:1.6; }
.t-small { font-size:13px; color:var(--ink-3); }
.t-mono { font-family:var(--font-mono); font-size:12px; color:var(--accent); }

/* Cards */
.cards-col { display:flex; flex-direction:column; gap:16px; }
.card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-xl); box-shadow:var(--sh-sm); overflow:hidden; }
.card-header { display:flex; align-items:center; justify-content:space-between; padding:17px 22px; border-bottom:1px solid var(--border-soft); }
.card-title { font-size:14px; font-weight:600; color:var(--ink); display:flex; align-items:center; gap:8px; }
.card-title svg { color:var(--ink-3); }
.card-action { padding:5px 12px; border-radius:var(--r-md); border:1px solid var(--border); background:var(--surface); font-size:12px; font-weight:600; color:var(--ink-2); cursor:pointer; font-family:var(--font); }
.card-action:hover { background:var(--surface-2); }
.card-action.accent { background:var(--ink); color:#fff; border-color:var(--ink); }

/* Field rows */
.field-row { display:flex; align-items:center; justify-content:space-between; padding:14px 22px; gap:12px; }
.field-row + .field-row { border-top:1px solid var(--border-soft); }
.field-label { font-size:14px; color:var(--ink); }
.field-value { font-size:14px; color:var(--ink-2); text-align:right; }
.field-row-right { display:flex; align-items:center; gap:10px; }
.field-value.masked { letter-spacing:4px; color:var(--ink-4); font-size:12px; }
.field-edit { font-size:12px; font-weight:500; color:var(--accent); cursor:pointer; white-space:nowrap; text-decoration:none; }
.field-edit:hover { color:var(--accent-dark); }

/* Stats */
.stats-row { display:grid; grid-template-columns:repeat(auto-fit, minmax(160px, 1fr)); gap:14px; margin-bottom:22px; }
.stat-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); padding:18px 22px; box-shadow:var(--sh-sm); }
.stat-label { font-size:12px; color:var(--ink-3); margin-top:2px; }
.stat-value { font-size:28px; font-weight:700; color:var(--ink); letter-spacing:-0.5px; }
.stat-sub { font-size:12px; color:var(--ink-3); margin-top:3px; }
.stat-trend { font-size:12px; color:var(--green); margin-top:2px; font-weight:500; }
/* last-tx on token stat card */
.stat-last-tx { font-size:12px; font-weight:500; margin-top:2px; }
.stat-last-tx--credit { color:var(--green); }
.stat-last-tx--debit  { color:var(--ink-3); }
.stat-last-tx-arrow   { }
.badge { display:inline-flex; align-items:center; gap:4px; margin-top:6px; padding:3px 10px; border-radius:100px; font-size:12px; font-weight:500; }
.badge.green { background:var(--green-soft); color:var(--green); }
.badge.accent { background:var(--accent-soft); color:var(--accent-dark); }
.badge.gray { background:var(--surface-2); color:var(--ink-3); }
.badge.red { background:var(--red-soft); color:var(--red); }
.badge.amber { background:rgba(245,158,11,.12); color:#b45309; }
.badge.navy { background:var(--navy-soft); color:var(--navy); }

/* Toggle */
.toggle-row { display:flex; align-items:center; justify-content:space-between; padding:14px 22px; }
.toggle-row + .toggle-row { border-top:1px solid var(--border-soft); }
.toggle-info .toggle-name { font-size:14px; font-weight:500; color:var(--ink); }
.toggle-info .toggle-desc { font-size:12px; color:var(--ink-3); margin-top:2px; }
.toggle { position:relative; width:38px; height:22px; flex-shrink:0; margin-left:16px; }
.toggle input { opacity:0; width:0; height:0; }
.toggle-track { position:absolute; inset:0; background:var(--border); border-radius:11px; cursor:pointer; transition:background var(--t-fast); }
.toggle-track::after { content:''; position:absolute; top:3px; left:3px; width:16px; height:16px; background:#fff; border-radius:50%; transition:transform var(--t-fast); box-shadow:0 1px 3px rgba(0,0,0,.15); }
.toggle input:checked + .toggle-track { background:var(--green); }
.toggle input:checked + .toggle-track::after { transform:translateX(16px); }

/* Buttons */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:7px; padding:9px 18px; border-radius:var(--r-md); font-size:14px; font-weight:500; cursor:pointer; font-family:var(--font); border:none; transition:all var(--t-fast); white-space:nowrap; }
.btn.primary { background:var(--ink); color:#fff; box-shadow:var(--sh-sm); }
.btn.primary:hover { background:var(--navy); transform:translateY(-1px); box-shadow:var(--sh-md); }
.btn.accent { background:var(--accent); color:#fff; box-shadow:var(--sh-accent); }
.btn.accent:hover { background:var(--accent-dark); transform:translateY(-1px); }
.btn.outline { background:transparent; border:1.5px solid var(--border); color:var(--ink); }
.btn.outline:hover { border-color:var(--ink-3); background:var(--surface-2); }
.btn.ghost { background:transparent; color:var(--ink-2); padding:9px 14px; }
.btn.ghost:hover { background:var(--surface-2); color:var(--ink); }
.btn.danger { background:var(--red-soft); color:var(--red); border:1px solid rgba(217,79,79,.2); }
.btn.danger:hover { background:var(--red); color:#fff; }
.btn.danger-outline { background:transparent; border:1px solid #F5C2C2; color:var(--red); }
.btn.danger-outline:hover { background:var(--red-soft); }
.btn-sm { font-size:13px !important; padding:6px 12px !important; border-radius:var(--r-sm) !important; }
.btn-icon { padding:7px; border-radius:var(--r-md); background:var(--surface-2); color:var(--ink-2); border:1px solid var(--border); }
.btn-icon:hover { background:var(--ink); color:#fff; border-color:var(--ink); }

/* Progress */
.progress-wrap { padding:0 22px 16px; }
.progress-meta { display:flex; justify-content:space-between; font-size:12px; color:var(--ink-3); margin-bottom:6px; }
.progress-meta-val { font-weight:500; color:var(--ink); }
.progress-bar-bg { height:8px; background:var(--surface-2); border-radius:4px; overflow:hidden; }
.progress-bar { height:100%; border-radius:4px; transition:width .3s ease; }
.progress-bar.accent { background:var(--accent); }
.progress-bar.green { background:var(--green); }
.progress-bar.red { background:var(--red); }
.usage-rows { padding:14px 22px; display:flex; flex-direction:column; gap:16px; }
.usage-row { display:flex; flex-direction:column; }

/* Table */
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:13px; }
th { text-align:left; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--ink-4); padding:10px 20px; border-bottom:1px solid var(--border-soft); }
td { padding:11px 20px; border-bottom:1px solid var(--border-soft); color:var(--ink-2); }
tr:last-child td { border-bottom:none; }
tr:hover td { background:var(--surface-2); }
.td-mono { font-size:12px; font-family:var(--font-mono); color:var(--ink-3); }
.td-amount.plus { color:var(--green); font-weight:600; }
.td-amount.minus { color:var(--ink-2); }

/* Plan cards */
.plan-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; padding:16px 22px; align-items:stretch; }
.plan-card { border:1px solid var(--border); border-radius:var(--r-lg); padding:16px; position:relative; display:flex; flex-direction:column; cursor:pointer; transition:all var(--t-mid); }
.plan-card:not(.current):hover { border-color:var(--accent); transform:translateY(-2px); box-shadow:var(--sh-md); }
/* overridden above */
.plan-card.current { border-color:var(--accent); }
.plan-card.popular { border:2px solid var(--accent); padding-top:22px; }
.plan-card-name { font-size:14px; font-weight:700; color:var(--ink); margin-bottom:4px; }
.plan-card-price { font-size:22px; font-weight:800; color:var(--ink); letter-spacing:-0.5px; }
.plan-card-price span:not(.plan-price-value) { font-size:13px; font-weight:400; color:var(--ink-3); }
.plan-card-features { margin-top:12px; display:flex; flex-direction:column; gap:5px; flex:1; padding-bottom:12px; }
.plan-card-features li { font-size:12px; color:var(--ink-3); list-style:none; display:flex; align-items:center; gap:6px; }
.plan-card-features li::before { content:'✓'; color:var(--green); font-weight:700; flex-shrink:0; }
.plan-card .current-tag { position:absolute; top:10px; right:10px; background:var(--accent-soft); color:var(--accent-dark); font-size:10px; font-weight:700; padding:2px 8px; border-radius:10px; }
.plan-card .popular-tag { position:absolute; top:-10px; left:50%; transform:translateX(-50%); background:var(--accent); color:#fff; font-size:10px; font-weight:700; padding:2px 8px; border-radius:10px; white-space:nowrap; }
.plan-card-btn { margin-top:auto; width:100%; text-align:center; }
.current-plan-banner { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:16px 22px; border-bottom:1px solid var(--border-soft); }
.cpb-left { display:flex; flex-direction:column; gap:6px; }
.cpb-name { font-size:17px; font-weight:700; color:var(--ink); letter-spacing:-0.2px; }
.cpb-status { display:flex; align-items:center; gap:8px; }
.cpb-active { display:inline-flex; align-items:center; gap:4px; font-size:11px; font-weight:600; color:var(--green); background:var(--green-soft); padding:2px 8px; border-radius:100px; }
.cpb-active::before { content:''; display:inline-block; width:5px; height:5px; border-radius:50%; background:var(--green); }
.cpb-active--amber { color:#b45309; background:var(--amber-soft); }
.cpb-active--amber::before { background:var(--amber); }
.cpb-ends { font-size:12px; color:var(--ink-3); }
.cpb-right { flex-shrink:0; display:flex; flex-direction:column; align-items:flex-end; gap:4px; }
.cpb-price { font-size:22px; font-weight:800; color:var(--ink); letter-spacing:-0.5px; line-height:1; }
.cpb-price span { font-size:13px; font-weight:400; color:var(--ink-3); letter-spacing:0; }
.cpb-lock { display:flex; align-items:center; gap:6px; font-size:11px; color:var(--ink-3); }
.cpb-update-btn { margin-left:2px; padding:1px 8px; border-radius:100px; border:1px solid var(--border); background:var(--surface); font-size:11px; font-weight:600; color:var(--ink-2); cursor:pointer; font-family:var(--font); transition:background var(--t-fast); }
.cpb-update-btn:hover { background:var(--surface-2); }

/* Referral */
.ref-link-box { display:flex; gap:8px; padding:12px 22px; align-items:center; }
.ref-link-input { flex:1; background:var(--surface-2); border:1px solid var(--border); border-radius:var(--r-md); padding:9px 12px; font-size:13px; color:var(--ink-2); font-family:var(--font); }
.ref-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:0; }
.ref-stat { padding:16px 20px; text-align:center; }
.ref-stat + .ref-stat { border-left:1px solid var(--border-soft); }
.ref-stat-value { font-size:26px; font-weight:800; color:var(--ink); letter-spacing:-0.5px; }
.ref-stat-label { font-size:12px; color:var(--ink-3); margin-top:3px; }

/* Export */
.export-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; padding:16px 20px; }
.export-card { border:1px solid var(--border); border-radius:var(--r-lg); padding:16px; display:flex; flex-direction:column; gap:8px; }
.export-card-icon { width:36px; height:36px; background:var(--surface-2); border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; }
.export-card-title { font-size:13px; font-weight:700; color:var(--ink); }
.export-card-desc { font-size:12px; color:var(--ink-3); line-height:1.5; }

/* Danger */
.card.danger { border-color:#F5C2C2; }
.danger-body { padding:16px 22px; }
.danger-desc { font-size:13px; color:var(--ink-3); margin-bottom:14px; line-height:1.5; }

/* Billing toggle */
.billing-toggle { display:inline-flex; background:var(--surface-2); border:1px solid var(--border); border-radius:var(--r-md); overflow:hidden; margin:0 22px 16px; }
.billing-opt { padding:6px 14px; font-size:12px; font-weight:600; color:var(--ink-3); cursor:pointer; }
.billing-opt.active { background:var(--surface); color:var(--ink); box-shadow:var(--sh-sm); }
.billing-save { font-size:11px; font-weight:700; color:var(--green); margin-left:4px; }

/* Section label */
.section-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.7px; color:var(--ink-4); margin-bottom:10px; }

/* ── JS tab system compatibility ─────────────────────────────────────────── */
.profile-tab-panel { display: none; }
.profile-tab-panel.profile-tab-panel--active { display: block; }
.nav-item.profile-nav-item--active {
  background: var(--surface-2);
  color: var(--ink);
}
.nav-item.profile-nav-item--active svg { opacity: .8; }
.nav-item.profile-nav-item--active .nav-dot { background: var(--accent); }

/* Loading/content state */
#loadingState {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 20px;
  color: var(--ink-3);
  font-size: 13px;
  gap: 10px;
}
#profileContent { display: none; }

/* ── p- variable aliases (modal compatibility) ───────────────────────────── */
:root {
  --p-bg: var(--bg);
  --p-surface: var(--surface);
  --p-surface2: var(--surface-2);
  --p-border: var(--border);
  --p-border-light: var(--border-soft);
  --p-text: var(--ink);
  --p-text-2: var(--ink-2);
  --p-text-3: var(--ink-3);
  --p-text-4: var(--ink-4);
  --p-accent: var(--accent);
  --p-accent-soft: var(--accent-soft);
  --p-accent-text: var(--accent-dark);
  --p-success: var(--green);
  --p-success-light: var(--green-soft);
  --p-danger: var(--red);
  --p-danger-light: var(--red-soft);
  --p-shadow-sm: var(--sh-sm);
  --p-radius: var(--r-lg);
  --p-radius-sm: var(--r-md);
}

/* ── Modal ───────────────────────────────────────────────────────────────── */
.modal-content { background:var(--surface); border-radius:var(--r-xl); width:100%; max-width:480px; box-shadow:var(--sh-lg); }
.modal-content--sm     { max-width:400px; }
.modal-content--cancel { max-width:440px; padding:0; overflow:hidden; }

/* ── Cancel modal: M3 hero ───────────────────────────────────────────────── */
.cm-hero { display:flex; align-items:flex-start; gap:14px; padding:20px 20px 0; }
.cm-hero-icon { width:44px; height:44px; border-radius:var(--r-lg); background:var(--accent-soft); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.cm-hero-icon svg { width:22px; height:22px; color:var(--accent); }
.cm-hero-title { font-size:16px; font-weight:700; color:var(--ink); margin-bottom:4px; line-height:1.3; }
.cm-hero-sub { font-size:13px; color:var(--ink-3); line-height:1.5; }

/* ── Cancel modal: M1 body ───────────────────────────────────────────────── */
.cm-body { padding:14px 20px 20px; }
.cm-eyebrow { display:flex; align-items:center; gap:8px; font-size:10px; font-weight:700; color:var(--accent); margin-bottom:10px; letter-spacing:.05em; text-transform:uppercase; }
.cm-eyebrow span { flex:1; height:1px; background:var(--accent-soft); }

/* Stats strip */
.cm-stats { display:flex; border:1px solid var(--border); border-radius:var(--r-lg); overflow:hidden; margin-bottom:14px; }
.cm-stat { flex:1; text-align:center; padding:11px 8px; background:var(--bg); border-right:1px solid var(--border); }
.cm-stat:last-child { border-right:none; }
.cm-stat .sv { font-size:18px; font-weight:800; color:var(--ink); line-height:1; display:block; }
.cm-stat .sl { font-size:10px; color:var(--ink-3); margin-top:3px; line-height:1.3; display:block; }

/* Plan compare cards */
.cm-plan-cards { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:14px; }
.cm-plan-card { border:1.5px solid var(--border); border-radius:var(--r-lg); padding:13px; background:var(--surface); position:relative; }
.cm-plan-card.current { border-color:var(--accent); }
.cm-plan-badge { position:absolute; top:-9px; left:50%; transform:translateX(-50%); background:var(--accent); color:#fff; font-size:9px; font-weight:700; padding:2px 9px; border-radius:20px; white-space:nowrap; }
.cm-plan-name { font-size:12px; font-weight:700; color:var(--ink); margin-bottom:3px; }
.cm-plan-price { font-size:17px; font-weight:800; color:var(--accent); margin-bottom:8px; line-height:1; }
.cm-plan-price sub { font-size:11px; font-weight:400; color:var(--ink-3); }
.cm-plan-price.grey { color:var(--ink-3); }
.cm-plan-feats { list-style:none; font-size:11px; color:var(--ink-2); display:flex; flex-direction:column; gap:5px; }
.cm-plan-feats li::before { content:'— '; color:var(--green); font-weight:700; }
.cm-plan-feats li.minus::before { content:'— '; color:var(--ink-4); }

/* Footer */
.cm-footer { display:flex; flex-direction:column; gap:7px; }
.cm-cancel-footnote { text-align:center; font-size:11px; color:var(--ink-4); line-height:1.5; margin-top:2px; }
.modal-header { display:flex; align-items:center; justify-content:space-between; padding:16px 20px; border-bottom:1px solid var(--border-soft); }
.modal-header h3 { font-size:15px; font-weight:700; color:var(--ink); margin:0; }
.modal-close { background:none; border:none; font-size:20px; color:var(--ink-3); cursor:pointer; line-height:1; padding:0; }
.modal-close:hover { color:var(--ink); }
.modal-body { padding:20px; }
.modal-footer { padding:12px 20px; border-top:1px solid var(--border-soft); display:flex; justify-content:flex-end; gap:8px; }

/* Forms for modals */
.p-input { width:100%; padding:9px 13px; border:1.5px solid var(--border); border-radius:var(--r-md); font-size:14px; font-family:var(--font); color:var(--ink); background:var(--surface); outline:none; transition:all var(--t-fast); }
.p-input::placeholder { color:var(--ink-4); }
.p-input:focus { border-color:var(--ink); box-shadow:0 0 0 3px rgba(26,25,23,.06); }
.p-form-group { display:flex; flex-direction:column; gap:5px; margin-bottom:14px; }
.p-form-label { font-size:13px; font-weight:500; color:var(--ink-2); }

/* Buttons for modals */
.p-btn-primary { display:inline-flex; align-items:center; gap:6px; padding:9px 18px; border-radius:var(--r-md); font-size:14px; font-weight:500; cursor:pointer; font-family:var(--font); background:var(--ink); color:#fff; border:none; transition:all var(--t-fast); }
.p-btn-primary:hover:not(:disabled) { background:var(--navy); transform:translateY(-1px); box-shadow:var(--sh-md); }
.p-btn-primary:disabled { background:var(--border); color:var(--ink-4); cursor:not-allowed; }
.p-btn-ghost { display:inline-flex; align-items:center; gap:6px; padding:9px 18px; border-radius:var(--r-md); font-size:14px; font-weight:500; cursor:pointer; font-family:var(--font); background:transparent; color:var(--ink-2); border:1px solid var(--border); transition:all var(--t-fast); }
.p-btn-ghost:hover { background:var(--surface-2); color:var(--ink); }
.p-btn-danger { display:inline-flex; align-items:center; gap:6px; padding:9px 18px; border-radius:var(--r-md); font-size:14px; font-weight:500; cursor:pointer; font-family:var(--font); background:var(--red-soft); color:var(--red); border:1px solid rgba(217,79,79,.2); transition:all var(--t-fast); }
.p-btn-danger:hover { background:var(--red); color:#fff; border-color:var(--red); }
.p-btn-sm { padding:6px 12px !important; font-size:13px !important; }

/* Password fields */
.password-input { position:relative; }
.password-input .p-input { padding-right:40px; }
.password-toggle { position:absolute; right:10px; top:50%; transform:translateY(-50%); background:none; border:none; cursor:pointer; color:var(--ink-4); padding:0; display:flex; }
.password-toggle:hover { color:var(--ink-2); }
.eye-icon { display:block; }
.password-strength { margin-top:6px; display:flex; align-items:center; gap:8px; }
.password-strength-bar { flex:1; height:4px; background:var(--surface-2); border-radius:2px; overflow:hidden; }
.password-strength-fill { height:100%; border-radius:2px; transition:width .3s,background .3s; }
.password-strength-text { font-size:11px; color:var(--ink-3); white-space:nowrap; }
.password-match { font-size:12px; margin-top:4px; }

/* Purchase modal */
.p-purchase-summary { background:var(--surface-2); border-radius:var(--r-md); padding:14px 16px; }
.p-purchase-row { display:flex; justify-content:space-between; font-size:13px; color:var(--ink-2); padding:4px 0; }
.p-purchase-divider { height:1px; background:var(--border); margin:8px 0; }
.p-purchase-total { font-size:15px; font-weight:700; color:var(--ink); }
.p-purchase-warning { margin-top:10px; padding:9px 12px; background:var(--amber-soft); border-radius:var(--r-md); font-size:12px; color:#92400e; line-height:1.5; }
.p-recurring-consent { display:flex; align-items:flex-start; gap:8px; margin-top:12px; cursor:pointer; }
.p-recurring-consent input[type=checkbox] { flex-shrink:0; margin-top:2px; width:15px; height:15px; cursor:pointer; accent-color:var(--accent); }
.p-recurring-consent span { font-size:12px; color:var(--ink-2); line-height:1.5; }
.p-recurring-consent a { color:var(--accent); text-decoration:none; }
.p-recurring-consent a:hover { text-decoration:underline; }
.p-recurring-consent--highlight { outline:2px solid var(--accent); outline-offset:3px; border-radius:var(--r-sm); }

/* Support modal */
.p-support-select, .p-support-textarea { width:100%; padding:9px 13px; border:1.5px solid var(--border); border-radius:var(--r-md); font-size:14px; font-family:var(--font); color:var(--ink); background:var(--surface); outline:none; transition:all var(--t-fast); }
.p-support-select:focus, .p-support-textarea:focus { border-color:var(--ink); box-shadow:0 0 0 3px rgba(26,25,23,.06); }
.p-support-textarea { height:120px; resize:vertical; }
.p-support-form { display:flex; flex-direction:column; gap:14px; }

/* Compare plans modal */
.p-compare-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; padding:20px; gap:12px; }
.p-cc { border:1px solid var(--border); border-radius:var(--r-lg); padding:16px; position:relative; }
.p-cc--popular { border-color:var(--accent); }
.p-cc-badge { position:absolute; top:-10px; left:50%; transform:translateX(-50%); background:var(--accent); color:#fff; font-size:10px; font-weight:700; padding:2px 10px; border-radius:10px; white-space:nowrap; }
.p-cc-name { font-size:15px; font-weight:700; color:var(--ink); margin-bottom:4px; }
.p-cc-price { font-size:22px; font-weight:800; color:var(--ink); letter-spacing:-0.5px; }
.p-cc-price-unit { font-size:13px; font-weight:400; color:var(--ink-3); }
.p-cc-divider { height:1px; background:var(--border-soft); margin:12px 0; }
.p-cc-features { list-style:none; display:flex; flex-direction:column; gap:6px; }
.p-cc-features li { font-size:12px; color:var(--ink-3); display:flex; align-items:center; gap:6px; }
.p-cc-check { color:var(--green); flex-shrink:0; }
.p-cc-dash { color:var(--ink-4); flex-shrink:0; }

/* Delete account */
.p-confirm-code { background:var(--surface-2); border:1px solid var(--border); border-radius:var(--r-sm); padding:2px 8px; font-size:12px; font-family:monospace; color:var(--ink-2); }
.p-delete-info-box { background:var(--red-soft); border:1px solid #F5C2C2; border-radius:var(--r-md); padding:16px; }
.p-delete-list { margin:8px 0 0 16px; display:flex; flex-direction:column; gap:4px; }
.p-delete-list li { font-size:13px; color:var(--ink-2); }
.p-delete-stat { font-weight:600; color:var(--ink); margin-left:4px; }
.delete-countdown-box { display:flex; align-items:flex-start; gap:10px; background:var(--surface-2); border:1px solid var(--border); border-radius:var(--r-md); padding:14px; }
.delete-countdown-text { font-size:12px; color:var(--ink-3); margin-top:3px; }

/* Spinner */
.spinner-small { width:16px; height:16px; border:2px solid var(--border); border-top-color:var(--accent); border-radius:50%; animation:spin .8s linear infinite; }
.loading-state { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:60px 20px; color:var(--ink-3); font-size:13px; gap:10px; }

/* Skeleton loading */
.skeleton { background:linear-gradient(90deg, var(--surface-2) 25%, var(--border-soft) 50%, var(--surface-2) 75%); background-size:200% 100%; animation:shimmer 1.4s infinite; border-radius:var(--r-sm); }
@keyframes shimmer { from { background-position:200% 0; } to { background-position:-200% 0; } }

/* Toast */
.toast { position:fixed; bottom:24px; right:24px; background:var(--surface); border:1px solid var(--border); padding:13px 16px; border-radius:var(--r-lg); font-size:14px; box-shadow:var(--sh-md); opacity:0; transform:translateY(12px); transition:opacity var(--t-mid),transform var(--t-mid); pointer-events:none; z-index:200; display:flex; align-items:center; gap:12px; max-width:320px; }
.toast.visible { opacity:1; transform:translateY(0); pointer-events:auto; }
.toast-icon { width:22px; height:22px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:13px; }
.toast.success .toast-icon { background:var(--green-soft); color:var(--green); }
.toast.error .toast-icon { background:var(--red-soft); color:var(--red); }
.toast-text { font-weight:500; color:var(--ink); }
.toast-sub { font-size:12px; color:var(--ink-3); margin-top:2px; }

/* TX table */
.tx-toolbar { padding:12px 22px; border-bottom:1px solid var(--border-soft); display:flex; gap:8px; }
.tx-search-wrap { position:relative; flex:1; }
.tx-search-icon { position:absolute; left:10px; top:50%; transform:translateY(-50%); color:var(--ink-4); }
.tx-search { width:100%; padding:7px 10px 7px 32px; border:1px solid var(--border); border-radius:var(--r-md); font-size:12px; font-family:var(--font); background:var(--surface); color:var(--ink); }
.tx-table-wrap { overflow-x:auto; }
.tx-table { width:100%; border-collapse:collapse; font-size:13px; }
.tx-table th { text-align:left; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--ink-4); padding:10px 20px; border-bottom:1px solid var(--border-soft); }
.tx-table td { padding:10px 20px; border-bottom:1px solid var(--border-soft); color:var(--ink-2); }
.tx-table tr:last-child td { border-bottom:none; }
.tx-table tr:hover td { background:var(--surface-2); }
.tx-th-right { text-align:right; }
.tx-th-sortable { cursor:pointer; user-select:none; }
.tx-th-sort-active { color:var(--ink-2); }
.tx-sort-icon { font-size:10px; }
.tx-pagination { display:flex; align-items:center; justify-content:space-between; padding:10px 22px; border-top:1px solid var(--border-soft); font-size:12px; color:var(--ink-3); }
.tx-per-page { display:flex; align-items:center; gap:6px; }
.tx-per-page select { border:1px solid var(--border); border-radius:var(--r-sm); padding:3px 6px; font-size:12px; font-family:var(--font); }
.tx-pages { display:flex; gap:4px; }
.tx-page-btn { padding:4px 10px; border:1px solid var(--border); border-radius:var(--r-sm); font-size:12px; font-family:var(--font); background:var(--surface); color:var(--ink-2); cursor:pointer; }
.tx-page-btn:hover:not(:disabled) { background:var(--surface-2); }
.tx-page-btn--active { background:var(--ink); color:#fff; border-color:var(--ink); }
.tx-page-btn:disabled { opacity:.4; cursor:default; }
/* TX row / cell classes */
.tx-td-amount { text-align:right; font-weight:600; white-space:nowrap; }
.tx-table td.tx-td-amount--credit { color:var(--green); }
.tx-table td.tx-td-amount--debit { color:var(--ink-2); }
.tx-td-id { white-space:nowrap; }
.tx-td-date { white-space:nowrap; }
.tx-td-details { font-size:12px; max-width:220px; }
.tx-id-inner { display:flex; align-items:center; gap:4px; }
.tx-hash-label { font-size:11px; font-family:var(--font-mono); color:var(--ink-3); }
.tx-copy-btn { background:none; border:none; cursor:pointer; color:var(--ink-4); padding:2px; display:flex; line-height:0; }
.tx-copy-btn:hover { color:var(--accent); }
.tx-file-ref { color:var(--accent); font-size:12px; cursor:pointer; text-decoration:underline; }
.tx-type-badge { display:inline-flex; align-items:center; padding:3px 10px; border-radius:100px; font-size:11px; font-weight:500; }
.tx-type-badge--credit, .tx-type-badge--debit, .tx-type-badge--other { background:var(--surface-2); color:var(--ink-3); }
/* TX toolbar type filter */
.tx-type-filter { border:1px solid var(--border); border-radius:var(--r-md); padding:5px 10px; font-size:12px; font-family:var(--font); background:var(--surface); color:var(--ink-2); }
.td-mono { font-size:12px; font-family:var(--font-mono); color:var(--ink-3); }
.td-amount.plus { color:var(--green); font-weight:600; }
.td-amount.minus { color:var(--ink-2); }

/* Payments table */
.payments-loading, .transactions-loading, .ref-invited-loading { display:flex; align-items:center; gap:8px; padding:20px; font-size:13px; color:var(--ink-3); }
.payments-empty, .transactions-empty, .ref-invited-empty { padding:40px 20px; text-align:center; color:var(--ink-3); font-size:13px; flex-direction:column; align-items:center; justify-content:center; gap:10px; }
.payments-empty svg, .transactions-empty svg { color:var(--ink-4); }
.payments-table-wrap { overflow-x:auto; }
.payments-table { width:100%; border-collapse:collapse; font-size:13px; }
.payments-table th { text-align:left; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--ink-4); padding:10px 20px; border-bottom:1px solid var(--border-soft); }
.payments-table td { padding:10px 20px; border-bottom:1px solid var(--border-soft); color:var(--ink-2); }
.payments-table tr:last-child td { border-bottom:none; }
.payments-th-right { text-align:right; }

/* Autotopup section */
.p-autotopup-section { padding:16px 22px; }
.p-autotopup-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.p-autotopup-header-text h2 { font-size:14px; font-weight:700; color:var(--ink); margin:0 0 2px; }
.p-autotopup-nocard { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--ink-3); padding:10px 14px; background:var(--surface-2); border-radius:var(--r-md); }
.p-autotopup-settings { display:flex; flex-direction:column; gap:12px; padding:0 22px 16px; border-top:1px solid var(--border-soft); margin-top:0; }
.p-autotopup-card-info { font-size:13px; color:var(--ink-2); padding-top:14px; }
.p-autotopup-card-row { display:flex; align-items:center; gap:10px; }
.p-autotopup-card-badge { display:inline-flex; align-items:center; gap:6px; padding:5px 10px; background:var(--surface-2); border:1px solid var(--border); border-radius:var(--r-md); font-size:12px; color:var(--ink-2); }
.p-autotopup-card-delete { background:none; border:none; padding:0; font-size:12px; color:var(--ink-4); cursor:pointer; font-family:var(--font); transition:color var(--t-fast); }
.p-autotopup-card-delete:hover { color:var(--error); }
.p-autotopup-field { display:flex; flex-direction:column; gap:4px; }
.p-autotopup-label { font-size:12px; font-weight:500; color:var(--ink-3); }
.p-autotopup-threshold-row { display:flex; align-items:center; gap:8px; }
.p-autotopup-threshold-input { width:60px; padding:6px 8px; border:1px solid var(--border); border-radius:var(--r-sm); font-size:13px; font-family:var(--font); }
.p-autotopup-hint-text { font-size:13px; color:var(--ink-2); }
.p-autotopup-packs { display:flex; gap:6px; flex-wrap:wrap; }
.p-autotopup-consent { font-size:11px; color:var(--ink-4); line-height:1.5; }
.p-autotopup-consent a { color:var(--accent); }

/* Token section helpers */
.p-tokens-status-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--sh-sm); padding:16px 22px; margin-bottom:16px; }
.p-tokens-status-top { display:flex; align-items:center; justify-content:space-between; }
.p-tokens-balance-label { font-size:12px; font-weight:500; color:var(--ink-3); margin-bottom:4px; }
.p-tokens-balance-value { font-size:26px; font-weight:800; color:var(--ink); letter-spacing:-0.5px; }
.p-tokens-balance-unit { font-size:14px; font-weight:400; color:var(--ink-3); margin-left:6px; }
.p-btn-buy-tokens { display:inline-flex; align-items:center; gap:6px; padding:9px 18px; border-radius:var(--r-md); font-size:14px; font-weight:500; cursor:pointer; font-family:var(--font); background:var(--ink); color:#fff; border:none; transition:all var(--t-fast); }
.p-btn-buy-tokens:hover { background:var(--navy); transform:translateY(-1px); box-shadow:var(--sh-md); }
.p-daily-banner { display:flex; align-items:center; justify-content:space-between; background:var(--green-soft); border:1px solid rgba(45,158,107,.2); border-radius:var(--r-md); padding:10px 14px; margin-bottom:12px; }
.p-daily-left { display:flex; align-items:center; gap:8px; }
.p-daily-title { font-size:13px; font-weight:600; color:var(--ink); }
.p-daily-sub { font-size:12px; color:var(--ink-3); margin-top:1px; }
.p-daily-timer { font-size:12px; font-weight:600; color:var(--ink-3); font-family:monospace; }
.p-usage-row { margin-bottom:12px; }
.p-usage-label-row { display:flex; justify-content:space-between; font-size:12px; color:var(--ink-3); margin-bottom:5px; }
.p-usage-value { font-weight:600; color:var(--ink-2); }
.p-progress-track { height:6px; background:var(--surface-2); border-radius:3px; overflow:hidden; }
.p-progress-fill { height:100%; border-radius:3px; background:var(--accent); }
.p-progress-fill--green { background:var(--green); }
.p-progress-fill--blue { background:#3b82f6; }
.p-usage-hint-row { display:flex; align-items:center; justify-content:space-between; margin-top:4px; }
.p-usage-hint { font-size:11px; color:var(--ink-4); }
.p-btn-refill { font-size:11px; font-weight:600; color:var(--accent); background:none; border:none; cursor:pointer; font-family:var(--font); padding:0; }

/* Token packs */
.p-token-packs { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:16px; }
.p-token-packs-scroll { padding:16px 22px 0; overflow-x:auto; }
.p-token-hint { font-size:12px; color:var(--ink-3); }
.p-token-custom-row { display:flex; align-items:center; gap:10px; padding:12px 22px; border-top:1px solid var(--border-soft); }
.p-token-custom-hint { font-size:13px; color:var(--ink-2); font-weight:500; white-space:nowrap; }
.p-token-custom-input { width:80px; border:1px solid var(--border); border-radius:var(--r-md); padding:7px 10px; font-family:var(--font); font-size:13px; color:var(--ink); background:var(--surface); outline:none; transition:border-color 150ms; }
.p-token-custom-input:focus { border-color:var(--accent); }
.p-token-custom-total { font-size:13px; color:var(--ink-3); white-space:nowrap; }
.p-token-custom-btn { font-size:12px; padding:7px 16px; font-family:var(--font); flex-shrink:0; margin-left:auto; }

/* Subscription status card */
.p-sub-status-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--sh-sm); padding:16px 22px; margin-bottom:16px; }
.p-sub-status-top { display:flex; align-items:flex-start; justify-content:space-between; }
.p-sub-status-name { font-size:16px; font-weight:700; color:var(--ink); }
.p-sub-status-period { font-size:12px; color:var(--ink-3); margin-top:3px; }
.p-sub-status-actions { display:flex; flex-direction:column; align-items:flex-end; gap:8px; }
.p-sub-status-price { font-size:18px; font-weight:700; color:var(--ink); }
.p-plan-price-unit { font-size:13px; font-weight:400; color:var(--ink-3); }
.p-btn-cancel-sub { background:none; border:none; font-size:12px; color:var(--ink-3); cursor:pointer; font-family:var(--font); text-decoration:underline; padding:0; }
.p-sub-cancel-notice { display:flex; align-items:center; gap:8px; font-size:12px; color:var(--ink-3); padding:12px 22px; border-top:1px solid var(--border-soft); background:var(--surface-2); border-radius:0 0 var(--r-lg) var(--r-lg); line-height:1.5; }
.p-sub-cancel-notice svg { flex-shrink:0; color:var(--orange-color); }
.p-upgrade-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.p-billing-segment { display:inline-flex; background:var(--surface-2); border:1px solid var(--border); border-radius:var(--r-md); overflow:hidden; }
.p-billing-seg-btn { padding:6px 14px; font-size:12px; font-weight:600; color:var(--ink-3); background:none; border:none; cursor:pointer; font-family:var(--font); }
.p-billing-seg-btn--active { background:var(--surface); color:var(--ink); box-shadow:var(--sh-sm); }
.p-billing-save { font-size:11px; color:var(--green); font-weight:700; }
.p-plan-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.p-plan-cards-loading { padding:20px; text-align:center; font-size:13px; color:var(--ink-3); }
.p-btn-compare { background:none; border:1px solid var(--border); border-radius:var(--r-md); padding:7px 16px; font-size:12px; font-weight:600; color:var(--ink-3); cursor:pointer; font-family:var(--font); }

/* Section helpers */
.p-section-title { font-size:15px; font-weight:700; color:var(--ink); margin-bottom:8px; }
.p-subsection-title { font-size:13px; font-weight:600; color:var(--ink); margin-bottom:8px; }
.p-desc { font-size:13px; color:var(--ink-3); line-height:1.5; }
.p-hint { font-size:12px; color:var(--ink-4); margin-top:6px; }
.p-section-divider { height:1px; background:var(--border-soft); margin:20px 0; }

/* Referral */
.p-ref-stats { display:grid; grid-template-columns:repeat(3,1fr); background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--sh-sm); margin-bottom:16px; }
.p-ref-stat { padding:16px 20px; text-align:center; }
.p-ref-stat + .p-ref-stat { border-left:1px solid var(--border-soft); }
.p-ref-stat-label { font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--ink-4); margin-bottom:4px; }
.p-ref-stat-value { font-size:26px; font-weight:800; color:var(--ink); letter-spacing:-0.5px; }
.p-ref-stat-sub { font-size:12px; color:var(--ink-3); margin-top:2px; }
.p-ref-link-row { display:flex; gap:8px; align-items:center; margin-bottom:6px; }
.p-input-mono { font-family:var(--font-mono); font-size:12px; }

/* Export grid */
.p-export-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; margin-bottom:16px; }
.p-export-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--sh-sm); padding:16px; display:flex; align-items:center; gap:14px; }
.p-export-card-icon { width:40px; height:40px; background:var(--surface-2); border-radius:var(--r-md); display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--ink-3); }
.p-export-card-info { flex:1; }
.p-export-card-title { font-size:13px; font-weight:600; color:var(--ink); }
.p-export-card-desc { font-size:12px; color:var(--ink-3); margin-top:2px; }

/* Auth modal compatibility */
.auth-modal-close { position:absolute; top:12px; right:12px; background:none; border:none; font-size:20px; color:var(--ink-3); cursor:pointer; line-height:1; }
.auth-modal-close:hover { color:var(--ink); }

/* ── Header extras (styles now in common.css) ────────────────────────────── */

/* ── Billing toggle active class (JS uses p-billing-seg-btn--active) ─────── */
.billing-opt.p-billing-seg-btn--active { background:var(--surface); color:var(--ink); box-shadow:var(--sh-sm); }

/* ── Plan cards (JS-rendered via _renderPlanCards, uses .plan-card CSS) ──── */
/* .plan-card already defined above in "Plan cards" section */
/* p-field-edit: JS sets this class on saveNameBtn during name edit mode */
.p-field-edit { font-size:12px; font-weight:500; color:var(--accent); cursor:pointer; white-space:nowrap; text-decoration:none; background:none; border:none; font-family:var(--font); }
.p-field-edit:hover { color:var(--accent-dark); }

/* ── Token packs (JS-rendered via _renderTokenPacks) — vertical tiles ────── */
.p-token-packs { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:16px; }
.p-token-pack { display:flex; flex-direction:column; align-items:center; text-align:center; padding:14px 10px; border:1px solid var(--border); border-radius:var(--r-lg); background:var(--surface); cursor:pointer; font-family:var(--font); position:relative; transition:all var(--t-mid); }
.p-token-pack:hover { border-color:var(--accent); transform:translateY(-2px); box-shadow:var(--sh-md); }
.p-token-pack--popular { border:2px solid var(--accent); }
.p-token-pack-badge { position:absolute; top:-10px; left:50%; transform:translateX(-50%); background:var(--accent); color:#fff; font-size:10px; font-weight:700; padding:2px 8px; border-radius:10px; white-space:nowrap; }
.p-token-pack-amount { font-size:20px; font-weight:800; color:var(--ink); line-height:1.1; }
.p-token-pack-unit { font-size:12px; color:var(--ink-3); margin:2px 0 10px; }
.p-token-pack-price { font-size:14px; font-weight:700; color:var(--ink); margin-bottom:4px; }
.p-token-pack-save { font-size:11px; color:var(--green); font-weight:600; margin-bottom:6px; }
.p-token-pack-buy-btn { display:block; width:100%; padding:6px; border-radius:var(--r-md); font-size:12px; font-weight:600; text-align:center; background:var(--surface-2); color:var(--ink-2); border:1px solid var(--border); margin-top:auto; }
.p-token-pack--popular .p-token-pack-buy-btn { background:var(--accent); color:#fff; border-color:var(--accent); }

/* ── Autotopup packs (JS-rendered via _renderAutoTopupPacks) ─────────────── */
.p-autotopup-pack { display:flex; align-items:center; gap:6px; padding:6px 12px; border:1.5px solid var(--border); border-radius:var(--r-md); background:var(--surface); cursor:pointer; font-family:var(--font); transition:all var(--t-fast); }
.p-autotopup-pack:hover { border-color:var(--accent); }
.p-autotopup-pack--active { border-color:var(--accent); background:var(--accent-soft); }
.p-autotopup-pack-tokens { font-size:13px; font-weight:700; color:var(--ink); }
.p-autotopup-pack-price { font-size:12px; color:var(--ink-3); }
.p-autotopup-pack-custom-input { width:64px; padding:3px 6px; border:1px solid var(--border); border-radius:var(--r-sm); font-size:12px; font-family:var(--font); background:var(--surface); color:var(--ink); outline:none; }
.p-autotopup-pack-custom-input:focus { border-color:var(--accent); }
.p-autotopup-pack--active .p-autotopup-pack-custom-input { background:var(--accent-soft); }
.p-autotopup-pack-custom-price { font-size:11px; color:var(--ink-3); white-space:nowrap; }

/* ── Payment status badges (JS-rendered via renderPayments) ──────────────── */
.payment-status { display:inline-flex; align-items:center; padding:3px 10px; border-radius:100px; font-size:12px; font-weight:500; }
.payment-status--success    { background:var(--green-soft); color:var(--green); }
.payment-status--pending    { background:color-mix(in srgb, #f59e0b 12%, transparent); color:#d97706; }
.payment-status--failed     { background:var(--red-soft); color:var(--red); }
.payment-status--refunded   { background:var(--surface-2); color:var(--ink-3); }

/* Highlight successful payment rows */
.payments-table tr.payment-row--success td { background:color-mix(in srgb, var(--green) 4%, transparent); }
.payments-table tr.payment-row--success .payment-amount { color:var(--green); font-weight:600; }

/* stat-last-tx: plain text trend (no badge) — defined above near stat-trend */

/* ── Transaction file preview popup (JS-created via setupTxImgPopup) ──── */
.tx-img-popup { position:fixed; z-index:300; background:var(--surface); border:1px solid var(--border); border-radius:var(--r-lg); box-shadow:var(--sh-md); padding:10px; width:220px; pointer-events:none; opacity:0; transition:opacity .15s; }
.tx-img-popup--visible { opacity:1; pointer-events:auto; }
.tx-img-popup-img-wrap { width:100%; height:130px; overflow:hidden; border-radius:var(--r-md); background:var(--surface-2); display:flex; align-items:center; justify-content:center; margin-bottom:8px; }
.tx-img-popup-img { width:100%; height:100%; object-fit:cover; display:block; }
.tx-img-popup-snippet { font-size:11px; color:var(--ink-3); line-height:1.5; margin-bottom:6px; max-height:60px; overflow:hidden; word-break:break-word; }
.tx-img-popup-name { font-size:12px; font-weight:600; color:var(--ink-2); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.tx-img-popup-na { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; padding:16px 0; color:var(--ink-4); font-size:11px; }

/* ── Fixed footer — like sticky header but at the bottom ─────────────────── */
/* Starts at the sidebar right edge (220px), spans to screen right.          */
/* Content scrolls behind it; .main has extra padding-bottom to compensate.  */
.app-footer {
    position: fixed;
    bottom: 0;
    left: 220px;
    right: 0;
    z-index: 0;           /* below noise-overlay (z-index:1) so texture falls on footer too */
    background: var(--surface);
    margin-top: 0;        /* reset common.css margin-top:auto */
}
