:root{--bg-primary: #0a0a1a;--bg-secondary: #0f0f2e;--bg-tertiary: #161640;--bg-card: rgba(20, 20, 60, .6);--bg-card-hover: rgba(30, 30, 80, .75);--accent-gold: #ffd700;--accent-gold-dim: #b8960f;--accent-purple: #a855f7;--accent-purple-ink: #ead9ff;--accent-purple-dim: #7c3aed;--accent-blue: #3b82f6;--accent-cyan: #22d3ee;--accent-pink: #ec4899;--accent-emerald: #10b981;--accent-amber: #f59e0b;--accent-red: #ef4444;--gradient-main: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-gold: linear-gradient(135deg, #ffd700 0%, #ff8c00 100%);--gradient-cosmic: linear-gradient(135deg, #0f0c29, #302b63, #24243e);--gradient-aurora: linear-gradient(135deg, #a855f7, #3b82f6, #22d3ee);--text-primary: #f0f0ff;--text-secondary: #b3b6df;--text-muted: #9b9fcf;--text-accent: #ffd700;--glass-bg: rgba(255, 255, 255, .07);--glass-border: rgba(255, 255, 255, .14);--glass-shadow: 0 8px 32px rgba(0, 0, 0, .3);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Noto Sans CJK SC", sans-serif;--font-serif: "Noto Serif", Georgia, serif;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 50%;--transition-fast: .15s ease;--transition-normal: .3s ease;--transition-slow: .5s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}.app-toast{position:fixed;left:50%;bottom:22px;transform:translate(-50%,14px);padding:10px 14px;border-radius:10px;font-size:.9rem;color:#fff;background:#0c1028eb;border:1px solid rgba(255,255,255,.16);box-shadow:0 10px 24px #00000059;opacity:0;pointer-events:none;transition:opacity .22s ease,transform .22s ease;z-index:5000}.app-toast.show{opacity:1;transform:translate(-50%)}.app-toast.warning{border-color:#f59e0b73}.app-toast.error{border-color:#ef444473}.app-toast.success{border-color:#10b98173}a{color:var(--accent-cyan);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-gold)}.stars-background{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;overflow:hidden;pointer-events:none}.star-particle{position:absolute;width:2px;height:2px;background:#fff;border-radius:50%;animation:twinkle var(--dur) ease-in-out infinite alternate;opacity:0}@keyframes twinkle{0%{opacity:.1;transform:scale(.8)}to{opacity:var(--opacity);transform:scale(1.2)}}.stars-background:before,.stars-background:after{content:"";position:absolute;border-radius:50%;filter:blur(100px);opacity:.15}.stars-background:before{width:600px;height:600px;top:-200px;right:-100px;background:radial-gradient(circle,var(--accent-purple),transparent 70%);animation:nebula-drift 20s ease-in-out infinite alternate}.stars-background:after{width:500px;height:500px;bottom:-100px;left:-100px;background:radial-gradient(circle,var(--accent-blue),transparent 70%);animation:nebula-drift 25s ease-in-out infinite alternate-reverse}@keyframes nebula-drift{0%{transform:translate(0) rotate(0)}to{transform:translate(50px,-30px) rotate(15deg)}}.glass-card{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);transition:transform var(--transition-normal),box-shadow var(--transition-normal)}.glass-card:hover{transform:translateY(-2px);box-shadow:0 12px 40px #0006,inset 0 0 0 1px #ffffff14}.app-header{position:sticky;top:0;z-index:100;background:#0a0a1ad9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--glass-border);padding:var(--space-sm) var(--space-xl)}.header-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg)}.logo-group{display:flex;align-items:center;gap:var(--space-md)}.logo-icon{font-size:2.5rem;animation:spin-slow 10s linear infinite;filter:drop-shadow(0 0 10px var(--accent-gold))}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.logo-text h1{font-family:var(--font-serif);font-size:1.5rem;font-weight:700;background:var(--gradient-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2}.logo-subtitle{font-size:.84rem;color:var(--text-secondary);letter-spacing:2px}.header-nav{display:flex;gap:var(--space-xs);overflow-x:auto;scrollbar-width:none}.header-nav::-webkit-scrollbar{display:none}.nav-btn{display:flex;flex-shrink:0;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border:none;background:transparent;color:var(--text-secondary);font-family:var(--font-sans);font-size:.94rem;font-weight:600;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.nav-btn:hover:not(:disabled){background:#ffffff0d;color:var(--text-primary)}.nav-btn.active{background:#a855f738;color:var(--accent-purple-ink);border:1px solid rgba(168,85,247,.42)}.nav-btn:disabled{opacity:.45;cursor:not-allowed}.nav-btn:focus-visible{outline:2px solid var(--accent-purple);outline-offset:2px}.nav-icon{font-size:1.1rem}.export-toolbar{position:sticky;top:78px;z-index:90;display:none;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-xl);background:#0a0a1aa6;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.08)}.export-toolbar.visible{display:flex}.export-btn{padding:.5rem .9rem;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.18);background:#ffffff14;color:var(--text-primary);font-size:.92rem;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.export-btn:hover:not(:disabled){border-color:#ffd70073;color:var(--accent-gold)}.export-btn:disabled{opacity:.45;cursor:not-allowed}.main-content{position:relative;z-index:1;max-width:1400px;margin:0 auto;padding:var(--space-xl);min-height:calc(100vh - 80px)}.section{display:none;animation:fadeSlideIn .5s ease forwards}.section.active{display:block}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.hero-section{text-align:center;padding:var(--space-3xl) 0 var(--space-2xl);position:relative}.hero-glow{position:absolute;top:50%;left:50%;width:400px;height:400px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(168,85,247,.15),transparent 70%);pointer-events:none;animation:pulse-glow 4s ease-in-out infinite}@keyframes pulse-glow{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.2);opacity:.8}}.hero-title{font-family:var(--font-serif);font-size:3rem;font-weight:800;background:linear-gradient(135deg,gold,#ff8c00,gold);background-size:200% 200%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer-text 3s ease infinite;margin-bottom:var(--space-md);position:relative;z-index:1}@keyframes shimmer-text{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.hero-desc{font-size:1.1rem;color:var(--text-secondary);max-width:600px;margin:0 auto;position:relative;z-index:1}.form-container{max-width:700px;margin:0 auto var(--space-3xl);padding:var(--space-2xl)}.form-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl);padding-bottom:var(--space-md);border-bottom:1px solid var(--glass-border)}.form-header h3{font-size:1.25rem;font-weight:600}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-lg);margin-bottom:var(--space-xl)}.form-group{display:flex;flex-direction:column;gap:var(--space-sm);min-width:0}.form-group label{font-size:.94rem;font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-xs)}.form-input{width:100%;min-width:0;padding:var(--space-md);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-sans);font-size:1rem;transition:all var(--transition-fast);outline:none}.form-input:focus{border-color:var(--accent-purple);box-shadow:0 0 0 3px #a855f733;background:#ffffff14}.form-input option{background:var(--bg-secondary);color:var(--text-primary)}.form-hint{font-size:.84rem;color:var(--text-muted);margin-top:-2px;line-height:1.55}.form-group.leap-group{transition:opacity var(--transition-fast)}.form-group.leap-group.dimmed{opacity:.58;pointer-events:none}.checkbox-toggle{display:inline-flex;align-items:center;gap:var(--space-sm);color:var(--text-secondary);font-size:.94rem;min-height:44px}.checkbox-toggle input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-purple);cursor:pointer}.checkbox-toggle input[type=checkbox]:disabled+span{opacity:.72}.gender-toggle{display:flex;gap:var(--space-sm)}.gender-btn{flex:1;padding:var(--space-md);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);background:#ffffff08;color:var(--text-secondary);font-family:var(--font-sans);font-size:.95rem;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:var(--space-xs)}.gender-btn:hover{background:#ffffff14}.gender-btn.active{border-color:#a855f770;background:#a855f738;color:var(--accent-purple-ink);font-weight:600}.gender-btn:focus-visible{outline:2px solid var(--accent-purple);outline-offset:2px}.submit-btn{width:100%;padding:var(--space-lg);border:none;border-radius:var(--radius-md);background:var(--gradient-main);color:#fff;font-family:var(--font-sans);font-size:1.1rem;font-weight:700;cursor:pointer;position:relative;overflow:hidden;transition:all var(--transition-normal)}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 8px 30px #667eea66}.submit-btn:active{transform:translateY(0)}.btn-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transform:translate(-100%);animation:btn-shimmer 3s ease infinite}@keyframes btn-shimmer{0%{transform:translate(-100%)}50%{transform:translate(100%)}to{transform:translate(100%)}}.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg);margin-top:var(--space-xl)}.feature-card{padding:var(--space-xl);text-align:center}.feature-card h4{font-size:1rem;font-weight:600;margin-bottom:var(--space-sm);color:var(--text-primary)}.feature-card p{font-size:.92rem;color:var(--text-secondary);line-height:1.5}.chart-header{text-align:center;margin-bottom:var(--space-2xl)}.chart-header h2{font-family:var(--font-serif);font-size:2rem;margin-bottom:var(--space-md)}.chart-info{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-md)}.info-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-md);background:#ffffff0d;border:1px solid var(--glass-border);border-radius:var(--radius-xl);font-size:.9rem;color:var(--text-secondary)}.info-badge .badge-value{color:var(--accent-gold);font-weight:600}.astrolabe-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr);gap:2px;background:#ffd7001a;border:2px solid rgba(255,215,0,.3);border-radius:var(--radius-md);overflow:hidden;max-width:1100px;margin:0 auto;aspect-ratio:1}.astrolabe-grid-wrap{overflow-x:auto;padding-bottom:var(--space-sm)}.palace-cell{background:var(--bg-card);padding:var(--space-sm);display:flex;flex-direction:column;gap:2px;font-size:.79rem;cursor:pointer;transition:all var(--transition-fast);position:relative;overflow:hidden;min-height:0}.palace-cell:hover{background:var(--bg-card-hover);z-index:2}.palace-cell:focus-visible{outline:2px solid rgba(34,211,238,.8);outline-offset:-2px;z-index:2}.palace-cell.selected{outline:2px solid rgba(34,211,238,.8);outline-offset:-2px;box-shadow:inset 0 0 0 1px #22d3ee59}.palace-cell.is-soul{border:2px solid var(--accent-gold);box-shadow:inset 0 0 20px #ffd7001a}.palace-cell.is-body{border:2px solid var(--accent-purple);box-shadow:inset 0 0 20px #a855f71a}.palace-center{grid-column:2 / 4;grid-row:2 / 4;background:#0f0f2ee6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-lg);cursor:default}.palace-center:hover{background:#0f0f2ee6;transform:none}.center-title{font-family:var(--font-serif);font-size:1.5rem;color:var(--accent-gold);font-weight:700}.center-subtitle{font-size:.9rem;color:var(--text-secondary);text-align:center;line-height:1.6}.center-info-grid{display:grid;grid-template-columns:1fr;gap:6px;font-size:.86rem;width:100%;max-width:280px}.center-info-item{display:flex;justify-content:space-between;gap:var(--space-sm)}.center-info-item .label{color:var(--text-secondary)}.center-info-item .value{color:var(--accent-gold);font-weight:600}.palace-name{font-weight:700;color:var(--accent-gold);font-size:.96rem;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.palace-name .stem-branch{font-weight:400;color:var(--text-secondary);font-size:.84rem}.palace-badge{font-size:.72rem;padding:1px 4px;border-radius:3px;font-weight:600}.badge-soul{background:#ffd70033;color:var(--accent-gold)}.badge-body{background:#a855f738;color:var(--accent-purple-ink)}.palace-stars{flex:1;display:flex;flex-direction:column;gap:3px;min-height:0;overflow:hidden}.star-row{display:flex;flex-wrap:wrap;gap:3px}.star-tag{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:4px;font-size:.86rem;font-weight:500;white-space:nowrap}.star-major{background:#ffd70026;color:gold;font-weight:700;font-size:.88rem}.star-lucun{background:#10b98126;color:#10b981;font-weight:700;font-size:.88rem}.star-tianma{background:#3b82f626;color:#3b82f6;font-weight:700;font-size:.88rem}.star-soft{background:#22d3ee1f;color:#22d3ee}.star-tough{background:#ef44441f;color:#ef4444}.star-adjective{background:#ffffff14;color:var(--text-secondary);font-size:.84rem}.star-bright{background:#ffd70026;color:gold;font-weight:700;border:1px solid rgba(255,215,0,.35)}.star-flower{background:#ec48991f;color:#ec4899}.star-helper{background:#10b9811f;color:#6ee7b7;font-size:.84rem}.brightness{font-size:.78rem;opacity:1}.palace-stage{font-size:.82rem;color:var(--text-secondary);display:flex;justify-content:space-between;padding-top:3px;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0}.palace-changsheng{color:var(--accent-emerald);font-size:.82rem}.palace-detail{margin-top:var(--space-lg);padding:var(--space-lg)}.palace-detail-empty{color:var(--text-muted);font-size:.9rem}.palace-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);margin-bottom:var(--space-sm)}.palace-detail-header h3{font-family:var(--font-serif);font-size:1.35rem;color:var(--accent-gold);line-height:1.2}.palace-detail-header p{margin-top:4px;color:var(--text-secondary);font-size:.92rem}.palace-detail-tone{border-radius:999px;padding:4px 10px;font-size:.84rem;font-weight:700;white-space:nowrap}.palace-detail-tone.tone-good{background:#10b98133;color:#10b981}.palace-detail-tone.tone-risk{background:#ef444433;color:#ef4444}.palace-detail-tone.tone-neutral{background:#3b82f633;color:#60a5fa}.palace-detail-explain{color:var(--text-secondary);font-size:.92rem;line-height:1.7;margin-bottom:var(--space-md)}.palace-detail-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-sm);margin-bottom:var(--space-md)}.palace-detail-stats div{background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:8px 10px;display:flex;flex-direction:column;gap:2px}.palace-detail-stats span{color:var(--text-secondary);font-size:.84rem}.palace-detail-stats strong{color:var(--text-primary);font-size:1.1rem}.palace-detail-block+.palace-detail-block{margin-top:var(--space-md)}.palace-detail-block h4{color:var(--accent-cyan);font-size:.92rem;margin-bottom:var(--space-xs)}.palace-detail-tags{display:flex;flex-wrap:wrap;gap:6px}.palace-detail-major-list{list-style:none;display:grid;gap:8px}.palace-detail-major-list li{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);padding:8px 10px;display:grid;gap:4px}.palace-detail-major-list strong{color:var(--text-primary);font-size:.92rem}.palace-detail-major-list span{color:var(--text-secondary);font-size:.86rem;line-height:1.55}.palace-detail-conclusion{margin-top:var(--space-md);padding:10px 14px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.1);background:#ffffff08;color:var(--text-secondary);font-size:.92rem;line-height:1.65}.analysis-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:var(--space-lg)}.analysis-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-xl);transition:all var(--transition-normal)}.analysis-card:hover{transform:translateY(-3px);box-shadow:0 10px 40px #0000004d}.analysis-card-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:1px solid var(--glass-border)}.analysis-card-icon{font-size:1.8rem}.analysis-card-title{font-size:1.1rem;font-weight:600}.analysis-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) 0;border-bottom:1px solid rgba(255,255,255,.03)}.analysis-item:last-child{border-bottom:none}.analysis-item.analysis-item-stack{flex-direction:column;align-items:stretch;gap:6px;padding-top:10px;padding-bottom:10px}.analysis-item-main{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.analysis-item-narrative{font-size:.9rem;line-height:1.65;color:var(--text-secondary);background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:8px 10px}.analysis-narrative{margin:14px 0 4px;font-size:.92rem;line-height:1.75;color:var(--text-secondary);padding:12px 14px;background:#a855f70d;border-left:3px solid rgba(168,85,247,.4);border-radius:0 8px 8px 0}.analysis-label{color:var(--text-secondary);font-size:.95rem}.analysis-value{color:var(--text-primary);font-weight:600;font-size:.96rem}.analysis-value.gold{color:var(--accent-gold)}.analysis-value.purple{color:var(--accent-purple-ink)}.analysis-value.cyan{color:var(--accent-cyan)}.analysis-value.emerald{color:var(--accent-emerald)}.analysis-value.pink{color:var(--accent-pink)}.lunar-star-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.lunar-star-col{border:1px solid rgba(255,255,255,.08);background:#ffffff08;border-radius:var(--radius-sm);padding:10px}.lunar-star-col-title{font-size:.86rem;font-weight:700;color:var(--accent-gold);margin-bottom:8px}.lunar-star-row{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05)}.lunar-star-row:last-child{border-bottom:none}.lunar-star-row-main{display:flex;flex-direction:column;gap:2px;min-width:0}.lunar-star-row-main strong{font-size:.9rem;color:var(--text-primary)}.lunar-star-row-main span{font-size:.84rem;color:var(--text-secondary)}.lunar-star-row-score{min-width:36px;text-align:right;font-size:.92rem;font-weight:800;color:var(--accent-gold)}.lunar-star-row-caution .lunar-star-row-score{color:#f87171}.lunar-palace-grid{margin-top:10px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.lunar-palace-row{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.05)}.lunar-palace-row:last-child{border-bottom:none}.lunar-palace-row-main{display:flex;flex-direction:column;gap:2px;min-width:0}.lunar-palace-row-main strong{font-size:.9rem;color:var(--text-primary)}.lunar-palace-row-main span{font-size:.84rem;color:var(--text-secondary)}.lunar-palace-row-score{min-width:44px;text-align:right;font-size:.9rem;font-weight:800;color:var(--accent-gold)}.lunar-palace-row-caution .lunar-palace-row-score{color:#f87171}.ai-markdown{font-size:.9rem;color:var(--text-secondary);line-height:1.75}.ai-markdown>:first-child{margin-top:0}.ai-markdown h1,.ai-markdown h2,.ai-markdown h3,.ai-markdown h4{color:var(--text-primary);margin:.9rem 0 .55rem;line-height:1.35}.ai-markdown h1{font-size:1.3rem}.ai-markdown h2{font-size:1.15rem}.ai-markdown h3{font-size:1.05rem}.ai-markdown p{margin:.5rem 0}.ai-markdown ul,.ai-markdown ol{margin:.55rem 0;padding-left:1.15rem}.ai-markdown li{margin:.2rem 0}.ai-markdown strong{color:var(--text-primary)}.ai-markdown em{color:var(--accent-cyan)}.ai-markdown code{background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:2px 6px;color:var(--accent-gold);font-size:.82em}.ai-markdown blockquote{margin:.75rem 0;padding:.55rem .8rem;border-left:3px solid rgba(255,215,0,.4);background:#ffd7000d;color:var(--text-secondary)}.interpret-display{margin-top:var(--space-md)}.interpret-display-wrap{border-top:1px solid rgba(255,255,255,.08);padding-top:var(--space-md)}.interpret-display-title{color:var(--accent-cyan);font-size:.9rem;font-weight:700;margin-bottom:var(--space-sm)}.interpret-display-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:var(--space-sm)}.interpret-display-card{background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);padding:10px 12px}.interpret-display-card h4{color:var(--text-primary);font-size:.94rem;margin:0 0 .35rem}.interpret-display-body{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.interpret-display-body p{margin:.25rem 0}.interpret-display-body ul,.interpret-display-body ol{margin:.2rem 0 .2rem 1.05rem}.brightness-meter{display:flex;gap:3px;align-items:center}.brightness-dot{width:8px;height:8px;border-radius:50%;background:#ffffff1a}.brightness-dot.filled{background:var(--accent-gold);box-shadow:0 0 6px var(--accent-gold)}.palace-detail-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-md)}.palace-detail-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.palace-detail-name{font-size:1.1rem;font-weight:700;color:var(--accent-gold)}.palace-detail-stars{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.detail-star-tag{padding:var(--space-xs) var(--space-md);border-radius:var(--radius-xl);font-size:.85rem;font-weight:500}.fortune-content h3{font-family:var(--font-serif);font-size:1.3rem;margin-bottom:var(--space-lg);color:var(--accent-gold)}.fortune-selector{display:flex;gap:var(--space-md);margin-bottom:var(--space-xl);flex-wrap:wrap}.fortune-tab{padding:var(--space-sm) var(--space-lg);border:1px solid var(--glass-border);border-radius:var(--radius-xl);background:transparent;color:var(--text-secondary);font-family:var(--font-sans);font-size:.95rem;cursor:pointer;transition:all var(--transition-fast)}.fortune-tab:hover{background:#ffffff0d}.fortune-tab.active{background:#a855f738;border-color:#a855f770;color:var(--accent-purple-ink);font-weight:600}.fortune-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(270px,1fr));gap:var(--space-lg)}.fortune-annual-wrap{display:grid;grid-template-columns:minmax(0,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.fortune-black-gold-card{position:relative;border-radius:var(--radius-lg);border:1px solid rgba(255,215,0,.35);background:radial-gradient(circle at 85% 10%,rgba(255,215,0,.2),transparent 38%),radial-gradient(circle at 10% 95%,rgba(255,184,0,.12),transparent 42%),linear-gradient(145deg,#0c0c12f5,#161208eb);box-shadow:0 14px 40px #00000073,inset 0 0 0 1px #ffd70014;padding:var(--space-lg)}.fortune-black-gold-head{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md)}.fortune-black-gold-label{color:#ffd700c2;font-size:.82rem;letter-spacing:1.2px;margin-bottom:4px}.fortune-black-gold-card h3{margin:0;color:#ffdf73;font-family:var(--font-serif);font-size:1.25rem}.fortune-black-gold-score{min-width:60px;height:60px;border-radius:999px;display:grid;place-items:center;border:1px solid rgba(255,215,0,.45);color:#ffdf73;font-weight:800;font-size:1.15rem;background:#ffd7001a}.fortune-black-gold-summary{margin-top:var(--space-sm);color:#fff4d7e0;font-size:.92rem;line-height:1.65}.fortune-black-gold-meta{margin-top:var(--space-sm);display:flex;flex-wrap:wrap;gap:var(--space-sm)}.fortune-black-gold-focus{margin-top:var(--space-md);display:flex;flex-wrap:wrap;gap:8px}.fortune-annual-card{background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md) var(--space-lg)}.fortune-annual-lead{margin-top:var(--space-sm);color:var(--text-secondary);font-size:.95rem}.fortune-annual-list{margin-top:var(--space-sm);padding-left:1.1rem;color:var(--text-secondary);font-size:.92rem;line-height:1.65}.fortune-annual-list li+li{margin-top:.35rem}.fortune-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:all var(--transition-normal)}.fortune-card:hover{transform:translateY(-3px);box-shadow:0 10px 30px #0000004d}.fortune-card-title{font-size:1rem;font-weight:600;color:var(--accent-gold);margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm)}.fortune-stars-list{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.mutagen-list{display:flex;gap:var(--space-sm);flex-wrap:wrap;margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid rgba(255,255,255,.05)}.mutagen-tag{padding:3px 10px;border-radius:var(--radius-sm);font-size:.84rem;font-weight:600}.mutagen-lu{background:#10b98126;color:#10b981}.mutagen-quan{background:#3b82f626;color:#3b82f6}.mutagen-ke{background:#a855f738;color:var(--accent-purple-ink)}.mutagen-ji{background:#ef444426;color:#ef4444}.life-content{display:flex;flex-direction:column;gap:var(--space-lg)}.life-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-md)}.life-summary-card{background:#ffffff0d;border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md)}.life-summary-label{font-size:.88rem;color:var(--text-secondary)}.life-summary-value{margin-top:4px;font-size:1.2rem;font-weight:700;color:var(--accent-gold)}.life-kline-card{padding:var(--space-lg)}.life-kline-header h3{font-size:1.1rem;margin-bottom:4px}.life-kline-header p{color:var(--text-secondary);font-size:.94rem;margin-bottom:var(--space-md)}.life-kline-wrap{width:100%;position:relative}.life-kline-echart{width:100%;min-height:300px;height:300px;display:block}.life-kline-echart-yearly{min-height:340px;height:340px}.life-grid-line{stroke:#ffffff1f;stroke-dasharray:5 6;stroke-width:1}.life-axis-label,.life-x-label{fill:var(--text-secondary);font-size:12px;text-anchor:middle}.life-axis-label{text-anchor:end}.life-wick{stroke-width:2}.life-candle{rx:2}.life-candle-up,.life-wick.life-candle-up{fill:#10b981;stroke:#10b981}.life-candle-down,.life-wick.life-candle-down{fill:#ef4444;stroke:#ef4444}.life-close-line{fill:none;stroke:url(#lifeLineGradient);stroke-width:2.5}.life-year-area{fill:#ffd7001f}.life-year-line{fill:none;stroke:gold;stroke-width:2.4}.life-year-marker{fill:gold;stroke:#0a0a1ae6;stroke-width:1}.life-legend{display:flex;flex-wrap:wrap;gap:var(--space-md);margin-top:var(--space-sm);color:var(--text-secondary);font-size:.86rem}.life-dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:6px}.life-dot.up{background:#10b981}.life-dot.down{background:#ef4444}.life-dot.line{background:linear-gradient(180deg,gold,#f59e0b)}.life-period-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:var(--space-md)}.life-period-card{background:#ffffff0a;border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md)}.life-period-age{color:var(--accent-gold);font-weight:700;margin-bottom:4px}.life-period-name{font-size:.92rem;margin-bottom:4px}.life-period-score{color:var(--text-secondary);font-size:.86rem;margin-bottom:6px}.life-period-stars{font-size:.84rem;color:var(--text-secondary);line-height:1.45}.life-empty{padding:var(--space-xl);text-align:center;color:var(--text-secondary)}.compare-layout{display:grid;grid-template-columns:340px minmax(0,1fr);gap:var(--space-lg);align-items:start}.compare-form-container{padding:var(--space-lg)}.compare-form-container .form-grid{grid-template-columns:1fr;gap:var(--space-md)}.compare-result{display:flex;flex-direction:column;gap:var(--space-lg)}.compare-main{padding:var(--space-lg)}.compare-score-wrap{display:flex;align-items:center;gap:var(--space-lg)}.compare-score-ring{position:relative;width:128px;height:128px;flex-shrink:0}.compare-score-svg{position:absolute;top:0;left:0;width:100%;height:100%}.compare-ring-track{fill:none;stroke:#ffffff21;stroke-width:12}.compare-ring-arc{fill:none;stroke:gold;stroke-width:12;stroke-linecap:round;transition:stroke-dashoffset .6s ease}.compare-score-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:2rem;font-weight:800;color:var(--accent-gold);line-height:1}.compare-score-meta h3{font-size:1.3rem;margin-bottom:4px}.compare-score-meta p{color:var(--text-secondary);font-size:.92rem;margin-bottom:10px}.compare-badges{display:flex;flex-wrap:wrap;gap:8px}.compare-badges span{font-size:.84rem;padding:3px 8px;border-radius:999px;background:#ffffff12;border:1px solid rgba(255,255,255,.1)}.compare-person-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-md)}.compare-person-card{background:#ffffff0a;border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-md)}.compare-person-name{font-size:1rem;font-weight:700;color:var(--accent-gold);margin-bottom:var(--space-sm)}.compare-person-item{display:flex;justify-content:space-between;gap:var(--space-sm);font-size:.9rem;padding:4px 0;border-bottom:1px solid rgba(255,255,255,.05)}.compare-person-item span{color:var(--text-secondary)}.compare-breakdown{padding:var(--space-lg)}.compare-breakdown-title{font-weight:700;color:var(--accent-gold);margin-bottom:var(--space-sm)}.compare-breakdown-items{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.compare-breakdown-items div{display:flex;justify-content:space-between;gap:12px;padding:8px 10px;border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);font-size:.85rem}.compare-breakdown-items span{color:var(--text-secondary)}.compare-breakdown-note{margin-top:var(--space-sm);color:var(--text-secondary);font-size:.86rem;line-height:1.55}.compare-huafei-grid{margin-top:var(--space-md);display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-md)}.compare-huafei-col{border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-md);padding:10px;background:#ffffff08}.compare-huafei-title{font-size:.9rem;color:var(--accent-gold);margin-bottom:8px}.compare-huafei-title strong{color:var(--text-primary);margin-left:6px}.compare-huafei-list{display:flex;flex-direction:column;gap:6px}.compare-huafei-item{display:grid;grid-template-columns:1.2fr 1fr auto;gap:8px;font-size:.84rem;color:var(--text-secondary)}.compare-huafei-item strong{color:var(--text-primary)}.compare-table{padding:var(--space-md)}.compare-table-head,.compare-row{display:grid;grid-template-columns:110px 1fr 1fr 160px;gap:10px;align-items:start}.compare-table-head{font-size:.86rem;color:var(--text-secondary);padding:0 4px 8px;border-bottom:1px solid rgba(255,255,255,.1)}.compare-row{font-size:.88rem;padding:10px 4px;border-bottom:1px solid rgba(255,255,255,.05)}.compare-row-title{color:var(--accent-gold);font-weight:700}.compare-row-stars{color:var(--text-secondary);line-height:1.45}.compare-row-shared{color:var(--accent-cyan);line-height:1.45}.compare-empty{padding:var(--space-xl);text-align:center;color:var(--text-secondary)}.compare-radar-card{padding:var(--space-lg)}.compare-radar-chart{width:100%;height:380px;margin-top:6px}.compare-radar-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.compare-radar-badges span{font-size:.78rem;padding:3px 9px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d}.compare-correlation-grid{margin-top:12px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.compare-correlation-item{border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-sm);background:#ffffff08;padding:10px}.compare-correlation-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px}.compare-correlation-head span{color:var(--text-secondary);font-size:.84rem}.compare-correlation-head strong{color:var(--accent-gold);font-size:.88rem}.compare-correlation-track{width:100%;height:8px;border-radius:999px;background:#ffffff14;overflow:hidden;margin-bottom:6px}.compare-correlation-track span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#22d3ee,gold)}.compare-correlation-note{color:var(--text-secondary);font-size:.84rem;line-height:1.45}.app-footer{position:relative;z-index:1;text-align:center;padding:var(--space-2xl) var(--space-xl);border-top:1px solid var(--glass-border);color:var(--text-muted);font-size:.85rem}.footer-note{margin-top:var(--space-xs);font-size:.8rem;letter-spacing:3px}.sihua-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media(max-width:1024px){.features-grid{grid-template-columns:repeat(2,1fr)}.compare-layout{grid-template-columns:1fr}}@media(max-width:768px){.header-content{flex-direction:column;gap:var(--space-sm)}.header-nav{width:100%;justify-content:flex-start;gap:8px;padding-bottom:2px}.hero-title{font-size:2rem}.form-grid{grid-template-columns:1fr}.features-grid{grid-template-columns:1fr 1fr}.main-content{padding:var(--space-md)}.astrolabe-grid{font-size:.72rem;min-width:760px}.palace-cell{padding:4px}.center-title{font-size:1rem}.center-info-grid{grid-template-columns:1fr;font-size:.8rem}.palace-detail{padding:var(--space-md)}.palace-detail-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.palace-detail-header{flex-direction:column;align-items:flex-start}.analysis-content{grid-template-columns:1fr}.sihua-grid{grid-template-columns:repeat(2,1fr);gap:10px}.lunar-star-grid,.lunar-palace-grid,.life-summary-grid{grid-template-columns:1fr}.compare-score-wrap{flex-direction:column;align-items:flex-start}.compare-person-grid,.compare-breakdown-items,.compare-huafei-grid,.compare-correlation-grid{grid-template-columns:1fr}.compare-radar-chart{height:320px}.compare-table-head,.compare-row{grid-template-columns:84px 1fr}.compare-table-head div:nth-child(n+3),.compare-row div:nth-child(n+3){display:none}.export-toolbar{top:116px;justify-content:flex-start;overflow-x:auto}}@media(max-width:480px){.features-grid{grid-template-columns:1fr}.form-container{padding:var(--space-lg)}.compare-form-container{padding:var(--space-md)}.compare-radar-chart{height:280px}.export-btn{font-size:.86rem;padding:.45rem .75rem}.header-content{padding:var(--space-xs) var(--space-sm)}.nav-btn{padding:var(--space-sm) .8rem;font-size:.84rem}.nav-icon{font-size:1rem}.logo-icon{font-size:1.8rem}.logo-text h1{font-size:1.2rem}.hero-title{font-size:1.6rem}.hero-desc{font-size:.92rem}.hero-section{padding:var(--space-xl) 0 var(--space-lg)}.astrolabe-grid{min-width:680px;font-size:.7rem}.astrolabe-grid-wrap{position:relative}.astrolabe-grid-wrap:after{content:"← vuốt ngang để xem →";display:block;text-align:center;font-size:.82rem;color:var(--text-muted);padding:var(--space-sm) 0}.palace-cell{padding:3px;gap:1px}.palace-name{font-size:.82rem}.star-tag{font-size:.8rem;padding:2px 5px}.star-major,.star-lucun,.star-tianma{font-size:.82rem}.center-title{font-size:.9rem}.center-subtitle{font-size:.8rem}.center-info-grid{font-size:.78rem;gap:4px var(--space-sm)}.palace-detail{padding:var(--space-sm)}.palace-detail-header h3{font-size:1.05rem}.palace-detail-stats{grid-template-columns:1fr 1fr;gap:6px}.palace-detail-stats strong{font-size:.88rem}.analysis-card{padding:var(--space-md)}.analysis-card-icon{font-size:1.4rem}.analysis-card-title{font-size:1rem}.sihua-grid{grid-template-columns:repeat(2,1fr);gap:8px}.fortune-grid{grid-template-columns:1fr}.fortune-card{padding:var(--space-md)}.fortune-black-gold-head{flex-direction:column;align-items:flex-start}.fortune-black-gold-score{width:54px;height:54px;font-size:1rem}.life-kline-echart{min-height:280px;height:280px}.life-kline-echart-yearly{min-height:260px;height:260px}.life-period-grid{grid-template-columns:repeat(2,1fr)}.compare-score-ring{width:96px;height:96px}.compare-score-value{font-size:1.6rem}.compare-score-meta h3{font-size:1.05rem}.compare-badges span{font-size:.78rem;padding:2px 6px}.export-toolbar{top:100px;padding:var(--space-xs) var(--space-sm);gap:var(--space-xs)}.fortune-decadal-grid{grid-template-columns:repeat(2,1fr)!important}}@media(max-width:360px){.main-content{padding:var(--space-sm)}.header-nav{gap:2px}.nav-btn{padding:6px 10px}.nav-icon{font-size:.95rem}.hero-title{font-size:1.35rem}.form-container{padding:var(--space-md)}.submit-btn{padding:var(--space-md);font-size:1rem}.astrolabe-grid{min-width:620px;font-size:.66rem}.analysis-card{padding:var(--space-sm)}.sihua-grid,.life-period-grid{grid-template-columns:1fr}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#a855f74d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#a855f780}.palace-tooltip{position:fixed;z-index:1000;background:#0f0f2ef2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:var(--space-lg);max-width:380px;box-shadow:0 20px 60px #00000080;pointer-events:none;opacity:0;transform:scale(.95);transition:opacity .2s ease,transform .2s ease}.palace-tooltip.show{opacity:1;transform:scale(1);pointer-events:auto}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0a0a1ae6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);opacity:0;pointer-events:none;transition:opacity .3s ease}.loading-overlay.active{opacity:1;pointer-events:all}.loading-spinner{width:60px;height:60px;border:3px solid rgba(168,85,247,.2);border-top-color:var(--accent-purple);border-radius:50%;animation:spin .8s linear infinite}.loading-text{font-size:1.1rem;color:var(--text-secondary)}.viet-lunar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.viet-lunar-lucky-row{margin-top:10px;flex-direction:column;align-items:flex-start;gap:8px}.viet-lunar-lucky-tags{display:flex;flex-wrap:wrap;gap:6px}.nav-btn[disabled]{position:relative}.nav-btn[disabled]:hover:after{content:"Nhập thông tin ngày sinh trước";position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:#0f0f2ef2;border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.8rem;white-space:nowrap;padding:4px 8px;pointer-events:none;z-index:200}.bat-trach-block{margin-top:14px;padding:12px 14px;background:#a855f70d;border:1px solid rgba(168,85,247,.15);border-radius:10px}.bat-trach-title{font-weight:600;color:var(--accent-purple-ink);font-size:.92rem;margin-bottom:10px}.bat-trach-dirs{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:.88rem}.bat-trach-col-title{font-weight:600;margin-bottom:5px}.bat-trach-col-title.lucky{color:var(--accent-cyan)}.bat-trach-col-title.unlucky{color:#f87171}.bat-trach-dir-row{display:flex;justify-content:space-between;gap:6px;line-height:1.7;color:var(--text-secondary);font-size:.86rem}.bat-trach-dir-name{font-weight:500}.bat-trach-dir-name.lucky{color:#34d399}.bat-trach-dir-name.unlucky{color:#f87171}.bat-trach-dir-type{color:var(--text-secondary);font-size:.84rem;text-align:right}@media(max-width:480px){.bat-trach-dirs{grid-template-columns:1fr}}
