/* ═══════════════════════════════════════════
   MOCK UI — Feature section visuals
═══════════════════════════════════════════ */

/* Shared mock card */
.mock-portfolio,
.mock-security,
.mock-bridge,
.mock-airdrop,
.mock-yields {
  background: var(--bg-subtle);
  border-radius: var(--r-lg);
  padding: var(--sp-5);
  font-size: .85rem;
}

.mock-label {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: var(--sp-4);
}

/* Portfolio mock */
.mock-port-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--sp-5);
  flex-wrap: wrap;
  gap: var(--sp-3);
}

.mock-balance {
  font-size: 1.8rem;
  font-weight: 900;
  letter-spacing: -.04em;
  color: var(--text);
  font-family: var(--font-mono);
}

.mock-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: var(--sp-2);
}

.mock-updated {
  font-size: .7rem;
  color: var(--text-muted);
}

.mock-assets {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--bg-border);
  border-radius: var(--r-md);
  overflow: hidden;
  margin-bottom: var(--sp-4);
}

.mock-asset {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--bg-border);
  background: var(--bg);
}

.mock-asset:last-child { border-bottom: none; }

.mock-asset-left {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.asset-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: var(--dot-color, var(--green));
  flex-shrink: 0;
}

.mock-asset-name  { font-weight: 600; font-size: .85rem; color: var(--text); }
.mock-asset-alloc { font-size: .72rem; color: var(--text-muted); }
.mock-asset-right { text-align: right; }
.mock-asset-usd   { font-weight: 700; font-family: var(--font-mono); font-size: .9rem; }
.mock-asset-pnl   { font-size: .72rem; font-weight: 600; font-family: var(--font-mono); }
.mock-asset-neutral { color: var(--text-muted); }

.mock-tax-banner {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: var(--bg-warn);
  border-radius: var(--r-md);
  font-size: .8rem;
  color: var(--warn);
  border: 1px solid rgba(217,119,6,.2);
}

.mock-tax-banner strong { color: var(--text); }

/* Security mock */
.mock-input-row {
  display: flex;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}

.mock-input {
  flex: 1;
  padding: 9px 12px;
  border: 1px solid var(--bg-border);
  border-radius: var(--r-sm);
  font-size: .75rem;
  font-family: var(--font-mono);
  color: var(--text-secondary);
  background: var(--bg);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mock-btn {
  padding: 9px 16px;
  border-radius: var(--r-sm);
  font-size: .78rem;
  font-weight: 700;
  white-space: nowrap;
  cursor: default;
}

.mock-btn--primary { background: var(--green); color: #fff; }
.mock-btn--purple  { background: var(--purple); color: #fff; }

.mock-score-row {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  padding: var(--sp-4) 0;
  margin-bottom: var(--sp-3);
  border-bottom: 1px solid var(--bg-border);
}

.mock-ring {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: 4px solid var(--green);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.mock-ring-value {
  font-size: 1rem;
  font-weight: 900;
  color: var(--green);
  font-family: var(--font-mono);
}

.mock-contract-name {
  font-weight: 700;
  font-size: .9rem;
  color: var(--text);
  margin-bottom: var(--sp-2);
}

.mock-checks {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: var(--sp-4);
}

.mock-check {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: .8rem;
  color: var(--text-secondary);
}

.mock-allowances { border-top: 1px solid var(--bg-border); padding-top: var(--sp-3); }
.mock-allowance-label {
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text-muted);
  margin-bottom: var(--sp-2);
}

.mock-allowance-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 7px 0;
  border-bottom: 1px solid var(--bg-border);
  font-size: .8rem;
}
.mock-allowance-row:last-child { border-bottom: none; }
.mock-allowance-left { display: flex; align-items: center; gap: var(--sp-2); color: var(--text-secondary); }

.mock-revoke-btn {
  font-size: .72rem;
  font-weight: 700;
  color: var(--dn);
  border: 1px solid rgba(220,38,38,.3);
  border-radius: var(--r-sm);
  padding: 3px 10px;
  cursor: default;
}

/* Bridge mock */
.mock-bridge { display: flex; flex-direction: column; gap: var(--sp-3); }
.mock-bridge-box {
  background: var(--bg);
  border: 1px solid var(--bg-border);
  border-radius: var(--r-md);
  padding: var(--sp-4);
}

.mock-bridge-token {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-top: var(--sp-2);
}

.mock-chain-badge {
  width: 36px;
  height: 36px;
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  flex-shrink: 0;
}

.mock-chain-badge--eth { background: rgba(98,126,234,.15); color: #627EEA; }
.mock-chain-badge--sol { background: rgba(153,69,255,.15); color: #9945FF; }

.mock-token-name  { font-weight: 700; font-size: .9rem; color: var(--text); }
.mock-token-chain { font-size: .72rem; color: var(--text-muted); }
.mock-bridge-amount { margin-left: auto; font-weight: 700; font-family: var(--font-mono); color: var(--text); }

.mock-bridge-arrow {
  text-align: center;
  color: var(--text-muted);
  font-size: 1.1rem;
  margin: -6px 0;
}

.mock-bridge-stats {
  display: flex;
  gap: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  background: var(--bg);
  border: 1px solid var(--bg-border);
  border-radius: var(--r-md);
}

.mock-bridge-stat { text-align: center; flex: 1; }
.mock-bridge-stat-v { font-weight: 700; font-size: .9rem; font-family: var(--font-mono); color: var(--text); }
.mock-bridge-stat-k { font-size: .68rem; color: var(--text-muted); margin-top: 2px; }

.mock-bridge-exec {
  padding: 11px;
  background: var(--green);
  color: #fff;
  border-radius: var(--r-md);
  text-align: center;
  font-weight: 700;
  font-size: .85rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
}

/* Airdrop mock */
.mock-airdrop-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3);
  margin-top: var(--sp-3);
}

.mock-airdrop-proto {
  background: var(--bg);
  border: 1px solid var(--bg-border);
  border-radius: var(--r-md);
  padding: var(--sp-3);
}

.mock-proto-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
}

.mock-proto-name { font-weight: 700; font-size: .82rem; color: var(--text); }

.mock-proto-detail {
  font-size: .72rem;
  color: var(--text-muted);
  margin-bottom: var(--sp-2);
}

.mock-progress-bar {
  height: 5px;
  background: var(--bg-muted);
  border-radius: var(--r-full);
  overflow: hidden;
  margin-bottom: 4px;
}

.mock-progress-fill {
  height: 100%;
  width: var(--fill-width, 50%);
  background: var(--fill-color, var(--green));
  border-radius: var(--r-full);
  transition: width 1s ease;
}

.mock-proto-pct { font-size: .72rem; font-weight: 600; color: var(--text-muted); }

/* Yields mock */
.mock-yields-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--sp-4);
}

.mock-yields-legend { display: flex; gap: var(--sp-2); }

.mock-yield-rows {
  display: flex;
  flex-direction: column;
  gap: 0;
  border: 1px solid var(--bg-border);
  border-radius: var(--r-md);
  overflow: hidden;
}

.mock-yield-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-3) var(--sp-4);
  border-bottom: 1px solid var(--bg-border);
  background: var(--bg);
  gap: var(--sp-3);
}

.mock-yield-row:last-child { border-bottom: none; }

.mock-yield-left { display: flex; align-items: center; gap: var(--sp-3); flex: 1; }

.mock-yield-icon {
  width: 34px;
  height: 34px;
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  font-weight: 800;
  flex-shrink: 0;
}

.mock-yield-icon--indigo { background: rgba(99,102,241,.12); color: #6366F1; }
.mock-yield-icon--green  { background: rgba(22,163,74,.10);  color: var(--green); }
.mock-yield-icon--red    { background: rgba(220,38,38,.10);  color: var(--red); }

.mock-yield-name { font-weight: 600; font-size: .85rem; color: var(--text); }
.mock-yield-desc { font-size: .72rem; color: var(--text-muted); line-height: 1.4; }

.mock-yield-right { text-align: right; }
.mock-yield-apy {
  font-size: 1rem;
  font-weight: 800;
  font-family: var(--font-mono);
  margin-bottom: 4px;
}