*,*:before,*:after{box-sizing:border-box}body{margin:0;padding:0;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}.app{min-height:100vh;background:linear-gradient(160deg,#fff5f7,#fef0f5 40%,#f5eeff);display:flex;flex-direction:column;font-family:Pretendard,Apple SD Gothic Neo,Noto Sans KR,sans-serif}.header{padding:48px 24px 36px;text-align:center}.header-inner{display:inline-flex;flex-direction:column;align-items:center;gap:8px}.logo-mark{font-size:28px;color:#c4778a;line-height:1;animation:pulse 2.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.92)}}.site-title{font-size:2.2rem;font-weight:800;letter-spacing:.18em;background:linear-gradient(135deg,#c4778a,#9b6fa8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.site-subtitle{font-size:.88rem;color:#b08898;letter-spacing:.03em;margin-top:4px}.main{flex:1;display:flex;justify-content:center;padding:0 16px 48px}.main-inner{width:100%;max-width:520px;display:flex;flex-direction:column;gap:20px}.form-card{background:#fff;border-radius:24px;box-shadow:0 4px 24px #c4778a14,0 1px 4px #c4778a0f;padding:40px 40px 36px;width:100%;border:1px solid rgba(232,180,192,.3)}.form-section{margin-bottom:0}.step-badge{display:inline-block;background:linear-gradient(135deg,#f0c8d2,#d9bce8);color:#8a4a60;font-size:.68rem;font-weight:700;letter-spacing:.12em;padding:4px 12px;border-radius:20px;margin-bottom:10px}.section-title{font-size:1.15rem;font-weight:700;color:#3a2030;margin-bottom:6px}.section-desc{font-size:.82rem;color:#9c7585;line-height:1.65;margin-bottom:20px}.divider{height:1px;background:linear-gradient(90deg,transparent,#f0dde4,transparent);margin:32px 0}.upload-zone{border:2px dashed #e8c4ce;border-radius:16px;cursor:pointer;transition:all .25s ease;overflow:hidden;min-height:200px;display:flex;align-items:center;justify-content:center;background:#fffbfc}.upload-zone:hover,.upload-zone.dragging{border-color:#c4778a;background:#fff5f7;transform:translateY(-1px);box-shadow:0 6px 20px #c4778a1f}.upload-zone.has-photo{border-style:solid;border-color:#c4778a;min-height:260px}.upload-placeholder{display:flex;flex-direction:column;align-items:center;gap:10px;padding:32px 24px}.upload-icon{opacity:.85;transition:transform .2s ease}.upload-zone:hover .upload-icon{transform:translateY(-3px)}.upload-main-text{font-size:.9rem;color:#7a5060;font-weight:500}.upload-sub-text{font-size:.75rem;color:#b898a4}.hidden-input{display:none}.photo-preview{position:relative;width:100%;height:100%;min-height:260px}.preview-img{width:100%;height:260px;object-fit:cover;display:block}.photo-overlay{position:absolute;inset:0;background:#c4778a00;display:flex;align-items:center;justify-content:center;transition:background .2s ease}.photo-preview:hover .photo-overlay{background:#c4778a80}.change-text{color:#fff;font-size:.9rem;font-weight:600;opacity:0;transition:opacity .2s ease;letter-spacing:.06em}.photo-preview:hover .change-text{opacity:1}.location-row{display:flex;gap:10px;align-items:center}.location-input-wrap{flex:1;position:relative;display:flex;align-items:center}.location-icon{position:absolute;left:14px;display:flex;align-items:center;pointer-events:none}.location-input{width:100%;padding:13px 38px 13px 42px;border:1.5px solid #e8c4ce;border-radius:12px;font-size:.92rem;color:#3a2030;background:#fffbfc;transition:all .2s ease;outline:none;font-family:inherit}.location-input::placeholder{color:#cbaab4}.location-input:focus{border-color:#c4778a;background:#fff5f7;box-shadow:0 0 0 3px #c4778a1a}.clear-btn{position:absolute;right:12px;background:none;border:none;color:#cbaab4;font-size:1.1rem;cursor:pointer;padding:2px 4px;line-height:1;transition:color .2s;display:flex;align-items:center}.clear-btn:hover{color:#c4778a}.auto-btn{display:flex;align-items:center;gap:6px;padding:13px 18px;background:linear-gradient(135deg,#f5e6ea,#ede6f5);border:1.5px solid #ddc4cc;border-radius:12px;color:#8a4a60;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;font-family:inherit;flex-shrink:0}.auto-btn:hover:not(:disabled){background:linear-gradient(135deg,#edd8de,#e0d4f0);border-color:#c4778a;transform:translateY(-1px)}.auto-btn:disabled{opacity:.6;cursor:not-allowed}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(138,74,96,.25);border-top-color:#8a4a60;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.spinner-white{border-color:#ffffff4d;border-top-color:#fff}@keyframes spin{to{transform:rotate(360deg)}}.submit-btn.analyzing{background:linear-gradient(135deg,#c4778a,#9b6fa8);color:#fff;cursor:wait;opacity:.85}.submit-btn{width:100%;margin-top:32px;padding:16px 24px;display:flex;align-items:center;justify-content:center;gap:10px;background:linear-gradient(135deg,#d9a0b0,#b888cc);border:none;border-radius:14px;color:#ffffffb3;font-size:1rem;font-weight:700;letter-spacing:.04em;cursor:not-allowed;transition:all .3s ease;font-family:inherit}.submit-btn.active{background:linear-gradient(135deg,#c4778a,#9b6fa8);color:#fff;cursor:pointer;box-shadow:0 6px 20px #c4778a59}.submit-btn.active:hover{transform:translateY(-2px);box-shadow:0 10px 28px #c4778a73}.submit-btn.active:active{transform:translateY(0)}.ready-text{text-align:center;margin-top:12px;font-size:.8rem;color:#c4778a;font-weight:500;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.error-card{display:flex;align-items:center;gap:10px;background:#fff5f5;border:1px solid #fccfcf;border-radius:14px;padding:16px 20px;animation:fadeIn .3s ease}.error-icon{font-size:1.1rem;flex-shrink:0}.error-card p{font-size:.88rem;color:#c0404a;line-height:1.5}.weather-card{background:#fff;border-radius:24px;box-shadow:0 4px 24px #c4778a14,0 1px 4px #c4778a0f;border:1px solid rgba(232,180,192,.3);overflow:hidden;animation:slideUp .4s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.weather-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.weather-location{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:600;color:#7a5060}.weather-badge{font-size:.68rem;font-weight:700;letter-spacing:.06em;background:linear-gradient(135deg,#f0c8d2,#d9bce8);color:#8a4a60;padding:4px 10px;border-radius:20px}.weather-main{display:flex;align-items:center;gap:16px;padding:20px 24px}.weather-emoji{font-size:3.2rem;line-height:1}.weather-temp-block{display:flex;flex-direction:column;gap:2px}.weather-temp{font-size:2.8rem;font-weight:800;background:linear-gradient(135deg,#c4778a,#9b6fa8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.weather-label{font-size:1rem;font-weight:600;color:#3a2030}.weather-feels{font-size:.78rem;color:#9c7585}.weather-stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid #fceef2}.weather-stat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 8px;border-right:1px solid #fceef2;transition:background .2s}.weather-stat:last-child{border-right:none}.weather-stat:hover{background:#fffbfc}.stat-icon{font-size:1.2rem}.stat-label{font-size:.68rem;color:#b898a4;font-weight:500}.stat-value{font-size:.9rem;font-weight:700;color:#3a2030}.stat-good .stat-value{color:#5a9e7a}.stat-warn .stat-value{color:#c49040}.stat-danger .stat-value{color:#c04848}.result-section{display:flex;flex-direction:column;gap:16px;animation:slideUp .5s ease}.skin-card{background:#fff;border-radius:24px;box-shadow:0 4px 24px #c4778a14,0 1px 4px #c4778a0f;border:1px solid rgba(232,180,192,.3);overflow:hidden}.skin-card-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0}.card-label{font-size:.85rem;font-weight:600;color:#7a5060;display:flex;align-items:center;gap:6px}.analysis-badge{font-size:.68rem;font-weight:700;letter-spacing:.06em;background:linear-gradient(135deg,#d9bce8,#f0c8d2);color:#6a3878;padding:4px 10px;border-radius:20px}.skin-tone-display{display:flex;align-items:center;gap:20px;padding:20px 24px}.skin-color-circle{width:72px;height:72px;border-radius:50%;border:3px solid white;box-shadow:0 4px 16px #00000026;flex-shrink:0;transition:transform .2s ease}.skin-color-circle:hover{transform:scale(1.06)}.skin-tone-info{flex:1}.tone-tags{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap}.tone-tag{font-size:.78rem;font-weight:700;padding:4px 12px;border-radius:20px;letter-spacing:.04em}.undertone-cool{background:#eae4f8;color:#5a3888}.undertone-warm{background:#fdecd8;color:#8a4820}.undertone-neutral{background:#fce8ec;color:#8a4050}.depth-tag{background:#f0f0f0;color:#606060}.skin-desc{font-size:.82rem;color:#9c7585;line-height:1.6}.palette-section{border-top:1px solid #fceef2;padding:20px 24px;display:flex;flex-direction:column;gap:14px}.foundation-tip{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,#fff8fa,#f8f4ff);border-radius:12px;padding:12px 14px;flex-wrap:wrap}.foundation-icon{font-size:1rem;flex-shrink:0}.palette-category{font-size:.72rem;font-weight:700;color:#9b6fa8;letter-spacing:.04em;display:block;margin-bottom:1px}.foundation-text{font-size:.85rem;font-weight:600;color:#3a2030}.finish-tag{margin-left:auto;font-size:.72rem;color:#c4778a;font-weight:600;background:#fff0f4;padding:3px 10px;border-radius:12px;white-space:nowrap}.swatch-row{display:flex;align-items:flex-start;gap:12px}.swatch-row>.palette-category{min-width:76px;padding-top:6px;flex-shrink:0;font-size:.75rem}.swatch-list{display:flex;gap:10px;flex-wrap:wrap}.swatch-item{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:default}.swatch-circle{width:32px;height:32px;border-radius:50%;border:2px solid rgba(255,255,255,.8);box-shadow:0 2px 8px #0000001f;transition:transform .15s ease,box-shadow .15s ease}.swatch-circle:hover{transform:scale(1.15);box-shadow:0 4px 12px #0000002e}.swatch-name{font-size:.62rem;color:#b898a4;text-align:center;max-width:44px;line-height:1.3;word-break:keep-all}.combined-tip-card{background:linear-gradient(135deg,#c4778a,#9b6fa8);border-radius:20px;padding:20px 24px;color:#fff}.combined-tip-header{display:flex;align-items:center;gap:8px;font-size:.8rem;font-weight:700;letter-spacing:.08em;opacity:.85;margin-bottom:10px}.combined-tip-text{font-size:.9rem;line-height:1.7;font-weight:500;opacity:.95}.tryOn-card{background:#fff;border-radius:24px;box-shadow:0 4px 24px #c4778a14,0 1px 4px #c4778a0f;border:1px solid rgba(232,180,192,.3);overflow:hidden}.tryOn-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 0;flex-wrap:wrap;gap:10px}.tryOn-title{display:flex;align-items:center;gap:8px;font-size:.9rem;font-weight:700;color:#3a2030}.tryOn-icon{font-size:1.1rem}.tryOn-toggle{display:flex;background:#f5eef2;border-radius:10px;padding:3px;gap:2px}.toggle-btn{padding:5px 14px;border:none;border-radius:8px;font-size:.78rem;font-weight:600;cursor:pointer;background:transparent;color:#b898a4;transition:all .2s ease;font-family:inherit}.toggle-btn.active{background:#fff;color:#c4778a;box-shadow:0 1px 4px #c4778a26}.tryOn-prompt{padding:24px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}.tryOn-desc{font-size:.85rem;color:#9c7585;line-height:1.7}.tryOn-desc span{color:#c4778a;font-weight:600}.tryOn-btn{display:flex;align-items:center;gap:8px;padding:14px 28px;background:linear-gradient(135deg,#c4778a,#9b6fa8);border:none;border-radius:14px;color:#fff;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .25s ease;font-family:inherit;letter-spacing:.03em;box-shadow:0 4px 16px #c4778a4d}.tryOn-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #c4778a66}.tryOn-btn:disabled{opacity:.75;cursor:wait}.tryOn-result{padding:20px 24px 24px;display:flex;flex-direction:column;gap:16px}.tryOn-img-wrap{position:relative;border-radius:16px;overflow:hidden;border:1.5px solid #f0dde4}.tryOn-img{width:100%;display:block;max-height:420px;object-fit:cover;transition:opacity .3s ease}.tryOn-img-label{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#00000073;color:#fff;font-size:.75rem;font-weight:600;padding:4px 14px;border-radius:20px;letter-spacing:.05em;white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tryOn-actions{display:flex;gap:10px}.download-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:13px 0;background:linear-gradient(135deg,#c4778a,#9b6fa8);border-radius:12px;color:#fff;font-size:.88rem;font-weight:700;text-decoration:none;transition:all .2s ease;box-shadow:0 3px 12px #c4778a40}.download-btn:hover{transform:translateY(-1px);box-shadow:0 6px 18px #c4778a59}.retry-btn{padding:13px 20px;background:#f5eef2;border:1.5px solid #e8c4ce;border-radius:12px;color:#9c7585;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.retry-btn:hover{background:#fceef2;border-color:#c4778a;color:#c4778a}.footer{text-align:center;padding:20px 24px;font-size:.75rem;color:#c4a4b0}@media(max-width:560px){.form-card{padding:28px 20px;border-radius:20px}.site-title{font-size:1.8rem}.location-row{flex-direction:column;align-items:stretch}.auto-btn{justify-content:center}.weather-stats{grid-template-columns:repeat(2,1fr)}.weather-stat:nth-child(2){border-right:none}.weather-stat:nth-child(1),.weather-stat:nth-child(2){border-bottom:1px solid #fceef2}}
