:root {
  --ink: #0b1c26;
  --ink-2: #17313d;
  --navy: #071927;
  --navy-soft: #0d2b39;
  --red: #8e2030;
  --red-deep: #68131f;
  --gold: #cba55f;
  --gold-light: #e7d2a2;
  --cream: #f6f1e8;
  --paper: #fffdf9;
  --muted: #667680;
  --line: rgba(11, 28, 38, .12);
  --shadow: 0 24px 70px rgba(7, 25, 39, .12);
  --shadow-soft: 0 12px 34px rgba(7, 25, 39, .08);
  --radius-xl: 30px;
  --radius-lg: 22px;
  --radius-md: 16px;
  --container: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: Inter, "SF Pro Display", "PingFang SC", "Microsoft YaHei", system-ui, -apple-system, sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
button, input { font: inherit; }
button { cursor: pointer; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
.container { width: min(var(--container), calc(100% - 40px)); margin-inline: auto; }
.section { padding: 112px 0; }
.section-muted { background: #f2f3f1; }
.skip-link { position: fixed; top: 10px; left: 10px; z-index: 999; transform: translateY(-160%); padding: 10px 14px; background: #fff; border-radius: 8px; box-shadow: var(--shadow-soft); }
.skip-link:focus { transform: translateY(0); }

.site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 50;
  transition: background .25s ease, box-shadow .25s ease, backdrop-filter .25s ease;
}
.site-header.is-scrolled { background: rgba(255, 253, 249, .88); box-shadow: 0 8px 28px rgba(7,25,39,.08); backdrop-filter: blur(18px); }
.nav-wrap { min-height: 82px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.brand { display: inline-flex; align-items: center; gap: 12px; }
.brand-mark { width: 42px; aspect-ratio: 1; display: grid; place-items: center; border-radius: 13px; background: linear-gradient(145deg, #9c2739, #711522); color: #fff7e8; font: 700 23px/1 serif; box-shadow: inset 0 0 0 1px rgba(255,255,255,.18), 0 10px 30px rgba(142,32,48,.2); }
.brand > span:last-child { display: grid; gap: 2px; }
.brand strong { font-size: 15px; letter-spacing: .08em; }
.brand small { font-size: 8px; letter-spacing: .18em; color: #6e7b82; }
.desktop-nav { display: flex; align-items: center; gap: 34px; margin-left: auto; }
.desktop-nav a { font-size: 14px; color: #394b55; transition: color .2s ease; }
.desktop-nav a:hover { color: var(--red); }

.btn { border: 0; border-radius: 999px; display: inline-flex; align-items: center; justify-content: center; gap: 10px; min-height: 48px; padding: 0 22px; font-weight: 700; transition: transform .2s ease, box-shadow .2s ease, background .2s ease, color .2s ease; }
.btn:hover { transform: translateY(-2px); }
.btn:focus-visible, .choice:has(input:focus-visible), a:focus-visible { outline: 3px solid rgba(203,165,95,.55); outline-offset: 3px; }
.btn svg { width: 19px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.btn-primary { color: #fff; background: linear-gradient(135deg, #9f2a3d, #741724); box-shadow: 0 14px 34px rgba(142,32,48,.26); }
.btn-primary:hover { box-shadow: 0 18px 42px rgba(142,32,48,.34); }
.btn-secondary { color: var(--ink); background: #edf0ef; box-shadow: inset 0 0 0 1px rgba(11,28,38,.08); }
.btn-ghost { background: rgba(255,255,255,.58); color: var(--red); box-shadow: inset 0 0 0 1px rgba(142,32,48,.18); }
.btn-link { min-height: auto; padding: 8px 0; border-radius: 0; background: none; color: #334751; border-bottom: 1px solid rgba(51,71,81,.35); }
.btn-lg { min-height: 58px; padding-inline: 28px; }
.btn-sm { min-height: 42px; padding-inline: 18px; font-size: 13px; }
.btn-full { width: 100%; }

.hero { min-height: 860px; position: relative; overflow: hidden; padding: 154px 0 90px; background: linear-gradient(140deg, #fffdf8 0%, #f5eee5 52%, #eadfd2 100%); }
.hero::before { content: ""; position: absolute; inset: auto 0 0; height: 140px; background: linear-gradient(180deg, transparent, rgba(142,32,48,.06)); }
.hero-grid { position: absolute; inset: 0; opacity: .3; background-image: linear-gradient(rgba(11,28,38,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(11,28,38,.035) 1px, transparent 1px); background-size: 54px 54px; mask-image: linear-gradient(to bottom, #000, transparent 80%); }
.hero-glow { position: absolute; border-radius: 50%; filter: blur(1px); pointer-events: none; }
.hero-glow-one { width: 500px; height: 500px; right: -180px; top: 40px; background: radial-gradient(circle, rgba(142,32,48,.18), transparent 67%); }
.hero-glow-two { width: 440px; height: 440px; left: -220px; bottom: -100px; background: radial-gradient(circle, rgba(203,165,95,.25), transparent 68%); }
.hero-layout { position: relative; z-index: 2; display: grid; grid-template-columns: 1.02fr .98fr; align-items: center; gap: 70px; }
.eyebrow { display: inline-flex; align-items: center; gap: 10px; color: var(--red); font-size: 12px; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.eyebrow span { width: 34px; height: 1px; background: currentColor; }
.eyebrow.dark { color: var(--red); }
.eyebrow.light { color: #e6c98e; }
.hero h1 { margin: 26px 0 24px; font-size: clamp(50px, 5.5vw, 78px); line-height: 1.08; letter-spacing: -.055em; font-family: "Songti SC", "Noto Serif SC", STSong, serif; font-weight: 800; }
.hero h1 em { display: block; font-style: normal; color: var(--red); position: relative; width: fit-content; }
.hero h1 em::after { content: ""; position: absolute; left: 2px; right: 0; bottom: -10px; height: 7px; background: linear-gradient(90deg, var(--gold), transparent); border-radius: 50%; opacity: .65; }
.hero-lead { max-width: 650px; margin: 0; color: #53656e; font-size: 18px; line-height: 1.9; }
.hero-actions { display: flex; align-items: center; gap: 24px; margin-top: 38px; }
.trust-row { margin-top: 54px; display: flex; gap: 34px; }
.trust-row > div { display: grid; gap: 4px; padding-right: 34px; border-right: 1px solid var(--line); }
.trust-row > div:last-child { border-right: 0; }
.trust-row strong { font-size: 17px; }
.trust-row span { font-size: 12px; color: var(--muted); }

.hero-visual { position: relative; min-height: 610px; }
.orbit { position: absolute; border: 1px solid rgba(142,32,48,.17); border-radius: 50%; }
.orbit-one { width: 520px; height: 520px; left: 22px; top: 30px; }
.orbit-two { width: 420px; height: 420px; left: 72px; top: 80px; border-style: dashed; animation: spin 36s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.report-card { position: absolute; width: 306px; height: 418px; left: 132px; top: 75px; border-radius: 14px 30px 24px 14px; padding: 28px; color: #f8e9cd; background: linear-gradient(145deg, #a12b40, #6d1421 75%); box-shadow: 0 42px 80px rgba(75,17,27,.32); transform: rotate(-3.5deg); overflow: hidden; }
.report-card::before { content: ""; position: absolute; inset: 12px; border: 1px solid rgba(231,210,162,.35); border-radius: 9px 24px 18px 9px; }
.report-card::after { content: ""; position: absolute; width: 190px; height: 190px; border-radius: 50%; right: -80px; bottom: -80px; border: 1px solid rgba(231,210,162,.25); box-shadow: 0 0 0 20px rgba(231,210,162,.04), 0 0 0 44px rgba(231,210,162,.03); }
.report-card-top { position: relative; z-index: 2; display: flex; justify-content: space-between; font-size: 8px; letter-spacing: .12em; opacity: .8; }
.report-monogram { position: relative; z-index: 2; margin-top: 50px; color: var(--gold-light); font: 700 68px/1 Georgia, serif; letter-spacing: -.08em; opacity: .26; }
.report-card h2 { position: relative; z-index: 2; margin: -12px 0 0; color: #fff8ec; font: 700 30px/1.4 "Songti SC", serif; letter-spacing: .08em; }
.report-lines { position: relative; z-index: 2; display: grid; gap: 8px; margin-top: 28px; }
.report-lines i { display: block; height: 1px; background: rgba(231,210,162,.3); }
.report-lines i:nth-child(2) { width: 74%; }
.report-lines i:nth-child(3) { width: 48%; }
.report-seal { position: absolute; z-index: 2; right: 28px; bottom: 34px; width: 62px; aspect-ratio: 1; display: grid; place-items: center; text-align: center; border: 1px solid rgba(231,210,162,.55); border-radius: 50%; font-size: 11px; line-height: 1.4; color: var(--gold-light); transform: rotate(8deg); }
.passport-card { position: absolute; z-index: 3; width: 178px; height: 248px; left: 40px; top: 270px; border-radius: 16px; padding: 24px 18px; color: #f9e8c7; background: linear-gradient(150deg, #173a46, #071927); box-shadow: 0 28px 55px rgba(7,25,39,.3); transform: rotate(7deg); text-align: center; }
.passport-card span { font-size: 10px; letter-spacing: .22em; }
.passport-card small { display: block; margin-top: 20px; font-size: 7px; letter-spacing: .17em; opacity: .7; }
.bauhinia { width: 92px; aspect-ratio: 1; display: grid; place-items: center; margin: 40px auto 0; border: 1px solid rgba(231,210,162,.5); border-radius: 50%; font-size: 42px; color: var(--gold-light); }
.radar-card { position: absolute; z-index: 4; width: 265px; right: -8px; bottom: 24px; border-radius: 22px; padding: 20px; color: #e7f0f2; background: rgba(7,25,39,.92); box-shadow: 0 28px 70px rgba(7,25,39,.25); backdrop-filter: blur(15px); display: grid; grid-template-columns: 1fr 128px; align-items: center; gap: 8px; }
.radar-card small { color: #9db1ba; font-size: 10px; }
.radar-card strong { display: block; margin-top: 8px; font-size: 14px; }
.radar-grid { fill: none; stroke: rgba(255,255,255,.16); stroke-width: 1; }
.radar-shape { fill: rgba(203,165,95,.22); stroke: #d4b572; stroke-width: 2; }
.radar-points { fill: #fff1ce; }
.skyline { position: absolute; left: -60px; right: -80px; bottom: -30px; z-index: 0; opacity: .1; }
.skyline path { fill: var(--navy); }

.section-head { max-width: 720px; margin-bottom: 48px; }
.section-head h2, .official-wrap h2 { margin: 16px 0; font: 750 clamp(34px, 4vw, 52px)/1.2 "Songti SC", "Noto Serif SC", serif; letter-spacing: -.035em; }
.section-head p, .official-wrap p { margin: 0; color: var(--muted); font-size: 16px; line-height: 1.85; }
.inline-head { max-width: none; display: flex; align-items: end; justify-content: space-between; gap: 70px; }
.inline-head > div { max-width: 620px; }
.inline-head > p { max-width: 430px; padding-bottom: 8px; }
.feature-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.feature-card { min-height: 304px; padding: 30px; border: 1px solid var(--line); border-radius: var(--radius-lg); background: rgba(255,255,255,.72); box-shadow: 0 20px 45px rgba(7,25,39,.045); transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.feature-card:hover { transform: translateY(-7px); box-shadow: var(--shadow-soft); border-color: rgba(142,32,48,.24); }
.icon-box { width: 54px; aspect-ratio: 1; display: grid; place-items: center; border-radius: 16px; color: var(--red); background: #f5e8e7; }
.icon-box svg { width: 25px; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.feature-card small { display: block; margin-top: 34px; color: var(--gold); font-size: 10px; font-weight: 800; letter-spacing: .13em; }
.feature-card h3 { margin: 11px 0 12px; font-size: 22px; }
.feature-card p { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.85; }

.path-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.path-card { min-height: 270px; position: relative; overflow: hidden; padding: 26px 22px; border-radius: 20px; border: 1px solid rgba(11,28,38,.08); background: #fff; display: flex; flex-direction: column; transition: transform .25s ease, box-shadow .25s ease; }
.path-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-soft); }
.path-card > span { color: var(--gold); font: 600 36px/1 Georgia, serif; opacity: .7; }
.path-card h3 { margin: auto 0 14px; font-size: 22px; }
.path-card p { min-height: 84px; margin: 0 0 20px; color: var(--muted); font-size: 13px; line-height: 1.75; }
.path-card b { padding-top: 16px; border-top: 1px solid var(--line); color: #42545e; font-size: 11px; letter-spacing: .06em; }
.path-red { color: #fff; background: linear-gradient(145deg, #9a283a, #6a1420); box-shadow: 0 24px 50px rgba(142,32,48,.18); }
.path-red > span, .path-red b { color: #ecd29c; }
.path-red p { color: rgba(255,255,255,.75); }
.path-red b { border-color: rgba(255,255,255,.16); }

.assessment-section { background: linear-gradient(180deg, #fffdf9 0, #f4eee5 100%); }
.assessment-shell { display: grid; grid-template-columns: 350px minmax(0, 1fr); gap: 28px; align-items: start; }
.assessment-intro { position: sticky; top: 110px; min-height: 650px; padding: 42px 36px; border-radius: var(--radius-xl); color: #fff; background: linear-gradient(165deg, #0c2c3a, #071927 72%); box-shadow: var(--shadow); overflow: hidden; }
.assessment-intro::after { content: ""; position: absolute; width: 280px; height: 280px; border-radius: 50%; right: -130px; bottom: -100px; border: 1px solid rgba(203,165,95,.25); box-shadow: 0 0 0 28px rgba(203,165,95,.035), 0 0 0 60px rgba(203,165,95,.025); }
.assessment-intro h2 { margin: 22px 0 16px; font: 700 34px/1.35 "Songti SC", serif; }
.assessment-intro > p { margin: 0; color: #aebdc4; font-size: 14px; line-height: 1.85; }
.assessment-intro ul { position: relative; z-index: 2; list-style: none; margin: 38px 0; padding: 0; display: grid; gap: 20px; }
.assessment-intro li { display: flex; align-items: center; gap: 14px; color: #dce5e8; font-size: 13px; }
.assessment-intro li i { width: 34px; aspect-ratio: 1; display: grid; place-items: center; flex: none; border-radius: 50%; border: 1px solid rgba(231,210,162,.45); color: #e7d2a2; font-style: normal; font-size: 10px; }
.assessment-note { position: relative; z-index: 2; padding-top: 22px; border-top: 1px solid rgba(255,255,255,.11); color: #8299a3; font-size: 11px; line-height: 1.75; }
.quiz-card { padding: 38px 42px 32px; border-radius: var(--radius-xl); background: #fff; box-shadow: var(--shadow); }
.quiz-header { display: flex; align-items: end; justify-content: space-between; gap: 20px; }
.quiz-header small { color: var(--red); font-size: 10px; font-weight: 800; letter-spacing: .15em; }
.quiz-header h3 { margin: 7px 0 0; font-size: 24px; }
.quiz-header > span { color: var(--muted); font-size: 13px; font-weight: 700; }
.progress-track { height: 5px; margin: 20px 0 34px; overflow: hidden; border-radius: 999px; background: #e9edeb; }
.progress-track i { display: block; width: 20%; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--gold), var(--red)); transition: width .3s ease; }
.form-step { display: none; }
.form-step.is-active { display: block; animation: stepIn .32s ease; }
@keyframes stepIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.form-step > h4 { margin: 0 0 30px; font: 700 26px/1.35 "Songti SC", serif; }
.question { margin: 0 0 30px; padding: 0; border: 0; }
.question legend { width: 100%; margin-bottom: 14px; font-size: 15px; font-weight: 750; line-height: 1.6; }
.question.is-invalid legend { color: var(--red); }
.choice-grid { display: grid; gap: 11px; }
.choice-grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.choice-grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.choice-grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.choice { position: relative; min-height: 62px; border: 1px solid #dfe5e3; border-radius: 14px; background: #fafbf9; display: flex; align-items: center; transition: border-color .2s ease, background .2s ease, transform .2s ease, box-shadow .2s ease; cursor: pointer; overflow: hidden; }
.choice:hover { border-color: rgba(142,32,48,.32); transform: translateY(-1px); }
.choice:has(input:checked) { border-color: var(--red); background: #fff7f6; box-shadow: inset 0 0 0 1px rgba(142,32,48,.12), 0 8px 20px rgba(142,32,48,.07); }
.choice input { position: absolute; opacity: 0; pointer-events: none; }
.choice > span { width: 100%; padding: 14px 36px 14px 16px; font-size: 13px; line-height: 1.5; }
.choice > span::after { content: ""; position: absolute; right: 14px; top: 50%; width: 16px; aspect-ratio: 1; border: 1px solid #b8c4c1; border-radius: 50%; transform: translateY(-50%); transition: .2s ease; }
.choice:has(input:checked) > span::after { border: 5px solid var(--red); background: #fff; }
.check-grid .choice > span::after { border-radius: 5px; }
.check-grid .choice:has(input:checked) > span::after { border: 0; background: var(--red); }
.check-grid .choice:has(input:checked) > span::before { content: "✓"; position: absolute; z-index: 2; right: 16px; top: 50%; transform: translateY(-52%); color: #fff; font-size: 12px; }
.choice b { display: block; font-size: 13px; }
.choice small { display: block; margin-top: 3px; color: var(--muted); font-size: 10px; }
.consent { display: flex; gap: 11px; align-items: flex-start; padding: 16px; border-radius: 12px; background: #f4f6f5; color: #5d6d75; font-size: 12px; line-height: 1.6; cursor: pointer; }
.consent input { margin-top: 2px; accent-color: var(--red); }
.form-alert { min-height: 20px; margin-top: -8px; color: var(--red); font-size: 12px; font-weight: 700; }
.quiz-actions { display: flex; justify-content: space-between; gap: 14px; padding-top: 22px; border-top: 1px solid var(--line); }
.quiz-actions .btn:last-child { margin-left: auto; }

.assessment-shell.is-results-mode { grid-template-columns: minmax(0, 1fr); }
.assessment-shell.is-results-mode .results { grid-column: 1; width: 100%; }
.results { grid-column: 1 / -1; border-radius: var(--radius-xl); overflow: hidden; background: #fff; box-shadow: var(--shadow); }
.result-hero { min-height: 270px; padding: 44px 50px; display: flex; align-items: center; justify-content: space-between; gap: 40px; color: #fff; background: radial-gradient(circle at 78% 24%, rgba(203,165,95,.22), transparent 22%), linear-gradient(145deg, #0d3140, #071927 72%); }
.result-hero h2 { margin: 18px 0 10px; font: 700 40px/1.25 "Songti SC", serif; }
.result-hero p { margin: 0; max-width: 650px; color: #b8c8ce; line-height: 1.75; }
.result-meta { display: flex; gap: 20px; margin-top: 26px; color: #8fa4ae; font-size: 11px; }
.result-gauge { --score: 85; width: 150px; aspect-ratio: 1; flex: none; border-radius: 50%; display: grid; place-content: center; text-align: center; background: radial-gradient(circle at center, #0a2230 56%, transparent 57%), conic-gradient(#d7b66f calc(var(--score) * 1%), rgba(255,255,255,.12) 0); box-shadow: inset 0 0 0 1px rgba(255,255,255,.06), 0 20px 40px rgba(0,0,0,.18); }
.result-gauge strong { font-size: 36px; }
.result-gauge small { margin-top: 2px; color: #9fb1b9; font-size: 10px; }
.result-body { display: grid; grid-template-columns: minmax(0, 1fr) 330px; gap: 34px; padding: 42px 46px; }
.result-main { min-width: 0; }
.result-block + .result-block { margin-top: 42px; }
.block-title { display: flex; align-items: center; gap: 14px; margin-bottom: 20px; }
.block-title > span { width: 38px; aspect-ratio: 1; display: grid; place-items: center; border-radius: 11px; color: var(--red); background: #f5e9e8; font: 700 11px Georgia, serif; }
.block-title small { color: var(--gold); font-size: 9px; font-weight: 800; letter-spacing: .15em; }
.block-title h3 { margin: 4px 0 0; font-size: 21px; }
.ranking-note { margin: -4px 0 16px; padding: 11px 14px; border-left: 3px solid var(--gold); border-radius: 0 10px 10px 0; color: #687980; background: #f7f6f1; font-size: 11px; line-height: 1.65; }
.ranking-list { display: grid; gap: 13px; }
.rank-card { position: relative; display: grid; grid-template-columns: 60px minmax(0, 1fr) 110px; gap: 15px; align-items: center; padding: 18px; border: 1px solid var(--line); border-radius: 16px; background: #fcfdfb; overflow: hidden; }
.rank-card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--rank-color, var(--gold)); }
.rank-index { width: 42px; aspect-ratio: 1; display: grid; place-items: center; border-radius: 50%; color: #fff; background: var(--ink); font: 700 13px Georgia, serif; }
.rank-heading { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; margin-bottom: 4px; }
.rank-copy h4 { margin: 0; font-size: 16px; }
.rank-category { display: inline-flex; padding: 3px 7px; border-radius: 999px; color: #41545d; background: #edf1f0; font-size: 8px; font-weight: 800; letter-spacing: .04em; }
.rank-official { color: #283f49 !important; font-weight: 700; }
.rank-copy p { margin: 0; color: var(--muted); font-size: 11px; line-height: 1.65; }
.rank-score { text-align: right; }
.rank-score strong { color: var(--red); font-size: 24px; }
.rank-score small { display: block; color: var(--muted); font-size: 9px; }
.rank-badge { display: inline-flex; margin-top: 6px; padding: 4px 8px; border-radius: 999px; color: #5b471c; background: #f4e8c8; font-size: 9px; font-weight: 800; }
.finding-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.finding { border-radius: 16px; padding: 20px; }
.finding.good { background: #f0f6f3; }
.finding.caution { background: #fbf4e8; }
.finding h4 { margin: 0 0 12px; font-size: 14px; }
.finding ul { margin: 0; padding-left: 18px; color: #52636c; font-size: 12px; line-height: 1.8; }
.action-list { display: grid; gap: 13px; margin: 0; padding: 0; counter-reset: action; list-style: none; }
.action-list li { position: relative; counter-increment: action; padding: 15px 16px 15px 52px; border: 1px solid var(--line); border-radius: 14px; color: #4f626b; font-size: 12px; line-height: 1.65; }
.action-list li::before { content: counter(action); position: absolute; left: 16px; top: 14px; width: 24px; aspect-ratio: 1; display: grid; place-items: center; border-radius: 50%; color: #fff; background: var(--red); font-size: 10px; font-weight: 800; }
.consult-card { position: sticky; top: 110px; align-self: start; padding: 28px; border-radius: 22px; color: #fff; background: linear-gradient(155deg, #923044, #68131f); box-shadow: 0 22px 46px rgba(142,32,48,.22); }
.consult-card > small { color: #e4ca94; font-size: 9px; font-weight: 800; letter-spacing: .14em; }
.consult-card h3 { margin: 12px 0 12px; font-size: 21px; line-height: 1.45; }
.consult-card > p { margin: 0; color: rgba(255,255,255,.72); font-size: 12px; line-height: 1.75; }
.qr-frame { width: 205px; margin: 24px auto 16px; padding: 8px; border-radius: 18px; background: #fff; box-shadow: 0 16px 35px rgba(48,6,13,.28); }
.qr-frame img { width: 100%; border-radius: 12px; }
.wechat-id { margin-bottom: 18px; text-align: center; color: rgba(255,255,255,.75); font-size: 11px; }
.wechat-id strong { color: #fff; }
.consult-card .btn-primary { color: var(--red-deep); background: #fff; box-shadow: none; }
.privacy-tip { margin-top: 15px; padding-top: 15px; border-top: 1px solid rgba(255,255,255,.13); color: rgba(255,255,255,.55); font-size: 9px; line-height: 1.65; }
.result-footer-actions { display: flex; gap: 12px; padding: 0 46px 24px; }
.legal-disclaimer { margin: 0; padding: 20px 46px 32px; border-top: 1px solid var(--line); color: #7b898f; font-size: 10px; line-height: 1.75; }

.official-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 90px; align-items: center; }
.official-links { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.official-links a { min-height: 78px; padding: 18px; display: flex; align-items: center; justify-content: space-between; gap: 12px; border: 1px solid var(--line); border-radius: 15px; background: #fff; font-size: 13px; font-weight: 700; transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease; }
.official-links a:hover { transform: translateY(-3px); border-color: rgba(142,32,48,.2); box-shadow: var(--shadow-soft); }
.official-links span { color: var(--red); font-size: 18px; }
.site-footer { padding: 34px 0; color: #dbe3e6; background: #06151f; }
.footer-grid { display: flex; align-items: center; justify-content: space-between; gap: 30px; }
.footer-brand strong { color: #fff; }
.footer-brand small { color: #879aa3; }
.site-footer p { margin: 0; color: #748891; font-size: 10px; }
.floating-contact { position: fixed; z-index: 45; right: 22px; bottom: calc(22px + env(safe-area-inset-bottom)); min-height: 54px; padding: 0 18px; border: 0; border-radius: 999px; display: flex; align-items: center; gap: 9px; color: #fff; background: linear-gradient(135deg, #9c293c, #711522); box-shadow: 0 16px 35px rgba(142,32,48,.3); }
.floating-contact svg { width: 20px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.floating-contact span { font-size: 12px; font-weight: 800; }

.reveal { opacity: 0; transform: translateY(16px); transition: opacity .65s ease, transform .65s ease; }
.reveal.is-visible { opacity: 1; transform: none; }
[hidden] { display: none !important; }

@media (max-width: 1100px) {
  .hero-layout { gap: 30px; }
  .hero-visual { transform: scale(.9); transform-origin: center; }
  .feature-grid { grid-template-columns: repeat(2, 1fr); }
  .path-grid { grid-template-columns: repeat(3, 1fr); }
  .assessment-shell { grid-template-columns: 300px minmax(0, 1fr); }
  .choice-grid-4 { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 860px) {
  .container { width: min(100% - 30px, var(--container)); }
  .section { padding: 82px 0; }
  .desktop-nav { display: none; }
  .nav-wrap { min-height: 70px; }
  .hero { min-height: auto; padding: 125px 0 60px; }
  .hero-layout { grid-template-columns: 1fr; }
  .hero-copy { text-align: center; }
  .hero-copy .eyebrow { justify-content: center; }
  .hero h1 em { margin-inline: auto; }
  .hero-lead { margin-inline: auto; }
  .hero-actions, .trust-row { justify-content: center; }
  .hero-visual { min-height: 560px; width: min(590px, 100%); margin-inline: auto; transform: scale(.92); }
  .inline-head, .official-wrap { grid-template-columns: 1fr; display: grid; gap: 30px; }
  .path-grid { grid-template-columns: repeat(2, 1fr); }
  .assessment-shell { grid-template-columns: 1fr; }
  .assessment-intro { position: relative; top: auto; min-height: auto; }
  .assessment-intro ul { grid-template-columns: 1fr 1fr; }
  .results { grid-column: 1; }
  .result-body { grid-template-columns: 1fr; }
  .consult-card { position: relative; top: auto; display: grid; grid-template-columns: minmax(0,1fr) 210px; column-gap: 22px; align-items: center; }
  .consult-card .qr-frame { grid-column: 2; grid-row: 1 / span 4; }
  .consult-card .wechat-id, .consult-card .btn, .consult-card .privacy-tip { grid-column: 1; }
  .official-links { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 620px) {
  .container { width: min(100% - 22px, var(--container)); }
  .site-header .btn-ghost { display: none; }
  .brand small { display: none; }
  .hero { padding-top: 108px; }
  .hero h1 { font-size: 44px; }
  .hero-lead { font-size: 15px; line-height: 1.8; }
  .hero-actions { flex-direction: column; gap: 12px; }
  .hero-actions .btn { width: 100%; }
  .trust-row { gap: 0; justify-content: space-between; }
  .trust-row > div { flex: 1; padding: 0 10px; }
  .trust-row strong { font-size: 14px; }
  .trust-row span { font-size: 9px; }
  .hero-visual { min-height: 460px; transform: none; }
  .orbit-one { width: 390px; height: 390px; left: calc(50% - 195px); top: 34px; }
  .orbit-two { width: 310px; height: 310px; left: calc(50% - 155px); top: 74px; }
  .report-card { width: 224px; height: 315px; left: calc(50% - 90px); top: 52px; padding: 20px; }
  .report-monogram { margin-top: 36px; font-size: 50px; }
  .report-card h2 { font-size: 22px; }
  .report-seal { width: 48px; right: 18px; bottom: 24px; font-size: 8px; }
  .passport-card { width: 130px; height: 185px; left: calc(50% - 173px); top: 213px; padding: 18px 10px; }
  .bauhinia { width: 64px; margin-top: 28px; font-size: 31px; }
  .radar-card { width: 224px; right: calc(50% - 188px); bottom: 0; grid-template-columns: 1fr 102px; padding: 14px; }
  .radar-card strong { font-size: 11px; }
  .feature-grid, .path-grid, .official-links { grid-template-columns: 1fr; }
  .path-card { min-height: 230px; }
  .path-card p { min-height: auto; }
  .assessment-intro { padding: 30px 24px; border-radius: 22px; }
  .assessment-intro ul { grid-template-columns: 1fr; }
  .quiz-card { padding: 28px 18px 22px; border-radius: 22px; }
  .choice-grid-2, .choice-grid-3, .choice-grid-4 { grid-template-columns: 1fr; }
  .choice { min-height: 58px; }
  .result-hero { padding: 32px 24px; flex-direction: column; align-items: flex-start; }
  .result-hero h2 { font-size: 31px; }
  .result-gauge { width: 128px; }
  .result-body { padding: 30px 18px; }
  .rank-card { grid-template-columns: 44px minmax(0, 1fr); }
  .rank-score { grid-column: 2; text-align: left; display: flex; align-items: center; gap: 8px; }
  .rank-score small { display: inline; }
  .finding-grid { grid-template-columns: 1fr; }
  .consult-card { display: block; padding: 24px 20px; }
  .consult-card .qr-frame { width: 190px; }
  .result-footer-actions { padding: 0 18px 18px; flex-direction: column; }
  .result-footer-actions .btn { width: 100%; }
  .legal-disclaimer { padding: 18px 18px 26px; }
  .footer-grid { flex-direction: column; align-items: flex-start; }
  .floating-contact { right: 12px; bottom: calc(12px + env(safe-area-inset-bottom)); }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}

@media print {
  .site-header, .hero, .framework, .pathways, .assessment-intro, .quiz-card, .official-section, .site-footer, .floating-contact, .result-footer-actions, .consult-card .btn { display: none !important; }
  body, .assessment-section { background: #fff !important; }
  .section { padding: 0; }
  .container, .assessment-shell { width: 100%; display: block; }
  .results { display: block !important; box-shadow: none; border-radius: 0; }
  .result-body { grid-template-columns: 1fr 260px; }
  .consult-card { position: static; box-shadow: none; }
}
