/* ===================================================
 NMTI v10 - 全面优化版样式
 =================================================== */

/* ---------- CSS变量 ---------- */
:root {
  --primary: #667eea;
  --primary-dark: #764ba2;
  --accent: #f5576c;
  --success: #22c55e;
  --warning: #f59e0b;
  --text: #333;
  --text-light: #666;
  --text-muted: #999;
  --bg: #f8f9fa;
  --card-bg: #ffffff;
  --radius-sm: 10px;
  --radius-md: 16px;
  --radius-lg: 20px;
  --shadow-sm: 0 2px 10px rgba(0,0,0,0.05);
  --shadow-md: 0 4px 20px rgba(0,0,0,0.08);
  --shadow-lg: 0 8px 30px rgba(0,0,0,0.12);
  --ease-out: cubic-bezier(0.4, 0, 0.2, 1);
}

/* ---------- 基础重置 ---------- */
* { margin: 0; padding: 0; box-sizing: border-box; }
html {
  scroll-behavior: smooth;
  -webkit-tap-highlight-color: transparent;
}
body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'PingFang SC', sans-serif;
  background: var(--bg); color: var(--text); line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100% !important;
  overflow-x: hidden;
}

/* 页面切换动画 */
.page { min-height: 100vh; background: var(--bg); animation: pageIn 0.4s ease-out; }
@keyframes pageIn { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }

/* ==================== 首页 ==================== */

.hero {
  position: relative; min-height: 56vh; display: flex;
  align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  padding: 40px 20px; overflow: hidden;
}
.hero-bg {
  position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.hero::before,.hero::after { content:''; position:absolute; border-radius:50%; pointer-events:none; }
.hero::before {
  width:300px;height:300px;background:rgba(255,255,255,0.07);top:-80px;right:-60px;
  animation: float 8s ease-in-out infinite;
}
.hero::after {
  width:200px;height:200px;background:rgba(255,255,255,0.04);bottom:-40px;left:-30px;
  animation: float 10s ease-in-out infinite reverse;
}
@keyframes float { 0%,100%{transform:translate(0,0)} 50%{transform:translate(20px,-20px)} }

.hero-content { position:relative; text-align:center; color:#fff; z-index:1; }
.hero-content h1 {
  font-size: clamp(36px,8vw,52px); font-weight:800; margin-bottom:14px;
  text-shadow: 0 2px 20px rgba(0,0,0,0.15); letter-spacing:-1px;
}
.hero-content p { font-size: clamp(16px,3.5vw,22px); opacity:0.92; margin-bottom:32px; }

/* 按钮基础 */
.btn {
  display:inline-block; padding:16px 48px; border:none; border-radius:50px;
  font-size:18px; font-weight:600; cursor:pointer; transition:all 0.3s ease;
  outline:none; -webkit-tap-highlight-color:transparent; position:relative; overflow:hidden;
}
.btn-primary {
  background: linear-gradient(135deg,#f093fb,#f5576c); color:white;
  box-shadow: 0 4px 20px rgba(245,87,108,0.35);
  animation: pulseGlow 2.5s ease-in-out infinite;
}
@keyframes pulseGlow {
  0%,100%{box-shadow:0 4px 20px rgba(245,87,108,0.35)}
  50%{box-shadow:0 6px 30px rgba(245,87,108,0.5)}
}
.btn-primary:hover { transform:translateY(-3px) scale(1.02); box-shadow:0 8px 30px rgba(245,87,108,0.45); }
.btn-primary:active { transform:translateY(-1px) scale(0.98); }
.btn-primary:disabled {
  background:#e5e7eb;color:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none;animation:none;
}
.btn-secondary { background:white;color:var(--text-light);border:2px solid #e5e7eb; }
.btn-secondary:hover { background:#f3f4f6;border-color:#d1d5db;color:var(--text); }
.btn-ghost { background:transparent;color:var(--text-muted);border:none;font-size:14px;padding:12px 16px; }
.btn-ghost:hover { color:var(--primary); }

/* 特性区域 */
.features { padding:clamp(40px,6vw,70px) 20px; max-width:800px;margin:0 auto; }
.features h2 {
  text-align:center;font-size:clamp(20px,4vw,26px);margin-bottom:clamp(24px,4vw,44px);
  color:var(--text);font-weight:700;
}
.feature-grid { display:flex; gap:24px;justify-content:center;flex-wrap:wrap; }
.feature-item {
  background:var(--card-bg);padding:32px 24px;border-radius:var(--radius-md);
  text-align:center;box-shadow:var(--shadow-sm);transition:all 0.35s ease;
  min-height:200px;width:calc(33.333%-16px);min-width:200px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.feature-item::before {
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--primary),var(--accent));opacity:0;transition:opacity .3s;
}
.feature-item:hover { transform:translateY(-6px);box-shadow:var(--shadow-lg); }
.feature-item:hover::before{ opacity:1; }
.feature-icon { font-size:48px;margin-bottom:16px;display:block;line-height:1;animation:iconBounce 3s ease-in-out infinite; }
.feature-item:nth-child(2) .feature-icon{animation-delay:.3s}
.feature-item:nth-child(3) .feature-icon{animation-delay:.6s}
@keyframes iconBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)} }
.feature-item h3{font-size:18px;margin-bottom:8px;color:var(--text);font-weight:600;}
.feature-item p{font-size:14px;color:var(--text-light);}

.btn-outline {
  display:inline-block;padding:8px 18px;border:1.5px solid var(--primary);border-radius:20px;
  background:transparent;color:var(--primary);font-size:13px;font-weight:500;
  cursor:pointer;transition:all .25s ease;margin-top:12px;
}
.btn-outline:hover { background:var(--primary);color:white;box-shadow:0 4px 12px rgba(102,126,234,.3); }

/* 手机端特性卡片 */
@media(max-width:600px){
  .hero{min-height:50vh;padding:28px 16px}
  .feature-grid{gap:14px;padding:0 4px}
  .feature-item{width:100%!important;min-width:auto!important;min-height:148px;padding:22px 18px}
  .feature-icon{font-size:38px}
}

.footer{text-align:center;padding:36px 20px;color:#bbb;font-size:14px}

/* ==================== 测试页 ==================== */

.test-header{
  padding:10px 16px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  display:flex;align-items:center;
}
.back-btn{
  display:inline-flex;align-items:center;gap:4px;
  background:rgba(255,255,255,0.15);border:none;color:white;
  padding:8px 14px;border-radius:20px;font-size:14px;cursor:pointer;
  transition:all .25s ease;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);
}
.back-btn:hover{background:rgba(255,255,255,0.26)}
.back-btn:active{transform:scale(.96)}
.back-btn svg{stroke:currentColor}

.progress-header{
  background:var(--card-bg);padding:16px 20px;position:sticky;top:0;z-index:100;
  box-shadow:0 2px 12px rgba(0,0,0,.06);
}
.prog-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.prog-text{font-size:13px;color:var(--text-light);font-weight:500}
.prog-pct{font-size:13px;font-weight:700;color:var(--primary)}
.prog-bar-wrap{
  height:6px;background:#eef0f4;border-radius:3px;overflow:hidden;margin-bottom:12px;
}
.prog-bar{
  height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-dark));border-radius:3px;
  transition:width .4s cubic-bezier(.4,0,.2,1);position:relative;
}
.prog-bar::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent);
  animation:shimmer 2.5s infinite;
}
@keyframes shimmer{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}

.meme-inline{
  display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:14px;
  animation:memeFadeIn .4s ease-out;
}
@keyframes memeFadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.meme-emoji-sm{font-size:18px}
.meme-text-sm{font-size:12px;color:#999;font-style:italic}

.pdots{display:flex;justify-content:center;gap:6px;flex-wrap:wrap}
.pdot{width:6px;height:6px;border-radius:50%;background:#e5e7eb;transition:all .3s ease}
.pdot.active{background:var(--primary);transform:scale(1.5);box-shadow:0 0 8px rgba(102,126,234,.4)}
.pdot.done{background:var(--success)}

/* 题目区域 */
.q-area{padding:20px 16px;max-width:600px;margin:0 auto}
.q-card{
  background:var(--card-bg);border-radius:var(--radius-lg);
  padding:clamp(24px,5vw,32px) 20px;box-shadow:var(--shadow-md);
  border:1px solid rgba(0,0,0,.03);
}
.q-card h2{font-size:clamp(17px,4vw,20px);line-height:1.65;margin-bottom:24px;color:var(--text);font-weight:600}
.options{display:flex;flex-direction:column;gap:11px}
.option-item{
  padding:15px 18px;border:2px solid #eef0f4;border-radius:14px;cursor:pointer;
  transition:all .25s cubic-bezier(.4,0,.2,1);background:var(--card-bg);position:relative;overflow:hidden;
  -webkit-tap-highlight-color:transparent;user-select:none;
}
.option-item::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--primary);
  transform:scaleY(0);transition:transform .25s ease;
}
.option-item:hover{border-color:var(--primary);background:#f8f9ff;transform:translateX(3px)}
.option-item.selected{
  border-color:var(--primary);background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:white;
  transform:scale(1.02);box-shadow:0 4px 16px rgba(102,126,234,.3)
}
.option-item.selected::before{transform:scaleY(1)}
.option-item.selected:hover{transform:scale(1.02)}
.option-text{font-size:14.5px;line-height:1.55;position:relative;z-index:1}

.action-area{padding:20px;max-width:600px;margin:0 auto}
#test .action-area{display:flex;gap:12px}
#test .action-area .btn{flex:1}

/* ==================== 结果页 ==================== */

.result-hero{
  position:relative;padding:clamp(48px,8vw,64px) 20px 36px;text-align:center;overflow:hidden
}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-icon-wrap{
  position:relative;z-index:1;margin-bottom:16px;
  animation:resultIconIn .7s cubic-bezier(.34,1.56,.64,1);
}
@keyframes resultIconIn{
  from{opacity:0;transform:scale(.3) rotate(-10deg)}to{opacity:1;transform:scale(1) rotate(0)}
}
.hero-icon{
  font-size:clamp(60px,12vw,84px);display:block;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,.15));
}
.hero-glow{
  position:absolute;width:120px;height:120px;border-radius:50%;
  filter:blur(50px);opacity:.45;top:50%;left:50%;transform:translate(-50%,-50%);z-index:0;
}
.type-badge{
  display:inline-block;padding:6px 18px;border-radius:20px;color:white;
  font-size:13px;font-weight:600;margin-bottom:12px;letter-spacing:.5px;
  animation:badgeSlide .5s ease-out .2s both;
}
@keyframes badgeSlide{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.hero-name{
  font-size:clamp(28px,7vw,38px);font-weight:800;margin-bottom:8px;color:var(--text);
  animation:nameSlide .5s ease-out .3s both;
}
@keyframes nameSlide{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.hero-sub{
  font-size:15px;color:var(--text-light);animation:subSlide .5s ease-out .4s both;
}
@keyframes subSlide{from{opacity:0}to{opacity:1}}

/* 卡片通用 */
.card{
  background:var(--card-bg);border-radius:var(--radius-md);padding:24px;
  margin:14px 20px;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.03);
  animation:cardUp .45s ease-out both;
}
.card:nth-child(2){animation-delay:.1s}.card:nth-child(3){animation-delay:.2s}
.card:nth-child(4){animation-delay:.3s}.card:nth-child(5){animation-delay:.4s}
@keyframes cardUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

.card-head{display:flex;align-items:center;gap:8px;margin-bottom:16px}
.card-tag{padding:4px 12px;border-radius:12px;font-size:13px;font-weight:500}
.card-tag.gold{background:linear-gradient(135deg,#ffd700,#ffed4a);color:#8b6914}
.card-hint{font-size:12px;color:var(--text-muted)}
.desc-text{font-size:15px;line-height:1.85;color:#555;margin-bottom:20px}

/* 特征标签 */
.feature-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}
.feature-tag{
  display:flex;align-items:center;gap:6px;padding:8px 14px;
  background:#f3f4f6;border-radius:20px;font-size:13px;color:#555;transition:transform .2s;
}
.feature-tag:hover{transform:translateY(-2px)}
.ft-dot{width:6px;height:6px;border-radius:50%}

/* 引用框 */
.quote-box{background:#f8f9fa;border-radius:12px;padding:20px;position:relative}
.quote-mark{font-size:44px;color:#ddd;position:absolute;top:10px;left:14px;line-height:1}
.quote-txt{font-size:15px;color:var(--text-light);font-style:italic;padding-left:28px;line-height:1.7}

/* 雷达图 */
.radar-area{display:flex;justify-content:center;padding:16px 0}
#radarCanvas{max-width:100%;height:auto}

/* 维度条 */
.dim-bars{display:flex;flex-direction:column;gap:11px}
.dim-bar{display:flex;align-items:center;gap:10px}
.dim-name{width:48px;font-size:12.5px;color:var(--text-light);flex-shrink:0}
.dim-track{flex:1;height:8px;background:#eef0f4;border-radius:4px;overflow:hidden}
.dim-fill{height:100%;border-radius:4px;transition:width .6s ease}
.dim-val{width:38px;font-size:11.5px;color:var(--text-muted);text-align:right}

/* 岗位标签 */
.job-block{margin-bottom:14px}
.job-label{font-size:13px;margin-bottom:8px;display:block}
.job-label.ok{color:var(--success)}.job-label.warn{color:var(--warning)}
.job-tags{display:flex;flex-wrap:wrap;gap:7px}
.job-tag{padding:6px 12px;border-radius:16px;font-size:12px}
.job-tag.ok{background:#dcfce7;color:#166534}
.job-tag.warn{background:#fef3c7;color:#92400e}

/* 建议 */
.advice-simple{background:#f0fdf4;border-radius:12px;padding:16px;margin-top:14px}
.advice-label{font-size:13px;color:var(--success);font-weight:600;display:block;margin-bottom:8px}
.advice-txt{font-size:14px;color:#555;line-height:1.68}

/* 高级内容锁定卡片 */
.premium-card{border:2px dashed #fbbf24;background:linear-gradient(135deg,#fffbeb,#fef3c7)}
.premium-lock{text-align:center;padding:20px 0}
.lock-icon{font-size:46px;margin-bottom:10px}
.lock-title{font-size:17px;font-weight:600;color:#92400e;margin-bottom:8px}
.lock-desc{font-size:13.5px;color:#a16207;margin-bottom:18px;line-height:1.55}
.perk-list{text-align:left;margin-bottom:22px}
.perk-item{display:flex;align-items:center;gap:10px;padding:7px 0;font-size:13.5px;color:#713f12}
.perk-check{color:var(--warning);font-weight:bold}
.btn-unlock{
  width:100%;padding:14px;background:linear-gradient(135deg,var(--warning),#fbbf24);
  border:none;border-radius:12px;color:white;font-size:15.5px;font-weight:600;
  cursor:pointer;margin-bottom:8px;transition:all .3s ease;
}
.btn-unlock:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(245,158,11,.4)}
.unlock-note{font-size:11.5px;color:#a16207}

/* 已解锁内容 */
.premium-opened{border:2px solid #fbbf24}
.unlocked-badge{
  margin-left:auto;padding:4px 12px;background:var(--success);color:white;
  border-radius:12px;font-size:12px;font-weight:600;
}
.premium-section{margin-bottom:22px;padding-bottom:22px;border-bottom:1px solid #eef0f4}
.premium-section.last{border-bottom:none;margin-bottom:0;padding-bottom:0}
.p-title{font-size:15.5px;font-weight:600;margin-bottom:14px;color:var(--text)}

.pm-item{background:#f9fafb;border-radius:12px;padding:15px;margin-bottom:11px;transition:transform .2s}
.pm-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.pm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px}
.pm-title{font-weight:600;color:var(--text)}
.pm-match{padding:4px 10px;border-radius:12px;font-size:11.5px;font-weight:600}
.pm-reason{font-size:13px;color:var(--text-light);margin-bottom:7px;line-height:1.5}
.pm-salary{font-size:13px;color:var(--success);font-weight:600}

/* 职业路径 */
.path-node{display:flex;gap:14px;margin-bottom:14px}
.path-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:5px}
.path-content{flex:1}
.path-year{font-size:12.5px;color:var(--text-light);display:block;margin-bottom:3px;font-weight:500}
.path-target{font-size:14px;color:var(--text);line-height:1.58}

/* 薪资预测 */
.salary-bar{display:flex;align-items:center;gap:12px;margin-bottom:11px}
.sy-year{width:48px;font-size:12.5px;color:var(--text-light)}
.sy-track{flex:1;height:10px;background:#eef0f4;border-radius:5px;overflow:hidden}
.sy-fill{height:100%;border-radius:5px;transition:width .8s cubic-bezier(.4,0,.2,1)}
.sy-range{width:86px;font-size:11.5px;color:var(--text-light);text-align:right}

/* 核心建议 */
.action-item{display:flex;align-items:flex-start;gap:10px;padding:9px 0;font-size:14px;color:#555;line-height:1.62}
.action-check{font-weight:bold;flex-shrink:0;font-size:15px}

/* 结果页按钮区 */
.btn-main{
  width:100%;padding:16px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  border:none;border-radius:12px;color:white;font-size:16px;font-weight:600;cursor:pointer;
  margin-bottom:12px;transition:all .3s ease;
}
.btn-main:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(102,126,234,.35)}
.btn-row-group{display:flex;gap:12px}
.btn-sub{
  flex:1;padding:14px;background:white;border:2px solid #eef0f4;border-radius:12px;
  color:var(--text-light);font-size:14px;cursor:pointer;transition:all .25s ease;
}
.btn-sub:hover{border-color:var(--primary);color:var(--primary)}
.page-footer{text-align:center;padding:28px;color:#bbb;font-size:12.5px}

/* ==================== 全部人格页 ==================== */

.types-header{padding:36px 20px 18px;text-align:center}
.types-header h1{font-size:24px;margin-bottom:18px;font-weight:700}
.filter-buttons{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}
.filter-btn{
  padding:8px 16px;border:1px solid #eef0f4;border-radius:20px;
  background:white;font-size:13px;color:var(--text-light);cursor:pointer;transition:all .25s;
}
.filter-btn.active{background:var(--primary);color:white;border-color:var(--primary)}
.types-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:14px;padding:20px;max-width:800px;margin:0 auto;
}
.type-card{
  background:white;border-radius:var(--radius-md);overflow:hidden;
  box-shadow:var(--shadow-sm);cursor:pointer;transition:all .3s ease;
}
.type-card{cursor:default}
.tc-header{padding:18px;text-align:center}
.tc-icon{font-size:38px;display:block;margin-bottom:6px}
.tc-code{font-size:11.5px;color:var(--text-light);font-weight:600}
.tc-body{padding:14px;text-align:center}
.tc-name{font-size:15.5px;font-weight:600;margin-bottom:3px}
.tc-sub{font-size:11.5px;color:var(--text-muted)}

/* ==================== 模态框 ==================== */

.modal-mask{
  position:fixed;inset:0;background:rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:center;z-index:1000;
  padding:20px;animation:fadeIn .25s ease;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-dialog{
  background:white;border-radius:20px;width:100%;max-width:400px;
  overflow:hidden;animation:modalIn .3s ease;
}
@keyframes modalIn{from{opacity:0;transform:scale(.92) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-head{
  display:flex;justify-content:space-between;align-items:center;padding:20px;
  border-bottom:1px solid #eef0f4;
}
.modal-title{font-size:17px;font-weight:600}
.modal-close{font-size:24px;color:var(--text-muted);cursor:pointer;transition:color .2s}
.modal-close:hover{color:var(--text)}

.poster-container{padding:20px;text-align:center}
.poster-container img{max-width:100%;border-radius:12px;box-shadow:var(--shadow-md)}
.poster-loading{padding:60px;color:var(--text-muted)}
.modal-actions{display:flex;gap:12px;padding:20px;border-top:1px solid #eef0f4}
.btn-modal-save,.btn-modal-share{flex:1;padding:14px;border-radius:10px;border:none;font-size:14px;cursor:pointer}
.btn-modal-save{background:#f3f4f6;color:var(--text)}
.btn-modal-share{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:white}

/* 支付弹窗 */
.pay-dialog{
  background:white;border-radius:20px;width:100%;max-width:360px;
  padding:32px 24px;text-align:center;
}
.pay-head{margin-bottom:18px}
.pay-icon{font-size:44px;display:block;margin-bottom:10px}
.pay-title{font-size:19px;font-weight:600}
.pay-price-area{margin-bottom:22px}
.pay-cny{font-size:20px;color:var(--warning)}
.pay-num{font-size:44px;font-weight:800;color:var(--warning)}
.pay-unit{font-size:14px;color:var(--text-muted)}
.pay-original{display:block;font-size:12.5px;color:var(--text-muted);text-decoration:line-through;margin-top:4px}
.pay-perks{text-align:left;margin-bottom:22px}
.pp-check{display:block;padding:7px 0;font-size:13.5px;color:#555}
.btn-pay{
  width:100%;padding:16px;background:linear-gradient(135deg,var(--success),#16a34a);
  border:none;border-radius:12px;color:white;font-size:16px;font-weight:600;
  cursor:pointer;margin-bottom:10px;transition:all .3s;
}
.btn-pay:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(34,197,94,.35)}
.pay-safe{font-size:11.5px;color:var(--text-muted)}

/* 人格图鉴弹窗 */
.gallery-dialog{
  background:white;border-radius:20px;width:100%;max-width:520px;
  max-height:85vh;overflow-y:auto;
}
.gallery-head{
  display:flex;justify-content:space-between;align-items:center;padding:20px 24px;
  border-bottom:1px solid #eef0f4;position:sticky;top:0;background:white;z-index:10;
  border-radius:20px 20px 0 0;
}
.gallery-title{font-size:17.5px;font-weight:600;color:var(--text)}
.gallery-content{padding:14px 20px 24px}
.gallery-card{
  background:#fafbfc;border-radius:12px;padding:15px;margin-bottom:12px;
  transition:transform .2s ease,box-shadow .2s ease;border-left:4px solid transparent;
}
.gallery-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.08)}
.gc-top{display:flex;align-items:center;gap:8px;margin-bottom:5px}
.gc-icon{font-size:26px;flex-shrink:0}
.gc-name{font-size:16px;font-weight:700;color:var(--text)}
.gc-type{
  font-size:10.5px;padding:3px 10px;border-radius:10px;margin-left:auto;
  white-space:nowrap;font-weight:600;
}
.gc-subtitle{font-size:12.5px;color:var(--text-muted);margin-bottom:7px;font-style:italic}
.gc-desc{font-size:12.5px;color:var(--text-light);line-height:1.65;margin-bottom:9px}
.gc-tags{display:flex;flex-wrap:wrap;gap:5px}
.gc-tag{font-size:10.5px;padding:4px 10px;border-radius:12px;background:#f0f9ff;color:#0369a1}

/* 手机端图鉴弹窗底部弹出 */
@media(max-width:560px){
  .gallery-dialog{
    max-width:100%;max-height:90vh;border-radius:20px 20px 0 0;
    position:fixed;bottom:0;left:0;right:0;
  }
  .gallery-content{padding:12px 16px 28px}
  .gallery-card{padding:13px;margin-bottom:9px}
  .modal-mask{align-items:flex-end;padding:0}
  .modal-mask .gallery-dialog{border-radius:20px 20px 0 0}
}

/* 管理员验证弹窗 */
.auth-dialog{background:white;border-radius:20px;padding:36px 28px;text-align:center;max-width:340px;margin:0 auto}
.auth-icon{font-size:48px;display:block;margin-bottom:14px}
.auth-title{font-size:20px;font-weight:700;margin-bottom:8px}
.auth-desc{font-size:14px;color:var(--text-light);margin-bottom:18px}
.auth-input{
  width:100%;padding:14px 16px;border:2px solid #eef0f4;border-radius:12px;
  font-size:16px;text-align:center;outline:none;margin-bottom:14px;transition:border-color .25s;
}
.auth-input:focus{border-color:var(--primary)}
.auth-btn{
  width:100%;padding:14px;background:var(--primary);color:white;
  border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;
  transition:all .25s;
}
.auth-btn:hover{background:var(--primary-dark)}
.auth-hint{font-size:12px;color:var(--text-muted);margin-top:14px}
.auth-back{margin-top:16px;background:none;border:none;color:var(--text-muted);font-size:14px;cursor:pointer}

/* ==================== 撒花庆祝特效容器 ==================== */

.confetti-container{
  position:fixed;inset:0;pointer-events:none;z-index:9999;overflow:hidden;
}
.confetti{
  position:absolute;width:10px;height:10px;top:-10px;opacity:0;
  animation:confettiFall linear forwards;
}
@keyframes confettiFall{
  0%{opacity:1;transform:translateY(0)rotate(0deg)}
  100%{opacity:0;transform:translateY(100vh)rotate(720deg)}
}

/* ==================== 微信小屏适配 + 安全区域 ==================== */

@media screen and (max-width:375px){
  .hero-content h1{font-size:34px}.hero-content p{font-size:16px}
  .q-card h2{font-size:16.5px}.hero-name{font-size:26px}
  .card{margin:12px 14px;padding:20px}
  .pm-item{padding:12px}
}

/* iPhone底部安全区域 */
@supports(padding:max(0px)){
  body{padding-bottom:env(safe-area-inset-bottom)}
  .action-area{padding-bottom:calc(20px + env(safe-area-inset-bottom))}
  .page-footer{padding-bottom:calc(28px + env(safe-area-inset-bottom))}
}

/* 减少动效偏好 */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

/* ---------- 微信分享引导蒙层 ---------- */
.wx-guide-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.75);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: guideFadeIn .3s ease-out;
}

.wx-guide-content {
  text-align: center;
  color: #fff;
  padding: 32px 24px;
}

.wx-guide-arrow {
  font-size: 64px;
  margin-bottom: 8px;
  animation: arrowBounce 1s ease-in-out infinite;
}

.wx-guide-title {
  font-size: 22px;
  font-weight: bold;
  margin: 0 0 12px;
}

.wx-guide-sub {
  font-size: 16px;
  opacity: 0.85;
  margin: 0 0 20px;
}

.wx-guide-hint {
  font-size: 14px;
  opacity: 0.65;
  margin: 24px 0 16px;
}

.wx-guide-btn {
  margin-top: 16px;
  padding: 14px 36px;
  font-size: 16px;
  border-radius: 50px;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(34,197,94,0.4);
  transition: transform .15s, box-shadow .15s;
}

.wx-guide-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 28px rgba(34,197,94,0.5);
}

.wx-guide-btn:active {
  transform: scale(0.97);
}

@keyframes guideFadeIn { from{opacity:0} to{opacity:1} }
@keyframes arrowBounce {
  0%,100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}
@keyframes pulseRing {
  0% { transform: scale(1); opacity: .7; }
  70% { transform: scale(1.8); opacity: 0; }
  100% { transform: scale(1.8); opacity: 0; }
}

/* ---------- 悬浮解锁按钮（右侧） ---------- */
.float-unlock {
  position: fixed;
  right: 10px;
  bottom: 100px;
  z-index: 900;
  background: linear-gradient(135deg, #667eea, #764ba2);
  color: #fff;
  padding: 12px 14px;
  border-radius: 24px;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(102,126,234,0.45);
  animation: floatBounce 2s ease-in-out infinite;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
  transition: transform .15s, box-shadow .15s;
}
.float-unlock:hover {
  transform: scale(1.08);
  box-shadow: 0 6px 28px rgba(102,126,234,0.55);
}
.float-unlock:active {
  transform: scale(0.95);
}
.float-unlock-text {
  display: block;
  font-size: 13px;
  font-weight: bold;
  line-height: 1.3;
  text-align: center;
  white-space: nowrap;
}

@keyframes floatBounce {
  0%,100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}
