@charset "UTF-8";

.inner {
	max-width: 1240px;
}

.hero {
	background-image: url(/img/sos/oden/bg_hero.webp);
	background-repeat: repeat;
	width: 100%;
	height: 100%;
}

.hero_wrap {
	position: relative;
}

.online_shop {
	position: absolute;
	bottom: 10px;
	right: 10px;
	z-index: 10;
}

.online_shop.-fix {
	position: fixed;
	bottom: 0;
	top: 10px;
}

.hero_ttl {
	width: 100%;
}

.hero_ttl img {
	width: 100%;
	height: auto;
}

.haikei_wrap {
	background-image: url(/img/sos/oden/bg.webp);
	background-repeat: repeat;
	width: 100%;
	height: 100%;
	padding: 170px 0 50px;
	margin-top: -120px;
}

.haikei_box {
	background-color: #fff;
	border-radius: 20px;
	position: relative;
	padding: 65px 110px;
	margin-bottom: 30px;
}

.haikei_box.-kikaku {
	padding-top: 100px;
}

.haikei_ttl {
	position: absolute;
	top: -65px;
	left: 50%;
	transform: translateX(-50%);
}

.haikei_box p {
	text-align: center;
	font-weight: bold;
	font-size: 18px;
	margin-bottom: 20px;
}

.haikei_box p span {
	color: #F35D1B;
}

.haikei_box p span.-line {
	display: inline-block;
	background-image: url(/img/sos/oden/bg_txt.webp);
	background-size: cover;
	background-repeat: no-repeat;
}

.link_btn {
	background-color: #F35D1B;
	border-radius: 10px;
	max-width: 315px;
	width: 100%;
	height: 60px;
	color: #fff;
	font-weight: bold;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	align-items: center;
	border: 2px solid #fff;
	transition: all 0.3s;
}

.link_btn:hover {
	background-color: #fff;
	color: #F35D1B;
	transition: all 0.3s;
	border: 2px solid #F35D1B;
}

.collabo {
	display: flex;
	gap: 65px;
	align-items: center;
	margin-bottom: 40px;
}

.collabo_cnt {}

.collabo_cnt h3 {
	margin-bottom: 20px;
}

.collabo_cnt p {
	font-weight: normal;
	font-size: unset;
	text-align: left;
	margin-bottom: 20px;
}

.collabo_img img {
	width: 100%;
	height: auto;
}

.hot {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 40px;
	padding: 40px 60px;
	background-color: #FFF8EF;
	border-radius: 20px;
}

.hot_box h3 {
	margin-bottom: 10px;
}

.omoi_ttl {
	background-color: #F35D1B;
	width: 100%;
	padding: 10px 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50px;
	margin-bottom: 10px;
}

.omoi_hot {
	border-bottom: 1px solid #F4D2AA;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	gap: 15px;
}

.omoi_hot:last-child {
	border-bottom: none;
}

.omoi_hot dt {
	flex: none;
}

.omoi_hot dd {
	font-weight: bold;
	font-size: 20px;
}

.stock {
	padding: 50px 0;
}

.stock_ttl {
	text-align: center;
}
.stock_ttl img{
	width: 100%;
	max-width: 1300px;
	height: auto;
}

.stock_voice {
	text-align: center;
}

.stock_img_box {
	padding: 30px 20px;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	gap: 55px;

}

.movie_deco {
	margin-bottom: 10px;
}

.stock_movie {
	max-width: 350px;
	position: relative;
}

.stock_movie video {
	width: 100%;
}

.eat {
	background-image: url(/img/sos/oden/bg02.webp);
	background-repeat: repeat;
	width: 100%;
	height: 100%;
	padding: 80px 0;
}

.e_inner {
	max-width: 1040px;
}

.eat_ttl {
	text-align: center;
	margin-bottom: 10px;
}

.eat_cap {
	font-weight: bold;
	font-size: 18px;
	text-align: center;
}

.eat_cnt {}

.eat_cnt h3 {
	background-color: #412C12;
	border-radius: 20px 20px 0 0;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	text-align: center;
	font-size: 28px;
	font-weight: bold;
	padding: 20px;
}

.eat_cnt h3 span {
	color: #F3C91B;
}

.eat_box {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 80px;
	padding: 30px 0;
}

.eat_txt_cnt {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
	border-bottom: 1px solid #ccc;
	padding: 5px 0;
}

.eat_txt_cnt:last-child {
	border-bottom: none;
}

.eat_txt_cnt dl {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	padding: 15px 0;
}

.eat_movie {
	max-width: 320px;
}

.eat_movie video {
	width: 100%;
}

.eat_txt_wrap {
	width: 100%;
}

.eat_txt_cnt dl.e03_dl {
	flex-direction: column;
	gap: 0;
}

.eat_txt_cnt dl.e03_dl dt {
	background-color: #F3C91B;
	padding: 2px 15px;
	text-align: center;
	display: inline-block;
	font-weight: bold;
	font-size: 20px;
	color: #412C12;
	width: 100px;
}

.story {
	background-image: url(/img/sos/oden/bg_hero.webp);
	background-repeat: repeat;
	width: 100%;
	height: 100%;
	padding: 50px 0;
}

.story_ttl {
	text-align: center;
	margin-bottom: 40px;
}

.story_cap {
	text-align: center;
	margin-bottom: 40px;
}

.bnr_wrap {
	display: flex;
	justify-content: center;
}

.story_sos {
	display: inline-block;
	text-align: center;
	margin: 0 auto 50px;
	transition: all 0.3s;
}

.story_sos:hover {
	transition: all 0.3s;
	opacity: 0.7;
}

.story_pt_wrap {
	display: flex;
	width: 100%;
	margin-bottom: 50px;
}

.story_pt {
	width: 50%;
}

.story_pt img {
	width: 100%;
	height: auto;
}

.question {
	margin-bottom: 30px;
}

.que_ttl {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 30px;
	margin-bottom: 40px;
}

.que_ttl:before,
.que_ttl:after {
	width: 100%;
	border-top: 8px double;
	content: '';
	flex-grow: 1;
}

.que_ttl:before {
	left: -3rem;
}

.que_ttl:after {
	right: -3rem;
}

.que_cnt {
	display: flex;
	justify-content: space-between;
}

.que_box {
	background-color: #fff;
	border-radius: 20px;
	position: relative;
	padding: 60px 20px 40px;
	text-align: center;
	width: 100%;
}

.mae .que_box {
	width: 48%;
}

.que_icn {
	position: absolute;
	transform: translateX(-50%);
	left: 50%;
	top: -35px;
}

.que_txt_item {
	position: relative;
	z-index: 5;
}

.ato .que_txt_item p {
	margin-bottom: 8px;
}

.que_box_ttl {
	font-weight: bold;
	font-size: 22px;
	color: #72AF1A;
	margin-bottom: 8px;
}

.ato .que_box_ttl {
	color: #F35D1B;
}

.que_list {
	display: inline-flex;
	flex-direction: column;
	gap: 5px;
	align-items: center;
	justify-content: center;
}

.que_list li {
	background-color: #EAF6F7;
	border-radius: 20px;
	padding: 12px 15px;
	font-weight: bold;
}

.que_arr {
	text-align: center;
	margin-bottom: 20px;
}

.que_goal {
	text-align: center;
	margin-bottom: 100px;
}

.message {
	position: relative;
	background-color: #fff;
	border-radius: 20px;
	padding: 100px 120px 70px;
}

.mess_bln {
	position: absolute;
	transform: translateX(-50%);
	left: 50%;
	top: -20px;
}

.mess_cnt {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	gap: 40px;
	margin-bottom: 40px;
}

.mess_box_cap {
	font-weight: bold;
	font-size: 18px;
	margin-bottom: 12px;
}

.mess_box_cap span {
	color: #F35D1B;
}

.mess_box_txt {
	background-color: #F7F3EA;
	border-radius: 20px;
	margin-bottom: 10px;
	padding: 15px 20px;
	font-weight: bold;
}

.mess_txt {
	text-align: center;
}










@media screen and (max-width:640px) {
	.hero {
		padding-top: 30px;
	}

	.online_shop {
		bottom: -100px;
		right: 5px;
	}

	.haikei_ttl {
		left: 0;
		transform: none;
		top: -45px;
	}

	.haikei_box {
		padding: 40px 20px;
	}

	.haikei_box.-kikaku {
		padding-top: 60px;
	}

	.haikei_box p {
		text-align: left;
		font-size: 16px;
	}

	.collabo {
		flex-direction: column-reverse;
		gap: 30px;
	}

	.collabo_img {
		max-width: 200px;
		margin: 0 auto;
	}

	.collabo_cnt h3 {
		text-align: center;
	}

	.hot {
		flex-direction: column-reverse;
		gap: 10px;
		padding: 30px 10px;
	}

	.omoi_hot dd {
		font-size: 15px;
	}

	.stock_ttl {
		display: flex;
		justify-content: center;
	}

	.stock_voice img {
		width: 100%;
		height: auto;
	}

	.stock_img_box {
		flex-direction: column;
		gap: 20px;
	}

	.stock {
		padding: 50px 0 0;
	}

	.stock_movie {
		margin: 0 auto;
	}

	.eat_ttl {
		display: flex;
		justify-content: center;
		padding: 0 30px;
	}

	.eat_cap {
		font-size: 16px;
		margin-bottom: 30px;
	}

	.eat_cnt h3 {
		font-size: 20px;
	}

	.eat_box {
		flex-direction: column;
		gap: 30px;
	}

	.eat_txt_img {
		flex: none;
	}

	.story_ttl {
		margin-bottom: 20px;
	}

	.story_pt_wrap {
		flex-direction: column;
	}

	.story_pt {
		width: 100%;
	}

	.que_ttl {
		gap: 20px;
	}

	.que_ttl img {
		max-width: 250px;
		width: 100%;
		height: auto;
	}

	.que_cnt {
		flex-direction: column;
	}

	.que_goal img {
		width: 100%;
	}

	.mae .que_box {
		width: 100%;
	}

	.que_box_ttl {
		font-size: 18px;
	}

	.que_list li {
		width: 100%;
	}

	.message {
		padding: 70px 20px 40px;
	}

	.mess_cnt {
		flex-direction: column-reverse;
		align-items: center;
		gap: 20px;
	}

	.mess_bln {
		transform: none;
		left: 20%;
	}

	.mess_box_cap {
		text-align: center;
	}

	.mess_txt {
		text-align: left;
	}

















}