*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#170f13;--card:#24161d;--gold:#d8b36a;--gold-dim:#9b7441;
  --red:#9f2e3a;--red-dim:#6f1e29;--text:#f4e7d6;--text-dim:#b7a694;
  --border:#3a2730;--shadow:0 8px 32px rgba(0,0,0,.45);
}
html{font-size:16px;scroll-behavior:smooth}
body{
  font-family:-apple-system,"PingFang SC","Noto Serif SC","Source Han Serif SC",
  "Noto Sans SC","Microsoft YaHei",serif;
  background:var(--bg);color:var(--text);min-height:100vh;
  line-height:1.7;overflow-x:hidden;
  position:relative;
}
body::before,
body::after{
  content:"";position:fixed;inset:auto;pointer-events:none;z-index:-1;filter:blur(12px);
}
body::before{
  width:38rem;height:38rem;top:-10rem;left:-9rem;
  background:radial-gradient(circle,rgba(159,46,58,.34) 0,rgba(159,46,58,0) 68%);
}
body::after{
  width:34rem;height:34rem;right:-8rem;bottom:-10rem;
  background:radial-gradient(circle,rgba(216,179,106,.18) 0,rgba(216,179,106,0) 68%);
}
.screen{display:none;min-height:100vh;flex-direction:column;align-items:center;width:100%}
.screen.active{display:flex}
a{color:var(--gold);text-decoration:none}

/* ===== LANDING ===== */
#landing{justify-content:center;text-align:center;padding:2rem 1rem 3rem}
.landing-panel,
.quiz-shell,
.result-card{
  position:relative;
}
.landing-panel{
  width:100%;max-width:760px;margin:0 auto;padding:2.6rem 1.4rem 2.1rem;
  background:
    linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.01)),
    linear-gradient(135deg,rgba(216,179,106,.1),rgba(159,46,58,.08));
  border:1px solid rgba(216,179,106,.22);border-radius:1.5rem;
  box-shadow:var(--shadow);overflow:hidden;
}
.landing-panel::before,
.quiz-shell::before,
.result-card::before{
  content:"";position:absolute;inset:12px;border:1px solid rgba(216,179,106,.12);
  border-radius:1.1rem;pointer-events:none;
}
.landing-badge{
  display:inline-block;padding:.3rem 1rem;border:1px solid var(--gold-dim);
  border-radius:2rem;font-size:.8rem;color:var(--gold);margin-bottom:1.5rem;
  letter-spacing:.15em;background:rgba(12,9,11,.3);
}
.landing-hook{
  color:#f0d9a8;font-size:.86rem;letter-spacing:.08em;margin:0 auto .8rem;max-width:560px;
}
.landing-title{
  font-size:clamp(2.4rem,7vw,4.2rem);font-weight:900;
  background:linear-gradient(135deg,var(--gold),#f0d080,var(--gold));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;line-height:1.2;margin-bottom:.5rem;
  text-shadow:0 12px 40px rgba(216,179,106,.16);
}
.landing-sub{
  font-size:clamp(1rem,3vw,1.4rem);color:var(--text-dim);margin-bottom:1.2rem;
  max-width:600px;margin-left:auto;margin-right:auto;
}
.landing-desc{
  font-size:.95rem;color:var(--text-dim);max-width:520px;
  margin:0 auto 2rem;line-height:1.95;
}
.landing-dims{
  display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;
  margin-bottom:1.4rem;
}
.dim-tag{
  padding:.42rem .95rem;background:rgba(212,167,75,.08);
  border:1px solid rgba(212,167,75,.2);border-radius:1rem;
  font-size:.82rem;color:var(--gold);
}
.landing-actions{
  display:flex;justify-content:center;gap:.8rem;flex-wrap:wrap;margin-bottom:1.35rem;
}
.btn-start{
  display:inline-block;padding:1rem 3rem;background:linear-gradient(135deg,var(--red),var(--red-dim));
  color:#fff;font-size:1.15rem;font-weight:700;border:none;border-radius:.6rem;
  cursor:pointer;transition:all .3s;letter-spacing:.1em;
}
.btn-start:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(196,30,58,.35)}
.btn-start:active{transform:translateY(0)}
.btn-secondary{
  padding:1rem 1.8rem;border:1px solid rgba(216,179,106,.28);border-radius:.6rem;
  background:rgba(255,255,255,.03);color:var(--text);cursor:pointer;
  transition:all .25s;font-size:1rem;
}
.btn-secondary:hover{background:rgba(216,179,106,.09);transform:translateY(-1px)}
.note-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem;
  max-width:680px;margin:0 auto 1.2rem;
}
.note-card{
  padding:1rem;background:rgba(17,11,15,.45);border:1px solid rgba(216,179,106,.12);
  border-radius:1rem;text-align:left;backdrop-filter:blur(6px);
}
.note-title{
  color:var(--gold);font-size:.82rem;font-weight:700;letter-spacing:.08em;margin-bottom:.45rem;
}
.note-text{
  color:var(--text-dim);font-size:.84rem;line-height:1.7;
}
.landing-meta{
  margin-top:.2rem;font-size:.78rem;color:var(--text-dim);opacity:.78;
}

/* ===== QUIZ ===== */
#quiz{padding:2rem 1rem 3rem;justify-content:flex-start}
.quiz-shell{
  width:100%;max-width:760px;padding:1.3rem;
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015));
  border:1px solid rgba(216,179,106,.18);border-radius:1.5rem;box-shadow:var(--shadow);
}
.progress-wrap{width:100%;max-width:640px;margin-bottom:2rem}
.progress-info{
  display:flex;justify-content:space-between;margin-bottom:.5rem;
  font-size:.85rem;color:var(--text-dim);
  align-items:flex-end;
}
.progress-copy{
  display:flex;flex-direction:column;align-items:flex-start;gap:.1rem;
}
.progress-kicker{
  font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-dim);
}
.progress-bar{
  width:100%;height:8px;background:rgba(255,255,255,.06);border-radius:999px;overflow:hidden;
}
.progress-fill{
  height:100%;background:linear-gradient(90deg,var(--gold),#f0d080);
  border-radius:999px;transition:width .4s ease;width:0;
}
.question-card{
  width:100%;max-width:640px;background:var(--card);
  border:1px solid var(--border);border-radius:1rem;
  padding:2rem;box-shadow:var(--shadow);animation:fadeUp .4s ease;
  background:
    linear-gradient(180deg,rgba(216,179,106,.05),rgba(216,179,106,0)),
    var(--card);
}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.q-number{font-size:.85rem;color:var(--gold);margin-bottom:1rem;font-weight:600}
.q-meta-row{
  display:flex;justify-content:space-between;gap:.8rem;flex-wrap:wrap;margin-bottom:.9rem;
}
.q-act,
.q-type{
  display:inline-flex;align-items:center;padding:.28rem .72rem;border-radius:999px;
  background:rgba(216,179,106,.08);border:1px solid rgba(216,179,106,.16);
  color:var(--gold);font-size:.74rem;letter-spacing:.06em;
}
.q-text{font-size:1.1rem;font-weight:600;margin-bottom:1.5rem;line-height:1.6}
.options{display:flex;flex-direction:column;gap:.7rem}
.opt-btn{
  display:block;width:100%;text-align:left;padding:1rem 1.2rem;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));border:1px solid var(--border);
  border-radius:.6rem;color:var(--text);font-size:.95rem;
  cursor:pointer;transition:all .25s;line-height:1.6;
}
.opt-btn:hover{
  background:rgba(212,167,75,.08);border-color:var(--gold-dim);transform:translateX(4px);
  box-shadow:0 14px 30px rgba(0,0,0,.16);
}
.opt-btn:active{transform:translateX(2px)}
.opt-btn.selected{
  background:rgba(212,167,75,.12);border-color:var(--gold);
  box-shadow:0 0 0 1px var(--gold);
}
.quiz-actions{
  display:flex;justify-content:space-between;gap:.8rem;margin-top:1.4rem;
}
.btn-nav{
  flex:1;padding:.85rem 1rem;border-radius:.6rem;border:1px solid var(--border);
  background:rgba(255,255,255,.04);color:var(--text);font-size:.92rem;
  cursor:pointer;transition:all .2s;
}
.btn-nav:hover:not(:disabled){background:rgba(255,255,255,.08)}
.btn-nav.primary{
  background:linear-gradient(135deg,var(--red),var(--red-dim));
  border-color:rgba(196,30,58,.45);color:#fff;font-weight:700;
}
.btn-nav.primary:hover:not(:disabled){
  box-shadow:0 8px 24px rgba(196,30,58,.28);transform:translateY(-1px);
}
.btn-nav:disabled{
  opacity:.42;cursor:not-allowed;box-shadow:none;transform:none;
}
.selection-hint{
  margin-top:.9rem;font-size:.78rem;color:var(--text-dim);text-align:center;
}
.quiz-shortcut{
  margin-top:1rem;font-size:.78rem;color:var(--text-dim);text-align:center;opacity:.76;
}

/* ===== RESULT ===== */
#result{padding:2rem 1rem;justify-content:flex-start}
.result-shell{
  width:100%;max-width:760px;
}
.result-card{
  width:100%;max-width:640px;background:var(--card);
  border:1px solid var(--border);border-radius:1.25rem;
  padding:2.5rem 2rem;box-shadow:var(--shadow);text-align:center;
  animation:fadeUp .6s ease;
  margin:0 auto;
  background:
    radial-gradient(circle at top,rgba(216,179,106,.12),rgba(216,179,106,0) 34%),
    linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,.015)),
    var(--card);
}
.char-avatar{
  width:96px;height:96px;border-radius:50%;
  background:linear-gradient(135deg,rgba(212,167,75,.15),rgba(212,167,75,.05));
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 1.2rem;overflow:hidden;
  border:3px solid var(--gold);box-shadow:0 0 24px rgba(212,167,75,.2);
  position:relative;
}
.char-avatar img,
.char-avatar canvas{
  width:100%;height:100%;display:block;
}
.char-avatar img{
  object-fit:cover;object-position:center 18%;
  transform:scale(1.02);
}
.char-avatar canvas{image-rendering:pixelated}
.result-hero{
  display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:center;text-align:left;margin-bottom:1rem;
}
.hero-copy{
  display:flex;flex-direction:column;gap:.35rem;
}
.result-kicker{
  font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-dim);
}
.char-name{
  font-size:1.8rem;font-weight:900;
  background:linear-gradient(135deg,var(--gold),#f0d080);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.char-title{font-size:1rem;color:var(--text-dim);margin:.3rem 0 1rem}
.result-motto{
  color:var(--text);font-size:.96rem;line-height:1.8;margin-bottom:.2rem;
}
.result-chip-row{
  display:flex;justify-content:center;gap:.55rem;flex-wrap:wrap;margin-bottom:1rem;
}
.result-chip{
  display:inline-flex;align-items:center;gap:.25rem;padding:.45rem .9rem;
  border-radius:999px;background:rgba(216,179,106,.08);border:1px solid rgba(216,179,106,.22);
  color:var(--gold);font-size:.82rem;
}
.result-chip.subtle{
  color:var(--text-dim);border-color:rgba(255,255,255,.08);background:rgba(255,255,255,.03);
}
.poster-card{
  padding:1.1rem 1rem 1rem;border-radius:1rem;margin-bottom:1.2rem;text-align:left;
  border:1px solid rgba(216,179,106,.24);
  background:
    linear-gradient(135deg,rgba(216,179,106,.12),rgba(159,46,58,.16)),
    rgba(255,255,255,.02);
}
.poster-kicker{
  font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#f0d9a8;margin-bottom:.4rem;
}
.poster-title{
  font-size:1.3rem;font-weight:800;color:#fff;margin-bottom:.35rem;
}
.poster-sub{
  color:var(--text-dim);font-size:.85rem;line-height:1.7;
}
.poster-grid{
  display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.65rem;margin-top:1rem;
}
.poster-stat{
  padding:.7rem .75rem;border-radius:.85rem;background:rgba(14,10,13,.34);border:1px solid rgba(255,255,255,.06);
}
.poster-stat-label{
  font-size:.68rem;color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.25rem;
}
.poster-stat-value{
  color:#fff;font-size:.92rem;font-weight:700;line-height:1.35;
}
.tag-row{
  display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-bottom:1.4rem;
}
.tag-chip{
  padding:.3rem .75rem;border-radius:999px;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);font-size:.76rem;color:var(--text-dim);
}
.match-pct{
  display:inline-block;padding:.4rem 1.2rem;
  background:rgba(212,167,75,.1);border:1px solid var(--gold-dim);
  border-radius:2rem;font-size:.9rem;color:var(--gold);margin-bottom:1.5rem;
}
.char-desc{
  font-size:.92rem;color:var(--text);line-height:1.9;
  text-align:left;margin-bottom:2rem;padding:0 .5rem;
}
.char-desc b{color:var(--gold);font-weight:600;display:inline-block;margin-top:.6rem}
.result-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem;margin-bottom:1.7rem;
}
.result-panel{
  padding:1rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);
  border-radius:1rem;text-align:left;
}
.compare-grid{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem;margin-bottom:1.6rem;
}
.compare-card{
  padding:1rem;border-radius:.95rem;text-align:left;background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
}
.compare-label{
  font-size:.72rem;color:var(--gold-dim);letter-spacing:.08em;text-transform:uppercase;margin-bottom:.35rem;
}
.compare-name{
  font-size:.95rem;font-weight:700;margin-bottom:.22rem;color:#fff;
}
.compare-note{
  color:var(--text-dim);font-size:.79rem;line-height:1.6;
}
.why-list{
  display:grid;grid-template-columns:1fr;gap:.7rem;margin-bottom:1.5rem;
}
.why-item{
  padding:.95rem 1rem;border-radius:.85rem;background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07);text-align:left;
}
.why-item strong{
  color:var(--gold);display:block;margin-bottom:.22rem;font-size:.82rem;letter-spacing:.06em;
}
.panel-text{
  color:var(--text-dim);font-size:.84rem;line-height:1.75;
}
.radar-wrap{margin:0 auto 2rem;max-width:320px}
.radar-wrap canvas{width:100%;height:auto}
.section-title{
  font-size:.85rem;color:var(--gold);font-weight:600;
  margin-bottom:.8rem;letter-spacing:.1em;
}
.secondary-match{
  background:rgba(255,255,255,.03);border:1px solid var(--border);
  border-radius:.8rem;padding:1rem;margin-bottom:1.5rem;text-align:left;
}
.secondary-match .sec-name{font-weight:700;color:var(--gold);font-size:.95rem}
.secondary-match .sec-pct{font-size:.82rem;color:var(--text-dim)}
.partner-rival{
  display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-bottom:2rem;
}
.pr-card{
  background:rgba(255,255,255,.03);border:1px solid var(--border);
  border-radius:.8rem;padding:1rem;text-align:left;
}
.pr-card.partner{border-color:rgba(76,175,80,.3)}
.pr-card.rival{border-color:rgba(244,67,54,.3)}
.pr-label{font-size:.78rem;font-weight:600;margin-bottom:.4rem}
.pr-card.partner .pr-label{color:#66bb6a}
.pr-card.rival .pr-label{color:#ef5350}
.pr-name{font-weight:700;font-size:.95rem;margin-bottom:.3rem}
.pr-reason{font-size:.8rem;color:var(--text-dim);line-height:1.5}
.share-copy{
  margin:0 auto 1.5rem;padding:1rem 1.1rem;border-radius:.95rem;text-align:left;
  background:rgba(255,255,255,.03);border:1px dashed rgba(216,179,106,.35);
}
.share-copy-label{
  font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-dim);margin-bottom:.45rem;
}
.share-copy-text{
  color:var(--text);font-size:.86rem;line-height:1.8;white-space:pre-line;
}
.feedback-row{
  display:flex;justify-content:center;gap:.6rem;flex-wrap:wrap;margin:0 0 1.4rem;
}
.feedback-btn{
  padding:.5rem 1rem;border-radius:999px;border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.03);color:var(--text-dim);font-size:.82rem;cursor:pointer;
  transition:all .2s;
}
.feedback-btn:hover{border-color:rgba(216,179,106,.3);color:var(--text)}
.btn-group{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;margin-top:.5rem}
.btn-share{
  padding:.75rem 1.8rem;background:rgba(212,167,75,.15);
  border:1px solid var(--gold-dim);color:var(--gold);
  border-radius:.5rem;cursor:pointer;font-size:.9rem;transition:all .2s;
}
.btn-share:hover{background:rgba(212,167,75,.25)}
.btn-poster{
  padding:.75rem 1.8rem;background:linear-gradient(135deg,var(--red),var(--red-dim));
  border:1px solid rgba(196,30,58,.42);color:#fff;border-radius:.5rem;cursor:pointer;font-size:.9rem;transition:all .2s;
}
.btn-poster:hover{box-shadow:0 8px 24px rgba(196,30,58,.24);transform:translateY(-1px)}
.btn-retry{
  padding:.75rem 1.8rem;background:rgba(255,255,255,.05);
  border:1px solid var(--border);color:var(--text-dim);
  border-radius:.5rem;cursor:pointer;font-size:.9rem;transition:all .2s;
}
.btn-retry:hover{background:rgba(255,255,255,.1)}
.toast{
  position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(80px);
  background:var(--gold);color:#000;padding:.7rem 1.5rem;border-radius:.5rem;
  font-size:.9rem;font-weight:600;opacity:0;transition:all .4s;z-index:999;
}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}

/* ===== FOOTER ===== */
.site-footer{
  width:100%;max-width:760px;margin-top:2rem;padding:1.25rem 1.2rem 0;
  border-top:1px solid var(--border);text-align:center;
}
.compact-footer{
  margin-left:auto;margin-right:auto;
}
.footer-title{font-size:.82rem;color:var(--gold-dim);font-weight:600;margin-bottom:.8rem}
.footer-text{font-size:.75rem;color:var(--text-dim);line-height:1.8;opacity:.7}
.footer-text p{margin-bottom:.4rem}
.footer-badges{
  display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-top:1rem;
}
.footer-badge{
  padding:.2rem .7rem;border:1px solid var(--border);border-radius:1rem;
  font-size:.7rem;color:var(--text-dim);
}
.creator-section{margin-top:1.5rem;padding-top:1.2rem;border-top:1px solid var(--border)}
.creator-info{font-size:.82rem;color:var(--text-dim);margin-bottom:.8rem}
.creator-info strong{color:var(--gold);font-weight:600}
.qrcode-wrap{display:none;margin:.8rem auto 0;width:120px}
.qrcode-wrap img{width:100%;height:auto;border-radius:.5rem;opacity:.85}
.qrcode-label{font-size:.7rem;color:var(--text-dim);margin-top:.4rem;opacity:.6}

/* ===== RESPONSIVE ===== */
@media(max-width:760px){
  .note-grid,
  .result-grid,
  .poster-grid,
  .compare-grid{
    grid-template-columns:1fr;
  }
  .landing-panel,
  .quiz-shell{
    padding:1.3rem 1rem 1.4rem;
  }
}
@media(max-width:480px){
  .question-card,.result-card{padding:1.5rem 1.2rem}
  .partner-rival{grid-template-columns:1fr}
  .char-desc{padding:0}
  .landing-actions{flex-direction:column}
  .btn-start,.btn-secondary{width:100%}
  .result-hero{grid-template-columns:1fr;text-align:center}
  .hero-copy{align-items:center}
  .quiz-shell{padding:1rem .9rem}
  .q-meta-row{justify-content:center}
}
