@charset "UTF-8";

/* SUB01-common */
.visual{background-image: url(/asset/img/visual-sub01.png) }

/* SUB01-01 */
.sub01-01-step {margin-bottom: 50px;}
.sub01-01-step ol{display: flex;}
.sub01-01-step ol li{
    width: 20%; padding: 10px;
}
.sub01-01-step ol li > em{display: block;
    width: 100%; padding: 10px;
    color: #fff; text-align: center;
    background-color: #6667AB;
    border-radius: 10px 10px 0 0;
    position: relative;
}
.sub01-01-step ol li > em span{ display: block;
    font-weight: 700; font-size: 5rem;
}
.sub01-01-step ol li > em::after {content: "";
    border: 10px solid transparent; border-left-color: #6667AB ;
    position: absolute; right: -20px; top: 50%;
}
.sub01-01-step ol li:last-child > em::after{display: none;}

.sub01-01-step ol dl{ padding: 10px; border: 3px solid #6667AB;}
.sub01-01-step ol dl dt{
    margin-bottom: 10px; 
    font-weight: 700; font-size: 2rem; text-align: center; 
 }
.sub01-01-step ol dl dd{
    margin-bottom: 20px;
    font-size: 1.6rem; color: #777;
}
.sub01-01-step ol dl dd:nth-of-type(2){font-size: 1.4rem; color: #999;}
.sub01-01-step ol dl dd em {font-weight: 700; color: #6667AB ;}
.sub01-01-rule-wrap ul{display: flex; margin-bottom: 50px;}
.sub01-01-rule-wrap li{
    width: 20%; padding: 20px 10px 10px 10px;
    border: 5px solid rgb(182, 15, 154);
    border-radius: 20px 0 20px 0;
    font-size: 1.4rem; color: #999;
}
.sub01-01-rule-wrap li + li {margin-left: 20px;}
.sub01-01-rule-wrap li span{display: block;
    margin-bottom: 10px;
    font-weight: 700; text-align: center; color: #555;
}
.sub01-01-rule-wrap li:nth-child(n+4){
    border-color: #34568b;
    background-color: #f4f4f4;
}
.sub01-01-rule-wrap h4{
    padding: 20px 0;
    font-weight: 700; font-size: 2.5rem; text-align: center;
}
.sub01-01-rule-wrap h4 span {color: #aaa; font-weight: 400;}

.sub01-01 .table-style01 col:nth-child(1) {width: 15%;}
.sub01-01 .table-style01 col:nth-child(2) {width: 25%;}
.sub01-01 .table-style01 col:nth-child(3) {width: 25%;}
.sub01-01 .table-style01 col:nth-child(4) {width: 35%;}

.sub01-01-rule-wrap p {font-size: 1.4rem; color: #999;}

/* SUB01-02 */
.sub01-02 .table-style01 td {text-align: center;}
.sub01-02 button {
    width: 100%; height: 100%;padding: 5px; 
    color: #fff;
}
.sub01-02 .table-btn-on {background-color: #34568b}
.sub01-02 .table-btn-off {background-color: #777;}

/* SUB01-03 */
.sub01-03-pro { margin-bottom: 100px; }
.sub01-03-pro-plan {display: flex;
    margin-bottom: 50px; padding-bottom: 40px;
    border-bottom: 5px dashed #b3bdce; 
    border-radius: 40px;
    position: relative;
}
.sub01-03-pro-plan::after {content: "";
    width: 55px; height: 55px; margin-left: -17px;
    background: url(/asset/img/arrow-01-03-02_new.png) no-repeat center bottom;
    position: absolute; left: 50%; bottom: -55px;
}
.sub01-03-pro-plan > li {
    width: calc( 100% / 3 ); padding: 20px;    
    border: 3px dashed #34568b; border-radius: 20px;
    text-align: center;
    position: relative;
}
.sub01-03-pro-plan > li + li {
    margin-left: 20px;
}
.sub01-03-pro-plan > li + li::after{content: "";
    width: 30px; height: 30px;
    background-image: url(/asset/img/arrow-01-03-01_new.png);
    position: absolute; left: -26px; top: 50%;
}
.sub01-03-pro-plan h4 {
    width: 70%; margin: 0 auto 20px auto; padding: 20px;
    font-size: 2rem; color: #fff; line-height: 1;
    background-color: #3f8688;
    border-radius: 20px 0 ;
    box-shadow: 0 2px 5px rgba(0,0,0,0.3);
}
.sub01-03-pro-plan li h4::before{
    content: ""; display: inline-block; margin-right: 5px;
    width: 25px;height: 23px;
    background-repeat: no-repeat; background-position: right center;
}
.sub01-03-pro-plan li:nth-child(1) h4::before, 
.sub01-03-pro-plan li:nth-child(3) h4::before {
    background-image: url(/asset/img/icon-01-03-01.png);
}
.sub01-03-pro-plan li:nth-child(2) h4::before{
    background-image: url(/asset/img/icon-01-03-02.png);
}
.sub01-03-pro-plan ul{
    width: 70%; margin: 0 auto;
    color: #555;
} 
.sub01-03-pro-plan ul li{
    margin-bottom: 10px;
    font-size: 14px; line-height: 30px;
    border: 2px solid #82c0c2;
    border-top-width: 10px;
    border-radius: 0 10px  ;
    box-shadow:  0 2px 5px rgba(0,0,0,0.3);
}
.sub01-03-pro-check {display: flex;
    padding: 20px;  
    border: 3px dashed #b3bdce; 
    border-radius: 40px;
}
.sub01-03-pro-check li {
    width: calc( 100% / 3 ); padding: 20px;
    font-weight: 700; font-size: 2rem; color: #fff;  
    background-color: #6667AB;
    border-radius: 20px;
    text-align: center;
}
.sub01-03-pro-check li + li {
    margin-left: 20px;
}

.sub01-03-stra-box{display: flex; 
    text-align: center;
}
.sub01-03-stra-box > div{display: flex;
    flex-direction: column;
    padding: 20px;
    border: 3px dashed #34568b;
    border-radius: 20px;
    position: relative;
}
.sub01-03-stra-box1 , .sub01-03-stra-box3{flex: 1 }
.sub01-03-stra-box2{flex: 2;}
.sub01-03-stra-box > div + div {margin-left: 20px;}
.sub01-03-stra-box > div + div::after {content: ""; 
    width: 30px; height: 30px;
    background-image: url(/asset/img/arrow-01-03-01_new.png);
    position: absolute; left: -26px; top: 50%;
}
.sub01-03-stra-box h4{ 
    margin-bottom: 30px;
    font-weight: 700; font-size: 3rem; 
}
.sub01-03-stra-box h4 span{display: block;
    font-weight: 400; font-size: 1.6rem; 
}
.sub01-03-stra-box > div  p {display: flex;
    flex-direction: column; justify-content: center;
    width: 180px; height:180px ; margin: 0 auto; padding: 0 23px;
    border: 5px solid #34568b; border-radius: 100%;
    font-weight: 700; font-size: 2rem; 
    background-color: #eee;
    box-shadow: 0 5px 5px rgba(0,0,0,0.3);
}
.sub01-03-stra-box2 div{ display: flex; justify-content: space-between;}
.sub01-03-stra-box2 div p {margin: 0 25px;
    position: relative; z-index: 100;
}
.sub01-03-stra-box2 ul{display: flex; 
    flex-direction: column; flex: 1;
}
.sub01-03-stra-box2 ul li{ 
    width: 100%; height: 40px;
    background-color: #34568b;
    font-size: 1.4rem; line-height: 40px; color: #fff;
    position: relative;
    box-shadow: 0 5px 5px rgba(0,0,0,0.3);
    border-radius: 10px 0 ;
}
.sub01-03-stra-box2 ul li + li {margin-top: 30px;}
.sub01-03-stra-box2 ul li::before {content: "";
    width: 50px; height: 2px; margin: auto;
    background-color: #34568b;
    position: absolute; top: 0; bottom: 0;
}
.sub01-03-stra-ul1 li::before{ right: -50px;
    transform-origin: left center;
}
.sub01-03-stra-ul1 li:nth-child(1):before {transform: rotate(45deg);}
.sub01-03-stra-ul1 li:nth-child(3):before {transform: rotate(-45deg);}
.sub01-03-stra-ul2 li::before{ left: -50px;
    transform-origin: right center;    
}
.sub01-03-stra-ul2 li:nth-child(1):before {transform: rotate(-45deg);}
.sub01-03-stra-ul2 li:nth-child(3):before {transform: rotate(45deg);}

/* SUB01-04 */


/* SUB01-05 */


/* SUB01-06 */




@media only screen and (max-width:1240px){

/* SUB01-01 */
.sub01-01-step ol{flex-wrap: wrap; }
.sub01-01-step ol li{ width: 100%; padding: 0; margin-bottom: 10px;}
.sub01-01-step ol li > em{padding: 5px; font-size: 1.4rem;}
.sub01-01-step ol li > em span{ display: inline-block; font-size: 1.4rem;}
.sub01-01-step ol li > em::after {display: none}
.sub01-01-step ol dl dt{font-size: 1.6rem;}
.sub01-01-step ol dl dd{margin-bottom: 10px; font-size: 1.4rem; }
.sub01-01-rule-wrap ul{margin-bottom: 20px; flex-wrap: wrap;}
.sub01-01-rule-wrap li{
    width: calc( ( 100% - 10px ) / 2 ); padding: 10px 5px 5px 5px ; margin-bottom: 10px;
    border: 3px solid rgb(182, 15, 154);
}
.sub01-01-rule-wrap li + li {margin-left: 0}
.sub01-01-rule-wrap li:nth-child(odd) {margin-right: 10px;}
.sub01-01-rule-wrap h4{ padding: 10px 0; font-size: 1.8rem;}

.sub01-01-rule-wrap p {font-size: 1.4rem; color: #999;}

/* SUB01-02 */
.sub01-02 .table-style01 thead th:nth-of-type(3){display: none;}
.sub01-02 .table-style01 thead th:nth-of-type(8){display: none;}
.sub01-02 .table-style01 tbody td:nth-of-type(1){display: none;}
.sub01-02 .table-style01 tbody td:nth-of-type(6){display: none;}

/* SUB01-03 */
.sub01-03-pro > div {display: flex;}
.sub01-03-pro-plan {
    flex-direction: column; flex: 3;
    margin: 0 20px 0 0; padding: 0;  
    border: none;
}
.sub01-03-pro-plan::after {display: none;}
.sub01-03-pro-plan > li {
    width: 100%; padding: 10px; margin-bottom: 0;    
    border: 3px dashed #34568b; border-radius: 20px;
}
.sub01-03-pro-plan > li + li {margin-left: 0; margin-top: 20px;}
.sub01-03-pro-plan > li + li::after{
    width: 20px;height: 20px; margin: auto;
    background-size: contain;
    left: 0; right: 0; top: -26px;
    transform: rotate(90deg);
}
.sub01-03-pro-plan h4 {
    width: 100%; margin: 0 auto 10px auto; padding: 10px;
    font-size: 1.6rem; 
    border-radius: 10px 10px 10px 0 ;
}
.sub01-03-pro-plan li h4::before{display: none;}
.sub01-03-pro-plan ul{ width: 100%;} 
.sub01-03-pro-plan ul li{
    margin-bottom: 5px; padding: 5px  0;
    font-size: 1.2rem; line-height: 1;
    border: 2px solid #82c0c2;
}
.sub01-03-pro-check {
    flex-direction: column; flex: 1; justify-content: space-between;
    padding: 10px;  
    border: 3px dashed #b3bdce; 
    border-radius: 20px;
}
.sub01-03-pro-check li { display: flex; justify-content: center; align-items: center;
    flex: 1;
    width: 100%; padding: 10px;
    font-size: 1.4rem; 
    border-radius: 10px;
}
.sub01-03-pro-check li + li {margin-left: 0; margin-top: 30px;}

.sub01-03-stra-box {flex-direction: column;}
.sub01-03-stra-box > div {padding: 10px;}
.sub01-03-stra-box > div + div {margin-left: 0px; margin-top: 30px;}
.sub01-03-stra-box > div + div::after {
    position: absolute; left: 50%; top: -36px;
    transform: rotate(90deg) translate(0 , 50%);
}
.sub01-03-stra-box h4{ 
    margin-bottom: 10px;
    font-size: 2rem; 
}
.sub01-03-stra-box h4 span{display: block;
    font-size: 1.4rem; 
}
.sub01-03-stra-box > div  p {
    width: 120px; height:120px ; padding: 0 15px;
    font-size: 1.4rem; 
}
.sub01-03-stra-box2 div p { width: 90px; height: 90px;  margin: 0 5px;}
.sub01-03-stra-box2 ul li{ 
    height: 30px;
    font-size: 1.2rem; line-height: 30px; 
}
.sub01-03-stra-box2 ul li + li {margin-top: 5px;}

/* SUB01-04 */


/* SUB01-05 */


/* SUB01-06 */




}



