/*
=========================================
	index.html
=========================================
*/

.header-logo {
	/*はじめは非表示*/
	opacity: 0;
}

/*　上に上がる動き　*/

.header-logo.disp {
	animation: dispAnime 0.5s forwards;
}
@keyframes dispAnime {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

/*　下に下がる動き　*/

.header-logo.nodisp {
	animation: nodispAnime 0.5s forwards;
}
@keyframes nodispAnime {
	from {
		opacity: 1;
	}
	to {
		opacity: 0;
	}
}
/*first-view
--------------------*/
#first-view {
	background: linear-gradient(#A38A9E 70%, #fff);
	height: 100vh;
	padding-top: 30px;
	padding-bottom: 200px;
}
#main-title {
	position: relative;
	z-index: 200;
	padding-top: 5px;
	padding-bottom: 50px;
	margin: 0 auto;
	font-family: 'Homemade Apple', cursive;
	font-size: 50px;
	color: #4C2F52;
	background-color: rgba(255,255,255,0.1);
	box-shadow: 0 0 15px rgba(255,255,200,0.5);
	width: 280px;
	height: 50px;
	border-radius: 100vh;
}
@media screen and (min-width: 768px) {
	#main-title {
		padding-top: 10px;
		padding-bottom: 30px;
		margin: 15px auto;
		width: 300px;
		height: 80px;
	}
}
#main-title span {
	position: absolute;
	left: 50%;
	top:65px;
	font-family: 'Hina Mincho', serif;
	font-size: 15px;
	color: #524240;
}

/*slide
--------------------*/
#slideShow {
	margin: 20px auto;
}
#slide {
	position: absolute;
	top: 45%;
	left: 50%;
	transform: translate(-50%,-150px);
}
#slider {
	position: relative;
	width: 300px;
	height: 300px;
	justify-content: center;
	display: flex;
	align-items: center;
}
#flame-sp {
	position: absolute;
	top: 45%;
	left: 50%;
	transform: translate(-50%,-180px);
	display: block;
	box-shadow:
		0 0 10px rgba(0,0,0,0.5),
		0 0 100px rgba(151,92,162,0.5) inset;
}
#flame-pc {
	display: none;
}
.slide-item {
	height: 320px;
}
.slide-item span {
	position: absolute;
	bottom: 0;
	transform: translate(-50%, 0);
	font-family: 'Hina Mincho', serif;
	font-size: 18px;
	width: 100%;
}
#slider img {
	width: 85%;
	max-height: 100%;
	display: block;
	margin-left: 23px;
	box-shadow: 0 0 15px rgba(255,255,255,0.5);
}

@media screen and (min-width: 768px) {
	#slide {
		top: 50%;
		left: 50%;
	}
	#slider {
		width: 700px;
		height: 300px;
	}
	#flame-sp {
		display: none;
	}
	#flame-pc {
		visibility: visible;
		width: 700px; /*元画像を幅700pxにする*/
		max-width: 100%;
		display: block;
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}
	.slide-item {
		margin: 0 30px;
		height: 300px;
	}
	@keyframes fadeInAnime{
	  from {
	    opacity: 0;
	  }

	  to {
	    opacity: 1;
	  }
	}
	.slick-active{
	  animation: fadeInAnime 2s linear 0s normal both;
	}
	#slider a:hover, #slider a:hover img {
	    opacity: 1;
	}
}


button {
	margin: 0;
	padding: 0;
	background: none;
	border: none;
	border-radius: 0;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
.slide-arrow {
	position: absolute;
	bottom: -50px;
	cursor: pointer;/*マウスカーソルを指マークに*/
	margin-top: -15px;
	background-color: rgba(255,255,255,0.1);
	box-shadow: 0 0 15px rgba(255,255,255,0.5);
	border-top: 2px solid #fff;/*矢印の色*/
	border-right: 2px solid #fff;/*矢印の色*/
	height: 13px;
	width: 13px;
}
.prev-arrow {
	left: 0;
	transform: rotate(-135deg);
}
.next-arrow {
	right: 0;
	transform: rotate(45deg);
}
@media screen and (min-width: 768px) {
	.slide-arrow {
		bottom: 8px;
	}
	.prev-arrow {
		left: -20px;
	}
	.next-arrow {
		right: -31px;
	}
}

.slide-dots {
	position: absolute;
	z-index: 3;
	bottom: -70px;
	left: 50%;
	transform: translate(-50%, 0);
}
@media screen and (min-width: 768px) {
	.slide-dots {
		bottom: -150px;
	}
}
.slide-dots li {
    display:inline-block;
	margin:0 5px;
}

.slide-dots button {
    color: transparent;
    outline: none;
    width:9px;/*ドットボタンのサイズ*/
    height:9px;/*ドットボタンのサイズ*/
    display:block;
    border-radius:50%;
    background:#78615F;/*ドットボタンの色*/
	border: #fff 1px solid;
}

.slide-dots .slick-active button{
    background: #D9B54A;/*ドットボタンの現在地表示の色*/
}

/*scroll Down
--------------------*/


.scroll-down {
	position: absolute;
	right: 100px;
	bottom: 20%;
	padding-left: 52px;
	margin-left: 81px;
	z-index: 100;
	transform: rotateZ(-90deg);
	transform-origin: right bottom;
	font-family: 'Noto Serif JP', serif;
/*	background: radial-gradient(farthest-side, #fff,#4C2F52);
	width: 70px;
	height: 30px;*/
}
@media screen and (min-width: 768px) {
	.scroll-down {
		right: 150px;
		bottom: 300px;
		width: 300px;
	}
}

@keyframes scroll-down-line {
  0% {
    transform-origin: 0% 50%;
    transform: scale(1, 1); }
  20% {
    transform-origin: 0% 50%;
    transform: scale(0.001, 1); }
  20.01% {
    transform-origin: 100% 50%; }
  38% {
    transform-origin: 100% 50%;
    transform: scale(1, 1); }
}

@keyframes bounce {
  0%, 15%, 38%, 60%, 75% {
    transform: translateX(0); }
  30% {
    transform: translateX(10px); }
  45% {
    transform: translateX(5px); }
}
.scroll-down__line {
	position: absolute;
	left: 0;
	top: 50%;
	width: 44px;
	height: 0px;
}
.scroll-down__line:after {
	content: '';
	display: block;
	width: 100%;
	height: 0;
	border-bottom: 0.5px solid #524240;
	transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94), opacity 0s linear 0.5s;
	transform-origin: right center;
	transform: scale(0.001, 1);
	opacity: 0; 
}
@media screen and (min-width: 768px) {
	.scroll-down__line {
		width: 150px;
		border-bottom: 1px solid #524240;

	}
}

.scroll-down__text {
	color: #524240;
	font-size: 12px;
	font-weight: bold;
	text-transform: uppercase;
	line-height: 1;
	letter-spacing: 0.2em;
	overflow: hidden;
}
@media screen and (min-width: 768px) {
	.scroll-down__text {
		font-size: 16px;
	}
}

.scroll-down__text span {
	display: block;
	transform: translate3d(0, 100%, 0);
	transition: transform 1.5s cubic-bezier(0.19, 1, 0.22, 1);
}
.scroll-down.is-active.is-inview .scroll-down__text {
	animation: bounce 2.5s infinite;
}
.scroll-down.is-active.is-inview .scroll-down__text span {
	transform: none;
}
.scroll-down.is-active.is-inview .scroll-down__line {
	animation: scroll-down-line 2.5s infinite 851ms;
}
.scroll-down.is-active.is-inview .scroll-down__line:after {
	transform: none;
	opacity: 1;
	transition: transform 1s cubic-bezier(0.23, 1, 0.32, 1), opacity 0s linear;
}
.is-body-touch .scroll-down {
	display: none;
}
/*newnews
--------------------*/

#newnews {
	position: absolute;
	width: 300px;
	left: 0;
	bottom: 0;
}
@media screen and (min-width: 768px) {
	#newnews {
		left: 10px;
		bottom: 10px;
	}
}
#newnews-chara {
	position: absolute;
	left: -5px;
	bottom: 10px;
}
#newnews-p {
	position: absolute;
	left: 80px;
	bottom: 10px;
}
#newnews p {
	color: #fff;
	background-color: #78615F;
	padding: 2px 5px 2px;
	margin-left: 2px;
	display: inline-block;
	border-radius: 5px 5px 0 0;
}
p#newnews-t {
	z-index: 2;
	color: #78615F;
	background-color: #fff;
	border-radius: 5px;
	margin-left: 0;
}

/*concept
--------------------*/

#bg {
	background-image: url(../img/top/cake_image.png);
	background-size: 500px;
	background-position: center center;
	background-repeat: no-repeat;
	margin-bottom: 30px;
}
#concept {
	margin-top: 50px;
	margin-bottom: 30px;
	height: 330px;
	padding: 30px 0;
	background-color: rgba(255,255,255,0.7);
}
#concept-msg {
	padding: 5px 0;
}
#concept-msg p {
	margin: 10px 8px;
	text-shadow: 0 0 2px rgba(0,0,0,0.7);
}
@media screen and (min-width: 768px) {
	#bg {
		background-size: 100%;
	}
	#concept h2 {
		margin: 10px 0 20px;
	}
	#concept-msg p {
		margin: 30px 8px;
		line-height: 2;
	}
}

/*pickup
--------------------*/
#pickup {
	margin: 50px 0;
	padding: 10px 0;
}
#pickup h2 {
	margin: 10px 0;
}
#pickup li {
	margin: 20px 0 40px;
	padding-bottom: 20px;
	border-bottom: 1px solid #78615F;
}
#pickup li:last-of-type {
	border: none;
}
#pickup li img {
	border: 3px solid #cbbc43;
	box-sizing: border-box;
}
#pickup li h3 {
	box-shadow:
		0 0 30px rgba(255,255,255,1) inset,
		0 0 40px rgba(245,235,190,0.8) inset,
		0 0 50px rgba(230,215,160,0.5) inset,
		0 0 80px rgba(200,190,140,0.3) inset,
		0 5px 5px rgba(0, 0, 0, .2);
	border-radius: 5px;
	width: 70%;
	margin: 10px auto;
}
@media screen and (min-width: 768px) {
	#pickup li {
		border: none;
	}
}

/*lineup
--------------------*/
.lineup-btn {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 161px;
}
.lineup-img {
	position: absolute;
	border: 2px solid #000;
	opacity: 0.7;
}
.lineup-btn a {
	display: block;
	width: 50%;
	top: 50%;
	padding: 5px 15px;
	border-radius: 100vh;
	background-image: linear-gradient(-20deg, #e9defa 0%, #fbfcdb 100%);
	color: #59220d;
	border: 2px solid #A38A9E;
	box-shadow: 0 2px 5px rgba(0, 0, 0, .2);
	-webkit-box-shadow: 0 2px 5px rgba(0, 0, 0, .2);
	transition: 0.5s;
	z-index: 50;
}
.lineup-btn a:hover {
	opacity: 1;
	transform: scale(1.1);
}
.lineup-btn a:hover + img {
	opacity: 1;
}
#lineup-list li {
	margin: 20px 0 40px;
}
.lineup-p {
	box-sizing: border-box;
}
#lineup .note {
	background-color: #fff; /* 背景色 */
	background-image: linear-gradient(180deg, #ccc 1px, transparent 1px); /* 罫線の色と太さ  */
	background-size: 100% 2em; /* 行の高さ */
	line-height: 2em; /* 文字の高さ */
	padding-bottom: 1px; /* 最終行の下にも罫線を引く */
	padding-top: 5px;
	padding-left: 5px;
	margin: 15px auto;
	width: 300px;
}
#holecut {
	position: relative;
	width: 100%;
	height: 100px;
}
#holucut-chara {
	position: absolute;
	right: 0;
}
#holecut span {
	position: absolute;
	right: 70px;
	top: 7px;
	display: block;
	padding: 5px 10px;
	border: 1px solid #D9B54A;
	border-radius: 8px;
	background-image: linear-gradient(-20deg, #F2B1E5 0%, #fbfcdb 100%);
}

/*access
--------------------*/
#access {
	margin: 0 auto;
	padding-bottom: 20px;
}
#shop-info {
	margin: 20px;
}

#shop-info img {
	max-width: 100%;
	margin-bottom: 20px;
}

#shop-info .deta-title {
	font-weight: bold;
}
.dashed-note {
	background-color: #fff; /* 背景色 */
	background-image: linear-gradient(90deg, transparent 0%, transparent 50%, #fff 50%, #fff 100%), /* 点線1の色 */
					  linear-gradient(180deg, #ccc 1px, transparent 1px); /* 点線2の色と太さ */
	background-size: 8px 100%, /* 点線1のサイズ */
					 100% 2em; /* 点線2のサイズ */
	line-height: 2em; /* 文字の高さ */
	padding-bottom: 1px; /* 最終行の下にも罫線を引く */
}

/*Google Map
--------------------*/
#access .map iframe {
	width: 100%;
	max-width: 580px;
	height: 350px;
	margin: 20px 0;
}
@media screen and (min-width: 768px) {
	#access .map iframe {
		height: 450px;
	}
}

