:root{--bg: #04060d;--panel: rgba(13, 20, 40, .72);--line: rgba(96, 165, 250, .14);--line-strong: rgba(125, 211, 252, .42);--text: #d9e4ff;--dim: #7787a8;--faint: #4a5878;--gold: #f3c96b;--gold-deep: #c9992e;--cyan: #55d7ff;--c-decadal: #2ee6c8;--c-yearly: #5ba0ff;--c-monthly: #ffa14e;--c-daily: #c78bff;--c-hourly: #ff77b7;--c-age: #f2d264;--m-lu: #34d399;--m-quan: #38bdf8;--m-ke: #fbbf24;--m-ji: #e35bd8;--font-body: "Microsoft YaHei UI", "Microsoft YaHei", "PingFang SC", "Source Han Sans SC", "Noto Sans CJK SC", sans-serif;--font-display: "KaiTi", "STKaiti", "DFKai-SB", "BiauKai", var(--font-body);font-family:var(--font-body);color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}::selection{background:#55d7ff4d}*{scrollbar-width:thin;scrollbar-color:rgba(96,165,250,.3) transparent}*::-webkit-scrollbar{height:6px;width:6px}*::-webkit-scrollbar-thumb{background:#60a5fa40;border-radius:3px}*::-webkit-scrollbar-track{background:transparent}.bg-fx{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:radial-gradient(900px 520px at 82% -12%,rgba(38,64,138,.38),transparent 65%),radial-gradient(720px 430px at 6% 10%,rgba(46,230,200,.08),transparent 60%),radial-gradient(1000px 720px at 50% 118%,rgba(122,60,190,.17),transparent 65%),radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,.25),transparent 100%),radial-gradient(1.6px 1.6px at 70% 18%,rgba(255,255,255,.2),transparent 100%),radial-gradient(1.4px 1.4px at 42% 64%,rgba(255,255,255,.14),transparent 100%),radial-gradient(1.8px 1.8px at 88% 52%,rgba(255,255,255,.18),transparent 100%),radial-gradient(1.2px 1.2px at 12% 82%,rgba(255,255,255,.12),transparent 100%)}.app{position:relative;z-index:1;max-width:1280px;margin:0 auto;padding:0 18px 34px}.top{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;padding-top:20px}.top h1{margin:0;font-family:var(--font-display);font-size:2rem;font-weight:700;letter-spacing:.4em;background:linear-gradient(120deg,#f3c96b,#fff2cf 45%,#f3c96b 75%);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 16px rgba(243,201,107,.4))}.top-sub{color:var(--dim);font-size:.75rem;letter-spacing:.3em}.top-actions{margin-left:auto;display:flex;gap:8px}.top-actions button{padding:6px 14px;border-radius:9px;border:1px solid rgba(85,215,255,.4);background:#55d7ff12;color:var(--cyan);font-size:.75rem;font-family:inherit;letter-spacing:1px;cursor:pointer;transition:.2s}.top-actions button:hover:not(:disabled){background:#55d7ff29;box-shadow:0 0 14px #55d7ff59}.top-actions button:disabled{opacity:.4;cursor:not-allowed}.input-panel{display:flex;flex-wrap:wrap;align-items:center;gap:10px 14px;margin:14px 0;padding:10px 14px;border-radius:12px;background:#0a102299;border:1px solid var(--line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);font-size:.8rem}.fld{display:inline-flex;align-items:center;gap:7px}.fld>span{color:var(--dim);letter-spacing:1px;flex:none}.input-panel input[type=text],.input-panel input:not([type]),.input-panel input[type=date],.input-panel select{background:#050914cc;border:1px solid var(--line);border-radius:8px;color:var(--text);padding:6px 9px;font-size:.8rem;font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s}.input-panel input:focus,.input-panel select:focus{border-color:var(--line-strong);box-shadow:0 0 10px #55d7ff33}.input-panel input[name=name],.fld input[maxlength]{width:90px}.input-panel input[type=time]{width:96px}.input-panel input.residence{width:132px}.input-panel select:disabled{opacity:.55}.ts-row{flex-basis:100%;display:flex;flex-wrap:wrap;align-items:center;gap:10px 14px;padding-top:8px;border-top:1px dashed var(--line)}.ts-lng{color:var(--dim);font-size:.72rem}.seg{display:inline-flex;border:1px solid var(--line);border-radius:9px;overflow:hidden;background:#05091499}.seg button{padding:6px 14px;background:transparent;border:none;color:var(--dim);cursor:pointer;font-size:.8rem;font-family:inherit;transition:.2s}.seg button.on{background:linear-gradient(135deg,#55d7ff38,#55d7ff0d);color:var(--cyan);text-shadow:0 0 8px rgba(85,215,255,.7)}.ck{display:inline-flex;align-items:center;gap:5px;color:var(--dim);cursor:pointer}.ck input{accent-color:var(--cyan)}.btn-go{margin-left:auto;padding:8px 26px;border:none;border-radius:10px;background:linear-gradient(135deg,#1f8ea8,#55d7ff);color:#04222e;font-weight:700;font-size:.85rem;letter-spacing:.35em;text-indent:.35em;cursor:pointer;box-shadow:0 0 18px #55d7ff66,inset 0 0 8px #ffffff40;transition:.2s}.btn-go:hover{transform:translateY(-1px);box-shadow:0 0 28px #55d7ffa6,inset 0 0 10px #ffffff59}.chart-outer{overflow-x:auto;padding:4px 2px 10px}.chart-wrap{position:relative;min-width:980px;border-radius:18px;padding:9px;background:#060a168c;border:1px solid rgba(96,165,250,.26);box-shadow:0 0 46px #55d7ff1a,0 0 130px #f3c96b0f,inset 0 0 26px #040814e6}.chart{position:relative;display:grid;gap:3px;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,minmax(188px,auto));grid-template-areas:"g3 g4 g5 g6" "g2 c  c  g7" "g1 c  c  g8" "g0 g11 g10 g9"}.chart-lines{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:6}.sline{stroke:var(--cyan);stroke-width:1.5;vector-effect:non-scaling-stroke;stroke-dasharray:7 5;animation:dashflow 1.1s linear infinite;opacity:.85}.sline-opp{stroke:var(--gold)}@keyframes dashflow{to{stroke-dashoffset:-12}}.sdot{fill:var(--cyan)}.sdot-opp{fill:var(--gold)}.sdot-src{fill:#fff;filter:drop-shadow(0 0 4px #55d7ff)}.palace{position:relative;display:flex;flex-direction:column;gap:2px;padding:6px 6px 4px;min-width:0;background:linear-gradient(165deg,#101932d9,#090e1ef0);border:1px solid var(--line);border-radius:8px;cursor:pointer;transition:border-color .22s,box-shadow .22s}.palace:hover{border-color:#7dd3fc80;box-shadow:0 0 14px #55d7ff2e,inset 0 0 18px #55d7ff0d}.palace.is-focus{border-color:#f3c96bd9;box-shadow:0 0 20px #f3c96b4d,inset 0 0 22px #f3c96b14}.palace.is-opp{border-color:#55d7ffa6;box-shadow:0 0 15px #55d7ff3d}.palace.is-trine{border-color:#2ee6c88c;box-shadow:0 0 13px #2ee6c833}.p-stars{display:flex;flex-direction:column;gap:2px;min-height:0}.p-major{display:flex;flex-wrap:wrap;gap:0 3px;align-items:flex-start}.star{display:inline-flex;flex-direction:column;align-items:center;line-height:1.05}.star-name{writing-mode:vertical-lr;text-orientation:upright;letter-spacing:1px;font-size:12.5px;white-space:nowrap}.star-major .star-name{color:var(--gold);font-weight:700;font-size:13.5px;text-shadow:0 0 9px rgba(243,201,107,.5)}.star-soft .star-name{color:#7dd3fc}.star-tough .star-name{color:#ff8896}.star-lucun .star-name,.star-tianma .star-name{color:#8be9c3}.star-flower .star-name{color:#f9a8d4}.star-helper .star-name,.star-adjective .star-name{color:#9fb2d8}.star-bright{font-size:9.5px;color:var(--dim);margin-top:1px;min-height:12px}.star-muts{display:flex;flex-direction:column;gap:2px;margin-top:1px}.mut{display:block;width:14px;height:14px;line-height:14px;text-align:center;font-size:10px;font-style:normal;font-weight:700;border-radius:3px}.mut-natal[data-m=禄]{background:var(--m-lu);color:#03140b;box-shadow:0 0 8px #34d399b3}.mut-natal[data-m=权]{background:var(--m-quan);color:#03121c;box-shadow:0 0 8px #38bdf8b3}.mut-natal[data-m=科]{background:var(--m-ke);color:#1c1203;box-shadow:0 0 8px #fbbf24b3}.mut-natal[data-m=忌]{background:var(--m-ji);color:#fff;box-shadow:0 0 8px #e35bd8b3}.mut-scope{background:transparent;border:1px solid;line-height:12px}.mut-self{background:transparent;border:1px dashed;line-height:12px}.mut-self[data-m=禄]{border-color:var(--m-lu);color:var(--m-lu)}.mut-self[data-m=权]{border-color:var(--m-quan);color:var(--m-quan)}.mut-self[data-m=科]{border-color:var(--m-ke);color:var(--m-ke)}.mut-self[data-m=忌]{border-color:var(--m-ji);color:var(--m-ji)}.mut-decadal{border-color:var(--c-decadal);color:var(--c-decadal)}.mut-yearly{border-color:var(--c-yearly);color:var(--c-yearly)}.mut-monthly{border-color:var(--c-monthly);color:var(--c-monthly)}.mut-daily{border-color:var(--c-daily);color:var(--c-daily)}.mut-hourly{border-color:var(--c-hourly);color:var(--c-hourly)}.p-adj{display:flex;flex-wrap:wrap;gap:1px 5px;font-size:10px;color:var(--dim)}.p-horostars{display:flex;flex-wrap:wrap;gap:1px 5px;font-size:10px}.hs-decadal{color:var(--c-decadal);text-shadow:0 0 6px rgba(46,230,200,.4)}.hs-yearly{color:var(--c-yearly);text-shadow:0 0 6px rgba(91,160,255,.4)}.hs-monthly{color:var(--c-monthly)}.hs-daily{color:var(--c-daily)}.hs-hourly{color:var(--c-hourly)}.p-spacer{flex:1}.p-chips{display:flex;flex-wrap:wrap;gap:2px;justify-content:flex-end}.chip{font-style:normal;font-size:10px;line-height:1.35;padding:0 4px;border-radius:4px;border:1px solid;letter-spacing:1px}.chip-decadal{color:var(--c-decadal);border-color:#2ee6c88c;background:#2ee6c817}.chip-yearly{color:var(--c-yearly);border-color:#5ba0ff8c;background:#5ba0ff17}.chip-age{color:var(--c-age);border-color:#f2d26480;background:#f2d26414}.chip-monthly{color:var(--c-monthly);border-color:#ffa14e8c;background:#ffa14e17}.chip-daily{color:var(--c-daily);border-color:#c78bff8c;background:#c78bff17}.chip-hourly{color:var(--c-hourly);border-color:#ff77b78c;background:#ff77b717}.p-foot{display:flex;align-items:flex-end;justify-content:space-between;gap:4px;margin-top:2px;border-top:1px dashed rgba(96,165,250,.16);padding-top:3px}.p-f-l,.p-f12{display:flex;flex-direction:column;font-size:9px;color:var(--faint);line-height:1.3}.p-f-m{text-align:center}.p-name{font-family:var(--font-display);font-size:15px;color:var(--gold);letter-spacing:2px;text-shadow:0 0 10px rgba(243,201,107,.4);white-space:nowrap}.p-body{font-style:normal;font-family:var(--font-body);font-size:9.5px;font-weight:700;color:#2b0716;background:linear-gradient(135deg,#ff77b7,#ff9db8);border-radius:3px;padding:1px 3px;margin-left:4px;vertical-align:2px;letter-spacing:1px;box-shadow:0 0 10px #ff77b7a6}.p-origin{font-style:normal;font-family:var(--font-body);font-size:9.5px;font-weight:700;color:var(--gold);border:1px solid rgba(243,201,107,.65);border-radius:3px;padding:0 3px;margin-left:4px;vertical-align:2px;letter-spacing:1px;box-shadow:0 0 8px #f3c96b4d}.p-range{font-size:9.5px;color:var(--dim);margin-top:1px}.p-ages{font-size:8px;color:var(--faint);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px}.p-f-r{display:flex;align-items:flex-end;gap:3px}.p-gz{writing-mode:vertical-lr;text-orientation:upright;font-size:12px;font-weight:600;color:var(--cyan);text-shadow:0 0 8px rgba(85,215,255,.55)}.center{grid-area:c;position:relative;display:flex;flex-direction:column;padding:16px 18px 12px;border:1px solid rgba(125,211,252,.22);border-radius:10px;background:radial-gradient(130% 105% at 50% 0%,#142042c7,#070b19f0);overflow:hidden}.center:before{content:"";position:absolute;top:-45%;right:-45%;bottom:-45%;left:-45%;background:conic-gradient(from 0deg,transparent 0deg,rgba(85,215,255,.5) 24deg,transparent 60deg,transparent 170deg,rgba(243,201,107,.4) 200deg,transparent 240deg,transparent 360deg);opacity:.07;animation:center-sweep 26s linear infinite;pointer-events:none}@keyframes center-sweep{to{transform:rotate(360deg)}}.center>*{position:relative}.center-head{display:flex;align-items:baseline;gap:10px;margin-bottom:10px}.center-head h2{margin:0;font-family:var(--font-display);font-size:1.55rem;letter-spacing:.35em;background:linear-gradient(120deg,#f3c96b,#fff3d1 50%,#f3c96b);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 12px rgba(243,201,107,.35))}.center-sub{font-size:.65rem;color:var(--dim);letter-spacing:.35em}.center-info{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:3px 16px;font-size:12px}.ci{display:flex;gap:8px;min-width:0}.ci b{flex:none;font-weight:400;color:var(--dim);letter-spacing:1px}.ci span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ci-wide{grid-column:1 / -1}.ci-wide span{color:var(--gold)}.pillars{display:flex;gap:10px;margin:12px 0 4px}.pillar{display:flex;flex-direction:column;align-items:center;padding:5px 9px 6px;border:1px solid rgba(243,201,107,.28);border-radius:7px;background:#f3c96b0d;box-shadow:inset 0 0 12px #f3c96b0d}.pillar i{font-style:normal;font-size:9px;color:var(--dim);margin-bottom:2px}.pillar b{font-family:var(--font-display);font-size:15px;line-height:1.15;color:var(--gold)}.target-line{margin-top:auto;padding-top:8px;font-size:11.5px;color:var(--dim)}.tl-tag{display:inline-block;margin-right:7px;padding:0 6px;border:1px solid rgba(85,215,255,.4);border-radius:4px;color:var(--cyan);font-size:10px;letter-spacing:2px}.depth-row{display:flex;gap:6px;flex-wrap:wrap;padding-top:8px}.db{width:34px;height:30px;border-radius:8px;border:1px solid var(--line);background:#ffffff08;color:var(--dim);font-size:13px;font-family:inherit;cursor:pointer;transition:.18s}.db:hover{border-color:var(--line-strong);color:var(--text)}.db-natal.on{background:#d9e4ff;color:#0a1020;border-color:transparent;box-shadow:0 0 12px #d9e4ff80}.db-decadal.on{background:var(--c-decadal);color:#04211b;border-color:transparent;box-shadow:0 0 13px #2ee6c899}.db-yearly.on{background:var(--c-yearly);color:#071429;border-color:transparent;box-shadow:0 0 13px #5ba0ff99}.db-monthly.on{background:var(--c-monthly);color:#2a1503;border-color:transparent;box-shadow:0 0 13px #ffa14e99}.db-daily.on{background:var(--c-daily);color:#1d0a33;border-color:transparent;box-shadow:0 0 13px #c78bff99}.db-hourly.on{background:var(--c-hourly);color:#2b0716;border-color:transparent;box-shadow:0 0 13px #ff77b799}.db-today{color:var(--gold);border-color:#f3c96b66}.db-today:hover{box-shadow:0 0 12px #f3c96b66;color:var(--gold)}.hbar{position:sticky;bottom:10px;z-index:20;display:flex;flex-direction:column;gap:5px;margin-top:14px;padding:9px 10px;border-radius:14px;background:#070b18db;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid rgba(96,165,250,.22);box-shadow:0 8px 34px #0000008c,0 0 26px #55d7ff17,inset 0 0 18px #0a122899}.hrow{display:flex;gap:8px;align-items:stretch;min-width:0}.hlabel{flex:none;width:48px;border-radius:8px;border:1px solid var(--line);background:#ffffff05;color:var(--faint);font-size:12px;font-family:inherit;letter-spacing:3px;cursor:pointer;transition:.2s}.hrow-decadal .hlabel.on{color:var(--c-decadal);border-color:#2ee6c899;box-shadow:0 0 11px #2ee6c84d;text-shadow:0 0 7px rgba(46,230,200,.8)}.hrow-yearly .hlabel.on{color:var(--c-yearly);border-color:#5ba0ff99;box-shadow:0 0 11px #5ba0ff4d;text-shadow:0 0 7px rgba(91,160,255,.8)}.hrow-monthly .hlabel.on{color:var(--c-monthly);border-color:#ffa14e99;box-shadow:0 0 11px #ffa14e4d;text-shadow:0 0 7px rgba(255,161,78,.8)}.hrow-daily .hlabel.on{color:var(--c-daily);border-color:#c78bff99;box-shadow:0 0 11px #c78bff4d;text-shadow:0 0 7px rgba(199,139,255,.8)}.hrow-hourly .hlabel.on{color:var(--c-hourly);border-color:#ff77b799;box-shadow:0 0 11px #ff77b74d;text-shadow:0 0 7px rgba(255,119,183,.8)}.hcells{display:flex;gap:4px;flex:1;min-width:0;overflow-x:auto;padding-bottom:2px}.hcells-grid{display:grid;grid-template-columns:repeat(15,minmax(0,1fr));overflow:visible}.hcell{flex:none;min-width:58px;padding:3px 6px;border-radius:7px;border:1px solid rgba(96,165,250,.14);background:#0d14288c;color:var(--text);font-family:inherit;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1.3;transition:border-color .16s,box-shadow .16s,background .16s,transform .16s}.hcells-grid .hcell{min-width:0;padding:2px}.hcell b{font-size:12px;font-weight:600;white-space:nowrap}.hcell i{font-style:normal;font-size:9.5px;color:var(--dim);white-space:nowrap}.hcell:hover{border-color:var(--line-strong);box-shadow:0 0 10px #55d7ff2e;transform:translateY(-1px)}.hcell.on-decadal{border-color:var(--c-decadal);background:#2ee6c824;box-shadow:0 0 14px #2ee6c861}.hcell.on-decadal i,.hcell.on-decadal b{color:#d9fff7}.hcell.on-yearly{border-color:var(--c-yearly);background:#5ba0ff26;box-shadow:0 0 14px #5ba0ff66}.hcell.on-yearly i,.hcell.on-yearly b{color:#e3edff}.hcell.on-monthly{border-color:var(--c-monthly);background:#ffa14e26;box-shadow:0 0 14px #ffa14e66}.hcell.on-monthly i,.hcell.on-monthly b{color:#fff0e0}.hcell.on-daily{border-color:var(--c-daily);background:#c78bff29;box-shadow:0 0 14px #c78bff6b}.hcell.on-daily i,.hcell.on-daily b{color:#f4eaff}.hcell.on-hourly{border-color:var(--c-hourly);background:#ff77b726;box-shadow:0 0 14px #ff77b766}.hcell.on-hourly i,.hcell.on-hourly b{color:#ffe9f3}.err-box{margin:30px auto;max-width:560px;padding:18px 22px;border:1px solid rgba(255,136,150,.4);border-radius:12px;background:#46101a4d;color:#ffb3bd;font-size:.85rem;text-align:center}.foot{margin-top:22px;text-align:center;font-size:.72rem;color:var(--faint);letter-spacing:1px}.foot a{color:var(--dim);text-decoration:none;border-bottom:1px dotted var(--faint)}.foot a:hover{color:var(--cyan)}@media (max-width: 1024px){.chart-wrap{min-width:0;padding:5px;border-radius:12px}.chart{gap:2px;grid-template-rows:repeat(4,minmax(150px,auto))}.palace{padding:3px 3px 2px;border-radius:5px;gap:1px}.star-name{font-size:10.5px;letter-spacing:0}.star-major .star-name{font-size:11.5px}.star-bright{font-size:8px;min-height:10px}.mut{width:11px;height:11px;line-height:11px;font-size:8px;border-radius:2px}.mut-scope{line-height:9px}.p-adj,.p-horostars{font-size:8.5px;gap:0 3px}.chip{font-size:8px;padding:0 2px;letter-spacing:0;border-radius:3px}.p-chips{gap:1px}.p-name{font-size:11.5px;letter-spacing:1px}.p-body,.p-origin{font-size:8px;padding:0 2px;margin-left:2px;letter-spacing:0}.p-f-l,.p-f12{font-size:7.5px}.p-gz{font-size:10px}.p-range{font-size:8px}.p-ages{display:none}.center{padding:8px 9px 6px}.center-head{margin-bottom:4px;gap:6px}.center-head h2{font-size:1.05rem;letter-spacing:.2em}.center-sub{display:none}.center-info{grid-template-columns:1fr;gap:1px;font-size:10px}.ci{gap:5px}.pillars{gap:5px;margin:6px 0 2px}.pillar{padding:3px 5px;border-radius:5px}.pillar b{font-size:12px}.pillar i{font-size:8px}.target-line{font-size:9px;padding-top:4px}.tl-tag{font-size:8px;padding:0 3px;margin-right:4px}.depth-row{gap:4px;padding-top:5px}.db{width:26px;height:24px;font-size:11px;border-radius:6px}}@media (max-width: 760px){.app{padding:0 8px 20px}.top{gap:10px;padding-top:12px}.top h1{font-size:1.35rem;letter-spacing:.25em}.top-sub{display:none}.top-actions button{padding:5px 9px;font-size:.68rem}.input-panel{gap:8px 10px;padding:8px 10px;margin:10px 0}.btn-go{margin-left:0;width:100%}.chart-outer{padding:2px 0 6px}.hbar{padding:5px;gap:3px;bottom:4px;border-radius:10px}.hlabel{width:30px;letter-spacing:0;font-size:10.5px;border-radius:6px}.hcells{gap:3px}.hcell{min-width:48px;padding:2px 4px;border-radius:5px}.hcell b{font-size:10.5px}.hcell i{font-size:8.5px}.hcells-grid{grid-template-columns:repeat(10,minmax(0,1fr));gap:2px}.hcells-grid .hcell:not(.on) i{display:none}.center{overflow-y:auto}.target-line{margin-top:6px}}
