

.heading01.big, .heading01.big::after { background: url(//resource.aichisogo.or.jp/souzoku/qa/images/headingImg.png) no-repeat top right; background-size: contain; }
.kv_img, .kv_img::after { background: url(//resource.aichisogo.or.jp/souzoku/qa/images/headingImg.png) no-repeat top right; background-size: contain; }


.qaWrap { }
.qaWrap .l_col-4 > * { text-indent: 0; padding-left: 0; }
.qaWrap .select { background: #fffae5; }


#qaSingle p+ul { margin-top: 10px; }
#qaSingle ul li { position: relative; line-height: 1.8; padding-left: 15px; }
#qaSingle ul li:not(:last-of-type) { margin-bottom: 5px; }
#qaSingle ul li::before { position: absolute; top: 9px; left: 0; content: ""; display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: #5d9724; }
#qaSingle ol { counter-reset: number; }
#qaSingle ol li { position: relative; line-height: 1.4em; padding-left: 1.5em;  }
#qaSingle ol li:not(:last-of-type) { margin-bottom: 5px; }
#qaSingle ol li::before { position: absolute; top: 0; left: 0; counter-increment: number; content: counter(number) "."; display: inline-block; line-height: 1.8em; }
#qaSingle table { border: 1px solid #5d9724; margin: 20px 0; }

@media screen and (max-width: 767px) {
  #qaSingle .table { overflow: auto; }
  #qaSingle table { min-width: 960px; }
}

#qaSingle table th, #qaSingle table td { padding: 10px; border: 1px solid #5d9724; line-height: 1.4em; font-size: 1.6rem; }
#qaSingle table thead tr th { background: #f6f6f6; }
#qaSingle table thead tr th:first-of-type { background: #fffae5; }
#qaSingle table tbody th { background: #fffae5; white-space: nowrap; }

@media screen and (min-width: 768px) {
  .glossary { padding: 0 20px; }
}

@media (max-width: 767px){
  .table-scroll { overflow-x: scroll;  white-space: nowrap; }
  #qaSingle table th, #qaSingle table td { font-size: 1.4rem; }
}


.glossary dl dt { font-weight: 500; color: #664733; font-size: 1.8rem; line-height: 1.4em; margin-bottom: 10px; letter-spacing: 1px; }
.glossary dl dt::before { position: relative; top: -2px; display: inline-block; margin-right: 8px; content: ""; width: 0; height: 0; border-style: solid; border-width: 5px 0 5px 7px; border-color: transparent transparent transparent #664733; }
.glossary dl dt:not(:first-of-type) { margin-top: 20px; }
.glossary dl dd p { line-height: 1.8em; letter-spacing: 1px; }
.qaList dl dt { position: relative; font-size: 2.1rem; line-height: 1.4em; letter-spacing: 1px; margin-bottom: 20px; padding: 8px 15px; background: #fff; border: 1px solid #5d9724; border-radius: 6px; }

@media screen and (max-width: 480px) {
  .qaList dl dt { font-size: 1.8rem; }
}

.qaList dl dt::before, .qaList dl dt::after { position: absolute; top: 100%; left: 30px; content: ''; height: 0; width: 0; border: 10px solid transparent; }
.qaList dl dt::before { border-top: 15px solid #5d9724; }
.qaList dl dt::after { margin-top: -2px; border-top: 15px solid #fff; }
.qaList dl dt:not(:first-of-type) { margin-top: 40px; }
.qaList dl dt span { margin-right: 5px; font-weight: bolder; color: #5d9724; font-size: 2.8rem; }

@media screen and (min-width: 768px) {
  .qaList dl dd { padding: 0 20px; }
}

@media screen and (max-width: 767px) and (min-width: 481px) {
  .qaList dl dd { padding: 0 10px; }
}

.qaList dl dd p { line-height: 1.9em; letter-spacing: 1px; }
.qaList dl dd p:not(:last-child) { margin-bottom: 10px; }

@media screen and (min-width: 768px) {
  .caseLink { text-align: right; padding: 15px; }
}

.caseLink a { -webkit-transition: all 600ms cubic-bezier(0.165, 0.84, 0.44, 1); transition: all 600ms cubic-bezier(0.165, 0.84, 0.44, 1); position: relative; display: inline-block; color: #ef7924; font-size: 2rem; font-weight: 500; letter-spacing: 1px; }
.caseLink a::before { position: absolute; }

.caseLink a::after { -webkit-transition: all 600ms cubic-bezier(0.165, 0.84, 0.44, 1); transition: all 600ms cubic-bezier(0.165, 0.84, 0.44, 1); content: ""; position: absolute; left: 0; bottom: -2px; width: 100%; border-bottom: 1px solid #ef7924;　}
.caseLink a:hover::after {　opacity: 0;　}

@media screen and (max-width: 480px) {
  .caseLink a { font-size: 1.6rem; padding-left: 30px; }
}

@media screen and (min-width: 768px) {
  .caseLink a::before { top: 50%; left: -35px; font-size: 3rem; margin-top: -15px; }
}

@media screen and (max-width: 768px) {
  .caseLink { padding: 20px; }

  .caseLink a::before { top: -2px; left: 0; font-size: 2.4rem; margin-top: 0; }
}

/*------------------------------------------------------
	caseInner
------------------------------------------------------*/
.caseInner { transition: background 0.3s; margin-bottom: 0; }
.caseInner .question { border-bottom: 1px solid #ccc; position: relative; cursor: pointer; }
.caseInner .question::before { content: 'Q'; font-family: 'Noto Sans JP', sans-serif; color: #5d9724; position: absolute; line-height: 1;}
.caseInner .question .btn { width: 20px; height: 20px; background-color: #5d9724; position: absolute; right: 10px; top: 26px; }
.caseInner .question .btn span { position: absolute; width: 12px; height: 2px; background-color: #fff; left: 0; right: 0; top: 0; bottom: 0; margin: auto;}
.caseInner .question .btn span:nth-of-type(2) { -webkit-transform: rotate(90deg); transform: rotate(90deg); }

.caseInner .answer { position: relative; background-color: #fff; border-radius: 6px; margin-left: 60px; margin-right: 20px; padding: 15px 15px 15px 50px; display: none;}
.caseInner .answer a{ text-decoration: underline; }
.caseInner .answer a:hover{ text-decoration: none; }
.caseInner .answer::before { content: 'A'; font-family: 'Noto Sans JP', sans-serif; color: #f79e00; position: absolute; line-height: 1;}
.caseInner .answer p { line-height: 1.8; margin-bottom: 15px; }
.caseInner .answer p:last-of-type { margin-bottom: 0; }

.caseInner.active { background-color: #f79e00; padding-bottom: 20px; border-bottom: 1px solid #fff;}
.caseInner.active .question { border-bottom-color: transparent; color: #fff;}
.caseInner.active .question::before { color: #fff;}
.caseInner.active .question .btn { background-color: #fff;}
.caseInner.active .question .btn span { background-color: #f79e00; }
.caseInner.active .question .btn span:nth-of-type(2) { display: none; }
.caseInner.active .answer { }
.caseInner.active .text { margin-bottom: 0; }


@media (min-width: 768px) {
	.caseInner {}
	.caseInner .question { font-size: 2.2rem; line-height: 1.5; padding: 20px 30px 20px 50px; font-weight: bold; }
	.caseInner .question::before { font-size: 2.8rem; left: 12px; top: 19px; }
	.caseInner .question .btn {}
	.caseInner .question .btn span {}
	.caseInner .answer { font-size: 1.8rem; line-height: 1.8; }
	.caseInner .answer::before { font-size: 2.8rem; left: 18px; top: 18px;}
}

@media (max-width: 767px) {
	.caseInner {}
	.caseInner .question { font-size: 1.8rem; padding: 15px 40px 15px 40px; line-height: 1.4; }
	.caseInner .question::before { font-size: 2.4rem; left: 10px; top: 13px;}
	.caseInner .question .btn { top: 18px;}
	.caseInner .question .btn span {}
	.caseInner .answer { font-size: 1.6rem; line-height: 2; margin-left: 10px; margin-right: 10px; padding: 15px 10px 15px 35px; }
	.caseInner .answer::before { font-size: 2.4rem; left: 10px; top: 15px;}
	.caseInner .answer ul { margin-left: 0; }
}
