@charset "utf-8";

@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:400,700&display=swap&subset=japanese');
@import url('https://fonts.googleapis.com/css?family=Barlow:400,700&display=swap');

html, 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, 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%;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	vertical-align: baseline;
	background: transparent;
}
span {
	font-size: inherit;
	font-family: inherit;
	font-weight: inherit;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}	
ol,ul {
	list-style: none;
}


/*　　基本設定
-------------------------------------------------------*/
html {
	font-size: 62.5%;
	height: 100%;
}
* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
body {
	position: relative;
	height: 100%;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 400;
	font-size: 14px; font-size: 1.4rem;
	line-height: 1.7;
	color: #333;
	-webkit-text-size-adjust: 100%;
}
.ff-en {
	font-family: 'Barlow', sans-serif;
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
a {
	color: #21b6c2;
	text-decoration: none;
}
a:hover {
	color: #0b9da9;
	text-decoration: none;
}
a.txt-link {
    color: #333;
}
a.txt-link:hover {
	color: #0b9da9;
	text-decoration: none;
}
.imgLink:hover img {
	filter: alpha(opacity=70);
	-ms-filter: "alpha( opacity=70 )";
	opacity:0.7;
}
.img-scale {
	overflow: hidden;
}
.img-scale img {
	transition: transform 0.1s linear;
}
.img-scale img:hover {
    opacity: 0.8;
	transform: scale(1.05);
}
.clearfix:after {
	content: ".";
	clear: both;
	display: block;
	visibility: hidden;
	height: 0;
	font-size: 0;
	line-height: 0;	
}
/* IS IE */
.clearfix {
 *display: inline-block;
 *zoom: 1;
}
.pc { display: block !important;}
.pc2 { display: inline-block !important;}
.tb,
.tb2 { display: none !important;}
.sp,
.sp2 { display: none !important;}
.pc-tb { display: block !important;}
.tb-sp { display: none !important;}

@media screen and (min-width: 768px) and (max-width: 1023px){
body { font-size: 14px; font-size: 1.4rem;}
.pc { display: none !important;}
.tb { display: block !important;}
.tb2 { display: inline-block !important;}
.sp,
.sp2 { display: none !important;}
.pc-tb { display: block !important;}
.tb-sp { display: block !important;}
}

@media screen and (max-width: 767px){
body { font-size: 14px; font-size: 1.4rem;}
body.toppage {
	background-image: none;
}
.pc { display: none !important;}
.tb,
.tb2 { display: none !important;}
.sp { display: block !important;}
.sp2 { display: inline-block !important;}
.pc-tb { display: none !important;}
.tb-sp { display: block !important;}
}

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





/*　　枠組み
-------------------------------------------------------*/
.wrapper1 {
	max-width: 980px;
	margin-right: auto;
	margin-left: auto;
}
.wrapper-table {
	overflow: auto;
}
.wrapper-flex-row {
	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
	-webkit-box-orient: horizontal;
  	-webkit-box-direction: normal;
  	-ms-flex-direction: row;
  	flex-direction: row;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.flex1 {
	flex: 1;
}
.fd-row {
  	-webkit-box-orient: horizontal;
  	-webkit-box-direction: normal;
  	-ms-flex-direction: row;
  	flex-direction: row;
}
.fd-reverse {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}
.fd-column {
  	-webkit-box-orient: vertical;
  	-webkit-box-direction: normal;
  	-ms-flex-direction: column;
  	flex-direction: column;
}
.fd-column-reverse {
  	-webkit-box-orient: vertical;
  	-webkit-box-direction: reverse;
  	-ms-flex-direction: column-reverse;
  	flex-direction: column-reverse;
}
.fw-wrap {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.fw-nowrap {
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
}
.fw-wrap-reverse {
	-ms-flex-wrap: wrap-reverse;
	flex-wrap: wrap-reverse;
}
.jc-start {
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}
.jc-between {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
.jc-center {
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
.jc-end {
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
}
.jc-space-around {
	-ms-flex-pack: distribute;
	justify-content: space-around;
}
.ai-baseline {
	-webkit-box-align: baseline;
	-ms-flex-align: baseline;
	align-items: baseline;
}
.ai-center {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
.ai-stretch {
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
.ai-start {
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}
.ai-end {
	-webkit-box-align: end;
	-ms-flex-align: end;
	align-items: flex-end;
}
.as-auto {
	-ms-flex-item-align:auto;
	align-self: auto;
}
.as-start {
	-ms-flex-item-align: start;
	align-self: flex-start;
}
.as-end {
	-ms-flex-item-align: end;
	align-self: flex-end;
}
.as-center {
	-ms-flex-item-align: center;
	align-self: center;
}
.as-baseline {
	-ms-flex-item-align: baseline;
	align-self: baseline;
}
.as-stretch {
	-ms-flex-item-align: stretch;
	align-self: stretch;
}
.wrapper-flex-row > .cnt-row2 {
    width: 470px;
	margin-right: 40px;
}
.wrapper-flex-row > .cnt-row2:nth-child(even) {
	margin-right: 0;
}
.fd-reverse > .cnt-row2 {
	margin-right: 0;
}
.fd-reverse > .cnt-row2:nth-child(even) {
	margin-right: 40px;
}
.wrapper-flex-row > .cnt-row2-full {
	width: 50%;
}
.wrapper-flex-row .cnt-row2-detergentlist {
	width: 470px;
}
.wrapper-flex-row > .cnt-row3,
.wrapper-flex-row > .cnt-row3-sp-row2 {
	width: 310px;
	margin-right: 25px;
}
.wrapper-flex-row > .cnt-row3:nth-child(3n),
.wrapper-flex-row > .cnt-row3-sp-row2:nth-child(3n) {
	margin-right: 0;
}
.fd-reverse > .cnt-row3 {
	margin-right: 0;
	margin-left: 25px;
}
.fd-reverse > .cnt-row3:nth-child(3n) {
	margin-left: 0;
}

@media screen and (min-width: 768px) and (max-width: 1023px){
.wrapper1 {
	max-width: auto;
	margin-left: 23px;
	margin-right: 23px;
	padding: 0;
}
.wrapper1 > .full {
	width: auto !important;
	margin-left: -23px !important;
	margin-right: -23px !important;
}
.tb-flex1 {
	flex: 1;
}
.tb-fd-row {
  	-webkit-box-orient: horizontal;
  	-webkit-box-direction: normal;
  	-ms-flex-direction: row;
  	flex-direction: row;
}
.tb-fd-reverse {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}
.tb-fd-column {
  	-webkit-box-orient: vertical;
  	-webkit-box-direction: normal;
  	-ms-flex-direction: column;
  	flex-direction: column;
}
.tb-fd-column-reverse {
  	-webkit-box-orient: vertical;
  	-webkit-box-direction: reverse;
  	-ms-flex-direction: column-reverse;
  	flex-direction: column-reverse;
}
.tb-fw-wrap {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.tb-fw-nowrap {
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
}
.tb-fw-wrap-reverse {
	-ms-flex-wrap: wrap-reverse;
	flex-wrap: wrap-reverse;
}
.tb-jc-start {
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}
.tb-jc-between {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
.tb-jc-center {
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
.tb-jc-end {
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
}
.tb-jc-space-around {
	-ms-flex-pack: distribute;
	justify-content: space-around;
}
.tb-ai-baseline {
	-webkit-box-align: baseline;
	-ms-flex-align: baseline;
	align-items: baseline;
}
.tb-ai-center {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
.tb-ai-stretch {
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
.tb-ai-start {
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}
.tb-ai-end {
	-webkit-box-align: end;
	-ms-flex-align: end;
	align-items: flex-end;
}
.tb-as-auto {
	-ms-flex-item-align:auto;
	align-self: auto;
}
.tb-as-start {
	-ms-flex-item-align: start;
	align-self: flex-start;
}
.tb-as-end {
	-ms-flex-item-align: end;
	align-self: flex-end;
}
.tb-as-center {
	-ms-flex-item-align: center;
	align-self: center;
}
.tb-as-baseline {
	-ms-flex-item-align: baseline;
	align-self: baseline;
}
.tb-as-stretch {
	-ms-flex-item-align: stretch;
	align-self: stretch;
}
.wrapper-flex-row > .cnt-row2 {
    width: 47.95%;
	margin-right: 4.08%;
}
.wrapper-flex-row > .cnt-row2:nth-child(even) {
	margin-right: 0;
}
.wrapper-flex-row > .cnt-row2-full {
	width: 50%;
}
.fd-reverse > .cnt-row2 {
	margin-right: 0;
}
.fd-reverse > .cnt-row2:nth-child(even) {
	margin-right: 4.08%;
}
.wrapper-flex-row .cnt-row2-detergentlist {
	width: 47.95%;
}
.wrapper-flex-row > .cnt-row3,
.wrapper-flex-row > .cnt-row3-sp-row2 {
    width: 31.63%;
	margin-right: 2.55%;
}
.wrapper-flex-row > .cnt-row3:nth-child(3n),
.wrapper-flex-row > .cnt-row3-sp-row2:nth-child(3n) {
	margin-right: 0;
}
.fd-reverse > .cnt-row3 {
	margin-right: 0;
	margin-left: 2.55%;
}
.fd-reverse > .cnt-row3:nth-child(3n) {
	margin-left: 0;
}
.tb-fd-column > .cnt-row2,
.tb-fd-column > .cnt-row2-full,
.tb-fd-column > .cnt-row3 {
	width: auto;
	margin-left: 0 !important;
	margin-right: 0 !important;
}
}

@media screen and (max-width: 767px){
.wrapper1 {
	max-width: auto;
	margin-left: 12px;
	margin-right: 12px;
	padding: 0;
}
.wrapper1 > .full {
	width: auto !important;
	margin-left: -12px !important;
	margin-right: -12px !important;
}
.sp-flex1 {
	flex: 1;
}
.sp-fd-row {
  	-webkit-box-orient: horizontal;
  	-webkit-box-direction: normal;
  	-ms-flex-direction: row;
  	flex-direction: row;
}
.sp-fd-reverse {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}
.sp-fd-column {
  	-webkit-box-orient: vertical;
  	-webkit-box-direction: normal;
  	-ms-flex-direction: column;
  	flex-direction: column;
}
.sp-fd-column-reverse {
  	-webkit-box-orient: vertical;
  	-webkit-box-direction: reverse;
  	-ms-flex-direction: column-reverse;
  	flex-direction: column-reverse;
}
.sp-fw-wrap {
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.sp-fw-nowrap {
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
}
.sp-fw-wrap-reverse {
	-ms-flex-wrap: wrap-reverse;
	flex-wrap: wrap-reverse;
}
.sp-jc-start {
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}
.sp-jc-between {
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
.sp-jc-center {
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}
.sp-jc-end {
	-webkit-box-pack: end;
	-ms-flex-pack: end;
	justify-content: flex-end;
}
.sp-jc-space-around {
	-ms-flex-pack: distribute;
	justify-content: space-around;
}
.sp-ai-baseline {
	-webkit-box-align: baseline;
	-ms-flex-align: baseline;
	align-items: baseline;
}
.sp-ai-center {
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
.sp-ai-stretch {
	-webkit-box-align: stretch;
	-ms-flex-align: stretch;
	align-items: stretch;
}
.sp-ai-start {
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}
.sp-ai-end {
	-webkit-box-align: end;
	-ms-flex-align: end;
	align-items: flex-end;
}
.sp-as-auto {
	-ms-flex-item-align:auto;
	align-self: auto;
}
.sp-as-start {
	-ms-flex-item-align: start;
	align-self: flex-start;
}
.sp-as-end {
	-ms-flex-item-align: end;
	align-self: flex-end;
}
.sp-as-center {
	-ms-flex-item-align: center;
	align-self: center;
}
.sp-as-baseline {
	-ms-flex-item-align: baseline;
	align-self: baseline;
}
.sp-as-stretch {
	-ms-flex-item-align: stretch;
	align-self: stretch;
}
.wrapper-flex-row > .cnt-row2 {
    width: 47.95%;
	margin-right: 4.08%;
}
.wrapper-flex-row > .cnt-row2:nth-child(even) {
	margin-right: 0;
}
.wrapper-flex-row > .cnt-row2-full {
	width: 50%;
}
.fd-reverse > .cnt-row2 {
	margin-right: 0;
}
.fd-reverse > .cnt-row2:nth-child(even) {
	margin-right: 4.08%;
}
.wrapper-flex-row > .cnt-row3-sp-row2 {
    width: 47.95%;
	margin-right: 4.08%;
}
.wrapper-flex-row > .cnt-row3-sp-row2:nth-child(odd) {
    margin-right: 4.08%;
}
.wrapper-flex-row > .cnt-row3-sp-row2:nth-child(even) {
	margin-right: 0;
}
.wrapper-flex-row > .cnt-row3 {
    width: 31.63%;
	margin-right: 2.55%;
}
.wrapper-flex-row > .cnt-row3:nth-child(3n) {
	margin-right: 0;
}
.fd-reverse > .cnt-row3 {
	margin-right: 0;
	margin-left: 2.55%;
}
.fd-reverse > .cnt-row3:nth-child(3n) {
	margin-left: 0;
}
.sp-fd-column > .cnt-row2,
.sp-fd-column > .cnt-row2-full,
.sp-fd-column > .cnt-row3 {
	width: auto;
	margin-left: 0 !important;
	margin-right: 0 !important;
}
}

@media screen and (max-width: 767px) and (orientation : landscape) {
.wrapper1 {
	max-width: 90%;
	margin-left: auto;
	margin-right: auto;
	padding: 0;
}
}



/*　　ヘッダー
-------------------------------------------------------*/
#header {
    position: relative;
	border-top: 6px solid #21b6c2;
}
#header.toppage-bg {
    background-image: url("../images/page/t_header_bg.jpg");
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}
#header.page-products-bg {
    height: 374px;
    background-image: url("../images/page/page_products.jpg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
#header.page-company-bg {
    height: 374px;
    background-image: url("../images/page/page_company.jpg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
#header.page-contact-bg {
    height: 374px;
    background-image: url("../images/page/page_contact.jpg");
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}
#header .wrapper-logo {
	width: 300px;
}
#header .wrapper-logo .tagline {
	margin: 25px 0 10px;
	font-size: 12px; font-size: 1.2rem;
    text-align: center;
}
.globalNav {
	width: 450px;
	margin-top: -6px;
}
.globalNav ul li {
    width: 146px;
}
.header-txt-img {
    margin: 65px 0 45px;
}
.top-header-tel-box {
    margin-top: 35px;
    background: linear-gradient(to right, transparent 60%, #fff 60%);
}
.top-header-tel-bg {
    padding: 15px 0 5px 120px;
    background-image: url("../images/page/t_header_tel_bg.png");
    background-repeat: no-repeat;
    background-position: left top;
}
.top-header-tel {
    margin-left: 40px;
    font-size: 28px; font-size: 2.8rem;
    font-weight: 700;
}
.pagetitle-products-box {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 82px;
    padding-top: 20px;
    background-color: rgba(51,51,51,0.4);
}
.pagetitle-company-box {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 82px;
    padding-top: 20px;
    background-color: rgba(51,51,51,0.3);
}
.pagetitle-contact-box {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 82px;
    padding-top: 20px;
    background-color: rgba(51,51,51,0.3);
}
.pagetitle-txt-jp {
    padding: 0 30px 0 0;
    font-size: 26px; font-size: 2.6rem;
    font-weight: 700;
    color: #fff;
    border-right: 1px solid #ccc;
}
.pagetitle-txt-en {
    padding: 4px 0 0 30px;
    font-size: 20px; font-size: 2.0rem;
    font-weight: 700;
    color: #fff;
}
.page-header-tel-box {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    margin-top: 35px;
    background: linear-gradient(to right, transparent 60%, #fff 60%);
}
.page-header-tel-bg {
    padding: 15px 0 5px 120px;
    background-image: url("../images/page/t_header_tel_bg.png");
    background-repeat: no-repeat;
    background-position: left top;
}
.page-header-tel {
    margin-left: 40px;
    font-size: 28px; font-size: 2.8rem;
    font-weight: 700;
}
.globalNav-sp2 {
	display: none;
}

@media screen and (min-width: 768px) and (max-width: 1023px){
#header.pagetitle-bg {
    height: 280px;
}
#header .wrapper-logo .tagline {
	margin: 10px 0 10px;
	font-size: 10px; font-size: 1.0rem;
}
#header.page-products-bg,
#header.page-company-bg,
#header.page-contact-bg {
    height: 280px;
}
.globalNav {
	width: 350px;
	margin-top: -6px;
}
.globalNav ul li {
	width: 32%;
}
.header-txt-img {
    margin: 45px 60px 35px;
}
.top-header-tel-bg {
    padding: 15px 0 5px 110px;
}
.top-header-tel {
    margin-left: 30px;
    font-size: 24px; font-size: 2.4rem;
    font-weight: 700;
}
.pagetitle-products-box,
.pagetitle-company-box,
.pagetitle-contact-box {
    padding-top: 24px;
}
.pagetitle-txt-jp {
    font-size: 20px; font-size: 2.0rem;
}
.pagetitle-txt-en {
    padding: 2px 0 0 30px;
    font-size: 18px; font-size: 1.8rem;
}
.page-header-tel-bg {
    padding: 15px 0 5px 110px;
}
.page-header-tel {
    margin-left: 30px;
    font-size: 24px; font-size: 2.4rem;
    font-weight: 700;
}
}

@media screen and (max-width: 767px){
#header.toppage-bg,
#header.page-products-bg,
#header.page-company-bg,
#header.page-contact-bg {
    height: auto;
    background-image: none;
}

#header .wrapper-logo {
	width: auto;
	text-align: center;
}
#header .wrapper-logo img {
    width: 280px;
}
#header .wrapper-logo .tagline {
	margin: 10px 0 10px;
}
.header-tel-sp {
    font-size: 24px; font-size: 2.4rem;
    text-align: center;
}
.header-tel-sp a {
	display: block;
	margin-top: 15px;
	padding: 10px;
    line-height: 1;
	border: 1px solid #21b6c2;
    background-color: #fff;
}
.header-tel-sp a:hover {
	background-color: #e6fdff;
}
.header-txt-img {
    display: none;
}
.top-header-tel-box,
.page-header-tel-box {
    display: none;
}
.pagetitle-products-box {
    position: relative;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 120px;
    padding-top: 86px;
    background-color: #e4e4e4;
    background-image: url("../images/page/page_products.jpg");
	background-repeat: no-repeat;
	background-position: top;
	background-size: auto 80px;
}
.pagetitle-company-box {
    position: relative;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 120px;
    padding-top: 86px;
    background-color: #e4e4e4;
    background-image: url("../images/page/page_company.jpg");
	background-repeat: no-repeat;
	background-position: top;
	background-size: auto 80px;
}
.pagetitle-contact-box {
    position: relative;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 120px;
    padding-top: 86px;
    background-color: #e4e4e4;
    background-image: url("../images/page/page_contact.jpg");
	background-repeat: no-repeat;
	background-position: top;
	background-size: auto 80px;
}
.pagetitle-txt-jp {
    padding: 0 20px 0 0;
    font-size: 16px; font-size: 1.6rem;
    border-right: 1px solid #ccc;
    color: #666;
}
.pagetitle-txt-en {
    padding: 2px 0 0 20px;
    font-size: 14px; font-size: 1.4rem;
    color: #666;
}
.globalNav {
	width: 100%;
	margin-top: -6px;
}
.globalNav ul {
	width: 100%;
}
.globalNav ul li {
	width: 32%;
}
.globalNav ul li:nth-of-type(2) {
	margin-left: 2%;
	margin-right: 2%;
}
}



/*　サイドスライドーメニュー（pc / tb）
--------------------------------*/
.header-sp {
	display: block;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 9000;
}
.globalNav-sp {
	position: fixed;
	right: -100%;
	top: 0;
	width: 400px;
	height: 100%;
	padding: 0 20px 30px;
	background-color: #333;
	transition: all .4s;
	z-index: 9000;
	overflow-y: auto;
}
#navmenu-sp {
    padding-top: 20px;
}
#navmenu-sp ul {
	padding: 20px;
}
#navmenu-sp li {
	padding: 5px 0;
	border-bottom: 1px solid rgba(255,255,255, 0.1);
}
#navmenu-sp ul li ul {
	padding: 0;
}
#navmenu-sp a {
	display: block;
	padding: 6px 8px 6px;
	margin: 0;
	color: #fff;
	font-size: 14px; font-size: 1.4rem;
	text-decoration: none;
	background-image: url("../images/pages/arrow_nav.png");
	background-repeat: no-repeat;
	background-size: 6px auto;
	background-position: center right 8px;
}
#navmenu-sp a:hover {
	color: #fff;
	background-color: #494949;
	background-image: url("../images/pages/arrow_nav.png");
	background-repeat: no-repeat;
	background-size: 6px auto;
	background-position: center right 8px;
}
.header-menu-tel {
	margin-top: 15px;
	color: #fff;
	font-size: 22px; font-size: 2.2rem;
	text-align: center;
}
.header-menu-tel a {
	display: block;
	margin-top: 30px;
	padding: 10px;
    line-height: 1;
    color: #fff;
	border: 1px solid rgba(255,255,255, 0.1);
}
.header-tel a:hover {
	background-color: #1a3956;
}
.hamburger {
	position: absolute;
	right: 0;
	top: 140px;
	width: 100px;
	height: 120px;
	cursor: pointer;
	z-index: 9000;
	margin: 0px;
	background-image: url("../images/common/menu_btn.png");
    background-repeat: no-repeat;
    background-size: 100% auto;
    transition: 0;
}
.hamburger:hover {
    opacity: 0.7;
}
/*
.hamburger {
	position: absolute;
	right: 0;
	top: 0;
	width: 50px;
	height: 50px;
	cursor: pointer;
	z-index: 9000;
	margin: 0px;
	background: #1a3956;
}
*/
.switch .menu:after {
	position: absolute;
	right: 25px;
	content: '＋';
	font-size: 14px;
	font-weight: 700;
	-moz-transition: all, 0.25s, linear;
	-o-transition: all, 0.25s, linear;
	-webkit-transition: all, 0.25s, linear;
	transition: all, 0.25s, linear;
}
.switch .menu.active:after {
	content: "－";
}
.m01:before {
	display: inline-block;
	vertical-align: middle;
}
.child {
	display: none;
	margin: 0 0 0 0px;
}
.inner-menu li a:before {
	content: '-';
	margin: 0 5px 0 0;
	color: #fff;
}
.globalNav-sp__list {
	margin: 0;
	padding: 0;
	list-style: none;
}
.globalNav-sp__item {
	text-align: center;
	padding: 0;
}
.globalNav-sp__item a {
	display: block;
	padding: 0;
	border-bottom: 1px solid #eee;
	text-decoration: none;
	color: #111;
}
.globalNav-sp__item a:hover {
	background-color: #eee;
}
.hamburger__line {
	position: absolute;
	left: 15px;
	width: 22px;
	height: 2px;
	background-color: #333;
	transition: all .3s;
}
.hamburger__line--1 {
    display: none;
	top: 20px;
	background-color: #fff;
}
.hamburger__line--2 {
	display: none;
	top: 21px;
	background-color: #fff;
}
.hamburger__line--3 {
    display: none;
	top: 28px;
	background-color: #fff;
}
/*
.black-bg {
	position: fixed;
	left: 0;
	top: 0;
	width: 100vw;
	height: 100vh;
	z-index: 100;
	background-color: #000;
	opacity: 0;
	visibility: hidden;
	transition: all .6s;
	cursor: pointer;
}
*/
#js-navclose {
    display: block;
    height: 40px;
    margin-top: 20px;
	cursor: pointer;
    background-color: #fff;
    background-image: url("../images/common/sp_close.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: auto 40px;
    border-radius: 0;
}

/* 表示された時用のCSS */
.nav-open .hamburger {
    display: none;
	position: absolute;
    right: 20px;
	top: 20px;
	width: 360px;
	height: 40px;
	cursor: pointer;
	z-index: 9000;
	margin: 0px;
	background-color: #fff;
    background-image: url("../images/common/sp_close.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: auto 40px;
    opacity: 1;
    transition: 0;
}
.nav-open .globalNav-sp {
	right: 0;
	padding: 0 20px 30px; /* globalNav-spと揃える */
}
.tgactive {
	background-color: #1a3956;
	transition: all .6s;
}
.tgactive span {
}
.nav-open .black-bg {
	opacity: .2;
	visibility: visible;
}
.nav-open .hamburger__line--1 {
    display: none;
	transform: rotate(45deg);
	top: 25px;
	background-color: #666;
}
.nav-open .hamburger__line--2 {
    display: none;
	width: 0;
	left: 50%;
}
.nav-open .hamburger__line--3 {
    display: none;
	transform: rotate(-45deg);
	top: 25px;
	background-color: #666;
}

@media screen and (min-width: 768px) and (max-width: 1023px){
.globalNav-sp {
	position: fixed;
	right: -100%;
	top: 0;
	width: 400px;
	height: 100%;
	padding: 0 20px 30px;
	background-color: #333;
	transition: all .4s;
	z-index: 9000;
	overflow-y: auto;
}
.hamburger {
	position: absolute;
	right: 0;
	top: 110px;
	width: 60px;
	height: 72px;
	cursor: pointer;
	z-index: 9000;
	margin: 0px;
	background-image: url("../images/common/menu_btn.png");
    background-repeat: no-repeat;
    background-size: 100% auto;
}
.nav-open .hamburger {
	position: absolute;
    right: 20px;
	top: 20px;
	width: 360px;
	height: 40px;
	cursor: pointer;
	z-index: 9000;
	margin: 0px;
	background-color: #fff;
    background-image: url("../images/common/sp_close.png");
    background-repeat: no-repeat;
    background-position: center;
    background-size: auto 40px;
}
}

/*　スマホ用メニュー
--------------------------------*/
@media screen and (max-width: 767px){
.globalNav-sp2 {
	display: block;
	margin-top: 15px;
}
.globalNav-sp2 dl dt {
	display: block;
	height: 40px;
	font-weight: 700;
	text-align: center;
	font-size: 0;
	background-color: #21b6c2;
	cursor: pointer;
}
.globalNav-sp2 dl dt span {
	display: inline-block;
	width: 100%;
	height: 40px;
	background-image: url(../images/common/sp_menu.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: auto 100%;
}
.globalNav-sp2 dl dt.active {
	background-color: #333;
}
.globalNav-sp2 dl dt.active span {
	display: inline-block;
	width: 100%;
	height: 40px;
	background-image: url(../images/common/sp_close2.png);
	background-repeat: no-repeat;
	background-position: center;
	background-size: auto 100%;
}
.globalNav-sp2 dl dd {
	display: none;
	background-color: #e4e4e4;;
}
.globalNav-sp2 .menu {
	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-orient: horizontal;
  	-webkit-box-direction: normal;
  	-ms-flex-direction: row;
  	flex-direction: row;
}
.globalNav-sp2 .menu li {
	width: 50%;
}
.globalNav-sp2 .menu li.category {
	width: 100%;
	padding: 10px;
	font-weight: 700;
	color: #fff;
    text-align: center;
	background-color: #666;
}
.globalNav-sp2 .menu li a {
	display: block;
	height: 100%;
	color: #000;
	padding: 12px 10px 12px 35px;
	background-color: #e4e4e4;
	background-image: url(../images/common/arrow_02.png);
	background-repeat: no-repeat;
	background-position: 15px 18px;
    background-size: 8px auto;
	border-bottom: 1px dotted #ccc;
}
.globalNav-sp2 .menu li a:hover {
	color: #0b9da9;
	text-decoration: none;
	background-color: #e6fdff;
}
.submenu .btn-contact1 {
	display: block;
	margin: 10px 12px 0;
	padding: 15px 10px;
	color: #21b6c2;
	line-height: 1;
	font-size: 16px; font-size: 1.6rem;
	border: 1px solid #21b6c2;
	text-align: center;
    background-color: #fff;
}
.submenu .btn-contact1:hover {
	color: #0b9da9;
	background-color: #e6fdff;
}
.submenu .btn-contact2 {
	display: block;
	margin: 10px 12px;
	padding: 10px;
	border: 1px solid #21b6c2;
    font-size: 24px; font-size: 2.4rem;
    line-height: 1;
	text-align: center;
    background-color: #fff;
}
.submenu .btn-contact2:hover {
	background-color: #e6fdff;
}
}



/*　　フッター 
-------------------------------------------------------*/
#footer {
    margin-top: 80px;
    background-color: #e4e4e4;
}
#footer .wrapper-logo {
    width: 300px;
    text-align: center;
}
#footer .wrapper-logo address {
    margin-top: 10px;
    font-size: 14px; font-size: 1.4rem;
    font-style: normal;
}
.footer-tel-box {
    background: linear-gradient(to right, transparent 60%, #fff 60%);
}
.footer-tel-bg {
    padding: 5px 0 15px 120px;
    background-image: url("../images/common/footer_tel_bg.png");
    background-repeat: no-repeat;
    background-position: left bottom;
}
.footer-tel {
    margin-left: 40px;
    font-size: 28px; font-size: 2.8rem;
    font-weight: 700;
}
.footer-txt-en {
    margin-top: 30px;
    font-size: 30px; font-size: 3.0rem;
    color: #fff;
}
.wrapper-sitemap {
    margin-top: 50px;
    padding-bottom: 30px;
    font-size: 14px; font-size: 1.4rem;
}
.sitemap-box1 {
    width: 68.36%;
}
.sitemap-box2 {
    width: 28.36%;
}
.sitemap-tit {
    background-image: url("../images/common/footer_line.png");
    background-repeat: repeat-x;
    background-position: center;
}
.sitemap-inner {
    padding: 20px;
}
.sitemap-tit span {
    display: inline-block;
    padding-right: 20px;
    background-color: #e4e4e4;
}
.sitemap-btn a {
    display: block;
    margin-bottom: 20px;
    padding: 15px;
    color: #fff;
    text-align: center;
    background-color: #21b6c2;
    background-image: url("../images/common/arrow_01.png");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 8px auto;
}
.sitemap-btn a:hover {
    background-color: #1ed0de;
}
.sitemap-list a {
    display: block;
    padding: 10px 0;
    color: #333;
}
.sitemap-list a:hover {
    color: #0b9da9;
}
.copyright-bg {
    padding: 50px 0;
    background-color: #21b6c2;
}
.copyright {
	font-size: 12px; font-size: 1.2rem;
	color: #fff;
}

@media screen and (min-width: 768px) and (max-width: 1023px){
#footer {
    margin-top: 60px;
}
.footer-tel-bg {
    padding: 5px 0 15px 110px;
}
.footer-tel {
    margin-left: 30px;
    font-size: 24px; font-size: 2.4rem;
    font-weight: 700;
}
.wrapper-sitemap {
    margin-top: 40px;
    padding-bottom: 20px;
}
.sitemap-inner {
    padding: 20px 5px;
}
.copyright-bg {
    padding: 30px 0;
}
.copyright {
	text-align: center;
}
}

@media screen and (max-width: 767px){
#footer {
    margin-top: 40px;
}
#footer .wrapper-logo {
    width: auto;
    margin: 0 -12px;
    padding: 20px 0;
    background-color: #fff;
}
#footer .wrapper-logo img {
    width: 280px;
}
.footer-txt-en {
    margin-top: 20px;
    font-size: 24px; font-size: 2.4rem;
    text-align: center;
}
.footer-contact-btn a {
	display: block;
	margin: 10px 0 0;
	padding: 15px 10px;
	color: #21b6c2;
	line-height: 1;
	font-size: 16px; font-size: 1.6rem;
	border: 1px solid #21b6c2;
	text-align: center;
    background-color: #fff;
}
.footer-contact-btn a:hover {
	color: #0b9da9;
	background-color: #e6fdff;
}
.footer-tel-sp {
    font-size: 24px; font-size: 2.4rem;
    text-align: center;
}
.footer-tel-sp a {
	display: block;
	margin-top: 15px;
	padding: 10px;
    line-height: 1;
	border: 1px solid #21b6c2;
    background-color: #fff;
}
.footer-tel-sp a:hover {
	background-color: #e6fdff;
}
.footer-link-sp {
    margin-bottom: 15px;
}
.footer-link-sp li {
    margin-top: 10px;
    padding-bottom: 10px;
    text-align: center;
}
.footer-link-sp li:first-child {
    border-bottom: 1px dotted #ccc;
}
.footer-link-sp li a {
    display: block;
    padding: 10px 0;
    color: #333;
}
.footer-link-sp li a:hover {
	color: #0b9da9;
	text-decoration: none;
}
.wrapper-sitemap {
    display: none;
}
.copyright-bg {
    padding: 30px 0;
}
.copyright {
	text-align: center;
}
}



/*　　コンテンツ共通パーツ
-------------------------------------------------------*/
.cnt-tit1 {
    font-size: 26px; font-size: 2.6rem;
    font-weight: 700;
    line-height: 1.5;
}
.cnt-tit2 {
    padding: 14px 10px;
    color: #fff;
    font-size: 20px; font-size: 2.0rem;
    font-weight: 700;
    line-height: 1.5;
    background-color: #333;
}
.cnt-tit3 {
    padding: 14px 10px;
    font-size: 18px; font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.5;
    background-color: #e4f7ff;
}
.line-L-RED {
    display: inline-block;
    padding: 2px 0 2px 10px;
    border-left: 8px solid #d91545;
}
.line-L-GRN {
    display: inline-block;
    padding: 2px 0 2px 10px;
    border-left: 8px solid #21b6c2;
}
.line-L-YEL {
    display: inline-block;
    padding: 2px 0 2px 10px;
    border-left: 4px solid #ffcc00;
}
.tit-line-GRN {
    background-image: url("../images/common/tit_line_GRN.png");
    background-repeat: repeat-x;
    background-position: center;
}
.tit-line-txt {
    display: inline-block;
    padding-right: 20px;
    font-size: 20px; font-size: 2.0rem;
    font-weight: 700;
    line-height: 1.5;
    background-color: #fff;
}
.tit-arrow {
    padding-left: 26px;
    font-weight: 700;
    line-height: 1.5;
    background-image: url("../images/common/arrow_03.png");
	background-repeat: no-repeat;
	background-position: left 3px;
    background-size: 18px;
}
.cnt-mix { overflow: hidden; zoom:1;}
.cnt-mix .cntL { float: left; margin-right:20px; margin-bottom: 10px;}
.cnt-mix .cntR { float: right; margin-left: 20px; margin-bottom: 10px;}
.cnt-mix .no-around { overflow: hidden; zoom:1;}
.list-disc { list-style-type: disc; list-style-position: outside; margin-left: 25px;}
.list-decimal { list-style-type: decimal; list-style-position: outside; margin-left: 25px;}
.list-kome { list-style-position: outside; margin-left: 1em; text-indent: -1em;}
.list-float-L li {
	float: left;
	margin-right: 55px;
}
.list-table {
	display: table;
}
.list-table-fix {
	display: table;
	table-layout: fixed;
}
.list-table li,
.list-table-fix li {
	display: table-cell;
}
.mark1 {
	display: inline-block;
	min-width: 100px;
    margin-left: 15px;
	padding: 3px 8px;
	color: #fff;
	font-size: 12px; font-size: 1.2rem;
	line-height: 1.5;
	text-align: center;
	border-radius: 4px;
	font-weight: 400;
	background-color: #d91545;
    vertical-align: middle;
}
.btn-txt a {
	display: inline-block;
    width: 400px;
	padding: 18px 30px;
    color: #fff;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
	background-color: #21b6c2;
    background-image: url("../images/common/arrow_01.png");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 8px auto;
    transition-duration: 0.2s;
}
.btn-txt-L a {
	display: inline-block;
    width: 61.22%;
	padding: 18px 30px;
    color: #fff;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
	background-color: #21b6c2;
    background-image: url("../images/common/arrow_01.png");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 8px auto;
    transition-duration: 0.2s;
}
.btn-txt a:hover,
.btn-txt-L a:hover {
	background-color: #1ed0de;
    transform: scale(1.05);
}
.btn-back a {
	display: inline-block;
    width: 400px;
	padding: 18px 30px;
    color: #fff;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
	background-color: #444;
    background-image: url("../images/common/arrow_04.png");
    background-repeat: no-repeat;
    background-position: left 10px center;
    background-size: 8px auto;
    transition-duration: 0.2s;
}
.btn-back a:hover {
    background-color: #666;
    transform: scale(1.05);
}
.invisible {
	opacity: 0;
	transform: translate(0, 60px);
}
.visible {
	opacity: 1.0;
	transform: translate(0, 0);
	transition: .8s;
}
#page-top a {
	display: block;
	position: fixed;
	bottom: 50px;
	right: 50px;
	width: 50px;
	height: 50px;
	background-image: url(../images/common/btn_pagetop.png);
	background-size: 100%;
	text-indent: -9999px;
	z-index: 500;
}
#page-top a:hover {
	opacity:0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha( opacity=70 )";
}


@media screen and (min-width: 768px) and (max-width: 1023px){
.cnt-tit1 {
    font-size: 22px; font-size: 2.2rem;
}
.cnt-tit2 {
    font-size: 18px; font-size: 1.8rem;
}
.cnt-tit3 {
    font-size: 16px; font-size: 1.6rem;
}
.cnt-mix .cntL.tb30,
.cnt-mix .cntR.tb30 { width: 30%;}
.cnt-mix .cntL.tb40,
.cnt-mix .cntR.tb40 { width: 40%;}
.cnt-mix .cntL.tb100,
.cnt-mix .cntR.tb100 { width: 100%;}
.btn-txt a,
.btn-back a{
    width: 300px;
}

#page-top a {
    width: 30px;
	height: 30px;
	bottom: 30px;
	right: 20px;
}
}

@media screen and (max-width: 736px){
.cnt-tit1 {
    font-size: 20px; font-size: 2.0rem;
}
.cnt-tit2 {
    font-size: 18px; font-size: 1.8rem;
}
.cnt-tit3 {
    font-size: 16px; font-size: 1.6rem;
}
.btn-txt a,
.btn-txt-L a,
.btn-back a {
    width: 90%;
}
.cnt-mix .cntL.sp30,
.cnt-mix .cntR.sp30 { width: 30%;}
.cnt-mix .cntL.sp40,
.cnt-mix .cntR.sp40 { width: 40%;}
.cnt-mix .cntL.sp100,
.cnt-mix .cntR.sp100 { width: 100%;}
#page-top a {
	display: block;
	position: fixed;
	bottom: 40px;
	right: 12px;
	width: 30px;
	height: 30px;
}
}



/*　　コンテンツ共通パーツ 　/　お問い合わせ
-------------------------------------------------------*/
.page-contact-btn-box {
    padding: 40px;
    border: 1px solid #ccc;
}
.page-contact-btn a {
	display: block;
	padding: 30px 30px;
    color: #fff;
    font-size: 20px; font-size: 2.0rem;
    font-weight: 700;
    line-height: 1.5;
    text-align: center;
	background-color: #21b6c2;
    background-image: url("../images/common/arrow_01.png");
    background-repeat: no-repeat;
    background-position: right 15px center;
    background-size: 8px auto;
    transition-duration: 0.2s;
}
.page-contact-btn a:hover {
	background-color: #1ed0de;
    transform: scale(1.05);
}
.page-contact-tel {
    font-size: 28px; font-size: 2.8rem;
    font-weight: 700;
}

@media screen and (min-width: 768px) and (max-width: 1023px){
.page-contact-btn-box {
    padding: 30px;
}
}

@media screen and (max-width: 736px){
.page-contact-btn-box {
    padding: 12px;
}
.page-contact-btn a {
	padding: 20px 20px;
    font-size: 16px; font-size: 1.6rem;
}
.page-contact-tel {
    font-size: 24px; font-size: 2.4rem;
}
}



/*　　コンテンツ共通パーツ 　/　アイコン
-------------------------------------------------------*/
.icon-tel {
	display: inline-block;
	width: 16px;
	height: 23px;
	background-image: url("../images/common/icon_tel.png");
	background-repeat: no-repeat;
	background-size: 16px auto;
	vertical-align: middle;
}
.icon-tel-WHT {
	display: inline-block;
	width: 16px;
	height: 23px;
	background-image: url("../images/common/icon_tel_WHT.png");
	background-repeat: no-repeat;
	background-size: 16px auto;
	vertical-align: middle;
}
.icon-fax {
	display: inline-block;
	width: 32px;
	height: 32px;
	background-image: url("../images/common/icon_fax.png");
	background-repeat: no-repeat;
	background-size: 32px auto;
	vertical-align: middle;
}
.icon-arrow {
    display: inline-block;
	width: 8px;
	height: 13px;
	background-image: url("../images/common/arrow_01.png");
	background-repeat: no-repeat;
	background-position: center;
    background-size: 8px auto;
}
.icon-arrow2 {
    display: inline-block;
	width: 18px;
	height: 18px;
	background-image: url("../images/common/arrow_03.png");
	background-repeat: no-repeat;
	background-position: center;
    background-size: 18px auto;
    vertical-align: middle;
}
.icon-arrow3 {
    display: inline-block;
    padding-left: 28px;
	min-height: 18px;
	background-image: url("../images/common/arrow_03.png");
	background-repeat: no-repeat;
	background-position: left 2px;
    background-size: 18px auto;
    vertical-align: middle;
}

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

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



/*　　コンテンツ共通パーツ / ページ内ナビ
-------------------------------------------------------*/
.parts-pagenav-box {
	padding: 10px;
	background-color: #effaff;
	border: 1px solid #ccc;
}
.parts-pagenav-box li a {
	display: block;
    min-height: 28px;
	padding: 0 0 0 30px;
    margin: 5px 0;
    color: #333;
	border: 1px solid #faf9fb;
    background-image: url("../images/common/arrow_03.png");
    background-repeat: no-repeat;
    background-position: 5px 3px;
    background-size: 18px;
}
.parts-pagenav-box li a:hover {
    color: #0b9da9;
    text-decoration: underline;
}
.parts-pagenav-box.nav-row-auto li {
	width: auto !important;
	padding-right: 30px;
}
.parts-pagenav-box.nav-row2 li {
	width: 50%;
}
.parts-pagenav-box.nav-row3 li {
	width: 33.333%;
}
.parts-pagenav-box.nav-row4 li {
	width: 20%;
}

@media screen and (min-width: 768px) and (max-width: 1023px){
.parts-pagenav-box.tb-nav-row-auto li {
	width: auto !important;
	padding-right: 30px;
}
}

@media screen and (max-width: 736px){
.parts-pagenav-box.nav-row2 li,
.parts-pagenav-box.nav-row3 li,
.parts-pagenav-box.nav-row4 li {
	width: 100%;
}
.parts-pagenav-box.sp-nav-row2 li {
	width: 50%;
}
}



/*　　コンテンツ共通パーツ / テーブル1
-------------------------------------------------------*/
.table-design1,
.table-design1-sp-block {
	width: 100%;
	border-top: 1px solid #ccc;
}
.table-design1 th,
.table-design1-sp-block th {
	padding: 15px;
	font-weight: 700;
	background-color: #effaff;
	border: 1px solid #ccc;
	vertical-align: middle;
}
.table-design1 td,
.table-design1-sp-block td {
	padding: 15px;
	background-color: #fff;
	border: 1px solid #ccc;
	vertical-align: middle;
}

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

@media screen and (max-width: 736px){
.table-design1-sp-block th,
.table-design1-sp-block td{
	display: block;
	border-top: 0;
	width: 100% !important;
	text-align: left;
}
}



/*　　コンテンツ共通パーツ / テーブル2
-------------------------------------------------------*/
.table-design2,
.table-design2-sp-block {
	width: 100%;
	border-bottom: 1px solid #ccc;
}
.table-design2 th,
.table-design2-sp-block th {
	padding: 15px 0 30px 0;
	font-weight: 700;
	border-top: 1px solid #ccc;
	vertical-align: top;
	text-align: right;
}
.table-design2 td,
.table-design2-sp-block td {
	padding: 17px 0 30px 60px;
	border-top: 1px solid #ccc;
	vertical-align: top;
}


@media screen and (min-width: 768px) and (max-width: 1023px){
.table-design2 td,
.table-design2-sp-block td {
	padding: 17px 0 30px 40px;
}
}

@media screen and (max-width: 736px){
.table-design2 th {
	padding: 10px 5px 25px 0;
	font-weight: 700;
}
.table-design2 td {
	padding: 12px 0 30px 20px;
	border-top: 1px solid #ccc;
}
.table-design2-sp-block th {
	display: block;
	width: 100% !important;
	padding: 10px 0 10px 0;
	text-align: left;
	border-top: 2px solid #ccc;
}
.table-design2-sp-block td {
	display: block;
	width: 100% !important;
	padding: 10px 0 30px 30px;
}
}




/*　　コンテンツ共通パーツ / 商品Box
-------------------------------------------------------*/
.parts-product-box {
    border-left: 1px solid #ccc;
    border-right: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
}
.parts-product-box .p-name {
	padding: 10px;
    color: #fff;
    background-color: #333;
}
.parts-product-box .inner-p-txt {
	padding: 10px;
}
.parts-product-box .p-img {
	padding: 20px 10px;
	text-align: center;
}



/*　　コンテンツ共通パーツ　/　お問い合わせ
-------------------------------------------------------*/
.parts-contact-tit {
	padding: 10px;
	color: #fff;
	font-size: 20px; font-size: 2.0rem;
	font-weight: 700;
	text-align: center;
	background-color: #1ac1ce;
	border-bottom: 4px solid #5ddbe5;
}
.parts-contact-box {
	padding: 40px;
	border-left: 10px solid #e1fbfd;
	border-right: 10px solid #e1fbfd;
	border-bottom: 10px solid #e1fbfd;
	text-align: center;
}
.parts-contact-box ul li.contact-tel {
	width: 30%;
}
.parts-contact-box ul li.contact-fax {
	width: 30%;
}
.parts-contact-box ul li.contact-web {
	width: 40%;
	padding-left: 30px;
}
.parts-contact-box ul li.contact-web a {
	display: block;
	padding: 16px;
	font-size: 18px; font-size: 1.8rem;
	font-weight: 700;
	border: 2px solid #1fc8d6;
	border-radius: 6px;
	background-color: #fff;
}
.parts-contact-box ul li.contact-web a:hover {
	background-color: #e6fdff;
}

@media screen and (min-width: 768px) and (max-width: 1023px){
.parts-contact-box {
	padding: 20px;
}
.parts-contact-box ul li.contact-tel {
	width: 50%;
}
.parts-contact-box ul li.contact-fax {
	width: 50%;
}
.parts-contact-box ul li.contact-web {
	width: 100%;
	padding-left: 0;
	margin-top: 20px;
}
}

@media screen and (max-width: 767px){
.parts-contact-box {
	padding: 20px 15px;
}
.parts-contact-box ul li.contact-tel {
	width: 100%;
}
.parts-contact-box ul li.contact-fax {
	width: 100%;
	margin-top: 20px;
}
.parts-contact-box ul li.contact-web {
	width: 100%;
	padding-left: 0;
	margin-top: 20px;
}
}



/*　　お知らせ　/　ページナビ
-------------------------------------------------------*/
.pagination {
  display: block;
  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden;
}
.pagination > li {
  display: inline;
}
.pagination > li > a,
.pagination > li > span {
  position: relative;
  float: left;
  padding: 8px 14px;
  margin-left: 8px;
  margin-top: 10px;
  line-height: 1.4;
  color: #333;
  text-decoration: none;
  background-color: #fff;
  border: 1px solid #ccc;
}
.pagination > li:first-child > a,
.pagination > li:first-child > span {
  margin-left: 0;
}
.pagination > li:last-child > a,
.pagination > li:last-child > span {

}
.pagination > li > a:hover,
.pagination > li > span:hover,
.pagination > li > a:focus,
.pagination > li > span:focus {
  z-index: 3;
  color: #21b6c2;
  background-color: #e6fdff;
  border: 1px solid #1fc8d6;
}
.pagination > .active > a,
.pagination > .active > span,
.pagination > .active > a:hover,
.pagination > .active > span:hover,
.pagination > .active > a:focus,
.pagination > .active > span:focus {
  z-index: 2;
  cursor: default;
  color: #fff;
  background-color: #333;
  border: 1px solid #333;
}



/*　　bg・カラー・フォントサイズ
-------------------------------------------------------*/
.bgcolor-WHT { background-color: #fff !important;}
.bgcolor-GRY { background-color: #f5f5f5 !important;}
.bgcolor-GRN { background-color: #21b6c2 !important;}
.bgcolor-LBU { background-color: #effaff !important;}
.color-BLK { color: #000 !important;}
.color-WHT { color: #fff !important;}
.color-RED { color: #ff0000 !important;}
.color-GRY { color: #666 !important;}
.fsXS { font-size: 10px; font-size: 1.0rem;}
.fsS { font-size: 12px; font-size: 1.2rem;}
.fsM { font-size: 14px; font-size: 1.4rem;}
.fsL { font-size: 16px; font-size: 1.6rem;}
.fsXL { font-size: 20px; font-size: 2.0rem;}
.fsXXL { font-size: 30px; font-size: 3.0rem;}
.fwB { font-weight: 700 !important;}
.fwN { font-weight: 400 !important;}
.borderBox { border: 1px solid #ccc !important;}
.borderT { border-top: 1px solid #ccc !important;}
.borderB { border-bottom: 1px solid #ccc !important;}
.borderL { border-left: 1px solid #ccc !important;}
.borderR { border-right: 1px solid #ccc !important;}
.borderBox-dot { border: 1px dotted #ccc !important;}
.borderT-dot { border-top: 1px dotted #ccc !important;}
.borderB-dot { border-bottom: 1px dotted #ccc !important;}
.borderL-dot { border-left: 1px dotted #ccc !important;}
.borderR-dot { border-right: 1px dotted #ccc !important;}
.lh10 { line-height: 1.0;}
.lh11 { line-height: 1.1;}
.lh12 { line-height: 1.2;}
.lh13 { line-height: 1.3;}
.lh14 { line-height: 1.4;}
.lh15 { line-height: 1.5;}
.lh16 { line-height: 1.6;}
.lh17 { line-height: 1.7;}
.lh18 { line-height: 1.8;}
.lh19 { line-height: 1.9;}
.lh20 { line-height: 2.0;}
.ls1 {letter-spacing: 1px;}
.ls2 {letter-spacing: 2px;}
.ls3 {letter-spacing: 3px;}
.ls4 {letter-spacing: 4px;}
.ls5 {letter-spacing: 5px;}
.ls6 {letter-spacing: 6px;}
.ls7 {letter-spacing: 7px;}
.ls8 {letter-spacing: 8px;}


@media screen and (min-width: 768px) and (max-width: 1023px){
.fsXS { font-size: 10px; font-size: 1.0rem;}
.fsS { font-size: 12px; font-size: 1.2rem;}
.fsM { font-size: 14px; font-size: 1.4rem;}
.fsL { font-size: 16px; font-size: 1.6rem;}
.fsXL { font-size: 18px; font-size: 1.8rem;}
.fsXXL { font-size: 22px; font-size: 2.2rem;}
}
@media screen and (max-width: 767px){
.fsXS { font-size: 10px; font-size: 1.0rem;}
.fsS { font-size: 12px; font-size: 1.2rem;}
.fsM { font-size: 14px; font-size: 1.4rem;}
.fsL { font-size: 16px; font-size: 1.6rem;}
.fsXL { font-size: 18px; font-size: 1.8rem;}
.fsXXL { font-size: 20px; font-size: 2.0rem;}
}


/*　　その他・マージン・パディング
-------------------------------------------------------*/
.flL { float: left !important;}
.flR { float: right !important;}
.flN { float: none !important;}
.vaT { vertical-align: top !important;}
.vaM { vertical-align: middle !important;}
.vaB { vertical-align: bottom !important;}
.tableFix { table-layout: fixed !important;}
.position-r { position: relative;}
.pd0 { padding: 0 !important;}
.pd10 { padding: 10px !important;}
.pd15 { padding: 15px !important;}
.pd20 { padding: 20px !important;}
.pdT0 { padding-top: 0 !important;}
.pdT5 { padding-top: 5px !important;}
.pdT10 { padding-top: 10px !important;}
.pdT15 { padding-top: 15px !important;}
.pdT20 { padding-top: 20px !important;}
.pdT25 { padding-top: 25px !important;}
.pdT30 { padding-top: 30px !important;}
.pdT35 { padding-top: 35px !important;}
.pdT40 { padding-top: 40px !important;}
.pdT45 { padding-top: 45px !important;}
.pdT50 { padding-top: 50px !important;}
.pdT55 { padding-top: 55px !important;}
.pdT60 { padding-top: 60px !important;}
.pdT65 { padding-top: 65px !important;}
.pdT70 { padding-top: 70px !important;}
.pdT75 { padding-top: 75px !important;}
.pdT80 { padding-top: 80px !important;}
.pdT85 { padding-top: 85px !important;}
.pdT90 { padding-top: 90px !important;}
.pdT95 { padding-top: 95px !important;}
.pdT100 { padding-top: 100px !important;}
.pdB0 { padding-bottom: 0 !important;}
.pdB5 { padding-bottom: 5px !important;}
.pdB10 { padding-bottom: 10px !important;}
.pdB15 { padding-bottom: 15px !important;}
.pdB20 { padding-bottom: 20px !important;}
.pdB25 { padding-bottom: 25px !important;}
.pdB30 { padding-bottom: 30px !important;}
.pdB35 { padding-bottom: 35px !important;}
.pdB40 { padding-bottom: 40px !important;}
.pdB45 { padding-bottom: 45px !important;}
.pdB50 { padding-bottom: 50px !important;}
.pdB55 { padding-bottom: 55px !important;}
.pdB60 { padding-bottom: 60px !important;}
.pdB65 { padding-bottom: 65px !important;}
.pdB70 { padding-bottom: 70px !important;}
.pdB75 { padding-bottom: 75px !important;}
.pdB80 { padding-bottom: 80px !important;}
.pdB85 { padding-bottom: 85px !important;}
.pdB90 { padding-bottom: 90px !important;}
.pdB95 { padding-bottom: 95px !important;}
.pdB100 { padding-bottom: 100px !important;}
.pdL0 { padding-left: 0 !important;}
.pdL5 { padding-left: 5px !important;}
.pdL10 { padding-left: 10px !important;}
.pdL15 { padding-left: 15px !important;}
.pdL20 { padding-left: 20px !important;}
.pdL25 { padding-left: 25px !important;}
.pdL30 { padding-left: 30px !important;}
.pdL35 { padding-left: 35px !important;}
.pdL40 { padding-left: 40px !important;}
.pdL45 { padding-left: 45px !important;}
.pdL50 { padding-left: 50px !important;}
.pdL55 { padding-left: 55px !important;}
.pdL60 { padding-left: 60px !important;}
.pdL65 { padding-left: 65px !important;}
.pdL70 { padding-left: 70px !important;}
.pdL75 { padding-left: 75px !important;}
.pdL80 { padding-left: 80px !important;}
.pdL85 { padding-left: 85px !important;}
.pdL90 { padding-left: 90px !important;}
.pdL95 { padding-left: 95px !important;}
.pdL100 { padding-left: 100px !important;}
.pdR0 { padding-right: 0 !important;}
.pdR5 { padding-right: 5px !important;}
.pdR10 { padding-right: 10px !important;}
.pdR15 { padding-right: 15px !important;}
.pdR20 { padding-right: 20px !important;}
.pdR25 { padding-right: 25px !important;}
.pdR30 { padding-right: 30px !important;}
.pdR35 { padding-right: 35px !important;}
.pdR40 { padding-right: 40px !important;}
.pdR45 { padding-right: 45px !important;}
.pdR50 { padding-right: 50px !important;}
.pdR55 { padding-right: 55px !important;}
.pdR60 { padding-right: 60px !important;}
.pdR65 { padding-right: 65px !important;}
.pdR70 { padding-right: 70px !important;}
.pdR75 { padding-right: 75px !important;}
.pdR80 { padding-right: 80px !important;}
.pdR85 { padding-right: 85px !important;}
.pdR90 { padding-right: 90px !important;}
.pdR95 { padding-right: 95px !important;}
.pdR100 { padding-right: 100px !important;}
.w5 { width: 5%;}
.w10 { width: 10% !important;}
.w15 { width: 15% !important;}
.w20 { width: 20% !important;}
.w25 { width: 25% !important;}
.w30 { width: 30% !important;}
.w35 { width: 35% !important;}
.w40 { width: 40% !important;}
.w45 { width: 45% !important;}
.w50 { width: 50% !important;}
.w55 { width: 55% !important;}
.w60 { width: 60% !important;}
.w65 { width: 65% !important;}
.w70 { width: 70% !important;}
.w75 { width: 75% !important;}
.w80 { width: 80% !important;}
.w85 { width: 85% !important;}
.w90 { width: 90% !important;}
.w95 { width: 95% !important;}
.w100 { width: 100% !important;}
.w20-sp-w100 { width: 20% !important;}
.w25-sp-w100 { width: 25% !important;}
.w30-sp-w100 { width: 30% !important;}
.w35-sp-w100 { width: 35% !important;}
.w40-sp-w100 { width: 40% !important;}
.mgCenter {
	margin-left: auto;
	margin-right: auto;
}
.mg0 { margin: 0 !important;}
.mgT0 { margin-top: 0 !important;}
.mgT5 { margin-top: 5px !important;}
.mgT10 { margin-top: 10px !important;}
.mgT15 { margin-top: 15px !important;}
.mgT20 { margin-top: 20px !important;}
.mgT25 { margin-top: 25px !important;}
.mgT30 { margin-top: 30px !important;}
.mgT35 { margin-top: 35px !important;}
.mgT40 { margin-top: 40px !important;}
.mgT45 { margin-top: 45px !important;}
.mgT50 { margin-top: 50px !important;}
.mgT55 { margin-top: 55px !important;}
.mgT60 { margin-top: 60px !important;}
.mgT65 { margin-top: 65px !important;}
.mgT70 { margin-top: 70px !important;}
.mgT75 { margin-top: 75px !important;}
.mgT80 { margin-top: 80px !important;}
.mgT85 { margin-top: 85px !important;}
.mgT90 { margin-top: 90px !important;}
.mgT95 { margin-top: 95px !important;}
.mgT100 { margin-top: 100px !important;}
.mgB0 { margin-bottom: 0 !important;}
.mgB5 { margin-bottom: 5px !important;}
.mgB10 { margin-bottom: 10px !important;}
.mgB15 { margin-bottom: 15px !important;}
.mgB20 { margin-bottom: 20px !important;}
.mgB25 { margin-bottom: 25px !important;}
.mgB30 { margin-bottom: 30px !important;}
.mgB35 { margin-bottom: 35px !important;}
.mgB40 { margin-bottom: 40px !important;}
.mgB45 { margin-bottom: 45px !important;}
.mgB50 { margin-bottom: 50px !important;}
.mgB55 { margin-bottom: 55px !important;}
.mgB60 { margin-bottom: 60px !important;}
.mgB65 { margin-bottom: 65px !important;}
.mgB70 { margin-bottom: 70px !important;}
.mgB75 { margin-bottom: 75px !important;}
.mgB80 { margin-bottom: 80px !important;}
.mgB85 { margin-bottom: 85px !important;}
.mgB90 { margin-bottom: 90px !important;}
.mgB95 { margin-bottom: 95px !important;}
.mgB100 { margin-bottom: 100px !important;}
.mgL0 { margin-left: 0 !important;}
.mgL5 { margin-left: 5px !important;}
.mgL10 { margin-left: 10px !important;}
.mgL15 { margin-left: 15px !important;}
.mgL20 { margin-left: 20px !important;}
.mgL25 { margin-left: 25px !important;}
.mgL30 { margin-left: 30px !important;}
.mgL35 { margin-left: 35px !important;}
.mgL40 { margin-left: 40px !important;}
.mgL45 { margin-left: 45px !important;}
.mgL50 { margin-left: 50px !important;}
.mgL55 { margin-left: 55px !important;}
.mgL60 { margin-left: 60px !important;}
.mgL65 { margin-left: 65px !important;}
.mgL70 { margin-left: 70px !important;}
.mgL75 { margin-left: 75px !important;}
.mgL80 { margin-left: 80px !important;}
.mgL85 { margin-left: 85px !important;}
.mgL90 { margin-left: 90px !important;}
.mgL95 { margin-left: 95px !important;}
.mgL100 { margin-left: 100px !important;}
.mgR0 { margin-right: 0 !important;}
.mgR5 { margin-right: 5px !important;}
.mgR10 { margin-right: 10px !important;}
.mgR15 { margin-right: 15px !important;}
.mgR20 { margin-right: 20px !important;}
.mgR25 { margin-right: 25px !important;}
.mgR30 { margin-right: 30px !important;}
.mgR35 { margin-right: 35px !important;}
.mgR40 { margin-right: 40px !important;}
.mgR45 { margin-right: 45px !important;}
.mgR50 { margin-right: 50px !important;}
.mgR55 { margin-right: 55px !important;}
.mgR60 { margin-right: 60px !important;}
.mgR65 { margin-right: 65px !important;}
.mgR70 { margin-right: 70px !important;}
.mgR75 { margin-right: 75px !important;}
.mgR80 { margin-right: 80px !important;}
.mgR85 { margin-right: 85px !important;}
.mgR90 { margin-right: 90px !important;}
.mgR95 { margin-right: 95px !important;}
.mgR100 { margin-right: 100px !important;}
.mgT-set1 {	margin-top: 100px !important;}
.mgT-set2 {	margin-top: 60px !important;}
.mgT-set3 {	margin-top: 40px !important;}
.mgT-set4 {	margin-top: 30px !important;}
.pdT-set1 {	padding-top: 100px !important;}
.pdT-set2 {	padding-top: 60px !important;}
.pdT-set3 {	padding-top: 40px !important;}
.mgB-set1 {	margin-bottom: 100px !important;}
.mgB-set2 {	margin-bottom: 60px !important;}
.mgB-set3 {	margin-bottom: 40px !important;}
.pdB-set1 {	padding-bottom: 100px !important;}
.pdB-set2 {	padding-bottom: 60px !important;}
.pdB-set3 {	padding-bottom: 40px !important;}
.alL { text-align: left !important;}
.alR { text-align: right !important;}
.alC { text-align: center !important;}
.alL-sp-alC { text-align: center !important;}
.alC-sp-alL { text-align: center !important;}

@media screen and (min-width: 768px) and (max-width: 1023px){
.tb-w10 { width: 10% !important;}
.tb-w15 { width: 15% !important;}
.tb-w20 { width: 20% !important;}
.tb-w25 { width: 25% !important;}
.tb-w30 { width: 30% !important;}
.tb-w35 { width: 35% !important;}
.tb-w40 { width: 40% !important;}
.tb-w45 { width: 45% !important;}
.tb-w50 { width: 50% !important;}
.tb-w55 { width: 55% !important;}
.tb-w60 { width: 60% !important;}
.tb-w65 { width: 65% !important;}
.tb-w70 { width: 70% !important;}
.tb-w75 { width: 75% !important;}
.tb-w80 { width: 80% !important;}
.tb-w85 { width: 85% !important;}
.tb-w90 { width: 90% !important;}
.tb-w95 { width: 95% !important;}
.tb-w100 { width: 100% !important;}
.mgT-set1 {	margin-top: 80px !important;}
.mgT-set2 {	margin-top: 40px !important;}
.mgT-set3 {	margin-top: 30px !important;}
.mgT-set4 {	margin-top: 30px !important;}
.pdT-set1 {	padding-top: 80px !important;}
.pdT-set2 {	padding-top: 40px !important;}
.pdT-set3 {	padding-top: 30px !important;}
.mgB-set1 {	margin-bottom: 80px !important;}
.mgB-set2 {	margin-bottom: 40px !important;}
.mgB-set3 {	margin-bottom: 30px !important;}
.pdB-set1 {	padding-bottom: 80px !important;}
.pdB-set2 {	padding-bottom: 40px !important;}
.pdB-set3 {	padding-bottom: 30px !important;}
.tb-mgT-set1 {	margin-top: 80px !important;}
.tb-mgT-set2 {	margin-top: 40px !important;}
.tb-mgT-set3 {	margin-top: 30px !important;}
.tb-mgT-set4 {	margin-top: 30px !important;}
.tb-pdT-set1 {	padding-top: 80px !important;}
.tb-pdT-set2 {	padding-top: 40px !important;}
.tb-pdT-set3 {	padding-top: 30px !important;}
.alC-sp-alL { text-align: center !important;}
}

@media screen and (max-width: 767px){
.w20-sp-w100,
.w25-sp-w100,
.w30-sp-w100,
.w35-sp-w100,
.w40-sp-w100 { width: 100% !important;}
.sp-w10 { width: 10% !important;}
.sp-w15 { width: 15% !important;}
.sp-w20 { width: 20% !important;}
.sp-w25 { width: 25% !important;}
.sp-w30 { width: 30% !important;}
.sp-w35 { width: 35% !important;}
.sp-w40 { width: 40% !important;}
.sp-w45 { width: 45% !important;}
.sp-w50 { width: 50% !important;}
.sp-w55 { width: 55% !important;}
.sp-w60 { width: 60% !important;}
.sp-w65 { width: 65% !important;}
.sp-w70 { width: 70% !important;}
.sp-w75 { width: 75% !important;}
.sp-w80 { width: 80% !important;}
.sp-w85 { width: 85% !important;}
.sp-w90 { width: 90% !important;}
.sp-w95 { width: 95% !important;}
.sp-w100 { width: 100% !important;}
.mgT-set1 {	margin-top: 50px !important;}
.mgT-set2 {	margin-top: 40px !important;}
.mgT-set3 {	margin-top: 30px !important;}
.mgT-set4 {	margin-top: 30px !important;}
.pdT-set1 {	padding-top: 50px !important;}
.pdT-set2 {	padding-top: 40px !important;}
.pdT-set3 {	padding-top: 30px !important;}
.mgB-set1 {	margin-bottom: 50px !important;}
.mgB-set2 {	margin-bottom: 40px !important;}
.mgB-set3 {	margin-bottom: 30px !important;}
.pdB-set1 {	padding-bottom: 50px !important;}
.pdB-set2 { padding-bottom: 40px !important;}
.pdB-set3 { padding-bottom: 30px !important;}
.sp-mgT-set1 {	margin-top: 50px !important;}
.sp-mgT-set2 {	margin-top: 40px !important;}
.sp-mgT-set3 {	margin-top: 30px !important;}
.sp-mgT-set4 {	margin-top: 30px !important;}
.sp-pdT-set1 {	padding-top: 50px !important;}
.sp-pdT-set2 {	padding-top: 40px !important;}
.sp-pdT-set3 {	padding-top: 30px !important;}
.sp-mgB-set1 {	margin-bottom: 50px !important;}
.sp-mgB-set2 {	margin-bottom: 40px !important;}
.sp-mgB-set3 {	margin-bottom: 30px !important;}
.sp-pdB-set1 {	padding-bottom: 50px !important;}
.sp-pdB-set2 { padding-bottom: 40px !important;}
.sp-pdB-set3 { padding-bottom: 30px !important;}
.alC-sp-alL { text-align: left !important;}
.sp-mgT0 { margin-top: 0 !important;}
.sp-mgT5 { margin-top: 5px !important;}
.sp-mgT10 { margin-top: 10px !important;}
.sp-mgT15 { margin-top: 15px !important;}
.sp-mgT20 { margin-top: 20px !important;}
.sp-mgT25 { margin-top: 25px !important;}
.sp-mgT30 { margin-top: 30px !important;}
.sp-mgT35 { margin-top: 35px !important;}
.sp-mgT40 { margin-top: 40px !important;}
.sp-mgT45 { margin-top: 45px !important;}
.sp-mgT50 { margin-top: 50px !important;}
}

