@charset "UTF-8";

/* -------------------------------------------
	over write
	base font size PC: 16px SP: 14px
---------------------------------------------- */
.wrapper { font-family: 'Noto Sans JP',sans-serif; font-size: 133.3333%; overflow: hidden; }
.wrapper b { font-weight: 700; }
.wrapper img { width: auto; height: auto; vertical-align: top; }
.container { position: relative; margin: 0 auto; padding-right: 13px; padding-left: 13px; max-width: 1200px; z-index: 10; }
#cmeFooter .toPageTop a { z-index: 100; }
@media only screen and (max-width: 767px) {
.container { padding-right: 25px; padding-left: 25px; }
}

/* -------------------------------------------
	view
---------------------------------------------- */
@media (min-width: 768px) {
	.sp,
	.sp_only { display: none !important; }
}
@media only screen and (max-width: 767px) {
	.pc,
	.pc_only { display: none !important; }
}

/* -------------------------------------------
	bottomShare
---------------------------------------------- */
#bottomShare {display: flex;justify-content: center;margin: 50px 0 50px;list-style-type: none;}
#bottomShare li#twitter .box .share,
#bottomShare li#facebook .box .share {width: 44px;height: 44px;margin: 0 13px;background-repeat: no-repeat;background-position: 50% 50%;text-indent: -9999px;outline: none;}
#bottomShare li#twitter .box .share {background-color: #1da1f2;background-image: url(/club-me/common/v0006/images/icon_twitter.svg);background-size: 25px auto;border-radius: 50%;}
#bottomShare li#facebook .box .share {background-image: url(/club-me/common/v0006/images/icon_facebook.svg);background-size: contain;}
@media only screen and (max-width: 767px) {
#bottomShare {margin: 40px 0 40px;}
#bottomShare li#twitter .box .share,
#bottomShare li#facebook .box .share {width: calc(100vw/(750/88));height: calc(100vw/(750/88));margin: 0 calc(100vw/(750/40));}
#bottomShare li#twitter .box .share {background-size: calc(100vw/(750/50)) auto;}
}

/* -------------------------------------------
	page_link
---------------------------------------------- */
a.page_link { color: #222222; display: inline-block; position: relative; vertical-align: bottom; padding-right: 65px; }
a.page_link:hover { text-decoration: none; }
a.page_link::after { background: url("/club-me/food/oyatsu_otsumami/img/common/arw_link.svg") center center/cover no-repeat; content: ""; position: absolute; top: calc(50% - 4px); right: 13px; width: 20px; height: 8px; }
a.page_link div { border-radius: 50%; display: block; position: absolute; top: calc(50% - 32px); right: -9px; overflow: hidden; width: 64px; height: 64px; }
a.page_link div::before { border-radius: 50%; background-color: #4c4a42; content: ""; position: absolute; top: 0px; right: 0px; width: 100%; height: 100%; transform: scale(0.575); z-index: -1; }
a.page_link div span { color: #ffffff; position: absolute; top: 50%; right: 37px; padding-right: 65px; transform: translateY(-50%); opacity: 0; }
@media only screen and (min-width: 768px) {
a.page_link div::before { transition: transform 0.3s ease-out; }
a.page_link:hover div::before { transform: scale(1); }
a.page_link div span { transition: opacity 0.3s ease-out; }
a.page_link:hover div span { opacity: 1; }
}
@media only screen and (max-width: 767px) {
a.page_link { padding-right: 30px; }
a.page_link::after { background-size: 9px 4px; top: calc(50% - 2px); right: 7px; width: 9px; height: 4px; }
a.page_link div { top: calc(50% - 12px); right: 0px; overflow: hidden; width: 24px; height: 24px; }
a.page_link div::before { transform: scale(1); }
a.page_link div span { display: none; }
}

/* -------------------------------------------
	page_back
---------------------------------------------- */
.page_back { margin-top: 70px; }
.page_back p { text-align: center; }
.page_back p a { border-radius: 3px; border: 1px solid #dbdbdb; color: #222222; display: inline-block; vertical-align: bottom; padding: 15px 20px; }
.page_back p a:hover { text-decoration: none; }
.page_back p a span { display: block; position: relative; padding: 0 20px; }
.page_back p a span::after { content: ''; display: block; position: absolute; top: calc(50% - 4px); right: 0px; width: 7px; height: 7px;  border-top: 2px solid #c00; border-right: 2px solid #c00; transform: rotate(45deg); }
@media only screen and (min-width: 768px) {
.page_back p a { transition: background-color 0.3s ease, color 0.3s ease; }
.page_back p a:hover { color: #c00; background-color: #f5f5f5; }
}
@media only screen and (max-width: 767px) {
.page_back { margin: 25px 0 40px 0; }
.page_back p a { display: block; font-size: 92.8571%; }
.page_back p a span::after { top: calc(50% - 3px); width: 5px; height: 5px; }
}

/* -------------------------------------------
	page_relation
---------------------------------------------- */
.page_relation { background-color: #f0f0f0; padding: 80px 0; }
.page_relation a { color: #222; display: block; margin-right: calc((30 / 1200) * 100%); width: calc(50% - ((30 / 1200) * 100%)); }
.page_relation a:nth-of-type(even) { margin-left: calc((30 / 1200) * 100%); margin-right: 0; }
.page_relation a:hover { text-decoration: none; }
.page_relation_heading { font-size: calc((20 / 16) * 100%); font-weight: 400; text-align: center; }
.page_relation_heading span { display: inline-block; vertical-align: top; position: relative; padding: 0 25px; }
.page_relation_heading span::before { background-color: #222; content: ""; position: absolute; left: 0; top: calc(50% - 12px); width: 1px; height: 24px; transform: rotate(-30deg); }
.page_relation_heading span::after { background-color: #222; content: ""; position: absolute; right: 0; top: calc(50% - 12px); width: 1px; height: 24px; transform: rotate(30deg); }
.page_relation_column { display: flex; margin-top: 40px; }
.page_relation_img img { width: 100%; image-rendering: -webkit-optimize-contrast; }
.page_relation_text { margin-top: 25px;}
.page_relation_text dl dt { font-size: calc((20 / 16) * 100%); font-weight: 700; }
.page_relation_text dl dd { line-height: calc(33 / 16); margin-top: 10px; }
@media only screen and (min-width: 768px) {
.page_relation a .page_relation_text p span::before { transition: transform 0.3s ease-out; }
.page_relation a:hover .page_relation_text p span::before { transform: scale(1.6); }
}
@media only screen and (max-width: 767px) {
	.page_relation { padding: 40px 0; }
	.page_relation .container { padding-right: 15px; padding-left: 15px }
	.page_relation a { display: block; margin: 0; width: auto; }
	.page_relation a:nth-of-type(even) { margin: 0; }
	.page_relation a:nth-of-type(n+2) { margin-top: 30px; }
	.page_relation_heading { font-size: 1em; line-height: calc(38 / 25); }
	.page_relation_heading span { padding: 0 5px; }
	.page_relation_heading span::before { top: calc(100% - 20px); height: 20px; }
	.page_relation_heading span::after { top: calc(100% - 20px); height: 20px; }
	.page_relation_column { display: block; margin-top: 15px; }
	.page_relation_text { margin-top: 12px; }
	.page_relation_text dl dt { font-size: 100%; }
	.page_relation_text dl dd { font-size: calc((13 / 14) * 100%); line-height: calc(40 / 26); margin-top: 6px; }
}


/* -------------------------------------------
	animetion
---------------------------------------------- */
@media only screen {
.anime-flow { will-change: transform; animation: flow 2s ease-in-out alternate infinite; }
.anime-flow-1 { animation-duration: 2.2s; }
.anime-flow-2 { animation-duration: 2.6s; }
.anime-flow-3 { animation-duration: 3.0s; }
.anime-flow-4 { animation-duration: 3.4s; }
.anime-inBottom { transition: transform 1s ease-out, opacity 1s ease-out; transform: translateY(50px); opacity: 0; }
.anime-inBottom.is-active { transform: translateY(0); opacity: 1; }
.anime-inRight { transition: transform 0.6s ease-out, opacity 1s ease-out; transform: translateX(50px); opacity: 0; }
.anime-inRight.is-active { transform: translateX(0); opacity: 1; }
.anime-inLeft { transition: transform 1s ease-out, opacity 1s ease-out; transform: translateX(-50px); opacity: 0; }
.anime-inLeft.is-active { transform: translateX(0); opacity: 1; }
.anime-inOpacity { transition: opacity 1s ease-out; opacity: 0; }
.anime-inOpacity.is-active { opacity: 1; }
.anime-inImgRight { display: block; overflow: hidden; position: relative; }
.anime-inImgRight::after { background-color: #f26179; content: ""; position: absolute; top: 0px; right: 0px; width: 0; height: 100%; }
.anime-inImgRight.is-active::after { animation: imgInRight 0.8s cubic-bezier(.15,.85,.47,1.01) forwards; }
.anime-inImgRight img { opacity: 0; }
.anime-inImgRight.is-active img { animation: imgInRightImg 0.8s cubic-bezier(.15,.85,.47,1.01) forwards; }
.anime-inImgLeft { display: block; overflow: hidden; position: relative; }
.anime-inImgLeft::after { background-color: #f26179; content: ""; position: absolute; top: 0px; left: 0px; width: 0; height: 100%; }
.anime-inImgLeft.is-active::after { animation: imgInLeft 0.8s cubic-bezier(.15,.85,.47,1.01) forwards; }
.anime-inImgLeft img { opacity: 0; }
.anime-inImgLeft.is-active img { animation: imgInLeftImg 0.8s cubic-bezier(.15,.85,.47,1.01) forwards; }
}

/* -------------------------------------------
	keyframes
---------------------------------------------- */
@keyframes imgInRight {
	0% { right: 0px; width: 0%; }
	29% { right: 0px; width: 100%; }
	31% { right: 0px; width: 100%; }
	100% { right: 100%; width: 100%; }
}
@keyframes imgInRightImg {
	0% { opacity: 0; }
	29% { opacity: 0; }
	30% { opacity: 1; }
	31% { opacity: 1; }
	100% { opacity: 1; }
}
@keyframes imgInLeft {
	0% { left: 0px; width: 0%; }
	29% { left: 0px; width: 100%; }
	31% { left: 0px; width: 100%; }
	100% { left: 100%; width: 100%; }
}
@keyframes imgInLeftImg {
	0% { opacity: 0; }
	29% { opacity: 0; }
	30% { opacity: 1; }
	31% { opacity: 1; }
	100% { opacity: 1; }
}
@keyframes flow {
	0% { transform: translateY(0); }
	100% { transform: translateY(15px);}
}
@keyframes imgMask {
	0% { -webkit-mask-size: 0%; }
	100% { -webkit-mask-size: 120%; }
}

