@charset "utf-8";

html{
    font-size: 62.5%;
    scroll-behavior: smooth;
}

/*------------------- base -------------------*/
a:hover{opacity:0.7;}
a{
	text-decoration:none;
    color: #fff;
}
p{
    line-height: 2.6;
    letter-spacing: 0.2rem;
}
@media screen and (max-width: 768px) {
    p{
        line-height: 2;
    }
}
img{
	max-width: 100%;
	height: auto;
}

/*------------------- ここからbody -------------------*/
body{
	font-family: "Noto Sans", sans-serif;
    font-optical-sizing: auto;
    font-weight: weight;
    font-style: normal;
    font-variation-settings:"wdth" 100;
	font-size: 1.6rem;
	color: #45413f;
}
@media screen and (max-width: 768px) {
    body{
        font-size: 1.5rem;
    }
}
/*----- toc上部固定 -----*/
.toc_box{
    width: 190px;
    background-color: #3E5ADE;
    color: #fff;
    padding: 20px 0;
    position: fixed;
    top: 0;
    right: 0;
    z-index: 1;
}
@media screen and (max-width: 768px) {
    .toc_box{
        top: unset;
        bottom: 0;
        left: 0;
        z-index: 2;
        background-color: #3e5adeb5;
    }
}
.toc_box .toc_list :nth-child(2){
    margin: 10px 0;
}
/*----- header -------------------*/
.header{
    width: 100%;
    height: 100vh;
    color: #fff;
    position: relative;
    z-index: 2;
}
.header_inner{
    height: 100%;
    display: flex;
}
/*----- 左ファーストビュー -----*/
.l_container{
    width: calc(100% - 190px);
    height: 100%;
    position: relative;
}
@media screen and (max-width: 768px) {
    .l_container{
        width: 100%;
        position: relative;
    }
}
.logo_sp_on{
    display: none;
}
@media screen and (max-width: 768px) {
    .logo_sp_on{
        display: block;
        filter: opacity(0.8);
        margin: 0;
        max-width: 200px;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 70;
    }
}
.slider_content{
    height: 100%;
    position: relative;
}
@media screen and (max-width: 768px) {
    .slider_content{
        margin-top: 0;
    }
}
.slider_items{
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    animation: slider_fw 18s infinite;
}
.slider_fw1{
    background: url(../images/fw.jpg) center center / cover no-repeat;
    animation-delay: -2s;
}
.slider_fw2{
    background: url(../images/fw2.jpg) center center / cover no-repeat;
    animation-delay: 4s;
}
.slider_fw3{
    background: url(../images/fw3.jpg) center center / cover no-repeat;
    animation-delay: 10s;
}

@keyframes slider_fw{
    0%{
        opacity: 0;
    }
    5.56%{
        opacity: 1; /*--- 1秒 ---*/
    }
    33.36%{
        opacity: 1; /*--- 6秒 ---*/
    }
    44.48%{
        opacity: 0; /*--- 8秒 ---*/
    }
    100%{
        opacity: 0;
    }
}
.top_fw_word{
    position: absolute;
    top: 80px;
    font-size: 6rem;
    font-family: "Zen Maru Gothic", serif;
    font-weight: 400;
    font-style: normal;
    right: 20px;
    text-align: right;
}
@media screen and (max-width: 540px) {
    .top_fw_word{
        display: none;
    }
}
/*----- 右サイドヘッダー -----*/
.r_container{
    width: 190px;
    height: 100%;
    background-color: #3E5ADE;
    padding-top: 30px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    overflow-y: scroll;
}
@media screen and (max-width: 768px) {
    .r_container{
       display: none;
    }
}
.logo2{
    text-align: center;
    margin-bottom: 35px;
}
.toc_list{
    width:fit-content;
    margin: 0 auto;
}
.toc_list :nth-child(2){
    margin: 8px 0;
}
.tel{
    font-size: 1.5rem;
}
/*----- pc_ナビゲーション -----*/
.pc_menu{
    text-align: center;
    margin-top: 35px;
}
.pc_menu .navitem{
    margin-bottom: 30px;
}
/*----- pc_ナビゲーション共通部分 -----*/
.navitem a::after{
    display: block;
    font-size: 1.1rem;
    text-align: center;
}
.navitem_home a::after{
    content: "ホーム";
}
.navitem_about a::after{
    content: "丸喜屋設備㈱について";
}
.navitem_news a::after{
    content: "最新情報・施工情報";
}
.navitem_concept a::after{
    content: "企業情報";
}
.navitem_recruit a::after{
    content: "採用情報";
}
.navitem_menu a::after{
    content: "スタッフインタビュー";
}
.navitem_info a::after{
    content: "お問い合わせ";
}
.navitem_hp a::after{
    content: "会社サイト";
}
/*------------------- home以外のheader内 -------------------*/
.other_page_header{
    width: 100%;
    background-color: #3E5ADE;
    color: #fff;
}
.other_page_header_inner{
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 16px;
}
@media screen and (max-width: 768px) {
    .other_page_header_inner{
    display: none;
}
}
.other_page_header_content{
    display: flex;
    align-items: center;
}
.other_page_header_logo{
    line-height: 0;
}
.other_page_pc_menu{
    display: flex;
    margin-left: 30px;
}
.other_page_pc_menu :not(:last-child){
    margin-right: 30px;
    text-align: center;
}
.other_page_pc_menu .navitem_home a::after{
    content: "ホーム";
}
/*------------------- spハンバーガーメニュー-------------------*/
.sp_hbg_menu{
    display: none;
}
@media screen and (max-width: 768px) {
    .sp_hbg_menu{
        display: block;
    }
}
.hbg_menu_btn{
    width: 30px;
    height: 24px;
    position: fixed;
    top: 16px;
    right: 13px;
	z-index: 90;
    cursor: pointer;
}
.hbg_menu_btn span:not(:last-child){
	width: 100%;
	height: 3px;
	position: absolute;
	background-color: #fccd63;
}
.hbg_menu_btn span:first-of-type{
	top: 0;
}
.hbg_menu_btn span:nth-of-type(2){
	top: 40%;
}
.hbg_menu_btn span:last-of-type{
	top: 48%;
    right: -1px;
	font-size: 1.2rem;
	color: #fccd63;
	position: absolute;
}
.hbg_menu_content{
	width: 100%;
	height: 100%;
	background-color: #010623e3;
    text-align: center;
    padding: 10px 60px;
	position: fixed;
	top: 0;
	z-index: 80;
    display: flex;
    flex-direction: column;
	transform: translateY(-100%);
	transition: .5s;
}
.hbg_menu_content nav{
	margin-bottom: 20px
}
.sp_navitem{
	margin-bottom: 14px;
}
.sp_navitem a::after{
    display: block;
    font-size: 1.1rem;
    text-align: center;
}
.sp_navitem_home a::after{
    content: "ホーム";
}
.sp_navitem_about a::after{
    content: "丸喜屋設備について";
}
.sp_navitem_company a::after{
    content: "企業情報";
}
.sp_navitem_menu a::after{
    content: "スタッフインタビュー";
}
.sp_navitem_recruit a::after{
    content: "採用情報";
}
.sp_navitem_news a::after{
    content: "最新情報・施工情報";
}
.sp_navitem_contact a::after{
    content: "お問い合わせ";
}
.sp_navitem_hp a::after{
    content: "会社サイト";
}
/*----- ハンバーガーボタンクリック時 -----*/
.hbg_menu_btn.active span:first-of-type{
	top: 20%;
	transform: rotate(45deg);
}
.hbg_menu_btn.active span:nth-of-type(2){
	top: 20%;
	transform: rotate(-45deg);
}
.hbg_menu_content.active{
  	transform: translateY(0);
  	overflow-y: scroll;
}
/*----- ここまでheader -------------------*/

/*----- ここからfooter -------------------*/
.footer{
    width: 100%;
    background-color: #3E5ADE;
    color: #fff;
}
.footer_inner{
    padding: 30px 0;
}
.footer_logo{
    max-width: 100%;
    margin: 0 auto;
    text-align: center;
}
.footer_menu{
    width: 50%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    padding-bottom: 40px;
    border-bottom: #fff 1px solid;
    margin: auto;
}
.footer_menu li{
    width: fit-content;
    position: relative;
    padding: 0 20px 0 15px;
}
.footer_menu li::before{
    content: "|";
    display: block;
    top: 0;
    left: 0;
    position: absolute;
}
.footer_menu a{
    font-size: 1.2rem;
}
.footer_menu :nth-child(even){
    margin: 0.6rem 0;
}
@media screen and (max-width: 589px) {
    .footer_menu{
        width: 100%;
    }
}
.footer_sns_icon::before{
    content: "follow us";
    display: block;
    text-align: center;
    font-size: 1.1rem;
    margin-bottom: 0.5rem;
}
.copyright{
    font-size: 1rem;
    text-align: center;
    margin-top: 16px;
}
/*----- ここまでfooter -------------------*/

/*----- 共通 -------------------*/
.main_container{
    padding-top: 80px;
}
.content{
    margin-bottom: 160px;
}
@media screen and (max-width: 768px) {
    .content{
        margin-bottom: 120px;
    }
}
.base_inner{
    max-width: 960px;
    margin: 0 auto;
}
.content_title{
    font-size: 2.4rem;
    color: #CB9D35;
    text-align: center;
    padding-top: 40px;
    margin-bottom: 40px;
}
/*----- top最上部にもどるbtn -----*/
.page_top{
    width: 54px;
    height: 54px;
    text-align: center;
    background-color: #3E5ADE;
    position: fixed;
    bottom: 10px;
    right: 10px;
    z-index: 1;
}
.page_top a{
    display: block;
    font-size: 1.6rem;
    color: #fff;
}
/*----- 共通 -------------------*/

/*----- Homeページ -------------------*/
/*----- home_news -----*/
.post_box{
    max-width: 680px;
    padding: 0 15px;
    margin: 0 auto;
}
.post_box .post_item:nth-child(even){
    margin: 3.2rem 0;
}
.post_item{
    display: inline-block;
}
@media screen and (max-width: 768px) {
    .post_item{
        display: flex;
    }
    .post_box{
        padding: 0;
    }
}
.post_link{
    display: flex;
    color: #45413f;
}
@media screen and (max-width: 768px) {
    .post_link{
        flex-direction: column;
    }
}
.post_link_l{
    opacity: 0.6;
    margin-right: 10rem;
}
.post_link_r{
    border-bottom: 0.5px solid;
    letter-spacing: 0.2rem;
}
/*-----  home_concept -----*/
.concept_content{
    background: url(../images/concept_bg.png) center bottom/ cover no-repeat;
    padding-bottom: 5%;
}
.concept_content .base_inner{
    max-width: 1200px;
}
.text_box{
    padding: 0 15px;
    text-align: right;
}
.concept_content .text_box .text_item_r{
    backdrop-filter: blur(7px);
}
.concept_content .text_box .text_item_r p a{
    color: #d71e1e;
}
.text_item_l .sub_title{
    font-size: 3.4rem;
    line-height: 2;
    letter-spacing: 0.6rem;
}
@media screen and (max-width: 768px) {
    .concept_content{
        background-size: contain;
    }
    .text_box{
        display: block;
    }
    .text_item_l{
        margin-right: 0;
        writing-mode: horizontal-tb;
        text-align: center;
    }
    .text_item_l .sub_title{
        font-size: 2.4rem;
        margin-bottom: 30px;
    }
    .text_item_r p{
        margin: 0 auto;
    }
}
@media screen and (max-width: 589px) {
    .text_item_l .sub_title{
        font-size: 2rem;
    }
    .br_sp_off{
        display: none;
    }
}
/*----- home_menu -----*/
.menu_slider_box{
    width: 100%;
}
.menu_slider_inner{
    overflow-y: scroll;
}
.slider_block{
    display: flex;
    width: max-content;
    padding: 0 4vw;
}
.slider_item:nth-child(even){
    margin: 0 4vw;
}
@media screen and (max-width: 768px) {
    .slider_item{
        width: 500px;
    }
}
@media screen and (max-width: 589px) {
    .slider_item{
        width: 260px;
    }
}
/*----- home_about-----*/
.about .sub_title{
    font-size: 2.5rem;
    text-align: center;
}
.about_box{
    display: flex;
    padding: 0 15px;
    justify-content: space-around;
}
.about_item_l{
    width: 45%;
}
.about_item_r{
    width: 45%;
}
@media screen and (max-width: 768px) {
    .about_box{
        flex-direction: column-reverse;
    }
    .about .sub_title{
        font-size: 1.8rem;
        border-bottom: #ccc 1px solid;
    }
    .about_item_r{
        margin: 0 auto;
    }
    .about_item_l{
        width: 95%;
        margin: auto;
    }
}
/*----- moreボタン -----*/
.more_btn{
    max-width: 152px;
    height: 56px;
    background-color: #50505c;
    margin: 80px auto 0;
}
.more_btn a{
    font-size: 2.4rem;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.top_rec_btn{
    margin: 80px 0  0 auto;
}
@media screen and (max-width: 589px) {
    .more_btn{
        max-width: 120px;
        height: 44px;
        margin: 50px auto 0;
    }
    .more_btn a{
        font-size: 1.8rem;
    }
}
/*----- ここまでHomeページ -------------------*/

/*----- Home以外のページ共通 -------------------*/
.mv_top{
    width: 100%;
    height: 280px;
    background: url(../images/mv_img.jpg) center top / cover no-repeat;
}
.recruit{
    background: url(../images/mv_img_recruit.jpg) center top / cover no-repeat;
}
.contact{
    background: url(../images/mv_img_contact.jpg) center left / cover no-repeat;
}
.mv_top_glass{
    height: 100%;
}
.mv_top_inner{
    max-width: 960px;
    height: 100%;
    position: relative;
    margin: 0 auto;
}
.top_title{
    font-size: 4.8rem;
    writing-mode: vertical-rl;
    letter-spacing: 0.6rem;
    position: absolute;
    top: 20%;
    right: -70px;
}
@media screen and (max-width: 1106px) {
    .top_title{
        writing-mode: horizontal-tb;
        right: 50%;
        top: 50%;
        transform: translate(50%, -50%);
        color: #fff;
        text-shadow: -4px 1px 3px #373737;
    }
}
.top_title::after{
    display: block;
    font-size: 1.6rem;
    margin-right: -8px;
}
@media screen and (max-width: 1024px) {
    .top_title::after{
        width: max-content;
       margin-top: -10px;
       color: #fff;
    }
}
.top_title_company::after{
    content: "企業情報";
}
.top_title_staff::after{
    content: "スタッフインタビュー";
}
.top_title_info::after{
    content: "お問い合わせ";
}
.top_title_about::after{
    content: "丸喜屋設備㈱について";
}
.top_title_news::after{
    content: "最新情報";
}
.top_title_recruit::after{
    content: "採用情報";
}
.top_title_recruit02::after{
    content: "山形市　採用情報";
}
.top_title_recruit03::after{
    content: "天童市　採用情報";
}
.top_title_recruit04::after{
    content: "東根市　採用情報";
}
.top_title_privacypolicy::after{
    content: "プライバシーポリシー";
}
/*----- ここまで　Home以外のページ共通 -------------------*/

/*----- スタッフインタビューページ -------------------*/

.staff_main .content{
    padding-bottom: 150px;
    margin-bottom: 0;
}
.concept_main_container{
    padding-top: 128px;
}
.concept_content_title_r{
    margin-left: 28%;
}
.concept_box {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    padding: 0 15px;
    margin-bottom: 40px;
    margin-left: 300px;
}
.concept_r{
    margin-right: -45px;
    transform: translate(0, 30%);
}
.concept_l{
    width: 500px;
    background-color: #fff;
    justify-content: center;
    align-items: center;
    padding: 20px 50px;
    border-radius: 115px;
    border: 1px solid #ccc;
    box-shadow: #7f8082a8 2px 4px 8px;
}
.staff_name{
    font-size: 2.4rem;
    text-align: center;
    margin-bottom: 16px;
}
.concept_txtbox{
    line-height: 2;
}
.concept_box_reverse{
    flex-direction: row-reverse;
}
.left_box{
    margin-left: -250px;
}
.concept_box .concept_r{
    transform: rotate(-5deg);
}
.concept_box_reverse .concept_r{
    margin-right: 0;
    margin-left: -70px;
    transform: rotate(8deg);
}
.concept_box2_slide_wrap{
    width: 90%;
    margin: 0 auto;
    padding: 0 40px;
    display: flex;
    overflow: hidden;
}
.concept_box2_slide{
    display: flex;
    padding: 0 3px;
    animation: concept-loop-slide 50s linear infinite;
}
.concept_box2_slide li{
    width: 304px;
    margin: 0 18px;
    display: block;
}
.concept_box2{
    max-width: 726px;
    padding: 0 15px;
    margin: 38px auto 0;;
}
.ttl{
    font-size: 2.4rem;
    color: #CB9D35;
    text-align: center;
    margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
    .concept_box {
        margin-left: 0;
    }
    .concept_l{
        padding: 5px 10px;
        border-radius: 40px;
    }
    .concept_r{
        margin-right: -10px;
    }
    .concept_box_reverse .concept_r{
        margin-left: -10px;
    }
    .left_box{
        margin-left: 0;
    }
    .staff_name{
        font-size: 2rem;
    }
}
/*----- ここまでスタッフインタビューページ -------------------*/

/*----- companyページ -------------------*/
.company01_txt{
    text-align: center;
    font-size: 4rem;
    font-family: 'Gill Sans', 'Gill Sans MT', 'Trebuchet MS', serif;
    font-weight: 400;
    line-height: 2.2;
}
.company02_wrap{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.company02_txt{
    width: 48%;
    line-height: 2.2;
}
.company_table{
    width: 70%;
    margin: auto;
    border-collapse: collapse;
}
.company_table th{
    text-align: left;
    padding: 30px 50px 15px 10px;
    border-bottom: #ccc 1px solid;
}
.company_table td{
    padding: 30px 0 15px 30px;
    border-bottom: #ccc 1px solid;
}
.company_wrap iframe {
    width: 95%;
    max-width: 100%;
    margin: 0 auto;
    display: block;
}
.company04_wrap{
    display: flex;
    width: 80%;
    justify-content: space-around;
    margin: 0 auto;

}
@media screen and (max-width: 768px) {
    .company01_txt{
        font-size: 2.3rem;
        line-height: 2;
    }
    .company02_wrap{
        flex-direction: column;
        padding: 20px 10px;
    }
    .company02_txt{
        width: 100%;
    }
    .company02_wrap img{
        width: 65%;
        margin: 20px 15px;
        display: block;
    }
    .company_table{
        width: 95%;
    }
    .company_table th{
        padding: 20px 0 15px 0;
    }
    .company_table td{
        padding: 20px 0 15px 50px;
    }
    .company04_wrap{
        flex-direction: column;
    }
}
/*----- ここまでcompanyページ -------------------*/

/* Aboutページ--------------------------- */
.about01_box{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.reverse{
    flex-direction: row-reverse;
}
.about_inner{
    padding: 10px 15px;
}
.about_inner p{
    line-height: 2;
}
.about01_box_ttl{
    font-size: 2.5rem;
}
.about_end_txt{
    text-align: center;
    font-size: 2rem;
    line-height: 2;
    margin-top: 40px;
}
.about03_wrap{
    display: flex;
}
.about03_wrap table{
    width: 50%;
}
.about03_wrap table tr th{
    font-size: 1.4rem;
    padding-right: 20px;
}
.about03_wrap img{
    width: 50%;
    height: fit-content;
}
@media screen and (max-width: 768px) {
    .about01_box{
        flex-direction: column;
    }
    .about03_wrap table tr th{
        padding-right: 5px;
        border-bottom: #ccc 1px solid;
    }
    .about03_wrap table tr td{
        font-size: 1.4rem;
        padding-left: 15px;
    }
}
/* ここまでAboutページ--------------------------- */

/* お問合せフォーム------------ */
.tel_box {
    text-align: center;
}
.tel_box a{
    color: #c70000;
    font-size: 4rem;
    font-weight: 500;
    text-align: center;
}
.conact_box{
    margin: 0 auto;
    max-width: 700px;
}
.conact_box input.wpcf7-form-control.wpcf7-text.wpcf7-validates-as-required,
.conact_box input.wpcf7-form-control.wpcf7-tel.wpcf7-text.wpcf7-validates-as-tel,
.conact_box textarea.wpcf7-form-control.wpcf7-textarea{
    width: 700px;
    height: 50px;
    margin-bottom: 30px;
    border: solid 1px #c9c9c9;
}
@media screen and (max-width: 768px){
    .conact_box input.wpcf7-form-control.wpcf7-text.wpcf7-validates-as-required,
    .conact_box input.wpcf7-form-control.wpcf7-tel.wpcf7-text.wpcf7-validates-as-tel,
    .conact_box textarea.wpcf7-form-control.wpcf7-textarea{
        display: block;
        width: 94vw;
        margin: 0 auto;
    }
}
textarea.wpcf7-form-control.wpcf7-textarea{
    height: 150px;
}
.submit_btn a{
    display: block;
    text-align: center;
    cursor: pointer;
    background: transparent;
    width: 152px;
    height: 56px;
    color: #fff;
    background-color: #2C2C31;
    margin: 80px auto 0;
    font-size: 2.4rem;
    border: 0;
}
@media screen and (max-width: 589px){
    .conact_box form a{
        max-width: 120px;
        height: 44px;
        margin: 50px auto 0;
        font-size: 1.8rem;
    }
}
/*----- ここまで店舗情報ページ -------------------*/

/*----- お問合せありがとうページ -------------------*/
.content_main{
    padding-top: 0;
}
.thanks_content{
    background: url(../images/thanks_bg.jpg) center center / cover no-repeat;
    padding: 80px 0;
    margin-bottom: 0;
}
.contact_finished_box{
    text-align: center;
}
/*----- ここまでお問合せありがとうページ -------------------*/
/* プライバシーポリシー------------------ */
.privacy_content{
    padding: 5px 10px;
}
.privacy_content a{
    color: #f00;
}
.privacypolicy_checkbox{
    text-align: center;
}
.privacypolicy_checkbox a{
    color: #9e1111;
}
@media screen and (max-width: 768px){
    .privacypolicy_checkbox{
        font-size: 1.3rem;
    }
}
/* ここまでプライバシーポリシー------------------ */
/* 応募フォーム ---- */
.entry_content{
    max-width: 960px;
    margin: 88px auto 0;
    padding: 0 15px;
}
@media screen and (max-width: 768px){
    .entry_content{
        margin: 40px auto 0;
    }     
}
.entry_content table{
    width: 100%;
    border-collapse: collapse;
    word-break: break-all;
    margin-bottom: 80px;
}
#recruitrecruit_05 table tbody tr{
    padding: 0;
    margin: 0;
    background: transparent;
    border: 0;
    outline: 0;
    font-size: 1em;
}
.entry_content table tbody tr th{
    width: 29%;
    font-weight: 500;
    text-align: left;
    vertical-align: middle;
    border-bottom: 1px solid #B2B2B2;
    padding: 20px 50px 20px 0;
}
.entry_content table tbody tr th .must{
    float: right;
    width: 55px;
    color: #fff;
    height: 23px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    font-weight: 500;
    background: #f50d0d8a;
    text-align: center;
}
.entry_content table tbody tr td{
    font-size: 1.3rem;
    text-align: left;
    vertical-align: middle;
    position: relative;
    border-bottom: 1px solid #B2B2B2;
    padding: 28px 0 28px 58px;
}
.entry_content table tbody tr td::before{
    position: absolute;
    left: 0;
    top: 27px;
    width: 1px;
    bottom: 27px;
    background: #B2B2B2;
    content: "";
}
.entry_content .info01{
    display: flex;
    justify-content: center;
}
.entry_content .info01 .info02 input{
    color: #fff;
    width: 152px;
    font-size: 1.6rem;
    cursor: pointer;
    background: #BC1616;
    margin: 68px auto 0;
    padding: 16px 40px;
    border-radius: 4px;
}
.entry_content .wpcf7-form-control,
.entry_content .wpcf7-text{
    width: 100%;
    height: 60px;
    color: #413b3b;
    font-size: 1.3rem;
    padding: 5px 10px 5px 23px;
    box-sizing: border-box;
    background: #efefef;
    border: 1px solid #efefef;
    border-radius: 4px;
}
.entry_content .wpcf7-submit,
.submit .wpcf7-submit{
    display: block;
    width: fit-content;
    height: 50px;
    background: #909299;
    text-align: center;
    color: #fff;
    padding: 0 20px;
    border: 1px solid #efefef;
    border-radius: 4px;
    margin: 0 auto;
}
.entry_content .wpcf7-textarea{
    height: 200px;
}
@media screen and (max-width: 768px){
    .entry_content table tbody tr th .must {
        width: 30px;
    }
    .entry_content table tbody tr th {
        padding: 20px 16px 20px 0;
    }
    .entry_content table tbody tr td{
        padding: 28px 0 28px 16px;
    }
}
/* ここまで応募フォーム ---- */
/*------------------- 採用ページ -------------------*/
#entry{
    margin-bottom: 40px;
}
.content_top_txt{
    max-width: 1000px;
    margin: 40px auto 0; 
}
.content_top_txt p{
    text-align: center;
}
.content_top_txt p span{
    position: relative;
}
.content_top_txt p span::after{
    content: "";
    width: 100%;
    height: 2px;
    background-color: #ff0000;
    position: absolute;
    display: block;
    bottom: -3px;
    left: 0;
}
.content_top_txt .font_big{
    font-size: 2.6rem;
    text-align: center;
}
.recruit_single_content01{
    max-width: 1078px;
    padding: 0 15px;
    margin: 0 auto;
}
.recruit_single_inner01{
    background-color: #fff;
    padding: 60px 60px 80px;
}
@media screen and (max-width: 768px){
    .content_top_txt{
        padding: 0 5px;
    }
    .recruit_single_inner01{
        background-color: #fff;
        padding: 20px 0 40px;
    }
    .content_top_txt .font_big{
        font-size: 2.3rem;
    }
}
.recruit_single_about{
    font-size: 1.8rem;
    padding-bottom: 40px;
    background-image: linear-gradient(90deg, #BC1616 15%, #B2B2B2 15%);
    background-repeat: no-repeat;
    background-size: 100% 2px;
    background-position: bottom;
}
.recruit_single_about p{
    line-height: 2;
}
@media screen and (max-width: 768px){
    .recruit_single_about{
        font-size: 1.6rem;
        padding-bottom: 20px;
    }
}
.recruit_single_box01{
    margin: 10px auto 0;
}
table.recruit_single_box01{
    border-collapse: collapse;
    border-spacing: 0;
}
.recruit_single_box01 th{
    text-align: start;
    vertical-align: top;
    padding: 46px 8vw 32px 0;
    border-bottom: solid 1px #B2B2B2;
}
@media screen and (max-width: 768px){
    .recruit_single_box01 th{
        width: 30%;
        padding: 24px 8vw 32px 0;
    }               
}
.recruit_single_box01 td{
    max-width: 706px;
    padding: 46px 0;
    border-bottom: solid 1px #B2B2B2;
}
@media screen and (max-width: 768px){
    .recruit_single_box01 td{
        padding: 24px 0;
    }
    .recruit_single_box01 td iframe{
        width: 100%;
    }            
}
.recruit_single_box01 span{
    display: block;
    position: relative;
}
.recruit_single_box01 span:not(:first-child){
    margin-top: 28px;
}
.recruit_single_box01 span::before{
    content: "";
    display: block;
    width: 9px;
    height: 9px;
    border-radius: 100%;
    background-color: #B2B2B2;
    position: absolute;
    top: 9px;
    left: -19px;
}
.single_main_container .btn{
    text-align: center;
    margin-top: 40px;
}
@media screen and (max-width: 768px){
    .content_top_txt p {
        line-height: 1.5;
    }
}
/*------------------- ここまで採用ページ -------------------*/
/*ぱんくずリスト*/
.page_map{
	display: flex;
	justify-content: left;
}
.page_map li{
	padding: 0 20px;
	position: relative;
    color: #7c7c7c;
}
.page_map li a{
    color: #7c7c7c;
}
.page_map li::after{
	content: "/";
	display: block;
	position:absolute;
	top: 0;
	right: -10px;
}
.page_map li:last-child::after{
	content: none;
}

/*ここまでぱんくずリスト------------*/
.sp{
    display: none;
}
.pc{
    display: block;
}
@media screen and (max-width: 768px){
    .sp{
        display: block;
    }
    .pc{
        display: none;
    }
}

.background-img::before {
    content: "";
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100vh;
    background-repeat: no-repeat;
    background-position: 50% 100%;
    background-image: url(../images/staff_bg.jpg);
    background-size: cover;
  }

  /* TOPコラム-------------------- */
.post_box .column_wrap .column {
    font-size: 20px;
}
.post_box .column_wrap .row {
    text-align: center;
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
}
.post_box .column_wrap .row .col-md-4 {
    background-color: rgba(255, 255, 255, 0.5);
    border-bottom: 1px solid #ccc;
}
.post_box .column_wrap .row .col-md-4 .news {
    display: flex;
    align-items: center;
}
.post_box .column_wrap .row .col-md-4 .news .news_pic {
    width: 20%;
}
.post_box .column_wrap .row .col-md-4 .news .news_pic img {
    width: 80px;
}
.post_box .column_wrap .row .col-md-4 .news .news_meta {
    width: 20%;
    flex-direction: column;
}
.post_box .column_wrap .row .col-md-4 .news .news_meta ul li {
    font-size: 14px;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    text-align: left;
    list-style: none;
    padding: 2px 3px;
}
.post_box .column_wrap .row .col-md-4 .news .news_meta ul li a {
    color: #333;
}
.post_box .column_wrap .row .col-md-4 .news .news_title {
    width: 20%;
    padding: 0;
    margin: 0;
    font-size: 16px;
    background-color: unset;
}
.post_box .column_wrap .row .col-md-4 .news .news_desc {
    width: 68%;
    display: flex;
    justify-content: space-around;
}
/* .post_box .column_wrap .row .col-md-4 .news .news_desc p {
    width: 50%;
} */
.news_title a,.news_desc a{
    color: #333;
}
.top .news_pic{
    display: none;
}
/*single.php______________________________*/
.article .article_header .article_title {
    color: #333;
    background-color: unset;
    text-align: center;
    font-size: 28px;
}
.article .article_header .article_meta {
    display: flex;
    -js-display: flex;
    padding: 30px 0;
    align-items: center;
    justify-content: space-between;
}
.article .article_header .article_meta ul {
    display: flex;
    -js-display: flex;
    align-items: center;
    justify-content: space-between;
}
.article .article_header .article_meta ul li {
    list-style: none;
    padding-right: 10px;
}
.article .article_header .article_meta ul li a {
    line-height: 1;
    display: inline-block;
    padding: 5px 10px;
    font-size: 14px;
    border: 1px solid #67abd3;
    color: #67abd3;
    text-decoration: none;
}
.article .article_header .article_meta time {
    width: 150px;
    margin-left: auto;
    font-size: 14px;
}
.article .privacy_policy {
    margin-top: 2rem;
    text-align: center;
}
.article .privacy_policy a {
    color: #c0c0c0;
}
.article .postLinks {
    margin-top: 50px;
    padding: 20px 0;
    border-top: 1px solid #ccc;
    display: flex;
    -js-display: flex;
}
.article .postLinks .postLink {
    width: 50%;
    padding: 15px 0;
}
.article .postLinks .postLink a {
    text-decoration: none;
    font-size: 14px;
}
.article .postLinks .postLink-prev i {
    margin-right: 10px;
}
.article .postLinks .postLink-next {
    text-align: right;
}

.postLink-next i, .postLink-next svg {
    margin-left: 10px;
}

.fa-chevron-right:before {
    content: "\f054";
}

.archive {
    border: 1px solid #ccc;
    margin-bottom: 30px;
}
.archive .archive_title {
    font-size: 16px;
    padding: 20px 10px;
    line-height: 1;
    border-bottom: 1px solid #ccc;
    background-color: #DC143C;
    color: #FFF;
    margin: 0;
}
.archive ul {
    list-style: none;
    list-style-position: inside;
    font-size: 14px;
}
.archive ul li {
    margin: 0;
    border-bottom: 1px solid #ccc;
    line-height: 1;
}
.archive ul li:last-child {
    border-bottom: none;
}
.archive ul li a {
    padding: 20px 10px;
    display: block;
    text-decoration: none;
    position: relative;
    line-height: 1;
    transition: all 300ms 0s ease;
    color: #333;
}
.archive ul li a:hover {
    background-color: rgba(112, 70, 46, 0.1);
}
.archive ul li a::after {
    font-weight: 900;
    position: absolute;
    top: 50%;
    right: 10px;
    display: block;
    margin-top: -0.5em;
    font-size: 14px;
    content: "→";
    font-family: "Font Awesome 5 Free";
    color: #bbb;
}
.comments {
    border-top: 1px solid #c0c0c0;
}
.comments .comment-respond {
    line-height: 3;
}
.comments .comment-respond .comment-form .comment-form-comment label {
    display: block;
}
.comments .comment-respond .comment-form .comment-form-comment textarea {
    width: 100%;
}
.comments .comment-respond .comment-form .comment-form-author {
    display: flex;
    align-items: center;
    position: relative;
}
.comments .comment-respond .comment-form .comment-form-author input {
    position: absolute;
    right: 0;
    width: 80%;
    max-width: 800px;
    height: 2.6em;
}
.comments .comment-respond .comment-form .comment-form-email {
    display: flex;
    align-items: center;
    position: relative;
}
.comments .comment-respond .comment-form .comment-form-email input {
    position: absolute;
    right: 0;
    width: 80%;
    max-width: 800px;
    height: 2.6em;
}
.comments .comment-respond .comment-form .comment-form-url {
    display: flex;
    align-items: center;
    position: relative;
}
.comments .comment-respond .comment-form .comment-form-url input {
    position: absolute;
    right: 0;
    width: 80%;
    max-width: 800px;
    height: 2.6em;
}
.comments .comment-respond .comment-form .form-submit {
    text-align: center;
}

.pp .content {
    width: 80%;
    max-width: 1200px;
    background-color: rgba(255, 255, 255, 0.9);
    box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.4705882353);
    padding: 2rem;
    margin: 100px auto 100px;
}
.content_4 .p404 {
    width: 80%;
    max-width: 1200px;
    margin: 0 auto;
    text-align: center;
    position: relative;
}
.content_4 .p404 p {
    text-align: center;
    position: absolute;
    left: 35%;
    bottom: 100px;
}
.content_4 .link_btn {
    box-sizing: border-box;
    width: 365px;
    max-width: 400px;
    margin: 0 auto;
}
.content_4 .link_btn .btn2::after {
    left: 350px;
}

.thanks h2 {
    margin-top: 300px;
}
.thanks a {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    display: block;
    color: #333;
    border-bottom: 1px solid #333;
    margin: 0 auto 100px;
}
/*articles.php____________________________*/
main {
    margin: 0 auto;
  }
  main .container {
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
    padding-bottom: 5em;
    margin-right: auto;
    margin-left: auto;
  }
  main .container .row .col-md-9 .row {
    display: flex;
  }
  @media screen and (max-width: 768px) {
    main .container .row .col-md-9 .row {
      flex-direction: column;
    }
  }
  main .container .row .col-md-9 .row .col-md-4 {
    width: 33%;
  }
  .main_title{
    text-align: center;
    font-size: 2.2rem;
    color: #CB9D35;
    margin-bottom: 20px;
  }
  main .container .navi {
    width: 70%;
    display: flex;
    justify-content: space-between;
    text-align: center;
    padding-top: 1rem;
  }
  main .container .navi .prev-post a,
  main .container .navi .next-post a{
    color: #242424;
  }
  main .container .navi .pagination .page-numbers {
    color: #242424;
    padding: 0 0.5rem;
  }
  .row {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    position: relative;
  }
  .news {
    width: 100%;
    margin: 10px;
  }
  .news .news_pic {
    margin-bottom: 10px;
  }
  .news a {
    text-decoration: none;
    display: inline-block;
    color: #333;
  }
  .news .news_pic img {
    height: auto;
    width: 100%;
    max-width: 200px;
    display: block;
  }
  .news .news_meta {
    display: flex;
    -js-display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 0 0;
  }
  .news .news_meta ul {
    list-style: none;
    padding: 0;
    display: flex;
    -js-display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .news .news_meta ul li {
    padding-right: 10px;
  }
  .news .news_meta ul li a {
    line-height: 1;
    display: inline-block;
    padding: 5px 10px;
    font-size: 12px;
    color: #0293AD;
    border: 1px solid #0293AD;
    text-decoration: none;
  }
  .news .news_time {
    margin-left: 5px;
    font-size: 12px;
  }
  .news .news_title {
    font-size: 14px;
    background-color: unset;
    padding: 0;
    margin: 0;
    line-height: 1.2;
  }
  .news .news_desc p {
    font-size: 13px;
    margin-bottom: 5px;
  }
  .col-md-9 {
    max-width: 70%;
    width: 70%;
    margin: 0 0 20px;
    padding: 0 20px;
    font-weight: normal;
    font-style: normal;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%;
  }
  .col-md-3, .col-md-4 {
    position: relative;
    width: 100%;
    min-height: 1px;
    padding-right: 15px;
    padding-left: 15px;
  }
  .col-md-3 {
    height: -webkit-fit-content;
    height: -moz-fit-content;
    height: fit-content;
    position: -webkit-sticky;
    position: sticky;
    top: 25%;
    left: 0;
    margin: 0 0.5em 0 0.5em;
    flex: 0 0 25%;
    max-width: 25%;
  }
  .col-md-3 .search {
    text-align: center;
  }
  .wpcf7-submit{
    cursor: pointer;
  }
@media screen and (max-width: 890px) {
    main .container .row {
        justify-content: flex-start;
    }
    main .container .row .col-md-9 {
        max-width: 100%;
        width: 100%;
        padding: 0 1em;
    }
    main .container .row .col-md-9 .row {
        flex-direction: row;
    }
    main .container .row .col-md-9 .row .col-md-4 {
        width: 50%;
        padding: 0.5em;
        border-bottom: 1px dashed #ccc;
    }
    main .container .row .col-md-9 .row .col-md-4 .news_pic {
        text-align: center;
    }
    main .container .row .col-md-9 .row .col-md-4 .news_pic img {
        max-width: 100px;
    }
    main .container .row .col-md-9 .row .col-md-4 .news_meta ul li {
        padding-right: 3px;
    }
    main .container .row .col-md-9 .row .col-md-4 .news_meta ul li a {
        text-align: center;
        padding: 0.5em;
    }
    main .container .row .col-md-3 {
        flex: 1;
        max-width: 100%;
        width: 100%;
    }
    .post_box .column_wrap .row .col-md-4 .news .news_title  {
        font-size: 18px;
      }
    .col-md-4{
        padding: 0;
    }
    .post_box .column_wrap .row .col-md-4 .news .news_desc {
        align-items: flex-end;
    }
}