@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;}

.nallow { display: none; }/* 201222change */
.wide { display: block; }/* 201222change */

.pc-only { display: block; }/* 201222change */
.sp-only { display: none !important; }/* 201222change */

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

    .pcOnly {display: none;}
}

@media screen and (max-width: 1025px) {
    .pc-only { display: none !important; }/* 201222change */
    .sp-only { display: block; }/* 201222change */
    .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 {/* 201222change */
    height: 62px;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    font-weight: 500;
    text-align: center;
    line-height: 1.5;
    padding: 0 15px;
    border-radius: 4px;
    transition: 0.5s ease;
    white-space: nowrap;}

.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;}

/*btnStyle02*/
.btnStyle02-rignt {text-align: right;}
.btnStyle02Red {
  display: inline-block;
  font-weight: bold;
  margin-top: 10px;
  padding: 3px 10px;
  text-decoration: none;
  color: #fff;
  background: #E61750;
  border-radius: 5px;
  transition: .4s;}
.btnStyle02Red:hover {
  background: #EA517B;
  color: white;}

.btnStyle02Yellow {
  display: inline-block;
  font-weight: bold;
  margin-top: 10px;
  padding: 3px 10px;
  text-decoration: none;
  color: #fff;
  background: #EAD065;
  border-radius: 5px;
  transition: .4s;}
.btnStyle02Yellow:hover {
  background: #E9D68A;
  color: white;}

.btnStyle02Blue {
  display: inline-block;
  font-weight: bold;
  margin-top: 10px;
  padding: 3px 10px;
  text-decoration: none;
  color: #fff;
  background: #3497E1;
  border-radius: 5px;
  transition: .4s;}
.btnStyle02Blue:hover {
  background: #65ACE1;
  color: white;}

@media screen and (max-width: 1025px) {
    .btnStyle01.sp-only {
        display: flex !important;
    }
}


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

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


/*### ### ### title ### ### ###*/
.titleAreaCsc{
    align-items: center;}

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

.titleAreaCsc h1,
.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;}

.titleAreaCsc h1,
.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 {
    font-size: 32px;
    position: relative;
    color: #333;
    font-weight: 700;}

.title02Style02sw {
    font-size: 30px;
    /*position: relative;*/
    text-align: center;
    color: #f39800;
    background: #fafad2;
    font-weight: 700;}
	
.title02Style02sw2 {
    font-size: 20px;
    /*position: relative;*/
    text-align: center;
    color: #f39800;
    background: #fafad2;
    font-weight: 700;}

.mainsbCopy01 {
    text-align: center;}

@media screen and (max-width: 1025px) {
    .title02Style,
    .title02Style02 {
        font-size: 27px;}

    .title02Style02sw {
        font-size: 22px;}
}

@media screen and (max-width: 690px) {
    .title02Style,
    .title02Style02 {
        font-size: 20px;}

    .title02Style02sw {
        font-size: 12px;}
		
	.title02Style02sw2 {
        font-size: 10px;}

    .title02Style {
        padding-left: 10px;}

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

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

.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 {
    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 {
    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 ###*/
.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: 10px;}
}


/* ### ### ### 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); 201222change */
    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 {/* 201222change */
    border-right: #eee 1px solid;
    display: flex;
    justify-content: center;
    align-items: center;
}

.navList li:last-child {/* 201222change */
    border-right: none;
}

.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: 1431px) {/* 201222change */
    .nallow { display: block; }
    .wide { display: none; }
}

@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 { /* 201222change */
        height: 48px;
        padding: 0 10px;
        font-size: 12px;}

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

@media screen and (max-width: 1051px) {
    .navList a {
        font-size: 12px;}
}

@media screen and (max-width: 1025px) {
    .nallow { display: none; }/* 201222change */
    .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 {
        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-right: none;
        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;}
    
}

/*### ### ### main ### ### ###*/
.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;}

.mainConAre hr {
  border-top: 1px solid #fff;
  margin: 10px;
  width: 100%;}


/*### mainConArea mainCon ###*/
.mainConArea .mainCon {
    /*background: rgba(255, 255, 255, 0.85);*/
    top: -80px;
    padding: 4em;
    position: relative;
    width: auto;
    min-height: 50%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-image: url('../image/mainTxtbg.png');
    background-size: 25% auto;
    background-position: center center;
    background-repeat: no-repeat;}

@media screen and (max-width: 690px) {
    .mainConArea .mainCon {
        top: -50px;
        left: 0;}
}


/*
.mainConArea .mainCon img {
    width: 30%;}

.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 ###*/
.mainTitleArea {
    width: 100%;
    display: flex;
    justify-content: center;
    text-align: 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: #ff8c00;*/
    /*padding: 10px 20px;*/
    text-align: center;
    color: #fff;
    font-size: 52px;
    text-shadow:1px 1px 20px #333;}

.mainTitleArea .txtWs {
    /*background: #ff8c00;
    padding: 10px 20px;*/
    text-align: center;
    color: #fff;
    font-size: 30px;
    text-shadow:1px 1px 20px #333;}

.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;*/
    letter-spacing: 0px;}

@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;*/
        font-size: 26px;}

    .mainTitleArea .txtWs {
        font-size: 14px;}

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

    .mainTitleArea .txtG {
        font-size: 34px;}

    .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;}
}


/*### ### ###blockStyleWrapper### ### ###*/
/*### blockStyle01 ###*/
.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;*/
    padding: 5px 10px;    
    max-width: 160px;
    margin: auto;
    margin-bottom: calc(20px + 15px);}

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

.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;*/
        padding: 5px 10px;
        max-width: 60px;}

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

    .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;*/
    padding: 10px 20px;
    max-width: 110px;
    width: 100%;}

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

.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 ###*/
.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 ###*/
.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 ###*/
.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 .titleAreaCsc {
    margin-bottom: 80px;}

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

.banBox {
    position: relative;
    /*padding: 4em;*/
    padding: 4em 4em 2em;
    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;}

.banBox .coroLink {
    text-align: center;
    margin-top: 30px;
    position: relative;}
.banBox .coroLink img{
    width: 80%;}
.banBox .coroLink .sp_none {
        display:block;}
.banBox .coroLink .sp_only {
        display:none;}


@media screen and (max-width: 1120px) {
    .banWrapper .titleAreaCsc {
        margin-bottom: 50px;}
    .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;}

    .banBox .coroLink {
        margin-top: 15px;}
    .banBox .coroLink .sp_none {
        display:none;}
    .banBox .coroLink .sp_only {
        display:block;}

    .banWrapper .titleAreaCsc {
        margin-bottom: 40px;}

    .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 ###*/
.sec02Wrapper .imgBgBlock {
    min-height: 260px;}

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


/*### blockStyle02Wrapper ###*/
.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 ###*/
.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;}
}


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

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


/*### sec01Wrapper ###*/
.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 ###*/
.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;}
}


/*### sec06Wrapper ###*/
.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 ###*/
.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 ###*/
.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 ###*/
.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 ###*/
.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);}
}