html {
	font-size: 62.5%;
}

body {
	font-family: "Noto Serif JP", serif;
	font-size: 1.6rem;
	font-weight: 500;
	font-feature-settings: "palt" 1;
	color: #010101;
	text-align: initial;
	letter-spacing: 0.025em;
	word-break: normal;
	word-wrap: break-word;
	stroke-dasharray: 3, 3;
	stroke-opacity: 0.5;
	stroke-width: 0.5px;
	shape-rendering: crispEdges;
	-webkit-text-size-adjust: 100%;
}

@supports (-webkit-touch-callout: none) {
	html {
		height: -webkit-fill-available;
	}

	main {
		height: -webkit-fill-available;
		min-height: calc(100vh - 208px);
	}
}

h1 {
	width: 360px;
	height: 33px;
}

h1 img {
	max-width: 360px;
}

h2 {
	padding-bottom: 0.5em;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1.4em;
	color: #010101;
	letter-spacing: initial;
}

ol,
ul {
	list-style: none;
}

li {
	line-height: 1.75em;
	color: #555;
}

main {
	width: 100%;
	height: calc(100vh - 208px);
	background: url(../img/img_logo-group.svg) center center / cover no-repeat;
}

main section {
	width: 100%;
	height: 100%;
}

main section div.wrapper {
	max-width: 1280px;
	height: 100%;
	padding: 0 15px;
	margin: 0 auto;
}

main p {
	margin-bottom: 1em;
	line-height: 2em;
	text-align: justify;
	text-justify: inter-character;
}

main p:last-child,
footer p:last-child {
	margin-bottom: 0;
}

.main-img {
	display: flex;
	align-items: center;
	width: 100%;
	height: calc(100% - 210px);
}

.main-list {
	height: 210px;
	padding-bottom: 40px;
}

footer {
	width: 100%;
	margin-bottom: 40px;
	background-color: #f1f1f1;
}

footer section {
	width: 100%;
}

footer section div.wrapper {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	max-width: 1280px;
	height: 168px;
	padding: 40px 15px;
	margin: 0 auto;
}

footer p {
	margin-bottom: 1em;
	font-size: 1.2rem;
	line-height: 1.4em;
	color: #010101;
	text-align: center;
	letter-spacing: 0.075em;
}

.contact {
	font-size: 1.2rem;
	text-align: center;
}

.contact a:hover {
	color: #ccc;
}

.contact a::before {
	margin-right: 0.5em;
	text-decoration: none;
	content: "-";
}

.contact a::after {
	margin-left: 0.5em;
	text-decoration: none;
	content: "-";
}

/* Utility */
/* -------------------------------------------------- */
img.fluid-image {
	display: block;
	width: 100%;
	height: auto;
}

.pc-none {
	display: block;
}

.sp-none {
	display: none;
}

@media print, screen and (min-width: 768px) {
	.pc-none {
		display: none;
	}

	.sp-none {
		display: block;
	}

	main {
		background: url(../img/img_logo-group.svg) center center / contain no-repeat;
	}
}
