*,
*::before,
*::after {
	box-sizing: border-box;
}

html,
body,
header,
main,
footer,
h1,
h2,
h3,
h4,
h5,
h6,
p,
div,
ul,
ol,
li,
dl,
dt,
dd,
table,
th,
td,
a,
figure,
figcaption,
address,
article,
blockquote,
label {
	font-size: 100%;
	font-weight: 400;
	font-style: normal;
	margin: 0;
	padding: 0;
	box-sizing: border-box;
	list-style: none;
}

html {
	scroll-behavior: smooth;
}

body {
	color: #333;
	font-size: 16px;
	font-family: sans-serif;
}

a {
	font: inherit;
	color: inherit;
	text-decoration: none;
}

img {
	max-width: 100%;
}

.menu {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin-inline: auto;
}

.menu a {
	color: #03008A;
	text-decoration: none;
	font-size: 16px;
	font-weight: bold;
	display: block;
	padding: 16px;
}

.menubg {
	background-color: #D9F4FF;

}

.topotoiawase {
	text-align: center;
	font-size: 32px;
	color: #333;
	font-weight: bold;
}

.footer {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin-left: auto;
	margin-right: auto;
	max-width: 60em;
	padding-inline: 18px;
	width: 100%;
	gap: 16px;
}

header {
	background-color: #ffffff;
	position: sticky;
	width: 100%;
	top: 0;
	z-index: 10000;
}

.mokuji {
	text-align: center;
	padding-top: 50px;
}

.homemoji {
	border-bottom: 5px solid #009CCD;
	font-size: 32px;
	line-height: 1.25;
	color: #353535;
	max-width: 100%;
	text-align: center;
	padding-block: 100px 12px;
	width: max-content;
	margin-inline: auto;
}

.midashi {
	min-height: 320px;
	height: 40vw;
	margin-inline: auto;
	max-height: 672px;
	max-width: 1440px;
	display: block;
	object-fit: cover;
	object-position: center;
}

footer {
	padding-block: 64px 72px;
}

.l-container {
	max-width: 1063px;
	margin-inline: auto;
}

.l-container--compact {
	max-width: 640px;
}

.l-header__title {
	align-items: center;
	color: #03008A;
	column-gap: 20px;
	display: flex;
	font-size: 16px;
	font-weight: normal;
	justify-content: center;
	text-align: center;
	padding: 16px 16px;
	width: 100%;
}

.l-header__logo {
	flex-shrink: 1;
	max-width: 44px;
	min-width: 24px;
}

.c-paragraph {
	font-size: 16px;
	line-height: 1.78;
	font-weight: normal;
	max-width: 640px;
	margin-inline: auto;
}

.c-paragraph + .c-paragraph {
	margin-top: 16px;
}

.c-bullet-point {
	padding-left: 1.25em;
}

.c-bullet-point::before {
	content: "・";
	margin-inline: -1.25em .25em;
}

.u-color--primary {
	color: #009CCD;
}

.u-text--center {
	text-align: center;
}

.u-text--end {
	text-align: end;
}

.mt32 {
	margin-top: 32px;
}

.mt96 {
	margin-top: 96px;
}

.px16 {
	padding-inline: 16px;
}

.px8 {
	padding-inline: 8px;
}

@media screen and (min-width: 960px) {
	.l-header__title {
		font-size: 32px;
		padding-block: 30px;
	}

}