@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Noto+Serif:wght@400;700&display=swap');

a {
	transition: all .3s;
}

a:hover {
	opacity: 0.7;
}

@media screen and (min-width:1201px){
	a[href*="tel:"] {
		pointer-events: none;
		cursor: default;
		text-decoration: none;
	}
}

/*-------------------- header --------------------*/

header {
	width: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 90;
	background-color: #FFFFFF;
	transform: translateY(-100%);
	transition: 0.5s;
	opacity: 0;
}

header.display {
	transform: translateY(0);
	opacity: 1;
}

header .header-top {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
}

header .header-top-left {
	width: 50%;
    min-width: calc(100% - 620px);
	display: flex;
	align-items: center;
	padding-left: 60px;
}

header .header-top-left .company-name {
	display: block;
	width: 277px;
}

header .header-top-left .company-name img {
	width: 100%;
	height: auto;
}

header .header-top-left .company-access {
	font-size:min(0.9vw, 14px);
	line-height:24px;
	font-weight:500;
	font-family:YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	letter-spacing: 0.42px;
	color: #080402;
	margin-left: 50px;
}

header .header-top-right {
	width:50%;
	max-width:620px;
	display: flex;
}

header .header-top-right .contact-link {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	width: 50%;
	height: 82px;
	background: #d38c2b;
	font-size:min(1.18vw, 18px);
	line-height:26px;
	font-weight:400;
	font-family:ten-mincho, serif;
	letter-spacing: 0.54px;
	color: #FDFAFA;
}

header .header-top-right .tel-link {
	position: relative;
	display: flex;
	flex-flow: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	width:50%;
	height: 82px;
	padding-left: 62px;
	background: #991a1b;
	font-size:min(1.45vw, 24px);
	line-height:40px;
	font-weight:500;
	font-family:YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	letter-spacing: 4.8px;
	color: #FFFFFF;
}

header .header-top-right .tel-link::before {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 22px;
	content: "";
	display: block;
	width: 37px;
	height: 37px;
	margin: auto 0;
	background-image: url(../images/material/call_header.png);
	background-size: contain;
	background-position: center;
}

header .header-top-right .tel-link .mincho {
	font-size:min(1.18vw, 18px);
	line-height:26px;
	font-weight:400;
	font-family:ten-mincho, serif;
	letter-spacing: 0.54px;
	color: #FDFAFA;
}

header .header-bottom {
	background-color: #FFFFFF;
}
header .header-bottom .logo-sp{
	position: absolute;
	top: 17px;
	left: 25px;
	display: none;
	width: 230px;
	height: 59px;
}
header .header-bottom .logo-sp img{
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
}

header .header-menu {
	display: flex;
	width: 100%;
	height: 95px;
	padding: 0 60px;
	align-items: center;
	justify-content: space-between;
}

header .header-menu .header-menu-content {
	position: relative;
	display: block;
	width: 220px;
	margin-top: 12px;
	text-align: center;
	font-weight:400;
	font-size:min(1.18vw, 18px);
	line-height:60px;
	font-family:ten-mincho, serif;
	letter-spacing: 0.54px;
	color: #080402;
	border-style: solid;
	border-width: 1px 1px 0 1px;
	border-color: #FFFFFF;
	border-radius: 5px 5px 0 0;
}

header .header-menu .header-menu-content.pulldown:hover{
	border-color: #DE4833;
}

header .header-menu .header-menu-content.pulldown .sub-menu{
	position: absolute;
	bottom: 0;
	left: -1px;
	width: calc(100% + 2px);
	height: 0;
	overflow: hidden;
	opacity: 0;
	transform: translateY(80%);
	transition: 0.5s;
	z-index: 95;
}

header .header-menu .header-menu-content.pulldown .sub-menu li {
	font-weight:400;
	font-size:min(1.16vw, 16px);
	line-height:24px;
	font-family:ten-mincho, serif;
	letter-spacing: 0.48px;
	color: #080402;
	transition: 0.5s;
}

header .header-menu .header-menu-content.pulldown .sub-menu li >a{
	display: block;
	padding: 14px 0;
}

header .header-menu .header-menu-content.pulldown .sub-menu li:hover{
	background-color: rgba(224, 71, 43, 0.3);
}

header .header-menu .header-menu-content.pulldown>a {
	position: relative;
	padding-right: 24px;
}

header .header-menu .header-menu-content>a{
	transition: 0.5s;
}

header .header-menu .header-menu-content>a:hover{
	opacity: 0.8;
}

header .header-menu .header-menu-content.pulldown>a::after {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	content: "";
	display: block;
	width: 14px;
	height: 7px;
	background-image: url(../images/material/angle.png);
	background-size: contain;
	background-repeat: no-repeat;
	margin: auto 0;
}

header .menu-button{
	position: absolute;
	top: 30px;
	right: 25px;
	display: none;
	width: 22px;
	height: 18px;
	cursor: pointer;
}
header .menu-button.open .line{
	display: none;
}
header .menu-button.open::before, header .menu-button.open::after{
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto 0;
	transition: 0.5s;
}
header .menu-button.open::before{
	transform: rotate(45deg);
}
header .menu-button.open::after{
	transform: rotate(135deg);
}
header .menu-button::before, header .menu-button::after{
	position: relative;
	content: "";
	display: block;
	width: 100%;
	height: 3px;
	background-color: #000;
}
header .menu-button .line{
	width: 100%;
	height: 3px;
	margin: 4.5px 0;
	background-color: #000;
}

@media screen and (min-width:1201px){
	header .header-menu .header-menu-content.pulldown:hover .sub-menu {
		height: auto;
		margin: 0 auto;
		text-align: center;
		background-color: #FFF;
		border-style: solid;
		border-width: 0 1px 1px;
		border-color: #DE4833;
		border-radius: 0 0 5px 5px;
		transform: translateY(calc(100% - 14px));
		opacity: 1;
	}
}

@media screen and (max-width:1200px){
	body {
		margin-top:  69px;
	}
	header {
		background-color: transparent;
	}
	header .header-top{
		display: none;
	}
	header .menu-button, header .header-bottom .logo-sp{
		display: block;
		z-index: 99;
	}
	header .header-bottom .logo-sp{
		left: 15px;
	}
	header .header-bottom .logo-sp img{
		width: 70%;
		height: 70%;
	}
	header .header-bottom{
		height: 70px;
	}
	
	header .header-menu {
		flex-flow: column;
		height: 0;
		padding: 0;
		overflow: hidden;
		align-items: flex-start;
		justify-content: flex-start;
		transition: 0.5s;
		background-color: rgba(255, 255, 255, 0.9);
	}
	header .menu-button.open + .header-menu{
		height: 100vh;
		padding-top: 80px;
	} 
	
	header .header-menu .header-menu-content {
		width: 100%;
		padding: 0;
		margin-top: 0;
		text-align: left;
		font-size: 18px;
		border-width: 0 0 1px 0;
		border-color: silver;
		border-radius: 0;
	}
	header .header-menu .header-menu-content.pulldown:hover{
		border-color: silver;
	}
	
	header .header-menu .header-menu-content.pulldown .sub-menu{
		position: relative;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 0;
		overflow: hidden;
		opacity: 0;
		transform: translateY(0);
		transition: 0.5s;
	}
	
	header .header-menu .header-menu-content.pulldown.open .sub-menu {
		height: auto;
		margin: 0;
		text-align: left;
		border:0 ;
		border-radius: 0;
		transform: translateY(0);
		opacity: 1;
	}
	
	header .header-menu .header-menu-content.pulldown .sub-menu li {
		font: 400 16px/24px ten-mincho, serif;
		letter-spacing: 0.48px;
		border-top: 1px solid silver;
		color: #080402;
		transition: 0.5s;
	}
	header .header-menu .header-menu-content.pulldown .sub-menu li>a{
		display: block;
		padding: 14px 30px;
	} 
	header .header-menu .header-menu-content.pulldown .sub-menu li br{
		display: none;
	}
	header .header-menu .header-menu-content.pulldown:hover .sub-menu li:hover{
		background-color: rgba(224, 71, 43, 0.3);
	}
	
	header .header-menu .header-menu-content>a {
		position: relative;
		display: block;
		padding:0 15px;
	}
	
	header .header-menu .header-menu-content.pulldown>a::after {
		position: absolute;
		top: 0;
		right: 15px;
		bottom: 0;
		content: "";
		display: block;
		width: 14px;
		height: 7px;
		background-image: url(../images/material/angle.png);
		background-size: contain;
		background-repeat: no-repeat;
		margin: auto 0;
	}
}

/*-------------------- footer --------------------*/

footer {
	padding: 70px 0 20px;
	text-align: center;
	background: linear-gradient(180deg, #52596C 0%, #52596C 100%);
}

.footer-top {
	margin-bottom: 65px;
}

.footer-top .share-link {
	font: 400 18px/22px 'Noto Serif', serif;
	letter-spacing: 1.8px;
	color: #FFFFFF;
	margin-bottom: 15px;
}

.footer-top .link-icon-wrap {
	display: flex;
	justify-content: center;
}

.footer-top .link-icon {
	display: block;
	width: 35px;
	height: 35px;
}

.footer-top .link-icon img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: center;
}

.footer-top .link-icon:not(:last-child) {
	margin-right: 33px;
}

.footer-bottom .privacypolicy-link {
	display: block;
	font: 400 16px 'Noto Sans JP', sans-serif;
	color: #FFFFFF;
	margin-bottom: 15px;
}

.footer-bottom .copyright {
	font: 400 18px/22px 'Noto Serif', serif;
	letter-spacing: 1.8px;
	color: #FFFFFF;
}

@media screen and (max-width:1200px){
	footer {
		padding: 40px 25px 15px;
	}
	
	.footer-top {
		margin-bottom: 40px;
	}
	
	.footer-top .share-link {
		font: 400 16px/22px 'Noto Serif', serif;
		letter-spacing: 0.45px;
		margin-bottom: 12px;
	}
	
	
	.footer-top .link-icon {
		width: 25px;
		height: 25px;
	}
	
	.footer-top .link-icon:not(:last-child) {
		margin-right: 25px;
	}
	
	.footer-bottom .privacypolicy-link {
		font: 400 14px 'Noto Sans JP', sans-serif;
		margin-bottom: 12px;
	}
	
	.footer-bottom .copyright {
		font: 400 12px/22px 'Noto Serif', serif;
		letter-spacing: 0.22px;
		color: #FFFFFF;
	}
}

/*-------------------- common-title --------------------*/

.common-title-wrap {
	position: relative;
	width: 100%;
	height: 220px;
	margin-top: 174px;
}
/* add 20250427 */
.common-title-wrap-bg {
	background-color: #be870e4a;
    width: 100%;
    height: 100%;
}

.common-title {
	position: absolute;
	top: 0;
	bottom: 0;
	width: 100%;
	height: 50px;
	margin:  auto 0;
	font: bold 34px/50px 'Noto Serif', serif;
	letter-spacing: 3.4px;
	text-align: center;
	color: #FFFFFF;
	z-index: 5;
	text-shadow: 2px 2px 2px #344f38; /* add 20250427 */
}

.common-title-wrap img {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	z-index: 0;
}

@media screen and (max-width:1200px) {
	.common-title {
		font: bold 24px/50px 'Noto Serif', serif;
		letter-spacing: 2.4px;
	}
	.common-title-wrap {
		margin-top: 0;
		height: 150px;
	}
}

/*-------------------- rehabilitation page --------------------*/

.rehabilitation-title-wrap {
	position: relative;
	margin-top: 174px;
	width: 100%;
	height: 655px;
	background-size: cover;
}

.rehabilitation-title-wrap img {
	position: relative;
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	z-index: 0;
}

.rehabilitation-title {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 140px;
	display: inline-block;
	width: auto;
	height: 115px;
	margin: auto 0;
	font: 400 50px/115px ten-mincho, serif;
	color: #080402;
	padding: 0 35px;
	background: #FFF;
	letter-spacing: 5px;
	z-index: 5;
}

.rehabilitation-title .orange {
	color: #E0472B;
}

@media screen and (max-width:1200px){
	.rehabilitation-title-wrap {
		margin-top: 0;
		height: 220px;
	}
	
	.rehabilitation-title {
		top: 140px;
		right: 0;
		left: 0;
		width: 320px;
		text-align: center;
		height: 40px;
		margin: 0 auto;
		font: 400 16px/40px ten-mincho, serif;
		padding: 0 10px;
		letter-spacing: 2.4px;
	}
	
}

.tel-button {
	position: relative;
	display:block;
	width: 480px;
	height: 90px;
	padding: 0 110px;
	text-align: right;
	margin: 0 auto;
	background-color: #e08a09;
	font: bold 24px/90px YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	letter-spacing: 2.4px;
	border-radius: 5px;
	color: #FFFFFF;
}

.tel-button::before {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 118px;
	content: "";
	display: block;
	width: 30px;
	height: 28px;
	margin: auto 0;
	background-image: url(../images/material/call_icon.png);
	background-size: contain;
	background-repeat: no-repeat;
}

@media screen and (max-width:1200px){
	.tel-button {
		position: relative;
		width: 100%;
		max-width: 260px;
		height: 60px;
		padding: 0 30px;
		font: bold 20px/60px YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
		letter-spacing: 0.84px;
	}
	.tel-button::before {
		left: 30px;
	}
}

h2 {
	font-family: 'Times New Roman', serif;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}