@charset "Shift_JIS";

body{
	width:100%; /*ページ全体の幅は100%と指定する*/
	height:auto;
	animation: fadeIn 3s ease 0s 1 normal;
	-webkit-animation: fadeIn 2s ease 0s 1 normal;
}

@keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}

@-webkit-keyframes fadeIn {
	0% {opacity: 0}
	100% {opacity: 1}
}


header{
	width:900px;
	margin:0 auto;	
}

header img{
	width:300px;
}


.header_langList {
	position: relative;
	float: right;
	/*padding: 17px 0;*/
	top:40px;
	margin: 0 10px;
}

.header_langList_item {
	float: left;
	color: #fff;
	font-size: 11px;
	font-weight: normal;
	letter-spacing: 0;
	width: 80px;
	line-height: 22px;
	text-align:center;
	border: solid 1px #0f89d2;
	background-color: #0f89d2;
}

.header_langList_link {
	display: block;
	color: #0f89d2;
	font-size: 11px;
	font-weight: normal;
	letter-spacing: 0;
	background-color: #fff;
	text-decoration:none;
}

.bx-wrapper {
	margin: 0 !important;
	-moz-box-shadow: none !important;
	-webkit-box-shadow: none !important;
	box-shadow: none !important;
	border: none !important;
	background: none !important;
}


span.active{
	color:#fff;
	background-color:#0f89d2;
	padding:2px;
}

a.language{
	text-decoration: none;
}
a.language:link {color:#0f89d2;} /*未訪問のリンクの色*/
a.language:visited {color:#0f89d2;} /*訪問済みのリンクの色*/
a.language:hover {color:#ff0000; background:none;} /*カーソルが乗っているリンクの色*/
a.language:active {color:#ffff00;} /*クリック中のリンクの色*/



.column div {
	position: relative;
	float: left;
	width: 220px;
	height: 220px;
	margin: 0 0 0 25px;
	padding: 0;
}
figure {
	width: 220px;
	height: 220px;
	margin: 0;
	padding: 0;
	background: #fff;
	overflow: hidden;
}

.column2 div {
	position: relative;
	float: left;
	width: 440px;
	height: 108px;
	margin: 0 0 0 25px;
	padding: 0;
}
.colum2 figure {
	width: 440px;
	height: 108px;
	margin: 0;
	padding: 0;
	background: #fff;
	overflow: hidden;
}

/* Zoom In #1 */
.hover01 figure img {
	-webkit-transform: scale(1);
	transform: scale(1);
	-webkit-transition: .3s ease-in-out;
	transition: .3s ease-in-out;
}
.hover01 figure:hover img {
	-webkit-transform: scale(1.1);
	transform: scale(1.1);
}

h1 {
	color:#666;
	font-size:36px;
	line-height:1.2;
	margin:0 0 0 5px;
}

h2 {
	color:#666;
	font-size:22px;
	font-weight:bold;
	line-height:1.2;
	margin:0 0 0 5px;
}

h2.ngroup{
	color:#fff;
	font-size:24px;
	font-weight:bold;
	line-height:1.2;
	position:relative;
	top:50px;
}


h3{
	font-size:20px;
	color:#666;
	padding:0 0 3px 0;
}

h3.slogan{
	font-size:18px;
	color:#f00;
	padding:0 0 3px 0;
}

div#top_img p img{
	width: 100%;
	max-width: 100%;
}

div#main{
	max-width:900px;
	margin:0 auto;
}

div#main img{
	max-width: 100%;
	height: auto;
}

div#main p{
	/*color:#333;*/
	font-size:14px;
	line-height:1.5;

}

table {
	width:100%;
	margin: 0px auto;
	font-size:14px;
}
.tbl-r02 th {
	background: #aaaaaa;
	border: solid 1px #fff;
	color: #fff;
	padding: 10px;
	vertical-align:middle;
}
.tbl-r02 td {
	background: #eeeeee;
	border: solid 1px #fff;
	color: #777;
	padding: 15px 15px 15px 30px;
	line-height:1.3;
}



section.box{
	margin-top:50px;
	margin-bottom:30px;
}

section.box_of{
	margin-top:50px;
	margin-bottom:30px;
	overflow: hidden;
}

section.box_bps{
	width:900px;
	margin-top:50px;
	margin-bottom:50px;
	overflow: hidden;
}
div.wrap2{
	width:900px;
	box-sizing: border-box;
}

div.left_box,div.photo{
	float: left;
}

div.right_box,div.photo{
	float: right;
}


div.data h2 {
	color:#666;
	font-size:36px;
	line-height:1.2;
}

div.wrap1{
	max-width:900px;
	display: flex:
}



div.left_box_4{
	width:220px;
	float:left;
	margin-right:5px;
}

.photo {
	width:		100%;
	margin:		0;
	padding:	0;
	position:	relative; /* 相対位置指定 */
}
.photo p{
	position: absolute;
	top: 0;/*画像の左上に配置*/
	left: 0;
	margin: 0; /*余計な隙間を除く*/
	color: #fff;/*文字*/
	background: none;/*背景色*/
	font-size: 16px;
	font-weight:bold;
	line-height: 1;/*行高は1に*/
	padding: 7px 12px;/*文字周りの余白*/
}
.photo p.bps{
	position: absolute;
	top: 0;/*画像の左上に配置*/
	left: 0;
	margin: 0; /*余計な隙間を除く*/
	color: #fff;/*文字*/
	text-shadow: 3px  3px 15px #888,
				 -3px  3px 15px #888,
				 3px -3px 15px #888,
				 -3px -3px 15px #888;
	background: none;/*背景色*/
	font-size: 16px;
	font-weight:bold;
	line-height: 1;/*行高は1に*/
	padding: 7px 12px;/*文字周りの余白*/
}





p.lead{
	margin:10px 0 20px 0;
	
}



div#ngroup_contents{
	width:100%;
	background-color:#000000;
	height:450px;

}

div#ngroup_main{
	max-width:900px;
	margin:0 auto;
	text-align:left;   /*全体を左揃えにする。*/
}
div.lead{
	position:relative;
	top:100px;
}
div#ngroup_main p{
	color:#bbb;
	font-size:14px;
	line-height:1.5;
}

h2.sub_title{
	position: absolute;/*絶対配置*/
	color: white;/*文字は白に*/
	line-height:1.4;
	top: 95px;
	left:60px;
	font-family:Times New Roman,Times,serif;
	font-size:48px;
	text-shadow:2px 1px 2px #000;
}

div#blands{
	position:relative;
	top:150px;
	display:block;
}

div#blands ul{
	width:370px;
}
div#blands ul li{
	max-width:72px;
}

.logo{
	float: left;
}


div.button{
	text-align:center;
}

button {
	margin: 15px auto;
	padding: 0.5em 5em;
	border: none;
	box-sizing:border-box;
	display: inline-block;
	font-size: 105%;
	position: relative;
	top:140px;
	right:-90px;
	cursor: pointer;
}

button::before,
button::after {
	box-sizing:border-box;
}


.buttonB {
	border:1px solid #fff;
	background-color: #000;
	color: #fff;
	transition: .6s all;
}

.buttonB:hover {
	border:1px solid #006ca7;
	background-color: #fff;
	color: #006ca7;
}


.buttonA {
	border:2px solid rgb(33,79,151);
	background-color: rgba(33,79,151,1);
	color: #ddd;
	transition: .6s all;
}

.buttonA:hover {
	border:2px solid rgb(33,79,151);
	background-color: rgba(33,79,151,.0);
	color:  rgba(33,79,151,1);
}

.buttonE {
	border:2px solid rgb(33,79,151);
	background-color: rgba(33,79,151,.0);
	color:  rgba(33,79,151,1);
	transition: .6s all;
	width:340px;
}

.buttonE:hover {
	border:2px solid rgb(33,79,151);
	background-color: rgba(33,79,151,1);
	color: #ddd;
	width:340px;

}

.buttonC {
	border:1px solid rgb(33,79,151);
	background-color: rgba(33,79,151,1);
	color: #ddd;
	transition: .6s all;
}

.buttonC:hover {
	border:1px solid #ddd;
	background-color: #fff;
	color: rgb(33,79,151);
}

.buttonD {
	border:1px solid rgb(255,0,0);
	background-color: rgba(255,0,0,0);
	color: #ddd;
	transition: .6s all;
}

.buttonD:hover {
	border:1px solid rgb(225,0,0);
	background-color: rgba(255,0,0,.1);
	color: rgb(255,0,0);
}




/*タブ切り替え全体のスタイル*/
.tabs {
	margin-top: 50px;
	padding-bottom: 40px;
	background-color: #fff;
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
	line-height:1.8;
	width: 100%;
	margin: 0 auto;}
/*タブのスタイル*/
.tab_item {
	width: calc(100%/3);
	height: 50px;
	border-bottom: 3px solid #0f89d2;
	background-color: #d9d9d9;
	line-height: 50px;
	font-size: 14px;
	text-align: center;
	color: #565656;
	display: block;
	float: left;
	text-align: center;
	font-weight: bold;
	transition: all 0.2s ease;
}
.tab_item:hover {
	opacity: 0.75;
}
/*ラジオボタンを全て消す*/
input[name="tab_item"] {
	display: none;
}
/*タブ切り替えの中身のスタイル*/
.tab_content {
	display: none;
	padding: 40px 40px 0;
	clear: both;
	overflow: hidden;

}

div.tab_content_description p.c-txtsp {
	line-height: 1.8;
}


/*選択されているタブのコンテンツのみを表示*/
#all:checked ~ #all_content,
#programming:checked ~ #programming_content,
#design:checked ~ #design_content {
	display: block;
}
/*選択されているタブのスタイルを変える*/
.tabs input:checked + .tab_item {
	background-color: #0f89d2;
	color: #fff;
}

footer{
	width:100%;
	background-color;#373737;
	height:auto;
}
footer p{
	padding:15px 0 15px 0;
	text-align:center;
	font-size:10px;
	color:#ccc;	
	background-color:#373737;
}


.pc {
	display: block !important;
}
.sp {
	display: none !important;
}


/*================================================
 *  タブレット向けデザイン
 ================================================*/
@media screen and (max-width:979px) {

header{
	width:auto;
}

header img{
	width:40%;
}

.header_langList {
	position: relative;
	right:40px;
}

div#main p{
	font-size:12px;

}

#slide {
	width:auto;
}


div.left_box_4{
	width:auto;
}


section.box{
	padding: 0 15px;
}

section.box_of{
	margin:0 15px;
}


section.box_bps{
	width:auto;
	padding:0 10px;
}




div.left_box,div.photo figure{
	float: none;/*floatをnoneで解除*/
	width: auto;/*幅をpx指定していたものをautoに設定*/
	margin-bottom: 10px;/*left-areaとrighat-areaの間に余白を入れる*/
}

div.right_box,div.photo figure{
	float: none;/*floatをnoneで解除*/
	width: auto;/*幅をpx指定していたものをautoに設定*/
}
div#ngroup_contents{
	height:550px;

}


div#ngroup_main{
	width:90%;
	margin:0 auto;
}


.buttonE {
	width:80%;
}

.buttonE:hover {
	width:80%;

}



}



/*================================================
 *  スマートフォン向けデザイン
 ================================================*/
@media screen and (max-width:767px) {


header img{
	width:40%;
}

.header_langList {
	top:15px;
}
.header_langList_item {
	font-size: 9px;
	width: 50px;
}
.header_langList_link {
	font-size: 9px;
}



.pc{
	display: none !important;
}
.sp{
	display: block !important;
}


table {
	width:100%;
	height:auto;
}

.tbl-r02 th {
	font-size:10px;
}
.tbl-r02 td {
	font-size:10px;
}


.tab_item {
	font-size: 12px;
}



div#main p{
	font-size:12px;

}
div.left_box_4{
	width:100%;
}


section.box{
	padding: 0 15px;
}



section.box_bps{
	width:auto;
	padding:0 10px;
}


div.left_box,div.photo figure{
	float: none;/*floatをnoneで解除*/
	width: auto;/*幅をpx指定していたものをautoに設定*/
	margin-bottom: 10px;/*left-areaとrighat-areaの間に余白を入れる*/
}

div.right_box,div.photo figure{
	float: none;/*floatをnoneで解除*/
	width: auto;/*幅をpx指定していたものをautoに設定*/
}



div#ngroup_contents{
	height:680px;

}


/*div#blands ul li{
	width:40px;
}*/
div#blands ul li img{
	width:90%;
}


.buttonE {
	width:30%;
}

.buttonE:hover {
	width:30%;

}



div#ngroup_main p{
	font-size:12px;
}
h2.ngroup{
	font-size:18px;
}




}


