@charset "UTF-8";

/* ========================================
	style
======================================== */

:root {
	--clip-cut: 70px;
	--clip-height: 70vw;
	--clip-right-x: calc(100vw - var(--clip-cut));
	--clip-right-y: calc(var(--clip-height) - var(--clip-cut));
}

/* --------- ビジネスページ 共通style --------- */

/* -- INTRO section -- */

.intro {
	overflow: hidden;
	margin-top: -2vw;
	padding-bottom: calc(1rem + 6vw);
}

.business__header {
	display: flex;
	flex-direction: column;
	align-items: center;
	z-index: 1;
	margin-bottom: 3rem;
}

.business__image-wrapper {
	position: relative;
	inline-size: 100vw;
	block-size: var(--clip-height);
}

.business__image {
	width: 100%;
	height: 100%;
	clip-path: polygon(
		var(--clip-cut) 0,
		100vw 0,
		100vw var(--clip-right-y),
		var(--clip-right-x) var(--clip-height),
		0 var(--clip-height),
		0 var(--clip-cut)
	);
}

.civil .business__image {
	background:
		var(--filter-image-url) var(--filter-image-option),
		url("images/main-business01.jpg") no-repeat center/cover;
}

.construction .business__image {
	background:
		var(--filter-image-url) var(--filter-image-option),
		url("images/main-business02.jpg") no-repeat center/cover;
}

.quality .business__image {
	background:
		var(--filter-image-url) var(--filter-image-option),
		url("images/main-business03.jpg") no-repeat center/cover;
}

.ict .business__image {
	background:
		var(--filter-image-url) var(--filter-image-option),
		url("images/main-business04.jpg") no-repeat center/cover;
}

.real-estate .business__image {
	background:
		var(--filter-image-url) var(--filter-image-option),
		url("images/main-business05.jpg") no-repeat center/cover;
}

.decor-line {
	position: absolute;
	transform: rotate(-45deg);
	z-index: 2;
}

.left-blue {
	top: 25px;
	left: -34px;
	inline-size: 130px;
	block-size: 6px;
	background-color: var(--nawa-blue);
}

.left-green {
	top: 17px;
	left: -10px;
	inline-size: 70px;
	block-size: 4px;
	background-color: var(--nawa-green);
}

.right-red {
	bottom: 30px;
	right: -33px;
	inline-size: 90px;
	block-size: 7px;
	background-color: var(--nawa-red);
}

.right-green {
	bottom: 15px;
	right: -2px;
	inline-size: 90px;
	block-size: 4px;
	background-color: var(--nawa-green);
}

.business__icon {
	width: 120px;
	aspect-ratio: 134/111;
	background-image: url("/assets/common/images/icon-civil.svg");
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
}

.civil .business__icon {
	background-image: url("/assets/common/images/icon-civil.svg");
}

.real-estate .business__icon {
	background-image: url("/assets/common/images/icon-realestate.svg");
}

.ict .business__icon {
	background-image: url("/assets/common/images/icon-ict.svg");
}

.construction .business__icon {
	background-image: url("/assets/common/images/icon-construction.svg");
}

.quality .business__icon {
	background-image: url("/assets/common/images/icon-quality.svg");
}

.business__title {
	font-size: 3.4rem;
	font-weight: 600;
	text-align: center;
	line-height: 0.8;
	margin-bottom: 2rem;
}

.business__title--en {
	font-size: 1.4rem;
	font-weight: 400;
	font-family: var(--font-family-en);
	color: var(--text-second-color);
}

.business__title--en {
	font-size: 1.4rem;
}

.business__copy {
	text-align: left;
	font-weight: 600;
	margin-bottom: 4rem;
}

/* --------- 土木事業・建築事業部 共通style --------- */

/* -- EXCELLENCE section -- */

.excellence-list {
	display: flex;
	flex-direction: column;
	gap: 2.4em;
	list-style: none;
}

.excellence-item {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	background-color: #fff;
	padding: 2rem 4rem 3rem;

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

.excellence-item::before {
	content: "";
	position: absolute;
	top: 3rem;
	right: 3rem;
	width: 12rem;
	height: 7rem;
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center;
	z-index: 1;
}

.construction-excellence .excellence-item:nth-child(1)::before {
	background-image: url("../../business/construction/images/excellence01.svg");
}

.construction-excellence .excellence-item:nth-child(2)::before {
	background-image: url("../../business/construction/images/excellence02.svg");
}

.construction-excellence .excellence-item:nth-child(3)::before {
	background-image: url("../../business/construction/images/excellence03.svg");
	block-size: 8rem;
}

.excellence-item:nth-child(1)::before {
	background-image: url("../../business/civil-engineering/images/excellence01.svg");
}

.excellence-item:nth-child(2)::before {
	background-image: url("../../business/civil-engineering/images/excellence02.svg");
}

.excellence-item:nth-child(3)::before {
	background-image: url("../../business/civil-engineering/images/excellence03.svg");
}

.excellence-number {
	font-size: 11rem;
	font-family: var(--font-family-en);
	width: 8rem;
	line-height: 1;
	text-align: center;
}

/* 1個目 */
.excellence-item:nth-child(1) .excellence-number {
	color: var(--nawa-green);
}

/* 2個目 */
.excellence-item:nth-child(2) .excellence-number {
	color: var(--nawa-red);
}

/* 3個目 */
.excellence-item:nth-child(3) .excellence-number {
	color: var(--nawa-blue);
}

.excellence-number {
	font-size: 9rem;
	font-family: var(--font-family-en);
	color: var(--num-color);
	width: 8rem;
	line-height: 1;
	text-align: center;
	margin-bottom: 1rem;
}

.excellence-image {
	order: 2;
	margin-bottom: 1em;
}

.excellence-content {
	flex-grow: 1;
	order: 3;
	padding: 0;
}

.excellence-title {
	font-size: clamp(2.2rem, 2.4vw, 2.8rem);
	font-weight: 600;
	line-height: 1.6;
	margin-bottom: 0.8em;
}

.excellence-text {
	line-height: 1.6;
}

/* -- INNOVATION section -- */

.innovation {
	position: relative;
	margin-top: 6rem;
	padding-top: 5rem;
	padding-bottom: 34vw;
	z-index: 0;
}

.innovation::before {
	content: "";
	position: absolute;
	inset: 0;
	background-color: #dbdbdb;
	clip-path: polygon(0 0, 100% 32vw, 100% 100%, 0% 100%);
	z-index: -2;
}

.innovation-case {
	display: grid;
	grid-template-columns: 1fr;
	gap: 5rem;
	max-width: 1200px;
	margin: 0 auto;
	padding: 2rem 1rem;
}

.case-item {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.case-image img {
	width: 100%;
	height: auto;
	display: block;
}

.case-number {
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-family-en);
	font-weight: 500;
	font-size: clamp(2.2rem, 2.4vw, 2.6rem);
	line-height: 1.6;
	background: var(--nawa-green);
	color: white;
	height: 6rem;
	width: 10vw;
	z-index: 1;
}

.case-title-flex {
	display: flex;
	align-items: center;
}

.case-title {
	display: flex;
	align-items: center;
	width: 100%;
	margin-left: -3rem;
	font-size: clamp(1.8rem, 2vw, 2.6rem);
	font-weight: 600;
	line-height: 1.4;
	padding: 3rem 2rem 3rem 5rem;
	background-color: rgba(238, 238, 238, 0.7);
}

.case-description {
	line-height: 1.6;
}

/* -- FIELDS section -- */

.fields {
	position: relative;
	margin-top: -28vw;
	padding-top: 25vw;
	z-index: 0;
}
.fields::before {
	content: "";
	position: absolute;
	inset: 0;
	background-color: var(--gray-100);
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center;
	clip-path: polygon(0 22vw, 100% 0, 100% 100%, 0% 100%);
	z-index: -2;
}

.fields-inner {
	display: flex;
	flex-direction: column;
	gap: 5rem;
	margin-bottom: 4em;
}

.fields-contents {
	display: flex;
	flex-direction: column-reverse;
	gap: 4rem;
}
.fields-text {
	display: flex;
	flex-direction: column;
	flex: 1 1 50%;
	gap: 2rem;
}

.fields-image {
	flex: 1 1 45%;
	aspect-ratio: 2 / 1;
	overflow: hidden;
	box-shadow: 1em 1em 0 var(--gray-200);
	margin-right: 1em;
}

.fields-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* --------- 建築事業部 style --------- */

.intro-department {
	display: flex;
	flex-wrap: wrap;
	max-width: 90%;
	margin-inline: auto;
	gap: 5rem;
	justify-content: center;
	margin-top: 10rem;
	margin-bottom: 6rem;
}

.department-item {
	position: relative;
	background-color: #fff;
	flex: 1;
	min-width: 270px;
	display: flex;
	flex-direction: column;
	box-shadow: 0 24px 30px rgba(0, 116, 60, 0.1);
}

.department-item::before {
	content: "";
	position: absolute;
	top: -0.8rem;
	left: 2rem;
	inline-size: 10px;
	block-size: 46px;
	background-color: var(--nawa-green);
}

.department-text {
	flex: 1;
	padding: 3rem;
}

.department-text h3 {
	font-size: 1.6em;
	font-weight: 700;
	margin-bottom: 2rem;
	text-align: center;
}

.department-text p {
	font-size: 0.88em;
	line-height: 1.7;
}

.department-image img {
	width: 100%;
	height: auto;
}

/* --------- 試験部 style --------- */

/* -- CAPABILITIES section -- */

.capabilities {
	position: relative;
	padding-bottom: calc(6rem + 8vw);
	z-index: 0;
}

.capabilities .title-band {
	margin-bottom: 0;
}

.capabilities-items {
	display: flex;
	flex-direction: column;
	gap: 9rem;
}

.capabilities-item {
	display: flex;
	flex-direction: column;
	gap: 3.5rem;
}

.capabilities-wrapper {
	display: flex;
	gap: 2rem;
	flex-direction: column;
}

.capabilities-contents {
	flex: 1;
}

.capabilities h4 {
	position: relative;
	font-size: clamp(1.8rem, 2vw, 2.6rem);
	font-weight: 700;
	margin-bottom: 3rem;
}

.capabilities h4::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -0.6rem;
	width: 100%;
	height: 2px;
	background: linear-gradient(to right, var(--nawa-green) 16%, var(--gray-200) 16%);
}

.capabilities-text {
	/* padding-bottom: 2rem; */
	line-height: 1.7;
}

.test-box {
	position: relative;
	border: 1px solid var(--gray-300);
	border-radius: 4px;
	padding: 2rem 2rem 1.6rem;
	margin-top: 3.5rem;
}

.test-title {
	position: absolute;
	font-size: 1.2rem;
	font-weight: 600;
	line-height: 1;
	display: inline-block;
	background-color: var(--black);
	color: #fff;
	padding: 0.5rem 2rem 0.7rem;
	top: -1.6rem;
}

.test-text {
	font-size: 1.2rem;
	line-height: 1.6;
}

.capabilities-image-box {
	display: flex;
	gap: 2rem;
}

.capabilities-image img {
	width: 100%;
	height: auto;
	display: block;
}

/* -- 研究所リンク section -- */

.dksiken {
	background-color: var(--gray-200);
	padding-block: 8rem;
}

.dksiken-link {
	display: flex;
	flex-direction: column;
	background-color: #fff;
	text-decoration: none;
	color: inherit;
	box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
}

.dksiken__image {
	aspect-ratio: 2 / 1;
	width: 100%;
	overflow: hidden;
}

.dksiken__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.dksiken-link__content {
	text-align: center;
	padding: 3rem;
}

.dksiken-link__logo {
	width: min(90%, 400px);
	height: auto;
	margin-bottom: 0.6rem;
}

.dksiken-link__text {
	font-weight: bold;
	font-size: 1.2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.8rem;
}

.dksiken-link__icon svg {
	width: 1rem;
	height: auto;
	display: inline-block;
}

.note-ast {
	list-style: none;
	font-size: 1.4rem;
	line-height: 1.8;
	margin-inline: auto;
	margin-bottom: 2rem;
}

.note-ast li {
	display: flex;
	align-items: flex-start;
	gap: 0.5em;
}

.note-ast__mark {
	color: var(--nawa-green);
	font-weight: bold;
	flex-shrink: 0;
	width: 1.2em;
	text-align: center;
}

.note-ast__text {
	flex: 1;
}

/* --------- ICT事業部 style --------- */

/* -- ABOUT section -- */

.about-wrapper {
	display: flex;
	flex-direction: column;
	margin-bottom: 6rem;
	gap: min(4vw, 5rem);
}

.about-text {
	flex: 1;
}

.about-text p {
	line-height: 1.8;
}

.about__note {
	margin-top: 2rem;
}

.about__image {
	width: 100%;
	aspect-ratio: 3 / 2;
	background-image: url("../ict-solutions/images/sitech.jpg");
	background-size: cover;
	background-position: center;
}

.ict-box {
	background-color: #fff;
	padding: 3rem;
	display: flex;
	flex-direction: column;
	gap: 3rem;
}

.ict-box-title {
	background-color: var(--black);
	color: #fff;
	text-align: center;
	font-weight: 700;
	font-size: 2rem;
	padding: 0.8rem;
}

.ict-text-wrapper {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 3rem;
}

.ict-text {
	font-size: 1.2rem;
}

.iconstruction-logo {
	width: min(40%, 300px);
	aspect-ratio: 383 / 174;
	background-image: url("../ict-solutions/images/iconstruction.png");
	background-size: cover;
	background-position: center;
}

.ict-table-wrapper {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}

.ict-table {
	border-collapse: collapse;
	line-height: 1.7;
	min-width: 500px;
}

.ict-table th,
.ict-table td {
	border: 1px solid var(--line-gray);
	padding: 0.6em 1.2em;
	font-size: 1.2rem;
}

.ict-table tbody th {
	color: var(--gray-300);
	text-align: center;
	font-weight: 600;
	inline-size: 18%;
}

.ict-table tbody td {
	inline-size: 41%;
}

.ict-table thead th {
	font-weight: 600;
	text-align: center;
	font-size: 1.4rem;
	block-size: 5rem;
}

.ict-table thead th:nth-child(2) {
	background-color: var(--nawa-green);
	color: #fff;
}

.ict-table thead th:nth-child(3) {
	background-color: var(--gray-200);
}

.ict-table tbody td:nth-child(2) {
	background-color: rgba(17, 136, 80, 0.1);
	font-weight: 600;
}

.pdf-button {
	background-color: var(--black);
	color: #fff;
	padding: 1.2rem 3rem;
	font-size: 1.2rem;
	line-height: 1;
	border-radius: 5px;
	text-decoration: none;
	position: relative;
	transition: background-color 0.3s ease;
	text-align: center;
	white-space: nowrap;
}

.button-wrapper {
	text-align: center;
	margin-top: clamp(6rem, 6vw, 8rem);
}

.pdf-button::after {
	content: "";
	display: inline-block;
	width: 1.6rem;
	height: 1.6rem;
	margin-left: 0.6rem;
	background-image: url("images/icon-pdf.svg");
	background-repeat: no-repeat;
	background-size: contain;
	vertical-align: middle;
	transition: filter 0.3s ease;
	transform: translateY(-1px);
}

.pdf-button:hover {
	background-color: var(--nawa-green);
}

.about-wrapper .white__note {
	margin-top: 1rem;
}

/* -- SERVICE section -- */

.service {
	padding-top: clamp(10rem, 12vw, 18rem);
}

/* --------- 不動産事業部 style --------- */

/* -- BtoB BtoC section -- */

.for-bc .title-section {
	margin-bottom: clamp(4rem, 5vw, 6rem);
}

.for-bc.btob {
	margin-bottom: 8em;
}

.for-bc-wrapper {
	display: flex;
	flex-direction: column;
	gap: 5rem;
}

.for-bc-intro {
	display: flex;
	flex-direction: column;
	gap: 3rem;
}

.for-business-image,
.for-customer-image {
	inline-size: 100%;
	aspect-ratio: 35 / 20;
	background-size: cover;
	background-position: center;
}

.for-business-image {
	background:
		var(--filter-image-url) var(--filter-image-option),
		url("../real-estate/images/img-section01.jpg") no-repeat center/cover;
}

.for-customer-image {
	background:
		var(--filter-image-url) var(--filter-image-option),
		url("../real-estate/images/img-section02.jpg") no-repeat center/cover;
}

.point-wrapper {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
}

.point {
	position: relative;
	background-color: #fff;
	padding: 4rem 2rem 3rem;
}

.point::before {
	content: "";
	position: absolute;
	top: -0.8rem;
	left: 1.2rem;
	inline-size: 10px;
	block-size: 40px;
	background-color: var(--nawa-green);
}

.point h3 {
	position: relative;
	padding-left: 4rem;
	margin-bottom: 3rem;
	font-size: clamp(1.8rem, 2.2vw, 2.6rem);
	font-weight: 600;
	line-height: 1.6;
}

.point h3::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -1rem;
	width: 100%;
	height: 2px;
	background: linear-gradient(to right, var(--nawa-green) 40%, var(--gray-200) 40%);
}

.point h3 span {
	position: absolute;
	font-size: clamp(2.2rem, 2.8vw, 3.2rem);
	font-weight: 400;
	line-height: 1.4;
	left: 0.6rem;
	top: 0;
	color: var(--nawa-green);
	font-family: var(--font-family-en);
}

.sc-text-wrapper {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 1.4rem;
	background-color: var(--nawa-green);
	color: #fff;
	border-radius: 5px;
	padding: 2.4rem 3rem;
	margin-top: 5rem;
	margin-bottom: 1rem;
	font-weight: 600;
	z-index: 2;
}

.sc-text-wrapper::after {
	content: "";
	position: absolute;
	bottom: 1px;
	left: 20%;
	transform: translateX(-50%) translateY(100%);
	width: 18px;
	aspect-ratio: 32/39;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='32' height='39' viewBox='0 0 32 39' fill='none'><path d='M32 39L0 0L32 0L32 39Z' fill='%23118850'/></svg>");
	background-repeat: no-repeat;
	background-size: contain;
	pointer-events: none;
}

.sc-note {
	font-size: 1.2rem;
}

.sc-info-wrapper {
	margin-bottom: 2rem;
}

.sc-info-image {
	width: 100%;
	aspect-ratio: 72 / 50;
	background-image: url("../real-estate/images/img-salescenter01.jpg");
	background-size: cover;
	background-position: center;
}

.sc-info-table-wrapper {
	background-color: #fff;
	padding: 2.2rem;
}

.sc-info-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 1.2rem;
}

.sc-info-table tr {
	border-block: 1px solid var(--nawa-green);
}

.sc-info-table th,
.sc-info-table td {
	vertical-align: middle;
	padding: 1.4rem 1rem;
}

.sc-info-table th {
	white-space: nowrap;
	font-weight: 500;
	color: var(--text-second-color);
	padding-right: 2rem;
}

.info-gallery-wrapper {
	display: flex;
	gap: 1rem;
}

.info-gallery {
	width: 100%;
	aspect-ratio: 113 / 100;
	background-size: cover;
	background-position: center;
}

.info-gallery:nth-child(1) {
	background-image: url("../real-estate/images/img-salescenter02.jpg");
}

.info-gallery:nth-child(2) {
	background-image: url("../real-estate/images/img-salescenter03.jpg");
}

.info-gallery:nth-child(3) {
	background-image: url("../real-estate/images/img-salescenter04.jpg");
}

/* -- 不動産事業部お問合せ -- */

.contact-footer .square-button {
	margin-top: 5em;
}

/* ========================================
	1024px未満専用スタイル（TAB）
======================================== */
@media screen and (width < 1024px) {
	/* --------- 建築事業部 style --------- */

	.intro-department {
		max-width: 95%;
		gap: 5rem 3rem;
	}
}

/* ========================================
	768px未満専用スタイル（SP）
======================================== */
@media screen and (width < 768px) {
	/* --------- 建築事業部 style --------- */

	.fields-image {
		/* flex: 1 1 45%; */
		aspect-ratio: unset;
		block-size: 45vw;
		margin-right: 1em;
	}
}

/* ========================================
	768px以上（PC&TAB）
======================================== */
@media screen and (768px <=width) {
	:root {
		--clip-cut: 180px;
		--clip-height: 540px;
	}

	/* --------- ビジネスページ 共通style --------- */

	/* -- INTRO section -- */

	.intro {
		margin-top: -6vw;
	}

	.business__image {
		clip-path: polygon(
			var(--clip-cut) 0,
			100vw 0,
			100vw var(--clip-right-y),
			var(--clip-right-x) var(--clip-height),
			0 var(--clip-height),
			0 var(--clip-cut)
		);
	}

	.left-blue {
		top: 90px;
		left: -100px;
		inline-size: 330px;
		block-size: 10px;
	}

	.left-green {
		top: 70px;
		left: -20px;
		inline-size: 160px;
		block-size: 6px;
	}

	.right-red {
		bottom: 80px;
		right: -45px;
		inline-size: 200px;
		block-size: 10px;
	}

	.right-green {
		bottom: 50px;
		right: -5px;
		inline-size: 230px;
		block-size: 6px;
	}

	.construction-excellence .excellence-item:nth-child(3)::before {
		block-size: 11rem;
		top: 50%;
	}

	/* --------- 土木事業・建築事業部 共通style --------- */

	/* -- EXCELLENCE section -- */

	.excellence-item {
		flex-direction: row;
		align-items: center;
		padding: 2rem 18rem 2rem 6rem;
		clip-path: polygon(45px 0, 100% 0, 100% calc(100% - 45px), calc(100% - 45px) 100%, 0 100%, 0 45px);
	}

	.excellence-item::before {
		top: 50%;
		right: 4rem;
		transform: translateY(-50%);
		width: 14rem;
		height: 9rem;
	}

	.excellence-number {
		font-size: 16rem;
	}

	.excellence-image {
		order: 1;
		margin-bottom: 0;
	}

	.excellence-content {
		order: 1;
		padding: 0 2em 0 4em;
	}

	/* -- INNOVATION section -- */

	.innovation {
		padding-top: 13rem;
		padding-bottom: 26vw;
	}

	.case-item {
		gap: 3rem;
	}

	.innovation-case {
		grid-template-columns: 1fr 1fr;
		gap: 4vw;
		padding: 0;
	}

	.case-number {
		inline-size: 6vw;
		height: 4.5rem;
	}

	.case-title {
		margin-left: -4rem;
		padding-left: 5.5rem;
	}

	/* -- FIELDS section -- */

	.fields {
		padding-top: 19vw;
	}

	.fields-inner {
		gap: 8rem;
		margin-bottom: 10em;
	}

	.fields-contents {
		flex-direction: row;
		gap: 5rem;
	}

	.fields-text {
		gap: 4rem;
	}

	.capabilities h4 {
		margin-bottom: 4rem;
	}

	.capabilities-sub-item {
		flex-direction: row;
		align-items: flex-start;
	}

	.capabilities-wrapper {
		flex-direction: row;
	}

	.capabilities-contents {
		flex: 1;
		padding-right: 2rem;
	}

	.capabilities-items {
		gap: 11rem;
	}

	.capabilities-item {
		gap: 5rem;
	}

	.capabilities-image-box {
		flex: 1;
		flex-direction: row;
	}

	.capabilities-image {
		flex: 1;
	}

	/* --------- 建築事業部 style --------- */

	.department-item {
		box-shadow: 0 30px 40px rgba(0, 116, 60, 0.1);
	}

	/* --------- 試験部 style --------- */

	/* -- CAPABILITIES section -- */

	.test-box {
		padding: 3rem 2rem 2rem;
		margin-top: 4rem;
	}

	/* -- 研究所リンク section -- */

	.dksiken-link {
		flex-direction: row;
		align-items: center;
		margin-inline: auto;
		inline-size: 80%;
	}

	.dksiken__image {
		flex: 0 0 45%;
		aspect-ratio: 7 / 3;
	}

	.dksiken-link__content {
		padding: 1rem;
	}

	.dksiken-link__text {
		font-size: 1.6rem;
	}
	.note-ast {
		text-align: center;
		justify-content: center;
	}

	.note-ast li {
		display: inline-flex;
		justify-content: center;
	}

	.note-ast__text {
		text-align: left;
	}

	/* --------- ICT事業部 style --------- */

	/* -- ABOUT section -- */

	.about-wrapper {
		flex-direction: row;
		align-items: stretch;
	}

	.about-text {
		flex: 6;
	}

	.about__image {
		flex: 4;
		aspect-ratio: auto;
		block-size: auto;
	}

	.about__note {
		margin-top: 4rem;
	}

	.ict-box {
		padding: 5rem 8rem 8rem;
		gap: 5rem;
	}

	.ict-text-wrapper {
		display: flex;
		flex-direction: row-reverse;
		gap: 6rem;
	}

	.ict-text {
		font-size: 1.4rem;
		flex: 0 1 80%;
	}

	.iconstruction-logo {
		flex: 0 1 20%;
		min-width: 160px;
	}

	.ict-table {
		min-width: 700px;
	}

	.ict-table th,
	.ict-table td {
		padding: 1.2em 1.2em;
	}

	.pdf-button {
		padding: 1.2rem 8rem;
		font-size: 1.5rem;
	}

	.pdf-button::after {
		inline-size: 1.8rem;
		block-size: 1.8rem;
		margin-left: 0.8rem;
		transform: translateY(-2px);
	}

	/* --------- 不動産事業部 style --------- */

	/* -- BtoB BtoC section -- */

	.for-bc.btob {
		margin-bottom: 10em;
	}

	.for-bc-wrapper {
		gap: 8rem;
	}

	.for-bc-intro {
		flex-direction: column-reverse;
	}

	.for-business-image,
	.for-customer-image {
		aspect-ratio: 60 / 19;
	}

	.point-wrapper {
		grid-template-columns: 1fr 1fr;
		gap: 5rem;
	}

	.point {
		position: relative;
		background-color: #fff;
		padding: 5rem 3rem 4rem;
	}

	.point::before {
		top: -1rem;
		left: 1.6rem;
		inline-size: 14px;
		block-size: 44px;
	}

	.point h3 {
		padding-left: 6rem;
		margin-bottom: 5rem;
		/* font-size: 2.6rem; */
	}

	.point h3::after {
		bottom: -1.4rem;
	}

	.point h3 span {
		position: absolute;
		/* font-size: 3.2rem; */
		font-weight: 400;
		line-height: 1.4;
		left: 0.6rem;
		top: 0;
		color: var(--nawa-green);
		font-family: var(--font-family-en);
	}

	.sc-text-wrapper {
		margin-top: 8rem;
		margin-bottom: 3rem;
		margin-right: 1rem;
		text-align: center;
		box-shadow: 1rem 1rem 0 var(--gray-200);
	}

	.sc-text {
		font-size: 2rem;
	}

	.sc-text-wrapper::after {
		left: 16%;
		inline-size: 38px;
		aspect-ratio: 32/39;
		filter: drop-shadow(1rem 1rem 0 var(--gray-200));
	}

	.sc-note {
		font-size: 1.6rem;
	}

	.sc-info-wrapper {
		display: flex;
		margin-bottom: 2rem;
	}

	.sc-info-image {
		flex: 0 0 60%;
		aspect-ratio: 7 / 4;
	}

	.sc-info-table-wrapper {
		flex: 0 0 40%;
		padding: 3rem;
	}

	.sc-info-table {
		font-size: 1.4rem;
	}

	.sc-info-table th {
		padding-right: 3rem;
	}

	.info-gallery {
		aspect-ratio: 40 / 26;
	}
}

/* ========================================
	768px以上1180px未満専用スタイル（TAB）
======================================== */
@media screen and (768px <=width < 1180px) {
	:root {
		--clip-cut: 120px;
		--clip-height: 400px;
	}

	/* --------- ビジネスページ 共通style --------- */

	/* -- INTRO section -- */

	.left-blue {
		top: 90px;
		left: -155px;
		inline-size: 330px;
		block-size: 10px;
	}

	.left-green {
		top: 70px;
		left: -70px;
		inline-size: 160px;
		block-size: 6px;
	}

	.right-red {
		bottom: 80px;
		right: -100px;
		inline-size: 200px;
		block-size: 10px;
	}

	.right-green {
		bottom: 50px;
		right: -62px;
		inline-size: 230px;
		block-size: 6px;
	}

	.sc-info-wrapper {
		display: block;
	}

	/* --------- 土木事業・建築事業部 共通style --------- */

	/* -- EXCELLENCE section -- */

	.excellence-item {
		padding: 3rem 16rem 3rem 5rem;
	}

	.excellence-item::before {
		right: 3rem;
		width: 14rem;
		height: 9rem;
	}

	.excellence-number {
		font-size: 14rem;
	}

	.excellence-content {
		order: 1;
		padding: 0 2em 0 3em;
	}

	.excellence-title {
		margin-bottom: 0.5em;
	}

	/* --------- 土木事業・建築事業部 共通style --------- */

	/* -- FIELDS section -- */

	.fields-contents {
		gap: 3rem;
	}

	/* --------- 建築事業部 style --------- */

	.department-text {
		padding: 3vw 4vw;
	}

	/* --------- ICT事業部 style --------- */

	/* -- ABOUT section -- */

	.ict-text-wrapper {
		gap: 4rem;
	}

	.ict-box {
		padding: 4rem 6rem 8rem;
		gap: 4rem;
	}

	/* --------- 不動産事業部 style --------- */

	/* -- BtoB BtoC section -- */

	.point {
		padding: 4rem 3rem 3rem;
	}

	.point-wrapper {
		gap: 4rem 3rem;
	}

	.point h3 {
		padding-left: 5vw;
	}
}

/* ========================================
	1180px以上専用スタイル（PC）
======================================== */
@media print, screen and (1180px <=width) {
	/* --------- ビジネスページ 共通style --------- */

	/* -- INTRO section -- */

	.business__icon {
		inline-size: 170px;
	}

	.business__title {
		font-size: 5.4rem;
		margin-bottom: 5rem;
	}

	.business__title--en {
		font-size: 2rem;
	}

	.business__copy {
		text-align: center;
		margin-bottom: 5rem;
	}

	/* -- INNOVATION section -- */

	.innovation-case {
		gap: 7rem;
	}

	.case-number {
		width: 100px;
	}

	/* --------- 建築事業部 style --------- */

	.department-text {
		padding: 5rem 5rem 4rem;
	}

	.department-item::before {
		top: -0.8rem;
		left: 3rem;
		inline-size: 14px;
		block-size: 70px;
	}

	/* --------- 試験部 style --------- */

	.test-title {
		font-size: 1.4rem;
	}

	.test-text {
		font-size: 1.4rem;
	}

	/* --------- ICT事業部 style --------- */

	/* -- ABOUT section -- */

	.ict-table th,
	.ict-table td {
		font-size: 1.6rem;
	}

	.ict-table thead th {
		font-size: 1.8rem;
	}
}

/* ========================================
	1200px以上専用スタイル（PC）
======================================== */
@media print, screen and (1200px <=width) {
	/* --------- 不動産事業部 style --------- */

	/* -- BtoB BtoC section -- */

	.for-bc-intro {
		text-align: center;
	}
}
