﻿/* ───────────────────────── Animations (파일 맨 아래나 Quick Links 밑에 추가) ───────────────────────── */
@keyframes shineFlash {
    0% { left: -150%; }
    100% { left: 200%; } /* 왼쪽 끝에서 오른쪽 끝으로 휙 지나감 */
}

@keyframes iconBounce {
    0% { transform: scale(1); }
    50% { transform: scale(1.15); } /* 순간적으로 아이콘이 커짐 */
    100% { transform: scale(1); }
}

/* ───────────────────────── Hero Slider ───────────────────────── */
.cms-hero-section { 
    position: relative; 
    width: 100%; 
    height: auto; /* 고정 높이 해제 */
    background: #111; 
    overflow: hidden; /* 영역 밖으로 삐져나가는 것 방지 */
}

.hero-swiper { 
    width: 100%; 
    height: auto; /* 내부 콘텐츠에 맞춤 */
}

/* absolute에서 relative로 변경하여 컨테이너가 높이를 가질 수 있도록 설정 */
.slide-content-wrap { 
    position: relative; 
    width: 100%; 
    height: auto; 
}

/* 관리자에서 p 태그로 감싸져서 올 경우를 대비해 p 태그도 공간 제약 해제 */
.slide-content-wrap p { 
    margin: 0; 
    padding: 0; 
    width: 100%; 
    height: auto; 
}

/* 비율에 따른 자동 높이 및 전체 이미지 표시 */
.slide-content-wrap img, 
.slide-content-wrap video, 
.slide-content-wrap iframe { 
    width: 100%; 
    height: auto; 
    display: block; 
    object-fit: contain; 
}

.slide-content-wrap a { 
    display: block; 
    width: 100%; 
    height: auto; 
}

.cms-hero-arrow { 
    position: absolute; 
    top: 50%; 
    transform: translateY(-50%); 
    z-index: 10; 
    color: rgba(255,255,255,0.4); 
    transition: 0.2s; 
    width: 3rem; 
    height: 3rem; 
}
.cms-hero-arrow:hover { color: #fff; }
.cms-hero-arrow-prev { left: 1.5rem; }
.cms-hero-arrow-next { right: 1.5rem; }

.cms-hero-dots { 
    position: absolute; 
    bottom: 2rem; 
    left: 50%; 
    transform: translateX(-50%); 
    z-index: 10; 
    display: flex; 
    gap: 0.5rem; 
}
.swiper-pagination-bullet { 
    width: 0.6rem; 
    height: 0.2rem; 
    border-radius: 0; 
    background: rgba(255,255,255,0.3) !important; 
    transition: 0.3s; 
    opacity: 1 !important; 
}
.swiper-pagination-bullet-active { 
    background: #fff !important; 
    width: 1.8rem; 
}

/* ───────────────────────── Quick Links ───────────────────────── */
.cms-quick-links-section { padding: 1.5rem 0; background: #e8efe8; }
.cms-welcome-label { text-align: center; font-size: 1.875rem; font-weight: 800; letter-spacing: 0.2rem; font-family: var(--font-section-title); color: #1f2937; }
.cms-quick-links-grid { display: flex; justify-content: center; flex-wrap: wrap; gap:2rem; }
.cms-quick-link { display: flex; flex-direction: column; align-items: center; gap: 0.5rem; padding: 1.5rem 2rem; }
.cms-quick-link-icon-wrap { 
    width: 6rem; 
    height: 6rem; 
    background: rgba(255,255,255,0.7); 
    border-radius: 50%; 
    display: flex; 
    align-items: center; 
    justify-content: center; 
    transition: all 0.4s cubic-bezier(0.25, 0.8, 0.25, 1); /* 더 부드러운 애니메이션 커브 */
    color: #1f2937; 
    position: relative; /* 플래시 효과를 위한 기준점 */
    overflow: hidden; /* 동그라미 밖으로 빛이 나가지 않게 설정 */
    box-shadow: 0 4px 6px rgba(0,0,0,0.05); /* 기본 상태의 은은한 그림자 */
}
.cms-quick-link:hover .cms-quick-link-icon-wrap { 
    background: #fff; 
    color: var(--accent-green); 
    transform: translateY(-8px) scale(1.05); /* 위로 떠오르고 살짝 커짐 */
    box-shadow: 0 12px 24px rgba(0,0,0,0.15); /* 떠오르면서 깊어지는 그림자 */
}

/* 3. 호버 시 내부 아이콘 바운스 애니메이션 */
.cms-quick-link:hover .cms-quick-link-icon {
    animation: iconBounce 0.5s ease-in-out;
}

/* 4. 플래시(빛 띠) 효과를 위한 가상 요소 생성 */
.cms-quick-link-icon-wrap::after {
    content: '';
    position: absolute;
    top: 0;
    left: -150%;
    width: 50%;
    height: 100%;
    background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,0.9) 50%, rgba(255,255,255,0) 100%);
    transform: skewX(-25deg); /* 사선으로 기울임 */
}

/* 5. 호버 시 빛이 지나가는 애니메이션 트리거 */
.cms-quick-link:hover .cms-quick-link-icon-wrap::after {
    animation: shineFlash 0.7s ease-in-out;
}
.cms-quick-link-title { font-size: var(--p2); font-weight: 700; color: #1f2937; }
.cms-quick-link-desc { font-size: var(--p3); color: #6b7280; opacity: 0; transition: 0.3s; display:none; }
.cms-quick-link:hover .cms-quick-link-desc { opacity: 0; }

/* ───────────────────────── Sermon Swiper ───────────────────────── */
.cms-messages-section { padding: 5rem 0; background: #fff; }
.cms-section-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 1rem; }
.cms-section-title { font-family: var(--font-section-title); font-size: var(--section-title); font-weight: 700; color: #111827; }
.cms-divider { height: 1px; background: #000; margin-bottom: 2rem; }
.cms-nav-controls { display: flex; gap: 0.5rem; }
.cms-nav-btn { width: 2.2rem; height: 2.2rem; border: 1px solid transparent; display: flex; align-items: center; justify-content: center; color: #9ca3af; transition: 0.2s; }
.cms-nav-btn:hover { color: #374151; }
.cms-message-card { display: block; }
.cms-message-thumb-wrap { display: block; aspect-ratio: 16/10; overflow: hidden; margin-bottom: 0.6rem; border-radius: 0.3rem; background: #f3f4f6; position: relative; }
.sermonBG { width: 100%; height: 100%; background-size: cover; background-position: center; transition: transform 0.5s ease; }
.cms-message-card:hover .sermonBG { transform: scale(1.05); }
.cms-message-meta { font-size: var(--p3); color: #888; margin-bottom: 0.3rem; }
.cms-message-title { font-size: var(--card-title); font-weight: 600; color: #111827; margin-bottom: 0.7rem; }
.cms-message-more { font-size: var(--p3); color: #888; transition: 0.2s; }
.cms-message-card:hover .cms-message-more { color: var(--accent-green); }

/* ───────────────────────── Worship Schedule (복구됨) ───────────────────────── */
.cms-worship-section { padding: 5rem 0; background: #fff; }
.cms-nav-indicator { font-size: var(--p4); font-weight: 400; color: #999; min-width: 3rem; text-align: center; display: flex; align-items: center; justify-content: center;}
.cms-divider-loose { height: 1px; background: #000; margin-top: 0.85rem; margin-bottom: 1.65rem; }
.cms-worship-pc-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); overflow: hidden; height: 32rem; }
.cms-worship-content-box { padding: 3rem; display: flex; gap: 30px; flex-direction: column; justify-content: center; align-items: flex-start; opacity: 1; transform: translateY(0); transition: opacity 0.3s ease, transform 0.3s ease; }
.cms-worship-image-wrap { position: relative; height: 65%; align-self: center; overflow: hidden; }
.cms-worship-parallax-inner { position: absolute; left: 0; right: 0; will-change: transform; top: -15%; bottom: -15%; }
.cms-worship-image { width: 100%; height: 100%; object-fit: cover; transition: opacity 0.5s cubic-bezier(0.4, 0, 0.2, 1); }
.cms-worship-mob-grid { display: grid; grid-template-columns: repeat(1, minmax(0, 1fr)); overflow: hidden; }
.cms-worship-content-box-mob { padding: 1.5rem; display: flex; flex-direction: column; justify-content: center; align-items: flex-start; opacity: 1; transform: translateY(0); transition: opacity 0.3s ease, transform 0.3s ease; }
.cms-worship-image-wrap-mob { position: relative; height: 18rem; overflow: hidden; }

/* ───────────────────────── Next Generation (애니메이션/호버 완벽 복구) ───────────────────────── */
.cms-nextgen-section { padding: 8rem 0; background: #59818B; }

.cms-nextgen-layout { display: grid; grid-template-columns: 1fr; gap: 3rem; }
@media (min-width: 1024px) {
    .cms-nextgen-layout { grid-template-columns: 1fr 3fr; gap: 2rem; } /* 좌측 1 : 우측 3 비율 */
}

/* 🚨 좌측 영역: 타이틀 + 서브타이틀 고정 */
.cms-nextgen-left { display: flex; flex-direction: column; gap: 2.5rem; }
.cms-nextgen-title { font-family: var(--font-section-title); font-size: var(--section-title); font-weight: 800; color: #fff; line-height: 1.1; letter-spacing: -0.02em; margin: 0; text-align: left; }
.cms-nextgen-subtitle { font-size: var(--section-sub); color: #fff; font-weight: 500; line-height: 1.4; margin: 0; text-align: left; }

/* 🚨 우측 영역: 6개 아이템 3x2 배열 */
.cms-nextgen-grid { display: grid; grid-template-columns: 1fr; gap: 2rem; }
@media (min-width: 768px) {
    .cms-nextgen-grid { grid-template-columns: repeat(3, 1fr); gap: 3rem 2rem; }
}

.cms-nextgen-item { opacity: 0.8; transition: opacity 0.3s ease; cursor: pointer; text-align: left; }
.cms-nextgen-item:hover { opacity: 1; }
.cms-nextgen-title-wrap { display: flex; align-items: center; gap: 0.5rem; margin-bottom: 1rem; justify-content: flex-start; }
.cms-nextgen-item-title { font-size: var(--h3); font-weight: 700; color: #fff; margin: 0; }
.cms-nextgen-arrow { color: #fff; opacity: 0; transform: translateX(0); transition: 0.3s ease; }
.cms-nextgen-item:hover .cms-nextgen-arrow { opacity: 1; transform: translateX(0.3rem); }
.cms-nextgen-desc { font-size: var(--p3); color: #e5e7eb; font-weight: 300; line-height: 1.6; margin: 0; word-break: keep-all; }

/* 🚨 호버 시 서서히 밝아지는 애니메이션 */
.cms-nextgen-item { display: block; padding: 1.4rem 0; border: none; cursor: pointer; transition: opacity 0.3s ease; opacity: 0.7; text-align: left; }
.cms-nextgen-item:hover { opacity: 1; }
.cms-nextgen-title-wrap { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 1rem; }
.cms-nextgen-title { color: #ffffff; font-size: var(--h3); font-weight: 700; letter-spacing: 0.01em; margin: 0; }

/* 🚨 화살표 이동 및 페이드 인 효과 */
.cms-nextgen-arrow { width: 1rem; height: 1rem; color: #ffffff; opacity: 0; transition: opacity 0.35s ease, transform 0.35s ease; transform: translateX(0); }
.cms-nextgen-item:hover .cms-nextgen-arrow { opacity: 1; transform: translateX(0.25rem); }

/* 🚨 텍스트 색상 변화 효과 */
.cms-nextgen-desc { color: #fbfbfb; font-size: var(--p3); font-weight: 300; line-height: 1.5; opacity: 0.8; transition: color 0.2s, opacity 0.2s; margin: 0; }
.cms-nextgen-item:hover .cms-nextgen-desc { color: #ffffff; opacity: 1; }

/* ───────────────────────── Gallery Swiper (호버 스케일/오버레이 복구) ───────────────────────── */
.cms-gallery-section { padding: 5rem 0; background: #fff; }
.cms-circle-nav-btn { width: 2.2rem; height: 2.2rem; border-radius: 50%; border: 2px solid #000; transition: 0.3s; display: flex; justify-content: center; align-items: center; }
.cms-circle-nav-btn:hover { background: #000; color: #fff; }
.cms-divider-gallery { height: 1px; background: #000; margin: 1.25rem 0 2rem; }
.cms-gallery-item-wrap { display: block; text-decoration: none; position: relative; }
.cms-gallery-thumb-wrap { position: relative; overflow: hidden; background-color: #f3f4f6; aspect-ratio: 4/3; }

/* 🚨 Swiper 갤러리 내부 이미지 스케일 업 애니메이션 */
.cms-gallery-thumb.galleryBG { width: 100%; height: 100%; background-size: cover; background-position: center; transition: transform 0.5s ease; }
.cms-gallery-item-wrap:hover .cms-gallery-thumb.galleryBG { transform: scale(1.05); }

/* 🚨 정보 오버레이 페이드 인 애니메이션 */
.cms-gallery-overlay { position: absolute; bottom: 0; left: 0; right: 0; height: 25%; padding: 0.6rem 1rem; background: rgba(0,0,0,0.45); backdrop-filter: blur(6px); opacity: 0; transition: opacity 0.3s ease; display: flex; flex-direction: column; justify-content: center; }
.cms-gallery-item-wrap:hover .cms-gallery-overlay { opacity: 1; }
.cms-gallery-overlay-title { color: #fff; font-size: var(--p3); font-weight: 600; margin: 0; }
.cms-gallery-overlay-date { color: rgba(255,255,255,0.7); font-size: var(--p4); margin-top: 0.2rem; margin: 0; }

.cms-gallery-view-all { text-align: center; margin-top: 2rem; }
.cms-view-all-link-center { display: inline-flex; align-items: center; gap: 0.4rem; font-weight: 500; font-size: var(--p2); transition: 0.2s; }
.cms-view-all-link-center:hover { color: var(--accent-green); }

/* ───────────────────────── Welcome Section (레이아웃 깨짐 복구) ───────────────────────── */
/* 🚨 원본 Main_v1.css의 형태를 그대로 가져왔습니다. */
.cms-welcome-section { position: relative; padding-top: 6rem; padding-bottom: 6rem; overflow: hidden; text-align: center; }
.cms-welcome-bg-wrap { position: absolute; left: 0; right: 0; top: -20%; bottom: -20%; will-change: transform; }
.cms-welcome-bg-img { width: 100%; height: 100%; object-fit: cover; }
.cms-welcome-bg-overlay { position: absolute; inset: 0; background-color: rgba(45, 62, 45, 0.6); }
.cms-welcome-content { position: relative; z-index: 10; max-width: 46rem; margin-left: auto; margin-right: auto; padding-left: 1.5rem; padding-right: 1.5rem; text-align: center; }
.cms-welcome-tag { color: #9dbd9d; letter-spacing: 0.2em; font-size: var(--p3); margin-bottom: 1.2rem; }
.cms-welcome-heading { color: #fff; font-size: var(--section-title); font-weight: 600; margin-bottom: 2rem; }
.cms-welcome-body { color: rgba(255,255,255,0.8); font-size: var(--p2); line-height: 1.5; margin-bottom: 2.5rem; }
.cms-welcome-cta { display: inline-block; background: #fff; color: #2d3e2d; padding: 0.8rem 2.2rem; font-weight: 700; box-shadow: 0 4px 6px rgba(0,0,0,0.1); transition: 0.2s; }
.cms-welcome-cta:hover { background: #f4f4f2; }

/* ───────────────────────── Fade Up & Media Queries ───────────────────────── */
.fade-up { opacity: 0; transform: translateY(3rem); transition: opacity 0.75s cubic-bezier(0.25,0.46,0.45,0.94), transform 0.75s cubic-bezier(0.25,0.46,0.45,0.94); }
.fade-up.visible { opacity: 1; transform: translateY(0); }

/* lg+ 이상 블록 컨트롤 */
@media (min-width: 1024px) {
    .lg\:block { display: block !important; }
    .lg\:hidden { display: none !important; }
}

@media (max-width: 1499px) {}
@media (max-width: 1199px) {
    .cms-nextgen-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 1023px) { /* lg 미만 */
    .lg\:block { display: none !important; }
    .lg\:hidden { display: block !important; }
}
@media (max-width: 992px) {
    .cms-desktop-nav { display: none; }
    .cms-nextgen-layout { grid-template-columns: 1fr; text-align: center; }
    .cms-nextgen-title-wrap { justify-content: center; }
    .cms-nextgen-item { text-align: center; }
}
@media (max-width: 767px) {
    :root { --font-size: 14px; }
    /*.cms-hero-section { height: 90vh; }*/
    .cms-quick-links-grid { padding: 0; gap: 1rem; }
    .cms-quick-link-icon-wrap { width: 4rem; height: 4rem; }
    .cms-footer-bottom { flex-direction: column; align-items: flex-start; gap: 2rem; }
    .cms-footer-copyright { text-align: left; }
    .cms-nextgen-grid { grid-template-columns: 1fr; }
    .hidden-xs { display: none !important; }
}