/* ============================================================
   姻缘匹配 — 温馨浪漫 × 科技光影
   ============================================================ */
:root{
  --red:#D45161;--rose:#E8837A;--peach:#F0B7A4;--gold:#E8C56D;
  --warm-bg:#FFF5F0;--card-bg:rgba(255,248,244,0.9);
  --text:#4A3035;--text-light:#8B6F75;
  --male-blue:#64B5F6;--female-pink:#F06292;
  --lock-green:#4CAF50;--glow-rose:0 0 40px rgba(232,131,122,0.25);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:"Microsoft YaHei","PingFang SC",sans-serif;
  background:linear-gradient(155deg,#FFF0EA 0%,#FFF5F0 25%,#FFF0EC 50%,#FFF3EE 75%,#FFF0EA 100%);
  min-height:100vh;color:var(--text);overflow-x:hidden;position:relative
}

/* ====== 粒子背景 ====== */
#particleCanvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none}

/* ====== 光晕 ====== */
.glow-orb{
  position:fixed;border-radius:50%;z-index:0;pointer-events:none;filter:blur(100px);
}
.orb-1{
  width:600px;height:600px;
  background:radial-gradient(circle,#FFE0D0 0%,#FFC8B8 30%,#FFE8D8 55%,transparent 75%);
  top:-100px;right:-80px;opacity:0.18;animation:floatOrb 8s ease-in-out infinite;
}
.orb-2{
  width:520px;height:520px;
  background:radial-gradient(circle,#FFF0E0 0%,#FFDDC8 35%,#FFF5EA 60%,transparent 80%);
  bottom:-80px;left:-60px;opacity:0.15;animation:floatOrb 10s ease-in-out infinite reverse;
}
.orb-3{
  width:400px;height:400px;
  background:radial-gradient(circle,#FFF8EE 0%,#FFE8D5 40%,transparent 78%);
  top:50%;left:50%;transform:translate(-50%,-50%);
  opacity:0.10;animation:floatOrb 12s ease-in-out infinite;
}
@keyframes floatOrb{
  0%,100%{transform:translate(0,0) scale(1)}
  25%{transform:translate(60px,-35px) scale(1.06)}
  50%{transform:translate(-25px,45px) scale(0.94)}
  75%{transform:translate(-45px,-25px) scale(1.04)}
}

/* ====== 飘落花瓣（纯CSS） ====== */
.petal{
  position:fixed;pointer-events:none;z-index:0;
  width:14px;height:14px;border-radius:50% 0 50% 0;
  background:rgba(255,183,178,0.22);
  animation:petalFall linear infinite;
}
@keyframes petalFall{
  0%{transform:translateY(-10vh) rotate(0deg) scale(1);opacity:0}
  10%{opacity:0.5}
  90%{opacity:0.3}
  100%{transform:translateY(110vh) rotate(720deg) scale(0.5);opacity:0}
}

/* ====== 玻璃效果 ====== */
.glass{
  background:rgba(255,250,246,0.82) !important;
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,220,210,0.55) !important;
  box-shadow:0 8px 40px rgba(180,120,110,0.08),0 2px 8px rgba(0,0,0,0.03),inset 0 1px 0 rgba(255,255,255,0.7) !important;
}

/* ====== Navbar ====== */
.navbar{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 28px;
  background:rgba(255,248,244,0.78);backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(212,81,97,0.1);
  position:sticky;top:0;z-index:100
}
.brand-icon{font-size:1.4rem;margin-right:6px}
.brand-text{
  font-weight:700;font-size:1.15rem;
  background:linear-gradient(135deg,#D45161,#E8837A,#E8C56D);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.nav-right{
  display:flex;align-items:center;gap:6px;
  font-size:0.82rem;color:#8B6F75;cursor:pointer;
  padding:7px 18px;border:1.5px solid rgba(212,81,97,0.25);border-radius:22px;
  transition:all 0.3s;background:rgba(255,240,235,0.5)
}
.nav-right:hover{color:#D45161;border-color:rgba(212,81,97,0.55);background:rgba(255,235,230,0.7)}
.nav-right.admin-active{
  background:rgba(212,81,97,0.1);border-color:rgba(212,81,97,0.6);color:#C04050;
  box-shadow:0 0 24px rgba(212,81,97,0.15)
}
.admin-dot{width:9px;height:9px;border-radius:50%;background:#CCC;transition:all 0.3s}
.nav-right.admin-active .admin-dot{background:#4CAF50;box-shadow:0 0 10px rgba(76,175,80,0.5)}

/* ====== View ====== */
.view{display:none;position:relative;z-index:1}
.view.active{display:block;animation:fadeIn 0.5s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ====== Header ====== */
.header{
  text-align:center;padding:55px 20px 38px;
  background:linear-gradient(180deg,rgba(255,210,195,0.35) 0%,rgba(255,225,210,0.18) 50%,transparent 100%);
  position:relative;overflow:hidden
}
.header::after{
  content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);
  width:260px;height:2px;
  background:linear-gradient(90deg,transparent,rgba(212,81,97,0.5),rgba(232,197,109,0.5),transparent)
}
.header h1{font-size:2.1rem;letter-spacing:6px;color:#4A3035}
.subtitle{margin-top:10px;font-size:0.95rem;color:#C08070}
.header-line{width:70px;height:2px;margin:16px auto 0;background:linear-gradient(90deg,transparent,#D45161,#E8C56D,transparent)}
.header-badge{
  display:inline-block;padding:5px 16px;border-radius:20px;
  font-size:0.72rem;letter-spacing:2px;margin-bottom:12px;
  background:rgba(212,81,97,0.06);color:#D45161;
  border:1px solid rgba(212,81,97,0.22)
}
.hero-header{background:linear-gradient(180deg,rgba(255,210,195,0.42) 0%,rgba(255,225,210,0.2) 50%,transparent 100%)}
.result-hd{background:linear-gradient(180deg,rgba(255,200,185,0.35) 0%,rgba(255,215,200,0.15) 50%,transparent 100%)}
.admin-hd{background:linear-gradient(180deg,rgba(210,170,180,0.3) 0%,rgba(220,185,195,0.12) 50%,transparent 100%)}

/* ====== Container ====== */
.container{max-width:840px;margin:0 auto;padding:0 24px 100px;position:relative;z-index:1}

/* ====== Token Page ====== */
.token-page{display:flex;justify-content:center;align-items:center;min-height:80vh;padding:20px}
.token-card{padding:64px 48px;text-align:center;max-width:460px;width:100%;border-radius:28px}
.token-ring{position:relative;width:108px;height:108px;margin:0 auto 30px}
.ring-outer{
  position:absolute;inset:-5px;border-radius:50%;
  border:2.5px solid transparent;
  border-top-color:rgba(212,81,97,0.55);border-right-color:rgba(232,197,109,0.55);
  animation:spin 3.5s linear infinite
}
.ring-inner{
  position:absolute;inset:0;border-radius:50%;
  background:rgba(255,250,246,0.92);
  display:flex;align-items:center;justify-content:center;font-size:2.8rem;
  box-shadow:0 0 40px rgba(212,81,97,0.1)
}
@keyframes spin{to{transform:rotate(360deg)}}
.gradient-text{
  background:linear-gradient(135deg,#D45161,#E8837A,#E8C56D);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;font-size:1.4rem
}
.token-card p{color:#8B6F75;font-size:0.92rem;margin-bottom:28px}
.token-row{display:flex;gap:12px}
.glow-input{
  flex:1;padding:15px 20px;border-radius:14px;font-size:1rem;font-family:inherit;
  background:rgba(255,248,244,0.9);border:2px solid rgba(212,81,97,0.18);
  color:#4A3035;outline:none;transition:all 0.35s
}
.glow-input:focus{
  border-color:rgba(212,81,97,0.5);
  box-shadow:0 0 30px rgba(232,131,122,0.18),0 0 0 5px rgba(232,131,122,0.04)
}
.glow-input::placeholder{color:rgba(180,130,130,0.3)}

/* ====== Stats ====== */
.stats-bar{display:flex;gap:14px;margin:0 0 24px;position:relative;z-index:2}
.stat{
  flex:1;text-align:center;padding:26px 18px;border-radius:18px;
  position:relative;overflow:hidden;
  background:rgba(255,248,244,0.85);border:1px solid rgba(255,220,210,0.5);
  box-shadow:0 6px 28px rgba(180,120,110,0.06)
}
.stat-ring{position:absolute;inset:4px;border-radius:14px;border:1.5px solid transparent;pointer-events:none}
.male-ring{border-left-color:rgba(100,181,246,0.3);border-bottom-color:rgba(100,181,246,0.12)}
.female-ring{border-left-color:rgba(240,98,146,0.3);border-bottom-color:rgba(240,98,146,0.12)}
.stat-num{font-size:2.4rem;font-weight:700;display:block}
.male-stat .stat-num{color:#42A5F5;text-shadow:0 0 24px rgba(66,165,245,0.22)}
.female-stat .stat-num{color:#EC407A;text-shadow:0 0 24px rgba(236,64,122,0.22)}
.stat-label{font-size:0.8rem;color:#8B6F75;margin-top:6px}

/* ====== Section ====== */
.section{margin-top:6px}
.section-hd{
  display:flex;align-items:center;gap:14px;
  padding:20px 4px 14px;font-size:1.1rem;font-weight:700
}
.male-hd{color:#42A5F5}.female-hd{color:#EC407A}
.section-line{flex:1;height:1px;background:linear-gradient(90deg,rgba(180,120,110,0.12),transparent)}

/* ====== User Grid ====== */
.user-grid{display:flex;flex-wrap:wrap;gap:12px}
.user-chip{
  background:rgba(255,250,246,0.82);backdrop-filter:blur(8px);
  border-radius:16px;padding:18px;display:flex;align-items:center;gap:16px;
  border:1.5px solid rgba(255,220,210,0.45);min-width:255px;flex:1;
  transition:all 0.35s;position:relative;overflow:hidden;
  box-shadow:0 3px 18px rgba(180,120,110,0.05)
}
.user-chip::before{
  content:'';position:absolute;top:0;left:0;width:100%;height:100%;
  background:radial-gradient(circle at 50% 0%,rgba(255,255,255,0.5),transparent 65%);
  pointer-events:none
}
.user-chip:hover{
  border-color:rgba(255,200,180,0.7);
  box-shadow:0 14px 44px rgba(180,120,110,0.12),0 0 36px rgba(212,81,97,0.06)
}
.user-chip.male{border-left:3px solid rgba(100,181,246,0.4)}
.user-chip.male:hover{border-left-color:#64B5F6;box-shadow:0 14px 44px rgba(180,120,110,0.12),0 0 36px rgba(100,181,246,0.12)}
.user-chip.female{border-left:3px solid rgba(240,98,146,0.4)}
.user-chip.female:hover{border-left-color:#F06292;box-shadow:0 14px 44px rgba(180,120,110,0.12),0 0 36px rgba(240,98,146,0.12)}
.chip-photo{
  width:60px;height:60px;border-radius:50%;object-fit:cover;
  border:2.5px solid rgba(232,197,109,0.5);flex-shrink:0
}
.chip-photo-ph{
  width:60px;height:60px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:30px
}
.chip-photo-ph.m{background:rgba(100,181,246,0.15);color:#42A5F5}
.chip-photo-ph.f{background:rgba(240,98,146,0.15);color:#EC407A}
.chip-body{flex:1;min-width:0}
.chip-name{font-weight:700;font-size:0.98rem;color:#4A3035}
.chip-age{font-size:0.74rem;color:#8B6F75;font-weight:400}
.chip-bazi{font-size:0.72rem;color:#C0A095;margin:4px 0}
.chip-detail{font-size:0.72rem;color:#6D5555;line-height:1.5}
.chip-phone{font-size:0.74rem;color:#D45161}

/* ====== Divider ====== */
.divider{display:flex;align-items:center;padding:26px 0}
.div-line{flex:1;height:1.5px;background:linear-gradient(90deg,transparent,rgba(232,197,109,0.35),transparent)}
.div-pulse{font-size:1.3rem;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}

/* ====== Bottom ====== */
.bottom-bar{display:flex;flex-direction:column;gap:14px;padding:32px 0}
.back-btn{width:100%;margin-top:24px}

/* ====== Card ====== */
.card{border-radius:18px;padding:24px 28px;margin-top:18px}
.card h3{font-size:1rem;color:#4A3035;margin-bottom:16px}
.row-inline{display:flex;gap:12px;align-items:center}
.row-inline input{
  flex:1;padding:13px 18px;border-radius:12px;font-size:0.92rem;font-family:inherit;
  background:rgba(255,248,244,0.9);border:2px solid rgba(212,81,97,0.16);
  color:#4A3035;outline:none;transition:all 0.35s
}
.row-inline input:focus{border-color:rgba(212,81,97,0.45);box-shadow:0 0 24px rgba(232,131,122,0.14)}

/* ====== Form ====== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:5px}
.fg.fw{grid-column:1/-1}
.fg label{font-size:0.8rem;font-weight:600;color:#5D4037}
.fg input,.fg select,.fg textarea{
  padding:11px 15px;border-radius:12px;font-size:0.9rem;font-family:inherit;
  background:rgba(255,248,244,0.9);border:2px solid rgba(180,120,110,0.12);
  color:#4A3035;outline:none;transition:all 0.35s
}
.fg input:focus,.fg select:focus,.fg textarea:focus{
  border-color:rgba(212,81,97,0.4);box-shadow:0 0 18px rgba(232,131,122,0.1)
}
.fg textarea{resize:vertical;min-height:58px}
.fg select{background:rgba(255,250,246,0.95)}
.fg select option{background:#FFF;color:#4A3035}

/* ====== Buttons ====== */
.btn{
  padding:13px 26px;font-size:0.92rem;font-weight:600;border-radius:50px;
  cursor:pointer;border:none;transition:all 0.35s;font-family:inherit;
  text-align:center;position:relative;overflow:hidden
}
.btn-primary{
  background:linear-gradient(135deg,#D45161,#E07870);color:#FFF;
  box-shadow:0 5px 22px rgba(212,81,97,0.35)
}
.btn-primary:hover{box-shadow:0 10px 34px rgba(212,81,97,0.5)}
.btn-glow{animation:btnGlow 3s ease-in-out infinite}
@keyframes btnGlow{
  0%,100%{box-shadow:0 5px 22px rgba(212,81,97,0.35)}
  50%{box-shadow:0 5px 38px rgba(212,81,97,0.55),0 0 64px rgba(232,131,122,0.16)}
}
.btn-outline{
  background:transparent;color:#C05060;
  border:2px solid rgba(212,81,97,0.3)
}
.btn-outline:hover{background:rgba(212,81,97,0.04);border-color:rgba(212,81,97,0.6);color:#D45161}
.btn-outline-glow:hover{border-color:rgba(212,81,97,0.55);box-shadow:0 0 28px rgba(212,81,97,0.14)}
.btn-sm{padding:9px 20px;font-size:0.82rem}
.btn-row{display:flex;gap:12px;flex-wrap:wrap}

/* ====== Lock Badge (大幅增强) ====== */
.lock-badge{display:inline-flex;align-items:center;font-size:0.8rem;cursor:default}
.lock-badge.locked{
  background:linear-gradient(135deg,#43A047,#66BB6A);color:#FFF;
  padding:2px 10px;border-radius:14px;font-size:0.68rem;font-weight:600;
  box-shadow:0 0 16px rgba(76,175,80,0.45),inset 0 1px 0 rgba(255,255,255,0.3);
  animation:lockPulse 2.5s ease-in-out infinite
}
@keyframes lockPulse{
  0%,100%{box-shadow:0 0 16px rgba(76,175,80,0.45)}
  50%{box-shadow:0 0 28px rgba(76,175,80,0.7),0 0 40px rgba(76,175,80,0.2)}
}
.lock-badge.unlocked{color:#CCC;font-size:0.75rem;opacity:0.4}

/* 已锁定卡片整体光晕 */
.chip-locked{
  border:2px solid rgba(76,175,80,0.5) !important;
  box-shadow:0 0 24px rgba(76,175,80,0.15),0 4px 20px rgba(180,120,110,0.08) !important;
  background:rgba(245,255,245,0.6) !important
}
.chip-locked::after{
  content:'';position:absolute;top:0;right:0;width:60px;height:60px;
  background:radial-gradient(circle,rgba(76,175,80,0.08),transparent 70%);
  pointer-events:none
}

/* ====== Admin ====== */
.admin-chip{
  background:rgba(255,250,246,0.82);backdrop-filter:blur(8px);
  border-radius:16px;padding:20px;margin-bottom:12px;
  display:flex;align-items:flex-start;gap:16px;
  border:1.5px solid rgba(255,220,210,0.45);position:relative;
  transition:all 0.35s;box-shadow:0 3px 18px rgba(180,120,110,0.05)
}
.admin-chip:hover{border-color:rgba(212,81,97,0.2);box-shadow:0 10px 34px rgba(180,120,110,0.12)}
.admin-chip .del-btn{
  position:absolute;top:10px;right:10px;z-index:2;
  width:32px;height:32px;border-radius:50%;
  background:rgba(198,40,40,0.08);border:1px solid rgba(198,40,40,0.22);
  color:#E53935;font-size:17px;font-weight:700;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.25s
}
.admin-chip .del-btn:hover{background:rgba(198,40,40,0.2);box-shadow:0 0 22px rgba(198,40,40,0.25);transform:scale(1.1)}

/* ====== Modal ====== */
.modal{display:none;position:fixed;inset:0;background:rgba(60,20,20,0.25);backdrop-filter:blur(5px);z-index:200;justify-content:center;align-items:center}
.modal.active{display:flex;animation:fadeIn 0.3s ease}
.modal-box{border-radius:24px;padding:38px;width:420px;max-width:90vw}
.modal-box h3{margin-bottom:22px;font-size:1.15rem}
.modal-box input{
  width:100%;padding:15px 20px;border-radius:14px;font-size:1rem;font-family:inherit;
  background:rgba(255,248,244,0.9);border:2px solid rgba(212,81,97,0.18);
  color:#4A3035;outline:none;transition:all 0.35s
}
.modal-box input:focus{border-color:rgba(212,81,97,0.5);box-shadow:0 0 28px rgba(232,131,122,0.15)}
.modal-btns{display:flex;gap:12px;margin-top:22px}
.modal-btns .btn{flex:1}

/* ====== Empty ====== */
.empty-box{text-align:center;padding:70px 20px;color:#8B6F75}
.empty-icon{font-size:4rem;margin-bottom:14px;opacity:0.45}

/* ====== Match Cards ====== */
.match-card{
  background:rgba(255,250,246,0.82);backdrop-filter:blur(8px);
  border-radius:18px;padding:32px;margin-bottom:20px;
  text-align:center;border:1.5px solid rgba(255,220,210,0.45);
  box-shadow:0 4px 24px rgba(180,120,110,0.06);transition:all 0.35s
}
.match-card:hover{border-color:rgba(212,81,97,0.2);box-shadow:0 14px 44px rgba(180,120,110,0.14)}
.score-badge{
  display:inline-flex;align-items:baseline;gap:4px;
  padding:11px 36px;border-radius:50px;color:#FFF;
  font-size:2.4rem;font-weight:700;margin-bottom:20px;
  box-shadow:0 10px 34px rgba(0,0,0,0.2)
}
.score-unit{font-size:1rem;opacity:0.85}
.couple{display:flex;align-items:center;justify-content:center;gap:24px;margin-bottom:22px}
.person-info{text-align:center;flex:1}
.person-info img{
  width:80px;height:80px;border-radius:50%;object-fit:cover;
  border:3px solid rgba(232,197,109,0.45)
}
.person-info .name{font-weight:700;margin-top:10px;font-size:1rem;color:#4A3035}
.person-info .bazi{font-size:0.74rem;color:#8B6F75;margin-top:4px}
.heart{font-size:1.8rem;flex-shrink:0;animation:pulse 1.5s ease-in-out infinite}
.analysis-box{
  font-size:0.88rem;color:#5D4037;line-height:2;
  padding:18px;background:rgba(255,245,240,0.55);border-radius:14px;
  border-left:3px solid rgba(232,197,109,0.55);text-align:left
}

/* ====== Utilities ====== */
.hint{font-size:0.78rem;color:#8B6F75;margin-top:10px}
.error-msg{color:#E53935;font-size:0.86rem;margin-top:12px;min-height:22px}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(180,120,110,0.2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(180,120,110,0.35)}
::selection{background:rgba(212,81,97,0.15);color:#4A3035}

@media(max-width:600px){
  .form-grid{grid-template-columns:1fr}
  .header h1{font-size:1.5rem}
  .token-card{padding:40px 24px}
  .couple{flex-direction:column}
  .user-chip{min-width:100%}
}
