/**
 * page-generic.css
 * service / cases / about / contact などの汎用ページ用スタイル
 * (ブランドシステム 09_brand.css を前提)
 */

.page-generic {
	padding-top: 80px; /* ヘッダー分 */
}

/* ページヒーロー共通 */
.page-hero {
	padding: 80px 0 72px;
	text-align: center;
	border-bottom: 1px solid var(--color-border);
}
.page-hero-title {
	font-family: var(--font-family-heading);
	font-size: clamp(2.8rem, 4.5vw, 4.0rem);
	font-weight: 800;
	color: var(--color-text-lead);
	margin: 0 0 20px;
	line-height: 1.4;
	letter-spacing: 0.02em;
}
.page-hero-lead {
	font-size: 1.7rem;
	color: var(--color-text-base);
	line-height: 1.9;
	max-width: 720px;
	margin: 0 auto 32px;
}

/* --- Case cards --- */
.case-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 20px;
}
.case-card {
	position: relative;
	background: var(--color-bg-body);
	border: 1px solid var(--color-border);
	border-left: 3px solid var(--color-brand);
	border-radius: var(--border-radius-base);
	padding: 28px 24px;
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.case-card:hover {
	transform: translateY(-3px);
	box-shadow: 0 12px 28px rgba(26, 62, 114, 0.1);
	border-left-color: var(--color-brand-hover);
}
.case-card::after {
	content: '+';
	position: absolute;
	top: 16px;
	right: 18px;
	font-family: var(--font-family-heading);
	font-size: 1.8rem;
	font-weight: 800;
	color: var(--color-brand);
	opacity: 0.25;
}
.case-card-industry {
	font-size: 1.2rem;
	font-weight: 600;
	color: var(--color-brand);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin: 0 0 8px;
}
.case-card-position {
	font-size: 1.8rem;
	font-weight: 700;
	color: var(--color-text-lead);
	margin: 0 0 12px;
	line-height: 1.5;
}
.case-card-outcome {
	font-size: 1.4rem;
	color: var(--color-text-base);
	line-height: 1.7;
	margin: 0;
	padding-top: 12px;
	border-top: 1px dashed var(--color-border);
}

/* --- Company info (about page) --- */
.company-info {
	max-width: 720px;
	margin: 0 auto;
	background: var(--color-bg-body);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	overflow: hidden;
}
.company-info-list {
	margin: 0;
	padding: 0;
}
.company-info-row {
	display: grid;
	grid-template-columns: 180px 1fr;
	padding: 18px 28px;
	border-bottom: 1px solid var(--color-border);
}
.company-info-row:last-child {
	border-bottom: 0;
}
.company-info-row dt {
	font-size: 1.3rem;
	font-weight: 700;
	color: var(--color-brand);
	letter-spacing: 0.05em;
	margin: 0;
}
.company-info-row dd {
	font-size: 1.5rem;
	color: var(--color-text-base);
	margin: 0;
	line-height: 1.7;
}
.company-info-row dd a {
	color: var(--color-brand);
	text-decoration: underline;
}

/* --- FAQ --- */
.faq-list {
	margin: 0;
}
.faq-row {
	background: var(--color-bg-body);
	border: 1px solid var(--color-border);
	border-radius: var(--border-radius-base);
	padding: 24px 28px;
	margin-bottom: 12px;
}
.faq-row dt {
	position: relative;
	padding-left: 28px;
	font-size: 1.6rem;
	font-weight: 700;
	color: var(--color-text-lead);
	margin: 0 0 10px;
	line-height: 1.5;
}
.faq-row dt::before {
	content: 'Q';
	position: absolute;
	left: 0;
	top: 0;
	font-family: var(--font-family-heading);
	font-weight: 800;
	color: var(--color-brand);
}
.faq-row dd {
	position: relative;
	padding-left: 28px;
	font-size: 1.4rem;
	color: var(--color-text-base);
	line-height: 1.8;
	margin: 0;
}
.faq-row dd::before {
	content: 'A';
	position: absolute;
	left: 0;
	top: 0;
	font-family: var(--font-family-heading);
	font-weight: 800;
	color: var(--color-text-light);
}

/* --- Responsive --- */
@media (max-width: 768px) {
	.page-hero {
		padding: 56px 0 48px;
	}
	.case-grid {
		grid-template-columns: 1fr;
	}
	.company-info-row {
		grid-template-columns: 1fr;
		gap: 6px;
		padding: 18px 20px;
	}
}
