@charset "UTF-8";
/* CSS Document */

.layout-flow-type01 {
    margin-top: 40px;
    max-width: 950px;
    margin-left: auto;
    margin-right: auto
}
.layout-flow-type01_inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: -40px
}

@media screen and (max-width: 900px) {
    .layout-flow-type01_inner {
        -webkit-box-orient:vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        margin-right: 0;
        margin-top: -30px
    }
}
.section-container {
    padding: 70px 0;
    text-align: center;
    position: relative
}
.section-container[data-sb-module-theme='gray01'] {
    background: #f8f8f8;
    color: #333
}
.section-container>*:first-child {
    margin-top: 0
}

.section-container[data-sb-section-border-lv2='true'] {
    padding-top: 80px;
    margin-top: 70px
}
@media screen and (max-width: 900px) {
    .section-container {
        padding:50px 15px;
        margin-left: -15px;
        margin-right: -15px
    }
}
.section-container>*:first-child {
    margin-top: 0
}

.section-container[data-sb-section-border-lv2='true'] {
    padding-top: 80px;
    margin-top: 70px
}

@media screen and (max-width: 900px) {
    .section-container[data-sb-section-border-lv2='true'] {
        padding-top:60px;
        margin-top: 50px
    }
}

.section-container[data-sb-section-border-lv2='true']::before {
    display: block;
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 10px;
    background: #fff
}
.section-container+.section-container::before {
    display: block;
    content: '';
    position: absolute;
    left: 50%;
    top: 0;
    width: 100%;
    height: 0px;
    background: #e0e0e0;
    max-width: 100%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%)
}

@media screen and (max-width: 900px) {
    .section-container+.section-container::before {
        width:100%
    }
}
@media screen and (max-width: 900px) {
    .section-container .section-container {
        margin-left:-15px;
        margin-right: -15px
    }
}

.section-container .section-container {
    padding-top: 50px;
    padding-bottom: 50px
}

@media screen and (max-width: 900px) {
    .section-container .section-container {
        padding-top:40px;
        padding-bottom: 40px
    }
}

.section-container .section-container:last-of-type {
    padding-bottom: 0
}

.section-container .section-container+.section-container::before {
    height: 1px;
    max-width: 950px
}

@media screen and (max-width: 900px) {
    .section-container .section-container+.section-container::before {
        width:-webkit-calc(100% - 30px);
        width: calc(100% - 30px)
    }
}
.title-lv1,.title-lv2,.title-lv3,.title-lv4,.title-lv5,.title-lv1-en,.title-lv2-en,.title-lv1-bg,.title-s-lv1,.title-s-lv2 {
    font-weight: bold;
    text-align: center
}

.title-lv1 {
    max-width: 950px;
    margin-left: auto;
    margin-right: auto;
    font-size: 4rem;
    line-height: 1.5;
    margin-bottom: 70px
}

@media screen and (max-width: 900px) {
    .title-lv1 {
        max-width:100%
    }
}

@media screen and (max-width: 900px) {
    .title-lv1 {
        font-size:2.3rem;
        line-height: 1.26087;
        margin-bottom: 50px
    }
}
.title-lv3 {
    max-width: 950px;
    margin-left: auto;
    margin-right: auto;
    font-size: 2.8rem;
    line-height: 1.5;
    margin-bottom: 40px
}

@media screen and (max-width: 900px) {
    .title-lv3 {
        max-width:100%
    }
}

@media screen and (max-width: 900px) {
    .title-lv3 {
        font-size:1.9rem;
        line-height: 1.31579;
        margin-bottom: 30px
    }
}
.text {
    margin-top: 40px;
    max-width: 950px;
    margin-left: auto;
    margin-right: auto
}

@media screen and (max-width: 900px) {
    .text {
        margin-top:30px
    }
}

[data-sb-margin-type='1col'] .text,[data-sb-margin-type='2col'] .text,.table-type01_data .text {
    margin-top: 30px
}

@media screen and (max-width: 900px) {
    [data-sb-margin-type='1col'] .text,[data-sb-margin-type='2col'] .text,.table-type01_data .text {
        margin-top:25px
    }
}
@media screen and (max-width: 900px) {
    .text {
        max-width:100%
    }
}

.text-bold {
    font-weight: bold
}
.box-flow-type01-02 {
    position: relative;
    margin-top: 40px;
    background-color: #fff;
    color: #333;
    width: -webkit-calc((100% - 50px) / 2);
    width: calc((100% - 50px) / 2);
    margin-right: 50px
}

@media screen and (max-width: 900px) {
    .box-flow-type01-02 {
        width:100%;
        margin-top: 30px
    }
}

.box-flow-type01-02::after {
    content: url("../img/arrow-flow.svg");
    position: absolute;
    top: 50%;
    right: -32px;
    display: inline-block;
    width: 24px;
    height: 24px;
    margin-top: -12px;
    line-height: 0;
    -webkit-transform: rotate(-90deg);
    -ms-transform: rotate(-90deg);
    transform: rotate(-90deg)
}

@media screen and (max-width: 900px) {
    .box-flow-type01-02::after {
        top:auto;
        bottom: -22.5px;
        width: 15px;
        height: 15px;
        margin-right: -7.5px;
        -webkit-transform: rotate(0);
        -ms-transform: rotate(0);
        transform: rotate(0);
        right: 50%
    }
}
.box-flow-type01-02:last-child::after,.arrow-none::after{
    content: none;
}

.box-flow-type01-02-last {
    margin-right: 0
}

.box-flow-type01-02::after {
    right: -37px
}

@media screen and (max-width: 900px) {
    .box-flow-type01-02::after {
        right:50%
    }
}

.box-flow-type01-02_text-number {
    margin-top: 0;
    padding: 5px 40px;
    background-color: #000;
    color: #fff;
    text-align: center;
    font-size: 1.4rem;
    font-weight: bold;
    line-height: 1.5;
    text-align: center
}
@media screen and (max-width: 900px) {
    .box-flow-type01-02_text-number {
        padding:5px 15px;
        font-size: 1.5rem;
        line-height: 1.4
    }
}
.box-flow-type01-02_box {
    padding: 30px;
    text-align: left;
    padding: 40px
}

@media screen and (max-width: 900px) {
    .box-flow-type01-02_box {
        padding:30px 15px
    }
}

.box-flow-type01-02_box>*:first-child {
    margin-top: 0
}
.image-type01 {
    margin-top: 40px
}

@media screen and (max-width: 900px) {
    .image-type01 {
        margin-top:30px
    }
}

[data-sb-margin-type='1col'] .image-type01,[data-sb-margin-type='2col'] .image-type01,.table-type01_data .image-type01 {
    margin-top: 30px
}

@media screen and (max-width: 900px) {
    [data-sb-margin-type='1col'] .image-type01,[data-sb-margin-type='2col'] .image-type01,.table-type01_data .image-type01 {
        margin-top:25px
    }
}
.image-type01_image {
    display: block
}
@media screen and (min-width: 901px) {
    .image-type01_image[data-sb-image-size-pc='full'] {
        width:100%
    }

    .image-type01_image[data-sb-image-size-pc='auto'] {
        max-width: 100%;
        margin: auto
    }
}
@media screen and (max-width: 900px) {
    .image-type01_image[data-sb-image-size-sp='full'] {
        width:100%
    }

    .image-type01_image[data-sb-image-size-sp='auto'] {
        max-width: 100%;
        margin: auto
    }
}
.tab-type01 {
    margin-top: 40px
}

@media screen and (max-width: 900px) {
    .tab-type01 {
        margin-top:30px
    }
}
@media screen and (max-width: 900px) {
    .tab-type01 {
        margin-left:-15px;
        margin-right: -15px
    }
}
@media screen and (max-width: 900px) {
    .tab-type01-detail {
        padding:0 15px
    }
}
.applink-ios {
    margin-top: 40px;
    max-width: 950px;
    margin-left: auto;
    margin-right: auto;
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    padding: 60px 0;
    background-color: #fff;
    text-align: center
}

@media screen and (max-width: 900px) {
    .applink-ios {
        margin-top:30px
    }
}

[data-sb-margin-type='1col'] .applink-ios,[data-sb-margin-type='2col'] .applink-ios,.table-type01_data .applink-ios {
    margin-top: 30px
}

@media screen and (max-width: 900px) {
    [data-sb-margin-type='1col'] .applink-ios,[data-sb-margin-type='2col'] .applink-ios,.table-type01_data .applink-ios {
        margin-top:25px
    }
}
@media screen and (max-width: 900px) {
    .applink-ios {
        max-width:100%
    }
}

@media screen and (max-width: 900px) {
    .applink-ios {
        -webkit-box-orient:vertical;
        -webkit-box-direction: normal;
        -webkit-flex-direction: column;
        -ms-flex-direction: column;
        flex-direction: column;
        padding: 40px 15px
    }
}

.applink-ios_section {
    -webkit-box-flex: 1;
    -webkit-flex-grow: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -webkit-flex-basis: 0%;
    -ms-flex-preferred-size: 0%;
    flex-basis: 0%;
    padding: 0 40px;
    border-left: 1px solid #e0e0e0
}

@media screen and (max-width: 900px) {
    .applink-ios_section {
        -webkit-flex-basis:auto;
        -ms-flex-preferred-size: auto;
        flex-basis: auto;
        margin-top: 30px;
        padding: 30px 0 0;
        border-left: none;
        border-top: 1px solid #e0e0e0
    }
}

.applink-ios_section:first-child {
    border-left: none
}

@media screen and (max-width: 900px) {
    .applink-ios_section:first-child {
        margin-top:0;
        padding-top: 0;
        border-top: none
    }
}

.applink-ios_section>*:first-child {
    margin-top: 0
}
.applink-ios_image {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    margin-top: 20px
}

.applink-ios_image>div:last-child {
    margin-right: 0
}

.applink-ios_image-badge-link {
    text-decoration: none;
    -webkit-transition: opacity 0.4s;
    transition: opacity 0.4s
}
.applink-ios_image-qr {
    margin-left: 60px
}

@media screen and (max-width: 900px) {
    .applink-ios_image-qr {
        display:none
    }
}
.mercury>.title-lv1,.mercury>header[data-sb-title-lv='1'] {
    padding-top: 70px
}

@media screen and (max-width: 900px) {
    .mercury>.title-lv1,.mercury>header[data-sb-title-lv='1'] {
        padding-top:50px
    }
}

[data-sb-margin-type='1col']>*:first-child,[data-sb-margin-type='2col']>*:first-child,[data-sb-margin-type='3col']>*:first-child,[data-sb-margin-type='4col']>*:first-child,[data-sb-margin-type='text-1col']>*:first-child,[data-sb-margin-type='text-2col']>*:first-child,[data-sb-margin-type='text-3col']>*:first-child,[data-sb-margin-type='text-4col']>*:first-child,[data-sb-margin-type='list-artice-type01']>*:first-child,[data-sb-margin-type='layout-form-type01']>*:first-child,[data-sb-margin-type='layout-form-type02']>*:first-child,.table-type01_data>*:first-child {
    margin-top: 0
}
.text+.text {
    margin-top: 30px
}

@media screen and (max-width: 900px) {
    .text+.text {
        margin-top:20px
    }
}

.pt0{
	padding-top: 0 !important;
}
.text-line{
	text-decoration:underline;
}
.mb30{
	margin-bottom: 30px;
}
.layout-flow-type01_inner .text{
	padding: 0 30px;
	margin-left: 0;
	text-align: left;
}
.flex-column{
	display: flex;
	flex-direction: column;
}
.ml0{
	margin-left: 0;
}
.image-border{
	border: solid #eee 2px;
}
.lead-section-container{
	background-color: #fff;
    margin: 30px;
    padding: 10px 30px 50px 30px;
}
.icon_image{
	width: 380px;
	margin: 0 auto;
	display: flex;
	flex-direction: row;
	justify-content: space-between;
}
.icon_image01_01,.icon_image01_03{
	width: auto;
	height: 100px;
}
.icon_image01{
	margin-right: 8px;
	margin-top: 30px;
}
.icon_image01_02{
	width: auto;
	height: 100px !important;
	background-color: white;
    border: none;
}

.icon_image01_03{
	margin-right: 0px;
}
.icon_image01_01{
	background-color: #fff;
}
.note{
	font-size: 1.2rem;
	text-align: right;
}
.c-s-list .text{
	margin-top: 10px; 
	}

@media screen and (max-width: 900px) {
	.lead-section-container{
	background-color: #fff;
    margin: 15px;
    padding: 5px 20px 25px 20px;
}
	.icon_image{
	max-width: 100%;
}
	.icon_image01_01,.icon_image01_02,.icon_image01_03{
	width: auto;
	height: 100px;
}
	.wb{
		word-break: break-all;
}
	.icon_image01_02{
	height: auto;
}
}
@media screen and (max-width: 767px) {
	.c-s-list{
	display: flex;
	justify-content: center;
	margin-top:-20px;
}
	.tac{
	text-align: center;
}
	.c-s-list .text{
	margin-top: 30px; 
	}
}