/* Slider */
.slick-slider
{
    position: relative;

    display: block;

    box-sizing: border-box;

    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;

    -webkit-touch-callout: none;
     -khtml-user-select: none;
    -ms-touch-action: pan-y;
        touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list
{
    position: relative;

    display: block;
    overflow: hidden;

    margin: 0;
    padding: 0;
}

.slick-list:focus
{
    outline: none;
}

.slick-list.dragging
{
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list
{
    -webkit-transform: translate3d(0, 0, 0);
        -ms-transform: translate3d(0, 0, 0);
            transform: translate3d(0, 0, 0);
}

.slick-track
{
    position: relative;
    top: 0;
    left: 0;

    display: block;
}

.slick-track:before,
.slick-track:after
{
    display: table;

    content: '';
}

.slick-track:after
{
    clear: both;
}

.slick-loading .slick-track
{
    visibility: hidden;
}

.slick-slide
{
    display: none;
    float: left;

    height: 100%;
    min-height: 1px;
}

[dir='rtl'] .slick-slide
{
    float: right;
}

.slick-slide img
{
    display: block;
    width: 100%;
}

.slick-slide.slick-loading img
{
    display: none;
}

.slick-slide.dragging img
{
    pointer-events: none;
}

.slick-initialized .slick-slide
{
    display: block;
}

.slick-loading .slick-slide
{
    visibility: hidden;
}

.slick-vertical .slick-slide
{
    display: block;

    height: auto;

    border: 1px solid transparent;
}

.slick-arrow.slick-hidden
{
    display: none;
}

/* dotts */
.slick-dots
{
    font-size: 0;

    position: relative; 
    z-index: 10;

    display: -ms-flexbox;
    display: flex;

    margin-top: 5px;

    -ms-flex-pack: justify;
    justify-content: space-between;
}
@media print, screen and (min-width: 768px)
{
    .slick-dots
    {
        margin-top: 10px;
    }
}

.slick-dots li
{
    position: relative;
    top: 0;

    width: calc(20% - 4px);

    cursor: pointer;

    border: none;
    background: transparent;
    background: #8d8d8d;
}
@media print, screen and (min-width: 768px)
{
    .slick-dots li
    {
        width: calc(20% - 8px);
    }
}

.slick-dots li.slick-active
{
    background: #fff;
}

.slick-dots li button
{
    cursor: pointer;

    color: transparent;
    border: none;
    outline: none; 
    background: transparent;
}

/* control */
button
{
    border: none;
}
button:focus
{
    outline: none;
}

.slick-next
{
    position: absolute;
    z-index: 10;
    top: 50%;
    right: -24px;

    overflow: hidden;

    width: 12px;
    height: 24px;
    margin-top: -12px;

    text-indent: 200%;

    color: transparent;
    background: url(../images/shop/next.png) no-repeat center center/cover;
}
@media print, screen and (min-width: 768px)
{
    .slick-next
    {
        right: -40px;

        width: 20px;
        height: 38px;
        margin-top: -19px;
    }
}

.slick-prev
{
    position: absolute;
    z-index: 10;
    top: 50%;
    left: -24px;

    overflow: hidden;

    width: 12px;
    height: 24px;
    margin-top: -12px;

    text-indent: 200%;

    color: transparent;
    background: url(../images/shop/prev.png) no-repeat center center/cover;
}
@media print, screen and (min-width: 768px)
{
    .slick-prev
    {
        left: -40px;

        width: 20px;
        height: 38px;
        margin-top: -19px;
    }
}

.voice-slider
{
    display: none;
}

.voice-slider.slick-initialized
{
    display: block;
}

.slick-slide:focus
{
    outline: none;
}

@media print, screen and (min-width: 768px)
{
    .slick-list.draggable
    {
        padding: 0 !important;
    }
}

.about-lead
{
    font-size: 1.5rem;
    font-weight: bold;
    line-height: 1.5; 

    margin-bottom: 20px;

    text-align: center;
}
.about-lead-text
{
    margin-bottom: 15px; 

    text-align: center;
}
@media print, screen and (min-width: 768px)
{
    .about-lead
    {
        font-size: 2.8rem;
        line-height: 1.5;

        margin-bottom: 40px;
    }
    .about-lead-text
    {
        margin-bottom: 40px;
    }
}

.icon-new
{
    display: inline-block;

    width: 22px; 
    margin-left: 8px;

    vertical-align: middle;
}
@media print, screen and (min-width: 768px)
{
    .icon-new
    {
        width: 29px;
        margin-left: 30px;
    }
}

@media print, screen and (min-width: 768px)
{
    .newstopics-post-wrapper
    {
        display: -ms-flexbox;
        display: flex;

        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    }
}

.newstopics-post:first-child
{
    padding-bottom: 20px;

    border-bottom: 1px solid #ccc;
}

.newstopics-post:not(:first-child)
{
    padding: 20px 0;

    border-bottom: 1px solid #ccc;
}

@media print, screen and (min-width: 768px)
{
    .newstopics-post
    {
        width: 33.33%;
        padding: 0 20px !important;
    }
    .newstopics-post:first-child
    {
        padding-bottom: 0;

        border-bottom: none;
    }
    .newstopics-post:not(:first-child)
    {
        padding: 0;

        border-bottom: none;
    }
    .newstopics-post:nth-child(n + 4)
    {
        margin-top: 60px;
    }
}

.newstopics-post a
{
    display: -ms-flexbox;
    display: flex;

    width: 100%;
}
@media print, screen and (min-width: 768px)
{
    .newstopics-post a
    {
        display: block;

        width: auto;
    }
}

.newstopics-img
{
    width: 96px;
}
@media print, screen and (min-width: 768px)
{
    .newstopics-img
    {
        width: 100%;
        margin-bottom: 20px;
    }
}

.newstopics-cont
{
    width: calc(100% - 96px);
    padding-left: 15px;
}
@media print, screen and (min-width: 768px)
{
    .newstopics-cont
    {
        width: 100%;
        padding-left: 0;
    }
}

.newstopics-date
{
    font-size: .9rem;

    margin-bottom: 10px;
}
@media print, screen and (min-width: 768px)
{
    .newstopics-date
    {
        font-size: 1.2rem;

        margin-bottom: 15px;
    }
}

.newstopics-category
{
    font-family: 'Roboto', sans-serif;
    font-size: .9rem;
    font-weight: bold;

    margin-bottom: 5px;
}
@media print, screen and (min-width: 768px)
{
    .newstopics-category
    {
        font-size: 1.2rem;
    }
}

.newstopics-ttl
{
    font-style: 1.2rem;
    line-height: 1.25;
}
@media print, screen and (min-width: 768px)
{
    .newstopics-ttl
    {
        font-size: 1.4rem;
        line-height: 1.57;
    }
}

@media print, screen and (min-width: 768px)
{
    .press-post-wrapper
    {
        max-width: 1000px;
        margin-right: auto; 
        margin-left: auto;
    }
}

.press-post a
{
    position: relative; 

    display: block;

    padding-right: 70px;
}
.press-post a::after
{
    position: absolute;
    top: 50%;
    right: 0;

    display: block;

    width: 52px;
    height: 6px;
    margin-top: -3px; 

    content: '';

    background: url(../images/top/icon_arrw.png) no-repeat center center/cover;
}
@media print, screen and (min-width: 768px)
{
    .press-post a
    {
        display: -ms-flexbox;
        display: flex;

        width: 100%;
        padding-right: 160px;
    }
    .press-post a::after
    {
        right: 30px; 

        width: 42px;
        height: 7px;

        background: url(../images/top/icon_arrw.png) no-repeat right center/cover;
    }
}

.press-post:first-child
{
    border-bottom: 1px solid #ccc;
}
.press-post:first-child a
{
    padding-bottom: 20px;
}
@media print, screen and (min-width: 768px)
{
    .press-post:first-child
    {
        border-top: 1px solid #ccc;
    }
    .press-post:first-child a
    {
        padding-top: 30px;
        padding-bottom: 30px;
    }
}

.press-post:not(:first-child)
{
    border-bottom: 1px solid #ccc;
}
.press-post:not(:first-child) a
{
    padding-top: 20px;
    padding-bottom: 20px;
}
@media print, screen and (min-width: 768px)
{
    .press-post:not(:first-child) a
    {
        padding-top: 30px;
        padding-bottom: 30px;
    }
}

.press-date
{
    font-size: .9rem;

    margin-bottom: 15px;
}
@media print, screen and (min-width: 768px)
{
    .press-date
    {
        font-size: 1.2rem; 

        width: 190px;
        margin-bottom: 0;
        padding-left: 20px;
    }
}

.press-ttl
{
    font-style: 1.2rem;
    line-height: 1.25;
}
@media print, screen and (min-width: 768px)
{
    .press-ttl
    {
        font-size: 1.4rem;
        line-height: 1.57; 

        width: calc(100% - 190px);
    }
}

.bnr
{
    width: calc(50% - 14px);
}
.bnr-wrapper
{
    display: -ms-flexbox;
    display: flex;

    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -ms-flex-pack: justify;
    justify-content: space-between;
}
.bnr a
{
    display: block;

    width: 100%;
    height: 100%;
}
@media print, screen and (min-width: 768px)
{
    .bnr
    {
        width: calc(25% - 18px);
    }
}
.bnr:not(:last-child):not(:nth-last-child(2))
{
    margin-bottom: 30px;
}
.bnr-img
{
    margin-bottom: 10px;
}
@media print, screen and (min-width: 768px)
{
    .bnr-img
    {
        margin-bottom: 18px;
    }
}
.bnr-ttl span
{
    display: block;

    text-align: center;
}
.bnr-ttl-en
{
    font-family: 'Roboto', sans-serif;
    font-size: 1.2rem;

    margin-bottom: 5px;
}
.bnr-ttl-ja
{
    font-family: 'Noto Sans JP'; 
    font-size: 1.0rem;
}
@media print, screen and (min-width: 768px)
{
    .bnr-ttl-en
    {
        font-size: 1.8rem;

        margin-bottom: 10px;
    }
    .bnr-ttl-ja
    {
        font-size: 1.6rem;
    }
}

.feature
{
    position: relative; 

    height: 0;
    padding-bottom: 58%;
}
.feature-group
{
    font-size: 0;
}
@media print, screen and (min-width: 768px)
{
    .feature-group
    {
        margin: 0 25px;
    }
}
.feature:not(:last-child)
{
    margin-bottom: 25px;
}
.feature--feature
{
    background: url(../images/top/feature01.png) no-repeat center center/cover;
}
.feature--recommend
{
    background: url(../images/top/feature02.png) no-repeat center center/cover;
}
.feature a
{
    position: absolute;
    top: 0;
    right: 0;
    left: 0;

    display: block;

    width: 100%;
    height: 100%;

    border: 0;
}


@media print, screen and (min-width: 768px)
{
	.feature-group {
		overflow: hidden;
	}
	
    .feature
    {
        display: inline-block;

        width: calc(50% - 15px);
        padding-bottom: 29%; 

        vertical-align: top;
    }
    
    .feature a:hover
    {
        opacity: 1;
    }
    .feature a:hover .more-btn
    {
        color: #1d2088;
    }
    .feature a:hover .more-btn::after,
    .feature a:hover .more-btn::before
    {
        width: 100%;
        height: 100%;
    }
    .feature a:hover .more-btn::before
    {
        transition: width .2s, height .2s .2s; 

        border-top-color: #1d2088;
        border-right-color: #1d2088;
    }
    .feature a:hover .more-btn::after
    {
        transition: border-color 0s ease-out .4s, width .2s .4s, height .2s .6s; 

        border-bottom-color: #1d2088;
        border-left-color: #1d2088;
    }
    .feature--feature
    {
        margin-right: 30px;
    }
}

.feature-cont
{
    position: absolute;
    top: 50%;
    left: 50%;

    width: 100%;

    -webkit-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%); 
    text-align: center;
}
.feature-ttl
{
    font-family: 'Roboto', sans-serif;
    font-size: 1.8rem;
    font-weight: bold;

    margin-bottom: 40px;
}
@media print, screen and (min-width: 768px)
{
    .feature-ttl
    {
        font-size: 3.6rem;

        margin-bottom: 35px;
    }
}

.hero
{
    position: relative;

    display: block;

    width: 100%;
}
.hero-next-img
{
    display: none;
}
@media print, screen and (min-width: 768px)
{
    .hero-next-img
    {
        position: absolute;
        z-index: -1;
        top: 0;
        left: 25%;

        display: block;

        width: 75%;

        -webkit-transform: translate(-100%, 0);
            -ms-transform: translate(-100%, 0);
                transform: translate(-100%, 0);
    }
    
    .hero-next-img-txt {
	    position: absolute;
	    left: 69%;
	    top: 50%;
	    z-index: 10000;
	    -webkit-transform: translate(0, -50%);
	    transform: translate(0, -50%);
    }
}
@media print, screen and (min-width: 768px)
{
    .hero-img-group
    {
        position: relative; 

        padding-left: 25%;
    }
    .hero-img
    {
        position: relative;
        z-index: 10;
    }
}
.hero-cont
{
    position: absolute;
    z-index: 10;
    bottom: 0;
    left: 0; 

    display: block;

    width: 53%;
    padding: 15px 12px;

    background: #fff;
}
@media print, screen and (min-width: 768px)
{
    .hero-cont
    {
        top: 50%;
        bottom: auto;

        padding: 0 50px;

        -webkit-transform: translate(0, -50%);
            -ms-transform: translate(0, -50%);
                transform: translate(0, -50%); 

        background: none;
    }
}
.hero-ttl
{
    font-family: 'Noto Sans JP';
    font-size: 6vw;
    font-weight: bold;
    line-height: 1.25;

    margin-bottom: 8px;

    color: #000;
}
@media print, screen and (min-width: 768px)
{
    .hero-ttl
    {
        font-size: 4vw;

        margin-bottom: 45px;
    }
}
.hero-text
{
    font-family: 'Noto Sans JP';
    font-size: 3vw;
    line-height: 1.4;
    margin-bottom: 15px; 

    color: #999;
}
@media print, screen and (min-width: 768px)
{
    .hero-text
    {
        font-size: 1.3vw;
		line-height: 1.4;
        margin-bottom: 50px;
    }
}
.hero-more
{
    font-family: 'Roboto', sans-serif; 
    font-size: 3vw;
    font-weight: bold;

    color: #1d2088;
}
@media print, screen and (min-width: 768px)
{
    .hero-more
    {
        font-size: .7vw;
    }
}
.hero-more span
{
    position: relative;

    display: inline-block;

    padding-right: 60px;
}
.hero-more span::after
{
    position: absolute;
    top: 50%;
    right: 0;

    display: block;

    width: 52px;
    height: 6px;
    margin-top: -3px; 

    content: '';

    background: url(../images/top/icon_arrw.png) no-repeat center center/cover;
}

.heroSlide-wrap
{
    overflow: hidden; 

    height: 0;
    padding-bottom: 120%;
}
@media print, screen and (min-width: 768px)
{
    .heroSlide-wrap
    {
        padding-bottom: 45%;
    }
}


.about-more--hover span::after, .about-more span::after {
    right: 90px;
}

@media print, screen and (min-width: 768px) {
	.about-more--hover span::after, .about-more span::after {
	    right: 0;
	}	
}