/*--------costBox01--------------------------*/

.costBox01 {
    position: relative;
    padding: 40px 30px;
    overflow: hidden;
}

.costBox01:before {
    content: "";
    height: 80%;
    width: 80%;
    border-left: 1px solid #abce05;
    border-top: 1px solid #abce05;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    background: url(../../common/img/bg_check01.png) left top no-repeat;
}

.costBox01:after {
    content: "";
    height: 80%;
    width: 80%;
    border-right: 1px solid #abce05;
    border-bottom: 1px solid #abce05;
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
    background: url(../../common/img/bg_check02.png) right bottom no-repeat;
}

.costBox01 li {
    padding: 3px 0 0 25px;
    line-height: 150%;
    margin-bottom: 10px;
    margin-left: 15px;
    position: relative;
    font-size: 18px;
}

.costBox01 li:last-child {
    margin-bottom: 0;
}

.costBox01 li:before {
    content: "";
    display: block;
    width: 12px;
    height: 12px;
    background-color: #abce05;
    position: absolute;
    left: 0;
    top: 10px;
}

.costBoxIn {
    overflow: hidden;
    margin-bottom: 30px;
    padding: 0 15px;
}

.costBox_l {
    float: left;
    width: 350px;
}

.costBox_r {
    float: right;
    width: 250px;
}

.h4_cost {
    font-size: 26px;
    color: #B3D31D;
    padding: 15px 0 30px;
}

.p_cost {
    color: #7a6a56;
    font-weight: bold;
}

.price {
    color: #7a6a56;
    font-weight: bold;
    font-size: 22px;
}

/* table */

/*テーブルスタイル02*/

.table_sub02 {
    width: 100%;
    border-collapse: collapse;
    border-top: 1px solid #2da479;
}

.table_sub02 tr {
    padding: 0;
    margin: 0;
    border-bottom: 1px solid #2da479;
}

.table_sub02 thead th {
    padding: 20px 25px 20px 25px;
    vertical-align: top;
    text-align: center;
    color: #fff;
    background-color: #75ccac;
}

.table_sub02 tbody th {
    padding: 20px 25px 20px 25px;
    vertical-align: top;
    text-align: left;
    color: #2da479;
}

.table_sub02 td {
    padding: 20px 25px 20px 25px;
    vertical-align: top;
    text-align: left;
}

.btnArea {
    width: 260px;
    height: 30px;
    text-align: center;
    font-size: 16px;
    line-height: 29px;
    margin: 0 auto;
    border: solid 1px #7a6a56;
}

.linkBtn {
    display: block;
    width: 260;
    height: 30px;
    color: #7a6a56 !important;
}

.linkBtn:hover {
    text-decoration: none;
}

.costBnr li {
    width: 220px;
    float: left;
    margin: 0 20px 10px 0;
}

.costBnr li:nth-child(3),
.costBnr li:last-child {
    margin-right: 0;
}

.costBnr li:nth-child(4) {
    margin-left: 125px;
}

.costBnr:after {
    content: "";
    display: block;
    clear: both;
}

.table_sub01 th {
    padding: 20px 15px 20px 20px !important;
    vertical-align: middle !important;

}

#card {
    display: flex;
    margin-top: 30px;
    padding: 30px 0;
    position: relative;
}

#card02 {
    display: flex;
    margin-top: 30px;
    margin-bottom: 60px;
    padding: 30px 0;
    position: relative;
}

#card:before,
#card02:before {
    content: "";
    height: 70px;
    width: 225px;
    border-left: 1px solid #49c1ba;
    border-top: 1px solid #49c1ba;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
}

#card:after,
#card02:after {
    content: "";
    height: 70px;
    width: 150px;
    border-right: 1px solid #49c1ba;
    border-bottom: 1px solid #49c1ba;
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
}


#card img,
#card02 img {
    padding-right: 35px;
}

#card img:first-child,
#card02 img:first-child {
    padding-right: 35px;
    padding-left: 50px;
}

.table_sub02 tr .total {
    background-color: #f6fbfb;
}