:root{
  --bg:#0D0D1A; --card:#1A1A2E; --glass:rgba(255,255,255,.05);
  --txt:#fff; --txt2:#B0B3C0; --txt3:#6B6F80; --accent:#FFD166;
  --cta:#7C5CFC; --rec:#FF4757; --ok:#2ED573; --link:#5B9DFF;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}
html,body{background:var(--bg);color:var(--txt);
  font-family:-apple-system,BlinkMacSystemFont,"PingFang SC","Microsoft YaHei",sans-serif}
#app{max-width:480px;margin:0 auto;min-height:100vh;position:relative;overflow-x:hidden;
  background:radial-gradient(120% 60% at 50% 0,#1b1b3a 0,#0D0D1A 60%)}
img{max-width:100%}

/* NavBar */
.navbar{height:44px;display:flex;align-items:center;justify-content:space-between;padding:0 12px;
  position:sticky;top:0;z-index:20;background:transparent}
.nav-back{background:none;border:none;color:#fff;font-size:30px;line-height:1;width:36px}
.nav-title{font-size:16px;font-weight:600}
.nav-right{width:36px}

/* Screens */
.screen{display:none;padding:8px 24px 40px;animation:fade .35s ease}
.screen.is-active{display:block}
@keyframes fade{from{opacity:0}to{opacity:1}}

/* 录音页 */
.star-deco{text-align:center;color:var(--accent);font-size:26px;margin-top:24px;animation:float 3s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.rec-title{text-align:center;font-size:24px;font-weight:700;margin-top:22px}
.rec-sub{text-align:center;color:var(--txt2);font-size:14px;margin-top:8px}
.rec-center{position:relative;width:200px;height:200px;margin:44px auto 8px;display:flex;align-items:center;justify-content:center}
.wave{position:absolute;inset:0;pointer-events:none}
.rec-btn{width:120px;height:120px;border-radius:50%;border:2px solid var(--cta);
  background:rgba(124,92,252,.15);display:flex;align-items:center;justify-content:center;
  transition:transform .18s ease,background .18s ease;touch-action:none}
.rec-btn.recording{background:var(--rec);border-color:var(--rec);transform:scale(1.08);
  box-shadow:0 0 34px rgba(255,71,87,.45);animation:pulse 1.4s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 22px rgba(255,71,87,.4)}50%{box-shadow:0 0 40px rgba(255,71,87,.7)}}
.rec-timer{text-align:center;font-size:15px;color:var(--txt);margin-top:14px}
.rec-hint{text-align:center;color:var(--accent);font-size:13px;min-height:18px;margin-top:6px}

/* 分析页 */
#screen-analyzing{text-align:center;padding-top:70px}
.orbit{width:160px;height:160px;margin:0 auto;position:relative}
.orbit-ring{position:absolute;inset:0;border-radius:50%;border:1px dashed rgba(124,92,252,.4);
  display:flex;align-items:center;justify-content:center;color:var(--txt3);font-size:13px;
  letter-spacing:2px;animation:spin 8s linear infinite;overflow:hidden;word-break:break-all;padding:10px}
@keyframes spin{to{transform:rotate(360deg)}}
.orbit-core{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:34px;
  filter:drop-shadow(0 0 12px var(--cta))}
.an-step{margin-top:34px;color:var(--txt2);font-size:15px;min-height:20px}
.an-bar{width:280px;height:4px;border-radius:2px;background:rgba(255,255,255,.1);margin:18px auto;overflow:hidden}
.an-bar i{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--cta),var(--accent));transition:width .4s ease}

/* 报告页 */
.rp-badge{margin:14px auto 0;width:max-content;padding:8px 22px;border-radius:22px;font-size:22px;font-weight:700;
  color:#1a1330;background:linear-gradient(135deg,var(--accent),#ffb347);box-shadow:0 6px 20px rgba(255,209,102,.3);
  animation:pop .35s cubic-bezier(.2,.8,.2,1.2)}
@keyframes pop{from{transform:scale(.4);opacity:0}to{transform:scale(1);opacity:1}}
.rp-slogan{text-align:center;color:var(--accent);font-size:14px;margin:10px 0 16px}
.card{background:var(--card);border-radius:16px;padding:18px;margin-bottom:16px;border:1px solid rgba(255,255,255,.06)}
.glass{background:var(--glass);backdrop-filter:blur(10px)}
.rp-desc{font-size:15px;line-height:1.7;color:#e7e8f0}
.sec-t{font-size:16px;font-weight:600;margin-bottom:12px}
.dims{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.dim{font-size:12px;color:var(--txt2);background:rgba(124,92,252,.14);border:1px solid rgba(124,92,252,.3);
  padding:4px 10px;border-radius:8px}
.dim b{color:#fff;font-weight:600}
.room{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.06);border-radius:12px;
  padding:12px 14px;margin-top:8px}
.room .rn{flex:1;min-width:0;font-size:15px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.room .on{font-size:12px;color:var(--ok)}
.room .on.mid{color:var(--accent)}
.room .go{color:var(--link);font-size:18px}
.motto{text-align:center;color:var(--accent);font-style:italic;font-size:16px;position:relative}
.motto .quote{font-size:34px;opacity:.3;margin-right:4px;vertical-align:-8px}

/* 按钮 */
.btn-row{display:flex;gap:12px;margin-top:8px}
.btn{flex:1;height:48px;border-radius:24px;border:none;font-size:16px;font-weight:600;color:#fff;
  background:var(--cta);box-shadow:0 6px 18px rgba(124,92,252,.35)}
.btn.primary{background:linear-gradient(135deg,var(--cta),#a58bff)}
.btn.ghost{background:rgba(255,255,255,.08);color:var(--txt2);box-shadow:none}
.btn.text{background:none;box-shadow:none;color:var(--txt3);height:38px;font-weight:400}
.btn:active{transform:scale(.97)}

/* 星座卡 */
.cardwrap{display:flex;justify-content:center;margin:8px 0 16px}
.voicecard{position:relative;width:330px;height:587px;border-radius:20px;overflow:hidden;
  background:#111;box-shadow:0 12px 40px rgba(0,0,0,.5)}
.vc-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.vc-top{position:absolute;top:34px;left:0;right:0;text-align:center;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.vc-name{font-size:30px;font-weight:800;color:#fff}
.vc-slogan{font-size:13px;color:#ffe9b0;margin-top:8px}
.vc-radar{position:absolute;top:158px;left:50%;transform:translateX(-50%)}
.vc-motto{position:absolute;bottom:126px;left:22px;right:22px;text-align:center;color:#fff;
  font-size:14px;line-height:1.5;font-style:italic;text-shadow:0 2px 10px rgba(0,0,0,.85)}
.vc-bottom{position:absolute;bottom:32px;left:20px;right:20px;display:flex;align-items:center;gap:10px}
.vc-nick{flex:1;min-width:0;font-size:13px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-shadow:0 1px 6px #000}
.vc-qr{width:56px;height:56px;background:#fff;border-radius:6px;padding:3px;flex:none}
.vc-qr img,.vc-qr canvas{width:100%!important;height:100%!important;display:block}
.vc-brand{position:absolute;bottom:12px;left:0;right:0;text-align:center;font-size:10px;color:rgba(255,255,255,.6)}
.save-tip{text-align:center;color:var(--txt3);font-size:12px;margin-top:12px;min-height:16px}

/* 弹窗 / toast */
.modal-mask{position:fixed;inset:0;background:rgba(0,0,0,.6);display:none;align-items:center;justify-content:center;z-index:50;padding:32px}
.modal-mask.show{display:flex}
.modal{background:#1c1c34;border-radius:18px;padding:26px 22px;max-width:320px;text-align:center;border:1px solid rgba(255,255,255,.08)}
.modal-ico{font-size:38px;margin-bottom:10px}
.modal h3{font-size:18px;margin-bottom:10px}
.modal p{font-size:14px;color:var(--txt2);line-height:1.6;margin-bottom:18px}
.modal p b{color:var(--accent)}
.modal .btn{width:100%}
.toast{position:fixed;left:50%;bottom:90px;transform:translateX(-50%);background:rgba(0,0,0,.85);
  color:#fff;padding:10px 18px;border-radius:22px;font-size:14px;opacity:0;pointer-events:none;
  transition:opacity .25s;z-index:60;max-width:80%;text-align:center}
.toast.show{opacity:1}

/* 落地页 */
.landing{padding:8px 24px 40px;text-align:center}
.ld-card img{width:78%;border-radius:16px;box-shadow:0 10px 34px rgba(0,0,0,.5);margin:10px 0}
.ld-name{font-size:24px;font-weight:700;margin-top:8px}
.ld-motto{color:var(--accent);font-style:italic;font-size:15px;margin:10px 0 4px}
.ld-cta{margin-top:26px}
.ld-dl{margin-top:16px;display:flex;gap:12px;justify-content:center}
.ld-dl a{flex:1;max-width:160px;height:46px;line-height:46px;border-radius:23px;background:rgba(255,255,255,.1);
  color:#fff;text-decoration:none;font-size:14px}
.ld-expired{padding-top:80px;color:var(--txt2)}
