.size-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1000;display:flex;justify-content:center;align-items:center}.size-modal{width:100%;max-width:600px;height:100%;max-height:100vh;background:#fff;display:flex;flex-direction:column;animation:slideUp .3s ease-out;position:relative}.size-modal__header{display:flex;align-items:center;justify-content:center;padding:16px 20px;position:relative;flex-shrink:0;border-bottom:1px solid #f0f0f0}.size-modal__title{font-size:16px;font-weight:700;color:#111}.size-modal__close{position:absolute;right:16px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer}.size-modal__close svg{width:24px;height:24px;stroke:#666}.size-modal__product{display:flex;align-items:center;gap:12px;padding:16px 20px;flex-shrink:0}.size-modal__product-img{width:52px;height:52px;border-radius:12px;background:#f5f5f5;overflow:hidden;flex-shrink:0}.size-modal__product-img img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.size-modal__product-info{flex:1;min-width:0}.size-modal__product-brand{font-size:11px;font-weight:600;color:#999;text-transform:uppercase;letter-spacing:.5px}.size-modal__product-name{font-size:13px;font-weight:500;color:#333;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.size-modal__profiles{padding:0 20px 16px;flex-shrink:0}.size-modal__profile-tabs{display:flex;gap:8px}.size-modal__profile-tab{padding:8px 16px;border-radius:20px;font-size:13px;font-weight:600;border:none;cursor:pointer;transition:all .2s;background:#f5f5f5;color:#666}.size-modal__profile-tab.active{background:#111;color:#fff}.size-modal__profile-summary{margin-top:12px;padding:12px 16px;background:#f8f8f8;border-radius:12px;font-size:13px;color:#666}.size-modal__progress{display:flex;align-items:center;gap:6px;padding:0 20px 20px;flex-shrink:0}.size-modal__progress-dot{height:8px;border-radius:4px;background:#e0e0e0;transition:all .3s;width:8px}.size-modal__progress-dot.active{width:24px;background:#111}.size-modal__progress-dot.completed{width:8px;background:#111}.size-modal__content{flex:1;overflow-y:auto;padding:0 20px 120px}.size-modal__step{animation:fadeIn .3s ease-out}.size-modal__step-header{text-align:center;margin-bottom:32px}.size-modal__step-header h2{font-size:22px;font-weight:800;color:#111;margin-bottom:8px}.size-modal__step-header p{font-size:14px;color:#888}.size-modal__gender-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;max-width:320px;margin:0 auto}.size-modal__gender-card{position:relative;padding:32px 24px;border-radius:20px;text-align:center;cursor:pointer;transition:all .2s;background:#f8f8f8;border:2px solid #e8e8e8}.size-modal__gender-card:active{transform:scale(.98)}.size-modal__gender-card.active{background:#fff;border-color:#111;box-shadow:0 4px 20px rgba(0,0,0,.1)}.size-modal__check{position:absolute;top:12px;right:12px;width:24px;height:24px;background:#111;border-radius:50%;display:flex;align-items:center;justify-content:center}.size-modal__check svg{width:14px;height:14px;stroke:#fff}.size-modal__gender-icon{width:64px;height:64px;margin:0 auto 16px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#fff;transition:all .2s}.size-modal__gender-icon.active{background:#111}.size-modal__gender-icon svg{width:32px;height:32px;stroke:#999;transition:all .2s}.size-modal__gender-icon.active svg{stroke:#fff}.size-modal__gender-label{font-size:15px;font-weight:700;color:#444}.size-modal__gender-card.active .size-modal__gender-label{color:#111}.size-modal__tip{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#111;border-radius:16px;margin-top:24px;max-width:320px;margin-left:auto;margin-right:auto}.size-modal__tip svg{width:20px;height:20px;stroke:#666;flex-shrink:0}.size-modal__tip p{font-size:13px;color:#aaa;line-height:1.5}.size-modal__tip strong{color:#fff}.size-modal__size-display{text-align:center;margin-bottom:32px}.size-modal__size-value{font-size:56px;font-weight:800;color:#111;line-height:1}.size-modal__size-unit{font-size:24px;font-weight:600;color:#999;margin-left:4px}.size-modal__size-conversion{font-size:14px;color:#888;margin-top:8px}.size-modal__size-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;max-width:400px;margin:0 auto}.size-modal__size-btn{height:52px;border-radius:16px;font-size:15px;font-weight:600;border:2px solid #e0e0e0;background:#fff;color:#444;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.size-modal__size-btn:active{transform:scale(.95)}.size-modal__size-btn.active{background:#111;border-color:#111;color:#fff}.size-modal__size-btn:not(.active):hover{border-color:#999}.size-modal__shape-section{margin-bottom:32px}.size-modal__shape-label{font-size:14px;font-weight:700;color:#333;margin-bottom:16px;display:flex;align-items:center;gap:8px}.size-modal__shape-label span{font-size:12px;font-weight:500;color:#999}.size-modal__shape-options{display:flex;gap:12px}.size-modal__shape-card{flex:1;padding:20px 12px;border-radius:20px;text-align:center;cursor:pointer;transition:all .2s;background:#f8f8f8;border:2px solid #e8e8e8}.size-modal__shape-card:active{transform:scale(.95)}.size-modal__shape-card.active{background:#fff;border-color:#111;box-shadow:0 4px 20px rgba(0,0,0,.1)}.size-modal__shape-visual{width:60px;height:40px;margin:0 auto 12px;display:flex;align-items:center;justify-content:center}.size-modal__shape-bar{border-radius:999px;background:#ccc;transition:all .2s}.size-modal__shape-bar.active{background:#111}.size-modal__shape-name{display:block;font-size:14px;font-weight:700;color:#444}.size-modal__shape-card.active .size-modal__shape-name{color:#111}.size-modal__shape-desc{display:block;font-size:11px;color:#999;margin-top:4px}.size-modal__complete{text-align:center;padding-top:20px}.size-modal__complete-icon{width:72px;height:72px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes popIn{0%{transform:scale(0)}70%{transform:scale(1.1)}to{transform:scale(1)}}.size-modal__complete-icon svg{width:36px;height:36px;stroke:#fff}.size-modal__complete h2{font-size:22px;font-weight:800;color:#111;margin-bottom:8px}.size-modal__complete p{font-size:14px;color:#888;margin-bottom:28px}.size-modal__summary{background:#f8f8f8;border-radius:20px;padding:20px;max-width:300px;margin:0 auto}.size-modal__summary-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #e8e8e8}.size-modal__summary-row:last-child{border-bottom:none}.size-modal__summary-row span:first-child{font-size:13px;color:#888}.size-modal__summary-row span:last-child{font-size:13px;font-weight:600;color:#111}.size-modal__footer{position:absolute;bottom:0;left:0;right:0;display:flex;gap:10px;padding:12px 20px max(12px,env(safe-area-inset-bottom));border-top:1px solid #f0f0f0;background:#fff}.size-modal__btn{height:52px;border-radius:16px;font-size:15px;font-weight:700;border:none;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.size-modal__btn:active{transform:scale(.98)}.size-modal__btn--back{width:52px;background:#fff;border:1px solid #e0e0e0;color:#666}.size-modal__btn--back svg{width:20px;height:20px;stroke:currentColor}.size-modal__btn--skip{flex:1;background:#fff;border:1px solid #e0e0e0;color:#666}.size-modal__btn--next{flex:1.5;background:#111;color:#fff}.size-modal__btn--complete{flex:1;background:#111;color:#fff}.size-modal__input-group{margin-bottom:24px;margin-left:0;margin-right:0}.size-modal__input-label{font-size:14px;font-weight:600;color:#333;margin-bottom:12px;display:block}.size-modal__input-field{display:flex;align-items:center;background:#f8f8f8;border-radius:12px;padding:0 16px;height:52px;border:2px solid transparent;transition:all .2s}.size-modal__input-field:focus-within{border-color:#111;background:#fff}.size-modal__input-field input{flex:1;border:none;background:none;font-size:16px;font-weight:600;color:#111;text-align:right;outline:none;min-width:0;-moz-appearance:textfield}.size-modal__input-field input::-webkit-inner-spin-button,.size-modal__input-field input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.size-modal__input-field input::-moz-placeholder{color:#ccc}.size-modal__input-field input::placeholder{color:#ccc}.size-modal__input-unit{font-size:14px;color:#888;margin-left:8px;flex-shrink:0}.size-modal__jewelry-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;max-width:400px;margin:0 auto}.size-modal__jewelry-btn{height:48px;border-radius:12px;font-size:14px;font-weight:600;border:2px solid #e0e0e0;background:#fff;color:#444;cursor:pointer;transition:all .2s}.size-modal__jewelry-btn:active{transform:scale(.95)}.size-modal__jewelry-btn.active{background:#111;border-color:#111;color:#fff}.size-modal__slider{margin:32px auto;max-width:320px}.size-modal__slider-track{position:relative;height:48px;background:#f5f5f5;border-radius:24px;padding:0 24px;display:flex;align-items:center}.size-modal__slider-input{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:pointer}.size-modal__slider-input::-webkit-slider-runnable-track{height:4px;background:#ddd;border-radius:2px}.size-modal__slider-input::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:28px;height:28px;background:#111;border-radius:50%;margin-top:-12px;box-shadow:0 2px 8px rgba(0,0,0,.2)}.size-modal__slider-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:12px;color:#999}.size-modal__loading{display:flex;align-items:center;justify-content:center;min-height:300px;color:#999}.size-modal__saved-profile{background:linear-gradient(135deg,#111,#333);border-radius:24px;padding:24px;text-align:center;margin:0 auto 24px;max-width:320px;color:#fff}.size-modal__saved-profile-badge{display:inline-block;background:hsla(0,0%,100%,.15);padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;margin-bottom:16px}.size-modal__saved-profile-main{margin-bottom:12px}.size-modal__saved-profile-size{font-size:48px;font-weight:800;line-height:1;display:block}.size-modal__saved-profile-sub{font-size:13px;color:hsla(0,0%,100%,.6);margin-top:8px;display:block}.size-modal__saved-profile-details{display:flex;align-items:center;justify-content:center;gap:8px;font-size:13px;color:hsla(0,0%,100%,.7);flex-wrap:wrap}.size-modal__profile-selector{margin-top:20px;max-width:320px;margin-left:auto;margin-right:auto}.size-modal__profile-selector-label{font-size:12px;color:#888;margin-bottom:12px;text-align:center}.size-modal__profile-selector .size-modal__profile-tabs{justify-content:center}.size-modal__btn--primary{flex:1.5;background:#111;color:#fff}.size-modal__size-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.size-modal__guide-toggle{display:flex;align-items:center;gap:4px;background:none;border:none;cursor:pointer;font-size:12px;color:#666;padding:6px 10px;border-radius:8px;transition:all .2s}.size-modal__guide-toggle:hover{background:#f5f5f5;color:#333}.size-modal__guide-toggle svg{width:16px;height:16px;stroke:currentColor;transition:transform .3s ease}.size-modal__guide-toggle svg.open{transform:rotate(180deg)}.size-modal__guide-content{background:#f8f8f8;border-radius:16px;padding:16px;margin-bottom:20px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;max-height:0;padding-top:0;padding-bottom:0}to{opacity:1;max-height:500px;padding-top:16px;padding-bottom:16px}}.size-modal__guide-table{width:100%}.size-modal__guide-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;padding:10px 0;border-bottom:1px solid #e8e8e8;font-size:13px;color:#555}.size-modal__guide-row:last-child{border-bottom:none}.size-modal__guide-row.header{font-weight:600;color:#888;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.size-modal__guide-row.active{background:hsla(0,0%,7%,.05);border-radius:8px;margin:0 -8px;padding-left:8px;padding-right:8px;font-weight:600;color:#111}.size-modal__guide-note{font-size:11px;color:#999;margin-top:12px;text-align:center}.size-modal__guide-tips{margin-bottom:16px}.size-modal__guide-tip{display:flex;align-items:center;gap:10px;padding:10px 0;font-size:13px;color:#555}.size-modal__guide-tip-num{width:24px;height:24px;background:#111;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.size-modal__fit-options{display:flex;flex-direction:column;gap:12px;max-width:360px;margin:0 auto}.size-modal__fit-card{display:flex;align-items:center;gap:16px;padding:20px;border-radius:16px;border:2px solid #e8e8e8;background:#fff;cursor:pointer;transition:all .2s}.size-modal__fit-card:active{transform:scale(.98)}.size-modal__fit-card.active{border-color:#111;box-shadow:0 4px 16px rgba(0,0,0,.1)}.size-modal__fit-icon{width:40px;height:40px;background:#f5f5f5;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px}.size-modal__fit-card.active .size-modal__fit-icon{background:#111;color:#fff}.size-modal__fit-content{flex:1}.size-modal__fit-label{display:block;font-size:15px;font-weight:600;color:#222}.size-modal__fit-desc{display:block;font-size:12px;color:#888;margin-top:2px}.size-modal__fit-check{width:24px;height:24px;background:#111;border-radius:50%;display:flex;align-items:center;justify-content:center}.size-modal__fit-check svg{width:14px;height:14px;stroke:#fff}.grade-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.grade-modal{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.grade-modal__header{display:flex;align-items:center;justify-content:space-between;padding:20px;border-bottom:1px solid #f0f0f0;position:sticky;top:0;background:#fff;z-index:10}.grade-modal__header h3{font-size:18px;font-weight:700;color:#111}.grade-modal__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer}.grade-modal__close svg{width:20px;height:20px;stroke:#666;stroke-width:2;fill:none}.grade-modal__product{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#f9f9f9}.grade-modal__thumb{width:60px;height:60px;-o-object-fit:cover;object-fit:cover;border-radius:8px;background:#fff}.grade-modal__product-info{display:flex;flex-direction:column;gap:4px}.grade-modal__brand{font-size:12px;color:#888}.grade-modal__name{font-size:14px;font-weight:600;color:#111;line-height:1.3}.grade-modal__section{padding:20px;border-bottom:1px solid #f0f0f0}.grade-modal__section-title{font-size:15px;font-weight:600;color:#111;margin-bottom:16px;display:flex;align-items:center;gap:8px}.grade-modal__section-badge{font-size:11px;font-weight:500;color:#666;background:#f0f0f0;padding:4px 8px;border-radius:4px}.grade-modal__options{display:flex;flex-direction:column;gap:12px}.grade-modal__option{display:flex;flex-direction:column;gap:6px;padding:16px;border:2px solid #e5e5e5;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s;position:relative;text-align:left}.grade-modal__option:hover:not(.disabled){border-color:#ccc}.grade-modal__option.selected{border-color:#111;background:#fafafa}.grade-modal__option.disabled{opacity:.5;cursor:not-allowed}.grade-modal__option-header{display:flex;align-items:center;justify-content:space-between}.grade-modal__option-label{font-size:15px;font-weight:600;color:#111}.grade-modal__option-price{font-size:15px;font-weight:700;color:#111}.grade-modal__option-price--kakao{display:flex;align-items:center;gap:4px;color:#391b1b;background:#fee500;padding:4px 10px;border-radius:6px;font-size:13px}.grade-modal__option-desc{font-size:13px;color:#888}.grade-modal__option-check{position:absolute;top:16px;right:16px;width:24px;height:24px;background:#111;border-radius:50%;display:flex;align-items:center;justify-content:center}.grade-modal__option-check svg{width:14px;height:14px;stroke:#fff;stroke-width:3;fill:none}.grade-modal__loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:20px;color:#888;font-size:14px}.grade-modal__spinner{width:20px;height:20px;border:2px solid #e5e5e5;border-top-color:#111;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.grade-modal__factories{display:flex;flex-direction:column;gap:8px}.grade-modal__factory{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f5f5f5;border-radius:8px}.grade-modal__factory-icon{font-size:18px}.grade-modal__factory-name{font-size:14px;font-weight:500;color:#333}.grade-modal__factory-note{font-size:12px;color:#888;margin-top:8px;padding-left:4px}.grade-modal__no-factory{padding:20px;text-align:center;color:#888;font-size:14px;background:#f9f9f9;border-radius:8px}.grade-modal__summary{padding:16px 20px;background:#f9f9f9}.grade-modal__summary-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;font-size:14px;color:#666}.grade-modal__summary-row--total{padding-top:12px;margin-top:8px;border-top:1px solid #e5e5e5}.grade-modal__summary-grade{font-weight:600;color:#111}.grade-modal__summary-price{font-size:18px;font-weight:700;color:#111}.grade-modal__actions{padding:16px 20px calc(16px + env(safe-area-inset-bottom))}.grade-modal__btn{width:100%;height:52px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.grade-modal__btn--primary{background:#111;color:#fff}.grade-modal__btn--primary:hover:not(:disabled){background:#333}.grade-modal__btn--primary:disabled{background:#ccc;cursor:not-allowed}.grade-modal__btn--kakao{background:#fee500;color:#391b1b}.grade-modal__btn--kakao:hover{background:#f5dc00}