@charset "utf-8";

:root {
    --animate-duration: 2s;
    --animate-delay: 1s;
    --animate-repeat: 1;
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sup {
    top: -0.5em
}

@media print, screen and (min-width : 769px){
    #access_header {
        top: inherit;
    }

    #contents_area {
        padding-top: 40px;
    }
}

@media screen and (max-width: 768px) {
    #global_navigation {
        top: 31px;
    }

    #contents_area {
        margin-top: 0;
        padding-top: 30px;
    }
}



.bg {
    background-color: #fff5c8;
}


.inner {
    padding: 30px 0 40px;
    margin: 0 auto;
    max-width: 980px;
}

.inner--size-s {
    padding-top: 15px;
}

.inner--size-m {
    padding-top: 40px;
}

.pt-0 {
    padding-top: 0;
}

@media screen and (max-width:767px) {
    .inner {
        padding: 20px 15px 35px;
        max-width: 100%;
    }

}

/* .section_visual {
    padding: 30px 0 40px;
} */

.section_visual .main_pic {
    position: relative;
}

.section_visual .main_pic img {
    width: 100%;
    vertical-align: middle;
}

.section_visual .main_pic + .main_pic {
    margin-top: 10px;
}

@media screen and (min-width:768px) {
    .section_visual .main_pic .b_console {
        position: relative;
        left: -2.6%;
        width: 102.7%;
    }
}

@media screen and (max-width:767px) {
    .section_visual .main_pic + .main_pic {
        margin-top: 1.5vw;
    }
}


.animate__animated {
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -webkit-animation-duration: var(--animate-duration);
    animation-duration: var(--animate-duration);
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
}

.animate__animated.animate__repeat-2 {
    -webkit-animation-iteration-count: calc(1 * 2);
    animation-iteration-count: calc(1 * 2);
    -webkit-animation-iteration-count: calc(var(--animate-repeat) * 2);
    animation-iteration-count: calc(var(--animate-repeat) * 2);
}

@keyframes poyopoyo {

    0%,
    40%,
    60%,
    80% {
        transform: scale(1.0);
    }

    50%,
    70% {
        transform: scale(0.8);
    }
}

@keyframes poyopoyoZoom {

    0%,
    40%,
    60%,
    80% {
        transform: scale(1.0);
    }

    50%,
    70% {
        transform: scale(1.2);
    }
}


.animate__popoyo {
    -webkit-animation-name: poyopoyo;
    animation-name: poyopoyo;
}

.animate__popoyoZoom {
    -webkit-animation-name: poyopoyoZoom;
    animation-name: poyopoyoZoom;
}



.pic_console_f {
    position: absolute;
    right: 10px;
    bottom: 10px;
    width: 702px;
}

@media screen and (max-width:767px) {
    .pic_console_f {
        margin: 0 auto;
        width: 95%;
        left: 0;
        right: 0;
        bottom: 2.15vw;
    }
}


@media screen and (min-width:768px) {
    .movie_intro {
        background: url(../img/bg_spot.png) repeat;
        background-size: 10px auto;
    }
}

@media screen and (max-width:767px) {
    .movie_intro {
        background: url(../img/bg_spot_sp.png) repeat;
        background-size: 11px auto;
    }

}

.center {
    text-align: center;
}


.img-wide {
    width: 100%;
    vertical-align: middle;
}


.title {
    position: relative;
    z-index: 1;
}

.tit_mov {
    text-align: left;
    margin-left: 22px;
}

.tit_mov img {
    width: 868px;
}

#contents_area .mov_thumb a:hover {
    opacity: 1;
}

.mov_thumb {
    position: relative;
    margin-top: -26px;
}

.mov_thumb img {
    max-width: 450px;
}

@media screen and (max-width:767px) {

    .tit_mov {
        margin-left: 0;
    }

    .tit_mov img {
        width: 100%;
    }

    .mov_thumb {
        margin-top: -2.5vw;
    }

    .mov_thumb img {
        max-width: 70vw;
    }
}

.title02 {
    text-align: right;
    margin-left: 250px;
}

.title02 img {
    width: 604px;
}


.ab_pic {
    position: relative;
    margin-top: -25px;
}

.pic_console_h {
    position: absolute;
    top: 17px;
    right: 38px;
    width: 612px;
}

@media screen and (max-width:767px) {
    .title02 {
        text-align: left;
        margin-left: 2.5vw;
        width: 86vw;
    }

    .title02 img {
        width: 100%;
    }

    .ab_pic {
        margin-top: -7vw;
    }

    .pic_console_h {
        width: 56vw;
        top: 5vw;
        right: 1.5vw;
    }

}


.title03 {
    margin-left: 30px;
}

.title03 img {
    width: 702px;
}

.ab_pic_2 {
    position: relative;
    overflow: hidden;
    margin-top: -29px;
    clip-path: polygon(0 0, 100% 0%, 100% 100%, 4.5% 100%);
}

.ab_pic_2::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 48px;
    height: 100%;
    background: url(../img/bd.png) no-repeat;
    background-size: 48px 510px;
    z-index: 1;
}

.ab_pic_2 .box-img {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 9;
    background: url(../img/pic_rfconsole_sunshied_txture.png);
    background-size: 100% auto;
}

.ab_pic_3 {
    margin-top: 10px;
}

.ab_pic_3_sp {
    display: none;
}

@media screen and (max-width:767px) {

    .title03 {
        text-align: left;
        margin-left: 0;
        margin-left: 3vw;
        width: 86vw;
    }

    .title03 img {
        width: 100%;
    }

    .ab_pic_2 {
        margin-top: -3.5vw;
        clip-path: polygon(0 0, 100% 0%, 100% 100%, 0 87%, 0% 100%);
    }

    .ab_pic_2::before {
       display: none;

    }


    .ab_pic_2 .box-img {
        background: url(../img/pic_rfconsole_sunshied_txture_sp.png);
        background-size: 100% auto;
    }

    .ab_pic_3_sp {
        position: relative;
        display: flex;
        margin-top: -8vw;
    }

    .ab_pic_3_sp img {
        max-width: 100%;
    }

    .ab_pic_3_sp {
        position: relative;
        display: flex;
        margin-top: calc(-1*(6vw + 4px));
    }

    .ab_pic_3_sp img {
        max-width: 100%;
        vertical-align: middle;
    }

    .ab_pic_3_3_sp {
        margin-top: 1.5vw;
    }
}


@media screen and (max-width:422px) {
    .ab_pic_3_sp {
        margin-top: calc(-1*(6vw + 1px));
    }
}


.title04 {
    text-align: right;
    margin-left: 400px;
}

.title04 img {
    width: 495px;
}

.nbox_pic {
    position: relative;
    margin-top: -34px;
}

@media screen and (max-width:767px) {
    .title04 {
        text-align: right;
        margin-left: 17.3vw;
        width: 71vw;
    }

    .title04 img {
        width: 100%;
    }

    .nbox_pic {
        margin-top: -5vw;
    }
}

.nbox_product {
    color: #B05F1A;
}

.bd_wrp {
    border: 1px solid #B1580E;
    background: #FFFBDA;
    font-weight: 500;
    line-height: 1;
    vertical-align: middle;
}

.product_wrap {
    display: flex;
    flex-wrap: wrap;
    box-sizing: border-box;
    justify-content: center;
    gap: 20px;
    width: 100%;
}

.product_wrap .product_col {
    width: 630px;
}

.product_wrap .pic_col {
    width: calc(100% - 650px);
}

.product_name {
    margin-bottom: 27px;
    font-size: 30px;
    font-weight: bold;
}

.product_price {
    margin-bottom: 12px;
    font-size: 14px;
    font-weight: bold;
}

.product_price .fs_27 {
    font-size: 27px;
}

.product_price .bd_wrp {
    position: relative;
    top: -8px;
    display: inline-block;
    padding: 5px 6px 3px 8px;
    font-size: 16px;
}

.product_options {
    margin-bottom: 18px;
    font-size: 16px;
    font-weight: bold;
    line-height: 1.65;
}

.product_options span {
    font-weight: 500;
    font-size: 13px;
}

.product_details {
    margin-bottom: 24px;
    font-size: 12.5px;
    font-weight: bold;
    line-height: 1.84;
}

.product_note {
    font-size: 11px;
    line-height: 1.64;
    font-weight: 500;
    padding-left: 12px;
    text-indent: -12px;
}

.product_note:not(.note_bg) li {
    margin-bottom: 3px;
}

.product_note .bd_wrp {
    margin: 0 4px;
    padding: 1.8px 4.2px 0px;
    font-size: 12px;
}

.pic_col .pic_wrp + .pic_wrp {
    margin-top: 14px;
}

.pic_col .pic_wrp .caption {
    margin-top: 7px;
    font-size: 11px;
    font-weight: 500;

}

.note_bg {
    margin: 36px 0;
    padding: 10px 28px 8px;
    background: #E6E6CD;
    font-size: 12px;
    line-height: 1.8;
}

.note_bg .bd_wrp {
    margin: -1px 3px 0 1px;
    padding: 0;
    width: 33px;
    display: inline-block;
    height: 14px;
}

.product_highlight h4 {
    margin-bottom: 13px;
    font-size: 18px;
    font-weight: bold;
}

.product_warranty {
    font-size: 11px;
    line-height: 1.64;
    font-weight: 500;
    padding-left: 12px;
    text-indent: -12px;
}


@media screen and (max-width:767px) {
    .product_wrap {
        display: block;
    }

    .product_wrap .product_col {
        width: 100%;
        margin-bottom: 20.7px;
    }

    .product_wrap .pic_col {
        margin: 0 auto;
        width: 76vw;
    }

    .product_name {
        margin-bottom: 17px;
        font-size: 18px;
    }

    .product_price {
        margin-bottom: 10px;
    }

    .product_price .fs_27 {
        font-size: 18.7px;
    }

    .product_price .bd_wrp {
        margin-top: 12px;
        font-size: 13px;
        padding: 6px 6px 3px 8px;
    }

    .product_options {
        margin-bottom: 8px;
        line-height: 1.5;
    }

    .product_options span {
        font-size: 12px;
    }

    .product_details {
        margin-bottom: 10px;
    }

    .product_note {
        font-size: 10px;
        padding-left: 10px;
        text-indent: -10px;
    }

    .product_note .bd_wrp {
        margin: 0 3px;
        padding: 1.8px 2.2px 0;
        font-size: 11px;
    }

    .pic_col .pic_wrp + .pic_wrp {
        margin-top: 15px;
    }

    .pic_col .pic_wrp .caption {
        margin-top: 8px;
        font-size: 13px;
    }

    .note_bg {
        margin: 25px 0;
        padding: 10px 28px 8px;
    }

    .note_bg li+li {
        margin-top: 3px ;
    }

    .product_highlight h4 {
        font-size: 15px;
        line-height: 1.5;
    }

    .product_warranty {
        padding-left: 11px;
        text-indent: -11px;
    }

}


.search_box a {
    border: 2px solid #000;
    background: #fff;
    color: #000 !important;
    width: 422px;
    margin: 0 auto;
    text-align: center;
    font-size: 21px;
    align-items: center;
    display: flex;
    justify-content: center;
    height: 37px;
}

.search_box a::before,
.search_box a::after {
    content: "";
    display: inline-block;
    vertical-align: middle;
}

.search_box a::before {
    margin-right: 30px;
    width: 35px;
    height: 24px;
    background: url(../img/location_icon.png) center center no-repeat;
    background-size: 35px auto;
}

.search_box a::after {
    margin-left: 28px;
    width: 21px;
    height: 21px;
    background: url(../img/arrow_icon.png) center center no-repeat;
    background-size: 21px auto;
}

@media screen and (max-width:767px) {
    .search_box_wrap {
        padding-bottom: 50px;
    }
    .search_box a {
        width: 100%;
    }
}