*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;font-family:Pretendard,Noto Sans KR,Apple SD Gothic Neo,sans-serif;line-height:1.5;font-weight:400;color:#1f2a3d;background:#f7f7f7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}input,button{font-family:inherit}input:focus,button:focus-visible{outline:2px solid #f08d53;outline-offset:2px}.page{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 20% 20%,#ffdbc0 0%,transparent 40%),radial-gradient(circle at 80% 0%,#b9ffd9 0%,transparent 35%),linear-gradient(145deg,#fdf6ef,#eff8ff)}.stylist-card{width:min(720px,100%);border-radius:24px;padding:30px;background-color:#ffffffd6;border:1px solid #f0d7c5;box-shadow:0 20px 50px #1b22331f;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:card-fade-in .55s ease-out}.eyebrow{margin:0;font-size:12px;letter-spacing:.18em;color:#99684f;font-weight:700}h1{margin:10px 0 8px;font-size:clamp(1.7rem,3.2vw,2.2rem);color:#1f2a3d}.subtitle{margin:0 0 20px;color:#5c6170}.stylist-form{display:grid;gap:14px}.field-label{display:block;margin-bottom:6px;font-size:14px;color:#3f4758;font-weight:600}.photo-input,input[type=number],input[type=text]{width:100%;border:1px solid #d4dae5;border-radius:12px;padding:12px;font:inherit;background:#fff;box-sizing:border-box}.photo-input{display:none}.upload-trigger{display:inline-flex;justify-content:center;align-items:center;width:fit-content;padding:10px 14px;border-radius:10px;border:1px solid #cfd7e6;background:#fff;color:#2d3a52;font-weight:600;cursor:pointer}.upload-file-name{margin:-6px 0 0;font-size:13px;color:#69758b}.photo-preview{min-height:210px;border:2px dashed #c9d5e8;border-radius:14px;display:grid;place-items:center;overflow:hidden;background:#f6f9fc;color:#6f7584;font-size:14px;padding:12px;cursor:copy;transition:border-color .2s ease,background-color .2s ease,transform .2s ease}.photo-preview.drag-active{border-color:#df5f79;background:#fff6f9;transform:scale(1.01)}.photo-placeholder{text-align:center}.photo-preview img{width:100%;height:100%;max-height:340px;object-fit:cover;border-radius:10px}.metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}button{margin-top:8px;border:0;border-radius:12px;padding:13px 16px;font:inherit;font-weight:700;color:#fff;background:linear-gradient(90deg,#e67b5d,#df5f79);cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}button:hover{transform:translateY(-1px);box-shadow:0 10px 20px #df5f7940}button:disabled{cursor:not-allowed;opacity:.7;transform:none;box-shadow:none}.status-text{margin-top:14px;font-size:14px;color:#234067}.progress-box{margin-top:16px;padding:14px;border-radius:12px;border:1px solid #d8e3f7;background:#f8fbff}.progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:14px;color:#2e446e}.progress-time{margin:0 0 8px;font-size:13px;color:#5a6d93}.progress-track{width:100%;height:10px;border-radius:999px;background:#dbe7f6;overflow:hidden}.progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#e67b5d,#df5f79);transition:width .55s ease}.report-card{margin-top:16px;padding:18px;border-radius:14px;border:1px solid #dce5f5;background:#f9fbff}.report-card h2{margin:0 0 10px;font-size:1.05rem;color:#22385f}.report-card p{margin:0;white-space:pre-wrap;color:#2f3f5f}.hair-card{margin-top:16px;padding:18px;border-radius:14px;border:1px solid #dce5f5;background:#fff}.hair-card h2{margin:0 0 10px;font-size:1.05rem;color:#22385f}.hair-card img{width:100%;border-radius:10px;border:1px solid #e6ebf5}.warning-text{margin-top:12px;font-size:14px;color:#8a4d1c}@keyframes card-fade-in{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media(max-width:640px){.stylist-card{padding:22px 16px;border-radius:18px}.metrics-grid{grid-template-columns:1fr}}
