@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Jost:wght@100..600&display=swap');


/*---BG CSSリセット---*/
#marbb img {
    max-width: 100%;
    height: auto;
    margin: 0 auto;
}
#marbb h1, #marbb .h1, #marbb h2, #marbb .h2, #marbb h3, #marbb .h3, #marbb h4, #marbb .h4, #marbb p, #marbb dl,#marbb table th, #marbb .inner, #marbb label {
    margin: 0;
    font-size: inherit;
    font-weight: inherit;
    color: inherit;
}
#marbb h1 small, #marbb h2 small, #marbb h3 small, #marbb h4 small, #marbb h5 small, #marbb h6 small, #marbb .h1 small, #marbb .h2 small, #marbb .h3 small, #marbb .h4 small, #marbb .h5 small, #marbb .h6 small, #marbb h1 .small, #marbb h2 .small, #marbb h3 .small, #marbb h4 .small, #marbb h5 .small, #marbb h6 .small, #marbb .h1 .small, #marbb .h2 .small, #marbb .h3 .small, #marbb .h4 .small, #marbb .h5 .small, #marbb .h6 .small, #marbb .pickupLayout th, #marbb .pickupLayout td, #marbb .pickupLayout h1, #marbb .pickupLayout h2, #marbb .pickupLayout h3, #marbb .pickupLayout h4, #marbb .pickupLayout h5, #marbb .pickupLayout h6 {
    font-size: inherit;
    color: inherit;
    line-height: inherit;
}
#marbb .section {
    padding: 0;
}
#marbb a {
    text-decoration: none;
    color: inherit;
}
#marbb a:hover {
    opacity: 0.7;
}




/*---LP共通----------------------------------------------------*/
#marbb {
    font-size: clamp(14px, 1.875vw, 14px);/*320px, 800px, 1200px想定*/
    font-family: "Jost", "Hiragino Kaku Gothic ProN",Meiryo,"Open Sans",Helvetica,Arial,-apple-system,blinkMacSystemFont,sans-serif;
    color: #1a0800;
}

/*font設定*/
#marbb .txt_center {
    text-align: center;
}
#marbb .txt_left {
    text-align: left;
}
#marbb .txt_right {
    text-align: right;
}
#marbb .txt_bold {
    font-weight: bold;
}
#marbb .txt_light {
    font-weight: normal;
}
#marbb .txt_small {
    font-size: 0.8em;
}
#marbb .txt_white {
    color: #fff;
}
#marbb .txt_blue {
    color: #1aa7c8;
}
#marbb .txt_gray {
    color: #898989;
}
#marbb .fsize_125 {
    font-size: 1.25em;
}
#marbb .fsize_150 {
    font-size: 1.5em;
}
#marbb .fsize_175 {
    font-size: 1.75em;
}
#marbb .fsize_200 {
    font-size: 2em;
}
#marbb .fsize_300 {
    font-size: 3em;
}

#marbb a.txt_link {
    text-decoration: underline;
    font-weight: bold;
}
#marbb a.a_blank:after {
    content: "\f08e";
    font-family: FontAwesome;
    display: inline-block;
    margin-left: 0.5em;
    font-size: 0.8em;
    vertical-align: top;
}

#marbb .pc_only {
    display: none;
}
@media screen and (min-width:1280px) {
    #marbb .pc_only {
        display: block;
    }
}





/*---メインイメージ--------------------------------------------------*/
#marbb header .main_img {
    background: #333;
    color: #fff;
    text-align: center;
}
#marbb header .main_img > p {
    padding: 15px 0;
    font-weight: 500;
    font-size: 1.25em;
}
#marbb header .main_img h1 {
    position: relative;
}
#marbb header .main_img > h1 .taiken_button {
    position: absolute;
    top: 18%;
    right: 15px;
    width: 100px;
    height: 100px;
}
#marbb header .main_img > h1 .taiken_button a {
    display: flex;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 1.25em;
    font-weight: bold;
    line-height: 1.2;
    background: #1aa7c8;
    box-shadow: 0 3px 6px rgba(0,0,0,0.8);
}
#marbb header .main_img > h1 .taiken_button.fixed {
    position: fixed;
    top: inherit;
    right: 15px;
    bottom: 30px;
    transition: 1s;
    width: 80px;
    height: 80px;
    opacity: 0;
    z-index: 100;
}
#marbb header .main_img > h1 .taiken_button.fixed.on_scroll {
    opacity: 1;
}
#marbb header .main_img > h1 .taiken_button.fixed a {
    box-shadow: 0 3px 6px rgba(0,0,0,0.3);
    font-size: 1em;
}

@media screen and (min-width:768px) {
    #marbb header .main_img h1 {
        display: grid;
        align-content: center;
        justify-content: center;
        grid-template-columns: repeat(2,1fr);
        aspect-ratio: 72/23;
        background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/mainimage_pc_bg.jpg') no-repeat center;
        background-size: cover;
    }
    #marbb header .main_img h1 > img.pc {
        width: 60%;
        max-width: 433px;
    }
    #marbb header .main_img > h1 .taiken_button {
        top: inherit;
        bottom: 15px;
    }
    #marbb header .main_img > h1 .taiken_button.fixed {
        right: 30px;
        bottom: 30px;
        width: 100px;
        height: 100px;
    }
    #marbb header .main_img > h1 .taiken_button.fixed a {
        font-size: 1.25em;
    }
}

@media screen and (min-width:1280px) {
    #marbb header .main_img > p {
        font-size: 2em;
    }
    #marbb header .main_img > p:last-child {
        padding: 25px 0 20px;
    }
    #marbb header .main_img > h1 .taiken_button {
        width: 10.4166vw;
        height: 10.4166vw;
        max-width: 150px;
        max-height: 150px;
        bottom: 30px;
        right: 30px;
    }
    #marbb header .main_img > h1 .taiken_button a {
        font-size: 1.7em;
    }
    #marbb header .main_img > h1 .taiken_button.fixed {
        width: 10.4166vw;
        height: 10.4166vw;
        max-width: 150px;
        max-height: 150px;
    }
    #marbb header .main_img > h1 .taiken_button.fixed a {
        font-size: 1.7em;
    }
}




/*---nav--------------------------------------------------*/
@media screen and (max-width:767px) {
    #marbb #g-nav{
        /*position:fixed;にし、z-indexの数値を大きくして前面へ*/
        position:fixed;
        z-index: 999;
        /*ナビのスタート位置と形状*/
        top:0;
        right: -120%;
        width:75%;
        height: 100vh;/*ナビの高さ*/
        background: rgba(17,17,17,0.9);
        /*動き*/
        transition: all 0.6s;
        box-shadow: 0 0 10px rgba(0,0,0,0.7);
    }
    
    /*アクティブクラスがついたら位置を0に*/
    #marbb #g-nav.panelactive{
        right: 0;
    }
    
    /*ナビゲーションの縦スクロール*/
    #marbb #g-nav.panelactive #g-nav-list{
        /*ナビの数が増えた場合縦スクロール*/
        position: fixed;
        z-index: 999; 
        width: 100%;
        height: 100vh;/*表示する高さ*/
        overflow: auto;
        -webkit-overflow-scrolling: touch;
    }
    
    /*ナビゲーション*/
    #marbb #g-nav ul {
        /*ナビゲーション天地中央揃え*/
        padding: 120px 30px 30px;
    }
    /*リストのレイアウト設定*/
    #marbb #g-nav li{
        list-style: none;
    }
    #marbb #g-nav li a{
        color: #fff;
        text-decoration: none;
        display: block;
        font-size: 1.5em;
        line-height: 2;
    }
    #marbb #g-nav li a:before{
        margin-right: 0.5em;
        color: #1aa7c8;
        content: "\f0da";
        font-family: FontAwesome;
        display: inline-block;
    }    
}

/*========= ボタンのためのCSS ===============*/
#marbb .openbtn{
    position:fixed;
    z-index: 99999;/*ボタンを最前面に*/
    top:70px;
    right: 10px;
    cursor: pointer;
    width: 50px;
    height:50px;
    background: rgba(17,17,17,0.9);
    box-shadow: 0 0 10px rgba(0,0,0,0.3);
    display: none;
}
/*×に変化*/	
#marbb .openbtn span{
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    height: 3px;
    background-color: #fff;
    width: 60%;
    box-shadow: 0 0 10px #000;
}
#marbb .openbtn span:nth-of-type(1) {
    top:13px;	
}
#marbb .openbtn span:nth-of-type(2) {
    top:23px;
}
#marbb .openbtn span:nth-of-type(3) {
    top:33px;
}
#marbb .openbtn.active span {
    box-shadow: none;
}
#marbb .openbtn.active span:nth-of-type(1) {
    top: 18px;
    left: 18px;
    transform: translateY(6px) rotate(-45deg);
    width: 30%;
}
#marbb .openbtn.active span:nth-of-type(2) {
    opacity: 0;
}
#marbb .openbtn.active span:nth-of-type(3){ 
    top: 30px;
    left: 18px;
    transform: translateY(-6px) rotate(45deg);
    width: 30%;
}

@media screen and (min-width:768px) {
    #marbb .openbtn {
        display: none;
    }
    #marbb #g-nav {
        max-width: 1170px;
        margin: 0 auto;
        background: #fff;
    }
    #marbb #g-nav ul {
        display: flex;
        justify-content: center;
    }
    #marbb #g-nav ul li {
        text-align: center;
    }
    #marbb #g-nav ul li a {
        display: block;
        padding: 15px 1.5em;
        font-weight: 500;
    }
    #marbb #g-nav ul li a:after {
        color: #1aa7c8;
        content: "\f0dd";
        font-family: FontAwesome;
        display: inline-block;
        line-height: 1;
        width: 100%;
    }
    /*上部メニュー固定*/
    #marbb #g-nav.nav-fixed {
        position: fixed;
        top: 114px;
        left: 0;
        box-shadow: 0 0 9px rgba(0,0,0,0.2);
        width: 100%;
        max-width: none;
        background: #fff;
        z-index: 100;
    }
}

@media screen and (min-width:1280px) {
    #marbb #g-nav ul li a {
        font-size: 1.5em;
        padding: 25px 1.5em;
    }
}

@media screen and (min-width:1024px) {
    /*上部メニュー固定*/
    #marbb #g-nav.nav-fixed {
        top: 0;
    }
    #marbb #g-nav.nav-fixed ul li a {
        padding-top: 15px;
        padding-bottom: 15px;
        font-size: 1.25em;
    }
    #marbb #g-nav.nav-fixed ul li a:after {
        margin-left: 0.5em;
        vertical-align: text-top;
        width: auto;
    }
}




/*---lead--------------------------------------------------*/
#marbb #lead {
    padding: 60px 15px 65px;
    background: #efefef;
}
#marbb #lead > p:first-child {
    margin-bottom: 30px;
    font-size: 1.5em;
}
#marbb #lead > p:last-child {
    margin-top: 15px;
}
#marbb #lead > h1 span {
    margin-bottom: 15px;
    display: inline-block;
    font-size: 1.25em;
}

@media screen and (min-width:768px) {
    #marbb #lead {
        padding: 6.25vw 15px calc(6.25vw + 5px);
    }
}

@media screen and (min-width:1280px) {
    #marbb #lead {
        padding: 90px 15px 100px;
    }
    #marbb #lead > p:first-child {
        font-size: 2em;
    }
    #marbb #lead > h1 span {
        font-size: 2em;
        margin-bottom: 30px;
    }
    #marbb #lead > h1 img {
        width: 24vw;
        max-width: 350px;
    }
    #marbb #lead > p:last-child {
        font-size: 1.5em;
        margin-top: 30px;
    }
}




/*---intro--------------------------------------------------*/
#marbb #intro {
    background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/intro_bg_sp.png') no-repeat center top;
    background-size: 100% auto;
    padding: 72vw 15px 65px;
}
#marbb #intro h2 {
    font-size: 2.5em;
    font-weight: 500;
    margin-bottom: 30px;
}
#marbb #intro p {
    line-height: 2;
}

@media screen and (min-width:768px) {
    #marbb #intro {
        background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/intro_bg_pc.png') no-repeat center right;
        background-size: auto 100%;
        padding: 0 15px;
        aspect-ratio: 16/9;
        display: flex;
        flex-wrap: wrap;
        align-content: center;
    }
    #marbb #intro p {
        padding-right: calc(50% + 30px);
    }
}

@media screen and (min-width:1280px) {
    #marbb #intro {
        padding: 0 calc((100% - 1170px) / 2);
    }
    #marbb #intro h2 {
        font-size: 3em;
    }
    #marbb #intro p {
        font-size: 1.25em;
    }
}




/*---.section共通--------------------------------------------------*/
#marbb .section {
    padding: 60px 15px 90px;
}
#marbb .section > h2 {
    font-size: 2.5em;
    margin-bottom: 30px;
    font-weight: 500;
}
#marbb .section .section_lead {
    line-height: 2;
    margin-bottom: 45px;
}
#marbb .section .number_list > li {
    position: relative;
    padding-top: 45px;
}
#marbb .section .number_list > li:not(:last-child) {
    margin-bottom: 90px;
}
#marbb .section .number_list > li:before {
    position: absolute;
    top: 0;
    right: 0;
}
#marbb .section .number_list > li:nth-child(1):before {
    content: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/num01.svg');
}
#marbb .section .number_list > li:nth-child(2):before {
    content: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/num02.svg');
}
#marbb .section .number_list > li:nth-child(3):before {
    content: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/num03.svg');
}
#marbb .section .number_list > li:nth-child(4):before {
    content: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/num04.svg');
}
#marbb .section .number_list li h3 {
    font-size: 1.5em;
    font-weight: bold;
    margin-bottom: 15px;
}
#marbb .section .number_list > li > p:not(:last-child) {
    margin-bottom: 30px;
}

@media screen and (min-width:768px) {
    #marbb .section .number_list > li {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: max-content 1fr;
        grid-gap: 0 30px;
    }
    #marbb .section .number_list > li:before {
        right: inherit;
        left: -15px;
    }
    #marbb .section .number_list > li:not(:last-child) {
        margin-bottom: 45px;
    }
    #marbb .section .number_list > li h3, #marbb .section .number_list > li p {
        grid-column: 1 / 2;
    }
    #marbb .section .number_list > li p {
        margin-bottom: 0;
    }
    #marbb .section .number_list > li p.img {
        grid-column: 2 / 3;
        grid-row: 1 / 3;
    }
}

@media screen and (min-width:1280px) {
    #marbb .section {
        padding: 90px calc((100% - 970px) / 2) 120px;
    }
    #marbb .section > h2 {
        font-size: 3em;
    }
    #marbb .section .section_lead {
        font-size: 1.25em;
        margin-bottom: 90px;
    }
    #marbb #reason .number_list {
        padding: 0 calc((100% - 970px) / 2);
    }
    #marbb .section .number_list > li:before {
        right: inherit;
        left: -60px;
    }
}





/*---reason--------------------------------------------------*/
#marbb #reason {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
}
#marbb #reason > h2 {
    width: 100%;
    margin: 0 0 30px 0;
    font-size: 1.5em;
    background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/bubble_bg.jpg') no-repeat center;
    background-size: cover;
    line-height: 1.2;
    padding: 35px 0 30px;
    font-weight: bold;
}
#marbb #reason > h2 span {
    font-size: 1.33333em;
}
#marbb #reason > .section_lead {
    padding: 0 15px;
}
#marbb #reason .number_list {
    padding: 0 15px;
}
#marbb #reason .number_list li > ol li {
    position: relative;
    background: #efefef;
    overflow: hidden;
    padding: 30px;
}
#marbb #reason .number_list li > ol li:after {
    content: "";
    display: block;
    width:0;
    height:0;
    border-style:solid;
    border-width: 60px 60px 60px 0;
    border-color: transparent #DCDDDD transparent transparent;
    position: absolute;
    top: -40px;
    left: -10px;
    transform: rotate(45deg);
    z-index: 0;
}
#marbb #reason .number_list li > ol li:not(:last-child) {
    margin-bottom: 15px;
}
#marbb #reason .number_list li > ol li .step_num {
    display: inline-block;
    position: absolute;
    top: 15px;
    left: 15px;
    z-index: 1;
}
#marbb #reason .number_list li > ol li > .img {
    margin-bottom: 30px;
}
#marbb #reason .number_list li > ol li > .img img {
    height: 180px;
}

@media screen and (max-width:767px) {
    #marbb #reason .number_list li:nth-child(4) .img img {
        max-width: 345px;
    }
}

@media screen and (min-width:768px) {
    #marbb #reason > h2 {
        font-size: 2em;
        padding: 65px 0 60px;
    }
    #marbb #reason > .section_lead {
        text-align: center;
    }
    #marbb #reason .number_list {
        padding-left: 15px;
        padding-right: 15px;
    }
    #marbb #reason .number_list li:nth-child(3) {
        grid-template-columns: 1fr;
    }
    #marbb #reason .number_list li:nth-child(3) > ol {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        grid-gap: 15px;
    }
    #marbb #reason .number_list li:nth-child(3) > ol li:not(:last-child) {
        margin: 0;
    }
    #marbb #reason .number_list li:nth-child(3) > ol li > .img img {
        max-height: 180px;
        height: 18vw;
    }
}

@media screen and (min-width:1280px) {
    #marbb #reason > h2 {
        margin-bottom: 90px;
    }
    #marbb #reason .number_list {
        padding-left: calc((100% - 970px) / 2);
        padding-right: calc((100% - 970px) / 2);
    }
    #marbb #reason .number_list li > ol li {
        padding: 45px;
    }
}





/*---merit--------------------------------------------------*/
#marbb #merit {
    background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/marbbsMERIT_sp.svg') no-repeat top right;
    background-color: #efefef;
    padding: 60px 0 90px;
}
#marbb #merit h2 {
    font-size: 2.5em;
    padding: 0 15px;
    margin-bottom: 30px;
    font-weight: 500;
}
#marbb #merit > p {
    line-height: 2em;
    padding: 0 15px;
    margin-bottom: 105px;
}
#marbb #merit > ul li {
    width: calc(100vw - 60px);
    background: rgba(255, 255, 255, 0.7);
    padding: 0 15px 30px;
    position: relative;
}
#marbb #merit > ul li:nth-child(2n) {
    margin-left: 60px;
}
#marbb #merit > ul li:after {
    content: "";
    display: block;
    background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/marbbsMERIT_pc.svg') no-repeat left bottom;
    background-size: contain;
    width: 275px;
    height: 46px;
    transform: rotate(90deg);
    position: absolute;
    right: -160px;
    bottom: 114px;
    opacity: 0.7;
}
#marbb #merit > ul li:nth-child(2n):after {
    left: -145px;
    right: inherit;
}
#marbb #merit > ul li:not(:last-child) {
    margin-bottom: 150px;
}
#marbb #merit > ul li > .img:first-child {
    width: calc(100vw - 60px);
    margin: 0 0 15px 45px;
    position: relative;
    top: -60px;
    z-index: 1;
}
#marbb #merit > ul li:nth-child(2n) > .img:first-child {
    margin-left: -75px;
}
#marbb #merit > ul li > h3 {
    font-weight: bold;
    font-size: 1.5em;
    margin-top: -60px;
    margin-bottom: 15px;
}
#marbb #merit > ul li > h3 span {
    font-size: 0.57em;
}
#marbb #merit > ul li > .merit_detail {
    margin-top: 15px;
    display: grid;
    grid-template-columns: 1fr;
    grid-gap: 15px;
}
#marbb #merit > ul li:nth-child(4) > .merit_detail {
    grid-gap: 30px;
}

@media screen and (min-width:768px) {
    #marbb #merit > p {
        font-size: 1.25em;
    }
    #marbb #merit > ul li {
        padding: calc(((40vw/3)*2) - 45px - 6em) 30px 30px;
        width: calc(100vw - 45px);
    }
    #marbb #merit > ul li:nth-child(2n) {
        margin-left: 45px;
    }
    #marbb #merit > ul li:after {
        background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/marbbsMERIT_pc.svg') no-repeat left bottom;
        background-size: contain;
        width: 100%;
        height: 45px;
        transform: rotate(0deg);
        position: absolute;
        right: inherit;
        bottom: inherit;
        top: -45px;
        left: 0;
    }
    #marbb #merit > ul li:nth-child(2n):after {
        left: inherit;
        right: 0;
        background-position: right bottom;
    }
    #marbb #merit > ul li > .img:first-child {
        width: 40vw;
        margin: 0;
        position: absolute;
        top: -45px;
        right: -45px;
    }
    #marbb #merit > ul li:nth-child(2n) > .img:first-child {
        margin-left: /*-90px*/0;
        right: inherit;
        left: -45px;
    }
    #marbb #merit > ul li > h3 {
        font-size: 2em;
        margin-top: /*calc((1em* 1.6* 4)* -1)*/ 0;
    }
    #marbb #merit > ul li:nth-child(2n) > h3 {
        padding-left: calc(40vw - 45px);
    }
    #marbb #merit > ul li > .merit_detail {
        grid-template-columns: repeat(2, 1fr);
        grid-gap: 30px;
        margin-top: 30px;
    }
    #marbb #merit > ul li > .merit_detail > .txt_small {
        grid-column: 1/3;
        margin-top: -15px;
    }
    #marbb #merit > ul li:nth-child(3) > .merit_detail {
        grid-template-columns: 1fr;
    }
    #marbb #merit > ul li:nth-child(4) > .merit_detail p {
        grid-column: 1/3;
    }
    #marbb #merit > ul li:nth-child(4) > .merit_detail img:last-child {
        grid-column: 1/3;
        width: calc((100% - 30px) / 2);
    }
}

@media screen and (min-width:1080px) {
    #marbb #merit {
        background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/marbbsMERIT_pc.svg') no-repeat top right;
        background-color: #efefef;
        padding: 90px calc((100% - 970px) / 2) 120px;
    }
    #marbb #merit h2 {
        font-size: 3em;
    }
    #marbb #merit > ul li {
        width: calc(100% - 45px);
        padding: 90px 45px 45px;
    }
    #marbb #merit > ul li > .img:first-child {
        width: 40%;
        margin: 0;
    }
    #marbb #merit > ul li > h3 {
        font-size: 2.5em;
    }
    #marbb #merit > ul li:nth-child(2n) > h3 {
        padding-left: calc(370px - 45px);
    }
    #marbb #merit > ul li > .merit_detail {
        grid-gap: 45px;
        margin-top: 45px;
    }
    #marbb #merit > ul li:nth-child(4) > .merit_detail {
        grid-gap: 45px;
    }
    #marbb #merit > ul li:nth-child(4) > .merit_detail img:last-child {
        width: calc((100% - 45px) / 2);
    }
}




/*---about--------------------------------------------------*/
#marbb #about {
    background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/nano-bubble_sp.svg') no-repeat top right;
}

@media screen and (min-width:1280px) {
    #marbb #about {
        background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/nano-bubble_pc.svg') no-repeat top right;
    }
}




/*---howto--------------------------------------------------*/
#marbb #howto {
    border: solid 10px #111;
    padding: 60px 15px 100px;
}
#marbb #howto h2 {
    font-size: 2.5em;
    text-align: center;
    line-height: 1;
    font-weight: bold;
    margin-bottom: 45px;
}
#marbb #howto h2 > .txt_small {
    font-size: 0.6em;
}
#marbb #howto > dl {
    margin-bottom: 30px;
}
#marbb #howto > dl dd {
    margin-top: 5px;
}
#marbb #howto > dl dd:before {
    content: "";
    display: inline-block;
    height: 20px;
    width: 20px;
    margin-right: 0.5em;
    vertical-align: middle;
}
#marbb #howto > dl dd:first-of-type:before {
    background: #d0e3e7;
}
#marbb #howto > dl dd:nth-of-type(2):before {
    background: #eddcd1;
}
#marbb #howto .howto_img {
    border-top: solid 1px #aaa;
    border-bottom: solid 1px #aaa;
    padding: 15px 0;
    overflow-x: scroll;
    margin-bottom: 45px;
}
#marbb #howto .howto_img img {
    height: 532px;
    width: auto;
    max-width: none;
}
#marbb #howto .howto_point:not(:last-child) {
    margin-bottom: 45px;
}
#marbb #howto .howto_point h3 .wbg {
    display: inline-block;
    margin-bottom: 15px;
    background: #fff;
    position: relative;
    padding-right: 0.5em;
    font-weight: bold;
    /*font-size: 1.25em;*/
}
#marbb #howto .howto_point h3 .wbg:after {
    content: "";
    display: block;
    width: calc(100vw - 51px);
    height: 1px;
    background: #111;
    position: absolute;
    top: 50%;
    left: 1px;
    transform: translateY(-50%);
    z-index: -1;
}
#marbb #howto .howto_point:not(:last-of-type) {
    margin-bottom: 45px;
}
#marbb #howto .howto_point > dl:not(:last-child) {
    margin-bottom: 15px;
}
#marbb #howto .howto_point > dl dt {
    margin-bottom: 5px;
    font-weight: bold;
    padding: 5px 15px;
    width: 60%;
    max-width: 200px;
}
#marbb #howto .howto_point > dl dt.blue {
    background: #d0e3e7;
    color: #3490ad;
}
#marbb #howto .howto_point > dl dt.orange {
    background: #eddcd1;
    color: #e49f67;
}
#marbb #howto .howto_point > dl dt.gray {
    background: #dbdcdc;
    color: #727171;
}

@media screen and (min-width:1280px) {
    #marbb #howto {
        padding: 90px calc((100% - 1190px) / 2) 120px;
    }
    #marbb #howto h2 {
        font-size: 3em;
    }
    #marbb #howto > dl {
        text-align: right;
        margin-bottom: 45px;
    }
    #marbb #howto > dl dd {
        display: inline-block;
    }
    #marbb #howto .howto_img {
        padding: 30px 0;
        margin-bottom: 90px;
        overflow-x: auto;
    }
    #marbb #howto .howto_img img {
        height: auto;
        width: 100%;
    }
    #marbb #howto .howto_point {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }
    #marbb #howto .howto_point h3 {
        grid-column: 1 / 3;
    }
    #marbb #howto .howto_point h3 .wbg {
        font-size: 1.25em;
    }
    #marbb #howto .howto_point h3 .wbg:after {
        width: 1169px;
    }
    #marbb #howto .howto_point > dl:nth-last-child(-n+2) {
        margin-bottom: 0;
    }
    #marbb #howto .howto_point > dl dt {
        display: inline-block;
    }
}




/*---voice--------------------------------------------------*/
#marbb #voice {
    padding: 60px 15px 90px;
    background: #efefef;
}
#marbb #voice h2 {
    font-size: 4em;
    line-height: 1;
    font-weight: 500;
    margin-bottom: 10px;
}
#marbb #voice h2 + p {
    margin-bottom: 30px;
}
#marbb #voice .movie {
    margin-bottom: 60px;
}
#marbb #voice .movie .movie_cover {
    aspect-ratio: 16/9;
    width: 100%;
    height: auto;
}
#marbb #voice .movie .movie_cover:not(:last-child) {
    margin-bottom: 30px;
}
#marbb #voice .movie .movie_cover iframe {
    width: 100%;
    height: 100%;
}
#marbb #voice .voice_banner {
    margin-bottom: 15px;
}
#marbb #voice .voice_banner a {
    border: solid 1px #111;
    background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/salonsvoice_banner.png') no-repeat center bottom;
    background-size: cover;
    color: #fff;
    font-size: 2em;
    display: inline-block;
    width: 100%;
    height: auto;
    padding: 15px;
    text-align: center;
    text-shadow: 0 0 10px rgba(0,0,0,0.7);
}

@media screen and (min-width:768px) {
    #marbb #voice .voice_banner a {
        width: 80vw;
        max-width: 800px;
        padding: 1em;
    }
    #marbb #voice .movie {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        margin-bottom: 90px;
    }
    #marbb #voice .movie .movie_cover {
        width: calc((100% - 15px) / 2);
        height: auto;
    }
    #marbb #voice .movie .movie_cover:nth-child(2n) {
        margin-left: 15px;
    }
}

@media screen and (min-width:1280px) {
    #marbb #voice {
        padding: 90px calc((100% - 970px) / 2) 120px;
    }
    #marbb #voice h2 {
        font-size: 6em;
    }
    #marbb #voice h2 > .txt_small {
        font-size: 0.5em;
    }
    #marbb #voice h2 + p {
        font-size: 1.5em;
        margin-bottom: 60px;
    }
    #marbb #voice .movie .movie_cover {
        width: calc((100% - 30px) / 2);
        height: auto;
    }
    #marbb #voice .movie .movie_cover:nth-child(2n) {
        margin-left: 30px;
    }
}




/*---taiken--------------------------------------------------*/
#marbb #taiken {
    padding: 60px 15px 90px;
    text-align: center;
}
#marbb #taiken h2 {
    font-size: 2.5em;
    font-weight: bold;
    margin-bottom: 45px;
}
#marbb #taiken > .showroom {
    margin-bottom: 60px;
}
#marbb #taiken > .showroom h3, #marbb #taiken > .visiting h3 {
    font-size: 1.5em;
    font-weight: bold;
    margin-bottom: 15px;
}
#marbb #taiken > .visiting h3 {
    margin-bottom: 30px;
}
#marbb #taiken > .showroom h3 + p {
    display: inline-block;
    padding: 5px 20px;
    background: #efefef;
    border-radius: 2em;
    margin-bottom: 30px;
}
#marbb #taiken > .showroom .showroom_map {
    position: relative;
}
#marbb #taiken > .showroom .showroom_map > ul, #marbb #taiken > .visiting ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
#marbb #taiken > .showroom .showroom_map > ul {
    margin-top: -2px;
    margin-bottom: 30px;
}
#marbb #taiken > .showroom .showroom_map > ul li, #marbb #taiken > .visiting ul li {
    width: calc((100% - 15px) / 2);
    background: #dfeff5;
    padding: 10px 10px/*15px*/;
}
#marbb #taiken > .showroom .showroom_map > ul li h4, #marbb #taiken > .visiting ul li h4 {
    font-weight: bold;
}
#marbb #taiken > .showroom .showroom_map > ul li a, #marbb #taiken > .visiting ul li a:not(.tel) {
    color: #fff;
    background: #1aa7c8;
    border-radius: 2em;
    padding: 5px 15px;
    margin-top: 5px;
    display: inline-block;
}
#marbb #taiken > .showroom .showroom_map > ul li a:after, #marbb #taiken > .visiting ul li a:not(.tel):after {
    content: "\f0da";
    font-family: FontAwesome;
    display: inline-block;
    margin-left: 0.5em;
}
#marbb #taiken > .showroom .showroom_map > ul li.osaka {
    position: absolute;
    top: 10px;
    left: 0;
}
#marbb #taiken > .showroom .showroom_map > ul li.tokyo {
    background: #ffe9dc;
}
#marbb #taiken > .showroom .showroom_map > ul li.tokyo a {
    background: #ff8828;
}
#marbb #taiken > .visiting ul li a.tel {
    color: #1aa7c8;
    font-size: 1.7em;
    letter-spacing: -0.05em;
    white-space: nowrap;
    margin-top: 5px;
    line-height: 1.3;
    display: inline-block;
}

@media screen and (min-width:768px) and (max-width:1079px) {
    #marbb #taiken > .showroom .showroom_map .map_img img {
        width: 70vw;
    }
    #marbb #taiken > .showroom .showroom_map > ul {
        justify-content: space-around;
    }
    #marbb #taiken > .showroom .showroom_map > ul li {
        width: 40vw;
    }
    #marbb #taiken > .showroom .showroom_map > ul li.osaka {
        top: inherit;
        left: calc((20vw - 30px) / 4);
        bottom: 49vw;
    }
}

@media screen and (min-width:1080px) {
    #marbb #taiken {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-column-gap: 30px;
    }
    #marbb #taiken h2 {
        grid-column: 1 / 3;
        margin-bottom: 60px;
    }
    #marbb #taiken > .showroom .showroom_map > ul li, #marbb #taiken > .visiting ul li {
        padding: 15px 10px;
    }
    #marbb #taiken > .visiting ul {
        display: inherit;
    }
    #marbb #taiken > .visiting ul li {
        width: 100%;
    }
    #marbb #taiken > .visiting ul li:not(:last-child) {
        margin-bottom: 15px;
    }
    #marbb #taiken > .showroom .showroom_map > ul li h4, #marbb #taiken > .visiting ul li h4, #marbb #taiken > .showroom h3 + p {
        font-size: 1.25em;
    }
}

@media screen and (min-width:1080px) and (max-width:1279px) {
    #marbb #taiken > .showroom .showroom_map > ul li.osaka p {
        letter-spacing: -0.05em;
        white-space: nowrap;
    }
}

@media screen and (min-width:1280px) {
    #marbb #taiken {
        padding: 90px calc((100% - 1170px) / 2) 120px;
        grid-column-gap: 60px;
    }
    #marbb #taiken > .showroom h3, #marbb #taiken > .visiting h3 {
        margin-bottom: 30px;
    }
    #marbb #taiken > .showroom h3 + p {
        font-weight: 500;
        padding: 5px 30px;
        margin-bottom: 30px;
    }
    #marbb #taiken > .showroom .showroom_map .map_img img {
        width: 100%;
    }
    #marbb #taiken > .showroom .showroom_map > ul li.osaka {
        top: inherit;
        bottom: 66%;
    }
    #marbb #taiken > .showroom .showroom_map > ul li a, #marbb #taiken > .visiting ul li a:not(.tel) {
        padding: 10px 30px;
        margin-top: 15px;
        font-size: 1.25em;
    }
    #marbb #taiken > .visiting ul li {
        padding: 30px;
    }
    #marbb #taiken > .visiting ul li a.tel {
        font-size: 2.75em;
        letter-spacing: normal;
        font-weight: bold;
    }
}




/*---bg_buy--------------------------------------------------*/
#marbb #bg_buy {
    padding: 60px 15px 90px;
    background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/buymerit_bg.jpg') no-repeat center;
    background-size: cover;
    text-align: center;
}
#marbb #bg_buy h2 {
    color: #fff;
    font-size: 2em;
    font-weight: bold;
    margin-bottom: 45px;
}
#marbb #bg_buy > ul {
    /*display: flex;
    flex-wrap: wrap;
    justify-content: center;*/
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 0 15px;
    align-content: center;
}
#marbb #bg_buy > ul li:not(:first-child) {
}
#marbb #bg_buy > ul li:first-child {
    grid-column: 1 / 3;
}
#marbb #bg_buy > ul li .circle {
    aspect-ratio: 1/1;
    background: #fff;
    margin: 0 auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-content: center;
    border-radius: 50%;
    max-width: 240px;
    height: auto;
}
#marbb #bg_buy > ul li:first-child .circle {
    width: calc((100% - 15px) / 2);
}
#marbb #bg_buy > ul li .circle h3 {
    font-size: 1.5em;
    font-weight: bold;
    line-height: 1.2;
    letter-spacing: -0.05em;
    margin-bottom: 10px;
    width: 100%;
}
#marbb #bg_buy > ul li .circle h3 + p {
    letter-spacing: -0.05em;
}
#marbb #bg_buy > ul li .circle h3 + p a {
    text-decoration: underline;
}
#marbb #bg_buy > ul li .circle h3 + p a:before {
    content: "\f0da";
    font-family: FontAwesome;
    display: inline-block;
    margin-right: 0.3em;
}

@media screen and (max-width:768px) {
    #marbb #bg_buy > ul li:last-child .circle h3 + p {
        margin-bottom: 10px;
    }
}

@media screen and (min-width:768px) {
    #marbb #bg_buy {
        padding-left: 30px;
        padding-right: 30px;
        background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/buymerit_bg_pc.jpg') no-repeat center;
        background-size: cover;
    }
    #marbb #bg_buy > ul {
        grid-template-columns: repeat(3, 1fr);
        grid-gap: 30px;
    }
    #marbb #bg_buy > ul li:first-child {
        grid-column: 1 / 2;
    }
    #marbb #bg_buy > ul li:first-child .circle {
        width: 100%;
    }
}

@media screen and (min-width:1080px) {
    #marbb #bg_buy {
        padding: 90px 0 120px;
    }
    #marbb #bg_buy h2 {
        font-size: 2.5em;
        margin-bottom: 60px;
    }
    #marbb #bg_buy > ul {
        display: flex;
        justify-content: center;
    }
    #marbb #bg_buy > ul li {
        margin: 0 30px;
    }
    #marbb #bg_buy > ul li .circle h3 {
        font-size: 1.75em;
        margin-bottom: 15px;
        letter-spacing: normal;
    }
    #marbb #bg_buy > ul li .circle h3 + p {
        font-size: 1em;
        letter-spacing: normal;
    }
}




/*---spec--------------------------------------------------*/
#marbb #spec {
    padding: 60px 15px 40px;
    background-image: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/spec_sp.svg'), url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/spec_bg_sp.svg');
    background-repeat: no-repeat;
    background-position: top right, right top;
}
#marbb #spec h2 {
    font-size: 2.5em;
    margin-bottom: 45px;
    font-weight: 500;
}
#marbb #spec .spec_detail:not(:last-child) {
    margin-bottom: 60px;
}
#marbb #spec .spec_detail > .img {
    margin-bottom: 30px;
    text-align: center;
}
#marbb #spec .spec_detail table {
    margin-bottom: 30px;
}
#marbb #spec .spec_detail.marbb2 table {
    background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/spec_marbb2.svg') no-repeat right top;
}
#marbb #spec .spec_detail.marbb3 table {
    background: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/spec_marbb3.svg') no-repeat right top;
}
#marbb #spec .spec_detail table tr th, #marbb #spec .spec_detail table tr td {
    vertical-align: middle;
    font-size: 0.85em;
}
#marbb #spec .spec_detail table tr:not(:last-child) th, #marbb #spec .spec_detail table tr:not(:last-child) td {
    padding-bottom: 15px;
}
#marbb #spec .spec_detail table tr th {
    width: 35%;
}
#marbb #spec .spec_detail .more_button {
    text-align: center;
}
#marbb #spec .spec_detail .more_button a {
    width: 80%;
    max-width: 280px;
    display: inline-block;
    padding: 15px;
    border: solid 1px #111;
    transition: 0.5s;
}
#marbb #spec .spec_detail .more_button a:after {
    content: "\f0da";
    font-family: FontAwesome;
    display: inline-block;
    margin-left: 0.5em;
}
#marbb #spec .spec_detail .more_button a:hover {
    background: #111;
    color: #fff;
    opacity: 1;
}

@media screen and (min-width:768px) {
    #marbb #spec {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-column-gap: 30px;
        background-image: url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/spec_sp.svg'), url('/_ui/responsive/common/ui_assets/online/bg/pickup/marbb/img/spec_bg.svg');
        background-repeat: no-repeat;
        background-position: top right, center top;
        background-size: auto, auto 45vw;
    }
    #marbb #spec h2 {
        grid-column: 1 / 3;
    }
    #marbb #spec .spec_detail > .img img {
        max-width: 80%;
    }
}

@media screen and (min-width:1280px) {
    #marbb #spec {
        padding: 90px calc((100% - 970px) / 2);
        grid-column-gap: 60px;
        background-size: auto 100px, contain;
    }
    #marbb #spec .spec_detail > .img {
        margin-bottom: 45px;
    }
    #marbb #spec .spec_detail table {
        margin-bottom: 45px;
    }
}











/*---フェードイン-------------------------------------------*/
#marbb .fadeIn {
  transform: translate3d(0, 20px, 0);
  transition: 1s;
  opacity: 0;
}

#marbb .fadeIn.animated {
  transform: translate3d(0, 0, 0);
  opacity: 1;
}









/**/