/* === app.css — Felix Design System v5 ===
   灵感: Linear · Reflect · Day One · Things
   原则: 手写字体 · 深棕基色 · 模块专属色 · 暗色完整 · 交互流畅 */

/* ============================================================
   Design Tokens
   ============================================================ */
:root {
  /* Brand — 暖珊瑚色 温暖而有活力 */
  --p:  #E8755A;
  --pd: #D15C3F;
  --pl: #FDE8E2;
  --pb: #FFF5F2;

  /* Module Accents — 四模块专属色 */
  --ma-invest:    #D97706;  /* 琥珀金 — 财富 */
  --ma-life:      #D97706;  /* 琥珀黄 — 成长 */
  --ma-rel:       #0284C7;  /* 天蓝 — 连接 */
  --ma-knowledge: #92400E;  /* 深棕 — 智慧 */

  /* Semantic */
  --success: #059669;
  --warning: #D97706;
  --danger:  #DC2626;
  --info:    #92400E;

  /* Text — 深棕色阶 */
  --t1: #3E2723;
  --t2: #6D4C41;
  --t3: #8D6E63;

  /* Surfaces — 暖白底色 */
  --bg: #FBF9F7;
  --ca: #FFFFFF;
  --ch: #F5F2F0;
  --bd: #E7E5E4;

  /* Shadows — 柔和投影 */
  --sh:    0 1px 2px rgba(62,39,35,.06);
  --sh-md: 0 4px 12px rgba(62,39,35,.08);
  --sh-lg: 0 8px 24px rgba(62,39,35,.10);

  /* Radii */
  --r8: 8px; --r10: 10px; --r12: 12px; --r16: 16px; --r20: 20px;

  /* Safe areas */
  --st: env(safe-area-inset-top, 0);
  --sb: env(safe-area-inset-bottom, 0);
}

/* ============================================================
   Dark Mode
   ============================================================ */
@media (prefers-color-scheme: dark) {
  :root {
    --p:  #F0856A;
    --pd: #E07055;
    --pl: rgba(232,117,90,.15);
    --pb: #1C1512;

    --ma-invest:    #F59E0B;
    --ma-life:      #F59E0B;
    --ma-rel:       #0EA5E9;
    --ma-knowledge: #B45309;

    --success: #34D399;
    --warning: #FBBF24;
    --danger:  #F87171;
    --info:    #B45309;

    --t1: #EFEBE9;
    --t2: #A1887F;
    --t3: #8D6E63;

    --bg: #0C0A09;
    --ca: #1C1917;
    --ch: #292524;
    --bd: #292524;

    --sh:    0 1px 2px rgba(0,0,0,.20);
    --sh-md: 0 4px 12px rgba(0,0,0,.30);
    --sh-lg: 0 8px 24px rgba(0,0,0,.40);
  }
}

/* ============================================================
   Reset & Body
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Ma+Shan+Zheng&display=swap');
/* Ma Shan Zheng — SIL Open Font License 1.1 (free commercial use) */

*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:'Ma Shan Zheng','KaiTi','STKaiti','楷体',cursive,sans-serif;
  background:var(--bg);color:var(--t1);font-size:16px;line-height:1.7;
  -webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;
  overflow-x:hidden;padding-bottom:calc(64px + var(--sb));
}

/* ============================================================
   Splash Screen
   ============================================================ */
.splash{position:fixed;inset:0;z-index:1000;background:var(--pb);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:48px 32px;transition:opacity .8s,visibility .8s}
.splash.hidden{opacity:0;visibility:hidden;pointer-events:none}
.splash-logo{margin-bottom:48px;animation:splashIn 1s ease both}
.splash-logo img,.splash-logo svg{width:72px;filter:drop-shadow(0 4px 16px rgba(232,117,90,.2))}
.splash-quote{max-width:320px;text-align:center;animation:splashIn 1s ease .35s both}
.splash-text{font-size:21px;color:var(--t1);line-height:2;font-weight:400;margin-bottom:24px;letter-spacing:.03em}
.splash-divider{width:40px;height:1.5px;background:var(--p);margin:0 auto 14px}
.splash-author{font-size:15px;color:var(--pd);font-weight:400;font-style:italic}
@keyframes splashIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   Topbar
   ============================================================ */
.tb{position:sticky;top:0;z-index:100;
  background:rgba(251,249,247,.88);backdrop-filter:blur(16px) saturate(180%);
  display:flex;justify-content:space-between;align-items:center;
  padding:calc(8px+var(--st)) 16px 8px;border-bottom:1px solid var(--bd)}
@media (prefers-color-scheme: dark) {
  .tb{background:rgba(12,10,9,.88)}
}
.tb-l img{height:28px}
.tb-r{display:flex;align-items:center;gap:8px}
.tb-b{background:var(--ch);border:none;padding:4px 10px;border-radius:12px;
  font-size:12px;font-weight:600;color:var(--t2);cursor:pointer}
.tb-u{background:none;border:1px solid var(--bd);width:32px;height:32px;border-radius:50%;
  font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--t2)}
.tb-u.logged-in{background:var(--p);color:#fff;border-color:var(--p)}

/* ============================================================
   Bottom Nav
   ============================================================ */
.tn{position:fixed;bottom:0;left:0;right:0;z-index:100;
  background:rgba(251,249,247,.92);backdrop-filter:blur(16px) saturate(180%);
  display:flex;border-top:1px solid var(--bd);padding-bottom:var(--sb)}
@media (prefers-color-scheme: dark) {
  .tn{background:rgba(12,10,9,.92)}
}
.ti{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:8px 4px 6px;cursor:pointer;color:var(--t3);transition:color .2s}
.ti.ac{color:var(--p)}
.ti-ic{font-size:20px;margin-bottom:2px}
.nav-icon{width:22px;height:22px;display:block;opacity:.45;transition:opacity .2s}
.ti.ac .nav-icon{opacity:1}
.ti-lb{font-size:10px;font-weight:500;white-space:nowrap}

/* ============================================================
   Tab Content
   ============================================================ */
.tc{display:none;padding:12px 16px;animation:fadeIn .25s ease}
.tc.ac{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   Cards
   ============================================================ */
.card{background:var(--ca);border-radius:var(--r12);padding:16px;
  box-shadow:var(--sh);margin-bottom:12px;border:1px solid var(--bd)}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.card-foot{display:flex;justify-content:space-between;align-items:center;margin-top:12px}

/* ============================================================
   Typography
   ============================================================ */
.stt{font-size:16px;font-weight:700;color:var(--t1);margin-bottom:8px}
.sts{font-size:12px;color:var(--t3);margin-bottom:12px}
.stl{font-size:11px;color:var(--t3);margin-bottom:6px}

/* ============================================================
   Buttons
   ============================================================ */
.btn{display:block;width:100%;padding:12px;background:var(--p);color:#fff;
  border:none;border-radius:var(--r10);font-size:15px;font-weight:600;cursor:pointer;
  transition:background .15s,transform .12s,box-shadow .15s;margin-top:12px}
.btn:hover{box-shadow:var(--sh-md)}
.btn:active{background:var(--pd);transform:scale(.98)}
.btn-sm{padding:8px 16px;font-size:13px;width:auto;display:inline-block}
.btn-outline{background:transparent;color:var(--p);border:1.5px solid var(--p)}
.btn-outline:active{background:var(--pl)}
.btn-danger{background:var(--danger)}
.btn-danger:active{background:#B91C1C}

/* ============================================================
   v0.4 Polish — 全局交互增强
   ============================================================ */
/* 卡片悬浮微提 */
.card,.plan-card,.contact-card{transition:box-shadow .2s,transform .15s}
.card:hover,.plan-card:hover,.contact-card:hover{box-shadow:var(--sh-md)}
.card:active{transform:scale(.995)}

/* 全局点击反馈 */
button,a,select,.ti,.chip,.via-quiz-entry,.ia-item,.swipe-card{
  -webkit-tap-highlight-color:transparent;touch-action:manipulation}

/* 可点击元素统一 pointer */
[onclick],.ti,.chip,.more,.rbk,.vtab,.res-tab,.jbtn,.via-quiz-entry{cursor:pointer}

/* 选中/激活态缩放反馈 */
.jbtn:active,.vtab:active,.res-tab:active,.ia-item:active{transform:scale(.97);transition:transform .1s}

/* 列表项点击反馈 */
.dash-item:active,.record-row:active,.career-item:active{background:var(--ch)}

/* Scrollbar 美化 */
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bd);border-radius:2px}
::-webkit-scrollbar-thumb:hover{background:var(--t3)}

/* 卡片间距紧缩 */
.card+.card,.card+.dash-section,.dash-section+.dash-section,.dash-section+.card{margin-top:8px}
.mt12,.card.mt12{margin-top:10px}

/* 表单紧凑优化 */
.fg{margin-bottom:8px}
.fg label.fl{font-size:12px;margin-bottom:3px}
.fi,.fs{padding:9px 12px;font-size:13px}
textarea.fi{min-height:70px}

/* 段落间距 */
.stt{margin-bottom:6px}
.sts{margin-bottom:10px}

/* Text contrast */
.text-center{text-align:center}

/* Stat grid 微调 */
.stat-card{padding:12px 10px}

/* Tab 内容呼吸 */
.tc.ac{padding:10px 14px}

/* 按钮微调 */
.btn{padding:11px;font-size:14px;letter-spacing:.02em}
.btn-sm{padding:7px 14px;font-size:12px}

/* ============================================================
   v0.4 Polish End
   ============================================================ */

/* ============================================================
   Chips & Tags
   ============================================================ */
.chip{display:inline-block;padding:6px 14px;border-radius:16px;font-size:13px;
  font-weight:500;background:var(--ch);color:var(--t2);cursor:pointer;transition:all .15s}
.chip:hover{background:var(--bd)}
.chip.ac{background:var(--p);color:#fff}
.chip-grp{display:flex;flex-wrap:wrap;gap:6px;margin:4px 0}

/* ============================================================
   Form Controls
   ============================================================ */
.fg{margin-bottom:10px}
.fl{display:block;font-size:13px;font-weight:600;color:var(--t2);margin-bottom:4px}
.fi{width:100%;padding:10px 12px;border:1.5px solid var(--bd);border-radius:var(--r8);
  font-size:14px;background:var(--ca);color:var(--t1);transition:border-color .15s,box-shadow .15s}
.fi:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 3px var(--pl)}
.fs{width:100%;padding:10px 12px;border:1.5px solid var(--bd);border-radius:var(--r8);
  font-size:14px;background:var(--ca);color:var(--t1);appearance:none;-webkit-appearance:none;
  cursor:pointer}
.fs:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 3px var(--pl)}
textarea.fi{resize:vertical;min-height:80px;font-family:inherit}
.fr{display:flex;gap:10px}
.fr>*{flex:1}
.pr{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}
.pr s{text-decoration:none;font-size:13px;font-weight:500;color:var(--t2)}
.ps{width:100%;-webkit-appearance:none;height:6px;border-radius:3px;
  background:var(--ch);outline:none;cursor:pointer}
.ps::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;
  border-radius:50%;background:var(--p);cursor:pointer;
  box-shadow:0 1px 3px rgba(232,117,90,.3);transition:transform .12s}
.ps::-webkit-slider-thumb:active{transform:scale(1.15)}

/* ============================================================
   Empty State
   ============================================================ */
.empty-state{padding:40px 20px;text-align:center}
.empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}
.empty-title{font-size:16px;font-weight:600;color:var(--t1);margin-bottom:8px}
.empty-desc{font-size:13px;color:var(--t3);max-width:280px;margin:0 auto 20px;line-height:1.7}
.empty-action .btn{max-width:220px;margin:0 auto}

/* ============================================================
   Stat Cards
   ============================================================ */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.stat-card{background:var(--ca);border-radius:var(--r12);padding:14px;
  box-shadow:var(--sh);text-align:center;border:1px solid var(--bd)}
.stat-value{font-size:22px;font-weight:800;color:var(--t1);font-variant-numeric:tabular-nums}
.stat-value.positive{color:var(--success)}
.stat-value.negative{color:var(--danger)}
.stat-value.accent{color:var(--p)}
.stat-label{font-size:11px;color:var(--t3);margin-top:4px;font-weight:500}

/* ============================================================
   Header
   ============================================================ */
.tb-name{font-size:17px;font-weight:700;color:var(--t1);letter-spacing:-.3px}
.tb-f{height:28px;vertical-align:middle;margin-right:6px}

/* ============================================================
   Investment Module
   ============================================================ */
.plan-card{padding:14px 14px 12px;background:var(--ca);border-radius:var(--r12);
  box-shadow:var(--sh);margin-bottom:8px;border:1px solid var(--bd)}
.plan-card:hover{box-shadow:var(--sh-md)}
.plan-header{cursor:pointer;padding:2px 0}
.plan-header:hover .plan-name{color:var(--p)}
.plan-name{font-size:15px;font-weight:600;color:var(--t1);margin-bottom:4px}
.plan-meta{font-size:12px;color:var(--t2);margin-left:8px}
.plan-summary{padding:4px 0;font-size:12px;color:var(--t2)}
.plan-expanded{margin-top:8px;padding-top:8px;border-top:1px solid var(--bd)}
.plan-actions{display:flex;gap:6px;margin-top:6px;flex-wrap:wrap}
.plan-actions .btn-sm{flex:0 0 auto;padding:5px 12px;font-size:12px;margin-top:0}

/* 编辑器下拉面板 (v7) */
.editor-card{animation:editorSlideIn .3s ease}
@keyframes editorSlideIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
#i-editor{margin-top:12px;margin-bottom:12px}
.dc{font-size:11px;color:var(--t3);text-align:center;margin-top:16px;padding:0 8px}

/* Dual Slider */
.slider-dual{background:var(--ca);border-radius:var(--r12);padding:12px 16px;
  box-shadow:var(--sh);border:1px solid var(--bd)}
.slider-label{display:flex;justify-content:space-between;font-size:14px}

/* Asset Grid */
.ia-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin:8px 0}
.ia-item{padding:10px;border:2px solid var(--bd);border-radius:var(--r10);
  cursor:pointer;transition:all .15s;background:var(--ca);position:relative}
.ia-item:hover{border-color:var(--t3)}
.ia-item:active{transform:scale(.97)}
.ia-item.selected{border-color:var(--p);background:var(--pl)}
.ia-check{position:absolute;top:6px;right:6px;width:18px;height:18px;
  border-radius:50%;border:2px solid var(--bd);transition:all .15s}
.ia-item.selected .ia-check{background:var(--p);border-color:var(--p)}
.ia-item.selected .ia-check::after{content:'';position:absolute;left:4px;top:1px;
  width:6px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.ia-name{font-size:13px;font-weight:600;color:var(--t1);margin-bottom:2px;padding-right:22px}
.ia-desc{font-size:11px;color:var(--t3)}
.ia-param{margin-bottom:4px}

/* ===== v9 Result Panel ===== */
.res-panel{background:var(--ca);border-radius:var(--r12);padding:16px;
  box-shadow:var(--sh);border:1px solid var(--bd);animation:editorSlideIn .3s ease}
.res-tabs{display:flex;gap:0;margin-bottom:12px;border:1px solid var(--bd);border-radius:var(--r8);overflow:hidden}
.res-tab{flex:1;padding:10px 0;border:none;background:transparent;color:var(--t2);
  font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;text-align:center}
.res-tab:first-child{border-right:1px solid var(--bd)}
.res-tab.active{background:var(--p);color:#fff}
.res-tab:not(.active):hover{background:var(--ch)}

/* Actual Value Grid */
.act-grid{max-height:280px;overflow-y:auto;margin-bottom:8px}
.act-row{display:flex;align-items:center;gap:8px;padding:6px 8px;
  border-radius:var(--r6);margin-bottom:2px;transition:background .15s}
.act-row:hover{background:var(--ch)}
.act-row.has-val{background:rgba(5,150,105,.05)}
.act-yr{font-size:12px;font-weight:600;color:var(--t2);width:48px;text-align:right;flex-shrink:0}
.act-inp{flex:1;padding:6px 10px;border:1.5px solid var(--bd);border-radius:var(--r6);
  font-size:13px;background:var(--ca);color:var(--t1);font-variant-numeric:tabular-nums;text-align:right}
.act-inp:focus{outline:none;border-color:var(--p);box-shadow:0 0 0 3px var(--pl)}
.act-unit{font-size:12px;color:var(--t3);width:16px;text-align:left;flex-shrink:0}

/* 按标的的实际值录入 */
.act-asset{margin-bottom:10px;padding:8px 10px;background:var(--ch);border-radius:var(--r8)}
.act-asset-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.act-asset-head span:first-child{font-size:13px;font-weight:600;color:var(--t1)}
.act-sim{font-size:11px;color:var(--t3);width:50px;text-align:right;flex-shrink:0}

/* Chart */
.cw{height:240px;margin:12px 0}
.yr{width:100%;margin-top:8px;-webkit-appearance:none;height:4px;background:var(--ch);border-radius:2px}
.yr::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;
  border-radius:50%;background:var(--p);cursor:pointer}
.yh{display:flex;justify-content:space-between;font-size:11px;color:var(--t3)}

/* View Tabs */
.vt{display:flex;gap:6px;margin-bottom:12px}
.vtab{padding:6px 14px;border:1.5px solid var(--bd);border-radius:16px;font-size:12px;
  font-weight:500;background:transparent;color:var(--t2);cursor:pointer;transition:all .15s}
.vtab:hover{border-color:var(--p);color:var(--p)}
.vtab.ac{background:var(--p);color:#fff;border-color:var(--p)}
.rbk{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;
  background:var(--ch);border-radius:20px;font-size:14px;color:var(--t2);
  cursor:pointer;font-weight:500;border:1px solid var(--bd);margin-bottom:12px;
  transition:all .2s}
.rbk:hover{background:var(--bd);color:var(--t1)}
.rbk:active{transform:scale(.97)}

/* 联系人资料卡 */
.contact-header{text-align:center;padding:20px 0 16px}
.contact-avatar{width:64px;height:64px;border-radius:50%;background:var(--ch);
  display:flex;align-items:center;justify-content:center;margin:0 auto 12px;
  font-size:32px;color:var(--t3);border:2px solid var(--bd)}
.contact-name{font-size:20px;font-weight:700;color:var(--t1);margin-bottom:4px}
.contact-type{display:inline-block;padding:3px 12px;border-radius:12px;font-size:12px;
  font-weight:500}
.contact-type.friend{background:rgba(2,132,199,.08);color:var(--ma-rel)}
.contact-type.client{background:rgba(217,119,6,.08);color:var(--ma-invest)}
.contact-type.family{background:rgba(5,150,105,.08);color:var(--success)}

/* 关系模块 section 卡 */
.rel-section{margin-top:12px;background:var(--ca);border-radius:var(--r12);
  padding:16px;border:1px solid var(--bd)}
.rel-section h3{font-size:14px;font-weight:600;color:var(--t2);margin-bottom:10px;
  display:flex;justify-content:space-between;align-items:center}
.rel-section h3 .section-action{font-size:12px;color:var(--p);cursor:pointer;font-weight:500}
.rel-section h3 .section-action:hover{text-decoration:underline}

/* 联系人列表卡片增强 */
.contact-card{padding:14px 16px;background:var(--ca);border-radius:var(--r12);
  border:1px solid var(--bd);margin-bottom:8px;cursor:pointer;transition:all .2s}
.contact-card:hover{box-shadow:var(--sh-md);border-color:var(--p)}
.contact-card .contact-name-sm{font-size:15px;font-weight:600;color:var(--t1)}
.contact-card .contact-meta{font-size:12px;color:var(--t3);margin-top:2px}
.contact-card .contact-right{text-align:right;flex-shrink:0}

/* 右滑删除 */
.swipe-wrapper{position:relative;overflow:hidden;margin-bottom:8px;border-radius:var(--r12)}
.swipe-delete{position:absolute;right:0;top:0;bottom:0;width:75px;
  background:var(--danger);color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:600;border-radius:0 var(--r12) var(--r12) 0;z-index:2;
  cursor:pointer;user-select:none}
.swipe-delete:active{opacity:.8}
.swipe-card{position:relative;z-index:3;background:var(--ca);
  transition:transform .25s ease;touch-action:pan-y}

@media (prefers-color-scheme:dark){
  .contact-card:hover{border-color:var(--ma-rel)}
}

/* ============================================================
   Life Module
   ============================================================ */
.jb{display:flex;gap:8px;margin-bottom:12px}
.jbtn{flex:1;padding:10px;border:2px solid var(--bd);border-radius:var(--r12);
  font-size:14px;font-weight:600;cursor:pointer;text-align:left;
  transition:all .15s;background:transparent;color:var(--t2)}
.jbtn.ac.pr{border-color:var(--ma-invest);background:rgba(217,119,6,.06);color:var(--ma-invest)}
.jbtn.ac.fr{border-color:var(--ma-life);background:rgba(217,119,6,.06);color:var(--ma-life)}
.je{position:relative;padding:12px 16px;margin-bottom:8px;background:var(--ca);
  border-radius:var(--r8);box-shadow:var(--sh);overflow:hidden;border:1px solid var(--bd)}
.je::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px}
.je.proud::before{background:var(--ma-invest)}
.je.frustrated::before{background:var(--ma-life)}
.jd{font-size:11px;color:var(--t3);margin-bottom:4px}
.jt{font-size:14px;color:var(--t1);line-height:1.6;word-break:break-word}

/* Compact Entry (近一周) */
.je-compact{display:flex;align-items:center;gap:6px;padding:6px 8px;margin-bottom:3px;
  background:var(--ch);border-radius:var(--r6);font-size:12px;border-left:3px solid transparent}
.je-compact.proud{border-left-color:var(--ma-invest)}
.je-compact.frustrated{border-left-color:var(--ma-life)}
.jec-type{font-size:14px;flex-shrink:0}
.jec-date{font-size:10px;color:var(--t3);flex-shrink:0;min-width:42px}
.jec-text{flex:1;color:var(--t1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Month Grid */
.month-grid{display:flex;flex-direction:column;gap:3px;margin:4px 0}
.month-cell{display:flex;align-items:center;gap:8px;padding:4px 8px;
  background:var(--ch);border-radius:var(--r6);cursor:pointer;transition:background .15s}
.month-cell:hover{background:var(--bd)}
.mc-label{font-size:11px;color:var(--t2);font-weight:600;min-width:52px}
.mc-bar{flex:1;height:6px;background:var(--bd);border-radius:3px;overflow:hidden}
.mc-fill{height:100%;border-radius:3px;transition:width .3s}
.mc-num{font-size:10px;color:var(--t3);min-width:24px;text-align:right}

/* Dual Row Layout */
.dual-row{display:flex;gap:8px;margin-top:12px}
.dual-card{flex:1;min-width:0;padding:10px;background:var(--ca);
  border-radius:var(--r10);box-shadow:var(--sh);border:1px solid var(--bd)}

/* Mood Tracker */
.mood-row{display:flex;gap:6px;margin-bottom:12px}
.mood-item{flex:1;text-align:center;padding:10px 4px;border:2px solid var(--bd);
  border-radius:var(--r12);cursor:pointer;transition:all .15s;background:transparent}
.mood-item:hover{border-color:var(--t3)}
.mood-item .mood-icon{font-size:24px;display:block;margin-bottom:4px}
.mood-item .mood-label{font-size:11px;color:var(--t2);font-weight:500}
.mood-item.ac{border-color:var(--p);background:var(--pl)}

/* Streak Badge */
.streak-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;
  background:var(--pl);border-radius:12px;font-size:12px;font-weight:600;
  color:var(--p);margin-bottom:12px}

/* ============================================================
   Relationship Module
   ============================================================ */
.rba{display:inline-block;padding:2px 8px;background:rgba(2,132,199,.1);
  color:var(--success);border-radius:10px;font-size:11px;font-weight:600;margin-top:4px}
.rba.urgent{background:rgba(220,38,38,.1);color:var(--danger)}
.ht{display:flex;flex-wrap:wrap;gap:6px;margin:8px 0}
.htg{padding:4px 10px;background:var(--ch);border-radius:10px;font-size:12px;color:var(--t2)}
.ri{padding:10px 12px;border-left:2px solid var(--bd);margin-bottom:6px;font-size:13px}
.rid{font-size:11px;color:var(--t3);margin-bottom:4px}
.rc-wrap{margin-top:12px}
.rc-wrap h3{font-size:14px;font-weight:600;color:var(--t2);margin-bottom:8px}
.health-badge{padding:6px 12px;border-radius:12px;font-size:12px;font-weight:600;display:inline-block}
.health-good{background:rgba(2,132,199,.12);color:var(--success)}
.health-warn{background:rgba(217,119,6,.12);color:var(--warning)}
.health-poor{background:rgba(220,38,38,.1);color:var(--danger)}

/* ============================================================
   Knowledge Module
   ============================================================ */
/* 表单美化 */
.form-hero{text-align:center;padding:20px 16px;margin-bottom:16px}
.form-hero-icon{font-size:40px;margin-bottom:8px}
.form-hero-title{font-size:18px;font-weight:700;color:var(--t1);margin-bottom:4px}
.form-hero-desc{font-size:13px;color:var(--t3)}
.fg-title{font-size:12px;font-weight:600;color:var(--ma-knowledge);text-transform:uppercase;
  letter-spacing:.5px;margin:16px 0 8px;padding-left:2px}

/* 状态药丸选择器 */
.status-pills{display:flex;gap:8px;margin-top:4px}
.status-pill{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;
  padding:12px 8px;background:var(--pb);border:2px solid var(--bd);border-radius:var(--r12);
  cursor:pointer;transition:all .18s}
.status-pill:hover{border-color:var(--ma-knowledge);background:rgba(146,64,14,.04)}
.status-pill.active{border-color:var(--ma-knowledge);background:rgba(146,64,14,.1);
  box-shadow:0 0 0 2px rgba(146,64,14,.15)}
.status-pill .pill-icon{font-size:22px}
.status-pill .pill-text{font-size:12px;font-weight:600;color:var(--t2)}
.status-pill.active .pill-text{color:var(--ma-knowledge)}

/* 书籍卡片 */
.book-card{display:flex;gap:12px;padding:12px;background:var(--ca);
  border-radius:var(--r12);box-shadow:var(--sh);margin-bottom:8px;
  align-items:flex-start;border:1px solid var(--bd);transition:box-shadow .15s}
.book-card:hover{box-shadow:var(--sh-md)}
.book-status{font-size:20px;flex-shrink:0;width:32px;text-align:center}
.book-info{flex:1;min-width:0}
.book-title{font-size:14px;font-weight:600;color:var(--t1);margin-bottom:2px}
.book-author{font-size:12px;color:var(--t2);margin-bottom:4px}
.book-progress{font-size:11px;color:var(--p);font-weight:500}
.book-note{font-size:12px;color:var(--t2);margin-top:4px;border-left:2px solid var(--p);
  padding-left:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.note-count{display:inline-block;margin-left:8px;font-size:10px;background:var(--ma-knowledge);
  color:#fff;padding:1px 6px;border-radius:8px;font-weight:600;vertical-align:middle}
.status-badge{padding:2px 8px;border-radius:8px;font-size:10px;font-weight:600}
.status-want{background:rgba(217,119,6,.1);color:var(--warning)}
.status-reading{background:rgba(146,64,14,.1);color:var(--info)}
.status-done{background:rgba(5,150,105,.1);color:var(--success)}

/* 最新笔记高亮 */
.note-latest{margin-top:12px;padding:12px;background:rgba(146,64,14,.06);border-radius:var(--r8);
  border-left:3px solid var(--ma-knowledge)}
.note-latest-label{font-size:11px;color:var(--ma-knowledge);font-weight:600;margin-bottom:6px}
.note-latest-text{font-size:13px;color:var(--t1);line-height:1.7}

/* 笔记头部 */
.note-header{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.note-header-count{font-size:13px;color:var(--t2);font-weight:500}

/* 添加笔记区域 */
.note-add-area{margin-top:12px;padding:12px;background:var(--pb);border-radius:var(--r8)}
.note-add-area .fi{margin-bottom:0}

/* 笔记展开按钮 */
.note-toggle{display:block;width:100%;margin-top:8px;padding:8px;background:var(--pb);border:none;
  border-radius:var(--r8);font-size:13px;color:var(--ma-knowledge);cursor:pointer;font-weight:500;
  transition:background .15s}
.note-toggle:hover{background:rgba(146,64,14,.1)}

/* 笔记搜索 */
.note-search{width:100%;margin-top:8px;padding:8px 12px;background:var(--input-bg);border:1px solid var(--bd);
  border-radius:var(--r8);font-size:13px;color:var(--t1);outline:none;box-sizing:border-box;
  font-family:inherit}
.note-search:focus{border-color:var(--ma-knowledge);box-shadow:0 0 0 2px rgba(146,64,14,.12)}
.note-search::placeholder{color:var(--t3)}

/* 笔记列表 */
.note-list-container{margin-top:8px}
.note-list{max-height:360px;overflow-y:auto}
.note-item{padding:10px 12px;background:var(--ca);border-radius:var(--r8);margin-bottom:6px;
  border:1px solid var(--bd)}
.note-item-text{font-size:13px;color:var(--t1);line-height:1.6;white-space:pre-wrap}
.note-item-meta{display:flex;justify-content:space-between;align-items:center;margin-top:6px}
.note-date{font-size:11px;color:var(--t3)}
.note-copy{font-size:11px;color:var(--ma-knowledge);background:none;border:none;cursor:pointer;
  padding:2px 6px;border-radius:4px;transition:background .12s}
.note-copy:hover{background:rgba(146,64,14,.08)}
.note-empty{text-align:center;padding:20px;font-size:13px;color:var(--t3)}

/* ============================================================
   Dashboard
   ============================================================ */
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.dash-card{background:var(--ca);border-radius:var(--r12);padding:14px;
  box-shadow:var(--sh);cursor:pointer;transition:transform .12s,box-shadow .15s;
  border:1px solid var(--bd)}
.dash-card:hover{box-shadow:var(--sh-md)}
.dash-card:active{transform:scale(.97)}
.dash-card-icon{font-size:28px;margin-bottom:8px}
.dash-card-title{font-size:11px;color:var(--t3);text-transform:uppercase;
  font-weight:600;margin-bottom:8px;letter-spacing:.5px}
.dash-card-value{font-size:24px;font-weight:800;color:var(--t1);font-variant-numeric:tabular-nums}
.dash-card-sub{font-size:11px;color:var(--t2);margin-top:4px}
.gap-up{background:rgba(5,150,105,.1);color:var(--success)}
.gap-down{background:rgba(220,38,38,.1);color:var(--danger)}
.dash-card .gap-badge{padding:2px 8px;border-radius:8px;font-size:11px;font-weight:600;display:inline-block}

.dash-list{margin-top:12px}
.dash-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--bd)}
.dash-item:last-child{border-bottom:none}
.dash-item-ic{font-size:18px;flex-shrink:0}
.dash-item-tx{flex:1;font-size:13px;color:var(--t1)}
.dash-item-sub{font-size:11px;color:var(--t3)}

.dash-section{margin-bottom:16px}
.dash-section-head{font-size:13px;font-weight:600;color:var(--t2);margin-bottom:8px;
  display:flex;justify-content:space-between;align-items:center}
.dash-section-head .more{font-size:11px;color:var(--p);cursor:pointer;font-weight:500}
.dash-section-head .more:hover{text-decoration:underline}

/* ============================================================
   Auth Panel
   ============================================================ */
.ao{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.45);display:none;
  backdrop-filter:blur(2px)}
.ao.show{display:block}
.ap{position:fixed;bottom:0;left:0;right:0;z-index:201;background:var(--ca);
  border-radius:20px 20px 0 0;padding:24px 20px calc(24px+var(--sb));
  box-shadow:0 -8px 32px rgba(0,0,0,.12);display:none;animation:slideUp .3s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.ao.show+.ap,.ao.show~.ap{display:block}
.at{font-size:18px;font-weight:700;color:var(--t1);margin-bottom:8px;text-align:center}
.as{font-size:13px;color:var(--t3);text-align:center;margin-bottom:20px;line-height:1.6}
.ob{display:flex;flex-direction:column;gap:10px}
.obn{width:100%;padding:14px;border:1.5px solid var(--bd);border-radius:var(--r12);
  font-size:15px;font-weight:600;cursor:pointer;background:var(--ca);color:var(--t1);
  text-align:center;transition:all .15s}
.obn:hover{background:var(--ch)}
.obn:active{transform:scale(.98)}
.obn-wx{background:#07C160;color:#fff;border-color:#07C160}
.obn-gg{border-color:#4285F4;color:#4285F4}
.obn-ap{border-color:var(--t1);color:var(--t1)}
.pn{padding:16px;margin-top:12px;text-align:center;font-size:11px;color:var(--t3);
  line-height:1.6;background:var(--pl);border-radius:var(--r8)}
.pn i{font-size:18px;display:block;margin-bottom:4px}
.pbn{width:100%;padding:14px;border:none;border-bottom:1px solid var(--bd);
  font-size:14px;font-weight:500;cursor:pointer;background:transparent;
  color:var(--t1);text-align:left;transition:background .15s}
.pbn:hover{background:var(--ch)}
.pbn:last-child{border-bottom:none}
.pbn.danger{color:var(--danger)}

/* ============================================================
   Privacy Page
   ============================================================ */
.privacy-page{padding:16px}
.privacy-hero{text-align:center;padding:24px 0;margin-bottom:16px}
.privacy-hero-icon{font-size:48px;margin-bottom:12px}
.privacy-hero-title{font-size:20px;font-weight:700;color:var(--t1);margin-bottom:4px}
.privacy-hero-sub{font-size:13px;color:var(--t2)}
.privacy-block{background:var(--ca);border-radius:var(--r12);padding:16px;
  box-shadow:var(--sh);margin-bottom:12px;border:1px solid var(--bd)}
.privacy-block-icon{font-size:24px;margin-bottom:8px}
.privacy-block-title{font-size:14px;font-weight:600;color:var(--t1);margin-bottom:4px}
.privacy-block-desc{font-size:12px;color:var(--t2);line-height:1.7}
.privacy-triangle{display:flex;justify-content:space-between;align-items:center;
  padding:20px;margin:16px 0;background:var(--ca);border-radius:var(--r16);
  box-shadow:var(--sh);border:1px solid var(--bd)}
.privacy-party{text-align:center;flex:1}
.privacy-party-icon{font-size:32px;margin-bottom:8px;display:block}
.privacy-party-name{font-size:12px;font-weight:600;color:var(--t1);margin-bottom:2px}
.privacy-party-desc{font-size:10px;color:var(--t3)}
.privacy-gap{font-size:20px;color:var(--t3);padding:0 8px}
.privacy-seal{text-align:center;padding:16px;margin-top:12px}
.privacy-seal-icon{font-size:36px;display:block;margin-bottom:8px}
.privacy-seal-text{font-size:14px;font-weight:700;color:var(--success)}

/* ============================================================
   Utility
   ============================================================ */
.fade-in{animation:fadeIn .3s ease}
.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}
.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}
.text-center{text-align:center}.text-sm{font-size:12px}.text-xs{font-size:10px}
.flex-between{display:flex;justify-content:space-between;align-items:center}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ============================================================
   Module Theme Overrides — Tab 切换时自动应用
   ============================================================ */
[data-theme="invest"] .ti.ac{color:var(--ma-invest)}
[data-theme="invest"] .stt{color:var(--ma-invest)}
[data-theme="invest"] .btn{background:var(--ma-invest)}
[data-theme="invest"] .btn-outline{background:transparent;color:var(--ma-invest);border-color:var(--ma-invest)}
[data-theme="invest"] .chip.ac{background:var(--ma-invest)}
[data-theme="invest"] .vtab.ac{background:var(--ma-invest);border-color:var(--ma-invest)}

[data-theme="life"] .ti.ac{color:var(--ma-life)}
[data-theme="life"] .stt{color:var(--ma-life)}
[data-theme="life"] .btn{background:var(--ma-life)}
[data-theme="life"] .btn-outline{background:transparent;color:var(--ma-life);border-color:var(--ma-life)}
[data-theme="life"] .chip.ac{background:var(--ma-life)}
[data-theme="life"] .vtab.ac{background:var(--ma-life);border-color:var(--ma-life)}

[data-theme="rel"] .ti.ac{color:var(--ma-rel)}
[data-theme="rel"] .stt{color:var(--ma-rel)}
[data-theme="rel"] .btn{background:var(--ma-rel)}
[data-theme="rel"] .btn-outline{background:transparent;color:var(--ma-rel);border-color:var(--ma-rel)}
[data-theme="rel"] .chip.ac{background:var(--ma-rel)}
[data-theme="rel"] .vtab.ac{background:var(--ma-rel);border-color:var(--ma-rel)}

[data-theme="knowledge"] .ti.ac{color:var(--ma-knowledge)}
[data-theme="knowledge"] .stt{color:var(--ma-knowledge)}
[data-theme="knowledge"] .btn{background:var(--ma-knowledge)}
[data-theme="knowledge"] .btn-outline{background:transparent;color:var(--ma-knowledge);border-color:var(--ma-knowledge)}
[data-theme="knowledge"] .chip.ac{background:var(--ma-knowledge)}
[data-theme="knowledge"] .vtab.ac{background:var(--ma-knowledge);border-color:var(--ma-knowledge)}

/* ============================================================
   VIA 性格优势系统 — 人生复利 v3
   ============================================================ */

/* 优势标签 */
.via-tag{display:inline-block;padding:1px 6px;border-radius:6px;font-size:10px;font-weight:600;margin-left:4px;vertical-align:middle}

/* 日记模板 */
.template-row{display:flex;gap:6px;margin-bottom:10px}
.tpl-chip{padding:4px 10px;border:1.5px solid var(--bd);border-radius:12px;font-size:11px;font-weight:500;cursor:pointer;color:var(--t2);background:transparent;transition:all .15s}
.tpl-chip.ac{border-color:var(--ma-life);background:rgba(217,119,6,.08);color:var(--ma-life)}

/* 平衡仪标签 */
.balance-label{text-align:center;font-size:13px;font-weight:600;margin-top:8px;padding:8px;border-radius:var(--r8)}
.balance-gold{color:#D97706;background:rgba(217,119,6,.06)}
.balance-ok{color:var(--t2)}
.balance-warm{color:var(--ma-life);background:rgba(217,119,6,.06)}

/* 沮丧转换笔记 */
.reframe-note{margin-top:6px;padding:6px 10px;background:rgba(217,119,6,.04);border-radius:6px;font-size:12px;color:var(--ma-life);border-left:2px solid var(--ma-life)}

/* VIA入口卡片 */
.via-quiz-entry{cursor:pointer;transition:transform .12s,box-shadow .15s}
.via-quiz-entry:active{transform:scale(.98)}
.via-weekly{cursor:pointer;transition:transform .12s,box-shadow .15s}
.via-weekly:active{transform:scale(.98)}

/* ============================================================
   闪光卡 (骄傲记录)
   ============================================================ */
.flc-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;
  backdrop-filter:blur(4px)}
.flc-overlay.show{opacity:1}
.flc-card{background:var(--ca);border-radius:var(--r20);padding:32px 24px;
  text-align:center;max-width:280px;width:90%;
  box-shadow:0 16px 48px rgba(0,0,0,.15),0 0 0 1px var(--bd);
  animation:flcBounce .5s cubic-bezier(.34,1.56,.64,1) both}
@keyframes flcBounce{from{transform:scale(.8) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.flc-sparkle{font-size:48px;margin-bottom:8px;animation:flcSpin 1.5s ease infinite}
@keyframes flcSpin{0%,100%{transform:rotate(0deg) scale(1)}50%{transform:rotate(5deg) scale(1.1)}}
.flc-domain{font-size:13px;color:var(--t3);margin-bottom:4px}
.flc-strength-name{font-size:26px;font-weight:800;color:var(--ma-life);margin-bottom:6px}
.flc-strength-desc{font-size:13px;color:var(--t2);margin-bottom:16px;line-height:1.6}
.flc-badge{display:inline-block;padding:6px 16px;background:rgba(217,119,6,.1);
  border-radius:16px;font-size:12px;font-weight:600;color:var(--ma-life);margin-bottom:16px}
.flc-close-btn{display:block;width:100%;padding:12px;background:var(--ma-life);color:#fff;
  border:none;border-radius:var(--r10);font-size:15px;font-weight:600;cursor:pointer;
  transition:background .15s}
.flc-close-btn:active{background:#D97706}

/* ============================================================
   沮丧转换弹窗
   ============================================================ */
.reframe-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.45);
  display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .3s;
  backdrop-filter:blur(2px)}
.reframe-overlay.show{opacity:1}
.reframe-modal{background:var(--ca);border-radius:20px 20px 0 0;padding:24px 20px;
  max-width:400px;width:100%;box-shadow:0 -8px 32px rgba(0,0,0,.1);
  animation:slideUp .3s ease}
.reframe-icon{font-size:40px;text-align:center;margin-bottom:8px}
.reframe-title{font-size:18px;font-weight:700;text-align:center;color:var(--t1);margin-bottom:8px}
.reframe-hint{font-size:13px;color:var(--t2);text-align:center;line-height:1.7;margin-bottom:16px;padding:10px;background:var(--ch);border-radius:var(--r8)}
.reframe-input-area{margin-bottom:12px}
.reframe-actions{display:flex;gap:8px}
.reframe-actions .btn{flex:1;margin-top:0}

/* ============================================================
   VIA自评问卷
   ============================================================ */
.quiz-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.45);
  display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .3s}
.quiz-overlay.show{opacity:1}
.quiz-modal{background:var(--ca);border-radius:20px 20px 0 0;padding:24px 20px;
  max-width:400px;width:100%;max-height:75vh;overflow-y:auto;
  box-shadow:0 -8px 32px rgba(0,0,0,.1);animation:slideUp .3s ease}
.quiz-header{text-align:center;margin-bottom:16px}
.quiz-header h3{font-size:18px;font-weight:700;color:var(--t1)}
.quiz-body{}
.quiz-item{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--bd)}
.quiz-q{font-size:14px;color:var(--t1);margin-bottom:10px;line-height:1.5}
.quiz-num{display:inline-block;background:var(--ma-life);color:#fff;padding:2px 8px;border-radius:8px;font-size:10px;font-weight:700;margin-right:6px}
.quiz-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--t3);margin-top:4px;gap:4px}
.quiz-labels span{flex:1;text-align:center}
.quiz-labels span:first-child{text-align:left}
.quiz-labels span:last-child{text-align:right}
.quiz-footer{text-align:center;margin-top:16px}
.quiz-footer .btn{margin-top:0}

/* 问卷结果 */
.quiz-result-overlay{position:fixed;inset:0;z-index:310;background:rgba(0,0,0,.55);
  display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;
  backdrop-filter:blur(4px)}
.quiz-result-overlay.show{opacity:1}
.quiz-result-modal{background:var(--ca);border-radius:var(--r20);padding:28px 20px;
  max-width:300px;width:90%;box-shadow:0 16px 48px rgba(0,0,0,.15);
  animation:flcBounce .5s cubic-bezier(.34,1.56,.64,1) both}
.quiz-result-modal h3{font-size:18px;text-align:center;margin-bottom:16px}
.quiz-top3{}
.quiz-rank{margin-bottom:10px}
.rank-badge{display:inline-block;width:24px;height:24px;text-align:center;line-height:24px;
  border-radius:50%;font-size:11px;font-weight:700;color:#fff;margin-right:8px;vertical-align:middle}
.rank-1 .rank-badge{background:#D97706}
.rank-2 .rank-badge{background:#A8A29E}
.rank-3 .rank-badge{background:#CD853F}
.rank-name{font-size:13px;font-weight:600;color:var(--t1);vertical-align:middle}
.rank-bar-wrap{height:6px;background:var(--ch);border-radius:3px;margin-top:6px;margin-left:36px}
.rank-bar{height:100%;border-radius:3px;background:var(--ma-life);transition:width .8s ease}
.quiz-result-note{font-size:11px;color:var(--t3);text-align:center;margin-top:16px;line-height:1.6}
.quiz-source{font-size:10px;color:var(--t3);text-align:center;margin-top:6px;line-height:1.4}
.quiz-source a{color:var(--p);text-decoration:underline}

/* ============================================================
   每周报告
   ============================================================ */
.report-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.45);
  display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .3s}
.report-overlay.show{opacity:1}
.report-modal{background:var(--ca);border-radius:20px 20px 0 0;padding:24px 20px;
  max-width:400px;width:100%;box-shadow:0 -8px 32px rgba(0,0,0,.1);
  animation:slideUp .3s ease}
.report-modal h3{font-size:16px;color:var(--t1);text-align:center;margin-bottom:4px}
.report-date{font-size:12px;color:var(--t3);text-align:center;margin-bottom:16px}
.report-section{margin-bottom:14px}
.report-label{font-size:13px;font-weight:600;color:var(--t2);margin-bottom:8px}
.report-strength{display:flex;justify-content:space-between;align-items:center;
  padding:6px 10px;background:var(--ch);border-radius:var(--r8);margin-bottom:4px;font-size:13px}
.report-stats{display:flex;gap:16px;font-size:12px;color:var(--t2)}
.report-stats span{display:flex;align-items:center;gap:4px}

/* ============================================================
   雷达图 + 职业推荐布局
   ============================================================ */
.radar-layout{display:flex;align-items:flex-start;gap:0;margin-top:4px}
.career-recs{display:flex;flex-direction:column;gap:4px}
.career-title{font-size:12px;font-weight:600;color:var(--t2);margin-bottom:4px;text-align:center}
.career-item{display:flex;align-items:center;gap:6px;padding:4px 6px;background:var(--ch);border-radius:var(--r6);font-size:11px}
.career-rank{width:16px;height:16px;border-radius:50%;background:var(--ma-life);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.career-name{color:var(--t1);font-weight:500;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.career-domain{font-size:9px;color:var(--t3);white-space:nowrap}
.career-note{font-size:9px;color:var(--t3);text-align:center;margin-top:4px}
@media (max-width:360px){.radar-layout{flex-direction:column}#comp-career{width:100%!important;padding-left:0!important;border-left:none!important;border-top:1px solid var(--bd);padding-top:8px;margin-top:8px}}

/* ============================================================
   挑战卡
   ============================================================ */
.via-challenge{border:1.5px dashed var(--ma-life);background:rgba(217,119,6,.03)}
.challenge-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.challenge-icon{font-size:24px}
.challenge-title{font-size:14px;font-weight:700;color:var(--ma-life)}
.challenge-task{font-size:14px;color:var(--t1);line-height:1.6;margin-bottom:8px}
.challenge-method{font-size:11px;color:var(--t3);margin-bottom:12px;line-height:1.4}
.challenge-completed{opacity:.6}
.challenge-done{text-align:center;padding:16px;color:var(--t2);font-size:14px}
.challenge-done span{display:block;margin-bottom:4px}

/* ============================================================
   热力图
   ============================================================ */
.heatmap{overflow-x:auto;padding:4px 0}
.hm-row{display:flex;align-items:center;gap:2px;margin-bottom:2px}
.hm-label{width:18px;font-size:10px;color:var(--t3);text-align:center;flex-shrink:0}
.hm-cell{width:12px;height:12px;border-radius:2px;background:var(--ch);flex-shrink:0}
.hm-cell.hm-empty{background:transparent}
.hm-cell.hm-l1{background:rgba(217,119,6,.12)}
.hm-cell.hm-l2{background:rgba(217,119,6,.3)}
.hm-cell.hm-l3{background:rgba(217,119,6,.55)}
.hm-cell.hm-l4{background:rgba(217,119,6,.85)}
.hm-legend{display:flex;align-items:center;justify-content:flex-end;gap:4px;
  margin-top:8px;font-size:10px;color:var(--t3)}
.hm-legend .hm-cell{display:inline-block;vertical-align:middle}

/* ============================================================
   里程碑 Toast 和 通用 Toast
   ============================================================ */
.milestone-toast{position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:400;
  background:var(--ca);padding:14px 24px;border-radius:var(--r16);
  box-shadow:0 8px 32px rgba(0,0,0,.12);display:flex;align-items:center;gap:10px;
  opacity:0;transition:opacity .4s,transform .4s;pointer-events:none;
  border:1px solid var(--bd)}
.milestone-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.ms-icon{font-size:28px}
.ms-text{font-size:14px;font-weight:600;color:var(--t1);white-space:nowrap}

.via-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);z-index:400;
  background:var(--ca);padding:10px 20px;border-radius:20px;
  box-shadow:0 4px 16px rgba(0,0,0,.1);font-size:13px;font-weight:600;color:var(--t1);
  opacity:0;transition:opacity .3s;pointer-events:none;border:1px solid var(--bd)}
.via-toast.show{opacity:1}

/* Reframe Toast */
.reframe-toast{position:fixed;bottom:120px;left:16px;right:16px;z-index:400;
  background:var(--ca);padding:12px 16px;border-radius:var(--r12);
  box-shadow:0 4px 24px rgba(0,0,0,.12);display:flex;align-items:flex-start;gap:10px;
  opacity:0;transform:translateY(12px);transition:all .35s ease;
  border:1px solid var(--bd);max-width:400px;margin:0 auto}
.reframe-toast.show{opacity:1;transform:translateY(0)}
.reframe-toast-icon{font-size:20px;flex-shrink:0;line-height:1.4}
.reframe-toast-title{font-size:13px;font-weight:700;color:var(--ma-life);margin-bottom:2px}
.reframe-toast-text{font-size:12px;color:var(--t2);line-height:1.5}

/* Strength Picker */
.strength-picker{margin-top:6px;padding:8px;background:var(--ch);border-radius:var(--r8)}
.strength-chip:hover{background:var(--pl)!important;border-color:var(--p)!important;color:var(--p)}

/* ============================================================
   暗色模式 VIA 适配
   ============================================================ */
/* ============================================================
   关系复利 — 开关 & 日期编辑 modal
   ============================================================ */
.toggle-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0}
.toggle-row .fl{flex:1;margin-bottom:0}
.tgl{position:relative;width:48px;height:28px;flex-shrink:0;cursor:pointer}
.tgl input{display:none}
.tgl-track{display:block;width:100%;height:100%;background:var(--bd);border-radius:14px;transition:background .25s}
.tgl input:checked+.tgl-track{background:var(--ma-rel)}
.tgl-thumb{position:absolute;top:3px;left:3px;width:22px;height:22px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.tgl input:checked~.tgl-thumb{transform:translateX(20px)}

.date-edit-modal{background:var(--ca);border-radius:20px 20px 0 0;padding:24px 20px;
  max-width:360px;width:100%;box-shadow:0 -8px 32px rgba(0,0,0,.1);animation:slideUp .3s ease}
.date-edit-modal h3{font-size:16px;color:var(--t1);text-align:center;margin-bottom:12px}
.date-repeat-info{font-size:11px;color:var(--t3);text-align:center;margin:-8px 0 12px}
.date-edit-modal .fg{margin-bottom:10px}
.date-edit-modal .fg:last-of-type{margin-bottom:14px}

@media (prefers-color-scheme: dark) {
  .flc-card{box-shadow:0 16px 48px rgba(0,0,0,.4),0 0 0 1px var(--bd)}
  .balance-gold{color:#F59E0B;background:rgba(245,158,11,.1)}
  .balance-warm{color:var(--ma-life);background:rgba(217,119,6,.1)}
  .reframe-hint{background:var(--ch)}
  .milestone-toast{box-shadow:0 8px 32px rgba(0,0,0,.4)}
  .via-toast{box-shadow:0 4px 16px rgba(0,0,0,.3)}
  .hm-cell.hm-l1{background:rgba(245,158,11,.15)}
  .hm-cell.hm-l2{background:rgba(245,158,11,.35)}
  .hm-cell.hm-l3{background:rgba(245,158,11,.6)}
  .hm-cell.hm-l4{background:rgba(245,158,11,.85)}
}
