.p-front-hero {
	overflow: hidden;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	padding: 168px 20px 80px;
	aspect-ratio: 16/9;
	z-index: 1;
}

.p-front-hero__bg {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}

.p-front-hero__bg img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: brightness(0.6);
}

.p-front-hero__content {
	display: flex;
	flex-direction: column;
	gap: 20px;
	max-width: 1000px;
	color: #fff;
}

.p-front-hero__head {
	display: flex;
	flex-direction: column;
	gap: 20px;
	color: #fbeab3;
	text-align: center;
}

.p-front-hero__head__title {
	font-size: 56px;
	font-weight: 700;
	line-height: 1;
	letter-spacing: 0.1em;
}

.p-front-hero__head__subtitle {
	font-size: 24px;
	letter-spacing: 0.05em;
}

.p-front-hero__highlight {
	width: fit-content;
	margin: 20px auto 0;
	padding: 12px 24px;
	background-color: #f0c960;
	border-radius: 8px;
	font-size: 18px;
	font-weight: 700;
	text-align: center;
}

.p-front-hero__highlight__label {
	color: #2a1600;
}

.p-front-hero__highlight__value {
	color: #b71505;
}

.p-front-hero__season {
	display: flex;
	flex-direction: column;
	margin: 0 auto;
}

.p-front-hero__season__item {
	display: grid;
	grid-template-columns: 64px 1fr;
	align-items: center;
	gap: 16px;
}

.p-front-hero__season__item__icon {
	width: 100%;
	height: 100%;
	aspect-ratio: 1 / 1;
}

.p-front-hero__season__item__icon img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.p-front-hero__season__item__text {
	font-size: 20px;
	letter-spacing: 0.05em;
	color: #f8f6d2;
}

.p-front-hero__season__item__text br {
	display: none;
}

@media screen and (max-width: 768px) {
	.p-front-hero {
		height: auto;
		padding: 0;
		aspect-ratio: auto;
	}

	.p-front-hero__bg img {
		filter: brightness(0.5);
	}

	.p-front-hero__content {
		padding: 120px 20px 60px;
	}

	.p-front-hero__head {
		gap: 16px;
	}

	.p-front-hero__head__title {
		font-size: 32px;
	}

	.p-front-hero__head__subtitle {
		font-size: 18px;
	}

	.p-front-hero__highlight {
		display: flex;
		flex-direction: column;
		width: 100%;
		margin-top: 0;
	}

	.p-front-hero__season {
		gap: 4px;
	}

	.p-front-hero__season__item {
		grid-template-columns: 48px 1fr;
		gap: 8px;
	}

	.p-front-hero__season__item__text {
		font-size: 18px;
	}

	.p-front-hero__season__item__text br {
		display: inline;
	}
}

.p-front-history {
	position: relative;
	padding: 80px 20px;
	z-index: 1;
}

.p-front-history__inner {
	max-width: 960px;
	margin: 0 auto;
}

.p-front-history__head {
	display: flex;
	flex-direction: column;
	gap: 8px;
	text-align: center;
}

.p-front-history__head__title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6a4c32;
}

.p-front-history__head__subtitle {
	color: #8c6b50;
}

.p-front-history__text {
	margin-top: 24px;
	padding: 24px;
	background-color: #fff;
	border: 2px solid #fce6cf;
	border-radius: 12px;
	line-height: 2;
	text-align: center;
}

@media screen and (max-width: 768px) {
	.p-front-history__text {
		text-align: left;
	}
}

.p-front-pickup {
	position: relative;
	padding: 80px 20px;
	z-index: 1;
}

.p-front-pickup__inner {
	max-width: 960px;
	margin: 0 auto;
}

.p-front-pickup__head {
	display: flex;
	flex-direction: column;
	gap: 8px;
	text-align: center;
}

.p-front-pickup__head__title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6a4c32;
}

.p-front-pickup__head__subtitle {
	color: #8c6b50;
}

.p-front-pickup__cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 32px;
	margin-top: 40px;
}

.p-front-pickup-card {
	display: flex;
	flex-direction: column;
	gap: 16px;
	padding: 20px;
	background-color: #fff;
	border: 2px solid #fce6cf;
	border-radius: 16px;
}

.p-front-pickup-card__img {
	overflow: hidden;
	width: 100%;
	aspect-ratio: 3/2;
}

.p-front-pickup-card__img img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.p-front-pickup-card__body {
	flex-grow: 1;
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.p-front-pickup-card__body__name {
	font-size: 1.2rem;
	font-weight: 700;
	color: #4b2c20;
}

.p-front-pickup-card__body__desc {
	line-height: 1.8;
}

.p-front-pickup__button {
	margin-top: 40px;
	text-align: center;
}

.p-front-kakigori {
	position: relative;
	padding: 80px 20px;
	z-index: 1;
}

.p-front-kakigori__inner {
	max-width: 960px;
	margin: 0 auto;
}

.p-front-kakigori__head {
	display: flex;
	flex-direction: column;
	gap: 8px;
	text-align: center;
}

.p-front-kakigori__head__title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6a4c32;
}

.p-front-kakigori__head__subtitle {
	color: #8c6b50;
}

.p-front-kakigori__row {
	display: grid;
	grid-template-columns: 40% 1fr;
	gap: 40px;
	margin-top: 40px;
	padding: 24px;
	background-color: #fff;
	border: 2px solid #f0e0d2;
	border-radius: 16px;
}

.p-front-kakigori__image {
	width: 100%;
	aspect-ratio: 3 / 2;
}

.p-front-kakigori__image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.p-front-kakigori__textarea {
	display: flex;
	flex-direction: column;
	gap: 1em;
}

.p-front-kakigori__textarea h3 {
	margin-bottom: -0.5em;
	border-bottom: 1px solid #6a4c32;
	font-size: 1.2rem;
	font-weight: 700;
	color: #6a4c32;
}

.p-front-kakigori__textarea ul {
	padding-left: 1.5em;
	list-style: disc;
}

@media screen and (max-width: 768px) {
	.p-front-kakigori__row {
		grid-template-columns: 1fr;
		padding: 20px;
	}
}

.p-front-taiyaki {
	position: relative;
	padding: 80px 20px;
	z-index: 1;
}

.p-front-taiyaki__inner {
	max-width: 960px;
	margin: 0 auto;
}

.p-front-taiyaki__head {
	display: flex;
	flex-direction: column;
	gap: 8px;
	text-align: center;
}

.p-front-taiyaki__head__title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6a4c32;
}

.p-front-taiyaki__head__subtitle {
	color: #8c6b50;
}

.p-front-taiyaki__row {
	display: grid;
	grid-template-columns: 40% 1fr;
	gap: 40px;
	align-items: center;
	margin-top: 40px;
	padding: 24px;
	background-color: #fff;
	border: 2px solid #f0e0d2;
	border-radius: 16px;
}

.p-front-taiyaki__image {
	width: 100%;
	aspect-ratio: 3 / 2;
}

.p-front-taiyaki__image img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.p-front-taiyaki__textarea {
	display: flex;
	flex-direction: column;
	gap: 1em;
}

.p-front-taiyaki__textarea h3 {
	margin-bottom: -0.5em;
	border-bottom: 1px solid #6a4c32;
	font-size: 1.2rem;
	font-weight: 700;
	color: #6a4c32;
}

.p-front-taiyaki__textarea ul {
	padding-left: 1.5em;
	list-style: disc;
}

@media screen and (max-width: 768px) {
	.p-front-taiyaki__row {
		grid-template-columns: 1fr;
		padding: 20px;
	}
}

.p-front-voice {
	position: relative;
	padding: 80px 20px;
	z-index: 1;
}

.p-front-voice__inner {
	max-width: 960px;
	margin: 0 auto;
}

.p-front-voice__head {
	display: flex;
	flex-direction: column;
	gap: 8px;
	text-align: center;
}

.p-front-voice__head__title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6a4c32;
}

.p-front-voice__head__subtitle {
	color: #8c6b50;
}

.p-front-voice__list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	margin-top: 40px;
}

.p-front-voice-item {
	position: relative;
	display: block;
	padding: 24px 16px;
	background-color: #fff0f5;
	border-radius: 16px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.p-front-voice-item:nth-child(2) {
	background-color: #f0fff0;
}

.p-front-voice-item:nth-child(3) {
	background-color: #fffff0;
}

.p-front-voice-item__type {
	content: '';
	position: absolute;
	top: -12px;
	left: 20px;
	width: 60%;
	height: 20px;
	background-color: #ffb6c1;
	border-radius: 4px;
	transform: rotate(-3deg);
}

.p-front-voice-item:nth-child(2) .p-front-voice-item__type {
	background-color: #b0e57c;
	transform: rotate(2deg);
}

.p-front-voice-item:nth-child(3) .p-front-voice-item__type {
	background-color: #fcd97b;
	transform: rotate(-2deg);
}

.p-front-voice-item__body {
	display: grid;
	grid-template-columns: 48px 1fr;
	align-items: center;
	gap: 12px;
}

.p-front-voice-item__body__icon {
	background-color: #fff;
	border-radius: 50%;
	border: 1px solid #ccc;
	aspect-ratio: 1/1;
}

.p-front-voice-item__body__icon img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.p-front-voice-item__body__text {
	line-height: 1.8;
}

@media screen and (max-width: 768px) {
	.p-front-voice__list {
		grid-template-columns: 1fr;
		gap: 40px;
	}
}

.p-front-faq {
	position: relative;
	padding: 80px 20px;
	z-index: 1;
}

.p-front-faq__inner {
	max-width: 960px;
	margin: 0 auto;
}

.p-front-faq__head {
	display: flex;
	flex-direction: column;
	gap: 8px;
	text-align: center;
}

.p-front-faq__head__title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6a4c32;
}

.p-front-faq__head__subtitle {
	color: #8c6b50;
}

.p-front-faq__list {
	display: flex;
	flex-direction: column;
	gap: 24px;
	margin-top: 40px;
}

.p-front-faq-item {
	overflow: hidden;
	border-radius: 8px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.p-front-faq-block__question {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 16px;
	padding: 16px 20px;
	background-color: #fef3dc;
	font-size: 18px;
	font-weight: 700;
	color: #5c3b1f;
}

.p-front-faq-block__question>span {
	padding: 4px;
	background-color: #fbd0d9;
	border-radius: 50%;
	line-height: 1;
	color: #8c2a25;
	aspect-ratio: 1/1;
}

.p-front-faq-block__answer {
	padding: 16px 20px;
	background-color: #fff8ee;
	line-height: 1.8;
}

.p-front-news {
	position: relative;
	padding: 80px 20px;
	z-index: 1;
}

.p-front-news__inner {
	max-width: 960px;
	margin: 0 auto;
}

.p-front-news__head {
	display: flex;
	flex-direction: column;
	gap: 8px;
	text-align: center;
}

.p-front-news__head__title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6a4c32;
}

.p-front-news__head__subtitle {
	color: #8c6b50;
}

.p-front-news__list {
	margin-top: 40px;
}

.p-front-news-item {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid #301102;
}

.p-front-news-item__inner {
	position: relative;
	display: grid;
	grid-template-columns: auto 6em 1fr;
	align-items: center;
	gap: 16px;
	padding-right: 16px;
}

.p-front-news-item__inner::after {
	content: '';
	position: absolute;
	top: 50%;
	right: 0;
	display: block;
	width: 6px;
	height: 12px;
	background-color: #938b8b;
	clip-path: polygon(1px 0%, 100% 50%, 1px 100%, 0% calc(100% - 1px), calc(100% - 2px) 50%, 0% 1px);
	transform: translateY(-50%);
}

.p-front-news-item__category {
	width: fit-content;
	padding: 8px 16px;
	background-color: #301102;
	font-size: 12px;
	line-height: 1;
	color: #fff;
	text-align: center;
}

.p-front-news-item__date {
	line-height: 1;
}

.p-front-news-item__title {
	font-size: 18px;
	font-weight: 700;
}

.p-front-news-item__none {
	padding: 24px 0;
	font-size: 18px;
}

.p-front-news__button {
	margin-top: 40px;
	text-align: center;
}


@media screen and (max-width: 768px) {
	.p-front-news-item__inner {
		display: flex;
		flex-wrap: wrap;
		gap: 8px 16px;
	}

	.p-front-news-item__category {
		max-width: calc(100% - (16px * 6) - 16px);
	}

	.p-front-news-item__date {
		width: 6em;
	}

	.p-front-news-item__title {
		width: 100%;
		font-size: 16px;
	}
}

.p-front-sns {
	position: relative;
	padding: 80px 20px;
	z-index: 1;
}

.p-front-sns__inner {
	max-width: 960px;
	margin: 0 auto;
}

.p-front-sns__head {
	display: flex;
	flex-direction: column;
	gap: 8px;
	text-align: center;
}

.p-front-sns__head__title {
	font-size: 1.8rem;
	font-weight: 700;
	color: #6a4c32;
}

.p-front-sns__head__subtitle {
	color: #8c6b50;
}

.p-front-sns__cards {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 40px;
	margin-top: 40px;
}

.p-front-sns-card {
	overflow: hidden;
	display: flex;
	align-items: center;
	padding: 16px;
	background-color: #fff;
	border-radius: 16px;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.p-front-sns-card__link {
	display: grid;
	grid-template-columns: 140px 1fr;
	align-items: center;
	gap: 16px;
}

.p-front-sns-card__qr {
	overflow: hidden;
	border-radius: 8px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.p-front-sns-card__qr img {
	display: block;
	width: 100%;
}

.p-front-sns-card__test {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.p-front-sns-card__title {
	font-size: 18px;
	font-weight: 700;
	color: #d74b90;
}

.p-front-sns-card--line .p-front-sns-card__title {
	color: #06C755;
}

@media screen and (max-width: 768px) {
	.p-front-sns__cards {
		grid-template-columns: 1fr;
	}
}