﻿:root{
  --bg1:#f2f7ff; --bg2:#f7f2ff; --ink:#0f172a; --muted:#64748b; --brand:#4f7cff; --brand2:#7c4dff;
  --pill:#e8efff; --shadow:0 10px 30px rgba(0,0,0,.08); --card:#ffffff; --line:rgba(15,23,42,.08);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Hiragino Sans GB","Microsoft YaHei",Segoe UI,Roboto,Helvetica,Arial,sans-serif; background:radial-gradient(1200px 1200px at 10% -10%,var(--bg1),transparent),radial-gradient(1200px 1200px at 100% 0%,var(--bg2),transparent),linear-gradient(180deg,#f8fbff,#f7f4ff 60%,#f7f7ff)}

/* 关键修复：统一图文对齐 */
figure{margin:0}           /* 去掉 figure 默认外边距，避免卡片内元素错位 */
img{display:block}         /* 消除图片行内基线差异，让高度一致 */

.paper{max-width:980px;margin:28px auto;padding:28px}
.hero{background:linear-gradient(180deg,#ffffffcc,#ffffffaa 60%,#ffffffcc);border:1px solid var(--line);border-radius:28px;padding:28px;box-shadow:var(--shadow)}
.logo{display:flex;align-items:center;gap:14px}
.logo .icon{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,var(--brand),var(--brand2));color:#fff;font-weight:800;font-size:26px;box-shadow:0 8px 20px rgba(79,124,255,.35)}
.logo h1{margin:0;font-size:32px;letter-spacing:.3px}
.tagline{margin:8px 0 14px;color:var(--muted)}
.pill{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:999px;background:linear-gradient(135deg,#e9efff,#efe8ff);color:#284081;font-weight:700;box-shadow:0 6px 18px rgba(79,124,255,.15)}
.pill .star{width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,var(--brand),var(--brand2));display:inline-block}
.subline{margin-top:12px;color:#2b3351}
.badges{display:flex;flex-wrap:wrap;gap:12px;margin:18px 0}
.badge{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 16px;font-weight:700;box-shadow:var(--shadow)}
.badge.em{background:linear-gradient(135deg,#e9efff,#efe8ff);border-color:transparent}
.cta-wrap{display:flex;gap:12px;flex-wrap:wrap}
.btn{cursor:pointer;user-select:none;border:0;padding:14px 22px;border-radius:999px;font-weight:800;letter-spacing:.5px}
.btn.primary{color:#fff;background:linear-gradient(135deg,var(--brand),var(--brand2));box-shadow:0 10px 24px rgba(79,124,255,.35)}
.btn.ghost{background:#fff;border:1px solid var(--line);color:#1f2a44}
.section{margin-top:32px;background:linear-gradient(180deg,#ffffff,#fbfbff);border:1px solid var(--line);border-radius:28px;box-shadow:var(--shadow)}
.section .head{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--line)}
.ribbon{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border-radius:999px;color:#fff;font-weight:800;font-size:15px;background:linear-gradient(135deg,var(--brand),var(--brand2));box-shadow:0 8px 22px rgba(79,124,255,.3)}
.logo .icon-img { width:56px; height:56px; border-radius:16px; object-fit:contain; padding:6px; box-shadow:0 8px 20px rgba(79,124,255,.18); }
.grid{padding:18px 18px 28px;display:grid;grid-template-columns:repeat(4,1fr);gap:18px;align-items:start} /* 让每列从顶部对齐 */
.grid-2{grid-template-columns:repeat(2,1fr) !important}
@media (max-width:980px){.paper{padding:16px}}
@media (max-width:820px){.grid{grid-template-columns:repeat(2,1fr)}.logo h1{font-size:26px}.logo .icon{width:50px;height:50px}}

.card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:14px;display:flex;flex-direction:column;gap:10px;height:100%}
.step{display:flex;align-items:center;gap:8px;font-weight:800;color:#1f2a44;min-height:32px} /* 统一标题高度，避免因换行造成的位移 */
.step .dot{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#e9efff,#efe8ff);color:#3651a5}

.shot{position:relative;width:100%;aspect-ratio:9/19.5;border-radius:16px;overflow:hidden;border:1px solid #c0c7de;background:#f8f9fc;margin-top:10px}
.shot.wide{aspect-ratio:16/9}
.shot img{width:100%;height:100%;object-fit:cover}

.cap{font-size:13px;color:#3a4466;line-height:1.5}
.notice{padding:16px 18px;border-top:1px dashed var(--line);background:linear-gradient(180deg,#fbfbff,#fff)}
.notice ul{margin:6px 0 0 18px;color:#475569}
.footer{margin:22px auto 8px;text-align:center;color:#7b859f;font-size:12px}

/* 打印优化 */
@media print{body{background:#fff}.paper{margin:0;padding:0}.hero,.section{box-shadow:none}}