* {
	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;
}

.pc-none {
	display: none;
}

.sp-none {
	display: block;
}

.service {
	padding-top: min(7.34375vw, 94px);
}

.service-semi__item {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.service-semi__item:nth-child(n+2) {
	margin-top: min(9.375vw, 120px);
}

.service-semi__item:nth-child(even) {
	flex-direction: row-reverse;
}

.service-semi__content {
	width: calc(50% - min(1.5625vw, 20px));
}

.service-semi__item:nth-child(even) .service-semi__content {
	padding-left: min(7.8125vw, 100px);
}

.service-semi__label {
	position: relative;
}

.service-semi__label-icon {
	display: flex;
	position: absolute;
	top: 50%;
	left: 0;
	align-items: center;
	justify-content: center;
	width: min(4.53125vw, 58px);
	height: min(4.53125vw, 58px);
	transform: translateY(-50%);
	background: #D9CFB4;
	content: "";
	color: #ffffff;
	font-weight: 400;
	font-size: min(1.25vw, 16px);
	line-height: 0.9;
}

.service-semi__label-text {
	padding-left: min(6.640625vw, 85px);
	font-size: min(1.875vw, 24px);
}

.service-semi__title {
	margin-top: min(5.46875vw, 70px);
	font-weight: 400;
	font-size: min(2.5vw, 32px);
	line-height: 1.5;
}

.service-semi__text {
	margin: min(3.125vw, 40px) 0;
	font-size: min(1.25vw, 16px);
	line-height: 2.5;
}

.service-semi__plan {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: min(32.03125vw, 410px);
	margin-top: min(0.625vw, 8px);
}

.service-semi__plan-text {
	font-size: min(1.015625vw, 13px);
	letter-spacing: 0.07em;
}

.service-semi__img {
	position: relative;
	width: calc(50% - min(1.5625vw, 20px));
}

.service-semi__img-wrap {
	position: relative;
	width: 100%;
}

.service-semi__img-wrap img {
	position: absolute;
	top: 50%;
	width: min(48.4375vw, 620px);
	height: min(30vw, 384px);
	transform: translateY(-50%);
}

.service-semi__item:nth-child(even) .service-semi__img img {
	right: 0;
}

.service-semi__item:nth-child(odd) .service-semi__img img {
	left: 0;
}

.service-reservation {
	padding-top: min(10.9375vw, 140px);
	text-align: center;
}

.service-reservation__text {
	display: inline-block;
	font-size: min(1.25vw, 16px);
	line-height: 2;
}

.service-reservation__text span {
	text-decoration: underline;
}

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

.pc-none {
	display: block;
}

.sp-none {
	display: none;
}

.service {
	padding-top: min(17.9487179487vw, 70px);
}

.service-semi__item {
	flex-direction: column;
}

.service-semi__item:nth-child(n+2) {
	margin-top: min(20.5128205128vw, 80px);
}

.service-semi__item:nth-child(even) {
	flex-direction: column;
}

.service-semi__content {
	width: 100%;
}

.service-semi__item:nth-child(even) .service-semi__content {
	padding-left: 0;
}

.service-semi__label-icon {
	width: min(10.7692307692vw, 42px);
	height: min(10.7692307692vw, 42px);
	font-size: min(3.0769230769vw, 12px);
}

.service-semi__label-text {
	padding-left: min(16.4102564103vw, 64px);
	font-size: min(5.1282051282vw, 20px);
}

.service-semi__title {
	margin-top: min(14.358974359vw, 56px);
	font-size: min(6.1538461538vw, 24px);
}

.service-semi__text {
	margin: min(10.2564102564vw, 40px) 0;
	font-size: min(3.5897435897vw, 14px);
}

.service-semi__plan {
	width: min(84.6153846154vw, 330px);
	margin-top: min(2.0512820513vw, 8px);
}

.service-semi__plan-text {
	font-size: min(3.0769230769vw, 12px);
}

.service-semi__img {
	width: min(100vw, 390px);
	margin-top: min(10.2564102564vw, 40px);
}

.service-semi__img-wrap {
	padding-top: 70%;
}

.service-semi__img-wrap img {
	-o-object-fit: cover;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.service-reservation {
	padding-top: min(17.9487179487vw, 70px);
}

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

}

