@charset "UTF-8" ;

/********************************************************************************
********************************************************************************/


/* ボディ */
body
{
	margin: 0 ;		/* スペース */
	padding: 0 ;		/* 余白 */
	font-size: 15px ;	/* 文字サイズ */
	line-height: 1.618 ;	/* 行の高さ */
}

/* スマホだけに適用するCSS */
@media screen and (max-width:479px)
{
	/* ボディ */
	body
	{
		font-size: 13px ;	/* 文字サイズ */
	}
}

/* ヘッダー */
.header
{
    border-top: 1px solid #ffffff ;		/* 枠線 */
	border-bottom: 1px solid #eeeeee ;		/* 枠線 */
	text-align: center ;			/* テキスト、画像の真ん中寄せ */
	padding: 1em 0 ;			/* 上下の余白 */
	margin-bottom: 1em ;			/* 他のブロックとのスペース */
	background: #ffffff ;			/* 背景色(確認用) */
	color:#000000 ;
}


.grad-demo1{
  padding: 16px 0px 0px 0px;
  background: linear-gradient(to right, #5632a8, #ffffff);
}

.grad-demo1_inner{
  padding: 10px 0px 0px 0px;
  background-color: #fff;
  font-size: 22px;

}


/* スマホだけに適用するCSS */
@media screen and (max-width:479px)
{
	/* ヘッダー */
	.header
	{
		font-size: 8px ;	/* 文字サイズ */
	}
}






/* ロゴ画像を囲むh1 */
.logo-wrapper
{
	margin: 0 ;
	padding: 0px 50px 10px 0px;
	line-height: 1 ;
}

/* ロゴ画像 */
.logo
{
	width: 50px ;
	height: auto ;
	float:right;
}

/* スマホだけに適用するCSS */
@media screen and (max-width:479px)
{
	/* ロゴ画像 */
	.logo
	{
		width: 50px ;
	}
}

/* フッター */
.footer
{
	border-top: 3px solid #888 ;		/* 枠線 */
	text-align: center ;			/* テキスト、画像の真ん中寄せ */
	margin-top: 2em ;			/* 他のブロックとのスペース */
	padding: 1em 0 ;			/* 上下の余白 */
	background: #e8e8e8 ;
}

/* 全体(デスクトップPCとスマホ)に適用するCSS */
.wrapper
{
	width: 1024px ;
	margin: 0 auto ;		/* 左右に[auto]を指定することで、真ん中に寄る */
	padding: 0 ;			/* 上下左右の余白を0にしておく */
}

/* スマホだけに適用するCSS */
@media screen and (max-width:479px)
{
	.wrapper
	{
		width: auto ;
		padding: 0 10px ;
	}
}

/* 全体(デスクトップPCとスマホ)に適用するCSS */
.main
{
	width: 740px ;
	padding: 0px ;					/* 上下左右に1pxの余白 */
	border: 0px solid rgba(0,0,0,.1) ;		/* 枠線 */
}

.side
{
	width: 220px ;
	padding: 0 10px ;					/* 上下左右に20pxの余白 */
}

.icon
	{
		width: 60px ;
		display: table-cell;
		vertical-align: middle;
		}

.itauth {
background-color:#dbedff; color:#143eb3;	/* IT認証風の水色背景青字 */
margin-top: 5px;
margin-bottom: 0;
}

.itauth2 {
border-bottom: solid 5px #dbedff;	/* IT認証風の水色ボーダー */
}

.grid a {
text-decoration: none;
}

.lang a {
color:#ff0000;	/* IT認証風の言語リンク赤色 */
}




/* スマホだけに適用するCSS */
@media screen and (max-width:479px)
{
	.main
	{
		width: auto ;
		padding: 0 ;		/* 余白 */
		border: none ;		/* 枠線 */
	}

	.side
	{
		width: auto ;
	}
	.pic:focus, .pic:active {
	position: fixed;
	top:0;
	left:0;
	right:0;
	bottom:0;
	margin:auto;
	height: auto;
	z-index: 100;
	background: #fff;
	padding: 0px;
	outline: 0.1px solid #aaa;
	width: 405px ;
	}
	.pic
	{
		width: 300px ;
	}
}

/* 全体(デスクトップPCとスマホ)に適用するCSS */
.main
{
    margin-left: auto;
    margin-right: auto;
}


/* スマホだけに適用するCSS */
@media screen and (max-width:479px)
{
	.main , .side
	{
		float: none ;
	}
}

.wrapper
{
	overflow: hidden ;
}




#page_top{
  width: 50px;
  height: 50px;
  position: fixed;
  right: 0;
  bottom: 0;
  background: #5632a8;
  opacity: 0.6;
}
#page_top a{
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
}
#page_top a::before{
  font-family: FontAwesome;
  content: '\f102';
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}


.grid {
  display: grid;
  gap: 1px;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));

}
.item1 {
  border-radius: 5px;
  background: -moz-linear-gradient(bottom, #ff9933, #FFC778);
  background: -webkit-linear-gradient(bottom, #ff9933, #FFC778);
  background: linear-gradient(to top, #ff9933, #FFC778);
  padding: 5px;
  text-align: center;
  font-size: 15px;
  font-weight: bold;
  text-shadow: 2px 2px 3px rgb(100 100 100);
}

.item2 {
  border-radius: 5px;
  background: -moz-linear-gradient(bottom, #3399ff, #7fbfff);
  background: -webkit-linear-gradient(bottom, #3399ff, #7fbfff);
  background: linear-gradient(to top, #3399ff, #7fbfff);
  padding: 5px;
  text-align: center;
  font-size: 15px;
  font-weight: bold;
  text-shadow: 2px 2px 3px rgb(100 100 100);
}

.item3 {
  border-radius: 5px;
  background: -moz-linear-gradient(bottom, #9b38ff, #df5aff);
  background: -webkit-linear-gradient(bottom, #9b38ff, #df5aff);
  background: linear-gradient(to top, #9b38ff, #df5aff);
  padding: 5px;
  text-align: center;
  font-size: 15px;
  font-weight: bold;
  text-shadow: 2px 2px 3px rgb(100 100 100);
}

.item4 {
  border-radius: 5px;
  background: -moz-linear-gradient(bottom, #9acd32, #b7de1e);
  background: -webkit-linear-gradient(bottom, #9acd32, #b7de1e);
  background: linear-gradient(to top, #9acd32, #b7de1e);
  padding: 5px;
  text-align: center;
  font-size: 15px;
  font-weight: bold;
  text-shadow: 2px 2px 3px rgb(100 100 100);
}

.item5 {
  border-radius: 5px;
  background: -moz-linear-gradient(bottom, #ff9933, #FFC778);
  background: -webkit-linear-gradient(bottom, #ff9933, #FFC778);
  background: linear-gradient(to top, #ff9933, #FFC778);
  padding: 5px;
  text-align: center;
  font-size: 15px;
  font-weight: bold;
  text-shadow: 2px 2px 3px rgb(100 100 100);
}

.item6 {
  border-radius: 5px;
  background: -moz-linear-gradient(bottom, #3399ff, #7fbfff);
  background: -webkit-linear-gradient(bottom, #3399ff, #7fbfff);
  background: linear-gradient(to top, #3399ff, #7fbfff);
  padding: 8px;
  text-align: center;
  font-weight: bold;
  font-size: 11px;
  text-shadow: 2px 2px 3px rgb(100 100 100);
}

.item7 {
  background: -moz-linear-gradient(bottom, #ffffff, #ffffff);
  background: -webkit-linear-gradient(bottom, #ffffff, #ffffff);
  background: linear-gradient(to top, #dbedff, #dbedff);
  padding: 8px;
  text-align: center;
  font-size: 15px;
  font-weight: bold;
  color:#000000;
  border: 1px solid gray;
  box-sizing: border-box;

}

.item8 {
  background: -moz-linear-gradient(bottom, #ffffff, #ffffff);
  background: -webkit-linear-gradient(bottom, #ffffff, #ffffff);
  background: linear-gradient(to top, #ffffff, #ffffff);
  padding: 8px;
  text-align: center;
  font-size: 15px;
  font-weight: bold;
  color:#000000;
  border: 1px solid gray;
  box-sizing: border-box;
}



.info{
    position:relative;
    width:100%;
    height:0;
    padding-top:25%;
}
.info iframe{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
}

.infocolor {
    border: 1px #dcdcdc solid;
}
