.chart-page{padding:4px;max-width:1200px;margin:0 auto}.chart-toolbar{display:flex;gap:6px;margin-bottom:4px;flex-wrap:wrap}.chart-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr);border:2px solid var(--chart-border);background:var(--surface);aspect-ratio:4 / 3;min-height:0}.chart-cell{border:1px solid var(--chart-border);overflow:hidden;min-width:0;min-height:0}.chart-center-cell{border:none}.chart-box{display:flex;flex-direction:column;height:100%;padding:2px 4px;font-size:12px}.box-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:2px}.palace-name{font-weight:700;font-size:14px}.limits{font-size:12px;color:var(--text-muted)}.box-stars{flex:1;overflow-y:auto;line-height:1.4}.star{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.major-star{font-weight:600}.major-star.north{color:#1e40af}.major-star.south{color:#b91c1c}.major-star.borrowed{color:#708090;font-weight:600}.minor-star{font-weight:400}.brightness{font-size:10px;font-weight:700;margin-left:2px;vertical-align:super}.brightness-miao{color:#b45309}.brightness-wang{color:#15803d}.brightness-de{color:#0369a1}.brightness-li{color:#6d28d9}.brightness-ping{color:#6b7280}.brightness-bu{color:#c2410c}.brightness-xian{color:#dc2626}[data-theme=dark] .brightness-miao{color:#fbbf24}[data-theme=dark] .brightness-wang{color:#4ade80}[data-theme=dark] .brightness-de{color:#38bdf8}[data-theme=dark] .brightness-li{color:#a78bfa}[data-theme=dark] .brightness-ping{color:#9ca3af}[data-theme=dark] .brightness-bu{color:#fb923c}[data-theme=dark] .brightness-xian{color:#f87171}.sihua{font-size:10px;font-weight:700;margin-left:2px;vertical-align:super}.sihua-lu{color:#15803d}.sihua-quan{color:#b45309}.sihua-ke{color:#0369a1}.sihua-ji{color:#dc2626}[data-theme=dark] .sihua-lu{color:#4ade80}[data-theme=dark] .sihua-quan{color:#fbbf24}[data-theme=dark] .sihua-ke{color:#38bdf8}[data-theme=dark] .sihua-ji{color:#f87171}.star-eng{font-size:11px}.box-branch{margin-top:auto;padding-top:3px;border-top:1px solid var(--border);font-size:13px;text-align:center}.branch-char{font-size:18px;font-weight:700}.chinese-glyph{font-size:18px;font-weight:700;font-family:Noto Sans SC,Microsoft YaHei,PingFang SC,Hiragino Sans GB,SimSun,STSong,sans-serif}.chart-center{display:flex;flex-direction:column;justify-content:center;padding:14px 18px;height:100%;font-size:13px;overflow-y:auto}.chart-name{text-align:center;font-size:22px;margin-bottom:14px}.chart-dates{margin-bottom:12px}.date-row,.pillar-row,.meta-row{display:flex;gap:6px;align-items:center;margin-bottom:3px;flex-wrap:wrap}.date-label,.pillar-label{width:85px;flex-shrink:0}.date-colon,.pillar-colon{width:12px}.four-pillars h3{font-size:15px;font-style:italic;margin-bottom:5px;margin-top:10px}.pillar-row .chinese-glyph{font-size:16px;margin-right:3px}.chart-meta{margin-top:10px;display:flex;gap:28px;flex-wrap:wrap}.meta-label{font-weight:600;font-style:italic;margin-right:5px}.element-weights{margin-top:10px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}.weight-item{font-size:13px}.about-overlay{position:fixed;inset:0;background:var(--overlay-bg);display:flex;align-items:center;justify-content:center;z-index:100}.about-dialog{background:var(--surface);padding:28px 32px;border-radius:8px;max-width:440px;width:90%;box-shadow:var(--shadow);color:var(--text)}.about-dialog h2{margin-bottom:4px;font-size:20px}.about-version{color:var(--text-muted);font-size:13px;margin-bottom:12px}.about-dialog p{margin-bottom:10px;font-size:14px;line-height:1.5}.about-legend{font-size:13px!important}.about-dialog button{margin-top:8px}.compare-dialog{max-width:560px}.compare-person-a{font-size:14px;margin-bottom:12px}.compare-saved{margin-bottom:12px}.compare-saved-label{font-size:12px;color:var(--text-dim);margin-bottom:6px}.compare-saved-list{display:flex;flex-wrap:wrap;gap:6px}.compare-saved-btn{font-size:12px;padding:4px 10px}.compare-form input[type=text]{width:100%;padding:8px;margin-bottom:8px;border:1px solid var(--border);border-radius:4px;font-size:14px;background:var(--bg);color:var(--text-body)}.compare-form-row{display:flex;gap:6px;margin-bottom:6px}.compare-form-row select{flex:1;padding:6px;font-size:12px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text-body)}.compare-form .btn-primary{width:100%;margin-top:8px}.compare-table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13px}.compare-table th,.compare-table td{border:1px solid var(--border-subtle);padding:8px 10px;text-align:left}.compare-table th{background:var(--surface);font-weight:600;font-size:12px}.compare-palace-name{font-weight:600;color:var(--text-heading)}.compare-notes{margin-top:12px}.compare-notes h3{font-size:14px;margin-bottom:6px}.compare-notes p{font-size:13px;line-height:1.6;color:var(--text-body)}.daxian-dialog{max-width:500px}.daxian-dialog h3{margin-top:12px;margin-bottom:6px;font-size:14px}.daxian-palace,.daxian-age{font-size:15px!important;margin-bottom:4px!important}.daxian-stars{margin-bottom:12px;line-height:1.6}.daxian-stars .star{font-size:14px;white-space:normal}.daxian-stars .major-star{font-size:15px}.daxian-interpretations{margin-top:12px;max-height:40vh;overflow-y:auto}.daxian-interpretations h3{margin-bottom:8px}.interp-card{padding:10px 12px;margin-bottom:8px;border-radius:6px;border-left:4px solid var(--border)}.interp-card.interp-positive{background:var(--success-bg);border-left-color:#22c55e}.interp-card.interp-neutral{background:#fefce8;border-left-color:#eab308}.interp-card.interp-challenging{background:var(--error-bg);border-left-color:#ef4444}[data-theme=dark] .interp-card.interp-neutral{background:#422006}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .interp-card.interp-neutral{background:#422006}}.interp-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}.interp-star{font-weight:700;font-size:14px}.interp-star.north{color:#1e40af}.interp-star.south{color:#b91c1c}.interp-keywords{font-size:12px;font-style:italic;color:var(--text-muted)}.interp-text{font-size:13px;line-height:1.5;color:var(--text-secondary);margin:0}.interp-extra{font-size:12px;font-style:italic;color:var(--text-muted);margin:4px 0 0;padding-top:4px;border-top:1px dashed var(--border)}.interp-star.minor{color:var(--text-muted)}.interp-star.combination{color:#7c3aed;font-style:italic}.interp-combination{border-left-color:#7c3aed!important;background:#f5f3ff}[data-theme=dark] .interp-combination{background:#1e1b4b}@media(prefers-color-scheme:dark){:root:not([data-theme=light]) .interp-combination{background:#1e1b4b}}.annual-overlay{margin-top:2px;padding-top:2px;border-top:1px dashed #c4b5fd}.annual-star{color:#7c3aed;font-weight:500;font-size:11px}.annual-palace-badge{display:inline-block;background:#7c3aed;color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:3px;margin-bottom:2px}.annual-palace-active{box-shadow:inset 0 0 0 2px #7c3aed}.annual-year-input{width:70px;padding:3px 6px;font-size:13px;border:1px solid var(--border);border-radius:4px;text-align:center;background:var(--input-bg);color:var(--text)}.monthly-overlay{margin-top:2px;padding-top:2px;border-top:1px dashed #99f6e4}.monthly-star{color:#0d9488;font-weight:500;font-size:11px}.transit-desc{font-size:10px;font-weight:400;line-height:1.4;margin-top:2px;opacity:.85}.monthly-palace-badge{display:inline-block;background:#0d9488;color:#fff;font-size:9px;font-weight:700;padding:1px 4px;border-radius:3px;margin-bottom:2px}.monthly-palace-active{box-shadow:inset 0 0 0 2px #0d9488}.monthly-month-select{padding:3px 6px;font-size:13px;border:1px solid var(--border);border-radius:4px;background:var(--input-bg);color:var(--text)}.btn-active{background:#7c3aed!important;color:#fff!important;border-color:#7c3aed!important}.btn-active-monthly{background:#0d9488!important;color:#fff!important;border-color:#0d9488!important}.paywall-gate{text-align:center;padding:24px 16px;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:8px;margin-top:8px}.paywall-gate p{margin-bottom:12px;color:#92400e;font-size:15px}.paywall-disclosure{margin-top:12px;color:#78350f;font-size:12px;line-height:1.4}.paywall-disclosure a{color:#78350f;text-decoration:underline}.btn-upgrade{background:#f59e0b!important;color:#78350f!important;font-size:16px;padding:12px 32px}.btn-upgrade:hover{background:#d97706!important}.restore-purchase{margin-top:12px}.btn-link{background:none;border:none;color:#92400e;text-decoration:underline;cursor:pointer;font-size:13px;padding:0}.btn-link:hover{color:#78350f}.restore-form{display:flex;gap:8px;align-items:center;justify-content:center;margin-top:8px;flex-wrap:wrap}.restore-form input[type=email]{padding:6px 10px;border:1px solid #d97706;border-radius:4px;font-size:13px;width:220px;background:var(--input-bg);color:var(--text)}.restore-error{color:var(--error-text);font-size:13px;width:100%;margin-top:4px}@media(max-width:1024px){.chart-box{font-size:10px;padding:2px 4px}.palace-name{font-size:12px}.star-eng{font-size:9px}.box-branch{font-size:11px}.branch-char{font-size:14px}.chart-center{font-size:11px;padding:8px 10px}.chart-name{font-size:16px}}@media(max-width:768px){.chart-page{padding:8px}.chart-grid-wrapper{overflow:auto;-webkit-overflow-scrolling:touch;border:2px solid var(--chart-border);background:var(--surface)}.chart-grid{min-width:700px;aspect-ratio:4 / 3;border:none}.chart-box{font-size:9px;padding:2px 3px}.palace-name{font-size:11px}.limits{font-size:9px}.star-eng{font-size:8px}.box-branch{font-size:10px}.branch-char,.chinese-glyph{font-size:12px}.chart-center{font-size:10px;padding:6px 8px}.chart-name{font-size:14px;margin-bottom:6px}.four-pillars h3,.pillar-row .chinese-glyph{font-size:11px}.chart-meta{gap:12px}}@media(max-width:480px){.chart-page{padding:4px}.chart-toolbar{position:sticky;top:0;background:var(--bg);z-index:10;padding:4px 0}.chart-grid-wrapper{overflow:hidden;border:none}.chart-grid{min-width:0;gap:1px}.chart-box{font-size:10px;padding:2px 3px;line-height:1.25;min-height:0}.chart-box .star-eng,.chart-box .limits{display:none}.palace-name{font-size:10px}.brightness,.sihua{font-size:8px;margin-left:1px}.box-branch{font-size:9px}.branch-char{font-size:13px}.annual-palace-badge,.monthly-palace-badge{font-size:8px;padding:0 3px}.chart-center{font-size:10px;padding:6px 8px;gap:4px}.chart-name{font-size:14px}.date-label,.pillar-label{min-width:56px}}@media(max-width:360px){.chart-box{font-size:9px;padding:1px 2px}.palace-name{font-size:9px}.brightness,.sihua{font-size:7px}.branch-char{font-size:11px}.chart-center{font-size:9px;padding:4px 6px}.chart-name{font-size:12px}}@media print{.chart-toolbar,.about-overlay{display:none!important}.chart-page{padding:0;max-width:none}.chart-grid-wrapper{overflow:visible}.chart-grid{aspect-ratio:auto;width:100%;height:92vh;min-width:unset;border:2px solid #000}.chart-box{font-size:11pt;padding:4pt 6pt}.palace-name{font-size:12pt}.limits{font-size:10pt}.star{font-size:9pt}.star-eng{font-size:8pt}.box-branch{font-size:11pt}.branch-char,.chinese-glyph{font-size:15pt}.chart-center{font-size:11pt}.chart-name{font-size:18pt}.four-pillars h3{font-size:12pt}.pillar-row .chinese-glyph{font-size:13pt}.meta-label,.weight-item{font-size:10pt}@page{size:landscape;margin:8mm}}:root{--bg: #f5f5f5;--surface: #ffffff;--text: #222222;--text-heading: #1e293b;--text-secondary: #333333;--text-muted: #666666;--text-dim: #94a3b8;--text-body: #475569;--primary: #2563eb;--primary-hover: #1d4ed8;--primary-active: #1e40af;--border: #cccccc;--border-light: #d1d5db;--border-subtle: #f1f5f9;--chart-border: #000000;--input-bg: #ffffff;--shadow: 0 2px 8px rgba(0, 0, 0, .1);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .08);--btn-sec-bg: #e5e7eb;--btn-sec-hover: #d1d5db;--btn-sec-active: #c0c4c9;--btn-sec-text: #333333;--error-bg: #fef2f2;--error-border: #fecaca;--error-text: #dc2626;--success-bg: #f0fdf4;--success-border: #bbf7d0;--success-text: #16a34a;--overlay-bg: rgba(0, 0, 0, .5)}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--text: #e2e8f0;--text-heading: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--text-dim: #64748b;--text-body: #94a3b8;--primary: #3b82f6;--primary-hover: #2563eb;--primary-active: #1d4ed8;--border: #334155;--border-light: #334155;--border-subtle: #1e293b;--chart-border: #475569;--input-bg: #0f172a;--shadow: 0 2px 8px rgba(0, 0, 0, .4);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .3);--btn-sec-bg: #334155;--btn-sec-hover: #475569;--btn-sec-active: #4b5e78;--btn-sec-text: #e2e8f0;--error-bg: #450a0a;--error-border: #7f1d1d;--error-text: #fca5a5;--success-bg: #052e16;--success-border: #166534;--success-text: #86efac;--overlay-bg: rgba(0, 0, 0, .7)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--bg: #0f172a;--surface: #1e293b;--text: #e2e8f0;--text-heading: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--text-dim: #64748b;--text-body: #94a3b8;--primary: #3b82f6;--primary-hover: #2563eb;--primary-active: #1d4ed8;--border: #334155;--border-light: #334155;--border-subtle: #1e293b;--chart-border: #475569;--input-bg: #0f172a;--shadow: 0 2px 8px rgba(0, 0, 0, .4);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .3);--btn-sec-bg: #334155;--btn-sec-hover: #475569;--btn-sec-active: #4b5e78;--btn-sec-text: #e2e8f0;--error-bg: #450a0a;--error-border: #7f1d1d;--error-text: #fca5a5;--success-bg: #052e16;--success-border: #166534;--success-text: #86efac;--overlay-bg: rgba(0, 0, 0, .7)}}*{margin:0;padding:0;box-sizing:border-box}html{touch-action:manipulation;color-scheme:light dark}body{font-family:Segoe UI,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-text-size-adjust:100%}.app{min-height:100vh;min-height:100dvh}.locale-switcher{display:flex;justify-content:flex-end;gap:4px;padding:8px 12px}.locale-btn{padding:4px 10px;border:1px solid var(--border-light);border-radius:4px;background:transparent;font-size:13px;cursor:pointer;color:var(--text-muted)}.locale-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.theme-toggle{padding:4px 8px;border:1px solid var(--border-light);border-radius:4px;background:transparent;font-size:16px;cursor:pointer;line-height:1;margin-right:4px}.theme-toggle:hover{background:var(--btn-sec-bg)}@media print{.locale-switcher{display:none!important}}.input-form-container{max-width:480px;margin:40px auto;padding:32px;background:var(--surface);border-radius:8px;box-shadow:var(--shadow)}.input-form-container h1{text-align:center;margin-bottom:24px;font-size:24px;color:var(--text-secondary)}.input-form{display:flex;flex-direction:column;gap:14px}.form-row{display:flex;align-items:center;gap:12px}.form-row>label:first-child{width:80px;font-weight:600;font-size:14px;flex-shrink:0}.form-row input[type=text],.form-row select{flex:1;padding:8px 10px;border:1px solid var(--border);border-radius:4px;font-size:16px;background:var(--input-bg);color:var(--text)}.radio-group{display:flex;gap:16px}.radio-group label{display:flex;align-items:center;gap:4px;font-size:14px;cursor:pointer}.radio-group input[type=radio]{width:18px;height:18px}.btn-primary{margin-top:8px;padding:14px;background:var(--primary);color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;-webkit-tap-highlight-color:transparent}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:active:not(:disabled){background:var(--primary-active)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:10px 16px;background:var(--btn-sec-bg);color:var(--btn-sec-text);border:1px solid var(--border-light);border-radius:4px;font-size:14px;cursor:pointer;-webkit-tap-highlight-color:transparent}.btn-secondary:hover{background:var(--btn-sec-hover)}.btn-secondary:active{background:var(--btn-sec-active)}.form-helper{display:block;margin-top:4px;font-size:12px;color:var(--text-muted, #6b7280);line-height:1.4}.form-helper a{color:var(--link, #2563eb);text-decoration:underline}.error-message{color:var(--error-text);font-size:14px;padding:8px;background:var(--error-bg);border:1px solid var(--error-border);border-radius:4px}.status-message{color:var(--success-text);font-size:14px;padding:8px;background:var(--success-bg);border:1px solid var(--success-border);border-radius:4px}.form-actions{display:flex;gap:8px}.form-actions .btn-secondary{flex:1}@media(max-width:520px){.input-form-container{margin:16px 8px;padding:20px 16px;border-radius:0;box-shadow:none;max-width:none;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.input-form-container h1{font-size:20px;margin-bottom:16px}.form-row{flex-direction:column;align-items:stretch;gap:4px}.form-row>label:first-child{width:auto}.radio-group{padding:4px 0}}.saved-charts{max-width:480px;margin:24px auto 0;padding:0 24px}.saved-charts h3{font-size:16px;color:var(--text-heading);margin-bottom:12px}.saved-charts-list{display:flex;flex-direction:column;gap:8px}.saved-chart-card{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:6px;cursor:pointer;transition:border-color .15s}.saved-chart-card:hover{border-color:var(--primary)}.saved-chart-info{display:flex;flex-direction:column;gap:2px}.saved-chart-name{font-weight:600;font-size:14px;color:var(--text-heading)}.saved-chart-detail{font-size:12px;color:var(--text-dim)}.saved-chart-delete{background:none;border:none;font-size:18px;color:var(--text-dim);cursor:pointer;padding:4px 8px;border-radius:4px}.saved-chart-delete:hover{color:#dc2626;background:#dc26261a}.landing-section{max-width:800px;margin:0 auto;padding:48px 24px 32px}.landing-headline{text-align:center;font-size:28px;color:var(--text-heading);margin-bottom:8px}.landing-subheadline{text-align:center;font-size:16px;color:var(--text-dim);margin-bottom:16px;line-height:1.5}.landing-entertainment-disclaimer{text-align:center;font-size:13px;color:var(--text-dim);margin:0 auto 40px;max-width:680px;padding:10px 16px;border:1px solid var(--border, #e5e7eb);border-radius:6px;line-height:1.5}.landing-features{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:48px}.feature-card{background:var(--surface);padding:24px;border-radius:8px;box-shadow:var(--shadow-sm);text-align:center}.feature-icon{font-size:32px;margin-bottom:8px;color:var(--primary)}.feature-card h3{font-size:18px;color:var(--text-heading);margin-bottom:6px}.feature-card p{font-size:14px;color:var(--text-dim);line-height:1.5}.landing-about{background:var(--surface);padding:32px;border-radius:8px;box-shadow:var(--shadow-sm);margin-bottom:32px}.landing-about h2{font-size:22px;color:var(--text-heading);margin-bottom:12px}.landing-about p{font-size:15px;color:var(--text-body);line-height:1.7}.landing-methodology{margin-top:12px;font-size:13px;color:var(--text-dim);font-style:italic}.landing-methodology a{color:var(--primary)}.landing-pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:48px}.pricing-card{background:var(--surface);padding:32px 24px;border-radius:8px;box-shadow:var(--shadow-sm);text-align:center;position:relative}.pricing-card h3{font-size:20px;color:var(--text-heading);margin-bottom:4px}.pricing-price{font-size:36px;font-weight:700;color:var(--text-heading);margin-bottom:16px}.pricing-price span{font-size:14px;font-weight:400;color:var(--text-dim)}.pricing-card ul{list-style:none;padding:0;text-align:left}.pricing-card li{font-size:14px;color:var(--text-body);padding:6px 0;border-bottom:1px solid var(--border-subtle)}.pricing-card li:before{content:"✓";color:#22c55e;font-weight:700;margin-right:6px}.pricing-premium{border:2px solid var(--primary)}.pricing-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--primary);color:#fff;font-size:12px;font-weight:600;padding:4px 16px;border-radius:12px;white-space:nowrap}.landing-footer{text-align:center;padding:16px 0;color:var(--text-dim);font-size:13px}.footer-links{margin-bottom:8px}.footer-privacy-rights{margin-bottom:8px;font-size:12px;opacity:.85}.footer-links a{color:var(--text-body);text-decoration:none;font-size:13px}.footer-links a:hover{color:var(--primary);text-decoration:underline}.footer-dot{margin:0 8px;color:var(--border-light)}@media(max-width:520px){.landing-section{padding:32px 16px 24px}.landing-headline{font-size:22px}.landing-features{grid-template-columns:1fr;gap:12px}.landing-about{padding:20px 16px}.landing-pricing{grid-template-columns:1fr;gap:16px}}@media print{.landing-section{display:none!important}}@supports (padding: env(safe-area-inset-top)){.app{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}}
