@charset "UTF-8";
/* CSS Document */
/*----------------------------------
	共通部分
----------------------------------*/
html{
	font-size: 62.5%;
	background-color: #ffffff;
	overflow-x:hidden;
	overflow-y:auto;
}
h1{
	display: none;
}
body{
	overflow-x:hidden;
	overflow-y:auto;
	font-family: 'Noto Serif JP', serif;
	line-height: 1.7;
	color: #333333;
}
a{
	text-decoration: none;
}
img{
	max-width: 100%;
}
.wrapper{
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 4%;
  	text-align: center;
}
.main-visual {
	background-size:cover;
	background-position: left;
	background-repeat: no-repeat;
    height: 340px;
	margin-bottom: 40px;
	position: relative;
}
.main-visual::before{
	background-color: rgba(0,0,0,.4) ;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	content: ' ';
}
.page-title{
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform : translate(-50%,-50%);
	transform : translate(-50%,-50%);
	color:#fff;
	font-size: 32px;
	letter-spacing: 0.05em;
}

/*----------------------------------
	header
----------------------------------*/
.menu-btn{
	display: none;
}
.page-header{
/*    background: rgba(255,255,255,0.1);*/
	display: flex;
    padding: 5px 20px;
    position: fixed;
    justify-content: space-between;
    transition: .5s;
    width: 100%;
	z-index: 2;
}
.page-header img{
	display: none;
}
.page-header.transform{
    background: rgba(255,255,255,0.9);
/*    padding: 10px;*/
}
.page-header.transform a{
	color: #333333;
}
.page-header.transform img{
	display:block;
}
/*
.page-header{
	display: flex;
	justify-content: space-between;
}
*/
.logo{
	width: 77px;
	height: auto;
	margin: auto 36px;
}
.main-nav{
	display: flex;
	font-size: 1.4rem;
	text-transform: uppercase;
	margin-top: 8px;
	list-style: none;
}
/*
.menu-sp{
	display: none;
}
*/
.sp{
	display: none;
}
.main-nav li{
	margin-left: 36px;
}
.main-nav li:last-of-type{
	margin-right: 36px;
}
.main-nav a{
	color: #FFFFFF;
}
.main-nav a:hover{
	color: #DEDEDE;
}
/*----------------------------------
	home
----------------------------------*/

/*---main visual---*/
#home-main-visual{
/*	background-image: url("../images/home/main_tenseiro.jpg");*/
/*.home-main-visual-img{*/
	width: 100vw;
	height: 100vh;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	display: flex;
/*  	position: relative;*/
}
.home-main-visual-logo{
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform : translate(-50%,-50%);
	transform : translate(-50%,-50%);
}
.home-main-visual-logo img{
	width: 60%;
	height: auto;
}
/*---共通---*/
.home-contents-title h2{
	padding: 40px 0 40px;
	font-size: 2.4rem;
	font-weight: normal;
}
.readmore{
	margin: 20px auto 40px;
}
.readmore img{
	width: 160px;
	height: auto;
	margin-right: 10px;
}
.readmore a{
	color: #333333;
	font-size: 1.6rem;
}
.readmore a:hover{
	color: #DEDEDE;
}
/*---menu---*/
.home-menu-img{
	max-width: 600px;
	min-width: 240px;
	width:100%;
	height: auto;
	margin: 0 auto;
}
.home-menu p{
	text-align:center;
	width: 90%;
	height: auto;
	word-wrap: normal;
	padding: 10px;
	font-size: 1.6rem;
	background-color: #ffffff;
	margin: 10px auto;
}
/*---news---*/
.home-news ul{
	list-style: none;
	margin: 0 0 20px;
	padding: 0;
}
.home-news li a{
	display: block;
	padding: 10px;
	border-bottom: dotted 1px #333333;
	font-size: 1.6rem;
	text-decoration: none;
	color: #333333;
}
.home-news li a:hover{
	background-color: #f3f3f3;
}
.home-news li a:after{
	content: "";
	display: block;
	clear: both;
}
.home-news li img{
	float: left;
	width: 20%;
	height: auto;
	border: none;
}
.home-news-txt{
	float: none;
	width: auto;
	margin-left: 20%;
	padding-left: 20px;
	text-align: left;
}
.home-news-txt span{
	display: block;
}

/*---kodawari---*/
.home-kodawari-img{
	max-width: 600px;
	min-width: 240px;
	width:100%;
	height: auto;
	margin: 0 auto;
}
.home-kodawari p{
	text-align:left;
	width: 35%;
	height: auto;
	word-wrap: normal;
	padding: 24px;
	font-size: 1.6rem;
	background-color: #ffffff;
	margin: 10px auto;
}

/*---Animation---*/
.sprite{
  width: 126px;
  height: 100px;
  margin: 60px auto;
  background: url("../images/sprite.png") no-repeat 0 0;
}
.sprite {
    /*一秒間に動くフレーム数*/
    -webkit-animation: play 1s steps(6) infinite;
    animation: play 1s steps(6) infinite;
}
@-webkit-keyframes play {
    /*一秒間に動くスタイル*/
    0% {
        background-position: 0px 0;
    }

    100% {
        background-position: -756px 0;
    }
}

@keyframes play {
    /*一秒間に動くスタイル*/
    0% {
        background-position: 0px 0;
    }

    100% {
        background-position: -756px 0;
    }
}
.jQuery .frame1 {
    background: url(../images/sprite.png) no-repeat 0 0;
}

.jQuery .frame2 {
    background: url(../images/sprite.png) no-repeat -126px 0;
}

.jQuery .frame3 {
    background: url(../images/sprite.png) no-repeat -252px 0;
}

.jQuery .frame4 {
    background: url(../images/sprite.png) no-repeat -378px 0;
}

.jQuery .frame5 {
    background: url(../images/sprite.png) no-repeat -504px 0;
}

.jQuery .frame6 {
    background: url(../images/sprite.png) no-repeat -630px 0;
}


/*----------------------------------
	news
----------------------------------*/
/*---news共通---*/
.news-visual{
	background-image: url("../images/news/news_mainv.jpg");
}
/*---news.html---*/
.news-title h2{
	padding: 40px 0 40px;
	font-size: 2rem;
}
.news-list{
	list-style: none;
	color: #333333;
}
.news-list a:hover{
	list-style: none;
	color: #333333;
}
/*---news-記事---*/

.news-contents{
/*	display: flex;*/
/*	justify-content: space-between;*/
	margin-bottom: 50px;
}
.article-txt{
	text-align: left;
	font-size: 1.4rem;
}

/*記事部分*/
article{
	width: 70%;
	margin: 0 auto;
}
.news-contents .readmore{
		margin-top: 70px;
	}
.post-info{
	position: relative;
	padding-top: 4px;
	margin-bottom: 40px;
}
.post-date{
	background: #f3f3f3;
	border-radius: 50%;
	color: #333333;
	width: 100px;
	height: 100px;
	font-size: 1.625rem;
	text-align: center;
	position: absolute;
	top: 0;
	padding-top:20px;
}
.post-date span{
	font-size: 1.2rem;
	border-top: 1px rgba(0,0,0,.4) solid;
	padding-top: 6px;
	display: block;
	width: 60%;
	margin: 0 auto;
}
.post-title{
	font-family: 'Noto Serif JP', serif;
	font-size: 1.8rem;
	font-weight: normal;
	text-align: left;
	margin-left: 140px;
	line-height: 100px;
}
article img{
	margin-bottom: 20px;
}
article p{
	margin-bottom: 1rem;
}

/*----------------------------------
	menu
----------------------------------*/
.menu-visual{
	background-image: url("../images/menu/tenseiro.jpg");
}
.memu-title{
	margin: 40px 0 20px;
}
.memu-title h3{
	font-size: 2.4rem;
	margin-bottom: 10px;
}
.memu-title p{
	font-size: 1.2rem;
	padding-bottom: 30px;
	width: 50%;
	margin: 0 auto;
}
.table-1{
	position: relative;
	height: 300px;
	margin-top:20px;
}
.table-2{
	position: relative;
	height: 150px;
	margin-top:20px;
}
.table-3{
	position: relative;
	height: 230px;
	margin-top:20px;
}
.table-4{
	position: relative;
	height: 120px;
	margin-top:20px;
}
caption{
	font-size: 1.8rem;
	margin-bottom: 10px;
}
.caption-main{
	margin-bottom: 0;
}
.caption-sub{
		font-size: 1.1rem;
	}
td{
	font-size: 1.4rem;
}
td:nth-child(odd){
	text-align: left;
	width: 190px;
}
td:nth-child(even){
	text-align: right;
	width: 80px;
}

.table-left{
	position: absolute;
	left: 10%;
}
.table-right{
	position: absolute;
	right: 10%;
}
.grid {
  display: grid;
  gap: 26px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  margin-top: 40px;
  margin-bottom: 50px;
}
.item p{
	font-size: 1.2rem;
}
/*----------------------------------
	shopinfo
----------------------------------*/
.shopinfo-visual{
	background-image: url("../images/shopinfo/shopinfo_mainv.jpg");
}
.shopinfo-contents-title{
	margin: 20px 0;
	font-size: 2rem;
}
.shopinfo-contents-title:last-of-type{
	margin-top: 40px;
}
.contact-content {
    max-width: 560px;
    margin-top: 10%;
	color: #333333;
	text-align: center;
}
.contact-info{
	max-width: 600px;
	margin: 0 auto;
	text-align: center;	
}
.contact-info p{
	margin: 16px auto;
	text-align: left;
	font-size: 1.4rem;
}
/*
.contact-info p:last-of-type{
	margin-bottom: 50px;
	
}
*/
iframe{
	width: 100%;
	margin-top: 20px;
	margin-bottom: 40px;
}

/*----------------------------------
	footer
----------------------------------*/
footer{
	background: #f3f3f3;
	text-align: center;
	padding: 40px 0;
	margin-top: 100px;
}
footer p{
	font-size: 1.4rem;
}
.footer-logo{
	width: 260px;
	height: auto;
}
.footer-txt{
	margin: 20px 0;
}

@media screen and (max-width: 800px){
	.table-1{
		position: static;
		height: auto;
	}
	.table-2{
		position: static;
		height: auto;
	}
	.table-3{
		position: static;
		height: auto;
	}
	.table-4{
		position: static;
		height: auto;
	}
	.table-left{
		position: static;
		margin: 0 auto;
	}
	.table-right{
		position: static;
		margin: 20px auto 0;
	}
}

@media screen and (max-width: 600px){
	.pc{
		display: none;
	}
	.sp{
		display: block;
	}
	.page-header.transform{
    	background: transparent;
	}
	.page-header{
		flex-direction: column;
		align-items: center;
	}
	
	/*header*/
	.menu-btn{
	  position: fixed;
	  top: 20px;
	  right: 20px;
	  z-index: 20;
	  width: 40px;
	  height: 40px;
	  display: flex;
	  justify-content: center;
	  align-items: center;
	  background: rgba(255,255,255,0.4);
		font-size: 1rem;
	  color: #fff;
	}
	.menu-btn .fa-close{
		display: none;
	}
	.menu{
		position: fixed;
		top: 0;
		right: 0;
		z-index: 1;
		width: 100vw;
		height: 100vh;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		background: rgba(0,0,0,0.7);
		transform: translateX(200vw);
		transition: transform .3s linear;
	}
	.menu-item{
		font-size: 2rem;
		width: 100%;
		height: auto;
		padding: 1.6em 1em;
		text-align: center;
		color: #fff;
		box-sizing: border-box;
	}
/*
	.menu-sp{
		display: block;
	}
*/
	.main-nav{
	display: block;
	font-size: 1.4rem;
	text-transform: uppercase;
	list-style: none;
}
	.main-nav li{
		margin: auto;
	}
.menu.is-active{
  transform: translateX(0);
}

.menu-btn.is-active .fa-close{
  display: block;
}
.menu-btn.is-active .fa-bars{
  display: none;
}
	
/*	メインビジュアル下までスクロール後のスタイル*/
	.page-header.transform .menu-btn{
  background: rgba(0,0,0,0.4);
}
	.page-header.transform a{
	color: #fff;
}
.page-header.transform .main-nav{
	display: block;
	font-size: 1.4rem;
	text-transform: uppercase;
	margin-top: 8px;
	list-style: none;
}
.page-header.transform img{
	display:none;
}
	
	/*home*/
	.home-mainv-cts{
		margin-top: 20%;
	}
	.home-contents-title h2{
		padding: 30px 0 30px;
		font-size: 2rem;
	}
	/*---Animation---*/
	.sprite{
		margin: 60px auto;
	}

	/*news 一覧*/
	.news-title h2{
		padding: 20px 0 20px;
		font-size: 1.8rem;
	}
	/*news article*/
	.news-contents{
		flex-direction: column;
	}
	article{
		width: 100%;
	}
    .post-info {
        margin-bottom: 20px;
		font-size: 1.2rem;
    }
	.post-date{
		background: transparent;
		border-radius: 0%;
		color: #333333;
		width: auto;
		height: auto;
		
		text-align: center;
		position: absolute;
		top: 0;
		padding-top:20px;
	}
	
/*
	.post-date span{
		font-size: 0.875rem;
		padding-top: 2px;
	}
*/
	.post-title span{
		margin-bottom: 5px;
		font-size: 1rem;
	}
	
	.post-title{
		margin-left: 10px;
		line-height: normal;
	}
	.news-contents .readmore{
		margin-top: 40px;
	}
	.readmore a{
		font-size: 1.1rem;
	}
	.readmore img{
		width: 80px;
		height: auto;
	}

	/*
	#news .page-title{
		margin-top: 30px;
	}
*/

	/*menu*/
	.memu-title h3{
		font-size: 2rem;
		margin-bottom: 10px;
	}
	.memu-title p{
		font-size: 1.1rem;
		margin-bottom: 32px;
		width: 70%;
		margin: 0 auto;
	}
	caption{
		font-size: 1.4rem;
	}
	
/*news  article*/
	
	/*共通*/
	.main-visual {
		height: 100px;
		margin-bottom: 40px;
	}
	.page-title{
		top: 50%;
		left: 50%;
		-webkit-transform : translate(-50%,-50%);
		transform : translate(-50%,-50%);
		color:#fff;
		font-size:1.8rem;
		letter-spacing: 0.05em;
	}

	/*shopinfo*/
	.shopinfo-contents-title{
		font-size: 1.4rem;
	}
	/*	footer*/
	footer{
		padding: 40px 0;
		margin-top: 50px;
	}
	.footer-logo{
		width: 100px;
		height: auto;
	}
	/*footer*/
	footer p{
		font-size: 1rem;
	}
	.footer-logo{
		width: 200px;
		height: auto;
	}
}

@media screen and (max-width: 750px){
	article{
		width: 90%;
		margin: 0 auto;
	}
}