<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">@charset "utf-8";

/*---------------------------------------------------------
	Top　スクロールエフェクト
---------------------------------------------------------*/


/*.fill_wrap {
    position: relative;
}

.fill_over {
    position: absolute;
    z-index: 10;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    pointer-events: none;

}

.fill_over.hide_ttl {
    left: -40px;
    width: calc(100% + 40px);
}

.fill_over::before {
    content: "";
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 15;
    background: #FFF;
    transform: translateX(0px);
    transform-origin: left center 0;
    transition: transform 0.5s cubic-bezier(0.55, 0.085, 0.68, 0.53) 0.3s;

}

.delay .fill_over::before {
    transition-delay: 1.3s;
}

.on .fill_over::before {
    transform: translateX(101%);
}

.fill_over::after {
    content: "";
    display: block;
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 15;
    background-color: rgb(65, 105, 225);
    background-image: linear-gradient(90deg, rgba(65, 105, 225, 1) 0%, rgba(75, 193, 203, 1) 100%);
    background-position: left center;
    background-size: 200% 100%;
    background-repeat: no-repeat;
    transform: scaleX(0) translateX(0px);
    transform-origin: left center 0;
    transition: transform 1s cubic-bezier(0.55, 0.085, 0.68, 0.53) 0s;
}

.delay .fill_over::after {
    transition-delay: 1.0s;
}

.on .fill_over::after {
    transform: scaleX(1) translateX(101%);
}*/

/*.inview.vertical {
    opacity: 0;
    transform: translateY(50px);
    transition: all 1s cubic-bezier(.3, .1, .3, 1);
}

.inview.vertical.on {
    opacity: 1;
    transform: translateY(0);
}

.inview.vertical.on.img_1 {
    transition-delay: 1.5s;
}

.inview.vertical.on.img_2 {
    transition-delay: 1.3s;
}

.inview.vertical.on.img_3 {
    transition-delay: 1.6s;
}

.inview.vertical.on.img_4 {
    transition-delay: 0.4s;
}

.inview.vertical.on.img_5 {
    transition-delay: 0.7s;
}

.inview.vertical.on.img_6 {
    transition-delay: 0.2s;
}*/





/*---------------------------------------------------------
	Top
---------------------------------------------------------*/
.index_bg {
    background: url(../img/index_main_bg.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
    width: 100%;
    height: 100%;
    margin-top: 90px;
}

#index_wrap {
    position: relative;
    width: 100%;
    padding-top: 355px;
    padding-bottom: 40px;

}


#index_wrap.on::before {
    /*transform: translateX(0);
	transition: transform 0.5s cubic-bezier(0.55, 0.085, 0.68, 0.53) 0s;*/
}



#index_main {
    position: relative;
    max-width: 1920px;
    margin: 0 auto;
}

#index_main img {
    display: block;
    max-width: 100%;
    /*width: 100%;
	height: 963px;
	object-fit: cover;
	max-height: calc(100vh - 100px);*/
}


#top_h1 {
    font-family: Cambria, 'Noto Serif JP', serif;
    position: absolute;
    right: 11%;
    bottom: 22%;
    /*max-width: 100%;
	padding: 0 20px;*/
    color: #fff;
}

#top_h1 h1 {
    font-size: 7.2rem;
    letter-spacing: 0;
    color: #fff;
    line-height: 1.45;
    font-weight: 500;
    margin-bottom: 35px;
}

#top_h1 span {
    font-size: 2.0rem;
    letter-spacing: 0;
    margin-left: 7%;
}

#top_h1 ruby&gt;rt {
    font-size: 1.9rem;
}

#top_h1 p{
	margin-top: 10pt;    
	margin-left: 7%;
}

.top_ttl {
    position: relative;
    display: inline-block;
    margin-bottom: 30px;
}

.top_ttl h2 {
    font-size: 3.0rem;
    font-weight: 500;
    letter-spacing: 0;
    margin-top: 15px;
}

.top_ttl span {
    display: inline-block;
    font-family: 'Montserrat', sans-serif;
    font-size: 3.0rem;
    line-height: 1.3;
    letter-spacing: 0.05em;
    font-weight: 500;
    color: #245499;
    position: relative;
}

.top_ttl span:before {
    content: "";
    position: absolute;
    width: 46px;
    height: 1px;
    top: 50%;
    left: -60px;
    background: #245499;
}

.top_link_btn a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 220px;
    height: 100%;
    padding: 20px;
    font-family: 'Montserrat', sans-serif;
    font-size: 1.4rem;
    /*font-weight: bold;*/
    color: #245499;
    border: 1px solid #245499;
    background-color: #FFF;
    cursor: pointer;
    text-decoration: none;
    transition: all .3s ease;
    position: relative;
}

.top_link_btn a:after {
    content: "";
    position: absolute;
    background: url(../img/arrow_r_n.svg);
    background-repeat: no-repeat;
    background-size: cover;
    width: 39px;
    height: 7px;
    top: calc(50% - 3.5px);
    right: 15px;
    /*transition: all .3s ease;*/
}

.top_link_btn a:hover {
    background-color: #245499;
    color: #FFF;
}

.top_link_btn a:hover:after {
    background: url(../img/arrow_r_w.svg);
}

.top_link_btn span {
    margin-right: 30px;
}


.index_bg_2 {
    background: url(../img/index_bg_02.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top center;
    width: 100%;
    height: 100%;
    z-index: -1;
}

/*----------------
	news
--------------------*/
#index_news {
    padding: 100px 0 0 0;
}

.news_wrap {
    max-width: 1360px;
    margin: 0 auto;
    padding: 0 20px;
}

.news_inner {
    width: 50%;
}

#index_news .top_ttl span {
    color: #fff;
}

#index_news .top_ttl span:before {
    background: #fff;
}

#index_news ul li {
    border-bottom: 1px solid #fff;
}

#index_news .news_item a {
    position: relative;
    display: block;
    padding: 15px 70px 8px 0;
    color: #fff;
    text-decoration: none;
}

#index_news .news_item a:after {
    content: "";
    position: absolute;
    background: url(../img/arrow_r_w.svg);
    background-repeat: no-repeat;
    background-size: cover;
    width: 39px;
    height: 7px;
    top: calc(50% - 3.5px);
    right: 15px;
    transition: all .3s ease;
}

#index_news .news_item a:hover:after {
    right: 5px;
}

.news_date {
    margin-right: 25px;
}

.news_cate {
    margin-right: 25px;
}

.news_inner .top_link_btn {
    margin-top: 40px;
}

.news_inner .top_link_btn a {
    border: 1px solid #fff;
}

.news_inner .top_link_btn a:hover {
    border: 1px solid #245499;
}

/*----------------
	copy
--------------------*/
#index_copy {
    color: #fff;
}

.copy_area {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    max-width: 1360px;
    margin: 0 auto;
    padding: 0 20px 125px 20px;
}

.copy_txt {
    width: 50%;
    max-width: 659px;
    padding-top: 90px;
    padding-bottom: 20px;
    letter-spacing: 0;
}

.copy_main {
    font-size: 4.0rem;
    font-weight: 500;
    letter-spacing: 0;
    margin-bottom: 25px;
}

/* .copy_sub{
	font-size:2.5rem;
	line-height:2.0;
	letter-spacing:0;
	margin-bottom:20px;
} */

.copy_img {
    position: absolute;
    display: flex;
    width: 57.6%;
    left: 53.7%;
}

.copy_img&gt;div {
    width: 33.333333%;
}

.copy_img&gt;div:first-child {
    margin-top: 55px;
}

.copy_img&gt;div:last-child {
    margin-top: 110px;
}

.copy_img img {
    width: 100%;
}



/*----------------
	corporate_info
--------------------*/
#index_corporate_info {
    position: relative;
    padding: 140px 0 90px 0;
}

.corporate_info_inner {
    max-width: 1360px;
    margin: 0 auto;
    padding: 0 20px;
}

.corporate_info_txt {
    width: 47%;
}

#index_corporate_info .top_link_btn {
    margin-top: 30px;
}


/*----------------
	business
--------------------*/
#index_business {
    position: relative;
    padding-top: 110px;
    padding-bottom: 145px;
    z-index: 1;
}

.business_inner {
    max-width: 1360px;
    margin: 0 auto;
    padding: 0 20px;
}

.business_link {
    /*     width: calc(600px + 50vw); */
    display: flex;
}

.business_item {
    position: relative;
    width: 49%;
    margin-right: 2%;
    overflow: hidden;
}

.business_item:last-child {
    margin-right: 0;
}

.business_item:first-child:after {
    content: "";
    position: absolute;
    background: url(../img/index_business_1.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: block;
    z-index: -1;
}

.business_item:nth-child(2):after {
    content: "";
    position: absolute;
    background: url(../img/index_business_2.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: block;
    z-index: -1;
}

/* .business_item:last-child:after {
    content: "";
    position: absolute;
    background: url(../img/index_business_3.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: block;
    z-index: -1;
} */

.business_item:after {
    -webkit-transition: -webkit-transform 0.8s ease;
    transition: -webkit-transform 0.8s ease;
    transition: transform 0.8s ease;
    transition: transform 0.8s ease, -webkit-transform 0.8s ease;
}

.business_item:hover:after {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
}

.business_item a {
    position: relative;
    display: flex;
    align-items: flex-end;
    height: 395px;
    color: #fff;
    text-decoration: none;
}

.business_txt {
    display: block;
    width: 100%;
    padding: 0 30px 40px 30px;
}

.business_txt h3 {
    font-size: 3.0rem;
    line-height: 1.5;
}

.business_txt span {
    display: inline-block;
    font-family: 'Montserrat', sans-serif;
    font-weight: 500;
    font-size: 1.8rem;
    margin-bottom: 15px;
}

/*----------------
	recruit
--------------------*/
#index_recruit {
    position: relative;
    padding-top: 140px;
}

#index_recruit:after {
    content: "";
    position: absolute;
    width: 100%;
    height: 603px;
    top: 0;
    left: 0;
    right: 0;
    background: url(../img/index_recruit_bg.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    z-index: -1;
}

.recruit_inner {
    max-width: 1360px;
    margin: 0 auto;
    padding: 0 20px;
    color: #fff;
}

#index_recruit .top_link_btn {
    margin-top: 20px;
}

#index_recruit .top_ttl span {
    color: #fff;
}

#index_recruit .top_ttl span:before {
    background: #fff;
}

#index_recruit .top_ttl h2 {
    color: #fff;
}

.recruit_img_area {
    /*position:absolute;*/
    width: 100vw;
    display: flex;
    margin-top: 45px;
}

.recruit_img {
    position: relative;
    margin-right: 1.5%;
    overflow: hidden;
}

.recruit_img img {
    width: 100%;
}

/*----------------
	contact
--------------------*/
/* #index_contact {
    position: relative;
    color: #fff;
    padding: 0 0 140px 0;
} */

#cta:after {
    /*     content: ""; */
    /*     position: absolute; */
    /*     background: url(../img/index_contact_bg.jpg); */
    /*     background-repeat: no-repeat; */
    /*     background-size: cover; */
    /*     background-position: center; */
    /*     z-index: -2; */
    top: -260px;
    /*     left: 0; */
    /*     right: 0; */
    /*     width: 100%; */
    height: calc(100% + 260px);
}

/* .contact_inner {
    max-width: 1360px;
    margin: 0 auto;
    padding: 100px 20px 0 20px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-end;
}

#index_contact .top_ttl {
    margin-bottom: 15px;
}

#index_contact .top_ttl span {
    color: #fff;
}

#index_contact .top_ttl span:before {
    background: #fff;
}

.contact_txt {
    width: 30%;
}

.contact_tel {
    width: 30%;
    text-align: center;
}

.contact_tel .tel_txt a {
    font-family: "oswald", sans-serif;
    font-size: 3.0rem;
    text-decoration: none;
    color: #fff !important;
}

.contact_tel .tel_txt a span {
    font-size: 2.4rem;
}

.contact_btn {
    width: 30%;
}

.top_contact_btn a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width: 300px;
    height: 100%;
    margin: 0 auto;
    padding: 30px;
    font-size: 1.4rem;
    font-weight: bold;
    color: #fff;
    border: 1px solid #fff;
    background: transparent;
    cursor: pointer;
    text-decoration: none;
    transition: all .3s ease;
}

.top_contact_btn a:hover {
    color: #245499;
    background: #fff;
} */

/*----------------
	bg_img
--------------------*/
.index_bg_area {
    width: 100%;
    height: 490px;
    background: url(../img/index_bg_img.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

@media screen and (max-width:1550px) {
    .index_bg {
        background: url(../img/index_main_bg_sp.png);
        background-repeat: no-repeat;
        background-size: cover;
        background-position: top center;
        margin-top: 0;
    }
}


@media (max-width: 1024px) {

    /*----------------
		copy
		--------------------*/
    .copy_img {
        position: static;
        width: 100%;
    }

    /*----------------
		business
		--------------------*/
    .business_link {
        flex-wrap: wrap;
    }

    .business_link {
        width: 100%;
    }

    .business_item {
        width: 100%;
        margin-right: 0;
        margin-bottom: 20px;
    }

    .business_item a {
        height: auto;
        min-height: 250px;
    }

}


@media screen and (max-width:767px) {

    /*---------------------------------------------------------
		Top　スクロールエフェクト
	---------------------------------------------------------*/
    .fill_over.hide_ttl {
        left: 0;
        width: 100%;
    }

    /*  */


    #top_h1 {
        position: static;
        text-align: right;
        padding: 0 20px 30px;
    }

    #top_h1 h1 {
        font-size: 8.4vw;
        margin-bottom: 20px;
    }

    #top_h1 span {
        font-size: 1.4rem;
        margin-left: auto;
    }
	#top_h1 p {
		margin-left:initial;
		text-align:left;
	}
	
	#top_h1 ruby&gt;rt {
		font-size: 0.9rem;
	}

    #index_wrap {
        margin-top: 65px;
        padding: 50px 0 30px 0;
    }

    #index_wrap::before {
        width: calc(100% - 80px);
    }

    #index_main {
        padding-top: 90px;
        /* 		top: 30px; */
    }

    #index_main img {
        /*height: calc(100vh - 65px) !important;
		object-fit: cover;
		max-height: 750px !important;*/
        min-height: 180px;
        object-fit: cover;
    }

    .top_ttl {
        margin-bottom: 20px;
    }

    .top_ttl h2 {
        font-size: 2.0rem;
        margin-top: 8px;
    }

    .top_ttl span {
        font-size: 2.2rem;
        padding-left: 10px;
    }

    .top_ttl span:before {
        width: 15px;
        left: -15px;
    }

    .top_link_btn a {
        max-width: 100%;
        margin: 0 auto;
        padding: 15px 0;
    }

    /*     .index_bg {
        background: url(../img/index_main_bg_sp.png);
        background-repeat: no-repeat;
        background-size: cover;
        background-position: top center;
        margin-top: 0;
    } */

    .index_bg_area {
        height: 200px;
    }

    /*----------------
		news
	--------------------*/
    #index_news {
        padding-top: 30px;
    }

    .news_inner {
        width: 100%;
    }

    .news_title {
        display: block;
    }

    #index_news .news_item a {
        padding: 10px 70px 10px 0;
    }

    .news_inner .top_link_btn {
        margin-top: 25px;
    }

    /*----------------
		copy
	--------------------*/
    .copy_txt {
        width: 100%;
        padding-top: 50px;
        padding-bottom: 0;
    }

    .copy_area {
        padding: 0 20px 50px 20px;
    }

    .copy_main {
        font-size: 2.5rem;
        margin-bottom: 15px;
    }

    /* 	.copy_sub{
		font-size:1.8rem;
		margin-bottom:10px;
	} */
    .copy_img {
        margin-top: 30px;
    }

    .copy_img&gt;div:first-child {
        margin-top: 6vw;
    }

    .copy_img&gt;div:last-child {
        margin-top: 12vw;
    }

    /*----------------
		corporate
	--------------------*/
    #index_corporate_info {
        padding: 60px 0 40px 0;
    }

    .corporate_info_txt {
        width: 100%;
    }

    #index_corporate_info .top_link_btn {
        margin-top: 25px;
    }

    /*----------------
		business
	--------------------*/
    #index_business {
        padding-top: 50px;
        padding-bottom: 70px;
    }

    .business_txt {
        padding: 40px 20px 20px 20px;
    }

    .business_txt h3 {
        font-size: 2.0rem;
    }

    .business_txt span {
        font-size: 1.4rem;
        margin-bottom: 15px;
    }

    /*----------------
		recruit
	--------------------*/
    #index_recruit {
        padding-top: 70px;
    }

    #index_recruit:after {
        height: 380px;
    }

    .recruit_img_area {
        /*flex-wrap:wrap;*/
        width: 100%;
    }

    /*----------------
		contact
	--------------------*/
    /*     #index_contact {
        padding-bottom: 70px;
    } */

    #cta:after {
        top: -101px;
        height: calc(100% + 101px);
    }

    /*     .contact_inner {
        padding: 50px 20px 0 20px;
    }

    .contact_txt {
        width: 100%;
    }

    .contact_tel {
        width: 100%;
        text-align: left;
        margin-top: 20px;
    }

    .contact_btn {
        width: 100%;
    }

    .top_contact_btn a {
        max-width: 100%;
        padding: 15px 0;
        margin: 30px auto 0 auto;
    } */

}</pre></body></html>