.cmn_wrap {
    padding: 0 10px;
}
.article__wrap {
    padding: 0 20px;
}
.article__txt {
    font-size: 90%;
    line-height: 1.6;
    margin-bottom: 20px;
}
.article__txt a {
    word-break: break-all;
}
.article__lead {
    margin-bottom: 45px;
}
.article__travel_area {
    margin-top: 10px;
    margin-bottom: 25px;
    text-align: right;
}
.article__travel {
    display: inline-block;
    padding-right: 40px;
    padding-bottom: 5px;
    font-size: 65%;
    margin-right: 10px;
}
.article__travel.genre {
    background: url(/data/feature/ethical_travel/img/article/boder.svg) no-repeat;
    background-size: 34vw;
    background-position: bottom right;
}
.article__travel.pink {
    background: url(/data/feature/ethical_travel/img/article/boder02.svg) no-repeat;
    background-size: 34vw;
    background-position: bottom right;
}
.article__travel.orenge {
    background: url(/data/feature/ethical_travel/img/article/boder03.svg) no-repeat;
    background-size: 34vw;
    background-position: bottom right;
}
.article__lead_top {
    text-align: center;
    font-weight: normal;
    font-size: 135%;
    line-height: 1.5;
}
.article__lead_img {
    margin: 10px auto 50px;
    max-width: 600px;
}
.pattern02 .article__flex {
    display: flex;
    flex-direction: column;
}
.pattern02 .article__box_left {
    order: 2;
    margin-bottom: 0;
}
/* .pattern02 .article__box_right .article__txt,
.pattern02 .article__box_left .article__txt {
    margin-bottom: 0;
} */
.pattern02 .article__box_left .article__txt {
    margin-bottom: 0;
}
.article__main_box {
    margin-bottom: 45px;
}
.article__main_box:last-child {
    margin-bottom: 0;
}
.article__box_left {
    margin-bottom: 20px;
}
.article__img {
    /* margin-top: 15px; */
    margin-bottom: 20px;
}
.article__img img {
    width: auto;
}
.article__sub_ttl {
    font-size: 125%;
    line-height: 1.4;
    margin-bottom: 20px;
    font-weight: normal;
}
.pattern04 .article__flex {
    display: flex;
    flex-direction: column;
}
.pattern04 .article__box_left {
    margin-bottom: 0;
    order: 2;
}
.pattern04 .article__box_right {
    display: flex;
    flex-direction: column;
}
.pattern04 .article__box_right .article__txt {
    order: 2;
}
.article__schedule {
    margin: 75px 0;
}
.article__schedule .list {
    overflow: hidden;
    margin-bottom: 20px;
}
.article__schedule .list:last-child {
    margin-bottom: 0;
}
.article__schedule .list dt {
    float: left;
}
.article__schedule .time {
    color: #0080bf;
}
.info {
    margin-top: 45px;
}
.article__info_top {
    width: 95px;
    margin: 0 auto 20px;
}
.item01_ttl {
    width: 168px;
    margin: 0 auto;
}
.article__info {
    margin-top: 27px;
}
.article__info li {
    margin-bottom: 30px;
    border-left: 1px solid #0080bf;
    padding-left: 10px;
    position: relative;
}
.article__info_txt {
    font-size: 90%;
    line-height: 1.6;
}
.article__info_txt a {
    color: #0080bf;
    text-decoration: underline;
    font-size: 91%;
    word-break: break-all;
}
.link_btn {
    width: 25px;
    position: absolute;
    bottom: 0;
    right: 0;
}
.article__btm_btn {
    width: 275px;
    margin: 0 auto;
}

@media screen and (min-width: 768px) {
    .article__main_box {
        margin-bottom: 160px;
    }
    .article__flex {
        display: flex;
    }
    .article__box_left {
        margin-bottom: 0;
        width: calc((100% - 70px)/2);
        margin-right: 70px;
    }
    .article__box_right {
        width: calc((100% - 70px)/2);
    }
    .article__sub_ttl {
        margin-bottom: 80px;
        font-size: 230%;
    }
    .article__img {
        margin-top: 0;
        margin-bottom: 58px;
    }
    .pattern01 .article__box_right .article__txt {
        padding-left: 85px;
    }
    .pattern02 .article__flex {
        flex-direction: initial;
    }
    .pattern02 .article__box_left {
        order: initial;
    }
    .pattern02 .article__box_left .article__txt {
        padding-right: 85px;
    }
    
    .pattern04 .article__flex {
        flex-direction: initial;
    }
    .pattern04 .article__box_right .article__txt {
        padding-left: 40px;
        order: initial;
    }
    .pattern04 .article__box_right .article__txt:first-child {
        margin-bottom: 80px;
    }
    .pattern04 .article__box_left {
        order: initial;
    }
    .article__schedule {
        margin: 0;
    }
    .article__schedule .list {
        display: flex;
    }
    .article__schedule .list dt {
        width: 135px;
        float: none;
    }
    .article__schedule .list dd {
        width: calc(100% - 135px);
    }
    
    .article__btm_btn {
        width: 345px;
    }
}
@media screen and (min-width: 1024px) {
    .article__bg {
        background: url(/data/feature/ethical_travel/img/article/bg.png);
        background-size: cover;
    }
    .article__wrap {
        padding: 0;
    }
    .article__txt {
        font-size: 137%;
    }
    .article__travel_area {
        margin-top: 20px;
        margin-bottom: 40px;
    }
    .article__travel {
        padding-bottom: 10px;
        padding-right: 60px;
        font-size: 112%;
        margin-right: 0;
        background-size: 215px !important;
    }
    .article__lead {
        width: 974px;
        margin: 0 auto 185px;
    }
    .article__lead_top {
        font-size: 250%;
    }
    .article__lead_img {
        margin: 70px auto 75px;
    }
    .pattern03 .article__sub_ttl {
        text-align: center;
        width: 960px;
        margin: 0 auto 80px;
    }
    .pattern03 .article__txt {
        width: 960px;
        margin: 0 auto 65px;
    }
    .pattern03 .article__img {
        text-align: center;
    }
    .article__info {
        width: 980px;
        margin: 40px auto 0;
    }
    .article__info_top {
        width: 130px;
    }
    .item01_ttl {
        width: 281px;
    }
    .article__info li {
        padding-left: 20px;
    }
    .article__info_txt {
        font-size: 125%;
    }
    .article__info_txt a {
        color: #3e3a39;
        text-decoration: none;
    }
}