@charset "utf-8";


/**
 * SP用
 */
@media ( width < 768px ) {
    .br-pc {
        display: none;
    }
    .br-sp {
        display: block;
    }

    .ws-section {
        margin: 0 auto;
        padding: 0;
        width: 100%;
    }
    .ws-section .faq-h2 {
        position: relative;
        margin: 0 0 1.5em;
        font-size: 6.0vw;
        font-weight: 600;
        text-align: center;
        line-height: 1.5;
    }
    .ws-section .faq-h2::before {
        position: absolute;
        content: "";
        top: calc( 100% + 10px );
        left: calc( 50% - 10.0vw );
        width: 20.0vw;
        height: 1px;
        background: #adadad;
    }
    .ws-section .faq-h2::after {
        position: absolute;
        content: attr(data-eng);
        top: calc( 100% + 20px );
        left: 0;
        width: 100%;
        font-size: 2.8vw;
        font-weight: 600;
        text-align: center;
    }

    #faq-service {
        margin: 0 auto;
        padding: 16.0vw 0 16.0vw;
        width: 100%;
        background: #f4f4f4;
    }
    .faq-service-grid {
        margin: 12.0vw auto 0;
        padding: 0;
        width: 90%;
        display: grid;
        grid-template-columns: 1fr;
        gap: 4.0vw 0;
    }
    .faq-service-grid .faq-service-item {
        margin: 0;
        padding: 4.0vw;
        width: 100%;
        background: #fff;
        border: 1px solid #d0d0d0;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0 4.0vw;
    }
    .faq-service-grid .faq-service-item .icon {
        margin: 0;
        padding: 0;
        width: 20%;
        height: auto;
        aspect-ratio: 1 / 1;
        flex: 0 0 20%;
    }
    .faq-service-grid .faq-service-item .icon img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }
    .faq-service-grid .faq-service-item .txt {
        margin: 0;
        padding: 0;
        width: auto;
        flex: 1 1 auto;
        color: #111;
        font-size: 4.0vw;
    }
    .faq-service-grid .faq-service-item .txt .strong {
        color: #e24b4b;
        font-weight: 700;
    }
    .faq-service-grid .faq-service-item::after {
        content: "";
        width: 0.6em;
        height: auto;
        aspect-ratio: 1 / 1;
        border-right: 2px solid #e24b4b;
        border-bottom: 2px solid #e24b4b;
        rotate: -45deg;
        flex: 0 0 0.6em;
    }

    #faq-contents {
        margin: 0 auto;
        padding: 12.0vw 0 12.0vw;
        width: 100%;
        background: #fff;
    }
    .faq-contents-grid {
        margin: 16.0vw auto 0;
        padding: 0;
        width: 90%;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 4.0vw 4.0vw;
    }
    .faq-contents-grid .faq-contents-item {
        margin: 0;
        padding: 4.0vw 0;
        width: 100%;
        background: #fff;
        border: 1px solid;
        border-image: linear-gradient(to bottom, #fbebdf, #f6d1c5 ) 1;
    }
    .faq-contents-grid .faq-contents-item .icon {
        margin: 0 auto;
        padding: 0;
        width: 60%;
        height: auto;
        aspect-ratio: 1 / 1;
    }
    .faq-contents-grid .faq-contents-item .icon img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }
    .faq-contents-grid .faq-contents-item .txt {
        margin: 0.8em 0 0;
        padding: 0;
        width: 100%;
        color: #111;
        font-size: 4.0vw;
        text-align: center;
    }

    #faq-focus {
        margin: 0 auto;
        padding: 12.0vw 0 8.0vw;
        width: 100%;
        background: #f4f4f4;
    }
    #faq-focus .faq-focus-box {
        margin: 0 auto;
        padding: 8.0vw 6.0vw;
        width: 90%;
        background: #fff;
        border: 1px solid #ddd;
    }
    #faq-focus .faq-focus-box > h2 {
        margin: 0 auto 4.0vw;
        padding: 0;
        width: 100%;
        font-size: 6.0vw;
        font-weight: 600;
        text-align: center;
    }
    #faq-focus .faq-focus-flex {
        margin: 4.0vw auto 0;
        padding: 4.0vw 0 0;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 4.0vw 0;
        border-top: 1px solid #ddd;
    }
    #faq-focus .faq-focus-flex .faq-focus-l,
    #faq-focus .faq-focus-flex .faq-focus-r {
        margin: 0;
        padding: 0;
        width: 100%;
    }
    #faq-focus .faq-focus-flex .faq-focus-l > a,
    #faq-focus .faq-focus-flex .faq-focus-r > a {
        display: block;
        position: relative;
        margin: 0;
        padding: 0 0 0 2.4em;
        color: #111;
        font-size: 3.6vw;
        text-align: left;
    }
    #faq-focus .faq-focus-flex .faq-focus-l > a + a,
    #faq-focus .faq-focus-flex .faq-focus-r > a + a {
        margin-top: 4.0vw;
    }
    #faq-focus .faq-focus-flex .faq-focus-l > a::before,
    #faq-focus .faq-focus-flex .faq-focus-r > a::before {
        position: absolute;
        content: "";
        top: 0;
        left: 0;
        width: 1.6em;
        height: auto;
        aspect-ratio: 1 / 1;
        background: url(/wp-content/themes/xeory_extension/qa/img/icon_Q.svg) no-repeat center / contain;
    }

    .qa_contents_main {
        margin-bottom: 0;
    }
    #contents_qa::before {
        content: none;
    }
    .qa_contents_header {
        background: transparent;
    }

    .qa_contents_main .qa_contents_ttl {
        position: relative;
        margin: 0 auto;
        padding: 30px 0 10px;
        width: max-content;
        border: 0;
    }
    .qa_contents_main .qa_contents_ttl > span {
        display: inline-block;
    }
    .qa_contents_main .qa_contents_ttl > span::before {
        content: "- ";
        color: #c95353;
    }
    .qa_contents_main .qa_contents_ttl > span::after {
        content: " -";
        color: #c95353;
    }
    .qa_contents_main .qa_contents_ttl > strong {
        font-size: 2.1em;
    }

    .qa_contents_main .qa_contents_ttl::before {
        position: absolute;
        content: "";
        top: calc( 50% - 2.0em + 15px );
        right: calc( 100% + 1.0em );
        margin: 0;
        padding: 0;
        display: block;
        width: 4.0em;
        height: auto;
        aspect-ratio: 1 / 1;
    }
    .qa_contents_main:nth-child(2) .qa_contents_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-1.svg) no-repeat center / contain;
    }
    .qa_contents_main:nth-child(3) .qa_contents_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-2.svg) no-repeat center / contain;
    }
    .qa_contents_main:nth-child(4) .qa_contents_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-3.svg) no-repeat center / contain;
    }

    .qa_contents_subttl {
        margin: 0 45px 10px;
        padding: 0 0 0 0.5em;
        width: calc( 100% - 45px * 2 );
        font-size: 1.8em;
        font-weight: 700;
        text-align: left;
        border-left: 4px solid #c95353;;
    }

    .qa_contents_header .qa_contents_nav_wrap {
        margin: 0 auto;
        padding: 0;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 2.0vw 0;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav {
        margin: 0;
        width: 100%;
        background: #fff;
        border: 1px solid #b1b1b1;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav .qa_contents_nav_ttl {
        margin: 0;
        padding: 2.0vw 0;
        width: 100%;
        text-align: center;
        background: #fcece0;
        border-bottom: 1px solid #b1b1b1;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav .qa_contents_nav_ttl::before {
        content: "";
        margin: 0 20px 0 0;
        padding: 0;
        top: auto;
        display: block;
        width: 4.0em;
        height: auto;
        aspect-ratio: 1 / 1;
        border: 0;
        transform: none;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav:nth-child(1) .qa_contents_nav_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-1.svg) no-repeat center / contain;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav:nth-child(2) .qa_contents_nav_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-2.svg) no-repeat center / contain;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav:nth-child(3) .qa_contents_nav_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-3.svg) no-repeat center / contain;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav .qa_contents_nav_ttl span {
        font-size: 150%;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav .qa_contents_nav_list {
        margin: 0;
        padding: 2.0vw;
        width: 100%;
        background: #fff;
    }
    .qa_contents_entry {
        padding: 0 2.0vw 0;
        background: #fff6ef;
        border: 1px solid #ddd;
    }
    .qa_contents_entry_wrap {
        padding-top: 0;
    }
    .qa_contents_entry_ttl {
        color: #c95353;
        background: transparent;
    }
    .qa_contents_entry_body {
        background: transparent;
        border: 0;
    }
    .qa_contents_entry_relation {
    }
    .qa_contents_entry_relation h4 {
        position: relative;
        margin: 0 auto 1.5em 0;
        padding: 0.5em 1.0em;
        width: max-content;
        color: #fff;
        font-size: 2.8vw;
        font-weight: 600;
        line-height: 1.0;
        background: #c95353;
    }
    .qa_contents_entry_relation h4::after {
        position: absolute;
        content: "";
        top: calc( 100% - 1px );
        left: calc( 50% - 0.5em );
        width: 1.0em;
        height: 0.7em;
        background: #c95353;
        clip-path: polygon( 0 0, 100% 0, 50% 100% );
    }
    .qa_contents_entry_relation .relation_entry .link_card {
        margin: 0 0 15px;
        width: 100%;
    }

    .qa_contents_entry_relation .relation_entry .link_card .text .cat {
        color: #c95353;
        background: #fff;
        border: 1px solid #c95353;;
        transition: color 0.2s ease, background 0.2s ease;
    }
    .qa_contents_entry_relation .relation_entry .link_card .text .cat a {
        color: #c95353;
        transition: color 0.2s ease, background 0.2s ease;
    }
    .qa_contents_entry_relation .relation_entry .link_card .text .cat:hover {
        background: #c95353;
    }
    .qa_contents_entry_relation .relation_entry .link_card .text .cat:hover a {
        color: #fff;
    }

    .ws-faq-cta {
        margin: 0 auto;
        padding: 8.0vw 0;
        width: 100%;
        background: #c64f4c;
    }
    .ws-faq-cta .ws-faq-cta-box {
        margin: 0 auto;
        padding: 6.0vw 0;
        width: 90%;
        background: #fff;
    }
    .ws-faq-cta .ws-faq-cta-box > p {
        margin: 0 auto 1.0em;
        padding: 0;
        width: 90%;
        color: #c95353;
        font-size: 4.6vw;
        font-weight: 600;
        text-align: center;
        line-height: 1.2;
    }
}


/**
 * PC用
 */
@media ( width >= 768px ) {
    .br-pc {
        display: block;
    }
    .br-sp {
        display: none;
    }

    .ws-section {
        margin: 0 auto;
        padding: 0;
        width: 100%;
    }
    .ws-section .faq-h2 {
        position: relative;
        margin: 0 0 1.5em;
        font-size: 30px;
        font-weight: 600;
        text-align: center;
        line-height: 1.5;
    }
    .ws-section .faq-h2::before {
        position: absolute;
        content: "";
        top: calc( 100% + 10px );
        left: calc( 50% - 67px );
        width: 134px;
        height: 1px;
        background: #adadad;
    }
    .ws-section .faq-h2::after {
        position: absolute;
        content: attr(data-eng);
        top: calc( 100% + 20px );
        left: 0;
        width: 100%;
        font-size: 14px;
        font-weight: 600;
        text-align: center;
    }

    #faq-service {
        margin: 0 auto;
        padding: 90px 0 120px;
        width: 100%;
        background: #f4f4f4;
    }
    .faq-service-grid {
        margin: 80px auto 0;
        padding: 0;
        width: 90%;
        max-width: 1100px;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 24px 24px;
    }
    .faq-service-grid .faq-service-item {
        margin: 0;
        padding: 24px;
        width: 100%;
        background: #fff;
        border: 1px solid #d0d0d0;
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0 20px;
    }
    .faq-service-grid .faq-service-item .icon {
        margin: 0;
        padding: 0;
        width: calc( 110 * min( 90vw, 1100px ) / 1100 );
        height: auto;
        aspect-ratio: 1 / 1;
        flex: 0 0 calc( 110 * min( 90vw, 1100px ) / 1100 );
    }
    .faq-service-grid .faq-service-item .icon img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }
    .faq-service-grid .faq-service-item .txt {
        margin: 0;
        padding: 0;
        width: auto;
        flex: 1 1 auto;
        color: #111;
        font-size: 22px;
    }
    .faq-service-grid .faq-service-item .txt .strong {
        color: #e24b4b;
        font-weight: 700;
    }
    .faq-service-grid .faq-service-item::after {
        content: "";
        width: 0.6em;
        height: auto;
        aspect-ratio: 1 / 1;
        border-right: 2px solid #e24b4b;
        border-bottom: 2px solid #e24b4b;
        rotate: -45deg;
        flex: 0 0 0.6em;
    }

    #faq-contents {
        margin: 0 auto;
        padding: 110px 0 100px;
        width: 100%;
        background: #fff;
    }
    .faq-contents-grid {
        margin: 80px auto 0;
        padding: 0;
        width: 90%;
        max-width: 1100px;
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 22px 22px;
    }
    .faq-contents-grid .faq-contents-item {
        margin: 0;
        padding: 35px 0;
        width: 100%;
        background: #fff;
        border: 1px solid;
        border-image: linear-gradient(to bottom, #fbebdf, #f6d1c5 ) 1;
    }
    .faq-contents-grid .faq-contents-item .icon {
        margin: 0 auto;
        padding: 0;
        width: calc( 163 * min( 90vw, 1100px ) / 1100 );
        height: auto;
        aspect-ratio: 1 / 1;
    }
    .faq-contents-grid .faq-contents-item .icon img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }
    .faq-contents-grid .faq-contents-item .txt {
        margin: 0.8em 0 0;
        padding: 0;
        width: 100%;
        color: #111;
        font-size: 24px;
        text-align: center;
    }

    #faq-focus {
        margin: 0 auto;
        padding: 116px 0 77px;
        width: 100%;
        background: #f4f4f4;
    }
    #faq-focus .faq-focus-box {
        margin: 0 auto;
        padding: 70px 50px;
        width: 90%;
        max-width: 1100px;
        background: #fff;
        border: 1px solid #ddd;
    }
    #faq-focus .faq-focus-box > h2 {
        margin: 0 auto 1.0em;
        padding: 0;
        width: 100%;
        font-size: 30px;
        font-weight: 600;
        text-align: center;
    }
    #faq-focus .faq-focus-flex {
        margin: 30px auto 0;
        padding: 30px 0 0;
        width: 100%;
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        border-top: 1px solid #ddd;
    }
    #faq-focus .faq-focus-flex .faq-focus-l,
    #faq-focus .faq-focus-flex .faq-focus-r {
        margin: 0;
        padding: 0;
        width: calc( 50% - 20px );
    }
    #faq-focus .faq-focus-flex .faq-focus-l > a,
    #faq-focus .faq-focus-flex .faq-focus-r > a {
        display: block;
        position: relative;
        margin: 0;
        padding: 0 0 0 2.0em;
        color: #111;
        font-size: 18px;
        text-align: left;
    }
    #faq-focus .faq-focus-flex .faq-focus-l > a + a,
    #faq-focus .faq-focus-flex .faq-focus-r > a + a {
        margin-top: 20px;
    }
    #faq-focus .faq-focus-flex .faq-focus-l > a::before,
    #faq-focus .faq-focus-flex .faq-focus-r > a::before {
        position: absolute;
        content: "";
        top: 0;
        left: 0;
        width: 1.5em;
        height: auto;
        aspect-ratio: 1 / 1;
        background: url(/wp-content/themes/xeory_extension/qa/img/icon_Q.svg) no-repeat center / contain;
    }

    .qa_contents_main {
        margin-bottom: 0;
    }
    #contents_qa::before {
        content: none;
    }
    .qa_contents_header {
        background: transparent;
    }

    .qa_contents_main .qa_contents_ttl {
        position: relative;
        margin: 0 auto;
        padding: 60px 0 30px;
        width: max-content;
        border: 0;
    }
    .qa_contents_main .qa_contents_ttl > span {
        display: inline-block;
    }
    .qa_contents_main .qa_contents_ttl > span::before {
        content: "- ";
        color: #c95353;
    }
    .qa_contents_main .qa_contents_ttl > span::after {
        content: " -";
        color: #c95353;
    }
    .qa_contents_main .qa_contents_ttl > strong {
        font-size: 2.1em;
    }

    .qa_contents_main .qa_contents_ttl::before {
        position: absolute;
        content: "";
        top: calc( 50% - 3.0em + 20px );
        right: calc( 100% + 1.0em );
        margin: 0;
        padding: 0;
        display: block;
        width: 6.0em;
        height: auto;
        aspect-ratio: 1 / 1;
    }
    .qa_contents_main:nth-child(2) .qa_contents_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-1.svg) no-repeat center / contain;
    }
    .qa_contents_main:nth-child(3) .qa_contents_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-2.svg) no-repeat center / contain;
    }
    .qa_contents_main:nth-child(4) .qa_contents_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-3.svg) no-repeat center / contain;
    }

    .qa_contents_subttl {
        margin: 0 45px 10px;
        padding: 0 0 0 0.5em;
        width: calc( 100% - 45px * 2 );
        font-size: 1.8em;
        font-weight: 700;
        text-align: left;
        border-left: 4px solid #c95353;;
    }

    .qa_contents_header .qa_contents_nav_wrap {
        padding-top: 0;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav {
        background: #fff;
        border: 1px solid #b1b1b1;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav .qa_contents_nav_ttl {
        margin: 0;
        padding: 18px 0;
        width: 100%;
        text-align: center;
        background: #fcece0;
        border-bottom: 1px solid #b1b1b1;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav .qa_contents_nav_ttl::before {
        content: "";
        margin: 0 10px 0 0;
        padding: 0;
        top: auto;
        display: block;
        width: 4.0em;
        height: auto;
        aspect-ratio: 1 / 1;
        border: 0;
        transform: none;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav:nth-child(1) .qa_contents_nav_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-1.svg) no-repeat center / contain;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav:nth-child(2) .qa_contents_nav_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-2.svg) no-repeat center / contain;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav:nth-child(3) .qa_contents_nav_ttl::before {
        background: url(/wp-content/themes/xeory_extension/faq/img/faq-icon-3-3.svg) no-repeat center / contain;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav .qa_contents_nav_ttl span {
        font-size: 150%;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav .qa_contents_nav_list {
        margin: 0;
        padding: 18px;
        width: 100%;
        color: #111;
        background: #fff;
    }
    .qa_contents_header .qa_contents_nav_wrap .qa_contents_nav .qa_contents_nav_list a {
        color: #111;
    }
    .qa_contents_entry {
        padding: 0 20px 0;
        background: #fff6ef;
        border: 1px solid #ddd;
    }
    .qa_contents_entry_wrap {
        padding-top: 0;
    }
    .qa_contents_entry_ttl {
        color: #c95353;
        background: transparent;
    }
    .qa_contents_entry_body {
        background: transparent;
        border: 0;
    }
    .qa_contents_entry_relation {
    }
    .qa_contents_entry_relation h4 {
        position: relative;
        margin: 0 auto 1.5em 0;
        padding: 0.5em 1.0em;
        width: max-content;
        color: #fff;
        font-size: 13px;
        font-weight: 600;
        line-height: 1.0;
        background: #c95353;
    }
    .qa_contents_entry_relation h4::after {
        position: absolute;
        content: "";
        top: calc( 100% - 1px );
        left: calc( 50% - 0.5em );
        width: 1.0em;
        height: 0.7em;
        background: #c95353;
        clip-path: polygon( 0 0, 100% 0, 50% 100% );
    }
    .qa_contents_entry_relation .relation_entry .link_card {
        margin: 0 0 15px;
        width: calc( 50% - 20px );
    }

    .qa_contents_entry_relation .relation_entry .link_card .text .cat {
        color: #c95353;
        background: #fff;
        border: 1px solid #c95353;;
        transition: color 0.2s ease, background 0.2s ease;
    }
    .qa_contents_entry_relation .relation_entry .link_card .text .cat a {
        color: #c95353;
        transition: color 0.2s ease, background 0.2s ease;
    }
    .qa_contents_entry_relation .relation_entry .link_card .text .cat:hover {
        background: #c95353;
    }
    .qa_contents_entry_relation .relation_entry .link_card .text .cat:hover a {
        color: #fff;
    }

    .ws-faq-cta {
        margin: 0 auto;
        padding: 50px 0;
        width: 100%;
        background: #c64f4c;
    }
    .ws-faq-cta .ws-faq-cta-box {
        margin: 0 auto;
        padding: 40px 0;
        width: 90%;
        max-width: 1100px;
        background: #fff;
    }
    .ws-faq-cta .ws-faq-cta-box > p {
        margin: 0 auto 1.0em;
        padding: 0;
        width: 90%;
        color: #c95353;
        font-size: 24px;
        font-weight: 600;
        text-align: center;
    }
}
