/*====================
機材センター（/equipment）
インナー最大幅: 1520px / 紺: #16346D
====================*/

.equipment-page {
	display: block;
	background: var(--color-topics-bg, #f4fafe);
}

/* 機材センター sub-kv（英字・右寄せ・長文改行） */
.page-equipment .sub-kv__title-en {
	letter-spacing: -0.01em;
	text-align: right;
}

.page-equipment .sub-kv__title-en--pc {
	font-size: clamp(72px, 8.5vw, 128px);
	line-height: 0.88;
}

@media screen and (max-width: 1919px) {
	.page-equipment .sub-kv__title-en--pc {
		max-width: min(52vw, 720px);
	}
}

@media screen and (max-width: 1279px) {
	.page-equipment .sub-kv__title-en--sp {
		right: clamp(16px, 4vw, 32px);
		max-width: calc(100% - clamp(32px, 8vw, 64px));
		font-size: clamp(36px, 8.5vw, 52px);
		line-height: 0.88;
		text-align: right;
	}
}

@media screen and (max-width: 600px) {
	.page-equipment .sub-kv__title-en--sp {
		right: 16px;
		max-width: calc(100% - 32px);
		font-size: clamp(30px, 8.8vw, 44px);
	}
}

@media screen and (max-width: 374px) {
	.page-equipment .sub-kv__title-en--sp {
		font-size: 28px;
	}
}

.equipment-page__inner {
	box-sizing: border-box;
	width: 100%;
	max-width: 1520px;
	margin-inline: auto;
	padding: 48px 16px 0px;
}

@media screen and (max-width: 600px) {
	.equipment-page__inner {
		padding-bottom: 0;
	}
}

/* --------------------------------------------------------------------------
   BOX1（セクション1・イントロ）— construction-intro と同型
   -------------------------------------------------------------------------- */
.equipment-intro__outer {
	box-sizing: border-box;
	position: relative;
	width: 1400px;
	max-width: calc(100% - 32px);
	margin: 0 auto;
	padding: 48px 16px 0;
}

@media screen and (max-width: 1919px) {
	.equipment-intro__outer {
		width: 100%;
		max-width: 1720px;
	}
}

@media screen and (max-width: 600px) {
	.equipment-intro__outer {
		padding: 32px 16px 0;
	}
}

.equipment-box1 {
	position: relative;
	z-index: 1;
	margin-bottom: 64px;
	padding-bottom: clamp(48px, 8vw, 93px);
}

@media screen and (max-width: 600px) {
	.equipment-box1 {
		margin-bottom: 48px;
		padding-bottom: 56px;
	}
}

.equipment-box1__bg {
	position: absolute;
	bottom: 0;
	left: -0.04em;
	z-index: 0;
	margin: 0;
	color: rgba(22, 52, 109, 0.06);
	font-family: var(--font-en);
	font-size: clamp(80px, 14vw, 180px);
	font-style: italic;
	font-weight: 500;
	line-height: 1;
	letter-spacing: -0.01em;
	white-space: nowrap;
	pointer-events: none;
	user-select: none;
}

@media screen and (max-width: 600px) {
	.equipment-box1__bg {
		left: -0.08em;
		font-size: clamp(64px, 18vw, 120px);
	}
}

.equipment-box1__inner {
	position: relative;
	z-index: 1;
}

.equipment-intro__inner {
	box-sizing: border-box;
	width: 100%;
	max-width: none;
	margin-inline: auto;
}

@media screen and (max-width: 1919px) {
	.equipment-intro__inner {
		max-width: 1480px;
	}
}

.equipment-intro__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(300px, 46%);
	gap: clamp(24px, 3vw, 48px);
	align-items: center;
	width: 100%;
	max-width: 1400px;
	margin-inline: auto;
}

@media screen and (max-width: 900px) {
	.equipment-intro__grid {
		grid-template-columns: 1fr;
	}
}

.equipment-intro__title {
	margin: 0 0 40px;
	color: #16346d;
	font-size: 32px;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.12em;
}

@media screen and (max-width: 600px) {
	.equipment-intro__grid {
		align-items: stretch;
	}

	.equipment-intro__media {
		order: -1;
		width: 100%;
		max-width: 100%;
	}

	.equipment-intro__title {
		margin-bottom: 24px;
		font-size: 24px;
		letter-spacing: 0.03em;
	}
}
@media screen and (max-width: 468px) {
	.equipment-intro__title {
		font-size: 22px;
		letter-spacing: -0.02em;
		line-height: 1.5;
	}
}
@media screen and (max-width: 374px) {
	.equipment-intro__title {
		font-size: 20px;
		letter-spacing: -0.03em;
	}
}

.equipment-intro__title.js-anim-sweep {
	display: inline-block;
	width: fit-content;
	max-width: 100%;
	vertical-align: top;
}

.equipment-intro__title .js-anim-sweep__content {
	display: block;
	color: #16346d;
}

.equipment-intro__text {
	color: #16346d;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.8;
	letter-spacing: 0.12em;
}

@media screen and (max-width: 600px) {
	.equipment-intro__text {
		font-size: 14px;
		letter-spacing: 0.13em;
	}
}

.equipment-intro__text-p {
	margin: 0 0 1em;
}

.equipment-intro__text-p:last-child {
	margin-bottom: 0;
}

.equipment-intro__media {
	position: relative;
	min-width: 0;
}

.equipment-intro__tri-stack {
	margin-left: auto;
	margin-right: 0;
	overflow: visible;
}

/* 機材センター：三角形PNG + 装飾三角（建築部より少し右寄せ・配色差） */
.equipment-intro__tri-stack .tri-stack__picture,
.equipment-intro__tri-stack .tri-stack__picture img {
	object-fit: contain;
	object-position: center;
}

.equipment-intro__tri-stack .tri-stack__shard--1 {
	top: 10%;
	left: 14%;
	z-index: 2;
	width: 74%;
	height: 80%;
	background: rgba(var(--tri-stack-16346d), 0.82);
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
	transform: translate(2%, 5%);
}

.equipment-intro__tri-stack .tri-stack__photo {
	z-index: 3;
}

.equipment-intro__tri-stack .tri-stack__shard--2 {
	top: -2%;
	right: -2%;
	width: 52px;
	height: 44px;
	background: rgba(var(--tri-stack-35566b), 0.9);
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.equipment-intro__tri-stack .tri-stack__shard--3 {
	bottom: 10%;
	left: -4%;
	width: 68px;
	height: 54px;
	background: rgba(var(--tri-stack-16346d), 0.86);
	clip-path: polygon(100% 50%, 0 0, 0 100%);
}

.equipment-intro__tri-stack .tri-stack__shard--4 {
	bottom: -1%;
	left: 28%;
	width: 44px;
	height: 36px;
	background: rgba(var(--tri-stack-92c8ea), 0.62);
	clip-path: polygon(50% 100%, 0 0, 100% 0);
}

.equipment-intro__tri-stack .tri-stack__shard--5 {
	bottom: 8%;
	right: 0;
	width: 40px;
	height: 34px;
	background: rgba(var(--tri-stack-b7d7eb), 0.58);
	clip-path: polygon(0 0, 100% 0, 50% 100%);
}

.equipment-intro__tri-stack .tri-stack__shard--6 {
	bottom: 18%;
	right: 10%;
	width: 34px;
	height: 30px;
	background: rgba(var(--tri-stack-9ad7ff), 0.52);
	clip-path: polygon(100% 0, 0 50%, 100% 100%);
}

@media screen and (max-width: 600px) {
	.equipment-intro__tri-stack {
		margin-left: 0;
		margin-right: 0;
	}

	.equipment-intro__tri-stack .tri-stack__shard--1 {
		top: 12%;
		left: 10%;
		width: 82%;
		height: 76%;
		transform: translate(0, 4%);
	}

	.equipment-intro__tri-stack .tri-stack__shard--2 {
		width: 40px;
		height: 34px;
	}

	.equipment-intro__tri-stack .tri-stack__shard--3 {
		left: -2%;
		width: 58px;
		height: 46px;
	}

	.equipment-intro__tri-stack .tri-stack__shard--4 {
		left: 22%;
		width: 40px;
		height: 32px;
	}

	.equipment-intro__tri-stack .tri-stack__shard--5 {
		width: 34px;
		height: 28px;
	}

	.equipment-intro__tri-stack .tri-stack__shard--6 {
		width: 28px;
		height: 24px;
	}
}

.equipment-intro__yuragi-slot {
	--equipment-intro-yuragi-w: 272px;
	--equipment-intro-yuragi-h: 129px;

	position: absolute;
	z-index: 0;
	bottom: 0;
	left: 0;
	width: var(--equipment-intro-yuragi-w);
	height: var(--equipment-intro-yuragi-h);
	overflow: visible;
	pointer-events: none;
}

@media screen and (max-width: 600px) {
	.equipment-intro__yuragi-slot {
		--equipment-intro-yuragi-w: 218px;
		--equipment-intro-yuragi-h: 103px;

		transform: scale(0.8);
		transform-origin: left bottom;
	}
}

.equipment-intro__yuragi {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: visible;
}

.equipment-intro__yuragi-shape {
	position: absolute;
	display: block;
	transform-origin: 50% 50%;
}

.equipment-intro__yuragi-shape--1 {
	top: 40px;
	left: 12px;
	width: 52px;
	height: 30px;
	background: rgba(100, 129, 184, 0.42);
	clip-path: polygon(0 30%, 100% 0, 100% 100%);
}

.equipment-intro__yuragi-shape--2 {
	top: 108px;
	left: 68px;
	width: 14px;
	height: 16px;
	background: rgba(22, 52, 109, 0.82);
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
}

.equipment-intro__yuragi-shape--3 {
	top: 114px;
	left: 0;
	width: 108px;
	height: 96px;
	background: rgba(183, 215, 235, 0.48);
	clip-path: polygon(0 100%, 100% 8%, 92% 100%);
}

/* --------------------------------------------------------------------------
   セクション2（主な取り扱い機材・工法）
   -------------------------------------------------------------------------- */
.equipment-products {
	margin-bottom: 72px;
}

@media screen and (max-width: 600px) {
	.equipment-products {
		margin-bottom: 48px;
	}
}

.equipment-products__head {
	position: relative;
	box-sizing: border-box;
	width: 100%;
	max-width: 1520px;
	margin-inline: auto;
	margin-bottom: 32px;
	padding: 8px 16px 0;
	text-align: center;
}
@media screen and (max-width: 600px) {
	.equipment-products__head {
		padding: 8px 8px 0;
	}
}

.equipment-products__badge {
	position: relative;
	z-index: 1;
	display: inline-flex;
	align-items: stretch;
	justify-content: center;
	margin: 0 0 16px;
	padding: 0;
}

.equipment-products__badge-tri {
	display: block;
	flex: 0 0 18px;
	width: 18px;
	height: 40px;
	background-color: #16346d;
}

.equipment-products__badge-tri--left {
	clip-path: polygon(100% 0, 100% 100%, 0 50%);
	transform: translateX(1px);
}

.equipment-products__badge-tri--right {
	clip-path: polygon(0 0, 0 100%, 100% 50%);
	transform: translateX(-1px);
}

.equipment-products__badge-text {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	height: 40px;
	padding: 0 16px;
	background-color: #16346d;
	color: #fff;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.3;
	letter-spacing: 0.13em;
	white-space: nowrap;
}

@media screen and (max-width: 600px) {
	.equipment-products__badge-text {
		font-size: 14px;
	}
}

.equipment-products__title {
	position: relative;
	z-index: 1;
	margin: 0;
	color: #16346d;
	font-size: 32px;
	font-weight: 700;
	line-height: 1.3;
	letter-spacing: 0.13em;
}

@media screen and (max-width: 600px) {
	.equipment-products__title {
		font-size: 24px;
	}
}

.equipment-products__title.js-anim-sweep {
	display: table;
	width: fit-content;
	max-width: 100%;
	margin-inline: auto;
	vertical-align: top;
}

.equipment-products__title .js-anim-sweep__content {
	display: block;
	color: #16346d;
}

.equipment-products__inner {
	box-sizing: border-box;
	width: 100%;
	max-width: 1520px;
	margin-inline: auto;
	padding-inline: 16px;
}

@media screen and (max-width: 600px) {
	.equipment-products__inner {
		padding-inline: 0;
	}
}
/* --------------------------------------------------------------------------
   セクション3（画像のみ）
   -------------------------------------------------------------------------- */
.equipment-visual {
	margin: 0;
	text-align: center;
}

.equipment-visual__inner {
	box-sizing: border-box;
	width: 100%;
	max-width: 760px;
	margin: 64px auto;
	padding-inline: 16px;
}

.equipment-visual__inner .js-anim-build-up__item {
	width: 100%;
}

.equipment-visual__link {
	display: block;
	width: fit-content;
	max-width: 100%;
	margin-inline: auto;
}

.equipment-visual__link:focus-visible {
	outline: 2px solid #16346d;
	outline-offset: 4px;
}

@media screen and (max-width: 600px) {
	.equipment-visual__inner {
		margin: 48px auto;
	}
}

.equipment-visual__picture {
	display: block;
	width: auto;
	max-width: 100%;
	height: auto;
	margin-inline: auto;
}

.equipment-visual__picture img {
	display: block;
	width: auto;
	max-width: 100%;
	height: auto;
	margin-inline: auto;
}

/* 工法セクション1（クイックデッキ / クイックデッキライト） */
.equipment-methods--1 {
	display: flex;
	flex-wrap: wrap;
	gap: clamp(24px, 3vw, 40px);
	align-items: stretch;
	margin-bottom: 32px;
}

@media screen and (max-width: 900px) {
	.equipment-methods--1 {
		flex-direction: column;
	}
}

.equipment-methods--1 .equipment-method {
	display: flex;
	flex: 1 1 0;
	flex-direction: column;
	min-width: 0;
}

.equipment-methods--1 .equipment-method__body {
	box-sizing: border-box;
	flex: 1;
	padding: 16px;
	background-color: #ffffff;
}

.equipment-methods--1 .equipment-method__intro {
	box-sizing: border-box;
	min-height: 110px;
	margin-bottom: 16px;
}

@media screen and (max-width: 900px) {
	.equipment-methods--1 .equipment-method__intro {
		min-height: auto;
		margin-bottom: 12px;
	}
}

@media screen and (max-width: 600px) {
	.equipment-methods--1 .equipment-method__intro {
		margin-bottom: 16px;
	}
}

/* 工法セクション2（VMAX） */
.equipment-methods--2 {
	margin-bottom: 32px;
}

.equipment-methods--2 .equipment-method__body {
	box-sizing: border-box;
	display: flex;
	flex-wrap: wrap;
	gap: clamp(16px, 2.5vw, 24px);
	align-items: flex-start;
	padding: 16px;
	background-color: #ffffff;
}

.equipment-methods--2 .equipment-method__intro {
	flex: 1 1 280px;
	min-width: 0;
	margin-bottom: 0;
}

@media screen and (max-width: 900px) {
	.equipment-methods--2 .equipment-method__intro {
		flex: none;
		width: 100%;
		margin-bottom: 0;
	}
}

.equipment-methods--2 .equipment-product__gallery {
	flex: 1 1 280px;
	min-width: 0;
}

.equipment-methods .equipment-method__title::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	background-image: var(--equipment-method-title-bg);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	opacity: 0.5;
	pointer-events: none;
}

.equipment-methods--2 .equipment-method__title::before,
.equipment-methods--3 .equipment-method__title::before {
	background-size: 100% 100%;
}

/* 工法セクション3（マルチアングル工法） */
.equipment-methods--3 {
	margin-bottom: 32px;
}

.equipment-methods--3 .equipment-method__body {
	box-sizing: border-box;
	padding: 16px;
	background-color: #ffffff;
}

.equipment-method__panel {
	width: 100%;
}

.equipment-method__split {
	display: flex;
	flex-wrap: wrap;
	gap: clamp(16px, 2.5vw, 32px);
	align-items: center;
	margin-bottom: 32px;
}

@media screen and (max-width: 900px) {
	.equipment-methods--3 .equipment-method__split {
		flex-direction: column;
		gap: 16px;
		margin-bottom: 24px;
	}
}

@media screen and (max-width: 600px) {
	.equipment-methods--3 .equipment-method__split {
		gap: 12px;
		margin-bottom: 16px;
	}
}

.equipment-methods--3 .equipment-method__intro {
	flex: 1 1 320px;
	min-width: 0;
	margin-bottom: 0;
}

@media screen and (max-width: 900px) {
	.equipment-methods--3 .equipment-method__intro {
		flex: none;
		width: 100%;
		margin-bottom: 0;
	}
}

.equipment-method__features {
	display: grid;
	flex: 1 1 480px;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 8px;
	min-width: 0;
	max-width: 816px;
	margin: 0 0 0 auto;
	padding: 0;
	list-style: none;
}

@media screen and (max-width: 900px) {
	.equipment-method__features {
		flex: none;
		width: 100%;
		max-width: none;
		margin-left: 0;
	}
}

@media screen and (max-width: 600px) {
	.equipment-method__features {
		grid-template-columns: 1fr;
	}
}

.equipment-method__feature {
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 40px;
	padding: 5px 10px;
	border: 2px solid #16346d;
	border-radius: 9px;
	background: #fff;
	color: #16346d;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.08em;
	text-align: center;
}

@media screen and (max-width: 600px) {
	.equipment-method__feature {
		width: 100%;
		min-height: 40px;
		font-size: 14px;
	}
}

.equipment-method__banner {
	box-sizing: border-box;
	display: block;
	width: fit-content;
	max-width: 700px;
	margin: 0 auto 32px;
	padding: 16px 48px;
	border-radius: 50px;
	background: #4fb8b6;
	color: #fff;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.08em;
	text-align: center;
}

@media screen and (max-width: 600px) {
	.equipment-method__banner {
		width: 100%;
		max-width: 100%;
		padding: 16px 24px;
		text-align: center;
	}
}

.equipment-method__banner-br {
	display: none;
}

@media screen and (max-width: 600px) {
	.equipment-method__banner-br {
		display: inline;
	}
}

.equipment-method__methods {
	margin-bottom: 64px;
}

.equipment-method__methods-stage {
	overflow: hidden;
	width: 100%;
}

.equipment-methods--3 .equipment-product__methods {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
	width: 100%;
	max-width: 1380px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
}

@media screen and (max-width: 600px) {
	.equipment-methods--3 .equipment-method__methods.is-slider-active .equipment-product__methods {
		display: flex;
		flex-wrap: nowrap;
		gap: 0;
		width: 100%;
		max-width: none;
		margin: 0;
	}

	.equipment-methods--3 .equipment-method__methods.is-slider-active [data-equipment-methods-slide] {
		flex: 0 0 100%;
		width: 100%;
		min-width: 100%;
		max-width: 100%;
		box-sizing: border-box;
	}
}

.equipment-methods--3 .equipment-product__method {
	overflow: hidden;
	border-radius: 12px;
}

.equipment-methods--3 .equipment-product__method-label {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 10px 8px;
}

.equipment-methods--3 .equipment-product__method-label-text {
	flex: 1 1 auto;
	min-width: 0;
}

.equipment-methods--3 .equipment-product__method-arrow {
	display: none;
	position: absolute;
	top: 50%;
	z-index: 1;
	width: 18px;
	height: 18px;
	padding: 0;
	border: 0;
	background: transparent;
	transform: translateY(-50%);
	cursor: pointer;
}

.equipment-method__methods.is-slider-active .equipment-product__method-arrow {
	display: block;
}

.equipment-methods--3 .equipment-product__method-arrow--prev {
	left: 8px;
}

.equipment-methods--3 .equipment-product__method-arrow--next {
	right: 8px;
}

.equipment-methods--3 .equipment-product__method-arrow-icon {
	display: block;
	width: 18px;
	height: 18px;
	background: #fff;
}

.equipment-methods--3 .equipment-product__method-arrow--prev .equipment-product__method-arrow-icon {
	clip-path: polygon(100% 0, 100% 100%, 0 50%);
}

.equipment-methods--3 .equipment-product__method-arrow--next .equipment-product__method-arrow-icon {
	clip-path: polygon(0 0, 100% 50%, 0 100%);
}

.equipment-methods--3 .equipment-method__methods.is-slider-active .equipment-product__method-label {
	padding-left: 34px;
	padding-right: 34px;
}

.equipment-method__closing {
	display: flex;
	flex-wrap: wrap;
	gap: 32px;
	align-items: stretch;
	width: 100%;
	max-width: 680px;
	margin: 0 auto;
	overflow: hidden;
	background: #fff;
}

@media screen and (max-width: 600px) {
	.equipment-method__closing {
		flex-direction: column-reverse;
		align-items: center;
		justify-content: center;
	}
}

.equipment-method__closing-media {
	flex: 0 0 auto;
	min-width: 0;
}

@media screen and (max-width: 600px) {
	.equipment-method__closing-media {
		flex: none;
		display: flex;
		justify-content: center;
		width: 100%;
	}
}

.equipment-method__closing-img,
.equipment-method__closing-img img {
	display: block;
	width: 100%;
	max-width: 217px;
	height: auto;
	object-fit: cover;
}

.equipment-method__closing-text {
	display: flex;
	flex: 1 1 0;
	min-width: 0;
	align-items: center;
	justify-content: center;
	margin: 0;
	padding: 72px 32px;
	border-top: solid 1px #16346d;
	border-bottom: solid 1px #16346d;
	color: #16346d;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.1em;
	text-align: center;
}

.equipment-method__closing-text.js-anim-sweep {
	position: relative;
	overflow: hidden;
}

.equipment-method__closing-text .js-anim-sweep__content {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	color: #16346d;
}

@media screen and (max-width: 600px) {
	.equipment-method__closing-text {
		flex: none;
		width: 100%;
		padding: 20px 8px;
		font-size: 20px;
	}
}
@media screen and (max-width: 374px) {
	.equipment-method__closing-text {
		font-size: 19.4px;
	}
}

.equipment-methods--3 .equipment-method__intro .equipment-method__text:first-child {
	margin-bottom: 1em;
}

@media screen and (max-width: 600px) {
	.equipment-methods--3 .equipment-method__intro .equipment-method__text:first-child {
		margin-bottom: 0.75em;
	}
}

.equipment-method__title {
	position: relative;
	display: grid;
	align-items: center;
	margin: 0;
	padding: 14px 24px;
	overflow: hidden;
	background-color: #16346d;
	color: #fff;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.32;
	letter-spacing: 0.13em;
}

@media screen and (max-width: 600px) {
	.equipment-method__title {
		font-size: 18px;
		padding: 12px 16px;
	}
}

.equipment-method__title-inner {
	position: relative;
	z-index: 1;
	grid-area: 1 / 1;
}

.equipment-method__title-inner.js-anim-sweep {
	display: inline-block;
	width: fit-content;
	max-width: 100%;
	vertical-align: top;
}

.equipment-method__title-inner .js-anim-sweep__content {
	display: block;
	color: #fff;
}

.equipment-method__title-sub {
	font-size: 0.85em;
	font-weight: 500;
}

.equipment-method__body {
	background-color: #ffffff;
}

.equipment-method__intro {
	margin-bottom: 24px;
	color: #16346d;
}

@media screen and (max-width: 900px) {
	.equipment-method__intro {
		margin-bottom: 0;
	}
}

.equipment-method__text {
	margin: 0;
	color: #16346d;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.5;
	letter-spacing: 0.12em;
}

@media screen and (max-width: 600px) {
	.equipment-method__text {
		font-size: 14px;
		letter-spacing: 0.13em;
	}
}
@media screen and (max-width: 374px) {
	.equipment-method__text {
		letter-spacing: 0.01em;
	}
}

.equipment-method__text + .equipment-method__text {
	margin-top: 1em;
}

@media screen and (max-width: 1079px) {
	.equipment-method__text-br {
		display: none;
	}
}

.equipment-methods--1 .equipment-product__gallery,
.equipment-methods--2 .equipment-product__gallery {
	margin-top: 0;
}

.equipment-methods--1 .equipment-product__specs {
	gap: 12px;
}

.equipment-methods--1 .equipment-product__spec {
	box-sizing: border-box;
	align-items: center;
	justify-content: flex-start;
	min-height: 84px;
	padding: 16px 20px;
	border-left: 4px solid #16346d;
	background: #ecf9ff;
	color: #16346d;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.08em;
	text-align: left;
}

@media screen and (max-width: 600px) {
	.equipment-methods--1 .equipment-product__spec {
		box-sizing: border-box;
		min-height: 44px;
		height: 44px;
		padding: 0 16px;
		font-size: 14px;
	}
}

/* 製品ブロック共通 */
.equipment-product {
	margin-bottom: 48px;
}

.equipment-product__bar {
	background: #16346d;
}

.equipment-product__title {
	margin: 0;
	padding: 14px 24px;
	color: #fff;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.32;
	letter-spacing: 0.13em;
}

@media screen and (max-width: 600px) {
	.equipment-product__title {
		font-size: 18px;
		padding: 12px 16px;
	}
}

.equipment-product__title-sub {
	font-size: 0.85em;
	font-weight: 500;
}

.equipment-product__body {
	padding: 32px 0 0;
}

.equipment-product__lead {
	margin: 0 0 24px;
	color: #16346d;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.8;
	letter-spacing: 0.12em;
}

@media screen and (max-width: 600px) {
	.equipment-product__lead {
		font-size: 14px;
		letter-spacing: 0.13em;
	}
}

/* 2カラム：テキスト＋写真 / スペック */
.equipment-product__split {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 38%);
	gap: clamp(24px, 3vw, 40px);
	align-items: start;
}

@media screen and (max-width: 900px) {
	.equipment-product__split {
		grid-template-columns: 1fr;
	}
}

.equipment-product__gallery {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
	margin-top: 8px;
}

@media screen and (max-width: 600px) {
	.equipment-product__gallery {
		grid-template-columns: 1fr;
	}
}

.equipment-product__gallery-item,
.equipment-product__method-media,
.equipment-product__highlight-media,
.equipment-product__systems-photo,
.equipment-product__cta-media,
.equipment-product__footnote-media {
	overflow: hidden;
	background: #dce8f4;
}

.equipment-product__img,
.equipment-product__img img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}

.equipment-product__specs {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	margin: 0;
	padding: 0;
	list-style: none;
}

@media screen and (max-width: 900px) {
	.equipment-product__specs {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 600px) {
	.equipment-product__specs {
		grid-template-columns: 1fr;
	}
}

.equipment-product__spec {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 56px;
	padding: 10px 14px;
	background: #e8f2fa;
	color: #16346d;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 0.08em;
	text-align: center;
}

/* 安全ネット */
.equipment-product__highlights {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 24px;
	margin: 0;
	padding: 0;
	list-style: none;
}

@media screen and (max-width: 600px) {
	.equipment-product__highlights {
		grid-template-columns: 1fr;
	}
}

.equipment-product__highlight {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.equipment-product__highlight-media {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 120px;
	padding: 16px;
	border: 1px solid #16346d;
	background: #fff;
}

.equipment-product__highlight-media .equipment-product__img,
.equipment-product__highlight-media .equipment-product__img img {
	width: auto;
	max-width: 100%;
	max-height: 88px;
	object-fit: contain;
}

.equipment-product__highlight-text {
	margin: 0;
	color: #16346d;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.1em;
	text-align: center;
}

/* マルチファン工法 */
.equipment-product__tags {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 0 0 20px;
	padding: 0;
	list-style: none;
}

.equipment-product__tag {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 36px;
	padding: 6px 16px;
	border: 1px solid #16346d;
	background: #fff;
	color: #16346d;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 0.08em;
}

.equipment-product__pill {
	margin: 0 0 28px;
	padding: 14px 24px;
	border-radius: 999px;
	background: linear-gradient(90deg, #2a9d8f 0%, #3db89e 100%);
	color: #fff;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.5;
	letter-spacing: 0.08em;
	text-align: center;
}

@media screen and (max-width: 600px) {
	.equipment-product__pill {
		font-size: 14px;
	}
}

.equipment-product__methods {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
	margin: 0 0 32px;
	padding: 0;
	list-style: none;
}

@media screen and (max-width: 900px) {
	.equipment-product__methods {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media screen and (max-width: 600px) {
	.equipment-product__methods {
		grid-template-columns: 1fr;
	}
}

.equipment-product__method-media {
	aspect-ratio: 4 / 3;
}

.equipment-product__method-label {
	margin: 0;
	padding: 10px 8px;
	background: #16346d;
	color: #fff;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 0.08em;
	text-align: center;
}

.equipment-product__footnote {
	margin-top: 8px;
	text-align: center;
}

.equipment-product__footnote-media {
	max-width: 720px;
	margin: 0 auto 16px;
}

.equipment-product__footnote-text {
	margin: 0;
	padding-top: 16px;
	border-top: 2px solid #16346d;
	color: #16346d;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.1em;
}

/* その他システム */
.equipment-product--systems .equipment-product__bar {
	background-color: transparent;
}

.equipment-product--systems .equipment-product__title {
	position: relative;
	display: grid;
	align-items: center;
	overflow: hidden;
	background-color: #16346d;
	color: #ffffff;
}

.equipment-product--systems .equipment-product__title::before {
	content: '';
	position: absolute;
	inset: 0;
	z-index: 0;
	background-image: var(--equipment-systems-title-bg);
	background-size: 100% 100%;
	background-position: center;
	background-repeat: no-repeat;
	opacity: 0.5;
	pointer-events: none;
}

.equipment-product__title-inner {
	position: relative;
	z-index: 1;
	grid-area: 1 / 1;
}

.equipment-product--systems {
	margin-bottom: 0;
}

.equipment-product--systems .equipment-product__body {
	box-sizing: border-box;
	padding: 24px 32px;
	margin-bottom: 0;
	background-color: #ffffff;
}

@media screen and (max-width: 600px) {
	.equipment-product--systems .equipment-product__body {
		padding: 24px 12px;
	}
}
.equipment-product__contact {
	color: #16346d;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.5;
	letter-spacing: 0.12em;
}

.equipment-product__contact-line {
	margin: 0;
}

.equipment-product__contact-line--mb {
	margin-bottom: 1em;
}

.equipment-product__contact-note-sp {
	display: none;
}

@media screen and (max-width: 600px) {
	.equipment-product__contact-note-pc {
		display: none;
	}

	.equipment-product__contact-note-sp {
		display: block;
	}

	.equipment-product__contact-note-sp-indent {
		display: block;
		padding-left: 1em;
	}
}

.equipment-product__contact-tel {
	color: inherit;
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

.equipment-product__contact-tel:hover {
	opacity: 0.75;
}

.equipment-product__systems {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 42%);
	gap: 32px;
	align-items: start;
}

@media screen and (max-width: 900px) {
	.equipment-product__systems {
		grid-template-columns: 1fr;
	}
}

.equipment-product__systems-photos {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

/* ガードフェンス CTA */
.equipment-product--cta-banner {
	margin-bottom: 0;
}

.equipment-product--cta-banner .equipment-product__body {
	padding-top: 0;
}

.equipment-product__cta {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(220px, 320px);
	overflow: hidden;
	background: #16346d;
	color: #fff;
}

@media screen and (max-width: 900px) {
	.equipment-product__cta {
		grid-template-columns: 1fr;
	}
}

.equipment-product__cta-body {
	padding: 32px 28px;
}

.equipment-product__cta-title {
	margin: 0 0 16px;
	font-size: 22px;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.08em;
}

@media screen and (max-width: 600px) {
	.equipment-product__cta-title {
		font-size: 18px;
	}
}

.equipment-product__cta-text {
	margin: 0 0 24px;
	font-size: 14px;
	line-height: 1.7;
	letter-spacing: 0.08em;
}

.equipment-product__cta-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 12px 22px;
	border: 1px solid #fff;
	color: #fff;
	font-size: 14px;
	letter-spacing: 0.08em;
	text-decoration: none;
	transition: background-color 0.2s ease;
}

.equipment-product__cta-btn:hover {
	background: rgba(255, 255, 255, 0.12);
}

.equipment-product__cta-media {
	display: flex;
	align-items: stretch;
	min-height: 180px;
	background: #0f2848;
}

.equipment-product__cta-media .equipment-product__img,
.equipment-product__cta-media .equipment-product__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* --------------------------------------------------------------------------
   レンタル
   -------------------------------------------------------------------------- */
.equipment-rental {
	margin-bottom: 72px;
}

.equipment-rental__title {
	margin: 0 0 32px;
	color: #16346d;
	font-size: clamp(20px, 2.2vw, 28px);
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.1em;
	text-align: center;
}

.equipment-rental__grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(280px, 42%);
	gap: 32px;
	align-items: start;
	margin-bottom: 40px;
}

@media screen and (max-width: 900px) {
	.equipment-rental__grid {
		grid-template-columns: 1fr;
	}
}

.equipment-rental__text {
	color: #16346d;
	font-size: 16px;
	line-height: 1.7;
	letter-spacing: 0.08em;
}

.equipment-rental__text p {
	margin: 0 0 1em;
}

.equipment-rental__photos {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
}

.equipment-rental__photo,
.equipment-rental__photo img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}

.equipment-rental__fence {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(200px, 280px);
	gap: 0;
	overflow: hidden;
	background: #16346d;
	color: #fff;
}

@media screen and (max-width: 900px) {
	.equipment-rental__fence {
		grid-template-columns: 1fr;
	}
}

.equipment-rental__br-sp {
	display: none;
}

@media screen and (max-width: 600px) {
	.equipment-rental__br-sp {
		display: inline;
	}
}

.equipment-rental__fence-body {
	padding: 24px 28px;
}

.equipment-rental__fence-label {
	margin: 0 0 12px;
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.1em;
}

.equipment-rental__fence-text {
	margin: 0 0 20px;
	font-size: 14px;
	line-height: 1.6;
	letter-spacing: 0.06em;
}

.equipment-rental__fence-btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 10px 20px;
	border: 1px solid #fff;
	color: #fff;
	font-size: 14px;
	text-decoration: none;
	transition: background-color 0.2s ease;
}

.equipment-rental__fence-btn:hover {
	background: rgba(255, 255, 255, 0.12);
}

.equipment-rental__fence-media {
	display: flex;
	align-items: stretch;
	min-height: 160px;
	background: #0f2848;
}

.equipment-rental__fence-img,
.equipment-rental__fence-img img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* --------------------------------------------------------------------------
   セクション4（フロー）背景 #fff / max 1520px
   -------------------------------------------------------------------------- */
.equipment-flow {
	box-sizing: border-box;
	width: 100%;
	padding: 80px 16px;
	background: transparent;
}

@media screen and (max-width: 600px) {
	.equipment-flow {
		padding: 0px 16px;
	}
}

.equipment-flow__inner {
	box-sizing: border-box;
	width: 100%;
	max-width: 1520px;
	margin: 0 auto;
	padding: clamp(32px, 5vw, 64px) clamp(16px, 4vw, 64px);
	background: #ffffff;
}

@media screen and (max-width: 600px) {
	.equipment-flow__inner {
		padding: 32px 16px;
	}
}

.equipment-flow__content {
	box-sizing: border-box;
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
}

/* BOX1 */
.equipment-flow__box1 {
	box-sizing: border-box;
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(320px, 636px);
	gap: clamp(24px, 4vw, 56px);
	align-items: center;
	margin-bottom: 56px;
}

@media screen and (max-width: 900px) {
	.equipment-flow__box1 {
		grid-template-columns: 1fr;
	}
}
@media screen and (max-width: 600px) {
	.equipment-flow__box1 {
		margin-bottom: 32px;
	}
}

.equipment-flow__box1-lead,
.equipment-flow__box1-title {
	margin: 0;
	color: #16346d;
	font-size: 28px;
	font-weight: 700;
	line-height: 1.5;
	letter-spacing: 0.05em;
}

@media screen and (max-width: 600px) {
	.equipment-flow__box1-lead,
	.equipment-flow__box1-title {
		font-size: 22px;
	}
}
@media screen and (max-width: 374px) {
	.equipment-flow__box1-lead,
	.equipment-flow__box1-title {
		font-size: 18px;
	}
}

.equipment-flow__box1-lead {
	margin-bottom: 0.25em;
}

.equipment-flow__box1-media {
	min-width: 0;
	max-width: 636px;
	margin-left: auto;
	text-align: center;
}

.equipment-flow__box1-picture,
.equipment-flow__box1-picture img {
	display: block;
	width: 100%;
	max-width: 636px;
	height: auto;
	margin-inline: auto;
}

@media screen and (max-width: 600px) {
	.equipment-flow__box1-media {
		max-width: none;
		margin-left: 0;
	}

	.equipment-flow__box1-picture,
	.equipment-flow__box1-picture img {
		width: 100%;
		max-width: 100%;
	}
}

/* BOX2（シェブロン） */
.equipment-flow__steps {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	width: 100%;
	max-width: 1260px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
}

@media screen and (max-width: 900px) {
	.equipment-flow__steps {
		flex-direction: column;
		align-items: stretch;
		max-width: 100%;
	}
}

.equipment-flow__step {
	position: relative;
	z-index: 1;
	display: flex;
	flex: 1 1 0;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
	min-width: 0;
	height: var(--equipment-flow-height, 91px);
	padding: 8px calc(var(--equipment-flow-arrow, 50px) + 16px) 8px calc(var(--equipment-flow-arrow, 50px) + 8px);
	background-color: var(--step-bg, #16346d);
	color: var(--step-color, #fff);
	font-size: clamp(12px, 1.2vw, 16px);
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 0.06em;
	text-align: center;
}

@media screen and (max-width: 900px) {
	.equipment-flow__steps {
		--equipment-flow-overlap: 22px;
		--equipment-flow-v-depth: 16px;
		--equipment-flow-step-body: 70px;
	}

	.equipment-flow__step {
		flex: none;
		width: 100%;
		height: calc(var(--equipment-flow-step-body) + var(--equipment-flow-overlap) - 1px);
		min-height: calc(var(--equipment-flow-step-body) + var(--equipment-flow-overlap) - 1px);
		flex-shrink: 0;
		margin-left: 0;
		padding: 0 16px;
		font-size: 16px;
		font-weight: 500;
		line-height: 1.25;
	}

	.equipment-flow__step--first,
	.equipment-flow__step--mid {
		padding-bottom: calc(var(--equipment-flow-v-depth) * 0.4);
		clip-path: polygon(
			0 0,
			100% 0,
			100% calc(100% - var(--equipment-flow-v-depth)),
			50% 100%,
			0 calc(100% - var(--equipment-flow-v-depth))
		);
	}

	.equipment-flow__step--first {
		z-index: 5;
		margin-top: 0;
	}

	.equipment-flow__step--mid {
		margin-top: calc(var(--equipment-flow-overlap) * -1 + 1px);
		padding-left: 16px;
	}

	.equipment-flow__step--mid .equipment-flow__step-label {
		padding-top: 20px;
	}

	.equipment-flow__step--last {
		margin-top: calc(var(--equipment-flow-overlap) * -1 + 1px);
		padding-top: calc(var(--equipment-flow-v-depth) * 0.4);
		padding-left: 16px;
		clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
	}
}

.equipment-flow__step-label {
	position: relative;
	z-index: 1;
}

.equipment-flow__step--first {
	z-index: 5;
	padding-left: 16px;
}

@media screen and (min-width: 901px) {
	.equipment-flow__step--first {
		clip-path: polygon(
			0 0,
			calc(100% - var(--equipment-flow-arrow, 50px)) 0,
			100% 50%,
			calc(100% - var(--equipment-flow-arrow, 50px)) 100%,
			0 100%
		);
	}
}

.equipment-flow__step--mid {
	z-index: 4;
	padding-left: 1em;
}

@media screen and (min-width: 901px) {
	.equipment-flow__step--mid {
		margin-left: calc(var(--equipment-flow-arrow, 50px) * -1 + 1px);
		clip-path: polygon(
			0 0,
			calc(100% - var(--equipment-flow-arrow, 50px)) 0,
			100% 50%,
			calc(100% - var(--equipment-flow-arrow, 50px)) 100%,
			0 100%
		);
	}

	.equipment-flow__step--mid .equipment-flow__step-label {
		padding-left: 1.5em;
	}
}

.equipment-flow__step--mid:nth-child(3) {
	z-index: 3;
}

.equipment-flow__step--mid:nth-child(4) {
	z-index: 2;
}

.equipment-flow__step--last {
	z-index: 1;
	padding-right: 16px;
	padding-left: 16px;
}

@media screen and (min-width: 901px) {
	.equipment-flow__step--last {
		margin-left: calc(var(--equipment-flow-arrow, 50px) * -1 + 1px);
		clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
	}
}

/* --------------------------------------------------------------------------
   セクション5（施工事例 / results-section）
   -------------------------------------------------------------------------- */
.equipment-page__results {
	margin-block: 0 64px;
}

.equipment-page__results .results-page__inner {
	box-sizing: border-box;
	width: 100%;
	max-width: 1520px;
	margin-inline: auto;
	padding: 64px 16px 0 16px;
}

.equipment-page__results .results-page__sections {
	gap: 0;
}

.equipment-page__results .results-section--no-title .results-section__head {
	margin-bottom: 24px;
}
