*,:before,:after{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f7f5f2;--surface:#fff;--border:#e8e4df;--text:#1a1612;--text-sub:#7a726a;--accent:#c8a97e;--accent-dark:#a8845a;--accent-light:#f5efe6;--radius:16px;--shadow:0 2px 24px #00000012}body{background:var(--bg);color:var(--text);min-height:100svh;font-family:Pretendard,Apple SD Gothic Neo,system-ui,sans-serif}#root{text-align:left;border:none;flex-direction:column;width:100%;min-height:100svh;display:flex}.top-bar{border-bottom:1px solid var(--border);background:var(--surface);align-items:center;padding:14px 20px;display:flex}.logo{letter-spacing:-.5px;color:var(--text);font-size:18px;font-weight:700}.page{flex-direction:column;min-height:100svh;display:flex}.container{flex-direction:column;flex:1;gap:20px;width:100%;max-width:130px;margin:0 auto;padding:24px 20px 40px;display:flex}.title-block h1{letter-spacing:-.8px;color:var(--text);margin-bottom:6px;font-size:22px;font-weight:700}.title-block p{color:var(--text-sub);font-size:14px;line-height:1.6}.supported-formats{color:var(--accent-dark);letter-spacing:.3px;margin-top:8px;font-size:12px;font-weight:500}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:20px;padding:20px;display:flex}.field-group{flex-direction:column;gap:12px;display:flex}.field-label{color:var(--text-sub);letter-spacing:.4px;text-transform:uppercase;font-size:13px;font-weight:600}.photo-drop{border:2px dashed var(--border);cursor:pointer;background:var(--bg);border-radius:12px;justify-content:center;align-items:center;width:100%;min-height:180px;transition:border-color .2s,background .2s,transform .15s;display:flex;position:relative;overflow:hidden}.photo-drop:hover{border-color:var(--accent);background:var(--accent-light)}.photo-drop.has-photo{border-style:solid;border-color:var(--border);min-height:unset;height:auto}.photo-drop.dragging{border-color:var(--accent);background:var(--accent-light);transform:scale(1.01)}.photo-placeholder{color:var(--text-sub);flex-direction:column;align-items:center;gap:10px;display:flex}.photo-placeholder svg{opacity:.5}.photo-placeholder span{font-size:14px;font-weight:500}.photo-placeholder small{opacity:.7;font-size:12px}.photo-preview{object-fit:contain;width:100%;height:auto;display:block}.file-input{display:none}.change-photo-btn{border:1px solid var(--border);color:var(--text-sub);cursor:pointer;background:0 0;border-radius:8px;align-self:flex-start;padding:6px 14px;font-size:13px;transition:border-color .2s,color .2s}.change-photo-btn:hover{border-color:var(--accent);color:var(--accent-dark)}.body-inputs{grid-template-columns:1fr 1fr;gap:12px;display:grid}.input-wrap{align-items:center;display:flex;position:relative}.body-input{border:1.5px solid var(--border);width:100%;color:var(--text);background:var(--surface);-moz-appearance:textfield;border-radius:10px;outline:none;padding:11px 40px 11px 14px;font-size:15px;font-weight:500;transition:border-color .2s,box-shadow .2s}.body-input::-webkit-inner-spin-button{-webkit-appearance:none}.body-input::-webkit-outer-spin-button{-webkit-appearance:none}.body-input::placeholder{color:#c0b8b0;font-weight:400}.body-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.unit{color:var(--text-sub);pointer-events:none;font-size:13px;font-weight:500;position:absolute;right:14px}.submit-btn{cursor:pointer;color:#fff;background:#d0ccc8;border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;width:100%;padding:13px;font-size:15px;font-weight:600;transition:background .2s,opacity .2s,transform .1s;display:flex}.submit-btn.active{background:var(--accent-dark)}.submit-btn.active:hover{background:#8e6d47;transform:translateY(-1px)}.submit-btn:disabled{cursor:not-allowed}.error-banner{color:#b91c1c;background:#fff5f5;border:1px solid #fecaca;border-radius:10px;align-items:center;gap:8px;padding:14px 16px;font-size:14px;line-height:1.5;display:flex}.loading-view{flex-direction:column;justify-content:center;align-items:center;gap:14px;padding:50px 0;display:flex}.loading-spinner{border:3px solid var(--accent-light);border-top-color:var(--accent-dark);border-radius:50%;width:40px;height:40px;animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-title{color:var(--text);font-size:15px;font-weight:600}.loading-sub{color:var(--text-sub);margin-top:-6px;font-size:13px}.result-view{flex-direction:column;gap:20px;display:flex}.result-header{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:16px;padding:20px;display:flex}.result-thumb{object-fit:cover;border-radius:12px;flex-shrink:0;width:80px;height:80px}.result-header-info{flex-direction:column;gap:6px;display:flex}.result-label{color:var(--text-sub);text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:600}.result-body-type{letter-spacing:-.5px;color:var(--text);font-size:22px;font-weight:700}.result-color-badge{background:var(--accent-light);color:var(--accent-dark);border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.report-body{flex-direction:column;gap:12px;display:flex}.report-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.report-section-title{color:var(--text-sub);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px;font-size:12px;font-weight:700}.report-text{color:var(--text);font-size:14px;line-height:1.7}.chip-label{color:var(--text-sub);margin:10px 0 6px;font-size:12px}.chip-row{flex-wrap:wrap;gap:8px;display:flex}.color-chip{border-radius:20px;padding:5px 12px;font-size:13px;font-weight:500}.color-chip--recommend{background:var(--accent-light);color:var(--accent-dark)}.color-chip--avoid{color:#888;background:#f5f5f5;text-decoration:line-through}.style-cards{flex-direction:column;gap:12px;display:flex}.style-card{background:var(--bg);border-radius:10px;flex-direction:column;gap:8px;padding:14px;display:flex}.style-card-category{color:var(--accent-dark);font-size:13px;font-weight:700}.style-card-desc{color:var(--text);font-size:13px;line-height:1.6}.item-chip{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:20px;padding:4px 10px;font-size:12px}.item-recommend-list{flex-direction:column;gap:12px;display:flex}.item-recommend-row{grid-template-columns:60px 1fr;align-items:baseline;gap:12px;display:grid}.item-recommend-label{color:var(--accent-dark);white-space:nowrap;font-size:12px;font-weight:600}.item-recommend-value{color:var(--text);font-size:13px;line-height:1.6}.overall-tip{align-items:flex-start;gap:12px;display:flex}.overall-tip svg{color:var(--accent);flex-shrink:0;margin-top:2px}.hair-section{padding:20px}.hair-generating{color:var(--text-sub);flex-direction:column;align-items:center;gap:10px;padding:28px 0;display:flex}.hair-generating p{color:var(--text);font-size:14px;font-weight:500}.hair-generating small{color:var(--text-sub);font-size:12px}.hair-spinner{border:3px solid var(--accent-light);border-top-color:var(--accent-dark);border-radius:50%;width:36px;height:36px;animation:.9s linear infinite spin}.hair-desc{color:var(--text-sub);margin-bottom:14px;font-size:13px}.hair-grid{grid-template-columns:1fr 1fr 1fr;gap:6px;display:grid}.hair-image-full{border-radius:10px;width:100%;display:block}.hair-image{aspect-ratio:1;object-fit:cover;border-radius:10px;width:100%;display:block}.hair-error{color:#b91c1c;padding:8px 0;font-size:13px}.consent-group{gap:10px}.consent-item{cursor:pointer;align-items:flex-start;gap:10px;display:flex}.consent-checkbox{width:18px;height:18px;accent-color:var(--accent-dark);cursor:pointer;flex-shrink:0;margin-top:1px}.consent-text{color:var(--text);font-size:13px;line-height:1.55}.consent-link{color:var(--accent-dark);text-underline-offset:2px;text-decoration:underline}.consent-disclaimer{color:var(--text-sub);background:var(--bg);border-left:3px solid var(--accent);border-radius:8px;padding:10px 12px;font-size:12px;line-height:1.6}.result-disclaimer{color:var(--text-sub);background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:10px;padding:12px 14px;font-size:12px;line-height:1.6}.result-capture{flex-direction:column;gap:20px;padding-bottom:4px;display:flex}.result-watermark{text-align:center;color:var(--text-sub);letter-spacing:.15em;text-transform:uppercase;opacity:.5;padding:12px 0 4px;font-size:11px;font-weight:600}.result-actions{grid-template-columns:1fr 1fr;gap:10px;display:grid}.action-btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:7px;padding:13px;font-size:14px;font-weight:600;transition:background .18s,transform .1s,opacity .2s;display:flex}.action-btn:disabled{cursor:not-allowed;opacity:.6}.action-btn:not(:disabled):hover{transform:translateY(-1px)}.action-btn--save{background:var(--accent-light);color:var(--accent-dark);border:1.5px solid var(--accent)}.action-btn--save:not(:disabled):hover{background:#eeddc8}.action-btn--share{background:var(--accent-dark);color:#fff}.action-btn--share:not(:disabled):hover{background:#8e6d47}.action-spinner{opacity:.7;border:2px solid;border-top-color:#0000;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin}.reset-btn{border:1.5px solid var(--border);background:var(--surface);width:100%;color:var(--text-sub);cursor:pointer;border-radius:12px;padding:16px;font-size:15px;font-weight:600;transition:border-color .2s,color .2s}.reset-btn:hover{border-color:var(--accent);color:var(--accent-dark)}@media (width<=480px){.container{padding:16px 16px 32px}.card{padding:16px}.title-block h1{font-size:20px}.result-body-type{font-size:18px}}.emerald-gradient{background:linear-gradient(135deg,#006d36 0%,#50c878 100%)}.landing .material-symbols-outlined{font-variation-settings:"FILL" 0, "wght" 300, "GRAD" 0, "opsz" 24;text-transform:none;white-space:nowrap;word-wrap:normal;-webkit-font-smoothing:antialiased;direction:ltr;font-family:Material Symbols Outlined;font-style:normal;line-height:1;display:inline-block}.landing .icon-filled{font-variation-settings:"FILL" 1, "wght" 300, "GRAD" 0, "opsz" 24}.landing{background-color:#f9f9f9;min-height:100dvh}
