/* FAQ */
form.faq-search-container{
	margin-bottom: 4.8rem;
}
.faq-search-box{
	display: flex;
	justify-content: center;
}
.faq-search-box input[type="text"]{
	width: 100%;
	max-width: 400px;
	font-size: 16px;
	padding: 10px;
}
.faq-search-box input[type="submit"]{
	-webkit-appearance: none;
    background: #0D3563;
    transition: opacity 300ms ease;
	width: 100%;
    max-width: 120px;
    height: 56px;
    margin: 0;
    cursor: pointer;
    border: none;
    color: #fff;
    display: inline-block;
    background-position: center;
    font-size: 16px;
    border-radius: 0 5px 5px 0;
}
.faq-search-box input[type="submit"]:hover {
    opacity: .7;
}
dl.faq dt {
    font-size: 2.2rem;
    line-height: 1.6;
    padding: 0 3px;
	background-color: #f5f5f5;
	font-weight: bold;
}
dl.faq dt::before{
	content:"Q. ";
}
dl.faq dd {
    margin-bottom: 3rem;
    line-height: 1.4;
    padding: 10px 10px;
	border:2px solid #f5f5f5;
}
dl.faq dd p:first-child::before {
    content:"A. ";
}

.faq-box h2.faq-ttl{
	margin-top: 7rem;
	text-align: left;
}
.viewImg img{
	max-width: 100%;
	width: 100%;
	height: auto;
}
.faq-box dd p:last-child {
	margin-bottom: 0;
}

.faq-category {
	display: flex;
	flex-wrap: wrap;
}
.faq-category a {
	display: block;
	max-width: calc(100% / 4 - 0.4rem);
	width: 100%;
	background: #f5f5f5;
	padding: 1rem;
	margin: 0.2rem;
	box-sizing: border-box;
	font-weight: bold;
	position: relative;
}
.accordion {
    position: relative;
    max-width: 1280px;
    margin: 0 auto 1.6rem;
}
.accordion-item {
    margin-bottom: 1.6rem;
}
.accordion-title {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
    transition: all 0.3s ease;
    position: relative;
    background-color: #e0e0e0;
    padding: 2.4rem 8rem;
    display: block;
    color: #333;
    font-weight: bold;
    font-size: 2rem;
    line-height: 1.4;
    cursor: pointer;
}
.accordion-title:hover {
    opacity: 0.7;
}
.accordion-title::before {
    content: "";
    position: absolute;
    right: 3rem;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 1px;
    background-color: #333;
    transition: transform 0.3s ease;
}
.accordion-title::after {
    content: "";
    position: absolute;
    right: 3rem;
    top: 50%;
    transform: translateY(-50%) rotate(90deg);
    width: 24px;
    height: 1px;
    background-color: #333;
    transition: transform 0.3s ease;
}
.accordion-title.active::after {
    transform: translateY(-50%) rotate(0deg);
}
.accordion-title span {
    position: relative;
    line-height: 1.4;
}
.accordion-title span::before {
    content: "Q";
    font-size: 4.8rem;
    line-height: 1;
    color: #0D3563;
    position: absolute;
    left: -50px;
    top: 50%;
    transform: translateY(-50%);
}
.accordion-content {
    max-height: 0;
    overflow: hidden;
	display: none;
    background-color: #fff;
	border: 1px solid #e0e0e0;
    border-top: none;
    padding: 2.8rem 2rem 2.8rem 8rem;
    position: relative;
    font-size: 1.8rem;
}
.accordion-content.active {
    max-height: 100%;
}
.accordion-content::before {
    content: "A";
    color: #9AD1FF;
    left: 2.8rem;
    top: 2rem;
    transform: translateY(0);
    font-size: 4.8rem;
    line-height: 1;
    position: absolute;
    z-index: 2;
	font-weight: bold;
}
.accordion-content p:last-child {
	margin-bottom: 0;
}
.faq-ttl-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.faq-wrapper h1 {
	text-align: left;
	position: relative;
	padding-left: 3.2rem;
}
.faq-wrapper h1::before {
	content: "Q.";
	position: absolute;
	left: 0;
}
.faq-wrapper .more {
	margin-top: 6.4rem;
}


.zero-faq {
    background: #F3F3F3;
	margin: 0 calc(50% - 50vw);
	padding: 8rem calc(50vw - 50% + 1%);
}
.zero-faq input {
    display: none;
}
.zero-faq-box {
    position: relative;
    max-width: 1280px;
    margin: 0 auto 1.6rem;
}
.zero-faq-box label{
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
    transition: all 0.5s;
    position: relative;
    background-color: #e0e0e0;
    padding: 2.4rem 8rem;
    display: block;
    color: #333;
    font-weight: bold;
    font-size: 2rem;
    line-height: 1.4;
}
.zero-faq-box label:hover {
    cursor: pointer;
    opacity:.5;
}
.zero-faq-box label::after,
.zero-faq-box label::before {
    content: "";
    position: absolute;
    right: 3rem;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 1px;
    background-color: #333;
    transition: all 0.5s;
    font-size: 2rem;
}
.zero-faq-box label span{
    position: relative;
    line-height: 1.4;
}
.zero-faq-box label span::before{
    content: "Q";
    font-size: 4.8rem;
    line-height: 1;
    color: #0D3563;
    position: absolute;
    left: -50px;
    top: 50%;
    transform: translateY(-50%);
}
.zero-faq-box label::after {
    transform: rotate(90deg);
}

.zero-faq-box .answer {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
    position: relative;
    max-height: 0;
    transition:.3s;
    overflow: hidden;
    background-color: #fff;
}
.zero-faq-box input:checked + label + .answer {
    max-height: 5000px;
}
.zero-faq-box input:checked + label::after {
    transform: rotate(180deg) !important;
}
.zero-faq-box .answer div.txt{
    padding:2.4rem 2rem 1rem 8rem;
    position:relative;
    font-size: 1.8rem;
}
.zero-faq-box .answer div.txt::before {
    content: "A";
    color: #9AD1FF;
    left: 3.2rem;
    top: 2rem;
    transform: translateY(0);
    font-size: 4.8rem;
    line-height: 1;
    position: absolute;
    z-index: 2;
}
.faq-box input {
    display: none;
}

@media screen and (max-width: 959px) {
    .zero-faq {
        padding: 4rem calc(50vw - 50% + 1%);
    }
    .zero-faq-box label{
        padding:2.2rem 6rem;
    }
    .zero-faq-box label span::before {
        left: -45px;
    }
    .zero-faq-box .answer div.txt{
        padding:2rem 2rem 2rem 6rem;
    }
    .zero-faq-box .answer div.txt::before {
        left: 1.0rem;
        top: 3.0rem;
    }    
}
@media screen and (max-width: 599px) {
    dl.faq dt{
        font-size: 1.8rem;
    }
}