@charset "UTF-8";
/*
	Filename: voice
	Version: 1.0.1
	受講者の声（インタビュー）アーカイブ／個別ページ
*/

/*-----------------------------------------------------
	Archive: カードグリッド
------------------------------------------------------*/
.voice_archive_list,
#home_voice .home_voice_list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 32px;
	margin-bottom: 40px;
}
@media screen and (max-width: 1024px) {
	#home_voice .home_voice_list {
		grid-template-columns: repeat(2, 1fr);
		gap: 24px;
	}
}
@media screen and (max-width: 600px) {
	#home_voice .home_voice_list {
		grid-template-columns: 1fr;
		gap: 20px;
	}
}

/*-----------------------------------------------------
	トップページ「受講者の声」セクション
------------------------------------------------------*/
#home_voice {
	padding: 60px 0;
}
@media screen and (max-width: 1024px) {
	.voice_archive_list {
		grid-template-columns: repeat(2, 1fr);
		gap: 24px;
	}
}
@media screen and (max-width: 600px) {
	.voice_archive_list {
		grid-template-columns: 1fr;
		gap: 20px;
	}
}

/*-----------------------------------------------------
	Card
------------------------------------------------------*/
.voice_card {
	background: #fff;
	border: 1px solid #d8dee2;
	border-radius: 4px;
	overflow: hidden;
	transition: box-shadow 0.25s ease, transform 0.25s ease;
}
.voice_card:hover {
	box-shadow: 0 8px 24px rgba(0,0,0,0.08);
	transform: translateY(-2px);
}
.voice_card_link {
	display: block;
	color: inherit;
	text-decoration: none;
}
.voice_card_thumb {
	position: relative;
	width: 100%;
	aspect-ratio: 3 / 2;
	overflow: hidden;
	background: #f4f6f8;
}
.voice_card_thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
	transition: transform 0.4s ease;
}
.voice_card:hover .voice_card_thumb img:not(.voice_card_thumb_logo) {
	transform: scale(1.04);
}
/* デフォルト画像 + ロゴオーバーレイ */
.voice_card_thumb--default::after {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(19, 88, 120, 0.45);
	pointer-events: none;
}
.voice_card_thumb_default {
	filter: brightness(0.95);
}
.voice_card_thumb_logo {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: auto !important;
	height: auto !important;
	max-width: 70%;
	max-height: 50%;
	object-fit: contain !important;
	z-index: 2;
	filter: brightness(0) invert(1);
	opacity: 0.95;
	transition: transform 0.4s ease;
}
.voice_card:hover .voice_card_thumb_logo {
	transform: translate(-50%, -50%) scale(1.04);
}
.voice_card_body {
	padding: 20px 22px 24px;
}
.voice_card_role {
	margin: 0 0 8px;
	font-size: 12px;
	letter-spacing: 0.08em;
	color: #135878;
	font-weight: 600;
}
.voice_card_title {
	margin: 0 0 12px;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.5;
	color: #1a2e3a;
}
.voice_card_excerpt {
	margin: 0 0 16px;
	font-size: 14px;
	line-height: 1.7;
	color: #4a5965;
}
.voice_card_more {
	display: inline-block;
	font-size: 12px;
	letter-spacing: 0.1em;
	color: #135878;
	font-weight: 600;
}

/*-----------------------------------------------------
	Pagination
------------------------------------------------------*/
.voice_pagination {
	display: flex;
	justify-content: center;
	margin: 40px 0 20px;
}
.voice_pagination ul {
	display: flex;
	gap: 6px;
	padding: 0;
	list-style: none;
}
.voice_pagination ul li {
	list-style: none;
}
.voice_pagination ul li a,
.voice_pagination ul li span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 10px;
	border: 1px solid #d8dee2;
	background: #fff;
	color: #135878;
	text-decoration: none;
	font-size: 14px;
}
.voice_pagination ul li span.current {
	background: #135878;
	color: #fff;
	border-color: #135878;
}
.voice_pagination ul li a:hover {
	background: #f4f6f8;
}

/*-----------------------------------------------------
	Empty state
------------------------------------------------------*/
.voice_empty {
	text-align: center;
	padding: 60px 20px;
	color: #6a7783;
	font-size: 15px;
}

/*-----------------------------------------------------
	Single（マガジン風インタビューレイアウト）
	構成：役職 → タイトル → ヒーロー画像 → 動画 → 本文 → 戻る
------------------------------------------------------*/
.voice_single {
	max-width: 920px;
	margin: 0 auto;
	padding: 0;
	background: transparent;
	border: none;
}
.voice_single_head {
	max-width: 880px;
	margin: 0 auto 36px;
	padding: 0 20px;
	text-align: center;
}
.voice_single_role {
	display: inline-block;
	margin: 0 0 14px;
	padding: 4px 14px;
	font-size: 12px;
	letter-spacing: 0.12em;
	color: #135878;
	font-weight: 600;
	background: #eaf1f5;
	border-radius: 2px;
}
.voice_single_title {
	margin: 0;
	font-size: 30px;
	font-weight: 700;
	line-height: 1.55;
	color: #1a2e3a;
	letter-spacing: 0.02em;
}
@media screen and (max-width: 600px) {
	.voice_single_title {
		font-size: 22px;
	}
}

/* ヒーロー画像（アイキャッチ未設定時は表示しない） */
.voice_single_thumb {
	width: 100%;
	margin: 0 0 36px;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #f4f6f8;
	border-radius: 4px;
}
.voice_single_thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}

/* 本文（ヒーロー画像と幅を揃える） */
.voice_single_body {
	max-width: 880px;
	margin: 0 auto;
	padding: 0 20px;
	font-size: 16px;
	line-height: 2;
	color: #2a3640;
}
.voice_single_body p {
	margin: 0 0 1.6em;
}
.voice_single_body h2,
.voice_single_body h3,
.voice_single_body h4 {
	font-weight: 700;
	color: #1a2e3a;
	line-height: 1.5;
}
.voice_single_body h2 {
	margin: 2.4em 0 1em;
	padding: 0 0 0 16px;
	font-size: 22px;
	border-left: 4px solid #135878;
}
.voice_single_body h3 {
	margin: 2em 0 0.8em;
	font-size: 18px;
	color: #135878;
}
.voice_single_body h4 {
	margin: 1.6em 0 0.6em;
	font-size: 16px;
}
.voice_single_body ul,
.voice_single_body ol {
	margin: 0 0 1.6em 1.5em;
}
.voice_single_body img {
	max-width: 100%;
	height: auto;
}
.voice_single_body blockquote,
.voice_single_body .wp-block-quote {
	margin: 1.5em 0;
	padding: 16px 20px;
	background: #f4f6f8;
	border-left: 3px solid #135878;
	font-size: 15px;
	line-height: 1.85;
	color: #4a5965;
}
.voice_single_body .wp-block-quote cite {
	display: block;
	margin-top: 8px;
	font-size: 13px;
	color: #6a7884;
	font-style: normal;
}

/* ブロックエディタ：画像ブロック */
.voice_single_body .wp-block-image {
	margin: 2em 0;
}
.voice_single_body .wp-block-image img {
	display: block;
	border-radius: 4px;
}
.voice_single_body .wp-block-image figcaption {
	margin-top: 10px;
	font-size: 13px;
	color: #6a7884;
	text-align: center;
	line-height: 1.6;
}
.voice_single_body .wp-block-image.alignleft {
	float: left;
	margin: 0.5em 1.5em 1.5em 0;
	max-width: 50%;
}
.voice_single_body .wp-block-image.alignright {
	float: right;
	margin: 0.5em 0 1.5em 1.5em;
	max-width: 50%;
}
.voice_single_body .wp-block-image.aligncenter {
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}
.voice_single_body .wp-block-image.alignwide,
.voice_single_body .wp-block-image.alignfull {
	margin-left: 50%;
	transform: translateX(-50%);
	max-width: 900px;
	width: calc(100vw - 40px);
}

/* ブロックエディタ：YouTube/動画埋込（レスポンシブ） */
.voice_single_body .wp-block-embed {
	margin: 2em 0;
}
.voice_single_body .wp-block-embed .wp-block-embed__wrapper {
	position: relative;
	padding-bottom: 56.25%; /* 16:9 */
	height: 0;
	overflow: hidden;
	background: #000;
	border-radius: 4px;
}
.voice_single_body .wp-block-embed iframe,
.voice_single_body .wp-block-embed object,
.voice_single_body .wp-block-embed embed,
.voice_single_body .wp-block-embed video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 0;
}
.voice_single_body .wp-block-embed figcaption {
	margin-top: 10px;
	font-size: 13px;
	color: #6a7884;
	text-align: center;
}

/* ブロックエディタ：ギャラリー */
.voice_single_body .wp-block-gallery {
	margin: 2em 0;
}

/* ブロックエディタ：区切り */
.voice_single_body .wp-block-separator {
	border: none;
	border-top: 1px solid #e4eaef;
	margin: 2.5em auto;
	max-width: 80px;
}

/* ブロックエディタ：リスト */
.voice_single_body .wp-block-list,
.voice_single_body ul.wp-block-list,
.voice_single_body ol.wp-block-list {
	margin: 0 0 1.6em 1.5em;
}
.voice_single_body .wp-block-list li {
	margin-bottom: 0.3em;
}

/* ブロックエディタ：テーブル */
.voice_single_body .wp-block-table {
	margin: 2em 0;
}
.voice_single_body .wp-block-table table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}
.voice_single_body .wp-block-table th,
.voice_single_body .wp-block-table td {
	padding: 10px 12px;
	border: 1px solid #e4eaef;
	text-align: left;
}
.voice_single_body .wp-block-table th {
	background: #f4f6f8;
	font-weight: 600;
}

/* float clearing for alignleft/alignright */
.voice_single_body::after {
	content: "";
	display: table;
	clear: both;
}

/* 戻る */
.voice_single_nav {
	max-width: 880px;
	margin: 60px auto 0;
	padding: 32px 20px 0;
	border-top: 1px solid #e4eaef;
	text-align: center;
}
.voice_single_back {
	display: inline-block;
	padding: 12px 32px;
	border: 1px solid #135878;
	color: #135878;
	background: #fff;
	text-decoration: none;
	font-size: 14px;
	letter-spacing: 0.06em;
	transition: background 0.2s ease, color 0.2s ease;
}
.voice_single_back:hover {
	background: #135878;
	color: #fff;
}
