*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{color:#1a1a2e;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#faf5ff;font-family:Noto Sans KR,system-ui,sans-serif;font-size:16px;line-height:1.5}body{min-height:100svh;overflow-x:hidden}#root{flex-direction:column;width:100%;max-width:480px;min-height:100svh;margin:0 auto;display:flex}button{cursor:pointer;border:none;outline:none;font-family:inherit}input{outline:none;font-family:inherit}img{max-width:100%}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-20px)scale(1.05)}}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.fade-in{animation:.45s both fadeIn}.hero-page{background:linear-gradient(160deg,#f8eeff 0%,#fff0f6 50%,#fff4e8 100%);justify-content:center;align-items:center;min-height:100svh;display:flex;position:relative;overflow:hidden}.hero-bg{pointer-events:none;position:absolute;inset:0}.orb{filter:blur(60px);opacity:.45;border-radius:50%;position:absolute}.orb1{background:radial-gradient(circle,#c9a7ff,#f4a8d0);width:280px;height:280px;animation:7s ease-in-out infinite float;top:-60px;left:-60px}.orb2{background:radial-gradient(circle,#ffb38a,#ff9bc1);width:220px;height:220px;animation:9s ease-in-out infinite reverse float;top:100px;right:-80px}.orb3{background:radial-gradient(circle,#a8e8ff,#c8b8ff);width:200px;height:200px;animation:11s ease-in-out infinite float;bottom:120px;left:-40px}.orb4{background:radial-gradient(circle,#ffd4a8,#ffaac8);width:160px;height:160px;animation:8s ease-in-out infinite reverse float;bottom:60px;right:-20px}.hero-content{z-index:1;text-align:center;flex-direction:column;align-items:center;gap:0;padding:40px 28px;display:flex;position:relative}.hero-brand{letter-spacing:6px;color:#9b6fcc;text-transform:uppercase;margin-bottom:20px;font-size:13px;font-weight:700}.hero-title{color:#1a1a2e;letter-spacing:-1px;margin-bottom:16px;font-size:42px;font-weight:900;line-height:1.15}.hero-sub{color:#6b6b8a;margin-bottom:32px;font-size:15px;line-height:1.7}.season-preview{gap:12px;margin-bottom:36px;display:flex}.season-orb{border-radius:50%;width:52px;height:52px;transition:transform .2s;box-shadow:0 4px 16px #0000001f}.season-orb:hover{transform:scale(1.1)}.btn-primary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#c9a7ff,#ff9bc1);border:none;border-radius:50px;justify-content:center;align-items:center;width:100%;max-width:320px;margin-bottom:12px;padding:16px 32px;font-size:16px;font-weight:700;transition:transform .18s,box-shadow .18s,opacity .18s;display:flex;box-shadow:0 8px 24px #c9a7ff73}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 32px #c9a7ff8c}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-primary.btn-large{padding:18px 40px;font-size:17px}.btn-primary.btn-gradient{background:linear-gradient(135deg,#9b6fcc,#ff6ba8,#ff9b58);box-shadow:0 8px 24px #9b6fcc66}.hero-caption{color:#9b9bb8;font-size:13px}.step-page{background:#faf5ff;flex-direction:column;min-height:100svh;display:flex}.step-header{background:#faf5ff;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.btn-back{color:#6b5b8a;cursor:pointer;background:#fff;border:1.5px solid #e8e0f0;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;transition:background .15s;display:flex}.btn-back:hover{background:#f0e8ff}.step-dots{align-items:center;gap:8px;display:flex}.dot{background:#ddd4f0;border-radius:50%;width:8px;height:8px;transition:all .25s}.dot.active{background:linear-gradient(90deg,#c9a7ff,#ff9bc1);border-radius:4px;width:24px}.dot.done{background:#c9a7ff;border-radius:50%;width:8px}.step-body{flex:1;padding:8px 24px 24px;overflow-y:auto}.step-title{color:#1a1a2e;letter-spacing:-.5px;margin-bottom:8px;font-size:24px;font-weight:800}.step-desc{color:#8878a8;margin-bottom:28px;font-size:14px;line-height:1.5}.step-footer{background:#fff;border-top:1px solid #f0e8ff;padding:16px 24px 32px}.photo-upload{cursor:pointer;background:#fff;border:2px dashed #d4c8f0;border-radius:20px;justify-content:center;align-items:center;width:100%;height:220px;margin-bottom:24px;transition:border-color .2s,background .2s;display:flex;position:relative;overflow:hidden}.photo-upload:hover{background:#faf5ff;border-color:#c9a7ff}.photo-upload.dragging{background:#f5eeff;border-color:#9b6fcc}.photo-upload.has-photo{cursor:default;border:none}.photo-placeholder{text-align:center}.photo-icon{margin-bottom:10px;font-size:40px}.photo-text{color:#4a3870;margin-bottom:4px;font-size:15px;font-weight:600}.photo-hint{color:#a898c8;font-size:13px}.photo-preview{object-fit:cover;width:100%;height:100%}.photo-change-btn{color:#6b5b8a;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffeb;border:1.5px solid #e0d8f0;border-radius:20px;padding:6px 14px;font-size:13px;font-weight:600;position:absolute;bottom:12px;right:12px}.input-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.input-group{flex-direction:column;gap:8px;display:flex}.input-label{color:#6b5b8a;text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.input-wrap{position:relative}.input-field{color:#1a1a2e;-moz-appearance:textfield;background:#fff;border:1.5px solid #e4d8f8;border-radius:14px;width:100%;padding:14px 44px 14px 16px;font-size:18px;font-weight:700;transition:border-color .2s,box-shadow .2s}.input-field::-webkit-inner-spin-button{-webkit-appearance:none}.input-field::-webkit-outer-spin-button{-webkit-appearance:none}.input-field:focus{border-color:#c9a7ff;box-shadow:0 0 0 3px #c9a7ff33}.input-unit{color:#a898c8;font-size:13px;font-weight:600;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.quiz-section{margin-bottom:28px}.quiz-q{color:#1a1a2e;margin-bottom:12px;font-size:15px;font-weight:700}.quiz-options{flex-direction:column;gap:10px;display:flex}.quiz-options.two-col{grid-template-columns:1fr 1fr;gap:10px;display:grid}.quiz-card{cursor:pointer;text-align:left;background:#fff;border:1.5px solid #e8e0f4;border-radius:16px;align-items:center;gap:12px;padding:14px 16px;transition:border-color .18s,box-shadow .18s,background .18s;display:flex;position:relative}.quiz-card:hover{background:#faf5ff;border-color:#c9a7ff}.quiz-card.selected{background:#f5eeff;border-color:#9b6fcc;box-shadow:0 0 0 3px #9b6fcc26}.quiz-card.quiz-card-sm{flex-direction:column;align-items:flex-start;gap:8px;padding:14px}.quiz-swatch{border-radius:12px;flex-shrink:0;width:44px;height:44px}.quiz-swatch-sm{border-radius:10px;width:100%;height:36px}.quiz-card-text{flex-direction:column;flex:1;gap:2px;display:flex}.quiz-card-label{color:#1a1a2e;font-size:14px;font-weight:700}.quiz-card-desc{color:#8878a8;font-size:12px}.quiz-check{color:#fff;background:linear-gradient(135deg,#9b6fcc,#ff9bc1);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;margin-left:auto;font-size:12px;font-weight:700;display:flex}.quiz-card-sm .quiz-check{position:absolute;top:10px;right:10px}.result-page{background:#faf5ff;min-height:100svh}.result-hero{text-align:center;padding:48px 28px 40px;position:relative;overflow:hidden}.result-hero:after{content:"";background:#faf5ff;border-radius:32px 32px 0 0;height:32px;position:absolute;bottom:-2px;left:0;right:0}.result-photo-wrap{border:3px solid #fffc;border-radius:50%;width:90px;height:90px;margin:0 auto 16px;overflow:hidden;box-shadow:0 4px 20px #00000026}.result-photo{object-fit:cover;width:100%;height:100%}.result-season-emoji{margin-bottom:12px;font-size:48px;animation:2s ease-in-out infinite pulse}.result-season-badge{color:#0000008c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff80;border-radius:20px;margin-bottom:10px;padding:4px 14px;font-size:12px;font-weight:600;display:inline-block}.result-season-name{letter-spacing:-1px;text-shadow:0 2px 8px #0000001a;margin-bottom:4px;font-size:34px;font-weight:900}.result-season-english{letter-spacing:3px;color:#0006;text-transform:uppercase;margin-bottom:10px;font-size:13px;font-weight:600}.result-tagline{color:#0000008c;font-size:15px;font-weight:500}.result-body{flex-direction:column;gap:16px;padding:8px 20px 40px;display:flex}.result-desc-card{background:#fff;border-radius:20px;padding:20px;box-shadow:0 2px 16px #9b6fcc14}.result-desc{color:#3a2a5a;white-space:pre-line;text-align:center;font-size:15px;line-height:1.7}.result-section{background:#fff;border-radius:20px;padding:20px;box-shadow:0 2px 16px #9b6fcc14}.result-section-title{color:#1a1a2e;margin-bottom:14px;font-size:15px;font-weight:700}.palette-row{justify-content:space-between;gap:10px;display:flex}.palette-item{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}.palette-swatch{aspect-ratio:1;border-radius:14px;width:100%;box-shadow:0 2px 8px #0000001a}.palette-name{color:#7868a8;text-align:center;word-break:keep-all;font-size:11px;font-weight:500}.keywords-row{flex-wrap:wrap;gap:8px;display:flex}.keyword-badge{color:#fff;text-shadow:0 1px 3px #0003;border-radius:20px;padding:6px 16px;font-size:13px;font-weight:600}.result-two-col{grid-template-columns:1fr 1fr;gap:12px;display:grid}.info-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 2px 16px #9b6fcc14}.best-card{border-top:3px solid #6fcf97}.avoid-card{border-top:3px solid #f4a4a4}.info-card-icon{margin-bottom:6px;font-size:20px}.info-card-title{color:#6b5b8a;margin-bottom:6px;font-size:12px;font-weight:700}.info-card-text{color:#3a2a5a;font-size:13px;line-height:1.6}.result-card{background:#fff;border-radius:20px;padding:20px;box-shadow:0 2px 16px #9b6fcc14}.makeup-tip{color:#3a2a5a;margin-top:4px;font-size:14px;line-height:1.7}.style-banner{border-radius:20px;justify-content:space-between;align-items:center;padding:20px 24px;display:flex;box-shadow:0 4px 20px #0000001a}.style-label{color:#00000073;font-size:13px;font-weight:600}.style-value{text-shadow:0 2px 8px #00000026;font-size:16px;font-weight:800}.btn-secondary{color:#6b5b8a;cursor:pointer;background:#fff;border:1.5px solid #e0d4f8;border-radius:50px;width:100%;margin-top:4px;padding:16px;font-size:15px;font-weight:600;transition:background .18s,border-color .18s}.btn-secondary:hover{background:#f8f2ff;border-color:#c9a7ff}@keyframes loadingDot{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.btn-ai{cursor:pointer;text-align:left;background:linear-gradient(135deg,#1a1a2e 0%,#4a0e8f 50%,#9b3fcc 100%);border:none;border-radius:20px;align-items:center;gap:14px;width:100%;padding:18px 20px;transition:transform .18s,box-shadow .18s;display:flex;box-shadow:0 8px 28px #4a0e8f59}.btn-ai:hover{transform:translateY(-2px);box-shadow:0 12px 36px #4a0e8f73}.btn-ai-icon{flex-shrink:0;font-size:30px}.btn-ai span{flex-direction:column;gap:2px;display:flex}.btn-ai-main{color:#fff;font-size:15px;font-weight:700}.btn-ai-sub{color:#ffffffa6;font-size:12px;line-height:1.4}.report-loading{text-align:center;background:#fff;border-radius:20px;padding:36px 24px;box-shadow:0 2px 16px #9b6fcc14}.report-loading-dots{justify-content:center;gap:8px;margin-bottom:16px;display:flex}.report-loading-dots span{background:linear-gradient(135deg,#9b6fcc,#ff9bc1);border-radius:50%;width:10px;height:10px;animation:1.4s ease-in-out infinite loadingDot}.report-loading-dots span:nth-child(2){animation-delay:.2s}.report-loading-dots span:nth-child(3){animation-delay:.4s}.report-loading-text{color:#3a2a5a;margin-bottom:4px;font-size:15px;font-weight:600}.report-loading-sub{color:#a898c8;font-size:13px}.report-error{text-align:center;background:#fff5f5;border:1.5px solid #ffc0c0;border-radius:16px;padding:20px}.report-error-msg{color:#c0304a;margin-bottom:12px;font-size:14px}.btn-retry{color:#c0304a;cursor:pointer;background:#fff;border:1.5px solid #f4a4a4;border-radius:20px;padding:10px 24px;font-size:14px;font-weight:600}.report-wrapper{border-radius:20px;overflow:hidden;box-shadow:0 4px 24px #4a0e8f1f}.report-header{align-items:center;gap:12px;padding:20px;display:flex}.report-header-icon{font-size:28px}.report-header-title{color:#000000b3;font-size:15px;font-weight:700}.report-header-sub{color:#00000073;margin-top:2px;font-size:12px}.report-section{background:#fff;border-bottom:1px solid #f0e8ff;padding:18px 20px}.report-section:last-child{border-bottom:none}.report-section-title{color:#1a1a2e;align-items:center;gap:8px;margin-bottom:10px;font-size:14px;font-weight:700;display:flex}.report-section-icon{font-size:16px}.report-section-content{color:#3a2a5a;white-space:pre-line;font-size:14px;line-height:1.8}.btn-hair{cursor:pointer;text-align:left;background:linear-gradient(135deg,#3d1f00 0%,#8b4513 50%,#c68642 100%);border:none;border-radius:20px;align-items:center;gap:14px;width:100%;padding:18px 20px;transition:transform .18s,box-shadow .18s;display:flex;box-shadow:0 8px 28px #8b45134d}.btn-hair:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 36px #8b451366}.btn-hair:disabled{opacity:.45;cursor:not-allowed}.btn-hair-icon{flex-shrink:0;font-size:30px}.btn-hair>span{flex-direction:column;gap:3px;display:flex}.btn-hair-main{color:#fff;font-size:15px;font-weight:700}.btn-hair-sub{color:#ffffffa6;font-size:12px;line-height:1.4}.hair-result{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 24px #8b451326}.hair-result-header{background:linear-gradient(135deg,#3d1f00 0%,#8b4513 50%,#c68642 100%);align-items:center;gap:12px;padding:16px 20px;display:flex}.hair-result-icon{font-size:28px}.hair-result-title{color:#fff;font-size:15px;font-weight:700}.hair-result-sub{color:#ffffffa6;margin-top:2px;font-size:12px}.hair-result-image{width:100%;display:block}.btn-download{text-align:center;color:#8b4513;background:#fff8f0;border-top:1px solid #f0e0d0;padding:14px;font-size:14px;font-weight:700;text-decoration:none;transition:background .15s;display:block}.btn-download:hover{background:#ffe8cc}
