:root{font-family:Manrope,Noto Sans KR,Apple SD Gothic Neo,sans-serif;line-height:1.45;font-weight:500;color:#2f2018;background-color:#f5e8de;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:radial-gradient(circle at 2% 10%,#ffdcbc 0%,transparent 30%),radial-gradient(circle at 96% 90%,#ffc69f 0%,transparent 35%),#f5e8de}.page{width:min(1080px,100%);margin:0 auto;padding:3rem 1.25rem 4rem;display:grid;gap:1.25rem}.hero{background:linear-gradient(135deg,#fffaf6,#ffe4d3 65%,#ffcfa6);border:1px solid #f2c8ac;border-radius:28px;padding:2rem;box-shadow:0 12px 40px #b4623b1f}.eyebrow{margin:0;letter-spacing:.08em;text-transform:uppercase;font-size:.78rem;color:#7c3f2b;font-weight:700}.hero h1{margin:.75rem 0 .25rem;font-size:clamp(1.8rem,2.8vw,2.8rem);line-height:1.2}.hero-copy{margin:0;max-width:60ch;color:#5f3f34}.checkout-notice{margin-top:.9rem;color:#5f2f22;font-weight:700}.flow-guide{margin:.75rem 0 0;font-size:.9rem;color:#7e4a36;font-weight:700}.lang-switch{margin-top:.9rem;display:inline-flex;align-items:center;gap:.45rem;flex-wrap:wrap}.lang-switch span{color:#6d4333;font-weight:700;font-size:.88rem}.lang-button{border:1px solid #c88f74;background:#fff7f0;color:#7a4a36;padding:.3rem .55rem;border-radius:999px;font-weight:700;cursor:pointer;font-size:.8rem}.lang-button.active{background:#b35f46;color:#fff;border-color:#b35f46}.workspace{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem}.upload-card,.preview-card,.result-card{background:#fffdfa;border:1px solid #f0d7c8;border-radius:22px;padding:1.25rem}h2{margin:0 0 1rem;font-size:1.05rem}.dropzone{border:2px dashed #d38f6b;border-radius:16px;min-height:170px;display:grid;place-content:center;text-align:center;gap:.3rem;color:#5e3c2f;padding:1rem;cursor:pointer;transition:background-color .2s ease,transform .2s ease}.dropzone:hover{background-color:#fff2e9;transform:translateY(-1px)}.dropzone input{display:none}.dropzone span{font-weight:700}.dropzone small{font-size:.82rem;color:#865f4f}.file-name{margin:.8rem 0 0;font-size:.92rem;color:#724636}.preview-card img{width:100%;aspect-ratio:1 / 1;object-fit:cover;border-radius:16px}.empty-preview{width:100%;aspect-ratio:1 / 1;border-radius:16px;background:linear-gradient(140deg,#fff4ea,#ffe6d5);border:1px dashed #d9a286;display:grid;place-items:center;color:#7b5849;text-align:center;padding:1rem}.result-head{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.result-head button{border:0;background:#b35f46;color:#fff;padding:.6rem .95rem;border-radius:999px;font-weight:600;cursor:pointer}.result-head button:disabled{opacity:.55;cursor:not-allowed}.placeholder-text{margin:0;color:#785444}.result-grid{margin-top:1rem;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.result-grid article{background:#fff8f2;border:1px solid #f3d9c6;border-radius:14px;padding:.9rem}.result-grid h3{margin:0 0 .5rem;font-size:.95rem}.result-grid p{margin:0;color:#5f4338}.meta,.makeup-list{margin:.75rem 0 0;padding-left:1.1rem;color:#65453a}.swatches{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.45rem}.swatches span{aspect-ratio:1 / 1;border-radius:10px;border:1px solid rgba(0,0,0,.06)}.report-card{margin-top:1rem;background:#fff6ed;border:1px solid #efceb5;border-radius:14px;padding:1rem}.report-card h3{margin:0 0 .65rem}.report-card p{margin:0;color:#5c3e31}.report-error{color:#b33636}.report-text{white-space:pre-wrap;line-height:1.55}.report-actions{margin-top:.9rem;display:flex;gap:.6rem;flex-wrap:wrap}.secondary-button{margin-top:.8rem;border:1px solid #b88670;background:#fff7f0;color:#6e4334;padding:.65rem 1rem;border-radius:999px;font-weight:700;cursor:pointer}.secondary-button:disabled{opacity:.6;cursor:wait}.payment-card{margin-top:1rem;background:#fff4ec;border:1px solid #e8c7b1;border-radius:14px;padding:1rem}.payment-card h3{margin:0 0 .5rem}.payment-card p{margin:0;color:#5c3e31}.payment-button{margin-top:.8rem;border:0;background:#87442f;color:#fff;padding:.65rem 1rem;border-radius:999px;font-weight:700;cursor:pointer}.payment-button:disabled{opacity:.6;cursor:wait}@media(max-width:860px){.workspace,.result-grid{grid-template-columns:1fr}.result-head{flex-direction:column;align-items:flex-start}}
