@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main .detail {
	position: relative;
}
#main .detail::after {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	content: "";
	z-index: 1;
	background-color: rgba(35, 24, 21, 0.7);
	pointer-events: none;
}
#main .detail .photo img {
	width: 100%;
}
#main .detail .content {
	position: absolute;
	z-index: 2;
	top: 50%;
	left: 50%;
	width: 100%;
	transform: translate(-50%,-50%);
}
#main .detail p {
	margin-top: 1rem;
	position: relative;
	z-index: 2;
	color: #fff;
	letter-spacing: 0.1em;
	line-height: 2.22;
	text-align: center;
}
#main .gift {
	padding: 5.7rem 0 14.4rem;
	background-color: #FCFBF7;
}
#main .gift .content {
	max-width: 118.7rem;
}
#main .gift .imgBox {
	flex-direction: row-reverse;
	align-items: center;
}
#main .gift .photoBox {
	width: 42.7%;
}
#main .gift .photoBox img {
	width: 100%;
}
#main .gift .textBox {
	margin: 5rem 0 0 9.2rem;
	flex: 1;
}
#main .gift .textBox h2 {
	margin-bottom: 9.3rem;
	font-size: 4.2rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 1.71;
}
#main .gift .textBox .text {
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 2.22;
}
#main .food .imgBox {
	align-items: center;
}
#main .food .imgBox .photoBox {
	width: 50.25%;
}
#main .food .imgBox .photoBox img {
	width: 100%;
}
#main .food .imgBox .textBox {
	padding: 1rem;
	flex: 1;
}
#main .food .imgBox .textBox .sub {
	margin-left: 9.5rem;
	max-width: 41rem;
}
#main .food .imgBox .textBox h2 {
	margin-bottom: 5.5rem;
	font-size: 4.2rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 1.71;
}
#main .food .imgBox .textBox .text {
	font-weight: 700;
	line-height: 1.95;
	font-size: 1.9rem;
	letter-spacing: 0.05em;
}
#main .food .imgBox:nth-child(1) .textBox {
	padding-bottom: 3.5rem;
}
#main .food .imgBox:nth-child(1) h2 {
	margin-right: -8rem;
}
#main .food .imgBox:nth-child(2n) {
	flex-direction: row-reverse;
}
#main .food .imgBox:nth-child(2n) .photoBox {
	width: 49.75%;
}
#main .food .imgBox:nth-child(2n) .sub {
	margin: 0 10rem 0 auto;
}
#main .touch {
	position: relative;
}
#main .touch .photo img {
	width: 100%;
}
#main .touch .content {
	position: absolute;
	z-index: 1;
	top: 15.5%;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	height: 84.5%;
}
#main .touch h2 {
	margin: 0 18rem 0 auto;
	width: 12.6rem;
	color: #fff;
	font-weight: 500;
	font-size: 4.2rem;
	letter-spacing: 0.05em;
	white-space: nowrap;
	writing-mode: vertical-rl;
	-webkit-writing-mode: tb-rl;
}
#main .touch h2 span {
	margin-top: 21rem;
	display: block;
}
#main .intro {
	position: relative;
	z-index: 2;
}
#main .intro .photo img {
	width: 100%;
}
#main .intro .textBox {
	padding: 0 7rem 10rem;
	width: 56.5%;
	position: absolute;
	z-index: 1;
	top: 50%;
	transform: translateY(-50%);
	right: 0;
}
#main .intro .textBox .image {
	margin: 0 auto 3rem;
	width: 9.2rem;
}
#main .intro .textBox .priceUl li {
	display: flex;
	flex-wrap: wrap;
}
#main .intro .textBox .priceUl .title,
#main .intro .textBox .priceUl .num {
	padding: 0 3rem;
	width: 50%;
	font-weight: 700;
	letter-spacing: 0.1em;
}
#main .intro .textBox .priceUl {
	margin-bottom: 8rem;
}
#main .intro .textBox .priceUl .title {
	padding-right: 2rem;
	text-align: right;
	font-size: 2.4rem;
	line-height: 2.03;
}
#main .intro .textBox .priceUl .title span {
	padding-right: 0.5rem;
	font-size: 3rem;
	vertical-align: -0.2rem;
}
#main .intro .textBox .priceUl .num {
	font-size: 2.7rem;
	line-height: 1.8;
}
#main .intro .textBox .priceUl .num span {
	font-size: 1.8rem;
}
#main .intro .textBox .sub {
	padding-left: 4rem;
}
#main .intro .textBox .sub .title,
#main .intro .textBox .sub .text {
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.1em;
	line-height: 2;
}
#main .otherPhoto img {
	width: 100%;
}
#main .contact {
	padding: 12.5rem 0 6.5rem;
	background-color: #FCFBF7;
}
#main .contact .errorMsg {
	margin-bottom: 2rem;
	color: #f00;
}
#main .contact .content {
	max-width: 50rem;
}
#main .contact dt {
	margin-bottom: 0.8rem;
	text-align: center;
	font-weight: 700;
	letter-spacing: 0.1em;
}
#main .contact dd {
	margin-bottom: 3rem;
	word-break: break-all;
}
#main .contact dd:last-child {
	margin-bottom: 4.8rem;
}
#main .contact input[type="text"],
#main .contact input[type="email"], 
#main .contact input[type="tel"],
#main .contact select, 
#main .contact textarea {
	padding: 0.5rem 1rem;
	width: 100%;
	display: block;
	height: 3.5rem;
	color: #231815;
	font-size: 1.6rem;
	border-radius: 0.3rem;
	border: 0.25px solid #231815;
	box-sizing: border-box;
	box-shadow: none;
	background-color: #fff;
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
}
#main .contact textarea {
	height: 10rem;
	resize: vertical;
}
#main .contact .submit {
	gap: 2rem;
}
#main .contact .submit input {
    width: 23rem;
    padding: 0.5rem 0;
    text-align: center;
	color: #fff;
    font-size: 1.8rem;
    font-weight: 500;
	letter-spacing: 0.1em;
    background-color: #1D0000;
	border-radius: 0.3rem;
	box-shadow: none;
	box-sizing: border-box;
    border: 0;
	cursor: pointer;
	appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
	transition: .3s;
}
#main #confirmForm {
	margin-top: 4rem;
}
#main #confirmForm dt {
	text-align: left;
}
#main .gallery {
	padding: 9.8rem 0 6.9rem;
}
#main .gallery .headLine01 {
	margin-bottom: 6.3rem;
}
#main .gallery ul {
	margin: 0 1.5rem;
	gap: 1.5rem;
	display: flex;
}
#main .gallery li {
	flex: 1;
}
#main .gallery li a {
	display: block;
	aspect-ratio: 1 / 1;
}
#main .gallery li a:hover {
	opacity: 0.7;
}
#main .gallery li a img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media all and (min-width: 897px) {
	#main .contact .submit input:hover {
		opacity: 0.7;
	}
}
@media all and (max-width: 896px) {
	#main .detail .content {
		padding: 0 2rem;
	}
	#main .detail p {
		margin: 0 0 1.5rem;
		letter-spacing: 0.05em;
		line-height: 2.16;
	}
	#main .gift {
		padding: 8.3rem 0 4.7rem;
		background-color: #fff;
	}
	#main .gift .imgBox {
		display: block;
	}
	#main .gift .photoBox {
		padding-left: 0.7rem;
		margin: 0 auto 7.5rem;
		width: 81.7%;
	}
	#main .gift .textBox {
		margin: 0;
	}
	#main .gift .textBox h2 {
		margin-bottom: 4rem;
		font-size: 2.7rem;
		line-height: 1.33;
	}
	#main .gift .textBox .text {
		font-weight: 700;
		letter-spacing: 0.05em;
		line-height: 1.61;
	}
	#main .food .imgBox {
		display: block;
	}
	#main .food .imgBox .photoBox {
		width: auto !important;
	}
	#main .food .imgBox .textBox {
		padding: 5.4rem 2.5rem 5.8rem 2.8rem !important;
	}
	#main .food .imgBox .textBox .sub {
		margin: 0 !important;
		max-width: 100%;
	}
	#main .food .imgBox .textBox h2 {
		margin-bottom: 2.5rem;
		font-size: 2.7rem;
		line-height: 1.33;
	}
	#main .food .imgBox .textBox .text {
		line-height: 1.61;
		font-size: 1.8rem;
	}
	#main .food .imgBox:nth-child(1) h2 {
		margin-right: 0;
	}
	#main .food .imgBox:nth-child(2) .textBox {
		padding-bottom: 8.5rem !important;
	}
	#main .food .imgBox:nth-child(2) h2 {
		margin-bottom: 3rem;
	}
	#main .touch .content {
		top: 16%;
		height: 84%;
	}
	#main .touch h2 {
		margin-right: 2.7rem;
		font-size: 2.65rem;
	}
	#main .touch .text {
		position: absolute;
		z-index: 1;
		bottom: 29.5%;
		left: 5.3rem;
		color: #fff;
		font-weight: 500;
		font-size: 2.65rem;
		letter-spacing: 0.05em;
		white-space: nowrap;
		writing-mode: vertical-rl;
		-webkit-writing-mode: tb-rl;
	}
	#main .intro .content {
		padding: 0;
	}
	#main .intro .textBox {
		margin-top: -6.2rem;
		padding: 5rem 2rem 4rem;
		width: auto;
		position: static;
		transform: translateY(0);
		background: url(../img/index/intro_bg_sp.png) repeat-x left top / 37.4rem 100%;
	}
	#main .intro .textBox .image {
		margin-bottom: 1.8rem;
		width: 13.2rem;
	}
	#main .intro .textBox .priceUl li {
		display: flex;
		flex-wrap: wrap;
	}
	#main .intro .textBox .priceUl .title,
	#main .intro .textBox .priceUl .num {
		padding: 0 1.8rem;
		line-height: 1.5 !important;
	}
	#main .intro .textBox .priceUl {
		margin-bottom: 6.9rem;
	}
	#main .intro .textBox .priceUl .title {
		padding: 0.2rem 0.7rem 0 1.8rem;
		font-size: 2.15rem;
	}
	#main .intro .textBox .priceUl .title span {
		padding-right: 0.3rem;
		font-size: 2.35rem;
		vertical-align: 0;
		line-height: 1.2;
	}
	#main .intro .textBox .priceUl .num {
		font-size: 2.3rem;
	}
	#main .intro .textBox .priceUl .num span {
		font-size: 2rem;
	}
	#main .intro .textBox .sub {
		padding-left: 0;
	}
	#main .intro .textBox .sub .title,
	#main .intro .textBox .sub .text {
		line-height: 1.37;
	}
	#main .intro .textBox .sub .text {
		margin-bottom: 2.7rem;
	}
	#main .intro .textBox .sub .text:last-child {
		margin-bottom: 0;
	}
	#main .otherPhoto {
		margin-top: -8.5rem;
	}
	#main .contact {
		padding: 5.5rem 0 5.3rem;
	}
	#main .contact .errorMsg {
		font-size: 1.6rem;
	}
	#main .contact .content {
		padding: 0 4rem;
	}
	#main .contact dt {
		margin-bottom: 0.7rem;
		font-size: 1.9rem;
	}
	#main .contact dd {
		margin-bottom: 1.6rem;
	}
	#main .contact dd:last-child {
		margin-bottom: 3.3rem;
	}
	#main .contact input[type="text"],
	#main .contact input[type="email"], 
	#main .contact input[type="tel"],
	#main .contact select, 
	#main .contact textarea {
		height: 4.1rem;
		border-width: 0.5px;
	}
	#main .contact textarea {
		height: 7rem;
	}
	#main .contact .submit {
		display: block;
	}
	#main .contact .submit li {
		margin: 0 auto;
		width: fit-content;
	}
	#main .contact .submit li:not(:last-child) {
		margin-bottom: 2rem;
	}
	#main .contact .submit input {
		padding: 0.7rem 0;
		width: 30rem;
		font-size: 1.9rem;
		border-radius: 0.5rem;
	}
	#main .gallery {
		padding: 5.5rem 0 3.2rem;
	}
	#main .gallery .headLine01 {
		margin-bottom: 1rem;
	}
	#main .gallery ul {
		margin: 0 0.5rem;
		gap: 0.5rem;
	}
}