@charset "UTF-8";
/*-----------------------------------
	common
-----------------------------------*/
.lunchbox {
	padding-top: 136px;
}
.lunchbox h2 {
	font-size: 36px;
	font-weight: 500;
	padding: 20px 20px 20px 77px;
	border: 1px solid #000;
	background: url(../img/common/icon_title.svg) no-repeat 28px 27px/39px;
	margin-bottom: 25px;
}
.lunchbox p.red {
	font-size: 21px;
	color: #ff0000;
	white-space: pre-line;
	margin-bottom: 20px;
	letter-spacing: -0.05em;
}
@media screen and (max-width: 840px) {
	.lunchbox h2 {
		font-size: 29px;
		padding: 20px 20px 20px 60px;
		background: url(../img/common/icon_title.svg) no-repeat 20px 25px/35px;
	}
}
@media screen and (max-width: 640px) {
	.lunchbox {
		padding-top: 75px;
	}
	.lunchbox h2 {
		font-size: 21px;
		letter-spacing: -0.08em;
		padding: 14px 15px 14px 48px;
		background: url(../img/common/icon_title.svg) no-repeat 17px 19px/24px;
		margin-bottom: 17px;
	}
	.lunchbox h2 span {
		display: none;
	}
	.lunchbox p.red {
		font-size: 13px;
		margin-bottom: 10px;
	}
}
/*-----------------------------------
	mainvisual_block
-----------------------------------*/
#mainvisual_block .ttl {
	width: 164px;
}
#mainvisual_block .mv_bottom .text p {
	font-size: min(15px,1.28vw);
}
#mainvisual_block .mv_bottom .text .ttl {
	position: static;
	font-size: min(51px,4.35vw);
	font-weight: 500;
	width: auto;
}
@media screen and (max-width: 840px) {
	#mainvisual_block .ttl {
		width: 115px;
	}
}
@media screen and (max-width: 640px) {
	#mainvisual_block .ttl {
		width: 66px;
		right: calc(5vw + 8px);
	}
	#mainvisual_block .mv_bottom .text p {
		font-size: min(15px,4vw);
	}
	#mainvisual_block .mv_bottom .text p span {
		letter-spacing: -0.1em;
	}
	#mainvisual_block .mv_bottom .text .ttl {
		display: none;
	}
}
/*-----------------------------------
	scroll_box
-----------------------------------*/
#scroll_box {
	padding: 30px 0;
}
@media screen and (max-width: 640px) {
	#scroll_box {
		display: none;
	}
}
/*-----------------------------------
	tel_block
-----------------------------------*/
#tel_block {
	padding-top: 0 !important;
}
#tel_block a.tel {
	font-size: min(193px, 16.49vw);
	letter-spacing: -0.08em;
	line-height: 1;
	color: #ff0000;
}
@media screen and (max-width: 640px) {
	#tel_block {
		padding-top: 30px !important;
	}
}
/*-----------------------------------
	download_block
-----------------------------------*/
#download_block h2 {
	position: relative;
}
#download_block h2 br {
	display: none;
}
#download_block h2::after {
	content: "";
	width: 8px;
	height: 15px;
	background: url(../img/common/icon_btn_arw_rt.svg) no-repeat center / contain;
	display: inline-block;
	vertical-align: middle;
	margin-left: 20px;
}
#download_block h2 a {
	width: 134px;
	height: 144px;
	background: url(../img/lunchbox/icon_pdf.svg) no-repeat center / contain;
	position: absolute;
	top: calc(50% - 72px);
	right: 27px;
}
#download_block .text {
	font-size: 19px;
	line-height: 1.58;
	white-space: pre-line;
}
@media screen and (max-width: 1110px) {
	#download_block h2 br {
		display: inline;
	}
	#download_block h2 a {
		width: 94px;
		height: 101px;
		top: calc(50% - 50.5px);
		right: 20px;
	}
}
@media screen and (max-width: 640px) {
	#download_block h2 a {
		width: 68px;
		height: 73px;
		top: 50px;
		right: 10px;
	}
	#download_block .text {
		font-size: 12px;
	}
}
/*-----------------------------------
	menu_block
-----------------------------------*/
#menu_block {
	background: #231815;
	padding: 136px 0;
	margin-top: 136px;
}
#menu_block .box {
	position: relative;
}
#menu_block .box.box:not(:last-child)::before {
	content: "";
	width: min(55px, 4.7vw);
	height: min(55px, 4.7vw);
	background: url(../img/lunchbox/menu_deco.svg) no-repeat center / contain;
	position: absolute;
	bottom: 100%;
	left: 100%;
}
#menu_block .box:nth-child(2n):not(:last-child)::before {
	left: max(-55px, -4.7vw);
}
#menu_block .box:not(:last-child) {
	margin-bottom: 80px;
}
#menu_block .box .image {
	position: relative;
	margin-bottom: 30px;
}
#menu_block .box .image .ttl {
	width: min(137px, 11.71vw);
	position: absolute;
	top: min(38px, 3.25vw);
	left: min(43px, 3.68vw);
}
#menu_block .box:nth-child(2n) .image .ttl {
	left: auto;
	right: min(43px, 3.68vw);
}
#menu_block .box .image .gentei {
	width: min(137px, 11.71vw);
	position: absolute;
	bottom: min(22px, 1.88vw);
	right: min(45px, 3.84vw);
}
#menu_block .box ul li {
	display: flex;
	justify-content: space-between;
	font-size: min(26px, 2.22vw);
	line-height: 2;
	color: #FFF;
	border-bottom: 0.5px solid #FFF;
}
#menu_block .box h3 {
	font-size: min(44px, 3.76vw);
	font-weight: 700;
	margin-bottom: 20px;
	color: #FFF;
}
#menu_block .box:last-child ul:not(:last-child) {
	margin-bottom: min(60px, 5.13vw);
}
@media screen and (max-width: 640px) {
	#menu_block {
		background: none;
		margin-top: 0;
		padding: 75px 0 0 0;
	}
	#menu_block .box::before {
		content: none;
		display: none;
	}
	#menu_block .box:not(:last-child) {
		margin-bottom: 47px;
	}
	#menu_block .box .image {
		margin-bottom: 23px;
	}
	#menu_block .box .image .ttl {
		width: 15.2vw;
		top: 47%;
		left: -2.4vw;
		transform: translateY(-50%);
	}
	#menu_block .box:nth-child(2n) .image .ttl {
		right: -2.4vw;
	}
	#menu_block .box .image .gentei {
		width: 17.6vw;
		top: 1.33vw;
		bottom: auto;
		left: 2.4vw;
		right: auto;
	}
	#menu_block .box ul li {
		flex-direction: column;
		font-size: 12px;
		color: #000;
		border-bottom: 0.5px solid #000;
	}
	#menu_block .box ul li span {
		width: max-content;
		margin: 0 0 0 auto;
	}
	#menu_block .box h3 {
		font-size: min(26px, 6.93vw);
		margin-bottom: 10px;
		color: #000;
	}
}