:root {
  --bg: #0a0a0c;
  --bg-2: #111114;
  --bg-3: #16161a;
  --ink: #d8d8d2;
  --ink-dim: #8a8a82;
  --accent: #00ff88;
  --accent-2: #ff5d2a;
  --warn: #ffcc33;
  --err: #ff3366;
  --line: #222226;
  --mono: ui-monospace, "JetBrains Mono", "Fira Code", Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }
html { scroll-padding-top: 80px; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--ink); font-family: var(--mono); font-size: 14px; line-height: 1.5; }
body {
  min-height: 100vh;
  background-image:
    radial-gradient(800px 400px at 80% -10%, rgba(0,255,136,0.06), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(255,93,42,0.05), transparent 60%);
  background-attachment: fixed;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-2); text-decoration: underline; }

.scanlines, .noise { position: fixed; inset: 0; pointer-events: none; z-index: 1000; }
.scanlines { background: repeating-linear-gradient(to bottom, rgba(255,255,255,0.025) 0 1px, transparent 1px 3px); mix-blend-mode: overlay; }
.noise {
  opacity: 0.06;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
}

.topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 22px;
  background: rgba(10,10,12,0.85);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--line);
}
.brand { display: flex; align-items: baseline; gap: 6px; color: inherit; }
.brand:hover { text-decoration: none; }
.logo { color: var(--accent); font-weight: 700; font-size: 20px; letter-spacing: 1px; }
.dot { color: var(--accent-2); font-weight: 700; }
.tld { color: var(--ink); font-weight: 700; font-size: 18px; }
.tagline { color: var(--ink-dim); margin-left: 10px; font-size: 12px; }

nav { display: flex; align-items: center; gap: 18px; font-size: 13px; }
nav a { color: var(--ink-dim); }
nav a:hover { color: var(--accent); }
.status { color: var(--ink-dim); display: inline-flex; gap: 6px; align-items: center; }
.led { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 8px var(--accent); animation: pulse 1.6s ease-in-out infinite; }
@keyframes pulse { 50% { opacity: 0.35; } }

main { max-width: 980px; margin: 0 auto; padding: 32px 22px 80px; }

.hero { padding: 28px 0 18px; border-bottom: 1px dashed var(--line); }
.hero h1 { font-size: 38px; margin: 0 0 8px; letter-spacing: -0.5px; }
.hero .sub { color: var(--ink-dim); margin: 0; max-width: 60ch; }
.glitch { position: relative; color: var(--accent-2); }
.glitch::before, .glitch::after { content: attr(data-text); position: absolute; left: 0; top: 0; width: 100%; overflow: hidden; }
.glitch::before { color: var(--accent); transform: translate(-1px,-1px); mix-blend-mode: screen; animation: g1 3s infinite linear; }
.glitch::after  { color: #2dd9ff; transform: translate(1px,1px);  mix-blend-mode: screen; animation: g2 2.4s infinite linear; }
@keyframes g1 { 0%,100%{clip-path:inset(0 0 80% 0)} 20%{clip-path:inset(40% 0 30% 0)} 40%{clip-path:inset(10% 0 60% 0)} 60%{clip-path:inset(70% 0 5% 0)} 80%{clip-path:inset(30% 0 50% 0)} }
@keyframes g2 { 0%,100%{clip-path:inset(80% 0 0 0)} 25%{clip-path:inset(20% 0 50% 0)} 50%{clip-path:inset(60% 0 20% 0)} 75%{clip-path:inset(0 0 70% 0)} }

.terminal { margin-top: 26px; background: var(--bg-2); border: 1px solid var(--line); border-radius: 6px; overflow: hidden; box-shadow: 0 0 0 1px rgba(0,255,136,0.04), 0 20px 60px rgba(0,0,0,0.5); }
.term-head { display: flex; align-items: center; gap: 8px; padding: 8px 12px; background: #0c0c10; border-bottom: 1px solid var(--line); color: var(--ink-dim); font-size: 12px; }
.term-head .dot { width: 10px; height: 10px; border-radius: 50%; background: #444; display: inline-block; }
.term-head .dot.red { background: #ff5f56; } .term-head .dot.yel { background: #ffbd2e; } .term-head .dot.grn { background: #27c93f; }
.term-title { margin-left: 6px; }
.status-chip { margin-left: auto; padding: 3px 8px; background: rgba(0,255,136,0.1); border: 1px solid var(--accent); color: var(--accent); border-radius: 3px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; }

.quoter { padding: 18px; display: grid; gap: 14px; }
.row { display: flex; gap: 12px; align-items: end; flex-wrap: wrap; }
label { display: flex; flex-direction: column; gap: 6px; flex: 1; min-width: 220px; color: var(--ink-dim); font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; }
.combo { display: flex; gap: 0; border: 1px solid var(--line); border-radius: 4px; background: var(--bg-3); min-width: 0; }
.combo input, .combo select { background: transparent; border: 0; color: var(--ink); font-family: var(--mono); font-size: 16px; padding: 12px 12px; outline: none; }
.combo input { flex: 1 1 auto; width: 100%; min-width: 0; }
.combo select { border-left: 1px solid var(--line); flex: 0 0 auto; min-width: 170px; max-width: none; cursor: pointer; }
.combo input:focus, .combo select:focus { background: rgba(0,255,136,0.04); }
/* kill the +/- spinner on number inputs */
.combo input[type="number"] { -moz-appearance: textfield; appearance: textfield; }
.combo input[type="number"]::-webkit-outer-spin-button,
.combo input[type="number"]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

#swap-dir { flex: 0 0 auto; align-self: flex-end; background: var(--bg-3); color: var(--accent); border: 1px solid var(--line); border-radius: 4px; padding: 0 14px; height: 46px; font-family: var(--mono); cursor: pointer; font-size: 18px; line-height: 1; text-transform: none; letter-spacing: 0; }
#swap-dir:hover { color: var(--accent-2); border-color: var(--accent-2); background: var(--bg-3); box-shadow: none; }

.controls { justify-content: space-between; align-items: center; }

.sort-group { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; flex: 0 0 auto; }
.sort-label { color: var(--ink-dim); font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; }
.pill { padding: 0; flex: 0 0 auto; min-width: 0; width: auto; text-transform: none; letter-spacing: 0; margin: 0; }
.pill input { position: absolute; opacity: 0; pointer-events: none; }
.pill span { display: inline-block; padding: 6px 14px; border: 1px solid var(--line); border-radius: 3px; color: var(--ink-dim); font-size: 13px; cursor: pointer; background: var(--bg-3); white-space: nowrap; line-height: 1.4; }
.pill input:checked + span { border-color: var(--accent); color: var(--accent); background: rgba(0,255,136,0.06); }
.pill span:hover { color: var(--ink); }

button, .btn { background: linear-gradient(180deg, #0d2a1c, #0a1a13); color: var(--accent); border: 1px solid var(--accent); font-family: var(--mono); font-size: 14px; padding: 12px 18px; border-radius: 4px; cursor: pointer; text-transform: uppercase; letter-spacing: 0.08em; transition: all 0.15s ease; }
button:hover, .btn:hover { background: var(--accent); color: #000; box-shadow: 0 0 18px rgba(0,255,136,0.4); text-decoration: none; }
button:active { transform: translateY(1px); }

.results { margin-top: 22px; display: grid; gap: 8px; }
.result { display: grid; grid-template-columns: 1fr auto auto; gap: 14px; align-items: center; padding: 14px 16px; background: var(--bg-2); border: 1px solid var(--line); border-radius: 4px; transition: border-color 0.15s ease, background 0.15s ease; }
.result:hover { border-color: var(--accent); background: #131318; }
.result.best { border-color: var(--accent); box-shadow: 0 0 0 1px var(--accent) inset; }
.result .name { display: flex; flex-direction: column; gap: 2px; }
.result .name b { color: var(--ink); font-weight: 600; }
.result .name small { color: var(--ink-dim); font-size: 11px; }
.result .rate { font-size: 16px; color: var(--accent); text-align: right; }
.result .rate small { display: block; color: var(--ink-dim); font-size: 11px; }
.result .cta { padding: 9px 14px; font-size: 12px; }
.result .badge { display: inline-block; font-size: 10px; padding: 2px 6px; border-radius: 3px; background: var(--accent); color: #000; margin-left: 6px; vertical-align: middle; letter-spacing: 0.1em; }
.result.disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; filter: grayscale(0.8); display: block; padding: 10px 16px; }
.result.disabled:hover { border-color: var(--line); background: var(--bg-2); }
.result .badge-disabled { background: #555; color: #ccc; }
.disabled-line { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; justify-content: flex-start; text-align: left; }
.disabled-line b { color: var(--ink); font-weight: 600; }
.disabled-line small { color: var(--ink-dim); font-size: 11px; }
.kyc-score { display: inline-flex; align-items: center; gap: 4px; font-size: 10px; padding: 2px 6px; border-radius: 3px; border: 1px solid var(--line); color: var(--ink-dim); margin-left: 6px; letter-spacing: 0.04em; cursor: help; }
.kyc-score .kyc-icon { width: 11px; height: 11px; flex: 0 0 auto; }
.kyc-score.k1 { color: var(--accent); border-color: var(--accent); background: rgba(0,255,136,0.06); }
.kyc-score.k2 { color: var(--warn); border-color: var(--warn); background: rgba(255,204,51,0.06); }
.kyc-score.k3 { color: var(--accent-2); border-color: var(--accent-2); background: rgba(255,93,42,0.06); }

.card-head { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.card-head .kyc-score { margin-left: 0; }

.muted { color: var(--ink-dim); font-size: 12px; font-weight: normal; text-transform: none; letter-spacing: 0; }

.results-wrap { margin-top: 26px; }
.results-wrap .results { margin-top: 14px; }
.picked-line { color: var(--ink-dim); font-size: 13px; padding: 6px 12px; border-left: 2px solid var(--accent); background: rgba(0,255,136,0.04); border-radius: 0 3px 3px 0; }
.picked-line b { color: var(--ink); }

/* When the user is picking a route, hide everything beneath the quotes to focus the eye. */
#app.quote-mode #privacy,
#app.quote-mode #partners,
#app.quote-mode #about,
#app.quote-mode #faq { display: none; }

/* Refund address only appears once the user has picked a route. */
#refund-block { display: none; }
#app.quote-mode #refund-block { display: flex; }

.result.selectable { cursor: pointer; grid-template-columns: auto 1fr auto; }
.result.selectable:hover { border-color: var(--accent); background: #131318; }
.result.selectable .pick { display: flex; align-items: center; }
.dot-outer { display: inline-block; width: 16px; height: 16px; border-radius: 50%; border: 1px solid var(--line); background: var(--bg); position: relative; }
.dot-inner { position: absolute; inset: 3px; border-radius: 50%; background: transparent; transition: background 0.12s ease; }
.result.picked { border-color: var(--accent); background: rgba(0,255,136,0.05); box-shadow: 0 0 0 1px var(--accent) inset; }
/* once anything is picked, suppress the "best" outline on rows that aren't the pick */
.results:has(.picked) .result.best:not(.picked) { border-color: var(--line); box-shadow: none; background: var(--bg-2); }
.result.picked .dot-outer { border-color: var(--accent); }
.result.picked .dot-inner { background: var(--accent); box-shadow: 0 0 8px var(--accent); }
.result.selectable:focus { outline: none; border-color: var(--accent); }

.form-err { color: var(--err); border-left: 2px solid var(--err); padding: 6px 12px; background: rgba(255,51,102,0.06); font-size: 13px; }

.trade-ids { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; }
.provider-id { color: var(--accent); }

.tos h2 { margin-top: 28px; }
.tos p { color: var(--ink-dim); max-width: 70ch; }
.tos .fineprint-top { margin-top: 24px; }

.privacy { margin-top: 56px; }
.privacy .panel { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 12px; margin-top: 14px; }
.privacy .tile { padding: 16px; background: var(--bg-2); border: 1px solid var(--line); border-radius: 4px; }
.privacy .tile b { color: var(--accent); display: block; margin-bottom: 4px; }
.privacy .tile small { color: var(--ink-dim); font-size: 12px; }
.privacy .lede { color: var(--ink); border-left: 2px solid var(--accent); padding: 6px 14px; background: rgba(0,255,136,0.04); margin-top: 14px; }

.mt-offset { margin-top: 40px; }

.recent { margin-top: 40px; }
.recent #recent-list { display: grid; gap: 8px; margin-top: 14px; }
.recent-row { display: grid; grid-template-columns: 1fr auto; gap: 6px 14px; padding: 12px 14px; background: var(--bg-2); border: 1px solid var(--line); border-radius: 4px; color: var(--ink); }
.recent-row:hover { border-color: var(--accent); text-decoration: none; background: #131318; }
.recent-pair { font-size: 14px; color: var(--ink); }
.recent-meta { color: var(--ink-dim); font-size: 11px; grid-column: 1; }
.recent-id { color: var(--accent); font-size: 11px; grid-column: 2; grid-row: span 2; align-self: center; overflow-wrap: anywhere; max-width: 280px; text-align: right; background: transparent; padding: 0; }

.empty { color: var(--ink-dim); padding: 18px; text-align: center; border: 1px dashed var(--line); border-radius: 4px; }

.exchanges, .about, .faq { margin-top: 56px; }
h2 { font-size: 18px; color: var(--ink); letter-spacing: 0.04em; border-bottom: 1px dashed var(--line); padding-bottom: 8px; }
.grid { display: grid; gap: 10px; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); margin-top: 14px; }
.card { background: var(--bg-2); border: 1px solid var(--line); border-radius: 4px; padding: 14px; display: flex; flex-direction: column; gap: 4px; }
.card b { color: var(--accent); }
.card small { color: var(--ink-dim); font-size: 11px; }
.card a { margin-top: 6px; font-size: 12px; }

.partner-card { flex-direction: row; align-items: center; gap: 14px; }
.partner-logo { flex: 0 0 auto; width: 42px; height: 42px; border-radius: 6px; background: var(--bg-3); border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; overflow: hidden; }
.partner-logo img { width: 32px; height: 32px; object-fit: contain; display: block; }
.partner-mono { font-size: 14px; font-weight: 700; color: var(--accent); letter-spacing: 0.04em; }
.partner-meta { display: flex; flex-direction: column; gap: 2px; min-width: 0; flex: 1; }
.partner-meta b { color: var(--ink); }
.partner-meta a { margin-top: 4px; }

.about p, .faq p { color: var(--ink-dim); }
.about .warn { color: var(--warn); border-left: 2px solid var(--warn); padding: 4px 12px; background: rgba(255,204,51,0.04); }
.faq details { padding: 10px 0; border-bottom: 1px solid var(--line); }
.faq summary { cursor: pointer; color: var(--ink); }
.faq summary:hover { color: var(--accent); }

/* --- trade page --- */
.trade-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; gap: 14px; flex-wrap: wrap; }
.trade-provider { display: inline-flex; align-items: center; gap: 8px; color: var(--ink); font-family: var(--mono); font-size: 13px; padding: 6px 12px; border: 1px solid var(--line); border-radius: 4px; background: var(--bg-3); }
.trade-provider img { border-radius: 4px; }
#countdown.low { color: #ffbd2e; }
#countdown.expired { color: #ff5f56; }
.back { color: var(--ink-dim); font-size: 13px; }
.back:hover { color: var(--accent); }
.trade-id { color: var(--ink-dim); font-size: 12px; font-family: var(--mono); }

.trade-card .trade-body { padding: 22px; display: grid; gap: 22px; }

.trade-summary { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 16px; border: 1px solid var(--line); border-radius: 4px; background: var(--bg-3); }
.trade-summary .leg { display: flex; flex-direction: column; gap: 2px; flex: 1; }
.trade-summary .leg span { color: var(--ink-dim); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; }
.trade-summary .leg b { color: var(--ink); font-size: 20px; word-break: break-all; }
.trade-summary .leg small { color: var(--ink-dim); font-size: 11px; }
.trade-summary .arrow { color: var(--accent); font-size: 24px; }

.steps { display: grid; gap: 6px; }
.step { display: flex; gap: 10px; align-items: center; color: var(--ink-dim); font-size: 13px; padding: 6px 0; }
.step .bullet { width: 10px; height: 10px; border-radius: 50%; background: var(--bg-3); border: 1px solid var(--line); flex: 0 0 auto; }
.step.done { color: var(--ink); }
.step.done .bullet { background: var(--accent); border-color: var(--accent); }
.step.active { color: var(--accent); }
.step.active .bullet { background: var(--accent); border-color: var(--accent); box-shadow: 0 0 10px var(--accent); animation: pulse 1.6s ease-in-out infinite; }

.dep-block { padding: 16px; border: 1px solid var(--line); border-radius: 4px; background: var(--bg-3); display: grid; gap: 8px; }
.dep-grid { display: grid; grid-template-columns: 1fr auto; gap: 18px; align-items: center; }
.dep-info { display: grid; gap: 8px; min-width: 0; }
.dep-qr { display: flex; align-items: center; justify-content: center; }
.dep-qr img { width: 180px; height: 180px; border-radius: 4px; background: #fff; padding: 6px; display: block; }
@media (max-width: 640px) {
  .dep-grid { grid-template-columns: 1fr; }
  .dep-qr { justify-content: flex-start; }
  .dep-qr img { width: 160px; height: 160px; }
}
.dep-label { color: var(--ink-dim); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; }
.dep-amount { color: var(--accent); font-size: 22px; }
.dep-addr { display: flex; gap: 8px; align-items: center; }
.dep-addr code { flex: 1; background: var(--bg); padding: 10px 12px; border-radius: 3px; border: 1px solid var(--line); overflow-wrap: anywhere; font-size: 13px; color: var(--ink); }
.copy { padding: 8px 12px; font-size: 11px; }
.dep-meta { display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap; color: var(--ink-dim); font-size: 12px; margin-top: 4px; }
.dep-meta code { color: var(--ink); background: var(--bg); padding: 1px 6px; border-radius: 2px; overflow-wrap: anywhere; }
.demo-bar { margin-top: 10px; padding: 10px 12px; border: 1px dashed var(--line); border-radius: 4px; display: flex; justify-content: space-between; gap: 12px; align-items: center; flex-wrap: wrap; }
.demo-bar small { color: var(--warn); font-size: 11px; }
.demo-bar button { padding: 8px 12px; font-size: 11px; }

/* phase visibility — only the phase matching current status is shown */
.phase { display: none; }
.trade-body.status-awaiting .phase-awaiting,
.trade-body.status-confirming .phase-confirming,
.trade-body.status-exchanging .phase-exchanging,
.trade-body.status-sending .phase-sending,
.trade-body.status-completed .phase-completed { display: flex; }
.phase-awaiting { display: grid !important; }
.trade-body:not(.status-awaiting) .phase-awaiting { display: none !important; }

/* progress phases */
.progress-block { padding: 22px; gap: 18px; border: 1px solid var(--line); border-radius: 4px; background: var(--bg-3); align-items: center; }
.progress-block h3 { margin: 0 0 4px; color: var(--ink); font-size: 16px; }
.progress-block p { margin: 0 0 6px; color: var(--ink-dim); }
.progress-block small { color: var(--ink-dim); font-size: 11px; }
.progress-block code { color: var(--ink); background: var(--bg); padding: 1px 6px; border-radius: 2px; overflow-wrap: anywhere; }

.spinner { width: 36px; height: 36px; flex: 0 0 auto; border-radius: 50%; border: 3px solid rgba(0,255,136,0.15); border-top-color: var(--accent); animation: spin 0.9s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* completed */
.success-block { flex-direction: column; align-items: center; text-align: center; padding: 32px 22px; border: 1px solid var(--accent); border-radius: 4px; background: rgba(0,255,136,0.04); gap: 8px; }
.success-block .checkmark { color: var(--accent); animation: pop 0.35s cubic-bezier(.2,1.4,.4,1); }
@keyframes pop { from { transform: scale(0.4); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.success-block h3 { margin: 6px 0 4px; color: var(--accent); letter-spacing: 0.04em; font-size: 18px; text-transform: uppercase; }
.success-amt { color: var(--ink); font-size: 22px; margin: 6px 0; }
.success-detail { color: var(--ink-dim); font-size: 12px; margin: 2px 0; }
.success-detail code { color: var(--ink); background: var(--bg); padding: 1px 6px; border-radius: 2px; overflow-wrap: anywhere; }
.success-block .btn { margin-top: 14px; }

/* status chip colors per phase */
.trade-body.status-completed ~ * .status-chip,
.term-head .status-chip { transition: all 0.2s ease; }
.status-chip.completed { background: var(--accent); color: #000; border-color: var(--accent); }
.status-chip.confirming, .status-chip.exchanging, .status-chip.sending { background: rgba(255,204,51,0.1); color: var(--warn); border-color: var(--warn); }

.trade-meta { margin-top: 18px; }
.trade-meta details { padding: 10px 0; }
.trade-meta summary { cursor: pointer; color: var(--ink-dim); font-size: 12px; }
.trade-meta pre { background: var(--bg-2); border: 1px solid var(--line); border-radius: 4px; padding: 12px; overflow: auto; font-size: 12px; color: var(--ink); }

.summary-line { padding: 12px 14px; background: var(--bg-3); border: 1px solid var(--line); border-radius: 4px; color: var(--ink-dim); font-size: 13px; }
.summary-line b { color: var(--ink); }
.summary-line .ex { color: var(--accent); }

footer { border-top: 1px dashed var(--line); padding: 32px 22px; max-width: 980px; margin: 40px auto 0; color: var(--ink-dim); }
.cols { display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.fineprint { font-size: 12px; max-width: 50ch; margin: 8px 0 0; }
.links { display: flex; gap: 14px; }
.bottom { display: flex; justify-content: space-between; margin-top: 22px; font-size: 12px; opacity: 0.7; }

@media (max-width: 760px) {
  .topbar { padding: 12px 16px; flex-wrap: wrap; gap: 10px; }
  .tagline { display: none; }
  nav { gap: 12px; flex-wrap: wrap; }
  .status { display: none; }
  main { padding: 22px 16px 60px; }
  .hero h1 { font-size: 28px; }
  .hero .sub { font-size: 13px; }
  .quoter { padding: 14px; gap: 12px; }
  .row { flex-direction: column; align-items: stretch; gap: 12px; }
  label { min-width: 0; }
  #swap-dir { align-self: center; transform: rotate(90deg); height: 38px; padding: 0 12px; }
  .controls { flex-direction: column; align-items: stretch; gap: 12px; }
  .sort-group { justify-content: flex-start; }
  .result.selectable { grid-template-columns: auto 1fr; gap: 10px; }
  .result .rate { grid-column: 2; text-align: left; }
  .result .pick { grid-row: span 2; }
  .trade-summary { flex-direction: column; align-items: stretch; }
  .trade-summary .arrow { transform: rotate(90deg); align-self: center; }
  .progress-block { flex-direction: column; text-align: center; }
  .dep-meta { flex-direction: column; gap: 6px; }
  .demo-bar { flex-direction: column; align-items: stretch; text-align: left; }
  .privacy .panel { grid-template-columns: 1fr; }
  .grid { grid-template-columns: 1fr; }
  footer { padding: 22px 16px; }
  .cols { flex-direction: column; gap: 14px; }
  .bottom { flex-direction: column; gap: 6px; }
}

@media (max-width: 420px) {
  .combo input, .combo select { font-size: 15px; padding: 10px 10px; }
  .combo select { min-width: 140px; }
  .hero h1 { font-size: 24px; }
  h2 { font-size: 16px; }
}

.coin-icon { vertical-align: middle; margin-right: 6px; border-radius: 50%; }

/* custom coin picker */
.combo { position: relative; }
.hidden-select { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; clip: rect(0 0 0 0); }
.coin-picker {
  display: inline-flex; align-items: center; gap: 8px;
  background: transparent; border: 0; border-left: 1px solid var(--line);
  color: var(--ink); font-family: var(--mono); font-size: 16px;
  padding: 12px 14px; cursor: pointer; min-width: 170px;
  outline: none;
}
.coin-picker:hover, .coin-picker[aria-expanded="true"] { background: rgba(0,255,136,0.04); }
.coin-picker .picker-icon { width: 20px; height: 20px; border-radius: 50%; flex-shrink: 0; }
.coin-picker .picker-text { flex: 1 1 auto; text-align: left; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.coin-picker .picker-caret { opacity: 0.6; font-size: 12px; }
.coin-pop {
  position: fixed;
  min-width: 220px; max-height: 320px; overflow-y: auto;
  background: var(--bg-3); border: 1px solid var(--line); border-radius: 4px;
  z-index: 1000; box-shadow: 0 4px 20px rgba(0,0,0,0.6);
}
.coin-opt { display: flex; align-items: center; gap: 10px; padding: 8px 12px; cursor: pointer; font-family: var(--mono); font-size: 14px; color: var(--ink); outline: none; }
.coin-opt:hover, .coin-opt:focus { background: rgba(0,255,136,0.08); }
.coin-opt img { width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0; }
@media (max-width: 420px) {
  .coin-picker { min-width: 140px; padding: 10px 10px; font-size: 15px; }
}
.rate-amt { display: inline-flex; align-items: center; gap: 6px; }
#send-amt, #recv-amt { display: inline-flex; align-items: center; gap: 6px; }
