@charset "utf-8";

/*
Site Name: 
Description: parts style
*/

/* header
----------------------------------------- */
#header #header-logo{
	float: left;
	width: 125px;
	margin: 5px 15px;
	padding: 0;
	display: none;
}
#header #copy-area{
	width: 100%;
	height: 40px;
	background: rgba(17, 17, 17, 0.6);
	clear: both;
	display: table;
}
#header #copy-area .copy{
	color: #FFF;
	font-size: 65%;
	width: calc(100% - 215px);
	margin: 0;
	padding: 0 20px;
	text-align: left;
	vertical-align: middle;
	display: table-cell;
}
#header #copy-area p.tel{
	float: right;
	margin: 0;
	padding: 0;
	display: table-cell;
}
#header #copy-area p.tel a{
	width: 215px;
	height: 40px;
	padding-left: 20px;
	background-color: #111;
	vertical-align: middle;
	display: table-cell;
	position: relative;
}
#header #copy-area p.tel a::before{
	content: "";
	width: 13px;
	height: 13px;
	background-image: url(../img/tel_icon.png);
	background-repeat: no-repeat;
	background-position: right top;
	background-size: cover;
	position: absolute;
	left: 15px;
	top: 12px;
}
#header #copy-area p.tel a img{
	width: 156px;
}
.fixed #header #header-logo{
	display: block;
}
.fixed #header #copy-area{
	float: right;
	width: auto;
	clear: none;
	display: inline;
}
.fixed #header #copy-area .copy{
	display: none;
}
@media all and (max-width: 768px){
#header #copy-area .copy{
	padding: 0 5px;
}
#header #copy-area p.tel a{
	width: 40px;
	padding-left: 0px;
	display: block;
}
#header #copy-area p.tel a img{
	display: none;
}
}

/* nav
----------------------------------------- */
nav#gloval-nav{
	margin: 0px auto;
	text-align: center;
	overflow: hidden;
}
nav#gloval-nav ul{
	margin: 0;
	padding: 0;
	clear: both;
}
nav#gloval-nav ul li{
	width: 20%;
	float: left;
	margin: 0;
	padding: 0;
	list-style-type: none;
	display: table;
}
nav#gloval-nav ul li a{
	color: #0A4840;
	font-weight: bold;
	height: 62px;
	padding: 0 5px;
	background-color: #FFF;
	text-decoration: none;
	vertical-align: middle;
	transition: none;
	display: table-cell;
}
nav#gloval-nav ul li a:hover,
nav#gloval-nav ul li.active a{
	background-color: #EEE;
}
nav#spmenu{
	display: none;
}
.fixed nav#gloval-nav ul li{
	width: 120px;
}
.fixed nav#gloval-nav ul li a{
	color: #FFF;
	font-size: 90%;
	height: 40px;
	background-color: #000;
}
.fixed nav#gloval-nav ul li a:hover,
.fixed nav#gloval-nav ul li.active a{
	color: #0A4840;
	background-color: #EEE;
}
@media all and (max-width: 768px){
nav#gloval-nav{
	display: none;
}
nav#spmenu{
	float: none;
	width: 100%;
	margin: 0px;
	background: rgba(17, 17, 17, 0.6);
	position: fixed;
	top: 40px;
	z-index: 600;
	display: none;
}
.nav-open nav#spmenu{
	display: block;
}
nav#spmenu ul{
	margin: 0px;
	padding: 0px;
	display: block;
}
nav#spmenu ul li{
	list-style-type: none;
}
nav#spmenu ul li a{
	color: #FFF;
	font-weight: bold;
	padding: 10px;
	display: block;
	text-decoration: none;
}
nav#spmenu ul li a:hover,
nav#spmenu ul li.active a{
	background: rgba(17, 17, 17, 0.6);
	text-decoration: none;
}
}


/* footer
----------------------------------------- */
#footer #footer-contents{
	background-color: #FFF;
	overflow: hidden;
}
#footer ul.sns-list{
	float: left;
	margin: 20px;
	padding: 0;	
}
#footer ul.sns-list li{
	width: 23px;
	margin: 0 2px;
	padding: 0;
	line-height: 0;
	list-style-type: none;
	display: inline-block;
}
#footer #pagetop{
	float: right;
	margin: 20px;
	padding: 0;
	position: relative;
	cursor: pointer;
}
#footer #pagetop::before{
	content: "";
	width: 14px;
	height: 7px;
	margin-right: 5px;
	background-image: url(../img/pagetop.png);
	background-repeat: no-repeat;
	background-position: left top;
	background-size: cover;
	display: inline-block;
}
#footer #footer-logo{
	float: left;
	width: 108px;
	margin: 20px 0;
	padding: 0;	
}
#footer p#copyright{
	float: right;
	color: #FFF;
	font-size: 80%;
	font-family: Verdana;
	margin: 30px 0;
	padding: 0;
	
}


/* content
----------------------------------------- */
#visual{
	width: 100%;
	overflow: hidden;
	position: relative;
	z-index: 1;
}
#visual div{
	z-index: 1;
}
#visual div img{
	width: 100%;
}

#visual #logo{
	width: 250px;
	height: 250px;
	margin: 0;
	padding: 0;
	transform: translateY(-50%) translateX(-50%);
	-webkit- transform: translateY(-50%) translateX(-50%);
	position: absolute;
	top: calc(50% - 60px);
	left: 50%;
	z-index: 2;
}
#contents #visual #logo{
	width: 170px;
	height: 170px;	
}
@media all and (max-width: 1280px){
#contents #visual div img{
	width: auto;
	max-width: none;
	height: 300px;
}
}
@media all and (max-width: 768px){
#visual #logo{
	width: 180px;
	height: 180px;
	top: 50%;
}	
#contents #visual #logo{
	width: 125px;
	height: 125px;	
}
#contents #visual div img{
	height: 250px;
}
}
@media all and (max-width: 640px){

}




ul.slider{
	margin: 0;
	padding: 0;
}
ul.slider li{
	float: left;
	margin: 0;
	padding: 0;
	list-style-type: none;
}

#address-section{
	margin: 80px 0;
	text-align: left;
	overflow: hidden;
	clear: both;
}
#contents #address-section{
	margin: 60px 0 40px;
}
#address-section #facebook{
	float: left;
	width: 46.315%;
	margin-bottom: 40px;
}
#address-section #shop-info{
	float: right;
	width: 46.315%;
}
#address-section #shop-info address{
	margin-bottom: 20px;
}
#address-section #shop-info address h4{
	color: #0A4840;
	font-size: 135%;
	font-weight: bold;
	margin: 0 0 5px;
	padding: 0 0 0 15px;
	position: relative;
}
#address-section #shop-info address h4::before{
	content: "";
	width: 6px;
	height: 25px;
	background-color: #0A4840;
	border-radius: 5px;
	display: block;
	position: absolute;
	left: 0;
	top: 0;
}
@media all and (max-width: 768px){
#address-section #facebook,
#address-section #shop-info{
	float: none;
	width: 100%;
}
}


#history-section canvas{
	width: 100%;
	position: absolute;
	top: 0;
	left:0;  
}
#waveCanvas{
	transform: rotateX(180deg);
}
  

/* main css
----------------------------------------- */
#main ul,
#main ol,
#main p{
	padding: 0px 0px 0.5em;
}

#main h2,
#main h3,
#main h4,
#main h5,
#main h6,
#main p{
	margin: 0 0px 15px;
	padding-bottom: 0;
}

#main h2{
	font-size: 150%;
	font-weight: bold;
	color: #0A4840;
	margin: 30px 0;
	padding: 0;
	text-align: center;
	position: relative;
	clear: both;
}
#main h2::before{
	content: "";
	width: 53px;
	height: 70px;
	margin-bottom: 30px;
	background-image: url(../img/headline2_icon.png);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	transform: translateX(-50%);
	-webkit- transform: translateX(-50%);
	position: relative;
	left: 50%;
	display: block;
}
#main h3{
	color: #0A4840;
	font-size: 135%;
	font-weight: bold;
	margin: 45px 0 20px;
	padding: 0 0 0 15px;
	position: relative;
}
#main h3::before{
	content: "";
	width: 6px;
	height: 25px;
	background-color: #0A4840;
	border-radius: 5px;
	display: block;
	position: absolute;
	left: 0;
	top: 0;
}
#contents #main h4{

}

#main ul li{
	margin-left: 5px;
	padding-left: 10px;
	background-image: url(../img/list_icon.png);
	background-repeat: no-repeat;
	background-position: left 5px;
	list-style-type: none;
}
main ul li ul,
#main ul li ol{
	padding: 5px 0px;
	margin-bottom: 0px;
}

#main ol li{
	margin-left: 25px;
	list-style-type: decimal;
}
#main ol li ol,
#main ol li ul{
	padding: 5px 0px;
	margin-bottom: 0px;
}
#main ol li ul li{
	list-style-type: none;
}

#main table{
	width: 98%;
	font-size: 100%;
	margin: 0px 0px 30px 0px;
	border-bottom: #CCCCCC solid 1px;
	/*border-left: #CCCCCC solid 1px;*/
}
#main table p{
	padding-left: 0px;
}
#main table th,
#main table td{
	padding: 10px;
	border-top: #CCCCCC solid 1px;
	/*border-right: #CCCCCC solid 1px;*/
}
#main table th{
	font-weight: bold;
	/*background-color: #EFEFEF;*/
}
#contents #main .bg-black h3{
    color: #FFF;
}
#contents #main .bg-black h3::before{
	background-color: #FFFFFF;

}
#contents #main .bg-black table th{
	font-weight: bold;
}

#contents #main .gallery-list2,
#contents #main .gallery-list3,
#contents #main .gallery-list4{
	margin: 30px -15px;
	padding: 0px;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
	clear: both;
}
#contents #main .gallery-list2{
	margin: 0px -25px 30px;
}
#contents #main .gallery-list2 article,
#contents #main .gallery-list3 article,
#contents #main .gallery-list4 article{
	float: left;
	margin: 0px 0px 25px;
	padding: 0px;
	background: none;
}
#contents #main .gallery-list2 article{
	width: 50%;
}
#contents #main .gallery-list3 article{
	width: 33.333%;
}
#contents #main .gallery-list4 article{
	width: 25%;
}
#contents #main .gallery-list2 article .gallery-inner{
	margin: 0px 25px;
}
#contents #main .gallery-list3 article .gallery-inner,
#contents #main .gallery-list4 article .gallery-inner{
	margin: 0px 15px;
}

#contents #main ul.page-nav{
	margin: 0px auto;
	padding: 0px 0px;
	display: table;
	overflow: hidden;
}
#contents #main ul.page-nav li{
	margin: 0px;
	padding: 0px;
	display: inline-block;
	background: none;
}
#contents #main ul.page-nav li a{
	padding: 0px 15px;
	border-left: #cccccc solid 1px;
}
#contents #main ul.page-nav li:first-child a{
	border-left: none;
}




@media all and (max-width: 990px){
#main h2{
	font-size: 180%;
}
#main table th,
#main table td{
	display: block;
}	
#contents #main .gallery-list2{
	margin: 0px;
}
#contents #main .gallery-list3,
#contents #main .gallery-list4{
	margin: 0px -10px;
}
#contents #main .gallery-list2 article .gallery-inner{
	margin: 0px;
}
#contents #main .gallery-list3 article .gallery-inner,
#contents #main .gallery-list4 article .gallery-inner{
	margin: 0px 10px;
}
#contents #main .gallery-list2 article{
	float: none;
	width: 100%;
}
#contents #main .gallery-list3 article,
#contents #main .gallery-list4 article{
	width: 50%;
}
}
	


/* history */
#main #history-section{
	color: #FFF;
	background-image: url(../img/history-section_bg.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	overflow: hidden;
	position: relative;
}
#main #history-section::before{
	content: "";
	width: 100%;
	height: 100%;
	background: rgba(51, 51, 51, 0.7);
	position: absolute;
	left: 0;
	top: 0;
}
#main #history-section .inner{
	padding-top: 155px;
}
#main #history-section ul.image-list{
	width: 1000px;
	margin: 0 -25px;
	padding: 0;
	clear: both;
	text-align: center;
	position: absolute;
	top: 10px;
}
#main #history-section .slick-list{
	overflow: visible;
}
#main #history-section ul.image-list li{
	float: left;
	/*width: calc(20% - 50px);*/
	margin: 0;
	padding: 0;
	background: none;
	text-align: center;
}
#main #history-section ul.image-list li img{
	width: 100%;
	height: 100%;
	/*width: 138px!important;
	height: 138px!important;*/
	max-width: 138px;
	margin: 0 auto;
	border-radius: 300px;
	display: block;
}
#main #history-section h2{
	color: #FFF;
	margin: 30px 0;
}
#contents #main #history-section h2{
	margin: 30px 0 -20px;
}
#main #history-section h2::before{
	content: none;
}
#main #history-section ul.btn-list{
	margin: 50px auto;
	text-align: center;
	display: table;
	overflow: hidden;
}
#main #history-section ul.btn-list li{
	float: left;
	margin: 0 10px;
	padding: 0;
	background-image: none;
}
#main #history-section ul.btn-list li a.btn{
	border: #999 solid 1px;
}
@media all and (max-width: 1000px){
	#main #history-section ul.image-list{
		width: 100%;
		margin: 0;
		left: 0;
	}
}
@media all and (max-width: 768px){
#main #history-section ul.image-list{
	/*margin: 0 auto;
	display: inline-flex;
	transform: translateX(-50%);
	-webkit- transform: translateX(-50%);
	position: relative;
	left: 50%;*/
}
#main #history-section ul.image-list li{
	/*float: left;
	width: 150px;
	margin: 0 15px;
	padding: 0;
	list-style-type: none;*/
}
}
@media all and (max-width: 640px){
#main #history-section ul.btn-list{
	width: 100%;
	margin: 50px -10px;
}
#main #history-section ul.btn-list li{
	width: calc(50% - 20px);
}
#main #history-section ul.btn-list li a{
	padding-left: 5px;
	padding-right: 5px;
	display: block;
}
}
@media all and (max-width: 480px){
#main #history-section ul.image-list li{
	padding: 0 10px;
}
}


/* home css
----------------------------------------- */
/* concept */
#home #main #concept-section{
	padding-bottom: 60px;
}
@media all and (max-width: 768px){
#home #main #concept-section .inner{
	max-width: calc(100% - 60px);
	margin: 0 30px;
	background-color: #FFF;
	overflow: hidden;
	z-index: 10;
	position: relative;
	top: -40px;
}
}


/* concept css
----------------------------------------- */
#contents .concept #main .concept-area{
	margin-bottom: 20px;
	background-color: #F3F3F3;
	text-align: center;
}
#contents .concept #main .concept-area p{
	color: #0A4840;
	font-size: 135%;
	font-weight: bold;	
	margin: 0;
	padding: 20px 10px;
    line-height: 1.8;
}

/* contact css
----------------------------------------- */
#contents .contact #main section form span.supplement{
	font-size: 80%;
	font-weight: normal;
	margin-top: 5px;
	display: block;
}
#contents .contact #main section form label#privacy-check{
	color: #111111;
	font-weight: bold;
	margin: 15px 0px 25px;
	padding: 5px 10px;
	background-color: #F3F3F3;
	display: block;
	position: relative;
}
#contents .contact #main section form label#privacy-check label.error{
	width: 100%;
	margin-bottom: 35px;
	position: absolute;
	left: 0;
	top: 35px;
}

#contents .contact #main section form input[type="text"],
#contents .contact #main section form textarea{
	width: calc(100% - 12px);
	max-width: 360px;
	padding: 5px;
	/*border-radius: 5px;*/
	border: 1px solid #CCC;
	background-color: #F3F3F3;
}
#contents .contact #main section form input[type="text"]:focus,
#contents .contact #main section form textarea:focus{
	background-color: #FFF;
}
#contents #main form input[type="checkbox"]{
	border: 1px solid #CCC;
}
#contents #main #privacy-area{
	height: 160px;
	margin: 0px;
	padding: 10px;
	border: #CCCCCC solid 1px;
	overflow: auto;
}
#contents #main form p.button{
	text-align: center;
}
#contents #main form p.button button,
#contents #main #formWrap form input[type="submit"]{
	color: #FFF;
	font-weight: bold;
	width: 280px;
	padding: 15px 10px;
	background-color: #0A4840;
	border: #0A4840 solid 1px;
	cursor: pointer;
}
#contents #main form p.button button:hover,
#contents #main #formWrap form input[type="submit"]:hover{
    background-color: #083A33;
}
