/* main common */
.maintit { padding-bottom: 40px; text-align: center; }
.maintit .tit1 { font-weight: 700; font-size: 45px; color: #3e3e3e; line-height: 1.4; letter-spacing: 0.01em; }
.maintit .tit2 { margin-top: 3px; font-size: 18px; color: #7f7f7f; line-height: 1.4; letter-spacing: 0.01em; }

/* main_visual */
#main_visual { position: relative; height:  800px; max-height: 100vh; overflow: hidden; }
#main_visual .mv_wrap { position: relative; height: 100%; }
#main_visual .mv_text { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
#main_visual .mv_text .contwrap { height: 100%; }
#main_visual .mv_text .textbox { z-index: 2;  position: relative; top: 55%; transform: translateY(-50%); text-align: left; }
#main_visual .mv_text .textbox .text1 { font-weight: 700; font-size: 60px; color: #fff; line-height: 1.3; }
#main_visual .mv_text .textbox .text2 { margin-top: 20px; font-size: 26px; color: #fff; line-height: 1.53; }
#main_visual .mv_text .textbox a { display: inline-block; margin-top: 35px; padding: 12px 37px; text-align: center; font-weight: 500; font-size: 22px; color: #fff; border: 1px solid #fff; border-radius: 100px; transition: background-color 0.3s, color 0.3s; }
#main_visual .mv_text .textbox a:hover { background-color: #fff; color: #333; }
#main_visual .mv_slick { z-index: 1; position: relative; height: 100%; }
#main_visual .mv_slick .slick-list, #main_visual .mv_slick .slick-track, #main_visual .mv_slick .slick-slide, #main_visual .mv_slick .slick-slide > div { height: 100%; }
#main_visual .mv_slick .con { position: relative; height: 100%; }
#main_visual .mv_slick .con .bg { z-index: 1; position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
#main_visual .mv_slick .slick-current .bg { animation: mv_bg forwards linear 3s; }
@keyframes mv_bg { 
    0% { transform: scale(1.1); }
    100% { transform: scale(1); }
}
#main_visual .mv_slick .con1 .bg { background: url(/image/main/mv_bg1.jpg) no-repeat center/cover; }
#main_visual .mv_slick .con2 .bg { background: url(/image/main/mv_bg2.jpg) no-repeat center/cover; }
#main_visual .mv_slick .con3 .bg { background: url(/image/main/mv_bg3.jpg) no-repeat center/cover; }
#main_visual .mv_slick .con .frame { z-index: 2; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background-color: rgba(0, 0, 0, 0.5); }
#main_visual .slick-dots { z-index: 10; position: absolute; left: 50%; transform: translateX(-50%); bottom: 30px; display: flex; flex-wrap: nowrap; }
#main_visual .slick-dots li { width: 10px; height: 10px; border-radius: 50%; background-color: #626262; margin: 0 6px; cursor: pointer; }
#main_visual .slick-dots li button { display: none; }
#main_visual .slick-dots li.slick-active { background-color: #fff; }
@media (max-width: 1535px) {
    #main_visual { height: calc(470px + 20vw); }
}
@media (max-width: 1279px) {
    #main_visual { height: calc(350px + 17vw); }
}
@media (max-width: 1023px) {
    #main_visual { height: calc(300px + 15vw); }
    #main_visual .slick-dots { bottom: 20px; }
    #main_visual .slick-dots li { width: 8px; height: 8px; }
}
@media (max-width: 767px) {
    #main_visual .mv_text .textbox .text2 br { display: none; }
    #main_visual .mv_text .textbox a { font-weight: normal; }
}

/* mainCompany */
#mainCompany { position: relative; padding: 80px 0; overflow: hidden; }
#mainCompany .contents { margin: -20px; font-weight: 700; font-size: 20px; color: #89a150; line-height: inherit; }
#mainCompany .contents * { font-weight: inherit; font-size: inherit; color: inherit; line-height: 1.3; }
#mainCompany .contents ul { display: flex; flex-wrap: nowrap; justify-content: space-between; margin: 0 auto; text-align: center; }
#mainCompany .contents ul li { padding: 20px; }
#mainCompany .contents ul li a { display: block; }
#mainCompany .contents ul li a .iconbox img { display: inline-block; width: 100%; transition: filter 0.3s; }
#mainCompany .contents ul li a:hover .iconbox img { filter: brightness(1.1); }
#mainCompany .contents ul li a .txtbox { margin-top: 15px; }
@media (max-width: 1535px) {
    #mainCompany .contents ul li a .txtbox { margin-top: 13px; }
}
@media (max-width: 1279px) {
    #mainCompany .contents { margin: -15px; }
    #mainCompany .contents ul li { padding: 15px; }
}
@media (max-width: 767px) {
    #mainCompany .contents {  font-weight: 500; margin: initial; }
    #mainCompany .contents ul { max-width: 450px; flex-wrap: wrap; }
    #mainCompany .contents ul li { padding: initial; width: 47%; }
    #mainCompany .contents ul li:nth-of-type(n + 3) { margin-top: 6%; }
}

/* mainNews */
#mainNews { position: relative; padding: 90px 0; overflow: hidden; }
#mainNews .bg { z-index: 1; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: url(/image/main/news_bg.jpg) no-repeat center/cover; }
#mainNews .contwrap { z-index: 2; }
#mainNews .morebtn { margin-top: 40px; text-align: center; }
#mainNews .morebtn a { display: inline-block; padding: 12px 34px; font-size: 18px; color: #000; letter-spacing: 0.01em; border: 1px solid #000; border-radius: 100px; transition: background-color 0.3s, color 0.3s; }
#mainNews .morebtn a:hover { background-color: #000; color: #fff; }
@media (max-width: 1023px) {
    #mainNews .bg { background-position-x: 0; }
}

/* mainContact */
#mainContact { position: relative; overflow: hidden; background-color: #f7f7f7; }
#mainContact .contents { position: relative; padding: 90px 0; display: flex; flex-wrap: nowrap; }
#mainContact .contents li:first-of-type { width: 45%; }
#mainContact .contents li:last-of-type { width: 55%; padding-left: 25px; }
#mainContact .img1 { z-index: 1; position: absolute; left: 0; bottom: 0; max-width: 45%; /* width: 600px; */ }

#mainContact dl { display: flex; flex-wrap: nowrap; align-items: end; width: 100%; }
#mainContact dl dt { width: 100%; }
#mainContact dl dt .textbox img { display: inline-block; width: 100px; }
#mainContact dl dt .textbox .text1 { margin-top: 5px; font-weight: 700; font-size: 32px; color: #e0644f; line-height: 1.52; }
#mainContact dl dt .textbox .text2 { font-size: 18px; color: #434343; line-height: 1.52; }
#mainContact dl dt .textbox .text3 { margin-top: 30px; display: flex; flex-wrap: nowrap; font-weight: 500; font-size: 18px; color: #fff; }
#mainContact dl dt .textbox .text3 * { font-weight: inherit; font-size: inherit !important; color: inherit; }
#mainContact dl dt .textbox .text3 a { display: inline-block; text-align: center; margin-right: 7px; padding: 13px 5px; width: 210px; border: 2px solid #7d983c; border-radius: 100px; transition: background-color 0.3s, color 0.3s; }
#mainContact dl dt .textbox .text3 a:first-of-type { background-color: #7d983c; color: #fff; }
/* #mainContact dl dt .textbox .text3 a:last-of-type { background-color: transparent; color: #7d983c; } */
#mainContact dl dd { margin-left: 20px; min-width: max-content; }
#mainContact dl dd img { width: 170px; }

@media (max-width: 1535px) {
    #mainContact .contents { padding: 80px 0; }
    #mainContact dl dt .textbox img { width: calc(60px + 2.5vw); }
    #mainContact dl dt .textbox .text3 { margin-top: 25px; }
    #mainContact dl dt .textbox .text3 a { width: 190px; }
    #mainContact dl dd { margin-left: 15px; }
    #mainContact dl dd img { width: calc(100px + 4.2vw); }
}
@media (max-width: 1279px) {
    #mainContact .contents { padding: 50px 0; }
    #mainContact dl dt .textbox img { width: calc(50px + 2vw); }
    #mainContact dl dt .textbox .text3 { margin-top: 20px; }
    #mainContact dl dt .textbox .text3 a { width: 160px; }
    #mainContact dl dd { margin-left: 10px; }
    #mainContact dl dd img { width: calc(80px + 2vw); }
}
@media (max-width: 1023px) {
    #mainContact .contents { padding: 40px 0 0; flex-wrap: wrap; flex-direction: column-reverse; }
    #mainContact .contents li:first-of-type { width: 100%; text-align: center; margin-top: 20px; }
    #mainContact .contents li:last-of-type { width: 100%; padding-left: initial; }
    #mainContact .img1 { position: relative; left: initial; bottom: initial; width: 100%; max-width: 300px; }
}
@media (max-width: 624px) {
    #mainContact .contents { padding: 30px 0 0; }
    #mainContact dl { display: block; text-align: center; }
    #mainContact dl dt .textbox .text3 { justify-content: center; }
    #mainContact dl dd { margin-left: initial; min-width: initial; margin-top: 15px; }
}