@charset "UTF-8";

/* ==========================================================================
   会社案内ページ固有スタイル
   ========================================================================== */


/* ---------- 代表挨拶 ---------- */

.company-greeting__grid {
	display: grid;
	grid-template-columns: 360px 1fr;
	gap: 60px;
	align-items: flex-start;
}

.company-greeting__image {
	border-radius: var(--radius-lg);
	overflow: hidden;
}

.company-greeting__image img {
	width: 100%;
	height: auto;
	display: block;
}

.company-greeting__position {
	font-size: 0.875rem;
	color: var(--color-text-light);
	letter-spacing: 0.1em;
	margin-bottom: 4px;
}

.company-greeting__name {
	font-family: var(--font-heading);
	font-size: 1.75rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	margin-bottom: 32px;
	padding-bottom: 24px;
	border-bottom: 2px solid var(--color-primary);
}

.company-greeting__body p {
	font-size: 0.9375rem;
	line-height: 2;
	margin-bottom: 16px;
}


/* ---------- 会社概要 ---------- */

.company-overview__location {
	margin-bottom: 8px;
}

.company-overview__location:last-child {
	margin-bottom: 0;
}

.company-overview__location strong {
	color: var(--color-primary);
	font-size: 0.8125rem;
	letter-spacing: 0.05em;
}

.company-overview__tel {
	font-family: var(--font-number);
	letter-spacing: 0.02em;
}

.company-overview__tel a {
	color: var(--color-primary);
}

.company-overview__tel a:hover {
	color: var(--color-accent);
}

.company-overview__business {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.company-overview__business li {
	position: relative;
	padding-left: 16px;
}

.company-overview__business li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.7em;
	width: 6px;
	height: 2px;
	background-color: var(--color-primary);
}


/* ---------- 沿革 ---------- */

.company-history__timeline {
	position: relative;
	padding-left: 200px;
}

/* 縦線 */
.company-history__timeline::before {
	content: '';
	position: absolute;
	left: 180px;
	top: 0;
	bottom: 0;
	width: 2px;
	background-color: var(--color-border);
}

.company-history__item {
	position: relative;
	padding: 0 0 48px 40px;
}

.company-history__item:last-child {
	padding-bottom: 0;
}

/* タイムラインのドット */
.company-history__item::before {
	content: '';
	position: absolute;
	left: -24px;
	top: 8px;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background-color: var(--color-primary);
	border: 2px solid var(--color-bg);
	box-shadow: 0 0 0 2px var(--color-primary);
}

.company-history__year {
	position: absolute;
	left: -240px;
	top: 0;
	width: 180px;
	text-align: right;
	font-family: var(--font-english);
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--color-primary);
	letter-spacing: 0.05em;
	line-height: 1.4;
}

.company-history__era {
	position: absolute;
	left: -240px;
	top: 2rem;
	width: 180px;
	text-align: right;
	font-size: 0.75rem;
	color: var(--color-text-light);
	letter-spacing: 0.03em;
}

.company-history__content p {
	font-size: 0.9375rem;
	line-height: 1.8;
	color: var(--color-text);
}


/* ---------- SDGs ---------- */

.company-sdgs__content {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 48px;
	align-items: flex-start;
}

.company-sdgs__subtitle {
	font-size: 1.25rem;
	font-weight: 700;
	margin-bottom: 20px;
	padding-left: 16px;
	border-left: 4px solid var(--color-accent);
}

.company-sdgs__body p {
	font-size: 0.9375rem;
	line-height: 2;
	margin-bottom: 12px;
}

.company-sdgs__goals {
	background-color: var(--color-bg);
	padding: 32px;
	border-radius: var(--radius-lg);
	border: 1px solid var(--color-border);
}

.company-sdgs__goals-title {
	font-size: 0.8125rem;
	font-weight: 700;
	color: var(--color-text-light);
	letter-spacing: 0.05em;
	margin-bottom: 16px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--color-border);
}

.company-sdgs__goals-list {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.company-sdgs__goal {
	display: block;
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--color-primary);
	padding-left: 16px;
	position: relative;
	line-height: 1.6;
}

.company-sdgs__goal::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.5em;
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background-color: var(--color-accent);
}


/* ---------- アクセス ---------- */

.company-access__locations {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 40px;
}

.company-access__location {
	display: flex;
	flex-direction: column;
}

.company-access__location-name {
	font-size: 1.125rem;
	font-weight: 700;
	margin-bottom: 12px;
	padding-left: 16px;
	border-left: 4px solid var(--color-primary);
}

.company-access__address {
	font-size: 0.9375rem;
	margin-bottom: 8px;
}

.company-access__transport {
	font-size: 0.8125rem;
	color: var(--color-text-light);
	line-height: 1.8;
	margin-bottom: 20px;
}

.company-access__map {
	margin-top: auto;
	border-radius: var(--radius-lg);
	overflow: hidden;
	border: 1px solid var(--color-border);
}

.company-access__map iframe {
	display: block;
	width: 100%;
}


/* ==========================================================================
   レスポンシブ
   ========================================================================== */

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

	/* 代表挨拶 */
	.company-greeting__grid {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.company-greeting__image {
		max-width: 280px;
		margin: 0 auto;
	}

	.company-greeting__name {
		font-size: 1.375rem;
		margin-bottom: 24px;
		padding-bottom: 16px;
	}

	.company-greeting__body p {
		font-size: 0.875rem;
	}

	/* 沿革 */
	.company-history__timeline {
		padding-left: 32px;
	}

	.company-history__timeline::before {
		left: 8px;
	}

	.company-history__item {
		padding-left: 32px;
		padding-bottom: 32px;
	}

	.company-history__item::before {
		left: -28px;
	}

	.company-history__year {
		position: static;
		width: auto;
		text-align: left;
		font-size: 1.25rem;
		margin-bottom: 0;
	}

	.company-history__era {
		position: static;
		width: auto;
		text-align: left;
		display: block;
		margin-bottom: 8px;
	}

	/* SDGs */
	.company-sdgs__content {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.company-sdgs__goals {
		padding: 24px;
	}

	/* アクセス */
	.company-access__locations {
		grid-template-columns: 1fr;
		gap: 48px;
	}

	.company-access__map iframe {
		height: 240px;
	}
}
