@charset "utf-8";

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
HOME
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
- ページヘッダー
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.gaufres-header {
	padding-block: clamp(160px, calc(100vw * 160 / 417), 200px) var(--padding-block);
	background: url("../img/decoration.svg") center top / 100% auto no-repeat;
	text-align: center;
}

.gaufres-header .heading_serif {
	margin-bottom: 1em;
	padding-left: 0.2em;
	color: var(--color_beige_dark);
	font-size: 44px;
	line-height: 1.2;
	letter-spacing: 0.06em;
}

.gaufres-header .description {
	margin-block: 2.5em 0.1em;
	font-family: var(--font_serif);
}

.gaufres-header .heading {
	color: var(--color_green);
	font-weight: 700;
	font-size: 24px;
	font-family: var(--font_serif);
}

@media (min-width: 768px) {
.gaufres-header {
	padding-top: 160px;
}
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
- ご予約受付期間
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.gaufres-reservation {
	padding-block: 40px;
	background: url("../img/reservation-background.webp") center center / auto 100% repeat-x;
}

.gaufres-reservation .content {
	padding: 26px 20px;
	border: 3px solid var(--color_beige_light);
	border-radius: 12px;
	background: var(--color_yellow);
	text-align: center;
}

.gaufres-reservation .heading_serif {
	margin-bottom: 0.4em;
	color: var(--color_red);
	font-weight: 500;
	font-size: 18px;
}

.gaufres-reservation .period {
	margin-bottom: 0.3em;
	font-size: 25px;
	font-family: var(--font_serif);
	line-height: 1.5;
}

.gaufres-reservation .description {
	color: var(--color_red);
	line-height: 1.5;
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
- Century Project
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.gaufres-century {
	padding-bottom: initial;
}

.gaufres-century .content {
	padding: 20px;
	background: #f1f0e1;
	-webkit-clip-path: polygon(0 2em, 2em 0, 100% 0, 100% calc(100% - 2em), calc(100% - 2em) 100%, 0 100%);
	clip-path: polygon(0 2em, 2em 0, 100% 0, 100% calc(100% - 2em), calc(100% - 2em) 100%, 0 100%);
}

.gaufres-century .wrapper {
	display: grid;
	grid-template-columns: auto auto;
	column-gap: 3%;
	justify-content: center;
	align-items: center;
}

.gaufres-century .description {
	margin-top: 1em;
	padding-top: 1em;
	border-top: 1px dashed;
	line-height: 1.5;
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
- 味
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.gaufres-flavor {
	--padding-inline: 3.6%;
	text-align: center;
}

.gaufres-flavor-intro {
	margin-bottom: -140px;
	padding-bottom: 400px;
	background: url("../img/flavor-intro.webp") center bottom / auto 518px no-repeat;
}

.gaufres-flavor-intro .heading_serif {
	margin-bottom: 0.5em;
	font-size: 26px;
	line-height: 1.5;
}

.gaufres-flavor-intro .description {
	font-size: 16px;
	font-family: var(--font_serif);
}

.gaufres-flavor-li {
	padding-block: max(160px, calc(100vw * 160 / 417)) 20px;
	border: 10px solid var(--color_flavor);
	border-radius: 100vw 100vw 0 0;
	background: right top / 81% auto no-repeat #fff;
}

.gaufres-flavor-fruit {
	--color_flavor: var(--color_fruit);
	background-image: url("../img/flavor-decoration-fruit.svg");
}

.gaufres-flavor-aroma {
	--color_flavor: var(--color_aroma);
	background-image: url("../img/flavor-decoration-aroma.svg");
}

.gaufres-flavor-roast {
	--color_flavor: var(--color_roast);
	background-image: url("../img/flavor-decoration-roast.svg");
}

.gaufres-flavor-li:not(:last-child) {
	margin-bottom: 40px;
}

.gaufres-flavor-li .heading_serif {
	margin-bottom: initial;
	color: var(--color_flavor);
	font-weight: 500;
	font-size: 28px;
}

.gaufres-flavor-li .description {
	margin-bottom: 1.5em;
	color: var(--color_flavor);
	font-weight: 700;
	font-family: var(--font_serif);
}

.gaufres-flavor-type-li .img {
	margin-bottom: 70px;
}

.gaufres-flavor-type-li .heading {
	margin-bottom: 0.2em;
	font-weight: inherit;
	font-size: 21px;
}

.gaufres-flavor-type-slider .swiper-button-prev,
.gaufres-flavor-type-slider .swiper-button-next {
	top: 24%;
	margin-top: initial;
}

.gaufres-flavor-type-slider .swiper-button-prev:hover,
.gaufres-flavor-type-slider .swiper-button-next:hover {
	color: var(--color_flavor);
}

.gaufres-flavor-type-slider .swiper-pagination {
	inset: 225px 0 auto;
}

.gaufres-flavor-type-slider .swiper-pagination-bullet-active,
.gaufres-flavor-type-slider .swiper-pagination-bullet:hover {
	background: var(--color_flavor);
}

.gaufres-flavor-li .frame {
	position: absolute;
	inset: 260px 10px auto;
}

.gaufres-flavor-fruit .frame {
	background-image: url("../img/flavor-frame-fruit.svg");
}

.gaufres-flavor-aroma .frame {
	background-image: url("../img/flavor-frame-aroma.svg");
}

.gaufres-flavor-roast .frame {
	background-image: url("../img/flavor-frame-roast.svg");
}

@media (min-width: 768px) {
.gaufres-flavor-li {
	padding-top: max(160px, calc(100vw * 160 / 1400));
}
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
- 特徴
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.gaufres-feature {
	background: rgb(var(--color_yellow_rgb), 0.5);
}

.gaufres-feature-image {
	display: flex;
	margin-bottom: 40px;
	justify-content: center;
	align-items: end;
}

.gaufres-feature-image .img01 {
	max-width: 70%;
	margin-right: max(-70px, -21%);
	border-radius: 50%;
}

.gaufres-feature-image .copy {
	display: grid;
	width: 127px;
	margin: 0 0 10px auto;
	border-radius: 50%;
	background: var(--color_red);
	color: #fff;
	font-weight: 700;
	font-size: 16px;
	text-align: center;
	aspect-ratio: 1;
	align-items: center;
}

.gaufres-feature-frame {
	padding: 0.7em;
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
- デザイン
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.gaufres-design {
	padding-block: clamp(160px, calc(100vw * 160 / 417), 200px) 0;
	background: url("../img/decoration.svg") center top / 100% auto no-repeat;
	text-align: center;
}

.gaufres-design .heading-large {
	display: block;
	font-size: 29px;
}

.gaufres-design .description {
	margin-top: 1.8em;
}

@media (min-width: 768px) {
.gaufres-design {
	padding-top: 160px;
}
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
- シーン
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.gaufres-scene {
	position: relative;
	z-index: 0;
	padding-bottom: clamp(160px, calc(100vw * 160 / 417), 200px);
}

.gaufres-scene::after {
	position: absolute;
	inset: 0;
	z-index: -1;
	background: url("../img/decoration.svg") center top / 100% auto no-repeat;
	content: "";
	transform: scaleY(-1);
}

.gaufres-scene-header {
	margin-bottom: 1.5em;
	padding-block: 3px;
	border-block: 3px solid var(--color_beige_light);
}

.gaufres-scene-header .inner {
	padding-block: 1.1em;
	background: rgb(var(--color_green_rgb), 0.39);
	font-family: var(--font_serif);
	text-align: center;
}

.gaufres-scene-figure {
	display: grid;
	font-size: 20px;
	font-family: var(--font_serif);
	gap: 1em;
}

.gaufres-scene-figure:nth-child(1) {
	grid-template-columns: auto auto;
	justify-content: start;
	align-items: center;
}

.gaufres-scene-figure:nth-child(2) {
	margin-block: max(-20px, -11%) 1em;
	grid-template-columns: auto auto;
	justify-content: end;
	align-items: center;
}

.gaufres-scene-figure:nth-child(3) {
	justify-items: center;
}

.gaufres-scene-figure .img {
	border-radius: 50%;
}

.gaufres-scene-figure figcaption {
	line-height: 1.4;
}

@media (min-width: 768px) {
.gaufres-scene {
	padding-bottom: 160px;
}
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
- 商品
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.gaufres-product .heading_serif {
	position: relative;
	z-index: 1;
	width: fit-content;
	margin: 0 auto -1.2em;
	padding: 0.2em 1em;
	border: 7px solid var(--color_beige_light);
	border-radius: 100vw;
	background: #fff;
	color: var(--color_beige);
	font-weight: 700;
	font-size: 25px;
}

.gaufres-product .content {
	padding: 60px var(--padding-inline) 40px;
	border: 7px solid var(--color_beige_light);
}

.gaufres-product-ul {
	margin-bottom: 50px;
}

.gaufres-product-li:not(:last-child) {
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--color_beige_light);
}

.gaufres-product-li .img {
	display: block;
	margin-inline: auto;
}

.gaufres-product-li .heading {
	margin-block: 1.1em 0.6em;
	font-weight: inherit;
	font-size: 20px;
	font-family: var(--font_serif);
	line-height: 1.3;
}

.gaufres-product-li .price {
	margin-bottom: 0.4em;
	font-size: 20px;
	font-family: var(--font_serif);
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
- キャンペーン
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.gaufres-event {
	padding-top: clamp(160px, calc(100vw * 160 / 417), 200px);
	border-radius: 100vw 100vw 0 0;
	background: url("../img/event-decoration.svg") center 8px / 100% auto no-repeat var(--color_green_light);
}

.gaufres-event-header {
	padding-bottom: 18px;
	text-align: center;
}

.gaufres-event-header .copy {
	display: grid;
	color: var(--color_red_light);
	font-weight: 700;
	font-size: 18px;
	grid-template-columns: auto auto auto;
	column-gap: 0.1em;
	justify-content: center;
	align-items: center;
}

.gaufres-event-header .copy::before {
	content: "＼";
	transform: rotate(20deg);
}

.gaufres-event-header .copy::after {
	content: "／";
	transform: rotate(-20deg);
}

.gaufres-event-header .copy-large {
	font-size: 22px;
}

.gaufres-event-header .limit {
	color: var(--color_green_dark);
	font-weight: 700;
	font-size: 40px;
	line-height: 1.2;
}

.gaufres-event-header .heading_serif {
	font-weight: 500;
	font-size: 26px;
}

.gaufres-event-period {
	padding: 0.3em var(--padding-inline);
	border-top: 3px solid var(--color_beige_light);
	background: var(--color_green_dark);
	color: #fff;
	font-weight: 700;
	font-size: 23px;
	text-align: center;
}

.gaufres-event-ribbon {
	position: relative;
	height: 28px;
	border-bottom: 4px solid var(--color_beige_light);
	background: var(--color_red);
}

.gaufres-event-ribbon img {
	position: absolute;
	inset: -6px 0 auto;
	margin-inline: auto;
}

.gaufres-event-img {
	display: block;
	margin: 0 auto 30px;
}

.gaufres-event .frame {
	background-color: #fff;
}

.gaufres-event-frame {
	padding-inline: 1em;
	border-inline: 3px solid var(--color_beige_light);
	background: #fff;
	text-align: center;
}

.gaufres-event-frame .strong {
	margin-top: 0.4em;
	color: var(--color_red);
	font-weight: 700;
	font-size: 20px;
	line-height: 1.6;
}

.gaufres-event-frame .amount {
	font-size: 42px;
	line-height: 1;
}

.gaufres-event-frame .tax {
	font-size: 13px;
}

.gaufres-event-frame .large {
	font-size: 22px;
}

.gaufres-event-description {
	margin-top: 0.8em;
}

@media (min-width: 768px) {
.gaufres-event {
	padding-top: 160px;
}
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
- SNS
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.gaufres-sns {
	background: var(--color_beige);
	text-align: center;
}

.gaufres-sns .heading_serif {
	width: 223px;
	margin: 0 auto 1em;
	padding-bottom: 1em;
	border-bottom: 1px solid;
	font-size: 21px;
}

.gaufres-sns-ul {
	display: grid;
	grid-template-columns: auto auto;
	column-gap: 50px;
	justify-content: center;
}

.gaufres-sns-li a:hover {
	opacity: var(--opacity);
}

/*+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+
- リンク
+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+--+*/
.gaufres-link-ul {
	display: grid;
	position: sticky;
	bottom: 0;
	z-index: 2;
	transition: transform var(--transition);
	grid-template-columns: 1fr 1fr;
}

.gaufres-link-ul:not(._show) {
	transform: translateY(100%);
}

.gaufres-link-li a {
	display: block;
	padding-bottom: 1.4em;
	color: #fff;
	text-align: center;
}

.gaufres-link-shop a {
	background: var(--color_red_light);
}

.gaufres-link-online a {
	background: #565656;
}

.gaufres-link-li a:hover {
	filter: contrast(1.5);
}

.gaufres-link-li .frame {
	height: 19px;
}

.gaufres-link-li .heading {
	margin-top: 0.3em;
	font-weight: 500;
	font-size: 16px;
	font-family: var(--font_serif);
}
