*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#f5f5f7;color:#1a1a2e;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#f5f5f7;display:block;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#root{max-width:480px;margin:0 auto;padding:0;text-align:left}.header{background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff;padding:48px 28px 40px;text-align:center}.header-sub{margin:0 0 8px;font-size:13px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:#a78bfa}.header-title{margin:0 0 12px;font-size:26px;font-weight:700;line-height:1.3;letter-spacing:-.5px}.header-desc{margin:0;font-size:14px;color:#fff9;line-height:1.6}.form{padding:28px 20px 40px;display:flex;flex-direction:column;gap:28px}.section{display:flex;flex-direction:column;gap:12px}.section-label{font-size:15px;font-weight:600;color:#1a1a2e}.photo-upload{border:2px dashed #d1d5db;border-radius:16px;background:#fff;cursor:pointer;overflow:hidden;transition:border-color .2s,background .2s;min-height:240px;display:flex;align-items:center;justify-content:center}.photo-upload:hover{border-color:#7c3aed;background:#faf5ff}.photo-upload.has-photo{border-style:solid;border-color:#7c3aed}.photo-upload.dragging{border-color:#7c3aed;background:#f5f0ff;transform:scale(1.01);transition:border-color .15s,background .15s,transform .15s}.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;padding:40px 20px}.photo-icon{width:72px;height:72px;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#9ca3af}.photo-text{margin:0;font-size:15px;font-weight:500;color:#4b5563}.photo-hint{margin:0;font-size:13px;color:#9ca3af}.photo-preview{width:100%;height:320px;object-fit:cover;display:block}.photo-reset{align-self:center;background:none;border:1px solid #d1d5db;border-radius:8px;padding:8px 20px;font-size:13px;color:#6b7280;cursor:pointer;transition:border-color .2s,color .2s}.photo-reset:hover{border-color:#7c3aed;color:#7c3aed}.input-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.input-group{display:flex;flex-direction:column;gap:8px}.input-label{font-size:13px;font-weight:500;color:#6b7280}.input-wrap{position:relative;display:flex;align-items:center}.input{width:100%;background:#fff;border:1.5px solid #e5e7eb;border-radius:12px;padding:14px 44px 14px 16px;font-size:22px;font-weight:600;color:#1a1a2e;outline:none;transition:border-color .2s;-moz-appearance:textfield}.input::-webkit-outer-spin-button,.input::-webkit-inner-spin-button{-webkit-appearance:none}.input::placeholder{color:#d1d5db;font-weight:400}.input:focus{border-color:#7c3aed}.input-unit{position:absolute;right:14px;font-size:13px;font-weight:500;color:#9ca3af}.submit-btn{width:100%;background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;border:none;border-radius:14px;padding:18px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.submit-btn:hover:not(:disabled){opacity:.92}.submit-btn:active:not(:disabled){transform:scale(.98)}.submit-btn:disabled{background:#e5e7eb;color:#9ca3af;cursor:not-allowed}.page.center{min-height:100vh;display:flex;align-items:center;justify-content:center}.loading-wrap{text-align:center;padding:40px 20px}.spinner{width:52px;height:52px;border:4px solid #e5e7eb;border-top-color:#7c3aed;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 24px}@keyframes spin{to{transform:rotate(360deg)}}.loading-title{margin:0 0 8px;font-size:18px;font-weight:700;color:#1a1a2e}.loading-sub{margin:0;font-size:14px;color:#6b7280}.error-wrap{text-align:center;padding:40px 20px;max-width:320px}.error-icon{width:52px;height:52px;background:#fee2e2;color:#dc2626;border-radius:50%;font-size:24px;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.error-title{margin:0 0 8px;font-size:18px;font-weight:700;color:#1a1a2e}.error-msg{margin:0 0 24px;font-size:14px;color:#6b7280}.result-body{padding:20px 20px 40px;display:flex;flex-direction:column;gap:16px}.result-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 1px 4px #0000000f}.tip-card{background:linear-gradient(135deg,#f5f3ff,#ede9fe)}.card-title{margin:0 0 14px;font-size:15px;font-weight:700;color:#1a1a2e}.card-text{margin:0;font-size:14px;color:#4b5563;line-height:1.7}.body-type-badge{display:inline-block;background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;font-size:14px;font-weight:700;padding:6px 16px;border-radius:100px;margin-bottom:12px}.color-list{display:flex;flex-wrap:wrap;gap:10px}.color-item{display:flex;flex-direction:column;align-items:center;gap:6px}.color-chip{width:40px;height:40px;border-radius:50%;border:2px solid rgba(0,0,0,.08);box-shadow:0 1px 3px #0000001f}.color-name{font-size:11px;color:#6b7280;font-weight:500}.tag-list{display:flex;flex-wrap:wrap;gap:8px}.tag{font-size:13px;font-weight:500;padding:6px 14px;border-radius:100px}.tag-good{background:#ede9fe;color:#6d28d9}.tag-bad{background:#fee2e2;color:#dc2626}.outfit-list{display:flex;flex-direction:column;gap:14px}.outfit-item{border-left:3px solid #7c3aed;padding-left:14px}.outfit-occasion{display:inline-block;font-size:12px;font-weight:700;color:#7c3aed;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.outfit-desc{margin:0;font-size:14px;color:#374151;line-height:1.6}.hair-loading{display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px 20px;background:#f9fafb;border-radius:12px}.hair-spinner{width:36px;height:36px;border:3px solid #e5e7eb;border-top-color:#7c3aed;border-radius:50%;animation:spin .8s linear infinite}.hair-loading-text{margin:0;font-size:14px;font-weight:600;color:#374151}.hair-loading-sub{margin:0;font-size:12px;color:#9ca3af}.hair-image{width:100%;border-radius:12px;display:block}.hair-disclaimer{margin:8px 0 0;font-size:11px;color:#9ca3af}.consent-body{padding:20px 20px 40px;display:flex;flex-direction:column;gap:16px}.consent-card{background:#fff;border-radius:16px;padding:24px 20px;box-shadow:0 1px 4px #0000000f;display:flex;flex-direction:column;gap:20px}.consent-title{margin:0;font-size:17px;font-weight:700;color:#1a1a2e}.consent-section{display:flex;gap:14px;align-items:flex-start}.consent-icon{font-size:22px;flex-shrink:0;margin-top:2px}.consent-item-title{margin:0 0 4px;font-size:14px;font-weight:600;color:#1a1a2e}.consent-item-desc{margin:0;font-size:13px;color:#4b5563;line-height:1.6}.agree-row{display:flex;gap:10px;align-items:flex-start;cursor:pointer;padding:14px;background:#f5f3ff;border-radius:10px;border:1.5px solid #ede9fe}.agree-checkbox{margin-top:2px;width:18px;height:18px;flex-shrink:0;accent-color:#7c3aed;cursor:pointer}.agree-text{font-size:13px;color:#374151;line-height:1.6}.ai-notice{display:flex;align-items:flex-start;gap:8px;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;padding:12px 14px}.ai-badge{background:#f59e0b;color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:100px;white-space:nowrap;flex-shrink:0}.ai-notice-text{font-size:12px;color:#78350f;line-height:1.5}.label-sub{font-size:12px;font-weight:400;color:#9ca3af}.photo-privacy{margin:4px 0 0;font-size:12px;color:#9ca3af;text-align:center}.input-disclaimer{margin:6px 0 0;font-size:12px;color:#9ca3af;line-height:1.5}.site-footer{text-align:center;padding:16px 0 0;display:flex;flex-direction:column;gap:4px}.site-footer p{margin:0;font-size:11px;color:#9ca3af}
