
:root { --primary:#1677ff; --primary-light:#e6f4ff; --accent:#0958d9; --bg:#f5f5f5; --card:#fff; --surface:#fafafa; --text:#141414; --text-secondary:#434343; --muted:#8c8c8c; --border:#f0f0f0; --success:#52c41a; --warning:#faad14; --danger:#ff4d4f; --shadow-sm:0 1px 2px rgba(0,0,0,.03); --shadow-lg:0 4px 16px rgba(0,0,0,.08); }
* { box-sizing:border-box; }
body { margin:0; font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif; background:linear-gradient(180deg,#f8fbff 0%,#f5f5f5 100%); color:var(--text); line-height:1.5715; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
.page { max-width:1280px; margin:0 auto; padding:24px 40px 60px; }
.hero { background:linear-gradient(135deg,#1677ff 0%,#0958d9 52%,#003eb3 100%); color:#fff; border-radius:8px; padding:42px 48px; margin-bottom:24px; box-shadow:var(--shadow-lg); position:relative; overflow:hidden; text-align:center; }
.hero h1 { margin:0 0 12px; font-size:28px; font-weight:600; line-height:1.35; letter-spacing:0; position:relative; z-index:1; }
.hero p { margin:0; opacity:.92; position:relative; z-index:1; }
.hero-score { margin-top:22px; font-size:3rem; font-weight:800; line-height:1; position:relative; z-index:1; }
.hero-score .grade-text { font-size:1rem; vertical-align:middle; margin-left:8px; }
.grade-text { display:inline-flex; align-items:center; width:max-content; padding:2px 8px; border-radius:999px; font-weight:800; line-height:1.35; }
.grade-text--excellent { background:#f6ffed; color:#389e0d; border:1px solid #b7eb8f; }
.grade-text--good { background:#f6ffed; color:#389e0d; border:1px solid #b7eb8f; }
.grade-text--pass { background:#fffbe6; color:#d48806; border:1px solid #ffe58f; }
.grade-text--fail { background:#fff2f0; color:#cf1322; border:1px solid #ffccc7; }
.grade-text--unknown { background:#f3f4f6; color:var(--muted); }
.hero .grade-text--excellent { color:#95de64; }
.hero .grade-text--good { color:#95de64; }
.hero .grade-text--pass { color:#ffe58f; }
.hero .grade-text--fail { color:#ffa39e; }
.hero .grade-text--unknown { color:rgba(255,255,255,.74); }
.hero .grade-text { display:inline; padding:0; border-radius:0; background:transparent; }
.legend-line { display:flex; flex-wrap:wrap; align-items:center; gap:10px 16px; margin-top:16px; }
.legend-chip { font-weight:700; font-size:.94rem; white-space:nowrap; }
.legend-chip--excellent { color:#95de64; }
.legend-chip--good { color:#95de64; }
.legend-chip--pass { color:#ffe58f; }
.legend-chip--fail { color:#ffa39e; }
.grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; }
.card { background:var(--card); border:1px solid var(--border); border-radius:8px; padding:24px; margin-bottom:20px; box-shadow:var(--shadow-sm); position:relative; overflow:hidden; transition:box-shadow .2s ease,border-color .2s ease; }
.card::before { content:""; position:absolute; top:0; left:0; width:4px; height:100%; background:var(--primary); opacity:0; transition:opacity .2s ease; }
.card:hover { box-shadow:var(--shadow-lg); border-color:#e8e8e8; }
.card:hover::before { opacity:1; }
.card h2 { margin:0 0 16px; color:var(--text); font-size:1rem; font-weight:600; padding-bottom:12px; border-bottom:1px solid var(--border); display:flex; align-items:center; gap:8px; }
.card h2::before { content:""; display:inline-block; width:4px; height:16px; border-radius:2px; background:var(--primary); }
.card h3 { margin:0 0 10px; font-size:1rem; color:var(--text); }
.metric-card .score { font-size:2.4rem; font-weight:800; }
.metric-card .grade { font-weight:700; }
a { color:var(--primary); text-decoration:none; }
a:hover { text-decoration:underline; }
.back-link { display:inline-block; margin-bottom:14px; }
.three-col { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; }
.review-card .callout { margin-bottom:14px; }
.mc-three-row { display:grid; grid-template-columns:1fr; gap:10px; }
.mc-review-row { display:grid; grid-template-columns:92px 1fr; align-items:start; gap:12px; padding:12px; border:1px solid var(--border); border-radius:8px; background:#fff; }
.mc-review-row:first-child { border-top:0; }
.mc-review-row h4 { margin:0; font-size:.92rem; font-weight:700; color:var(--text); display:flex; align-items:center; gap:8px; min-height:28px; }
.mc-review-row h4::before { content:""; flex:0 0 24px; width:24px; height:24px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; color:#fff; font-size:14px; font-weight:800; line-height:1; box-shadow:0 2px 6px rgba(0,0,0,.12); }
.mc-review-row--highlight h4::before { content:"✓"; background:#52c41a; }
.mc-review-row--gap h4::before { content:"!"; background:#ff4d4f; }
.mc-review-row--suggestion h4::before { content:"↗"; background:#1677ff; }
.mc-review-row--highlight { background:#f6ffed; border-color:#b7eb8f; }
.mc-review-row--gap { background:#fff2f0; border-color:#ffccc7; }
.mc-review-row--suggestion { background:#e6f4ff; border-color:#91caff; }
.mc-point-row { display:flex; flex-wrap:wrap; gap:8px; }
.mc-point-chip { display:inline-flex; align-items:center; padding:5px 10px; border-radius:4px; border:1px solid #d9d9d9; background:#fff; color:var(--text-secondary); font-size:.84rem; line-height:1.4; }
.mc-point-chip--highlight { border-color:#b7eb8f; background:#f6ffed; color:#389e0d; }
.mc-point-chip--gap { border-color:#ffccc7; background:#fff2f0; color:#cf1322; }
.mc-point-chip--suggestion { border-color:#91caff; background:#e6f4ff; color:#0958d9; }
.table-wrapper { overflow-x:auto; border:1px solid var(--border); border-radius:8px; }
table { width:100%; border-collapse:separate; border-spacing:0; font-size:.92rem; }
th, td { padding:12px 14px; border-bottom:1px solid var(--border); border-right:1px solid #f0f0f0; text-align:left; vertical-align:top; }
td:last-child, th:last-child { border-right:0; }
tr:last-child td { border-bottom:0; }
th { background:var(--surface); color:#1d39c4; font-weight:700; white-space:nowrap; border-bottom:2px solid #1677ff; }
tr:hover td { background:#f6f9ff; }
ul { margin:0; padding-left:20px; }
.dimension-detail .mc-chart-grid { display:grid; grid-template-columns:1fr; gap:14px; margin-top:12px; }
.mc-chart-card { background:#fff; border:1px solid var(--border); border-radius:8px; padding:16px; box-shadow:var(--shadow-sm); }
.mc-chart-card h3 { margin:0 0 12px; color:var(--text); font-size:1rem; }
.mc-chart-note { margin:12px 0 0; color:var(--muted); font-size:.9rem; }
.mc-bar-list { display:grid; gap:10px; }
.mc-bar-row { display:grid; gap:5px; }
.mc-bar-meta { display:flex; justify-content:space-between; gap:12px; font-size:.9rem; }
.mc-bar-label { color:var(--text-secondary); font-weight:700; }
.mc-bar-value { color:var(--text); font-weight:700; white-space:nowrap; }
.mc-bar-track { width:100%; height:9px; border-radius:999px; background:#f0f0f0; overflow:hidden; }
.mc-bar-fill { display:block; height:100%; border-radius:inherit; }
.mc-bar-fill--good { background:var(--success); }
.mc-bar-fill--pass { background:var(--warning); }
.mc-bar-fill--improve { background:var(--danger); }
.mc-bar-fill--neutral { background:#8c8c8c; }
.mc-bar-percent { color:var(--muted); font-size:.82rem; text-align:right; }
.mc-plan-breakdown { margin-top:14px; border:1px solid var(--border); border-radius:8px; background:#fff; overflow:hidden; }
.mc-plan-breakdown > summary { cursor:pointer; list-style:none; padding:13px 16px; color:#1d39c4; font-weight:700; background:linear-gradient(180deg,#fff 0%,#f0f5ff 100%); border-bottom:1px solid #d6e4ff; }
.mc-plan-breakdown > summary::-webkit-details-marker { display:none; }
.mc-plan-breakdown .table-wrapper { border:none; box-shadow:none; border-radius:0; }
.report-table th { background:var(--surface); }
.callout { display:flex; gap:10px; padding:14px; border-radius:8px; background:linear-gradient(135deg,#f0f7ff 0%,#fff 100%); border:1px solid #bae0ff; color:var(--text-secondary); }
.callout-icon { flex:0 0 22px; width:22px; height:22px; border-radius:50%; background:var(--primary); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:800; }
.report-footer { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:10px 18px; margin-top:26px; padding:18px 0 0; border-top:1px solid var(--border); color:var(--muted); font-size:.9rem; }
.report-footer span:first-child { color:var(--text-secondary); font-weight:700; }
@media (max-width:820px) { .grid,.three-col,.mc-review-row { grid-template-columns:1fr; } .page { padding:20px 14px 36px; } .hero { padding:28px 20px; } .hero h1 { font-size:1.7rem; } .hero-score { font-size:2.35rem; } th,td { padding:10px 8px; } }
