@charset "UTF-8";

@media screen and (min-width:769px) {
    .contact {
        position: relative
    }
}

@media screen and (max-width:768px) {
    .contact__mainvisual {
        /* background-image: url(../img/contact/mainvisual.jpg) */
    }
}

@media screen and (min-width:769px) {
    .contact__mainvisual {
        margin-left: 46.56%;
        padding-bottom: 37.5%;
        /* background-image: url(../img/contact/mainvisual_pc.jpg) */
    }
}

@media screen and (min-width:1025px) {
    .contact__mainvisual {
        margin-left: 595px
    }
}

@media screen and (min-width:1281px) {
    .contact__mainvisual {
        margin-left: 46.48%
    }
}

@media screen and (max-width:768px) {
    .contact__heading {
        margin: 23px 0 0 7.03%;
        font-size: 30px
    }
}

@media screen and (min-width:769px) {
    .contact__heading {
        position: absolute;
        top: 0;
        left: 7.03%;
        padding-top: calc(18.75% - 34.4px);
        letter-spacing: .17em;
        font-size: 40px
    }
}

@media screen and (min-width:1025px) {
    .contact__heading {
        left: 330px
    }
}

@media screen and (min-width:1281px) {
    .contact__heading {
        left: 25.78125%
    }
}

.contact__heading--sleeve {
    font-family: Hiragino Kaku Gothic ProN, メイリオ, Meiryo, Verdana, ＭＳ\ Ｐゴシック, sans-serif
}

@media screen and (max-width:768px) {
    .contact__heading--sleeve {
        letter-spacing: .2em;
        font-family: Hiragino Kaku Gothic ProN, メイリオ, Meiryo, Verdana, ＭＳ\ Ｐゴシック, sans-serif;
        font-size: 16px;
        line-height: 2.2
    }
}

@media screen and (min-width:769px) {
    .contact__heading--sleeve {
        display: block;
        margin-top: 5px;
        letter-spacing: .2em;
        font-size: 16px;
        line-height: 1.8
    }
}

.faq {
    padding-bottom: 80px;
}

/* @media screen and (max-width:768px) {
    .faq {
        padding-bottom: 80px;
    }
} */

@media screen and (min-width:1025px) {
    .faq {
        margin: 0 0 0 280px;
    }
}

@media screen and (min-width:1281px) {
    .faq {
        margin: 0 20% 0 21.875%
    }
}

@media screen and (min-width:769px) {
    .faq__body {
        margin: 98px auto 0;
        max-width: 744px
    }
}

@media screen and (min-width:1025px) {
    .faq__body {
        margin: 98px auto 0 0
    }
}

@media screen and (min-width:1281px) {
    .faq__body {
        margin: 98px auto 0
    }
}

.faq__heading {
    text-align: center
}

@media screen and (max-width:768px) {
    .faq__heading {
        margin-top: 70px;
        padding-top: 5px;
        font-size: 25px;
        line-height: 2.1
    }
}

@media screen and (min-width:769px) {
    .faq__heading {
        font-size: 28px;
        line-height: 2.4
    }
}

.faq__heading--sleeve {
    font-family: Hiragino Kaku Gothic ProN, メイリオ, Meiryo, Verdana, ＭＳ\ Ｐゴシック, sans-serif
}

@media screen and (max-width:768px) {
    .faq__heading--sleeve {
        font-size: 14px
    }
}

@media screen and (min-width:769px) {
    .faq__heading--sleeve {
        font-size: 16px
    }
}

@media screen and (max-width:768px) {
    .faq__qas {
        margin: 50px 0
    }
}

@media screen and (min-width:769px) {
    .faq__qas {
        margin: 62px 0 120px
    }
}

.faq__qa {
    padding-bottom: 40px;
    border-bottom: 1px solid #cdcbca
}

@media screen and (max-width:768px) {
    .faq__qa+.faq__qa {
        margin-top: 40px
    }
}

@media screen and (min-width:769px) {
    .faq__qa {
        margin-left: 50px;
        font-size: 13px
    }

    .faq__qa+.faq__qa {
        margin-top: 30px
    }
}

.faq__question {
    position: relative;
    font-size: .9rem;
    font-weight: normal;
    letter-spacing: .25em;
    padding-right: 23px;
}

.faq__question:before {
    content: "・";
    display: block;
    position: absolute;
    left: 0;
    border-radius: 50%;
    text-align: center;
    font-family: Suranna, serif
}

@media screen and (max-width:768px) {
    .faq__question {
        padding-left: calc(32px + .75em);
        letter-spacing: .1em;
        line-height: 32px
    }

    .faq__question:before {
        margin-right: .75em;
        width: 32px;
        height: 32px;
        text-indent: 0;
        font-size: 16px
    }

    .faq__question a {
        padding-right: 30px
    }
}

@media screen and (min-width:769px) {
    .faq__question {
        padding-left: 56px;
        line-height: 34px
    }

    .faq__question:before {
        width: 34px;
        height: 34px;
        letter-spacing: 0;
        font-size: 16px
    }
}

.faq__answer {
    display: none
}

.faq__answer:after,
.faq__answer:before {
    display: inline-block
}

.faq__answer:before {
    content: "A";
    border: 1px solid;
    border-radius: 50%;
    background-color: #5a5251;
    text-align: center;
    text-indent: 0;
    color: #fff;
    font-family: Suranna, serif;
    opacity: 0;
}

@media screen and (max-width:768px) {
    .faq__answer {
        margin-top: 18px;
        padding-right: 1em;
        padding-left: calc(32px + .75em);
        text-indent: calc(-40px - .75em);
        letter-spacing: .2em;
        font-size: 14px;
        line-height: 2.7
    }

    .faq__answer:before {
        margin-right: .75em;
        width: 32px;
        height: 32px;
        letter-spacing: 0;
        font-size: 16px;
        line-height: 1.8
    }
}

@media screen and (min-width:769px) {
    .faq__answer {
        margin-top: .7em;
        padding-left: 56px;
        text-indent: -56px;
        letter-spacing: .2em
    }

    .faq__answer:before {
        position: relative;
        top: 9px;
        margin-right: 22px;
        width: 27px;
        height: 27px;
        letter-spacing: 0;
        font-size: 16px;
        line-height: 2
    }
}

label {
    position: relative
}

label:after {
    content: "";
    position: absolute;
    top: 10px;
    right: 10px;
    border: 5px solid transparent;
    border-top: 5px solid #000;
    border-top: none\9;
    border-bottom: 0;
    width: 0;
    height: 0
}

input,
textarea {
    padding: 8px 12px
}

.contactForm {
    background-color: #f3efee
}

@media screen and (max-width:768px) {
    .contactForm form {
        margin-top: 40px;
        font-size: 14px
    }
}

@media screen and (min-width:1025px) {
    .contactForm {
        padding: 0 0 0 280px
    }
}

@media screen and (min-width:1281px) {
    .contactForm {
        padding: 0 20% 0 21.875%
    }
}

@media screen and (max-width:768px) {
    .contactForm__body {
        padding: 68px 0 90px
    }
}

@media screen and (min-width:769px) {
    .contactForm__body {
        margin: 0 auto;
        padding: 0 50px 120px;
        max-width: 744px
    }
}

@media screen and (min-width:1025px) {
    .contactForm__body {
        margin: 0 auto 0 0
    }
}

@media screen and (min-width:1281px) {
    .contactForm__body {
        margin: 0 auto
    }
}

.contactForm__heading {
    text-align: center
}

@media screen and (max-width:768px) {
    .contactForm__heading {
        margin-bottom: 5px;
        letter-spacing: .2em;
        font-size: 25px
    }
}

@media screen and (min-width:769px) {
    .contactForm__heading {
        margin-bottom: 8px;
        padding-top: 85px;
        font-size: 28px
    }
}

@media screen and (max-width:768px) {
    .contactForm__subheading {
        margin-bottom: 15px;
        letter-spacing: .2em
    }
}

@media screen and (min-width:769px) {
    .contactForm__subheading {
        width: 165px;
        letter-spacing: .2em;
        font-size: 14px
    }
}

.contactForm__text {
    text-align: center
}

@media screen and (max-width:768px) {
    .contactForm__text {
        letter-spacing: .17em;
        font-size: 14px
    }
}

@media screen and (min-width:769px) {
    .contactForm__text {
        letter-spacing: .2em
    }
}

@media screen and (max-width:768px) {
    .contactForm__text--link {
        letter-spacing: .2em;
        font-size: 14px
    }
}

@media screen and (min-width:769px) {
    .contactForm__text--link {
        position: relative;
        top: 7px;
        letter-spacing: .2em;
        font-size: 12px
    }
}

@media screen and (min-width:769px) {
    .contactForm__text--link a {
        padding-right: 26px;
        transition: opacity .8s cubic-bezier(.215, .61, .355, 1)
    }

    .contactForm__text--link a:hover {
        opacity: .8
    }
}

.contactForm__annotation {
    padding-left: 1em;
    text-indent: -1em;
    letter-spacing: .17em;
    font-size: 12px;
    line-height: 2.1
}

.contactForm__annotation:before {
    content: "・"
}

.contactForm__annotation+.contactForm__annotation {
    margin-top: 6px
}

@media screen and (max-width:768px) {
    .contactForm__items+.contactForm__items {
        margin-top: 24px
    }
}

@media screen and (min-width:769px) {
    .contactForm__items {
        display: table;
        margin-top: 41px
    }

    .contactForm__items+.contactForm__items {
        margin-top: 30px
    }
}

@media screen and (min-width:769px) {
    .contactForm__item {
        display: table-cell;
        vertical-align: middle
    }
}

@media screen and (max-width:768px) {
    .contactForm__input {
        width: 100%;
        height: 45px;
        letter-spacing: .2em
    }
}

@media screen and (min-width:769px) {
    .contactForm__input {
        width: 480px;
        height: 47px
    }
}

.contactForm__select {
    position: relative;
    padding-left: 1em;
    border: none;
    height: 45px;
    background-color: #fff;
    line-height: 45px
}

@media screen and (max-width:768px) {
    .contactForm__select {
        width: 100%;
        letter-spacing: .2em
    }
}

@media screen and (min-width:769px) {
    .contactForm__select {
        width: 480px;
        height: 47px
    }
}

@media screen and (max-width:768px) {
    .contactForm__textarea {
        width: 100%;
        height: 170px;
        letter-spacing: .2em
    }
}

@media screen and (min-width:769px) {
    .contactForm__textarea {
        width: 480px;
        height: 197px
    }
}

.contactForm__button {
    display: block;
    border: 1px solid;
    height: 45px;
    background-color: hsla(0, 0%, 100%, 0)
}

@media screen and (max-width:768px) {
    .contactForm__button {
        margin: 27px auto 0;
        width: 262px;
        letter-spacing: .3em;
        line-height: 45px
    }
}

@media screen and (min-width:769px) {
    .contactForm__button {
        margin: 42px auto 0;
        width: 236px
    }
}

.contactForm__annotations {
    margin: 54px 0 30px
}

.contact__request {
    text-align: center;
    font-size: 14px
}

.contact__request dt {
    letter-spacing: .15em
}

@media screen and (max-width:768px) {
    .contact__request {
        padding: 56px 0 65px;
        letter-spacing: .1em
    }

    .contact__request dd {
        margin-top: 18px;
        letter-spacing: .2em
    }
}

@media screen and (min-width:769px) {
    .contact__request {
        padding: 96px 0
    }

    .contact__request dt {
        font-size: 16px
    }

    .contact__request dd {
        letter-spacing: .17em
    }
}

.contact__telephone {
    letter-spacing: .1em !important
}

.contact__telephone a {
    margin-right: 20px !important
}

.contact__telephone:before {
    content: "";
    display: inline-block;
    margin-right: .5em;
    /* background: url(../img/contact/telephone.png) 0 no-repeat; */
    background-size: cover;
    vertical-align: sub
}

@media screen and (max-width:768px) {
    .contact__telephone {
        margin-top: 20px;
        letter-spacing: .1em;
        font-size: 35px
    }

    .contact__telephone:before {
        width: 43px;
        height: 43px
    }
}

@media screen and (min-width:769px) {
    .contact__telephone {
        position: relative;
        margin: 21px;
        margin-top: 7px;
        font-size: 50px
    }

    .contact__telephone:before {
        width: 53px;
        height: 53px
    }
}


.QAContext {
    text-indent: 0px;
    margin-top: 20px;
}

.QAContext h6 {
    font-size: 14px;
    font-weight: 600;
}

.QAContext .accordion-header .accordion-button {
    font-size: 14px;
}

.accordion-button:not(.collapsed) {
    color: white;
    background: gray;
}

.accordion-button:focus {
    box-shadow: none;
}

.accordion-body {
    font-size: 14px;
    line-height: 2;
}