@charset "UTF-8";
/**
 * ALPS 2026 Design System - Modern Luxury Eyewear
 * ══════════════════════════════════════════════════════════════════════════
 * 
 * 컨셉: Refined Luxury meets Modern Minimalism
 * 톤: 프리미엄 아이웨어 브랜드 - 세련되고 신뢰감 있는
 * 
 * @버전: 3.0 (Full Redesign)
 * @최종수정: 2026-01-07
 * @작업내용: 2026 트렌드 기반 전면 리디자인
 *   - 다크모드 지원
 *   - 글래스모피즘 효과
 *   - 대담한 타이포그래피
 *   - 마이크로 인터랙션
 */
/* ══════════════════════════════════════════════════════════════════════════
   1. 색상 시스템 (2026 Premium Color Palette)
   ══════════════════════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════════════════════
   2. 타이포그래피 (Bold & Expressive)
   ══════════════════════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════════════════════
   3. 간격 시스템 (4px Base - Refined Grid)
   ══════════════════════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════════════════════
   4. 테두리 & 그림자 (Modern Elevation)
   ══════════════════════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════════════════════
   5. 트랜지션 & 애니메이션 (Smooth & Refined)
   ══════════════════════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════════════════════
   6. 브레이크포인트 (Mobile-First)
   ══════════════════════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════════════════════
   7. 레이아웃
   ══════════════════════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════════════════════
   8. Z-Index Scale
   ══════════════════════════════════════════════════════════════════════════ */
/* ══════════════════════════════════════════════════════════════════════════
   9. CSS Custom Properties (Light/Dark Theme)
   ══════════════════════════════════════════════════════════════════════════ */
:root {
  --color-primary: #18181B;
  --color-primary-light: #3D3D44;
  --color-primary-dark: #0D0D0F;
  --color-accent: #F59E0B;
  --color-accent-light: #FCD34D;
  --color-bg: #FFFFFF;
  --color-bg-secondary: #FAFAFA;
  --color-bg-tertiary: #F5F5F5;
  --color-bg-elevated: #FFFFFF;
  --color-bg-overlay: rgba(0, 0, 0, 0.5);
  --color-text: #171717;
  --color-text-secondary: #525252;
  --color-text-tertiary: #A3A3A3;
  --color-text-inverse: #FFFFFF;
  --color-text-link: #18181B;
  --color-border: #E5E5E5;
  --color-border-light: #F5F5F5;
  --color-border-focus: #18181B;
  --color-success: #22C55E;
  --color-warning: #F59E0B;
  --color-error: #EF4444;
  --color-info: #3B82F6;
  --primary-color: #18181B;
  --secondary-color: #F59E0B;
  --gray-1-color: #F5F5F5;
  --gray-2-color: #E5E5E5;
  --gray-3-color: #D4D4D4;
  --gray-4-color: #A3A3A3;
  --gray-5-color: #737373;
  --gray-6-color: #525252;
  --dark-1-color: #404040;
  --dark-2-color: #171717;
  --blue-1-color: #D4D4D4;
  --font-display: Pretendard, -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --font-body: Pretendard, -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --space-1: 0.4rem;
  --space-2: 0.8rem;
  --space-3: 1.2rem;
  --space-4: 1.6rem;
  --space-5: 2rem;
  --space-6: 2.4rem;
  --space-8: 3.2rem;
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;
  --shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, 0.04), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.07), 0 8px 10px -6px rgba(0, 0, 0, 0.07);
  --transition-fast: all 150ms cubic-bezier(0, 0, 0.2, 1);
  --transition-base: all 200ms cubic-bezier(0, 0, 0.2, 1);
}

/* ══════════════════════════════════════════════════════════════════════════
   10. Mixins (Utility Functions)
   ══════════════════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════════════════════════════════
   공통 상품 카드 스타일 (2026-02-02)
   - 메인페이지 모든 상품 카드에 적용
   - .good-slide-*, .best-item-* 공통 스타일
   ══════════════════════════════════════════════════════════════════════════ */
.good-slide-img,
.best-item-img {
  border-radius: 0 !important;
}
.good-slide-badge,
.best-item-badge {
  display: none !important;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.95);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}
@keyframes shimmer {
  0% {
    background-position: -200% 0;
  }
  100% {
    background-position: 200% 0;
  }
}
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
/**
 * ALPS 2026 - Common Base Styles
 * ══════════════════════════════════════════════════════════════════════════
 * 
 * Modern Reset + Typography + Utilities
 * 
 * @버전: 3.0
 * @최종수정: 2026-01-07
 */
/* ══════════════════════════════════════════════════════════════════════════
   1. Modern CSS Reset
   ══════════════════════════════════════════════════════════════════════════ */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 62.5%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
}
@media (min-width: 1024px) {
  html {
    font-size: 62.5%;
  }
}

body {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--color-text);
  background: var(--color-bg);
  min-height: 100vh;
  overflow-x: hidden;
}

html {
  scrollbar-gutter: stable;
}

::selection {
  background: rgba(245, 158, 11, 0.2);
  color: #18181B;
}

/* ══════════════════════════════════════════════════════════════════════════
   2. Typography Reset
   ══════════════════════════════════════════════════════════════════════════ */
h1, h2, h3, h4, h5, h6 {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-text);
  letter-spacing: -0.025em;
}

h1 {
  font-size: 3.6rem;
}
@media (min-width: 1024px) {
  h1 {
    font-size: 4.8rem;
  }
}

h2 {
  font-size: 2.8rem;
}
@media (min-width: 1024px) {
  h2 {
    font-size: 3.6rem;
  }
}

h3 {
  font-size: 2.2rem;
}
@media (min-width: 1024px) {
  h3 {
    font-size: 2.8rem;
  }
}

h4 {
  font-size: 1.8rem;
}
@media (min-width: 1024px) {
  h4 {
    font-size: 2.2rem;
  }
}

h5 {
  font-size: 1.6rem;
}
@media (min-width: 1024px) {
  h5 {
    font-size: 1.8rem;
  }
}

h6 {
  font-size: 1.4rem;
}
@media (min-width: 1024px) {
  h6 {
    font-size: 1.6rem;
  }
}

p {
  margin: 0;
  line-height: 1.65;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color 200ms cubic-bezier(0, 0, 0.2, 1), background-color 200ms cubic-bezier(0, 0, 0.2, 1), border-color 200ms cubic-bezier(0, 0, 0.2, 1);
}
a:hover {
  color: var(--color-text-link);
}

strong, b {
  font-weight: 600;
}

em, i {
  font-style: italic;
}

small {
  font-size: 1.2rem;
}

/* ══════════════════════════════════════════════════════════════════════════
   3. List Reset
   ══════════════════════════════════════════════════════════════════════════ */
ul, ol {
  list-style: none;
}

/* ══════════════════════════════════════════════════════════════════════════
   4. Form Reset
   ══════════════════════════════════════════════════════════════════════════ */
button, input, select, textarea {
  font: inherit;
  color: inherit;
  background: transparent;
  border: none;
  outline: none;
}

button {
  cursor: pointer;
}
button:disabled {
  cursor: not-allowed;
}

input::placeholder, textarea::placeholder {
  color: var(--color-text-tertiary);
  opacity: 1;
}
input:focus, textarea:focus {
  outline: none;
}

input[type=search]::-webkit-search-decoration,
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-results-button,
input[type=search]::-webkit-search-results-decoration {
  -webkit-appearance: none;
}

select {
  appearance: none;
  cursor: pointer;
}

/* ══════════════════════════════════════════════════════════════════════════
   5. Media Reset
   ══════════════════════════════════════════════════════════════════════════ */
img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
  height: auto;
}

img {
  border: 0;
  vertical-align: middle;
}

/* ══════════════════════════════════════════════════════════════════════════
   6. Table Reset
   ══════════════════════════════════════════════════════════════════════════ */
table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
}

/* ══════════════════════════════════════════════════════════════════════════
   7. Misc Reset
   ══════════════════════════════════════════════════════════════════════════ */
hr {
  border: none;
  height: 1px;
  background: var(--color-border);
  margin: 2.4rem 0;
}

address {
  font-style: normal;
}

/* ══════════════════════════════════════════════════════════════════════════
   8. Layout System
   ══════════════════════════════════════════════════════════════════════════ */
#wrap,
#app {
  width: 100%;
  min-height: 100vh;
  max-width: none;
  margin: 0 auto;
  background: var(--color-bg);
  position: relative;
}
@media (min-width: 1024px) {
  #wrap,
  #app {
    box-shadow: 0 0 80px rgba(0, 0, 0, 0.03);
  }
}

.container {
  width: 100%;
  max-width: 1024px;
  margin: 0 auto;
  padding: 0 1.6rem;
}
@media (min-width: 768px) {
  .container {
    padding: 0 2.4rem;
  }
}
@media (min-width: 1024px) {
  .container {
    padding: 0 3.2rem;
  }
}
.container--sm {
  max-width: 480px;
}
.container--md {
  max-width: 640px;
}
.container--lg {
  max-width: 768px;
}
.container--fluid {
  max-width: none;
}

.section {
  padding: 4.8rem 0;
}
@media (min-width: 1024px) {
  .section {
    padding: 6.4rem 0;
  }
}
.section--sm {
  padding: 3.2rem 0;
}
@media (min-width: 1024px) {
  .section--sm {
    padding: 4rem 0;
  }
}
.section--lg {
  padding: 6.4rem 0;
}
@media (min-width: 1024px) {
  .section--lg {
    padding: 9.6rem 0;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   9. Section Headers (Modern Style)
   ══════════════════════════════════════════════════════════════════════════ */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2.4rem;
}
@media (min-width: 1024px) {
  .section-header {
    margin-bottom: 3.2rem;
  }
}
.section-header--center {
  justify-content: center;
  text-align: center;
}

.section-title {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.2;
  font-size: 2.2rem;
  color: var(--color-text);
  position: relative;
}
@media (min-width: 1024px) {
  .section-title {
    font-size: 2.8rem;
  }
}
.section-title--accent::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.8rem;
  width: 48px;
  height: 3px;
  background: linear-gradient(90deg, #F59E0B, #FCD34D);
  border-radius: 9999px;
}
.section-title--sm {
  font-size: 1.8rem;
}
@media (min-width: 1024px) {
  .section-title--sm {
    font-size: 2.2rem;
  }
}

.section-subtitle {
  font-size: 1.2rem;
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 500;
  margin-bottom: 0.8rem;
}

.section-link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--color-text-secondary);
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.section-link::after {
  content: "→";
  font-size: 1.4rem;
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
.section-link:hover {
  color: var(--color-text);
}
.section-link:hover::after {
  transform: translateX(4px);
}

/* ══════════════════════════════════════════════════════════════════════════
   10. Buttons
   ══════════════════════════════════════════════════════════════════════════ */
.btn, .social-btn, .cart-btn,
.buy-btn, .ds_btn, .btn-white, .btn-dark, .btn-success, .btn-danger, .btn-ghost, .btn-outline, .btn-secondary, .btn-primary {
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  border-radius: 12px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.btn:disabled, .social-btn:disabled, .cart-btn:disabled,
.buy-btn:disabled, .ds_btn:disabled, .btn-white:disabled, .btn-dark:disabled, .btn-success:disabled, .btn-danger:disabled, .btn-ghost:disabled, .btn-outline:disabled, .btn-secondary:disabled, .btn-primary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.btn, .social-btn, .cart-btn,
.buy-btn, .ds_btn, .btn-white, .btn-dark, .btn-success, .btn-danger, .btn-ghost, .btn-outline, .btn-secondary, .btn-primary {
  height: 44px;
  padding: 0 2rem;
  font-size: 1.2rem;
  border-radius: 12px;
}
.btn--sm {
  height: 36px;
  padding: 0 1.6rem;
  font-size: 1.1rem;
  border-radius: 8px;
}
.btn--lg {
  height: 52px;
  padding: 0 3.2rem;
  font-size: 1.4rem;
  border-radius: 16px;
}
.btn--full {
  width: 100%;
}
.btn--primary {
  background: #18181B;
  color: #FFFFFF;
}
.btn--primary:hover:not(:disabled) {
  background: #27272D;
  transform: translateY(-2px);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
}
.btn--primary:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.04), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
}
.btn--secondary {
  background: transparent;
  color: #18181B;
  border: 1.5px solid #18181B;
}
.btn--secondary:hover:not(:disabled) {
  background: #18181B;
  color: #FFFFFF;
  transform: translateY(-2px);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
}
.btn--ghost {
  background: transparent;
  color: var(--color-text-secondary);
}
.btn--ghost:hover:not(:disabled) {
  background: var(--color-bg-secondary);
  color: var(--color-text);
}
.btn--accent {
  background: linear-gradient(135deg, #F59E0B, #D97706);
  color: #18181B;
  font-weight: 700;
}
.btn--accent:hover:not(:disabled) {
  background: linear-gradient(135deg, #FBBF24, #F59E0B);
  transform: translateY(-2px);
  box-shadow: 0 10px 40px -10px rgba(245, 158, 11, 0.25);
}
.btn--icon {
  width: 44px;
  padding: 0;
}
.btn--icon.btn--sm {
  width: 36px;
}
.btn--icon.btn--lg {
  width: 52px;
}
.btn--rounded {
  border-radius: 9999px;
}
.btn--loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
}
.btn--loading::after {
  content: "";
  position: absolute;
  width: 20px;
  height: 20px;
  border: 2px solid transparent;
  border-top-color: currentColor;
  border-radius: 9999px;
  animation: spin 0.6s linear infinite;
}

/* ══════════════════════════════════════════════════════════════════════════
   11. Form Elements
   ══════════════════════════════════════════════════════════════════════════ */
.input, input[type=text]:not(.no-style),
input[type=email]:not(.no-style),
input[type=password]:not(.no-style),
input[type=tel]:not(.no-style),
input[type=number]:not(.no-style),
input[type=search]:not(.no-style), .search-input input, .textarea, textarea:not(.no-style) {
  width: 100%;
  height: 44px;
  padding: 0 1.6rem;
  font-size: 1.4rem;
  background: var(--color-bg);
  border: 1.5px solid var(--color-border);
  border-radius: 12px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.input:hover:not(:disabled):not(:focus), input[type=text]:hover:not(:disabled):not(:focus):not(.no-style),
input[type=email]:hover:not(:disabled):not(:focus):not(.no-style),
input[type=password]:hover:not(:disabled):not(:focus):not(.no-style),
input[type=tel]:hover:not(:disabled):not(:focus):not(.no-style),
input[type=number]:hover:not(:disabled):not(:focus):not(.no-style),
input[type=search]:hover:not(:disabled):not(:focus):not(.no-style), .search-input input:hover:not(:disabled):not(:focus), .textarea:hover:not(:disabled):not(:focus), textarea:hover:not(:disabled):not(:focus):not(.no-style) {
  border-color: #A3A3A3;
}
.input:focus, input[type=text]:focus:not(.no-style),
input[type=email]:focus:not(.no-style),
input[type=password]:focus:not(.no-style),
input[type=tel]:focus:not(.no-style),
input[type=number]:focus:not(.no-style),
input[type=search]:focus:not(.no-style), .search-input input:focus, .textarea:focus, textarea:focus:not(.no-style) {
  border-color: #18181B;
  box-shadow: 0 0 0 4px rgba(24, 24, 27, 0.08);
}
.input:disabled, input[type=text]:disabled:not(.no-style),
input[type=email]:disabled:not(.no-style),
input[type=password]:disabled:not(.no-style),
input[type=tel]:disabled:not(.no-style),
input[type=number]:disabled:not(.no-style),
input[type=search]:disabled:not(.no-style), .search-input input:disabled, .textarea:disabled, textarea:disabled:not(.no-style) {
  background: var(--color-bg-secondary);
  cursor: not-allowed;
  opacity: 0.6;
}
.input--error {
  border-color: #EF4444;
}
.input--error:focus {
  box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.08);
}
.input--sm {
  height: 36px;
  padding: 0 1.2rem;
  font-size: 1.2rem;
}
.input--lg {
  height: 52px;
  padding: 0 2rem;
  font-size: 1.6rem;
}

.textarea, textarea:not(.no-style) {
  height: auto;
  min-height: 120px;
  padding: 1.2rem 1.6rem;
  resize: vertical;
}

.label {
  display: block;
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--color-text);
  margin-bottom: 0.8rem;
}

.input-group {
  margin-bottom: 2rem;
}

.input-hint {
  display: block;
  font-size: 1.1rem;
  color: var(--color-text-tertiary);
  margin-top: 0.4rem;
}

.input-error {
  display: block;
  font-size: 1.1rem;
  color: #EF4444;
  margin-top: 0.4rem;
}

/* ══════════════════════════════════════════════════════════════════════════
   12. Cards
   ══════════════════════════════════════════════════════════════════════════ */
.card {
  background: var(--color-bg-elevated);
  border-radius: 16px;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.04), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
  border: 1px solid var(--color-border-light);
  padding: 2rem;
}
@media (min-width: 1024px) {
  .card {
    padding: 2.4rem;
  }
}
.card--interactive {
  background: var(--color-bg-elevated);
  border-radius: 16px;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.04), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
  border: 1px solid var(--color-border-light);
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1), transform 300ms cubic-bezier(0.34, 1.56, 0.64, 1);
  cursor: pointer;
}
.card--interactive:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
  border-color: var(--color-border);
}
.card--interactive:active {
  transform: translateY(-2px);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
}
.card--interactive {
  padding: 0;
}
.card--flat {
  box-shadow: none;
  border: 1px solid var(--color-border);
}
.card--elevated {
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
  border: none;
}

/* ══════════════════════════════════════════════════════════════════════════
   13. Badges & Tags
   ══════════════════════════════════════════════════════════════════════════ */
.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.4rem 0.8rem;
  font-size: 1rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-radius: 4px;
  line-height: 1;
}
.badge--primary {
  background: #18181B;
  color: #FFFFFF;
}
.badge--accent {
  background: #F59E0B;
  color: #18181B;
}
.badge--success {
  background: #22C55E;
  color: #FFFFFF;
}
.badge--warning {
  background: #F59E0B;
  color: #18181B;
}
.badge--error {
  background: #EF4444;
  color: #FFFFFF;
}
.badge--new {
  background: #059669;
  color: #FFFFFF;
}
.badge--best {
  background: linear-gradient(135deg, #F59E0B, #D97706);
  color: #18181B;
}
.badge--sale {
  background: #DC2626;
  color: #FFFFFF;
}
.badge--outline {
  background: transparent;
  border: 1px solid currentColor;
}
.badge--rounded {
  border-radius: 9999px;
  padding: 0.4rem 1.2rem;
}
.badge--lg {
  padding: 0.6rem 1.2rem;
  font-size: 1.1rem;
}

.tag {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 1.2rem;
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--color-text-secondary);
  background: var(--color-bg-secondary);
  border-radius: 9999px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.tag:hover {
  background: var(--color-bg-tertiary);
  color: var(--color-text);
}
.tag--active {
  background: #18181B;
  color: #FFFFFF;
}

/* ══════════════════════════════════════════════════════════════════════════
   14. Loading States
   ══════════════════════════════════════════════════════════════════════════ */
.skeleton, .skeleton-image, .skeleton-circle, .skeleton-text {
  background: linear-gradient(90deg, #F5F5F5 25%, #E5E5E5 50%, #F5F5F5 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
  border-radius: 8px;
}
.skeleton--text {
  height: 1.4em;
  width: 100%;
}
.skeleton--circle {
  border-radius: 9999px;
}
.skeleton--card {
  aspect-ratio: 1/1;
}

.spinner {
  width: 24px;
  height: 24px;
  border: 2px solid var(--color-border);
  border-top-color: #18181B;
  border-radius: 9999px;
  animation: spin 0.6s linear infinite;
}
.spinner--sm {
  width: 16px;
  height: 16px;
}
.spinner--lg {
  width: 32px;
  height: 32px;
  border-width: 3px;
}

/* ══════════════════════════════════════════════════════════════════════════
   15. Accessibility
   ══════════════════════════════════════════════════════════════════════════ */
.sr-only,
.sound_only {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

:focus-visible {
  outline: 2px solid #F59E0B;
  outline-offset: 2px;
}

.skip-link {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.skip-link:focus {
  position: fixed;
  top: 1.6rem;
  left: 1.6rem;
  z-index: 9999;
  padding: 1.2rem 2rem;
  background: #18181B;
  color: #FFFFFF;
  font-weight: 600;
  border-radius: 12px;
  clip: auto;
  width: auto;
  height: auto;
}

/* ══════════════════════════════════════════════════════════════════════════
   16. Utility Classes
   ══════════════════════════════════════════════════════════════════════════ */
.hidden {
  display: none !important;
}

.block {
  display: block;
}

.inline-block {
  display: inline-block;
}

.flex {
  display: flex;
}

.inline-flex {
  display: inline-flex;
}

.grid {
  display: grid;
}

.flex-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.flex-col {
  display: flex;
  flex-direction: column;
}

.flex-wrap {
  flex-wrap: wrap;
}

.flex-1 {
  flex: 1;
}

.items-center {
  align-items: center;
}

.items-start {
  align-items: flex-start;
}

.items-end {
  align-items: flex-end;
}

.justify-center {
  justify-content: center;
}

.justify-between {
  justify-content: space-between;
}

.justify-end {
  justify-content: flex-end;
}

.gap-1 {
  gap: 0.4rem;
}

.gap-2 {
  gap: 0.8rem;
}

.gap-3 {
  gap: 1.2rem;
}

.gap-4 {
  gap: 1.6rem;
}

.gap-5 {
  gap: 2rem;
}

.gap-6 {
  gap: 2.4rem;
}

.gap-8 {
  gap: 3.2rem;
}

.text-left {
  text-align: left;
}

.text-center {
  text-align: center;
}

.text-right {
  text-align: right;
}

.text-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.text-clamp-2 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}

.text-clamp-3 {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}

.font-regular {
  font-weight: 400;
}

.font-medium {
  font-weight: 500;
}

.font-semibold {
  font-weight: 600;
}

.font-bold {
  font-weight: 700;
}

.text-primary {
  color: var(--color-text) !important;
}

.text-secondary {
  color: var(--color-text-secondary) !important;
}

.text-muted {
  color: var(--color-text-tertiary) !important;
}

.text-accent {
  color: #F59E0B !important;
}

.text-success {
  color: #22C55E !important;
}

.text-error {
  color: #EF4444 !important;
}

.bg-primary {
  background: var(--color-bg) !important;
}

.bg-secondary {
  background: var(--color-bg-secondary) !important;
}

.bg-tertiary {
  background: var(--color-bg-tertiary) !important;
}

.mt-0 {
  margin-top: 0 !important;
}

.mt-2 {
  margin-top: 0.8rem !important;
}

.mt-4 {
  margin-top: 1.6rem !important;
}

.mt-6 {
  margin-top: 2.4rem !important;
}

.mt-8 {
  margin-top: 3.2rem !important;
}

.mb-0 {
  margin-bottom: 0 !important;
}

.mb-2 {
  margin-bottom: 0.8rem !important;
}

.mb-4 {
  margin-bottom: 1.6rem !important;
}

.mb-6 {
  margin-bottom: 2.4rem !important;
}

.mb-8 {
  margin-bottom: 3.2rem !important;
}

.pt-0 {
  padding-top: 0 !important;
}

.pt-4 {
  padding-top: 1.6rem !important;
}

.pb-0 {
  padding-bottom: 0 !important;
}

.pb-4 {
  padding-bottom: 1.6rem !important;
}

.relative {
  position: relative;
}

.absolute {
  position: absolute;
}

.fixed {
  position: fixed;
}

.sticky {
  position: sticky;
}

.overflow-hidden {
  overflow: hidden;
}

.overflow-auto {
  overflow: auto;
}

.cursor-pointer {
  cursor: pointer;
}

.cursor-not-allowed {
  cursor: not-allowed;
}

@media (min-width: 768px) {
  .mobile-only {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .desktop-only {
    display: none !important;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   17. Animations
   ══════════════════════════════════════════════════════════════════════════ */
.animate-fadeIn {
  animation: fadeIn 300ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.animate-fadeInUp {
  animation: fadeInUp 300ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.animate-scaleIn {
  animation: scaleIn 300ms cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

.delay-1 {
  animation-delay: 0.1s;
}

.delay-2 {
  animation-delay: 0.2s;
}

.delay-3 {
  animation-delay: 0.3s;
}

.delay-4 {
  animation-delay: 0.4s;
}

.delay-5 {
  animation-delay: 0.5s;
}

.delay-6 {
  animation-delay: 0.6s;
}

.delay-7 {
  animation-delay: 0.7s;
}

.delay-8 {
  animation-delay: 0.8s;
}

.delay-9 {
  animation-delay: 0.9s;
}

.delay-10 {
  animation-delay: 1s;
}

/**
 * ALPS 2026 - Premium Header
 * ══════════════════════════════════════════════════════════════════════════
 * 
 * 2026 트렌드 반영:
 * - 미니멀 & 클린 디자인
 * - 글래스모피즘 효과
 * - 부드러운 마이크로 인터랙션
 * - 대담한 로고 중심 레이아웃
 * 
 * @버전: 3.0
 * @최종수정: 2026-01-07
 */
/* ══════════════════════════════════════════════════════════════════════════
   헤더 컨테이너
   ══════════════════════════════════════════════════════════════════════════ */
#header {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: 30;
  background: #fff;
  border-bottom: 1px solid rgba(23, 23, 23, 0.04);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), background 0.2s ease, box-shadow 0.2s ease;
}
#header.scrolled {
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 4px 30px rgba(0, 0, 0, 0.04);
}
#header.scrolled .header-main {
  height: 56px;
}
#header.header-hidden {
  transform: translateY(-100%);
}
#header.header-visible {
  transform: translateY(0);
}

/* ══════════════════════════════════════════════════════════════════════════
   헤더 메인 영역
   ══════════════════════════════════════════════════════════════════════════ */
.header .header-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 60px;
  height: 60px;
  padding: 1.2rem 1.6rem;
  position: relative;
  max-width: none;
  margin: 0 auto;
  transition: height 300ms cubic-bezier(0.25, 0.1, 0.25, 1);
}
@media (min-width: 1024px) {
  .header .header-main {
    height: 72px;
    min-height: 72px;
    padding: 1.6rem 3.2rem;
  }
}
.header .header-main .header-left {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  z-index: 2;
  flex: 0 0 auto;
}
.header .header-main .menu-toggle {
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  position: relative;
  overflow: hidden;
}
@media (min-width: 1024px) {
  .header .header-main .menu-toggle {
    display: none;
  }
}
.header .header-main .menu-toggle::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #F5F5F5;
  opacity: 0;
  transition: opacity 150ms cubic-bezier(0, 0, 0.2, 1);
}
.header .header-main .menu-toggle:hover::before {
  opacity: 1;
}
.header .header-main .menu-toggle:active::before {
  opacity: 1;
  background: #E5E5E5;
}
.header .header-main .menu-toggle img {
  width: 22px;
  height: 22px;
  position: relative;
  z-index: 1;
  opacity: 0.7;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.header .header-main .menu-toggle:hover img {
  opacity: 1;
}
.header .header-main .back_btn {
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.header .header-main .back_btn:hover {
  background: #F5F5F5;
  transform: translateX(-2px);
}
.header .header-main .back_btn img {
  width: 22px;
  height: 22px;
  opacity: 0.7;
}
.header .header-main .logo {
  display: flex;
  align-items: center;
  z-index: 1;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  flex-shrink: 0;
}
.header .header-main .logo a {
  display: flex;
  align-items: center;
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
.header .header-main .logo a:hover {
  transform: scale(1.02);
}
.header .header-main .logo a:active {
  transform: scale(0.98);
}
.header .header-main .logo img {
  height: 26px;
  width: auto;
  display: block;
}
@media (min-width: 768px) {
  .header .header-main .logo img {
    height: 28px;
  }
}
@media (min-width: 1024px) {
  .header .header-main .logo img {
    height: 32px;
  }
}
.header .header-main .desktop-nav {
  display: none;
}
@media (min-width: 1024px) {
  .header .header-main .desktop-nav {
    display: flex;
    align-items: center;
    flex: 1;
    gap: 0.4rem;
  }
}
.header .header-main .desktop-nav .nav-item {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 1.4rem;
  font-weight: 500;
  color: #525252;
  padding: 1rem 1.6rem;
  border-radius: 12px;
  position: relative;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  white-space: nowrap;
}
.header .header-main .desktop-nav .nav-item::after {
  content: "";
  position: absolute;
  bottom: 2px;
  left: 1.6rem;
  right: 1.6rem;
  height: 2px;
  background: #18181B;
  border-radius: 9999px;
  transform: scaleX(0);
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
.header .header-main .desktop-nav .nav-item:hover {
  color: #18181B;
  background: rgba(24, 24, 27, 0.04);
}
.header .header-main .desktop-nav .nav-item.active {
  color: #18181B;
  font-weight: 600;
}
.header .header-main .desktop-nav .nav-item.active::after {
  transform: scaleX(1);
}
.header .header-main .header-right {
  display: flex;
  align-items: center;
  gap: 0.2rem;
  z-index: 2;
  flex: 0 0 auto;
}
@media (min-width: 768px) {
  .header .header-main .header-right {
    gap: 0.4rem;
  }
}
@media (min-width: 1024px) {
  .header .header-main .header-right {
    gap: 0.8rem;
  }
}
.header .header-main .show-desktop {
  display: none !important;
}
@media (min-width: 1024px) {
  .header .header-main .show-desktop {
    display: flex !important;
  }
}
.header .header-main .hide-desktop {
  display: flex !important;
}
@media (min-width: 1024px) {
  .header .header-main .hide-desktop {
    display: none !important;
  }
}
.header .header-main .header-nav {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-right: 16px;
  padding-right: 16px;
  border-right: 1px solid #E5E5E5;
}
.header .header-main .header-nav .nav-link {
  display: inline-block;
  font-size: 13px;
  font-weight: 500;
  color: #525252;
  padding: 8px 12px;
  border-radius: 8px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  white-space: nowrap;
  text-decoration: none;
}
.header .header-main .header-nav .nav-link:hover {
  color: #171717;
  background: #F5F5F5;
}
.header .header-main .header-nav .nav-link.active {
  color: #18181B;
  font-weight: 600;
}
.header .header-main .header-icons {
  display: flex;
  align-items: center;
  gap: 0.2rem;
}
@media (min-width: 768px) {
  .header .header-main .header-icons {
    gap: 0.4rem;
  }
}
.header .header-main .icon-btn {
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  position: relative;
  overflow: hidden;
  color: #525252;
}
.header .header-main .icon-btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #F5F5F5;
  opacity: 0;
  transition: opacity 150ms cubic-bezier(0, 0, 0.2, 1);
}
.header .header-main .icon-btn:hover::before {
  opacity: 1;
}
.header .header-main .icon-btn:active::before {
  opacity: 1;
  background: #E5E5E5;
}
.header .header-main .icon-btn img {
  width: 22px;
  height: 22px;
  opacity: 0.65;
  position: relative;
  z-index: 1;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.header .header-main .icon-btn svg {
  width: 22px;
  height: 22px;
  position: relative;
  z-index: 1;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.header .header-main .icon-btn:hover {
  color: #171717;
}
.header .header-main .icon-btn:hover img {
  opacity: 0.9;
}
.header .header-main .cart-btn {
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  position: relative;
  overflow: visible;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.header .header-main .cart-btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: #F5F5F5;
  border-radius: 12px;
  opacity: 0;
  transition: opacity 150ms cubic-bezier(0, 0, 0.2, 1);
}
.header .header-main .cart-btn:hover::before {
  opacity: 1;
}
.header .header-main .cart-btn img {
  width: 22px;
  height: 22px;
  opacity: 0.65;
  position: relative;
  z-index: 1;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.header .header-main .cart-btn:hover img {
  opacity: 0.9;
}
.header .header-main .cart-btn-cnt {
  position: absolute;
  top: 2px;
  right: 2px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  background: #18181B;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  box-shadow: 0 2px 8px rgba(24, 24, 27, 0.3);
  animation: scaleIn 150ms cubic-bezier(0.34, 1.56, 0.64, 1);
}
.header .header-main .cart-btn-cnt span {
  font-size: 1rem;
  font-weight: 700;
  color: #FFFFFF;
  line-height: 1;
}
.header .header-main .star-review {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 1.2rem;
  font-weight: 700;
  color: #262626;
  padding: 0.4rem 0.8rem;
  background: #FFFBEB;
  border-radius: 8px;
}
.header .header-main .star-review img {
  width: 16px;
  height: 16px;
}

/* ══════════════════════════════════════════════════════════════════════════
   하위 네비게이션 (카테고리 탭) - Premium Style
   ══════════════════════════════════════════════════════════════════════════ */
.nav {
  background: #FFFFFF;
  border-bottom: 1px solid #F5F5F5;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.nav::-webkit-scrollbar {
  display: none;
}
.nav {
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.nav .navigation {
  max-width: none;
  margin: 0 auto;
}
@media (min-width: 1024px) {
  .nav .navigation {
    padding: 0 3.2rem;
  }
}
.nav .navigation .nav-list {
  display: flex;
  align-items: center;
  padding: 0 1.2rem;
}
@media (min-width: 1024px) {
  .nav .navigation .nav-list {
    padding: 0;
    justify-content: center;
    gap: 0.8rem;
  }
}
.nav .navigation .nav-list .list-item {
  flex-shrink: 0;
  font-size: 1.2rem;
  font-weight: 500;
  color: #737373;
  padding: 1.6rem 1.2rem;
  position: relative;
  white-space: nowrap;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .nav .navigation .nav-list .list-item {
    font-size: 1.4rem;
    padding: 1.6rem 1.6rem;
  }
}
@media (min-width: 1024px) {
  .nav .navigation .nav-list .list-item {
    padding: 1.6rem 2rem;
  }
}
.nav .navigation .nav-list .list-item::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 0;
  height: 2px;
  background: #18181B;
  border-radius: 9999px;
  transform: translateX(-50%);
  transition: width 150ms cubic-bezier(0, 0, 0.2, 1);
}
.nav .navigation .nav-list .list-item:hover {
  color: #262626;
}
.nav .navigation .nav-list .list-item:hover::after {
  width: 16px;
}
.nav .navigation .nav-list .list-item.active {
  color: #18181B;
  font-weight: 600;
}
.nav .navigation .nav-list .list-item.active::after {
  width: calc(100% - 2.4rem);
}
@media (min-width: 1024px) {
  .nav .navigation .nav-list .list-item.active::after {
    width: calc(100% - 4rem);
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   모바일 사이드 메뉴 (GNB) - Premium Slide Panel
   ══════════════════════════════════════════════════════════════════════════ */
.gnb {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  max-width: 360px;
  height: 100vh;
  height: 100dvh;
  background: #FFFFFF;
  z-index: 9999;
  overflow-y: auto;
  overflow-x: hidden;
  transform: translateX(-100%);
  transition: transform 400ms cubic-bezier(0, 0, 0.2, 1);
  box-shadow: none;
}
@media (min-width: 1024px) {
  .gnb {
    display: none;
  }
}
.gnb.active {
  transform: translateX(0);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.15);
}
.gnb .gnb-wr {
  min-height: 100%;
  display: flex;
  flex-direction: column;
}
.gnb .gnb-wr .gnb-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 60px;
  padding: 0 1.6rem;
  border-bottom: 1px solid #F5F5F5;
  position: sticky;
  top: 0;
  background: #FFFFFF;
  z-index: 10;
  flex-shrink: 0;
}
.gnb .gnb-wr .gnb-hd .close {
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  font-size: 1.2rem;
  font-weight: 600;
  color: #525252;
  padding: 0.8rem 1.2rem;
  margin-left: -1.2rem;
  border-radius: 12px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.gnb .gnb-wr .gnb-hd .close:hover {
  background: #F5F5F5;
  color: #262626;
}
.gnb .gnb-wr .gnb-hd .close img {
  width: 20px;
  height: 20px;
  opacity: 0.7;
}
.gnb .gnb-wr .gnb-hd .gnb-tit {
  font-size: 1.6rem;
  font-weight: 700;
  color: #171717;
  letter-spacing: -0.025em;
}
.gnb .gnb-wr .gnb-hd .cart-btn {
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  padding: 0.8rem;
  border-radius: 8px;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.gnb .gnb-wr .gnb-hd .cart-btn:hover {
  background: #F5F5F5;
}
.gnb .gnb-wr .gnb-hd .cart-btn img {
  width: 24px;
  opacity: 0.7;
}
.gnb .gnb-wr .gnb-ls {
  flex: 1;
}
.gnb .gnb-wr .gnb-ls .inner {
  padding-bottom: 8rem;
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item {
  border-bottom: 1px solid #FAFAFA;
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item.active {
  background: #FCFCFC;
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item.active .item-inner .arr-img {
  transform: rotate(180deg);
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item.active .sub-ls {
  display: block;
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item .item-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 2rem 2rem;
  font-size: 1.6rem;
  font-weight: 600;
  color: #262626;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item .item-inner:hover {
  background: #FAFAFA;
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item .item-inner:active {
  background: #F5F5F5;
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item .item-inner .arr-img {
  width: 20px;
  height: 20px;
  opacity: 0.4;
  transition: transform 200ms cubic-bezier(0, 0, 0.2, 1);
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item .sub-ls {
  display: none;
  padding: 0.8rem 0 2rem;
  background: #FCFCFC;
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item .sub-ls .sub-item a {
  display: block;
  padding: 1.2rem 2rem 1.2rem 3.2rem;
  font-size: 1.4rem;
  font-weight: 500;
  color: #737373;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  position: relative;
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item .sub-ls .sub-item a::before {
  content: "";
  position: absolute;
  left: 2rem;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 4px;
  background: #D4D4D4;
  border-radius: 9999px;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item .sub-ls .sub-item a:hover {
  color: #262626;
  background: #FAFAFA;
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item .sub-ls .sub-item a:hover::before {
  background: #737373;
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item .sub-ls .sub-item.active a {
  color: #18181B;
  font-weight: 600;
}
.gnb .gnb-wr .gnb-ls .inner .gnb-item .sub-ls .sub-item.active a::before {
  background: #18181B;
  width: 6px;
  height: 6px;
}
.gnb .gnb-banner {
  padding: 2rem;
  flex-shrink: 0;
}
.gnb .gnb-banner .img-wr {
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
}
.gnb .gnb-banner .img-wr img {
  width: 100%;
  display: block;
}

.gnb-bg {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(23, 23, 23, 0.4);
  z-index: 9998;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  transition: opacity 400ms cubic-bezier(0, 0, 0.2, 1);
}
.gnb-bg.active {
  display: block;
  opacity: 1;
}

/* ══════════════════════════════════════════════════════════════════════════
   검색 패널 - Premium Search Experience
   ══════════════════════════════════════════════════════════════════════════ */
.check {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  max-width: 100%;
  height: 100vh;
  height: 100dvh;
  background: #FFFFFF;
  z-index: 50;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 400ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .check {
    max-width: 480px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.15);
  }
}
/* 데스크탑에서 검색 패널 완전 숨김 - 모바일 전용 */
@media (min-width: 1024px) {
  .check {
    display: none !important;
  }
}
.check.active {
  transform: translateX(0);
}
.check .chc-wr {
  min-height: 100%;
  display: flex;
  flex-direction: column;
}
.check .chc-wr .chc-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 60px;
  padding: 0 1.6rem;
  border-bottom: 1px solid #F5F5F5;
  position: sticky;
  top: 0;
  background: #FFFFFF;
  z-index: 10;
}
@media (min-width: 768px) {
  .check .chc-wr .chc-hd {
    height: 72px;
    padding: 0 2.4rem;
  }
}
.check .chc-wr .chc-hd .close {
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  font-size: 1.2rem;
  font-weight: 600;
  color: #525252;
  padding: 0.8rem 1.2rem;
  border-radius: 12px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.check .chc-wr .chc-hd .close:hover {
  background: #F5F5F5;
  color: #262626;
}
.check .chc-wr .chc-hd .chc-tit {
  font-size: 1.6rem;
  font-weight: 700;
  color: #171717;
  letter-spacing: -0.025em;
}
.check .chc-wr .input-box {
  padding: 2rem;
}
@media (min-width: 768px) {
  .check .chc-wr .input-box {
    padding: 2.4rem;
  }
}
.check .chc-wr .input-box .search-form {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  background: #FAFAFA;
  border: 2px solid transparent;
  border-radius: 16px;
  padding: 0 1.6rem;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.check .chc-wr .input-box .search-form:focus-within {
  background: #FFFFFF;
  border-color: #18181B;
  box-shadow: 0 0 0 4px rgba(24, 24, 27, 0.08);
}
.check .chc-wr .input-box .search-form .search-contents {
  flex: 1;
  height: 52px;
  border: none;
  outline: none;
  background: transparent;
  font-size: 1.6rem;
  font-weight: 500;
  color: #171717;
}
.check .chc-wr .input-box .search-form .search-contents::placeholder {
  color: #A3A3A3;
  font-weight: 400;
}
.check .chc-wr .input-box .search-form .search-btn {
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: #18181B;
  border-radius: 12px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.check .chc-wr .input-box .search-form .search-btn:hover {
  background: #27272D;
  transform: scale(1.05);
}
.check .chc-wr .input-box .search-form .search-btn:active {
  transform: scale(0.98);
}
.check .chc-wr .input-box .search-form .search-btn img {
  width: 22px;
  height: 22px;
  filter: brightness(0) invert(1);
}
.check .chc-wr .keywords {
  padding: 0 2rem;
  flex: 1;
}
@media (min-width: 768px) {
  .check .chc-wr .keywords {
    padding: 0 2.4rem;
  }
}
.check .chc-wr .keywords .kw-wr {
  margin-top: 1.6rem;
}
.check .chc-wr .keywords .kw-wr:first-child {
  margin-top: 0;
}
.check .chc-wr .keywords .kw-wr .kw-tit {
  font-size: 1.2rem;
  font-weight: 600;
  color: #737373;
  text-transform: uppercase;
  letter-spacing: 0.025em;
  margin-bottom: 1.2rem;
}
.check .chc-wr .keywords .kw-wr .kw-ls {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}
.check .chc-wr .keywords .kw-wr .kw-ls .kw-item {
  display: inline-block;
  padding: 0.8rem 1.6rem;
  font-size: 1.2rem;
  font-weight: 500;
  color: #404040;
  background: #FFFFFF;
  border: 1.5px solid #E5E5E5;
  border-radius: 9999px;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.check .chc-wr .keywords .kw-wr .kw-ls .kw-item:hover {
  border-color: #18181B;
  color: #18181B;
  background: rgba(24, 24, 27, 0.04);
  transform: translateY(-1px);
}
.check .chc-wr .keywords .kw-wr .kw-ls .kw-item:active {
  transform: translateY(0);
}

/* ══════════════════════════════════════════════════════════════════════════
   상단 프로모션 배너 - Premium Announcement Bar
   ══════════════════════════════════════════════════════════════════════════ */
.line_banner {
  background: #18181B;
  padding: 1rem 1.6rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.line_banner::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255, 255, 255, 0.05) 50%, transparent 100%);
  pointer-events: none;
}
.line_banner a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  font-size: 1.1rem;
  font-weight: 600;
  color: #FFFFFF;
  position: relative;
  z-index: 1;
}
@media (min-width: 768px) {
  .line_banner a {
    font-size: 1.2rem;
  }
}
.line_banner a .icon_kakao {
  width: 16px;
  height: 16px;
}
.line_banner a::after {
  content: "→";
  margin-left: 0.4rem;
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
.line_banner a:hover::after {
  transform: translateX(4px);
}

.kakao_banner {
  background: #FEE500;
  padding: 1rem 1.6rem;
  text-align: center;
}
.kakao_banner a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  font-size: 1.1rem;
  font-weight: 700;
  color: #171717;
}
@media (min-width: 768px) {
  .kakao_banner a {
    font-size: 1.2rem;
  }
}
.kakao_banner a .icon_kakao {
  width: 18px;
  height: 18px;
}

/* ══════════════════════════════════════════════════════════════════════════
   페이지별 특수 헤더 스타일
   ══════════════════════════════════════════════════════════════════════════ */
.header--transparent #header {
  background: transparent;
  border-bottom-color: transparent;
}
.header--transparent #header.scrolled {
  background: #fff;
  border-bottom-color: rgba(23, 23, 23, 0.06);
}

.header--dark #header {
  background: #171717;
  border-bottom-color: rgba(255, 255, 255, 0.05);
}
.header--dark #header .header-main .logo img {
  filter: brightness(0) invert(1);
}
.header--dark #header .header-main .menu-toggle img,
.header--dark #header .header-main .icon-btn img,
.header--dark #header .header-main .cart-btn img,
.header--dark #header .header-main .back_btn img {
  filter: brightness(0) invert(1);
  opacity: 0.9;
}
.header--dark #header .nav {
  background: #171717;
  border-bottom-color: rgba(255, 255, 255, 0.08);
}
.header--dark #header .nav .navigation .nav-list .list-item {
  color: #A3A3A3;
}
.header--dark #header .nav .navigation .nav-list .list-item:hover {
  color: #FFFFFF;
}
.header--dark #header .nav .navigation .nav-list .list-item.active {
  color: #FFFFFF;
}
.header--dark #header .nav .navigation .nav-list .list-item.active::after {
  background: #FFFFFF;
}

/*** header ***/
#blank_header {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  z-index: 998;
  bottom: 1px solid var(--primary-color);
  max-width: 640px;
  width: 100%;
}

.blank_header .header-main {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 11px 12px;
  position: relative;
  background-color: #fff;
  box-sizing: border-box;
  transition: 0.4s;
  border-bottom: 1px solid var(--primary-color);
}
.blank_header .header-main .back_btn {
  background-color: transparent;
  border: 0;
}
.blank_header .header-main .logo {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.blank_header .header-main .logo img {
  width: 93px;
}
.blank_header .header-main .cart-btn {
  display: inline-block;
  width: 24px;
}
.blank_header .header-main .cart-btn img {
  width: 100%;
  vertical-align: middle;
}
.blank_header .header-main .back {
  display: inline-block;
  width: 24px;
}
.blank_header .header-main .back img {
  width: 100%;
  vertical-align: middle;
}

/**
 * ALPS 2026 - Premium Footer & Bottom Navigation
 * ══════════════════════════════════════════════════════════════════════════
 * 
 * 2026 트렌드 반영:
 * - 미니멀한 정보 배치
 * - 마이크로 인터랙션
 * - 글래스모피즘 하단 네비
 * - 대담한 타이포그래피
 * 
 * @버전: 3.0
 * @최종수정: 2026-01-07
 */
/* ══════════════════════════════════════════════════════════════════════════
   하단 네비게이션 (모바일 전용) - Premium Glass Style
   ══════════════════════════════════════════════════════════════════════════ */
#bottom_nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 25;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid rgba(23, 23, 23, 0.06);
  padding-bottom: env(safe-area-inset-bottom, 0);
}
@media (min-width: 1024px) {
  #bottom_nav {
    display: none !important;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
  }
}
#bottom_nav .quick-nav {
  height: 56px;
}
#bottom_nav .quick-nav .quick-list {
  display: flex;
  align-items: stretch;
  justify-content: space-around;
  height: 100%;
}
#bottom_nav .quick-nav .quick-list > li {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}
#bottom_nav .quick-nav .quick-list .quick-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.2rem;
  width: 100%;
  height: 100%;
  padding: 0.8rem 0;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  position: relative;
}
#bottom_nav .quick-nav .quick-list .quick-item::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 44px;
  height: 44px;
  background: #F5F5F5;
  border-radius: 12px;
  transform: translate(-50%, -50%) scale(0);
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
#bottom_nav .quick-nav .quick-list .quick-item:active::before {
  transform: translate(-50%, -50%) scale(1);
}
#bottom_nav .quick-nav .quick-list .quick-item svg {
  width: 22px;
  height: 22px;
  color: #A3A3A3;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
  position: relative;
  z-index: 1;
}
#bottom_nav .quick-nav .quick-list .quick-item .icon-box {
  position: relative;
  width: 24px;
  height: 24px;
  z-index: 1;
}
#bottom_nav .quick-nav .quick-list .quick-item .icon-box img {
  position: absolute;
  top: 0;
  left: 0;
  width: 24px;
  height: 24px;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
#bottom_nav .quick-nav .quick-list .quick-item .icon-box img:first-child {
  opacity: 0.5;
}
#bottom_nav .quick-nav .quick-list .quick-item .icon-box img:nth-child(2) {
  opacity: 0;
}
#bottom_nav .quick-nav .quick-list .quick-item .quick-cate {
  font-size: 1rem;
  font-weight: 500;
  color: #A3A3A3;
  line-height: 1;
  position: relative;
  z-index: 1;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
#bottom_nav .quick-nav .quick-list .quick-item:hover svg, #bottom_nav .quick-nav .quick-list .quick-item.active svg {
  color: #18181B;
}
#bottom_nav .quick-nav .quick-list .quick-item:hover .icon-box img:first-child, #bottom_nav .quick-nav .quick-list .quick-item.active .icon-box img:first-child {
  opacity: 0;
}
#bottom_nav .quick-nav .quick-list .quick-item:hover .icon-box img:nth-child(2), #bottom_nav .quick-nav .quick-list .quick-item.active .icon-box img:nth-child(2) {
  opacity: 1;
}
#bottom_nav .quick-nav .quick-list .quick-item:hover .quick-cate, #bottom_nav .quick-nav .quick-list .quick-item.active .quick-cate {
  color: #18181B;
}
#bottom_nav .quick-nav .quick-list .quick-item.active .quick-cate {
  font-weight: 700;
  color: #18181B;
}
#bottom_nav .quick-nav .quick-list .quick-item.active::after {
  content: "";
  position: absolute;
  top: 4px;
  left: 50%;
  transform: translateX(-50%);
  width: 4px;
  height: 4px;
  background: #18181B;
  border-radius: 9999px;
}

/* ══════════════════════════════════════════════════════════════════════════
   하단 여백 (네비게이션 영역 확보)
   ══════════════════════════════════════════════════════════════════════════ */
.has-bottom-nav {
  padding-bottom: calc(56px + env(safe-area-inset-bottom, 0));
}
@media (min-width: 1024px) {
  .has-bottom-nav {
    padding-bottom: 0;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   푸터 - Premium Minimal Design
   ══════════════════════════════════════════════════════════════════════════ */
#footer {
  background: #FCFCFC;
  margin-bottom: calc(56px + env(safe-area-inset-bottom, 0));
  border-top: 1px solid #F5F5F5;
}
@media (min-width: 1024px) {
  #footer {
    margin-bottom: 0;
  }
}

.footer {
  padding: 4rem 0 3.2rem;
}
@media (min-width: 1024px) {
  .footer {
    padding: 6.4rem 0 4.8rem;
  }
}
.footer .footer-inner, .footer .ft-wr {
  max-width: none;
  margin: 0 auto;
  padding: 0 2rem;
}
@media (min-width: 768px) {
  .footer .footer-inner, .footer .ft-wr {
    padding: 0 2.4rem;
  }
}
@media (min-width: 1024px) {
  .footer .footer-inner, .footer .ft-wr {
    padding: 0 3.2rem;
  }
}
.footer .footer-top {
  display: flex;
  flex-direction: column;
  gap: 3.2rem;
  padding-bottom: 3.2rem;
  border-bottom: 1px solid #F5F5F5;
}
@media (min-width: 1024px) {
  .footer .footer-top {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    gap: 4.8rem;
    padding-bottom: 4rem;
  }
}
.footer .footer-top .footer-logo img {
  height: 26px;
  width: auto;
  opacity: 0.7;
  transition: opacity 150ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 1024px) {
  .footer .footer-top .footer-logo img {
    height: 30px;
  }
}
.footer .footer-top .footer-logo img:hover {
  opacity: 1;
}
.footer .footer-top .footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 2.4rem;
}
@media (min-width: 1024px) {
  .footer .footer-top .footer-links {
    gap: 3.2rem;
  }
}
.footer .footer-top .footer-links a {
  font-size: 1.2rem;
  font-weight: 500;
  color: #525252;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
  position: relative;
}
@media (min-width: 1024px) {
  .footer .footer-top .footer-links a {
    font-size: 1.4rem;
  }
}
.footer .footer-top .footer-links a::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 1px;
  background: #18181B;
  transition: width 150ms cubic-bezier(0, 0, 0.2, 1);
}
.footer .footer-top .footer-links a:hover {
  color: #18181B;
}
.footer .footer-top .footer-links a:hover::after {
  width: 100%;
}
.footer .footer-top .footer-links a.privacy {
  font-weight: 700;
  color: #262626;
}
.footer .footer-middle {
  padding: 3.2rem 0;
}
@media (min-width: 1024px) {
  .footer .footer-middle {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 4.8rem;
    padding: 4rem 0;
  }
}
.footer .footer-middle .company-info {
  margin-bottom: 3.2rem;
}
@media (min-width: 1024px) {
  .footer .footer-middle .company-info {
    margin-bottom: 0;
  }
}
.footer .footer-middle .company-info .company-name {
  font-size: 1.6rem;
  font-weight: 700;
  color: #262626;
  margin-bottom: 1.6rem;
}
@media (min-width: 1024px) {
  .footer .footer-middle .company-info .company-name {
    font-size: 1.8rem;
    margin-bottom: 2rem;
  }
}
.footer .footer-middle .company-info .info-list {
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}
.footer .footer-middle .company-info .info-list li {
  font-size: 1.1rem;
  color: #737373;
  line-height: 1.65;
}
@media (min-width: 768px) {
  .footer .footer-middle .company-info .info-list li {
    font-size: 1.2rem;
  }
}
.footer .footer-middle .company-info .info-list li strong {
  font-weight: 600;
  color: #525252;
  margin-right: 0.6rem;
}
.footer .footer-middle .company-info .info-list li a {
  color: inherit;
  transition: color 150ms cubic-bezier(0, 0, 0.2, 1);
}
.footer .footer-middle .company-info .info-list li a:hover {
  color: #18181B;
}
.footer .footer-middle .cs-info {
  background: #FFFFFF;
  padding: 2.4rem;
  border-radius: 20px;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.04), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
}
@media (min-width: 1024px) {
  .footer .footer-middle .cs-info {
    padding: 3.2rem;
  }
}
.footer .footer-middle .cs-info .cs-title {
  font-size: 1.2rem;
  font-weight: 600;
  color: #737373;
  text-transform: uppercase;
  letter-spacing: 0.025em;
  margin-bottom: 1.2rem;
}
@media (min-width: 1024px) {
  .footer .footer-middle .cs-info .cs-title {
    font-size: 1.2rem;
    margin-bottom: 1.6rem;
  }
}
.footer .footer-middle .cs-info .cs-number {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 3.6rem;
  font-weight: 800;
  color: #18181B;
  letter-spacing: -0.05em;
  margin-bottom: 1.2rem;
}
@media (min-width: 1024px) {
  .footer .footer-middle .cs-info .cs-number {
    font-size: 4.2rem;
  }
}
.footer .footer-middle .cs-info .cs-number a {
  color: inherit;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.footer .footer-middle .cs-info .cs-number a:hover {
  color: #0D0D0F;
}
.footer .footer-middle .cs-info .cs-time {
  font-size: 1.2rem;
  color: #737373;
  line-height: 1.65;
}
@media (min-width: 768px) {
  .footer .footer-middle .cs-info .cs-time br {
    display: none;
  }
}
.footer .footer-middle .cs-info .cs-time strong {
  font-weight: 600;
  color: #525252;
}
.footer .footer-middle .cs-info .cs-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  margin-top: 2rem;
  padding: 1.2rem 2rem;
  font-size: 1.2rem;
  font-weight: 600;
  color: #404040;
  background: #FAFAFA;
  border-radius: 12px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.footer .footer-middle .cs-info .cs-btn:hover {
  background: #18181B;
  color: #FFFFFF;
  transform: translateY(-1px);
}
.footer .footer-middle .cs-info .cs-btn:active {
  transform: translateY(0);
}
.footer .footer-bottom {
  padding-top: 3.2rem;
  border-top: 1px solid #F5F5F5;
}
@media (min-width: 1024px) {
  .footer .footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 4rem;
  }
}
.footer .footer-bottom .copyright {
  font-size: 1.1rem;
  color: #A3A3A3;
  line-height: 1.65;
}
@media (min-width: 768px) {
  .footer .footer-bottom .copyright {
    font-size: 1.2rem;
  }
}
.footer .footer-bottom .social-links {
  display: flex;
  gap: 0.8rem;
  margin-top: 2rem;
}
@media (min-width: 1024px) {
  .footer .footer-bottom .social-links {
    margin-top: 0;
    gap: 1.2rem;
  }
}
.footer .footer-bottom .social-links a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  background: #F5F5F5;
  border-radius: 9999px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 1024px) {
  .footer .footer-bottom .social-links a {
    width: 44px;
    height: 44px;
  }
}
.footer .footer-bottom .social-links a:hover {
  background: #18181B;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(24, 24, 27, 0.25);
}
.footer .footer-bottom .social-links a:hover img {
  filter: brightness(0) invert(1);
}
.footer .footer-bottom .social-links a:active {
  transform: translateY(0);
}
.footer .footer-bottom .social-links a img {
  width: 20px;
  height: 20px;
  opacity: 0.6;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.footer .footer-bottom .social-links a.instagram:hover {
  background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
}
.footer .footer-bottom .social-links a.kakao:hover {
  background: #FEE500;
}
.footer .footer-bottom .social-links a.kakao:hover img {
  filter: none;
}
.footer .footer-bottom .social-links a.naver:hover {
  background: #03C75A;
}
.footer .footer-bottom .social-links a.youtube:hover {
  background: #FF0000;
}
.footer .footer-bottom .trust-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 1.6rem;
  margin-top: 2.4rem;
}
@media (min-width: 1024px) {
  .footer .footer-bottom .trust-badges {
    margin-top: 0;
  }
}
.footer .footer-bottom .trust-badges img {
  height: 28px;
  opacity: 0.5;
  filter: grayscale(100%);
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.footer .footer-bottom .trust-badges img:hover {
  opacity: 1;
  filter: grayscale(0%);
}

/* ══════════════════════════════════════════════════════════════════════════
   간단한 푸터 (모바일 최적화)
   ══════════════════════════════════════════════════════════════════════════ */
.footer-simple {
  background: #FCFCFC;
  padding: 3.2rem 2rem;
  text-align: center;
  border-top: 1px solid #F5F5F5;
}
@media (min-width: 1024px) {
  .footer-simple {
    padding: 4rem;
  }
}
.footer-simple .footer-logo {
  margin-bottom: 2rem;
}
.footer-simple .footer-logo img {
  height: 22px;
  opacity: 0.5;
}
.footer-simple .footer-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.4rem 1.6rem;
  margin-bottom: 2rem;
}
.footer-simple .footer-links a {
  font-size: 1.1rem;
  color: #737373;
  transition: color 150ms cubic-bezier(0, 0, 0.2, 1);
}
.footer-simple .footer-links a:hover {
  color: #18181B;
}
.footer-simple .footer-links .divider {
  color: #E5E5E5;
}
.footer-simple .copyright {
  font-size: 1.1rem;
  color: #A3A3A3;
}

/* ══════════════════════════════════════════════════════════════════════════
   레거시 호환 (기존 클래스명 지원)
   ══════════════════════════════════════════════════════════════════════════ */
.ft-hd {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
  padding-bottom: 2.4rem;
  border-bottom: 1px solid #F5F5F5;
}
@media (min-width: 1024px) {
  .ft-hd {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 3.2rem;
    padding-bottom: 3.2rem;
  }
}
.ft-hd .img-box a {
  display: block;
}
.ft-hd .img-box a img {
  height: 26px;
  width: auto;
  opacity: 0.7;
}
@media (min-width: 1024px) {
  .ft-hd .img-box a img {
    height: 30px;
  }
}
.ft-hd .ft-link {
  display: flex;
  flex-wrap: wrap;
  gap: 1.6rem 2rem;
}
.ft-hd .ft-link li a {
  font-size: 1.2rem;
  font-weight: 500;
  color: #525252;
  transition: color 150ms cubic-bezier(0, 0, 0.2, 1);
}
.ft-hd .ft-link li a:hover {
  color: #18181B;
}

.copy {
  font-size: 1.1rem;
  color: #737373;
  line-height: 1.65;
  padding-top: 2.4rem;
}
@media (min-width: 768px) {
  .copy {
    font-size: 1.2rem;
  }
}
@media (min-width: 1024px) {
  .copy br {
    display: none;
  }
}

#quick-btn-wrap {
  position: fixed;
  z-index: 900;
  right: 20px;
  bottom: 80px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-flow: column;
}
#quick-btn-wrap .quick-btn {
  width: 35px;
  height: 35px;
  cursor: pointer;
}
#quick-btn-wrap .quick-btn.btn-down {
  margin-top: 8px;
}
#quick-btn-wrap .quick-btn.btn-up {
  margin-top: 8px;
}

/**
 * ALPS 2026 - Premium Button System
 * ══════════════════════════════════════════════════════════════════════════
 * 
 * 버튼 디자인 시스템:
 * - 일관된 높이와 패딩
 * - 명확한 상태 변화
 * - 접근성 고려
 * - 마이크로 인터랙션
 * 
 * @버전: 3.0
 * @최종수정: 2026-01-07
 */
/* ══════════════════════════════════════════════════════════════════════════
   버튼 베이스
   ══════════════════════════════════════════════════════════════════════════ */
.btn, .social-btn, .cart-btn,
.buy-btn, .ds_btn, .btn-white, .btn-dark, .btn-success, .btn-danger, .btn-ghost, .btn-outline, .btn-secondary, .btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  box-sizing: border-box;
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  border: none;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
  height: 48px;
  padding: 0 2.4rem;
  font-size: 1.2rem;
  border-radius: 12px;
}
.btn:focus-visible, .social-btn:focus-visible, .cart-btn:focus-visible,
.buy-btn:focus-visible, .ds_btn:focus-visible, .btn-white:focus-visible, .btn-dark:focus-visible, .btn-success:focus-visible, .btn-danger:focus-visible, .btn-ghost:focus-visible, .btn-outline:focus-visible, .btn-secondary:focus-visible, .btn-primary:focus-visible {
  outline: 2px solid #18181B;
  outline-offset: 2px;
}
.btn:disabled, .social-btn:disabled, .cart-btn:disabled,
.buy-btn:disabled, .ds_btn:disabled, .btn-white:disabled, .btn-dark:disabled, .btn-success:disabled, .btn-danger:disabled, .btn-ghost:disabled, .btn-outline:disabled, .btn-secondary:disabled, .btn-primary:disabled, .btn.disabled, .disabled.social-btn, .disabled.cart-btn,
.disabled.buy-btn, .disabled.ds_btn, .disabled.btn-white, .disabled.btn-dark, .disabled.btn-success, .disabled.btn-danger, .disabled.btn-ghost, .disabled.btn-outline, .disabled.btn-secondary, .disabled.btn-primary {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}
.btn .btn-icon, .social-btn .btn-icon, .cart-btn .btn-icon,
.buy-btn .btn-icon, .ds_btn .btn-icon, .btn-white .btn-icon, .btn-dark .btn-icon, .btn-success .btn-icon, .btn-danger .btn-icon, .btn-ghost .btn-icon, .btn-outline .btn-icon, .btn-secondary .btn-icon, .btn-primary .btn-icon {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════════════════════
   버튼 변형 (Variants)
   ══════════════════════════════════════════════════════════════════════════ */
.btn-primary {
  background: #18181B;
  color: #FFFFFF;
}
.btn-primary:hover {
  background: #0D0D0F;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(24, 24, 27, 0.25);
}
.btn-primary:active {
  background: #0D0D0F;
  transform: translateY(0);
  box-shadow: none;
}

.btn-secondary {
  background: #F5F5F5;
  color: #404040;
}
.btn-secondary:hover {
  background: #E5E5E5;
  transform: translateY(-1px);
}
.btn-secondary:active {
  background: #D4D4D4;
  transform: translateY(0);
}

.btn-outline {
  background: transparent;
  color: #404040;
  border: 1.5px solid #E5E5E5;
}
.btn-outline:hover {
  border-color: #18181B;
  color: #18181B;
  background: rgba(24, 24, 27, 0.04);
  transform: translateY(-1px);
}
.btn-outline:active {
  background: rgba(24, 24, 27, 0.08);
  transform: translateY(0);
}

.btn-ghost {
  background: transparent;
  color: #525252;
}
.btn-ghost:hover {
  background: #F5F5F5;
  color: #262626;
}
.btn-ghost:active {
  background: #E5E5E5;
}

.btn-danger {
  background: #EF4444;
  color: #FFFFFF;
}
.btn-danger:hover {
  background: #DC2626;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(239, 68, 68, 0.25);
}
.btn-danger:active {
  background: #B91C1C;
  transform: translateY(0);
}

.btn-success {
  background: #22C55E;
  color: #FFFFFF;
}
.btn-success:hover {
  background: #16A34A;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(34, 197, 94, 0.25);
}
.btn-success:active {
  background: #15803D;
  transform: translateY(0);
}

.btn-dark {
  background: #171717;
  color: #FFFFFF;
}
.btn-dark:hover {
  background: #262626;
  transform: translateY(-1px);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
}
.btn-dark:active {
  background: #404040;
  transform: translateY(0);
}

.btn-white {
  background: #FFFFFF;
  color: #171717;
}
.btn-white:hover {
  background: rgba(255, 255, 255, 0.9);
  transform: translateY(-1px);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
}
.btn-white:active {
  background: rgba(255, 255, 255, 0.85);
  transform: translateY(0);
}

/* ══════════════════════════════════════════════════════════════════════════
   버튼 크기 (Sizes)
   ══════════════════════════════════════════════════════════════════════════ */
.btn-xs {
  height: 32px;
  padding: 0 1.2rem;
  font-size: 1.1rem;
  border-radius: 8px;
}
.btn-xs .btn-icon {
  width: 14px;
  height: 14px;
}

.btn-sm {
  height: 40px;
  padding: 0 1.6rem;
  font-size: 1.2rem;
  border-radius: 8px;
}
.btn-sm .btn-icon {
  width: 16px;
  height: 16px;
}

.btn-md {
  height: 48px;
  padding: 0 2.4rem;
  font-size: 1.2rem;
  border-radius: 12px;
}

.btn-lg {
  height: 56px;
  padding: 0 3.2rem;
  font-size: 1.4rem;
  border-radius: 16px;
}
.btn-lg .btn-icon {
  width: 20px;
  height: 20px;
}

.btn-xl {
  height: 64px;
  padding: 0 4rem;
  font-size: 1.6rem;
  font-weight: 700;
  border-radius: 16px;
}
.btn-xl .btn-icon {
  width: 24px;
  height: 24px;
}

/* ══════════════════════════════════════════════════════════════════════════
   버튼 레이아웃 (Layout)
   ══════════════════════════════════════════════════════════════════════════ */
.btn-block {
  width: 100%;
}

.btn-pill {
  border-radius: 9999px;
}

.btn-icon-only {
  padding: 0;
}
.btn-icon-only.btn-xs {
  width: 32px;
}
.btn-icon-only.btn-sm {
  width: 40px;
}
.btn-icon-only.btn-md, .btn-icon-only:not([class*=btn-]) {
  width: 48px;
}
.btn-icon-only.btn-lg {
  width: 56px;
}
.btn-icon-only.btn-xl {
  width: 64px;
}

/* ══════════════════════════════════════════════════════════════════════════
   버튼 그룹
   ══════════════════════════════════════════════════════════════════════════ */
.btn-group {
  display: flex;
  gap: 0.8rem;
}
.btn-group.btn-group-full .btn, .btn-group.btn-group-full .social-btn, .btn-group.btn-group-full .cart-btn,
.btn-group.btn-group-full .buy-btn, .btn-group.btn-group-full .ds_btn, .btn-group.btn-group-full .btn-primary, .btn-group.btn-group-full .btn-secondary, .btn-group.btn-group-full .btn-outline, .btn-group.btn-group-full .btn-ghost, .btn-group.btn-group-full .btn-danger, .btn-group.btn-group-full .btn-success, .btn-group.btn-group-full .btn-dark, .btn-group.btn-group-full .btn-white {
  flex: 1;
}
.btn-group.btn-group-vertical {
  flex-direction: column;
}
.btn-group.btn-group-vertical .btn, .btn-group.btn-group-vertical .social-btn, .btn-group.btn-group-vertical .cart-btn,
.btn-group.btn-group-vertical .buy-btn, .btn-group.btn-group-vertical .ds_btn, .btn-group.btn-group-vertical .btn-primary, .btn-group.btn-group-vertical .btn-secondary, .btn-group.btn-group-vertical .btn-outline, .btn-group.btn-group-vertical .btn-ghost, .btn-group.btn-group-vertical .btn-danger, .btn-group.btn-group-vertical .btn-success, .btn-group.btn-group-vertical .btn-dark, .btn-group.btn-group-vertical .btn-white {
  width: 100%;
}

/* ══════════════════════════════════════════════════════════════════════════
   레거시 호환 (기존 클래스)
   ══════════════════════════════════════════════════════════════════════════ */
.ds_btn {
  width: 100%;
  height: 50px;
  font-size: 1.4rem;
  font-weight: 600;
  border-radius: 12px;
}
.ds_btn.type1 {
  background: transparent;
  color: #18181B;
  border: 2px solid #18181B;
}
.ds_btn.type1:hover {
  background: #18181B;
  color: #FFFFFF;
  transform: translateY(-1px);
}
.ds_btn.type2 {
  background: #F5F5F5;
  color: #525252;
  border: 1px solid #E5E5E5;
}
.ds_btn.type2:hover {
  background: #E5E5E5;
  transform: translateY(-1px);
}
.ds_btn.type3 {
  background: #18181B;
  color: #FFFFFF;
  border: none;
}
.ds_btn.type3:hover {
  background: #0D0D0F;
  transform: translateY(-1px);
}
.ds_btn.type4 {
  background: #171717;
  color: #FFFFFF;
  border: none;
}
.ds_btn.type4:hover {
  background: #262626;
  transform: translateY(-1px);
}

.cart-btn,
.buy-btn {
  width: 100%;
  height: 56px;
  font-size: 1.4rem;
  font-weight: 700;
  border-radius: 16px;
}

.cart-btn {
  background: #F5F5F5;
  color: #262626;
}
.cart-btn:hover {
  background: #E5E5E5;
  transform: translateY(-1px);
}

.buy-btn {
  background: #18181B;
  color: #FFFFFF;
}
.buy-btn:hover {
  background: #0D0D0F;
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(24, 24, 27, 0.25);
}

.qty-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: #FAFAFA;
  border: 1px solid #E5E5E5;
  border-radius: 8px;
  color: #404040;
  font-size: 1.6rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.qty-btn:hover {
  background: #F5F5F5;
  border-color: #D4D4D4;
}
.qty-btn:active {
  background: #E5E5E5;
}
.qty-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.like-btn,
.wish-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
  border-radius: 9999px;
  border: none;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.like-btn img,
.wish-btn img {
  width: 22px;
  height: 22px;
  opacity: 0.6;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.like-btn:hover,
.wish-btn:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
}
.like-btn:hover img,
.wish-btn:hover img {
  opacity: 1;
}
.like-btn.active,
.wish-btn.active {
  background: #DC2626;
}
.like-btn.active img,
.wish-btn.active img {
  filter: brightness(0) invert(1);
  opacity: 1;
}

.social-btn {
  width: 100%;
  height: 52px;
  font-size: 1.4rem;
  font-weight: 600;
  border-radius: 16px;
  gap: 1.2rem;
}
.social-btn img {
  width: 24px;
  height: 24px;
}
.social-btn.kakao {
  background: #FEE500;
  color: #191919;
}
.social-btn.kakao:hover {
  background: #E6CE00;
}
.social-btn.naver {
  background: #03C75A;
  color: #FFFFFF;
}
.social-btn.naver:hover {
  background: #02B351;
}
.social-btn.google {
  background: #FFFFFF;
  color: #404040;
  border: 1px solid #E5E5E5;
}
.social-btn.google:hover {
  background: #FAFAFA;
}
.social-btn.apple {
  background: #171717;
  color: #FFFFFF;
}
.social-btn.apple:hover {
  background: #262626;
}

.fab {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background: #18181B;
  color: #FFFFFF;
  border-radius: 9999px;
  border: none;
  cursor: pointer;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.fab:hover {
  transform: scale(1.05);
  box-shadow: 0 8px 32px rgba(24, 24, 27, 0.3);
}
.fab:active {
  transform: scale(0.98);
}
.fab img {
  width: 24px;
  height: 24px;
}

/**
 * ALPS 2026 - Premium Input System
 * ══════════════════════════════════════════════════════════════════════════
 * 
 * 입력 필드 디자인 시스템:
 * - 일관된 스타일링
 * - 명확한 상태 표시
 * - 접근성 고려
 * - 반응형 대응
 * 
 * @버전: 3.0
 * @최종수정: 2026-01-07
 */
/* ══════════════════════════════════════════════════════════════════════════
   입력 필드 베이스
   ══════════════════════════════════════════════════════════════════════════ */
.input, input[type=text]:not(.no-style),
input[type=email]:not(.no-style),
input[type=password]:not(.no-style),
input[type=tel]:not(.no-style),
input[type=number]:not(.no-style),
input[type=search]:not(.no-style), .search-input input, .textarea, textarea:not(.no-style) {
  display: block;
  width: 100%;
  height: 52px;
  padding: 0 1.6rem;
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  color: #171717;
  background: #FFFFFF;
  border: 1.5px solid #E5E5E5;
  border-radius: 16px;
  outline: none;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  box-sizing: border-box;
}
.input::placeholder, input[type=text]:not(.no-style)::placeholder,
input[type=email]:not(.no-style)::placeholder,
input[type=password]:not(.no-style)::placeholder,
input[type=tel]:not(.no-style)::placeholder,
input[type=number]:not(.no-style)::placeholder,
input[type=search]:not(.no-style)::placeholder, .search-input input::placeholder, .textarea::placeholder, textarea:not(.no-style)::placeholder {
  color: #A3A3A3;
  font-weight: 400;
}
.input:focus, input[type=text]:focus:not(.no-style),
input[type=email]:focus:not(.no-style),
input[type=password]:focus:not(.no-style),
input[type=tel]:focus:not(.no-style),
input[type=number]:focus:not(.no-style),
input[type=search]:focus:not(.no-style), .search-input input:focus, .textarea:focus, textarea:focus:not(.no-style) {
  border-color: #18181B;
  box-shadow: 0 0 0 4px rgba(24, 24, 27, 0.08);
}
.input:hover:not(:focus):not(:disabled), input[type=text]:hover:not(:focus):not(:disabled):not(.no-style),
input[type=email]:hover:not(:focus):not(:disabled):not(.no-style),
input[type=password]:hover:not(:focus):not(:disabled):not(.no-style),
input[type=tel]:hover:not(:focus):not(:disabled):not(.no-style),
input[type=number]:hover:not(:focus):not(:disabled):not(.no-style),
input[type=search]:hover:not(:focus):not(:disabled):not(.no-style), .search-input input:hover:not(:focus):not(:disabled), .textarea:hover:not(:focus):not(:disabled), textarea:hover:not(:focus):not(:disabled):not(.no-style) {
  border-color: #D4D4D4;
}
.input:disabled, input[type=text]:disabled:not(.no-style),
input[type=email]:disabled:not(.no-style),
input[type=password]:disabled:not(.no-style),
input[type=tel]:disabled:not(.no-style),
input[type=number]:disabled:not(.no-style),
input[type=search]:disabled:not(.no-style), .search-input input:disabled, .textarea:disabled, textarea:disabled:not(.no-style) {
  background: #FAFAFA;
  color: #A3A3A3;
  cursor: not-allowed;
}
.input:read-only, input[type=text]:read-only:not(.no-style),
input[type=email]:read-only:not(.no-style),
input[type=password]:read-only:not(.no-style),
input[type=tel]:read-only:not(.no-style),
input[type=number]:read-only:not(.no-style),
input[type=search]:read-only:not(.no-style), .search-input input:read-only, .textarea:read-only, textarea:read-only:not(.no-style) {
  background: #FAFAFA;
  color: #525252;
  cursor: default;
}
.input:read-only:focus, input[type=text]:read-only:focus:not(.no-style),
input[type=email]:read-only:focus:not(.no-style),
input[type=password]:read-only:focus:not(.no-style),
input[type=tel]:read-only:focus:not(.no-style),
input[type=number]:read-only:focus:not(.no-style),
input[type=search]:read-only:focus:not(.no-style), .search-input input:read-only:focus, .textarea:read-only:focus, textarea:read-only:focus:not(.no-style) {
  border-color: #E5E5E5;
  box-shadow: none;
}

/* ══════════════════════════════════════════════════════════════════════════
   입력 필드 크기
   ══════════════════════════════════════════════════════════════════════════ */
.input-sm {
  height: 44px;
  padding: 0 1.2rem;
  font-size: 1.2rem;
  border-radius: 12px;
}

.input-lg {
  height: 60px;
  padding: 0 2rem;
  font-size: 1.6rem;
  border-radius: 16px;
}

/* ══════════════════════════════════════════════════════════════════════════
   입력 필드 상태
   ══════════════════════════════════════════════════════════════════════════ */
.input-error,
.input.error,
input.error[type=text]:not(.no-style),
input.error[type=email]:not(.no-style),
input.error[type=password]:not(.no-style),
input.error[type=tel]:not(.no-style),
input.error[type=number]:not(.no-style),
input.error[type=search]:not(.no-style),
.search-input input.error,
.error.textarea,
textarea.error:not(.no-style) {
  border-color: #EF4444;
}
.input-error:focus,
.input.error:focus,
input.error[type=text]:focus:not(.no-style),
input.error[type=email]:focus:not(.no-style),
input.error[type=password]:focus:not(.no-style),
input.error[type=tel]:focus:not(.no-style),
input.error[type=number]:focus:not(.no-style),
input.error[type=search]:focus:not(.no-style),
.search-input input.error:focus,
.error.textarea:focus,
textarea.error:focus:not(.no-style) {
  border-color: #EF4444;
  box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.08);
}

.input-success,
.input.success,
input.success[type=text]:not(.no-style),
input.success[type=email]:not(.no-style),
input.success[type=password]:not(.no-style),
input.success[type=tel]:not(.no-style),
input.success[type=number]:not(.no-style),
input.success[type=search]:not(.no-style),
.search-input input.success,
.success.textarea,
textarea.success:not(.no-style) {
  border-color: #22C55E;
}
.input-success:focus,
.input.success:focus,
input.success[type=text]:focus:not(.no-style),
input.success[type=email]:focus:not(.no-style),
input.success[type=password]:focus:not(.no-style),
input.success[type=tel]:focus:not(.no-style),
input.success[type=number]:focus:not(.no-style),
input.success[type=search]:focus:not(.no-style),
.search-input input.success:focus,
.success.textarea:focus,
textarea.success:focus:not(.no-style) {
  border-color: #22C55E;
  box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.08);
}

/* ══════════════════════════════════════════════════════════════════════════
   폼 그룹
   ══════════════════════════════════════════════════════════════════════════ */
.form-group {
  margin-bottom: 2rem;
}
.form-group:last-child {
  margin-bottom: 0;
}

.form-label {
  display: block;
  font-size: 1.2rem;
  font-weight: 600;
  color: #404040;
  margin-bottom: 0.8rem;
}
.form-label .required {
  color: #EF4444;
  margin-left: 0.4rem;
}

.form-help {
  margin-top: 0.8rem;
  font-size: 1.2rem;
  color: #737373;
  line-height: 1.65;
}

.form-error {
  margin-top: 0.8rem;
  font-size: 1.2rem;
  color: #EF4444;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.form-error::before {
  content: "!";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  background: #EF4444;
  color: #FFFFFF;
  font-size: 1rem;
  font-weight: 700;
  border-radius: 9999px;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════════════════════
   입력 필드 래퍼 (아이콘 포함)
   ══════════════════════════════════════════════════════════════════════════ */
.input-wrapper {
  position: relative;
}
.input-wrapper .input, .input-wrapper input[type=text]:not(.no-style),
.input-wrapper input[type=email]:not(.no-style),
.input-wrapper input[type=password]:not(.no-style),
.input-wrapper input[type=tel]:not(.no-style),
.input-wrapper input[type=number]:not(.no-style),
.input-wrapper input[type=search]:not(.no-style), .input-wrapper .search-input input, .search-input .input-wrapper input, .input-wrapper .textarea, .input-wrapper textarea:not(.no-style) {
  padding-right: 4.8rem;
}
.input-wrapper.has-icon-left .input, .input-wrapper.has-icon-left input[type=text]:not(.no-style),
.input-wrapper.has-icon-left input[type=email]:not(.no-style),
.input-wrapper.has-icon-left input[type=password]:not(.no-style),
.input-wrapper.has-icon-left input[type=tel]:not(.no-style),
.input-wrapper.has-icon-left input[type=number]:not(.no-style),
.input-wrapper.has-icon-left input[type=search]:not(.no-style), .input-wrapper.has-icon-left .search-input input, .search-input .input-wrapper.has-icon-left input, .input-wrapper.has-icon-left .textarea, .input-wrapper.has-icon-left textarea:not(.no-style) {
  padding-left: 4.8rem;
  padding-right: 1.6rem;
}
.input-wrapper.has-icon-left .input-icon-left {
  position: absolute;
  left: 1.6rem;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  color: #A3A3A3;
  pointer-events: none;
}
.input-wrapper .input-icon-right {
  position: absolute;
  right: 1.6rem;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  color: #A3A3A3;
}
.input-wrapper .input-clear {
  position: absolute;
  right: 1.6rem;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: #E5E5E5;
  border-radius: 9999px;
  border: none;
  cursor: pointer;
  opacity: 0;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.input-wrapper .input-clear::before, .input-wrapper .input-clear::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 2px;
  background: #737373;
  border-radius: 1px;
}
.input-wrapper .input-clear::before {
  transform: rotate(45deg);
}
.input-wrapper .input-clear::after {
  transform: rotate(-45deg);
}
.input-wrapper .input-clear:hover {
  background: #D4D4D4;
}
.input-wrapper .input:focus + .input-clear, .input-wrapper input[type=text]:focus:not(.no-style) + .input-clear,
.input-wrapper input[type=email]:focus:not(.no-style) + .input-clear,
.input-wrapper input[type=password]:focus:not(.no-style) + .input-clear,
.input-wrapper input[type=tel]:focus:not(.no-style) + .input-clear,
.input-wrapper input[type=number]:focus:not(.no-style) + .input-clear,
.input-wrapper input[type=search]:focus:not(.no-style) + .input-clear, .input-wrapper .search-input input:focus + .input-clear, .search-input .input-wrapper input:focus + .input-clear, .input-wrapper .textarea:focus + .input-clear, .input-wrapper textarea:focus:not(.no-style) + .input-clear,
.input-wrapper .input:not(:placeholder-shown) + .input-clear,
.input-wrapper input[type=text]:not(:placeholder-shown):not(.no-style) + .input-clear,
.input-wrapper input[type=email]:not(:placeholder-shown):not(.no-style) + .input-clear,
.input-wrapper input[type=password]:not(:placeholder-shown):not(.no-style) + .input-clear,
.input-wrapper input[type=tel]:not(:placeholder-shown):not(.no-style) + .input-clear,
.input-wrapper input[type=number]:not(:placeholder-shown):not(.no-style) + .input-clear,
.input-wrapper input[type=search]:not(:placeholder-shown):not(.no-style) + .input-clear,
.input-wrapper .search-input input:not(:placeholder-shown) + .input-clear,
.search-input .input-wrapper input:not(:placeholder-shown) + .input-clear,
.input-wrapper .textarea:not(:placeholder-shown) + .input-clear,
.input-wrapper textarea:not(:placeholder-shown):not(.no-style) + .input-clear {
  opacity: 1;
}

/* ══════════════════════════════════════════════════════════════════════════
   텍스트에어리어
   ══════════════════════════════════════════════════════════════════════════ */
.textarea, textarea:not(.no-style) {
  display: block;
  width: 100%;
  min-height: 120px;
  padding: 1.6rem;
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  color: #171717;
  background: #FFFFFF;
  border: 1.5px solid #E5E5E5;
  border-radius: 16px;
  outline: none;
  resize: vertical;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  line-height: 1.65;
  box-sizing: border-box;
}
.textarea::placeholder, textarea:not(.no-style)::placeholder {
  color: #A3A3A3;
}
.textarea:focus, textarea:focus:not(.no-style) {
  border-color: #18181B;
  box-shadow: 0 0 0 4px rgba(24, 24, 27, 0.08);
}
.textarea:hover:not(:focus):not(:disabled), textarea:hover:not(:focus):not(:disabled):not(.no-style) {
  border-color: #D4D4D4;
}
.textarea:disabled, textarea:disabled:not(.no-style) {
  background: #FAFAFA;
  color: #A3A3A3;
  cursor: not-allowed;
}

/* ══════════════════════════════════════════════════════════════════════════
   셀렉트 박스
   ══════════════════════════════════════════════════════════════════════════ */
.select, select:not(.no-style) {
  display: block;
  width: 100%;
  height: 52px;
  padding: 0 4rem 0 1.6rem;
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 1.4rem;
  font-weight: 400;
  color: #171717;
  background: #FFFFFF;
  border: 1.5px solid #E5E5E5;
  border-radius: 16px;
  outline: none;
  cursor: pointer;
  appearance: none;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  box-sizing: border-box;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237A8799' d='M6 8.5L1.5 4h9L6 8.5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1.6rem center;
  background-size: 12px;
}
.select:focus, select:focus:not(.no-style) {
  border-color: #18181B;
  box-shadow: 0 0 0 4px rgba(24, 24, 27, 0.08);
}
.select:hover:not(:focus):not(:disabled), select:hover:not(:focus):not(:disabled):not(.no-style) {
  border-color: #D4D4D4;
}
.select:disabled, select:disabled:not(.no-style) {
  background-color: #FAFAFA;
  color: #A3A3A3;
  cursor: not-allowed;
}
.select option, select:not(.no-style) option {
  font-weight: 400;
  padding: 0.8rem;
}

/* ══════════════════════════════════════════════════════════════════════════
   체크박스
   ══════════════════════════════════════════════════════════════════════════ */
.checkbox {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  cursor: pointer;
}
.checkbox input[type=checkbox] {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.checkbox input[type=checkbox] + .checkbox-box {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: #FFFFFF;
  border: 2px solid #D4D4D4;
  border-radius: 8px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  flex-shrink: 0;
}
.checkbox input[type=checkbox] + .checkbox-box::after {
  content: "";
  width: 10px;
  height: 6px;
  border: 2px solid #FFFFFF;
  border-top: none;
  border-right: none;
  transform: rotate(-45deg) scale(0);
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
.checkbox input[type=checkbox]:checked + .checkbox-box {
  background: #18181B;
  border-color: #18181B;
}
.checkbox input[type=checkbox]:checked + .checkbox-box::after {
  transform: rotate(-45deg) scale(1);
}
.checkbox input[type=checkbox]:focus + .checkbox-box {
  box-shadow: 0 0 0 4px rgba(24, 24, 27, 0.12);
}
.checkbox input[type=checkbox]:disabled + .checkbox-box {
  background: #F5F5F5;
  border-color: #E5E5E5;
  cursor: not-allowed;
}
.checkbox input[type=checkbox]:disabled:checked + .checkbox-box {
  background: #D4D4D4;
  border-color: #D4D4D4;
}
.checkbox .checkbox-label {
  font-size: 1.2rem;
  font-weight: 500;
  color: #404040;
  line-height: 1.35;
}
.checkbox .checkbox-label a {
  color: #18181B;
  text-decoration: underline;
}

/* ══════════════════════════════════════════════════════════════════════════
   라디오 버튼
   ══════════════════════════════════════════════════════════════════════════ */
.radio {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  cursor: pointer;
}
.radio input[type=radio] {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.radio input[type=radio] + .radio-dot {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: #FFFFFF;
  border: 2px solid #D4D4D4;
  border-radius: 9999px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  flex-shrink: 0;
}
.radio input[type=radio] + .radio-dot::after {
  content: "";
  width: 10px;
  height: 10px;
  background: #FFFFFF;
  border-radius: 9999px;
  transform: scale(0);
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
.radio input[type=radio]:checked + .radio-dot {
  border-color: #18181B;
}
.radio input[type=radio]:checked + .radio-dot::after {
  background: #18181B;
  transform: scale(1);
}
.radio input[type=radio]:focus + .radio-dot {
  box-shadow: 0 0 0 4px rgba(24, 24, 27, 0.12);
}
.radio input[type=radio]:disabled + .radio-dot {
  background: #F5F5F5;
  border-color: #E5E5E5;
  cursor: not-allowed;
}
.radio .radio-label {
  font-size: 1.2rem;
  font-weight: 500;
  color: #404040;
}

/* ══════════════════════════════════════════════════════════════════════════
   토글 스위치
   ══════════════════════════════════════════════════════════════════════════ */
.toggle {
  display: inline-flex;
  align-items: center;
  gap: 1.2rem;
  cursor: pointer;
}
.toggle input[type=checkbox] {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.toggle input[type=checkbox] + .toggle-track {
  position: relative;
  width: 48px;
  height: 28px;
  background: #E5E5E5;
  border-radius: 9999px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.toggle input[type=checkbox] + .toggle-track::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 22px;
  height: 22px;
  background: #FFFFFF;
  border-radius: 9999px;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.04), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.toggle input[type=checkbox]:checked + .toggle-track {
  background: #18181B;
}
.toggle input[type=checkbox]:checked + .toggle-track::after {
  left: 23px;
}
.toggle input[type=checkbox]:focus + .toggle-track {
  box-shadow: 0 0 0 4px rgba(24, 24, 27, 0.12);
}
.toggle input[type=checkbox]:disabled + .toggle-track {
  opacity: 0.5;
  cursor: not-allowed;
}
.toggle .toggle-label {
  font-size: 1.2rem;
  font-weight: 500;
  color: #404040;
}

/* ══════════════════════════════════════════════════════════════════════════
   검색 입력 필드
   ══════════════════════════════════════════════════════════════════════════ */
.search-input {
  position: relative;
}
.search-input input {
  padding-left: 4.8rem;
  padding-right: 1.6rem;
  border-radius: 9999px;
  background: #FAFAFA;
  border-color: transparent;
}
.search-input input:focus {
  background: #FFFFFF;
  border-color: #18181B;
}
.search-input .search-icon {
  position: absolute;
  left: 1.6rem;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  color: #A3A3A3;
  pointer-events: none;
}
.search-input .search-btn {
  position: absolute;
  right: 0.4rem;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: #18181B;
  border-radius: 9999px;
  border: none;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.search-input .search-btn img {
  width: 20px;
  height: 20px;
  filter: brightness(0) invert(1);
}
.search-input .search-btn:hover {
  background: #0D0D0F;
  transform: translateY(-50%) scale(1.05);
}

/* ══════════════════════════════════════════════════════════════════════════
   파일 업로드
   ══════════════════════════════════════════════════════════════════════════ */
.file-upload .file-input {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.file-upload .file-label {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  min-height: 140px;
  padding: 2.4rem;
  background: #FAFAFA;
  border: 2px dashed #E5E5E5;
  border-radius: 16px;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.file-upload .file-label:hover {
  background: #FFFFFF;
  border-color: #18181B;
}
.file-upload .file-label:hover .file-icon {
  transform: translateY(-4px);
}
.file-upload .file-label .file-icon {
  width: 48px;
  height: 48px;
  color: #A3A3A3;
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
.file-upload .file-label .file-text {
  text-align: center;
}
.file-upload .file-label .file-text .primary {
  font-size: 1.4rem;
  font-weight: 600;
  color: #404040;
  margin-bottom: 0.4rem;
}
.file-upload .file-label .file-text .secondary {
  font-size: 1.2rem;
  color: #A3A3A3;
}
.file-upload .file-list {
  margin-top: 1.2rem;
}
.file-upload .file-list .file-item {
  display: flex;
  align-items: center;
  gap: 1.2rem;
  padding: 1.2rem 1.6rem;
  background: #FAFAFA;
  border-radius: 12px;
  margin-bottom: 0.8rem;
}
.file-upload .file-list .file-item:last-child {
  margin-bottom: 0;
}
.file-upload .file-list .file-item .file-name {
  flex: 1;
  font-size: 1.2rem;
  font-weight: 500;
  color: #404040;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.file-upload .file-list .file-item .file-size {
  font-size: 1.1rem;
  color: #A3A3A3;
  flex-shrink: 0;
}
.file-upload .file-list .file-item .file-remove {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: #E5E5E5;
  border-radius: 9999px;
  border: none;
  cursor: pointer;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
  flex-shrink: 0;
}
.file-upload .file-list .file-item .file-remove:hover {
  background: #EF4444;
  color: #FFFFFF;
}

/* ══════════════════════════════════════════════════════════════════════════
   레거시 호환
   ══════════════════════════════════════════════════════════════════════════ */
/**
 * ALPS 2026 - Premium Pagination
 * ══════════════════════════════════════════════════════════════════════════
 * 
 * 페이지네이션 디자인:
 * - 미니멀한 숫자 기반 디자인
 * - 명확한 현재 페이지 표시
 * - 접근성 고려
 * - 반응형 대응
 * 
 * @버전: 3.0
 * @최종수정: 2026-01-07
 */
/* ══════════════════════════════════════════════════════════════════════════
   페이지네이션 래퍼
   ══════════════════════════════════════════════════════════════════════════ */
.pg_wrap {
  padding: 4rem 0 2.4rem;
}
@media (min-width: 1024px) {
  .pg_wrap {
    padding: 4.8rem 0 3.2rem;
  }
}

.pg {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
}
@media (min-width: 768px) {
  .pg {
    gap: 0.6rem;
  }
}
.pg .sound_only {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.pg a,
.pg strong {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 0.8rem;
  font-size: 1.2rem;
  font-weight: 500;
  text-decoration: none;
  border-radius: 12px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .pg a,
  .pg strong {
    min-width: 40px;
    height: 40px;
    font-size: 1.4rem;
  }
}
.pg .pg_page {
  color: #737373;
  background: transparent;
}
.pg .pg_page:hover {
  color: #262626;
  background: #F5F5F5;
}
.pg .pg_page:active {
  background: #E5E5E5;
}
.pg .pg_current {
  color: #FFFFFF;
  background: #18181B;
  font-weight: 700;
}
.pg .pg_current:hover {
  background: #18181B;
}
.pg .pg_start,
.pg .pg_prev,
.pg .pg_next,
.pg .pg_end {
  color: #A3A3A3;
  background: transparent;
  font-size: 1.4rem;
}
.pg .pg_start:hover,
.pg .pg_prev:hover,
.pg .pg_next:hover,
.pg .pg_end:hover {
  color: #404040;
  background: #F5F5F5;
}
.pg .pg_start:active,
.pg .pg_prev:active,
.pg .pg_next:active,
.pg .pg_end:active {
  background: #E5E5E5;
}
.pg .pg_start,
.pg .pg_prev,
.pg .pg_next,
.pg .pg_end {
  text-indent: 0;
  background-image: none;
}
.pg .pg_start img,
.pg .pg_prev img,
.pg .pg_next img,
.pg .pg_end img {
  width: 14px;
  height: 14px;
  opacity: 0.5;
  transition: opacity 150ms cubic-bezier(0, 0, 0.2, 1);
}
.pg .pg_start:hover img,
.pg .pg_prev:hover img,
.pg .pg_next:hover img,
.pg .pg_end:hover img {
  opacity: 0.8;
}
.pg .pg_start::before {
  content: "«";
  font-weight: 700;
}
.pg .pg_prev::before {
  content: "‹";
  font-weight: 700;
  font-size: 1.6rem;
}
.pg .pg_next::before {
  content: "›";
  font-weight: 700;
  font-size: 1.6rem;
}
.pg .pg_end::before {
  content: "»";
  font-weight: 700;
}

/* ══════════════════════════════════════════════════════════════════════════
   페이지네이션 변형
   ══════════════════════════════════════════════════════════════════════════ */
.pg--outline .pg_page {
  border: 1px solid #E5E5E5;
}
.pg--outline .pg_page:hover {
  border-color: #D4D4D4;
}
.pg--outline .pg_current {
  border: 1px solid #18181B;
}
.pg--outline .pg_start,
.pg--outline .pg_prev,
.pg--outline .pg_next,
.pg--outline .pg_end {
  border: 1px solid #E5E5E5;
}
.pg--outline .pg_start:hover,
.pg--outline .pg_prev:hover,
.pg--outline .pg_next:hover,
.pg--outline .pg_end:hover {
  border-color: #D4D4D4;
}

.pg--rounded .pg a,
.pg--rounded .pg strong {
  border-radius: 9999px;
}

.pg--compact {
  gap: 0.2rem;
}
.pg--compact a,
.pg--compact strong {
  min-width: 32px;
  height: 32px;
  font-size: 1.2rem;
}

.pg--dark .pg_page {
  color: #A3A3A3;
}
.pg--dark .pg_page:hover {
  color: #FFFFFF;
  background: rgba(255, 255, 255, 0.1);
}
.pg--dark .pg_current {
  background: #FFFFFF;
  color: #171717;
}
.pg--dark .pg_start,
.pg--dark .pg_prev,
.pg--dark .pg_next,
.pg--dark .pg_end {
  color: #737373;
}
.pg--dark .pg_start:hover,
.pg--dark .pg_prev:hover,
.pg--dark .pg_next:hover,
.pg--dark .pg_end:hover {
  color: #FFFFFF;
  background: rgba(255, 255, 255, 0.1);
}

/* ══════════════════════════════════════════════════════════════════════════
   심플 페이지네이션 (이전/다음만)
   ══════════════════════════════════════════════════════════════════════════ */
.pg-simple {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.6rem;
  padding: 3.2rem 0;
}
.pg-simple .pg-info {
  font-size: 1.2rem;
  font-weight: 500;
  color: #737373;
}
.pg-simple .pg-info .current {
  font-weight: 700;
  color: #262626;
}
.pg-simple .pg-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: #FFFFFF;
  border: 1px solid #E5E5E5;
  border-radius: 12px;
  color: #525252;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.pg-simple .pg-btn:hover {
  background: #FAFAFA;
  border-color: #D4D4D4;
  color: #262626;
}
.pg-simple .pg-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.pg-simple .pg-btn img {
  width: 18px;
  height: 18px;
}

/* ══════════════════════════════════════════════════════════════════════════
   더보기 버튼 (Load More)
   ══════════════════════════════════════════════════════════════════════════ */
.load-more {
  text-align: center;
  padding: 3.2rem 0;
}
.load-more .load-more-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  height: 48px;
  padding: 0 3.2rem;
  background: #FFFFFF;
  color: #404040;
  font-size: 1.2rem;
  font-weight: 600;
  border: 1.5px solid #E5E5E5;
  border-radius: 9999px;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .load-more .load-more-btn {
    height: 52px;
    padding: 0 4rem;
    font-size: 1.4rem;
  }
}
.load-more .load-more-btn:hover {
  background: #FAFAFA;
  border-color: #18181B;
  color: #18181B;
  transform: translateY(-1px);
}
.load-more .load-more-btn:active {
  transform: translateY(0);
}
.load-more .load-more-btn.loading {
  pointer-events: none;
}
.load-more .load-more-btn.loading .load-more-icon {
  animation: spin 1s linear infinite;
}
.load-more .load-more-btn .load-more-icon {
  width: 18px;
  height: 18px;
}
.load-more .load-more-info {
  margin-top: 1.2rem;
  font-size: 1.2rem;
  color: #A3A3A3;
}
.load-more .load-more-info .current {
  font-weight: 600;
  color: #525252;
}

/* ══════════════════════════════════════════════════════════════════════════
   무한 스크롤 인디케이터
   ══════════════════════════════════════════════════════════════════════════ */
.infinite-scroll-loader {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3.2rem 0;
  gap: 1.2rem;
}
.infinite-scroll-loader .spinner {
  width: 24px;
  height: 24px;
  border: 2px solid #E5E5E5;
  border-top-color: #18181B;
  border-radius: 9999px;
  animation: spin 0.8s linear infinite;
}
.infinite-scroll-loader .text {
  font-size: 1.2rem;
  font-weight: 500;
  color: #737373;
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
/* ══════════════════════════════════════════════════════════════════════════
   Swiper 페이지네이션 커스텀
   ══════════════════════════════════════════════════════════════════════════ */
.swiper-pagination .swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  background: #D4D4D4;
  opacity: 1;
  margin: 0 4px !important;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.swiper-pagination .swiper-pagination-bullet-active {
  width: 24px;
  background: #18181B;
  border-radius: 9999px;
}
.swiper-pagination.swiper-pagination-light .swiper-pagination-bullet {
  background: rgba(255, 255, 255, 0.35);
}
.swiper-pagination.swiper-pagination-light .swiper-pagination-bullet-active {
  background: #FFFFFF;
}
.swiper-pagination.swiper-pagination-dark .swiper-pagination-bullet {
  background: #E5E5E5;
}
.swiper-pagination.swiper-pagination-dark .swiper-pagination-bullet-active {
  background: #262626;
}

.swiper-button-prev,
.swiper-button-next {
  width: 44px;
  height: 44px;
  background: #FFFFFF;
  border-radius: 9999px;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.swiper-button-prev::after,
.swiper-button-next::after {
  font-size: 1.4rem;
  font-weight: 700;
  color: #525252;
}
.swiper-button-prev:hover,
.swiper-button-next:hover {
  background: #18181B;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
}
.swiper-button-prev:hover::after,
.swiper-button-next:hover::after {
  color: #FFFFFF;
}
.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.swiper-button-prev.swiper-button-disabled:hover,
.swiper-button-next.swiper-button-disabled:hover {
  background: #FFFFFF;
}
.swiper-button-prev.swiper-button-disabled:hover::after,
.swiper-button-next.swiper-button-disabled:hover::after {
  color: #525252;
}

/**
 * ALPS 2026 - Premium Animations & Micro-interactions
 * ══════════════════════════════════════════════════════════════════════════
 * 
 * 마이크로 인터랙션:
 * - 부드러운 전환 효과
 * - 피드백 애니메이션
 * - 로딩 상태
 * - 스크롤 애니메이션
 * 
 * @버전: 3.0
 * @최종수정: 2026-01-07
 */
/* ══════════════════════════════════════════════════════════════════════════
   기본 키프레임 애니메이션
   ══════════════════════════════════════════════════════════════════════════ */
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes slideDown {
  from {
    opacity: 0;
    transform: translateY(-20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(20px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}
@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.9);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes scaleOut {
  from {
    opacity: 1;
    transform: scale(1);
  }
  to {
    opacity: 0;
    transform: scale(0.9);
  }
}
@keyframes bounce {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-8px);
  }
}
@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}
@keyframes shake {
  0%, 100% {
    transform: translateX(0);
  }
  10%, 30%, 50%, 70%, 90% {
    transform: translateX(-4px);
  }
  20%, 40%, 60%, 80% {
    transform: translateX(4px);
  }
}
@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}
@keyframes heartbeat {
  0%, 100% {
    transform: scale(1);
  }
  14% {
    transform: scale(1.3);
  }
  28% {
    transform: scale(1);
  }
  42% {
    transform: scale(1.3);
  }
  70% {
    transform: scale(1);
  }
}
@keyframes ripple {
  0% {
    transform: scale(0);
    opacity: 1;
  }
  100% {
    transform: scale(4);
    opacity: 0;
  }
}
/* ══════════════════════════════════════════════════════════════════════════
   애니메이션 유틸리티 클래스
   ══════════════════════════════════════════════════════════════════════════ */
.animate-fadeIn {
  animation: fadeIn 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.animate-fadeOut {
  animation: fadeOut 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.animate-slideUp {
  animation: slideUp 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.animate-slideDown {
  animation: slideDown 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.animate-slideInLeft {
  animation: slideInLeft 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.animate-slideInRight {
  animation: slideInRight 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.animate-scaleIn {
  animation: scaleIn 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.animate-scaleOut {
  animation: scaleOut 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.animate-bounce {
  animation: bounce 0.6s ease-in-out infinite;
}

.animate-pulse {
  animation: pulse 2s ease-in-out infinite;
}

.animate-shake {
  animation: shake 0.5s ease-in-out;
}

.animate-spin {
  animation: spin 1s linear infinite;
}

.animate-heartbeat {
  animation: heartbeat 1.5s ease-in-out infinite;
}

.delay-100 {
  animation-delay: 100ms;
}

.delay-200 {
  animation-delay: 200ms;
}

.delay-300 {
  animation-delay: 300ms;
}

.delay-400 {
  animation-delay: 400ms;
}

.delay-500 {
  animation-delay: 500ms;
}

.duration-fast {
  animation-duration: 150ms;
}

.duration-base {
  animation-duration: 200ms;
}

.duration-normal {
  animation-duration: 300ms;
}

.duration-slow {
  animation-duration: 400ms;
}

/* ══════════════════════════════════════════════════════════════════════════
   호버 효과
   ══════════════════════════════════════════════════════════════════════════ */
.hover-lift {
  transition: transform 200ms cubic-bezier(0, 0, 0.2, 1), box-shadow 200ms cubic-bezier(0, 0, 0.2, 1);
}
.hover-lift:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
}

.hover-scale {
  transition: transform 200ms cubic-bezier(0, 0, 0.2, 1);
}
.hover-scale:hover {
  transform: scale(1.02);
}

.hover-glow {
  transition: box-shadow 200ms cubic-bezier(0, 0, 0.2, 1);
}
.hover-glow:hover {
  box-shadow: 0 0 24px rgba(24, 24, 27, 0.2);
}

.hover-bright {
  transition: filter 200ms cubic-bezier(0, 0, 0.2, 1);
}
.hover-bright:hover {
  filter: brightness(1.1);
}

/* ══════════════════════════════════════════════════════════════════════════
   리플 이펙트 (버튼 클릭)
   ══════════════════════════════════════════════════════════════════════════ */
.ripple {
  position: relative;
  overflow: hidden;
}
.ripple::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 10px;
  height: 10px;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 9999px;
  transform: translate(-50%, -50%) scale(0);
  pointer-events: none;
}
.ripple:active::after {
  animation: ripple 0.6s ease-out;
}

/* ══════════════════════════════════════════════════════════════════════════
   로딩 상태
   ══════════════════════════════════════════════════════════════════════════ */
.spinner {
  display: inline-block;
  width: 24px;
  height: 24px;
  border: 2px solid #E5E5E5;
  border-top-color: #18181B;
  border-radius: 9999px;
  animation: spin 0.8s linear infinite;
}
.spinner.spinner-sm {
  width: 16px;
  height: 16px;
  border-width: 2px;
}
.spinner.spinner-lg {
  width: 40px;
  height: 40px;
  border-width: 3px;
}
.spinner.spinner-white {
  border-color: rgba(255, 255, 255, 0.2);
  border-top-color: #FFFFFF;
}

.skeleton, .skeleton-image, .skeleton-circle, .skeleton-text {
  background: linear-gradient(90deg, #F5F5F5 0%, #FAFAFA 50%, #F5F5F5 100%);
  background-size: 200% 100%;
  animation: skeleton 1.5s ease-in-out infinite;
  border-radius: 8px;
}
@keyframes skeleton {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

.skeleton-text {
  height: 1em;
}
.skeleton-text.skeleton-text-sm {
  height: 0.875em;
}
.skeleton-text.skeleton-text-lg {
  height: 1.5em;
}

.skeleton-circle {
  border-radius: 9999px;
}

.skeleton-image {
  aspect-ratio: 1/1;
}

.loading-dots {
  display: inline-flex;
  gap: 4px;
}
.loading-dots span {
  width: 8px;
  height: 8px;
  background: #18181B;
  border-radius: 9999px;
  animation: loadingDot 1.4s ease-in-out infinite;
}
.loading-dots span:nth-child(2) {
  animation-delay: 0.2s;
}
.loading-dots span:nth-child(3) {
  animation-delay: 0.4s;
}
@keyframes loadingDot {
  0%, 80%, 100% {
    opacity: 0.2;
    transform: scale(0.8);
  }
  40% {
    opacity: 1;
    transform: scale(1);
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   스크롤 트리거 애니메이션 (AOS 대체)
   ══════════════════════════════════════════════════════════════════════════ */
[data-animate] {
  opacity: 0;
  transition: opacity 400ms cubic-bezier(0, 0, 0.2, 1), transform 400ms cubic-bezier(0, 0, 0.2, 1);
}
[data-animate].is-visible {
  opacity: 1;
  transform: none;
}

[data-animate=fade-up] {
  transform: translateY(30px);
}

[data-animate=fade-down] {
  transform: translateY(-30px);
}

[data-animate=fade-left] {
  transform: translateX(30px);
}

[data-animate=fade-right] {
  transform: translateX(-30px);
}

[data-animate=zoom-in] {
  transform: scale(0.9);
}

[data-animate=zoom-out] {
  transform: scale(1.1);
}

/* ══════════════════════════════════════════════════════════════════════════
   토스트/알림 애니메이션
   ══════════════════════════════════════════════════════════════════════════ */
.toast-enter {
  animation: slideInRight 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.toast-exit {
  animation: slideOutRight 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}
@keyframes slideOutRight {
  from {
    opacity: 1;
    transform: translateX(0);
  }
  to {
    opacity: 0;
    transform: translateX(100%);
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   모달 애니메이션
   ══════════════════════════════════════════════════════════════════════════ */
.modal-backdrop-enter {
  animation: fadeIn 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.modal-backdrop-exit {
  animation: fadeOut 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}

.modal-content-enter {
  animation: modalIn 300ms cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}
@keyframes modalIn {
  from {
    opacity: 0;
    transform: scale(0.95) translateY(20px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

.modal-content-exit {
  animation: modalOut 200ms cubic-bezier(0, 0, 0.2, 1) forwards;
}
@keyframes modalOut {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
  to {
    opacity: 0;
    transform: scale(0.95) translateY(20px);
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   페이지 전환
   ══════════════════════════════════════════════════════════════════════════ */
.page-enter {
  opacity: 0;
  transform: translateY(20px);
}

.page-enter-active {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 300ms cubic-bezier(0, 0, 0.2, 1), transform 300ms cubic-bezier(0, 0, 0.2, 1);
}

.page-exit {
  opacity: 1;
  transform: translateY(0);
}

.page-exit-active {
  opacity: 0;
  transform: translateY(-20px);
  transition: opacity 300ms cubic-bezier(0, 0, 0.2, 1), transform 300ms cubic-bezier(0, 0, 0.2, 1);
}

/* ══════════════════════════════════════════════════════════════════════════
   Reduced Motion (접근성)
   ══════════════════════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
.m-1 {
  margin: 0.4rem;
}

.my-1 {
  margin-top: 0.4rem;
  margin-bottom: 0.4rem;
}

.mx-1 {
  margin-right: 0.4rem;
  margin-left: 0.4rem;
}

.ml-1 {
  margin-left: 0.4rem;
}

.mr-1 {
  margin-right: 0.4rem;
}

.mt-1 {
  margin-top: 0.4rem;
}

.mb-1 {
  margin-bottom: 0.4rem;
}

.m-2 {
  margin: 0.8rem;
}

.my-2 {
  margin-top: 0.8rem;
  margin-bottom: 0.8rem;
}

.mx-2 {
  margin-right: 0.8rem;
  margin-left: 0.8rem;
}

.ml-2 {
  margin-left: 0.8rem;
}

.mr-2 {
  margin-right: 0.8rem;
}

.mt-2 {
  margin-top: 0.8rem;
}

.mb-2 {
  margin-bottom: 0.8rem;
}

.m-3 {
  margin: 1.2rem;
}

.my-3 {
  margin-top: 1.2rem;
  margin-bottom: 1.2rem;
}

.mx-3 {
  margin-right: 1.2rem;
  margin-left: 1.2rem;
}

.ml-3 {
  margin-left: 1.2rem;
}

.mr-3 {
  margin-right: 1.2rem;
}

.mt-3 {
  margin-top: 1.2rem;
}

.mb-3 {
  margin-bottom: 1.2rem;
}

.m-4 {
  margin: 1.6rem;
}

.my-4 {
  margin-top: 1.6rem;
  margin-bottom: 1.6rem;
}

.mx-4 {
  margin-right: 1.6rem;
  margin-left: 1.6rem;
}

.ml-4 {
  margin-left: 1.6rem;
}

.mr-4 {
  margin-right: 1.6rem;
}

.mt-4 {
  margin-top: 1.6rem;
}

.mb-4 {
  margin-bottom: 1.6rem;
}

.m-5 {
  margin: 2rem;
}

.my-5 {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

.mx-5 {
  margin-right: 2rem;
  margin-left: 2rem;
}

.ml-5 {
  margin-left: 2rem;
}

.mr-5 {
  margin-right: 2rem;
}

.mt-5 {
  margin-top: 2rem;
}

.mb-5 {
  margin-bottom: 2rem;
}

.m-6 {
  margin: 2.4rem;
}

.my-6 {
  margin-top: 2.4rem;
  margin-bottom: 2.4rem;
}

.mx-6 {
  margin-right: 2.4rem;
  margin-left: 2.4rem;
}

.ml-6 {
  margin-left: 2.4rem;
}

.mr-6 {
  margin-right: 2.4rem;
}

.mt-6 {
  margin-top: 2.4rem;
}

.mb-6 {
  margin-bottom: 2.4rem;
}

.m-7 {
  margin: 2.8rem;
}

.my-7 {
  margin-top: 2.8rem;
  margin-bottom: 2.8rem;
}

.mx-7 {
  margin-right: 2.8rem;
  margin-left: 2.8rem;
}

.ml-7 {
  margin-left: 2.8rem;
}

.mr-7 {
  margin-right: 2.8rem;
}

.mt-7 {
  margin-top: 2.8rem;
}

.mb-7 {
  margin-bottom: 2.8rem;
}

.m-8 {
  margin: 3.2rem;
}

.my-8 {
  margin-top: 3.2rem;
  margin-bottom: 3.2rem;
}

.mx-8 {
  margin-right: 3.2rem;
  margin-left: 3.2rem;
}

.ml-8 {
  margin-left: 3.2rem;
}

.mr-8 {
  margin-right: 3.2rem;
}

.mt-8 {
  margin-top: 3.2rem;
}

.mb-8 {
  margin-bottom: 3.2rem;
}

.m-9 {
  margin: 3.6rem;
}

.my-9 {
  margin-top: 3.6rem;
  margin-bottom: 3.6rem;
}

.mx-9 {
  margin-right: 3.6rem;
  margin-left: 3.6rem;
}

.ml-9 {
  margin-left: 3.6rem;
}

.mr-9 {
  margin-right: 3.6rem;
}

.mt-9 {
  margin-top: 3.6rem;
}

.mb-9 {
  margin-bottom: 3.6rem;
}

.m-10 {
  margin: 4rem;
}

.my-10 {
  margin-top: 4rem;
  margin-bottom: 4rem;
}

.mx-10 {
  margin-right: 4rem;
  margin-left: 4rem;
}

.ml-10 {
  margin-left: 4rem;
}

.mr-10 {
  margin-right: 4rem;
}

.mt-10 {
  margin-top: 4rem;
}

.mb-10 {
  margin-bottom: 4rem;
}

.m-11 {
  margin: 4.4rem;
}

.my-11 {
  margin-top: 4.4rem;
  margin-bottom: 4.4rem;
}

.mx-11 {
  margin-right: 4.4rem;
  margin-left: 4.4rem;
}

.ml-11 {
  margin-left: 4.4rem;
}

.mr-11 {
  margin-right: 4.4rem;
}

.mt-11 {
  margin-top: 4.4rem;
}

.mb-11 {
  margin-bottom: 4.4rem;
}

.m-12 {
  margin: 4.8rem;
}

.my-12 {
  margin-top: 4.8rem;
  margin-bottom: 4.8rem;
}

.mx-12 {
  margin-right: 4.8rem;
  margin-left: 4.8rem;
}

.ml-12 {
  margin-left: 4.8rem;
}

.mr-12 {
  margin-right: 4.8rem;
}

.mt-12 {
  margin-top: 4.8rem;
}

.mb-12 {
  margin-bottom: 4.8rem;
}

/**
 * ALPS 2026 - Premium Main Page
 * ══════════════════════════════════════════════════════════════════════════
 * 
 * 2026 프리미엄 커머스 트렌드:
 * - 대담한 히어로 배너
 * - 마이크로 인터랙션
 * - 그라데이션 & 글래스모피즘
 * - 콘텐츠 우선 레이아웃
 * - 부드러운 애니메이션
 * 
 * @버전: 3.0
 * @최종수정: 2026-01-07
 */
/* ══════════════════════════════════════════════════════════════════════════
   메인 페이지 래퍼
   ══════════════════════════════════════════════════════════════════════════ */
.main {
  background: #FFFFFF;
  padding-bottom: calc(56px + env(safe-area-inset-bottom, 0));
}
@media (min-width: 1024px) {
  .main {
    padding-bottom: 0;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   메인 배너 (히어로) - Premium Full-Width Hero
   ══════════════════════════════════════════════════════════════════════════ */
.main-banner {
  position: relative;
  background: linear-gradient(135deg, #F5F5F5 0%, #FAFAFA 100%);
  overflow: hidden;
}
.main-banner .main-banner-swiper .main-slide-list {
  position: relative;
  line-height: 0;
}
.main-banner .main-banner-swiper .main-slide-list::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 0%, transparent 40%, rgba(23, 23, 23, 0.4) 100%);
  z-index: 5;
  pointer-events: none;
}
.main-banner .main-banner-swiper .main-slide-list img {
  width: 100%;
  height: auto;
  min-height: 340px;
  max-height: 520px;
  object-fit: cover;
}
@media (min-width: 768px) {
  .main-banner .main-banner-swiper .main-slide-list img {
    min-height: 420px;
    max-height: 600px;
  }
}
@media (min-width: 1024px) {
  .main-banner .main-banner-swiper .main-slide-list img {
    min-height: 500px;
    max-height: 720px;
  }
}
.main-banner .main-banner-swiper .main-slide-list .banner-txt {
  position: absolute;
  left: 2rem;
  bottom: 3.2rem;
  right: 2rem;
  z-index: 10;
}
@media (min-width: 768px) {
  .main-banner .main-banner-swiper .main-slide-list .banner-txt {
    left: 4rem;
    bottom: 4.8rem;
    right: auto;
    max-width: 540px;
  }
}
@media (min-width: 1024px) {
  .main-banner .main-banner-swiper .main-slide-list .banner-txt {
    left: 6.4rem;
    bottom: 6.4rem;
    max-width: 640px;
  }
}
.main-banner .main-banner-swiper .main-slide-list .banner-txt .txt {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: clamp(2.4rem, 6vw, 4.8rem);
  font-weight: 800;
  color: #FFFFFF;
  line-height: 1.1;
  letter-spacing: -0.05em;
  text-shadow: 0 4px 40px rgba(23, 23, 23, 0.25);
  margin-bottom: 1.6rem;
}
@media (min-width: 768px) {
  .main-banner .main-banner-swiper .main-slide-list .banner-txt .txt {
    margin-bottom: 2rem;
  }
}
.main-banner .main-banner-swiper .main-slide-list .banner-txt .sub-txt {
  font-size: 1.4rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.85);
  line-height: 1.65;
  margin-bottom: 2rem;
  max-width: 400px;
}
@media (min-width: 768px) {
  .main-banner .main-banner-swiper .main-slide-list .banner-txt .sub-txt {
    font-size: 1.6rem;
    margin-bottom: 2.4rem;
  }
}
.main-banner .main-banner-swiper .main-slide-list .banner-txt .all {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  height: 48px;
  padding: 0 2.4rem;
  background: #FFFFFF;
  color: #171717;
  font-size: 1.2rem;
  font-weight: 700;
  border-radius: 9999px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  box-shadow: 0 8px 32px rgba(23, 23, 23, 0.2);
}
@media (min-width: 768px) {
  .main-banner .main-banner-swiper .main-slide-list .banner-txt .all {
    height: 56px;
    padding: 0 3.2rem;
    font-size: 1.4rem;
  }
}
.main-banner .main-banner-swiper .main-slide-list .banner-txt .all::after {
  content: "→";
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
.main-banner .main-banner-swiper .main-slide-list .banner-txt .all:hover {
  background: #18181B;
  color: #FFFFFF;
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(24, 24, 27, 0.3);
}
.main-banner .main-banner-swiper .main-slide-list .banner-txt .all:hover::after {
  transform: translateX(4px);
}
.main-banner .main-banner-swiper .main-slide-list .banner-txt .all:active {
  transform: translateY(0);
}
.main-banner .swiper-pagination {
  bottom: 2rem !important;
}
@media (min-width: 768px) {
  .main-banner .swiper-pagination {
    bottom: 3.2rem !important;
  }
}
.main-banner .swiper-pagination .swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  background: rgba(255, 255, 255, 0.35);
  opacity: 1;
  margin: 0 5px !important;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  border-radius: 9999px;
}
.main-banner .swiper-pagination .swiper-pagination-bullet-active {
  width: 28px;
  background: #FFFFFF;
}
.main-banner .swiper-button-prev,
.main-banner .swiper-button-next {
  display: none;
}
@media (min-width: 1024px) {
  .main-banner .swiper-button-prev,
  .main-banner .swiper-button-next {
    display: flex;
    width: 56px;
    height: 56px;
    background: rgba(255, 255, 255, 0.9);
    backdrop-filter: blur(8px);
    border-radius: 9999px;
    transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  }
  .main-banner .swiper-button-prev::after,
  .main-banner .swiper-button-next::after {
    font-size: 1.6rem;
    font-weight: 700;
    color: #404040;
  }
  .main-banner .swiper-button-prev:hover,
  .main-banner .swiper-button-next:hover {
    background: #FFFFFF;
    transform: scale(1.05);
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
  }
}
.main-banner .swiper-button-prev {
  left: 3.2rem;
}
.main-banner .swiper-button-next {
  right: 3.2rem;
}

/* ══════════════════════════════════════════════════════════════════════════
   미니 배너 (카테고리 퀵링크) - Premium Icon Grid
   ══════════════════════════════════════════════════════════════════════════ */
.mini-banner-wrap {
  padding: 1.6rem 2rem;
  background: #FFFFFF;
}
@media (min-width: 768px) {
  .mini-banner-wrap {
    padding: 2rem 2.4rem;
  }
}
@media (min-width: 1024px) {
  .mini-banner-wrap {
    padding: 2.4rem 3.2rem;
    max-width: none;
    margin: 0 auto;
  }
}
.mini-banner-wrap .mini-banner-swiper {
  overflow: hidden;
}
.mini-banner-wrap .mini-banner-swiper .swiper-wrapper {
  display: flex;
}
.mini-banner-wrap .mini-banner-swiper .swiper-slide {
  flex: 1;
  width: calc(33.333% - 8px) !important;
}
@media (min-width: 768px) {
  .mini-banner-wrap .mini-banner-swiper .swiper-slide {
    width: calc(33.333% - 10px) !important;
  }
}
@media (min-width: 1024px) {
  .mini-banner-wrap .mini-banner-swiper .swiper-slide {
    width: calc(33.333% - 12px) !important;
  }
}
.mini-banner-wrap .mini-banner-item {
  text-align: center;
}
.mini-banner-wrap .mini-banner-item a {
  display: block;
  text-decoration: none;
}
.mini-banner-wrap .mini-banner-item a:hover .mini-banner-img {
  transform: scale(1.02);
  box-shadow: 0 8px 24px rgba(23, 23, 23, 0.15);
}
.mini-banner-wrap .mini-banner-item a:hover .mini-banner-title {
  color: #18181B;
}
.mini-banner-wrap .mini-banner-item .mini-banner-img {
  width: 100%;
  aspect-ratio: 16/9;
  border-radius: 12px;
  background: #FAFAFA;
  overflow: hidden;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  position: relative;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.04), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
}
@media (min-width: 768px) {
  .mini-banner-wrap .mini-banner-item .mini-banner-img {
    border-radius: 16px;
  }
}
@media (min-width: 1024px) {
  .mini-banner-wrap .mini-banner-item .mini-banner-img {
    border-radius: 16px;
  }
}
.mini-banner-wrap .mini-banner-item .mini-banner-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: relative;
  z-index: 1;
}
.mini-banner-wrap .mini-banner-item .mini-banner-title {
  margin-top: 0.8rem;
  font-size: 1.15rem;
  font-weight: 600;
  color: #404040;
  transition: color 150ms cubic-bezier(0, 0, 0.2, 1);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (min-width: 768px) {
  .mini-banner-wrap .mini-banner-item .mini-banner-title {
    font-size: 1.2rem;
    margin-top: 1.2rem;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   섹션 공통 스타일 - Premium Section System
   ══════════════════════════════════════════════════════════════════════════ */
.main-section, .review, .event, .good, .category-best-section {
  background: #FFFFFF;
}
.main-section + .main-section, .review + .main-section, .main-section + .review, .review + .review, .event + .main-section, .event + .review, .main-section + .event, .review + .event, .event + .event, .good + .main-section, .good + .review, .good + .event, .main-section + .good, .review + .good, .event + .good, .good + .good, .category-best-section + .main-section, .category-best-section + .review, .category-best-section + .event, .category-best-section + .good, .main-section + .category-best-section, .review + .category-best-section, .event + .category-best-section, .good + .category-best-section, .category-best-section + .category-best-section {
  margin-top: 0.8rem;
}
@media (min-width: 1024px) {
  .main-section + .main-section, .review + .main-section, .main-section + .review, .review + .review, .event + .main-section, .event + .review, .main-section + .event, .review + .event, .event + .event, .good + .main-section, .good + .review, .good + .event, .main-section + .good, .review + .good, .event + .good, .good + .good, .category-best-section + .main-section, .category-best-section + .review, .category-best-section + .event, .category-best-section + .good, .main-section + .category-best-section, .review + .category-best-section, .event + .category-best-section, .good + .category-best-section, .category-best-section + .category-best-section {
    margin-top: 1.2rem;
  }
}

.main-section__inner {
  padding: 3.2rem 2rem;
}
@media (min-width: 768px) {
  .main-section__inner {
    padding: 4rem 2.4rem;
  }
}
@media (min-width: 1024px) {
  .main-section__inner {
    padding: 4.8rem 3.2rem;
    max-width: none;
    margin: 0 auto;
  }
}

.main-section__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2.4rem;
}
@media (min-width: 1024px) {
  .main-section__header {
    margin-bottom: 3.2rem;
  }
}

.main-section__title {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  color: #171717;
  letter-spacing: -0.025em;
  position: relative;
}
@media (min-width: 768px) {
  .main-section__title {
    font-size: 2.2rem;
  }
}
@media (min-width: 1024px) {
  .main-section__title {
    font-size: 2.8rem;
  }
}

.main-section__subtitle {
  font-size: 1.2rem;
  font-weight: 500;
  color: #A3A3A3;
  margin-top: 0.4rem;
  text-transform: uppercase;
  letter-spacing: 0.025em;
}
@media (min-width: 768px) {
  .main-section__subtitle {
    font-size: 1.2rem;
  }
}

.main-section__link, .section-link, .review .review-title .best-link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  font-size: 1.2rem;
  font-weight: 600;
  color: #737373;
  padding: 0.8rem 1.2rem;
  border-radius: 12px;
}
@media (min-width: 768px) {
  .main-section__link, .section-link, .review .review-title .best-link {
    font-size: 1.4rem;
  }
}
.main-section__link::after, .section-link::after, .review .review-title .best-link::after {
  content: "→";
}

/* ══════════════════════════════════════════════════════════════════════════
   상품 카드 - Premium Product Card (3:4 비율, 대형 이미지)
   ══════════════════════════════════════════════════════════════════════════ */
.product-list {
  position: relative;
}
.product-list a {
  display: block;
  text-decoration: none;
}
.product-list a:hover .img-box img,
.product-list a:hover picture img {
  transform: scale(1.04);
}
.product-list a:hover .product-txt .name {
  color: #18181B;
}
.product-list picture,
.product-list .img-box {
  position: relative;
  display: block;
  border-radius: 16px;
  overflow: hidden;
  background: #FAFAFA;
  aspect-ratio: 4/5;
}
@media (min-width: 1024px) {
  .product-list picture,
  .product-list .img-box {
    border-radius: 20px;
  }
}
.product-list picture img,
.product-list .img-box img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 400ms cubic-bezier(0, 0, 0.2, 1);
}
.product-list .product_wish_btn {
  position: absolute;
  top: 1.2rem;
  right: 1.2rem;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
  border-radius: 9999px;
  box-shadow: 0 2px 12px rgba(23, 23, 23, 0.08);
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 1024px) {
  .product-list .product_wish_btn {
    width: 40px;
    height: 40px;
  }
}
.product-list .product_wish_btn img {
  width: 18px;
  height: 18px;
  opacity: 0.6;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 1024px) {
  .product-list .product_wish_btn img {
    width: 20px;
    height: 20px;
  }
}
.product-list .product_wish_btn:hover {
  transform: scale(1.1);
  background: #FFFFFF;
  box-shadow: 0 4px 16px rgba(23, 23, 23, 0.12);
}
.product-list .product_wish_btn:hover img {
  opacity: 1;
}
.product-list .product_wish_btn.active {
  background: #DC2626;
}
.product-list .product_wish_btn.active img {
  filter: brightness(0) invert(1);
  opacity: 1;
}
.product-list .item-badges {
  position: absolute;
  top: 1.2rem;
  left: 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  z-index: 5;
}
.product-list .item-badges .badge {
  display: inline-block;
  padding: 0.4rem 0.8rem;
  font-size: 1rem;
  font-weight: 700;
  border-radius: 8px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
@media (min-width: 1024px) {
  .product-list .item-badges .badge {
    font-size: 1.1rem;
    padding: 0.4rem 1rem;
  }
}
.product-list .item-badges .badge-new {
  background: #18181B;
  color: #FFFFFF;
}
.product-list .item-badges .badge-best {
  background: #F59E0B;
  color: #FFFFFF;
}
.product-list .item-badges .badge-sale {
  background: #DC2626;
  color: #FFFFFF;
}
.product-list .item-badges .badge-soldout {
  background: #A3A3A3;
  color: #FFFFFF;
}

.product-txt {
  padding: 1.6rem 0 0.8rem;
}
.product-txt .name {
  font-size: 1.2rem;
  font-weight: 500;
  color: #737373;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  min-height: calc(1.2rem * 1.35 * 2);
  margin-bottom: 0.8rem;
  transition: color 150ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .product-txt .name {
    font-size: 1.4rem;
    min-height: calc(1.4rem * 1.35 * 2);
  }
}
.product-txt .price {
  font-size: 1.2rem;
  font-weight: 400;
  color: #A3A3A3;
  text-decoration: line-through;
}
.product-txt .price.discount {
  margin-bottom: 0.2rem;
}
.product-txt .final-price {
  display: flex;
  align-items: baseline;
  gap: 0.8rem;
  flex-wrap: wrap;
}
.product-txt .final-price .discount-rate {
  font-size: 1.6rem;
  font-weight: 800;
  color: #DC2626;
}
@media (min-width: 768px) {
  .product-txt .final-price .discount-rate {
    font-size: 1.8rem;
  }
}
.product-txt .final-price .current-price {
  font-size: 1.6rem;
  font-weight: 700;
  color: #171717;
}
@media (min-width: 768px) {
  .product-txt .final-price .current-price {
    font-size: 1.8rem;
  }
}
.product-txt .size {
  font-size: 1.1rem;
  color: #A3A3A3;
  margin-top: 0.6rem;
}
.product-txt .review-info {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 0.8rem;
  font-size: 1.1rem;
  color: #737373;
}
.product-txt .review-info .star {
  color: #F59E0B;
}

/* ══════════════════════════════════════════════════════════════════════════
   카테고리별 베스트 섹션 - Premium Carousel (한 화면 최대 4개, 대형 이미지)
   ══════════════════════════════════════════════════════════════════════════ */
.category-best-section {
  padding: 3.2rem 0;
}
@media (min-width: 768px) {
  .category-best-section {
    padding: 4rem 0;
  }
}
@media (min-width: 1024px) {
  .category-best-section {
    padding: 4.8rem 0;
  }
}
.category-best-section .section-header {
  padding: 0 2rem;
}
@media (min-width: 768px) {
  .category-best-section .section-header {
    padding: 0 2.4rem;
  }
}
@media (min-width: 1024px) {
  .category-best-section .section-header {
    padding: 0 3.2rem;
    max-width: none;
    margin: 0 auto 3.2rem;
  }
}

.best-swiper {
  overflow: hidden;
  padding: 0;
  margin: 0;
}
/* 2026-02-10: 좌우 간격은 Swiper JS slidesOffsetBefore/After로 처리 */
.best-swiper .swiper-wrapper {
  padding: 0.8rem 0;
}
/* 2026-02-10: slidesPerView: 'auto' + freeMode - CSS로 슬라이드 너비 지정 */
.best-swiper .swiper-slide {
  width: 45%;
}
@media (min-width: 768px) {
  .best-swiper .swiper-slide {
    width: 30%;
  }
}
@media (min-width: 1024px) {
  .best-swiper .swiper-slide {
    width: 18.5%;
  }
}
.best-swiper .best-item-img {
  padding-top: 133.33% !important;
  border-radius: 0 !important;
}
@media (min-width: 1024px) {
  .best-swiper .best-item-img {
    border-radius: 0 !important;
  }
}
/* best-item 스타일은 스킨 파일에서 관리 - style.css 중복 제거 (2026-02-26) */
.best-swiper .best-prev,
.best-swiper .best-next {
  display: none;
}
@media (min-width: 1024px) {
  .best-swiper .best-prev,
  .best-swiper .best-next {
    display: flex;
    width: 52px;
    height: 52px;
    background: #FFFFFF;
    border: 1px solid #F5F5F5;
    border-radius: 9999px;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
    top: 35%;
    transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  }
  .best-swiper .best-prev::after,
  .best-swiper .best-next::after {
    font-size: 1.4rem;
    font-weight: 700;
    color: #525252;
  }
  .best-swiper .best-prev:hover,
  .best-swiper .best-next:hover {
    background: #18181B;
    border-color: #18181B;
  }
  .best-swiper .best-prev:hover::after,
  .best-swiper .best-next:hover::after {
    color: #FFFFFF;
  }
  .best-swiper .best-prev.swiper-button-disabled,
  .best-swiper .best-next.swiper-button-disabled {
    opacity: 0.3;
    cursor: not-allowed;
  }
  .best-swiper .best-prev.swiper-button-disabled:hover,
  .best-swiper .best-next.swiper-button-disabled:hover {
    background: #FFFFFF;
    border-color: #F5F5F5;
  }
  .best-swiper .best-prev.swiper-button-disabled:hover::after,
  .best-swiper .best-next.swiper-button-disabled:hover::after {
    color: #525252;
  }
}
.best-swiper .best-prev {
  left: 1.2rem;
}
.best-swiper .best-next {
  right: 1.2rem;
}

.best-pagination {
  margin-top: 2rem;
  text-align: center;
}
.best-pagination .swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  background: #E5E5E5;
  opacity: 1;
  margin: 0 4px !important;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  border-radius: 9999px;
}
.best-pagination .swiper-pagination-bullet-active {
  width: 24px;
  background: #18181B;
}

/* ══════════════════════════════════════════════════════════════════════════
   베스트 상품 - Premium Rolling Carousel (한 화면에 2~4개, 롤링 효과)
   ══════════════════════════════════════════════════════════════════════════ */
.good {
  padding: 3.2rem 0;
}
@media (min-width: 768px) {
  .good {
    padding: 4rem 0;
  }
}
@media (min-width: 1024px) {
  .good {
    padding: 4.8rem 0;
  }
}
.good .good-title {
  display: flex;
  flex-direction: column;
  margin-bottom: 2.4rem;
  padding: 0 2rem;
}
@media (min-width: 768px) {
  .good .good-title {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
    padding: 0 2.4rem;
  }
}
@media (min-width: 1024px) {
  .good .good-title {
    margin-bottom: 3.2rem;
    padding: 0 3.2rem;
    max-width: none;
    margin-left: auto;
    margin-right: auto;
  }
}
.good .good-title .title-wrap {
  margin-bottom: 1.6rem;
}
@media (min-width: 768px) {
  .good .good-title .title-wrap {
    margin-bottom: 0;
  }
}
.good .good-title .title {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  color: #171717;
  letter-spacing: -0.025em;
}
@media (min-width: 768px) {
  .good .good-title .title {
    font-size: 2.2rem;
  }
}
@media (min-width: 1024px) {
  /* 2026-02-02: .section-title과 동일한 크기로 통일 */
  .good .good-title .title {
    font-size: 2.8rem;
  }
}
.good .good-title .txt {
  font-size: 1.1rem;
  font-weight: 500;
  color: #A3A3A3;
  letter-spacing: 0.025em;
  text-transform: uppercase;
  margin-top: 0.4rem;
}
@media (min-width: 768px) {
  .good .good-title .txt {
    font-size: 1.2rem;
  }
}
.good .good-product {
  position: relative;
}
.good .good-product .product-wrap {
  display: flex !important;
  overflow: hidden;
}
.good .good-product .product-list {
  flex-shrink: 0;
  width: calc(50% - 1.2rem);
  margin-right: 1.2rem;
}
@media (min-width: 768px) {
  .good .good-product .product-list {
    width: calc(33.333% - 1.6rem);
    margin-right: 1.6rem;
  }
}
@media (min-width: 1024px) {
  .good .good-product .product-list {
    width: calc(25% - 2rem);
    margin-right: 2rem;
  }
}
.good .good-swiper {
  padding: 0;
  margin: 0;
  overflow: hidden;
}
/* 2026-02-10: 좌우 간격은 Swiper JS slidesOffsetBefore/After로 처리 */
/* 2026-02-10: slidesPerView: 'auto' + freeMode - CSS로 슬라이드 너비 지정 */
.good .good-swiper .swiper-slide {
  width: 45%;
}
@media (min-width: 768px) {
  .good .good-swiper .swiper-slide {
    width: 30%;
  }
}
@media (min-width: 1024px) {
  .good .good-swiper .swiper-slide {
    width: 18.5%;
  }
}
.good .good-swiper .good-prev,
.good .good-swiper .good-next {
  display: none;
}
@media (min-width: 1024px) {
  .good .good-swiper .good-prev,
  .good .good-swiper .good-next {
    display: flex;
    width: 52px;
    height: 52px;
    background: #FFFFFF;
    border: 1px solid #F5F5F5;
    border-radius: 9999px;
    box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.06), 0 4px 6px -4px rgba(0, 0, 0, 0.06);
    top: 35%;
    transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  }
  .good .good-swiper .good-prev::after,
  .good .good-swiper .good-next::after {
    font-size: 1.4rem;
    font-weight: 700;
    color: #525252;
  }
  .good .good-swiper .good-prev:hover,
  .good .good-swiper .good-next:hover {
    background: #18181B;
    border-color: #18181B;
  }
  .good .good-swiper .good-prev:hover::after,
  .good .good-swiper .good-next:hover::after {
    color: #FFFFFF;
  }
  .good .good-swiper .good-prev.swiper-button-disabled,
  .good .good-swiper .good-next.swiper-button-disabled {
    opacity: 0.3;
    cursor: not-allowed;
  }
  .good .good-swiper .good-prev.swiper-button-disabled:hover,
  .good .good-swiper .good-next.swiper-button-disabled:hover {
    background: #FFFFFF;
    border-color: #F5F5F5;
  }
  .good .good-swiper .good-prev.swiper-button-disabled:hover::after,
  .good .good-swiper .good-next.swiper-button-disabled:hover::after {
    color: #525252;
  }
}
.good .good-swiper .good-prev {
  left: 1.2rem;
}
.good .good-swiper .good-next {
  right: 1.2rem;
}
.good .good-pagination {
  margin-top: 2.4rem;
  position: relative;
  text-align: center;
}
@media (min-width: 1024px) {
  .good .good-pagination {
    margin-top: 3.2rem;
  }
}
.good .good-pagination .swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  background: #E5E5E5;
  opacity: 1;
  margin: 0 4px !important;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  border-radius: 9999px;
}
.good .good-pagination .swiper-pagination-bullet-active {
  width: 28px;
  background: #18181B;
}
.good .all-button {
  text-align: center;
  padding: 4rem 2rem 0;
}
@media (min-width: 1024px) {
  .good .all-button {
    padding-top: 4.8rem;
  }
}
.good .all-button .all {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  height: 52px;
  padding: 0 4rem;
  background: #FFFFFF;
  color: #262626;
  font-size: 1.4rem;
  font-weight: 600;
  border: 2px solid #E5E5E5;
  border-radius: 9999px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .good .all-button .all {
    height: 56px;
    padding: 0 4.8rem;
  }
}
.good .all-button .all::after {
  content: "→";
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
.good .all-button .all:hover {
  background: #18181B;
  color: #FFFFFF;
  border-color: #18181B;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(24, 24, 27, 0.2);
}
.good .all-button .all:hover::after {
  transform: translateX(4px);
}
.good .all-button .all:active {
  transform: translateY(0);
}

/* ══════════════════════════════════════════════════════════════════════════
   이벤트 배너 섹션 - Premium Event Cards
   ══════════════════════════════════════════════════════════════════════════ */
.event {
  background: #FCFCFC;
  padding: 3.2rem 0;
}
@media (min-width: 768px) {
  .event {
    padding: 4rem 0;
  }
}
@media (min-width: 1024px) {
  .event {
    padding: 4.8rem 0;
  }
}
.event .event-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2rem;
  margin-bottom: 2.4rem;
}
@media (min-width: 768px) {
  .event .event-header {
    padding: 0 2.4rem;
  }
}
@media (min-width: 1024px) {
  .event .event-header {
    padding: 0 3.2rem;
    max-width: none;
    margin: 0 auto 3.2rem;
  }
}
.event .event-banner {
  padding: 0 2rem;
  overflow: hidden;
}
@media (min-width: 768px) {
  .event .event-banner {
    padding: 0 2.4rem;
  }
}
@media (min-width: 1024px) {
  .event .event-banner {
    padding: 0 3.2rem;
    max-width: none;
    margin: 0 auto;
  }
}
.event .event-banner .event-slide .event-list {
  width: 260px !important;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05), 0 2px 4px -2px rgba(0, 0, 0, 0.05);
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .event .event-banner .event-slide .event-list {
    width: 320px !important;
  }
}
@media (min-width: 1024px) {
  .event .event-banner .event-slide .event-list {
    width: 380px !important;
  }
}
.event .event-banner .event-slide .event-list:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.07), 0 8px 10px -6px rgba(0, 0, 0, 0.07);
}
.event .event-banner .event-slide .event-list .event-item {
  display: block;
  position: relative;
}
.event .event-banner .event-slide .event-list .event-item img {
  width: 100%;
  display: block;
}
.event .event-banner .event-slide .event-list .event-item .event-label {
  position: absolute;
  top: 1.6rem;
  left: 1.6rem;
  padding: 0.6rem 1.2rem;
  background: #FFFFFF;
  border-radius: 9999px;
  font-size: 1.1rem;
  font-weight: 700;
  color: #18181B;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.04), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
}
.event .mainPagination {
  margin-top: 2.4rem;
  position: relative;
}
@media (min-width: 1024px) {
  .event .mainPagination {
    margin-top: 3.2rem;
  }
}
.event .mainPagination .swiper-pagination-bullet {
  width: 8px;
  height: 8px;
  background: #E5E5E5;
  opacity: 1;
  margin: 0 4px !important;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.event .mainPagination .swiper-pagination-bullet-active {
  width: 24px;
  border-radius: 9999px;
  background: #18181B;
}

/* ══════════════════════════════════════════════════════════════════════════
   블루라이트 프로모션 섹션 - Premium Feature Banner
   ══════════════════════════════════════════════════════════════════════════ */
.bluelight {
  position: relative;
  overflow: hidden;
}
.bluelight .video {
  width: 100%;
  position: relative;
}
.bluelight .video::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(23, 23, 23, 0.6) 0%, transparent 60%);
  z-index: 5;
}
@media (min-width: 768px) {
  .bluelight .video::before {
    background: linear-gradient(90deg, rgba(23, 23, 23, 0.5) 0%, transparent 50%);
  }
}
.bluelight .video img,
.bluelight .video video {
  width: 100%;
  display: block;
  min-height: 320px;
  object-fit: cover;
}
@media (min-width: 768px) {
  .bluelight .video img,
  .bluelight .video video {
    min-height: 400px;
  }
}
@media (min-width: 1024px) {
  .bluelight .video img,
  .bluelight .video video {
    min-height: 480px;
  }
}
.bluelight .bluelight-txt {
  position: absolute;
  left: 2rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
}
@media (min-width: 768px) {
  .bluelight .bluelight-txt {
    left: 4rem;
  }
}
@media (min-width: 1024px) {
  .bluelight .bluelight-txt {
    left: 6.4rem;
    max-width: 500px;
  }
}
.bluelight .bluelight-txt .title {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: clamp(3.2rem, 8vw, 6.4rem);
  font-weight: 800;
  color: #FFFFFF;
  line-height: 0.9;
  letter-spacing: -0.05em;
  text-shadow: 0 4px 40px rgba(23, 23, 23, 0.3);
}
.bluelight .bluelight-txt .txt {
  display: block;
  font-size: 1.4rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.85);
  padding: 2rem 0 2.4rem;
  max-width: 280px;
  line-height: 1.65;
}
@media (min-width: 768px) {
  .bluelight .bluelight-txt .txt {
    font-size: 1.6rem;
    padding: 2.4rem 0 3.2rem;
    max-width: 360px;
  }
}
.bluelight .bluelight-txt .bluelight-link {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  height: 44px;
  padding: 0 2rem;
  background: #FFFFFF;
  color: #171717;
  font-size: 1.2rem;
  font-weight: 700;
  border-radius: 9999px;
  box-shadow: 0 8px 32px rgba(23, 23, 23, 0.2);
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .bluelight .bluelight-txt .bluelight-link {
    height: 52px;
    padding: 0 2.4rem;
    font-size: 1.4rem;
  }
}
.bluelight .bluelight-txt .bluelight-link::after {
  content: "→";
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
.bluelight .bluelight-txt .bluelight-link:hover {
  background: #18181B;
  color: #FFFFFF;
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(24, 24, 27, 0.3);
}
.bluelight .bluelight-txt .bluelight-link:hover::after {
  transform: translateX(4px);
}

/* ══════════════════════════════════════════════════════════════════════════
   리뷰 섹션 - Premium Review Showcase (3:4 비율, 롤링 효과)
   ══════════════════════════════════════════════════════════════════════════ */
.review {
  padding: 3.2rem 0;
}
@media (min-width: 768px) {
  .review {
    padding: 4rem 0;
  }
}
@media (min-width: 1024px) {
  .review {
    padding: 4.8rem 0;
  }
}
.review .review-title {
  display: flex;
  flex-direction: column;
  margin-bottom: 2.4rem;
  padding: 0 2rem;
}
@media (min-width: 768px) {
  .review .review-title {
    padding: 0 2.4rem;
  }
}
@media (min-width: 1024px) {
  .review .review-title {
    margin-bottom: 3.2rem;
    padding: 0 3.2rem;
    max-width: none;
    margin-left: auto;
    margin-right: auto;
  }
}
.review .review-title .flex-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.review .review-title .title {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  color: #171717;
  letter-spacing: -0.025em;
}
@media (min-width: 768px) {
  .review .review-title .title {
    font-size: 2.8rem;
  }
}
@media (min-width: 1024px) {
  .review .review-title .title {
    font-size: 3.6rem;
  }
}
.review .review-title .txt {
  font-size: 1.1rem;
  font-weight: 500;
  color: #A3A3A3;
  letter-spacing: 0.025em;
  text-transform: uppercase;
  margin-top: 0.4rem;
}
.review .review-contents {
  overflow: hidden;
  padding: 0 2rem;
}
@media (min-width: 768px) {
  .review .review-contents {
    padding: 0 2.4rem;
  }
}
@media (min-width: 1024px) {
  .review .review-contents {
    padding: 0 3.2rem;
    max-width: none;
    margin: 0 auto;
  }
}
.review .review-contents .swiper-slide {
  width: calc(50% - 0.8rem) !important;
}
@media (min-width: 768px) {
  .review .review-contents .swiper-slide {
    width: calc(33.333% - 1.2rem) !important;
  }
}
@media (min-width: 1024px) {
  .review .review-contents .swiper-slide {
    width: calc(25% - 1.6rem) !important;
  }
}
.review .review-contents .review-list .review-item {
  display: block;
  text-decoration: none;
  transition: transform 200ms cubic-bezier(0, 0, 0.2, 1);
}
.review .review-contents .review-list .review-item:hover {
  transform: translateY(-6px);
}
.review .review-contents .review-list .review-item:hover .img-wr img {
  transform: scale(1.04);
}
.review .review-contents .review-list .review-item:hover .review-txt .name {
  color: #0D0D0F;
}
.review .review-contents .review-list .review-item .img-wr {
  border-radius: 16px;
  overflow: hidden;
  background: #FAFAFA;
  aspect-ratio: 3/4;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.04), 0 1px 2px -1px rgba(0, 0, 0, 0.04);
}
@media (min-width: 1024px) {
  .review .review-contents .review-list .review-item .img-wr {
    border-radius: 20px;
  }
}
.review .review-contents .review-list .review-item .img-wr img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 400ms cubic-bezier(0, 0, 0.2, 1);
}
.review .review-contents .review-list .review-item .review-txt {
  padding: 1.6rem 0.4rem;
}
.review .review-contents .review-list .review-item .review-txt .name {
  font-size: 1.2rem;
  font-weight: 700;
  color: #18181B;
  margin-bottom: 0.4rem;
  transition: color 150ms cubic-bezier(0, 0, 0.2, 1);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (min-width: 768px) {
  .review .review-contents .review-list .review-item .review-txt .name {
    font-size: 1.4rem;
  }
}
.review .review-contents .review-list .review-item .review-txt .nickname {
  font-size: 1.2rem;
  font-weight: 600;
  color: #262626;
}
@media (min-width: 768px) {
  .review .review-contents .review-list .review-item .review-txt .nickname {
    font-size: 1.4rem;
  }
}
.review .review-contents .review-list .review-item .review-txt .txt {
  font-size: 1.2rem;
  font-weight: 400;
  color: #737373;
  line-height: 1.65;
  margin-top: 0.8rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.review .review-contents .review-list .review-item .review-txt .rating {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 0.8rem;
}
.review .review-contents .review-list .review-item .review-txt .rating .stars {
  color: #F59E0B;
  font-size: 1.2rem;
}

/* ══════════════════════════════════════════════════════════════════════════
   하단 배너 - Premium CTA Banner
   ══════════════════════════════════════════════════════════════════════════ */
.bottom-banner {
  padding: 2.4rem 2rem 4rem;
}
@media (min-width: 768px) {
  .bottom-banner {
    padding: 3.2rem 2.4rem 4.8rem;
  }
}
@media (min-width: 1024px) {
  .bottom-banner {
    padding: 4rem 3.2rem 6.4rem;
    max-width: none;
    margin: 0 auto;
  }
}
.bottom-banner .banner-wrap {
  display: flex;
  flex-direction: column;
  padding: 3.2rem 2.4rem;
  background: linear-gradient(135deg, #F6F6F7 0%, rgba(245, 158, 11, 0.08) 100%);
  border-radius: 20px;
  position: relative;
  overflow: hidden;
  text-decoration: none;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .bottom-banner .banner-wrap {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    padding: 4rem 3.2rem;
    border-radius: 24px;
  }
}
@media (min-width: 1024px) {
  .bottom-banner .banner-wrap {
    padding: 4.8rem 4rem;
  }
}
.bottom-banner .banner-wrap::before {
  content: "";
  position: absolute;
  right: -60px;
  top: -60px;
  width: 180px;
  height: 180px;
  background: linear-gradient(135deg, rgba(24, 24, 27, 0.1), rgba(245, 158, 11, 0.1));
  border-radius: 9999px;
}
@media (min-width: 768px) {
  .bottom-banner .banner-wrap::before {
    width: 280px;
    height: 280px;
    right: -80px;
    top: -80px;
  }
}
.bottom-banner .banner-wrap::after {
  content: "";
  position: absolute;
  right: 40px;
  bottom: -40px;
  width: 100px;
  height: 100px;
  background: rgba(24, 24, 27, 0.08);
  border-radius: 9999px;
}
@media (min-width: 768px) {
  .bottom-banner .banner-wrap::after {
    width: 160px;
    height: 160px;
    right: 80px;
    bottom: -60px;
  }
}
.bottom-banner .banner-wrap:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 60px rgba(24, 24, 27, 0.15);
}
.bottom-banner .banner-wrap .content {
  position: relative;
  z-index: 1;
}
.bottom-banner .banner-wrap .title {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  color: #18181B;
  margin-bottom: 0.8rem;
}
@media (min-width: 768px) {
  .bottom-banner .banner-wrap .title {
    font-size: 2.8rem;
  }
}
@media (min-width: 1024px) {
  .bottom-banner .banner-wrap .title {
    font-size: 3.6rem;
  }
}
.bottom-banner .banner-wrap .txt {
  font-size: 1.4rem;
  font-weight: 500;
  color: #0D0D0F;
}
@media (min-width: 768px) {
  .bottom-banner .banner-wrap .txt {
    font-size: 1.6rem;
  }
}
.bottom-banner .banner-wrap .banner-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  margin-top: 2.4rem;
  padding: 1.2rem 2.4rem;
  background: #18181B;
  color: #FFFFFF;
  font-size: 1.2rem;
  font-weight: 700;
  border-radius: 9999px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  position: relative;
  z-index: 1;
}
@media (min-width: 768px) {
  .bottom-banner .banner-wrap .banner-btn {
    margin-top: 0;
    padding: 1.6rem 3.2rem;
    font-size: 1.4rem;
  }
}
.bottom-banner .banner-wrap .banner-btn::after {
  content: "→";
  transition: transform 150ms cubic-bezier(0, 0, 0.2, 1);
}
.bottom-banner .banner-wrap .banner-btn:hover {
  background: #0D0D0F;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(24, 24, 27, 0.3);
}
.bottom-banner .banner-wrap .banner-btn:hover::after {
  transform: translateX(4px);
}

/* ══════════════════════════════════════════════════════════════════════════
   레거시 호환
   ══════════════════════════════════════════════════════════════════════════ */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 2.4rem;
}
@media (min-width: 1024px) {
  .section-header {
    margin-bottom: 3.2rem;
  }
}

.section-title {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  color: #171717;
}
@media (min-width: 1024px) {
  .section-title {
    font-size: 2.8rem;
  }
}

#app .title {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-weight: 700;
  color: #171717;
  letter-spacing: -0.025em;
}

#app .login-box .kakao-login {
  display: flex;
  justify-content: center;
  margin-top: 20px;
}
#app .login-box .kakao-login .login-inner {
  padding: 12px 60px;
  background-color: #ffd600;
  border-radius: 50px;
  font-size: 1.1em;
  font-weight: 600;
  color: var(--dark-2-color);
}
#app .login-box .kakao-login .login-inner img {
  width: 13px;
  margin-right: 4px;
  vertical-align: middle;
}
#app .login-form {
  width: 254px;
  margin: 0 auto;
}
#app .login-form input.login-input {
  width: 100%;
  padding: 12px 22px;
  margin-bottom: 8px;
  border: none;
  border-radius: 50px;
  background-color: #efefef;
  box-sizing: border-box;
  font-size: 13px;
  font-weight: 600;
  color: #898989;
}
#app .login-form input.login-input::placeholder {
  font-size: 13px;
  font-weight: 600;
  color: #898989;
}
#app .login-form input.login-input:nth-of-type(2) {
  margin-bottom: 0;
}
#app .login-form .remember-me {
  padding: 12px 0;
  display: flex;
  align-items: center;
}
#app .login-form .remember-me .form-check-label {
  font-size: 1.3em;
  line-height: 1.3846em;
  color: var(--gray-6-color);
  cursor: pointer;
}
#app .login-form .remember-me .form-check-input {
  width: 15px;
  height: 15px;
  border-radius: 50%;
  margin: 0 5px 0 0;
  border: none;
  appearance: none;
  -webkit-appearance: none;
  background: url("../img/icon/select4.png") no-repeat;
  background-size: contain;
  cursor: pointer;
}
#app .login-form .remember-me input[type=checkbox]:checked {
  background: url("../img/icon/select.png") no-repeat;
  background-size: contain;
}
#app .login-form .login-btn {
  display: flex;
  flex-direction: column;
  row-gap: 4px;
}
#app .login-form .login-btn .btn_submit {
  width: 100%;
  font-size: 1.3em;
  font-weight: 600;
  line-height: 1.3;
  color: #fff;
  padding: 12px 0;
  border-radius: 50px;
  border: none;
  background: var(--primary-color);
  box-sizing: border-box;
  border: 1px solid var(--primary-color);
  text-align: center;
}
#app .login-form .login-btn .signup-btn {
  display: block;
  color: var(--primary-color);
  background: #fff;
}
#app .info-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 254px;
  margin: 12px auto;
}
#app .info-link .info-ls {
  font-size: 1.3em;
  line-height: 1.384em;
  color: var(--gray-6-color);
  cursor: pointer;
}

#app {
  /*** cart ***/
}
#app .cart {
  padding: 0 20px;
}
#app .cart .note-info {
  margin: 60px 0;
}
#app .cart .note-info .note {
  font-size: 1.5em;
  color: var(--primary-color);
  text-align: center;
  letter-spacing: -1px;
}
#app .cart .note-info .note .space-box {
  display: block;
  height: 20px;
}
#app .cart .sub-title .title {
  font-size: 1.4em;
  font-weight: 400;
  color: var(--dark-2-color);
}
#app .cart .sub-box {
  padding: 16px 0;
  border-bottom: 1px solid var(--primary-color);
}
#app .cart .total-price {
  border-bottom: 1px solid var(--primary-color);
}
#app .cart .total-price .price {
  padding: 16px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--gray-2-color);
}
#app .cart .total-price .price:last-child {
  border-bottom: none;
}
#app .cart .total-price .price .price-name {
  font-size: 1.4em;
  color: var(--gray-5-color);
}
#app .cart .total-price .price .pay {
  font-size: 1.4em;
  font-weight: 500;
  letter-spacing: -0.03em;
  color: var(--dark-1-color);
}
#app .cart .total-price .price {
  /*&.total{
      .pay{
          font-size:1.8em;
          font-weight:600;
          line-height:1.1933em;
          color:#FF2F41;
      }
  }*/
}
#app .cart .reserve .login-box {
  padding-bottom: 20px;
  border-bottom: 1px solid #B7D0E2;
}
#app .cart .reserve .login-box .note {
  font-size: 1.2em;
  line-height: 1.1933em;
  color: var(--gray-5-color);
  font-weight: 400;
  padding-top: 4px;
}
#app .cart .reserve .login-info {
  margin-top: 16px;
}
#app .cart .reserve .login-info .info-input {
  font-size: 1.2em;
  font-weight: 400;
  color: var(--gray-5-color);
  border: 1px solid var(--gray-2-color);
  width: 100%;
  padding: 10px;
  box-sizing: border-box;
  outline: none;
}
#app .cart .reserve .login-info .info-input:last-child {
  margin-top: 12px;
}
#app .cart .reserve .no-reserve {
  margin-top: 16px;
}
#app .cart .reserve .after {
  display: none;
}
#app .cart .reserve.on .login-box {
  display: none;
}
#app .cart .reserve.on .after {
  display: block;
}
#app .cart .reserve.on .no-reserve {
  display: none;
}
#app .cart .pickup {
  padding: 16px 0 40px;
}
#app .cart .pickup .pick-store .note {
  font-size: 1.2em;
  color: #D32F2F;
  padding-top: 4px;
}
#app .cart .pickup .pick-store .pick-item {
  font-size: 1.4em;
  font-weight: 600;
  line-height: 1.2em;
  width: 100%;
  padding: 16.5px 10px;
  margin-top: 16px;
  box-sizing: border-box;
  display: inline-block;
  text-align: center;
  border-radius: 10px;
  cursor: pointer;
}
#app .cart .pickup .pick-store .pick-item.pick-select {
  border: 1px solid var(--primary-color);
  color: var(--primary-color);
}
#app .cart .pickup .pick-store .pick-item.pick-reserve {
  color: var(--gray-5-color);
  border: 1px solid var(--gray-4-color);
  background-color: var(--gray-4-color);
}
#app .cart .pickup .pick-store .pickup-select {
  margin-top: 40px;
  display: none;
}
#app .cart .pickup .pick-store .pickup-select .store-list {
  padding: 0 0 0 27px;
  border-top: none;
  position: relative;
  width: 100%;
  cursor: inherit;
}
#app .cart .pickup .pick-store .pickup-select .store-list::after {
  background: url("../img/icon/location.png") no-repeat;
  content: "";
  width: 19px;
  height: 19px;
  background-size: contain;
  left: 0;
  top: 0;
  position: absolute;
}
#app .cart .pickup .pick-store .pickup-select .store-list .change-btn {
  display: inline-block;
  font-size: 1.2em;
  color: var(--dark-1-color);
  line-height: 1.2em;
  padding: 4px 12px;
  background-color: var(--gray-2-color);
  position: absolute;
  right: 0;
  top: 0;
}
#app .cart .pickup .pick-store .pickup-select .map {
  margin-top: 20px;
}
#app .cart .pickup .pick-store .pickup-select .map img {
  width: 100%;
}
#app .cart .pickup.on .note {
  display: none;
}
#app .cart .pickup.on .pick-select {
  display: none;
}
#app .cart .pickup.on .pick-item.pick-reserve {
  background-color: var(--primary-color);
  color: #fff;
  border: 1px solid var(--primary-color);
  margin-top: 20px;
}
#app .cart .pickup.on .pickup-select {
  display: block;
}
#app {
  /*** reserve-note ***/
}
#app .reserve-note {
  padding: 20px 20px 40px;
  background-color: #DCECF5;
}
#app .reserve-note .note-title {
  font-size: 1.5em;
  font-weight: 600;
  color: var(--primary-color);
}
#app .reserve-note .note-list .note-item {
  font-size: 1.4em;
  line-height: 1.5em;
  letter-spacing: -0.07em;
  color: var(--gray-6-color);
  padding-top: 4px;
}
#app {
  /*** store-page ***/
}
#app .store-page {
  display: none;
  position: fixed;
  top: 117px;
  max-width: 640px;
  width: 100%;
  z-index: 1000;
  background-color: #fff;
  min-height: calc(100vh - 182px);
}
#app .store-page.on {
  display: block;
}
#app .store-page .st-hd {
  padding: 8px 12px;
  border-bottom: 1px solid var(--primary-color);
  position: relative;
}
#app .store-page .st-hd .back {
  width: 24px;
  display: block;
}
#app .store-page .st-hd .back img {
  width: 100%;
}
#app .store-page .st-hd .st-tit {
  font-size: 1.6em;
  font-weight: 700;
  color: var(--primary-color);
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
#app .store-page .tab-wrap {
  margin-top: 0;
}
#app .store-page .tab-contents {
  display: none;
  background-color: #fff;
}
#app .store-page .tab-contents.current {
  display: block;
}
#app .store-page .tab-contents .map {
  height: calc(100vh - 362px);
}
#app .store-page .tab-contents .map img {
  height: 100%;
}
#app .store-bg {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 10;
  display: none;
  z-index: 999;
}
#app .store-bg.on {
  display: block;
}

/*** tab ***/
.tab-wrap {
  display: flex;
  padding-top: 20px;
}
.tab-wrap .tab-list {
  width: 50%;
}
.tab-wrap .tab-list .tab-item {
  color: var(--gray-3-color);
  font-size: 1.6em;
  font-weight: 500;
  line-height: 1.2em;
  display: inline-block;
  width: 100%;
  text-align: center;
  padding: 10px 0 9px;
  box-sizing: border-box;
  border-bottom: 1px solid var(--gray-3-color);
  cursor: pointer;
}
.tab-wrap .tab-list.active .tab-item {
  font-weight: 700;
  color: #212121;
  border-bottom: 1px solid var(--blue-1-color);
}

/*** search-form ***/
.input-box {
  width: 100%;
}
.input-box .search-form {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--primary-color);
}
.input-box .search-form .search-contents {
  padding: 0 0 0 4px;
  border: none;
  outline: none;
  font-size: 1.6em;
  line-height: 3.2rem;
  height: 32px;
  font-weight: 500;
  color: #212121;
  width: 100%;
}
.input-box .search-form .search-contents::placeholder {
  font-size: 16px;
  color: var(--gray-5-color);
  line-height: 1.2em;
  font-weight: 500;
}
.input-box .btn_search {
  border: none;
  background: none;
}
.input-box .btn_search img {
  width: 21px;
  margin-right: 4px;
}

.store-search {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  margin: 20px;
}
.store-search .area-select {
  width: 81px;
  outline: none;
  border: none;
  border-bottom: 1px solid var(--primary-color);
  font-size: 1.6em;
  font-weight: 500;
  color: #212121;
  padding: 6px 4px;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: url("../img/icon/b-arrow2.png") no-repeat;
  background-size: 19px 19px;
  background-position: right center;
}

/*** store ***/
.tab-contents .store {
  height: inherit;
}

.store .map {
  height: calc(100vh - 305px);
}
.store .map img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.store .map {
  /*** map내에 매장명 custom***/
}
.store .map .info-title {
  font-size: 1.2rem;
  font-weight: 500;
  color: #fff;
  text-align: center;
  background: rgba(0, 0, 0, 0.5);
  border-radius: 15px;
  padding: 0.8rem;
  position: relative;
  top: -8px;
}
.store .map .info-title:after {
  background: none !important;
  height: 0 !important;
  width: 0 !important;
  border-left: 9px solid transparent;
  border-right: 9px solid transparent;
  border-bottom: 8px solid rgba(0, 0, 0, 0.5);
  position: absolute;
  content: "";
  left: 50%;
  top: 100%;
  transform: translateX(-50%) rotate(180deg);
}

/*** view-list ***/
.view-list {
  position: fixed;
  z-index: 899;
  bottom: 60px;
  left: 50%;
  transform: translate(-50%, 0);
  right: 0;
  background-color: #fff;
  max-width: 640px;
  width: 100%;
  border-radius: 10px 10px 0 0;
}
.view-list .view-list-title {
  padding: 16px;
  text-align: center;
  box-shadow: 0px -7px 9px rgba(0, 0, 0, 0.1);
  cursor: pointer;
  border-radius: 10px 10px 0 0;
}
.view-list .view-list-title.active {
  border-bottom: 1px solid var(--blue-1-color);
}
.view-list .view-list-title .title {
  font-size: 1.6em;
  font-weight: 600;
  color: var(--primary-color) !important;
}
.view-list .view-list-contents {
  display: none;
  max-height: 245px;
  overflow-y: auto;
  -ms-overflow-style: none; /* 인터넷 익스플로러 스크롤바 없애기*/
  scrollbar-width: none; /* 파이어폭스 스크롤바 없애기 */
}
.view-list .view-list-contents::-webkit-scrollbar {
  display: none;
}
.view-list .view-list-contents .ls-btn-wr:first-child {
  border-top: none;
}

.ls-btn-wr {
  position: relative;
  border-top: 1px solid var(--blue-1-color);
  padding: 16px;
}
.ls-btn-wr:first-child {
  border-top: 0;
}
.ls-btn-wr .eye-click {
  position: absolute;
  width: 24px;
  height: 24px;
  right: 16px;
  top: 16px;
  background: url("../img/icon/eye_heart_full.png");
  background-size: cover;
}
.ls-btn-wr .eye-click.no-interest {
  background: url("../img/icon/eye_heart.png");
  background-size: cover;
}

.store-list {
  width: calc(100% - 26px);
  box-sizing: border-box;
  text-align: left;
  cursor: pointer;
}
.store-list .store-name {
  font-size: 1.6em;
  font-weight: 700;
  color: #212121;
}
.store-list .store-add {
  font-size: 1.2em;
  font-weight: 500;
  color: var(--gray-6-color);
  display: block;
  padding-top: 8px;
}
.store-list .store-number {
  font-size: 1.2em;
  font-weight: 500;
  color: var(--gray-6-color);
  display: inline-block;
  position: relative;
  padding-top: 8px;
}
.store-list .store-number::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  background-color: var(--gray-6-color);
  left: 0;
  bottom: 0;
}

/*** interest-store ***/
.interest-store {
  margin-bottom: 200px;
}

#app {
  /*** mypage ***/
}
#app .mypage .mypage-note {
  margin: 60px auto;
}
#app .mypage .mypage-note .note {
  text-align: center;
  font-size: 1.5em;
  letter-spacing: -1px;
  color: var(--primary-color);
}
#app .mypage .mypage-note .img-box {
  text-align: center;
  margin: 20px auto 0;
  width: 90%;
  max-width: 290px;
}
#app .mypage .mypage-note .img-box img {
  width: 100%;
}
#app .mypage .mypage-note .kakao-login {
  margin-top: 40px;
}
#app .mypage .mypage-note .kakao-login .login-inner {
  padding: 12px 22px;
  font-size: 1.3em;
  line-height: 1.2em;
}
#app .mypage .mypage-note .kakao-login .login-inner img {
  margin-right: 9.5px;
}
#app {
  /*** mypage-login ***/
}
#app .mypage-login {
  padding-bottom: 4rem;
}
#app .mypage-login .member {
  padding: 40px 20px;
  background-color: #dcecf5;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#app .mypage-login .member .member-info {
  font-size: 2.1em;
  line-height: 1.4em;
  color: #1b4469;
}
#app .mypage-login .member .member-info .name {
  font-weight: 700;
}
#app .mypage-login .member .modi {
  text-align: center;
  cursor: pointer;
}
#app .mypage-login .member .modi .modi-label {
  display: block;
  font-size: 1.2em;
  font-weight: 500;
  color: #5f84a1;
  padding-top: 4px;
}
#app .mypage-login .mypage-list {
  display: block;
}
#app .mypage-login .mypage-list .mypage-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 20px;
  border-bottom: 1px solid var(--gray-1-color);
  background-color: #fff;
}
#app .mypage-login .mypage-list .mypage-item .list-name {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 1.4em;
  font-weight: 500;
  color: var(--gray-6-color);
}
#app .mypage-login .mypage-list .mypage-item .list-name img {
  width: 24px;
}
#app .mypage-login .mypage-list .mypage-item .list-name .store-num {
  font-size: 0.7em;
  font-weight: 500;
  color: #fff;
  display: inline-block;
  padding: 2px 7px;
  background-color: var(--primary-color);
  border-radius: 50px;
}
#app .mypage-login .mypage-list .mypage-item .list-count {
  font-size: 1.4em;
  font-weight: 500;
  color: var(--gray-6-color);
  display: flex;
  align-items: center;
}
#app .mypage-login .mypage-list .mypage-item .list-count .count-num {
  font-size: 21px;
  line-height: 1.4em;
  color: var(--primary-color);
  font-weight: 700;
  padding-right: 4px;
}
#app .mypage-login .mypage-list .mypage-item .arrow-btn {
  width: 17px;
  line-height: 0;
}
#app .mypage-login .mypage-list .mypage-item .arrow-btn img {
  width: 100%;
}
#app .mypage-login .mypage-list.etc {
  padding: 0 0 20px 0;
  background-color: var(--gray-1-color);
}
#app .mypage-login .mypage-list.etc .mypage-item {
  padding: 16px 20px;
}
#app .mypage-login .mypage-list.etc .mypage-item .list-name {
  gap: 4px;
}
#app .mypage-login .logout-btn {
  text-align: center;
}
#app .mypage-login .logout-btn .logout {
  font-size: 1.1em;
  color: #848484;
  position: relative;
  letter-spacing: -0.04em;
  display: inline-block;
  cursor: pointer;
  line-height: 1.2rem;
  text-decoration: underline;
  padding: 2rem 0;
}
#app .mypage-login {
  /*** info-check ***/
}
#app .mypage-login .info-check {
  display: none;
}
#app .mypage-login .info-check.on {
  display: block;
}
#app .mypage-login .info-check .check-input-form .check-input-inner:first-child {
  padding-bottom: 16px;
}
#app .mypage-login .info-check .check-input-form .check-input-inner .cont {
  padding: 8px 12px;
  margin-top: 4px;
  font-size: 1.4em;
  color: var(--dark-2-color);
}
#app {
  /*** info-find ***/
}
#app .info-find {
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  background-color: #fff;
  border-radius: 5px;
  z-index: 1000;
  padding: 40px 29px;
  width: calc(100% - 40px);
  box-sizing: border-box;
  display: none;
  max-width: 350px;
}
#app .info-find.on {
  display: block;
}
#app .info-find .find-tit {
  font-size: 20px;
  font-weight: 700;
  color: #212121;
  text-align: center;
}
#app .info-find .note {
  font-size: 1.5em;
  letter-spacing: -1px;
  color: #212121;
  padding-top: 4px;
  text-align: center;
}
#app .info-find .check-input-form {
  margin: 40px 0;
}
#app .info-find .check-input-form .info-wr-label {
  color: var(--dark-2-color);
  font-size: 1.4em;
  font-weight: 600;
  display: block;
}
#app .info-find .check-input-form .info-wr-input {
  font-size: 14px;
  font-weight: 400;
  color: var(--gray-4-color);
  border: none;
  border-bottom: 1px solid var(--gray-3-color);
  padding: 8px 12px;
  width: 100%;
  box-sizing: border-box;
  margin-top: 4px;
  outline: none;
}
#app .info-find .check-input-form .info-wr-input::placeholder {
  font-size: 14px;
  font-weight: 400;
  color: var(--gray-4-color);
}
#app .info-find .confirm-btn {
  text-align: center;
  display: block;
  margin-top: 20px;
}
#app .info-find .confirm-btn input {
  font-size: 1.3em;
  font-weight: 600;
  color: #fff;
  padding: 12px 116px;
  border-radius: 50px;
  border: none;
  background: var(--primary-color);
  line-height: 1.2em;
  display: inline-block;
  cursor: pointer;
}
#app .info-find .btn_submit {
  font-size: 1.3em;
  font-weight: 600;
  color: #fff;
  padding: 1.2rem 0;
  border-radius: 50px;
  border: none;
  background: var(--primary-color);
  line-height: 1.2em;
  display: inline-block;
  cursor: pointer;
  width: 98%;
  max-width: 254px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
}
#app .mypage-bg {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 999;
  display: none;
}
#app .mypage-bg.on {
  display: block;
}
#app .exit-btn {
  position: absolute;
  right: 6px;
  top: 6px;
  width: 32px;
  cursor: pointer;
}
#app .exit-btn img {
  width: 100%;
}

/*** couponbox ***/
.my-tit {
  text-align: center;
  padding: 40px 0;
}
.my-tit .title {
  font-size: 20px;
  font-weight: 700;
}
.my-tit .txt {
  font-size: 1.5em;
  color: #212121;
  letter-spacing: -1px;
  padding-top: 4px;
}

.couponbox {
  padding: 0 20px 40px;
}
.couponbox .coupon-list .coupon-cont {
  background-color: #efefef;
  border-radius: 10px;
  padding: 2rem;
  position: relative;
  margin-bottom: 16px;
}
.couponbox .coupon-list .coupon-cont:last-child {
  margin-bottom: 40px;
}
.couponbox .coupon-list .coupon-cont .coupon-top {
  margin-bottom: 1.2rem;
}
.couponbox .coupon-list .coupon-cont .coupon-top .day {
  color: var(--primary-color);
  font-size: 1.6em;
  font-weight: 700;
}
.couponbox .coupon-list .coupon-cont .coupon-top .term {
  font-size: 1.2em;
  color: #616161;
}
.couponbox .coupon-list .coupon-cont .cont {
  padding-top: 12px;
  border-top: 1px solid #fff;
}
.couponbox .coupon-list .coupon-cont .cont .coupon-name {
  display: block;
  color: #616161;
  font-size: 1.6em;
  font-weight: 500;
}
.couponbox .coupon-list .coupon-cont .cont .dis-price {
  display: block;
  color: #616161;
  font-size: 1.6em;
  font-weight: 700;
  padding-top: 4px;
}
.couponbox .coupon-list .coupon-cont .cont .note {
  display: block;
  color: #90aec4;
  font-size: 1.2em;
  letter-spacing: -1px;
  padding-top: 4px;
}
.couponbox .coupon-list .coupon-cont .cont .note.min-price {
  padding-top: 12px;
}
.couponbox .coupon-list .coupon-cont .apply {
  font-size: 1.4em;
  font-weight: 500;
  line-height: 1.2em;
  color: #616161;
  display: inline-block;
  padding: 8px 12px;
  border-radius: 2px;
  background-color: #fff;
  position: absolute;
  right: 20px;
  bottom: 21px;
}

#app {
  /*** mileage ***/
}
#app .mileage {
  padding: 0 20px 40px;
}
#app .mileage .total-mile {
  border-top: 1px solid var(--blue-1-color);
  border-bottom: 1px solid var(--blue-1-color);
  padding: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#app .mileage .total-mile .total-label {
  font-size: 1.4em;
  line-height: 1.2857em;
  color: #212121;
  font-weight: 500;
}
#app .mileage .total-mile .total-price {
  font-size: 1.4em;
  line-height: 1.2857em;
  color: var(--primary-color);
  font-weight: 700;
}
#app .mileage .mileage-list {
  margin-top: 40px;
}
#app .mileage .mileage-list .mileage-cont {
  background-color: #efefef;
  border-radius: 10px;
  padding: 16px 20px;
  margin-bottom: 8px;
}
#app .mileage .mileage-list .mileage-cont:last-child {
  margin-bottom: 0px;
}
#app .mileage .mileage-list .mileage-cont .mileage-top .term {
  font-size: 1.2em;
  color: #616161;
}
#app .mileage .mileage-list .mileage-cont .cont {
  margin-top: 12px;
  border-top: 1px solid #fff;
  padding-top: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#app .mileage .mileage-list .mileage-cont .cont .note {
  font-size: 1.4em;
  font-weight: 500;
  color: #616161;
}
#app .mileage .mileage-list .mileage-cont .cont .note.mile {
  font-weight: 600;
}

/*** modify ***/
.modify .mymodify-tit-wr {
  margin: 40px 0;
}
.modify .mymodify-tit-wr .mymodify-tit {
  font-size: 20px;
  text-align: center;
  color: #212121;
  font-weight: 700;
}

.my-modify-hd {
  padding: 12px 20px;
  background-color: #dcecf5;
}
.my-modify-hd .tit {
  font-size: 1.3rem;
  line-height: 1.8rem;
  color: #1b4469;
}

.my-modify {
  margin: 40px 20px;
}
.my-modify .my-list {
  margin-bottom: 36px;
}
.my-modify .my-list .my-l {
  font-size: 1.4rem;
  color: var(--dark-2-color);
  font-weight: 600;
  position: relative;
  padding-right: 12px;
}
.my-modify .my-list .my-l::after {
  position: absolute;
  content: "";
  background: url("../img/icon/star.png") no-repeat;
  width: 10px;
  height: 10px;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  background-size: contain;
}
.my-modify .my-list .my-l.my-ns::after {
  background: none;
}
.my-modify .my-list .my-input-form {
  position: relative;
}
.my-modify .my-list .my-input {
  width: 100%;
  outline: none;
  padding: 8px 12px;
  border: none;
  border-bottom: 1px solid var(--gray-3-color);
  box-sizing: border-box;
  font-size: 1.4em;
  font-weight: 400;
  line-height: 1.2em;
  color: var(---dark-2-color);
  margin-top: 4px;
}
.my-modify .my-list .my-input::placeholder {
  color: var(--gray-4-color);
}
.my-modify .my-list input[type=file] {
  margin-top: 6px;
  width: calc(100% - 84px);
  color: var(--gray-4-color);
}
.my-modify .my-list input[type=file]::file-selector-button {
  display: none;
}
.my-modify .my-list .file-select {
  font-size: 14px;
  line-height: 1.2em;
  font-weight: 600;
  color: var(--primary-color);
  border: 1px solid var(--primary-color);
  border-radius: 5px;
  padding: 6.5px 12px;
  position: absolute;
  right: 0;
  bottom: 1.5px;
}
.my-modify .my-list .my-note {
  display: block;
  font-size: 1.1em;
  color: var(--gray-5-color);
  font-weight: 400;
  padding-top: 4px;
}
.my-modify .my-list .postal-box .postal-input-form {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.my-modify .my-list .postal-box .postal-input-form .my-input {
  margin-top: 6px;
  max-width: 242px;
  width: calc(100% - 122px);
}
.my-modify .my-list .postal-box .my-input {
  margin-top: 8px;
}
.my-modify .my-list .postal-box .search-btn {
  font-size: 1.4em;
  font-weight: 600;
  color: var(--primary-color);
  padding: 6.5px 12px;
  border: 1px solid var(--primary-color);
  border-radius: 5px;
  line-height: 1.2em;
  background-color: #fff;
}
.my-modify .my-list .tel-input-form {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--gray-6-color);
}
.my-modify .my-list .tel-input-form .tel-input {
  width: 33.33%;
  text-align: center;
  font-size: 1.6em;
  font-weight: 400;
  color: var(--gray-3-color);
  padding: 10px 12px;
}
.my-modify .my-list .tel-input-form .tel-input::placeholder {
  font-weight: 400;
}
.my-modify .my-list .tel-input-form .tel-select-box {
  text-align: center;
  appearance: none;
  background: url("../img/icon/b-arrow.png") no-repeat;
  background-size: 18px 18px;
  background-position: center right;
}
.my-modify .my-list .setting-check-form {
  display: flex;
  gap: 20px;
  align-items: center;
  justify-content: flex-start;
  padding-top: 16px;
}
.my-modify .my-list .setting-check-form .setting-check-inner input {
  appearance: none;
  -webkit-appearance: none;
  margin: 0;
  cursor: pointer;
}
.my-modify .my-list .setting-check-form .setting-check-inner label {
  padding-left: 22px;
  font-size: 1.4em;
  font-weight: 500;
  line-height: 1.2857em;
  color: var(--dark-2-color);
  position: relative;
  cursor: pointer;
}
.my-modify .my-list .setting-check-form .setting-check-inner label::after {
  position: absolute;
  content: "";
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1px solid var(--gray-5-color);
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  box-sizing: border-box;
}
.my-modify .my-list .setting-check-form .setting-check-inner input[type=radio]:checked + label {
  position: relative;
}
.my-modify .my-list .setting-check-form .setting-check-inner input[type=radio]:checked + label::after {
  position: absolute;
  content: "";
  background: url("../img/icon/select.png") no-repeat;
  background-size: cover;
  border: none;
}
.my-modify .my-list .note {
  font-size: 1.2em;
  font-weight: 500;
  color: var(--gray-5-color);
  padding-top: 8px;
}
.my-modify .my-list2 .my-l {
  line-height: 1.2857em;
}
.my-modify .my-list2 .sns-kakao {
  display: inline-block;
  padding-top: 12px;
}
.my-modify .my-list2 .sns-kakao img {
  width: 24px;
}
.my-modify .button-wr {
  justify-content: center;
  gap: 12px;
  padding-top: 20px;
}
.my-modify .button-wr .btn, .my-modify .button-wr .btn-primary, .my-modify .button-wr .btn-secondary, .my-modify .button-wr .btn-outline, .my-modify .button-wr .btn-ghost, .my-modify .button-wr .btn-danger, .my-modify .button-wr .btn-success, .my-modify .button-wr .btn-dark, .my-modify .button-wr .btn-white, .my-modify .button-wr .ds_btn, .my-modify .button-wr .cart-btn,
.my-modify .button-wr .buy-btn, .my-modify .button-wr .social-btn {
  padding: 0 23px;
  cursor: pointer;
  width: auto;
}

/*** resrvebox***/
.reserve-bg {
  background-color: #dcecf5;
}

.booking-tit {
  padding: 5.1rem 0 5.2rem;
}

.reservebox {
  padding: 0 20px 40px;
}
.reservebox .reserve-list .reserve-cont {
  margin-top: 1.2rem;
  background-color: #fff;
  border-radius: 10px;
  padding: 1.6rem 2rem;
}
.reservebox .reserve-list .reserve-cont:first-child {
  margin-top: 0;
}
.reservebox .reserve-list .reserve-cont .wr-top {
  display: flex;
  flex-direction: column;
}
.reservebox .reserve-list .reserve-cont .wr-top .rs-num {
  font-size: 1.2em;
  line-height: 1.2rem;
}
.reservebox .reserve-list .reserve-cont .wr-top .date {
  font-size: 1.2rem;
  margin-top: 0.4rem;
}
.reservebox .reserve-list .reserve-cont .pd-cont {
  border-top: none;
  padding: 1.2rem 0 2.4em;
}
.reservebox .reserve-list .reserve-cont .status-wr {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
}
.reservebox .reserve-list .reserve-cont .status-wr .current-status {
  font-size: 1.4em;
  font-weight: 600;
  color: #212121;
}
.reservebox .reserve-list .reserve-cont .status-wr .current-status.status-cancel {
  color: #d32f2f;
}
.reservebox .reserve-list .reserve-cont .status-wr .reset-btn {
  font-size: 1.2em;
  line-height: 1.2em;
  color: var(--gray-5-color);
  border-bottom: 1px solid var(--gray-5-color);
}
.reservebox {
  /* 예약내역조회 없을 시 */
}
.reservebox .none-have {
  padding-top: 23%;
}
.reservebox .none-have .txt {
  color: #b7d0e2;
}

/*** resrvebox-detail***/
.reservebox-detail {
  padding: 0 2rem 4rem;
}
.reservebox-detail .detail-list-cont {
  background-color: #fff;
  border-radius: 10px;
  margin-bottom: 2rem;
}
.reservebox-detail .detail-list-cont:last-child {
  margin-bottom: 0;
}
.reservebox-detail .detail-list-cont .detail-header {
  padding: 2.2rem 2rem 1.6rem;
}
.reservebox-detail .detail-list-cont .detail-header .cont-title {
  font-size: 1.4rem;
  color: var(--primary-color);
  font-weight: 600;
}
.reservebox-detail .detail-list-cont .detail-section {
  padding: 0 2rem 2rem;
}
.reservebox-detail .detail-list-cont .detail-section .link-box {
  text-align: right;
  padding: 1.2rem 0 1.6rem;
}
.reservebox-detail .detail-list-cont .detail-section .link-box .reserve-write-link {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--primary-color);
  line-height: 1.68rem;
}
.reservebox-detail .detail-list-cont .detail-section .store-cont {
  padding: 0 2rem;
}
.reservebox-detail .detail-list-cont .detail-section .store-cont li {
  padding: 0.6rem 0;
}
.reservebox-detail .detail-list-cont .detail-section .store-cont .name {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--primary-color);
  padding: 0.8rem 0 1rem;
}
.reservebox-detail .detail-list-cont .detail-section .store-cont .info {
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--dark-1-color);
  position: relative;
  padding-left: 7.7rem;
}
.reservebox-detail .detail-list-cont .detail-section .store-cont .info .info-title {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  font-weight: 600;
}
.reservebox-detail .detail-list-cont .payment-section .detail-table-cont {
  font-weight: 500;
}
.reservebox-detail .detail-list-cont .payment-section .detail-table-title {
  font-weight: 600;
}
.reservebox-detail .detail-list-cont .map-section {
  padding: 0 1rem 1rem;
}
.reservebox-detail .detail-list-cont .map-section .map {
  margin: 3.6rem auto 0 !important;
  height: 32rem;
  overflow: hidden;
}
.reservebox-detail .detail-list-cont .map-section .map img {
  width: 100%;
}
.reservebox-detail {
  /* 예약취소 */
}
.reservebox-detail #sod_fin_cancel {
  margin-top: 2rem;
}
.reservebox-detail #sod_fin_cancel .fin_cancel_cont {
  font-size: 1.4rem;
  font-weight: 600;
  padding: 1.65rem 0;
  width: 100%;
  border-radius: 10px;
  line-height: 1.68rem;
  text-align: center;
}
.reservebox-detail #sod_fin_cancel p {
  color: var(--gray-5-color);
  background-color: var(--gray-4-color);
}
.reservebox-detail #sod_fin_cancel {
  /* 예약 취소하기 */
}
.reservebox-detail #sod_fin_cancel .sod_fin_c_btn {
  color: #fff;
  background-color: var(--primary-color);
}
.reservebox-detail #sod_fin_cancel #sod_cancel_pop {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.reservebox-detail #sod_fin_cancel #sod_cancel_pop #sod_fin_cancelfrm {
  background-color: #fff;
  border-radius: 5px;
  padding: 4rem 2.8rem;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 98%;
  max-width: 350px;
  box-sizing: border-box;
  text-align: center;
}
.reservebox-detail #sod_fin_cancel #sod_cancel_pop #sod_fin_cancelfrm h2 {
  font-size: 2rem;
  font-weight: 700;
  text-align: center;
}
.reservebox-detail #sod_fin_cancel #sod_cancel_pop .frm_input {
  padding: 0.8rem 1.2rem;
  color: var(--dark-2-color);
  border: none;
  width: 100%;
  box-sizing: border-box;
  border-bottom: 1px solid var(--gray-3-color);
  outline: 0;
  margin-top: 4rem;
}
.reservebox-detail #sod_fin_cancel #sod_cancel_pop .frm_input::placeholder {
  color: var(--gray-4-color);
}
.reservebox-detail #sod_fin_cancel #sod_cancel_pop .btn_frmline {
  font-size: 1.3rem;
  color: #fff;
  font-weight: 600;
  width: 90%;
  max-width: 254px;
  background-color: var(--primary-color);
  border-radius: 50px;
  line-height: 1.56rem;
  padding: 1.2rem 0;
  margin-top: 4rem;
}
.reservebox-detail #sod_fin_cancel #sod_cancel_pop .sod_cls_btn {
  position: absolute;
  right: 6px;
  top: 6px;
  width: 32px;
}
.reservebox-detail #sod_fin_cancel #sod_cancel_pop .sod_cls_btn i {
  text-indent: -999999px;
  width: 32px;
  height: 32px;
  background: url("../img/icon/close2.png") no-repeat;
  background-size: cover;
}
.reservebox-detail #sod_fin_cancel #sod_cancel_pop .sod_cls_btn img {
  width: 100%;
}

.pd-cont {
  border-top: 1px solid var(--gray-2-color);
  border-bottom: 1px solid var(--gray-2-color);
  padding: 12px 0;
  display: flex;
  align-items: center;
  gap: 12px;
}
.pd-cont .img-box {
  width: 77px;
}
.pd-cont .img-box img {
  width: 100%;
}
.pd-cont .pd-info .name {
  font-size: 1.4em;
  font-weight: 500;
  color: var(--dark-1-color);
  display: block;
}
.pd-cont .pd-info .figure {
  font-size: 1.2em;
  color: var(--dark-2-color);
  display: flex;
  align-items: center;
  padding: 4px 0 8px;
}
.pd-cont .pd-info .figure .option {
  color: #18181B;
  font-size: 1rem;
  padding: 2px 3px;
  background-color: #e2eaf6;
  border-radius: 2px;
  margin-right: 4px;
}
.pd-cont .pd-info .info {
  font-size: 1.4em;
  font-weight: 500;
  color: var(--gray-6-color);
  display: inline-block;
  padding-right: 17px;
  position: relative;
}
.pd-cont .pd-info .info::after {
  position: absolute;
  content: "";
  width: 1px;
  height: 12px;
  background-color: var(--gray-4-color);
  right: 7px;
  top: 50%;
  transform: translateY(-50%);
}
.pd-cont .pd-info .info:last-child::after {
  background: none;
}

#app {
  /*** likebox ***/
}
#app .likebox {
  margin: 0 20px;
  padding-bottom: 4rem;
}
#app .likebox .select-box {
  border-bottom: none;
}
#app .likebox .select-box .like-wr {
  padding: 19px 0 20px;
  display: flex;
  align-items: center;
  position: relative;
  border-bottom: 1px solid var(--gray-2-color);
}
#app .likebox .select-box .like-wr .item-contents {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-left: 30px;
}
#app .likebox .select-box .like-wr .item-contents .img-bx {
  width: 77px;
  line-height: 0;
}
#app .likebox .select-box .like-wr .item-contents .img-bx img {
  width: 100%;
}
#app .likebox .select-box .like-wr .item-contents .txt-box {
  margin-right: 3.5rem;
}
#app .likebox .select-box .like-wr .item-contents .txt-box .name {
  font-size: 1.4em;
  font-weight: 500;
  color: var(--dark-1-color);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  text-overflow: ellipsis;
  overflow: hidden;
}
#app .likebox .select-box .like-wr .item-contents .txt-box .like-date {
  font-size: 1.2rem;
  line-height: 1.8rem;
  color: #818181;
  margin-top: 0.4rem;
}
#app .likebox .select-box .like-wr .item-contents .txt-box .like-date .like-time {
  margin-left: 0.8rem;
}
#app .likebox .select-box .like-wr .like-del-btn {
  width: 34px;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
#app .likebox .select-box .like-wr .like-del-btn img {
  width: 100%;
}
#app .likebox .select-box .like-wr .like-del-btn .border-like {
  display: none;
}
#app .likebox .select-box .like-wr .like-del-btn.on .fill-like {
  display: none;
}
#app .likebox .select-box .like-wr .like-del-btn.on .border-like {
  display: block;
}
#app .likebox .button-wr {
  margin: 20px 0 0;
  padding: 0;
  display: inherit;
}
#app .likebox .button-wr .btn, #app .likebox .button-wr .btn-primary, #app .likebox .button-wr .btn-secondary, #app .likebox .button-wr .btn-outline, #app .likebox .button-wr .btn-ghost, #app .likebox .button-wr .btn-danger, #app .likebox .button-wr .btn-success, #app .likebox .button-wr .btn-dark, #app .likebox .button-wr .btn-white, #app .likebox .button-wr .ds_btn, #app .likebox .button-wr .cart-btn,
#app .likebox .button-wr .buy-btn, #app .likebox .button-wr .social-btn {
  width: 100%;
}
#app .likebox .button-wr .btn:not(.next-btn), #app .likebox .button-wr .btn-primary:not(.next-btn), #app .likebox .button-wr .btn-secondary:not(.next-btn), #app .likebox .button-wr .btn-outline:not(.next-btn), #app .likebox .button-wr .btn-ghost:not(.next-btn), #app .likebox .button-wr .btn-danger:not(.next-btn), #app .likebox .button-wr .btn-success:not(.next-btn), #app .likebox .button-wr .btn-dark:not(.next-btn), #app .likebox .button-wr .btn-white:not(.next-btn), #app .likebox .button-wr .ds_btn:not(.next-btn), #app .likebox .button-wr .cart-btn:not(.next-btn),
#app .likebox .button-wr .buy-btn:not(.next-btn), #app .likebox .button-wr .social-btn:not(.next-btn) {
  color: #212121;
}
#app .likebox .button-wr .btn.next-btn, #app .likebox .button-wr .next-btn.btn-primary, #app .likebox .button-wr .next-btn.btn-secondary, #app .likebox .button-wr .next-btn.btn-outline, #app .likebox .button-wr .next-btn.btn-ghost, #app .likebox .button-wr .next-btn.btn-danger, #app .likebox .button-wr .next-btn.btn-success, #app .likebox .button-wr .next-btn.btn-dark, #app .likebox .button-wr .next-btn.btn-white, #app .likebox .button-wr .next-btn.ds_btn, #app .likebox .button-wr .next-btn.cart-btn,
#app .likebox .button-wr .next-btn.buy-btn, #app .likebox .button-wr .next-btn.social-btn {
  margin-top: 8px;
}

/*** brand-story tab ***/
.ab1 {
  box-sizing: border-box;
  position: relative;
}
.ab1::after {
  position: absolute;
  content: "";
  left: 0;
  bottom: 0;
  top: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 0;
}
.ab1 video {
  overflow: hidden;
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.ab1 video[poster] {
  width: 100%;
  object-fit: cover;
}
.ab1 .tab-wr {
  padding: 40px 24px;
  width: 100%;
  box-sizing: border-box;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
}
.ab1 .tab-wr .tab-ls {
  display: block;
  font-size: 23px;
  line-height: 1.2em;
  color: var(--gray-4-color);
  font-weight: 600;
  padding: 24px 0 24px 20px;
  border: 1px solid var(--gray-4-color);
  margin-bottom: 12px;
}
.ab1 .tab-wr .tab-ls.active {
  color: #fff;
  border: 1px solid #fff;
  background-color: rgba(255, 255, 255, 0.3);
}
.ab1 .ab-txt-wr {
  padding: 40px 24px;
  width: 100%;
  box-sizing: border-box;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 1;
}
.ab1 .ab-txt-wr::after {
  position: absolute;
  content: "";
  left: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background: url("../img/web/png/bg2.png") no-repeat;
  z-index: 0;
}
.ab1 .ab-txt-wr .eyeiyagi {
  font-size: 55px;
  font-weight: 600;
  color: #fff;
  position: relative;
  z-index: 1;
}
.ab1 .ab-txt-wr .txt {
  font-size: 23px;
  font-weight: 600;
  color: #fff;
  padding-top: 20px;
  position: relative;
  z-index: 1;
}

/*** about ***/
.about .ab2 {
  padding: 80px 24px;
  background-color: #000;
}
.about .ab2 .story {
  padding: 20px;
  margin-bottom: 40px;
  height: 353px;
  box-sizing: border-box;
  position: relative;
  overflow: hidden;
}
.about .ab2 .story .story-bg-wr {
  height: 140%;
  top: 0;
  left: 0;
  margin: 0 auto;
  position: absolute;
  width: 100%;
}
.about .ab2 .story .story-bg-wr img {
  transform: translateY(-50%);
  width: 100%;
}
.about .ab2 .story .story-txt-wr {
  position: relative;
  z-index: 1;
}
.about .ab2 .story .story-txt-wr .story-tit {
  font-size: 20px;
  font-weight: 600;
  color: #fff;
}
.about .ab2 .story .story-txt-wr .story-txt {
  font-size: 1.6em;
  color: var(--gray-4-color);
  letter-spacing: -1px;
  padding-top: 20px;
  line-height: 1.6em;
}
.about .ab3 {
  padding: 80px 24px;
  background-color: #000;
}
.about .ab3 .value-wr {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.about .ab3 .value-wr .value {
  width: 270px;
  height: 270px;
  border: 1px solid var(--gray-4-color);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.about .ab3 .value-wr .value:nth-of-type(2) {
  margin: -70px 0;
}
.about .ab3 .value-wr .value .vl-tit {
  font-size: 20px;
  font-weight: 600;
  color: #fff;
  text-transform: uppercase;
}
.about .ab3 .value-wr .value .vl-txt {
  font-size: 1.6em;
  letter-spacing: -1px;
  color: var(--gray-4-color);
  text-transform: uppercase;
  padding-top: 20px;
}
.about .ab4 {
  padding: 80px 0;
  background-color: #000;
}
.about .ab4 .global-tit {
  font-size: 20px;
  font-weight: 600;
  color: #fff;
  text-align: center;
}
.about .ab4 .global {
  margin: 31px 0;
  padding: 0 24px;
}
.about .ab4 .global .global-ls {
  width: 100%;
  text-align: center;
  background-color: rgba(255, 255, 255, 0.2);
  padding: 20px 0;
  margin-bottom: 12px;
  font-size: 20px;
  text-align: center;
  color: var(--gray-4-color);
}
.about .ab4 .global .global-ls:last-child {
  margin-bottom: 0;
}
.about .ab4 .slide-bnn {
  padding: 12px 24px 13px;
  overflow: hidden;
  width: 100%;
  box-sizing: border-box;
}
.about .ab4 .slide-bnn .bnn-wr {
  transition-timing-function: linear;
  width: 100%;
}
.about .ab4 .slide-bnn .bnn-wr .bnn-ls {
  font-size: 1.6em;
  letter-spacing: -1px;
  color: var(--gray-4-color);
  width: max-content !important;
}
.about .ab4 .global-img {
  background-color: #000;
  margin-top: 46px;
  position: relative;
}
.about .ab4 .global-img img {
  width: 100%;
}

@media screen and (min-width: 640px) {
  .about .ab4 {
    padding: 8rem 0 0.5rem;
  }
}
#app {
  /*** brand ***/
}
#app .brand .br1 .eyeiyagi {
  line-height: 0.9em;
}
#app .brand .br2 {
  padding: 0 24px 80px;
  background-color: #000;
}
#app .brand .br2 .br-txt {
  font-size: 1.6em;
  letter-spacing: -1px;
  color: var(--gray-4-color);
  line-height: 1.6em;
}
#app .brand .br3 {
  padding: 80px 24px 160px;
  background-color: #000;
}
#app .brand .br3 .prof-txt {
  font-size: 20px;
  line-height: 1.405em;
  color: #fff;
  font-weight: 600;
  word-break: break-all;
}
#app .brand .br3 .prof-wr {
  margin-top: 40px;
  padding: 20px 16px 20px;
  background-color: rgba(255, 255, 255, 0.2);
}
#app .brand .br3 .prof-wr .prof {
  font-size: 40px;
  font-weight: 600;
  color: #fff;
  display: flex;
  align-items: center;
  gap: 12px;
}
#app .brand .br3 .prof-wr .prof .school {
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: -1px;
  color: var(--gray-1-color);
}
#app .brand .br3 .prof-wr .history {
  margin-top: 24px;
}
#app .brand .br3 .prof-wr .history .history-ls {
  font-size: 1.4em;
  letter-spacing: -1px;
  color: var(--gray-1-color);
  padding: 16px 0;
  border-top: 1px solid var(--gray-4-color);
  display: flex;
}
#app .brand .br3 .prof-wr .history .history-ls .year {
  width: 28.013%;
  display: inline-block;
}
#app .brand .br3 .prof-wr .history .history-ls .hs-cont {
  width: 71.987%;
  display: inline-block;
}
#app .brand .br3 .prof-wr .history .history-ls.ls-box .year {
  width: 46.254%;
}
#app .brand .br3 .prof-wr .history .history-ls.ls-box .hs-cont {
  width: 53.746%;
}
#app .brand .br4 {
  background-color: #000;
  padding: 0 24px;
}
#app .brand .br4 .labo-wr {
  text-align: center;
  padding-bottom: 80px;
}
#app .brand .br4 .labo-wr .labo {
  font-size: 20px;
  font-weight: 400;
  color: #fff;
  margin-bottom: 40px;
}
#app .brand .br4 .labo-wr img.img1 {
  width: 158px;
}
#app .brand .br4 .labo-wr img.img2 {
  width: 299px;
}
#app .brand .br4 .labo-wr img.img3 {
  width: 276px;
}
#app .brand .br4 .labo-wr img.img4 {
  width: 132px;
}
#app .brand .br4 .labo-wr .labo-swiper {
  overflow: hidden;
  position: relative;
}
#app .brand .br4 .labo-wr .labo-swiper .labo-txt {
  font-size: 1.6em;
  color: var(--gray-4-color);
  padding-top: 20px;
  letter-spacing: -1px;
}
#app .brand .br4 .labo-wr .labo-swiper .swiper-btn {
  background-image: none;
  width: auto;
  height: auto;
  margin-top: 0;
  transform: translateY(-50%);
}
#app .brand .br4 .labo-wr .labo-swiper .swiper-btn.swiper-button-next {
  right: 0;
}
#app .brand .br4 .labo-wr .labo-swiper .swiper-btn.swiper-button-prev {
  left: 0;
}

#app {
  /*** labo ***/
}
#app .lb1 .ab-txt-wr {
  padding: 20px 24px;
}
#app .lb1 .ab-txt-wr::after {
  background: none;
}
#app .lb1 .ab-txt-wr .txt2 {
  font-size: 1.6em;
  letter-spacing: -1px;
  color: var(--gray-4-color);
  line-height: 1.55em;
  padding-top: 40px;
  position: relative;
  z-index: 1;
}
#app .labo .lb1 .txt {
  color: var(--gray-1-color);
}
#app .labo .lb2 {
  text-align: center;
  padding: 0 24px;
}
#app .labo .lb2 .lab-story {
  margin-top: 160px;
  text-align: center;
}
#app .labo .lb2 .lab-story .lab-tit {
  font-size: 20px;
  color: var(--dark-2-color);
  font-weight: 600;
}
#app .labo .lb2 .lab-story .lab-txt {
  font-size: 1.6em;
  letter-spacing: -1px;
  padding-top: 20px;
  line-height: 1.28em;
  color: var(--gray-6-color);
}
#app .labo .lb2 .youtube-btn {
  font-size: 1.6em;
  line-height: 1.2em;
  letter-spacing: -1px;
  color: var(--gray-6-color);
  display: inline-block;
  padding: 12px 86px;
  border: 1px solid var(--gray-6-color);
  border-radius: 50px;
  margin-top: 40px;
}
#app .labo .lb3 {
  padding: 0 24px;
  margin-bottom: 160px;
}
#app .labo .lb3 .lb-history {
  margin-top: 40px;
}
#app .labo .lb3 .lb-history .years {
  font-size: 40px;
  font-weight: 400;
  color: var(--dark-2-color);
}
#app .labo .lb3 .lb-history .history-wr {
  padding-top: 20px;
}
#app .labo .lb3 .lb-history .history-wr .history-ls {
  display: flex;
  border-bottom: 1px solid var(--gray-4-color);
  padding: 16px 0 16px 14.6198%;
  font-size: 1.4em;
  letter-spacing: -1px;
  color: var(--gray-6-color);
  position: relative;
}
#app .labo .lb3 .lb-history .history-wr .history-ls:first-child {
  border-top: 1px solid var(--gray-4-color);
}
#app .labo .lb3 .lb-history .history-wr .history-ls .year {
  color: var(--gray-4-color);
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

#app {
  /*** certification ***/
}
#app .ct1 {
  background: url("../img/web/jpg/bg4.jpg") no-repeat;
  background-size: cover;
  background-position: center center;
}
#app .ct1 .eyeiyagi {
  line-height: 0.9em;
  padding-top: 481px;
}
#app .ct1 .txt {
  font-size: 25px;
}
#app .ct2 {
  margin: 160px 24px;
  text-align: center;
}
#app .ct2 .cert-tit {
  font-size: 20px;
  color: var(--dark-2-color);
  font-weight: 600;
}
#app .ct2 .cert-ls {
  padding-top: 40px;
  display: flex;
  gap: 20px 8px;
  justify-content: space-between;
  flex-wrap: wrap;
}
#app .ct2 .cert-ls .cert-item {
  width: calc(50% - 4px);
}
#app .ct2 .cert-ls .cert-item img {
  width: 100%;
}
#app .ct2 .cert-ls .cert-item .info {
  font-size: 1.4em;
  letter-spacing: -1px;
  text-align: center;
  color: var(--gray-6-color);
  display: block;
}
#app .ct2 .cert-ls .cert-item .info.date {
  padding-top: 12px;
}

/*** social ***/
.social .sc1 {
  background: url("../img/web/jpg/bg5.jpg") no-repeat;
  background-size: cover;
  background-position: center center;
}
.social .sc1::after {
  background: rgba(0, 0, 0, 0.3);
}
.social .sc1 .ab-txt-wr::after {
  background: none;
}
.social .sc1 .ab-txt-wr .eyeiyagi {
  line-height: 0.9em;
}
.social .sc2 {
  margin: 40px 24px;
}
.social .sc2 .media video {
  width: 100%;
  aspect-ratio: 171/110;
  height: 100%;
  object-fit: cover;
}
.social .sc2 .media .media-img {
  width: 100%;
  line-height: 0;
  margin-top: 8px;
}
.social .sc2 .media .media-img img {
  width: 100%;
}
.social .sc2 .media-cont .cont-hd {
  padding: 20px 60px;
  text-align: center;
}
.social .sc2 .media-cont .cont-hd .cont-cate {
  font-size: 1.6em;
  color: #000;
}
.social .sc2 .media-cont .cont-hd .cont-tit {
  font-size: 2em;
  font-weight: 600;
  color: #000;
  margin-top: 8px;
}
.social .sc2 .media-cont .cont-body {
  border-top: 2px solid var(--dark-2-color);
  padding-top: 12px;
}
.social .sc2 .media-cont .cont-body .cont-txt {
  font-size: 1.6em;
  line-height: 1.8em;
  letter-spacing: -1px;
  color: var(--gray-6-color);
}
.social .sc3 {
  padding-bottom: 40px;
}
.social .sc3 .artimg-slide {
  overflow: hidden;
}
.social .sc3 .artimg-slide.slide-bottom {
  margin-top: 8px;
}
.social .sc3 .artimg-slide .artimg-ls {
  transition-timing-function: linear;
}
.social .sc3 .artimg-slide .artimg-ls .artimg-item {
  line-height: 0;
}
.social .sc3 .artimg-slide .artimg-ls .artimg-item img {
  width: 100%;
}

@media screen and (min-width: 640px) {
  .social .sc3 {
    padding: 0 2.4rem 4rem;
  }
}
#app {
  /*** comments ***/
}
#app .comments {
  padding: 0 0 4rem;
}
#app .comments .best-comments {
  padding: 39px 0 36px;
  background-color: #dcecf5;
}
#app .comments .best-comments .best-tit {
  text-align: center;
  font-size: 25px;
  font-weight: 600;
  color: var(--primary-color);
}
#app .comments .best-comments .best-wr {
  overflow: hidden;
  padding-top: 20x;
  overflow: hidden;
  padding: 20px 20px 0;
  width: 100%;
  box-sizing: border-box;
}
#app .comments .best-comments .best-wr .best-ls {
  border-radius: 10px;
  overflow: hidden;
}
#app .comments .best-comments .best-wr .best-ls img {
  width: 100%;
  display: block;
  height: auto;
}
#app .comments .best-comments .best-wr .best-ls .cm-txt {
  padding: 12px 8px;
  background-color: #fff;
}
#app .comments .best-comments .best-wr .best-ls .cm-txt .best-tit {
  text-align: center;
  font-size: 1.4em;
  font-weight: 500;
  color: var(--dark-2-color);
}
#app .comments .best-comments .best-wr .best-ls .cm-txt .txt {
  font-size: 1.2em;
  color: var(--gray-5-color);
  padding-top: 8px;
}
#app .comments .best-comments .best-wr .best-ls .cm-txt .star-ls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5px;
  padding-top: 8px;
}
#app .comments .best-comments .best-wr .best-ls .cm-txt .star-ls .star {
  color: var(--primary-color);
  font-size: 1.2em;
}
#app .comments .benefit {
  margin: 40px 0;
  text-align: center;
}
#app .comments .benefit .benefit-tit {
  font-size: 1.6em;
  font-weight: 600;
  color: #212121;
  position: relative;
  display: inline-block;
  padding: 0 4px;
  z-index: 1;
}
#app .comments .benefit .benefit-tit::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 11px;
  background-color: #dcecf5;
  left: 0;
  bottom: 0;
  z-index: -1;
}
#app .comments .benefit .benefit-ls .benefit-item {
  padding-top: 20px;
}
#app .comments .benefit .benefit-ls .benefit-item img {
  width: 272px;
}
#app .comments .cm-box .cm-tit {
  font-size: 20px;
  font-weight: 600;
  text-align: center;
  color: #212121;
}
#app .comments .cm-box .prd-find {
  margin: 20px 20px 28px;
}
#app .comments .cm-box .cm-ls .cm-cont-wr {
  border-top: 1px solid #dcecf5;
  padding: 20px;
  display: flex;
  align-items: flex-start;
  gap: 8px;
  cursor: pointer;
}
#app .comments .cm-box .cm-ls .cm-cont-wr .img-bx {
  width: 64px;
  min-width: 64px;
  line-height: 0;
}
#app .comments .cm-box .cm-ls .cm-cont-wr .img-bx img {
  width: 100%;
}
#app .comments .cm-box .cm-ls .cm-cont-wr .cm-cont .name {
  display: block;
  font-size: 1.4rem;
  font-weight: 500;
  color: #212121;
}
#app .comments .cm-box .cm-ls .cm-cont-wr .cm-cont .txt {
  font-size: 1.4em;
  letter-spacing: -1px;
  color: var(--dark-2-color);
  font-weight: 500;
  -webkit-line-clamp: 1;
  padding-top: 0.4rem;
}
#app .comments .cm-box .cm-ls .cm-cont-wr .cm-cont .file img {
  width: 17px;
}
#app .comments .cm-box .cm-ls .cm-cont-wr .cm-cont .writer {
  display: block;
  font-size: 1.2em;
  color: #838383;
  padding-top: 1.2rem;
}
#app .comments .cm-box #sps_empty {
  text-align: center;
}

.review_detail_cnt {
  width: 100%;
  background: rgba(0, 0, 0, 0.1) !important;
  z-index: 1001;
}
.review_detail_cnt .review_detail_in {
  position: relative;
  background-color: #fff;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 96%;
  max-width: 620px;
  height: 83vh;
  overflow-y: auto;
  padding-bottom: 4rem;
  box-sizing: border-box;
}
.review_detail_cnt .review-detail-header {
  padding: 40px 20px;
}
.review_detail_cnt .review-detail-header .review-detail-title {
  font-size: 2rem;
  font-weight: 700;
  color: var(--primary-color);
  text-align: center;
  padding: 0;
  border-bottom: 0;
}
.review_detail_cnt .post-wr {
  margin: 0;
  padding: 0 20px;
}
.review_detail_cnt .post-wr .post-product {
  padding: 12px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  border-bottom: 1px solid var(--blue-1-color);
  margin-bottom: 16px;
}
.review_detail_cnt .post-wr .post-product .img-box {
  width: 77px;
}
.review_detail_cnt .post-wr .post-product .img-box img {
  width: 100%;
}
.review_detail_cnt .post-wr .post-product-name {
  width: calc(100% - 89px);
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--blue-1-color);
}
.review_detail_cnt .post-wr {
  /*&-photo{
      border-radius:5px;
      overflow:hidden;
      margin-bottom:12px;
      display:none;

      &.on{
          display:inherit;
      }

      img{
          width:100%;
      }
  }*/
}
.review_detail_cnt .post-wr .post-cont {
  margin-top: 0;
  min-height: 114px;
  max-height: 326px;
  -ms-overflow-style: none;
  scrollbar-width: none;
  overflow-y: auto;
}
.review_detail_cnt .post-wr .post-cont::-webkit-scrollbar {
  display: none;
}
.review_detail_cnt .post-wr .post-cont img {
  width: 100%;
}
.review_detail_cnt .post-wr .post-cont p {
  font-size: 1.4rem;
  color: var(--primary-color);
  line-height: 1.8rem;
  font-weight: 500;
}
.review_detail_cnt .rd_cls i {
  display: none;
}
.review_detail_cnt .rd_cls {
  width: 32px;
  height: 32px;
  background: url(../img/icon/close2.png) no-repeat center center;
  background-size: contain;
  top: 6px;
  right: 6px;
}

.qna {
  padding-bottom: 4rem;
}
.qna .qna-find {
  margin: 40px 20px 0;
}
.qna .qna-wr {
  padding: 28px 20px 0;
}
.qna .qna-wr .qna-ls {
  display: flex;
  align-items: center;
  gap: 12px;
  position: relative;
  padding: 8px 0;
  border-bottom: 1px solid var(--gray-2-color);
}
.qna .qna-wr .qna-ls img {
  width: 64px;
}
.qna .qna-wr .qna-ls .qna-cont .cont-txt {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 1.6em;
  line-height: 1.125em;
  color: var(--primary-color);
  font-weight: 500;
}
.qna .qna-wr .qna-ls .qna-cont .cont-txt img {
  width: 18px;
}
.qna .qna-wr .qna-ls .qna-cont .info {
  font-size: 1.2em;
  line-height: 1.5em;
  color: #818181;
  padding-top: 8px;
  display: inline-block;
}
.qna .qna-wr .qna-ls .qna-cont .info.writer {
  padding-right: 8px;
}
.qna .qna-wr .qna-ls .status {
  font-size: 1.2em;
  letter-spacing: -0.04em;
  color: var(--dark-1-color);
  display: inline-block;
  padding: 4px 12px;
  background-color: var(--gray-2-color);
  position: absolute;
  right: 0;
  bottom: 8px;
}
.qna .qna-wr .qna-ls .status.complet {
  background-color: #dcecf5;
}
.qna .wrt-btn {
  text-align: center;
  margin-top: 4rem;
}
.qna .wrt-btn a {
  font-size: 1.4em;
  font-weight: 600;
  color: #fff;
  padding: 16.5px 95px;
  display: inline-block;
  border-radius: 10px;
  background-color: var(--primary-color);
  line-height: 1.2em;
}

/*** qna-write ***/
.qna-wrt .sub_contents_wrapper {
  padding: 2.5rem 2rem 0;
}
.qna-wrt .wrt-box {
  width: 100%;
  border: 1px solid #cadeee;
  box-sizing: border-box;
  margin-bottom: 8px;
}
.qna-wrt #bo_w .bo_v_option .chk_box {
  margin-right: 1rem;
}
.qna-wrt #bo_w .bo_v_option .chk_box input[type=checkbox] + label {
  padding-left: 2.6rem;
  padding-top: 0;
  font-size: 1.2rem;
  color: var(--dark-1-color);
  cursor: pointer;
}
.qna-wrt #bo_w .bo_v_option .chk_box input[type=checkbox] + label span {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: none;
  background: url(../img/icon/select4.png) no-repeat;
  background-size: contain;
  top: 50%;
  transform: translateY(-50%);
}
.qna-wrt #bo_w .bo_v_option .chk_box input[type=checkbox]:checked + label span {
  background: url(../img/icon/select.png) no-repeat;
  background-size: contain;
}
.qna-wrt #bo_w .bo_w_tit {
  border: 1px solid #cadeee;
}
.qna-wrt #bo_w .bo_w_tit #autosave_wrapper {
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 0.4rem;
  margin: 0;
}
.qna-wrt #bo_w .bo_w_tit #autosave_wrapper .frm_input {
  padding: 1.2rem 0.4rem 1.2rem 1.2rem;
  margin: 0;
  border: none;
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--dark-2-color);
  line-height: 1.2em;
  outline: none;
  width: calc(100% - 160px);
  -webkit-line-clamp: 1;
}
.qna-wrt #bo_w .bo_w_tit #autosave_wrapper .frm_input::placeholder {
  font-size: 14px;
  font-weight: 600;
  color: #cadeee;
  line-height: 1.2em;
}
.qna-wrt #bo_w .bo_w_tit #autosave_wrapper .btn_frmline {
  font-size: 1.4rem;
  font-weight: 600;
  color: #fff;
  line-height: 1.2em;
  display: inline-block;
  padding: 8px 20px;
  background-color: var(--primary-color);
  border-radius: 5px;
  position: initial;
  height: auto;
  max-width: max-content;
  word-break: keep-all;
}
.qna-wrt #bo_w .bo_w_tit #autosave_wrapper #autosave_pop {
  display: none;
}
.qna-wrt #bo_w .wr_content {
  margin-top: 0.8rem;
}
.qna-wrt #bo_w .wr_content iframe {
  min-height: 250px;
}
.qna-wrt #bo_w .wr_content iframe body {
  margin: 0 !important;
}
.qna-wrt #bo_w .wr_content iframe #smart_editor2 #smart_editor2_content {
  border: none;
}
.qna-wrt #bo_w .bo_w_link {
  position: relative;
  margin-top: 0.8rem;
}
.qna-wrt #bo_w .bo_w_link label {
  width: 41px;
  height: 41px;
  line-height: 41px;
  background: url("../img/icon/file2.png") no-repeat;
  background-size: contain;
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
.qna-wrt #bo_w .bo_w_link label i {
  display: none;
}
.qna-wrt #bo_w .bo_w_link .frm_input {
  border: 1px solid #cadeee;
  width: 100%;
  box-sizing: border-box;
  padding-left: 41px;
  outline: none;
  font-size: 14px;
  font-weight: 600;
  color: #cadeee;
  line-height: 1.2em;
  padding: 1.2rem 0 1.2rem 4.5rem;
}
.qna-wrt #bo_w .btn_confirm {
  display: flex;
  justify-content: center;
  gap: 12px;
  padding: 2rem 0;
  margin: 4rem 0 0;
}
.qna-wrt #bo_w .btn_confirm .btn, .qna-wrt #bo_w .btn_confirm .btn-primary, .qna-wrt #bo_w .btn_confirm .btn-secondary, .qna-wrt #bo_w .btn_confirm .btn-outline, .qna-wrt #bo_w .btn_confirm .btn-ghost, .qna-wrt #bo_w .btn_confirm .btn-danger, .qna-wrt #bo_w .btn_confirm .btn-success, .qna-wrt #bo_w .btn_confirm .btn-dark, .qna-wrt #bo_w .btn_confirm .btn-white, .qna-wrt #bo_w .btn_confirm .ds_btn, .qna-wrt #bo_w .btn_confirm .cart-btn,
.qna-wrt #bo_w .btn_confirm .buy-btn, .qna-wrt #bo_w .btn_confirm .social-btn {
  font-size: 1.4em;
  line-height: 3.8rem;
  font-weight: 600;
  color: var(--primary-color);
  display: inline-block;
  border: 1px solid var(--primary-color);
  border-radius: 5px;
  padding: 0 2.3rem;
  box-sizing: border-box;
}
.qna-wrt #bo_w .btn_confirm .btn.btn_submit, .qna-wrt #bo_w .btn_confirm .btn_submit.btn-primary, .qna-wrt #bo_w .btn_confirm .btn_submit.btn-secondary, .qna-wrt #bo_w .btn_confirm .btn_submit.btn-outline, .qna-wrt #bo_w .btn_confirm .btn_submit.btn-ghost, .qna-wrt #bo_w .btn_confirm .btn_submit.btn-danger, .qna-wrt #bo_w .btn_confirm .btn_submit.btn-success, .qna-wrt #bo_w .btn_confirm .btn_submit.btn-dark, .qna-wrt #bo_w .btn_confirm .btn_submit.btn-white, .qna-wrt #bo_w .btn_confirm .btn_submit.ds_btn, .qna-wrt #bo_w .btn_confirm .btn_submit.cart-btn,
.qna-wrt #bo_w .btn_confirm .btn_submit.buy-btn, .qna-wrt #bo_w .btn_confirm .btn_submit.social-btn {
  color: #fff;
  background-color: var(--primary-color);
}

/*** 취소/작성완료 버튼 ***/
.btn-wr {
  display: flex;
  justify-content: center;
  gap: 12px;
  padding: 20px 0;
}
.btn-wr .btn, .btn-wr .btn-primary, .btn-wr .btn-secondary, .btn-wr .btn-outline, .btn-wr .btn-ghost, .btn-wr .btn-danger, .btn-wr .btn-success, .btn-wr .btn-dark, .btn-wr .btn-white, .btn-wr .ds_btn, .btn-wr .cart-btn,
.btn-wr .buy-btn, .btn-wr .social-btn {
  font-size: 1.4em;
  line-height: 1.2em;
  font-weight: 600;
  color: var(--primary-color);
  display: inline-block;
  border: 1px solid var(--primary-color);
  border-radius: 5px;
  padding: 11.5px 23px;
  box-sizing: border-box;
}
.btn-wr .btn.btn_submit, .btn-wr .btn_submit.btn-primary, .btn-wr .btn_submit.btn-secondary, .btn-wr .btn_submit.btn-outline, .btn-wr .btn_submit.btn-ghost, .btn-wr .btn_submit.btn-danger, .btn-wr .btn_submit.btn-success, .btn-wr .btn_submit.btn-dark, .btn-wr .btn_submit.btn-white, .btn-wr .btn_submit.ds_btn, .btn-wr .btn_submit.cart-btn,
.btn-wr .btn_submit.buy-btn, .btn-wr .btn_submit.social-btn {
  color: #fff;
  background-color: var(--primary-color);
}

/*** qna-post ***/
.sub_contents_wrapper {
  padding: 3.5rem 2rem 0;
}
.sub_contents_wrapper header #bo_v_title {
  padding: 1.6rem 0;
}
.sub_contents_wrapper header #bo_v_title .bo_v_tit {
  margin: 0;
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1.8rem;
  color: var(--primary-color);
}
.sub_contents_wrapper #bo_v_info {
  margin-top: 0;
  border-top: none;
  border-bottom: none;
  position: relative;
}
.sub_contents_wrapper #bo_v_info .profile_info {
  border-top: 1px solid var(--blue-1-color);
  border-bottom: 1px solid var(--blue-1-color);
  width: 100%;
  margin: 0;
  float: none;
}
.sub_contents_wrapper #bo_v_info .profile_info .profile_info_ct {
  padding: 0.8rem 0;
  float: none;
  display: flex;
  align-items: center;
}
.sub_contents_wrapper #bo_v_info strong {
  font-weight: 400;
  font-size: 1.2rem;
  line-height: 1.8rem;
  color: #818181;
  margin-right: 0.8rem;
}
.sub_contents_wrapper #bo_v_info #bo_v_top {
  position: absolute;
  right: 0;
  bottom: 8px;
}
.sub_contents_wrapper #bo_v_info #bo_v_top .btn_bo_user {
  margin: 0;
  display: flex;
  align-items: center;
}
.sub_contents_wrapper #bo_v_info #bo_v_top .btn_bo_user .btn_more_opt {
  width: 18px;
  height: 18px;
  background: url("../img/icon/dot.png") no-repeat;
  background-size: contain;
  margin-top: 0;
}
.sub_contents_wrapper #bo_v_info #bo_v_top .btn_bo_user .btn_more_opt i {
  display: none;
}
.sub_contents_wrapper #bo_v_atc {
  margin-top: 1.6rem;
}
.sub_contents_wrapper #bo_v_atc #bo_v_con {
  border: 1px solid var(--blue-1-color);
  border-radius: 5px;
  padding: 1.2rem;
  box-sizing: border-box;
  min-height: 250px;
  margin: 0;
  font-size: 1.4rem;
  line-height: 1.8rem;
  color: var(--primary-color);
  font-weight: 500;
}
.sub_contents_wrapper #bo_v_atc .btn_bo_user_btm_v {
  margin-top: 1.6rem;
}
.sub_contents_wrapper #bo_v_atc .btn_bo_user_btm_v .btn_v_01 {
  display: flex;
  justify-content: end;
  gap: 8px;
}
.sub_contents_wrapper #bo_v_atc .btn_bo_user_btm_v .btn_v_01 .btn_b01 {
  width: 34px;
  height: 34px;
  display: block;
  padding: 0;
  background-color: var(--primary-color) !important;
  background: url("../img/icon/list.png") no-repeat;
  background-size: contain;
  border-radius: 5px;
  text-indent: -9999px;
}
.sub_contents_wrapper #bo_v_atc .btn_bo_user_btm_v .btn_v_01 .btn_b01.sub_btns {
  background: url("../img/icon/write.png") no-repeat;
  background-size: contain;
}
.sub_contents_wrapper #bo_v_atc .btn_bo_user_btm_v .btn_v_01 .btn_b01.delete_btns {
  background: url("../img/icon/delete.png") no-repeat !important;
  background-size: contain !important;
}
.sub_contents_wrapper #bo_v_atc .btn_bo_user_btm_v .btn_v_01 .btn_b01 i {
  display: none;
}
.sub_contents_wrapper .bo_v_nb {
  margin: 0.4rem 0 4rem;
}
.sub_contents_wrapper .bo_v_nb li {
  border-top: 1px solid var(--blue-1-color);
  padding: 0.8rem 0;
}
.sub_contents_wrapper .bo_v_nb li:last-child {
  border-bottom: 1px solid var(--blue-1-color);
}
.sub_contents_wrapper .bo_v_nb li dd {
  float: left;
}
.sub_contents_wrapper .bo_v_nb li .nb_tit {
  padding-left: 1.8rem;
  position: relative;
}
.sub_contents_wrapper .bo_v_nb li .nb_tit::before {
  position: absolute;
  content: "";
  width: 18px;
  height: 18px;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background: url("../img/icon/b-arrow3.png") no-repeat;
  background-size: cover;
}
.sub_contents_wrapper .bo_v_nb li .nb_tit i {
  display: none;
}
.sub_contents_wrapper .bo_v_nb li .elc_01 {
  width: 23%;
}
.sub_contents_wrapper .bo_v_nb li .elc_01 .nb_tit {
  font-size: 1.2rem;
  line-height: 1.8rem;
  color: #818181;
}
.sub_contents_wrapper .bo_v_nb li .elc_02 {
  line-height: 1.8rem;
}
.sub_contents_wrapper .bo_v_nb li .elc_02 a {
  font-size: 1.2rem;
  line-height: 1.8rem;
  color: #818181;
}
.sub_contents_wrapper .bo_v_nb li .elc_03 {
  float: right;
}
.sub_contents_wrapper .bo_v_nb li .elc_03 .nb_date {
  font-size: 1.2rem;
  line-height: 1.8rem;
  color: #818181;
}
.sub_contents_wrapper .cmt_btn {
  margin: 0;
  padding: 1.6rem 0;
  border-bottom: none;
  width: 100%;
  box-sizing: border-box;
  text-align: left;
}
.sub_contents_wrapper .cmt_btn .total {
  font-size: 1.4rem;
  color: var(--primary-color);
  font-weight: 500;
  line-height: 1.8rem;
}
.sub_contents_wrapper .cmt_btn .total::after {
  content: none;
}
.sub_contents_wrapper .cmt_btn .total b {
  font-size: 1.4rem;
  color: var(--primary-color);
  font-weight: 500;
  line-height: 1.8rem;
}
.sub_contents_wrapper #bo_vc {
  text-align: center;
}
.sub_contents_wrapper #bo_vc #bo_vc_empty {
  padding: 3rem 0 8rem !important;
  font-size: 1.4rem;
  line-height: 1.8rem;
  color: var(--primary-color);
  font-weight: 500;
}
.sub_contents_wrapper #bo_vc article {
  text-align: left;
  padding: 0 0 2rem;
  position: relative;
}
.sub_contents_wrapper #bo_vc article header {
  padding: 0.8rem 0;
  border-top: 1px solid var(--blue-1-color);
  border-bottom: 1px solid var(--blue-1-color);
}
.sub_contents_wrapper #bo_vc article header span {
  font-size: 1.2rem;
  line-height: 1.8rem;
  color: var(--blue-1-color);
}
.sub_contents_wrapper #bo_vc article header span .member {
  margin-right: 0.8rem;
}
.sub_contents_wrapper #bo_vc article .cmt_contents {
  background-color: #dcecf5;
  border-radius: 5px;
  padding: 1.2rem;
  min-height: 150px;
  margin-top: 1.6rem;
  box-sizing: border-box;
}
.sub_contents_wrapper #bo_vc article .cmt_contents p {
  font-size: 1.4rem;
  line-height: 1.8rem;
  color: var(--primary-color);
  font-weight: 500;
}
.sub_contents_wrapper #bo_vc article .bo_vl_opt {
  position: absolute;
  top: 0.8rem;
  right: 0;
}
.sub_contents_wrapper #bo_vc article .bo_vl_opt .btn_cm_opt {
  width: 18px;
  height: 18px;
  background: url("../img/icon/dot2.png") no-repeat;
  background-size: contain;
}
.sub_contents_wrapper #bo_vc article .bo_vl_opt .btn_cm_opt i {
  display: none;
}
.sub_contents_wrapper #bo_vc_w {
  border-top: 1px solid var(--blue-1-color);
}
.sub_contents_wrapper #bo_vc_w #wr_content {
  width: 100%;
  box-sizing: border-box;
  min-height: 68px;
  padding: 1.2rem;
  border: 1px solid #cadeee;
  border-radius: 5px;
  resize: none;
  outline: none;
  margin-top: 1.6rem;
  background-color: #fff;
}
.sub_contents_wrapper #bo_vc_w #wr_content::placeholder {
  font-size: 1.4rem;
  line-height: 1.8rem;
  font-weight: 500;
  color: #b7d0e2;
}
.sub_contents_wrapper #bo_vc_w .bo_vc_w_wr .btn_confirm {
  display: flex;
  justify-content: center;
  margin-top: 1.2rem;
  position: relative;
}
.sub_contents_wrapper #bo_vc_w .bo_vc_w_wr .btn_confirm .chk_box {
  position: absolute;
  left: 0;
  top: 0;
  line-height: 1.8rem;
  display: inline-block;
}
.sub_contents_wrapper #bo_vc_w .bo_vc_w_wr .btn_confirm .chk_box label {
  font-size: 1.3rem !important;
  color: var(--gray-6-color);
  line-height: 1.8rem;
  display: inline-block;
  padding: 0;
  position: relative;
  padding-left: 2.2rem;
}
.sub_contents_wrapper #bo_vc_w .bo_vc_w_wr .btn_confirm .chk_box input[type=checkbox] {
  display: none;
}
.sub_contents_wrapper #bo_vc_w .bo_vc_w_wr .btn_confirm .chk_box input[type=checkbox] + label span {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  border: none;
  display: inline-block;
  width: 14px;
  height: 14px;
  background: url(../img/icon/select4.png) no-repeat;
  background-size: contain;
}
.sub_contents_wrapper #bo_vc_w .bo_vc_w_wr .btn_confirm .chk_box input[type=checkbox]:checked + label span {
  background: url(../img/icon/select.png) no-repeat;
  background-size: contain;
}
.sub_contents_wrapper #bo_vc_w .bo_vc_w_wr .btn_submit {
  font-size: 1.4rem;
  line-height: 1.68rem;
  color: #fff;
  font-weight: 600;
  padding: 0.8rem 2.4rem;
  border-radius: 5px;
  background-color: var(--primary-color);
}

/*** 리뷰상세&고객문의상세 공통 ***/
.post-wr {
  margin: 35px 20px 40px;
}
.post-wr .post-hd .post-tit {
  padding: 16px 0;
  border-bottom: 1px solid var(--blue-1-color);
  font-size: 1.4em;
  font-weight: 500;
  color: var(--primary-color);
  line-height: 1.2857em;
}
.post-wr .post-hd .post-info {
  padding: 8px 0;
  border-bottom: 1px solid var(--blue-1-color);
  position: relative;
}
.post-wr .post-hd .post-info::after {
  position: absolute;
  content: "";
  width: 18px;
  height: 18px;
  background: url("../img/web/png/dot.png") no-repeat;
  background-size: contain;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
.post-wr .post-hd .post-info .info {
  font-size: 1.2em;
  line-height: 1.5em;
  color: #818181;
}
.post-wr .post-hd .post-info .info.writer {
  margin-right: 8px;
}
.post-wr .post-cont {
  margin-top: 16px;
  padding: 12px;
  border-radius: 5px;
  border: 1px solid var(--blue-1-color);
  min-height: 250px;
  box-sizing: border-box;
}
.post-wr .post-cont .txt {
  font-size: 1.4em;
  line-height: 1.2857em;
  font-weight: 500;
  color: var(--primary-color);
}

/*** secret-window ***/
.secret-winow {
  background-color: #fff;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  max-width: 390px;
  z-index: 1001;
  margin: 0 auto;
}

/*** term ***/
.term-wr {
  padding: 20px;
}
.term-wr .term1 {
  padding: 16px;
  border-radius: 8px;
  background-color: var(--gray-1-color);
  margin-bottom: 20px;
}
.term-wr .term1 .agree-tit {
  font-size: 1.4em;
  font-weight: 700;
  color: var(--dark-2-color);
}
.term-wr .term1 .cont-box {
  display: flex;
  margin-top: 12px;
}
.term-wr .term1 .cont-box .agree-form {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}
.term-wr .term1 .cont-box .agree-form label {
  order: 2;
  font-size: 1.4rem;
  color: var(--gray-6-color);
  cursor: pointer;
  flex: 1;
}
.term-wr .term1 .cont-box .agree-form input[type=checkbox] {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border: 1px solid var(--gray-4-color);
  box-sizing: border-box;
  border-radius: 50%;
  order: 1;
  cursor: pointer;
}
.term-wr .term1 .cont-box .agree-form input[type=checkbox]:checked {
  background: url("../img/icon/select2.png") no-repeat;
  background-size: cover;
  border: 0;
}
.term-wr .term2 {
  border-radius: 8px;
  border: 1px solid var(--gray-2-color);
  margin-bottom: 20px;
}
.term-wr .term2 .term-tit-wr {
  display: flex;
  align-items: center;
  position: relative;
  padding: 16px;
}
.term-wr .term2 .term-tit-wr .agree-form {
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.term-wr .term2 .term-tit-wr .agree-form label {
  order: 2;
  font-size: 1.4rem;
  color: var(--dark-1-color);
  cursor: pointer;
  font-weight: 500;
  position: relative;
}
.term-wr .term2 .term-tit-wr .agree-form label::after {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  background: url("../img/icon/star.png") no-repeat;
  background-size: contain;
  top: 50%;
  transform: translateY(-50%);
  right: -14px;
}
.term-wr .term2 .term-tit-wr .agree-form input[type=checkbox] {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border: 1px solid var(--gray-4-color);
  box-sizing: border-box;
  border-radius: 50%;
  order: 1;
  cursor: pointer;
}
.term-wr .term2 .term-tit-wr .agree-form input[type=checkbox]:checked {
  background: url("../img/icon/select3.png") no-repeat;
  background-size: cover;
  border: 0;
}
.term-wr .term2 .term-txt {
  padding: 16px;
}
.term-wr .term2 .term-txt .txt {
  height: 140px;
  font-size: 1rem;
  color: var(--gray-6-color);
  width: 100%;
  box-sizing: border-box;
  border: none;
  resize: none;
  outline: none;
  background-color: #fff;
  -ms-overflow-style: none;
}
.term-wr .term2 .term-txt .txt::-webkit-scrollbar {
  display: none;
}
.term-wr .term2 .term-txt table {
  border-collapse: collapse;
  width: 100%;
}
.term-wr .term2 .term-txt table col {
  width: 33.3333%;
}
.term-wr .term2 .term-txt table th {
  font-size: 1.4rem;
  color: var(--gray-6-color);
  font-weight: 500;
  text-align: center;
  padding: 7px;
  background-color: var(--gray-2-color);
  line-height: 1.7rem;
  box-sizing: border-box;
}
.term-wr .term2 .term-txt table td {
  font-size: 1rem;
  text-align: center;
  color: var(--gray-6-color);
  padding: 10px 7px;
  border-right: 1px solid var(--gray-2-color);
  border-bottom: 1px solid var(--gray-2-color);
  box-sizing: border-box;
}
.term-wr .term2 .term-txt table td:first-child {
  border-left: 1px solid var(--gray-2-color);
}

/*** signup-complete ***/
.signup-complete {
  background: url("../img/web/png/signup-bg.png") no-repeat;
  width: 100%;
  aspect-ratio: 39/34;
  background-size: 100% auto;
  background-position: 0 0;
}
.signup-complete .mypage .mypage-note {
  margin: 0 !important;
  padding: 100px 0 40px;
}
.signup-complete .main-btn-box {
  text-align: center;
}
.signup-complete .main-btn-box .main-btn {
  font-size: 1.4em;
  font-weight: 600;
  color: #fff;
  border-radius: 10px;
  background-color: var(--primary-color);
  display: inline-block;
  line-height: 1.2em;
  padding: 16.5px 89px;
}

/*** 취소/확인 버튼 ***/
.button-wr {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 20px;
}
.button-wr .btn, .button-wr .btn-primary, .button-wr .btn-secondary, .button-wr .btn-outline, .button-wr .btn-ghost, .button-wr .btn-danger, .button-wr .btn-success, .button-wr .btn-dark, .button-wr .btn-white, .button-wr .ds_btn, .button-wr .cart-btn,
.button-wr .buy-btn, .button-wr .social-btn {
  font-size: 1.4em;
  font-weight: 600;
  color: var(--primary-color);
  border-radius: 5px;
  border: 1px solid var(--primary-color);
  display: inline-block;
  line-height: 3.8rem;
  width: calc(50% - 6px);
  box-sizing: border-box;
  text-align: center;
  cursor: pointer;
}
.button-wr .btn.next-btn, .button-wr .next-btn.btn-primary, .button-wr .next-btn.btn-secondary, .button-wr .next-btn.btn-outline, .button-wr .next-btn.btn-ghost, .button-wr .next-btn.btn-danger, .button-wr .next-btn.btn-success, .button-wr .next-btn.btn-dark, .button-wr .next-btn.btn-white, .button-wr .next-btn.ds_btn, .button-wr .next-btn.cart-btn,
.button-wr .next-btn.buy-btn, .button-wr .next-btn.social-btn {
  color: #fff;
  background-color: var(--primary-color);
}

#app {
  /*** refund ***/
}
#app .refund .refund-hd {
  padding: 108px 20px 151px;
  height: 76.5vh;
  background: url("../img/web/jpg/refund-bg.jpg") no-repeat center center;
  background-size: cover;
  width: 100%;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: center;
}
#app .refund .refund-hd .rf-tit {
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -1px;
  color: #fff;
  text-align: center;
}
#app .refund .refund-hd .rf-cont {
  margin-top: 18px;
  display: grid;
}
#app .refund .refund-hd .rf-cont .rule-wr {
  display: grid;
  grid-template-columns: 99px auto;
  margin-top: 42px;
  width: 100%;
}
#app .refund .refund-hd .rf-cont .rule-wr .icon-wr {
  width: 99px;
  text-align: center;
}
#app .refund .refund-hd .rf-cont .rule-wr .icon-wr img {
  width: 100%;
}
#app .refund .refund-hd .rf-cont .rule-wr .icon-wr .icon-label {
  font-size: 2em;
  letter-spacing: -1px;
  color: #fff;
  padding-top: 8px;
}
#app .refund .refund-hd .rf-cont .rule-wr .rule-inner {
  padding-left: 11.5px;
}
#app .refund .refund-hd .rf-cont .rule-wr .rule-inner .rule {
  margin-top: 32px;
}
#app .refund .refund-hd .rf-cont .rule-wr .rule-inner .rule:first-child {
  margin-top: 0;
}
#app .refund .refund-hd .rf-cont .rule-wr .rule-inner .rule .txt {
  font-size: 1.6em;
  letter-spacing: -1px;
  color: #fff;
}
#app .refund .refund-hd .rf-cont .rule-wr .rule-inner .rule .txt.condi {
  position: relative;
  padding-left: 14px;
}
#app .refund .refund-hd .rf-cont .rule-wr .rule-inner .rule .txt.condi::after {
  position: absolute;
  content: "";
  width: 3px;
  height: 3px;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background-color: #fff;
  border-radius: 50%;
}
#app .refund .refund-hd .rf-cont .rule-wr .rule-inner .rule .txt.condi-cont {
  padding-top: 8px;
}
#app .refund .rule-information {
  margin: 60px 0 218px;
}
#app .refund .rule-information .rule-tit-wr {
  text-align: center;
}
#app .refund .rule-information .rule-tit-wr .rule-tit {
  font-size: 1.6em;
  font-weight: 600;
  color: #fff;
  display: inline-block;
  padding: 4px 20px;
  background-color: var(--primary-color);
  border-radius: 50px;
  line-height: 1.5em;
  letter-spacing: -0.02em;
}
#app .refund .rule-information .rule-ls {
  margin-top: 20px;
}
#app .refund .rule-information .rule-ls .rule-item {
  padding: 24px 20px;
  border-bottom: 1px solid var(--gray-2-color);
}
#app .refund .rule-information .rule-ls .rule-item .rule-term {
  font-size: 1.5em;
  font-weight: 600;
  color: var(--primary-color);
}
#app .refund .rule-information .rule-ls .rule-item .note-ls .note-item {
  font-size: 1.4em;
  font-weight: 400;
  letter-spacing: -1px;
  line-height: 1.5em;
  color: var(--gray-6-color);
  padding-top: 4px;
}
#app .refund .rule-information .rule-ls .rule-item .note-ls .note-item .core {
  font-weight: 600;
}
#app .refund .rule-information .rule-ls .rule-item .refer-ls {
  padding-top: 20px;
}

#app .password-page {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100vh;
}
#app .password-page form {
  width: 100%;
}
#app .password-page .lock {
  position: relative;
  padding: 40px 20px 60px;
  width: 100%;
  box-sizing: border-box;
}
#app .password-page .lock .lock-wr {
  text-align: center;
  letter-spacing: -1px;
}
#app .password-page .lock .lock-wr .lock-cont {
  font-size: 1.8em;
  color: var(--primary-color);
  padding-top: 20px;
}
#app .password-page .lock .lock-wr .lock-txt {
  font-size: 1.5em;
  color: var(--primary-color);
  padding-top: 20px;
}
#app .password-page .lock .lock-form {
  margin-top: 40px;
  text-align: center;
}
#app .password-page .lock .lock-form .lock-ele {
  display: block;
  width: 80%;
  max-width: 254px;
  border: none;
  outline: none;
  border-radius: 50px;
  box-sizing: border-box;
  font-size: 13px;
  font-weight: 600;
  margin: 0 auto;
  line-height: 1.2em;
}
#app .password-page .lock .lock-form .lock-ele.lock-input {
  background-color: #DCECF5;
  color: var(--dark-2-color);
  outline: none;
  padding: 12px 20px;
}
#app .password-page .lock .lock-form .lock-ele.lock-input::placeholder {
  font-size: 13px;
  font-weight: 600;
  color: #90AEC4;
}
#app .password-page .lock .lock-form .lock-ele.btn-submit {
  color: #fff;
  background-color: var(--primary-color);
  padding: 12px 0;
  margin-top: 8px;
  display: inline-block;
  text-align: center;
}
#app .password-page .lock .exit-btn {
  right: 20px;
  top: 20px;
}

/*** nopage ***/
.nopage {
  text-align: center;
  box-sizing: border-box;
  min-height: calc(100vh - 199.64px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.nopage.empty {
  min-height: calc(100vh - 264.12px);
}
.nopage .basket {
  margin-top: -18.5rem;
}
.nopage .heart {
  margin-top: -13.5rem;
}
.nopage .nopage-txt {
  font-size: 1.4em;
  color: var(--gray-5-color);
  margin-top: 12px;
}
.nopage .nopage-btn {
  font-size: 1.4em;
  font-weight: 600;
  color: #fff;
  line-height: 1.2em;
  display: inline-block;
  padding: 16.5px 63px;
  border-radius: 10px;
  margin-top: 28px;
  background-color: var(--primary-color);
}
.nopage .nopage-btn.login-btn {
  padding: 16.5px 83px;
}

.cart-products {
  padding-bottom: 20px;
}
.cart-products-header {
  padding: 40px 20px;
}
.cart-products-title {
  font-size: 2rem;
  font-weight: 700;
  color: var(--primary-color);
  text-align: center;
}
.cart-products-inner {
  padding: 0 20px;
}
.cart-products-inner .select-form {
  padding-left: 26px;
}
.cart-products-inner .select-box {
  padding: 20px 0;
}
.cart-products-inner .select-box .item-contents .name {
  padding-right: 38px;
}
.cart-products-inner .total-price .total {
  padding: 16px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.cart-products-inner .total-price .total .price-name {
  font-size: 1.4em;
  color: var(--gray-5-color);
}
.cart-products-inner .total-price .total .pay {
  letter-spacing: -0.03em;
  font-size: 1.8em;
  font-weight: 600;
  line-height: 1.1933em;
  color: #ff2f41;
}
.cart-products .button-wr {
  margin-top: 20px;
  display: inherit;
}
.cart-products .button-wr .btn, .cart-products .button-wr .btn-primary, .cart-products .button-wr .btn-secondary, .cart-products .button-wr .btn-outline, .cart-products .button-wr .btn-ghost, .cart-products .button-wr .btn-danger, .cart-products .button-wr .btn-success, .cart-products .button-wr .btn-dark, .cart-products .button-wr .btn-white, .cart-products .button-wr .ds_btn, .cart-products .button-wr .cart-btn,
.cart-products .button-wr .buy-btn, .cart-products .button-wr .social-btn {
  width: 100%;
}
.cart-products .button-wr .btn.next-btn, .cart-products .button-wr .next-btn.btn-primary, .cart-products .button-wr .next-btn.btn-secondary, .cart-products .button-wr .next-btn.btn-outline, .cart-products .button-wr .next-btn.btn-ghost, .cart-products .button-wr .next-btn.btn-danger, .cart-products .button-wr .next-btn.btn-success, .cart-products .button-wr .next-btn.btn-dark, .cart-products .button-wr .next-btn.btn-white, .cart-products .button-wr .next-btn.ds_btn, .cart-products .button-wr .next-btn.cart-btn,
.cart-products .button-wr .next-btn.buy-btn, .cart-products .button-wr .next-btn.social-btn {
  margin-top: 8px;
}
.cart-products .all-select {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.cart-products .all-select .form-check-label {
  cursor: pointer;
}
.cart-products .all-select .delete_check {
  color: #616161;
  font-size: 1.4rem;
  text-decoration: underline;
}

/*** qna ***/
.board_tit {
  padding: 28px 20px;
  background-color: #DCECF5;
}
.board_tit .board-tit {
  font-size: 25px;
  font-weight: 700;
  color: var(--primary-color);
}
.board_tit .board-txt {
  font-size: 1.1em;
  color: var(--gray-5-color);
}

.board_faq .board_content .board_list {
  margin: 40px 0;
  padding: 0 20px;
}
.board_faq .board_content .board_list .list_item {
  border-top: 1px solid #90aec4;
}
.board_faq .board_content .board_list .list_item:last-child {
  border-bottom: 1px solid #90aec4;
}
.board_faq .board_content .board_list .list_item.active .content_tit .icon {
  background: url("../img/icon/minus.svg") no-repeat center;
}
.board_faq .board_content .board_list .list_item.active .accordion_cont {
  display: block;
}
.board_faq .board_content .board_list .list_item .content_tit {
  display: flex;
  padding: 20px 0;
  justify-content: space-between;
  align-items: center;
}
.board_faq .board_content .board_list .list_item .content_tit .tit_text {
  width: 85%;
  font-size: 1.6em;
  font-weight: 500;
  line-height: 19px;
  color: #212121;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.board_faq .board_content .board_list .list_item .content_tit .icon {
  width: 24px;
  height: 24px;
  background: url("../img/icon/plus.svg") no-repeat center;
  text-indent: -10000px;
}
.board_faq .board_content .board_list .list_item .accordion_cont {
  display: none;
}
.board_faq .board_content .board_list .list_item .accordion_cont .cont_txt {
  padding: 20px;
  background-color: #dcecf5;
  font-size: 1.4em;
  font-weight: 500;
  line-height: 17px;
  color: #414141;
}

.event_wrap .board_content .event_list {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 20px;
}
.event_wrap .board_content .event_list .list_item {
  position: relative;
}
.event_wrap .board_content .event_list .list_item picture img {
  width: 100%;
}
.event_wrap .board_content .event_list .event_end {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
}
.event_wrap .board_content .event_list .event_end p {
  font-size: 2.5rem;
  line-height: 100%;
  color: #fff;
  font-weight: 500;
}

.pickup_about_wrap .pickup_about {
  padding: 0 0 4rem;
}
.pickup_about_wrap .pickup_about .board_tit .board-txt {
  margin-top: 8px;
  font-size: 1.4em;
  line-height: 20px;
  color: var(--primary-color);
}
.pickup_about_wrap .pickup_about .pickup_about-wr {
  margin: 20px;
}
.pickup_about_wrap .pickup_about .pickup_about-wr .pickup_about-ls {
  padding: 20px 0;
  border-bottom: 1px solid var(--gray-2-color);
}
.pickup_about_wrap .pickup_about .pickup_about-wr .pickup_about-ls .pickup_list {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
}
.pickup_about_wrap .pickup_about .pickup_about-wr .pickup_about-ls .pickup_list .pickup_about-cont .cont-txt {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 1.6em;
  line-height: 1.125em;
  color: var(--primary-color);
  font-weight: 500;
}
.pickup_about_wrap .pickup_about .pickup_about-wr .pickup_about-ls .pickup_list .pickup_about-cont .cont-txt img {
  width: 18px;
}
.pickup_about_wrap .pickup_about .pickup_about-wr .pickup_about-ls .pickup_list .pickup_about-cont .info {
  font-size: 1.2em;
  line-height: 1.5em;
  color: #818181;
  padding-top: 8px;
  display: inline-block;
}
.pickup_about_wrap .pickup_about .pickup_about-wr .pickup_about-ls .pickup_list .pickup_about-cont .info.writer {
  padding-right: 8px;
}
.pickup_about_wrap .pickup_about .pickup_about-wr .pickup_about-ls .pickup_list .status {
  font-size: 1.2em;
  letter-spacing: -0.04em;
  color: var(--dark-1-color);
  display: inline-block;
  padding: 4px 12px;
  margin-bottom: 5px;
  background-color: var(--gray-2-color);
}
.pickup_about_wrap .pickup_about .pickup_about-wr .pickup_about-ls .pickup_list .status.complete {
  background-color: #DCECF5;
}

.qna_pickup_4 .board_tit .board-txt {
  margin-top: 8px;
  font-size: 1.4em;
  line-height: 20px;
  color: var(--primary-color);
}

.pickup_partner_wrap .partner_content .partner_top {
  position: relative;
}
.pickup_partner_wrap .partner_content .partner_top video {
  overflow: hidden;
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.pickup_partner_wrap .partner_content .partner_top video[poster] {
  width: 100%;
  object-fit: cover;
}
.pickup_partner_wrap .partner_content .partner_top .partner_text_box {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  padding: 20px 24px;
  box-sizing: border-box;
  z-index: 1;
}
.pickup_partner_wrap .partner_content .partner_top .partner_text_box::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0), #000000);
  z-index: -1;
}
.pickup_partner_wrap .partner_content .partner_top .partner_text_box .part_title {
  font-size: 5.5em;
  font-weight: 600;
  line-height: 50px;
  color: #fff;
  margin-bottom: 20px;
}
.pickup_partner_wrap .partner_content .partner_top .partner_text_box .sub_tit {
  font-size: 2.5em;
  font-weight: 600;
  line-height: 30px;
  color: #fff;
  margin-bottom: 40px;
}
.pickup_partner_wrap .partner_content .partner_top .partner_text_box .txt {
  font-size: 1.6em;
  line-height: 2.485rem;
  color: var(--gray-4-color);
  letter-spacing: -1px;
}
.pickup_partner_wrap .partner_content .partner_bottom {
  padding: 160px 0;
  background-color: #000;
  text-align: center;
}
.pickup_partner_wrap .partner_content .partner_bottom .partner_text .part_title {
  font-size: 20px;
  font-weight: 600;
  color: #fff;
  margin-bottom: 20px;
}
.pickup_partner_wrap .partner_content .partner_bottom .partner_text .sub_title {
  font-size: 16px;
  font-weight: 19px;
  color: var(--gray-4-color);
  margin-bottom: 40px;
}
.pickup_partner_wrap .partner_content .partner_bottom .partner_text .go_partner_btn {
  display: block;
  max-width: 295px;
  margin: 0 auto;
  padding: 11px 0;
  border: 1px solid var(--gray-4-color);
  border-radius: 50px;
  line-height: normal;
  font-size: 16px;
  color: var(--gray-4-color);
}

/*** nomember-pickup ***/
.nomembers-pickup .mypage {
  margin-bottom: 40px;
}
.nomembers-pickup .term-wr .term2 .term-txt .txt {
  overflow-y: auto;
}
.nomembers-pickup .term-wr .term2 .term-txt table tr:first-child {
  border-top: 1px solid var(--gray-2-color);
}
.nomembers-pickup .term-wr .term2 .term-txt table td {
  text-align: left;
  vertical-align: top;
}
.nomembers-pickup .nomember-pickup {
  border-top: 1px solid var(--primary-color);
  padding-bottom: 20px;
}
.nomembers-pickup .nomember-pickup-title {
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--primary-color);
  padding: 16px 0;
}
.nomembers-pickup .nomember-pickup .reserve-btn {
  text-align: center;
}
.nomembers-pickup .nomember-pickup .reserve-btn input {
  width: 100%;
  max-width: 254px;
  font-size: 1.3em;
  font-weight: 600;
  color: #fff;
  padding: 12px 0;
  border-radius: 50px;
  border: none;
  background: var(--primary-color);
}

.auth_inquiry {
  background-color: #DCECF5;
  padding-bottom: 4rem;
}
.auth_inquiry .my-tit {
  padding: 4rem 0 2rem;
}
.auth_inquiry .sub_contents_wrapper {
  padding: 0;
  margin-bottom: 0 !important;
}
.auth_inquiry .sub_contents_wrapper #bo_list {
  display: flex;
  flex-direction: column;
}
.auth_inquiry .inquiry {
  background-color: #fff;
  border-radius: 10px;
  padding: 1.6rem 2rem;
  margin-bottom: 1.2rem;
  display: flex;
  width: 100%;
  box-sizing: border-box;
}
.auth_inquiry .td_chk {
  text-align: left !important;
  width: 38px !important;
  position: relative;
}
.auth_inquiry .td_chk input {
  margin: 0;
  appearance: none;
  cursor: pointer;
}
.auth_inquiry .td_chk input:after {
  box-sizing: border-box;
  border: 1px solid #dbdbdb;
  border-radius: 50%;
  width: 18px;
  height: 18px;
  position: absolute;
  content: "";
  left: 0;
  top: 4px;
}
.auth_inquiry .td_chk input[type=checkbox]:checked:after {
  background: url("../img/icon/select.png") no-repeat;
  background-size: cover;
  border: none;
}
.auth_inquiry {
  /*detail_inquiry*/
}
.auth_inquiry #bo_v {
  padding: 0 2rem;
  margin-bottom: 0;
}
.auth_inquiry #bo_v #bo_v_title {
  padding: 0;
  font-size: 1.4rem !important;
  color: var(--primary-color);
  font-weight: 600;
}
.auth_inquiry #bo_v header {
  background-color: #fff;
  padding: 2rem 2rem 1.3rem;
  border-radius: 10px 10px 0 0;
  border: none;
}
.auth_inquiry #bo_v #bo_v_info {
  background-color: #fff;
  padding: 0 2rem 2rem;
  border: none;
  border-radius: 0 0 10px 10px;
  margin-bottom: 2rem;
}
.auth_inquiry #bo_v #bo_v_atc {
  border: none;
  border-radius: 10px;
  padding: 2rem;
  margin: 0 0 2rem;
}
.auth_inquiry #bo_v #bo_v_atc #bo_v_con {
  border: 0;
  padding: 0;
}
.auth_inquiry #bo_v #bo_v_atc #sod_fin {
  display: flex;
  flex-direction: column;
}
.auth_inquiry #bo_v #bo_v_atc #sod_fin #sod_fin_no {
  order: 2;
}
.auth_inquiry #bo_v #bo_v_atc #sod_fin #sod_fin_list {
  order: 1;
}
.auth_inquiry #bo_v_top {
  padding: 0;
  margin-top: 2rem;
}
.auth_inquiry #bo_v_ans {
  border: 0;
  border-radius: 10px;
  padding: 2rem;
  margin: 4rem 0 0;
}

/**
 * ALPS 2026 - Premium Product Detail Page
 * ══════════════════════════════════════════════════════════════════════════
 * 
 * 상품 상세 페이지:
 * - 이머시브 갤러리
 * - 프리미엄 정보 레이아웃
 * - 고정 구매 바
 * - 부드러운 인터랙션
 * 
 * @버전: 3.0
 * @최종수정: 2026-01-07
 */
/* ══════════════════════════════════════════════════════════════════════════
   상품 상세 래퍼
   ══════════════════════════════════════════════════════════════════════════ */
.product_detail_wrap {
  background: #FFFFFF;
  padding-bottom: calc(72px + env(safe-area-inset-bottom, 0));
}
@media (min-width: 1024px) {
  .product_detail_wrap {
    padding-bottom: 6.4rem;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   썸네일 갤러리 - Premium Immersive Gallery
   ══════════════════════════════════════════════════════════════════════════ */
.thumbnail {
  position: relative;
  overflow: hidden;
  background: #FAFAFA;
}
.thumbnail .item_box .item img {
  width: 100%;
  display: block;
}
.thumbnail .product-pagination {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 3.2rem;
  padding: 0 2rem;
  z-index: 10;
  display: flex;
  gap: 2px;
}
@media (min-width: 768px) {
  .thumbnail .product-pagination {
    bottom: 4rem;
    padding: 0 3.2rem;
  }
}
.thumbnail .product-pagination .swiper-pagination-bullet {
  flex: 1;
  height: 3px;
  background: rgba(255, 255, 255, 0.3);
  border-radius: 9999px;
  margin: 0;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.thumbnail .product-pagination .swiper-pagination-bullet-active {
  background: #FFFFFF;
}
.thumbnail .image-counter {
  position: absolute;
  right: 2rem;
  bottom: 2rem;
  padding: 0.6rem 1.2rem;
  background: rgba(23, 23, 23, 0.6);
  backdrop-filter: blur(8px);
  border-radius: 9999px;
  font-size: 1.1rem;
  font-weight: 600;
  color: #FFFFFF;
  z-index: 10;
}

/* ══════════════════════════════════════════════════════════════════════════
   상품 정보 영역 - Premium Info Section
   ══════════════════════════════════════════════════════════════════════════ */
.infoArea {
  width: 100%;
}
.infoArea .description .product_info {
  padding: 2.4rem 2rem;
}
@media (min-width: 768px) {
  .infoArea .description .product_info {
    padding: 3.2rem 2.4rem;
  }
}
@media (min-width: 1024px) {
  .infoArea .description .product_info {
    padding: 4rem 3.2rem;
    max-width: none;
    margin: 0 auto;
  }
}
.infoArea .description .product_info .brand {
  font-size: 1.2rem;
  font-weight: 600;
  color: #18181B;
  margin-bottom: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.025em;
}
.infoArea .description .product_info .name {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.35;
  color: #171717;
  margin-bottom: 1.6rem;
}
@media (min-width: 768px) {
  .infoArea .description .product_info .name {
    font-size: 2.2rem;
  }
}
@media (min-width: 1024px) {
  .infoArea .description .product_info .name {
    font-size: 2.8rem;
  }
}
.infoArea .description .product_info .price_box {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.8rem 1.2rem;
  margin-top: 1.6rem;
}
.infoArea .description .product_info .price_box .per {
  font-size: 2.2rem;
  font-weight: 800;
  color: #DC2626;
}
@media (min-width: 768px) {
  .infoArea .description .product_info .price_box .per {
    font-size: 2.8rem;
  }
}
.infoArea .description .product_info .price_box .price {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  color: #171717;
}
@media (min-width: 768px) {
  .infoArea .description .product_info .price_box .price {
    font-size: 2.8rem;
  }
}
.infoArea .description .product_info .price_box .custom {
  font-size: 1.4rem;
  font-weight: 400;
  color: #A3A3A3;
  text-decoration: line-through;
}
.infoArea .description .product_info .review_info {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  margin-top: 1.6rem;
  padding-top: 1.6rem;
  border-top: 1px solid #F5F5F5;
}
.infoArea .description .product_info .review_info .stars {
  display: flex;
  gap: 2px;
  color: #F59E0B;
}
.infoArea .description .product_info .review_info .rating {
  font-size: 1.4rem;
  font-weight: 700;
  color: #262626;
}
.infoArea .description .product_info .review_info .count {
  font-size: 1.2rem;
  color: #A3A3A3;
}
.infoArea .description .custom_promotion {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  padding: 1.6rem 2rem;
  background: linear-gradient(90deg, #F6F6F7 0%, rgba(245, 158, 11, 0.08) 100%);
}
@media (min-width: 768px) {
  .infoArea .description .custom_promotion {
    padding: 2rem 2.4rem;
  }
}
.infoArea .description .custom_promotion .txt01 {
  font-size: 1.4rem;
  font-weight: 700;
  color: #18181B;
}
.infoArea .description .custom_promotion .txt02 {
  font-size: 1.2rem;
  font-weight: 600;
  color: #0D0D0F;
}
.infoArea .description .custom_promotion .txt03 {
  font-size: 1.2rem;
  font-weight: 400;
  color: #0D0D0F;
}
.infoArea .option .option_color {
  padding: 2rem;
}
@media (min-width: 768px) {
  .infoArea .option .option_color {
    padding: 2.4rem;
  }
}
.infoArea .option .option_color .option_title {
  font-size: 1.2rem;
  font-weight: 600;
  color: #404040;
  margin-bottom: 1.6rem;
}
.infoArea .option .option_color .option_box {
  display: flex;
  flex-wrap: wrap;
  gap: 1.2rem;
}
.infoArea .option .option_color .option_box .item {
  text-align: center;
  cursor: pointer;
}
.infoArea .option .option_color .option_box .item .img_box {
  width: 56px;
  height: 56px;
  border-radius: 9999px;
  border: 2px solid #F5F5F5;
  overflow: hidden;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .infoArea .option .option_color .option_box .item .img_box {
    width: 64px;
    height: 64px;
  }
}
.infoArea .option .option_color .option_box .item .img_box img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.infoArea .option .option_color .option_box .item .img_box.active {
  border-color: #18181B;
  box-shadow: 0 0 0 4px rgba(24, 24, 27, 0.12);
}
.infoArea .option .option_color .option_box .item h5 {
  margin-top: 0.8rem;
  font-size: 1.1rem;
  font-weight: 500;
  color: #525252;
}
@media (min-width: 768px) {
  .infoArea .option .option_color .option_box .item h5 {
    font-size: 1.2rem;
  }
}
.infoArea .option .option_eyesight,
.infoArea .option .option_size {
  padding: 2rem;
  border-top: 1px solid #F5F5F5;
}
@media (min-width: 768px) {
  .infoArea .option .option_eyesight,
  .infoArea .option .option_size {
    padding: 2.4rem;
  }
}
.infoArea .option .product_select {
  padding: 1.6rem 2rem;
  background: #FCFCFC;
  border-top: 1px solid #F5F5F5;
}
@media (min-width: 768px) {
  .infoArea .option .product_select {
    padding: 2rem 2.4rem;
  }
}
.infoArea .detail_info {
  border-top: 8px solid #FAFAFA;
}
.infoArea .detail_info .info_title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.6rem 2rem;
  font-size: 1.4rem;
  font-weight: 600;
  color: #262626;
  border-bottom: 1px solid #F5F5F5;
  cursor: pointer;
}
@media (min-width: 768px) {
  .infoArea .detail_info .info_title {
    padding: 2rem 2.4rem;
  }
}
.infoArea .detail_info .info_title .arrow {
  width: 20px;
  height: 20px;
  transition: transform 200ms cubic-bezier(0, 0, 0.2, 1);
}
.infoArea .detail_info .info_title.active .arrow {
  transform: rotate(180deg);
}
.infoArea .detail_info .info_box {
  padding: 2rem;
}
@media (min-width: 768px) {
  .infoArea .detail_info .info_box {
    padding: 2.4rem;
  }
}
.infoArea .detail_info .info_box .item {
  display: flex;
  align-items: flex-start;
  gap: 1.2rem;
  margin-bottom: 1.2rem;
  padding-left: 2.4rem;
  position: relative;
}
.infoArea .detail_info .info_box .item:last-child {
  margin-bottom: 0;
}
.infoArea .detail_info .info_box .item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 4px;
  width: 16px;
  height: 16px;
  background: url("../img/icon/check.png") no-repeat center;
  background-size: contain;
}
.infoArea .detail_info .info_box .item .item_title {
  flex-shrink: 0;
  width: 80px;
  font-size: 1.2rem;
  font-weight: 500;
  color: #737373;
}
@media (min-width: 768px) {
  .infoArea .detail_info .info_box .item .item_title {
    width: 100px;
  }
}
.infoArea .detail_info .info_box .item .item_text {
  flex: 1;
  font-size: 1.2rem;
  font-weight: 400;
  color: #404040;
  line-height: 1.65;
}
.infoArea .detail_info.detail_info2 .info_title {
  background: #262626;
  color: #FFFFFF;
  border-bottom-color: #404040;
}
.infoArea .detail_info.detail_info2 .info_box {
  background: #F5F5F5;
}
.infoArea .buy_content .buy_btn {
  position: fixed;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 100%;
  max-width: 640px;
  z-index: 25;
  display: flex;
  align-items: stretch;
  height: 72px;
  background: #171717;
  padding-bottom: env(safe-area-inset-bottom, 0);
}
@media (min-width: 1024px) {
  .infoArea .buy_content .buy_btn {
    position: static;
    transform: none;
    max-width: none;
    height: 64px;
    border-radius: 16px;
    margin: 2.4rem;
    padding-bottom: 0;
  }
}
.infoArea .buy_content .buy_btn .item {
  height: 100%;
}
.infoArea .buy_content .buy_btn .wish_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0.4rem;
  width: 72px;
  height: 100%;
  border-right: 1px solid rgba(255, 255, 255, 0.1);
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.infoArea .buy_content .buy_btn .wish_btn:hover {
  background: rgba(255, 255, 255, 0.05);
}
.infoArea .buy_content .buy_btn .wish_btn .img-box {
  width: 24px;
  height: 24px;
}
.infoArea .buy_content .buy_btn .wish_btn .img-box img {
  width: 100%;
  filter: brightness(0) invert(1);
}
.infoArea .buy_content .buy_btn .wish_btn .img-box .fill-wish {
  display: none;
}
.infoArea .buy_content .buy_btn .wish_btn.on .fill-wish {
  display: block;
}
.infoArea .buy_content .buy_btn .wish_btn.on .none-wish {
  display: none;
}
.infoArea .buy_content .buy_btn .wish_btn .count {
  font-size: 1.1rem;
  font-weight: 600;
  color: #FFFFFF;
}
.infoArea .buy_content .buy_btn .reserve_btn {
  flex: 1;
}
.infoArea .buy_content .buy_btn .reserve_btn .reser {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-size: 1.6rem;
  font-weight: 700;
  color: #FFFFFF;
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.infoArea .buy_content .buy_btn .reserve_btn .reser:hover {
  background: rgba(255, 255, 255, 0.05);
}
.infoArea .buy_content .option_basket {
  display: none;
  position: fixed;
  inset: 0;
  max-width: 640px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 50;
  background: rgba(23, 23, 23, 0.5);
  backdrop-filter: blur(8px);
}
.infoArea .buy_content .option_basket.active {
  display: block;
}
.infoArea .buy_content .bg_close {
  position: absolute;
  inset: 0;
  z-index: 1;
  cursor: pointer;
}
.infoArea .buy_content .option_box {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  background: #FFFFFF;
  border-radius: 24px 24px 0 0;
  z-index: 2;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
  animation: slideUp 400ms cubic-bezier(0, 0, 0.2, 1);
}
@keyframes slideUp {
  from {
    transform: translateY(100%);
  }
  to {
    transform: translateY(0);
  }
}
.infoArea .buy_content .option_box .title {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: 2rem 2rem;
  border-bottom: 1px solid #F5F5F5;
}
.infoArea .buy_content .option_box .title::before {
  content: "";
  position: absolute;
  top: 0.8rem;
  left: 50%;
  transform: translateX(-50%);
  width: 40px;
  height: 4px;
  background: #E5E5E5;
  border-radius: 9999px;
}
.infoArea .buy_content .option_box .title span {
  font-size: 1.6rem;
  font-weight: 700;
  color: #171717;
}
.infoArea .buy_content .option_box .title .close {
  position: absolute;
  right: 1.6rem;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 9999px;
  cursor: pointer;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.infoArea .buy_content .option_box .title .close:hover {
  background: #F5F5F5;
}
.infoArea .buy_content .option_box .title .close img {
  width: 20px;
  height: 20px;
  opacity: 0.7;
}
.infoArea .buy_content .option_box .info_txt {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.6rem 2rem;
  background: #FCFCFC;
}
.infoArea .buy_content .option_box .info_txt .name {
  font-size: 1.4rem;
  font-weight: 600;
  color: #262626;
}
.infoArea .buy_content .option_box .info_txt .price {
  font-size: 1.4rem;
  font-weight: 700;
  color: #171717;
}
.infoArea .buy_content .option_box .option_wrap {
  flex: 1;
  overflow-y: auto;
  max-height: 40vh;
  padding-bottom: 1.6rem;
}
.infoArea .buy_content .option_box .option_select {
  padding: 2rem;
}
.infoArea .buy_content .option_box .option_select .item {
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: 1.2rem 1.6rem;
  margin-bottom: 1.6rem;
}
.infoArea .buy_content .option_box .option_select .item:last-child {
  margin-bottom: 0;
}
.infoArea .buy_content .option_box .option_select .item label {
  font-size: 1.2rem;
  font-weight: 500;
  color: #737373;
  line-height: 48px;
}
.infoArea .buy_content .option_box .option_select .item.select_box select {
  width: 100%;
  height: 48px;
  padding: 0 4rem 0 1.6rem;
  font-size: 1.2rem;
  color: #404040;
  background: #FFFFFF;
  border: 1.5px solid #E5E5E5;
  border-radius: 12px;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237A8799' d='M6 8.5L1.5 4h9L6 8.5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1.6rem center;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.infoArea .buy_content .option_box .option_select .item.select_box select:focus {
  border-color: #18181B;
  box-shadow: 0 0 0 3px rgba(24, 24, 27, 0.08);
}
.infoArea .buy_content .option_box .option_select .item.count_box .opt_count {
  display: flex;
  border: 1.5px solid #E5E5E5;
  border-radius: 12px;
  overflow: hidden;
}
.infoArea .buy_content .option_box .option_select .item.count_box .opt_count .sit_qty_minus,
.infoArea .buy_content .option_box .option_select .item.count_box .opt_count .sit_qty_plus {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 46px;
  background: #FAFAFA;
  border: none;
  cursor: pointer;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.infoArea .buy_content .option_box .option_select .item.count_box .opt_count .sit_qty_minus:hover,
.infoArea .buy_content .option_box .option_select .item.count_box .opt_count .sit_qty_plus:hover {
  background: #F5F5F5;
}
.infoArea .buy_content .option_box .option_select .item.count_box .opt_count .num_input {
  flex: 1;
  height: 46px;
  border: none;
  text-align: center;
  font-size: 1.4rem;
  font-weight: 600;
  color: #171717;
  background: #FFFFFF;
}
.infoArea .buy_content .option_box #sit_sel_option .sit_opt_list {
  position: relative;
  padding: 1.6rem 2rem;
  border-bottom: 1px solid #F5F5F5;
}
.infoArea .buy_content .option_box #sit_sel_option .sit_opt_list .opt_name .sit_opt_subj {
  font-size: 1.4rem;
  font-weight: 500;
  color: #262626;
}
.infoArea .buy_content .option_box #sit_sel_option .sit_opt_list .sit_opt_prc {
  font-size: 1.4rem;
  font-weight: 700;
  color: #171717;
  float: right;
  margin-right: 3.2rem;
}
.infoArea .buy_content .option_box #sit_sel_option .sit_opt_list .opt_count {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 1.2rem;
  padding: 0.6rem;
  border: 1px solid #E5E5E5;
  border-radius: 8px;
}
.infoArea .buy_content .option_box #sit_sel_option .sit_opt_list .opt_count .fa {
  display: none;
}
.infoArea .buy_content .option_box #sit_sel_option .sit_opt_list .opt_count .sit_qty_plus,
.infoArea .buy_content .option_box #sit_sel_option .sit_opt_list .opt_count .sit_qty_minus {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background: url("../img/icon/plus.png") no-repeat center;
  background-size: 16px;
  cursor: pointer;
}
.infoArea .buy_content .option_box #sit_sel_option .sit_opt_list .opt_count .sit_qty_minus {
  background-image: url("../img/icon/minus.png");
}
.infoArea .buy_content .option_box #sit_sel_option .sit_opt_list .opt_count .num_input {
  width: 32px;
  height: 24px;
  border: none;
  text-align: center;
  font-size: 1.2rem;
  font-weight: 600;
  color: #171717;
}
.infoArea .buy_content .option_box #sit_sel_option .sit_opt_list .opt_count .sit_opt_del {
  position: absolute;
  right: 2rem;
  top: 1.6rem;
  width: 20px;
  height: 20px;
  background: url("../img/icon/close.png") no-repeat center;
  background-size: 12px;
  text-indent: -9999px;
  cursor: pointer;
}
.infoArea .buy_content .option_box #sit_tot_price {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 2rem;
  background: #FCFCFC;
}
.infoArea .buy_content .option_box #sit_tot_price span {
  font-size: 1.4rem;
  font-weight: 500;
  color: #525252;
}
.infoArea .buy_content .option_box #sit_tot_price strong {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 1.8rem;
  font-weight: 700;
  color: #18181B;
}
.infoArea .buy_content .option_box .basket_btn {
  padding: 1.6rem 2rem;
}
.infoArea .buy_content .option_box .basket_btn button[type=submit] {
  width: 100%;
  height: 52px;
  font-size: 1.4rem;
  font-weight: 700;
  color: #18181B;
  background: #FFFFFF;
  border: 2px solid #18181B;
  border-radius: 16px;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.infoArea .buy_content .option_box .basket_btn button[type=submit]:hover {
  background: rgba(24, 24, 27, 0.04);
}
.infoArea .buy_content .option_box .buy_button {
  display: flex;
  align-items: stretch;
  background: #18181B;
  padding-bottom: env(safe-area-inset-bottom, 0);
}
.infoArea .buy_content .option_box .buy_button .item {
  height: 56px;
}
.infoArea .buy_content .option_box .buy_button .wish_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0.4rem;
  width: 56px;
  border-right: 1px solid rgba(255, 255, 255, 0.2);
  cursor: pointer;
}
.infoArea .buy_content .option_box .buy_button .wish_btn .img-box {
  width: 20px;
}
.infoArea .buy_content .option_box .buy_button .wish_btn .img-box img {
  width: 100%;
  filter: brightness(0) invert(1);
}
.infoArea .buy_content .option_box .buy_button .wish_btn .count {
  font-size: 1rem;
  font-weight: 600;
  color: #FFFFFF;
}
.infoArea .buy_content .option_box .buy_button .reserve_btn {
  flex: 1;
}
.infoArea .buy_content .option_box .buy_button .reserve_btn .reser {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-size: 1.4rem;
  font-weight: 700;
  color: #FFFFFF;
  background: transparent;
  border: none;
  cursor: pointer;
}

/* ══════════════════════════════════════════════════════════════════════════
   레거시 호환
   ══════════════════════════════════════════════════════════════════════════ */
#sit {
  margin: 0;
}

.additional .tab_menu {
  display: flex;
  position: sticky;
  left: 0;
  top: 83px;
  background: #fff;
  z-index: 1;
}
.additional .tab_menu .tab-button {
  padding: 12px 0;
  font-size: 14px;
  font-weight: 400;
  color: var(--dark-2-color);
  flex: 1;
  text-align: center;
  border-bottom: 1px solid transparent;
  transition: 0.5s;
  cursor: pointer;
}
.additional .tab_menu .tab-button:hover, .additional .tab_menu .tab-button.active {
  color: var(--primary-color);
  border-bottom: 1px solid var(--blue-1-color);
  font-weight: 700;
}
.additional .tab_con {
  margin: 0px auto 40px;
  box-sizing: border-box;
}
.additional .tab_con .sub_contents_wrapper {
  padding: 0;
}
.additional .tab_con .tc_title {
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  text-align: center;
  color: #212121;
  font-weight: 600;
}
.additional .tab_con .tc_title a {
  width: 24px;
  margin-left: 0.4rem;
}
.additional .tab_con .tc_title a img {
  width: 100%;
}
.additional .tab_con.tab_con1 .product_details {
  max-width: 1040px;
}
.additional .tab_con.tab_con1 .product_details img {
  width: 100%;
}
.additional .tab_con.tab_con1 .product_details div a {
  display: inherit;
}
.additional .tab_con.tab_con2 .sit_use_top {
  display: none;
  /*background: #f8f7f7;
  position: relative;
  border: 1px solid #dad8d8;
  margin: 20px 0 15px;
  padding: 20px 40px;
  box-sizing: border-box;
  font-size: 12px;
  line-height: 45px;
  min-height: 90px;
  vertical-align: middle;
  #sit_use_wbtn {
    position: absolute;
    top: 50%;
    right: 30px;
    transform: translate(0, -50%);
    > a {
      padding: 0 20px;
      line-height: 45px;
      font-weight: bold;
      font-size: 1.167em;
      letter-spacing: -0.1em;

      &.btn01 {
        display: inline-block;
        border: 1px solid #bababa;
        border-radius: 3px;
        background: #fff;
        color: #717171;
        text-decoration: none;
        vertical-align: middle;
      }
      &.btn02 {
        display: inline-block;
        background: #18181B;
        color: #fff;
        border-radius: 3px;
        text-decoration: none;
        vertical-align: middle;
      }

      .sound_only {
        display: inline-block !important;
        position: absolute;
        top: 0;
        left: 0;
        margin: 0 !important;
        padding: 0 !important;
        font-size: 0;
        line-height: 0;
        border: 0 !important;
        overflow: hidden !important;
      }


    }
  }*/
}
.additional .tab_con.tab_con2 .review_wrap {
  border-top: 1px solid #dcecf5;
}
.additional .tab_con.tab_con2 .review_wrap .box {
  padding: 2rem;
  border-bottom: 1px solid #dcecf5;
  display: flex;
  flex-wrap: wrap;
}
.additional .tab_con.tab_con2 .review_wrap .box:last-child {
  border-bottom: 0;
}
.additional .tab_con.tab_con2 .review_wrap .box .user {
  color: #838383;
  font-size: 1.2rem;
  order: 4;
}
.additional .tab_con.tab_con2 .review_wrap .box .title {
  font-size: 1.6rem;
  font-weight: 600;
  width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: var(--blue-1-color) !important;
  margin-bottom: 0.8rem;
  order: 1;
  flex-basis: 100%;
}
.additional .tab_con.tab_con2 .review_wrap .box .text {
  color: var(--dark-2-color);
  transition: all 0.2s;
  font-weight: 500;
  width: 100%;
  white-space: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  font-size: 1.4rem;
  margin-bottom: 1.6rem;
  order: 2;
  flex-basis: 100%;
}
.additional .tab_con.tab_con2 .review_wrap .box .date {
  color: #838383;
  font-size: 1.2rem;
  order: 3;
  margin-right: 0.8rem;
}
.additional .tab_con.tab_con2 .review-wrt {
  font-size: 1.4em;
  font-weight: 600;
  color: #fff;
  padding: 16.5px 0;
  width: 95%;
  max-width: 226px;
  display: inline-block;
  border-radius: 10px;
  background-color: var(--primary-color);
  line-height: 1.2em;
  margin: 4rem auto 0;
  display: flex;
  justify-content: center;
}
.additional .tab_con.tab_con3 {
  padding: 0;
}
.additional .tab_con.tab_con3 .sec1 {
  padding: 0 16px;
  padding-bottom: 50px;
  overflow: hidden;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper {
  width: 100%;
  max-width: 1520px;
  margin: 0 auto;
  position: relative;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper .info_wrap {
  display: flex;
  flex-flow: column;
  justify-content: space-between;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper .info_wrap .info.txt {
  padding: 0 40px 30px 0;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper .info_wrap .info.txt h1 {
  font-style: italic;
  font-size: 3.2em;
  line-height: 4rem;
  color: #18181B;
  letter-spacing: -1px;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper .info_wrap .info.txt h4 {
  margin-top: 35px;
  margin-bottom: 30px;
  color: #625e5e;
  font-size: 1.7em;
  font-weight: 400;
  letter-spacing: -0.5px;
  line-height: 26px;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper .info_wrap .info.txt h4 span {
  color: #18181B;
  font-weight: 600;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper .info_wrap .info.txt p {
  line-height: 26px;
  color: #625e5e;
  font-size: 1.7em;
  font-weight: 500;
  letter-spacing: -0.5px;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper .info_wrap .info.txt p strong {
  font-weight: 700;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper .info_wrap .info.txt p span {
  color: #18181B;
  font-weight: 600;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper .info_wrap .info.img img {
  width: 100%;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper > .absol.absol2 {
  padding-top: 10px;
}
.additional .tab_con.tab_con3 .sec1 .sub_contents_wrapper > .absol.absol2 img {
  width: 100%;
}
.additional .tab_con.tab_con3 .sec3 {
  padding: 100px 0;
  background-color: #f5f5f5;
}
.additional .tab_con.tab_con3 .sec3 .sub_contents_wrapper.con_inner {
  padding: 0 20px;
}
.additional .tab_con.tab_con3 .sec3 .sub_contents_wrapper.con_inner .product_title {
  margin-bottom: 60px;
}
.additional .tab_con.tab_con3 .sec3 .sub_contents_wrapper.con_inner .product_title .title {
  font-size: 3.5em;
  font-weight: 400;
  line-height: 42px;
  margin-bottom: 24px;
  text-align: center;
}
.additional .tab_con.tab_con3 .sec3 .sub_contents_wrapper.con_inner .product_title .title strong {
  font-weight: 600;
}
.additional .tab_con.tab_con3 .sec3 .sub_contents_wrapper.con_inner .product_title h4 {
  font-size: 17px;
  color: #333;
  font-weight: 500;
  line-height: 24px;
  letter-spacing: -1px;
  text-align: center;
}
.additional .tab_con.tab_con3 .sec3 .sub_contents_wrapper.con_inner .compare_con {
  display: flex;
  position: relative;
  flex-flow: column;
}
.additional .tab_con.tab_con3 .sec3 .sub_contents_wrapper.con_inner .compare_con .box {
  width: 100%;
  margin-right: 0;
  margin-bottom: 20px;
  line-height: 0;
}
.additional .tab_con.tab_con3 .sec3 .sub_contents_wrapper.con_inner .compare_con .box:last-child {
  margin-bottom: 0;
}
.additional .tab_con.tab_con3 .sec3 .sub_contents_wrapper.con_inner .compare_con .box img {
  width: 100%;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  overflow: hidden;
}
.additional .tab_con.tab_con3 .sec3 .sub_contents_wrapper.con_inner .compare_con .box p {
  padding: 16px 20px;
  color: #1e2448;
  font-size: 12px;
  font-weight: 500;
  text-align: center;
  background-color: #ebe7e3;
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px;
}

.review_pop_wrap {
  position: fixed;
  left: 0;
  background: rgba(0, 0, 0, 0.2);
  width: 100%;
  height: 100vh;
  z-index: 1005;
  overflow: hidden;
  top: 50%;
  transform: translateY(-50%);
}
.review_pop_wrap .rv_pop {
  width: 100%;
  max-width: 800px;
  height: 100vh;
  margin: 0 auto;
  background: #fff;
}
.review_pop_wrap .rv_pop .rv_title {
  position: relative;
  border-bottom: 1px solid #ddd;
  text-align: center;
  padding: 20px 0;
}
.review_pop_wrap .rv_pop .rv_title .f18 {
  font-weight: 700;
  font-size: 18px;
  line-height: 28px;
}
.review_pop_wrap .rv_pop .rv_title .close {
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
}
.review_pop_wrap .rv_pop .rv_title .close img {
  width: 100%;
  max-width: 15px;
}
.review_pop_wrap .rv_pop .rv_con {
  padding: 15px 70px;
  overflow-y: auto;
  height: calc(100% - 70px);
}
.review_pop_wrap .rv_pop .rv_con .box {
  border-bottom: 1px solid #ddd;
  padding: 30px 0;
}
.review_pop_wrap .rv_pop .rv_con .box.text {
  border-bottom: 0;
  padding-top: 40px;
}
.review_pop_wrap .rv_pop .rv_con .box.text img {
  max-width: 100%;
  height: auto !important;
  width: auto !important;
}
.review_pop_wrap .rv_pop .rv_con .box.text .con_txt p {
  font-size: 20px;
  font-weight: 300;
  color: #18181B;
  line-height: 32px;
}
.review_pop_wrap .rv_pop .rv_con .box .name {
  font-size: 16px;
  font-weight: 700;
  line-height: 26px;
}
.review_pop_wrap .rv_pop .rv_con .box .date {
  font-size: 13px;
  font-weight: 400;
  line-height: 21px;
  color: #aaa;
}
.review_pop_wrap .rv_pop .rv_con .box .pd_name {
  font-size: 15px;
  font-weight: 600;
  line-height: 25px;
  letter-spacing: -0.5px;
}
.review_pop_wrap .rv_pop .rv_con .box .price {
  letter-spacing: 0;
}
.review_pop_wrap .rv_pop .rv_con .box .price .f12 {
  color: #bbb;
  text-decoration: line-through;
  margin-right: 7px;
}
.review_pop_wrap .rv_pop .rv_con .box .img_wrap {
  margin-top: 50px;
}
.review_pop_wrap .rv_pop .rv_con .box .img_wrap .rv_image {
  margin: 0 0 20px;
  border-radius: 20px;
  overflow: hidden;
  flex: 0 1 calc(50% - 10px);
  display: flex;
}
.review_pop_wrap .rv_pop .rv_con .box .img_wrap .rv_image img {
  border-radius: 20px;
  width: auto;
}

/**
 * ALPS 2026 - Premium Product List Page
 * ══════════════════════════════════════════════════════════════════════════
 * 
 * 상품 목록 페이지:
 * - 미니멀한 그리드 레이아웃
 * - 프리미엄 필터/정렬 UI
 * - 부드러운 인터랙션
 * 
 * @버전: 3.0
 * @최종수정: 2026-01-07
 */
/* ══════════════════════════════════════════════════════════════════════════
   상품 목록 페이지 래퍼
   ══════════════════════════════════════════════════════════════════════════ */
.products {
  background: #FFFFFF;
  padding-bottom: calc(56px + env(safe-area-inset-bottom, 0) + 3.2rem);
}
@media (min-width: 1024px) {
  .products {
    padding-bottom: 6.4rem;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   페이지 타이틀 (Premium Hero Style)
   ══════════════════════════════════════════════════════════════════════════ */
.products_title {
  padding: 4rem 2rem;
  text-align: center;
  background: linear-gradient(180deg, #FCFCFC 0%, #FFFFFF 100%);
}
@media (min-width: 768px) {
  .products_title {
    padding: 4.8rem 2.4rem;
  }
}
@media (min-width: 1024px) {
  .products_title {
    padding: 6.4rem 3.2rem;
  }
}
.products_title_top {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  color: #171717;
  letter-spacing: -0.025em;
  margin-bottom: 1.2rem;
}
@media (min-width: 768px) {
  .products_title_top {
    font-size: 2.8rem;
  }
}
@media (min-width: 1024px) {
  .products_title_top {
    font-size: 3.6rem;
    margin-bottom: 1.6rem;
  }
}
.products_title_bottom {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.65;
  color: #737373;
  max-width: 480px;
  margin: 0 auto;
}
@media (min-width: 768px) {
  .products_title_bottom {
    font-size: 1.6rem;
  }
}
.products_title_bottom .word-bold {
  font-weight: 600;
  color: #404040;
}

.products_head_html img {
  width: 100%;
  display: block;
}

/* ══════════════════════════════════════════════════════════════════════════
   서브 탭 (카테고리 필터) - Premium Pill Style
   ══════════════════════════════════════════════════════════════════════════ */
.products_tabs {
  padding: 2rem;
}
@media (min-width: 768px) {
  .products_tabs {
    padding: 2.4rem;
  }
}
@media (min-width: 1024px) {
  .products_tabs {
    padding: 3.2rem;
    max-width: none;
    margin: 0 auto;
  }
}
.products_tabs ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.8rem;
}
@media (min-width: 768px) {
  .products_tabs ul {
    gap: 1rem;
  }
}
.products_tabs ul .tab_item a {
  display: inline-block;
  padding: 0.8rem 1.6rem;
  font-size: 1.2rem;
  font-weight: 500;
  color: #737373;
  background: #FFFFFF;
  border: 1.5px solid #E5E5E5;
  border-radius: 9999px;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .products_tabs ul .tab_item a {
    padding: 1rem 2rem;
    font-size: 1.4rem;
  }
}
.products_tabs ul .tab_item a:hover {
  border-color: #D4D4D4;
  color: #404040;
  background: #FAFAFA;
}
.products_tabs ul .tab_item.active a {
  background: #171717;
  color: #FFFFFF;
  border-color: #171717;
  font-weight: 600;
}

/* ══════════════════════════════════════════════════════════════════════════
   유틸리티 바 (정렬/카운트) - Premium Minimal
   ══════════════════════════════════════════════════════════════════════════ */
.products_utils {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.6rem 2rem;
}
@media (min-width: 768px) {
  .products_utils {
    padding: 2rem 2.4rem;
  }
}
@media (min-width: 1024px) {
  .products_utils {
    padding: 2.4rem 3.2rem;
    max-width: none;
    margin: 0 auto;
  }
}
.products_utils .total {
  font-size: 1.2rem;
  font-weight: 500;
  color: #737373;
}
.products_utils .total strong {
  font-weight: 700;
  color: #262626;
}
.products_utils .sort {
  display: flex;
  align-items: center;
  gap: 1.2rem;
}
.products_utils .sort_select {
  appearance: none;
  -webkit-appearance: none;
  padding: 0.8rem 3.2rem 0.8rem 1.2rem;
  font-size: 1.2rem;
  font-weight: 500;
  color: #404040;
  background: #FFFFFF;
  border: 1px solid #E5E5E5;
  border-radius: 12px;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237A8799' d='M6 8.5L1.5 4h9L6 8.5z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 12px;
}
.products_utils .sort_select:hover {
  border-color: #D4D4D4;
}
.products_utils .sort_select:focus {
  outline: none;
  border-color: #18181B;
  box-shadow: 0 0 0 3px rgba(24, 24, 27, 0.08);
}
.products_utils .view_mode {
  display: flex;
  gap: 0.4rem;
}
.products_utils .view_mode button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: transparent;
  border: 1px solid #E5E5E5;
  border-radius: 8px;
  color: #A3A3A3;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.products_utils .view_mode button:hover {
  border-color: #D4D4D4;
  color: #525252;
}
.products_utils .view_mode button.active {
  background: #171717;
  border-color: #171717;
  color: #FFFFFF;
}
.products_utils .view_mode button img {
  width: 18px;
  height: 18px;
}

/* ══════════════════════════════════════════════════════════════════════════
   상품 리스트 그리드 - Premium Grid
   ══════════════════════════════════════════════════════════════════════════ */
.products_list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2.4rem 1.6rem;
  padding: 0 2rem;
}
@media (min-width: 768px) {
  .products_list {
    grid-template-columns: repeat(3, 1fr);
    gap: 3.2rem 2rem;
    padding: 0 2.4rem;
  }
}
@media (min-width: 1024px) {
  .products_list {
    grid-template-columns: repeat(4, 1fr);
    gap: 4rem 2.4rem;
    padding: 0 3.2rem;
    max-width: none;
    margin: 0 auto;
  }
}
.products_list .product {
  position: relative;
}
.products_list .product_img {
  display: block;
  width: 100%;
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  background: #FAFAFA;
  aspect-ratio: 1/1.2;
}
@media (min-width: 1024px) {
  .products_list .product_img {
    border-radius: 20px;
  }
}
.products_list .product_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 400ms cubic-bezier(0, 0, 0.2, 1);
}
.products_list .product_img .over-img {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  opacity: 0;
  z-index: 5;
  transition: opacity 200ms cubic-bezier(0, 0, 0.2, 1);
}
.products_list .product_img:hover img {
  transform: scale(1.04);
}
.products_list .product_img:hover .over-img {
  opacity: 1;
}
.products_list .product_info {
  padding-top: 1.6rem;
}
.products_list .product_info_title {
  font-size: 1.2rem;
  font-weight: 500;
  color: #262626;
  line-height: 1.35;
  margin-bottom: 0.8rem;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  transition: color 150ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 768px) {
  .products_list .product_info_title {
    font-size: 1.4rem;
  }
}
.products_list .product_info_title:hover {
  color: #18181B;
}
.products_list .product_info_price {
  font-size: 1.6rem;
  font-weight: 700;
  color: #171717;
}
@media (min-width: 768px) {
  .products_list .product_info_price {
    font-size: 1.8rem;
  }
}
.products_list .product_info_etc {
  font-size: 1.1rem;
  color: #A3A3A3;
  margin-top: 0.4rem;
}
@media (min-width: 768px) {
  .products_list .product_info_etc {
    font-size: 1.2rem;
  }
}
.products_list .product_info .cutsom {
  display: block;
  font-size: 1.2rem;
  font-weight: 400;
  color: #A3A3A3;
  text-decoration: line-through;
  margin-bottom: 0.4rem;
}
.products_list .product_info .final-price {
  display: flex;
  align-items: baseline;
  gap: 0.8rem;
}
.products_list .product_info .final-price .discount-rate {
  font-size: 1.6rem;
  font-weight: 800;
  color: #DC2626;
}
@media (min-width: 768px) {
  .products_list .product_info .final-price .discount-rate {
    font-size: 1.8rem;
  }
}
.products_list .product_wish_btn {
  position: absolute;
  top: 1.2rem;
  right: 1.2rem;
  z-index: 10;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(8px);
  border-radius: 9999px;
  box-shadow: 0 2px 12px rgba(23, 23, 23, 0.08);
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 1024px) {
  .products_list .product_wish_btn {
    width: 40px;
    height: 40px;
  }
}
.products_list .product_wish_btn img {
  width: 18px;
  height: 18px;
  opacity: 0.6;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
@media (min-width: 1024px) {
  .products_list .product_wish_btn img {
    width: 20px;
    height: 20px;
  }
}
.products_list .product_wish_btn:hover {
  transform: scale(1.1);
  box-shadow: 0 4px 16px rgba(23, 23, 23, 0.12);
}
.products_list .product_wish_btn:hover img {
  opacity: 1;
}
.products_list .product_wish_btn.active {
  background: #DC2626;
}
.products_list .product_wish_btn.active img {
  filter: brightness(0) invert(1);
  opacity: 1;
}
.products_list .product .product-badges {
  position: absolute;
  top: 1.2rem;
  left: 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  z-index: 5;
}
.products_list .product .product-badges .badge {
  display: inline-block;
  padding: 0.4rem 0.8rem;
  font-size: 1rem;
  font-weight: 700;
  border-radius: 8px;
  text-transform: uppercase;
}
.products_list .product .product-badges .badge-new {
  background: #18181B;
  color: #FFFFFF;
}
.products_list .product .product-badges .badge-best {
  background: #F59E0B;
  color: #FFFFFF;
}
.products_list .product .product-badges .badge-sale {
  background: #DC2626;
  color: #FFFFFF;
}
.products_list .product .product-badges .badge-soldout {
  background: #A3A3A3;
  color: #FFFFFF;
}

/* ══════════════════════════════════════════════════════════════════════════
   빈 상태
   ══════════════════════════════════════════════════════════════════════════ */
.products_empty {
  text-align: center;
  padding: 8rem 2rem;
}
.products_empty .empty-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 2.4rem;
  opacity: 0.3;
}
.products_empty .empty-title {
  font-size: 1.6rem;
  font-weight: 600;
  color: #525252;
  margin-bottom: 0.8rem;
}
.products_empty .empty-text {
  font-size: 1.4rem;
  color: #A3A3A3;
}

/* ══════════════════════════════════════════════════════════════════════════
   필터 패널 (사이드 필터)
   ══════════════════════════════════════════════════════════════════════════ */
.products_filter {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  max-width: 360px;
  height: 100vh;
  height: 100dvh;
  background: #FFFFFF;
  z-index: 50;
  transform: translateX(-100%);
  transition: transform 400ms cubic-bezier(0, 0, 0.2, 1);
  box-shadow: none;
}
@media (min-width: 1024px) {
  .products_filter {
    position: static;
    transform: none;
    max-width: 280px;
    height: auto;
    box-shadow: none;
  }
}
.products_filter.active {
  transform: translateX(0);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.15);
}
.products_filter_header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 60px;
  padding: 0 1.6rem;
  border-bottom: 1px solid #F5F5F5;
}
.products_filter_header .title {
  font-size: 1.6rem;
  font-weight: 700;
  color: #171717;
}
.products_filter_header .close {
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  margin: 0;
  font: inherit;
  color: inherit;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  transition: all 150ms cubic-bezier(0, 0, 0.2, 1);
}
.products_filter_header .close:hover {
  background: #F5F5F5;
}
.products_filter_header .close img {
  width: 20px;
  height: 20px;
  opacity: 0.7;
}
@media (min-width: 1024px) {
  .products_filter_header .close {
    display: none;
  }
}
.products_filter_body {
  padding: 2rem;
  overflow-y: auto;
  max-height: calc(100vh - 60px - 80px);
}
.products_filter_group {
  margin-bottom: 2.4rem;
}
.products_filter_group:last-child {
  margin-bottom: 0;
}
.products_filter_group .group-title {
  font-size: 1.2rem;
  font-weight: 600;
  color: #404040;
  margin-bottom: 1.2rem;
}
.products_filter_group .group-items {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}
.products_filter_group .filter-item {
  padding: 0.8rem 1.2rem;
  font-size: 1.2rem;
  font-weight: 500;
  color: #525252;
  background: #FAFAFA;
  border: 1px solid transparent;
  border-radius: 12px;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.products_filter_group .filter-item:hover {
  background: #F5F5F5;
}
.products_filter_group .filter-item.active {
  background: rgba(24, 24, 27, 0.08);
  color: #18181B;
  border-color: #18181B;
}
.products_filter_footer {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1.6rem;
  background: #FFFFFF;
  border-top: 1px solid #F5F5F5;
  display: flex;
  gap: 1.2rem;
}
@media (min-width: 1024px) {
  .products_filter_footer {
    display: none;
  }
}
.products_filter_footer .btn-reset {
  flex: 1;
  height: 48px;
  background: #F5F5F5;
  color: #404040;
  font-size: 1.2rem;
  font-weight: 600;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.products_filter_footer .btn-reset:hover {
  background: #E5E5E5;
}
.products_filter_footer .btn-apply {
  flex: 2;
  height: 48px;
  background: #18181B;
  color: #FFFFFF;
  font-size: 1.2rem;
  font-weight: 700;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0, 0, 0.2, 1);
}
.products_filter_footer .btn-apply:hover {
  background: #0D0D0F;
}

.products_filter_bg {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(23, 23, 23, 0.4);
  z-index: 40;
  backdrop-filter: blur(8px);
}
.products_filter_bg.active {
  display: block;
}
@media (min-width: 1024px) {
  .products_filter_bg {
    display: none !important;
  }
}

/* ══════════════════════════════════════════════════════════════════════════
   레거시 호환
   ══════════════════════════════════════════════════════════════════════════ */
@media screen and (min-width: 768px) {
  #app .products_title_bottom .dp-block {
    display: block;
  }
}
/* 팝업레이어 */
#hd_pop {
  z-index: 90000;
  position: relative;
  margin: 0 auto;
  height: 0;
}
#hd_pop .hd_pops {
  position: absolute;
  left: 50%;
  top: 50px;
  transform: translateX(-50%);
  border: 1px solid #e9e9e9;
  background: #fff;
  width: 92%;
}
#hd_pop .hd_pops .hd_pops_con {
  cursor: pointer;
  max-width: 100%;
  line-height: 0;
}
#hd_pop .hd_pops .hd_pops_con p {
  line-height: 0;
}
#hd_pop .hd_pops .hd_pops_con img {
  width: 100%;
}
#hd_pop .hd_pops_footer {
  background: #000;
  color: #fff;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#hd_pop .hd_pops_footer.after {
  display: block;
  visibility: hidden;
  clear: both;
  content: "";
}
#hd_pop .hd_pops_footer button {
  padding: 10px;
  color: #fff;
  font-size: 1.3em;
  line-height: 1.2em;
  cursor: pointer;
}
#hd_pop .hd_pops_footer button.hd_pops_reject {
  background: #000;
  text-align: left;
}
#hd_pop .hd_pops_footer button.hd_pops_close {
  height: 100%;
  background: #393939;
}

@media screen and (min-width: 640px) {
  #hd_pop .hd_pops {
    left: 200px;
    top: 100px;
    transform: none;
    width: auto;
  }
  #hd_pop .hd_pops_con {
    width: 450px;
  }
}
/* 캡챠 자동등록(입력)방지 기본 */
#captcha {
  display: inline-block;
  position: relative;
}
#captcha audio {
  margin: 12px 0 4px;
  display: block;
  width: 100%;
}
#captcha #captcha_img {
  height: 40px;
  border: 1px solid #898989;
  vertical-align: top;
  padding: 0;
  margin: 0;
  display: inline-block;
  width: 90px;
}
#captcha #captcha_mp3 {
  margin: 0;
  padding: 0;
  width: 40px;
  height: 40px;
  border: 0;
  background: transparent;
  vertical-align: middle;
  overflow: hidden;
  cursor: pointer;
  background: url("../img/web/png/captcha.png") no-repeat;
  text-indent: -999px;
  border-radius: 3px;
  display: none;
}
#captcha #captcha_reload {
  margin: 0;
  padding: 0;
  width: 40px;
  height: 40px;
  border: 0;
  background: transparent;
  vertical-align: middle;
  overflow: hidden;
  cursor: pointer;
  background: url("../img/web/png/captcha.png") no-repeat 0 -40px;
  text-indent: -999px;
  border-radius: 3px;
}
#captcha #captcha_key {
  margin: 0 0 0 3px;
  padding: 0 5px;
  width: 90px;
  height: 40px;
  border: 1px solid #ccc;
  background: #fff;
  font-size: 1.333em;
  font-weight: bold;
  text-align: center;
  border-radius: 3px;
  vertical-align: top;
  position: relative;
  background-image: url("../img/icon/star.png");
  background-repeat: no-repeat;
  background-position: 97% 7%;
  background-size: 11px 11px;
}
#captcha #captcha_info {
  display: block;
  margin: 5px 0 0;
  font-size: 1.2em;
  letter-spacing: -0.1em;
}

/*** 장바구니 상품 리스트 ***/
.select-list {
  /*** 전체선택 ***/
}
.select-list .all-select {
  padding: 12px 0;
}
.select-list .all-select .form-check-label {
  font-size: 1.4em;
  color: var(--gray-6-color);
  line-height: 1.2857em;
  padding-left: 22px;
}
.select-list .select-form {
  position: relative;
}
.select-list .select-form input[type=checkbox] {
  display: none;
}
.select-list .select-form input[type=checkbox] + label::after {
  position: absolute;
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 1px solid var(--gray-4-color);
  box-sizing: border-box;
  border-radius: 50%;
  left: 2px;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
}
.select-list .select-form input[type=checkbox]:checked + label::after {
  position: absolute;
  content: "";
  background: url("../img/icon/select.png") no-repeat;
  background-size: contain;
  width: 14px;
  height: 14px;
  border: none;
  box-sizing: border-box;
  left: 2px;
  top: 50%;
  transform: translateY(-50%);
}
.select-list .select-form input[type=checkbox] {
  display: none;
}
.select-list .select-form input[type=radio] + label::after {
  position: absolute;
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 1px solid var(--gray-4-color);
  box-sizing: border-box;
  border-radius: 50%;
  left: 2px;
  top: 50%;
  transform: translateY(-50%);
}
.select-list .select-form input[type=radio]:checked + label::after {
  position: absolute;
  content: "";
  background: url("../img/icon/select.png") no-repeat;
  background-size: contain;
  width: 14px;
  height: 14px;
  border: none;
  box-sizing: border-box;
  left: 2px;
  top: 50%;
  transform: translateY(-50%);
}
.select-list .select-form input[type=radio] {
  display: none;
}
.select-list .select-box {
  border-top: 1px solid var(--primary-color);
  border-bottom: 1px solid var(--primary-color);
}
.select-list .select-box .item {
  display: flex;
  align-items: center;
  padding: 20px 0;
  border-bottom: 1px solid var(--gray-2-color);
  width: 100%;
  position: relative;
}
.select-list .select-box .item:last-child {
  border-bottom: none;
}
.select-list .select-box .item .item-contents {
  display: flex;
  width: 100%;
}
.select-list .select-box .item .item-contents .img-bx {
  width: 76px;
}
.select-list .select-box .item .item-contents .img-bx img {
  width: 100%;
}
.select-list .select-box .item .item-contents .txt-box {
  padding-left: 8px;
  width: calc(100% - 76px);
  box-sizing: border-box;
  position: relative;
}
.select-list .select-box .item .item-contents .txt-box .name {
  font-size: 1.5em;
  letter-spacing: -0.04em;
  color: var(--dark-1-color);
}
.select-list .select-box .item .item-contents .txt-box .figure-ls {
  padding-top: 8px;
  font-size: 10px;
}
.select-list .select-box .item .item-contents .txt-box .figure-ls li {
  font-size: 1.4em;
  color: var(--gray-5-color);
  display: block;
}
.select-list .select-box .item .item-contents .txt-box .price {
  font-size: 1.4em;
  letter-spacing: -0.03em;
  font-weight: 500;
  color: var(--dark-1-color);
  display: block;
  position: absolute;
  bottom: 0;
  right: 0;
}
.select-list .select-box .item .close-btn {
  width: 12px;
  position: absolute;
  top: 20px;
  right: 0;
}
.select-list .select-box .item .close-btn img {
  width: 100%;
}

/*** 제품 삭제 버튼 ***/
.like-all {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.like-all .all-select {
  border-bottom: none;
}
.like-all .del-btn {
  font-size: 1.4em;
  line-height: 1em;
  font-weight: 400;
  color: var(--gray-6-color);
  background-color: #fff;
  border: none;
  border-bottom: 1px solid var(--gray-6-color);
  cursor: pointer;
}

#sod_frm_pay {
  margin-top: 1.6rem;
  padding-top: 1.6rem;
  border-top: 1px solid var(--primary-color);
}
#sod_frm_pay h2 {
  font-size: 1.4em;
  font-weight: 400;
  color: var(--dark-2-color);
}
#sod_frm_pay #od_tot_price {
  margin: 1.6rem 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#sod_frm_pay #od_tot_price span {
  font-size: 1.4em;
  color: var(--gray-5-color);
}
#sod_frm_pay #od_tot_price div {
  font-size: 1.8em;
  font-weight: 600;
  line-height: 1.1933em;
  color: #ff2f41;
  letter-spacing: -0.54px;
}

#display_pay_button {
  margin-top: 1.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
}
@media screen and (min-width: 500px) {
  #display_pay_button {
    flex-direction: row;
    gap: 1.6rem;
  }
}
#display_pay_button .btn01,
#display_pay_button .btn_submit {
  font-size: 1.4em;
  font-weight: 600;
  width: 100%;
  box-sizing: border-box;
  display: block;
  text-align: center;
  border-radius: 10px;
  cursor: pointer;
  line-height: 50px;
}
#display_pay_button .btn01 {
  border: 1px solid #ddd;
  background-color: #ddd;
}
#display_pay_button .btn_submit {
  border: 1px solid var(--primary-color);
  color: var(--primary-color);
  background-color: #fff;
}

.board_wrap .wrt-btn {
  text-align: center;
  padding: 20px 0;
}
.board_wrap .wrt-btn a {
  font-size: 1.4em;
  font-weight: 600;
  color: #fff;
  padding: 16.5px 95px;
  display: inline-block;
  border-radius: 10px;
  background-color: var(--primary-color);
  margin-bottom: 40px;
  line-height: 1.2em;
}

.board_event .event_list {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 20px;
}
.board_event .event_list .list_item picture img {
  width: 100%;
}

.none-have {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 306.12px);
  box-sizing: border-box;
}
.none-have svg {
  margin-top: -27rem;
}
.none-have .txt {
  margin-top: 12px;
  font-size: 1.4rem;
  color: var(--gray-5-color);
}

.useform_write {
  padding: 0 2rem 4rem;
  background-color: #fff;
  height: 100vh;
  box-sizing: border-box;
}
.useform_write #win_title {
  margin: 0 10px;
  font-size: 20px;
  font-weight: 700;
  padding: 40px 0;
  line-height: 25px;
  text-align: center;
  color: var(--primary-color);
}
.useform_write .new_win_con .form_title input[type=text]#is_subject {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid #cadeee;
  font-size: 14px;
  line-height: 120%;
  color: #212121;
  font-weight: 400;
  box-sizing: border-box;
}
.useform_write .new_win_con .form_title input[type=text]#is_subject::placeholder {
  color: #cadeee;
  font-weight: 600;
}
.useform_write .new_win_con .form_content {
  margin-top: 12px;
}
.useform_write .new_win_con .form_content::after {
  content: "";
  display: block;
  clear: both;
}
.useform_write .new_win_con .form_content .cke_sc {
  margin-bottom: 0.8rem;
  padding: 5px 10px;
  float: right;
  border: 1px solid #ccc !important;
  background: #fafafa !important;
  color: #000 !important;
  text-decoration: none !important;
  line-height: 23px;
  vertical-align: middle;
}
.useform_write .new_win_con .form_content .cke_sc .btn_cke_sc {
  line-height: normal;
}
.useform_write .new_win_con .win_btn {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 20px;
  gap: 12px;
}
.useform_write .new_win_con .win_btn .btn_submit,
.useform_write .new_win_con .win_btn .btn_close {
  padding: 10px 23px;
  border: 1px solid #65c2bd;
  border-radius: 5px;
  font-size: 14px;
  font-weight: 600;
  line-height: 120%;
}
.useform_write .new_win_con .win_btn .btn_submit {
  order: 2;
  color: #fff;
  background-color: #65c2bd;
}
.useform_write .new_win_con .win_btn .btn_close {
  order: 1;
  color: #65c2bd;
}

.event {
  padding-bottom: 4rem;
}
.event .sub_contents_wrapper header {
  display: flex;
  flex-flow: column;
  border-bottom: 1px solid #5F84A1;
}
.event .sub_contents_wrapper header #bo_v_title {
  border-bottom: 1px solid #5F84A1;
  order: 1;
}
.event .sub_contents_wrapper header h5 {
  order: 2;
  font-size: 1.2rem;
  line-height: 1.8rem;
  color: #818181;
  padding: 0.8rem 0;
}
.event .sub_contents_wrapper h6 {
  display: none;
}
.event .sub_contents_wrapper #bo_v_info {
  display: none;
}
.event .sub_contents_wrapper #bo_v_atc #bo_v_con {
  padding: 0;
  border: none;
  border-radius: 0;
}
.event .sub_contents_wrapper #bo_v_atc #bo_v_con img {
  width: 100%;
}
.event .sub_contents_wrapper #bo_v_share {
  padding: 0;
}
.event .sub_contents_wrapper .btn_v_01 .btn_b01 {
  padding: 0 !important;
  background: url("../img/icon/write.png") no-repeat !important;
  background-size: contain !important;
}
.event .sub_contents_wrapper .btn_v_01 .btn_b01.sub_btns {
  background: url("../img/icon/list.png") no-repeat !important;
  background-size: contain !important;
}

.event .w_tables {
  border-top: 0 !important;
}
.event .w_tables td {
  border-bottom: 1px solid #CADEEE !important;
}
.event .w_tables .thead {
  padding: 1.2rem 1rem !important;
  word-break: keep-all;
}
.event .w_tables .w_inputs {
  padding: 0.5rem 0.8rem;
  border-radius: 3px;
  box-sizing: border-box;
}
.event .w_tables .w_inputs::placeholder {
  color: #CADEEE;
}
.event .w_tables .hasDatepicker {
  width: 47% !important;
}
.event .w_tables .cont_td {
  border-bottom: 0 !important;
}
.event .w_tables .chk_box {
  margin-right: 1rem !important;
}
.event .w_tables .chk_box input[type=checkbox] + label {
  font-size: 1.2rem;
  color: var(--dark-1-color);
  padding-left: 2.6rem;
  padding-top: 0;
}
.event .w_tables .chk_box input[type=checkbox] + label span {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 0;
  background: url("../img/icon/select4.png") no-repeat center center;
  background-size: cover;
  top: 50%;
  transform: translateY(-50%);
}
.event .w_tables .chk_box input[type=checkbox]:checked + label span {
  background: url("../img/icon/select.png") no-repeat center center;
  background-size: cover;
}
.event .w_tables #wr_content {
  box-sizing: border-box;
}

.ui-widget.ui-widget-content {
  left: 50% !important;
  transform: translateX(-50%);
  width: 90% !important;
  max-width: 350px;
}

.nomembers-order .nomember-pickup-title p {
  font-size: 1.2rem;
  color: var(--primary-color);
  margin-top: 0.8rem;
}
.nomembers-order .nonmember-info .info-input {
  font-size: 1.2em;
  font-weight: 400;
  color: var(--gray-5-color);
  border: 1px solid var(--gray-2-color);
  width: 100%;
  padding: 10px;
  box-sizing: border-box;
  outline: none;
  margin-bottom: 1.2rem;
}
.nomembers-order .nonmember-info .info-input:last-child {
  margin-bottom: 2rem;
}
.nomembers-order .reserve-btn button {
  width: 100%;
  display: block;
  max-width: 254px;
  margin: 0 auto;
  line-height: 1.56rem;
  font-size: 1.3em;
  font-weight: 600;
  color: #fff;
  padding: 12px 0;
  border-radius: 50px;
  border: none;
  background: var(--primary-color);
}

.pickup-search {
  padding-bottom: 4rem;
  background-color: #fff;
}
.pickup-search .find_store {
  flex-direction: column;
}
.pickup-search .find_store .sec1 {
  width: 100% !important;
}
.pickup-search .find_store .sec1 .top_banner {
  height: 55vh !important;
  max-height: 465px;
}
.pickup-search .find_store .sec1 #map {
  height: 55vh !important;
  max-height: 465px;
}
.pickup-search .find_store .sub_contents_wrapper {
  width: 100% !important;
  padding: 0;
}
.pickup-search .find_store .sub_contents_wrapper .board {
  margin: 0 !important;
}
.pickup-search .find_store .sub_contents_wrapper .board .line_list_title {
  display: none;
}
.pickup-search .find_store .sec2 .accordion {
  border-top: 1px solid var(--blue-1-color);
}
.pickup-search .find_store .sec2 .accordion li {
  border-bottom: 1px solid var(--blue-1-color);
  padding: 1.6rem !important;
  cursor: pointer;
}
.pickup-search .find_store .sec2 .accordion .address p {
  display: none;
}
.pickup-search .find_store .sec2 .accordion .detail {
  padding: 0 !important;
}
.pickup-search .find_store .sec2 .accordion .detail p {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--primary-color);
  margin-bottom: 0;
  line-height: 1.92rem;
}
.pickup-search .find_store .sec2 .accordion .detail .con h5 {
  line-height: 1.44rem;
}
.pickup-search .find_store .sec2 .accordion .detail .con h5 strong {
  display: none;
}
.pickup-search .find_store .sec2 .accordion .detail .con h5 span {
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--gray-6-color);
  display: block;
  padding-top: 8px;
}
.pickup-search .find_store .sec2 .accordion .detail .con h5:nth-of-type(2) span {
  position: relative;
  display: inline-block;
}
.pickup-search .find_store .sec2 .accordion .detail .con h5:nth-of-type(2) span::after {
  position: absolute;
  content: "";
  width: 100%;
  height: 1px;
  background-color: var(--gray-6-color);
  left: 0;
  bottom: 0;
}
.pickup-search .find_store .m_line_list_title {
  display: block;
  padding: 2rem;
  margin: 0 !important;
  width: 100%;
  box-sizing: border-box;
}
.pickup-search .find_store .m_line_list_title .title {
  display: none;
}
.pickup-search .find_store .m_line_list_title .search_bar {
  position: relative;
}
.pickup-search .find_store .m_line_list_title .search_bar input {
  font-size: 1.6rem;
  line-height: 1.92rem;
  font-weight: 500;
  color: var(--primary-color);
  max-width: none;
  width: 100%;
  padding: 0.5rem 0.4rem;
  border: none;
  border-bottom: 1px solid var(--primary-color);
  box-sizing: border-box;
  border-radius: 0;
  outline: none;
}
.pickup-search .find_store .m_line_list_title .search_bar input::placeholder {
  color: var(--gray-5-color);
}
.pickup-search .find_store .m_line_list_title .search_bar button {
  position: absolute;
  transform: translateY(-50%);
  top: 50%;
  right: 4px;
  width: 21px;
  height: 21px;
  background: url(../img/icon/search2.png) no-repeat;
  background-size: contain;
}
.pickup-search .store_info {
  background: #fff;
  padding: 10px 13px;
  border: 1px solid #333;
  min-width: 205px;
}
.pickup-search .store_info .info-title {
  display: block;
  background: #50627F;
  color: #fff;
  text-align: center;
  height: 24px;
  line-height: 22px;
  border-radius: 4px;
  padding: 0px 10px;
}
.pickup-search .store_info .store_addr {
  font-size: 13px;
  color: #111;
  font-weight: 500;
  word-break: keep-all;
  margin-top: 0.5rem;
}
.pickup-search .store_info .store_tel {
  font-size: 13px;
  line-height: 25px;
  word-break: keep-all;
}
.pickup-search .store_info .store_btn_area {
  text-align: center;
  padding: 0.5rem 0;
  margin: 1rem auto;
  border: 1px solid #666;
}
.pickup-search .store_info .store_btn_area button {
  padding: 0.5rem 0;
  width: 100%;
}

#bo_w .bo_w_flie .file_wr {
  background: #fff;
  border: 1px solid #CADEEE;
  border-radius: 0;
  height: inherit;
  padding: 0.8rem 0;
}
#bo_w .bo_w_flie .file_wr .frm_file {
  padding-left: 45px;
  margin-top: 0;
  font-size: 14px;
  color: #616161;
  background: none;
}
#bo_w .bo_w_flie .file_wr .frm_file::file-selector-button {
  background-color: var(--primary-color);
  color: #fff;
  border: 0;
  border-radius: 14px;
  font-size: 14px;
  font-weight: 500;
  padding: 0.4rem 1.5rem;
  margin-right: 0.8rem;
}
#bo_w .bo_w_flie .lb_icon {
  width: 41px;
  height: 41px;
  line-height: 41px;
  background: url(../img/icon/bx_folder.png) no-repeat;
  background-size: contain;
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
#bo_w .bo_w_flie .lb_icon i {
  display: none;
}
#bo_w .btn_confirm {
  display: flex;
  justify-content: center;
  gap: 12px;
  padding: 2rem 0;
  margin: 4rem 0 0;
}
#bo_w .btn_confirm .btn, #bo_w .btn_confirm .btn-primary, #bo_w .btn_confirm .btn-secondary, #bo_w .btn_confirm .btn-outline, #bo_w .btn_confirm .btn-ghost, #bo_w .btn_confirm .btn-danger, #bo_w .btn_confirm .btn-success, #bo_w .btn_confirm .btn-dark, #bo_w .btn_confirm .btn-white, #bo_w .btn_confirm .ds_btn, #bo_w .btn_confirm .cart-btn,
#bo_w .btn_confirm .buy-btn, #bo_w .btn_confirm .social-btn {
  font-size: 1.4em;
  line-height: 3.8rem;
  font-weight: 600;
  color: var(--primary-color);
  display: inline-block;
  border: 1px solid var(--primary-color);
  border-radius: 5px;
  padding: 0 2.3rem;
  box-sizing: border-box;
}
#bo_w .btn_confirm .btn.btn_submit, #bo_w .btn_confirm .btn_submit.btn-primary, #bo_w .btn_confirm .btn_submit.btn-secondary, #bo_w .btn_confirm .btn_submit.btn-outline, #bo_w .btn_confirm .btn_submit.btn-ghost, #bo_w .btn_confirm .btn_submit.btn-danger, #bo_w .btn_confirm .btn_submit.btn-success, #bo_w .btn_confirm .btn_submit.btn-dark, #bo_w .btn_confirm .btn_submit.btn-white, #bo_w .btn_confirm .btn_submit.ds_btn, #bo_w .btn_confirm .btn_submit.cart-btn,
#bo_w .btn_confirm .btn_submit.buy-btn, #bo_w .btn_confirm .btn_submit.social-btn {
  color: #fff;
  background-color: var(--primary-color);
}

.detail-table {
  border-collapse: collapse;
  width: 100%;
}
.detail-table tbody:last-child tr:first-child {
  margin-top: 1.2rem;
}
.detail-table tr {
  border-bottom: 1px solid var(--gray-2-color);
}
.detail-table tr:first-child {
  border-top: 1px solid var(--gray-2-color);
}
.detail-table .clear-tr {
  height: 12px;
  border-top: none;
}
.detail-table-cont {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--dark-1-color);
  padding: 1.6rem 1rem;
}
.detail-table-cont.total-price {
  font-weight: 700;
}
.detail-table-title {
  background-color: var(--gray-1-color);
  text-align: left;
  width: 77px;
  font-weight: 600;
}
.detail-table-title.total {
  background-color: #DCECF5;
  font-weight: 700;
}

#sod_fin_list {
  margin-top: 1.6rem;
}
#sod_fin_list table {
  width: 100%;
  border-collapse: collapse;
}
#sod_fin_list table thead {
  display: none;
}
#sod_fin_list table tr {
  display: flex;
  align-items: center;
  gap: 12px;
  border-top: 1px solid var(--gray-2-color);
  border-bottom: 1px solid var(--gray-2-color);
  padding: 1.2rem 0;
}
#sod_fin_list table .sod_img {
  width: 77px;
  line-height: 0;
}
#sod_fin_list table .sod_img img {
  width: 100%;
}
#sod_fin_list table .sod_name {
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--dark-1-color);
  display: block;
}
#sod_fin_list table .sod_opt {
  font-size: 1.2rem;
  color: var(--dark-2-color);
  display: flex;
  align-items: center;
  padding: 4px 0 8px;
}
#sod_fin_list table .sod_opt .option {
  color: #18181B;
  font-size: 1rem;
  padding: 2px 3px;
  background-color: #e2eaf6;
  border-radius: 2px;
  margin-right: 4px;
}
#sod_fin_list table .td_numbig {
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--gray-6-color);
  display: inline-block;
  padding-right: 17px;
  position: relative;
}
#sod_fin_list table .td_numbig::after {
  position: absolute;
  content: "";
  width: 1px;
  height: 12px;
  background-color: var(--gray-4-color);
  right: 7px;
  top: 50%;
  transform: translateY(-50%);
}
#sod_fin_list table .td_mngsmall {
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--gray-6-color);
  display: inline-block;
  padding-right: 17px;
}

.thumbnail_icon {
  position: absolute;
  left: 10px;
  top: 10px;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  z-index: 10;
}
.thumbnail_icon .icon_cont {
  display: block;
  text-align: center;
  line-height: 3rem;
  font-size: 1.4rem;
  font-weight: 600;
  color: #fff;
  width: 30px;
  height: 30px;
  background-color: #FF4C6D;
  border-radius: 5px;
}
.thumbnail_icon .icon_cont.thumb_icon_2 {
  font-size: 1rem;
}

.product_detail_wrap .detailArea .thumbnail_icon {
  left: 16px;
  top: 16px;
  gap: 0.8rem;
}
.product_detail_wrap .detailArea .thumbnail_icon .icon_cont {
  font-size: 1.8rem;
  height: 50px;
  width: 50px;
  line-height: 5rem;
}

.cart #sod_frm_pay h2 {
  margin-bottom: 1.6rem;
}
.cart #sod_frm_pay .pay_tbl {
  position: relative;
  margin-bottom: 1.2rem;
}
.cart #sod_frm_pay .pay_tbl table {
  width: 100%;
  border-collapse: collapse;
}
.cart #sod_frm_pay .pay_tbl tr:nth-of-type(1) {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.cart #sod_frm_pay .pay_tbl tr:nth-of-type(1) th {
  font-size: 1.4rem;
  color: var(--gray-5-color);
  font-weight: 400;
}
.cart #sod_frm_pay .pay_tbl tr:nth-of-type(1) td:nth-of-type(1) {
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--dark-2-color);
}
.cart #sod_frm_pay .pay_tbl tr:nth-of-type(1) td:nth-of-type(1) > #od_cp_price {
  margin-right: 0.3rem;
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--dark-2-color);
}
.cart #sod_frm_pay .pay_tbl tr:nth-of-type(1) td:nth-of-type(1) > .btn_frmline {
  font-size: 1.4rem;
  color: var(--dark-2-color);
  padding: 0.8rem 3.1rem;
  border: 1px solid var(--gray-2-color);
  line-height: normal;
  margin-left: 1.2rem;
}
.cart #sod_frm_pay .pay_tbl tr:nth-of-type(1) td:nth-of-type(1) > .btn_frmline.apply_on {
  padding: 0.8rem 1.2rem;
}
.cart #sod_frm_pay .pay_tbl tr:nth-of-type(1) td:nth-of-type(1) .cp_cancel {
  font-size: 1.4rem;
  color: var(--dark-2-color);
  padding: 0.8rem 1.2rem;
  border: 1px solid var(--gray-2-color);
  line-height: normal;
  margin-left: 0.4rem;
}
.cart #sod_frm_pay .od_coupon_wrap {
  position: fixed;
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.6);
  z-index: 1001;
}
.cart #sod_frm_pay #od_coupon_frm {
  z-index: 10000;
  position: relative;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 72%;
  max-width: 460px;
  height: auto !important;
  height: 500px;
  max-height: 500px;
  border: 1px solid #000;
  background: #fff;
  overflow-y: auto;
  border: 1px solid var(--gray-2-color);
  box-sizing: border-box;
}
.cart #sod_frm_pay #od_coupon_frm caption,
.cart #sod_frm_pay #od_coupon_frm thead {
  display: none;
}
.cart #sod_frm_pay #od_coupon_frm h3 {
  font-size: 1.2rem;
  font-weight: 500;
  letter-spacing: -0.48px;
  color: var(--dark-1-color);
  line-height: 4.2rem;
  text-align: center;
  border-bottom: 1px solid var(--gray-2-color);
}
.cart #sod_frm_pay #od_coupon_frm .tbl_wrap {
  padding: 0.8rem 1.2rem;
  box-sizing: border-box;
  width: 100%;
}
.cart #sod_frm_pay #od_coupon_frm tbody tr {
  display: flex;
  justify-content: space-between;
  gap: 1.2rem;
  align-items: center;
  padding: 1.2rem 0;
}
.cart #sod_frm_pay #od_coupon_frm tbody tr td {
  font-size: 1.4rem;
  letter-spacing: -0.56px;
  color: var(--dark-1-color);
  line-height: 1.68rem;
  font-weight: 400;
}
.cart #sod_frm_pay #od_coupon_frm tbody tr td:nth-of-type(1) {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  text-overflow: ellipsis;
  overflow: hidden;
  width: 73.5%;
}
.cart #sod_frm_pay #od_coupon_frm tbody .td_numbig {
  margin-left: 1.2rem;
  text-align: right;
}
.cart #sod_frm_pay #od_coupon_frm tbody .od_cp_apply {
  font-size: 1.2rem;
  font-weight: 400;
  letter-spacing: -0.48px;
  color: var(--dark-1-color);
  line-height: normal;
  padding: 0.4rem 0.8rem;
  background: var(--gray-2-color);
  word-break: keep-all;
}
.cart #sod_frm_pay #od_coupon_frm .btn_confirm {
  position: absolute;
  top: 5px;
  right: 5px;
}
.cart #sod_frm_pay #od_coupon_frm .btn_confirm i {
  display: none;
}
.cart #sod_frm_pay #od_coupon_frm .btn_confirm button {
  width: 32px;
  height: 32px;
  background: url("../img/icon/close2.png") no-repeat center center;
  background-size: cover;
}
.cart #sod_frm_pay #od_pay_sl {
  font-size: 1.4rem;
  color: var(--dark-2-color);
  text-align: right;
  border-bottom: 1px solid var(--gray-2-color);
  padding-bottom: 1.6rem;
}
.cart #sod_frm_pay #od_pay_sl label {
  font-size: 1.4rem;
  color: var(--gray-5-color);
  float: left;
  line-height: 3.4rem;
}
.cart #sod_frm_pay #od_pay_sl #od_temp_point {
  padding: 1rem;
  background-color: var(--gray-2-color);
  width: 51.5%;
  max-width: 180px;
  box-sizing: border-box;
  margin-right: 0.8rem;
  font-size: 1.2rem;
  color: var(--dark-2-color);
  outline: none;
  border-radius: 0;
}
.cart #sod_frm_pay #od_pay_sl #sod_frm_pt {
  margin-top: 0.8rem;
  font-size: 1.2rem;
  color: var(--gray-5-color);
  font-weight: 400;
}
.cart #sod_frm_pay #od_pay_sl #sod_frm_pt span {
  display: block;
}
.cart #sod_frm_pay #od_pay_sl #sod_frm_pt span strong {
  font-weight: 400;
  margin-right: 0.3rem;
}
.cart #sod_frm_pay #od_pay_sl #sod_frm_pt #use_max_point {
  font-style: normal;
}

.auth_inquiry #bo_btn_top {
  display: none;
  order: 2;
}
.auth_inquiry #bo_cate {
  background: none;
  padding: 0;
  margin: 0;
  border: none;
  order: 1;
}
.auth_inquiry #bo_cate h2 {
  display: none;
}
.auth_inquiry #bo_cate #bo_cate_ul {
  display: flex;
  align-items: center;
}
.auth_inquiry #bo_cate li {
  padding: 0;
  width: 50%;
}
.auth_inquiry #bo_cate li #bo_cate_on {
  background: none;
  box-shadow: none;
  color: var(--primary-color);
  border-bottom-color: var(--primary-color);
}
.auth_inquiry #bo_cate li a {
  font-size: 1.6rem;
  line-height: 1.92rem;
  text-align: center;
  color: #B7D0E2;
  font-weight: 500;
  padding: 1rem;
  border-bottom: 1px solid #B7D0E2;
  border-radius: 0;
}
.auth_inquiry #fqalist {
  order: 4;
  display: flex;
  flex-direction: column;
}
.auth_inquiry #fqalist .tbl_head01 {
  padding: 1.6rem 2rem 0;
  order: 2;
}
.auth_inquiry #fqalist .tbl_head01 .inquiry:last-child {
  margin-bottom: 0;
}
.auth_inquiry #fqalist .tbl_head01 .inquiry-head {
  position: relative;
  width: calc(100% - 38px);
}
.auth_inquiry #fqalist .tbl_head01 .inquiry-head li {
  font-size: 1.2rem;
  color: var(--dark-1-color);
  margin-bottom: 0.4rem;
}
.auth_inquiry #fqalist .tbl_head01 .inquiry-head li:nth-of-type(3) {
  margin-bottom: 0.8rem;
}
.auth_inquiry #fqalist .tbl_head01 .inquiry-head li:nth-of-type(4) {
  margin-bottom: 0;
}
.auth_inquiry #fqalist .tbl_head01 .inquiry-head .order-num {
  font-weight: 600;
  font-size: 1.4rem;
  margin-bottom: 0.8rem;
  padding-right: 5.3rem;
  text-decoration: underline;
}
.auth_inquiry #fqalist .tbl_head01 .inquiry-head .order-num a {
  line-height: 1.68rem;
  letter-spacing: -0.5px;
}
.auth_inquiry #fqalist .tbl_head01 .inquiry-head .order-num span {
  text-decoration: underline;
}
.auth_inquiry #fqalist .tbl_head01 .inquiry-head .return-btn {
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--blue-1-color);
  padding: 0.4rem 0.8rem;
  border: 1px solid var(--blue-1-color);
  border-radius: 13px;
  line-height: 1.44rem;
  position: absolute;
  right: 0;
  top: 0;
}
.auth_inquiry #fqalist .tbl_head01 .inquiry-status {
  border-top: 1px solid var(--gray-2-color);
  padding-top: 1.2rem;
}
.auth_inquiry #fqalist .tbl_head01 .inquiry-status p {
  font-size: 1.4rem;
  color: var(--primary-color);
  font-weight: 600;
}
.auth_inquiry #fqalist .tbl_head01 .inquiry-status.waiting-status p {
  color: #D32F2F;
}
.auth_inquiry #fqalist .bo_fx {
  order: 1;
  padding: 2.4rem 2rem 0.3rem;
  margin-bottom: 0;
  float: none;
  overflow: hidden;
}
.auth_inquiry #fqalist .bo_fx .td_all_chk {
  position: relative;
  padding-left: 26px;
  display: inline-block;
}
.auth_inquiry #fqalist .bo_fx .td_all_chk input {
  margin: 0;
  appearance: none;
  cursor: pointer;
}
.auth_inquiry #fqalist .bo_fx .td_all_chk input::after {
  box-sizing: border-box;
  border-radius: 50%;
  width: 18px;
  height: 18px;
  position: absolute;
  content: "";
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  background: url("../img/icon/select4.png") no-repeat;
  background-size: cover;
  border: 0;
}
.auth_inquiry #fqalist .bo_fx .td_all_chk input[type=checkbox]:checked::after {
  background: url("../img/icon/select.png") no-repeat;
  background-size: cover;
}
.auth_inquiry #fqalist .bo_fx .td_all_chk input[type=checkbox]:checked {
  border: 0;
}
.auth_inquiry #fqalist .bo_fx .td_all_chk label {
  font-size: 1.2rem;
  color: var(--dark-1-color);
  cursor: pointer;
}
.auth_inquiry #fqalist .bo_fx .btn_bo_user li {
  float: none;
  margin-left: 0;
}
.auth_inquiry #fqalist .bo_fx .btn_bo_user li:last-child {
  display: none;
}
.auth_inquiry #fqalist .bo_fx .btn_bo_user .btn_admin {
  font-size: 1.2rem;
  line-height: 1.44rem;
  font-weight: 400;
  color: var(--dark-1-color);
  text-decoration: underline;
}
.auth_inquiry #bo_sch {
  order: 3;
  float: none;
  border: none;
  background: none;
  border-radius: 0;
  padding: 0 2rem;
  margin-top: 2.4rem;
  position: relative;
}
.auth_inquiry #bo_sch .sch_input {
  outline: none;
  border-bottom: 1px solid var(--primary-color);
  width: 100%;
  height: auto;
  padding: 0.5rem 0.4rem;
  font-size: 1.6rem;
  font-weight: 500;
}
.auth_inquiry #bo_sch .sch_btn {
  width: 21px;
  height: 21px;
  background: url("../img/icon/search2.png") no-repeat;
  background-size: contain;
  float: none;
  position: absolute;
  right: 24px;
  top: 50%;
  transform: translateY(-50%);
}
.auth_inquiry #bo_sch .sch_btn i {
  display: none;
}

.auth_inquiry_add {
  padding: 2rem 2rem 4rem;
}

.auth_inquiry {
  /*inquiry-detail*/
}
.auth_inquiry #bo_v #bo_v_con {
  min-height: auto;
}
.auth_inquiry #bo_v #bo_v_title .bo_v_cate {
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--blue-1-color);
  padding: 0.4rem 0.8rem;
  border: 1px solid var(--blue-1-color);
  border-radius: 13px;
  line-height: 1.44rem;
  margin-right: 0.5rem !important;
  height: auto;
}
.auth_inquiry #bo_v #bo_v_title p {
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--primary-color);
  padding-top: 0.4rem;
}
.auth_inquiry #bo_v #bo_v_atc #sod_fin_no {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--primary-color);
  line-height: 1.68rem;
  padding: 1.2rem 0 1.6rem;
  text-align: right;
}
.auth_inquiry #bo_v #bo_v_atc #sod_fin_no a {
  color: var(--primary-color);
  text-decoration: none;
}
.auth_inquiry #bo_v #bo_v_atc #sod_fin_list h2 {
  display: none;
}
.auth_inquiry #bo_v #bo_v_top {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.auth_inquiry #bo_v #bo_v_top .bo_v_nb {
  float: none;
  display: flex;
  align-items: center;
  gap: 8px;
}
.auth_inquiry #bo_v #bo_v_top .bo_v_nb li {
  border: 0;
  float: none;
  margin-right: 0;
}
.auth_inquiry #bo_v #bo_v_top .btn_b01 {
  font-size: 1.4rem;
  font-weight: 500;
  background-color: var(--primary-color);
  padding: 0 3.6rem;
  border-radius: 5px;
  color: #fff;
  display: inline-block;
  line-height: 3.4rem;
}
.auth_inquiry #bo_v #bo_v_top .btn_b01 i {
  display: none;
}
.auth_inquiry #bo_v #bo_v_top .bo_v_com {
  float: none;
}
.auth_inquiry #bo_v #bo_v_top .bo_v_com li {
  float: none;
  margin-left: 0;
}
.auth_inquiry #bo_v #bo_v_top .bo_v_com .btn_b01 {
  text-indent: -99999px;
  width: 34px;
  height: 34px;
  display: inline-block;
  box-sizing: border-box;
  padding: 0;
  background: var(--primary-color) url("../img/icon/list.png") no-repeat;
  background-size: contain;
}
.auth_inquiry #bo_v #bo_v_ans h2 {
  padding: 0;
  background: none;
}
.auth_inquiry #bo_v #bo_v_ans h2 .bo_v_reply {
  background: none;
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--primary-color);
  display: block;
  height: auto;
  line-height: 1.68rem;
  padding: 0 0 1.6rem 0;
}
.auth_inquiry #bo_v #bo_v_ans h2 .bo_v_reply i {
  display: none;
}
.auth_inquiry #bo_v #bo_v_ans h2 .bo_v_reply_num {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--dark-1-color);
  background-color: var(--gray-2-color);
  display: block;
  border-radius: 0;
  padding: 1.6rem 1rem;
  line-height: 1.44rem;
  height: auto;
}
.auth_inquiry #bo_v #bo_v_ans .add_qa {
  font-size: 1.2rem;
  font-weight: 500;
  line-height: 1.44rem;
  color: #fff;
  padding: 0.4rem 0.8rem;
  border-radius: 3px;
  background-color: var(--primary-color);
  top: 20px;
  right: 20px;
}
.auth_inquiry #bo_v #bo_v_ans .add_qa i {
  display: none;
}
.auth_inquiry #bo_v #bo_v_ans #ans_datetime {
  background: none;
  padding: 0.8rem 1rem;
  font-style: inherit;
  font-size: 1.2rem;
  line-height: 1.8rem;
  color: var(--gray-6-color);
  border-top: 1px solid var(--gray-2-color);
}
.auth_inquiry #bo_v #bo_v_ans #ans_datetime i {
  display: none;
}
.auth_inquiry #bo_v #bo_v_ans #ans_con {
  margin: 0;
  padding: 1.2rem 1rem;
  font-size: 1.2rem;
  line-height: 1.44rem;
  color: var(--dark-1-color);
  border-top: 1px solid var(--gray-2-color);
}
.auth_inquiry #bo_v #bo_v_ans #ans_add {
  padding: 0;
  margin-top: 2.8rem;
}
.auth_inquiry #bo_v #bo_v_ans #ans_add .btn_b03 {
  font-size: 1.2rem;
  line-height: 1.44rem;
  text-decoration: underline;
  color: #929292;
}
.auth_inquiry #bo_v #bo_v_ans #ans_add .btn_b03:first-child {
  margin-right: 1.2rem;
}

.auth_inquiry_add #bo_w .form_01 ul {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.auth_inquiry_add #bo_w .form_01 ul li {
  flex-basis: 100%;
}
.auth_inquiry_add #bo_w .form_01 ul li:first-child {
  margin-bottom: 1.2rem;
}
.auth_inquiry_add #bo_w .form_01 ul li:nth-of-type(6) {
  display: none;
}
.auth_inquiry_add #bo_w #qa_category {
  border: none;
  border-bottom: 1px solid var(--primary-color);
  border-radius: 0;
  font-size: 1.6rem;
  font-weight: 500;
  color: var(--primary-color);
  height: 31px;
  width: 81px;
  appearance: none;
  -webkit-appearance: none;
  background: url("../img/icon/b-arrow2.png") no-repeat;
  background-size: 19px 19px;
  background-repeat: no-repeat;
  background-position: 98% center;
  padding: 0.6rem 0.4rem;
  box-sizing: border-box;
}
.auth_inquiry_add #bo_w .bo_w_hp {
  float: none;
  width: auto;
  flex-basis: calc(50% - 4px) !important;
}
.auth_inquiry_add #bo_w .bo_w_hp input {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #cadeee;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--dark-2-color);
  outline: none;
  padding: 0.9rem 1.6rem;
}
.auth_inquiry_add #bo_w .bo_w_hp input::placeholder {
  color: #cadeee;
}
.auth_inquiry_add #bo_w .bo_w_sbj input {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #cadeee;
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--dark-2-color);
  outline: none;
  padding: 0.9rem 1.6rem;
}
.auth_inquiry_add #bo_w .bo_w_sbj input::placeholder {
  color: #cadeee;
}
.auth_inquiry_add #bo_w .qa_content_wrap textarea {
  border: 1px solid #cadeee;
  outline: none;
  width: 100%;
  padding: 1.6rem;
  box-sizing: border-box;
  min-height: 250px;
  height: auto !important;
}
.auth_inquiry_add #bo_w .btn_confirm i {
  display: none;
}

.survey {
  position: relative;
}
.survey::after {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  background-color: #000;
  opacity: 0.2;
}
.survey video {
  overflow: hidden;
  position: absolute;
  top: 0;
  object-fit: cover;
  z-index: 0;
  max-width: 640px;
}
.survey video[poster] {
  width: 100%;
  height: 100% !important;
  object-fit: cover;
}
.survey {
  /*** survey-header ***/
}
.survey-header-inner {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 4rem 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}
.survey-header-inner .survey-header-title {
  font-size: 2.3rem;
  font-weight: 400;
  color: #fff;
}
.survey-header-inner .survey-header-txt {
  font-size: 1.6rem;
  letter-spacing: -0.1rem;
  color: var(--gray-4-color);
  margin-top: 2rem;
  transition-delay: 0.2s;
  line-height: 2.43rem;
}
.survey-header-inner .time {
  display: flex;
  font-size: 1.6rem;
  color: var(--gray-4-color);
  gap: 4px;
  align-items: center;
  justify-content: center;
  margin: 2rem 0;
  transition-delay: 0.3s;
}
.survey-header-inner .time img {
  width: 19px;
}
.survey-header-inner .start-btn {
  font-size: 1.6rem;
  letter-spacing: -0.1rem;
  color: var(--gray-4-color);
  padding: 1.2rem 6rem;
  border: 1px solid var(--gray-4-color);
  border-radius: 50px;
  line-height: 1.7rem;
  transition: 0.6s;
  transition-delay: 0.5s;
}
.survey-header-inner .start-btn:hover {
  color: var(--gray-6-color);
  background-color: #fff;
}
.survey-header-inner .start-btn:active {
  color: var(--gray-6-color);
  background-color: #fff;
}
.survey {
  /*** survey-contents ***/
}
.survey .survey-contents {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  display: none;
  position: relative;
}
.survey .survey-contents::after {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  right: 0;
  bottom: 0;
  background-color: #000;
  opacity: 0.2;
}
.survey .survey-contents {
  /*** pagination ***/
}
.survey .survey-contents .quiz-pagination {
  position: absolute;
  z-index: 1;
  width: 79.4871%;
  min-width: 345px;
  text-align: center;
  left: 50%;
  top: 14%;
  transform: translateX(-50%);
}
.survey .survey-contents .quiz-pagination .pagination {
  font-size: 4rem;
  color: #fff;
  margin-bottom: 2rem;
  display: inline-block;
}
.survey .survey-contents .quiz-pagination {
  /*** scroll-bar ***/
}
.survey .survey-contents .quiz-pagination .progress-line {
  transition: 0.6s ease-out;
  -webkit-transition: 0.6s ease-out;
  z-index: 999;
  margin: 0 1.75rem;
  height: 2px;
  background-color: rgba(255, 255, 255, 0.3019607843);
  display: block;
  position: relative;
  overflow: hidden;
}
.survey .survey-contents .quiz-pagination .progress-line .active {
  position: absolute;
  top: 0;
  left: 0;
  height: 2px;
  width: 0;
  z-index: 999;
  background-color: #fff;
  transition: 1s;
}
.survey .survey-contents-inner {
  width: 79.4871%;
  min-width: 345px;
  height: 270px;
  position: relative;
  overflow: hidden;
  margin-top: 0.5rem;
  padding-bottom: 0.2rem;
}
.survey .survey-contents-inner .survey-quiz {
  opacity: 0;
  position: absolute;
  width: 100%;
  top: -100%;
  z-index: 1;
  transition: 1s;
  padding-bottom: 0.2rem;
}
.survey .survey-contents-inner .survey-quiz-inner {
  padding-bottom: 0.2rem;
}
.survey .survey-contents-inner .survey-quiz-title {
  font-size: 2.3rem;
  text-align: center;
  color: #fff;
  font-weight: 400;
}
.survey .survey-contents-inner .survey-quiz-answer {
  padding: 4rem 1.75rem 0.2rem;
}
.survey .survey-contents-inner .survey-quiz-answer .answer {
  text-align: center;
}
.survey .survey-contents-inner .survey-quiz-answer .answer-btn {
  font-size: 1.6rem;
  letter-spacing: -0.1rem;
  font-weight: 400;
  color: #fff;
  line-height: 4.3rem;
  border: 1px solid var(--gray-4-color);
  margin-bottom: 1.2rem;
  width: 100%;
  box-sizing: border-box;
}
.survey .survey-contents-inner .survey-quiz-answer .answer-btn:hover {
  background-color: rgba(217, 217, 217, 0.3019607843);
}
.survey .survey-contents-inner .survey-quiz-answer .answer-btn:active {
  background-color: rgba(217, 217, 217, 0.3019607843);
}
.survey .survey-contents-inner .survey-quiz-answer .answer:last-child .answer-btn {
  margin-bottom: 0;
}
.survey .survey-contents-inner .survey-quiz.active {
  opacity: 1;
  top: 0;
}
.survey .survey-contents-inner .survey-quiz.next {
  opacity: 0;
  top: 100%;
}
.survey {
  /*** survey-result ***/
}
.survey-result {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.survey-result-inner {
  position: relative;
  z-index: 1;
  text-align: center;
  padding: 2.6rem 1.7rem 2rem;
}
.survey-result-inner.other-result {
  display: none;
}
.survey-result-inner .personal {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  border: 1px solid #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 1.6rem;
  box-sizing: border-box;
  word-break: keep-all;
  margin: 4rem auto;
}
.survey-result-inner .personal-cnt {
  font-size: 2.3rem;
  color: #fff;
}
.survey-result-inner .personal-result {
  font-size: 1.8rem;
  color: #fff;
  margin-top: 0.4rem;
}
.survey-result-inner .link-btn {
  display: inline-block;
  line-height: 1.92rem;
  font-size: 1.6rem;
  letter-spacing: -0.1rem;
  padding: 1.2rem 4.6rem;
  color: var(--gray-4-color);
  border: 1px solid var(--gray-4-color);
  border-radius: 50px;
  margin-top: 2rem;
  transition: 0.4s;
}
.survey-result-inner .link-btn:hover {
  background-color: #fff;
  border: 1px solid #fff;
  color: var(--gray-6-color);
}
.survey-result-inner .link-btn:active {
  background-color: #fff;
  border: 1px solid #fff;
  color: var(--gray-6-color);
}
.survey-result-title {
  font-size: 2.3rem;
  font-weight: 400;
  color: #fff;
}
.survey-result-txt {
  font-size: 1.6rem;
  letter-spacing: -0.1rem;
  line-height: 2.3rem;
  color: var(--gray-4-color);
  margin-top: 2rem;
}
.survey-result-txt .strong {
  font-weight: 700;
}

@media screen and (max-width: 380px) {
  .survey .survey-contents .quiz-pagination {
    top: 6%;
  }
}
.search-result {
  padding-bottom: 40px;
}
.search-result .founded {
  padding-bottom: 4rem;
}
.search-result .input-box {
  padding: 1.2rem 2rem 0;
  box-sizing: border-box;
  margin-bottom: 1.6rem;
}
.search-result .products_utils {
  padding: 1.3rem 2rem;
}
.search-result {
  /*** 검색결과 없을 경우 ***/
}
.search-result .none-page {
  padding: 0 2.564% 2.564%;
  text-align: center;
}
.search-result .none-page .txt {
  border-radius: 10px;
  font-size: 1.4rem;
  color: var(--gray-5-color);
  background-color: var(--gray-2-color);
  width: 100%;
  padding: 6.7rem 0;
}

.provisions {
  background-color: var(--gray-2-color);
}
.provisions .provision {
  padding: 2rem 2rem 4rem;
}
.provisions .provision-txt {
  font-size: 1.2rem;
  color: var(--gray-6-color);
}
.provisions .provision-table {
  border-collapse: collapse;
  width: 100%;
}
.provisions .provision-table tr:first-child td {
  border-top: 1px solid var(--gray-3-color);
}
.provisions .provision-table th {
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--gray-6-color);
  padding: 0.8rem 1.3rem;
  background-color: var(--gray-3-color);
  border-right: 1px solid var(--gray-3-color);
  word-break: keep-all;
}
.provisions .provision-table th:first-child {
  border-left: 1px solid var(--gray-3-color);
}
.provisions .provision-table td {
  font-size: 1rem;
  color: var(--gray-6-color);
  padding: 0.4rem 0.2rem;
  border-right: 1px solid var(--gray-3-color);
  border-bottom: 1px solid var(--gray-3-color);
  background-color: #fff;
  vertical-align: top;
}
.provisions .provision-table td:first-child {
  border-left: 1px solid var(--gray-3-color);
}

.lens-method .img-box img {
  width: 100%;
}

.trial .img-box img {
  width: 100%;
}

.manage {
  padding-bottom: 5.7rem;
}
.manage #smb_my_ov {
  background-color: #DCECF5;
  padding: 4rem 2rem;
}
.manage #smb_my_ov .smb_me {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4rem;
}
.manage #smb_my_ov .smb_me .my_ov {
  font-size: 2.1rem;
  font-weight: 400;
  line-height: 2.94rem;
  color: var(--primary-color);
}
.manage #smb_my_ov .smb_me .my_ov_name {
  font-weight: 700;
}
.manage #smb_my_ov .smb_me .smb_info {
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--blue-1-color);
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  align-items: center;
  line-height: inherit;
}
.manage #smb_my_ov .op_area {
  background-color: #fff;
  padding: 1.2rem 2rem;
  border-radius: 10px;
}
.manage #smb_my_ov .op_area dt {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--dark-2-color);
  margin: 1.6rem 0 0.8rem;
}
.manage #smb_my_ov .op_area dd {
  font-size: 1.4rem;
  color: var(--gray-6-color);
  padding-bottom: 1.6rem;
  border-bottom: 1px solid #DCECF5;
}
.manage #smb_my_ov .op_area dd:last-of-type {
  border-bottom: 0;
}
.manage #smb_my_od .smb_my_more a {
  font-size: 1.4rem;
  font-weight: 500;
  color: var(--gray-6-color);
  padding: 1.6rem 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.manage #smb_my_od .smb_my_more img {
  width: 17px;
}
.manage #smb_my .logout-btn {
  text-align: center;
  border-top: 20px solid #F5F5F5;
}
.manage #smb_my .logout-btn .logout {
  font-size: 1.1rem;
  line-height: 1.1879rem;
  letter-spacing: -0.44px;
  text-decoration: underline;
  color: #848484;
  display: inline-block;
  padding: 2rem 1rem;
}

/*** register ***/
.register {
  padding-bottom: 4rem;
}
.register #fregisterform {
  padding-bottom: 0;
}
.register #fregisterform div {
  margin: 0;
}
.register .register_form_inner {
  background: none;
  border: 0;
  border-radius: 0;
}
.register .register_form_inner:last-child ul {
  padding: 4rem 2rem 0;
}
.register .register_form_inner h2 {
  padding: 12px 20px !important;
  background-color: #DCECF5;
  font-size: 1.3rem;
  line-height: 1.8rem;
  color: var(--primary-color);
  font-weight: 400;
  border-bottom: 0 !important;
}
.register .register_form_inner ul {
  padding: 4rem 2rem;
}
.register .register_form_inner li {
  margin-bottom: 3.6rem;
}
.register .register_form_inner li:last-child {
  margin-bottom: 0;
}
.register .register_form_inner .form_50 {
  width: 100%;
  margin-right: 0;
}
.register .register_form_inner label {
  font-size: 1.4rem;
  color: var(--dark-2-color);
  font-weight: 600;
  position: relative;
  line-height: 1.68rem;
  margin-bottom: 0.4rem;
  display: block;
}
.register .register_form_inner .frm_input {
  font-size: 1.4rem;
  color: var(--dark-2-color);
  border-bottom: 1px solid var(--gray-3-color);
  padding: 0.8rem 1.2rem;
  width: 100%;
  box-sizing: border-box;
  outline: none;
  font-weight: 400;
}
.register .register_form_inner .frm_input::placeholder {
  color: #c7c7c7;
  font-weight: 400;
}
.register .register_form_inner #mb_3 {
  width: calc(100% - 83px) !important;
  float: left;
  margin-bottom: 0.6rem;
}
.register .register_form_inner .tooltip_icon {
  display: none;
}
.register .register_form_inner .tooltip {
  font-size: 1.1rem;
  color: var(--gray-5-color);
  margin-top: 0.4rem;
  display: block;
}
.register .register_form_inner .ser_bbt {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--primary-color);
  line-height: 1.68rem;
  padding: 0.65rem 1.2rem;
  border: 1px solid var(--primary-color);
  border-radius: 5px;
  box-sizing: border-box;
  margin-left: 0.5rem;
  margin-top: 0.1rem;
  float: right;
}
.register .register_form_inner #map {
  height: 219px;
  width: 100%;
}
.register .register_form_inner .checked_frm label:first-child {
  margin-bottom: 1.2rem;
}
.register .register_form_inner .checked_frm .checked_label {
  display: inline-flex;
  align-items: center;
  padding: 0.4rem 0;
  gap: 0.4rem;
  margin-right: 2rem;
  margin-bottom: 0;
  cursor: pointer;
}
.register .register_form_inner .checked_frm .checked_label input[type=radio] {
  margin: 0.2rem 0.2rem 0;
  appearance: none;
  -webkit-appearance: none;
  width: 15px;
  height: 15px;
  border: 1px solid var(--gray-5-color);
  border-radius: 50%;
  box-sizing: border-box;
}
.register .register_form_inner .checked_frm .checked_label input[type=radio]:checked {
  border: none;
  background: url("../img/icon/select.png") no-repeat center center;
  background-size: cover;
}
.register .register_form_inner .note {
  font-size: 1.2rem;
  color: var(--gray-5-color);
  font-weight: 500;
  display: inline-block;
  margin-left: 0.4rem;
  line-height: 1.68rem;
  vertical-align: text-top;
}
.register .register_form_inner .card_expire .expire_date {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0;
  margin-right: 1.6rem;
  width: 35%;
}
.register .btn_confirm {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  padding: 2rem;
}
.register .btn_confirm .btn_close {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--primary-color);
  line-height: 1.68rem;
  border: 1px solid var(--primary-color);
  border-radius: 5px;
  width: auto;
  height: auto !important;
  padding: 1.15rem 2.3rem;
  float: none;
}
.register .btn_confirm .btn_submit {
  margin-left: 0;
  background-color: var(--primary-color);
  color: #fff;
}

.manage-reserve-detail {
  padding: 0 2rem 4rem;
}
.manage-reserve-detail .sub_contents_wrapper {
  padding: 0;
}
.manage-reserve-detail #sod_fin_list, .manage-reserve-detail #sod_fin_orderer, .manage-reserve-detail #sod_fin_pay {
  border-radius: 10px;
  background-color: #fff;
  padding: 1rem 2rem 2rem;
  margin-bottom: 2rem;
  margin-top: 0;
}
.manage-reserve-detail #sod_fin_list h2, .manage-reserve-detail #sod_fin_list h3, .manage-reserve-detail #sod_fin_orderer h2, .manage-reserve-detail #sod_fin_orderer h3, .manage-reserve-detail #sod_fin_pay h2, .manage-reserve-detail #sod_fin_pay h3 {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--primary-color);
  padding: 1.2rem 0 1.6rem;
}
.manage-reserve-detail #sod_fin_list tr:last-child, .manage-reserve-detail #sod_fin_orderer tr:last-child, .manage-reserve-detail #sod_fin_pay tr:last-child {
  border-bottom: 0;
}
.manage-reserve-detail .detail-table th, .manage-reserve-detail .detail-table li span {
  background-color: var(--gray-1-color);
  text-align: left;
  width: 77px;
  font-weight: 600;
  padding: 1.6rem 1rem 1.5rem;
  font-size: 1.2rem;
}
.manage-reserve-detail .detail-table td, .manage-reserve-detail .detail-table li strong {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--dark-1-color);
  padding: 1.6rem 1rem;
}
.manage-reserve-detail .detail-table .clear-tr {
  height: 12px;
  border-top: none;
}
.manage-reserve-detail .detail-table li {
  border-top: 1px solid var(--gray-2-color);
}
.manage-reserve-detail .detail-table li span {
  display: inline-block;
}
.manage-reserve-detail .detail-table li strong {
  font-weight: 500;
}
.manage-reserve-detail .detail-table .sod_fin_tot:first-child span {
  background-color: #DCECF5;
  vertical-align: middle;
  padding: 0.9rem 1rem 0.8rem;
}
.manage-reserve-detail .detail-table .sod_fin_tot:first-child strong {
  font-weight: 700;
  vertical-align: middle;
}
.manage-reserve-detail #sod_fin_orderer.fin_v02 {
  padding: 1rem;
}
.manage-reserve-detail #sod_fin_orderer.fin_v02 h3 {
  padding: 1.2rem 1rem 1.6rem;
}
.manage-reserve-detail #sod_fin_orderer .pick_med {
  margin: 0 !important;
}
.manage-reserve-detail #sod_fin_orderer .pick_med .detail {
  padding: 0 2rem !important;
}
.manage-reserve-detail #sod_fin_orderer .pick_med #shop_name {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--primary-color);
  padding: 0.8rem 0 1rem;
}
.manage-reserve-detail #sod_fin_orderer .pick_med .con h5 {
  font-size: 1.2rem !important;
  font-weight: 500;
  color: var(--dark-1-color);
  position: relative;
  padding: 0.6rem 7.7rem;
  margin: 0;
}
.manage-reserve-detail #sod_fin_orderer .pick_med .con h5 strong {
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  font-weight: 600;
}
.manage-reserve-detail #sod_fin_orderer .pick_med #pick_map {
  height: 320px;
  margin: 3.6rem 0 0 !important;
}
.manage-reserve-detail #sod_fin_cancel {
  margin-top: 4rem;
}
.manage-reserve-detail #sod_fin_cancel p {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--blue-1-color);
  text-align: center;
  margin-bottom: 1.6rem;
}
.manage-reserve-detail #sod_fin_cancel .sod_fin_c_btn {
  font-size: 1.4rem;
  font-weight: 600;
  color: #fff !important;
  line-height: normal;
  width: 100%;
  text-align: center;
  padding: 0.9rem 0 0.8rem;
  background-color: var(--primary-color);
  border-radius: 10px;
  border: 0 !important;
  margin-bottom: 0 !important;
}
.manage-reserve-detail #sod_fin_cancel .sod_fin_c_btn span {
  font-size: 1.2rem !important;
  display: block;
  font-weight: 500;
  color: #90AEC4;
  margin-top: 0.2rem;
}
.manage-reserve-detail #sod_fin_cancel .cancle_confirm {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--gray-5-color);
  background-color: var(--gray-4-color);
  padding: 1.65rem 0;
  border-radius: 10px;
  margin-top: 0;
}

/*# sourceMappingURL=style.css.map */
