/* ==========================================================================
   Breakout Algo — desktop web app (standalone fallback client)
   Design system ported from the PrimeX CRM (structure, typography, density,
   gradient accents) re-keyed to the Breakout green palette. Inter-only type,
   fixed-viewport shell with internal scrolling, translucent gradient-striped
   cards. Class names are the app's API — do not rename.
   ========================================================================== */
:root{
  --bg:#060806; --bg2:#080b09; --bg3:#0b100c; --card:#0d130e; --card2:#101710;
  --line:rgba(57,255,107,.10); --line2:rgba(57,255,107,.06); --line3:rgba(57,255,107,.18);
  --accent:#39ff6b; --accent-b:#2ee65f; --accent-l:#a9ffc9; --accent-dim:rgba(57,255,107,.12);
  --ink:#041708;
  --text:#eef7f0; --text2:#6d8a75; --text3:#3c5544; --text4:#4c6653;
  --up:#52ff8a; --down:#f87171; --warn:#fbbf24; --gold:#fbbf24; --purple:#a78bfa;
  --plot:#ffffff; --plot-dim:rgba(255,255,255,.5);   /* premium white chart lines */
  --radius:10px; --r-lg:14px;
  --ease:cubic-bezier(.4,0,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;}
body{
  background:var(--bg);
  color:var(--text);font-family:'Inter',-apple-system,BlinkMacSystemFont,sans-serif;
  font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;
}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit;}
input,select,textarea{font-family:inherit;color:inherit;}
a{color:var(--accent);text-decoration:none;}
/* CRM is Inter-only — .serif is kept as the "display heading" hook. */
.serif{font-family:'Inter',sans-serif;font-weight:600;letter-spacing:-.02em;}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace;font-variant-numeric:tabular-nums;letter-spacing:-.01em;}
.up{color:var(--up);} .down{color:var(--down);} .dim{color:var(--text2);}
::selection{background:rgba(57,255,107,.28);color:#04170a;}
*::-webkit-scrollbar{width:7px;height:7px;}
*::-webkit-scrollbar-thumb{background:rgba(57,255,107,.15);border-radius:4px;}
*::-webkit-scrollbar-thumb:hover{background:rgba(57,255,107,.28);}
@keyframes spin{to{transform:rotate(360deg);}} .spin{display:inline-block;animation:spin .9s linear infinite;}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
@keyframes ldot{0%,100%{opacity:1;}50%{opacity:.35;}}
.fade>*{animation:fadeUp .26s var(--ease) both;}
.fade>*:nth-child(2){animation-delay:40ms;}.fade>*:nth-child(3){animation-delay:80ms;}
.fade>*:nth-child(4){animation-delay:120ms;}.fade>*:nth-child(5){animation-delay:160ms;}.fade>*:nth-child(6){animation-delay:200ms;}

/* ── App shell — fixed viewport, content scrolls internally (CRM) ───────── */
.shell{display:flex;height:100vh;height:100dvh;overflow:hidden;}
.rail{
  width:220px;min-width:220px;height:100%;overflow-y:auto;
  background:linear-gradient(180deg,#060806 0%,#050705 100%);
  border-right:1px solid var(--line2);
  padding:18px 0 14px;display:flex;flex-direction:column;
}
.rail-brand{display:flex;align-items:center;gap:8px;padding:2px 20px 16px;}
.rail-brand img{width:138px;max-width:100%;display:block;}
.rail-brand::after{content:'';width:7px;height:7px;border-radius:50%;background:var(--accent-b);
  box-shadow:0 0 12px rgba(57,255,107,.8);animation:ldot 3s ease-in-out infinite;flex-shrink:0;}
.rail-label{font-size:9px;font-weight:600;letter-spacing:.14em;color:var(--text3);margin:14px 24px 4px;text-transform:uppercase;}
.nav-item{
  display:flex;align-items:center;gap:11px;
  padding:9px 14px;margin:1px 10px;border-radius:8px;border:1px solid transparent;
  color:var(--text2);font-size:13px;font-weight:500;text-align:left;position:relative;
  transition:all .22s var(--ease);
}
.nav-item i{font-size:16px;width:19px;text-align:center;}
.nav-item:hover{background:rgba(57,255,107,.05);color:#b9d8c1;}
.nav-item.active{background:linear-gradient(90deg,rgba(57,255,107,.12),rgba(57,255,107,.04));border-color:rgba(57,255,107,.15);color:var(--accent-l);}
.nav-item.active::before{content:'';position:absolute;left:-10px;top:50%;transform:translateY(-50%);
  width:2px;height:18px;border-radius:0 2px 2px 0;background:var(--accent-b);box-shadow:0 0 8px rgba(57,255,107,.5);}
.rail-foot{margin-top:auto;padding:10px 12px 0;border-top:1px solid var(--line2);display:flex;align-items:center;gap:10px;}
.rail-ava{width:30px;height:30px;border-radius:50%;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#12b344,#39ff6b);color:var(--ink);font-size:11px;font-weight:700;}
.rail-name{margin:0;font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rail-handle{margin:0;font-size:10px;color:var(--text2);}
.rail-out{padding:6px;color:var(--text2);font-size:15px;border-radius:7px;transition:all .2s;}
.rail-out:hover{color:var(--down);background:rgba(248,113,113,.08);}

.main{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden;background:var(--bg2);}
.topbar{
  flex-shrink:0;display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 28px;border-bottom:1px solid var(--line2);
  background:rgba(6,8,6,.6);backdrop-filter:blur(10px);
}
.topbar h1{font-size:14px;font-weight:600;letter-spacing:-.01em;}
.topbar .beta{font-size:8.5px;font-weight:700;letter-spacing:.1em;color:var(--warn);
  background:rgba(251,191,36,.1);border:1px solid rgba(251,191,36,.22);padding:1.5px 6px;border-radius:4px;
  vertical-align:2px;margin-left:9px;}
.topbar .right{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text2);}
.content{flex:1;overflow-y:auto;padding:24px 28px 56px;}
.content>*,.content>.fade{max-width:1560px;margin-left:auto;margin-right:auto;}
@media(max-width:900px){
  .shell{height:auto;overflow:visible;display:block;}
  .rail{display:none;}
  .main{overflow:visible;}
  .content{overflow:visible;padding:16px 14px 48px;}
  .topbar{padding:12px 16px;}
}

/* ── Stat cards — translucent, gradient top strip, hover lift (CRM) ─────── */
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:13px;margin-bottom:22px;}
.stat{
  position:relative;overflow:hidden;
  padding:15px 17px;border-radius:var(--r-lg);
  background:rgba(13,19,14,.45);border:1px solid rgba(57,255,107,.08);
  display:flex;flex-direction:column;gap:4px;
  transition:all .22s var(--ease);
}
.stat:hover{background:rgba(13,19,14,.7);border-color:rgba(57,255,107,.2);transform:translateY(-1px);}
.stat::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,rgba(57,255,107,.7),transparent);}
.stat .v{order:2;font-size:23px;font-weight:600;letter-spacing:-.025em;line-height:1.1;color:var(--text);font-variant-numeric:tabular-nums;font-family:'Inter',sans-serif;}
.stat .v.acc{color:var(--accent);}
.stat .l{order:1;font-size:9.5px;font-weight:500;letter-spacing:.1em;color:var(--text2);text-transform:uppercase;}
.stat .d{order:3;font-size:10.5px;color:var(--text2);margin-top:1px;}

/* ── Panels ─────────────────────────────────────────────────────────────── */
.panel{background:var(--card);border:1px solid var(--line2);border-radius:var(--r-lg);margin-bottom:20px;overflow:hidden;}
.panel-h{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--line2);}
.panel-h .t{font-size:11px;font-weight:600;letter-spacing:.1em;color:var(--text2);text-transform:uppercase;}
.panel-b{padding:18px;}
.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:start;}
.grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:13px;}
@media(max-width:1000px){.grid2,.grid3{grid-template-columns:1fr;}}

table.tbl{width:100%;border-collapse:collapse;font-size:12.5px;}
.tbl th{padding:9px 16px;text-align:left;font-size:9.5px;font-weight:600;letter-spacing:.1em;color:var(--text3);text-transform:uppercase;border-bottom:1px solid var(--line);white-space:nowrap;}
.tbl td{padding:10px 16px;border-bottom:1px solid var(--line2);vertical-align:middle;font-variant-numeric:tabular-nums;}
.tbl tr:last-child td{border-bottom:0;}
.tbl tr:hover td{background:rgba(57,255,107,.02);}
.tw{overflow-x:auto;}

.pill{display:inline-block;padding:2px 7px;border-radius:5px;font-size:10px;font-weight:600;letter-spacing:.02em;}
.pill.g{background:rgba(57,255,107,.1);color:var(--accent);border:1px solid rgba(57,255,107,.22);}
.pill.y{background:rgba(251,191,36,.1);color:var(--warn);border:1px solid rgba(251,191,36,.22);}
.pill.r{background:rgba(248,113,113,.1);color:var(--down);border:1px solid rgba(248,113,113,.22);}
.pill.n{background:rgba(255,255,255,.04);color:var(--text2);border:1px solid rgba(255,255,255,.08);}

/* ── Buttons — gradient accents (CRM ptab/refresh language) ─────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:9px 16px;border-radius:9px;
  border:1px solid rgba(57,255,107,.12);background:rgba(16,23,16,.5);
  color:var(--text);font-size:12.5px;font-weight:600;transition:all .22s var(--ease);
}
.btn:hover{border-color:rgba(57,255,107,.3);background:rgba(16,23,16,.85);transform:translateY(-1px);}
.btn:disabled{opacity:.5;cursor:default;transform:none;}
.btn.primary{
  background:linear-gradient(135deg,#2ee65f 0%,#39ff6b 55%,#7dffab 130%);
  border-color:transparent;color:var(--ink);font-weight:700;
  box-shadow:0 4px 18px rgba(57,255,107,.28),inset 0 1px 0 rgba(255,255,255,.25);
}
.btn.primary:hover{box-shadow:0 8px 26px rgba(57,255,107,.4),inset 0 1px 0 rgba(255,255,255,.25);}
.btn.ghost{background:transparent;color:var(--text2);}
.btn.ghost:hover{color:var(--accent);}
.btn.danger{border-color:rgba(248,113,113,.3);background:rgba(248,113,113,.08);color:var(--down);}
.btn.danger:hover{border-color:rgba(248,113,113,.5);background:rgba(248,113,113,.14);}
.btn.block{width:100%;}
.btn.sm{padding:5px 11px;font-size:11px;border-radius:7px;}

/* ── Forms ──────────────────────────────────────────────────────────────── */
.f-label{font-size:9.5px;font-weight:600;letter-spacing:.12em;color:var(--text2);margin:13px 0 6px;text-transform:uppercase;}
.f-input{width:100%;background:rgba(8,11,9,.8);border:1px solid var(--line);border-radius:8px;color:var(--text);font-size:13px;padding:9px 12px;outline:none;transition:border-color .2s;}
.f-input:focus{border-color:rgba(57,255,107,.35);box-shadow:0 0 0 3px rgba(57,255,107,.06);}
textarea.f-input{min-height:110px;resize:vertical;}
.f-note{font-size:11px;color:var(--text2);margin-top:8px;line-height:1.5;}
.f-err{font-size:12px;color:var(--down);margin-top:10px;min-height:16px;}
.segs{display:grid;grid-template-columns:1fr 1fr;gap:6px;background:rgba(16,23,16,.5);border:1px solid var(--line);border-radius:9px;padding:3px;}
.segs button{padding:8px;border-radius:7px;border:0;background:transparent;color:var(--text2);font-weight:600;font-size:12px;transition:all .22s var(--ease);}
.segs button.on{background:linear-gradient(135deg,rgba(57,255,107,.2),rgba(57,255,107,.08));color:var(--accent-l);
  box-shadow:0 2px 8px rgba(57,255,107,.12),inset 0 1px 0 rgba(255,255,255,.04);}

.empty{padding:26px 18px;color:var(--text2);font-size:12.5px;text-align:center;}
.loading{padding:40px 0;text-align:center;color:var(--text2);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;}

/* ── Modal ──────────────────────────────────────────────────────────────── */
.overlay{position:fixed;inset:0;z-index:200;background:rgba(2,4,2,.72);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:16px;}
.modal{width:100%;max-width:470px;background:var(--card);border:1px solid var(--line3);border-radius:var(--r-lg);padding:22px;max-height:calc(100dvh - 60px);overflow-y:auto;box-shadow:0 24px 70px rgba(0,0,0,.65);}
.m-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;}
.m-head h3{font-size:16px;font-weight:600;letter-spacing:-.01em;}
.m-head button{color:var(--text2);font-size:18px;line-height:1;}
.m-head button:hover{color:var(--text);}

/* ── Progress bar ───────────────────────────────────────────────────────── */
.bar{height:7px;border-radius:4px;background:rgba(16,23,16,.8);overflow:hidden;}
.bar>i{display:block;height:100%;border-radius:4px;background:linear-gradient(90deg,#12b344,#39ff6b);}
