*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#0f0f0f;color:#f5f0e8;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}:root{--primary: #8c30e8;--primary-hover: #7a26d4;--bg: #191121;--bg-card: rgba(255, 255, 255, .05);--bg-card-hover: rgba(255, 255, 255, .08);--border: rgba(255, 255, 255, .1);--text: #ffffff;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--text-faint: #64748b;--font: "Plus Jakarta Sans", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100dvh;-webkit-font-smoothing:antialiased}.screen{position:relative;display:flex;flex-direction:column;min-height:100dvh;max-width:430px;margin:0 auto;background:var(--bg);overflow-x:hidden;padding-bottom:140px}.topnav{display:flex;flex-direction:column;gap:12px;padding:24px 16px 0}.topnav-row{display:flex;align-items:center;justify-content:space-between}.back-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);color:var(--text);cursor:pointer;transition:background .2s}.back-btn:hover{background:var(--bg-card-hover)}.back-btn .material-symbols-outlined{font-size:18px}.step-label{font-size:13px;font-weight:600;color:var(--text-muted)}.topnav-spacer{width:40px}.progress-row{display:flex;justify-content:space-between;align-items:center;padding:0 4px}.progress-title{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--primary)}.progress-pct{font-size:11px;font-weight:500;color:var(--text-muted)}.progress-bar{height:6px;width:100%;border-radius:999px;background:var(--bg-card);overflow:hidden}.progress-fill{height:100%;border-radius:999px;background:var(--primary);transition:width .4s ease}.main-content{flex:1;padding:36px 24px 0}.step-header{text-align:center;margin-bottom:40px}.step-title{font-size:30px;font-weight:800;line-height:1.2;letter-spacing:-.5px;color:var(--text);margin-bottom:12px}.step-desc{font-size:14px;color:var(--text-muted);line-height:1.65;max-width:280px;margin:0 auto}.photo-upload{position:relative;width:100%;aspect-ratio:3 / 4;border-radius:20px;border:1.5px dashed var(--border);background:var(--bg-card);cursor:pointer;overflow:hidden;transition:border-color .2s,background .2s;display:flex;align-items:center;justify-content:center}.photo-upload:hover{border-color:var(--primary);background:#8c30e80d}.photo-upload.drag-over{border-color:var(--primary);background:#8c30e814}.photo-upload.has-photo{border-style:solid;border-color:var(--border)}.photo-preview{width:100%;height:100%;object-fit:cover;display:block}.photo-overlay{position:absolute;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.photo-upload:hover .photo-overlay{opacity:1}.photo-overlay-text{font-size:14px;font-weight:600;color:#fff;letter-spacing:.5px}.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:16px}.upload-icon-wrap{width:64px;height:64px;border-radius:50%;background:var(--bg-card-hover);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:color .2s,background .2s}.photo-upload:hover .upload-icon-wrap{background:#8c30e826;color:var(--primary)}.upload-icon-wrap .material-symbols-outlined{font-size:28px}.upload-text{font-size:15px;font-weight:600;color:var(--text-secondary)}.upload-hint{font-size:12px;color:var(--text-faint)}.form-sections{display:flex;flex-direction:column;gap:36px}.form-section-label{font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-secondary);margin-bottom:16px;padding:0 4px}.gender-toggle{display:flex;padding:6px;border-radius:14px;background:var(--bg-card);border:1px solid var(--border);gap:2px}.gender-option{flex:1}.gender-option input{position:absolute;opacity:0;width:0;height:0}.gender-label{display:flex;height:48px;align-items:center;justify-content:center;border-radius:10px;font-size:14px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .2s}.gender-option input:checked+.gender-label{background:var(--primary);color:#fff;box-shadow:0 4px 16px #8c30e859}.slider-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:12px;padding:0 4px}.slider-value{display:flex;align-items:baseline;gap:4px}.slider-num{font-size:28px;font-weight:800;color:var(--primary);line-height:1}.slider-unit{font-size:13px;font-weight:500;color:var(--text-muted)}.slider-wrap{position:relative;height:56px;display:flex;align-items:center}.slider-glow{position:absolute;inset:0;background:#8c30e814;border-radius:14px;filter:blur(12px);opacity:0;transition:opacity .2s;pointer-events:none}.slider-wrap:hover .slider-glow{opacity:1}input[type=range]{width:100%;height:6px;border-radius:999px;background:var(--bg-card-hover);appearance:none;cursor:pointer;position:relative;z-index:1;accent-color:var(--primary)}input[type=range]::-webkit-slider-thumb{appearance:none;width:22px;height:22px;border-radius:50%;background:var(--primary);box-shadow:0 2px 8px #8c30e880;cursor:pointer;transition:box-shadow .2s}input[type=range]::-webkit-slider-thumb:hover{box-shadow:0 2px 16px #8c30e8b3}.slider-range{display:flex;justify-content:space-between;padding:0 4px;margin-top:-4px}.slider-range span{font-size:10px;font-weight:700;color:var(--text-faint)}.error-box{margin:16px 24px 0;padding:14px 16px;border-radius:12px;background:#ef44441a;border:1px solid rgba(239,68,68,.25);color:#f87171;font-size:13px;font-weight:500;line-height:1.5}.footer{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:430px;padding:20px 24px;background:linear-gradient(to top,var(--bg) 70%,transparent);z-index:10}.continue-btn{width:100%;padding:18px;border-radius:14px;border:none;background:var(--primary);color:#fff;font-size:16px;font-weight:700;font-family:var(--font);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 8px 24px #8c30e859;letter-spacing:.3px}.continue-btn:hover{background:var(--primary-hover);transform:translateY(-1px)}.continue-btn:active{transform:scale(.98)}.continue-btn:disabled{background:var(--bg-card-hover);color:var(--text-faint);box-shadow:none;cursor:not-allowed;transform:none}.continue-btn .material-symbols-outlined{font-size:20px}.home-indicator{display:flex;justify-content:center;margin-top:12px}.home-indicator-bar{width:128px;height:5px;border-radius:999px;background:var(--bg-card-hover)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;gap:20px;background:var(--bg);max-width:430px;margin:0 auto}.loading-spinner{width:52px;height:52px;border:3px solid var(--bg-card-hover);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:17px;font-weight:700;color:var(--text)}.loading-sub{font-size:13px;color:var(--text-muted)}.result-screen{max-width:430px;margin:0 auto;padding:48px 20px 60px;background:var(--bg);min-height:100dvh}.result-header{text-align:center;margin-bottom:32px}.result-sub{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--primary);margin-bottom:8px}.result-title{font-size:28px;font-weight:800;color:var(--text)}.report{display:flex;flex-direction:column;gap:20px}.report-hero{padding:28px 24px;border-radius:18px;background:linear-gradient(135deg,#8c30e833,#8c30e80d);border:1px solid rgba(140,48,232,.25);text-align:center}.report-body-type{font-size:22px;font-weight:800;color:var(--primary);margin-bottom:8px}.report-body-desc{font-size:14px;color:var(--text-secondary);line-height:1.65}.report-section{background:var(--bg-card);border:1px solid var(--border);border-radius:18px;padding:22px 20px}.report-section-title{font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--primary);margin-bottom:16px}.style-list{display:flex;flex-direction:column;gap:14px}.style-item{display:flex;gap:14px;align-items:flex-start}.style-number{font-size:11px;font-weight:700;color:var(--primary);min-width:28px;padding-top:2px}.style-name{font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}.style-desc{font-size:13px;color:var(--text-muted);line-height:1.55}.items-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.item-card{background:var(--bg-card-hover);border-radius:12px;padding:14px}.item-label{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text-faint);margin-bottom:6px}.item-value{font-size:13px;font-weight:600;color:var(--text-secondary)}.color-palette{display:flex;gap:10px;flex-wrap:wrap}.color-swatch{flex:1;min-width:48px;height:64px;border-radius:12px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:6px;box-shadow:0 4px 12px #0000004d}.color-code{font-size:9px;font-weight:700;color:#ffffffe6;text-shadow:0 1px 3px rgba(0,0,0,.5);letter-spacing:.5px}.avoid-box{font-size:14px;color:var(--text-secondary);line-height:1.65}
