:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{min-height:100svh}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*{box-sizing:border-box;margin:0;padding:0}body{color:#f0f0f0;background:#0a0a0a;min-height:100vh;font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#root{border:none;width:100%;max-width:100%;min-height:100vh}.app{flex-direction:column;min-height:100vh;display:flex}.header{text-align:center;border-bottom:1px solid #1e1e1e;padding:32px 24px 24px}.logo{letter-spacing:.05em;color:#fff;font-size:20px;font-weight:600}.tagline{color:#666;letter-spacing:.08em;margin-top:6px;font-size:13px}.main{flex-direction:column;flex:1;align-items:center;padding:48px 24px;display:flex}.profile-form{flex-direction:column;gap:40px;width:100%;max-width:480px;display:flex}.form-title{color:#fff;letter-spacing:-.5px;font-size:32px;font-weight:700}.form-desc{color:#888;margin-top:8px;font-size:15px;line-height:1.6}.section{flex-direction:column;gap:12px;display:flex}.section-label{letter-spacing:.1em;text-transform:uppercase;color:#aaa;font-size:13px;font-weight:600}.photo-upload{aspect-ratio:3/4;cursor:pointer;background:#111;border:2px dashed #2e2e2e;border-radius:20px;justify-content:center;align-items:center;width:100%;max-height:420px;transition:border-color .2s,background .2s;display:flex;position:relative;overflow:hidden}.photo-upload:hover{background:#151515;border-color:#444}.photo-upload.dragging{background:#c084fc0d;border-color:#c084fc}.photo-upload.has-photo{border-style:solid;border-color:#2e2e2e}.photo-placeholder{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:24px;display:flex}.upload-icon{color:#555;transition:color .2s}.photo-upload:hover .upload-icon{color:#888}.upload-text{color:#666;font-size:15px}.upload-hint{color:#444;font-size:12px}.photo-preview{object-fit:cover;object-position:top center;width:100%;height:100%}.file-input{display:none}.remove-photo{color:#888;cursor:pointer;background:0 0;border:1px solid #2e2e2e;border-radius:8px;align-self:flex-end;padding:6px 14px;font-size:13px;transition:border-color .2s,color .2s}.remove-photo:hover{color:#ccc;border-color:#555}.body-inputs{grid-template-columns:1fr 1fr;gap:16px;display:grid}.input-group{flex-direction:column;gap:8px;display:flex}.input-group label{color:#888;font-size:14px}.input-wrapper{align-items:center;display:flex;position:relative}.input-wrapper input{color:#fff;-moz-appearance:textfield;background:#111;border:1px solid #2e2e2e;border-radius:12px;outline:none;width:100%;padding:16px 48px 16px 18px;font-size:20px;font-weight:600;transition:border-color .2s}.input-wrapper input::-webkit-outer-spin-button{-webkit-appearance:none}.input-wrapper input::-webkit-inner-spin-button{-webkit-appearance:none}.input-wrapper input:focus{border-color:#c084fc}.input-wrapper input::placeholder{color:#333;font-weight:400}.unit{color:#555;pointer-events:none;font-size:13px;position:absolute;right:16px}.btn-group{flex-direction:column;gap:12px;display:flex}.submit-btn{color:#fff;cursor:pointer;letter-spacing:.02em;background:linear-gradient(135deg,#c084fc,#818cf8);border:none;border-radius:14px;width:100%;padding:18px;font-size:16px;font-weight:600;transition:opacity .2s,transform .1s}.hair-btn{background:linear-gradient(135deg,#f472b6,#fb923c)}.submit-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.3;cursor:not-allowed}.loading-state{color:#888;flex-direction:column;align-items:center;gap:16px;padding:48px 24px;font-size:15px;display:flex}.loading-spinner{border:2px solid #2e2e2e;border-top-color:#c084fc;border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.error-state{color:#fca5a5;text-align:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:12px;max-width:480px;margin:0 auto;padding:16px 20px;font-size:14px}.report{flex-direction:column;gap:16px;width:100%;max-width:480px;margin:0 auto;padding-top:48px;display:flex}.report-title{color:#fff;letter-spacing:-.3px;border-bottom:1px solid #1e1e1e;padding-bottom:16px;font-size:24px;font-weight:700}.report-card{background:#111;border:1px solid #1e1e1e;border-radius:16px;flex-direction:column;gap:12px;padding:20px;display:flex}.report-card h3{letter-spacing:.1em;text-transform:uppercase;color:#666;font-size:12px;font-weight:600}.report-value{color:#fff;font-size:18px;font-weight:600}.tag-list{flex-wrap:wrap;gap:8px;list-style:none;display:flex}.tag{color:#ccc;background:#1a1a1a;border:1px solid #2e2e2e;border-radius:20px;padding:4px 12px;font-size:13px}.color-tag{color:#e9d5ff;border-color:#c084fc66}.item-list{flex-direction:column;gap:8px;list-style:none;display:flex}.item-list li{color:#ccc;padding-left:16px;font-size:14px;line-height:1.5;position:relative}.item-list li:before{content:"—";color:#555;position:absolute;left:0}.avoid-list li:before{content:"✕";color:#ef4444;font-size:11px}.advice-card{background:#c084fc0d;border-color:#c084fc33}.advice-text{color:#e9d5ff;font-size:15px;line-height:1.7}.hair-report{margin-top:0}.report-subtitle{color:#666;margin-top:-8px;margin-bottom:4px;font-size:14px}.hair-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.hair-card{background:#111;border:1px solid #1e1e1e;border-radius:16px;flex-direction:column;transition:border-color .2s,transform .2s;display:flex;overflow:hidden}.hair-card:hover{border-color:#333;transform:translateY(-2px)}.hair-card-image{aspect-ratio:2/3;flex-shrink:0;width:100%;overflow:hidden}.hair-img{object-fit:cover;object-position:top center;width:100%;height:100%;display:block}.hair-img-placeholder{opacity:.7;justify-content:center;align-items:center;width:100%;height:100%;font-size:28px;display:flex}@keyframes shimmer{0%{opacity:.5}50%{opacity:.8}to{opacity:.5}}.shimmer{animation:1.4s ease-in-out infinite shimmer}.hair-card-body{flex-direction:column;flex:1;gap:8px;padding:14px;display:flex}.hair-badges{flex-wrap:wrap;gap:6px;display:flex}.hair-badge{letter-spacing:.06em;text-transform:uppercase;color:#888;background:#1a1a1a;border:1px solid #2e2e2e;border-radius:20px;padding:2px 8px;font-size:10px;font-weight:600}.hair-korean{color:#fff;font-size:15px;font-weight:700;line-height:1.3}.hair-english{color:#555;margin-top:-4px;font-size:11px}.hair-desc{color:#aaa;font-size:12px;line-height:1.6}.hair-why{background:#c084fc12;border-left:2px solid #c084fc;border-radius:0 8px 8px 0;margin-top:2px;padding:8px 10px}.hair-why-label{letter-spacing:.06em;text-transform:uppercase;color:#c084fc;margin-bottom:4px;font-size:10px;font-weight:600;display:block}.hair-why p{color:#ccc;font-size:12px;line-height:1.5}.hair-tip{align-items:flex-start;gap:6px;margin-top:2px;display:flex}.hair-tip-icon{flex-shrink:0;margin-top:1px;font-size:12px}.hair-tip p{color:#666;font-size:11px;line-height:1.5}@media (width<=480px){.header{padding:24px 20px 20px}.main{padding:32px 20px}.form-title{font-size:26px}.photo-upload{max-height:360px}.hair-grid{grid-template-columns:repeat(2,1fr);gap:10px}}
