.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 #000;background:#fff;aspect-ratio:4 / 3;min-height:0}.chart-cell{border:1px solid #000;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:#555}.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}.star-eng{font-size:11px}.box-branch{margin-top:auto;padding-top:3px;border-top:1px solid #ddd;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:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.about-dialog{background:#fff;padding:28px 32px;border-radius:8px;max-width:440px;width:90%;box-shadow:0 4px 24px #0003}.about-dialog h2{margin-bottom:4px;font-size:20px}.about-version{color:#666;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}.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 #ccc}.interp-card.interp-positive{background:#f0fdf4;border-left-color:#22c55e}.interp-card.interp-neutral{background:#fefce8;border-left-color:#eab308}.interp-card.interp-challenging{background:#fef2f2;border-left-color:#ef4444}.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:#666}.interp-text{font-size:13px;line-height:1.5;color:#333;margin:0}.interp-extra{font-size:12px;font-style:italic;color:#555;margin:4px 0 0;padding-top:4px;border-top:1px dashed #ddd}.interp-star.minor{color:#555}.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 #ccc;border-radius:4px;text-align:center}.monthly-overlay{margin-top:2px;padding-top:2px;border-top:1px dashed #99f6e4}.monthly-star{color:#0d9488;font-weight:500;font-size:11px}.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 #ccc;border-radius:4px}.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}.btn-upgrade{background:#f59e0b!important;color:#78350f!important;font-size:16px;padding:12px 32px}.btn-upgrade:hover{background:#d97706!important}@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 #000;background:#fff}.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:#f5f5f5;z-index:10;padding:4px 0}.chart-grid-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.chart-grid{min-width:600px}}@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}}*{margin:0;padding:0;box-sizing:border-box}html{touch-action:manipulation}body{font-family:Segoe UI,Helvetica Neue,Arial,sans-serif;background:#f5f5f5;color:#222;-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 #d1d5db;border-radius:4px;background:transparent;font-size:13px;cursor:pointer;color:#666}.locale-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}@media print{.locale-switcher{display:none!important}}.input-form-container{max-width:480px;margin:40px auto;padding:32px;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.input-form-container h1{text-align:center;margin-bottom:24px;font-size:24px;color:#333}.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 #ccc;border-radius:4px;font-size:16px}.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:#2563eb;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:#1d4ed8}.btn-primary:active:not(:disabled){background:#1e40af}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:10px 16px;background:#e5e7eb;color:#333;border:1px solid #d1d5db;border-radius:4px;font-size:14px;cursor:pointer;-webkit-tap-highlight-color:transparent}.btn-secondary:hover{background:#d1d5db}.btn-secondary:active{background:#c0c4c9}.error-message{color:#dc2626;font-size:14px;padding:8px;background:#fef2f2;border:1px solid #fecaca;border-radius:4px}.status-message{color:#16a34a;font-size:14px;padding:8px;background:#f0fdf4;border:1px solid #bbf7d0;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}.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}}.landing-section{max-width:800px;margin:0 auto;padding:48px 24px 32px}.landing-headline{text-align:center;font-size:28px;color:#1e293b;margin-bottom:8px}.landing-subheadline{text-align:center;font-size:16px;color:#64748b;margin-bottom:40px;line-height:1.5}.landing-features{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:48px}.feature-card{background:#fff;padding:24px;border-radius:8px;box-shadow:0 1px 4px #00000014;text-align:center}.feature-icon{font-size:32px;margin-bottom:8px;color:#2563eb}.feature-card h3{font-size:18px;color:#1e293b;margin-bottom:6px}.feature-card p{font-size:14px;color:#64748b;line-height:1.5}.landing-about{background:#fff;padding:32px;border-radius:8px;box-shadow:0 1px 4px #00000014;margin-bottom:32px}.landing-about h2{font-size:22px;color:#1e293b;margin-bottom:12px}.landing-about p{font-size:15px;color:#475569;line-height:1.7}.landing-footer{text-align:center;padding:16px 0;color:#94a3b8;font-size:13px}@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}}@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)}}
