:root{--bg: #ffffff;--bg-alt: #F5F5F7;--surface: #ffffff;--border: #E5E7EB;--border-light: #F3F4F6;--indigo: #4F46E5;--indigo-dark: #4338CA;--indigo-light: #EEF2FF;--indigo-mid: #C7D2FE;--amber: #F59E0B;--amber-light: #FEF3C7;--text-primary: #111827;--text-secondary: #6B7280;--text-tertiary: #9CA3AF;--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.07), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 12px 40px rgba(0,0,0,.1), 0 4px 8px rgba(0,0,0,.04);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-pill: 999px;--font-body: "DM Sans", system-ui, sans-serif;--font-display: "Fraunces", Georgia, serif}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:var(--font-body);background:var(--bg-alt);color:var(--text-primary);-webkit-font-smoothing:antialiased;line-height:1.6}#root{height:100%}button{cursor:pointer;border:none;font-family:inherit;background:none}input{font-family:inherit}.app{display:flex;flex-direction:column;min-height:100dvh}.site-header{position:fixed;top:0;left:0;right:0;z-index:100;height:56px;background:#fffffff2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-xs)}.header-inner{max-width:480px;margin:0 auto;padding:0 20px;height:100%;display:flex;align-items:center;justify-content:space-between}.site-header-logo{font-size:.9rem;font-weight:700;color:var(--text-primary);text-decoration:none;letter-spacing:-.01em;transition:color .18s}.site-header-logo:hover{color:var(--indigo)}.site-header-right{display:flex;align-items:center;gap:14px}.site-footer{border-top:1px solid var(--border-light);background:var(--bg);padding:20px 0}.footer-inner{max-width:480px;margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between}.site-footer-link{font-size:.82rem;color:var(--text-tertiary);text-decoration:none;transition:color .18s}.site-footer-link:hover{color:var(--text-secondary);text-decoration:underline}.site-footer-contact{font-size:.82rem;font-weight:600;color:var(--indigo);text-decoration:none;padding:6px 16px;border:1.5px solid var(--indigo-mid);border-radius:var(--radius-pill);background:var(--indigo-light);transition:all .18s ease}.site-footer-contact:hover{background:var(--indigo);border-color:var(--indigo);color:#fff}.app-main{flex:1;display:flex;flex-direction:column;align-items:center;padding-top:56px}.step-container{width:100%;flex:1;display:flex;flex-direction:column;align-items:center}.step-container.fading-out{animation:stepFadeOut .4s ease-in forwards;pointer-events:none}@keyframes stepFadeOut{0%{opacity:1}to{opacity:0}}.view{width:100%;max-width:480px;flex:1;display:flex;flex-direction:column;align-items:center;padding:32px 20px 48px;animation:fadeSlideUp .5s ease-out both}@keyframes fadeSlideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.view-title{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:28px;text-align:center;line-height:1.3}.lang-switcher{display:flex;background:var(--bg-alt);border:1px solid var(--border);border-radius:var(--radius-pill);padding:3px;gap:2px}.lang-btn{padding:5px 14px;border-radius:var(--radius-pill);background:transparent;color:var(--text-secondary);font-size:.78rem;font-weight:600;letter-spacing:.04em;transition:all .18s ease}.lang-btn:hover:not(:disabled){color:var(--text-primary);background:#0000000a}.lang-btn.active{background:var(--indigo);color:#fff;box-shadow:var(--shadow-xs)}.lang-btn:disabled{opacity:.4;cursor:not-allowed}.progress-bar-wrap{flex:1;display:flex;flex-direction:column;gap:8px;justify-content:center;max-width:240px}.progress-bar-track{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--indigo);border-radius:2px;transition:width .4s ease}.progress-dots{display:flex;gap:6px;justify-content:center}.progress-dot{width:22px;height:22px;border-radius:50%;background:var(--bg-alt);border:1.5px solid var(--border);font-size:.65rem;font-weight:700;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;transition:all .25s ease}.progress-dot.done{background:var(--indigo-light);border-color:var(--indigo-mid);color:var(--indigo)}.progress-dot.current{background:var(--indigo);border-color:var(--indigo);color:#fff;box-shadow:0 0 0 3px var(--indigo-light)}.landing-view{position:relative;justify-content:center;min-height:calc(100dvh - 60px);background:var(--bg);overflow:hidden}.landing-dot-bg{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,#D1D5DB 1px,transparent 1px);background-size:28px 28px;opacity:.5;pointer-events:none}.landing-content{position:relative;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px;padding:0 8px}.landing-eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--indigo);background:var(--indigo-light);padding:4px 14px;border-radius:var(--radius-pill)}.landing-title{font-family:var(--font-display);font-size:clamp(1.75rem,6vw,2.75rem);font-weight:700;line-height:1.15;color:var(--text-primary);max-width:340px;word-break:keep-all}.landing-subtitle{font-size:1rem;color:var(--text-secondary);max-width:300px;line-height:1.65}.start-btn{margin-top:8px;padding:15px 40px;border-radius:var(--radius-pill);background:var(--indigo);color:#fff;font-size:1rem;font-weight:600;letter-spacing:.01em;box-shadow:0 4px 14px #4f46e559;transition:all .18s ease}.start-btn:hover{background:var(--indigo-dark);transform:translateY(-2px);box-shadow:0 8px 24px #4f46e566}.start-btn:active{transform:scale(.97)}.landing-hint{font-size:.8rem;color:var(--text-tertiary)}.q1-view{background:var(--bg-alt)}.constellation-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%}.constellation-card{display:flex;align-items:center;gap:8px;padding:12px 14px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-pill);transition:all .18s ease;box-shadow:var(--shadow-xs)}.constellation-card:hover{border-color:var(--indigo);background:var(--indigo-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.constellation-card:active{transform:scale(.96);background:var(--indigo)}.constellation-card:active .constellation-name,.constellation-card.selected .constellation-name{color:#fff}.constellation-card.selected{background:var(--indigo);border-color:var(--indigo);box-shadow:var(--shadow-sm)}.constellation-emoji{font-size:1.2rem;flex-shrink:0}.constellation-name{font-size:.82rem;font-weight:500;color:var(--text-primary);text-align:left;line-height:1.2}.q2-view{background:var(--bg-alt)}.image-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;width:100%}.image-card{aspect-ratio:3/2;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2.75rem;border:2px solid transparent;transition:all .2s ease;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.image-card:hover{transform:scale(1.03);box-shadow:var(--shadow-md)}.image-card:active{transform:scale(.97)}.image-card.selected{border-color:var(--indigo);box-shadow:0 0 0 3px var(--indigo-light),var(--shadow-md)}.image-card.selected:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#4f46e54d;border-radius:inherit}.image-photo{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:inherit}.image-check{position:absolute;top:10px;right:10px;z-index:2;width:26px;height:26px;background:var(--indigo);color:#fff;border-radius:50%;font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.qn-view{justify-content:center;min-height:calc(100dvh - 80px);background:var(--bg-alt)}.question-card{width:100%;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:32px 24px;display:flex;flex-direction:column;gap:24px;box-shadow:var(--shadow-md)}.question-card.loading-card{align-items:center;justify-content:center;min-height:220px}.question-text{font-family:var(--font-display);font-size:1.3rem;font-weight:600;line-height:1.4;text-align:center;color:var(--text-primary)}.options-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.option-btn{padding:14px 12px;border-radius:var(--radius-md);background:var(--bg);border:1.5px solid var(--border);color:var(--text-primary);font-size:.88rem;font-weight:500;line-height:1.35;text-align:center;transition:all .18s ease}.option-btn:hover{border-color:var(--indigo);background:var(--indigo-light);color:var(--indigo);box-shadow:var(--shadow-xs)}.option-btn:active,.option-btn.selected{background:var(--indigo);border-color:var(--indigo);color:#fff}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--indigo);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.q5-view{justify-content:center;min-height:calc(100dvh - 80px);background:var(--bg-alt)}.q5-form{display:flex;flex-direction:column;gap:14px;align-items:center;width:100%}.q5-input{width:100%;padding:14px 18px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:1.1rem;font-weight:500;outline:none;transition:border-color .2s,box-shadow .2s;text-align:center}.q5-input:focus{border-color:var(--indigo);box-shadow:0 0 0 3px var(--indigo-light)}.q5-input::placeholder{color:var(--text-tertiary)}.q5-char-count{font-size:.75rem;color:var(--text-tertiary);align-self:flex-end}.q5-chips{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;min-height:36px}.chip{padding:6px 18px;border-radius:var(--radius-pill);background:var(--indigo-light);border:1.5px solid var(--indigo-mid);color:var(--indigo);font-size:.85rem;font-weight:600;transition:all .18s ease;cursor:pointer}.chip:hover{background:var(--indigo);border-color:var(--indigo);color:#fff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.chip:active{transform:scale(.95)}.chip-skeleton{width:76px;height:34px;background:var(--border-light);border:1.5px solid var(--border);border-radius:var(--radius-pill);animation:shimmer 1.2s ease-in-out infinite;cursor:default}@keyframes shimmer{0%,to{opacity:.5}50%{opacity:1}}.submit-btn{padding:13px 40px;border-radius:var(--radius-pill);background:var(--indigo);color:#fff;font-size:1rem;font-weight:600;box-shadow:0 4px 14px #4f46e54d;transition:all .18s ease}.submit-btn:hover:not(:disabled){background:var(--indigo-dark);transform:translateY(-2px);box-shadow:0 6px 20px #4f46e566}.submit-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.loading-view{justify-content:center;align-items:center;min-height:calc(100dvh - 60px);background:var(--bg)}.loading-content{display:flex;flex-direction:column;align-items:center;gap:20px;text-align:center}.loading-dots{display:flex;gap:10px;align-items:center}.loading-dot{width:12px;height:12px;border-radius:50%;background:var(--indigo);animation:pulse-dot 1.2s ease-in-out infinite both}@keyframes pulse-dot{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.loading-title{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--text-primary)}.loading-subtitle{color:var(--text-secondary);font-size:.92rem;max-width:260px;line-height:1.65}.result-view{min-height:calc(100dvh - 60px);justify-content:flex-start;padding-top:28px;gap:20px;background:var(--bg-alt)}.result-card{width:100%;background:var(--surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:32px 24px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:24px;animation:fadeSlideUp .6s ease both}.result-card-header{display:flex;flex-direction:column;gap:10px}.result-eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--indigo)}.result-personality{font-size:.95rem;line-height:1.7;color:var(--text-secondary)}.career-nav{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:12px}.career-nav-btn{width:32px;height:32px;border-radius:50%;border:1.5px solid var(--border);background:var(--bg);color:var(--text-primary);font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .18s ease;box-shadow:var(--shadow-xs)}.career-nav-btn:hover:not(:disabled){border-color:var(--indigo);color:var(--indigo);background:var(--indigo-light)}.career-nav-btn:disabled{opacity:.3;cursor:default}.career-nav-indicator{font-size:.8rem;font-weight:600;color:var(--text-tertiary);min-width:36px;text-align:center}.career-card{background:var(--bg-alt);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:20px 16px 16px;display:flex;flex-direction:column;align-items:center;gap:8px}.career-card-title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--text-primary);text-align:center}.career-card-tagline{font-size:.85rem;color:var(--text-secondary);text-align:center;line-height:1.55;font-style:italic}.career-radar-wrap{width:100%;max-width:280px;margin:8px auto 0}.radar-subtitle{font-size:.73rem;color:var(--text-tertiary);text-align:center;margin-top:4px}.details-toggle{margin-top:10px;font-size:.78rem;font-weight:600;color:var(--text-tertiary);background:none;border:none;cursor:pointer;transition:color .18s;padding:4px 0}.details-toggle:hover{color:var(--indigo)}.details-panel{width:100%;max-height:0;overflow:hidden;transition:max-height .35s ease}.details-panel.open{max-height:800px}.details-inner{padding-top:12px;display:flex;flex-direction:column}.details-row{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;column-gap:8px;row-gap:3px;padding:10px 0;align-items:center}.details-row.divider{border-top:1px solid var(--border-light)}.details-label{font-size:.8rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.details-dim-desc{font-size:.75rem;color:var(--text-tertiary);text-align:right;line-height:1.3}.details-score{font-size:.8rem;font-weight:700;color:var(--indigo);white-space:nowrap}.details-explanation{grid-column:1 / -1;font-size:.8rem;color:var(--text-secondary);line-height:1.55}.result-section{display:flex;flex-direction:column;gap:8px}.result-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary)}.result-body{font-size:.92rem;line-height:1.7;color:var(--text-secondary)}.career-tags{display:flex;flex-wrap:wrap;gap:8px}.career-tag{padding:5px 16px;background:var(--indigo-light);border:1px solid var(--indigo-mid);border-radius:var(--radius-pill);font-size:.83rem;color:var(--indigo);font-weight:600}.famous-section{background:var(--bg-alt);border-left:3px solid var(--amber);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:14px 16px}.result-famous-name{font-size:1rem;font-weight:700;color:var(--text-primary)}.personal-sentence{border-top:1px solid var(--border-light);padding-top:20px}.result-personal{font-family:var(--font-display);font-style:italic;font-size:1.05rem;line-height:1.65;color:var(--indigo)}.retry-btn{padding:12px 32px;border-radius:var(--radius-pill);background:transparent;border:1.5px solid var(--indigo);color:var(--indigo);font-size:.95rem;font-weight:600;transition:all .18s ease}.retry-btn:hover{background:var(--indigo);color:#fff;box-shadow:0 4px 14px #4f46e54d}.toast{position:fixed;bottom:32px;left:50%;transform:translate(-50%);background:var(--text-primary);color:#fff;padding:10px 22px;border-radius:var(--radius-pill);font-size:.85rem;font-weight:500;z-index:100;box-shadow:var(--shadow-md);white-space:nowrap;animation:toast-in .3s ease,toast-out .3s ease 2.7s forwards}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes toast-out{to{opacity:0;transform:translate(-50%) translateY(16px)}}@media(max-width:360px){.constellation-grid{grid-template-columns:repeat(2,1fr)}.options-grid{grid-template-columns:1fr}}
