/**
 * 하룹팝업 공통 스타일
 * 
 * 미리보기와 실제 팝업에서 동일하게 사용되는 스타일
 * 이 파일은 admin과 frontend 모두에서 로드됩니다
 * @version 2.2.0
 */

/* ===================================
   팝업 기본 구조 - 미리보기/실제 공통
   =================================== */

/* 슬라이드형 팝업 정확한 스타일 */
.haroop-popup-slide,
.haroop-preview-popup.haroop-popup-slide {
    padding: var(--popup-padding, 32px) !important;
    background: var(--popup-bg, #ffffff) !important;
    border-radius: var(--popup-radius, 20px) !important;
    border: var(--popup-border-width, 0px) solid var(--popup-border-color, transparent) !important;
    box-shadow: var(--popup-box-shadow, 0 0 0 1px rgba(0,0,0,0.04), 0 2px 8px rgba(0,0,0,0.04), 0 12px 24px rgba(0,0,0,0.08)) !important;
    overflow: hidden !important;
}

/* 슬라이드 컨트롤 (탭) - 보더 완전 제거 */
.haroop-popup-slide .haroop-slide-controls,
.haroop-preview-popup.haroop-popup-slide .haroop-slide-controls {
    display: flex !important;
    gap: var(--popup-tab-gap, 8px) !important;
    margin: 0 0 var(--popup-tab-margin, 24px) 0 !important;
    padding: 4px !important;
    background: var(--popup-tab-controls-bg, #f5f5f7) !important;
    border-radius: var(--popup-tab-radius, 12px) !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

/* 슬라이드 버튼 */
.haroop-popup-slide .haroop-slide-button,
.haroop-preview-popup.haroop-popup-slide .haroop-slide-button {
    flex: 1 !important;
    padding: 10px 16px !important;
    background: var(--popup-tab-bg, transparent) !important;
    color: var(--popup-tab-text, #86868b) !important;
    border: none !important;
    cursor: pointer !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    border-radius: 8px !important;
    font-size: var(--popup-tab-font-size, 14px) !important;
    font-weight: var(--popup-tab-font-weight, 500) !important;
    line-height: var(--popup-line-height, 1.4) !important;
    letter-spacing: var(--popup-letter-spacing, -0.01em) !important;
    text-transform: var(--popup-text-transform, none) !important;
    outline: none !important;
    position: relative !important;
    white-space: nowrap !important;
}

.haroop-popup-slide .haroop-slide-button:hover,
.haroop-preview-popup.haroop-popup-slide .haroop-slide-button:hover {
    background: var(--popup-tab-bg-hover, rgba(0,0,0,0.04)) !important;
    color: var(--popup-tab-text-hover, #1d1d1f) !important;
}

.haroop-popup-slide .haroop-slide-button.active,
.haroop-preview-popup.haroop-popup-slide .haroop-slide-button.active {
    background: var(--popup-tab-bg-active, #ffffff) !important;
    color: var(--popup-tab-text-active, #1d1d1f) !important;
    font-weight: var(--popup-tab-font-weight-active, 600) !important;
    box-shadow: var(--popup-tab-active-shadow, 0 0 0 0.5px rgba(0,0,0,0.04), 0 1px 3px rgba(0,0,0,0.04), 0 2px 8px rgba(0,0,0,0.04)) !important;
}

/* 슬라이드 컨테이너 - 보더 완전 제거 */
.haroop-popup-slide .haroop-slide-container,
.haroop-preview-popup.haroop-popup-slide .haroop-slide-container {
    position: relative !important;
    margin: 0 !important;
    border-radius: var(--popup-slide-radius, 16px) !important;
    overflow: hidden !important;
    background: var(--popup-slide-bg, #fafafa) !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

/* 슬라이드 아이템 */
.haroop-popup-slide .haroop-slide,
.haroop-preview-popup.haroop-popup-slide .haroop-slide {
    display: none;
}

.haroop-popup-slide .haroop-slide.active,
.haroop-preview-popup.haroop-popup-slide .haroop-slide.active {
    display: block;
}

/* 슬라이드 이미지 */
.haroop-popup-slide .haroop-slide img,
.haroop-preview-popup.haroop-popup-slide .haroop-slide img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
}

/* 슬라이드 푸터 (버튼 영역) */
.haroop-popup-slide .haroop-popup-footer,
.haroop-preview-popup.haroop-popup-slide .haroop-popup-footer {
    display: flex !important;
    gap: 0 !important;
    justify-content: center !important;
    align-items: stretch !important;
    padding: 0 !important;
    margin-top: var(--popup-footer-margin, 0) !important;
    background: transparent !important;
    flex-wrap: nowrap !important;
    overflow: hidden !important;
    border-radius: var(--popup-button-radius, 12px) !important;
}

/* ===================================
   일반형 팝업 정확한 스타일
   =================================== */
.haroop-popup-general,
.haroop-preview-popup.haroop-popup-general {
    padding: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    border: none !important;
}

/* 일반형 컨테이너 */
.haroop-popup-general .haroop-general-container,
.haroop-preview-popup.haroop-popup-general .haroop-general-container {
    display: flex !important;
    gap: var(--popup-gap, 20px) !important;
    width: 100% !important;
    align-items: stretch !important;
}

/* 일반형 아이템 */
.haroop-popup-general .haroop-general-item,
.haroop-preview-popup.haroop-popup-general .haroop-general-item {
    flex: 1 !important;
    background: var(--popup-bg, #ffffff) !important;
    border-radius: var(--popup-radius, 20px) !important;
    border: var(--popup-border-width, 0px) solid var(--popup-border-color, transparent) !important;
    overflow: hidden !important;
    box-shadow: var(--popup-box-shadow, 0 0 0 1px rgba(0,0,0,0.04), 0 2px 8px rgba(0,0,0,0.04), 0 12px 24px rgba(0,0,0,0.08)) !important;
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
}

/* 일반형 이미지 */
.haroop-popup-general .haroop-general-item img,
.haroop-preview-popup.haroop-popup-general .haroop-general-item img {
    width: 100% !important;
    height: auto !important;
    display: block !important;
    flex-shrink: 0 !important;
}

/* 일반형 개별 버튼 - 이미지 아래 위치 */
.haroop-popup-general .haroop-general-item .haroop-popup-footer,
.haroop-preview-popup.haroop-popup-general .haroop-general-item .haroop-popup-footer,
.haroop-preview-popup .haroop-general-item .haroop-popup-footer {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    background: transparent !important;
    padding: 0 !important;
    display: flex !important;
    gap: 0 !important;
    justify-content: center !important;
    align-items: stretch !important;
    flex-wrap: nowrap !important;
    overflow: hidden !important;
    border-radius: 0 0 var(--popup-radius, 20px) var(--popup-radius, 20px) !important;
}

/* 일반형 전체 닫기 버튼 영역 */
.haroop-popup-general .haroop-global-close-wrap,
.haroop-preview-popup.haroop-popup-general .haroop-global-close-wrap {
    text-align: center !important;
    margin-top: 24px !important;
    padding: 0 !important;
    background: transparent !important;
}

/* ===================================
   공통 버튼 스타일
   =================================== */
.haroop-popup-footer button,
.haroop-popup-footer a,
.haroop-preview-popup .haroop-popup-footer button,
.haroop-preview-popup .haroop-popup-footer a {
    padding: 12px 20px !important;
    background: var(--popup-button-bg, #1d1d1f) !important;
    color: var(--popup-button-text, #ffffff) !important;
    border: none !important;
    border-radius: 0 !important;
    cursor: pointer !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: var(--popup-button-font-size, 14px) !important;
    font-weight: var(--popup-button-font-weight, 500) !important;
    letter-spacing: var(--popup-letter-spacing, -0.01em) !important;
    line-height: var(--popup-line-height, 1.2) !important;
    transition: all 0.2s ease !important;
    text-align: center !important;
    outline: none !important;
    position: relative !important;
    white-space: nowrap !important;
    min-width: auto !important;
    flex: 1 !important;
    border-right: 1px solid rgba(255,255,255,0.1) !important;
}

/* 마지막 버튼 테두리 제거 */
.haroop-popup-footer button:last-child,
.haroop-popup-footer a:last-child,
.haroop-preview-popup .haroop-popup-footer button:last-child,
.haroop-preview-popup .haroop-popup-footer a:last-child {
    border-right: none !important;
}

.haroop-popup-footer button:hover,
.haroop-popup-footer a:hover,
.haroop-preview-popup .haroop-popup-footer button:hover,
.haroop-preview-popup .haroop-popup-footer a:hover {
    background: var(--popup-button-hover, #000000) !important;
    color: var(--popup-button-text-hover, #ffffff) !important;
    transform: scale(1.02) !important;
}

/* 일반형 개별 버튼 특별 스타일 - 미리보기 포함 */
.haroop-general-item .haroop-popup-footer button,
.haroop-general-item .haroop-popup-footer a,
.haroop-preview-popup .haroop-general-item .haroop-popup-footer button,
.haroop-preview-popup .haroop-general-item .haroop-popup-footer a {
    padding: 10px 16px !important;
    font-size: 13px !important;
    min-width: auto !important;
    flex: 1 !important;
    border-radius: 0 !important;
    border-right: 1px solid rgba(255,255,255,0.1) !important;
}

/* 마지막 버튼 테두리 제거 */
.haroop-general-item .haroop-popup-footer button:last-child,
.haroop-general-item .haroop-popup-footer a:last-child,
.haroop-preview-popup .haroop-general-item .haroop-popup-footer button:last-child,
.haroop-preview-popup .haroop-general-item .haroop-popup-footer a:last-child {
    border-right: none !important;
}

/* 전체 닫기 버튼 */
.haroop-global-close-bottom {
    background: #f5f5f7 !important;
    color: #1d1d1f !important;
    border: none !important;
    padding: 12px 32px !important;
    border-radius: 980px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
    outline: none !important;
    letter-spacing: -0.01em !important;
}

.haroop-global-close-bottom:hover {
    background: #e8e8ed !important;
    transform: scale(1.02) !important;
}

/* ===================================
   모바일 스타일 (미리보기/실제 공통)
   =================================== */
@media (max-width: 992px) {
    /* 일반형 모바일 - 겹침 처리 */
    .haroop-popup-general.haroop-mobile-overlapping .haroop-general-container,
    .haroop-preview-popup.haroop-popup-general.haroop-mobile-overlapping .haroop-general-container {
        display: block !important;
        gap: 0 !important;
    }
    
    .haroop-popup-general.haroop-mobile-overlapping .haroop-general-item,
    .haroop-preview-popup.haroop-popup-general.haroop-mobile-overlapping .haroop-general-item {
        position: relative !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
    }
    
    /* 슬라이드형 모바일 조정 */
    .haroop-popup-slide,
    .haroop-preview-popup.haroop-popup-slide {
        padding: var(--popup-padding-mobile, 24px) !important;
    }
    
    .haroop-popup-slide .haroop-slide-button,
    .haroop-preview-popup.haroop-popup-slide .haroop-slide-button {
        font-size: var(--popup-tab-font-size-mobile, 13px) !important;
        padding: 8px 12px !important;
    }
}

/* 미리보기 모바일 뷰어 스타일 */
.haroop-preview-viewport.mobile-view {
    max-width: 375px !important;
    margin: 0 auto !important;
    position: relative !important;
    min-height: 600px !important;
    background: transparent !important;
    border-radius: 0 !important;
    padding: 40px 20px !important;
    box-shadow: none !important;
}

/* 모바일 뷰포트 내부 장치 프레임 제거 */
.haroop-preview-viewport.mobile-view::before {
    display: none !important;
}

/* 모바일 일반형 래퍼 */
.haroop-mobile-general-wrapper {
    position: relative !important;
    width: 100% !important;
    min-height: 400px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* 모바일 일반형 개별 팝업 - 중앙 정렬 */
.haroop-mobile-general-wrapper .haroop-popup-general {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 90% !important;
    max-width: 320px !important;
    margin: 0 !important;
}

.haroop-mobile-general-wrapper .haroop-popup-general .haroop-general-container {
    display: block !important;
    gap: 0 !important;
}

.haroop-mobile-general-wrapper .haroop-popup-general .haroop-general-item {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    background: var(--popup-bg, #ffffff) !important;
    border-radius: var(--popup-radius, 20px) !important;
    overflow: hidden !important;
    box-shadow: 0 10px 40px rgba(0,0,0,0.2) !important;
}

/* ===================================
   미리보기 전용 조정
   =================================== */
.haroop-preview-popup {
    position: relative !important;
    transform: none !important;
    top: auto !important;
    left: auto !important;
    margin: 0 auto !important;
}

/* 미리보기 모바일 크기 */
.haroop-mobile-preview {
    max-width: 375px !important;
}

/* ===================================
   CSS 변수 기본값 (공통)
   =================================== */
.haroop-popup,
.haroop-preview-popup {
    /* 레이아웃 */
    --popup-padding: 32px;
    --popup-gap: 20px;
    --popup-radius: 20px;
    --popup-border-width: 0px;
    --popup-border-color: transparent;
    
    /* 배경 */
    --popup-bg: #ffffff;
    
    /* 텍스트 */
    --popup-text: #1d1d1f;
    --popup-text-hover: #000000;
    --popup-font-size: 14px;
    --popup-font-weight: 500;
    --popup-line-height: 1.4;
    --popup-letter-spacing: -0.01em;
    --popup-text-transform: none;
    
    /* 버튼 */
    --popup-button-bg: #1d1d1f;
    --popup-button-text: #ffffff;
    --popup-button-hover: #000000;
    --popup-button-text-hover: #ffffff;
    --popup-button-radius: 980px;
    --popup-button-font-size: 14px;
    --popup-button-font-weight: 500;
    
    /* 탭 */
    --popup-tab-gap: 8px;
    --popup-tab-margin: 24px;
    --popup-tab-radius: 8px;
    --popup-tab-bg: transparent;
    --popup-tab-bg-hover: rgba(0,0,0,0.04);
    --popup-tab-bg-active: #ffffff;
    --popup-tab-text: #86868b;
    --popup-tab-text-hover: #1d1d1f;
    --popup-tab-text-active: #1d1d1f;
    --popup-tab-font-size: 14px;
    --popup-tab-font-weight: 500;
    --popup-tab-font-weight-active: 600;
    
    /* 푸터 */
    --popup-footer-margin: 28px;
    
    /* 그림자 */
    --popup-box-shadow-offset: 0px;
    --popup-box-shadow-blur: 24px;
    --popup-box-shadow-color: rgba(0, 0, 0, 0.08);
}