@charset "UTF-8";

.common_page-title {
	width: 100% !important;
}

.works_head-container {
	display: block;
	max-width: 1920px;
	width: 100%;
	margin: 0 auto;
}

.works_head-contents {
	display: flex;
	position: relative;
	bottom: 0;
	max-width: 1460px;
	margin-left: auto;
	column-gap: 10px;
	justify-content: space-between;
}

.works_head-img {
	overflow: hidden;
	max-width: 735px;
	margin-top: clamp(0rem, -0.417rem + 0.87vw, 0.625rem);
}

.works_head-img img {
	width: 100%;
	height: 100%;

	object-fit: cover;
	object-position: center;
}

.works_head-details {
	width: 100%;
}

.works_head-details p {
	font-size: 16px;
	line-height: 27px;
	text-align: justify;
}

.work_trouble-container {
	display: flex;
	max-width: 1000px;
	margin: 0 auto;
	flex-direction: column;
}

.work_trouble-title {
	display: flex;
	font-weight: bold;
	font-size: clamp(1.25rem, 0.746rem + 1.05vw, 1.75rem);
	letter-spacing: 0.05em;
	column-gap: 5px;
	justify-content: center;
	align-items: center;
}

.work_trouble-title::before {
	display: block;
	width: 18px;
	background-color: #142b8b;
	content: "";

	clip-path: polygon(0 0, 0% 100%, 100% 50%);
	aspect-ratio: 9/10;
}

.work_trouble-wrap {
	display: block;
	position: relative;
	width: 100%;
}


.work_trouble-list {
	display: flex;
	position: relative;
	width: 100%;
	column-gap: clamp(0rem, -2.526rem + 5.26vw, 0.938rem);
	flex-wrap: wrap;
	justify-content: space-between;
}
.work_trouble-list::before {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: -1;
	transform: translate(-50%, -50%);
	max-width: 270px;
	width: clamp(8.75rem, -13.145rem + 45.61vw, 16.875rem);
	background-image: url(../images/work_trouble-bg.webp);
	background-repeat: no-repeat;
	background-position: center;
	background-size: 100%;
	opacity: 0.1;
	content: "";

	aspect-ratio: 270/283;
}

.work_trouble-item {
	display: flex;
	position: relative;
	max-width: 480px;
	width: calc(50% - clamp(0rem, -1.263rem + 2.63vw, 0.469rem));
	flex-direction: column;
}
@media screen and (min-width: 375px) {
	.work_trouble-item {
		width: calc(50% - clamp(0rem, -1.263rem + 2.63vw, 0.469rem));
	}
}

.work_trouble-item p {
	display: flex;
	width: 100%;
	height: 100%;
	background-color: #142b8b;
	color: #ffffff;

/*font-weight: 500;*/
	font-size: clamp(0.813rem, 0.498rem + 0.66vw, 1.125rem);
	line-height: clamp(1.375rem, 1.06rem + 0.66vw, 1.688rem);
	text-align: justify;
	align-items: center;

	clip-path: polygon(10px 0%, 100% 0%, calc(100% - 10px) 100%, 0% 100%);
}


.work_trouble-wrap img {
	position: absolute;
	right: 0;
	bottom: 0;
	max-width: 100px;
	min-width: 65px;
	width: clamp(4.063rem, -1.832rem + 12.28vw, 6.25rem);
}


.works_solve-container {
	display: block;
	position: relative;
	width: 100%;
	background-color: #142b8b;
}

.works_solve-container::before , .works_solve-container::after {
	position: absolute;
	left: 50%;
	z-index: 2;
	transform: translateX(-50%);
	width: 50px;
	content: "";

	aspect-ratio: 2/1;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.works_solve-container::before {
	top: -1px;
	background-color: #ffffff;
}

.works_solve-container::after {
	top: calc(100% - 1px);
	background-color: #142b8b;
}

.works_solve-inner {
	display: flex;
	position: relative;
	max-width: 1000px;
	margin: 0 auto;
	justify-content: center;
	align-items: center;
}

.works_solve-content {
	display: flex;
	position: relative;
	align-items: center;
}

.works_solve-img {
	position: absolute;
	left: calc(100% + clamp(0.625rem, -0.124rem + 1.44vw, 1.25rem));
	max-width: 105px;
	width: 100%;
}

@media screen and (max-width: 833px) {
	.works_solve-img {
		display: none;
	}
}

.works_solve-theme {
	display: block;
	width: fit-content;
	margin: 0 auto;
	color: #ffffff;
	font-weight: bold;
	font-size: 28px;
	text-align: center;
	letter-spacing: 0.05em;
}


.solve_theme-point {
	display: inline-block;
	position: relative;
	transform: rotateZ(-4deg);
	transform-origin: center;
	margin: 0 0.27em;
	padding: 0 20px;
	background-color: #ffffff;
	color: #142b8b;
	font-size: 47px;
}

.solve_theme-point::before , .solve_theme-point::after {
	display: block;
	position: absolute;
	width: 15px;
	height: 30px;
	content: "";
}

.solve_theme-point::before {
	top: 0;
	left: 0;
	border-top: 5px solid #142b8b;
	border-left: 5px solid #142b8b;
	box-shadow: -5px -5px 0 #ffffff, -5px 5px 0 #ffffff, 5px -5px 0 #ffffff;
}

.solve_theme-point::after {
	right: 0;
	bottom: 0;
	border-right: 5px solid #142b8b;
	border-bottom: 5px solid #142b8b;
	box-shadow: 5px 5px 0 #ffffff, 5px -5px 0 #ffffff, -5px 5px 0 #ffffff;
}

.works_solve-theme span:not(.solve_theme-point) {
	display: inline-block;
	font-size: 35px;
}

.works_solve-theme span:not(.solve_theme-point):nth-last-of-type(2) {
	transform: translateY(3px) rotateZ(15deg);
}

.works_solve-theme span:not(.solve_theme-point):nth-last-of-type(1) {
	transform: translateY(5px) rotateZ(30deg);
}

.works_merit-container {
	display: flex;
	max-width: 1920px;
	width: 100%;
	margin: 0 auto;
	flex-direction: column;
}

.works_merit-title {
	display: flex;
	font-weight: bold;
	font-size: clamp(1.25rem, -0.097rem + 2.81vw, 1.75rem);
	letter-spacing: 0.1em;
	justify-content: center;
	align-items: baseline;
}

.works_merit-title::before , .works_merit-title::after {
	display: block;
	max-width: 55px;
	width: clamp(1.563rem, -3.49rem + 10.53vw, 3.438rem);
	height: 1px;
	margin: auto 0 clamp(1.063rem, 0.557rem + 1.05vw, 1.25rem);
	background-color: #142b8b;
	content: "";
}

.works_merit-title::before {
	margin-right: clamp(0.625rem, -0.217rem + 1.75vw, 0.938rem);
}

.works_merit-title::after {
	margin-left: clamp(0.625rem, -0.217rem + 1.75vw, 0.938rem);
}

.works_merit-title span {
	font-weight: 900;
	font-size: 35px;
}


.works_merit-list {
	display: flex;
	max-width: 1140px;
	width: 100%;
	margin: 0 auto;
	column-gap: 10px;
	flex-direction: column;
	flex-wrap: wrap;
	counter-reset: number;
}

.works_merit-item {
	position: relative;
	max-width: 1070px;
	width: 97.5%;
}

.works_merit-item::before {
	display: block;
	position: absolute;
	z-index: -1;
	max-width: 1015px;
	width: 100%;
	background-color: #142b8b;
	opacity: 0.1;
	content: "";
}


.works_merit-contents {
	display: flex;
	column-gap: 10px;
	justify-content: space-between;
}
.works_merit-img {
	max-width: 590px;
	width: 100%;

/*margin-left: auto;*/

	aspect-ratio: 59/39;
}

.works_merit-img img {
	width: 100%;
	height: 100%;
}

.works_merit-details {
	width: 100%;
}
.works_merit-subtitle {
	display: flex;
	margin-bottom: 15px;
	color: #142b8b;
	font-weight: bold;
	font-size: clamp(1.375rem, -0.141rem + 3.16vw, 1.938rem);
	line-height: clamp(2.25rem, -0.276rem + 5.26vw, 3.188rem);
	letter-spacing: 0.05em;
	flex-direction: column;
}

.works_merit-subtitle::before {
	margin-bottom: clamp(0.5rem, 0.163rem + 0.7vw, 0.625rem);
	font-family: "Noto Serif JP", serif;
	font-weight: 900;
	font-size: clamp(3.875rem, 0.001rem + 8.07vw, 5.313rem);
	line-height: 1.15;
	content: counter(number);
	counter-increment: number;
}

.works_merit-text {
	font-size: 14px;
	line-height: 27px;
	text-align: justify;
}

.works_merit-mincolumn {
	display: flex;
	column-gap: 10px;
	flex-direction: row-reverse;
	justify-content: flex-end;
	align-items: flex-end;
}
.works_merit-mincolumn h5 {
	display: flex;
	margin-bottom: 10px;
	padding-left: 5px;
	color: #142b8b;
	font-weight: bold;
	font-size: 14px;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	column-gap: 5px;
}

.works_merit-mincolumn h5::after {
	display: flex;
	width: 25px;
	height: 1px;
	margin-top: 0.7em;
	background-color: #142b8b;
	content: "";
}

.works_merit-mincolumn ul {
	display: flex;
	color: #142b8b;
	font-weight: 500;
	font-size: clamp(0.813rem, 0.476rem + 0.7vw, 0.938rem);
	column-gap: clamp(0.313rem, -0.53rem + 1.75vw, 0.625rem);
	flex-wrap: wrap;

	row-gap: 5px;
}

.works_merit-mincolumn li {
	display: flex;
	min-width: 80px;
	background-color: #f3f3f3;
	justify-content: center;
	align-items: center;
}

.works_diagonal-title {
	display: flex;
	font-weight: bold;
	font-size: clamp(1.25rem, -0.097rem + 2.81vw, 1.75rem);
	letter-spacing: 0.05em;
	column-gap: clamp(1.125rem, 0.788rem + 0.7vw, 1.25rem);
	align-items: baseline;
}


.works_diagonal-title::before {
	transform: rotate(26.5deg) translateY(5px);
	transform-origin: center bottom;
	width: 1px;
	height: clamp(1.563rem, -0.122rem + 3.51vw, 2.188rem);
	background-color: #142b8b;
	content: "";
}
.works_vehicle-container {
	display: block;
	max-width: 1000px;
	margin: 0 auto;
}


.works_vehicle-text {
	font-size: clamp(0.875rem, 0.538rem + 0.7vw, 1rem);
	line-height: 25px;
	text-align: justify;
}
.works_vehicle-text {
	margin-bottom: 20px;
}

.works_vehicle-list {
	display: flex;
	column-gap: clamp(0.938rem, -7.393rem + 15.98vw, 3.125rem);
	flex-wrap: wrap;
}

.works_vehicle-item {
	display: block;
	max-width: 390px;
}

.works_vehicle-contents {
	display: flex;
	width: 100%;
	flex-direction: column;
}


.works_vehicle-img {
	display: flex;
	min-width: 155px;
	width: 100%;
	margin-bottom: 10px;
	background-color: #f3f3f3;
	justify-content: center;
	align-items: center;

	aspect-ratio: 3/2;
}

.works_vehicle-img img {
	width: 100%;
}

.vehicle_mini-img img {
	max-width: calc(100% / 2);
}
@media screen and (min-width: 501px) {
	.works_vehicle-item {
		width: calc(50% - 7.5px);
	}
	.works_vehicle-img {
		width: 100%;
	}
}
@media screen and (max-width: 500px) {
	.works_vehicle-list {
		flex-direction: column;
	}
	.works_vehicle-item {
		width: 100%;
	}
	.works_vehicle-img {
		width: clamp(9.688rem, -49.063rem + 235vw, 24.375rem);
	}
}

.works_vehicle-details h5 {
	display: flex;
	position: relative;
	width: fit-content;
	margin-bottom: 5px;
	color: #142b8b;
	font-weight: bold;
	font-size: clamp(0.875rem, 0.033rem + 1.75vw, 1.188rem);
	flex-direction: column;

	row-gap: clamp(0rem, -0.505rem + 1.05vw, 0.188rem);
}

.works_vehicle-details h5::after {
	display: block;
	width: 100%;
	height: 1px;
	background-color: #142b8b;
	content: "";
}


.works_vehicle-details ul {
	display: flex;
	font-size: clamp(0.875rem, 0.538rem + 0.7vw, 1rem);
	line-height: clamp(1.563rem, 1.394rem + 0.35vw, 1.625rem);
	flex-direction: column;
}

.works_vehicle-details li {
	display: flex;
	text-align: justify;
}

.works_vehicle-details li::before {
	content: "･";
}

@media screen and (min-width: 768px) {
	.display_mb {
		display: none;
	}
	.main_container {
		padding-bottom: 100px;
	}
	.common_page-title {
		margin-bottom: 35px;
	}

	.works_head-container {
		margin-bottom: 105px;
	}

	.works_head-contents {
		width: 97.5%;
		flex-direction: row-reverse;

		row-gap: 25px;
	}

	.works_head-img {
		width: 100%;
		height: 355px;
	}

	.works_head-details {
		max-width: 655px;
	}

	.works_head-details p {
		margin-bottom: 30px;
	}

	.work_trouble-container {
		width: 95%;
		margin-bottom: 25px;

		row-gap: 40px;
	}

	.work_trouble-wrap {
		padding-bottom: 40px;
	}

	.work_trouble-list {
		row-gap: 30px;
	}
	.work_trouble-item p {
		min-height: 75px;
		padding: 10.5px calc(10px + 30px) 10.5px calc(10px + 15px);
	}

	.trouble_count-even .work_trouble-item:nth-last-of-type(1) p {
		padding-right: calc(10px + clamp(1.875rem, -4.02rem + 12.28vw, 4.063rem));
	}
	.work_trouble-item::after {
		display: block;
		width: 30px;
		margin-top: -1px;
		margin-right: calc(10px + 10px);
		margin-left: auto;
		background-color: #142b8b;
		content: "";

		aspect-ratio: 6/5;
		clip-path: polygon(78% 0, 0 0, 100% 100%);
	}
	.works_solve-container {
		margin-bottom: calc(25px + 70px);
	}
	.works_solve-inner {
		width: 95%;
		padding: 50.5px 0;
	}

	.works_solve-theme br {
		display: none;
	}
	.works_merit-container {
		margin-bottom: 55px;
	}
	.works_merit-list {
		margin-top: -1.0417%;

		row-gap: 130px;
	}
	.works_merit-item {
		width: 97.5%;
	}

	.works_merit-item:nth-child(odd) {
		margin-left: auto;
	}

	.works_merit-item:nth-child(even) {
		margin-right: auto;
	}

	.works_merit-item::before {
		bottom: 50px;

		aspect-ratio: 29/15;
	}
	.works_merit-item:nth-child(odd)::before {
		left: 41.5888%;
	}


	.works_merit-item:nth-child(even)::before {
		right: 41.5888%;
	}




	.works_merit-item:nth-child(odd) .works_merit-contents {
		flex-direction: row-reverse;
	}
	.works_merit-img {
		margin-top: calc(20px + 100px);

		aspect-ratio: 59/39;
	}



	.works_merit-details {
		max-width: 430px;
	}
	.works_merit-text {
		margin-bottom: 30px;
	}
	.works_merit-mincolumn li {
		padding: 7px 15px;
		border-radius: 17.5px;
	}
	.works_vehicle-container {
		width: 95%;
	}

	.works_vehicle-container .works_diagonal-title {
		margin-bottom: 20px;
	}


	.works_vehicle-img {
		margin-bottom: 10px;
	}
	.works_vehicle-list {
		row-gap: 30px;
	}

	.works_vehicle-details h5 {
		font-weight: bold;
	}
}

@media screen and (max-width: 767px) {
	.display_pc {
		display: none;
	}

	.main_container {
		padding-bottom: 50px;
	}
	.common_page-title {
		margin-bottom: 30px;
		padding: 0 !important;
	}

	.works_head-container {
		margin-bottom: 40px;
	}

	.works_head-contents {
		width: 100%;
		margin-bottom: 35px;
		padding-left: 20px;
		flex-direction: column-reverse;

		row-gap: 15px;
	}

	.works_head-img {
		min-width: 260px;
		width: 73.2395%;
		margin-left: auto;

		aspect-ratio: 52/25;
	}

	.works_head-details {
		padding-right: 20px;
	}

	.work_trouble-container {
		width: 100%;
		margin-bottom: 5px;
		padding: 0 17.5px;

		row-gap: 25px;
	}


	.work_trouble-wrap {
		padding-bottom: 50px;
	}
	.work_trouble-list {
		row-gap: 10px;
	}
	@media screen and (max-width: 374px) {
		.work_trouble-list {
			flex-direction: column;
		}
		.work_trouble-item {
			width: 100%;
		}
	}
	.work_trouble-item p {
		min-height: 115px;
		padding: 13.5px calc(10px + 5px);
	}
	.work_trouble-wrap img {
		right: 12.5px;
	}
	.works_solve-container {
		margin-bottom: calc(25px + 10px);
	}
	.works_solve-inner {
		width: 100%;
		padding: 16px 0;
	}
	.works_solve-theme {
		line-height: 70px;
	}
	.works_merit-container {
		margin-bottom: 55px;
	}
	.works_merit-list {
		row-gap: 55px;
	}
	.works_merit-item {
		width: 100%;
		padding-left: 30px;
	}

	.works_merit-item::before {
		top: calc(15px + 40px);
		right: 0;
		width: 58.6667%;

		aspect-ratio: 11/7;
	}


	.works_merit-contents {
		flex-direction: row-reverse;
	}
	.works_merit-img {
		aspect-ratio: 19/13;
	}
	.works_merit-subtitle {
		padding-right: 20px;
	}
	.works_merit-text {
		margin-bottom: 15px;
		padding-right: 20px;
	}
	.works_merit-mincolumn ul {
		flex-direction: column;
	}
	.works_merit-mincolumn li {
		min-width: 140px;
		padding: 3px 10px;
		border-radius: 12.5px;
	}
	.works_vehicle-container {
		width: 100%;
		padding: 0 20px;
	}

	.works_vehicle-container .works_diagonal-title {
		margin-bottom: 10px;
	}

	.works_vehicle-img {
		margin-bottom: 5px;
	}

	.works_vehicle-list {
		row-gap: 25px;
	}

	.works_vehicle-details h5 {
		font-weight: 500;
	}
}
