*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);font-family:Pretendard,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#root{width:100%;display:flex;justify-content:center}.container{width:100%;padding:20px;display:flex;justify-content:center}.card{background:#fff;border-radius:24px;padding:40px 36px;width:100%;max-width:420px;box-shadow:0 20px 60px #00000026}.header{text-align:center;margin-bottom:32px}.header h1{font-size:1.8rem;font-weight:800;color:#1a1a2e;margin-bottom:6px}.header p{color:#888;font-size:.95rem}.form{display:flex;flex-direction:column;gap:24px}.photo-section{display:flex;flex-direction:column;align-items:center;gap:12px}.photo-upload{width:180px;height:220px;border-radius:16px;border:2px dashed #d0d0e0;cursor:pointer;overflow:hidden;transition:border-color .2s,background .2s;background:#f8f8fc;display:flex;align-items:center;justify-content:center}.photo-upload:hover{border-color:#764ba2;background:#f3f0ff}.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:#aaa;font-size:.85rem}.photo-icon{font-size:2.5rem}.photo-hint{font-size:.75rem;color:#bbb}.photo-preview{width:100%;height:100%;object-fit:cover}.inputs{display:flex;gap:16px}.input-group{flex:1;display:flex;flex-direction:column;gap:8px}.input-group label{font-size:.85rem;font-weight:600;color:#444}.input-wrapper{display:flex;align-items:center;border:1.5px solid #e0e0e8;border-radius:12px;overflow:hidden;transition:border-color .2s}.input-wrapper:focus-within{border-color:#764ba2}.input-wrapper input{flex:1;border:none;outline:none;padding:12px 14px;font-size:1rem;color:#1a1a2e;background:transparent;width:100%}.unit{padding:0 12px;color:#999;font-size:.85rem;font-weight:500;background:#f8f8fc;border-left:1.5px solid #e0e0e8;height:100%;display:flex;align-items:center}.btn-primary{width:100%;padding:15px;border:none;border-radius:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1rem;font-weight:700;cursor:pointer;transition:opacity .2s,transform .1s}.btn-primary:hover{opacity:.9;transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{padding:8px 20px;border:1.5px solid #764ba2;border-radius:10px;background:transparent;color:#764ba2;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:#f3f0ff}.error-msg{color:#e53e3e;font-size:.85rem;text-align:center;padding:10px 14px;background:#fff5f5;border-radius:10px;border:1px solid #fed7d7}.loading-text{display:flex;align-items:center;justify-content:center;gap:10px}.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)}}.btn-primary:disabled{opacity:.75;cursor:not-allowed;transform:none}.report-card{background:#fff;border-radius:24px;padding:40px 36px;width:100%;max-width:600px;box-shadow:0 20px 60px #00000026;display:flex;flex-direction:column;gap:28px}.report-header{text-align:center}.report-header h1{font-size:1.7rem;font-weight:800;color:#1a1a2e;margin-bottom:12px}.body-type-badge{display:inline-block;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.9rem;font-weight:700;padding:6px 20px;border-radius:999px}.report-summary{background:#f8f8fc;border-left:4px solid #764ba2;border-radius:0 12px 12px 0;padding:16px 20px;color:#333;font-size:.95rem;line-height:1.7}.report-sections{display:flex;flex-direction:column;gap:24px}.report-section h2{font-size:1rem;font-weight:700;color:#1a1a2e;margin-bottom:14px}.recommendation-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.recommend-box{background:#f8f8fc;border-radius:14px;padding:14px 16px}.recommend-box h3{font-size:.8rem;font-weight:700;color:#764ba2;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.recommend-box ul{list-style:none;display:flex;flex-direction:column;gap:5px}.recommend-box ul li{font-size:.85rem;color:#444;padding-left:12px;position:relative}.recommend-box ul li:before{content:"•";position:absolute;left:0;color:#764ba2}.color-guide{display:flex;flex-direction:column;gap:12px}.color-label{font-size:.8rem;font-weight:600;margin-bottom:8px}.color-label.good{color:#38a169}.color-label.bad{color:#e53e3e}.color-tags{display:flex;flex-wrap:wrap;gap:8px}.color-tag{padding:5px 14px;border-radius:999px;font-size:.82rem;font-weight:500}.color-tag.good{background:#f0fff4;color:#276749;border:1px solid #9ae6b4}.color-tag.bad{background:#fff5f5;color:#c53030;border:1px solid #feb2b2}.tips-list{list-style:none;display:flex;flex-direction:column;gap:10px}.tips-list li{display:flex;align-items:flex-start;gap:10px;font-size:.9rem;color:#444;line-height:1.6;padding:12px 16px;background:#f8f8fc;border-radius:12px}.tips-list li:before{content:"✓";color:#764ba2;font-weight:700;flex-shrink:0}
