@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=LINE+Seed+JP:wght@400;700&display=swap');
html{
	font-size: 16px;
}
body{
	font-size: clamp(1rem, 0.9386rem + 0.2618vw, 1.125rem);
    margin: 0;
	font-family: "Helvetica Neue",
    Arial,
	"LINE Seed JP",
    "Hiragino Kaku Gothic ProN",
    "Hiragino Sans",
    "Noto Sans JP",
    sans-serif;
	color: #222;
	font-weight: 400;
}
a{
	text-decoration: none;
}
p{
	margin: 0;
	line-height: 1.5;
}

h1{
	font-weight: 700;
	font-size: clamp(2.5rem, -0.6051rem + 6.469vw, 4rem);
	letter-spacing: 0.05em;
	margin: 0.5em 0;
	text-align: center;
}
h3{
	font-weight: 600;
	font-size: clamp(1rem, 0.9386rem + 0.2618vw, 1.125rem);
	line-height: 1.2;
	margin: 0;
	text-align: left;
}
h3 span{
	background: linear-gradient(transparent 70%, #e6eb8b 70%);
	display: inline-block;
	margin-bottom: .7em;
}
/*--- PC ---*/
@media screen and (min-width:768px){
.sp{
	display: none;
}
}
/*--- SP ---*/
@media screen and (max-width:767px) {
		h1{
	font-size: calc((100vw - 20vh - 5rem) / 10.5);
}
	h3{
		text-align: left;
	}
h3 span{
	display: inline;
	line-height: 1.7;
}
.pc{
	display: none;
}
}

@media screen and (max-width:639px){
	h1{font-size: calc((100vw - 6rem) / 10.5);
}
}
.main{
	width: 100vw;
	height: 100vh;
	display: block;
	margin: 0 auto;
	background-image: url(/img/entrance-bg_pc.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position-y: top;
	background-position-x: 70%;
	position: relative;
}
.contents{
	display: flex;
	justify-content: center;
	align-items: center;
	max-width: calc(100vw - 3rem);
	position: absolute;
	right: 4%;
	top: 15%;
}

.introduction{
	width: fit-content;
	display: flex;
	justify-content: center;
	flex-direction: column;
	gap: 3rem;
	background: rgba(255, 255, 255, 0.85);
	backdrop-filter: blur(6px);
	border-radius: 15px;
  	box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
	padding: 3.5rem 5rem 3rem;
}

.introduction .info{
	display: flex;
	flex-direction: column;
	width: fit-content;
	margin: 0 auto;
	gap: 2rem;
}
.introduction .attribute{
	font-size: 0.875em;
	text-align: left;
	margin-bottom: 0.5rem;
	border: #333 solid 1px;
	background-color: #FFF;
	width: fit-content;
	margin: 0 auto;
	padding: 4px 8px 4px 12px;
	vertical-align: middle;
}
.introduction .tel{
	display: flex;
	gap: .25rem 1.5rem;
	font-size: 1.5rem;
	font-weight: 600;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
}
.introduction .tel p{
	line-height: 1.25;
}
.introduction .tel a{
	color: #3056a5;
}
.introduction .tel a:hover{
	opacity: 0.8;
}

@media screen and (max-width:1139px) {
.introduction .info{
	gap: 1rem;
}
.main{
	background-position-y: 20%;
	background-position-x: left;
	background-size: cover;
	background-image: url(/img/entrance-bg_sp.jpg);
	background-repeat: no-repeat;
}
.contents{
	width: fit-content;
	max-width: fit-content;
	right: 3vw;
	top: 15%;
}
.introduction{
	padding: clamp(2rem, 1.4636rem + 2.8605vw, 3.5rem) clamp(1.5rem, -3.6752rem + 10.7817vw, 4rem) clamp(1.7rem, 1.2352rem + 2.4791vw, 3rem);
	max-width: clamp(18rem, 8.3456rem + 51.4899vw, 45rem);
	/* h3の文字数とpaddingで調整 */
	gap: 1rem;
}
}

@media screen and (max-width:767px){
	.main{
		max-height: 100vh;
	}
	.contents{
		max-width: calc(100% - 24vh);
		top:22%;
	}
	.introduction{
	padding: 1.5rem 1.75rem;
}
.main{
	background-position-y: 20%;
	background-size: cover;
}
}
@media screen and (max-width:639px){
.contents{
		min-width: calc(100vw - 3rem);
		max-width:  unset;
		width:  calc(100vw - 3rem);
		top:34%;
		right: 50%;
		transform: translateX(50%);
	}
		.introduction{
		max-width: unset;
}
}