@charset "utf-8";
/* CSS Document */



/*mainv
----------------------------------------*/
.main-block {
	background: #091837;
	width: 100%;
	max-width: 1500px;
	margin: 0 auto;
	/*height: 100vh;*/
}

.main-block .inner{
	/*margin:  0 auto;*/
	padding: 7%;
	position: relative;
	text-align: center;
}

.main-block .main-catch:nth-of-type(1){
	position:absolute;
	top: 50%;
	font-size: 2.0rem;
	background: rgba(255,255,255,0.93);
	padding: 10px 16px 10px 20px;
	left: 4%;
	color: #0C1E44;
}

.main-block .main-catch:nth-of-type(2){
	position:absolute;
	top: 63%;
	font-size: 2.0rem;
	background: rgba(255,255,255,0.93);
	padding: 10px 20px 10px 10px;
	left: 4%;
	color: #0C1E44;
}

.main-block .txt-l{
	font-size: 2.6rem !important;
}


@media screen and (min-width:767px) and ( max-width:896px){
	.main-block{
		height: 100vh;
	}
	
	.main-block .main-catch:nth-of-type(1){
		position:absolute;
		top: 83%;
		font-size: 1.0rem;
		background: rgba(255,255,255,0.93);
		padding: 8px 12px 8px 8px;
		left: 9%;
		color: #0C1E44;
	}

	.main-block .main-catch:nth-of-type(2){
		position:absolute;
		top: 98%;
		font-size: 1.0rem;
		background: rgba(255,255,255,0.93);
		padding: 8px 15px 8px 8px;
		left: 9%;
		color: #0C1E44;
	}

	.main-block .txt-l{
		font-size: 1.4rem !important;
	}
}

@media screen and (max-width: 480px){
	.main-block{
		height: 80vh;
	}
	
	.main-block .main-catch:nth-of-type(1){
		position:absolute;
		top: 83%;
		font-size: 1.0rem;
		background: rgba(255,255,255,0.93);
		padding: 8px 12px 8px 8px;
		left: 9%;
		color: #0C1E44;
	}

	.main-block .main-catch:nth-of-type(2){
		position:absolute;
		top: 98%;
		font-size: 1.0rem;
		background: rgba(255,255,255,0.93);
		padding: 8px 15px 8px 8px;
		left: 9%;
		color: #0C1E44;
	}

	.main-block .txt-l{
		font-size: 1.4rem !important;
	}
}


/*scrollアニメーション
----------------------------------------*/

.box {
 /* width: 300px;*/
  /*height: 300px;
  margin: calc(50vh - 150px) auto;*/
  border-radius: 5px;
  box-shadow: 0 2px 30px #999;
  /*background: #fff;*/
  position: relative;
  /*overflow: hidden;*/
}

/* アニメーション設定 */
.arrowWrap {
  position: absolute;
  right: 0;
  bottom: 0;
  height: 280px;
}

.arrowInner p {
  font-size: 15px;
  text-align: end;
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
	color: #fff;
}

.arrow {
  width: 1px;
  height: 100px;
  margin: 50px auto 0;
  background-color: #eee;
  position: relative;
  overflow: hidden;
}

.arrow::before {
  content: '';
  width: 1px;
  height: 100px;
  margin: 50px auto 0;
  background-color: #000;
  position: absolute;
  top: -150px;
  left: 0;
  -webkit-animation: arrow 2.5s ease 0s infinite normal;
  animation: arrow 2.5s ease 0s infinite normal;
}

@keyframes arrow {
  0% {
    -webkit-transform: translate3d(-50%, 0, 0);
    transform: translate3d(-50%, 0, 0);
  }

  60% {
    -webkit-transform: translate3d(-50%, 100px, 0);
    transform: translate3d(-50%, 100px, 0);
  }

  100% {
    -webkit-transform: translate3d(-50%, 100px, 0);
    transform: translate3d(-50%, 100px, 0);
  }
}

@media screen and (max-width: 767px){
	.box {
		border-radius: 5px;
		box-shadow: 0 2px 30px #999;
		position: relative;
		z-index: 300;
	}
	
	.arrowWrap {
		position: absolute;
		right: 0;
		bottom: 0;
		top: 72px;
		left: 0;
		height: 0;
	}
	.arrow {
	  width: 1px;
	  height: 50px;
	  margin: 10px auto 0;
	}
	
	.arrowInner p {
	  font-size: 13px;
	  text-align: center;
	  -webkit-transform: rotate(90deg);
	  transform:none;
	}
}



.bg-dot{
	margin     : auto auto 80px;
	max-width  : inherit;
	height     : auto;		  /* ドット（水玉）模様のCSS */
	background-color   : #ffffff;
	background-image   : radial-gradient(rgba(12, 30, 68, 0.10) 13%, transparent 13%),
				   radial-gradient(rgba(12, 30, 68, 0.10) 13%, transparent 13%);
	background-position: 0 0, 9px 9px;
	background-size    : 18px 18px;
	display: block;
}


.top__page .first-block{
	display: flex;
	align-items: center;
	position: relative;
	height: auto;
	max-width: 1200px;
	flex-wrap: wrap;
	margin: auto;
	/*margin: 20px 0 20px auto;*/
}
.top__page .first-block .catch{
	font-size: 1.2rem;
	z-index: 100;
}

.top__page .first-block .text-block{
	font-family: "Noto Sans JP";
	background: rgba(255,255,255,0.90);
	/*position: absolute;*/
	margin: 0 0 0 auto;
	padding: 6% 4%;
	width: 63%;
	display: block;
}

.brackets {
	padding: 30px;
	position: relative;
}

.brackets::before,
.brackets::after {
	content: '';
	width: 30px;
	height: 30px;
	position: absolute;
}

.brackets::before {
	border-left: solid 2px #F9D401;
	border-top: solid 2px #F9D401;
	top: 0;
	left: 0;
}

.brackets::after {
	border-right: solid 2px #F9D401;
	border-bottom: solid 2px #F9D401;
	bottom: 0;
	right: 0;
}


@media screen and (max-width: 767px){
	
	.top__page .contents{
		margin-top: 0;
	}
	
	.top__page .first-block{
		display: block;
		padding: 40px auto;
		margin: 0;
	}
	.top__page .first-block .catch{
		font-size: 1.0rem;
	}
	
	.top__page .first-block .text-block{
		margin: 0 0 0 auto;
		padding: 6% 4%;
		width: 100%;
		display: block;
	}
	
	.brackets{
		padding: 14px;
		margin-bottom: 20px;
	}


}


/*work-block
----------------------------------------*/
.top__page .work-block{
	display: flex;
	margin: 60px auto;
	max-width: 900px;
	justify-content: space-between;
}

.top__page .work-block .icon{
	text-align: center;
}

.top__page .work-block .icon figure{
	background: #fff;
	border-radius:50%;
	width: 170px;
	height: 170px;
	text-align: center;
	margin: 0 auto 15px;
	position: relative;
	vertical-align: middle;
}


.top__page .work-block .icon figure img{
	  position: absolute;
	  top: 50%;
	  left: 50%;
	  -webkit-transform : translate(-50%,-50%);
	  transform : translate(-50%,-50%);
	  width: calc(170px / 2);
	  text-align: center;/*一応BOX内の文字も中央寄せ*/

}





@media screen and (max-width: 767px){
	.top__page .work-block{
		max-width: inherit;
		width: 100%;
		flex-wrap: wrap;
	}
	
	.top__page .work-block .icon{
		width: 46%;
		text-align: center;
		
	}
	
	.top__page .work-block .icon figure{
		background: #fff;
		border-radius:50%;
		width: 140px;
		height: 140px;
		text-align: center;
		margin: 0 auto 15px;
		position: relative;
		vertical-align: middle;
	}
}





/*link-block
----------------------------------------*/
.top__page .link-block{
	display: flex;
	justify-content: space-between;
	position: relative;
}
.top__page .link-block figure{
	display: inline-block;
	margin: 0 auto;
	overflow: hidden;
	cursor: pointer;
}
.top__page .link-block figure img{
	position: relative;
	max-width: 100%;
	transition-duration: 0.5s;
	margin: 0;
	padding: 0;
	display: block;
}

.top__page .link-block a figure{
	display: inline-block;
	vertical-align:bottom;
}
 
.top__page .link-block figure:hover img{
  transform: scale(1.2) !important;
  transition-duration: 0.5s !important;
}

.top__page .link-block .text{
	position: absolute;
    top: 36%;
    left: 0;
    right: 0;
    text-align: center;
    color: #fff;
}

.top__page .link-block .text p.ttl{
	font-size: 1.6rem;
}

.top__page .link-block .text p.explain{
	font-family: "Noto Sans JP";
	font-size: 0.8rem;
	text-align: center
}


.top__page .link-block > div{
	position: relative;
	width: 100%;
	overflow: hidden;
}

.top__page .link-block > div a figure::after{
	content: '';
	position: absolute;
	width: 93%;
	height: 93%;
	bottom: 3%;
    right: 3.5%;
	display: block;
  	border: 1px solid #fff;
}

.top__page .link-block > div::before{
	content: '';
	position: absolute;
	width: 0;
	height: 0;
	bottom: 22px;
    right: 28px;
	border-style: solid;
	border-width: 0 0 20px 20px;
	border-color: transparent transparent rgba(249,212,1,0.75) transparent;
	z-index: 2000;
}


.top__page .contents .contents-in{
	width: 100%;
	max-width: 1040px;
}

@media all and (-ms-high-contrast: none){
	.top__page .contents .contents-in{
		max-width: none!important;
		width: 100% !important;
	}
	.top__page .link-block a figure{
		width: 100%;
		display: inline-block;
		vertical-align:bottom;
		max-height: 400px;
	}
}



@media screen and (max-width: 767px){
	.top__page .link-block > div a figure::after{
		width: 96%;
		height: 90%;
		bottom: 4%;
    	right: 2%;
	}
	
	
	
	.top__page .contents > .contents-in{
		padding: 0;
	}
	
	
	
	
	.top__page .link-block{
		display: block;
		justify-content: space-between;
		position: relative;
	}
	
	.top__page .link-block figure{
		max-height: 20vh;
		
	}
	
	.top__page .link-block .text{
		top: 18%;
	}

	.top__page .link-block .text p.ttl{
		font-size: 1.0rem;
		margin: 0px 0 6px;
	}

	.top__page .link-block .text p.explain{
		font-family: "Noto Sans JP";
		font-size: 0.78rem;
		text-align: center
	}
	
	.top__page .link-block > div::before{
		content: '';
		position: absolute;
		width: 0;
		height: 0;
		bottom: 12px;
    	right: 12px;
		border-width: 0 0 15px 15px;
	}	
}	