@charset "utf-8";

body{
}
.body_sub{
    margin: 0;
}
.body_sub #main{
    height:85px;
}


/* ヘッダーメニュー */
#header{
    background: rgba(5, 31, 64, 0.8);
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 9999;
}
#header:after{content:"";clear:both;display:block}
#header ul li a{
    color: #fff;
    text-decoration: none;
    display: block;
    width: 100%;
    text-align: center;
    font-size: 1.25rem;
}
input{border:none;padding:10px;border-radius:20px}
.logo{float:left;padding:26px 0 26px}
.logo a{font-size:28px;display:block;padding:0 0 0 20px}
nav{float:right;}
nav>ul{float:left;position:relative}
nav li{list-style:none;float:left}
nav .dropdown{position:relative}
nav li a{float:left;padding: 18px 18px 18px 0;}
nav li a:hover{
    opacity:.8;
    transition: 0.5s;
}
nav li ul{display:none}
nav li:hover ul{display:inline}
nav li li{float:none}
nav .dropdown ul{position:absolute;left:0;top:100%;background:#fff;padding:20px 0;border-bottom:3px solid #34495e}
nav .dropdown li{white-space:nowrap}
nav .dropdown li a{padding:10px 35px;font-size:13px;min-width:200px}
nav .mega-dropdown{width:100%;position:absolute;top:100%;left:0;background:#fff;overflow:hidden;padding:20px 35px;border-bottom:3px solid #34495e}
nav li li a{float:none;color:#333;display:block;padding:8px 10px;border-radius:3px;font-size:13px}
nav li li a:hover{background:#bdc3c7;background:#FAFBFB}
.mega-col{width:25%;float:left}
#menu-icon{position:absolute;right:0;top:50%;margin-top:-12px;margin-right:20px;display:none}
#menu-icon span{border:2px solid #fff;width:30px;margin-bottom:5px;display:block;-webkit-transition:all .2s;transition:all .1s}
.swiper-slide img{margin: -190px 0 0;}

#cv_wrap{
    float: right;
}
#cv_wrap p{
    float: right;
}
#cv_wrap p a.h_entry{
    background: #1ed15d;
    font-size: 18px;
    font-weight: 600;
    padding: 14px 64px;
    display: block;
    color: #fff;
    text-decoration: none;
}

@media only screen and (max-width: 1300px) {
    #cv_wrap {
        background: #25395c;
        float: right;
        position: fixed;
        bottom: 0;
        width: 100%;
        padding: 10px 3%;
    }
    #cv_wrap p {
/*        float: none;*/
        width: 50%;
        margin: 0 auto;
        text-align: center;
        border-radius: 4px;
    }
    #cv_wrap p a.h_entry{
        padding: 24px 64px;
        border-radius: 4px;
    }
    #cv_wrap p.tel_on {
        padding: 7px 0 0 0;
    }
}

@media only screen and (max-width: 960px) {
    nav{display:none;width:100%;clear:both;float:none;max-height:400px;}
    #menu-icon{display:inline;top:29px;cursor:pointer;z-index: 9999;}
    #menu-icon.active .first{transform:rotate(45deg);-webkit-transform:rotate(45deg);margin-top:10px}
    #menu-icon.active .second{transform:rotate(135deg);-webkit-transform:rotate(135deg);position:relative;top:-9px;}
    #menu-icon.active .third{display:none}
    .search{float:none}
    .search input{width:100%}
    nav{padding:10px}
    nav ul{float:none}
    nav li{float:none}
    nav ul li a{float:none;padding:8px;display:block}
    #header nav ul ul{display:block;position:static;background:none;border:none;padding:0}
    #header nav a{color:#fff;padding:8px}
    #header nav a:hover{background:#fff;color:#333;border-radius:3px}
    #header nav ul li li a:before{content:"- "}
    .mega-col{width:100%}
}
@media only screen and (max-width: 480px) {
    #menu-icon{top:32px;}
    #logo{width: 220px;}
    #header{
        padding: 10px 3% 10px 0;
    }
    #header ul li a{
        font-size: 1rem;
        line-height: 1.2rem;
    }
    nav {
        margin: 0 0 -12px;
    }
}

/************ common ************/

.line_gray{
    position: absolute;
    width: 100%;
    height: 2px;
    background: rgba(200,200,200,0.5);
    top: 5px;
}
.line_blue{
    position: absolute;
    height: 2px;
    background: #71b6f4;
    top: 0;
}
#about span,
#about p span,
#culture span,
#culture p span,
#performance span,
#performance p span,
#recruit span,
#recruit p span{
    letter-spacing: -13px;
    font-family: "RoHMinchoPro_l";
    font-weight: 100;
}
#culture span,
#culture p span,
#recruit span,
#recruit p span{
    color:#fff;
}
.container {
  display: inline-table;
}
.container img{
    width: 47%;
    margin: 0 1%;
}
#recruit .container {
  display: inline-flex;
}
#to_top{
    position: fixed;
    bottom: 70px;
    right: 20px;
    box-shadow: 0 0 15px rgba(0,0,0,0.04);
    border-radius: 100%;
    z-index: 9999;
}


/************ main ************/

#main_copy {
    width: 100%;
    padding: 0 0 0;
    margin:0 0 0;
    position: absolute;
    z-index: 100;
    height: 540px;
    overflow: hidden;
}
#main_copy p {
    color: #FFF;
    font-size: 80px;
    line-height: 90px;
    padding: 80px 0 0 60px;
    text-shadow: 0 0 15px rgba(0,0,0,.5);
}
#main_copy p span{
    color:#FFF;
    font-size: 80%;
    text-shadow: 0 0 10px rgba(0,0,0,.5);
}
#main_copy p span .tight{
    letter-spacing: -13px;
    font-weight: 100;
}
#main_copy p span.sml{
    color:#FFF;
    font-size: 34px;
    text-shadow: 0 0 10px rgba(0,0,0,.5);
}

#main {
    background: url(../img/mi_bg.jpg) no-repeat center top;
    background-size: cover;
    padding: 0 0 0;
    margin:0 0 0;
    position: relative;
    height: 540px;
    overflow: hidden;
    color:#FFF;
}
#main2 {
    background: url(../img/mi_bg2.jpg) no-repeat center top;
    background-size: cover;
    padding: 0 0 0;
    margin:0 0 0;
    position: relative;
    height: 540px;
    overflow: hidden;
    color:#FFF;
}
#main3 {
    background: url(../img/mi_bg3.jpg) no-repeat center top;
    background-size: cover;
    padding: 0 0 0;
    margin:0 0 0;
    position: relative;
    height: 540px;
    overflow: hidden;
    color:#FFF;
}
#main4 {
    background: url(../img/mi_bg4.jpg) no-repeat center top;
    background-size: cover;
    padding: 0 0 0;
    margin:0 0 0;
    position: relative;
    height: 540px;
    overflow: hidden;
    color:#FFF;
}
#main p {
    color: #FFF;
    font-size: 100px;
    line-height: 115px;
    padding: 80px 0 0 60px;
    text-shadow: 0 0 15px rgba(0,0,0,1);
}
#main p span{
    color:#FFF;
    font-size: 34px;
    text-shadow: 0 0 10px rgba(0,0,0,1);
}
#main p span .tight{
    letter-spacing: -13px;
    font-weight: 100;
}
#main2 p {
    color: #FFF;
    font-size: 100px;
    line-height: 115px;
    padding: 80px 0 0 60px;
    text-shadow: 0 0 15px rgba(0,0,0,1);
    text-align: right;
}
#main2 p span.sml{
    color:#FFF;
    font-size: 34px;
    text-shadow: 0 0 10px rgba(0,0,0,1);
}
#main2 p span.tight{
    color:#FFF;
    letter-spacing: -63px;
    font-weight: 100;
}

.flex-container {
  display: flex;
}

.flex-container2 {
  display: flex;
    justify-content: center;
}
.flex-container2 .item a {
    color: #fff;
    margin: 0 28px;
    text-decoration: none;
}
.flex-container2 .item a:hover {
    color: #aaa;
}

#about_ttl .box{
    background: url(../img/about_ttl.png) no-repeat right top;
}
#about_ttl p{
    font-size: 2em;
    line-height: 112px;
    height: 112px;
    padding-right: 20px;
    text-align: right;
}
#about {
    background: url(../img/about_bg.jpg) no-repeat center top fixed;
    position: relative;
}
#about .line_blue{
    width: 270px;
    right: 0;
}


#news_ttl .box{
    background: url(../img/news_ttl.png) no-repeat left top;
}
#news_ttl p{
    font-size: 2em;
    line-height: 112px;
    height: 112px;
    padding-left: 20px;
    text-align: left;
}
#news {
    background: #f9f9f9;
    position: relative;
}
#news .line_blue{
    width: 280px;
    left: 0;
}

.news-list{
  list-style: none outside;
  margin: 0;
  padding: 0;
}
.news-list .item{
  display: flow-root;
  flex-wrap: wrap;
  flex-wrap: nowrap;
  color: #333;
  border-bottom: 1px solid #CCC;
  padding: 20px 20px;
}
.news-list .item a{
  text-decoration: none;
}
.news-list .item:first-child{
  border-top: 1px solid #CCC;
}
.news-list .item .date{
  margin: 0;
  min-width: 120px;
  font-size: 16px;
  color: #999;
  padding: 0 20px 0 0;
}
.news-list .item .title{
  margin: 0;
  width: 100%;
font-weight: bold;
}
.news-list .item a:hover .title{
  color: #00F;
}
.news-list .item .article{
  margin: 0;
  width: 100%;
}
.news-list .item a:hover .article{
  color: #00F;
}

@media screen and (max-width: 767px){
    .news-list .item a{
      flex-wrap: wrap;
    }
    .news-list .item .date{
      min-width: 100px;
    }
    .news-list .item .title{
      margin-top: 10px;
    }
}




#culture_ttl .box{
    background: url(../img/culture_ttl.png) no-repeat left top;
}
#culture_ttl p{
    font-size: 2em;
    line-height: 112px;
    height: 112px;
    padding-left: 20px;
    text-align: left;
}
#culture {
    background: url(../img/culture_bg.jpg) no-repeat center top fixed;
    position: relative;
}
#culture_sub {
    background: url(../img/culture_in_bg.jpg) no-repeat center top fixed;
    position: relative;
}
#culture h2,
#culture p{
    color:#fff;
}
#culture .line_blue,
#culture_sub .line_blue{
    width: 280px;
    left: 0;
}

#divercity_ttl .box{
    background: url(../img/divercity_ttl.png) no-repeat right top;
}
#divercity_ttl p{
    font-size: 2em;
    line-height: 112px;
    height: 112px;
    padding-right: 20px;
    text-align: right;
}
#divercity {
    background: #f5f5f5;
    position: relative;
}
#divercity .line_blue{
    width: 270px;
    right: 0;
}
/* divercity吹き出し本体 */
#divercity .stuff_l{
    position: relative;
    padding: 20px 30px;
    border-radius: 10px;
    background-color: #fff;
    margin: 30px 40px 70px 270px;
    box-shadow: 0 1px 7px rgba(0,0,0,.01);
}
#divercity .stuff_r{
    position: relative;
    padding: 20px 30px;
    border-radius: 10px;
    background-color: #fff;
    margin: 30px 270px 70px 40px;
    box-shadow: 0 1px 7px rgba(0,0,0,.01);
}
#divercity .stuff_l p,
#divercity .stuff_r p{
    font-size: 1.4em;
    font-weight: bold;
}
#divercity .stuff_l p span,
#divercity .stuff_r p span{
    font-size: 0.8em;
    font-weight: 100;
    background: #24395b;
    letter-spacing: 0;
    color: #fff;
    padding: 3px 16px;
    display: inline-block;
    margin: 0 0 10px;
    border-radius: 4px;
}
/* 画像 - 絶対配置で左右に配置 */
#divercity .stuff_l .icon{
    position: absolute;
    left: -190px;
    top: -20px;
}
#divercity .stuff_r .icon{
    position: absolute;
    right: -190px;
    top: -20px;
}
/* 三角アイコン */
#divercity .stuff_l::before{
    content: '';
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    left: -15px;
    top: 20px;
    border-right: 15px solid #fff;
    border-top: 15px solid transparent;
    border-bottom: 15px solid transparent;
}
#divercity .stuff_r::before{
    content: '';
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    right: -15px;
    top: 20px;
    border-left: 15px solid #fff;
    border-top: 15px solid transparent;
    border-bottom: 15px solid transparent;
}
#icon_career{
    position: relative;
    margin: 0 80px 15px 0;
}

#performance_ttl .box{
    background: url(../img/performance_ttl.png) no-repeat right top;
}
#performance_ttl p{
    font-size: 2em;
    line-height: 112px;
    height: 112px;
    padding-right: 20px;
    text-align: right;
}
#performance {
    position: relative;
}
#performance .line_blue{
    width: 230px;
    right: 0;
}

#member_ttl .box{
    background: url(../img/member_ttl.png) no-repeat left top;
}
#member_ttl p{
    font-size: 2em;
    line-height: 112px;
    height: 112px;
    padding-left: 20px;
    text-align: left;
}
#member {
    background: url(../img/member_bg.jpg) no-repeat center top fixed;
    position: relative;
}
#member_sub {
    background: url(../img/member_in_bg.jpg) no-repeat center top fixed;
    position: relative;
}
#member .line_blue,
#member_sub .line_blue{
    width: 270px;
    left: 0;
}
.member_wrap{
    display: inline-block;
    background: #f3f3f3;
    border: solid 10px #fff;
    padding: 40px;
    width: 100%;
}
.member_img{
    width: 47%;
    margin-right: 3%;
    float: left;
}
.member_inner{
    width: 49%;
    display: inline-block;
}
.member_wrap h3{
    font-size: 4em;
    font-family: "RoHMinchoPro_l";
}
.member_wrap h3::before{
    content: "";
    display:block;
    width: 100%;
    height: 2px;
    background: rgba(200,200,200,0.5);
}
.member_wrap h3::after{
    content: "";
    display:block;
    width: 100%;
    height: 2px;
    background: url(../img/member_uline.jpg) no-repeat left top;
}
.member_wrap h3 span{
    font-size: 35%;
    font-family: "RoHMinchoPro_l";
    display: block;
    padding: 0 0 15px 5px;
    letter-spacing: 8px;
}
.member_wrap h4{
    font-size: 1.4em;
    font-weight: 600;
}

#works_ttl .box{
    background: url(../img/work_ttl.png) no-repeat right top;
}
#works_ttl p{
    font-size: 2em;
    line-height: 112px;
    height: 112px;
    padding-right: 20px;
    text-align: right;
}
#works {
    background: url(../img/work_bg.jpg) no-repeat center top fixed;
    position: relative;
}
#works .line_blue{
    width: 380px;
    right: 0;
}

#recruit_ttl .box{
    background: url(../img/recruit_ttl.png) no-repeat left top;
}
#recruit_ttl p{
    font-size: 2em;
    line-height: 112px;
    height: 112px;
    padding-left: 20px;
    text-align: left;
}
#recruit {
    background: url(../img/recruit_bg.jpg) no-repeat center top fixed;
    position: relative;
}
#recruit_sub {
    background: url(../img/recruit_in_bg.jpg) no-repeat center top fixed;
    position: relative;
}
#recruit h2,
#recruit p{
    color:#fff;
}
#recruit .line_blue,
#recruit_sub .line_blue{
    width: 170px;
    left: 0;
}

#contact_ttl .box{
    background: url(../img/contact_ttl.png) no-repeat left top;
}
#contact_ttl p{
    font-size: 2em;
    line-height: 112px;
    height: 112px;
    padding-left: 20px;
    text-align: left;
}


/************ トップblog用 ************/

.post{
    width: 32%;
    float: left;
    margin: 0 2% 30px 0;
}
.post:nth-child(3n){
    margin: 0 0 30px 0;
}
.post-date,.post-title a,.post-content p,.post-content p a{
    text-decoration: none;
}
.post span:first-child a{
    display: block;
    height: 225px;
    overflow: hidden;
    width: 100%;
    margin: 0 0 10px;
}
.post img{
    margin:0 0 5px;
}
.post img:hover{
    opacity:.8;
    transition: 0.5s;
}
.post-title a:hover,.post-content p a:hover{
    color:#e66607;
}
.post-date{
    font-size: 1.4rem;
}
.post-title a{
    display:block;
    margin:0 0 20px;
    font-size: 1.9rem;
    height: 40px;
}
.post-content p .readme{
    font-size: 1.4rem;
    text-align: right;
    display: block;
}


/************ サブページ ************/

h3.sub_ttl{
    background: #5280cc;
    color: #fff;
    width: 70%;
    padding: 15px 0;
    box-shadow: 10px 10px 0 rgba(36, 57, 91, 0.1);
    font-size: 1.8em;
}
.interviewer {
    position: relative;
    display: block;
    right: 0;
    margin-left: 180px;
    margin-bottom: 50px;
    width: fit-content;
}
.interviewer p{
    padding: 0 0 0 40px;
}
.interviewer p span{
    width: 50px;
    display: inline-block;
    margin: 0 0 0 -50px;
}
.interviewer p span::before{
    content: '';
    position: absolute;
    display: block;
    width: 30px;
    height: 0;
    top: 14px;
    border-bottom: solid 1px #333;
}

/* 吹き出し本体 */
.interviewee{
    position: relative;
    padding: 20px 30px;
    border-radius: 10px;
    background-color: #d5e6ff;
    margin: 30px 100px 100px 190px
}
.interviewee p{
    font-size: 1.1em;
}
/* 画像 - 絶対配置で左上に配置 */
.interviewee .icon{
    position: absolute;
    left: -190px;
    top: -20px;
}
/* 三角アイコン */
.interviewee::before{
    content: '';
    position: absolute;
    display: block;
    width: 0;
    height: 0;
    left: -15px;
    top: 20px;
    border-right: 15px solid #d5e6ff;
    border-top: 15px solid transparent;
    border-bottom: 15px solid transparent;
}
.occupation{
    width: 940px;
    margin: 0 auto 80px;
}
.fas{
    margin: 0 10px 0 0;
    width: 24px;
    text-align: center;
}


/*footer*/

#company_ttl .box{
    background: url(../img/company_ttl.png) no-repeat right top;
}
#company_ttl p{
    font-size: 2em;
    line-height: 112px;
    height: 112px;
    padding-right: 20px;
    text-align: right;
}
#company_sub {
    background: url(../img/company_in_bg.jpg) no-repeat center top fixed;
    position: relative;
}
#company_sub .line_blue{
    width: 180px;
    right: 0;
}
footer .line_blue{
    width: 180px;
    right: 0;
}
footer{
    background: #0c1925 url(../img/company_bg.jpg) no-repeat center top fixed;
    position: relative;
}
footer p{
    color: #ffffff;
}
footer #company{
    margin: 0 auto 20px;
    text-align: center;
}
footer #company h3{
    color: #fff;
    font-size: 3rem;
    margin: 0 0 20px;
}
footer #company span{
    color: #fff;
    font-size: 1.4rem;
}
footer #company p {
    margin: 0 0 25px;
    border-bottom: 1px solid #fff;
    padding: 0 0 15px;
}
footer #company #tel{
    width: 100%;
    margin: 0 auto;
    background: rgba(0,0,0,0.5);
    padding: 15px 20px;
}
footer #company #tel .tel-number{
    margin: 5px 0;
    padding: 10px 0 10px;
    font-size: 3em;
}
footer #company #tel #attention{
    font-size: 1.4rem;
    margin:0;
}
.copyright{
    padding: 45px 0;
    background: #0c1925;
}
/* swiperタッチ無効 */
.swiper-container{
    pointer-events: none;
}
/* thanks */
#thx_body{
    position: relative;
    z-index: 100;
}
#thanks_wrap {
    background: rgba(255,255,255,.8);
    padding: 50px 0;
}
/********************************************************************************************/
@media screen and (max-width: 1300px) {  
    
    #to_top {
        bottom: 100px;
    }
    .copyright {
        font-size: 0.8em;
        line-height: 20px;
        padding: 25px 0 100px;
        background: #0c1925;
    }
}
/********************************************************************************************/
@media screen and (max-width: 1100px) {
    
    
    
}
/********************************************************************************************/
@media screen and (max-width: 1024px) {
    
/************ トップblog用 ************/
    .post {
        width: 49%;
        float: left;
        margin: 0 2% 30px 0;
    }    
    .post:nth-child(2n) {
        margin: 0 0 30px 0;
    }
    .post:nth-child(3n) {
        margin: 0 2% 30px 0;
    }
    .post:nth-child(5){
        margin: 0 2% 0 0;
    }
    .post:nth-child(6) {
        margin: 0;
    }
    .post:nth-child(9) {
        display: none;
    }
    .post-title a {
        text-align: center;
        line-height: 2.5rem;
    }
    .post-content p{
        text-align: center;
        line-height: 2.5rem;
    }
    .post-content p .readme {
        font-size: 1.1em;
        display: block;
        width: 70%;
        margin: 25px auto 20px;
        padding: 14px 0;
        border: none;
        border-radius: 4px;
        text-align: center;
        background: #1798e0;
        color: #FFF;
        transition: 0.5s;
    }
    .post span:first-child a {
        position: relative;
        height: 180px;
        margin: 0 0 10px;
    }
    .post span:first-child a img {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        margin: auto;
        width: 100%;
    }
    
    
    #main {
        background: url(../img/mi_bg.jpg) no-repeat right 40% top;
    }
    #main2 {
        background: url(../img/mi_bg2.jpg) no-repeat right 60% top;
    }
    #main_copy p {
        font-size: 80px;
        line-height: 95px;
        padding: 120px 0 0 20px;
    }
    #main_copy p span {
        font-size: 26px;
    }
    #main2 p {
        font-size: 80px;
        line-height: 95px;
        padding: 120px 0 0 20px;
    }
    #main2 p span.sml {
        font-size: 26px;
    }
    
    .member_wrap h3 span {
        font-size: 28%;
        font-family: "RoHMinchoPro_l";
        display: block;
        padding: 0 0 15px 5px;
        letter-spacing: 5px;
    }
    
    .occupation{
        width: 100%;
        margin: 0 auto 100px;
    }
    
    #icon_career{
        position: relative;
        margin: 0 auto 15px;
    }
}
/********************************************************************************************/
@media screen and (max-width: 896px) {
    h2 {
        font-size: 3.4rem;
    }
    #about_ttl .box,
    #culture_ttl .box,
    #divercity_ttl .box,
    #performance_ttl .box,
    #member_ttl .box,
    #works_ttl .box,
    #recruit_ttl .box,
    #company_ttl .box,
    #contact_ttl .box{
        background-size: auto 70px;
    }
    #about_ttl p,
    #culture_ttl p,
    #divercity_ttl p,
    #performance_ttl p,
    #member_ttl p,
    #works_ttl p,
    #recruit_ttl p,
    #company_ttl p,
    #contact_ttl p{
        font-size: 2em;
        line-height: 80px;
        height: 80px;
    }
    #divercity .stuff_l{
        margin: 30px 10px 40px 140px;
        padding: 10px 20px;
    }
    #divercity .stuff_r {
        margin: 30px 140px 40px 10px;
        padding: 10px 20px;
    }
    #divercity .stuff_l .icon{
        width: 100px;
        left: -130px;
        top: -15px;
    }
    #divercity .stuff_r .icon {
        width: 100px;
        right: -130px;
        top: -15px;
    }
    
    
    /************ サブページ ************/
    h3.sub_ttl {
        width: 100%;
    }
    .interviewee{
        margin: 30px 40px 60px 150px;
    }
    .interviewee .icon{
        width: 100px;
        left: -130px;
        top: -15px;
    }
    
    
}
/********************************************************************************************/
@media screen and (max-width: 480px) {
    .body_sub {
        margin: 0;
    }
    .body_sub #main,.body_sub #main2{
        height:61px;
    }
    #cv_wrap p:last-child {
        height: 55px;
/*        width: 60%;*/
    }
    #cv_wrap p a.h_entry {
        padding: 14px 0;
    }
    #cv_wrap p.tel_on {
        padding: 5px 0 0 0;
    }
    
    

    /************ common ************/

    #about span,
    #about p span,
    #culture span,
    #culture p span,
    #divercity span,
    #divercity p span,
    #performance span,
    #performance p span,
    #recruit span,
    #recruit p span{
        letter-spacing: -8px;
        font-family: "RoHMinchoPro_l";
        font-weight: 100;
    }
    
    #main_copy p span {
        font-size: 18px;
        display: inline-block;
    }
    #main_copy p {
        font-size: 34px;
        line-height: 42px;
        padding: 78px 0 0 5px;
    }
    #main_copy p span .tight{
        letter-spacing: -7px;
    }
    #main_copy p span.sml {
        font-size: 18px;
        display: inline-block;
    }
    .flex-container {
      display: contents;
    }
    .flex-container2 {
      display: contents;
    }
    .flex-container2 .item a {
        margin: 10px auto;
        display: block;
    }
    
    #main {
        background: url(../img/mi_bg.jpg) no-repeat right 38% top 0px;
        background-size: 310%;
        height: 230px;
    }
    #main2 {
        background: url(../img/mi_bg2.jpg) no-repeat right 63% top 0px;
        background-size: 310%;
        height: 230px;
    }
    #main3 {
        background: url(../img/mi_bg3.jpg) no-repeat right 5% top 0px;
        background-size: 215%;
        height: 290px;
    }
    #main4 {
        background: url(../img/mi_bg4.jpg) no-repeat right 40% top 0px;
        background-size: 215%;
        height: 290px;
    }
    #main p span {
        font-size: 18px;
        display: inline-block;
    }
    #main p {
        font-size: 34px;
        line-height: 42px;
        padding: 78px 0 0 5px;
    }
    #main p span .tight{
        letter-spacing: -7px;
    }
    #main2 p span.sml {
        font-size: 18px;
        display: inline-block;
    }
    #main2 p {
        font-size: 34px;
        line-height: 42px;
        padding: 78px 0 0 5px;
    }
    #main2 p span.tight{
        letter-spacing: -27px;
    }
    h2 {
        font-size: 1.2rem;
        line-height: 2rem;
        padding: 0;
    }
    #about_ttl .box,
    #culture_ttl .box,
    #divercity_ttl .box,
    #performance_ttl .box,
    #member_ttl .box,
    #works_ttl .box,
    #recruit_ttl .box,
    #company_ttl .box,
    #contact_ttl .box {
        background-size: auto 42px;
    }
    #about_ttl p,
    #culture_ttl p,
    #divercity_ttl p,
    #performance_ttl p,
    #member_ttl p,
    #works_ttl p,
    #recruit_ttl p,
    #company_ttl p,
    #contact_ttl p{
        font-size: 1.5em;
        line-height: 42px;
        height: 42px;
    }
    #about,
    #culture,
    #divercity,
    #performance,
    #member,
    #works,
    #recruit,
    #company{
        background-attachment: scroll;
        background-repeat: no-repeat;
    }
    #culture_sub,
    #member_sub,
    #recruit_sub {
        background-attachment: scroll;
        background-repeat: no-repeat;
    }
    #member{
        background-attachment: scroll;
        background-repeat: repeat;
    }
    #works {
        background: url(../img/work_bg_sp.jpg) no-repeat center top;
        background-size: cover;
    }
    #about {
        background-position: left -450px top;
        background-size: 1450px;
    }
    #culture {
        background-position: left -800px top;
        background-size: 1450px;
    }
    #divercity {
        background-position: left -800px top;
        background-size: 1450px;
    }
    #recruit {
        background-position: left -350px top;
        background-size: 1450px;
        background-color: #143965;
    }
    #recruit .container {
      display: block;
    }
    #recruit h2{
        font-size: 1.6em;
    }
    .container img{
        width: 90%;
        padding: 0;
    }
    .container img:first-child{
        margin: 0 0 30px;
    }
    .member_wrap{
        padding: 0;
    }
    .member_img{
        width: 100%;
        margin-right: 0;
        float: none;
    }
    .member_inner{
        width: 100%;
        text-align: center;
        padding: 0 4% 40px;
    }
    .member_wrap h3{
        font-size: 2.4em;
    }
    .member_wrap h3::before{
        height: 6px;
        background: none;
    }
    .member_wrap h3::after{
        content: "";
        display:block;
        width: 100%;
        height: 2px;
        background: url(../img/member_uline.jpg) no-repeat left top;
    }
    .member_wrap h3 span{
        font-size: 35%;
        font-family: "RoHMinchoPro_l";
        display: block;
        padding: 0 0 15px 5px;
        letter-spacing: 6px;
    }
    .member_wrap h4{
        font-size: 1.3em;
    }
    
    
    /************ トップblog用 ************/
    .post,
    .post:nth-child(2n),
    .post:nth-child(3n),
    .post:nth-child(5n){
        width: 94%;
        float: left;
        margin: 0 3% 30px;
    }
    .post span:first-child a {
        height: 160px;
    }
    .post:nth-child(6){
        width: 94%;
        float: left;
        margin: 0 3% 30;
    }
    .post-title a {
        font-size: 1.5rem;
        height: auto;
    }
    .post-content p .readme {
        font-size: 1.1em;
        display: block;
        width: 80%;
        margin: 25px auto 20px;
        padding: 14px 0;
        border: none;
        border-radius: 4px;
        text-align: center;
        background: #1798e0;
        color: #FFF;
        transition: 0.5s;
    }
    
    
    /************ サブページ ************/
    h3.sub_ttl {
        width: 90%;
        padding: 10px 20px;
        line-height: 1.5em;
        font-size: 1.2em;
    }
    .interviewer {
        margin-left: 5%;
        margin-right: 5%;
        margin-bottom: 30px;
    }
    .interviewer p span {
        width: 45px;
        display: inline-block;
        margin: 0 0 0 -45px;
    }
    .interviewer p span::before {
        width: 20px;
        top: 12px;
    }
    .interviewee {
        margin: 0px 20px 40px 100px;
    }
    .interviewee .icon {
        width: 60px;
        left: -90px;
        top: 0px;
    }
    
    
    
    /*footer*/
    footer {
        background-position: right -380px top;
        background-size: 1220px;
    }
    footer{
        background-attachment: scroll;
        background-repeat: repeat;
    }
    footer #company h3 {
        font-size: 1.8rem;
        margin: 0 0 10px;
    }
    #to_top {
        bottom: 84px;
        right: 15px;
        width: 44px;
    }
    .copyright {
        font-size: 0.8em;
        line-height: 20px;
        padding: 25px 0 80px;
        background: #0c1925;
    }
}