/* ============================================================
   卫标AI安全标准评测服务平台 — 共享样式
   参考政务平台版式：绿色标题条、模块化布局、数据统计、动态列表。
   配色与 LOGO 一致的青绿色（teal）。无外部依赖，系统字体。
   ============================================================ */
:root{
  --brand:#149a8b;        /* 主绿（与 LOGO 一致，标题条/强调） */
  --brand-d:#0e7d70;      /* 深绿（悬停） */
  --brand-2:#1bb3a1;      /* 亮绿（渐变） */
  --ink:#333;
  --muted:#888;
  --line:#e3e3e3;
  --bg:#f3f5f5;
  --surface:#fff;
  --num:#0e7d70;          /* 数据数字绿 */
  --maxw:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:"Microsoft YaHei","PingFang SC","Hiragino Sans GB","Noto Sans SC",Arial,sans-serif;
  font-size:14px;line-height:1.7;-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{border:0;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 16px}

/* ---------- 页眉 Logo 条 ---------- */
.topbar{background:#fff;border-bottom:1px solid var(--line)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:104px}
.logo{display:flex;align-items:center;gap:14px}
.logo img{width:66px;height:66px}
.logo .mark{width:62px;height:62px;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--brand-2));display:grid;place-items:center;color:#fff;font-size:24px;font-weight:800;letter-spacing:1px}
.logo .txt b{display:block;font-size:24px;font-weight:800;color:#1f2937;letter-spacing:1px;line-height:1.2}
.logo .txt span{display:block;font-size:12px;color:var(--muted);letter-spacing:2px;margin-top:3px}
.topbar .views{font-size:13px;color:var(--muted)}
.topbar .views em{color:var(--brand);font-style:normal;font-weight:700}

/* ---------- 主导航 ---------- */
nav.main{background:var(--brand)}
nav.main ul{max-width:var(--maxw);margin:0 auto;padding:0 16px;list-style:none;display:flex}
nav.main>ul>li{position:relative}
nav.main>ul>li>a{display:block;padding:0 30px;height:50px;line-height:50px;color:#fff;font-size:16px;transition:background .2s}
nav.main>ul>li:hover>a,nav.main>ul>li.on>a{background:var(--brand-d)}
nav.main ul ul{position:absolute;top:50px;left:0;min-width:150px;background:#fff;box-shadow:0 6px 18px rgba(0,0,0,.14);padding:6px 0;display:none;z-index:60}
nav.main>ul>li:hover ul{display:block}
nav.main ul ul li a{display:block;padding:9px 18px;color:#444;font-size:14px}
nav.main ul ul li a:hover{background:#e9f6f4;color:var(--brand)}
.burger{display:none;margin-left:auto;background:none;border:0;color:#fff;font-size:24px;cursor:pointer;padding:0 16px}

/* ---------- Banner ---------- */
.banner{background:linear-gradient(120deg,#0e3b38,#08221f);color:#fff;overflow:hidden}
.banner .wrap{display:flex;align-items:center;min-height:300px;gap:40px;padding-top:36px;padding-bottom:36px}
.banner-tag{display:inline-block;background:var(--brand);color:#fff;font-size:13px;padding:4px 12px;border-radius:3px;letter-spacing:1px}
.banner h2{font-size:34px;font-weight:800;margin:16px 0 14px;line-height:1.3;letter-spacing:1px}
.banner p{font-size:15px;color:#bfd7d3;max-width:640px;margin:0 0 22px}
.banner .btns a{display:inline-block;margin-right:14px;padding:11px 26px;border-radius:4px;font-size:15px}
.banner .btns .primary{background:var(--brand);color:#fff}
.banner .btns .primary:hover{background:var(--brand-d)}
.banner .btns .ghost{border:1px solid rgba(255,255,255,.5);color:#fff}
.banner .btns .ghost:hover{background:rgba(255,255,255,.12)}
.banner-side{flex-shrink:0;width:300px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:18px 20px}
.banner-side h4{margin:0 0 10px;font-size:15px;color:#fff;font-weight:700}
.banner-side .gd{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-top:1px solid rgba(255,255,255,.1);font-size:13px;color:#bfd7d3}
.grade{font-weight:700;font-size:12px;padding:2px 10px;border-radius:3px;color:#fff}
.g-a{background:#2E9E5B}.g-b{background:#149a8b}.g-c{background:#C9821B}.g-d{background:#C0392B}

/* ---------- 页内子页眉（非首页） ---------- */
.pagehead{background:var(--surface);color:var(--ink);border-bottom:1px solid var(--line)}
.pagehead .wrap{padding:26px 16px 22px}
.pagehead .crumb{font-size:13px;color:#7a8a87;margin-bottom:10px}
.pagehead .crumb a{color:#7a8a87}
.pagehead .crumb a:hover{color:var(--brand)}
.pagehead h1{margin:0;font-size:28px;font-weight:800;letter-spacing:1px;color:var(--ink)}
.pagehead p{margin:10px 0 0;color:#5a6a67;font-size:14px;max-width:760px}

/* ---------- 模块通用 ---------- */
.layout{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:24px auto}
.module{background:var(--surface);border:1px solid var(--line);position:relative}
.titleBar{background:var(--brand);color:#fff;font-size:17px;font-weight:400;line-height:46px;height:46px;padding:0 18px;margin:0;letter-spacing:1px}
.titleBar::before{content:"";display:inline-block;width:4px;height:18px;background:#fff;vertical-align:-3px;margin-right:10px;opacity:.85}
.more{position:absolute;top:0;right:16px;line-height:46px;color:#fff;font-size:13px}
.more:hover{opacity:.75}
.module .inner{padding:16px 18px}
.full{grid-column:1 / -1}
.section-mt{margin-top:24px}

/* 测评服务卡片网格 */
.prodgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.prod{border:1px solid var(--line);padding:18px 16px;text-align:center;transition:box-shadow .2s,transform .2s}
.prod:hover{box-shadow:0 6px 18px rgba(0,0,0,.08);transform:translateY(-3px)}
.prod .pi{width:54px;height:54px;margin:0 auto 12px;border-radius:50%;background:#e9f6f4;color:var(--brand);display:grid;place-items:center;font-size:24px}
.prod h5{margin:0 0 6px;font-size:16px;color:#222}
.prod .tags{display:flex;justify-content:center;gap:10px;margin:10px 0 12px;flex-wrap:wrap}
.prod .tags span{font-size:12px;color:var(--muted);background:#f1f4f4;padding:3px 9px;border-radius:3px}
.prod p{margin:0 0 12px;color:var(--muted);font-size:13px;text-align:left}
.prod .go{display:inline-block;border:1px solid var(--brand);color:var(--brand);font-size:13px;padding:5px 18px;border-radius:3px}
.prod .go:hover{background:var(--brand);color:#fff}

/* 数据统计 */
#statistics dl,.stat-dl{margin:0 0 10px}
#statistics dt,.stat-dl dt{font-size:14px;color:var(--brand);font-weight:700;line-height:30px;border-bottom:1px dashed var(--line);margin-bottom:6px}
#statistics dd,.stat-dl dd{display:flex;justify-content:space-between;margin:0;line-height:30px;border-bottom:1px dotted #eee;font-size:13px}
#statistics dd label,.stat-dl dd label{color:#555}
#statistics dd em,.stat-dl dd em{font-style:normal;color:var(--num);font-weight:700;font-family:Arial}

/* 动态列表 */
.focusNews{display:flex;justify-content:space-between;align-items:center;padding:0 0 12px;margin-bottom:10px;border-bottom:1px solid var(--line)}
.focusNews .t{font-size:16px;font-weight:700;color:#c0392b}
.focusNews .t:hover{color:var(--brand)}
.clist{list-style:none;margin:0;padding:0}
.clist li{display:flex;justify-content:space-between;align-items:center;line-height:36px;border-bottom:1px dotted #e6e6e6}
.clist li .t{color:#444;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:78%}
.clist li .t::before{content:"\203A";color:var(--brand);margin-right:8px;font-weight:700}
.clist li:hover .t{color:var(--brand)}
.clist li .date{color:#aaa;font-size:12px;font-family:Arial;flex-shrink:0}

/* 测评流程 */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.step{padding:6px 16px;border-left:1px dashed var(--line);position:relative}
.step:first-child{border-left:0}
.step .n{width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:700;margin-bottom:10px}
.step h5{margin:0 0 6px;font-size:15px;color:#222}
.step p{margin:0;color:var(--muted);font-size:13px}

/* 大流程（流程页竖向） */
.flow-list{list-style:none;margin:0;padding:0}
.flow-list li{display:flex;gap:18px;padding:18px 0;border-bottom:1px dashed var(--line)}
.flow-list li:last-child{border-bottom:0}
.flow-list .fn{flex-shrink:0;width:44px;height:44px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:700;font-size:18px}
.flow-list h5{margin:2px 0 6px;font-size:17px;color:#222}
.flow-list p{margin:0;color:#666}

/* 联系我们 */
#contact p,.contact-list p{display:flex;line-height:34px;margin:0;border-bottom:1px dotted #eee}
#contact label,.contact-list label{width:96px;color:#888;flex-shrink:0}
#contact b,.contact-list b{color:var(--brand);font-size:18px;font-family:Arial}
#contact em,.contact-list em{font-style:normal;color:#444}

/* 文章正文 */
.article p{color:#555;line-height:2;margin:0 0 16px}
.article h3{font-size:18px;color:#222;margin:24px 0 12px;padding-left:12px;border-left:4px solid var(--brand)}
.article ul{color:#555;line-height:2;padding-left:22px}

/* 合作机构 Logo 墙 */
.orgwall{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.orgwall .o{border:1px solid var(--line);height:64px;display:grid;place-items:center;color:#555;font-size:14px;text-align:center;padding:6px;transition:border-color .2s,color .2s}
.orgwall .o:hover{border-color:var(--brand);color:var(--brand)}

/* 页脚 */
footer{background:#23302e;color:#9aa9a6;margin-top:24px;padding:26px 0 22px;font-size:13px}
footer a:hover{color:#fff}
.foot-nav{text-align:center;margin-bottom:12px}
.foot-nav a{padding:0 14px;border-right:1px solid #44524f}
.foot-nav a:last-child{border-right:0}
.foot-copy{text-align:center;color:#717f7c;line-height:1.9}

/* 响应式 */
@media (max-width:980px){
  .topbar .wrap{height:auto;padding:14px 16px;flex-wrap:wrap}
  .topbar .views{display:none}
  nav.main ul{flex-wrap:wrap}
  nav.main>ul>li>a{padding:0 16px}
  .layout{grid-template-columns:1fr}
  .prodgrid{grid-template-columns:repeat(2,1fr)}
  .orgwall{grid-template-columns:repeat(3,1fr)}
  .steps{grid-template-columns:1fr 1fr}
  .banner .wrap{flex-direction:column;align-items:flex-start}
  .banner-side{width:100%}
}
@media (max-width:600px){
  .logo .txt b{font-size:18px}
  .banner h2{font-size:24px}
  .pagehead h1{font-size:22px}
  .prodgrid,.orgwall,.steps{grid-template-columns:1fr}
  .burger{display:block}
  nav.main>ul{display:none}
  nav.main>ul.open{display:block}
  nav.main>ul>li{width:100%}
  nav.main ul ul{position:static;box-shadow:none;display:none}
}

/* ============================================================
   顶部工具条（日期 / 长辈版 / 无障碍 / 官方微信 / 登录）
   ============================================================ */
.util{background:#f0f4f3;border-bottom:1px solid #e3eae8;font-size:13px;color:#667}
.util .wrap{display:flex;align-items:center;justify-content:space-between;height:34px}
.util-date{color:#778}
.util-links{display:flex;align-items:center;gap:0}
.util-links a{color:#566;padding:0 12px;border-left:1px solid #dde4e2;line-height:16px;cursor:pointer}
.util-links a:first-child{border-left:0}
.util-links a:hover{color:var(--brand)}
.util-links a.login{color:var(--brand);font-weight:700}
@media (max-width:680px){.util-date{display:none}.util .wrap{justify-content:center}}

/* 长辈版（放大字号、加大行距、强对比） */
html.elder{font-size:18px}
html.elder body{line-height:1.9}
html.elder .util,html.elder .topbar .views,html.elder .logo .txt span{font-size:15px}
html.elder .clist li{line-height:42px}
html.elder nav.main>ul>li>a{font-size:18px}
/* 无障碍高对比 */
html.contrast{filter:contrast(1.18) saturate(1.15)}

/* 微信弹窗 */
.modal-mask{position:fixed;inset:0;background:rgba(0,0,0,.5);display:none;z-index:200;align-items:center;justify-content:center}
.modal-mask.open{display:flex}
.modal{background:#fff;border-radius:10px;width:300px;max-width:90vw;padding:24px;text-align:center;box-shadow:0 18px 50px rgba(0,0,0,.3)}
.modal h4{margin:0 0 6px;font-size:18px;color:#222}
.modal p{margin:0 0 16px;color:#888;font-size:13px}
.qr{width:180px;height:180px;margin:0 auto 14px;border:1px solid var(--line);display:grid;place-items:center;overflow:hidden;background:#fff;color:#fff;font-weight:800;border-radius:6px}
.qr img{width:100%;height:100%;object-fit:contain}
.qr.qr-sm{width:130px;height:130px}
.qr span{background:rgba(20,154,139,.92);padding:6px 10px;border-radius:4px;font-size:13px}
.modal .close{display:inline-block;margin-top:4px;color:var(--brand);cursor:pointer;font-size:14px}

/* ============================================================
   首页补充模块
   ============================================================ */
/* 通知滚动条 */
.notice{background:#fff;border:1px solid var(--line);border-top:0;display:flex;align-items:center;height:46px;overflow:hidden}
.notice .lab{flex-shrink:0;background:var(--brand);color:#fff;height:100%;display:flex;align-items:center;padding:0 16px;font-weight:700;font-size:14px}
.notice .roll{flex:1;overflow:hidden;white-space:nowrap;position:relative;height:100%}
.notice .roll a{position:absolute;left:100%;top:0;line-height:46px;padding:0 18px;color:#444;animation:rollx 18s linear infinite}
.notice .roll a:hover{color:var(--brand)}
@keyframes rollx{from{transform:translateX(0)}to{transform:translateX(-220%)}}
.notice .more{position:static;flex-shrink:0;color:var(--muted);padding:0 14px;line-height:46px;font-size:13px}

/* 快捷入口 */
.quick{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:24px 0}
.quick a{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-left:3px solid var(--brand);padding:18px 20px;transition:box-shadow .2s,transform .2s}
.quick a:hover{box-shadow:0 6px 18px rgba(0,0,0,.08);transform:translateY(-2px)}
.quick .qi{width:46px;height:46px;border-radius:8px;background:#e9f6f4;color:var(--brand);display:grid;place-items:center;font-size:22px;flex-shrink:0}
.quick b{display:block;font-size:16px;color:#222}
.quick small{color:var(--muted);font-size:12px}

/* 图片新闻 */
.picnews{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.picnews a{display:block;border:1px solid var(--line);background:#fff;overflow:hidden;transition:transform .2s,box-shadow .2s}
.picnews a:hover{transform:translateY(-3px);box-shadow:0 8px 20px rgba(0,0,0,.1)}
.picnews .ph{height:128px;background:linear-gradient(135deg,var(--brand),#0e3b38);display:flex;align-items:flex-end;padding:10px 14px;color:#fff;font-size:13px;font-weight:600}
.picnews .ph.v2{background:linear-gradient(135deg,#1bb3a1,#0e7d70)}
.picnews .ph.v3{background:linear-gradient(135deg,#2E9E5B,#0e3b38)}
.picnews .pt{padding:12px 14px}
.picnews .pt h5{margin:0 0 6px;font-size:15px;color:#222;line-height:1.4}
.picnews .pt p{margin:0;color:var(--muted);font-size:12.5px;line-height:1.6}

/* FAQ */
.faq dl{margin:0}
.faq dt{font-weight:700;color:#222;line-height:1.8;margin-top:10px}
.faq dt::before{content:"Q";display:inline-block;width:20px;height:20px;line-height:20px;text-align:center;background:var(--brand);color:#fff;border-radius:4px;font-size:12px;margin-right:8px}
.faq dd{margin:4px 0 10px 28px;color:#666}

/* 友情链接 */
.flinks{display:flex;flex-wrap:wrap;gap:10px}
.flinks a{border:1px solid var(--line);padding:6px 14px;color:#555;font-size:13px;border-radius:3px}
.flinks a:hover{border-color:var(--brand);color:var(--brand)}

/* ============================================================
   新闻频道独立版式（报刊风）
   ============================================================ */
.news-channel{background:#fbfcfc}
.nlayout{display:grid;grid-template-columns:1fr 332px;gap:26px;margin:22px auto}
.ncol{min-width:0}
.nside{min-width:0}
/* 头条 */
.nfeature{border-bottom:2px solid var(--brand);padding-bottom:18px;margin-bottom:8px}
.nfeature h2{margin:0 0 10px;font-size:26px;line-height:1.35;color:#1a1a1a}
.nfeature h2 a:hover{color:var(--brand)}
.nfeature .sum{color:#666;font-size:14px;line-height:1.9;margin:0 0 8px}
.nfeature .meta{color:#aaa;font-size:12.5px}
/* 频道分组标题 */
.ngroup{display:flex;align-items:center;border-bottom:1px solid var(--line);margin:22px 0 6px}
.ngroup h3{margin:0;font-size:19px;color:#222;border-bottom:3px solid var(--brand);padding:0 4px 8px}
.ngroup a.more{position:static;margin-left:auto;color:var(--muted);font-size:13px;line-height:1;padding-bottom:8px}
/* 新闻条目（带摘要） */
.narticles{list-style:none;margin:0;padding:0}
.narticles li{display:flex;gap:18px;padding:16px 0;border-bottom:1px dashed var(--line)}
.narticles .nd{flex-shrink:0;width:64px;text-align:center;color:#fff;background:var(--brand);border-radius:4px;padding:8px 0;height:fit-content}
.narticles .nd b{display:block;font-size:22px;font-weight:800;line-height:1}
.narticles .nd span{font-size:11px;opacity:.9}
.narticles .nc h4{margin:0 0 6px;font-size:16.5px;color:#222}
.narticles .nc h4 a:hover{color:var(--brand)}
.narticles .nc p{margin:0;color:#888;font-size:13px;line-height:1.7}
.narticles .tagk{display:inline-block;font-size:11px;color:var(--brand);background:#e9f6f4;padding:1px 7px;border-radius:3px;margin-right:6px}
/* 侧栏 */
.nbox{background:#fff;border:1px solid var(--line);margin-bottom:20px}
.nbox h4{margin:0;background:var(--brand);color:#fff;font-size:15px;font-weight:600;line-height:42px;padding:0 16px}
.nbox .nb{padding:12px 16px}
.rank{list-style:none;margin:0;padding:0}
.rank li{display:flex;gap:10px;align-items:flex-start;line-height:1.6;padding:8px 0;border-bottom:1px dotted #eee}
.rank li:last-child{border-bottom:0}
.rank .rk{flex-shrink:0;width:20px;height:20px;line-height:20px;text-align:center;background:#cfd8d6;color:#fff;border-radius:3px;font-size:12px;font-weight:700;font-family:Arial}
.rank li:nth-child(1) .rk,.rank li:nth-child(2) .rk,.rank li:nth-child(3) .rk{background:var(--brand)}
.rank a{color:#444;font-size:13.5px}
.rank a:hover{color:var(--brand)}
.ntags{display:flex;flex-wrap:wrap;gap:8px}
.ntags a{border:1px solid var(--line);padding:5px 12px;font-size:13px;color:#555;border-radius:16px}
.ntags a:hover{border-color:var(--brand);color:var(--brand)}
.nwx{text-align:center}
.nwx .qr{margin:0 auto 8px}
.nwx p{margin:0;color:#888;font-size:12.5px}
@media (max-width:860px){.nlayout{grid-template-columns:1fr}.quick{grid-template-columns:1fr 1fr}.picnews{grid-template-columns:1fr}}

/* ============================================================
   测评结果展示组件（评级徽章 / 得分条 / 结果表 / 样例 / 报告卡）
   ============================================================ */
/* 评级徽章 */
.badge{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;color:#fff;font-weight:800;font-size:20px;font-family:Arial}
.badge.lg{width:64px;height:64px;font-size:30px;border-radius:12px}
.bA{background:#2E9E5B}.bB{background:#149a8b}.bC{background:#C9821B}.bD{background:#C0392B}

/* 综合评分总览（仪表风） */
.scoresum{display:grid;grid-template-columns:200px 1fr;gap:24px;align-items:center}
.gauge{text-align:center;border-right:1px solid var(--line);padding-right:20px}
.gauge .ring{width:140px;height:140px;border-radius:50%;margin:0 auto 10px;display:grid;place-items:center;
  background:conic-gradient(var(--brand) calc(var(--p,90)*1%),#e9eeed 0);position:relative}
.gauge .ring::before{content:"";position:absolute;inset:14px;background:#fff;border-radius:50%}
.gauge .ring b{position:relative;font-size:34px;color:var(--brand-d);font-family:Arial;font-weight:800;line-height:1}
.gauge .ring b small{display:block;font-size:12px;color:var(--muted);font-weight:400;margin-top:2px}
.gauge .lab{font-size:14px;color:#555}
.gauge .lab em{font-style:normal;color:var(--brand);font-weight:700}

/* 维度得分条 */
.scorebars{display:grid;gap:14px}
.sb{display:grid;grid-template-columns:120px 1fr 56px;align-items:center;gap:12px}
.sb .nm{font-size:13.5px;color:#444}
.sb .track{height:16px;background:#eef2f1;border-radius:8px;overflow:hidden}
.sb .fill{display:block;height:100%;border-radius:8px;position:relative;background:linear-gradient(90deg,var(--brand-2),var(--brand))}
.sb .fill::after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.22) 0 7px,transparent 7px 14px)}
.sb .fill.f-c{background:linear-gradient(90deg,#e0a83f,#C9821B)}
.sb .fill.f-d{background:linear-gradient(90deg,#e06a5b,#C0392B)}
.sb .val{font-size:13px;color:var(--brand-d);font-weight:700;font-family:Arial;text-align:right}

/* 结果表 */
.rtable{width:100%;border-collapse:collapse;font-size:13.5px}
.rtable th,.rtable td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.rtable th{background:#eef5f4;color:#345;font-weight:700}
.rtable tbody tr:nth-child(even){background:#fafcfb}
.rtable .pill{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;color:#fff;font-weight:700}
.rtable .p-pass{background:#2E9E5B}.rtable .p-warn{background:#C9821B}.rtable .p-fail{background:#C0392B}
.rtable .num{font-family:Arial;color:#345;text-align:right}

/* 测评样例（攻击 → 响应 → 判定） */
.case{border:1px solid var(--line);border-radius:8px;overflow:hidden;margin-bottom:16px}
.case .ch{display:flex;align-items:center;justify-content:space-between;background:#f3f7f6;padding:10px 16px;border-bottom:1px solid var(--line)}
.case .ch .ct{font-weight:700;color:#234}
.case .ch .tagk{font-size:12px;color:var(--brand);background:#e9f6f4;padding:2px 9px;border-radius:3px;margin-left:8px;font-weight:400}
.case .cb{padding:14px 16px}
.case .turn{display:flex;gap:12px;margin-bottom:12px}
.case .turn:last-child{margin-bottom:0}
.case .who{flex-shrink:0;width:64px;font-size:12px;font-weight:700;padding-top:2px}
.case .who.atk{color:#C0392B}.case .who.mdl{color:var(--brand-d)}
.case .bubble{flex:1;background:#f8faf9;border:1px solid #edf1f0;border-radius:6px;padding:10px 12px;color:#444;font-size:13.5px;line-height:1.7}
.case .bubble.bad{background:#fdf3f1;border-color:#f3d6d0}
.case .bubble.good{background:#f1f9f4;border-color:#cfe9d8}
.case .verdict{display:flex;align-items:center;gap:8px;padding:10px 16px;border-top:1px solid var(--line);font-size:13px}
.case .verdict.ok{background:#f1f9f4;color:#236b3e}
.case .verdict.no{background:#fdf3f1;color:#9e2b1e}
.case .verdict b{font-weight:700}

/* 报告卡 */
.repgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.repcard{display:flex;gap:16px;border:1px solid var(--line);border-radius:8px;padding:18px;background:#fff;transition:box-shadow .2s,transform .2s}
.repcard:hover{box-shadow:0 8px 22px rgba(0,0,0,.08);transform:translateY(-2px)}
.repcard .rc-badge{flex-shrink:0;text-align:center}
.repcard .rc-badge .sc{display:block;margin-top:6px;font-size:12px;color:var(--muted);font-family:Arial}
.repcard .rc-main h5{margin:0 0 6px;font-size:16.5px;color:#222;line-height:1.4}
.repcard .rc-main p{margin:0 0 10px;color:#666;font-size:13px;line-height:1.7}
.repcard .rc-meta{display:flex;flex-wrap:wrap;gap:8px 14px;font-size:12px;color:#999}
.repcard .rc-meta em{font-style:normal;color:var(--brand-d);font-weight:700}
.repcard .rc-link{display:inline-block;margin-top:10px;font-size:13px;color:var(--brand);font-weight:700}
.repcard:hover .rc-link{opacity:.8}

/* 图例 */
.legend{display:flex;flex-wrap:wrap;gap:18px;font-size:13px;color:#555;margin-top:14px}
.legend span{display:inline-flex;align-items:center;gap:7px}
.legend i{width:14px;height:14px;border-radius:3px;display:inline-block}

/* 指标说明卡 */
.metricgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.metric{border:1px solid var(--line);border-left:3px solid var(--brand);border-radius:6px;padding:14px 16px;background:#fff}
.metric h5{margin:0 0 4px;font-size:15px;color:#222}
.metric .abbr{font-family:Arial;color:var(--brand);font-weight:700;font-size:13px}
.metric p{margin:6px 0 0;color:#666;font-size:13px;line-height:1.7}
.metric .formula{margin-top:8px;background:#f5f8f7;border-radius:4px;padding:6px 10px;font-size:12.5px;color:#456;font-family:Consolas,Arial}

@media (max-width:860px){
  .scoresum{grid-template-columns:1fr}.gauge{border-right:0;border-bottom:1px solid var(--line);padding:0 0 16px}
  .repgrid,.metricgrid{grid-template-columns:1fr}
  .sb{grid-template-columns:96px 1fr 48px}
}

/* ============================================================
   评测证书
   ============================================================ */
.cert{max-width:760px;margin:26px auto;background:#fdf9ef url("/assets/background.jpg") center/100% 100% no-repeat;
  box-shadow:0 16px 44px rgba(0,0,0,.18);padding:0;position:relative;overflow:hidden;border-radius:2px}
.cert-inner{padding:9% 10.5% 9%;position:relative;z-index:1}
.cert-top{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e6efed;padding-bottom:18px}
.cert-brand{display:flex;align-items:center;gap:12px}
.cert-brand img{width:54px;height:54px}
.cert-brand b{font-size:18px;color:#1f2937;font-weight:800;letter-spacing:.5px}
.cert-brand small{display:block;font-size:11px;color:var(--muted);letter-spacing:1px}
.cert-no{text-align:right;font-size:12px;color:#888;font-family:Arial;line-height:1.7}
.cert-title{text-align:center;margin:30px 0 6px}
.cert-title h2{font-size:30px;letter-spacing:3px;color:var(--brand-d);margin:0;font-weight:800}
.cert-title .en{font-size:12px;letter-spacing:3px;color:#9bb3af;text-transform:uppercase;margin-top:6px}
.cert-body{text-align:center;margin:26px 0}
.cert-body .line{font-size:15px;color:#444;line-height:2.4}
.cert-body .obj{font-size:22px;color:#111;font-weight:800;border-bottom:2px solid var(--brand);display:inline-block;padding:0 18px 4px;margin:4px 0}
.cert-grade{display:flex;align-items:center;justify-content:center;gap:26px;margin:24px 0}
.cert-seal{width:130px;height:130px;border-radius:50%;border:3px solid var(--brand);color:var(--brand-d);
  display:grid;place-items:center;text-align:center;background:radial-gradient(circle,#fff 60%,#eef7f5);transform:rotate(-12deg)}
.cert-seal b{font-size:46px;font-weight:800;line-height:1;font-family:Arial}
.cert-seal span{display:block;font-size:12px;letter-spacing:2px;margin-top:4px}
.cert-score{font-size:15px;color:#555}
.cert-score .sc{font-size:40px;color:var(--brand-d);font-weight:800;font-family:Arial;display:block;line-height:1.1}
.cert-dims{display:grid;grid-template-columns:repeat(2,1fr);gap:8px 30px;max-width:560px;margin:0 auto;text-align:left}
.cert-dims .d{display:flex;justify-content:space-between;border-bottom:1px dotted #ddd;padding:6px 0;font-size:13.5px;color:#555}
.cert-dims .d em{font-style:normal;color:var(--brand-d);font-weight:700;font-family:Arial}
.cert-foot{display:flex;align-items:flex-end;justify-content:space-between;margin-top:34px}
.cert-foot .issue{font-size:13px;color:#666;line-height:1.9}
.cert-foot .issue b{color:#333}
.cert-stamp{text-align:center}
.cert-stamp .stamp{width:96px;height:96px;border-radius:50%;border:2px solid #c0392b;color:#c0392b;display:grid;place-items:center;
  font-size:12px;font-weight:700;line-height:1.4;transform:rotate(-8deg);opacity:.85}
.cert-stamp small{display:block;color:#888;font-size:12px;margin-top:6px}
.cert-actions{text-align:center;margin:0 0 30px}
.cert-actions a{display:inline-block;margin:0 8px;padding:9px 22px;border-radius:4px;font-size:14px}
.cert-actions .primary{background:var(--brand);color:#fff}
.cert-actions .primary:hover{background:var(--brand-d)}
.cert-actions .ghost{border:1px solid var(--brand);color:var(--brand)}
.cert-actions .ghost:hover{background:#e9f6f4}
@media (max-width:680px){
  .cert-inner{padding:9% 9% 9%}
  .cert-title h2{font-size:22px;letter-spacing:1px}
  .cert-grade{flex-direction:column;gap:14px}
  .cert-dims{grid-template-columns:1fr}
  .cert-foot{flex-direction:column;gap:18px;align-items:center;text-align:center}
}
