@import url('//fonts.googleapis.com/earlyaccess/notosansjapanese.css');
body {
    font-family: 'Noto Sans Japanese', 'Noto Sans CJK JP', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', Arial, Tahoma, Verdana, sans-serif;
}

.section_ttl_br {
    display: none;
}

.main_visual {
    color: #74573a;
    padding: 43px 0 40px;
    text-align: center;
}

.instagram .main_visual {
    background-image: url(/voices/campaign/2018spring/img/01-02_img/main_visual_bg2.png);
}

.ichijo .main_visual {
    background-image: url(/voices/campaign/2018spring/img/01-02_img/main_visual_bg.png);
}

.main_visual_ttl {
    margin: 0 0 32px;
}

.main_visual_txt {
    font-size: 18px;
    font-weight: bold;
    margin: 0 0 18px;
}

.main_visual_attention {
    font-size: 18px;
}

.contents {
    background-image: url(/voices/campaign/2018spring/img/01-02_img/contents_bg.png);
}

.contents_inner {
    margin: auto;
    max-width: 750px;
    padding: 40px 10px 0;
}

.link_btn {
    border: 2px solid #e3ddd8;
    border-radius: 4px;
    color: #74573a;
    display: block;
    font-size: 15px;
    font-weight: bold;
}

.link_btn.is-hover:hover {
    background-color: #74573a;
    color: #fff;
    transition: .3s;
}

.link_btn.is-hover:hover .arrow::before,
.link_btn.is-hover:hover .arrow::after {
    border-color: #fff;
}

.nav_list {
    display: flex;
    justify-content: space-between;
    margin: auto;
    max-width: 570px;
    padding: 0 0 50px;
}

.link_btn_return {
    padding: 20px 0 20px 32px;
    width: 190px;
}

.link_btn_next {
    padding: 20px 60px 20px 0;
    text-align: right;
    width: 360px;
}

.instagram .link_btn_next {
    padding: 20px 66px 20px 0;
}

.arrow {
    position: relative;
}

.arrow.return_arrow::before,
.arrow.return_arrow::after {
    transform: rotate(-45deg);
}

.arrow.return_arrow::before {
    left: -17px;
}

.arrow.return_arrow::after {
    left: -10px;
}

.arrow.next_arrow.course_link {
    width: 100%;
}

.arrow.next_arrow::before,
.arrow.next_arrow::after {
    transform: rotate(135deg);
}

.arrow.next_arrow::before {
    right: -17px;
}

.arrow.next_arrow::after {
    right: -10px;
}

.arrow::before,
.arrow::after {
    border-left: 1px solid #74573a;
    border-top: 1px solid #74573a;
    bottom: 0;
    content: '';
    height: 7px;
    margin: auto;
    position: absolute;
    top: 0;
    transition: .3s;
    width: 7px;
}

.section_ttl {
    margin: 0 0 20px;
    text-align: center;
}

.section04 {
    margin: -15px 0 0;
}

.section04 .section_ttl {
    font-size: 15px;
    line-height: 1.5;
    margin: 0 0 30px;
    font-weight: bold;
}

.media_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto 45px;
}

.section04 .media_list {
    margin: 0 auto 30px;
}

.media_txt {
    color: #333;
    font-size: 15px;
    line-height: 22px;
    margin: 15px 0 0;
}

.media_modal_txt {
    display: none;
}

.modal_main .media_modal_txt {
    display: block;
}

.modal_main .media_name {
    text-align: left;
}

.media_name {
    display: block;
    font-weight: bold;
    text-align: center;
}

.section01 .media_name {
    font-size: 22px;
}

.section02 .media_name {
    font-size: 18px;
}

.section03 .media_name {
    font-size: 16px;
}

.section01 .media_list {
    justify-content: center;
}

.section01 .media_list_item {
    max-width: 420px;
}

.section02 .media_list {
    max-width: 630px;
}

.section02 .media_list_item {
    width: 47.61904%;
}

.section03 .media_list {
    max-width: 750px;
}

.section03 .media_list_item {
    margin: 0 0 26px 0;
    width: 30.66666%;
}

.section04 .media_list_item {
    margin: 0 0 10px 0;
    width: 24%;
}

.section04 .media_txt {
    display: none;
}

.media_list_img {
    box-shadow: 2px 2px 8px 0 rgba(15, 4, 9, .1);
}

.media_img_wrap {
    cursor: pointer;
    display: block;
}

.footer-block-txt {
    color: #333;
    font-size: 22px;
    font-weight: bold;
    margin: 0 0 15px;
    text-align: center;
}

.footer-btn_link {
    border: 2px solid #ddd;
    font-size: 20px;
    margin: auto;
    padding: 28px 0 28px 40px;
    position: relative;
    text-align: center;
    transition: .2s;
    width: 400px;
}

.footer-btn_link:hover {
    opacity: .6;
}

.footer-btn_link .footer-btn-icon {
    background-image: url(/voices/campaign/2018spring/img/01-02_img/icon_insta.png);
    bottom: 0;
    height: 44px;
    left: -62px;
    margin: auto;
    position: absolute;
    top: 0;
    width: 44px;
}

.footer-btn_link .arrow.next_arrow::before,
.footer-btn_link .arrow.next_arrow::after {
    height: 10px;
    width: 10px;
}

.footer-btn_link .arrow.next_arrow::before {
    right: -20px;
}

.footer-btn {
    margin: 0 0 40px;
}

.footer_foot_txt {
    background-color: #eee;
    color: #666;
    font-size: 13px;
    padding: 14px 0;
    text-align: center;
}

.modal_wrap {
    display: none;
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
}

.modal_overlay {
    background-color: rgba(0, 0, 0, .6);
    cursor: pointer;
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
}

.modal_main {
    border-radius: 15px;
    padding: 0 20px 40px;
    text-align: center;
}

.modal_main_inner {
    background: #fff;
    display: inline-block;
    margin: 0 0 40px;
    padding: 10px 10px 16px 10px;
    position: relative;
}

.modal-img {
    display: inline-block;
    margin: 0 0 15px;
    text-align: center;
    width: 600px;
    max-width: 100%;
}


.modal-img img {
    width: 100%;
    max-width: 600px;
    margin: auto;
}

.modal-txt {
    color: #333;
    font-size: 14px;
    line-height: 22px;
    padding: 0 10px;
    text-align: left;
}

.modal-inner {
    display: flex;
    height: 100%;
    justify-content: center;
    left: 0;
    padding: 50px 0 40px;
    position: absolute;
    top: 0;
    width: 100%;
}

.modal-inner.center {
    align-items: center;
}

.modal-inner.center .modal_main_inner {
    margin: 0;
}

.modal-close-icon {
    cursor: pointer;
    height: 35px;
    position: absolute;
    right: 0;
    top: -43px;
    width: 35px;
}

.modal-close-icon::before,
.modal-close-icon::after {
    background: #fff;
    content: '';
    height: 100%;
    left: 0;
    margin: auto;
    position: absolute;
    right: 0;
    width: 3px;
}

.modal-close-icon::before {
    transform: rotate(45deg);
}

.modal-close-icon::after {
    transform: rotate(-45deg);
}

.contents_inner2 {
    margin: auto;
    max-width: 960px;
    padding: 0 10px;
}

.bnr_photocon_ttl {
    padding-top: 30px;
    font-size: 18px;
    font-weight: bold;
    text-align: center;
}

.bnr_photocon ul {
    max-width: 750px;
    margin: auto;
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
    padding: 15px 0 30px;
}

.bnr_photocon li {
    width: calc( 50% - 13px);
}

.bnr_photocon li:nth-child(n + 3) {
    margin-top: 13px;
}

.bnr_photocon a {
    transition: .5s ease-in-out;
    display: block;
}

.bnr_photocon a:hover {
    opacity: 0.7;
}

.bnr_photocon a img {
    width: 100%;
}

.p-Footer__list {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin: auto;
    max-width: 960px;
    text-align: center;
    padding-bottom: 80px;
}

.p-Footer__list a {
    text-decoration: none;
}

.p-banner-text {
    margin: 0 0 20px;
}

.p-section--footer {
    padding: 80px 0;
}

.p-Section-top {
    padding: 0 0 28px;
}

.p-Footer__link {
    margin: 0 auto;
}

.c-Footer-sns {
    background-color: #fff;
    border: 2px solid #ddd;
    border-radius: 8px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 460px;
}

.c-Footer-sns__link {
    -webkit-transition: .3s;
    transition: .3s;
    width: 50%;
}

.c-Footer-sns__link:first-child {
    border-right: 2px solid #ddd;
}

.c-Footer-sns__link img {
    display: block;
    margin: 0 auto;
}

.c-Footer-sns__link a {
    display: block;
    padding: 18px 0;
}

.c-Footer-sns__link:hover {
    opacity: .6;
}

.c-Footer-link__text {
    color: #333;
    font-size: 15px;
    font-weight: bold;
    text-decoration: none;
}

.c-Footer-banner-link {
    -webkit-transition: .3s;
    transition: .3s;
}

.c-Footer-banner-link:hover {
    opacity: .6;
}

.totop {
    text-align: center;
    padding-bottom: 30px;
    color: #999999;
    font-size: 12px;
}

.totop img {
    padding-bottom: 5px;
}

.totop a {
    color: #999999;
}

.totop a:hover {
    opacity: 0.6;
}

@media screen and (max-width: 600px) {
    .main_visual {
        padding: 30px 20px;
    }
    .main_visual_ttl {
        margin: 0 0 12px;
    }
    .main_visual_txt {
        font-size: 14px;
        line-height: 25px;
        margin: 0 0 23px;
    }
    .main_visual_attention {
        font-size: 14px;
    }
    .contents_inner {
        padding: 25px 20px 0;
    }
    .nav_list .link_btn {
        font-size: 12px;
    }
    .nav_list {
        padding: 0 0 30px;
        width: 100%;
    }
    .nav_list_item:first-child {
        margin: 0 5px 0 0;
        width: 44.28358%;
    }
    .nav_list_item:nth-child(2) {
        margin: 0 5px 0 0;
        width: 55.22388%;
    }
    .link_btn_return {
        padding: 20px 0 20px 12px;
        text-align: center;
        width: 100%;
    }
    .link_btn_next {
        line-height: 18px;
        padding: 8px 14px;
        text-align: center;
        width: 100%;
    }
    .instagram .link_btn_next {
        padding: 8px 14px;
    }
    .arrow.next_arrow.course_link::before,
    .arrow.next_arrow.course_link::after {
        bottom: 6px;
        top: auto;
    }
    .section_ttl {
        margin: 0 0 10px;
    }
    .section04 {
        margin: 0;
    }
    .section04 .section_ttl {
        margin: 0 0 10px;
    }
    .media_list {
        margin: 0 0 26px;
    }
    .section04 .media_list {
        margin: 0 0 26px;
    }
    .media_txt {
        font-size: 14px;
        line-height: 18px;
        margin: 7px 0 0;
    }
    .section01 .media_name {
        font-size: 20px;
    }
    .section02 .media_name {
        font-size: 16px;
    }
    .section03 .media_name {
        font-size: 14px;
    }
    .section01 .media_list_item {
        width: 265px;
    }
    .section02 .media_list_item {
        width: 47.76119%;
    }
    .section03 .media_list_item {
        margin: 0 0 10px;
        width: 31.34328%;
    }
    .section03 .media_txt {
        display: none;
    }
    .footer-block-txt {
        line-height: 28px;
    }
    .footer-btn_link {
        font-size: 18px;
        width: 100%;
    }
    .footer-btn_link .footer-btn-icon {
        left: -55px;
    }
    .footer_foot_txt {
        font-size: 10px;
        padding: 7px 0;
    }
    .modal_main {
        padding: 15px;
        top: auto;
    }
    .modal-inner {
        padding: 20px 0 15px;
    }
    .modal-txt {
        max-width: none!important;
    }
    .modal-img {
        width: auto;
    }
    .modal-close-icon {
        height: 25px;
        right: 0;
        top: -28px;
        width: 25px;
    }
    .contents_inner2 {
        padding: 25px 20px 0;
    }
    .bnr_photocon_ttl {
        font-size: 16px;
    }
    .bnr_photocon li {
        width: calc( 50% - 8px);
    }
    
    .bnr_photocon li:nth-child(3),
    .bnr_photocon li:nth-child(4) {
        margin-top: 13px;
    }
    .bnr_photocon ul li img {
        width: 100%;
    }
    .bnr_photocon ul li img {
        width: 100%;
    }
    .p-Footer__link {
        width: 100%;
    }
    .c-Footer-sns {
        width: 100%;
    }
    .p-Footer__list {
        padding-bottom: 60px;
    }
}

@media screen and (max-width: 374px) {
    .main_visual_txt {
        font-size: 14px;
    }
    .nav_list {
        flex-wrap: wrap;
    }
    .nav_list_item:first-child {
        margin: 0 0 15px;
        width: 100%;
    }
    .nav_list_item:nth-child(2) {
        width: 100%;
    }
    .section_ttl_br {
        display: block;
    }
}