*,:before,:after{box-sizing:border-box}:root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif}html,body{overscroll-behavior:none;background:#0d0d0d;margin:0;padding:0}#root{width:100%;max-width:480px;min-height:100dvh;margin:0 auto}button,input{font-family:inherit}a{text-decoration:none}.main-page{color:#fff;background:#0d0d0d;flex-direction:column;align-items:center;min-height:100dvh;padding-bottom:32px;display:flex;position:relative;overflow:hidden}.main-bg{pointer-events:none;background:radial-gradient(at 70% 10%,#c41e3a40 0%,#0000 60%),radial-gradient(at 20% 80%,#c9b1d926 0%,#0000 50%);position:absolute;inset:0}.main-header{flex-direction:column;gap:4px;width:100%;padding:36px 28px 0;display:flex}.opi-logo{letter-spacing:.35em;color:#fff;background:#cc2529;border-radius:3px;padding:3px 10px;font-size:13px;font-weight:800;display:inline-block}.main-tagline{letter-spacing:.2em;color:#888;text-transform:uppercase;margin:4px 0 0;font-size:11px}.main-content{z-index:1;flex-direction:column;flex:1;gap:36px;width:100%;padding:40px 28px 0;display:flex;position:relative}.hero-section{flex-direction:column;gap:16px;display:flex}.hero-title{letter-spacing:-.02em;margin:0;font-size:34px;font-weight:800;line-height:1.25}.hero-accent{color:#cc2529;font-style:italic}.hero-desc{color:#999;margin:0;font-size:14px;line-height:1.7}.name-input-section{flex-direction:column;gap:10px;display:flex}.name-label{letter-spacing:.08em;color:#aaa;text-transform:uppercase;font-size:12px;font-weight:600}.name-input{color:#fff;box-sizing:border-box;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:14px;outline:none;width:100%;padding:16px 20px;font-size:16px;transition:border-color .2s}.name-input::placeholder{color:#555}.name-input:focus{background:#ffffff17;border-color:#cc252980}.cta-section{flex-direction:column;gap:14px;display:flex}.btn-primary{color:#fff;letter-spacing:.03em;cursor:pointer;background:#cc2529;border:none;border-radius:16px;justify-content:center;align-items:center;gap:8px;width:100%;padding:18px;font-size:16px;font-weight:700;transition:all .2s;display:flex;box-shadow:0 8px 32px #cc252959}.btn-primary:hover{background:#a81f23;transform:translateY(-1px);box-shadow:0 12px 40px #cc252973}.btn-primary:active{transform:translateY(0)}.btn-icon{font-size:14px}.btn-secondary{color:#888;cursor:pointer;background:0 0;border:1px solid #ffffff1f;border-radius:16px;width:100%;padding:16px;font-size:14px;font-weight:500;transition:all .2s}.btn-secondary:hover{color:#fff;background:#ffffff0d;border-color:#ffffff4d}.nail-swatches{z-index:1;gap:10px;padding:32px 0 0;display:flex;position:relative}.swatch-dot{border-radius:50%;flex-shrink:0;width:28px;height:28px;box-shadow:0 2px 8px #0006}.capture-page{color:#fff;background:#0d0d0d;flex-direction:column;align-items:center;min-height:100dvh;display:flex}.back-btn{color:#aaa;cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:20px 24px 8px;font-size:14px;transition:color .2s}.back-btn:hover{color:#fff}.camera-container{background:#111;flex:1;justify-content:center;align-items:center;width:100%;display:flex;position:relative;overflow:hidden}.camera-video{object-fit:cover;width:100%;height:100%}.hand-overlay{pointer-events:none;width:100%;height:100%;position:absolute;inset:0}.camera-error{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:40px;display:flex}.error-icon{font-size:48px}.countdown{color:#fff;text-shadow:0 0 40px #cc2529cc;pointer-events:none;justify-content:center;align-items:center;font-size:100px;font-weight:900;animation:1s ease-out count-pulse;display:flex;position:absolute;inset:0}@keyframes count-pulse{0%{opacity:0;transform:scale(1.5)}to{opacity:1;transform:scale(1)}}.capture-bottom{background:#0d0d0d;flex-direction:column;align-items:center;gap:14px;width:100%;padding:16px 24px 40px;display:flex}.capture-tip{color:#555;margin:0;font-size:12px}.hand-status{background:#ffffff0f;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;transition:background .3s;display:flex}.hand-status--stable{background:#00e6761f}.status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;transition:background .3s}.status-dot--loading{background:#555;animation:1.2s ease-in-out infinite blink}.status-dot--none{background:#555}.status-dot--detecting{background:#ff9b3d;animation:.8s ease-in-out infinite blink}.status-dot--stable{background:#00e676}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.status-text{color:#ccc;white-space:nowrap;margin:0;font-size:13px}.hand-status--stable .status-text{color:#00e676}.capture-btn{cursor:pointer;background:#fff;border:3px solid #ffffff4d;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;transition:all .2s;display:flex;box-shadow:0 0 0 6px #ffffff1f}.capture-btn:hover{transform:scale(1.05)}.capture-btn:active{transform:scale(.95)}.capture-btn:disabled{opacity:.5;cursor:not-allowed}.capture-btn--ready{animation:1.4s ease-in-out infinite ready-pulse;box-shadow:0 0 0 6px #00e6764d}@keyframes ready-pulse{0%,to{box-shadow:0 0 0 6px #00e6764d}50%{box-shadow:0 0 0 12px #00e6761a}}.capture-btn-inner{background:#cc2529;border-radius:50%;width:56px;height:56px;transition:background .2s;display:block}.capture-btn--ready .capture-btn-inner{background:#00c853}.select-page{color:#fff;background:#0d0d0d;flex-direction:column;min-height:100dvh;padding-bottom:32px;display:flex}.back-btn-select{color:#aaa;cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:20px 24px 0;font-size:14px;transition:color .2s}.back-btn-select:hover{color:#fff}.select-header{padding:24px 28px 32px}.select-title{letter-spacing:-.02em;margin:0 0 12px;font-size:28px;font-weight:800;line-height:1.3}.select-subtitle{color:#888;margin:0;font-size:13px;line-height:1.6}.type-grid{grid-template-columns:1fr 1fr;gap:12px;padding:0 20px;display:grid}.type-card{cursor:pointer;aspect-ratio:.85;border:none;border-radius:20px;padding:0;transition:transform .2s,box-shadow .2s;overflow:hidden}.type-card:hover{transform:scale(1.02)translateY(-2px);box-shadow:0 12px 40px #0006}.type-card:active{transform:scale(.98)}.type-card-inner{flex-direction:column;align-items:flex-start;gap:6px;width:100%;height:100%;padding:20px 16px;display:flex}.type-season-icon{font-size:28px;line-height:1}.type-name-ko{letter-spacing:-.01em;margin:8px 0 0;font-size:15px;font-weight:800}.type-name-en{letter-spacing:.05em;text-transform:uppercase;margin:0;font-size:10px;font-weight:600}.type-subtitle{margin:4px 0 8px;font-size:11px;font-weight:500;line-height:1.4}.type-keywords{flex-wrap:wrap;gap:4px;display:flex}.keyword-chip{border-radius:20px;padding:3px 8px;font-size:10px;font-weight:600}.analyzing-page{background:#0d0d0d;justify-content:center;align-items:center;min-height:100dvh;display:flex;position:relative;overflow:hidden}.analyzing-bg{background:radial-gradient(#cc252926 0%,#0000 70%);animation:2s ease-in-out infinite bg-pulse;position:absolute;inset:0}@keyframes bg-pulse{0%,to{opacity:.6}50%{opacity:1}}.analyzing-content{z-index:1;flex-direction:column;align-items:center;gap:24px;display:flex;position:relative}.scan-ring{border:1px solid #cc25294d;border-radius:50%;justify-content:center;align-items:center;width:140px;height:140px;animation:3s linear infinite ring-rotate;display:flex}@keyframes ring-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.scan-ring-inner{border:2px solid #cc2529;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;animation:2s linear infinite reverse ring-rotate;display:flex;position:relative}.scan-pulse{border:2px solid #cc252966;border-radius:50%;animation:1.5s ease-out infinite scan-expand;position:absolute;inset:-8px}@keyframes scan-expand{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.5)}}.scan-icon{color:#cc2529;font-size:32px;animation:4s linear infinite icon-spin}@keyframes icon-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.analyzing-title{color:#fff;letter-spacing:.05em;margin:0;font-size:24px;font-weight:800}.analyzing-step{color:#888;min-height:20px;margin:0;font-size:14px;transition:opacity .3s}.progress-bar-wrap{align-items:center;gap:12px;width:240px;display:flex}.progress-bar{background:#ffffff1a;border-radius:2px;flex:1;height:3px;overflow:hidden}.progress-fill{background:#cc2529;border-radius:2px;height:100%;transition:width 50ms linear}.progress-pct{color:#666;text-align:right;width:32px;font-size:12px}.modal-backdrop{z-index:100;background:#000000b3;align-items:flex-end;animation:.2s backdrop-in;display:flex;position:fixed;inset:0}@keyframes backdrop-in{0%{opacity:0}to{opacity:1}}.modal-sheet{background:#1a1a1a;border-radius:24px 24px 0 0;flex-direction:column;width:100%;padding:12px 0 48px;animation:.3s cubic-bezier(.34,1.3,.64,1) forwards sheet-in;display:flex}@keyframes sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-handle{background:#fff3;border-radius:2px;width:36px;height:4px;margin:0 auto 20px}.modal-header{justify-content:space-between;align-items:center;padding:0 24px 20px;display:flex}.modal-title{color:#fff;margin:0;font-size:18px;font-weight:800}.modal-close{color:#888;cursor:pointer;background:0 0;border:none;padding:4px;font-size:18px;line-height:1}.modal-tabs{gap:8px;margin-bottom:24px;padding:0 24px;display:flex}.modal-tab{color:#888;cursor:pointer;background:#ffffff0f;border:1.5px solid #ffffff14;border-radius:12px;flex:1;padding:12px;font-size:14px;font-weight:600;transition:all .2s}.modal-tab.active{color:#fff;background:#cc252926;border-color:#cc2529}.modal-body{flex-direction:column;align-items:center;gap:20px;padding:0 24px;display:flex}.modal-desc{color:#888;text-align:center;margin:0;font-size:13px;line-height:1.6}.preview-badge{border-radius:50px;padding:12px 24px;font-size:15px;font-weight:700}.qr-wrapper{background:#fff;border-radius:16px;flex-direction:column;align-items:center;gap:10px;padding:16px;display:flex}.qr-url{color:#888;margin:0;font-size:11px}.modal-action-btn{color:#fff;cursor:pointer;background:#cc2529;border:none;border-radius:16px;width:100%;padding:18px;font-size:16px;font-weight:700;transition:all .2s}.modal-action-btn:hover{background:#a81f23}.modal-action-btn:disabled{opacity:.6;cursor:not-allowed}.result-card-export{border-radius:24px;width:360px;min-height:640px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;position:relative;overflow:hidden}.rc-bg{position:absolute;inset:0}.rc-content{z-index:1;flex-direction:column;gap:16px;padding:32px 28px 36px;display:flex;position:relative}.rc-top{align-items:center;gap:8px;display:flex}.rc-logo{letter-spacing:.3em;color:#cc2529;background:#ffffffe6;border-radius:4px;padding:3px 8px;font-size:10px;font-weight:800}.rc-label{color:#ffffffb3;letter-spacing:.15em;text-transform:uppercase;margin:0;font-size:10px}.rc-username{color:#fffc;margin:0;font-size:13px;font-weight:600}.rc-tone{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:16px;align-items:center;gap:16px;padding:16px 20px;display:flex}.rc-icon{font-size:36px;line-height:1}.rc-tone-en{letter-spacing:.15em;text-transform:uppercase;opacity:.75;margin:0 0 4px;font-size:10px;font-weight:700}.rc-tone-ko{letter-spacing:-.02em;margin:0;font-size:22px;font-weight:900}.rc-section-label{letter-spacing:.1em;text-transform:uppercase;opacity:.75;margin:0;font-size:11px;font-weight:700}.rc-colors{grid-template-columns:repeat(4,1fr);gap:12px 8px;display:grid}.rc-color-item{flex-direction:column;align-items:center;gap:6px;display:flex}.rc-swatch{border-radius:50%;width:52px;height:52px;box-shadow:0 3px 10px #00000040}.rc-color-name{text-align:center;opacity:.85;word-break:break-word;margin:0;font-size:8px;font-weight:600;line-height:1.3}.rc-footer{text-align:center;opacity:.5;letter-spacing:.05em;margin:4px 0 0;font-size:10px}.result-page{background:#0d0d0d;min-height:100dvh;position:relative;overflow:hidden}.result-bg{opacity:.12;pointer-events:none;z-index:0;position:fixed;inset:0}.result-scroll{z-index:1;flex-direction:column;min-height:100dvh;padding-bottom:40px;display:flex;position:relative}.result-header{align-items:center;gap:12px;padding:36px 28px 0;display:flex}.opi-logo-sm{letter-spacing:.3em;color:#fff;background:#cc2529;border-radius:3px;padding:3px 8px;font-size:11px;font-weight:800}.result-username{color:#888;margin:0;font-size:13px}.tone-reveal{cursor:pointer;min-height:260px;margin:28px 20px}.tone-tap-hint{color:#888;flex-direction:column;justify-content:center;align-items:center;gap:16px;height:260px;font-size:14px;display:flex;position:relative}.tone-tap-ripple{border:2px solid #cc2529;border-radius:50%;width:80px;height:80px;animation:1.5s ease-out infinite ripple}@keyframes ripple{0%{opacity:1;transform:scale(.8)}to{opacity:0;transform:scale(1.4)}}.tone-result-card{border-radius:24px;flex-direction:column;gap:8px;padding:28px 24px 24px;animation:.6s cubic-bezier(.34,1.56,.64,1) forwards card-in;display:flex}@keyframes card-in{0%{opacity:0;transform:scale(.85)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.tone-season-icon{font-size:40px;line-height:1}.tone-name-en{letter-spacing:.2em;text-transform:uppercase;opacity:.7;margin:8px 0 0;font-size:11px;font-weight:700}.tone-name-ko{letter-spacing:-.02em;margin:0;font-size:32px;font-weight:900;line-height:1.1}.tone-subtitle{opacity:.85;margin:4px 0 0;font-size:13px;font-weight:600}.tone-desc{opacity:.8;margin:8px 0 0;font-size:13px;line-height:1.65}.tone-keywords{flex-wrap:wrap;gap:6px;margin-top:12px;display:flex}.tone-keyword{border-radius:20px;padding:4px 10px;font-size:11px;font-weight:600}.colors-section{flex-direction:column;gap:20px;animation:.5s forwards fade-up;display:flex}@keyframes fade-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.colors-header{justify-content:space-between;align-items:center;padding:0 28px;display:flex}.colors-title{color:#fff;margin:0;font-size:18px;font-weight:800}.colors-count{color:#666;background:#ffffff0f;border-radius:12px;padding:4px 10px;font-size:12px}.color-slider{scrollbar-width:none;gap:12px;padding:4px 20px 8px;display:flex;overflow-x:auto}.color-slider::-webkit-scrollbar{display:none}.color-slide{cursor:pointer;opacity:0;background:#ffffff0d;border:1.5px solid #ffffff14;border-radius:18px;flex-direction:column;flex-shrink:0;align-items:center;gap:10px;width:100px;padding:12px;transition:all .2s;animation:.4s forwards slide-in;display:flex}@keyframes slide-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.color-slide:hover{background:#ffffff14;border-color:#ffffff40;transform:translateY(-3px)}.color-slide.active{background:#cc25291f;border-color:#cc2529;transform:translateY(-3px)}.color-swatch-lg{border-radius:50%;flex-shrink:0;width:60px;height:60px;box-shadow:0 4px 16px #0006}.color-info-sm{text-align:center}.color-name-sm{color:#ccc;word-break:break-word;margin:0;font-size:10px;font-weight:600;line-height:1.3}.color-collection{color:#666;margin:2px 0 0;font-size:9px}.color-detail-card{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:20px;align-items:center;gap:20px;margin:0 20px;padding:20px;animation:.3s forwards fade-up;display:flex}.detail-left{flex-shrink:0}.detail-swatch{border-radius:50%;width:72px;height:72px;box-shadow:0 4px 20px #00000080}.detail-right{flex:1;min-width:0}.detail-collection{color:#888;text-transform:uppercase;letter-spacing:.1em;margin:0 0 4px;font-size:10px}.detail-name{color:#fff;margin:0 0 2px;font-size:15px;font-weight:800;line-height:1.3}.detail-name-ko{color:#999;margin:0 0 12px;font-size:12px}.detail-buy-btn{color:#fff;background:#cc2529;border-radius:10px;padding:8px 16px;font-size:12px;font-weight:700;text-decoration:none;transition:background .2s;display:inline-block}.detail-buy-btn:hover{background:#a81f23}.color-grid-section{padding:0 28px}.grid-label{color:#666;text-transform:uppercase;letter-spacing:.1em;margin:0 0 12px;font-size:11px}.color-grid{flex-wrap:wrap;gap:10px;display:flex}.grid-dot{cursor:pointer;border:2px solid #0000;border-radius:50%;width:36px;height:36px;transition:all .15s;box-shadow:0 2px 8px #00000059}.grid-dot:hover{transform:scale(1.15)}.grid-dot-active{border-color:#fff;transform:scale(1.2);box-shadow:0 4px 16px #00000080}.result-actions{opacity:0;flex-direction:column;gap:12px;padding:32px 20px 0;animation:.4s .2s forwards fade-up;display:flex}.save-btn{color:#fff;cursor:pointer;background:#cc2529;border:none;border-radius:16px;width:100%;padding:18px;font-size:16px;font-weight:700;transition:all .2s;box-shadow:0 8px 32px #cc252959}.save-btn:hover{background:#a81f23;transform:translateY(-1px)}.restart-btn{color:#888;cursor:pointer;background:0 0;border:1px solid #ffffff1f;border-radius:16px;width:100%;padding:16px;font-size:14px;transition:all .2s}.restart-btn:hover{color:#fff;border-color:#ffffff4d}
