*{box-sizing:border-box;margin:0;padding:0}:root{--bg-void:#05050a;--bg-deep:#080810;--bg-card:#0f0f1e;--bg-card-alt:#12122a;--bg-input:#0a0a18;--purple-bright:#c77dff;--purple-mid:#9d4edd;--purple-deep:#6a0dad;--purple-glow:#9d4edd33;--gold-bright:gold;--gold-mid:#d4af37;--gold-soft:#c9a84c;--gold-glow:#d4af372e;--wood-color:#4ade80;--fire-color:#ff6b6b;--earth-color:#fbbf24;--metal-color:#94a3b8;--water-color:#60a5fa;--text-primary:#f0e8ff;--text-secondary:#b09acc;--text-gold:#d4af37;--text-dim:#6b6080;--border-subtle:#9d4edd1f;--border-mid:#9d4edd4d;--border-gold:#d4af3740;--glow-purple:0 0 24px #9d4edd59, 0 0 60px #9d4edd1a;--glow-gold:0 0 24px #d4af3759, 0 0 60px #d4af3714;--shadow-card:0 8px 32px #00000080;--font-display:"Cinzel", "Noto Serif KR", serif;--font-korean:"Noto Serif KR", serif;--font-body:"Inter", sans-serif;--transition-fast:all .2s cubic-bezier(.4, 0, .2, 1);--transition-normal:all .35s cubic-bezier(.4, 0, .2, 1)}html{scroll-behavior:smooth}body{background-color:var(--bg-void);color:var(--text-primary);font-family:var(--font-korean);-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}#star-canvas{pointer-events:none;z-index:0;width:100%;height:100%;position:fixed;top:0;left:0}.app-wrapper{z-index:1;min-height:100vh;position:relative}.container{max-width:480px;margin:0 auto;padding:0 16px}.site-header{text-align:center;padding:36px 20px 16px}.site-logo{font-family:var(--font-display);color:var(--gold-bright);letter-spacing:.1em;text-shadow:var(--glow-gold);cursor:pointer;margin-bottom:6px;font-size:clamp(1.6rem,5vw,2.2rem);font-weight:700;display:block}.site-tagline{color:var(--text-dim);letter-spacing:.14em;font-size:.78rem;font-weight:300}.header-divider{background:linear-gradient(90deg, transparent, var(--gold-mid), transparent);width:140px;height:1px;margin:14px auto 0}.section-label{align-items:center;gap:10px;margin-bottom:14px;display:flex}.section-label-text{font-family:var(--font-body);letter-spacing:.22em;text-transform:uppercase;color:var(--purple-bright);white-space:nowrap;font-size:.68rem;font-weight:600}.section-label-line{background:linear-gradient(90deg, var(--border-subtle), transparent);flex:1;height:1px}.magic-card{background:var(--bg-card);border:1px solid var(--border-subtle);transition:var(--transition-normal);box-shadow:var(--shadow-card);border-radius:20px;margin-bottom:14px;padding:22px 20px;position:relative;overflow:hidden}.magic-card:before{content:"";background:linear-gradient(90deg, transparent, var(--purple-mid), transparent);opacity:.5;height:1px;position:absolute;top:0;left:0;right:0}.character-hero{background:var(--bg-card);border:1px solid var(--border-mid);text-align:center;box-shadow:var(--glow-purple), var(--shadow-card);border-radius:24px;margin-bottom:14px;padding:28px 24px 20px;position:relative;overflow:hidden}.character-hero:before{content:"";background:radial-gradient(ellipse at 50% 0%, var(--purple-glow) 0%, transparent 65%);pointer-events:none;position:absolute;inset:0}.character-emoji-lg{z-index:1;margin-bottom:12px;font-size:4.5rem;animation:4s ease-in-out infinite float;display:block;position:relative}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.character-badge{font-family:var(--font-body);letter-spacing:.2em;color:var(--purple-bright);text-transform:uppercase;background:#9d4edd1f;border:1px solid #9d4edd4d;border-radius:20px;margin-bottom:10px;padding:4px 12px;font-size:.65rem;font-weight:600;display:inline-block}.character-name-lg{font-family:var(--font-korean);color:var(--text-primary);margin-bottom:10px;font-size:1.5rem;font-weight:700;line-height:1.3}.character-punchline-box{border:1px solid var(--border-gold);background:#d4af3712;border-radius:12px;margin:12px 0;padding:12px 16px}.character-punchline-box p{color:var(--gold-soft);font-size:.9rem;font-style:italic;line-height:1.6}.character-desc-text{color:var(--text-secondary);text-align:left;font-size:.85rem;line-height:1.8}.share-btn-row{gap:10px;margin-top:18px;display:flex}.share-btn{border:1px solid var(--border-mid);color:var(--text-secondary);font-size:.82rem;font-family:var(--font-korean);cursor:pointer;transition:var(--transition-fast);text-align:center;background:#9d4edd14;border-radius:12px;flex:1;padding:12px 8px}.share-btn:hover{border-color:var(--purple-bright);color:var(--purple-bright);background:#9d4edd26}.pillars-grid{grid-template-columns:repeat(4,1fr);gap:8px;margin:16px 0 12px;display:grid}.pillar-card{border:1px solid var(--border-subtle);text-align:center;transition:var(--transition-fast);background:#9d4edd0f;border-radius:14px;padding:14px 6px}.pillar-card:hover{border-color:var(--border-mid);background:#9d4edd1f}.pillar-label{color:var(--text-dim);letter-spacing:.08em;font-size:.65rem;font-family:var(--font-body);margin-bottom:10px;font-weight:600}.pillar-stem{color:var(--gold-bright);text-shadow:0 0 12px #d4af3780;margin-bottom:2px;font-size:1.7rem;font-weight:700;line-height:1;display:block}.pillar-stem-ko{color:var(--text-dim);margin-bottom:8px;font-size:.68rem;display:block}.pillar-branch{color:var(--purple-bright);text-shadow:0 0 12px #c77dff66;margin-bottom:2px;font-size:1.5rem;font-weight:600;line-height:1;display:block}.pillar-branch-ko{color:var(--text-dim);font-size:.68rem;display:block}.pillar-tengod{color:var(--text-dim);border-top:1px solid var(--border-subtle);margin-top:8px;padding-top:7px;font-size:.6rem;line-height:1.4}.saju-summary-row{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.saju-chip{border:1px solid var(--border-subtle);color:var(--text-secondary);font-size:.75rem;font-family:var(--font-body);background:#9d4edd1a;border-radius:20px;padding:5px 12px}.saju-chip strong{color:var(--gold-soft)}.gilsin-row{flex-wrap:wrap;align-items:center;gap:6px;margin-top:10px;display:flex}.gilsin-badge{color:var(--gold-bright);border:1px solid var(--border-gold);background:#d4af371a;border-radius:20px;padding:3px 10px;font-size:.7rem}.ohaeng-section{margin:4px 0}.ohaeng-chart-wrap{align-items:center;gap:20px;display:flex}.donut-svg-wrap{flex-shrink:0}.ohaeng-legend{flex-direction:column;flex:1;gap:10px;display:flex}.ohaeng-bar-row{align-items:center;gap:8px;display:flex}.ohaeng-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.ohaeng-name{color:var(--text-secondary);width:46px;font-size:.78rem;font-family:var(--font-korean);flex-shrink:0}.ohaeng-bar-bg{background:#ffffff0d;border-radius:4px;flex:1;height:7px;overflow:hidden}.ohaeng-bar-fill{border-radius:4px;height:100%;transition:width 1.2s cubic-bezier(.4,0,.2,1)}.ohaeng-pct{color:var(--text-dim);text-align:right;width:32px;font-size:.72rem;font-family:var(--font-body)}.healing-card{background:var(--bg-card);border:1px solid var(--border-gold);box-shadow:0 0 20px #d4af370f, var(--shadow-card);border-radius:20px;margin-bottom:14px;padding:22px 20px}.healing-notice{color:var(--text-secondary);border-left:3px solid var(--gold-mid);background:#d4af370d;border-radius:10px;margin-bottom:16px;padding:10px 14px;font-size:.8rem;line-height:1.6}.healing-mission{border-bottom:1px solid #d4af3714;align-items:flex-start;gap:12px;padding:12px 0;display:flex}.healing-mission:last-child{border-bottom:none;padding-bottom:0}.healing-icon{flex-shrink:0;padding-top:1px;font-size:1.3rem}.healing-text{color:var(--text-secondary);font-size:.88rem;line-height:1.65}.interpretation-card{background:var(--bg-card);border:1px solid var(--border-subtle);box-shadow:var(--shadow-card);border-radius:20px;margin-bottom:14px;padding:22px 20px}.interpretation-text{color:var(--text-secondary);white-space:pre-line;font-size:.88rem;line-height:1.9}.yongshin-row{border-top:1px solid var(--border-subtle);color:var(--gold-soft);margin-top:14px;padding-top:14px;font-size:.8rem}.form-group{margin-bottom:18px}.form-label{color:var(--text-secondary);letter-spacing:.06em;font-size:.8rem;font-family:var(--font-body);margin-bottom:8px;font-weight:500;display:block}.form-label span{color:var(--text-dim);font-weight:400}.form-input{background:var(--bg-input);border:1px solid var(--border-subtle);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:var(--transition-fast);border-radius:12px;outline:none;padding:13px 16px;font-size:.95rem}.form-input:focus{border-color:var(--purple-mid);box-shadow:0 0 0 3px var(--purple-glow)}.form-input::placeholder{color:var(--text-dim)}.form-input[type=date],.form-input[type=time]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}.form-select{background:var(--bg-input);border:1px solid var(--border-subtle);width:100%;color:var(--text-primary);font-family:var(--font-body);cursor:pointer;transition:var(--transition-fast);border-radius:12px;outline:none;padding:13px 16px;font-size:.95rem}.form-select:focus{border-color:var(--purple-mid);box-shadow:0 0 0 3px var(--purple-glow)}.toggle-row{gap:8px;display:flex}.toggle-option{background:var(--bg-input);border:1px solid var(--border-subtle);color:var(--text-dim);font-size:.88rem;font-family:var(--font-korean);cursor:pointer;transition:var(--transition-fast);text-align:center;-webkit-user-select:none;user-select:none;border-radius:10px;flex:1;padding:11px 8px}.toggle-option.active{border-color:var(--purple-mid);color:var(--purple-bright);background:#9d4edd2e;font-weight:600}.btn-primary{background:linear-gradient(135deg, var(--purple-deep) 0%, var(--purple-mid) 60%, var(--purple-deep) 100%);color:#fff;width:100%;font-family:var(--font-display);letter-spacing:.1em;cursor:pointer;transition:var(--transition-normal);border:1px solid #9d4edd99;border-radius:14px;padding:17px;font-size:1rem;font-weight:600;position:relative;overflow:hidden}.btn-primary:before{content:"";background:linear-gradient(90deg,#0000,#ffffff14,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.btn-primary:hover{box-shadow:var(--glow-purple);transform:translateY(-1px)}.btn-primary:hover:before{left:100%}.btn-primary:active{transform:translateY(0)}.btn-ghost{border:1px solid var(--border-subtle);color:var(--text-dim);font-family:var(--font-body);cursor:pointer;transition:var(--transition-fast);text-align:center;background:0 0;border-radius:12px;width:100%;padding:11px 20px;font-size:.83rem}.btn-ghost:hover{border-color:var(--border-mid);color:var(--text-secondary)}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000005e0;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--bg-card);border:1px solid var(--border-mid);width:100%;max-width:380px;box-shadow:var(--glow-purple), 0 24px 80px #000c;border-radius:24px;padding:28px 24px;animation:.3s cubic-bezier(.4,0,.2,1) slideUp;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.modal-title{font-family:var(--font-display);color:var(--gold-bright);letter-spacing:.08em;text-align:center;margin-bottom:8px;font-size:1.05rem}.modal-close{border:1px solid var(--border-subtle);width:32px;height:32px;color:var(--text-dim);cursor:pointer;transition:var(--transition-fast);background:#ffffff0f;border-radius:50%;justify-content:center;align-items:center;font-size:.9rem;display:flex;position:absolute;top:16px;right:16px}.modal-close:hover{color:var(--text-primary)}.loading-overlay{background:var(--bg-void);z-index:200;flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex;position:fixed;inset:0}.loading-ring{border:2px solid var(--border-subtle);border-top-color:var(--purple-bright);border-right-color:var(--gold-mid);border-radius:50%;width:52px;height:52px;animation:1.2s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-title{font-family:var(--font-display);color:var(--gold-bright);letter-spacing:.15em;font-size:1rem}.loading-subtitle{color:var(--text-dim);letter-spacing:.08em;font-size:.8rem;animation:2s ease-in-out infinite blink}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.btn-social{width:100%;font-family:var(--font-korean);cursor:pointer;transition:var(--transition-fast);letter-spacing:.03em;border:none;border-radius:12px;padding:14px 16px;font-size:.92rem;font-weight:600}.btn-social:hover{opacity:.9;transform:translateY(-1px)}@media (width<=400px){.pillars-grid{gap:5px}.pillar-stem{font-size:1.45rem}.pillar-branch{font-size:1.25rem}.ohaeng-chart-wrap{flex-direction:column}.character-name-lg{font-size:1.3rem}}.ai-interpretation-wrap{position:relative}.ai-streaming-indicator{border:1px solid var(--border-subtle);background:#9d4edd14;border-radius:10px;align-items:center;margin-bottom:14px;padding:10px 14px;display:flex}.ai-dot{background:var(--purple-bright);border-radius:50%;width:6px;height:6px;margin-right:4px;animation:1.2s ease-in-out infinite ai-bounce}.ai-dot:nth-child(2){animation-delay:.2s}.ai-dot:nth-child(3){animation-delay:.4s}@keyframes ai-bounce{0%,80%,to{opacity:.4;transform:translateY(0)}40%{opacity:1;transform:translateY(-5px)}}.ai-content{color:var(--text-secondary);font-size:.88rem;line-height:1.9}.ai-content h3.ai-section-header{font-family:var(--font-korean);border-bottom:1px solid var(--border-subtle);margin:20px 0 8px;padding-bottom:6px;font-size:.98rem;font-weight:700}.ai-section-header.ai-gold{color:var(--gold-bright);border-color:var(--border-gold)}.ai-section-header.ai-green{color:#4ade80;border-color:#4ade8033}.ai-section-header.ai-pink{color:#ff6b9d;border-color:#ff6b9d33}.ai-section-header.ai-purple{color:var(--purple-bright);border-color:var(--border-mid)}.ai-content strong{color:var(--text-primary);font-weight:600}.ai-cursor{color:var(--purple-bright);margin-left:1px;font-weight:300;animation:.8s step-end infinite blink-cursor;display:inline-block}@keyframes blink-cursor{0%,to{opacity:1}50%{opacity:0}}.ai-card{background:var(--bg-card);border:1px solid var(--border-mid);box-shadow:var(--glow-purple), var(--shadow-card);border-radius:20px;margin-bottom:14px;padding:22px 20px;position:relative;overflow:hidden}.ai-card:before{content:"";background:linear-gradient(90deg, var(--purple-deep), var(--purple-bright), var(--gold-mid), var(--purple-bright), var(--purple-deep));opacity:.7;height:2px;position:absolute;top:0;left:0;right:0}.record-list{flex-direction:column;gap:10px;margin-top:12px;display:flex}.record-item{background:var(--bg-input);border:1px solid var(--border-subtle);cursor:pointer;transition:var(--transition-fast);border-radius:12px;align-items:center;gap:12px;padding:12px 14px;display:flex}.record-item:hover{border-color:var(--border-mid);background:#9d4edd14}.record-emoji{flex-shrink:0;font-size:1.4rem}.record-info{flex:1;min-width:0}.record-name{color:var(--text-primary);margin-bottom:3px;font-size:.88rem;font-weight:600}.record-date{color:var(--text-dim);font-size:.72rem;font-family:var(--font-body)}.nav-tabs{gap:6px;margin-bottom:16px;display:flex}.nav-tab{border:1px solid var(--border-subtle);color:var(--text-dim);font-size:.8rem;font-family:var(--font-korean);cursor:pointer;transition:var(--transition-fast);text-align:center;background:0 0;border-radius:10px;flex:1;padding:10px 6px}.nav-tab.active{border-color:var(--purple-mid);color:var(--purple-bright);background:#9d4edd26;font-weight:600}.toast{border:1px solid var(--border-mid);color:var(--text-primary);z-index:300;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);white-space:nowrap;box-shadow:var(--glow-purple);background:#0f0f1ef2;border-radius:24px;padding:11px 22px;font-size:.83rem;animation:.3s cubic-bezier(.4,0,.2,1) toast-in;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(16px)}to{opacity:1;transform:translate(-50%)translateY(0)}}
