/* --------------------
 Reason
-------------------- */
.reason__overview {
    margin: 0 0 80px;
}

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

.reason__overview-container {
    container: container/inline-size;
    width: 100%;
}

.reason__overview-container-inner {
    padding: 0;
}

@media (min-width: 992px) {
    .reason__overview-container-inner {
        padding: 0 calc(var(--global-contact-width) + 20px) 0 calc(50cqw - 510px);
    }
}

@container container (min-width: 1400px) {
    .reason__overview-container-inner {
        padding: 0 calc(var(--global-contact-width) + 20px);
    }
}

.reason__overview-container-inner-contents {
    margin: 0 auto;
    max-width: 1020px;
    padding: 0 16px;
    width: 100%;
}

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

@container container (min-width: 1400px) {
    .reason__overview-container-inner-contents {
        margin: 0 auto;
    }
}

.reason__overview__main {
    display: flex;
    flex-flow: column nowrap;
    gap: 30px;
}

@media (min-width: 768px) {
    .reason__overview__main {
        align-items: flex-start;
        flex-direction: row;
    }
}

@media (min-width: 1240px) {
    .reason__overview__main {
        gap: 40px;
    }
}

.reason__overview__main__contents {
    width: 100%;
}

@media (min-width: 768px) {
    .reason__overview__main__contents {
        width: calc(60% - 30px);
    }
}

@media (min-width: 992px) {
    .reason__overview__main__contents {
        width: calc(55% - 30px);
    }
}

@media (min-width: 1240px) {
    .reason__overview__main__contents {
        width: calc(50% - 40px);
    }
}

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

.reason__overview__main__contents__title {
    font-family: var(--serif);
    font-size: var(--fs20);
    font-weight: 200;
    letter-spacing: 0.12em;
    line-height: 1.8;
    margin: 0 0 30px;
}

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

@media (min-width: 1240px) {
    .reason__overview__main__contents__title {
        font-size: var(--fs24);
    }
}

.reason__overview__main__contents__content p {
    font-size: var(--fs14);
    letter-spacing: 0.1em;
    line-height: 2;
    margin: 0 0 1.5em;
}

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

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

.reason__overview__main__fig {
    width: 100%;
}

@media (min-width: 768px) {
    .reason__overview__main__fig {
        width: 40%;
    }
}

@media (min-width: 992px) {
    .reason__overview__main__fig {
        width: 45%;
    }
}

@media (min-width: 1240px) {
    .reason__overview__main__fig {
        width: 50%;
    }
}

.reason__overview__main__fig img {
    border-radius: 15px;
}

@media (max-width: 767px) {
    .reason__overview__main__fig img {
        width: 100%;
    }
}

@media (min-width: 768px) {
    .reason__overview__main__fig img {
        border-radius: 30px;
    }
}

.reason__detail-container {
    container: container/inline-size;
    width: 100%;
}

.reason__detail-container-inner {
    padding: 0;
}

@media (min-width: 992px) {
    .reason__detail-container-inner {
        padding: 0 calc(var(--global-contact-width) + 20px) 0 calc(50cqw - 510px);
    }
}

@container container (min-width: 1400px) {
    .reason__detail-container-inner {
        padding: 0 calc(var(--global-contact-width) + 20px);
    }
}

.reason__detail-container-inner-contents {
    margin: 0 auto;
    max-width: 1020px;
    padding: 0 16px;
    width: 100%;
}

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

@container container (min-width: 1400px) {
    .reason__detail-container-inner-contents {
        margin: 0 auto;
    }
}

.reason__detail__title {
    font-family: var(--serif);
    font-size: var(--fs24);
    font-weight: 200;
    letter-spacing: 0.12em;
    line-height: 1.2;
    margin: 0 auto 30px;
    padding: 30px 0px;
    position: relative;
    text-align: center;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
}

@media (min-width: 768px) {
    .reason__detail__title {
        font-size: var(--fs30);
        margin: 0 auto 60px;
        padding: 40px 80px;
    }
}

.reason__detail__title:before {
    background-image: url(../images/commons/com-title-corner-left-top.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    display: block;
    height: 22px;
    left: -10px;
    position: absolute;
    top: 0;
    width: 39px;
}

@media (min-width: 768px) {
    .reason__detail__title:before {
        height: 44px;
        width: 78px;
    }
}

.reason__detail__title:after {
    background-image: url(../images/commons/com-title-corner-right-bottom.svg);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    bottom: 0;
    content: "";
    display: block;
    height: 22px;
    position: absolute;
    right: -10px;
    width: 39px;
}

@media (min-width: 768px) {
    .reason__detail__title:after {
        height: 44px;
        width: 78px;
    }
}

.reason__detail__item {
    display: flex;
    flex-flow: column nowrap;
    gap: 16px 40px;
    margin: 0 0 40px;
}

@media (min-width: 768px) {
    .reason__detail__item {
        align-items: center;
        flex-direction: row;
        margin: 0 0 30px;
    }
}

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

.reason__detail__item__fig {
    width: 100%;
}

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

.reason__detail__item__fig img {
    border-radius: 15px;
}

@media (max-width: 767px) {
    .reason__detail__item__fig img {
        width: 100%;
    }
}

@media (min-width: 768px) {
    .reason__detail__item__fig img {
        border-radius: 30px;
    }
}

.reason__detail__item__main {
    width: 100%;
}

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

.reason__detail__item__main__title {
    font-size: var(--fs20);
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: 1.8;
    margin: 0 0 20px;
}

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

.reason__detail__item__main__content p {
    font-size: var(--fs14);
    letter-spacing: 0.1em;
    line-height: 2;
    margin: 0 0 1.5em;
}

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

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