/*
Theme Name: i-seisakujo
Description: 株式会社飯野製作所 | 埼玉県 CNC旋盤 金属加工 プロトタイプ試作 小ロット
Theme URI: http://www.i-seisakujo.co.jp/
Version: 1.0
License: i-seisakujo
License URI: http://www.i-seisakujo.co.jp/
*/

@charset "UTF-8";
@import url(https://fonts.googleapis.com/css?family=Lato:400,700);
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);


/****************************************

          リセットCSSここから

*****************************************/

*{
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

html {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-size:62.5%; /*1em=10px */
    overflow-y: scroll; /* 1 */
    -webkit-text-size-adjust: 100%; /* 2 */
    margin:0;
    padding:0;
    border:0;
    outline:0;
    vertical-align:baseline;
    background:transparent;
}


body, div, span, object, iframe,h1, h2, h3, h4, h5, h6, p, blockquote, pre,abbr, address, cite, code,del, dfn, em, img, ins, kbd, q, samp,small, strong, sub, sup, var,b, i,dl, dt, dd, ol, ul, li,fieldset, form, label, legend,table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary,time, mark, audio, video {
    margin:0;
    padding:0;
    border:0;
    outline:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

h1,h2,h3,h4,h5,h6 {
    font-weight:normal;
}

article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section,main { 
    display:block;
}

ul,ol {
    list-style:none;
}

blockquote, q {
    quotes:none;
}

blockquote:before, blockquote:after,
q:before, q:after {
    content:'';
    content:none;
}

a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
}

/* change colours to suit your needs */
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}

/* change colours to suit your needs */
mark {
    background-color:#ff9;
    color:#000; 
    font-style:italic;
    font-weight:bold;
}

del {
    text-decoration: line-through;
}

abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}

table {
    border-collapse:collapse;
    border-spacing:0;
}

img{
    vertical-align: top;
}

/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;   
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}

input, select {
    vertical-align:middle;
}

/****************************************

          body設定(主に書式)

*****************************************/
body{
    font-family: Lato, "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    color: #262626;
    line-height: 1.6;
}

/****************************************

          ページ共通

*****************************************/
#wrapper{
	width: 100%;
	min-width: 1060px;
	min-height:100%;
	float: none;
	margin: 0 auto;
    overflow: hidden;
}


@media screen and (max-width: 767px) {
    #wrapper{
        width: 100%;
        min-width: 0;
        min-height:100%;
        float: none;
        margin: 0 auto;
        overflow: hidden;
    }
    
}

/****************************************

          フォント指定

*****************************************/
li,tt,tr,dt,dd,p{
	font-size: 1.3em;
}

h1{
    color: #040602;
    font-weight: bold;
    font-size: 2em;
}
h2{
	font-size: 1.8em;
	font-weight: bold;
    color: #040601;
}
h3{
    font-size: 1.6em;
    color: #262626;
}
h4{
    font-size: 1.4em;
	font-weight: bold;
    color: #040601;
}
h5{
	font-size:1.4em;
    color:#040601;
	font-weight:bold;
}
 
/****************************************

          リンク指定

*****************************************/

a:link,a:visited{
	font-weight: normal;
    color: #6AAC28;
    text-decoration: underline;
	-webkit-transition:0.2s linear;
	transition:0.2s linear;
}
a:hover,a:active {
	font-weight: normal;
    color: #6AAC28;
    text-decoration: none;
	-webkit-transition:0.2s linear;
	transition:0.2s linear;
}




/****************************************

         オンマウス時のアクション

*****************************************/

a:hover img.img_opacity {
	opacity: 0.75;
	filter: alpha(opacity=75);
	-webkit-transition:0.2s linear;
	transition:0.2s linear;
}
a img.img_opacity {
	-webkit-transition:0.2s linear;
	transition:0.2s linear;
}

a:hover img.img_opacity0 {
    opacity: 0;
    filter: alpha(opacity=0);
    -webkit-transition: 0.4s linear;
    transition:0.4s linear;
}
a img.img_opacity0 {
    -webkit-transition: 0.4s linear;
    transition:0.4s linear;
}




/****************************************

pcヘッダー

*****************************************/
@media screen and (min-width: 768px) {

    #sp_header,#sp_navi,#toggle{display: none;}

    #pc_header{
        width:100%;
        border-top: 4px solid #6AAD29;
    }
    
}


.pc_header_box{
    width: 960px;
    height: 116px;
    margin: 0 auto;
}


.logo{
    float: left;
    margin-top: 38px;
}

.header_right{
    width: 590px;
    float: right;
    padding-top: 30px;
}

.header_info{
    width: 100%;
    height:14px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    margin: 0 0 10px 0;
    background:url(images/header_info.png) no-repeat top left;
}

.header_tel{
    width: 421px;
    height:28px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    background:url(images/header_tel.png) no-repeat left center;
    float: left;
}

.header_btn{
    float: right;
}


/****************************************

spヘッダー

*****************************************/
@media screen and (max-width: 767px) {
    #pc_header,#pc_header_page{display: none;}
    img{width: 100%; height: auto;}

    #sp_header{
        display: block;
        width:100%;
    }
    
    .sp_logo{
        width: 65%;
        margin: 0 auto;
        padding: 15px 0;
    }
    
    
    
    

    #toggle {
        position:absolute; /*bodyに対しての絶対位置指定です*/
        right:15px;
        top:25px;
        width:30px;
        height:25px;
        cursor:pointer;
        z-index: 9999;
    }

    #toggle div {
        position:relative;
    } /*spanの絶対位置指定の親にします*/
    #toggle span {
        display:block;
        position:absolute; /*#navToggle div に対して*/
        width:100%;
        height: 4px;
        background: #999;
        border-radius: 4px;
        -webkit-transition: .35s ease-in-out;
        transition: .35s ease-in-out;
    }
    #toggle span:nth-child(1) {
        top:0;
    }
    #toggle span:nth-child(2) {
        top:11px;
    }
    #toggle span:nth-child(3) {
        top:22px;
    }
    
    .open_navi #toggle{
        position: fixed;
    }

    .open_navi #toggle span:nth-of-type(1) {
        -webkit-transform: translateY(11px) rotate(-315deg);
        transform: translateY(11px) rotate(-315deg);
    }
    .open_navi #toggle span:nth-of-type(2) {
        opacity: 0;
    }
    .open_navi #toggle span:nth-of-type(3) {
        -webkit-transform: translateY(-11px) rotate(315deg);
        transform: translateY(-11px) rotate(315deg);
    }


    #sp_navi {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: 100vw;
        overflow-y: scroll;
        text-align: left;
        background-color: rgba(0,0,0,.9);
        z-index: 999;
        -webkit-transform: translateY(-100%);
        transform: translateY(-100%);
        -webkit-transition:.7s ease-in-out;
        transition: .7s ease-in-out;
    }


    .open_navi #sp_navi {
        -webkit-transform: translateY(0);
        transform: translateY(0);
        -webkit-transition:.7s ease-in-out;
        transition: .7s ease-in-out;
    }


    .open_navi #wrapper {
        -webkit-transform-origin: left center;
        transform-origin: left center;
        -webkit-filter: blur(3px);
        filter: blur(3px);
        -webkit-transition:.7s ease-in-out;
        transition: .7s ease-in-out;
    }



    #sp_navi .menu {
        padding-top: 80px;
        text-align: center;
    }

    #sp_navi .menu .menu-item{
        width:100%;
        text-align:center;
        border:#666 1px solid;
        cursor:pointer;
        color: #FFF;
        margin: 0 auto;
        font-size: 1.4rem;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
    }


    #sp_navi .menu-item a,
    #sp_navi .menu-item span{
        display: block;
        padding: 15px 0 14px;
    }

    #sp_navi .menu-item a:link,
    #sp_navi .menu-item a:visited,
    #sp_navi .menu-item a:hover,
    #sp_navi .menu-item a:active,
    #sp_navi .sub-menu li a:link,
    #sp_navi .sub-menu li a:visited,
    #sp_navi .sub-menu li a:hover,
    #sp_navi .sub-menu li a:active{
        color: #FFF;
        text-decoration: none;
    }

    #sp_navi .sub-menu{
        width:100%;
        text-align:center;
        display:none;
    }
    #sp_navi .sub-menu li{
        width:100%;
        text-align:center;
        border-top:#666 1px solid;
    }

    #sp_navi .sub-menu li a{
        display: block;
        padding: 11px 0 10px;
        color: #ccc;
        background:rgba(255,255,0,0.2);
    }
    #sp_navi .sub-menu li a:hover{
        color: #ccc;
        background:none;
    }


    .menu-item-has-children{
        position: relative;
    }

    .menu-item-has-children::before{
        content: '';
        width: 14px;
        height: 14px;
        border: 0px;
        border-top: solid 3px #ddd;
        border-right: solid 3px #ddd;
        -webkit-transform: rotate(135deg);
        transform: rotate(135deg);
        -webkit-transition:.2s ease-in-out;
        transition: .2s ease-in-out;
        position: absolute;
        top: 14px;
        right: 20px;
    }
    .menu-item-has-children.menu_open::before{
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
        -webkit-transition:.2s ease-in-out;
        transition: .2s ease-in-out;
        top:22px;
    }

}



/****************************************

pc用 横ナビ

*****************************************/
#g_navi{
	width: 100%;
	height: 71px;
	margin: 0 auto;
    background: url(images/navi_bg.jpg) left bottom repeat-x;
    z-index: 9999;
    position: relative;
    border-top: 1px solid #E8E8E8;
}
#g_navi .menu{
  *zoom: 1;
    width: 960px;
  list-style-type: none;
  margin:0 auto;
}
#g_navi .menu:before, #g_navi .menu:after{
  content: "";
  display: table;
}
#g_navi .menu:after{
  clear: both;
}
#g_navi .menu li{
  position: relative;
  width: 160px;
  float: left;
  text-align: center;
  line-height:0;
}

#g_navi .menu li a{
  display: block;
  margin: 0;
  color: #000;
  font-size: 1.4em;
  line-height: 1;
  text-decoration: none;
}
#g_navi .menu li ul{
  list-style: none;
  position: absolute;
  z-index: 9999;
  top: 100%;
  left: 0;
  margin: 0;
  padding: 0;
}
#g_navi .menu li ul li{
  width: 100%;
}
#g_navi .menu li ul li a{
	width:160px;
	padding:13px 5px;
  border-top: 1px solid #ccc;
  font-size:0.7em;
  background: #FFF;
  text-align: center;
  opacity: 0.95;
	filter: alpha(opacity=95);
}

#g_navi .menu li ul li a:hover{
    background:#6AAD29;
	color:#FFF;
	-webkit-transition:0.2s linear;
	transition:0.2s linear;
}





#g_navi .menu li ul{
    visibility: hidden;
    opacity: 0;
    -webkit-transition:0s;
    transition: 0s;
}
#g_navi .menu li:hover ul{
    visibility: visible;
    opacity: 0.95;
}
#g_navi .menu li ul li a{
    visibility: hidden;
    opacity: 0;
    -webkit-transition:.5s;
    transition: .5s;
}
#g_navi .menu li:hover ul li a{
    visibility: visible;
    opacity: 1;
}




#g_navi .menu > li > a {
    position: relative;
    display: inline-block;
    -webkit-transition: .6s;
    transition: .6s;
}

#g_navi .menu > li > a::after {
    position: absolute;
    left: 0;
    content: '';
    width: 0;
    height: 4px;
    background-color: #6AAD29;
    -webkit-transition: .6s;
    transition: .6s;
    opacity: 0;
    filter: alpha(opacity=0);
}

#g_navi .menu > li > a::after {
    bottom:0;
}

#g_navi .menu > li > a:hover::after {
    width: 100%;
    opacity: 1;
    filter: alpha(opacity=100);
}






/****************************************

          ティーザー

*****************************************/

#slider{
	width: 100%;
	height:550px;
    margin: 0 auto 70px;
    position: relative;
}


#slider .metaslider{
    width: 1920px;
    position: absolute;
    left:calc(50% - 960px);
}

#teaser{
    width: 100%;
    height:200px;
    margin: 0 auto;
    position: relative;
}
#teaser img{
    width: 1920px;
    position: absolute;
    left:calc(50% - 960px);
}


@media screen and (max-width: 767px) {
    
    #sp_slider{
        width: 100%;
        margin-bottom: 60px;
    }
    
    #sp_slider .metaslider{
        width:100%;
    }
    
    
    #sp_teaser{
        width: 100%;
        padding: 0;
        border-top: solid 4px #E8E8E8;
        text-align: center;
    }
    
    #sp_teaser img{
        width: 200%;
        position: relative;
        top:0;
        left:-40%;
    }

}



/****************************************

          content 共通設定

*****************************************/
#contents{
    width: 960px;
    margin: 0 auto;
}

main#top_main{
    width: 960px;
    margin: 0 auto;
}

main#left_box{
    width: 700px;
    float: left;
}


.breadcrumb_area {
	width: 100%;
	height: auto;
	margin:0 auto 55px;
    background: #EFEFEF;
}
.breadcrumb{
	width: 960px;
	margin:0 auto;
    text-align: right;
    padding: 3px 0;
}


.main_bottom_box{
    text-align: center;
    margin-top: 60px;
    padding-bottom: 50px;
    background: url(images/border.jpg) left bottom repeat-x;
}

.main_bottom_box_tit{
    width: auto;
    height:22px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    background:url(images/bottom_tit.png) no-repeat center center;
    margin-bottom: 20px;
}




.bottom_btn{
    width: 960px;
    height: 220px;
    margin: 50px auto 0;
    position: relative;
    background: url(images/bottom_btn_bg.jpg) 0 0 no-repeat;
}
.bottom_btn img{
    position: absolute;
    bottom: 30px;
    right: 30px;
}



@media screen and (max-width: 767px) {
    
    main#top_main {
        width: 100%;
        padding: 0 2%;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
    }
    main#left_box{
        width: 100%;
        float: none;
    }
    .breadcrumb_area {
        width: auto;
        height: auto;
        margin:0px auto 35px;
        padding: 0 10px;
        background: #EFEFEF;
    }
    .breadcrumb{
        width: 100%;
        margin:0 auto;
        text-align: right;
    }
    #contents{
        width: 100%;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        margin: 0 auto;
        padding: 0 2%;
    }
    .breadcrumb{
        width: 100%;
        margin:0 auto 30px;
        text-align: right;
        padding: 2% 0;
    }

    
    .bottom_btn{
        display: none;
    }
    
    .main_bottom_box{
        text-align: center;
        margin-top: 60px;
        padding-bottom: 30px;
        background: url(images/border.jpg) left bottom repeat-x;
    }

    .main_bottom_box_tit{
        width: auto;
        height:22px;
        text-indent: 100%;
        overflow: hidden;
        white-space: nowrap;
        background:url(images/bottom_tit.png) no-repeat center center;
        background-size: contain;
        margin-bottom: 10px;
    }
}



/****************************************

          contentトップ用

*****************************************/

.top_box01{
	width: auto;
    margin:0 auto 50px;
}

.top_headline{
    width: auto;
    height:230px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    background:url(images/top_headline.png) no-repeat center center;
}

.top_headline_wrap{
    width: 230px;
    float: left;
    background: url(images/top_box01_tit_bg.jpg) 0 0 no-repeat;
}

.top_box01_text{
    width: 730px;
    height: 230px;
    float: right;
    padding: 35px 200px 0 30px;
    background: url(images/top_box01_bg.jpg) 0 0 no-repeat;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}





.top_box02{
    margin-bottom: 60px;
}

.top_box02_tit{
    width: auto;
    height:57px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    margin-bottom: 30px;
    background:url(images/top_box02_tit.png) no-repeat center top;
}

.top_box02_parts{
    width: 300px;
    float: left;
    -webkit-box-shadow: 3px 3px 4px rgba(0,0,0,.2);
    box-shadow: 3px 3px 4px rgba(0,0,0,.2);
    margin: 0 30px 30px 0;
}

.top_box02_parts_img img{
    width: 300px;
    height: auto;
}

.top_box02_parts_text{
    padding: 10px 15px;
    border-top: 3px solid #6AAD29;
}
.top_box02_parts_text h3{
    font-size: 1.5rem;
    padding-left: 17px;
    font-weight: bold;
    margin-bottom: 5px;
    position: relative;
}
.top_box02_parts_text h3::before{
    position: absolute;
    content: '';
    left: 0;
    top:9px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #6AAD29;
    border-right: 2px solid #6AAD29;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.top_box02_parts_text h3 a {
    color: #262626;
    position: relative;
    display: inline-block;
    text-decoration: none;
    font-weight: bold;
}
.top_box02_parts_text a::after {
    position: absolute;
    bottom: 0px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #6AAD29;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
}
.top_box02_parts_text a:hover::after {
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}


.top_box02_btn li{
    -webkit-box-shadow: 3px 3px 4px rgba(0,0,0,.2);
    box-shadow: 3px 3px 4px rgba(0,0,0,.2);
    float: left;
}
.top_box02_btn li:last-child{
    float: right;
}


.top_box03{
    margin-bottom: 55px;
    text-align: center;
}

.top_box03_tit{
    width: auto;
    height:57px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    margin-bottom: 30px;
    background:url(images/top_box03_tit.png) no-repeat center top;
}

.top_box03_subtit{
    width: auto;
    height:26px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    margin-bottom: 30px;
    background:url(images/top_box03_text.png) no-repeat center top;
}

.top_box03_bana{
    margin-top: 30px;
}

.top_box03_bana li{
    float: left;
    position: relative;
}

.top_box03_bana li .img_opacity0{
    position: absolute;
    top: 0;
    left: 0;
    z-index: 2;
}



@media screen and (min-width: 768px) {

    .top_box02_parts:nth-child(3n){
        margin-right: 0;
    }
    .top_box02_parts:nth-child(3n+1){
        clear: both;
    }
    .top_box02_parts:nth-last-child(-n+3){
        margin-bottom: 50px;
    }
    
    .top_box03_bana li:last-child{
        float: right;
    }
    
}


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

    
    .top_headline{
        width: auto;
        height:230px;
        text-indent: 100%;
        overflow: hidden;
        white-space: nowrap;
        background:url(images/top_headline.png) no-repeat center center;
    }

    .top_headline_wrap{
        width: 100%;
        float: none;
        background: url(images/top_box01_tit_bg.jpg) 0 0 no-repeat;
        background-size: cover;
    }

    .top_box01_text{
        width: 100%;
        height: auto;
        float: none;
        padding: 4%;
        background: url(images/top_box01_bg.jpg) 0 0 no-repeat;
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        background-size: cover;
    }
    .top_box02_inner {
        margin-bottom: 6px;
    }
    .top_box02_parts{
        width: 48%;
        float: left;
        -webkit-box-shadow: 3px 3px 4px rgba(0,0,0,.2);
        box-shadow: 3px 3px 4px rgba(0,0,0,.2);
        margin: 0 2% 6% 0;
    }
    .top_box02_parts_text{
        padding: 10%;
        border-top: 3px solid #6AAD29;
    }
    .top_box02_parts_img img{
        width: 100%;
        height: auto;
    }
    .top_box02_parts:nth-child(2n){
        margin-right: 0;
    }
    .top_box02_parts:nth-child(2n+1){
        clear: both;
    }
    .top_box02_btn li{
        -webkit-box-shadow: 3px 3px 4px rgba(0,0,0,.2);
        box-shadow: 3px 3px 4px rgba(0,0,0,.2);
        float: none;
        margin-bottom: 6%;
    }
    .top_box02_btn li:last-child{
        float: none;
        margin-bottom: 0;
    }
    .top_box03_subtit{
        width: auto;
        height: auto;
        text-indent: 100%;
        overflow: hidden;
        white-space: nowrap;
        margin-bottom: 6%;
        background:url(images/top_box03_text.png) no-repeat center top;
        background-size: contain;
    }
    .top_box03_bana li{
        float: none;
        margin-bottom: 6%;
    }
}


/****************************************

news トップ用

*****************************************/


.news_box{
    width: 100%;
}

.news_tit{
    width: auto;
    height:35px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    margin-bottom: 15px;
    background:url(images/top_news_tit.png) no-repeat left top;
}

.news_post{
    height: 240px;
    overflow-y: scroll;
}

.news_list{
    width: 97%;
    padding: 0 0 1.8%;
    border-bottom: 1px dotted #CCC;
    margin-bottom: 2.2%;
}

.news_list h3{
    color: #BA9D51;
    font-size: 1.3rem;
    position: relative;
    padding-left: 25px;
    margin-bottom: 5px;
}

.news_list h3:before{
    content: "";
    position: absolute;
    display:block;
    width: 14px;
    height: 2px;
    background: #6AAD29;
    left: 0;
    top: 50%;
}

.news_list a {
    color: #262626;
    position: relative;
    text-decoration: none;
    padding-bottom: 3px;
    font-weight: bold;
}
.news_list a::after {
    position: absolute;
    bottom: 0px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #6AAD29;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
}
.news_list a:hover::after {
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}


.news_list p{
    padding-left: 20px;
    font-size: 1.3rem;
}


@media screen and (max-width: 767px) {
    
    .news_box{
        width: 100%;
        float: none;
        margin-bottom: 40px;
    }
    
    .news_post{
        width: 100%;
        height: 180px;
        overflow-y: scroll;
    }
    
    .data {
        width: 100%;
        float: none;
        color: #666;
        font-size: 1.4rem;
    }
    .news_list h4 {
        font-size: 1.4rem;
        width: 100%;
        float: none;
    }
}


/****************************************

          content下層用

*****************************************/

/* 当社について */

.strength_box01,
.strength_box02{
    margin-bottom: 40px;
}

.strength_box_tit{
    width: 100%;
    position: relative;
    padding: 8px 5px 7px 215px;
    background: url(images/02box_tit_bg.jpg) 0 0 repeat;
    border: 1px solid #CCC;
    margin-bottom: 15px;
}
.strength_box_tit:before{
    content: '';
    position: absolute;
    width: 190px;
    height: 43px;
    background: url(images/02box_tit01.jpg) 0 0 no-repeat;
    top: -10px;
    left: 10px;
}
.tit01:before{
    background: url(images/02box_tit01.jpg) 0 0 no-repeat;
}
.tit02:before{
    background: url(images/02box_tit02.jpg) 0 0 no-repeat;
}
.tit03:before{
    background: url(images/02box_tit03.jpg) 0 0 no-repeat;
}


.strength_box_text{
    width: 450px;
    float: left;
}
.strength_box_text02{
    width: 450px;
    float: right;
}
.strength_box_img{
    float: right;
}
.strength_box_img02{
    float: left;
}
.strength_box_img img,
.strength_box_img02 img{
    width: 230px;
    height: auto;
}



@media screen and (max-width: 767px) {
    
    .strength_box_tit{
        width: 100%;
        position: relative;
        padding: 40px 10px 7px;
        background: url(images/02box_tit_bg.jpg) 0 0 repeat;
        border: 1px solid #CCC;
        margin-bottom: 15px;
    }
    .strength_box_tit:before{
        content: '';
        position: absolute;
        width: 190px;
        height: 43px;
        background: url(images/02box_tit01.jpg) 0 0 no-repeat;
        top: -10px;
        left: 10px;
    }
    
    
    .strength_box_text,
    .strength_box_text02{
        width: 100%;
        float: none;
        margin-bottom: 15px;
    }
    .strength_box_img,
    .strength_box_img02{
        float: none;
    }
    .strength_box_img img,
    .strength_box_img02 img{
        width: 100%;
        height: auto;
    }
    
}




/* 設備紹介 */

.introduction_box{
    padding: 35px 30px 30px;
    background: url(images/facility.jpg) left 25px top no-repeat,#F5F5F5;
    border: 1px solid #CCC;
    margin-bottom: 30px;
}

.introduction_box_text{
    width: 360px;
    float: right;
}

.introduction_box_text h2{
    margin-bottom: 15px;
}

.introduction_box_img{
    width: 260px;
    padding: 5px;
    background: #FFF;
}



@media screen and (max-width: 767px) {
    
    .introduction_box{
        padding: 35px 10px 10px;
        background: url(images/facility.jpg) left 15px top no-repeat,#F5F5F5;
        border: 1px solid #CCC;
        margin-bottom: 30px;
    }

    .introduction_box_text{
        width: 100%;
        float: none;
        margin-bottom: 15px;
    }
    
    .introduction_box_img{
        width: 100%;
        padding: 5px;
        background: #FFF;
    }
    
}


/* 納品までの流れ */

.flow_box{
    padding: 10px;
    border: 10px solid #F5F5F5;
    outline: 1px solid #CCC;
    margin-bottom: 30px;
}
.flow_box:last-of-type{
    margin-bottom: 0;
}

.flow_box_text{
    width: 420px;
    float: left;
}

.flow_box_img{
    float: right;
}

.step01{
    padding: 16px 0 32px 100px;
    background: url(images/step01.png) left top no-repeat;
    margin-bottom: 10px;
}
.step02{
    padding: 16px 0 32px 100px;
    background: url(images/step02.png) left top no-repeat;
    margin-bottom: 10px;
}

.step03{
    padding: 16px 0 32px 100px;
    background: url(images/step03.png) left top no-repeat;
    margin-bottom: 10px;
}

.step04{
    padding: 16px 0 32px 100px;
    background: url(images/step04.png) left top no-repeat;
    margin-bottom: 10px;
}



@media screen and (max-width: 767px) {
    
    .flow_box_text{
        width: 100%;
        float: none;
        margin-bottom: 15px;
    }

    .flow_box_img{
        float: none;
    }
    
}


/* お問い合わせ */

.contact_text{
    margin-bottom: 15px;
}

.sitepolicy{
    padding: 20px;
    background: #F5F5F5;
    border: 1px solid #CCC;
    margin-bottom: 40px;
}

.sitepolicy dt{
    color: #040600;
    font-size: 1.6rem;
    font-weight: bold;
    padding-left: 25px;
    background: url(images/circle.png) left top 5px no-repeat;
    margin-bottom: 10px;
}




/* アルミ加工 */

.performance_parts{
    width: 220px;
    float: left;
    -webkit-box-shadow: 3px 3px 4px rgba(0,0,0,.2);
    box-shadow: 3px 3px 4px rgba(0,0,0,.2);
    margin: 0 20px 20px 0;
}

.performance_parts_img img{
    width: 220px;
    height: auto;
}

.performance_parts_text{
    padding: 10px;
    border-top: 3px solid #6AAD29;
}
.performance_parts_text h3{
    font-size: 1.3rem;
    padding-left: 17px;
    font-weight: bold;
    margin-bottom: 5px;
    position: relative;
}
.performance_parts_text h3::before{
    position: absolute;
    content: '';
    left: 0;
    top:6px;
    width: 6px;
    height: 6px;
    border-top: 2px solid #6AAD29;
    border-right: 2px solid #6AAD29;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.performance_parts_text h3 a {
    color: #262626;
    position: relative;
    display: inline-block;
    text-decoration: none;
    font-weight: bold;
}
.performance_parts_text a::after {
    position: absolute;
    bottom: 0px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #6AAD29;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
}
.performance_parts_text a:hover::after {
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}

@media screen and (min-width: 768px) {

    .performance_parts:nth-child(3n){
        margin-right: 0;
    }
    .performance_parts:nth-child(3n+1){
        clear: both;
    }

}


@media screen and (max-width: 767px) {
    
    .performance_parts{
        width: 49%;
        float: left;
        -webkit-box-shadow: 3px 3px 4px rgba(0,0,0,.2);
        box-shadow: 3px 3px 4px rgba(0,0,0,.2);
        margin: 0 2% 6% 0;
    }

    .performance_parts_img img{
        width: 100%;
        height: auto;
    }
    
    .performance_parts:nth-child(2n){
        margin-right: 0;
    }
    .performance_parts:nth-child(2n+1){
        clear: both;
    }
    
}




/* 会社概要 */

.overview_box01{
    height: 525px;
    padding: 23px 30px 30px 18px;
    background: url(images/08box01_bg.jpg) 0 0 no-repeat;
    margin-bottom: 30px;
}

.overview_box01_tit{
    width: auto;
    height:106px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    margin-bottom: 20px;
    background:url(images/08box01_tit.png) no-repeat left top;
}

.overview_box01_text{
    padding-left: 12px;
}
.overview_box01_text p{
    color: #FFF;
}

.name{
    width: auto;
    height:21px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    margin-top: 35px;
    background:url(images/name.png) no-repeat right top;
}

.overview_img{
    margin-bottom: 20px;
}
.overview_img li{
    float: left;
    margin-right: 20px;
}
.overview_img li:last-child{
    margin-right: 0;
}

@media screen and (max-width: 767px) {
    
    .overview_box01{
        height: auto;
        padding: 15px;
        background: url(images/08box01_bg.jpg) 0 0 no-repeat;
        background-size: cover;
        margin-bottom: 30px;
    }

    .overview_box01_tit{
        width: auto;
        height:76px;
        text-indent: 100%;
        overflow: hidden;
        white-space: nowrap;
        margin-bottom: 10px;
        background:url(images/08box01_tit.png) no-repeat left center;
        background-size: contain;
    }
    
    .overview_box01_text{
        padding-left: 0;
    }
    

    .overview_img li{
        width: 32%;
        float: left;
        margin-right: 2%;
    }
    .overview_img li:last-child{
        margin-right: 0;
    }
    
    .google_map iframe{
        width: 100%;
        height: auto;
    }
    
}







.access_box01{
    padding: 20px;
    background: #F5F5F5;
    border: 1px solid #CCC;
    margin-bottom: 30px;
}

.access_box01 dt{
    color: #040600;
    font-size: 1.6rem;
    font-weight: bold;
    padding-left: 25px;
    background: url(images/circle.png) left top 5px no-repeat;
    margin-bottom: 10px;
}

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

    
    
}

/****************************************

         single.php

*****************************************/

#single_box {
	width: 100%;
    margin: 0 auto;
}

.single_text01 {
	width: 100%;
}
.single_text01 img{
    max-width: 100%;
    height: auto;
    margin: 10px 0;
}

.pager{
	clear:both;
	text-align:center;
	padding:30px 0;
}

a.page-numbers,
.pager .current{
	background:rgba(0,0,0,0.02);
	border:solid 1px rgba(0,0,0,0.1);
	border-radius:5px;
	padding:5px 8px;
	margin:0 2px;
    font-size: 1.4rem;
}
.pager .current{
	background:rgba(0,0,0,1);
	border:solid 1px rgba(0,0,0,1);
	color:rgba(255,255,255,1);
}
.nav-below{
    margin: 30px 0 20px;
    text-align: center;
}

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

    .single_box {
        width: auto;
        padding: 0 10px;
    }
}


/****************************************

sp_footer

*****************************************/

@media screen and (max-width: 767px) {
    
    #pc_footer{
        display: none;
    }
    
    #sp_footer {
        padding: 20px 0;
        text-align: center;
        margin-top: 80px;
        border-top: solid 2px #6aad2a;
        background: #efefef;
    }
    
    .sp_pagetop{
        width: 50px;
        position: fixed;
        bottom:0;
        right:0;
    }
    
}


/****************************************

pc_footer

*****************************************/
@media screen and (min-width: 768px) {
    #sp_footer{
        display: none;
    }
}

#pc_footer {
    width:100%;
    background: url(images/footer_bg.jpg) left top repeat-x;
    height: 210px;
    margin-top: 80px;
    text-align: center;
}

.footer_box{
    width: 100%;
    height: 170px;
    padding: 30px 0 0;
    margin: 0 auto;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.pagetop{
    position: fixed;
    bottom: 80px;
    right: 80px;
}

.footer_logo{
    margin-bottom: 20px;
}







.copyright{
    color: #969592;
    padding-top: 11px;
}


/****************************************

         sidebar

*****************************************/

#sidebar{
	width:230px;
	float:right;
}

.side_bana{
    margin-bottom: 30px;
}
.side_bana li{
    margin-bottom: 10px;
}
.side_bana li:last-child{
    margin-bottom: 0;
}

.side_info{
    width: 222px;
    padding: 15px 10px;
    background: #FFF;
    border: 1px solid #CCC;
    outline: 4px solid #EFEFEF;
    margin:0 auto 25px;
}

.side_info_tit{
    height:41px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    margin-bottom: 15px;
    background:url(images/side_info_logo.png) no-repeat center top;
}

.side_tel{
    height:45px;
    text-indent: 100%;
    overflow: hidden;
    white-space: nowrap;
    background:url(images/side_tel.png) no-repeat left top;
    margin:10px 0 15px;
}


.side_link li{
    margin-bottom: 20px;
    padding:0 0 20px 25px;
    border-bottom: 1px solid #EFEFEF;
    position: relative;
}
.side_link li:before{
    content: "";
    position: absolute;
    display:block;
    width: 15px;
    height: 4px;
    background: #6AAD29;
    left: 0;
    top: 9px;
}

.side_link li a{
    color: #262626;
    position: relative;
    text-decoration: none;
    padding-bottom: 3px;
}
.side_link li a::after {
    position: absolute;
    bottom: 0px;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #6AAD29;
    -webkit-transform: scale(0, 1);
    transform: scale(0, 1);
    -webkit-transform-origin: right top;
    transform-origin: right top;
    -webkit-transition: -webkit-transform .3s;
    transition: -webkit-transform .3s;
    transition: transform .3s;
    transition: transform .3s, -webkit-transform .3s;
}
.side_link li a:hover::after {
    -webkit-transform-origin: left top;
    transform-origin: left top;
    -webkit-transform: scale(1, 1);
    transform: scale(1, 1);
}
.side_link li:last-child{
    margin-bottom: 0;
}



@media screen and (max-width: 767px) {
    #sidebar{
        display: none;
    }
}


/****************************************

         タイトル

*****************************************/

h1.headline{
    padding: 0 0 13px 20px;
    margin-bottom: 20px;
    background: url(images/headline_h1.png) left bottom no-repeat;
}
.headline_text{
    margin-bottom: 30px;
}

h2.subhead01{
    height: 45px;
    line-height: 47px;
    padding: 0 0 0 35px;
    margin-bottom: 20px;
    background: url(images/subhead01_h2.jpg) left bottom no-repeat;
    font-size: 2rem;
    color: #FFF;
}
h2.subhead01 span{
    padding-left: 10px;
    font-size: 1.2rem;
    color:#D1C3A9;
}

h2.subhead02{
    padding: 8px 5px 8px 12px;
    margin-bottom: 20px;
    font-size: 1.6rem;
    background: url(images/subhead02_h2.png) left top no-repeat;
    color: #180101;
    font-weight: bold;
}



h3.subhead01{
    padding: 6px 5px 5px;
    border: 1px solid #8F712E;
    color: #5B2C00;
    font-weight: bold;
    font-size: 1.8rem;
    margin-bottom: 20px;
    text-align: center;
    background: -webkit-gradient(linear, left top, left bottom, from(#FAFDD0), color-stop(49%, #FAFDD0),color-stop(50%, #E0DFA9),to(#FBFACC));
    background: linear-gradient(to bottom, #FAFDD0 0%, #FAFDD0 49%,#E0DFA9 50%,#FBFACC 100%);
}





@media screen and (max-width: 767px) {
    
    
}


/****************************************

         テーブル

*****************************************/


.overview_table{
    width: 100%;
    border-collapse: collapse;
    border: 1px solid #CCC;
}

.overview_table th{
    width: 30%;
    text-align: left;
    padding: 2.4% 1% 2% 2%;
    background: #F5F5F5;
    font-weight: bold;
    border: 1px solid #CCC;
}

.overview_table td{
    width: 64%;
    text-align: left;
    padding: 2.4% 1% 2% 2%;
    background: #FFF;
    border: 1px solid #CCC;
}



/****************************************

         P

*****************************************/
/* 改行 */
p.line_break,
span.line_break{
	padding-top: 20px;
}
/* 改行 */
p.line_break02{
	padding-top: 30px;
}
/* 赤文字*/
.red{
	color: #f00;
	font-weight: bold;
}
.big_red{
    color: #f00;
    font-size: 1.8rem;
}
/* 強調*/
.big_bold{
	font-size:1.6rem;
	font-weight: bold;
}
.bold{
	font-weight: bold;
}

/* 小文字*/
.small{
	font-size: 1em;
	font-weight: bold;
	color: #384C0E;
}

.green{
    color: #6AAC26;
    font-weight: bold;
}


/****************************************

         Contact Form7

*****************************************/

.wpcf7{
	width:100%;
}

.wpcf7-form textarea{
	width: 650px !important; /*本文*/
}
.wpcf7-form .wpcf7-submit{
	width: 50px !important; /*送信ボタン*/
}
.wpcf7 p {
	line-height: 2.0; /*項目間の隙間*/
	padding-top: 3px;
}
.wpcf7-form input{
	width: auto !important; /*ラジオボタン、チェックボタン*/
}
.contact_p_strong{
	border-top: 1px dotted #999;
	font-weight: bold;
	margin-top: 15px;
	padding-top: 15px !important;
}
.normal{
	font-weight: normal;	
}
.wpcf7-submit{
    margin-top:10px;
}

.wpcf7-response-output{
    font-size: 1.3em;
}
/****************************************

         追加

*****************************************/

.mb0{
    margin-bottom: 0;
}

/****************************************

          clearfix

*****************************************/
.clearfix:after{
    content: "."; 
    display: block; 
    height: 0; 
    font-size:0;    
    clear: both; 
    visibility:hidden;
}
.clearfix{
    display: inline-block;
} 
/* Hides from IE Mac */
* html .clearfix{
    height: 1%;
}
.clearfix{
    display:block;
}

/* End Hack */