@charset "UTF-8";
html {
  height: 100%;
  margin: 0;
  padding: 0;
  font-size: 62.5%; /* 10px */
}
body {
  width: 100%;
  height: 100%;
  color: #404040;
  font-family: -apple-system,BlinkMacSystemFont,"Helvetica Neue","游ゴシック Medium",YuGothic,YuGothicM,"Hiragino Kaku Gothic ProN",メイリオ,Meiryo,sans-serif;
  position: relative;
  line-height: 1.2rem;
  background: #61cfe9;
  margin: 0;
  padding: 0;
}

a {
  color: #404040;
  text-decoration: underline;
}

a:hover {
  color: #404040;
  text-decoration: none;
}


/****** header ******/
header {
  width: 100%;
  padding: 25px 0;
  text-align: center;
  background: #ffffff;
}
header h1 {
  text-align: center;
  padding: 0;
  margin: 0;
  font-size: 2.4rem;
  line-height: 3.4rem;
}
header span {
  font-size: 1.6rem;
}

/****** main-visual ******/
.main-visual {
  max-width: 950px;
  height: 392px;
  background: #ffffff;
  box-sizing: border-box;
  padding: 50px 30px 0 30px;
  border-radius: 20px;
  margin: 80px auto;
  font-size: 1.4rem;
  line-height: 1.8rem;
}
.main-visual .inner-main-cont {
  display: flex;
  box-sizing: border-box;
  margin-bottom: 30px;
  flex-direction: row-reverse;
}
.main-visual .inner-main-cont .main-cont-txt {
  width: 100%;
  padding-right: 20px;
  flex: 1;
  box-sizing: border-box;
}
.main-visual .inner-main-cont .main-cont-txt h2 {
  font-size: 2.4rem;
  line-height: 3.8rem;
  font-weight: bold;
  margin-bottom: 20px;
}
.main-visual .inner-main-cont .main-cont-txt h2 span {
  font-size: 4.2rem;
  color: #026db7;
  font-weight: bold;
}
.main-visual .inner-main-cont .main-cont-txt p {
  font-size: 1.8rem;
  line-height: 2.4rem;
}
.main-visual .inner-main-cont .main-cont-pic {
  width: 452px;
  box-sizing: border-box;
  margin-top: -80px;
  margin-bottom: -80px;
}

/****** average-area ******/
.average-area {
  max-width: 950px;
  background: #ffffff;
  box-sizing: border-box;
  padding: 50px 30px;
  border-radius: 20px;
  margin: 0 auto 50px auto;
  font-size: 1.4rem;
  line-height: 1.8rem;
}
.average-area h2 {
  font-size: 2.8rem;
  line-height: 3.8rem;
  color: #026db7;
  padding-bottom: 40px;
}
.average-area .average-inner {
  display: flex;
  box-sizing: border-box;
}
.average-area .average-inner .average-pic-pos {
  width: 400px;
  box-sizing: border-box;
}
.average-area .average-inner .average-txt-pos {
  width: 100%;
  padding-left: 30px;
  flex: 1;
  box-sizing: border-box;
}
.average-area .average-inner .average-txt-pos .ave-s-txt {
  font-size: 1.2rem;
  line-height: 1.6rem;;
}

/****** joint-area ******/
.joint-area {
  max-width: 950px;
  background: #ffffff;
  box-sizing: border-box;
  padding: 50px 30px;
  border-radius: 20px;
  margin: 0 auto 50px auto;
  font-size: 1.4rem;
  line-height: 1.8rem;
}
.joint-area h2 {
  font-size: 2.8rem;
  line-height: 3.8rem;
  color: #026db7;
  padding-bottom: 40px;
}
.joint-area .joint-inner {
  display: flex;
  box-sizing: border-box;
  flex-direction: row-reverse;
}
.joint-area .joint-inner .joint-txt-pos {
  width: 100%;
  padding-right: 30px;
  flex: 1;
  box-sizing: border-box;
}
.joint-area .joint-inner .joint-txt-pos .joint-link-txt {
  font-size: 1.6rem;
  line-height: 2.0rem;
}
.joint-area .joint-inner .joint-pic-pos {
  width: 400px;
  box-sizing: border-box;
}

/****** task-area ******/
.task-area {
  max-width: 950px;
  background: #ffffff;
  box-sizing: border-box;
  padding: 50px 30px;
  border-radius: 20px;
  margin: 0 auto 50px auto;
  font-size: 1.4rem;
  line-height: 1.8rem;
}
.task-area h2 {
  font-size: 2.8rem;
  line-height: 3.8rem;
  color: #026db7;
  padding-bottom: 40px;
}
.task-area .task-inner {
  display: flex;
  box-sizing: border-box;
}
.task-area .task-inner .task-pic-pos {
  width: 250px;
  box-sizing: border-box;
}
.task-area .task-inner .task-pic-pos img:hover {
  opacity: 0.6;
}
.task-area .task-inner .task-txt-pos {
  width: 100%;
  padding-left: 30px;
  flex: 1;
  box-sizing: border-box;
}

/****** news-area ******/
.news-area {
  max-width: 950px;
  background: #ffffff;
  box-sizing: border-box;
  padding: 50px 30px 30px 30px;
  border-radius: 20px;
  margin: 0 auto 50px auto;
  font-size: 1.4rem;
  line-height: 1.8rem;
}
.news-area h2 {
  font-size: 2.8rem;
  line-height: 3.8rem;
  color: #026db7;
  padding-bottom: 40px;
}
.news-area dl {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}
.news-area dt {
  width: 15%;
  padding-bottom: 20px;
  margin-bottom: 20px;
  box-sizing: border-box;
  border-bottom: 1px solid #e4e4e4;
}
.news-area dd {
  width: 85%;
  padding-bottom: 20px;
  margin-bottom: 20px;
  box-sizing: border-box;
  border-bottom: 1px solid #e4e4e4;
}

/****** supplement-area ******/
.supplement-area {
  max-width: 950px;
  box-sizing: border-box;
  padding: 0 0 50px 0;
  margin: 0 auto;
  font-size: 1.4rem;
  line-height: 1.8rem;
  color: #ffffff;
}
.supplement-area h2 {
  font-size: 1.6rem;
  line-height: 2.0rem;
  margin-bottom: 10px;
}
.supplement-area .supplement-link-txt {
  font-size: 1.6rem;
  line-height: 2.0rem;
}
.supplement-area a {
  color: #ffffff;
  text-decoration: underline;
}
.supplement-area a:hover {
  color: #ffffff;
  text-decoration: none;
}


/****** フェード　******/
.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 1.0s;
  animation-fill-mode: forwards;
  opacity: 0;
}
  
@keyframes fadeUpAnime {
  from {
    opacity: 0;
    transform: translateY(100px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.fadeUpTrigger {
  opacity: 0;
}



/******************************************************
smartphone
******************************************************/
@media screen and (max-width: 768px) {

/****** header ******/
header {
  width: 100%;
  padding: 15px 0;
  text-align: center;
  background: #ffffff;
}
header h1 {
  text-align: center;
  padding: 0;
  margin: 0 auto;
  font-size: 1.8rem;
  line-height: 2.8rem;
  width: 94%;
}
header span {
  font-size: 1.2rem;
}

/****** main-visual ******/
.main-visual {
  width: 94%;
  height: auto;
  background: #ffffff;
  box-sizing: border-box;
  padding: 20px;
  border-radius: 20px;
  margin: 80px auto 50px auto;
}
.main-visual .inner-main-cont {
  display: block;
  box-sizing: border-box;
}
.main-visual .inner-main-cont .main-cont-txt {
  width: 100%;
  padding-right: 0;
  box-sizing: border-box;
}
.main-visual .inner-main-cont .main-cont-txt h2 {
  font-size: 1.8rem;
  line-height: 3.2rem;
  font-weight: bold;
  margin-bottom: 20px;
}
.main-visual .inner-main-cont .main-cont-txt h2 span {
  font-size: 3.6rem;
  color: #026db7;
  font-weight: bold;
}
.main-visual .inner-main-cont .main-cont-txt p {
  font-size: 1.8rem;
  line-height: 2.4rem;
}
.main-visual .inner-main-cont .main-cont-pic {
  width: 100%;
  box-sizing: border-box;
  padding-bottom: 30px;
  margin-top: -50px;
  margin-bottom: 0;
}
.main-visual .inner-main-cont .main-cont-pic img {
  width: 100%;
}

/****** average-area ******/
.average-area {
  width: 94%;
  padding: 20px;
  margin: 0 auto 50px auto;
}
.average-area h2 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  color: #026db7;
  padding-bottom: 30px;
}
.average-area h2 br {
  display: none;
}
.average-area .average-inner {
  display: block;
  box-sizing: border-box;
}
.average-area .average-inner .average-pic-pos {
  width: 100%;
  box-sizing: border-box;
  margin-bottom: 20px;
}
.average-area .average-inner .average-pic-pos img {
  width: 100%;
}
.average-area .average-inner .average-txt-pos {
  width: 100%;
  padding-left: 0;
  box-sizing: border-box;
}

/****** joint-area ******/
.joint-area {
  width: 94%;
  padding: 20px;
  margin: 0 auto 50px auto;
}
.joint-area h2 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  color: #026db7;
  padding-bottom: 30px;
}
.joint-area .joint-inner {
  display: block;
  box-sizing: border-box;
}
.joint-area .joint-inner .joint-txt-pos {
  width: 100%;
  padding-right: 0;
  box-sizing: border-box;
}
.joint-area .joint-inner .joint-pic-pos {
  width: 100%;
  box-sizing: border-box;
  margin-bottom: 20px;
}
.joint-area .joint-inner .joint-pic-pos img {
  width: 100%;
}

/****** task-area ******/
.task-area {
  width: 94%;
  padding: 20px;
  margin: 0 auto 50px auto;
}
.task-area h2 {
  font-size: 2.4rem;
  line-height: 3.4rem;
  color: #026db7;
  padding-bottom: 30px;
}
.task-area .task-inner {
  display: block;
  box-sizing: border-box;
}
.task-area .task-inner .task-pic-pos {
  width: auto;
  box-sizing: border-box;
  text-align: center;
  margin-bottom: 20px;
}
.task-area .task-inner .task-pic-pos img {
  margin-left: auto;
  margin-right: auto;
}
.task-area .task-inner .task-txt-pos {
  width: 100%;
  padding-left: 0;
  box-sizing: border-box;
}

/****** news-area ******/
.news-area {
  width: 94%;
  padding: 20px;
  margin: 0 auto 50px auto;
}
.news-area h2 {
  font-size: 2.8rem;
  line-height: 3.8rem;
  color: #026db7;
  padding-bottom: 30px;
}
.news-area dl {
  display: block;
  width: 100%;
}
.news-area dt {
  width: 100%;
  padding-bottom: 10px;
  margin-bottom: 0;
  box-sizing: border-box;
  border-bottom: none;
}
.news-area dd {
  width: 100%;
  padding-bottom: 20px;
  margin-bottom: 20px;
  box-sizing: border-box;
  border-bottom: 1px solid #e4e4e4;
}

/****** supplement-area ******/
.supplement-area {
  width: 94%;
  padding: 0 0 50px 0;
  margin: 0 auto;
  color: #ffffff;
}

}

/****** clearfix ******/
.clearfix::after {
    content: "";
    display: block;
    clear: both;
}

/****** common style ******/
.mb5 { margin-bottom: 5px; }
.mb10 { margin-bottom: 10px; }
.mb20 { margin-bottom: 20px; }
.mb30 { margin-bottom: 30px; }
.mb40 { margin-bottom: 40px; }
.mb50 { margin-bottom: 50px; }
.mb60 { margin-bottom: 60px; }
.mb70 { margin-bottom: 70px; }
.mb90 { margin-bottom: 90px; }
.mb100 { margin-bottom: 100px; }
.mb80 { margin-bottom: 80px; }