<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">@charset "utf-8";

/* -------------------------------------------
メインコンテンツ
-------------------------------------------*/

main {
    position: relative;
    background: #fff;
    padding: 0;
    margin: 0;
    overflow: hidden;
    font-weight: 500;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}


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

    main {
        padding: 0;
    }

}

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

    main {
        padding: 0;
    }

}

/* -------------------------------------------
ヘッダー
-------------------------------------------*/

#header {
    position: relative;
    background: #EFEFEF;
    padding: 0;
    margin: 0;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}


/* -------------------------------------------
ヘッドライン
-------------------------------------------*/

#header ul.headline {
    display: table;
    width: 100%;
    padding: 0;
    margin: 0;
    background-color: #808080;
    list-style: none;
}


#header ul.headline li {
    position: relative;
    display: table-cell;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0px;
    font-size: 14px;
    line-height: 1;
    vertical-align: middle;
}

#header ul.headline li.catch {
    color: #fff;
    letter-spacing: 0.3em;
    padding: 6px 20px;
}

#header ul.headline li.btns {
    color: #fff;
    padding: 0;
    width: 100px;
    text-align: center;
    border-left: #808080 1px solid;
}
#header ul.headline li.btns:nth-child(4) {
	width: 125px;
}

#header ul.headline li.btns a.btn_access,
#header ul.headline li.btns a.btn_company,
#header ul.headline li.btns a.btn_contact,
#header ul.headline li.btns a.btn_lang {
    position: relative;
    display: block;
    font-size: 14px;
    line-height: 1.4;
    margin: 0;
    padding: 6px 0;
    color: #fff;
    text-decoration: none;
    text-align: center;
    z-index: 1;
}

#header ul.headline li.btns a.btn_lang {
    background-color: #666;
}
#header ul.headline li.btns a.btn_lang:hover {
    background-color: #777;
}
#header ul.headline li.btns a.btn_access{
    background-color: #555;
}
#header ul.headline li.btns a.btn_access:hover {
    background-color: #666;
}
#header ul.headline li.btns a.btn_company {
    background-color: #333;
}
#header ul.headline li.btns a.btn_company:hover {
    background-color: #444;
}

#header ul.headline li.btns a.btn_contact {
    background-color: #000;
}
#header ul.headline li.btns a.btn_contact:hover {
    background-color: #222;
}



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

    #header ul.headline li.catch {
        letter-spacing: 0.1em;
        padding: 6px 20px;
        font-size: 12px;
    }

    #header ul.headline li.btns {
        display: none;

    }
    #header ul.headline li.btns.lang {
    	display: block;
    	width: auto;
    }
    #header ul.headline li.btns a.btn_lang {
	    background-color: #444;
	    padding: 4px 5px;
	}
	#header ul.headline li.btns a.btn_lang:hover {
	    background-color: #555;
	}


}




/* -------------------------------------------
ヘッダーロゴ、ショットカット、バーガーメニュー
-------------------------------------------*/


#header ul.headitem {
    display: table;
    width: 100%;
    padding: 0;
    margin: 0;
    background-color: #EFEFEF;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

#header ul.headitem li {
    position: relative;
    display: table-cell;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    vertical-align: middle;
    padding: 0 0 0 30px;
    white-space: nowrap;
}

element.style {
}
#header ul.headitem li {
    position: relative;
    display: table-cell;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    vertical-align: middle;
    padding: 0 0 0 30px;
    margin: 0;
    white-space: nowrap;
}

#header ul.headitem li.logo {
    width: 300px;
    padding: 20px 20px;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

#header ul.headitem li.bmenu {
    width: 80px;
}

#header ul.headitem li.logo a.sitelogo {
    display: block;
    padding: 0;
    margin: 0 auto;
    width: 100%;
}

#header ul.headitem li.logo a.sitelogo img {
    display: block;
    padding: 0;
    margin: 0;
    width: 100%;
    height: auto;
}



#header ul.headitem.fix {
    position: fixed;
    left: 0;
    top: 0px;
    z-index: 10;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

#header ul.headitem.fix li.logo {
    width: 260px;
    padding: 10px 20px;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}





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


    #header ul.headitem li.logo {
        width: 240px;
    }

    #header ul.headitem li.bmenu {
        width: 70px;
    }
}


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

	#header ul.headitem {
		transition: none;
	}
    #header ul.headitem li.logo,
    #header ul.headitem.fix li.logo {
        width: 70%;
        padding: 10px 20px;
    }


    #header ul.headitem li:nth-child(2) {
        display: none;
    }

    #header ul.headitem.fix {
        position: relative;
    }




}

.nav ul.smenu &gt; li:hover {
    background-color: transparent;
    opacity: 0.8;
}


/* -------------------------------------------
共通
-------------------------------------------*/
.center{
	text-align: center;
}
.t_right{
	text-align: right;
	display: block;
}



.bold{
	font-weight:bold;
}

#contact,
#faq,
#company {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
}

#company .contheader,
#faq .contheader,
#contact .contheader {
    position: relative;
    display: block;
    padding: 30px 0;
    margin: 0 0 50px 0;
    text-align: left;
    background: rgb(224, 224, 224);
    background: -moz-linear-gradient(-45deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    background: -webkit-linear-gradient(-45deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    background: linear-gradient(135deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#e0e0e0', endColorstr='#eeeeee', GradientType=1);
}
#misc #company .contheader{
    margin: 0;
}


.contimg {
    position: relative;
    display: block;
    overflow: hidden;
    padding: 0;
    max-height: 260px;
    margin: 0 0 -1px;
}

.contimg img {
    display: block;
    width: 100%;
    height: auto;
    padding: 0;
    margin: 0;

}

.contimg .contentsttl {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 320px;
    display: block;
    line-height: 1;
    padding: 20px 15px 18px 15px;
    margin: -30px 0 0px -160px;
    font-size: 20px;
    font-weight: 400;
    letter-spacing: 0em;
    text-align: center;
    color: #fff;
    background-color: #0f8150;
}

.contheader .ttl {
    color: #000;
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}

.contwrap .btn {
    color: #000;
}

.contwrap .btn::before {
    position: absolute;
    top: 50%;
    right: 10px;
    display: block;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 0;
    content: "";
    background: url(../../img/common/arrow.svg) center center no-repeat;
    background-size: contain;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

.contwrap .btn:hover::before {
    right: 5px;
}

.contwrap .col .col.rimg {
    float: right;
    padding: 1% 0px 1% 0;
}

.contwrap .col .col.w30 {
    width: 26.8%;
}
.contwrap .col .col.w70 {
    width: 73.2%;
}

.contwrap .col &gt; .col.rimg {
    float: right;
    padding: 1% 0px 1% 0;
}

#misc nav.inpagelink ul li a,
#faq nav.inpagelink ul li a {
    border: 5px solid #d3d3d3;
}
#misc nav.inpagelink ul li a:hover,
#faq nav.inpagelink ul li a:hover {
    border: 5px solid #afafaf;
    background-color: rgba(255, 255, 255, 0.4);
}
#misc nav.inpagelink ul li.active a,
#faq nav.inpagelink ul li.active a {
    border: 1px solid #afafaf;
    background-color: rgba(255, 255, 255, 0.4);
}


.movie{
  position:relative;
  width:100%;
  padding-top:56.4%;
  margin: 0 0 20px;
}
.movie iframe{
  position:absolute;
  top:0;
  right:0;
  width:100%;
  height:100%;
}


@media only screen and (max-width: 680px) {
	.contimg .contentsttl {
	    width: 230px;
	    padding: 8px 5px 8px 5px;
	    margin: -16px 0 0px -115px;
	    font-size: 16px;
	}
	#misc .contimg .contentsttl {
	    font-size: 15px;
	}
	
	.contwrap .col .col.w30,
	.contwrap .col .col.w70 {
	    width: 100%;
	}
}

/* -------------------------------------------
採用情報コラム
-------------------------------------------*/
#saiyou {
    display: block;
    position: relative;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    text-align: center;
    padding: 51px 0;
    margin: 0;
    background: rgb(169, 169, 169);
    background: -moz-linear-gradient(top, rgb(169, 169, 169) 0%, rgb(121, 121, 121) 100%);
    background: -webkit-linear-gradient(top, rgb(169, 169, 169) 0%, rgb(121, 121, 121) 100%);
    background: linear-gradient(to bottom, rgb(169, 169, 169) 0%, rgb(121, 121, 121) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#a9a9a9', endColorstr='#797979', GradientType=0);
    font-family: sans-serif;
    min-height: 360px;
}


#saiyou ul {
    display: table;
    list-style: none;
    padding: 0;
    margin: 0 auto;
    table-layout: fixed;
    width: 460px;
}

#saiyou ul li {
    display: table-cell;
    padding: 0 0px;
    margin: 0;
    width: 50%;
    text-align: center;
}

#saiyou ul li a {
    display: block;
    width: 100%;
    height: 20px;
    padding: 0;
    margin: 0;
    font-size: 18px;
    color: #fff;
}

#saiyou ul li a img {
    display: block;
    margin: 0 auto 10px auto;
    width: 100%;
    max-width: 150px;
}

#saiyou ul li a:hover {
    opacity: 0.6;

}

.img_left {
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 34%;
    max-width: 520px;
    margin: 0;
    padding: 0;
    z-index: 0;
}


.img_right {
    display: block;
    position: absolute;
    bottom: 0;
    right: 0;
    width: 24%;
    max-width: 360px;
    margin: 0;
    padding: 0;
}

.img_left img,
.img_right img {
    display: block;
    width: 100%;
    height: auto;
}


@media only screen and (max-width: 1024px) {
    #saiyou {
        padding: 30px 0 100px 0;
    }

    #saiyou ul {
        width: 380px;
    }

    #saiyou ul li a img {
        display: block;
        margin: 0 auto 10px auto;
        width: 60%;
        max-width: 150px;
    }
}

@media only screen and (max-width: 680px) {
    #saiyou {
        padding: 30px 0 160px 0;
    }

    #saiyou ul {
        width: 90%;
    }

    #saiyou ul li a {
        font-size: 14px;
    }

    .img_left {
        width: 60%;
    }

    .img_right {
        width: 42%;
    }
}



/* -------------------------------------------
お問い合せ
-------------------------------------------*/
#inquiry {
    display: block;
    position: relative;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    text-align: center;
    padding: 50px 0;
    margin: 0;
    background-color: #575757;
    font-family: sans-serif;
}

#inquiry .lead {
    color: #fff;
    margin: 0 20px 50px 20px;
    font-size: 14px;
}

#inquiry ul {
    display: table;
    list-style: none;
    padding: 0;
    margin: 0 auto;
    table-layout: fixed;
    color: #fff;
}

#inquiry ul li {
    display: table-cell;
    padding: 0 20px;
    margin: 0;
    text-align: center;
}

#inquiry ul li figure {
    display: block;
    margin: 0 auto 10px auto;
    width: 100%;
    max-width: 140px;
}

#inquiry ul li figure img {
    display: block;
    margin: 0;
    width: 100%;
    height: auto;
}

#inquiry ul li h3 {
    display: block;
    margin: 10px 0 0 0;
    font-size: 18px;
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}

#inquiry ul li .tel {
    display: block;
    font-size: 12px;
}

#inquiry ul li .tel .tel_num,
#inquiry ul li .tel .tel_num_en {
    display: inline-block;
    font-size: 20px;
    color: #fff;
}

#inquiry ul li .tel .tel_num a {
    color: #fff;
}

#inquiry a.btn {
    display: inline-block;
    width: 24em;
    margin: 15px 10px;
}

@media only screen and (max-width: 1024px) {
    #inquiry {
        display: block;
        padding: 30px 20px;
        margin: 0 auto;
    }

    #inquiry a.btn {
        display: inline-block;
        width: 48%;
        margin: 15px 1%;
    }
}

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

    #inquiry {
        display: block;
        padding: 30px 20px;
        margin: 0 auto;
    }

    #inquiry ul {
        display: block;
        padding: 0;
        margin: 0 auto;
        text-align: center;
    }

    #inquiry ul li {
        display: inline-block;
        padding: 10px 0;
        margin: 0;
        width: 48%;
        vertical-align: top;
    }

    #inquiry ul li figure {
        display: block;
        margin: 0 auto 10px auto;
        width: 80%;
    }

    #inquiry ul li .tel .tel_num,
    #inquiry ul li .tel .tel_num_en {
        display: inline-block;
        font-size: 16px;
    }

    #inquiry a.btn {
        display: block;
        width: 100%;
        max-width: auto;
        margin: 15px auto;
    }

}



/*----------------------------------------------------------------------------------------------------------------------------
パンくず
----------------------------------------------------------------------------------------------------------------------------*/

.breadcrumb {
    display: block;
    padding: 12px 0;
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
    font-family: sans-serif;
    background-color: #646464;
}

.breadcrumb ul {
    display: block;
    padding: 0 30px;
    margin: 0 auto;
    list-style: none;
    font-size: 0;
    line-height: 1;
    clear: both;
}

.breadcrumb ul li {
    display: inline-block;
    position: relative;
    padding: 0 26px 0 0;
    text-align: left;
    vertical-align: top;
    font-size: 12px;
}

.breadcrumb ul li:after {
    position: absolute;
    top: 50%;
    right: 0;
    display: block;
    width: 8px;
    height: 8px;
    margin-right: 12px;
    margin-top: -5px;
    border-left: 1px solid rgba(255, 255, 255, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.4);
    content: "";
    -webkit-transform: rotate(225deg);
    transform: rotate(225deg);
}

.breadcrumb ul li:last-child span {
    display: inline;
    height: 14px;
    color: #ccc;
}

.breadcrumb ul li:last-child:after {
    display: none;
}

.breadcrumb ul li a {
    display: inline;
    position: relative;
    padding: 0;
    margin: 0;
    text-decoration: none;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #ccc;
}

.breadcrumb ul li a:hover,
.breadcrumb ul li a:active {
    color: #ccc;
    text-decoration: underline;
}

.breadcrumb ul li:first-child {
    padding: 0;
    margin: 0;
    text-align: left;
    position: relative;
    z-index: 50;
}

.breadcrumb ul li:first-child a {
    padding: 0 0 0 22px;
    position: relative;
    margin: 0 26px 0 0;
    display: inline-block;
    background-image: url(../../img/common/icon_home.svg);
    background-repeat: no-repeat;
    background-position: 0 top;
    background-size: 10px;
}

.breadcrumb ul li:first-child a:hover,
.breadcrumb ul li:first-child a:active {
    text-decoration: underline;
}

@media only screen and (max-width:960px) {
    .breadcrumb ul {
        display: block;
        text-align: left;
    }

    .breadcrumb ul li {
        display: inline;
        position: relative;
        padding: 0 26px 0 0;
        margin-bottom: 20px;
        line-height: 1.6;
    }

    .breadcrumb ul li:first-child a {
        display: inline;
    }
}

@media only screen and (max-width:680px) {
    .breadcrumb {
        display: none;
    }
}

/* -------------------------------------------
フッター
-------------------------------------------*/


footer {
    position: relative;
    padding: 50px 30px 30px 30px;
    margin: 0;
    background: #464646;
    color: #ccc;
    text-align: center;
}

footer nav {
    display: table;
    width: 90%;
    max-width: 450px;
    padding: 0 0 0 50px;
    margin: 0 auto 50px auto;
    table-layout: fixed;
}

footer nav .fcol {
    display: table-cell;
    padding: 0;
    margin: 0;
    text-align: left;
    width: 100%;
}

footer nav .fcol .mds {
    display: inline-block;
    position: relative;
    font-size: 16px;
    color: #fff;
    line-height: 1.5;
    padding: 0;
    margin: 0 0 0.5em 0;
    font-weight: 400;
}


footer nav ul.fmenu {
    display: block;
    padding: 0;
    margin: 0;
    text-align: left;
    list-style: none;

}

footer nav ul.fmenu li {
    position: relative;
    display: block;
    padding: 5px 0;
    margin: 0;
    vertical-align: middle;
    font-size: 12px;
    font-family: sans-serif;
}

footer nav ul.fmenu li a {
    display: inline-block;
    padding: 40px;
    margin: 0;
    padding: 0;
    color: #ccc;
    text-decoration: none;
    border-radius: 4px;
}

footer nav ul.fmenu li a:hover {
    color: #fff;
}


.logo_f{
	color: #fff;
	font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
	font-size: 28px;
    font-weight: 500;
    display: block;
    margin: 0 0 15px;
}
.logo_f span{
	letter-spacing: 0;
    font-size: 22px;
    display: inline-block;
    margin: 0 8px 0 0;
    vertical-align: middle;
}
.logo_f img{
	width: 40px;
	display: inline-block;
    vertical-align: middle;
    margin: 0 8px 0 0;
}

footer address {
    display: block;
    padding: 0;
    margin: 0;
    font-size: 12px;
    font-style: normal;
    font-family: sans-serif;
}

footer address br {
    display: none;
}

footer address a {
    color: #fff;
}

footer .copyright {
    display: block;
    padding: 0;
    margin: 50px 0 100px 0;
    font-size: 10px;
    font-style: normal;
}

@media only screen and (max-width: 680px) {
    footer {
        padding: 30px 20px 128px 20px;
        margin-bottom: 48px;
        background-position: center bottom;
    }

    footer nav {
        display: block;
        width: 90%;
        padding: 0;
        margin: 0 auto 50px auto;
    }

    footer nav .fcol {
        display: block;
        padding: 0;
        margin: 0 0 20px 0;
        text-align: left;
    }

    footer nav .fcol .mds {
        display: block;
        position: relative;
        padding-bottom: 5px;
        border-bottom: 1px solid #999;
    }





    footer nav .fcol .mds::before,
    footer nav .fcol .mds::after {
        position: absolute;
        top: 10px;
        right: 5px;
        display: block;
        width: 12px;
        height: 2px;
        content: "";
        background-color: #fff;
        -webkit-transition: -webkit-transform .3s;
        transition: -webkit-transform .3s;
        transition: transform .3s;
        transition: transform .3s, -webkit-transform .3s;
    }

    footer nav .fcol .mds::before {
        -webkit-transform: rotate(90deg);
        -moz-transform: rotate(90deg);
        -o-transform: rotate(90deg);
        -ms-transform: rotate(90deg)
    }


    footer nav .fcol .mds.active::before,
    footer nav .fcol .mds.active::after {
        position: absolute;
        top: 10px;
        right: 5px;
        display: block;
        width: 12px;
        height: 2px;
        content: "";
        background-color: #fff;
    }

    footer nav .fcol .mds.active::before {
        -webkit-transform: rotate(0deg);
        -moz-transform: rotate(0deg);
        -o-transform: rotate(0deg);
        -ms-transform: rotate(0deg)
    }


    footer nav ul.fmenu {
        display: none;
    }

    footer address {
        font-size: 12px;
        line-height: 1.8;
    }

    footer address span {
        display: block;
        font-size: 18px;
    }

    footer address .tel_num,
    footer address .tel_num_en {
        display: inline-block;
        font-size: 18px;
    }


    footer address br {
        display: block;
    }

    footer .copyright {
        margin: 20px 0;
    }

}


@media only screen and (max-width: 320px) {
	.logo_f{
		font-size: 24px;
	}
}




/*------------------------------------------------------------------
Cookie同意
------------------------------------------------------------------*/

.cookie-consent {
	position: fixed;
	bottom: 0;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
	width: 100%;
	height: 100%;
	font-size: 14px;
    letter-spacing: 0.03em;
    line-height: 1.6;
	color: #fff;
	background: rgba(0,0,0,.8);
	padding: 0;
	box-sizing: border-box;
	visibility: hidden;
	z-index: 9000;
	font-weight: 500;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}

.cookie-consent .cookie-box{
	background: rgba(0,0,0,1);
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 70%;
    height: 70vh;
    padding: 130px;
    display: grid;
}

.cookie-consent .cookie-text{
	font-size: 20px;
}

.cookie-consent.is-show {
	visibility: visible;
}
.cookie-consent a {
	color: #fff !important;
	text-decoration: underline;
}
.cookie-agree {
	color: #fff;
	background: #568A73;
	padding: .5em 10em;
    text-align: center;
    font-size: 20px;
    margin: 0 auto;
    border-radius: 4px;
}
.cookie-agree:hover {
	cursor: pointer;
}
.cc-hide {
	animation: hide 0.5s linear 0s;
	animation-fill-mode: forwards;
}
@keyframes hide {
	from {
	  opacity: 1;
	}
	to {
	  opacity: 0;
	  visibility: hidden;
	}
}
@media screen and (max-width: 680px) {
	.cookie-consent {
	  flex-direction: column;
	  font-size: 13px;
	}
	.cookie-consent .cookie-text {
	  margin-bottom: 1.5em;
	  font-size: 18px;
	}
	.cookie-consent .cookie-box {
	    width: 90%;
	    height: 62vh;
	    padding: 60px 20px;
	    display: block;
	}
	.cookie-agree {
	    padding: .5em 5em;
	    max-width: 100%;
	}
}



/*------------------------------------------------------------------
トップページコンセプト
------------------------------------------------------------------*/

#concept {
    display: block;
    width: 100%;
    position: relative;
    padding: 70px 0;
    margin: 0;
    background: url(../../img/toppage/bg_topics.jpg) center top no-repeat rgb(90, 90, 90);
    background-size: cover;
}

#concept .strength {
    display: block;
    position: relative;
    width: 90%;
    max-width: 1200px;
    position: relative;
    padding: 20px 50px 20px 380px;
    margin: 0 auto 50px auto;
    color: #fff;
    text-align: left;
}

#concept .strength::before {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 50px;
    height: 50px;
    margin: 0;
    content: "";
    border-top: 5px solid #fff;
    border-left: 5px solid #fff;
}

#concept .strength::after {
    position: absolute;
    bottom: 0;
    right: 0;
    display: block;
    width: 50px;
    height: 50px;
    margin: 0;
    content: "";
    border-bottom: 5px solid #fff;
    border-right: 5px solid #fff;
}

#concept .strength figure {
    display: block;
    width: 340px;
    position: absolute;
    bottom: -50px;
    left: 20px;
    padding: 0;
    margin: 0;
}

#concept .strength figure img {
    display: block;
    width: 100%;
    height: auto;
    padding: 0;
    margin: 0;
}

#concept .strength h2 {
    display: block;
    width: 100%;
    height: auto;
    padding: 0;
    margin: 0 0 20px 0;
    font-size: 28px;
    line-height: 1.5;
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}

#concept .strength .lead {
    display: block;
    width: 100%;
    height: auto;
    padding: 0;
    margin: 0 0 20px 0;
    font-size: 18px;
    line-height: 1.8;
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}

@media only screen and (max-width: 1024px) {
    #concept {
        padding: 40px 0;
    }

    #concept .strength {
        padding: 30px 50px 10px 230px;
        margin: 0 auto 30px auto;
    }

    #concept .strength::before {
        width: 30px;
        height: 30px;
        border-top: 3px solid #fff;
        border-left: 3px solid #fff;
    }

    #concept .strength::after {
        width: 30px;
        height: 30px;
        border-bottom: 3px solid #fff;
        border-right: 3px solid #fff;
    }


    #concept .strength figure {
        display: block;
        width: 180px;
        position: absolute;
        bottom: inherit;
        top: 30px;
        left: 20px;
        padding: 0;
        margin: 0;
        border-bottom: 2px solid #999;
    }

    #concept .strength h2 {
        display: block;
        width: 100%;
        height: auto;
        padding: 0;
        margin: 0 0 20px 0;
        font-size: 20px;
        line-height: 1.5;
        font-weight: 400;
        font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    }

    #concept .strength .lead {
        display: block;
        width: 100%;
        height: auto;
        padding: 0;
        margin: 0 0 20px 0;
        font-size: 14px;
        line-height: 1.8;
        font-weight: 400;
        font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    }
}

@media only screen and (max-width: 680px) {
    #concept {
        padding: 30px 0 10px 0;
    }

    #concept .strength {
        padding: 20px 20px 110px 20px;
        margin: 0 auto 30px auto;
    }

    #concept .strength::before {
        width: 30px;
        height: 30px;
        border-top: 3px solid #fff;
        border-left: 3px solid #fff;
    }

    #concept .strength::after {
        width: 30px;
        height: 30px;
        border-bottom: 3px solid #fff;
        border-right: 3px solid #fff;
    }


    #concept .strength figure {
        display: block;
        width: 160px;
        position: absolute;
        bottom: -30px;
        top: auto;
        left: 50%;
        padding: 0;
        margin: 0 0 0 -80px;
        border-bottom: none;
    }

    #concept .strength h2 {
        font-size: 18px;
        margin-bottom: 10px;
    }

    #concept .strength h2 br {
        display: none;
    }

    #concept .strength .lead {
        font-size: 14px;
    }
}

/*------------------------------------------------------------------
トピックス
------------------------------------------------------------------*/
.topics {
    display: block;
    padding: 35px 0 0;
    margin: 0 auto;
    text-align: center;
    width: 90%;
    max-width: 1200px;
    border-top: 0px solid #666;
    border-bottom: 0px solid #666;
background: -moz-linear-gradient(left,  rgba(68,68,68,0) 0%, rgba(102,102,102,1) 50%, rgba(68,68,68,0) 100%);
background: -webkit-linear-gradient(left,  rgba(68,68,68,0) 0%,rgba(102,102,102,1) 50%,rgba(68,68,68,0) 100%);
background: linear-gradient(to right,  rgba(68,68,68,0) 0%,rgba(102,102,102,1) 50%,rgba(68,68,68,0) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00444444', endColorstr='#00444444',GradientType=1 );




}

.topics .topics_area{
	background-color: #EFEFEF;
	color: #000;
	width: 100%;
	padding: 15px 0px;
	margin: 30px 0 20px;
	height: 260px;
    overflow-y: scroll;
}


.topics .newsttl {
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    font-size: 24px;
    vertical-align: top;
    padding: 0;
    margin: 0;
    color: #fff;
}

.topics .newsttl span {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0 0 0.1em 0;
    font-family: 'Lato', sans-serif;
    font-size: 48px;
    letter-spacing: 1.85px;
    line-height: 1;
}


.topics ul {
    display: block;
    padding: 0 30px;
    margin: 0 -30px 0 0;
    text-align: left;
    list-style: none;
    font-size: 0;
    width: 100%;
    box-sizing: border-box;
}

.topics ul li {
    display: inline-block;
    padding: 5px 0 0;
    margin: 0 0 10px;
    width: 100%;
    box-sizing: border-box;
    vertical-align: top;
    border-bottom: 1px dotted #999;
}

.topics ul li a {
    display: table;
    color: #000;
    text-decoration: none;
}

.topics ul li a:hover {
    opacity: 0.6;
}

.topics ul li a figure {
    display: table-cell;
    width: 150px;
    vertical-align: top;
    box-sizing: border-box;
    padding: 0 30px 0 0;
    margin: 0;
}

.topics ul li a figure img {
    display: block;
    width: 100%;
    height: auto;
}
.topics ul li a p.date{
	margin: 0 20px 0 0;
	display: inline-block;
}

.topics ul li a p {
    display: inline-block;
    font-size: 16px;
    letter-spacing: 0;
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}

.topics ul li a p.cate {
    display: inline-block;
    width: 9em;
    font-size: 14px;
    padding: 1px 10px;
    letter-spacing: 0;
    text-align: center;
    background-color: #848484;
    margin: 0 10px 5px 0;
    font-weight: 500;
    color: #fff;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}
.topics ul li a p.cate.announcements {
	background-color: #848484;
}
.topics ul li a p.cate.product {
	background-color: #2b86b7;
}
.topics ul li a p.cate.exhibition {
	background-color: #3cb595;
}
.topics ul li a p.cate.urgent {
	background-color: #c15757;
}

.topics_btn{
	text-align: center;
	margin: 0 18px;
}


@media only screen and (max-width: 1024px) {
    .topics {
        padding: 15px 0 5px 0;
    }
    .topics .topics_area {
    	padding: 10px;
    }

    .topics ul {
        padding: 0 20px;
        margin: 0;
    }

    .topics ul li {
        padding: 10px 30px 10px 0;
        vertical-align: top;
    }

    .topics ul li a figure {
        width: 50%;
        padding: 0 20px 0 0;
    }

    .topics ul li a p {
        display: block;
        font-size: 14px;
        line-height: 1.5;
        margin: 0 0 5px;
    }

    .topics ul li a p br {
        display: none;
    }

    .topics ul li a p.cate {
        font-size: 12px;
    }

}

@media only screen and (max-width: 800px) {
    .topics .newsttl {
        font-size: 20px;
    }

    .topics .newsttl span {
        font-size: 36px;
    }

}

@media only screen and (max-width: 680px) {
    .topics {
        padding: 30px 0 0px 0;
        margin: 0 auto 20px;
    }
    .topics ul {
        padding: 0;
    }

    .topics ul li {
        padding: 10px 0px 10px 0;
        vertical-align: top;
        width: 100%;
        display: block;
    }

    .topics ul li a figure {
        width: 120px;
        padding: 0 15px 0 0;
        margin: 0;
    }
}

/*------------------------------------------------------------------
特徴
------------------------------------------------------------------*/

.feature {
    display: block;
    width: 100%;
    position: relative;
    padding: 0 0 0px 0;
    margin: 0;
    background: #3E3E3E;
}

.feature ul {
    display: block;
    padding: 0;
    margin: 0 -2px 0 0;
    list-style: none;
    font-size: 0;
    overflow: hidden;
}

.feature ul li {
    display: inline-block;
    box-sizing: border-box;
    width: 50%;
    height: auto;
    padding: 0 2px 0 0;
    margin: 0;
    vertical-align: top;
    font-size: 16px;
}

.feature ul li .replace {
    display: block;
    position: relative;
    padding: 50px;
    margin: 0;
    background-color: #545454;
    color: #fff;
    text-decoration: none;
}

.feature ul li .replace + .replace {
    margin: 2px 0 0 0;
}

.feature ul li a:hover {
    background-color: #555;
}

.feature ul li .replace .wrap {
    display: block;
    padding: 0;
    margin: 0 0 0 auto;
    width: 100%;
    max-width: 550px;
}

.feature ul li:nth-child(even) .replace .wrap {
    display: block;
    padding: 0;
    margin: 0 auto 0 0;
    width: 100%;
    max-width: 550px;
}

.feature ul li .replace .wrap figure.img_full {
    display: block;
    width: 100%;
    padding: 0;
    margin: 30px 0;
}

.feature ul li .replace .wrap figure.img_full.middle {
    width: 75%;
    margin: 30px auto;
}

.feature ul li .replace .wrap figure.img_full img {
    display: block;
    width: 100%;
    height: auto;
}

.feature ul li .replace .wrap figure.img_half {
    display: block;
    width: 36%;
    padding: 0;
    margin: 4px 0 20px 20px;
    float: right;
}

.feature ul li .replace .wrap figure.img_half img {
    display: block;
    width: 100%;
    height: auto;
}



.feature ul li .replace .wrap h3 {
    display: block;
    position: relative;
    height: auto;
    padding: 0;
    margin: 0 0 20px 0;
    font-size: 28px;
    line-height: 1.5;
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}

.feature ul li a .wrap h3::after {
    position: absolute;
    top: 10px;
    right: 0px;
    display: block;
    width: 30px;
    height: 30px;
    margin: 0;
    content: "";
    background: url(../../img/common/arrow_w.svg) center center no-repeat;
    background-size: contain;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

.feature ul li a:hover .wrap h3::after {
    right: -5px;
}

.feature ul li .replace .wrap p {
    letter-spacing: 0;
    font-size: 16px;
}

@media only screen and (max-width: 1024px) {
    .feature ul li .replace .wrap h3 {
        font-size: 20px;
    }

    .feature ul li .replace .wrap p {
        font-size: 14px;
    }
}

@media only screen and (max-width: 680px) {
    .feature ul {
        display: block;
        padding: 0;
        margin: 0;
    }

    .feature ul li {
        display: block;
        box-sizing: border-box;
        width: 100%;
        padding: 1px 0;
    }

    .feature ul li .replace {
        display: block;
        position: relative;
        padding: 20px 20px 10px 20px;
        margin: 0;
        background-color: #545454;
        color: #fff;
        text-decoration: none;
    }

    .feature ul li .replace + a {
        margin: 2px 0 0 0;
    }

    .feature ul li .replace .wrap h3::after {
        top: 0px;
    }

}




/*------------------------------------------------------------------
トップページプロダクト一覧
------------------------------------------------------------------*/



#toppage .product_list {
    display: block;
    position: relative;
    padding: 50px 0;
    margin: 0;
    text-align: center;
    background: #2E2E2E;
}

#toppage .product_list:nth-child(even) {
    background: #3E3E3E;
}


#toppage ul.productlist {
    margin: 30px -10px 0px 0;
}

#toppage ul.productlist li {
    width: 25%;
}

#toppage .other_pro_txt{
	color: #fff;
	margin: 45px 0 0;
}
#toppage .other_pro_txt h2 {
    font-weight: 500;
    font-size: 26px;
}
#toppage .other_pro_txt .lead {
    line-height: 2;
    margin: 0 0 1em;
}

@media only screen and (max-width: 1024px) {
    #toppage ul.productlist li {
        width: 50%;
    }
}

@media only screen and (max-width: 680px) {
	#toppage .product_list {
    	padding: 50px 0 30px 0;
    }
    #toppage ul.productlist li {
        width: 100%;
        padding: 0 10px 20px 0;
    }
    #toppage .other_pro_txt h2 {
	    font-size: 20px;
	}
	#toppage .other_pro_txt .lead {
	    font-size: 14px;
	}
}

@media only screen and (max-width: 320px) {
	#toppage .colttl.sss a{
		font-size: 18px;
    	padding: 0px 25px 0 0;
	}
	#toppage .colttl.sss a::after {
	    width: 22px;
	    height: 22px;
	}
}

/* -------------------------------------------
ページタイトル
-------------------------------------------*/

.contheader {
    display: block;
    padding: 20px 0;
    margin: 0;
    text-align: left;
    background-color: #D8D8D8;
}

/* -------------------------------------------
汎用コンテンツ（明るいグレー背景）
-------------------------------------------*/
#misc {
    display: block;
    width: 100%;
    padding: 0 0 50px 0;
    margin: 0;
    color: #000;
    background-color: #eee;
}

#misc .contheader {
    position: relative;
    display: block;
    padding: 20px 0;
    margin: 0 0 50px 0;
    text-align: left;
    background: rgb(224, 224, 224);
    background: -moz-linear-gradient(-45deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    background: -webkit-linear-gradient(-45deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    background: linear-gradient(135deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#e0e0e0', endColorstr='#eeeeee', GradientType=1);
}

#misc .contheader .ttl {
    color: #000;
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}

#misc .colttl {
    color: #000;
    text-align: center;
}

#misc .btn {
    color: #000;
}

#misc .btn::before {
    position: absolute;
    top: 50%;
    right: 10px;
    display: block;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 0;
    content: "";
    background: url(../../img/common/arrow.svg) center center no-repeat;
    background-size: contain;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

#misc .btn:hover::before {
    right: 5px;
}


@media only screen and (max-width: 680px) {
    #misc .contheader {
        margin: 0 0 20px 0;
    }

    #misc .contheader .ttl {
        font-size: 28px;
    }

    #misc .contentsttl {
        font-size: 22px;

    }
}


/* -------------------------------------------
採用情報
-------------------------------------------*/


#careers {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
}

#careers .contheader {
    position: relative;
    display: block;
    padding: 30px 0;
    margin: 0;
    text-align: left;
    background: rgb(224, 224, 224);
    background: -moz-linear-gradient(-45deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    background: -webkit-linear-gradient(-45deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    background: linear-gradient(135deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#e0e0e0', endColorstr='#eeeeee', GradientType=1);
}

#careers .contheader .wrap {
    display: table;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0;
    margin: 0 auto;
    width: 90%;
    max-width: 1200px;
}

#careers .contimg {
    margin: 0 0 50px 0;
}


#careers .contimg .contentsttl.mess {
    width: 280px;
    margin: -30px 0 0px -140px;
}



#careers .img_right {
    display: block;
    position: absolute;
    bottom: 0px;
    right: 2%;
    width: 160px;
    margin: 0;
    padding: 0;
}

#careers .img_right img {
    display: block;
    width: 100%;
    height: auto;
}

#careers .contheader a.ttllink {
    display: inline-block;
    padding: 0;
    margin: 0;
    color: #474747;
}

#careers .contheader a.ttllink:hover {
    color: #bfbfbf;
}

#careers .contheader .categoryttl {
    display: table-cell;
    padding: 0;
    margin: 0;
    vertical-align: top;
}


#careers .contheader nav {
    display: table-cell;
    padding: 0 200px 0 0;
    margin: 0 0 0 0;
    width: 40%;
    vertical-align: middle;
}

#careers .contheader nav ul {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
    list-style: none;
    font-size: 0;
}

#careers .contheader ul li {
    display: inline-block;
    width: 100%;
    padding: 0;
    margin: 0;
    list-style: none;
    font-size: 14px;
}



#careers .contheader ul li a {
    position: relative;
    display: block;
    box-sizing: border-box;
    font-size: 14px;
    font-weight: normal;
    line-height: 1.5;
    margin: 0 0 6px 6px;
    padding: 5px 10px 5px 25px;
    border: 2px solid #d9d9d9;
    background-color: rgba(255, 255, 255, 0.2);
    color: #000;
    text-decoration: none;
    text-align: left;
    z-index: 1;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}


#careers .contheader ul li a::before {
    position: absolute;
    top: 50%;
    left: 10px;
    display: block;
    width: 10px;
    height: 10px;
    margin: -5px 0 0 0;
    content: "";
    background: url(../../img/common/arrow.svg) center center no-repeat;
    background-size: contain;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

#careers .contheader ul li a:hover {
    border: 2px solid #cccccc;
    background-color: rgba(255, 255, 255, 0.4);
}

#careers .contheader ul li.active a {
    border: 2px solid rgba(0, 130, 78, 0.37);
    background-color: rgba(255, 255, 255, 0.4);
}

#careers .contheader ul li a:hover::before {
    right: 5px;
}


#careers .mdscategory {
    display: inline-block;
    line-height: 1.5;
    padding: 0;
    margin: 0 0 30px 0;
    font-size: 28px;
    font-weight: 600;
    color: #000;
}

#careers .mdscategory::after {
    display: inline-block;
    border-top: 3px solid #0f8150;
    margin: -5px 0 0 15px;
    padding: 0;
    vertical-align: middle;
    width: 30px;
    height: 0;
    content: "";
}

#careers .cont_bottom {
    display: block;
    position: relative;
    padding: 0px 0 50px 0;
    margin: 0;
}


#careers .btn {
    display: block;
    margin: 0 auto;
    color: #000;
}

#careers .btn::before {
    position: absolute;
    top: 50%;
    right: 10px;
    display: block;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 0;
    content: "";
    background: url(../../img/common/arrow.svg) center center no-repeat;
    background-size: contain;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

#careers .btn:hover::before {
    right: 5px;
}




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


    #careers .contheader {
        padding: 30px 0;
    }

    #careers .contheader nav {
        width: 60%;
    }

}

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


    #careers .contheader nav {
        width: auto;
    }


}

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

    #careers .contheader {
        padding: 10px 0;
        width: 100%;
        overflow: hidden;
    }

    #careers .contheader .categoryttl {
        display: block;
        width: 100%;
        padding: 0;
        margin: 0;
    }

    #careers .contheader nav {
        display: block;
        width: 100%;
        padding: 0;
    }

    #careers .contheader nav ul {
        display: block;
        padding: 0;
        margin: 0 -2px 0 0;
        list-style: none;
        font-size: 0;
        box-sizing: border-box;
    }

    #careers .contheader ul li {
        display: inline-block;
        box-sizing: border-box;
        width: 50%;
        padding: 0 2px 2px 0;
        margin: 0;
    }

    #careers .contheader ul li a {
        font-size: 12px;
        margin: 0;
        background-color: rgba(255, 255, 255, 1);
    }

    #careers .contheader ul li a:hover {
        border: 2px solid #cccccc;
        background-color: rgba(255, 255, 255, 1);
    }

    #careers .contheader ul li.active a {
        border: 2px solid rgba(0, 130, 78, 1);
        background-color: rgba(255, 255, 255, 1);
    }

    #careers .img_right {
        display: block;
        position: absolute;
        bottom: inherit;
        top: 10px;
        right: 8%;
        width: 32%;
        overflow: hidden;
        margin: 0;
        padding: 0;
    }

    #careers .contimg {
        margin: 0 0 30px 0;
    }

    #careers .contimg .contentsttl {
        width: 110px;
        padding: 12px 0 8px 0;
        margin: -22px 0 0px -55px;
        font-size: 16px;
    }

    #careers .mdscategory {
        margin: 0 0 20px 0;
        font-size: 20px;
    }

    #careers .mdscategory::after {
        border-top: 2px solid #0f8150;
        margin: -5px 0 0 10px;
        width: 24px;
    }

    #careers .cont_bottom {
        padding: 0px 0 20px 0;
    }

}



/* -------------------------------------------
先輩からのメッセージ　タブ
-------------------------------------------*/



#careers .mess_menu {
    display: block;
    margin: 0;
    padding: 30px 0 30px 0;
}

#careers .person_list ul {
    display: block;
    margin: 0 -20px 20px 0;
    padding: 0;
    list-style: none;
    font-size: 0;
}

#careers .person_list ul li {
    display: inline-block;
    margin: 0;
    padding: 0 20px 0 0;
    width: 16.66%;
    text-align: center;
}

#careers .person_list ul li:nth-child(n + 7) {
	margin: 20px 0 0;
}

#careers .person_list ul li a {
    display: table;
    position: relative;
    width: 100%;
    margin: 0;
    padding: 0px;
    font-size: 16px;
    border-bottom: 5px solid #d6e8e8;
}

#careers .person_list ul li.active a,
#careers .person_list ul li a:hover {
    border-bottom: 5px solid #0f8150;
}

#careers .person_list ul li.active a::after {
    display: block;
    position: absolute;
    bottom: -15px;
    left: 50%;
    border-top: 10px solid #0f8150;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    margin: 0 0 0 -10px;
    padding: 0;
    width: 0;
    height: 0;
    content: "";
}

#careers .person_list ul li a p {
    display: table-cell;
    margin: 0;
    padding: 0;
    vertical-align: middle;
    font-size: 16px;
}

#careers .person_list ul li a p span {
    display: inline-block;
    font-size: 14px;
    margin: 0 10px 0 0;
}

@media only screen and (max-width: 960px) {
    #careers .person_list ul li {
        display: inline-block;
        margin: 0;
        padding: 0 10px 15px 0;
        width: 33.33%;
    }
    #careers .person_list ul li:nth-child(n + 7) {
		margin: 0;
	}
}

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

    #careers .mess_menu {
        display: block;
        margin: 0;
        padding: 20px 0 10px 0;
    }

    #careers .person_list ul {
        display: block;
        margin: 0 -10px 0px 0;
        padding: 0;
        list-style: none;
        font-size: 0;
    }

    #careers .person_list ul li {
        display: inline-block;
        margin: 0;
        padding: 0 10px 15px 0;
        width: 50%;
    }

    #careers .person_list ul li.active a::after {
        display: block;
        position: absolute;
        bottom: -10px;
        left: 50%;
        border-top: 6px solid #0f8150;
        border-left: 6px solid transparent;
        border-right: 6px solid transparent;
        margin: 0;
        padding: 0;
        width: 0;
        height: 0;
        content: "";
    }

    #careers .person_list ul li a figure {
        display: table-cell;
        width: 30%;
        margin: 0;
        padding: 0 0 0 10px;
        vertical-align: middle;
    }

    #careers .person_list ul li a p {
        padding: 0 0 0 10px;
    }

    #careers .person_list ul li a p span {
        margin: 0 5px 0 0;
        padding: 0;
        line-height: 1;
    }

}


/* -------------------------------------------
先輩からのメッセージ
-------------------------------------------*/


#careers .mess_ttl {
    display: block;
    position: relative;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    padding: 120px 0;
    margin: 0 0 40px 0;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
}

#careers .mess_ttl.right {
	text-align: right;
}

#careers .mess_ttl .parson_ttl {
    display: inline-block;
    box-sizing: border-box;
    width: 50%;
    margin: 0;
    padding: 30px;
    background-color: rgba(255, 255, 255, 0.8);
    text-align: left;

}

#careers .mess_ttl .wrap {
    display: table;
    width: 100%;
    margin: 0 auto;
    padding: 0;
}



#careers .mess_ttl .person_photo {
    display: table-cell;
    width: 30%;
    margin: 0;
    padding: 0;
}

#careers .mess_ttl .person_photo figure {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
}

#careers .mess_ttl .person_photo figure img {
    display: block;
    width: 100%;
    height: auto;
}

#careers .mess_ttl .parson_detail {
    display: table-cell;
    margin: 0;
    padding: 0 0 0 30px;
    vertical-align: middle;
}




#careers .mess_ttl .contentsttl {
    display: inline-block;
    position: relative;
    line-height: 1;
    padding: 10px 15px 8px 15px;
    margin: 0 0 0px 0;
    font-size: 16px;
    font-weight: 400;
    color: #fff;
    background-color: #0f8150;
}

#careers .mess_ttl .main_message {
    display: block;
    position: relative;
    line-height: 1.5;
    padding: 10px 0 0 0;
    margin: 0 0 20px 0;
    font-size: 32px;
    font-weight: 600;
    color: #000;
}

#careers .mess_ttl .person_name {
    display: block;
    position: relative;
    line-height: 1.5;
    padding: 0;
    margin: 0;
    font-size: 18px;
    font-weight: 400;
    color: #000;
}

#careers .mess_ttl .person_name span {
    display: inline-block;
    position: relative;
    line-height: 1.5;
    padding: 0;
    margin: 0 5px;
    font-size: 28px;
    font-weight: 600;
    color: #000;
}





#careers .mess_wrap {
    display: block;
    position: relative;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    padding: 40px 0 40px 0;
    margin: 0;
}

#careers .mess_wrap::after {
    content: ".";
    display: block;
    height: 0;
    font-size: 0;
    clear: both;
    visibility: hidden;
}


#careers .mess_wrap .mds_ques {
    display: inline-block;
    line-height: 1.5;
    padding: 0;
    margin: 0 0 10px 0;
    font-size: 24px;
    font-weight: 800;
    color: #000;
}

#careers .mess_wrap .mds_ques span {
    display: inline-block;
    line-height: 1.5;
    padding: 0;
    margin: 0 15px 10px 0;
    font-size: 48px;
    font-weight: 800;
    color: #ccc;
}


#careers .mess_wrap .mds_ques::after {
    display: inline-block;
    border-top: 2px solid #0f8150;
    margin: -3px 0 0 20px;
    padding: 0;
    vertical-align: middle;
    width: 30px;
    height: 0;
    content: "";
}

#careers .mds_ans {
    display: block;
    position: relative;
    line-height: 1.5;
    padding: 0;
    margin: 0 0 50px 0;
    font-size: 18px;
    font-weight: 500;
    color: #000;
}



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

    #careers .mess_ttl .main_message {
        font-size: 28px;
    }

    #careers .mess_ttl .main_message br {
        display: none;
    }
}





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


    #careers .mess_ttl {

        padding: 0;
        margin: 0 0 40px 0;
    }

    #careers .mess_ttl .parson_ttl {
        width: 60%;
        padding: 14px;
    }

    #careers .mess_ttl .contentsttl {
        line-height: 1;
        padding: 6px 10px 6px 10px;
        margin: 0;
        font-size: 12px;
    }

    #careers .mess_ttl .person_photo {
        display: table-cell;
        width: 40%;
        margin: 0;
        padding: 0;
        vertical-align: bottom;
    }


    #careers .mess_ttl .main_message {
        padding: 10px 0 10px 0;
        margin: 0;
        font-size: 14px;
    }

    #careers .mess_ttl .main_message br {
        display: none;
    }

    #careers .mess_ttl .person_name {
        font-size: 12px;
    }

    #careers .mess_ttl .person_name span {
        font-size: 14px;
    }


    #careers .mess_wrap {
        padding: 20px 0 20px 0;
    }


    #careers .mess_wrap .mds_ques {
        margin: 0 0 0px 0;
        font-size: 20px;
        font-weight: 600;
    }

    #careers .mess_wrap .mds_ques span {
        display: block;
        margin: 0;
        font-size: 28px;
    }

    #careers .mess_wrap .mds_ques::after {
        border-top: 2px solid #0f8150;
        margin: -3px 0 0 10px;
        width: 25px;
    }

    #careers .mds_ans {
        margin: 0 0 10px 0;
        font-size: 14px;
    }

}


/*------------------------------------------------------------------
製品情報タイトル
------------------------------------------------------------------*/

#product {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
}

#product .categoryheader {
    display: block;
    padding: 50px 0;
    margin: 0;
    text-align: left;
    background: rgb(224, 224, 224);
    background: -moz-linear-gradient(-45deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    background: -webkit-linear-gradient(-45deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    background: linear-gradient(135deg, rgb(224, 224, 224) 0%, rgb(238, 238, 238) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#e0e0e0', endColorstr='#eeeeee', GradientType=1);
}

#product .categoryheader .wrap {
    display: table;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0;
    margin: 0 auto;
    width: 90%;
    max-width: 1200px;
}

#product .categoryheader a.ttllink {
    display: inline-block;
    padding: 0;
    margin: 0;
    color: #474747;
}

#product .categoryheader a.ttllink:hover {
    color: #bfbfbf;
}

#product .categoryheader .categoryttl {
    display: table-cell;
    padding: 0;
    margin: 0;
    vertical-align: middle;
}

#product .categoryheader .categoryttl h1 {
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    font-size: 24px;
    vertical-align: top;
    padding: 0;
    margin: 0;
}

#product .categoryheader .categoryttl h1 span {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0 0 0.1em 0;
    font-family: 'Lato', sans-serif;
    font-size: 48px;
    letter-spacing: 1.85px;
    line-height: 1;
}
#product .categoryheader .categoryttl h1.logo_sss span img{
    height: 68px;
}

#product .categoryheader nav {
    display: table-cell;
    padding: 0;
    margin: 0;
    width: 40%;
    vertical-align: top;
}

#product .categoryheader nav ul {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
    list-style: none;
    font-size: 0;
}

#product .categoryheader ul li {
    display: inline-block;
    width: 50%;
    padding: 0;
    margin: 0;
    list-style: none;
    font-size: 14px;
}



#product .categoryheader ul li a {
    position: relative;
    display: block;
    box-sizing: border-box;
    font-size: 14px;
    line-height: 1.5;
    margin: 0 0 6px 6px;
    padding: 5px 10px 5px 25px;
    border: 2px solid #d9d9d9;
    background-color: rgba(255, 255, 255, 0.2);
    color: #000;
    text-decoration: none;
    text-align: left;
    z-index: 1;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}


#product .categoryheader ul li a::before {
    position: absolute;
    top: 50%;
    left: 10px;
    display: block;
    width: 10px;
    height: 10px;
    margin: -5px 0 0 0;
    content: "";
    background: url(../../img/common/arrow.svg) center center no-repeat;
    background-size: contain;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

#product .categoryheader ul li a:hover {
    border: 2px solid #ccc;
    background-color: rgba(255, 255, 255, 0.4);
}

#product .categoryheader ul li.active a {
    border: 2px solid rgba(0, 130, 78, 0.37);
    background-color: rgba(255, 255, 255, 0.4);
}

#product .categoryheader ul li a:hover::before {
    right: 5px;
}

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


    #product .categoryheader {
        padding: 30px 0;
    }

    #product .categoryheader .categoryttl h1 {
        font-size: 24px;
    }

    #product .categoryheader .categoryttl h1 span {
        font-size: 36px;
    }

}

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

	#product .categoryheader .categoryttl h1.logo_sss span img{
	    height: 48px;
	}

    #product .categoryheader nav {
        display: table-cell;
        padding: 0;
        margin: 0;
        width: 50%;
        vertical-align: top;
    }

    #product .categoryheader .categoryttl h1 {
        font-size: 20px;
    }

    #product .categoryheader .categoryttl h1 span {
        font-size: 36px;
    }

}

@media only screen and (max-width: 680px) {
	#product .categoryheader .categoryttl h1.logo_sss span img{
	    height: auto;
	    width: 100%;
	}

    #product .categoryheader .categoryttl {
        display: block;
        padding: 0;
        margin: 0 0 0px 0;
    }

    #product .categoryheader nav {
        display: block;
        padding: 0;
        margin: 0;
        width: 100%;
        vertical-align: top;
    }

    #product .categoryheader nav ul {
        display: block;
        width: auto;
        padding: 0;
        margin: 15px -2px 0 0;
        list-style: none;
        font-size: 0;
    }

    #product .categoryheader ul li {
        display: inline-block;
        box-sizing: border-box;
        width: 50%;
        padding: 0 2px 2px 0;
        margin: 0;
    }

    #product .categoryheader ul li a {
        font-size: 12px;
        margin: 0;
    }


}

/*------------------------------------------------------------------
製品カテゴリー
------------------------------------------------------------------*/

#product .category {
    display: table;
    width: 100%;
    position: relative;
    padding: 0;
    margin: 0;
    text-align: left;
    background: rgb(155, 155, 155);
    background: -moz-linear-gradient(top, rgb(155, 155, 155) 0%, rgb(98, 98, 98) 100%);
    background: -webkit-linear-gradient(top, rgb(155, 155, 155) 0%, rgb(98, 98, 98) 100%);
    background: linear-gradient(to bottom, rgb(155, 155, 155) 0%, rgb(98, 98, 98) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#9b9b9b', endColorstr='#626262', GradientType=0);
}


#product .category .categorylead {
    display: table-cell;
    width: 50%;
    vertical-align: middle;
    box-sizing: border-box;
    padding: 0;
    color: #fff;
}

#product .category .categorylead .wrap {
    display: block;
    box-sizing: border-box;
    width: 90%;
    max-width: 600px;
    vertical-align: top;
    padding: 0 50px 0 0;
    margin: 50px 0 50px auto;
    color: #fff;
}

#product .category .categorylead h2 {
    font-weight: 500;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    font-size: 32px;
    line-height: 1;
    padding: 0;
    margin: 0 0 30px 0;
}

#product .category .categorylead h2.logo_sss img {
    width: 68%;
    vertical-align: middle;
    margin: -6px 0 0 2px;
}

#product .category .categorylead .lead {
    line-height: 2;
    letter-spacing: 0;
}

#product .category .categoryimg {
    position: relative;
    display: table-cell;
    width: 50%;
    height: 500px;
    vertical-align: top;
    box-sizing: border-box;
    padding: 0;
    overflow: hidden;
}

#product .category .categoryimg img {
    position: absolute;
    width: auto;
    height: auto;
    max-width: 100%;
    left: 50%;
    top: 50%;
    -webkit-transform: translate3d(-50%, -50%, 0);
    transform: translate3d(-50%, -50%, 0);
}


#product .category .categoryimg img{
	left: 0\9;
    top: 0\9;
    -webkit-transform: none\9;
    transform: none\9;
}
@media all and (-ms-high-contrast: none){
  #product .category .categoryimg img{
    left: 0;
    top: 0;
    -webkit-transform: none;
    transform: none;
  }
}


#product .product_list {
    display: block;
    width: 100%;
    position: relative;
    padding: 60px 0 60px 0;
    margin: 0;
    text-align: center;
    background: #2E2E2E;
}

@media only screen and (max-width: 1024px) {
    #product .category .categorylead h2 {
        font-size: 24px;
        line-height: 1.2;
        margin: 0 0 20px 0;
    }

    #product .category .categorylead .lead {
        font-size: 16px;
        line-height: 1.8;
    }

    #product .category .categoryimg {
        height: 300px;
    }
}

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

    #product .category {
        display: block;
        width: 100%;
        padding: 30px 0;
        margin: 0;
    }

    #product .category .categorylead {
        display: block;
        width: 100%;
    }


    #product .category .categorylead .wrap {
        display: block;
        box-sizing: border-box;
        width: 90%;
        max-width: 90%;
        padding: 0px;
        margin: 0 auto;
    }

    #product .category .categoryimg {
        display: block;
        width: 90%;
        height: 200px;
        padding: 0;
        margin: 0 auto;
    }

    #product .category .categoryimg img {
        position: relative;
        width: 100%;
        height: auto;
        min-width: auto;
        min-height: auto;
        left: inherit;
        top: inherit;
        -webkit-transform: translate3d(0%, 0%, 0);
        transform: translate3d(0%, 0%, 0);
    }

    #product .product_list {
        padding: 30px 0 30px 0;
    }
}




/*------------------------------------------------------------------
製品詳細
------------------------------------------------------------------*/
#product .item {
    display: block;
    padding: 0;
    margin: 0;
    text-align: left;
}


#product .item .itemttl {
    display: block;
    position: relative;
    padding: 50px 0;
    margin: 0;
    text-align: left;
    background: rgb(155, 155, 155);
    background: -moz-linear-gradient(top, rgb(155, 155, 155) 0%, rgb(98, 98, 98) 100%);
    background: -webkit-linear-gradient(top, rgb(155, 155, 155) 0%, rgb(98, 98, 98) 100%);
    background: linear-gradient(to bottom, rgb(155, 155, 155) 0%, rgb(98, 98, 98) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#9b9b9b', endColorstr='#626262', GradientType=0);
}

#product .item .itemttl:after {
    position: absolute;
    bottom: -10px;
    left: 50%;
    display: block;
    width: 0;
    height: 0;
    margin: 0 0 0 -10px;
    border-top: 10px solid rgb(98, 98, 98);
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    content: "";
}

#product .item .itemttl .wrap {
    display: table;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0;
    margin: 0 auto;
    width: 90%;
    max-width: 1200px;
}

#product .item .itemttl .wrap .itembody {
    display: table-cell;
    width: 50%;
    vertical-align: top;
    box-sizing: border-box;
    padding: 0 10px 0 0;
    color: #fff;
}

#product .item .itemttl .wrap h2 {
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    font-size: 48px;
    line-height: 1;
    padding: 0;
    margin: 0 0 30px 0;
}
#product .item .itemttl .wrap h2.logo_ts img{
	height: 46px;
	width: auto;
}

#product .item .itemttl .wrap .lead {
    line-height: 2;
    letter-spacing: 0;
}


#product .item .itemttl .wrap .itemimg {
    display: table-cell;
    width: 50%;
    vertical-align: top;
    box-sizing: border-box;
    padding: 0 0 0 20px;
}

#product .item .itemttl .wrap .itemimg img {
    display: block;
    width: 100%;
    height: auto;
}


#product .item .itemttl .wrap .itembody p a.btn {
    display: inline-block;
    width: 48%;
    box-sizing: border-box;
    margin-right: 2%;
}

#product .item .itemttl .wrap .itembody p a.btn.case::before {
	transform: rotate(90deg);
}
#product .item .itemttl .wrap .itembody p a.btn.case:hover::before {
    right: 10px;
    top: 60%;
}

#product .item .productdetail {
    display: block;
    padding: 50px 0;
    margin: 0;
    text-align: left;
    background-color: #eee;
}

#product #case ul.productlist li .replace {
    display: block;
    padding: 0 0 30px 0;
    margin: 0;
    color: #fff;
    text-decoration: none;
}

#product #case ul.productlist li .replace figure {
    display: block;
    overflow: hidden;
    padding: 0;
    margin: 0 0 20px 0;
    border-radius: 0px;
    background-color: #000;
}

#product #case ul.productlist li .replace figure img {
    display: block;
    width: 100%;
    height: auto;
    -webkit-transition: -webkit-transform all 0.3s ease-out;
    transition: -webkit-transform all 0.3s ease-out;
    transition: transform all 0.3s ease-out;
    transition: transform all 0.3s ease-out, -webkit-transform all 0.3s ease-out;
    opacity: 1;
}

#product #case ul.productlist li .replace .itemlead {
    display: block;
    padding: 0;
    margin: 0 10px;
    font-size: 13px;
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    letter-spacing: 0;
}

#product #case ul.productlist li .replace h3 {
    display: block;
    position: relative;
    padding: 0;
    margin: 0 10px 0.5em 10px;
    font-size: 26px;
    font-weight: 500;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}

#product #case ul.productlist li .replace p {
    display: block;
    padding: 0;
    margin: 0 10px;
    line-height: 2;
    font-size: 14px;
    letter-spacing: 0;
    font-weight: 500;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}

.productdetail #case ul.productlist li .replace p,
.productdetail #case ul.productlist li .replace h3 {
	color: #000;
}


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

    #product .item .itemttl .wrap h2 {
        font-size: 38px;
        line-height: 1.3;
        margin: 0 0 20px 0;
    }

    #product .item .itemttl .wrap .lead {
        line-height: 1.8;
        letter-spacing: 0;
    }

    #product .item .itemttl .wrap .itembody p a.btn {
        display: block;
        width: auto;
        margin-right: 0;
    }
    #product #case ul.productlist li .replace h3 {
        font-size: 23px;
    }
}

@media only screen and (max-width: 800px) {
	#product .item .itemttl .wrap h2.logo_ts img{
		height: 40px;
	}
}

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

	#product .item .itemttl .wrap h2.logo_ts img{
		margin: 10px 0 0;
	}

    #product .item .itemttl {
        display: block;
        padding: 30px 0;
        margin: 0;
    }

    #product .item .itemttl .wrap {
        display: block;
        margin: 0 auto;
        width: 90%;
    }
    
    #product .item .itemttl .wrap .lead {
        font-size: 16px;
    }

    #product .item .itemttl .wrap .itembody {
        display: block;
        width: auto;
        padding: 0;
        color: #fff;
    }

    #product .item .itemttl .wrap .itemimg {
        display: block;
        width: 100%;
        padding: 0;
        margin: 0;
    }
}


/* -------------------------------------------
製品説明・その他
-------------------------------------------*/
#product dl.dl_feature .mds_circle {
    background-color: #0f8150;
    color: #fff;
}

#product dl.dl_feature:nth-of-type(2) .mds_circle {
    background-color: #0f6f81;
    color: #fff;
}

#product dl.dl_feature:nth-of-type(3) .mds_circle {
    background-color: #0f4481;
    color: #fff;
}

#product dl.dl_feature .mds_box {
    background-color: #0f8150;
    color: #fff;
}

#product dl.dl_feature:nth-of-type(2) .mds_box {
    background-color: #0f6f81;
    color: #fff;
}

#product dl.dl_feature:nth-of-type(3) .mds_box {
    background-color: #0f4481;
    color: #fff;
}

#product dl.dl_feature {
    display: table;
    padding: 0;
    margin: 0;
}

#product dl.dl_feature dt {
    display: table-cell;
    padding: 0;
    margin: 0;
    vertical-align: middle;
}

#product dl.dl_feature dd {
    display: table-cell;
    padding: 0 0 0 30px;
    margin: 0;
    vertical-align: middle;
}

#product dl.dl_feature dd ul.list {
    padding: 0;
    margin: 0;
}

@media only screen and (max-width: 680px) {
    #product dl.dl_feature dt {
        display: block;
        padding: 0;
        margin: 0;
        text-align: center;
    }

    #product dl.dl_feature dd {
        display: block;
        padding: 0;
        margin: 0;
    }
    
    #product dl.dl_feature .mds_circle{
    	margin: 0 auto 1em;
    }
}

/* -------------------------------------------
テーブル（事例）
-------------------------------------------*/

#product .tbl_jirei {
    border-collapse: collapse;
    width: 100%;
    border-top: 1px solid #d3d3d3;
    border-bottom: 1px solid #d3d3d3;
    margin: 0 0 50px 0;
    background-color: #fdfff5;
    border-collapse: collapse;
}

#product .tbl_jirei th,
#product .tbl_jirei td {
    border-bottom: 1px solid #d3d3d3;
    vertical-align: top;
}

#product .tbl_jirei th {
    font-size: 14px;
    white-space: nowrap;
    padding: 10px;
}

#product .tbl_jirei td {
    font-size: 14px;
    padding: 10px;
    text-align: center;
    border-left: 1px solid #d3d3d3;
}


#product .tbl_jirei td p {
    margin: 0;
}

#product .tbl_jirei td p + p {
    margin: 10px 0 0 0;
}

#product .tbl_jirei td ul.note {
    margin: 0;
}

#product .tbl_jirei td ul.list {
    margin: 0;
}

#product .tbl_jirei .color1 {
    background-color: #fcfcea;
}

#product .tbl_jirei .color2 {
    background-color: #eafcea;
}

@media only screen and (max-width: 1120px) {
    #product .tbl_jirei {
        display: block;
        width: 100%;
        overflow: scroll;
    }


    #product .tbl_jirei th {
        font-size: 12px;
        white-space: nowrap;
        padding: 10px;
    }

    #product .tbl_jirei td {
        font-size: 12px;
        padding: 10px;
        text-align: center;
        border-left: 1px solid #d3d3d3;
    }
}

/* -------------------------------------------
受注の流れ
-------------------------------------------*/

.order_flow {
    display: block;
    clear: both;
    position: relative;
    width: 100%;
    text-align: left;
    padding: 0 0 40px 0;
    margin: 0;
    min-height: 100px;
}

.order_flow::before {
    display: block;
    position: absolute;
    left: 50%;
    bottom: 0;
    width: 4px;
    height: 100%;
    border-left: 4px solid #0f8150;
    margin: 0 0 0 -2px;
    z-index: 0;
    content: "";
    clear: both;
}

.order_flow:nth-last-child(1)::before {
    display: none;
}


.order_flow::after {
    display: block;
    content: "";
    clear: both;
}



.order_flow .note {
    font-size: 12px;
    padding-bottom: 30px;

}

.order_flow .ttl_flow {
    display: block;
    position: relative;
    font-size: 18px;
    text-align: center;
    color: #000;
    line-height: 1.5;
    padding: 10px 0;
    margin: 0 0 1em 0;
    font-weight: 500;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    background-color: #fff;
}

.order_flow .mds_flow {
    display: block;
    position: relative;
    font-size: 18px;
    color: #000;
    line-height: 1.5;
    padding: 0 0 10px 0;
    margin: 0 0 1em 0;
    font-weight: 500;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    border-bottom: 2px solid #ccc;
}

.order_flow .flow {
    position: absolute;
    left: 50%;
    display: block;
    box-sizing: border-box;
    margin: 0 0 0 -16%;
    width: 32%;
    z-index: 1;
}

.order_flow .flow:before {
    position: absolute;
    top: 0px;
    left: 50%;
    display: block;
    width: 20px;
    height: 20px;
    margin: -22px 0 0 -10px;
    border-right: 4px solid #0f8150;
    border-bottom: 4px solid #0f8150;
    content: "";
    -webkit-transform: rotate(45deg);
    -moz-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}

.order_flow:nth-of-type(1) .flow:before {
    display: none;
}

.order_flow .flow h3 {
    display: block;
    margin: 0;
    text-align: center;
    padding: 20px;
    font-size: 24px;
    background-color: #0f8150;
    color: #fff;
}

.order_flow .flow_reviewer {
    display: inline-block;
    box-sizing: border-box;
    width: 34%;
    margin: 0;
    padding: 0;
}

.order_flow .flow_reviewer .ttl_flow {
    margin-right: 40px;
}

.order_flow .flow_reviewer .mds_flow {
    padding-right: 40px;
}

.order_flow .flow_reviewer p {
    margin: 0 40px 10px 0;
    padding: 0;
}

.order_flow .flow_reviewer .photo {
    margin-right: 40px;
}




.order_flow .flow_responsible {
    display: inline-block;
    box-sizing: border-box;
    width: 34%;
    float: right;
    padding: 0;
}

.order_flow .flow_responsible .ttl_flow {
    margin-left: 40px;
}

.order_flow .flow_responsible .mds_flow {
    padding-left: 40px;
}

.order_flow .flow_responsible p {
    margin: 0 0 10px 40px;
    padding: 0;
}

.order_flow .flow_responsible .photo {
    margin-left: 40px;
}



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

    .order_flow {
        padding: 0 0 20px 0;
    }

    .order_flow .flow {
        position: relative;
        left: 0;
        display: block;
        box-sizing: border-box;
        margin: 0 0 10px 0;
        width: 100%;
        z-index: 1;
    }

    .order_flow .flow h3 {
        padding: 10px;
        font-size: 18px;

    }

    .order_flow .mds_flow {

        font-size: 16px;
        padding: 0;
        margin: 0 0 0.3em 0;
        border-bottom: 0px solid #ccc;
    }


    .order_flow .ttl_flow {
        font-size: 14px;
        padding: 10px 0;
        margin: 1em 0;
    }



    .order_flow .flow_reviewer {
        width: 50%;
    }

    .order_flow .flow_reviewer .ttl_flow {
        margin-right: 10px;
    }

    .order_flow .flow_reviewer .mds_flow {
        padding-right: 10px;
    }

    .order_flow .flow_reviewer p {
        margin: 0 10px 10px 0;
        padding: 0;
        font-size: 14px;
    }

    .order_flow .flow_reviewer .photo {
        margin: 0 10px 10px 0;
    }


    .order_flow .flow_responsible {
        width: 50%;
    }

    .order_flow .flow_responsible .ttl_flow {
        margin-left: 10px;
    }

    .order_flow .flow_responsible .mds_flow {
        padding-left: 10px;
    }

    .order_flow .flow_responsible p {
        margin: 0 0 10px 10px;
        padding: 0;
        font-size: 14px;
    }

    .order_flow .flow_responsible .photo {
        margin: 0 0 10px 10px;
    }

    .order_flow .note {
        font-size: 12px !important;
        line-height: 1.3;
        padding-bottom: 20px;

    }
}



/* -------------------------------------------
お知らせ一覧
-------------------------------------------*/


#news ul.list_news_thumb {
    position: relative;
    display: block;
    padding: 0;
    margin: 0 0 40px;
    text-align: left;
}

#news ul.list_news_thumb li {
    position: relative;
    box-sizing: border-box;
    display: table;
    float: none;
    padding: 1px;
    margin: 10px 0;
    width: 100%;
    font-size: 14px;
    text-align: left;
}

#news ul.list_news_thumb li figure {
    display: table-cell;
    padding: 0 30px 0 0;
    margin: 0;
    width: 240px;
    height: auto;
    vertical-align: middle;
}

#news ul.list_news_thumb li figure img {
    display: block;
    padding: 0;
    margin: 0;
    width: 100%;
    height: auto;
}

#news ul.list_news_thumb li div {
    display: table-cell;
    box-sizing: border-box;
    padding: 0;
    margin: 0;
    vertical-align: middle;
    text-align: left;
}

#news ul.list_news_thumb li a h3 {
    display: block;
    box-sizing: border-box;
    padding: 0;
    margin: 0 0 6px 0;
    font-size: 18px;
    text-align: left;
    font-weight: bold;
}

#news ul.list_news_thumb li a p {
    display: block;
    box-sizing: border-box;
    padding: 0;
    margin: 0 0 10px 0;
    text-align: left;
    font-size: 16px;
}

#news ul.list_news_thumb li span.icon_category {
    display: inline-block;
    width: 9em;
    font-size: 14px;
    padding: 2px;
    letter-spacing: 0;
    text-align: center;
    background-color: #848484;
    margin: 0 10px 5px 0;
    color: #fff;
    font-weight: 500;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}
#news ul.list_news_thumb li span.icon_category.announcements {
	background-color: #848484;
}
#news ul.list_news_thumb li span.icon_category.product {
	background-color: #2b86b7;
}
#news ul.list_news_thumb li span.icon_category.exhibition {
	background-color: #3cb595;
}
#news ul.list_news_thumb li span.icon_category.urgent {
	background-color: #c15757;
}

#news ul.list_news_thumb li a {
    display: table;
    box-sizing: border-box;
    padding: 25px;
    margin: 0;
    width: 100%;
    text-align: left;
    background-color: #d8d8d8;
}

#news ul.list_news_thumb li a:hover {
    background-color: #ccc;
}


@media only screen and (max-width: 1024px) {
    #news ul.list_news_thumb li {
        font-size: 12px;
    }
}

@media only screen and (max-width: 680px) {
	#news .lead br {
		display: block;
	}
    #news ul.list_news_thumb li {
        width: 100%;
        display: block;
        margin: 0 0 20px 0;
        padding: 0;
    }

    #news ul.list_news_thumb li a {
        padding: 0;
    }

    #news ul.list_news_thumb li figure {
        display: block;
        padding: 0;
        margin: 0;
        width: 100%;
    }

    #news ul.list_news_thumb li figure img {
        display: block;
        padding: 0;
        margin: 0;
        width: 100%;
        height: auto;
    }

    #news ul.list_news_thumb li div {
        display: block;
        box-sizing: border-box;
        padding: 20px;
        margin: 0;
        text-align: left;
    }
}


/* -------------------------------------------
お知らせ詳細
-------------------------------------------*/

#news .newsmain{
	margin: 0;
	padding: 0;
}
#news .newsmain img{
	display: block;
	max-width:70%;
	margin: 0 auto 40px;
}

#news .lead{
	line-height:1.8;
}
.ttl.news {
    font-size: 34px;
}
.contwrap .mds_rect {
    display: block;
}
#news .contwrap {
    margin: 0 auto;
}


@media only screen and (max-width: 680px) {
	#news .newsmain img{
		max-width:100%;
		margin: 0 auto 30px;
	}
	.ttl.news {
	    font-size: 24px;
	}
	#news .mds_rect {
	    margin: 40px 0 1em 0;
	}
}


/* -------------------------------------------
よくあるご質問
-------------------------------------------*/

#faq {
	background: #eee;
}

#faq_list {
	padding: 0 0 10px;
	margin: 0;
}

#faq_list nav.inpagelink ul {
	text-align: left;
	margin: 0 0px 40px 0;
}
#faq_list nav.inpagelink ul li {
    padding: 0 10px 0 0;
}

#faq_list .acmenu {
	display: block;
	clear: both;
	margin-bottom: 60px;
	border-bottom: 1px solid #ddd;
}


#faq_list dt {
	display: block;
	margin: 0;
	position: relative;
	padding: 18px 35px 18px 50px;
	text-align: left;
	font-size: 16px;
	box-sizing: border-box;
	border-top: 1px solid #ddd;
	cursor: pointer;
}

#faq_list dt:hover,
#faq_list dt.active {
	background: #e8e8e8;
}

#faq_list .acmenu dt:before,
#faq_list .acmenu dd:before{
	position: absolute;
	font-family: "Hiragino Sans";
	font-size: 20px;
	font-weight: 900;
	line-height: 1;
	color: #568A73;
	display: block;
}
#faq_list .acmenu dt:before {
	top: 28px;
	left: 15px;
	width: 20px;
	height: 20px;
	margin-top: -10px;
	content: "Q";
}
#faq_list .acmenu dd:before {
	top: 24px;
	left: 50px;
	width: 32px;
	height: 32px;
	content: "A";
}


#faq_list .acmenu dt:after {
	position: absolute;
	top: 50%;
	right: 15px;
	display: block;
	width: 8px;
	height: 8px;
	margin-top: -8px;
	border-left: 2px solid rgba(0, 0, 0, 1);
	border-top: 2px solid rgba(0, 0, 0, 1);
	content: "";
	-webkit-transform: rotate(225deg);
	-moz-transform: rotate(225deg);
	-o-transform: rotate(225deg);
	-ms-transform: rotate(225deg);
	transform: rotate(225deg);
}

#faq_list .acmenu dt.active {
	background: #e8e8e8;
}

#faq_list .acmenu dt.active:after {
	position: absolute;
	top: 50%;
	right: 15px;
	display: block;
	width: 8px;
	height: 8px;
	margin-top: -3px;
	border-left: 2px solid rgba(0, 0, 0, 1);
	border-top: 2px solid rgba(0, 0, 0, 1);
	content: "";
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
}

#faq_list .acmenu dt.active {
	background: #e8e8e8;
}

#faq_list .acmenu dd figure {
	margin: 0 0 20px;
	padding: 0;
}

#faq_list .acmenu dd img {
	max-width: 100%;
	height: auto;
	
}

#faq_list .acmenu dd {
	position: relative;
	display: none;
	margin: 0;
	padding: 20px 10px 20px 80px;
	text-align: left;
	border: none;
	border-top: 1px solid rgba(0, 0, 0, 0.05);
}
#faq_list .acmenu dd p{
	font-size: 16px;
}

#faq_list .acmenu dd a.btn{
	display: inline-block;
    min-width: 15em;
    max-width: 100%;
    margin: 0;
    color: #000;
}
#faq_list .acmenu dd a.btn::before {
    background: url(../../img/common/arrow.svg) center center no-repeat;
    background-size: contain;
}

.acmenu .search_word {
	background-color: rgba(200, 228, 255, 0.5);
	padding: 2px;
}

@media only screen and (max-width: 1024px) {
	#faq_list nav.inpagelink ul li {
    	width: 33.33%;
    }
}

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

	#faq nav.inpagelink ul li {
    	width: 50%;
    	padding: 0 5px 0 0;
    }
    #faq nav.inpagelink ul li a {
	    border: 2px solid #d3d3d3;
	    padding: 5px 5px 5px 15px;
	}
	#faq nav.inpagelink ul li a::before {
        left: 5px;
    }
    #faq nav.inpagelink ul li a:hover {
    	border: 2px solid #afafaf;
    }
    
	#faq_list .acmenu dd {
		padding: 20px 0 20px 45px;
	}
	#faq_list .acmenu dd:before {
		left: 10px;
	}
	#faq_list .acmenu dd img {
		max-width: 100%;
		height: auto;
	}
	#faq_list .acmenu dd a.btn{
		width: 100%;
	}
	#faq_list dt p {
		padding: 0;
	}

	#faq_list dt span {
	    float: none;
	}
}

/* -------------------------------------------
お問い合わせフォーム
-------------------------------------------*/


#contact_form {
    position: relative;
    display: block;
    padding: 0 0 40px;
    margin: 0;
    text-align: center;
}

dl.dl_verisign {
    display: table;
    padding: 0;
    margin: 20px auto;
    list-style: none;
    text-align: left;
    font-size: 12px;
}

dl.dl_verisign dt {
    display: table-cell;
    padding: 0;
    margin: 0;
    width: 120px;
    vertical-align: middle;
    text-align: center;
}

dl.dl_verisign dd {
    display: table-cell;
    padding: 0;
    margin: 0;
    width: auto;
    vertical-align: middle;
}

dl.inq_item {
    padding: 0;
    margin: 0 auto 30px;
    list-style: none;
    display: block;
    text-align: left;
    border-top: 3px solid #d3d3d3;
}

dl.inq_item dt {
    float: left;
    padding: 20px 0 0 0px;
    margin: 0;
    position: relative;
    width: 14em;
    z-index: +1;
    height: 45px;
}

dl.inq_item dt.hissu {
    padding: 0;
    margin: 0;
    position: relative;
    width: 10em;
    z-index: +1;
}

dl.inq_item dt.hissu:after {
    display: inline-block;
    box-sizing: border-box;
    clear: both;
    width: 15px;
    height: 15px;
    margin: 0 0 0 5px;
    position: relative;
    pointer-events: none;
    top: 0;
    right: 0;
    content: "★";
    color: #923D3D;
}

.hissu_mark {
    display: inline-block;
    margin: 0 2px 0 2px;
    color: #0f8150;
}

dl.inq_item dd {
    min-height: 60px;
    margin: 0;
    padding: 20px 20px 20px 15em;
    position: relative;
    vertical-align: bottom;
    line-height: 1.8;
    border-bottom: 1px solid #d3d3d3;
}

dl.inq_item dd:last-child {
    border-bottom: 3px solid #d3d3d3;
}

dl.inq_item dd .comment {
    margin: 0;
    padding: 0;
    font-size: 14px;
    display: block;
}

dl.inq_item dd input[type="text"] {
    max-width: 100%;
    height: auto;
    margin: 0 10px 0 0;
    padding: 7px;
    background-color: rgba(0, 0, 0, 0.02);
    border: 3px solid #d3d3d3;
}

dl.inq_item dt.hissu+dd input[type="text"] {
    background-color: rgba(229, 208, 177, 0.2);
    border: 4px solid rgba(0, 0, 0, 0.08);
}

dl.inq_item dd textarea {
	display: block;
    width: 100%;
    height: auto;
    margin: 0 0 0 0;
    padding: 7px;
    line-height: 1.4;
    background-color: rgba(0, 0, 0, 0.02);
    border: 3px solid #d3d3d3;
}

dl.inq_item .customSelect {
    box-sizing: border-box;
    font-size: 12px;
    display: block;
    color: #000;
    padding: 0;
    white-space: nowrap;
    border: rgba(204, 204, 204, 0.5) solid 0px;
    background-color: #FFF;
    margin: 0px 5px 0px 0px;
    max-width: 100%;
    background-color: rgba(0, 0, 0, 0.06);
}

dl.inq_item .customSelect.changed {
    position: relative;
    width: 100%;
    padding: 0;
    margin: 0;
}

dl.inq_item .customSelectInner {
    display: inline-block;
    padding: 10px;
    margin: 0px;
    line-height: 1.4;
    width: 100%;
    overflow: hidden;
    text-align: left;
}

dl.inq_item label.arrow {
    position: relative;
    display: inline-block;
}

dl.inq_item label.arrow:after {
    display: block;
    box-sizing: border-box;
    clear: both;
    width: 10px;
    height: 10px;
    margin: -10px 0 0 0;
    border-left: rgba(0, 0, 0, 1) solid 2px;
    border-bottom: rgba(0, 0, 0, 1) solid 2px;
    position: absolute;
    pointer-events: none;
    top: 50%;
    right: 15px;
    content: "";
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

input[type="submit"].btn_submit {
    position: relative;
    display: inline-block;
    font-size: 16px;
    max-width: 28em;
    min-width: 18em;
    font-weight: normal;
    line-height: 1.4;
    margin: 15px 0 15px 0;
    padding: 15px 30px;
    border: 4px solid #568A73;
    border-radius: 4px;
    text-decoration: none;
    text-align: center;
    z-index: 1;
    cursor: pointer;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
    background: #fff url(../../img/common/arrow.svg) top 15px right 10px no-repeat;
    background-size: 20px;
}

input[type="submit"].btn_submit:hover {
    border: 4px solid #8cc4ab;
    background-color: rgba(255, 255, 255, 0.2);
    background: #fff url(../../img/common/arrow.svg) top 15px right 5px no-repeat;
    background-size: 20px;
}

.select_address {
    width: 260px;
    height: 35px;
    margin: 0 0 6px 0;
    padding: 0 0 0 8px;
    letter-spacing: 1px;
    border: none;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    border-radius: 3px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    text-indent: .01px;
    text-overflow: "";
    background-color: #f4f3f3;
    cursor: pointer;
}

.select_address::-ms-expand {
    display: none;
}

#contact_form .btn_return {
    position: relative;
    display: inline-block;
    font-size: 16px;
    max-width: 28em;
    min-width: 14em;
    font-weight: normal;
    line-height: 1.4;
    margin: 15px 10px 15px 0;
    padding: 15px 30px;
    border: 4px solid rgba(146, 146, 146, 0.3);
    border-radius: 4px;
    text-decoration: none;
    text-align: center;
    z-index: 1;
    cursor: pointer;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

#contact_form .btn_return:hover {
    background: rgba(146, 132, 111, 0.1);
}

.validateerror{
	margin: 0;
}
.validateerror .absolutetxt{
	color: #E00A17;
}

#contact .btn {
    color: #000;
}

#contact .btn::before {
    position: absolute;
    top: 50%;
    right: 10px;
    display: block;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 0;
    content: "";
    background: url(../../img/common/arrow.svg) center center no-repeat;
    background-size: contain;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

#contact .btn .btn:hover::before {
    right: 5px;
}


@media only screen and (max-width: 680px) {
    #contact_form {
        position: relative;
        display: block;
        padding: 20px 0;
        margin: 0;
        text-align: center;
    }
    dl.inq_item dt {
        float: none;
        width: 100%;
        margin: 0 0 5px 0;
        height: auto;
    }
    dl.inq_item dd {
        margin: 0 0 0 0;
        padding: 0 0 20px;
        position: relative;
        vertical-align: bottom;
        min-height: auto;
    }
    dl.inq_item dd input[type="text"] {
        box-sizing: border-box;
        width: 100%;
        height: auto;
        margin: 5px 0 5px 0;
        padding: 5px;
    }
    dl.inq_item dd textarea {
        box-sizing: border-box;
        width: 100%;
        margin: 5px 0 5px 0;
        padding: 5px;
    }
    #contact_form .btn_return {
    	margin: 5px 0;
    	min-width: 12em;
    }
}



/* -------------------------------------------
企業案内
-------------------------------------------*/


#company .contheader .wrap {
    display: table;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    padding: 0;
    margin: 0 auto;
    width: 90%;
    max-width: 1200px;
}

#company .contimg {
    margin: 0 0 50px 0;
}


#company .contheader nav {
    display: table-cell;
    padding: 0 0 0 0;
    margin: 0 0 0 0;
    width: 40%;
    vertical-align: middle;
}

#company .contheader nav ul {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
    list-style: none;
    font-size: 0;
}

#company .contheader ul li {
    display: inline-block;
    width: 50%;
    padding: 0;
    margin: 0;
    list-style: none;
    font-size: 14px;
}



#company .contheader ul li a {
    position: relative;
    display: block;
    box-sizing: border-box;
    font-size: 14px;
    font-weight: normal;
    line-height: 1.5;
    margin: 0 0 6px 6px;
    padding: 4px 10px 4px 25px;
    border: 2px solid #d9d9d9;
    background-color: rgba(255, 255, 255, 0.2);
    color: #000;
    text-decoration: none;
    text-align: left;
    z-index: 1;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}


#company .contheader ul li a::before {
    position: absolute;
    top: 50%;
    left: 10px;
    display: block;
    width: 10px;
    height: 10px;
    margin: -5px 0 0 0;
    content: "";
    background: url(../../img/common/arrow.svg) center center no-repeat;
    background-size: contain;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

#company .contheader ul li a:hover {
    border: 2px solid #cccccc;
    background-color: rgba(255, 255, 255, 0.4);
}

#company .contheader ul li.active a {
    border: 2px solid rgba(0, 130, 78, 0.37);
    background-color: rgba(255, 255, 255, 0.4);
}

#company .contheader ul li a:hover::before {
    right: 5px;
}

#company dl.list_dl dt {
    width: 13em;
    padding: 20px;
    line-height: 1.8;
}
#company dl.list_dl dd {
    padding: 20px 0 20px 13em;
    line-height: 1.8;
}
#company dl.list_dl dd .contwrap{
    margin: 0;
}
#company dl.list_dl dd .btn{
    margin: 0;
}
#company dl.list_dl dd .cate{
	display: block;
}
#company dl.list_dl dd .cate:not(:first-child){
	margin: 10px 0 0;
}

#company .message p{
    margin: 0 0 10px;
    font-size: 18px;
    line-height: 1.8;
}
#company .message p.pres{
    text-align: right;
}

@media only screen and (max-width: 1024px) {
	#company .contheader ul li a {
	    white-space: normal;
	    text-overflow: clip;
	    vertical-align: middle;
	    line-height: 1.3;
	    font-size: 13px;
	}
	
	#company .contheader ul li a span{
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translateY(-50%) translateX(-50%); 
		-webkit-transform: translateY(-50%) translateX(-50%);
		width: 100%;
		box-sizing: border-box;
		padding: 0 10px 0 25px;
	}
	
}


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

	#company .contheader .ttl {
        padding: 0;
    }
    #company .contheader nav {
        display: block;
        padding: 0;
        margin: 10px 0 0;
        width: 100%;
        vertical-align: top;
    }

    #company .contheader nav ul {
        margin: 0 -2px 0 0;
    }

    #company .contheader ul li {
        padding: 0 2px 2px 0;
        width: 100%;
    }

    #company .contheader ul li a {
        font-size: 12px;
        line-height: 1.5;
        margin: 0;
    }
    #company .contheader ul li a span{
		position: relative;
		top: auto;
		left: auto;
		transform: none; 
		-webkit-transform: none;
		padding: 0;
	}
	#company dl.list_dl dt {
	    width: 100%;
	    padding: 10px 15px;
	    margin: 0 0 15px;
	    display: block;
	    background: #ddd;
	}
	#company dl.list_dl dd {
	    display: block;
	    padding: 15px;
	}
	#company dl.list_dl dd .btn{
	    margin: 20px 0;
	}
	#company dl.list_dl.history dt {
	    margin: 5px 0 0;
	    background: transparent;
	}
	#company .message p {
	    font-size: 16px;
	}
}



/* -------------------------------------------
導入事例
-------------------------------------------*/

#case .product_list {
    display: block;
    position: relative;
    padding: 50px 0 70px 0;
    margin: 0;
    text-align: center;
    background: #2E2E2E;
}

#case .product_list + .product_list {
    background: #3E3E3E;
}

#case ul.productlist li a h3 {
    padding: 0 25px 0 0;
    font-size: 24px;
}

#case ul.productlist {
    margin: 0px -10px 0px 0;
}

#case ul.productlist li {
    width: 25%;
}

#case ul.productlist li.active a {
    position: relative;
}
#case ul.productlist li.active a:before {
    content: "";
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.25);
    top: 0;
    left: 0;
    position:absolute;
    z-index: 5;
}
#case ul.productlist li.active a:hover figure img {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-transition-duration: 0s;
    transition-duration: 0s;
    opacity: 1;
}
#case ul.productlist li.active a:hover h3::after {
    right: 0px;
}

#product #case .product_list .mds_line {
	color: #eee;
	text-align: left;
}

#product #case .item .itemttl .wrap h2 span{
	font-size: 44px;
}
#product #case .item .itemttl .wrap h2 span{
	display: block;
	font-size: 24px;
	line-height: 1.4;
	margin:0 0 10px;
}

#case .cont_bottom {
    display: block;
    position: relative;
    padding: 0px 0 50px 0;
    margin: 0;
}


#case .btn {
    display: block;
    margin: 0 auto;
    color: #000;
}

#case .btn::before {
    position: absolute;
    top: 50%;
    right: 10px;
    display: block;
    width: 20px;
    height: 20px;
    margin: -10px 0 0 0;
    content: "";
    background: url(../../img/common/arrow.svg) center center no-repeat;
    background-size: contain;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

#case .btn:hover::before {
    right: 5px;
}


#case .corp{
	font-size: 22px;
    margin: 35px 0 0;
    padding: 35px 0 5px;
    border-top: 1px solid #a7a7a7;
}

#product #case .item .productdetail:last-of-type {
    padding: 0;
    margin: -70px 0 0;
}
#case .relation{
	display: block;
	background-color: rgba(222, 222, 222, 1);
	padding: 30px 0 70px;
	margin: 60px 0;
}

#case .date {
	margin: 40px 0 0;
}

#case .relation + hr.devider {
	display: none;
}

@media only screen and (max-width: 1024px) {
    #case ul.productlist li {
        width: 50%;
    }
}

@media only screen and (max-width: 680px) {
    #case ul.productlist li {
        width: 100%;
    }
    #product #case .categoryheader .categoryttl {
	    margin: 0;
	}
	#product .item .itemttl .wrap h2 {
    	font-size: 34px;
    }
    #product #case .item .itemttl .wrap h2 span {
	    font-size: 20px;
	}
	#case .corp {
	    font-size: 20px;
	    margin: 20px 0 0;
	    padding: 20px 0 5px;
    }
}


/* -------------------------------------------
カタログダウンロード
-------------------------------------------*/

#catalog ul.productlist li a h3 {
    padding: 0 25px 0 0;
    margin: 0 30px;
    font-size: 20px;
}
#catalog ul.productlist {
    margin: 0px -10px 0px 0;
}

#catalog ul.productlist li {
    width: 25%;
}
#catalog ul.productlist li a {
    padding: 0 0 20px;
}

a.btn.catalog {
    font-weight: 400;
    color: #000;
    font-size: 20px;
    max-width: 100%;
    min-width: 24em;
    padding: 20px 40px 20px 20px;
}
a.btn.catalog::before {
    background: url(../../img/common/arrow.svg) center center no-repeat;
    background-size: contain;
}

@media only screen and (max-width: 1024px) {
    #catalog ul.productlist li {
        width: 50%;
    }
    #catalog ul.productlist li a h3 {
	    padding: 0 15px 0 0;
	    margin: 0 10px;
	    font-size: 17px;
	}
	#catalog ul.productlist li a h3 br{
	    display: none;
	}
	#catalog ul.productlist li a h3::after {
	    position: absolute;
	    top: 2px;
	    width: 15px;
    	height: 15px;
    }
}


/* -------------------------------------------
先輩からのメッセージ　一覧
-------------------------------------------*/

#careers.messtop{
	 background: #efefef;
}
#careers.messtop ul.productlist {
    padding: 30px 0 0;
    margin: 0 -30px 0px 0;
}
#careers.messtop ul.productlist li {
    width: 33.3%;
    padding: 0 30px 30px 0;
}
#careers.messtop ul.productlist li a .itemlead + h3 {
    font-size: 22px;
}
#careers.messtop ul.productlist li a p {
    font-size: 16px;
}
#careers.messtop ul.productlist li a .itemlead {
    font-size: 14px;
}

@media only screen and (max-width: 1024px) {
	#careers.messtop ul.productlist li {
	    width: 50%;
	}
}

@media only screen and (max-width: 680px) {
	#careers .contimg .contentsttl.mess {
	    width: 240px;
	    margin: -20px 0 0px -120px;
	}
	#careers.messtop ul.productlist {
	    padding: 30px 0 0;
	    margin: 0 0px 0px 0;
	}
	#careers.messtop ul.productlist li {
	    width: 100%;
	    padding: 0 0 20px 0;
	}
	

}


/* -------------------------------------------
製品詳細
-------------------------------------------*/

dl.result_dl {
    display: table;
    width: 100%;
    box-sizing: border-box;
    border-bottom: 1px solid #aaa;
    padding: 0;
    margin: 0;
    text-align: left;
    font-weight: 400;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
}

dl.result_dl:first-of-type {
    border-bottom: none;
}
dl.result_dl:last-of-type {
    margin: 0 0 30px;
}
dl.result_dl dt {
    width: 8em;
    overflow: hidden;
    white-space: nowrap;
    padding: 20px 0;
    font-size: 18px;
    display: table-cell;
    vertical-align: middle;
    border-top: 1px solid #aaa;
}

dl.result_dl dd {
    margin: 0;
    padding: 20px 0 20px 2em;
    border-top: 1px solid #aaa;
    font-size: 18px;
    display: table-cell;
    vertical-align: middle;
}
dl.result_dl dd.photo{
	margin: 0;
	width: 250px;
	font-size: 0;
}
dl.result_dl dd.photo img{
	width: 100%;
}

ul.other_list {
    display: block;
    width: 100%;
    padding: 0;
    margin: 0;
    list-style: none;
    font-size: 0;
    text-align: center;
}

ul.other_list li {
    display: inline-block;
    width: 25%;
    padding: 0;
    margin: 0;
    list-style: none;
    font-size: 14px;
}



ul.other_list li a {
    position: relative;
    display: block;
    box-sizing: border-box;
    font-size: 16px;
    line-height: 1.5;
    margin: 0 0 6px 6px;
    padding: 10px 10px 10px 25px;
    border: 2px solid #d9d9d9;
    background-color: rgba(255, 255, 255, 0.2);
    color: #000;
    text-decoration: none;
    text-align: left;
    z-index: 1;
    font-family: Hiragino Sans, "游ゴシック", YuGothic, "メイリオ", "meiryo", sans-serif;
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}


ul.other_list li a::before {
    position: absolute;
    top: 50%;
    left: 10px;
    display: block;
    width: 10px;
    height: 10px;
    margin: -5px 0 0 0;
    content: "";
    background: url(../../img/common/arrow.svg) center center no-repeat;
    background-size: contain;
    -webkit-transition: all 0.1s ease-in-out;
    transition: all 0.1s ease-in-out;
}

ul.other_list li a:hover {
    border: 2px solid #ccc;
    background-color: rgba(255, 255, 255, 0.4);
}

ul.other_list li.active a {
    border: 2px solid rgba(0, 130, 78, 0.37);
    background-color: rgba(255, 255, 255, 0.4);
}

ul.other_list li a:hover::before {
    right: 5px;
}

ul.other_list.insulation li {
    width: 33.33%;
}

#item_list.contwrap{
	margin: 0 -50px 0 0;
}
#item_list .tbl th,
#item_list .tbl td{
	line-height: 1.8;
}
#item_list .tbl th{
	width: 400px;
}

@media only screen and (max-width: 740px) {
	#item_list.contwrap{
		margin: 0 auto;
	}
}
@media only screen and (max-width: 680px) {
    dl.result_dl {
        display:block;
        border-top: 1px solid #ddd;
        padding: 20px 0;
    }

    dl.result_dl dt {
        padding: 0;
        width: 100%;
        display:block;
        border-top: none;
    }
    dl.result_dl dd {
        box-sizing: border-box;
        margin: 0;
        padding: 8px 0 8px 0;
        font-size: 14px;
        display:block;
        width: 100%;
        border-top: none
    }
    dl.result_dl dd.photo{
		margin: 0;
		width: 100%;
	}
	dl.result_dl dd.photo img {
	    width: 80%;
	    margin: 0 auto;
	}
	ul.other_list {
	    text-align: left;
	}
	ul.other_list li {
    	width: 50%;
    }
	ul.other_list li a {
	    font-size: 12px;
	    padding: 5px 10px 5px 25px;
	    margin: 0 0 2px 2px;
	}
	ul.other_list.insulation li {
	    width: 100%;
	}
	#item_list .tbl th{
		width: auto;
	}
}



/* -------------------------------------------
アクセス
-------------------------------------------*/

#access dl.list_dl dd ul.list{
	margin: 0;
}
#access dl.list_dl dd ul.list li:last-child{
	margin: 0;
}


#access iframe{
	width: 100%;
	height: 450px;
	display: block;
	margin: 0 0 40px;
	padding: 0;
}

#access .contheader{
	margin: 0;
}
#access .contimg{
	margin:0 0 50px;
}


@media only screen and (max-width: 680px) {
	#access .contimg{
		margin:0 0 20px;
	}
	#access dl.list_dl dd ul.list{
		margin: 30px 0;
	}
	#misc #access nav.inpagelink ul li a {
	    border: 3px solid #d3d3d3;
	}
	#access nav.inpagelink ul li {
    	width: 100%;
    }
    nav.inpagelink ul li a {
    	padding: 4px;
    }
}


/* -------------------------------------------
ファナック製品
-------------------------------------------*/


#product.fanuc .ttl span{
    font-size: 30px;
}

#product.fanuc .lead {
    font-size: 19px;
    line-height: 2;
    margin: 0 0 3em 0;
}
#product.fanuc .mds_line {
    margin: 2em 0 1em;
}
.tbl_comparison {
    border-collapse: collapse;
    width: 100%;
    margin: 0;
}

.tbl_comparison td,
.tbl_comparison th {
    border: 1px solid #c7c7c7;
    vertical-align: top;
    text-align: center;
}
.tbl_comparison th {
    font-size: 16px;
    white-space: nowrap;
    min-width: 4em;
    padding: 5px 25px;
    background: #ddd;
    border-right: 1px solid #fff;
}
.tbl_comparison td {
    font-size: 16px;
    padding: 8px 25px;
}

.tbl_comparison td:nth-of-type(1) {
    text-align: left;
}
.tbl_comparison tr th:first-of-type,
.tbl_comparison tr td:first-of-type {
    border-left: none;
}
.tbl_comparison tr th:last-of-type,
.tbl_comparison tr td:last-of-type {
    border-right: none;
}
#product.fanuc .tbl_comparison.td_l td{
	text-align: left;
	vertical-align: middle;
}
#product.fanuc .tbl_comparison td {
    padding: 20px 25px;
}


@media only screen and (max-width: 680px){
	#product.fanuc .ttl span {
	    font-size: 24px;
	}
	#product.fanuc .mds_line {
	    font-size: 24px;
	}
	#product.fanuc .contwrap .mds_rect{
		margin-top: 2em; 
	}
		.tbl_comparison {
	    margin: 0 0 10px;
	}
	
	.tbl_comparison th,
	.tbl_comparison td {
	    padding: 5px;
	    font-size: 14px;
	}
	.list_process li{
		width: 100%;
		padding: 0;
		margin: 0 0 40px;
	}
	.list_process li:not(:last-child)::before {
	   position: absolute;
	    top: auto;
	    bottom: -20px;
	    right: 50%;
	    display: block;
	    margin-top: 0;
	    margin-right: -24px;
	    border-width: 22px 24px 0 24px;
	    border-color: #568A73 transparent transparent transparent;
	}
	#product.fanuc .scroll{
		overflow-x: scroll;
	}
	#product.fanuc .scroll .tbl_comparison{
		width: 500px;
	}
	#product.fanuc .tbl_comparison td {
	    padding: 10px 5px;
	}
}

/* -------------------------------------------
ファナック製品バナー
-------------------------------------------*/

.bnr_fanuc .mds{
	color: #fff;
    font-size: 26px;
    margin: 0 0 15px;
    display: inline-block;
}

.bnr_fanuc {
	margin: 30px 0 0;
}
.bnr_fanuc a .photo:hover img {
    -webkit-transform: scale(1.02);
    transform: scale(1.02);
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    opacity: 0.8;
}

@media only screen and (min-width: 681px){
	.bnr_fanuc .sp{
		display: none;
	}
}
@media only screen and (max-width: 680px){
	.bnr_fanuc .pc{
		display: none;
	}
	.bnr_fanuc {
		margin: 20px 0 0;
	}
	.bnr_fanuc .mds {
    	font-size: 22px;
    }
}



/* -------------------------------------------
英語スマホナビ
-------------------------------------------*/

@media only screen and (max-width: 680px) {
	#nav_sp_fix ul.smenu li a {
	    padding: 14px 8px 14px 5px;
	}
	#nav_sp_fix ul.smenu li:nth-of-type(3) a::before {
	    margin: 0 4px 0 0;
	}
}


/* -------------------------------------------
印刷時
-------------------------------------------*/

@media print {
	body {
		width: 1080px;
	}
	#nav_sp_fix {
		display: none;
	}
	#topmainimg .flexslider .slides li {
		height: 600px !important;
	}
	footer {
	    background-color: #2E2E2E;
	}
}</pre></body></html>