@charset"UTF-8";
@font-face {
    font-family: Yu Mincho;
    src: url("../font/Yu Mincho.otf");
}
/*01 HTMLリセット*/
body{margin:0px;padding:0px;font-family:"游ゴシック", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "ＭＳ Ｐゴシック", "Osaka";font-size: 112.5%; color: #131313;}
div,
form,
h1,h2,h3,h4,
ul,li,
dl,dt,dd,
p{margin:0px;padding:0px;line-height: 1.5em;}
p,dt,dd{text-align:justify;text-justify:distribute;}
a img,img{border:0;}
li{list-style-type:none;}

*{transition:color 200ms,background 200ms,border 200ms,opacity 300ms;
-moz-transition:color 200ms,background 200ms,border 200ms,opacity 300ms;
-webkit-transition:color 200ms,background 200ms,border 200ms,opacity 300ms;
-o-transition:color 200ms,background 200ms,border 200ms,opacity 300ms}

.f_yum{font-family: "游明朝", Yu Mincho;}

/*02 共通用基本設定*/
h1{}
h2{}
h3{}
h4{}
.clr{clear:both;}
.floatL{float:left;}
.floatR{float:right;}
.alignL{text-align:left;}
.alignR{text-align:right;}
.alignC{clear:both;text-align:center;}
.lastChild{margin-right:0%!important;float:right!important;}

.p-t5{
    padding-top: 5px;
}
.p-t10{
    padding-top: 10px;
}
.p-l20{
    padding-left: 20px;
}




/*03 レーヤアウト*/
#Wrap{}
#Contents{}
address{}




/*04 ヘッダー関連*/
header{
    position: relative;
}
header h1{
    position: absolute;
    z-index: 9;
    left: 50px;
    top: 50px;
}
header h1 span{
    display: none;
}
header img{
    display: block;
    max-width: 100%;
    height: auto;
}
header h1 a{
    display: block;
}
header h1 a:hover{
    filter: alpha(opacity=60);-moz-opacity:0.6;opacity:0.6;
}
header #Header{
    position: absolute;
    z-index: 9;
    width: 802px;
    right: 45px;
    top: 50px;
}
header .head-link li{
    float: right;
    margin-right: 1.2em;
}
header .head-link li:first-child{
    padding-left: 1em;
}
header .head-link li a{
    background: url(../img/common/ico_arrow01.png) no-repeat left center;
    padding-left: 1.1em;
    color: #131313;
    text-decoration: none;
}
header .head-link li a:hover{
    color:#e40443;
}


header nav{
    width: 100%;
    padding-top: 25px;
}
header nav ul{
    width: 100%;
    background-color: #FFFFFF;
    box-shadow: rgba(0,0,0,.18) 5px 4px 0;
    border-radius: 13px;
    overflow: hidden;
}
header nav li{
    width: 16.666%;
    float: left;
    background: url(../img/common/ico_line01.png) no-repeat left center;
}
header nav li:nth-child(1){
    background-image: none;
}
header nav li a{
    padding: 14px 0;
    display: block;
    margin-right: 1px;
    margin-left: 2px;
}
header nav li a.active,
header nav li a:hover{
    background-color: #e40443;
}

header .side-contact{
    position: fixed;
    right: 0;
    z-index: 99;
    top: 50%;
}

header #Show{
    width: 100%;
    position: relative;
}
header #Show .swiper-slide p{
    display: block;
    width: 35%;
    font-size: 200.222%;
    color: #FFFFFF;
    background-color: #e40443;
    font-family: "游明朝", Yu Mincho;
    position: absolute;
    line-height: 1.5em;
    top: 40%;
}
header #Show .swiper-slide span{
    display: block;
    padding: 10% 15%;
}
header #Show .swiper-slide:nth-child(1) p{
    right: 0;
}
header #Show .swiper-slide:nth-child(2) p{
    left: 0;
}
header #Show .swiper-slide:nth-child(3) p{
    left: 0;
}
header #Show .swiper-slide:nth-child(4) p{
    right: 0;
}
header #Show img{
    width: 100%;
    height: auto;
    display: block;
}
header #Menu{
    display: none;
}

#PageTtl{
    height: 620px;
    background-repeat:no-repeat;
    background-position: center center;
    background-size: auto 100%;
}
#PageTtl h2{
    position: absolute;
    width: 100%;
    left: 0;
    bottom: 15%;
}
#PageTtl h2 img{
    display: block;
    margin: 0 auto;
    height: auto;
}
#PageTtl img{
    height: 100%;
    width: auto;
    max-width: none;
}

#Path{
    background-color: #efefef;
    padding-top: 13px;
    padding-bottom: 11px;
}
#Path ul{
    width: 1100px;
    margin: 0 auto;
}
#Path li{
    float: left;
    margin-right: 20px;
}
#Path li a{
    color: #131313;
    margin-right: 20px;
    text-decoration: none;
}
#Path li a:hover{
    text-decoration: underline;
}


/*05 コンテンツ関連　*/
.home_txt{
    background-image:url(../img/top/bg01.jpg);
    background-repeat:no-repeat;
    background-position: center center;
    filter:"progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='scale')"\9;
    -moz-background-size:100% 100%\9;
    background-size:100% 100%\9;
    background-size:cover;
    -moz-background-size:cover;
    -webkit-background-size:cover;
    padding: 150px 30px;
}
.home_txt h2{
    font-family: "游明朝", Yu Mincho;
    font-size: 250%;
    color: #e40443;
    text-align: center;
    padding-bottom: 30px;
}
.home_txt p{
    text-align: center;
    line-height: 2.2em;
    padding-top: 15px;
}
.home_logos{
    background: url(../img/common/bg01.gif) repeat-x left bottom;
    background-size: auto 100%;
    padding: 75px 30px;
}
.home_logos h2{
    display: block;
    text-align: center;
    padding-bottom: 25px;
}
.home_logos img{
    display: block;
    margin: 0 auto;
    max-width: 100%;
    height: auto;
}
.home_logos ul{
    max-width: 1100px;
    margin: 0 auto;
}
.home_logos li{
    width: 19.272%;
    margin-right: 0.91%;
    float: left;
}
.home_logos li:last-child{
    margin-right: 0;
}
.home_logos a{
    display: block;
}
.home_logos a:hover{
    filter: alpha(opacity=60);-moz-opacity:0.6;opacity:0.6;
}


.home_logos_link{

    background-size: auto 100%;
    padding: 75px 30px;
}
.home_logos_link h2{
    display: block;
    text-align: center;
    padding-bottom: 25px;
}
.home_logos_link img{
    display: block;
    margin: 0 auto;
    max-width: 100%;
    height: auto;
}
.home_logos_link ul{
    max-width: 1100px;
    margin: 0 auto;
}
.home_logos_link li{
    width: 25%;
    margin-right: 0.91%;
    vertical-align:  middle;  
    float: left;
}
.home_logos_link li:last-child{
    margin-right: 0;
}
.home_logos_link a{
    display: block;
}
.home_logos_link a:hover{
    filter: alpha(opacity=60);-moz-opacity:0.6;opacity:0.6;
}



.home_logos_link_pc{
    background-color: #fffbeb;
    background-size: auto 100%;
    padding: 10px 30px 75px 30px;
}
.home_logos_link_pc h2{
    display: block;
    text-align: center;
    padding-bottom: 25px;
}
.home_logos_link_pc img{
    display: block;
    margin: 0 auto;
    max-width: 100%;
    height: auto;
}
.home_logos_link_pc ul{
    max-width: 1100px;
    margin: 0 auto;
    text-align: center;

}
.home_logos_link_pc li{
    width: 24.0%;
    margin-right: 0.91%;
    margin-top: 5%;   
    vertical-align:  middle;
    display: inline-block;   
    float: none;
}
.home_logos_link_pc li:last-child{
    margin-right: 0;
}
.home_logos_link_pc a{
    display: block;
}
.home_logos_link_pc a:hover{
    filter: alpha(opacity=60);-moz-opacity:0.6;opacity:0.6;
}



#Recruit{
    width: 1100px;
    margin: 0 auto;
    padding-top: 75px;
    padding-bottom: 140px;
}
#Recruit dt{
    font-size: 150%;
    text-align: center;
    color: #e40443;
    padding-bottom: 30px;
}
#Recruit dd{
    line-height: 2.2em;
    text-align: center;
}
#Recruit table{
    margin: 50px 0;
    width: 100%;
    border-top: #bcbcbc solid 1px;
}
#Recruit th{
    width: 210px;
    font-weight: normal;
    text-align: center;
    border-bottom: #bcbcbc solid 1px;
    padding: 15px 10px;
}
#Recruit td{
    padding: 15px 10px;
    border-bottom: #bcbcbc solid 1px;
}
#Recruit .btn-box{
    max-width: 774px;
    margin: 0 auto;
}
#Recruit .btn-box li{
    width: 48.708%;
    float: left;
}
#Recruit .btn-box li:last-child{
    float: right;
}
#Recruit .btn-box li img{
    display: block;
    max-width: 100%;
    height: auto;
}

#Strength{
    padding: 60px 0 0 0;
}
#Strength .box{
    width: 1036px;
    border: #e40443 solid 2px;
    margin: 0 auto;
    box-shadow: #fff3f3 27px 27px 0;
    color: #e40443;
}
#Strength .sub-box{
    box-shadow: #ffffff 25px 25px 0 inset;
    background-color: #fff3f3;
    padding: 5% 8% 3% 8%;
}
#Strength .box h2{
    font-size: 211.111%;
    color: #e40443;
    text-align: center;
    font-weight: normal;
}
#Strength .box h2 img{
    margin: 0 auto 10px auto;
    display: block;
}
#Strength .box dl{
    padding-top: 35px;
}
#Strength .box dt{
    font-size: 120%;
    font-weight: bold;
    background: url(../img/common/ico_line02.png) repeat-x left bottom;
    display: inline-block;
    padding-bottom: 8px;
    margin-bottom: 8px;
}
#Strength .box dd{
    padding-bottom: 15px;
    display: block;
}
#Strength .list .bgc{
    background-color: #fffbeb;
    margin-top: 80px;
    padding-bottom: 80px;
}
#Strength .list dl{
    width: 1040px;
    margin: 0 auto;
}
#Strength .list dt{
    display: flex;
    text-align: center;
    font-size: 188.889%;
    color: #e40443;
    justify-content: flex-start;
    align-items: center;
    position: relative;
    z-index: 9;
    top: -30px;
}
#Strength .list dt img{
    display: block;
    align-items: center;

}
#Strength .list dt span{
    margin-left: 30px;
    display: block;
    width: 100%;
    text-align: left;
}
#Strength .list dt span.alignC{
    text-align: center!important;
    margin-left: 0;
}
#Strength .list dd{
    padding-left: 20px;
    margin-top: -50px;
}
#Strength .list dd p{
    padding-top: 8px;
    text-align: center;

}
#Strength .list dd a{
    display: block;
    margin: 0 auto;
    width: 252px;
    height: 68px;
    line-height: 68px;
    border: #e40443 solid 2px;
    margin-top: 20px;
    text-align: center;
    text-decoration: none;
    color: #e40443;
    font-size: 111.111%;
    background:#ffffff url(../img/common/ico_arrow02.png) no-repeat 95% 50%;
}
#Strength .list dd a:hover{
    background-color: #e40443;
    color: #ffffff;
}
#Strength .list dd a:hover span{
    text-indent: 0em;
}
#Strength .list dd a span{
    display: block;
    text-indent: 0.8em;
}
#Strength .list dd a .ico01{
    background: url(../img/common/ico02.png) no-repeat 7% 50%;
}
#Strength .list dd a .ico02{
    background: url(../img/common/ico03.png) no-repeat 7% 50%;
}
#Strength .list dd a .ico03{
    background: url(../img/common/ico04.png) no-repeat 7% 50%;
}

#Flow .box{
    width: 1100px;
    margin: 0 auto;
}
#Flow .bgc{
    background:#fff3f3 url(../img/flow/box_top.gif) no-repeat center top;
}
#Flow .sub-box{
    background: url(../img/flow/box_btm.gif) no-repeat center bottom;
}
#Flow .line{
    background: url(../img/common/ico_line03.png) repeat-y 7.590% top;
    padding-top: 120px;
    width: 1100px;
    margin: 0 auto;

}

#Flow dl{
    padding-top: 120px;
    padding-bottom: 100px;
    padding-left: 17.272%;
    position: relative;
    background: url(../img/common/ico_line03.png) repeat-y 7.590% top;
}
#Flow dl.top{
    padding-top: 0;
    margin-top: 50px;
}
#Flow dl.top img{
    top: 0;
}
#Flow dl.last{
    background-image: none;
    padding-top: 0;
}
#Flow dl.last dt img{
    top: 0;
}


#Flow dt img{
    width: 15.181%;
    height: auto;
    display: block;
    position: absolute;
    left: 0;
    top: 120px;
}
#Flow dt{
    font-size: 188.889%;
    color: #e40443;
    padding-bottom: 15px;
}
#Flow dd .article{
    width: 50%;
    float: left;
}
#Flow dd .pic{
    width: 46.5%;
    float: right;
    display: block;
    height: auto;
}

#Flow .contact-box{
    width: 885px;
    margin: 0 auto;
    padding: 50px 0;
}
#Flow .contact-box .ttl{
    padding-bottom: 20px;
    font-size: 188.889%;
    text-align: center;
    color: #e40443;
}
#Flow .contact-box img{
    display: block;
}
#Flow .contact-box ul{
    width: 100%;
}
#Flow .contact-box li:first-child{
    width: 45%;
    float: left;
}
#Flow .contact-box li:last-child{
    width: 45%;
    float: right;
}
#Flow .contact-box li img{
    display: block;
    max-width: 100%;
    height: auto;
}
#Flow .contact-box li a{
    display: block;
    width: 100%;
}
#Flow .contact-box li a:hover{
    filter: alpha(opacity=60);-moz-opacity:0.6;opacity:0.6;
}

#Contact{
    width: 1100px;
    margin: 0 auto;
    padding: 50px 0;
}
#Contact table{
    border-top: #bdbdbd solid 1px;
    width: 100%;
}
#Contact th{
    width: 221px;
    text-align: left;
    font-weight: normal;
    background-color: #fff3f3;
    padding: 10px 12px;
    border-bottom: #bdbdbd solid 1px;
}
#Contact th img{
    vertical-align: middle;
    margin-left: 10px;
}
#Contact td{
    padding: 5px 20px;
    border-bottom: #bdbdbd solid 1px;
}
#Contact td select,
#Contact td input,
#Contact td textarea{
    font-size: 100%;
    padding: 6px 1.5%;
    border: #d2d2d2 solid 1px;
    border-radius: 6px;
    display: block;
    margin: 3px 0;
}
#Contact td textarea{
    width: 97%;
}
#Contact td input.checkbox,
#Contact td input.radio{
    display: inline-block;
}
#Contact .btn-send{
    display: block;
    width: 412px;
    height: 88px;
    background:#e40443 url(../img/common/ico_arrow03.png) no-repeat 95% 50%;
    font-size: 145%;
    color: #FFFFFF;
    margin: 40px auto 0 auto;
    border: #e40443 solid 2px;
    cursor: pointer;
}
#Contact .btn-send:hover{
    color: #e40443;
    background:#FFFFFF url(../img/common/ico_arrow02.png) no-repeat 95% 50%;
}
#Products h2{
    font-weight: normal;
    text-align: center;
    color: #e40443;
    font-size: 188.889%;
    padding-top: 70px;
    padding-bottom: 50px;
}

#Products .boxA{
    border-top: #e40443 solid 2px;
    background-color: #fffbeb;
    padding-top: 50px;
    padding-bottom: 50px;
    padding-left: 20px;
    padding-right: 20px;
}

#Products .boxB{
    border-top: #e40443 solid 2px;
    background-color: #ececec;
    padding-top: 50px;
    padding-bottom: 50px;
    padding-left: 20px;
    padding-right: 20px;
}

#Products .boxC{
    border-top: #e40443 solid 2px;
    background-color: #fffbeb;
    padding-top: 50px;
    padding-bottom: 0px;
    padding-left: 20px;
    padding-right: 20px;
}


#Products h3{
    background: url(../img/products/ico_line01.png) no-repeat top center;
    font-size: 145%;
    font-weight: normal;
    text-align: center;
    font-family: "游明朝", Yu Mincho;
    margin-bottom: 30px;
}
#Products h3 span{
    display: block;
    background: url(../img/products/ico_line02.png) no-repeat bottom center;
    padding: 10px 0 25px 0;
}

#Products .ttl{
    background: url(../img/products/ico_line03.png) repeat-x center center;
    width: 1100px;
    margin: 50px auto 25px auto;
    text-align: center;
    font-size: 166.667%;
    color: #e40443;
}
#Products .boxA .ttl span{
    padding: 0 20px;
    background-color: #fffbeb;
}
#Products .boxB .ttl span{
    padding: 0 20px;
    background-color: #ececec;
}

#Products .boxC .ttl span{
    padding: 0 20px;
    background-color: #fffbeb;
}

#Products ul{
    width: 1100px;
    margin: 0 auto;
}
#Products li{
    width: 32.454%;
    margin-right: 1.319%;
    float: left;
}
#Products li:last-child{
    margin-right: 0;
}
#Products li img{
    display: block;
    width: 100%;
    height: auto;
}
#Products li dl{
    padding-top: 10px;
}
#Products li dt{
    color: #e40443;
    text-align: center;
    font-size: 120%;
}
#Products li dd{
    font-size: 90%;
}

#Products .btn-box{
    max-width: 1100px;
    margin: 50px auto 20px;
}
#Products .btn-box li{
    width: 32%;
    float: left;
}
#Products .btn-box li:last-child{
    float: right;
}
#Products .btn-box li img{
    display: block;
    max-width: 100%;
    height: auto;
	margin: 10px 0px 0px 0px;
}


#Products .btn-box2{
    max-width: 800px;
    margin: 10px auto 50px;
}
#Products .btn-box2 li{
    width: 48%;
    float: left;
}
#Products .btn-box2 li:last-child{
    float: right;
}
#Products .btn-box2 li img{
    display: block;
    max-width: 100%;
    height: auto;
	margin: 10px 0px 0px 0px;
}



.company #Idea{
    background-image:url(../img/company/bg01.jpg);
    background-repeat:no-repeat;
    background-position: center center;
    filter:"progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='scale')"\9;
    -moz-background-size:100% 100%\9;
    background-size:100% 100%\9;
    background-size:cover;
    -moz-background-size:cover;
    -webkit-background-size:cover;
    margin-top: 110px;
    padding-bottom: 110px;
}
.company #Idea h2{
    width: 633px;
    height: 192px;
    background-color: #e40443;
    box-shadow: rgba(0,0,0,.18) 5px 4px 0;
    color: #ffffff;
    font-weight: normal;
    text-align: center;
    margin:0 auto;
    position: relative;
    top: -50px;
    padding-top: 60px;
    font-size: 188.889%;
}
.company #Idea h2 img{
    display: block;
    margin: 0 auto 20px auto;
}
.company #Idea .article{
    text-align: center;
    color: #e40443;
    line-height: 2.2em;
    padding-bottom: 50px;
}
.company #Idea table{
    width: 650px;
    margin: 0 auto;
}
.company #Idea td{
    height: 80px;
    background:#ffffff url(../img/common/ico_arrow02.png) no-repeat 95% 50%;
}
.company #Idea td:hover{
    background:#e40443 url(../img/common/ico_arrow03.png) no-repeat 95% 50%;
}
.company #Idea td.top{
    background:#ffffff url(../img/common/ico_arrow02.png) no-repeat 97.5% 50%;
}
.company #Idea td.top:hover{
    background:#e40443 url(../img/common/ico_arrow03.png) no-repeat 97.5% 50%;
}
.company #Idea td a{
    display: flex;
    justify-content: space-around;
    align-items: center;
    height: 100%;
    border: #e40443 solid 2px;
    text-decoration: none;
    text-align: center;
    color: #e40443;
    font-size: 90%;
    line-height: 1.3em;
    padding-left: 70px;
    padding-right: 60px;
}
.company #Idea td a:hover{
    color: #ffffff;
}
.company #Idea td a span{
    display: block;
}
.company #Idea td a.ico01{
    background: url(../img/common/ico13.png) no-repeat 20px 50%;
}
.company #Idea td a.ico01:hover{
    background: url(../img/common/ico13_o.png) no-repeat 20px 50%;
}
.company #Idea td a.ico02{
    background: url(../img/common/ico05.png) no-repeat 28px 50%;
}
.company #Idea td a.ico02:hover{
    background: url(../img/common/ico05_o.png) no-repeat 28px 50%;
}
.company #Idea td a.ico03{
    background: url(../img/common/ico06.png) no-repeat 28px 50%;
}
.company #Idea td a.ico03:hover{
    background: url(../img/common/ico06_o.png) no-repeat 28px 50%;
}
.company #Idea td a.ico04{
    background: url(../img/common/ico07.png) no-repeat 28px 50%;
}
.company #Idea td a.ico04:hover{
    background: url(../img/common/ico07_o.png) no-repeat 28px 50%;
}
.company #Idea td a.ico05{
    background: url(../img/common/ico08.png) no-repeat 28px 50%;
}
.company #Idea td a.ico05:hover{
    background: url(../img/common/ico08_o.png) no-repeat 28px 50%;
}

.company #Manager{
    background-image:url(../img/company/bg02.jpg);
    background-repeat:no-repeat;
    background-position: center center;
    filter:"progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='scale')"\9;
    -moz-background-size:100% 100%\9;
    background-size:100% 100%\9;
    background-size:cover;
    -moz-background-size:cover;
    -webkit-background-size:cover;
    padding: 70px 0 50px 0;
}
.company #Manager h2{
    font-size: 188.889%;
    text-align: center;
    font-weight: normal;
    color: #e40443;
}
.company #Manager h2 span{
    display: block;
    font-size: 47.368%;
    text-align: right;
    color: #131313;
}
.company #Manager img{
    display: block;
    margin: 0 auto;
}
.company #Manager .sub-box{
    width: 1100px;
    margin: 0 auto;
}
.company #Manager p{
    text-align: center;
    line-height: 2.2em;
    padding-top: 20px;
}
.company #Info{
    width: 1100px;
    margin: 0 auto;
    padding-bottom: 110px;
    padding-top: 100px;
}
.company #Info h2{
    font-size: 188.889%;
    text-align: center;
    font-weight: normal;
    color: #e40443;
    padding-bottom: 60px;
}
.company #Info h2 img{
    margin: 0 auto 15px auto;
}

.company #Info img{
    display: block;
    max-width: 100%;
    height: auto;
    margin: 0 auto;
}
.company #Info table{
    margin-top: 50px;
    width: 100%;
    border-top: #bcbcbc solid 1px;
}
.company #Info th{
    width: 210px;
    border-bottom: #bcbcbc solid 1px;
    font-weight: normal;
    padding: 15px 0;
}
.company #Info td{
    border-bottom: #bcbcbc solid 1px;
    padding: 15px 0 15px 10px;
}

.company #History{
    background-image:url(../img/company/bg03.jpg);
    background-repeat:no-repeat;
    background-position: center center;
    filter:"progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='scale')"\9;
    -moz-background-size:100% 100%\9;
    background-size:100% 100%\9;
    background-size:cover;
    -moz-background-size:cover;
    -webkit-background-size:cover;
    padding: 70px 0 50px 0;
}
.company #History h2{
    font-size: 188.889%;
    text-align: center;
    font-weight: normal;
    color: #e40443;
    margin-bottom: 80px;
}
.company #History h2 span{
    display: block;
    font-size: 47.368%;
    text-align: right;
    color: #131313;
}
.company #History img{
    display: block;
    margin: 0 auto 15px auto;
}
.company #History ul{
    width: 950px;
    margin: 0 auto;
}
.company #History li{
    clear: both;
    padding-bottom: 40px;
    background: url(../img/common/ico_line04.png) repeat-y 9px 5px;
}
.company #History li:first-child div{
    line-height: 21px;
    height: 21px;
}
.company #History li:first-child p{
    margin-top: -4px;
}
.company #History li:last-child{
    background-image: none;
}
.company #History li .date{
    float: left;
    padding-left: 40px;
    background: url(../img/common/ico12.png) no-repeat left center;
}
.company #History li p{
    padding-left: 20px;
    float: left;
}
.company #Address{
    padding: 70px 0 50px 0;
}
.company #Address h2{
    font-size: 188.889%;
    text-align: center;
    font-weight: normal;
    color: #e40443;
    margin-bottom: 80px;
}
.company #Address h2 span{
    display: block;
    font-size: 47.368%;
    text-align: right;
    color: #131313;
}
.company #Address img{
    display: block;
    margin: 0 auto 15px auto;
    max-width: 100%;
    height: auto;
}
.company #Address iframe{
    display: block;
    width: 100%;
    height: 430px;
    margin-top: 60px;
    margin-bottom: 50px;
    border: none;
}
.company #Address .info{
    width: 1040px;
    padding: 30px;
    margin: 0 auto;
    background-color: #fff3f3;
    font-size: 166.667%;
    text-align: center;
    position: relative;
}
.company #Address .info span{
    display: inline-block;
    margin-top: 10px;
}
.company #Address .info small{
    display: block;
    font-size: 53.333%;
    line-height: 1em;
    text-align: left;
}
.company #Address .info:before{content:"";position:absolute;left:50%;top:-17px;width:0;height:0;border-left:17px solid transparent;border-bottom:17px solid #fff3f3;border-right:17px solid transparent;margin-left:-17px;}



#FootNavi{
    width: 100%;
    font-size: 77.778%;
    padding-bottom: 30px;
}
#FootNavi img{
    display: block;
    width: 100%;
    height: auto;
}
#FootNavi .sub-box{
    width: 1100px;
    margin: 0 auto;
}
#FootNavi ul{
    text-align: center;
    margin-left: 55px;
    margin-right: 55px;
    margin-bottom: 15px;
    padding-bottom: 15px;
    border-bottom: #cdcdcd solid 1px;
}
#FootNavi li{
    display: inline-block;
    font-size: 114.285%;
    padding-top: 30px;
}
#FootNavi li a{
    display: block;
    text-align: center;
    color: #131313;
    line-height: 1.2em;
    text-decoration: none;
    padding-left: 30px;
    padding-right: 30px;
}
#FootNavi li span{
    font-weight: bold;
}
#FootNavi li small{
    font-size: 75%;
    color: #e40443;
    display: block;
    padding-top: 5px;
    line-height: 1.2em;
}
#FootNavi .foot-pic span{
    display: none;
}

footer{
    background-color: #ececec;
    position: relative;
}
footer img{
    max-width: 100%;
    display: block;
    height: auto;
}
footer .sub-box{
    width: 1100px;
    margin: 0 auto;
    padding: 40px 0;
}
footer .sub-box .floatL{
    width: 34.272%;
    float: left;
}
footer .sub-box .floatL p{
    padding-left: 28%;
}
footer .sub-box .floatL span{
    display: none;
}
footer .sub-box table{
    width: 54.545%;
    float: right;
}
footer .sub-box td{
    background-color: #FFFFFF;
}
footer .sub-box td.bgc{
    background-color: #e40443;
}
footer .sub-box td a{
    display: block;
    padding: 15px;
}
footer .sub-box td a:hover{
    filter: alpha(opacity=60);-moz-opacity:0.6;opacity:0.6;
}
footer .sub-box td span{
    display: block;
    padding: 15px;
}

.btn-pagetop{
    width: 82px;
    position: absolute;
    right: 55px;
    bottom: 123px;
    border-radius: 10px;
    box-shadow: rgba(0,0,0,.18) 5px 4px 0;
    overflow: hidden;
    z-index: 99;
}
.btn-pagetop:hover{
    filter: alpha(opacity=60);-moz-opacity:0.6;opacity:0.6;
}

address{
    background-color: #e40443;
    color: #FFFFFF;
    font-size: 66.667%;
    padding: 12px;
    font-style: normal;
    text-align: center;
}

@media all and (min-width:1499px)
{
	
	.sp {
        display: none;
       }    
    }


@media all and (max-width:1499px)
{
	
	.sp {
        display: none;
       }    

	.pc {
 display: block;
}	
	
    header h1{
        width: 30%;
    }
    header #Header{
        width: 53.333%;
    }
    header #Show .swiper-slide p{
        width: 40%;
    font-size: 180.222%;        
    }
    .btn-pagetop{
        width: 60px;
        right: 20px;
        bottom: 60px;
    }
}

@media all and (max-width:1199px)
{
	
	.sp {
        display: none;
       }    

	.pc {
 display: block;
}	
	
    body{
        font-size: 100%;
    }
    .home_logos ul{
        width: 90%;
    }
    .home_logos_link ul{
        width: 90%;
    } 
    .home_logos_link_pc ul{
        width: 90%;
    }       
    
    header #Show .swiper-slide p{
        font-size: 150%;
    }
    header .head-link li{
        font-size: 80%;
    }
    header .head-link li.tel img{
        width: 200px;
    }
    .home_txt{
        padding: 50px 30px;
    }
    .home_txt h2{
        font-size: 200%;
    }
    .home_logos h2 img{
        width: 240px;
        height: auto;
    }
    #PageTtl{
        height: 450px;
        overflow: hidden;
    }
    #PageTtl h2 img{
        height: 120px;
        width: auto;
    }

    #Path{
        padding-left: 10px;
        padding-right: 10px;
    }
    #Path ul{
        width: auto;
    }

    #Recruit{
        width: auto;
        padding-left: 20px;
        padding-right: 20px;
    }

    #Strength img{
        max-width: 100%;
        height: auto;
        display: block;
    }
    #Strength .list dl{
        width: auto;
        padding-left: 20px;
        padding-right: 20px;
    }
    #Strength .box{
        width: auto;
        margin-left: 20px;
        margin-right: 20px;
    }
    #Flow .contact-box,
    #Flow .box{
        width: auto;
        padding-left: 20px;
        padding-right: 20px;
    }
    #Flow .line{
        width: auto;
        margin-left: 20px;
        margin-right: 20px;
    }
    #Flow .box dl{
        padding-bottom: 50px!important;
    }
    #Flow .line,
    #Flow dl{
        padding-bottom: 0;
        padding-top: 80px;
    }

    #Flow .contact-box .ttl,
    #Flow dt{
        font-size: 150%;
    }
    #Flow dt img{
        width: 14.4%;
        top:80px;
    }
    #Flow dd .pic{
        width: 100%;
        float: none;
    }
    #Flow dd .article{
        width: 100%;
        float: none;
        padding-top: 20px;
    }

    #Contact{
        width: auto;
        padding-left: 20px;
        padding-right: 20px;
    }

    #FootNavi .sub-box,
    footer .sub-box{
        width: auto;
        padding-left: 15px;
        padding-right: 15px;
    }

    #FootNavi ul{
        margin-left: 0;
        margin-right: 0;
    }
    #FootNavi li{
        width: 16.666%;
        float: left;
    }
    #FootNavi li a{
        padding-left: 5px;
        padding-right: 5px;
    }

    footer .sub-box{
        padding-top: 20px;
        padding-bottom: 20px;
    }

    .company #History ul,
    .company #Manager .sub-box,
    .company #Info{
        width: auto;
        padding-left: 20px;
        padding-right: 20px;
    }

    .company #Address .info,
    .company #Address .pic{
        width: auto;
        margin-left: 20px;
        margin-right: 20px;
    }
}

@media all and (max-width:767px)
{
	
	.sp {
        display: block;
       }    

	.pc {
 display: none;
}		

    header h1{
        width: 50%;
        left: 20px;
        top: 20px;
        z-index: 999;
    }
    header .head-link,
    header nav,
    header .side-contact{
        display: none!important;
    }
    header #Header{
        width: 100%;
        right: 0;
        top: 0;
    }
    #Menu {
        position: absolute;
        top: 0;
        width: 100%;
        z-index: 99;
        display: block!important;
    }
    #Menu .btn-menu {
        width: 9.387%;
        position: absolute;
        right: 2.607%;
        top: 20px;
        margin-right: 2px;
        margin-bottom: 2px;
        display: block;
        z-index: 999;
    }
    #Menu .btn-menu span{
        display: none;
    }
    #Menu .btn-menu.open {
        right: 1%;
        top: 1%;
    }
    #Menu .btn-menu.open img {
        display: none;
    }
    #Menu .btn-menu.open span,
    #Menu .btn-menu.open span img{
        display: block!important;
    }
    #Menu .menu-list {
        clear: both;
        display: none;
        width: auto;
        position: relative;
        z-index: 998;
        padding: 20% 20px 10% 20px;
        background-color: #ffffff;
        box-shadow: rgba(0,0,0,.18) 5px 4px 0;
    }
    #Menu .menu-list ul {
        float: none;
        border: #e40443 solid 2px;
        border-radius: 15px;
        padding: 5% 10%;
    }
    #Menu .menu-list li {
        display: block;
        margin: 0;
        font-size: 120%;
        text-align: center;
        padding: 15px;
        border-bottom: #c3c3c3 solid 2px;
    }
    #Menu .menu-list li:last-child{
        border-bottom: none;
    }
    #Menu .menu-list li a {
        display: block;
        color: #131313;
        text-align: center;
        text-decoration: none;
    }
    #Menu .menu-list li span{
        display: block;
        width: 48%;
        margin-right: 2%;
        float: left;
        text-align: right;
    }
    #Menu .menu-list li small{
        display: block;
        width: 48%;
        margin-left: 2%;
        float: left;
        text-align: left;
        color: #e40443;
    }
    #Menu .btn-mail{
        display: block;
        position: absolute;
        width: 9.387%;
        right: 13.298%;
        top: 20px;
    }
    #Menu .btn-tel{
        display: block;
        position: absolute;
        width: 9.387%;
        right: 23.989%;
        top: 20px;
    }
    header #Show .swiper-slide p{
        font-size: 120%;
        width: auto;
        display: inline-block;
    }
    header #Show .swiper-slide span{
        padding: 15px 25px;
    }

    header h1 img,
    footer .sub-box .floatL img{
        display: none;
    }
    header h1 span,
    header h1 span img,
    footer .sub-box .floatL span,
    footer .sub-box .floatL span img{
        display: block!important;
    }

    #PageTtl{
        height: 390px;
    }

    .home_txt {
        background-image: url(../img/top/sp_bg01.jpg);
        padding-top: 20%;
        padding-bottom: 20%;
    }
    .home_txt p{
        line-height: 1.8em;
    }
    .home_logos{
        padding-top: 30px;
        padding-bottom: 30px;
    }
    .home_logos ul{
        width: auto;
        text-align: center;
    }
    .home_logos li{
        width: 30%;
        display: inline-block;
        float: none;
    }

    .home_logos_link{
        padding-top: 30px;
        padding-bottom: 30px;
        background-color: #fffbeb;        
    }
    .home_logos_link ul{
        width: auto;
        text-align: center;
    }
    .home_logos_link li{
        width: 30%;
        display: inline-block;
        float: none;
    }

    .home_logos_link_pc{
        padding-top: 30px;
        padding-bottom: 30px;
        background-color: #fffbeb;
 
    }
    .home_logos_link_pc ul{
        width: auto;
        text-align: center;
    }
    .home_logos_link_pc li{
        width: 30%;
        display: inline-block;
        float: none;
    }


    #Recruit{
        padding-top: 30px;
        padding-bottom: 50px;
    }
    #Recruit table{
        margin-bottom: 20px;
    }
    #Recruit th{
        width: 100px;
        padding: 10px 0;
    }
    #Recruit td{
        padding: 10px 0;
    }
    #Recruit .btn-box li{
        width: 100%;
        float: none;
    }
    #Recruit .btn-box li:last-child{
        margin-top: 10px;
    }

    #Strength .box{
        box-shadow: #fff3f3 12px 12px 0;
    }
    #Strength .sub-box{
        box-shadow: #ffffff 10px 10px 0 inset;
        padding: 30px;
    }
    #Strength .list dt{
        font-size: 150%;
        top: -20px;
    }
    #Strength .list dt img{
        width: 120px;
        height: 120px;
    }
    #Strength .list dd{
        padding-left: 10px;
        margin-top: -40px;
    }
    #Strength .list dd a{
        height: 60px;
        line-height: 60px;
    }
    #Flow .box dl{
        padding-bottom: 0!important;
    }
    #Flow .bgc dl{
        padding-bottom: 50px!important;
    }
    #Flow .contact-box .ttl,
    #Flow dt{
        font-size: 120%;
    }
    #Flow .contact-box{
        padding-top: 30px;
        padding-bottom: 30px;
    }
    #Flow .contact-box li{
        width: auto!important;
        float: none!important;
    }
    #Flow .contact-box li:last-child{
        margin: 20px auto 0 auto;
        width: 100%!important;

    }
    #Flow .contact-box li img{
        width: 100%;
        height: auto;
    }
    #Contact{

    }
    #Contact .btn-send{
        width: 80%;
        height: 60px;
    }

    #Contact td p.floatL{
        float: none!important;
    }
    #Contact td p.p-l20{
        padding-left: 0;
        padding-top: 5px;
    }
    #Contact td select{
        width: 145px;
    }

    #Products .boxA,
    #Products .boxB{
        padding-top: 20px;
        padding-bottom: 30px;
    }

    #Products .boxC{
        padding-top: 10px;
        padding-bottom: 0px;
    }    

    #Products .boxA .ttl span,
    #Products .boxB .ttl span,
    #Products .boxC .ttl span{
        padding: 0 10px;
    }

    #Products .ttl,
    #Products ul{
        width: auto;
    }

    #Products h2{
        font-size: 150%;
        padding-top: 40px;
        padding-bottom: 20px;
    }

    #Products h3{
        font-size: 120%;
    }

    #Products .ttl{
        font-size: 130%;
        margin-top: 30px;
        margin-bottom: 15px;
    }
    #Products li{
        width: 100%;
        margin-right: 0;
        float: none;
        margin-bottom: 15px;
    }

    #Products li:last-child{
        margin-bottom: 0;
    }

    #Products .btn-box li{
        width: 100%;
        float: none;
    }
    #Products .btn-box li:last-child{
        margin-top: 10px;
    }	

    #Products .btn-box2 li{
        width: 100%;
        float: none;
    }
    #Products .btn-box2 li:last-child{
        margin-top: 10px;
    }		
	
    .company h2{
        font-size: 150%!important;
        padding-bottom: 30px!important;
        margin-bottom: 0!important;
    }
    .company h2 img{
        height: 35px!important;
        width: auto!important;
        margin-bottom: 10px!important;
    }
    .company #Idea h2{
        width: 400px;
    }
    .company #Idea table{
        width: auto;
    }
    .company #Address iframe{
        margin-bottom: 40px;
    }
    .company #Address .info{
        font-size: 120%;
        padding: 15px 20px;
    }
    .company #Address .info span{
        margin-top: 5px;
    }
    .company #Idea{
        margin-top: 80px;
        padding-bottom: 50px;
    }
    .company #Idea h2{
        width: 290px;
        height: 120px;
        padding-top: 30px;
        font-size: 150%;
        top: -30px;
    }
    .company #Idea h2 img{
        width: 40px;
        height: auto;
        display: block;
    }
    .company #Idea{
        padding-left: 20px;
        padding-right: 20px;
    }
    .company #Idea table{
        width: 100%;
    }
    .company #Idea td{
        display: block;
        width: 100%;
    }
    .company #Idea td:nth-child(2){
        margin-top: 10px;
    }
    .company #Idea .article{
        padding-bottom: 30px;
        line-height: 1.8em;
    }
    .company #Info{
        padding-top: 50px;
        padding-bottom: 50px;
    }
    .company #Info th{
        width: 85px;
        padding: 8px 0;
    }
    .company #Info td{
        width: 130px;
        padding: 8px 0 8px 8px;
    }
    .company #History{
        padding: 50px 0 0 0;
    }
    .company #History li .date{
        padding-left: 30px;
    }
    .company #History li p{
        float: none;
        padding-left: 120px;
    }
    .company #Address{
        padding: 30px 0;
    }



    .company #Manager{
        padding: 30px 0 30px 0;
    }
    .company #Manager p{
        line-height: 1.8em;
    }


    #FootNavi .foot-pic img{
        display: none;
    }
    #FootNavi .foot-pic span,
    #FootNavi .foot-pic span img{
        display: block!important;
    }
    #FootNavi .sub-box{
        padding-left: 0;
        padding-right: 0;
    }
    #FootNavi .sub-box p{
        padding-left: 20px;
        padding-right: 20px;
    }
    #FootNavi ul{
        padding-bottom: 0;
    }
    #FootNavi li{
        width: 50%;
        float: left;
        padding-top: 0;
        border-bottom: #cdcdcd dashed 1px;
    }
    #FootNavi li:nth-child(5),
    #FootNavi li:nth-child(6){
        border-bottom: none;
    }
    #FootNavi li span{
        margin-right: 10px;
    }
    #FootNavi li small{
        display: inline-block;
    }
    #FootNavi li:nth-child(even) a{
        border-left: #cdcdcd dashed 1px;
    }
    #FootNavi li a{
        padding: 15px;
        text-align: left;
    }
    .btn-pagetop{
        display: none;
    }
    footer .sub-box .floatL{
        float: none;
        width: auto;
    }
    footer .sub-box .floatL img{
        width: 84%;
        margin: 0 auto;
    }
    footer .sub-box .floatL p{
        padding-left: 30%;
    }
    footer .sub-box table{
        width: 100%;
        margin-top: 20px;
    }
    footer .sub-box td{
        width: 100%;
        float: left;
    }
    footer .sub-box td:first-child{
        margin-bottom: 5px;
    }

}

@media all and (max-width:440px)
{
	
	.sp {
        display: block;
       }    

	.pc {
 display: none;
}
	
    body{
        font-size: 87.5%;
    }
    #Menu .menu-list ul{
        padding: 20px;
    }
    #Menu .menu-list li {
        font-size: 100%;
        padding-left: 0;
        padding-right: 0;
    }
    #PageTtl{
        height: 220px;
    }
    #PageTtl h2 img {
        height: 80px;
    }

    header #Show .swiper-slide p{
        font-size: 80%;
        width: auto;
        display: inline-block;
    }
    header #Show .swiper-slide span{
        padding: 10px 20px;
    }
    .home_txt h2{
        font-size: 150%;
    }
    #Strength{
        padding-top: 30px;
    }
    #Strength .list .bgc{
        margin-top: 50px;
        padding-bottom: 50px;
    }
    #Strength .list dt img{
        width: 70px;
        height: 70px;
    }
    #Strength .list dt{
        font-size: 130%;
        top: -10px;
    }
    #Strength .list dd{
        margin-top: -25px;
    }
    #Strength .list dd a{
        width: auto;
        height: 45px;
        line-height: 45px;
    }
    #Strength .list dd span{
        display: inline-block!important;
        padding: 0 30px 0 50px;
    }
    #Strength .sub-box{
        padding: 20px 20px 10px 20px;
    }
    #Strength .box dl{
        padding-top: 20px;
    }
    #Strength .box dt{
        font-size: 100%;
    }
    #Strength .box h2{
        font-size: 180%;
    }
    #Strength .box h2 img{
        width: 35px;
        height: auto;
    }

    #Products h2{
        font-size: 120%;
    }

    #Products h3{
        font-size: 100%;
        background-size: 100% auto;
    }
    #Products h3 span{
        background-size: 100% auto;
    }

    #Products .ttl{
        font-size: 110%;
    }
}



/* hack css */
header .head-link,
header nav ul,
.home_logos ul,
.home_logos_link ul,
.home_logos_link_pc ul,
footer .sub-box,
#FootNavi ul,
#Menu .menu-list li,
#FootNavi ul,
#Path ul,
#Recruit .btn-box,
#Flow dl,
#Flow .contact-box ul,
#Products ul,
.company #History li
{display:inline-block;}

header .head-link:after,
header nav ul:after,
.home_logos ul:after,
.home_logos_link ul:after,
.home_logos_link_pc ul:after,
footer .sub-box:after,
#FootNavi ul:after,
#Menu .menu-list li:after,
#FootNavi ul:after,
#Path ul:after,
#Recruit .btn-box:after,
#Flow dl:after,
#Flow .contact-box ul:after,
#Products ul:after,
.company #History li:after
{content: ".";display: block;height: 0;clear: both;visibility: hidden;overflow: hidden;}

/* Hide from IE-mac \*/
*html header .head-link,
*html header nav ul,
*html .home_logos ul,
*html .home_logos_link ul,
*html .home_logos_link_pc ul,
*html footer .sub-box,
*html #FootNavi ul,
*html #Menu .menu-list li,
*html #FootNavi ul,
*html #Path ul,
*html #Recruit .btn-box,
*html #Flow dl,
*html #Flow .contact-box ul,
*html #Products ul,
*html .company #History li
{height: 1%;}

header .head-link,
header nav ul,
.home_logos ul,
.home_logos_link ul,
.home_logos_link_pc ul,
footer .sub-box,
#FootNavi ul,
#Menu .menu-list li,
#FootNavi ul,
#Path ul,
#Recruit .btn-box,
#Flow dl,
#Flow .contact-box ul,
#Products ul,
.company #History li
{display: block;}
/* End hide fromIE-mac*/