@charset "UTF-8";

/*
========================================

	service.css
    base_km.css／km.cssでも設定あり

========================================
*/

.font-light {font-family:/*YakuHanJP,*/'FP-ヒラギノUD丸ゴ StdN W3','Noto Sans JP','Hiragino Kaku Gothic Pro','Osaka','Meiryo','MS PGothic',Sans-Serif;}
.font-semibold {font-family:/*YakuHanJP,*/'FP-ヒラギノUD丸ゴ StdN W5','Noto Sans JP','Hiragino Kaku Gothic Pro','Osaka','Meiryo','MS PGothic',Sans-Serif;}
.font-bold {font-family:/*YakuHanJP,*/'FP-ヒラギノUD丸ゴ StdN W6','Noto Sans JP','Hiragino Kaku Gothic Pro','Osaka','Meiryo','MS PGothic',Sans-Serif;}

div.panel-group a.km_service_btn .service_name h4 {
    font-family:/*YakuHanJP,*/'FP-ヒラギノUD丸ゴ StdN W6','Noto Sans JP','Hiragino Kaku Gothic Pro','Osaka','Meiryo','MS PGothic',Sans-Serif;
}
div.km_serviceBox div.inner h4  {
    font-family:/*YakuHanJP,*/'FP-ヒラギノUD丸ゴ StdN W6','Noto Sans JP','Hiragino Kaku Gothic Pro','Osaka','Meiryo','MS PGothic',Sans-Serif;
    font-weight: 900;
    text-shadow: 1px 2px 0 #fff,
                -1px 1px 0 #fff,
                1px -1px 0 #fff,
                -1px -1px 0 #fff;
}
div.km_serviceBox div.merit p.title {font-family:/*YakuHanJP,*/'FP-ヒラギノUD丸ゴ StdN W6','Noto Sans JP','Hiragino Kaku Gothic Pro','Osaka','Meiryo','MS PGothic',Sans-Serif;}

div.panel-group a.km_service_btn .tree_icon_box {
    transition: all .2s ease;
}

div.panel-group a.km_service_btn:hover .tree_icon_box {
    transform: scale(1.2);
}

.wrapper {
	animation: fadein 1s forwards;
}

@keyframes fadein {
	0% {opacity: 0}
	100% {opacity: 1}
}

/*----------------------------------------
   layout
----------------------------------------*/

body {
    background-image: url("/common/cmn_img/bg_ground.jpg");
    background-size: 500px;
    background-repeat: repeat;
    background-position: 0 0;
}

div.sky {
    background-image: linear-gradient(#73c9ff 0, #9cddff 20vh, #c4f0ff 40vh, #c4f0ff 100vh);/*bg_sky_cloud.svg*/
}

div.h2Box {
    display: block;
    width: 100%;
    background-image: url("/common/cmn_img/bg_cloud01.png");/*fallback*/
    background-image: url("/common/cmn_img/bg_cloud01.svg"), none;
    background-size: contain;
    background-position:center 20px;
    background-repeat: no-repeat;
}

@media (min-width: 1024px) {
    div.h2Box {
        margin:auto;
        background-size: contain;
        background-position:center 48px;
    }
}

/*----------------------------------------
   tab
----------------------------------------*/

.tab-panel {
    background-image: url("/common/cmn_img/bg_sky_cloud.png");/*fallback*/
    background-image: url("/common/cmn_img/bg_sky_cloud.svg"), none;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center 80px;
    background-attachment: fixed;
}

.tab {
    list-style:none;
    text-align:center;
    cursor:pointer;
    background-color: #fff;

    display: flex;
    align-items: center;
    justify-content: center;

    min-height: 128px;
    margin: 0 2px;
    width: calc(33.333333% - 4px);/**/

    border-radius: 8px;
    border:4px solid #1F9947;
}

.tab h3 { 
    width: 100%;
    margin-bottom: 4px;
}

.tab h3 span.sv_number {
    color:#7cc171;
}

.tab h3 span.title {
    color: #007025;
    display: block;
    /*font-size:calc(1.1rem + .25vw); km_display-10*/
    font-size: 1rem;
}

.tab.is-active  { 
     position: relative;
     border:4px solid #007025;
     background-color: #1F9947;
     font-weight: 700;
     font-family:/*YakuHanJP,*/'FP-ヒラギノUD丸ゴ StdN W6','Noto Sans JP','Hiragino Kaku Gothic Pro','Osaka','Meiryo','MS PGothic',Sans-Serif;
}

.tab.is-active h3 span.title {
    color:#FFF;
    transition: all 0.2s ease-out;
  }

.tab h3 span.title {
    margin-top: 0.5rem;
    margin-bottom: 0.35rem;
}

.tab.is-active h3 span.title {
    margin-top: 0.35rem;
    margin-bottom: 0.5rem;
 }

.tab.is-active::before {
     content: '';
     position: absolute;
     display: block;
     z-index: 1;
     border-style: solid;
     border-color: #007025 transparent;
     border-width: 14px 14px 0 14px;
     bottom: -16px;
     left: 50%;
     margin-left: -14px;
}

@media (min-width: 640px) {

    .tab h3 span.title {
        font-size:calc(1.1rem + .25vw); /*km_display-10*/
    }

}

@media (min-width: 1024px) {

    .tab h3 span.title {
        font-size:calc(1.275rem + .3vw);/*km_display-9*/
    }

    .tab.is-active h3 span.title {
        font-size:calc(1.3rem + .6vw);/*km_display-8*/
      }
    
    .tab.is-active  { 
        background-color: #1F9947;
        border-radius: 8px;
   }

    .tab.is-active::before {
        border-width: 20px 20px 0 20px;
        bottom: -24px;
        left: 50%;
        margin-left: -20px;
    }

}

  .panel-group {
    padding-bottom: 18vw;
    min-height: 70vh;
    background-image: url("/common/cmn_img/bg_woods.png");/*fallback*/
    background-image: url("/common/cmn_img/bg_woods.svg"), none;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center bottom;
  }

  .panel{
    display:none;
  }

  .panel.is-show {
    display: block;/*表示*/
    animation: fadein 1s forwards;/*line28*/
    z-index: 1000;
  }

/*----------------------------------------
    service
----------------------------------------*/

.road {
    width: 100%;
    background-image: url("/service/img/bg_road.png"); /*fallback*/
    background-image: url("/service/img/bg_road.svg"), none;
    background-size: 85%;
    background-repeat: repeat-y;
    background-position: center top;
}

@media (min-width: 1440px) {

    .road {
        width: 100%;
        background-image: url("/service/img/bg_road.png"); /*fallback*/
        background-image: url("/service/img/bg_road.svg"), none;
        background-size: 63%;
        background-repeat: repeat-y;
        background-position: center top;
    }
}

/*div.wrapper <---sticky container*/

    ul#stickList {
        display: none;
        height: 0;
        width: 0;
    }

	@media (min-width: 1280px) and (min-height: 768px) {/*高さ768px以上*/

        div.wrapper {position: relative;} 

		ul#stickList {
			display: block;
			position: absolute; /*relative div.wrapper*/
			top:96px;
			width: 134px;
			left: calc(100% - 134px);
			overflow: auto;
			opacity: 0;
			height: 660px;/*ul#stickList 60*11*/
			margin-top: -660px;
			z-index: 99;
			/*box-shadow: -12px 0 12px -12px rgba(255,96,77,0.3);左だけ*/
		}
		ul#stickList.list_on {
			position: sticky;
			opacity: 1;
			animation: fadein 1s forwards;
		}
		ul#stickList.list_on li {
			position: relative;
			display: block;
			width: 100%;
			height:60px;
			/*padding-left: 8px;*/
		}
		ul#stickList.list_on li a {
			display: flex;
			height: 100%;
			align-items: center;
			padding-left: 12px;
			/*background-color:rgba(255,255,255,0.9);*/
			background-color: #fff;
			border-top: 1px solid #007025;
			border-left: 1px solid #007025;
            font-size: 0.75rem;
			letter-spacing: -0.05rem;
			line-height: normal;
		}
		ul#stickList.list_on li:first-child a {
			border-top: 4px solid #007025;
			border-top-left-radius: 6px;
		}
		ul#stickList.list_on li:last-child a {
			border-bottom-left-radius: 6px;
			border-bottom: 4px solid #007025;
		}
		ul#stickList.list_on li a.active {
            color: #fff;
            border-top:3px solid #007025;
            border-bottom:2px solid #007025;
            background-color: #1F9947;
			font-weight: 700;
		}

		ul#stickList.list_on a.active::before {
			content: '';
			display: inline-block;
			margin-right:4px;
			margin-left: -40px;
			width: 40px;
			height: 4px;
			background-color: #007025;
			animation: .2s fadeinDown; 
		}

	}/*@media end*/

	@media (min-height: 768px) {/*高さ768px以上*/
		ul#stickList {
			top:calc(50vh - 300px);
		}
	}/*@media end*/

@media (min-width: 1440px) and (min-height: 768px) {

	ul#stickList {
		top:calc(50vh - 340px);
		width: 166px;
		left: calc(100% - 166px);
		height: 770px;/*ul#stickList 70*11*/
		margin-top: -770px;
	}
	ul#stickList.list_on li {
		height:70px;
	}
	ul#stickList.list_on li a {
		font-size: 0.875rem;
		letter-spacing: normal;
        padding-right: 8px;
	}
	ul#stickList.list_on a.active::before {
		margin-right:12px;
	}
}

@media (min-width: 1600px) and (min-height: 768px) {

	ul#stickList {
		width: 240px;
		left: calc(100% - 240px);
	}
	ul#stickList.list_on li a {
		font-size: 1rem;
	}
	ul#stickList.list_on a.active::before {
		margin-right:12px;
	}
}

a.icon_tree01,
a.icon_tree02,
a.icon_tree03,
a.icon_tree04,
a.icon_tree05,
a.icon_tree06,
a.icon_tree07,
a.icon_tree08,
a.icon_tree09,
a.icon_tree10,
a.icon_tree11 {
    background-size: 60px 60px;
    background-position: center right;
    background-repeat: no-repeat;
}

a.icon_tree01{
    background-image: url("/service/img/tree_01.png");/*fallback*/
    background-image: url("/service/img/tree_01.svg"), none;
}
a.icon_tree02{
    background-image: url("/service/img/tree_02.png");/*fallback*/
    background-image: url("/service/img/tree_02.svg"), none;
}
a.icon_tree03{
    background-image: url("/service/img/tree_03.png");/*fallback*/
    background-image: url("/service/img/tree_03.svg"), none;
}
a.icon_tree04{
    background-image: url("/service/img/tree_04.png");/*fallback*/
    background-image: url("/service/img/tree_04.svg"), none;
}
a.icon_tree05{
    background-image: url("/service/img/tree_05.png");/*fallback*/
    background-image: url("/service/img/tree_05.svg"), none;
}
a.icon_tree06{
    background-image: url("/service/img/tree_06.png");/*fallback*/
    background-image: url("/service/img/tree_06.svg"), none;
}
a.icon_tree07{
    background-image: url("/service/img/tree_07.png");/*fallback*/
    background-image: url("/service/img/tree_07.svg"), none;
}
a.icon_tree08{
    background-image: url("/service/img/tree_08.png");/*fallback*/
    background-image: url("/service/img/tree_08.svg"), none;
}
a.icon_tree09{
    background-image: url("/service/img/tree_09.png");/*fallback*/
    background-image: url("/service/img/tree_09.svg"), none;
}
a.icon_tree10{
    background-image: url("/service/img/tree_10.png");/*fallback*/
    background-image: url("/service/img/tree_10.svg"), none;
}
a.icon_tree11{
    background-image: url("/service/img/tree_11.png");/*fallback*/
    background-image: url("/service/img/tree_11.svg"), none;
}

div.board {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50%;
    margin:0 auto ;
    padding:2rem;
    text-align: center;
    background-image: url("/service/img/bg_board.png");/*fallback*/
    background-image: url("/service/img/bg_board.svg"), none;
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
    min-height: 20vh;
}

div.board h3 {
    height: fit-content;
    line-height: 1.25;
}

div.board h3 span.sv_number {
    display: block;
    margin-bottom: 8px;
    font-size:1rem; /*IE*/
    font-size:clamp(0.875rem, 1.5vw, 1.25rem);
    color:#1F9947;
}

div.board h3 span.cate_title {
    font-size:calc(1.325rem + 1.1vw); /*IE*/
    font-size:clamp(1.25rem, 2.5vw, 2.5rem);
}
    
    @media (min-width: 1024px) {

        div#cate01,
        div#cate02,
        div#cate03 {
            padding-top: 96px;
        }
    
        div.board {
            background-image: url("/service/img/bg_board.png");/*fallback*/
            background-image: url("/service/img/bg_board.svg"), none;
            background-size: contain;
            background-position: top center;
            background-repeat: no-repeat;
            width: 50%;
            height: fit-content;
            padding: 5vw ;
        }
    
    }/*@media end*/

#service01{
    background-image: url("/service/img/bg_tree_01.png");/*fallback*/
    background-image: url("/service/img/bg_tree_01.svg"), none;
}
#service02{
    background-image: url("/service/img/bg_tree_02.png");/*fallback*/
    background-image: url("/service/img/bg_tree_02.svg"), none;
}
#service03{
    background-image: url("/service/img/bg_tree_03.png");/*fallback*/
    background-image: url("/service/img/bg_tree_03.svg"), none;
}
#service04{
    background-image: url("/service/img/bg_tree_04.png");/*fallback*/
    background-image: url("/service/img/bg_tree_04.svg"), none;
}
#service05{
    background-image: url("/service/img/bg_tree_05.png");/*fallback*/
    background-image: url("/service/img/bg_tree_05.svg"), none;
}
#service06{
    background-image: url("/service/img/bg_tree_06.png");/*fallback*/
    background-image: url("/service/img/bg_tree_06.svg"), none;
}
#service07{
    background-image: url("/service/img/bg_tree_07.png");/*fallback*/
    background-image: url("/service/img/bg_tree_07.svg"), none;
}
#service08{
    background-image: url("/service/img/bg_tree_08.png");/*fallback*/
    background-image: url("/service/img/bg_tree_08.svg"), none;
}
#service09{
    background-image: url("/service/img/bg_tree_09.png");/*fallback*/
    background-image: url("/service/img/bg_tree_09.svg"), none;
}
#service10{
    background-image: url("/service/img/bg_tree_10.png");/*fallback*/
    background-image: url("/service/img/bg_tree_10.svg"), none;
}
#service11{
    background-image: url("/service/img/bg_tree_11.png");/*fallback*/
    background-image: url("/service/img/bg_tree_11.svg"), none;
}

#service01,
#service03,
#service05,
#service07,
#service09,
#service11{
    background-size: 12vw;
    background-position: 0 0;
    background-repeat: no-repeat;
}
#service02,
#service04,
#service06,
#service08,
#service10{ 
    background-size: 12vw;
    background-position: 88vw 0;
    background-repeat: no-repeat;
}

    @media (min-width: 1024px) {
        #service01,
        #service03,
        #service05,
        #service07,
        #service09,
        #service11{
            background-size: 12vw;
            background-position: 2vw 0;
            background-repeat: no-repeat;
            min-height: calc(100vh - 96px);
            display: flex;
            align-items: center;
        }
        #service02,
        #service04,
        #service06,
        #service08,
        #service10{
            background-size: 12vw;
            background-position: 86vw 0;
            background-repeat: no-repeat;
            min-height: calc(100vh - 96px);
            display: flex;
            align-items: center;
        }
    }/*@media end*/

    @media (min-width: 1280px) {

        .road {
            padding-right: 90px; /*ul#stickListの幅*/
        }

        #service01,
        #service03,
        #service05,
        #service07,
        #service09,
        #service11{
            background-size: 8vw;
            background-position: 2vw 1vw;
            background-repeat: no-repeat;
        }
        #service02,
        #service04,
        #service06,
        #service08,
        #service10{
            background-size: 8vw;
            background-position: (90vw - 90px) 1vw;
            background-repeat: no-repeat;
        }
    }/*@media end*/

    @media (min-width: 1440px) {

        .road {
            padding-right: 120px; /*ul#stickListの幅*/
        }
        #service02,
        #service04,
        #service06,
        #service08,
        #service10{
            background-position: calc(87vw - 120px) 6vw;
        }
    }

    @media (min-width: 1920px) {
        #service01,
        #service03,
        #service05,
        #service07,
        #service09,
        #service11{
            background-size: 10vw;
            background-position: 3vw 6vw;
            background-repeat: no-repeat;
        }
        #service02,
        #service04,
        #service06,
        #service08,
        #service10{
            background-size: 10vw;
            background-position: calc(87vw - 120px) 6vw;
            background-repeat: no-repeat;
        }
    }/*@media end*/

 div.km_serviceBox div.sv_inner { 
    background-color: #f8f8ec;
    border-radius:16px;
}

    @media (min-width: 1024px) {
        div.km_serviceBox div.sv_inner { 
            background-color: #f8f8ec;
            border-radius: 9999px;
        }
    }/*@media end*/
    

div.km_serviceBox div.merit {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    max-width:720px;
}

div.km_serviceBox div.merit div {
    padding: 0 1rem 1rem 1rem;
}

div.km_serviceBox div.merit div .title {
    color: #007025;
}

div.km_serviceBox div.merit img {
    z-index: 999;/*最前面に*/
}

 @media (min-width: 1024px) {

    div.km_serviceBox div.merit {
        flex-direction: row;
        justify-content: center;
        width:auto;
    }

    div.km_serviceBox div.merit div {
        background-color: #fff;
        border-radius: 50% 60% 70% 60% / 60% 70% 70% 70% !important;
        padding:1.5rem 3rem;
    }

    div.km_serviceBox div.merit div.type_l {
        margin-left: 0;
        margin-right: -4rem;
        /*background-image: linear-gradient(90deg, #1f9947, #007025) !important;*/
        padding:1.5rem 4rem !important;
        border-radius: 50% 60% 70% 60% / 60% 70% 70% 70% !important;
    }

    div.km_serviceBox div.merit div.type_r {
        margin-right: 0;
        margin-left: -4rem;
        /*background-image: linear-gradient(90deg, #007025, #1f9947) !important;*/
        padding:1.5rem 4rem !important;
        border-radius: 40% 40% 50% 40%/30% 50% 50% 50% !important;
    }

    #service01 div.merit div,
    #service04 div.merit div,
    #service07 div.merit div,
    #service10 div.merit div {
        background-color:rgba(31, 153, 71,0.35);/*#1f9947*/   
        background-image: radial-gradient( #edf3c9 40%, #f8fae9 40%, #f8fae9 60%, #fff 60%, #fff 90%,#fff 100%);  
    }
    #service02 div.merit div,
    #service05 div.merit div,
    #service08 div.merit div,
    #service11 div.merit div {
        background-color:rgba(139, 178, 32,0.35);/*#8BB220*/
        background-image: radial-gradient( #edf3c9 40%, #f8fae9 40%, #f8fae9 60%, #fff 60%, #fff 90%,#fff 100%)
    }
    #service03 div.merit div,
    #service06 div.merit div,
    #service09 div.merit div {
        background-color:rgba(0, 136, 146,0.35);/*#008892*/
        background-image: radial-gradient( #edf3c9 40%, #f8fae9 40%, #f8fae9 60%, #fff 60%, #fff 90%,#fff 100%)
    }

  }/*@media end*/

  @media (min-width: 1440px) {

    div.km_serviceBox div.merit div {
        padding:2rem 3rem;
    }

    div.km_serviceBox div.merit div.type_l {
        padding:3rem !important;
    }

    div.km_serviceBox div.merit div.type_r {
        padding:3rem !important;
    }

  }/*@media end*/


/*----------------------------------------
   parts
----------------------------------------*/

.balloon_l,
.balloon_r,
.balloon_t,
.balloon_b {
    display: block;
    position: relative;
    padding: 16px;
    border-radius: 16px;;
    background-color: #fff;
    color:  #1f9947;
    border: 3px solid #7cc171;
    font-weight: 700;
    width: fit-content;
}

.balloon_l::before,
.balloon_l::after {
    content: "";
    display: inline-block;
    position: absolute;
    top: 50%;
    left: -28px;
    bottom:auto;
    transform: translateY(-50%);
}
.balloon_l::before {
    border: solid 12px transparent;
    border-right: 24px solid #7cc171;    
    margin-left: -10px;
}
.balloon_l::after {
    border: solid 12px transparent;
    border-right: solid 22px #fff;
    margin-left: -4px;
    margin-top: 0;
}

.balloon_r::before,
.balloon_r::after {
    content: "";
    display: inline-block;
    position: absolute;
    top: 50%;
    right: -28px;
    bottom:auto;
    transform: translateY(-50%);
}
.balloon_r::before {
    border: solid 12px transparent;
    border-left: 24px solid #7cc171;    
    margin-right: -10px;
}
.balloon_r::after {
    border: solid 12px transparent;
    border-left: solid 22px #fff;
    margin-right: -4px;
    margin-top: 0;
}

.balloon_t::before {
    content: "";
    display: inline-block;
    position: absolute;
    top: -24px; 
    left: calc(50% - 12px);
    border: 12px solid transparent;
    border-bottom: 24px solid #7cc171;
}

.balloon_t::before,
.balloon_t::after {
    content: "";
    display: inline-block;
    position: absolute;
    bottom:calc(100% + 3px);
    left: 50%;
    transform: translateX(-50%);
}
.balloon_t::before {
    border: solid 12px transparent;
    border-bottom: solid 11px #7cc171;
}
.balloon_t::after {
    border: solid 14px transparent;
    border-bottom: solid 12px #fff;
    margin-bottom: -5px;
}
.balloon_b::before,
.balloon_b::after {
    content: "";
    display: inline-block;
    position: absolute;
    top:calc(100% + 3px);
    left: 50%;
    transform: translateX(-50%);
}
.balloon_b::before {
    border: solid 12px transparent;
    border-top: solid 11px #7cc171;
}
.balloon_b::after {
    border: solid 14px transparent;
    border-top: solid 12px #fff;
    margin-top: -5px;
}

  @media (min-width: 1024px) {
    .balloon_reset_l::before,
    .balloon_reset_l::after {
        content: "";
        display: inline-block;
        position: absolute;
        top: 50%;
        left: -20px;
        bottom:auto;
        transform: translateY(-50%);
    }
    .balloon_reset_l::before {
        border: solid 12px transparent;
        border-right: 17px solid #7cc171;    
        margin-left: -10px;
    }
    .balloon_reset_l::after {
        border: solid 12px transparent;
        border-right: solid 17px #fff;
        margin-left: -6px;
        margin-top: 0;
    }
    .balloon_reset_r::before,
    .balloon_reset_r::after {
        content: "";
        display: inline-block;
        position: absolute;
        top: 50%;
        right: -28px;
        bottom:auto;
        transform: translateY(-50%);
    }
    .balloon_reset_r::before {
        border: solid 12px transparent;
        border-left: 24px solid #7cc171;    
        margin-right: -10px;
    }
    .balloon_reset_r::after {
        border: solid 12px transparent;
        border-left: solid 22px #fff;
        margin-right: -4px;
        margin-top: 0;
    }
    
    }/*@media end*/

/*----------------------------------------
   PDCA cicle
----------------------------------------*/

.circle { 
    position: relative;
}

dl.step {
    width: 100%;
    padding:1rem 0.5rem;
    z-index: 2;
}

dl.step dt {
    text-align: center;    
    font-weight: 700;
    color: #007025;
}

dl.step dd {
    text-align: center;
    max-width: 480px;
}

dd.miniIcon img {margin: auto !important;}

.arrow_move {display: none;}

.slide {display: none;}

@media (min-width: 1024px) {

    dl.step dd.text {
        text-align: left;
        padding:0 1rem;
        font-size:0.9375rem;
        position:relative;
    }
    
    dl.step dd.text::before {
        content: "";
        display: block;
        position: absolute;
        left: 0px;
        height: 8px;
        width: 8px;
        border-radius: 50%;
        background: #1f9947;
        top: 10px;
        left: 0;
        /*transform: translateY(-50%);*/
    }
    
    dd.miniIcon {display: none;}

    .arrow_move {
        display: block;
        width: 110%;
        height: 90px;
        margin:auto;
        animation: arrow 16s linear infinite;

        position: absolute;
        top:0;
        bottom:0;
        right:0;
        left:-5%;

        z-index: -1;
    }

    .arrow_move img {
        height: 90px;
        width: auto;
    }

    img.staticImg {display: none;}

    dl.step {
        border: none;
        background: none !important;
    }

    dl.step.plan,
    dl.step.do,
    dl.step.check,
    dl.step.action {
        margin:0;
        border:0;
    } 

    .circle { 
        border-radius: 50%;
        position: relative;

        width: 640px;
        height:640px;

        background-size: 100%;
        z-index: 1;
        animation: step 16s linear infinite;

        background-color:#D8E58A;
    }
    
    @media (min-width: 1280px) {
    .circle { 
        width: 560px;
        height:560px;
    }
} 
    .contentsArea .squareBox .inner .circle .merit {
        width:248px;
        height: auto;
        transform: translate(100px, 260px) !important;
    }

    .slide {
        display: block;
        position: absolute;
        width:160px;
        height: 160px;

        top:40%;
        left:50%;
        transform: translate(-50%, -50%) !important;
    }

    .slide img {
        position: absolute;
        top:0;
        bottom:0;
        left: 0;
        right: 0;
        margin: auto;
    }

    .slide img.step01 {
        animation: crossfade01 16s linear 0s infinite ;
    }

    .slide img.step02 {
        animation: crossfade02 16s linear 0s infinite ;
    }

    .slide img.step03 {
        animation: crossfade03 16s linear 0s infinite ;
    }

    .slide  img.step04 {
        animation: crossfade04 16s linear 0s infinite ;
    }

    .common {
        width: 50%; 
        height: 50%;
        position: absolute;
        left: 25%;
        top: 25%;
    }

    .topBox {
        position: absolute;
        left: 25%;
        top: -25%;
        transform-origin: center 150%;
        /*border-radius:78% 65% 63% 90% / 89% 72% 86% 89% ; */
        border-radius:50%; 
        background: #fff;
        border: 6px solid #BBDBA3;
        animation: content01 16s linear 0s infinite ;
    }

    .rightBox {
        position: absolute;
        left: 75%;
        top: 25%;
        transform-origin: -50% center;
        /*border-radius:78% 65% 63% 90% / 89% 72% 86% 89% ; */
        border-radius:50%; 
        background: #fff;
        border: 6px solid #BBDBA3;
        animation: content02 16s linear 0s infinite ;
    }

    .bottomBox {
        position: absolute;
        left: 25%;
        top: 75%;
        transform-origin: center -50%;
        /*border-radius:78% 65% 63% 90% / 89% 72% 86% 89% ; */
        border-radius:50%; 
        background: #fff;
        border: 6px solid #BBDBA3;
        animation: content03 16s linear 0s infinite ;
    }

    .leftBox {
        position: absolute;
        left: -25%;
        top: 25%;
        transform-origin: 150% center;
        /*border-radius:78% 65% 63% 90% / 89% 72% 86% 89% ; */
        border-radius:50%; 
        background: #fff;
        border: 6px solid #BBDBA3;
        animation: content04 16s linear 0s infinite ;
    }

    .content {
        width: 100%; 
        height: 100%;
        margin: auto;
        word-wrap: break-word;
        border-radius: 50%;
    }

}/*@media end*/

@keyframes arrow {
    0% { transform: rotateX(0deg) rotate(90deg);}
    100% { transform: rotateX(0deg) rotate(450deg);}
}

@keyframes content01 {
0% {border-color:#1f9947;background:#fc3;}
20% {border-color:#1f9947;background:#fff;}
25% {border-color:#f6f6f6;background:#fff;}
95% {border-color:#f6f6f6;background:#f5fac4;}
100% {border-color:#1f9947;background:#fc3;}
}

@keyframes content02 {
0% {border-color:#f6f6f6;background:#fff;}
20% {border-color:#f6f6f6;background:#fff;}
25% {border-color:#1f9947;background:#fc3;}
45% {border-color:#1f9947;background:#f5fac4;}
50% {border-color:#f6f6f6;background:#fff;}
100% {border-color:#f6f6f6;background:#fff;}
}

@keyframes content03 {
0% {border-color:#f6f6f6;background:#fff;}
45% {border-color:#f6f6f6;background:#fff;}
50% {border-color:#1f9947;background:#fc3;}
70% {border-color:#1f9947;background:#f5fac4;}
75% {border-color:#f6f6f6;background:#fff;}
100% {border-color:#f6f6f6;background:#fff;}
}

@keyframes content04 {
0% {border-color:#f6f6f6;background:#fff;}
70% {border-color:#f6f6f6;background:#fff;}
75% {border-color:#1f9947;background:#fc3;}
95% {border-color:#1f9947;background:#f5fac4;}
100% {border-color:#f6f6f6;background:#f5fac4;}
}


@keyframes crossfade01 {
0% {opacity:1;}
20% {opacity:1;}
25% {opacity:0;}
95% {opacity:0;}
100% {opacity:1;}
}

@keyframes crossfade02 {
0% {opacity:0;}
20% {opacity:0;}
25% { opacity:1;}
45% { opacity:1;}
50% {opacity:0;}
100% {opacity:0;}
}

@keyframes crossfade03 {
0% {opacity:0;}
45% {opacity:0;}
50% { opacity:1;}
70% { opacity:1;}
75% {opacity:0;}
100% {opacity:0;}
}

@keyframes crossfade04 {
0% {opacity:0;}
70% {opacity:0;}
75% { opacity:1;}
95% { opacity:1;}
100% {opacity:0;}
}

/*------------------------------PDCA circle*/