@charset "UTF-8";

.insta_link {
	position: fixed;
	top: 90px;
	right: 40px;
	z-index: 5;
	max-width: 70px;
	width: 100%;
}

.insta_link img {
	width: 100%;
}

@media screen and (max-width: 500px) {
	.insta_link {
		top: 70px;
		right: 10px;
		width: 50px;
	}
}

.festival_keyvisual {
	position: relative;
	padding-top: 75px;
}

.festival_keyvisual-bg {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100%;
	height: clamp(31.25rem, 21.806rem + 47.22vw, 63.125rem);
	opacity: 0.15;
	filter: blur(6px);

	object-fit: cover;
	object-position: center;
}


.keyvisual_confetti {
	position: absolute;
	top: 155px;
	left: 50%;
	transform: translateX(-50%);
	width: 1920px;
}

.festival_keyvisual-inner {
	position: relative;
	padding-top: clamp(2.188rem, 1.723rem + 1.98vw, 2.813rem);
}

.festival_keyvisual-contents {
	display: block;
	position: relative;
	max-width: 1680px;
	width: 90%;
	margin: auto;
}

.fv-pc_img {
	max-width: 100%;
	margin: auto;
}

.fv-right-top_img {
	position: absolute;
	top: -3%;
	right: 8%;
	width: clamp(12.5rem, 2.069rem + 20.86vw, 20.063rem);
}

@media screen and (max-width: 1200px) {
	.fv-right-top_img {
		top: -10%;
	}
}

.festival_keyvisual-left {
	position: absolute;
	top: 10px;
	right: calc(100% - 10px);
	max-width: 86px;
	width: 14%;
}

.festival_keyvisual-main {
	width: 100%;
}

.festival_count-text {
	display: flex;
	position: absolute;
	transform: rotateZ(21deg);
	transform-origin: center;
	color: #e80000;
	font-weight: 900;
	font-size: clamp(0.75rem, 0.425rem + 1.39vw, 1.188rem);
	align-items: center;
}

.festival_count-text.that_day {
	font-size: clamp(1.063rem, 0.181rem + 3.76vw, 2.25rem);
}

.festival_count-text::before , .festival_count-text::after {
	display: block;
	width: clamp(0.188rem, 0.095rem + 0.4vw, 0.313rem);
	background-color: #e80000;
	content: "";

	aspect-ratio: 1/10;
}

.festival_count-text::before {
	transform: rotateZ(-24deg);
	margin-right: clamp(0.5rem, 0.407rem + 0.4vw, 0.625rem);
}

.festival_count-text::after {
	transform: rotateZ(24deg);
	margin-left: clamp(0.5rem, 0.407rem + 0.4vw, 0.625rem);
}


.festival_count-text span {
	display: inline-block;
}

.count_down {
	margin-left: clamp(0.125rem, -0.014rem + 0.59vw, 0.313rem);
	font-size: clamp(1.563rem, 0.681rem + 3.76vw, 2.75rem);
}

.festival_count-text span:not(.count_down) {
	transform: rotateZ(10deg);
	font-weight: bold;
	font-size: clamp(1.063rem, 0.181rem + 3.76vw, 2.25rem);
}

.fv-title_mb , .fv-bottom-flex {
	display: none;
}

@media screen and (min-width: 1000px) {
	.company-slider {
		position: relative;
		top: -100px;
	}
}

@media screen and (min-width: 768px) {
	.festival_keyvisual {
		padding-top: 75px;
	}

	.keyvisual_confetti {
		top: 155px;
		width: 1920px;
	}

	.festival_count-text {
		top: 20px;
		right: 0;
	}

	.festival_count-text span:not(.count_down) {
		font-weight: bold;
	}

	.festival_keyvisual-contents {
		/* width: 75%; */
		margin: 0 auto;
	}
}

@media screen and (max-width: 767px) {
	.festival_keyvisual {
		/* padding-top: 50px; */
	}

	.keyvisual_confetti {
		top: 15px;
		width: 573px;
	}

	.insta_link , .festival_keyvisual-left {
		display: none;
	}

	.festival_keyvisual-contents {
		/* left: 50%;
		transform: translateX(-50%); */
		/* width: 104%; */
	}

	.festival_count-text {
		right: 5%;
		white-space: nowrap;
	}

	.festival_count-text span:not(.count_down) {
		font-weight: 900;
	}

	@media screen and (min-width: 375px) {
		.festival_count-text {
			top: clamp(0.313rem, -1.312rem + 6.93vw, 2.5rem);
		}
	}

	@media screen and (max-width: 374px) {
		.festival_count-text {
			bottom: calc(100% - 40px);
		}
	}
}

@media screen and (max-width: 700px) {
	.festival_keyvisual-inner {
		padding-top: 80px;
	}

	.festival_keyvisual-contents {
		width: 95%;
	}

	.festival_keyvisual-bg {
		height: 100vh;
	}

	.fv-right-top_img {
		right: 0;
	}

	.fv-pc_img {
		display: none;
	}

	.fv-title_mb {
		display: block;
		max-width: 350px;
		margin: auto;
	}

	.fv-bottom-flex {
		display: block;
		position: relative;
		max-width: 500px;
		height: 100%;
		margin: auto;
	}

	.fv-bottom-left {
		position: relative;
		z-index: 2;
		width: 230px;
		height: 100%;
	}

	.fv-bottom-right {
		position: absolute;
		top: 0;
		right: 0;
		z-index: 1;
		width: 220px;
		height: 100%;
	}
}

@media screen and (max-width: 500px) {
	.festival_keyvisual-inner {
		padding-top: 50px;
	}
	.fv-right-top_img {
		top: -15%;
	}
}


/* ファーストビュー */

.fv-container {
	padding-top: 56px;
	padding-bottom: 30px;
	background-image: url(../images/top-fv_img.png);
	background-repeat: no-repeat;
	background-size: cover;
}

.fv-contents__container {
	position: relative;
	max-width: 1400px;
	margin: auto;
}

.center-contents__container {
	position: relative;
	z-index: 10;
}

.center-title__container {
	position: relative;
	max-width: 630px;
	min-width: 350px;
	margin: auto;
	padding-top: 7.5%;
	padding-bottom: 7.5%;
	background-image: url(../images/title-bg_img.png);
	background-repeat: no-repeat;
	background-position-x: 50%;
	background-position-y: 0%;
	background-size: contain;
	text-align: center;
}

.count-text_wrap {
	position: absolute;
	top: 0;
	right: 7%;
	transform: rotate(20deg);
}

.count-text {
	position: relative;
	color: #ff0000;
	font-weight: 900;
	font-size: clamp(0.938rem, 0.877rem + 0.26vw, 1.188rem);
}

.count-text::before {
	position: absolute;
	bottom: 0;
	left: -20px;
	transform: rotate(-20deg);
	width: clamp(0.188rem, 0.157rem + 0.13vw, 0.313rem);
	height: clamp(1.875rem, 1.632rem + 1.04vw, 2.875rem);
	background-color: #ff0000;
	content: "";
}

.count-text::after {
	position: absolute;
	right: -20px;
	bottom: 0;
	transform: rotate(20deg);
	width: clamp(0.188rem, 0.157rem + 0.13vw, 0.313rem);
	height: clamp(1.875rem, 1.632rem + 1.04vw, 2.875rem);
	background-color: #ff0000;
	content: "";
}

.count-text span {
	font-size: clamp(1.5rem, 1.197rem + 1.29vw, 2.75rem);
}

.top-title-text {
	font-weight: 700;
	font-size: clamp(1.063rem, 0.179rem + 1.41vw, 1.875rem);
}

.main-title-text {
	font-size: clamp(3rem, -0.872rem + 6.2vw, 6.563rem);
	line-height: 1.1;
}

.event-day {
	color: #ff0000;
	font-weight: 900;
	font-size: clamp(1.438rem, 0.079rem + 2.17vw, 2.688rem);
}

.event-day span {
	font-size: clamp(1.125rem, 0.989rem + 0.22vw, 1.25rem);
}

.time-place_text {
	font-weight: 700;
	line-height: 2;
}

.left-deco_img {
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

.right-deco_img {
	position: absolute;
	right: 0;
	bottom: 0;
	z-index: 0;
	z-index: -1;
}

.left-menu__container {
	position: absolute;
	right: calc(100% + 105px);
	bottom: 10%;
	z-index: 1;
	width: 265px;
	border-radius: 50%;
	background-color: #dec70d;

	aspect-ratio: 1;
}

@media screen and (max-width: 1400px) {
	.left-menu__container {
		display: none;
	}

	.right-menu__container {
		display: none;
	}
}

.menu-top-title {
	padding-top: 30px;
	color: #ffffff;
	font-size: 40px;
	text-align: center;
}

.menu-list {
	display: flex;
	width: 70%;
	margin: auto;
	padding-top: 8px;
	flex-wrap: wrap;
	justify-content: center;
}

.menu-contents {
	width: calc(100% / 2);
	color: #ffffff;
	font-size: 17px;
	line-height: 1.6;
}

.right-menu__container {
	position: absolute;
	top: 50px;
	left: calc(100% + 40px);
	z-index: 1;
	width: 336px;
	border-radius: 50%;
	background-color: #fa7b35;

	aspect-ratio: 1;
}

.right-menu__container .menu-top-title {
	font-size: 50px;
}

.right-menu__container .menu-contents {
	font-size: 18px;
}

.right-menu__container .menu-list {
	width: 80%;
}

.company-slider {
	margin-top: 30px;
}

.slider-contents {
	max-width: 265px;
	width: 100%;
	margin: 0 20px;

	aspect-ratio: 53/45;
}

.slide_wrap {
	display: block;
	position: relative;
	width: 100%;
	height: 100%;
	transition: all 0.5s;
}

.slick-slide img {
	/* align-self: start; */
	max-width: 90%;
}

.slide_wrap:hover {
	opacity: 0.7;
}

.top_img {
	/* width: 100%; */
	max-height: 100%;

	object-fit: cover;
	object-position: center;
}

.bottom_img {
	/* width: 100%; */
	height: auto;

	object-fit: cover;
	object-position: center;
}

.top_wrap {
	display: flex;
	overflow: hidden;
	max-width: 265px;
	width: 100% !important;
	padding: 5px;
	border-radius: 5px;
	box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
	background-color: #ffffff;
	justify-content: center;
	align-items: center;

	aspect-ratio: 53/37;
}

.bottom_wrap {
	display: flex;
	position: absolute;
	bottom: 0;
	left: 50%;
	overflow: hidden;
	transform: translateX(-50%);
	max-width: 220px;
	width: 85%;
	margin: auto;
	border-radius: 5px;
	border-radius: 5px;
	box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
	background-color: #ffffff;
	justify-content: center;
	align-items: center;

	aspect-ratio: 22/7;
}

.button_container {
	margin-top: 80px;
	text-align: center;
}

@media screen and (max-width: 768px) {
	.button_container {
		margin-top: 40px;
	}
}

/* スポンサー企業 */

.top-main_contents {
	position: relative;
	background-color: rgba(255, 255, 255, 0.95);
	background-image: url(../images/bottom-bg.png);
	background-repeat: no-repeat;
	background-position: right bottom;
	background-blend-mode: lighten;
	background-size: clamp(22.5rem, 1.364rem + 90.18vw, 69rem);
}

.top-side-bg {
	position: absolute;
	top: -1%;
	top: 0;
	left: 0;
	z-index: 0;
	max-width: 100%;
}

@media screen and (max-width: 645px) {
	.top-side-bg {
		top: 0;
	}
}

/* スマイルプロジェクトとは？ */

.smile-project__container {
	padding-top: 220px;
	padding-bottom: 170px;
	/* background-image: url(../images/top-left-bg.png), url(../images/top-right-bg.png);
	background-repeat: no-repeat;
	background-position-x: -2%, 102%;
	background-position-y: 9%;
	background-size: clamp(6.875rem, -5.625rem + 50vw, 31.875rem); */
}

.background__container {
	background-image: url(../images/smile_bg.png);
	background-repeat: no-repeat;
	background-position-x: 55%;
	background-position-y: 40%;
	background-size: clamp(20.625rem, -2.438rem + 82vw, 43.688rem);
}

.smile-logo-img {
	margin: auto;
}

.contents-title_wrap_smile {
	margin-top: 20px;
	font-family: "コーポレート・ロゴ ver2";
	text-align: center;
}

.en-title {
	color: #fa7b35;
	font-weight: 500;
	font-size: clamp(1rem, 0.813rem + 0.5vw, 1.188rem);
}

.ja-title {
	color: #585858;
	font-weight: 700;
	font-size: clamp(1.75rem, 1rem + 2vw, 2.5rem);
}

.smile-project_textarea {
	margin-top: 35px;
	color: #404040;
	font-size: clamp(0.875rem, 0.563rem + 0.83vw, 1.188rem);
	line-height: 1.6;
	text-align: center;
}

@media screen and (max-width: 768px) {
	.smile-project__container {
		padding-top: 55px;
		padding-bottom: 36px;
		background-position-y: 0;
	}

	.contents-title_wrap_smile {
		margin-top: 0;
	}
}

/* お知らせ */

.news__container {
	padding-top: 70px;
}

.news-contents_container {
	position: relative;
	z-index: 1;
	max-width: 700px;
	width: 90%;
	margin: auto;
	margin-top: 70px;
}

.news-flex-contents {
	display: flex;
	padding-right: 15px;
	padding-bottom: 10px;
	padding-left: 30px;
	border-bottom: 1px solid #707070;
	font-size: clamp(0.875rem, 0.563rem + 1vw, 1.125rem);
	justify-content: space-between;
	align-items: center;
}

.news-flex-contents:not(:first-child) {
	margin-top: 12px;
}

.news-text_wrap {
	display: flex;
	color: #3e3e3e;
}

.news-title {
	display: -webkit-box;
	overflow: hidden;
	padding-left: 55px;
	-webkit-box-orient: vertical;

	-webkit-line-clamp: 1;
}

#postid_1355 .news-title {
	color: #FF0000;
}

@media screen and (max-width: 768px) {
	.news__container {
		margin-bottom: 90px;
	}
	.news-contents_container {
		margin-top: 36px;
	}
}

@media screen and (max-width: 600px) {
	.news-flex-contents {
		padding-left: 20px;
	}

	.news-title {
		padding-left: 25px;
	}
}

/* 私たちの活動 */

.activity__container {
	margin-top: 150px;
	background-image: url(../images/activity_bg.png);
	background-repeat: no-repeat;
	background-position: clamp(1.875rem, -9.375rem + 30vw, 7.5rem) center;
	background-size: contain;
}

.img-flex_wrap {
	display: flex;
	width: 90%;
	margin: auto;
	margin-top: 16px;
	column-gap: 20px;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;

	row-gap: 24px;
}

.activity_img:first-of-type {
	max-width: clamp(15.063rem, 4.063rem + 22.92vw, 21.25rem);
	width: 100%;
	height: 100%;
}

.activity_img:last-of-type {
	max-width: clamp(22.5rem, 3.722rem + 39.12vw, 33.063rem);
	width: 100%;
	height: 100%;
}

@media screen and (max-width: 768px) {
	.activity__container {
		margin-top: 40px;
		background-image: none;
	}
}

@media screen and (max-width: 689px) {
	.img-flex_wrap {
		width: 85%;
		margin-top: 30px;
	}
}

/* 出店情報 */

.shop__container {
	margin-top: 120px;
	padding: 80px 0;
	/* background-image: url(../images/top-left-bg.png), url(../images/top-right-bg.png);
    background-repeat: no-repeat;
    background-position-x: -2%, 102%;
    background-position-y: 9%;
    background-size: clamp(6.875rem, -5.625rem + 50vw, 31.875rem); */
}

.bg-area_container {
	background-image: url(../images/shop_bg.png);
	background-repeat: no-repeat;
	background-size: contain;
}

.img-area_container {
	position: relative;
	max-width: 1000px;
	width: 95%;
	margin: auto;
}

.shop-icon {
	position: absolute;
}


.contents-title_wrap {
	position: relative;
	background-image: url(../images/store-title-bg.png);
	background-repeat: no-repeat;
	background-position-x: center;
	background-size: contain;
	line-height: 2;
	text-align: center;
}

.smile-project__container .contents-title_wrap {
	background-image: none;
}

.contents-title_wrap.title-margin {
	margin-top: 100px;
}

.title-en {
	color: #939393;
	font-family: "Impact";
	font-size: clamp(1.125rem, 0.125rem + 2.67vw, 2.125rem);
}

.title-ja {
	color: #fa7b35;
	font-weight: 900;
	font-size: clamp(1.125rem, 0.125rem + 2.67vw, 2.125rem);
}

.title-bottom_text_side {
	margin-top: 16px;
	text-align: center;
}

.text-icon_wrap {
	display: inline-block;
	position: relative;
}

.shop-icon.icon_1 {
	top: 26.5%;
}

.shop-icon.icon_2 {
	top: 15%;
	left: 15%;
}

.shop-icon.icon_3 {
	top: 15%;
	right: 10%;
}

.shop-icon.icon_4 {
	right: 25%;
	bottom: -2%;
}

.shop-icon.icon_5 {
	right: 12%;
	bottom: -5%;
}

@media screen and (max-width: 1012px) {
	.shop-icon.icon_1 {
		top: 17.5%;
		left: 10%;
	}

	.shop-icon.icon_3 {
		top: 10%;
		right: 13%;
	}
}

@media screen and (max-width: 767px) {
	.contents-title_wrap.title-margin {
		margin-top: 60px;
	}
}

@media screen and (max-width: 671px) {
	.text-icon_wrap {
		font-size: 13px;
	}

	.shop-icon.icon_2 {
		left: -10%;
		max-width: 60px;
	}

	.shop-icon.icon_1 , .shop-icon.icon_3 , .shop-icon.icon_4 , .shop-icon.icon_5 {
		display: none;
	}
}

.shop-img-list {
	display: flex;
	max-width: 1000px;

/* width: 95%; */
	margin: auto;
	margin-top: 85px;
	column-gap: 5%;
	flex-wrap: wrap;
	justify-content: space-between;

	row-gap: 50px;
}

.shop-info-wrap {
	max-width: 300px;
	width: 30%;
}

.shop-info-wrap > a {
	display: flex;
	width: fit-content;
	margin-top: 15px;
	margin-left: auto;
	color: #fa7b35;
	font-weight: 500;
	font-size: 15px;
	align-items: center;
}

.shop-info-wrap > a i {
	margin-left: 10px;
}

.shop-page-link {
	position: relative;
	width: 100%;
}

.shop-img {
	overflow: hidden;
	max-width: 100%;
	margin-bottom: 20px;
	border-radius: 10px;
	box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);

	aspect-ratio: 3/2;
}

.shop-img a {
	display: flex;
	height: 100%;
	background-color: #ffffff;
	justify-content: center;
	align-items: center;
}

.shop-img img {
	width: 100%;
	height: 100%;
	margin: auto;

	object-fit: contain;
	object-position: center;
}

.shop-info-bg {
	width: 100%;
	border-radius: 10px;
	transition: all 0.3s;
}

.shop_category {
	display: flex;
	max-width: fit-content;
	padding: 5px 30px;
	border-radius: 15px;
	color: #ffffff;
	font-weight: 900;
	font-size: 14px;
}

/*.shop-page-link:hover .shop-info-bg {
	opacity: 1;
}*/

.shop-title {
	overflow: hidden;
	padding-top: 5px;
	font-weight: bold;
	font-size: clamp(1.25rem, 0.694rem + 1.16vw, 1.563rem);
	white-space: nowrap;
	text-overflow: ellipsis;
}

.shop-info-bg p {
	display: -webkit-box;
	overflow: hidden;
	margin-top: 10px;
	font-size: clamp(0.813rem, 0.59rem + 0.46vw, 0.938rem);
	line-height: 25px;
	text-align: justify;
	-webkit-box-orient: vertical;

	-webkit-line-clamp: 2;
}

@media screen and (max-width: 1012px) {
	.shop-img-list {
		justify-content: space-evenly;
	}
}

@media screen and (max-width: 768px) {
	.shop-icon.icon_3 {
		right: 9%;
	}

	.shop-icon.icon_5 {
		right: 7%;
	}
}

@media screen and (max-width: 767px) {
	.shop__container {
		margin-top: 60px;
		padding: 45px 0;
		background-image: none;
		background-position-y: center;
	}

	.shop-img-list::after {
		display: block;
		max-width: 300px;
		width: calc(100%/ 2);
		content: "";
	}

	.shop-info-wrap {
		width: calc(100% / 2);
	}

	.contents-title_wrap {
		width: 90%;
		margin: auto;
		line-height: 1.5;
	}

	.shop-img-list {
		margin-top: 40px;
	}

	.shop-icon.icon_2 {
		display: none;
	}

	.shop-icon.icon_3 {
		display: none;
	}
}

@media screen and (max-width: 660px) {
	.shop-info-wrap {
		width: 100%;
	}
}

/* 当日プログラム */

.timetable__container {
	max-width: 1920px;
	margin: auto;
	margin-top: 100px;
	padding-bottom: 170px;
	background-image: url(../images/program_bg.png);
	background-repeat: no-repeat;
	background-position-y: center;
	background-size: 100%;
}

.title-bottom-text_width {
	max-width: 357px;
	margin: auto;
	margin-top: 50px;
	font-size: 17px;
	line-height: 1.7;
}

.program-time_container {
	text-align: center;
}

.program-time_container {
	max-width: 513px;
	width: 90%;
	margin: auto;
	margin-top: 23px;
	padding-top: 16px;
	padding-bottom: 63px;
	background-image: url(../images/timetable_img.png);
	background-repeat: no-repeat;
	background-position-x: center;
	background-size: contain;
}

.text-line-marker {
	padding: 0 20px;
	background: linear-gradient(transparent 30%, rgba(222, 193, 13, 0.5) 30%);
	color: #fa7b35;
	font-weight: 700;
	font-size: 20px;
	line-height: 1.5;
}

.time-img_wrap {
	position: relative;
	max-width: 316px;
	margin: auto;
	margin-top: 20px;
}

.time_img {
	position: relative;
	max-width: 316px;
	margin: auto;
}

.time-left-top {
	position: absolute;
	top: -9px;
	left: -22px;
	max-width: 56px;
}

.place-text {
	margin-top: 6px;
	color: #fa7b35;
	font-weight: 700;
}

.button_container.program_button {
	margin-top: 25px;
}

@media screen and (max-width: 768px) {
	.timetable__container {
		margin-top: 45px;
		padding-bottom: 36px;
	}
}

@media screen and (max-width: 550px) {
	.title-bottom-text_width {
		max-width: 294px;
		margin-top: 30px;
		font-size: 14px;
	}

	.program-time_container {
		padding-top: 0;
	}

	.text-line-marker {
		padding: 0 15px;
		font-size: 16px;
	}

	.time-img_wrap {
		max-width: 210px;
		margin-top: 10px;
	}

	.time_img {
		max-width: 210px;
	}

	.time-left-top {
		max-width: 42px;
	}

	.place-text {
		font-size: 14px;
	}
}

/* スポンサー */

.company__container {
	max-width: 1000px;
	margin: auto;

/* padding-top: 165px; */
	padding-bottom: 86px;
}

.contents-title {
	margin-bottom: 30px;
	color: #fa7b35;
	font-size: clamp(1.563rem, 1.396rem + 0.71vw, 2.25rem);
	text-align: center;
}

.common_company-list {
	display: flex;
	margin: 0 auto;
	flex-wrap: wrap;
}

.company-max-list {
	margin-top: 36px;
	margin-bottom: 45px;
	column-gap: 2.6667%;

	row-gap: 20px;
}


.company-mini-list {
	row-gap: 15px;
}

.common_company-item {
	overflow: hidden;
	box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
	background-color: #ffffff;
}

.common_company-item.company-private {
	box-shadow: none;
	background-color: transparent;
}

.company-max-item {
	max-width: 230px;
	width: 23%;

	aspect-ratio: 23/11;
}




@media screen and (min-width: 835px) {
	.company-max-list {
		column-gap: 2.6667%;
	}

	.company-max-item {
		width: 23%;
	}
}


@media screen and (max-width: 834px) {
	.company-max-list {
		max-width: 750px;
		column-gap: 4%;
	}

	.company-max-item {
		width: 30.6667%;
	}
}

@media screen and (max-width: 767px) {
	.company-max-list {
		max-width: 790px;
		column-gap: 6.3292%;
	}

	.company-max-item {
		width: 29.114%;
	}

	.time-place_text {
		transform: translateX(-5px);
		margin-bottom: 20px;
		font-weight: 600;
		line-height: 1.7;
	}

	.private_sp {
		font-size: 14px;
	}
}


@media screen and (max-width: 500px) {
	.company-max-list {
		max-width: 490px;
		column-gap: 6.1225%;
	}

	.company-max-item {
		width: 46.9388%;
	}
}

.company-mini-item {
	max-width: 185px;

	aspect-ratio: 37/18;
}

.company-img {
	transform: scale(0.9);

/* width: 100%; */
	max-width: 90%;
	max-height: 100%;
	transition: all 0.3s;

	object-fit: cover;
	object-position: center;
}

.common_company-item a:hover .company-img {
	transform: scale(1);
}

.company-wrap a {
	display: flex;
	width: 100%;
	height: 100%;
	justify-content: center;
	align-items: center;
}

.place {
	display: flex;
	width: 100%;
	height: 100%;
	justify-content: center;
	align-items: center;
}

.company-private .place {
	justify-content: flex-start;
}

.company-link-list {
	display: flex;
	column-gap: clamp(1.875rem, 0.625rem + 2.6vw, 3.75rem);
	flex-wrap: wrap;
	justify-content: center;

	row-gap: 15px;
}

@media screen and (min-width: 768px) {
	.company__container {
		width: 95%;

/* padding-top: 8.7395%; */
		padding-bottom: 85px;
	}

	.company-mini-list {
		margin-top: 35px;
	}

	.company-link-list {
		margin-top: 40px;
		column-gap: clamp(1.875rem, 0.625rem + 2.6vw, 3.75rem);
	}

	@media screen and (min-width: 835px) {
		.company-mini-list {
			max-width: 985px;
			column-gap: 1.5229%;
		}

		.company-mini-item {
			width: 18.7818%;
		}
	}

	@media screen and (max-width: 834px) {
		.company-mini-list {
			max-width: 785px;
			column-gap: 1.9109%;
		}

		.company-mini-item {
			width: 23.5669%;
		}
	}
}

@media screen and (max-width: 767px) {
	.fv-container {
		padding-top: 0;
	}

	.contents-title {
		margin-bottom: 20px;
	}

	.company-max-list {
		margin-bottom: 30px;
	}

	.center-contents__container {
		padding-top: 55px;
	}

	.company__container {
		width: 100%;
		padding: 40px 30px 40px;
	}

	.company-mini-list {
		margin-top: 20px;
	}

	.company-link-list {
		margin-top: 30px;
		column-gap: clamp(1.25rem, 0.803rem + 2.24vw, 1.875rem);
	}

	@media screen and (min-width: 375px) {
		.company-mini-list {
			max-width: 585px;
			column-gap: 2.5642%;
		}

		.company-mini-item {
			width: 31.624%;
		}
	}

	@media screen

	/*and (min-width: 375px)*/
	and (max-width: 374px) {
		.company-mini-list {
			max-width: 385px;
			column-gap: 3.8962%;
		}

		.company-mini-item {
			width: 48.052%;
		}
	}

	/*@media screen and (max-width: 374px) {
		.company-mini-list {
			max-width: 185px;
		}

		.company-mini-item {
			width: 100%;
		}
	}*/
}

@media screen and (max-width: 600px) {
	.left-deco_img , .right-deco_img {
		width: 200px;
	}
}

/*.company-link-wrap {
	width: calc(100% / 4);
}*/

.company-link-text {
	color: #2b2d6e;
	font-size: 17px;
	transition: all 0.3s;
}

.company-link-text:hover {
	opacity: 0.7;
}

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

@media screen and (max-width: 768px) {
	.bottom-text {
		font-size: 14px;
	}
}

.map_container {
	margin-top: 30px;
}

.map_container .contents-title_wrap {
	margin-bottom: 40px;
}

.map_guideline {
	font-size: clamp(1.125rem, 0.679rem + 1.43vw, 1.25rem);
	text-align: center;
}

.map_guideline span {
	font-weight: 900;
}

.map_about {
	display: block;
	max-width: 1005px;
	width: calc(100% - 40px);
	margin: 0 auto 20px;
}

.map_img {
	max-width: 600px;
	width: 100%;
	margin: 0 auto;
}

.map_about-list {
	display: flex;
	font-weight: 500;
	font-size: clamp(0.625rem, -0.491rem + 3.57vw, 0.938rem);
	column-gap: 15px;
	flex-wrap: wrap;

	row-gap: 10px;
}

.map_about-list li {
	display: flex;
	column-gap: 5px;
	align-items: center;
}

.map_about-list li::before {
	display: block;
	width: 16px;
	align-items: center;
	content: "";

	aspect-ratio: 1;
}

#food::before {
	background-color: #fa7412;
}

#sales::before {
	background-color: #5486ab;
}

#recreate::before {
	background-color: #dec70e;
}

#rest::before {
	background-color: #6dd335;
}

.map_list_container {
	display: flex;
	max-width: 1005px;
	width: calc(100% - 30px);
	margin: 0 auto;
	flex-direction: column;
}

.map_list {
	display: flex;
	width: 100%;
	margin-bottom: 20px;
	flex-wrap: wrap;
}

.map_item {
	display: block;
	position: relative;
	border-top: 1px solid #707070;
	border-bottom: 1px solid #707070;
}

.map_item::before , .map_item::after {
	display: block;
	position: absolute;
	top: 0;
	z-index: 3;
	width: 1px;
	height: 100%;
	background-color: #707070;
}


@media screen and (min-width: 768px) {
	.page-title_wrap {
		margin-bottom: 50px;
	}

	.map_item {
		width: calc(100% / 5);
	}

	.map_guideline {
		margin-bottom: 40px;
	}

	.map_about {
		margin-bottom: 40px;
	}

	.map_img {
		margin-bottom: 30px;
	}

	.map_list {
		margin-bottom: 30px;

		row-gap: 20px;
	}

	.map_item:nth-child(5n+1)::before , .map_item:nth-child(5n)::after , .map_item:not(:nth-child(5n))::after {
		content: "";
	}

	.map_item:nth-child(5n+1)::before {
		right: 100%;
	}

	.map_item:nth-child(5n)::after , .map_item:not(:nth-child(5n))::after {
		left: 100%;
	}
}

@media screen and (max-width: 767px) {
	.page-title_wrap {
		margin-bottom: 10px;
	}

	.map_item {
		width: calc(100% / 3);
	}

	.map_guideline {
		margin-bottom: 20px;
	}

	.map_about {
		margin-bottom: 20px;
	}

	.map_img {
		margin-bottom: 10px;
	}

	.map_list {
		margin-bottom: 20px;

		row-gap: 10px;
	}

	.map_item:nth-child(3n+1)::before , .map_item:nth-child(3n)::after , .map_item:not(:nth-child(3n))::after {
		content: "";
	}

	.map_item:nth-child(3n+1)::before {
		right: 100%;
	}

	.map_item:nth-child(3n)::after , .map_item:not(:nth-child(3n))::after {
		left: 100%;
	}
}

.map_item-content {
	display: flex;
	flex-direction: column-reverse;
	justify-content: space-between;
}

.map_item-img {
	overflow: hidden;
	transform-origin: center;
	width: 100%;
	height: 100%;

/*aspect-ratio: 23/16;*/

	aspect-ratio: 10/7;
}


.map_item-img img {
	width: 100%;
	height: 100%;
	transition: all 0.5s;

	object-fit: contain;
	object-position: center;
}

.map_item a {
	color: #3e3e3e;
	transition: all 0.5s;
}

.map_item a:hover .map_item-img img {
	transform: scale(1.1);
}

.map_item-detail {
	display: flex;
	border-bottom: 1px solid #707070;
	text-align: center;
	align-items: center;
}

.map_item-num {
	display: flex;
	width: clamp(1.563rem, -0.235rem + 3.75vw, 2.188rem);
	border-right: 1px solid #707070;
	color: #ffffff;
	font-weight: 900;
	font-size: clamp(0.938rem, 0.039rem + 1.87vw, 1.25rem);
	justify-content: center;
	align-items: center;
	transition: all 0.5s;

	aspect-ratio: 1/1;
}

.map_item a:hover .map_item-num {
	background-color: #ffffff !important;
}

.map_item-title {
	display: flex;
	overflow: hidden;
	width: calc(100% - clamp(1.563rem, -0.235rem + 3.75vw, 2.188rem));
	padding: 0 5px;
	font-size: clamp(0.625rem, -0.274rem + 1.87vw, 0.938rem);
	text-align: justify;
	justify-content: center;
}

.map_item-title span {
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}

.slick-slide {
	height: auto !important;
	/* 余白対策（開発環境専用） */
}

/* LINE */
.festival_line-container {
	display: flex;
	margin: 0 auto;
	column-gap: clamp(0.625rem, -2.533rem + 6.58vw, 1.25rem);
}

.festival_line-img {
	max-width: 384px;
}

.festival_line-contents {
	max-width: 470px;
}

.festival_line-contents h2 {
	display: flex;
	width: 100%;
	margin-bottom: 5px;
	padding: clamp(0.5rem, -1.395rem + 3.95vw, 0.875rem) 10px;
	background-color: #06c755;
	color: #ffffff;
	font-size: clamp(1.313rem, -6.582rem + 16.45vw, 2.875rem);
	column-gap: clamp(0.188rem, -0.444rem + 1.32vw, 0.313rem);
	justify-content: center;
	align-items: baseline;
}

.festival_line-contents h2 span {
	font-size: clamp(2.125rem, -9.559rem + 24.34vw, 4.438rem);
}

.festival_line-contents p {
	margin-bottom: 25px;
	color: #fa7b35;
	font-weight: bold;
	font-size: clamp(0.875rem, -3.23rem + 8.55vw, 1.688rem);
	line-height: clamp(1.313rem, -4.688rem + 12.5vw, 2.5rem);
	letter-spacing: 0.05em;
}

.festival_line-contents p strong {
	display: flex;
	margin-bottom: clamp(0rem, -1.579rem + 3.29vw, 0.313rem);
	font-size: clamp(1.313rem, -6.582rem + 16.45vw, 2.875rem);
	align-items: center;
}

.festival_line-contents p strong i {
	margin-left: clamp(0.188rem, -0.444rem + 1.32vw, 0.313rem);
	color: #707070;
	font-size: clamp(2.5rem, -5.711rem + 17.11vw, 4.125rem);
}

.festival_line-contents p span {
	display: inline-flex;
	position: relative;
	z-index: 1;
}

.festival_line-contents p span::after {
	display: block;
	position: absolute;
	bottom: 5px;
	left: 0;
	z-index: -1;
	width: 100%;
	height: clamp(0.313rem, -1.266rem + 3.29vw, 0.625rem);
	background-color: #dec70d;
	content: "";
}

.festival_line-qr {
	display: flex;
	margin-bottom: 20px;
	color: #fa7b35;
	letter-spacing: 0.05em;
	column-gap: 5px;
	align-items: flex-end;
}

.line_qr-img {
	overflow: hidden;
	max-width: 90px;
	width: 100%;
	border-radius: 3px;

/*background-color: #888888;*/

	aspect-ratio: 1/1;
}

.line_qr-img img {
	width: 100%;
}

.festival_line-qr dt {
	padding-left: 5px;
	font-weight: 500;
	font-size: 14px;
	text-indent: 0.5em;
}

.festival_line-qr dd {
	display: flex;
	font-weight: bold;
	font-size: 15px;
	align-items: center;
}

.festival_line-qr dd::before {
	display: block;
	max-width: 12px;
	width: 100%;
	margin-right: 2px;
	background-color: #fa7b35;
	content: "";

	aspect-ratio: 6/7;
	clip-path: polygon(0 50%, 100% 100%, 100% 0);
}

.festival_line-contents .page-link-button {
	display: block;
	width: fit-content;
	background-color: #06c755;
}

.festival_line-contents .page-link-button::after {
	background-image: url(../images/link-arrow_line.png);
}

@media screen and (min-width: 768px) {
	.festival_line-container {
		max-width: 980px;
		width: 95%;
		padding-top: 260px;
	}

	.festival_line-img {
		min-width: 340px;
		width: 100%;
	}

	.festival_line-contents {
		width: 100%;
	}

	.festival_line-contents p {
		margin-bottom: 25px;
	}

	.festival_line-qr {
		display: flex;
	}
}

@media screen and (max-width: 767px) {
	.festival_line-container {
		max-width: 235px;
		width: 100%;
		padding-top: 80px;
		flex-direction: column-reverse;
	}

	.festival_line-img {
		min-width: 160px;
		width: 60%;
		margin-top: -50px;
		margin-left: 95px;
	}

	.festival_line-contents {
		width: 100%;
	}

	.festival_line-contents p {
		margin-bottom: 20px;
	}

	.festival_line-qr {
		display: none;
	}

	.festival_line-contents .page-link-button {
		margin-right: 35px;
		padding: 5.5px 8px;
	}

	.festival_line-contents .page-link-button::after {
		right: -35px;
		width: 35px;
	}
}

.thanks__container {
	margin-bottom: 50px;
}
