/* Morfolabs demo terminal — deck-matched theme (lime + teal, dark).
   Mirrors Morfolabs_Pro-Market_Management_Dark.pdf. Self-contained; no
   Tailwind build. Production terminal theme is untouched. */

:root {
  --bg:        #0a0e12;
  --bg-soft:   #0c1116;
  --panel:     #0f151c;
  --panel-2:   #121a22;
  --panel-hi:  #16202a;
  --line:      rgba(255,255,255,0.07);
  --line-2:    rgba(255,255,255,0.12);

  --lime:      #c3f53c;
  --lime-dim:  #9fce2f;
  --teal:      #3ddc97;
  --teal-dim:  #2bb37a;
  --red:       #e56b6b;
  --red-dim:   #c14e4e;
  --amber:     #f5c451;

  --text:      #e7edf3;
  --muted:     #9aa4ad;
  --dim:       #626d77;

  --mono: 'JetBrains Mono', ui-monospace, Menlo, monospace;
  --grot: 'Space Grotesk', system-ui, -apple-system, sans-serif;

  --r: 14px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background:
    radial-gradient(1200px 600px at 85% -5%, rgba(61,220,151,0.06), transparent 60%),
    radial-gradient(900px 500px at 100% 100%, rgba(195,245,60,0.05), transparent 55%),
    var(--bg);
  color: var(--text);
  font-family: var(--grot);
  font-size: 14px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }

/* ── typography ── */
.eyebrow {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--dim);
}
.eyebrow.lime { color: var(--lime); }
.eyebrow.teal { color: var(--teal); }
h1,h2,h3 { font-family: var(--grot); font-weight: 700; margin: 0; letter-spacing: -0.01em; }
.mono { font-family: var(--mono); }
.num  { font-family: var(--mono); font-variant-numeric: tabular-nums; }
.pos { color: var(--teal); }
.neg { color: var(--red); }
.lime-t { color: var(--lime); }
.teal-t { color: var(--teal); }
.muted { color: var(--muted); }
.dim { color: var(--dim); }

/* ── brand lockup ── */
.brand { display:flex; align-items:center; gap:10px; }
.brand .logo { width:26px; height:26px; object-fit:contain; }
.brand .word { font-family: var(--mono); font-weight:700; font-size:16px; letter-spacing:-0.02em; }
.brand .word .a { color: var(--lime); }
.brand .word .b { color: #fff; }
.brand .sub { font-family: var(--mono); font-size:9px; letter-spacing:0.2em; color:var(--dim); text-transform:uppercase; }

/* ── app shell ── */
.shell { display:flex; min-height:100vh; }
.side {
  width: 224px; flex-shrink:0; background: rgba(9,12,16,0.7);
  border-right:1px solid var(--line); display:flex; flex-direction:column;
  position: sticky; top:0; height:100vh;
}
.side-brand { padding:18px 16px; border-bottom:1px solid var(--line); }
.nav { flex:1; padding:14px 12px; display:flex; flex-direction:column; gap:2px; }
.nav-label { font-family:var(--mono); font-size:9px; letter-spacing:0.2em; text-transform:uppercase; color:#4a545d; padding:0 10px; margin:14px 0 6px; }
.nav-link {
  display:flex; align-items:center; gap:10px; padding:9px 10px; border-radius:10px;
  color:var(--muted); font-size:13px; transition:all .15s; position:relative;
}
.nav-link svg { width:16px; height:16px; opacity:.7; }
.nav-link:hover { background:var(--panel); color:#fff; }
.nav-link.active { background: linear-gradient(90deg, rgba(195,245,60,0.12), rgba(195,245,60,0.02)); color:#fff; }
.nav-link.active svg { opacity:1; color:var(--lime); }
.nav-link.active::before { content:""; position:absolute; left:0; top:22%; bottom:22%; width:2px; border-radius:2px; background:var(--lime); }
.side-foot { border-top:1px solid var(--line); padding:12px; }

/* ── topbar ── */
.main { flex:1; min-width:0; display:flex; flex-direction:column; }
.topbar {
  height:56px; display:flex; align-items:center; justify-content:space-between;
  padding:0 24px; border-bottom:1px solid var(--line);
  background: rgba(10,14,18,0.6); backdrop-filter: blur(8px); position:sticky; top:0; z-index:20;
}
.content { padding:24px; max-width:1600px; width:100%; }

/* ── live badge ── */
.live { display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--lime); }
.dot { width:7px; height:7px; border-radius:50%; background:var(--lime); box-shadow:0 0 8px rgba(195,245,60,0.8); animation:pulse 2s ease-in-out infinite; }
.dot.teal { background:var(--teal); box-shadow:0 0 8px rgba(61,220,151,0.8); }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.35} }

/* ── pill / chip ── */
.pill { display:inline-flex; align-items:center; gap:6px; padding:5px 12px; border:1px solid var(--line-2); border-radius:999px; font-family:var(--mono); font-size:10px; letter-spacing:0.14em; text-transform:uppercase; color:var(--muted); }
.pill.lime { border-color: rgba(195,245,60,0.4); color:var(--lime); }

/* ── cards ── */
.card {
  background: linear-gradient(180deg, var(--panel-2), var(--panel));
  border:1px solid var(--line); border-radius:var(--r); padding:18px;
  position:relative; overflow:hidden;
}
.card.accent-lime::before, .card.accent-teal::before {
  content:""; position:absolute; left:0; top:14px; bottom:14px; width:3px; border-radius:3px;
}
.card.accent-lime::before { background:var(--lime); }
.card.accent-teal::before { background:var(--teal); }
.card-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.card-title { font-family:var(--mono); font-size:10px; letter-spacing:0.18em; text-transform:uppercase; color:var(--dim); }

/* ── kpi strip ── */
.kpis { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:14px; }
.kpi { background:linear-gradient(180deg,var(--panel-2),var(--panel)); border:1px solid var(--line); border-radius:var(--r); padding:16px 18px; }
.kpi .k-label { font-family:var(--mono); font-size:10px; letter-spacing:0.16em; text-transform:uppercase; color:var(--dim); }
.kpi .k-val { font-family:var(--grot); font-weight:700; font-size:26px; margin-top:8px; letter-spacing:-0.02em; }
.kpi .k-sub { font-family:var(--mono); font-size:11px; color:var(--muted); margin-top:4px; }

/* ── page header ── */
.page-head { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:22px; gap:16px; flex-wrap:wrap; }
.page-head h1 { font-size:26px; }
.page-head .lead { color:var(--muted); font-size:13px; margin-top:6px; max-width:640px; }

/* ── tables ── */
table { width:100%; border-collapse:collapse; }
thead th { font-family:var(--mono); font-size:9.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--dim); font-weight:500; text-align:right; padding:0 14px 12px; }
thead th:first-child { text-align:left; }
tbody td { font-family:var(--mono); font-size:12.5px; padding:11px 14px; text-align:right; border-top:1px solid var(--line); font-variant-numeric:tabular-nums; }
tbody td:first-child { text-align:left; }
tbody tr.clickable { cursor:pointer; transition:background .12s; }
tbody tr.clickable:hover { background:var(--panel-hi); }

/* ── market row asset ── */
.asset { display:flex; align-items:center; gap:10px; }
.asset .tick { width:30px; height:30px; border-radius:9px; background:var(--panel-hi); border:1px solid var(--line-2); display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-weight:700; font-size:11px; color:var(--lime); }
.asset .nm { font-family:var(--grot); font-weight:600; font-size:13px; color:#fff; }
.asset .q { font-family:var(--mono); font-size:10px; color:var(--dim); }

/* ── orderbook ── */
.book { display:flex; flex-direction:column; gap:1px; }
.book .row { position:relative; display:grid; grid-template-columns:1fr 1fr 1fr; font-family:var(--mono); font-size:12px; padding:5px 12px; z-index:1; font-variant-numeric:tabular-nums; }
.book .row span:nth-child(2){ text-align:right; color:var(--muted); }
.book .row span:nth-child(3){ text-align:right; color:var(--dim); }
.book .row .depth { position:absolute; top:0; bottom:0; right:0; z-index:-1; opacity:0.16; border-radius:3px; }
.book .ask .p { color:var(--red); }
.book .ask .depth { background:var(--red); }
.book .bid .p { color:var(--teal); }
.book .bid .depth { background:var(--teal); }
.book .head { display:grid; grid-template-columns:1fr 1fr 1fr; font-family:var(--mono); font-size:9px; letter-spacing:0.14em; text-transform:uppercase; color:var(--dim); padding:0 12px 8px; }
.book .head span:nth-child(2),.book .head span:nth-child(3){ text-align:right; }
.book .mid { display:flex; align-items:center; gap:12px; padding:10px 12px; margin:2px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.book .mid .price { font-family:var(--grot); font-weight:700; font-size:20px; }
.book .mid .usd { font-family:var(--mono); font-size:11px; color:var(--dim); }

/* ── trades ticker ── */
.trades { display:flex; flex-direction:column; max-height:420px; overflow-y:auto; }
.trades .t { display:flex; align-items:center; gap:12px; font-family:var(--mono); font-size:12px; padding:7px 4px; border-top:1px solid var(--line); font-variant-numeric:tabular-nums; flex:0 0 auto; }
.trades .t .tside { width:34px; flex:0 0 34px; font-size:9px; letter-spacing:0.12em; text-transform:uppercase; }
.trades .t.buy .tside { color:var(--teal); }
.trades .t.sell .tside { color:var(--red); }
.trades .t .px { margin-left:auto; text-align:right; }
.trades .t.buy .px { color:var(--teal); }
.trades .t.sell .px { color:var(--red); }
.trades .t .ago { color:var(--dim); text-align:right; }
.flash-in { animation:flash .6s ease-out; }
@keyframes flash { from{ background:rgba(195,245,60,0.10);} to{ background:transparent;} }

/* ── buttons / inputs ── */
.btn { font-family:var(--mono); font-size:11px; letter-spacing:0.1em; text-transform:uppercase; padding:9px 16px; border-radius:10px; border:1px solid var(--line-2); background:var(--panel-hi); color:var(--text); cursor:pointer; transition:all .15s; display:inline-flex; align-items:center; gap:8px; }
.btn:hover { border-color:var(--line-2); background:var(--panel-hi); }
.btn.lime { background:var(--lime); color:#0a0e12; border-color:var(--lime); font-weight:700; }
.btn.lime:hover { background:var(--lime-dim); }
select, input[type=text], input[type=password] {
  font-family:var(--mono); font-size:12px; background:var(--panel); color:var(--text);
  border:1px solid var(--line-2); border-radius:10px; padding:9px 12px; outline:none;
}
select:focus, input:focus { border-color:rgba(195,245,60,0.5); }

/* ── grids ── */
.grid-2 { display:grid; grid-template-columns:1.35fr 1fr; gap:18px; align-items:start; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; align-items:start; }
@media (max-width:1024px){ .grid-2,.grid-3{ grid-template-columns:1fr; } }

/* ── login ── */
.login-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; padding:24px; }
.login-card { width:100%; max-width:400px; }
.login-card .ring { position:fixed; right:-8%; top:50%; transform:translateY(-50%); width:640px; height:760px; border:1px solid rgba(61,220,151,0.10); border-radius:50%/40%; pointer-events:none; }
.field { display:flex; flex-direction:column; gap:8px; margin-top:18px; }
.err { color:var(--red); font-family:var(--mono); font-size:11px; margin-top:12px; }

/* ── report bars ── */
.bars { display:flex; align-items:flex-end; gap:5px; height:130px; }
.bars .b { flex:1; background:linear-gradient(180deg,var(--teal),rgba(61,220,151,0.25)); border-radius:4px 4px 0 0; min-height:3px; transition:height .3s; }

/* ── cockpit log ── */
.log { font-family:var(--mono); font-size:12px; max-height:340px; overflow:auto; }
.log .line { padding:5px 8px; border-top:1px solid var(--line); display:flex; gap:10px; }
.log .line .tag { color:var(--lime); }
.log .line .s-buy { color:var(--teal); }
.log .line .s-sell { color:var(--red); }

.section-gap { margin-top:22px; }
.spark { display:block; }
.right { text-align:right; }
