/* =====================================================================
   QuantsBroker Portal — dashboard & admin shell (neo-brutalist)
   Sidebar · topbar · stat cards · tables · code/docs · API keys · drawer
   Link AFTER portal.css on dashboard.html and admin.html
   ===================================================================== */

/* =================== SHELL =================== */
.dash { display: grid; grid-template-columns: 264px 1fr; min-height: 100vh; }
.dash__side {
  position: sticky; top: 0; align-self: start; height: 100vh; overflow-y: auto;
  background: var(--ink); color: var(--paper); border-right: var(--bw-thick) solid var(--ink);
  display: flex; flex-direction: column; gap: 1rem; padding: 1.2rem 1rem;
}
.dash__side .brand__word { color: var(--paper); } .dash__side .brand__b { color: var(--yellow); }
.dash__nav { display: flex; flex-direction: column; gap: .35rem; margin-top: .6rem; }
.dash__nav a {
  display: flex; align-items: center; gap: .7rem; padding: .7rem .8rem; font-family: var(--mono); font-size: .82rem;
  text-transform: uppercase; letter-spacing: .04em; color: #b8b4a8; border: 2px solid transparent;
  transition: background var(--d-fast), color var(--d-fast), transform var(--d-fast);
}
.dash__nav a .ic { width: 1.1rem; text-align: center; }
.dash__nav a:hover { color: var(--paper); background: #1b1b1b; }
.dash__nav a.is-active { background: var(--yellow); color: var(--ink); border-color: var(--ink); box-shadow: 4px 4px 0 #000; }
.dash__side-foot { margin-top: auto; display: flex; flex-direction: column; gap: .6rem; font-family: var(--mono); font-size: .72rem; color: #8a8f98; }
.dash__plan { border: 2px solid #2a2a2a; padding: .6rem; }
.dash__plan b { color: var(--yellow); display: block; font-size: .8rem; }

.dash__main { min-width: 0; display: flex; flex-direction: column; }
.dash__top { position: sticky; top: 0; z-index: 30; display: flex; align-items: center; gap: 1rem; padding: .9rem var(--gutter); background: var(--paper); border-bottom: var(--bw-thick) solid var(--ink); }
.dash__top h1 { font-family: var(--display); text-transform: uppercase; font-size: clamp(1.1rem, 1rem + .8vw, 1.6rem); letter-spacing: -.01em; }
.dash__top .spacer { flex: 1; }
.dash__top .who { font-family: var(--mono); font-size: .78rem; text-align: right; line-height: 1.2; }
.dash__top .who b { display: block; }
.dash__burger { display: none; }
.dash__content { padding: clamp(1.2rem, 1rem + 2vw, 2.2rem) var(--gutter); display: grid; gap: clamp(1.2rem, 1rem + 1.5vw, 1.8rem); }
.dash__view { display: none; gap: inherit; }
.dash__view.is-active { display: grid; animation: viewIn .35s var(--ease) both; }
@keyframes viewIn { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

.sec-head { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.sec-head h2 { font-family: var(--display); text-transform: uppercase; font-size: clamp(1.3rem, 1rem + 1.4vw, 1.9rem); letter-spacing: -.02em; line-height: 1; }
.sec-head p { font-family: var(--mono); font-size: .78rem; color: #777; }

/* =================== CARDS / STATS =================== */
.panel { background: var(--paper); border: var(--bw-thick) solid var(--ink); box-shadow: var(--shadow); padding: clamp(1.1rem, 1rem + 1vw, 1.6rem); }
.panel--ink { background: var(--ink); color: var(--paper); }
.panel--y { background: var(--yellow); } .panel--blue { background: var(--blue); color: #fff; } .panel--pink { background: var(--pink); }
.panel__head { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: 1rem; }
.panel__head h3 { font-family: var(--display); text-transform: uppercase; font-size: 1.05rem; letter-spacing: -.01em; }

.stat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(.9rem, 1vw, 1.3rem); }
.stat { background: var(--paper); border: var(--bw-thick) solid var(--ink); box-shadow: var(--shadow); padding: 1.1rem 1.2rem; position: relative; }
.stat__top { display: flex; align-items: center; justify-content: space-between; font-family: var(--mono); font-size: .68rem; text-transform: uppercase; letter-spacing: .06em; color: #777; }
.stat__top .delta { font-weight: 700; } .delta.up { color: #109b5b; } .delta.down { color: #c83232; }
.stat__num { font-family: var(--display); font-size: clamp(1.7rem, 1rem + 2.4vw, 2.6rem); line-height: 1; letter-spacing: -.03em; margin: .5rem 0 .2rem; }
.stat__label { font-family: var(--mono); font-size: .72rem; color: #555; }
.stat--accent { background: var(--yellow); } .stat--blue { background: var(--blue); color: #fff; } .stat--blue .stat__top, .stat--blue .stat__label { color: rgba(255,255,255,.8); }

/* charts (mock) */
.bars { display: flex; align-items: flex-end; gap: .5rem; height: 140px; }
.bars i { flex: 1; background: var(--blue); border: 2px solid var(--ink); box-shadow: 3px 3px 0 var(--ink); transition: height var(--d-norm) var(--ease); }
.bars i:nth-child(even) { background: var(--ink); }
.spark { width: 100%; height: 70px; }
.spark path { fill: none; stroke: var(--green); stroke-width: 3; }

/* =================== TABLES =================== */
.table-wrap { overflow-x: auto; border: var(--bw-thick) solid var(--ink); box-shadow: var(--shadow); background: var(--paper); }
.table { width: 100%; min-width: 640px; border-collapse: collapse; }
.table thead th { background: var(--ink); color: var(--paper); font-family: var(--mono); font-size: .68rem; text-transform: uppercase; letter-spacing: .06em; text-align: left; padding: .8rem 1rem; }
.table td { padding: .85rem 1rem; border-top: 2px solid var(--ink); font-size: .9rem; vertical-align: middle; }
.table tbody tr:hover { background: var(--paper-2); }
.table .co { font-weight: 700; } .table .sub { font-family: var(--mono); font-size: .72rem; color: #777; }
.row-actions { display: flex; gap: .4rem; flex-wrap: wrap; }

/* =================== CODE / DOCS / KEYS =================== */
.codepanel { background: #0e0e0e; border: var(--bw-thick) solid var(--ink); box-shadow: var(--shadow); color: #e6e3d8; overflow: hidden; }
.codepanel__bar { display: flex; align-items: center; gap: .5rem; padding: .55rem .8rem; background: #1b1b1b; border-bottom: var(--bw) solid #2a2a2a; font-family: var(--mono); font-size: .72rem; color: #8a8f98; }
.codepanel__dot { width: 11px; height: 11px; border-radius: 50%; border: 2px solid #000; }
.codepanel__dot--r { background: var(--red); } .codepanel__dot--y { background: var(--yellow); } .codepanel__dot--g { background: var(--green); }
.codepanel pre { margin: 0; padding: 1rem 1.1rem; overflow-x: auto; font-family: var(--mono); font-size: .82rem; line-height: 1.7; white-space: pre; }
.c-c { color: #6b7280; font-style: italic; } .c-k { color: var(--pink); } .c-s { color: #8ce99a; } .c-f { color: var(--yellow); } .c-n { color: #7cc7ff; }
.tabs { display: flex; gap: 0; border-bottom: var(--bw) solid #2a2a2a; background: #141414; }
.tab { font-family: var(--mono); font-size: .76rem; padding: .55rem 1rem; color: #8a8f98; border-right: 2px solid #2a2a2a; }
.tab.is-active { background: var(--yellow); color: var(--ink); font-weight: 700; }
.copy { margin-left: auto; font-family: var(--mono); font-size: .64rem; font-weight: 700; letter-spacing: .06em; padding: .25rem .5rem; border: 2px solid currentColor; }

.endpoint { display: grid; grid-template-columns: auto 1fr; gap: .2rem .8rem; align-items: center; padding: .7rem .9rem; border: var(--bw) solid var(--ink); background: var(--paper); margin-bottom: .6rem; }
.verb { grid-row: 1 / span 2; align-self: center; font-family: var(--mono); font-weight: 700; font-size: .68rem; padding: .25rem .5rem; border: 2px solid var(--ink); }
.verb--get { background: var(--green); } .verb--post { background: var(--blue); color: #fff; } .verb--del { background: var(--red); color: #fff; } .verb--wss { background: var(--pink); }
.endpoint .path { font-family: var(--mono); font-weight: 700; font-size: .9rem; } .endpoint .desc { font-size: .76rem; color: #777; }

.keyrow { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; padding: .8rem; border: var(--bw) solid var(--ink); background: var(--paper-2); margin-bottom: .7rem; }
.keyrow .kname { font-family: var(--mono); font-weight: 700; font-size: .72rem; text-transform: uppercase; }
.keyrow code { flex: 1; min-width: 180px; font-family: var(--mono); font-size: .82rem; background: var(--ink); color: var(--paper); padding: .5rem .7rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* =================== DRAWER / MODAL =================== */
.overlay { position: fixed; inset: 0; z-index: 80; background: rgba(10,10,10,.55); display: none; }
.overlay.show { display: block; }
.drawer { position: fixed; top: 0; right: 0; z-index: 90; width: min(100%, 480px); height: 100vh; overflow-y: auto; background: var(--paper); border-left: var(--bw-thick) solid var(--ink); box-shadow: -14px 0 0 rgba(10,10,10,.15); transform: translateX(102%); transition: transform var(--d-norm) var(--ease); }
.drawer.show { transform: none; }
.drawer__head { position: sticky; top: 0; display: flex; align-items: center; justify-content: space-between; padding: 1rem var(--gutter); background: var(--ink); color: var(--paper); border-bottom: var(--bw) solid var(--ink); }
.drawer__body { padding: var(--gutter); display: grid; gap: 1rem; }
.kv { display: grid; grid-template-columns: 38% 1fr; gap: .3rem .6rem; font-size: .88rem; }
.kv dt { font-family: var(--mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .04em; color: #777; }
.kv dd { font-weight: 600; }

.empty { text-align: center; padding: 2.5rem 1rem; font-family: var(--mono); color: #999; }

/* =================== RESPONSIVE =================== */
@media (max-width: 980px) { .stat-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 860px) {
  .dash { grid-template-columns: 1fr; }
  .dash__side { position: fixed; z-index: 60; top: 0; left: 0; width: min(82vw, 300px); transform: translateX(-102%); transition: transform var(--d-norm) var(--ease); }
  .dash__side.show { transform: none; box-shadow: var(--shadow-lg); }
  .dash__burger { display: inline-flex; }
}
@media (max-width: 560px) { .stat-grid { grid-template-columns: 1fr; } }
