@media screen and (max-width: 787px) {
    .ec-footerRole {
        margin-top: 8vw;
        background: #F0E8DF;
    }
    .ec-footerRole .ec-footer-top-link img {
        width: auto;
    }

    .ec-footer-bottom {
        background: #333;
        padding: 6vw 6vw 18vw;
    }
    .ec-footerNavi {
        padding: 0 0 1vw;
        color: white;
        list-style: none;
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .ec-footerNavi .ec-footerNavi__link {
        display: inline-block;
    }
    .footerInfo-block {
        margin-top: 0;
    }
    .ec-footerNavi .ec-footerNavi__link a {
        border-bottom: none;
        position: relative;
        font-size: 3.2vw;
        color: white;
        text-decoration: none;
        margin-left: 0;
        margin-right: 0;
        padding: 10px 0px;
    }
    .ec-footer-top .ec-footerNavi .ec-footerNavi__link:nth-child(1) a {
        margin-left: 5vw;
    }
    .ec-footer-top .ec-footerNavi .ec-footerNavi__link:nth-child(3) a{
        margin-right: 7vw;
    }
    .ec-footerNavi .ec-footerNavi__link a:hover {
        opacity: .8;
        text-decoration: none;
        font-size: 3.2vw;
    }

    .ec-footer-top {
        padding: 2vw 0;
    }
    .footerInfo-block .ft-des {
        font-size: 2.5vw;
    }
    .footerInfo-block .ft-title {
        font-size: 4vw;
    }
    .footerInfo-block .ft-title::before {
        content: '';
        background-color: #C3B3A1;
        width: 1.6vw;
        height: 1.7vw;
        vertical-align: middle;
        margin-right: 1.3333vw;
        display: inline-block;
    }
    .footerInfo-block a {
        text-decoration: underline;
    }
    .footerInfo-block {
        width: 100%;
        border-bottom: 1px solid #E0E0E0;
        padding-bottom: 17px;
    }
    .ec-footerRole__box:nth-of-type(3) .footerInfo-block:nth-of-type(2) {
        border-bottom: none;
    }
    .footerInfo-block .mb15 {
        margin-bottom: 1rem;
    }
    .logo-ft {
        height: 13.3333vw;
        width: 42%;
        position: initial;
    }
    .logo-ft .penguin img {
        width: 23vw;
        bottom: -5px;
    }
    .ec-footer-bottom .ec-footerTitle__copyright {
        margin: 0 auto;
        font-size: 3.2vw;
    }
    .footerAboutactive {
        background: #F0E8DF;
        padding: 6vw 6vw;
    }
    .footerAboutactive .footerAboutactiveBlock {
        margin-bottom: 4vw;
    }
    .footerAboutactive .footerAboutactiveTitle {
        font-size: 3.5vw;
        font-weight: bold;
        margin-bottom: 2vw;
        text-align: center;
    }
    .footerAboutactiveText {
        font-size: 3.4vw;
    }
    .footerAboutactive .footerAboutactiveSubBox .footerAboutactiveSubTitle {
        font-size: 3.2vw;
        letter-spacing: .06em;
        font-weight: bold;
        margin-bottom: 2vw;
        text-align: center;
        width: 100%;
        text-align: center;
        margin: 10px;
    }
    .footerAboutactive .footerAboutactiveSubBox {
        display: block;
        margin-bottom: 0;
    }
    .footerAboutactive .footerAboutactiveSubBox dd {
        margin-bottom: 2vw;
        width: 100%;
    }
    .footerAboutactive .footerAboutactiveSubBox dd:last-child {
        margin-bottom: 0;
    }
    .footerAboutactive .footerAboutactiveSubBox dd a {
        background-color: #f5f5f5;
        padding: 3vw 0;
        display: inline-block;
        border-radius: 5px;
        width: 100%;
        font-size: 3vw;
        font-weight: bold;
        letter-spacing: .04em;
        line-height: 1em;
        color: #333;
        text-align: center;
    }

    /*
    フッタータイトル

    フッタープロジェクトで使用するタイトル用のコンポーネントです。

    Markup:
    include /assets/tmpl/elements/11.8.footer.pug
    +ec-footerTitle

    sg-wrapper:
    <div class="ec-footerRole">
    <div class="ec-footerRole__inner">
        <sg-wrapper-content/>
    </div>
    </div>

    Styleguide 11.3.2
    */
    .ec-footerTitle {
        padding: 10.6667vw 0 16vw;
        text-align: center;
        color: white;
    }
    .ec-footerTitle .ec-footerTitle__logo {
        display: block;
        margin-bottom: 2.6667vw;
        font-weight: bold;
    }
    .ec-footerTitle .ec-footerTitle__logo a {
        color: inherit;
        text-decoration: none;
    }
    .ec-footerTitle .ec-footerTitle__logo a:hover {
        text-decoration: none;
    }
    .ec-footerTitle .ec-footerTitle__logo a {
        font-size: 5.8667vw;
        color: inherit;
    }
    .ec-footerTitle .ec-footerTitle__logo:hover a {
        opacity: .8;
        text-decoration: none;
    }
    .ec-footerTitle .ec-footerTitle__copyright {
        font-size: 2.6667vw;
    }
    .ec-footer-bottom .ec-footerTitle__copyright {
        font-size: 2.75vw;
        text-align: left;
    }

    .ec-footer-bottom .ec-footerTitle__copyright a {
        font-size: 2.75vw;
    }
    .footerCompanyOverview {
        color: #fff;
        font-size: 3.2vw;
        letter-spacing: .05em;
        line-height: 1.7;
        margin-bottom: 5vw;
    }
    .footerCompanyOverviewStorong {
        font-size: 3.8vw;
    }
    .footerInfo-block .ft-des {
        line-height: 1.65em;
        font-size: 3.2vw;
    }
    .footerInfo-block .ft-des .ftdesLink {
        position: relative;
    }

    .footerInfo-block .ft-des .ftdesLink::after {
        position: absolute;
        top: .5vw;
        bottom: 0;
        right: -2.5vw;
        margin: auto;
        content: "";
        width: 1.6vw;
        height: 2.7vw;
    }

    .ec-footerRole .ec-footer-top-link {
        text-align: center;
        height: 40px;
        position: relative;
    }

    .ec-footerRole .ec-footer-top-link a:after {
        position: absolute;
        top: 36%;
        left: 46%;
        content: "";
        background: url(/html/template/default/assets/img/footer/go_top.svg) no-repeat 0 0;
        width:  29px;
        height: 14px;
    }

    .ec-footerNavi .ec-footerNavi__link img {
        width: 1.3vw;
        height: 2.4vw;
    }

    .ec-footer-top {
        background: #fff;
    }

    .ec-footer-top .ec-footerRole__inner,
    .ec-footer-bottom .ec-footerRole__inner,
    .ec-footer-middle .ec-footerRole__inner {
        display: block;
        flex-wrap: wrap;
        max-width: 1220px;
        padding-left: 0;
        padding-right: 0;
        justify-content: center;
    }

    .ec-footer-bottom .ec-footerRole__inner .ec-footerNavi .left {
        width: 60%;
    }

    .ec-footer-bottom .ec-footerRole__inner .ec-footerNavi .right {
        width: 40%;
    }

    .ec-footerRole__box {
        width: 100%;
        padding: 0 5vw;
    }

    .ec-footerRole__box:last-child {
        padding-bottom: 3vw;
    }

    .footerInfo-block {
        margin: 15px 0px 0px;
        width: 100%;
    }

    .footerInfo-block img {
        width: 1.3vw;
        height: 2.4vw;
    }

    .footerInfo-block:nth-of-type(2) {
        margin-top: 12px;
    }
    .ec-footer-middle {
        background: #f5f5f5;
        padding: 5px;
    }

    .ec-footer-top .ec-footerNavi {
        margin: 0;
        text-align: left;
        width: 100%;
    }

    .footerInfo-block a,
    .cartInfoBlock a {
        color: #333;
        text-decoration: underline;
        font-size: 3.2vw;
    }

    .footerInfo-block dt {
        line-height: 1.65em;
        font-size: 3.5vw;
        font-weight: bold;
    }

    .footerInfo-block dd,
    .footerInfoFaqBox li {
        line-height: 1.65em;
        font-size: 3.2vw;
    }
    .footerInfoFaqBox {
        padding-left: 1.3em;
    }
    .footerInfoFaqBox li {
        list-style: unset;
    }

    
}

