@charset "UTF-8";
/* ==========================================================================
   Meal Mile Program LP
   ========================================================================== */

/* --------------------------------------------------------------------------
   共通
   -------------------------------------------------------------------------- */
.mm-w1440 {
	max-width: 1440px;
	margin: 0 auto;
}

.mm-inner {
	max-width: 1110px;
	margin: -45px auto 0;
	padding: 0 20px;
}

/* --------------------------------------------------------------------------
   MV
   -------------------------------------------------------------------------- */
.mm-mv {
	position: relative;
	width: 100%;
	overflow: hidden;
	max-width: 1440px;
	margin: 0 auto;
}

.mm-mv__img {
	width: 100%;
	height: auto;
	display: block;
	pointer-events: none;
}

/* MV プレースホルダー（Figmaから手動書き出し後に削除） */
.mm-mv__placeholder {
	width: 100%;
	height: 500px;
	background: #efe0c4;
	display: flex;
	align-items: center;
	justify-content: center;
}

.mm-mv__title {
	display: flex;
	flex-direction: column;
	align-items: center;
	background: rgba(67, 89, 20, 0.85);
	padding: 40px 80px;
	border-radius: 20px;
	color: #fff;
}

.mm-mv__title-icon {
	font-size: 40px;
	margin-bottom: 8px;
}

.mm-mv__title-main {
	font-size: 64px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.2;
}

.mm-mv__title-sub {
	font-size: 40px;
	font-weight: 700;
	letter-spacing: 0.1em;
}

/* --------------------------------------------------------------------------
   導入セクション
   -------------------------------------------------------------------------- */
.mm-intro {
	position: relative;
	background: linear-gradient(180deg, #e8f4f8 0%, #d4ecce 100%);
	padding: 160px 0 250px;
	overflow: hidden;
}

/* 背景画像 */
.mm-intro__bg {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 1988px;
	height: 100%;
	z-index: 0;
	border-radius: 10px;
	overflow: hidden;
}

.mm-intro__bg-img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* 雲の装飾 */
.mm-intro__cloud {
	position: absolute;
	top: 0;
	width: 898px;
	height: 456px;
	z-index: 0;
	pointer-events: none;
}

.mm-intro__cloud--left {
	left: -590px;
}

.mm-intro__cloud--right {
	right: -590px;
	transform: scaleX(-1);
}

.mm-intro__cloud img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* コンテンツのz-index */
.mm-intro .mm-inner {
	position: relative;
	z-index: 1;
}

/* 装飾イラスト */
.mm-intro__deco {
	position: absolute;
	bottom: 80px;
	left: 50%;
	transform: translateX(-50%);
	width: 1440px;
	height: 180px;
	z-index: 1;
	pointer-events: none;
}

.mm-intro__deco-house {
	position: absolute;
	width: 212px;
	bottom: 30px;
	left: 76px;
	transform: rotate(-2deg);
}

.mm-intro__deco-trees {
	position: absolute;
	width: 136px;
	bottom: 10px;
	left: 0;
	transform: rotate(-3deg);
}

.mm-intro__deco-man {
	position: absolute;
	width: 93px;
	bottom: 0;
	left: 323px;
}

.mm-intro__deco-woman {
	position: absolute;
	width: 56px;
	bottom: 0;
	left: 281px;
}

.mm-intro__lead {
	text-align: center;
	color: #004662;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0.04em;
	margin-bottom: 64px;
}

.mm-intro__lead-main {
	font-size: 36px;
	display: block;
	margin-bottom: 8px;
}

.mm-intro__lead-sub {
	font-size: 28px;
	display: block;
}

.mm-intro__lead-highlight {
	font-size: 32px;
}

/* ミールマイルプログラムとは？ */
.mm-about {
	background: #fff;
	border: 10px solid #fff;
	border-radius: 40px;
	padding: 40px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 40px;
}

.mm-heading {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 16px 64px;
	border-radius: 100px;
	color: #fff;
	font-size: 36px;
	font-weight: 700;
	line-height: 1.5;
}

.mm-heading--blue {
	background: #005475;
}

.mm-heading--brown {
	background: #503300;
}

.mm-heading--green {
	background: #435914;
}

.mm-heading--navy {
	background: #143359;
}

.mm-about__text {
	font-size: 28px;
	font-weight: 700;
	line-height: 1.5;
	text-align: center;
	letter-spacing: 0.04em;
	color: #000;
}

.mm-about__apps {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	max-width: 1020px;
	padding: 0 40px;
	box-sizing: border-box;
	gap: 10px;
}

.mm-about__app-icon {
	width: 128px;
	height: 128px;
	border-radius: 20px;
	overflow: hidden;
	flex-shrink: 0;
}

.mm-about__app-icon img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.mm-about__store {
	display: flex;
	align-items: center;
	gap: 8px;
	background: #e6f5f9;
	border-radius: 10px;
	padding: 16px 24px;
}

.mm-about__store-info {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.mm-about__store-badge {
	height: 56px;
}

.mm-about__store-badge img {
	height: 100%;
	width: auto;
}


.mm-about__store-note {
	font-size: 10px;
	line-height: 1.4;
	color: #000;
	letter-spacing: 0.02em;
}

.mm-about__store-or {
	font-size: 13px;
	font-weight: 500;
	color: #000;
	letter-spacing: 0.04em;
}

.mm-about__store-qr {
	width: 100px;
	height: 100px;
	background: #fff;
}

.mm-about__store-qr img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* --------------------------------------------------------------------------
   使い方セクション
   -------------------------------------------------------------------------- */
.mm-howto {
	position: relative;
	padding: 80px 0;
	background: url(../img/mm-howto-bg.png) center top / cover no-repeat;
	overflow: hidden;
	margin-top: -91px;
	z-index: 1;
}

.mm-howto__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 64px;
	margin-bottom: 64px;
}

.mm-howto__desc {
	font-size: 28px;
	font-weight: 700;
	line-height: 1.5;
	color: #432b00;
	letter-spacing: 0.04em;
}

.mm-howto__notice {
	position: relative;
	background: #feeed3;
	border: 10px solid #feeed3;
	border-radius: 40px;
	padding: 24px 10px;
	width: 100%;
}

.mm-howto__notice-icon {
	position: absolute;
	top: -42px;
	left: -36px;
	width: 57px;
	height: 70px;
	transform: rotate(16.28deg);
	pointer-events: none;
}

.mm-howto__notice-title {
	font-size: 27px;
	font-weight: 700;
	color: #c33910;
	line-height: 1.5;
	letter-spacing: 0.04em;
	margin-bottom: 4px;
	position: relative;
	left: 30px;
}

.mm-howto__notice-text {
	font-size: 22px;
	font-weight: 500;
	color: #432b00;
	line-height: 1.5;
	letter-spacing: 0.04em;
	position: relative;
	left: 30px;
}

/* CTA ボタン */
.mm-cta-buttons {
	display: flex;
	justify-content: space-between;
	gap: 64px;
	margin-bottom: 64px;
}

.mm-cta-btn {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 523px;
	height: 100px;
	background: #79c163;
	border-radius: 8px;
	box-shadow: 4.8px 4.8px 0 0 #5ca945;
	color: #fff;
	text-decoration: none;
	text-align: center;
	transition: opacity 0.3s;
}

.mm-cta-btn:hover {
	opacity: 0.8;
}

.mm-cta-btn__sub {
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.6;
}

.mm-cta-btn__main {
	font-size: 27px;
	font-weight: 700;
	letter-spacing: 0.1em;
	line-height: 1.6;
}

/* ステップカード */
.mm-steps {
	display: flex;
	flex-direction: column;
	gap: 64px;
}

.mm-step {
	background: #fff;
	border: 10px solid #fff;
	border-radius: 40px;
	padding: 24px 40px;
	display: flex;
	gap: 24px;
	align-items: center;
	justify-content: center;
}

.mm-step--reverse {
	flex-direction: row-reverse;
}

.mm-step__content {
	flex: 1;
	min-width: 0;
}

.mm-step__title {
	font-size: 26px;
	font-weight: 700;
	color: #a56a00;
	line-height: 1.5;
	letter-spacing: 0.04em;
	margin-bottom: 18px;
}

.mm-step__text {
	font-size: 24px;
	font-weight: 500;
	color: #000;
	line-height: 1.5;
	letter-spacing: 0.04em;
}

.mm-step__text--alert {
	color: #c33910;
	font-weight: 700;
}

.mm-step__text a {
	color: #000;
	text-decoration: underline;
}

.mm-step__img {
	width: 252px;
	flex-shrink: 0;
}

.mm-step__img img {
	width: 100%;
	height: auto;
	display: block;
}

/* STEP 01 値引きシール（2枚重ね） */
.mm-step__stickers {
	position: relative;
	width: 188px;
	height: 132px;
}

.mm-step__sticker {
	position: absolute;
	width: 154px;
	height: auto;
}

.mm-step__sticker--20off {
	top: 8px;
	left: 31px;
	transform: rotate(2.34deg);
}

.mm-step__sticker--half {
	top: 27px;
	left: 0;
	transform: rotate(11.25deg);
}

/* STEP 01 ほうれん草装飾 */
.mm-step--has-deco {
	position: relative;
	overflow: visible;
}

.mm-step__deco-spinach {
	position: absolute;
	width: 98px;
	height: auto;
	top: -76px;
	left: -81px;
	transform: rotate(-31.55deg);
	pointer-events: none;
}

/* STEP 02 かぼちゃ・にんじん装飾 */
.mm-step__deco-pumpkin {
	position: absolute;
	width: 143px;
	height: auto;
	top: -16px;
	right: -71px;
	pointer-events: none;
}

.mm-step__deco-carrot {
	position: absolute;
	width: 74px;
	height: auto;
	bottom: 22px;
	left: -63px;
	transform: rotate(49.79deg);
	pointer-events: none;
}

/* STEP 03 トマト装飾 */
.mm-step__deco-tomato {
	position: absolute;
	width: 85px;
	height: auto;
	top: -25px;
	right: -50px;
	transform: rotate(10.64deg);
	pointer-events: none;
}

/* ing・fanカード画像（SVG合成） */
.mm-card-img {
	position: relative;
	width: 188px;
	height: 148px;
}

.mm-card-img img {
	position: absolute;
	display: block;
	width: 60%;
	height: 95px;
}

.mm-card-img__club {
	width: 152px;
	height: 114px;
	left: 0;
	top: 25px;
	transform: rotate(12.4deg);
}

.mm-card-img__vcard {
	width: 111px;
	height: 73px;
	left: 77px;
	top: 9px;
	transform: rotate(2.48deg);
}

.mm-step__sub-img {
	margin-top: 32px;
}

.mm-step__sub-img img {
	height: 68px;
	width: auto;
	display: block;
}

.mm-game + .mm-steps {
	margin-top: 75px;
}

/* --------------------------------------------------------------------------
   ゲームの遊び方セクション
   -------------------------------------------------------------------------- */
.mm-game {
	position: relative;
	width: 100vw;
	left: 50%;
	transform: translateX(-50%);
	margin-top: 64px;
	padding: 80px 0 150px;
	overflow: hidden;
}

.mm-game__bg {
	position: absolute;
	top: 0;
	left: 50%;
	margin-left: -720px;
	width: 1440px;
	height: 100%;
}

.mm-game__bg-img {
	position: relative;
	z-index: 0;
	width: 100%;
	height: 100%;
	object-fit: fill;
}

.mm-game__inner {
	position: relative;
	z-index: 1;
	max-width: 1110px;
	margin: 0 auto;
	padding: 0 20px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 64px;
}

.mm-game__content {
	background: #fff;
	border: 10px solid #fff;
	border-radius: 24px;
	padding: 48px;
	width: 822px;
	max-width: 100%;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 32px;
}

.mm-game__subtitle {
	font-size: 27px;
	font-weight: 700;
	color: #435914;
	line-height: 1.5;
	letter-spacing: 0.04em;
	text-align: center;
}

.mm-game__screenshots {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 640px;
	max-width: 100%;
}

.mm-game__screenshot {
	width: 280px;
	border-radius: 10px;
	overflow: hidden;
}

.mm-game__screenshot img {
	width: 100%;
	height: auto;
	display: block;
}

.mm-game__arrow {
	width: 40px;
	height: auto;
	display: block;
	flex-shrink: 0;
}

.mm-game__desc {
	font-size: 24px;
	font-weight: 500;
	color: #000;
	line-height: 1.5;
	letter-spacing: 0.04em;
	text-align: center;
}

.mm-game__results {
	display: flex;
	justify-content: space-between;
	width: 640px;
	max-width: 100%;
}

.mm-game__result {
	width: 280px;
	height: 384px;
	border-radius: 10px;
	overflow: hidden;
}

.mm-game__result img {
	width: 100%;
	height: auto;
	display: block;
}

/* 装飾画像 */
.mm-game__deco {
	position: absolute;
	z-index: 1;
	pointer-events: none;
}

.mm-game__deco--fence-left {
	bottom: 0;
	left: 0;
	width: 49%;
}

.mm-game__deco--fence-right {
	bottom: 0;
	right: 0;
	width: 49%;
	transform: scaleX(-1);
}

.mm-game__deco--cow {
	bottom: 115px;
	left: 250px;
	width: 238px;
	z-index: 3;
}

.mm-game__deco--car {
	bottom: 56px;
	right: 240px;
	width: 194px;
	z-index: 3;
}

.mm-game__deco--chicken {
	top: 36px;
	left: 198px;
	width: 190px;
	z-index: 3;
}

.mm-game__deco--pig {
	top: 55px;
	right: 200px;
	width: 180px;
	z-index: 3;
}

.mm-game__deco img {
	width: 100%;
	height: auto;
}

/* --------------------------------------------------------------------------
   ingポイントの付与セクション
   -------------------------------------------------------------------------- */
.mm-points {
	padding: 0 0 80px;
	background: linear-gradient(180deg, #f5e6b8 0%, #d4ecce 100%);
}

/* --------------------------------------------------------------------------
   集計期間・お問い合わせセクション
   -------------------------------------------------------------------------- */
.mm-faq {
	position: relative;
	padding: 80px 0 100px;
	overflow: hidden;
}

.mm-faq__bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
}

.mm-faq__bg-img {
	width: 100%;
	height: 100%;
	object-fit: fill;
}

.mm-faq__inner {
	position: relative;
	z-index: 1;
	max-width: 1110px;
	margin: 0 auto;
	padding: 0 20px;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 80px;
}

/* FAQ装飾 */
.mm-faq__deco {
	position: absolute;
	z-index: 2;
	pointer-events: none;
}

.mm-faq__deco img {
	width: 100%;
	height: auto;
}

.mm-faq__deco--fish-left {
	top: 62px;
	left: 10%;
	width: 215px;
}

.mm-faq__deco--fish-right {
	top: 138px;
	right: 5%;
	width: 362px;
	transform: rotate(-15.85deg);
}

.mm-faq__deco--fish-big {
	top: 55%;
	left: 1%;
	width: 238px;
	transform: rotate(-162.24deg) scaleY(-1);
}

.mm-faq__deco--seaweed {
	bottom: 0;
	right: 5%;
	width: 117px;
	z-index: 2;
}

.mm-faq__deco--bubble-left {
	top: 12%;
	left: 3%;
	width: 72px;
	transform: rotate(-90deg) scaleY(-1);
}

.mm-faq__deco--bubble-right {
	top: 8%;
	right: 3%;
	width: 72px;
	transform: rotate(90deg) scaleX(-1);
}

.mm-faq__deco--bubble-sm-left {
	top: 5%;
	left: 25%;
	width: 34px;
	transform: rotate(171.91deg);
}

.mm-faq__deco--bubble-sm-right {
	top: 9%;
	right: 28%;
	width: 34px;
	transform: rotate(149.57deg);
}

/* 集計期間 */
.mm-period {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 64px;
}

.mm-period__content {
	background: #fff;
	border: 10px solid #fff;
	border-radius: 40px;
	padding: 64px 110px;
	width: 100%;
	box-sizing: border-box;
}

.mm-period__text {
	font-size: 20px;
	font-weight: 700;
	color: #000;
	line-height: 1.5;
	letter-spacing: 0.04em;
}

.mm-period__text p {
	margin: 0;
}

.mm-period__text p + p {
	margin-top: 0;
}

.mm-period__text .blank {
	height: 1.5em;
}

/* よくあるご質問ボタン */
.mm-faq-btn {
	display: inline-flex;
	align-items: center;
	gap: 16px;
	padding: 16px 64px;
	background: #fff;
	border: 2px solid #143359;
	border-radius: 100px;
	color: #143359;
	font-size: 36px;
	font-weight: 700;
	line-height: 1.5;
	text-decoration: none;
	transition: opacity 0.3s;
}

.mm-faq-btn:hover {
	opacity: 0.7;
}

.mm-faq-btn__arrow {
	font-size: 24px;
}

/* お問い合わせ */
.mm-contact {
	width: 100%;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 64px;
}

.mm-contact__content {
	background: #fff;
	border: 10px solid #fff;
	border-radius: 40px;
	padding: 64px 110px;
	width: 100%;
	box-sizing: border-box;
}

.mm-contact__body {
	max-width: 640px;
	margin: 0 auto;
}

.mm-contact__section {
	margin-bottom: 40px;
}

.mm-contact__section:last-child {
	margin-bottom: 0;
}

.mm-contact__section-title {
	font-size: 30px;
	font-weight: 700;
	color: #000;
	line-height: 1.5;
	letter-spacing: 0.04em;
	margin-bottom: 24px;
}

.mm-contact__label {
	font-size: 24px;
	font-weight: 500;
	color: #000;
	line-height: 1.5;
	letter-spacing: 0.04em;
}

.mm-contact__phone {
	display: flex;
	align-items: center;
}

.mm-contact__phone-icon {
	width: 56px;
	height: 64px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.mm-contact__phone-icon img {
	width: 48px;
	height: auto;
}

.mm-contact__phone-number {
	font-family: "Noto Sans", sans-serif;
	font-size: 32px;
	font-weight: 600;
	color: #18AB4C;
	letter-spacing: 1.28px;
	line-height: 180%;
	padding-right: 10px;
}

.mm-contact__phone-info {
	font-size: 16px;
	font-weight: 400;
	color: #000;
	line-height: 1.8;
}

.mm-contact__text {
	font-size: 24px;
	font-weight: 700;
	color: #000;
	letter-spacing: 0.04em;
	line-height: 1.5;
}

.mm-contact__text + .mm-contact__text {
	margin-top: 8px;
}

.mm-contact__text--medium {
	font-weight: 500;
}

.mm-contact__link {
	color: #000;
	text-decoration: underline;
}

/* --------------------------------------------------------------------------
   アニメーション
   -------------------------------------------------------------------------- */
/* アニメーションは GSAP ScrollTrigger で制御 */

/* --------------------------------------------------------------------------
   表示切り替え
   -------------------------------------------------------------------------- */
.spOnly {
	display: none;
}

/* --------------------------------------------------------------------------
   レスポンシブ
   -------------------------------------------------------------------------- */
@media screen and (max-width: 767px) {
	.spOnly {
		display: block;
	}

	br.spOnly {
		display: inline;
	}

	.pcOnly {
		display: none !important;
	}
	.mm-inner {
		margin: 0px auto 0;
	}

	.mm-intro__lead {
		margin: -100px auto 60px;
	}

	.mm-intro__lead-main {
		font-size: 22px;
	}

	.mm-intro__lead-sub {
		font-size: 16px;
	}

	.mm-intro__lead-highlight {
		font-size: 18px;
	}

	.mm-heading {
		font-size: 22px;
		padding: 12px 32px;
		text-align: center;
	}

	.mm-about {
		padding: 24px 16px;
		gap: 24px;
		border-radius: 20px;
	}

	.mm-about__text {
		font-size: 18px;
		text-align: left;
	}

	.mm-intro {
		padding-bottom: 200px;
		margin-bottom: -100px;
	}

	.mm-intro__bg {
		width: 100%;
	}

	.mm-intro__cloud {
		width: 300px;
		height: 150px;
	}

	.mm-intro__cloud--left {
		left: -200px;
	}

	.mm-intro__cloud--right {
		right: -200px;
	}

	.mm-intro__deco {
		width: 100%;
		height: 120px;
		z-index: 2;
	}

	.mm-intro__deco-house {
		width: 120px;
		left: 20px;
		bottom: 20px;
	}

	.mm-intro__deco-trees {
		width: 80px;
		left: 0;
		bottom: 5px;
	}

	.mm-intro__deco-man {
		width: 60px;
		left: 160px;
	}

	.mm-intro__deco-woman {
		width: 36px;
		left: 130px;
	}

	.mm-about__apps {
		flex-direction: column;
		gap: 16px;
		padding: 0;
	}

	.mm-about__app-icon {
		width: 80px;
		height: 80px;
	}

	.mm-about__store {
		width: 100%;
		box-sizing: border-box;
		flex-flow: column nowrap;
		justify-content: center;
		align-items: center;
	}

	.mm-about__store-badge img {
		margin: 0 auto 10px;
		display: block;
	}

	.mm-howto {
		padding: 80px 0;
		background: url(../img/mm-howto-bg-sp.png) center top / cover no-repeat;
		margin-top: 20px;
	}

	.mm-howto__header {
		gap: 30px;
		margin-bottom: 33px;
	}

	.mm-howto__desc {
		font-size: 18px;
	}

	.mm-howto__notice {
		border-radius: 20px;
		padding: 16px 20px;
	}

	.mm-howto__notice-title {
		font-size: 20px;
		left: 0;
	}

	.mm-howto__notice-text {
		font-size: 18px;
		left: 0;
	}

	.mm-howto__notice-icon {
		top: -27px;
		left: -26px;
		width: 44px;
		height: 52px;
	}

	.mm-cta-buttons {
		flex-direction: column;
		gap: 16px;
	}

	.mm-cta-btn {
		width: 100%;
		height: auto;
		padding: 16px;
	}

	.mm-cta-btn__sub {
		font-size: 14px;
	}

	.mm-cta-btn__main {
		font-size: 18px;
	}

	.mm-step {
		flex-direction: column !important;
		padding: 20px;
		border-radius: 20px;
		gap: 16px;
	}

	.mm-step__title {
		font-size: 22px;
	}

	.mm-step__text {
		font-size: 18px;
	}

	.mm-step__img {
		width: 254px;
	}

	.mm-step__stickers {
		width: 188px;
	}

	.mm-step__sub-img.spOnly {
		margin-top: 10px;
	}

	.mm-step__sub-img.spOnly img {
		height: auto;
	}

	.mm-step__deco-spinach {
		width: 50px;
		top: -40px;
		left: -20px;
	}

	.mm-step__deco-pumpkin {
		width: 74px;
		top: -38px;
		right: -18px;
	}

	.mm-step__deco-carrot {
		width: 54px;
		bottom: -30px;
		left: -23px;
	}

	.mm-step__deco-tomato {
		width: 60px;
		top: -47px;
		right: -15px;
	}

	.mm-step__sticker--half {
		top: 36px;
		left: -29px;
	}

	.mm-card-img img {
		width: 88%;
		height: 95px;
	}

	.mm-card-img {
		width: 188px;
		height: 148px;
	}

	.mm-card-img__club {
		width: 114px;
		height: 85px;
		left: 0;
		top: 18px;
	}

	.mm-card-img__vcard {
		width: 83px;
		height: 55px;
		left: 57px;
		top: 7px;
	}

	.mm-mv__placeholder {
		height: 300px;
	}

	.mm-mv__title-main {
		font-size: 36px;
	}

	.mm-mv__title-sub {
		font-size: 24px;
	}

	.mm-game__content {
		width: 100%;
		padding: 24px 16px;
	}

	.mm-game__subtitle {
		font-size: 22px;
	}

	.mm-game__screenshots {
		width: 100%;
		flex-direction: column;
		align-items: center;
		gap: 16px;
	}

	.mm-game__screenshot {
		width: 90%;
	}

	.mm-game__arrow {
		transform: rotate(90deg) !important;
	}

	.mm-game__desc {
		font-size: 18px;
		text-align: left;
	}

	.mm-game__desc br {
		display: none;
	}

	.mm-game__results {
		display: none;
	}

	.mm-game__result {
		width: 42%;
		height: auto;
	}

	/* ゲーム結果スライダー */
	.mm-game__results-slider {
		display: flex;
		align-items: center;
		gap: 12px;
		width: 100%;
	}

	.mm-game__slider-arrow {
		background: none;
		border: none;
		padding: 0;
		cursor: pointer;
		width: 12px;
		flex-shrink: 0;
	}

	.mm-game__slider-arrow img {
		width: 100%;
		height: auto;
	}

	.mm-game__slider-track {
		overflow: hidden;
		width: 100%;
		border-radius: 10px;
	}

	.mm-game__slider-slide {
		display: none;
	}

	.mm-game__slider-slide.is-active {
		display: block;
	}

	.mm-game__slider-slide img {
		width: 100%;
		height: auto;
		display: block;
		border-radius: 10px;
	}

	.mm-period__content {
		padding: 32px 20px;
		border-radius: 20px;
	}

	.mm-period__text {
		font-size: 16px;
	}

	.mm-faq-btn {
		font-size: 22px;
		padding: 12px 32px;
	}

	.mm-contact__content {
		padding: 32px 20px;
		border-radius: 20px;
	}

	.mm-contact__section-title {
		font-size: 20px;
		margin-bottom: 16px;
	}

	.mm-contact__label {
		font-size: 16px;
	}

	.mm-contact__phone-number {
		font-size: 26px;
		margin-left: 10px;
	}

	.mm-contact__phone-info {
		font-size: 13px;
		width: 100%;
	}

	.mm-contact__text {
		font-size: 16px;
	}

	/* ゲームセクション */
	.mm-game {
		padding: 60px 0 100px;
		margin-top: 40px;
	}

	.mm-game__inner {
		gap: 34px;
	}

	.mm-game__bg {
		width: 100%;
		left: 0;
		margin-left: 0;
	}

	.mm-game .mm-heading {
		font-size: 20px;
	}

	.mm-game__arrow {
		width: 24px;
	}

	.mm-game__deco--chicken {
		top: 58px;
		left: 10px;
		width: 80px;
	}

	.mm-game__deco--pig {
		top: 44px;
		right: 10px;
		width: 75px;
	}

	.mm-game__deco--cow {
		bottom: 50px;
		left: 10px;
		width: 100px;
	}

	.mm-game__deco--car {
		bottom: 30px;
		right: 10px;
		width: 85px;
	}

	.mm-game__deco--fence-left {
		width: 50%;
	}

	.mm-game__deco--fence-right {
		width: 50%;
	}

	/* ステップ05 */
	.mm-game + .mm-steps {
		margin-top: 40px;
	}

	/* ポイント付与セクション */
	.mm-points {
		padding: 0 0 40px;
	}

	/* FAQセクション */
	.mm-faq {
		padding: 40px 0 60px;
	}

	.mm-faq__inner {
		gap: 40px;
	}

	.mm-faq__deco--fish-left {
		top: 20px;
		left: 0;
		width: 100px;
	}

	.mm-faq__deco--fish-right {
		top: 36px;
		right: 0;
		width: 96px;
	}

	.mm-faq__deco--fish-big {
		top: 56%;
		left: -2%;
		width: 86px;
	}

	.mm-faq__deco--seaweed {
		right: 2%;
		width: 60px;
	}

	.mm-faq__deco--bubble-left,
	.mm-faq__deco--bubble-right {
		width: 40px;
	}

	.mm-faq__deco--bubble-sm-left,
	.mm-faq__deco--bubble-sm-right {
		width: 20px;
	}

	/* 集計期間 */
	.mm-period {
		gap: 32px;
	}

	.mm-period__content {
		padding: 24px 16px;
		border-radius: 20px;
	}

	/* よくあるご質問ボタン */
	.mm-faq-btn {
		font-size: 20px;
		padding: 12px 32px;
	}

	/* お問い合わせ */
	.mm-contact {
		gap: 32px;
	}

	.mm-contact__content {
		padding: 24px 16px;
		border-radius: 20px;
	}

	.mm-contact__body {
		max-width: 100%;
	}

	.mm-contact__section {
		margin-bottom: 24px;
	}

	.mm-contact__phone {
		flex-wrap: wrap;
	}

	.mm-contact__phone-icon {
		width: 40px;
		height: 48px;
	}

	.mm-contact__phone-icon img {
		width: 36px;
	}

}
