@charset "UTF-8";
/* CSS Document */
.body {
  font-family: 'Helvetica';
}
.container {
  display: grid;
  grid-template-columns: repeat(3, minmax(100px, 2fr)); /* デスクトップ時 4列 */
  grid-template-rows: repeat(19, minmax(50px, auto)); /* 16行 */
  grid-column-gap: 5px;
  grid-row-gap: 5px;
}


  .div1 { grid-area: 1 / 1; }
  .div2 { grid-area: 1 / 2; }
  .div3 { grid-area: 2 / 1; }
  .div4 { grid-area: 2 / 2; }
  .div5 { grid-area: 2 / 3; }
  .div6 { grid-area: 3 / 1 / 3 / 3; }
  .div7 { grid-area: 3 / 2; }
  .div8 { grid-area: 3 / 3; }
  .div9 { grid-area: 4 / 1; }
  .div10 { grid-area: 4 / 2; }
  .div11 { grid-area: 4 / 3; }
  .div12 { grid-area: 5 / 1; } 
  .div13 { grid-area: 5 / 2; }
  .div14 { grid-area: 5 / 3; }
  .div15 { grid-area: 6 / 1; } 
  .div16 { grid-area: 6 / 2; }
  .div17 { grid-area: 6 / 3; }
  .div18 { grid-area: 7 / 1; }
  .div19 { grid-area: 7 / 2; }
  .div20 { grid-area: 7 / 3; }
  .div21 { grid-area: 8 / 1; }
  .div22 { grid-area: 8 / 2; }
  .div23 { grid-area: 8 / 3; } 
  .div24 { grid-area: 9 / 1; }
  .div25 { grid-area: 9 / 2; }
  .div26 { grid-area: 9 / 3; }
  .div27 { grid-area: 10 / 1; }
  .div28 { grid-area: 10 / 2; }
  .div29 { grid-area: 10 / 3; }
  .div30 { grid-area: 11 / 1; }
  .div31 { grid-area: 11 / 2; }
  .div32 { grid-area: 11 / 3; }
  .div33 { grid-area: 12 / 1; }
  .div34 { grid-area: 12 / 2 / 12 / 4; }
  .div35 { grid-area: 13 / 1; }
  .div36 { grid-area: 13 / 2; }
  .div37 { grid-area: 13 / 3; }
  .div38 { grid-area: 14 / 1; }
  .div39 { grid-area: 14 / 2; }
  .div40 { grid-area: 14 / 3; }
  .div41 { grid-area: 15 / 1; }
  .div42 { grid-area: 15 / 2; }
  .div43 { grid-area: 15 / 3; }
  .div44 { grid-area: 18 / 2; }
  .div45 { grid-area: 19 / 2; }

@media (max-width: 768px) {
  .container {
    grid-template-columns: 1fr; /* 1列に変更 */
    grid-template-rows: repeat(auto-fill, minmax(50px, auto)); /* 行は自動調整 */
padding-right: 5px;  }
	
  /* スマホ用の個別スタイル */
  .div1 { grid-area: 1 / 2; }
  .div2 { grid-area: 1 / 3; }
  .div4 { grid-area: 2 / 3; }
  .div5 { grid-area: 2 / 2; }
  .div6 { grid-area: 3 / 2 / 3 / 4; }
  .div10 { grid-area: 4 / 2; }
  .div11 { grid-area: 4 / 3; }
  .div12 { grid-area: 5 / 2; }
  .div9 { grid-area: 5 / 3; }
  .div16 { grid-area: 6 / 2; }
  .div18 { grid-area: 6 / 3; } 
  .div19 { grid-area: 7 / 2; } 
  .div15 { grid-area: 7 / 3; } 
  .div21 { grid-area: 8 / 2 / 9 / 4; } 
  .div22 { grid-area: 9 / 3; } 
  .div23 { grid-area: 9 / 2; } 
  .div24 { grid-area: 10 / 3; } 
  .div26 { grid-area: 10 / 2; } 
  .div25 { grid-area: 11 / 3; } 
  .div28 { grid-area: 12 / 2; } 
  .div29 { grid-area: 12 / 3; } 
  .div30 { grid-area: 13 / 2; } 
  .div27 { grid-area: 13 / 3; } 
  .div34 { grid-area: 14 / 2 / 14 / 4; } 
  .div35 { grid-area: 15 / 2; } 
  .div37 { grid-area: 14 / 2; }   
  .div36 { grid-area: 15 / 3; } 	
  .div40 { grid-area: 16 / 2; } 
  .div33 { grid-area: 16 / 3; } 
  .div42 { grid-area: 17 / 2 / 18 / 4; } 
  .div41 { grid-area: 18 / 3; } 
  .div43 { grid-area: 18 / 2; } 
  .div44 { grid-area: 20 / 2 / 20 / 4; } 
  .div45 { grid-area: 21 / 2 / 22 / 4; } 

	
	/* それぞれのアイテムを順番に縦に並べる */

  /* 必要に応じて他の .divX にも個別調整を加える */
	
	
}






.grid-item {
  width: 100%; /* 幅を100%に設定 */
}


.div1 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div1 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div1 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div1:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div2 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div2 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div2 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div2:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div3 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div3 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div3 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div3:hover .mask {
	opacity:		1;	/* マスクを表示する */
}



.div4 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div4 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
color:			#fff;
}
.div4 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div4:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div5 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div5 .caption {
	font-size:		100%;
	text-align: 		center;
	color:			#fff;	padding-top:		70%;

}
.div5 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div5:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div6 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div6 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		35%;
	color:			#fff;
}
.div6 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div6:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div7 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div7 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div7 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div7:hover .mask {
	opacity:		1;	/* マスクを表示する */
}



.div8 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div8 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div8 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div8:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div9 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div9 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div9 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div9:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div10 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div10 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
color:			#fff;
}
.div10 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div10:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div11 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div11 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div11 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div11:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div12 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div12 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div12 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div12:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div13 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div13 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div13 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div13:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div14 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div14 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div14 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div14:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div15 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div15 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div15 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div15:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div16 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div16 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div16 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div16:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div17 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div17 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div17 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div17:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div18 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div18 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div18 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div18:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div19 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div19 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div19 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div19:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div19 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div19 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div19 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div19:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div20 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div20 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div20 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div20:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div21 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div21 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div21 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div21:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div22 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div22 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div22 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div22:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div23 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div23 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div23 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div23:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div24 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div24 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div24 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div24:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div25 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div25 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div25 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div25:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div26 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div26 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div26 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div26:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div27 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div27 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div27 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div27:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div28 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div28 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div28 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div28:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div29 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div29 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div29 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div29:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div30 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div30 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div30 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div30:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div31 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div31 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div31 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div31:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div32 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div32 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div32 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div32:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div33 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div33 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div33 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div33:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div34 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div34 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		35%;
	color:			#fff;
}
.div34 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div34:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div35 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div35 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div35 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div35:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div36 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div36 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div36 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div36:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div37 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div37 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div37 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div37:hover .mask {
	opacity:		1;	/* マスクを表示する */
}

.div38 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div38 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div38 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div38:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div39 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div39 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div39 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div39:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div40 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div40 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div40 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div40:hover .mask {
	opacity:		1;	/* マスクを表示する */
}



.div41 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div41 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div41 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div41:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div42 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div42 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div42 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div42:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div43 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div43 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div43 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div43:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div44 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div44 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div44 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div44:hover .mask {
	opacity:		1;	/* マスクを表示する */
}


.div45 {
	overflow:		hidden;
	position:		relative;	/* 相対位置指定 */
}
.div45 .caption {
	font-size:		100%;
	text-align: 		center;	padding-top:		70%;
	color:			#fff;
}
.div45 .mask {
	width:			100%;
     min-height: 100%;
	position:		absolute;	/* 絶対位置指定 */
	top:			0;
	left:			0;
	opacity:		0;	/* マスクを表示しない */
	background-color:	rgba(0,0,0,0.4);	/* マスクは半透明 */
	-webkit-transition:	all 0.2s ease;
	transition:		all 0.2s ease;
}
.div45:hover .mask {
	opacity:		1;	/* マスクを表示する */
}





div{
  position: relative; /*親要素にrelative*/
}
d{
  margin: 0;
  font-size: 22px;
  color: #fff;
  position: absolute;
  right: 20px; /*左から30px*/
}

c{
  margin: 0;
  color: #fff;
  left: 5px; /*左から30px*/
}

h{
  margin: 0;
  font-size: 12px;
  color: #000;
  position: absolute;
  bottom: 1px; /*上から20px*/
  right: 1px; /*左から30px*/
}
j{
  margin: 0;
  font-size: 12px;
  color: #000;
  position: absolute;
  bottom: 1px; /*上から20px*/
  left: 1px; /*左から30px*/
}
m{
  margin: 0;
  font-size: 12px;
  color: #000;
  position: absolute;
  top: 1px; /*上から20px*/
  right: 1px; /*左から30px*/
}

n{
  margin: 0;
  color: #000;
  position: absolute;
  left: 1px; /*左から30px*/
}

a:link {
  color:rgba(var(--color-foreground), 0.75) !important;
  font-weight :normal !important;
}
a:visited {
  color:rgba(var(--color-foreground), 0.75) !important;
  font-weight :normal !important;
}
a:active {
  color:rgba(var(--color-foreground), 0.75) !important;
  font-weight :normal !important;
}

a:hover {
   opacity: 0.75; /* 25％ほど透明にする */
}


img:hover {
   opacity: 0.75; /* 25％ほど透明にする */
}


img {
    width: 100%;
    height: 100%;
object-fit: cover;
}


body {
  padding: 5px 5px;
}
h1 {
  margin-bottom: 100px;
}
h2 {
  margin-bottom: 50px;
}
/* スライドする要素 */
.content {
   background-image: cover;
   width: 350px;
   height: 400px;
 
}
/* スライドレールの枠 */
.wrap {
  overflow: hidden;
  display: flex;
  align-items: center;
  height: 400px;
  margin-bottom: 100px;

}
/* content4つをまとめたスライドブロック */
.slideshow {
  display: flex;
  -webkit-animation: loop-slide 20s infinite linear 1s both;
  animation: loop-slide 20s infinite linear 1s both;
}
@-webkit-keyframes loop-slide {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes loop-slide {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

.wrapper{
     width: 100%;
     position: relative;
     min-height: 100%;
}

.border {
    width: 100%;
    max-width: 300px; /* 必要に応じて調整 */
    margin: 0 auto; /* 中央に配置 */
    border: solid 1px #454545;
    padding: 1px;
    box-sizing: border-box;
}




.divlogo {
	width:	250px;
     height: 25px;
	margin-bottom: 20px;
	}


.div{
  font-family: 'Helvetica';
}

body{
  font-family: 'Helvetica';
}

img { image-rendering: -webkit-optimize-contrast; }


.text {
            position: absolute;
            bottom: 0;
            right: 0;
            margin: 20px;
            font-size: 10px;
            text-align: right 

}

.text2 {
            bottom: 10;
            right: 0;
            margin: 0px;
            font-size: 13px;
        }


     body, html {
        margin: 0;  /* 全体の余白をリセット */
        padding: 0;
    }

body {
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}


a {
  text-decoration: none !important; /* 強制的に適用 */
}

.footer {
  position: fixed;
  bottom: 0;
  width: 100%;
  background-color: #333; /* フッターの背景色 */
  color: #fff; /* フッターの文字色 */
  text-align: center;
  padding: 20px;
}


.child {
  position: relative;
  left: 0; /* これが横ずれを防ぐ */
}


