/**
 * Corporate Philosophy Page Styles (企業情報 - 企業理念)
 *
 * Mobile-first: base styles for 400px, desktop overrides via media queries.
 *
 * Font: Noto Sans JP (Regular 400, Bold 700), Reddit Sans (SemiBold 600)
 * Text color: #333333
 * Corporate green: #6BB529
 * Background: #F3F8E7
 * Content width: 1100px (desktop centered)
 *
 * @package Okayama
 */



.page-corporate-philosophy {
	background-color: #f3f8e7;
}



.philosophy-hero {
	position: relative;
	padding: 40px 20px 0;
	overflow: hidden;
}

.philosophy-hero__inner {
	position: relative;
	z-index: 1;
}

.philosophy-hero__text {
	text-align: center;
	margin-bottom: 24px;
}

.philosophy-hero__subtitle-en {
	font-family: 'Reddit Sans', sans-serif;
	font-size: 16px;
	font-weight: 600;
	color: #6bb529;
	line-height: 1.6;
	margin: 0 0 4px;
}

.philosophy-hero__title {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 28px;
	font-weight: 700;
	color: #333;
	line-height: 1.6;
	margin: 0;
}

.philosophy-hero__images {
	display: flex;
	gap: 16px;
	justify-content: center;
}

.philosophy-hero__image-wrap {
	width: 172px;
	height: 181px;
	border-radius: 40% 60% 55% 45% / 55% 40% 60% 45%;
	overflow: hidden;
	border: 2px solid #6bb529;
	flex-shrink: 0;
}

.philosophy-hero__image-wrap--right {
	border-radius: 55% 45% 40% 60% / 45% 55% 45% 55%;
}

.philosophy-hero__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.philosophy-hero__decoration {
	position: absolute;
	top: -40px;
	right: -60px;
	width: 300px;
	pointer-events: none;
	z-index: 0;
}

.philosophy-hero__decoration-img {
	width: 100%;
	height: auto;
}



.philosophy-content {
	padding: 80px 20px 0;
	display: flex;
	flex-direction: column;
	gap: 80px;
}



.philosophy-card {
	background-color: #fff;
	border-radius: 18px;
	padding: 40px 20px;
	scroll-margin-top: 80px;
}

.philosophy-card__inner {

}

.philosophy-card__title {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 23px;
	font-weight: 700;
	color: #6bb529;
	line-height: 1.6;
	text-align: center;
	margin: 0 0 16px;
}

.philosophy-card__subtitle {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 18px;
	font-weight: 700;
	color: #333;
	line-height: 1.6;
	text-align: center;
	margin: 0 0 16px;
}

.philosophy-card__text {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 14px;
	font-weight: 400;
	color: #333;
	line-height: 2;
	text-align: center;
	margin: 0;
}

.philosophy-card__text--large {
	font-size: 18px;
	font-weight: 700;
	line-height: 1.6;
}


.philosophy-card__list {
	margin: 0;
	padding-left: 27px;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 18px;
	font-weight: 700;
	color: #333;
	line-height: 1.6;
}

.philosophy-card__list li {
	padding-left: 4px;
}


.philosophy-card__image {
	margin-top: 24px;
	border-radius: 18px;
	overflow: hidden;
}

.philosophy-card__image-img {
	width: 100%;
	height: auto;
	display: block;
}


.philosophy-card__diagram {
	margin-top: 24px;
}

.philosophy-card__diagram-img {
	width: 100%;
	height: auto;
	display: block;
}



@media (min-width: 768px) {

	.philosophy-hero {
		padding: 80px var(--corp-pad-side) 0;
	}

	.philosophy-hero__inner {
		display: flex;
		align-items: flex-start;
		justify-content: space-between;
	}

	.philosophy-hero__text {
		text-align: left;
		margin-bottom: 0;
		padding-top: 60px;
	}

	.philosophy-hero__title {
		font-size: 40px;
	}

	.philosophy-hero__images {
		gap: 24px;
	}

	.philosophy-hero__image-wrap {
		width: 240px;
		height: 253px;
	}

	.philosophy-hero__decoration {
		top: -80px;
		right: -40px;
		width: 500px;
	}


	.philosophy-content {
		padding: 80px var(--corp-pad-side) 0;
	}

	.philosophy-card {
		width: 100%;
		max-width: 1100px;
		margin: 0 auto;
		border-radius: 30px;
		padding: 64px clamp(20px, 6vw, 80px);
	}

	.philosophy-card__title {
		font-size: 35px;
		margin-bottom: 35px;
	}

	.philosophy-card__subtitle {
		font-size: 24px;
	}

	.philosophy-card__text {
		font-size: 16px;
	}

	.philosophy-card__text--large {
		font-size: 24px;
	}

	.philosophy-card__list {
		font-size: 24px;
		padding-left: 36px;
	}

	.philosophy-card__image {
		border-radius: 30px;
	}

	.philosophy-card__diagram {
		max-width: 657px;
		margin: 40px auto 0;
	}
}



@media (min-width: 1400px) {
	.philosophy-hero__image-wrap {
		width: 312px;
		height: 329px;
	}
}
