* {
	box-sizing: border-box;
}

html,
body {
	margin: 0;
	padding: 0;
}

body {
	font-family: YuGothic, "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, "Questrial", "Noto Sans JP", sans-serif;
}

ul,
ol {
	margin: 0;
	padding: 0;
	list-style: none;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
	margin: 0;
	padding: 0;
	color: #3E3A39;
}

img {
	display: block;
	width: 100%;
	height: auto;
}

picture {
	display: block;
	width: 100%;
	height: auto;
}

figure {
	margin: 0;
}

a {
	color: #3E3A39;
	text-decoration: none;
	transition: 0.3s;
}

a:hover {
	cursor: pointer;
	opacity: 0.8;
}

.pc-none {
	display: none;
}

.sp-none {
	display: block;
}

.top-fv {
	display: flex;
	position: relative;
	align-items: flex-start;
	justify-content: center;
	width: 100%;
	max-width: 1920px;
	height: min(44.4444444444vw, 640px);
	margin: 0 auto;
	padding: min(5.5555555556vw, 80px) min(8.3333333333vw, 120px) 0 min(8.3333333333vw, 120px);
}

.top-fv__bg {
	z-index: -1;
	position: absolute;
	top: min(13.8888888889vw, 200px);
	left: min(8.3333333333vw, 120px);
	width: min(52.0833333333vw, 750px);
	height: min(25vw, 360px);
	content: "";
}

.top-fv__bg img {
	-o-object-fit: contain;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.top-fv__left {
	width: 60%;
	margin-left: min(8.3333333333vw, 120px);
}

.top-fv__right {
	width: 40%;
}

.top-fv__title {
	margin-top: min(2.0833333333vw, 30px);
	font-weight: 400;
	font-size: min(2.7777777778vw, 40px);
	line-height: 1.5;
}

.top-fv__wrap {
	-moz-column-gap: min(2.0833333333vw, 30px);
	display: flex;
	column-gap: min(2.0833333333vw, 30px);
	align-items: center;
	justify-content: center;
	margin-top: min(2.0833333333vw, 30px);
}

.top-fv__text {
	color: #34bdf0;
	font-size: min(1.5277777778vw, 22px);
}

.top-fv__btn {
	position: relative;
	padding: min(0.8333333333vw, 12px) min(5.2777777778vw, 76px) min(0.8333333333vw, 12px) min(2.7777777778vw, 40px);
	border-radius: 9999px;
	background: #34bdf0;
	color: #ffffff;
	font-size: min(1.3888888889vw, 20px);
}

.top-fv__btn::after {
	-webkit-clip-path: polygon(0 0, 0% 100%, 100% 50%);
	position: absolute;
	top: 50%;
	right: min(1.1111111111vw, 16px);
	width: min(1.1111111111vw, 16px);
	height: min(0.6944444444vw, 10px);
	transform: translateY(-50%);
	background: #ffffff;
	content: "";
	clip-path: polygon(0 0, 0% 100%, 100% 50%);
}

.top-fv__img {
	width: 100%;
	height: min(30.5555555556vw, 440px);
}

.top-body {
	padding-bottom: min(10.4166666667vw, 150px);
}

.top-swiper,
.top-swiper-sp {
	margin-bottom: min(4.1666666667vw, 60px);
}

.top-swiper__pagination,
.top-swiper__pagination-sp {
	text-align: center;
}

.top-swiper__pagination .swiper-pagination-bullet-active,
.top-swiper__pagination-sp .swiper-pagination-bullet-active {
	background: #FAE200;
}

.top-news {
	position: relative;
	padding: 0 0 min(10.4166666667vw, 150px) 0;
}

.top-news__wrap {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	width: 100%;
	max-width: 1320px;
	margin: min(6.9444444444vw, 100px) auto 0 auto;
}

.top-news__title,
.top-contact__title {
	font-weight: 700;
	font-size: min(1.9444444444vw, 28px);
	text-align: center;
}

.top-news__item:nth-child(n+2) {
	margin-top: min(1.0416666667vw, 15px);
}

.top-news__item-link {
	-moz-column-gap: min(6.25vw, 90px);
	display: flex;
	column-gap: min(6.25vw, 90px);
	align-items: center;
	justify-content: flex-start;
}

.top-news__item-date,
.top-news__item-title {
	font-size: min(1.3888888889vw, 20px);
	line-height: 1.5;
}

.top-news__btn {
	position: relative;
	width: min(14.5833333333vw, 210px);
	padding-bottom: min(0.9722222222vw, 14px);
	color: #34bdf0;
}

.top-news__btn::after {
	-webkit-clip-path: polygon(0 75%, 90% 75%, 90% 0%, 100% 100%, 0% 100%);
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: min(0.8333333333vw, 12px);
	background-color: #34bdf0;
	content: "";
	clip-path: polygon(0 75%, 90% 75%, 90% 0%, 100% 100%, 0% 100%);
}

.top-news__btn-link {
	color: #34bdf0;
	font-weight: 700;
	font-size: min(0.9722222222vw, 14px);
}

.top-news__bg {
	z-index: -1;
	position: absolute;
	top: 0;
	left: 60%;
	width: min(5vw, 72px);
	height: min(3.4722222222vw, 50px);
	transform: translate(-50%, -50%);
	content: "";
}

.top-contact {
	position: relative;
	padding-bottom: min(5.5555555556vw, 80px);
}

.top-contact__wrap {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	width: min(87.5vw, 1260px);
	margin-top: min(5.5555555556vw, 80px);
}

.top-contact__sub-wrap {
	-moz-column-gap: min(9.0277777778vw, 130px);
	display: flex;
	column-gap: min(9.0277777778vw, 130px);
	align-items: flex-start;
	justify-content: space-between;
}

.top-contact__tel-group,
.top-contact__btn {
	margin-top: min(4.1666666667vw, 60px);
}

.top-contact__tel-text {
	font-weight: 700;
	font-size: min(1.3888888889vw, 20px);
}

.top-contact__tel-text.--large {
	display: inline-block;
	width: 100%;
	margin-top: min(0.6944444444vw, 10px);
	font-weight: 400;
	font-size: min(2.3611111111vw, 34px);
}

.top-contact__tel-text.--small {
	margin-top: min(0.6944444444vw, 10px);
	font-weight: 400;
	font-size: min(1.1111111111vw, 16px);
}

.top-contact__btn-text {
	font-weight: 700;
	font-size: min(1.3888888889vw, 20px);
}

.top-contact__btn-link {
	display: inline-block;
	position: relative;
	margin-top: min(1.1111111111vw, 16px);
	padding: min(1.3888888889vw, 20px) min(4.8611111111vw, 70px) min(1.3888888889vw, 20px) min(1.7361111111vw, 25px);
	border-radius: 9999px;
	background: #34bdf0;
	color: #ffffff;
	font-weight: 700;
	font-size: min(1.25vw, 18px);
	transition: all 0.5s;
}

.top-contact__btn-link::before,
.top-contact__btn-link::after {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	border-radius: 9999px;
	content: "";
}

.top-contact__btn-link::before {
	right: min(0.8333333333vw, 12px);
	width: min(2.5vw, 36px);
	height: min(2.5vw, 36px);
	background: #ffffff;
}

.top-contact__btn-link::after {
	right: min(1.8055555556vw, 26px);
	width: min(0.5555555556vw, 8px);
	height: min(0.5555555556vw, 8px);
	background: #C7E8FA;
}

.top-contact__btn-link:hover {
	background: #C7E8FA;
	color: #34bdf0;
}

.top-contact__img {
	width: min(26.7361111111vw, 385px);
}

.top-contact__bg {
	z-index: -1;
	position: absolute;
	top: 0;
	left: 10%;
	width: min(5vw, 72px);
	height: min(3.4722222222vw, 50px);
	transform: translate(-50%, -50%);
	content: "";
}

@media screen and (min-width: 768px) {

.top-contact__tel-text.--large {
	pointer-events: none;
}

}

@media screen and (max-width: 767px) {

.pc-none {
	display: block;
}

.sp-none {
	display: none;
}

.top-fv {
	flex-direction: column-reverse;
	max-width: 332px;
	height: min(128.2051282051vw, 500px);
	margin-top: min(17.9487179487vw, 70px);
	padding: 0 min(3.0769230769vw, 12px);
}

.top-fv__bg {
	top: 0;
	left: 50%;
	width: min(77.6923076923vw, 303px);
	height: min(100.5128205128vw, 392px);
	transform: translateX(-50%);
}

.top-fv__left {
	width: 100%;
	margin-left: 0;
}

.top-fv__right {
	width: 100%;
	margin-top: min(7.6923076923vw, 30px);
}

.top-fv__title {
	margin: min(7.6923076923vw, 30px) auto 0 auto;
	font-size: min(5.641025641vw, 22px);
}

.top-fv__wrap {
	-moz-column-gap: 0;
	column-gap: 0;
	justify-content: space-between;
	margin-top: min(5.1282051282vw, 20px);
}

.top-fv__text {
	font-size: min(3.5897435897vw, 14px);
}

.top-fv__btn {
	padding: min(2.0512820513vw, 8px) min(8.2051282051vw, 32px) min(2.0512820513vw, 8px) min(4.1025641026vw, 16px);
	font-size: min(3.5897435897vw, 14px);
}

.top-fv__btn::after {
	right: min(2.0512820513vw, 8px);
	width: min(3.0769230769vw, 12px);
	height: min(2.0512820513vw, 8px);
}

.top-fv__img {
	width: min(85.1282051282vw, 332px);
	height: min(56.4102564103vw, 220px);
	margin: 0 auto;
}

.top-body {
	padding-bottom: min(11.5384615385vw, 45px);
}

.top-swiper,
.top-swiper-sp {
	margin-bottom: min(7.6923076923vw, 30px);
}

.top-news {
	padding: 0 0 min(20.5128205128vw, 80px) 0;
}

.top-news__wrap {
	flex-direction: column;
	align-items: center;
	justify-content: center;
	margin: min(12.8205128205vw, 50px) auto 0 auto;
}

.top-news__title,
.top-contact__title {
	font-size: min(5.641025641vw, 22px);
}

.top-news__item:nth-child(n+2) {
	margin-top: min(3.8461538462vw, 15px);
}

.top-news__item-link {
	-moz-column-gap: min(7.6923076923vw, 30px);
	column-gap: min(7.6923076923vw, 30px);
}

.top-news__item-date,
.top-news__item-title {
	font-size: min(4.1025641026vw, 16px);
}

.top-news__btn {
	width: min(46.1538461538vw, 180px);
	margin-top: min(11.2820512821vw, 44px);
}

.top-news__btn::after {
	-webkit-clip-path: polygon(0 75%, 95% 75%, 95% 0%, 100% 100%, 0% 100%);
	height: min(1.5384615385vw, 6px);
	clip-path: polygon(0 75%, 95% 75%, 95% 0%, 100% 100%, 0% 100%);
}

.top-news__btn-link {
	font-size: min(3.5897435897vw, 14px);
}

.top-news__bg {
	left: 70%;
	width: min(10.5128205128vw, 41px);
	height: min(7.6923076923vw, 30px);
}

.top-contact {
	padding-bottom: min(20.5128205128vw, 80px);
}

.top-contact__wrap {
	flex-direction: column;
	align-items: center;
	width: 100%;
	margin-top: 0;
}

.top-contact__sub-wrap {
	flex-direction: column;
	align-items: center;
}

.top-contact__tel-group,
.top-contact__btn {
	margin-top: min(10.2564102564vw, 40px);
}

.top-contact__tel-text {
	font-size: min(3.5897435897vw, 14px);
	text-align: center;
}

.top-contact__tel-text.--large {
	margin-top: min(3.8461538462vw, 15px);
	font-size: min(6.1538461538vw, 24px);
}

.top-contact__tel-text.--small {
	margin-top: min(3.8461538462vw, 15px);
	font-size: min(3.5897435897vw, 14px);
}

.top-contact__btn-text {
	font-size: min(3.5897435897vw, 14px);
	text-align: center;
}

.top-contact__btn-link {
	margin-top: min(4.1025641026vw, 16px);
	padding: min(3.0769230769vw, 12px) min(13.5897435897vw, 53px) min(3.0769230769vw, 12px) min(4.6153846154vw, 18px);
	font-size: min(4.1025641026vw, 16px);
}

.top-contact__btn-link::before {
	right: min(3.0769230769vw, 12px);
	width: min(6.1538461538vw, 24px);
	height: min(6.1538461538vw, 24px);
}

.top-contact__btn-link::after {
	right: min(5.3846153846vw, 21px);
	width: min(1.5384615385vw, 6px);
	height: min(1.5384615385vw, 6px);
}

.top-contact__img {
	width: min(74.358974359vw, 290px);
	margin-top: min(7.6923076923vw, 30px);
}

.top-contact__bg {
	display: none;
}

}

