/* ============================================================
   AI 深度报告解析 — 共享设计系统
   配色与字体对齐主站「金融人的产业链大课」标准（A1 Daylight · 投行年报风）
   ============================================================ */

:root{
  --bg:#fafaf7;
  --bg-2:#ffffff;
  --panel:#ffffff;
  --panel-2:#f3f3ee;
  --panel-3:#ebe8e0;
  --line:#dcd8cd;
  --line-2:#cbc6b8;
  --text:#1a1a17;
  --muted:#55524a;
  --muted-2:#8a857a;
  --accent:#1d4ed8;      /* prussian blue（主强调，对齐主站 --accent） */
  --accent-soft:#eaf0ff;
  --stamp:#c8341f;       /* signal red（印章红，对齐主站 --stamp） */
  --accent-2:#b8860b;    /* gold（原 amber → 主站 --x-h） */
  --accent-3:#6a3aa8;    /* purple（原 violet → 主站 --l4） */
  --accent-4:#2d7a3f;    /* green（原 green → 主站 --l3） */
  --accent-5:#a8345c;    /* magenta（原 rose → 主站 --l5） */
  --accent-6:#1d5a9b;    /* blue（原 blue → 主站 --l2） */
  --shadow:0 18px 40px -26px rgba(0,0,0,.45);
  --radius:8px;
  --maxw:1180px;
  --font:"IBM Plex Sans","Noto Sans SC","PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;
  --serif:"Noto Serif SC","Source Han Serif SC","Songti SC",serif;
  --mono:"IBM Plex Mono","SFMono-Regular",ui-monospace,Menlo,Consolas,monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);background:var(--bg);color:var(--text);
  line-height:1.7;-webkit-font-smoothing:antialiased;font-size:16px;
}
a{color:inherit}
img{max-width:100%}
::selection{background:rgba(29,78,216,.16)}

/* scrollbar */
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:var(--panel-2)}
::-webkit-scrollbar-thumb{background:#cbc6b8;border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:#b3ae9f}

/* ---------- top reading progress ---------- */
#progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:120;
  background:linear-gradient(90deg,var(--accent),var(--stamp));box-shadow:0 0 10px rgba(29,78,216,.5)}

/* ---------- header ---------- */
.site-header{position:sticky;top:0;z-index:100;backdrop-filter:blur(14px);
  background:rgba(250,250,247,.86);border-bottom:1px solid var(--line)}
.site-header .bar{max-width:var(--maxw);margin:0 auto;padding:11px 22px;
  display:flex;align-items:center;gap:16px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.3px;
  text-decoration:none;font-size:15px;white-space:nowrap}
.brand .dot{width:10px;height:10px;border-radius:50%;
  background:var(--stamp)}
.brand small{color:var(--muted);font-weight:500}
.crumb{color:var(--muted);font-size:13.5px;display:flex;align-items:center;gap:8px;overflow:hidden}
.crumb b{color:var(--text);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.site-header .spacer{flex:1}
.back-link{margin-left:auto;text-decoration:none;color:var(--muted);font-size:13.5px;
  border:1px solid var(--line-2);padding:6px 13px;border-radius:999px;white-space:nowrap;
  transition:.2s;display:inline-flex;align-items:center;gap:6px}
.back-link:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{scroll-margin-top:72px}
.lede{font-size:18.5px;color:#44413a;max-width:880px}
.muted{color:var(--muted)}
.center{text-align:center}

/* ---------- hero ---------- */
.hero{padding:64px 0 30px;position:relative}
.hero .kicker{display:inline-flex;align-items:center;gap:9px;color:var(--accent);
  font-size:12.5px;font-weight:700;letter-spacing:2.2px;text-transform:uppercase;
  border:1px solid var(--line-2);padding:6px 14px;border-radius:999px;
  background:var(--accent-soft)}
.hero h1{font-family:var(--serif);font-size:clamp(30px,4.6vw,52px);line-height:1.18;margin:20px 0 8px;
  letter-spacing:.01em;font-weight:800}
.hero .sub{font-size:16px;color:var(--muted);margin-bottom:18px}
.hero .meta{display:flex;flex-wrap:wrap;gap:10px 18px;color:var(--muted-2);
  font-size:13px;margin-top:18px;align-items:center}
.hero .meta .who{color:var(--muted)}

/* ---------- section heading ---------- */
.s-head{display:flex;align-items:baseline;gap:16px;margin:54px 0 22px}
.s-head .num{font-family:var(--mono);font-size:14px;color:var(--accent);
  border:1px solid var(--line-2);border-radius:6px;padding:4px 9px;flex:none;
  background:var(--accent-soft)}
.s-head h2{font-family:var(--serif);font-size:clamp(22px,3vw,30px);margin:0;font-weight:800;letter-spacing:.01em}
.s-head p{margin:4px 0 0;color:var(--muted);font-size:14.5px}

/* ---------- cards / grid ---------- */
.grid{display:grid;gap:18px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
@media(max-width:920px){.g2,.g3,.g4{grid-template-columns:1fr}}
@media(max-width:920px){.g3.keep,.g4.keep{grid-template-columns:repeat(2,1fr)}}

.card{background:var(--panel);
  border:1px solid var(--line);border-radius:var(--radius);padding:22px;position:relative;
  transition:.2s;overflow:hidden}
.card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:var(--shadow)}
.card h3{margin:0 0 8px;font-size:18px;font-weight:700}
.card p{margin:0;color:var(--muted);font-size:14.5px}
.card .ico{font-size:22px;margin-bottom:10px;display:block}
.card.glow::before{content:"";position:absolute;inset:0;border-radius:var(--radius);
  padding:1px;background:linear-gradient(135deg,var(--accent),transparent 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:.5;pointer-events:none}

/* chip / tag / pill */
.tag{display:inline-block;font-size:12px;font-weight:600;padding:3px 10px;border-radius:999px;
  background:var(--panel-2);border:1px solid var(--line-2);color:var(--muted);margin:2px 3px 2px 0}
.tag.cy{color:var(--accent);border-color:rgba(29,78,216,.35);background:rgba(29,78,216,.08)}
.tag.am{color:var(--accent-2);border-color:rgba(184,134,11,.35);background:rgba(184,134,11,.09)}
.tag.vi{color:var(--accent-3);border-color:rgba(106,58,168,.35);background:rgba(106,58,168,.08)}
.tag.gr{color:var(--accent-4);border-color:rgba(45,122,63,.35);background:rgba(45,122,63,.08)}
.tag.ro{color:var(--accent-5);border-color:rgba(168,52,92,.35);background:rgba(168,52,92,.08)}

/* ---------- KPI / stat ---------- */
.kpis{display:grid;gap:16px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:18px 20px;
  position:relative;overflow:hidden}
.kpi .v{font-size:clamp(26px,3.4vw,38px);font-weight:800;letter-spacing:-1px;
  font-family:var(--mono);line-height:1;color:var(--accent)}
.kpi .l{color:var(--muted);font-size:13.5px;margin-top:9px}
.kpi .sub{color:var(--muted-2);font-size:12px;margin-top:3px}
.kpi.am .v{color:var(--accent-2)}
.kpi.vi .v{color:var(--accent-3)}
.kpi.gr .v{color:var(--accent-4)}

/* ---------- prose ---------- */
.prose p{color:#44413a;font-size:15.5px;margin:0 0 16px}
.prose strong{color:var(--text);font-weight:680}
.prose ul{padding-left:4px;list-style:none;margin:0 0 18px}
.prose ul li{position:relative;padding-left:24px;margin:9px 0;color:#44413a;font-size:15.5px}
.prose ul li::before{content:"";position:absolute;left:4px;top:11px;width:7px;height:7px;
  border-radius:2px;background:var(--accent);transform:rotate(45deg)}

/* ---------- callout ---------- */
.callout{border:1px solid var(--line-2);border-left:3px solid var(--accent);
  background:linear-gradient(180deg,rgba(29,78,216,.05),transparent);
  border-radius:8px;padding:16px 20px;margin:20px 0}
.callout .lab{font-size:11.5px;font-weight:700;letter-spacing:1.6px;text-transform:uppercase;
  color:var(--accent);margin-bottom:6px;display:block}
.callout.am{border-left-color:var(--accent-2)}
.callout.am .lab{color:var(--accent-2)}.callout.am{background:linear-gradient(180deg,rgba(184,134,11,.06),transparent)}
.callout.vi{border-left-color:var(--accent-3)}
.callout.vi .lab{color:var(--accent-3)}.callout.vi{background:linear-gradient(180deg,rgba(106,58,168,.06),transparent)}
.callout.ro{border-left-color:var(--accent-5)}
.callout.ro .lab{color:var(--accent-5)}.callout.ro{background:linear-gradient(180deg,rgba(168,52,92,.06),transparent)}
.callout p{margin:0;color:#44413a;font-size:15px}

/* ---------- glossary term tooltip ---------- */
.t{border-bottom:1.5px dotted var(--accent);cursor:help;color:var(--accent);
  font-weight:600;white-space:nowrap;transition:.15s}
.t:hover,.t:focus{background:rgba(29,78,216,.10);outline:none}
.t.am{border-color:var(--accent-2);color:var(--accent-2)}
.t.am:hover{background:rgba(184,134,11,.13)}
.t.vi{border-color:var(--accent-3);color:var(--accent-3)}
.t.vi:hover{background:rgba(106,58,168,.13)}
#tip{position:fixed;z-index:200;max-width:340px;background:#ffffff;
  border:1px solid var(--line-2);border-radius:10px;padding:13px 15px;
  box-shadow:0 16px 44px rgba(0,0,0,.18);opacity:0;transform:translateY(6px);
  pointer-events:none;transition:opacity .16s,transform .16s;font-size:13.5px;line-height:1.6}
#tip.show{opacity:1;transform:translateY(0)}
#tip .tt{font-weight:750;color:var(--accent);margin-bottom:5px;font-size:14px;
  display:flex;align-items:center;gap:7px}
#tip .tt .en{color:var(--muted-2);font-weight:500;font-family:var(--mono);font-size:11.5px}
#tip .td{color:#44413a}
#tip::after{content:"";position:absolute;width:11px;height:11px;background:#ffffff;
  border-right:1px solid var(--line-2);border-bottom:1px solid var(--line-2);
  transform:rotate(45deg)}
#tip.below::after{top:-6px;border:0;border-left:1px solid var(--line-2);border-top:1px solid var(--line-2)}
#tip.above::after{bottom:-6px}

/* ---------- bar charts ---------- */
.bars{margin:8px 0}
.bar-row{display:grid;grid-template-columns:165px 1fr auto;gap:14px;align-items:center;
  margin:11px 0}
.bar-label{font-size:13.5px;color:var(--muted);text-align:right;line-height:1.3}
.bar-label b{color:var(--text);display:block;font-weight:600}
.bar-track{height:30px;background:var(--panel-2);border-radius:7px;overflow:hidden;position:relative;
  border:1px solid var(--line)}
.bar-fill{height:100%;width:0;border-radius:6px;transition:width 1.1s cubic-bezier(.22,1,.36,1);
  background:linear-gradient(90deg,var(--accent),#2563eb);position:relative;
  display:flex;align-items:center}
.bar-fill.am{background:linear-gradient(90deg,var(--accent-2),#9a6f0a)}
.bar-fill.vi{background:linear-gradient(90deg,var(--accent-3),#7c4bc4)}
.bar-fill.gr{background:linear-gradient(90deg,var(--accent-4),#256634)}
.bar-fill.ro{background:linear-gradient(90deg,var(--accent-5),#8c2c4d)}
.bar-fill.muted{background:linear-gradient(90deg,#b3ae9f,#9c978a)}
.bar-val{font-family:var(--mono);font-size:13.5px;color:var(--text);font-weight:600;min-width:54px}
.bar-row.in .bar-fill{width:var(--w)}
@media(max-width:620px){.bar-row{grid-template-columns:110px 1fr auto;gap:9px}.bar-label{font-size:12px}}

/* ---------- data table ---------- */
.tbl-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:10px;background:var(--panel)}
table.data{width:100%;border-collapse:collapse;font-size:14px;min-width:560px}
table.data th,table.data td{padding:12px 15px;text-align:left;border-bottom:1px solid var(--line)}
table.data thead th{background:var(--panel-2);color:var(--muted);font-weight:600;font-size:12.5px;
  letter-spacing:.4px;text-transform:uppercase;position:sticky;top:0;white-space:nowrap}
table.data.sortable thead th{cursor:pointer;user-select:none}
table.data.sortable thead th:hover{color:var(--text)}
table.data.sortable thead th::after{content:"⇅";opacity:.3;margin-left:6px;font-size:11px}
table.data.sortable thead th.asc::after{content:"↑";opacity:1;color:var(--accent)}
table.data.sortable thead th.desc::after{content:"↓";opacity:1;color:var(--accent)}
table.data tbody tr{transition:.15s}
table.data tbody tr:hover{background:var(--panel-2)}
table.data td b{color:var(--text)}
table.data .hi{color:var(--accent);font-weight:700;font-family:var(--mono)}
table.data .hi-am{color:var(--accent-2);font-weight:700;font-family:var(--mono)}
table.data .num{font-family:var(--mono);font-size:13.5px}
table.data caption{caption-side:bottom;color:var(--muted-2);font-size:12px;padding:10px;text-align:left}

/* ---------- tabs ---------- */
.tabs{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 20px;border-bottom:1px solid var(--line);
  padding-bottom:0}
.tab{background:transparent;border:0;border-bottom:2px solid transparent;color:var(--muted);
  font-family:var(--font);font-size:14.5px;font-weight:600;padding:11px 16px;cursor:pointer;
  transition:.2s;margin-bottom:-1px;border-radius:7px 7px 0 0}
.tab:hover{color:var(--text);background:var(--panel)}
.tab.active{color:var(--accent);border-bottom-color:var(--accent)}
.panel[data-panel]{display:none;animation:fade .4s}
.panel[data-panel].active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- timeline (horizontal scroll) ---------- */
.timeline{position:relative;margin:24px 0;padding-left:26px}
.timeline::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(var(--accent),var(--accent-3),transparent)}
.tl-item{position:relative;padding:0 0 26px 0}
.tl-item::before{content:"";position:absolute;left:-26px;top:5px;width:14px;height:14px;border-radius:50%;
  background:var(--bg);border:3px solid var(--accent);box-shadow:0 0 0 4px rgba(29,78,216,.12)}
.tl-item .yr{font-family:var(--mono);font-size:13px;color:var(--accent);font-weight:700}
.tl-item h4{margin:2px 0 4px;font-size:16.5px}
.tl-item p{margin:0;color:var(--muted);font-size:14px}

/* ---------- compare two-column ---------- */
.vs{display:grid;grid-template-columns:1fr 56px 1fr;gap:0;align-items:stretch;margin:18px 0}
.vs .col{background:var(--panel);border:1px solid var(--line);padding:20px;border-radius:10px}
.vs .col.l{border-radius:10px 0 0 10px}
.vs .col.r{border-radius:0 10px 10px 0}
.vs .mid{display:flex;align-items:center;justify-content:center;font-family:var(--mono);
  font-weight:800;color:var(--muted-2);font-size:15px}
.vs h4{margin:0 0 12px;font-size:17px;display:flex;align-items:center;gap:8px}
.vs .row{display:flex;justify-content:space-between;gap:10px;padding:8px 0;
  border-bottom:1px dashed var(--line);font-size:14px}
.vs .row:last-child{border-bottom:0}
.vs .row .k{color:var(--muted)}
.vs .row .v{font-family:var(--mono);font-weight:600;text-align:right}
@media(max-width:760px){.vs{grid-template-columns:1fr;gap:10px}
  .vs .col.l,.vs .col.r{border-radius:10px}.vs .mid{padding:4px}}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}

/* ---------- footer ---------- */
.site-footer{border-top:1px solid var(--line);margin-top:70px;padding:34px 0;color:var(--muted-2);font-size:13px}
.site-footer .wrap{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center}
.site-footer a{color:var(--muted);text-decoration:none}
.site-footer a:hover{color:var(--accent)}

/* ---------- misc ---------- */
.note-src{font-size:12px;color:var(--muted-2);margin-top:8px;font-style:italic}
.divider{height:1px;background:var(--line);margin:40px 0}
.chips{display:flex;flex-wrap:wrap;gap:7px;margin:14px 0}
.back-top{position:fixed;right:22px;bottom:22px;width:44px;height:44px;border-radius:50%;
  background:var(--panel-2);border:1px solid var(--line-2);color:var(--text);cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:18px;opacity:0;pointer-events:none;
  transition:.3s;z-index:90}
.back-top.show{opacity:1;pointer-events:auto}
.back-top:hover{border-color:var(--accent);color:var(--accent)}

/* highlight key inline numbers */
.kx{font-family:var(--mono);font-weight:700;color:var(--accent)}
.kx.am{color:var(--accent-2)}.kx.vi{color:var(--accent-3)}.kx.gr{color:var(--accent-4)}.kx.ro{color:var(--accent-5)}
