/* レイアウト共通 */

.l-container {
	width: 100%;
	max-width: var(--container);
	margin: 0 auto;
	padding-inline: var(--sp-5);
}
.l-container--narrow {
	max-width: var(--container-narrow);
	margin-inline: auto;
	padding-inline: var(--sp-5);
}
.l-container--wide {
	max-width: var(--container-wide);
	margin: 0 auto;
	padding-inline: var(--sp-5);
}

.l-section {
	padding-block: var(--sp-8);
}
.l-section--alt {
	background: var(--c-bg-section);
}
@media (max-width: 768px) {
	.l-section { padding-block: var(--sp-6); }
}

.l-main {
	min-height: 60vh;
	padding-block-start: 0;
	padding-block-end: var(--sp-9);
}

/* ページタイトル（記事ヘッダー） */
.p-articleHead {
	margin-block-end: var(--sp-6);
}
.p-articleHead__title {
	font-size: var(--fs-3xl);
	line-height: var(--lh-snug);
	font-weight: var(--fw-bold);
	color: var(--c-fg);
}
@media (max-width: 640px) {
	.p-articleHead__title { font-size: var(--fs-xl); }
}
.p-articleHead__meta {
	margin-block-start: var(--sp-2);
	color: var(--c-fg-muted);
	font-size: var(--fs-sm);
}

/* グリッド */
.l-grid {
	display: grid;
	gap: var(--sp-5);
}
.l-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.l-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.l-grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
@media (max-width: 900px) {
	.l-grid--3, .l-grid--4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
	.l-grid--2, .l-grid--3, .l-grid--4 { grid-template-columns: 1fr; }
}

/* 2カラム（メイン+サイド） */
.l-content {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: var(--sp-7);
	align-items: start;
}
@media (max-width: 1000px) {
	.l-content { grid-template-columns: 1fr; gap: var(--sp-6); }
}

/* セクション見出し（細身・モノトーン基調） */
.c-sectionHead {
	margin-block-end: var(--sp-6);
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: var(--sp-4);
	flex-wrap: wrap;
}
.c-sectionHead__title {
	font-size: var(--fs-xl);
	font-weight: var(--fw-bold);
	color: var(--c-fg);
	letter-spacing: -.005em;
	display: flex;
	align-items: center;
	gap: var(--sp-3);
}
.c-sectionHead__title::before {
	content: "";
	display: inline-block;
	width: 28px; height: 1px;
	background: var(--c-primary);
	flex: 0 0 auto;
}
.c-sectionHead__more a {
	color: var(--c-primary);
	font-weight: var(--fw-medium);
	font-size: var(--fs-sm);
}
.c-sectionHead__more a::after {
	content: " →";
}

/* ボタン（細身・抑制系） */
.c-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--sp-2);
	padding: 14px var(--sp-6);
	border-radius: var(--r-md);
	font-weight: var(--fw-medium);
	font-size: var(--fs-sm);
	letter-spacing: .04em;
	transition: transform var(--dur-fast) var(--ease), background var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease), border-color var(--dur-fast) var(--ease);
	min-height: 48px;
	text-align: center;
	line-height: 1.3;
	cursor: pointer;
	border: 1px solid transparent;
}
.c-btn:hover { transform: translateY(-1px); }
.c-btn:active { transform: translateY(0); }

.c-btn--primary {
	background: var(--c-fg);   /* 墨色（ロゴ色）をプライマリボタンに */
	color: #fff;
	border-color: var(--c-fg);
}
.c-btn--primary:hover {
	background: var(--c-primary-dark);
	border-color: var(--c-primary-dark);
	color: #fff;
	box-shadow: var(--shadow-md);
}

.c-btn--accent {
	background: var(--c-accent);
	color: #fff;
	border-color: var(--c-accent);
}
.c-btn--accent:hover {
	background: var(--c-accent-dark);
	border-color: var(--c-accent-dark);
	color: #fff;
	box-shadow: var(--shadow-md);
}

.c-btn--ghost {
	background: transparent;
	color: var(--c-fg);
	border: 1px solid var(--c-fg-muted);
}
.c-btn--ghost:hover {
	background: var(--c-fg);
	color: #fff;
	border-color: var(--c-fg);
}

.c-btn--block {
	display: flex;
	width: 100%;
}

/* バッジ（細身・上品系） */
.c-badge {
	display: inline-flex;
	align-items: center;
	gap: var(--sp-1);
	padding: 4px 12px;
	border-radius: var(--r-sm);
	font-size: var(--fs-xs);
	font-weight: var(--fw-medium);
	letter-spacing: .06em;
	border: 1px solid transparent;
}
.c-badge--primary { background: var(--c-primary-soft); color: var(--c-primary-dark); border-color: var(--c-primary-light); }
.c-badge--accent  { background: var(--c-accent-soft); color: var(--c-accent-dark); border-color: rgba(198, 139, 88, .35); }
.c-badge--muted   { background: var(--c-bg-section); color: var(--c-fg-muted); }
.c-badge--closed  { background: var(--c-bg-section); color: var(--c-fg-faint); border-color: var(--c-border); }

/* パンくず */
.c-breadcrumb {
	font-size: var(--fs-sm);
	color: var(--c-fg-muted);
	margin-block-end: var(--sp-4);
}
.c-breadcrumb a { color: var(--c-fg-muted); }
.c-breadcrumb a:hover { color: var(--c-primary); }
.c-breadcrumb__sep { margin: 0 var(--sp-2); color: var(--c-fg-faint); }

/* ページネーション */
.c-pagination {
	display: flex;
	gap: var(--sp-2);
	justify-content: center;
	margin-block-start: var(--sp-7);
	flex-wrap: wrap;
}
.c-pagination .page-numbers {
	min-width: 40px;
	height: 40px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0 var(--sp-3);
	border: 1px solid var(--c-border);
	border-radius: var(--r-md);
	font-weight: var(--fw-medium);
	color: var(--c-fg);
	background: var(--c-bg-card);
	transition: all var(--dur-fast) var(--ease);
}
.c-pagination .page-numbers.current {
	background: var(--c-primary);
	color: #fff;
	border-color: var(--c-primary);
}
.c-pagination .page-numbers:hover:not(.current) {
	border-color: var(--c-primary);
	color: var(--c-primary);
}

/* お知らせ・エラーメッセージ */
.c-notice {
	padding: var(--sp-4) var(--sp-5);
	border-radius: var(--r-md);
	margin-block: var(--sp-4);
}
.c-notice--info  { background: var(--c-primary-soft); color: var(--c-primary-dark); border-left: 4px solid var(--c-primary); }
.c-notice--warn  { background: var(--c-accent-soft); color: var(--c-accent-dark); border-left: 4px solid var(--c-accent); }
.c-notice--error { background: #FCEAEA; color: var(--c-error); border-left: 4px solid var(--c-error); }
