#hero-image {
	padding: 0px 2.6dvw 0 2.6dvw;
	position: relative;
	width: 100%;
	height: calc(100dvh - 110px);
	max-height: 1210px;
	box-sizing: border-box;
	margin: 0 auto 80px;
}

#hero-image-slide {
	height: 100%;
	position: relative;
	z-index: 1;
}

#hero-image-slide img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 20px;
}

#hero-image-slide .slick-list,
#hero-image-slide .slick-track {
	height: 100%;
}

#hiro-catch {
	position: absolute;
	z-index: 2;
	top: 10%;
	left: 10%;
	font-weight: 200;
	font-size: clamp(40px, 3.125dvw, 60px);
	text-align: center;
	line-height: 1.4em;
	font-family: "m-plus-2p", sans-serif;
	font-weight: 300;
	font-style: normal;
	text-shadow: 0 0 2px #fff, 0 0 2px #fff, 0 0 2px #fff, 0 0 2px #fff, 0 0 2px #fff;
}

#hero-image-time {
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: 3;
	background: rgba(255, 255, 255, 0.95);
	border-radius: 10px 0 0 10px;
	box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.3);
	overflow: hidden;
}

#hero-image-time table {
	width: 100%;
	margin-bottom: 20px;
}

#hero-image-time thead th {
	font-size: 24px;
	color: #fff;
	background: #1c52a0;
}

#hero-image-time thead th img {
	vertical-align: middle;
	margin-right: 5px;
}

#hero-image-time th,
#hero-image-time td {
	padding: 5px;
	font-weight: 400;
	vertical-align: middle;
	text-align: center;
	border-bottom: 1px solid #ccc;
	border-left: 1px solid #999;
	box-sizing: border-box;
}

#hero-image-time td {
	color: #144ba5;
	min-width: 70px;
}

#hero-image-time p {
	line-height: 1.4em;
	margin: 0 20px;
	font-size: 15px;
}

#hero-image-time dl {
	margin: 0 20px;
	line-height: 1.4em;
	display: flex;
	font-size: 15px;
}

#hero-image-time dl dt {
	font-weight: 700;
	white-space: nowrap;
}

#hero-image-time dl dd ul {
	padding: 0 0 0 40px;
}

#hero-image-time table small {
	font-size: 14px;
	color: #222;
}

.slick-dots {
	display: flex;
	gap: 10px;
	justify-content: center;
	list-style: none;
	position: absolute;
	width: 100%;
	z-index: 2;
	bottom: 20px;
	left: 0;
}

.slick-dots button {
	width: 10px;
	height: 10px;
	border-radius: 50px;
	background: #73786f;
	text-indent: -9999px;
	display: block;
	border: 0;
	padding: 0;
}

.slick-dots .slick-active button {
	background: #4b4b4b;
}

#top1 {
	padding: 0 20px;
	max-width: 1340px;
	margin: 0 auto 80px;
	display: flex;
	box-sizing: border-box;
	gap: 40px;
}

#top1_l {
	border: 5px solid #707070;
	border-radius: 20px;
	width: 320px;
	flex: none;
	overflow: hidden;
	box-sizing: border-box;
}

#top1_l dt {
	color: #fff;
	background: #707070;
	font-weight: 700;
	text-align: center;
	line-height: 40px;
}

#top1_l dd {
	height: 240px;
}

#top1_l dd iframe {
	width: 370px;
    height: 240px;
    border-radius: 0 0 10px 10px;
    margin: 0 0 0 -30px;
}

#top1_l dd img {
	display: block;
}

#top1 article {
	width: calc(100% - 380px);
	flex: none;
	display: flex;
	justify-content: space-between;
}

#top1 article dl {
	width: 300px;
	flex: none;
}

#top1 article dl dd {
	padding: 10px;
}

#top1 article dl dt a {
	height: 150px;
	border-radius: 40px;
	box-sizing: border-box;
	text-align: center;
	text-decoration: none;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 20px;
	font-size: 22px;
	color: #000000;
	box-shadow: 0 5px 5px rgba(0, 0, 0, 0.3);
}

#top1 article dl:nth-child(1) a {
	border: 5px solid #ff6c00;
}

#top1 article dl:nth-child(1) a:hover {
	background: #fba260;
	color: #fff;
}

#top1 article dl:nth-child(2) a {
	border: 5px solid #2155a4;
}

#top1 article dl:nth-child(2) a:hover {
	background: #719bdb;
	color: #fff;
}

#top1 article dl:nth-child(3) a {
	border: 5px solid #707070;
}

#top1 article dl:nth-child(3) a:hover {
	background: #aca5a5;
	color: #fff;
}

#top2 {
	padding: 0 3%;
	margin: 0 auto 160px;
}

#top2 article {
	max-width: 1620px;
	display: flex;
	margin: 0 auto;
	gap: 3.7%;
}

#top2 #news {
	width: 40.7%;
	flex: none;
	padding: 40px 1vw 10px 2vw;
	box-sizing: border-box;
	background: #e4f4f8;
	border-radius: 20px;
	box-shadow: 0 3px 5px rgba(0, 0, 0, 0.2) inset;
}

#top2 #calendar {
	width: calc(100% - 44.4%);
	flex: none;
	padding: 50px 3.125dvw 40px;
	box-sizing: border-box;
	background: #e4f4f8;
	border-radius: 20px;
	box-shadow: 0 3px 5px rgba(0, 0, 0, 0.2) inset;
}

#top2 h2 {
	font-size: 28px;
	color: #2055a3;
	font-weight: 700;
	margin-bottom: 35px;
	text-align: center;
}

#news_inner {
	border-top: 2px solid #fff;
	border-bottom: 2px solid #fff;
	margin: 0 auto 20px;
	height: 300px;
	overflow: auto;
}

#news dl {
	padding: 15px 0;
	border-bottom: 2px solid #fff;
}

#news dt {
	display: flex;
	font-weight: 700;
	gap: 20px;
}

#news dt time {
	display: block;
	width: 90px;
	color: #197099;
}

#calendar_inner {
	display: flex;
	gap: 2.34375dvw;
	margin: 0 auto 40px;
}

#calendar_inner iframe {
	display: block;
	width: calc((100% - 2.34375dvw) / 2);
	height: 220px;
	background: #dae2e4;
}

.hanrei {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	line-height: 25px;
}

.hanrei ul {
	display: flex;
	gap: 20px;
	align-items: center;
	list-style: none;
	margin-bottom: 20px;
}

.hanrei ul li {
	display: flex;
	;
	align-items: center;
}

.hanrei .box {
	width: 38px;
	height: 25px;
	display: inline-block;
	box-sizing: border-box;
	border: 1px solid #ccc;
}

.hanrei4 {
	display: flex;
	;
	align-items: center;
}

.hanrei1 .box {
	background: #fff;
}

.hanrei2 .box {
	background: #808080;
}

.hanrei3 .box {
	background: #6583ae;
}

.hanrei4 .box {
	background: #fac98e;
}

.more a {
	display: block;
	border: 2px solid #707070;
	background: #fff;
	line-height: 40px;
	border-radius: 22px;
	text-align: center;
	text-decoration: none;
	color: #000;
	font-size: 20px;
	box-shadow: 0 3px 3px rgba(0, 0, 0, 0.3);
}

.more a:hover {
	color: #fff;
	background: #174ea1;
}

#top3 {
	padding: 0 20px;
	max-width: 1620px;
	box-sizing: border-box;
	margin: 0 auto 160px;
	display: flex;
	gap: 45px;
}

.top3_fukidashi {
	position: relative;
	border: 8px solid #2055a3;
	color: #2055a3;
	box-sizing: border-box;
	padding: 20px;
	width: 320px;
	font-size: 26px;
	line-height: 1.6em;
	border-radius: 30px;
	background: #fff;
}

.top3_fukidashi::after {
	content: "";
	position: absolute;
	display: block;
	width: 41px;
	height: 50px;
	top: 70px;
	right: -41px;
	background: url('../images/common/fukidashi_shippo.png') no-repeat;
}

#top3 article {
	width: calc(100% - 365px);
	flex: none;
	display: flex;
}

#top3 .arrow {
	width: clamp(30px, 3.125dvw, 60px);
	display: flex;
	align-items: center;
}

#top3 .arrow img {
	display: block;
}

#top3 article dl {
	width: calc((100% - 12.5dvw) / 4);
	display: flex;
	flex-direction: column;
}

#top3 article dl dt {
	height: calc(100% - 40px);
	display: flex;
	justify-content: center;
	align-items: center;
}

#top3 article dl dt img {
	display: block;
}

#top3 article dl dd {
	font-size: 21px;
	line-height: 38px;
	border: 1px solid #2055a3;
	border-radius: 20px;
	text-align: center;
	color: #2055a3;
	margin-top: auto;
}

#top4 {
	padding: 50px 3% 40px;
	background: #e4f4f8;
	position: relative;
}

#top4:before {
	content: "";
	width: 100%;
	height: 2px;
	background: #fff;
	top: 8px;
	left: 0;
	position: absolute;
}

#top4 h2 {
	font-size: 36px;
	color: #2055a3;
	margin: 0 auto 40px;
	text-align: center;
}

#top4 article {
	max-width: 1620px;
	margin: 0 auto;
	display: flex;
	gap: 40px;
}

#top4 article .inner {
	width: calc((100% - 40px) / 2);
	flex: none;
}

#top4 article h3 {
	line-height: 50px;
	font-size: 28px;
	color: #fff;
	background: #2055a3;
	border-radius: 25px;
	text-align: center;
	margin: 0 auto 40px;
}

#top4 article figure {
	display: flex;
	gap: 30px;
	margin: 0 auto 30px;
}

#top4 article figure img {
	width: 232px;
	max-width: initial !important;
	display: block;
	flex: none;
}

#top4 article figure figcaption {
	width: calc(100% - 262px);
	flex: none;
}

#top4 article figure figcaption h4 {
	color: #2055a3;
}

#top5 {
	padding: 40px 3% 40px;
	border-top: 2px solid #fff;
	background: #e4f4f8;
	position: relative;
	margin: 0 auto 70px;
}

#top5 article {
	max-width: 790px;
	margin: 0 auto;
	text-align: center;
}

#top5 article .more {
	padding: 40px 0 0;
}

#top5 article .more a {
	border: 5px solid #2055a3;
}

#top5:after {
	content: "";
	width: 100%;
	height: 2px;
	background: #fff;
	bottom: 8px;
	left: 0;
	position: absolute;
}

#top6 {
	padding: 0 3%;
	background: url('../images/common/bg_ohisama.webp') no-repeat center center;
}

#top6 article {
	max-width: 1280px;
	margin: 0 auto;
	min-height: 690px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}

#top6 article #top5_l {
	order: 1;
	width: 650px;
	flex: none;
	font-size: 24px;
	color: #ff7022;
}

#top6 article #top5_r {
	order: 2;
	width: 580px;
	flex: none;
}

#top6 article #top5_r img {
	float: right;
}

#top6 article #top5_r h3 {
	font-size: 32px;
	color: #ff5a00;
	clear: both;
	margin-bottom: 30px;
}

#top6 article #top5_r h3 strong {
	font-size: 48px;
}

#top6 article .more a {
	border: 5px solid #ff5a00;
}

#top6 article .more a:hover {
	background: #ff5a00;
}