@charset "UTF-8";@import url("/fnc_css/font/font.css");html { overflow-x: hidden; }
section { width: 100%; }
section > div { width: 100%; position: relative; }
/* 1번섹션 */
.main01-swiper { width: 100%; height: 100vh; }
.main01-slide { text-align: center; display: flex; flex-direction: column; align-items: center; color: #fff; padding-top: 250px; background: url("/fnc_images/main/main_bg1.jpg") no-repeat center/cover; }
.main01-slide > p { font-size: 20px; line-height: 28px; margin-bottom: 10px; }
.main01-slide > h2 { font-size: 60px; line-height: 70px; font-weight: bold; }
/* 불렛박스 위치 */
.main01-swiper .main01-pagination { z-index: 10; position: absolute; left: 50%; transform: translateX(-50%); bottom: 50%; width: fit-content; right: unset; height: fit-content; }
/* 기본불렛 */
.main01-swiper .main01-pagination .swiper-pagination-bullet { background-color: #fff; border-radius: 0; width: 40px; height: 10px; border: 2px solid #fff; transition: all 0.3s; margin: 0 10px; opacity: 0.35; border-radius: 10px; }
/* 현재페이지 불렛 */
.main01-swiper .main01-pagination .swiper-pagination-bullet-active { opacity: 1; }
.main01-link { width: 100%; max-width: 1360px; padding: 0 30px; display: flex; gap: 65px; position: absolute; bottom: 23%; left: 50%; transform: translateX(-50%); z-index: 10; }
.main01-link > a { width: 25%; height: 200px; padding: 30px 40px; background-color: rgba(255, 255, 255, 0.3); backdrop-filter: blur(15px); -webkit-backdrop-filter: blur(15px); border-radius: 10px; display: flex; flex-direction: column; justify-content: space-between; transition: all 0.3s; }
.main01-link > a:hover { background-color: #005fa2; }
.main01-link > a > p { color: #fff; font-size: 20px; line-height: 28px; font-weight: bold; }
.main01-link > a > div { display: flex; justify-content: end; }
.main01-scroll { position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%); z-index: 10; color: #fff; display: flex; flex-direction: column; align-items: center; gap: 20px; }
.main01-scroll > p { font-size: 15px; line-height: 23px; text-align: center; }
/* 2번섹션 */
.main02-wrap { width: 100%; max-width: 1360px; padding: 0 30px; margin: 75px auto 100px; }
.main02-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 50px; }
.main02-top-left { display: flex; align-items: center; gap: 25px; }

.main-subtitle { position: relative; }
.main-subtitle > p { font-size: 16px; line-height: 24px; font-weight: 700; color: #005fa2; position: absolute; left: 0; top: -24px; }
.main-subtitle > h3 { font-size: 40px; line-height: 50px; font-weight: bold; letter-spacing: -1px; }

.main02-top-left .main-subtitle > p { display: none; }
.main02-top-left .main-subtitle.active > p { display: block; }
.main02-top-left .main-subtitle > h3 { color: #b8b8b8; cursor: pointer; user-select: none; }
.main02-top-left .main-subtitle.active > h3 { color: #000; }

.main-link-btn { width: 200px; height: 60px; box-shadow: 15px 15px 25px #62789e29; border-radius: 50px; background-color: #005fa2; display: flex; align-items: center; justify-content: space-between; padding: 0 35px; color: #fff; font-size: 16px; line-height: 24px; font-weight: 500; transition: all 0.3s; border: 2px solid #005fa2; }
.main-link-btn:hover { color: #005fa2; background-color: #fff; }
.main-link-btn > span { width: 10px; height: 12px; transition: all 0.3s; background: url("/fnc_images/main/main_arrow_white.svg") no-repeat center; }
.main-link-btn:hover > span { background: url("/fnc_images/main/main_arrow.svg") no-repeat center; }
.main02-bot { width: 1600px; }

.main02-bot > div { display: none; }
.main02-bot > div.active { display: block; }
.main02-slide { width: 100%; height: 350px; padding: 35px 40px; border-radius: 20px; background-color: #f4f7fb; display: flex; flex-direction: column; justify-content: space-between; }
.main02-slide > div > h4 { font-size: 18px; line-height: 26px; font-weight: 500; color: #005fa2; margin-bottom: 10px; font-weight: bold; }
.main02-slide > div > h3 { font-size: 22px; line-height: 30px; font-weight: bold; margin-bottom: 15px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; word-break: normal; overflow: hidden; text-overflow: ellipsis; }
.main02-slide:hover > div > h3 { text-decoration: underline; }
.main02-slide > div > p { font-size: 16px; line-height: 24px; color: #343434; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; word-break: normal; overflow: hidden; text-overflow: ellipsis; }
.main02-slide > p { font-size: 16px; line-height: 24px; color: #878787; display: flex; gap: 8px; justify-content: end; align-items: center; }
/* 3번섹션 */
#main03 { width: 100%; background: url("/fnc_images/main/main03_bg.png") no-repeat left bottom/contain; }
.main03-wrap { width: 100%; max-width: 1360px; padding: 0 30px; margin: 0 auto 100px; }
.main03-wrap .main-subtitle { margin-bottom: 45px; }
.main03-flex { display: flex; justify-content: space-between; gap: 250px; }
.main03-flex-left { flex-shrink: 0; }
.main03-flex-right { width: 100%; display: grid; grid-template-columns: repeat(2, 1fr); column-gap: 30px; row-gap: 50px; }
.main03-flex-right-item { width: 100%; }
.main03-flex-right-item > div { width: 100%; aspect-ratio: 1/1; border-radius: 20px; overflow: hidden; margin-bottom: 15px; }
.main03-flex-right-item > div > img { width: 100%; height: 100%; object-fit: cover; transition: all 0.3s; }
.main03-flex-right-item:hover > div > img { scale: 1.1; }
.main03-flex-right-item > h3 { font-size: 20px; line-height: 28px; font-weight: bold; margin-bottom: 15px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; word-break: normal; overflow: hidden; text-overflow: ellipsis; }
.main03-flex-right-item:hover > h3 { text-decoration: underline; }
.main03-flex-right-item > p { font-size: 16px; line-height: 24px; color: #878787; display: flex; gap: 8px; justify-content: end; align-items: center; }
/* 4번섹션 */
#main04 { width: 100%; height: 360px; background: url("/fnc_images/main/main04_bg.jpg") no-repeat center/cover; }
.main04-wrap { width: 100%; height: 100%; max-width: 1360px; padding: 0 30px; margin: 0 auto; }
.main04-flex { width: 100%; height: 100%; display: flex; align-items: center; justify-content: space-between; color: #fff; }
.main04-flex-left > h3 { font-size: 40px; line-height: 50px; font-weight: bold; letter-spacing: -1px; margin-bottom: 5px; }
.main04-flex-left > p { font-size: 18px; line-height: 26px; font-weight: 500; }
.main04-flex-right { display: flex; align-items: center; gap: 10px; }
.main04-flex-right > a { display: flex; align-items: center; gap: 15px; padding: 0 30px; border-radius: 35px; height: 70px; transition: all 0.3s; }
.main04-flex-right > a > p { font-size: 24px; line-height: 32px; font-weight: bold; transition: all 0.3s; }
.main04-flex-right > a:hover { background-color: rgba(255, 255, 255, 0.3); }
.main04-flex-right > p { font-size: 24px; }
/* 5번섹션 */
/* 6번섹션 */
/* 7번섹션 */

/* 반응형 */
/* @media (max-width: 1439px) { } */
@media (max-width: 1279px){
 .main01-link { gap: 30px; }
 .main03-flex { gap: 100px; }
 .main04-flex-right > a { padding: 0 20px; height: 60px; }
 .main04-flex-right > a > p { font-size: 20px; line-height: 30px; }
 }
@media (max-width: 1023px){
 .main-subtitle > h3 { font-size: 24px; line-height: 32px; }
 .main-link-btn { width: 160px; height: 45px; padding: 0 20px; }
 .main01-swiper { height: 600px; }
 .main01-slide { padding: 130px 15px 0; }
 .main01-slide > p { font-size: 18px; line-height: 26px; }
 .main01-slide > h2 { font-size: 32px; line-height: 40px; }
 .main01-swiper .main01-pagination { bottom: 0; top: 250px; }
 .main01-scroll { display: none; }
 .main01-link { padding: 0 15px; bottom: 50px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 15px; }
 .main01-link > a { flex-direction: row; align-items: center; justify-content: space-between; width: 100%; height: 100px; padding: 15px; }
 .main02-wrap { padding: 0 15px; margin: 50px auto; }
 .main02-bot { width: 100%; }
 .main02-slide { height: 300px; padding: 30px; }
 .main03-wrap { padding: 0 15px; margin: 0 auto 50px; }
 .main03-wrap .main-subtitle { margin-bottom: 20px; }
 .main03-flex-right { column-gap: 20px; row-gap: 30px; }
 .main04-wrap { padding: 0 15px; }
 .main04-flex { flex-direction: column; justify-content: center; align-items: start; gap: 30px; }
 }
@media (max-width: 767px){
 .main-link-btn { width: 150px; height: 40px; padding: 0 15px; font-size: 14px; }
 .main01-swiper { height: 500px; }
 .main01-slide > p { font-size: 16px; line-height: 24px; }
 .main01-slide > h2 { font-size: 24px; line-height: 32px; }
 .main01-link > a { height: 60px; }
 .main01-link > a > p { font-size: 14px; line-height: 22px; }
 .main01-link > a > div { height: 30px; }
 .main02-top-left { gap: 10px; }
 .main02-top { flex-direction: column; align-items: start; gap: 20px; margin-bottom: 30px; }
 .main02-slide { min-height: 200px; height: auto; padding: 20px; gap:20px;}
 .main02-slide > div > h4 { font-size: 16px; line-height: 24px; }
 .main02-slide > div > h3 { font-size: 20px; line-height: 28px; }
 .main02-slide > p { font-size: 14px; }
 #main03 { background: none; }
 .main03-flex { gap: 30px; flex-direction: column; }
 .main03-flex-right-item > h3 { font-size: 18px; line-height: 26px; }
 .main03-flex-right-item > p { font-size: 14px; }
 .main03-flex-right { column-gap: 15px; row-gap: 20px; }
 #main04 { height: 300px; }
 .main04-flex-left > h3 { font-size: 24px; line-height: 32px; }
 .main04-flex-left > p { font-size: 16px; line-height: 24px; }
 .main04-flex-right > a { padding: 0; gap:10px; }
 .main04-flex-right > a:hover { background-color: transparent; }
 .main04-flex-right > a > p { font-size: 16px; line-height: 24px; }
 .main04-flex-right > a > img { width: 40px; }
 }
@media (max-width: 479px){
 .main02-slide > div > h3 { font-size: 18px; line-height: 26px; }
 .main03-flex-right-item > h3 { font-size: 18px; line-height: 26px; }
 }
