@charset "utf-8";

/* -------------------------------------------------- */
/* PC*/
/* -------------------------------------------------- */
/* MV */
/* ----------------------------------- */

#mv {
	position: relative;
	margin-bottom: 100px;
}

#mvTit {
	font-size: 3.6rem;
	font-weight: bold;
	position: absolute;
	top: 50px;
	left: 50px;
	color: #FFF;
}

#mvImg2 {
	position: absolute;
	bottom: -80px;
	right: 40px;
}

/* リンクエリア */
/* ----------------------------------- */
#contentLink {
	display: flex;
	flex-wrap: wrap;
	gap: 30px;
	margin-bottom: 80px;
}

#topHoliday {
	width: calc(50% - 15px);
}

#topHoliday .calender {
	width: 100%;
	margin: 0 auto;
}

#topHoliday .xo-event-calendar table.xo-month .month-event-title {
	font-size: 1rem;
}

#topHoliday .xo-event-calendar table.xo-month {
	height: 380px;
}

#contentBtn {
	width: calc(50% - 15px);
}

#contentBtn ul {
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	height: 100%;
	gap: 10px;
}

#contentBtn a {
	height: 100%;
	padding: 0 50px;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	align-items: center;
	gap: 10px;
	border: 1px solid #CCC;
	border-radius: 10px;
	background: url(../../img/common/icon_arrow_b.svg) right 10px center no-repeat;
	font-size: 2rem;
	transition: all 0.3s ease-in-out 0s;
}

#contentBtn a:hover {
	border: 1px solid #2ebcf1;
	background: url(../../img/common/icon_arrow_w.svg) right 10px center no-repeat #2ebcf1;
	color: #FFF;
}

#vaccination a::before {
	content: "";
	width: 28px;
	height: 48px;
	background: url(../../img/top/link_img1.png) 0 0 no-repeat;
	background-size: contain;
	display: inline-block;
	vertical-align: middle;
}

#checkup a::before {
	content: "";
	width: 44px;
	height: 48px;
	background: url(../../img/top/link_img2.png) 0 0 no-repeat;
	background-size: contain;
	display: inline-block;
	vertical-align: middle;
}

#renkei a::before {
	content: "";
	width: 46px;
	height: 48px;
	background: url(../../img/top/link_img3.png) 0 0 no-repeat;
	background-size: contain;
	display: inline-block;
	vertical-align: middle;
}

#vaccination {
	flex-grow: 1;
}

.contentBtnSubTxt {
	font-size: 1.2rem;
	display: block;
}

#checkup {
	flex-grow: 1;
}

#renkei {
	flex-grow: 1;
}

/* 新着情報 */
/* ----------------------------------- */
#topics {
	margin-bottom: 80px;
}

#topics .scroll {
	width: 100%;
	height: 300px;
	padding: 40px;
	border: 1px solid #CCC;
	position: relative;
	overflow: hidden;
}

#topics li {
	padding-bottom: 10px;
	margin-bottom: 15px;
	border-bottom: 1px solid #CCC;
}

.date {
	font-size: 1.4rem;
}

.topicsTit {
	font-size: 1.6rem;
}

.ps__thumb-y {
	width: 10px;
	background-color: #2ebcf1;
	border-radius: 0px;
	transition:none;
	right: 0;
}	
.ps--active-x > .ps__rail-x,
.ps--active-y > .ps__rail-y {
	background-color: #eeeeee;
}

.ps__rail-y.ps--clicking .ps__thumb-y {
	background-color: #2ebcf1;
	width: 10px;
}

.ps__rail-y:hover > .ps__thumb-y, .ps__rail-y:focus > .ps__thumb-y, .ps__rail-y.ps--clicking .ps__thumb-y {
	background-color: #2ebcf1;
	width: 10px;
}

.ps__rail-x, .ps__rail-y {
	opacity: 1!important;
	width: 10px;
}

/* link */
/* ----------------------------------- */
.outLink {
	margin-bottom: 80px;
}

.outLink ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 20px 2%;
}

.outLink ul li {
	width: 32%;
}

.outLink ul li a {
	width: 100%;
	height: 100%;
	padding: 15px;
	display: block;
	border: 1px solid #2ebcf1;
	color: #333;
	background: url(../../img/common/icon_link.svg) right 10px center no-repeat;
	transition: all 0.3s ease-in-out 0s;
	border-radius: 5px;
	font-size: 1.6rem;
}

.outLink ul li a:hover {
	color: #fff;
	background: url(../../img/common/icon_link_w.svg) right 10px center no-repeat #2ebcf1;
	transition: all 0.3s ease-in-out 0s;
}



/* -------------------------------------------------- */
/* TAB&SP */
/* -------------------------------------------------- */
@media screen and (max-width: 1024px) {
	/* MV */
	/* ----------------------------------- */
	#mvImg1 {
		width: 100%;
	}

	#mvImg1 img {
		width: 100%;
	}

	#mvImg2 {
		width: 40%;
	}

	#mvImg2 img {
		width: 100%;
		height: auto;
	}

	#mvTit {
		font-size: 2.8rem;
		left: calc(50px + 5%);
	}


	/* リンクエリア */
	/* ----------------------------------- */
	#topHoliday {
		width: 100%;
	}

	#contentBtn {
		width: 100%;
	}

	#contentBtn a {
		height: 100%;
		padding: 20px 50px;
		display: flex;
		flex-wrap: wrap;
		justify-content: flex-start;
		align-items: center;
		gap: 10px;
		border: 1px solid #CCC;
		border-radius: 10px;
		background: url(../../img/common/icon_arrow_b.svg) right 10px center no-repeat;
		font-size: 2rem;
		transition: all 0.3s ease-in-out 0s;
	}


}


/* -------------------------------------------------- */
/* TAB(調整) */
/* -------------------------------------------------- */
@media screen and (min-width: 768px) and (max-width: 1024px) {

}
/* -------------------------------------------------- */
/* SP(調整) */
/* -------------------------------------------------- */
@media screen and (max-width: 767px) {
	/* MV */
	/* ----------------------------------- */
	#mvTit {
		font-size: 1.8rem;
		left: calc(30px + 5%);
	}

	#mvImg2 {
		width: 70%;
		position: absolute;
		bottom: -80px;
		right: auto;
		position: absolute;
		left: 50%;
		-webkit-transform: translate(-50%, 0);
		transform: translate(-50%, 0);
	}

	/* リンク */
	/* ----------------------------------- */
	#contentLink {
		margin-bottom: 40px;
	}

	#contentBtn a {
		height: 100%;
		padding: 20px 30px;
		display: flex;
		flex-wrap: nowrap;
		justify-content: flex-start;
		align-items: center;
		gap: 10px;
		border: 1px solid #CCC;
		border-radius: 10px;
		background: url(../../img/common/icon_arrow_b.svg) right 10px center no-repeat;
		font-size: 1.6rem;
		transition: all 0.3s ease-in-out 0s;
	}

	.contentBtnSubTxt {
		font-size: 1rem;
	}

	/* 新着情報 */
	/* ----------------------------------- */
	#topics {
		margin-bottom: 40px;
	}

	#topics .scroll {
		padding: 20px;
	}

	/* 外部リンク */
	/* ----------------------------------- */
	.outLink {
		margin-bottom: 40px;
	}

	.outLink ul li {
		width: 49%;
	}

	.outLink ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		align-items: center;
		gap: 10px 2%;
	}

}