:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box}.stylist-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.stylist-card{background:#fff;border-radius:24px;padding:2.5rem;width:100%;max-width:480px;box-shadow:0 20px 60px #0003}.stylist-header{text-align:center;margin-bottom:2rem}.stylist-icon{font-size:3rem;display:block;margin-bottom:.5rem}.stylist-header h1{font-size:1.8rem;font-weight:700;color:#1a1a2e;margin:0 0 .5rem;line-height:1.2}.stylist-header p{font-size:.9rem;color:#6b7280;margin:0}.photo-section{display:flex;flex-direction:column;align-items:center;margin-bottom:1.8rem}.photo-upload-area{width:160px;height:160px;border-radius:50%;border:3px dashed #c4b5fd;cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#f5f3ff;transition:border-color .2s,background .2s}.photo-upload-area:hover{border-color:#7c3aed;background:#ede9fe}.photo-upload-area.dragging{border-color:#7c3aed;border-style:solid;background:#ede9fe;transform:scale(1.04);box-shadow:0 0 0 4px #ddd6fe;transition:transform .15s,box-shadow .15s}.photo-preview{width:100%;height:100%;object-fit:cover}.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:.3rem}.photo-icon{font-size:2.5rem}.photo-text{font-size:.8rem;font-weight:600;color:#7c3aed}.photo-subtext{font-size:.7rem;color:#a78bfa}.photo-reset-btn{margin-top:.8rem;background:none;border:1px solid #c4b5fd;color:#7c3aed;border-radius:20px;padding:.3rem 1rem;font-size:.8rem;cursor:pointer;transition:background .2s}.photo-reset-btn:hover{background:#f5f3ff;border-color:#7c3aed}.body-info-section{display:flex;flex-direction:column;gap:1.2rem;margin-bottom:2rem}.input-group{display:flex;flex-direction:column;gap:.4rem}.input-group label{font-size:.875rem;font-weight:600;color:#374151}.input-wrapper{position:relative;display:flex;align-items:center}.input-wrapper input{width:100%;padding:.75rem 3rem .75rem 1rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;color:#1f2937;background:#f9fafb;outline:none;transition:border-color .2s,background .2s;appearance:textfield;-moz-appearance:textfield}.input-wrapper input::-webkit-outer-spin-button,.input-wrapper input::-webkit-inner-spin-button{-webkit-appearance:none}.input-wrapper input:focus{border-color:#7c3aed;background:#fff}.input-wrapper input::placeholder{color:#9ca3af}.unit{position:absolute;right:1rem;font-size:.875rem;font-weight:600;color:#6b7280;pointer-events:none}.submit-btn{width:100%;padding:1rem;background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;border:none;border-radius:14px;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .1s;letter-spacing:.02em}.submit-btn:hover{opacity:.9;transform:translateY(-1px)}.submit-btn:active{transform:translateY(0)}.submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.loading-text{display:flex;align-items:center;justify-content:center;gap:.6rem}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-msg{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:10px;padding:.75rem 1rem;font-size:.875rem;margin-bottom:1rem}.report-section{display:flex;flex-direction:column;gap:1rem}.report-block{background:#f9fafb;border-radius:14px;padding:1rem 1.2rem}.report-block p{margin:0;font-size:.875rem;color:#4b5563;line-height:1.7}.report-label{font-size:.72rem;font-weight:700;color:#7c3aed;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.6rem}.report-body{background:linear-gradient(135deg,#ede9fe,#faf5ff);border:1px solid #ddd6fe}.report-body .report-label{color:#5b21b6}.report-color{background:linear-gradient(135deg,#fdf4ff,#faf5ff);border:1px solid #e9d5ff}.report-color .report-label{color:#7e22ce}.season-badge{display:inline-block;background:linear-gradient(135deg,#7c3aed,#a855f7);color:#fff;border-radius:20px;padding:.3rem 1rem;font-size:.875rem;font-weight:700;margin-bottom:.5rem}.color-desc{margin:0 0 .7rem;font-size:.875rem;color:#4b5563;line-height:1.6}.color-palette{display:flex;flex-wrap:wrap;gap:.4rem}.color-chip{background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;padding:.25rem .7rem;font-size:.8rem;color:#374151;font-weight:500}.style-list{display:flex;flex-direction:column;gap:.8rem}.style-item{display:flex;flex-direction:column;gap:.25rem;padding-bottom:.8rem;border-bottom:1px solid #e5e7eb}.style-item:last-child{padding-bottom:0;border-bottom:none}.style-name{font-size:.9rem;font-weight:700;color:#1f2937}.style-desc{font-size:.8rem;color:#6b7280;line-height:1.5}.item-tags{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.2rem}.item-tag{background:#ede9fe;color:#6d28d9;border-radius:6px;padding:.15rem .6rem;font-size:.75rem;font-weight:600}.report-avoid{background:#fff7ed;border:1px solid #fed7aa}.report-avoid .report-label{color:#c2410c}.report-avoid p{color:#7c2d12}.report-tips{background:#f0fdf4;border:1px solid #bbf7d0}.report-tips .report-label{color:#15803d}.tips-list{margin:0;padding-left:1.2rem;display:flex;flex-direction:column;gap:.4rem}.tips-list li{font-size:.875rem;color:#166534;line-height:1.6}.report-hair{background:linear-gradient(135deg,#fdf2f8,#fce7f3);border:1px solid #f9a8d4}.report-hair .report-label{color:#be185d}.hair-loading{display:flex;flex-direction:column;align-items:center;gap:.8rem;padding:1.5rem 0}.hair-loading p{margin:0;font-size:.85rem;color:#9d174d;text-align:center;line-height:1.6}.spinner-lg{display:inline-block;width:36px;height:36px;border:3px solid #f9a8d4;border-top-color:#be185d;border-radius:50%;animation:spin .8s linear infinite}.hair-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;border-radius:10px;padding:.75rem 1rem;font-size:.875rem}.hair-grid-img{width:100%;border-radius:12px;display:block}.reset-btn{width:100%;padding:.875rem;background:#fff;border:2px solid #7c3aed;color:#7c3aed;border-radius:14px;font-size:.95rem;font-weight:700;cursor:pointer;transition:background .2s,color .2s;margin-top:.5rem}.reset-btn:hover{background:#7c3aed;color:#fff}
