/*!
Theme Name: building
Theme URI: http://underscores.me/
Author: Underscores.me
Author URI: http://underscores.me/
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: building
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

building is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

@charset "utf-8";

/* kv
   ================================================================== */
.kv{
	margin: 0 0 0;
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100%;
}

.kv::after{
	content: "";
    background-image: url("/wp-content/themes/building/img/dot_bg.png");
    background-position: 0 0;
    background-repeat: repeat;
    background-size: auto;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.kv .inner{
	padding: 0 5vw 65%;
	display: flex;
	box-sizing: border-box;
	align-items: flex-end;
	height: calc(100vh - 10vw);
    max-width: 100%;
    max-height: 1000px;
}

.kv .inbox{
	margin: 0 0 0;
    z-index: 1;
}

.kv h2{
    position: relative;
    z-index: 1;
}

.kv h2 .hid{
    display: block;
    overflow: hidden;
}

.kv h2 .block{
    display: block;
}

.kv h2 .block,
.kv h2 .block > span{
    font-size: 6vw;
    line-height: 170%;
    display: inline-block;
    color: #fff;
    letter-spacing: 0.1em;
    font-family: 'Noto Serif JP';
}

.kv h2 .block .siz_l{
    font-size: 7vw;
}

#loopslider{
    position: absolute;
    bottom: 52%;
    left: 0;
}

#loopslider li{
    margin-right: 8vw;
    font-size: 20vw;
    letter-spacing: 0.1em;
    line-height: 1;
    font-family: 'Oswald';
    color: rgba(255,255,255,.3);
}


/* video
   ================================================================== */
#bg_movie{
    position: absolute;
    top: 50%;
    left: 50%;
    min-width: 100%;
    min-height: 100vh;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}


/* under_kv
   ================================================================== */
.under_kv{
	margin: 0 0 0;
    position: relative;
}

.under_kv.staff{
	background: #212A37;
}

.under_kv .bg_height{
    position: relative;
    overflow: hidden;
}

.under_kv .bg_height::before{
    content: "";
    background: rgba(0,0,0,.20);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
}

.under_kv.cover15 .bg_height::before{
    background: rgba(0,0,0,.15);
}

.under_kv .bg{
    position: absolute;
    top: -10px;
    left: 0;
    width: 100%;
    height: 120%;
    z-index: 1;
}

.under_kv.staff .bg{
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vw;
}

.under_kv .bg > div{
    height: 100%;
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
    z-index: 1;
}

.under_kv.construction .bg > div{
	background-image: url("/wp-content/themes/building/img/kv_construction.webp");
}

.under_kv.project .bg > div{
	background-image: url("/wp-content/themes/building/img/kv_project.webp");
}

.under_kv.news .bg > div{
	background-image: url("/wp-content/themes/building/img/kv_news.webp");
}

.under_kv.kenji_takaoka .bg > div{
	background-image: url("/wp-content/themes/building/img/kv_sp_takaoka.webp");
}

.under_kv.takayuki_saito .bg > div{
	background-image: url("/wp-content/themes/building/img/kv_sp_saito.webp");
}

.under_kv.ryuji_kubo .bg > div{
	background-image: url("/wp-content/themes/building/img/kv_sp_kubo.webp");
}

.under_kv.ryohei_hashimitsu .bg > div{
	background-image: url("/wp-content/themes/building/img/kv_sp_hashimitsu.webp");
}

.under_kv.issei_matsuo .bg > div{
	background-image: url("/wp-content/themes/building/img/kv_sp_matsuo.webp");
}

.under_kv.company_kv .bg > div{
	background-image: url("/wp-content/themes/building/img/kv_company.webp");
}

.under_kv.recruit_kv .bg > div{
	background-image: url("/wp-content/themes/building/img/kv_recruit.webp");
}

.under_kv.contact_kv .bg > div{
	background-image: url("/wp-content/themes/building/img/kv_contact.webp");
}

.under_kv .inner{
    height: 100vw;
    padding: 0 8vw 10vw;
    box-sizing: border-box;
    display: flex;
    align-items: flex-end;
}

.under_kv.staff .inner{
    padding-top: 6vw;
    padding-bottom: 15vw;
    height: auto;
}

.under_kv.staff.txt_right .inner{
    justify-content: flex-end;
}

.under_kv .inbox{
    position: relative;
    z-index: 3;
}

.under_kv h2 > span{
    display: block;
}

.under_kv h2 span{
    line-height: 150%;
    color: #fff;
    letter-spacing: 0.1em;
}

.under_kv h2 .eng{
    padding: 0 0 2vw;
    font-size: 4vw;
    font-family: 'Oswald';
    display: inline-block;
    border-bottom: 1px solid #fff;
}

.under_kv.staff h2 .eng{
    min-width: 37vw;
}

.under_kv h2 .jpn{
    margin: 1vw 0 0;
    font-size: 8vw;
    font-weight: 900;
    letter-spacing: 0.15em;
}

.under_kv .name{
    margin: 2vw 0 0;
    font-size: 5vw;
    font-family: 'Oswald';
    line-height: 150%;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.1em;
}

.under_kv .staff_message{
    margin: 0 auto 0;
    display: flex;
    justify-content: center;
    z-index: 3;
    position: absolute;
    top: 35vw;
    right: 0;
}

.under_kv.txt_right .staff_message{
    right: auto;
    left: 0;
}

.under_kv .staff_message ul{
    width: 45vw;
    display: flex;
    justify-content: center;
}

.under_kv .staff_message ul li{
    margin: 0 1.5vw;
    width: 12vw;
    line-height: 0;
}

.under_kv .staff_message ul li > span{
    padding: 4vw 1.5vw;
    font-size: 5.5vw;
    line-height: 150%;
    letter-spacing: 0.1em;
    font-weight: 700;
    color: #1A1A1A;
    background: #fff;
    writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    display: inline-block;
    white-space: nowrap;
}


/* index_news
   ================================================================== */
.index_news{
	margin: -17vw 0 0;
    padding: 0 0 10vw;
    width: 100%;
	position: absolute;
    z-index: 5;
    overflow: hidden;
}

.index_news .inner{
    margin: 0 0 0 auto;
    padding: 0;
    width: 95%;
    position: relative;
    box-sizing: border-box;
}

.index_news .inner::before{
    content: "";
    width: 2000%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 100%;
    background: #fff;
}

.index_news .flex{
    padding: 6vw 7vw;
    overflow: hidden;
    background: #fff;
}

.index_news .left{
    margin: 0 0 0;
}

.index_news h2{
    font-size: 5vw;
    font-weight: 700;
    letter-spacing: 0.1em;
    font-family: 'Oswald';
}

.index_news .right{
    margin: 4vw 0 0;
    padding: 4vw 0 0;
    position: relative;
}

.index_news .right::before{
    content: "";
    background: #ddd;
    width: 20vw;
    height: 1px;
    position: absolute;
    top: 0;
    left: 0;
}

.index_news .right a{
    display: block;
}

.index_news .right a span{
    display: block;
    font-size: 3.5vw;
    font-weight: 400;
    line-height: 150%;
}

.index_news .right .date, .index_news .right .date time, .index_news .right .date a{
    color: #ccc !important;
}

.index_news .right .title{
    margin: 2vw 0 0;
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
    font-weight: 500;
}

.index_news .view_more_btn{
    margin: 6vw 0 0;
}


/* index_philosophy
   ================================================================== */
.index_philosophy{
	margin: 0 0 0;
    position: relative;
    overflow: hidden;
}

.index_philosophy .bg{
    background-image: url("/wp-content/themes/building/img/kv_philosophy.webp");
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.index_philosophy .bg::after{
    content: "";
    background: rgba(0,149,218,.15);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.index_philosophy .inner{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 160vw;
    position: relative;
    z-index: 1;
    box-sizing: border-box;
}

.index_philosophy .logo{
    margin: 20vw auto 0;
    width: 25vw;
    line-height: 0;
}

.index_philosophy .txt{
    position: absolute;
    top: 55vw;
    right: 6vw;
    display: flex;
}

.index_philosophy .txt li{
    margin: 0 0 0 2vw;
    font-size: 4.5vw;
    letter-spacing: 0.3em;
    font-weight: 500;
    color: #fff;
    line-height: 150%;
    font-family: 'Noto Serif JP';
    writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    white-space: nowrap;
}


/* index_about
   ================================================================== */
.index_about{
	margin: 15vw 0 0;
    position: relative;
    overflow: hidden;
}

.index_about ul{
	margin: 8vw 0 0;
}

.index_about ul li{
	margin: 0 0 0;
}

.index_about ul .photo{
	margin: 0 0 0;
}

.index_about ul .text_box{
	padding: 3vw 4vw;
}

.index_about ul h3{
    font-size: 4.2vw;
    line-height: 170%;
    color: #0095DA;
    letter-spacing: 0.2em;
    font-family: 'Noto Serif JP';
}

.index_about ul p{
    margin: 2vw 0 0;
    font-size: 3.4vw;
}


/* index_construction
   ================================================================== */
.index_construction{
	margin: 15vw 0 0;
    position: relative;
    overflow: hidden;
}

.index_construction .bg{
	margin: 8vw 6vw 0 -3vw;
    line-height: 0;
}

.index_construction .circle_btn{
	margin: 6vw 0 0;
}


@media screen and (max-width : 499px){
    
    /* scroll_block */
    .scroll_block{
        margin: 6vw -3vw 0;
    }
    
    .scroll_block ul{
        padding: 0 3vw 3vw;
        display: flex;
        overflow-x: scroll;
    }
    
    .scroll_block ul li a{
        white-space: nowrap;
    }
    
    /* construction_list_slider */
    .construction_list_slider{
        width: 75%;
    }
    
    .construction_list_slider .slick-list{
	    overflow: inherit;
    }
    
    .construction_list_slider .construction_list_linkbox{
	    padding-right: 3vw;
    }
    
}


/* cat_list
   ================================================================== */
.cat_list{
	font-size: 0;
    position: relative;
    z-index: 1;
}

.cat_list li{
	margin: 0 5px 5px 0;
    display: inline-block;
    vertical-align: top;
    box-sizing: border-box;
    width: auto;
}

.cat_list li a{
	padding: 1.3vw 2.5vw;
    font-size: 3.1vw;
    line-height: 145%;
    background: #eee;
    border: 1px solid #eee;
    display: block;
}


/* bg_sections_wrap
   ================================================================== */
.bg_sections_wrap{
	margin: 15vw 0 0;
    padding: 15vw 0;
    background: #212A37;
}


/* index_message
   ================================================================== */
.index_message{
	margin: 0 0 0;
    position: relative;
    overflow: hidden;
}

.index_message .inner{
	padding: 0;
}

.index_message .main{
    margin: 8vw 0 0;
	display: flex;
}

.index_message .photo_box.sp{
    margin: 0 0 0 5vw;
}

.index_message .main .text_box{
    width: 30vw;
	display: flex;
    justify-content: center;
}

.index_message .main .text_box h2{
    display: flex;
}

.index_message .main .text_box h2 > span{
    margin: 0 1vw;
    font-size: 6vw;
    display: block;
    line-height: 150%;
    font-weight: 500;
    letter-spacing: 0.6em;
    font-family: 'Noto Serif JP';
    color: #fff;
    writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    white-space: nowrap;
}

.index_message .main .photo_box{
    width: 70vw;
	position: relative;
}

.index_message .main .photo_box .photo{
    width: 100%;
    height: 55vw;
    background-image: url("/wp-content/themes/building/img/message_photo.webp");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

.index_message .main .photo_box .photo.sp{
    margin: 6vw 9vw 0 auto;
    width: 60%;
    height: 55vw;
}

.index_message .main .photo_box .photo img{
	display: none;
}

.index_message .main .photo_box .name{
    margin: 0 0 0 5vw;
}

.index_message .main .photo_box .name > span{
    display: block;
    line-height: 100%;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #fff;
}

.index_message .main .photo_box .name .eng{
    font-size: 8vw;
    font-family: 'Oswald';
}

.index_message .main .photo_box .name .jpn{
    margin: 4vw 0 0 1vw;
    font-size: 4.2vw;
    letter-spacing: 0.3em;
    font-family: 'Noto Serif JP';
}

.index_message .bottom{
    margin: 5vw 0 0;
    display: flex;
}

.index_message .bottom .photo{
    width: 30vw;
}

.index_message .bottom .text_box{
    padding: 0 3vw;
    width: 100%;
    box-sizing: border-box;
}

.index_message .bottom .text_box .kumamoto{
    width: 70%;
    line-height: 0;
}

.index_message .bottom .text_box h3{
    margin: 5vw 0 0;
    font-size: 5.5vw;
    line-height: 180%;
    letter-spacing: 0.3em;
    color: #fff;
    font-family: 'Noto Serif JP';
}

.index_message .bottom .text_box p{
    margin: 5vw 0 0;
    color: #fff;
}

.index_message .bottom .text_box .circle_btn{
    margin: 8vw 0 0;
}


/* index_staff
   ================================================================== */
.index_staff{
	margin: 15vw 0 0;
    position: relative;
}

.index_staff .inner{
    padding-top: 15vw;
    padding-bottom: 15vw;
	position: relative;
}

.index_staff .inner::before{
    content: "";
    background: #0D131C;
    width: 50%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 50%;
}

.index_staff .top_box{
	margin: 0;
    position: relative;
    z-index: 1;
}

.index_staff .top_box h2{
    font-size: 6.5vw;
    line-height: 180%;
    font-weight: 500;
    letter-spacing: 0.3em;
    color: #fff;
    font-family: 'Noto Serif JP';
}

.index_staff .top_box .txt{
    margin: 5vw 0 0;
}

.index_staff .top_box p{
    font-size: 4.2vw;
    line-height: 180%;
    color: #fff;
}

.index_staff ul{
    margin: 10vw 0 0;
    position: relative;
    z-index: 1;
}

.index_staff ul li{
    margin: 10vw 0 0;
}

.index_staff ul li:first-child{
    margin-top: 0;
}

.index_staff ul .hid{
    overflow: hidden;
}

.index_staff ul .photo{
    position: relative;
}

.index_staff ul .photo::before{
    content: "";
    background: rgba(0,0,0,.15);
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.index_staff ul .text_box{
    padding: 5vw 0 0;
}

.index_staff ul .text_box .name > span{
    display: block;
    line-height: 100%;
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #fff;
}

.index_staff ul .text_box .name .eng{
    font-size: 8vw;
    font-family: 'Oswald';
}

.index_staff ul .text_box .name .jpn{
    margin: 4vw 0 0 1vw;
    font-size: 4.2vw;
    letter-spacing: 0.3em;
    font-family: 'Noto Serif JP';
}

.index_staff ul .text_box .catch{
    margin: 4vw 0 0;
}

.index_staff ul .text_box .catch,
.index_staff ul .text_box .catch > span{
    font-size: 6vw;
    display: inline-block;
    line-height: 130%;
    font-weight: 500;
    letter-spacing: 0.1em;
    color: #fff;
    font-family: 'Noto Serif JP';
}

.index_staff ul .text_box .catch .siz_l{
    font-size: 7vw;
}

.index_staff ul .circle_btn{
    margin: 6vw 0 0;
    text-align: right;
}

.index_staff ul .circle_btn a{
    min-width: 38vw;
}


/* recruit_information
   ================================================================== */
.recruit_information{
	margin: 15vw 0 0;
    position: relative;
    overflow: hidden;
    z-index: 1;
}

.recruit_information .photo_box{
	margin: 10vw 0 0;
    position: relative;
}

.recruit_information .photo_box a{
	display: block;
    position: relative;
}

.recruit_information .photo_box .photo{
	display: block;
}

.recruit_information .photo_box .text{
	display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 90%;
    line-height: 0;
}

.recruit_information .text_box{
	padding: 5vw 0 0;
}

.recruit_information .text_box h3{
	font-size: 4vw;
    line-height: 160%;
    font-weight: 700;
    color: #fff;
}

.recruit_information .text_box p{
	margin: 4vw 0 0;
    color: #fff;
}

.recruit_information .text_box .circle_btn{
	margin: 6vw 0 0;
}


/* construction_list_page
   ================================================================== */
.construction_list_page{
	padding: 15vw 0 25vw;
}

.construction_list > li{
	margin: 10vw 0 0;
    padding: 5vw;
    border: 3px solid #F1F1F1;
}

.construction_list > li:first-child{
	margin-top: 0;
}

.construction_photo_slider .photo{
	width: 100%;
    height: 50vw;
}

.construction_list .bottom_box{
	margin: 2vw 0 0;
}

.construction_list .site{
    margin: 4vw 0 0;
	font-size: 4vw;
    font-weight: 500;
}

.construction_list .site.done{
	color: #0095DA;
}

.construction_list .site.underconstruction{
	color: #E74C3C;
}

.construction_list .title{
    margin: 1vw 0 0;
	font-size: 7.0vw;
    line-height: 130%;
    font-weight: 900;
}

.construction_list .text{
    margin: 4vw 0 0;
}


/* pagination
   ================================================================== */
.pagination{
	text-align: center;
	padding: 10vw 0 5px;
	font-size: 0;
}

.pagination li{
	display: inline-block;
    vertical-align: top;
	margin: 6px 3px 0;
}

.pagination li.disabled{
	display: none;
}

.pagination a,
.pagination .active span{
	text-decoration: none;
	background: #ddd;
	color: #FFF;
	padding: 2px 0 0;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 16px;
	width: 34px;
	height: 34px;
    box-sizing: border-box;
    letter-spacing: 0;
    transition: all ease-out 0.3s;
    font-family: "メイリオ","ms pgothic", sans-serif;
}

.pagination .active span{
	background: #0095DA;
}


/* projec_message
   ================================================================== */
.projec_message{
	padding: 15vw 0 25vw;
    background: #212A37;
}

.projec_message .block_title + .check_list{
	margin: 5vw 0 0;
}

.projec_message .border_box{
	margin: 10vw 0 0;
    padding: 4vw;
    border: 1px solid #A6ADB6;
}

.projec_message .border_box h4{
	font-size: 4.4vw;
    font-weight: 700;
    color: #fff;
}

.projec_message .border_box .check_list{
	margin: 1vw 0 0;
}


/* project_page
   ================================================================== */
.project_page{
	padding: 15vw 0 25vw;
}

.project_list > li{
	margin: 15vw 0 0;
}

.project_list > li:first-child{
	margin-top: 0;
}

.project_list .title{
    padding: 3vw 0;
	display: flex;
    align-items: center;
    border-top: 1px solid #ddd;
    position: relative;
}

.project_list .title::before{
    content: "";
    width: 25vw;
    height: 1px;
    background: #0095DA;
    position: absolute;
    top: -1px;
    left: 0;
}

.project_list .title > span{
	display: block;
    line-height: 150%;
}

.project_list .title .num{
	font-size: 10vw;
    font-family: 'Oswald';
    font-weight: 700;
    color: #eee;
}

.project_list .title .txt{
    padding: 2vw 0 0 3vw;
	font-size: 4.2vw;
    font-weight: 700;
    color: #0095DA;
}

.project_list .flex_column{
    margin: 3vw 0 0;
}

.project_list .flex_column .left{
    width: 50%;
    line-height: 0;
}

.project_list .flex_column .right{
    margin: 5vw 0 0;
}

.project_list .flex_column .pdf_btn{
    margin: 5vw 0 0;
}

.project_list .applying{
    margin: 3vw 0 0;
    padding: 15vw 3vw;
    font-size: 3.5vw;
    font-weight: 400;
    line-height: 150%;
    text-align: center;
    background: #F9F9F9;
}


/* message
   ================================================================== */
.message{
	padding: 15vw 0 30vw;
    background: #F9F9F9;
}

.message p{
	margin: 8vw 0 0;
    line-height: 180%;
}

.message .name{
	margin: 8vw 0 0 auto;
    width: 35vw;
    line-height: 0;
}

.message_bg{
	margin: -15vw 0 0 auto;
    width: 95vw;
    overflow: hidden;position: relative;
    z-index: 2;
}

.message_bg .inner{
	padding: 0;
}


/* company
   ================================================================== */
.company{
	padding: 15vw 0;
}

.company_block .profile_box{
    margin: 10vw 0 0;
}


/* history
   ================================================================== */
.history{
	padding: 15vw 0 25vw;
    background: #F9F9F9;
}

.company_block .history_box{
    margin: 10vw 0 0;
}

.company_block .history_box ul > li{
    padding: 4vw 3vw;
    border-bottom: 1px dashed #DAD3CF;
}

.company_block .history_box ul .date,
.company_block .history_box ul p{
    font-size: 3.5vw;
    font-weight: 400;
    letter-spacing: 0.1em;
}

.company_block .history_box ul p{
    margin: 2vw 0 0;
}


/* news_list_block
   ================================================================== */
.news_list_block{
    padding: 15vw 0 15vw;
}

.news_list > li{
	margin: -60px 0 0;
    padding: 60px 0 0;
    border-bottom: 1px solid #ddd;
    transition: all cubic-bezier(0.77, 0, 0.175, 1) 0.3s;
    opacity: 1;
    visibility: visible;
}

.news_list > li.is-hidden{
    opacity: 0;
    height: 0;
    margin: 0;
    padding: 0;
    border-bottom: none;
    visibility: hidden;
}

.news_list > li .btn_box{
    padding: 4vw 8vw 4vw 3vw;

	display: block;
    position: relative;
    box-sizing: border-box;
    cursor: pointer;
}

.news_list > li .btn_box::after{
    content: "";
    background: url("/wp-content/themes/building/img/arrow_right.svg") no-repeat center center;
    background-size: 100%;
    width: 2vw;
    height: 6vw;
    position: absolute;
    margin: auto;
    top: 7vw;
    bottom: 0;
    right: 3vw;
    transition: .3s;
}

.news_list > li .btn_box.active::after{
    transform: rotate(-90deg);
    transform-origin: center center;
}

.news_list > li .show_box{
    padding: 0 3vw 7vw;
	display: none;
}

.news_list > li.open .show_box{
	display: block;
}

.news_list > li .show_box .photo{
	margin-top: 3vw;
	margin-bottom: 4vw;
}

.news_list > li .show_box .photo img{
	max-height: 500px;
}

.news_list > li .date{
	font-size: 15px;
    font-weight: 700;
    letter-spacing: 0;
    color: #0095DA;
}

.news_list > li .title{
    margin: 2vw 0 0;
	font-size: 15px;
    font-weight: 500;
    color: #222;
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
}

.news_list > li .btn_box.active .title{
	overflow: inherit;
	display: block;
}

.news_list_block .more_btn{
	margin: 10vw 0 0;
    position: relative;
    z-index: 10;
}


/* contact_block
   ================================================================== */
.contact_block{
	margin: 15vw 0 15vw;
}

.contact_block .inner{
	padding: 0 3vw;
}


/* contact
   ================================================================== */
/* form */
.contact{
	padding: 0 0 0;
}

.contact form{
	margin-top: -90px;
    padding-top: 90px;
}

.contact form *{
	font-family: "Noto Sans JP";
}

.contact .top_text{
    font-size: 3.1vw;
    text-align: center;
}

.conf_text{
    margin: 10vw 0 0;
	font-size: 4vw;
    color: #E74C3C;
    text-align: center;
    font-weight: 700;
	line-height: 150%;
}

.req{
	color: #E74C3C;
}

.contact table{
    margin: 10vw auto 0;
	width: 100%;
	box-sizing: border-box;
}

.contact th,
.contact td{
	font-size: 16px;
	line-height: 150%;
	letter-spacing: 0.10em;
	width: 100%;
	display: block;
	font-weight: normal;
	border-bottom: none;
	box-sizing: border-box;
}

.contact th{
	padding: 0 0 10px;
    font-weight: 500;
}

.contact td{
	padding: 0 0 25px;
    position: relative;
}

.contact td .balloon{
    position: absolute;
    bottom: -25px;
    left: 15px;
    height: 16px;
    line-height: 1;
    font-size: 13px;
    color: #EA3E32;
    letter-spacing: 0;
}

.contact output,
.contact input,
.contact select,
.contact textarea{
	margin: 0;
	font-size: 16px;
    line-height: 170%;
    letter-spacing: 0.1em;
	padding: 15px;
	box-sizing: border-box;
	width: 100%;
    background: #F8F8F8;
	border: 1px solid #F8F8F8;
	vertical-align: middle;
}

/* 確認画面の入力文字背景 */
.contact output{
    display: block;
    background: rgba(0,25,118,.1);
    border-color: rgba(0,25,118,.1);
}

.contact select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("../images/common/down-arrow.svg");
    background-color: #F8F8F8;
	background-repeat: no-repeat;
	background-size: 10px 8px;
	background-position: right 16px center;
}

input:focus,
select:focus,
textarea:focus{
    outline: none;
}

textarea::-webkit-input-placeholder,
select::-webkit-input-placeholder,
input::-webkit-input-placeholder{
    color: #ddd;
}

textarea::-moz-placeholder,
textarea::-moz-placeholder,
select::-moz-placeholder{
    color: #ddd; opacity: 1;
}

textarea:-ms-input-placeholder,
select:-ms-input-placeholder,
input:-ms-input-placeholder{
    color: #ddd;
}

.contact textarea{
    height: 50vw;
	line-height: 150%;
}

.contact textarea.height120{
    height: 30vw;
}

/* ラジオボタン */
.contact .radio_input{
    padding: 0 0 17px;
}

.contact .radio_input output{
    margin: 0 0 8px;
}

.radio_input label{
    margin: 0 0 8px;
	display: flex;
    align-items: center;
    cursor: pointer;
}

input[type='checkbox'] ,
input[type='radio'] {
    appearance: none;
    outline: none;
    display: block;
    position: relative;
    text-align: center;
    cursor: pointer;
    width: 18px;
    height: 18px;
	margin: 0 10px 0 0;
    font-size: 0;
    padding: 0 !important;
    border: none;
    background: none;
}

input[type='checkbox']::before ,
input[type='radio']::before {
    display: block;
    position: absolute;
    content: '';
    width: 18px;
    height: 18px;
    background: #fff;
    border: solid 1px #ddd;
    border-radius: 100%;
}

input[type='checkbox']:checked::before ,
input[type='radio']:checked::before {
    border-color: #333;
}

input[type='checkbox']::after ,
input[type='radio']::after {
    display: block;
    content: '';
    position: absolute;
    left: 5px;
    top: 5px;
    width: 10px;
    height: 10px;
    background: #333;
    border-radius: 100%;
    opacity: 0;
}

input[type='checkbox']:checked::after ,
input[type='radio']:checked::after {
    opacity: 1;
}

/* 郵便番号 */
.address output,
.address input{
    width: 125px;
}

/* 都道府県 */
.prefectures output,
.prefectures select{
    width: 250px;
}

/* ⽣年⽉⽇ */
.birth .flex{
	display: flex;
    align-items: center;
}

.birth .flex p{
    margin: 0 10px;
    font-size: 15px;
    font-weight: 400;
}

.birth .flex select{
    background-image: none;
}

.birth .w100 select{
    width: 75px;
}

.zas_btn_area{
	margin: auto;
	text-align: center;
	padding: 30px 0 0;
	font-size: 0;
	box-sizing: border-box;
	max-width: 500px;
}

.zas_btn_area button{
	font-size: 16px;
	color: #FFF;
	border: none;
	position: relative;
	overflow: hidden;
	text-align: center;
    transition: .3s;
}

.zas_btn_area button > span{
	padding: 12px 0;
	border: none;
	display: block;
	font-size: 16px;
    font-weight: 400;
	line-height: 150%;
	color: #FFF;
}

.zas_btn_area button:disabled{
	background: #ccc !important;
    border-color: #ccc !important;
    cursor: auto;
}

.zas_btn_area button:disabled span{
    color: #fff !important;
}

.zas_btn_area .zas_btn01 button{
	background: #0095DA;
	width: 55%;
	max-width: 260px;
}

.zas_btn_area .zas_btn02 button{
	margin-right: 2%;
	background: #ccc;
	width: 28%;
}

.zas_btn_area .zas_btn03 button{
	background: #0095DA;
	width: 55%;
	max-width: 260px;
}


/* thanks
   ================================================================== */
.thanks p{
    margin: 0 0 0;
	font-size: 4vw;
	line-height: 150%;
}

.thanks .go_top_btn{
	margin: 8vw 0 0;
	text-align: center;
}


/* recruit_top
   ================================================================== */
.recruit_top{
	margin: 0;
    overflow: hidden;
}

.recruit_top .text_box{
	padding: 15vw 0 50vw;
    background: #212A37;
}

.recruit_top .text_box h3{
	font-size: 6.5vw;
    font-weight: 700;
    color: #fff;
}

.recruit_top .text_box p{
	margin: 4vw 0 0;
    color: #fff;
}

.recruit_top .recruit_move{
	margin: -35vw 0 0;
}

.recruit_top .recruit_move .inner{
	padding: 0;
}

.recruit_top .recruit_move .bg_box{
    padding: 10vw 5vw;
    width: 90vw;
    background: #0D131C;
    box-sizing: border-box;
    line-height: 0;
}

.recruit_top .recruit_move video{
	width: 100%;
}


/* job_information
   ================================================================== */
.job_information{
	margin: 0;
	padding: 15vw 0;
    overflow: hidden;
}

.job_information .bg_title{
	margin: 8vw 0 0;
}

.job_information .common_table{
	margin: 5vw 0 0;
}

.bg_title{
    padding: 3vw 4vw;
    font-size: 3.7vw;
    line-height: 150%;
    font-weight: 700;
    color: #fff;
    background: #0095DA;
}


/* recruit_message
   ================================================================== */
.recruit_message{
	margin: 0;
	padding: 15vw 0;
    overflow: hidden;
    background: #212A37;
}

.recruit_message .title_box{
	margin: 0 0 0;
}

.recruit_message .title_box .logo{
    margin: 0 auto;
	width: 35vw;
    line-height: 0;
}

.recruit_message .title_box .logo img{
	width: 100%;
}

.recruit_message .title_box .text_list{
	margin: 4vw 0 0;
}

.recruit_message .title_box .text_list > li{
	padding: 3vw 0;
    display: flex;
    border-bottom: 1px solid #424953;
}

.recruit_message .title_box .text_list > li > span{
	display: block;
    line-height: 150%;
    color: #fff;
    font-weight: 700;
    letter-spacing: 0.1em;
}

.recruit_message .title_box .text_list .num{
	font-size: 5vw;
    font-family: 'Oswald';
}

.recruit_message .title_box .text_list .txt{
    padding: 0 0 0 3vw;
	font-size: 6vw;
}

.recruit_message .title_box .bottom_text{
    margin: 5vw 0 0;
	font-size: 6vw;
    color: #fff;
    font-weight: 900;
    letter-spacing: 0.05em;
}

.recruit_message .title_box .bottom_text > span{
    display: inline-block;
    color: inherit;
    font-weight: inherit;
}

.recruit_message .title_box .bottom_text .siz_l{
    font-size: 8.5vw;
}

.recruit_message .title_box .photos_list_5{
    margin-top: 8vw;
}

/* photos_list_5 */
.photos_list_5{
    margin-left: -1.5%;
    margin-right: -1.5%;
    font-size: 0;
    text-align: center;
}

.photos_list_5 > li{
    margin: -1vw 1.5% 0;
    width: 30%;
    display: inline-block;
    vertical-align: top;
    box-sizing: border-box;
    line-height: 0;
}

.photos_list_5.square > li{
    margin-top: 5vw;
}

/* photos_list_3*/
.photos_list_3{
    font-size: 0;
    text-align: center;
}

.photos_list_3 > li{
    margin: 3vw 2% 0 0;
    width: 49%;
    display: inline-block;
    vertical-align: top;
    box-sizing: border-box;
    line-height: 0;
}

.photos_list_3 > li:nth-child(2n+2){
    margin-right: 0;
}

/* bottom_box*/
.recruit_message .bottom_box{
	margin: 8vw 0 0;
}

.recruit_message .bottom_box .top_text{
	color: #fff;
}

.recruit_message .bottom_box .message_list{
	margin: 8vw 0 0;
}

.recruit_message .bottom_box .message_list li{
	margin: 2vw 0 0;
    padding: 4vw;
    background: #444B56;
}

.recruit_message .bottom_box .message_list li h4{
	font-size: 4.5vw;
    color: #fff;
}

.recruit_message .bottom_box .message_list li p{
	margin: 2vw 0 0;
    color: #fff;
}

.recruit_message .bottom_box .photos_list li{
	margin: 0 2vw 0 0;
    width: 40vw;
    line-height: 0;
    font-size: 37vw;
}

.recruit_message .bottom_box .photos_list li span{
	opacity: 0;
    display: block;
    overflow: hidden;
    height: 0;
}

.recruit_message .bottom_box .message_text_box{
	margin: 8vw 0 0;
    padding: 5vw 4vw;
    background: #0D131C;
}

.recruit_message .bottom_box .message_text_box h3{
	font-size: 5.0vw;
    color: #fff;
}

.recruit_message .bottom_box .message_text_box p{
	margin: 8vw 0 0;
    color: #fff;
}


/* contact_block recruit_page
   ================================================================== */
.recruit_page.contact_block{
	margin: 20vw 0 15vw;
}

.recruit_page.contact_block .block_title{
    margin: 0 0 10vw;
	text-align: center;
}

.recruit_page.contact_block .block_title.border::before{
    width: 100%;
}


/* staff_block
   ================================================================== */
.staff_block{
	margin: 0 0 0;
    padding: 15vw 0;
    background: #212A37;
}

.staff_block h2{
    padding: 0 0 4vw;
    position: relative;
    z-index: 1;
    font-size: 6vw;
    line-height: 170%;
    color: #fff;
    letter-spacing: 0.1em;
    font-family: 'Noto Serif JP';
    border-bottom: 1px solid #A6ADB6;
}

.staff_block h2::before{
    content: "";
    width: 25vw;
    height: 4px;
    background: #A6ADB6;
    position: absolute;
    top: 100%;
    left: 0;
}

.staff_block h2 > span{
    display: inline-block;
    color: inherit;
    font-family: inherit;
}

.staff_block h2 .siz_l{
    font-size: 7vw;
}

/* sticky_wrap */
.staff_block .sticky_wrap{
    padding: 10vw 0;
}

.staff_block .sticky_wrap .sticky_box{
    margin: 0 0 0 auto;
    padding: 5vw 0 5vw;
    position: sticky;
    top: 100px;
    right: 0;
    height: 40vw;
    line-height: 0;
    text-align: right;
    z-index: 1;
}

.staff_block .sticky_wrap .sticky_box img{
    height: 100%;
}

.staff_block .sticky_wrap .contents_box{
    margin-top: -45vw;
    overflow: hidden;
}

/* staff_profile */
.staff_profile{
    margin: 0 0 0;
    position: relative;
    z-index: 2;
}

.staff_profile h3{
    font-size: 6vw;
    font-family: 'Oswald';
    color: #fff;
    font-weight: 700;
}

.staff_profile .pc_flex{
    margin: 6vw 0 0;
}

.staff_profile .text_box{
    margin: 0 0 0;
}

.staff_profile .text_box .sp_flex{
    display: flex;
    align-items: center;
}

.staff_profile .text_box .sp_flex .photo{
    width: 40vw;
}

.staff_profile .text_box .sp_flex h4{
    padding: 0 0 0 5vw;
    width: calc(100% - 40vw);
    box-sizing: border-box;
}

.staff_profile .text_box .sp_flex h4 > span{
    display: block;
    line-height: 150%;
    color: #fff;
    font-weight: 700;
}

.staff_profile .text_box .sp_flex h4 .jpn{
    font-size: 6vw;
    letter-spacing: 0.15em;
}

.staff_profile .text_box .sp_flex h4 .eng{
    margin: 1vw 0 0;
    font-size: 4vw;
    letter-spacing: 0.10em;
    font-family: 'Oswald';
}

.staff_profile .text_box .top_box{
    margin: 6vw 0 0;
}

.staff_profile .text_box p{
    color: #fff;
}

.staff_profile .text_box p + p{
    margin: 2vw 0 0;
}

.staff_profile .text_box p.f14{
    font-size: 3.2vw;
}

.staff_profile .bottom_box{
    margin: 14vw 0 0;
    padding: 5vw 0 0;
    position: relative;
}

.staff_profile .bottom_box::before{
    content: "";
    background: #A6ADB6;
    width: 1px;
    height: 8vw;
    position: absolute;
    bottom: 100%;
    left: 5vw;
}

/* staff_message / staff_important */
.staff_message.about{
    margin: 28vw 0 0;
}

.staff_message.about .bg{
    padding: 0 0 28vw;
    position: relative;
}

.staff_message.about .bg::before{
    content: "";
    background: #0D131C;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
}

.staff_message .inner{
    padding: 0;
    position: relative;
    z-index: 2;
}

.staff_message .photo{
    margin: -15vw 0 0;
    width: 100%;
    display: inline-block;
    position: relative;
    z-index: 2;
}

.staff_message.about .photo{
    text-align: right;
}

.staff_message .photo img{
    width: 90vw;
}

.staff_message ul{
    margin: 8vw 3vw 0;
}

.staff_message ul > li{
    margin: 8vw 0 0;
}

.staff_message ul h4{
    font-size: 5vw;
    font-family: 'Noto Serif JP';
    color: #fff;
    letter-spacing: 0.2em;
}

.staff_message ul h4 .num{
    margin: 0 0 0 3vw;
    font-size: 8vw;
    vertical-align: text-bottom;
    font-family: 'Noto Serif JP';
    color: #fff;
    font-weight: 400;
    letter-spacing: 0.015em;
}

.staff_message ul p{
    margin: 3vw 0 0;
    color: #fff;
}

/* futures */
.futures{
    margin: 15vw 0 0;
}

.futures .bg{
    padding: 8vw 0 8vw 3vw;
    position: relative;
}

.futures .bg::before{
    content: "";
    background: #0D131C;
    width: 100vw;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.futures .inner{
    position: relative;
    z-index: 2;
}

.futures .pc_flex{
    margin: 6vw 0 0;
}

.futures .text_box{
    margin: 0 0 0;
}

.futures .text_box .sp_flex{
    display: flex;
    align-items: center;
}

.futures .text_box .sp_flex .photo{
    width: 40vw;
}

.futures .text_box .sp_flex h4{
    padding: 0 0 0 5vw;
    width: calc(100% - 40vw);
    font-size: 6vw;
    box-sizing: border-box;
    color: #fff;
    font-weight: 700;
    letter-spacing: 0.2em;
}

.futures .text_box p{
    margin: 6vw 0 0;
    color: #fff;
}


@media screen and (min-width : 500px){


    /* kv
       ================================================================== */
    .kv .inner{
    	padding: 0 8.0vw 22.5vw;
    	height: 100vh;
        max-height: calc(100vh - 6.0vw);
        min-height: 600px;
    }
    
    .kv h2 .block,
    .kv h2 .block > span{
        font-size: 3.5vw;
        line-height: 7.0vw;
    }
    
    .kv h2 .block .siz_l{
        font-size: 4.0vw;
    }
    
    #loopslider{
        bottom: 31.8vw;
    }
    
    #loopslider li{
        margin-right: 6vw;
        font-size: 20.3vw;
    }


    /* video
       ================================================================== */
    #bg_movie{
        min-width: 100%;
        height: 100vh;
        min-height: 600px;
    }


    /* under_kv
       ================================================================== */
    .under_kv{
    	margin: 0 0 0;
    }

    .under_kv.staff .bg{
        position: absolute;
        top: -10px;
        left: 0;
        width: 100%;
        height: 120%;
        z-index: 1;
    }

    .under_kv.takayuki_saito .bg > div{
    	background-image: url("../images/staff/takayuki_saito/webp/kv.webp");
    }
    
    .under_kv.kenji_takaoka .bg > div{
    	background-image: url("../images/staff/kenji_takaoka/webp/kv.webp");
    }

    .under_kv.ryuji_kubo .bg > div{
    	background-image: url("../images/staff/ryuji_kubo/webp/kv.webp");
    }
    
    .under_kv.ryohei_hashimitsu .bg > div{
    	background-image: url("../images/staff/ryohei_hashimitsu/webp/kv.webp");
    }
    
    .under_kv.issei_matsuo .bg > div{
    	background-image: url("../images/staff/issei_matsuo/webp/kv.webp");
    }
    
    .under_kv .inner{
        height: 55.0vw;
        padding: 0 6.5vw 5.0vw;
    }
    
    .under_kv.staff .inner{
        padding-top: 0;
        padding-bottom: 5.0vw;
        height: 65.0vw;
    }

    .under_kv.staff.txt_right .inner{
        justify-content: flex-start;
    }
    
    .under_kv h2 .eng{
        padding: 0 0 1.0vw;
        font-size: 2.5vw;
    }
    
    .under_kv.staff h2 .eng{
        min-width: 26.0vw;
    }
    
    .under_kv h2 .jpn{
        margin: 1.0vw 0 0;
        font-size: 5.2vw;
    }
    
    .under_kv .name{
        margin: .5vw 0 0;
        font-size: 3.5vw;
    }

    .under_kv .staff_message{
        margin: auto;
        padding: 0 5.0vw;
        position: absolute;
        top: 22.0vw;
        right: 0;
        left: 0;
        justify-content: flex-end;
        box-sizing: border-box;
    }

    .under_kv.txt_right .staff_message{
        right: 0;
        left: 0;
    }

    .under_kv .staff_message.posi_center{
        top: 0;
    }

    .under_kv.text_position_top .staff_message.posi_center{
        top: 34%;
    }
    
    .under_kv .staff_message ul li{
        margin: 0 0 0 2.0vw;
        width: 6vw;
    }
    
    .under_kv .staff_message ul li > span{
        padding: 2.5vw .8vw;
        font-size: 3.1vw;
        line-height: 150%;
        letter-spacing: 0.3em;
    }


    /* index_news
       ================================================================== */
    .index_news{
    	margin: -6.0vw 0 0;
        padding: 0 0 6.0vw;
        width: 100%;
        box-sizing: border-box;
    }
    
    .index_news .inner{
        margin: 0 0 0 auto;
        width: 73.7%;
    }
    
    .index_news .flex{
        padding: 2.6vw 0;
        height: 12.0vw;
        box-sizing: border-box;
        display: flex;
        align-items: center;
        position: relative;
    }
    
    .index_news .left{
        margin: 0 0 0;
        padding: 0 0 0 4.0vw;
        width: 18.7vw;
        height: 7.0vw;
        box-sizing: border-box;
    }
    
    .index_news h2{
        font-size: 2.3vw;
    }
    
    .index_news .right{
        margin: 0 0 0;
        padding: 0 2.0vw 0 4.0vw;
        width: calc(100% - 18.7vw);
        height: 7.0vw;
        display: flex;
        align-items: center;
    }
    
    .index_news .right::before{
        width: 1px;
        height: 100%;
        top: 0;
        left: 0;
    }
    
    .index_news .right a span, .index_news .right time{
        font-size: 1.3vw;
        transition: .3s;
    }
    
    .index_news .right .title,.index_news .right h3.title{
        margin: 1.3vw 0 0;
		font-size:13px;
    }
    
    .index_news .right a:hover .title{
        color: #0095DA;
    }
    
    .index_news .view_more_btn{
        margin: 0;
        position: absolute;
        top: 7vw;
        left: 0;
    }


    /* index_philosophy
       ================================================================== */
    .index_philosophy{
    	margin: 0 0 0;
    }
    
    .index_philosophy .inner{
        height: 85.0vw;
    }
    
    .index_philosophy .logo{
        margin: 0 auto;
        width: 17.0vw;
    }
    
    .index_philosophy .txt{
        top: 16.5vw;
        right: 5.0vw;
    }
    
    .index_philosophy .txt li{
        margin: 0 0 0 3.0vw;
        font-size: 2.3vw;
        letter-spacing: 0.7em;
    }


    /* index_about
       ================================================================== */
    .index_about{
    	margin: 11.0vw 0 0;
    }
    
    .index_about ul{
    	margin: 6.4vw auto 0;
        display: flex;
        justify-content: space-between;
    }
    
    .index_about ul li{
    	margin: 0 0 0 0;
        width: calc((100% / 3) - 2.5vw);
    }
    
    .index_about ul li:last-child{
    	margin-right: 0;
    }
    
    .index_about ul .photo{
    	height: 22vw;
    }
    
    .index_about ul .text_box{
    	padding: 2.2vw 1.0vw 0;
    }
    
    .index_about ul h3{
        font-size: 2.2vw;
        line-height: 5.0vw;
        letter-spacing: 0.15em;
    }
    
    .index_about ul p{
        margin: .5vw 0 0;
        font-size: 1.4vw;
        line-height: 2.5vw;
    }


    /* index_construction
       ================================================================== */
    .index_construction{
    	margin: 9.0vw 0 0;
        position: relative;
    }
    
    .index_construction .inner{
        padding-top: 44.0vw;
        position: relative;
    }
    
    .index_construction .block_title{
    	margin: 0;
        position: absolute;
        right: 2vw;
        top: 21.0vw;
        z-index: 1;
    }
    
    .index_construction .block_title .eng{
    	font-size: 6.0vw;
    }
    
    .index_construction .block_title .jpn{
    	padding-left: 27.5vw;
    }
    
    .index_construction .bg{
    	margin: 0;
        position: absolute;
        right: 22vw;
        top: 0;
        height: 40.0vw;
        width: 78vw;
        background-image: url("/wp-content/themes/building/img/index_construction.webp");
        background-position: center center;
        background-repeat: no-repeat;
        background-size: cover;
    }
    
    .index_construction .bg img{
    	display: none;
    }
    
    .index_construction .circle_btn{
    	margin: 3.0vw 0 0;
    }

    
    /* cat_list
       ================================================================== */
    .cat_list{
    	font-size: 0;
    }
    
    .cat_list li{
    	margin: 0 1.0vw 1.0vw 0;
    }
    
    .cat_list li a{
    	padding: .5vw 2.5vw;
        font-size: 1.3vw;
        transition: .3s;
    }
    
    .cat_list li a:hover{
    	background: #1F1F1F;
        color: #eee;
    }


    /* bg_sections_wrap
       ================================================================== */
    .bg_sections_wrap{
    	margin: 11.0vw 0 0;
        padding: 13.7vw 0 13.5vw;
    }


    /* index_message
       ================================================================== */
    .index_message{
    	margin: 0 0 0;
        position: relative;
    }
    
    .index_message .main{
        margin: 0;
    	display: flex;
    }
    
    .index_message .main .text_box{
        width: 20%;
    	display: flex;
        justify-content: center;
    }
    
    .index_message .main .text_box h2{
        display: flex;
    }
    
    .index_message .main .text_box h2 > span{
        margin: 0 .5vw;
        font-size: 3.5vw;
        line-height: 150%;
        letter-spacing: 0.5em;
    }
    
    .index_message .main .photo_box{
        width: 80%;
    }
    
    .index_message .main .photo_box .photo{
        width: 100%;
        height: auto;
        background-image: none;
    }
    
    .index_message .main .photo_box .photo img{
    	display: block;
    }
    
    .index_message .main .photo_box .name{
        margin: 0 0 0;
        position: absolute;
        top: 20%;
        right: 2%;
    }
    
    .index_message .main .photo_box .name .eng{
        font-size: 5.8vw;
    }
    
    .index_message .main .photo_box .name .jpn{
        margin: 1.5vw 0 0 1.0vw;
        font-size: 3.0vw;
    }
    
    .index_message .bottom{
        margin: -8.5vw 0 0;
        display: flex;
        position: relative;
        z-index: 1;
    }
    
    .index_message .bottom .photo{
        padding: 0 0 0 2%;
        width: 40%;
        box-sizing: border-box;
    }
    
    
    .index_message .bottom .text_box{
        padding: 17.0vw 2.0vw 0 6.8vw;
        width: calc(100% - 40%);
    }
    
    .index_message .bottom .text_box .kumamoto{
        width: 90%;
    }
    
    .index_message .bottom .text_box h3{
        margin: 3.5vw 0 0;
        font-size: 3.0vw;
        line-height: 5.0vw;
    }
    
    .index_message .bottom .text_box p{
        margin: 3.5vw 0 0;
        line-height: 3.0vw;
        max-width: 46.0vw;
    }
    
    .index_message .bottom .text_box .circle_btn{
        margin: 4.0vw 0 0;
    }


    /* index_staff
       ================================================================== */
    .index_staff{
    	margin: 15.3vw 0 0;
    }
    
    .index_staff .inner{
        padding: 0;
    }
    
    .index_staff .inner::before{
        width: 60%;
        left: 40%;
    }
    
    .index_staff .top_box{
    	margin: 0 0 0 auto;
        padding: 0 1vw 0 0;
        padding-top: 9.5vw;
        padding-bottom: 15.5vw;
        position: sticky;
        top: 0;
        right: 0;
        display: flex;
        justify-content: flex-end;
        width: 30%;
        height: 85.0vw;
        box-sizing: border-box;
    }
    
    .index_staff .top_box h2{
        font-size: 4.0vw;
        line-height: 180%;
        font-weight: 500;
        letter-spacing: 0.5em;
        writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        white-space: nowrap;
    }
    
    .index_staff .top_box .txt.pc{
        margin: 0 1.5vw 0 0;
        display: flex;
        line-height: 150%;
    }
    
    .index_staff .top_box p{
        font-size: 1.6vw;
        line-height: 250%;
        letter-spacing: 0.4em;
        writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        white-space: nowrap;
    }
    
    .index_staff ul{
        margin: -85.0vw 0 0;
        padding-top: 9.5vw;
        padding-bottom: 15.5vw;
        width: 70%;
    }
    
    .index_staff ul li{
        margin: 8.5vw 0 0;
        position: relative;
    }
    
    .index_staff ul .text_box{
        padding: 0 0 4.0vw 4.0vw;
        position: absolute;
        bottom: 0;
        left: 0;
    }
    
    .index_staff ul .text_box .name .eng{
        font-size: 4.5vw;
    }
    
    .index_staff ul .text_box .name .jpn{
        margin: 2.0vw 0 0;
        font-size: 2.2vw;
    }
    
    .index_staff ul .text_box .catch{
        margin: 1.0vw 0 0 -2.0vw;
    }
    
    .index_staff ul .text_box .catch,
    .index_staff ul .text_box .catch > span{
        font-size: 4.0vw;
    }
    
    .index_staff ul .text_box .catch .siz_l{
        font-size: 5.0vw;
    }
    
    .index_staff ul .circle_btn{
        margin: 0 0 0;
        position: absolute;
        right: -13.2vw;
        bottom: -5.0vw;
        text-align: right;
    }
    
    .index_staff ul .circle_btn a{
        min-width: 20vw;
    }


    /* recruit_information
       ================================================================== */
    .recruit_information{
    	margin: 10.0vw 0 0;
    }
    
    .recruit_information .inner{
    	max-width: 1500px;
    }
    
    .recruit_information .photo_box{
    	margin: 3.5vw 0 0;
    }
    
    .recruit_information .photo_box a{
    	overflow: hidden;
        position: relative;
    }
    
    .recruit_information .photo_box a::before{
        content: "";
        background: rgba(255,255,255,.35);
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
        transition: .3s ease;
        opacity: 0;
        z-index: 1;
    }
    
    .recruit_information .photo_box a:hover::before{
        opacity: 1;
    }
    
    .recruit_information .photo_box .photo{
    	transition: .3s ease;
    }
    
    .recruit_information .photo_box a:hover .photo{
    	transform: scale(1.05);
    }
    
    .recruit_information .photo_box .text{
        left: -.2vw;
        bottom: -.2vw;
        width: 90%;
        z-index: 2;
    }
    
    .recruit_information .text_box{
    	padding: 3.0vw 0 0;
        text-align: right;
    }
    
    .recruit_information .text_box h3{
    	font-size: 1.7vw;
    }
    
    .recruit_information .text_box p{
    	margin: 2.0vw 0 0;
        line-height: 2.5vw;
    }
    
    .recruit_information .text_box .circle_btn{
    	margin: 2.0vw 0 0;
    }


    /* construction_list_page
       ================================================================== */
    .construction_list_page{
    	padding: 10.8vw 0 19.0vw;
    }
    
    .construction_list > li{
    	margin: 5.0vw 0 0;
        padding: 5.0vw;
        border-width: 5px;
    }
    
    .construction_photo_slider .photo{
        height: 45.0vw;
    }
    
    .construction_list .bottom_box{
    	margin: 2.6vw 0 0;
    }
    
    .construction_list .site{
        margin: 1.0vw 0 0;
    	font-size: 1.5vw;
    }
    
    .construction_list .title{
        margin: .5vw 0 0;
    	font-size: 3.5vw;
    }
    
    .construction_list .text{
        margin: 1.0vw 0 0;
        line-height: 2.7vw;
    }
 	

	/* pagination
	   ================================================================== */
	.pagination{
		margin: 14.5vw 0 0;
		padding: 0;
	}

    .pagination a,
    .pagination .active span{
    	padding: 1px 0 0;
    }
	
	.pagination a:hover{
		background: #0095DA;
	}


    /* projec_message
       ================================================================== */
    .projec_message{
    	padding: 10.0vw 0 11.2vw;
    }
    
    .projec_message .block_title + .check_list{
    	margin: 3.7vw 0 0;
    }
    
    .projec_message .border_box{
    	margin: 7.5vw 0 0;
        padding: 2.8vw 3.0vw 4.0vw;
    }
    
    .projec_message .border_box h4{
    	font-size: 2.4vw;
    }
    
    .projec_message .border_box .check_list{
    	margin: .5vw 0 0;
    }


    /* project_page
       ================================================================== */
    .project_page{
    	padding: 10.0vw 0 20.0vw;
    }
    
    .project_list > li{
    	margin: 10.0vw 0 0;
    }
    
    .project_list .title{
        padding: 2.0vw 0;
    }
    
    .project_list .title::before{
        width: 20.0vw;
    }
    
    .project_list .title .num{
    	font-size: 5.0vw;
    }
    
    .project_list .title .txt{
        padding: .5vw 0 0 2.0vw;
    	font-size: 2.2vw;
    }
    
    .project_list .flex_column{
        margin: 2.5vw 0 0;
        display: flex;
    }
    
    .project_list .flex_column .left{
        width: 35.0vw;
    }
    
    .project_list .flex_column .right{
        margin: 0 0 0;
        padding: 0 0 0 2.5vw;
        width: calc(100% - 35.0vw);
        box-sizing: border-box;
    }
    
    .project_list .flex_column .pdf_btn{
        margin: 2.2vw 0 0;
    }
    
    .project_list .applying{
        margin: 2.5vw 0 0;
        padding: 6.1vw 1.0vw;
        font-size: 1.6vw;
    }


    /* message
       ================================================================== */
    .message{
    	padding: 10.0vw 0 25.0vw;
    }
    
    .message p{
    	margin: 3.0vw 0 0;
        line-height: 3.5vw;
    }
    
    .message .name{
    	margin: 4.5vw 0 0 auto;
        width: 17.4vw;
    }

    .message_bg{
    	margin: -15vw 0 0 auto;
        width: 95vw;
    }

    .message_bg .bg{
        height: 36.0vw;
        background-image: url("/wp-content/themes/building/img/message_bg_sp.webp");
        background-position: center bottom;
        background-repeat: no-repeat;
        background-size: cover;
    }

    .message_bg .bg img{
    	display: none;
    }


    /* company
       ================================================================== */
    .company{
    	padding: 12vw 0 17vw;
    }
    
    .company_block .profile_box{
        margin: 5vw 0 0;
    }
    
    
    /* history
       ================================================================== */
    .history{
    	padding: 10vw 0;
    }
    
    .company_block .history_box{
        margin: 2.5vw 0 0;
    }
    
    .company_block .history_box ul > li{
        padding: 1.1vw 2.0vw;
        display: flex;
    }
    
    .company_block .history_box ul .date,
    .company_block .history_box ul p{
        font-size: 1.5vw;
        line-height: 4.3vw;
        box-sizing: border-box;
    }
    
    .company_block .history_box ul .date{
        width: 19.5vw;
    }
    
    .company_block .history_box ul p{
        margin: 0 0 0;
        width: calc(100% - 19.5vw);
    }


    /* news_list_block
       ================================================================== */
    .news_list_block{
        padding: 8.0vw 0 16vw;
    }

    .news_list > li .btn_box{
        padding: 2vw 6vw 2vw 2vw;
    }
    
    .news_list > li .btn_box::after{
        width: 1vw;
        height: 3vw;
        top: 3vw;
        bottom: 0;
        right: 2vw;
    }

    .news_list > li .show_box .photo{
    	margin-top: 2vw;
    	margin-bottom: 2vw;
    }
    
    .news_list > li .date{
    	font-size: 16px;
    }
    
    .news_list > li .title{
        margin: 1vw 0 0;
    	font-size: 16px;
    }

    .news_list > li .show_box{
        padding: 0 2vw 2.5vw;
    }

    .news_list > li .show_box .detail_body{
        padding: 0 2vw;
    }
    
    .news_list_block .more_btn{
    	margin: 12vw 0 0;
    }
    
    .news_list > li .btn_box::after{
        transition: all cubic-bezier(0.77, 0, 0.175, 1) 0.3s;
    }
    
    .news_list > li .btn_box .date,
    .news_list > li .btn_box .title{
        transition: .3s;
    }
 	
    .news_list > li .btn_box:hover::after{
        opacity: .3;
    }
    
    .news_list > li .btn_box:hover .date,
    .news_list > li .btn_box:hover .title{
        color: #0095DA;
    }


    /* contact_block
       ================================================================== */
    .contact_block{
    	margin: 10vw 0 16vw;
    }
    
    .contact_block .inner{
    	padding: 0 2vw;
    }


    /* contact
       ================================================================== */
    /* form */
    .contact{
        margin: 0 auto;
    	padding: 0 0 0;
        width: 70.0vw;
    }
    
    .contact .top_text{
        margin: 0 0 0;
        font-size: 1.4vw;
    }
    
    .conf_text{
        margin: 0 0 0;
    	font-size: 1.5vw;
    }
    
    .contact table{
        margin: 7vw 0 0;
    }
    
    .contact th,
    .contact td{
        width: auto;
    	font-size: 15px;
    }
    
    .contact th{
    	padding: 0 0 0;
        box-sizing: border-box;
    }
    
    .contact .title_top th{
    	padding-top: 31px;
        vertical-align: top;
    }
    
    .contact td{
    	padding: 17px 0 18px;
    }
    
    .contact output,
    .contact input,
    .contact select,
    .contact textarea{
    	margin: 0;
    	font-size: 16px;
    	padding: 15px;
    }
	
	.contact select{
		vertical-align: middle;
	}
    
    .contact textarea{
        height: 235px;
    }

    .contact textarea.height120{
        height: 120px;
    }
    
    /* ラジオボタン */
    .contact .radio_input{
        padding: 17px 0 2px;
    }

    .contact .radio_input output{
        margin: 0 0 15px;
    }
    
    .radio_input label{
        margin: 0 10px 15px 0;
    	display: inline-flex;
        align-items: center;
    }
    
    input[type='checkbox'] ,
    input[type='radio'] {
        appearance: none;
        outline: none;
        display: block;
        position: relative;
        text-align: center;
        cursor: pointer;
        width: 18px;
        height: 18px;
    	margin: 0 10px 0 0;
        font-size: 0;
        padding: 0;
        border: none;
    }
    
    input[type='checkbox']::before ,
    input[type='radio']::before {
        width: 18px;
        height: 18px;
    }
    
    input[type='checkbox']::after ,
    input[type='radio']::after {
        left: 5px;
        top: 5px;
        width: 10px;
        height: 10px;
    }
    
    /* ラジオボタン */
    .contact .radio_input{
        padding: 20px 0 15px;
    }

    .contact .radio_input output{
        margin: 0 0 15px;
    }
    
    .radio_input label{
        margin: 0 20px 15px 0;
    	display: inline-flex;
        align-items: center;
    }

    /* 郵便番号 */
    .address output,
    .address input{
        width: 125px;
    }

    /* 都道府県 */
    .prefectures output,
    .prefectures select{
        width: 250px;
    }

    /* ⽣年⽉⽇ */
    .birth .flex p{
        margin: 0 20px;
        font-size: 15px;
    }
    
    .zas_btn_area{
    	margin: auto;
    	text-align: center;
    	padding: 40px 0 0;
    	font-size: 0;
    	box-sizing: border-box;
    }
    
    .zas_btn_area button{
    	font-size: 16px;
    	color: #FFF;
    	border: 2px solid #0095DA;
    	position: relative;
    	overflow: hidden;
    	text-align: center;
        transition: .3s;
        cursor: pointer;
    }
    
    .zas_btn_area button span{
    	padding: 12px 0;
    	border: none;
    	display: block;
    	font-size: 16px;
        transition: .3s;
    }
    
    .zas_btn_area .zas_btn01 button{
    	width: 50%;
    	max-width: 280px;
    }
    
    .zas_btn_area .zas_btn02 button{
    	margin-right: 2%;
    	width: 28%;
        border-color: #ccc;
    }
    
    .zas_btn_area .zas_btn03 button{
    	width: 50%;
    	max-width: 280px;
    }
    
    .zas_btn_area .zas_btn01 button:hover,
    .zas_btn_area .zas_btn03 button:hover{
    	background: #fff;
    }
    
    .zas_btn_area .zas_btn02 button:hover{
    	opacity: .5;
    }
    
    .zas_btn_area .zas_btn01 button:hover span,
    .zas_btn_area .zas_btn03 button:hover span{
    	color: #0095DA;
    }


    /* thanks
       ================================================================== */
    .thanks p{
        margin: 0 0 0;
    	font-size: 1.6vw;
        line-height: 3.9vw;
        text-align: center;
    }
    
    .thanks .go_top_btn{
    	margin: 6vw 0 0;
    }


    /* recruit_top
       ================================================================== */
    .recruit_top{
    	margin: 0;
    }
    
    .recruit_top .text_box{
    	padding: 9.0vw 0 29.0vw;
    }
    
    .recruit_top .text_box h3{
    	font-size: 3.8vw;
        line-height: 6.0vw;
    }
    
    .recruit_top .text_box p{
    	margin: 3.0vw 0 0;
        line-height: 2.5vw;
    }
    
    .recruit_top .recruit_move{
    	margin: -23.5vw 0 0;
    }
    
    .recruit_top .recruit_move .inner{
    	padding: 0 2.0vw;
    }

    .recruit_top .recruit_move .bg_box{
        padding: 8.0vw 5.0vw;
        width: 62.5%;
        position: relative;
    }
    
    .recruit_top .recruit_move .bg_box::before{
        content: "";
        background: #0D131C;
        width: 100vw;
        height: 100%;
        position: absolute;
        top: 0;
        right: 100%;
    }
    
    .recruit_top .recruit_move video{
    	width: 50.0vw;
    }


    /* job_information
       ================================================================== */
    .job_information{
    	margin: 0;
    	padding: 11.2vw 0 9.3vw;
    }
    
    .job_information .bg_title{
    	margin: 5.2vw 0 0;
    }
    
    .job_information .common_table{
    	margin: 2.5vw 0 0;
    }
    
    .bg_title{
        padding: 1.4vw 2.0vw;
        font-size: 1.8vw;
    }


    /* recruit_message
       ================================================================== */
    .recruit_message{
    	margin: 0;
    	padding: 9.0vw 0 16.8vw;
    }
    
    .recruit_message .title_box{
    	margin: 0 0 0;
    }
    
    .recruit_message .title_box .flex{
    	display: flex;
        align-items: flex-end;
    }
    
    .recruit_message .title_box .logo{
    	width: 25.0vw;
    }
    
    .recruit_message .title_box .text_list{
    	margin: 0 0 0;
        padding: 2.0vw 0 0 4.6vw;
        width: calc(100% - 25.0vw);
        box-sizing: border-box;
    }
    
    .recruit_message .title_box .text_list > li{
    	padding: 3.0vw 0 1.5vw;
        max-width: 61.5vw;
        box-sizing: border-box;
    }
    
    .recruit_message .title_box .text_list .num{
    	font-size: 2.3vw;
    }
    
    .recruit_message .title_box .text_list .txt{
        padding: 0 0 0 1.4vw;
    	font-size: 3.0vw;
    }
    
    .recruit_message .title_box .bottom_text{
        margin: 4.0vw 0 0;
    	font-size: 5.0vw;
    }
    
    .recruit_message .title_box .bottom_text .siz_l{
        font-size: 6.5vw;
    }
    
    .recruit_message .title_box .photos_list_5{
        margin-top: 5.4vw;
    }
    
    /* photos_list_5 */
    .photos_list_5{
        margin-left: 0;
        margin-right: 0;
        display: flex;
        justify-content: space-between;
    }
    
    .photos_list_5 > li{
        margin: 0 0 0;
        width: 18.4%;
        display: block;
    }
    
    .photos_list_5.square > li{
        margin-top: 0;
    }
    
    .photos_list_5 > li:nth-child(3){
        margin-left: 0;
        margin-right: 0;
    }
    
    /* photos_list_3*/
    .photos_list_3{
        font-size: 0;
        text-align: left;
    }
    
    .photos_list_3 > li{
        margin: 2.0vw 2% 0 0;
        width: 32%;
    }
    
    .photos_list_3 > li:nth-child(2n+2){
        margin-right: 2%;
    }
    
    .photos_list_3 > li:nth-child(3n+3){
        margin-right: 0;
    }
    
    /* bottom_box*/
    .recruit_message .bottom_box{
    	margin: 5.5vw 0 0;
    }
    
    .recruit_message .bottom_box .message_list{
    	margin: 1.0vw 0 0;
        font-size: 0;
    }
    
    .recruit_message .bottom_box .message_list li{
    	margin: 2.5vw 2% 0 0;
        padding: 3.0vw;
        width: 49%;
        min-height: 16.0vw;
        display: inline-block;
        vertical-align: top;
        box-sizing: border-box;
    }
    
    .recruit_message .bottom_box .message_list li:nth-child(2n+2){
    	margin-right: 0;
    }
    
    .recruit_message .bottom_box .message_list li h4{
    	font-size: 2.5vw;
    }
    
    .recruit_message .bottom_box .message_list li p{
    	margin: 1.0vw 0 0;
        line-height: 3.0vw;
    }

    .recruit_message .bottom_box .photos_list_5{
    	margin: 3.5vw 0 0;
    }
    
    .recruit_message .bottom_box .message_text_box{
    	margin: 4.0vw 0 0;
        padding: 2.7vw 3.0vw;
    }
    
    .recruit_message .bottom_box .message_text_box h3{
    	font-size: 3.0vw;
        line-height: 5.0vw;
    }
    
    .recruit_message .bottom_box .message_text_box p{
    	margin: 2.0vw 0 0;
        line-height: 3.0vw;
    }

    
    /* contact_block recruit_page
       ================================================================== */
    .recruit_page.contact_block{
    	margin: 15.0vw 0 17.5vw;
    }
    
    .recruit_page.contact_block .block_title{
        margin: 0 0 6.7vw;
    }


    /* staff_block
       ================================================================== */
    .staff_block{
    	margin: 0 0 0;
        padding: 8.5vw 0 12.0vw;
    }
    
    .staff_block h2{
        padding: 0 0 5.0vw;
        font-size: 4.0vw;
        letter-spacing: 0.2em;
    }
    
    .staff_block h2::before{
        width: 10.0vw;
        height: 4px;
    }
    
    .staff_block h2 .siz_l{
        font-size: 5.0vw;
    }
    
    /* sticky_wrap */
    .staff_block .sticky_wrap{
        padding: 5.0vw 0 0;
    }
    
    .staff_block .sticky_wrap .sticky_box{
        margin: 0 0 0 auto;
        padding: 0 0 3.0vw;
        position: sticky;
        top: 10.0vw;
        right: 0;
        height: 50.0vw;
    }
    
    .staff_block .sticky_wrap .contents_box{
        margin-top: -50.0vw;
    }
    
    /* staff_profile */
    .staff_profile{
        margin: 0 0 0;
    }
    
    .staff_profile h3{
        font-size: 2.5vw;
    }
    
    .staff_profile .pc_flex{
        margin: 3.5vw 0 0;
        display: flex;
    }
    
    .staff_profile .photo_box.pc{
        width: 25.0vw;
        height: auto;
    }
    
    .staff_profile .text_box{
        margin: 0 0 0;
        padding: 0 0 0 5.5vw;
        width: calc(100% - 25.0vw);
        box-sizing: border-box;
    }
    
    .staff_profile .text_box .sp_flex{
        display: block;
    }
    
    .staff_profile .text_box .sp_flex .photo{
        display: none;
    }
    
    .staff_profile .text_box .sp_flex h4{
        padding: 0 0 0;
        width: 100%;
    }
    
    .staff_profile .text_box .sp_flex h4 .jpn{
        font-size: 2.3vw;
    }
    
    .staff_profile .text_box .sp_flex h4 .eng{
        margin: .5vw 0 0;
        font-size: 1.5vw;
    }
    
    .staff_profile .text_box .top_box{
        margin: 1.7vw 0 0;
    }

    .staff_profile .text_box p{
        line-height: 2.5vw;
    }

    .staff_profile .text_box p + p{
        margin: 1.0vw 0 0;
    }
    
    .staff_profile .text_box p.f14{
        font-size: 1.4vw;
    }
    
    .staff_profile .bottom_box{
        margin: 4.5vw 0 0;
        padding: 2.0vw 0 0;
        position: relative;
    }
    
    .staff_profile .bottom_box::before{
        height: 2.5vw;
        left: 2.0vw;
    }
    
    /* staff_message / staff_important */
    .staff_message.about{
        margin: 20.0vw 0 0;
    }
    
    .staff_message .bg{
        margin: 0 auto;
    }
    
    .staff_message.about .bg{
        padding: 0 0 26.0vw;
    }
    
    .staff_message.about .bg::before{
        content: "";
        background: #0D131C;
        width: 100vw;
        height: 100%;
        position: absolute;
        top: 0;
        right: 5vw;
    }
    
    .staff_message .inner{
        padding: 0 8.0vw 0 5.0vw;
    }
    
    .staff_message .photo{
        margin: -12.0vw 0 0;
        width: 100%;
    }
    
    .staff_message .photo img{
        width: 95.0vw;
        max-width: 90%;
    }
    
    .staff_message ul{
        margin: 0 0 0;
        width: auto !important;
    }
    
    .staff_message ul > li{
        margin: 7.0vw 0 0;
    }
    
    .staff_message ul h4{
        font-size: 3.0vw;
    }
    
    .staff_message ul h4 .num{
        margin: 0 0 0 2.0vw;
        font-size: 4.5vw;
    }
    
    .staff_message ul p{
        margin: 2.5vw 0 0;
        line-height: 3.5vw;
    }
    
    /* futures */
    .futures{
        margin: 10.0vw 0 0;
    }
    
    .futures .bg{
        margin: 0 auto;
        padding: 4.5vw 0 4.5vw 5.0vw;
        box-sizing: border-box;
    }
    
    .futures .bg::before{
        content: "";
        background: #0D131C;
        width: 100vw;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
    }
    
    .futures .inner{
        padding: 0;
        position: relative;
        z-index: 2;
    }
    
    .futures .pc_flex{
        margin: 0 0 0;
        display: flex;
    }
    
    .futures .photo_box.pc{
        width: 25.0vw;
    }
    
    .futures .text_box{
        margin: 0 0 0;
        padding: 0 0 0 4.3vw;
        width: calc(100% - 25.0vw);
        box-sizing: border-box;
    }
    
    .futures .text_box .sp_flex{
        display: block;
    }
    
    .futures .text_box .sp_flex .photo{
        display: none;
    }
    
    .futures .text_box .sp_flex h4{
        padding: 0 0 0;
        width: 100%;
        font-size: 3.0vw;
    }
    
    .futures .text_box p{
        margin: 2.5vw 0 0;
        line-height: 3.5vw;
    }

    
}
@media screen and (min-width : 1040px){    


    /* kv
       ================================================================== */
    .kv .inner{
    	padding: 0 20px 225px;
        max-width: 1040px;
    	height: 100vh;
        max-height: calc(100vh - 60px);
        min-height: 600px;
    }
    
    .kv h2 .block,
    .kv h2 .block > span{
        font-size: 35px;
        line-height: 70px;
    }
    
    .kv h2 .block .siz_l{
        font-size: 40px;
    }
    
    #loopslider{
        bottom: 318px;
    }
    
    #loopslider li{
        margin-right: 80px;
        font-size: 203px;
    }


    /* video
       ================================================================== */
    #bg_movie{
        min-width: 100%;
        height: 100%;
        min-height: 100%;
    }


    /* under_kv
       ================================================================== */
    .under_kv{
    	margin: 0 0 0;
    }
    
    .under_kv .inner{
        height: 550px;
        max-width: 2000px;
        padding: 0 65px 50px;
    }
    
    .under_kv.staff .inner{
        padding-bottom: 50px;
        height: 650px;
    }
    
    .under_kv h2 .eng{
        padding: 0 0 10px;
        font-size: 25px;
    }
    
    .under_kv.staff h2 .eng{
        min-width: 260px;
    }
    
    .under_kv h2 .jpn{
        margin: 10px 0 0;
        font-size: 52px;
    }
    
    .under_kv .name{
        margin: 5px 0 0;
        font-size: 35px;
    }

    .under_kv .staff_message{
        margin: auto;
        padding: 0 50px;
        max-width: 1500px;
        position: absolute;
        top: 220px;
        right: 0;
        left: 0;
        justify-content: flex-end;
        box-sizing: border-box;
    }

    .under_kv .staff_message.posi_center{
        top: 50%;
    }

    .under_kv.text_position_top .staff_message.posi_center{
        top: 34%;
    }
    
    .under_kv .staff_message ul li{
        margin: 0 0 0 20px;
        width: 62px;
    }
    
    .under_kv .staff_message ul li > span{
        padding: 25px 8px;
        font-size: 31px;
        line-height: 150%;
        letter-spacing: 0.3em;
    }


    /* index_news
       ================================================================== */
    .index_news{
    	margin: -60px 0 0;
        padding: 0 0 60px;
    }
    
    .index_news .inner{
        margin: 0 auto;
        width: 1040px;
    }
    
    .index_news .flex{
        margin: 0 0 0 auto;
        padding: 26px 0;
        width: 73.7%;
        height: 120px;
        box-sizing: border-box;
        display: flex;
        align-items: center;
        position: relative;
    }
    
    .index_news .left{
        margin: 0 0 0;
        padding: 0 0 0 40px;
        width: 187px;
        height: 70px;
        box-sizing: border-box;
    }
    
    .index_news h2{
        font-size: 23px;
    }
    
    .index_news .right{
        margin: 0 0 0;
        padding: 0 0 0 40px;
        width: calc(100% - 187px);
        height: 70px;
        display: flex;
        align-items: center;
    }
    
    .index_news .right::before{
        width: 1px;
        height: 100%;
        top: 0;
        left: 0;
    }
    
    .index_news .right a span, .index_news .right time{
        font-size: 13px;
    }
    
    .index_news .right .title,.index_news .right h3.title{
        margin: 13px 0 0;
		font-size:13px;
    }
    
    .index_news .view_more_btn{
        margin: 0;
        position: absolute;
        top: 74px;
        left: 0;
    }


    /* index_philosophy
       ================================================================== */
    .index_philosophy{
    	margin: 0 0 0;
    }
    
    .index_philosophy .inner{
        height: 850px;
    }
    
    .index_philosophy .logo{
        margin: 0 auto;
        width: 170px;
    }
    
    .index_philosophy .txt{
        top: 165px;
        right: 50px;
    }
    
    .index_philosophy .txt li{
        margin: 0 0 0 30px;
        font-size: 23px;
        letter-spacing: 0.7em;
    }


    /* index_about
       ================================================================== */
    .index_about{
    	margin: 110px 0 0;
    }
    
    .index_about ul{
    	margin: 64px auto 0;
        display: flex;
        justify-content: space-between;
    }
    
    .index_about ul li{
    	margin: 0 0 0 0;
        width: calc((100% / 3) - 25px);
    }
    
    .index_about ul li:last-child{
    	margin-right: 0;
    }
    
    .index_about ul .photo{
    	height: 220px;
    }
    
    .index_about ul .text_box{
    	padding: 22px 10px 0;
    }
    
    .index_about ul h3{
        font-size: 22px;
        line-height: 50px;
        letter-spacing: 0.2em;
    }
    
    .index_about ul p{
        margin: 5px 0 0;
        font-size: 14px;
        line-height: 25px;
    }


    /* index_construction
       ================================================================== */
    .index_construction{
    	margin: 90px 0 0;
        position: relative;
    }
    
    .index_construction .inner{
        padding-top: 440px;
        position: relative;
    }
    
    .index_construction .block_title{
    	margin: 0;
        position: absolute;
        right: 20px;
        top: 210px;
        z-index: 1;
    }
    
    .index_construction .block_title .eng{
    	font-size: 60px;
    }
    
    .index_construction .block_title .jpn{
    	padding-left: 275px;
    }
    
    .index_construction .bg{
    	margin: 0;
        position: absolute;
        right: 221px;
        top: 0;
        height: 400px;
        width: 100vw;
    }
    
    .index_construction .circle_btn{
    	margin: 30px 0 0;
    }
    
    
    /* cat_list
       ================================================================== */
    .cat_list{
    	font-size: 0;
    }
    
    .cat_list li{
    	margin: 0 10px 10px 0;
    }
    
    .cat_list li a{
    	padding: 5px 25px;
        font-size: 13px;
    }


    /* bg_sections_wrap
       ================================================================== */
    .bg_sections_wrap{
    	margin: 110px 0 0;
        padding: 137px 0 135px;
    }


    /* index_message
       ================================================================== */
    .index_message{
    	margin: 0 0 0;
        position: relative;
    }
    
    .index_message .inner{
        width: 100%;
        max-width: 1920px;
    }
    
    .index_message .main{
    	display: flex;
    }
    
    .index_message .main .text_box{
        padding: 25px 0 0;
        width: 25%;
    	display: flex;
        justify-content: center;
    }
    
    .index_message .main .text_box h2{
        display: flex;
    }
    
    .index_message .main .text_box h2 > span{
        margin: 0 5px;
        font-size: 35px;
        line-height: 150%;
        letter-spacing: .6em;
    }
    
    .index_message .main .photo_box{
        width: 75%;
    }
    
    .index_message .main .photo_box .photo{
        width: 100%;
        height: auto;
        background-image: none;
    }
    
    .index_message .main .photo_box .photo img{
    	display: block;
    }
    
    .index_message .main .photo_box .name{
        margin: 0 0 0;
        position: absolute;
        top: 20%;
        right: 5%;
    }
    
    .index_message .main .photo_box .name .eng{
        font-size: 58px;
    }
    
    .index_message .main .photo_box .name .jpn{
        margin: 15px 0 0 10px;
        font-size: 30px;
    }
    
    .index_message .bottom{
        margin: -85px 0 0;
        display: flex;
        position: relative;
        z-index: 1;
    }
    
    .index_message .bottom .photo{
        padding: 0 0 0 10%;
        width: 40%;
        box-sizing: border-box;
    }
    
    
    .index_message .bottom .text_box{
        padding: 170px 20px 0 108px;
        width: calc(100% - 40%);
    }
    
    .index_message .bottom .text_box .kumamoto{
        width: 342px;
    }
    
    .index_message .bottom .text_box h3{
        margin: 35px 0 0;
        font-size: 30px;
        line-height: 50px;
    }
    
    .index_message .bottom .text_box p{
        margin: 35px 0 0;
        line-height: 30px;
        max-width: 460px;
    }
    
    .index_message .bottom .text_box .circle_btn{
        margin: 40px 0 0;
    }


    /* index_staff
       ================================================================== */
    .index_staff{
    	margin: 153px 0 0;
    }
    
    .index_staff .inner{
        padding: 0;
        width: 100%;
        max-width: 1920px;
    }
    
    .index_staff .inner::before{
        width: 60%;
        left: 40%;
    }
    
    .index_staff .top_box{
    	margin: 0 0 0 auto;
        padding: 0 0 0 70px;
        padding-top: 95px;
        padding-bottom: 155px;
        position: sticky;
        top: 0;
        right: 0;
        display: flex;
        justify-content: center;
        width: 30%;
        height: 850px;
        box-sizing: border-box;
    }
    
    .index_staff .top_box h2{
        font-size: 40px;
        line-height: 180%;
        font-weight: 500;
        letter-spacing: 0.5em;
        writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        white-space: nowrap;
    }
    
    .index_staff .top_box .txt.pc{
        margin: 0 15px 0 0;
        display: flex;
        width: 80px;
    }
    
    .index_staff .top_box p{
        font-size: 16px;
        line-height: 250%;
        letter-spacing: 0.4em;
        writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        white-space: nowrap;
    }
    
    .index_staff ul{
        margin: -850px 0 0;
        padding-top: 95px;
        padding-bottom: 155px;
        width: 70%;
    }
    
    .index_staff ul li{
        margin: 85px 0 0;
        position: relative;
    }
    
    .index_staff ul .text_box{
        padding: 0 0 40px 40px;
        position: absolute;
        bottom: 0;
        left: 0;
    }
    
    .index_staff ul .text_box .name .eng{
        font-size: 45px;
    }
    
    .index_staff ul .text_box .name .jpn{
        margin: 20px 0 0;
        font-size: 22px;
    }
    
    .index_staff ul .text_box .catch{
        margin: 10px 0 0 -20px;
    }
    
    .index_staff ul .text_box .catch,
    .index_staff ul .text_box .catch > span{
        font-size: 40px;
    }
    
    .index_staff ul .text_box .catch .siz_l{
        font-size: 50px;
    }
    
    .index_staff ul .circle_btn{
        margin: 0 0 0;
        position: absolute;
        right: -132px;
        bottom: -50px;
        text-align: right;
    }
    
    .index_staff ul .circle_btn a{
        min-width: 200px;
    }


    /* recruit_information
       ================================================================== */
    .recruit_information{
    	margin: 100px 0 0;
    }
    
    .recruit_information .photo_box{
    	margin: 35px 0 0;
    }
    
    .recruit_information .photo_box .text{
        left: -3px;
        bottom: -2px;
        width: 90%;
    }
    
    .recruit_information .text_box{
    	padding: 30px 0 0;
        text-align: right;
    }
    
    .recruit_information .text_box h3{
    	font-size: 17px;
    }
    
    .recruit_information .text_box p{
    	margin: 20px 0 0;
        line-height: 25px;
    }
    
    .recruit_information .text_box .circle_btn{
    	margin: 20px 0 0;
    }


    /* construction_list_page
       ================================================================== */
    .construction_list_page{
    	padding: 108px 0 190px;
    }
    
    .construction_list > li{
    	margin: 50px 0 0;
        padding: 50px;
        border-width: 5px;
    }
    
    .construction_photo_slider .photo{
        height: 450px;
    }
    
    .construction_list .bottom_box{
    	margin: 26px 0 0;
    }
    
    .construction_list .site{
        margin: 10px 0 0;
    	font-size: 15px;
    }
    
    .construction_list .title{
        margin: 5px 0 0;
    	font-size: 35px;
    }
    
    .construction_list .text{
        margin: 10px 0 0;
        line-height: 27px;
    }

	/* pagination
	   ================================================================== */
	.pagination{
		margin: 145px 0 0;
		padding: 0;
	}

    .pagination a,
    .pagination .active span{
        padding: 2px 0 0;
    	font-size: 15px;
    	width: 40px;
    	height: 40px;
    }


    /* projec_message
       ================================================================== */
    .projec_message{
    	padding: 100px 0 112px;
    }
    
    .projec_message .block_title + .check_list{
    	margin: 37px 0 0;
    }
    
    .projec_message .border_box{
    	margin: 75px 0 0;
        padding: 28px 30px 40px;
    }
    
    .projec_message .border_box h4{
    	font-size: 24px;
    }
    
    .projec_message .border_box .check_list{
    	margin: 5px 0 0;
    }


    /* project_page
       ================================================================== */
    .project_page{
    	padding: 100px 0 200px;
    }
    
    .project_list > li{
    	margin: 100px 0 0;
    }
    
    .project_list .title{
        padding: 20px 0;
    }
    
    .project_list .title::before{
        width: 200px;
    }
    
    .project_list .title .num{
    	font-size: 50px;
    }
    
    .project_list .title .txt{
        padding: 5px 0 0 20px;
    	font-size: 22px;
    }
    
    .project_list .flex_column{
        margin: 25px 0 0;
        display: flex;
    }
    
    .project_list .flex_column .left{
        width: 350px;
    }
    
    .project_list .flex_column .right{
        margin: 0 0 0;
        padding: 0 0 0 25px;
        width: calc(100% - 350px);
        box-sizing: border-box;
    }
    
    .project_list .flex_column .pdf_btn{
        margin: 22px 0 0;
    }
    
    .project_list .applying{
        margin: 25px 0 0;
        padding: 61px 10px;
        font-size: 16px;
    }


    /* message
       ================================================================== */
    .message{
    	padding: 100px 0 450px;
    }
    
    .message p{
    	margin: 30px 0 0;
        line-height: 35px;
    }
    
    .message .name{
    	margin: 45px 0 0 auto;
        width: 174px;
    }

    .message_bg{
    	margin: -335px 0 0 0;
        width: 100%;
    }

    .message_bg .bg{
        width: 100vw;
        height: 500px;
        background-image: url("/wp-content/uploads/2025/11/message_bg_sp.webp");
        background-position: center center;
        background-repeat: no-repeat;
        background-size: cover;
    }


    /* company
       ================================================================== */
    .company{
    	padding: 120px 0 170px;
    }
    
    .company_block .profile_box{
        margin: 50px 0 0;
    }
    
    
    /* history
       ================================================================== */
    .history{
    	padding: 100px 0;
    }
    
    .company_block .history_box{
        margin: 25px 0 0;
    }
    
    .company_block .history_box ul > li{
        padding: 11px 20px;
        display: flex;
    }
    
    .company_block .history_box ul .date,
    .company_block .history_box ul p{
        font-size: 15px;
        line-height: 43px;
        box-sizing: border-box;
    }
    
    .company_block .history_box ul .date{
        width: 195px;
    }
    
    .company_block .history_box ul p{
        margin: 0 0 0;
        width: calc(100% - 195px);
    }


    /* news_list_block
       ================================================================== */
    .news_list_block{
        padding: 80px 0 160px;
    }

    .news_list > li{
        margin: -100px 0 0;
        padding: 100px 0 0;
    }
    
    .news_list > li .btn_box{
        padding: 20px 50px 20px 20px;
    }
    
    .news_list > li .btn_box::after{
        width: 10px;
        height: 21px;
        top: 15px;
        bottom: 0;
        right: 21px;
    }

    .news_list > li .show_box .photo{
    	margin-top: 12px;
    	margin-bottom: 20px;
    }
    
    .news_list > li .date{
    	font-size: 16px;
    }
    
    .news_list > li .title{
        margin: 8px 0 0;
    	font-size: 16px;
    }

    .news_list > li .show_box{
        padding: 0 20px 25px;
    }

    .news_list > li .show_box .detail_body{
        padding: 0 20px 0 0px;
    }
    
    .news_list_block .more_btn{
    	margin: 120px 0 0;
    }


    /* contact_block
       ================================================================== */
    .contact_block{
    	margin: 100px 0 160px;
    }
    
    .contact_block .inner{
    	padding: 0;
    }


    /* contact
       ================================================================== */
    /* form */
    .contact{
        margin: 0 auto;
    	padding: 0 0 0;
        width: 700px;
    }

    .contact form{
    	margin-top: -140px;
        padding-top: 140px;
    }
    
    .contact .top_text{
        margin: 0 0 0;
    	font-size: 14px;
    }
    
    .conf_text{
        margin: 0 0 0;
    	font-size: 15px;
    }
    
    .contact table{
        margin: 70px 0 0;
    	font-size: 15px;
    }
    
    .contact table td,
    .contact table th{
    	font-size: 15px;
    }
    
    .contact th{
    	padding: 0 0 0;
    }
    
    .contact td{
    	padding: 20px 0 30px;
    }
    
    .contact output,
    .contact input,
    .contact select,
    .contact textarea{
    	font-size: 15px;
    	padding: 19px 25px;
    }
    
    .contact textarea{
        height: 235px;
    }

    .contact textarea.height120{
        height: 120px;
    }

    /* 郵便番号 */
    .address output,
    .address input{
        width: 125px;
    }

    /* 都道府県 */
    .prefectures output,
    .prefectures select{
        width: 250px;
    }

    /* ⽣年⽉⽇ */
    .birth .flex p{
        margin: 0 20px;
        font-size: 15px;
    }

    .birth .w100 select{
        width: 100px;
    }
    
    .zas_btn_area{
    	padding: 60px 0 0;
    }
    
    .zas_btn_area button{
    	font-size: 16px;
    }
    
    .zas_btn_area button > span{
    	padding: 17px 0;
    	font-size: 16px;
    }
    
    .zas_btn_area .zas_btn01 button{
    	width: 280px;
    }
    
    .zas_btn_area .zas_btn02 button{
    	margin-right: 2%;
    	width: 28%;
    }
    
    .zas_btn_area .zas_btn03 button{
    	width: 280px;
    }


    /* thanks
       ================================================================== */
    .thanks p{
        margin: 0 0 0;
    	font-size: 16px;
        line-height: 39px;
    }
    
    .thanks .go_top_btn{
    	margin: 60px 0 0;
    }


    /* recruit_top
       ================================================================== */
    .recruit_top{
    	margin: 0;
    }
    
    .recruit_top .text_box{
    	padding: 90px 0 290px;
    }
    
    .recruit_top .text_box h3{
    	font-size: 38px;
        line-height: 60px;
    }
    
    .recruit_top .text_box p{
    	margin: 30px 0 0;
        line-height: 25px;
    }
    
    .recruit_top .recruit_move{
    	margin: -235px 0 0;
    }
    
    .recruit_top .recruit_move .inner{
    	padding: 0 20px;
    }

    .recruit_top .recruit_move .bg_box{
        padding: 80px 50px;
        width: 62.5%;
    }
    
    .recruit_top .recruit_move video{
    	width: 500px;
    }


    /* job_information
       ================================================================== */
    .job_information{
    	margin: 0;
    	padding: 112px 0 93px;
    }
    
    .job_information .bg_title{
    	margin: 52px 0 0;
    }
    
    .job_information .common_table{
    	margin: 25px 0 0;
    }
    
    .bg_title{
        padding: 14px 20px;
        font-size: 18px;
    }


    /* recruit_message
       ================================================================== */
    .recruit_message{
    	margin: 0;
    	padding: 90px 0 168px;
    }
    
    .recruit_message .title_box{
    	margin: 0 0 0;
    }
    
    .recruit_message .title_box .flex{
    	display: flex;
        align-items: flex-end;
    }
    
    .recruit_message .title_box .logo{
    	width: 250px;
    }
    
    .recruit_message .title_box .text_list{
    	margin: 0 0 0;
        padding: 20px 0 0 46px;
        width: calc(100% - 250px);
        box-sizing: border-box;
    }
    
    .recruit_message .title_box .text_list > li{
    	padding: 30px 0 15px;
        max-width: 615px;
        box-sizing: border-box;
    }
    
    .recruit_message .title_box .text_list .num{
    	font-size: 23px;
    }
    
    .recruit_message .title_box .text_list .txt{
        padding: 0 0 0 14px;
    	font-size: 30px;
    }
    
    .recruit_message .title_box .bottom_text{
        margin: 40px 0 0;
    	font-size: 50px;
    }
    
    .recruit_message .title_box .bottom_text .siz_l{
        font-size: 65px;
    }
    
    .recruit_message .title_box .photos_list_5{
        margin-top: 54px;
    }
    
    /* photos_list_5 */
    .photos_list_5{
        margin-left: 0;
        margin-right: 0;
        display: flex;
        justify-content: space-between;
    }
    
    .photos_list_5 > li{
        margin: 0 0 0;
        width: 18.4%;
        display: block;
    }
    
    .photos_list_5.square > li{
        margin-top: 0;
    }
    
    .photos_list_5 > li:nth-child(3){
        margin-left: 0;
        margin-right: 0;
    }
    
    /* photos_list_3*/
    .photos_list_3{
        font-size: 0;
        text-align: left;
    }
    
    .photos_list_3 > li{
        margin: 20px 2% 0 0;
        width: 32%;
    }
    
    .photos_list_3 > li:nth-child(2n+2){
        margin-right: 2%;
    }
    
    .photos_list_3 > li:nth-child(3n+3){
        margin-right: 0;
    }
    
    /* bottom_box*/
    .recruit_message .bottom_box{
    	margin: 55px 0 0;
    }
    
    .recruit_message .bottom_box .message_list{
    	margin: 10px 0 0;
        font-size: 0;
    }
    
    .recruit_message .bottom_box .message_list li{
    	margin: 25px 2% 0 0;
        padding: 30px;
        width: 49%;
        min-height: 160px;
        display: inline-block;
        vertical-align: top;
        box-sizing: border-box;
    }
    
    .recruit_message .bottom_box .message_list li:nth-child(2n+2){
    	margin-right: 0;
    }
    
    .recruit_message .bottom_box .message_list li h4{
    	font-size: 25px;
    }
    
    .recruit_message .bottom_box .message_list li p{
    	margin: 10px 0 0;
        line-height: 30px;
    }

    .recruit_message .bottom_box .photos_list_5{
    	margin: 35px 0 0;
    }
    
    .recruit_message .bottom_box .message_text_box{
    	margin: 40px 0 0;
        padding: 27px 30px;
    }
    
    .recruit_message .bottom_box .message_text_box h3{
    	font-size: 30px;
        line-height: 50px;
    }
    
    .recruit_message .bottom_box .message_text_box p{
    	margin: 20px 0 0;
        line-height: 30px;
    }

    
    /* contact_block recruit_page
       ================================================================== */
    .recruit_page.contact_block{
    	margin: 150px 0 175px;
    }
    
    .recruit_page.contact_block .block_title{
        margin: 0 0 67px;
    }


    /* staff_block
       ================================================================== */
    .staff_block{
    	margin: 0 0 0;
        padding: 85px 0 120px;
    }
    
    .staff_block h2{
        padding: 0 0 40px;
        font-size: 40px;
        letter-spacing: 0.2em;
    }
    
    .staff_block h2::before{
        width: 100px;
        height: 4px;
    }
    
    .staff_block h2 .siz_l{
        font-size: 50px;
    }
    
    /* sticky_wrap */
    .staff_block .sticky_wrap{
        padding: 50px 0 0;
    }
    
    .staff_block .sticky_wrap .sticky_box{
        margin: 0 0 0 auto;
        padding: 0 0 30px;
        position: sticky;
        top: 100px;
        right: 0;
        height: 500px;
    }
    
    .staff_block .sticky_wrap .contents_box{
        margin-top: -500px;
    }
    
    /* staff_profile */
    .staff_profile{
        margin: 0 0 0;
    }
    
    .staff_profile h3{
        font-size: 25px;
    }
    
    .staff_profile .pc_flex{
        margin: 35px 0 0;
        display: flex;
    }
    
    .staff_profile .photo_box.pc{
        width: 250px;
        height: auto;
    }
    
    .staff_profile .text_box{
        margin: 0 0 0;
        padding: 0 0 0 55px;
        width: calc(100% - 250px);
        box-sizing: border-box;
    }
    
    .staff_profile .text_box .sp_flex{
        display: block;
    }
    
    .staff_profile .text_box .sp_flex .photo{
        display: none;
    }
    
    .staff_profile .text_box .sp_flex h4{
        padding: 0 0 0;
        width: 100%;
    }
    
    .staff_profile .text_box .sp_flex h4 .jpn{
        font-size: 23px;
    }
    
    .staff_profile .text_box .sp_flex h4 .eng{
        margin: 5px 0 0;
        font-size: 15px;
    }
    
    .staff_profile .text_box .top_box{
        margin: 17px 0 0;
    }

    .staff_profile .text_box p{
        line-height: 25px;
    }

    .staff_profile .text_box p + p{
        margin: 10px 0 0;
    }
    
    .staff_profile .text_box p.f14{
        font-size: 14px;
    }
    
    .staff_profile .bottom_box{
        margin: 45px 0 0;
        padding: 20px 0 0;
        position: relative;
    }
    
    .staff_profile .bottom_box::before{
        height: 25px;
        left: 20px;
    }
    
    /* staff_message / staff_important */
    .staff_message.about{
        margin: 200px 0 0;
    }
    
    .staff_message .bg{
        margin: 0 auto;
        max-width: 1290px;
    }
    
    .staff_message.about .bg{
        padding: 0 0 260px;
    }
    
    .staff_message.about .bg::before{
        content: "";
        background: #0D131C;
        width: 100vw;
        height: 100%;
        position: absolute;
        top: 0;
        right: 58px;
    }
    
    .staff_message .inner{
        padding: 0 80px;
        max-width: 1160px;
    }
    
    .staff_message .photo{
        margin: -120px 0 0;
        width: 100%;
    }
    
    .staff_message .photo img{
        width: 950px;
        max-width: 90%;
    }
    
    .staff_message ul{
        margin: 0 0 0 50px;
    }
    
    .staff_message ul > li{
        margin: 70px 0 0;
    }
    
    .staff_message ul h4{
        font-size: 30px;
    }
    
    .staff_message ul h4 .num{
        margin: 0 0 0 20px;
        font-size: 45px;
    }
    
    .staff_message ul p{
        margin: 25px 0 0;
        line-height: 35px;
    }
    
    /* futures */
    .futures{
        margin: 100px 0 0;
    }
    
    .futures .bg{
        margin: 0 auto;
        padding: 45px 0 45px 50px;
        max-width: 1000px;
        box-sizing: border-box;
    }
    
    .futures .bg::before{
        content: "";
        background: #0D131C;
        width: 100vw;
        height: 100%;
        position: absolute;
        top: 0;
        left: 0;
    }
    
    .futures .inner{
        padding: 0;
        position: relative;
        z-index: 2;
    }
    
    .futures .pc_flex{
        margin: 0 0 0;
        display: flex;
    }
    
    .futures .photo_box.pc{
        width: 250px;
    }
    
    .futures .text_box{
        margin: 0 0 0;
        padding: 0 0 0 43px;
        width: calc(100% - 250px);
        box-sizing: border-box;
    }
    
    .futures .text_box .sp_flex{
        display: block;
    }
    
    .futures .text_box .sp_flex .photo{
        display: none;
    }
    
    .futures .text_box .sp_flex h4{
        padding: 0 0 0;
        width: 100%;
        font-size: 30px;
    }
    
    .futures .text_box p{
        margin: 25px 0 0;
        line-height: 35px;
    }
    

}
@media screen and (min-width : 1200px){


    /* index_about
       ================================================================== */
    .index_about ul .photo{
    	height: 300px;
    }
    
    .index_about ul .text_box{
    	padding: 22px 40px 0;
    }


    /* index_construction
       ================================================================== */
    .index_construction .block_title{
        right: -88px;
    }
    
    .index_construction .bg{
        right: 113px;
    }
    
    
}

.news_list > li .date time {
    color: inherit;
}
td.sex [type="radio"] {
	display: inline-block;
}
.text-set-contactform7 {
	padding: 10px !important;
	background: #F8F8F8;
	border: 1px solid #F8F8F8;
	margin-bottom: 2em;
}
input[value="戻る"],input[value="送信する"],input[value="確認画面へ"]{
	background: #0095DA;
	width: 55%;
	max-width: 260px;
	cursor: pointer;
}

input[value="戻る"],input[value="送信する"],input[value="確認画面へ"] {
	font-size: 16px;
	color: #FFF;
	border: none;
	position: relative;
	overflow: hidden;
	text-align: center;
	transition: .3s;
	margin: 1em 0;
}

input[value="戻る"]:hover,input[value="送信する"]:hover,input[value="確認画面へ"]:hover{
	background: #fff;
	color: #0095da;
 box-shadow: 0 0 1px #0095da inset;
}
.wpcf7-spinner {
	display: block;
}