/* ============================================================
   记工表 官网 V3 · sections（hero / acts / bento / personas / trust / platforms / download）
   颜色字号一律 var(--*)（tokens.css 单一真相源）
   真机为高保真 CSS 仿真功能页（上线前可替换真截图）
   ============================================================ */

/* ===== 共享：真机外壳 + 屏幕（编辑工程质感） ===== */
.device { width: clamp(232px, 62vw, 320px); border-radius: var(--r-phone); background: var(--ink-surface); padding: 10px; box-shadow: var(--shadow-phone); position: relative; }
.device::after { content: ""; position: absolute; top: 15px; left: 50%; transform: translateX(-50%); width: 34%; height: 22px; background: var(--ink-surface); border-radius: var(--r-chip); }
.scr { background: var(--surface); border-radius: var(--r-card-lg); overflow: hidden; aspect-ratio: 9/19.3; text-align: left; }
.scr-head { background: var(--grad-surface); color: var(--surface); padding: 44px 16px 16px; }
.scr-head .row { display: flex; align-items: center; justify-content: space-between; }
.scr-head .ttl { font-size: 17px; font-weight: var(--fw-med); letter-spacing: var(--ls-title); }
.scr-head .mon { font-size: 11px; opacity: .92; background: var(--glass-20); padding: 3px 9px; border-radius: var(--r-chip); }
.scr-sum { display: flex; gap: 8px; margin-top: 14px; }
.scr-sum .b { flex: 1; background: var(--glass-16); border-radius: var(--r-input); padding: 9px 10px; }
.scr-sum .k { font-size: 10px; opacity: .88; }
.scr-sum .v { font-family: var(--num); font-variant-numeric: tabular-nums; font-size: 18px; font-weight: var(--fw-bold); margin-top: 3px; }
.scr-sum .v small { font-size: 11px; font-family: var(--font); }
.scr-sum .v.ok2 { font-size: 13px; font-family: var(--font); color: var(--teal-100); }
.scr-body { padding: 12px 14px; }
.scr-row { display: flex; align-items: center; gap: 10px; padding: 9px 0; border-bottom: 1px solid var(--line); }
.scr-row:last-child { border-bottom: 0; }
.scr-av { width: 32px; height: 32px; border-radius: 50%; flex: none; display: grid; place-items: center; color: var(--surface); font-size: 12px; font-weight: var(--fw-bold); background: var(--teal); }
.scr-av.b2 { background: var(--teal-700); }
.scr-nm { flex: 1; min-width: 0; }
.scr-nm .n { font-size: 13px; font-weight: var(--fw-med); color: var(--ink); }
.scr-nm .t { font-size: 10.5px; color: var(--ink-3); }
.scr-amt { text-align: right; font-family: var(--num); font-variant-numeric: tabular-nums; }
.scr-amt .w { font-size: 13px; font-weight: var(--fw-bold); color: var(--teal-700); }
.scr-amt .s { display: block; font-size: 10px; color: var(--ink-3); }
.scr-foot { padding: 10px 14px 14px; font-size: 11px; color: var(--teal); font-weight: var(--fw-med); border-top: 1px solid var(--line); background: var(--surface); }

/* 红章母题（Hero + Act02 共用） */
.seal { width: 84px; height: 84px; border-radius: 50%; display: grid; place-items: center; color: var(--seal); border: 2.5px solid currentColor; box-shadow: inset 0 0 0 4px var(--seal-wash), var(--shadow-seal); background: var(--glass-94); transform: rotate(-8deg); }
.seal span { font-size: 12px; font-weight: var(--fw-hero); line-height: 1.08; text-align: center; letter-spacing: 1px; }

/* ===== HERO ===== */
.hero { padding-top: clamp(2.5rem, 1.5rem + 4vw, 4.5rem); padding-bottom: var(--rhythm-wide); position: relative; }
.hero::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 60%; background-image: var(--tex-blueprint); -webkit-mask-image: linear-gradient(var(--surface), transparent); mask-image: linear-gradient(var(--surface), transparent); opacity: .7; z-index: var(--z-blueprint); pointer-events: none; }
.hero-grid { position: relative; z-index: var(--z-raised); display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(1.5rem, 1rem + 4vw, 4rem); align-items: center; }
.hero-copy { max-width: 16ch; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 0.5rem; font-size: var(--t-sm); font-weight: var(--fw-bold); color: var(--teal); letter-spacing: 0.04em; }
.hero-eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--teal); box-shadow: 0 0 0 4px var(--surface-teal); }
.hero-title { margin-top: var(--s-4); font-size: var(--t-display); font-weight: var(--fw-hero); line-height: var(--lh-display); letter-spacing: var(--ls-display); color: var(--ink); text-wrap: balance; word-break: keep-all; }
.hero-title .ac { color: var(--teal); }
.hero-sub { margin-top: var(--s-5); max-width: 34ch; font-size: var(--t-lead); color: var(--ink-2); line-height: 1.5; }
.hero-cta { margin-top: var(--rhythm-tight); display: flex; flex-wrap: wrap; gap: var(--s-3); align-items: center; }
.hero-note { margin-top: var(--s-5); display: flex; align-items: center; gap: 0.5rem; font-size: var(--t-sm); color: var(--ink-3); }
.hero-note b { color: var(--ink-2); font-weight: var(--fw-med); }
.hero-stage { position: relative; display: grid; place-items: center; }
.hero-stage .device { transform: rotate(2deg); }
.hero-tag { position: absolute; background: var(--surface); border-radius: var(--r-card); padding: 10px 13px; box-shadow: var(--shadow-lg); display: flex; align-items: center; gap: 9px; font-size: 13px; font-weight: var(--fw-med); color: var(--ink); z-index: var(--z-raised); }
.hero-tag small { display: block; font-weight: var(--fw-reg); font-size: 11px; color: var(--ink-3); }
.hero-tag .i { width: 30px; height: 30px; border-radius: var(--r-sm); display: grid; place-items: center; flex: none; background: var(--teal); color: var(--surface); }
.hero-tag .i svg { width: 17px; height: 17px; }
.hero-tag.t1 { top: 6%; left: -4%; }
.hero-stage .seal { position: absolute; right: -2%; bottom: 12%; z-index: var(--z-raised); }
@media (max-width: 833px) {
  .hero-grid { grid-template-columns: 1fr; gap: var(--rhythm-tight); }
  .hero-copy { max-width: 22ch; }
  .hero-tag.t1 { left: 2%; }
}
@media (max-width: 480px) { .hero-tag { display: none; } }

/* ===== ACT 对比章（01 记工 / 02 对工 共用骨架） ===== */
.act-head { display: grid; grid-template-columns: auto 1fr; gap: var(--s-4); align-items: end; padding-bottom: var(--s-5); border-bottom: var(--hairline); }
.act-head .ix { font-family: var(--num); font-size: var(--t-index); font-weight: var(--fw-hero); line-height: 0.8; color: var(--line-strong); }
.ch--dark .act-head .ix { color: var(--ink-surface-2); }
.ch--dark .act-head { border-bottom-color: var(--line-on-dark); }
.act-head-main { display: grid; gap: var(--s-2); }
.vs2 { margin-top: var(--rhythm-tight); display: grid; grid-template-columns: 1fr 84px 1fr; gap: clamp(0.8rem, 2vw, 1.8rem); align-items: center; }
.vs-side { display: grid; gap: var(--s-3); }
.vs-label { display: inline-flex; align-items: center; gap: 0.35rem; font-size: var(--t-xs); font-weight: var(--fw-bold); padding: 0.3rem 0.75rem; border-radius: var(--r-chip); width: fit-content; }
.vs-label.bad { background: var(--surface-sunk); color: var(--ink-3); }
.vs-label.good { background: var(--surface-teal); color: var(--teal); }
.vs-label svg { width: 13px; height: 13px; }
.vs-x { color: var(--seal); font-weight: var(--fw-hero); }
.vs-h { font-size: var(--t-h3); font-weight: var(--fw-med); line-height: var(--lh-tight); letter-spacing: var(--ls-title); }
.vs-side.bad .vs-h { color: var(--ink-3); }
.vs-arrow2 { display: grid; place-items: center; gap: 0.4rem; }
.vs-arrow2 .a { width: 46px; height: 46px; border-radius: 50%; background: var(--teal); color: var(--surface); display: grid; place-items: center; box-shadow: var(--shadow-md); }
.vs-arrow2 .a svg { width: 23px; height: 23px; }
.vs-arrow2 .t { font-size: var(--t-xs); color: var(--ink-3); white-space: nowrap; font-weight: var(--fw-med); }
.act-benefit { margin-top: var(--rhythm-tight); font-size: var(--t-lead); color: var(--ink-2); }
.act-benefit b { color: var(--ink); font-weight: var(--fw-bold); }
.ch--dark .act-benefit { color: var(--ink-on-dark-2); } .ch--dark .act-benefit b { color: var(--ink-on-dark); }

/* 老办法做旧本子（冷灰，禁米色 slop） */
.oldway { background: var(--surface-sunk); border-radius: var(--r-card-lg); padding: 1.3rem; position: relative; box-shadow: inset 0 0 0 1px var(--line-strong); }
.oldway .stamp { position: absolute; right: 16px; top: 16px; color: var(--seal); border: 2px solid currentColor; border-radius: var(--r-badge); padding: 0.1rem 0.5rem; font-weight: var(--fw-hero); font-size: var(--t-sm); transform: rotate(7deg); opacity: .85; }
.note { background: var(--surface); border-radius: var(--r-input); padding: 0.9rem 1.1rem 1rem; background-image: var(--tex-ledger); }
.note .nh { font-size: var(--t-xs); color: var(--ink-4); margin-bottom: 0.4rem; }
.tally { display: flex; justify-content: space-between; align-items: baseline; padding: 0.25rem 0; color: var(--ink-3); }
.tally .who { font-size: var(--t-sm); }
.tally .n { font-family: var(--num); font-variant-numeric: tabular-nums; font-size: 1.5rem; font-weight: var(--fw-bold); }
.tally.conflict .n { color: var(--seal); }
.chat { margin-top: 0.9rem; display: grid; gap: 0.45rem; }
.bub { max-width: 86%; padding: 0.5rem 0.8rem; border-radius: var(--r-input); font-size: var(--t-sm); line-height: 1.35; }
.bub.l { background: var(--surface); color: var(--ink-2); justify-self: start; border-bottom-left-radius: 4px; box-shadow: var(--shadow-xs); }
.bub.r { background: var(--teal-200); color: var(--teal-800); justify-self: end; border-bottom-right-radius: 4px; }

/* 记工录入真机页（Act01 after） */
.scr-input { padding: 14px; display: grid; gap: 12px; }
.scr-seg { display: flex; gap: 6px; background: var(--surface-sunk); border-radius: var(--r-input); padding: 4px; }
.scr-seg b { flex: 1; text-align: center; font-size: 12px; font-weight: var(--fw-med); padding: 7px 0; border-radius: var(--r-sm); color: var(--ink-3); }
.scr-seg b.on { background: var(--surface); color: var(--teal); box-shadow: var(--shadow-xs); }
.scr-field { display: flex; align-items: center; justify-content: space-between; padding: 11px 12px; border: var(--hairline); border-radius: var(--r-input); font-size: 13px; }
.scr-field .k { color: var(--ink-3); }
.scr-field .v { font-family: var(--num); font-variant-numeric: tabular-nums; font-weight: var(--fw-bold); color: var(--ink); }
.scr-save { text-align: center; background: var(--teal); color: var(--surface); font-weight: var(--fw-med); padding: 11px; border-radius: var(--r-btn); font-size: 13px; }

@media (max-width: 833px) {
  .act-head { grid-template-columns: 1fr; gap: var(--s-2); }
  .vs2 { grid-template-columns: 1fr; gap: 0.6rem; }
  .vs-arrow2 { transform: rotate(90deg); margin: 0.2rem 0; }
  .vs-arrow2 .t { display: none; }
}

/* ===== ACT 02 · 对工（招牌滚动叙事暗场） ===== */
.stage-outer { position: relative; }
.js:not(.is-cheap) .stage-outer { height: 260vh; }
.is-cheap .stage-outer, .no-js .stage-outer { height: auto; }
.stage { position: sticky; top: 56px; min-height: calc(100vh - 56px); display: grid; align-content: center; }
.is-cheap .stage, .no-js .stage { position: static; min-height: 0; padding-block: var(--section-y); }
@media (prefers-reduced-motion: reduce) { .stage-outer { height: auto !important; } .stage { position: static !important; min-height: 0 !important; padding-block: var(--section-y); } }
.stage::before { content: ""; position: absolute; inset: 0; background-image: var(--tex-blueprint); opacity: .5; pointer-events: none; }
.stage::after { content: ""; position: absolute; inset: 0; background: var(--atmos-stage); pointer-events: none; }
.stage-wrap { position: relative; z-index: var(--z-raised); max-width: var(--container); margin-inline: auto; padding-inline: var(--pad-x); width: 100%; }

.ledger2 { margin-top: var(--rhythm-tight); display: grid; grid-template-columns: 1fr auto 1fr; gap: clamp(0.8rem, 2.5vw, 2rem); align-items: stretch; max-width: 820px; margin-inline: auto; }
.led-col { background: var(--ink-surface-2); border: var(--hairline-dark); border-radius: var(--r-card-lg); padding: 1.1rem 1.15rem 1.2rem; }
.led-col h4 { font-size: 0.95rem; font-weight: var(--fw-med); color: var(--ink-on-dark); }
.led-col .role { font-size: var(--t-xs); color: var(--ink-on-dark-2); margin-bottom: 0.7rem; }
.led-line { display: flex; align-items: center; justify-content: space-between; padding: 0.5rem 0; border-bottom: var(--hairline-dark); font-size: var(--t-sm); color: var(--ink-on-dark-2); }
.led-line:last-of-type { border-bottom: 0; }
.led-line b { font-family: var(--num); font-variant-numeric: tabular-nums; color: var(--ink-on-dark); font-weight: var(--fw-med); }
.led-line .ot { color: var(--amber); }
.led-line .chk { color: var(--teal-300); opacity: 0; transition: opacity var(--dur) var(--ease-out-expo); }
.led-sum { margin-top: 0.7rem; padding-top: 0.7rem; border-top: var(--hairline-dark); display: flex; align-items: baseline; justify-content: space-between; }
.led-sum .k { font-size: var(--t-sm); color: var(--ink-on-dark-2); }
.led-sum .v { font-family: var(--num); font-variant-numeric: tabular-nums; font-size: 1.5rem; font-weight: var(--fw-bold); color: var(--teal-300); }
.led-mid { display: grid; place-items: center; }
.led-mid .seal { width: 96px; height: 96px; }
.stage-status { margin-top: var(--rhythm-tight); text-align: center; }
.stage-status .step-cue { font-size: var(--t-sm); color: var(--ink-on-dark-2); }

/* 步进态（JS 加在 .stage 上；默认=争执态） */
.stage .led-line .chk { opacity: 0; }
.stage.s2 .led-line .chk, .stage.s3 .led-line .chk { opacity: 1; }
.stage .led-mid .seal { opacity: 0; transform: rotate(-16deg) scale(1.6); }
.stage.s3 .led-mid .seal { opacity: 1; transform: rotate(-8deg) scale(1); transition: opacity var(--dur) , transform var(--dur-slow) var(--ease-seal); }
/* 降级终态：直接 s3 */
.is-cheap .stage .led-line .chk, .no-js .stage .led-line .chk { opacity: 1; }
.is-cheap .stage .led-mid .seal, .no-js .stage .led-mid .seal { opacity: 1; transform: rotate(-8deg) scale(1); }
@media (prefers-reduced-motion: reduce) { .stage .led-line .chk { opacity: 1 !important; } .stage .led-mid .seal { opacity: 1 !important; transform: rotate(-8deg) scale(1) !important; } }

@media (max-width: 833px) {
  .ledger2 { grid-template-columns: 1fr; }
  .led-mid { order: -1; }
  .led-mid .seal { width: 78px; height: 78px; }
}

/* ===== ACT 03 · 算钱（透明账本对账单） ===== */
.pay-grid { margin-top: var(--rhythm-tight); display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1.5rem, 1rem + 3vw, 4rem); align-items: center; }
.pay-copy .lead { max-width: 32ch; }
.pay-points { margin-top: var(--s-5); display: grid; gap: 0.7rem; }
.pay-points li { display: flex; align-items: flex-start; gap: 0.6rem; font-size: var(--t-base); color: var(--ink-2); list-style: none; }
.pay-points svg { width: 18px; height: 18px; color: var(--teal); flex: none; margin-top: 2px; }
.paycard { background: var(--surface); border-radius: var(--r-card-lg); padding: clamp(1.6rem, 1rem + 2vw, 2.4rem); box-shadow: var(--shadow-lg); border: var(--hairline); position: relative; overflow: hidden; }
.paycard::before { content: "对账单"; position: absolute; right: -10px; top: 14px; transform: rotate(8deg); color: var(--seal); border: 2px solid currentColor; border-radius: var(--r-badge); padding: 0.1rem 0.6rem; font-size: var(--t-xs); font-weight: var(--fw-hero); opacity: .55; }
.pay-row { display: flex; align-items: baseline; justify-content: space-between; padding: 0.75rem 0; }
.pay-row + .pay-row { border-top: var(--hairline); }
.pay-row .k { font-size: var(--t-base); color: var(--ink-2); }
.pay-amt { font-family: var(--num); font-variant-numeric: tabular-nums; font-size: 1.3rem; font-weight: var(--fw-med); color: var(--ink); }
.pay-amt.deduct { color: var(--amber-text); }
.pay-amt .cur { font-size: 0.62em; color: var(--ink-3); margin-right: 0.1em; }
.pay-net { margin-top: 0.4rem; border-top: var(--hairline-strong); padding-top: 0.9rem; }
.pay-net .k { font-weight: var(--fw-med); color: var(--ink); }
.pay-net .pay-amt { font-size: 2.1rem; font-weight: var(--fw-hero); color: var(--teal-700); }
@media (max-width: 833px) { .pay-grid { grid-template-columns: 1fr; } }

/* ===== ACT 04 · Bento 能力区（强层级） ===== */
.bento { margin-top: var(--rhythm-tight); display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: var(--bento-row); gap: var(--gap); }
.tile { border-radius: var(--r-card-lg); padding: clamp(1.4rem, 1rem + 1.4vw, 2.1rem); display: flex; flex-direction: column; position: relative; overflow: hidden; background: var(--surface); border: var(--hairline); }
.tile.lead-tile { grid-column: span 2; grid-row: span 2; background: var(--teal); color: var(--surface); border-color: transparent; }
.tile.dark { grid-column: span 4; background: var(--ink-surface); color: var(--ink-on-dark); border-color: transparent; background-image: var(--tex-blueprint); }
.tile.col-2 { grid-column: span 2; }
.tile .kx { font-size: var(--t-sm); font-weight: var(--fw-bold); color: var(--teal); letter-spacing: var(--ls-title); }
.tile.lead-tile .kx, .tile.dark .kx { color: var(--on-dark-85); }
.tile h3 { margin-top: 0.4rem; font-size: var(--t-h3); font-weight: var(--fw-med); line-height: 1.15; letter-spacing: var(--ls-title); color: inherit; }
.tile p { margin-top: 0.6rem; font-size: var(--t-base); line-height: 1.5; color: var(--ink-2); max-width: 32ch; }
.tile.lead-tile p, .tile.dark p { color: var(--on-dark-80); }
.tile .vis { margin-top: auto; padding-top: 1.2rem; }
.bars { display: flex; align-items: flex-end; gap: 7px; height: 70px; }
.bars i { flex: 1; background: var(--glass-35); border-radius: var(--r-bar) var(--r-bar) 0 0; }
.bars i.hi { background: var(--surface); }
.chips { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.chips b { font-size: var(--t-xs); font-weight: var(--fw-med); padding: 0.3rem 0.7rem; border-radius: var(--r-chip); background: var(--surface-teal); color: var(--teal); }
.roles { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.roles span { display: inline-flex; align-items: center; gap: 0.4rem; font-size: var(--t-sm); font-weight: var(--fw-med); padding: 0.4rem 0.7rem; border-radius: var(--r-chip); background: var(--glass-12); color: var(--ink-on-dark); }
.roles i { width: 22px; height: 22px; border-radius: 50%; display: grid; place-items: center; font-size: 11px; font-style: normal; background: var(--teal-300); color: var(--ink-surface); }
@media (max-width: 833px) {
  .bento { grid-template-columns: repeat(2, 1fr); }
  .tile.lead-tile { grid-column: span 2; grid-row: span 2; }
  .tile.col-2, .tile.dark { grid-column: span 2; }
}
@media (max-width: 540px) {
  .bento { grid-template-columns: 1fr; grid-auto-rows: auto; }
  .tile, .tile.lead-tile, .tile.col-2, .tile.dark { grid-column: span 1; grid-row: auto; min-height: 0; }
}

/* ===== 适用人群（编辑式名册） ===== */
.roster { margin-top: var(--rhythm-tight); display: grid; grid-template-columns: repeat(4,1fr); gap: var(--gap); }
.person { background: var(--surface); border-radius: var(--r-card-lg); padding: 1.5rem 1.4rem 1.6rem; border: var(--hairline); position: relative; }
.person .pn { font-family: var(--num); font-size: var(--t-xs); color: var(--ink-3); }
.person .ic { width: 52px; height: 52px; margin: 0.8rem 0 0.9rem; border-radius: var(--r-card); display: grid; place-items: center; background: var(--surface-teal); color: var(--teal); }
.person .ic svg { width: 28px; height: 28px; }
.person h3 { font-size: var(--t-h4); font-weight: var(--fw-bold); letter-spacing: var(--ls-title); }
.person p { margin-top: 0.4rem; font-size: var(--t-sm); color: var(--ink-2); line-height: 1.55; }
@media (max-width: 833px) { .roster { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 460px) { .roster { grid-template-columns: 1fr; } }

/* ===== 信任机制（机制卡） ===== */
.trust-grid { margin-top: var(--rhythm-tight); display: grid; grid-template-columns: repeat(4,1fr); gap: var(--gap); }
.trust-card { background: var(--surface); border: var(--hairline); border-radius: var(--r-card); padding: 1.4rem 1.3rem; }
.trust-card .ic { width: 44px; height: 44px; border-radius: var(--r-input); display: grid; place-items: center; background: var(--surface-teal); color: var(--teal); margin-bottom: 0.9rem; }
.trust-card .ic svg { width: 22px; height: 22px; }
.trust-card h3 { font-size: var(--t-h4); font-weight: var(--fw-bold); letter-spacing: var(--ls-title); }
.trust-card p { margin-top: 0.35rem; font-size: var(--t-sm); color: var(--ink-2); line-height: 1.55; }
@media (max-width: 833px) { .trust-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 460px) { .trust-grid { grid-template-columns: 1fr; } }

/* ===== 多端同步（设备行） ===== */
.plat-row { margin-top: var(--rhythm-tight); display: grid; grid-template-columns: repeat(4,1fr); gap: var(--gap); max-width: 880px; }
.plat-cell { display: grid; justify-items: center; gap: 0.7rem; text-align: center; }
.plat-cell .g { width: clamp(56px,14vw,82px); height: clamp(56px,14vw,82px); border-radius: var(--r-card); display: grid; place-items: center; background: var(--surface); box-shadow: var(--shadow-sm); border: var(--hairline); }
.plat-cell .g svg { width: 46%; height: 46%; color: var(--ink); }
.plat-cell .nm { font-size: var(--t-base); font-weight: var(--fw-bold); letter-spacing: var(--ls-title); }
.plat-cell .ds { font-size: var(--t-xs); color: var(--ink-3); }
@media (max-width: 540px) { .plat-row { grid-template-columns: repeat(2,1fr); } }

/* ===== 下载 CTA（暗色 + 蓝图 · 扫码为主） ===== */
.download { background-image: var(--tex-blueprint); position: relative; }
.download::after { content: ""; position: absolute; inset: 0; background: var(--atmos-stage); pointer-events: none; }
.download .ch-wrap { position: relative; z-index: var(--z-raised); }

/* 扫码卡（白底，二维码需白底可扫；主码更大） */
.dl-scan { margin-top: var(--rhythm-tight); display: grid; grid-template-columns: 1.5fr 1fr; gap: var(--gap); align-items: stretch; }
.qr-card { background: var(--surface); border-radius: var(--r-card-lg); padding: clamp(1.2rem, 1rem + 1vw, 1.8rem); display: flex; gap: clamp(0.9rem, 2vw, 1.4rem); align-items: center; box-shadow: var(--shadow-lg); position: relative; }
.qr-card .qr-img { flex: none; background: var(--surface); border-radius: var(--r-card); padding: 8px; box-shadow: inset 0 0 0 1px var(--line); }
.qr-card .qr-img img { width: clamp(116px, 26vw, 164px); height: auto; border-radius: var(--r-sm); display: block; }
.qr-meta b { display: block; font-size: var(--t-h4); font-weight: var(--fw-bold); color: var(--ink); letter-spacing: var(--ls-title); }
.qr-meta p { margin-top: 0.4rem; font-size: var(--t-sm); color: var(--ink-2); line-height: 1.55; }
.qr-meta p strong { color: var(--teal); font-weight: var(--fw-med); }
.qr-os { margin-top: 0.8rem; display: flex; align-items: center; gap: 0.55rem; color: var(--ink-3); }
.qr-os svg { width: 19px; height: 19px; }
.qr-os span { font-size: var(--t-xs); color: var(--ink-3); }
.qr-primary::before { content: "推荐"; position: absolute; top: 12px; right: 14px; font-size: var(--t-xs); font-weight: var(--fw-bold); color: var(--teal); background: var(--surface-teal); padding: 0.15rem 0.6rem; border-radius: var(--r-chip); }

/* 给「正用手机看官网」的人：直达智能下载页（按机型自动跳市场） */
.dl-onphone { margin-top: var(--s-6); display: flex; align-items: center; gap: 0.7rem; flex-wrap: wrap; font-size: var(--t-base); color: var(--ink-on-dark-2); }
.dl-onphone .btn-ghost { color: var(--teal-300); box-shadow: inset 0 0 0 1.5px var(--line-on-dark); }
.dl-onphone .btn-ghost:hover { background: var(--glass-10); }

@media (max-width: 833px) { .dl-scan { grid-template-columns: 1fr; } }
@media (max-width: 460px) { .qr-card { flex-direction: column; text-align: center; } .qr-os { justify-content: center; } }

/* ===== 常见问题 FAQ（原生 details · 内容常驻 DOM 供爬虫/AI 抽取） ===== */
.faqs { margin-top: var(--rhythm-tight); display: grid; gap: var(--gap-tight); max-width: 920px; }
.faq-q2 { background: var(--surface); border: var(--hairline); border-radius: var(--r-card); overflow: hidden; transition: box-shadow var(--dur) var(--ease-out-soft); }
.faq-q2[open] { box-shadow: var(--shadow-sm); }
.faq-q2 > summary { cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding: 1.05rem 1.3rem; font-size: var(--t-h4); font-weight: var(--fw-med); line-height: var(--lh-tight); letter-spacing: var(--ls-title); color: var(--ink); }
.faq-q2 > summary::-webkit-details-marker { display: none; }
.faq-q2 > summary:hover { background: var(--surface-teal); }
.faq-q2 > summary:focus-visible { outline: none; box-shadow: var(--shadow-focus); }
.faq-q2 .mk { flex: none; width: 26px; height: 26px; display: grid; place-items: center; color: var(--teal); transition: transform var(--dur) var(--ease-out-expo); }
.faq-q2 .mk svg { width: 20px; height: 20px; }
.faq-q2[open] .mk { transform: rotate(135deg); }
.faq-a2 { padding: 0 1.3rem 1.15rem; }
.faq-a2 p { font-size: var(--t-base); line-height: var(--lh-body); color: var(--ink-2); }
.faq-a2 strong { color: var(--teal-700); font-weight: var(--fw-med); }
.faq-a2 a { color: var(--teal); font-weight: var(--fw-med); text-decoration: underline; text-underline-offset: 2px; }
.is-cheap .faq-q2 .mk { transition: none; }
