#title {
	background-image: url("../img/image.jpg");
}
main p span,
h2 span span,
h3 span {
	white-space: nowrap;
}
h3 {
	color: #666;
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 600;
	font-size: 1.1em;
	text-align: center;
	margin-bottom: 1em;
}
#roots dt {
	margin-bottom: .5em;
	text-align: justify;
}
#roots ol {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 1em;
}
#roots ol li {
	font-size: .9em;
	width: calc(50% - .5rem);
	position: relative;
}
#roots ol li::before {
	color: #fff;
	font-size: 1.3em;
	font-weight: 700;
	line-height: 2rem;
	text-align: center;
	background-color: #4ab98d;
	border: 1px solid #fff;
	border-radius: 50%;
	display: block;
	width: 2rem;
	height: 2rem;
	position: absolute;
	top: .5rem;
	left: .5rem;
}
#roots ol li:first-child::before {
	content: '1'
}
#roots ol li:nth-child(2)::before {
	content: '2'
}
#roots ol li:nth-child(3)::before {
	content: '3'
}
#roots ol li:nth-child(4)::before {
	content: '4'
}
#roots ol img {
	width: 100%;
}
#roots dd + dt {
	margin-top: 1.5em;
}
div#map {
	margin: 1.5em 0;
	border: 1px solid #ddd;
	width: 100%;
	height: 400px;
}
a.destination {
	color: #fff;
	font-size: 13px;
	padding: 10px;
	background-color: #4ab98d;
	border-radius: 8px;
	display: block;
	position: relative;
	transform: translate(calc(50% - 24px), -8px);
}
a.destination::after {
	content: '';
	border-top: 8px solid #4ab98d;
	border-right: 8px solid transparent;
	border-left: 8px solid transparent;
	width: 0;
	height: 0;
	position: absolute;
	left: 16px;
	top: 100%;
}
div.busstop {
	color: #000;
	font-size: 11px;
	line-height: 1.2;
	padding-left: 20px;
	text-shadow: 2px 2px 0 #fff, -2px -2px 0 #fff, -2px 2px 0 #fff, 2px -2px 0 #fff, 0px 2px 0 #fff, 0 -2px 0 #fff, -2px 0 0 #fff, 2px 0 0 #fff;
	background: url('../img/busstop.svg') left / contain no-repeat;
	transform: translateX(50%);
}
#roots ul + p {
	margin: .5em 0 3em 0;
}
#roots ul {
	padding-left: 1.5em;
}
#roots ul li + li {
	margin-top: 1.5em;
}
#roots p small {
	font-size: .9em;
	text-indent: -1em;
	padding-left: 1em;
	display: block;
}
#insurances {
	padding-top: 15em;
	background: url("../img/snack.jpg") center 3em / 12em auto no-repeat;
}
#insurances dt {
	font-size: 1.1em;
	text-align: center;
}
#insurances dd {
	padding-top: 0;
}
#insurances dd + dt {
	padding-top: 1em;
}
#insurances ul {
	padding: 0;
	list-style: none;
}
#insurances li {
	text-align: center;
	margin-top: 0;
}
#card p,
#hotel p {
	text-align: center;
}