@charset "utf-8";

.inner1440 {
	width: 95%;
	max-width: 1440px;
	margin: 0 auto;
}

.inner940 {
	width: 95%;
	max-width: 940px;
	margin: 0 auto;
}

header .logo {
	position: fixed;
	top: 26px;
	left: 56px;
	z-index: 2;
}

@media screen and (max-width: 767px) {
	header .logo {
		position: fixed;
		top: 15px;
		left: 15px;
		width: 160px;
	}
}

header .inquiry-btn {
	position: fixed;
	top: 21px;
	right: 56px;
	height: 64px;
	border-radius: 32px;
	width: 260px;
	background-color: #B8183F;
	z-index: 2;
	display:flex;
	justify-content: center;
	align-items:center;
}

@media screen and (max-width: 767px) {
	header .inquiry-btn {
		top: 10px;
		right: 10px;
		width: 168px;
		height: 36px;
		border-radius: 18px;
	}
}

header .inquiry-btn:hover {
	background-color: #fff;
	border: 1px solid #B8183F;
}

header .inquiry-btn p {
	position: relative;
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 18px;
	line-height: 1.5em;
	letter-spacing: 0.05em;
	text-align: center;
	color: #fff;
	padding-right: 15px;
}

@media screen and (max-width: 767px) {
	header .inquiry-btn p {
		font-size: 12px;
	}
}

@media screen and (max-width: 767px) {
	header .inquiry-btn p span {
		padding-bottom: 2px;
		padding-left: 12px;
	}
}

header .inquiry-btn:hover p {
	color: #B8183F;
}

header .inquiry-btn::after {
	content: "";
	position: absolute;
	right: 18px;
	top: 0;
	bottom: 0;
	margin: auto 0;
	width: 9px;
	height: 9px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	transform: rotate(45deg);
}

@media screen and (max-width: 767px) {
	header .inquiry-btn::after {
		right: 10px;
		width: 6px;
		height: 6px;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
	}
}

header .inquiry-btn:hover::after {
	border-top: 3px solid #B8183F;
	border-right: 3px solid #B8183F;
}

/* 1 */
#first-view {
	background-image: url(./common/img/03.poster.jpg);
	background-repeat: no-repeat;
	background-size: 100% auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding-top: 110px;
	padding-bottom: 120px;
}

@media screen and (max-width: 767px) {
	#first-view {
		background-image: url(./common/img/03.poster-sp.jpg);
		padding-top: 17vw;
		padding-bottom: 40px;
	}
}

#first-view .text1 {
	margin-bottom: 65px;
	margin-left: auto;
	margin-right: auto;
	display: block;
	width: 88vw;
	max-width: 1155px;
	margin-bottom: calc(6500vw / 1920);
}

#first-view .scroll {
	font-family: Roboto Condensed;
	font-weight: normal;
	font-size: 16px;
	letter-spacing: 0.1em;
	line-height: 62px;
	color: #fff;
	writing-mode: vertical-lr;
	transform: rotate(180deg);
	margin-right: auto;
	padding-right: 35px;
	margin-bottom: calc(67500vw / 1920);
	position: relative;
}

@media screen and (max-width: 940px) {
	#first-view .scroll {
		opacity: 0;
	}
}

@media screen and (max-width: 767px) {
	#first-view .scroll {
		margin-bottom: calc(8000vw / 375);
	}
}

#first-view .scroll:before {
	content: "";
	position: absolute;
	bottom: 62px;
	left: 32px;
	height: 48px;
	border-left: 1px solid white;
}

#first-view h3 {
	font-family: "Noto Sans JP";
	font-weight: 900;
	font-size: 70px;
	letter-spacing: 0.02em;
	text-align: center;
	line-height: 1.25em;
	color: #b8183f;
	text-shadow: 0px 0px 10px #fff;
	margin-bottom: 50px;
}

@media screen and (max-width: 940px) {
	#first-view h3 {
		font-size: 7.4vw;
		line-height: 1.5em;
		margin-bottom: 10px;
	}
}

#first-view p {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 24px;
	letter-spacing: 0.05em;
	line-height: 40px;
	text-align: left;
	color: #b8183f;
	margin-top: .7em;
}

@media screen and (max-width: 767px) {
	#first-view p {
		font-size: 14px;
		line-height: 1.8em;
	}
}

/* 2 */
#trouble {
	background-color: #EBECDF;
	padding-top: 70px;
	padding-bottom: 230px;
}

@media screen and (max-width: 767px) {
	#trouble {
		padding-top: 20px;
		padding-bottom: 160px;
	}
}

#trouble .text2 {
	margin-left: auto;
	margin-right: auto;
	display: block;
	margin-top: 20px;
	margin-bottom: -20px;
}

@media screen and (max-width: 1440px) {
	#trouble .text2 {
		width: 88vw;
	}
}

#trouble .boxes .box {
	width: calc(128000% / 1440);
	margin-top: 75px;
	background-color: #fff;
	padding: 40px 60px 35px;
	position: relative;
	border: 4px solid black;
	box-shadow: 6px 6px 0px 0px black;
}

@media screen and (max-width: 767px) {
	#trouble .boxes .box {
		width: 100%;
		margin-top: 40px;
		padding: 20px 30px;
		border: 2px solid black;
		box-shadow: 4px 4px 0px 0px black;
	}
}

#trouble .box:nth-child(even) {
	margin-right: 0;
	margin-left: auto;
}

#trouble .boxes .box h3 {
	font-family: "Noto Sans JP";
	font-weight: 900;
	font-size: 48px;
	letter-spacing: 0.02em;
	line-height: 58px;
	text-align: left;
	color: #000;
	z-index: 1;
	position: relative;
}

@media screen and (max-width: 767px) {
	#trouble .boxes .box h3 {
		font-weight: 900;
		font-size: 20px;
		line-height: 1.5em;
	}
}

@media screen and (max-width: 1440px) {
	#trouble .boxes .box h3 br {
		display: none;
	}
}

#trouble .boxes .box h3:before {
	content: "“";
	position: absolute;
	left: -40px;
	top: -10px;
	font-family: "Noto Sans JP";
	font-weight: 900;
	font-size: 60px;
	letter-spacing: 0.02em;
	line-height: 52px;
	text-align: left;
	color: #b8183f;
}

@media screen and (max-width: 767px) {
	#trouble .boxes .box h3:before {
		left: -18px;
		top: -6px;
		font-size: 24px;
		line-height: 24px;
	}
}

#trouble .boxes .box h3 span {
	font-family: "Noto Sans JP";
	font-weight: 900;
	font-size: 60px;
	letter-spacing: 0.02em;
	line-height: 52px;
	text-align: left;
	color: #b8183f;
	position: relative;
	top: 40px;
}

@media screen and (max-width: 767px) {
	#trouble .boxes .box h3 span {
		top: 22px;
	}
}

@media screen and (max-width: 767px) {
	#trouble .boxes .box h3 span {
		font-size: 24px;
		line-height: 24px;
	}
}

#trouble .boxes .box .example {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 24px;
	letter-spacing: 0.05em;
	line-height: 40px;
	text-align: left;
	color: #000;
	text-decoration: underline;
	text-decoration-thickness: 3px;
	margin-top: 24px;
	margin-bottom: 11px;
}

@media screen and (max-width: 767px) {
	#trouble .boxes .box .example {
		font-size: 16px;
		line-height: 20px;
		text-decoration-thickness: 2px;
		margin-top: 18px;
		margin-bottom: 12px;
	}
}

#trouble .boxes .box .list {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 24px;
	letter-spacing: 0.05em;
	line-height: 42px;
	text-align: left;
	color: #000;
	z-index: 1;
	position: relative;
}

@media screen and (max-width: 767px) {
	#trouble .boxes .box .list {
		font-size: 16px;
		line-height: 24px;
	}
}

#trouble .boxes .box .list span {
	font-family: "Noto Sans JP";
	font-weight: 500;
	font-size: 24px;
	letter-spacing: 0.05em;
	line-height: 30px;
	text-align: left;
	color: #b8183f;
}

@media screen and (max-width: 767px) {
	#trouble .boxes .box .list span {
		font-size: 16px;
		line-height: 30px;
	}
}

#trouble .boxes .box .red {
	display: flex;
	align-items: center;
	z-index: 1;
	position: relative;
	padding-top: 5px;
}

@media screen and (max-width: 767px) {
	#trouble .boxes .box .red img {
		width: 32px;
	}
}

#trouble .boxes .box .red .text {
	font-family: "Noto Sans JP";
	font-weight: 900;
	font-size: 30px;
	letter-spacing: 0.05em;
	line-height: 40px;
	text-align: left;
	color: #b8183f;
	margin-left: 13px;
	margin-top: 20px;
	margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
	#trouble .boxes .box .red .text {
		font-size: 18px;
		line-height: 27px;
		margin-left: 10px;
		margin-top: 15px;
		margin-bottom: 10px;
	}
}

#trouble .boxes .box .watermark {
	position: absolute;
	right: 40px;
	bottom: 30px;
}

@media screen and (max-width: 767px) {
	#trouble .boxes .box .watermark {
		right: 20px;
		bottom: 20px;
		height: 40vw;
	}
}

/* 3 */
#features {
	background-color: #B8183F;
	clip-path: polygon(50% calc(14000vw / 1920), 100% 0, 100% 100%, 0 100%, 0 0);
	padding-top: 240px;
	padding-bottom: 120px;
	margin-top: -140px;
}

@media screen and (max-width: 767px) {
	#features {
		padding-top: 60px;
		padding-bottom: 20px;
		margin-top: -120px;
	}
}

#features .text3 {
	margin-left: auto;
	margin-right: auto;
	display: block;
}

@media screen and (max-width: 767px) {
	#features .text3 {
		width: 88vw;
	}
}

#features h3 {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 32px;
	letter-spacing: 0.02em;
	line-height: 54px;
	text-align: center;
	color: #fff;
	margin-top: 65px;
	margin-bottom: 65px;
}

@media screen and (max-width: 767px) {
	#features h3 {
		font-size: 16px;
		line-height: 1.8em;
		text-align: left;
		margin-top: 35px;
		margin-bottom: 35px;
	}
}

@media screen and (max-width: 1440px) {
	#features h3 br {
		display: none;
	}
}

#features .boxes {
	display: flex;
	justify-content: space-between;
}

@media screen and (max-width: 767px) {
	#features .boxes {
		flex-direction: column;
	}
}

#features .boxes .box {
	width: calc(44000% / 1440);
}

@media screen and (max-width: 767px) {
	#features .boxes .box {
		width: 100%;
	}
}

#features .boxes .box img {
	width: 100%;
}

#features .boxes .box p {
	width: 100%;
	margin-top: 25px;
	font-family: "Noto Sans JP";
	font-weight: 500;
	font-size: 26px;
	letter-spacing: 0.02em;
	line-height: 46px;
	text-align: left;
	color: #fff;
}

@media screen and (max-width: 767px) {
	#features .boxes .box p {
		margin-top: 15px;
		margin-bottom: 30px;
		font-size: 14px;
		line-height: 1.8em;
	}
}


/* 4 */
#base {
	padding-top: 160px;
	padding-bottom: 100px;
}

@media screen and (max-width: 767px) {
	#base {
		padding-top: 40px;
		padding-bottom: 40px;
	}
}

/* 共通 */
.section-title {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 50px;
	line-height: 90px;
	text-align: center;
	position: relative;
}

/* 共通 */
@media screen and (max-width: 1440px) {
	.section-title {
		font-size: 35px;
		line-height: 1.5em;
	}
}

/* 共通 */
@media screen and (max-width: 767px) {
	.section-title {
		font-size: 20px;
	}
}

/* 共通 */
.section-title span {
	position: relative;
	z-index: 1;
}

#base .section-title04 {
	color: #1a1311;
	display: flex;
	justify-content: center;
	align-items: center;
}

#base .section-title04::before {
	content: "BASE";
	position: absolute;
	font-family: Roboto Condensed;
	font-weight: bold;
	font-size: 200px;
	line-height: 90px;
	text-align: center;
	color: #eee;
	white-space: nowrap;
}

@media screen and (max-width: 1440px) {
	#base .section-title04::before {
		font-size: 13vw;
	}

}

#base .map {
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-top: 85px;
	margin-bottom: 35px;
}

@media screen and (max-width: 767px) {
	#base .map {
		margin-top: 30px;
		margin-bottom: 25px;
	}
}

#base .boxes {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

#base .boxes .box {
	width: calc(44000% / 1440);
	margin-top: 13px;
	margin-bottom: 43px;
}

@media screen and (max-width: 1500px) {
	#base .boxes .box {
		width: 48%;
	}
}

@media screen and (max-width: 950px) {
	#base .boxes .box {
		width: 100%;
		margin-top: 10px;
		margin-bottom: 10px;
	}
}

#base .boxes .box h3 {
	width: 100%;
	padding-bottom: 15px;
	font-family: Roboto;
	font-weight: bold;
	font-size: 28px;
	letter-spacing: 0.02em;
	line-height: 32px;
	text-align: left;
	color: #b8183f;
	border-bottom: 2px solid #B8183F;
	margin-bottom: 15px;
}

@media screen and (max-width: 767px) {
	#base .boxes .box h3 {
		padding-bottom: 10px;
		font-size: 13px;
		line-height: 20px;
		margin-bottom: 10px;
	}
}

#base .boxes .box h3 span {
	font-family: Roboto;
	font-weight: bold;
	font-size: 20px;
	letter-spacing: 0.02em;
	line-height: 32px;
	text-align: center;
	color: #fff;
	display: inline-block;
	width: 32px;
	height: 32px;
	border-radius: 16px;
	background-color: #B8183F;
	margin-right: 10px;
}

@media screen and (max-width: 767px) {
	#base .boxes .box h3 span {
		font-size: 13px;
		line-height: 20px;
		width: 20px;
		height: 20px;
		border-radius: 10px;
		margin-right: 5px;
	}
}

#base .boxes .box:first-child h3::after {
	content: "(Headquarters)";
	font-family: Roboto;
	font-weight: bold;
	font-size: 24px;
	letter-spacing: 0.02em;
	line-height: 1.5em;
	text-align: center;
	color: #B8183F;
	display: inline-block;
}

@media screen and (max-width: 767px) {
	#base .boxes .box:first-child h3::after {
		font-size: 11px;
	}
}

#base .boxes .box p {
	width: 100%;
	font-family: Roboto;
	font-weight: 500;
	font-size: 24px;
	letter-spacing: 0.05em;
	line-height: 32px;
	text-align: left;
	color: #000;
}

@media screen and (max-width: 767px) {
	#base .boxes .box p {
		width: 100%;
		font-size: 13px;
		line-height: 20px;
	}
}

/* 5 */
#success-story {
	background-color: #B8183F;
	padding-top: 160px;
	padding-bottom: 140px;
}

@media screen and (max-width: 767px) {
	#success-story {
		padding-top: 60px;
		padding-bottom: 60px;
	}
}

#success-story .section-title05 {
	color: #fff;
	display: flex;
	justify-content: center;
	align-items: center;
}

#success-story .section-title05::before {
	content: "SUCCESS STORY";
	position: absolute;
	font-family: Roboto Condensed;
	font-weight: bold;
	font-size: 200px;
	line-height: 90px;
	text-align: center;
	color: #fff;
	opacity: 0.2;
	white-space: nowrap;

}

@media screen and (max-width: 1440px) {
	#success-story .section-title05::before {
		font-size: 13vw;
	}

}

#success-story .boxes {
	margin-top: 95px;
}

@media screen and (max-width: 767px) {
	#success-story .boxes {
		margin-top: 50px;
	}
}

#success-story .boxes .box {
	width: 100%;
	padding: 65px;
	display: flex;
	margin-top: 50px;
	background-color: #fff;
}

@media screen and (max-width: 1440px) {
	#success-story .boxes .box {
		padding: 35px;
	}
}

@media screen and (max-width: 767px) {
	#success-story .boxes .box {
		padding: 20px 10px;
		flex-direction: column;
		margin-top: 20px;
	}
}

#success-story .boxes .box .picture {
	position: relative;
	width: 33%;
}

@media screen and (max-width: 767px) {
	#success-story .boxes .box .picture {
		width: 100%;
	}
}

#success-story .boxes .box .picture img {
	width: 100%;
}

#success-story .boxes .box .picture p {
	position: absolute;
	top: -40px;
	left: 5px;
	font-family: Roboto;
	font-weight: bold;
	font-size: 80px;
	line-height: 90px;
	text-align: left;
	color: #b8183f;
}

@media screen and (max-width: 1440px) {
	#success-story .boxes .box .picture p {
		font-size: calc(8000vw / 1440);
	}
}

@media screen and (max-width: 767px) {
	#success-story .boxes .box .picture p {
		top: auto;
		left: auto;
		bottom: -35px;
		right: 5px;
		font-size: 50px;
		line-height: 80px;
	}
}

#success-story .boxes .box .texts {
	width: 62%;
	margin-left: 50px;
}

@media screen and (max-width: 767px) {
	#success-story .boxes .box .texts {
		width: 100%;
		margin-left: 0;
		margin-top: 15px;
		margin-bottom: 5px;
	}
}

#success-story .boxes .box .texts .up .list {
	display: flex;
	align-items: center;
	margin-bottom: 12px;
}

@media screen and (max-width: 767px) {
	#success-story .boxes .box .texts .up .list {
		margin-bottom: 8px;
	}
}

#success-story .boxes .box .texts .up .list .lefty {
	height: 40px;
	width: 160px;
	background-color: #B8183F;
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 22px;
	line-height: 40px;
	text-align: center;
	color: #fff;
	margin-right: 20px;
}

@media screen and (max-width: 1440px) {
	#success-story .boxes .box .texts .up .list .lefty {
		font-size: 18px;
		line-height: 40px;
		width: 120px;
	}
}

@media screen and (max-width: 767px) {
	#success-story .boxes .box .texts .up .list .lefty {
		height: 25px;
		width: 70px;
		font-size: 12px;
		line-height: 25px;
		margin-right: 10px;
	}
}

#success-story .boxes .box .texts .up .list .righty {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 28px;
	letter-spacing: 0.02em;
	line-height: 40px;
	text-align: left;
	color: #000;
}

@media screen and (max-width: 1440px) {
	#success-story .boxes .box .texts .up .list .righty {
		font-size: 18px;
	}
}

@media screen and (max-width: 767px) {
	#success-story .boxes .box .texts .up .list .righty {
		font-size: 13px;
		line-height: 25px;
	}
}

#success-story .boxes .box .texts .down {
	font-family: "Noto Sans JP";
	font-weight: 500;
	font-size: 24px;
	letter-spacing: 0.02em;
	line-height: 44px;
	text-align: left;
	color: #000;
	margin-top: 25px;
}

@media screen and (max-width: 1440px) {
	#success-story .boxes .box .texts .down {
		font-size: 15px;
		line-height: 1.5em;
	}
}

@media screen and (max-width: 767px) {
	#success-story .boxes .box .texts .down {
		font-size: 13px;
		line-height: 1.8em;
		margin-top: 20px;
	}
}

/* 6 */
#service {
	padding-top: 170px;
	padding-bottom: 60px;
}

@media screen and (max-width: 767px) {
	#service {
		padding-top: 60px;
		padding-bottom: 20px;
	}
}

#service .section-title06 {
	color: #1a1311;
	display: flex;
	justify-content: center;
	align-items: center;
}

#service .section-title06::before {
	content: "SERVICE";
	position: absolute;
	font-family: Roboto Condensed;
	font-weight: bold;
	font-size: 200px;
	line-height: 90px;
	text-align: center;
	color: #eee;
	white-space: nowrap;

}

@media screen and (max-width: 1440px) {
	#service .section-title06::before {
		font-size: 13vw;
	}

}

#service h3 {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 42px;
	line-height: 60px;
	text-align: center;
	color: #b8183f;
	margin-top: 100px;
	margin-bottom: 55px;
}

@media screen and (max-width: 767px) {
	#service h3 {
		font-size: 17px;
		line-height: 28px;
		margin-top: 50px;
		margin-bottom: 30px;
	}
}

#service .boxes {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin-top: 20px;
}

#service .boxes .box {
	width: calc(34000% / 1440);
	background-color: #FABE00;
	padding: 35px 35px 30px;
	border-radius: 10px;
	box-shadow: 0 6px 0 #B5B5B5;
}

@media screen and (max-width: 767px) {
	#service .boxes .box {
		width: 49%;
		padding: 10px;
		margin-bottom: 15px;
	}
}

#service .boxes .box .text1 {
	font-family: "Noto Sans JP";
	font-weight: 900;
	font-size: 38px;
	line-height: 50px;
	text-align: left;
	color: #b8183f;
}

@media screen and (max-width: 1440px) {
	#service .boxes .box .text1 {
		font-size: calc(3800vw / 1600);
		line-height: 1.5em;
	}
}

@media screen and (max-width: 767px) {
	#service .boxes .box .text1 {
		font-size: 20px;
		line-height: 25px;
	}
}

#service .boxes .box .text2 {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 30px;
	line-height: 40px;
	text-align: left;
	color: #b8183f;
}

@media screen and (max-width: 1440px) {
	#service .boxes .box .text2 {
		font-size: calc(3000vw / 1600);
		line-height: 1.5em;
	}
}

@media screen and (max-width: 767px) {
	#service .boxes .box .text2 {
		font-size: 17px;
		line-height: 25px;
	}
}

#service .boxes .box .text3 {
	font-family: "Noto Sans JP";
	font-weight: 500;
	font-size: 22px;
	letter-spacing: 0.05em;
	line-height: 32px;
	text-align: left;
	color: #000;
	padding-top: 15px
}

@media screen and (max-width: 1440px) {
	#service .boxes .box .text3 {
		font-size: calc(2200vw / 1600);
		line-height: 1.5em;
	}
}

@media screen and (max-width: 767px) {
	#service .boxes .box .text3 {
		font-size: 12px;
		line-height: 18px;
		padding-top: 5px;
	}
}

/* 6.5 */
#service-supplement {
	padding-bottom: 140px;
}

@media screen and (max-width: 1440px) {
	#service-supplement {
		padding-bottom: 80px;
	}
}

@media screen and (max-width: 767px) {
	#service-supplement {
		padding-bottom: 50px;
	}
}

#service-supplement h3 {
	height: 88px;
	width: 100%;
	padding-left: 30px;
	background-color: #B8183F;
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 30px;
	line-height: 88px;
	text-align: left;
	color: #fff;
}

@media screen and (max-width: 767px) {
	#service-supplement h3 {
		height: 50px;
		padding-left: 15px;
		font-size: 15px;
		line-height: 50px;
	}
}

#service-supplement .boxes {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#service-supplement .boxes .box {
	width: calc(42000% / 1440);
	margin-top: 60px;
	margin-bottom: 17px;
}

@media screen and (max-width: 1440px) {
	#service-supplement .boxes .box {
		width: 48%;
	}
}

@media screen and (max-width: 767px) {
	#service-supplement .boxes .box {
		width: 100%;
		margin-top: 20px;
	}
}

#service-supplement .boxes .box img {
	width: 100%;
}

#service-supplement .boxes .box .text1 {
	width: 100%;
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 26px;
	line-height: 60px;
	text-align: left;
	color: #b8183f;
	margin-top: 12px;
}

@media screen and (max-width: 767px) {
	#service-supplement .boxes .box .text1 {
		font-size: 16px;
		line-height: 24px;
		margin-top: 10px;
	}
}

#service-supplement .boxes .box .text2 {
	width: 100%;
	font-family: "Noto Sans JP";
	font-weight: normal;
	font-size: 20px;
	letter-spacing: 0.05em;
	line-height: 32px;
	text-align: left;
	color: #000;
}

@media screen and (max-width: 767px) {
	#service-supplement .boxes .box .text2 {
		font-size: 14px;
		line-height: 1.8em;
		margin-top: 10px;
	}
}

#service-supplement .caution {
	font-family: "Noto Sans JP";
	font-weight: normal;
	font-size: 20px;
	letter-spacing: 0.05em;
	line-height: 1.5em;
	text-align: left;
	color: #000;
	margin-top: 40px;
}

@media screen and (max-width: 767px) {
	#service-supplement .caution {
		font-size: 12px;
		margin-top: 20px;
	}
}


/* 7 */
#personnel-dept {
	background-color: #EBECDF;
	padding-top: 165px;
	padding-bottom: 140px;
}

@media screen and (max-width: 767px) {
	#personnel-dept {
		padding-top: 60px;
		padding-bottom: 60px;
	}
}

#personnel-dept .section-title07 {
	color: #1a1311;
	display: flex;
	justify-content: center;
	align-items: center;
}

#personnel-dept .section-title07::before {
	content: "PERSONNEL DEPT";
	position: absolute;
	font-family: Roboto Condensed;
	font-weight: bold;
	font-size: 200px;
	line-height: 90px;
	text-align: center;
	color: #fff;
	white-space: nowrap;
}

@media screen and (max-width: 1440px) {
	#personnel-dept .section-title07::before {
		font-size: 13vw;
	}

}

#personnel-dept .up {
	display: flex;
	justify-content: space-between;
	margin-top: 125px;
}

@media screen and (max-width: 767px) {
	#personnel-dept .up {
		flex-direction: column;
		margin-top: 40px;
	}
}

#personnel-dept .up .left {
	display: flex;
	flex-direction: column;
	align-items: center;
	width: calc(75700% / 1440);
}

@media screen and (max-width: 767px) {
	#personnel-dept .up .left {
		width: 100%;
	}
}

#personnel-dept .up .left h3 {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 66px;
	line-height: 84px;
	text-align: left;
	color: #000;
	margin-top: 5px;
	margin-bottom: 40px;
	position: relative;
}

@media screen and (max-width: 1440px) {
	#personnel-dept .up .left h3 {
		font-size: calc(6600vw / 1600);
		line-height: 1.5em;
		margin-bottom: calc(5000vw / 1600);
	}
}

@media screen and (max-width: 767px) {
	#personnel-dept .up .left h3 {
		font-size: 20px;
		line-height: 30px;
		margin-bottom: 30px;
	}
}

#personnel-dept .up .left h3::before {
	content: "";
	position: absolute;
	top: -5px;
	left: -40px;
	height: 52px;
	width: 18px;
	border-top: 2px solid black;
	border-left: 2px solid black;
}

@media screen and (max-width: 1440px) {
	#personnel-dept .up .left h3::before {
		top: -0.5vw;
		left: -2vw;
		height: calc(5200vw / 1600);
		width: calc(1800vw / 1600);
	}
}

@media screen and (max-width: 767px) {
	#personnel-dept .up .left h3::before {
		top: -3px;
		left: -15px;
		height: 26px;
		width: 9px;
	}
}

#personnel-dept .up .left h3::after {
	content: "";
	position: absolute;
	bottom: -5px;
	right: -40px;
	height: 52px;
	width: 18px;
	border-bottom: 2px solid black;
	border-right: 2px solid black;
}

@media screen and (max-width: 1440px) {
	#personnel-dept .up .left h3::after {
		bottom: -0.5vw;
		right: -2vw;
		height: calc(5200vw / 1440);
		width: calc(1800vw / 1440);
	}
}

@media screen and (max-width: 767px) {
	#personnel-dept .up .left h3::after {
		bottom: -3px;
		right: -15px;
		height: 26px;
		width: 9px;
	}
}

#personnel-dept .up .left .items {
	display: flex;
	justify-content: space-between;
}

#personnel-dept .up .left .items .item {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 240px;
	height: 240px;
	border-radius: 120px;
	background-color: #242458;
	margin: 10px;
}

@media screen and (max-width: 1440px) {
	#personnel-dept .up .left .items .item {
		width: calc(24000vw / 1600);
		height: calc(24000vw / 1600);
		border-radius: calc(12000vw / 1600);
		margin: 5px;
	}
}

@media screen and (max-width: 767px) {
	#personnel-dept .up .left .items .item {
		width: 30vw;
		height: 30vw;
		border-radius: 15vw;
		margin: 5px;
	}
}

#personnel-dept .up .left .items .item p {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 30px;
	letter-spacing: 0.03em;
	line-height: 40px;
	text-align: center;
	color: #fff;
}

@media screen and (max-width: 1440px) {
	#personnel-dept .up .left .items .item p {
		font-size: calc(3000vw / 1600);
		line-height: 24px;
	}
}

@media screen and (max-width: 767px) {
	#personnel-dept .up .left .items .item p {
		font-size: 14px;
		line-height: 1.3em;
	}
}

#personnel-dept .up .left .items p span {
	font-family: "Noto Sans JP";
	font-weight: normal;
	font-size: 18px;
	letter-spacing: 0.03em;
	line-height: 18px;
	text-align: center;
	color: #fff;
}

@media screen and (max-width: 1440px) {
	#personnel-dept .up .left .items p span {
		font-size: calc(1200vw / 1600);
	}
}

@media screen and (max-width: 767px) {
	#personnel-dept .up .left .items p span {
		font-size: 12px;
	}
}

#personnel-dept .up .right {
	padding-right: 30px;
}

@media screen and (max-width: 1440px) {
	#personnel-dept .up .right {
		padding-right: 15px;
	}
}

@media screen and (max-width: 767px) {
	#personnel-dept .up .right {
		padding-right: 30px;
		padding-left: 30px;
		padding-top: 40px;
	}
}

#personnel-dept .down {
	background-color: #fff;
	padding: 78px 100px 90px;
	margin-top: -160px;
	position: relative;
}

@media screen and (max-width: 1440px) {
	#personnel-dept .down {
		padding: 60px 60px 80px;
		margin-top: -130px;
	}
}

@media screen and (max-width: 767px) {
	#personnel-dept .down {
		padding: 30px 15px 40px;
		margin-top: -130px;
	}
}

#personnel-dept .down p {
	font-family: "Noto Sans JP";
	font-weight: 500;
	font-size: 22px;
	letter-spacing: 0.02em;
	line-height: 42px;
	text-align: left;
	color: #000;
	margin-bottom: 1.9em;
}

@media screen and (max-width: 767px) {
	#personnel-dept .down p {
		font-size: 14px;
		line-height: 1.8em;
	}
}

#personnel-dept .down .mid-btn {
	margin-left: auto;
	margin-right: auto;
	width: 460px;
	height: 86px;
	border-radius: 43px;
	background-color: #B8183F;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-top: 50px;
}

@media screen and (max-width: 767px) {
	#personnel-dept .down .mid-btn {
		width: 267px;
		height: 50px;
		border-radius: 25px;
		margin-top: 25px
	}
}

#personnel-dept .down .mid-btn:hover {
	background-color: #FFF;
	border: 1px solid #B8183F;
}

#personnel-dept .down .mid-btn p {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 22px;
	letter-spacing: 0.05em;
	text-align: left;
	color: #fff;
	position: relative;
	display: contents;
}

@media screen and (max-width: 767px) {
	#personnel-dept .down .mid-btn p {
		font-size: 14px;
		margin-bottom: 0;
	}
}

@media screen and (max-width: 767px) {
	#personnel-dept .down .mid-btn p span {
		padding-bottom: 2px;
	}
}

#personnel-dept .down .mid-btn:hover p {
	color: #B8183F;
}

#personnel-dept .down .mid-btn p::after {
	content: "";
	background-image: url(./common/img/link.svg);
	background-size: cover;
	width: 16px;
	height: 16px;
	margin-left: 5px;
}

@media screen and (max-width: 767px) {
	#personnel-dept .down .mid-btn p::after {
		width: 10px;
		height: 10px;
		margin-left: 3px;
	}
}

#personnel-dept .down .mid-btn:hover p::after {
	background-image: url(./common/img/link.hover.svg);
}


/* 8 */
#about-us {
	background-color: #B8183F;
	padding-top: 170px;
	padding-bottom: 165px;
}

@media screen and (max-width: 767px) {
	#about-us {
		padding-top: 60px;
		padding-bottom: 60px;
	}
}

#about-us .section-title08 {
	color: #fff;
	display: flex;
	justify-content: center;
	align-items: center;
}

#about-us .section-title08::before {
	content: "ABOUT US";
	position: absolute;
	font-family: Roboto Condensed;
	font-weight: bold;
	font-size: 200px;
	line-height: 90px;
	text-align: center;
	color: #fff;
	opacity: 0.2;
	white-space: nowrap;
}

@media screen and (max-width: 1440px) {
	#about-us .section-title08::before {
		font-size: 13vw;
	}

}

#about-us .whiteboard {
	background-color: #fff;
	padding: 40px 100px 60px;
	margin-top: 95px;
	margin-bottom: 110px;
}

@media screen and (max-width: 767px) {
	#about-us .whiteboard {
		padding: 10px 15px 10px;
		margin-top: 50px;
		margin-bottom: 60px;
	}
}

#about-us .whiteboard table {
	font-family: "Noto Sans JP";
	font-weight: 500;
	font-size: 22px;
	letter-spacing: 0.02em;
	line-height: 44px;
	text-align: left;
	color: #000;
}

@media screen and (max-width: 767px) {
	#about-us .whiteboard table {
		font-size: 14px;
		line-height: 1.5em;
	}
}

#about-us .whiteboard table tr {
	border-bottom: 1px solid #D4D0D0;
}

@media screen and (max-width: 767px) {
	#about-us .whiteboard table tr {
		display: flex;
		flex-direction: column;
	}
}

#about-us .whiteboard table tr:last-child {
	border-bottom: none;
}

#about-us .whiteboard table th {
	width: calc(18800% / 1240);
	vertical-align: top;
	padding-top: 1em;
	font-weight: bold;
}

@media screen and (max-width: 940px) {
	#about-us .whiteboard table th {
		width: 25%;
	}
}

@media screen and (max-width: 767px) {
	#about-us .whiteboard table th {
		width: 100%;
	}
}

#about-us .whiteboard table td {
	padding-top: .5em;
	padding-bottom: 1em;
}

#about-us iframe {
	display: block;
	margin-left: auto;
	margin-right: auto;
	width: 1215px;
	height: 683px;
}

@media screen and (max-width: 1440px) {
	#about-us iframe {
		width: 88vw;
		height: 49.5vw;
	}
}

#about-us .text-bottom {
	margin-top: 45px;
	margin-left: auto;
	margin-right: auto;
	font-family: "Noto Sans JP";
	font-weight: 500;
	font-size: 22px;
	letter-spacing: 0.02em;
	line-height: 42px;
	text-align: left;
	color: #fff;
	max-width: 1215px;
}

@media screen and (max-width: 1440px) {
	#about-us .text-bottom {
		width: 88vw;
		font-size: 14px;
		line-height: 1.5em;
	}
}

/* 9 */
#inquiry {
	height: 580px;
	background-image: url(./common/img/26.inquiry.jpg);
	padding-top: 200px;
}

@media screen and (max-width: 767px) {
	#inquiry {
		height: 200px;
		background-size: cover;
		padding-top: 70px;
	}
}

#inquiry .big-btn {
	width: 860px;
	height: 180px;
	border-radius: 90px;
	margin-left: auto;
	margin-right: auto;
	background-color: #B8183F;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}

@media screen and (max-width: 940px) {
	#inquiry .big-btn {
		width: 500px;
		height: 100px;
		border-radius: 50px;
	}
}

@media screen and (max-width: 767px) {
	#inquiry .big-btn {
		width: 258px;
		height: 54px;
		border-radius: 27px;
	}
}

#inquiry .big-btn:hover {
	background-color: #FFF;
	border: 1px solid #B8183F;
}

#inquiry .big-btn p {
	font-family: "Noto Sans JP";
	font-weight: bold;
	font-size: 34px;
	letter-spacing: 0.05em;
	line-height: 90px;
	text-align: center;
	color: #fff;
}

@media screen and (max-width: 767px) {
	#inquiry .big-btn p {
		font-size: 14px;
		line-height: 21px;
	}
}

#inquiry .big-btn:hover p {
	color: #B8183F;
}

#inquiry .big-btn p:after {
	content: "";
	position: absolute;
	right: 58px;
	top: 0;
	bottom: 0;
	margin: auto 0;
	height: 25px;
	width: 25px;
	border-top: 4px solid white;
	border-right: 4px solid white;
	transform: rotate(45deg);
}

@media screen and (max-width: 767px) {
	#inquiry .big-btn p:after {
		right: 20px;
		height: 8px;
		width: 8px;
		border-top: 2px solid white;
		border-right: 2px solid white;
	}
}

#inquiry .big-btn:hover p:after {
	border-top: 4px solid #B8183F;
	border-right: 4px solid #B8183F;
}

footer {
	padding-top: 50px;
	padding-bottom: 45px;
}

@media screen and (max-width: 767px) {
	footer {
		padding-top: 30px;
		padding-bottom: 25px;
	}
}

footer .inner1440 {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

@media screen and (max-width: 767px) {
	footer .lefty img {
		width: 120px;
	}

}

footer .lefty {
	margin-right: 18px;
}

footer .lefty .office {
	font-family: "Noto Sans JP";
	font-weight: 500;
	font-size: 18px;
	letter-spacing: 0.02em;
	line-height: 30px;
	text-align: left;
	color: #000;
	margin-top: 22px;
}

@media screen and (max-width: 767px) {
	footer .lefty .office {
		font-size: 12px;
		line-height: 18px;
		margin-top: 10px;
	}
}

footer .lefty .tel-adr {
	font-family: "Noto Sans JP";
	font-weight: 300;
	font-size: 16px;
	letter-spacing: 0.02em;
	line-height: 24px;
	text-align: left;
	color: #000;
	margin-top: 5px;
}

@media screen and (max-width: 767px) {
	footer .lefty .tel-adr {
		font-size: 10px;
		line-height: 15px;
		margin-top: 10px;
		margin-bottom: 0;
	}
}

footer .lefty .copyright {
	font-family: "Noto Sans JP";
	font-weight: 300;
	font-size: 14px;
	letter-spacing: 0.02em;
	line-height: 30px;
	text-align: left;
	color: #000;
	margin-top: 25px;
}

@media screen and (max-width: 767px) {
	footer .lefty .copyright {
		font-size: 10px;
		line-height: 15px;
		margin-top: 10px
	}
}

@media screen and (max-width: 767px) {
	footer .righty {
		width: 150px;
	}
}

h6 {
	font-size: 25px;
	line-height: 1.5em;
	margin-top: -8px;
}

@media screen and (max-width: 1440px) {
	h6 {
		font-size: 18px;
		margin-top: 0px;
	}
}

@media screen and (max-width: 767px) {
	h6 {
		font-size: 12px;
	}
}

footer .righty .links {
	display: flex;
	margin-top: 30px;
	margin-bottom: 26px;
}

@media screen and (max-width: 767px) {
	footer .righty .links {
		margin-top: 20px;
		margin-bottom: 20px;
	}
}

footer .righty .links a {
	width: 32px;
	margin-right: 6px;
}