@font-face{font-family:Jmono;font-weight:400 550;font-display:swap;src:url("jmono-medium.ttf") format("truetype")}
@font-face{font-family:Jmono;font-weight:600 800;font-display:swap;src:url("jmono-bold.ttf") format("truetype")}
:root{
  --sheet:#fff;
  --ink:#16171d;--ink-2:#5b6070;--ink-3:#8a8f9c;--ink-4:#b6bac6;
  --line:#eef0f3;--line-2:#f4f5f7;--sunken:#f7f8fa;--hover:#f4f9ff;
  --pri:#1677ff;--pri-deep:#0e5fd8;--pri-tint:#e8f1ff;--pri-tint-2:#f2f7ff;
  --page-bg:#e9edf3;
  --chart-blue:#1677ff;--chart-teal:#20c4a6;--chart-amber:#ffa63d;--chart-red:#f0483b;
  --r-high:#e5484d;--r-high-bg:#fdecec;--r-mid:#e8973a;--r-mid-bg:#fdf1e0;--r-low:#3d8bef;--r-low-bg:#eaf2fd;--r-done:#1f9f6b;--r-done-bg:#e7f6ef;
  --sh-1:0 1px 2px rgba(22,30,55,.05);--sh-2:0 2px 18px rgba(20,30,55,.06);
  --primary:var(--pri);--accent:var(--pri);--blue:var(--chart-blue);--green:var(--chart-teal);--orange:var(--chart-amber);--red:var(--chart-red);--yellow:#f0b400;--cyan:#20c4a6;
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei",sans-serif;background:var(--page-bg);color:var(--ink);font-size:14px;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button,input,select{font:inherit}
.tnum,.value,.num,strong,b{font-variant-numeric:tabular-nums}

/* Shared shell: same visual language as the approved home page, without repeating the home hero */
.system-shell{
  min-height:100vh;
  background:
    linear-gradient(to bottom,rgba(233,237,243,0) 0,rgba(233,237,243,.42) 138px,var(--page-bg) 250px),
    url("bg5.png") right top / 900px auto no-repeat,
    var(--page-bg);
}
.topbar{height:68px;display:flex;align-items:center;gap:16px;padding:15px 26px;color:var(--ink);position:relative;z-index:5}
.brand{display:flex;align-items:center;gap:10px;color:var(--ink);flex:none;font-weight:700;white-space:nowrap}
.brand img{width:34px;height:34px;object-fit:contain}
.brand span{font-size:16px}
.topnav{display:flex;gap:4px;flex:1;justify-content:center;align-items:center}
.topnav a{display:flex;align-items:center;height:38px;padding:0 16px;border-radius:19px;color:#3f475a;text-decoration:none;font-size:14px;cursor:pointer;border:1px solid transparent;transition:background-color .18s,color .18s,border-color .18s}
.topnav a.active{background:rgba(255,255,255,.72);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #fff;color:var(--pri);font-weight:600;box-shadow:0 4px 12px rgba(10,20,50,.12)}
.topnav a:hover:not(.active){background:rgba(255,255,255,.45);color:var(--pri)}
.top-user{display:flex;align-items:center;gap:14px;flex:none;color:#3f475a}
.company{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer;height:38px;padding:0 14px;border-radius:19px;background:rgba(255,255,255,.55);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(22,30,55,.1);color:#3f475a}
.bell{width:38px;height:38px;border-radius:50%;border:1px solid rgba(22,30,55,.1);background:rgba(255,255,255,.55);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;color:#3f475a;font-size:18px;position:relative}
.bell:after{content:"66";position:absolute;top:-2px;right:-2px;min-width:16px;height:16px;padding:0 4px;background:var(--r-high);color:#fff;border-radius:8px;font-size:10px;line-height:16px;text-align:center;border:2px solid #fff;font-weight:600}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--pri);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;box-shadow:inset 0 1px 0 rgba(255,255,255,.4),0 2px 8px rgba(22,119,255,.35)}

.workspace{display:flex;gap:16px;min-height:calc(100vh - 68px);padding:0 16px 22px}
.sidebar{width:220px;flex:none;background:rgba(255,255,255,.78);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #fff;border-radius:16px;box-shadow:var(--sh-2);padding:10px;overflow:auto}
.menu-group{border-bottom:1px solid var(--line-2);padding:6px 0}
.menu-title{height:36px;display:flex;align-items:center;justify-content:space-between;color:var(--ink);font-weight:600;padding:0 10px;border-radius:10px}
.menu-item{height:36px;display:flex;align-items:center;padding:0 10px 0 28px;color:var(--ink-2);border-radius:10px;margin:2px 0;position:relative;white-space:nowrap;transition:background-color .16s,color .16s}
.menu-item:hover{background:rgba(255,255,255,.72);color:var(--pri)}
.menu-item.active{background:var(--pri-tint);color:var(--pri);font-weight:600}
.menu-item.active:before{content:"";position:absolute;left:10px;top:50%;width:7px;height:7px;border-radius:50%;background:var(--pri);transform:translateY(-50%)}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.tabs{height:38px;display:flex;align-items:center;gap:6px;margin:0 0 12px;padding:2px;background:rgba(255,255,255,.55);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #fff;border-radius:14px;box-shadow:var(--sh-1);overflow:auto}
.tab{height:30px;display:flex;align-items:center;gap:8px;padding:0 13px;border-radius:9px;font-size:13px;color:var(--ink-2);white-space:nowrap}
.tab.active{background:var(--pri-tint);color:var(--pri);font-weight:600}
.tab i{font-size:14px;color:var(--ink-3)}
.tab.active i{color:var(--pri)}
.content{overflow:auto;padding:0}

.page-card{background:var(--sheet);border:0;border-radius:16px;box-shadow:var(--sh-2);overflow:hidden}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;padding:24px 24px 20px;background:linear-gradient(180deg,#fff 0,#fff 62%,#fbfcff 100%);border-bottom:1px solid var(--line)}
.page-title{font-size:26px;line-height:1.2;font-weight:760;color:var(--ink);margin:0 0 7px;letter-spacing:-.2px}
.page-sub{color:var(--ink-3);font-size:13px}
.toolbar{display:flex;gap:12px;align-items:center}
.select-like,.input-like{height:34px;min-width:120px;border:1px solid var(--line);border-radius:9px;background:rgba(255,255,255,.86);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 12px;color:var(--ink-2);box-shadow:var(--sh-1)}
.btn{height:34px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink-2);padding:0 16px;display:inline-flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:transform .16s,background-color .16s,color .16s,border-color .16s}
.btn:hover{color:var(--pri);border-color:#cfe0ff;background:#f8fbff}
.btn:active{transform:scale(.98)}
.btn.primary{background:var(--pri);border-color:var(--pri);color:#fff;box-shadow:0 4px 12px rgba(22,119,255,.22)}
.btn.link{border-color:#cfe0ff;color:var(--pri);background:#fff}
.btn.danger{border-color:#ffd6d3;color:var(--r-high)}

.filter-card{display:grid;grid-template-columns:repeat(5,minmax(150px,1fr));gap:16px;align-items:end;background:rgba(255,255,255,.82);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid #fff;border-radius:16px;box-shadow:var(--sh-2);padding:20px;margin-bottom:16px}
.field label{display:block;color:var(--ink);margin-bottom:8px;font-weight:500}
.field .input-like,.field .select-like{height:34px;width:100%;color:var(--ink-3)}
.filter-actions{display:flex;gap:8px;justify-content:flex-end;grid-column:1 / -1}

.kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;padding:20px}
.kpi{min-height:118px;background:linear-gradient(180deg,#fff,#f7faff);border:1px solid var(--line);border-radius:16px;box-shadow:var(--sh-1);padding:18px 20px;position:relative;overflow:hidden}
.kpi:before{content:"";position:absolute;left:0;top:18px;bottom:18px;width:4px;border-radius:4px;background:var(--chart-blue)}
.kpi.red{background:#fff8f8}.kpi.red:before{background:var(--chart-red)}
.kpi.orange{background:#fffaf1}.kpi.orange:before{background:var(--chart-amber)}
.kpi.green{background:#f6fcf9}.kpi.green:before{background:var(--chart-teal)}
.kpi.gray{background:#fafafa}.kpi.gray:before{background:#9aa0aa}
.kpi .label{color:var(--ink-2);margin-bottom:10px}
.kpi .value{font:760 30px/1 Jmono,monospace;color:var(--chart-blue);letter-spacing:-.5px}
.kpi.red .value{color:var(--chart-red)}.kpi.orange .value{color:var(--chart-amber)}.kpi.green .value{color:var(--chart-teal)}.kpi.gray .value{color:#828894}
.kpi .trend{margin-top:12px;font-size:12px;color:var(--r-high)}
.kpi .trend.down{color:var(--r-done)}

.section{background:#fff;border-top:1px solid var(--line);padding:24px 20px}
.section-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.section-grid.three{grid-template-columns:1.08fr .88fr 1.04fr;gap:18px}
.section-title{font-size:20px;font-weight:760;margin:0 0 16px;color:var(--ink);letter-spacing:-.1px}
.section-note{font-size:12px;color:var(--ink-3);margin-top:-8px;margin-bottom:12px}
.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
.data-table th{height:36px;background:#fafbfc;color:var(--ink-3);font-weight:500;text-align:left;border-bottom:1px solid var(--line);padding:0 12px;word-break:keep-all}
.data-table td{height:36px;border-bottom:1px solid var(--line-2);padding:6px 12px;color:var(--ink-2);line-height:1.45;word-break:keep-all}
.data-table tr:last-child td{border-bottom:0}
.data-table tbody tr:hover td{background:var(--hover)}
.tag{display:inline-flex;align-items:center;height:22px;padding:0 8px;border-radius:5px;font-size:12px;font-weight:500;background:var(--sunken);color:var(--ink-2);font-style:normal;white-space:nowrap}
.tag.green{background:var(--r-done-bg);color:var(--r-done)}.tag.orange{background:var(--r-mid-bg);color:var(--r-mid)}.tag.red{background:var(--r-high-bg);color:var(--r-high)}.tag.blue{background:var(--r-low-bg);color:var(--r-low)}.tag.yellow{background:#fff7d6;color:#aa7a00}

.gauge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px 36px}
.gauge{text-align:center;min-width:0}
.gauge .name{font-weight:700;margin-bottom:10px;color:var(--ink)}
.dial{width:86px;height:48px;margin:0 auto 8px;position:relative;overflow:hidden}
.dial:before{content:"";position:absolute;inset:0;border-radius:90px 90px 0 0;background:conic-gradient(from 270deg,var(--chart-teal) 0 42%,var(--chart-amber) 42% 70%,var(--chart-red) 70% 100%);transform-origin:50% 100%}
.dial:after{content:"";position:absolute;left:16px;right:16px;bottom:0;height:31px;background:#fff;border-radius:50px 50px 0 0}
.needle{position:absolute;width:34px;height:4px;background:var(--chart-blue);left:45px;bottom:4px;transform-origin:0 50%;clip-path:polygon(0 50%,100% 0,85% 50%,100% 100%)}
.gauge .num{font:760 16px/1 Jmono,monospace;margin-top:4px}
.gauge .threshold{font-size:12px;color:var(--ink-3);margin-top:4px}
.metric-list{display:grid;gap:10px}
.metric-row{display:grid;grid-template-columns:1fr auto;align-items:center;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:#fbfcff}
.metric-row strong{font:760 22px/1 Jmono,monospace;color:var(--chart-blue)}
.bars{display:grid;gap:12px}
.bar-row{display:grid;grid-template-columns:130px 1fr 56px;align-items:center;gap:12px}
.bar-track{height:10px;background:#edf2f9;border-radius:8px;overflow:hidden}
.bar-track span{display:block;height:100%;border-radius:8px;background:linear-gradient(90deg,var(--chart-blue),var(--chart-teal))}
.rank-list{display:grid;gap:8px}
.rank-item{display:grid;grid-template-columns:28px 1fr auto;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:12px;background:#fff}
.rank-no{height:24px;width:24px;border-radius:7px;background:var(--pri-tint);color:var(--pri);display:flex;align-items:center;justify-content:center;font:700 13px/1 Jmono}
.rank-item:nth-child(-n+3) .rank-no{background:var(--pri);color:#fff}
.chart-box{border:1px solid var(--line);border-radius:12px;background:#fff;min-height:210px;padding:14px;box-shadow:var(--sh-1)}
.pie-wrap{display:flex;align-items:center;gap:18px}
.pie{width:128px;height:128px;border-radius:50%;background:conic-gradient(var(--chart-blue) 0 55%,var(--chart-teal) 55% 85%,var(--chart-amber) 85% 100%);position:relative;flex:none}
.pie:after{content:"";position:absolute;inset:32px;background:#fff;border-radius:50%}
.legend{display:grid;gap:8px;color:var(--ink-2)}
.legend span{display:inline-flex;align-items:center;gap:6px}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block;background:currentColor}
.heat-matrix{display:grid;grid-template-columns:repeat(5,1fr);gap:5px;max-width:260px}
.heat-cell{height:30px;border-radius:5px;background:#e8f7fb}
.heat-cell.lv1{background:#dff8f5}.heat-cell.lv2{background:#bfeee8}.heat-cell.lv3{background:#89dfd4}.heat-cell.lv4{background:#4cc9bc}.heat-cell.lv5{background:#20a99c}

.alert-card{background:#fff;border:1px solid #fff;border-radius:16px;box-shadow:var(--sh-2);padding:20px;margin-bottom:16px}
.alert-head{display:flex;align-items:center;justify-content:space-between;gap:20px;margin-bottom:16px}
.alert-title{display:flex;align-items:center;gap:10px;font-size:20px;font-weight:760;color:var(--ink)}
.alert-time{color:var(--ink-2)}
.alert-desc{color:var(--ink-2);margin-bottom:16px}
.alert-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:14px 24px;color:var(--ink-2)}
.alert-meta b{color:var(--ink);font-weight:600}
.alert-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.status{height:26px;border-radius:6px;display:inline-flex;align-items:center;padding:0 10px;color:#fff;font-weight:700;font-size:13px}
.status.tip{background:#009a28}.status.warn{background:#e6a300}.status.danger{background:var(--r-high)}.status.done{background:var(--pri)}.status.ignore{background:#f5a400}
.score-podium{display:grid;grid-template-columns:1fr 1fr 1fr;align-items:end;gap:12px;margin:10px 0 18px}
.podium{border:1px solid var(--line);border-radius:12px;background:#fbfcff;text-align:center;padding:14px 10px}
.podium.first{padding-top:24px;border-color:#c9d6ff;background:#f3f6ff}
.podium .score{font:760 24px/1 Jmono,monospace;color:var(--chart-blue);margin-top:8px}
.podium .person{font-weight:700}
.mini-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.mini-stat{border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:#fff;box-shadow:var(--sh-1)}
.mini-stat .num{font:760 26px/1 Jmono,monospace;color:var(--chart-blue);margin-bottom:8px}

/* Dark cockpit: keep the contract's big-screen type, but align colors with the new system */
.cockpit-body{min-height:100vh;background:#06162d;color:#dcecff;overflow:hidden}
.cockpit{width:100vw;height:100vh;min-width:1180px;min-height:720px;padding:8px 12px 12px;background:
  radial-gradient(circle at 50% 0,rgba(22,119,255,.24),transparent 32%),
  linear-gradient(180deg,#0b2141 0%,#07182f 46%,#071427 100%)}
.cockpit-head{height:44px;display:grid;grid-template-columns:360px 1fr 300px;align-items:start}
.status-strip{display:flex;gap:18px;align-items:flex-start}
.status-chip{text-align:center;color:#8da5c5;font-size:11px}
.status-chip b{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;margin:0 auto 4px;font:700 13px/1 Jmono}
.status-chip.triangle b{clip-path:polygon(50% 0,100% 100%,0 100%);border-radius:0;padding-top:8px;background:var(--chart-amber)}
.status-chip.red b{background:var(--chart-red)}.status-chip.green b{background:var(--chart-teal)}
.cockpit-title{text-align:center;letter-spacing:8px;font-size:22px;font-weight:800;text-shadow:0 0 12px rgba(22,119,255,.8);position:relative}
.cockpit-title:before,.cockpit-title:after{content:"";display:inline-block;width:78px;height:2px;background:var(--chart-blue);vertical-align:middle;margin:0 18px;box-shadow:0 0 10px var(--chart-blue)}
.cockpit-title small{display:block;letter-spacing:5px;font-size:10px;color:#6f86aa;margin-top:4px;font-weight:400;text-shadow:none}
.clock{text-align:right;color:#4dd8ff;font:700 17px/1.2 Jmono,monospace;letter-spacing:4px}
.clock small{display:block;color:#6f86aa;font:400 11px/1.8 -apple-system,BlinkMacSystemFont,"PingFang SC",sans-serif;letter-spacing:0}
.cockpit-grid{height:calc(100vh - 52px);display:grid;grid-template-columns:280px 1fr 280px;grid-template-rows:36% 36% 1fr;gap:8px}
.cpanel{background:rgba(12,35,67,.9);border:1px solid rgba(61,135,255,.28);box-shadow:inset 0 0 22px rgba(45,112,255,.08);border-radius:8px;min-height:0;overflow:hidden}
.cpanel-title{height:30px;display:flex;align-items:center;gap:8px;padding:0 10px;border-bottom:1px solid rgba(92,145,220,.13);font-weight:700;color:#e6f3ff}
.cpanel-title:before{content:"";width:7px;height:7px;border-radius:50%;background:var(--chart-blue);box-shadow:0 0 8px var(--chart-blue)}
.cpanel-body{height:calc(100% - 30px);padding:10px;min-height:0}
.mid-bottom{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.cbar-chart{height:100%;display:flex;align-items:end;gap:54px;padding:20px 36px 28px;border-bottom:1px solid rgba(255,255,255,.12)}
.cbar{width:58px;border-radius:4px 4px 0 0;background:linear-gradient(180deg,#4d97ff,#1677ff);box-shadow:0 0 18px rgba(22,119,255,.22)}
.cbar:nth-child(2){background:linear-gradient(180deg,#20c4a6,#126c5a)}.cbar:nth-child(3){background:linear-gradient(180deg,#ffa63d,#795817)}.cbar:nth-child(4){background:linear-gradient(180deg,#f0483b,#81303a)}.cbar:nth-child(5){background:linear-gradient(180deg,#7aa7ff,#3158f3)}.cbar:nth-child(6){background:linear-gradient(180deg,#20c4a6,#166d73)}
.risk-heat{display:grid;grid-template-columns:repeat(12,1fr);gap:2px;padding:12px 42px 4px}
.risk-heat span{height:25px;border-radius:2px;background:#18b879}
.risk-heat span:nth-child(5n){background:#87d61d}.risk-heat span:nth-child(7n){background:#f5b70a}.risk-heat span:nth-child(11n){background:#ff7a1a}.risk-heat span:nth-child(13n){background:#e33a3f}
.donut-dark{width:116px;height:116px;border-radius:50%;background:conic-gradient(var(--chart-red) 0 7%,var(--chart-amber) 7% 26%,var(--chart-blue) 26% 100%);margin:22px auto;position:relative}
.donut-dark:after{content:"";position:absolute;inset:30px;border-radius:50%;background:#102746}
.donut-label{position:absolute;inset:30px;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.donut-label b{font:700 21px/1 Jmono;color:#fff}.donut-label span{font-size:11px;color:#8da5c5;margin-top:3px}
.top10{display:grid;gap:0}.top10-row{display:grid;grid-template-columns:26px 1fr 120px 58px;align-items:center;min-height:25px;border-bottom:1px solid rgba(126,164,220,.08);color:#9cb0cf;font-size:12px}
.top10-row b{width:20px;height:20px;border-radius:4px;background:rgba(80,126,190,.18);display:flex;align-items:center;justify-content:center;color:#9fb8d8}.top10-row:nth-child(-n+3) b{background:var(--chart-red);color:#fff}
.risk-badge{font-size:11px;color:#ff4d4f;font-weight:700}.risk-badge.mid{color:#ffba2c}.risk-badge.done{color:#20c4a6}
.ring-dark{width:78px;height:78px;border-radius:50%;background:conic-gradient(var(--chart-teal) 0 92%,rgba(100,130,180,.16) 92%);display:flex;align-items:center;justify-content:center;margin:14px auto 8px;position:relative}
.ring-dark:after{content:"";position:absolute;inset:13px;background:#102746;border-radius:50%}.ring-dark b{position:relative;z-index:1;color:var(--chart-teal);font:700 18px/1 Jmono}
.score-lines{display:grid;gap:9px;margin-top:10px}.score-line{display:grid;grid-template-columns:70px 1fr 28px;gap:8px;align-items:center;color:#9cb0cf;font-size:12px}
.score-track{height:5px;background:rgba(130,160,210,.18);border-radius:10px;overflow:hidden}.score-track span{display:block;height:100%;background:var(--chart-teal);border-radius:10px}
.fix-grid{display:grid;gap:8px;margin-top:4px}.fix-row{display:grid;grid-template-columns:1fr auto;align-items:center;color:#9cb0cf}.fix-row b{font:700 14px/1 Jmono}
@media (max-width:1100px){
  .topbar{padding:12px 16px;height:auto;flex-wrap:wrap}.topnav{order:3;justify-content:flex-start;overflow:auto;width:100%}.topnav a{flex:none}.workspace{padding:0 10px 18px}.sidebar{display:none}.kpi-grid{grid-template-columns:repeat(2,1fr)}.section-grid,.section-grid.three{grid-template-columns:1fr}.filter-card{grid-template-columns:1fr 1fr}.alert-meta{grid-template-columns:1fr 1fr}
}
