/*!教室詳細用*/
.about {
	margin-top: 0px;
}

.about div {
	width: unset!important;
	margin:unset!important;
}

.wrapper,.container{
	background: #fff;
}

.main{
	width: 100%;
	max-width: 850px;
	padding:10px 0 0 0;
}
.hero{
	background-image: none;
	background-size: auto;
	position: relative;	
	  width: 100vw;
	  left: 50%;
	  right: 50%;
	  margin-left: -50vw;
	  margin-right: -50vw;
	  height: 50vw;
}

.top-banner p{
	 color: #fff;
	 margin: 0 auto;
	 font-size: 13px;
	 font-weight: normal;
	 padding-left: 20px;
 }

.font-red{
	color:red;
	font-weight:bold;
}

p.school-attention__top {
  position: relative;
  width: 100vw!important;
  left: 50%!important;
  right: 50%!important;
  margin-top:10px!important;
  margin-left: -50vw!important;
  margin-right: -50vw!important;
  margin-bottom: 3vw!important;
  padding:3vw 0;
  background-color: #003C84;
}

p.school-attention__top span{
	color:#fff!important;
	font-size: 1.5vw!important;
	letter-spacing: 0.1em;
}


/*		
		.hero::after {
			content: '';
			position: absolute;
			right: 0;
			top: 35%;
			width: 35%;
			height: 65%;
			background-image:url(https://rwd.eiken-academy.h2-server.com/rwd-top/img/ac_mv.png);
			background-repeat: no-repeat;
			background-size: cover;
			z-index: 1;
			background-position: center center;
			transform: translateX(-65%);
		}
*/
.hero__mv{
	position: absolute;
	top:0;
	right: 0;
	height: 103%;
}
.hero__container {
	min-height: auto;
	//max-width: 850px;
	margin: 0 auto;
	position: relative;
	display: flex;
	z-index: 2;
}
.hero__content {
	//max-width: 400px;
	width: 100%;
	max-width: 55%;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding-top:1vw;
}

.main-title {
	color: #222222;
	font-size: 3vw;
	font-weight: 700;
	line-height: 1.7;
	margin-bottom: 1rem;
	letter-spacing: 0.2em;
	margin-top: 0;
	padding-left: 0%;
	text-align:center;
	font-family: "BIZ UDMincho", serif;
	  font-weight: bold;
	  font-style: normal;
}
.main-title_l {
	font-size: 76px;
}

.hero__cta__pc {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.hero__cta__pc a.btn-hover{
	text-align: center;
}

.mv-catch-txt_pc {
	width: 100%;
	max-width: 80%;
	margin-bottom: 2vw;
}

.mv-3circle {
	width: 100%;
	max-width: 80%;
}

.mv-cta-txt {
	width: 100%;
	margin: 2vw 0 0.5vw;
	max-width: 80%;
}

.cta-image {
	width: 100%;
	max-width: 90%;
}

.hero__cta__sp {
	display: none;
}

p.about-ea__video{
	margin: 0 auto;
	text-align: center;
}

p.about-ea__video video{
	width: 95%;
}

h2.video__about-eikenac{
	position: relative;
	z-index: 1;
	//width: 70%;
	margin: 0 auto 3vw;
}

h2.video__about-eikenac span{
	font-size: 1em!important;
}

#about-ea__container{
	text-align: center;
}

#about-ea__container  h2{
	color: #003C84;
	line-height: 1.2;
}

#about-ea__container .ribbon__yellow{
	margin-bottom:2.5em!important;
}

#about-ea__container .ribbon__yellow::after {
	margin-bottom:-10px;
}

#basic-info__container{
	margin-top:3vw;
	margin-bottom:5.5vw;
}

.nearby-classrooms__header .ribbon__yellow{
	line-height: 1.2;
}

.nearby-classrooms__header .ribbon__yellow::after {
	margin-bottom:-0.9vw;
}


/*!全幅青背景見出し*/
.about .basic-info__header,.about .nearby-classrooms__header,.about .nearby-school__header,.about .pass-record__header,.about .greetings__header,.about .voice__header{
	position: relative;
	width: 100vw!important;
	left: 50%;
	right: 50%;
	margin-top: 3vw!important;
	margin-left: -50vw!important;
	margin-right: -50vw!important;
	margin-bottom: 3vw!important;
	padding: 3vw 0;
	background-color: #003C84;
	text-align: center;
}

.basic-info__map{
	text-align: center;
}

.basic-info__map iframe{
	width: 95%;
}

/*!基本情報ボタン*/

  .about-ea__button {
	display: flex;
	flex-wrap: wrap;
	gap: 15px;
	margin: 0 auto;
	padding: 30px 0;
	position: sticky;
	top: 0;
	z-index: 1;
}

.tab-link {
	flex: 1;
	min-width: 120px;
	background-color: #f0f0f0;
	color: #333;
	border: none;
	border-radius: 5px;
	padding: 15px 10px;
	font-size: 16px;
	text-align: center;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	transition: background-color 0.2s;
}

.tab-link:hover {
	background-color: #e0e0e0;
}

.tab-link.active {
	background-color: #1a3a7e;
	color: white;
}

.triangle {
	display: inline-block;
	margin-left: 5px;
}

.content-section {
	padding: 60px 20px;
	min-height: 400px;
	max-width: 800px;
	margin: 0 auto;
	background-color: white;
}

h2 {
	color: #1a3a7e;
	margin-top: 0;
}

/* スムーズスクロール */
html {
	scroll-behavior: smooth;
}

/* レスポンシブデザイン */
@media (max-width: 769px) {
	.button-container {
		flex-direction: column;
	}
	
	.tab-link {
		width: 100%;
	}
}

/*!基本情報の表*/
.basic-info__table {
	margin: 0 auto;
}

.info-table {
	width: 100%;
	border-collapse: collapse;
	background-color: #fff;
	margin-bottom: 30px;
}

.info-table th,
.info-table td {
	padding: 12px 15px;
	border: 1px solid #ddd;
	text-align: left;
	vertical-align: middle; /* 上下中央配置 */
}

/* 通常の見出しセル */
.info-table th {
	background-color: #fff;
	color: #333;
	font-weight: normal;
	width: 160px;
}

/* 教室名の行（最初の行）だけ青い背景に */
.info-table tr:first-child th,
.info-table tr:first-child td {
	background-color: #1a3a7e;
	color: white;
	font-weight: bold;
}

/* 偶数行の背景色 */
.info-table tr:nth-child(even) td {
	//background-color: #f9f9f9;
}

/* レスポンシブ対応 */
@media (max-width: 640px) {
/*	.info-table, 
	.info-table tbody, 
	.info-table tr, 
	.info-table th, 
	.info-table td {
		display: block;
		width: 100%;
	}
*/	
	.info-table{
		font-size: 14px;
	}

	.info-table th {
		text-align: left;
		padding: 10px;
		width: 120px;
	}
	
	.info-table td {
		border-top: none;
		padding: 10px;
	}
	
	.info-table tr {
		margin-bottom: 1em;
	}
}



.title-decoration-yellow {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 13px;
	background: #FFC800;
	z-index: -1;
	transform: skewX(-45deg);
}


.ribbon__yellow {
	position: relative;
	display: inline-block;
}

.ribbon__yellow h2 {
	margin: 0;
	padding: 0;
	font-weight: bold;
	color: #fff;
	font-size: 20px;
	position: relative;
	z-index: 1;
	font-size: 2em !important;
	font-weight: bold;
	padding:0 0.5em;
}

.ribbon__yellow::after {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	bottom: 0vw;
	width: 100%;
	height: 13px;
	background: #FFC800;
	z-index: 0;
	transform: skewX(-45deg);
}

.about .button__blue-frame{
	width: 30%!important;
	margin:30px auto!important;
}

.button__blue-frame a{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #003686;
	text-decoration: none;
	font-size: 14px;
	font-weight: 600;
	border: 2px solid #003686;
	padding: 0.5rem;
	border-radius: 100px;
	width: 100%;
}


#basic-info__container .button__blue-frame a{
	position: relative;
}

#basic-info__container .button__blue-frame a:after{
	content: "▶";
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
}


/*!近隣の英検アカデミー教室一覧*/
 .nearby-classrooms_table {
	max-width: 800px;
	margin: 0 auto;
}

 .nearby-classrooms_table table {
	width: 100%;
	border-collapse: collapse;
	background-color: #fff;
	margin-bottom: 30px;
}

 .nearby-classrooms_table table th,
 .nearby-classrooms_table table td {
	padding: 12px 15px;
	border: 1px solid #ddd;
	vertical-align: middle;
}

/* ヘッダー行 */
 .nearby-classrooms_table table thead th {
	background-color: #1a3a7e;
	color: white;
	font-weight: bold;
	text-align: center;
}

/* エリア列（最初の列）のスタイル - クラス名を使わずにセレクタで指定 */
 .nearby-classrooms_table table tbody td:first-child {
	background-color: #1a3a7e;
	color: white;
	text-align: center;
	width: 30%;
}

/* 教室リンク */
.school-link {
	color: #0066cc;
	text-decoration: none;
	margin-right: 15px;
	display: inline-block;
}

.school-link:hover {
	text-decoration: underline;
}

/* レスポンシブ対応 */
@media (max-width: 640px) {
	.area-table, 
	.area-table tbody, 
	.area-table tr, 
	.area-table th, 
	.area-table td {
		display: block;
		width: 100%;
	}
	
	.area-table tbody td:first-child {
		width: 100%;
	}
	
	.area-table td {
		border-top: none;
	}
	
	.area-table tr {
		margin-bottom: 1em;
	}
	
	.school-link {
		margin-bottom: 8px;
	}
}


/*!近隣の学校一覧*/
.nearby-school__list{
	font-size: 1.2em;
	font-weight: bold;
}

.small-txt{
	font-size: 70%;
}

/*!保護者の声*/

.voice__header h2{
	line-height: 1.2;
	color:#fff!important;
}

.voice__header .ribbon__yellow::after {
	bottom: -0.9vw;
}

.about .voice__container {
	max-width: 800px;
	margin: 0 auto!important;
	width: 100%!important;
}

.about .voice__card {
	background-color: #deedfc;
	border-radius: 5px;
	padding: 20px!important;
	margin-bottom: 20px!important;
	display: flex;
	align-items: flex-start;
	width: 100%!important;
}

.about .avatar {
	width: 25%!important;
	height: 25%!important;
	margin-right: 20px;
	flex-shrink: 0;
}

.avatar img{
	width: 100%;
	height: 100%;
}

.voice__content {
	flex-grow: 1;
}

.voice__content p{
	line-height: 1.5!important;
}

.voice__title {
	font-size: 1.8em;
	font-weight: bold;
	margin-bottom: 5px;
	color: #333;
}

.voice__subtitle {
	font-size: 1.2em;
	font-weight: bold;
	color: #333;
	margin-bottom: 10px;
}

.voice__text {
	font-size: 14px;
	line-height: 1.6;
	color: #333;
	letter-spacing: 0.1em;
}

@media (max-width: 600px) {
	.testimonial-card {
		flex-direction: column;
	}
	
	.avatar {
		margin-bottom: 15px;
		margin-right: 0;
	}
}

/*!合格実績*/
.results-header-txt {
	background: #fff;
	color: #000;
}

.results-subtitle {
	text-align: center;
	font-size: 16px;
	font-weight: 600;
	padding: 0 0 1rem 0;
	margin-bottom: 0;
}

.result-list {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	margin-bottom: 2rem;
	margin: 0 auto;
}

.about .result-card {
	background: white;
	padding: 0.5rem 0.5rem 1rem 0.5rem!important;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	box-shadow: 0 0 5px 0 rgba(0, 0, 0, 0.3);
}

.result-image {
	width: 120px !important;
	height: 120px;
	background: #f0f0f0;
	flex-shrink: 0;
}

.about .result-content {
	margin-top: auto!important;
}

.result-content_title {
	font-size: 15px;
	font-weight: 600;
	flex-grow: 1;
}

.result-text {
	font-size: 14px;
	line-height: 1.6;
	margin-bottom: 0.5rem;
}

.result-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #003686;
	text-decoration: none;
	font-size: 14px;
	font-weight: 600;
	border: 2px solid #003686;
	padding: 0.3rem;
	border-radius: 100px;
	width: 100%;
}

.view-all-button {
	display: flex;
	align-items: center;
	justify-content: center;
	color: #003686;
	background: #fff;
	text-decoration: none;
	font-size: 14px;
	font-weight: 600;
	border: 2px solid #003686;
	padding: 0.5rem;
	border-radius: 100px;
	max-width: 300px;
	margin: 2em auto;
	width: 80%;
	position: relative;
}


a.result-button {
	position: relative;
}

a.view-all-button:after,a.result-button:after{
	content: "▶";
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
}

@media screen and (min-width: 960px) {
	.result-list {
		max-width: 1200px;
		flex-direction: row;
		justify-content: center;
	}
	
	.about .result-card {
		height: 420px;
		flex-direction: column;
		width: 25%!important;
	}
	.result-image {
		width: 100% !important;
		height: auto;
	}
}

/*!共通パーツ*/
/*!選ばれる理由*/
.reasons-container{
	margin-top:2em;
	text-align: center;
}

 .reasons-container h2{
	line-height: 1.2;
	color:#1a3a7e!important;
}

.reasons-container .ribbon__yellow{
	margin-bottom:3em!important;
}

.reasons-container .ribbon__yellow::after{
	bottom: -0.9vw;
}


.about .reasons-content {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 20px;
	max-width: 1200px;
	margin-bottom: 40px!important;
}

.about .reason-card {
	width: 270px!important;
	background-color: #0c2f81; /* 濃い青色の背景 */
	overflow: hidden;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
	display: flex;
	flex-direction: column;
	align-items:center;
	padding-bottom: 20px;
}

.about .reason-header {
	position: relative;
	padding: 15px 10px 15px 20px;
	margin:0 auto!important;
}

.reason-title {
	position: relative;
	color: #0c2f81;
	font-weight: bold;
	font-size: 18px;
	padding: 0 30px;
	display: inline-block;
	margin-bottom: 15px;
	z-index: 1;
}

.reason-title:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #ffc72c; /* 黄色の背景 */
	transform: skew(-45deg);
	z-index: -1;
}

.reason-text {
	color: white;
	text-align: center;
	font-size: 16px;
	line-height: 1.6;
	padding: 0 15px 15px;
}

.about .reason-image {
	flex-grow: 1;
	width:80%!important;
}

.reason-image img{
	width: 100%;
	height: 150px;
	object-fit: cover;
	display: block;
	border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.see-more-button {
	background-color: #ffc72c; /* 黄色のボタン */
	color: #333;
	font-weight: bold;
	padding: 15px 40px;
	border-radius: 50px;
	text-align: center;
	display: inline-block;
	cursor: pointer;
	transition: all 0.3s ease;
	text-decoration: none;
	font-size: 16px;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
	position: relative;
}

.see-more-button:after {
	content: "▶";
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
}

.see-more-button:hover {
	background-color: #ffd152;
}

@media (max-width: 768px) {
	.reasons-container {
		flex-direction: column;
		align-items: center;
	}
	
	.reason-card {
		width: 100%;
		max-width: 400px;
	}
}



/*!コース一覧*/
.about .course-wrapper {
/*	
	background: #003686;
	width: 100%;
	padding: 2rem 1rem;
	*/
	position: relative;
	width: 100vw!important;
	left: 50%;
	right: 50%;
	margin-top: 3vw!important;
	margin-left: -50vw!important;
	margin-right: -50vw!important;
	margin-bottom: 3vw!important;
	padding: 3vw 0;
	background-color: #003C84;
	text-align: center;
}

#course-section {
	padding: 2rem 1rem;
	max-width: 830px;
	margin: 0 auto;
}

#course-section .ribbon__yellow{
	margin-bottom: 2.5em!important;
}

.course-title {
	color: white;
	text-align: center;
	font-size: 24px;
	font-weight: 600;
	margin-bottom: 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2rem;
}

.title-decoration {
	width: 42px;
	height: 15px;
	background: #FFC800;
	transform: skewX(-45deg);
	position: relative;
	display: inline-block;
}

.about .course-group {
	text-align: left;
	margin-bottom: 2rem!important;
	max-width: 600px;
	margin-left: auto!important;
	margin-right: auto!important;
}

.group-title {
	color: white;
	font-size: 18px;
	margin-bottom: 1rem;
	font-weight: 700;
}

.course-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-bottom: 2rem;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}

.course-button {
	background: white;
	color: #2F2F2F;
	text-decoration: none;
	padding: 1rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-weight: 500;
}

.arrow {
	color: #003686;
	font-size: 12px;
	flex-shrink: 0;
}

.course-button>.arrow {
	color: #4B4B4B;
}



@media screen and (min-width: 960px) {
	#course-section {
		padding: 2rem;
		margin: 0 auto;
	}
	
	.title-decoration {
		width: 165px;
	}
	
	.course-groups-container {
			display: flex;
			gap: 2rem;
		}
	.course-group {
		flex: 1;
	}
	
	.group-title {
		margin-bottom: 1rem;
	}
	
	.course-list {
		margin-bottom: 0;
	}
	
	.course-button {
		font-size: 16px;
	}
}

/*!共通パーツ 項目別対策*/
.topics-section {
	padding: 0;
	max-width: 400px;
	margin: 0 auto;
	text-align: center;
}

.topics-title {
	color: #003C84;
	font-size: 24px;
	font-weight: 600;
	margin-bottom: 2rem;
	position: relative;
	display: inline-block;
	padding: 0 20px 4px;
	z-index: 1;
}

.topic-item {
	margin-bottom: 2rem;
	box-shadow: 0px 1px 5px 1px rgba(0, 0, 0, 0.1);
	display: flex;
	flex-direction: column;
}

.topic-image {
	max-width: 400px;
	width: 100%;
	background: #f0f0f0;
}

.topic-content {
	text-align: center;
	padding: 0.5em;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.topic-title {
	font-size: 1.3em!important;
	font-weight: 600;
	color: #003C84!important;
	margin-top:0.5em!important;
	text-align: left;
}

.topic-text {
	font-size: 14px;
	line-height: 1.7!important;
	color: #333;
	margin-bottom: 1rem;
	text-align: left;
}

.topic-button {
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	background: #003686;
	color: white;
	text-decoration: none;
	padding: 0.8rem;
	border-radius: 26px;
	font-size: 11px;
	font-weight: bold;
	margin-top: auto;
	margin-inline: auto;
	margin-bottom: 5px;
	width: 205px;
	height: 42px;
	line-height: 1.2;
}

.topic-button__text {
	flex: 1;
	text-align: center;
	font-size: 11px;
}

.topic-button__arrow {
	flex-shrink: 0;
	font-size: 12px;
}

.topics-eiken .topic-title {
	color: #BA0008!important;
	font-size: 1.5em!important;
}

.topics-eiken .topic-button {
	background: #BA0008;
}

@media screen and (min-width: 960px) {
	.topics-section {
		max-width: 1050px;
	}
	.about .topics-col {
			display: flex;
			gap: 40px;
			width: 100%!important;
		}
	.about .topics-col > .about .topic-item {
		//width: 325px!important;
		height: 560px;
	}
	
}

@media screen and (min-width: 769px) {
	.topics-section {
		max-width: 100%;
	}
	
	.about .topics-col {
		display: flex;
		gap: 40px;
		//justify-content: space-between;
		width: 100%!important;
	}
	.about .topic-item {
		width: 30%!important;
	}
	
	.topics-section {
		max-width: 100%;
		padding: 0;
	}
	
	.topics-col{
		display: flex;
		gap:10px;
		//justify-content: space-between;
	}
	
	.topic-item{
		width: 32%;
	}
	
	.about .topic-item{
		margin-bottom:2em!important;
	}
	
	.topics-eiken .topic-item{
		flex-direction: row;
		width:100%!important;
	}
	
	.topic-text {
		font-size: 14px;
	}
	
	.topics-section {
		max-width: 1050px!important;
	}
	
	.topics-eiken .topic-image {
		max-width: 430px;
	}
}

/*!共通パーツ 合格率*/

.passtare__container{
	position: relative;
	width: 100vw;
	left: 50%;
	right: 50%;
	margin-top: 3vw;
	margin-left: -50vw;
	margin-right: -50vw;
	margin-bottom: 3vw;
	padding: 3vw 0;
	background-color: #003C84;
	text-align: center;
}

.about .passrate {
	width: 100%!important;
	max-width: 750px;
	border-radius: 10px;
	padding: 20px!important;
	text-align: center;
	color: white;
	position: relative;
	overflow: hidden;
	padding-top: 30px!important;
	margin:0 auto!important;
}

.about .passrate__speech-bubble {
	background-color: white;
	color: #0c2f81;
	font-weight: bold;
	font-size: 14px;
	padding: 8px 20px;
	border-radius: 20px;
	//display: inline-block;
	margin:0 auto!important;
	position: relative;
	max-width: 50%;
}

.passrate__speech-bubble:after {
	content: "";
	position: absolute;
	bottom: -8px;
	left: 50%;
	transform: translateX(-50%);
	border-width: 8px 8px 0;
	border-style: solid;
	border-color: white transparent transparent transparent;
}

.passrate__title {
	font-size: 24px;
	font-weight: bold;
	margin-bottom: 15px;
	position: relative;
	display: inline-block;
	padding-bottom: 5px;
	margin-top: 10px;
	color:#fff;
}

.about .passrate__content-box {
	background-color: white;
	color: #0c2f81;
	padding: 20px!important;
	margin-top: 20px!important;
	text-align: center;
	line-height: 2;
}

.passrate__content-box p{
	font-size: 1.1em;
	line-height: 25px!important;
	letter-spacing: 0.1em;
}

.passrate__dotted-line {
	display: block;
	border-top: 1px dashed #aaa;
	margin: 15px 0;
}

.passrate__highlight-number {
	font-size: 28px;
	font-weight: bold;
	color: #ff4500; /* 強調色 (オレンジ赤) */
	margin: 0 5px;
}

.passrate__highlight-text {
	font-weight: bold;
}

.passrate__final-message {
	font-weight: bold;
	margin-top: 10px;
}

.dashed-note {
  background-color: #fff;
  background-image: linear-gradient(90deg, transparent 0%, transparent 50%, #fff 50%, #fff 100%),linear-gradient(180deg, #ccc 1px, transparent 1px);
  background-size: 8px 100%,100% 2.5em;
  line-height: 2.5em;
  padding-bottom: 1px;
}



/*!共通パーツ よくある質問*/
.faq-section {
	position: relative;
	width: 100vw!important;
	left: 50%;
	right: 50%;
	margin-top: -3vw!important;
	margin-left: -50vw!important;
	margin-right: -50vw!important;
	margin-bottom: 3vw!important;
	padding: 3vw 0;
	background-color: #DFEDFD;
	text-align: center;
	font-weight: 700;
}

.faq-title {
	color: #003C84;
	font-size: 24px;
	font-weight: 600;
	margin-bottom: 2rem;
	position: relative;
	display: inline-block;
	padding: 0 20px 4px;
	z-index: 1;
}

.about .faq-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	text-align: left;
	width: 90%!important;
	max-width: 850px;
	margin: 0 auto!important;
}

.faq-item {
	background: white;
	border-radius: 8px;
	overflow: hidden;
}

.faq-checkbox {
	display: none;
}

.faq-label {
	padding: 1rem;
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	cursor: pointer;
	position: relative;
	font-size: 14px;
	line-height: 1.6;
}

.question-icon {
	color: #003686;
	font-weight: bold;
	flex-shrink: 0;
}

.faq-arrow {
	position: absolute;
	right: 1rem;
	top: 50%;
	transform: translateY(-50%);
	width: 0;
	height: 0;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 8px solid #003686;
	transition: transform 0.3s ease;
}

.faq-checkbox:checked ~ .faq-answer {
	max-height: 500px;
	padding: 0 1rem 1rem 2.5rem;
}

.faq-answer {
	max-height: 0;
	overflow: hidden;
	padding: 0 1rem 0 2.5rem;
	font-size: 14px;
	line-height: 1.6;
	transition: all 0.3s ease;
}

.about .video-container {	
	position: relative;
	padding-bottom: 56.25%!important;
	padding-top: 30px!important;
	height: 0;
	overflow: hidden;
	width: 95% !important;
	margin: 0 auto !important;
}

/*!共通CTA*/
.about .school__cta{
	margin:2em 0!important;
}

#sp-mv{
	display: none;
}

.br-pc {
	display: block;
}

.br-sp{
	display: none;
}

/*!タブレット表示*/
@media screen and (max-width: 825px) {
	.about .hero img{
		width:unset!important;
	}
	
	.about p.voice__title{
		font-size: 1.1em;
	}
	
	.about .common-cta_buttons-container {
		margin: 0 !important;
		gap: 20px!important;
		bottom: 5%!important;
	}
}

@media screen and (max-width: 960px) {
	
	.about{
		padding:0 15px;
	}
	
	div.about-ea__button {
		width: 100% !important;
		padding: 40px 5px 20px 5px;
	}
	
	.about .basic-info__header,.about .nearby-classrooms__header,.about .nearby-school__header,.about .pass-record__header,.about .greetings__header,.about .voice__header{
		position: relative;
		width: 100vw!important;
		left: 50%;
		right: 50%;
		margin-top: 3vw!important;
		margin-left: -50vw!important;
		margin-right: -50vw!important;
		margin-bottom: 3vw!important;
		background-color: #003C84;
		text-align: center;
		padding: 2em 1em 2.5em;
		overflow: hidden;
		white-space: normal;
		word-wrap: break-word;
		word-break: break-all;
	}
	
	.result-list{
		gap:1em;
	}
	
	.result-image{
		width: 20%!important;
		height: 20%;
	}
	
	.about .result-content{
		width: 100%!important;
	}
	
	.result-button{
		width: 40%;
	}
	
	.result-content a{
		float: right;
	}
	
	.about p.group-title{
		padding-left:20px!important;
	}
		
	.about .topic-item{
		padding:0!important;
		width: 100% !important;
		margin: 20px 0 !important;
	}
	
	.about .topic-content{
		padding: 0.8em!important;
	}
	
	.about .button__blue-frame {
		width: 50% !important;
		margin: 30px auto !important;
	}
	
	.about .reason-text {
		font-size:14px;
		padding:0 15px 15px!important;
	}
	
	.about .reasons-content {
		gap:10px;
		padding: 0;
	}
	
	.about .reason-card {
		width: 31%!important;
	}
	
	.about .reason-image {
		flex-grow: 1;
		width: 80% !important;
		padding: 0;
	}
	
	.about .reason-image img {
		width: 100%!important;
	}
	
	.common-cta_buttons-container,.common-cta_button-row{
		padding: 0!important;
	}

	
}



/*!モバイル表示*/
@media screen and (max-width: 500px) {
	
	#sp-mv{
		display: block;
		padding:0;
		text-align: center;
	}
	
	#sp-mv img.cta{
		width:90%!important;
	}
	
	.common-cta_sp .common-cta_button {
		width: 82%!important;
	}
	
	.hero{
		display: none;
	}
	
	
	.br-pc {
		display: none;
	}
	
	.br-sp{
		display: block;
	}
	
	p.school-attention__top{
		text-align: left!important;
		padding:25px!important;
	}
	p.school-attention__top span{
		font-size: 12px!important;
	}
	
	h2.video__about-eikenac {
		width: 100%;
	}
	
	h2.video__about-eikenac span {
		font-size: 0.8em!important;
	}
	
	div.about-ea__button {
		padding: 30px 10px 20px 10px;
	}
	
	.tab-link {
		min-width: 45%;
		font-size:0.75em;
	}
	
	.about div.ribbon__yellow{
		padding:0!important;
	}
	
	.ribbon__yellow::after {
		bottom:-5px;
	}
	
	.ribbon__yellow h2{
		font-size: 1.3em!important;
	}
	
	
	.about .basic-info__header,.about .nearby-classrooms__header,.about .nearby-school__header,.about .pass-record__header,.about .greetings__header,.about .voice__header{
		padding: 2em 1em 2.5em;
		overflow: hidden;
		white-space: normal;
		word-wrap: break-word;
		word-break: break-all;
	}
	
	.about .result-card {
		flex-direction: column;
	}
	
	.result-image {
		width: 70% !important;
		height: 70%;
	}
	
	.result-button {
		width: 50%;
		margin: 0 auto;
		display: block;
		text-align: center;
	}
	
	.result-content a {
		float: unset;
	}
	
	.about #greetings__container p{
		padding:0 10px!important;
	}
	
	.voice__header .ribbon__yellow::after {
		bottom: -15px;
	}
	
	.voice__content p {
		line-height: 1.2!important;
	}
	
	.about p.voice__title{
		margin:5px 0!important;
		font-size: 1.2em;
	}
	
	.about p.voice__subtitle{
		margin:5px 0!important;
	}
	
	.about .voice__card {
		padding: 15px !important;
	}
	
	.about .voice__content{
		padding:0 0 0 10px!important;
	}
	
	.about .avatar {
		padding:0!important;
	}
	
	.about p.group-title{
		padding-left:20px!important;
	}
	
	.about .course-groups-container,.about .course-group{
		padding: 0;
	}
	
	.topics-section{
		padding: 2rem 0;
	}
	
	.passrate__content-box p {
		font-size: 0.9em;
		line-height: 15px !important;
		letter-spacing: 0em;
	}
	
	.about .reasons-content{
		flex-direction: column;
		align-items: center;
	}
	
	.about .reason-card {
		width: 90% !important;
	}
	
	.about .button__blue-frame {
		width: 60% !important;
	}
}

/*!教室一覧用*/
.municipality__classroom--section{
	position: relative;
	width: 100vw !important;
	left: 50% !important;
	right: 50% !important;
	margin-top: 10px !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	padding: 2vw 3vw 4vw;
	background-color: #fff;	
}

.municipality__classroom--section .municipality__classroom--container{
	max-width: 850px;
	margin:0 auto!important;
}

.municipality__classroom--title {
	position: relative;
	display: block;
	width: fit-content!important;
	margin: 0 auto 1em!important;
	padding: 0 5px;
	font-weight: bold;
}

.municipality__classroom--title::after {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	bottom: -3px;
	width: 100%;
	height: 13px;
	background: #FFC800;
	z-index: 0;
	transform: skewX(-45deg);
}


.municipality__classroom--container h2{
	margin-bottom: 35px;
}

.about .municipality__classroom-list{
	gap:1em;
	margin-bottom:2em!important;
	display:flex;
}	
	
.about .municipality__classroom{
//		justify-content: center;
		color: #333333;
		background-color: #fff;
		border-radius: 10px;
		box-shadow: 6px 6px 10px 0px rgba(0, 0, 0, 0.4);
		display: flex;
		flex-direction: column;
		height: 265px;
		//margin:1em 1em 2em 1em!important;
}
.about .municipality__classname{
	background-color: #083681;
	border-radius: 10px 10px 0 0;
	color:#fff;
	margin:0!important;
	padding:5px 15px!important;
	font-size:1.1em;
	font-weight: bold;
}

.about .municipality__distance {
	display: inline-flex;
	align-items: center;
	padding-left: 2.5em!important;
	position: relative;
	margin-top: 1.5em !important;
	margin-bottom: 0 !important;
}

.about .municipality__distance::before {
	content: '';
	position: absolute;
	left: 15px;
	width: 1em;
	height: 2em;
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	background-image: url("https://eiken-academy.com/wp-content/themes/eiken/images/icon_train.png");
}


.about .municipality__address{
	line-height: 1.2!important;
	display: inline-flex;
	align-items: center;
	padding-left: 2.5em!important;
	position: relative;
}
.about .municipality__address::before{
	content: '';
	position: absolute;
	left: 15px;
	width: 1em;
	height: 2em;
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	background-image: url("https://eiken-academy.com/wp-content/themes/eiken/images/icon_map-pin.png");
}
.about .municipality__button{
	display: flex;
	justify-content: center;
	margin-top: auto!important;
	padding-bottom: 1.5em;
}
	
.about .municipality__button > div{
	width: calc(50% - var(--wp--style--block-gap, .5em) * .5)!important;
}

.municipality-list__section{
	position: relative;
	width: 100vw !important;
	left: 50% !important;
	right: 50% !important;
	margin-top: 10px !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	padding: 3vw 0;
	background-color: #deedfc;
	text-align: center;
}

.municipality-list__section .wp-block-cover__inner-container{
	width: 850px!important;
	margin: 0 auto !important;
}

.about .municipality-list__col{
	margin-bottom:1em!important;
}

.municipality-list__head{
	background: #458cdb;
	color: #fff;
	border-radius: 5px;
	padding:0.4em!important;
	font-size:1.3em;
	margin:0 0 1em 0!important;
}


.municipality__list-button a{
	font-size: 14px;
	font-weight: bold;
	text-align: left;
	position: relative;
	display: inline-block;
	padding:15px;
}

.municipality__list-button a:after {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 6px 0 6px 8px;
  border-color: transparent transparent transparent #333;
  position: absolute;
  top: 0;
  right: 10px;
  bottom: 0;
  margin: auto;
}

.municipality-list__section h2{
	color:#1a3a7e!important;
}

.municipality-list__section .ribbon__yellow{
	margin-bottom:3em!important;
}




.classroom__section {
	position: relative;
	width: 100vw !important;
	left: 50% !important;
	right: 50% !important;
	margin-top: 10px !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	//margin-bottom: 3vw !important;
	padding: 3vw 0;
	background-color: #deedfc;
	text-align: center;
}

.about .classroom__container{
	max-width: 850px;
	margin:0 auto!important;
}

.classroom__title {
	text-align: center;
	font-size: 24px;
	font-weight: bold;
	margin-bottom: 15px;
	color: #333;
	position: relative;
}

/*
.classroom__title:after {
	content: "";
	display: block;
	width: 280px;
	height: 5px;
	background-color: #ffd952;
	position: absolute;
	bottom: -10px;
	left: 50%;
	transform: translateX(-50%);
	border-radius: 2px;
}
*/
.about .classroom__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 15px;
	margin-top: 30px!important;
	text-align: left;
}

.about .classroom__item {
		padding: 2em;
		font-size: 15px;
		line-height: 1.6;
		transition: all 0.3s ease;
		margin-top: 3em !important;
		display: flex;
		flex-wrap: wrap;
		gap: 1em;
		background-color: #fff;
		border-radius: 5px;
}

.classroom__item:hover {
	//transform: translateY(-2px);
	//box-shadow: 0 4px 8px rgba(0,0,0,0.1);
	//opacity: 0.7;
}

.classroom__item a {
/*	text-decoration: none;
	font-size: 14px;
	color: #000;
	font-weight:bold;
	display: block;
	width: 100%;
*/	
	
	margin-right: 0;
	padding: 0.6em;
	color: #111;
	border: 1px solid #999;
	border-radius: 5px;
	text-decoration: none;
}

.classroom__item a:hover{
	opacity: 0.7;
}

.classroom__arrow {
	color: #666;
	font-size: 12px;
}

.about_movie{
position: relative;
width: 100vw !important;
left: 50% !important;
right: 50% !important;
margin-left: -50vw !important;
margin-right: -50vw !important;
margin-bottom: 3vw !important;
padding: 3vw 0;
background-color: #fff;
text-align: center;
}

.about_movie .online-video{
	max-width:850px;
	margin:3em auto 0!important;
	padding:0 2em;
}



.about_movie h2{
	color:#1a3a7e!important;
	line-height: 1.2;
} 

.about_movie .ribbon__yellow::after{
	margin-bottom:-15px;
}

/*! 教室一覧（都道府県） */
.location-list_section {
/*	padding: 2rem 1rem;
	margin: 0 auto;
	text-align: center;
	background: #DFEDFD;
	font-weight: 600;
*/	
	position: relative;
	width: 100vw !important;
	left: 50% !important;
	right: 50% !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	//margin-bottom: 3vw !important;
	padding: 3vw 0;
	background-color: #deedfc;
	text-align: center;
}	

.location-list_section h2,.classroom__section h2{
	color:#1a3a7e!important;
}

.about .location-list_list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	text-align: left;
	max-width: 850px;
	margin: 3em auto!important;
}

.about .location-list_item {
	background: white;
	border-radius: 5px;
	overflow: hidden;
	margin:0!important;
	padding:1em;
}

.location-list_section .arrow{
	color: #111;
	font-size: 12px;
	flex-shrink: 0;
}

.location-list_section .prefecture-btn{
		text-decoration: none;
		border-radius: 4px;
		display: flex;
		align-items: center;
		justify-content: space-between;
		font-size: 15px;
		flex: 0 1 auto;
		min-width: 80px;
}

/* チェックボックスを非表示 */
.location-list_checkbox {
	display: none;
}

.location-list_label {
	padding-bottom: 10px;
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
	position: relative;
	font-size: 14px;
	font-weight: bold;
	line-height: 1.6;
	width: 100%;
	justify-content: space-between;
	align-items: center;
}

.location-list_label .arrow{
	font-size: 1.2em;
	color:#000;
}

/*location-list_*/
/*
.location-list_arrow {
	position: absolute;
	right: 1rem;
	top: 50%;
	transform: translateY(-50%);
	width: 0;
	height: 0;
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 8px solid #000;
	transition: transform 0.3s ease;
}
*/

.about .location-list_prefecture {
	//max-height: 0;
	//overflow: hidden;
	padding-left: 1em;
	font-size: 14px;
	line-height: 1.6;
	transition: all 0.3s ease;
	margin:0!important;
	display: flex;
	flex-wrap: wrap;
	gap:1em;
}

.location-list_prefecture a{
	margin-right: 0;
	padding:0.6em;
	color:#111;
	border:1px solid #999;
	border-radius: 5px;
	text-decoration: none;
}

/* チェックボックスがチェックされた時の状態 */
/*
.location-list_checkbox:checked ~ .location-list_prefecture {
	max-height: 500px;
	padding: 0 1rem 1rem 1.5rem;
}

.location-list_checkbox:checked ~ .location-list_label .arrow {
	transform: rotate(180deg);
}

.location-list_label:hover {
	opacity: 0.7;
}
*/

/*!新規上段コンテンツ*/
.about .uni-txt_head{
	position: relative;
	width: 100vw !important;
	left: 50%;
	right: 50%;
	margin-top: -3vw !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	margin-bottom: 3vw !important;
	padding: 3vw 0;
	background-color: #003C84;
	text-align: center;
}
.about .uni-txt_head h2{
	line-height: 1.2;
	color: #fff !important;
}

.uni-txt_head .ribbon__yellow::after {
	bottom: -0.9vw;
}

/* 戦略設計図とは？ */
#pass-blueprint{
	position: relative;
	width: 100vw !important;
	left: 50%;
	right: 50%;
	margin-top: -3vw !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	margin-bottom: 3vw !important;
	background-image: 
	url("https://eiken-academy.com/wp-content/uploads/2025/09/pass-blueprint-img.png"); 
	//url("https://eiken-ac.h2-server.com/wp-content/uploads/2025/08/pass-blueprint-img.png"); 
	background-color: #b3d6ff;
	background-repeat: no-repeat;
	//background-position: center left;
	background-position: calc(28% - 100px) top;
}

#pass-blueprint .wp-block-group__inner-container,
#student-success .wp-block-group__inner-container, 
#exam-support .wp-block-group__inner-container,
#school-improve-reason .wp-block-group__inner-container
{
	max-width:850px;
	margin:0 auto!important;
	padding:1em 0;
}

#pass-blueprint_box_l,#pass-blueprint_box_r{
	display: flex;
	margin-bottom:2em!important;
}


#pass-blueprint_box_l .wp-block-column,#pass-blueprint_box_r .wp-block-column{
	background:#fff;
	align-items: center;
	justify-content: center;
	border-radius: 3px;
	box-shadow: 3px 3px 10px 0px rgba(0, 0, 0, 0.3);
}

#pass-blueprint_box_r{
	justify-content: flex-end
}

#pass-blueprint_box_l{
	margin-top:1em!important;
}

#pass-blueprint_box_r .pass-blueprint_box_head,#pass-blueprint_box_l .pass-blueprint_box_head{
  background-image: linear-gradient(#003c84, #002047);
  color:#fff;
  padding:0.3em 1.5em;
  font-weight: bold;
  font-size: 1.5em;
  margin:0!important;
}


.pass-blueprint_head{
  font-weight: 900;
  letter-spacing: .02em;
  line-height: 1.2!important;
  color: #003c84;
  font-size: 24px;
  font-weight: bold;
  -webkit-text-stroke: 3px white;
  text-stroke: 3px white;
  paint-order: stroke fill;
}

#pass-blueprint .pass-blueprint_box_txt{
	padding:0.7em 1.1em;
	line-height: 1.6;
	font-size: 15px;
}

/*! こんな生徒を英検合格に導いています*/

#student-success{
	position: relative;
	width: 100vw !important;
	left: 50%;
	right: 50%;
	margin-top: -3vw !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	margin-bottom: 3vw !important;
	background-image: 
	url("https://eiken-academy.com/wp-content/uploads/2025/09/student-success_img.png"); 
	//url("https://eiken-ac.h2-server.com/wp-content/uploads/2025/08/student-success_img.png"); 
	background-color: #b3d6ff;
	background-repeat: no-repeat;
	//background-position: center right;  
	background-position: calc(50% - -150px) top;
}

#student-success .wp-block-group__inner-container, #exam-support .wp-block-group__inner-container{
	padding:4em 0;
}
#student-success ul{
	margin: 10px 5px;
	padding-left: 30px;
}

#student-success li{
	list-style: disc;
	line-height: 1.3 !important;
	margin-bottom:0.8em;
}

.student-success_box .wp-block-column{
	margin:0 auto;
	background: #fff;
	padding:2em;
	box-shadow: 3px 3px 10px 0px rgba(0, 0, 0, 0.3);
}

.about .student-success_txt{
	margin-top:1em;
	line-height: 1.5;
}

@media screen and (max-width: 825px) {
	#student-success ul{
		padding-left: 15px;
	}
	
	.student-success_box div{
		padding:1em!important;
	}
}

/*! 4つの壁*/

.four-barriers_box{
	gap:3em;
}


 .four-barriers_point {
	background: white;
	border: 5px solid #003C84;
	border-radius: 8px;
	padding: 20px 20px 10px 20px;
	max-width: 600px;
	width: 100%;
	box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
	position: relative;
	margin-top: 20px;
	text-align: center;
}

.four-barriers_header {
	position: absolute;
	top: -45px;
	left: 50%;
	transform: translateX(-50%);
	background: white;
	padding: 0 20px;
	font-size:1.5em;
	font-weight: bold;
	color: #003C84;
	letter-spacing: 2px;
}

.four-barriers_title {
	background-image: linear-gradient(#003c84, #002047);
	color: white;
	text-align: center;
	margin-bottom: 25px;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
	font-size: 1.5em;
	font-weight:600;
	letter-spacing: 1.5px;
}

.vocabulary-title {
	font-size: 24px;
	font-weight: bold;
	letter-spacing: 1px;
}

.four-barriers_txt {
	text-align: center;
	font-size: 1.2em;
	line-height: 1.5!important;
	color: #003C84;
	font-weight: 600;
	margin: 20px 5px 10px 5px!important;
}


/*!内部進学・定期テスト対策も万全 */
#exam-support{
	position: relative;
	width: 100vw !important;
	left: 50%;
	right: 50%;
	margin-top: -3vw !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	margin-bottom: 3vw !important;
	background-image: 
	url("https://eiken-ac.h2-server.com/wp-content/uploads/2025/08/exam-support-img.png"); 
	background-color: #b3d6ff;
	background-repeat: no-repeat;
	background-position: center left;  
}

.exam-support_box{
	justify-content: flex-end
}

.exam-support_box .wp-block-column{
	margin:0 auto;
	background: #fff;
	box-shadow: 3px 3px 10px 0px rgba(0, 0, 0, 0.3);
	padding:1em;
	font-size:15px!important;
}


/*! 選ばれる理由 */

.about .why-choose_box-wrapper {
	max-width: 1200px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	gap: 100px;
	margin-top:3em!important;
}

.about .why-choose_box-container {
	background-color: #F5F5F5;
	overflow: visible;
	position: relative;
	min-height: 350px;
	display: flex;
	align-items: center;
}

.about .why-choose_box-content-area {
	flex: 1;
	padding: 50px 40px;
	z-index: 2;
	position: relative;
	max-width: 60%;
}

.about .why-choose_box-content-area--right {
	margin-left: auto!important;
}

.why-choose_box-feature-label {
	position: absolute;
	top: -30px;
	display: flex;
	align-items: flex-end;
	font-size: 22px;
	font-weight: bold;
	color: #1e3a8a;
	padding: 0 15px;
	z-index: 3;
}

.why-choose_box-feature-label--left {
	left: 30px;
}

.why-choose_box-feature-label--right {
	right: 260px;
}

.why-choose_box-slash {
	font-size: 28px;
	margin-right: 10px;
	transform: rotate(15deg);
	display: inline-block;
	line-height: 1;
}

.why-choose_box-feature-text {
	margin-right: 6px;
	font-size: 16px;
	line-height: 1;
}

.why-choose_box-feature-number {
	font-size: 38px;
	margin-left: 4px;
	line-height: 1;
}

.why-choose_box-main-title {
	font-size: 26px;
	font-weight: bold;
	color: #1e3a8a;
	line-height: 1.5;
	margin-bottom: 15px;
}

.why-choose_box-description {
	font-size: 15px;
	line-height: 1.7;
	color: #333;
	margin-bottom: 6px;
}

.why-choose_box-results {
	font-weight: bold;
	color: #1e3a8a;
}

.about .why-choose_box-blue-shape {
	position: absolute;
	top: 0;
	bottom: 0;
	width: 45%!important;
	background-image: linear-gradient(90deg, #004fae, #002047);
	z-index: 1;
}

.about .why-choose_box-blue-shape--left {
	left: 0;
	clip-path: polygon(0% 0%, 70% 0%, 100% 100%, 0% 100%);
}

.about .why-choose_box-blue-shape--right {
	right: 0;
	clip-path: polygon(30% 0%, 100% 0%, 100% 100%, 0% 100%);
}

.why-choose_box-image-container {
	position: absolute;
	top: -30px;
	overflow: hidden;
	z-index: 3;
	max-width: 400px;
	height: auto;
}

.why-choose_box-image-container--left {
	left: 0;
}

.why-choose_box-image-container--right {
	right: 0;
}

.why-choose_box-placeholder-image {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.why-choose_box-people-placeholder {
	display: flex;
	gap: 20px;
	align-items: center;
}

.why-choose_box-people-placeholder img{
	max-width: 360px;
}

.why-choose_box-person {
	width: 60px;
	height: 80px;
	border-radius: 30px 30px 0 0;
	position: relative;
}

.why-choose_box-person--student {
	background: #4a5568;
}

.why-choose_box-person--teacher {
	background: #2d3748;
}

.why-choose_box-person::before {
	content: '';
	position: absolute;
	width: 24px;
	height: 24px;
	background: #fff;
	border-radius: 50%;
	top: 12px;
	left: 50%;
	transform: translateX(-50%);
}

/*! 成績アップする理由 */
#school-improve-reason-wrapper{
	position: relative;
	width: 100vw !important;
	left: 50%;
	right: 50%;
	margin-top: -3vw !important;
	margin-left: -50vw !important;
	margin-right: -50vw !important;
	background-color: #f5f5f5;
	background-repeat: no-repeat;
	background-position: center left;
}


	.about .school-improve-reason ,.about .school-improve-reason-inner{
	max-width: 850px;
	margin: 0 auto!important;
	padding: 1em;
	border-radius: 10px;
}

.school-improve-reason__container {
	display: flex;
	gap: 40px;
	align-items: flex-start;
}

.school-improve-reason__column {
	flex: 1;
	display: flex;
	flex-direction: column;
}

.about .school-improve-reason__header {
	background-image: linear-gradient(#003c84, #002047);
	color: white;
	padding: 20px;
	text-align: center;
	font-weight: bold;
	font-size: 18px;
	margin-bottom: 20px!important;
}

.school-improve-reason__content {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.school-improve-reason__item {
	background-color: #fff;
	padding: 20px;
	border-bottom: 1px solid #ddd;
	min-height: 80px;
	display: flex;
	align-items: center;
	font-size: 14px;
	line-height: 1.5;
	position: relative;
}

.school-improve-reason__item:last-child {
	border-bottom: none;
}

.school-improve-reason__item-text {
	width: 100%;
}

/* 左カラムの各項目に個別に矢印を配置 */
.school-improve-reason__column:first-child .school-improve-reason__item::after {
	content: '▶';
	position: absolute;
	right: -30px;
	top: 50%;
	transform: translateY(-50%);
	color: #2c5282;
	font-size: 20px;
	font-weight: bold;
	z-index: 1;
}

.about .school-improve-reason-leave{
	padding:1.5em 2em;
	font-size: 1.2em;
	line-height: 1.5;
	background-image: linear-gradient(#003c84, #002047);
	width: 60%;
	margin: 0 auto!important;
	color: #fff;
	font-weight: 600;
}

/* レスポンシブ対応 */
@media (max-width: 768px) {
	.about .uni-txt_head {
	padding: 2em 1em 2.5em;
	}
	
	.uni-txt_head .ribbon__yellow::after {
		bottom: -15px;
	}
	.school-improve-reason {
		padding: 15px;
	}

	.school-improve-reason__container {
		gap: 30px;
	}

	.school-improve-reason__column:first-child .school-improve-reason__item::after {
		right: -25px;
		font-size: 18px;
	}

	.school-improve-reason__header {
		font-size: 16px;
		padding: 15px;
	}

	.school-improve-reason__item {
		padding: 15px;
		font-size: 13px;
		min-height: 70px; /* 固定高さ */
	}
	
	#student-success .wp-block-group__inner-container, #exam-support .wp-block-group__inner-container {
		padding: 4em 2em;
	}
	
	#pass-blueprint_box_l, #pass-blueprint_box_r {
		margin:1em 2em 2em!important;
	}
	
	.about .four-barriers{
		margin-top:50px!important;
	}
	
	.about .four-barriers_title{
		padding: 0.5em 0!important;
	}
	
	.about .four-barriers_header{
		top: -25px;
		width: 50%!important;
	}
	
	.about .school-improve-reason{
		padding: 0;
	}
	
	.about .school-improve-reason-leave {
		font-size: 0.8em;
		padding: 1.1em!important;
	}
	
	.four-barriers-space{
		display: none;
	}
	
	.about .pass-blueprint_box_head{
		font-size:1.2em!important;
		text-align: center;
	}
}

@media (max-width: 480px) {
	
	#pass-blueprint,#student-success,#exam-support {
		background-image: none;
	}
	
	#student-success .wp-block-group__inner-container, #exam-support .wp-block-group__inner-container {
		padding: 1em;
	}
	

	#pass-blueprint_box_l, #pass-blueprint_box_r{
		padding: 0 1em;
		margin: 1em 0!important;
	}

	
	#pass-blueprint_box_l p, #pass-blueprint_box_r p{
		padding: 1em!important;
	}
	
	.about .pass-blueprint_head{
		font-size: 1.2em!important;
		line-height: 1.3!important;
	}
	
	.school-improve-reason {
		padding: 10px;
	}

	.school-improve-reason__container {
		gap: 20px;
	}

	.school-improve-reason__column:first-child .school-improve-reason__item::after {
		right: -17px;
		font-size: 13px;
	}

	.school-improve-reason__header {
		font-size: 16px;
		padding: 12px;
	}

	.school-improve-reason__item {
		padding: 9px;
		font-size: 12px;
		min-height: 120px; /* より大きめの固定高さ */
		line-height: 1.4;
		
	}
	
	.about .school-improve-reason__header {
		padding: 15px;
		font-size: 15px;
		line-height: 1.6;
	}
	
	.about .school-improve-reason__bluetxt{
		font-size: 13px;
		line-height: 1.4 !important;
	}
	
	
	.about .why-choose_box-image-container {
		top:auto;
		bottom: 5%;
		left: 50%;
		transform: translate(-50%);
		width: 80%!important;
		order: 2;
	}
	
	.about .why-choose_box-content-area {
		padding: 40px 20px !important;
	}
}

@media (max-width: 400px) {
	.about .why-choose_box-blue-shape {
		height: 205px!important;
	}
}
@media (max-width: 768px) {
	.about .why-choose_box-wrapper {
		gap: 80px;
		margin-top:50px!important;
	}

	.why-choose_box-container {
		flex-direction: column;
		min-height: auto;
	}

	.about .why-choose_box-content-area {
		padding: 40px 30px 30px 30px;
		max-width: 100%;
		width: 100%;
		box-sizing: border-box;
		margin-left: 0;
		text-align: left;
		order: 1;
	}

	.why-choose_box-content-area--right {
		margin-left: 0;
		text-align: left;
	}

	.why-choose_box-feature-label--left,
	.why-choose_box-feature-label--right {
		left: 0;
		right: auto;
		font-size: 18px;
		top: -30px;
	}

	.why-choose_box-feature-text {
		font-size: 14px;
	}

	.why-choose_box-feature-number {
		font-size: 30px;
	}

	.why-choose_box-main-title {
		font-size: 20px;
	}

	.why-choose_box-description {
		font-size: 13px;
	}

	.about .why-choose_box-blue-shape {
		position: relative;
		width: 100%!important;
		height: 260px;
		order: 3;
	}

	.about .why-choose_box-blue-shape--left,
	.about .why-choose_box-blue-shape--right {
		clip-path: polygon(0% 35%, 100% 0%, 100% 100%, 0% 100%);
	}

	.about .why-choose_box-image-container {
		position: absolute;
		top:auto;
		bottom: 5%;
		left: 50%;
		transform: translate(-50%);
		width: 80%!important;
		order: 2;
	}

	.about .why-choose_box-image-container--left,
	.about .why-choose_box-image-container--right {
		/*left: 50%;
		right: auto;
		transform: translate(-50%, -50%);
		*/
	}
	
	.why-choose_box-people-placeholder img{
		width: 80%;
		margin:0 auto;
	}

	.why-choose_box-person {
		width: 45px;
		height: 60px;
		border-radius: 22px 22px 0 0;
	}

	.why-choose_box-person::before {
		width: 18px;
		height: 18px;
		top: 8px;
	}
}

@media (max-width: 768px) {
	.four-barriers_point {
		padding: 20px 25px;
		margin: 10px;
	}
	
	.four-barriers_header {
		font-size: 24px;
	}
	
	.vocabulary-title {
		font-size: 20px;
	}
	
	.student-success_txt {
		font-size: 16px;
	}
	
	.why-choose_box-feature-label--right{
		right: auto !important;
	}
}

/*! 新規上段コンテンツここまで */


/*!　NEW東京一覧用 */
#tokyo-23 {
	margin-bottom:2em!important;
}
.page-title {
	text-align: center;
	font-weight: bold;
	color: #333;
	margin-bottom: 30px;
}

.about .ward-container {
	max-width: 900px;
	margin: 0 auto!important;
	border-radius: 8px;
	padding: 1.5em;
}

.classroom-count {
	color: #666;
	margin-bottom: 15px;
	text-align: right;
}

.about .table-layout {
	display: grid;
	grid-template-columns: 60px 1fr 1fr 1fr; /* PC: 4カラム（区名 + 教室3列） */
	gap: 15px;
	align-items: center;
	margin:auto!important
}

.about .table-layout .ward-title {
	margin: 0 !important;
	align-self: center;
}

.ward-title {
	font-weight: bold;
	color: #333;
	white-space: nowrap;
	grid-column: 1;
	text-orientation: upright;
	justify-self: center;
	align-self: start;
	margin-top: 10px;
	width: 80px;
}

#tokyo-23 .ward-title a{
	text-decoration: underline;
}

.classroom-button {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	background: #F5F9FF !important;
	border: none !important;
	border-radius: 50px !important;
	padding: 10px 20px !important;
	font-weight: bold !important;
	color: #083681 !important;
	transition: color 0.3s ease !important;
	box-shadow: 0 3px 5px rgba(0, 0, 0, 0.1) !important;
	position: relative !important;
	z-index: 1 !important;
	overflow: hidden !important;
	font-size: 13px;
}
	
	.classroom-button::before{
		content: "";
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: 0;
		z-index: -1;
		background: #083681;
		border-radius: 50px;
		transform-origin: 100% 50%;
		transform: scaleX(0);
		transition: transform ease 0.3s;
	}}

#tokyo-23 .arrow , #tokyo-suburbs .arrow {
	margin-left: 10px;
}

.classroom-button:hover,#tokyo-23 .classroom-button:hover .arrow,#tokyo-suburbs .classroom-button:hover .arrow{
	color:#fff!important;
}

.classroom-button:hover::before {
	transform-origin: 0% 50%;
	transform: scaleX(1);
}

.classroom-button::before{
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	background: #083681;
	border-radius: 50px;
	transform-origin: 100% 50%;
	transform: scaleX(0);
	transition: transform ease 0.3s;
}

.classroom-button:active {
	transform: translateY(0);
}

.classroom-name {
	flex: 1;
	text-align: left;
}


#tokyo-23, #tokyo-suburbs {
	background-color: #FAFCFF;
	box-shadow: 3px 3px 5px rgba(0, 0, 0, 0.1) !important;
	border-radius: 0 0 10px 10px;
}

#tokyo-23 a, #tokyo-suburbs a{
	text-decoration: none;
}

h3.tokyo-23-title, h3.tokyo-suburbs-title {
	background-color: #083681;
	color: #fff;
	padding: 0.5em 1.5em;
	margin: 0 !important;
	font-size:1.2em!important;
	font-weight: bold;
	border-radius: 10px 10px 0 0;
}


.about .tokyo-23-select{
	margin: 0 auto 2em!important;
	max-width: 900px;
	display: flex;
	justify-content: center;
	gap:2em;
}


a.tokyo-23-button,a.tokyo-suburbs-button{
	padding:0.5em 1.5em;
	background-color:#083681;
	border-radius: 50px;
	color:#fff!important;
	font-size: 1.3em;
	font-weight: 600;
	text-decoration: none;
	display: flex;
	justify-content: space-between;
	width: 200px;
}

a.tokyo-23-button:hover,a.tokyo-suburbs-button:hover{
	opacity:0.5;

}

.location-list_section .municipality__classroom--section{
	background-color: unset;
	padding: 0 0 2rem;
}

.location-list_section #tokyo-23, #tokyo-suburbs{
	max-width: 850px;
	margin:0 auto 2em!important;
}

.location-list_section .tokyo-23-title,.location-list_section .tokyo-suburbs-title{
	text-align: left;
}


/* スマホ対応（3カラム：区名 + 教室2列） */
@media (max-width: 768px) {
	
	a.tokyo-23-button,a.tokyo-suburbs-button{
		font-size: 1.2em;
	}
	.ward-container {
		padding: 20px 15px;
	}

	.table-layout {
		grid-template-columns: 60px 1fr 1fr;
		gap: 12px;
	}

	.ward-title {
		writing-mode: horizontal-tb;
		text-orientation: mixed;
		margin-top: 0;
		width: 60px;
		text-align: center;
		align-self: center;
		font-size:13px!important;
	}
	
	.classroom-name{
		font-size:12px!important;
	}

	.classroom-button {
		padding: 15px 16px;
		min-width: 140px;
	}
	
	/* 1行目のボタン配置 */
	.classroom-button[style*="grid-row: 1; grid-column: 2"] {
		grid-row: 1 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 1; grid-column: 3"] {
		grid-row: 1 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 1; grid-column: 4"] {
		grid-row: 2 !important;
		grid-column: 2 !important;
	}

	/* 2行目のボタン配置 */
	.classroom-button[style*="grid-row: 2; grid-column: 2"] {
		grid-row: 2 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 2; grid-column: 3"] {
		grid-row: 3 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 2; grid-column: 4"] {
		grid-row: 3 !important;
		grid-column: 3 !important;
	}

	/* 3行目のボタン配置 */
	.classroom-button[style*="grid-row: 3; grid-column: 2"] {
		grid-row: 4 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 3; grid-column: 3"] {
		grid-row: 4 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 3; grid-column: 4"] {
		grid-row: 5 !important;
		grid-column: 2 !important;
	}

	/* 4行目のボタン配置 */
	.classroom-button[style*="grid-row: 4; grid-column: 2"] {
		grid-row: 5 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 4; grid-column: 3"] {
		grid-row: 6 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 4; grid-column: 4"] {
		grid-row: 6 !important;
		grid-column: 3 !important;
	}

	/* 5行目のボタン配置 */
	.classroom-button[style*="grid-row: 5; grid-column: 2"] {
		grid-row: 7 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 5; grid-column: 3"] {
		grid-row: 7 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 5; grid-column: 4"] {
		grid-row: 8 !important;
		grid-column: 2 !important;
	}

	/* 6行目のボタン配置 */
	.classroom-button[style*="grid-row: 6; grid-column: 2"] {
		grid-row: 8 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 6; grid-column: 3"] {
		grid-row: 9 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 6; grid-column: 4"] {
		grid-row: 9 !important;
		grid-column: 3 !important;
	}

	/* 7行目のボタン配置 */
	.classroom-button[style*="grid-row: 7; grid-column: 2"] {
		grid-row: 10 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 7; grid-column: 3"] {
		grid-row: 10 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 7; grid-column: 4"] {
		grid-row: 11 !important;
		grid-column: 2 !important;
	}
}

/* 小さいスマホ対応（3カラム：区名 + 教室2列） */
@media (max-width: 480px) {
	.table-layout {
		grid-template-columns: 50px 1fr 1fr;
		gap: 8px;
	}
	
	.ward-container {
		padding: 15px 10px!important;
	}
	
	.ward-title {
		width: 50px;
		align-self: center;
	}
	
	.classroom-button {
		padding: 5px 10px!important;
		min-width: 120px;
		border-radius: 15px !important;
	}
}

/* タブレット対応（3カラム：区名 + 教室2列） */
@media (min-width: 769px) and (max-width: 1024px) {
	.table-layout {
		grid-template-columns: 80px 1fr 1fr;
		gap: 15px;
	}
	
	.ward-title {
		width: 80px;
		align-self: center;
	}
	
	.classroom-button {
		min-width: 180px;
	}
	
	/* 1行目のボタン配置 */
	.classroom-button[style*="grid-row: 1; grid-column: 2"] {
		grid-row: 1 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 1; grid-column: 3"] {
		grid-row: 1 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 1; grid-column: 4"] {
		grid-row: 2 !important;
		grid-column: 2 !important;
	}

	/* 2行目のボタン配置 */
	.classroom-button[style*="grid-row: 2; grid-column: 2"] {
		grid-row: 2 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 2; grid-column: 3"] {
		grid-row: 3 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 2; grid-column: 4"] {
		grid-row: 3 !important;
		grid-column: 3 !important;
	}

	/* 3行目のボタン配置 */
	.classroom-button[style*="grid-row: 3; grid-column: 2"] {
		grid-row: 4 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 3; grid-column: 3"] {
		grid-row: 4 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 3; grid-column: 4"] {
		grid-row: 5 !important;
		grid-column: 2 !important;
	}

	/* 4行目のボタン配置 */
	.classroom-button[style*="grid-row: 4; grid-column: 2"] {
		grid-row: 5 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 4; grid-column: 3"] {
		grid-row: 6 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 4; grid-column: 4"] {
		grid-row: 6 !important;
		grid-column: 3 !important;
	}

	/* 5行目のボタン配置 */
	.classroom-button[style*="grid-row: 5; grid-column: 2"] {
		grid-row: 7 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 5; grid-column: 3"] {
		grid-row: 7 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 5; grid-column: 4"] {
		grid-row: 8 !important;
		grid-column: 2 !important;
	}

	/* 6行目のボタン配置 */
	.classroom-button[style*="grid-row: 6; grid-column: 2"] {
		grid-row: 8 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 6; grid-column: 3"] {
		grid-row: 9 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 6; grid-column: 4"] {
		grid-row: 9 !important;
		grid-column: 3 !important;
	}

	/* 7行目のボタン配置 */
	.classroom-button[style*="grid-row: 7; grid-column: 2"] {
		grid-row: 10 !important;
		grid-column: 2 !important;
	}
	.classroom-button[style*="grid-row: 7; grid-column: 3"] {
		grid-row: 10 !important;
		grid-column: 3 !important;
	}
	.classroom-button[style*="grid-row: 7; grid-column: 4"] {
		grid-row: 11 !important;
		grid-column: 2 !important;
	}
}

/* PC対応（4カラム：区名 + 教室3列） */
@media (min-width: 1025px) {
	.table-layout {
		grid-template-columns: 60px 1fr 1fr 1fr;
		gap: 15px;
	}
	
	.classroom-button {
		min-width: 200px;
	}
}
/*!　NEW東京一覧用ここまで */

/*! 市・区一覧用 */
.about .c-municipality-list{
	margin-bottom:5rem!important;
}

.c-municipality-list h3{
	color:#1a3a7e;
	font-size:1.2em;
	text-align: center;
	font-weight: 600;
	margin-bottom:20px;
}

.about .c-municipality-list__link{
	width:75%!important;
}

.about .c-municipality-list__grid {
	margin-bottom:1.5rem!important;
}

@media (max-width: 600px) {
	.about .c-municipality-list{
		margin-bottom:2rem!important;
	}
	
	.about .c-municipality-list__grid {
		margin-bottom:15px!important;
		gap:15px;
	}
}


/* レスポンシブデザイン */
@media (max-width: 825px) {
	.classroom__grid {
		grid-template-columns: repeat(2, 1fr);
	}
	
	.hero img {
		width: unset !important;
	}
	
	.about .hero__content{
		margin:0 !important;
		padding:0 20px!important;
	}
	.classroom__section, .location-list_section{
		padding:1.5em 15px;
	}
	
	.about .classroom__item{
		margin:0!important;
	}
	
	#about-ea__container .ribbon__yellow {
		margin-bottom: 1.5em !important;
	}
	
	.about_movie .online-video video{
		height: auto;
	}
	
	.municipality-list__section{
		padding:10px;
	}
	
	.about .municipality-list__head{
		padding:1em!important;
	}
	
	.about .municipality-list__col{
		gap:1em;
	}
	
	#pass-blueprint_box_r .pass-blueprint_box_head, #pass-blueprint_box_l .pass-blueprint_box_head,
	#pass-blueprint_box_r .pass-blueprint_box_txt, #pass-blueprint_box_l .pass-blueprint_box_txt  {
	padding:1em!important;
	}
	
	.four-barriers_box{
		justify-content: center;
	}
	
	.uni-txt_head + .four-barriers{
		margin-top:3em!important;
	}
	
	.about .why-choose_box-content-area
	{
		padding:50px 60px;
	}
	
	.why-choose_box-feature-label--right{
		right:220px;
	}
	
}

@media (max-width: 768px) {
	.municipality-list__dummy-col{
		display: none !important;
	}

}

@media (max-width: 500px) {
	.classroom-grid {
		grid-template-columns: 1fr;
	}
	#sp-mv{
		display: block;
		padding:0;
		text-align: center;
	}
	
	#sp-mv img.cta{
		width:90%!important;
	}
	
	#about-ea__container .ribbon__yellow {
		margin-bottom: 1em !important;
	}
	
	.hero{
		display: none;
	}
	
	.reasons-container .see-more-button {
		margin-bottom:1em;
	}
	
	.reasons-container .ribbon__yellow::after {
		bottom: -12px;
	}
	
	.municipality__classroom--container h2 {
		font-size: 1.3em!important;
	}
	
	p.school-attention__top{
		text-align: left!important;
		padding:25px!important;
	}
	p.school-attention__top span{
		font-size: 12px!important;
	}
	
	.about .municipality__button{
		display: flex;
		justify-content: center;
	}
	
	p.municipality__address{
		margin-bottom: 0 !important;
	}
	
	.about .classroom__grid {
		grid-template-columns: repeat(2, 1fr);
	}
	
	.about .municipality__classroom{
			height: 230px;
	}
	
	.about .municipality__button{
		padding-bottom: 1.2em;
	}
	

}

.yt-video {
  width: 95%;
  aspect-ratio: 16 / 9;
  max-width: 870px;
  margin:0 auto;
  padding:0 10px;
}
.yt-video iframe {
  width: 100%;
  height: 100%;
}


/*!新入塾の流れ*/
/* 全体のコンテナ */
.flow-simple {
	max-width: 1200px;
	margin: 0 auto;
	padding: 40px 0;
}

/* 共通のカラム設定 */
.flow-simple .wp-block-column {
	text-align: center;
	position: relative;
	background-color: #F5F9FF;
	border-radius: 12px;
	padding: 30px 20px 25px 20px;
	margin-top: 15px; /* STEPラベル用のスペース */
}

/* PC版（横並び） */
@media (min-width: 783px) {
	.flow-simple {
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 20px;
	}

	.flow-simple .wp-block-column {
		flex: 1;
		max-width: 200px;
	}

	/* PC版の横棒（ステップ間の接続線） */
	.flow-simple .wp-block-column:not(:last-child)::after {
		content: '';
		position: absolute;
		top: 50%;
		right: -21px;
		transform: translateY(-50%);
		width: 21px;
		height: 4px;
		background-color: #2E5BBA;
		z-index: 5;
	}
}

/* SP版（縦並び） */
@media (max-width: 782px) {
	.flow-simple {
		display: block;
	}

	.flow-simple .wp-block-column {
		margin-bottom: 60px;
		background-color: #F5F9FF;
		border-radius: 12px;
		padding: 20px 40px 20px 20px; /* 右側のパディングを多めに */
		margin-top: 15px; /* STEPラベルのはみ出し用上部マージン */
		height: 80px; /* 背景を固定の低い高さに */
		display: flex;
		align-items: center;
		text-align: left;
		position: relative;
		overflow: visible; /* はみ出しを表示 */
	}

	.flow-simple .wp-block-column:last-child {
		margin-bottom: 0;
	}

	/* SP版の縦の線（ステップ間の接続線） */
	.flow-simple .wp-block-column:not(:last-child)::before {
		content: '';
		position: absolute;
		bottom: -45px;
		left: 50%;
		transform: translateX(-50%);
		width: 4px;
		height: 45px;
		background-color: #2E5BBA;
	}

	/* SP版でのSTEPラベル - 背景から上にはみ出し */
	.flow-simple .wp-block-column .flow-step {
		position: absolute !important;
		top: -25px !important;
		left: 20px !important;
		transform: none !important;
		z-index: 10 !important;
		text-align: center;
	}

	/* SP版でのテキスト部分 */
	.flow-simple .wp-block-column .flow-title {
		flex: 1;
		margin: 0 !important;
		text-align: left !important;
		margin-top: 5px !important; /* STEPラベル用の少しのスペース */
		padding-left: 5px!important;
		font-size:16px;
	}

	/* SP版での画像 - 右側にはみ出し */
	.flow-simple .wp-block-column .flow-pic {
		position: absolute !important;
		right: -12px !important; /* 背景から右にはみ出し */
		top: 50% !important;
		transform: translateY(-50%) !important;
		margin: 0 !important;
		z-index: 5 !important;
	}
}

/* STEPテキストのスタイリング - カードからはみ出すように配置 */
.flow-step {
	//background-color: #2E5BBA !important;
	background-image: linear-gradient(90deg, #004bc7, #001230)!important;
	color: white !important;
	padding: 3px 16px !important;
	border-radius: 20px !important;
	font-size: 15px !important;
	font-weight: bold !important;
	margin: 0 !important;
	display: inline-block !important;
	text-transform: uppercase !important;
	position: absolute !important;
	top: -15px !important;
	left: 50% !important;
	transform: translateX(-50%) !important;
	z-index: 10 !important;
	width: 110px!important;
}

/* 画像のスタイリング */
.flow-pic {
	margin: 0 0 15px 0 !important;
}

.flow-pic img {
	width: 90px !important;
	height: 90px !important;
	border-radius: 50% !important;
	object-fit: cover !important;
	//border: 3px solid #fff !important;
	//box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1) !important;
}

/* 説明テキストのスタイリング */
.flow-title {
	color: #2E5BBA !important;
	font-size: 16px !important;
	font-weight: bold !important;
	margin: 0 !important;
	line-height: 1.4 !important;
	padding:0!important;
}

/* PC版でのレスポンシブ調整 */
@media (min-width: 782px) and (max-width: 1024px) {
	.flow-simple .wp-block-column {
		max-width: 180px;
		padding: 25px 15px 20px 15px;
	}

	.flow-pic img {
		width: 100px !important;
		height: 100px !important;
	}

	.flow-title {
		font-size: 14px !important;
	}

	.flow-step {
		font-size: 12px !important;
		padding: 6px 12px !important;
	}
}

/* 小さいスクリーン向け調整 */
@media (max-width: 480px) {
	.flow-simple .wp-block-column {
		//padding: 25px 15px 20px 10px;
		grid-template-columns: 1fr 100px;
		margin-right: 15px;
	}

	.flow-pic img {
		width: 90px !important;
		height: 90px !important;
	}

	.flow-title {
		font-size: 16px !important;
	}

	/* 小さい画面での画像のはみ出し調整 */
	.flow-simple .wp-block-column .flow-pic {
		right: -15px;
	}
}

/* SP版での画像サイズ調整 */
@media (max-width: 782px) {
	.flow-pic img {
		width: 100px !important;
		height: 100px !important;
	}
}

.about .flow-main-mv{
	 margin-bottom:30px!important;
 }

.about .flow-main-mv p{
	margin:0;
	padding:0;
}

.flow-main-mv__heading p:last-of-type{
	font-size:26px;
	line-height: 1.3 !important;
}
/* 基本レイアウト(SP) */
.flow-main-mv .wp-block-group__inner-container {
  display: grid;
  gap: 5px;
}
.flow-main-mv .flow-main-mv__heading {
  order: 1;
  text-align: center;
}
/* headingの中は縦並び(WordPressのgridを上書き) */
.flow-main-mv .flow-main-mv__heading .wp-block-group__inner-container {
  display: block;
}
.flow-main-mv .flow-main-mv__img {
  order: 2;
  margin: 0;
  max-width: 100%;
  min-width: 0;
}
.flow-main-mv .flow-main-mv__txt {
  order: 3;
  margin: 0;
  line-height: 1.6;
}
/* PC レイアウト */
@media (min-width: 768px) {
	.about .flow-main-mv{
		 margin-bottom:50px!important;
	 }
	
  .flow-main-mv > .wp-block-group__inner-container {
	grid-template-columns: 1.08fr 1fr;
	gap: 40px;
	align-items: start;
  }
  
  /* 左カラム: heading */
  .flow-main-mv .flow-main-mv__heading {
	grid-column: 1;
	grid-row: 1;
	min-width: 0;
	text-align: left;
  }
  
  /* 左カラム: txt */
  .flow-main-mv .flow-main-mv__txt {
	grid-column: 1;
	grid-row: 2;
	margin-top: 20px;
	min-width: 0;
  }
  
  /* 右カラム: img(2行分を占有) */
  .flow-main-mv .flow-main-mv__img {
	grid-column: 2;
	grid-row: 1 / 3;
	align-self: start;
	min-width: 0;
  }
}
/* タブレット用(任意) */
@media (min-width: 1024px) {
  .flow-main-mv > .wp-block-group__inner-container {
	gap: 0 20px;
  }
}
/* 画像スタイル */
.flow-main-mv .flow-main-mv__img img {
  max-width: 100%;
  height: auto;
  display: block;
  width: 100%;
}
/* レスポンシブブレーク */
.flow-main-mv .br-sp {
  display: inline;
}
@media (min-width: 768px) {
  .flow-main-mv .br-sp {
	display: none;
  }
}


/* 詳細ステップフロー */
.flow-main-step {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0;
}

/* 各ステップコンテンツ */
.about .flow-main-step-content {
	margin-bottom: 39px!important;
	background-color: #F5F9FF;
	border-radius: 12px;
	overflow: visible;
	position: relative;
}

.flow-main-step-content:last-child {
	margin-bottom: 0;
}

/* ステップ間の接続線 */
.flow-main-step-content:not(:last-child)::after {
	content: '';
	position: absolute;
	bottom: -39px;
	left: 50%;
	transform: translateX(-50%);
	width: 6px;
	height: 40px;
	background-color: #1E3A8A;
	z-index: 20;
}

/* ステップタイトル */
.about .flow-main-step-title {
	background-image: linear-gradient(90deg, #004bc7, #001230)!important;
	color: white !important;
	font-size: 22px !important;
	font-weight: bold !important;
	margin: 0 !important;
	padding: 10px 20px !important;
	text-align: left !important;
	border-radius: 12px 12px 0 0;
}

.about .flow-main-step-title .step-txt{
	margin-right: 3px;
}

.about .flow-main-step-title>span{
	margin-right: 13px;
}

.step-txt{
	font-size: 0.7em;
	margin-right: 5px;
}

/* PC版レイアウト（横並び） */
@media (min-width: 783px) {
	.flow-main-step-content .wp-block-columns {
		display: flex;
		align-items: flex-start;
		gap: 20px;
		margin: 0;
		padding: 20px 20px 30px;
	}

	.flow-main-step-img {
		flex: 0 0 200px;
		text-align: center;
		flex-basis: 28%!important;
	}

	.flow-main-step-img img {
		width: 180px;
		height: 180px;
		border-radius: 50%;
		object-fit: cover;
		//box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
		//border: 4px solid white;
	}

	.flow-main-step-txt {
		flex: 1;
		padding-left: 0;
		flex-basis: 72%!important;
	}

	.flow-main-step-txt p {
		color: #292929;
		font-size: 16px;
		line-height: 1.8;
		margin-bottom: 5px;
	}

	.about .flow-main-step-txt p:last-of-type {
		margin-bottom:30px!important;
	}

	.flow-main-step-cta {
		margin: 0;
		float: right;
	}

	.flow-main-step-cta img {
		width: 100%;
		max-width: 380px;
		height: auto;
		cursor: pointer;
		transition: transform 0.2s ease;
	}

	.flow-main-step-cta img:hover {
		transform: translateY(-2px);
	}
}

/* SP版レイアウト（縦並び） */
@media (max-width: 782px) {
	.flow-main-step-content .wp-block-columns {
		display: block;
		margin: 0;
		padding:20px 15px;
	}

	.flow-main-step-img {
		text-align: center;
		margin-bottom: 20px;
	}

	.flow-main-step-img img {
		width: 175px!important;
		height: 175px;
		border-radius: 50%;
		object-fit: cover;
		//box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
	}
	
	.about .flow-main-step-title{
		line-height: 1.3!important;
		display: flex;
		align-items: center;
	}
	
	.about .flow-main-step-title>span {
		text-align:center;
	}

	.flow-main-step-txt {
		text-align: left;
	}

	.flow-main-step-txt p {
		font-size: 16px;
		line-height: 1.7;
		margin-bottom: 12px;
	}

	.flow-main-step-txt p:last-of-type {
		margin-bottom: 20px!important;
	}

	.flow-main-step-cta {
		//margin: 0;
		text-align: center;
	}

	.flow-main-step-cta img {
		width: 100%;
		max-width: 300px;
		height: auto;
		cursor: pointer;
		transition: transform 0.2s ease;
	}

	.flow-main-step-cta img:hover {
		transform: translateY(-1px);
	}
}

/* 強調テキストのスタイリング */
.flow-main-step-txt span[style*="font-weight:bold"] {
	font-weight: bold;
	color: #1E3A8A;
}

/* リンクのスタイリング */
.flow-main-step-txt a {
	color: #292929;
	text-decoration: underline;
	//font-weight: bold;
}

.flow-main-step-txt a:hover {
	color: #1E40AF;
}

/*
.wp-block-group__inner-container,
.wp-block-columns,
.wp-block-column,
.wp-block-image {
	display: block;
}

.wp-block-image figure {
	margin: 0;
}

.yt-video {
  width: 95%;
  aspect-ratio: 16 / 9;
  max-width: 870px;
  margin:0 auto;
  padding:0 10px;
}
.yt-video iframe {
  width: 100%;
  height: 100%;
}
*/

/*! サブテキスト、下線付き見出し */

.about .c-heading--underline {
	text-align: center;
	margin: 20px 0 50px!important;
}

.c-heading--underline .c-heading--underline__sub {
	font-size: 17px;
	color: #b8d4e8;
	letter-spacing: 0.1em;
	font-weight: 400;
	text-transform: lowercase;
	text-align: center;
	margin:0!important;
}

.c-heading--underline h2 {
	font-size: 36px;
	color: #003a70;
	font-weight: 700;
	margin: 0;
	letter-spacing: 0.05em;
	position: relative;
	display: inline-block;
	padding: 0 90px 5px;
}

.c-heading--underline h2::before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 2px;
	background-color: #e8e8e8;
}

.c-heading--underline h2::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 60px;
	height: 2px;
	background-color: #003a70;
}

@media (max-width: 768px) {
	.about .c-heading--underline {
		margin: 40px 0 30px !important;
	}
	
	.c-heading--underline h2 {
		font-size: 2rem;
		padding: 0 15px 5px;
	}
}