:root{--sans:system-ui, "Segoe UI", Roboto, sans-serif;font-family:var(--sans);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,:before,:after{box-sizing:border-box}body{margin:0}#root{min-height:100svh}.page{background:#faf9fb;flex-direction:column;min-height:100svh;display:flex}.header{background:#fff;border-bottom:1px solid #ece9f1;padding:20px 32px}.logo-text{letter-spacing:-.5px;background:linear-gradient(135deg,#aa3bff,#7c3aed);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:700}.main{flex:1;justify-content:center;align-items:flex-start;padding:40px 20px 60px;display:flex}.card{background:#fff;border-radius:20px;width:100%;max-width:440px;padding:40px 36px;box-shadow:0 4px 24px #00000012}.title{color:#1a1625;letter-spacing:-.5px;text-align:center;margin:0 0 8px;font-size:26px;font-weight:700}.subtitle{color:#7c7589;text-align:center;margin:0 0 32px;font-size:14px;line-height:1.5}.error-box{color:#b91c1c;background:#fff0f0;border:1px solid #fca5a5;border-radius:10px;margin-bottom:20px;padding:12px 16px;font-size:13px}.form{flex-direction:column;gap:24px;display:flex}.photo-upload{cursor:pointer;background:#f8f4ff;border:2.5px dashed #d4b8ff;border-radius:50%;width:140px;height:140px;margin:0 auto;transition:border-color .2s,background .2s;position:relative;overflow:hidden}.photo-upload:hover{background:#f3eaff;border-color:#aa3bff}.photo-upload:focus-visible{outline-offset:3px;outline:2px solid #aa3bff}.photo-upload.dragging{background:#f0e5ff;border-style:solid;border-color:#aa3bff;transform:scale(1.04)}.photo-placeholder{flex-direction:column;justify-content:center;align-items:center;gap:6px;width:100%;height:100%;display:flex}.upload-icon{color:#aa3bff;width:36px;height:36px}.upload-label{color:#7c3aed;font-size:13px;font-weight:600}.upload-hint{color:#a78bca;font-size:11px}.photo-preview{object-fit:cover;width:100%;height:100%}.photo-overlay{opacity:0;color:#fff;background:#6432b48c;justify-content:center;align-items:center;font-size:13px;font-weight:600;transition:opacity .2s;display:flex;position:absolute;inset:0}.photo-upload:hover .photo-overlay{opacity:1}.hidden-input{display:none}.input-row{gap:16px;display:flex}.input-group{flex-direction:column;flex:1;gap:8px;display:flex}.label{color:#4a4158;font-size:13px;font-weight:600}.input-wrapper{align-items:center;display:flex;position:relative}.input{color:#1a1625;box-sizing:border-box;appearance:textfield;background:#faf9fb;border:1.5px solid #e5e1ed;border-radius:10px;width:100%;padding:12px 40px 12px 14px;font-family:inherit;font-size:16px;transition:border-color .2s,box-shadow .2s}.input::-webkit-inner-spin-button{appearance:none}.input::-webkit-outer-spin-button{appearance:none}.input::placeholder{color:#c2bacf}.input:focus{background:#fff;border-color:#aa3bff;outline:none;box-shadow:0 0 0 3px #aa3bff1a}.unit{color:#a78bca;pointer-events:none;font-size:13px;font-weight:500;position:absolute;right:12px}.submit-btn{color:#fff;cursor:pointer;letter-spacing:-.2px;background:linear-gradient(135deg,#aa3bff,#7c3aed);border:none;border-radius:12px;width:100%;padding:14px;font-family:inherit;font-size:16px;font-weight:600;transition:opacity .2s,transform .1s}.submit-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.4;cursor:not-allowed}.loading-card{flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 20px;display:flex}.spinner{border:4px solid #ece9f1;border-top-color:#aa3bff;border-radius:50%;width:52px;height:52px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-title{color:#1a1625;margin:0;font-size:18px;font-weight:600}.loading-sub{color:#7c7589;margin:0;font-size:14px}.result-card{background:#fff;border-radius:20px;width:100%;max-width:720px;overflow:hidden;box-shadow:0 4px 24px #00000012}.result-header{background:linear-gradient(135deg,#f8f4ff,#fff);border-bottom:1px solid #f0ecf8;padding:32px 40px 24px}.result-title{color:#1a1625;letter-spacing:-.5px;margin:0 0 8px;font-size:22px;font-weight:700}.result-meta{color:#a78bca;font-size:13px;font-weight:500}.report-body{flex-direction:column;gap:4px;padding:32px 40px;display:flex}@media (width<=600px){.report-body{padding:24px 20px}}.report-section{color:#7c3aed;letter-spacing:-.3px;border-bottom:1.5px solid #f0ecf8;margin:24px 0 10px;padding-bottom:8px;font-size:16px;font-weight:700}.report-section:first-child{margin-top:0}.report-para{color:#3d3549;margin:4px 0;font-size:14.5px;line-height:1.75}.report-list{flex-direction:column;gap:6px;margin:4px 0;padding-left:20px;display:flex}.report-list li{color:#3d3549;font-size:14.5px;line-height:1.7}.hairstyle-section{border-top:1px solid #f0ecf8;padding:28px 40px}@media (width<=600px){.hairstyle-section{padding:20px}}.hairstyle-title{color:#7c3aed;letter-spacing:-.3px;margin:0 0 4px;font-size:16px;font-weight:700}.hairstyle-sub{color:#a78bca;margin:0 0 16px;font-size:13px}.hairstyle-grid{border-radius:12px;width:100%;display:block;box-shadow:0 2px 12px #7c3aed1a}.reset-btn{color:#7c7589;cursor:pointer;letter-spacing:-.2px;background:0 0;border:2px solid #e5e1ed;border-radius:12px;width:calc(100% - 80px);margin:0 40px 32px;padding:13px;font-family:inherit;font-size:15px;font-weight:600;transition:border-color .2s,color .2s;display:block}.reset-btn:hover{color:#7c3aed;border-color:#aa3bff}@media (width<=600px){.reset-btn{width:calc(100% - 40px);margin:0 20px 24px}}
