/*
@import url(animate.css);
@import url(//maxcdn.bootstrapcdn.com/font-awesome/4.1.0/css/font-awesome.min.css);
@import url(//fonts.googleapis.com/css?family=Cabin:400,600,700);
@import url(//fonts.googleapis.com/css?family=Open+Sans:400,600,300);
*/
@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
@import "grid.css";
@import "font-awesome.css";


/*========================================================
                      Main Styles
=========================================================*/

body {
	background: white;
	color: #777;
	line-height: 22px;
	font-weight: 400;
	font-size: 14px;
	font-family: "メイリオ", Meiryo, Osaka, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	-webkit-text-size-adjust: none;
	font-family: 'Noto Sans Japanese';
	font-style: normal;
	font-weight: 300;
}

.bold {
font-weight:700;
}

img {
  max-width: 100%;
  height: auto; }

@media (max-width: 767px) {
#bread {
	display: none!important;
}
}
@media (max-width: 479px) {
#bread {
	display: none!important;
}
}

nav#bread {
	background-color:#EEE;
	display:block;
	width:100%;
}
nav#bread div {
	margin: auto;
	float:none;
}
nav#bread div ul {
	color:#000;
	margin: 6px 0;
	float:left;
}

nav#bread div ul li {
	float:left;
	background-image:url(../images/bread_p.png);
	background-repeat:no-repeat;
	background-position:center left;
	padding-left:16px;
	margin-right:12px;
	font-size:85%;
}
nav#bread div ul li:first-child {
	background-image: none;
	padding-left: 0;
}

nav#bread div ul li a {
	text-decoration: underline;
}

h1, h2, h3, h4, h5, h6 {
	line-height:1.5em;
}

h2 {
		font-weight: 500;
		font-size: 30px;
}

h3 {
	width:100%;
	background-color:#000;
		z-index:20;
}
h3 span {
	color:#FFF;
	display:block;
	height:140px;
	margin:0 auto;
	padding-top:25px;
	background-color:#000;
		font-weight: 500;
		font-size: 30px;
		line-height:150%;
}
h3 span p {
		font-weight: 400;
		font-size: 24px;
	}
@media (min-width: 768px) and (max-width: 979px) {
h3 span {
		padding-top:30px!important;
}
}
@media (max-width: 767px) {
h3 span {
	text-align:left;
	padding-top:30px!important;
}
}
@media (max-width: 479px) {
h3 span {
	text-align:center;
		padding-top:30px!important;
}
}

h3 span#molding {
		background-image:url(../images/h3_molding_bg.jpg);
		background-position: top right;
		background-repeat:no-repeat;
}

h4 {
		font-weight: 500;
		font-size: 24px;
  color: #333;
}

h5 {
		font-weight: 500;
		font-size: 18px;
  color: #666;
}

h5 a:hover {
    color: #71d759; }

h6 {
		font-weight: 500;
		font-size: 20px;
  color: #666;
}

h6 a:hover {
    color: #00d1f0; }


a {
  font: inherit;
  color: inherit;
  text-decoration: none;
  -moz-transition: 0.3s all ease;
  -o-transition: 0.3s all ease;
  -webkit-transition: 0.3s all ease;
  transition: 0.3s all ease; }

a:active {
    background: transparent; }

a[href^="tel:"] {
  color: inherit;
  text-decoration: none; }

sub {
	font-size:60%;
	font-weight:500;
	vertical-align:baseline;
}

/*=============    Support Classes    =================*/
.center {
  text-align: center; }

.t__right {
  text-align: right; }

.mg-add {
  margin-top: 5px; }

.mt {
  margin-top: 65px; }

.pad-r {
  padding-right: 50px; }

.oh {
  overflow: hidden; }

/*====================================================
                      Main Layout
======================================================*/
.page {
  overflow: hidden;
  min-height: 500px; }

.lt-ie9 .page {
    min-width: 1200px; }

h4 + .off1 {
  margin-top: 15px; }

h4 + .off2 {
  margin-top: 20px; }

h5 + .off1 {
  margin-top: 15px; }

h5 + .off2 {
  margin-top: 20px; }

p + .off1 {
  margin-top: 15px; }

p + .off2 {
  margin-top: 20px; }

h6 + .off1 {
  margin-top: 10px; }

p + h6 {
  margin-top: 40px; }

.lazy-img + .off1 {
  margin-top: 20px; }

.row + .off1 {
  margin-top: 30px; }

.row + .off2 {
  margin-top: 60px; }

.marked-list + .off1 {
  margin-top: 22px; }

.row + .off0 {
  margin-top: 0; 
}


/*========================================================
                     Components
=========================================================*/
/*========================   Menu   ==========================*/
.nav {
float: right;
z-index:30;
margin-bottom:10px;
}
.sf-menu > li.lang > a {
		background-color:#DDDDDD;
		color:#666;
		border: 1px solid #999;
		border-radius: 0;
		padding: 4px 8px;
}
.sf-menu > li.lang > a:hover {
		color:#777;
	    background-color: #eee;
}
.sf-menu > li.ask > a {
		background-color:#666;
		color:#FFF;
		font-weight:600;
}
.sf-menu > li.ask > a:hover {
		background-color:#F00000;
}

.sf-menu {
  display: inline-block;}
  .sf-menu:before, .sf-menu:after {
    display: table;
    content: "";
    line-height: 0; }
  .sf-menu:after {
    clear: both; }
  .sf-menu > li {
    position: relative;
    float: left; }
    .sf-menu > li + li {
      margin-left: 10px; }

@media (max-width: 767px) {
  .sf-menu {
    display: none; }
  .nav {
			margin-top:0;
    text-align: center;
    float: none;
				}
}

.sf-menu {
		font-weight: 400;
		font-size: 14px;
}
.sf-menu a { display: block; }

.sf-menu > li > a {
		color : #000; 
		padding:5px 10px;
		border-radius: 4px;
  -webkit-border-radius: 4px; 
  -moz-border-radius: 4px;
	background : #FFF;
}
.sf-menu > li.sfHover > a, .sf-menu > li > a:hover {
color : #FFF;
background : #999;
}
.sf-menu > li.active > a {
color : #FFF;
background : #999;
pointer-events:none;
}

.sf-menu ul {
  display: none;
  position: absolute;
  top: 100%;
  min-width: 180px;
  max-width: 180px;
  margin-top: 10px;
  text-align: center;
		font-weight: 400;
		font-size: 12px;
  background: #F00000;
  z-index: 40;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }
.sf-menu ul:before {
    content: '';
    position: absolute;
    top: -5px;
    left: 20%;
    margin-left: -5px;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 0 4.5px 5px 4.5px;
    border-color: transparent transparent #F00000 transparent; }
.sf-menu ul > li {
  position: relative; }
.sf-menu ul > li > a {
				font-size:110%;
    display: block;
    color: #fff;
    padding: 12px 5px; }
.sf-menu ul > li.sfHover > a, .sf-menu ul > li > a:hover {
	color: #ffffff;
	background: #CD0002;
}
/*.sf-menu ul > li + li {
    border-top: 1px solid #FFF; }
*/
.sf-menu ul ul {
	position: absolute;
	top: 0;
	left: 100%;
	margin-top: 0;
	padding: 0;
	background: #CD0002;
	z-index: 50;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
  .sf-menu ul ul:before {
    display: none; }

.sf-menu ul ul > li > a {
		font-size:100%;
		color: #ffffff;
}
.sf-menu ul ul > li.sfHover > a, .sf-menu ul ul > li > a:hover {
	background-color: #B90001;
	}
.sf-menu ul ul > li + li {
	}

/*
		.sf-menu > li > .sf-with-ul {
		position: relative; }
		.sf-menu > li > .sf-with-ul:before {
  position: absolute;
  left: 50%;
  top: 100%;
  margin-left: -6px;
  content: '\f0d7';
  font: 400 12px/12px 'FontAwesome'; }
*/

@media (min-width: 768px) and (max-width: 979px) {
  .sf-menu > li + li {
    margin-left: 10px; } 
}
/*==================  Select Menu  ======================*/
.select-menu {
  position: relative;
  display: none;
  margin: 0 auto;
  width: 420px;
  background: white url("data:image/png;base64,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") no-repeat right center;
  overflow: hidden; }
  .select-menu .select {
    width: 440px;
    height: 30px;
    color: #585858;
    background-color: transparent;
				font-weight: 400;
				font-size: 14px;
    line-height: 30px;
    border: none;
    border-radius: 0;
    box-shadow: none;
    outline: none;
    -webkit-appearance: none; }
    .select-menu .select::-ms-expand {
      display: none; }
  @media (max-width: 767px) {
    .select-menu {
      display: block; } }
  @media (max-width: 479px) {
    .select-menu {
      width: 270px; }
      .select-menu .select {
        width: 290px; } }

/*==================  Stuck menu  ======================*/
.isStuck {
	background-color: #DDD;
	padding: 15px 0;
  z-index: 999; }

@media only screen and (max-width: 979px) {
  .isStuck {
    display: none !important; } }
/*==================   Lazy Img    ======================*/
/*lazy-img {
  display: block;
  position: relative;
  height: 0;
  overflow: hidden;
  background: white url(../images/lazy-loader.gif) no-repeat center center; }
  .lazy-img img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: auto;
    z-index: 0;
    -moz-transition: 1s all ease;
    -o-transition: 1s all ease;
    -webkit-transition: 1s all ease;
    transition: 1s all ease;
    opacity: 0; }
    .lt-ie9 .lazy-img img {
      -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
      filter: alpha(opacity=0); }
  .lazy-img .lazy-loaded {
    opacity: 1; }
    .lt-ie9 .lazy-img .lazy-loaded {
      -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=1)";
      filter: alpha(opacity=100); }
*/
/*==================   Tumbnail    ======================*/
.thumb {
  display: block;
  position: relative;
  overflow: hidden; }
  .thumb img {
    -moz-transition: 0.5s all ease;
    -o-transition: 0.5s all ease;
    -webkit-transition: 0.5s all ease;
    transition: 0.5s all ease; }
  .thumb_overlay {
    position: absolute;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 0;
    -moz-transition: 0.3s all ease;
    -o-transition: 0.3s all ease;
    -webkit-transition: 0.3s all ease;
    transition: 0.3s all ease;
    background-color: white;
    color: black; }
    .lt-ie9 .thumb_overlay {
      -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
      filter: alpha(opacity=0); }
    .thumb_overlay:before {
      content: "\f065";
      position: absolute;
      top: 50%;
      left: 0;
      right: 0;
      font: 400 20px "FontAwesome";
      line-height: 20px;
      margin-top: -10px;
      text-align: center; }
      .lt-ie9 .thumb_overlay:before {
        display: none; }
  .thumb:hover {
    background-image: none; }
    .thumb:hover .thumb_overlay {
      opacity: 0.5; }
      .lt-ie9 .thumb:hover .thumb_overlay {
        -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0.5)";
        filter: alpha(opacity=50); }
      .lt-ie9 .thumb:hover .thumb_overlay:before {
        display: block; }
    .thumb:hover img {
      -moz-transform: scale(1.2);
      -ms-transform: scale(1.2);
      -o-transform: scale(1.2);
      -webkit-transform: scale(1.2);
      transform: scale(1.2); }

/*==================     ToTop     ======================*/
.toTop {
  width: 50px;
  height: 50px;
  font-size: 12px;
  line-height: 65px;
  color: #fff;
  background: #F00000;
		background-image:url(../images/top.png);
		background-position: 0 0;
  position: fixed;
  right: 66px;
  bottom: 180px;
  border-radius: 50%;
  display: none;
  overflow: hidden;
  text-align: center;
  text-decoration: none;
  z-index: 100; }
  .toTop:hover {
  color: #fff;
  background: #CD0002;
		background-image:url(../images/top.png);
		background-position: 0 0;
  text-decoration: none; }

@media only screen and (max-width: 1399px) {
  .toTop {
    display: none !important; } }
/*==================   Parallax    ======================*/
.parallax {
  background-position: 50% 0;
  background-repeat: no-repeat; }
.mobile .parallax, .tablet .parallax {
    background-position: 50% 0 !important;
    background-size: cover; }

.parallax1 {
  background-image: url(../images/page-1_img04.jpg);
  padding: 92px 0 123px;
		background-size: cover;
  color: #fff; }
  .parallax1 .container {
    padding-right: 680px; }
    @media (min-width: 980px) and (max-width: 1199px) {
      .parallax1 .container {
        padding-right: 600px; } }
    @media (min-width: 768px) and (max-width: 979px) {
      .parallax1 .container {
        padding-right: 200px; } }
    @media (max-width: 767px) {
      .parallax1 .container {
        padding-right: 0; } }
  .parallax1 h2, .parallax1 h3 {
    text-transform: uppercase; }
  .parallax1 h2 {
					font-weight: 500;
					font-size: 30px;
}
    .parallax1 h2 + h3 {
    margin-top: 14px; }
  .parallax1 h3 {
					font-weight: 500;
					font-size: 30px;
}
  .parallax1 h2 + p {
    margin-top: 20px; }
  .parallax1 p {
    font-size: 16px;
    line-height: 24px;
    color: #fff; }
  @media (max-width: 479px) {
    .parallax1 h2 {
      font-size: 25px;
      line-height: 44px; }
    .parallax1 p {
      color: #fff; } }

.parallax2 {
  background-image: url(../images/page-2_img02.jpg);
  padding: 69px 0;
  color: #ffffff; }
  .parallax2 h5, .parallax2 h4 {
    color: #ffffff; }

@media (max-width: 767px) {
  .parallax {
    background-position: 50% 0 !important;
    background-size: cover; } }
/*========================================================
                    HEADER Section
=========================================================*/
header {
	background-color: #DDD;
	width:100%;
	padding: 15px 0 0 0;
	position:fixed;
	z-index:10;
}
@media print {
header {	position: relative; }
.content {	margin-top:0!important; }
}

.header_panel:before, .header_panel:after {
    display: table;
    content: "";
    line-height: 0; }
.header_panel:after {
    clear: both; }
  @media (max-width: 767px) {
.header {
      text-align: center; } }

.nav {
  margin-top: 10px; }

/*==================     Brand     ======================*/
.brand {
  float: left;
		margin: 0;
	}
  @media (max-width: 767px) {
    .brand {
      float: none; } }

/*========================================================
                    CONTENT Section 
=========================================================*/
.content {
  background: white;
		margin-top:70px;
}
@media (min-width: 980px) and (max-width: 1199px) {
.content {
		margin-top:120px;
}
}
@media (min-width: 768px) and (max-width: 979px) {
.content {
		margin-top:120px;
}
}
@media (max-width: 767px) {
.content {
		margin-top:120px;
}
}
@media (max-width: 479px) {
.content {
		margin-top:120px;
}
}
.bg-content {
  background: #EEE;
}

/*==================      Well      ======================*/
.well {
  padding-top: 40px;
  padding-bottom: 40px; }

.well2 {
  padding-top: 50px;
  padding-bottom: 50px; }
  .well2__ins1 {
    padding-bottom: 76px; }

.well3 {
  padding-top: 40px;
  padding-bottom: 40px; }
  .well3__ins1 {
    padding-top: 40px; }

.well4 {
  padding-top: 70px;
  padding-bottom: 72px; }

/*==================      Box      ======================*/
.box {
  border: 1px solid #e8e8e8;
  padding: 39px 35px 43px 31px;
		font-weight: 400;
		font-size: 16px;
}
  .box_left {
    float: left;
    margin-right: 40px; }
  .box_right {
    float: right;
    margin-left: 40px; }
  .box h3 + p {
    margin-top: 5px; }
  .box p + .link {
    margin-top: 5px; }
  .box_cnt__no-flow {
    overflow: hidden; }
  .box:before, .box:after {
    display: table;
    content: "";
    line-height: 0; }
  .box:after {
    clear: both; }
  @media (min-width: 768px) and (max-width: 979px) {
    .box {
      padding: 20px; }
      .box_left {
        margin-right: 20px; }
      .box_right {
        margin-left: 20px; }
      .box h3 {
        font-size: 32px; } }
  @media (max-width: 479px) {
    .box_left, .box_right {
      float: none;
      margin: 0 0 15px; } }

.box_skin1 h3, .box_skin1 .link {
  color: #ff6156; }

.box_skin2 h3, .box_skin2 .link {
  color: #71d759; }

.box_skin3 h3, .box_skin3 .link {
  color: #f8b62b; }

.box_skin4 h3, .box_skin4 .link {
  color: #51d3a5; }

/*==================    table    ======================*/
th{
	width:70px;
	text-align:left;
	font-weight:bold;
}

/*==================    Buttons    ======================*/
.btn {
  display: inline-block;
  padding: 0.5em 2em;
		font-weight: 500;
		font-size: 14px;
  color: #ffffff;
		border-radius: 4px;
  -webkit-border-radius: 4px; 
  -moz-border-radius: 4px;
 }
.btn:hover {
    background: #CD0002; }

.btn_skin1 {
  background: #F00000; }

.btn_skin2 {
  background: #ff6156; }

.btn2_wr {
  display: table;
  margin-right: 79px; }

.btn2 {
  display: table-cell;
  vertical-align: middle;
  width: 118px;
  height: 118px;
  text-align: center;
		font-weight: 500;
		font-size: 16px;
  color: #ffffff;
  background: #00d1f0;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  border-radius: 50%;
  text-transform: uppercase; }
  .btn2:hover {
    background: #ff6156; }

.banner2_btn {
  display: inline-block;
  padding: 11.5px 25px 11.5px 28px;
  text-transform: uppercase;
		font-weight: 500;
		font-size: 14px;
  color: #3e3d44;
  background: #fff; }
  .banner2_btn:hover {
    background: #71d759;
    color: #ffffff; }

/*==================  Banner  ======================*/
.banner1 {
  background: #71d759;
  color: #ffffff;
  padding: 60px 0 62px; }
  .banner1 h2 {
    float: left;
    margin-top: 8px; }
  .banner1 .btn2_wr {
    float: right; }
  @media (max-width: 1199px) {
    .banner1 {
      padding: 30px 0 32px; }
      .banner1 h2, .banner1 .btn2_wr {
        float: none; }
      .banner1 .btn2_wr {
        margin-top: 15px; } }

.banner2 {
  padding: 19px 25px 23px 29px;
  background: #ff6156;
  color: #ffffff;
  margin-top: 66px; }
  .banner2 img {
    float: left;
    margin-right: 13px; }
  .banner2_cnt {
    margin-top: 7px; }
    .banner2_cnt h2 {
      font: 300 54px/65px "Open Sans", sans-serif;
      text-transform: uppercase; }
      .banner2_cnt h2 + p {
        margin-top: 11px; }
    .banner2_cnt p {
      font-size: 16px;
      line-height: 24px; }
      .banner2_cnt p + .banner2_btn {
        margin-top: 20px; }
  .lt-ie9 .banner2_cnt h2 {
    font-size: 51px; }
  .banner2:before, .banner2:after {
    display: table;
    content: "";
    line-height: 0; }
  .banner2:after {
    clear: both; }
  @media (min-width: 768px) and (max-width: 979px), (max-width: 479px) {
    .banner2 {
      margin-top: 0;
      text-align: center;
      padding: 10px; }
      .banner2 img {
        float: none;
        margin-bottom: 10px; }
      .banner2_cnt h2 {
        font-size: 49px; } }
  @media (max-width: 479px) {
    .banner2_cnt h2 {
      font-size: 35px; } }

/*==================      Link     ======================*/
.link {
  position: relative;
  display: inline-block;
  text-transform: uppercase; }
  .link:after {
    content: '＞';
    display: inline-block;
    margin-left: 8px;
				font-weight: 400;
    font-size: 12px; }
  .link:hover {
    color: #F00000; }

.link1 {
  font-size: 14px; }

.link2 {
		font-weight: 400;
		font-size: 14px;
  color: #5c5c5c; }
  .link2:after {
    color: #b7b7b7;
    -moz-transition: 0.3s all ease;
    -o-transition: 0.3s all ease;
    -webkit-transition: 0.3s all ease;
    transition: 0.3s all ease; }
  .link2:hover:after {
    color: #F00000; }

/*==================  Member box  ======================*/
.member-box h5 {
  font-size: 20px;
  font-weight: 300; }
.member-box .lazy-img + h5 {
  margin-top: 23px; }
.member-box h5 + p {
  margin-top: 9px; }
.member-box a:hover {
  color: #f8b62b; }

/*==================  Marked List  ======================*/
.marked-list li {
  position: relative;
  padding-left: 20px;
  color: #00d1f0;
  text-transform: uppercase; }
  .marked-list li:before {
    content: '\f138';
    position: absolute;
    left: 0;
    top: 0;
    line-height: 22px;
    font-size: 12px;
    color: #b7b7b7; }
  .marked-list li + li {
    margin-top: 8px; }
.marked-list a:hover {
  text-decoration: underline; }

/*==================  Price List  ======================*/
.price-list {
  text-transform: uppercase;
  color: #3e3d44; }
  .price-list li {
    position: relative;
    padding-right: 60px; }
    .price-list li + li {
      margin-top: 8px; }
  .price-list a {
    display: inline-block; }
    .price-list a:hover {
      color: #00d1f0; }
  .price-list .price {
    position: absolute;
    right: 0;
    top: 0; }

.various {
  position: relative;
  display: block;
  height: 100%; }
  .various .video-icon {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    text-align: center;
    font-size: 60px;
    line-height: 60px;
    margin-top: -30px;
    color: #000;
    -moz-transition: 0.3s all ease;
    -o-transition: 0.3s all ease;
    -webkit-transition: 0.3s all ease;
    transition: 0.3s all ease; }
    .various .video-icon:before {
      content: '▶';
     opacity: 0.8; }
  .various:hover .video-icon {
    opacity: 0.4; }
    .lt-ie9 .various:hover .video-icon {
      -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0.4)";
      filter: alpha(opacity=40); }
  .various + h5 {
    margin-top: 22px; }

/*==================    Map    ======================*/
.map {
width: 100%;
  height: 286px; }
  .map iframe,
  .map2 iframe,
  .map3 iframe {
  width: 100%;
  height: 100%;
  }
  .map img {
    max-width: none !important; }
  @media (max-width: 767px) {
    .map {
      height: 250px; } }
  @media (max-width: 479px) {
    .map {
      height: 200px; } }

.map2 {
width: 100%;
  height: 324px; }
  .map2 img {
    max-width: none !important; }
  @media (max-width: 767px) {
    .map2 {
      height: 250px; } }
  @media (max-width: 479px) {
    .map2 {
      height: 200px; } }

/*add 20150831*/
.map3 {
width: 100%;
  height: 280px; }
  .map3 img {
    max-width: none !important; }
  @media (min-width: 980px) and (max-width: 1199px) {
    .map3 {
      height: 230px; } }
  @media (min-width: 768px) and (max-width: 979px) {
    .map3 {
      height: 182px; } }

/*==================    Address    ======================*/
address {
  margin: 29px 0 79px; }
  address .addr, address .phone, address .mail {
    position: relative;
    padding-left: 60px;
    margin-top: 21px; }
    address .addr:before, address .phone:before, address .mail:before {
      position: absolute;
      left: 0;
      top: 5px;
      font-size: 50px;
							font-weight: 400;
}
  address .addr:before {
    color: #ff6156;
    content: '\f015'; }
  address .phone:before {
    color: #71d759;
    content: '\f095'; }
  address .mail {
    color: #00d1f0; }
    address .mail a:hover {
      text-decoration: underline; }
    address .mail:before {
      color: #00d1f0;
      content: '\f0e0'; }

.policy-box h6 {
  font-weight: 500; }
.policy-box + .policy-box {
  margin-top: 22px; }

.policy-link {
  margin-top: 20px;
  color: #00d1f0; }
  .policy-link a:hover {
    color: #71d759; }

/*========================================================
                     FOOTER Section
=========================================================*/
.footer {
  padding: 40px 0;
  text-align: center;
		background-color:#DDD;
	}
  .footer .social-list + .footer-menu {
    margin-top: 40px; }
  .footer .footer-menu + .copyright {
    margin-top: 40px; }
  .footer.page2 {
    border-top: 1px solid #d6d6d6; }
  @media (max-width: 767px) {
    .footer .footer-menu {
      display: none; } }

/*==================     Social list     ======================*/
.social-list li {
  display: inline-block;
  margin: 0 8px; }
  .social-list li a {
    display: inline-block;
    width: 49px;
    height: 49px;
    line-height: 49px;
    text-align: center;
    color: #ffffff;
    font-size: 16px;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%; }
    .social-list li a.fa-linkedin {
      background: #88d0e1; }
    .social-list li a.fa-google-plus {
      background: #ff8a8e; }
    .social-list li a.fa-facebook {
      background: #6982b8; }
    .social-list li a.fa-rss {
      background: #f6cf71; }
    .social-list li a:hover {
      background: #71d759; }
@media (max-width: 479px) {
  .social-list li {
    margin: 0 6px; } }

/*==================     Footer menu     ======================*/
.footer-menu li {
  display: inline-block;
		font-weight: 400;
		font-size: 14px;
  color: #4d4d4d;
  margin: 0 22px; }
  .footer-menu li a:hover, .footer-menu li.active a {
    color: #F00000; }

.foot-logo {
	margin:10px;
}
.copyright {
		font-weight: 400;
		font-size: 12px;
  color: #575757;
  text-transform: uppercase; }
  .copyright .divid {
    display: inline-block;
    width: 1px;
    height: 30px;
    background: #dddddd;
    margin: -5px 5px 0; }
  .copyright a:hover {
    text-decoration: underline; }

dl.news dt {
	clear:both;
	float:left;
}
dl.news dd {
	margin-left:10em;
}
@media (max-width: 767px) {
dl.news dt {
	float:none;
}
dl.news dd {
	margin-left:0;
	margin-bottom:0.8em;
}
}
@media (max-width: 479px) {
dl.news dt {
	float:none;
}
dl.news dd {
	margin-left:0;
	margin-bottom:0.8em;
}
}


.button {
	display: inline-block;
	width: 100%;
	height: 60px;
	text-align: center;
	text-decoration: none;
	line-height: 54px;
	outline: none;
	font-weight: 400;
	font-size: 16px;
	cursor:pointer;
}
.button::before,
.button::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.button,
.button::before,
.button::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}

.button {
	background-color: #666;
	color: #fff;
	border-radius: 6px;
}
.button:hover {
	background-color: #F00000;
}

ul.link_b {
	width: 100%;
}
ul.link_b li {
	float:left;
	margin-right:2%;
}
ul.link_b li:last-child {
	margin-right:0;
}
ul.w1 li {
	width: 50%;
	float:none;
	margin: 0 25%;
}
ul.w2 li {
	width: 48%;
}
ul.w3 li {
	width: 32%;
}
ul.w4 li {
	width: 23%;
}

ul.dotted li:before {
content:"・";
}
ul.dotted li {
margin-bottom:8px;
}

@media (max-width: 767px) {
ul.link_b li {
	width: 100%;
	margin-bottom:10px;
}
ul.link_b li:last-child {
	margin-bottom:0;
}
ul.w1 li {
	margin: 0;
}
}
@media (max-width: 479px) {
ul.link_b li {
	width: 100%;
	margin-bottom:10px;
}
ul.link_b li:last-child {
	margin-bottom:0;
}
}



/*ご挨拶*/

.sign {
	font-size:1.2em;
	font-weight:600;
	text-align:center;
	margin-top:30px;
	color:#333;
}

/*タブ切り替え*/
.hide {
	display:none;
}

/*ADD_Style*/
div.bottom_con{
	padding-bottom:80px;
}

a.button_selected{
	background-color: #F00000;
}

div.button_selected{
	background-color: #F00000;
}

.c1h6{
	margin-top:15px;
}

.header_fixer{
	padding-top:85px;
	margin-top:-85px;
}

@media (min-width: 768px) and (max-width: 1199px){
	.header_fixer{
		padding-top:139px;
		margin-top:-139px;
	}
}

@media (max-width: 767px) {
	.header_fixer{
		padding-top:135px;
		margin-top:-135px;
	}
}

.img_test{
	width: 100%;
    height: auto;
    z-index: 0;
}

.banner_wrapper{
	width:200px;
	height:53px;
	padding-bottom:40px;
	margin:0px auto;
}

.ISO {
text-align: center;
}
.ISO img {
	width:100%;
	margin-bottom:15px;
}

		#env-policy h6 {
			display:inline-block;
			border-bottom:2px solid #999;
			padding:8px 20px;
		}
		#env-policy {
			width:100%;
			text-align:center;
			margin:0 auto;
			position: relative;
			padding:0;
			min-height:300px;
			overflow:visible;
		}
		#env-policy:after {
			display:block;
			background-color: #EEE;
			position: absolute;
			right: 30px;
			bottom: 20px;
			content: ' ';
			width: 400px;
			max-width:70%;
			height:100px;
			box-shadow: -20px 20px 20px rgba(0,0,0,.5);
			-webkit-transform: rotate(3deg);
			transform: rotate(3deg);
			z-index:1;
		}
		
		
		.fold {
			min-height:300px;
			position:relative;
			width:100%;
			padding:30px 5% 50px 5%;
			margin:0;
			overflow:hidden;
			box-sizing:border-box;
			background-color: #EEE;
			z-index:2;
}
 
.fold:after {
			content:"";
			position:absolute;
			bottom:0;
			right:0;
			border-width:16px 16px 16px 16px;
			border-style:solid;
			border-color:#CCC #FFF #FFF #CCC;
			display:block;
			width:0;
			box-shadow:0 3px 3px rgba(0,0,0,0.3), -3px 3px 3px rgba(0,0,0,0.2);
			z-index:3;
}

.env-frame {
	text-align:left;
	border:1px solid #999;
	background:#FFF;
	padding:40px 10%;
	margin-top:30px;
	box-sizing:border-box;
	line-height:1.8;
}

.env-frame ol li {
	list-style-type:decimal;
	margin-bottom:20px;
}
.env-frame ol li:last-child {
	margin-bottom:0;
}

table.product {
	width:100%;
	margin:20px 0;
	border-collapse:collapse;
}
table.product caption {
	margin:0 0 15px 0;
	font-size:120%;
	font-weight:600;
	text-align:left;
}

table.product th,
table.product td {
	border:1px solid #666;
	padding:5px 8px;
	vertical-align:middle;
}

table.product th {
	width:70%;
}

table.product thead {
	text-align:center;
	background:#EEE;
}


#product {
	overflow:hidden;
}
#product h4 + h6 {
	margin-top:30px;
}
#product h6 {
		font-weight: 500;
		font-size: 20px;
		color: #000;
		border-bottom:2px solid #C00;
		padding:0 0 5px 5px;
		margin:0 0 15px 0;
}

#product .mg-add {
	padding:5px;
}
#product .mg-add img {
	border:1px solid #CCC !important;
}
#product ul {
	margin:5px 5px 20px 5px;
	color:#000;
}
#product ul li {
	line-height:1.4;
	padding:5px;
	border-bottom:1px dotted #999;
}
#product ul li:nth-child(1) {
	font-weight:600;
}
#product ul li:nth-child(2) {
	padding-left:6em;
}
#product ul li:nth-child(2):before {
	content:"材質";
	font-weight:600;
	display:inline-block;
	width:6em;
	margin-left:-6em;
	padding-left:5px;
	box-sizing:border-box;
}
#product ul li:nth-child(3) {
	padding-left:6em;
}
#product ul li:nth-child(3):before {
	content:"単重（kg）";
	font-weight:600;
	display:inline-block;
	width:6em;
	margin-left:-6em;
	padding-left:5px;
	box-sizing:border-box;
}

#product .grid_3:nth-child(4n+1) {
	clear:both;
}

.well3 + .well3 {
	padding-top:0;
}