<meta charset="utf-8">


.main_visual { height: 100vh; width: 100%; overflow-x: hidden; position: relative; }
.main_visual .swiper { width: 100%; height: 100vh; }
.main_visual .swiper-slide { background-position: center; background-size: cover; display: flex; align-items: center; justify-content: center; }
.main_visual .swiper-slide:nth-child(1n) { background-image: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url(../img/main_banner_img01.jpg); }
.main_visual .swiper-slide:nth-child(2n) { background-image: linear-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.5)), url(../img/main_banner_img02.jpg); }
.main_visual .swiper-slide.video-slide, .main_visual .swiper-slide.youtube-slide { background-image: none; }
.main_visual .swiper-slide .visual-tit { color: #fff; text-align: center; position: relative; z-index: 2; padding: 0 20px; }
.main_visual .swiper-slide .title { font-weight: 500; line-height: 1.2; font-size: 3vw; margin-bottom: 20px; }
.main_visual .swiper-slide .description { font-size: 0.9vw; color: #fff; opacity: 0.8 }
.video-background { position: absolute; top: 0; left: 0; width: 100%; height: 100%; object-fit: cover; }
.video-slide::before, .youtube-slide::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); z-index: 1; }
.main_visual .nav-and-scroll { position: absolute; bottom: 50px; right: 150px; display: flex; align-items: center; z-index: 100; }
.main_visual .nav-buttons { display: flex; margin-right: 10px; }
.main_visual .swiper-button-next, .main_visual .swiper-button-prev { position: relative; width: 80px; height: 80px; border-radius: 50%; border: 1px solid rgba(255, 255, 255, 0.2); background-color: transparent; transition: all ease 0.3s; margin: 0 5px; }
.main_visual .swiper-button-prev { background: url('../img/main_arrow01.png') no-repeat center; }
.main_visual .swiper-button-next { background: url('../img/main_arrow02.png') no-repeat center; }
.main_visual .swiper-button-prev::after, .main_visual .swiper-button-next::after { content: ''; }
.main_visual .swiper-button-prev:hover, .main_visual .swiper-button-next:hover { border-color: #fff; }
.main_visual .scroll_move { width: 80px; height: 80px; display: flex; justify-content: center; align-items: center; border-radius: 50%; background-color: rgba(255, 255, 255, 0.2); animation: moveUpDown 2s infinite; }
.main_visual .scroll_move .scroll_icon { font-size: 30px; color: #fff; line-height: 1; animation: bounce_frames 0.5s alternate infinite cubic-bezier(0.5, 0.05, 1, 0.5); }
@keyframes moveUpDown { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
@keyframes bounce_frames { from { transform: translateY(0); } to { transform: translateY(5px); } }

/* 애니메이션 스타일 */
@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translate3d(0, 40px, 0);
    }
    to {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }
}

.main_visual .swiper-slide .title,
.main_visual .swiper-slide .description {
    opacity: 0;
    animation-duration: 1s;
    animation-fill-mode: both;
}

.main_visual .swiper-slide-active .title {
    animation-name: fadeInUp;
    animation-delay: 0.5s;
}

.main_visual .swiper-slide-active .description {
    animation-name: fadeInUp;
    animation-delay: 1s;
}

@media screen and (max-width: 768px) {
    .main_visual .swiper-slide .title { font-size: 8vw; }
    .main_visual .swiper-slide .description { font-size: 3.5vw; word-break: keep-all; line-height: 1.65 }
    .main_visual .nav-and-scroll { bottom: 10px; right: 10px; }
    .main_visual .swiper-button-next, .main_visual .swiper-button-prev, .main_visual .scroll_move { width: 50px; height: 50px; }
    .main_visual .scroll_move .scroll_icon { font-size: 16px; }
}

@media screen and (max-width: 480px) {
    .main_visual .nav-buttons { display: none}
}




		
.container { max-width: 1600px; margin: 0 auto; padding: 0 20px; }

.section01 { width: 100%; padding: 150px 0;}
.section01 h2 {font-size: 50px; font-weight: bold; letter-spacing: -1px; margin-bottom: 50px }
.section01 .copy{ font-size: 27px; font-weight: 500; color: #fff; margin-bottom: 20px; }
.section01 .news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.section01 .news-item { position: relative; overflow: hidden; border-radius: 10px; height: 360px; }
.section01 .news-content { position: absolute; bottom: 0; left: 0; right: 0; padding: 30px; background: linear-gradient(to top, rgba(0,0,0,0.8), rgba(0,0,0,0)); color: white; }
.section01 .news-content h2 { margin: 0 0 10px 0; font-size: 24px; letter-spacing: 0; color: #fff; text-align: left; }
.section01 .news-meta { font-size: 14px; opacity: 0.8; }
.section01 .side-news { display: flex; flex-direction: column; gap: 20px; }
.section01 .side-news-item { display: flex; gap: 20px; align-items: center; }
.section01 .side-news-item img { width: 100px; height: 75px; object-fit: cover; border-radius: 5px; }
.section01 .side-news-content { flex: 1; }
.section01 .side-news-content h3 { margin: 0 0 5px 0; font-size: 16px; }
.section01 .side-news-meta { font-size: 14px; color: #555; }

@media (max-width: 768px) {
	.section01 { padding: 50px 0}
    .section01 .copy { font-size: 22px; margin-bottom: 20px; }
    .section01 .news-grid { grid-template-columns: 1fr; gap: 20px; }
    .section01 .news-item { height: 250px; }
    .section01 .news-content h2 { font-size: 20px; }
    .section01 .side-news-item { border-bottom: 1px solid #eee; padding-bottom: 20px; }
    .section01 .side-news-item:last-child { border-bottom: none; }
    .section01 .side-news-content h3 { font-size: 18px; }
}

@media (max-width: 480px) {
    .section01 .news-item { height: 200px; }
    .section01 .news-content h2 { font-size: 18px; }
    .section01 .side-news-item img { width: 80px; height: 60px; }
    .section01 .side-news-content h3 { font-size: 16px; }
}

.section02 { width: 100%; padding-bottom: 150px}
.section02 .main_copy { font-size: 50px; font-weight: bold; letter-spacing: -1px; color: #1a2b3c; padding-bottom: 20px}
.section02 p { font-size: 18px; color: #555; line-height: 1.65; font-weight: 400; padding-bottom: 50px; word-break: keep-all}		
.section02 .bear-grid { display: flex; justify-content: space-between; margin-bottom: 100px; background-size: cover; background-position: center; height: 700px; transition: background-image 1.5s ease; position: relative; } 
.section02 .bear-grid::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-color: rgba(0, 0, 0, 0.3); z-index: 1; } 
.section02 .bear-item { flex: 1; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; color: #fff; position: relative; z-index: 2; }
.section02 .bear-item:not(:last-child)::after {  content: '';  position: absolute;  right: 0;  top: 0; height: 100%;   width: 1px; background-color: rgba(255, 255, 255, 0.2); }
.section02 .bear-letter { font-size: 48px; font-weight: bold; }
.section02 .bear-title { font-size: 18px; margin-bottom: 10px; line-height: 1.65; opacity: 0.8; font-weight: 400 }
.section02 .bear-description { font-size: 20px; font-weight: 500 }
.section02 .flex-section { display: flex; flex-wrap: wrap;gap: 30px; margin: 40px 0;}
.section02 .flex-item { flex: 1; min-width: 300px; padding: 25px; box-sizing: border-box;} 
.section02 .flex-item p { font-size: 18px; line-height: 1.65; color: #555; margin: 0; }

.mission-grid { position: relative;width: 100%; background-color: transparent;overflow: hidden}
.mission-grid::before { content: '';position: absolute; top: 0; left: 0;width: 100%; height: 100%; background-color: #f8f9fa; transform: scaleX(0); animation: backgroundSlide 1s ease-out forwards;}
.mission-grid .inner {position: relative;  display: flex; justify-content: space-between; padding: 100px 0; z-index: 1; }
.mission-grid .left { width: 30%}
.mission-grid .left h2 { font-size: 50px; letter-spacing: -1px; font-weight: bold; max-width: 300px}
.mission-grid .left .view-btn { width: 200px; height: 75px; border: 1px solid #1465f4; border-radius: 40px; overflow: hidden; margin-top: 30px } 
.mission-grid .left .view-btn a { display: flex; align-items: center; justify-content: flex-start; width: 100%; height: 100%; padding-left: 90px; font-size: 18px; font-weight: 700; color: #1465f4; text-decoration: none; transition: color 0.3s; position: relative; } 
.mission-grid .left .view-btn a::before { content: ''; position: absolute; left: 14px; top: 50%; width: 52px; height: 52px; background: #1465f4; border-radius: 50%; transition: all 0.3s ease; z-index: 1; transform: translateY(-50%); } 
.mission-grid .left .view-btn a:hover::before { width: 100%; height: 100%; left: 0; top: 0; border-radius: 40px; transform: none; } 
.mission-grid .left .view-btn a:hover { color: #fff; } 
.mission-grid .left .view-btn a span { position: absolute; top: 50%; left: 30px; transform: translateY(-50%); color: #fff; transition: all 0.3s ease; z-index: 2; width: 20px; height: 20px; display: flex; align-items: center; justify-content: center; } 
.mission-grid .left .view-btn a:hover span { left: 45px; } 
.mission-grid .left .view-btn a .text { position: relative; z-index: 2; }
.mission-grid .right { width: 70%}
.mission-grid .flex-item { flex: 1;padding: 0 20px; line-height: 1.65; font-size: 18px;}

@keyframes backgroundSlide {
  0% {
    transform: scaleX(0);
    transform-origin: left;
  }
  100% {
    transform: scaleX(1);
    transform-origin: left;
  }
}


@media (max-width: 1200px) { 
    .section02 .bear-grid { height: 500px; } 
    .section02 .bear-letter { font-size: 36px; } 
    .section02 .bear-title { font-size: 16px; } 
    .section02 .bear-description { font-size: 18px; } 
}

@media (max-width: 768px) { 
    .section02 .bear-grid { flex-direction: column; height: auto; } 
    .section02 .bear-item { padding: 30px 0; } 
    .section02 .bear-item:not(:last-child)::after { width: 100%; height: 1px; bottom: 0; top: auto; left: 0; } 
    .section02 .flex-section { flex-direction: column; margin: 50px 0; } 
    .section02 .flex-item { padding: 0;  } 
    .mission-grid .mission-grid { flex-direction: column; } 
    .mission-grid .mission-item { margin: 10px 0; } 
    .mission-grid .inner { display: block}
    .mission-grid .left { width: 100%}
    .mission-grid .left .view-btn { width: 100px; height: 65px; border: 1px solid #1465f4; border-radius: 40px; overflow: hidden; margin-top: 30px } 
    .mission-grid .right { width: 100%}
}

@media all and (max-width: 576px) {
	.section02 { padding: 50px 0}
	.section02 .flex-item p { padding-bottom: 0px}
    .section02 .left h2 { font-size: 32px}

      .mission-grid .left .view-btn {
        width: 160px;
        height: 60px;
        margin-top: 20px;
      }

      .mission-grid .left .view-btn a {
        padding-left: 70px;
        font-size: 16px;
      }

      .mission-grid .left .view-btn a::before {
        left: 10px;
        width: 42px;
        height: 42px;
      }

      .mission-grid .left .view-btn a span {
        left: 24px;
        width: 16px;
        height: 16px;
      }

      .mission-grid .left .view-btn a:hover span {
        left: 36px;
      }


}


@media (max-width: 480px) { 
    .section02 .bear-letter { font-size: 28px; } 
    .section02 .bear-title { font-size: 14px; } 
    .section02 .bear-description { font-size: 16px; } 
    .mission-grid .mission-letter { font-size: 20px; } 
}
		
		
.section03 { width: 100%; padding: 200px 0}		
.section03 .container .header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 120px; }
.section03 .container .header h2 { font-size: 50px; font-weight: bold; letter-spacing: -1px; color: #1a2b3c; margin: 0; }
.section03 .container .header p { font-size: 18px; color: #555; font-weight: 400; max-width: 600px; line-height: 1.65}		
.section03 .container .description { font-size: 18px; text-align: left; max-width: 600px; word-break: keep-all; }
.section03 .container .flex-layout { display: flex; flex-wrap: wrap; gap: 20px; justify-content: space-between; align-items: flex-start; min-height: 300px; }
.section03 .container .box {  background-color: #f0f0f0;  padding: 20px; font-size: 14px;  flex-basis: calc(20% - 24px);  max-width: calc(20% - 24px); box-sizing: border-box;  position: relative; background-size: cover;  background-position: center;  color: white; display: flex; justify-content: center; align-items: flex-start; padding-top: 10px; padding-bottom: 30px; }
.section03 .container .box::before { 
    content: none; /* ::before 요소 비활성화 */
}
.section03 .box-1 { height: 588px; margin-top: 0; background-image: url('../img/section03_img01.jpg'); }
.section03 .box-2 { height: 351px; margin-top: 287px; background-image: url('../img/section03_img02.jpg'); }
.section03 .box-3 { height: 476px; margin-top: 0px; background-image: url('../img/section03_img03.jpg'); }
.section03 .box-4 { height: 280px; margin-top: 128px; background-image: url('../img/section03_img04.jpg'); }
.section03 .box-5 { height: 546px; margin-top: 230px; background-image: url('../img/section03_img05.jpg'); }
@media (max-width: 1200px) {
	.section03 .box { flex-basis: calc(33.333% - 14px); }
}
@media (max-width: 768px) {
    .section03 { 
        padding: 50px 0
    }
	.section03 .box {
		flex-basis: 100%;
		margin-top: 40px !important;
	}
	.section03 .header {
		flex-direction: column;
		align-items: flex-start;
	}
	.section03 .header-text {
		margin-top: 10px;
		text-align: left;
	}
}

@media (max-width: 576px) {
    .section03 .container .flex-layout {
        height: 476px;
        position: relative;
        overflow: hidden;
    }
    .section03 .container .box {
        flex-basis: 100%;
        max-width: 100%;
        height: 476px;
        margin-top: 0 !important;
        position: absolute;
        top: 0;
        left: 0;
        opacity: 1;
        transition: all 0.3s ease;
        padding-bottom: 30px; /* 모바일에서도 제목이 잘리지 않도록 여유 공간 추가 */
    }
    .section03 .container .box::before {
        content: none;
    }
    .section03 .swiper-slide {
        transition: transform 0.3s ease, opacity 0.3s ease;
    }
    .section03 .swiper-slide-active {
        z-index: 5;
        opacity: 1;
    }
    .section03 .swiper-slide-next {
        z-index: 4;
        opacity: 0.8;
        transform: scale(0.9) translateX(10%);
    }
    .section03 .swiper-slide-next ~ .swiper-slide {
        z-index: 3;
        opacity: 0.6;
        transform: scale(0.8) translateX(20%);
    }
}

.flex-layout {
    position: relative;
    overflow: hidden;
    touch-action: pan-y;
    cursor: grab;
}



		
.section04 .black_bg { position: relative; padding-top: 100px; opacity: 0; transform: translateX(-50px); transition: all 0.2s; }
.section04 .black_bg:before, .section04 .black_bg:after { content: ""; position: absolute; top: 0; z-index: -2; height: 485px; }
.section04 .black_bg:before { left: -55px; width: calc(100% + 110px); background-color: #222; }
.section04 .black_bg:after { right: -55px; width: 165px; background-color: #fff; z-index: -1; }
.section04 .black_bg .txt_area { position: relative; z-index: 1; max-width: 1280px; width: 75%; margin: 0 auto; color: #fff;  font-size: 18px; line-height: 1.65; word-break: keep-all; transition: all 0.2s; }
.section04 .black_bg .txt_area h2 { margin-top: 35px; font-size: 62px; font-weight: 600; line-height: 1; word-break: keep-all; }
.section04 .black_bg .txt_area a { position: absolute; right: 0; top: 15px; padding-right: 25px; font-size: 16px; font-weight: 500; color: #fff; line-height: 13px; }
.section04 .black_bg .txt_area a:before, .section04 .black_bg .txt_area a:after {position: absolute; top: 1px; font-size: 13px; transition: all 0.3s; }
.section04 .black_bg .txt_area a:before { right: 10px; opacity: 0; }
.section04 .black_bg .txt_area a:after { right: 0; }
.section04 .black_bg .txt_area a:hover:before { right: 0; opacity: 1; transition-delay: 0.1s; }
.section04 .black_bg .txt_area a:hover:after { right: -10px; opacity: 0; }
.section04 .black_bg .bg { position: relative; z-index: 0; width: calc(100% + 55px); height: 605px; margin-top: -26px; background: url(../img/section04_img01.jpg) bottom no-repeat fixed; background-size: cover; opacity: 0; animation-delay: 0.6s; transition: all 0.2s; }
@media (max-width: 1280px) { 
	.section04 .black_bg .txt_area { width: calc(100% - 165px); margin: 0; padding-left: 5%; }
}
@media (max-width: 1024px) { 
	.section04 .black_bg { padding: 80px 0 60px; } 
	.section04 .black_bg:before { height: 100%; } 
	.section04 .black_bg:after { display: none; } 
	.section04 .black_bg .txt_area { width: 100%; padding: 0 5%; } 
	.section04 .black_bg .txt_area p { font-size: 56px; } 
	.section04 .black_bg .txt_area a { right: 5%; } 
	.section04 .black_bg .bg { width: calc(100% - 40px); height: 300px; margin: -20px auto 0; } 
}
@media (max-width: 768px) { 
	.section04 .black_bg .txt_area { padding: 0 0 0 80px; } 
	.section04 .black_bg .txt_area h2 { font-size: 32px}
	.section04 .black_bg .txt_area p { font-size: 46px; } 
	.section04 .black_bg .bg { height: 250px; background-attachment: unset; background-position: center; } 
	.section04 .black_bg .txt_area a { display: block; position: relative; right: auto; top: auto;  margin-top: 100px; }
}
@media (max-width: 480px) { 
	.section04 .black_bg { padding-top: 60px; } 
	.section04 .black_bg .txt_area { padding: 0 0 0 80px; font-size: 16px } 
	.section04 .black_bg .txt_area p { font-size: 38px; } 
	.section04 .black_bg .bg { width: calc(100% - 30px); height: 200px; } 
}
		


    
.section05 { width: 100%; padding: 200px 0; }    
.section05 .top_section { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 30px; }
.section05 .top_section h2 { font-size: 50px; font-weight: bold; letter-spacing: -1px; margin-bottom: 10px; flex: 0 0 50%; }
.section05 .description { flex: 0 0 35%; text-align: left; font-size: 18px; color: #555; font-weight: 400; line-height: 1.6; word-break: keep-all; }
.section05 .image-container { display: flex; justify-content: space-between; gap: 20px; height: 600px; }
.section05 .image-wrapper { flex: 1; position: relative; overflow: hidden; }
.section05 .image { width: 100%;  height: 100%;  background-size: cover; background-position: center; background-repeat: no-repeat;transition: opacity 0.5s ease-in-out;}
.section05 .image-primary { position: relative; z-index: 1; }
.section05 .image-secondary { position: absolute; top: 0;left: 0;opacity: 0;z-index: 2;}
.section05 .image-wrapper:hover .image-primary { opacity: 0; }
.section05 .image-wrapper:hover .image-secondary { opacity: 1; }

@media (max-width: 768px) {
	.section05 { padding: 50px 0}
    .section05 .top_section { flex-direction: column; }
	.section05 .top_section h2 { font-size: 32px}
	.section05 .description { flex: 0 0 100%; }
    .section05 .image-container { flex-direction: column; height: auto; }
    .section05 .image-wrapper { height: 300px; }
    .section05 .description { margin-top: 20px; }
}
	


.section06 { width: 100%; padding: 150px 0}
.section06 .main-title { font-size: 50px; color: #000; margin-bottom: 20px; letter-spacing: -1px; font-weight: bold; }
.section06 .subtitle { font-size: 18px; color: #555; max-width: 600px; line-height: 1.65; margin: 0 auto; }		
.section06 .top-section { text-align: center; margin-bottom: 40px; }
.section06 .gallery { display: flex; justify-content: flex-start; height: 700px; overflow: hidden; width: 100%; }
.section06 .gallery-item { flex: 1 0 20%; transition: flex-basis 0.5s ease; position: relative; overflow: hidden; cursor: pointer; }
.section06 .gallery-item:last-child { margin-left: auto; }
.section06 .gallery-item img { height: 100%; width: 100%; object-fit: cover; object-position: left; transition: object-position 0.5s ease, filter 0.5s ease; filter: brightness(0.7); }
.section06 .gallery-item-text { position: absolute; bottom: 30px; left: 30px; color: white; font-size: 18px; line-height: 1.65; max-width: 80%; z-index: 2;}
.section06 .gallery-item::after { content: attr(data-number); position: absolute; top: 20px; right: 20px; color: white; font-size: 24px; font-weight: bold; }		
.section06 .gallery-item::before { content: attr(data-number); position: absolute; top: 20px; left: 20px; color: white; font-size: 24px; z-index: 1; opacity: 0; transition: opacity 0.3s ease; z-index: 2;}
.section06 .gallery-item:hover img { filter: brightness(0.85); }
.section06 .gallery-item.active::before { opacity: 1; }
.section06 .gallery-item.shrink .gallery-item-text, .gallery-item.shrink::before { opacity: 0; }


@media (max-width: 1200px) { 
	.section06 .gallery { height: 500px; }
}
@media (max-width: 768px) {
    .section06 { padding: 50px 0; } 
    .section06 .gallery-item-text { font-size: 16px; left: 10px; writing-mode: vertical-rl; text-orientation: mixed; transform: rotate(360deg); height: auto; max-height: 80%; width: auto; max-width: none; bottom: 20px; line-height: 1.2; }
    .section06 .gallery-item-text br { display: none; }
    .section06 .gallery-item::after { font-size: 20px; } 
}


.tl_video_bg_wrap .video_area {background-image:url(../img/movie_bg.jpg);background-position:center;background-repeat:no-repeat;background-size:cover;height:506px;position:relative;z-index:1;display:flex;align-items:center;  justify-content: center; background-attachment:fixed}
.tl_video_bg_wrap .video_area .inner {padding: 0; width: 100%;}
.tl_video_bg_wrap .video_area .title {text-align: center; font-size: 18px; color: #f5f5f5; font-weight: 600; padding-bottom: 30px; letter-spacing: 15px; margin-top: -20px; position: relative;}

.tl_video_bg_wrap .video_area .intro_video_iner {width: 100%; height: 100%; display: flex; flex-direction: column; align-items: center; justify-content: center;}
.tl_video_bg_wrap .video_area .intro_video_icon {display: flex; align-items: center; justify-content: center; margin-top: 50px; position: relative;}
.tl_video_bg_wrap .video_area .video-play-button {position: relative; z-index: 10; box-sizing: content-box; display: block; width: 32px; height: 44px; background: linear-gradient(to right, #fdb812, #d19504); border-radius: 50%; padding: 18px 20px 18px 28px; border: none; cursor: pointer;}
.tl_video_bg_wrap .video_area .video-play-button:before {content: ""; position: absolute; z-index: 0; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%); display: block; width: 80px; height: 80px; background: rgba(255, 255, 255, .3); border-radius: 50%; animation: pulse-border 1.5s ease-out infinite;}

.tl_video_bg_wrap .video_area .video-play-button:after {content: ""; position: absolute; z-index: 1; left: 50%; top: 50%; transform: translateX(-50%) translateY(-50%); display: block; width: 80px; height: 80px; background: rgba(255, 255, 255, .2); border-radius: 50%; transition: all .2s;}
.tl_video_bg_wrap .video_area .video-play-button:hover:after {background: rgba(255, 255, 255, 0.3);}
.tl_video_bg_wrap .video_area .video-play-button img {position: relative; z-index: 3; max-width: 100%; width: auto; height: auto;}
.tl_video_bg_wrap .video_area .video-play-button span {display: inline-block; position: relative; z-index: 3; top: 8px; cursor: pointer; color: #fff; font-size: 28px;}

@keyframes pulse-border {0% {transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1); opacity: 1;} 100% {transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1.5); opacity: 0;}}
        
#video-box {max-width: 800px; width: 100%; margin: 0 auto; display: none; border: 2px solid #fff; border-radius: 4px; position: relative;}
#video-box .iframe-wrapper {background-color: black; width: 100%; padding-top: 66.666%; position: relative;}
#video-box .b-close {position: absolute; border: 0; outline: 0; background-color: transparent; z-index: 30; width: 30px; height: 30px; right: 5px; top: 5px; color: #fff; font-size: 28px; line-height: 1em; cursor: pointer;}
.iframe-wrapper iframe {position: absolute; z-index: 10; left: 0; top: 0; width: 100%; height: 100%;}
.iframe-wrapper iframe.on {z-index: 20;}



 @media (max-width: 768px) {
	 .tl_video_bg_wrap .video_area {height: 400px;}
	 .tl_video_bg_wrap .video_area .title {font-size: 16px; letter-spacing: 10px;} 
	 .tl_video_bg_wrap .video_area .intro_video_icon {margin-top: 30px;}
}





		
.section07 { width: 100%; padding: 0 0 150px 0}
.section07 .container-flex { max-width: 1600px; margin: 150px auto 0 auto; display: flex; gap: 40px; padding: 0 20px } 
.section07 .content { flex: 1; max-width: calc(50% - 20px); } 
.section07 .title { font-size: 50px; color: #000; letter-spacing: -1px; line-height: 1.2; margin-bottom: 30px; } 
.section07 .description { font-size: 20px; color: #333; line-height: 1.65; margin-bottom: 40px; max-width: 500px; word-break: keep-all } 
.section07 .highlight-list { list-style-type: none; padding: 0; } 
.section07 .highlight-item { display: flex; align-items: center; color: #555 } 
.section07 .highlight-icon { width: 50px; height: 50px; display: flex; align-items: center; justify-content: center; margin-right: 20px; font-size: 20px; }
.section07 .highlight-text { font-size: 18px; color: #555; font-weight: 400 } 
.section07 .image-container { flex: 1; max-width: calc(50% - 20px); } 

.section07-swiper { width: 100%; height: 400px; position: relative; overflow: hidden; }
.section07-swiper .swiper-wrapper { transition-timing-function: linear; }
.section07-swiper .swiper-slide { width: 100%; height: 100%; transition: transform 0.2s ease; }
.section07-swiper .swiper-slide img { width: 100%; height: 100%; object-fit: cover; }
.section07-swiper .swiper-button-next, .section07-swiper .swiper-button-prev { position: absolute; bottom: 20px; top: auto; color: #fff;  padding: 10px; width: 40px; height: 40px;}
.section07-swiper .swiper-button-next { right: 20px; }
.section07-swiper .swiper-button-prev { right: 70px; left: auto; }
.section07-swiper .swiper-button-next::after, .section07-swiper .swiper-button-prev::after { font-size: 18px; }



@media (max-width: 1024px) {
        .section07 .container-flex { 
            flex-direction: column; 
        }
        .section07 .content,
        .section07 .image-container { 
            max-width: 100%; 
            margin-bottom: 40px; 
        }
        .section07-swiper {
            height: 400px;
        }
}

@media (max-width: 768px) {
        .section07 {
            padding: 50px 0
         }
        .section07 .container-flex { 
			flex-direction: column; 
			margin: 50px 0
	      }
}
           
 
