@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@300;400;500;600;700&family=Noto+Serif+SC:wght@400;600;700&display=swap");.app-root{--bg:#FAFAFA;--card:#FFFFFF;--border:#EBEBEB;--border-soft:#F0F0F0;--text-1:#1A1A1A;--text-2:#555;--text-3:#888;--text-4:#BBB;--accent:#E8A23B;--paid:#7B4EA3;--paid-soft:#F1ECF6;--paid-deep:#5E377E;--male:#2878D9;--female:#D46A8A;--gold:#C89B1E;--gold-soft:#FBF3E3;--err:#C62828;--ok:#3FA85F;--wx-wood:#3FA85F;--wx-fire:#E53935;--wx-earth:#B8691A;--wx-metal:#C89B1E;--wx-water:#2878D9;--cred-1:#CCC;--cred-2:#3FA85F;--cred-3:#2878D9;--cred-4:#7B4EA3;--cred-5:#C89B1E;--cred-6:#C62828;font-family:Noto Sans SC,system-ui,sans-serif;background:var(--bg);color:var(--text-1);line-height:1.6;min-height:100vh}.app-root *{box-sizing:border-box}html:has(.app-root){scrollbar-gutter:stable;overflow-y:scroll}.app-root .topbar{background:var(--card);border-bottom:1px solid var(--border);height:64px;position:sticky;top:0;z-index:10}.app-root .topbar-inner{max-width:960px;margin:0 auto;padding:0;height:100%;display:flex;align-items:center;justify-content:space-between}@media (max-width:960px){.app-root .topbar-inner{padding:0 16px}}.app-root .brand-logo{font-family:"Noto Serif SC",serif;font-size:22px;font-weight:700;letter-spacing:8px}.app-root .back-link{font-size:12px;color:var(--text-3);text-decoration:none;letter-spacing:1px;cursor:pointer}.app-root .back-link:hover{color:var(--text-1)}.app-root .main{max-width:1040px;margin:0 auto;padding:28px 0 80px}@media (max-width:1040px){.app-root .main{padding:28px 16px 80px}}.app-root .btn{padding:7px 16px;border-radius:6px;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;letter-spacing:2px;border:1px solid var(--border);background:var(--card);color:var(--text-2);transition:all .15s;display:inline-block;text-decoration:none;line-height:1.4}.app-root .btn:hover{border-color:var(--text-3);color:var(--text-1)}.app-root .btn.primary{background:var(--text-1);color:#fff;border-color:var(--text-1)}.app-root .btn.primary:hover{background:#000;color:#fff}.app-root .btn.ghost{background:var(--card);color:var(--text-2)}.app-root .btn.small{padding:4px 10px;font-size:11px;letter-spacing:1px}.app-root .btn:disabled{opacity:.4;cursor:not-allowed}.app-root .auth-wrap{display:flex;align-items:center;justify-content:center;padding:40px 20px;min-height:calc(100vh - 64px)}.app-root .auth-shell{width:100%;max-width:570px;background:var(--card);border:1px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.04);display:flex;flex-direction:column;min-height:640px}.app-root .auth-shell .shell-head{padding:18px 24px 12px;border-bottom:1px solid var(--border-soft);display:flex;align-items:center;justify-content:space-between;flex:0 0 auto}.app-root .auth-shell .brand{font-family:"Noto Serif SC",serif;font-size:18px;font-weight:700;letter-spacing:6px}.app-root .auth-page{padding:22px 24px 24px;display:flex;flex:1;flex-direction:column}.app-root .auth-page .page-body{flex:1}.app-root .auth-page h2{font-family:"Noto Serif SC",serif;font-size:18px;font-weight:600;letter-spacing:0;margin-bottom:32px}.app-root .auth-page h2+.subtitle{margin-top:-24px;margin-bottom:32px}.app-root .auth-page .subtitle{font-size:11px;color:var(--text-3);letter-spacing:.5px}.app-root .field{margin-bottom:32px}.app-root .field label{display:block;font-size:14px;color:var(--text-1);margin-bottom:6px;letter-spacing:1px}.app-root .field .input-row{display:flex;gap:8px}.app-root input[type=date],.app-root input[type=email],.app-root input[type=password],.app-root input[type=text],.app-root input[type=time],.app-root select{width:100%;height:42px;padding:0 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;font-family:inherit;background:var(--card);color:rgba(26,26,26,.6)}.app-root input::placeholder{color:var(--text-4)}.app-root input[type=date],.app-root input[type=time]{-webkit-appearance:none;appearance:none;position:relative}.app-root input[type=date]::-webkit-date-and-time-value,.app-root input[type=time]::-webkit-date-and-time-value{text-align:left}.app-root input[type=date]::-webkit-calendar-picker-indicator,.app-root input[type=time]::-webkit-calendar-picker-indicator{cursor:pointer}.app-root input:focus,.app-root select:focus{outline:none;border-color:var(--text-1)}.app-root input:disabled,.app-root select:disabled{background:#F5F5F5;color:var(--text-4);cursor:not-allowed}.app-root .hint{font-size:11px;color:var(--text-3);margin-top:4px;letter-spacing:.3px}.app-root .hint.err{color:var(--err)}.app-root .hint.ok{color:var(--ok)}.react-datepicker-wrapper{display:block;width:100%}.app-root .picker-input-wrap{display:flex;align-items:center;justify-content:space-between;width:100%;height:42px;padding:0 12px;border:1px solid var(--border);border-radius:6px;background:var(--card);cursor:pointer}.app-root .picker-input-wrap:hover{border-color:var(--text-3)}.app-root .picker-input-wrap input{flex:1;height:100%;padding:0!important;background:transparent!important}.app-root .picker-icon{flex-shrink:0;display:flex;align-items:center;margin-left:8px}.app-root .time-row{display:flex;align-items:center;gap:8px}.app-root .time-select-wrap{position:relative;flex:1}.app-root .time-select-wrap select{width:100%;height:42px;padding:0 12px;border:1px solid var(--border);border-radius:6px;background:var(--card);font-size:14px;color:var(--text-1);appearance:none;cursor:pointer;font-family:inherit}.app-root .time-select-wrap select:hover{border-color:var(--text-3)}.app-root .time-select-wrap select:disabled{background:#F5F5F5;cursor:not-allowed;color:var(--text-4)}.app-root .time-select-wrap .time-icon{position:absolute;right:10px;top:50%;transform:translateY(-50%);pointer-events:none}.app-root .time-sep{font-size:18px;font-weight:600;color:var(--text-3);line-height:42px}.island-picker-popper{z-index:100!important}.island-picker-popper .react-datepicker__triangle{display:none!important}.island-calendar.react-datepicker{font-family:Noto Sans SC,system-ui,sans-serif;font-size:13px;border:1px solid #ebebeb;border-radius:12px;background:#FFFFFF;box-shadow:0 8px 32px rgba(0,0,0,.08);color:#1A1A1A;overflow:hidden}.island-calendar .react-datepicker__header{background:#FFFFFF;border-bottom:1px solid #f0f0f0;padding:14px 12px 8px}.island-calendar .react-datepicker__current-month,.island-calendar h2.react-datepicker__current-month{font-family:Noto Sans SC,system-ui,sans-serif;font-size:14px;font-weight:600;color:#1A1A1A;letter-spacing:1px;margin:0;padding:0}.island-calendar .react-datepicker__month-select,.island-calendar .react-datepicker__year-select{font-family:Noto Sans SC,system-ui,sans-serif;font-size:13px;color:#1A1A1A;border:1px solid #ebebeb;border-radius:6px;padding:2px 6px;background:#FAFAFA;cursor:pointer}.island-calendar .react-datepicker__month-select:focus-visible,.island-calendar .react-datepicker__year-select:focus-visible{outline:none;border-color:#1A1A1A}.island-calendar .react-datepicker__navigation{top:12px}.island-calendar .react-datepicker__navigation-icon:before{border-color:#1A1A1A;border-width:2px 2px 0 0;height:8px;width:8px}.island-calendar .react-datepicker__navigation:hover :before{border-color:#555}.island-calendar .react-datepicker__day-name{color:#888;font-size:12px;font-weight:500;width:2.2em;line-height:2.2em;margin:.15em}.island-calendar .react-datepicker__day{color:#1A1A1A;font-size:13px;width:2.2em;line-height:2.2em;margin:.15em;border-radius:6px;transition:background .15s,color .15s}.island-calendar .react-datepicker__day:not([aria-disabled=true]):hover{background:#F0F0F0;border-radius:6px}.island-calendar .react-datepicker__day--today{font-weight:600;background:#F5F5F5;border-radius:6px}.island-calendar .react-datepicker__day--selected{background:#1A1A1A!important;color:#FFFFFF!important;font-weight:500;border-radius:6px}.island-calendar .react-datepicker__day--selected:hover{background:#333!important}.island-calendar .react-datepicker__day--keyboard-selected{background:#EBEBEB;color:#1A1A1A;border-radius:6px}.island-calendar .react-datepicker__day--keyboard-selected:hover{background:#1A1A1A!important;color:#FFFFFF!important}.island-calendar .react-datepicker__day--outside-month{color:#CCC}.island-calendar .react-datepicker__day--disabled{color:#DDD!important;cursor:default}.island-calendar .react-datepicker__month{margin:6px 10px 10px}.island-calendar .react-datepicker__time-container{border-left:none;width:100%}.island-calendar .react-datepicker__time-container .react-datepicker__time{background:#FFFFFF;border-radius:0 0 12px 12px}.island-calendar .react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box{width:100%}.island-calendar .react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list{height:200px;scrollbar-width:thin;scrollbar-color:#DDD transparent}.island-calendar .react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item{height:auto;padding:8px 16px;font-size:13px;color:#1A1A1A;display:flex;align-items:center;justify-content:center;transition:background .15s}.island-calendar .react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item:hover{background:#F0F0F0}.island-calendar .react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected{background:#1A1A1A!important;color:#FFFFFF;font-weight:500}.island-calendar .react-datepicker__time-container .react-datepicker__time .react-datepicker__time-box ul.react-datepicker__time-list li.react-datepicker__time-list-item--selected:hover{background:#333!important}.island-calendar .react-datepicker-time__header{font-family:Noto Sans SC,system-ui,sans-serif;font-size:14px;font-weight:500;color:#1A1A1A}.island-calendar.react-datepicker--time-only{min-width:140px}.island-calendar.react-datepicker--time-only .react-datepicker__time-container{border-radius:12px}.island-calendar.react-datepicker--time-only .react-datepicker__time,.island-calendar.react-datepicker--time-only .react-datepicker__time-box{border-radius:0 0 12px 12px}.app-root .auth-shell .btn.code-btn{height:42px;padding:0 14px;font-size:12px;letter-spacing:1px;white-space:nowrap}.app-root .actions{margin-top:auto;padding-top:18px;display:flex;gap:10px;justify-content:flex-end;align-items:center}.app-root .actions.between{display:flex;justify-content:space-between;gap:10px;align-items:center}.app-root .actions.split{justify-content:center}.app-root .actions.split .btn{flex:1;width:auto;min-width:0}.app-root .auth-shell .btn{flex:0 0 auto;width:120px;min-width:120px;padding:0;height:42px;font-size:13px;display:inline-flex;align-items:center;justify-content:center}.app-root .auth-shell .btn.full{flex:1;width:auto}.app-root .skip-link{text-align:center;padding:14px 0 2px;font-size:13px;font-weight:500;color:var(--text-2);letter-spacing:2px;cursor:pointer}.app-root .skip-link:hover{color:var(--text-1)}.app-root .text-link{font-size:12px;color:var(--text-3);cursor:pointer;letter-spacing:1px}.app-root .text-link:hover{color:var(--text-1)}.app-root .more-toggle{display:flex;align-items:center;justify-content:center;gap:8px;height:42px;border:1px dashed var(--text-1);border-radius:6px;font-size:13px;color:var(--text-1);letter-spacing:2px;cursor:pointer;margin-bottom:32px;background:transparent}.app-root .more-toggle:hover{background:#F5F5F5}.app-root .step-dots{display:flex;gap:8px;align-items:center}.app-root .step-dots .dot{width:9px;height:9px;border-radius:50%;border:1.5px solid #111;background:#fff;transition:background .15s}.app-root .step-dots .dot.done{background:#111}.app-root .step-dots.v2{justify-content:center;padding:16px 0 4px}.app-root .step-dots.v2 .dot{width:8px;height:8px;border:none;background:#DDD}.app-root .step-dots.v2 .dot.active{background:#111}.app-root .gender-row{display:flex;gap:16px;justify-content:center;margin-top:10px}.app-root .gender-row.compact{justify-content:flex-start}.app-root .gender-row.compact .gender-pick{flex:0 0 89px}.app-root .gender-pick{flex:1;height:44px;border:1px solid var(--border);border-radius:6px;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:6px;cursor:pointer;font-size:13px;color:var(--text-2);letter-spacing:2px;transition:all .15s}.app-root .gender-pick .symbol{font-size:16px}.app-root .gender-pick.female .symbol{color:var(--female)}.app-root .gender-pick.male .symbol{color:var(--male)}.app-root .gender-pick.active{border-color:var(--text-1);background:#FAFAFA}.app-root .triplet{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.app-root .field-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.app-root .field-head label{margin-bottom:0;color:var(--text-1)}.app-root .mini-seg{display:inline-flex;border:1px solid var(--border);border-radius:999px;overflow:hidden;height:22px}.app-root .mini-seg button{height:100%;padding:0 10px;background:var(--card);border:none;font-family:inherit;font-size:11px;color:var(--text-3);cursor:pointer;letter-spacing:1px}.app-root .mini-seg button.active{background:#111;color:#fff}.app-root .u-switch{display:inline-flex;align-items:center;gap:10px;font-size:12px;color:var(--text-3);letter-spacing:1px;cursor:pointer;user-select:none}.app-root .u-switch .sw{width:40px;height:22px;background:#DDD;border-radius:999px;position:relative;transition:background .15s}.app-root .u-switch .sw:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;background:#fff;border-radius:50%;transition:left .15s}.app-root .u-switch.on{color:var(--text-1)}.app-root .u-switch.on .sw{background:#111}.app-root .u-switch.on .sw:after{left:20px}.app-root .u-switch.disabled{opacity:.4;pointer-events:none}.app-root .wheel-picker{display:flex;height:78px;border:1px solid var(--border);border-radius:6px;background:var(--card);position:relative;overflow:hidden}.app-root .wheel-picker:after,.app-root .wheel-picker:before{content:"";position:absolute;left:0;right:0;height:26px;pointer-events:none;z-index:2}.app-root .wheel-picker:before{top:0;background:linear-gradient(180deg,#fff,rgba(255,255,255,.6) 60%,rgba(255,255,255,0))}.app-root .wheel-picker:after{bottom:0;background:linear-gradient(0deg,#fff,rgba(255,255,255,.6) 60%,rgba(255,255,255,0))}.app-root .wheel-picker .indicator{position:absolute;left:6px;right:6px;top:50%;transform:translateY(-50%);height:26px;border-top:1px solid var(--border);border-bottom:1px solid var(--border);pointer-events:none;z-index:1}.app-root .wheel{flex:1;overflow-y:scroll;scroll-snap-type:y mandatory;text-align:center;scrollbar-width:none}.app-root .wheel::-webkit-scrollbar{display:none}.app-root .wheel .filler{height:26px}.app-root .wheel .item{height:26px;line-height:26px;scroll-snap-align:center;font-size:13px;color:var(--text-4);font-family:inherit;transition:color .15s,font-weight .15s}.app-root .wheel .item.on{color:var(--text-1);font-weight:600;font-size:14px}.app-root .wheel-picker.disabled{background:#FAFAFA;pointer-events:none}.app-root .wheel-picker.disabled .wheel .item{color:var(--text-4)}.app-root .wheel-picker.disabled .wheel .item.on{color:var(--text-2)}.app-root .sms-ask{background:#FAFAFA;border:1px solid var(--border-soft);border-radius:10px;padding:22px 24px;margin-top:6px}.app-root .sms-ask-title{font-family:"Noto Serif SC",serif;font-size:15px;font-weight:600;letter-spacing:2px;color:var(--text-1);margin-bottom:12px}.app-root .sms-ask-list{list-style:none;padding:0;margin:0 0 14px}.app-root .sms-ask-list li{position:relative;padding:6px 0 6px 20px;font-size:13px;color:var(--text-2);line-height:1.65;letter-spacing:.5px;border-bottom:1px dashed var(--border-soft)}.app-root .sms-ask-list li:last-child{border-bottom:none}.app-root .sms-ask-list li:before{content:"";position:absolute;left:4px;top:14px;width:4px;height:4px;border-radius:50%;background:var(--text-3)}.app-root .sms-ask-foot{font-size:11px;color:var(--text-4);letter-spacing:1px;text-align:right}.app-root .user-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px 28px;display:flex;gap:20px;align-items:center;justify-content:space-between;margin-bottom:20px}.app-root .user-meta{min-width:0}.app-root .user-nick{font-family:"Noto Serif SC",serif;font-size:22px;font-weight:600;letter-spacing:0}.app-root .user-phone{font-size:12px;color:var(--text-3);margin-top:2px;letter-spacing:1px}.app-root .entitlement-box{display:flex;align-items:center;gap:14px}.app-root .level-inline{display:inline-flex;align-items:center;user-select:none}.app-root .level-inline .tag{font-family:Noto Sans SC,system-ui,sans-serif;font-size:12px;font-weight:600;letter-spacing:2px;color:#fff;background:var(--paid);padding:3px 9px;border-radius:4px}.app-root .level-inline .tag.free{color:#fff;background:var(--text-4)}.app-root .upgrade-bar{display:inline-flex;align-items:center;gap:8px;font-size:12px;line-height:1;cursor:pointer;user-select:none;font-variant-numeric:tabular-nums}.app-root .upgrade-bar .q-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.app-root .upgrade-bar .q-text{color:var(--text-2);letter-spacing:.5px}.app-root .upgrade-bar .q-text strong{color:var(--text-1);font-weight:600}.app-root .upgrade-bar .q-link{font-weight:500;margin-left:4px;text-decoration:none}.app-root .upgrade-bar:hover .q-link{text-decoration:underline}.app-root .upgrade-bar.free,.app-root .upgrade-bar.free .q-link,.app-root .upgrade-bar.pro,.app-root .upgrade-bar.pro .q-link{color:var(--paid)}.app-root .tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px}.app-root .tab{padding:12px 20px;font-size:13px;color:var(--text-3);cursor:pointer;letter-spacing:2px;border-bottom:2px solid transparent;margin-bottom:-1px}.app-root .tab.active{color:var(--text-1);border-bottom-color:#111;font-weight:600}.app-root .pane{display:none}.app-root .pane.active{display:block}.app-root .chart-detail{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:24px 28px;position:relative;margin-bottom:18px}.app-root .chart-header{display:flex;align-items:center;gap:10px;height:28px;margin-bottom:18px}.app-root .chart-name{font-family:"Noto Serif SC",serif;font-size:18px;font-weight:600;letter-spacing:0;color:var(--text-1)}.app-root .gender-dot{width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;color:#fff;flex-shrink:0}.app-root .gender-dot.m{background:var(--male)}.app-root .gender-dot.f{background:var(--female)}.app-root .chart-birth{font-size:12px;color:var(--text-3);letter-spacing:1px;height:20px;line-height:20px;margin-bottom:16px}.app-root .chart-edit,.app-root .chart-view-btn{position:absolute;top:22px;right:26px;font-size:12px;color:var(--text-3);background:transparent;border:1px solid var(--border);cursor:pointer;letter-spacing:2px;padding:6px 14px;border-radius:6px;font-family:inherit;transition:all .15s}.app-root .chart-edit:hover,.app-root .chart-view-btn:hover{color:var(--text-1);border-color:var(--text-3)}.app-root .chart-panel{display:none}.app-root .chart-panel.active{display:block}.app-root .bazi-title{font-size:13px;color:#9CA3AF;font-weight:500;letter-spacing:.2em;height:20px;line-height:20px;margin-bottom:20px}.app-root .bazi-matrix{display:grid;grid-template-columns:72px repeat(4,208px);grid-template-rows:48px 48px 62px 62px 83px;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#fff;width:fit-content;margin:0 auto}.app-root .bazi-matrix .cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:10px 8px;border-bottom:1px solid var(--border);border-right:1px solid var(--border);font-family:inherit;overflow:hidden}.app-root .bazi-matrix .cell:nth-child(5n){border-right:none}.app-root .bazi-matrix .cell:nth-child(n+21){border-bottom:none}.app-root .bazi-matrix .cell.header-col,.app-root .bazi-matrix .cell.header-row{background:#F9F9F7;font-size:12px;color:#6B7280;font-weight:500;letter-spacing:2px}.app-root .bazi-matrix .cell.corner{background:#F5F5F2}.app-root .bazi-matrix .cell.star{font-size:14px;color:#4B5563;font-weight:500;letter-spacing:1px}.app-root .bazi-matrix .cell.star.day-self{color:var(--male);font-weight:700}.app-root .bazi-matrix .cell.star.day-self.f{color:var(--female)}.app-root .bazi-matrix .big-char{font-family:"Noto Serif SC",serif;font-size:38px;font-weight:700;line-height:1.1}.app-root .bazi-matrix .big-char.wood{color:var(--wx-wood)}.app-root .bazi-matrix .big-char.fire{color:var(--wx-fire)}.app-root .bazi-matrix .big-char.earth{color:var(--wx-earth)}.app-root .bazi-matrix .big-char.metal{color:var(--wx-metal)}.app-root .bazi-matrix .big-char.water{color:var(--wx-water)}.app-root .bazi-matrix .big-char.unknown{color:var(--text-4)}.app-root .bazi-matrix .cell.star.unknown-star{color:var(--text-4);font-weight:500}.app-root .bazi-matrix .cell.canggan{justify-content:flex-start;padding-top:10px}.app-root .bazi-matrix .cg{display:flex;flex-direction:column;gap:3px;width:100%;min-height:63px;align-items:center}.app-root .bazi-matrix .cg .empty,.app-root .bazi-matrix .cg .line{height:18px;line-height:1.375;font-size:13px;white-space:nowrap}.app-root .bazi-matrix .cg .s{font-weight:600;font-size:13px}.app-root .bazi-matrix .cg .s.wood{color:var(--wx-wood)}.app-root .bazi-matrix .cg .s.fire{color:var(--wx-fire)}.app-root .bazi-matrix .cg .s.earth{color:var(--wx-earth)}.app-root .bazi-matrix .cg .s.metal{color:var(--wx-metal)}.app-root .bazi-matrix .cg .s.water{color:var(--wx-water)}.app-root .bazi-matrix .cg .g{color:#374151;margin-left:6px;font-size:13px;font-weight:400}.app-root .bazi-matrix .cg .unknown-line{color:var(--text-4)}.app-root .chart-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media (max-width:700px){.app-root .chart-selector{grid-template-columns:repeat(2,1fr)}}.app-root .chart-mini{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:all .15s;display:flex;flex-direction:column;gap:4px;min-height:72px;position:relative}.app-root .chart-mini:hover{border-color:var(--text-3);box-shadow:0 4px 12px rgba(0,0,0,.04)}.app-root .chart-mini.active{border-color:#111;border-width:2px;padding:13px 15px;background:var(--card)}.app-root .chart-mini.self:not(.active){background:#FFF8E8;border-color:var(--accent)}.app-root .chart-mini .m-top{display:flex;align-items:center;gap:8px;height:22px}.app-root .chart-mini .m-name{font-family:"Noto Serif SC",serif;font-size:15px;font-weight:600;color:var(--text-1);letter-spacing:1px}.app-root .chart-mini .m-gender{width:14px;height:14px;border-radius:50%;font-size:9px;color:#fff;display:inline-flex;align-items:center;justify-content:center}.app-root .chart-mini .m-gender.m{background:var(--male)}.app-root .chart-mini .m-gender.f{background:var(--female)}.app-root .chart-mini .m-self-tag{position:absolute;top:10px;right:12px;font-size:10px;color:var(--accent);background:rgba(232,162,59,.15);border:1px solid var(--accent);padding:1px 7px;border-radius:4px;letter-spacing:2px;font-weight:600}.app-root .chart-mini .m-meta{font-size:11px;color:var(--text-3);letter-spacing:.5px;margin-top:2px}.app-root .chart-mini .m-star{font-size:14px;color:var(--accent);line-height:1;margin-left:auto}.app-root .chart-mini.add{border-style:dashed;align-items:center;justify-content:center;color:var(--text-3);font-size:13px;letter-spacing:3px}.app-root .chart-mini.add:hover{border-style:dashed;border-color:var(--text-2);color:var(--text-1);background:#FAFAFA}.app-root .form-grid{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:8px 20px}.app-root .form-row{display:grid;grid-template-columns:140px 1fr auto;align-items:center;padding:14px 4px;border-bottom:1px solid var(--border-soft);gap:14px}.app-root .form-row:last-child{border-bottom:none}.app-root .form-row .lbl{font-size:13px;color:var(--text-2);letter-spacing:1px}.app-root .form-row .val{font-size:14px;color:var(--text-1);min-width:0;overflow:hidden;text-overflow:ellipsis}.app-root .form-row .val.muted{color:var(--text-4)}.app-root .form-row .edit{font-size:12px;color:var(--text-3);cursor:pointer;letter-spacing:1px}.app-root .form-row .edit:hover{color:var(--text-1)}.app-root .form-row .edit.disabled{color:var(--text-4);cursor:not-allowed}.app-root .history-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}@media (max-width:1040px){.app-root .history-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:600px){.app-root .history-grid{grid-template-columns:repeat(2,1fr)}}.app-root .history-grid .card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:14px 14px 16px;cursor:pointer;transition:all .15s;position:relative;display:flex;flex-direction:column;gap:10px;height:220px;overflow:hidden}.app-root .history-grid .card:hover{border-color:var(--text-3);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.04)}.app-root .history-grid .card-header{display:flex;gap:16px;width:100%;position:relative}.app-root .history-grid .card-header-left{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.app-root .history-grid .card-body-bottom{display:flex;flex-direction:column;gap:8px;flex:1 0 0;min-height:0}.app-root .history-grid .card-name{font-family:"Noto Serif SC",serif;font-size:16px;font-weight:600;color:var(--text-1);letter-spacing:1px;line-height:1.25;height:2.5em;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-break:break-word}.app-root .history-grid .gender-dot{width:20px;height:20px;border-radius:50%;font-size:11px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.app-root .history-grid .gender-dot.m{background:var(--male)}.app-root .history-grid .gender-dot.f{background:var(--female)}.app-root .history-grid .card-divider{height:1px;background:var(--border-soft);margin:0}.app-root .history-grid .stem-row{display:flex;align-items:center;gap:6px}.app-root .history-grid .stem-char{font-family:"Noto Serif SC",serif;font-size:22px;font-weight:700;line-height:1}.app-root .history-grid .stem-char.wood{color:var(--wx-wood)}.app-root .history-grid .stem-char.fire{color:var(--wx-fire)}.app-root .history-grid .stem-char.earth{color:var(--wx-earth)}.app-root .history-grid .stem-char.metal{color:var(--wx-metal)}.app-root .history-grid .stem-char.water{color:var(--wx-water)}.app-root .history-grid .stem-label{font-size:11px;color:var(--text-2);letter-spacing:1px}.app-root .history-grid .card-birth{font-size:12px;color:var(--text-2);letter-spacing:.5px;line-height:normal}.app-root .history-grid .card-cred{font-size:11px;font-weight:700;letter-spacing:1.5px;line-height:normal}.app-root .history-grid .card-cred.c1{color:#999}.app-root .history-grid .card-cred.c2{color:var(--cred-2)}.app-root .history-grid .card-cred.c3{color:var(--cred-3)}.app-root .history-grid .card-cred.c4{color:var(--cred-4)}.app-root .history-grid .card-cred.c5{color:var(--cred-5)}.app-root .history-grid .card-liunian{position:absolute;right:0;bottom:0;font-size:11px;color:var(--text-3);letter-spacing:.5px;font-variant-numeric:tabular-nums;pointer-events:none}.app-root .history-grid .card-bio{font-size:12px;color:var(--text-3);line-height:19px;letter-spacing:.3px;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;word-break:break-word;height:57px;flex:0 0 57px}.app-root .history-grid .card.pinned{border-color:var(--accent);outline:1px solid var(--accent)}.app-root .pin-star{margin-left:auto;font-size:16px;line-height:1;color:var(--text-4);cursor:pointer;user-select:none;transition:color .15s,transform .15s;padding:2px 4px}.app-root .pin-star:hover{color:var(--accent);transform:scale(1.15)}.app-root .pin-star.on{color:var(--accent)}.app-root .modal-mask{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:50;display:none;align-items:center;justify-content:center;padding:20px}.app-root .modal-mask.open{display:flex}.app-root .modal{background:var(--card);border-radius:12px;width:100%;max-width:520px;padding:28px;box-shadow:0 4px 24px rgba(0,0,0,.04);max-height:calc(100vh - 40px);overflow-y:auto;position:relative}.app-root .modal h3{font-family:"Noto Serif SC",serif;font-size:18px;font-weight:600;letter-spacing:0;margin-bottom:4px}.app-root .modal .sub{font-size:11px;color:var(--text-3);margin-bottom:32px;letter-spacing:.5px}.app-root .modal-close{position:absolute;top:20px;right:20px;cursor:pointer;color:var(--text-3);font-size:22px;line-height:1;background:transparent;border:none;z-index:1}.app-root .compare-card{margin-top:0;border:1px solid var(--border);border-radius:8px;overflow:hidden}.app-root .compare-table{width:100%;border-collapse:separate;border-spacing:0}.app-root .compare-table td,.app-root .compare-table th{padding:10px 12px;text-align:center;font-size:13px;border-bottom:1px solid var(--border-soft)}.app-root .compare-table th{font-weight:500;color:var(--text-1);letter-spacing:2px;font-size:14px;background:#FAFAFA}.app-root .compare-table td{font-weight:400}.app-root .compare-table td:first-child{color:var(--text-1)}.app-root .compare-table td:nth-child(2){color:var(--text-3)}.app-root .compare-table td:last-child{color:var(--paid)}.app-root .compare-table tr:last-child td,.app-root .compare-table tr:last-child th{border-bottom:none}.app-root .compare-table.is-pro td:last-child,.app-root .compare-table.is-pro th:last-child{background:var(--paid-soft);border-left:2px solid var(--paid);border-right:2px solid var(--paid)}.app-root .compare-table.is-pro th:last-child{border-top:2px solid var(--paid);border-top-left-radius:8px;border-top-right-radius:8px}.app-root .compare-table.is-pro tr:last-child td:last-child{border-bottom:2px solid var(--paid);border-bottom-left-radius:8px;border-bottom-right-radius:8px}.app-root .pro-badge{display:inline-block;margin-left:8px;padding:2px 10px;font-size:12px;font-weight:500;color:#fff;background:var(--paid);border-radius:4px;letter-spacing:1px;vertical-align:1px}.app-root .upgrade-actions{display:flex;gap:10px;margin-top:22px}.app-root .upgrade-actions .btn{flex:1;height:44px;font-size:14px;font-weight:500;letter-spacing:1.5px}.app-root .btn.buy-disabled{background:#F5F5F5;color:var(--text-4);border:1px solid var(--border);cursor:not-allowed}.app-root .btn.buy-wechat{background:#fff;color:var(--text-1);border:1px solid rgba(26,26,26,.2);cursor:pointer}.app-root .btn.buy-wechat:hover{border-color:var(--text-1)}.app-root .qr-modal{max-width:360px;text-align:center}.app-root .qr-modal .sub{margin-bottom:18px}.app-root .qr-wrap{width:100%;display:flex;justify-content:center;padding:8px;border:1px solid var(--border-soft);border-radius:8px;background:#fff}.app-root .qr-wrap img{width:100%;max-width:280px;height:auto;display:block}.app-root .cdk-row{display:flex;gap:8px;align-items:stretch}.app-root .cdk-row input{flex:1;border:1px solid var(--border);border-radius:6px;padding:0 12px;font-family:monospace}.app-root .cdk-row .btn,.app-root .cdk-row input{height:44px;box-sizing:border-box;font-size:14px;letter-spacing:2px}.app-root .cdk-row .btn{padding:0 22px;font-weight:500}.app-root .cdk-hint{font-size:12px;margin-top:10px;color:var(--text-3);line-height:1.5;min-height:36px}.app-root .cdk-hint.err{color:var(--err)}.app-root .cdk-hint.ok{color:var(--ok)}.app-root .cdk-modal{min-height:240px}.app-root .edit-field{margin-bottom:14px}.app-root .edit-field label{font-size:12px;color:var(--text-2);letter-spacing:1px}.app-root .modal .field:last-of-type{margin-bottom:0}.app-root .modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:24px}.app-root .modal-actions.split{justify-content:center}.app-root .modal-actions.split .btn{flex:1;width:auto;min-width:0;padding:0;height:42px;font-size:13px;display:inline-flex;align-items:center;justify-content:center}.app-root .debug-bar{position:fixed;bottom:16px;left:50%;transform:translateX(-50%);background:#111;color:#fff;border-radius:999px;padding:6px 8px;display:flex;gap:4px;z-index:99;font-size:11px;align-items:center;flex-wrap:wrap;max-width:90vw}.app-root .debug-bar>span{padding:4px 8px;opacity:.6}.app-root .debug-bar button{background:transparent;border:none;color:#fff;padding:4px 10px;border-radius:999px;cursor:pointer;font-family:inherit;font-size:11px}.app-root .debug-bar button.on{background:#fff;color:#111}.app-root .debug-bar .sep{border-left:1px solid #444;padding-left:8px;margin-left:4px}.app-root .page[data-page="3"] .field{margin-bottom:10px}.app-root .page[data-page="3"] .hint{margin-top:4px}.app-root .page[data-page="3"] input,.app-root .page[data-page="3"] select{height:34px}.app-root .landing{max-width:480px;margin:40px auto;padding:40px 28px;background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 24px rgba(0,0,0,.04)}.app-root .landing h1{font-family:"Noto Serif SC",serif;font-size:24px;font-weight:600;letter-spacing:4px;margin-bottom:8px;text-align:center}.app-root .landing .sub{font-size:12px;color:var(--text-3);letter-spacing:1px;text-align:center;margin-bottom:28px}.app-root .landing .nav-list{display:flex;flex-direction:column;gap:12px}.app-root .landing .nav-item{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border:1px solid var(--border);border-radius:8px;cursor:pointer;color:var(--text-1);text-decoration:none;transition:all .15s}.app-root .landing .nav-item:hover{border-color:var(--text-1);background:#FAFAFA}.app-root .landing .nav-item .t{font-family:"Noto Serif SC",serif;font-size:15px;letter-spacing:2px}.app-root .landing .nav-item .d{font-size:11px;color:var(--text-3);margin-top:2px;letter-spacing:.3px}.app-root .landing .nav-item .arrow{color:var(--text-3);font-size:16px}