/* =========================================================================
   标段生命周期管理系统 · 设计系统（工程可信 / 企业仪表盘）
   token → base → 布局 → 组件。无外部依赖。
   ========================================================================= */

/* ---------- 设计令牌 ---------- */
:root{
  /* 表面与文字 */
  --bg:#eef2f8;
  --surface:#ffffff;
  --surface-2:#f7f9fc;
  --sidebar:#0f1a2e;
  --sidebar-2:#17243f;
  --sidebar-line:#243352;
  --sidebar-fg:#9bb0cd;
  --sidebar-fg-strong:#e9eff8;
  --ink:#0f1a2e;
  --ink-2:#3a4a64;
  --muted:#6c7c95;
  --line:#e2e8f1;
  --line-2:#eef1f7;

  /* 主色（钢蓝） */
  --primary:#1d4ed8;
  --primary-strong:#1e40af;
  --primary-soft:#eaf1ff;

  /* 语义色 */
  --pass:#15803d;  --pass-soft:#ecfdf3;  --pass-line:#bbf7d0;
  --warn:#b07912;  --warn-soft:#fff7e6;  --warn-line:#f4d480;
  --fail:#c0392b;  --fail-soft:#fdeceb;  --fail-line:#f1c5c0;

  /* 字号 */
  --fs-12:12px; --fs-13:13px; --fs-14:14px; --fs-16:16px;
  --fs-18:18px; --fs-22:22px; --fs-28:28px;

  /* 间距 / 圆角 / 阴影 */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px; --sp-5:20px;
  --sp-6:24px; --sp-8:32px;
  --r-sm:6px; --r:8px; --r-lg:12px; --r-pill:999px;
  --sh-1:0 1px 2px rgba(15,26,46,.05);
  --sh-2:0 1px 3px rgba(15,26,46,.07),0 1px 2px rgba(15,26,46,.04);
  --sh-side:0 0 0 1px rgba(15,26,46,.04);

  --side-w:232px;
  --sans:-apple-system,"Segoe UI","PingFang SC","Microsoft YaHei","Noto Sans SC",sans-serif;
  --mono:"SF Mono","Cascadia Code","JetBrains Mono",Consolas,monospace;
}

/* ---------- 基础 ---------- */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  font-size:var(--fs-14);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-strong)}
h1,h2,h3{margin:0;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.icon{width:16px;height:16px;flex:none;stroke:currentColor;fill:none;stroke-width:1.8}
.muted{color:var(--muted)}
.unit{color:var(--muted);font-size:var(--fs-12);font-weight:400;margin-left:4px}

/* =========================================================================
   布局外壳
   ========================================================================= */
.app{display:flex;min-height:100vh}

/* ---------- 侧栏 ---------- */
.sidebar{
  position:fixed;top:0;left:0;bottom:0;width:var(--side-w);
  background:var(--sidebar);color:var(--sidebar-fg);
  display:flex;flex-direction:column;z-index:40;
}
.brand{display:flex;align-items:center;gap:11px;padding:18px 18px 16px}
.brand .logo{width:32px;height:32px;flex:none;color:#7aa2ff}
.brand b{color:var(--sidebar-fg-strong);font-size:var(--fs-18);line-height:1.2;letter-spacing:.01em}
.brand small{display:block;color:var(--sidebar-fg);font-size:var(--fs-12);font-weight:400}
.nav{padding:8px 10px;display:flex;flex-direction:column;gap:2px}
.nav-sec{padding:14px 18px 6px;font-size:var(--fs-12);letter-spacing:.04em;
  color:var(--sidebar-fg);opacity:.7}
.nav-item{
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r-sm);
  color:var(--sidebar-fg);font-size:var(--fs-14);position:relative;
}
.nav-item .icon{width:17px;height:17px;color:var(--sidebar-fg)}
.nav-item:hover{background:var(--sidebar-2);color:var(--sidebar-fg-strong)}
.nav-item.active{background:var(--sidebar-2);color:#fff;font-weight:500}
.nav-item.active::before{content:"";position:absolute;left:0;top:7px;bottom:7px;width:3px;
  border-radius:0 3px 3px 0;background:#5b8cff}
.nav-item.active .icon{color:#7aa2ff}
.sidebar-foot{margin-top:auto;padding:14px 18px;border-top:1px solid var(--sidebar-line);
  font-size:var(--fs-12);color:var(--sidebar-fg);line-height:1.6}
.sidebar-foot b{color:var(--sidebar-fg-strong)}

/* ---------- 主列 ---------- */
.main{flex:1;min-width:0;margin-left:var(--side-w);display:flex;flex-direction:column}
.topbar{
  position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:16px;
  background:rgba(255,255,255,.92);backdrop-filter:saturate(1.4) blur(6px);
  border-bottom:1px solid var(--line);padding:12px 28px;
}
/* 标段内业务动作 Tab（顶部子导航，仅已建账标段显示） */
.section-tabs{display:flex;gap:0;padding:0 20px;background:var(--surface);
  border-bottom:1px solid var(--line);overflow-x:auto;position:sticky;top:49px;z-index:20}
.stab{padding:11px 14px;font-size:var(--fs-14);color:var(--ink-2);
  border-bottom:2px solid transparent;white-space:nowrap;display:inline-flex;
  align-items:center;gap:7px;text-decoration:none}
.stab .icon{width:15px;height:15px;flex:none}
.stab:hover{color:var(--ink);background:var(--surface-2)}
.stab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}
.nav .nav-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
.nav-item{min-width:0}
.menu-btn{display:none;width:34px;height:34px;border:1px solid var(--line);background:#fff;
  border-radius:var(--r-sm);align-items:center;justify-content:center;color:var(--ink-2);cursor:pointer}
.topbar-title{font-size:var(--fs-16);font-weight:600}
.topbar-title .crumb{color:var(--muted);font-weight:400}
.topbar-meta{margin-left:auto;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.status-badge{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-13);font-weight:600;
  padding:5px 11px;border-radius:var(--r-pill);border:1px solid transparent}
.status-badge .icon{width:14px;height:14px}
.status-badge.pass{background:var(--pass-soft);color:var(--pass);border-color:var(--pass-line)}
.status-badge.warn{background:var(--warn-soft);color:var(--warn);border-color:var(--warn-line)}
.status-badge.fail{background:var(--fail-soft);color:var(--fail);border-color:var(--fail-line)}

.content{padding:24px 28px 40px;max-width:1280px;width:100%}
.foot{padding:18px 28px 28px;color:var(--muted);font-size:var(--fs-12)}

.scrim{display:none}

/* =========================================================================
   排版与通用
   ========================================================================= */
.page-head{margin-bottom:var(--sp-5)}
.page-title{font-size:var(--fs-22);font-weight:600}
.page-sub{color:var(--muted);margin-top:4px;font-size:var(--fs-13)}
.section-title{font-size:var(--fs-16);font-weight:600;margin:30px 0 12px;display:flex;align-items:center;gap:8px}
.section-title:first-child{margin-top:0}
.section-title .icon{color:var(--primary)}
.section-title .hint{margin-left:auto;font-size:var(--fs-12);color:var(--muted);font-weight:400}

.note{background:var(--warn-soft);border:1px solid var(--warn-line);border-radius:var(--r);
  padding:10px 14px;font-size:var(--fs-13);color:var(--ink-2)}
.note.blue{background:var(--primary-soft);border-color:#bcd2ff;color:var(--primary-strong)}
.note .icon{color:var(--warn);width:15px;height:15px;vertical-align:-2px;margin-right:4px}
.note.blue .icon{color:var(--primary)}

/* =========================================================================
   组件：KPI / 链 / 表格 / 护栏 / 校验 / 标签 / 卡片
   ========================================================================= */

/* KPI 卡 */
.kpi-grid{display:grid;gap:12px}
.kpi-grid.g4{grid-template-columns:repeat(4,1fr)}
.kpi-grid.g3{grid-template-columns:repeat(3,1fr)}
.kpi-grid.g2{grid-template-columns:repeat(2,1fr)}
.kpi{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:14px 16px;box-shadow:var(--sh-1)}
.kpi .label{color:var(--muted);font-size:var(--fs-12);display:flex;align-items:center;gap:6px}
.kpi .value{font-size:var(--fs-28);font-weight:700;font-variant-numeric:tabular-nums;
  margin-top:6px;letter-spacing:-.02em;line-height:1.1}
.kpi .value.sm{font-size:var(--fs-22)}
.kpi .sub{color:var(--muted);font-size:var(--fs-12);margin-top:4px;font-variant-numeric:tabular-nums}
.kpi.accent{border-top:3px solid var(--primary)}
.kpi.accent.pass{border-top-color:var(--pass)}

/* 全链步进条 */
.chain{display:flex;align-items:stretch;gap:0;margin-top:6px}
.chain-step{flex:0 1 auto;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:12px 16px;min-width:148px;text-align:center;box-shadow:var(--sh-1)}
.chain-step .label{font-size:var(--fs-12);color:var(--muted)}
.chain-step .value{font-size:var(--fs-18);font-weight:700;font-variant-numeric:tabular-nums;margin-top:3px}
.chain-step.final{border:2px solid var(--pass);background:var(--pass-soft)}
.chain-step.final .value{color:var(--pass)}
.chain-step .sub{font-size:var(--fs-11);color:var(--muted);margin-top:2px}
.chain-sep{flex:1 1 auto;min-width:20px;position:relative}
.chain-sep::before{content:"";position:absolute;left:4px;right:4px;top:50%;height:2px;
  background:var(--line);transform:translateY(-50%)}
.chain-sep::after{content:"";position:absolute;right:2px;top:50%;transform:translateY(-50%);
  border-left:7px solid var(--primary);border-top:5px solid transparent;border-bottom:5px solid transparent}

/* 元信息条 */
.meta-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:6px 0 4px}
.meta{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:10px 14px}
.meta .label{font-size:var(--fs-12);color:var(--muted)}
.meta .value{font-size:var(--fs-14);font-weight:600;margin-top:2px;font-variant-numeric:tabular-nums}

/* 表格 */
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1)}
.table-wrap.scroll-y{max-height:70vh}
table.tbl{width:100%;border-collapse:collapse;background:var(--surface);font-size:var(--fs-13)}
table.tbl th,table.tbl td{padding:8px 12px;text-align:left;vertical-align:middle;border-bottom:1px solid var(--line-2)}
table.tbl thead th{position:sticky;top:0;background:var(--surface-2);font-weight:600;color:var(--ink-2);
  font-size:var(--fs-12);border-bottom:1px solid var(--line);white-space:nowrap;z-index:1}
table.tbl tbody tr:hover{background:var(--primary-soft)}
table.tbl .num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
table.tbl .code{font-family:var(--mono);font-size:var(--fs-12);color:var(--ink-2)}
table.tbl .neg{color:var(--fail);font-weight:600}
table.tbl tr.total td{font-weight:700;background:var(--surface-2);border-top:2px solid var(--line)}
table.tbl tr.ch-head td{background:#eef3fb;font-weight:700;color:var(--primary-strong);
  font-size:var(--fs-12);letter-spacing:.02em}
table.tbl tr.pass{background:var(--pass-soft)}
table.tbl tr.warn{background:var(--warn-soft)}
table.tbl tr.fail{background:var(--fail-soft)}
table.tbl caption{caption-side:top;text-align:left;padding:8px 4px;color:var(--muted);font-size:var(--fs-12)}

/* 护栏卡 */
.guard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.guard{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--muted);
  border-radius:var(--r);padding:13px 15px;box-shadow:var(--sh-1)}
.guard.pass{border-left-color:var(--pass)} .guard.warn{border-left-color:var(--warn)} .guard.fail{border-left-color:var(--fail)}
.guard .ghead{display:flex;align-items:center;gap:8px;font-weight:600;font-size:var(--fs-14)}
.guard .ghead .icon{width:16px;height:16px}
.guard.pass .ghead .icon{color:var(--pass)} .guard.warn .ghead .icon{color:var(--warn)} .guard.fail .ghead .icon{color:var(--fail)}
.guard .gmsg{font-size:var(--fs-13);color:var(--ink-2);margin-top:6px}
.guard .gmsg.dim{color:var(--muted);font-size:var(--fs-12)}

/* 校验卡 */
.check-list{display:flex;flex-direction:column;gap:10px}
.check{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--muted);
  border-radius:var(--r);padding:12px 15px;box-shadow:var(--sh-1)}
.check.pass{border-left-color:var(--pass)} .check.warn{border-left-color:var(--warn);background:var(--warn-soft)} .check.fail{border-left-color:var(--fail)}
.check .row1{display:flex;align-items:center;gap:8px;font-size:var(--fs-14)}
.check .row1 .icon{width:16px;height:16px;flex:none}
.check.pass .icon{color:var(--pass)} .check.warn .icon{color:var(--warn)} .check.fail .icon{color:var(--fail)}
.check .row1 b{font-weight:600}
.check .row1 .tag{margin-left:auto;font-size:var(--fs-12);color:var(--muted)}
.check .desc{color:var(--muted);font-size:var(--fs-13);margin-top:4px}
.check .details{margin-top:8px;color:var(--muted);font-size:var(--fs-12)}
.check details summary{cursor:pointer;color:var(--primary);font-size:var(--fs-12)}

/* 药丸标签 */
.pill{display:inline-flex;align-items:center;gap:5px;font-size:var(--fs-12);font-weight:600;
  padding:3px 9px;border-radius:var(--r-pill);border:1px solid transparent}
.pill .icon{width:13px;height:13px}
.pill.pass{background:var(--pass-soft);color:var(--pass);border-color:var(--pass-line)}
.pill.warn{background:var(--warn-soft);color:var(--warn);border-color:var(--warn-line)}
.pill.fail{background:var(--fail-soft);color:var(--fail);border-color:var(--fail-line)}
.pill.muted{background:var(--surface-2);color:var(--muted);border-color:var(--line)}

/* 横幅 */
.banner{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--r-lg);
  font-weight:600;font-size:var(--fs-14);border:1px solid transparent;margin-bottom:var(--sp-4)}
.banner .icon{width:18px;height:18px}
.banner.pass{background:var(--pass-soft);color:var(--pass);border-color:var(--pass-line)}
.banner.warn{background:var(--warn-soft);color:var(--warn);border-color:var(--warn-line)}
.banner.fail{background:var(--fail-soft);color:var(--fail);border-color:var(--fail-line)}

/* 分段控件（期次 tab） */
.tabs{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);
  padding:4px;gap:4px;margin:6px 0 4px}
.tab{padding:7px 16px;border-radius:var(--r-sm);color:var(--ink-2);font-size:var(--fs-13);font-weight:500;
  display:inline-flex;align-items:center;gap:8px}
.tab:hover{background:var(--surface-2)}
.tab.active{background:var(--primary);color:#fff}
.tab.active .muted,.tab.active .unit{color:rgba(255,255,255,.8)}

/* 通用卡 + kv */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:16px;box-shadow:var(--sh-1)}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;margin-top:12px}
.tile{display:block;background:var(--surface);border:1px solid var(--line);border-top:3px solid var(--muted);
  border-radius:var(--r-lg);padding:16px;color:var(--ink);box-shadow:var(--sh-1);transition:transform .12s,box-shadow .12s}
.tile:hover{transform:translateY(-2px);box-shadow:var(--sh-2)}
.tile.pass{border-top-color:var(--pass)} .tile.warn{border-top-color:var(--warn)} .tile.fail{border-top-color:var(--fail)}
.tile-title{font-weight:600;font-size:var(--fs-15);margin-bottom:10px;line-height:1.35}
.kv{display:flex;justify-content:space-between;font-size:var(--fs-13);margin:4px 0}
.kv .k{color:var(--muted)} .kv .v{font-variant-numeric:tabular-nums;font-weight:600}
.tile-foot{margin-top:10px;font-size:var(--fs-13)}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.chip{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-pill);
  padding:5px 12px;font-size:var(--fs-12);color:var(--ink-2)}
.chip b{color:var(--ink);font-weight:700}

/* 输入 vs 派生 行标签 */
.tag-input{display:inline-block;font-size:var(--fs-11);font-weight:600;padding:2px 8px;border-radius:var(--r-pill);
  background:var(--primary-soft);color:var(--primary-strong)}
.tag-derive{display:inline-block;font-size:var(--fs-11);font-weight:600;padding:2px 8px;border-radius:var(--r-pill);
  background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line)}
.ok{color:var(--pass);font-weight:600} .ko{color:var(--warn);font-weight:600}

/* 结算瀑布（横向条） */
.waterfall{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.wf-row{display:grid;grid-template-columns:200px 1fr 150px;align-items:center;gap:14px}
.wf-label{font-size:var(--fs-13);color:var(--ink-2)}
.wf-label b{color:var(--ink);font-weight:600}
.wf-track{height:22px;background:var(--surface-2);border-radius:var(--r-sm);overflow:hidden}
.wf-bar{height:100%;border-radius:var(--r-sm);background:var(--primary);min-width:3px}
.wf-row.plus .wf-bar{background:var(--pass)}
.wf-row.minus .wf-bar{background:var(--warn)}
.wf-row.total .wf-bar{background:var(--primary-strong)}
.wf-amt{text-align:right;font-variant-numeric:tabular-nums;font-weight:700;font-size:var(--fs-14)}
.wf-amt small{display:block;font-size:var(--fs-11);color:var(--muted);font-weight:400}

/* =========================================================================
   响应式
   ========================================================================= */
@media (max-width: 980px){
  .kpi-grid.g4{grid-template-columns:repeat(2,1fr)}
  .kpi-grid.g3{grid-template-columns:repeat(2,1fr)}
  .guard-grid{grid-template-columns:1fr}
  .meta-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width: 760px){
  .sidebar{transform:translateX(-100%);transition:transform .2s ease;box-shadow:0 0 40px rgba(0,0,0,.3)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .menu-btn{display:inline-flex}
  .scrim.show{display:block;position:fixed;inset:0;background:rgba(15,26,46,.4);z-index:35}
  .content,.topbar,.foot{padding-left:18px;padding-right:18px}
  .kpi-grid.g4,.kpi-grid.g3,.kpi-grid.g2{grid-template-columns:1fr}
  .chain{flex-wrap:wrap}
  .chain-sep{display:none}
  .chain-step{flex:1 1 45%}
  .wf-row{grid-template-columns:1fr;gap:4px}
  .wf-amt{text-align:left}
}

/* =========================================================================
   打印
   ========================================================================= */
@media print{
  .sidebar,.menu-btn,.topbar .status-badge,.foot{display:none!important}
  .main{margin-left:0}
  .content{padding:0;max-width:none}
  body{background:#fff}
  .card,.kpi,.tbl,.guard,.check,.tile,.banner,.table-wrap{box-shadow:none!important;break-inside:avoid}
  a{color:var(--ink)}
}

/* =========================================================================
   表单 / 按钮
   ========================================================================= */
.form{max-width:820px}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:6px}
.field{display:flex;flex-direction:column;gap:5px;font-size:var(--fs-13)}
.field>span{color:var(--ink-2);font-weight:500}
.field em{font-style:normal;font-weight:400;color:var(--muted);margin-left:4px}
.field input,.field select,.field textarea{padding:8px 10px;border:1px solid var(--line);
  border-radius:var(--r);font-size:var(--fs-14);font-family:inherit;background:#fff;color:var(--ink)}
.field input[type=file]{padding:6px 8px;background:var(--surface-2)}
.field input:focus,.field select:focus{outline:none;border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-soft)}
.form-actions{display:flex;gap:10px;margin-top:20px;align-items:center}
.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;border-radius:var(--r);
  border:1px solid var(--line);background:#fff;color:var(--ink);font-size:var(--fs-14);
  font-weight:500;cursor:pointer;text-decoration:none}
.btn:hover{background:var(--surface-2);color:var(--ink)}
.btn .icon{width:15px;height:15px}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-strong);color:#fff}
.btn-ghost{background:transparent}
.upload-zone{border:2px dashed var(--line);border-radius:var(--r-lg);padding:24px;text-align:center;
  color:var(--muted);background:var(--surface-2)}
.upload-zone .icon{width:28px;height:28px;color:var(--primary);margin-bottom:6px}
.empty-state{text-align:center;padding:40px 20px;color:var(--muted)}
.empty-state .icon{width:36px;height:36px;color:var(--line);margin-bottom:8px}
@media(max-width:680px){.form-grid{grid-template-columns:1fr}}
