/* ---------------------
---------TOP PAGE-------*/
/*FV*/
.main {
    position: relative;
    top: 0;
    right: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10;
}
.main img {
height: auto;
width: 100%;
}
.fv-wrapper{
    overflow-x: hidden;
    position: fixed;
    height: 100vh;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 99;
}
.fv-wrapper.hidden {
  display: none;    /* .hidden クラスが追加されたときに非表示 */
}
.contents-wrapper{
    margin-top: 100vh;
    position: absolute;
    z-index: 99;
    background-color: #edf2f7;
}
.fv-area{
    position: relative;
}
.fv-frame{
    position: absolute;
    z-index: 11;
}
.fv-frame-left{
    top: 0;
    left: 0;
    width: 350px;
}
.fv-frame-right{
    bottom: 0;
    right: 0;
    width: 380px;
}
.fv-title{
    position: absolute;
    z-index: 11;
    width:40vw;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.slider {
    overflow: hidden;
}
.swiper {
    height: 100vh;
    top: 0;
    right: 0;
}
@keyframes zoomUp {
0% {
    transform: scale(1);
}
100% {
    transform: scale(1.05);
}
}
.swiper-img {
transform: scale(1);
transition: transform 8s linear;
will-change: transform;
height: 100vh;
}

.swiper-img.zoom {
transform: scale(1.05);
}
.swiper-slide img {
    height: 100%;
}


/* maquee */
.txtanimation {
    display: flex;
    width: 100%;
    overflow: hidden !important;
}
.txtanimation p {
    font-size: clamp(8rem, 5.333rem + 13.33vw, 22rem);
    line-height: 1;
    letter-spacing: 0;
    flex: 0 0 auto;
    color: #fff;
    font-weight: 600;
}
.txtanimation p:nth-of-type(1) {
    animation: loop_01 60s -30s linear infinite;
}
.txtanimation p:nth-of-type(2) {
    animation: loop_02 60s linear infinite;
}

@keyframes loop_01 {
0% {
    transform: translateX(100%);
}
100% {
    transform: translateX(-100%);
}
}
@keyframes loop_02 {
0% {
    transform: translateX(0);
}
100% {
    transform: translateX(-200%);
}
}

@media (max-width: 1199px) {
    .fv-title{
        width:80vw;
    }
    .fv-frame-left{
        left: 0;
        top: 0;
        width: 200px;
    }
    .fv-frame-right{
        bottom: 0;
        right: 0;
        width: 190px;
    }
    .swiper-slide img {
        object-fit: cover;
        object-position: 88% 0%;
        }
    .contents-wrapper{
    margin-top: 100vh;
}
    }
@media (max-width: 767px) {
    .fv-wrapper{
        height: 100vh;
    }
    
    .contents-wrapper{
        width: 100%;
    }
    .swiper {
    height: 100vh;
    }
}

/* s-about */
.s-about{
    background-image: url(/img/logomark-blur.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position:right 440px;
    background-size: 600px;
}
.s-about .__wrapper{
    overflow: hidden;
}
.s-about .__txt{
    margin-left: 90px;
}

    @media (max-width:1800px){
        .s-about .__txt-title {
            display: block;
        }
        .s-about .__txt-title p{
        margin-left: 0;
        }
    }
    @media (max-width: 1199px) {
        .s-about .__txt{
            margin-left: 40px;
            }
        .s-about .__txt-title h2{
            font-size:clamp(4rem, 3.272rem + 3.64vw, 6rem);
        }
        .s-about{
            background-size: 400px;
        }
    }
    @media screen and (max-width: 991px) {
        .s-about .__txt{
            margin-left: 0;
            padding: 0 40px;
        }
        .__txt-txt {
            width: 100%;
        }
    }
    @media (max-width: 576px){
        .s-about .__txt{
            padding: 0 24px;
        }
    }
/* s-news */
.s-news .__txt-title {
    display: inline-block;
}
.s-news .__txt-title p{
    margin-left: 0;
}
.news-list-wrapper{
    background-color: #fff;
    padding: 40px;
    height: 50vh;
    overflow-y: scroll !important;
}
.news-list-wrapper li{
    border-bottom: 1px solid #e2e2e2;
    display: grid;
}
.news-data{
    font-size: 1.6rem;
    display: inline-block;
    color: #c2c2c2;
}
.news-new-tag{
font-weight: 600;
color: #ff2626;
margin-left: 24px;
}
.news-new-tag {
    display: none;
    }
li:first-of-type .news-new-tag {
display: inline;
}
.link-icon{
    width: 12px;
    height: 12px;
    object-fit: contain;
}
.news-list-wrapper li a{
    transition: all 0.1s ease-in-out;
}
@media (hover: hover) {
.news-list-wrapper li a:hover{
    opacity: 0.4;
}
}

@media screen and (max-width: 991px) {
    .news-txt{
        margin-top: 8px;
    }
    .news-list-wrapper{
        padding: 20px;
    }
    }


/* s-strengths */
.s-strengths{
    background-color: #cdd1d5;
    background-image: url("/img/strength/noise.jpg");
    background-repeat: repeat;
    background-size:cover;
    border-top: 10px solid transparent;
    border-bottom: 10px solid transparent;
    border-image: linear-gradient(90deg, rgba(127, 101, 21, 1), rgba(255, 238, 186, 1));
    border-image-slice: 1;
}
.item{
    background-color: #fff;
    width: 18%;
    padding: 48px 0;
}
.item-img{
    width:100px ;
    height: 120px;
}
.item-img img{
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.item-txt p{
    font-size: 1.6rem;
}
.s-strengths .__txt-sub-title p{
    font-size: 1.6rem;
    color: #181818;
    font-weight: 400;
}
.s-strengths .__txt-title{
    display: inline-block;
}
.s-strengths .__txt-title p{
    margin-left: 0;
}
    @media (max-width: 1199px) {
        .s-strengths .__txt-title h2{
            font-size:clamp(4rem, 3.272rem + 3.64vw, 6rem);
        }
        .item{
            width: 19%;
            padding: 24px 8px;
            }
        .item-img{
            width:76px ;
            height:76px ;
        }
    }
    @media (max-width: 767px) {
        .item{
                width: 160px;
                padding: 24px 8px;
                margin: 4px;
                }
        .s-strengths .group{
            justify-content: center !important;
        }
        .item-img{
            width:60px ;
            height:60px ;
        }
        }
    @media (max-width: 576px) {
        .item{
            width: 100%;
            margin: 4px 0;
        }
    }

/* s-recruit */
.s-recruit{
    background-image: url("/img/aurora.jpg");
    background-repeat: repeat;
    background-size:cover;
}
.s-recruit .__txt{
    margin-left: 90px; 
}
    @media (max-width:1800px){
        .s-recruit .__txt-title {
            display: block;
        }
            .s-recruit .__txt-title p{
            margin-left: 0;
        }
    }
    @media (max-width: 1199px) {
        .s-recruit .__txt{
            margin-left: 40px;
            }
        .s-recruitt .__txt-title h2{
            font-size:clamp(4rem, 3.272rem + 3.64vw, 6rem);
        }
    }
    @media screen and (max-width: 991px) {
        .s-recruit .__txt{
            margin-left: 0;
            padding: 0 40px;
        }
    }
    @media (max-width: 576px){
        .s-recruit .__txt{
            padding: 0 24px;
        }
    }

/* ---------------------
---------p-service-------*/
.p-service .__wrapper .__txt h4{
    font-size: clamp(1.6rem, 0.7rem + 1.2vw, 2.2rem);
    font-weight: 800;
    font-family: "Noto Sans JP", sans-serif;
}
.p-service .__wrapper .__txt{
    padding-left: 60px;
}
.p-service .__wrapper .__txt p{
    font-weight: 400;
}
.p-service .strengths .container .__wrapper{
    background-color: #f4f4f4;
    padding: 40px 60px;
}
.p-service .strengths .__wrapper .item{
    width: 100%;
    background: none;
    padding: 40px 0;
    position: relative;
}
.p-service .strengths .__wrapper .item::after {
    content: "";
    position: absolute;
    width: 80%;
    height: 1px;
    bottom: 0%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: #e4e3e3;
    }
.p-service .strengths .container .__img{
    width: 100px;
}
.p-service .strengths .container .__img img{
    object-fit: contain;
}
.p-service .strengths .__txt .__txt-title{
    font-size: 1.6rem;
    font-weight: 800;
    font-family: "Noto Sans JP", sans-serif;
    color: #3572b7;
    margin-bottom: 10px;
}
.check-icon{
    width: 20px;
    height: 20px;
    margin-right: 10px;
}
.check-icon img{
    object-fit: contain;
}
    @media (max-width: 1199px) {
        .p-service .__wrapper .__txt{
        }
        .p-service .strengths .__wrapper .item .__txt{
            padding-left: 20px;
        }
    }
    @media (max-width: 991px) {
        .p-service .__wrapper .__txt h4{
        font-size: 1.8rem
        }
        .p-service .__wrapper .__txt{
            padding:0;
        }
        .p-service .strengths .container .__img{
            width: 80px;
            margin-right: 20px;
        }
        .p-service .strengths .__wrapper .item{
            padding: 20px 0;
        }
    }
    @media (max-width: 767px) {
        .p-service .strengths .container .__wrapper{
        padding: 30px 20px;
        }
    }
    @media (max-width: 575px) {
        .p-service .strengths .__txt h5{
            justify-content: center !important;
        }
        .p-service .__wrapper .__txt{
            margin-top: 20px;
        }
        .p-service .__wrapper .__txt p{
            text-align: start;
            margin-top: 12px;
        }
        .p-service .strengths .container .__img{
            margin-right: 0;
        }
        .p-service .making-things .three-img .__img{
            padding-left: 0;
            margin-top: 8px;
        }
    }
/* ---------------------
---------p-company-------*/
.greetings .president-name span{
    display: inline-block;
    width: 40%;
}
/* 背景色変化の指定 */
.p-company .panel-wrapper{
    transition: background-color 1s ease;
}
.panel {
    min-height: 100vh;
    display: flex;
    justify-content: space-around;
    align-items: center;
    }
.color-d-gray {
    background-color: #373738;
}
.company .s-title h3,.company .s-title p{
    color: #fff;
}
.company tbody{
    color: #fff;
}
    @media (max-width: 575px) { /* SP時はデフォで背景を暗くする */
    .company{
        background-color: #373738;
    }
    }
.p-company table{
    width: 100% !important;
}
.p-company th, .p-company td {
    border-bottom: 1px solid #5a5a5a;
    padding: 40px 0;
    font-size: 1.6rem;
}
.p-company td{
    padding-left: 40px;
}
.p-company .company{
    padding: 90px 0;
}
.history-wrapper{
    max-width: 1100px;
    margin: 0 auto;
}
.history-wrapper ul{
    padding: 30px 0;
} 
.history-wrapper .month{
    line-height: 1.0;
    width: 36px;
}
.history-wrapper .event{
    margin-left: 20px;
    line-height: 1.0;
}
.history-wrapper .year{
    position: relative;
    
}
.history-wrapper .year p{
    color: #0e2a4a;
    font-weight: 800;   
    font-size: clamp(2rem, 1.7rem + 0.4vw, 2.2rem);
    line-height: 1.0;
}
.history-wrapper .year::after{
    position: absolute;
    content: "";
    width: 12px;
    height: 12px;
    bottom: -20px;
    left: 40px;
    background-color: #d1e2f7;
    border-radius: 50%;
}
.year {
    position: relative; 
}
.line {
    width: 4px;
    height: 0;
    background-color: #d1e2f7;
    position: absolute;
    top: 32px;
    left: 46px;
    transform: translateX(-50%);
    transition: height 8s ease;
    opacity: 0.6;
}
.line.active {
    height: 840px;
}
.map{
    width: 100%;
    height: 60vh;
}
.map iframe{
    width: 100%;
    height: 100%;
}
.access .txt{
    margin-top: 12px;
}
.access .txt .train{
    display: flex;
    align-items: center;
    margin-top: 8px;
}
.access .txt .train h5{
    font-size:clamp(1.6rem, 1.3rem + 0.4vw, 1.8rem);
    font-weight: 800;
}
.access .s-title p{
    color: #0e2a4a;
}
@media (max-width: 767px) {
    .access .txt .train{
    display: block;
    padding: 0;
    }
    .p-company th, .p-company th,.p-company th, .p-company td{
        display: block;
        padding: 0;
        font-size:clamp(1.4rem, 1.257rem + 0.72vw, 1.6rem) ;
    }
    .p-company th, .p-company td{
        border-bottom: unset;
        margin-top: 8px;
    }
    .p-company tr{
        display: block;
        border-bottom: 1px solid #e2e2e2;
        padding: 20px 0;
    }
    .history-wrapper .row{
        display: block !important;
    }
    .history-wrapper .year{
    margin-bottom: 20px;
    width: fit-content;
    }
    .history-wrapper ul{
        padding: 24px 0;
    }
    .history-wrapper .event {
    line-height: 1.0;
    margin-left: 10px;
    width: 80%;
    }
    .history-wrapper .month {
        width: 20%;
    }
    .line.active {
        height: 1180px;
    }
}
    @media (max-width: 576px) {
    .greetings .president-name span {
        width: 70%;
    }
    .line.active {
        height: 1200px;
    }
    @media (max-width: 420px) {
    .line.active {
        height: 1300px;
    }   
    }
    @media (max-width: 376px) {
    .line.active {
        height: 1360px;
    }   
    }
}

/* ---------------------
---------p-recruit-------*/

.p-recruit .works{
    position: relative;
}
.p-recruit .works::after{
    position: absolute;
    content: "";
    background-image: url(/img/p-recruit/bright.svg);
    background-repeat: no-repeat;
    background-size: contain;
    width: 900px;
    height: 900px;
    top: 30px;
    right: -160px;
    opacity: 0.6;
    z-index: 10;
}
.p-recruit .__wrapper .__txt h4 ,.process .title h4{
    font-size: clamp(1.6rem, 0.7rem + 1.2vw, 2.2rem);
    font-weight: 800;
    font-family: "Noto Sans JP", sans-serif;
    position: relative;
    z-index: 11;
}
.p-recruit .__wrapper .__txt h4{
    font-size: 3.6rem;
    line-height: 1.6;
    font-weight: 800;
    font-style: italic;
    font-family: "Noto Sans JP", sans-serif;
    color: transparent;
    background: #6ccdf0;
    background: linear-gradient(90deg,rgba(108, 205, 240, 1) 0%, rgba(24, 100, 222, 1) 100%);
    -webkit-background-clip: text;
    position: relative;
    display: inline-block;
    margin: 20px 0 0 20px;
}
.p-recruit .__wrapper .__txt h4::before{
    position: absolute;
    content: "";
    background-image: url("/img/p-recruit/left.png");
    background-repeat: no-repeat;
    background-size: contain;
    width: clamp(2.4rem, 1.403rem + 2.08vw, 4rem);
    height: clamp(2.4rem, 1.403rem + 2.08vw, 4rem);
    top: -5px;
    left: -50px;
    z-index: 998;
    transform: rotate(4deg);
}
.p-recruit .__wrapper .__txt h4::after{
    position: absolute;
    content: "";
    background-image: url("/img/p-recruit/rihgt.png");
    background-repeat: no-repeat;
    background-size: contain;
    width: clamp(2.4rem, 1.403rem + 2.08vw, 4rem);
    height: clamp(2.4rem, 1.403rem + 2.08vw, 4rem);
    bottom: -5px;
    right: -40px;
    transform: rotate(4deg);
}
.p-recruit .__wrapper .__txt p{
    margin-left: 20px;
}
.p-recruit .merit .three-img .three-img-item{
    width: 32%;
}
.p-recruit .merit .three-img .__img{
width: 100%;
}
.p-recruit .merit .three-img .__txt{
    margin-top: 12px;
}
.p-recruit .merit .three-img .__txt h4{
    font-size: clamp(1.4rem, 1.1rem + 0.4vw, 1.6rem);
    font-weight: 700;
}
.p-recruit .merit .three-img .__txt span{
    font-size:clamp(1.6rem, 1.3rem + 0.4vw, 1.8rem);
    font-weight: 900;
    color: #366baa;
    margin-right: 8px;
}
.p-recruit .merit .three-img .__txt p{
    margin-top: 8px;
}
/* parallax-img */
.bg-center .parallax-img {
height: 80vh;
overflow: hidden;
width: auto;
}
.bg-center .parallax-img img {
height: 120%;
width: 100%;
}
.sp-parallax-img{
    display: none;
}

.recruitment-table-item{
    display: flex;
    border-bottom: 1px solid #e2e2e2;
}
.recruitment-table-item .title{
    flex: 2;
    padding: 40px;
    background-color: #f3f3f3;
    font-weight: 600;
}
.recruitment-table-item .txt{
    flex: 10;
    padding: 40px;
}
.process{
    background-color: #fff;
}
.process .title h4{
    font-size: clamp(1.6rem, 1.3rem + 0.4vw, 1.8rem);
}
.process .three-img .__wrapper{
    position: relative;
    padding: 0 24px;
}
.process .three-img .__wrapper::after{
    position: absolute;
    content: "";
    background-image: url(/img/p-recruit/flow-arrow.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 30px;
    height: 60px;
    top: 30%;
    right: -5%;
}
.process .three-img .__wrapper:last-child::after {
    display: none;
}
.process .three-img .__wrapper .__txt p{
    margin-left: 0;
}

.process .title span{
    background-color: #0e2a4a;
    color: #fff;
    border-radius: 50%;
    padding: 12px;
    margin-right: 12px;
    font-family: "Moderustic", sans-serif;
}
.process .__txt-tel .call{
    width: fit-content;
    font-size: clamp(1.4rem, 1.1rem + 0.4vw, 1.6rem);
    padding: 8px 16px;
    
}
.process .__txt-form{
    background-color:#0e2a4a;
    display: inline-block;
    padding:12px 32px;
    transition: all 0.2s ease-in-out;
}
.process .__txt-form:hover{
    opacity: 0.6;
}
.process .__txt-form p{
    color: #fff;
}
    @media (max-width: 1199px) {
        .recruitment-table-item{
    display: block;
}
        .p-recruit .__wrapper .__txt h4{
            font-size: clamp(2rem, 1.563rem + 2.18vw, 3.2rem);
        }
        .bg-center .parallax-img{
        height: 30vh;
    }
        
    }
    @media (min-width: 576px) and (max-width:767px){
        .tel-form{
            display: flex;
            align-items: center;
        }
        .tel-form .__txt-form{
            margin-left: 10px;
        }
    }
    @media (min-width: 767px) and (max-width:820px){
        .p-recruit .__wrapper .__txt h4::after{
        right: 0;
        }
        
        
    }

    @media (max-width: 767px) {
        .process .three-img .__wrapper{
        padding: 0;
        margin-top: 60px;
    }
    .process .three-img .__wrapper:first-child{
        margin-top: 0;
    }
    .process .three-img .__wrapper::after{
    position: absolute;
    content: "";
    background-image: url(/img/p-recruit/sp-flow-arrow.png);
    background-repeat: no-repeat;
    background-size: contain;
    width: 50px;
    height: 25px;
    top: 106%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 11;
}
    .process .three-img .__wrapper{
        padding: 0;
    }
        .tel-form{
            text-align: center;
            margin-bottom: 20px;
    }
    .process .__txt-tel .call{
        margin: 0 auto;
    }
    .p-recruit .__wrapper .__txt h4{
        margin: 0 30px;
        line-height: 1.6;
    }
    .p-recruit .__wrapper .__txt h4::before{
    top: -4px;
    left: -30px;
    }
    .p-recruit .__wrapper .__txt h4::after{
    bottom: -4px;
    right: -30px;
    }
    .p-recruit .__wrapper .__txt p{
        margin-left: 0;
    }
    .bg-center .parallax-img{
        height: 30vh;
    }
    .p-recruit .works::after{
        width: 400px;
        height: 400px;
        top: unset;
        bottom: -60px;
        right: 0;
        }
}
    @media (max-width: 575px) {
    .three-img .__wrapper{
        margin-top: 80px;
    }
    .recruitment-table-item .title{
    padding: 12px;
    }
    .recruitment-table-item .txt{
    padding: 12px;
    }
    .p-recruit .merit .three-img .three-img-item{
        width: 100%;
        margin-bottom: 40px;
    }
    .p-recruit .merit .three-img .three-img-item:last-child{
        margin-bottom: 0;
    }
    
}

/* ---------------------
---------p-contact-------*/
.p-contact .tel-fax .__wrapper{
    max-width: 1110px;
    margin: 0 auto;
}
.__tel,.__fax{
    background-color: #f5f5f5;
}
.__fax .__fax-num-icon{
    width: 21px;
    margin-right: 4px;
    margin-bottom: 4px;
}
.__tel-num,.__fax-num{
    font-size: clamp(2.8rem, 2.2rem + 0.8vw, 3.2rem);
    font-weight: 600;
    font-family: "Noto Sans JP", sans-serif;
    color:#0e2a4a;
}
/* form */
.required{
    color: #fd2121;
    font-weight: 800;
    border: 1px solid #fd2121;
    line-height: 1.0;
    padding: 0 6px;
    border-radius: 6px;
    font-size: 1.4rem;
    margin-right: 4px;
}
.form-body{
    overflow-x: hidden !important;
}
.pp__wrapper{
    height: 60vh;
    overflow-y:scroll;
    border: 1px solid #ddd;
}
.form-body th{
    font-size:clamp(1.4rem, 1.1rem + 0.4vw, 1.6rem) ;
    font-weight: 500;
    padding: 20px;
    background-color: #f6f6f6;
    border-bottom: 1px solid #fff;
}
.form-body td{
    font-size:clamp(1.4rem, 1.1rem + 0.4vw, 1.6rem) ;
    font-weight: 400;
    padding: 10px 20px;
    border-bottom: none;
}
.form-control{
    font-size: clamp(1.4rem, 1.1rem + 0.4vw, 1.6rem);
    padding: 8px !important;
}
select{
    padding: 8px !important;
}
.form-control::placeholder {
    color: #d8d8d8 !important;
    font-weight: 400 !important;
}
table .required{
    margin-left: 10px;
}
/* pp */
.ttl_policy{
    font-size: clamp(1.4rem, 1.1rem + 0.4vw, 1.6rem);
    font-weight: 800;
    color: #0e2a4a;
}
.lead_policy{
    position: relative;
    padding-bottom: 30px !important;
}
.lead_policy::after{
    content: "";
    position: absolute;
    width: 100%;
    height: 1px;
    bottom: 0%;
    left: 0%;
    background: #ebeef0;
}
.privacyBox p{
    line-height: 1.4 !important;
}
.privacyBox-2nd{
    font-size: clamp(1.2rem, 0.9rem + 0.4vw, 1.4rem);
    margin-left: 20px;
}
.privacyBox-2nd li{
    margin-bottom: 4px;
    line-height: 1.4;
}
.privacyBox p strong{
    display: block;
    margin-bottom: 4px !important;
    font-weight: 600;
}
.information-address p{
    font-size: clamp(1.4rem, 1.1rem + 0.4vw, 1.6rem);
    line-height: 1.4;
}
.agree-txt{
    font-size:clamp(1.4rem, 1.1rem + 0.4vw, 1.6rem);
    margin-left: 8px;
}
.go-back{
    background-color: #e9e9e9;
    border: none;
    color: #000000;
    transition: all 0.2s ease-in-out;
}
.go-back:hover {
    background-color: #a8a8a8;
}
.go-back:hover .btn-text{
color: #000;
}
.go-back:hover::before {
    animation: unset;
}
    @media (max-width: 767px) {
        .form-body th{
            padding: 12px;
        }
    .form-body td{
        padding: 10px 4px;
    }
    .privacyBox-2nd{
        font-size: clamp(1.2rem, 1.057rem + 0.72vw, 1.4rem);
        margin-left: 12px;
    }
    .privacyBox-2nd li{
        margin-bottom: 8px !important;
        line-height: 1.6 !important;
    }
}