:root{
  --red:#ff2442; --red-d:#d8112c; --ink:#17171a; --gray:#6b7280; --bg:#f6f6f8;
  --card:#fff; --line:#e9e9ef; --pos:#16a34a; --neu:#c2820a; --neg:#e11d48; --blue:#2563eb;
  --sh:0 1px 3px rgba(20,20,40,.06),0 6px 20px rgba(20,20,40,.05);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif;
  line-height:1.65;-webkit-font-smoothing:antialiased}
.wrap{max-width:1080px;margin:0 auto;padding:0 20px}
a{color:inherit;text-decoration:none}

/* topbar */
.topbar{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar .wrap{display:flex;align-items:center;gap:18px;height:58px}
.brand{font-weight:800;font-size:16px;display:flex;align-items:center;gap:8px;white-space:nowrap}
.brand .dot{width:11px;height:11px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px rgba(255,36,66,.16)}
.nav{display:flex;gap:4px;margin-left:auto;flex-wrap:wrap}
.nav a{padding:7px 12px;border-radius:8px;font-size:14px;color:var(--gray);font-weight:600}
.nav a:hover{background:#f1f1f5;color:var(--ink)}
.nav a.on{background:var(--red);color:#fff}
.menu{display:none;margin-left:auto;background:none;border:1px solid var(--line);border-radius:8px;font-size:18px;padding:4px 10px;cursor:pointer}

/* page */
main.wrap{padding-top:30px;padding-bottom:60px}
.page-title{font-size:30px;font-weight:800;margin:.2em 0 .1em;letter-spacing:-.5px}
.page-sub{color:var(--gray);font-size:15px;margin:.2em 0 1.6em}

/* hero */
.hero{display:grid;grid-template-columns:1.4fr 1fr;gap:28px;align-items:center;
  background:linear-gradient(135deg,#fff,#fff6f7);border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:var(--sh);margin-bottom:24px}
.kicker{color:var(--red);font-weight:800;font-size:13px;letter-spacing:1px;margin:0 0 6px}
.hero h2{font-size:23px;line-height:1.4;margin:.1em 0 .5em;font-weight:800}
.hero .hl{color:var(--red);border-bottom:3px solid rgba(255,36,66,.3)}
.hero .lead{color:#444;margin:0;font-size:15px}
.gauge{text-align:center}
.gnum{font-size:46px;font-weight:900;color:var(--red);line-height:1}
.gnum span{font-size:18px;color:var(--gray);font-weight:700}
.gbar{height:14px;border-radius:10px;margin:14px 0 8px;position:relative;
  background:linear-gradient(90deg,#e11d48,#f59e0b 50%,#16a34a)}
.gmark{position:absolute;top:-5px;width:6px;height:24px;background:#111;border:2px solid #fff;border-radius:3px;transform:translateX(-50%);box-shadow:0 1px 4px rgba(0,0,0,.3)}
.gscale{display:flex;justify-content:space-between;font-size:11px;color:var(--gray)}
.gscale span:nth-child(2){font-weight:700;color:var(--ink)}

/* stat grid */
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:24px 0}
.stat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--sh)}
.snum{font-size:30px;font-weight:900;color:var(--red);line-height:1.1}
.slabel{font-weight:700;font-size:14px;margin-top:4px}
.ssub{color:var(--gray);font-size:12px;margin-top:2px}

/* panels */
.panel{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:var(--sh);margin:18px 0}
.panel h3{margin:0 0 14px;font-size:19px;font-weight:800}
.panel.danger{border-color:rgba(225,29,72,.25);background:linear-gradient(180deg,#fff,#fff7f8)}
.note{background:#fff8e1;border-left:4px solid var(--neu);padding:10px 14px;border-radius:8px;font-size:14px;margin:14px 0 0}
.muted{color:var(--gray);font-size:13px}

/* stacked sentiment */
.stack{display:flex;height:42px;border-radius:10px;overflow:hidden;font-size:13px;font-weight:700;color:#fff}
.stack .seg{display:flex;align-items:center;justify-content:center;white-space:nowrap}
.seg.pos{background:var(--pos)} .seg.neu{background:var(--neu)} .seg.neg{background:var(--neg)}

/* big list */
ol.big{margin:0;padding-left:22px} ol.big li{margin:10px 0;font-size:15px}

/* nav cards */
.navcards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px}
.nc{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--sh);transition:.15s;border-top:3px solid var(--gray)}
.nc:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(20,20,40,.1)}
.nc.pos{border-top-color:var(--pos)} .nc.neg{border-top-color:var(--neg)}
.nc h4{margin:0 0 4px;font-size:16px} .nc p{margin:0;color:var(--gray);font-size:13px}

/* pain sections */
.pain{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:22px 24px;box-shadow:var(--sh);margin:16px 0}
.painhead{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.painhead h3{margin:0;font-size:19px;font-weight:800}
.sev{font-size:12px;font-weight:800;padding:4px 10px;border-radius:20px;white-space:nowrap;color:#fff}
.sev.p0{background:var(--neg)} .sev.p1{background:var(--neu)} .sev.p2{background:#64748b}
.paindesc{color:#333;font-size:15px;margin:.2em 0 1em}

/* quotes */
.q{margin:12px 0;background:#fafafc;border-left:4px solid var(--red);border-radius:0 10px 10px 0;padding:12px 16px;font-size:14.5px;color:#222;font-style:normal}
.qfoot{display:flex;align-items:center;gap:12px;margin-top:8px}
.qmeta{font-size:12px;color:var(--gray)}
.qlink{margin-left:auto;font-size:12px;font-weight:700;color:var(--red);border:1px solid rgba(255,36,66,.3);padding:3px 9px;border-radius:14px}
.qlink:hover{background:var(--red);color:#fff}

/* screenshots */
.shot{margin:16px 0 0;max-width:420px}
.shot img{width:100%;border:1px solid var(--line);border-radius:12px;box-shadow:var(--sh)}
.shot figcaption{font-size:12.5px;color:var(--gray);margin-top:8px;line-height:1.5}

/* good */
.good{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--pos);border-radius:0 12px 12px 0;padding:18px 22px;box-shadow:var(--sh);margin:14px 0}
.good h3{margin:0 0 6px;font-size:17px;color:#0f7a37}
.good p{margin:0;font-size:14.5px;color:#333}

/* tables */
table{width:100%;border-collapse:collapse;font-size:14px}
.cmp th,.cmp td{padding:11px 12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.cmp th{background:#fafafc;font-weight:700;color:var(--gray);font-size:13px}
.cmp .win{color:var(--pos);font-weight:700}
.kv td{padding:9px 12px;border-bottom:1px solid var(--line)}
.kv td:first-child{font-weight:700;width:140px;color:var(--gray)}

/* bars */
.bars{display:flex;flex-direction:column;gap:8px}
.bar{display:grid;grid-template-columns:130px 1fr 48px;align-items:center;gap:10px;font-size:13px}
.blab{color:#333;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.btrack{background:#eef0f4;border-radius:6px;height:18px;overflow:hidden}
.bfill{display:block;height:100%;border-radius:6px}
.bfill.red{background:linear-gradient(90deg,#ff7a90,#ff2442)}
.bfill.blue{background:linear-gradient(90deg,#60a5fa,#2563eb)}
.bval{font-weight:700;color:var(--gray)}

/* timeline */
.timeline{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tl{border-radius:12px;padding:16px;border:1px solid var(--line)}
.tl.gold{background:#fffbeb;border-color:#fde68a} .tl.warn{background:#fff7ed;border-color:#fed7aa} .tl.bad{background:#fef2f2;border-color:#fecaca}
.tldate{font-weight:800;font-size:13px;display:block;margin-bottom:6px}
.tl p{margin:0;font-size:13.5px;color:#444}

/* recs */
ul.recs{margin:6px 0 0;padding-left:20px} ul.recs li{margin:9px 0;font-size:14.5px}
ul.files{margin:8px 0 0;padding-left:18px;font-size:13.5px} ul.files li{margin:5px 0}
code{background:#f1f1f5;padding:1px 6px;border-radius:5px;font-size:12.5px}

/* posts grid */
.filters{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:18px;align-items:center}
.fgroup{display:flex;gap:6px;background:var(--card);border:1px solid var(--line);border-radius:10px;padding:5px}
.fb,.sb{border:none;background:none;padding:6px 12px;border-radius:7px;font-size:13px;font-weight:700;color:var(--gray);cursor:pointer}
.fb.on,.sb.on{background:var(--red);color:#fff}
.posts{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:16px}
.post{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--sh);transition:.15s;display:flex;flex-direction:column}
.post:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(20,20,40,.12)}
.pthumb{position:relative;aspect-ratio:4/3;background:#f1f1f5;overflow:hidden}
.pthumb img{width:100%;height:100%;object-fit:cover}
.noimg{display:flex;align-items:center;justify-content:center;height:100%;color:#bbb;font-size:13px}
.ptag{position:absolute;top:8px;left:8px;font-size:11px;font-weight:800;color:#fff;padding:3px 8px;border-radius:12px}
.ptag.pos{background:var(--pos)} .ptag.neu{background:var(--neu)} .ptag.neg{background:var(--neg)}
.pbody{padding:12px 13px;display:flex;flex-direction:column;flex:1}
.pbody h4{margin:0 0 6px;font-size:14.5px;line-height:1.4;font-weight:700;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pmeta{font-size:12px;color:var(--gray);margin-bottom:8px}
.peng{display:flex;gap:12px;font-size:12.5px;color:#555;margin-top:auto}
.pgo{margin-top:10px;font-size:12.5px;font-weight:700;color:var(--red)}

footer{border-top:1px solid var(--line);background:#fff;padding:24px 0;margin-top:30px}
footer p{margin:4px 0;font-size:12.5px;color:var(--gray)}

@media(max-width:820px){
  .nav{display:none;position:absolute;top:58px;left:0;right:0;background:#fff;flex-direction:column;padding:10px;border-bottom:1px solid var(--line)}
  body.navopen .nav{display:flex}
  .menu{display:block}
  .hero,.grid4,.navcards,.timeline{grid-template-columns:1fr}
  .grid4{grid-template-columns:1fr 1fr}
  .bar{grid-template-columns:96px 1fr 40px}
}
