*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8f5ff;margin:0;font-family:Pretendard,Noto Sans KR,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}#root{width:100%;min-height:100vh}button{font-family:inherit}h1,h2,h3,h4,p{margin:0}*,:before,:after{box-sizing:border-box;margin:0;padding:0}.app{color:#1a1a2e;background:#f8f5ff;flex-direction:column;min-height:100vh;font-family:Pretendard,Noto Sans KR,system-ui,-apple-system,sans-serif;display:flex}.header{text-align:center;background:linear-gradient(135deg,#6d28d9 0%,#9333ea 50%,#ec4899 100%);padding:48px 24px 0;position:relative;overflow:hidden}.header:before{content:"";background:radial-gradient(circle at 20%,#ffffff1a 0%,#0000 60%),radial-gradient(circle at 80% 20%,#ffffff14 0%,#0000 50%);position:absolute;inset:0}.header-inner{z-index:1;max-width:600px;margin:0 auto;padding-bottom:48px;position:relative}.logo{align-items:center;gap:10px;margin-bottom:12px;display:inline-flex}.logo-icon{filter:drop-shadow(0 4px 8px #0003);font-size:40px;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.logo-text{color:#fff;letter-spacing:-.5px;text-shadow:0 2px 12px #0003;font-size:36px;font-weight:800}.logo-badge{color:#fff;letter-spacing:1px;background:#ffffff40;border:1px solid #fff6;border-radius:20px;padding:3px 8px;font-size:11px;font-weight:700}.header-sub{color:#ffffffe6;text-shadow:0 1px 4px #00000026;font-size:18px;font-weight:400}.header-wave{height:48px;margin-top:-1px;position:relative}.header-wave svg{width:100%;height:100%;position:absolute;bottom:0;left:0}.main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:32px 20px 48px}.steps-bar{justify-content:center;align-items:center;gap:0;margin-bottom:32px;display:flex}.step-item{color:#7c3aed;align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.step-num{color:#fff;background:linear-gradient(135deg,#7c3aed,#ec4899);border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex;box-shadow:0 2px 8px #7c3aed66}.step-divider{opacity:.4;background:linear-gradient(90deg,#7c3aed,#ec4899);width:48px;height:2px;margin:0 8px}.content-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;display:grid}@media (width<=768px){.content-grid{grid-template-columns:1fr}}.card{background:#fff;border:1px solid #6d28d914;border-radius:20px;padding:28px;box-shadow:0 4px 24px #6d28d914,0 1px 4px #0000000a}.card-header{margin-bottom:24px}.card-header h2{color:#1a1a2e;margin-bottom:6px;font-size:20px;font-weight:700}.card-header p{color:#64748b;font-size:14px}.upload-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=480px){.upload-grid{grid-template-columns:1fr}}.upload-section{flex-direction:column;gap:8px;display:flex}.upload-tag{text-align:center;border-radius:20px;width:fit-content;margin:0 auto;padding:3px 10px;font-size:11px;font-weight:600}.upload-tag.required{color:#db2777;background:#fce7f3}.upload-tag.optional{color:#7c3aed;background:#ede9fe}.photo-upload{cursor:pointer;aspect-ratio:1;background:#faf7ff;border:2px dashed #d1c4f0;border-radius:16px;transition:all .25s;position:relative;overflow:hidden}.photo-upload:hover,.photo-upload.dragging{border-color:var(--accent,#7c3aed);background:#6d28d90a;transform:translateY(-2px);box-shadow:0 8px 24px #6d28d91f}.photo-upload.has-preview{border-style:solid;border-color:var(--accent,#7c3aed);cursor:default}.upload-placeholder{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:6px;height:100%;padding:20px;display:flex}.upload-icon-wrap{background:linear-gradient(135deg,#6d28d91a,#ec48991a);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:4px;display:flex}.upload-icon{font-size:28px}.upload-label{color:#1a1a2e;font-size:14px;font-weight:700}.upload-sublabel{color:#94a3b8;font-size:12px}.upload-hint{color:#7c3aed;background:#6d28d90f;border-radius:20px;margin-top:4px;padding:4px 10px;font-size:11px;font-weight:600}.upload-formats{color:#cbd5e1;font-size:10px}.preview-container{width:100%;height:100%;position:relative}.preview-image{object-fit:cover;width:100%;height:100%}.preview-overlay{background:0 0;justify-content:center;align-items:center;transition:background .2s;display:flex;position:absolute;inset:0}.preview-container:hover .preview-overlay{background:#0006}.change-btn{color:#1a1a2e;cursor:pointer;opacity:0;background:#fff;border:none;border-radius:20px;padding:8px 16px;font-size:13px;font-weight:600;transition:opacity .2s;box-shadow:0 2px 8px #0003}.preview-container:hover .change-btn{opacity:1}.preview-badge{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;font-size:11px;font-weight:600;display:flex;position:absolute;bottom:8px;left:8px}.form-group{margin-bottom:20px}.form-label{color:#374151;align-items:center;gap:6px;margin-bottom:10px;font-size:14px;font-weight:600;display:flex}.age-display{color:#fff;background:linear-gradient(135deg,#7c3aed,#ec4899);border-radius:20px;margin-left:auto;padding:2px 12px;font-size:13px;font-weight:700}.slider-wrap{flex-direction:column;gap:4px;display:flex}.age-slider{appearance:none;cursor:pointer;background:linear-gradient(90deg,#7c3aed,#ec4899);border-radius:3px;outline:none;width:100%;height:6px}.age-slider::-webkit-slider-thumb{appearance:none;cursor:pointer;background:#fff;border:3px solid #7c3aed;border-radius:50%;width:20px;height:20px;transition:transform .15s;box-shadow:0 2px 8px #7c3aed4d}.age-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.slider-labels{color:#94a3b8;justify-content:space-between;padding:0 2px;font-size:11px;display:flex}.gender-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.gender-btn{cursor:pointer;color:#6b7280;background:#fff;border:2px solid #e5e7eb;border-radius:14px;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;font-size:13px;font-weight:600;transition:all .2s;display:flex}.gender-btn:hover{color:#7c3aed;background:#faf5ff;border-color:#c4b5fd}.gender-btn.active{color:#7c3aed;background:linear-gradient(135deg,#ede9fe,#fce7f3);border-color:#7c3aed;box-shadow:0 4px 12px #7c3aed26}.gender-icon{font-size:28px}.api-toggle{cursor:pointer;color:#374151;background:#f8f5ff;border:1.5px solid #e5e7eb;border-radius:12px;align-items:center;gap:8px;width:100%;padding:12px 16px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.api-toggle:hover{color:#7c3aed;background:#ede9fe;border-color:#7c3aed}.chevron{margin-left:auto;font-size:20px;transition:transform .2s;display:inline-block}.chevron.open{transform:rotate(90deg)}.api-key-wrap{background:#f8f5ff;border:1px solid #e5e7eb;border-radius:12px;margin-top:12px;padding:14px}.api-hint{color:#64748b;margin-bottom:10px;font-size:12px}.api-hint a{color:#7c3aed;font-weight:600;text-decoration:none}.api-hint a:hover{text-decoration:underline}.api-input-row{gap:8px;display:flex}.api-input{color:#374151;background:#fff;border:1.5px solid #d1d5db;border-radius:10px;outline:none;flex:1;padding:10px 14px;font-family:monospace;font-size:13px;transition:border-color .2s}.api-input:focus{border-color:#7c3aed;box-shadow:0 0 0 3px #7c3aed1a}.api-eye{cursor:pointer;background:#fff;border:1.5px solid #d1d5db;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;transition:all .2s;display:flex}.api-eye:hover{background:#f5f3ff;border-color:#7c3aed}.error-msg{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:10px;align-items:center;gap:8px;margin-bottom:16px;padding:12px 16px;font-size:13px;font-weight:500;display:flex}.generate-btn{color:#fff;cursor:pointer;letter-spacing:.3px;background:linear-gradient(135deg,#7c3aed 0%,#9333ea 50%,#ec4899 100%);border:none;border-radius:14px;justify-content:center;align-items:center;gap:10px;width:100%;padding:16px 24px;font-size:16px;font-weight:700;transition:all .25s;display:flex;box-shadow:0 4px 20px #7c3aed66}.generate-btn:hover:not(.disabled){transform:translateY(-2px);box-shadow:0 8px 28px #7c3aed80}.generate-btn:active:not(.disabled){transform:translateY(0)}.generate-btn.disabled{opacity:.5;cursor:not-allowed;box-shadow:none;background:#9ca3af}.btn-icon{font-size:20px}.generate-hint{text-align:center;color:#94a3b8;margin-top:10px;font-size:12px}.info-box{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@media (width<=640px){.info-box{grid-template-columns:1fr}}.info-item{background:#fff;border:1px solid #6d28d914;border-radius:16px;align-items:flex-start;gap:14px;padding:20px;display:flex;box-shadow:0 2px 12px #6d28d90a}.info-icon{flex-shrink:0;font-size:28px}.info-item strong{color:#1a1a2e;margin-bottom:4px;font-size:14px;font-weight:700;display:block}.info-item p{color:#64748b;font-size:12px;line-height:1.5}.loading-screen{justify-content:center;align-items:center;min-height:60vh;display:flex}.loading-card{text-align:center;background:#fff;border:1px solid #6d28d914;border-radius:24px;width:100%;max-width:440px;padding:48px 40px;box-shadow:0 8px 40px #6d28d91f}.loading-animation{justify-content:center;margin-bottom:32px;display:flex}.pulse-rings{justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:relative}.ring{border:3px solid #0000;border-radius:50%;animation:2s ease-in-out infinite pulse-ring;position:absolute}.ring1{border-color:#7c3aed33;width:100px;height:100px;animation-delay:0s}.ring2{border-color:#9333ea59;width:72px;height:72px;animation-delay:.3s}.ring3{border-color:#ec489980;width:48px;height:48px;animation-delay:.6s}.ring-center{z-index:1;font-size:28px;animation:4s linear infinite spin-slow;position:relative}@keyframes pulse-ring{0%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.05)}to{opacity:.3;transform:scale(.8)}}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-title{color:#1a1a2e;margin-bottom:12px;font-size:22px;font-weight:700}.loading-status{color:#7c3aed;min-height:20px;margin-bottom:24px;font-size:14px;font-weight:500}.progress-bar-wrap{background:#ede9fe;border-radius:3px;width:100%;height:6px;margin-bottom:16px;overflow:hidden}.progress-bar-inner{background:linear-gradient(90deg,#7c3aed,#ec4899);border-radius:3px;height:100%;animation:2.5s ease-in-out infinite progress-move}@keyframes progress-move{0%{width:0%;transform:translate(0)}50%{width:70%}to{width:100%;transform:translate(0)}}.loading-note{color:#94a3b8;margin-top:8px;font-size:12px}.result-screen{flex-direction:column;align-items:center;gap:32px;display:flex}.result-header{text-align:center}.result-header h2{color:#1a1a2e;margin-bottom:8px;font-size:28px;font-weight:800}.result-header p{color:#64748b;font-size:16px}.result-comparison{flex-wrap:wrap;justify-content:center;align-items:center;gap:24px;display:flex}.compare-card{flex-direction:column;align-items:center;gap:12px;display:flex}.compare-label{color:#64748b;background:#f1f5f9;border-radius:20px;padding:6px 16px;font-size:14px;font-weight:600}.active-label{color:#fff;background:linear-gradient(135deg,#7c3aed,#ec4899)}.compare-img{object-fit:cover;border-radius:20px;width:220px;height:220px;box-shadow:0 8px 32px #0000001f}.result-highlight .compare-img{border:3px solid #7c3aed;box-shadow:0 12px 40px #7c3aed4d}.compare-age{color:#374151;background:#fff;border:1.5px solid #e5e7eb;border-radius:20px;padding:4px 14px;font-size:14px;font-weight:700}.active-age{color:#7c3aed;background:linear-gradient(135deg,#ede9fe,#fce7f3);border-color:#c4b5fd}.compare-arrow{justify-content:center;align-items:center;display:flex}.arrow-inner{flex-direction:column;align-items:center;gap:6px;display:flex}.arrow-icon{font-size:32px}.arrow-text{color:#7c3aed;white-space:nowrap;background:#ede9fe;border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}.parent-ref{background:#fff;border:1px solid #e5e7eb;border-radius:14px;align-items:center;gap:12px;padding:14px 20px;display:flex;box-shadow:0 2px 8px #0000000a}.parent-ref p{color:#64748b;font-size:13px;font-weight:500}.parent-thumb{object-fit:cover;border:2px solid #c4b5fd;border-radius:50%;width:44px;height:44px}.result-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.action-btn{cursor:pointer;border:none;border-radius:14px;align-items:center;gap:8px;padding:14px 28px;font-size:15px;font-weight:700;transition:all .2s;display:flex}.primary-btn{color:#fff;background:linear-gradient(135deg,#7c3aed,#ec4899);box-shadow:0 4px 16px #7c3aed59}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #7c3aed73}.secondary-btn{color:#7c3aed;background:#fff;border:2px solid #7c3aed}.secondary-btn:hover{background:#ede9fe;transform:translateY(-2px)}.disclaimer{color:#94a3b8;text-align:center;max-width:480px;font-size:12px}.footer{text-align:center;background:#fff;border-top:1px solid #f1f5f9;padding:24px}.footer p{color:#64748b;font-size:14px;font-weight:500}.footer-sub{color:#94a3b8;margin-top:4px;font-size:12px}@media (width<=480px){.header-inner{padding-bottom:36px}.logo-text{font-size:28px}.header-sub{font-size:15px}.main{padding:20px 16px 40px}.card{padding:20px}.steps-bar{gap:0}.step-divider{width:28px}.compare-img{width:160px;height:160px}.result-comparison{gap:16px}}
