@charset "utf-8";
#mv {  
	width: 100%;
	position: relative;
}
#mv_inner {
	width: 1150px;
	height: 100%;
	margin: 0 auto;
	position: absolute;
	left: 50%;
	top: 0;
	transform: translateX(-50%);
	z-index: 999;
	display: flex;
	/*justify-content: space-between;*/
	justify-content: flex-end;
	align-items: center;
}
#catch_box {
  margin-bottom: 120px;
  display: flex;
  flex-direction: column;
}
#catch {
  margin-bottom: 15px;
  font-size: 2.9rem;
  font-weight: 700;
  font-family: 'zenKaku', sans-serif;
  color: #fff;
  filter: drop-shadow(0 0 5px #333)
}
#catch_detail {
  font-size: 2rem;
  font-weight: 500;
  font-family: 'zenKaku', sans-serif;  
  line-height: 1.9;
  color: #fff;
  filter: drop-shadow(0 0 5px #333)
}
#bk_visual_left {
  left: -200px;
  top: 0;
}
#bk_visual_right {
  right: 0;
  top: -100px;
}
.bk_visual {
  position: absolute;
  z-index: 100;
}
section .btn:last-child {
  margin-bottom: 0;
}
@media screen and (max-width:768px) {
  #mv_inner {
    width: 100%;
    padding: 0 15px;
  }
  #catch_box {
    margin-bottom: 0;
    margin-top: 0;
  }
  #catch {
    font-size: 5.5vw;
    line-height: 1.5;
  }
  #catch_detail {
    font-size: 4vw;
  }
  .bk_visual {
    display: none;
  }
}

/***** swiper *****/
#swiper-slide1 {
	background: url("../images/top/mv_01.jpg") 50% 100% no-repeat;
	background-size: cover;
}
.swiper {
  width: 100%!important;
/*	height: calc(100vh - 100px)!important;*/
  margin: -100px 0 0!important;
	/*overflow: visible !important;*/
	position: relative!important;
}
.swiper .swiper-slide {
  width: 100%!important;	
  height: 100vh!important;
  text-align: center;
}
/*
.swiper .swiper-slide img {
	width: 100%;
}
*/
:root {
  --swiper-theme-color: var(--base-color)!important;
}
.swiper-pagination {
	width: 1150px!important;
	margin: 0 auto!important;
	text-align: left!important;
	left: 0!important;
	bottom: 200px!important;
  z-index: 1000;
}
.swiper-pagination-bullet {
	width: 70px!important;
	height: 3px!important;
	background: #fff!important;
	opacity: 1!important;
	border-radius: 0!important;
}
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin-right: 10px!important;
}
.swiper-pagination-bullet-active {
  opacity: 1;
  background: var(--swiper-pagination-color,var(--swiper-theme-color))!important;
}
.swiper-container-free-mode > .swiper-wrapper{-webkit-transition-timing-function:linear!important; -o-transition-timing-function:linear!important; transition-timing-function:linear!important; }

/*スライダーのやじるし調整*/
.swiper-button-next, .swiper-button-prev{
	top: 30px!important;
	left: auto!important;
	right: 0!important;
}
/*ボタンのポジションの調整*/
.swiper-button-next{
	right: 0!important;
}
.swiper-button-prev{
	right: 55px!important;
}
/*ボタンの色の調整*/
.swiper-button-next, .swiper-button-prev{
	border:solid rgba(89,194,252,1) 2px;
	padding: 3px 20px;
	transition-duration: 200ms;
	color: rgba(89,194,252,1);
}

/*端っこのコンテンツに到達したときのボタンの挙動*/
.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled{
	opacity: 1!important;
	border: 2px solid #ccc;
	color: #ccc;
}
.swiper-button-next.swiper-button-disabled:after, .swiper-button-prev.swiper-button-disabled:after{
	color: #ccc;
}
.swiper-button-next:after, .swiper-button-prev:after{
	font-size: 2rem!important;
	color: rgba(89,194,252,1);
}

@media screen and (max-width:768px){
#swiper-slide1 {
	background: url("../images/top/mv_01.jpg") 50% 100% no-repeat;
	background-size: cover;
}
  .swiper .swiper-slide {
    height: 100%!important;
  }
  
.swiper {
  width: 100%!important;
	height: 80vw!important;
  margin-top: 0!important;
}

.swiper-pagination {
	width: 100%!important;
	left: 0%!important;
	transform: translate(0,0)!important;
	text-align: center!important;
	bottom: 10px!important;
}

.swiper-pagination-bullet {
	width: 15%!important;
	height: 5px!important;
}
	
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
	margin: 0 5px!important;
}
}

/***** タイトル *****/
.ttl_box {
  margin-bottom: 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.ttl_box .ttl {
  margin-bottom: 0;
}
.ttl_box > p a {
  width: 100px;
  padding: 3px 0;
  font-size: 1.4rem;
  font-weight: 700;
  font-family: 'zenKaku', sans-serif;
  text-align: center;
  text-decoration: none;
  color: #fff;
  background: var(--base-color);
  display: block;
  border: var(--base-color) 2px solid;
  transition: 0.5s;
}
.ttl_box > p a:hover {  
  color: var(--base-color);
  background: #fff;
}
.ttl {
  margin-bottom: 40px;
  font-family: 'zenKaku', sans-serif;
  font-size: 3.5rem;
  font-weight: 700;
  line-height: 1;
}
.ttl span {
  margin-bottom: 10px;
  font-size: 1.5rem;
  font-weight: 500;
  font-family: 'zenKaku', sans-serif;
  color: var(--base-color);
  display: block;
}
@media screen and (max-width:768px){
  .ttl_box {
    margin-bottom: 20px;
  }
  .ttl {
    margin-bottom: 20px;
    font-size: 2.7rem;
  }
  }

/***** お知らせ *****/
#news {
  padding: var(--top-contents-pad);
  background: var(--gry-color);
}
#news > div {
  width: 1150px;
  margin: 0 auto;
}
#news dl {
  padding-top: 20px;
  border-top: #ddd 1px solid;
}
#news dl dt {
  width: 15em;
  float: left;
  clear: left;
  display: flex;
  align-items: center;
}
#news dl dt span {
  width: 100px;
  margin-left: 2.5em;
  padding: 3px 0;
  font-size: 1.3rem;
  font-weight: 500;
  text-align: center;
  background: var(--sub-color1);
}
#news dl dd {
  margin-bottom: 20px;
  padding: 0 0 20px 13em;
  border-bottom: #ddd 1px solid;
}
#news dl dd:last-child {
  margin-bottom: 0;
}
#news dl dd a {
  color: #000;
}
@media screen and (max-width:768px){
  #news {
    padding: var(--top-contents-pad);
  }
  #news > div {
    width: 100%;
    padding: 0 15px;
  }
  #news dl {
    padding-top: 20px;
    border-top: #ddd 1px solid;
  }
  #news dl dt {
    width: 100%;
    float: none;
  }
  #news dl dt span {
    width: 100px;
    margin-left: 20px;
    padding: 2px 0;
  }
  #news dl dd {
    padding: 5px 0 20px;
  }
  #news dl dd:last-child {
    margin-bottom: 0;
  }
  #news dl dd a {
    color: #000;
  }
}

/***** 活動目標 *****/
#objective {
  width: 1150px;
  margin: 0 auto;
  padding: var(--top-contents-pad);
  text-align: center;
}
#objective_list {
  display: none;
}
@media screen and (max-width:768px){
  #objective {
    width: 100%;
    padding: 30px 15px;
    text-align: left;
  }
  #objective .ttl {
    text-align: center;
  }
  #objective_figure {
    display: none;
  }
  #objective_list {
    margin-top: 20px;
    display: block;
  }
  #objective_list li {
    margin-bottom: 10px;
    padding: 5px;
    border: var(--base-color) 2px solid;
    border-radius: 5px;
    display: flex;
    align-items: center;
  }
  #objective_list li > p:nth-child(1) {
    margin-right: 7px;
  }
  #objective_list li > p:nth-child(2) {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--base-color);
    flex: 1;
  }
}

/***** 育成 *****/
#training {
  padding: var(--top-contents-pad);
  background: url("../images/top/training_bk.gif") var(--base-color);
}
#training > div {
  width: 1150px;
  margin: 0 auto;
}
#training > div > p {
  text-align: center;
  color: #fff;
}
#training .ttl {
  text-align: center;
  color: #fff;
}
#training .ttl > span {
  color: #fff;
}
#training > div > div {
  margin-top: 40px;
  display: flex;
  justify-content: space-between;
}
#training > div > div > div {
  width: 47%;
  padding: 40px;
  text-align: center;
  border: #87D4FF 5px solid;
  background: #fff;
}
#training > div > div > div > p:nth-of-type(1),
#training > div > div > div > div > p:nth-of-type(1)  {
  margin-top: 20px;
  font-size: 2.2rem;
  font-weight: 700;
  font-family: 'zenKaku', sans-serif;
  color: var(--base-color);
}
.detail_btn {
  margin: 20px auto 0;
}
.detail_btn a {
  padding: 5px 10px;
  font-size: 1.4rem;
  font-weight: 500;
  text-decoration: none;
  color: #fff;
  background: var(--base-color);
  border: var(--base-color) 2px solid;
  transition: 0.5s;
}
.detail_btn a:hover {
  color: var(--base-color);
  background: #fff;  
}
@media screen and (max-width:768px){
  #training {
    padding: 30px 15px;
  }
  #training > div {
    width: 100%;
    margin: 0;
    text-align: left;
  }
  #training > div > p {
    text-align: left;
  }
  #training > div > div {
    margin-top: 20px;
    display: block;
  }
  #training > div > div > div {
    margin-top: 15px;
    padding: 20px;
    border: #87D4FF 3px solid;
  }
  #training > div > div > div:nth-child(1) {
    width: 100%;
  }
  #training > div > div > div:nth-child(2) {
    width: 100%;
  }
  #training > div > div > div > p:nth-of-type(1) {
    margin-top: 10px;
    font-size: 2rem;
  }
  .detail_btn {
  margin: 10px auto 0;
}
  #training > div > div > div > figure {
    height: 100px;
  }
  #training > div > div > div > figure > img {
    height: 100%;
  }
}