/* swiper */
.swiper-sec { padding: 0rem 0; position: relative;}
.swiper-sec .front-lead-text { position: absolute; top: 8em; left: 1em; text-shadow: 0 2px 4px rgba(255, 255, 255, 0.2);  z-index: 2;}
.swiper-sec .front-lead-text p { font-size: clamp( 2.5em, 4vw, 4em); font-weight: bold; line-height: normal;}
.swiper-sec .front-lead-text span { font-size: clamp( 1.4em, 2vw, 1.6em); font-weight: 500; line-height: 2;}
.swiper-sec .front-lead-text .tablet { display: none;}

@media screen and (max-width: 1300px) {
    .swiper-sec .front-lead-text .tablet { display: block;}
}

@media screen and (max-width: 1080px) {
    .swiper-sec .front-lead-text { top: 5em; left: 1em;}
}
@media only screen and (max-width:468px) {
    .swiper-sec .front-lead-text { top: 3.5em; left: 1em;}
}

.swiper-sec .catch { font-family: var(--oswald); position: absolute; bottom: 1em; left: 1em; z-index: 1; line-height: 1;}
.swiper-sec .catch p { font-size: clamp(3.5em, 8vw, 11em); letter-spacing: 0.02em; color: #fff; opacity: 0.7;}


.swiper-wrap { width: 100%; margin-left: auto; padding-left: 70px;}
.swiper-wrap .swiper-wrapper { margin-top: 5em; height: unset;}
.front-page-swiper{ width: 100%; background-image: url('../images/front-page/swiper-image.jpg'); background-size: cover; background-position: center; position: relative;}
.swiper-slide { display: flex; align-items: center; justify-content: center;}
.swiper-slide img {  max-width: 600px; width: 100%; margin-left: auto; margin-right: 0%;}


@media screen and (max-width: 1080px) {
    .swiper-wrap { padding-left: 2.5em;}
    .swiper-wrap .swiper-wrapper { margin-top: 16em;}
}

/* lead-sec */
.lead-sec { position: relative; background: linear-gradient(270deg, #22c75b, #21c06f, #1eb495); animation: flowGradient 5s ease infinite;padding: 10em 0px; top: -5em;}  
@keyframes flowGradient { 0% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } 100% { background-position: 0% 50%; }}
.lead-sec::before { content: ""; position: absolute; background: url(../images/front-page/lead-sec_01.png) no-repeat; z-index: 0; width: 650px; height: 650px; right: 0px; background-size: contain; top: -5em;}  
.lead-sec > * { position: relative; z-index: 1;}  
.lead-sec .inner { color: #fff;}  

@media screen and (max-width: 1400px) {
    .lead-sec .inner { margin-left: 70px;}  
}

@media screen and (max-width: 1080px) {
    .lead-sec .inner { padding-left: 30px; margin: 0 auto;}  
    .lead-sec::before { bottom: 300px; top: unset; width: 100%; height: 100%; background-size: contain; background-position: bottom;}
}


.lead-sec .flex { gap: 2em;}
/* left */
.lead-sec .flex .left { flex: 1;}
.lead-sec .flex .left .text-area { max-width: 600px;}
.lead-sec .flex .left .text-area h2 { font-size: clamp(24px, 4vw, 32px);}
.lead-sec .flex .left .text-area p { font-size: clamp(1em, 4vw, 1.2em);}

/* right */
.lead-sec .flex .right { flex: 1;}
.lead-sec .flex .right .member-image { position: relative; bottom: -15em;}

@media screen and (max-width: 1080px) {
    .lead-sec { padding: 8em 0px 0em;}
    .lead-sec .flex { flex-direction: column; }
    .lead-sec .flex .right .member-image { bottom: -2em;}
}

/* service-sec */
.back-ground-pink { padding: 0px 0px 5em;}
.back-ground-pink::after {  content: ""; position: absolute; top: -15em; right: 0%; width: calc(100%); height: 30em; background: var(--pink-linear); background-repeat: no-repeat; background-size: cover; background-position: center; z-index: -2;}  
.service-sec .service-list { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1.5em; margin-top: 3em;}

@media screen and (max-width: 1080px) {
.back-ground-pink::after { top: -5em; height: 20em;}
.service-sec .service-list { grid-template-columns: repeat(3, 1fr);}
}

@media only screen and (max-width:468px) {
    .service-sec .service-list { grid-template-columns: repeat(2, 1fr);}
}


/* recruit-sec */
.recruit-sec { position: relative;}  
.recruit-sec::after { content: ""; bottom: 5em; right: 0%; width: calc(100% - 5em); height: 65%; background-image: url(../images/front-page/recruit-sec_02.png); background-repeat: no-repeat; background-size: cover; background-position: center; z-index: -1; position: absolute;}  
.recruit-sec .inner { } 

.lead-text { display: flex; width: fit-content; margin-left: auto; position: absolute; right: 0px; top: -5em; z-index: 9;}
.lead-text p { height: fit-content; color: #fff; font-size: clamp(16px, 4vw, 2.8em); font-weight: bold; padding: 0.3em 0.1em;}
.member { width: 85%; position: relative; z-index: 1;}

/* recruit-entry-sec */
.recruit-entry-sec { background-image: linear-gradient(rgba(34, 199, 91, 0.4), rgba(30, 180, 149, 0.4)), url(../images/front-page/recruit-entry-sec.jpg); background-repeat: no-repeat; background-size: cover; background-position: center;}
.recruit-entry-sec .wrap { display: flex; justify-content: space-between; gap: 1.5em; background-color: #fff; padding: 5em 2em;}
@media only screen and (max-width:468px) {
    .recruit-entry-sec .wrap { flex-direction: column;}
}

/* .topics-sec */
.topics-sec .flex { gap: 1.5em;}
.topics-sec .flex .left { flex: 1;}
.topics-sec .flex .right { flex: 2;}

@media screen and (max-width: 1080px) {
    .topics-sec .flex {  flex-direction: column;}
}

.news-list {}
.news-list li { border-bottom: 1px solid #D6D6D6; font-size: 1.1em; padding: 1em 0px;}
.news-list li:nth-of-type(1) { border-top: 1px solid #D6D6D6;}
.news-list li a { display: flex; gap: 1em;}
.news-list li .date { color: var(--green);}
.news-list li .text { color: #0F4B67;}


/* scroll_down */
.scroll_down{  position: absolute; left: 35px; bottom: 120px;}
.scroll_down p{  position: absolute; left: -8px; bottom: 116px; font-size: 13px; letter-spacing: 1px; font-weight: bold; writing-mode: sideways-lr; text-decoration: none; text-transform: uppercase;}
.scroll_down:before { content: ""; position: absolute; bottom: 0; left: -5px; width: 11px; height: 11px; border-radius: 50%; background:#000; animation: circlemove 1.6s ease-in-out infinite, cirlemovehide 1.6s ease-out infinite;}
@keyframes circlemove{ 0%{bottom:100px;} 100%{bottom:0px;}}
@keyframes cirlemovehide{ 0%{opacity:0} 50%{opacity:1;} 80%{opacity:0.9;} 100%{opacity:0;}}
.scroll_down:after{ content:""; position: absolute; bottom:0; left:0; width:2px; height: 100px; background:#000;}


@media screen and (max-width: 1080px) {
    .scroll_down {left: 1.2em;}
}