:root{--bg: #0e1116;--panel: #161b22;--panel-2: #1d232c;--border: #2a3140;--text: #e6edf3;--text-dim: #9da7b3;--accent: #f0c97a;--highlight: rgba(240, 201, 122, .22);--highlight-strong: rgba(240, 201, 122, .45);--mutagen-lu: #4ade80;--mutagen-quan: #60a5fa;--mutagen-ke: #c084fc;--mutagen-ji: #f87171;--bright-miao: #f0c97a;--bright-wang: #fcd34d;--bright-de: #a3e635;--bright-li: #94a3b8;--bright-ping: #94a3b8;--bright-bu: #fb923c;--bright-xian: #f87171}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:PingFang TC,Noto Sans TC,Microsoft JhengHei,-apple-system,sans-serif;font-size:14px;min-height:100vh}button{font-family:inherit;cursor:pointer}.app{max-width:1400px;margin:0 auto;padding:20px}.app-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px;flex-wrap:wrap;gap:12px}.app-header h1{font-size:22px;margin:0;letter-spacing:2px}.app-header .subtitle{color:var(--text-dim);font-size:12px}.app-body{display:grid;grid-template-columns:1fr 360px;gap:20px;align-items:start}@media (max-width: 1100px){.app-body{grid-template-columns:1fr}}.input-form{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:16px}.input-form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.input-form label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-dim)}.input-form input,.input-form select{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:8px 10px;font-size:13px;font-family:inherit}.input-form .checkbox-label{flex-direction:row;align-items:center;gap:8px;cursor:pointer}.input-form button{background:var(--accent);color:#1a1f2b;border:none;border-radius:6px;padding:10px 16px;font-weight:600;font-size:13px;transition:opacity .15s}.input-form button:hover{opacity:.88}.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}.tabs{display:inline-flex;background:var(--panel);border:1px solid var(--border);border-radius:8px;padding:3px}.tabs button{background:transparent;border:none;color:var(--text-dim);padding:6px 12px;border-radius:6px;font-size:12px;transition:all .15s}.tabs button.active{background:var(--panel-2);color:var(--accent)}.chart-wrap{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px}.trad-chart{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,minmax(140px,auto));gap:4px;aspect-ratio:1 / 1;min-width:0}.trad-cell{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:6px 8px;display:flex;flex-direction:column;font-size:11px;line-height:1.4;cursor:pointer;transition:all .15s;position:relative;overflow:hidden}.trad-cell:hover{border-color:var(--accent)}.trad-cell.is-highlight{background:var(--highlight);border-color:var(--accent)}.trad-cell.is-selected{background:var(--highlight-strong);border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) inset}.trad-cell.center{grid-column:2 / 4;grid-row:2 / 4;background:var(--panel);border:1px solid var(--border);cursor:default;align-items:center;justify-content:center;text-align:center;padding:12px}.trad-cell.center:hover{border-color:var(--border)}.cell-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;gap:4px}.cell-header-left{display:flex;align-items:center;flex-wrap:wrap;gap:4px;min-width:0}.cell-palace-name{font-size:13px;font-weight:600;color:var(--accent);letter-spacing:1px}.cell-gz{font-size:10px;color:var(--text-dim)}.cell-body-marker{display:inline-block;font-size:9px;background:var(--accent);color:#1a1f2b;border-radius:3px;padding:1px 4px;margin-left:4px}.cell-stars{flex:1;display:flex;flex-direction:column;gap:2px}.star-line{display:flex;flex-wrap:wrap;gap:6px}.star{white-space:nowrap}.star.major{font-weight:600;color:var(--text)}.star.minor{color:var(--text-dim);font-size:10.5px}.star.adjective{color:#6b7280;font-size:10px}.brightness{font-size:9px;color:var(--text-dim);margin-left:2px}.brightness.廟{color:var(--bright-miao)}.brightness.旺{color:var(--bright-wang)}.brightness.得{color:var(--bright-de)}.brightness.利{color:var(--bright-li)}.brightness.平{color:var(--bright-ping)}.brightness.不{color:var(--bright-bu)}.brightness.陷{color:var(--bright-xian)}.mutagen-badge{display:inline-block;font-size:9px;border-radius:3px;padding:1px 4px;margin-left:2px;font-weight:600;color:#fff}.mutagen-badge.祿{background:var(--mutagen-lu)}.mutagen-badge.權{background:var(--mutagen-quan)}.mutagen-badge.科{background:var(--mutagen-ke)}.mutagen-badge.忌{background:var(--mutagen-ji)}.cell-footer{display:flex;justify-content:space-between;margin-top:4px;font-size:9.5px;color:var(--text-dim);border-top:1px dashed var(--border);padding-top:3px}.cell-age-range{color:var(--accent);font-weight:600}.horo-name,.horo-name-inline{font-size:9px;color:#60a5fa;background:#60a5fa26;padding:1px 5px;border-radius:3px;white-space:nowrap}.center-info{display:flex;flex-direction:column;gap:6px;font-size:12px}.center-info .center-title{font-size:16px;font-weight:600;color:var(--accent);letter-spacing:4px;margin-bottom:6px}.center-info .info-row{display:flex;justify-content:space-between;gap:12px;color:var(--text-dim)}.center-info .info-row b{color:var(--text);font-weight:500}.modern-chart{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.modern-card{background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:12px;cursor:pointer;transition:all .15s;font-size:12px}.modern-card:hover{border-color:var(--accent)}.modern-card.is-highlight{background:var(--highlight);border-color:var(--accent)}.modern-card.is-selected{background:var(--highlight-strong);border-color:var(--accent);box-shadow:0 0 0 2px var(--accent) inset}.modern-card .card-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border)}.modern-card .card-name{font-size:16px;font-weight:600;color:var(--accent);letter-spacing:2px}.modern-card .card-gz{font-size:11px;color:var(--text-dim)}.modern-card .card-section{margin-bottom:6px}.modern-card .card-section-label{font-size:10px;color:var(--text-dim);margin-bottom:2px}.detail-panel{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px;position:sticky;top:20px;max-height:calc(100vh - 40px);overflow-y:auto}.detail-panel h2{font-size:18px;margin:0 0 4px;color:var(--accent);letter-spacing:2px}.detail-panel .gz-line{font-size:12px;color:var(--text-dim);margin-bottom:16px}.detail-section{margin-bottom:14px;padding-bottom:10px;border-bottom:1px dashed var(--border)}.detail-section:last-child{border-bottom:none}.detail-section-title{font-size:11px;color:var(--text-dim);margin-bottom:6px;letter-spacing:1px}.detail-section-content{font-size:13px;line-height:1.7}.detail-empty{color:var(--text-dim);padding:40px 20px;text-align:center;font-size:13px}.horoscope-control{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.horoscope-control select{background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:6px 10px;font-size:12px;font-family:inherit}.horoscope-info{font-size:11px;color:var(--text-dim);background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:6px 10px}.horoscope-info b{color:#60a5fa}.page-tabs{display:inline-flex;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:4px;gap:2px}.page-tabs button{background:transparent;border:none;color:var(--text-dim);padding:8px 16px;border-radius:7px;font-size:13px;font-weight:500;transition:all .15s;letter-spacing:1px}.page-tabs button:hover{color:var(--text)}.page-tabs button.active{background:var(--panel-2);color:var(--accent);box-shadow:0 0 0 1px var(--border)}.header-actions{display:flex;gap:8px;align-items:center}.icon-button{background:var(--panel);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:6px 12px;font-size:12px;font-family:inherit}.icon-button:hover{border-color:var(--accent);color:var(--accent)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:24px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto}.modal h2{margin:0 0 4px;font-size:18px;color:var(--accent)}.modal .modal-sub{font-size:12px;color:var(--text-dim);margin-bottom:18px}.modal label{display:block;margin-bottom:14px}.modal label .lbl{font-size:12px;color:var(--text-dim);margin-bottom:4px;display:flex;justify-content:space-between}.modal input,.modal select,.modal textarea{width:100%;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:6px;padding:10px 12px;font-size:13px;font-family:inherit}.modal .preset-buttons{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.modal .preset-buttons button{background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);border-radius:4px;padding:4px 8px;font-size:11px}.modal .preset-buttons button:hover{color:var(--accent);border-color:var(--accent)}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.modal-actions button{border:none;border-radius:6px;padding:10px 18px;font-weight:600;font-size:13px}.modal-actions .primary{background:var(--accent);color:#1a1f2b}.modal-actions .secondary{background:var(--panel-2);color:var(--text);border:1px solid var(--border)}.interpret-block{margin-top:14px;padding-top:14px;border-top:1px dashed var(--border)}.interpret-block .interpret-button{background:linear-gradient(135deg,var(--mutagen-ke),var(--mutagen-quan));color:#fff;border:none;border-radius:6px;padding:8px 16px;font-size:12px;font-weight:600;width:100%;transition:opacity .15s}.interpret-block .interpret-button:hover{opacity:.88}.interpret-block .interpret-button:disabled{opacity:.5;cursor:not-allowed}.interpret-content{margin-top:12px;padding:12px;background:var(--panel-2);border:1px solid var(--border);border-radius:6px;font-size:13px;line-height:1.8;white-space:pre-wrap}.interpret-content.streaming:after{content:"▌";color:var(--accent);animation:blink 1s steps(2) infinite}@keyframes blink{50%{opacity:0}}.interpret-error{margin-top:12px;padding:10px 12px;background:#f871711a;border:1px solid var(--mutagen-ji);border-radius:6px;font-size:12px;color:var(--mutagen-ji)}.kline-wrap{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:20px}.kline-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px}.kline-header h2{margin:0;font-size:16px;color:var(--accent);letter-spacing:2px}.kline-legend{font-size:11px;color:var(--text-dim)}.kline-legend span{margin-right:12px}.kline-legend .up{color:var(--mutagen-lu)}.kline-legend .down{color:var(--mutagen-ji)}.kline-svg{width:100%;height:auto;display:block}.kline-table{margin-top:20px;width:100%;font-size:12px;border-collapse:collapse}.kline-table th,.kline-table td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border)}.kline-table th{color:var(--text-dim);font-weight:500;font-size:11px;letter-spacing:1px}.kline-table tbody tr:hover{background:var(--panel-2)}.kline-table .num-up{color:var(--mutagen-lu)}.kline-table .num-down{color:var(--mutagen-ji)}.match-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 1000px){.match-grid{grid-template-columns:1fr}}.match-person{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px}.match-person h3{margin:0 0 12px;font-size:14px;color:var(--accent);letter-spacing:2px}.match-mini-chart{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;margin-top:10px}.match-mini-chart .mini-cell{background:var(--panel-2);border:1px solid var(--border);border-radius:4px;padding:4px 6px;font-size:10px;min-height:50px;position:relative}.match-mini-chart .mini-cell .mini-name{font-weight:600;color:var(--accent);font-size:11px}.match-mini-chart .mini-cell.center{grid-column:2 / 4;grid-row:2 / 4;background:var(--panel);display:flex;flex-direction:column;justify-content:center;align-items:center;font-size:11px;line-height:1.6}.flyto-section{margin-top:20px;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:16px}.flyto-section h3{margin:0 0 8px;font-size:14px;color:var(--accent);letter-spacing:2px}.flyto-section p.note{font-size:12px;color:var(--text-dim);margin:0 0 14px}.flyto-table{width:100%;font-size:12px;border-collapse:collapse}.flyto-table th,.flyto-table td{text-align:left;padding:8px 10px;border-bottom:1px solid var(--border)}.flyto-table th{color:var(--text-dim);font-weight:500;font-size:11px}.flyto-table .star-name{font-weight:600;color:var(--text)}.flyto-table tbody tr:hover{background:var(--panel-2)}.match-score-card{background:linear-gradient(135deg,var(--panel-2),var(--panel));border:1px solid var(--accent);border-radius:10px;padding:20px;margin-top:16px;text-align:center}.match-score-card .score-num{font-size:48px;font-weight:700;color:var(--accent);line-height:1}.match-score-card .score-label{font-size:12px;color:var(--text-dim);margin-top:6px;letter-spacing:2px}.match-score-card .score-text{margin-top:14px;font-size:13px;color:var(--text);line-height:1.7}.self-mutagen-strip{display:flex;gap:2px;margin-top:2px}.self-mutagen-badge{font-size:9px;font-weight:600;padding:0 4px;border-radius:3px;color:#fff;border:1px dashed rgba(255,255,255,.4);letter-spacing:.5px}.self-mutagen-badge.祿{background:var(--mutagen-lu)}.self-mutagen-badge.權{background:var(--mutagen-quan)}.self-mutagen-badge.科{background:var(--mutagen-ke)}.self-mutagen-badge.忌{background:var(--mutagen-ji)}.trad-chart-wrapper{position:relative}.flying-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:5}.flying-overlay line{stroke-linecap:round}.flying-overlay .arrow-head{fill:currentColor}.flying-legend{position:absolute;top:8px;right:8px;background:#0e1116f0;border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:11.5px;z-index:10;max-width:250px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:none}.flying-legend-section{margin-bottom:8px}.flying-legend-section:last-child{margin-bottom:0}.flying-legend-title{font-size:10.5px;color:var(--accent);font-weight:600;margin-bottom:5px;letter-spacing:.5px;padding-bottom:3px;border-bottom:1px dashed var(--border)}.flying-legend-row{display:flex;align-items:center;gap:5px;padding:2px 0;white-space:nowrap}.flying-legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.flying-legend-star{color:var(--text);font-weight:500}.flying-legend-arrow{color:var(--text-dim)}.flying-legend-dest{color:var(--accent);font-weight:500}.flying-toggle{display:inline-flex;align-items:center;gap:6px;background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);border-radius:6px;padding:6px 12px;font-size:12px;font-family:inherit;cursor:pointer}.flying-toggle.active{color:var(--accent);border-color:var(--accent)}.flying-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px}.flying-row .star{font-weight:600;color:var(--text)}.flying-row .arrow{color:var(--text-dim);font-size:14px}.flying-row .to-palace{color:var(--accent);font-weight:500}.flying-row .self-tag{color:var(--mutagen-ji);font-size:10px;background:#f8717126;padding:1px 6px;border-radius:3px;margin-left:4px}
