@charset "utf-8";

/*-------------------------------------------
utility
-------------------------------------------*/
img {
	display: block;
	max-width: 100%;
	height: auto;
}

/*------------------------------------------
  Display / Layout
------------------------------------------*/
.flex {
	display: flex;
}

.flex--center {
	justify-content: center;
	align-items: center;
}

.flex--between {
	justify-content: space-between;
}

.width-100 {
	width: 100%;
}

#vehicle a:visited {
	background-color: var(--color-accent);
}

/*------------------------------------------
  Container
------------------------------------------*/
.max-width {
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;
}

@media (max-width: 1000px) {
	.pad-x {
		padding-left: 20px;
		padding-right: 20px;
	}
}

/*-------------------------------------------
btn
-------------------------------------------*/
/* ------------------------------
   ボタン本体
------------------------------ */

.btn {
	/* 変更用変数 */
	--btn-padding-y: 0.75em;
	--btn-padding-x: 1em;
	--btn-font-size: 1.0rem;
	--btn-gap: 0.5em;


	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--btn-gap);

	padding: var(--btn-padding-y) var(--btn-padding-x);
	font-size: var(--btn-font-size);
	line-height: 1;

	border-radius: 4px;
	background: var(--color-accent);
	color: #fff;

	text-decoration: none;
	cursor: pointer;
}

/* ------------------------------
   アイコン
------------------------------ */

.btn-icon {
	display: inline-flex;
	align-items: center;
}

/* SVG / img 共通 */
.btn-icon svg,
.btn-icon img {
	width: 1em;
	height: 1em;
}

/* 矢印アイコンをつける */
.btn-icon-arrow {
	width: 0.5em;
	height: 0.5em;

	border-top: 2px solid currentColor;
	border-right: 2px solid currentColor;

	transform: rotate(45deg);
}

/* ------------------------------
   テキスト
------------------------------ */

.btn-label {
	white-space: nowrap;
}


/*-------------------------------------------
base
-------------------------------------------*/
.contents {
	width: auto !important;
	max-width: 1000px;
	padding-top: 120px;
}

.max-width {
	max-width: 1000px;
}

.reason-content.odd.flex.flex--between {
	gap: 20px;
}

/*-------------------------------------------
イントロセクション
-------------------------------------------*/
.ttl img {
	display: inline;
}

#plastering p {
	font-size: 1.6rem;
}

.intro .flex.flex--between {
	margin-bottom: 170px;
}

.intro-text {
	width: calc(50% - 60px);
}



.intro-heading {
	font-size: 4.2rem;
	font-weight: bold;
	margin-bottom: 19px;
	line-height: 1.2;
}

.intro-subttl-block {
	margin-bottom: 18px;
}


.intro .blue-bg {
	background-color: var(--color-main);
	color: #fff;
	font-size: 2.0rem;
	font-weight: bold;
	padding: 10px 5px 10px 5px;
	margin-bottom: 5px;
	line-height: 2.5;
}

@media screen and (max-width: 1000px) {
	.intro .flex.flex--between {
		gap: 10px;
	}

	.intro-text {
		width: 60%;
	}

	h2.intro-heading {
		font-size: 3.0rem;
	}
}

@media screen and (max-width: 640px) {
	.intro .flex.flex--between {
		flex-direction: column;
	}

	.intro-text,
	.intro-image {
		width: 100%;
	}

	.intro-text {
		margin-bottom: 30px;
	}

	.intro .flex.flex--between {
		margin-bottom: 0px;
	}

	section.intro.pad-x {
		margin-bottom: 50px;
	}

	.intro-heading {
		font-size: 3.2rem;
		margin-bottom: 10px;
	}

	.intro .blue-bg {
		padding: 5px;
		margin-bottom: 5px;
		line-height: 2.3;
	}
}

/*-------------------------------------------
選ばれる理由
-------------------------------------------*/
section.reason {
	padding: 100px 0;
}

.reason-heading {
	font-size: 3.2rem;
	font-weight: bold;
	margin-bottom: 45px;
	text-align: center;
}

.reason .wrapper {
	background-color: transparent;
}

.reason-content-wrap {
	background-color: #fff;
	border-radius: 20px;
}

.reason-text {
	width: calc(50% - 30px);
}

.reason-main-text {
	margin-bottom: 45px;
}

.reason-subtit {
	font-size: 2.3rem;
	font-weight: bold;
	color: #000e35;
}

.reason1 {
	border-radius: 10px 10px 0px 0px;
}

.reason4 {
	border-radius: 0px 0px 10px 10px;
}

.num-block {
	margin-bottom: 10px;
}

.reason-content.odd {
	padding: 75px;
	background-color: #000e35;
}

.odd .reason-subtit {
	border-bottom: 1px solid #fff;
	display: block;
	margin-bottom: 10px;
	padding-bottom: 10px;
	color: #fff;
}

.even .reason-subtit {
	color: #000e35;
	border-bottom: 1px solid #000e35;
	display: block;
	margin-bottom: 10px;
	padding-bottom: 10px;
}

.odd .reason-main-text {
	color: #fff;
	font-size: 1.6rem;
	line-height: 1.875;
}

.even .reason-main-text {
	font-size: 1.6rem;
	line-height: 1.875;
}



.reason-content.even {
	background-color: #fff;
	padding: 75px;
}

.reason .btn {
	font-size: 1.6rem;
	border-radius: 50px;
	font-weight: bold;
	padding: 15px 83px;
	gap: 10px;
	/*transition: var(--transition-normal);*/
}

.reason a:hover.btn {
	opacity: 0.7;

}



.btn-icon-arrow {
	transition: var(--transition-normal);
}

/*.btn:hover .btn-icon-arrow {
	transform: translateX(5px) rotate(45deg);
}*/

.reason-content.odd.flex.flex--between,
.reason-content.even.flex.flex--between {
	padding: 70px;
	gap: 20px;
}

.reason-content.even.flex.flex--between.reason4 {
	align-items: center;
	padding-top: 55px;
	padding-bottom: 55px;
}

.reason .reason2-btn {
	padding: 15px 43px;
}

.reason .reason3-btn {
	padding: 15px 60px;

}

section.intro.pad-x {
	margin-top: 44px;
}

.btn-wrap a:visited {
	background-color: var(--color-accent) !important;
}

.reason4 p.reason-main-text {
	margin-bottom: 15px;
}

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

	.reason-content.odd.flex.flex--between,
	.reason-content.even.flex.flex--between {
		padding: 30px;
		gap: 20px;
	}
}

@media screen and (max-width: 640px) {
	.reason-content.odd.flex.flex--between {
		padding: 20px;
		padding-bottom: 50px;
	}

	.reason-content.even.flex.flex--between {
		flex-direction: column;
		padding: 20px;
		padding-bottom: 50px;
		gap: 0;
	}

	.reason-content.odd.flex.flex--between {
		gap: 0px;
	}

	.reason-text {
		width: 100%;
	}

	.reason-content {
		display: flex;
		flex-direction: column;
	}

	.reason-text {
		display: contents;
	}

	.num-block,
	.reason-subtit,
	.reason-main-text {
		order: 1;
	}

	.reason-image {
		order: 2;
		margin-bottom: 30px;
	}

	.btn-wrap {
		order: 3;
		margin-top: 16px;
	}

	.reason-main-text {
		margin-bottom: 30px;
	}

	section.reason {
		padding: 50px 0;
	}

	.reason .btn {
		padding: 1.0em 2.8em;
	}

	.menuDrawer a:link,
	a:visited {
		background-color: var(--color-main) !important;
	}

}

@media screen and (max-width: 480px) {
	.contents {
		padding-top: 0px !important;
	}

	#plastering p {
		font-size: 1.3rem;
	}

	.intro .blue-bg {
		font-size: 1.5rem;
		font-feature-settings: "palt";
	}

	h2.intro-heading,
	.reason-heading {
		font-size: 2.2rem;
	}

	.intro-heading {
		margin-bottom: 5px;
	}

	.num-block img {
		width: 35%;
	}

	.even .reason-main-text,
	.odd .reason-main-text {
		font-size: 1.3rem;
	}

	.num-block {
		margin-bottom: 5px;
	}

	.reason .btn {
		padding: 1.1em 2.8em;
		font-size: 1.3rem;
		display: block;
		text-align: center;
	}

	.btn-wrap {
		margin-top: 0px;
	}

	.intro .blue-bg {
		line-height: 2.2;
	}

	h3.reason-subtit {
		font-size: 2.0rem;
	}

	.reason-content.even.flex.flex--between.reason4 {
		align-items: unset;
		padding-top: 40px;
		padding-bottom: 40px;
	}

	.reason-content.odd.flex.flex--between,
	.reason-content.even.flex.flex--between {
		padding: 40px 20px;
	}


	.reason-image {
		margin-bottom: 20px;
	}
}