/* --------------------
 Contact
-------------------- */
.com-page-head {
    background-image: url(../images/pages/contact/contact-page-head.webp);
}

.contact {
    margin: 0 0 60px;
}

@media (min-width: 768px) {
    .contact {
        margin: 0 0 120px;
    }
}

.contact__overview {
    margin: 0 0 60px;
}

@media (min-width: 768px) {
    .contact__overview {
        margin: 0 0 100px;
    }
}

.contact__overview-container {
    margin: 0 auto;
    max-width: 1100px;
    padding: 0 16px;
    width: 100%;
}

@media (min-width: 768px) {
    .contact__overview-container {
        padding: 0 30px;
    }
}

.contact__overview__menu {
    align-items: center;
    display: flex;
    flex-flow: column nowrap;
    gap: 24px 40px;
    justify-content: space-between;
    margin: 0 auto;
    max-width: 340px;
    width: 100%;
}

@media (min-width: 768px) {
    .contact__overview__menu {
        flex-direction: row;
        max-width: 680px;
    }
}

@media (min-width: 992px) {
    .contact__overview__menu {
        gap: 70px;
    }
}

.contact__overview__menu__item {
    width: 100%;
}

@media (min-width: 768px) {
    .contact__overview__menu__item {
        width: calc(50% - 20px);
    }
}

@media (min-width: 992px) {
    .contact__overview__menu__item {
        width: calc(50% - 35px);
    }
}

.contact__overview__menu__item .com-button {
    margin: 0 auto;
    width: 100%;
}

.contact__faq {
    container-type: inline-size;
    overflow-x: clip;
    padding: 120px 0 120px;
    position: relative;
}

@media (min-width: 768px) {
    .contact__faq {
        padding: 140px 0 220px;
    }
}

.contact__faq:before {
    background-color: #ffffff;
    content: "";
    display: block;
    height: 140px;
    left: -1px;
    -webkit-mask-image: url(../images/commons/com-bg-mask-top.svg);
    mask-image: url(../images/commons/com-bg-mask-top.svg);
    -webkit-mask-position: center bottom;
    mask-position: center bottom;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: auto 100%;
    mask-size: auto 100%;
    pointer-events: none;
    position: absolute;
    right: -1px;
    top: 0;
    transform: translateY(-2px);
    width: auto;
    z-index: 1;
}

@container (min-width: 1200px) {
    .contact__faq:before {
        aspect-ratio: 1200/140;
        height: auto;
        -webkit-mask-size: cover;
        mask-size: cover;
    }
}

.contact__faq:after {
    background-color: #ffffff;
    bottom: 0;
    content: "";
    display: block;
    height: 140px;
    left: -1px;
    -webkit-mask-image: url(../images/commons/com-bg-mask-bottom.svg);
    mask-image: url(../images/commons/com-bg-mask-bottom.svg);
    -webkit-mask-position: center top;
    mask-position: center top;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: auto 100%;
    mask-size: auto 100%;
    pointer-events: none;
    position: absolute;
    right: -1px;
    top: auto;
    transform: translateY(2px);
    width: auto;
    z-index: 1;
}

@container (min-width: 1200px) {
    .contact__faq:after {
        aspect-ratio: 1200/140;
        height: auto;
        -webkit-mask-size: cover;
        mask-size: cover;
    }
}

.contact__faq__bg {
    background-color: #345569;
    bottom: 0;
    display: block;
    left: 0;
    overflow: hidden;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 0;
}

.contact__faq__bg:before {
    background-image: url(../images/commons/com-bg.svg);
    background-position: right bottom;
    background-repeat: no-repeat;
    background-size: 2010px 3516px;
    bottom: -450px;
    content: "";
    display: block;
    left: 0;
    -webkit-mask-image: linear-gradient(-120deg, rgba(72, 102, 120, 0) 0%, rgba(72, 102, 120, 0) 20%, #486678 100%);
    mask-image: linear-gradient(-120deg, rgba(72, 102, 120, 0) 0%, rgba(72, 102, 120, 0) 20%, #486678 100%);
    position: absolute;
    right: 170px;
    top: 0;
    z-index: 0;
}

.contact__faq-container {
    margin: 0 auto;
    max-width: 1120px;
    padding: 0 16px;
    position: relative;
    width: 100%;
    z-index: 2;
}

@media (min-width: 768px) {
    .contact__faq-container {
        padding: 0 30px;
    }
}

.contact__faq__content {
    margin: 0 0 60px;
}

@media (min-width: 768px) {
    .contact__faq__content {
        margin: 0 0 80px;
    }
}

.contact__faq__content p {
    color: #b0a39f;
    font-size: var(--fs14);
    letter-spacing: 0.1em;
    line-height: 1.9;
    margin: 0 0 1.5em;
    text-align: center;
}

.contact__faq__content p:last-child {
    margin-bottom: 0;
}

@media (min-width: 768px) {
    .contact__faq__content p {
        font-size: var(--fs16);
    }
}

.contact__faq__menu {
    align-items: center;
    display: flex;
    flex-flow: row wrap;
    gap: 16px;
    justify-content: flex-start;
    margin: 0 0 60px;
}

@media (min-width: 768px) {
    .contact__faq__menu {
        gap: 20px;
    }
}

.contact__faq__menu__item {
    width: calc(50% - 10px);
}

@media (min-width: 768px) {
    .contact__faq__menu__item {
        width: calc(33.33333% - 13.33333px);
    }
}

@media (min-width: 992px) {
    .contact__faq__menu__item {
        width: calc(20% - 16px);
    }
}

.contact__faq__menu__item button {
    align-items: center;
    -webkit-appearance: none;
    appearance: none;
    background: none;
    border: 1px solid #b0a39f;
    border-radius: 22px;
    color: #b0a39f;
    display: flex;
    flex-flow: row nowrap;
    font-feature-settings: "palt";
    font-size: var(--fs12);
    font-weight: 500;
    height: 44px;
    justify-content: stretch;
    letter-spacing: 0.15em;
    line-height: 1.2;
    padding: 0 16px;
    position: relative;
    text-align: left;
    transition: background-color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s, color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    width: 100%;
}

@media (min-width: 768px) {
    .contact__faq__menu__item button {
        font-size: var(--fs14);
        padding: 0 24px;
    }
}

@media (min-width: 992px) {
    .contact__faq__menu__item button {
        font-size: min(var(--fs14), 1.2096774194vw);
        padding: 0 min(24px, 2.0161290323vw);
    }
}

.contact__faq__menu__item button:after {
    background-color: #b0a39f;
    content: "";
    display: block;
    height: 6px;
    margin: 0;
    -webkit-mask-image: url(../images/pages/contact/contact-menu-angle-bottom.svg);
    mask-image: url(../images/pages/contact/contact-menu-angle-bottom.svg);
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-size: contain;
    mask-size: contain;
    position: absolute;
    right: 12px;
    top: 18px;
    transition: background-color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    width: 10px;
}

.contact__faq__menu__item button:focus {
    background-color: #b0a39f;
    color: #ffffff;
}

.contact__faq__menu__item button:focus:after {
    background-color: #ffffff;
}

@media (hover: hover) and (pointer: fine) {
    .contact__faq__menu__item button:hover {
        background-color: #b0a39f;
        color: #ffffff;
    }

    .contact__faq__menu__item button:hover:after {
        background-color: #ffffff;
    }
}

.contact__faq__main {
    margin: 0 0 60px;
}

@media (min-width: 768px) {
    .contact__faq__main {
        margin: 0 0 120px;
    }
}

.contact__faq__main:last-child {
    margin-bottom: 0;
}

.contact__faq__main__title {
    color: #b0a39f;
    font-size: var(--fs24);
    font-weight: 500;
    letter-spacing: 0.2em;
    line-height: 1.4;
    margin: 0 0 30px;
    text-align: center;
}

@media (min-width: 768px) {
    .contact__faq__main__title {
        margin: 0 0 40px;
    }
}

.contact__faq__main__list__item {
    background-color: #d7dde1;
    margin: 0;
    padding: 0;
}

.contact__faq__main__list__item__head {
    align-items: center;
    background-color: #e6eaec;
    border-bottom: 1px solid #cdd5da;
    cursor: pointer;
    display: flex;
    flex-flow: row nowrap;
    font-size: var(--fs10);
    gap: 30px;
    justify-content: flex-start;
    margin: 0;
    padding: 16px 0 20px 40px;
    position: relative;
    transition: color 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
}

@media (min-width: 768px) {
    .contact__faq__main__list__item__head {
        padding: 24px 0 20px 60px;
    }
}

@media (min-width: 992px) {
    .contact__faq__main__list__item__head {
        padding: 24px 0 20px 80px;
    }
}

.contact__faq__main__list__item__head:before {
    align-items: center;
    bottom: 0;
    content: "Q";
    display: flex;
    flex-flow: row nowrap;
    flex-grow: 0;
    flex-shrink: 0;
    font-size: var(--fs18);
    font-weight: 500;
    justify-content: center;
    left: 10px;
    line-height: 1.4;
    margin: auto 0;
    position: absolute;
    top: 0;
}

@media (min-width: 768px) {
    .contact__faq__main__list__item__head:before {
        font-size: var(--fs20);
        left: 20px;
    }
}

@media (min-width: 992px) {
    .contact__faq__main__list__item__head:before {
        left: 30px;
    }
}

.contact__faq__main__list__item__head__title {
    flex-grow: 1;
    flex-shrink: 1;
    font-size: var(--fs14);
    font-weight: 400;
    gap: 4px;
    letter-spacing: 0.1em;
    line-height: 1.6;
    margin: 0;
    padding: 0 64px 0 0;
    position: relative;
}

@media (min-width: 768px) {
    .contact__faq__main__list__item__head__title {
        font-size: var(--fs16);
    }
}

.contact__faq__main__list__item__head__title:before, .contact__faq__main__list__item__head__title:after {
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 0;
    content: "";
    display: block;
    height: 15px;
    margin: auto 0;
    position: absolute;
    right: 25px;
    top: 0;
    transition: transform 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s, opacity 0.35s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    width: 15px;
}

.contact__faq__main__list__item__head__title:before {
    background-image: url(../images/pages/contact/contact-faq-icon-plus.svg);
}

.contact__faq__main__list__item__head__title:after {
    background-image: url(../images/pages/contact/contact-faq-icon-minus.svg);
    opacity: 0;
}

.contact__faq__main__list__item__head:focus {
    color: var(--color-orange);
}

@media (hover: hover) and (pointer: fine) {
    .contact__faq__main__list__item__head:hover {
        color: var(--color-orange);
    }
}

.contact__faq__main__list__item__contents {
    align-items: flex-start;
    background-color: #d7dde1;
    display: none;
    flex-flow: row nowrap;
    gap: 8px;
    justify-content: flex-start;
    padding: 20px 20px 20px 40px;
    position: relative;
    transform: translateZ(0);
}

@media (min-width: 768px) {
    .contact__faq__main__list__item__contents {
        padding: 30px 60px 30px 60px;
    }
}

@media (min-width: 992px) {
    .contact__faq__main__list__item__contents {
        padding: 30px 60px 30px 80px;
    }
}

.contact__faq__main__list__item__contents__content {
    padding: 0;
}

@media (min-width: 768px) {
    .contact__faq__main__list__item__contents__content {
        padding: 2px 0 0;
    }
}

.contact__faq__main__list__item__contents__content p {
    font-size: var(--fs14);
    letter-spacing: 0.1em;
    line-height: 1.8;
    margin: 0 0 1.5em;
    word-break: break-all;
}

.contact__faq__main__list__item__contents__content p:last-child {
    margin-bottom: 0;
}

@media (min-width: 768px) {
    .contact__faq__main__list__item__contents__content p {
        font-size: var(--fs16);
    }
}

.contact__faq__main__list__item__contents__content p a {
    color: var(--color-theme);
    text-decoration: underline;
}

.contact__faq__main__list__item__contents__content p a:focus {
    text-decoration: none;
}

@media (hover: hover) and (pointer: fine) {
    .contact__faq__main__list__item__contents__content p a:hover {
        text-decoration: none;
    }
}

.contact__faq__main__list__item__contents__content p b, .contact__faq__main__list__item__contents__content p strong {
    font-weight: 700;
}

.contact__faq__main__list__item.-active .contact__faq__main__list__item__head {
    color: var(--color-orange);
}

.contact__faq__main__list__item.-active .contact__faq__main__list__item__head__title:before {
    opacity: 0;
}

.contact__faq__main__list__item.-active .contact__faq__main__list__item__head__title:after {
    opacity: 1;
}