body {
	background: linear-gradient(135deg, #fff8ec 0%, #fefefe 100%);
	color: #2f2f2f;
	margin: 0;
	padding: 0;
	line-height: 1.8;
}

.interview-container {
	max-width: 1100px;
	margin: auto;
	padding: 80px 20px;
}

.interview-profile,
.interview-section,
.interview-qa {
	background: #ffffffec;
	border-radius: 20px;
	box-shadow: 0 12px 36px rgba(0, 0, 0, 0.06);
	padding: 48px;
	margin-bottom: 70px;
	display: flex;
	gap: 48px;
	align-items: center;
	flex-wrap: wrap;
	transition: transform 0.4s ease;
}

.interview-profile:hover,
.interview-section:hover,
.interview-qa:hover {
	transform: translateY(-4px);
}

.row-reverse {
	flex-direction: row-reverse;
}

.profile-text,
.section-text {
	flex: 1;
	min-width: 280px;
}

.profile-text h2 {
	font-size: 32px;
	font-weight: 700;
	color: #4a2c2a;
	margin-bottom: 10px;
	line-height: 1.2;
}

.profile-text .position {
	font-size: 16px;
	color: #7b6f67;
	font-weight: 500;
	margin-bottom: 16px;
}

.meta {
	font-size: 14px;
	color: #666;
	margin-bottom: 4px;
}

.profile-image img,
.gallery-image img {
	width: 100%;
	max-width: 280px;
	border-radius: 16px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
}

.catchphrase {
	color: #a24c2a;
	font-weight: bold;
	font-style: italic;
	margin-top: 24px;
	font-size: 18px;
}

h3 {
	font-size: 22px;
	border-left: 4px solid #4a2c2a;
	padding-left: 14px;
	margin-bottom: 16px;
	font-weight: 600;
}

.section-text p {
	font-size: 16px;
	color: #333;
}

.qa-block {
	margin-top: 30px;
}
.qa-block h4 {
	font-weight: 600;
	color: #4a2c2a;
	margin-bottom: 8px;
	font-size: 18px;
}
.qa-block p {
	color: #444;
	font-size: 16px;
}

/* ========== アニメーション ========== */
[data-animate] {
	opacity: 0;
	transform: translateY(40px);
	transition: all 0.9s cubic-bezier(0.25, 0.8, 0.25, 1);
	will-change: transform, opacity;
}

[data-animate].animate-fade-up {
	opacity: 1;
	transform: translateY(0);
}
[data-animate="fade-left"] {
	transform: translateX(-60px);
}
[data-animate="fade-right"] {
	transform: translateX(60px);
}
[data-animate].animate-fade-left,
[data-animate].animate-fade-right {
	opacity: 1;
	transform: translateX(0);
}

/* ========== レスポンシブ ========== */
@media (max-width: 768px) {
	.interview-profile,
	.interview-section {
		flex-direction: column;
	}

	.profile-text h2 {
		font-size: 26px;
	}

	.gallery-image img,
	.profile-image img {
		margin: auto;
	}

	.section-text,
	.profile-text {
		padding: 0 10px;
	}
}

#sidebar {
	display: none;
}

/* ========== 入社メッセージセクション ========== */
.entry-message {
	background: #ffffffec;
	border-radius: 20px;
	box-shadow: 0 12px 36px rgba(0, 0, 0, 0.06);
	padding: 48px;
	margin-bottom: 70px;
	transition: transform 0.4s ease;
}

.entry-message:hover {
	transform: translateY(-4px);
}

.entry-message h2 {
	font-size: 28px;
	color: #4a2c2a;
	margin-bottom: 20px;
	border-left: 4px solid #4a2c2a;
	padding-left: 14px;
	font-weight: 600;
}

.entry-message .lead {
	font-size: 16px;
	line-height: 1.9;
	color: #333;
	white-space: pre-line;
}

/* ========== クレドガーデンの魅力3つ ========== */
.entry-points {
	background: #ffffffec;
	border-radius: 20px;
	box-shadow: 0 12px 36px rgba(0, 0, 0, 0.06);
	padding: 48px;
	margin-bottom: 70px;
	transition: transform 0.4s ease;
}

.entry-points:hover {
	transform: translateY(-4px);
}

.entry-points h2 {
	font-size: 28px;
	color: #4a2c2a;
	margin-bottom: 32px;
	border-left: 4px solid #4a2c2a;
	padding-left: 14px;
	font-weight: 600;
}

.points-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 24px;
}

.point-card {
	flex: 1 1 300px;
	background: #fef6f1;
	padding: 24px;
	border-radius: 14px;
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.05);
	transition: transform 0.3s ease;
}

.point-card:hover {
	transform: translateY(-6px);
}

.point-card h3 {
	font-size: 18px;
	font-weight: bold;
	color: #a24c2a;
	margin-bottom: 12px;
}

.point-card p {
	font-size: 15.5px;
	color: #444;
	line-height: 1.8;
}

/* ========== 職場の雰囲気 ========== */
.entry-gallery {
	background: #ffffffec;
	border-radius: 20px;
	box-shadow: 0 12px 36px rgba(0, 0, 0, 0.06);
	padding: 48px;
	margin-bottom: 70px;
	transition: transform 0.4s ease;
}

.entry-gallery:hover {
	transform: translateY(-4px);
}

.entry-gallery h2 {
	font-size: 28px;
	color: #4a2c2a;
	margin-bottom: 20px;
	border-left: 4px solid #4a2c2a;
	padding-left: 14px;
	font-weight: 600;
}

.gallery-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 16px;
}

.gallery-item {
	text-align: center;
}

.gallery-item img {
	width: 60%;
	border-radius: 12px;
	object-fit: cover;
	aspect-ratio: 4 / 3;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.06);
	transition: transform 0.3s ease;
}

.gallery-item img:hover {
	transform: scale(1.02);
}

/* ========== レスポンシブ調整 ========== */
@media (max-width: 768px) {
	.points-grid {
		flex-direction: column;
	}

	.entry-message h2,
	.entry-points h2,
	.entry-gallery h2 {
		font-size: 24px;
	}

	.entry-message .lead {
		font-size: 15px;
	}

	.point-card h3 {
		font-size: 16px;
	}

	.point-card p {
		font-size: 14.5px;
	}
}

/* ========== スマホ（599px以下）専用レスポンシブ ========== */
@media (max-width: 599px) {
	.interview-container {
		padding: 40px 15px;
	}

	.interview-profile,
	.interview-section,
	.interview-qa,
	.entry-message,
	.entry-points,
	.entry-gallery {
		padding: 24px;
		margin-bottom: 40px;
		gap: 20px;
		flex-direction: column; /* 強制1カラム */
	}

	.profile-text h2 {
		font-size: 22px;
	}

	.profile-text .position {
		font-size: 14px;
		margin-bottom: 10px;
	}

	.meta {
		font-size: 13px;
	}

	.catchphrase {
		font-size: 15px;
		margin-top: 16px;
	}

	h3 {
		font-size: 18px;
		padding-left: 10px;
		margin-bottom: 12px;
	}

	.section-text p,
	.qa-block p,
	.entry-message .lead,
	.point-card p {
		font-size: 14px;
		line-height: 1.6;
	}

	.qa-block h4 {
		font-size: 16px;
	}

	.profile-image img,
	.gallery-image img {
		max-width: 220px;
		margin: auto;
	}

	.points-grid {
		gap: 16px;
	}

	.point-card {
		padding: 16px;
	}

	.point-card h3 {
		font-size: 15px;
	}

	.gallery-item img {
		width: 100%; /* スマホは幅いっぱい */
		aspect-ratio: 4/3; /* 比率維持 */
	}
}
