@charset "UTF-8";


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

    .spNone {
        display: none;
    }

    .pcNone{
        display: block;
    }

    .sp_imax {
        width:100%; max-width: 100%;
    }

    .cmn_maxbox,
    .cmn_maxbox_600,
    .cmn_maxbox_800,
    .cmn_maxbox_1060{
        padding-left: 3%;
        padding-right: 3%;
    }

/* cmn ///////////////////////////////////// */
/* modal_menu */
.header_modalmenu_btn {
    display: inline-flex;
}
/*header*/
.header_infobar{
    height: 60px;
}
.header_logo{
    width: auto;
    border-right: none;
}
.header_logo a img {
    padding-top: 5px;
    padding-bottom: 5px;
    padding-left: 15px;
    height: 50px;
}
/* cmn_maintitle */
.cmn_maintitle{
    height: 360px;
}
.cmn_maintitle h1{
    padding-top: 160px;
}

/* cmn_tit */
.cmn_tit_2nd h2{
    padding-left: 0;
}
/* home ///////////////////////////////////// */
.home_copy{
    right: 0;
    width: 100%;
    text-align: center;
}

/* cmn_contents */

.home_contents div ul li{
    padding: 100px 40px 40px;
}



/* pd ///////////////////////////////////// */
.pd_flow_fig * {
    display: none;
}

.pd_flow_fig .pcNone {
    display: inline-block;
}




/* recruit ///////////////////////////////////// */

.recruit_contact > div{
    display: block;
    padding-top: 50px;
    padding-bottom: 50px;
}

.recruit_contact > div > div:nth-of-type(1){
    width: 100%;
    text-align: center;
}

.recruit_contact > div > div:nth-of-type(2){
    width: 471px;
    margin: auto;
    text-align: center;
    border-left: none;
    padding: 40px 0;
}

.recruit_contact .cmn_btn a{
    margin: 0 auto;
}

/* sub ///////////////////////////////////// */

}



@media (max-width: 800px) {
/* cmn ///////////////////////////////////// */
/* font-size */
.fs18{
    font-size: 1.6rem;
}

.fs20{
    font-size: 1.8rem;
}

.fs24{
    font-size: 2.0rem;
}

.fs28{
    font-size: 2.4rem;
}

.fs32{
    font-size: 2.8rem;
}

.fs36{
    font-size: 3.2rem;
}

.fs48{
    font-size: 3.6rem;
}

.fs60{
    font-size: 5.0rem;
}

.fs62{
    font-size: 5.0rem;
}

/* cmn_maintitle */
.cmn_maintitle{
    height: 300px;
}

.cmn_maintitle h1{
    padding-top: 145px;
}

/* box_inner */
.cmn_boxinner_70{
    padding-top: 60px;
    padding-bottom: 60px;
}

.cmn_boxinner_90{
    padding-top: 70px;
    padding-bottom: 70px;
}

.cmn_boxinner_100{
    padding-top: 80px;
    padding-bottom: 80px;
}


/* padding */
.pb100{
    padding-bottom: 80px;
}
.pb150{
    padding-bottom: 120px;
}

/* footer */
.footer_topbox{
    display: block;
}

.footer_topbox_right{
    width: 100%;
    margin-bottom: 30px;
}

.footer_topbox_right figure{
    width: 50%;
}

.footer_topbox_right p{
    text-align: left;
}

.footer_topbox_left{
    width: 100%;
}

.footer_bottombox{
    padding-top: 18px;
    padding-bottom: 18px;
}

.footer_gotop a {
    width: 60px;
    padding: 16px 0px 17px;
}

/* cmn_tit */
.cmn_tit_1st{
    padding-top: 60px;
    padding-bottom: 40px;
}

/* cmn_case_list */
.cmn_case_item{
    width: 50%;
}

.cmn_case_item:nth-of-type(3){
    border-top: none;
}

.cmn_case_item:nth-of-type(2n-1){
    border-right: solid 1px #ffffff;
}

.cmn_case_item:nth-of-type(2n){
    border-right: none;
}

/* cmn_dl */
.cmn_dl > div{
    display: block;
}

.cmn_dl > div > dt{
    padding: 20px 20px 10px 20px;
    width: 100%;
}

.cmn_dl > div > dd{
    padding: 0 20px 20px 20px;
    width: 100%;
}

/* cmn_cms_editor */
.cmn_cms_editor h3 {
    font-size: 1.7rem;
}

.cmn_cms_editor h4 {
    font-size: 1.6rem;
}

.cmn_cms_editor h5 {
    font-size: 1.5rem;
}

.cmn_cms_editor h6 {
    font-size: 1.5rem;
}


/* tweet popup */
.tweet_modal__content{
    padding: 0 3%;
}

.tweet_modal__content .article_inner .swiper-container {
    /* max-height: 350px; */
}

/* home ///////////////////////////////////// */
/* home_maintitle */
.home_copy{
    top: 45%;
}
/* home_news */
.home_news{
    position: relative;
    padding: 20px 0;
}
.home_news > div{
    display: block;
}

.home_news h2{
    text-align: center;
}

.home_news small{
    display: block;
}

.home_news .home_news_tit{
    padding: 0;
}

.home_news .cmn_btn2{
padding-top: 20px;
}

.home_news .cmn_btn2 a{
    margin: 0 auto;
}

/* cmn_contents */

.home_contents div ul{
    display: block;
}

.home_contents div ul li{
    width: 100%;
    padding: 60px 30px 30px;
    border-right: none;
}

.home_contents div ul li::after{
    height: 40px;
}


/* news ///////////////////////////////////// */
.news_body dl div{
    display: block;
}

.news_body dl div dt{
    width: 100%;
    padding: 20px 0 10px 0;
}

.news_body dl div dd{
    width: 100%;
    padding: 0 0 20px 0;
}

/* company ///////////////////////////////////// */
.company_greeting > div{
    display: block;
}

.company_greeting p{
    padding: 0;
}

.company_greeting figure{
    margin-top: 30px;
}

.company_client ul{
    display: block;
}

.company_client ul li{
    width: 100%;
}

.company_history .cmn_dl + p {
    font-size: 1.6rem;
}

/* recruit ///////////////////////////////////// */
.recruit_contact > div > div:nth-of-type(2) strong::before{
    left: 35px;
}

/* contact ///////////////////////////////////// */
.contact_form > div > p{
    margin-bottom: 30px;
}


}
































@media (max-width: 560px) {
/* cmn ///////////////////////////////////// */
/* font-size */
.fs14{
    font-size: 1.3rem;
}

.fs24{
    font-size: 1.8rem;
}

.fs28{
    font-size: 2.0rem;
}

.fs32{
    font-size: 2.4rem;
}

.fs36{
    font-size: 2.8rem;
}

.fs48{
    font-size: 3.0rem;
}

.fs60{
    font-size: 4.0rem;
}

.fs62{
    font-size: 3.0rem;
}

/* cmn_maintitle */
.cmn_maintitle{
    height: 200px;
}

.cmn_maintitle h1{
    padding-top: 100px;
}

/* box_inner */
.cmn_boxinner_70{
    padding-top: 50px;
    padding-bottom: 50px;
}

.cmn_boxinner_90{
    padding-top: 50px;
    padding-bottom: 50px;
}

.cmn_boxinner_100{
    padding-top: 60px;
    padding-bottom: 60px;
}


/* padding */
.pb100{
    padding-bottom: 60px;
}

.pb150{
    padding-bottom: 90px;
}

/* footer */
.footer_topbox_right figure{
    width: 60%;
}

.footer_bottombox small{
    line-height: 1.4rem;
}

/* cmn_tit */
.cmn_tit_1st{
    padding-top: 50px;
    padding-bottom: 30px;
}

.cmn_tit_2nd h2{
    padding-bottom: 15px;
}
.cmn_tit_2nd{
    margin-bottom: 20px;
}

/* cmn_case_list */
.cmn_case_list{
    display: block;
}

.cmn_case_item{
    width: 100%;
}

.cmn_case_item:nth-of-type(2){
    border-top: none;
}

.cmn_case_item:nth-of-type(2n-1){
    border-right: none;
}

/* tweet popup */
.tweet_modal__content article{
    padding: 30px;
}

.tweet_modal__content .article_inner > strong{
    padding: 0 0 30px;
}

.tweet_modal__content .cmn_cms_editor{
    padding: 30px 0;
}

.tweet_modal__content .swiper-slide img{
    padding: 0 0 30px;
}

.tweet_modal__content .article_inner .swiper-container {
    /* max-height: 250px; */
}

.tweet_modal__content .swiper-button-next,
.tweet_modal__content .swiper-button-prev {
    width: 22px;
    height: 34px;
    margin-top: -34px;
    background-size: 22px 34px;
}

.tweet_modal__content .swiper-button-prev,
.tweet_modal__content .swiper-container-rtl .swiper-button-next {
    left: 20px;
}

.tweet_modal__content .swiper-button-next,
.tweet_modal__content .swiper-container-rtl .swiper-button-prev {
    right: 20px;
}

/* home ///////////////////////////////////// */
/* home_maintitle */

.home_copy strong{
    margin-bottom: 15px;
}

/* cmn_contents */

.home_contents div ul li{
    padding: 60px 3% 30px;
}

.home_contents div ul li small{
    margin-bottom: 20px;
}

.home_contents div ul li p{
    margin-bottom: 30px;
}

/* home_point */
.home_point > div > div{
    width: 100%;
    display: block;
}

.home_point > div > div > .cmn_btn:first-of-type{
    margin-bottom: 20px;
}

/* news ///////////////////////////////////// */
.tweet_modal__content .article_inner > small{
    padding-left: 0;
}


/* facility ///////////////////////////////////// */
.facility_img > section ul{
    display: block;
}
.facility_img > section ul li{
    width: 100%;
    margin-bottom: 10px;
}

/* recruit ///////////////////////////////////// */
.recruit_contact > div > div:nth-of-type(2){
    width: 100%;
    padding: 30px 0;
}

.recruit_contact > div > div:nth-of-type(2) strong{
    padding-left: 0;
}
.recruit_contact > div > div:nth-of-type(2) strong::before{
    content: none;
}

/* contact ///////////////////////////////////// */
.contact_form > div > p{
    margin-bottom: 10px;
}








}



