/* Layout
---------------------------------------------------------- */

#wrapper {
    background: url(../img/bg_sub_common01.jpg) center top no-repeat !important;
}

#headerWrap {
    height: 226px;
}

#contents {
    width: 1000px;
    margin: 0 auto;
}

#contentsLeft {
    margin-bottom: 50px;
}


/* subHeader
---------------------------------------------------------- */

#subHeader {
    position: relative;
    margin-bottom: 34px;
}

#subHeader:after {
    content: "";
    display: block;
    width: 2000px;
    height: 240px;
    position: absolute;
    left: 50%;
    top: 0;
    margin-left: -1000px;
    background: url(../img/img_sub_header01.png) center center no-repeat;
    z-index: 100;
}

#subHeaderIn {
    width: 1000px;
    margin: 0 auto;
    height: 240px;
    position: relative;
}

#subHeaderIn:after {
    content: "";
    display: block;
    width: 68px;
    height: 49px;
    background: url(../img/bg_sub_header.png) center center no-repeat;
    position: absolute;
    top: 13px;
    right: -30px;
    z-index: 100;
}


/* breadcrumb
---------------------------------------------------------- */

#breadcrumb {
    position: absolute;
    width: 1000px;
    margin: 0 auto;
    overflow: hidden;
    bottom: 0;
    left: 50%;
    margin-left: -500px;
    z-index: 200;
}

#breadcrumb ul {
    overflow: hidden;
    float: right;
    margin-bottom: 73px;
}

#breadcrumb ul:after {
    margin-top: 8px;
    content: "";
    display: block;
    width: 100%;
    height: 1px;
    background: #abce05;
    z-index: 300;
    position: relative;
}

#breadcrumb ul li {
    display: inline-block;
    color: #abce05;
}

#breadcrumb a {
    color: #abce05;
}

#breadcrumb a:hover {
    color: #abce05;
    text-decoration: underline;
}

#breadcrumb li:after {
    content: '';
    display: inline-block;
    width: 20px;
    height: 12px;
    background-image: url(../img/ico_breadcurmb_arrow.png);
    background-repeat: no-repeat;
    background-position: center center;
    margin: 0px 4px 0px 10px;
    position: relative;
}

#breadcrumb li:last-child:after {
    content: none;
    padding: 0px;
    position: relative;
    top: 0px;
}


/* side
---------------------------------------------------------- */
.side_tit01 {
    position: relative;
}

.side_tit01:after {
    position: absolute;
    content: "";
    display: block;
    width: 287px;
    height: 105px;
    background: url(../img/img_side_tit01.png) center center no-repeat;
    left: 0;
    top: 0;
}

/* lNavi
---------------------------------------------------------- */

#lNavi {
    overflow: hidden;
}

#lNavi li {
    margin-bottom: 10px;
}

#lNavi li:last-child {
    margin-bottom: 0;
}

#lNavi li a {
    display: block;
}

#lNavi #lnavi01 a:hover,
#lNavi #lnavi01 a.current {
    background: url(../img/lnavi_on01.png) center center no-repeat;
}

#lNavi #lnavi02 a:hover,
#lNavi #lnavi02 a.current {
    background: url(../img/lnavi_on02.png) center center no-repeat;
}

#lNavi #lnavi03 a:hover,
#lNavi #lnavi03 a.current {
    background: url(../img/lnavi_on03.png) center center no-repeat;
}

#lNavi #lnavi04 a:hover,
#lNavi #lnavi04 a.current {
    background: url(../img/lnavi_on04.png) center center no-repeat;
}

#lNavi #lnavi05 a:hover,
#lNavi #lnavi05 a.current {
    background: url(../img/lnavi_on05.png) center center no-repeat;
}

#lNavi #lnavi06 a:hover,
#lNavi #lnavi06 a.current {
    background: url(../img/lnavi_on06.png) center center no-repeat;
}

#lNavi #lnavi07 a:hover,
#lNavi #lnavi07 a.current {
    background: url(../img/lnavi_on07.png) center center no-repeat;
}

#lNavi #lnavi08 a:hover,
#lNavi #lnavi08 a.current {
    background: url(../img/lnavi_on08.png) center center no-repeat;
}

#lNavi #lnavi09 a:hover,
#lNavi #lnavi09 a.current {
    background: url(../img/lnavi_on09.png) center center no-repeat;
}

#lNavi #lnavi10 a:hover,
#lNavi #lnavi10 a.current {
    background: url(../img/lnavi_on10.png) center center no-repeat;
}

#lNavi #lnavi11 a:hover,
#lNavi #lnavi11 a.current {
    background: url(../img/lnavi_on11.png) center center no-repeat;
}

#lNavi #lnavi12 a:hover,
#lNavi #lnavi12 a.current {
    background: url(../img/lnavi_on12.png) center center no-repeat;
}

#lNavi li a:hover img,
#lNavi li a.current img {
    visibility: hidden;
}


/* bnrSubArea01
---------------------------------------------------------- */

.bnrSubArea01 {
    padding-top: 50px;
}

.bnrSubArea01 ul li {
    margin-bottom: 20px;
}


/* sub page style
---------------------------------------------------------- */


/* h */

.h3_ti01 {
    font-size: 28px;
    color: #000000;
    font-weight: bold;
    margin-bottom: 40px;
    position: relative;
}

.h3_ti01:after {
    content: "";
    display: block;
    height: 13px;
    width: 100%;
    margin-top: 40px;
    background: url(../img/img_h3_01.png) left bottom no-repeat;
}

.h3_ti02 {
    font-size: 26px;
    font-weight: bold;
    line-height: 150%;
    margin-bottom: 32px;
    position: relative;
    color: #2da479;
    font-weight: normal;
}

.h3_ti02 span {
    display: block;
    border: 1px solid #2da479;
    color: #2da479;
    background: url(../img/bg_h3_02.png) right bottom no-repeat;
    padding: 15px 20px;
}

.h3_ti02:before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    left: 9px;
    bottom: -9px;
    border-right: 1px solid #2da479;
    border-bottom: 1px solid #2da479;
}

.h3_ti03 {
    font-size: 22px;
    padding: 3px 0 8px 63px;
    font-weight: bold;
    line-height: 150%;
    margin-bottom: 23px;
    position: relative;
    background: url(../img/bg_h3_03.png) left bottom no-repeat;
    color: #49c1ba;
    font-weight: normal;
}

.h3_ti03:after {
    content: "";
    width: 100%;
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    border-bottom: 1px solid #49c1ba;
}


.h4_ti01 {
    font-size: 24px;
    color: #49c1ba;
    font-weight: normal;
    line-height: 160%;
    margin-bottom: 20px;
    position: relative;
}


.h4_ti02 {
    font-size: 24px;
    font-weight: bold;
    line-height: 140%;
    margin: 10px 0 10px;
    position: relative;
}

.h4_ti03 {
    font-size: 24px;
    color: #24a578;
    font-weight: normal;
    line-height: 160%;
    margin-bottom: 20px;
    position: relative;
}


/* box */

.div_box01 {
    margin-bottom: 60px;
}

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

.div_boxMin01 {
    margin-bottom: 40px;
    position: relative;
}

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

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

.div_boxMin02 {
    margin-bottom: 40px;
    position: relative;
}

.div_boxMin02:before {
    content: "";
    height: 70px;
    width: 225px;
    border-left: 1px solid #24a578;
    border-top: 1px solid #24a578;
    display: block;
    position: absolute;
    top: 0;
    left: 0;
}

.div_boxMin02:after {
    content: "";
    height: 70px;
    width: 150px;
    border-right: 1px solid #24a578;
    border-bottom: 1px solid #24a578;
    display: block;
    position: absolute;
    right: 0;
    bottom: 0;
}

.label_boxMin01 {
    position: absolute;
    border: 1px solid #49c1ba;
    left: 50px;
    top: -13px;
    background: #fff;
}

.div_boxMinIn {
    padding: 40px 30px;
}

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

.div_boxWrap01 .div_boxMin01:first-child {
    margin-top: 13px;
}

.div_boxWrap01 .div_boxMin01:last-child {
    margin-bottom: 0;
}

.div_boxMin01 .flImgR,
.div_boxMin01 .flImgL {
    margin-bottom: 0 !important;
}

.div_box01 p {
    overflow: hidden;
}

.div_flow01 {
    background: url(../img/bg_common02.jpg);
    position: relative;
}

.flowItem {
    overflow: hidden;
    position: relative;
    background: url(../img/bg_flow01.jpg) 35px top repeat-y;
}

.flowItem:before {
    content: '';
    display: block;
    width: 70px;
    height: 90px;
    position: absolute;
    left: 0;
    top: 0;
    background-repeat: no-repeat;
    background-position: center top;
    position: absolute;
    z-index: 100;
    background-color: #fff;
}

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

.flowNum01:before {
    background-image: url(../img/flow_num01.png);
}

.flowNum02:before {
    background-image: url(../img/flow_num02.png);
}

.flowNum03:before {
    background-image: url(../img/flow_num03.png);
}

.flowNum04:before {
    background-image: url(../img/flow_num04.png);
}

.flowNum05:before {
    background-image: url(../img/flow_num05.png);
}

.flowNum06:before {
    background-image: url(../img/flow_num06.png);
}

.flowNum07:before {
    background-image: url(../img/flow_num07.png);
}

.flowNum08:before {
    background-image: url(../img/flow_num08.png);
}

.flowNum09:before {
    background-image: url(../img/flow_num09.png);
}

.flowNum10:before {
    background-image: url(../img/flow_num10.png);
}

.pointNum01:before {
    background-image: url(../img/point_num01.png);
}

.pointNum02:before {
    background-image: url(../img/point_num02.png);
}

.pointNum03:before {
    background-image: url(../img/point_num03.png);
}

.pointNum04:before {
    background-image: url(../img/point_num04.png);
}

.pointNum05:before {
    background-image: url(../img/point_num05.png);
}

.pointNum06:before {
    background-image: url(../img/point_num06.png);
}

.pointNum07:before {
    background-image: url(../img/point_num07.png);
}

.pointNum08:before {
    background-image: url(../img/point_num08.png);
}

.pointNum09:before {
    background-image: url(../img/point_num09.png);
}

.pointNum10:before {
    background-image: url(../img/point_num10.png);
}

.frowItemIn {
    padding-left: 110px;
    overflow: hidden;
    margin-bottom: 20px;
}

.flowItem:last-child .frowItemIn {
    margin-bottom: 0px;
}

.flowItem .h4_flow01 {
    font-size: 22px;
    padding: 12px 0 0px 0px;
    font-weight: bold;
    line-height: 150%;
    margin-bottom: 19px;
    position: relative;
    color: #2da479;
    font-weight: normal;
}

.h4_staff01 {
    font-size: 18px;
    padding: 3px 0 8px 63px;
    font-weight: bold;
    line-height: 150%;
    margin-bottom: 23px;
    position: relative;
    background: url(../img/bg_h3_03.png) left bottom no-repeat;
    color: #49c1ba;
    font-weight: normal;
}

.h4_staff01:after {
    content: "";
    width: 100%;
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    border-bottom: 1px solid #49c1ba;
}



/* table */


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

.table_sub01 {
    width: 100%;
    border-collapse: collapse;
    border-top: 1px solid #abcc2a;
}

.table_sub01 tr {
    padding: 0;
    margin: 0;
    border-bottom: 1px solid #abcc2a;
}

.table_sub01 th {
    padding: 20px 25px 20px 25px;
    vertical-align: top;
    text-align: left;
    color: #abcc2a;
}

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


/*checkBox01*/

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

.checkBox01: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(../img/bg_check01.png) left top no-repeat;
}

.checkBox01: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(../img/bg_check02.png) right bottom no-repeat;
}

.checkBox01 li {
    padding: 3px 0 0 25px;
    line-height: 150%;
    margin-bottom: 23px;
    margin-left: 15px;
    position: relative;
    font-size: 18px;
    color: #7a6a56;
    font-weight: bold;
}

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

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

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

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

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

.checkBox02 li {
    padding: 3px 0 0 25px;
    line-height: 150%;
    margin-bottom: 23px;
    margin-left: 15px;
    position: relative;
    font-size: 18px;
    color: #7a6a56;
    font-weight: bold;
}

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

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

.checkBoxLeft {
    float: left;
    width: 300px;
}

.checkBoxRight {
    float: right;
    width: 300px;
}

/*imgBox01*/

.imgBoxWrap {
    padding-top: 10px;
}


.imgBox01 {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

.imgBox01 li {
    width: 200px;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 30px;
}

.imgBox01 li img {
    margin-bottom: 10px;
}

.imgBox01 li:nth-child(2) {
    margin: 0 50px;
}

.imgBox01 li:nth-child(4) {
    margin-right: 20px;
    margin-bottom: 0;
}

.imgBox01 li:nth-child(5) {
    margin-left: 20px;
    margin-bottom: 0;
}

.imgBox01 .title {
    display: flex;
    flex-direction: column;
    align-items: center;
    font-size: 20px;
    font-weight: 300;
    margin-bottom: 10px;
}

.imgBox01 .title .tit {
    background-color: #abce05;
    color: #fff;
    margin-bottom: 8px;
    padding: 1px 25px;
    line-height: 1.5;
}

.imgBox01 p {
    font-feature-settings: "palt";
    width: 188px;
}