@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap');
/* common */
h2 {
    margin: 0 auto;
    text-align: center;
}
h2.h2_head{
    position: relative;
    padding-top: 20vw;
}
img{
    width: 100%;
}
#feature h2.h2_head,#voice h2.h2_head,#step h2.h2_head{
    padding-top: 16vw;
}
h2.h2_head p{
    background-color: #5CB037;
    padding: 0.1em 0.3em;
    display: inline-block;
    text-align: center;
    color: #FFFFFF;
    font-size: 7vw;
    white-space: pre;
    margin:3vw auto 3vw;
    z-index: 1;
    position: relative;
}
h2.h2_head p + br + p{
    margin-top: -2vw;
}
h2.h2_head p + p{
    margin-top: -2vw;
}
h2.h2_head img{
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 0vw;
}

#whats_this h2.h2_head img{
    width: 67vw;
}
#feature h2.h2_head img{
    width: 36vw;
    top: 2vw;
}
#howtouse h2.h2_head img{
    width: 50vw;
    top: 5vw;
}
#voice h2.h2_head img{
    width: 30vw;
    top: 4vw;
}
#step h2.h2_head img{
    width: 25vw;
    top: 2vw;
}


.backline {
    display: inline-block;
    position: relative;
    margin: 1.66667vw auto 0;
}
.backline span{
    position: relative;
    z-index: 1;
}
.backline::before {
    content: "";
    display: block;
    background-color: #EDBA0E;
    opacity: 0.4;
    position: absolute;
    transform: translateX(-50%);
    bottom: -5%;
    left: 50%;
    width: 110%;
    height: 0.6em;
    z-index: 0;
}
.anno {
    color: #333333;
    font-size: 3.2vw;
    text-align: left;
    padding-left: 1em;
    text-indent: -1.2em;
    line-height: 1.8;
}
.img_center img {
    display: block;
    margin: 0 auto;
}
.blankLink {
    font-size: 3.2vw;
    color: #333333;
    margin-left: 2em;
}
.blankLink::after {
    content: "";
    display: inline-block;
    width: 3.73333vw;
    height: 3.73333vw;
    margin-left: 4vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_blank.png);
    background-repeat: no-repeat;
    background-size: contain;
}

/* アコーディオン */
.acd-check {
	display: none;
}
.acd-label {
	display: block;
	margin-bottom: 1px;
    position: relative;
}
.acd-content {
	height: 0;
	opacity: 0;
	transition: .5s;
	visibility: hidden;
}
.acd-content *{
	height: 0;
}
.acd-check:checked + .acd-label + .acd-content {
	height: auto;
	opacity: 1;
	/*padding: 10px;*/
	visibility: visible;
}
.acd-check:checked + .acd-label + .acd-content *{
	height: auto;
}

/*========= 流れるテキスト ===============*/

/*全共通*/

.main_visual dd,.main_visual dt{
    letter-spacing: normal;
}

.slide-in {
	overflow: hidden;
    display: inline-block;
}

.slide-in_inner {
	display: inline-block;

}
@keyframes img-wrap {
    100% {
        transform: translateX(100%);
    }
}

.kv_text_item {
    overflow: hidden;
    position: relative;
    opacity: 0;
    line-height: 1;
}

.kv_text_item:before {
    background: #fff;
    bottom: 0;
    content: '';
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    z-index: 1;
    height: 100%;
}

.kv_text_item_01 {
    width:49.6vw;
    top: -17.6vw;
}
.kv_text_item_02 {
    width:58.67vw;
    top: -14vw;
}
.kv_text_item_03 {
    width:40.53vw;
    top: -11vw;
}

.kv_text_item_04 {
    width: 44.07vw;
    top: -8.67vw;
    height: 27.4vw;
    left: -11.13vw;
    transform: rotate(-1deg);
}
.kv_text_item_04 img{
    height: 100%;
}


.kv_text_item_01:before {
    width:49.7vw;
}
.kv_text_item_02:before {
    width:58.68vw;
}
.kv_text_item_03:before {
    width:40.54vw;
}
.kv_text_item_04:before {
    width:44.1vw;
    height: 27.4vw;
}

.kv_text_item.is_show {
    opacity: 1;
    transition: all 2s;
}

.kv_text_item.is_show:before {
    animation: img-wrap 2s cubic-bezier(.4, 0, .2, 1) forwards;
}

.kv_tab{
    position: absolute;
    top: 86vw;
    left: 0.67vw;
    display: none;
    width: 43.33vw;
}


/* header */
.global_header {
    background-color: #004B34;
    border-bottom: 1px solid #BED730;
    min-height: 49px;
    height: 49px;
    box-shadow: 0 6px 6px rgba(0,0,0,0.16);
    position: fixed;
}
.global_header .logo_area {
    margin: 4px 0 0 20px;
}
.global_header .logo_area .logo {
    height: auto;
    width: auto;
}
.global_header .logo_area .logo img {
    display: inline-block;
    width: 90px;
}
div#nav-drawer {
    background-color: #FFFFFF;
    width: 36px;
    height: 36px;
    margin: 6px 20px 0 0;
}
#nav-open {
    width: 36px;
    height: 36px;
    box-sizing: border-box;
    padding: 12px 10px;
}
#nav-open span, #nav-open span:before, #nav-open span:after {
    width: 16px;
    height: 1px;
    -webkit-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}
#nav-open span:before {
    bottom: -4.5px;
}
#nav-open span:after {
    bottom: -10px;
}
#nav-open.navi-active span {
    -webkit-transform: translateY(7px) rotate(-45deg);
    -ms-transform: translateY(7px) rotate(-45deg);
    transform: translateY(7px) rotate(-45deg);
}
#nav-open.navi-active span::before {
    opacity: 0;
}
#nav-open.navi-active span::after {
    -webkit-transform: translateY(-10px) rotate(90deg);
    -ms-transform: translateY(-10px) rotate(90deg);
    transform: translateY(-10px) rotate(90deg);
}
.login {
    display: block;
    text-align: unset;
    margin: 6px 8px 6px 0;
    float: right;
}
.login p {
    margin: 0;
}
.login p a{
    background-color: #BED730;
    display: inline-block;
    color: #FFFFFF;
    width: 68px;
    height: 36px;
    text-align: center;
    font-weight: bold;
    padding: 10px 0;
    line-height: 1;
}
#nav-content {
    background-color: #FFFFFF;
    top: 50px;
    padding-top: 16px;
    padding-bottom: 16px;
}
#nav-input:checked ~ #nav-content {
    box-shadow: 0 6px 6px rgb(0 0 0 / 16%);
}
.nav_link {
    position: relative;
    width: 89.33333vw;
    padding: 3vw 6vw;
    background-color: unset;
    border-bottom: 1px solid #D5D5D5;
    text-align: center;
    margin: 0 auto;
}
.nav_link:last-child {
    border-bottom: none;
}
.nav_link::after {
    display: none;
}
.nav_link a {
    color: #5CB037;
}


/* main */
.main_visual {
    padding-top: 0;
    background-image: unset;
    background-color: #F5FFF1;
}
.main_visual h1{
    position: relative;
    background-color: #FFFFFF;
    padding: 0;
    height: 159vw;
    width: 100vw;
    padding-top: 49px;
}
.main_visual h1 img {
    width: 100%;
}
.main_visual h1 .kv_img{
    position: relative;
    width: 96vw;
    margin: 0 auto;
    display: none;
}

.main_visual h1 .kv_img img {
    width: 100%;
    position: absolute;
    left: 0;
    top: 5.33vw;
    right: 0;
    margin: 0 auto;
}
.main_visual h1 .detail {
    width: 100vw;
    position: absolute;
    left: 0;
    top: 0;
    display: none;
}
.main_visual h1 .kv_text {
    position: absolute;
    top:86vw;
    left: 38.93vw;
}
.campaign {
    padding-top: 8vw;
    text-align: center;
}
.campaign h3 {
    color: #5CB037;
    font-size: 5.33333vw;
    font-weight: 600;
    text-align: center;
    margin: 0 auto 16px;
    width: 67%;
    position: relative;
}
.campaign h3::before {
    content: "";
    display: block;
    width: 2px;
    height: 61px;
    border-right: 2px dotted #5CB037;
    margin: 0;
    position: absolute;
    top: 0;
    left: -1%;
    -webkit-transform: translateY(3px) rotate(-15deg);
    -ms-transform: translateY(3px) rotate(-15deg);
    transform: translateY(3px) rotate(-15deg);
}
.campaign h3::after {
    content: "";
    display: block;
    width: 2px;
    height: 61px;
    border-right: 2px dotted #5CB037;
    margin: 0;
    position: absolute;
    top: 0;
    right: -1%;
    -webkit-transform: translateY(3px) rotate(15deg);
    -ms-transform: translateY(3px) rotate(15deg);
    transform: translateY(3px) rotate(15deg);
}
.campaign p.campaign_head {
    display: inline-block;
    color: #5CB037;
    font-size: 6.66667vw;
    font-weight: 600;
    text-align: center;
    margin: 0 auto;
    position: relative;
}
.acd-label {
    color: #5CB037;
    border-top: 1px solid #EDBA0E;
    border-bottom: 1px solid #EDBA0E;
    padding: 1.86667vw 8vw;
    margin-top: 10vw;
    margin-bottom: 4.26667vw;
    font-size: 4.8vw;
    font-weight: 700;
    position: relative;
}
.acd-label::before {
    content: "";
    width: 4.8vw;
    display: block;
    position: absolute;
    right: 5%;
    top: 50%;
    border-top: 2px solid #AEAEAE;
    transform: translateY(-50%) rotate(90deg);
    -webkit-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    transition: all 0.3s ease;
}
.acd-label::after {
    content: "";
    width: 4.8vw;
    display: block;
    position: absolute;
    right: 5%;
    top: 50%;
    border-top: 2px solid #AEAEAE;
    transform: translateY(-50%);
}
/*.acd-check:checked + .acd-label + .acd-content {
    padding: 0 6.13333vw 0;
}*/
.acd-check:checked + .acd-label::before {
    transform: translateY(-50%)rotate(0);
}
.campaign_desc {
    background-color: #F5FFF1;
}
.campaign_desc .campaign_desc_inner {
    text-align: center;
    width: 90%;
    margin: 0 auto;
}
.campaign_desc .campaign_desc_inner h3,.campaign_desc .campaign_desc_inner p.campaign_desc_read {
    color: #5CB037;
    text-align: center;
}
.campaign_desc .campaign_desc_inner h3{
    text-align: center;
}
.campaign_desc .campaign_desc_inner p.campaign_desc_read + .campaign_desc_anno .anno {
    text-align: left;
}
.campaign_desc .campaign_desc_inner h3,.campaign_desc .campaign_desc_inner p.campaign_desc_read span{
    font-weight: bold;
}
.campaign_desc .campaign_desc_inner h3{
    display: inline-block;
    padding: 0 2.66667vw;
    margin: 3vw auto 0;
    border-bottom: 2px dotted #5CB037;
    font-size: 5.33333vw;
}
.campaign_desc .campaign_desc_inner p.campaign_desc_read{
    font-size: 6.13333vw;
    margin: 2.66667vw auto;
}
.campaign_desc .campaign_desc_conditions{
    width: 89.33333vw;
    margin: 0 auto 6.4vw;
    border-bottom: 1px solid #D5D5D5;
}
.campaign_desc .campaign_desc_conditions dl{
    width: 81.06667vw;
    margin: 0 auto 5.33333vw;
    border-left: 2px dotted #5CB037;
}
.campaign_desc .campaign_desc_conditions dl dt,.campaign_desc .campaign_desc_conditions dl dd{
    font-size: 4.1vw;
    margin-left: 7.46667vw;
}
.campaign_desc .campaign_desc_conditions dl dt{
    color: #5CB037;
    margin-top: 4.93333vw;
    margin-bottom: 1.73333vw;
    position: relative;
}
.campaign_desc .campaign_desc_conditions dl dd{
    color: #333333;
    line-height: 2;
    font-weight: normal;
}
.campaign_desc .campaign_desc_conditions dl dt.campaign_desc_conditions_1::before{
    content: "";
    display: inline-block;
    width: 10.66667vw;
    height: 10.66667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/conditions_num_1.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    top: -2vw;
    left: -18%;
}
.campaign_desc .campaign_desc_conditions dl dt.campaign_desc_conditions_2::before{
    content: "";
    display: inline-block;
    width: 10.66667vw;
    height: 10.66667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/conditions_num_2.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    top: -2vw;
    left: -18%;
}
.campaign_desc .campaign_desc_conditions dl dt.campaign_desc_conditions_3::before{
    content: "";
    display: inline-block;
    width: 10.66667vw;
    height: 10.66667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/conditions_num_3.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    top: -2vw;
    left: -18%;
}

.campaign_another {
    background-color: #FFFFFF;
    width: 89.33333vw;
    border-radius: 20px;
    margin: 4.26667vw auto 0;
    padding: 5.33333vw 2.66667vw;
    text-align: center;
}
.campaign_another h3{
    color: #5CB037;
    font-size: 6.4vw;
    font-weight: 700;
    margin: 0 auto 4.26667vw;
    text-align: center;
}
.campaign_another h3::after{
    content: "";
    display: block;
    width: 12.8vw;
    border-bottom: 1px solid #EDBA0E;
    margin: 4.26667vw auto 0;
}
.campaign_another p{
    margin-bottom: 4.26667vw;
}
.campaign_another p:last-child{
    margin-bottom: 0;
}
.campaign_another p img{
    max-width: 84vw;
}

/* whats_this */
#whats_this {
    background-color: #FFFFFF;
    padding-top: 5.33333vw;
}
.whats_this_read {
    text-align: center;
    margin-top: 5.33333vw;
    margin-bottom: 4.26667vw;
}
.whats_this_read p{
    font-size: 4.8vw;
    color: #333333;
}
.whats_this_video {
    padding-bottom: 16vw;
    margin-top: 8vw;
    text-align: center;
}
.whats_this_video h3 {
    display: inline-block;
    font-size: 4.26667vw;
    color: #333333;
    text-align: center;
    line-height: 2;
    position: relative;
}
.whats_this_video h3::before {
    content: "";
    display: block;
    width: 2px;
    height: 6em;
    border-right: 2px dotted #5CB037;
    margin: 0;
    position: absolute;
    top: 0;
    left: -18%;
    -webkit-transform: translateY(3px) rotate(-30deg);
    -ms-transform: translateY(3px) rotate(-30deg);
    transform: translateY(3px) rotate(-30deg);
}
.whats_this_video h3::after {
    content: "";
    display: block;
    width: 2px;
    height: 6em;
    border-right: 2px dotted #5CB037;
    margin: 0;
    position: absolute;
    top: 0;
    right: -18%;
    -webkit-transform: translateY(3px) rotate(30deg);
    -ms-transform: translateY(3px) rotate(30deg);
    transform: translateY(3px) rotate(30deg);
}
.whats_this_video .video_wrap {
    width: 94.66667vw;
    padding-top: 22vw;
    margin: 0 auto;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_whatsthis_1.png);
    background-repeat: no-repeat;
    background-size: contain;
    min-height: 94.67vw;
}

.whats_this_video .tabs {
    margin-top: 50px;
    padding-bottom: 14.49275vw;
    width: 94.33816vw;
    margin: 0 auto;
    border-radius: 10px 10px 0 0;
    overflow: hidden;
}
.whats_this_video .tab_item {
    display: block;
    width: 42vw;
    height: 8.53333vw;
    margin-right: 1.5vw;
    background-color: #5CB037;
    line-height: 8.53333vw;
    font-size: 1.73333vw;
    text-align: center;
    color: #FFFFFF;
    float: left;
    text-align: center;
    font-weight: bold;
    border: 1px solid #FFFFFF;
    border-radius: 50px;
    transform: translateX(10%);
}
.whats_this_video .tab_item.tab_naraigoto ,
.whats_this_video .tab_item.tab_otsukai {
    margin-right: 0;
}
/*ラジオボタンを全て消す*/
.whats_this_video input[name="tab_item"] {
    display: none;
}

/*タブ切り替えの中身のスタイル*/
.whats_this_video .tab_content {
    display: none;
    width: 84vw;
    padding: 0;
    margin: 12vw auto 0;
    clear: both;
    overflow: hidden;
}
.whats_this_video .tab_content iframe{
    width: 100%;
    height: 48vw;
}
.whats_this_video #kurashi:checked ~ #kurashi_content,
.whats_this_video #otsukai:checked ~ #otsukai_content,
.whats_this_video #naraigoto:checked ~ #naraigoto_content {
    display: block;
}
.whats_this_video .tabs input#kurashi:checked + .tab_item {
    background-color: #FFFFFF;
    border-color: #5CB037;
    color: #5CB037;
}
.whats_this_video .tabs input#otsukai:checked + .tab_item {
    background-color: #FFFFFF;
    border-color: #5CB037;
    color: #5CB037;
}
.whats_this_video .tabs input#naraigoto:checked + .tab_item {
    background-color: #FFFFFF;
    border-color: #5CB037;
    color: #5CB037;
}

/* feature */
#feature {
    background-color: #FFFBEF;
    padding: 6.93333vw 1.92vw 16vw;
}

.feature_desc {
    width: 100%;
    margin-top: 8.53333vw;
    text-align: center;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_feature_1.png);
    background-repeat: no-repeat;
    background-size: cover;
}
.feature_desc h3 {
    display: inline-block;
    margin: 9.86667vw auto 0;
    font-size: 6.4vw;
    font-weight: bold;
    color: #5CB037;
    line-height: 1.4;
}
.feature_desc h3::before {
    content: "";
    display: block;
    width: 11.2vw;
    height: 11.2vw;
    margin: 0 auto 1.46667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_feature_1.png);
    background-repeat: no-repeat;
    background-size: contain;
}
.feature_desc h3::after {
    content: "";
    display: block;
    width: 15.2vw;
    height: 1px;
    margin: 4vw auto 0;
    border-bottom: 1px solid #EDBA0E;
}
.feature_desc_read {
    margin-top: 6vw;
    margin-bottom: 10vw;
    text-align: center;
}
.feature_desc_read p{
    font-size: 4.26667vw;
    color: #333333;
    margin-bottom: 0;
}
.border-dot {
    padding: 5.33333vw;
    border: 2px dotted #5CB037;
    border-radius: 20px;
}
.feature_desc dl{
    margin: 0 auto 5.86667vw;
    width: 89.06667vw;
}
.feature_desc dl dt{
    color: #5CB037;
    font-weight: bold;
    font-size: 4.26667vw;
    text-align: center;
    margin-bottom: 4.26667vw;
}
.feature_desc dl dd{
    color: #333333;
    font-size: 4.26667vw;
    text-align: left;
    margin-top: 4.26667vw;
}
dd.icon-check{
    padding-left: 9.06666vw;
    position: relative;
}
.icon-check::before {
    content: "";
    display: block;
    width: 6.93333vw;
    height: 6.4vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_feature_2.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
    left: 0;
}
.feature_desc.point1 .feature_desc_read{
    margin-top:6vw;
    margin-bottom: 10vw;
}
.triangle {
    width: 0;
    height: 0;
    margin: 0 auto;
    border-style: solid;
    border-width: 4.53333vw 6.66667vw 0 6.66667vw;
    border-color: #EDBA0E transparent transparent transparent;
}
.dotline-bottom {
    display: inline-block;
    margin: 0 auto;
    font-size: 5.33333vw;
    font-weight: bold;
    color: #5CB037;
    text-align: center;
}
.dotline-bottom::after {
    content: "";
    display: block;
    width: 110%;
    border-bottom: 2px dotted #5CB037;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
}
.feature_desc_solution {
    margin-top: 4.26667vw;
    text-align: center;
}
.feature_desc_solution dl {
    margin: 24.53333vw auto 1.86667vw;
    position: relative;
}
.feature_desc_solution dl::before {
    content: "";
    display: block;
    width: 33.33333vw;
    height: 18.66667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_illust_feature_1.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: -18.66667vw;
    left: 20%;
}
.feature_desc_solution dl::after {
    content: "";
    display: block;
    width: 28.66667vw;
    height: 27.86667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_balloon_feature_1.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: -21.33333vw;
    right: 5.33333vw;
}
.feature_desc_solution dl.border-dot {
    margin-top: 24.53333vw;
    padding-top: 3.2vw;
    position: relative;
}
.feature_desc_solution dl dt{
    display: inline-block;
    padding-left: 9.33333vw;
    margin-bottom: 3.2vw;
    position: relative;
}
.feature_desc_solution dl dt::before{
    content: "";
    display: block;
    width: 5.86667vw;
    height: 5.86667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_feature_3.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    left: 0;
}
.feature_desc_solution dl dd{
    display: inline-block;
    margin: 0 auto;
    font-size: 3.73333vw;
    position: relative;
}
.anno {
    color: #333333;
    font-size: 3.2vw;
}
.feature_desc_solution .anno{
    margin-left: 8.8vw;
}
.feature_desc_post {
    display: flex;
    justify-content: center;
    margin-top: 5.33333vw;
}
.feature_desc_post .post {
    width: 39.06667vw;
    height: 56vw;
    background-image:url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_back_feature_1.png);
    background-size: contain;
    background-repeat: no-repeat;
}
.feature_desc_post .post.top {
    transform: scale(1, -1);
}
.feature_desc_post .post:first-child {
    margin-right: 4.66667vw;
}
.feature_desc_post .post p{
    margin-top: 12.8vw;
    padding: 0 3.2vw;
    font-size: 3.2vw;
    line-height: 1.8;
}
.feature_desc_post .post.top p{
    transform: scale(1, -1);
    margin-top: 11.5vw;
}
.feature_desc_post .post p span{
    display: block;
    width: 11.6vw;
    margin: 1.06667vw auto 0;
}
.feature_desc_private {
    margin-top: 25vw;
    padding-bottom: 13.86667vw;
}
.feature_desc_private dl {
    margin: 0 auto 1.86667vw;
    text-align: center;
    position: relative;
}
.feature_desc_private dl::before {
    content: "";
    display: block;
    width: 18.13vw;
    height: 18.66667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_illust_feature_2_sp.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: -16.8vw;
    left: 33.6vw;
}
.feature_desc_private dl::after {
    content: "";
    display: block;
    width: 28.66667vw;
    height: 27.86667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_balloon_feature_2.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    top: -24vw;
    right: 53.33vw;
}
.feature_desc_private dl dt{
    display: inline-block;
    padding-left: 9.33333vw;
    margin-bottom: 3.2vw;
    position: relative;
}
.feature_desc_private dl dt::before{
    content: "";
    display: block;
    width: 5.86667vw;
    height: 5.86667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_feature_3.png);
    background-size: contain;
    background-repeat: no-repeat;
    position: absolute;
    left: 0;
}
.feature_desc_private dl dd {
    margin-top : 0;
}

.feature_desc.point2 {
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_feature_2.png);
    background-repeat: no-repeat;
    background-size: contain;
    padding-bottom: 4vw;
    min-height: 286.67vw;
}
.feature_desc.point2 h3::before {
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_feature_5.png);
    background-repeat: no-repeat;
    background-size: contain;
}
.feature_desc.point2 .slick-slide .img_scale img:hover {
    opacity: 1;
}
.feature_desc.point2 .slick-slide .img_scale .slider_bubble {
    display: none;
}

.feature_desc.point2 .slick-slide .img_scale .slider_bubble.bubble_01 {
    display: block;
}

.feature_desc.point2 .slick-slide .img_scale {
    position: relative;
    display: block;
}

.feature_desc.point2 .slick-slide img {
    max-width: 86vw;
    margin: 0 auto;
    display: block;
}
.feature_desc.point2 .slick-slide .img_scale .slider_bubble{
    position: absolute;
    width: 39.2vw;
    top: 0;
    left: 0;
}
.feature_desc.point2 .slick-slide .img_scale .bubble_01{
    top: 0;
    left: 52vw;
}
.feature_desc.point2 .slick-slide .img_scale .bubble_02{
    top: 50.13vw;
    left: 2.4vw;
}
.feature_desc.point2 .slick-slide .img_scale .bubble_03{
    top: 21.33vw;
    left: 10.67vw;
}
.feature_desc.point2 .slick-slide .img_scale .bubble_04{
    top: 16vw;
    left: 3.73vw;
}
.feature_desc.point2 .slick-slide .img_scale .bubble_05{
    top: 16vw;
    left: 3.73vw;
}
.feature_desc.point2 .slick-slide .img_scale .bubble_06{
    top: 15.47vw;
    left: 53.33vw;
}
.feature_desc.point2 .slick-slide .numbering {
    display: none;
}

.customdots {
    width: 89.33333vw;
    margin: 0 auto 4.26667vw;
}
.customdots li {
    display: inline-block;
    box-sizing: border-box;
    width: 43.73333vw;
    padding: 2.66667vw 3.46667vw;
    margin-top: 2.13333vw;
    background-color: #FFFBEF;
    border-radius: 10px;
    color: #5CB037;
    font-size: 3.73333vw;
    font-weight: bold;
    text-align: center;
    vertical-align: top;
}
.customdots li.slick-active {
    background-color: #5CB037;
    color: #FFFFFF;
}
.customdots li:nth-child(odd) {
    margin-right: 1.86667vw;
}
.mi-mon_guide {
    margin-top: 10.66667vw;
}
.mi-mon_guide .balloon{
    width: 80vw;
    box-sizing: border-box;
    background-color: #5CB037;
    padding: 2.66667vw 6vw;
    margin: 0 auto 6.67vw;
    font-size: 3.73333vw;
    font-weight: bold;
    color: #FFFFFF;
    border-radius: 10px;
    text-align: center;
    position: relative;
}
.mi-mon_guide .balloon:after{
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 2.93333vw 1.6vw 0 1.6vw;
    border-color: #5CB037 transparent transparent transparent;
    position: absolute;
    left: 50%;
    bottom: -2vw;
    transform: translateX(-50%);
}
.mi-mon_guide .download_area{
    display: block;
    width: 89.33333vw;
    height: 150.4vw;
    box-sizing: border-box;
    margin: 0 auto;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_feature_3.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: relative;
}
.mi-mon_guide .download_area .appbtn_wrap {
    display: block;
    width: 74.66667vw;
    box-sizing: border-box;
    padding: 5.33333vw;
    margin: 0 auto;
    background-color: #FFFFFF;
    border-radius: 10px;
    position: absolute;
    bottom: 17.33333vw;
    left: 50%;
    transform: translateX(-50%);
}
.mi-mon_guide .download_area .appbtn_wrap p {
    margin: 0 auto;
    font-size: 4.26667vw;
    font-weight: bold;
    color: #5CB037;
    text-align: center;
}
.mi-mon_guide .download_area .appbtn_wrap p+p {
    margin-top: 1.33333vw;
}
.mi-mon_guide .download_area .appbtn_wrap p img {
    max-width: 17.6vw;
}
.mi-mon_guide .download_area .appbtn_wrap .btn_area {
    text-align: center;
    margin-top: 4.26667vw;
}
.mi-mon_guide .download_area .appbtn_wrap .btn_area a {
    display: inline-block;
    width: 27.46667vw;
}
.mi-mon_guide .download_area .appbtn_wrap .btn_area a:first-child {
    margin-right: 4.26667vw;
}

.feature_desc.point3 {
    width: 97.06667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_feature_4.png);
    background-repeat: no-repeat;
    background-size: contain;
    min-height: 224vw;
}
.feature_desc.point3 h3 {
    margin: 7.19vw auto 0;
}
.feature_desc.point3 h3::before {
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_feature_6.png);
    background-repeat: no-repeat;
    background-size: contain;
}
.feature_desc.point3 .feature_desc_read {
    margin: 2.67vw auto 5.33vw;
}
.feature_desc.point3 .card_view_area {
    max-width: 63.2vw;
    margin: 0 auto;
}
.feature_desc.point3 .card_view {
    max-width: 63.2vw;
    margin: 0 auto;
    display: none;
}
.feature_desc.point3 .card_choice_area > div {
    text-align: center;
}
.feature_desc.point3 .card_choice_mi-mon {
    margin-bottom: 7.2vw;
}
.feature_desc.point3 .card_choice {
    display: inline-block;
    max-width: 27.06667vw;
    margin: 2.26vw 4.26667vw 0 auto;
}
.feature_desc.point3 .card_choice:nth-child(n+4) {
    margin: 4.26vw 4.26667vw 0 auto;
}
.feature_desc.point3 .card_choice.active img {
    box-shadow: 8px 8px 10px rgb(0,0,0,0.58);
    transform: translate(-8px, -8px);
    /*border: 4px solid #5CB037;
    border-radius: 9px;*/
}
.feature_desc.point3 .card_choice:hover {
    cursor: pointer;
}
.feature_desc.point3 .card_wrap {
    width: 97.06667vw;
    padding-bottom: 2vw;
}
.feature_desc.point3 .card_choice_mi-mon .card_choice:nth-child(even) {
    margin-right: 0;
}
.feature_desc.point3 .card_choice_another .card_choice:nth-child(3n) {
    margin-right: 0;
}
.feature_desc.point3 .card_choice span{
    display: block;
    font-size: 3.2vw;
}
.feature_desc.point3 .card_choice_read{
    display: block;
    text-align: center;
    font-size: 4.26667vw;
    font-weight: bold;
    color: #5CB037;
}
.feature_desc.point3 .card_choice_head{
    display: block;
    text-align: center;
    font-size: 3.73333vw;
}
.feature_desc.point3 .card_choice_head{
    margin: 2.13333vw auto 3.73333vw;
}

#howtouse .acd-label {
    padding: 5.33333vw 0 5.33333vw 22.93333vw;
}
#howtouse .acd-label img {
    display: inline-block;
    max-width: 11.46666vw;
    position: absolute;
    left: 7vw;
    top: 3vw;
}

#howtouse .acd-content h3 {
    display: inline-block;
    text-align: center;
    font-size: 5.33333vw;
    font-weight: bold;
    color: #5CB037;
    margin: 5vw auto 8vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
}
#howtouse .acd-content h3 span {
    position: relative;
}
#howtouse .acd-content h3 span::after {
    content: "";
    display: inline-block;
    width: 120%;
    border-bottom: dotted 2px #5CB037;
    position: absolute;
    bottom: 0;
    left: -10%;
}
#howtouse .acd-content .img_center img {
    max-width: 53.93333vw;
}
#shopping_content .shopping_content_item_mark .stores {
    margin: 0 0 30px;
    text-align: center;
}

#shopping_content .shopping_content_item_mark .stores .stores_navi {
    display: flex;
    justify-content: center;
}

#howtouse .acd-content .campaign_desc_inner.step_02{
    padding: 0 6.13vw;
}

#howtouse .acd-content .campaign_desc_inner.step_02 .since {
    margin-top: 10.13vw;
}

#howtouse .acd-content .campaign_desc_inner.step_02 .since p {
    font-size: 4.26vw;
    line-height: 2;
}

#howtouse .stores .tab_item{
    border: solid 1px #75c04a;
    box-sizing: border-box;
    color: #75c04a;
    font-weight: bold;
    width: 16vw;
    border-radius: 2em;
    font-size: 3.3vw;
    display: inline-block;
    padding: 2vw 1vw;
    text-align: center;
    margin:0 0 0 1vw;
}

#howtouse .stores input:checked + .tab_item{
    background: #75c04a;
    color: #fff;
}

#howtouse .storeListLink{
    text-align: center;
    margin-top: 6.67vw;
}

#howtouse .storeListLink a{
    text-decoration: underline;
    font-size: 3.73vw;
}

#howtouse .display_sp .storeListLink p{
    font-size: 3.2vw;
}

/*ラジオボタンを全て消す*/
#howtouse .stores input[name="tab_item_01"] {
    display: none;
}

/*タブ切り替えの中身のスタイル*/
#howtouse .stores .tab_content {
    display: none;
    clear: both;
    overflow: hidden;
}
#howtouse .stores #conveni_sp:checked ~ #conveni_content_sp,
#howtouse .stores #super_sp:checked ~ #super_content_sp,
#howtouse .stores #restaurant_sp:checked ~ #restaurant_content_sp,
#howtouse .stores #other_sp:checked ~ #other_content_sp{
    display: block;
}

#howtouse .stores .tab_content .stores_list {
    width: 100%;
    margin: 5.33vw auto 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
}

#howtouse .stores .tab_content .stores_list li {
    width: 41.06vw;
    padding: 2.67vw 0 0;
    text-align: center;
}

#howtouse .stores .tab_content .stores_list li img {
    width: 21.33vw;
}

#howtouse .stores .tab_content .stores_list li span {
    font-size: 14px;
    line-height: 1.69429;
    display: block;
    letter-spacing: -0.08em;
}

#howtouse .display_sp .shopping_content_item_mark{
    border: 1px solid #5CB037;
    border-radius: 2.67vw;
    padding: 1.86vw;
    text-align: center;
    margin: 10vw auto 8vw;
}

#howtouse .display_sp .shopping_content_item_mark h3{
    margin: 1.2vw auto 3.46666vw;
    left: 0%;
    transform: translateX(0%);
}

#howtouse .display_sp .shopping_content_item_mark img{
    width: 73.33vw;
    display: block;
    margin: 0 auto;
}

#howtouse .display_sp .shopping_content_item_mark .shopping_mark + h3{
    margin-top: 12vw;
}

#howtouse .display_sp .shopping_content_item_mark img{
    width: 73.33vw;
    display: block;
    margin: 0 auto;
}

#howtouse .display_sp .shopping_content_item_mark .stores{
    text-align: center;
}

#slider_howtouse_sp{
    width: 100%;
    margin-top: 5.33vw;
}

#slider_howtouse_sp .slick-list{
    width: 100%;
}

#slider_howtouse_sp .slick-dots{
    bottom: -5.34vw;
}

#slider_howtouse_sp .slick-arrow {
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    padding: 0;
    width: 5.33vw;
    height: 10.13vw;
    color: transparent;
    z-index: 1;
    transition: opacity 0.5s;
    z-index: 1;
}
#slider_howtouse_sp .slick-arrow:hover {
    opacity: 0.7;
}

/* 共通設定 */

#slider_howtouse_sp .slick-next::before,
#slider_howtouse_sp .slick-next::after,
#slider_howtouse_sp .slick-prev::before,
#slider_howtouse_sp .slick-prev::after {
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
#slider_howtouse_sp .slick-next::after,
#slider_howtouse_sp .slick-prev::after {
    width: 3.73vw;
    height: 3.73vw;
    border-top: 2px solid #AEAEAE;
    border-right: 2px solid #AEAEAE;
}

/* next */

#slider_howtouse_sp .slick-next {
    right: 0px;
}
#slider_howtouse_sp .slick-next::after {
    right: 1.07vw;
    transform: rotate(45deg);
}

/* prev */

#slider_howtouse_sp .slick-prev {
    left: 0px;
}
#slider_howtouse_sp .slick-prev::after {
    left: 1.07vw;
    transform: rotate(-135deg);
}
  
@media screen and (max-width: 767px) {
    #slider_howtouse_sp .slick-next::after,
    #slider_howtouse_sp .slick-prev::after {
        width: 2.67vw;
        height: 2.67vw;
    }
    #slider_howtouse_sp .slick-next {
        right: 2.13vw;
    }
    #slider_howtouse_sp .slick-prev {
        left: 2.13vw;
    }
    #slider_howtouse_sp .slick-next::after {
        right: 0.53vw;
    }
}

.slider_howtouse_item > p{
    width: 68%;
    background-color: #F2F9EF;
    border-radius: 4.26vw;
    color: #5CB037;
    font-weight: bold;
    margin: 0 auto;
    text-align: center;
    font-size: 4.26vw;
    padding: 2.67vw 0;
}

.howtouse_charge_item{
    display: flex;
    margin-top: 5.86vw;
    flex-direction: column;
}

.howtouse_charge_item .item_img{
    width: 100%;
    margin: auto;
}
.howtouse_charge_item .item_img img{
    width: 24.53vw;
    margin: 0 auto;
    display: block;
}

.howtouse_charge_item p{
    font-size: 4.26vw;
    line-height: 2;
    width: 85%;
    margin: 0 auto;
    color: #333333;
}

#slider_howtouse_sp + p.img_center{
    margin-top: 16.53vw;
}

#slider_howtouse_sp + p.img_center img{
    width: 40vw;
}




#voice {
    background-color: #FFFBEF;
    padding-top: 6.93333vw;
    padding-bottom: 20vw;
    margin-top: 10vw;
}
#voice h2 {
    margin-bottom: 8.53333vw;
}
#voice .voice_user {
    position: relative;
    margin-top: 2.13333vw;
}
#voice .voice_user p {
    position: absolute;
    display: inline-block;
    width: 56.53333vw;
    font-size: 4.26666vw;
    color: #333333;
    line-height: 2;
    right: 10vw;
    top: 3%;
}
#voice .voice_1 {
    height: 26.66667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_voice_1.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}
#voice .voice_2 {
    height: 26.66667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_voice_2.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}
#voice .voice_3 {
    height: 26.66667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_voice_3.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}
#voice .voice_4 {
    height: 27.46667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_voice_4.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}
#voice .voice_5 {
    height: 26.66667vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_voice_5.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
}
#voice .voice_2 p,#voice .voice_4 p{
    left: 13vw;
}

#step {
    padding-bottom: 8.53333vw;
}
#step h2{
    margin:10.67vw auto 0;
}
#step .acd-label {
    padding: 5.33333vw 0 5.33333vw 22.93333vw;
}
#step .acd-label img {
    display: inline-block;
    max-width: 11.46666vw;
    position: absolute;
    left: 7vw;
    top: 3vw;
}
#step .acd-content h3 {
    display: inline-block;
    text-align: center;
    font-size: 5.33333vw;
    font-weight: bold;
    color: #5CB037;
    margin: 7vw auto 3vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
}
#step .acd-content h3 span {
    position: relative;
}
#step .acd-content h3 span::after {
    content: "";
    display: inline-block;
    width: 120%;
    border-bottom: dotted 2px #5CB037;
    position: absolute;
    bottom: 0;
    left: -10%;
}
.text {
    font-size: 4.26667vw;
    color: #333333;
}
.text.center {
    text-align: center;
}
.step_desc_inner {
    max-width: 89.33333vw;
    margin: 0 auto;
}
.step_desc_inner h4 {
    display: inline-block;
    max-width: 89.33333vw;
    margin: 6vw auto 5.33333vw;
    font-size: 4.26667vw;
    font-weight: bold;
    position: relative;
    left:50%;
    transform: translateX(-50%);
    color: #5CB037;
}
.step_desc_inner h4::before {
    content: "";
    display: block;
    width: 2px;
    height: 1.5em;
    border-right: 2px dotted #5CB037;
    margin: 0;
    position: absolute;
    bottom: 15%;
    left: -8%;
    -webkit-transform: translateY(3px) rotate(-30deg);
    -ms-transform: translateY(3px) rotate(-30deg);
    transform: translateY(3px) rotate(-30deg);
}
.step_desc_inner h4::after {
    content: "";
    display: block;
    width: 2px;
    height: 1.5em;
    border-right: 2px dotted #5CB037;
    margin: 0;
    position: absolute;
    bottom: 15%;
    right: -8%;
    -webkit-transform: translateY(3px) rotate(30deg);
    -ms-transform: translateY(3px) rotate(30deg);
    transform: translateY(3px) rotate(30deg);
}
.step_table tr {
    border-top: 2px solid #FFFFFF;
}
.step_table tbody {
    border: 2px solid #FFFFFF;
}
.step_table th {
    background-color: #5CB037;
    color: #FFFFFF;
    width: 26.66667vw;
    height: 21.33333vw;
    font-size: 3.73333vw;
    font-weight: bold;
    border-top-color: #FFFFFF !important;
}
.step_table td {
    background-color: #FFFBEF;
    color: #5CB037;
    font-size: 3.73333vw;
    font-weight: bold;
    border-left-color: #FFFFFF;
    border-top-color: #FFFFFF !important;
    border-left: 2px solid #FFFFFF;
    border-top: 2px solid #FFFFFF !important;
    display: flex;
    align-items: center;
    justify-content: space-around;
}

.step_table td p{
    width: 40%;
    text-align: left;
    color: #5CB037;
}
.step_table td div{
    width: 60%;
    text-align: center;
}
.step_table td div img{
    width: initial;
}

.useguide_desc_inner ul {
    list-style: disc;
    padding-left: 5.33333vw;
}
.step_desc_inner ul {
    list-style: disc;
    padding-left: 2em;
}
.step_desc_inner ul li,.useguide_desc_inner ul li {
    margin-bottom: 2.66667vw;
    font-size: 4.27vw;
}

#campaign2 {
    background-color: #F5FFF1;
    padding-bottom: 8vw;;
}
.cashless {
    position: relative;
    margin-bottom: 16vw;
}

.cashless .display_sp {
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_cashless_sp_bg.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    min-height: 183vw;

}

.cashless .display_sp img{
    width: 90.66vw;
    display: block;
    margin: 0 auto;
    padding-top: 2vw;
}
.cashless .btn-app {
    font-size: 4.8vw;
    font-weight: bold;
    padding: 0;
    position: absolute;
    bottom: 16vw;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
}
.cashless .btn-app a{
    display: block;
    width: 89.06667vw;
    padding: 4.26667vw;
    box-sizing: border-box;
    background-color: #EDBA0E;
    border-radius: 88vh;
    line-height: 4vw;
    text-align: center;
    color: #FFFFFF;
    position: relative;
    margin: 0 auto;
}
.cashless .btn-app a::after{
    content: "";
    display: inline-block;
    width: 2.66667vw;
    height: 5.33333vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_arrow_white.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    right: 5vw;
    top: 50%;
    transform: translateY(-50%);
}


.useguide h3{
    font-size: 4.26667vw;
    font-weight: bold;
    border-left: solid 1.33333vw #5CB037;
    padding-left: 1.33333vw;
}
.useguide_desc_inner {
    max-width: 89.33333vw;
    margin: 0 auto;
}
.useguide .acd-label {
    margin-bottom: 10.66667vw;
}
.useguide_desc_inner ul {
    margin-top: 3.44446vw;
}
.useguide .anno {
    margin-bottom: 1vw;
}
.useguide .blankLink {
    display: inline-block;
    margin-top: 0;
    margin-bottom: 4.26667vw;
    margin-left: 1em;
    font-weight: bold;
}
.useguide .linklist{
    margin-top: 8vw;
}
.useguide .linklist a{
    display: inline-block;
    margin-left: 0;
    text-indent: -1em;
    padding-left: 1em;
    font-weight: bold;
    line-height: 1.7;
}
.useguide_desc_inner .anno_list {
    margin-bottom: 10.66667vw;
}
.useguide_desc_inner .anno_list .anno {
    margin-top: 6.4vw;
}
.inquiry {
    max-width: 89.33333vw;
    margin: 0 auto;
}
.inquiry h2 {
    font-size: 7.46666vw;
    font-weight: bold;
    color: #5CB037;
    margin-bottom: 8.53333vw;
}
.inquiry h3 {
    font-size: 4.26667vw;
    font-weight: bold;
    border-left: solid 1.33333vw #5CB037;
    padding-left: 1.33333vw;
}
.inquiry img {
    max-width: 76vw;
}
.inquiry p.img_center {
    margin: 8.53vw auto;
}
.banner_area {
    max-width: 89.33333vw;
    margin: 10.66666vw auto 0;
}
.banner_area p{
    margin-top: 6.4vw;
}
.banner_area p:first-child{
    margin-top: 0;
}

.followbtn {
    background-color: #5CB037;
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    padding-top: 8vw;
    padding-bottom: 7.46vw;
    z-index: 980;
    display: none;
}

.followbtn .followbtn_inner {
    margin: 0 auto;
}

.followbtn .followbtn_inner .followbtn_contents {
    text-align: center;
}

.followbtn .followbtn_inner .followbtn_contents .btn {
    width: 100vw;
    margin-right: 1.87vw;
    background-color: #EDBA0E;
    font-size: 4vw;
    font-weight: 600;
    border-radius: 88vh;
    padding: 2.93vw 23.73vw 3.73vw;
    letter-spacing: 1px;
    border: 2px solid #FFFFFF;
    z-index: 1000;
    position: relative;
    color: #FFFFFF;
}
.followbtn .followbtn_inner .followbtn_contents .btn::after {
    content: "";
    display: inline-block;
    width: 2.66667vw;
    height: 5.33333vw;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_arrow_white.png);
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    right: 5vw;
    top: 50%;
    transform: translateY(-50%);
}

.returnbtn{
    position: fixed;
    bottom: 22vw;
    right: 17px;
    width: 56px;
    height: 56px;
    display: none;
    z-index: 1000;
}
.returnbtn a{
    display: inline-block;
}

.returnbtn a img{
    width: 100%;
    filter: drop-shadow(0px 8px 16px rgba(0,0,0,0.16));
}


.shareArea {
    padding-bottom: 15.45894vw;
}
.share {
    margin-top: 8.5vw;
}
.shareAreaTag {
    width: 90.33816vw;
    margin: 15.45894vw auto 0;
    display: block;
    line-height: 0;
}
.share_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    padding-left: 0;
}
.share_item {
    margin: 0 3.86473vw;
}
.share_item a {
    display: block;
    line-height: 0;
}
.share_item a img {
    max-width: 16vw;
}
footer {
    background-color: unset;
    border-top: solid 1px #009595;
}
.relation {
    margin-bottom: 6.03865vw;
    text-align: center;
}
.relation .relationLink:first-child {
    margin-top: 8vw;
    margin-bottom: 2.41546vw;
}
.relation .relationLink a {
    position: relative;
}
.relation .relationLink a::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -7.24638vw;
    width: 14px;
    height: 14px;
    background: url(/brand/googlepay_visa/img/icon-blank.png);
    background-repeat: no-repeat;
    background-size: 100%;
    background-position: center;
    -webkit-transform: translate(0, -50%);
        -ms-transform: translate(0, -50%);
            transform: translate(0, -50%);
}
.copyright {
    background-color: #EFEFEF;
    padding: 1.69082vw 0 2.17391vw 0;
    text-align: center;
    font-size: 3.38164vw;
}

@media print, screen and (min-width: 768px){
    h2.h2_head{
        padding-top: 34px;
    }
    #feature h2.h2_head,#voice h2.h2_head,#step h2.h2_head{
        padding-top: 34px;
    }
    h2.h2_head p,#step h2.h2_head p{
        font-size: 38px;
        margin:55px auto 30px;
    }
    h2.h2_head p + br + p{
        margin-top: -15px;
    }
    h2.h2_head p + p{
        margin-top: -15px;
    }
    h2.h2_head img{
        top: 0;
    }
    
    #whats_this h2.h2_head img{
        width: 316px;
        top: 0;
    }
    #feature h2.h2_head img{
        width: 174px;
        top: 11px;
    }
    #howtouse h2.h2_head img{
        width: 275px;
        top: -15px;
    }
    #voice h2.h2_head img{
        width: 160px;
        top: 23px;
    }
    #step h2.h2_head img{
        width: 130px;
        top: 0;
    }
    .blankLink::after {
        width: 10px;
        height: 10px;
        margin-left: 10px;
    }

    .global_header {
        min-height: 56px;
        height: 56px;
        position: relative;
    }
    .global_header .logo_area {
        display: inline-block;
    }
    .global_header .logo_area .logo {
        display: inline-block;
    }
    .display_pc.navWrap {
        position: relative;
        display: block;
        width: 923px!important;
        margin: 0 auto;
        top: 25px;
        background-color: #FFFFFF;
        border-radius: 10px;
        min-width: 1px;
    }
    .display_pc.navWrap .NaviInner{
        width:100%;
        padding:0;
    }
    .NaviListWarp .NaviList li{
        width: 325px;
    }
    .login {
        display: none;
    }
    .NaviListWarp {
        padding: 30px 15px;
        display: block !important;
    }
    .NaviList {
        width: 883px;
        display: block;
        margin: 0 auto;
    }
    .NaviList a {
        color: #5CB037;
        width: 226px;
        font-size: 16px;
        font-weight: bold;
        text-align: center;
        margin-right: 0;
        height: initial;
        padding-top:0;
        margin:0 auto;
    }
    .NaviList li {
        width: 226px;
        padding: 0;
        border-right: 1px solid #D5D5D5;
        text-align: center;
        vertical-align: middle;
        border-color: #D5D5D5;
    }
    #ft {
        display: table-cell;
        width: 226px;
        padding-top:0;
        border-right: 1px solid #D5D5D5;
        border-left: none;
        text-align: left;
        vertical-align: text-top;
        border-color: #D5D5D5;
        padding: 0;
    }

    #fs{
        padding: 0; 
    }

    .kv_text_item {
        overflow: hidden;
        position: relative;
        opacity: 0;
    }
    
    .kv_text_item_01 {
        width:189px;
        top: -66px;
    }
    .kv_text_item_02 {
        width:225px;
        top: -63px;
    }
    .kv_text_item_03 {
        width:155px;
        top: -56px;
    }
    
    .kv_text_item_04 {
        width: 328px;
        top: 0px;
        height: 176px;
        left: -38px;
        transform: rotate(-1deg);
    }
    
    .kv_text_item_01:before {
        width:356px;
    }
    .kv_text_item_02:before {
        width:424px;
    }
    .kv_text_item_03:before {
        width:292px;
    }
    
    .kv_text_item_04:before {
        width:329px;
        height: 178px;
    }
    
    .kv_tab{
        position: absolute;
        top: 300px;
        left: 75px;
        display: none;
        width: 183px;
    }

    .main_visual h1 {
        padding: 0;
        height: 863px;
        width: 100%;
        margin-bottom: 36px;
    }

    .main_visual h1 .kv_img{
        max-width: 1254px;
        width: 90vw;
    }

    .main_visual h1 .kv_img img {
        max-width: 1254px;
        position: absolute;
        width: 90vw;
        left: 0;
        top: 20px;
        right: 0;
        margin: 0 auto;
    }

    .main_visual h1 .detail {
        max-width: 1409px;
        width: 100%;
        right: 0;
        margin: 0 auto;
    }

    .main_visual h1 .detail img {
        max-width: 1409px;
        width: 100%;
        background-color: #fff;
    }

    .main_visual h1 .kv_text {
        position: absolute;
        top:213px;
        left: 320px;
    }
    

    .campaign {
        padding-top: 20px;
    }

    .campaign h3 {
        font-size: 34px;
        margin: 0 auto 20px;
        width: 715px;
    }
    .campaign h3::before {
        content: "";
        display: block;
        width: 2px;
        height: 40px;
        border-right: 2px dotted #5CB037;
        margin: 0;
        position: absolute;
        top: -3px;
        left: -1%;
        -webkit-transform: translateY(3px) rotate(
    -15deg
    );
        -ms-transform: translateY(3px) rotate(-15deg);
        transform: translateY(3px) rotate(
    -15deg
    );
    }
    .campaign h3::after {
        content: "";
        display: block;
        width: 2px;
        height: 40px;
        border-right: 2px dotted #5CB037;
        margin: 0;
        position: absolute;
        top: -3px;
        right: -1%;
        -webkit-transform: translateY(3px) rotate(
    15deg
    );
        -ms-transform: translateY(3px) rotate(15deg);
        transform: translateY(3px) rotate(
    15deg
    );
    }
    .campaign p.campaign_head {
        font-size: 38px;
        margin: 0 auto 15px;
    }
    .campaign_desc {
        background-color: #F5FFF1;
        max-width: 1000px;
        margin: 0 auto;
    }
    .acd-label {
        padding: 15px 60px;
        margin-top: 40px;
        margin-bottom: 4.26667vw;
        font-size: 24px;
        border: 1px solid #EDBA0E;
    }
    .acd-label::before {
        content: "";
        width: 18px;
        display: block;
        position: absolute;
        right: 5%;
        top: 50%;
        border-top: 2px solid #AEAEAE;
        transform: translateY(-50%) rotate(
    90deg
    );
        -webkit-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all 0.3s ease;
    }
    .acd-label::after {
        content: "";
        width: 18px;
        display: block;
        position: absolute;
        right: 5%;
        top: 50%;
        border-top: 2px solid #AEAEAE;
        transform: translateY(-50%);
    }
    .campaign_desc .campaign_desc_inner{
        width: 100%;
    }
    .campaign_desc .campaign_desc_inner h3 {
        padding: 0 10px;
        margin: 20px auto 0;
        font-size: 24px;
    }
    .campaign_desc .campaign_desc_inner p.campaign_desc_read {
        font-size: 46px;
        margin: 10px auto;
    }
    .campaign_desc .campaign_desc_inner p.campaign_desc_read + .campaign_desc_anno .anno {
        text-align: center;
    }
    .anno {
        font-size: 12px;
    }
    .campaign_desc_inner .anno {
        margin-top: 15px;
        text-align: center;
    }
    .campaign_desc .campaign_desc_conditions dl dt, .campaign_desc .campaign_desc_conditions dl dd {
        font-size: 20px;
        margin-left: 0;
        text-align: center;
    }
    .campaign_desc .campaign_desc_conditions dl dd {
        font-size: 18px;
    }
    .campaign_desc .campaign_desc_conditions dl dt {
        color: #5CB037;
        margin-top: 0;
        padding-top: 34px;
        margin-bottom: 13px;
        position: relative;
    }
    .campaign_desc .campaign_desc_conditions dl {
        width: 81.06667vw;
        margin: 0 auto 5.33333vw;
        border-left: none;
    }
    .conditions_wrap {
        display: inline-block;
        width: 312px;
        vertical-align: top;
        margin-right: 26px;
    }
    .conditions_wrap:last-child {
        margin-right: 0;
    }
    .campaign_desc .campaign_desc_conditions {
        width: 1000px;
        margin: 0 auto 36px;
        border-bottom: 1px solid #D5D5D5;
    }
    .campaign_desc .campaign_desc_conditions dl {
        width: 1000px;
        margin: 46px auto 36px;
        border-left: none;
        border-top: 2px dotted #5CB037;
    }
    .campaign_desc_anno .anno {
        text-align: left;
    }
    .campaign_desc .campaign_desc_conditions dl dt.campaign_desc_conditions_1::before {
        content: "";
        display: inline-block;
        width: 60px;
        height: 60px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/conditions_num_1.png);
        background-repeat: no-repeat;
        background-size: contain;
        position: absolute;
        top: -55%;
        left: 50%;
        transform: translateX(-50%);
    }
    .campaign_desc .campaign_desc_conditions dl dt.campaign_desc_conditions_2::before {
        content: "";
        display: inline-block;
        width: 60px;
        height: 60px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/conditions_num_2.png);
        background-repeat: no-repeat;
        background-size: contain;
        position: absolute;
        top: -55%;
        left: 50%;
        transform: translateX(-50%);
    }
    .campaign_desc .campaign_desc_conditions dl dt.campaign_desc_conditions_3::before {
        content: "";
        display: inline-block;
        width: 60px;
        height: 60px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/conditions_num_3.png);
        background-repeat: no-repeat;
        background-size: contain;
        position: absolute;
        top: -55%;
        left: 50%;
        transform: translateX(-50%);
    }
    .acd-check:checked + .acd-label + .acd-content {
        padding: 0 0 0;
    }
    .campaign_another {
        width: 1000px;
        margin: 60px auto 0;
        padding: 60px;
    }
    .campaign_another h3 {
        font-size: 32px;
        margin: 0 auto 60px;
    }
    .campaign_another h3::after {
        width: 48px;
        margin: 20px auto 0;
    }
    .campaign_another p {
        display: inline-block;
        margin-bottom: 0;
    }
    .campaign_another p img {
        max-width: 416px;
    }
    .campaign_another p:last-child {
        margin-left: 40px;
    }
    #whats_this {
        padding-top: 60px;
        max-width: 1000px;
        margin: 0 auto;
    }
    .whats_this_read {
        width: 444px;
        margin-top: 150px;
        margin-bottom: 0;
        margin-right: 60px;
        text-align: left;
        float: right;
    }
    .whats_this_read p {
        font-size: 20px;
    }
    .whats_this_read .backline::before {
        left: 0;
        transform: translateX(0);
        width: 100%;
    }
    .backline {
        display: inline-block;
        position: relative;
        margin: 10px auto 0;
    }
    #whats_this .insert_pc{
        max-width: 380px;
        float: right;
        margin-right: 50px;
        margin-top: 28px;
    }
    .whats_this_video {
        padding-bottom: 60px;
        margin-top: 0;
        padding-top: 40px;
        clear: both;
    }
    .whats_this_video h3 {
        display: inline-block;
        font-size: 18px;
        color: #333333;
        text-align: center;
        line-height: 2;
        position: relative;
    }
    .whats_this_video h3::before {
        content: "";
        display: block;
        width: 2px;
        height: 4em;
        border-right: 2px dotted #5CB037;
        margin: 0;
        position: absolute;
        top: 0;
        left: -18%;
        -webkit-transform: translateY(3px) rotate(
    -30deg
    );
        -ms-transform: translateY(3px) rotate(-30deg);
        transform: translateY(3px) rotate(
    -30deg
    );
    }
    .whats_this_video h3::after {
        content: "";
        display: block;
        width: 2px;
        height: 4em;
        border-right: 2px dotted #5CB037;
        margin: 0;
        position: absolute;
        top: 0;
        right: -18%;
        -webkit-transform: translateY(3px) rotate(
    30deg
    );
        -ms-transform: translateY(3px) rotate(30deg);
        transform: translateY(3px) rotate(
    30deg
    );
    }
    .whats_this_video .video_wrap {
        width: 1000px;
        padding-top: 220px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_whatsthis_1.png);
        min-height: 1034px;
    }
    .whats_this_video .tabs {
        margin-top: 50px;
        padding-bottom: 14.49275vw;
        width: 1000px;
        margin: 0 auto;
        border-radius: 10px 10px 0 0;
        overflow: hidden;
    }
    .whats_this_video .tab_item {
        display: block;
        width: 414px;
        height: 50px;
        margin-right: 1.5vw;
        line-height: 50px;
        font-size: 22px;
        border-radius: 50px;
        transform: translateX(18%);
    }
    .whats_this_video .tab_content {
        width: 880px;
        margin: 75px auto 0;
        clear: both;
        overflow: hidden;
        max-height: 502px;
    }
    .whats_this_video .tab_content iframe{
        height: 500px;
    }

    /* feature */

    #feature {
        background-color: #FFFBEF;
        padding: 60px 0 90px;
    }

    .feature_desc {
        width: 1000px;
        margin: 42px auto 0;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_feature_1_pc.png);
        background-repeat: no-repeat;
        background-size: contain;
        min-height: 955px;
    }
    .feature_desc h3 {
        margin: 40px auto 0;
        font-size: 32px;
    }
    .feature_desc h3::before {
        width: 61px;
        height: 61px;
        margin: 0 auto 12px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_feature_1.png);
        background-repeat: no-repeat;
        background-size: contain;
    }
    .feature_desc h3::after {
        width: 48px;
        height: 1px;
        margin: 16px auto 0;
        border-bottom: 1px solid #EDBA0E;
    }
    .feature_desc_read {
        margin-top: 38px;
        margin-bottom: 48px;
        text-align: center;
    }
    .feature_desc_read p {
        font-size: 18px;
        margin-bottom: 0;
    }
    .feature_desc dl {
        margin: 0 auto 24px;
        width: 880px;
        padding: 30px;
    }
    .feature_desc dl dt {
        font-size: 20px;
        margin-bottom: 4px;
    }
    .feature_desc dl dd {
        font-size: 16px;
        line-height: 1.7;
        margin-top: 10px;
    }

    .feature_desc.point1 .feature_desc_read{
        margin-top:12px;
        margin-bottom: 25px;
    }
    .icon-check::before {
        width: 26px;
        height: 24px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_feature_2.png);
        background-size: contain;
        background-repeat: no-repeat;
        left: 40px;
    }
    dd.icon-check {
        padding-left: 76px;
        position: relative;
    }
    .triangle {
        width: 0;
        height: 0;
        margin: 0 auto;
        border-style: solid;
        border-width: 17px 27.5px 0 27.5px;
        border-color: #EDBA0E transparent transparent transparent;
    }
    .triangle + .dotline-bottom.display_pc{
        margin-top: 20px;
    }
    .triangle + .dotline-bottom.display_pc::after{
        width: 83%;
        top:6px;
    }
    .dotline-bottom.display_pc + .display_pc{
        display: flex;
        margin-top: 15px;
        justify-content: flex-start;
    }
    .dotline-bottom {
        font-size: 24px;
    }
    .feature_desc_solution {
        margin-top: 0px;
    }
    .feature_desc_solution dl.border-dot {
        margin-top: 105px;
        padding-top: 3.2vw;
        position: relative;
        width: 293px;
    }
    .feature_desc_solution dl::before {
        width: 150px;
        height: 70px;
        top: -70px;
        left: 10%;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_illust_feature_1_pc.png);
    }
    .feature_desc_solution dl::after {
        width: 117px;
        height: 124px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_balloon_feature_1_pc.png);
        background-size: contain;
        background-repeat: no-repeat;
        position: absolute;
        top: -87px;
        right: -16px;
    }

    .feature_desc_solution dl.border-dot {
        margin: 94px 0px 0px 60px;
        padding: 18px 22px 15px 22px;
    }

    .feature_desc_solution dl dt{
        padding-left: 34px;
    }

    .feature_desc_solution dl dt::before{
        width: 22px;
        height: 22px;
        left: 8px;
    }

    .feature_desc_solution .anno{
        margin: 6px 0px 0 60px;
    }

    .feature_desc_post {
        margin-top: 10px;
        flex-direction: column;
    }

    .feature_desc_post .post {
        width: 295px;
        margin-right: 0;
        height: 125px;
        background-image:url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_back_feature_1_pc.png);
        padding: 18px 48px;
    }

    .feature_desc_post .post.top {
        transform: rotate(180deg);
        margin-top:20px;
        display: flex;
        align-items: center;
        flex-direction: row-reverse;
    }

    .feature_desc_post .post:first-child {
        margin-right: 0px;
    }

    .feature_desc_post .post p {
        margin-top: 0;
        padding: 0 0;
        font-size: 13px;
        line-height: 1.6;
    }

    .feature_desc_post .post.top p,
    .feature_desc_post .post.top img{
        transform: rotate(-180deg);
    }

    .feature_desc_post .post.top img{
        width: 24%;
        height: auto;
    }

    .feature_desc_post .post.top p{
        margin-top: 0px;
        padding-left: 9px;
        width: 76%;
    }

    .feature_desc_post .post p span{
        width: 50px;
        margin: 0 auto;
    }

    .feature_desc_private {
        margin-top: 0px;
        padding-bottom: 0px;
    }

    .feature_desc_private dl {
        margin: 103px 0px 0px 0px;
        padding: 18px 22px 15px 22px;
        width: 290px;
    }

    .feature_desc_private dl::before {
        width: 64px;
        height: 64px;
        top: -62px;
        left: 39%;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_illust_feature_2.png);
    }

    
    .feature_desc_private dl::after {
        width: 114px;
        height: 120px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_balloon_feature_2_pc.png);
        top: -100px;
        right: -11px;
    }
    .feature_desc_private dl dt {
        padding-left: 34px;
    }

    .feature_desc_private dl dt::before {
        width: 22px;
        height: 22px;
        left: 8px;
    }

    .customdots {
        display: inline-block!important;
        vertical-align: top;
        width: 440px;
        margin: 130px 0 0 30px;
    }
    .customdots li {
        width: 440px;
        padding: 12px;
        margin-top: 8px;
        font-size: 18px;
    }
    .slick-list {
        display: inline-block;
        width: 409px;
    }
    #slider {
        height: 643px;
    }

    .mi-mon_guide {
        margin-top: 60px;
    }
    .mi-mon_guide .balloon {
        width: 759px;
        padding: 8px 0;
        font-size: 20px;
        margin: 0 auto 10px;
    }
    .feature_desc.point2 {
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_feature_2_pc.png);
        background-repeat: no-repeat;
        background-size: contain;
        padding-bottom: 4vw;
        min-height: 1px;
    }
    .mi-mon_guide .balloon:after {
        content: "";
        display: block;
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 11px 6px 0 6px;
        border-color: #5CB037 transparent transparent transparent;
        position: absolute;
        left: 50%;
        bottom: -10px;
        transform: translateX(-50%);
    }
    .mi-mon_guide .download_area {
        display: block;
        width: 880px;
        height: 617px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_feature_3_pc.png);
        background-repeat: no-repeat;
        background-size: contain;
    }
    .mi-mon_guide .download_area .appbtn_wrap {
        width: 466px;
        padding: 49px 26px 33px 29px;
        border-radius: 10px;
        position: absolute;
        bottom: 106px;
        left: 67%;
        transform: translateX(-50%);
    }
    .mi-mon_guide .download_area .appbtn_wrap p {
        display: inline-block;
        font-size: 21px;
        vertical-align: middle;
    }
    .mi-mon_guide .download_area .appbtn_wrap p:first-child {
        display: inline-block;
        max-width: 90px;
        margin-left: 30px;
    }
    .mi-mon_guide .download_area .appbtn_wrap p+p {
        margin-top: 0;
        margin-left: 25px;
    }
    .mi-mon_guide .download_area .appbtn_wrap .btn_area {
        text-align: center;
        margin-top: 22px;
    }
    .mi-mon_guide .download_area .appbtn_wrap .btn_area a:first-child {
        margin-right: 20px;
    }
    .mi-mon_guide .download_area .appbtn_wrap .btn_area a img {
        max-width: 186px;
    }
    .mi-mon_guide .download_area .appbtn_wrap .btn_area a {
        width: 186px;
    }
    .feature_desc.point3 {
        width: 1000px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_feature_4_pc.png);
        background-repeat: no-repeat;
        background-size: contain;
        min-height: 795px;
    }
    .feature_desc.point3 h3{
        margin: 30px auto 0;
    }
    .feature_desc.point3 .feature_desc_read{
        margin:15px auto 30px;
    }
    .feature_desc.point3 .card_wrap {
        width: 880px;
        padding-bottom: 0;
        text-align: center;
        margin: 0 auto;
    }
    .feature_desc.point3 .card_view_area {
        display: inline-block;
        max-width: 430px;
        margin: 0;
        vertical-align: middle;
    }
    .feature_desc.point3 .card_view {
        max-width: 430px;
        margin: 0 auto;
        display: none;
    }
    .card_choice_area {
        display: inline-block;
        max-width: 389px;
        vertical-align: middle;
        margin-left: 48px;
    }
    .feature_desc.point3 .card_choice_read {
        font-size: 16px;
    }
    .feature_desc.point3 .card_choice_head {
        font-size: 16px;
        margin: 15px auto;
    }
    .feature_desc.point3 .card_choice_mi-mon {
        margin-bottom: 30px;
    }
    .feature_desc.point3 .card_choice {
        display: inline-block;
        max-width: 116px;
        margin: 5px 15px 0 auto;
    }

    .feature_desc.point3 .card_choice:nth-child(n+4) {
        margin: 25px 15px 0 auto;
    }

    .card_choice_area img {
        max-width: 118px;
    }
    .feature_desc.point3 .card_choice span {
        font-size: 12px;
    }

    .feature_desc.point2 .slick-slide .img_scale .slider_bubble{
        position: absolute;
        width: 147px;
        top: 0;
        left: 0;
    }
    .feature_desc.point2 .slick-slide .img_scale .bubble_01{
        top: 73px;
        left: 226px;
    }
    .feature_desc.point2 .slick-slide .img_scale .bubble_02{
        top: 266px;
        left: 9px;
    }
    .feature_desc.point2 .slick-slide .img_scale .bubble_03{
        top: 122px;
        left: 64px;
    }
    .feature_desc.point2 .slick-slide .img_scale .bubble_04{
        top: 115px;
        left: 17px;
    }
    .feature_desc.point2 .slick-slide .img_scale .bubble_05{
        top: 115px;
        left: 17px;
    }
    .feature_desc.point2 .slick-slide .img_scale .bubble_06{
        top: 107px;
        left: 235px;
    }

    #howtouse .tabs{
        width: 1000px;
        min-height: 1135px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_howtouse_pc.png);
        background-repeat: no-repeat;
        padding: 63px 40px;
        background-size: contain;
        margin: 0 auto;
    }

    #howtouse .tabs .tab_item_01{
        font-size: 24px;
        font-weight: bold;
        text-align: center;
        width: 37%;
        margin-left: 2%;
        background-color: #F8FFF5;
        border-radius: 2em;
        color: #5CB037;
        display: inline-block;
        height: 80px;
        line-height: 80px;
        position: relative;
        text-indent: 3em;
    }

    #howtouse .tabs #charge:checked + .tab_item_01,
    #howtouse .tabs #shopping:checked +  .tab_item_01{
        background-color: #5CB037;
        color: #FFFFFF;
    }

    #howtouse .tabs .tab_item_01.step1::before{
        content: "";
        display: inline-block;
        width: 58px;
        height: 58px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_howto_1.png);
        background-repeat: no-repeat;
        background-size: contain;
        position: absolute;
        left: 62px;
        top: 10px;
    }

    #howtouse .tabs #charge:checked + .tab_item_01.step1::before{
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_howto_1_white.png);
    }

    #howtouse .tabs .tab_item_01.step2{
        margin-left: 16%;
    }

    #howtouse .tabs .tab_item_01.step2::before{
        content: "";
        display: inline-block;
        width: 58px;
        height: 58px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_howto_2.png);
        background-repeat: no-repeat;
        background-size: contain;
        position: absolute;
        left: 62px;
        top: 10px;
    }

    #howtouse .tabs #shopping:checked + .tab_item_01.step2::before{
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_icon_howto_2_white.png);
    }

    /*ラジオボタンを全て消す*/
    #howtouse .tabs input[name="tab_item_01"] {
        display: none;
    }

    /*タブ切り替えの中身のスタイル*/
    #howtouse .tabs .tab_content_01 {
        display: none;
        clear: both;
        overflow: hidden;
    }

    #howtouse .tabs #charge:checked ~ #charge_content,
    #howtouse .tabs #shopping:checked ~ #shopping_content{
        display: block;
        margin-top: 80px;
    }

    #howtouse .tabs #shopping:checked ~ #shopping_content{
        margin-top: 40px;
        padding-top: 40px;
    }


    #howtouse .tabs #charge:checked ~ #charge_content{
        display: flex;
    }

    #howtouse .tabs #charge_content .area_img{
        width: 38%;
        margin-left: 5%;
        margin-top: 55px;
    }

    #howtouse .tabs #charge_content .area_text{
        display: flex;
        flex-direction: column;
        width: 52%;
        margin-left: 5%;
    }

    #slider_howtouse{
        width: 100%;
        margin-top: 20px;
    }

    #slider_howtouse .slick-list{
        width: 100%;
    }

    #slider_howtouse .slick-dots{
        bottom: 0px;
    }

    #slider_howtouse .slick-arrow {
        display: block;
        position: absolute;
        top: 0;
        bottom: 0;
        margin: auto;
        padding: 0;
        width: 20px;
        height: 38px;
        color: transparent;
        z-index: 1;
        transition: opacity 0.5s;
        z-index: 1;
      }
      #slider_howtouse .slick-arrow:hover {
        opacity: 0.7;
      }
      
      /* 共通設定 */
      
      #slider_howtouse .slick-next::before,
      #slider_howtouse .slick-next::after,
      #slider_howtouse .slick-prev::before,
      #slider_howtouse .slick-prev::after {
        position: absolute;
        top: 0;
        bottom: 0;
        margin: auto;
        content: "";
        vertical-align: middle;
      }
      #slider_howtouse .slick-next::after,
      #slider_howtouse .slick-prev::after {
        width: 14px;
        height: 14px;
        border-top: 2px solid #AEAEAE;
        border-right: 2px solid #AEAEAE;
      }
      
      /* next */
      
      #slider_howtouse .slick-next {
        right: 0px;
      }
      #slider_howtouse .slick-next::after {
        right: 4px;
        transform: rotate(45deg);
      }
      
      /* prev */
      
      #slider_howtouse .slick-prev {
        left: 0px;
      }
      #slider_howtouse .slick-prev::after {
        left: 4px;
        transform: rotate(-135deg);
      }
      
      @media screen and (max-width: 767px) {
        #slider_howtouse .slick-next::after,
        #slider_howtouse .slick-prev::after {
          width: 10px;
          height: 10px;
        }
        #slider_howtouse .slick-next {
          right: 8px;
        }
        #slider_howtouse .slick-prev {
          left: 8px;
        }
        #slider_howtouse .slick-next::after {
          right: 2px;
        }
      }

    .slider_howtouse_item > p{
        width: 68%;
        background-color: #F2F9EF;
        border-radius: 16px;
        color: #5CB037;
        font-weight: bold;
        margin: 0 auto;
        text-align: center;
        font-size: 22px;
        padding: 10px 0;
    }

    .howtouse_charge_item{
        display: flex;
        margin-top: 25px;
        flex-direction: row;
    }

    .howtouse_charge_item .item_img{
        width: 26%;
        margin: auto;
        margin-left: 4%;
    }
    .howtouse_charge_item .item_img img{
        width: 100%;
    }

    .howtouse_charge_item p{
        font-size: 16px;
        line-height: 2;
        width: 61%;
        margin: 0 4% 0 5%;
        color: #333333;
    }

    #slider_howtouse + p.dotline-bottom{
        margin-top: 105px;
    }

    #shopping_content .shopping_content_item_card {
        position: relative;
        z-index: 1;
        text-align: center;
        position: relative;
        height: 420px;
    }

    #shopping_content .shopping_content_item_card div{
        position: absolute;
    }

    #shopping_content .shopping_content_item_card .card_text{
        background-color: #FFFFFF;
        border-radius: 20px;
        text-align: center;
        width: 45%;
        height: 356px;
        padding: 63px 18px;
    }

    #shopping_content .shopping_content_item_card .card_img{
        top: -40px;
    }

    #shopping_content .shopping_content_item_card .card_text p {
        text-align: left;
        font-size: 18px;
        line-height: 2;
        margin-top: 10px;
    }

    #shopping_content .shopping_content_item_card_01 .card_text{
        margin: 0 0 0 auto;
        right: 20px;
    }

    #shopping_content .shopping_content_item_card_02{
        margin-top: 110px;
    }

    #shopping_content .shopping_content_item_card_02 .card_text{
        margin: 0 auto 0 0;
        z-index: 1;
        padding: 120px 18px;
    }

    #shopping_content .shopping_content_item_card_02 .card_img{
        right: 12px;
    }

    #shopping_content .shopping_content_item_mark{
        text-align: center;
        background-color: #FFFFFF;
        border-radius: 20px;
        padding: 50px 20px;
        border: none;
    }

    #shopping_content .shopping_content_item_mark .shopping_mark{
        text-align: center;
        margin-top: 20px;
    }

    #shopping_content .shopping_content_item_mark .shopping_mark img {
        width: 280px;
    }

    #shopping_content .shopping_content_item_mark .shopping_mark + h3 {
        margin-top: 50px;
    }

    #shopping_content .shopping_content_item_mark .stores {
        margin: 0 0 30px;
    }

    #shopping_content .shopping_content_item_mark .stores .stores_navi {
        display: flex;
        justify-content: center;
    }

    #howtouse {
        padding-top: 75px;
    }

    #howtouse .stores .tab_item{
        border: solid 1px #75c04a;
        box-sizing: border-box;
        color: #75c04a;
        font-weight: bold;
        align-items: center;
        width: 178px;
        border-radius: 40px;
        font-size: 16px;
        display: inline-block;
        padding: 8px;
        text-align: center;
        margin:20px 0 0 8px;
    }

    #howtouse .stores input:checked + .tab_item{
        background: #75c04a;
        color: #fff;
    }

    #howtouse .storeListLink{
        text-align: center;
        margin-top: 25px;
    }

    #howtouse .storeListLink a{
        text-decoration: underline;
        font-size: 14px;
    }

    /*ラジオボタンを全て消す*/
    #howtouse .stores input[name="tab_item_01"] {
        display: none;
    }

    /*タブ切り替えの中身のスタイル*/
    #howtouse .stores .tab_content {
        display: none;
        clear: both;
        overflow: hidden;
    }
    #howtouse .stores #conveni:checked ~ #conveni_content,
    #howtouse .stores #super:checked ~ #super_content,
    #howtouse .stores #restaurant:checked ~ #restaurant_content,
    #howtouse .stores #other:checked ~ #other_content{
        display: block;
    }

    #howtouse .stores .tab_content .stores_list {
        width: 640px;
        margin: 20px auto 0;
        display: flex;
        flex-wrap: wrap;
        justify-content: flex-start;
    }

    #howtouse .stores .tab_content .stores_list li {
        width: 160px;
        padding: 10px 0 0;
        text-align: center;
    }

    #howtouse .stores .tab_content .stores_list li img {
        width: 100px;
    }

    #howtouse .stores .tab_content .stores_list li span {
        font-size: 14px;
        line-height: 1.69429;
        display: block;
        letter-spacing: -0.08em;
    }
    


    #voice {
        text-align: center;
        padding-top: 26px;
        padding-bottom: 94px;
        margin-top:66px
    }
    #voice h2 {
        margin-bottom: 0;
    }

    #voice > div{
        max-width: 1000px;
        margin: 0 auto;
        text-align: center;
    }
    #voice .voice_user {
        position: relative;
        margin-top: 16px;
        display: inline-block;
        width: 250px;
    }
    #voice .voice_1 {
        height: 150px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_voice_1_pc.png);
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
    }
    #voice .voice_2 {
        height: 150px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_voice_2_pc.png);
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
    }
    #voice .voice_3 {
        height: 150px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_voice_3_pc.png);
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
    }
    #voice .voice_4 {
        height: 150px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_voice_4_pc.png);
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
    }
    #voice .voice_5 {
        height: 150px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_voice_5_pc.png);
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
    }
    #voice .voice_user p {
        width: 156px;
        font-size: 16px;
        color: #333333;
        line-height: 1.5;
        left: 34%;
        top: 24%;
    }

    #step {
        max-width: 1000px;
        margin: 0 auto;
    }

    #step h2{
        margin: 40px auto 0;
    }
    #step p{
        font-size: 18px;
        line-height: 1.7;
    }

    #step p.anno{
        text-align: center;
        font-size: 12px;
    }

    #step .acd-content h3 {
        font-size: 24px;
        margin: 51px auto 30px auto;
    }
    #step h3 span {
        font-size: 24px;
    }

    #step th,
    #step td {
        font-size: 20px;
    }

    #step .acd-label {
        padding: 27px 0 21px 130px;
        margin-bottom: 0px;
    }

    #step .acd-label img {
        max-width: 60px;
        left: 60px;
        top: 10px;
    }

    .step_desc_inner{
        width: 80%;
        max-width: initial;
    }


    .step_desc_inner.step2{
        width: 85%;
        margin: 40px auto 0;
    }

    .step_desc_inner.step2 p{
        line-height: 1.9;
    }

    .step_desc_inner h4 {
        margin: 20px auto 10px;
        font-size: 24px;
    }

    .step_table th {
        width: 29%;
        height: 123px;
        text-align: center;
    }

    .step_table td p{
        text-align: center;
    }

    #campaign2{
        padding-bottom: 60px;
    }

    #campaign2 .campaign_desc .campaign{
        padding-top: 65px;
    }

    .campaign_desc .acd-label{
        margin-bottom: 10px;
    }

    .cashless {
        margin-bottom: 30px;
    }

    .cashless .display_pc {
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_cashless_pc_bg.png);
        background-repeat: no-repeat;
        background-size: cover;
        background-position: center;
        min-height: 567px;
    
    }
    
    .cashless .display_pc img{
        width: 650px;
        display: block;
        margin: 0 auto;
        padding-top: 55px;
    }

    .cashless .btn-app {
        font-size: 20px;
        bottom: 58px;
        left: 50%;
        transform: translateX(-50%);
        z-index: 1;
        width: 615px;
    }

    .cashless .btn-app a{
        display: block;
        width: 100%;
        padding: 14px;
        border-radius: 88vh;
        line-height: 1.4;
    }

    .cashless .btn-app a::after{
        width: 20px;
        height:20px;
        right: 20px;
    }

    .useguide{
        max-width: 1000px;
        margin: 0 auto;
    }

    .useguide p{
        font-size: 18px;
    }

    .useguide p.anno{
        font-size: 12px;
        color: #333;
    }

    .useguide h3{
        font-size: 18px;
        border-left: solid 2px #5CB037;
        padding-left: 12px;
        margin-bottom: 13px;
        margin-top: 30px;
    }

    .useguide a{
        font-size: 12px;
    }

    .useguide .blankLink {
        margin-bottom: 10px;
    }

    .useguide .acd-label {
        margin-bottom: 48px;
    }

    .useguide .acd-content {
        width: 88%;
        margin: 0 auto;
    }

    .useguide .acd-content p{
        line-height: 1.7;
    }

    .useguide_desc_inner .anno_list {
        margin-bottom: 10px;
    }

    .useguide_desc_inner .anno_list .anno {
        margin-top: 10px;
    }

    .useguide_desc_inner ul {
        padding-left: 1em;
        margin: 10px;
    }

    .useguide_desc_inner ul li{
        margin-bottom: 2.66667vw;
    }

    .useguide .linklist{
        margin-top: 25px;
    }

    .step_desc_inner ul li, .useguide_desc_inner ul li{
        margin-bottom: 10px;
        font-size: 18px;
    }

    .inquiry{
        max-width: 1000px;
        margin: 0 auto;
    }

    .inquiry p {
        font-size: 18px;
        width: 62%;
        margin: 10px auto;
    }

    .inquiry p.anno {
        text-indent: -0.5em;
        font-size: 12px;
        color: #333;
    }

    .inquiry h2{
        font-size: 32px;
        margin-bottom: 60px;
        padding-top: 60px;
    }

    .inquiry h3{
        font-size: 18px;
        width: 62%;
        margin: 0 auto;
        border-left: solid 2px #5CB037;
        padding-left: 10px;
    }

    .inquiry img{
        max-width: 575px;
        margin: 15px auto 23px;
    }

    .inquiry p.img_center {
        margin: 32px auto;
    }

    .banner_area{
        max-width: 1000px;
        margin: 117px auto 136px;
        display: flex;
        justify-content: space-evenly;
        align-items: flex-start;
    }

    .banner_area p{
        width: 30%;
        margin-top: 0px;
    }

    .banner_area p a{
        display: inline-block;
    }

    .followbtn {
        background-color: #5CB037;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        padding-top: 30px;
        padding-bottom: 28px;
        z-index: 980;
        display: none;
    }

    .followbtn .followbtn_inner {
        max-width: 1000px;
        margin: 0 auto;
    }

    .followbtn .followbtn_inner .followbtn_contents .btn::after {
        width: 16px;
        height: 16px;
        right: 16px;
    }

    .followbtn .followbtn_inner .followbtn_contents .btn {
        width: 500px;
        margin-right: 7px;
        background-color: #EDBA0E;
        font-size: 15px;
        font-weight: 600;
        border-radius: 88vh;
        padding: 11px 89px 14px;
        letter-spacing: 1px;
        border: 2px solid #FFFFFF;
        z-index: 1000;
        position: relative;
    }

    .followbtn .followbtn_inner .followbtn_contents {
        text-align: center;
    }

    .shareArea {
        padding-bottom: 64px;
        max-width: 1000px;
        margin: 0 auto;
    }
    .shareArea .inner {
        width: 698px;
        margin: 0 auto;
    }
    .shareAreaTag {
        width: 500px;
        margin: 64px auto 0;
        display: block;
        line-height: 0;
    }
    .share {
        margin-top: 64px;
    }
    .share_list {
        margin: 10px 0 0;
    }
    .share_item {
        margin: 0 20px;
    }
    .share_item a {
        -webkit-transition: opacity 0.4s;
        -o-transition: opacity 0.4s;
        transition: opacity 0.4s;
    }
    .share_item a img {
        max-width: 100%;
    }
    footer {
        border-top: 1px solid #009595;
        padding-top: 30px;
        text-align: center;
        font-size: 14px;
    }
    .relation {
        margin-bottom: 28px;
    }
    .relation .relationLink {
        display: inline-block;
        position: relative;
        padding-right: 45px;
    }
    .relation .relationLink:first-child {
        margin-bottom: 0;
    }
    .relation .relationLink:not(:first-child) {
        margin-left: 20px;
        padding-left: 20px;
        border-left: 1px solid #999999;
    }
    .relation .relationLink a::after {
        content: "";
        position: absolute;
        top: 50%;
        right: -30px;
        width: 14px;
        height: 14px;
        background: url(/brand/googlepay_visa/img/icon-blank.png);
        background-repeat: no-repeat;
        background-size: 100%;
        background-position: center;
        -webkit-transform: translate(0, -50%);
            -ms-transform: translate(0, -50%);
                transform: translate(0, -50%);
    }
    .copyright {
        background-color: #EFEFEF;
        padding: 7px 0 9px 0;
    }
    .copyright p {
        font-size: 14px;
    }

    .relation .relationLink:first-child{
        margin-top: 10px;
    }

    .returnbtn{
        bottom: 90px;
    }
}

@media print, screen and (min-width: 768px) and (max-width:1019px){
    .main_visual h1{
        width: 1020px;
        height: 660px;
    }
    .main_visual h1 .kv_img{
        width: 919px;
    }

    .main_visual h1 .kv_img img {
        width: 918px;
    }

    .main_visual h1 .detail {
        width: 1020px;
    }

    .main_visual h1 .detail img {
        width: 1020px;
    }

    .main_visual h1 .kv_text {
        position: absolute;
        top: 294px;
        left: 280px;
    }

    .kv_tab {
        top: 348px;
        left: 92px;
        width: 183.79px;
    }


    .kv_text_item_01 {
        width:257px;
        top: -50px;
    }
    .kv_text_item_02 {
        width:295.4px;
        top: -47.8px;
    }
    .kv_text_item_03 {
        width:208.48px;
        top: -45px;
    }
    
    .kv_text_item_04 {
        width: 239.59px;
        top: 0px;
        height: 146.97px;
        left: -27.5px;
    }

    .kv_text_item_01:before {
        width:258px;
    }
    .kv_text_item_02:before {
        width:296px;
    }
    .kv_text_item_03:before {
        width:209px;
    }
    
    .kv_text_item_04:before {
        width: 241px;
        height: 147px;
    }


}

@media print, screen and (min-width: 1020px) {

    /* .main_visual h1 {
        height: 83vw;
    } */

    .main_visual h1 .kv_text {
        position: absolute;
        top: 28.83vw;
        left: 27.406vw;
    }

    .kv_tab{
        top: 34.06vw;
        left: 9vw;
        width: 18.02vw;
    }

    .kv_text_item_01 {
        width:25.27vw;
        top: -4.89vw;
    }
    .kv_text_item_02 {
        width:28.96vw;
        top: -4.68vw;
    }
    .kv_text_item_03 {
        width:20.44vw;
        top: -4.40vw;
    }
    
    .kv_text_item_04 {
        width: 23.49vw;
        top: 0px;
        height: 14.41vw;
        left: -2.70vw;
    }

    .kv_text_item_01:before {
        width:25.28vw;
    }
    .kv_text_item_02:before {
        width:28.97vw;
    }
    .kv_text_item_03:before {
        width:20.45vw;
    }
    
    .kv_text_item_04:before {
        width: 23.6vw;
        height: 14.41vw;
    }

}

@media print, screen and (min-width: 1409px) {
    /* .main_visual h1 {
        height: 1130px;
    } */
    .main_visual h1 .kv_text{
        left: calc((100vw - 1409px) / 2 + 368px);
        top: 403px;
    }
    .kv_tab{
        left: calc((100vw - 1409px) / 2 + 120px);
        top: 480px;
        width: 254px;
    }

    .kv_text_item_01 {
        width:356px;
        top: -69px;
    }
    .kv_text_item_02 {
        width:408px;
        top: -66px;
    }
    .kv_text_item_03 {
        width:288px;
        top: -62px;
    }
    
    .kv_text_item_04 {
        width: 331px;
        height: 203px;
        left: -38px;
    }

    .kv_text_item_01:before {
        width:357px;
    }
    .kv_text_item_02:before {
        width:409px;
    }
    .kv_text_item_03:before {
        width:289px;
    }
    
    .kv_text_item_04:before {
        width: 332px;
        height: 203vw;
    }
}

.main_visual h1 .detail .kv_leadtext {
    padding-bottom: 50px;
    text-align: center;
    z-index: 100;
    position: relative;
    top: -10px;
}

.main_visual h1 .detail .kv_good_design {
    text-align: center;
    z-index: 100;
    padding-bottom: 50px;
    position: relative;
    top: -10px;
}

.comic {
    width: 1000px;
    min-height: 780px;
    background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_comic_pc.png);
    background-repeat: no-repeat;
    padding: 83px 40px;
    margin: 60px auto 0;
}

.comic_emphasis {
    color: #5CB037;
    margin-bottom: 19px;
    font-size: 28px;
}

.comic_emphasis_link {
    font-size: 24px;
    color: #5CB037;
    margin-bottom: 31.5px;
}

.comic_emphasis_link a{
    text-decoration: underline;
}

.comic_emphasis::before {
    content: "";
    display: block;
    width: 2px;
    height: 1.5em;
    border-right: 2px dotted #5CB037;
    margin: 0;
    position: absolute;
    top: -1.8%;
    left: 20%;
    -webkit-transform: translateY(3px) rotate(-30deg);
    -ms-transform: translateY(3px) rotate(-30deg);
    transform: translateY(3px) rotate(-30deg);
}

.comic_emphasis::after {
    content: "";
    display: block;
    width: 2px;
    height: 1.5em;
    border-right: 2px dotted #5CB037;
    margin: 0;
    position: absolute;
    top: -1.8%;
    right: 20%;
    -webkit-transform: translateY(3px) rotate(30deg);
    -ms-transform: translateY(3px) rotate(30deg);
    transform: translateY(3px) rotate(30deg);
}

@media print, screen and (min-width: 540px) and (max-width:767px){
    /* .main_visual h1  {
        height: 190vw;
    } */
    .main_visual h1 .detail .kv_leadtext {
        padding-bottom: 20px;
        text-align: center;
        z-index: 100;
        position: relative;
    }
    
    .main_visual h1 .detail .kv_good_design {
        text-align: center;
        z-index: 100;
        position: relative;
    }
    
    .comic {
        width: 356px;
        min-height: 460px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_comic_sp.png);
        background-repeat: no-repeat;
        padding: 24px 40px 44px;
        margin: 40px auto 0;
    }
    
    .comic_emphasis {
        color: #5CB037;
        margin-bottom: 10px;
        font-size: 20px;
    }
    
    .comic_emphasis_link {
        font-size: 18px;
        color: #5CB037;
        margin-bottom: 25px;
    }
    
    .comic_emphasis_link a{
        text-decoration: underline;
    }
    
    .comic_emphasis::before {
        content: "";
        display: block;
        width: 2px;
        height: 3em;
        border-right: 2px dotted #5CB037;
        margin: 0;
        position: absolute;
        top: 1.2%;
        left: 7%;
        -webkit-transform: translateY(3px) rotate(-20deg);
        -ms-transform: translateY(3px) rotate(-20deg);
        transform: translateY(3px) rotate(-20deg);
    }
    
    .comic_emphasis::after {
        content: "";
        display: block;
        width: 2px;
        height: 3em;
        border-right: 2px dotted #5CB037;
        margin: 0;
        position: absolute;
        top: 1.2%;
        right: 7%;
        -webkit-transform: translateY(3px) rotate(20deg);
        -ms-transform: translateY(3px) rotate(20deg);
        transform: translateY(3px) rotate(20deg);
    }

    .campaign {
        padding-top: 50px;
    }
}


@media screen and (max-width: 539px) {
    /* .main_visual h1  {
        height: 205vw;
    } */
    .main_visual h1 .detail .kv_leadtext {
        padding-bottom: 20px;
        text-align: center;
        z-index: 100;
        position: relative;
    }
    
    .main_visual h1 .detail .kv_good_design {
        text-align: center;
        z-index: 100;
        position: relative;
    }
    
    .comic {
        width: 356px;
        min-height: 460px;
        background-image: url(/prepaid/kazokunoosaifu/lp/img/kazokunoosaifu_bg_comic_sp.png);
        background-repeat: no-repeat;
        padding: 24px 40px 44px;
        margin: 40px auto 0;
    }
    
    .comic_emphasis {
        color: #5CB037;
        margin-bottom: 10px;
        font-size: 20px;
    }
    
    .comic_emphasis_link {
        font-size: 18px;
        color: #5CB037;
        margin-bottom: 25px;
    }
    
    .comic_emphasis_link a{
        text-decoration: underline;
    }
    
    .comic_emphasis::before {
        content: "";
        display: block;
        width: 2px;
        height: 3em;
        border-right: 2px dotted #5CB037;
        margin: 0;
        position: absolute;
        top: 1.2%;
        left: 7%;
        -webkit-transform: translateY(3px) rotate(-20deg);
        -ms-transform: translateY(3px) rotate(-20deg);
        transform: translateY(3px) rotate(-20deg);
    }
    
    .comic_emphasis::after {
        content: "";
        display: block;
        width: 2px;
        height: 3em;
        border-right: 2px dotted #5CB037;
        margin: 0;
        position: absolute;
        top: 1.2%;
        right: 7%;
        -webkit-transform: translateY(3px) rotate(20deg);
        -ms-transform: translateY(3px) rotate(20deg);
        transform: translateY(3px) rotate(20deg);
    }

    .campaign {
        padding-top: 50px;
    }
}

