@charset "UTF-8";
/* =========================================================
   sections.css
   フロントページの大型セクション群

   既存サイトの実装方式を踏襲:
   - 画像は通常フロー(中央寄せ)で配置し、それが「枠」の高さを決める
   - 縦書きテキストは position: absolute で画像の上に重ねる
   - 数値は既存サイトの値をそのまま使用(top:-75px, font-size:55pt等)
   ========================================================= */

/* =========================================================
   .hero ヒーローセクション
   ========================================================= */
.hero {
	width: 100%;
	background: var(--color-bg);
	padding-top: 270px;
	padding-bottom: 0px;
}

/* メインキャッチセット(画像+縦書きテキストの枠)
   既存サイトの .main-copy-set 相当 */
.hero__inner {
	position: relative;
	width: 1200px;
	height: 500px;
	margin: 0 auto;
}

/* =========================================================
   ヒーロー画像
   .main-copy-set 内に通常フローで配置(absolute使わない)
   既存サイトの aligncenter と同じ振る舞い
   ========================================================= */
.hero__image {
	display: block;
	margin: 0 auto;
	max-width: 100%;
	height: auto;
	/* 既存サイトの画像原寸: 1353 × 535 */
}

/* =========================================================
   縦書きキャッチコピー(画像の上に重ねる)
   ========================================================= */

/* 大見出し「地域の未来を／創造します」
   既存サイトの .main-copy01 相当 */
.hero__title {
	position: absolute;
	top: -80px;
	left: 22%;
	display: inline-block;
	writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: lr-tb;
	vertical-align: top;
	font-family: "book antiqua", palatino, serif;
	font-size: 55pt;
	font-weight: bold;
	line-height: 130%;
	color: #000000;
	margin: 0;
	transition: all 0.7s;
}

/* 小見出し(リード文)
   既存サイトの .main-copy02 相当 */
.hero__lead {
	position: absolute;
	top: -75px;
	left: 11%;
	display: inline-block;
	writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: lr-tb;
	vertical-align: top;
	font-size: 13pt;
	line-height: 200%;
	color: #000000;
	margin: 0;
	transition: all 0.7s;
}

/* =========================================================
   タブレット(〜999px)
   既存サイトのタブレット用数値を採用
   ========================================================= */
@media screen and (max-width: 999px) {

		.hero {
		/* SPヘッダー(64px)+呼吸(36px) = 100px */
		padding-top: 100px;
		padding-bottom: 40px;
		margin-bottom: 30px;
	}

	.hero__inner {
		width: 100vw;
		height: 220px;
	}

	.hero__title {
		top: -18px;
		left: 25vw;
		font-size: 22pt;
	}

	.hero__lead {
		top: -15px;
		left: 8%;
		font-size: 10.5pt;
		line-height: 150%;
	}
}

/* =========================================================
   スマホ(〜759px)
   既存サイトのスマホ用数値を採用
   ========================================================= */
@media screen and (max-width: 759px) {

	.hero__inner {
		width: 100vw;
		height: 160px;
	}

	.hero__title {
		top: -10px;
		left: 27vw;
		font-size: 20pt;
		line-height: 110%;
	}

	.hero__lead {
		top: -11px;
		left: 10vw;
		height: 300px;
		font-size: 10pt;
		line-height: 150%;
	}
}






/* =========================================================
   .news-section
   トップページの「News」セクション
   ========================================================= */
.news-section {
	width: 100%;
	padding-block: 0px;
}

.news-section__inner {
	width: 100%;
	max-width: 1200px;
	margin-inline: auto;
	padding-inline: var(--container-padding);
	display: grid;
	grid-template-columns: 240px 1fr;
	gap: 60px;
	align-items: start;
}

/* ---------- 左: セクションタイトル ---------- */
.news-section__header {
	padding-top: 8px;
    text-align: right;
}

.news-section__title {
	display: inline-block;
	font-family: var(--font-family-en);
	font-size: 32px;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.05em;
	color: var(--color-heading);
	margin: 0;
	padding-bottom: 8px;
	/* 既存サイトの「ピンクのグラデーション罫線」を踏襲 */
	border-bottom: 4px solid;
	border-image: linear-gradient(to right, #ff5cb1, #c8a2ff) 1;
}

/* ---------- 右: お知らせリスト ---------- */
.news-list {
	margin: 0;
	padding: 0;
	list-style: none;
    width: 700px;
}

.news-list__item {
	border-bottom: 1px solid var(--color-border);
}

.news-list__item:first-child {
	border-top: 1px solid var(--color-border);
}

.news-list__link {
	display: flex;
	align-items: baseline;
	gap: 32px;
	padding: 16px 8px;
	color: var(--color-text);
	transition: background-color var(--transition-fast),
		color var(--transition-fast);
}

.news-list__link:hover,
.news-list__link:focus-visible {
	background: var(--color-bg-alt);
	color: var(--color-accent);
}

.news-list__date {
	flex-shrink: 0;
	font-family: var(--font-family-en);
	font-size: 16px;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.05em;
	color: var(--color-text);
	white-space: nowrap;
}

.news-list__title {
	font-size: 15px;
	line-height: 1.6;
	color: var(--color-text);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.news-list__empty {
	padding: 24px 8px;
	color: var(--color-text-muted);
}

.news-section__more {
	margin-top: 30px;
	text-align: center;
    width: 700px;
}

/* =========================================================
   News タブレット(〜960px)
   ========================================================= */
@media screen and (max-width: 960px) {

	.news-section {
		padding-block: 60px;
	}

	.news-section__inner {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.news-section__header {
		padding-top: 0;
		text-align: center;
	}

	.news-section__title {
		font-size: 36px;
	}
}

/* =========================================================
   News スマホ(〜640px)
   ========================================================= */
@media screen and (max-width: 640px) {

	.news-section {
		padding-block: 48px;
	}

	.news-section__title {
		font-size: 30px;
	}

	.news-list__link {
		flex-direction: column;
		gap: 4px;
		padding: 16px 4px;
	}

	.news-list__date {
		font-size: 14px;
	}

	.news-list__title {
		font-size: 14px;
	}
}


/* =========================================================
   .promo
   トップページの「事業内容/会社案内」誘導セクション
   ========================================================= */
.promo {
	width: 100%;
	padding-block: 80px;
}

/* =========================================================
   事業内容セクション(.promo--business)
   画像左・テキスト右
   ========================================================= */
.promo--business .promo__inner {
	width: 100%;
	max-width: 1200px;
	margin-inline: auto;
	padding-inline: var(--container-padding);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 80px;
	align-items: center;
}

.promo--business .promo__image img {
	display: block;
	width: 100%;
	height: auto;
}

.promo--business .promo__body {
	display: flex;
	flex-direction: column;
	gap: 24px;
}

.promo--business .promo__title {
	font-family: var(--font-family-mincho);
	font-size: 32px;
	font-weight: var(--font-weight-bold);
	line-height: 1.5;
	letter-spacing: 0.05em;
	color: var(--color-heading);
	margin: 0;
}

.promo--business .promo__text {
	font-size: 15px;
	line-height: 1.9;
	color: var(--color-text);
	margin: 0;
}

.promo--business .promo__action {
	margin: 0;
	margin-top: 8px;
}

/* =========================================================
   会社案内セクション(.promo--about)
   1100pxのグレー枠に、左30%テキスト + 右70%(画像2枚)を収める
   全要素はグレー枠の内側に完全に収まる(はみ出しなし)
   ========================================================= */
.promo--about .promo__inner {
	width: 1100px;
	max-width: 100%;
	margin-inline: auto;
	background: #dcdcdc;
	padding: 50px 40px;
	display: grid;
	/* 左30% : 右70% */
	grid-template-columns: 30% 1fr;
	gap: 40px;
	align-items: stretch;
}

/* ---------- 左: テキストエリア(縦に積む) ---------- */
.promo--about .promo__body {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 40px;
	height: 100%;
	padding: 20px 0;
}

/* 縦書きの「会社案内」タイトル */
.promo--about .promo__title {
	writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	font-family: var(--font-family-mincho);
	font-size: 32px;
	font-weight: var(--font-weight-bold);
	line-height: 1.4;
	letter-spacing: 0.5em;
	color: var(--color-heading);
	margin: 0;
}

/* リード+ボタンのグループ */
.promo--about .promo__text-group {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 32px;
}

.promo--about .promo__text {
	font-size: 14px;
	line-height: 1.9;
	color: var(--color-text);
	margin: 0;
	text-align: center;
}

.promo--about .promo__action {
	margin: 0;
}

/* 会社案内ボタンは角張った長方形、紫マゼンタ */
.promo--about .btn--magenta {
	min-width: 200px;
	height: 50px;
	border-radius: 0;
	background: #c800c8;
	border-color: #c800c8;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.3em;
}

.promo--about .btn--magenta:hover,
.promo--about .btn--magenta:focus-visible {
	background: #a800a8;
	border-color: #a800a8;
}

/* ---------- 右: 画像2枚 ---------- */
.promo--about .promo__image {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 8px;
	height: 100%;
	min-height: 460px;
}

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

/* =========================================================
   タブレット(〜960px) - 縦積みに変更
   ========================================================= */
@media screen and (max-width: 960px) {

	.promo {
		padding-block: 60px;
	}

	.promo--business .promo__inner {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.promo--about .promo__inner {
		grid-template-columns: 1fr;
		gap: 32px;
		padding: 40px 24px;
	}

	.promo--about .promo__body {
		flex-direction: column;
		align-items: center;
		gap: 24px;
		padding: 0;
		text-align: center;
	}

	.promo--about .promo__title {
		writing-mode: horizontal-tb;
		-webkit-writing-mode: horizontal-tb;
		font-size: 28px;
		letter-spacing: 0.1em;
	}

	.promo--about .promo__text-group {
		margin-top: 0;
		gap: 20px;
		align-items: center;
	}
}

/* =========================================================
   スマホ(〜640px)
   ========================================================= */
@media screen and (max-width: 640px) {

	.promo {
		padding-block: 48px;
	}

	.promo--business .promo__inner {
		gap: 24px;
	}

	.promo--business .promo__title {
		font-size: 22px;
	}

	.promo--about .promo__inner {
		padding: 32px 16px;
	}

	.promo--about .promo__title {
		font-size: 24px;
	}

	.promo--about .promo__text {
		font-size: 13px;
	}

	.promo--about .promo__image {
		gap: 8px;
	}
}