
:root{color-scheme:light;--bg-deepest:#F5F0E8;--bg-card:#FFFFFF;--bg-hover:#F0EBE0;--gold-primary:#C75B39;--gold-light:#D97D54;--gold-secondary:#D4A853;--gold-secondary-light:#E5C76D;--gold-secondary-translucent:rgba(212,168,83,0.45);--gold-translucent:rgba(199,91,57,0.45);--gold-bg-light:rgba(199,91,57,0.10);--gold-bg-subtle:rgba(199,91,57,0.05);--text-primary:#3D3530;--text-secondary:#7A7068;--text-tertiary:#9A9088;--color-good:#7A9A6E;--color-bad:#C75B39;--border-subtle:rgba(61,53,48,0.08);--radius:12px;--radius-sm:8px;--space-xs:4px;--space-sm:10px;--space-md:20px;--space-lg:32px;--space-xl:48px}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg-deepest);color:var(--text-primary);font-family:'Noto Sans SC','PingFang SC','Microsoft YaHei',sans-serif;line-height:1.7;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}
.serif{font-family:'Noto Serif SC','STSong','Songti SC',serif}.mono{font-family:'JetBrains Mono','Consolas',monospace}
.container{max-width:960px;margin:0 auto;padding:0 32px}@media(max-width:640px){.container{padding:0 16px}}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 32px;border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:500;cursor:pointer;transition:all .25s;font-family:inherit;letter-spacing:0.5px}
.btn-primary{background:var(--gold-primary);color:var(--bg-deepest);position:relative}.btn-primary:hover{background:var(--gold-light);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{background:#475569;color:var(--text-secondary);cursor:not-allowed;transform:none}
.btn-primary.pulse{animation:pulseGlow 2s ease-in-out infinite}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 10px rgba(199,91,57,0.15)}50%{box-shadow:0 0 28px rgba(199,91,57,0.35)}}
.btn-secondary{background:transparent;border:1.5px solid var(--gold-primary);color:var(--gold-primary)}.btn-secondary:hover{background:var(--gold-bg-light)}
.btn-ghost{background:transparent;border:1px solid var(--border-subtle);color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}
.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:32px;box-shadow:0 4px 24px rgba(0,0,0,0.25)}.card-accent{border-left:3px solid var(--gold-translucent)}
.page{display:none;padding:40px 0 60px}.page.active{display:block;animation:pageFade .2s ease}@keyframes pageFade{from{opacity:0}to{opacity:1}}
.sidebar{position:fixed;left:0;top:0;bottom:0;width:64px;z-index:200;background:var(--bg-deepest);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:4px;border-radius:0 8px 8px 0}
.sidebar .sb-logo{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--gold-secondary);border-radius:50%;margin-bottom:12px;cursor:pointer;transition:all .3s}
.sidebar .sb-logo:hover{border-color:var(--gold-primary);transform:scale(1.05)}
.sidebar .sb-btn{width:44px;height:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;border:none;border-radius:8px;background:transparent;color:var(--text-tertiary);cursor:pointer;transition:all .25s;font-family:inherit;gap:2px;padding:0;position:relative;font-size:10px}
.sidebar .sb-btn:hover{background:var(--gold-bg-light);color:var(--gold-secondary)}.sidebar .sb-btn:hover svg{transform:translateX(2px)}.sidebar .sb-btn svg{transition:transform .25s}
.sidebar .sb-btn.active{color:var(--gold-secondary);background:var(--gold-bg-light)}
.sidebar .sb-btn.active::before{content:'';position:absolute;left:-6px;top:50%;transform:translateY(-50%);width:3px;height:16px;background:var(--gold-primary);border-radius:0 3px 3px 0}
.sidebar .sb-btn .sb-lb{display:block;text-align:center;font-size:10px;line-height:1.2;margin-top:1px}
.master-btn{position:fixed;top:14px;right:16px;z-index:150;display:flex;flex-direction:column;align-items:center;gap:2px;background:transparent;border:none;border-radius:8px;color:var(--text-tertiary);cursor:pointer;padding:6px 8px;font-size:11px;font-family:inherit;transition:all .25s}
.master-btn:hover{background:var(--gold-bg-light);color:var(--gold-secondary)}.master-btn:hover svg{transform:translateX(2px)}.master-btn svg{transition:transform .25s}
.master-btn .mb-label{font-size:10px;color:var(--text-tertiary);transition:color .25s}
.master-btn:hover .mb-label{color:var(--gold-secondary)}
.mask{display:none;position:fixed;inset:0;z-index:300;background:rgba(0,0,0,0.15)}.mask.show{display:block}
.mp{display:none;position:fixed;top:0;right:0;bottom:0;width:340px;z-index:310;background:var(--bg-card);border-left:1px solid var(--border-subtle);padding:24px 20px;overflow-y:auto;animation:slideIn .3s ease}.mp.show{display:block}@keyframes slideIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
.mp-header{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;border-bottom:1px solid var(--border-subtle);margin-bottom:16px}
.mp-header h3{font-family:'Noto Serif SC',serif;font-size:18px;color:var(--gold-primary);font-weight:700;letter-spacing:6px}
.mp-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-subtle);border-radius:50%;background:transparent;color:var(--text-tertiary);cursor:pointer;font-size:14px;transition:all .2s;font-family:inherit;padding:0}
.mp-close:hover{border-color:var(--gold-translucent);color:var(--gold-primary);background:var(--gold-bg-light)}
.mp-section{margin-bottom:14px}
.mp-label{font-size:11px;color:var(--text-tertiary);letter-spacing:2px;margin-bottom:6px;font-weight:500}
.mp-input{width:100%;padding:11px 14px;background:var(--bg-deepest);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:inherit;box-sizing:border-box;outline:none;transition:border-color .2s}
.mp-input:focus{border-color:var(--gold-translucent)}
.mp-status{text-align:center;font-size:12px;color:var(--text-tertiary);margin-bottom:14px;padding:8px;background:var(--gold-bg-subtle);border-radius:var(--radius-sm)}
.mp-points-card{background:var(--gold-bg-light);border:1px solid var(--gold-translucent);border-radius:var(--radius-sm);padding:14px 16px;margin-bottom:14px}
.mpc-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}
.mpc-row:last-child{margin-bottom:0}
.mpc-label{font-size:12px;color:var(--text-secondary)}
.mpc-value{font-size:24px;font-weight:700;color:var(--gold-primary);font-family:'JetBrains Mono',monospace}
.mpc-sub{font-size:13px;color:var(--text-secondary)}
.mpc-sub em{font-style:normal;color:var(--gold-primary);font-weight:600}
.mp-action{width:100%;margin-bottom:8px}
.mp-divider{height:1px;background:var(--border-subtle);margin:12px 0}
.mp-report-list{font-size:13px;color:var(--text-secondary);line-height:1.8}
.logo-area{text-align:center;padding:40px 0 20px}
.logo-icon{width:56px;height:56px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;border:2px solid var(--gold-primary);border-radius:50%}
.logo-name{font-family:'Noto Serif SC',serif;font-size:32px;font-weight:700;color:var(--gold-primary);letter-spacing:8px}
.logo-sub{font-size:14px;color:var(--text-secondary);margin-top:4px;letter-spacing:2px}
.logo-desc{font-size:14px;color:var(--text-tertiary);margin-top:16px;max-width:420px;margin-left:auto;margin-right:auto;line-height:1.9}
.hero-verse{text-align:center;padding:8px 0 28px;opacity:0;animation:verseFade 1.8s ease 0.3s forwards}
@keyframes verseFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.hero-verse .hv-line{font-family:'Noto Serif SC',serif;font-size:15px;color:var(--text-secondary);line-height:2.1;letter-spacing:2px}
.hero-verse .hv-line em{font-style:normal;color:var(--gold-primary)}
.birth-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:28px 24px 32px;margin-bottom:24px;position:relative;overflow:hidden}
.birth-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold-primary),var(--gold-secondary),var(--gold-primary))}
.birth-card .bc-seal{font-family:'Noto Serif SC',serif;font-size:13px;color:var(--gold-primary);text-align:center;margin-bottom:22px;letter-spacing:6px;font-weight:600;display:flex;align-items:center;justify-content:center;gap:12px}
.birth-card .bc-seal::before,.birth-card .bc-seal::after{content:'';width:24px;height:1px;background:linear-gradient(90deg,transparent,var(--gold-secondary-translucent))}
.birth-card .bc-seal::after{background:linear-gradient(90deg,var(--gold-secondary-translucent),transparent)}
.scard{animation:cardIn 0.45s ease both}
#summaryGrid .scard:nth-child(1){animation-delay:0s}
#summaryGrid .scard:nth-child(2){animation-delay:0.08s}
#summaryGrid .scard:nth-child(3){animation-delay:0.16s}
#summaryGrid .scard:nth-child(4){animation-delay:0.24s}
#summaryGrid .scard:nth-child(5){animation-delay:0.32s}
#summaryGrid .scard:nth-child(6){animation-delay:0.4s}
@keyframes cardIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.input-group{display:flex;gap:8px;margin-bottom:12px}
.input-group input,.input-group select{flex:1;min-width:0;padding:14px;background:var(--bg-deepest);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:15px;font-family:inherit;text-align:center}
.input-group input:focus,.input-group select:focus{outline:none;border-color:var(--gold-translucent)}
.cs-wrap{position:relative;flex:1;min-width:0}
.cs-trigger{padding:14px;background:var(--bg-deepest);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:15px;font-family:inherit;text-align:center;cursor:pointer;user-select:none}
.cs-trigger:hover{border-color:var(--gold-translucent)}
.cs-drop{display:none;position:absolute;top:100%;left:0;min-width:100%;z-index:200;max-height:200px;overflow-y:auto;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:0 0 var(--radius-sm) var(--radius-sm)}
.cs-drop.show{display:block}.cs-opt{padding:10px 18px;font-size:14px;color:var(--text-secondary);cursor:pointer;text-align:center}
.cs-opt:hover{background:var(--gold-bg-light);color:var(--gold-primary)}.cs-opt.sel{background:var(--gold-bg-light);color:var(--gold-primary);font-weight:600}
.cs-wrap.open .cs-trigger{border-color:var(--gold-primary);border-radius:var(--radius-sm) var(--radius-sm) 0 0}
.gender-toggle{display:flex;justify-content:center;gap:0;margin-bottom:var(--space-md)}
.gender-toggle .gt{flex:1;max-width:140px;padding:14px 0;text-align:center;background:var(--bg-deepest);border:1.5px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;font-size:16px;font-weight:500}.gender-toggle .gt:first-child{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.gender-toggle .gt:last-child{border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.gender-toggle .gt.active{background:var(--gold-bg-light);border-color:var(--gold-primary);color:var(--gold-primary);font-weight:600}
.calendar-toggle{display:flex;gap:10px;margin:16px 0}
.calendar-toggle button{flex:1;padding:12px;border:1.5px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-deepest);color:var(--text-secondary);font-size:15px;cursor:pointer;font-family:inherit}
.calendar-toggle button.active{background:var(--gold-bg-light);border-color:var(--gold-primary);color:var(--gold-primary);font-weight:600}
#leapMonthRow{display:none;text-align:center;margin:12px 0}
.loading-hex{width:80px;height:80px;margin:0 auto 24px;position:relative;animation:hexSpin 3s linear infinite}
.loading-hex::before{content:'';position:absolute;inset:0;border:3px solid transparent;border-top-color:var(--gold-primary);border-radius:50%;animation:hexInner 1.5s ease-in-out infinite}
@keyframes hexSpin{100%{transform:rotate(360deg)}}@keyframes hexInner{0%,100%{border-top-color:var(--gold-primary)}50%{border-top-color:var(--gold-light)}}
.loading-text{text-align:center;font-size:16px;color:var(--text-secondary)}
.loading-steps{margin-top:24px;text-align:center}.loading-steps .ls{display:block;font-size:14px;color:var(--text-tertiary);margin:6px 0}.loading-steps .ls.done{color:var(--color-good)}
/* === Chat Redesign === */
#page-chat.page{display:none}
#page-chat.page.active{display:flex;padding:0;margin:0;margin-left:244px;position:static;height:100vh;overflow:hidden;flex-direction:column}
#page-chat .chat-area{flex:1;display:flex;flex-direction:column;min-height:0}
#page-chat .chat-messages{flex:1;overflow-y:auto;padding:24px 28px;background:var(--bg-deepest);scroll-behavior:smooth}
#page-chat .chat-messages::-webkit-scrollbar{width:4px}
#page-chat .chat-messages::-webkit-scrollbar-track{background:transparent}
#page-chat .chat-messages::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:2px}
.chat-keywords{position:fixed;left:64px;top:0;bottom:0;width:180px;z-index:190;background:var(--bg-card);border-right:1px solid var(--border-subtle);display:none;flex-direction:column;padding:16px 0}
.chat-keywords.show{display:flex}
.chat-keywords .ck-title{font-size:11px;color:var(--text-tertiary);padding:0 16px 12px;border-bottom:1px solid var(--border-subtle);margin-bottom:6px;letter-spacing:3px;font-weight:500}
.ck-list{flex:1;overflow-y:auto}
.ck-item{display:flex;align-items:center;gap:8px;padding:8px 16px;cursor:pointer;font-size:12px;color:var(--text-secondary);border-left:2px solid transparent;transition:all .2s}
.ck-item:hover{background:var(--bg-hover);color:var(--text-primary)}
.ck-item.active{border-left-color:var(--gold-primary);color:var(--gold-primary);background:var(--gold-bg-light)}
.ck-item .ck-num{width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:9px;border-radius:50%;background:var(--border-subtle);color:var(--text-tertiary);flex-shrink:0}
.ck-item.active .ck-num{background:var(--gold-primary);color:var(--bg-card)}
.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}
.summary-grid + .detail-panel{margin-top:20px}
.summar-wrap{position:relative;min-height:460px}
.summar-wrap .summary-grid{transition:all .45s cubic-bezier(.4,0,.2,1)}
.summar-wrap.expanded .summary-grid{position:absolute;left:0;top:0;width:240px;z-index:10;grid-template-columns:1fr;gap:8px;overflow-y:auto;max-height:580px;padding-right:4px}
.summar-wrap.expanded .scard{padding:12px 14px;border-radius:6px;cursor:pointer}
.summar-wrap.expanded .scard.active{border-color:var(--gold-primary);background:var(--gold-bg-light)}
.summar-wrap.expanded .scard .sc-main{font-size:13px;margin-bottom:1px}
.summar-wrap.expanded .scard .sc-sub{font-size:11px;line-height:1.4}
.summar-wrap.expanded .scard h4{font-size:12px;margin:0 0 3px;padding-bottom:2px;letter-spacing:0}
.summar-wrap.expanded .detail-panel{display:block;margin-left:260px;min-height:400px}
@keyframes panelIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}
@media(max-width:680px){.summar-wrap.expanded .summary-grid{position:static;width:100%;grid-template-columns:1fr 1fr;max-height:none}.summar-wrap.expanded .detail-panel{margin-left:0}}
.scard{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:24px 22px;cursor:pointer;transition:all .3s;position:relative;overflow:hidden}
.scard::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--gold-primary),var(--gold-secondary));opacity:0;transition:opacity .3s}
.scard:hover::before{opacity:1}
.scard:hover{border-color:var(--gold-translucent);box-shadow:0 8px 28px rgba(199,91,57,0.08);transform:translateY(-2px)}
.scard.locked{opacity:0.7;cursor:default}.scard.locked:hover{border-color:var(--border-subtle);box-shadow:none;transform:none}.scard.locked::before{opacity:0}
.scard h4{font-family:'Noto Serif SC',serif;font-size:14px;color:var(--gold-primary);margin:0 0 10px;padding:0 0 8px 18px;border-bottom:1px solid var(--border-subtle);letter-spacing:2px;font-weight:600;position:relative}
#summaryGrid .scard:nth-child(1) h4::before{content:'\2630';position:absolute;left:0;top:0;font-size:12px;color:var(--gold-secondary);opacity:0.6}
#summaryGrid .scard:nth-child(2) h4::before{content:'\2606';position:absolute;left:0;top:0;font-size:12px;color:var(--gold-secondary);opacity:0.6}
#summaryGrid .scard:nth-child(3) h4::before{content:'\25C7';position:absolute;left:0;top:0;font-size:11px;color:var(--gold-secondary);opacity:0.6}
#summaryGrid .scard:nth-child(4) h4::before{content:'\25CB';position:absolute;left:0;top:0;font-size:12px;color:var(--gold-secondary);opacity:0.6}
#summaryGrid .scard:nth-child(5) h4::before{content:'\2727';position:absolute;left:0;top:0;font-size:12px;color:var(--gold-secondary);opacity:0.6}
#summaryGrid .scard:nth-child(6) h4::before{content:'\268A';position:absolute;left:0;top:0;font-size:14px;color:var(--gold-secondary);opacity:0.6}
.scard .sc-main{font-family:'Noto Serif SC',serif;font-size:21px;color:var(--text-primary);font-weight:700;margin-bottom:10px;letter-spacing:0.5px;padding:8px 10px;background:var(--gold-bg-subtle);border-radius:6px;text-align:center;line-height:1.4}
.scard .sc-sub{font-size:13px;color:var(--text-secondary);line-height:1.8;margin-bottom:2px}
.scard .sc-tag{display:inline-block;background:var(--gold-bg-light);color:var(--gold-primary);font-size:10px;padding:2px 10px;border-radius:10px;margin-right:4px;margin-bottom:2px;font-weight:500;letter-spacing:0.5px}
.scard .sc-divider{height:1px;background:linear-gradient(90deg,transparent,var(--border-subtle),transparent);margin:8px 0}
.scard .sc-row{display:flex;justify-content:space-between;font-size:13px;color:var(--text-secondary);margin:3px 0;padding:2px 0}
.scard .sc-label{color:var(--text-tertiary);font-size:11px;letter-spacing:0.5px}
.scard .sc-lock{font-size:13px;color:var(--text-tertiary);text-align:center;padding:14px 0 6px;line-height:1.8}
.scard .sc-lock-icon{width:40px;height:40px;margin:0 auto 8px;border:2px dashed var(--border-subtle);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-tertiary);transition:all .3s}
.scard.locked:hover .sc-lock-icon{border-color:var(--gold-secondary-translucent);color:var(--gold-secondary);transform:scale(1.05)}
/* === Detail Panel Design === */
.bazi-scroll{display:flex;gap:14px;justify-content:center;margin:20px 0;flex-wrap:wrap}
.bazi-pillar{text-align:center;padding:22px 18px 16px;background:var(--bg-deepest);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);min-width:82px;position:relative}
.bazi-pillar::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:22px;height:4px;background:var(--gold-primary);border-radius:0 0 3px 3px}
.bazi-pillar .bp-label{font-size:10px;color:var(--text-tertiary);margin-bottom:6px;letter-spacing:3px;font-weight:500}
.bazi-pillar .bp-gan{font-size:28px;font-weight:700;color:var(--text-primary);font-family:'Noto Serif SC',serif;line-height:1.2}
.bazi-pillar .bp-zhi{font-size:20px;color:var(--text-secondary);margin-top:2px;font-family:'Noto Serif SC',serif}
.bazi-pillar .bp-cang{font-size:11px;color:var(--gold-secondary);margin-top:8px;padding-top:8px;border-top:1px solid var(--border-subtle);line-height:1.6}
.dm-seal{display:inline-flex;align-items:center;gap:12px;padding:10px 28px;border:2px solid var(--gold-primary);border-radius:var(--radius-sm);margin:8px auto;background:var(--gold-bg-light)}
.dm-seal .dm-char{font-size:22px;font-weight:700;color:var(--gold-primary);font-family:'Noto Serif SC',serif}
.dm-seal .dm-label{font-size:13px;color:var(--text-secondary)}
.dm-seal .dm-strong{font-size:13px;color:var(--gold-primary);font-weight:600}
.wuxing-detail{margin:12px 0;padding:14px 18px;background:var(--bg-deepest);border-radius:var(--radius-sm)}
.wuxing-detail .wx-title{font-size:12px;color:var(--text-tertiary);margin-bottom:8px;letter-spacing:2px}
.wuxing-detail .wx-bar-wrap{display:flex;gap:6px;margin-bottom:6px}.wuxing-detail .wx-bar{height:10px;border-radius:var(--radius-sm)}
.wuxing-detail .wx-nums{font-size:12px;color:var(--text-secondary);margin-top:4px}.wuxing-detail .wx-nums span{margin-right:12px}
.dayun-section{margin:16px 0}
.dayun-section .du-header{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gold-translucent);font-weight:600;margin-bottom:12px;font-family:'Noto Serif SC',serif;letter-spacing:1px}
.dayun-track{display:flex;gap:0;padding:12px 0;position:relative;overflow-x:auto}
.dayun-track::-webkit-scrollbar{height:3px;background:transparent}
.dayun-track::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:2px}
.dayun-track::before{content:'';position:absolute;top:50%;left:12px;right:12px;height:2px;background:var(--border-subtle);transform:translateY(-50%)}
.dayun-item{display:flex;flex-direction:column;align-items:center;min-width:68px;padding:6px;position:relative;z-index:1;flex-shrink:0}
.dayun-item .du-dot{width:10px;height:10px;border-radius:50%;background:var(--gold-primary);margin-bottom:6px;border:2px solid var(--bg-card);box-shadow:0 0 0 1px var(--gold-translucent)}
.dayun-item .du-ganzhi{font-size:14px;font-weight:700;color:var(--text-primary);font-family:'Noto Serif SC',serif}
.dayun-item .du-age{font-size:11px;color:var(--text-tertiary)}.dayun-item .du-ten{font-size:10px;color:var(--gold-secondary)}
.dayun-item.du-current .du-dot{background:var(--gold-light);width:14px;height:14px}
.dayun-item.du-current .du-ganzhi{color:var(--gold-primary);font-size:16px}
.liunian-box{margin:12px 0;padding:14px 18px;background:var(--gold-bg-light);border:1px solid var(--gold-translucent);border-radius:var(--radius-sm);display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.liunian-box .ln-label{font-size:11px;color:var(--text-tertiary);letter-spacing:2px}
.liunian-box .ln-ganzhi{font-size:18px;font-weight:700;color:var(--gold-primary);font-family:'Noto Serif SC',serif}
.liunian-box .ln-info{font-size:13px;color:var(--text-secondary)}
.zw-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:5px;max-width:420px;margin:12px auto}
.zw-cell{text-align:center;padding:0;border-radius:6px;position:relative;min-height:54px;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-deepest)}
.zw-cell .zw-top{padding:3px 2px 2px;border-bottom:1px solid rgba(61,53,48,0.05)}
.zw-cell .zw-top .zw-name{font-size:10px;font-weight:600;color:var(--text-tertiary);letter-spacing:1px}
.zw-cell .zw-mid{padding:4px 2px;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}
.zw-cell .zw-mid .zw-star-wrap{position:relative;display:inline-block;line-height:1.2}
.zw-cell .zw-mid .zw-star-wrap .zw-dot{position:absolute;top:-4px;right:-6px;width:4px;height:4px;border-radius:50%;background:var(--gold-primary);opacity:0.6}
.zw-cell .zw-mid .zw-major-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:0 6px;padding:3px 0}
.zw-cell .zw-mid .zw-star.zw-lg{font-size:15px;font-weight:700;color:var(--text-primary);font-family:'Noto Serif SC',serif;line-height:1.5}
.zw-cell .zw-mid .zw-star.zw-sm{font-size:13px;font-weight:600;color:var(--text-primary);font-family:'Noto Serif SC',serif;line-height:1.5}
.zw-cell .zw-mid .zw-star-aux{font-size:9px;font-weight:400;color:var(--text-tertiary);font-family:'Noto Sans SC',sans-serif;line-height:1.3}
.zw-cell .zw-mid .zw-minor-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:0 4px;padding:1px 0 2px}
.zw-cell .zw-bot{padding:2px 2px 3px;border-top:1px solid rgba(61,53,48,0.05)}
.zw-cell .zw-bot .zw-tag{display:inline-block;font-size:7px;padding:0 3px;border-radius:2px;margin:0 1px;font-weight:600}
.zw-cell .zw-bot .zw-tag.zw-lx{color:#C06040}
.zw-cell .zw-bot .zw-tag.zw-xx{color:var(--color-good)}
.zw-cell .zw-bot .zw-tag.zw-si{color:var(--gold-primary);background:var(--gold-bg-subtle)}
.zw-cell.zw-mg{background:var(--gold-bg-light);border:1.5px solid var(--gold-primary)}
.zw-cell.zw-mg::before{content:'';position:absolute;left:-1px;top:4px;bottom:4px;width:2px;background:linear-gradient(180deg,var(--gold-primary),var(--gold-secondary));border-radius:0 2px 2px 0}
/* 中心摘要卡 */
.zw-center-card{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--gold-bg-light);border:1.5px solid var(--gold-translucent);padding:10px 6px;text-align:center;border-radius:6px}
.zw-center-card .zwc-main{font-size:14px;font-weight:700;color:var(--gold-primary);font-family:'Noto Serif SC',serif;line-height:1.4}
.zw-center-card .zwc-sub{font-size:10px;color:var(--text-secondary);margin-top:2px}
.zw-center-card .zwc-mid{display:flex;align-items:center;justify-content:center;gap:4px;flex-wrap:wrap;margin-top:4px}
.zw-center-card .zwc-mid .zwc-tag{font-size:7px;padding:1px 4px;border-radius:2px;font-weight:600}
.zw-center-card .zwc-mid .zwc-tag.zw-lx{color:#C06040}
.zw-center-card .zwc-mid .zwc-tag.zw-xx{color:var(--color-good)}
.zw-center-card .zwc-mid .zwc-tag.zw-si{color:var(--gold-primary);background:var(--gold-bg-subtle)}

.qm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin:10px 0}
.qm-cell{background:var(--bg-deepest);border:1px solid var(--border-subtle);border-radius:6px;padding:8px 6px;text-align:center;position:relative}
.qm-cell .qm-name{font-size:12px;font-weight:700;color:var(--gold-translucent);margin-bottom:3px;letter-spacing:2px}
.qm-cell .qm-men{font-size:22px;font-weight:700;color:var(--text-primary);font-family:'Noto Serif SC',serif;line-height:1.3;letter-spacing:2px}
.qm-cell .qm-detail{font-size:10px;color:var(--text-secondary);line-height:1.8}
.qm-cell .qm-detail em{font-style:normal;color:var(--text-primary);font-weight:500}
.qm-cell .qm-detail .qm-gan{color:var(--gold-primary)}
.qm-cell .qm-parts{display:flex;gap:2px;justify-content:center;margin-top:4px;flex-wrap:wrap}
.qm-cell .qm-parts .qm-tag{display:inline-block;font-size:9px;padding:1px 6px;border-radius:3px;background:var(--gold-bg-subtle);color:var(--text-secondary)}
.qm-cell .qm-empty{display:inline-block;font-size:9px;padding:1px 6px;border-radius:3px;background:rgba(199,91,57,0.06);color:var(--color-bad);font-weight:500}
.qm-header{font-size:13px;color:var(--text-secondary);margin-bottom:12px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.qm-header .qm-hl{font-weight:600;color:var(--gold-primary);font-family:'Noto Serif SC',serif;font-size:15px}
.liuren-layer{margin:14px 0}
.liuren-layer .ll-header{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--gold-translucent);font-weight:600;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border-subtle);font-family:'Noto Serif SC',serif}
.liuren-layer .ll-header .ll-icon{width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;border:1.5px solid var(--gold-translucent);color:var(--gold-translucent)}
.sike-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:8px 0}
.sike-card{background:var(--bg-deepest);border:1px solid var(--border-subtle);border-radius:6px;padding:10px;text-align:center}
.sike-card .sk-name{font-size:10px;color:var(--text-tertiary);margin-bottom:3px}
.sike-card .sk-shang{font-size:16px;font-weight:700;color:var(--gold-primary);font-family:'Noto Serif SC',serif}
.sike-card .sk-arrow{font-size:10px;color:var(--text-tertiary);margin:1px 0}
.sike-card .sk-xia{font-size:14px;color:var(--text-secondary);font-family:'Noto Serif SC',serif}
.sanchuan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:8px 0}
.sanchuan-item{background:var(--bg-deepest);border:1px solid var(--border-subtle);border-radius:6px;padding:10px;text-align:center}
.sanchuan-item .sc-label{font-size:10px;color:var(--text-tertiary)}
.sanchuan-item .sc-ganzhi{font-size:17px;font-weight:700;color:var(--gold-primary);font-family:'Noto Serif SC',serif;margin:4px 0}
.sanchuan-item .sc-detail{font-size:11px;color:var(--text-secondary);line-height:1.6}
.tj-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;max-width:340px;margin:10px auto}
.tj-cell{background:var(--bg-deepest);border:1px solid var(--border-subtle);border-radius:6px;padding:6px 4px;text-align:center}
.tj-cell .tj-pos{font-size:9px;color:var(--text-tertiary)}
.tj-cell .tj-name{font-size:13px;color:var(--text-primary);font-weight:500;font-family:'Noto Serif SC',serif}
.tj-cell.tj-empty{background:transparent;border-color:transparent}
.tj-cell.tj-center{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--gold-bg-light);border-color:var(--gold-translucent);font-size:10px;color:var(--gold-secondary)}
.zw-center-card{display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--gold-bg-light);border-color:var(--gold-translucent);padding:8px 4px;text-align:center}
.zw-center-card .zwc-main{font-size:13px;font-weight:700;color:var(--gold-primary);font-family:'Noto Serif SC',serif}
.zw-center-card .zwc-sub{font-size:10px;color:var(--text-secondary);margin-top:2px}
.msg{padding:18px 22px;margin-bottom:16px;max-width:82%;border-radius:var(--radius-sm);position:relative;animation:msgIn .35s ease both;transform-origin:top center}
@keyframes msgIn{from{opacity:0;transform:translateY(12px) scale(0.97)}to{opacity:1;transform:translateY(0) scale(1)}}
.msg.system{background:var(--bg-card);border:1px solid var(--border-subtle);border-left:3px solid var(--gold-translucent);border-radius:0 var(--radius-sm) var(--radius-sm) var(--radius-sm);margin-right:auto;box-shadow:0 1px 6px rgba(0,0,0,0.04)}
.msg.system .msg-label{font-family:'Noto Serif SC',serif;font-size:13px;color:var(--gold-primary);font-weight:600;margin-bottom:8px;letter-spacing:1px;display:flex;align-items:center;gap:8px}
.msg.system .msg-label::before{content:'';display:inline-block;width:16px;height:16px;border:1.5px solid var(--gold-primary);border-radius:50%;flex-shrink:0}
.msg.system .msg-body{font-size:14px;color:var(--text-primary);line-height:1.9}
.msg.system{position:relative;padding-bottom:32px}
.msg-copy{position:absolute;bottom:6px;right:8px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;padding:0;border:1px solid var(--border-subtle);border-radius:6px;background:var(--bg-card);color:var(--text-tertiary);cursor:pointer;opacity:0;transition:opacity .25s,color .25s,background .25s;z-index:5}
.msg.system:hover .msg-copy{opacity:0.6}.msg.system:hover .msg-copy:hover{opacity:1;background:var(--gold-bg-light);color:var(--gold-primary);border-color:var(--gold-translucent)}
.msg.system .msg-body p{margin-bottom:8px}
.msg.system .msg-body p:last-child{margin-bottom:0}
.msg.user{background:var(--gold-primary);margin-left:auto;text-align:left;border-radius:var(--radius-sm) var(--radius-sm) 0 var(--radius-sm);box-shadow:0 2px 10px rgba(199,91,57,0.15);max-width:75%;width:fit-content}
.msg.user .msg-body{color:#F5F0E8;font-size:14px;line-height:1.8}
.msg.system.streaming .msg-body::after{content:'|';display:inline;animation:blinkCursor .8s step-end infinite;color:var(--gold-primary);font-weight:300;margin-left:2px}
@keyframes blinkCursor{0%,100%{opacity:1}50%{opacity:0}}
.chat-header{display:flex;align-items:center;gap:12px;padding:14px 60px 14px 24px;border-bottom:1px solid var(--border-subtle);background:var(--bg-card)}
.chat-header .ch-brand{display:flex;align-items:center;gap:10px}
.chat-header .ch-dot{width:8px;height:8px;border-radius:50%;background:var(--color-good);position:relative}
.chat-header .ch-dot::after{content:'';position:absolute;inset:-2px;border-radius:50%;border:1.5px solid var(--color-good);animation:chPulse 2s ease-in-out infinite}
@keyframes chPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(1.3)}}
.chat-header .ch-title{font-family:'Noto Serif SC',serif;font-size:16px;color:var(--gold-primary);font-weight:700;letter-spacing:3px}
.chat-header .ch-sub{font-size:11px;color:var(--text-tertiary)}
.chat-header .ch-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.chat-header .ch-pts{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary);background:var(--gold-bg-light);border:1px solid rgba(212,168,83,0.2);padding:5px 12px;border-radius:6px}
.chat-header .ch-pts .ch-pts-num{color:var(--gold-primary);font-weight:700;font-size:14px;font-family:'JetBrains Mono',monospace}
.chat-header .ch-pts .ch-pts-unit{font-size:11px}
.chat-input-area{background:var(--bg-card);border-top:1px solid var(--border-subtle);padding:12px 24px 16px}
.chat-input-row{display:flex;gap:10px;align-items:flex-end}
.chat-input-row input{flex:1;padding:12px 18px;background:var(--bg-deepest);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:inherit;transition:border-color .2s;outline:none}
.chat-input-row input:focus{border-color:var(--gold-translucent);background:var(--bg-card)}
.chat-input-row input:disabled{opacity:0.6;cursor:not-allowed}
.chat-input-row input::placeholder{color:var(--text-tertiary);font-size:13px}
.chat-input-row .btn-send{min-width:72px;padding:12px 20px;border-radius:var(--radius-sm);font-size:14px;gap:6px}
.choice-overlay{display:none;position:fixed;inset:0;z-index:400;background:rgba(0,0,0,0.2);align-items:center;justify-content:center}.choice-overlay.show{display:flex}
.choice-box{background:var(--bg-card);border-radius:var(--radius);padding:28px;max-width:420px;width:90%;text-align:center}
.choice-box h3{font-family:'Noto Serif SC',serif;font-size:20px;color:var(--gold-primary);margin-bottom:8px;letter-spacing:2px}
.choice-row{display:flex;gap:12px}.choice-row .btn{flex:1;padding:16px 8px;font-size:14px}
.choice-row .btn small{display:block;font-size:11px;font-weight:400;margin-top:4px;color:var(--text-secondary)}
.recharge-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;max-width:720px;margin:0 auto}@media(max-width:600px){.recharge-grid{grid-template-columns:1fr}}
.detail-panel{display:none;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:32px;min-height:200px;animation:panelIn .35s ease}
.detail-panel.show{display:block}
.dp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--border-subtle)}
.dp-header h3{font-family:'Noto Serif SC',serif;font-size:20px;color:var(--gold-primary);margin:0;letter-spacing:2px}
.dp-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-subtle);border-radius:50%;background:transparent;color:var(--text-tertiary);cursor:pointer;font-size:18px;transition:all .2s}
.dp-close:hover{border-color:var(--gold-translucent);color:var(--gold-primary);background:var(--gold-bg-light);transform:scale(1.05)}
@keyframes panelIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.typing-indicator{display:none;align-items:center;gap:12px;padding:14px 22px;margin-bottom:16px;background:var(--bg-card);border:1px solid var(--border-subtle);border-left:3px solid var(--gold-translucent);border-radius:0 var(--radius-sm) var(--radius-sm) var(--radius-sm);max-width:160px;margin-right:auto}
.typing-indicator.show{display:flex}
.typing-indicator .ty-dots{display:flex;gap:5px}
.typing-indicator .ty-dot{width:7px;height:7px;border-radius:50%;background:var(--text-tertiary);animation:tyBounce 1.2s ease-in-out infinite}
.typing-indicator .ty-dot:nth-child(2){animation-delay:0.2s}
.typing-indicator .ty-dot:nth-child(3){animation-delay:0.4s}
@keyframes tyBounce{0%,80%,100%{transform:scale(0.6);opacity:0.3}40%{transform:scale(1);opacity:1}}
.chat-scroll-btn{display:none;position:absolute;bottom:80px;right:28px;width:36px;height:36px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border-subtle);color:var(--text-tertiary);cursor:pointer;align-items:center;justify-content:center;box-shadow:0 2px 12px rgba(0,0,0,0.08);transition:all .2s;z-index:20}
.chat-scroll-btn.show{display:flex}
.chat-scroll-btn:hover{background:var(--gold-bg-light);color:var(--gold-primary);border-color:var(--gold-translucent)}
.chat-messages-wrap{position:relative;flex:1;overflow:hidden;display:flex;flex-direction:column}
.cost-badge{display:flex;align-items:center;gap:10px;padding:6px 0 8px;font-size:12px;color:var(--text-tertiary)}
.cost-badge .cb-item{display:flex;align-items:center;gap:4px}
.cost-badge .cb-item .cb-icon{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--text-tertiary);display:flex;align-items:center;justify-content:center;font-size:7px;font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--text-tertiary)}
.cost-badge .cb-item.cb-active{color:var(--gold-primary)}
.cost-badge .cb-item.cb-active .cb-icon{border-color:var(--gold-primary);color:var(--gold-primary)}
.cost-badge .cb-divider{width:1px;height:12px;background:var(--border-subtle)}
.cost-badge .cb-amount{font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--gold-primary)}
.choice-overlay{display:none;position:fixed;inset:0;z-index:400;background:rgba(61,53,48,0.25);align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.choice-overlay.show{display:flex}
.choice-letter{background:var(--bg-card);border-radius:var(--radius);max-width:440px;width:92%;overflow:hidden;box-shadow:0 12px 48px rgba(0,0,0,0.12);animation:letterIn .4s ease both}
@keyframes letterIn{from{opacity:0;transform:translateY(24px) scale(0.95)}to{opacity:1;transform:translateY(0) scale(1)}}
.choice-letter .cl-top{position:relative;padding:24px 28px 16px;text-align:center;overflow:hidden}
.choice-letter .cl-top::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold-primary),var(--gold-secondary),transparent)}
.choice-letter .cl-seal{width:38px;height:38px;margin:0 auto 10px;border:2px solid var(--gold-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;transform:rotate(-15deg)}
.choice-letter .cl-seal svg{width:20px;height:20px;color:var(--gold-primary)}
.choice-letter .cl-title{font-family:'Noto Serif SC',serif;font-size:18px;color:var(--gold-primary);font-weight:700;letter-spacing:3px}
.choice-letter .cl-sub{font-size:13px;color:var(--text-secondary);margin-top:4px;line-height:1.6}
.choice-letter .cl-body{padding:8px 28px 20px}
.choice-letter .cl-option{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;margin:8px 0;border:1.5px solid var(--border-subtle);border-radius:var(--radius-sm);cursor:pointer;transition:all .25s;text-align:left}
.choice-letter .cl-option:hover{border-color:var(--gold-translucent);background:var(--gold-bg-light)}
.choice-letter .cl-option.cl-recommend{border-color:var(--gold-translucent);background:var(--gold-bg-light)}
.choice-letter .cl-option .cl-opt-icon{width:36px;height:36px;flex-shrink:0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;font-family:'Noto Serif SC',serif}
.choice-letter .cl-option .cl-opt-icon.cl-icon-bazi{background:var(--gold-bg-light);color:var(--gold-primary)}
.choice-letter .cl-option .cl-opt-icon.cl-icon-gua{background:rgba(122,154,110,0.12);color:var(--color-good)}
.choice-letter .cl-option .cl-opt-text{flex:1}
.choice-letter .cl-option .cl-opt-name{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:2px}
.choice-letter .cl-option .cl-opt-desc{font-size:12px;color:var(--text-secondary);line-height:1.5}
.choice-letter .cl-option .cl-opt-tag{display:inline-block;font-size:10px;padding:1px 10px;border-radius:10px;background:var(--gold-bg-light);color:var(--gold-primary);margin-top:4px}
.choice-letter .cl-option .cl-opt-tag.cl-tag-gua{background:rgba(122,154,110,0.12);color:var(--color-good)}
.choice-letter .cl-foot{padding:4px 28px 18px;text-align:center}
.choice-letter .cl-cancel{font-size:13px;color:var(--text-tertiary);background:none;border:none;cursor:pointer;padding:8px 16px;font-family:inherit;transition:color .2s}
.choice-letter .cl-cancel:hover{color:var(--text-primary)}
.welcome-card{max-width:600px;margin:0 auto 24px;padding:32px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);text-align:center;animation:msgIn .5s ease both}
.welcome-card .wc-icon{width:48px;height:48px;margin:0 auto 14px;border:2px solid var(--gold-primary);border-radius:50%;display:flex;align-items:center;justify-content:center}
.welcome-card .wc-title{font-family:'Noto Serif SC',serif;font-size:20px;color:var(--gold-primary);font-weight:700;letter-spacing:4px;margin-bottom:6px}
.welcome-card .wc-body{font-size:14px;color:var(--text-secondary);line-height:2;margin-top:10px}
.welcome-card .wc-body span{display:inline-block;background:var(--gold-bg-light);color:var(--gold-primary);padding:2px 14px;border-radius:10px;font-size:13px;margin:2px 4px}
.welcome-card .wc-hint{font-size:13px;color:var(--text-tertiary);margin-top:14px;padding-top:14px;border-top:1px solid var(--border-subtle);line-height:1.8}
.rc-card{background:var(--bg-card);border:1.5px solid var(--border-subtle);border-radius:var(--radius);padding:24px 22px;text-align:center;cursor:pointer;transition:all .25s}.rc-card:hover{border-color:var(--gold-translucent)}
.rc-card.recommend{border-color:var(--gold-primary);background:var(--gold-bg-light)}.rc-card .rc-price{font-size:28px;color:var(--gold-primary);font-weight:700;margin-bottom:8px}
.rc-card .rc-name{font-size:16px;color:var(--text-primary);font-weight:600;letter-spacing:4px;margin-bottom:4px}
.rc-card .rc-points{font-size:14px;color:var(--text-secondary)}
.rc-card .rc-gift{font-size:13px;color:var(--color-good);margin-bottom:8px}.rc-card .rc-badge{display:inline-block;background:var(--gold-primary);color:var(--bg-deepest);font-size:10px;padding:2px 12px;border-radius:10px;font-weight:600;letter-spacing:1px}
.report-header{text-align:center;padding:32px 0 20px}
.report-title{font-family:'Noto Serif SC',serif;font-size:26px;font-weight:700;color:var(--gold-primary);letter-spacing:6px;margin-bottom:4px}
.report-sub{font-size:13px;color:var(--text-tertiary);letter-spacing:2px;margin-bottom:20px}
.report-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:28px;margin-bottom:20px;box-shadow:0 2px 12px rgba(0,0,0,0.04)}
.report-card-dk{background:var(--bg-deepest);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:28px;margin-bottom:20px;box-shadow:0 2px 12px rgba(0,0,0,0.03)}
.rpt-unlock{max-width:460px;margin:32px auto;text-align:center;padding:40px 28px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);position:relative;overflow:hidden}
.rpt-unlock::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--gold-primary),var(--gold-secondary),var(--gold-primary))}
.rpt-unlock .ru-icon{width:44px;height:44px;margin:0 auto 14px;border:2px solid var(--gold-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;color:var(--gold-primary);font-family:'Noto Serif SC',serif}
.rpt-unlock .ru-title{font-family:'Noto Serif SC',serif;font-size:22px;font-weight:700;color:var(--gold-primary);letter-spacing:4px;margin-bottom:8px}
.rpt-unlock .ru-sub{font-size:14px;color:var(--text-tertiary);margin-bottom:20px;line-height:1.6}
.rpt-unlock .ru-cost{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:20px;padding:10px 18px;background:var(--gold-bg-light);border:1px solid var(--gold-translucent);border-radius:var(--radius-sm)}
.rpt-unlock .ru-cost .ru-cost-label{font-size:14px;color:var(--text-secondary)}
.rpt-unlock .ru-cost .ru-cost-num{font-size:26px;font-weight:700;color:var(--gold-primary);font-family:'JetBrains Mono',monospace;letter-spacing:-1px}
.rpt-unlock .ru-cost .ru-cost-unit{font-size:14px;color:var(--text-secondary)}
.rpt-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:820px;margin:0 auto}.rpt-row .rpt-unlock{margin:0;max-width:none}@media(max-width:680px){.rpt-row{grid-template-columns:1fr}}
.ru-progress{margin:20px 0;display:none;padding:16px;background:var(--bg-deepest);border-radius:var(--radius-sm)}
.rup-bar{width:100%;height:8px;background:var(--border-subtle);border-radius:var(--radius-sm);overflow:hidden}
.rup-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--gold-primary),var(--gold-light));border-radius:var(--radius-sm);transition:width .6s ease}
.rup-text{font-size:13px;color:var(--text-tertiary);margin-top:8px;text-align:center}
.report-highlight{background:var(--gold-bg-light);border-left:3px solid var(--gold-translucent);padding:16px 20px;margin:14px 0;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:14px;line-height:1.8}
.report-footer{text-align:center;padding:16px 0 8px}
.page-header{text-align:center;padding:28px 0 20px}
.page-header .ph-title{font-family:'Noto Serif SC',serif;font-size:22px;color:var(--gold-primary);font-weight:700;letter-spacing:6px;margin-bottom:6px}
.page-header .ph-sub{font-size:13px;color:var(--text-tertiary);letter-spacing:2px}
.page-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius);padding:28px;font-size:14px;color:var(--text-secondary);line-height:2.1}
.page-card .pc-h4{font-family:'Noto Serif SC',serif;font-size:16px;color:var(--gold-primary);font-weight:600;margin:24px 0 10px;letter-spacing:2px;padding-left:12px;border-left:2px solid var(--gold-translucent)}
.page-card .pc-h4:first-child{margin-top:0}
.page-card p{margin-bottom:10px;text-indent:2em}
.page-card p:last-child{margin-bottom:0}
.page-foot{text-align:center;padding:20px 0}
.birth-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;margin-bottom:24px;background:var(--gold-bg-subtle);border:1px solid var(--border-subtle);border-left:2px solid var(--gold-primary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;gap:10px}
.birth-bar .bb-icon{width:auto;height:26px;border-radius:13px;border:1.5px solid var(--gold-secondary-translucent);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:10px;color:var(--gold-secondary);padding:0 8px;letter-spacing:1px}
.birth-bar .bb-info{flex:1;min-width:0}
.birth-bar .bb-info .bb-label{font-size:10px;color:var(--text-tertiary);letter-spacing:1px;margin-bottom:1px}
.birth-bar .bb-info .bb-value{font-size:14px;color:var(--text-primary);font-weight:500;font-family:'Noto Serif SC',serif}
.birth-bar .bb-info .bb-value .bb-sep{color:var(--text-tertiary);font-weight:300;margin:0 4px;font-family:'Noto Sans SC',sans-serif}
.birth-bar .bb-info .bb-gender{display:inline-block;font-size:10px;padding:1px 8px;border-radius:8px;background:var(--gold-bg-light);color:var(--gold-primary);margin-left:4px}
.birth-bar .bb-edit{flex-shrink:0}
.footer{text-align:center;padding:12px 0 24px;font-size:12px;color:var(--text-tertiary)}
.footer{text-align:center;padding:12px 0 24px;font-size:12px;color:var(--text-tertiary)}
.footer a{color:var(--text-tertiary);text-decoration:none}.footer a:hover{color:var(--gold-primary)}
#page-chat.page.active ~ .footer{display:none}
body:has(#page-chat.page.active){overflow:hidden}
@media(max-width:768px){#page-chat{margin-left:190px}.chat-keywords{width:130px}.chat-keywords .ck-title{padding:0 12px 10px;font-size:10px}.ck-item{padding:6px 12px;font-size:11px}.container{padding:0 16px}.card{padding:20px}}
@media(max-width:500px){#page-chat{margin-left:0}.chat-keywords{display:none!important}.chat-header{padding:10px 50px 10px 14px}.chat-input-area{padding:10px 14px 14px}#page-chat .chat-messages{padding:16px 14px}.msg{max-width:96%;padding:14px 16px}}
