:root{
  --ink:#0E1116; --panel:#161A21; --panel-2:#1D222B; --panel-3:#232A35;
  --line:#262D38; --line-2:#313a47;
  --text:#E7EAF0; --muted:#8B94A4; --faint:#5B6473;
  --solar:#FFB020; --solar-dim:#7a5a18;
  --volt:#3DA9FC;
  --good:#2ECC71; --warn:#F5A623; --bad:#FF5A6A; --info:#3DA9FC;
  --radius:12px; --radius-sm:9px;
  --mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  --sans:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:var(--ink); color:var(--text); font-family:var(--sans);
  font-size:14px; line-height:1.45; -webkit-font-smoothing:antialiased;
}
button{font-family:inherit}
a{color:var(--volt);text-decoration:none}
::selection{background:var(--solar);color:#1a1206}

/* ---------- layout ---------- */
.app{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
.sidebar{
  border-right:1px solid var(--line); background:#11141A;
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;
}
.brand{display:flex;gap:11px;align-items:center;padding:18px 18px 16px}
.brand-mark{width:38px;height:38px;border-radius:10px;background:var(--panel);
  display:grid;place-items:center;border:1px solid var(--line)}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-text strong{font-size:17px;letter-spacing:-.02em}
.brand-text span{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em}
.nav{display:flex;flex-direction:column;gap:2px;padding:6px 10px;overflow-y:auto;flex:1}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;
  color:var(--muted);cursor:pointer;font-weight:500;border:1px solid transparent;
  user-select:none;font-size:13.5px;
}
.nav-item:hover{background:var(--panel);color:var(--text)}
.nav-item.active{background:var(--panel-2);color:var(--text);border-color:var(--line-2)}
.nav-item.active .nav-ico{color:var(--solar)}
.nav-ico{width:18px;text-align:center;font-size:15px;opacity:.95}
.nav-badge{margin-left:auto;font-family:var(--mono);font-size:11px;background:var(--panel-3);
  color:var(--muted);padding:1px 7px;border-radius:20px}
.sidebar-foot{padding:12px 12px 16px;border-top:1px solid var(--line)}
.ver{font-size:10.5px;color:var(--faint);text-align:center;margin-top:8px;letter-spacing:.03em}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{
  height:60px;border-bottom:1px solid var(--line);display:flex;align-items:center;
  gap:14px;padding:0 22px;position:sticky;top:0;background:rgba(14,17,22,.86);
  backdrop-filter:blur(8px);z-index:30;
}
.topbar-title{font-size:18px;font-weight:700;letter-spacing:-.01em}
.topbar-actions{margin-left:auto;display:flex;gap:9px;align-items:center;flex-wrap:wrap}
.view{padding:22px;max-width:1280px;width:100%}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line-2);
  background:var(--panel-2);color:var(--text);padding:8px 13px;border-radius:9px;
  font-weight:600;font-size:13px;cursor:pointer;transition:.12s;white-space:nowrap;
}
.btn:hover{background:var(--panel-3);border-color:#3c4654}
.btn-primary{background:var(--solar);color:#1a1206;border-color:var(--solar)}
.btn-primary:hover{background:#ffc24d;border-color:#ffc24d}
.btn-ghost{background:transparent}
.btn-ghost:hover{background:var(--panel)}
.btn-danger{color:var(--bad);border-color:#48303a}
.btn-danger:hover{background:#241317;border-color:var(--bad)}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-block{width:100%;justify-content:center}
.icon-btn{background:var(--panel-2);border:1px solid var(--line);color:var(--text);
  width:36px;height:36px;border-radius:9px;cursor:pointer;font-size:18px;display:grid;place-items:center}
.icon-btn:hover{background:var(--panel-3)}

/* ---------- cards / kpi ---------- */
.grid{display:grid;gap:14px}
.kpis{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:18px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.kpi{display:flex;flex-direction:column;gap:5px;position:relative;overflow:hidden}
.kpi-label{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.kpi-value{font-family:var(--mono);font-size:27px;font-weight:700;letter-spacing:-.02em;line-height:1}
.kpi-sub{font-size:12px;color:var(--muted)}
.kpi-accent{position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--solar)}
.kpi-accent.volt{background:var(--volt)} .kpi-accent.good{background:var(--good)}
.kpi-accent.warn{background:var(--warn)} .kpi-accent.bad{background:var(--bad)}
.money{font-family:var(--mono)}

.section-head{display:flex;align-items:center;gap:10px;margin:24px 0 12px}
.section-head h2{font-size:15px;margin:0;font-weight:700;letter-spacing:-.01em}
.section-head .hint{font-size:12px;color:var(--muted)}
.section-head .spacer{flex:1}

/* ---------- tables ---------- */
.table-wrap{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:auto}
table{width:100%;border-collapse:collapse;font-size:13px;min-width:560px}
thead th{
  text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.08em;
  color:var(--muted);font-weight:600;padding:11px 14px;border-bottom:1px solid var(--line);
  white-space:nowrap;background:var(--panel);position:sticky;top:0;
}
tbody td{padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--panel-2)}
td.num,th.num{text-align:right;font-family:var(--mono)}
.row-click{cursor:pointer}

/* ---------- badges / chips ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;
  padding:3px 9px;border-radius:20px;border:1px solid var(--line-2);background:var(--panel-2);white-space:nowrap}
.badge .dot{width:6px;height:6px;border-radius:50%;background:var(--muted)}
.badge.good{color:var(--good);border-color:#234b34;background:#13251b}.badge.good .dot{background:var(--good)}
.badge.warn{color:var(--warn);border-color:#4d3c1c;background:#241d10}.badge.warn .dot{background:var(--warn)}
.badge.bad{color:var(--bad);border-color:#48303a;background:#251217}.badge.bad .dot{background:var(--bad)}
.badge.volt{color:var(--volt);border-color:#1d3a52;background:#10202e}.badge.volt .dot{background:var(--volt)}
.badge.solar{color:var(--solar);border-color:#4d3a14;background:#241b0c}.badge.solar .dot{background:var(--solar)}
.chip{font-size:11px;color:var(--muted);background:var(--panel-2);border:1px solid var(--line);
  padding:2px 8px;border-radius:6px;font-family:var(--mono)}

/* ---------- filters ---------- */
.toolbar{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:14px;align-items:center}
.input,select,textarea{
  background:var(--panel-2);border:1px solid var(--line-2);color:var(--text);
  padding:8px 11px;border-radius:9px;font-size:13px;font-family:inherit;outline:none;width:100%;
}
.input:focus,select:focus,textarea:focus{border-color:var(--solar)}
.search{max-width:280px}
select{cursor:pointer}
.seg{display:flex;background:var(--panel-2);border:1px solid var(--line);border-radius:9px;padding:3px;gap:2px}
.seg button{background:transparent;border:none;color:var(--muted);padding:6px 11px;border-radius:7px;
  cursor:pointer;font-size:12.5px;font-weight:600}
.seg button.active{background:var(--panel-3);color:var(--text)}

/* ---------- pipeline / kanban ---------- */
.board{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(248px,1fr);gap:13px;overflow-x:auto;padding-bottom:8px}
.col{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);display:flex;flex-direction:column;min-height:120px}
.col-head{display:flex;align-items:center;gap:8px;padding:12px 13px;border-bottom:1px solid var(--line);font-weight:700;font-size:13px}
.col-head .count{margin-left:auto;font-family:var(--mono);font-size:11px;color:var(--muted);background:var(--panel-2);padding:1px 8px;border-radius:20px}
.col-head .stage-dot{width:8px;height:8px;border-radius:50%}
.col-body{padding:10px;display:flex;flex-direction:column;gap:9px;flex:1;min-height:40px}
.col-body.drag-over{background:var(--panel-2);outline:1px dashed var(--solar-dim);outline-offset:-6px}
.kcard{background:var(--panel-2);border:1px solid var(--line-2);border-radius:10px;padding:11px;cursor:grab}
.kcard:active{cursor:grabbing}
.kcard.dragging{opacity:.4}
.kcard .k-top{display:flex;justify-content:space-between;gap:8px;align-items:flex-start}
.kcard .k-name{font-weight:700;font-size:13.5px}
.kcard .k-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.kcard .k-mrr{font-family:var(--mono);font-size:12px;color:var(--solar);font-weight:700}

/* ---------- modal ---------- */
.modal-root{position:fixed;inset:0;display:none;z-index:80}
.modal-root.open{display:block}
.modal-bg{position:absolute;inset:0;background:rgba(6,8,11,.66);backdrop-filter:blur(3px)}
.modal{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:var(--panel);border:1px solid var(--line-2);border-radius:16px;
  width:min(640px,calc(100vw - 28px));max-height:calc(100vh - 48px);overflow:auto;
  box-shadow:0 24px 70px rgba(0,0,0,.55)
}
.modal.wide{width:min(880px,calc(100vw - 28px))}
.modal-head{display:flex;align-items:center;gap:10px;padding:18px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--panel);z-index:2}
.modal-head h3{margin:0;font-size:16px}
.modal-head .x{margin-left:auto}
.modal-body{padding:20px}
.modal-foot{padding:14px 20px;border-top:1px solid var(--line);display:flex;gap:9px;justify-content:flex-end;position:sticky;bottom:0;background:var(--panel)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:12px;color:var(--muted);font-weight:600}
.field .help{font-size:11px;color:var(--faint)}
textarea{resize:vertical;min-height:74px;line-height:1.5}

/* ---------- misc ---------- */
.muted{color:var(--muted)}
.empty{padding:46px 20px;text-align:center;color:var(--muted)}
.empty h3{color:var(--text);margin:0 0 6px;font-size:15px}
.empty p{margin:0 0 16px;font-size:13px}
.two-col{display:grid;grid-template-columns:1.6fr 1fr;gap:14px;align-items:start}
.list{display:flex;flex-direction:column;gap:9px}
.alert{display:flex;gap:11px;align-items:flex-start;padding:12px 14px;border-radius:10px;border:1px solid var(--line);background:var(--panel-2);font-size:13px}
.alert .a-ico{font-size:16px;line-height:1.2}
.alert.warn{border-color:#4d3c1c;background:#1d1810}
.alert.bad{border-color:#48303a;background:#1d1115}
.alert .a-cta{margin-left:auto}
.kv{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--line);font-size:13px}
.kv:last-child{border:none}
.kv .k{color:var(--muted)}
.kv .v{font-family:var(--mono)}
.bar{height:7px;border-radius:6px;background:var(--panel-3);overflow:hidden}
.bar > span{display:block;height:100%;background:var(--solar)}
.copybox{position:relative}
.tag{display:inline-block;font-size:11px;color:var(--volt);background:#10202e;border:1px solid #1d3a52;padding:1px 7px;border-radius:6px;margin:0 4px 4px 0}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:13px}
.creative{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:9px}
.creative.win{border-color:var(--solar-dim)}
.creative .c-body{font-size:12.5px;color:var(--text);white-space:pre-wrap;background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:10px;max-height:150px;overflow:auto;line-height:1.5}
.creative .c-head{display:flex;align-items:center;gap:8px}
.creative .c-head .c-title{font-weight:700;font-size:13.5px}
.bench{font-family:var(--mono);font-size:12px}
.tpl{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:9px}
.tpl pre{margin:0;white-space:pre-wrap;font-family:var(--sans);font-size:13px;color:var(--text);
  background:var(--panel-2);border:1px solid var(--line);border-radius:8px;padding:11px;line-height:1.55}

/* ---------- toast ---------- */
.toast-root{position:fixed;bottom:18px;left:50%;transform:translateX(-50%);z-index:120;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:var(--panel-3);border:1px solid var(--line-2);color:var(--text);padding:10px 16px;border-radius:10px;
  font-size:13px;font-weight:500;box-shadow:0 10px 30px rgba(0,0,0,.4);animation:rise .2s ease}
.toast.good{border-color:#234b34} .toast.bad{border-color:#48303a}
@keyframes rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.only-mobile{display:none}
@media(max-width:880px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;z-index:60;width:236px;transform:translateX(-110%);transition:.22s}
  .sidebar.open{transform:none;box-shadow:0 0 0 100vmax rgba(0,0,0,.5)}
  .only-mobile{display:grid}
  .two-col{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .view{padding:16px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
