
.faq {
	max-width: 1000px;
	margin-top: 0px;
	margin-right: auto;
	margin-left: auto;
	padding: 20px;
	border-radius: 10px;
}
.faq h2 {
	text-align: center;
	font-size: 2.8rem;
	margin-bottom: 20px;
	font-family: inherit;
}

.faq .narrow {
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 20px;
}

.faq .narrow input[type="text"] {
	width: 40%;
	font-size: 16px;
	border: 1px solid #ccc;
	border-radius: 4px;
	margin-left: 10px;
}

@media (max-width: 768px) {
	.faq .narrow {
		flex-direction: column;
		margin-bottom: 20px;
	}

	.faq .narrow input[type="text"] {
		width: 80%;
		font-size: 16px;
		border: 1px solid #ccc;
		border-radius: 4px;
		margin-top: 10px;
		margin-left: 10px;
	}
}

.faq .faq-category {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	margin-left: auto;
	margin-right: 0;
	margin-bottom: 5px;
}

.faq .faq-category .label {
	font-size: 0.9em;
}

.faq .faq-category .category {
	width: 120px;
	text-align: center;
	color: white;
	font-weight: bold;
	border-radius: 3px;
	margin-right: 10px;
}

/* カテゴリ別背景 */
.faq .category-A {
  background-color: #FFBE3B;
}
.faq .category-B {
  background-color: #CDD204;
}
.faq .category-C {
  background-color: #8EC16B;
}
.faq .category-D {
  background-color: #6BD7F9;
}
.faq .category-E {
  background-color: #6E88F6;
}
.faq .category-F {
  background-color: #C762F0;
}
.faq .category-G {
  background-color: #FFA3E7;
}
.faq .category-H {
  background-color: #FFBE3B;
}
.faq .category-J {
  background-color: #CDD204;
}
.faq .category-K {
  background-color: #8EC16B;
}
.faq .category-L {
  background-color: #6BD7F9;
}
.faq .category-M {
  background-color: #6E88F6;
}
.faq .category-N {
  background-color: #C762F0;
}
.faq .category-P {
  background-color: #FFA3E7;
}
.faq .category-Q {
  background-color: #FFBE3B;
}
.faq .category-R {
  background-color: #CDD204;
}
.faq .category-S {
  background-color: #8EC16B;
}
.faq .category-T {
  background-color: #6BD7F9;
}
.faq .category-U {
  background-color: #6E88F6;
}
.faq .category-V {
  background-color: #C762F0;
}
.faq .category-W {
  background-color: #FFA3E7;
}
.faq .category-X {
  background-color: #FFBE3B;
}
.faq .category-Y {
  background-color: #FF5050;
}
.faq .category-Z {
  background-color: #969696;
}
.faq-list {
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.faq-answer {
	background-color: #fff;
	padding: 10px;
	border-radius: 5px;
	border: 1px solid #ccc;
	margin-bottom: 5px;
}

.faq-answer img {
	margin: 0 auto;
	display: block;
}


.faq-answer .summary-bar {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	background-color: #fff;
}

.faq-answer .summary-bar .caption {
	width: 120px;
	text-align: center;
	padding: 5px 10px;
	color: white;
	font-weight: bold;
	border-radius: 3px;
	margin-right: 20px;
	background-color: #004A98;
}

.faq-answer .summary-bar .caption-faq {
	width: 120px;
	text-align: center;
	padding: 5px 10px;
	color: white;
	font-weight: bold;
	border-radius: 3px;
	margin-right: 20px;
	background-color: gray;
}

.faq-answer .summary-bar .caption-cmn {
	width: 120px;
	text-align: center;
	padding: 5px 10px;
	color: white;
	font-weight: bold;
	border-radius: 3px;
	margin-right: 20px;
}

.faq-answer .summary-bar .summary {
	font-size: 1.6rem;
	font-weight: bold;
}

.faq-answer .main-area {
	align-items: center;
	justify-content: flex-start;
	background-color: #fff;
	padding: 15px 1.5rem 5px 1.5rem;
	text-align: left;
}

.faq-answer .foot-area {
	margin-top: 10px;
	margin-right: 10px;
	text-align: right;
}

.faq-links {
	display: flex;
	justify-content: center;
}
.faq-links a {
	text-decoration: none;
	color: #003087;
	font-size: 16px;
}
.faq-links a:hover {
	text-decoration: underline;
}

.faq-item {
	display: flex;
	flex-direction: row; /* デフォルトでは横並び */
	align-items: center;
	justify-content: flex-start;
	background-color: #fff;
	padding: 10px;
	border-radius: 5px;
	border: 1px solid #ccc;
	flex-wrap: wrap; /* 必要なら折り返し */
}

.faq-item .topic {
	font-weight: bold;
}

.faq-item .caption {
	width: 120px;
	text-align: center;
	padding: 5px 10px;
	color: white;
	font-weight: bold;
	border-radius: 3px;
	margin-right: 20px;
	background-color: #004A98;
}

.faq-item .summary-bar {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	background-color: #fff;
}

/* ▼ 画面幅が768px以下のときは縦並びに変更 ▼ */
@media (max-width: 768px) {
	.faq {
		padding: 10px;
	}

	.faq-item {
		flex-direction: column;
		align-items: flex-start;
		background-color: #fff;
		padding-left: 1.0rem;
		padding-right: 1.0rem;
		padding-top: 10px;
		padding-bottom: 5px;
		border-radius: 5px;
		border: 1px solid #ccc;
		flex-wrap: wrap; /* 必要なら折り返し */
	}
	
	.faq-item .summary-bar {
		display: flex;
		align-items: center;
		justify-content: flex-start;
		background-color: #fff;
	}
	
	.faq-item .caption {
		width: 100px;
		text-align: center;
		padding: 5px 10px;
		color: white;
		font-weight: bold;
		border-radius: 3px;
		margin-right: 20px;
		background-color: #004A98;
	}

	.faq .faq-category .category {
		margin-right: 0;
		margin-bottom: 10px;
	}

	.faq-item .topic {
		padding-left: 1rem;
		padding-right: 1rem;
		width: 100%;
		box-sizing: border-box;
		margin-top: 10px;
		margin-bottom: 10px;
	}

	.faq-answer .summary-bar {
		display: flex;
		align-items: center;
		justify-content: flex-start;
		background-color: #fff;
	}

	.faq-answer .summary-bar .caption {
		width: 100px;
		text-align: center;
		padding: 5px 10px;
		color: white;
		font-weight: bold;
		border-radius: 3px;
		margin-right: 20px;
		background-color: #004A98;
	}

	.faq-answer .summary-bar .caption-faq {
		width: 100px;
		text-align: center;
		padding: 5px 10px;
		color: white;
		font-weight: bold;
		border-radius: 3px;
		margin-right: 20px;
		background-color: gray;
	}

	.faq-answer .summary-bar .caption-cmn {
		width: 120px;
		text-align: center;
		padding: 5px 10px;
		color: white;
		font-weight: bold;
		border-radius: 3px;
		margin-right: 20px;
	}

	.faq-answer .summary-bar .summary {
		font-size: 1.6rem;
		font-weight: bold;
	}

	.faq-answer .main-area {
		display: flex;
		align-items: center;
		justify-content: flex-start;
		background-color: #fff;
		padding: 15px 1.0rem 5px 1.0rem;
		text-align: left;
	}

}



