/* Floating Ads Style (Responsive Height) */

.floating-ad {
    position: fixed;
    top: 150px; /* 헤더 높이만큼 띄움 (필요시 조절) */
    width: 140px; /* 배너 가로폭 고정 */
    z-index: 990;

    /* 💡 [핵심] Flexbox를 사용하여 높이 분배 */
    display: flex;
    flex-direction: column;
    gap: 20px; /* 배너 사이 간격 */

    /* 💡 [핵심] 화면 높이의 80%를 넘지 않도록 제한 */
    max-height: calc(100vh - 200px);
}

.floating-ad.left {
    left: 20px; /* 왼쪽 여백 */
}

.floating-ad.right {
    right: 20px; /* 오른쪽 여백 */
}

/* 모든 링크 공통 스타일 */
.floating-ad a {
    display: block;
    overflow: hidden;
    transition: transform 0.2s;
}

/* 💡 [수정] 이미지가 들어가는 배너 링크에만 높이 450px 고정 */
.floating-ad a:not(.floating-contact-btn) {
    width: 140px; /* 배너 가로폭 고정 */
    height: 450px; /* 높이 고정 */
    /* 💡 [추가] contain 사용 시 남는 공간 배경색 */
    background-color: #f0f0f0; /* 밝은 회색, 필요시 수정 */
}

.floating-ad a:hover {
    transform: scale(1.05); /* 호버 시 살짝 커짐 */
}

/* 💡 [추가] 플로팅 버튼 스타일 */
.floating-contact-btn {
    display: block;
    margin-top: 15px;
    background-color: #009fe3;
    color: #fff;
    text-align: center;
    padding: 12px 0;
    border-radius: 8px;
    text-decoration: none;
    font-weight: bold;
    transition: background-color 0.3s;
    /* 버튼은 높이 자동 조절 (padding에 따름) */
    height: auto;
}

.floating-contact-btn:hover {
    background-color: #007bb5;
}

.floating-ad img {
    width: 100% !important;
    height: 100% !important;
    /* 💡 [수정] 이미지 전체가 보이도록 리사이징 (비율 유지) */
    object-fit: fill !important;
    display: block;
}

/* 모바일 반응형 스타일 */
@media (max-width: 1024px) {
    /* 왼쪽 플로팅 영역 전체 숨김 */
    .floating-ad.left {
        display: none !important;
    }

    /* 오른쪽 플로팅 영역 스타일 재정의 */
    .floating-ad.right {
        top: auto;
        bottom: 20px;
        right: 15px;
        width: auto;
        max-height: none;
        gap: 0;
        z-index: 999;
    }

    /* 오른쪽 영역 내의 일반 배너(이미지) 숨김 */
    .floating-ad.right > a:not(.floating-contact-btn) {
        display: none !important;
    }

    /* 문의하기 버튼 스타일 (모바일용 원형 버튼) */
    .floating-contact-btn {
        margin-top: 0;
        padding: 0;
        width: 50px;
        height: 50px;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        box-shadow: 0 4px 10px rgba(0,0,0,0.3);
    }

    .floating-contact-btn .text {
        display: none; /* 텍스트 숨김 */
    }

    .floating-contact-btn .icon {
        font-size: 24px;
        margin: 0;
    }
}
