/*!教室詳細用*/
.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;
}

.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:4vw;
}

.main-title {
	color: #222222;
	font-size: 3vw;
	font-weight: 700;
	line-height: 1.7;
	margin-bottom: 2rem;
	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;
}

.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%;
}
/*!近隣の英検アカデミー教室一覧*/
 .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%;
}

@media screen and (min-width: 960px) {
	.result-list {
		max-width: 1200px;
		flex-direction: row;
		justify-content: center;
	}
	
	.result-card {
		height: 420px;
		flex-direction: column;
		width: 25%;
	}
	.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 20px;
	}
	
	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: 3vw 0;
	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;
}

.municipality__classroom-list{
	gap:0;
}	
	
.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);
		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:1.2em 0!important;
}
	
.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 {
/*	
	background-color: white;
	border-radius: 5px;
	padding: 15px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	*/
		padding: 1.5em;
		font-size: 14px;
		line-height: 1.6;
		transition: all 0.3s ease;
		margin-top: 3em!important;
		display: flex;
		flex-wrap: wrap;
		gap: 1em;
		background-color: #fff;
	
}

.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 0.9em;
	color: #111;
	border: 1px solid #999;
	border-radius: 5px;
	text-decoration: none;
}

.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_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 0.9em;
	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;
}
*/

/* レスポンシブデザイン */
@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;
	}
	
}

@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);
	}

}

