h1.wp-block-heading {
	width: 100%;
	max-width: 880px;
	margin-right: auto;
	margin-bottom: 0;
	margin-left: auto;
	padding: 10px 6px 10px 17px;
	color: var(--wp--preset--color--dark-01);
	font-weight: 400;
	font-size: 2rem;
	letter-spacing: 0.2rem;
	text-align: center;

	@media (width <= 767px) {
		max-width: calc(100vw - 2rem);
		font-size: 1.5rem;
	}
}

h2.wp-block-heading {
	line-height: 1;
	@media (width <= 767px) {
		width: 100%;
		max-width: calc(100vw - 2rem);
		font-size: 1.2rem;
	}
	&.is-style-default {
		position: relative;
		max-width: 880px;
		margin-right: auto;
		margin-bottom: 0;
		margin-left: auto;
		font-weight: 400;
		font-size: 2rem;
		font-family: var(--wp--preset--font-family--ryo-display);
		line-height: 1;
		letter-spacing: 0.3rem;
		text-align: center;
		@media (width <= 767px) {
			width: 100%;
			max-width: calc(100vw - 2rem);
			font-size: 1.5rem;
			letter-spacing: 0.1rem;
		}
		&::before {
			right: 0;
			bottom: calc(100% + 25px);
			left: 0;
			display: block;
			width: 50px;
			height: 50px;
			margin-right: auto;
			margin-bottom: 1rem;
			margin-left: auto;
			background-image: url(../../images/ornament_sakura.svg);
			background-repeat: no-repeat;
			background-position: center;
			content: "";
		}

		&::after {
			display: block;
			width: 100%;
			height: 4px;
			margin-top: 1rem;
			margin-right: auto;
			margin-left: auto;
			background-color: var(--wp--preset--color--primary);
			content: "";
		}
	}

	+ * {
		margin-top: 4rem;
	}
}

h3.wp-block-heading {
	line-height: 1;
	@media (width <= 767px) {
		max-width: calc(100vw - 2rem);
		font-size: 1.1rem;
	}
	&.is-style-default {
		position: relative;
		max-width: 880px;
		margin-right: auto;
		margin-bottom: 0;
		margin-left: auto;
		padding: 1rem 0 1rem 3rem;
		color: var(--wp--preset--color--light-01);
		font-weight: 500;
		font-size: 1.7rem;
		font-family: var(--wp--preset--font-family--ryo-display);
		line-height: 1.5;
		background-color: var(--wp--preset--color--primary);
		@media (width <= 767px) {
			width: 100%;
			max-width: calc(100vw - 2rem);
			font-size: 1.7rem;
		}
		&::before {
			position: absolute;
			top: 50%;
			left: 0;
			width: 30px;
			height: 5px;
			background-color: var(--wp--preset--color--primary-dark);
			transform: translateY(-50%);
			content: "";
		}

		&:first-of-type {
			border-top: 0;
		}

		&.has-text-align-left {
			margin-left: 0;
			text-align: left;
		}
	}

	&.is-style-member {
		display: flex;
		align-items: center;
		font-size: 1.6rem;
		font-family: var(--wp--preset--font-family--ryo-display);

		&::before {
			width: 30px;
			height: 30px;
			margin-right: 0.5rem;
			background-image: url(../../images/ornament_leaf.svg);
			content: "";
		}
	}

	+ * {
		margin-top: 3rem;
	}
}

h4.wp-block-heading {
	&.is-style-default {
		width: 100%;
		max-width: 880px;
		margin-right: auto;
		margin-left: auto;
		padding: 0.5rem 0;
		font-weight: 400;
		font-size: 1.2rem;
		border-bottom: 1px solid var(--wp--preset--color--primary);
		@media (width <= 767px) {
			width: 100%;
			max-width: calc(100vw - 2rem);
			font-size: 1.2rem;
		}
	}

	+ * {
		margin-top: 2rem;
	}
}

h5.wp-block-heading {
	margin: 0 0 1rem 0;
	color: var(--wp--preset--color--secondary);
	font-weight: 500;
	font-size: 1.1rem;

	+ * {
		margin-top: 2rem;
	}
}

h6.wp-block-heading {
	margin: 20px 0 15px 5px;
	color: #ec8fb0;
	font-size: 1rem;

	+ * {
		margin-top: 2rem;
	}
}
