@import url("https://fonts.googleapis.com/css?family=Noto+Sans+JP:100,300,400,500,700,900&display=swap&subset=japanese");
@import url("https://fonts.googleapis.com/css?family=EB+Garamond:400,700,800&display=swap");

/*### ### ###common### ### ###*/
body,
html {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 14px;
    line-height: 1.5;
    color: #888;
    font-weight: 400;
}

li {
    list-style-type: none;
}

a {
    text-decoration: none;
    color: #000;
}

a:hover {
    text-decoration: none;
}

* {
    box-sizing: border-box;
}

.mb100 {
    margin-bottom: 100px;
}

.mb80 {
    margin-bottom: 80px;
}

.mb60 {
    margin-bottom: 60px;
}

.mb40 {
    margin-bottom: 40px;
}

.mb30 {
    margin-bottom: 30px;
}

.mb20 {
    margin-bottom: 20px;
}

.mb5 {
    margin-bottom: 5px;
}


.pcOnly {
    display: block;
}

.pcNone {
    display: none;
}

.spNone {
    display: block;
}

.spOnly {
    display: none;
}

@media screen and (max-width: 1120px) {
    .pcNone {
        display: block;
    }

    .pcOnly {
        display: none;
    }
}

@media screen and (max-width: 1025px) {
    .mb100 {
        margin-bottom: 80px;
    }

    .mb80 {
        margin-bottom: 40px;
    }

    .mb60 {
        margin-bottom: 35px;
    }

    .mb40 {
        margin-bottom: 30px;
    }

    .mb30 {
        margin-bottom: 20px;
    }
}

@media screen and (max-width: 690px) {
    .mb100 {
        margin-bottom: 60px;
    }

    .spNone {
        display: none;
    }

    .spOnly {
        display: block;
    }
}

/* ### ### ###btnStyle### ### ###*/
/*btnStyle01 */
.btnStyle01 {
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    font-weight: 500;
    text-align: center;
    line-height: 1.5;
    padding: 10px 15px;
    border-radius: 4px;
    transition: 0.5s ease;
}

.btnStyle01 img {
    max-width: 20px;
    width: 100%;
    margin-right: 5px;
}

.btnStyle01:hover {
    color: #fff;
    opacity: 0.8;
}

.btnStyle01.bgBlue {
    background: #ff4500;
}

.btnStyle01.bgPink {
    background: #0000cd;
}

.btnStyle01.bgGreen {
    background: #06BD67;
}

/*### ### ###imgBgBlock### ### ###*/

.imgBgBlock {
    background-position: center;
    background-repeat: no-repeat;
    background-size: cover;
}

@media screen and (max-width: 690px) {
    .imgBgBlock {
        min-height: 180px;
    }
}

/*### ### ###title### ### ###*/

.titleAreaC {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
}

.titleAreaC h1,
.titleAreaC h2,
.titleAreaC h3,
.titleAreaC h4,
.titleAreaC h5 {
    text-align: center;
}

.titleAreaL {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
}

.titleAreaR {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-end;
}

.titleAreaC h1,
.titleAreaC h2,
.titleAreaC h3,
.titleAreaC h4,
.titleAreaC h5,
.titleAreaL h1,
.titleAreaL h2,
.titleAreaL h3,
.titleAreaL h4,
.titleAreaL h5,
.titleAreaR h1,
.titleAreaR h2,
.titleAreaR h3,
.titleAreaR h4,
.titleAreaR h5 {
    margin: 0;
    width: 100%;
}

/* @media screen and (max-width: 690px) {
    .titleAreaC {
        align-items: flex-start;
    }

    .titleAreaC h1,
    .titleAreaC h2,
    .titleAreaC h3,
    .titleAreaC h4,
    .titleAreaC h5 {
        text-align: left;
    }
} */

/*title01Style*/

.title01Style {
    font-size: 42px;
    line-height: 1.6;
    font-weight: 700;
    color: #333;
}

@media screen and (max-width: 1025px) {
    .title01Style {
        font-size: 32px;
    }
}

@media screen and (max-width: 690px) {
    .title01Style {
        font-size: 23px;
    }
}

/*title02Style*/

.title02Style {
    font-size: 32px;
    padding-left: 30px;
    position: relative;
    color: #333;
    font-weight: 700;
}

.title02Style::before {
    display: block;
    content: "";
    position: absolute;
    left: 0;
    height: 100%;
    width: 8px;
    background: #06BD67;
}

/*title02Style02*/

.title02Style02 {
    font-size: 32px;
    position: relative;
    color: #333;
    font-weight: 700;
}

@media screen and (max-width: 1025px) {

    .title02Style,
    .title02Style02 {
        font-size: 27px;
    }
}

@media screen and (max-width: 690px) {

    .title02Style,
    .title02Style02 {
        font-size: 20px;
    }

    .title02Style {
        padding-left: 10px;
    }

    .titleAreaC .title02Style02 {
        text-align: center;
    }

    .title02Style::before {
        width: 4px;
    }
}

/*title03Style*/

.title03Style {
    font-size: 26px;
    font-weight: 400;
    color: #333;
    line-height: 1.5;
    padding-bottom: 10px;
    position: relative;
}

.title03Style::before {
    display: block;
    content: "";
    position: absolute;
    width: 100%;
    left: 0;
    bottom: 0;
    height: 2px;
    background: #ddd;
}

.title03Style::after {
    display: block;
    content: "";
    position: absolute;
    width: 60px;
    height: 2px;
    background: #06BD67;
    left: 0;
    bottom: 0;
}

/*title03Style02*/

.title03Style02 {
    font-size: 26px;
    color: #06BD67;
    font-weight: 700;
    line-height: 1.5;
}

.title03Style02 span {
    display: block;
}

.title03Style02 .label {
    display: inline-block;
    background: #f5f5f5;
    padding: 8px;
    color: #06BD67;
    font-weight: 700;
    font-size: 14px;
    text-align: center;
    margin-bottom: 15px;
}

/*title03Style03*/

.title03Style03 {
    font-size: 26px;
    color: #333;
    font-weight: 700;
    line-height: 1.5;
    margin: 0;
}

@media screen and (max-width: 1025px) {

    .title03Style,
    .title03Style02,
    .title03Style03 {
        font-size: 21px;
    }
}

@media screen and (max-width: 690px) {

    .title03Style,
    .title03Style02,
    .title03Style03 {
        font-size: 18px;
    }

    .title03Style::after {
        width: 40px;
    }
}

/*title04Style*/

.title04Style {
    font-size: 20px;
    color: #06BD67;
    font-weight: 700;
    line-height: 1.5;
    display: block;
}

@media screen and (max-width: 690px) {
    .title04Style {
        font-size: 14px;
    }
}



/**/

.innerCon {
    max-width: 1120px;
    margin-left: auto;
    margin-right: auto;
}

@media screen and (max-width: 1120px) {
    .innerCon {
        max-width: calc(100% - 40px);
    }
}

@media screen and (max-width: 690px) {
    .innerCon {
        max-width: calc(100% - 30px);
    }
}

/*linkStyle01*/

.linkStyle01 {
    font-size: 20px;
    font-weight: 500;
    color: #333;
    display: block;
    line-height: 1.5;
}

@media screen and (max-width: 1025px) {
    .linkStyle01 {
        font-size: 18px;
    }
}

@media screen and (max-width: 690px) {
    .linkStyle01 {
        font-size: 12px;
    }
}

/* ### ### ###col### ### ###*/

/*col3Area*/

.col3Area {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}

.col3Area .col {
    width: calc((100% - 40px)/3);
}

@media screen and (max-width: 690px) {
    .col3Area .col {
        width: calc((100% - 10px)/3);
    }
}

/*col46Area*/

.col46Area {
    display: flex;
    justify-content: space-between;
}

.col46Area .col4 {
    width: calc(40% - 20px);
}

.col46Area .col6 {
    width: calc(60% - 20px);
}

@media screen and (max-width: 1025px) {
    .col46Area .col4 {
        width: calc(40% - 10px);
    }

    .col46Area .col6 {
        width: calc(60% - 10px);
    }
}

@media screen and (max-width: 690px) {
    .col46Area {
        flex-wrap: wrap;
    }

    .col46Area .col4.imgBgBlock {
        order: 1;
        margin-bottom: 20px;
    }

    .col46Area .col6 {
        order: 2;
    }

    .col46Area .col6 {
        width: 100%;
    }

    .col46Area .col4 {
        width: 100%;
    }
}

/*col2Area*/

.col2Area {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.col2Area .col {
    width: calc((100% - 40px)/2);
    margin-bottom: 40px;
}

.col2Area .col:nth-last-child(1),
.col2Area .col:nth-last-child(2) {
    margin-bottom: 0;
}

@media screen and (max-width: 1025px) {
    .col2Area .col {
        width: 100%;
        margin-bottom: 10px;
    }

    .col2Area .col+.col {
        margin-top: 40px;
    }
}

/*### ### ###header### ### ###*/
.headerWrapper {
    position: fixed;
    top: 0;
    width: 100%;
    background: #fff;
    left: 0;
    z-index: 10;
    padding: 10px;
    box-shadow: 0 0 20px rgba(255, 255, 255, 0.5);
}

.headerArea {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
}

.headerArea .logoArea {
    max-width: calc(15% - 10px);
}

.headerArea .logoArea a {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}

.headerArea .logoArea a img {
    width: 100%;
    max-width: 210px
}

.headerArea .navWrapper {
    max-width: calc(85% - 10px);
    width: 100%;
}

.headerArea .menuBtnWrapper {
    display: none;
}

.navWrapper {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.navWrapper .navListArea {
    max-width: calc(69% - 5px);
}

.navWrapper .btnArea {
    max-width: calc(31% - 5px);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.navWrapper .btnStyle01+.btnStyle01 {
    margin-left: 5px;
}


.btnStyle01.sp_only {
	display:none;
}

.navList {
    display: flex;
    justify-content: space-between;
}

.navList a {
    display: block;
    padding: 20px 10px;
    position: relative;
    text-align: center;
    color: #333;
}

.navList li.isHere a::before {
    transform: scaleX(1);
}

.navList a:hover::before {
    transform: scaleX(1);
}

.navList a::before {
    display: block;
    content: "";
    position: absolute;
    width: 100%;
    height: 5px;
    background: #06BD67;
    bottom: 0;
    left: 0;
    transform-origin: center;
    transform: scaleX(0);
    transition: .5s ease;
}

@media screen and (max-width: 1400px) {
    .headerArea .logoArea {
        /*max-width: calc(25% - 10px);*/
    }

    .headerArea .navWrapper {
        /*max-width: calc(75% - 10px);*/
        width: 100%;
    }

    .navList a {
        padding: 10px 5px;
        font-size: 13px;
    }

    .navWrapper .btnStyle01 {
        padding: 10px 10px;
        font-size: 12px;
    }

    .navWrapper .btnStyle01 img {
        max-width: 14px;
    }
}

@media screen and (max-width: 1025px) {

	.headerArea .logoArea {
        max-width: calc(25% - 10px);
    }

    .spBtnList {
        position: fixed;
        width: 100%;
        left: 50%;
        transform: translateX(-50%);
        top: 60px;
        display: flex;
    }

    .spBtnList .btnStyle01 {
        /*width: 50%;*/
		flex-grow:1;
        border-radius: 0;
		padding: 10px 3%;
    }
	
    .spBtnList .btnStyle01 img {
        display: none;
    }
	
    .headerWrapper {
        width: calc(100% - 20px);
        left: 50%;
        transform: translate(-50%);
    }

    .headerArea .navWrapper {
        max-width: 100%;
        width: 100%;
    }

    .navWrapper {
        position: absolute;
        flex-direction: column;
        width: 100%;
        flex-wrap: wrap;
        top: 59px;
        background: #fff;
        left: 0;
        z-index: 1;
        border-top: 1px solid #f5f5f5;
        padding-bottom: 30px;
        max-width: 100%;
        width: 100%;
    }

    /*navWrapper*/
    .navWrapper {
        opacity: 0;
        visibility: hidden;
        transform: translateY(-30px);
        transition: 1s ease;
    }

    .navWrapper.is-active {
        opacity: 1;
        visibility: visible;
        transform: translateY(0px);
    }

    .navWrapper .navListArea {
        max-width: 100%;
        width: 100%;
    }

    .navList {
        flex-wrap: wrap;
    }

    .navList li {
        width: 100%;
        border-bottom: 1px dashed #f5f5f5;
    }

    .navList a {
        padding: 20px 6px;
        font-size: 15px;
    }

    .navWrapper .btnArea {
        max-width: 100%;
        margin-top: 30px;
        width: 50%;
    }

    .navWrapper .btnArea .btnStyle01 {
        width: 50%;
        padding: 15px 10px;
        font-size: 15px;
    }

    .headerArea .menuBtnWrapper {
        display: block;
        width: 35px;
        height: 20px;
    }

    .headerArea .menuBtnWrapper .menBtn {
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        align-items: center;
        width: 100%;
        height: 100%;
    }

    .headerArea .menuBtnWrapper .menBtn .line {
        display: block;
        background: #333;
        height: 2px;
        width: 100%;
    }
}

@media screen and (max-width: 690px) {
    .spBtnList {
        top: 55px;
    }

    .headerArea .logoArea {
        max-width: calc(45% - 10px);
    }

    .navWrapper {
        top: 55px;
    }

    .navWrapper .btnArea {
        max-width: calc(100% - 20px);
        width: 100%;
    }
	
	.btnStyle01.sp_only {
		display:block;
	}
	.btnStyle01.sp_none {
		display:none;
	}
	
}

/*### ### ###mainImg### ### ###*/

.mainImgWrapper {
    height: 100vh;
    position: relative;
}

.mainImgArea {
    height: 100%;
}

.mainImgSlider {
    height: 100%;
}

.mainImgSlider .imgBgBlock {
    height: 100%;
}

.mainConArea {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 1;
}

.mainConArea .mainCon {
    background: rgba(255, 255, 255, 0.85);
    padding: 4em;
    position: relative;
    width: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.mainConArea .labelArea {
    position: absolute;
    top: -35px;
    left: -30px;
    font-size: 29px;
    font-weight: 700;
    color: #333;
    text-align: center;
    line-height: 1;
    border: 2px solid #333;
    padding: 13px 15px;
    border-radius: 2.5px;
    letter-spacing: 2px;
}

.mainConArea .labelArea::before {
    content: "";
    display: block;
    position: absolute;
    width: 30px;
    left: 20%;
    height: 2px;
    background: rgba(255, 255, 255, 1);
    left: 20%;
    bottom: -2px;
}

.mainConArea .labelArea::after {
    content: "";
    display: block;
    width: 28px;
    height: 15px;
    border: 2px solid #333;
    transform: skewX(39deg) rotate(30deg);
    border-width: 0px 2px 3px 0;
    position: absolute;
    left: 20%;
    bottom: -11px;
}

.mainTitleArea {
    width: 100%;
    display: flex;
    justify-content: center;
}

.mainTitleArea span {
    display: inline-block;
    font-weight: 700;
    line-height: 1;
    margin-bottom: 15px;
}

.mainTitleArea span:nth-last-child(1),
.mainTitleArea span:nth-last-child(2) {
    margin-bottom: 0;
}

.mainTitleArea .txtW {
    background: #83c52c;
    padding: 10px 20px;
    text-align: center;
    color: #fff;
    font-size: 57px;
}

.mainTitleArea .txtB {
    color: #333;
    font-size: 46px;
}

.mainTitleArea .txtG {
    font-size: 73px;
    color: #dc143c;
}

.mainTitleArea .txtF {
    transform: translateY(10px);
    margin-left: -15px;
    letter-spacing: 0;
}

.mainTitle {
    letter-spacing: 8px;
}

@media screen and (max-width: 1025px) {
    .mainImgWrapper {
        height: 75vh;
    }

    .mainConArea .labelArea {
        top: -50px;
    }
}

@media screen and (max-width: 690px) {
    .mainImgWrapper {
        height: 70vh;
    }

    .mainConArea .mainCon {
        padding: 2em 2em;
    }

    .mainConArea .labelArea {
        top: -29px;
        font-size: 16px;
        padding: 10px 15px;
    }

    .mainTitleArea .txtW {
        padding: 8px 10px;
        font-size: 28px;
		letter-spacing: 3px;
    }

    .mainTitleArea .txtB {
        font-size: 24px;
    }

    .mainTitleArea .txtG {
        font-size: 29px;
		letter-spacing: 3px;
    }

    .mainTitleArea span {
        margin-bottom: 8px;
    }

    .mainTitle {
        line-height: 1;
    }

    .mainConArea .labelArea::after {
        width: 18px;
        height: 10px;
        transform: skewX(30deg) rotate(30deg);
        border-width: 0px 1px 2px 0;
        left: 20%;
        bottom: -7px;
    }

    .mainConArea .labelArea::before {
        width: 20px;
        background: rgba(255, 255, 255, 1);
    }

    .mainConArea .labelArea {
        top: -32px;
        padding: 8px 15px;
		left: 20px;
    }
}

/*### ### ###blockStyleWrapper### ### ###*/

.blockStyle01 {
    position: relative;
    border: 2px solid #ddd;
    border-radius: 5px;
    padding: 0 2em 2em 2em;
    text-align: center;
    background: #fff;
}

.blockStyle01 .imgArea {
    position: relative;
    top: -10px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 30px;
    max-width: 160px;
    margin: auto;
    margin-bottom: calc(20px + 15px);
}

.blockStyle01 .imgArea img {
    max-height: 70px;
}

.blockStyle01 .imgArea::after {
    display: block;
    content: "";
    position: absolute;
    border-style: solid;
    border-color: transparent transparent transparent #fff;
    border-width: 20px 80px;
    bottom: -20px;
    left: 0;
}

.blockStyle01 .imgArea::before {
    display: block;
    content: "";
    position: absolute;
    border-style: solid;
    border-color: transparent #fff transparent transparent;
    border-width: 20px 80px;
    bottom: -20px;
    right: 0;
}

.blockStyle01::after {
    display: block;
    content: "";
    position: absolute;
    border: 30px solid;
    bottom: -60px;
    left: 50%;
    transform: translateX(-50%);
}

.blockStyle01.colorRed .imgArea::after {
    border-color: transparent transparent transparent #E61750;
}

.blockStyle01.colorRed .imgArea::before {
    border-color: transparent #E61750 transparent transparent;
}

.blockStyle01.colorYellow .imgArea::after {

    border-color: transparent transparent transparent #EAC737;
}

.blockStyle01.colorYellow .imgArea::before {
    border-color: transparent #EAC737 transparent transparent;
}

.blockStyle01.colorBlue .imgArea::after {
    border-color: transparent transparent transparent #3497E1;
}

.blockStyle01.colorBlue .imgArea::before {
    border-color: transparent #3497E1 transparent transparent;
}

.blockStyle01.colorGreen .imgArea::after {
    border-color: transparent transparent transparent #06BD67;
}

.blockStyle01.colorGreen .imgArea::before {
    border-color: transparent #06BD67 transparent transparent;
}

.blockStyle01.colorRed::after {
    border-color: #E61750 transparent transparent transparent;
}

.blockStyle01.colorYellow::after {
    border-color: #EAC737 transparent transparent transparent;
}

.blockStyle01.colorBlue::after {
    border-color: #3497E1 transparent transparent transparent;
}

.blockStyle01Wrapper .col {
    border-radius: 10px;
    transition: 0.5s ease;
}

.blockStyle01Wrapper .col:hover {
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
    border-radius: 10px;
}

@media screen and (max-width: 1025px) {
    .blockStyle01 {
        padding: 0 1em 2em;
    }

    .blockStyle01 .imgArea {
        padding: 20px;
        max-width: 140px;
    }

    .blockStyle01::after {
        border: 25px solid;
        bottom: -50px;
    }

}

@media screen and (max-width: 690px) {

    .blockStyle01 .imgArea::after {
        border-width: 10px 60px;
        bottom: -5px;
    }

    .blockStyle01 .imgArea::before {
        border-width: 10px 60px;
        bottom: -5px;
    }

    .blockStyle01 .imgArea {
        margin-bottom: calc(5px + 10px);
        padding: 10px;
        max-width: 60px;
    }

    .blockStyle01 .imgArea img {
        max-height: 30px;
    }

    .blockStyle01 {
        padding: 0 5px 15px;
    }

    .blockStyle01 .linkStyle01 {
        margin-top: -8px;
    }

    .blockStyle01::after {
        border: 10px solid;
        bottom: -20px;
    }
}

.colorRed .imgArea {
    background: #E61750;
}

.colorYellow .imgArea {
    background: #EAC737;
}

.colorBlue .imgArea {
    background: #3497E1;
}

.colorGreen .imgArea {
    background: #06BD67;
}

/*titleStyle01Area*/

.titleStyle01Area {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    padding-bottom: 15px;
}

.titleStyle01Area .titleArea {
    margin-top: 15px;
}

.titleStyle01Area .imgArea {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    padding: 20px;
    max-width: 110px;
    width: 100%;
}

.titleStyle01Area .imgArea img {
    max-height: 50px;
}

.titleStyle01Area .imgArea::before {
    display: block;
    content: "";
    position: absolute;
    border-style: solid;
    border-color: transparent transparent transparent #fff;
    border-width: 15px 55px;
    bottom: -15px;
    left: 0;
}

.titleStyle01Area .imgArea::after {
    display: block;
    content: "";
    position: absolute;
    border-style: solid;
    border-color: transparent #fff transparent transparent;
    border-width: 15px 55px;
    bottom: -15px;
    right: 0;
}

.titleStyle01Area .titleArea {
    width: calc(100% - 110px);
    background: #f5f5f5;
    padding: 20px;
    font-size: 20px;
    font-weight: 500;
}

@media screen and (max-width: 1025px) {

    .titleStyle01Area .imgArea img {
        max-height: 40px;
    }

    .titleStyle01Area .imgArea {
        padding: 10px;
        max-width: 80px;
    }

    .titleStyle01Area .titleArea {
        width: calc(100% - 80px);
        font-size: 17px;
        padding: 15px;
    }

}

@media screen and (max-width: 690px) {

    .titleStyle01Area .imgArea::before {
        border-width: 8px 55px;
        bottom: -8px;
    }

    .titleStyle01Area .imgArea::after {
        border-width: 8px 55px;
        bottom: -8px;
    }

    .titleStyle01Area .titleArea {
        width: calc(100% - 60px);
        padding: 10px;
        font-size: 15px;
    }

    .titleStyle01Area .imgArea {
        padding: 10px;
        max-width: 60px;
    }

    .titleStyle01Area .imgArea img {
        max-height: 30px;
    }

    .titleStyle01Area {
        padding-bottom: 8px;
    }

    .titleStyle01Area .titleArea {
        margin-top: 8px;
    }

}

.colorRed.titleStyle01Area .imgArea::before {
    border-color: transparent transparent transparent #E61750;
}

.colorRed.titleStyle01Area .imgArea::after {
    border-color: transparent #E61750 transparent transparent;
}

.colorYellow.titleStyle01Area .imgArea::before {
    border-color: transparent transparent transparent #EAC737;
}

.colorYellow.titleStyle01Area .imgArea::after {
    border-color: transparent #EAC737 transparent transparent;
}

.colorBlue.titleStyle01Area .imgArea::before {
    border-color: transparent transparent transparent #3497E1;
}

.colorBlue.titleStyle01Area .imgArea::after {
    border-color: transparent #3497E1 transparent transparent;
}

.colorRed .titleArea {
    color: #E61750;
}

.colorYellow .titleArea {
    color: #EAC737;
}

.colorBlue .titleArea {
    color: #3497E1;
}

.sec01Wrapper .conArea {
    padding: 2em;
}

.sec01Wrapper {
    position: relative;
    z-index: 1;
}

.sec01Wrapper::before {
    display: block;
    content: "";
    position: absolute;
    width: 65%;
    height: 960px;
    <!--background: #fffacd;-->
    right: 0;
    top: 0;
    z-index: -1;
}

@media screen and (max-width: 1025px) {
    .sec01Wrapper .conArea {
        padding: 1em;
    }

    .sec01Wrapper::before {
        height: 750px;
    }
}

@media screen and (max-width: 690px) {
    .sec01Wrapper .conArea {
        padding: 0;
        margin-top: 20px;
    }

    .sec01Wrapper::before {
        height: 440px;
        right: 0;
        width: 90%;
    }

    .sec01Wrapper .col46Area .col4.imgBgBlock {
        margin: 20px auto;
    }
}

.sec03Wrapper {
    position: relative;
    z-index: 1;
}

.sec03Wrapper::before {
    display: block;
    content: "";
    position: absolute;
    width: 65%;
    height: 960px;
    background: #EFF5F2;
    left: 0;
    top: 0;
    z-index: -1;
}

@media screen and (max-width: 690px) {
    .sec03Wrapper::before {
        height: 470px;
        width: 90%;
    }
}

.sec04Wrapper {
    position: relative;
    z-index: 1;
}

.sec04Wrapper::before {
    display: block;
    content: "";
    position: absolute;
    width: 100%;
    height: 420px;
    background: #EFF5F2;
    left: 0;
    top: 0;
    z-index: -1;
}


@media screen and (max-width: 690px) {
    .sec04Wrapper::before {
        height: 550px;
    }
}

/*banWrapper*/

.banWrapper {
    width: 100%;
    position: relative;
    padding: 5em 0 0;
    z-index: 1;
}

.banWrapper::before {
    display: block;
    content: "";
    position: absolute;
    width: 100%;
    height: calc(100% - 80px);
    left: 0;
    top: 0;
    background: #fafad2;
    z-index: -1;
}

.banWrapper .titleAreaC {
    margin-bottom: 80px;
}

.banBox {
    position: relative;
    padding: 4em;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
    max-width: 920px;
    margin: auto;
}

.banBox .labelArea {
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    position: absolute;
    justify-content: center;
    top: 0;
    width: 100%;
    transform: translateY(-25px) translateX(-50%);
}

.banBox .label {
    font-size: 18px;
    color: #333;
    text-align: center;
    padding: 10px 40px;
    background: #fff;
    border-radius: 50px;
    font-weight: 500;
    box-shadow: 10px 10px 22px -5px rgba(0, 0, 0, 0.3);
    position: relative;
}

.banBox .label::after {
    display: block;
    content: "";
    position: absolute;
    border: 10px solid;
    border-color: transparent transparent transparent #fff;
    bottom: -10px;
    right: 25px;
    transform: rotate(15deg);
}

.banBox .btnStyle01 {
    padding: 20px;
    font-size: 23px;
    position: relative;
    border-bottom: 5px solid;
    border-radius: 5px;
}

.banBox .btnStyle01 img {
    max-width: 30px;
    margin-right: 15px;
}

.banBox .btnStyle01.bgBlue {
    border-color: #f0e68c;
}

.banBox .btnStyle01.bgPink {
    border-color: #00bfff;
}
.banBox .btnStyle01.bgGreen {
    border-color: #adff2f;
}
.banBox .btnStyle01.sp_only {
	display:none;
}

@media screen and (max-width: 1120px) {
    .banWrapper .titleAreaC {
        margin-bottom: 60px;
    }
}

@media screen and (max-width: 1025px) {
    .banBox {
        max-width: calc(100% - 40px);
        padding: 3em 2em;
    }
	.banBox .btnStyle01 {
	    font-size: 19px;
	}

    .banWrapper {
        padding: 2em 0 0;
    }

    .banWrapper .col2Area .col {
        width: calc((100% - 10px)/2);
        margin-top: 0;
    }
}

@media screen and (max-width: 690px) {
    .banBox .btnStyle01 {
        padding: 10px 3%;
        font-size: 16px;
        font-weight: 700;
    }
	.banBox .btnStyle01.sp_none {
		display:none;
	}
	.banBox .btnStyle01.sp_only {
		display:block;
	}
    .banBox {
        padding: calc(1em + 15px) 1em 1em;
        border-radius: 0;
    }

    .banBox .labelArea {
        transform: translateY(-20px) translateX(-50%);
    }

    .banBox .label {
        font-size: 12px;
        padding: 8px 25px;
        font-weight: 700;
    }

    .banWrapper .titleAreaC {
        margin-bottom: 35px;
    }

    .banBox .btnStyle01 img {
        display: none;
    }

    .banWrapper {
        padding: 2em 0;
    }

    .banWrapper::before {
        height: 100%
    }

    .banWrapper .col2Area .col {
        width: calc((100% - 10px)/2);
        margin-top: 0;
    }
}

@media screen and (max-width: 480px) {

    .banBox .btnStyle01 {

        font-size: 3.2vw;
    }

}



.sec02Wrapper .imgBgBlock {
    min-height: 260px;
}

@media screen and (max-width: 690px) {
    .sec02Wrapper .imgBgBlock {
        min-height: 180px;
    }
}

.blockStyle02Wrapper {
    position: relative;
}

.blockStyle02Area {
    position: relative;
    padding: 3em;
    background: #fff;
    border: 2px solid #ddd;
    border-radius: 20px;
    display: flex;
    justify-content: space-between;
}

.blockStyle02Area .colL,
.blockStyle02Area .colR {
    width: calc(50% - 20px);
}

.blockStyle02Wrapper .labelArea {
    position: absolute;
    padding: 20px;
    max-width: 110px;
    width: 100%;
    background: #06BD67;
    left: 0;
    top: -20px;
    z-index: 2;
}

.blockStyle02Wrapper .labelArea::after {
    display: block;
    content: "";
    position: absolute;
    border: 40px solid #06BD67;
    border-color: transparent transparent transparent #06BD67;
    border-width: 10px calc(110px/2);
    left: 0;
    bottom: -10px;
}

.blockStyle02Wrapper .labelArea::before {
    display: block;
    content: "";
    position: absolute;
    border: 40px solid #06BD67;
    border-color: transparent #06BD67 transparent transparent;
    border-width: 10px calc(110px/2);
    right: 0;
    bottom: -10px;
}

.blockStyle02Wrapper .labelArea .label {
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.blockStyle02Wrapper .labelArea .label span {
    display: block;
    text-align: center;
    line-height: 1;
}

.blockStyle02Wrapper .labelArea .label .fontB {
    font-size: 32px;
    font-weight: 700;
    margin-top: 5px;
}

.blockStyle02Wrapper .labelArea .label .fontS {
    font-size: 18px;
}

@media screen and (max-width: 1025px) {
    .blockStyle02Area {
        padding: 1.5em;
    }

    .blockStyle02Wrapper:nth-child(3) .blockStyle02Area .txtStyle01 {
        min-height: 145px;
    }

    .blockStyle02Area .colL,
    .blockStyle02Area .colR {
        width: calc(50% - 10px);
    }

    .blockStyle02Wrapper .labelArea {
        padding: 12px;
        max-width: 90px;
    }
}

@media screen and (max-width: 690px) {
    .blockStyle02Area {
        flex-wrap: wrap;
        padding: calc(50px + 20px) 20px 40px;
    }

    .title03Style02 .label {
        margin-bottom: 0;
        margin-top: 10px;
    }

    .blockStyle02Area .colL,
    .blockStyle02Area .colR {
        width: 100%;
    }

    .blockStyle02Area .colL {
        margin-bottom: 20px;
    }

    .blockStyle02Wrapper .labelArea {
        padding: 10px;
        max-width: 60px;
        top: -10px;
        left: 20px;
    }

    .blockStyle02Wrapper .labelArea .label .fontS {
        font-size: 16px;
        font-weight: 700;
    }

    .blockStyle02Wrapper .labelArea .label .fontB {
        font-size: 16px;
        font-weight: 700;
    }
}

/*sliderStyle01*/

.sliderStyle01 {
    height: 100%;
    position: relative;
}

.sliderStyle01 .imgBgBlock {
    height: 100%;
    min-height: 350px;
}

@media screen and (max-width: 690px) {
    .sliderStyle01 .imgBgBlock {
        min-height: 200px;
        background-position: top;
    }
}

.sliderStyle01ToolArea {
    position: absolute;
    width: 100%;
    z-index: 10;
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: #fff;
    width: 130px;
    bottom: 3em;
    padding: 10px;
    left: calc(50% - 20px - 130px);
}

.sliderStyle01ToolArea .swiper-pagination,
.sliderStyle01ToolArea .sliderStyle01Prev,
.sliderStyle01ToolArea .sliderStyle01Next {
    position: static;
}

.sliderStyle01ToolArea .sliderStyle01Prev,
.sliderStyle01ToolArea .sliderStyle01Next {
    width: 20px;
    height: 20px;
    top: auto;
    transform: translateY(0);
    margin: 0;
}

.sliderStyle01ToolArea .sliderStyle01Prev::after,
.sliderStyle01ToolArea .sliderStyle01Next::after {
    display: block;
    content: "";
    position: relative;
    margin-left: auto;
    margin-right: auto;
}

.sliderStyle01ToolArea .sliderStyle01Prev::after {
    border: 10px #06BD67 solid;
    border-color: transparent #06BD67 transparent transparent;
}

.sliderStyle01ToolArea .sliderStyle01Next::after {
    border: 10px #06BD67 solid;
    border-color: transparent transparent transparent #06BD67;
}

.sliderStyle01ToolArea .sliderStyle01Nav {
    color: #888;
}

.sliderStyle01ToolArea .sliderStyle01Nav .swiper-pagination-current,
.sliderStyle01ToolArea .sliderStyle01Nav .swiper-pagination-total {
    color: #333;
    font-size: 14px;
    font-weight: bold;
}

@media screen and (max-width: 1025px) {
    .sliderStyle01ToolArea {
        bottom: 1.5em;
        left: calc(50% - 10px - 130px);
    }
}

@media screen and (max-width: 690px) {

    .sliderStyle01Nav .swiper-pagination-current,
    .sliderStyle01Nav .swiper-pagination-total {
        font-size: 11px;
    }

    .sliderStyle01ToolArea {
        width: 100px;
        padding: 7px;
        right: 20px;
        left: auto;
    }

    .sliderStyle01ToolArea .sliderStyle01Prev::after {
        border: 7px #06BD67 solid;
        border-color: transparent #06BD67 transparent transparent;
    }

    .sliderStyle01ToolArea .sliderStyle01Next::after {
        border: 7px #06BD67 solid;
        border-color: transparent transparent transparent #06BD67;
    }
}

/*txt*/

.txtStyle01 {
    line-height: 1.8;
    display: block;
}

@media screen and (max-width: 690px) {
    .txtStyle01 {
        line-height: 1.8;
    }
}

/*section*/

.sec01Wrapper{
    padding: 3em 0;
}
.sec02Wrapper,
.sec03Wrapper,
.sec04Wrapper,
.sec05Wrapper,
.sec06Wrapper {
    padding: 8em 0;
}

@media screen and (max-width: 1025px) {

    .sec01Wrapper,
    .sec02Wrapper,
    .sec03Wrapper,
    .sec04Wrapper,
    .sec05Wrapper,
    .sec06Wrapper {
        padding: 5em 0;
    }
}

@media screen and (max-width: 690px) {

    .sec01Wrapper,
    .sec02Wrapper,
    .sec03Wrapper,
    .sec04Wrapper,
    .sec05Wrapper,
    .sec06Wrapper {
        padding: 3em 0;
    }
}

/*blockStyle03Wrapper*/

.blockStyle03Wrapper {
    background: #fff;
    border-radius: 10px;
}

.blockStyle03Area {
    padding: 20px 45px 0;
}

@media screen and (max-width: 1025px) {

    .blockStyle03Area .titleAreaL {
        margin-bottom: 15px;
    }
}

@media screen and (max-width: 690px) {
    .blockStyle03Wrapper {
        background: #fff;
        border-radius: 0;
    }

    .blockStyle03Area {
        padding: 0;
    }
}

/*titleStyle02Area*/

.titleStyle02Area {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    transform: translateX(-20px);
    margin-bottom: 20px;
}

.titleStyle02Area .numArea {
    display: block;
    font-weight: 700;
    color: #06BD67;
    font-size: 30px;
    letter-spacing: 2px;
    margin-right: 20px;
}

@media screen and (max-width: 690px) {
    .titleStyle02Area {
        transform: translateX(0px);
        position: relative;
        padding-bottom: 8px;
    }

    .titleStyle02Area::before {
        display: block;
        content: "";
        position: absolute;
        width: 100%;
        left: 0;
        bottom: 0;
        height: 2px;
        background: #ddd;
    }

    .titleStyle02Area::after {
        display: block;
        content: "";
        position: absolute;
        width: 60px;
        height: 2px;
        background: #06BD67;
        left: 0;
        bottom: 0;
    }

    .titleStyle02Area .numArea {
        font-size: 27px;
        margin-right: 10px;
    }
}

.blockStyle03ConWrapper {
    padding: 0 0 40px 40px;
    border-left: 2px solid #06BD67;
}

.blockStyle03ConArea {
    border-bottom: 2px solid #ddd;
    padding-bottom: 40px;
    display: flex;
    justify-content: space-between;
}

.blockStyle03ConArea .colL {
    width: calc(40% - 20px);
}

.blockStyle03ConArea .colR {
    width: calc(60% - 20px);
}

@media screen and (max-width: 1025px) {

    .blockStyle03ConArea {
        flex-wrap: wrap;
    }

    .blockStyle03ConArea .colL {
        width: 100%;
    }

    .blockStyle03ConArea .colR {
        width: 100%;
    }

    .blockStyle03ConArea .imgBgBlock {
        min-height: 300px;
        margin-top: 20px;
    }
}

@media screen and (max-width: 690px) {
    .blockStyle03ConArea .imgBgBlock {
        min-height: 200px;
    }

    .blockStyle03ConWrapper {
        padding: 0;
        border: none;
    }

    .blockStyle03Area+.blockStyle03Area {
        margin-top: 50px;
    }

    .blockStyle03Area:last-child .blockStyle03ConArea::before,
    .blockStyle03Area:last-child .blockStyle03ConArea::after {
        display: none;
    }

    .blockStyle03ConArea {
        flex-wrap: wrap;
        border-bottom: none;
        position: relative;
    }

    .blockStyle03ConArea::before {
        display: block;
        content: "";
        position: absolute;
        width: 100%;
        height: 2px;
        background: #06BD67;
        bottom: 0;
    }

    .blockStyle03ConArea::after {
        display: block;
        content: "";
        position: absolute;
        width: 40px;
        height: 40px;
        border: 2px solid #06BD67;
        border-width: 0 2px 2px 0;
        left: 50%;
        transform: translateX(-50%) rotate(45deg);
        bottom: -20px;
        background: #fff;
    }

    .blockStyle03ConArea .colL {
        width: 100%;
    }

    .blockStyle03ConArea .colR {
        width: 100%;
        margin-top: 30px;
    }
}

/*faqArea*/

.faqArea {
    box-shadow: 0 0 20px -5px rgba(0, 0, 0, 0.2);
}

.faqArea .qArea,
.faqArea .aArea {
    padding: 25px;
}

.faqArea .qArea {
    display: flex;
    position: relative;
    padding-left: 60px;
    justify-content: space-between;
    background: #fff;
    align-items: center;
}

.faqArea .qArea p {
    font-size: 14px;
    color: #333;
    font-weight: bold;
    line-height: 1.6;
}

.faqArea .qArea .txt {
    width: calc(100% - 25px - 5px);
}

.faqArea .qArea .faqBtn {
    display: block;
    width: 25px;
    height: 25px;
    position: relative;
    margin-left: 5px;
}

.faqArea .qArea .faqBtn::before {
    display: block;
    content: "";
    position: absolute;
    width: 100%;
    height: 2px;
    background: #06BD67;
    top: 50%;
    transform: translateY(-50%);
}

.faqArea .qArea .faqBtn::after {
    display: block;
    content: "";
    position: absolute;
    width: 2px;
    height: 100%;
    background: #06BD67;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    transition: .3s ease;
}

.faqArea .qArea .faqBtn.isActive::after {
    height: 0;
}

.faqArea .qArea::before {
    display: block;
    content: "";
    position: absolute;
    left: 20px;
    font-size: 30px;
    font-weight: 700;
    color: #06BD67;
    line-height: 1;
    top: 18px;
    content: "Q";
}

.faqArea .aArea {
    padding-left: 60px;
    background: #06BD67;
    position: relative;
}


.faqArea .aArea p {
    font-size: 14px;
    color: #fff;
    font-weight: bold;
    line-height: 1.6;
}

.faqArea .aArea::before {
    display: block;
    content: "";
    position: absolute;
    left: 20px;
    font-size: 30px;
    font-weight: 700;
    color: #fff;
    line-height: 1;
    top: 18px;
    content: "A";
}

.faqArea+.faqArea {
    margin-top: 20px;
}

.faqArea .aArea {
    display: none;
}

.faqArea.isActive .aArea {
    display: block;
}

@media screen and (max-width: 690px) {

    .faqArea .qArea,
    .faqArea .aArea {
        padding: 20px;
        padding-left: 40px;
        padding-right: 10px;
    }

    .faqArea .qArea::before,
    .faqArea .aArea::before {
        left: 10px;
        font-size: 25px;
        top: 15px;
    }

    .faqArea .qArea .faqBtn {
        width: 18px;
        height: 18px;
    }

    .faqArea .qArea .txt {
        width: calc(100% - 18px - 5px);
    }
}

/*col4Area*/

.col4Area {
    display: flex;
    justify-content: space-between;
}

.col4Area .col {
    width: calc((100% - 60px)/4);
}

@media screen and (max-width: 1025px) {
    .col4Area {
        flex-wrap: wrap;
    }

    .col4Area .col {
        width: calc((100% - 10px)/2);
        margin-bottom: 20px;
    }
}

/*sec06*/

.sec06Wrapper .blockStyle01::after {
    display: none;
}

.sec06Wrapper .blockStyle01 {
    padding: 0 1em 2em 1em;
}

.sec06Wrapper .titleAreaC {
    justify-content: center;
}

@media screen and (max-width: 690px) {
    .sec06Wrapper .title04Style {
        font-size: 17px;
        text-align: center;
    }

    .sec06Wrapper .blockStyle01 {
        text-align: left;
    }

    .sec06Wrapper .blockStyle01 {
        padding: 0 10px 20px;
    }

    .sec06Wrapper .titleAreaC {
        margin-top: -10px;
        margin-bottom: 10px;
    }
}

.footerWrapper {
    width: 100%;
    padding: 30px 0;
}

.footerArea {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.footerArea .footerLogoArea img {
    width: auto;
    max-width: 210px
}

.footerArea .rightTxtArea {
    display: flex;
    flex-wrap: wrap;
}

.footerArea .rightTxtArea small {
    color: #06BD67;
    font-size: 12px;
}

.footerArea .rightTxtArea a {
    color: #06BD67;
    font-size: 13px;
    display: block;
    margin-right: 10px;
}

@media screen and (max-width: 690px) {
    .footerArea {
        flex-wrap: wrap;
    }

    .footerWrapper {
        padding: 15px 0;
    }

    .footerArea .rightTxtArea small {
        font-size: 10px;
        text-align: center;
        display: block;
    }

    .rightTxtArea {
        width: 100%;
    }

    .footerLogoArea {
        width: 100%;
        text-align: center;
    }

    .footerArea .rightTxtArea a {
        width: 100%;
        text-align: center;
        margin: 10px auto;
    }

    .footerArea .rightTxtArea small {
        width: 100%;
        text-align: center;
    }
}

.sec05Wrapper {
    background: #EFF5F2;
}

body {
    counter-reset: num1;
}

.secTitleWrapper {
    position: relative;
}

.secTitleWrapper::after {
    counter-increment: num1;
    content: "0"counter(num1);
    position: absolute;
    right: 0;
    top: 10%;
    font-size: 195px;
    line-height: 0.5;
    color: rgba(6, 189, 103, 0.1);
    font-family: "EB Garamond", serif;
    z-index: -1;
}

@media screen and (max-width: 690px) {
    .secTitleWrapper::after {
        top: -5%;
        font-size: 100px;
    }
}

.positionBtnArea {
    display: none;
}

@media screen and (max-width: 690px) {
    .positionBtnArea {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
margin-top: 35px;
        <!--margin-bottom: 60px;-->
    }

    .positionBtnArea .col {
        border: 2px solid #06BD67;
        border-radius: 5px;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        position: relative;
        width: calc((100% - 10px)/2);
        background: #fff;
        font-size: 14px;
        line-height: 1.5;
        margin-bottom: 10px;
    }

    .positionBtnArea .col a {
        color: #333;
        font-weight: bold;
        padding: 15px 10px;
        display: block;
        width: 100%;
        text-align: center;
    }

    .positionBtnArea .col::before {
        display: block;
        content: "";
        position: absolute;
        right: 10px;
        top: 50%;
        transform: translateY(-50%);
        border: 8px solid #06BD67;
        border-color: #06BD67 transparent transparent transparent;
        right: 3px;
        top: 60%;
        transform: translateY(-50%);
    }

    .posBtnWrapper01 .col::before,
    .posBtnWrapper02 .col::before {
        right: auto;
        top: auto;
        left: 50%;
        bottom: -16px;
        transform: translateX(-50%);
    }

    .positionBtnArea .col .label {
        position: absolute;
        width: 30px;
        height: 30px;
        background: #06BD67;
        border-radius: 100%;
        left: -5px;
        top: -10px;
    }

    .posBtnWrapper01 {
        counter-reset: num2;
    }

    .posBtnWrapper01 .label::before {
        width: 100%;
        position: absolute;
        height: 100%;
        top: 50%;
        left: 50%;
        transform: translateY(-50%) translateX(-50%);
        text-align: center;
        line-height: 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }

    .posBtnWrapper01 .label::before {
        counter-increment: num2;
        content: counter(num2);
        font-size: 16px;
        font-weight: bold;
        color: #fff;
    }

    .posBtnWrapper02 .label::before {
        width: 100%;
        position: absolute;
        height: 100%;
        top: 50%;
        left: 50%;
        transform: translateY(-50%) translateX(-50%);
        text-align: center;
        line-height: 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }

    .posBtnWrapper02 .label::before {
        display: block;
        content: "";
        position: absolute;
        background-image: url(../image/homeIcon.png);
        background-position: center;
        background-size: 20px;
        background-repeat: no-repeat;
    }

    .posBtnWrapper03 {
        counter-reset: num3;
    }

    .posBtnWrapper03 .col {
        border: none;
        border-radius: 0;
        margin-bottom: 20px;
        width: calc((100% - 20px)/2);
        border-radius: 5px;
    }

    .posBtnWrapper03 .col:last-child::before {
        display: none;
    }

    .posBtnWrapper03 .col::before {
        border-color: transparent transparent transparent #06BD67;
        right: -17px;
        top: 52%;
    }

    .posBtnWrapper03 .col .label {
        border-radius: 0;
        font-size: 10px;
        text-align: center;
        color: #fff;
        font-weight: 700;
        height: 33px;
        line-height: 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
    }

    .posBtnWrapper03 .col .label .num {
        margin-top: 3px;
    }

    .posBtnWrapper03 .col .label::after {
        display: block;
        content: "";
        position: absolute;
        border: 20px solid #06BD67;
        border-color: transparent transparent transparent #06BD67;
        border-width: 3px calc(30px / 2);
        left: 0;
        bottom: -3px;
    }

    .posBtnWrapper03 .col .label::before {
        display: block;
        content: "";
        position: absolute;
        border: 20px solid #06BD67;
        border-color: transparent #06BD67 transparent transparent;
        border-width: 3px calc(30px / 2);
        right: 0;
        bottom: -3px;
    }
}

.returntop_area {
    width: 40px;
    height: 40px;
    position: fixed;
    z-index: 10;
    right: 20px;
    bottom: 20px;
    border-radius: 100%;
    background: #E5F3FA;
    -webkit-transition: 0.5s ease;
    -o-transition: 0.5s ease;
    transition: 0.5s ease;
}

.returntop_area::before {
    content: "";
    display: block;
    left: 55%;
    top: 45%;
    -webkit-transform-origin: center;
    -ms-transform-origin: center;
    transform-origin: center;
    -webkit-transform: rotate(-45deg) translateX(-50%) translateY(-50%);
    -ms-transform: rotate(-45deg) translateX(-50%) translateY(-50%);
    transform: rotate(-45deg) translateX(-50%) translateY(-50%);
    width: 5px;
    height: 5px;
    border: 2px solid #06BD67;
    border-width: 2px 2px 0 0;
    position: absolute;
    -webkit-transition: 0.5s ease;
    -o-transition: 0.5s ease;
    transition: 0.5s ease;
}

.returntop_area::after {
    content: "";
    display: block;
    left: 50%;
    top: 50%;
    -webkit-transform-origin: center;
    -ms-transform-origin: center;
    transform-origin: center;
    -webkit-transform: translateX(-50%) translateY(-50%) scale(1);
    -ms-transform: translateX(-50%) translateY(-50%) scale(1);
    transform: translateX(-50%) translateY(-50%) scale(1);
    width: 100%;
    height: 100%;
    border: 1px solid #06BD67;
    position: absolute;
    border-radius: 100%;
    -webkit-transition: 0.5s ease;
    -o-transition: 0.5s ease;
    transition: 0.5s ease;
}

.returntop_area:hover::after {
    width: 100%;
    height: 100%;
    -webkit-transform: translateX(-50%) translateY(-50%) scale(1.5);
    -ms-transform: translateX(-50%) translateY(-50%) scale(1.5);
    transform: translateX(-50%) translateY(-50%) scale(1.5);
}

.returntop_area:hover {
    -webkit-box-shadow: 0 0 20px rgba(255, 255, 255, 0.8);
    box-shadow: 0 0 20px rgba(255, 255, 255, 0.8);
}

@media screen and (max-width: 690px) {
    .returntop_area {
        width: 30px;
        height: 30px;
        right: 7px;
        bottom: 25px;
    }

    .returntop_area::before {
        left: 55%;
        top: 44%;
        width: 4px;
        height: 4px;
    }

    .returntop_area:hover::after {
        -webkit-transform: translateX(-50%) translateY(-50%) scale(1.2);
        -ms-transform: translateX(-50%) translateY(-50%) scale(1.2);
        transform: translateX(-50%) translateY(-50%) scale(1.2);
    }
}