:root{
  --bg:#f4f3ee; --surface:#ffffff; --surface2:#f1efe8; --text:#23231f; --muted:#6c6b64;
  --border:rgba(0,0,0,.12); --border2:rgba(0,0,0,.22);
  --accent:#185fa5; --accent-bg:#e6f1fb; --green:#0f6e56; --green-bg:#e1f5ee;
  --red:#a32d2d; --amber:#854f0b; --radius:12px; --radius-sm:8px;
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
@media (prefers-color-scheme: dark){
  :root{ --bg:#1a1a18; --surface:#242420; --surface2:#2c2c28; --text:#ECEAE3; --muted:#a3a299;
    --border:rgba(255,255,255,.14); --border2:rgba(255,255,255,.28);
    --accent:#85b7eb; --accent-bg:#143049; --green:#5dcaa5; --green-bg:#0f3b30; --red:#f09595; --amber:#efb24f; }
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.5}
a{color:var(--accent);text-decoration:none}
h1{font-size:22px;font-weight:600;margin:0 0 8px}
h2{font-size:18px;font-weight:600;margin:0 0 12px}

.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:10px 18px;background:var(--surface);border-bottom:1px solid var(--border)}
.brand{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:600}
.brand .ico{color:var(--accent);font-style:normal}
.brand .accent{color:var(--accent)}
.tagline{font-size:12px;color:var(--muted);font-weight:400;margin-left:8px}
.topright{display:flex;align-items:center;gap:10px}
.langsw{display:flex;border:1px solid var(--border2);border-radius:var(--radius-sm);overflow:hidden}
.langsw a{padding:5px 10px;font-size:13px;color:var(--muted)}
.langsw a.on{background:var(--accent-bg);color:var(--accent)}
.btn{padding:6px 12px;border:1px solid var(--border2);border-radius:var(--radius-sm);font-size:13px;color:var(--text)}

.wrap{max-width:1120px;margin:0 auto;padding:18px}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:14px}
.muted{color:var(--muted)}
.err{color:var(--red);font-weight:500}
.note{font-size:12px;color:var(--muted);margin-top:6px}

/* upload */
.upload{max-width:620px;margin:40px auto}
.uprow{display:flex;align-items:center;gap:14px;margin:18px 0}
.filebtn{flex:1;display:flex;flex-direction:column;gap:6px;padding:14px;border:1px dashed var(--border2);
  border-radius:var(--radius-sm);font-size:13px;color:var(--muted);cursor:pointer}
.filebtn span{font-weight:500;color:var(--text)}
.or{color:var(--muted)}
.primary{padding:10px 18px;border:none;border-radius:var(--radius-sm);background:var(--accent);color:#fff;font-size:14px;cursor:pointer}
.primary:disabled{opacity:.45;cursor:not-allowed}

/* controller info */
.cinfo{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.cinfo-main{flex:1;min-width:180px}
.cname{font-size:17px;font-weight:600}
.badge{font-size:12px;padding:4px 10px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;gap:6px}
.b-blue{background:var(--accent-bg);color:var(--accent)}
.b-green{background:var(--green-bg);color:var(--green)}
.b-green .d{width:8px;height:8px;border-radius:50%;background:var(--green)}

/* layout */
.layout{display:grid;grid-template-columns:180px minmax(0,1fr);gap:16px;align-items:start}
.side{position:sticky;top:64px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:6px;display:flex;flex-direction:column;gap:2px}
.side a{padding:8px 10px;border-radius:var(--radius-sm);font-size:14px;color:var(--text)}
.side a:hover{background:var(--surface2)}
.content{min-width:0}
section{scroll-margin-top:70px;margin-bottom:8px}

.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:14px}
.mc{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px}
.ml{font-size:12px;color:var(--muted);margin-bottom:4px}
.mv{font-size:24px;font-weight:600}

.h{font-size:14px;font-weight:600;margin-bottom:10px}
.chartbox{position:relative;width:100%;height:220px}
.row{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-top:1px solid var(--border);flex-wrap:wrap}
.row:first-of-type{border-top:none}
.rname{font-weight:500}
.rmeta{font-size:12px;color:var(--muted)}
.tag{font-style:normal;background:var(--surface2);padding:1px 7px;border-radius:6px;font-size:11px;color:var(--muted)}
.tag-info{background:var(--accent-bg);color:var(--accent)}

.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{font-size:12px;padding:5px 10px;border-radius:var(--radius-sm);background:var(--surface2);border:1px solid var(--border)}

.objh{margin:22px 0 10px}
.objsec{margin-bottom:18px}
.objhead{display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap;align-items:baseline;margin-bottom:6px}
.objtitle{font-weight:600;font-size:15px}

.tablewrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface)}
table{border-collapse:collapse;width:100%;font-size:13px;white-space:nowrap}
th,td{padding:6px 10px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
th{background:var(--surface2);font-weight:600;position:sticky;top:0}
td.num,td:last-child{}
tbody tr:hover{background:var(--surface2)}

@media (max-width:760px){
  .layout{grid-template-columns:1fr}
  .side{position:static;flex-direction:row;flex-wrap:wrap}
}
