*,:before,:after{box-sizing:border-box}:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Pretendard,Apple SD Gothic Neo,system-ui,-apple-system,sans-serif}body{background:#faf9f7;margin:0;padding:0}#root{min-height:100vh}.profile-page{background:#faf9f7;flex-direction:column;align-items:center;min-height:100vh;padding:60px 24px 80px;display:flex}.profile-header{text-align:center;margin-bottom:48px}.profile-subtitle{letter-spacing:2px;text-transform:uppercase;color:#b89f7a;margin-bottom:12px;font-size:13px;font-weight:600}.profile-title{color:#1a1a1a;letter-spacing:-1px;margin:0 0 16px;font-size:42px;font-weight:700;line-height:1.1}.profile-desc{color:#7a7a7a;max-width:420px;font-size:16px;line-height:1.6}.profile-form{flex-direction:column;gap:32px;width:100%;max-width:480px;display:flex}.form-section{flex-direction:column;gap:12px;display:flex}.section-label{color:#1a1a1a;letter-spacing:.3px;font-size:14px;font-weight:600}.photo-upload{aspect-ratio:3/4;cursor:pointer;background:#fff;border:2px dashed #d9d2c8;border-radius:20px;justify-content:center;align-items:center;width:100%;max-height:420px;transition:border-color .25s,background .25s,box-shadow .25s;display:flex;position:relative;overflow:hidden}.photo-upload:hover,.photo-upload.dragging{background:#fdf8f2;border-color:#b89f7a;box-shadow:0 8px 32px #b89f7a26}.photo-upload.has-photo{border-style:solid;border-color:#0000}.photo-placeholder{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:32px;display:flex}.upload-icon{color:#b89f7a;background:#f5f0e8;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:4px;display:flex}.upload-icon svg{width:28px;height:28px}.upload-text{color:#3a3a3a;margin:0;font-size:15px;font-weight:500}.upload-hint{color:#aaa;margin:0;font-size:13px}.photo-preview{object-fit:cover;width:100%;height:100%}.photo-overlay{opacity:0;background:#00000073;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.photo-upload:hover .photo-overlay{opacity:1}.photo-overlay span{color:#fff;letter-spacing:.5px;font-size:15px;font-weight:600}.body-inputs{grid-template-columns:1fr 1fr;gap:16px;display:grid}.input-group{flex-direction:column;gap:8px;display:flex}.input-label{color:#7a7a7a;font-size:13px;font-weight:500}.input-wrapper{align-items:center;display:flex;position:relative}.input-wrapper input{color:#1a1a1a;box-sizing:border-box;appearance:textfield;background:#fff;border:1.5px solid #e5ddd3;border-radius:12px;outline:none;width:100%;padding:14px 48px 14px 18px;font-size:20px;font-weight:600;transition:border-color .2s,box-shadow .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:#b89f7a;box-shadow:0 0 0 3px #b89f7a26}.input-wrapper input::placeholder{color:#ccc;font-weight:400}.input-unit{color:#b89f7a;pointer-events:none;font-size:14px;font-weight:500;position:absolute;right:16px}.submit-btn{color:#fff;letter-spacing:.3px;cursor:pointer;background:#1a1a1a;border:none;border-radius:14px;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:8px;padding:18px;font-size:16px;font-weight:600;transition:background .2s,transform .15s,box-shadow .2s;display:flex}.submit-btn svg{width:20px;height:20px;transition:transform .2s}.submit-btn:hover:not(:disabled){background:#b89f7a;box-shadow:0 8px 24px #b89f7a59}.submit-btn:hover:not(:disabled) svg{transform:translate(4px)}.submit-btn:active:not(:disabled){transform:scale(.98)}.submit-btn:disabled{cursor:not-allowed;background:#d9d2c8}@media (width<=480px){.profile-title{font-size:32px}.photo-upload{max-height:340px}}.report-page{background:#faf9f7;flex-direction:column;align-items:center;min-height:100vh;padding:60px 24px 80px;display:flex}.report-header{text-align:center;margin-bottom:48px}.report-subtitle{letter-spacing:2px;text-transform:uppercase;color:#b89f7a;margin-bottom:12px;font-size:13px;font-weight:600}.report-title{color:#1a1a1a;letter-spacing:-1px;margin:0;font-size:36px;font-weight:700}.report-body{grid-template-columns:220px 1fr;align-items:start;gap:32px;width:100%;max-width:900px;display:grid}.report-aside{position:sticky;top:24px}.report-photo{aspect-ratio:3/4;object-fit:cover;border-radius:20px;width:100%;box-shadow:0 8px 32px #0000001a}.report-sections{flex-direction:column;gap:20px;display:flex}.report-section{background:#fff;border-radius:16px;padding:24px 28px;box-shadow:0 2px 12px #0000000d}.section-header{align-items:center;gap:10px;margin-bottom:14px;display:flex}.section-icon{font-size:20px;line-height:1}.section-title{color:#1a1a1a;letter-spacing:-.3px;margin:0;font-size:17px;font-weight:700}.section-content{flex-direction:column;gap:6px;display:flex}.section-content p{color:#444;margin:0;font-size:15px;line-height:1.7}.section-content strong{color:#1a1a1a;font-weight:600}.report-list-item{color:#444;align-items:flex-start;gap:10px;font-size:15px;line-height:1.7;display:flex}.bullet{background:#b89f7a;border-radius:50%;flex-shrink:0;width:6px;height:6px;margin-top:8px}.hair-section{width:100%;max-width:900px;margin-top:48px}.hair-section-header{text-align:center;margin-bottom:28px}.hair-section-title{color:#1a1a1a;letter-spacing:-.5px;margin:0 0 8px;font-size:24px;font-weight:700}.hair-section-desc{color:#888;margin:0;font-size:14px}.hair-trigger-btn{color:#fff;cursor:pointer;letter-spacing:-.2px;background:linear-gradient(135deg,#b89f7a,#d4b896);border:none;border-radius:16px;justify-content:center;align-items:center;gap:10px;width:100%;padding:18px 32px;font-size:16px;font-weight:700;transition:opacity .2s,transform .15s;display:flex}.hair-trigger-btn svg{flex-shrink:0;width:20px;height:20px}.hair-trigger-btn:hover{opacity:.9;transform:translateY(-1px)}.hair-trigger-btn:active{transform:translateY(0)}.hair-loading{flex-direction:column;align-items:center;gap:12px;padding:48px 0;display:flex}.hair-error{text-align:center;color:#888;flex-direction:column;align-items:center;gap:12px;padding:32px 0;font-size:14px;display:flex}.hair-retry-btn{color:#b89f7a;cursor:pointer;background:0 0;border:1.5px solid #b89f7a;border-radius:10px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .2s,color .2s}.hair-retry-btn:hover{color:#fff;background:#b89f7a}.report-footer{margin-top:48px}.reset-btn{color:#1a1a1a;cursor:pointer;background:0 0;border:1.5px solid #1a1a1a;border-radius:12px;padding:14px 40px;font-size:15px;font-weight:600;transition:background .2s,color .2s}.reset-btn:hover{color:#fff;background:#1a1a1a}@media (width<=700px){.report-body{grid-template-columns:1fr}.report-aside{position:static}.report-photo{aspect-ratio:auto;max-height:300px}.report-title{font-size:28px}}.hair-grid{grid-template-columns:repeat(3,1fr);gap:16px;width:100%;display:grid}.hair-card{background:#fff;border-radius:16px;flex-direction:column;display:flex;overflow:hidden;box-shadow:0 2px 12px #00000012}.hair-card-img{aspect-ratio:1;object-fit:cover;width:100%}.hair-card-error{aspect-ratio:1;color:#aaa;background:#f3ede6;justify-content:center;align-items:center;width:100%;font-size:13px;display:flex}.hair-card-info{padding:12px 14px 14px}.hair-card-name{color:#1a1a1a;letter-spacing:-.2px;margin:0 0 4px;font-size:13px;font-weight:700}.hair-card-desc{color:#888;margin:0;font-size:12px;line-height:1.5}@media (width<=700px){.hair-grid{grid-template-columns:repeat(2,1fr);gap:12px}}@media (width<=420px){.hair-grid{grid-template-columns:1fr}}.loading-screen{background:#faf9f7;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100vh;display:flex}.loading-spinner{border:3px solid #e5ddd3;border-top-color:#b89f7a;border-radius:50%;width:52px;height:52px;animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:#1a1a1a;margin:8px 0 0;font-size:18px;font-weight:600}.loading-sub{color:#aaa;margin:0;font-size:14px}
