@charset "utf-8";
@import url('https://fonts.googleapis.com/earlyaccess/notosansjp.css');
@import url('https://fonts.googleapis.com/css?family=Montserrat:500');
html {
	font-size: 62.5%;
}
body {
	position: relative;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	font-size: 12px;
	line-height: 200%;
	font-family: 'Noto Sans JP', sans-serif;
	color: #8f4332;
	background-color: #fff;
}
.bgNoPattern {
	background-color: #f8efe8;
}
#contentsWrapper .fontEn {
	font-family: 'Montserrat', sans-serif;
}
#contentsWrapper a {
	color: #8f4332;
	text-decoration: none;
	transition: all 300ms linear;
}
#contentsWrapper a:hover {
	color: #d42525;
}
#contentsWrapper .btn a {
	display: block;
	width: 95%;
	margin: 1.3em auto;
	padding: 0.75em 0;
	color: #fff;
	background-color: #78c909;
	border-radius: 4px;
	transition: all 200ms linear;
}
#contentsWrapper .btn a:hover {
	margin: 1.6em auto 1em;
	text-decoration: none;
}
img.cover {
	width: 100%;
	height: auto;
}
#loaderBase {
	display: none;
	position: fixed;
	width: 100%;
	height: 100vh;
	top: 0px;
	left: 0px;
	background-color: #fff;
	z-index: 200;
}
.init {
	opacity: 0;
	-webkit-transform: translateY(20px);
	transform: translateY(20px);
}
.preload {
	display: none;
}
.dispWide {
	display: block;
}
.dispNarrow {
	display: none;
}
.alignCenter {
	text-align: center;
}
h3 .fontEn {
	display: block;
}
.textIndent {
	margin-left: 1em;
	text-indent: -1em;
}
.textWhite {
	color:#fff;
}
.textPink {
	color: #e83355;
}
.textBold {
	font-weight: bold;
}
.textNormal {
	font-weight: normal;
}
.textXXLarge {
	font-size: 34px;
}
.textXLarge {
	font-size: 30px;
	line-height: 120%;
}
.textLarge {
	font-size: 24px;
}
.textRegular {
	font-size: 18px;
	line-height: 200%;
}
.textRegular .icon {
	width: 22px;
	height: 22px;
	vertical-align: sub;
}
.textSmall {
	font-size: 15px;
	line-height: 200%;
}
.textSmall .icon {
	display: inline-block;
	width: 20px;
	height: 20px;
	vertical-align: sub;
}
.textXSmall {
	font-size: 12px;
}
.text0 {
	font-size: 0;
}
.lineHeight130 {
	line-height: 130%;
}
.spacing1 {
	letter-spacing: 0.1em;
}
.spacing2 {
	letter-spacing: 0.2em;
}
.spacing3 {
	letter-spacing: 0.2em;
}
h3.title {
	line-height: 400%;
}
h3.title span + span {
	padding-bottom: 0.8em;
	background-image: url("../images/titleBar.png");
	background-position: center bottom;
	background-repeat: repeat-x;
}
.flexBlock {
	display: -webkit-flex;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	flex-direction: row;
	list-style: none;
	margin: 0 auto;
}
.flexBlockColumn {
	flex-direction: column;
}
#contentsWrapper {
	position: relative;
	overflow: hidden;
}
.widthWrapper {
	position: relative;
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
}
.section .widthWrapper {
	padding: 50px 0 40px;
}
.container {
	position: relative;
	width: 90%;
	margin: 0 auto;
	z-index: 1;
}
/*
.catchVisual {
	padding-bottom: 5em;
}
*/
.catchVisual .slider,
.catchVisual .slider .sliderImage,
.catchVisual > div {
	height: 100vw;
	max-height: 640px;
}
.catchVisual .slider .sliderImage {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}

.catchVisual .slider {
	background-color: #fff;
}
.catchVisual > div {
	width: 100%;
}
.catchVisual .slider .sliderImage {
	position: relative;
	opacity: 0.4;
	-webkit-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.catchVisual .slider .sliderImage.slick-active,
.catchVisual .slider .sliderImage.slick-current {
	opacity: 1;
	-webkit-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.catchVisual .slider .sliderImage > a,
.catchVisual > div > a,
.catchVisual .slider .sliderImage > span,
.catchVisual > div > span {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.catchVisual .slick-list {
	z-index: 1;
}
.slider {
	height: 100vh;
	overflow: hidden;
}
@media screen and (max-width:800px){
	.slider {
		height:auto!important;
	}
}
.mainVisual {
	position: relative;
	width: 100%;
	height: 100vh;
	height: calc(100vh - 48px);
	max-height: 68vw;
	margin: 0 auto;
	padding: 0;
	border: 20px solid #fff;
	box-sizing: border-box;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}
.mainVisual .iconNew {
	position: absolute;
	top: 20px;
	left: 20px;
	width: 4vw;
	max-width: 78px;
}
.mainVisual .btnDetail a {
	position: absolute;
	bottom: 10px;
	right: 0;
	display: block;
	padding: 0.5em 1em 0.5em 2em;
	background-color: #fff;
	z-index: 50;
}
.mainVisual .btnDetail a:hover {
	right: -0.5em;
	color: #8f4332;
}
.mainVisual h2 {
	position: absolute;
	top: 0;
	left: 78px;
	/*
	left: 4vw;
	*/
	width: 15%;
	height: 15%;
	background-image: url("../images/logoTabemas.png");
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
}
.mainVisual.motch h2 {
	background-image: url("../images/logoMotch.png");
}
.mainVisual.assorted h2 {
	background-image: url("../images/logoTabemas.png");
}
.mainVisual .container {
	height: 100%;
}
@media screen and (min-width: 801px) and (max-width: 1280px) {
	.mainVisual {
		height: calc(100vh - 3.8vw);
		border: 1.5625vw solid #fff;
	}
	.mainVisual .iconNew {
		position: absolute;
		top: 1.5625vw;
		left: 1.5625vw;
	}
	.mainVisual .btnDetail a {
		bottom: 0.78125vw;
	}
	.mainVisual h2 {
		left: 6.09375vw;
	}
}
@media screen and (max-width:800px){
	.mainVisual {
		position: relative;
		height: calc(100vh - 15vw);
		max-height: 132vw;
		border: 5.2vw solid #fff;
	}
	.mainVisual .iconNew {
		top: 2.8vw;
		left: 2.8vw;
		width: 10.4vw;
		height: 10.4vw;
	}
	.mainVisual h2 {
		top: 0;
		left: 15vw;
		width: 25%;
		height: 25%;
		background-position: center top;
	}
	.mainVisual .btnDetail a {
		bottom: 0;
	}
	.mainVisual .container {
		width: 100%;
	}
}
#news .widthWrapper {
	padding: 30px 0 45px;
}
#news h3 {
	margin-bottom: 1.25em;
}
#news li span {
	margin-right: 1em;
}
#about {
	position: relative;
	height: 38.8888vw;
	max-height: 560px;
	background-color: #f8eeec;
	background-image: url("../images/pc/bgAbout.png");
	background-position: center top;
	background-repeat: repeat-x;
}
#about .obj {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 46.52777vw;
	max-height: 670px;
	background-image: url("../images/pc/bgAboutObj.png");
	background-position: center top;
	background-repeat: no-repeat;
	background-size: auto 100%;
	overflow: visible;
}
#about .widthWrapper {
	height: 32.6vw;
	max-height: 470px;
}
#about.action .obj {
	animation: fadeAndSlideIn 0.25s linear forwards;
}
#about.action .widthWrapper {
	animation: fadeAndSlideIn 0.25s linear 0.15s forwards;
}
#about .flexBlock {
	height: 32.6vw;
	max-height: 470px;
}
#about .flexBlock h4 {
	margin: 0.5em auto;
}
#about .flexBlock p {
	line-height: 270%;
}
#about .flexBlock p.textWithTradeMark {
	transform: translateY(-1em);
}
#about .flexBlock p.textWithTradeMark .logoImg {
	display: inline-block;
	width: 5.25em;
	height: 3em;
	transform: translateY(0.75em);
	background-image: url("../images/logoTabemas.png");
	background-position: left 0.5em top;
	background-repeat: no-repeat;
	background-size: 100% auto;
}
#items {
	padding-bottom: 1.5em;
	background-color: #faf4d5;
}
#items .itemList {
	justify-content: center;
}
#items .itemList:nth-child(n+2) {
	display: none;
}
#items .itemList li {
	width: 23%;
	margin: 0 1% 1.5em;
	border-bottom: 1px dashed #8f4332;
	box-sizing: border-box;
}
#items .itemList li.btnMore {
	width: 100%;
	margin: 0;
	border-bottom: none;
}
#items .itemList li.btnMore > span {
	display: block;
	width: 31.5%;
	margin: 1em auto;
	padding: 0.5em 1em;
	color: #843929;
	border: 2px solid #843929;
	cursor: pointer;
	transition: all 200ms linear;
}
#items .itemList li.btnMore > span span {
	padding-right: 1.2em;
	background-image: url("../images/arrowMore.png");
	background-position: right center;
	background-repeat: no-repeat;
	background-size: 1.2em 1.2em;
	transition: all 200ms linear;
}
#items .itemList li.btnMore > span:hover {
	color: #fff;
	background-color: #843929;
	border: 2px solid #843929;
}
#items .itemList li.btnMore > span:hover span {
	background-image: url("../images/arrowMoreHover.png");
}

#items .itemList li a .thumb {
	display: block;
	position: relative;
	width: 100%;
	padding-top: 100%;
	background-color: #fff;
	opacity: 1;
	transition: all 300ms linear;
	overflow: hidden;
}
#items .itemList li a:hover .thumb {
	opacity: 0.8;
}
#items .itemList li a .thumb img {
	position: absolute;
	width: 101%;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
}
#items .itemList li .itemName {
	margin: 0.5em 0;
	padding: 0.5em 0;
	line-height: 165%;
	/*
	background-image: url("../images/iconEnd.png");
	background-position: left center;
	background-repeat: no-repeat;
	background-size: auto 4em;
	*/
}
#items .itemList li.new .itemName {
	background-image: url("../images/iconNew.png");
}
#items .itemList li .itemName.itemNameLong,
#items .itemList li.new .itemName.itemNameLong {
	background-size: contain;
}
footer {
	padding: 3em 0 2em;
	background-color: #e6f1e5;
}
footer p {
	margin-bottom: 2em;
}
.snsBlock .snsIcon {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}
.snsBlock .snsIcon a,
.snsBlock .snsIcon img {
	position: relative!important;
	width: 100%!important;
	height: 100%!important;
}
.snsBlock .snsIcon a {
	display: block;
}
.mainVisual .snsBlock {
	position: absolute;
	top: 40px;
	right: 2em;
	z-index: 50;
}
footer .snsBlock {
	justify-content: center;
	margin-bottom: 2em;
}
.mainVisual .snsBlock .snsIcon,
footer .snsBlock .snsIcon {
	width: 3.5vw;
	max-width: 40px;
	height: 3.5vw;
	max-height: 40px;
}
.mainVisual .snsBlock .snsIcon {
	margin-left: 4px;
}
footer .snsBlock .snsIcon {
	margin: 0 4px;
}
footer .snsBlock .twitter {
	background-image: url("../images/iconTwitterBrown.png");
}
footer .snsBlock .facebook {
	background-image: url("../images/iconFacebookBrown.png");
}
#goBack {
	position: fixed;
	right: 10px;
	bottom: 45px;
	width: 10vw;
	max-width: 100px;
	z-index: 100;
}
@media screen and (min-width: 801px) and (max-width: 1200px) {
	.textXXLarge {
		font-size: 2.8vw;
	}
	.textXLarge {
		font-size: 2.5vw;
	}
	.textLarge {
		font-size: 2vw;
	}
	.textRegular {
		font-size: 1.5vw;
	}
	.textRegular .icon {
		width: 2vw;
		height: 2vw;
		vertical-align: sub;
	}
	.textSmall {
		font-size: 1.25vw;
	}
	.textSmall .icon {
		width: 1.6666vw;
		height: 1.6666vw;
		vertical-align: sub;
	}
	.textXSmall {
		font-size: 1vw;
	}
	.section .widthWrapper {
		padding: 4.58vw 0 3.75vw;
	}
	#news .widthWrapper {
		padding: 2.5vw 0 4.2vw;
	}
	#about .flexBlock h4 {
		margin: auto;
	}
	footer {
		padding: 1.5em 0 1em;
	}
	footer p {
		margin-bottom: 1em;
	}
	.mainVisual .snsBlock {
		top: 2.5vw;
	}
	footer .snsBlock {
		margin-bottom: 1em;
	}
}
@media screen and (max-width: 800px) {
	#contentsWrapper .btn a,
	#contentsWrapper .btn a:hover {
		width: 100%;
		margin: 0.75em auto;
	}
	#loader {
		width: 100px;
		height: 100px;
		margin-top: -50px;
		margin-left: -50px;
	}
	.dispWide {
		display: none;
	}
	.dispNarrow {
		display: block;
	}
	.title .textNormal {
		font-weight: bold;
		letter-spacing: 0.1em;
	}
	.textXXLarge {
		font-size: 7vw;
	}
	.textXLarge {
		font-size: 5.86vw;
	}
	.textLarge {
		font-size: 4.6vw;
	}
	.textRegular,
	.textSmall {
		font-size: 3.2vw;
	}
	.textRegular .icon {
		width: 4.5vw;
		height: 4.5vw;
		vertical-align: text-top;
	}
	.textSmall .icon {
		width: 4vw;
		height: 4vw;
		vertical-align: sub;
	}
	#about .spacing1 + .textSmall,
	.textXSmall {
		font-size: 2.4vw;
	}
	h3.title .spacing1 {
		letter-spacing: 0.075em;
	}
	.spacing2 {
		letter-spacing: 0.12em;
	}
	h3.title {
		line-height: 260%;
	}
	h3.title span + span {
		background-size: auto 3px;
	}
	.section .widthWrapper {
		padding: 8vw 0 4vw;
	}
	.container {
		width: 92%;
	}
	#news .widthWrapper {
		padding: 6vw 0;
	}
	#news h3 {
		margin-bottom: 0.5em;
	}
	#news ul {
		line-height: 160%;
	}
	#news li + li {
		margin-top: 0.5em;
	}
	#news li span {
		display: block;
		margin-right: 1em;
	}
	#about {
		position: relative;
		height: 148vw;
		min-height: 148vw;
		background-image: url("../images/sp/bgAbout.png");
		background-position: center top;
		background-repeat: repeat-x;
		background-size: auto 17.3vw;
	}
	#about .obj {
		height: 50vw;
		max-height: 50vw;
		background-image: url("../images/sp/bgAboutObj2.png");
		background-size: 100% auto;
	}
	#about .widthWrapper {
		height: auto;
		max-height: 110vw;
		padding-bottom: 60vw;
		background-image: url("../images/sp/bgAboutObj.png");
		background-position: center bottom;
		background-repeat: no-repeat;
		background-size: 100% auto;
	}
	#about .flexBlock {
		height: auto;
		max-height: inherit;
	}
	#about .flexBlock h4 {
		line-height: 160%;
	}
	#about .flexBlock p {
		line-height: 250%;
	}
	#about .flexBlock p.textWithTradeMark .logoImg {
		width: 7em;
		height: 4em;
		transform: translateY(1em);
	}

	#items {
		padding: 2vw 0 10vw;
	}
	#items .itemList li {
		width: 48%;
		margin: 10vw 1% 0;
	}
	/*
	#items .itemList li:first-child {
		margin-top: 5vw;
	}
	*/
	#items .itemList li.btnMore > span {
		width: 92%;
		margin: 10vw auto 0;
		box-sizing: border-box;
		border: 1px solid #843929;
	}
	footer {
		padding: 3em 0 2em;
	}
	footer p {
		width: 92%;
		margin: 0 auto 1em;
		line-height: 190%;
	}
	.mainVisual .snsBlock {
		position: absolute;
		top: 3vw;
		right: 3vw;
	}
	.mainVisual .snsBlock .snsIcon,
	footer .snsBlock .snsIcon {
		width: 7.8vw;
		max-width: 7.8vw;
		height: 7.8vw;
		max-height: 7.8vw;
	}
	.mainVisual .snsBlock .snsIcon {
		margin-left: 1.335vw;
	}
	footer .snsBlock .snsIcon {
		margin: 0 1vw;
	}
	#goBack {
		bottom: 60px;
		width: 15vw;
	}
}
/* animation */
@keyframes fadeAndSlideIn {
	0% {
		opacity: 0;
		-webkit-transform: translateY(20px);
		transform: translateY(20px);
	}
	100% {
		opacity: 1;
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}
