/*
Theme Name: qcraft_japan
*/


@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;600;700&family=Zen+Antique&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&display=swap');


html {
 margin-top: 0px !important;
}

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, pre,
abbr, address, cite, code,
del, dfn, img, ins, kbd, q, samp,
small, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
	padding: 0;
	border: 0;
	outline: 0;
	vertical-align: baseline;
	background: transparent;
	font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック","メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.6em;
	margin-top: 0;
	margin-right: 0;
	margin-bottom: 0;
	margin-left: 0;
	color: #333;
	font-size: 15px;
	font-weight: 400;
	letter-spacing: 1px;
}

em {
	font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック","メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color: #333;
	font-size: 15px;
	font-style: italic;	
}

body {
    line-height:1;
	-webkit-text-size-adjust: 100%;
}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section { 
    display:block;
}
nav ul {
    list-style:none;
}

a {
    margin:0;
    padding:0;
    font-size:100%;
    vertical-align:baseline;
    background:transparent;
	text-decoration: none;
	color: #333;
}
/* change colours to suit your needs */
ins {
    background-color:#ff9;
    color:#000;
    text-decoration:none;
}
/* change colours to suit your needs */
mark {
    background-color:#ff9;
    color:#000; 
    font-style:italic;
    font-weight:bold;
}
del {
    text-decoration: line-through;
}
abbr[title], dfn[title] {
    border-bottom:1px dotted;
    cursor:help;
}
table {
   /* border-collapse:collapse;*/
    border-spacing:0;
}
/* change border colour to suit your needs */
hr {
    display:block;
    height:1px;
    border:0;   
    border-top:1px solid #cccccc;
    margin:1em 0;
    padding:0;
}
input, select {
    vertical-align:middle;
}

li {
	list-style: none;	
}

img {
	vertical-align: bottom;
	max-width: 100%;
	height: auto;
}

/*end reset*/

/* ----------------------------------------------------
    text
---------------------------------------------------- */

.serif {
	font-family: "Noto Serif JP", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "游明朝","ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.sans-serif {
	font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック","メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.lato {
	font-family: 'Lato', sans-serif;
}



.tc {text-align: center !important;}
.tr {text-align: right !important;}
.tl {text-align: left !important;}

.bold {font-weight:bold;}
 
.font10{font-size:10px !important;}
.font11{font-size:11px !important;}
.font12{font-size:12px !important;}
.font13{font-size:13px !important;}
.font14{font-size:14px !important;}
.font15{font-size:15px !important;}
.font16{font-size:16px !important;}
.font17{font-size:17px !important;}
.font18{font-size:18px !important;}
.font19{font-size:19px !important;}
.font20{font-size:20px !important;}
.font21{font-size:21px !important;}
.font22{font-size:22px !important;}
.font23{font-size:23px !important;}
.font24{font-size:24px !important;}
.font25{font-size:25px !important;}
.font26{font-size:26px !important;}
.font27{font-size:27px !important;}
.font28{font-size:28px !important;}
.font29{font-size:29px !important;}
.font30{font-size:30px !important;}
.font32{font-size:32px !important;}
.font34{font-size:34px !important;}
.font36{font-size:36px !important;}
.font40{font-size:40px !important;}
 
/* ----------------------------------------------------
    float
---------------------------------------------------- */
.fr {float: right !important;}
.fl {float: left !important;}
 
.clear {clear: both;}
 
.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
 
.clearfix {
  min-height: 1px;
}
 
* html .clearfix {
  height: 1px;
  /*¥*//*/
  height: auto;
  overflow: hidden;
  /**/
}
 

/* ----------------------------------------------------
    margin
---------------------------------------------------- */
 
.mt00 { margin-top:  0px !important; }
.mt05 { margin-top:  5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt35 { margin-top: 35px !important; }
.mt40 { margin-top: 40px !important; }
.mt50 { margin-top: 50px !important; }
.mt60 { margin-top: 60px !important; }
.mt80 { margin-top: 80px !important; }
 
.mr00 { margin-right:  0px !important; }
.mr05 { margin-right:  5px !important; }
.mr10 { margin-right: 10px !important; }
.mr15 { margin-right: 15px !important; }
.mr20 { margin-right: 20px !important; }
.mr25 { margin-right: 25px !important; }
.mr30 { margin-right: 30px !important; }
.mr35 { margin-right: 35px !important; }
.mr40 { margin-right: 40px !important; }
.mr50 { margin-right: 50px !important; }
.mr60 { margin-right: 60px !important; }
.mr65 { margin-right: 65px !important; }
 
.mb00 { margin-bottom:  0px !important; }
.mb05 { margin-bottom:  5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb35 { margin-bottom: 35px !important; }
.mb40 { margin-bottom: 40px !important; }
.mb50 { margin-bottom: 50px !important; }
.mb55 { margin-bottom: 55px !important; }
.mb60 { margin-bottom: 60px !important; }
.mb70 { margin-bottom: 70px !important; }
.mb76 { margin-bottom: 76px !important; }
.mb80 { margin-bottom: 80px !important; }
.mb90 { margin-bottom: 90px !important; }
.mb100 { margin-bottom: 100px !important; }
 
.ml00 { margin-left:  0px !important; }
.ml05 { margin-left:  5px !important; }
.ml10 { margin-left: 10px !important; }
.ml15 { margin-left: 15px !important; }
.ml20 { margin-left: 20px !important; }
.ml25 { margin-left: 25px !important; }
.ml30 { margin-left: 30px !important; }
.ml35 { margin-left: 35px !important; }
.ml40 { margin-left: 40px !important; }
 
/* ----------------------------------------------------
    padding
---------------------------------------------------- */
 
.pt00 { padding-top:  0px !important; }
.pt05 { padding-top:  5px !important; }
.pt10 { padding-top: 10px !important; }
.pt15 { padding-top: 15px !important; }
.pt20 { padding-top: 20px !important; }
.pt25 { padding-top: 25px !important; }
.pt30 { padding-top: 30px !important; }
.pt35 { padding-top: 35px !important; }
.pt40 { padding-top: 40px !important; }
.pt80 { padding-top: 80px !important; }
 
.pr00 { padding-right:  0px !important; }
.pr05 { padding-right:  5px !important; }
.pr10 { padding-right: 10px !important; }
.pr15 { padding-right: 15px !important; }
.pr20 { padding-right: 20px !important; }
.pr25 { padding-right: 25px !important; }
.pr30 { padding-right: 30px !important; }
.pr35 { padding-right: 35px !important; }
.pr40 { padding-right: 40px !important; }
 
.pb00 { padding-bottom:  0px !important; }
.pb05 { padding-bottom:  5px !important; }
.pb10 { padding-bottom: 10px !important; }
.pb15 { padding-bottom: 15px !important; }
.pb20 { padding-bottom: 20px !important; }
.pb25 { padding-bottom: 25px !important; }
.pb30 { padding-bottom: 30px !important; }
.pb35 { padding-bottom: 35px !important; }
.pb40 { padding-bottom: 40px !important; }
 
.pl00 { padding-left:  0px !important; }
.pl05 { padding-left:  5px !important; }
.pl10 { padding-left: 10px !important; }
.pl15 { padding-left: 15px !important; }
.pl20 { padding-left: 20px !important; }
.pl25 { padding-left: 25px !important; }
.pl30 { padding-left: 30px !important; }
.pl35 { padding-left: 35px !important; }
.pl40 { padding-left: 40px !important; }






/* ----------------------------------------------------

    common

---------------------------------------------------- */


/* IE10以前でのみ有効 */
html {
height: 100%\9;
overflow: hidden\9;
}
body {
height: 100%\9;
overflow: scroll\9;
}
/* IE10以降でのみ有効 */
@media all and (-ms-high-contrast: none) {
	html {
		height: 100%;
		overflow: hidden;
	}
	body {
		height: 100%;
		overflow-y: scroll;
		overflow-x: hidden;
	}
}

.sec_in1000 {
	max-width: 1000px;
	width: 90%;
	margin: auto;
	position: relative;
}



.sec_in1200 {
	max-width: 1200px;
	width: 90%;
	margin: auto;
	position: relative;
}

.sec_in1300 {
	max-width: 1300px;
	width: 90%;
	margin: auto;
	position: relative;
}

.sec_in1400 {
	max-width: 1400px;
	width: 90%;
	margin: auto;
	position: relative;
}

.overflow-h {overflow: hidden;}

.object-fit-img {
  object-fit: contain;
  font-family: 'object-fit: contain;';
}

body {
	overflow-x: hidden;
	transition: .3s;
	position: relative;
}





.page_wrap01 {padding: 120px 0 100px;}


.error404 .page-title {
	font-size: 24px;
	font-weight: bold;
	color: #222;
	text-align: center;
	margin-bottom: 30px;
}

.error404 .page-content {
	text-align: center;
}

.error404 .page-content p {
	margin-bottom: 20px;
}

.error404 input[type="search"] {
	font-size: 16px;
	box-sizing: border-box;
	padding: 10px;
	border: solid 1px #ccc;
	width: 86%;
}

.error404 input[type="submit"] {
	box-sizing: border-box;
	padding: 9px;
	font-size: 16px;
	text-align: center;
	color: #fff;
	background: #333;
	border: none;
	width: 13%;
	cursor: pointer;
}

.error404 .b_contact::after {width: 100%;}

.search .page-content p {
	margin-bottom: 20px;
}

.search input[type="search"] {
	font-size: 16px;
	box-sizing: border-box;
	padding: 10px;
	border: solid 1px #ccc;
	width: 86%;
}

.search input[type="submit"] {
	box-sizing: border-box;
	padding: 9px;
	font-size: 16px;
	text-align: center;
	color: #fff;
	background: #333;
	border: none;
	width: 13%;
	cursor: pointer;
}

.search .page-title {
	font-size: 24px;
	font-weight: bold;
	color: #222;
	text-align: center;
	margin-bottom: 30px;
}

.search article {
	padding-bottom: 30px;
	margin-bottom: 30px;
	border-bottom: solid 1px #ddd;
}

.search article .entry-title a {
	display: block;
	font-size: 20px;
	font-weight: bold;
	color: #222;
	margin-bottom: 10px;
}

.search article .entry-meta {display: none;}

.search article .entry-summary p {
	color: #999;
}

.search .post-thumbnail {
	display: block;
	padding-bottom: 20px;
}




/*代表挨拶*/
.page_img_bg_about {background-image: url("images/about/page_img.jpg");}






.breadcrumbs {
	width: 92%;
	margin: auto;
	box-sizing: border-box;
	padding: 20px 0;
}

.breadcrumbs p {
	font-size: 14px;
	letter-spacing: 2px;
	color: #999;
	line-height: 1.3;
	text-align: right;
}

.breadcrumbs span {
	font-size: 14px;
	letter-spacing: 2px;
	color: #999;
	line-height: 1.3;
}

.breadcrumbs span a {
	font-size: 14px;
	letter-spacing: 2px;
	color: #999;
	line-height: 1.3;
	text-decoration: underline;
}

.breadcrumbs span a:hover {
	text-decoration: none;
	color: #71b383;
}




.page_wrap {padding: 100px 0;}




@media screen and ( max-width:991px ){
	.breadcrumbs p {font-size: 12px; letter-spacing: 1px;}
	.breadcrumbs span {font-size: 12px; letter-spacing: 1px;}
	.breadcrumbs span a {font-size: 12px; letter-spacing: 1px;}
	.breadcrumbs {width: 91%;}
	
	
	.page_wrap {padding: 60px 0;}

}




.blog_pages {
	text-align: center;
	min-height: 30px;
	margin-bottom: 30px;
	margin-top: 40px;
}

.blog_pages .page-numbers {
    border: solid 1px #71b383;
    padding: 4px 10px 4px;
    font-size: 15px;
    margin-right: 1px;
    color: #71b383;
	box-sizing: border-box;
}

.blog_pages .prev {
	padding: 4px 8px 4px;
}

.blog_pages .next {
	padding: 4px 8px 4px;
}

.blog_pages .current {
    border: solid 1px #71b383;
    padding: 4px 10px 4px;
    font-size: 15px;
    margin-right: 1px;
    color: #fff;
	background: #71b383;
	box-sizing: border-box;
}

a.page-numbers:hover {
	color: #fff;
	background: #71b383;
}




/* ----------------------------------------------------

    header

---------------------------------------------------- */

header {
	position: relative;
	
}

.header_top {
	overflow: hidden;
	padding: 25px 0 0;
	box-sizing: border-box;
	width: 100%;
	min-height: 80px;
	position: absolute;
	top: 0;
	z-index: 9500;
	transition: .3s;
}

.header_top.fixed {
	position: fixed;
	background: rgba(0,0,0,0.6);
	padding: 15px 0 10px;
	min-height: 60px;
	backdrop-filter: blur(10px);
}

.header_left {
	float: left;
	max-width: 200px;
	opacity: 1;
	visibility: visible;
	transition: .3s;
	padding-top: 18px;
	padding-left: 2.5%;
}
.header_left.hidden {opacity: 0;}

.header_top.fixed .header_left {
	padding-top: 0;
	padding-left: 25px;
	max-width: 130px;
}


.header_right {
	float: right;
	width: 70%;
	max-width: 680px;
	box-sizing: border-box;
	overflow: hidden;
	padding: 20px 40px 0 10px;
	transition: .3s;
}

.header_top.fixed .header_right {padding-top: 13px;}

.header_right01 {
	float: right;
}


.header_right nav ul {overflow: hidden;}
.header_right nav li {float: left;}
.header_right nav li a {
	box-sizing: border-box;
	padding: 2px 25px;
	font-size: 21px;
	letter-spacing: 0;
	line-height: 1.2;
	color: #fff;
	font-weight: 400;
	transition: .3s;
	text-shadow: 0 0 5px rgba(0,0,0,0.8);
}

.header_right nav li:nth-of-type(1) a {padding-left: 0;}
.header_right nav li:last-of-type a {padding-right: 0;}

.header_right nav li a:hover {color: #71b383;}

.home .header_right nav .nav_home a {color: #71b383;}
.page-template-page-about .header_right nav .nav_about a {color: #71b383;}
.page-template-page-technology .header_right nav .nav_technology a {color: #71b383;}
.page-id-13 .header_right nav .nav_news a {color: #71b383;}

.nav02 {
	width: 80px;
    height: 80px;
    background: #222;
    position: fixed;
    right: 30px;
    top: 30px;
	box-sizing: border-box;
	z-index: 99999;
	padding: 11px 0 19px;
	cursor: pointer;
}

.main_img_wrap {
	position: relative;
	width: 100%;
	height: 100vh;
}

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

.main_text {
	max-width: 920px;
	width: 90%;
	margin: auto;
	position: absolute;
	left: 0;
	right: 0;
	top: 39%;
	z-index: 100;
	text-align: center;
}

.main_text h2 {
	font-size: 80px;
	font-weight: 900;
	/*color: #fff;
	text-shadow: 1px 1px 10px rgba(0,0,0,0.9);*/
	padding-bottom: 10px;
	letter-spacing: 0;
}

.main_text h3 {
	font-size: 30px;
	font-weight: 700;
	color: #fff;
	text-shadow: 1px 1px 10px rgba(0,0,0,0.9);
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.main_text.show h3 {transform: translateY(0); opacity: 1;}

.main_text h2 span {
	font-size: 1em;
	font-weight: 900;
	color: #fff;
	text-shadow: 1px 1px 10px rgba(0,0,0,0.9);
	letter-spacing: 0;
	display: inline-block;
}
.animate span:nth-of-type(1) {
	animation-delay: .45s;
}
.animate span:nth-of-type(2) {
	animation-delay: .5s;
}
.animate span:nth-of-type(3) {
	animation-delay: .55s;
}
.animate span:nth-of-type(4) {
	animation-delay: .6s;
}
.animate span:nth-of-type(5) {
	animation-delay: .65s;
}
.animate span:nth-of-type(6) {
	animation-delay: .7s;
}
.animate span:nth-of-type(7) {
	animation-delay: .75s;
}
.animate span:nth-of-type(8) {
	animation-delay: .8s;
}
.animate span:nth-of-type(9) {
	animation-delay: .85s;
}
.animate span:nth-of-type(10) {
	animation-delay: .9s;
}
.animate span:nth-of-type(11) {
	animation-delay: .95s;
}
.animate span:nth-of-type(12) {
	animation-delay: 1s;
}
.animate span:nth-of-type(13) {
	animation-delay: 1.05s;
}
.animate span:nth-of-type(14) {
	animation-delay: 1.1s;
}
.animate span:nth-of-type(15) {
	animation-delay: 1.15s;
}
.animate span:nth-of-type(16) {
	animation-delay: 1.2s;
}
.animate span:nth-of-type(17) {
	animation-delay: 1.25s;
}
.animate span:nth-of-type(18) {
	animation-delay: 1.3s;
}
.animate span:nth-of-type(19) {
	animation-delay: 1.35s;
}
.animate span:nth-of-type(20) {
	animation-delay: 1.4s;
}
.animate span:nth-of-type(21) {
	animation-delay: 1.45s;
}
.animate span:nth-of-type(22) {
	animation-delay: 1.5s;
}
.animate span:nth-of-type(23) {
	animation-delay: 1.55s;
}
.animate span:nth-of-type(24) {
	animation-delay: 1.6s;
}

.seven span {
	color: #fff;
	opacity: 0;
	transform: translate(-150px, 0) scale(.3);
	animation: leftRight .5s forwards;
}

.text_yellow {color: #fff000 !important;}


@keyframes leftRight {
	40% {
		transform: translate(50px, 0) scale(.7);
		opacity: 1;
		color: #fff;
	}

	60% {
		color: #71b383;
	}

	80% {
		transform: translate(0) scale(2);
		opacity: 0;
	}

	100% {
		transform: translate(0) scale(1);
		opacity: 1;
	}
}






.menu-trigger,
.menu-trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}
.menu-trigger {
	position: relative;
	width: 100%;
    height: 100%;
	
	box-sizing: border-box;
}
.menu-trigger span {
	position: absolute;
	left: 0;
    right: 0;
    margin: auto;
	width: 30px;
	height: 1px;
	background-color: #fff;
	border-radius: 0;
}
.menu-trigger span:nth-of-type(1) {
	top: 20px;
	transform: translateY(-3px);
	transition: .2s;
}
.menu-trigger span:nth-of-type(2) {
	top: 24px;
}
.menu-trigger span:nth-of-type(3) {
	bottom: 21px;
	transform: translateY(3px);
	transition: .2s;
}

.nav02:hover span:nth-of-type(1) {
	transform: translateY(0);
}

.nav02:hover span:nth-of-type(3) {
	transform: translateY(0);
}

.menu-trigger.active {
	transition: .3s;
}

.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(4px) rotate(-45deg);
	transform: translateY(4px) rotate(-45deg);
	width: 30px;
}
.menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
}
.menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(-4px) rotate(45deg);
	transform: translateY(-4px) rotate(45deg);
	width: 30px;
}

.menu-trigger p {
	text-align: center;
    font-size: 10px;
    color: #fff;
    letter-spacing: 0;
	position: absolute;
	bottom: 0;
	width: 30px;
	left: 0;
	right: 0;
	margin: auto;
}







.sp_menu_wrap {
	overflow: scroll;
    position: fixed;
    top: 0;
    z-index: 8000;
	margin: auto;
    color: #111;
    text-align: center;
	width: 100%;
    height: 100vh;
    /*padding: 10vh 10px 10vh;*/
	box-sizing: border-box;
	transition: .3s;
	opacity: 0;
	visibility: hidden;
	margin-right: 110px;
	background: #222;
}

.sp_menu_wrap.open {
	opacity: 1;
	visibility: visible
}

/*.sp_menu_left {
	width: 50%;
	position: -webkit-sticky;
	position: sticky;
	height: 100vh;
	top:0;
	float: left;
}

.sp_menu_left img {
	object-fit: cover;
	width: 100%;
	height: 100vh;
}*/

.sp_menu_box {
	box-sizing: border-box;
	/*float: right;*/
	width: 100%;
	padding-top: 14vh;
	padding-bottom: 14vh
}

.sp_menu_in {
	max-width: 400px;
	width: 90%;
	margin: auto;
}

.sp_menu_in h2 {text-align: center; margin-bottom: 80px;}
.sp_menu_in ul {margin-bottom: 80px;}
.sp_menu_in li {margin-bottom: 90px;}
.sp_menu_in li a {
	font-size: 28px;
	letter-spacing: 5px;
	line-height: 1.3;
	color: #fff;
}

.sp_menu_in li a span {
	text-align: center;
	display: block;
	font-size: 12px;
	color: #999;
}

.sp_menu_in li a:hover {
	color: #71b383;
}

.sp_menu_in li a:hover span {
	color: #71b383;
}

.sp_menu_info h4 {font-size: 18px; padding-bottom: 15px; color: #999;}

.sp_menu_info p {
	font-size: 15px;
	line-height: 1.6;
	text-align: center;
	margin-bottom: 40px;
	color: #999;
}

.sp_copy {
	text-align: center;
	font-size: 12px;
	letter-spacing: 2px;
	line-height: 1.3;
	color: #999;
}

.sp_menu_btn {margin-bottom: 40px;}

.sp_menu_btn a {
	display: block;
	max-width: 400px;
	width: 100%;
	margin: auto;
	box-sizing: border-box;
	background: #dccd59;
	padding: 20px 10px;
	text-align: center;
	font-size: 16px;
	color: #222;
	transition: .3s;
}

.sp_menu_btn a img {
	padding-right: 10px;
	transition: .3s;
}

.sp_menu_btn a:hover {
	background: #b20000;
	color: #fff;
}

.sp_menu_btn a:hover img {
	filter: invert(100%);
}

.sp_menu_sns {margin: 30px 0 40px;}

.sp_menu_sns h4 a {
	display: block;
	width: 30px;
	margin: auto;
}




/* ----------------------------------------------------

    top

---------------------------------------------------- */

.top01 {
	padding: 90px 0;
	background-image: url("images/top/top_bg01.jpg");
	background-repeat: no-repeat;
	background-position: center top;
	background-size: cover;
	position: relative;
}

.top01::after {
	display: block;
	content: "";
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.1);
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}

.top01 .sec_in1200 {
	position: relative;
	z-index: 10;
}

.top01_in01 {margin-bottom: 40px;}

.top01_box {margin-bottom: 30px;}
.top01 h2 {
	font-size: 32px;
	font-weight: 600;
	color: #fff;
	display: block;
	margin-bottom: 20px;
	line-height: 1.4;
	text-shadow: 0 0 10px #000, 0 0 10px #000, 0 0 10px #000, 0 0 10px #000;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: .4s;
}
.top01 .top01_box.show h2 {transform: translateY(0); opacity: 1;}
.top01 .top01_in02.show h2 {transform: translateY(0); opacity: 1;}

.top01 h3 {
	font-size: 22px;
	font-weight: 600;
	color: #fff;
	line-height: 1.4;
	text-shadow: 0 0 10px #000, 0 0 10px #000, 0 0 10px #000, 0 0 10px #000;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: .45s;
}
.top01 .top01_box.show h3 {transform: translateY(0); opacity: 1;}

.top01_box p {
	font-size: 17px;
	color: #fff;
	line-height: 1.7;
	text-shadow: 0 0 10px #000, 0 0 10px #000, 0 0 10px #000, 0 0 10px #000;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: .5s;
}
.top01 .top01_box.show p {transform: translateY(0); opacity: 1;}

.top01 ol li {
	font-size: 17px;
	color: #fff;
	line-height: 1.7;
	margin-left: 1.3em;
	list-style: decimal;
	text-shadow: 0 0 10px #000, 0 0 10px #000, 0 0 10px #000, 0 0 10px #000;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: .5s;
}
.top01 .top01_box.show ol li {transform: translateY(0); opacity: 1;}

.top01_in02 {padding-top: 30px;}

.top01_in02_box {
	float: left;
	width: 46%;
	margin: 0 2%;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: .5s;
}
.top01_in02_box:nth-of-type(2) {transition-delay: .6s;}

.top01_in02.show .top01_in02_box {transform: translateY(0); opacity: 1;}

.top01_in02_box h4 {display: block; margin-bottom: 10px;}
.top01_in02_box p {font-size: 16px; line-height: 1.5; text-align: center; color: #fff; text-shadow: 0 0 10px #000, 0 0 10px #000, 0 0 10px #000, 0 0 10px #000;}







/* ----------------------------------------------------

    footer

---------------------------------------------------- */

footer {
	background: #251e1c;
	padding: 90px 0 70px;
}

.footer_in {
	width: 88%;
	margin: auto;
}

.footer_contact {
	max-width: 1200px;
	width: 100%;
	margin: 0 auto 50px;
}

.footer_contact h2 {
	font-size: 32px;
	font-weight: 500;
	line-height: 1.4;
	color: #fff;
	margin-bottom: 20px;
	text-align: center;
}

.footer_contact p {
	font-size: 17px;
	line-height: 1.6;
	color: #fff;
	text-align: center;
}

.footer_contact p a {font-size: 1em; color: #fff;}
.footer_contact p a:hover {color: #71b383;}
.footer_bottom {overflow: hidden;}

.footer_bottom h2 {float: left; padding-right: 30px;}
.copyright {float: left; font-size: 13px; letter-spacing: 0; color: #878788; line-height: 1.4; padding-top: 15px;}



.footer_contact_box {
	max-width: 500px;
	margin: 0 auto 30px;
	padding-top: 40px;
}
.footer_contact_box ul {margin-bottom: 3px;}
.footer_contact_box li {margin-bottom: 15px;}
.footer_contact_box li:nth-of-type(2) {margin-bottom: 8px;}
.footer_contact_box li input {
	font-size: 17px;
	box-sizing: border-box;
	width: 100%;
	padding: 20px;
	border-radius: 50px;
	background: #403d3c;
	color: #fff;
	line-height: 1.3;
	border: none;
}

.footer_contact_box li input::placeholder {color: #fff;}

.footer_contact_box li textarea {
	font-size: 17px;
	box-sizing: border-box;
	width: 100%;
	padding: 20px;
	border-radius: 50px;
	background: #403d3c;
	color: #fff;
	line-height: 1.3;
	border: none;
	height: 3.7em;
}
.footer_contact_box li textarea::placeholder {color: #fff;}

.contact_btn input[type="submit"] {
	width: 100%;
	box-sizing: border-box;
	font-size: 18px;
	letter-spacing: 2px;
	padding: 20px;
	border-radius: 50px;
	background: #71b383;
	color: #fff;
	line-height: 1.2;
	transition: .3s;
	cursor: pointer;
	border: none;
}

.contact_btn input[type="submit"]:hover {
	background: #5fb7d6;
}

.grecaptcha-badge { visibility: hidden; }


@media screen and ( max-width:567px ){
	.footer_contact_box li input {font-size: 16px;}
	.footer_contact_box li textarea {font-size: 16px;}
	.contact_btn input[type="submit"] {font-size: 16px;}
}





/* ----------------------------------------------------

    about

---------------------------------------------------- */

.text_green {color: #71b383 !important;}

.about01 {padding: 60px 0;}

.about01_in {
	max-width: 1200px;
	width: 88%;
	margin: auto;
}

.page_title01 {
	display: inline-block;
	font-size: 34px;
	font-weight: 600;
	line-height: 1.3;
	padding: 10px 0 10px 46px;
	background-image: url("images/about/title_icon01.png");
	background-repeat: no-repeat;
	background-size: 40px;
	background-position: left center;
}

.about01_in02 {
	max-width: 700px;
	width: 80%;
	margin: auto;
	position: relative;
	bottom: 30px;
}

.about02 {padding-bottom: 50px;}

.about02_in {
	max-width: 1200px;
	width: 88%;
	margin: auto;
}

.about02_box {margin-bottom: 80px;}

.about02_box_img {
	width: 52%;
	max-width: 650px;
	float: left;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: .5s;
}
.about02_box.show .about02_box_img {
	opacity: 1;
	transform: translateY(0);
}

.about02_box_text {
	float: right;
	width: 43%;
	padding-top: 20px;
}

.about02_box_text h3 {
	font-size: 28px;
	font-weight: 600;
	line-height: 1.3;
	color: #71b383;
	padding-bottom: 25px;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: .6s;
}
.about02_box.show .about02_box_text h3 {
	opacity: 1;
	transform: translateY(0);
}

.about02_box_text dl {
	display: table;
	width: 100%;
	margin-bottom: 15px;
	transform: translateY(100px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	transition-delay: .7s;
}
.about02_box.show .about02_box_text dl {
	opacity: 1;
	transform: translateY(0);
}

.about02_box_text dt {
	display: table-cell;
	width: 1em;
	font-size: 20px;
	color: #71b383;
	line-height: 1;
	vertical-align: top;
	box-sizing: border-box;
	position: relative;
	top: 4px;
}

.about02_box_text dd {
	display: table-cell;
	font-size: 18px;
	line-height: 1.6;
	vertical-align: top;
	box-sizing: border-box;
	padding-left: 3px;
}

.about02_box_text dd span {
	font-size: 1em;
	font-weight: 600;
}


.about03 {
	background: #36454B;
	background: -webkit-linear-gradient(top left, rgba(54, 69, 75, 1) 0%, rgba(27, 35, 40, 1) 100%);
	background: -o-linear-gradient(top left, rgba(54, 69, 75, 1) 0%, rgba(27, 35, 40, 1) 100%);
	background: linear-gradient(to bottom right, rgba(54, 69, 75, 1) 0%, rgba(27, 35, 40, 1) 100%);
	padding: 80px 0;
}

.about03 .page_title01 {color: #fff; margin-bottom: 20px;}

.about03_left {
	width: 62%;
	float: left;
}

.about03_right {
	width: 32%;
	float: right;
	max-width: 420px;
}

.about03_left dl {display: block; width: 100%; margin-bottom: 20px;}
.about03_left dt {
	font-size: 18px;
	font-weight: 600;
	color: #fff;
	line-height: 1.5;
}

.about03_left dd {
	font-size: 18px;
	color: #fff;
	line-height: 1.5;
}

.about03_b_text h3 {
	display: block;
	font-size: 24px;
	color: #fff;
	font-weight: 600;
	line-height: 1.3;
}

.about04 {
	padding: 90px 0 70px;
}

.about04_in {padding-top: 30px;}

.about04_bnr {
	float: left;
	width: 25%;
	margin: 0 0 50px;
	transform: translateY(70px);
	opacity: 0;
	transition: all 1s cubic-bezier(0.215, 0.61, 0.355, 1);
	
}

.about04_bnr:nth-of-type(1) {transition-delay: .4s;}
.about04_bnr:nth-of-type(2) {transition-delay: .5s;}
.about04_bnr:nth-of-type(3) {transition-delay: .6s;}
.about04_bnr:nth-of-type(4) {transition-delay: .7s;}
.about04_bnr:nth-of-type(5) {transition-delay: .8s;}
.about04_bnr:nth-of-type(6) {transition-delay: .9s;}
.about04_bnr:nth-of-type(7) {transition-delay: 1s;}
.about04_bnr:nth-of-type(8) {transition-delay: 1.1s;}


.about04.show .about04_bnr {
	opacity: 1;
	transform: translateY(0);
}

.about05 {
	padding: 90px 0 0;
	background-image: url("images/about/bg01.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
}

.about05 .page_title01 {color: #fff;}

.about05_in01 {padding: 30px 0 60px;}

.about05_box {
	float: left;
	width: 23%;
	margin: 0 1%;
	box-sizing: border-box;
	border: solid 5px #71b383;
	padding: 20px 10px 10px;
	text-align: center;
	background: #fff;
	min-height: 220px;
}

.about05_box_no {
	padding-bottom: 10px;
}

.about05_box_no p.number {
	font-size: 110px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	color: #71b383;
	display: inline-block;
}

.about05_box_no span {
	font-size: 50px;
	font-weight: 900;
	line-height: 1;
	color: #71b383;
}

.about05_box p {
	font-size: 17px;
	letter-spacing: 0;
	line-height: 1.3;
	text-align: center;
}

.about05_in02_left {
	float: left;
	width: 30%;
	padding-top: 50px;
}

.about05_in02_right {
	float: right;
	width: 70%;
}

.about05_title {
	text-align: center;
}

.about05_title p {
	font-size: 19px;
	font-weight: 600;
	line-height: 1.3;
	color: #fff;
	padding-bottom: 10px;
}

.about05_title h2 {
	font-size: 60px;
	font-weight: 900;
	line-height: 1;
	color: #fff;
}

.page_title01 span {font-size: 0.6em; font-weight: 600; letter-spacing: 0; padding-left: 20px;}

.about06 {padding: 70px 0;}

.about06_title {
	background: #71b383;
	border-radius: 10px;
	box-sizing: border-box;
	padding: 20px 30px;
	margin-bottom: 40px;
	margin-top: 30px;
}

.about06_title p {
	font-size: 20px;
	font-weight: 600;
	line-height: 1.1;
	color: #fff;
}

.about06_title h3 {
	font-size: 44px;
	font-weight: 900;
	line-height: 1.1;
	color: #fff;
	letter-spacing: 0;
}

.about06_title h3 span {
	font-size: 1.3em;
	font-weight: 900;
	letter-spacing: 0;
	color: #fff;
	line-height: 1.1;
}

.about06_box {margin-bottom: 50px;}

.about06_box_dl01 {display: table; width: 100%;}
.about06_box_dl01 > dt {
	display: table-cell;
	width: 64%;
	box-sizing: border-box;
	padding-right: 3%;
	position: relative;
	vertical-align: top;
	overflow: hidden;
}

.about06_box_dl01 > dt::before {
	display: block;
	content: "";
	width: 4px;
	height: 100%;
	background: #71b383;
	position: absolute;
	top: 10px;
	left: 10px;
}

.about06_box_dl01 > dd {
	display: table-cell;
	width: 36%;
	box-sizing: border-box;
	vertical-align: top;
}

.about06_box_dl01 > dd img {
	object-fit: cover;
	width: 100%;
	height: 280px;
}
.about06_box02 .about06_box_dl01 > dd img {height: 250px;}
.about06_box03 .about06_box_dl01 > dd img {height: 230px;}
.about06_box04 .about06_box_dl01 > dd img {height: 250px;}

.about06_box_dl01 > dt h3 {
	font-size: 28px;
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: 0;
}

.about06_box_dl01 > dt h3 span {
	display: inline-block;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background:#71b383;
	margin-right: 12px;
	position: relative;
	top: 1px;
}

.about06_box_in {
	padding: 0 20px 10px 50px;
	box-sizing: border-box;
}

.about06_box_dl02 {padding-top: 20px;}
.about06_box_dl02 dt {
	font-size: 20px;
	line-height: 1.2;
	font-weight: 600;
	letter-spacing: 0;
}
.about06_box_dl02 dd {
	font-size: 17px;
	line-height: 1.5;
}

.about06_box_in_b_text {font-size: 18px; line-height: 1.3; text-align: right; padding-top: 20px; letter-spacing: 0;}

.about07 {
	padding: 70px 0;
	background: #71B383;
	background: -webkit-linear-gradient(top left, rgba(113, 179, 131, 1) 0%, rgba(31, 66, 29, 1) 100%);
	background: -o-linear-gradient(top left, rgba(113, 179, 131, 1) 0%, rgba(31, 66, 29, 1) 100%);
	background: linear-gradient(to bottom right, rgba(113, 179, 131, 1) 0%, rgba(31, 66, 29, 1) 100%);
}

.about07 .page_title01 {color: #fff;}
.about07 .about06_title h3 {font-size: 36px; line-height: 1.3;}


.about08 {
	padding: 80px 0;
	background-image: url("images/about/bg03.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center 99%;
}


.about08_box {
	float: left;
	width: 49%;
	margin: 0 0.5%;
	background-image: url("images/about/bg02.png");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center 100px;
	box-sizing: border-box;
	padding: 0 30px 50px;
}

.about08_box_img {margin-bottom: 10px;}

.about08_box h3 {
	display: block;
	text-align: center;
	font-size: 38px;
	font-weight: 900;
	letter-spacing: 0;
	line-height: 1.2;
	padding-bottom: 10px;
	margin-bottom: 25px;
	box-sizing: border-box;
	border-bottom: solid 1px #ccc;
	color: #7cda85;
}

.about08_box_text {
	max-width: 400px;
	width: 100%;
	margin: auto;
}

.about08_box_text p {
	font-size: 22px;
	line-height: 2em;
	color: #fff;
	letter-spacing: 0;
	margin-bottom: 20px;
	font-weight: 500;
}

.about08_box_text p span {
	font-size: 1.5em;
	color: #fff;
	letter-spacing: 0;
	font-weight: 500;
}

.about08_box_icon {
	max-width: 400px;
	width: 100%;
	margin: auto;
}



@media screen and ( max-width:1366px ){
	.about02_box_img {width: 46%;}
	.about02_box_img img {object-fit: cover; width: 100%; height: 340px;}
	.about02_box_text {width: 50%;}
	.about02_box_text dl {margin-bottom: 10px;}
	.about02_box_text dt {font-size: 17px;}
	.about02_box_text dd {font-size: 16px; line-height: 1.5;}
	
	.about05_box_no p.number {font-size: 82px; letter-spacing: -3px;}
	.about05_box_no span {font-size: 40px; padding-left: 3px;}
	.about05_box {min-height: 180px; padding: 12px 6px 10px;}
	.about05_box p {font-size: 16px;}
	
	.about06_title h3 {font-size: 40px;}
	
	.about07 .about06_title h3 {font-size: 30px;}
}

@media screen and ( max-width:1199px ){
	.about06_title h3 {font-size: 34px; line-height: 1.3;}
	.about06_title h3 span {font-size: 1.2em;}
	
	.about08_box h3 {font-size: 32px;}
	.about08_box_text p {font-size: 18px;}
	.about08_box_text p span {font-size: 1.4em;}
}


@media screen and ( max-width:991px ){
	.about01_in02 {max-width: 500px; bottom: 0;}
	.about02_box_text h3 {font-size: 24px; padding-bottom: 15px;}
	.about02_box_text {padding-top: 0;}
	.about02_box_img img {height: 280px;}
	.about02_box {margin-bottom: 50px;}
	
	.about04 {padding: 50px 0 30px;}
	
	.about05_box {border: solid 3px #71b383; min-height: 150px;}
	.about05_box_no p.number {font-size: 64px; letter-spacing: -3px;}
	.about05_box_no span {font-size: 32px; padding-left: 3px;}
	.about05_box p {font-size: 14px; letter-spacing: 0}
	
	.about05_title p {font-size: 15px; letter-spacing: 0;}
	.about05_title h2 {font-size: 44px;}
	
	.page_title01 span {display: block; padding-left: 0;}
	.about06 .page_title01 {background-position: left 12px;}
	
	.about06_box_dl01 > dt h3 {font-size: 22px;}
	.about06_box_dl01 > dt h3 span {width: 19px; height: 19px;}
	.about06_box_dl01 > dt::before {left: 8px; width: 3px;}
	.about06_box_dl02 {padding-top: 12px;}
	.about06_box_dl02 dt {font-size: 17px;}
	.about06_box_dl02 dd {font-size: 15px;}
	.about06_box_in {padding: 0 20px 10px 34px;}
	
	.about07 {padding: 40px 0;}
	.about07 .page_title01 {font-size: 31px; letter-spacing: 0;}
	.about07 .about06_title {margin-bottom: 20px;}
	.about07 .about06_title h3 {font-size: 24px; font-weight: 600;}
	
	.about08 {padding: 60px 0;}
	.about08_box {padding: 0 20px 10px;}
	.about08_box h3 {font-size: 28px;}
	.about08_box_text p {font-size: 17px;}
}

@media screen and ( max-width:767px ){
	.about01_in02 {padding-top: 30px;}
	.about01_in .page_title01 {max-width: 160px; display: block; margin: auto;}
	.about02_box_img {float: none; width: 100%; margin: 0 auto 20px;}
	.about02_box_text {float: none; width: 100%; margin: 0 auto;}
	.about02_box_text dl {margin-bottom: 5px;}
	.about02_box {margin-bottom: 56px;}
	.about03 {padding: 50px 0;}
	.about03_left dt {font-size: 16px;}
	.about03_left dd {font-size: 16px;}
	.about03_b_text h3 {font-size: 18px;}
	.about03_left dl {margin-bottom: 12px;}
	.page_title01 {font-size: 28px; background-size: 32px; padding: 8px 0 8px 38px;}
	
	.about04_bnr {width: 33.3%; margin: 0 0 30px;}
	
	.about05 {padding-top: 50px;}
	.about05_box {width: 48%; margin: 0 1% 15px;}
	.about05_in01 {padding: 30px 0;}
	
	.about05_in02_left {float: none; width: 100%; margin: 0 auto 25px; padding-top: 10px;}
	.about05_in02_right {float: none; width: 100%; margin: auto;}
	
	.about06_title p {font-size: 17px;}
	.about06_title h3 {font-size: 25px;}
	
	.about07 .page_title01 {background-position: left 11px;}
	
	.about08_box {float: none; width: 100%; margin: 0 auto 30px;}
}

@media screen and ( max-width:640px ){
	.about06_box_dl01 > dt {display: block; width: 100%; margin: 0 auto 20px; padding-right: 0;}
	.about06_box_dl01 > dd {display: block; width: 100%; margin: 0 auto;}
	
	.about06 {padding: 50px 0 20px;}
	.about06_title {padding: 14px 18px; border-radius: 7px; margin-bottom: 20px; margin-top: 20px;}
	.about06_title h3 {font-size: 21px;}
	.about06_box {margin-bottom: 35px;}
	.about06_box_dl02 dt {font-size: 16px;}
	.about06_box_dl02 dd {letter-spacing: 0;}
	.about06_box_in_b_text {font-size: 15px;}
	.about06_box_dl01 > dd img {height: 260px !important;}
	
	.about07 {padding: 30px 0 20px;}
	.about07 .page_title01 {font-size: 26px;}
	.about07 .about06_title h3 {font-size: 18px}
	
}

@media screen and ( max-width:500px ){
	.about02_box_text h3 {font-size: 22px;}
	.about02_box_text h3 br {display: none;}
	.about02_box_text dt {font-size: 16px;}
	.about02_box_text dd {font-size: 15px; line-height: 1.5;}
	.about02_box_img img {height: 230px;}
	.about02 {padding-bottom: 20px;}
	
	.about03_right {float: none; width: 80%; margin: 0 auto 20px; max-width: 270px;}
	.about03_left {float: none; width: 100%;}
	.about03 .page_title01 {max-width: 120px; display: block; margin: 0 auto 20px;}
	.about03 .sec_in1000 {width: 86%;}
	.about03_b_text {padding-top: 20px;}
	.about04 .page_title01 {max-width: 212px; display: block; margin: 0 auto; letter-spacing: 0;}
	.about04_bnr {width: 50%; margin: 0 0 25px;}
	
	.about05 .page_title01 {font-size: 24px; background-position: left 3px; padding: 3px 0 3px 38px;}
	.about05_title h2 {font-size: 38px;}
	
	.about08 {padding: 60px 0 20px;}
	.about08_box_text {max-width: 280px;}
	.about08_box_text p {font-size: 16px;}
	.about08_box_icon {max-width: 320px;}
	.about08_box h3 {font-size: 20px;}
}

@media screen and ( max-width:450px ){
.about03_right {max-width: 240px;}
	
	.about05_box {margin-bottom: 8px; min-height: 140px;}
	.about05_box_no p.number {font-size: 54px; letter-spacing: -2px;}
	.about05_box p {font-size: 13px;}
	
	.about06_title h3 {font-size: 20px;}
	.about06_box_dl01 > dt h3 {font-size: 20px;}
	.about06_box_dl02 dt {font-size: 15px;}
	.about06_box_dl01 > dt h3 span {width: 16px; height: 16px; margin-right: 6px; top: 0;}
	.about06_box_dl01 > dt::before {width: 2px; left: 7px;}
	.about06_box_in {padding-left: 24px;}
	.about06_box_dl01 > dd img {height: 220px !important;}
	
	.about07 .about06_title h3 {font-size: 16px;}
	
	.main_text h2 span {line-height: 1.4;}
}











/* ----------------------------------------------------

    technology

---------------------------------------------------- */

.technology_img_wrap .main_text {max-width: 1040px;}
.technology_img_wrap .main_text h2 {font-size: 72px;}


.technology01 {
	padding: 80px 0 100px;
	background-image: url("images/technology/bg01.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center top;
}

.technology01_in {
	max-width: 1200px;
	width: 88%;
	margin: auto;
}

.technology01 .page_title01 {color: #fff;}
.technology01 .page_title01 span {color: #fff;}

.technology01_in02 {padding-top: 60px; margin-bottom: 60px;}

.technology01_in03 {max-width: 1000px; width: 100%; margin: auto;}

.technology01_in03_box {
	float: left;
	width: 47%;
	box-sizing: border-box;
	background-image: url("images/technology/bg01-2.png");
	background-repeat: no-repeat;
	background-position: left top;
	background-size: contain;
	padding: 25px 40px;
	min-height: 200px;
}

.technology01_in03_box:nth-of-type(2) {float: right;}

.technology01_in03_box h3 {
	font-size: 30px;
	font-weight: 600;
	line-height: 1.3;
	display: block;
	padding-bottom: 10px;
	color: #7cdb86;
}

.technology01_in03_box li {
	background-image: url("images/technology/icon01.png");
	background-repeat: no-repeat;
	background-position: left 3px;
	background-size: 10px;
	font-size: 18px;
	line-height: 1.3;
	padding: 0 0 4px 20px;
	color: #fff;
	max-width: 300px;
	margin-bottom: 6px;
	letter-spacing: 0;
}



.technology02 {
	padding: 90px 0 110px;
	background-color:#060002;
	background-image: url("images/technology/bg02.jpg");
	background-repeat: no-repeat;
	background-position: center 20%;
	background-size: 100vw;
}

.technology02 .page_title01 {
	color: #fff;
	background-position: left 12px;
}

.technology02_in {
	max-width: 1200px;
	width: 88%;
	margin: auto;
}

.technology02_in01 {margin-bottom: 160px; padding-top: 60px;}

.technology02_in dl {display: table; width: 100%;}
.technology02_in dt {
	display: table-cell;
	width: 230px;
	vertical-align: middle;
}

.technology02_in dd {
	display: table-cell;
	box-sizing: border-box;
	padding-left: 2%;
	vertical-align: middle;
}

.technology02_in dt h3 {
	font-size: 120px;
	font-weight: 900;
	color: #fff;
	line-height: 1;
	letter-spacing: 0;
}

.technology02_in dt h3 span {
	font-size: 0.4em;
	font-weight: 900;
	color: #fff;
}

.technology02_in dt p {
	font-size: 16px;
	line-height: 1.7;
	color: #fff;
	letter-spacing: 0;
}

.technology02_in dd h4 {
	font-size: 38px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.2;
	color: #fff;
	text-align: center;
	padding-bottom: 28px;
	text-shadow: 0 0 10px #000, 0 0 10px #000, 0 0 10px #000;
}


.technology03 {padding: 90px 0 100px;}

.technology03 .page_title01 {
	background-position: left 12px;
	margin-bottom: 50px;
}
.technology03 .page_title01 span {
	display: block;
	font-size: 0.9em;
	font-weight: 600;
	color: #71b383;
	line-height: 1.2;
	letter-spacing: 0;
	padding-left: 0;
	padding-top: 8px;
}

.technology03_in {
	max-width: 1000px;
	width: 100%;
	margin: auto;
}

.technology03_box01 {margin-bottom: 40px;}

.technology03_box02 {margin-bottom: 70px;}
.technology03_box02 h3 {
	font-size: 24px;
	letter-spacing: 0;
	line-height: 1.3;
	font-weight: 600;
	padding-bottom: 25px;
}

.technology03_bottom {
	box-sizing: border-box;
	padding: 30px 40px 20px;
	background: #ddf2e2;
}

.technology03_bottom dl {display: table; width: 100%; margin-bottom: 10px;}

.technology03_bottom dt {
	display: table-cell;
	width: 1em;
	font-size: 18px;
	color: #71b383;
	line-height: 1.3;
	vertical-align: top;
}

.technology03_bottom dd {
	display: table-cell;
	font-size: 17px;
	line-height: 1.4;
	vertical-align: top;
	letter-spacing: 0;
	box-sizing: border-box;
	padding-left: 5px;
}


.technology04 {padding: 20px 0 90px;}

.technology04 .page_title01 {
	background-position: left 12px;
	margin-bottom: 30px;
}
.technology04 .page_title01 span {
	display: block;
	font-size: 0.5em;
	line-height: 1.3;
	letter-spacing: 0;
	padding-left: 0;
	padding-top: 8px;
	font-weight: 400;
}

.technology04_in h3 {
	display: block;
	box-sizing: border-box;
	background: #e5e3e5;
	text-align: center;
	padding: 14px;
	font-size: 28px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.2;
	border-radius: 10px;
	margin-bottom: 12px;
}

.technology04_img {margin-bottom: 15px;}

.technology04_arrow {
	max-width: 800px;
	width: 100%;
	margin: 0 auto 20px;
}

.technology04_bottom {
	display: block;
	box-sizing: border-box;
	background: #71b383;
	text-align: center;
	color: #fff;
	padding: 22px 14px;
	font-size: 28px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.2;
	border-radius: 10px;
}


.technology05 {padding: 20px 0 90px;}

.technology05 .page_title01 {
	background-position: left 12px;
	margin-bottom: 30px;
}

.technology05_text {
	margin-bottom: 10px;
	box-sizing: border-box;
	padding-left: 50px;
}
.technology05_text p {
	font-size: 17px;
	letter-spacing: 0;
	line-height: 1.5;
}

.technology05_bottom {
	box-sizing: border-box;
	padding: 140px 0;
	background-image: url("images/technology/bg03.png");
	background-repeat: no-repeat;
	background-position: center top;
	background-size: contain;
}

.technology05_bottom dl {display: table; width: 100%;}

.technology05_bottom dt {
	display: table-cell;
	width: 24%;
	vertical-align: middle;
	text-align: center;
	color: #fff;
	font-size: 100px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
	padding-right: 20px;
}

.technology05_bottom dd {
	display: table-cell;
	width: 38%;
	vertical-align: middle;
	box-sizing: border-box;
	padding: 0 30px;
}

.technology05_bottom dd:nth-of-type(1) {
	padding: 0 50px 0 20px;
}

.technology05_bottom dd h3 {
	font-size: 24px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.2;
	color: #71b383;
	padding-bottom: 10px;
}

.technology05_bottom dd h4 {
	font-size: 20px;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.2;
	background: #71b383;
	color: #fff;
	box-sizing: border-box;
	padding: 8px 10px;
	text-align: center;
	display: block;
	margin: 10px 0 7px;
}

.technology05_bottom dd p {
	font-size: 17px;
	letter-spacing: 0;
	line-height: 1.4;
}


.technology06 {
	padding: 100px 0;
	background: #36454B;
	background: -webkit-linear-gradient(top left, rgba(54, 69, 75, 1) 0%, rgba(27, 35, 40, 1) 100%);
	background: -o-linear-gradient(top left, rgba(54, 69, 75, 1) 0%, rgba(27, 35, 40, 1) 100%);
	background: linear-gradient(to bottom right, rgba(54, 69, 75, 1) 0%, rgba(27, 35, 40, 1) 100%);
}

.technology06 .page_title01 {
	background-position: left 12px;
	margin-bottom: 30px;
	color: #fff;
}

.technology06 .page_title01 span {
	color: #fff;
}

.technology06_text p {
	color: #fff;
	font-size: 26px;
	font-weight: 600;
	line-height: 1.3;
}

.technology06_img01 {margin-bottom: 40px; padding-top: 60px;}

.technology06_in01 {margin-bottom: 40px;}

.technology06_in01_img01 {
	float: left;
	width: 47%;
}

.technology06_in01_img02 {
	float: right;
	width: 52%;
}

.technology06_in01_text {
	font-size: 17px;
	text-align: center;
	letter-spacing: 0;
	line-height: 1.5;
	padding-top: 10px;
	color: #fff;
}

.technology06_bottom {
	max-width: 800px;
	width: 100%;
	margin: auto;
}



.technology07 {
	padding: 80px 0;
	background-image: url("images/technology/bg04.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center center;
}

.technology07 .page_title01 {
	background-position: left 12px;
	margin-bottom: 30px;
	color: #fff;
}

.technology07_in01 {margin-bottom: 40px;}

.technology07_in01 dl {
	display: table;
	width: 100%;
}

.technology07_in01 dt {
	display: table-cell;
	width: 45%;
	vertical-align: top;
}

.technology07_in01 dd {
	display: table-cell;
	width: 55%;
	vertical-align: middle;
	box-sizing: border-box;
	padding-left: 3%;
}

.technology07_in01 dd h3 {
	font-size: 30px;
	letter-spacing: 0;
	font-weight: 900;
	line-height: 1;
	color: #62bb88;
	padding-bottom: 10px;
}

.technology07_in01 dd h4 {
	font-size: 30px;
	letter-spacing: 0;
	font-weight: 600;
	line-height: 1.3;
	color: #62bb88;
	padding-bottom: 10px;
}

.technology07_in01 dd p {
	font-size: 17px;
	letter-spacing: 0;
	line-height: 1.5;
	color: #fff;
}

.technology07_in02 {margin-bottom: 10px;}

.technology07_in02_box {
	float: left;
	width: 33.3%;
	margin: 0;
}

.technology07_in03 {
	margin-bottom: 50px;
}

.technology07_in03 h3 {
	font-size: 30px;
	color: #fff;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.2;
	text-align: center;
	display: block;
	margin-bottom: 40px;
}

.technology07_in03 p {
	font-size: 17px;
	color: #fff;
	letter-spacing: 0;
	line-height: 1.4;
	text-align: center;
	display: block;
	margin-bottom: 30px;
}

.technology07_in03_img {
	max-width: 900px;
	width: 100%;
	margin: auto;
}

.technology07_in04 {margin-bottom: 40px;}

.technology07_in04_img {
	float: right;
	width: 26%;
}

.technology07_in04_text {
	float: left;
	width: 71%;
	padding-top: 20px;
}

.technology07_in04_text h3 {
	font-size: 30px;
	color: #62bb88;
	font-weight: 600;
	letter-spacing: 0;
	line-height: 1.2;
	display: block;
	margin-bottom: 20px;
}

.technology07_in04_text p {
	font-size: 18px;
	color: #fff;
	letter-spacing: 0;
	line-height: 1.6;
}

.technology07_in05 dl {width: 100%; margin-bottom: 20px;}

.technology07_in05 dt {
	font-size: 26px;
	color: #fff;
	font-weight: 600;
	margin-bottom: 5px;
	letter-spacing: 0;
	line-height: 1.2;
}

.technology07_in05 dd {
	font-size: 18px;
	color: #fff;
	letter-spacing: 0;
	line-height: 1.5;
}

.technology08 {
	padding: 100px 0 200px;
	background-image: url("images/technology/bg05.jpg");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center bottom;
}

.technology08_title01 {
	max-width: 400px;
	width: 100%;
	margin: 0 auto 100px;
}

.technology08_title02 {margin-bottom: 50px;}

.technology08_title02 h2 {
	font-weight: 800;
	font-size: 38px;
	letter-spacing: 0;
	line-height: 1.4;
	text-align: center;
	display: block;
	background: #FDFEFF;
	background: -webkit-linear-gradient(rgba(253, 254, 255, 1) 0%, rgba(170, 237, 204, 1) 100%);
	background: -o-linear-gradient(rgba(253, 254, 255, 1) 0%, rgba(170, 237, 204, 1) 100%);
	background: linear-gradient(rgba(253, 254, 255, 1) 0%, rgba(170, 237, 204, 1) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.technology08_title02 h2 span {
	display: block;
	padding-top: 15px;
	font-weight: 800;
	font-size: 1.2em;
	letter-spacing: 0;
	line-height: 1.2;
	background: #FDFEFF;
	background: -webkit-linear-gradient(rgba(253, 254, 255, 1) 0%, rgba(170, 237, 204, 1) 100%);
	background: -o-linear-gradient(rgba(253, 254, 255, 1) 0%, rgba(170, 237, 204, 1) 100%);
	background: linear-gradient(rgba(253, 254, 255, 1) 0%, rgba(170, 237, 204, 1) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.technology08_movie {
	max-width: 860px;
	width: 100%;
	margin: auto;
}

.technology08_movie video {
	width: 100%;
	height: auto;
}




@media screen and ( max-width:1536px ){
	.technology01_in {max-width: 1000px;}
	.technology01_in03 {max-width: 800px;}
	.technology_img_wrap .main_text h2 {font-size: 56px;}
	.technology02 {background-position: center 180px; background-size: 1536px;}
}

@media screen and ( max-width:1366px ){
	.technology02 {background-position: center 200px; background-size: 100vw;}
	.technology04_bottom {font-size: 24px;}
	.technology05 .page_title01 {font-size: 28px; background-position: left 8px;}
	.technology05_text p {font-size: 16px;}
	.technology05_bottom {max-width: 1000px; margin: auto; padding: 110px 0;}
	.technology05_bottom dd h3 {font-size: 20px; padding-bottom: 3px;}
	.technology05_bottom dd h4 {font-size: 17px; padding: 4px 10px;}
	.technology05_bottom dd p {font-size: 15px;}
	.technology05_bottom dt {font-size: 90px;}
	
	.technology06 .page_title01 {font-size: 28px; margin-bottom: 20px;}
	.technology06 .page_title01 span {display: inline-block;}
	.technology06_img01 {padding-top: 40px;}
	.technology06_in01_text {font-size: 16px;}
	.technology06_bottom {max-width: 600px;}
	.technology06 {padding: 70px 0;}
	
	.technology07 {padding: 60px 0; background-size: 1423px; background-position: center -32px;}
	.technology07_in01 {margin-bottom: 20px;}
	.technology07_in01 dd h3 {font-size: 26px; padding-bottom: 4px;}
	.technology07_in01 dd h4 {font-size: 28px;}
	.technology07_in01 dt {width: 42%;}
	.technology07_in01 dd {width: 58%;}
	.technology07_in02 {margin-bottom: 30px;}
	.technology07_in03 p {text-shadow: 0 0 10px #000, 0 0 10px #000, 0 0 10px #000;}
}

@media screen and ( max-width:1320px ){
	.technology07 {background-size: 1383px; background-position: center -144px;}
	.technology07 .sec_in1200 {max-width: 1080px;}
	.technology07_in02 {max-width: 1000px; margin: auto;}
	.technology07_in01 dt {width: 420px;}
	.technology07_in01 dd {width: auto;}
	.technology07_in03_img {max-width: 760px;}
	.technology07_in04_text p {font-size: 17px;}
}

@media screen and ( max-width:1199px ){
	.technology08 {padding: 60px 0 110px;}
	.technology08_title01 {margin-bottom: 60px;}
	.technology08_title02 h2 {font-size: 28px;}
}

@media screen and ( max-width:1100px ){
	.technology07 {background-size: 1333px; background-position: center -240px;}
	.technology07 .sec_in1200 {max-width: 800px;}
	.technology07_in01 dt {width: 320px;}
	.technology07_in01 dd h4 {font-size: 22px;}
	.technology07_in01 dd p {font-size: 16px;}
	.technology07_in03 h3 {font-size: 26px;}
	.technology07_in04_text h3 {font-size: 26px;}
	.technology07_in04_text p {font-size: 16px;}
	.technology07_in03_img {max-width: 660px;}
}

@media screen and ( max-width:991px ){
	.technology01 .page_title01 {background-position: left 12px;}
	.technology01_in03_box h3 {font-size: 26px;}
	.technology01_in03_box li {font-size: 16px;}
	.technology_img_wrap .main_text h2 {font-size: 44px;}
	
	.technology02 {background-position: center 180px;}
	.technology02_in dd h4 {font-size: 28px; padding-bottom: 20px;}
	.technology02_in01 {margin-bottom: 100px; padding-top: 40px;}
	
	.technology02_in dt {width: 160px;}
	.technology02_in dt h3 {font-size: 90px;}
	.technology02_in dt p {font-size: 14px; line-height: 1.5;}
	
	.technology03 {padding: 60px 0;}
	.technology03 .page_title01 {font-size: 28px;}
	.technology03_bottom dd {font-size: 16px;}
	
	.technology04 .page_title01 {font-size: 28px; background-position: left 7px; margin-bottom: 20px;}
	.technology04_in h3 {font-size: 22px;}
	.technology04_bottom {font-size: 20px;}
	.technology04 {padding: 0 0 50px;}
	
	.technology05_bottom {background-position: center center; padding: 60px 0;}
	
	.technology06 .page_title01 {font-size: 26px; background-position: left 7px;}
	.technology06 .page_title01 span {display: block;}
	.technology05_text {padding-left: 0;}
	.technology06_img01 {padding-top: 20px; margin-bottom: 30px;}
	
	.technology07 {padding: 50px 0; background-position: center -233px;}
	.technology07 .page_title01 {font-size: 28px;}
	.technology07_in01 dt {width: 38%;}
	.technology07_in01 dd {width: 62%;}
	.technology07_in01 dd h4 {font-size: 24px;}
	.technology07_in01 dd p {font-size: 15px;}
	.technology07_in03 h3 {font-size: 22px;}
	.technology07_in03 p {font-size: 16px;}
	.technology07_in04_text {padding-top: 0;}
	.technology07_in04_text h3 {font-size: 24px;}
	.technology07_in04_text p {font-size: 16px;}
	.technology07_in05 dt {font-size: 22px;}
	.technology07_in05 dd {font-size: 16px;}
	.technology07_in03_img {max-width: 600px;}
	
	.technology08_title01 {margin-bottom: 30px;}
}

@media screen and ( max-width:860px ){
	.technology05 {padding: 10px 0 50px;}
	.technology05 .page_title01 {margin-bottom: 10px; font-size: 24px;}
	.technology05_text {padding-left: 0;}
	.technology05_bottom {background-image: none; padding: 0;}
	.technology05_bottom dl {display: block; width: 100%;}
	.technology05_bottom dt {display: block; margin: 0 auto; padding: 40px 10px; background: #71b383; border-radius: 50%; box-sizing: border-box; width: 140px; height: 140px; font-size: 60px; line-height: 1}
	.technology05_bottom dd {display: block; width: 100%; margin: 15px auto; padding: 20px !important; background: #eee; border-radius: 10px;}
	
	.technology07 {background-size: 1192px; background-position: center -191px;}
	.technology07 .sec_in1200 {max-width: 600px;}
	.technology07_in01 dt {width: 240px;}
	.technology07_in01 dd h4 {font-size: 22px;}
	.technology07_in01 dd p {font-size: 16px;}
	.technology07_in03 h3 {font-size: 19px;}
	.technology07_in03 p {font-size: 15px;}
	.technology07_in04_text h3 {font-size: 22px;}
	.technology07_in04_text p {font-size: 16px;}
	.technology07_in03_img {max-width: 500px;}
	.technology07_in05 dt {font-size: 20px;}
}

@media screen and ( max-width:767px ){
	.technology01_in02 {padding-top: 20px; margin-bottom: 40px;}
	.technology01_in03_box {background-size: cover;}
	.technology_img_wrap .main_text h2 {font-size: 34px;}
	.technology02 {padding: 50px 0 60px; background-position: center 150px;}
	.technology02_in dd h4 {font-size: 22px;}
	
	.technology03 .page_title01 {font-size: 25px;}
	.technology03 .page_title01 span {font-size: 0.8em;}
	.technology03_box02 h3 {font-size: 20px; padding-bottom: 10px;}
	.technology03_box02 {margin-bottom: 40px}
	.technology03 .page_title01 {margin-bottom: 30px;}
	.technology04_bottom {font-size: 20px; text-align: left; padding: 14px;}
	
	.technology06_in01 {margin-bottom: 25px;}
	.technology06_in01_img01 {float: none; width: 100%; margin: 0 auto 25px; max-width: 600px;}
	.technology06_in01_img02 {float: none; width: 100%; margin: 0 auto; max-width: 600px;}
	.technology06_in01_text {font-size: 15px;}
	
	.technology07 {background-size: 1200px; background-position: center -20px;}
	.technology07_in01 dt {display: block; width: 100%; margin: 0 auto 20px; max-width: 480px;}
	.technology07_in01 dd {display: block; width: 100%; margin: 0 auto; max-width: 480px; padding-left: 0;}
	
	.technology08_title02 h2 {font-size: 22px;}
}

@media screen and ( max-width:640px ){
	.technology01 {padding: 50px 0;}
	.technology01_in03_box {float: none; width: 100%; margin: 0 auto 15px; background-size: contain;}
	.technology01_in03 {max-width: 370px;}
	.technology01_in03_box h3 {font-size: 22px;}
	
	.technology02 {background-position: center 320px;}
	.technology02_in dl {display: block;}
	.technology02_in dt {display: block; width: 100%; margin: 0 auto 20px;}
	.technology02_in dd {display: block; width: 100%; margin: 0 auto;}
	.technology02_in dt h3 {text-align: center;}
	.technology02_in dt p {text-align: center;}
	
	.technology02_img03_wrap {overflow-x: scroll;}
	.technology02_img03_wrap img {width: 600px; max-width: inherit;}
	
	.technology03_box_img {overflow-x: scroll;}
	.technology03_box_img img {width: 640px; max-width: inherit;}
	
	.technology04 .page_title01 {font-size: 24px;}
	.technology04 .page_title01 span {font-size: 0.6em;}
	.technology04_in h3 {font-size: 20px;}
	.technology04_img {overflow-x: scroll;}
	.technology04_img img {width: 740px; max-width: inherit;}
	
	.technology05_text {margin-bottom: 20px;}
	.technology05 .page_title01 {font-size: 22px;}
	.technology05_bottom dt {font-size: 48px; width: 120px; height: 120px; padding: 36px 10px;}
	
	.technology06_img01 {overflow-x: scroll;}
	.technology06_img01 img {width: 800px; max-width: inherit;}
	
	.technology07 {background-size: 1340px; background-position: center -156px;}
	.technology07 .sec_in1200 {max-width: 500px;}
	.technology07_in03 h3 {font-size: 17px;}
	.technology07_in03 p {font-size: 14px;}
}

@media screen and ( max-width:567px ){
	.technology02 .page_title01 {font-size: 24px;}
	.technology02_in01 {padding-top:10px;}
	.technology02_in dd h4 {font-size: 20px; padding-bottom: 10px;}
	.technology03 .page_title01 {font-size: 22px;}
	.technology03 {padding: 40px 0;}
	.technology03 .page_title01 {margin-bottom: 10px;}
	.technology03_bottom {padding: 20px 20px 10px;}
	.technology03_bottom dt {font-size: 16px;}
	.technology03_box02 h3 {font-size: 18px;}
	
	.technology06 {padding: 40px 0;}
	
	.technology07 {
		background-image: none;
		background: #427055;
		background: -webkit-linear-gradient(229deg, rgba(66, 112, 85, 1) 0%, rgba(5, 0, 0, 1) 43%);
		background: -o-linear-gradient(229deg, rgba(66, 112, 85, 1) 0%, rgba(5, 0, 0, 1) 43%);
		background: linear-gradient(319deg, rgba(66, 112, 85, 1) 0%, rgba(5, 0, 0, 1) 43%);
	}
	.technology07 .sec_in1200 {width: 86%;}
	.technology07_in02_box {float: none; width: 100%; margin: 0 auto;}
	.technology07_in03 h3 {font-size: 20px; line-height: 1.4; text-align: left;}
	.technology07_in04_img {float: none; width: 100%; margin: 0 auto 25px; max-width:200px;}
	.technology07_in04_text {float: none; width: 100%; margin: 0 auto;}
	.technology07_in05 dt {font-size: 20px;}
	.technology07_in05 dd {font-size: 15px;}
	.technology07_in04_text p {font-size: 15px;}
	.technology07_in03 p {text-align: left;}
	
	.technology07 .page_title01 {font-size: 24px; background-position: left 7px; margin-bottom: 10px;}
	.technology07_in01 {margin-bottom: 10px;}
	.technology07_in03 h3 {margin-bottom: 14px;}
	
	.technology08 {padding: 50px 0 60px;}
}

@media screen and ( max-width:450px ){
	.technology01 {padding: 40px 0 20px;}
	.technology01_in03_box {min-height: 180px;}
	.technology_img_wrap .main_text h2 {font-size: 32px;}
	.technology02 .page_title01 {font-size: 21px;}
	
	.technology03_bottom dd {font-size: 15px;}
	
	.technology04_in h3 {font-size: 18px; text-align: left;}
	.technology04_bottom {font-size: 18px;}
	
	.technology05 {padding-bottom: 30px;}
	.technology05 .page_title01 {font-size: 21px;}
	.technology05_bottom dt {font-size: 42px; width: 100px; height: 100px; padding: 30px 10px;}
	.technology05_text p {font-size: 15px;}
	
	.technology06 .page_title01 {font-size: 22px;}
	.technology06_in01_text {font-size: 14px;}
	.technology07_in01 dd h4 {font-size: 21px;}
	
	.technology08_title01 {max-width: 280px;}
}









/* ----------------------------------------------------

    news

---------------------------------------------------- */

.news01 {padding: 70px 0 60px;}

.news01_in {
	max-width: 1200px;
	width: 88%;
	margin: auto;
}

.news_box {
	display: table;
	width: 100%;
	box-sizing: border-box;
	padding: 50px 0;
	border-bottom: solid 1px #333;
}

.news_box dt {
	display: table-cell;
	width: 160px;
	box-sizing: border-box;
	vertical-align: top;
	color: #868687;
	font-size: 16px;
	line-height: 1.3;
}

.news_box dd {
	display: table-cell;
	box-sizing: border-box;
	vertical-align: top;
	padding-left: 20px;
}

.news_box dd h3 {
	font-size: 18px;
	font-weight: 500;
	line-height: 1.5;
	padding-bottom: 5px;
}

.news_box dd .news_box_text {
	font-size: 16px;
	line-height: 1.5;
	color: #868687;
}

.news_box dd .news_box_text p {
	font-size: 1em;
	line-height: 1.5;
	color: #868687;
}



@media screen and ( max-width:991px ){
	.news_box dt {width: 120px;}
	.news_box dd h3 {font-size: 17px;}
	.news_box dd .news_box_text {font-size: 15px;}
}

@media screen and ( max-width:767px ){
	.news01 {padding: 30px 0 60px;}
}

@media screen and ( max-width:567px ){
	.news_box {display: block; padding: 30px 0;}
	.news_box dt {display: table; width: 100%; margin-bottom: 10px; font-size: 14px;}
	.news_box dd {display: table; width: 100%; padding-left: 0;}
}





.single .breadcrumbs_wrap {margin-top: 80px;}

.single_wrap {
	padding: 90px 0 100px;
}

.single_img {
	padding-top: 10px;
	margin-bottom: 30px;
	text-align: center;
}

.single_img img {
	width: 100%;
	object-fit: cover;
	height: 560px;
}

.single_title {
	font-size: 28px;
	letter-spacing: 1px;
	display: block;
	line-height: 1.3;
	padding-bottom: 10px;
	margin-bottom: 20px;
	border-bottom: solid 1px #333;
}

.post-navigation {
	padding: 30px 0;
}

.nav-links {
	overflow: hidden;
	width: 100%;
	box-sizing: border-box;
	padding: 20px 0;
}

.nav-links a {
	font-size: 12px;
	letter-spacing: 0;
}

.nav-links a:nth-of-type(1) {
	display: block;
	width: 50%;
	float: left;
	border-right: solid 1px #ccc;
	box-sizing: border-box;
	padding: 20px 10px 20px 0;
}

.nav-links a:nth-of-type(2) {
	display: block;
	width: 50%;
	float: right;
	text-align: right;
	box-sizing: border-box;
	padding: 20px 0 20px 10px;
}

.nav-links a:hover {
	color: #71b383;
}

.nav-links a span {
	font-size: 13px;
}

.nav-links a:hover span {
	color: #71b383;
}

.entry-content {
	padding-bottom: 30px;
	border-bottom: solid 5px #eee;
}

.cat-links {
	margin-bottom: 10px;
}

.cat-links a {
	display: inline-block;
    box-sizing: border-box;
    font-size: 12px;
    color: #222;
    letter-spacing: 1px;
    padding: 4px 10px;
    text-align: center;
    line-height: 1;
    width: 108px;
    border: solid 1px #222;
}

.single .entry-title {
	font-size: 26px;
	color: #222;
	padding-top: 10px;
	letter-spacing: 2px;
	font-weight: 500;
	margin-bottom: 15px;
}
.entry-date {padding-bottom: 10px;}

.byline {
	display: none;
	
}

.entry-date a {
	cursor:default;
}

.comments-link {
	display: none;
}

.edit-link {
	display: none;
}

.single .post-thumbnail {
	max-width: 800px;
	margin: 0 auto 25px;
}

.single .post-thumbnail img {
	max-width: 800px;
    max-height: 800px;
    height: auto;
    width: auto;
	/*height: 460px;
	object-fit: cover;*/
	border-radius: 15px;
	text-align: center;
	margin: auto;
	display: block;
}

@media screen and ( max-width:800px ){
	.single .post-thumbnail img{width: 100%;}
}

.single .entry-content {
	padding: 30px 0 20px;
	margin-top: 40px;
	border-top: solid 1px #ccc;
	clear: both;
	margin-bottom: 30px;
}

.single .entry-content p {
	font-size: 16px;
	line-height: 1.7;
	letter-spacing: 1px;
}

.entry-date {
	color: #888;
	float: right;
	font-family: 'Lato', sans-serif;
}

.wp-block-table tbody {
	border-top: solid 1px #eee;
    border-left: solid 1px #eee;
}

.single .btn01 a {width: 100%; margin: auto;}

@media screen and ( max-width:991px ){
	.single_wrap {padding-top: 70px;}
}

@media screen and ( max-width:767px ){
	.news01 {padding: 70px 0;}
	/*.single .post-thumbnail img {height: 400px;}*/
	.single .breadcrumbs_wrap {margin-top: 66px;}
}

@media screen and ( max-width:567px ){
	.news01 {padding: 50px 0 30px;}
	.single .post-thumbnail img {/*height: 300px;*/ border-radius: 10px;}
	.news01 .t_news_box {margin-bottom: 10px;}
	.news01_title {margin-bottom: 20px;}
	.news01_title h2 {font-size: 26px; letter-spacing: 1px;}
	.entry-date {font-size: 13px;}
	.single .post-thumbnail {margin-bottom: 5px;}
}

@media screen and ( max-width:500px ){
	.single .breadcrumbs_wrap {margin-top: 60px;}
	.news01 {padding: 30px 0 20px;}
	.post-navigation {padding: 0;}
}

@media screen and ( max-width:450px ){
	.single_wrap {padding: 40px 0 40px;}
	/*.single .post-thumbnail img {height: 250px;}*/
	.single .entry-title {font-size: 22px; letter-spacing: 1px;}
	.nav-links a span {font-size: 12px;}
	.single .entry-content {margin-bottom: 10px;}
}









/* ----------------------------------------------------

    メディアクエリ

---------------------------------------------------- */



.max1366 {display: none !important;}
.min1367 {display: block !important;}
.max1279 {display: none !important;}
.min1280 {display: block !important;}
.max1199 {display: none !important;}
.min1200 {display: block !important;}
.max991 {display: none !important;}
.min992 {display: block !important;}
.max850 {display: none !important;}
.min851 {display: block !important;}
.max767 {display: none !important;}
.min768 {display: block !important;}
.max640 {display: none !important;}
.min641 {display: block !important;}
.max567 {display: none !important;}
.min568 {display: block !important;}
.max450 {display: none !important;}
.min451 {display: block !important;}



@media screen and ( min-width:1921px ){

}


@media screen and ( max-width:1680px ){
	
}

@media screen and ( max-width:1536px ){
	.header_left {max-width: 180px;}
	
	
	.sp_menu {padding-top: 10vh;}
	
	.main_text h2 {font-size: 74px;}
	.main_text h3 {font-size: 26px;}
	
	.main_img_wrap {height: 800px;}
	.main_img img {height: 800px;}
	
	

}

@media screen and ( max-width:1366px ){
	.max1366 {display: block !important;}
	.min1367 {display: none !important;}
	
	.main_img_wrap {height: 740px;}
	.main_img img {height: 740px;}

	.header_left {padding-top: 0; max-width: 150px;}
	.header_right {max-width: 600px;}
	.header_right nav li a {font-size: 18px;}
	.main_text h2 {font-size: 66px;}
	.main_text h3 {font-size: 22px;}
	
	.nav02 {width: 70px; height: 70px; padding: 6px 0 14px; right: 20px; top: 20px;}
	
	.top01 .sec_in1200 {max-width: 1000px;}
	.top01 h2 {font-size: 30px;}
	.top01 p {font-size: 16px;}
	.top01 h3 {font-size: 21px;}
	.top01 ol li {font-size: 16px;}
	
	footer {padding: 60px 0 50px;}
	.footer_contact p {font-size: 15px;}
	.copyright {font-size: 11px;}
	.footer_bottom h2 img {width: 130px;}
	.footer_contact h2 {font-size: 28px;}
}

@media screen and ( max-width:1279px ){
	.max1279 {display: block !important;}
	.min1280 {display: none !important;}
	

}

@media screen and ( max-width:1199px ){
	.max1199 {display: block !important;}
	.min1200 {display: none !important;}
	

	
}

@media screen and ( max-width:991px ){
	.max991 {display: block !important;}
	.min992 {display: none !important;}
	
	.main_text h2 {font-size: 56px;}
	.main_text h3 {font-size: 20px;}
	
	
	.sp_menu_in {max-width: 350px;}
	.sp_menu_in h2 img {width: 180px;}
	.sp_menu_in h2 {margin-bottom: 60px;}
	.sp_menu_in li {margin-bottom: 70px;}
	.sp_menu_in li a {font-size: 30px; letter-spacing: 1px;}
	.sp_menu_in li a span {font-size: 13px;}
	.sp_menu_info p {font-size: 12px; line-height: 1.8;}
	.sp_copy {font-size: 11px; letter-spacing: 1px; color: #999;}
	
	.top01 .sec_in1200 {width: 86%;}
	.top01 h2 {font-size: 30px;}
	.top01 p {font-size: 15px;}
	.top01 h3 {font-size: 21px;}
	.top01 ol li {font-size: 15px;}
	
	.header_top.fixed {position: absolute; background: transparent; min-height: 80px; padding: 25px 0 0; backdrop-filter:none;}
	.header_top.fixed .header_left {max-width: 150px; padding-left: 2.5%;}
}

@media screen and ( max-width:896px ){
	
}

@media screen and ( max-width:767px ){
	
	.max767 {display: block !important;}
	.min768 {display: none !important;}
	
	html {overflow-x: hidden;}
	
	.main_img_wrap {height: 700px;}
	.main_img img {height: 700px;}
	.main_text {top: 43%;}
	
	.main_text h2 {font-size: 46px;}
	.main_text h3 {font-size: 17px;}
	
	.nav02 {width: 60px; height: 60px; padding: 4px 0 6px;}
	
	
	.menu-trigger,
	.menu-trigger span {
		display: inline-block;
		transition: all .4s;
		box-sizing: border-box;
	}
	.menu-trigger {
		position: relative;
		width: 100%;
		height: 100%;
	}
	.menu-trigger span {
		position: absolute;
		left: 0;
		right: 0;
		margin: auto;
		width: 30px;
		height: 1px;
		background-color: #fff;
		border-radius: 0;
	}
	
	.menu-trigger span:nth-of-type(1) {top: 16px;}
	.menu-trigger span:nth-of-type(2) {top: 19px;}
	.menu-trigger span:nth-of-type(3) {bottom: 27px;}
	.menu-trigger.active span:nth-of-type(1) {transform: translateY(3px) rotate(-45deg);}
	.menu-trigger.active span:nth-of-type(3) {transform: translateY(-3px) rotate(45deg);}

	.menu-trigger p {
		text-align: center;
		font-size: 10px;
		color: #fff;
		position: absolute;
		bottom: 5px;
		left: 0;
		right: 0;
		letter-spacing: 0;
	}
	
	.header_right {max-width: 180px; padding: 10px 30px 0 10px;}
	.header_top {padding-top: 15px;}
	
	.top01 {padding: 70px 0;}
	.top01 .top01_in02_in p {font-size: 13px; letter-spacing: 0;}
}

@media screen and ( max-width:640px ){
	.max640 {display: block !important;}
	.min641 {display: none !important;}
}

@media screen and ( max-width:567px ){	
	.max567 {display: block !important;}
	.min568 {display: none !important;}
	
	.main_img_wrap {height: 600px;}
	.main_img img {height: 600px;}
	.main_text {top: 40%;}
	.main_text h2 {line-height: 1.3; margin-bottom: 20px;}
	
	.header_left {max-width: 110px; padding: 10px 0 0 15px;}
	.header_top.fixed .header_left {max-width: 110px; padding: 10px 0 0 15px;}
	.header_right {padding: 0 10px 0 0;}
	
	.sp_menu_in h2 img {max-width: 150px;}
	.sp_menu_in li a {font-size: 22px;}
	.sp_menu_in li {margin-bottom: 50px;}
	
	.top01 {padding: 50px 0 30px; background-position: 70% top;}
	.top01 h2 {font-size: 25px;}
	.top01 h3 {font-size: 19px; padding-bottom: 10px;}
	.top01_in02 {padding-top: 10px;}
	.top01_in02_box {float: none; width: 100%; margin: 0 auto 40px; max-width: 340px;}
	.top01_in02_box h4 {margin-bottom: 0;}
	
	.footer_bottom h2 {float: none; margin: auto; text-align: center; padding-right: 0; padding-bottom: 30px;}
	.copyright {text-align: center; float: none;}
}

@media screen and ( max-width:500px ){

	
	
}

@media screen and ( max-width:450px ){
	.max450 {display: block !important;}
	.min451 {display: none !important;}
	
	.main_img_wrap {height: 500px;}
	.main_img img {height: 500px;}
	.header_top {padding-top: 10px;}
	.main_text h3 {font-size: 14px;}
	.nav02 {top: 10px; right: 10px;}
	
	footer {padding: 50px 0 40px;}
	.footer_contact h2 {font-size: 26px;}
	.footer_contact p {text-align: left;}
}

@media screen and ( max-width:360px ){
	

}

@media screen and ( max-width:325px ){
	
	
}



















