@charset "utf-8";

/* ファーストビュー
------------------------------------------------------------*/
#first_view::before{
	content: '';
	width: 100%;
	height: 300px;
	background-color: #f4f4ef;
	position: absolute;
	bottom: 0;
}

/* メインエリア
------------------------------------------------------------*/
#main_area{position: relative;}
#main_area .splide__track{border-radius: 30px;}
#main_area .splide__slide,#main_area .splide__slide img{
	width: 100%;
	height: 800px;
}
#main_area .splide__slide img{
	display: block;
	object-fit: cover;
	object-position: center;
	transition: 15s ease-out;
}
#main_area .splide__slide.is-active img{
	transform: scale(1.12);
	transition-delay: 0s;
}
.main_copy{
	position: absolute;
	left: 4.5%;
	bottom: 14%;
}
.main_copy p{margin-bottom: 60px;}
.main_copy p img{width: clamp(600px, 30vw, 734px);}
.main_copy ul{display: flex;}
.main_copy ul li:not(:last-child){margin-right: 25px;}
.main_copy ul li img{width: clamp(180px, 18vw, 220px);}

/* お知らせ
------------------------------------------------------------*/
.news_box,.news_con > li a{
	display: flex;
	flex-wrap: wrap;
}
.news_box{align-items: flex-start;}
.news_con > li a{align-items: center;}
.news_title{width: 370px;}
.news_con{width: calc(100% - 370px);}

.news_con > li{border-bottom: 1px #474240 solid;}
.news_con > li a{
	padding: 45px 60px 45px 25px;
	background: url("../images/arrow_b.webp") no-repeat 97% center / 27px;
}
.news_con > li.fixed_news{border-bottom: none;}
.news_con > li.fixed_news a{
	border: 1px #cc4640 solid;
	background-color: #cc4640;
	border-radius: 10px;
}
.news_con > li a p{width: 115px;}
.news_con > li a h3{width: calc(100% - 115px);}
.news_con > li.fixed_news a h3{color: #fff;}
@media (any-hover: hover){
	.news_con > li a:hover{
		background-position: 97.8% center;
		padding-left: 40px;
	}
}

/* 診療のご案内
------------------------------------------------------------*/
.guide_box ul{
	max-width: 1630px;
	width: 90%;
	margin: 0 auto;
}
.guide_box li{
	width: 19%;
	margin: 0 0.5%;
}
.guide_box li:not(:nth-last-child(-n+4)){margin-bottom: 13px;}
.guide_box li a{
	display: block;
	background-color: #fff;
	border-radius: 20px;
	padding: 40px 15px 35px;
}
.guide_box li div{
	border-bottom: 2px #ddddd3 dashed;
	padding-bottom: 30px;
	margin-bottom: 25px;
}
.guide_box li div img{width: clamp(100px, 10vw, 190px);}
.guide_box li h3{
	display: flex;
	align-items: center;
	line-height: 1;
}
.guide_box li h3::before{
	content: '';
	width: 28px;
	aspect-ratio: 1 / 1;
	background: url("../images/top/guide_btn_icon.webp") no-repeat center / contain;
	margin-right: 8px;
	flex-shrink: 0;
}
.guide_box li h3,.guide_box li h3::before{transition: all .3s;}
@media (any-hover: hover){
	.guide_box li a:hover h3{color: #cc4640;}
	.guide_box li a:hover h3::before{background-image: url("../images/top/guide_btn_icon_on.webp");}
}

/* 地域の皆様へ院長からのご挨拶
------------------------------------------------------------*/
.gretting,.gretting_img .mask{position: relative;}
.gretting_box{
	display: flex;
	align-items: center;
}
.gretting_img{
	max-width: 100%;
	width: 40%;
	flex-shrink: 0;
	position: absolute;
	left: 0;
}
.gretting_box,.gretting_img,.gretting_img .mask,.gretting_img .mask img{height: 790px;}
.gretting_img .mask{border-radius: 0 30px 30px 0;}
.gretting_img .mask img{object-fit: cover;}
.gretting_img > p{
	position: absolute;
	right: 0;
	bottom: 0;
}
.gretting_img > p img{border-radius: 30px 0 30px 0;}
.gretting_con{padding-left: 44%;}
.bnr_box{
	max-width: 1225px;
	width: 100%;
	margin: 0 auto;
}
.bnr_box > li{width: 49.5%;}

/* 1025px以下から
------------------------------------------------------------*/
@media only screen and (max-width:1025px){
	
	/* ファーストビュー
	--------------------------------------*/
	#first_view::before{height: 150px;}
	
	/* メインエリア
	--------------------------------------*/
	#main_area .splide__track{border-radius: 20px;}
	#main_area .splide__slide,#main_area .splide__slide img{height: 550px;}
	.main_copy p{margin-bottom: 40px;}
	.main_copy p img{width: 400px;}
	.main_copy ul li:not(:last-child){margin-right: 15px;}
	.main_copy ul li img{width: 140px;}
	
	/* お知らせ
	--------------------------------------*/
	.news_title{width: 200px;}
	.news_con{width: calc(100% - 200px);}
	.news_con > li a{
		padding: 30px 20px;
		background-image: none;
	}
	.news_con > li.fixed_news a{border-radius: 8px;}
	.news_con > li a p{width: 90px;}
	.news_con > li a h3{width: calc(100% - 90px);}


	/* 診療のご案内
	--------------------------------------*/
	.guide_box ul.flex_start{justify-content: space-between;}
	.guide_box li{
		width: 32%;
		margin: 0;
	}
	.guide_box li:not(:nth-last-child(-n+3)){margin-bottom: 15px;}
	.guide_box li a{
		padding: 25px 15px 28px;
		border-radius: 10px;
	}
	.guide_box li div{
		padding-bottom: 25px;
		margin-bottom: 20px;
	}
	.guide_box li div img{width: 90px;}
	.guide_box li h3::before{width: 25px;}
	
	/* 地域の皆様へ院長からのご挨拶
	--------------------------------------*/
	.gretting_box,.gretting_img,.gretting_img .mask,.gretting_img .mask img{height: 550px;}
	.gretting_img .mask{border-radius: 0 20px 20px 0;}
	.gretting_img > p img{
		width: 230px;
		border-radius: 20px 0 20px 0;
	}
}

/* 750px以下から
------------------------------------------------------------*/
@media only screen and (max-width:750px){
	
	/* ファーストビュー
	--------------------------------------*/
	#first_view::before{height: 150px;}
	
	/* メインエリア
	--------------------------------------*/
	#main_area .splide__slide,#main_area .splide__slide img{height: 530px;}
	.main_copy{
		left: 15px;
		bottom: 50px;
	}
	.main_copy p{margin-bottom: 25px;}
	.main_copy p img{
		max-width: 330px;
		width: 88%;
	}
	.main_copy ul li:not(:last-child){margin-right: 10px;}
	.main_copy ul li img{width: 110px;}
	
	/* お知らせ
	--------------------------------------*/
	.news_title,.news_con,.news_con > li a p,.news_con > li a h3{width: 100%;}
	.news_title{
		margin-bottom: 40px;
		display: flex;
		align-items: flex-end;
		justify-content: space-between;
	}
	.news_title .title{margin-bottom: 0!important;}
	.news_con > li a{padding: 23px 15px 25px;}
	.news_con > li a p{margin-bottom: 5px;}
	.news_con > li a h3{line-height: 1.3;}

	
	/* 診療のご案内
	--------------------------------------*/
	.guide_box ul{max-width: 240px;}
	.guide_box li{width: 100%;}
	.guide_box li:not(:last-child){margin-bottom: 15px;}
	
	/* 地域の皆様へ院長からのご挨拶
	--------------------------------------*/
	.gretting .title{margin-bottom: 50px;}
	.gretting_box{
		height: inherit;
		flex-wrap: wrap;
	}
	.gretting_img,.gretting_img .mask,.gretting_img .mask img{height: 400px;}
	.gretting_img{
		position: relative;
		margin: 0 auto 35px;
	}
	.gretting_img,.gretting_con{width: 100%;}
	.gretting_img .mask{
		position: static;
		border-radius: 20px;
	}
	.gretting_img .mask img{object-position: center top;}
	.gretting_img > p img{width: 200px;}
	.gretting_con{padding-left: 0;}
	.bnr_box > li{width: 100%;}
	.bnr_box > li:not(:last-child){margin-bottom: 15px;}
	.bnr_box > li img{
		max-width: 450px;
		width: 100%;
		display: block;
		margin: 0 auto;
	}
	
}