@charset "UTF-8";

.section ul li {
    list-style: disc inside;
}


/* for Desktop */
@media only screen and (min-width: 481px) {
    .section {
        margin-bottom: 100px;
    }
    .section p:not(:last-child),
    .section ul:not(:last-child),
    .section dl dd:not(:last-child),
    .section table:not(:last-child) {
        margin-bottom: 1.5rem;
    }

    #sg_flow {
        padding: 0px;
        display: flex;
        justify-content: space-between;
        flex-wrap: wrap;
        margin-top: 0px;
        margin-right: 0px;
        margin-bottom: 80px;
        margin-left: 0px;
    }
    #sg_flow dl {
        border: 2px solid #a37d56;
        padding: 30px 24px;
        height: auto;
        width: 32%;
        margin-top: 0px;
        margin-right: 0px;
        margin-bottom: 20px;
        margin-left: 0px;
    }
    #sg_flow dl dt {
        font-size: 110%;
        font-weight: bold;
        color: #a37d56;
        padding: 0px;
        margin-top: 0px;
        margin-right: 0px;
        margin-bottom: 10px;
        margin-left: 0px;
    }
    #sg_flow dl dt span {
        color: #333;
        font-size: 70%;
    }
    #sg_flow dl dd {
        padding: 0px;
        margin-top: 0px;
        margin-right: 0px;
        margin-bottom: 20px;
        margin-left: 0px;
    }
    #sg_flow dl dd img {
        width: 100%;
    }
    #sg_flow dl p {
        font-size: 95%;
    }
    #sg_flow dl p:not(:last-child) {
        margin-bottom: .5rem;
    }
    #sg_flow dl p.is-small {
        line-height: 1.6;
        font-size: 12.5px;
    }

    .section .title {
        font-size: 120%;
        font-weight: bold;
        color: #34805a;
        padding: 0px;
        margin-top: 0px;
        margin-right: 0px;
        margin-bottom: 20px;
        margin-left: 0px;
    }

    .section.--feature{
        background-color: #f5f5f5;
        margin-top: 100px;
        padding: 100px 0;
        position: relative;
    }
    .section.--feature::after{
        content: "";
        width: 100vw;
        height: 100%;
        background-color: #f5f5f5;
        position: absolute;
        top: 0;
        left: calc((100vw - 100%) / -2);
        z-index: -1;
        pointer-events: none
    }
    #sg_feature{
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 40px;
    }
    /* #sg_feature dl:not(:last-child){
        margin-bottom: 50px;
    } */
    #sg_feature .feature-box:nth-child(2){
        margin-top: 60px;
    }
    #sg_feature .feature-box-title{
        font-size: 120%;
        font-weight: bold;
        color: #34805a;
        margin: 24px 0;
        text-align: center;
    }
    #sg_feature .image{
        max-width: 100%;
    }
    #sg_feature .image img{
        width: 100%;
    }

}

/* for Mobile */
@media only screen and (max-width: 480px) {
    .section {
        margin-bottom: 100px;
        padding-left: 1rem;
        padding-right: 1rem;
    }
    .section p:not(:last-child),
    .section ul:not(:last-child),
    .section dl dd:not(:last-child),
    .section table:not(:last-child) {
        margin-bottom: 1.5rem;
    }
    #sg_flow {
        padding: 0px;
        margin-top: 0px;
        margin-right: 0px;
        margin-bottom: 80px;
        margin-left: 0px;
    }
    #sg_flow dl {
        border: 2px solid #a37d56;
        height: auto;
        width: 90%;
        margin-top: 0px;
        margin-right: auto;
        margin-bottom: 30px;
        margin-left: auto;
        padding-top: 30px;
        padding-right: 20px;
        padding-bottom: 30px;
        padding-left: 20px;
    }
    #sg_flow dl dt {
        font-size: 110%;
        font-weight: bold;
        color: #a37d56;
        padding: 0px;
        margin-top: 0px;
        margin-right: 0px;
        margin-bottom: 10px;
        margin-left: 0px;
    }
    #sg_flow dl dt span {
        color: #333;
        font-size: 70%;
    }
    #sg_flow dl dd {
        padding: 0px;
        margin-top: 0px;
        margin-right: 0px;
        margin-bottom: 20px;
        margin-left: 0px;
    }
    #sg_flow dl dd img {
        width: 100%;
    }
    #sg_flow dl p {
        font-size: 95%;
    }
    #sg_flow dl p:not(:last-child) {
        margin-bottom: .5rem;
    }
    #sg_flow dl p.is-small {
        line-height: 1.6;
        font-size: 12.5px;
    }

    .section .title {
        font-size: 120%;
        font-weight: bold;
        color: #34805a;
        padding: 0px;
        margin-top: 0px;
        margin-right: 0px;
        margin-bottom: 20px;
        margin-left: 0px;
    }

    .section.--feature{
        background-color: #f5f5f5;
        padding: 100px 1rem;
    }
    #sg_feature .feature-box:not(:last-child){
        margin-bottom: 50px;
    }
    #sg_feature .feature-box-title{
        font-size: 120%;
        font-weight: bold;
        color: #34805a;
        margin: 24px 0 16px;
        text-align: center;
    }
    #sg_feature .image{
        max-width: 100%;
        width: 80%;
        margin: 0 auto;
    }
    #sg_feature .image img{
        width: 100%;
    }
}

