
:root { --primary:#1a56db; --bg:#f5f7fb; --card:#fff; --text:#111928; --muted:#6b7280; --border:#e5e7eb; }
* { box-sizing:border-box; }
body { margin:0; font-family:"PingFang SC","Microsoft YaHei",system-ui,sans-serif; background:var(--bg); color:var(--text); line-height:1.65; }
.page { max-width:1180px; margin:0 auto; padding:32px 20px 48px; }
.hero { background:linear-gradient(135deg,#1a56db,#3f83f8); color:#fff; border-radius:22px; padding:32px; margin-bottom:24px; box-shadow:0 12px 32px rgba(15,23,42,.12); }
.hero h1 { margin:0 0 10px; font-size:2.1rem; line-height:1.25; }
.hero p { margin:0; opacity:.92; }
.hero-score { margin-top:20px; font-size:3rem; font-weight:800; line-height: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:#d1fae5; color:#065f46; }
.grade-text--good { background:#d1fae5; color:#065f46; }
.grade-text--pass { background:#fef3c7; color:#92400e; }
.grade-text--fail { background:#fee2e2; color:#991b1b; }
.grade-text--unknown { background:#f3f4f6; color:var(--muted); }
.hero .grade-text--excellent { color:#bbf7d0; }
.hero .grade-text--good { color:#a7f3d0; }
.hero .grade-text--pass { color:#fde68a; }
.hero .grade-text--fail { color:#fecaca; }
.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:#bbf7d0; }
.legend-chip--good { color:#a7f3d0; }
.legend-chip--pass { color:#fde68a; }
.legend-chip--fail { color:#fecaca; }
.grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; }
.card { background:var(--card); border:1px solid var(--border); border-radius:18px; padding:22px; margin-bottom:22px; box-shadow:0 8px 24px rgba(15,23,42,.05); }
.card h2 { margin:0 0 12px; color:var(--primary); font-size:1.2rem; }
.card h3 { margin:0 0 8px; font-size:1rem; }
.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:10px 0; border-top:1px dashed rgba(30,64,175,.18); }
.mc-review-row:first-child { border-top:0; }
.mc-review-row h4 { margin:2px 0 0; font-size:.92rem; font-weight:700; color:#334155; }
.mc-review-row--highlight { background:linear-gradient(90deg,rgba(34,197,94,.1),rgba(34,197,94,.02)); border-left:3px solid rgba(22,163,74,.5); padding-left:10px; border-radius:8px; }
.mc-review-row--gap { background:linear-gradient(90deg,rgba(239,68,68,.1),rgba(239,68,68,.02)); border-left:3px solid rgba(220,38,38,.5); padding-left:10px; border-radius:8px; }
.mc-review-row--suggestion { background:linear-gradient(90deg,rgba(245,158,11,.1),rgba(245,158,11,.02)); border-left:3px solid rgba(217,119,6,.52); padding-left:10px; border-radius:8px; }
.mc-point-row { display:flex; flex-wrap:wrap; gap:8px; }
.mc-point-chip { display:inline-flex; align-items:center; padding:6px 11px; border-radius:999px; border:1px solid rgba(30,64,175,.16); background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(244,250,255,.92)); color:#334155; font-size:.84rem; line-height:1.35; }
.mc-point-chip--highlight { border-color:rgba(21,128,61,.28); background:linear-gradient(180deg,rgba(240,253,244,.98),rgba(220,252,231,.92)); color:#166534; }
.mc-point-chip--gap { border-color:rgba(185,28,28,.28); background:linear-gradient(180deg,rgba(254,242,242,.98),rgba(254,226,226,.92)); color:#991b1b; }
.mc-point-chip--suggestion { border-color:rgba(161,98,7,.28); background:linear-gradient(180deg,rgba(255,251,235,.98),rgba(254,243,199,.92)); color:#92400e; }
.table-wrapper { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:.92rem; }
th, td { padding:12px 14px; border-bottom:1px solid var(--border); text-align:left; vertical-align:top; }
th { background:#f9fafb; white-space:nowrap; }
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:linear-gradient(180deg,#fff,#f8fbff); border:1px solid rgba(37,99,235,.16); border-radius:14px; padding:16px; box-shadow:0 10px 24px rgba(15,23,42,.06); }
.mc-chart-card h3 { margin:0 0 12px; color:#10284f; 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:#334155; font-weight:700; }
.mc-bar-value { color:#0f172a; font-weight:700; white-space:nowrap; }
.mc-bar-track { width:100%; height:9px; border-radius:999px; background:#e5edf8; overflow:hidden; }
.mc-bar-fill { display:block; height:100%; border-radius:inherit; }
.mc-bar-fill--good { background:linear-gradient(90deg,#22c55e,#16a34a); }
.mc-bar-fill--pass { background:linear-gradient(90deg,#f59e0b,#d97706); }
.mc-bar-fill--improve { background:linear-gradient(90deg,#ef4444,#dc2626); }
.mc-bar-fill--neutral { background:linear-gradient(90deg,#94a3b8,#64748b); }
.mc-bar-percent { color:var(--muted); font-size:.82rem; text-align:right; }
.mc-plan-breakdown { margin-top:14px; border:1px solid rgba(37,99,235,.16); border-radius:14px; background:#fff; overflow:hidden; }
.mc-plan-breakdown > summary { cursor:pointer; list-style:none; padding:13px 16px; color:var(--primary); font-weight:800; background:linear-gradient(180deg,#eff6ff,#fff); border-bottom:1px solid rgba(37,99,235,.12); }
.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:#f9fafb; }
.callout { display:flex; gap:10px; padding:14px; border-radius:12px; background:#eff6ff; color:#1e3a8a; }
.callout-icon { flex:0 0 22px; width:22px; height:22px; border-radius:50%; background:#dbeafe; display:flex; align-items:center; justify-content:center; font-weight:800; }
@media (max-width:820px) { .grid,.three-col,.mc-review-row { grid-template-columns:1fr; } .page { padding:20px 14px 36px; } .hero h1 { font-size:1.7rem; } }
