@charset "UTF-8";

.submenu {height: 87vh; z-index: 0;}
.sub_top, .submenu_2depth {display: none !important;}
.quick-menu-fixed {background: #ffffff; }

/* 메인 히어로 섹션 */
.hero-section {position: relative; /*top: -100px; margin-bottom: -100px;*/ background: #000; overflow: hidden;}
.hero-slider {position: relative;}
.slide-item {position: relative; height: 50vw; display: flex; align-items: center; overflow: hidden;}
.slide-image {position: absolute; top: 0; left: 0; width: 100%; height: calc(100% - 80px); z-index: 0; }
.slide-image img, .slide-image video {width: 100%; height: 100%; object-fit: fill; object-position: center;}
.slide-content {position: absolute; bottom: 0; left: 0; right: 0; z-index: 2; background: #ffffff; padding:20px; padding-right: 60px; color: #fff; text-align: left; border-bottom: 1px solid #d7d7d7; min-height: 80px;}
.performance-info {display: flex; align-items: center; margin: 0 auto;}
.performance-title {font-size: 30px; font-weight: 600; color: #000000; flex: 1; margin-right: 20px; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; box-orient: vertical;}
.performance-link {display: flex; align-items: center; gap: 8px; background: rgba(255, 255, 255, 0.1); padding: 12px 20px; border-radius: 25px; text-decoration: none; color: #000000; font-size: 14px; font-weight: 500; transition: all 0.3s ease; backdrop-filter: blur(10px); border: 1px solid rgba(255, 255, 255, 0.2);}
.performance-link:hover {background: rgba(255, 255, 255, 0.2); transform: translateX(5px);}

/* 슬라이드 네비게이션 스타일 */
.hero-slider .slick-prev {left: 20px;}
.hero-slider .slick-next {right: 80px;}
.hero-slider .slick-dots {position: absolute; bottom: 100px; left: 50%; transform: translateX(-50%); z-index: 8;}
.hero-slider .slick-dots li {display: inline-block; margin: 0 5px;}
.hero-slider .slick-dots li button {height: 15px; border-radius:15px; background: #ffffff; font-size: 0; cursor: pointer; transition: all 0.3s ease;}
.hero-slider .slick-dots li.slick-active button {background: #fff;}
.hero-slider .slick-dots li button:hover {background: rgba(255, 255, 255, 0.5);}

.section-header {text-align: center; margin-bottom: 20px; display: flex; align-items: center; justify-content: center; flex-direction: column;}
.section-header h2 {font-size: 45px; font-weight: 700; margin-bottom: 50px;}
.section-header p {font-size: 20px; color: #666; margin-bottom: 20px;}

/* 문화행사 섹션 */
.cultural-events {padding:100px 5% 60px 5%; margin: auto; border-bottom: 1px solid #d7d7d7;}
.event-tabs {display: flex; justify-content: flex-start; align-items: center; gap: 0px; font-size: 26px; color: #888888; font-weight: 500;}
.event-tabs .tab {height: auto; padding:0px 5px; margin: 0px 10px; cursor: pointer; transition: all 0.3s ease; outline: none;}
.event-tabs .tab:hover, .event-tabs .tab.active {color: var(--color2); background: linear-gradient(to top, #47474721 50%, transparent 50%);}
.event-tabs .tab-more:hover {color: var(--color2);}
.event-tabs .tab-more {cursor: pointer; font-size: 30px; font-weight: lighter; color: #666; padding: 0px 10px;}
.cultural-events .event-cards {display: flex;justify-content: center; gap: 30px; margin: 0 auto; transition: all 0.3s ease;}
.cultural-events .event-card {margin: 20px; border-radius: 12px; overflow: hidden; transition: transform 0.3s ease; cursor: pointer;}
.cultural-events .event-card:hover {transform: translateY(-5px);}
.cultural-events .event-image { /*height: 30vw;*/height: 24vw; border-radius: 15px; overflow: hidden; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); position: relative;}
.cultural-events .event-image img {width: 100%; height: 100%;object-fit: fill;}
.cultural-events .event-image .event-type-label {position: absolute; top: 1rem; left: 12px; padding: 6px 12px; border-radius: 20px; font-size: 0.8rem; font-weight: 400; color: #ffffff; z-index: 10; letter-spacing: 0px;}
.cultural-events .event-type-label.foundation {background: var(--color3, #006596);}
.cultural-events .event-type-label.region {background: var(--color, #e325cc);}
/* 뱃지 → 제목(최대 2줄) 세로 배치: 가로 flex 시 2줄 제목 옆에 뱃지가 끼는 문제 방지 */
.cultural-events .event-title-row {display: flex; flex-direction: column; align-items: flex-start; gap: 6px; margin-bottom: 8px; width: 100%; min-width: 0; box-sizing: border-box;}
.cultural-events .event-title-row .event-title {width: 100%; max-width: 100%; flex: none; margin-bottom: 0; height: auto; max-height: calc(1.35em * 2 + 6px); font-size: 18px; font-weight: 600; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; box-orient: vertical; white-space: normal; word-break: break-word; box-sizing: border-box;}
.cultural-events .event-info .event-type-label {position: static; padding: 6px 12px; border-radius: 20px; font-size: 0.8rem; font-weight: 400; color: #ffffff; letter-spacing: 0; display: inline-block; line-height: 1.2; max-width: 100%; box-sizing: border-box; word-break: keep-all; white-space: normal; text-align: center;}
.cultural-events .event-info {padding: 20px 0px; text-align: left; min-width: 0;}
.cultural-events .event-date {color: #666; margin-bottom: 10px;}
.cultural-events .event-title {font-size: 18px; font-weight: 600; height: 50px; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical; box-orient: vertical; margin-bottom: 8px;}
.cultural-events .event-location {color: #666; margin-bottom: 15px;}
.cultural-events .event-location::before {content: "\f3c5"; font-family: "Font Awesome 6 Free"; font-weight: 900; margin-right: 5px;}
.cultural-events .event-link {color: #006596; text-decoration: none; font-size: 14px; font-weight: 500;}

/* 문화행사 슬라이드 네비게이션 스타일 */
.cultural_event_slick .slick-prev {left: -20px; top: 40%;}
.cultural_event_slick .slick-next {right: -30px; top: 40%;}
.cultural_event_slick .slick-prev:before {content: ''; background: url(/resources/view/phcf/images/prev_1.png) no-repeat 0 0; height: 35px; width: 35px; display: block;}
.cultural_event_slick .slick-next:before {content: ''; background: url(/resources/view/phcf/images/next_1.png) no-repeat 0 0; height: 35px; width: 35px; display: block;}
.cultural_event_slick .slick-dots {position: absolute; bottom: 0px; left: 50%; transform: translateX(-50%); z-index: 10;}
.cultural_event_slick .slick-dots li {display: inline-block; margin: 0 5px;}
.cultural_event_slick .slick-dots li button {background: #bbbbbb; }
.cultural_event_slick .slick-dots li.slick-active button {background: #000000;}
.cultural_event_slick .slick-dots li button:hover {background: #000000;}

/* 문화소식 섹션 */
.cultural-news {padding:60px 5%; margin: auto;}
.news-tabs {display: flex; gap: 3%; flex-wrap: wrap; align-items: center;}
.news-tabs .tab {font-size: 23px; color: #242424; font-weight: 500; height: auto; margin-bottom: 0px; cursor: pointer; transition: all 0.3s ease; outline: none;}
.news-tabs .tab:hover {color: var(--color2);}
.news-tabs .tab.active {color: var(--color2); font-weight: bold; background: linear-gradient(to top, #47474721 50%, transparent 50%);}
.news-tabs .tab-more {cursor: pointer; font-size: 23px; font-weight: lighter; color: #666; padding: 0px 10px;}
.news-tabs .tab-more:hover {color: var(--color2);}
.news-container {display: flex; justify-content:space-evenly; gap: 20px; margin: 0 auto; margin-top: 80px;}
.news-content {display: flex; flex-direction: column; gap: 10px; width: 50%;}
.news-list {display: none; animation: fadeIn 0.3s ease-in-out;}
.news-list.active {display: block;}

@keyframes fadeIn {
    from {opacity: 0; transform: translateY(10px);}
    to {opacity: 1; transform: translateY(0);}
}

.news-item {display: flex; align-items: center; gap: 10px; padding:15px 15px; margin: 10px 0px; border: 1px solid #d1d1d1; border-radius: 10px; transition: all 0.3s ease; cursor: pointer;}
.news-item:hover {transform: translateY(-3px); box-shadow: 1px 1px 6px rgb(0 0 0 / 29%);}
.news-item:hover .news-title {color: var(--color2); font-weight: bold;}
.news-item:hover .news-date {font-size: 16px;}
.news-category {font-weight: bold; min-width: 110px;}
.news-title {flex: 1; color: #333; text-decoration: none; height: 20px; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 1; line-clamp: 1; -webkit-box-orient: vertical; box-orient: vertical;}
.news-title:hover {color: #006596;}
.news-date {font-size: 14px; color: #666;}
.news-gallery {width:47%;}
.gallery-items {position: relative; max-height: 420px; border-radius: 30px; overflow: hidden;}
.gallery-items img {width: 100%; height: 100%; object-fit: fill;}
.news-gallery .slick-dots {bottom: 10px !important;}

/* 유관기관 섹션 */
.partner-institutions {padding: 0px 5% 60px 5%; margin: auto;}
.partner-logos {display: flex; justify-content: center; gap: 50px; margin: 0 auto;}
.partner-item {cursor: pointer; display: flex; flex-direction: column; align-items: center; gap: 15px; padding: 20px 0px; margin: 0px 10px; transition: all 0.3s ease;}
.partner-item:hover {transform: translateY(-3px);}
.partner-item img {width: 120px; height: 120px; border: 1px solid #b2b2b2; border-radius: 100%; object-fit: none; filter: grayscale(100%); transition: all 0.3s ease;}
.partner-item:hover img {filter: grayscale(0%); box-shadow: 1px 1px 6px rgb(0 0 0 / 29%);}
.partner-item span {font-weight: 600; text-align: center; margin-top: 10px; display: block;}
.partner-item:hover span {color: var(--color3);}
.partner-institutions .slick-prev {left: -50px;}
.partner-institutions .slick-next {right: -50px;}
.partner-institutions .slick-prev:before {content: ''; background: url(/resources/view/phcf/images/prev_1.png) no-repeat 0 0; height: 35px; width: 35px; display: block;}
.partner-institutions .slick-next:before {content: ''; background: url(/resources/view/phcf/images/next_1.png) no-repeat 0 0; height: 35px; width: 35px; display: block;}

/* 문화영상 섹션 */
.cultural-videos {color: #fff; background: #ffffff00 url(/resources/view/phcf/images/footer_bg.png) top center no-repeat; background-size: cover; color: white; padding:150px 20px 0px 20px; width: 100%; position: relative; z-index:9;}
.cultural-videos footer {background: none !important;}
.cultural-videos .section-header h2 {color: #fff;}
.cultural-videos .section-header p {color: #ffffff;}
.video-cards {display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 30px; padding: 60px 0; margin: 0 auto; }
.video-card {text-align: center; overflow: hidden; margin: 10px; transition: transform 0.3s ease;}
.video-card:hover {transform: translateY(-5px);}
.video-thumbnail {position: relative; background: #000000; height: 500px; border-radius: 30px; overflow: hidden;}
.video-thumbnail img {width: 100%; height: 100%; object-fit: cover;}
.play-button {position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); background:transparent; color: #fff; width: 60px; height: 60px; border-radius: 50%; border: 3px solid #fff; display: flex; align-items: center; justify-content: center; font-size: 24px; cursor: pointer; transition: all 0.3s ease;}
.play-button:hover {background: rgba(0, 0, 0, 0.9); transform: translate(-50%, -50%) scale(1.1);}
.video-info {padding: 20px 0px;}
.video-title {font-size: 18px; font-weight: 600; color: #fff; margin-bottom: 8px;}

.submenu_current_title{padding:0;}
/* 반응형 디자인 */
@media (max-width: 1630px) {
    .news-gallery {width:50%;}
    .news-content {width: 45%; padding-right: 48px;}
    .cultural-events .event-cards {padding-right: 45px;}
    .cultural_event_slick .slick-prev{left: 10px;}
    .cultural_event_slick .slick-next {right: 30px;}
    .partner-institutions .slick-prev {left: -20px;}
    .partner-institutions .slick-next {right: -35px;}
    .partner-institutions {padding: 0px 80px 60px 30px;}
}
@media (max-width: 1200px) {
    .news-container { flex-direction: column-reverse; margin-top: 30px;}
    .news-content {width: 90%; padding-right: 0px; margin: 0px 20px;}
    .news-gallery {width:94%;padding: 10px 20px;}
    .cultural-videos{background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 3%, #265b9c 15%), url(/resources/view/phcf/images/footer_bg.png) top center no-repeat; background-size: contain;}
}
@media (max-width: 1000px) {
    .slide-image img {object-fit: cover;}
    .slide-content {padding: 10px; min-height: auto;}
    .hero-section .slide-item .slide-content .performance-title {font-size: 18px;}
    .cultural-events .event-image {height: 350px;}
    .cultural-events .event-tabs, .event-tabs .tab-more { justify-content: center; font-size: 18px; padding: 0px 0px; margin-left: 10px;}
    .event-tabs .tab { margin: 0px 0px;padding: 0px 5px;}
    .cultural-events .event-type-label{font-size: 12px; padding: 4px 8px;}
    .cultural-events .event-info .event-type-label{font-size: 12px; padding: 4px 8px;}
    .cultural-events .event-title{font-size:15px; height: auto;}
    .cultural-events .event-title-row .event-title{font-size: 15px; max-height: calc(1.35em * 2 + 6px);}
    .cultural-events .event-date{font-size:14px; margin-bottom: 5px;}
    .cultural-events .event-location{font-size:14px;}
    .video-title{font-size:14px; margin-bottom: 30px;}
    .cultural-events .event-image img{object-fit: cover;}
}
@media (max-width: 1024px) {
    .cultural-news, .cultural-events {padding: 70px 0px 20px 0;}
    .section-header h2 {font-size: 36px; margin-bottom: 0;}
    .section-header p {font-size:16px;}
    .hero-section {/* top:-100px;*/ margin-bottom: 0px;}
    .hero-section .slide-item {height: 55vw;}
    .hero-slider .slick-prev { left: 5px; }
    .hero-slider .slick-next { right: 10px; }
    .cultural-events .event-cards { padding: 0px 10px; }
    .partner-institutions { padding:0px 20px 20px 20px; }
    .performance-info {height: 50px;}
    .performance-title {font-size: 18px; margin-right: 0;}
    .performance-link {padding: 5px 0px;}
    .performance-link img {width:40px;}
    .news-content, .news-gallery {width: 100%; padding: 0px 20px; margin: 0px 0px;}
    .news-item { flex-direction: column; align-items: flex-start;}
    .news-tabs .tab { font-size: 20px; gap: 5px; }
    .partner-item {margin: 0;}
    .partner-item img { width: 80px; height: 80px; object-fit: contain !important;}
    .partner-item span {font-weight: 100; font-size: 13px; word-wrap: break-word;}
    .partner-institutions .slick-prev {left: -15px;}
    .partner-institutions .slick-next {right: -15px;}
    .gallery-items img {padding: 0px 0px;}
    .video-cards {grid-template-columns: 1fr; padding: 20px 0; }
    .cultural-events .event-card {margin: 0px 5px;}
    .cultural_event_slick .slick-prev:before{left: 0px;}
    .cultural_event_slick .slick-next {right: 5px;}
    .cultural-videos { padding: 100px 10px 0px 10px;}
    .video-thumbnail {height: auto; min-height: 230px; border-radius: 10px;}
    .video-thumbnail iframe { min-height: 230px;}
}
@media (max-width: 560px) {
    .cultural-events .event-image {height: 30vh;}
    .news-tabs .tab, .news-tabs .tab-more { font-size: 16px; }
    .news-tabs .tab-more {padding: 0px 5px;}
    .news-tabs { gap: 10px;}
    .hero-section .slide-item {height: 65vw;}
    .cultural_event_slick .slick-prev,
    .cultural_event_slick .slick-next {
        display: none !important;
    }
    .hero-slider .slick-prev,
    .hero-slider .slick-next {
        display: none !important;
    }
    .hero-slider .slick-dots {
        display: none !important;
    }
    .partner-institutions .slick-prev,
    .partner-institutions .slick-next {
        display: none !important;
    }
    .cultural_event_slick .slick-prev{left: 20px;}
    .slick-dots li {margin: 0 2px;}
}

/* 메인 페이지 dialog 팝업 */
.ui-widget-overlay {
    display: block !important;
    background: rgba(0, 0, 0, 0.5) !important;
    cursor: pointer !important;
}
.main_popup.ui-widget.ui-widget-content {box-shadow: 0 0 10px rgb(209 209 209 / 30%); padding: 10px; border-radius: 15px;}
.main_popup .ui-dialog-content label.input[type=checkbox] {background: #eeeeee;}
.main_popup .ui-widget-header { border: 0px solid #ddd !important; background: #ffffff !important; border-bottom: 1px solid #eeeeee !important;}
.main_popup .ui-widget-header .ui-button {border: 0px solid #c5c5c5 !important;}
.main_popup .ui-dialog-titlebar-close {background: #fff url(/resources/view/phcf/images/btn-close-search.png) no-repeat !important; top: 20px !important; right: 0px !important;}
.main_popup .ui-dialog-titlebar-close .ui-button-icon, .ui-dialog .ui-dialog-titlebar-close .ui-button-icon {background-image: none !important;}
.main_popup .ui-dialog-buttonpane button { background: #4689d3 !important; font-size: 0.9em !important;}
.main_popup .ui-dialog-buttonpane button:hover { background: #666666 !important; font-size: 0.9em !important;}
.main_popup .ui-dialog-content img {width: auto; max-width: 100%;}
.main_popup .ui-widget-content {height: auto !important;}
.main_popup .popup-checkbox-container { text-align: right;font-size: 14px;}
.main_popup .popup-checkbox-container input[type=checkbox] {margin-right: 5px;}
.main_popup table { width: 100% !important; border: 1px solid #9c9c9c !important; border-collapse: collapse; }
.main_popup table th, .main_popup table td {vertical-align: middle; }
.main_popup table th { text-align: center; background: #fafafa; color: #666666;}
.main_popup table td { text-align: left; padding: 5px 10px;}

/* 모바일 대응 */
@media only screen and (max-width: 1024px) {
    .ui-widget.ui-widget-content {top: 120px !important; left: 0px !important; margin: 10px;}
}


#cultural_event_slick .slick-track {
    margin-left: 0 !important;
    margin-right: auto !important;
  }
#cultural_event_slick .slick-slide { min-width: 0; }


.color_change .event-tabs .tab:hover, .color_change .event-tabs .tab.active,
.color_change .news-tabs .tab.active{background: linear-gradient(to top, #e325cc 50%, transparent 50%);}


