﻿:root{
    --bg:#0b0f19;
    --panel:#111827;
    --panel2:#0f172a;
    --text:#e5e7eb;
    --muted:#9ca3af;
    --border:#1f2937;
    --ok:#22c55e;
    --warn:#f59e0b;
    --bad:#ef4444;
    --accent:#60a5fa;
    --accent2:#a78bfa;
    --link:#93c5fd;
    --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
}
*{box-sizing:border-box}
body{margin:0;background:linear-gradient(180deg,#050814 0%, #0b0f19 60%);color:var(--text);font-family:var(--sans)}
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}
.layout{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.sidebar{
    background:rgba(10,14,26,.85);
    border-right:1px solid rgba(255,255,255,.06);
    position:sticky;top:0;height:100vh;overflow:auto;
    padding:16px 12px;
}
.brand{display:flex;align-items:center;gap:10px;padding:10px 10px 12px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:10px}
.logo{
    width:34px;height:34px;border-radius:10px;
    background:radial-gradient(circle at 30% 30%, var(--accent), transparent 60%),
                radial-gradient(circle at 70% 60%, var(--accent2), transparent 60%),
                #0a1020;
    border:1px solid rgba(255,255,255,.06);
    box-shadow:0 8px 24px rgba(0,0,0,.35);
}
.brand h1{font-size:14px;margin:0;line-height:1.1}
.brand .sub{font-size:12px;color:var(--muted);margin-top:2px}
.badge{
    display:inline-flex;align-items:center;gap:6px;
    font-size:11px;padding:4px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.03);color:var(--muted);
    margin-left:auto;
}
.dot{width:8px;height:8px;border-radius:50%}
.dot.ok{background:var(--ok)} .dot.warn{background:var(--warn)} .dot.bad{background:var(--bad)}
.nav{margin-top:10px}
.nav a{
    display:flex;align-items:center;gap:10px;
    padding:10px 10px;border-radius:10px;color:var(--text);
    border:1px solid transparent;
}
.nav a:hover{background:rgba(255,255,255,.03);border-color:rgba(255,255,255,.06)}
.nav a.active{background:rgba(96,165,250,.10);border-color:rgba(96,165,250,.25)}
.nav .ico{width:18px;height:18px;opacity:.9}

.content{display:flex;flex-direction:column;min-width:0}
.topbar{
    position:sticky;top:0;z-index:20;
    background:rgba(6,10,22,.75);
    backdrop-filter: blur(10px);
    border-bottom:1px solid rgba(255,255,255,.06);
    padding:10px 14px;
}
.topbar-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.ctl{
    display:flex;align-items:center;gap:8px;
    background:rgba(255,255,255,.03);
    border:1px solid rgba(255,255,255,.06);
    padding:8px 10px;border-radius:12px;
}
.ctl label{font-size:12px;color:var(--muted)}
select,input[type="text"]{
    background:transparent;border:1px solid rgba(255,255,255,.10);
    color:var(--text);border-radius:10px;padding:7px 10px;font-size:12px;outline:none;
}
select{padding-right:28px}
.toggle{
    display:flex;align-items:center;gap:8px;
    padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.03);cursor:pointer;user-select:none;
    font-size:12px;color:var(--muted);
}
.toggle[data-on="true"]{border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.10);color:#d1fae5}
.toggle.kill[data-on="true"]{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.10);color:#fee2e2}
.toggle .knob{width:10px;height:10px;border-radius:50%;background:rgba(156,163,175,.8)}
.toggle[data-on="true"] .knob{background:var(--ok)}
.toggle.kill[data-on="true"] .knob{background:var(--bad)}
.indicators{display:flex;gap:8px;flex-wrap:wrap;margin-left:auto}
.pill{
    display:flex;align-items:center;gap:8px;
    border:1px solid rgba(255,255,255,.08);border-radius:999px;
    padding:6px 10px;background:rgba(255,255,255,.03);
    font-size:12px;color:var(--muted);
}
.pill b{color:var(--text);font-weight:600}
.btn{
    appearance:none;border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.03);
    color:var(--text);font-size:12px;border-radius:12px;
    padding:7px 10px;cursor:pointer;
}
.btn:hover{border-color:rgba(96,165,250,.35);background:rgba(96,165,250,.10)}
.btn.primary{border-color:rgba(96,165,250,.35);background:rgba(96,165,250,.16)}
.btn.danger{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.10)}

.main{padding:16px 16px 24px;min-width:0}
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.card{
    background:linear-gradient(180deg, rgba(17,24,39,.95), rgba(15,23,42,.85));
    border:1px solid rgba(255,255,255,.06);
    border-radius:16px;
    box-shadow:0 10px 30px rgba(0,0,0,.35);
    overflow:hidden;
    min-width:0;
}
.card .hd{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.06)}
.card .hd h2{margin:0;font-size:13px;letter-spacing:.2px}
.card .hd .actions{display:flex;gap:8px;flex-wrap:wrap}
.body{padding:12px 14px}
.kv{display:grid;grid-template-columns:180px 1fr;gap:8px 12px}
.kv .k{color:var(--muted);font-size:12px}
.kv .v{font-size:12px;min-width:0;overflow:hidden;text-overflow:ellipsis}
.mono{font-family:var(--mono)}
.muted{color:var(--muted)}
.ok{color:var(--ok)} .warnc{color:var(--warn)} .badc{color:var(--bad)}
table{width:100%;border-collapse:collapse;font-size:12px}
th,td{padding:8px 8px;border-bottom:1px solid rgba(255,255,255,.06);vertical-align:top}
th{color:var(--muted);font-weight:600;text-align:left}
.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;border:1px solid rgba(255,255,255,.08);background:rgba(0,0,0,.15);color:var(--muted);font-size:11px}
.chips{display:flex;gap:6px;flex-wrap:wrap}
.row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.hr{height:1px;background:rgba(255,255,255,.06);margin:10px 0}
.small{font-size:11px}
.col-12{grid-column:span 12}
.col-8{grid-column:span 8}
.col-6{grid-column:span 6}
.col-4{grid-column:span 4}
@media (max-width: 1100px){
    .layout{grid-template-columns:1fr}
    .sidebar{position:relative;height:auto}
    .indicators{margin-left:0}
}
@media (max-width: 900px){
    .col-8,.col-6,.col-4{grid-column:span 12}
}

.barwrap{margin-top:10px}
.bar{
    height:10px;border-radius:999px;border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.03);overflow:hidden;
}
.bar > span{
    display:block;height:100%;
    background:linear-gradient(90deg, rgba(96,165,250,.9), rgba(167,139,250,.9));
    width:0%;
}

.modal-backdrop{
    position:fixed;inset:0;background:rgba(0,0,0,.55);
    display:none;align-items:center;justify-content:center;z-index:50;
}
.modal{width:min(980px,92vw);max-height:86vh;overflow:auto;
    border-radius:16px;border:1px solid rgba(255,255,255,.10);
    background:linear-gradient(180deg, rgba(17,24,39,.98), rgba(15,23,42,.92));
    box-shadow:0 20px 60px rgba(0,0,0,.6);
}
.modal .hd{position:sticky;top:0;background:rgba(8,12,22,.85);backdrop-filter:blur(10px)}
pre{margin:0;padding:12px 14px;white-space:pre-wrap;word-break:break-word}
/* ML theme override */
body{
    background:
        radial-gradient(circle at top left, rgba(37,99,235,.16), transparent 28%),
        radial-gradient(circle at top right, rgba(14,165,233,.11), transparent 24%),
        linear-gradient(180deg,#04101f 0%,#071224 46%,#040b17 100%);
}
.sidebar{
    background:
        linear-gradient(180deg, rgba(10,20,38,.96), rgba(7,14,30,.96)),
        radial-gradient(circle at top left, rgba(56,189,248,.08), transparent 30%);
    border-right:1px solid rgba(147,197,253,.10);
}
.brand{
    padding:12px;
    border:1px solid rgba(147,197,253,.10);
    border-radius:18px;
    background:
        linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.01)),
        linear-gradient(180deg, rgba(15,23,42,.84), rgba(10,18,35,.92));
    box-shadow:0 16px 50px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.02);
}
.nav a{min-height:42px;border-radius:14px}
.nav a:hover{background:linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.015));border-color:rgba(147,197,253,.14)}
.nav a.active{background:linear-gradient(180deg, rgba(96,165,250,.16), rgba(96,165,250,.06));border-color:rgba(96,165,250,.28);box-shadow:0 8px 24px rgba(37,99,235,.12)}
.topbar{background:linear-gradient(180deg, rgba(8,16,33,.92), rgba(8,16,33,.78)),radial-gradient(circle at top right, rgba(59,130,246,.08), transparent 26%);border-bottom:1px solid rgba(147,197,253,.10);backdrop-filter:blur(16px)}
.ctl,.pill{background:rgba(6,16,34,.72);border-color:rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.02)}
.btn{border-color:rgba(255,255,255,.08);background:linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025));box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.btn:hover{border-color:rgba(96,165,250,.28);background:linear-gradient(180deg, rgba(96,165,250,.14), rgba(96,165,250,.06));box-shadow:0 8px 24px rgba(37,99,235,.14)}
.btn.primary{border-color:rgba(96,165,250,.30);background:linear-gradient(180deg, rgba(96,165,250,.20), rgba(96,165,250,.09))}
.btn.danger{border-color:rgba(239,68,68,.28);background:linear-gradient(180deg, rgba(239,68,68,.20), rgba(239,68,68,.08))}
.card{border-radius:20px;border:1px solid rgba(147,197,253,.10);background:linear-gradient(180deg, rgba(14,24,45,.96) 0%, rgba(8,16,33,.96) 100%);box-shadow:0 16px 50px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.02);overflow:hidden}
.card .hd{min-height:56px;padding:12px 14px;background:linear-gradient(180deg, rgba(255,255,255,.015), rgba(255,255,255,0)),linear-gradient(90deg, rgba(59,130,246,.06), transparent 35%)}
.card .hd h2{font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.045em}
.card .bd{padding:14px}
.chip,.badge,.tag{background:rgba(6,16,34,.78);border-color:rgba(255,255,255,.07);color:#c7d2fe;box-shadow:inset 0 1px 0 rgba(255,255,255,.02)}
.hr,.divider{background:linear-gradient(90deg, rgba(255,255,255,.06), rgba(255,255,255,.02), rgba(255,255,255,.06))}
.modal .hd{background:rgba(8,12,22,.88)}


/* unified header spacing */
.portfolio-page {
  gap: var(--page-gap) !important;
}

.portfolio-page .page-title,
.portfolio-page .page-subtitle {
  margin: 0 !important;
}

.portfolio-page > .grid,
.portfolio-page > .stack,
.portfolio-page > section + section {
  margin-top: 0 !important;
}


/* unified type rhythm */
.portfolio-page .page-title {
  font-size: 18px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
}

.portfolio-page .page-subtitle {
  font-size: 14px !important;
  line-height: 1.55 !important;
}

.portfolio-page .card .hd h2,
.portfolio-page .card h2 {
  font-size: 13px !important;
  line-height: 1.2 !important;
  font-weight: 900 !important;
  letter-spacing: 0.045em !important;
}

.portfolio-page .card .bd,
.portfolio-page .card .body,
.portfolio-page table,
.portfolio-page td,
.portfolio-page .kpi .v,
.portfolio-page .ref .v {
  font-size: 13px !important;
}

.portfolio-page th,
.portfolio-page .hint,
.portfolio-page .small,
.portfolio-page .kpi .sub,
.portfolio-page .ref .k {
  font-size: 11px !important;
}
