:root{--bg: #0a0a12;--surface: #13132a;--surface2: #1a1a35;--border: rgba(130, 100, 255, .2);--purple: #7c5cbf;--violet: #9b6dff;--indigo: #4a3fa0;--gold: #e8c84a;--gold-dim: #b89a2a;--text: #e8e4f0;--text-muted:#a09ab8;--star: rgba(232, 200, 74, .6)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:Apple SD Gothic Neo,Noto Sans KR,Malgun Gothic,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100dvh;overflow-x:hidden}body:before,body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}body:before{background-image:radial-gradient(1px 1px at 10% 15%,var(--star) 0%,transparent 100%),radial-gradient(1px 1px at 25% 40%,var(--star) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 40% 8%,var(--star) 0%,transparent 100%),radial-gradient(1px 1px at 55% 55%,var(--star) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 70% 20%,var(--star) 0%,transparent 100%),radial-gradient(1px 1px at 80% 65%,var(--star) 0%,transparent 100%),radial-gradient(1px 1px at 90% 10%,var(--star) 0%,transparent 100%),radial-gradient(2px 2px at 15% 75%,var(--star) 0%,transparent 100%),radial-gradient(1px 1px at 35% 90%,var(--star) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 60% 80%,var(--star) 0%,transparent 100%),radial-gradient(1px 1px at 75% 45%,var(--star) 0%,transparent 100%),radial-gradient(1px 1px at 5% 50%,var(--star) 0%,transparent 100%),radial-gradient(2px 2px at 95% 85%,var(--star) 0%,transparent 100%),radial-gradient(1px 1px at 48% 30%,var(--star) 0%,transparent 100%),radial-gradient(1.5px 1.5px at 88% 38%,var(--star) 0%,transparent 100%);animation:twinkle 6s ease-in-out infinite alternate}body:after{background:radial-gradient(ellipse 60% 40% at 20% 30%,rgba(76,50,160,.18) 0%,transparent 70%),radial-gradient(ellipse 50% 35% at 80% 70%,rgba(120,60,180,.14) 0%,transparent 70%),radial-gradient(ellipse 40% 30% at 50% 50%,rgba(60,40,120,.1) 0%,transparent 70%)}@keyframes twinkle{0%{opacity:.7}50%{opacity:1}to{opacity:.5}}#root{position:relative;z-index:1;min-height:100dvh;display:flex;flex-direction:column;align-items:center}h1,h2,h3{line-height:1.3}.text-gold{background:linear-gradient(135deg,var(--gold) 0%,#fff3b0 50%,var(--gold-dim) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-violet{background:linear-gradient(135deg,var(--violet) 0%,#c4a8ff 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px}.card-glass{background:#14122ab3;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(130,100,255,.25);border-radius:20px;padding:24px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 28px;border-radius:50px;border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s,opacity .15s;text-decoration:none;letter-spacing:.02em}.btn:active{transform:scale(.97)}.btn-gold{background:linear-gradient(135deg,#c9a227 0%,var(--gold) 50%,#e0b830 100%);color:#1a1200;box-shadow:0 4px 20px #e8c84a59}.btn-gold:hover{box-shadow:0 6px 28px #e8c84a80;transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--violet);border:1.5px solid var(--violet)}.btn-outline:hover{background:#9b6dff1a}.btn-ghost{background:#ffffff0f;color:var(--text-muted);border:1px solid rgba(255,255,255,.1)}.btn-ghost:hover{background:#ffffff1a;color:var(--text)}.form-select,.form-input{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:1rem;padding:12px 14px;-moz-appearance:none;appearance:none;-webkit-appearance:none;outline:none;transition:border-color .2s,box-shadow .2s}.form-select:focus,.form-input:focus{border-color:var(--violet);box-shadow:0 0 0 3px #9b6dff26}.form-select option{background:var(--surface2)}label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:6px;letter-spacing:.03em}.checkbox-row{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.9rem;color:var(--text-muted)}.checkbox-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--violet);cursor:pointer}.stars{display:inline-flex;gap:3px;font-size:1.1rem}.star-empty{color:#e8c84a40}.divider{width:100%;height:1px;background:var(--border);margin:20px 0}.page{width:100%;max-width:480px;margin:0 auto;padding:0 20px 40px;display:flex;flex-direction:column;min-height:100dvh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--indigo);border-radius:3px}.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-40{margin-top:40px}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.w-full{width:100%}.landing{justify-content:space-between;padding-top:0}.landing-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 0 32px;gap:32px}.landing-orb{position:relative;width:120px;height:120px;display:flex;align-items:center;justify-content:center}.landing-orb:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;background:radial-gradient(circle at 35% 35%,rgba(155,109,255,.35) 0%,rgba(76,50,160,.2) 50%,transparent 70%);filter:blur(16px);animation:orb-pulse 3s ease-in-out infinite}.landing-orb-emoji{font-size:72px;line-height:1;animation:orb-float 4s ease-in-out infinite;position:relative;z-index:1;filter:drop-shadow(0 0 20px rgba(155,109,255,.5))}@keyframes orb-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes orb-pulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.15)}}.landing-headline{display:flex;flex-direction:column;gap:16px}.landing-headline h1{font-size:2.4rem;font-weight:800;line-height:1.25;letter-spacing:-.02em}.landing-sub{font-size:.97rem;color:var(--text-muted);line-height:1.7}.landing-cta{width:100%;max-width:320px;font-size:1.1rem;padding:16px 32px;letter-spacing:.04em}.landing-hint{font-size:.8rem;color:#a09ab899;letter-spacing:.02em}.landing-footer{padding-bottom:24px;text-align:center;font-size:.75rem;color:#a09ab866;letter-spacing:.03em}.input-form{padding-top:20px}.form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.btn-back{background:none;border:none;color:var(--text-muted);font-size:.9rem;cursor:pointer;padding:8px 0;transition:color .15s;letter-spacing:.02em}.btn-back:hover{color:var(--text)}.form-step-badge{font-size:.78rem;color:var(--violet);background:#9b6dff1a;padding:4px 12px;border-radius:20px;border:1px solid rgba(155,109,255,.25);letter-spacing:.03em}.form-hero{text-align:center;margin-bottom:28px}.form-orb{font-size:2.8rem;margin-bottom:12px;filter:drop-shadow(0 0 18px rgba(155,109,255,.55));animation:orb-pulse 3s ease-in-out infinite}@keyframes orb-pulse{0%,to{transform:scale(1);filter:drop-shadow(0 0 18px rgba(155,109,255,.55))}50%{transform:scale(1.07);filter:drop-shadow(0 0 28px rgba(155,109,255,.8))}}.form-desc{font-size:1rem;line-height:1.75;color:var(--text-muted)}.form-card{padding:24px 20px}.form-group{display:flex;flex-direction:column}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-row-3{display:grid;grid-template-columns:2fr 1.2fr 1.2fr;gap:8px}.form-row-3 .form-input,.form-row-3 .form-select{font-size:.9rem;padding:11px 8px}.form-select:disabled,.form-input:disabled{opacity:.35;cursor:not-allowed}.field-hint{font-size:.78rem;color:var(--violet);opacity:.8}.radio-group{display:flex;gap:16px;flex-wrap:wrap;margin-top:4px}.radio-row{display:flex;align-items:center;gap:6px;font-size:.9rem;color:var(--text);cursor:pointer;margin-bottom:0}.radio-row input[type=radio]{width:16px;height:16px;accent-color:var(--violet);cursor:pointer}.form-error{font-size:.85rem;color:#ff7b7b;background:#ff505012;border:1px solid rgba(255,80,80,.2);border-radius:8px;padding:8px 12px}.form-note{font-size:.75rem;color:var(--text-muted);opacity:.5}.loading-page{width:100%;max-width:480px;margin:0 auto;min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:0 20px}.loading-body{display:flex;flex-direction:column;align-items:center;gap:40px}.loading-visual{position:relative;width:140px;height:140px;display:flex;align-items:center;justify-content:center}.loading-orb{width:72px;height:72px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#b98cffe6,#643cc8b3 60%,#3c1e7880);box-shadow:0 0 24px #9b6dff99,0 0 56px #9b6dff4d,inset 0 0 20px #e8c84a26;animation:orb-breathe 2.4s ease-in-out infinite}@keyframes orb-breathe{0%,to{transform:scale(1);box-shadow:0 0 24px #9b6dff99,0 0 56px #9b6dff4d}50%{transform:scale(1.1);box-shadow:0 0 36px #9b6dffcc,0 0 80px #9b6dff66}}.loading-ring{position:absolute;top:0;right:0;bottom:0;left:0;animation:ring-spin 5s linear infinite}.loading-star{position:absolute;top:50%;left:50%;font-size:.75rem;color:var(--gold);opacity:.85;transform:rotate(calc(var(--i) * 45deg)) translateY(-58px) rotate(calc(var(--i) * -45deg));text-shadow:0 0 6px rgba(232,200,74,.8)}@keyframes ring-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-msg{font-size:1.05rem;color:var(--text-muted);text-align:center;line-height:1.6;transition:opacity .3s ease;min-height:1.7em}.loading-msg.msg-visible{opacity:1}.loading-msg.msg-hidden{opacity:0}.loading-msg-final{font-size:1.2rem;font-weight:700;letter-spacing:.02em;text-shadow:0 0 20px rgba(232,200,74,.4)}.loading-dots{display:flex;gap:8px}.loading-dots span{width:6px;height:6px;border-radius:50%;background:var(--violet);opacity:.4;animation:dot-pulse 1.4s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes dot-pulse{0%,to{opacity:.25;transform:scale(1)}50%{opacity:.9;transform:scale(1.3)}}.result-page{padding-top:20px;padding-bottom:0}.result-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.result-hero{text-align:center;margin-bottom:24px}.result-emoji{font-size:4rem;line-height:1;margin-bottom:16px;filter:drop-shadow(0 0 24px rgba(155,109,255,.6));animation:emoji-float 4s ease-in-out infinite}@keyframes emoji-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.result-title{font-size:1.45rem;font-weight:800;letter-spacing:.02em;line-height:1.35;margin-bottom:16px;text-shadow:0 0 32px rgba(232,200,74,.35)}.result-signs{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.sign-badge{font-size:.8rem;padding:5px 14px;border-radius:20px;letter-spacing:.04em}.sign-sun{background:#e8c84a1f;border:1px solid rgba(232,200,74,.35);color:var(--gold)}.sign-moon{background:#9b6dff1f;border:1px solid rgba(155,109,255,.35);color:var(--violet)}.result-stats{display:flex;align-items:center;justify-content:space-around;padding:20px 16px;margin-bottom:16px;gap:8px}.stat-item{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1}.stat-label{font-size:.72rem;color:var(--text-muted);letter-spacing:.04em}.stat-value{font-size:1rem;font-weight:700;letter-spacing:.01em}.stat-divider{width:1px;height:36px;background:var(--border);flex-shrink:0}.charm-stars{display:flex;gap:2px;font-size:.95rem}.star-filled{color:var(--gold)}.star-empty{color:var(--border)}.result-section{margin-bottom:16px;padding:22px 20px}.result-karma{background:#9b6dff0d;border-color:#9b6dff33}.section-title{font-size:.82rem;font-weight:700;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:14px}.section-body{font-size:.97rem;line-height:1.85;color:var(--text);word-break:keep-all}.result-actions{margin-top:8px}
