:root {
  --primary: #6C5CE7;
  --primary-light: #A29BFE;
  --primary-dark: #5A4BD1;
  --bg: #F8F9FE;
  --card: #FFFFFF;
  --text: #2D3436;
  --text-light: #636E72;
  --text-muted: #B0B0C0;
  --border: #E8E8F0;
  --success: #00B894;
  --shadow: 0 4px 24px rgba(108,92,231,0.10);
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.06);
  --radius: 16px;
  --radius-sm: 10px;
}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Hiragino Sans GB','Microsoft YaHei',sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;}
.container{max-width:720px;margin:0 auto;padding:0 16px;}
.page-hidden{display:none!important;}

/* ======== 首页 ======== */
#page-home{min-height:100vh;display:flex;flex-direction:column;}
.hero{text-align:center;padding:48px 20px 32px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;border-radius:0 0 32px 32px;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;top:-60%;right:-30%;width:300px;height:300px;background:rgba(255,255,255,.08);border-radius:50%;}
.hero::after{content:'';position:absolute;bottom:-40%;left:-20%;width:250px;height:250px;background:rgba(255,255,255,.05);border-radius:50%;}
.hero h1{font-size:28px;font-weight:700;margin-bottom:8px;position:relative;z-index:1;}
.hero p{font-size:14px;opacity:.9;position:relative;z-index:1;max-width:400px;margin:0 auto;}
.hero-icon{font-size:48px;margin-bottom:12px;position:relative;z-index:1;}
.back-home{position:absolute;top:16px;left:16px;color:rgba(255,255,255,.85);text-decoration:none;font-size:14px;font-weight:500;z-index:10;padding:4px 12px;border-radius:20px;background:rgba(255,255,255,.15);backdrop-filter:blur(4px);transition:all .2s;}
.back-home:hover{background:rgba(255,255,255,.25);}
.intro-section{padding:24px 16px;}
.intro-card{background:var(--card);border-radius:var(--radius);padding:20px;margin-bottom:16px;box-shadow:var(--shadow-sm);border:1px solid var(--border);}
.intro-card h3{font-size:16px;color:var(--primary);margin-bottom:10px;display:flex;align-items:center;gap:8px;}
.intro-card h3 .icon{font-size:20px;}
.intro-card p,.intro-card li{font-size:13px;color:var(--text-light);line-height:1.8;}
.intro-card ul{padding-left:16px;}
.intro-card li{margin-bottom:4px;}
.dim-preview{display:flex;flex-direction:column;gap:8px;margin-top:12px;}
.dim-row{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;}
.dim-a{color:var(--primary);min-width:48px;text-align:right;}
.dim-b{color:#E74C3C;min-width:48px;}
.dim-bar-wrap{flex:1;height:8px;border-radius:4px;display:flex;overflow:hidden;}
.dim-bar-l{flex:1;background:linear-gradient(90deg,var(--primary-light),var(--primary));border-radius:4px 0 0 4px;}
.dim-bar-r{flex:1;background:linear-gradient(90deg,#FF6B6B,#E74C3C);border-radius:0 4px 4px 0;}
.quick-badge{display:inline-block;padding:4px 14px;border-radius:50px;font-size:11px;font-weight:700;color:#fff;background:linear-gradient(135deg,#FF6B6B,#FF8E53);margin-bottom:12px;}

/* ======== 恢复/报告提示 ======== */
.report-banner{margin:0 16px 12px;max-width:400px;margin-left:auto;margin-right:auto;background:var(--card);border:1px solid rgba(46,204,113,.2);border-radius:var(--radius);padding:16px;display:flex;align-items:center;justify-content:space-between;gap:12px;animation:fadeSlideIn .4s ease;box-shadow:var(--shadow-sm);}
.report-banner-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0;}
.resume-banner{margin:0 16px 12px;max-width:400px;margin-left:auto;margin-right:auto;background:var(--card);border:1px solid rgba(108,92,231,.2);border-radius:var(--radius);padding:16px;animation:fadeSlideIn .4s ease;box-shadow:var(--shadow-sm);}
@keyframes fadeSlideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.resume-info{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px;}
.resume-icon{font-size:20px;flex-shrink:0;margin-top:2px;}
.resume-text{display:flex;flex-direction:column;gap:2px;}
.resume-text strong{font-size:14px;color:var(--text);}
.resume-text span{font-size:12px;color:var(--text-muted);}
.resume-btns{display:flex;gap:8px;}
.btn-resume{flex:1;padding:10px;border:none;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s;-webkit-tap-highlight-color:transparent;}
.btn-resume:active{transform:scale(.97);}
.btn-resume-discard{flex:1;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:13px;cursor:pointer;}
.btn-start{display:block;width:calc(100% - 32px);max-width:400px;margin:8px auto 40px;padding:16px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;border:none;border-radius:50px;font-size:18px;font-weight:600;cursor:pointer;box-shadow:0 6px 20px rgba(108,92,231,.35);transition:transform .2s;letter-spacing:2px;-webkit-tap-highlight-color:transparent;}
.btn-start:active{transform:scale(.97);}

/* ======== 答题页 ======== */
#page-test{min-height:100vh;padding-bottom:100px;}
.test-header{position:sticky;top:0;z-index:100;background:var(--card);padding:12px 16px 8px;box-shadow:var(--shadow-sm);border-bottom:1px solid var(--border);}
.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:13px;color:var(--text-light);}
.progress-info strong{color:var(--primary);font-size:15px;}
.progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:3px;transition:width .4s ease;}
.question-area{padding:24px 0;position:relative;overflow:hidden;min-height:200px;}
.question-card{background:var(--card);border-radius:var(--radius);padding:24px 20px;box-shadow:var(--shadow-sm);border:1px solid var(--border);transition:opacity .3s,transform .3s;}
.question-card.slide-out-left{opacity:0;transform:translateX(-60px);pointer-events:none;}
.question-card.slide-out-right{opacity:0;transform:translateX(60px);pointer-events:none;}
.question-card.slide-in-left{animation:slideInLeft .3s ease forwards;}
.question-card.slide-in-right{animation:slideInRight .3s ease forwards;}
@keyframes slideInLeft{from{opacity:0;transform:translateX(60px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideInRight{from{opacity:0;transform:translateX(-60px)}to{opacity:1;transform:translateX(0)}}
.q-badge{display:inline-block;padding:4px 14px;border-radius:50px;font-size:12px;font-weight:700;color:#fff;margin-bottom:16px;background:linear-gradient(135deg,var(--primary),var(--primary-light));}
.q-text{font-size:17px;line-height:1.7;margin-bottom:20px;font-weight:600;color:var(--text);}
.option-btn{display:flex;align-items:center;gap:12px;width:100%;padding:16px;margin-bottom:10px;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:15px;color:var(--text);transition:all .2s;-webkit-tap-highlight-color:transparent;text-align:left;}
.option-btn:active{transform:scale(.98);}
.option-btn.selected{border-color:var(--primary);background:#F0EDFF;}
.option-circle{width:32px;height:32px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--text-light);flex-shrink:0;transition:all .2s;}
.option-btn.selected .option-circle{border-color:var(--primary);background:var(--primary);color:#fff;}
.option-text{flex:1;line-height:1.5;}
.test-nav{position:fixed;bottom:0;left:0;right:0;background:var(--card);padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));box-shadow:0 -2px 12px rgba(0,0,0,.06);display:flex;gap:12px;z-index:100;border-top:1px solid var(--border);}
.test-nav button{flex:1;padding:12px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;border:none;transition:all .2s;-webkit-tap-highlight-color:transparent;}
.btn-prev{background:var(--bg);color:var(--text-light);border:1px solid var(--border);}
.btn-next{background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;box-shadow:0 4px 12px rgba(108,92,231,.25);}
.btn-prev:disabled,.btn-next:disabled{opacity:.5;pointer-events:none;}

/* ======== 答题卡浮标 ======== */
.answer-sheet-fab{display:none!important;position:fixed;right:16px;bottom:90px;width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(108,92,231,.4);cursor:pointer;z-index:200;-webkit-tap-highlight-color:transparent;transition:transform .2s;}
.answer-sheet-fab:active{transform:scale(.9);}
.fab-icon{font-size:22px;}
.fab-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;border-radius:10px;background:#E74C3C;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg);}
.fab-badge.all-done{background:var(--success);}
.answer-sheet-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);z-index:300;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease;}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.answer-sheet-panel{width:100%;max-width:500px;max-height:75vh;background:var(--card);border-radius:20px 20px 0 0;padding:20px 16px;padding-bottom:max(20px,env(safe-area-inset-bottom));display:flex;flex-direction:column;animation:slideUp .3s ease;}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.answer-sheet-header{display:flex;align-items:center;gap:10px;margin-bottom:12px;}
.answer-sheet-title{font-size:16px;font-weight:700;color:var(--text);}
.answer-sheet-stats{flex:1;font-size:12px;color:var(--text-muted);}
.answer-sheet-close{width:32px;height:32px;border-radius:50%;border:none;background:var(--bg);color:var(--text-light);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.answer-sheet-legend{display:flex;gap:14px;margin-bottom:12px;font-size:11px;color:var(--text-muted);}
.legend-item{display:flex;align-items:center;gap:4px;}
.legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0;}
.legend-done{background:var(--primary);}
.legend-current{background:#E040FB;box-shadow:0 0 6px #E040FB;}
.legend-undone{background:var(--border);}
.answer-sheet-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;overflow-y:auto;flex:1;padding:4px 0;}
.sheet-cell{width:100%;aspect-ratio:1;border-radius:6px;border:none;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s;-webkit-tap-highlight-color:transparent;background:var(--border);color:var(--text-muted);}
.sheet-cell:active{transform:scale(.88);}
.sheet-cell.cell-done{background:var(--primary);color:#fff;}
.sheet-cell.cell-current{background:#E040FB;color:#fff;box-shadow:0 0 8px rgba(224,64,251,.4);}
.sheet-cell.cell-undone{background:var(--border);color:var(--text-muted);}
.answer-sheet-jump-btn{margin-top:12px;padding:12px;border:none;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:transform .2s;}
.answer-sheet-jump-btn:active{transform:scale(.97);}
.answer-sheet-jump-btn:disabled{opacity:.5;cursor:default;}

/* ======== 确认弹窗 ======== */
.confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px;}
.confirm-modal{background:var(--card);border-radius:var(--radius);padding:24px;max-width:360px;width:100%;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.2);animation:modalIn .25s ease;}
@keyframes modalIn{from{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:none}}
.confirm-modal h3{font-size:18px;margin-bottom:12px;}
.confirm-modal p{font-size:14px;color:var(--text-light);margin-bottom:20px;line-height:1.6;}
.confirm-btns{display:flex;gap:10px;}
.btn-confirm-cancel{flex:1;padding:12px;border:1px solid var(--border);border-radius:10px;background:var(--card);color:var(--text-light);font-size:14px;cursor:pointer;}
.btn-confirm-ok{flex:1;padding:12px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-size:14px;font-weight:600;cursor:pointer;}

/* ======== 报告页 ======== */
#page-report{min-height:100vh;padding-bottom:40px;}
.report-hero{text-align:center;padding:52px 20px 36px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);color:#fff;border-radius:0 0 36px 36px;position:relative;overflow:hidden;}
.report-hero::before{content:'';position:absolute;top:-80px;right:-60px;width:240px;height:240px;background:rgba(255,255,255,.08);border-radius:50%;}
.report-hero h2{font-size:26px;margin-bottom:8px;position:relative;z-index:1;font-weight:800;}
.report-hero p{font-size:13px;opacity:.85;position:relative;z-index:1;}

/* 主类型卡片 */
.main-type-card{margin:-36px 16px 24px;background:var(--card);border-radius:20px;padding:28px 24px;box-shadow:0 8px 40px rgba(0,0,0,.08);text-align:center;position:relative;z-index:10;border:1px solid rgba(108,92,231,.1);}
.main-type-icon{font-size:56px;margin-bottom:8px;}
.main-type-name{font-size:28px;font-weight:800;letter-spacing:2px;margin-bottom:4px;}
.main-type-en{font-size:14px;color:var(--text-muted);margin-bottom:8px;}
.main-type-brief{font-size:14px;color:var(--text-light);line-height:1.6;font-style:italic;}
.main-type-divider{height:1px;background:var(--border);margin:18px 0;}
.trait-tags{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin:12px 0;}
.trait-tag{padding:5px 14px;border-radius:50px;font-size:12px;font-weight:600;white-space:nowrap;}

/* 维度条 */
.report-section{margin:16px;background:var(--card);border-radius:var(--radius);padding:22px 20px;box-shadow:var(--shadow-sm);border:1px solid var(--border);position:relative;overflow:hidden;}
.report-section:hover{box-shadow:0 4px 20px rgba(108,92,231,.08);}
.report-section h3{font-size:17px;margin-bottom:16px;display:flex;align-items:center;gap:8px;color:var(--text);font-weight:700;}
.report-section h3 .icon{font-size:20px;}
.chapter-divider{margin:32px 16px 12px;padding:0 4px 12px;font-size:18px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:12px;position:relative;}
.chapter-divider::after{content:'';position:absolute;bottom:0;left:4px;right:4px;height:2px;background:linear-gradient(90deg,var(--primary),rgba(108,92,231,.3) 40%,transparent 100%);border-radius:1px;}
.chapter-divider span{display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-size:11px;font-weight:700;padding:4px 14px;border-radius:50px;white-space:nowrap;letter-spacing:1px;}

/* 双极维度条 */
.bipolar-item{margin-bottom:16px;}
.bipolar-item:last-child{margin-bottom:0;}
.bipolar-labels{display:flex;justify-content:space-between;margin-bottom:6px;font-size:13px;font-weight:600;}
.bipolar-l{color:var(--primary);}
.bipolar-r{color:#E74C3C;}
.bipolar-track{height:24px;border-radius:12px;background:var(--border);position:relative;overflow:hidden;display:flex;}
.bipolar-fill-l{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-light));border-radius:12px 0 0 12px;transition:width 1s ease;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;min-width:36px;}
.bipolar-fill-r{height:100%;background:linear-gradient(90deg,#FF6B6B,#E74C3C);border-radius:0 12px 12px 0;transition:width 1s ease;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;min-width:36px;}

/* 详细描述 */
.type-desc-text{font-size:14px;color:var(--text-light);line-height:1.9;margin-bottom:16px;}
.type-section-block{margin-bottom:16px;padding:16px;border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);}
.type-section-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:10px;display:flex;align-items:center;gap:6px;}
.type-list-item{font-size:13px;color:var(--text-light);padding:6px 0;border-bottom:1px solid var(--border);line-height:1.7;}
.type-list-item:last-child{border:none;padding-bottom:0;}
.type-list-item.strength::before{content:'✅ ';font-size:12px;}
.type-list-item.challenge::before{content:'⚡ ';font-size:12px;}

/* 名人和职业标签 */
.tag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;}
.info-tag{padding:5px 14px;border-radius:50px;font-size:12px;font-weight:600;white-space:nowrap;}
.career-tag{background:rgba(108,92,231,.08);color:var(--primary);border:1px solid rgba(108,92,231,.15);}
.celeb-tag{background:rgba(255,107,107,.08);color:#E74C3C;border:1px solid rgba(255,107,107,.15);}

/* 成长建议 */
.advice-box{padding:16px 18px;border-radius:var(--radius-sm);background:rgba(108,92,231,.04);border-left:4px solid var(--primary);font-size:14px;color:var(--text-light);line-height:1.9;font-style:italic;}

/* 合拍分享 */
.compat-share-section{margin:16px;background:var(--card);border-radius:var(--radius);padding:24px 20px;box-shadow:var(--shadow-sm);text-align:center;border:1px solid var(--border);}
.compat-share-icon{font-size:40px;margin-bottom:8px;}
.compat-share-title{font-size:18px;font-weight:700;margin-bottom:6px;}
.compat-share-desc{font-size:13px;color:var(--text-light);margin-bottom:16px;line-height:1.6;}
.btn-compat-share{padding:12px 28px;border:none;border-radius:50px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 16px rgba(108,92,231,.25);transition:transform .2s;}
.btn-compat-share:active{transform:scale(.97);}

/* Canvas名片 */
#persona-card-wrapper{display:flex;justify-content:center;overflow:hidden;border-radius:var(--radius-sm);margin-bottom:16px;}
#persona-card-canvas{width:100%;max-width:420px;height:auto;border-radius:var(--radius-sm);box-shadow:0 4px 20px rgba(0,0,0,.1);}
.btn-save-card{display:block;width:100%;padding:14px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;border:none;border-radius:50px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s;}
.btn-save-card:active{transform:scale(.97);}

/* 免责声明 */
.disclaimer{margin:16px;padding:16px;border-radius:var(--radius);background:var(--bg);border:1px solid var(--border);font-size:12px;color:var(--text-muted);line-height:1.8;text-align:center;}
.btn-restart{display:block;width:calc(100% - 32px);max-width:400px;margin:32px auto;padding:16px;background:var(--card);color:var(--primary);border:2px solid var(--primary);border-radius:50px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;-webkit-tap-highlight-color:transparent;}
.btn-restart:active{background:rgba(108,92,231,.06);transform:scale(.97);}

/* 完整版引导 */
.full-version-box{margin:16px;background:linear-gradient(135deg,#F0EDFF,#E8E5FF);border:1px solid rgba(108,92,231,.2);border-radius:var(--radius);padding:20px;text-align:center;}
.full-version-box p{font-size:14px;color:var(--text-light);margin-bottom:12px;line-height:1.6;}
.btn-full-version{display:inline-block;padding:10px 28px;border-radius:50px;background:linear-gradient(135deg,var(--primary),var(--primary-light));color:#fff;text-decoration:none;font-size:14px;font-weight:600;box-shadow:0 4px 12px rgba(108,92,231,.25);transition:transform .2s;}
.btn-full-version:active{transform:scale(.97);}

/* toast */
.compat-link-toast{position:fixed;top:20%;left:50%;transform:translateX(-50%) translateY(-10px);background:rgba(0,0,0,.8);color:#fff;padding:12px 24px;border-radius:12px;font-size:14px;z-index:99999;opacity:0;transition:all .3s;white-space:pre-line;text-align:center;}
.compat-link-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ======== 响应式 ======== */
@media(max-width:374px){.hero h1{font-size:24px;}.q-text{font-size:15px;}}
@media(min-width:768px){.container{padding:0 24px;}.hero{padding:60px 40px 44px;}.hero h1{font-size:36px;}.report-section{padding:28px;margin:20px;}.chapter-divider{margin:36px 20px 14px;font-size:20px;}}
