@charset 'utf-8';

/* =========================================================
  Business List
========================================================= */
.p-business-list__body {
	width: min(83.333vw, 1600px);
	margin-left: auto;
	margin-right: auto;
}

.p-business-list__item {
	display: grid;
	grid-template-columns:
		minmax(220px, 24.375%)
		minmax(320px, 34.438%)
		minmax(260px, 1fr);
	align-items: center;
	column-gap: clamp(30px, 3.65vw, 70px);
	width: min(83.333vw, 1600px);
	margin-inline: auto;
	padding-top: clamp(60px, 5.2vw, 100px);
	padding-bottom: clamp(60px, 5.2vw, 100px);
}

.p-business-list__item:nth-child(even) {
	background-color: #f7f7f7;
	box-shadow: 0 0 0 100vmax #f7f7f7;
	clip-path: inset(0 -100vmax);
}
.p-business-list__title {
	position: relative;
	align-self: start;
	padding-top: 0.1em;
	padding-bottom: 0.75em;
	font-size: clamp(30px, 2.083vw, 40px);
	font-weight: 600;
	line-height: 1.4;
}

.p-business-list__title::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: clamp(42px, 2.917vw, 56px);
	height: 4px;
	background-color: var(--color-primary);
}

.p-business-list__image img {
	width: 100%;
	aspect-ratio: 551 / 321;
	object-fit: cover;
}

.p-business-list__text-list {
	font-size: clamp(17px, 1.302vw, 25px);
	font-weight: 400;
	line-height: 1.65;
}

.p-business-list__text-list li {
	display: flex;
	align-items: flex-start;
}

.p-business-list__text-list li::before {
	content: "・";
	flex: 0 0 auto;
	color: var(--color-primary);
	font-weight: 700;
}

/* =========================================================
  Business List - Tablet
========================================================= */
@media (max-width: 1300px) {
	.p-business-list__body {
		width: min(90vw, 1100px);
	}

	.p-business-list__item {
		grid-template-columns: minmax(200px, 0.8fr) minmax(300px, 1.15fr) minmax(240px, 1fr);
		column-gap: clamp(24px, 3vw, 40px);
	}

	.p-business-list__title {
		font-size: clamp(26px, 2.35vw, 32px);
	}

	.p-business-list__text-list {
		font-size: clamp(16px, 1.55vw, 20px);
	}
}

@media (max-width: 1023px) {
	.p-business-list__body {
		width: 100%;
		padding-left: var(--container-padding-sp);
		padding-right: var(--container-padding-sp);
	}

	.p-business-list__item {
		grid-template-columns: 220px 1fr;
		grid-template-areas:
			"title image"
			"text image";
		align-items: start;
		column-gap: 32px;
	}

	.p-business-list__title {
		grid-area: title;
		margin-bottom: 28px;
		font-size: clamp(24px, 3vw, 30px);
	}

	.p-business-list__image {
		grid-area: image;
	}

	.p-business-list__text-list {
		grid-area: text;
		font-size: clamp(15px, 2vw, 18px);
		line-height: 1.8;
	}
}

/* =========================================================
  Business List - SP
========================================================= */
@media (max-width: 767px) {
	.p-business-list {
		padding-bottom: 65px;
	}

	.p-business-list__item {
		display: block;
	}


	.p-business-list__title {
		margin-bottom: 24px;
		font-size: 22px;
	}

	.p-business-list__title::after {
		width: 42px;
		height: 3px;
	}

	.p-business-list__image {
		margin-bottom: 22px;
	}

	.p-business-list__text-list {
		font-size: 17px;
		line-height: 1.8;
	}
}

/* =========================================================
  Business Other
========================================================= */
.p-business-other {
	padding-top: clamp(70px, 7.8vw, 150px);
	padding-bottom: clamp(80px, 8.33vw, 160px);
}
.p-business-other__body {
	max-width: min(97vw,1500px);
	margin-left: auto;
	margin-right: auto;
}
.p-business-other__list {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	margin-top: clamp(55px, 5.2vw, 100px);
	border-top: 1px solid var(--color-border);
	border-left: 1px solid var(--color-border);
}

.p-business-other__item {
	display: grid;
	grid-template-columns: 273px 1fr;
	column-gap: 20px;
	padding: clamp(14px, 1.3vw, 25px) clamp(12px, 1.3vw, 25px) clamp(36px, 3.9vw, 75px);
	border-right: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
}

.p-business-other__image img {
	width: 100%;
	aspect-ratio: 273 / 231;
	object-fit: cover;
}

.p-business-other__text h3 {
	font-size: clamp(22px, 1.5625vw, 30px);
	font-weight: 600;
	line-height: 1.4;
}

.p-business-other__text ul {
	margin-top: 0.75em;
	font-size: clamp(17px, 1.302vw, 25px);
	font-weight: 400;
	line-height: 1.6;
}

.p-business-other__text li {
	display: flex;
	align-items: flex-start;
}

.p-business-other__text li::before {
	content: "・";
	flex: 0 0 auto;
	color: var(--color-text);
}

/* =========================================================
  Business Other - Tablet
========================================================= */
@media (max-width: 1500px) {
	.p-business-other__item {
		grid-template-columns: minmax(180px, 36%) 1fr;
		column-gap: clamp(18px, 2.1vw, 32px);
	}

	.p-business-other__text h3 {
		font-size: clamp(18px, 2vw, 24px);
	}

	.p-business-other__text ul {
		font-size: clamp(15px, 1.8vw, 18px);
	}
}

/* =========================================================
  Business Other - SP
========================================================= */
@media (max-width: 767px) {
	.p-business-other__body {
		width: 100%;
		padding-left: var(--container-padding-sp);
		padding-right: var(--container-padding-sp);
	}
	.p-business-other {
		padding-top: 60px;
		padding-bottom: 70px;
	}

	.p-business-other__list {
		grid-template-columns: 1fr;
		margin-top: 45px;
	}

	.p-business-other__item {
		display: block;
		padding: 24px 18px;
	}

	.p-business-other__image {
		margin-bottom: 16px;
	}

	.p-business-other__text h3 {
		font-size: 21px;
	}

	.p-business-other__text ul {
		font-size: 16px;
		line-height: 1.75;
	}
}


/* =========================================================
  Custom Override
  Business Other：箇条書きを Business List と同じデザインに
========================================================= */

.p-business-other__text li::before {
	content: "・";
	flex: 0 0 auto;
	color: var(--color-primary);
	font-weight: 700;
}

/* =========================================================
  Custom Override
  Typography
========================================================= */

.p-business h2,
.p-business h3,
.p-business h4 {
	font-weight: 400;
	letter-spacing: .04em;
	color: #333;
}

.p-business p,
.p-business li {
	color: #444;
	line-height: 1.8;
}