/* ==========================================================================
   支配·臣服人格测试 · 视觉语言 = The Pudding 编辑型数据叙事（沿用 MBTI 家族）
   暖纸底 + 朱红强调 + Fraunces 衬线 × Space Mono 等宽，扁平实色，无渐变
   结果页核心：单条「支配 ←→ 臣服」光谱 + 定位标记
   ========================================================================== */
:root{
  --paper:#f4efe6;        /* 暖纸张底 */
  --ink:#1a1714;          /* 墨色 */
  --ink-soft:#6b6258;     /* 次级文字 */
  --rule:#cdc3b3;         /* 发丝线 */
  --vermilion:#e8503a;    /* 朱红：支配极 */
  --vermilion-deep:#c33b27;
  --blue:#2b4a6f;         /* 墨蓝：臣服极 */
  --gold:#c98a1e;         /* 芥末金：双向/中性 */
  --gold-deep:#a8740f;
  --teal:#3f7a6d;         /* 墨绿：同意端 */
  --track:#e3dccd;        /* 数据条底槽 */
  --acc:var(--vermilion); /* 结果强调色，按类型在 .result 上切换 */
  --acc-deep:var(--vermilion-deep);
}

*{ box-sizing:border-box; margin:0; padding:0; -webkit-tap-highlight-color:transparent; }
html,body{ height:100%; }

body{
  background:var(--paper);
  color:var(--ink);
  font-family:"Noto Serif SC", serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

#app{
  max-width:460px;
  margin:0 auto;
  min-height:100dvh;
  position:relative;
  box-shadow:0 0 0 1px rgba(26,23,20,.06);
}

/* ---------- 屏幕切换 ---------- */
.screen{ display:none; min-height:100dvh; flex-direction:column; }
.screen.active{ display:flex; animation:fade .45s ease; }
@keyframes fade{ from{ opacity:0; transform:translateY(6px); } to{ opacity:1; transform:none; } }

.scribble{ display:inline-block; position:relative; }
.scribble::after{
  content:""; position:absolute; left:-2%; right:-2%; bottom:-.06em; height:.34em;
  background:var(--vermilion); opacity:.85; z-index:-1;
  border-radius:60% 40% 55% 45% / 60% 55% 45% 40%; transform:rotate(-.6deg);
}

/* ============================================================
   屏 1 · 首页
   ============================================================ */
.home{
  flex:1; display:flex; flex-direction:column;
  padding:calc(env(safe-area-inset-top) + 22px) 30px calc(env(safe-area-inset-bottom) + 26px);
}
.home__brand{
  display:flex; align-items:center; justify-content:space-between;
  padding-bottom:14px; border-bottom:1.5px solid var(--ink);
}
.home__brand-mark{ font-family:"Space Mono",monospace; font-weight:700; font-size:13px; letter-spacing:.06em; }
.home__brand-mark b{ color:var(--vermilion-deep); }
.home__issue{ font-family:"Space Mono",monospace; font-size:11px; color:var(--ink-soft); letter-spacing:.05em; }

.home__hero{ flex:1; display:flex; flex-direction:column; justify-content:center; padding:8px 0; }
.home__kicker{
  margin:0 0 22px; font-family:"Space Mono",monospace; font-size:11px;
  letter-spacing:.2em; text-transform:uppercase; color:var(--ink-soft);
  display:flex; align-items:center; gap:10px;
}
.home__kicker::before{ content:""; width:34px; height:1.5px; background:var(--ink); }
.home__h1{
  font-family:"Noto Serif SC",serif; font-weight:700; font-size:clamp(44px,13vw,56px);
  line-height:1.08; letter-spacing:-.01em; margin:0 0 26px; text-wrap:pretty;
}
.home__h1 .ln2{ display:block; }
.home__sub{
  font-family:"Noto Serif SC",serif; font-weight:400; font-size:17px; line-height:1.7;
  color:var(--ink-soft); margin:0; max-width:300px; text-wrap:pretty;
}
.home__sub em{ font-style:normal; color:var(--ink); font-weight:500; box-shadow:inset 0 -10px 0 rgba(232,80,58,.18); }

.home__preview{ margin:34px 0 0; }
.home__preview-label{
  font-family:"Space Mono",monospace; font-size:10px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--ink-soft); margin-bottom:10px;
}

.home__cta-wrap{ margin-top:34px; }
.btn-primary{
  width:100%; border:none; background:var(--vermilion); color:#fff;
  font-family:"Noto Serif SC",serif; font-weight:600; font-size:18px; letter-spacing:.04em;
  padding:18px 24px; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:12px;
  box-shadow:4px 4px 0 var(--ink); transition:transform .08s, box-shadow .08s;
}
.btn-primary:hover{ transform:translate(2px,2px); box-shadow:2px 2px 0 var(--ink); }
.btn-primary:active{ transform:translate(4px,4px); box-shadow:0 0 0 var(--ink); }
.btn-primary svg{ display:block; }
.home__foot{
  margin-top:18px; text-align:center; font-family:"Space Mono",monospace;
  font-size:11px; letter-spacing:.04em; color:var(--ink-soft);
}
.home__foot span{ white-space:nowrap; }
.home__foot .dot{ color:var(--vermilion); margin:0 6px; }

/* ============================================================
   支配 ←→ 臣服 光谱（首页预告 & 结果页核心）
   ============================================================ */
.spectrum{ width:100%; }
.spectrum__poles{
  display:flex; justify-content:space-between; margin-bottom:9px;
  font-family:"Space Mono",monospace; font-size:12px; font-weight:700; letter-spacing:.04em;
}
.spectrum__poles .dom{ color:var(--vermilion-deep); }
.spectrum__poles .sub{ color:var(--blue); }
.spectrum__track{
  position:relative; height:14px; border-radius:7px;
  background:linear-gradient(90deg, var(--vermilion) 0%, #e9e1d2 50%, var(--blue) 100%);
}
.spectrum__center{
  position:absolute; left:50%; top:-5px; bottom:-5px; width:1.5px;
  background:var(--ink-soft); transform:translateX(-50%); opacity:.5;
}
.spectrum__marker{
  position:absolute; top:50%; width:20px; height:20px; border-radius:50%;
  background:var(--paper); border:3px solid var(--ink);
  transform:translate(-50%,-50%); box-shadow:2px 2px 0 rgba(26,23,20,.25);
}
.spectrum__read{
  margin-top:11px; font-family:"Space Mono",monospace; font-size:11px;
  letter-spacing:.04em; color:var(--ink-soft);
}
.spectrum--preview .spectrum__track{ height:12px; }

/* ============================================================
   屏 2 · 答题页
   ============================================================ */
.quiz{
  flex:1; display:flex; flex-direction:column;
  padding:calc(env(safe-area-inset-top) + 18px) 30px calc(env(safe-area-inset-bottom) + 34px);
}
.quiz__back{
  align-self:flex-start; border:none; background:none; cursor:pointer;
  font-family:"Space Mono",monospace; font-size:12px; letter-spacing:.04em;
  color:var(--ink-soft); padding:2px 0; margin-bottom:12px; transition:color .15s, opacity .15s;
}
.quiz__back:hover{ color:var(--vermilion-deep); }
.quiz__back[disabled]{ opacity:0; pointer-events:none; }

.quiz__top{ flex:0 0 auto; }
.quiz__progress-row{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:11px; }
.quiz__count{ font-family:"Space Mono",monospace; font-size:13px; font-weight:700; letter-spacing:.04em; }
.quiz__count .cur{ color:var(--vermilion-deep); font-size:20px; }
.quiz__count .tot{ color:var(--ink-soft); }
.quiz__pct{ font-family:"Space Mono",monospace; font-size:11px; letter-spacing:.1em; color:var(--ink-soft); text-transform:uppercase; }
.quiz__bar{ height:6px; background:#e0d8c9; position:relative; overflow:hidden; }
.quiz__bar-fill{ position:absolute; inset:0 auto 0 0; width:0; background:var(--ink); transition:width .35s ease; }
.quiz__bar-fill::after{ content:""; position:absolute; right:0; top:0; bottom:0; width:3px; background:var(--vermilion); }
.quiz__ticks{
  display:flex; justify-content:space-between; margin-top:7px;
  font-family:"Space Mono",monospace; font-size:9px; letter-spacing:.05em; color:#a89e8e;
}

.quiz__mid{ flex:1; display:flex; flex-direction:column; justify-content:center; padding:10px 0; }
/* SOP 阶段引导 */
.quiz__stage{ margin-bottom:14px; display:flex; flex-direction:column; gap:3px; }
.quiz__stage-no{ font-family:"Space Mono",monospace; font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--vermilion-deep); }
.quiz__stage-name{ font-family:"Noto Serif SC",serif; font-weight:600; font-size:15px; color:var(--ink); }
.quiz__stage-lead{ font-family:"Fraunces",serif; font-style:italic; font-size:13px; line-height:1.5; color:var(--ink-soft); margin-top:2px; text-wrap:pretty; }
.quiz__q-index{
  font-family:"Fraunces",serif; font-style:italic; font-weight:400; font-size:46px;
  color:var(--rule); line-height:1; margin-bottom:18px;
}
.quiz__q-index b{ color:var(--vermilion); font-style:normal; font-weight:600; }
.quiz__question{
  font-family:"Fraunces",serif; font-weight:500; font-size:clamp(26px,7vw,30px);
  line-height:1.32; letter-spacing:-.01em; margin:0; text-wrap:pretty;
}
.quiz__question.swap{ animation:qswap .35s ease; }
@keyframes qswap{ from{ opacity:0; transform:translateX(16px); } to{ opacity:1; transform:none; } }
.quiz__hint{
  margin-top:18px; font-family:"Space Mono",monospace; font-size:11px; letter-spacing:.06em;
  color:var(--ink-soft); display:flex; align-items:center; gap:8px;
}
.quiz__hint::before{ content:""; width:18px; height:1.5px; background:var(--rule); }

/* 7 级量表 */
.scale{ flex:0 0 auto; }
.scale__labels{
  display:flex; justify-content:space-between; margin-bottom:18px;
  font-family:"Noto Serif SC",serif; font-size:15px; font-weight:500;
}
.scale__labels .agree{ color:var(--teal); }
.scale__labels .disagree{ color:var(--blue); text-align:right; }
.scale__labels small{
  display:block; font-family:"Space Mono",monospace; font-size:9px; letter-spacing:.12em;
  text-transform:uppercase; font-weight:400; color:#a89e8e; margin-top:2px;
}
.scale__dots{ display:flex; align-items:center; justify-content:space-between; position:relative; padding:0 2px; }
.scale__line{ position:absolute; left:18px; right:18px; top:50%; height:1.5px; background:var(--rule); transform:translateY(-50%); z-index:0; }
.dot{
  position:relative; z-index:1; border-radius:50%; background:var(--paper);
  cursor:pointer; transition:transform .12s; flex:none;
}
.dot:hover{ transform:scale(1.08); }
.dot:active{ transform:scale(.92); }
.dot.s1,.dot.s7{ width:52px; height:52px; }
.dot.s2,.dot.s6{ width:42px; height:42px; }
.dot.s3,.dot.s5{ width:32px; height:32px; }
.dot.s4{ width:24px; height:24px; }
.dot.s1{ border:2.5px solid var(--teal); }
.dot.s2{ border:2.5px solid #8fa39c; }
.dot.s3{ border:2px solid #b7b0a3; }
.dot.s4{ border:2px solid #c3bcae; }
.dot.s5{ border:2px solid #a8aab4; }
.dot.s6{ border:2.5px solid #7d8aa0; }
.dot.s7{ border:2.5px solid var(--blue); }

.dot.is-selected{ box-shadow:0 0 0 5px rgba(26,23,20,.08), 3px 3px 0 var(--ink); }
.dot.is-selected.agree{ background:var(--teal); border-color:var(--teal); }
.dot.is-selected.neutral{ background:var(--ink-soft); border-color:var(--ink-soft); }
.dot.is-selected.disagree{ background:var(--blue); border-color:var(--blue); }
.dot.is-selected::after{
  content:""; position:absolute; inset:0; margin:auto; width:13px; height:9px;
  border-left:2.6px solid #fff; border-bottom:2.6px solid #fff;
  transform:translateY(-1px) rotate(-45deg);
}
.dot.is-selected.s3::after,.dot.is-selected.s4::after,.dot.is-selected.s5::after{
  width:10px; height:7px; border-width:2.2px;
}

@media (max-width:380px){
  .dot.s1,.dot.s7{ width:46px; height:46px; }
  .dot.s2,.dot.s6{ width:38px; height:38px; }
  .dot.s3,.dot.s5{ width:29px; height:29px; }
  .dot.s4{ width:22px; height:22px; }
  .home,.quiz{ padding-left:24px; padding-right:24px; }
}

/* ============================================================
   屏 3 · 结果页
   ============================================================ */
.result{
  flex:1; display:flex; flex-direction:column;
  padding:calc(env(safe-area-inset-top) + 20px) 30px calc(env(safe-area-inset-bottom) + 26px);
}
/* 结果强调色按类型切换 */
.result.acc-dom{ --acc:var(--vermilion); --acc-deep:var(--vermilion-deep); }
.result.acc-sub{ --acc:var(--blue); --acc-deep:var(--blue); }
.result.acc-mix{ --acc:var(--gold); --acc-deep:var(--gold-deep); }
.result.acc-teal{ --acc:var(--teal); --acc-deep:#2f5d52; }

.result__eyebrow{
  font-family:"Space Mono",monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-soft); margin:0 0 6px; display:flex; justify-content:space-between;
}
.result__type{
  font-family:"Noto Serif SC",serif; font-weight:700; font-size:clamp(40px,12vw,54px);
  letter-spacing:.01em; line-height:1.04; margin:4px 0 6px; color:var(--acc-deep);
}
.result__tagline{
  font-family:"Fraunces",serif; font-style:italic; font-weight:400; font-size:16px; line-height:1.5;
  color:var(--ink-soft); margin:0 0 16px; padding-left:14px; border-left:2.5px solid var(--acc); text-wrap:pretty;
}
.result__divider{ height:1.5px; background:var(--ink); margin:2px 0 18px; }

/* 结果页光谱 */
.result .spectrum{ margin-bottom:20px; }
.result .spectrum__marker{ border-color:var(--acc-deep); }

/* 解读 */
.result__read{
  font-family:"Noto Serif SC",serif; font-size:14.5px; line-height:1.72; color:var(--ink);
  margin:0 0 16px; padding-top:2px; text-wrap:pretty;
}

/* 特质 / 契合提醒 两栏 */
.traits{ display:grid; grid-template-columns:1fr 1fr; border:1.5px solid var(--ink); margin-bottom:18px; }
.traits__col{ padding:12px 13px; }
.traits__col + .traits__col{ border-left:1.5px solid var(--ink); }
.traits__title{
  font-family:"Space Mono",monospace; font-size:10px; letter-spacing:.12em; text-transform:uppercase;
  margin:0 0 9px; display:flex; align-items:center; gap:6px;
}
.traits__title.plus{ color:var(--acc-deep); }
.traits__title.minus{ color:var(--ink-soft); }
.traits__title .sym{ font-family:"Fraunces",serif; font-weight:700; font-size:15px; }
.traits__list{ margin:0; padding:0; list-style:none; }
.traits__list li{
  font-family:"Noto Serif SC",serif; font-size:13.5px; line-height:1.45; color:var(--ink);
  padding:5px 0 5px 14px; position:relative; text-wrap:pretty;
}
.traits__list li::before{ content:""; position:absolute; left:0; top:.78em; width:5px; height:5px; }
.traits__col.plus-col li::before{ background:var(--acc); }
.traits__col.minus-col li::before{ background:var(--ink-soft); transform:rotate(45deg); }

.result__actions{ margin-top:auto; display:flex; gap:12px; padding-top:8px; }
.btn-ghost,.btn-solid{
  flex:1; font-family:"Noto Serif SC",serif; font-weight:600; font-size:15px; padding:14px 10px;
  cursor:pointer; text-align:center; border:1.5px solid var(--ink); background:transparent; color:var(--ink);
  transition:transform .08s, box-shadow .08s, background .15s, color .15s;
}
.btn-solid{ background:var(--ink); color:var(--paper); box-shadow:3px 3px 0 var(--acc); }
.btn-ghost:hover{ background:var(--ink); color:var(--paper); }
.btn-solid:hover{ transform:translate(1.5px,1.5px); box-shadow:1.5px 1.5px 0 var(--acc); }

.result__foot{
  margin-top:16px; text-align:center; font-family:"Space Mono",monospace;
  font-size:10px; line-height:1.6; letter-spacing:.03em; color:#a89e8e; text-transform:none;
}

/* ============================================================
   桌面端专属布局（≥900px）
   ============================================================ */
@media (min-width:900px){
  #app{ max-width:1080px; }

  .home{ padding:52px 72px 44px; }
  .home__hero{
    display:grid; grid-template-columns:1.05fr .95fr; gap:64px; align-items:center; padding:20px 0;
  }
  .home__lede{ display:flex; flex-direction:column; }
  .home__kicker{ margin-bottom:26px; }
  .home__h1{ font-size:clamp(58px,6vw,82px); margin-bottom:30px; }
  .home__sub{ font-size:19px; max-width:380px; }
  .home__preview{
    margin:0; align-self:center; width:100%;
    border-left:1.5px solid var(--rule); padding-left:32px;
  }
  .home__preview-label{ font-size:11px; margin-bottom:12px; }
  .home__cta-wrap{ margin-top:38px; max-width:380px; margin-right:auto; }
  .home__foot{ text-align:left; }

  .quiz{ max-width:760px; margin:0 auto; width:100%; padding:36px 0 56px; }
  .quiz__question{ font-size:clamp(32px,3.2vw,40px); }
  .quiz__q-index{ font-size:58px; }
  .quiz__hint{ font-size:12px; }
  .scale__labels{ font-size:17px; max-width:560px; margin:0 auto 18px; width:100%; }
  .scale__dots{ max-width:560px; margin:0 auto; }
  .scale__line{ left:24px; right:24px; }
  .dot.s1,.dot.s7{ width:60px; height:60px; }
  .dot.s2,.dot.s6{ width:48px; height:48px; }
  .dot.s3,.dot.s5{ width:38px; height:38px; }
  .dot.s4{ width:28px; height:28px; }

  .result{ padding:48px 72px 40px; max-width:980px; margin:0 auto; width:100%; }
  .result__type{ font-size:clamp(48px,5vw,64px); }
  .result__tagline{ font-size:18px; max-width:680px; }
  .quad__box{ max-width:300px; margin-left:0; }
  .combo{ margin-top:28px; }
  .result__grid{ display:grid; grid-template-columns:1.25fr 1fr; gap:46px; align-items:start; }
  .result__main{ display:flex; flex-direction:column; }
  .traits{ margin-bottom:0; }
  .result__read{ margin-bottom:0; margin-top:18px; font-size:15px; }
  .result__actions{ max-width:440px; margin-top:36px; }
}

/* ============================================================
   v2 新组件：双轴象限图 · 强度条 · MBTI 合体解读 · 补选器
   ============================================================ */
/* 首页预告里的双轴条 */
.home__preview-note{ margin-top:12px; font-family:"Space Mono",monospace; font-size:11px; letter-spacing:.02em; color:var(--ink-soft); }

/* 两条强度条 */
.axisbars{ display:flex; flex-direction:column; gap:13px; }
.axisbars--preview{ gap:11px; }
.axisbar__head{ display:flex; justify-content:space-between; align-items:baseline; font-family:"Space Mono",monospace; font-size:11px; letter-spacing:.04em; color:var(--ink-soft); margin-bottom:5px; }
.axisbar__head b{ font-weight:700; }
.axisbar__track{ height:12px; background:var(--track); position:relative; }
.axisbar__fill{ position:absolute; left:0; top:0; bottom:0; }
.axisbar--d .axisbar__fill{ background:var(--vermilion); } .axisbar--d .axisbar__head b{ color:var(--vermilion-deep); }
.axisbar--s .axisbar__fill{ background:var(--blue); }      .axisbar--s .axisbar__head b{ color:var(--blue); }
.axisbar--o .axisbar__fill{ background:var(--gold); }      .axisbar--o .axisbar__head b{ color:var(--gold-deep); }

/* 象限图 */
.quad{ margin-bottom:20px; }
.quad__box{
  position:relative; width:100%; max-width:280px; aspect-ratio:1/1;
  margin:0 auto 18px; border:1.5px solid var(--ink); background:rgba(26,23,20,.015);
}
.quad__axis-x,.quad__axis-y{ display:none; }
.quad__line{ position:absolute; background:var(--rule); }
.quad__line--v{ left:50%; top:0; bottom:0; width:1px; }
.quad__line--h{ top:50%; left:0; right:0; height:1px; }
.quad__q{
  position:absolute; font-family:"Space Mono",monospace; font-size:10px;
  letter-spacing:.08em; color:#a89e8e;
}
.quad__q--tl{ top:9px; left:10px; } .quad__q--tr{ top:9px; right:10px; }
.quad__q--bl{ bottom:9px; left:10px; } .quad__q--br{ bottom:9px; right:10px; }
.quad__dot{
  position:absolute; width:18px; height:18px; border-radius:50%;
  background:var(--acc); border:3px solid var(--paper);
  box-shadow:0 0 0 1.5px var(--acc-deep), 2px 2px 0 rgba(26,23,20,.22);
  transform:translate(-50%,50%);
}

/* MBTI × 支配臣服 合体解读 */
.combo{ border:1.5px solid var(--ink); padding:16px 16px 18px; margin:18px 0 4px; background:rgba(26,23,20,.022); }
.combo--locked{ background:none; border-style:dashed; }
.combo__eyebrow{ font-family:"Space Mono",monospace; font-size:10px; letter-spacing:.13em; text-transform:uppercase; color:var(--acc-deep); margin:0 0 9px; }
.combo__title{ font-family:"Noto Serif SC",serif; font-weight:700; font-size:19px; line-height:1.3; margin:0 0 11px; }
.combo__title b{ font-family:"Fraunces",serif; font-weight:600; letter-spacing:.02em; }
.combo__title span{ color:var(--acc); margin:0 5px; font-weight:400; }
.combo__para{ font-family:"Noto Serif SC",serif; font-size:14px; line-height:1.78; margin:0 0 13px; text-wrap:pretty; }
.combo__tags{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:8px; }
.combo__tags li{ font-family:"Space Mono",monospace; font-size:11px; letter-spacing:.01em; color:var(--acc-deep); border:1.2px solid var(--acc); padding:4px 9px; }
.combo__hint{ font-family:"Noto Serif SC",serif; font-size:13.5px; color:var(--ink-soft); margin:0 0 13px; }
.combo__pick{ display:flex; gap:10px; }
.combo__pick select{
  flex:1; min-width:0; font-family:"Noto Serif SC",serif; font-size:14px; padding:11px 12px;
  border:1.5px solid var(--ink); background:var(--paper); color:var(--ink); border-radius:0;
  -webkit-appearance:none; appearance:none; cursor:pointer;
}
.combo__pick .btn-solid{ flex:0 0 auto; width:auto; padding:11px 22px; }
.combo__link{ margin:13px 0 0; font-family:"Space Mono",monospace; font-size:11px; color:var(--ink-soft); }
.combo__link a{ color:var(--acc-deep); }

/* 性偏好亮点标签 */
.facets{ margin:18px 0 4px; }
.facets__title{ font-family:"Space Mono",monospace; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); margin:0 0 11px; display:flex; justify-content:space-between; align-items:baseline; gap:10px; }
.facets__title span{ font-size:9px; letter-spacing:.03em; color:#a89e8e; text-transform:none; flex:none; }
.facets__list{ list-style:none; margin:0; padding:0; display:flex; flex-wrap:wrap; gap:8px; }
.facets__list li{ font-family:"Noto Serif SC",serif; font-weight:500; font-size:13px; padding:5px 11px; border:1.3px solid; }
.facets__list li.is-d{ color:var(--vermilion-deep); border-color:var(--vermilion); }
.facets__list li.is-s{ color:var(--blue); border-color:var(--blue); }
.facets__none{ font-family:"Noto Serif SC",serif; font-size:13.5px; color:var(--ink-soft); margin:0; }
