.noTitleBG {
	padding-top: 78px;
	width: 100vw;
}
.TitleBG {
	background: linear-gradient(rgba(230,230,255,0.5), rgba(230,230,255,0.5)), url(img/title_img.jpg) center center / cover no-repeat;
	width: 100vw;
	height: 360px;
	display: flex;
	justify-content: center;
	align-items: center;
}
/* ナビバー高さの変化に対応 */
@media screen and (max-width:768px) {
	.TitleBG {
		height: 220px;
		padding-top: 56px;
	}
}
@media screen and (min-width:769px) {
	.TitleBG {
		padding-top: 84px;
	}
}
@media screen and (min-width:1199px) {
	.TitleBG {
		padding-top: 103px;
	}
}
@media screen and (min-width:1423px) {
	.TitleBG {
		padding-top: 78px;
	}
}
.TitleBG h1 {
	width: 50%;
	margin: auto;
	text-align: center;
	background: white;
	opacity: 0.7;
	padding: 1em;
}
.topImg {
	margin: auto;
}
.topImg img {
	height: auto;
	max-width: 480px;
	margin: auto;
}
@media screen and (max-width:768px) {
	.TitleBG h1 {
		width: 80%;
		margin: auto;
		text-align: center;
	}

	.topImg img {
		height: auto;
		width: 100%;
	}
}

/* 発明力とは_トップ画像に入れ替え */
.activityImg {
	background: linear-gradient(rgba(230,230,255,0.5), rgba(230,230,255,0.5)), url(img/activity_title_img.jpg) center center / cover no-repeat;
}
/* 塾長の部屋用_トップ画像に入れ替え */
.jukucho-roomImg {
	background: linear-gradient(rgba(230,230,255,0.5), rgba(230,230,255,0.5)), url(img/jukucho-room_img.jpg) center center / cover no-repeat;
}
/* 月額顧問サービス_トップ画像に入れ替え */
.advisory-serviceImg {
	background: linear-gradient(rgba(230,230,255,0.5), rgba(230,230,255,0.5)), url(img/advisory-service_title-img.jpg) center center / cover no-repeat;
}
/* pifv書籍購入者限定特典ページ_トップ画像に入れ替え */
.special-pifvImg {
	background: linear-gradient(rgba(0,0,0,0.1), rgba(30,30,30,0.3)), url(img/special-pifv_title-img.jpg) center center / cover no-repeat;
}


/* メンバー紹介個別ページ */
.MemberTitleBG {
	background: url(img/title_img.jpg) left / cover no-repeat;
	width: 100vw;
	height: 400px;
	display: flex;
	justify-content: center;
	align-items: center;
}
/* 楠浦さん画像に入れ替え */
.kusuuraImg {
	background: url(/wp-content/uploads/2020/09/Kusuura_L-min.png) left / cover no-repeat;
}
/* 秋好さん画像に入れ替え */
.akiyoshiImg {
	background: url(/wp-content/uploads/2020/09/Akiyoshi_L.png) left / cover no-repeat;
}
/* 畑田さん画像に入れ替え */
.hatadaImg {
	background: url(/wp-content/uploads/2020/09/hatada_L.png) left / cover no-repeat;
}
/* ナビバー高さの変化に対応 */
@media screen and (max-width:768px) {
	.MemberTitleBG {
		height: 220px;
		padding-top: 56px;
	}
}
@media screen and (min-width:769px) {
	.MemberTitleBG {
		height: 300px;
		padding-top: 84px;
		position:relative;
		top: 40px;
	}
}
@media screen and (min-width:1199px) {
	.MemberTitleBG {
		height: 400px;
		padding-top: 103px;
		position:relative;
		top: 40px;
	}
}
@media screen and (min-width:1423px) {
	.MemberTitleBG {
		padding-top: 78px;
		position:relative;
		top: 40px;
	}
}
/* スマホ表示の調整 */
@media screen and (max-width:768px) {
	.bottom-space {
		padding-bottom: 150px;
	}
	.name-box {
		position:relative;
		top: 180px;
	}
	.name-box-l {
		position:relative;
		top: 200px;
	}
}
@media screen and (max-width:768px) {
	.bottom-space-extra {
	   padding-bottom: 200px; /* 150pxから50px増やす */
	}
 }
/* メンバー紹介個別ページここまで */

.blogText img {
	max-width: 100%;
	height: auto;
    display: block;
    margin: auto;
}
.fixMargin {
    margin: unset !important;
}

/* 動画埋め込み */
.blogText iframe {
		width: 792px;
		height: 440px;
}

@media screen and (max-width:768px) {
	.blogText iframe {
		width: 396px;
		height: 220px;
}
}

/*「「「「「「「「「「「「 PDFプレビュー用iframe 「「「「「「「「「「「「「*/
/* PDFプレビュー用iframe */
.blogText .pdf-preview iframe {
    width: 100%;
    height: 500px;
    max-width: 100%;
}

/* スマホ表示では高さを短く */
@media screen and (max-width: 768px) {
    .blogText .pdf-preview iframe {
        height: 350px;
    }
}

/* blogの文字スタイルの調節 */
.blogTitle h1{
	font-size: 1.5rem;
	color: #45596d;
}

@media screen and (max-width:768px) {
	.blogTitle h1 {
		font-size: 1.2rem;
		padding: 0 1rem;
	}
}

.blogText h2 {
    font-size: 1.5rem;
    margin: 2.5rem 0 16px 0;
	font-weight: bold;
	padding: 1rem;
	background-color: #f5f8fa;
    border-left: 6px solid #023eb5;
}
.blogText h3, .blogText h4, .blogText h5 {
    margin:  2rem 0  1rem 1.5rem;
    font-weight: bold;
}
.blogText h3{
    font-size: 1.25rem;
}
.blogText h4{
    font-size: 1.25rem;
}
.blogText h5{
    font-size: 1.125rem;
    font-weight: normal;	
}
.blogText p{
	margin: 1rem 0 1rem  2rem;
	line-height: 1.7;
}
.blogText ul{
    margin: 1rem 0 1rem  2rem;
}

.blogText blockquote {
    margin: 0 2rem 0 3rem;
    position: relative;
    padding: 30px 15px 8px 15px;
    box-sizing: border-box;
    font-style: italic;
    background: #efefef;
    color: #555;
}
.blogText blockquote:before {
    display: inline-block;
    position: absolute;
    top: 5px;
    left: 3px;
    content: "“";
    font-family: sans-serif;
    color: #cfcfcf;
    font-size: 90px;
    line-height: 1;
}
.blogText a {
    color: #296ec5;
    text-decoration: underline;
    background-color: transparent;
    word-break: break-all;
}
/* リスト内のURLも確実に改行 */
.blogText ul li,
.blogText ol li {
    word-break: break-all;
    overflow-wrap: break-word;
}

/* 表の余白調整 */
.blogText table p {
	margin: 0.3rem 0.3rem 0.3rem 0.5rem;
	line-height: 1;
}
.blogText table {
    margin: 0.5rem auto;
}
/* --- ブログ本文の表：PCは折り返し、スマホは横スクロール --- */
/* 表全体をスクロール可能に */
.blogText {
  overflow-x: auto;
}
/* 自然な列幅計算（PC時は折り返し） */
.blogText table {
  width: 100%;
  border-collapse: collapse;
  table-layout: auto;
}
/* 各セルの最大幅（スマホ時の1セル伸びすぎ防止） */
.blogText th,
.blogText td {
  padding: 0.5em;
  word-break: break-word;
  overflow-wrap: anywhere;
  white-space: normal;
  max-width: 400px;
}
/* 狭い画面では横スクロール＋自然な折り返しを両立 */
@media (max-width: 768px) {
  .blogText table {
    display: block;
    overflow-x: auto;
    white-space: normal;
  }
  .blogText th,
  .blogText td {
	padding: 0.3em;
    white-space: normal;
    min-width: 200px;
  }
}

/* ブログの文中のリンクが色が変わらない(altではなくspanで囲われるため)対策 */
.blogText p a span {
    color: #296ec5;
    text-decoration: underline;
    background-color: transparent;
}

@media screen and (max-width:768px) {
	.blogText h2 {
		font-size: 1.2rem;
		margin: 2.5rem 1rem 16px;
	}
    .blogText h3, h4 {
		font-size: 1.25rem;
		padding: 0;
	}
	.blogText p {
		margin: 0;
		padding: 1rem 1.2rem;
	}
	.blogText ul{
		margin: 1rem;
	}
	blockquote {
		margin: 0 1rem;
	}
}

/* 知見(コラム)アーカイブのサムネ調整 */
.thumbnail img {
	max-width: 15vw;
	height: auto;
}
@media screen and (max-width:768px) {
	.thumbnail img {
		max-width: 70vw;
		height: auto;
	}
}

/* アーカイブのしろフレーム幅調節 */
.inner{
	max-width: 1000px;
}
.outer{
	max-width: 1200px;
}

/*「「「「「 「「「「「「「Elementor style fix 「「「「「「「「「「「「「*/
/* 背景色が消える */
.BGfix{
	background-color: #F5F9FC !important;
}
.BGwhite{
	background-color: #ffffff !important;
}

/* 見出しのスタイル崩れ */
.heddingFix h2 {
	margin: 6rem auto 2rem;
	max-width: 1200px;
	text-align: center;
	font-weight: bold;
	line-height: 1.5;
}

/* ボタンのスタイルがデフォ系に変更される */
.btnFix1 .elementor-button-link.elementor-button.elementor-size-md {
	font-weight: bold !important;
	fill: #000 !important;
	color: #000 !important;
	background-color: #fff !important;
	border-style: solid !important;
	border-width: 1px 1px 1px 1px !important;
	border-color: #000 !important;
	border-radius: 0 0 0 0 !important;
	box-shadow: 0 4px 8px 1px rgba(217.50000000000003,217.50000000000003,217.50000000000003,.5) !important;
	padding: 2em 4em 2em 4em !important;
	margin: 3rem auto 4rem !important;
}

/* 勝手に入るhiddenを解除 */
[hidden] {display: none!important;}

.blog_card h3{
	margin: 0 auto;
	max-width: 240px;
	box-shadow: 0 4px 8px 1px rgb(232 232 232 / 50%);
    padding: 0.4rem 1rem;
}

/* 塾長の部屋、関連記事部分用に追加 */
.blog_card_title{
	margin: 0 auto;
	max-width: 240px;
	box-shadow: 0 4px 8px 1px rgb(232 232 232 / 50%);
    padding: 0.4rem 1rem;
}

/* ブログタイトルにカテゴリーボタン追加  */
.post-categories {
	list-style-type: none;
	padding: 0;
	margin: 0;
	text-align: center;
}
.post-categories li {
	display: inline-block;
	border: solid 1px #6c757d;
	border-radius: 2px;
	margin-right: 1em;
}
.post-categories a {
	display: block;
	color: #6c757d;
	padding: 2px 6px;
	font-size: 14px;
}
/* 1分コラムのカテゴリボタンはリンクさせない */
.events-0 a {
	pointer-events: none;
	display: block;
	color: #6c757d;
	padding: 2px 6px;
	font-size: 14px;
}
.post-categories a.voice-category,
.post-categories a.jukucho-room-category,
.post-categories a.column-category {
	font-size: 20px !important;
}
.post-categories a:hover,
.post-categories a:active {
	opacity: 0.7;
}
/* お声の子テーマ表示調整 */
.voice-child li {
	border: none;
}
.voice-child a.voice-category {
	text-decoration: underline;
	font-size: 1.125rem !important;
}
.parent-link a {
	color: #6c757d;
	text-decoration: underline;
	font-size: 1.5rem;
}

/* パンくずリスト */
.pankuzu {
    padding: 130px 0 1px 0 !important;
}
@media screen and (max-width:414px) {
	.pankuzu {
		padding: 90px 0 1px 0 !important;
	}
}

/* 1分コラム 個別設定 */
.single-column1min h2 {
    background-color: transparent;
}

/* =============================================
1分コラム - 読者アンケートボタン用CSS
============================================= */

/* 読者アンケートボタン */
.blogText a.reader-questionnaire-btn {
    background-color: #20477A;
    color: white;
    text-decoration: none;
    padding: 12px 16px;
    border-radius: 4px;
    display: inline-block;
    transition: all 0.3s ease;
    box-shadow: 0 4px 8px rgba(0,0,0,0.15);
    position: relative;
    overflow: hidden;
}

.blogText a.reader-questionnaire-btn:hover {
    background-color: #1a3a66;
    color: white;
    text-decoration: none;
    transform: translateY(2px);
    box-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

/* 光の波エフェクト */
.blogText a.reader-questionnaire-btn:before {
    content: "";
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(120deg,
            transparent,
            rgba(255, 255, 255, 0.3),
            transparent);
    transition: all 0.8s;
}

/* ホバー時の光の波アニメーション */
.blogText a.reader-questionnaire-btn:hover:before {
    left: 100%;
}

/* =============================================
   お知らせ記事用テーブルスタイル
   ============================================= */
.single-news .blogText table {
    width: 100%;
    border-collapse: collapse;
    border: 2px solid #adb5bd;
    margin: 1.5rem auto;
    background-color: #fff;
}

.single-news .blogText table th,
.single-news .blogText table td {
    border: 1px solid #dee2e6;
    padding: 0.75rem 1rem;
    vertical-align: top;
    text-align: left;
}

/* ヘッダー行（1行目）のスタイル */
.single-news .blogText table tr:first-child td,
.single-news .blogText table tr:first-child th {
    background-color: #f5f8fa;
    font-weight: bold;
    text-align: center;
}

/* 1列目（項目名列）のスタイル */
.single-news .blogText table td:first-child,
.single-news .blogText table th:first-child {
    background-color: #f9fafb;
    font-weight: bold;
}

/* テーブル内のテキスト調整 */
.single-news .blogText table p {
    margin: 0.3rem 0;
    line-height: 1.5;
}

/* スマホ表示時のテーブル調整 */
@media screen and (max-width: 768px) {
    .single-news .blogText table {
        font-size: 0.8rem;
        display: block;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
    }
    
    .single-news .blogText table th,
    .single-news .blogText table td {
        padding: 0.5rem 0.6rem;
        min-width: 100px;
    }
}