.header {
	padding-bottom: 23px;
}

@media screen and (max-width: 969px) {
	.header {
		padding-bottom: 20px;
	}
	.footer {
		padding-top: 50px;	
	}
}

.hero {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 200px;
	background: transparent linear-gradient(90deg, #8B76D6 0%, #00B3BA 100%) 0% 0% no-repeat padding-box;
	color: #fff;
}

.hero__title {
	font-size: 32px;
	font-weight: bold;
	letter-spacing: .1em;
}

@media screen and (max-width: 969px) {
	.hero {
		height: 120px;
	}

	.hero__title {
		font-size: 18px;
	}
}

.content {
	background-color: #F7F7F7;
	text-align: center;
	padding: 5em 1em;
}

@media screen and (max-width: 969px) {
	.content {
		padding: 3em 1em;
	}
}

.content__inner {
	width: 100%;
	max-width: 1200px;
	margin-inline: auto;
}

.content__inner > *:first-child {
	margin-top: 0 !important;
}

.content__inner > *:last-child {
	margin-bottom: 0 !important;
}

.c-button {
	display: inline-block;
	padding: 1em 3em;
	background-color: #5d52cc;
	border: 1px solid #5d52cc;
	color: #fff;
	border-radius: 4em;
	font-size: 16px;
	line-height: 1.4;
	font-weight: bold;
	cursor: pointer;
	transition: color .1s ease-in-out, background-color .1s ease-in-out;
}

.c-button--lg {
	padding: 1em 3.5em;
	font-size: 18px;
}

.c-button--back {
	border: 1px solid #aaa;
	background-color: #aaa;
	color: #fff;
}

.c-button-outer {
	text-align: center;
	margin-block: 3em;
}

.c-button:hover {
	color: #5d52cc;
	background-color: #fff;
}

.c-button--back:hover {
	color: #aaa;
}

.boards {
	display: flex;
	flex-wrap: wrap;
	gap: 2em;
	width: 100%;
}

.board {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: calc(50% - 1em);
	background-color: #fff;
	padding: 3em 1em;
	gap: 1.5em;
	transition: box-shadow .1s ease-in-out;
}

@media screen and (max-width: 969px) {
	.board {
		width: 100%;
	}
	.board__title {
		font-size: 14px;
	}
}

.board:hover {
	box-shadow: 0 0 10px rgba(0, 0, 0, .2);
}

.board strong {
	font-weight: bold;
	font-size: 28px;
}

.board__message {
	padding: 1em 3em;
	background-color: #5d52cc;
	border: 1px solid #5d52cc;
	color: #fff;
	border-radius: 4em;
	font-size: 16px;
	font-weight: bold;
	line-height: 1.4;
	transition: color .1s ease-in-out, background-color .1s ease-in-out;
}

.board:hover .board__message {
	color: #5d52cc;
	background-color: #fff;
}

.heading {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	margin-top: 3em;
	margin-bottom: 1em;
	line-height: 1.4;
}

@media screen and (max-width: 969px) {
	.heading {
		font-size: 18px;
	}
}

.message {
	font-size: 16px;
	margin-block: 3em;
}

@media screen and (max-width: 969px) {
	.message {
		font-size: 14px;
		margin-block: 2em;
	}
}

.message strong {
	font-weight: bold;
}

.message small {
	font-size: .75em;
	line-height: 2;
	display: block;
	margin-block: .5em;
}

.message a {
	text-decoration: underline;
	color: #5d52cc;
	font-weight: bold;
	margin-inline: .25em;
}

.message a:hover {
	text-decoration: none;
}

.history {
	display: flex;
	flex-direction: column;
	margin-block: 3em;
	width: 100%;
	max-width: 800px;
	margin-inline: auto;
	gap: 1.5em;
	text-align: left;
}

.history li {
	position: relative;
	padding-left: 1.25em;
}

.history li::before {
	content: '';
	position: absolute;
	top: 5px;
	left: 0;
	width: 8px;
	height: 8px;
	border-radius: 100%;
	background-color: currentColor;
}

.panel {
	margin-block: 5em;
	background-color: #fff;
	padding: 3em 1em;
}

.panel--half-padding {
	padding-block: 1.5em;
}

.panel > *:first-child {
	margin-top: 0 !important;
}

.panel > *:last-child {
	margin-bottom: 0 !important;
}

.h-mt-0 {
	margin-top: 0 !important;
}

.h-mb-0 {
	margin-bottom: 0 !important;
}

.form-table {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	width: 100%;
	margin-block: 3em;
	gap: 1.5em;
	text-align: left;
	margin-inline: auto;
	max-width: 900px;
}

.form-table__tr {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	gap: 1em;
}

.form-table__th {
	width: calc(30% - 1em);
	font-weight: bold;
	font-size: 16px;
}

.form-table__td {
	width: 70%;
}

.form-message {
	color: red;
}

.form-table__td input[type="text"],
.form-table__td input[type="tel"],
.form-table__td input[type="email"],
.form-table__td textarea {
	width: 100%;
	padding: 1em 1.5em;
	border: 1px solid #ccc;
	border-radius: 4px;
	font-size: 16px;
	line-height: 1.4;
}

.form-table__td textarea {
	height: 300px;
}

.radio-group {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	width: 100%;
	gap: 1em;
	margin-bottom: 1em;
}

.radio-box {
	display: flex;
	align-items: center;
	width: fit-content;
}

.radio-box input[type="radio"] {
	-webkit-appearance: checkbox;
}

.label {
	display: inline-block;
	font-size: 16px;
	background-color: #aaa;
	color: #fff;
	padding: .5em 1em;
	border-radius: 3em;
	margin-right: .5em;
}

.label--required {
	background-color: #03b1b9;
}

@media screen and (max-width: 969px) {
	.form-table__th {
		width: 100%;
	}
	.form-table__td {
		width: 100%;
	}
}

/* マニュアル */
.content--manual {
	text-align: left;
}

.content--manual .content__inner {
	max-width: 1000px;
}

.toc {
	background-color: #FFF;
	padding: 3em 2em;
	max-width: 740px;
	width: 100%;
	margin-inline: auto;
}

.toc__heading {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 1.5em;
	line-height: 1.4;
}

@media screen and (max-width: 969px) {
	.toc {
		background-color: #FFF;
		padding: 2em 1em;
	}

	.toc__heading {
		font-size: 18px;
	}
}

.toc__ol {
	display: flex;
	flex-direction: column;
	gap: 1em;
	list-style: decimal;
	padding-inline-start: 1em;
	margin-left: 1em;
}

.toc__ol a {
	color: #5d52cc;
	text-decoration: underline;
	font-weight: bold;
	line-height: 1.4;
}

.toc__ol a:hover {
	text-decoration: none;
}

.content--manual .heading {
	text-align: left;
	padding-left: .5em;
	border-left: 5px solid #5d52cc;
}

.flow {
	display: flex;
	flex-direction: column;
	gap: 1em;
	list-style: decimal;
	padding-inline-start: 1em;
	margin-left: 1em;	
	margin-block: 2em;
	font-size: 16px;
	line-height: 2;
}

.content--manual p {
	font-size: 16px;
	margin-bottom: 1em;
}

.content--manual h4 {
	font-weight: bold;
	margin-top: 2em;
	margin-bottom: 1em;
	line-height: 1.4;
	font-size: 18px;
}

.content--manual p strong {
	font-weight: bold;
}

.content--manual p a {
	color: #5d52cc;
	text-decoration: underline;
}

.content--manual p a:hover {
	text-decoration: none;
}

.content--manual figure {
	display: block;
	text-align: center;
	margin-block: 2em;
	width: 100%;
	max-width: 800px;
	margin-inline: auto;
}

.content--manual figure img {
	width: auto;
	max-width: 100%;
	height: auto;
	border: 1px solid #ccc;
	border-radius: 5px;
}

.content--manual figure figcaption {
	display: block;
	color: #666;
	margin-top: 1em;
	font-size: 14px;
	line-height: 1.4;
}

@media screen and (max-width: 969px) {
	.flow {
		font-size: 13px;
	}

	.content--manual p {
		font-size: 13px;
	}

	.content--manual h4 {
		font-size: 16px;
	}
}

.news {
	display: grid;
	gap: 2em;
	width: 100%;
}

.news__item {
	display: grid;
	width: 100%;
	background-color: #fff;
	padding: 2em;
	gap: 1em;
	text-align: left;
}

.news__heading {
	margin-bottom: 1em;

	strong {
		font-size: 24px;
		font-weight: bold;
		line-height: 1.4;
		margin-block-end: 1em;

		@media screen and (max-width: 969px) {
			font-size: 18px;
		}
	}

	span {
		font-size: 14px;
		color: #666;
		margin-inline-start: 1em;
	}
}