@charset "UTF-8";
/*!00Basic*/
/*!01ヘッダ*/
/*!1.5 ハンバーガーボタン*/
/*!02FV*/
/*!03 TOP NEWS*/
/*!04 TOPコンテント*/
/*!05 TOP SERVICE*/
/*!06 TOP CASE*/
/*!07 TOP INFO*/
/*!08 TOP CONTACT*/
/*!09 NEWS*/
/*!10 FOOTER*/



/*!00Basic*/
@media screen and (max-width: 1248px) {
	
	.w1200 {

		margin: 64px 24px 48px;

	}
	
}

/*!---------------1248 END---------------*/









@media screen and (max-width: 1200px) {
	
	/*!---------------01ヘッダ---------------*/
	
	header {
		display: block;
		position: fixed;
		height: 70px;
		width: calc(100% - 32px);
		padding: 4px 0px;
		margin: 16px;
		z-index: 9;
		transition: 0.5s;
		border-radius: 8px;
	}
	
	.ttl {
		max-width: 200px;
	}
	
	.pc_nav a {
		margin-left: 20px;
		font-size: 16px;
		font-weight: 400;
		color: #121212;
	}
	
	.menu > li a {
		display: block;
		font-size: 16px;
		font-weight: 800;

	}
	
	/*!1.5 ハンバーガーボタン*/
	
	.header {
	  position: relative;
	  z-index: 10;
	  display: fixed;
	  width: 100%;
	  display: none;
	}
}
	
/*!---------------1200 END---------------*/







	
	
@media screen and (max-width: 999px){
		.header {
			position: fixed;
			z-index: 10;
			display: block;
			width: 100%;
			transition: 0.2s;
		}
		.hamburger {
			/* アニメーションの変化時間 */
			transition: 0.2s;
		}
		header.scroll-nav .hamburger {
			position: fixed;
			top: 24px;
			right: 24px;
			width: 28px;
			height: 17px;
			z-index: 9999;
			/* アニメーションの変化時間 */
			transition: 0.5s;
		}
		
		.header__nav {
		  position: fixed;
		  top: 0;
		  left: 0;
		  width: 100%;
		  height: 100vh;
		  background: rgb(48, 70, 185);
		  background: linear-gradient(90deg, #015eea 0%, #00c0fa 100%);
		  padding: 20px 28px;
		  opacity: 0;
		  visibility: hidden;
		  transition: opacity 0.5s, visibility 0.5s;
		}
		.header__nav.is-open {
		  opacity: 1;
		  visibility: visible;
		}
		
		.header__nav-list {
		  list-style: none;
		  padding-top: 48px;
		}
		
		.header__nav-item {
		  margin: 15px 0;
		}
		.header__nav-item a {
		  color: #fff;
		  text-decoration: none;
		  font-family: "brother-1816", sans-serif;
		  font-weight: 700;
		  font-style: normal;
		  font-size: 5vw;
		  margin: 24px 0;
		  text-align: right;
		  display: block;
		  line-height: 1.5em !important;
		}
		.header__nav-item a:hover {
		  filter:alpha(opacity=70);
		  -moz-opacity: 0.7;
		  opacity: 0.7;
		  -moz-transition: .2s;
		  -webkit-transition: .2s;
		  -o-transition: .2s;
		  -ms-transition: .2s;
		  transition: .2s;
		  
		}
		.header__nav-item a span {
			font-size: 16px;
			color: #fff;
			font-weight: 600;
			display: block;
			margin: 8px;
		}
		
		
		
		
		
		
		
		.hamburger {
		  position: fixed;
		  top: 40px;
		  right: 32px;
		  width: 28px;
		  height: 17px;
		  z-index: 9999;
		}
		.hamburger__trigger {
		  display: inline-block;
		  transition: all 0.4s;
		  box-sizing: border-box;
		  position: relative;
		  background: transparent;
		  border: none;
		  cursor: pointer;
		  outline: none;
		  width: 24px;
		  height: 21px;
		}
		.hamburger__trigger span {
		  display: inline-block;
		  transition: all 0.4s;
		  position: absolute;
		  left: 0;
		  width: 100%;
		  height: 2px;
		  background-color: #111;
		}
		.hamburger__trigger span:nth-of-type(1) {
		  top: 0;
		}
		.hamburger__trigger span:nth-of-type(2) {
		  top: 9px;
		  transition: all 0.25s 0.25s;
		  opacity: 1;
		}
		.hamburger__trigger span:nth-of-type(3) {
		  bottom: 0;
		}
		.hamburger__trigger.is-active span:nth-of-type(1) {
		  transform: translateY(9px) rotate(-45deg);
		  background: #fff;
		}
		.hamburger__trigger.is-active span:nth-of-type(2) {
		  opacity: 0;
		}
		.hamburger__trigger.is-active span:nth-of-type(3) {
		  transform: translateY(-9px) rotate(45deg);
		  background: #fff;
		}
		
		body.is-open {
		  height: 100vh;
		  overflow-y: hidden;
		}
		
		
		
		
		
		header {
			display: block;
			position: fixed;
			height: 70px !important;
			width: calc(100% - 32px);
			padding: 4px 0px;
			margin: 16px;
			z-index: 9;
			transition: 0.5s;
			border-radius: 8px;
		}
		
		header.scroll-nav {
			position: fixed;
			height: 100px;
			width: calc(100% - 0px);
			padding: 16px 24px;
			margin: 0 0 16px 0;
			z-index: 9;
			transition: 0.5s;
			background: #fff;
			border-radius: 0px;
		}
		
		header.scroll-nav .menu {
			position: relative;
			bottom: 8px;
		}
		
		
		
		
		
		
		/*!---------------02FV---------------*/
		.fv {
			width: 100%;
			height: 100%;
			margin: 0;
			padding: 0;
			overflow: hidden;
			background: url(images/fv.jpg) no-repeat center center;
			background-size: cover;
		}
		.fv2 {
			width: 100%;
			height: 100%;
			margin: 0;
			padding: 0;
			overflow: hidden;
			background: url(images/30th.png) no-repeat left 24px top 100px;
			Background-size: 260px;
		}
		
		.fv_text {
			padding: 32px;
			position: absolute;
			right: 32px;
			bottom: 35%;
		}
		.fv_text h1 {
			color: #fff;
			font-weight: 400;
			font-size: 8vw;
			font-family: "futura-pt-bold", sans-serif;
			font-weight: 700;
			font-style: normal;
			margin-bottom: 32px;
			letter-spacing: 0.04em;
			line-height: 1em;
			text-align: right;
			position: relative;
			left: 64px;
			
		}
		
		.fv_text h2 {
			color: #fff;
			font-size: 14px;
			font-weight: 600;
			letter-spacing: 0.1em;
			line-height: 2.4em;
			margin-bottom: 32px;
			text-align: right;
		}
				
		
		
		/*!---------------04 TOPコンテント---------------*/
		
		.top_product {
			width: 100%;
			margin: 32px auto;
			background: rgba(255, 255, 255, 0.883);
			min-height: auto;
			border-top: 1px solid #121212;
			border-bottom: 1px solid #121212;
			
		}
		
		.four {
			width: 33.333%;
			border-left: 1px solid #121212;
			min-height: auto;
			background: #fff;
			padding-bottom: 24px;
		}
		.four:first-child {
			width: 33.333%;
			border-left: none !important;
			border-right: none !important;
			min-height: auto;
		}
		.four:last-child {
			width: 33.333%;
			border-left: 1px solid #121212;
			
			min-height: auto !important;
		}
		.four p {
			margin: 8px auto 8px;
			text-align: center;
			padding: 0 16px;
		}

		
		
		
	}
	
	
	
	
	
	
	

	
	
	
	
	








@media screen and (max-width: 799px){
	.pc {display: none !important;}
	.sp_100 {
		width: 100% !important;
	}

	.hamburger {
		position: fixed;
		top: 34px !important;
		right: 32px !important;
		width: 28px;
		height: 17px;
		z-index: 9999;
		/* アニメーションの変化時間 */
		transition: 0.2s;
	}
	header.scroll-nav .hamburger {
		position: fixed;
		top: 18px !important;
		right: 18px !important;
		width: 28px;
		height: 17px;
		z-index: 9999;
		/* アニメーションの変化時間 */
		transition: 0.5s;
	}
	
	
	.about1 {
		padding: 0 24px;
		width: auto;
	}
	.about1 img {
		max-width: 200px;
		margin-left: auto;
		margin-right: auto;
	}
	.about2 {
		padding: 8px 0 8px 0;
		width: auto;
		margin: 8px 0 0 0;
	}
	
	.footer_news1 {
		padding: 0 24px;
		width: 100%;
	}
	
	.footer_news2 {
		padding: 8px 0 8px 0;
		width: 100%;
		margin: 8px 0 0 0;
	}
	
	
	.four {
		width: 50%;
		border-left: 1px solid #121212;
		min-height: auto;
		background: #fff;
		padding-bottom: 24px;
	}
	.four:first-child {
		width: 50%;
		border-left: none !important;
		border-right: none !important;
		border-bottom: 1px solid #121212;
		min-height: auto;
	}
	.four:nth-child(2) {
		width: 50%;
		border-left: 1px solid #121212;
		border-right: none !important;
		border-bottom: 1px solid #121212;
		min-height: auto;
	}
	.four:nth-child(3) {
		width: 50%;
		border-left: none !important;
		border-right: none !important;
		min-height: auto;
	}
	
	
	.four:last-child {
		width: 50%;
		border-left: none !important;
		border-right: none !important;
		min-height: auto !important;
	}
	.four:nth-child(even) {
		border-left: none !important;
		border-right: 1px solid #121212;
	}
	.four:nth-child(odd) {
		border-left: none !important;
		border-right: none !important;
	}
	.br {
		border-right: none !important;
	}
	
	
	
	
	.four_original {
		width: 50%;
		border-left: 1px solid #121212;
		min-height: auto;
		background: #fff;
		padding-bottom: 24px;
	}
	.four_original:first-child {
		width: 50%;
		border-left: none !important;
		border-right: none !important;
		border-bottom: 1px solid #121212;
		min-height: auto;
	}
	.four_original:nth-child(2) {
		width: 50%;
		border-left: 1px solid #121212;
		border-right: none !important;
		border-bottom: 1px solid #121212;
		min-height: auto;
	}
	.four_original:nth-child(3) {
		width: 50%;
		border-left: none !important;
		border-right: none !important;
		min-height: auto;
	}
	
	
	.four_original:last-child {
		width: 50%;
		border-left: none !important;
		border-right: none !important;
		min-height: auto !important;
	}
	.four_original:nth-child(even) {
		border-left: none !important;
		border-right: 1px solid #121212;
	}
	.four_original:nth-child(odd) {
		border-left: none !important;
		border-right: none !important;
	}
	
	
	.corp_tbl2 {
		width: 100%;
	}
	.corp_tbl2 tr {
		border-bottom: 1px solid #121212;
	}
	.corp_tbl2 th {
		width: 100%;
		padding: 32px 0 8px 16px;
		letter-spacing: 0.08em;
		line-height: 1.7em;
		display: block;
	}
	.corp_tbl2 td {
		padding: 8px 0 16px 16px;
		letter-spacing: 0.08em;
		line-height: 1.7em;
		display: block;
		width: 100%;
	}

}



@media screen and (max-width: 599px){
	
	.fv_text h1 {
	color: #fff;
	font-weight: 400;
	font-size: 10vw !important;
	font-family: "futura-pt-bold", sans-serif;
	font-weight: 700;
	font-style: normal;
	margin-bottom: 32px;
	letter-spacing: 0.04em;
	line-height: 1em;
	text-align: right;
	position: relative;
	left: 64px;
}
	
	.fv_text h2 {
		color: #fff;
		font-size: 12px !important;
		font-weight: 600;
		letter-spacing: 0.1em;
		line-height: 2.4em;
		margin-bottom: 32px;
		text-align: left;
		position: relative;
		left: 40px;
	}
	.fv_text h2 br {
		display: none;
	}
	
	.bg_contact1 {
		background: url(images/bg_contact_01.jpg) no-repeat center center;
		background-size: cover;
		width: 100%;
		height: 160px;
		display: flex;
		justify-content: flex-start;
		align-content: center;
		flex-direction: row;
		flex-wrap: wrap;
		padding: 120px 0;
		border-bottom: 1px solid #fff;
	}
	
	.bg_contact2 {
		background: url(images/bg_contact_02.jpg) no-repeat center center;
		background-size: cover;
		width: 100%;
		height: 160px;
		display: flex;
		justify-content: flex-start;
		align-content: center;
		flex-direction: row;
		flex-wrap: wrap;
		padding: 120px 0;
		border-left: none;
	}
	
	.eq {
		width: 100%;
		padding: 128px;
		background: url(images/top_eq.jpg) no-repeat center center;
		background-size: cover;
		height: 300px;
	}
	
	copyright .ml16 {
		margin: 8px 16px 8px 0;
	}
	
	
	.news_ttl {
		font-family: "futura-pt-bold", sans-serif;
		font-weight: 700;
		font-style: normal;
		font-size: 40px;
		width: auto;
		background: linear-gradient(90deg, #015eea 0%, #00c0fa 100%);
		-webkit-background-clip: text;
		-webkit-text-fill-color: transparent;
		display: inline-block;
		line-height: 1.2em !important;
	}
	
	
	.wrap {
		background: url(images/bg.jpg) no-repeat right center;
		background-size: 200%;
	}
	
	
	.fv2 {
		width: 100%;
		height: 100%;
		margin: 0;
		padding: 0;
		overflow: hidden;
		background: url(images/30th.png) no-repeat left 24px top 100px;
		Background-size: 160px;
	}
	
	
	
	
	
	.four {
		width: 100%;
		border-left: none !important;
		border-right: none !important;
		min-height: auto;
		background: #fff;
		padding-bottom: 24px;
	}
	.four:first-child {
		width: 100%;
		border-left: none !important;
		border-right: none !important;
		border-bottom: 1px solid #121212;
		min-height: auto;
	}
	.four:nth-child(2) {
		width: 100%;
		border-left: 1px solid #121212;
		border-left: none !important;
		border-right: none !important;
		min-height: auto;
	}
	.four:nth-child(3) {
		width: 100%;
		border-left: none !important;
		border-right: none !important;
		min-height: auto;
	}
	
	
	.four:last-child {
		width: 100%;
		border-left: none !important;
		border-right: none !important;
		min-height: auto !important;
	}
	.four:nth-child(even) {
		border-left: none !important;
		border-right: 1px solid #121212;
	}
	.four:nth-child(odd) {
		border-left: none !important;
		border-right: none !important;
	}
	.br {
		border-right: none !important;
	}
	.four p {
		font-size: 12px !important;
	}
	
	
	
	
}
