:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1a1a1a;background-color:#f7f5f2;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}.page{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:2rem 1rem 4rem;background:#f7f5f2}.header{text-align:center;margin-bottom:2.5rem}.header-logo{font-size:1.8rem;color:#b8935a}.header-title{font-size:2rem;font-weight:700;letter-spacing:.08em;color:#1a1a1a;margin:.4rem 0 .3rem}.header-sub{font-size:.9rem;color:#999;margin:0}.card{width:100%;max-width:480px;background:#fff;border:1px solid #ececec;border-radius:20px;padding:2rem;display:flex;flex-direction:column;gap:2rem;box-shadow:0 4px 24px #0000000f}.section-title{font-size:1.1rem;font-weight:600;color:#1a1a1a;margin:0 0 .3rem}.section-desc{font-size:.85rem;color:#aaa;margin:0;line-height:1.6}.field-label{display:block;font-size:.78rem;font-weight:600;letter-spacing:.06em;color:#aaa;text-transform:uppercase;margin-bottom:.6rem}.photo-upload{position:relative;width:100%;aspect-ratio:3 / 4;max-height:340px;border:2px dashed #e0dbd4;border-radius:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;overflow:hidden;transition:border-color .2s,background .2s;background:#faf9f7}.photo-upload:hover,.photo-upload.dragging{border-color:#b8935a;background:#fdf8f2}.photo-upload.has-photo{border-style:solid;border-color:#ececec}.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;pointer-events:none}.photo-icon{font-size:2.5rem;opacity:.35}.photo-text{font-size:.9rem;color:#bbb;margin:0}.photo-hint{font-size:.75rem;color:#ccc;margin:0}.photo-preview{width:100%;height:100%;object-fit:cover;display:block}.photo-remove{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;border:none;background:#00000059;color:#fff;font-size:.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .2s}.photo-remove:hover{background:#c80000a6;border-color:transparent}.gender-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.gender-btn{padding:.75rem;border-radius:10px;border:1.5px solid #e8e3dd;background:#faf9f7;color:#999;font-size:.95rem;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .2s,background .2s,color .2s}.gender-btn:hover{border-color:#b8935a;color:#b8935a}.gender-btn.selected{border-color:#b8935a;background:#fdf6ec;color:#b8935a;font-weight:600}.input-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.input-group{display:flex;flex-direction:column}.input-wrap{position:relative;display:flex;align-items:center}.input{width:100%;padding:.75rem 2.8rem .75rem 1rem;background:#faf9f7;border:1.5px solid #e8e3dd;border-radius:10px;color:#1a1a1a;font-size:1.1rem;font-family:inherit;outline:none;transition:border-color .2s;box-sizing:border-box;-moz-appearance:textfield}.input::-webkit-outer-spin-button,.input::-webkit-inner-spin-button{-webkit-appearance:none}.input:focus{border-color:#b8935a}.input::placeholder{color:#ccc}.input-unit{position:absolute;right:.9rem;font-size:.85rem;color:#bbb;pointer-events:none}.submit-btn{width:100%;padding:1rem;border-radius:12px;border:none;font-size:1rem;font-weight:600;font-family:inherit;letter-spacing:.03em;cursor:pointer;background:#e8e3dd;color:#bbb;transition:background .25s,color .25s,transform .1s}.submit-btn.active{background:#b8935a;color:#fff}.submit-btn.active:hover{background:#c9a46a}.submit-btn.active:active{transform:scale(.98)}.submit-btn:disabled{cursor:not-allowed}.error-box{background:#fff3f3;border:1px solid #f5c5c5;border-radius:10px;padding:.85rem 1rem;font-size:.88rem;color:#c0392b}.loading-card{display:flex;flex-direction:column;align-items:center;gap:1.2rem;padding:3rem 2rem;background:#fff;border-radius:20px;border:1px solid #ececec;box-shadow:0 4px 24px #0000000f;width:100%;max-width:480px}.spinner{width:48px;height:48px;border:3px solid #e8e3dd;border-top-color:#b8935a;border-radius:50%;animation:spin .85s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:1.05rem;font-weight:600;color:#1a1a1a;margin:0}.loading-sub{font-size:.85rem;color:#aaa;margin:0}.result-section{display:flex;flex-direction:column;gap:.6rem}.result-label{font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#aaa;margin:0}.result-text{font-size:.95rem;color:#333;line-height:1.7;margin:0}.tag-row{display:flex;flex-wrap:wrap;gap:.5rem}.tag{padding:.35rem .85rem;border-radius:100px;font-size:.85rem;font-weight:500}.tag-color{background:#fdf6ec;color:#b8935a;border:1px solid #f0e0c8}.tag-item{background:#f4f2ff;color:#6c5ce7;border:1px solid #ddd9ff}.result-list{margin:0;padding-left:1.2rem;display:flex;flex-direction:column;gap:.4rem}.result-list li{font-size:.95rem;color:#333;line-height:1.6}.result-list.avoid li{color:#888}.result-list.avoid li::marker{color:#ccc}.tip-box{background:#fdf6ec;border:1px solid #f0e0c8;border-radius:14px;padding:1.2rem;display:flex;flex-direction:column;gap:.5rem}.tip-label{font-size:.78rem;font-weight:700;letter-spacing:.06em;color:#b8935a;text-transform:uppercase}.tip-text{font-size:.95rem;color:#5a4020;line-height:1.7;margin:0}
