@charset "UTF-8";

/*
========================================

	resolution.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.km_resolutionBox div.ex p.prob,
div.km_resolutionBox div.ex p.res {/*font-semibold*/
    font-family:/*YakuHanJP,*/'FP-ヒラギノUD丸ゴ StdN W5','Noto Sans JP','Hiragino Kaku Gothic Pro','Osaka','Meiryo','MS PGothic',Sans-Serif;
}

div.panel-group a.km_resolution_btn div.problem h4,
div.km_resolutionBox div.ex div.title_circle p {/*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_resolution_btn .people_icon_box {
    transition: all .2s ease;
}

div.panel-group a.km_resolution_btn:hover .people_icon_box {
    transform: scale(1.2);
}

.wrapper {
	animation: fadein 1s forwards;
}

@keyframes fadein {
	0% {opacity: 0}
	100% {opacity: 1}
}

/*----------------------------------------
   layout
----------------------------------------*/

body {background-image: linear-gradient(#73c9ff 0, #9cddff 20vh, #c4f0ff 40vh, #c4f0ff 100vh);}/*bg_sky_cloud.svg*/

.wrapper {
    /*background-color:#c4f0ff;*/
    background-image: url("/common/cmn_img/bg_sky.png");/*fallback*/
    background-image: url("/common/cmn_img/bg_sky_cloud.svg"), none;
    background-size: 200%;
    background-repeat: no-repeat;
    background-position: center top;
    background-attachment: fixed;
}

div.h2Box {
    display: block;
    width: 100%;
    background-color:rgba(31,153,71,0.75);
    /*background-image: url("/common/cmn_img/bg_title.png"); fallback
    background-image: url("/common/cmn_img/bg_title.svg"), none;
    background-size: cover;
    background-repeat: no-repeat;
    background-position:bottom center;*/
    background-blend-mode: multiply;

    margin-bottom: 2rem;
}

div.h2Box h2 {
    color: #fff;
}

@media (min-width: 992px) {
    
    .wrapper {background-size: contain;} 
 
}/*@media end*/

/*----------------------------------------
   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:#007025;
}

.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.1rem + .25vw);/*km_display-10*/
    }

    .tab.is-active h3 span.title {
        font-size:calc(1.275rem + .3vw);/*km_display-9*/
      }
    
    .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: 100vh;*/
    /*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;*/
    min-height: 35vh;
  }

  .panel{
    display:none;
  }

  .panel.is-show {
    display: block;/*表示*/
    animation: fadein 1s forwards;/*line28*/
    z-index: 1000;
  }

/*----------------------------------------
    resolution
----------------------------------------*/

/*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: 160px;
			left: calc(100% - 160px);
			overflow: auto;
			opacity: 0;
			height: 600px;/*ul#stickList 60*10*/
			margin-top: -600px;
			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;
            padding-right: 8px;
			/*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: 500;
            font-family:/*YakuHanJP,*/'FP-ヒラギノUD丸ゴ StdN W5','Noto Sans JP','Hiragino Kaku Gothic Pro','Osaka','Meiryo','MS PGothic',Sans-Serif;
		}
		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: 210px;
		left: calc(100% - 210px);
		height: 700px;/*ul#stickList 70*10*/
		margin-top: -700px;
	}
	ul#stickList.list_on li {
		height:70px;
	}
	ul#stickList.list_on li a {
		font-size: 0.875rem;
		letter-spacing: normal;
        padding-left: 8px;
        padding-right: 8px;
	}
	ul#stickList.list_on a.active::before {
		margin-right:12px;
	}
}

@media (min-width: 1600px) and (min-height: 768px) {
	ul#stickList {
		width: 280px;
		left: calc(100% - 280px);
	}
	ul#stickList.list_on li a {
		font-size: 1rem;
	}
	ul#stickList.list_on a.active::before {
		margin-right:12px;
	}
}

div.ground {
    padding:32px 0;
    background-image: url("/common/cmn_img/bg_ground.jpg");
    background-size: 500px;
    background-repeat: repeat;
}

div.board {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin:1rem auto;
    text-align: center;
}

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, 2.5vw, 1.5rem);
    color:#1F9947;
}

div.board h3 span.cate_title {
    font-size:clamp(1.5rem, 2.5vw, 2.5rem);
    line-height: 1.75;
}
    
    @media (min-width: 1280px) {

        div.ground {
            padding-right:90px; /*ul#stickListの幅*/
        }

        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;*/
            margin:2rem auto;
        }
    
    }/*@media end*/

    @media (min-width: 1440px) {

        div.ground {
            padding-right:120px; /*ul#stickListの幅*/
        }

    }

    @media (min-width: 1920px) {
        
        div.ground {
            padding-right:0; /*ul#stickListの幅*/
        }

    }

    div.panel-group p.prob {
        position: relative;
        width: fit-content;
        padding: 0.5rem 1.5rem;
    }

    div.panel-group p.prob::before, div.panel-group p.prob::after {
        content: '';
        width: 0.75rem;
        height: 0.75rem;
        position: absolute;
    }

    div.panel-group p.prob::before {
        /*border-left: solid 4px #7cc171;
        border-top: solid 4px #7cc171;
        top: 0;
        left: 0;
        border-top: solid 4px #7cc171;
        top:calc(50% - 2px);
        left: 0;*/
        content: '';
        width: 12px;
        height: 12px;
        border: 0;
        border-top: solid 4px #7cc171;
        border-right: solid 4px #7cc171;
        position: absolute;
        top:calc(50% - 4px);
        left: 0;
        transform: rotate(45deg);
    }
/*
    div.panel-group p.prob::after {
        border-right: solid 4px #7cc171;
        border-bottom: solid 4px #7cc171;
        bottom: 0;
        right: 0;
    }
*/
    div.km_resolutionBox p.prob {
        position: relative;
        width: fit-content;
        padding: 0.5rem 1.5rem;
    }

    div.km_resolutionBox p.prob::before, div.km_resolutionBox p.prob::after {
        content: '';
        width: 1rem;
        height: 1rem;
        position: absolute;
    }

    div.km_resolutionBox p.prob::before {
        border-left: double 6px #fff;
        border-top: double 6px #fff;
        top: 0;
        left: 0;
    }

    div.km_resolutionBox p.prob::after {
        border-right: double 6px #fff;
        border-bottom: double 6px #fff;
        bottom: 0;
        right: 0;
    }