: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;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;margin:0;padding:0}.app{min-height:100vh;background:linear-gradient(135deg,#f5f0eb,#ede8e3);font-family:Apple SD Gothic Neo,Noto Sans KR,system-ui,sans-serif;color:#2d2d2d}.preview-banner{background:#f59e0b;color:#1a1a1a;text-align:center;padding:6px 16px;font-size:.75rem;font-weight:700;letter-spacing:.5px}.header{text-align:center;padding:48px 24px 32px;background:#fff;border-bottom:1px solid #e8e0d8}.header h1{font-size:2rem;font-weight:700;letter-spacing:-.5px;color:#1a1a1a;margin-bottom:8px}.header p{font-size:.95rem;color:#888}.main{max-width:480px;margin:0 auto;padding:32px 20px 60px}.form{display:flex;flex-direction:column;gap:24px}.section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 12px #0000000f;display:flex;flex-direction:column;gap:16px}.section h2{font-size:1rem;font-weight:600;color:#1a1a1a}.photo-upload{border:2px dashed #d4c9be;border-radius:12px;cursor:pointer;overflow:hidden;transition:border-color .2s;min-height:200px;display:flex;align-items:center;justify-content:center}.photo-upload:hover{border-color:#a08060}.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px;text-align:center}.photo-icon{font-size:2.5rem}.photo-placeholder p{font-size:.95rem;color:#555;font-weight:500}.photo-hint{font-size:.8rem!important;color:#aaa!important;font-weight:400!important}.photo-preview{width:100%;max-height:320px;object-fit:cover;display:block}.input-group{display:flex;flex-direction:column;gap:8px}.input-group label{font-size:.875rem;font-weight:500;color:#555}.input-wrapper{display:flex;align-items:center;border:1.5px solid #e0d8d0;border-radius:10px;overflow:hidden;transition:border-color .2s}.input-wrapper:focus-within{border-color:#a08060}.input-wrapper input{flex:1;border:none;outline:none;padding:14px 16px;font-size:1rem;background:transparent;color:#1a1a1a}.input-wrapper input::placeholder{color:#bbb}.unit{padding:14px 16px;font-size:.875rem;color:#999;background:#faf8f6;border-left:1.5px solid #e0d8d0}.btn-primary{width:100%;padding:16px;background:#2d2d2d;color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;letter-spacing:-.2px}.btn-primary:hover:not(:disabled){background:#1a1a1a}.btn-primary:disabled{background:#ccc;cursor:not-allowed}.btn-secondary{width:100%;padding:10px;background:transparent;color:#888;border:1.5px solid #e0d8d0;border-radius:10px;font-size:.875rem;cursor:pointer;transition:all .2s}.btn-secondary:hover{border-color:#a08060;color:#a08060}.error-box{background:#fff0f0;border:1.5px solid #ffcccc;border-radius:10px;padding:14px 16px;font-size:.875rem;color:#c0392b}.main.center{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 140px)}.analyzing-box{text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 24px}.analyzing-box h2{font-size:1.25rem;font-weight:700;color:#1a1a1a}.analyzing-box p{font-size:.95rem;color:#666;line-height:1.6}.analyzing-hint{font-size:.8rem!important;color:#aaa!important;margin-top:4px}.spinner{width:48px;height:48px;border:4px solid #e0d8d0;border-top-color:#2d2d2d;border-radius:50%;animation:spin .9s linear infinite;margin-bottom:8px}@keyframes spin{to{transform:rotate(360deg)}}.result-header{background:#fff;border-radius:16px;padding:20px;box-shadow:0 2px 12px #0000000f;display:flex;gap:16px;align-items:center}.result-photo-wrap{width:80px;height:80px;border-radius:12px;overflow:hidden;flex-shrink:0}.result-photo{width:100%;height:100%;object-fit:cover}.result-info{display:flex;gap:8px;flex-wrap:wrap}.result-info span{background:#f5f0eb;border-radius:20px;padding:6px 14px;font-size:.875rem;font-weight:500;color:#555}.report-content{display:flex;flex-direction:column;gap:20px}.report-section{border-left:3px solid #d4c9be;padding-left:14px}.report-section-title{font-size:.95rem;font-weight:700;color:#1a1a1a;margin-bottom:8px}.report-section-body{display:flex;flex-direction:column;gap:6px}.report-section-body p{font-size:.9rem;color:#444;line-height:1.65}.report-bullet:before{content:"• ";color:#a08060;font-weight:700}
