/* ===== Donezo 风格 · 数采看板 ===== */
:root{
  --bg:#f1f1f0;
  --card:#ffffff;
  --ink:#1c1e1d;
  --ink2:#797d7a;
  --line:#e8e9e8;
  --green-900:#131514;
  --green-700:#2c2f2d;
  --green-500:#6a706c;
  --green-300:#b4b8b5;
  --green-100:#ececeb;
  --ok:#52645a;    --ok-bg:#edf0ee;
  --amber:#8a7347; --amber-bg:#f4f0e7;
  --red:#9c4a41;   --red-bg:#f5ecea;
  --radius:16px;
  --shadow:0 1px 2px rgba(28,30,29,.04),0 8px 24px rgba(28,30,29,.06);
  --mono:"Cascadia Code",Consolas,"JetBrains Mono","SFMono-Regular",Menlo,monospace;
  font-size:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:"Segoe UI","PingFang SC","Microsoft YaHei",system-ui,sans-serif;
  background:var(--bg);color:var(--ink);
}
.hidden{display:none!important}
.mono{font-family:var(--mono)}

/* ===== 布局 ===== */
.layout{display:flex;min-height:100vh;max-width:1560px;margin:0 auto;padding:16px;gap:16px}
.sidebar{
  width:220px;flex:none;background:var(--card);border-radius:20px;box-shadow:var(--shadow);
  padding:22px 14px;display:flex;flex-direction:column;position:sticky;top:16px;height:calc(100vh - 32px);
}
.main{flex:1;min-width:0;display:flex;flex-direction:column;gap:16px}
.tab{display:flex;flex-direction:column;gap:16px}

/* ===== 侧边栏 ===== */
.logo{display:flex;align-items:center;gap:10px;padding:0 8px 20px}
.logo-mark{
  width:38px;height:38px;border-radius:12px;background:var(--green-700);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;
}
.logo-text{font-size:19px;font-weight:700}
.menu-label{font-size:11px;letter-spacing:.12em;color:var(--ink2);padding:8px 10px 6px;text-transform:uppercase}
.menu{display:flex;flex-direction:column;gap:2px}
.menu-item{
  display:flex;align-items:center;gap:10px;padding:11px 12px;border:none;background:none;
  border-radius:12px;font-size:14.5px;color:var(--ink2);cursor:pointer;text-align:left;font-weight:500;
}
.menu-item:hover{background:var(--green-100);color:var(--green-700)}
.menu-item.active{background:var(--green-100);color:var(--green-700);font-weight:700;position:relative}
.menu-item.active::before{content:"";position:absolute;left:-14px;top:20%;height:60%;width:4px;border-radius:4px;background:var(--green-700)}
.mi-icon{width:20px;text-align:center}
.sidebar-foot{margin-top:auto;padding:10px 8px}
.data-status{font-size:12px;color:var(--ink2);line-height:1.7;background:var(--bg);border-radius:12px;padding:10px 12px}
.demo-switch{display:block;margin-top:10px;font-size:12.5px;color:var(--green-700);text-decoration:none;padding:0 4px}
.demo-switch:hover{text-decoration:underline}

/* ===== 顶栏 ===== */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 22px}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px}
.page-title-wrap h1{font-size:24px;font-weight:800}
.subtitle{color:var(--ink2);font-size:13px;margin-top:3px}
.topbar-right{display:flex;align-items:center;gap:12px}
.snap-date{font-size:13px;color:var(--ink2);white-space:nowrap}
.badge-demo{
  background:var(--amber-bg);color:var(--amber);font-size:12.5px;font-weight:700;
  padding:6px 12px;border-radius:999px;white-space:nowrap;
}

/* ===== 控件 ===== */
.select,.input{
  border:1px solid var(--line);border-radius:10px;padding:8px 12px;font-size:13.5px;
  background:#fff;color:var(--ink);outline:none;font-family:inherit;
}
.select:focus,.input:focus{border-color:var(--green-500)}
.input{min-width:150px}
.filters{display:flex;gap:8px;flex-wrap:wrap}

/* ===== KPI 卡 ===== */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kpi{
  background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 22px;
  display:flex;flex-direction:column;gap:8px;position:relative;
}
.kpi .k-label{font-size:13.5px;font-weight:600;opacity:.95}
.kpi .k-value{font-size:32px;font-weight:800;letter-spacing:-.02em;font-family:var(--mono)}
.kpi .k-note{font-size:12px;color:var(--ink2)}

/* ===== 网格 ===== */
.grid-2{display:grid;grid-template-columns:5fr 7fr;gap:16px}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.card-head h2{font-size:16.5px;font-weight:700}
.hint{font-size:12px;color:var(--ink2);font-weight:400}
.chip{background:var(--green-100);color:var(--green-700);border-radius:999px;padding:4px 12px;font-size:12px;font-weight:600}
.legend{font-size:12.5px;color:var(--ink2);display:flex;align-items:center;gap:6px}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block}
.dot.g1{background:var(--green-700)} .dot.g2{background:var(--green-300)}

/* ===== 概要 ===== */
.summary-list{list-style:none;display:flex;flex-direction:column;gap:9px;max-height:320px;overflow-y:auto}
.summary-list li{
  background:var(--bg);border-radius:12px;padding:11px 14px;font-size:13.5px;line-height:1.55;
}
.summary-list li.warn{background:var(--amber-bg);color:var(--amber)}
.summary-list li.info{background:#eceef0;color:#5c6570}

/* ===== 表格 ===== */
.table-wrap{overflow-x:auto}
.table-wrap.freeze{max-height:max(340px,calc(100vh - 248px));overflow:auto}
.table-wrap.freeze thead th{
  position:sticky;top:0;z-index:3;background:var(--card);
  box-shadow:0 1px 0 var(--line);border-bottom:none;
}
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{
  text-align:left;color:var(--ink2);font-weight:600;font-size:12.5px;
  padding:10px 12px;border-bottom:1px solid var(--line);white-space:nowrap;
}
th.sortable{cursor:pointer;user-select:none}
th.sortable:hover{color:var(--ink)}
.sort-ind{font-size:9px;margin-left:3px;color:var(--green-700)}
td{padding:11px 12px;border-bottom:1px solid var(--line);white-space:nowrap}
tr:last-child td{border-bottom:none}
tbody tr.clickable{cursor:pointer}
tbody tr.clickable:hover{background:var(--green-100)}
.num{font-variant-numeric:tabular-nums;text-align:right;font-family:var(--mono)}
th.num{text-align:right;font-family:inherit}
.pos{color:var(--ok);font-weight:700}
.zero{color:var(--ink2)}
.rate-txt{font-family:var(--mono);font-variant-numeric:tabular-nums}
.rate-low{color:var(--red);font-weight:700;background:var(--red-bg);padding:2px 8px;border-radius:6px}
.sn-tag{font-size:11.5px;color:var(--ink2)}
.link-cell{cursor:pointer;color:var(--green-700);text-decoration:underline dotted;text-underline-offset:3px}
.link-cell:hover{color:var(--green-900);text-decoration-style:solid}
.person{display:flex;align-items:center;gap:10px}
.avatar{
  width:30px;height:30px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  font-size:12.5px;font-weight:700;color:#fff;
}
.p-sub{font-size:11.5px;color:var(--ink2)}

/* ===== 明细分组 ===== */
tr.group-row td{background:#f7f7f6;font-weight:600;cursor:pointer;user-select:none}
tr.group-row:hover td{background:var(--green-100)}
.tw-caret{display:inline-block;width:16px;color:var(--ink2);transition:transform .15s;font-size:11px}
.tw-caret.open{transform:rotate(90deg)}
td.td-task{white-space:normal;min-width:180px;padding-left:30px;color:var(--ink)}

/* ===== 弹出卡片 ===== */
.popover{
  position:fixed;z-index:70;background:#fff;border-radius:14px;padding:14px 16px;
  box-shadow:0 4px 12px rgba(28,30,29,.10),0 16px 48px rgba(28,30,29,.22);
  min-width:220px;max-width:360px;max-height:62vh;overflow-y:auto;
}
.popover.center{left:50%!important;top:50%!important;transform:translate(-50%,-50%)}
.pop-head{display:flex;align-items:center;gap:12px;margin-bottom:8px;position:sticky;top:-14px;background:#fff;padding:4px 0}
.pop-head h4{font-size:13.5px;font-weight:700;flex:1}
.pop-x{cursor:pointer;color:var(--ink2);font-size:13px;padding:2px 6px;border-radius:6px}
.pop-x:hover{background:var(--red-bg);color:var(--red)}
.sn-line{font-family:var(--mono);font-size:12.5px;padding:4px 0;border-bottom:1px dashed var(--line);color:var(--ink)}
.sn-line:last-child{border-bottom:none}
.user-line{display:flex;align-items:center;justify-content:space-between;gap:14px;font-size:13px;padding:5px 0;border-bottom:1px dashed var(--line)}
.user-line:last-child{border-bottom:none}
.user-line .u-id{font-family:var(--mono);font-size:11.5px;color:var(--ink2)}
.pop-empty{color:var(--ink2);font-size:12.5px;padding:6px 0}

/* ===== 分页 ===== */
.pager{display:flex;gap:6px;justify-content:center;padding-top:14px;flex-wrap:wrap}
.pager button{
  border:1px solid var(--line);background:#fff;border-radius:8px;padding:6px 12px;cursor:pointer;font-size:13px;
}
.pager button.cur{background:var(--green-700);color:#fff;border-color:var(--green-700);font-weight:700}
.pager .pg-info{align-self:center;font-size:12.5px;color:var(--ink2);padding:0 8px}

/* ===== 图表 ===== */
.chart{width:100%;min-height:200px;position:relative}
.chart svg{display:block;width:100%}
.axis-text{font-size:10.5px;fill:var(--ink2);font-family:var(--mono)}
.grid-line{stroke:var(--line);stroke-width:1}
.tooltip{
  position:fixed;z-index:99;background:#122e20;color:#fff;border-radius:10px;padding:8px 12px;
  font-size:12.5px;line-height:1.6;pointer-events:none;box-shadow:0 6px 20px rgba(0,0,0,.25);max-width:260px;
}

/* ===== 弹窗 ===== */
.modal-mask{
  position:fixed;inset:0;background:rgba(14,25,19,.45);z-index:50;
  display:flex;align-items:center;justify-content:center;padding:24px;
}
.modal{width:min(980px,96vw);max-height:92vh;overflow-y:auto;padding:24px 26px}
.modal-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:14px}
.modal-head h2{font-size:20px;font-weight:800}
.modal-close{
  margin-left:auto;order:3;border:none;background:var(--bg);width:34px;height:34px;border-radius:50%;
  cursor:pointer;font-size:14px;color:var(--ink2);flex:none;
}
.modal-close:hover{background:var(--red-bg);color:var(--red)}
.gran-group{display:flex;background:var(--bg);border-radius:10px;padding:3px;gap:2px;order:2;margin-left:auto}
.gran-group button{
  border:none;background:none;padding:7px 16px;border-radius:8px;cursor:pointer;font-size:13px;color:var(--ink2);font-weight:600;
}
.gran-group button.active{background:var(--green-700);color:#fff}
.modal-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}
.mk{background:var(--bg);border-radius:12px;padding:12px 14px}
.mk .k-label{font-size:12px;color:var(--ink2)}
.mk .k-value{font-size:20px;font-weight:800;margin-top:2px;font-family:var(--mono)}
.modal-charts{display:flex;flex-direction:column;gap:18px}
.modal-charts h3{font-size:13.5px;color:var(--ink2);font-weight:600;margin-bottom:6px}

/* ===== 响应式 ===== */
@media (max-width:1100px){
  .grid-2{grid-template-columns:1fr}
  .kpi-row{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:760px){
  .layout{flex-direction:column;padding:10px}
  .sidebar{width:100%;height:auto;position:static;flex-direction:row;align-items:center;gap:10px;padding:12px}
  .logo{padding:0}
  .menu{flex-direction:row;flex:1;overflow-x:auto}
  .menu-label,.sidebar-foot{display:none}
  .kpi-row{grid-template-columns:1fr 1fr}
  .modal-kpis{grid-template-columns:1fr 1fr}
}
