/* vantage.css — HTMX+Alpine app — R5B "The Warmth" */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

/* ── Tokens ─────────────────────────────────────── */
:root {
  --bg:            #080705;
  --surface:       #0e0c09;
  --elevated:      #141108;
  --border:        #201c14;
  --border-mid:    #2a2418;
  --accent:        #c07828;
  --accent-soft:   #3a2808;
  --accent-hover:  #d4893a;
  --text-primary:  #eae4d8;
  --text-soft:     #8a8070;
  --text-muted:    #5a5040;
  --text-dim:      #302818;
  --status-on:     #3a9e5f;
  --status-warn:   #c07a20;
  --profit:        #2dcc6f;
  --loss:          #d44040;
  --font-sans:     'Inter', system-ui, sans-serif;
  --font-mono:     'JetBrains Mono', 'Fira Code', monospace;
  --font-serif:    'Cormorant Garamond', Georgia, serif;
  --r:             2px;
  --r-input:       22px;
  --shadow:        0 2px 12px rgba(0,0,0,.5);
  --t:             140ms ease;
}

/* ── Reset ──────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-font-smoothing:antialiased; }
body { font-family:var(--font-sans); font-size:13px; line-height:1.55; background:var(--bg); color:var(--text-primary); }
a    { color:inherit; text-decoration:none; }
input,button,select,textarea { font-family:inherit; }
::selection { background:rgba(192,120,40,.25); color:var(--text-primary); }

/* ── Scrollbar ──────────────────────────────────── */
::-webkit-scrollbar       { width:3px; height:3px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--accent); border-radius:2px; }
* { scrollbar-width:thin; scrollbar-color:var(--accent) var(--bg); }

/* ── App shell ──────────────────────────────────── */
html, body { height:100%; overflow:hidden; }
.app-shell { display:flex; flex-direction:column; height:100vh; }

/* ── Top bar ────────────────────────────────────── */
.topbar {
  display:flex; align-items:stretch; height:46px;
  background:var(--surface); border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.topbar-brand {
  display:flex; flex-direction:column; justify-content:center;
  padding:0 18px; border-right:1px solid var(--border); min-width:160px; gap:5px;
}
.topbar-wordmark {
  font-family:var(--font-serif); font-weight:700; font-size:22px;
  letter-spacing:.06em; color:var(--text-primary); line-height:1;
}
.topbar-domain {
  font-family:var(--font-sans); font-weight:700; font-size:11px;
  letter-spacing:.2em; color:var(--accent); text-transform:uppercase;
}
.topbar-nav { display:flex; align-items:stretch; border-right:1px solid var(--border); }
.topbar-nav a {
  display:flex; align-items:center; position:relative;
  padding:0 18px; border-right:1px solid var(--border);
  font-size:11px; font-weight:500; color:var(--text-soft);
  transition:color var(--t), background var(--t);
  white-space:nowrap;
}
.topbar-nav a:hover   { background:rgba(20,17,8,.6); color:var(--text-primary); }
.topbar-nav a.active  { background:var(--elevated); color:var(--text-primary); }
.topbar-nav a.active::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px; background:var(--accent);
}
.topbar-status {
  flex:1; display:flex; align-items:center; justify-content:flex-end;
  gap:14px; padding:0 18px;
}
.notif-badge {
  display:inline-flex; align-items:center; justify-content:center;
  width:14px; height:14px; border-radius:50%;
  background:var(--accent); color:var(--bg);
  font-size:8px; font-weight:700; margin-left:4px;
}
.bridge-pip {
  display:inline-block; width:5px; height:5px; border-radius:50%;
  flex-shrink:0;
}
.tier-badge {
  font-family:var(--font-mono); font-size:9px; letter-spacing:.06em;
  padding:2px 7px; border-radius:var(--r);
  background:var(--accent-soft); color:var(--accent);
}
.topbar-sep { width:1px; height:14px; background:var(--border); }
.topbar-clock { font-family:var(--font-mono); font-size:9px; color:var(--text-muted); }

/* ── Grace banner ───────────────────────────────── */
.grace-banner {
  background:var(--accent-soft); border-bottom:1px solid rgba(192,120,40,.3);
  padding:7px 18px; display:flex; align-items:center; gap:10px;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--accent); cursor:pointer;
  flex-shrink:0;
}
.grace-banner:hover { background:rgba(58,40,8,.7); }

/* ── App content ────────────────────────────────── */
.app-content { flex:1; display:flex; overflow:hidden; }

/* ── Sidebar (chat left rail) ───────────────────── */
.sidebar {
  width:220px; border-right:1px solid var(--border);
  background:var(--surface); display:flex; flex-direction:column; flex-shrink:0;
}
.sidebar-head, .rail-head {
  padding:10px 14px 8px; border-bottom:1px solid var(--border);
}
.sidebar-item {
  padding:9px 14px; border-bottom:1px solid var(--border);
  cursor:pointer; border-left:3px solid transparent;
  transition:background var(--t);
}
.sidebar-item.active { background:var(--elevated); border-left-color:var(--accent); }
.sidebar-item:hover:not(.active) { background:rgba(20,17,8,.4); }
.sidebar-add { padding:9px 14px; font-size:10px; cursor:pointer; color:var(--accent); }
.sidebar-add:hover { text-decoration:underline; }

/* ── Chat thread ────────────────────────────────── */
.chat-main  { flex:1; display:flex; flex-direction:column; overflow:hidden; }
.chat-header {
  padding:0 20px; height:36px; border-bottom:1px solid var(--border);
  background:var(--surface); display:flex; align-items:center; gap:10px; flex-shrink:0;
}
.chat-messages { flex:1; overflow-y:auto; padding:18px 20px; display:flex; flex-direction:column; gap:12px; }
.msg-row { display:grid; grid-template-columns:44px 1fr; gap:0 10px; }
.msg-role { text-align:right; padding-top:2px; font-family:var(--font-mono); font-size:9px; }
.msg-role.desk   { color:var(--accent); }
.msg-role.user   { color:var(--text-soft); }
.msg-role.system { color:var(--loss); }
.msg-body p  { font-size:13px; line-height:1.65; margin:0 0 3px; }
.msg-body.system p { color:var(--loss); }
.msg-ts  { font-family:var(--font-mono); font-size:8px; color:var(--text-dim); }
.wire    {
  font-family:var(--font-mono); font-size:8.5px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--text-dim); text-align:center;
  padding:4px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  margin:4px 0;
}
.rate-banner {
  padding:8px 20px; background:rgba(212,64,64,.08);
  border-top:1px solid rgba(212,64,64,.15);
  font-family:var(--font-mono); font-size:11px; color:var(--loss); flex-shrink:0;
}
.input-bar {
  border-top:1px solid var(--border); padding:10px 20px;
  background:var(--surface); display:flex; align-items:center; gap:10px; flex-shrink:0;
}
.input-slash { font-family:var(--font-mono); font-size:11px; color:var(--text-dim); flex-shrink:0; }
.input-pill {
  flex:1; display:flex; align-items:center;
  background:var(--elevated); border:1px solid var(--border-mid);
  border-radius:var(--r-input); padding:10px 18px;
}
.input-pill input {
  flex:1; background:transparent; border:none; outline:none;
  font-size:13px; color:var(--text-primary);
}
.input-pill input::placeholder { color:var(--text-dim); }
.send-btn {
  width:28px; height:28px; border-radius:50%; border:none;
  background:var(--accent); color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  transition:opacity var(--t);
}
.send-btn:hover   { opacity:.85; }
.send-btn:disabled { opacity:.3; cursor:not-allowed; }

/* ── Right rail ─────────────────────────────────── */
.rail {
  width:240px; border-left:1px solid var(--border);
  background:var(--surface); display:flex; flex-direction:column; flex-shrink:0; overflow-y:auto;
}
.rail-section { padding:14px; border-bottom:1px solid var(--border); }
.pos-row { padding:8px 14px; border-bottom:1px solid var(--border); }
.pos-total { padding:8px 14px; background:var(--elevated); }

/* ── Page content (non-chat pages) ─────────────── */
.page { flex:1; overflow-y:auto; }
.page-inner { padding:24px; max-width:1100px; margin:0 auto; }
.page-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:24px; }
.page-title  { font-size:18px; font-weight:600; color:var(--text-primary); letter-spacing:-.02em; }
.page-sub    { font-family:var(--font-mono); font-size:10px; color:var(--text-muted); margin-top:2px; }

/* ── Cards ──────────────────────────────────────── */
.card { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); overflow:hidden; }
.card-head {
  padding:10px 14px; border-bottom:1px solid var(--border);
  background:var(--elevated); display:flex; justify-content:space-between; align-items:center;
}
.card-body { padding:14px; }

/* ── Grid ───────────────────────────────────────── */
.g2 { display:grid; grid-template-columns:1fr 1fr;      gap:16px; }
.g3 { display:grid; grid-template-columns:1fr 1fr 1fr;  gap:16px; }
.g4 { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }

/* ── Stat cell ──────────────────────────────────── */
.stat { background:var(--surface); border:1px solid var(--border); border-radius:var(--r); padding:12px 14px; }
.stat-label { font-family:var(--font-mono); font-size:8px; letter-spacing:.1em; text-transform:uppercase; color:var(--text-muted); margin-bottom:6px; }
.stat-value { font-family:var(--font-mono); font-size:16px; color:var(--text-primary); }

/* ── Table ──────────────────────────────────────── */
.tbl { width:100%; border-collapse:collapse; }
.tbl-head th { padding:6px 14px; font-family:var(--font-mono); font-size:7.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--text-muted); text-align:left; border-bottom:1px solid var(--border); }
.tbl-body td { padding:8px 14px; font-family:var(--font-mono); font-size:10px; border-bottom:1px solid var(--border); vertical-align:middle; }
.tbl-body tr:nth-child(even) td { background:var(--elevated); }
.tbl-body tr:last-child td { border-bottom:none; }
.tbl-foot td { padding:8px 14px; background:var(--elevated); font-family:var(--font-mono); font-size:10px; }

/* ── Forms ──────────────────────────────────────── */
.field { display:flex; flex-direction:column; gap:6px; }
.field label { font-family:var(--font-mono); font-size:10px; text-transform:uppercase; letter-spacing:.08em; color:var(--text-muted); }
.field input, .field textarea, .field select {
  background:var(--elevated); border:1px solid var(--border-mid); border-radius:var(--r);
  color:var(--text-primary); font-family:var(--font-mono); font-size:12px;
  padding:9px 12px; outline:none; transition:border-color var(--t); width:100%;
}
.field input:focus, .field textarea:focus { border-color:var(--accent); box-shadow:0 0 0 2px rgba(192,120,40,.12); }
.field input::placeholder { color:var(--text-dim); }
.field input[type=password] { letter-spacing:.1em; }

/* ── Buttons ────────────────────────────────────── */
.btn {
  font-family:var(--font-mono); font-size:10px; font-weight:500; letter-spacing:.06em;
  padding:8px 16px; border-radius:var(--r); cursor:pointer;
  border:1px solid var(--border-mid); background:var(--elevated); color:var(--text-soft);
  transition:all var(--t); white-space:nowrap; display:inline-flex; align-items:center; gap:6px;
}
.btn:hover    { border-color:var(--text-muted); color:var(--text-primary); }
.btn:disabled { opacity:.3; cursor:not-allowed; }
.btn-primary  { background:var(--accent); color:var(--bg); border-color:var(--accent); font-weight:700; }
.btn-primary:hover { background:var(--accent-hover); border-color:var(--accent-hover); }
.btn-danger   { background:rgba(212,64,64,.1); color:var(--loss); border-color:rgba(212,64,64,.3); }
.btn-danger:hover { background:rgba(212,64,64,.2); }
.btn-sm       { font-size:9px; padding:4px 10px; }
.btn-ghost    { background:transparent; border-color:transparent; }
.btn-ghost:hover { background:var(--elevated); border-color:var(--border-mid); }

/* ── Inline labels ──────────────────────────────── */
.cap {
  font-family:var(--font-mono); font-size:8px; font-weight:700;
  letter-spacing:.16em; text-transform:uppercase; color:var(--text-muted);
}
.pip { display:inline-block; width:5px; height:5px; border-radius:50%; flex-shrink:0; }

/* ── Badges ─────────────────────────────────────── */
.badge-on   { color:var(--status-on); }
.badge-warn { color:var(--status-warn); }
.badge-loss { color:var(--loss); }
.badge-profit { color:var(--profit); }
.badge-buy  { color:var(--accent); font-weight:700; letter-spacing:.08em; }
.badge-sell { color:var(--loss);   font-weight:700; letter-spacing:.08em; }

/* ── Progress bar ───────────────────────────────── */
.progress-wrap { height:3px; background:var(--border); border-radius:2px; overflow:hidden; margin-top:6px; }
.progress-fill { height:100%; border-radius:2px; transition:width 600ms ease; }

/* ── Alert / info boxes ─────────────────────────── */
.alert       { padding:10px 14px; border-radius:var(--r); border:1px solid; font-family:var(--font-mono); font-size:11px; line-height:1.55; }
.alert-warn  { background:var(--accent-soft); border-color:rgba(192,120,40,.3); color:var(--accent); }
.alert-loss  { background:rgba(212,64,64,.08); border-color:rgba(212,64,64,.25); color:var(--loss); }
.alert-on    { background:rgba(58,158,95,.08); border-color:rgba(58,158,95,.25); color:var(--status-on); }

/* ── Step progress ──────────────────────────────── */
.step-bar { display:flex; gap:6px; }
.step-seg { height:3px; width:32px; border-radius:1px; background:var(--border); transition:background var(--t); }
.step-seg.done { background:var(--accent); }

/* ── Onboarding / centered pages ────────────────── */
.center-page { flex:1; display:flex; align-items:center; justify-content:center; padding:40px 20px; }
.form-card   { width:100%; max-width:480px; background:var(--surface); border:1px solid var(--border); border-radius:var(--r); padding:32px; }

/* ── Settings tabs ──────────────────────────────── */
.stab-bar { display:flex; gap:0; border-bottom:1px solid var(--border); margin-bottom:24px; }
.stab     { padding:10px 18px; font-size:12px; font-weight:500; color:var(--text-muted); border-bottom:2px solid transparent; cursor:pointer; transition:all var(--t); background:transparent; border-top:none; border-left:none; border-right:none; }
.stab:hover   { color:var(--text-primary); }
.stab.active  { color:var(--text-primary); border-bottom-color:var(--accent); }

/* ── Grace page ─────────────────────────────────── */
.grace-card  { position:relative; overflow:hidden; }
.grace-top   { position:absolute; top:0; left:0; right:0; height:3px; background:var(--status-warn); }
.grace-timer { font-family:var(--font-mono); font-size:48px; font-weight:700; color:var(--text-primary); text-align:center; letter-spacing:.04em; }
.check-row   { display:flex; align-items:center; gap:10px; padding:8px 0; }
.check-dashed{ flex:1; border-bottom:1px dashed var(--border); }

/* ── Toggle checkbox ────────────────────────────── */
.toggle-row  { display:flex; align-items:flex-start; gap:12px; cursor:pointer; padding:6px 0; }
.toggle-box  { width:16px; height:16px; border:1px solid var(--border-mid); border-radius:var(--r); display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:2px; transition:all var(--t); }
.toggle-box.on { background:var(--accent); border-color:var(--accent); }
.toggle-inner { width:8px; height:8px; background:#fff; border-radius:1px; }

/* ── Pair code display ──────────────────────────── */
.pair-code-display { font-family:var(--font-mono); font-size:36px; font-weight:700; letter-spacing:.3em; color:var(--accent); text-align:center; padding:20px; }

/* ── BUY/SELL direction toggle ──────────────────── */
.dir-toggle { display:flex; gap:8px; }
.dir-btn {
  flex:1; padding:8px; font-family:var(--font-mono); font-size:11px; font-weight:700;
  border-radius:var(--r); cursor:pointer; transition:all var(--t); border:1px solid var(--border);
  background:var(--elevated); color:var(--text-muted);
}
.dir-btn.active-buy  { background:var(--accent); color:var(--bg); border-color:var(--accent); }
.dir-btn.active-sell { background:var(--loss);   color:#fff; border-color:var(--loss); }

/* ── Paper balance large ────────────────────────── */
.big-balance { font-family:var(--font-mono); font-size:22px; color:var(--text-primary); }

/* ── Score large ────────────────────────────────── */
.score-big { font-family:var(--font-mono); font-size:48px; font-weight:500; line-height:1; color:var(--text-primary); }

/* ── Token row (settings bridge) ────────────────── */
.token-row { display:flex; align-items:center; justify-content:space-between; padding:12px 14px; background:var(--elevated); border:1px solid var(--border-mid); border-radius:var(--r); }

/* ── Public top bar ─────────────────────────────── */
.pub-bar {
  position:fixed; top:0; left:0; right:0; z-index:100;
  height:46px; display:flex; align-items:center; justify-content:space-between;
  padding:0 28px; background:rgba(8,7,5,.9); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
}
.pub-brand { display:flex; flex-direction:column; justify-content:center; gap:5px; }
.pub-wordmark {
  font-family:var(--font-serif); font-weight:700; font-size:22px;
  letter-spacing:.06em; color:var(--text-primary); line-height:1;
}
.pub-domain {
  font-family:var(--font-sans); font-weight:700; font-size:11px;
  letter-spacing:.2em; color:var(--accent); text-transform:uppercase;
}
.pub-nav { display:flex; align-items:center; gap:0; }
.pub-nav a {
  font-family:var(--font-mono); font-size:10px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--text-muted); padding:0 16px; height:46px;
  display:flex; align-items:center; border-left:1px solid var(--border);
  transition:color var(--t), background var(--t);
}
.pub-nav a:hover { color:var(--text-primary); background:rgba(20,17,8,.6); }
.pub-nav a.cta   { color:var(--accent); }
.pub-nav a.cta:hover { color:var(--accent-hover); }

/* ── Landing page ───────────────────────────────── */
.landing { min-height:100vh; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:86px 20px 40px; overflow-y:auto; background:var(--bg); }
.landing-wordmark { font-family:var(--font-serif); font-size:56px; font-weight:700; letter-spacing:.06em; color:var(--text-primary); margin-bottom:8px; }
.landing-tagline  { font-family:var(--font-mono); font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--text-muted); margin-bottom:40px; }
