/*
Theme Name: Flatsome Child
Description: This is a child theme for Flatsome Theme
Author: UX Themes
Template: flatsome
Version: 3.0
*/

/*************** ADD CUSTOM CSS HERE.   ***************/

@import url('https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&family=Noto+Sans+JP:wght@100..900&display=swap');

* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}
html {
	overflow-x: hidden;
	overflow-y: auto;
}
body {
	width: 100%;
	font-size: 16px;
	line-height: 1.5em;
	position: relative;
	color: #000;
	font-weight: 400;
	font-family: "Noto Sans JP", serif;
	overflow: hidden;
	overflow-y: auto;
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	letter-spacing: 0.5px;
}
img {
	max-width:100%;
	 -webkit-backface-visibility: hidden;
    -ms-transform: translateZ(0); /* IE 9 */
    -webkit-transform: translateZ(0); /* Chrome, Safari, Opera */
    transform: translateZ(0);
}
/* .container {
	padding-right: 0;
	padding-left: 0;
} */
body,
li,
address {
	line-height: 1.5em;
}
input,
button,
select,
textarea {
	font-size: 16px;
	/* -webkit-appearance: none;*/
}
p {
	font-size: 16px;
	margin: 0 0 10px;
}
a {
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
	text-decoration: inherit;
}
a:hover {
	text-decoration: none;
	color: #028400;
}
h1,
h2,
h3,
h4,
h5,
h6 {
	margin: 10px 0 10px 0;
	line-height: 1.5em;
	color: #000;
}

a[href^="tel"] {
	color: inherit;
	text-decoration: none;
}
input[type=text],
input[type=email],
input[type=password],
textarea {
	-webkit-appearance: none;
}
.center {
	text-align: center;
}
/* .container {
	width: 1100px;
	max-width: 1100px;
} */
.show-tb {
	display: none;
}
.show-sp {
	display: none;
}

/***top***/
.section {
	padding: 110px 0 !important;
}
.sect-about {
	position: relative;
}
.sect-about:after {
	content: 'Who Are We';
	font-size: 120px;
	color: #efefef;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	position: absolute;
	line-height: 0.8em;
	white-space: nowrap;
}
.sect-news {
	background: #f5f5f5;
}
/*.sect-news{
	content: 'News';
	font-size: 120px;
	color: #e5e5e5;
	top: -50px;
	left: 0px;
	position: absolute;
	line-height: 0.8em;
	z-index:1;
}*/

.title-big1 {
	position: relative;
	margin-bottom: 50px;
	padding-bottom: 30px;
}
.title-big1:after {
	content: '';
	display: inline-block;
	width: 70px;
	height: 8px;
	border-radius: 8px;
	background: #b3dab2;
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
}
.title-big1 h2 {
	color: #000;
	font-size: 42px;
	font-weight: bold;
	margin: 0 0 10px 0;
	line-height: 1em;
}
.title-big1 span {
	display: inline-block;
	color: #028400;
	font-size: 22px;
	line-height: 1em;
}
.title-big2 {
	position: relative;
	margin-bottom: 15px;
	padding-left: 30px;
}
.title-big2:after {
	content: '';
	display: inline-block;
	width: 14px;
	height: 14px;
	border-radius: 100%;
	background: #b3dab2;
	position: absolute;
	left: 0;
	top: 22px;
}
.title-big2 h2 {
	font-size: 36px;
	font-weight: bold;
	color: #028400;
}
.title-big3 {
	position: relative;
	margin-bottom: 50px;
	padding-left: 30px;
}
.title-big3:after {
	content: '';
	display: inline-block;
	width: 8px;
	height: 100%;
	border-radius: 8px;
	background: #b3dab2;
	position: absolute;
	top: 0;
	left: 0;
}
.title-big3 h2 {
	color: #000;
	font-size: 42px;
	font-weight: bold;
	margin: 0 0 10px 0;
	line-height: 1em;
}
.title-big3 span {
	display: inline-block;
	color: #028400;
	font-size: 22px;
	line-height: 1em;
}
.title-big4 {
	position: relative;
	margin-bottom: 50px;
}
.title-big4 h2 {
	color: #000;
	font-size: 28px;
	font-weight: bold;
	margin: 0 0 10px 0;
	line-height: 1em;
}
.title-big4 span {
	display: inline-block;
	/* color: #028400; */
	font-size: 22px;
	line-height: 1em;
	margin-top: 15px;
}
.row-full {
	width: 100%;
	max-width: 100% !important;
}
.about-fea {
	padding: 0 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: justify;
	position: relative;
	top: -20px;
}
.about-fea h2 {
	text-align: left;
}
.section.section-s {
	padding: 0 !important;
}
.service-box .text-box {
	height: 100%;
	position: relative;
}
.service-box .text-box label {
	background: #fff;
	width: 60px;
	height: 60px;
	text-align: center;
	font-size: 42px;
	color: #028400;
	position: absolute;
	top: 0;
	left: 0;
	line-height: 60px;
}
.service-box .text-box h3 {
	font-weight: bold;
	font-size: 24px;
}
.service-box .text-box .text-box-content {
	padding-left: 80px;
	padding-top: 4px;
}
.btn-st1 {
	color: #000;
	background: none;
	position: relative;
	padding-right: 60px;
	padding-left: 0;
	line-height: 46px;
	border: 0;
	z-index: 3;
}
.btn-st1:after {
	content: '';
	display: inline-block;
	width: 46px;
	height: 46px;
	position: absolute;
	right: 0;
	top: 0;
	background: url('assets/images/ar1.png') no-repeat;
	-webkit-transition: all ease 0.2s;
	-moz-transition: all ease 0.2s;
	-o-transition: all ease 0.2s;
	-ms-transition: all ease 0.2s;
	transition: all ease 0.2s;
}
.btn-st1:hover {
	background: none !important;
	color: #028400;
	box-shadow: 0 0 0;
}
.btn-st1:hover:after {
	right: -10px;
}
.btn-st2 {
	color: #fff;
	background: none;
	position: relative;
	padding-right: 60px;
	padding-left: 0;
	line-height: 46px;
}
.btn-st2:after {
	content: '';
	display: inline-block;
	width: 46px;
	height: 46px;
	position: absolute;
	right: 0;
	top: 0;
	background: url('assets/images/ar2.png') no-repeat;
	-webkit-transition: all ease 0.2s;
	-moz-transition: all ease 0.2s;
	-o-transition: all ease 0.2s;
	-ms-transition: all ease 0.2s;
	transition: all ease 0.2s;
}
.btn-st2:hover {
	background: none !important;
	color: #cdcdcd;
	box-shadow: 0 0 0;
}
.btn-st2:hover:after {
	right: -10px;
}
.bg-st1 {
	background: url('assets/images/bg1.jpg') no-repeat center center;
	color: #fff;
}
.bg-st1 .title-big3 h2 {
	color: #fff;
}
.bg-st1 .title-big3 h2 span {
	color: #fff;
}
.mrt-30 {
	margin-top: 30px;
}
.col-ser {
	position: relative;
}
.col-ser .col-inner {
	position: relative;
	z-index: 2
}
.col-ser:after {
	content: 'Services';
	font-size: 120px;
	color: #efefef;
	top: 0;
	left: 0;
	position: absolute;
	line-height: 0.8em;
	z-index: 1;
}
.gg-iframe iframe {
	width: 100%;
	height: 625px;
}
.sect-news.no-bg {
	background: none;
}
.sect-news.no-bg:after {
	display: none;
}
.sect-news .blog-post-inner {
	position: relative;
	padding-top: 30px;
	text-align: left;
}
.sect-news .blog-post-inner .post-meta {
	position: absolute;
	top: 0;
	left: 0;
	color: #028400;
}
.sect-news .blog-post-inner .tag-label {
	position: absolute;
	top: 2px;
	left: 100px;
	color: #028400;
	border: solid 1px #028400;
	background: #fff;
}
.sect-news .blog-post-inner .tag-label:hover {
	color: #fff;
	background: #028400;
}
.sect-news .blog-post-inner a {
	color: #000;
}
.sect-news .blog-post-inner a:hover {
	color: #028400;
}
.sect-news .box-blog-post .is-divider {
	display: none;
}
.sect-news .box-blog-post .box-text {
	padding-bottom: 0;
}
.work-blk img {
	border: solid 1px #cecece;
}
.btn-work-cat {
	color: #000;
	display: inline-block;
	border: solid 1px #028400;
	background: #fff;
	height: 42px;
	line-height: 40px;
	border-radius: 21px;
	padding: 0 30px;
}
.btn-work-cat:hover {
	color: #fff;
	background: #028400;
}
.portfolio-categories button.active {
	color: #fff;
	background: #028400;
}
.portfolio-posts {
	display: flex;
    align-content: flex-start;
    flex-wrap: wrap;
}
.portfolio-item {
	width: 33.33%;
	max-width: 33.33%;
	flex-basis: 33.33%;
	padding: 0 15px;
}
.portfolio-item h3 {
	font-size: 16px;
	font-weight: 500;
}

.btn-work-cat.current {
	color: #fff;
	background: #028400;
}
.info-row {
	padding: 13px 0;
	border-bottom: solid 1px #c4c4c4
}
.info-row.no-br {
	border-bottom: 0;
}
.info-row label {
	font-weight: bold;
	color: #028400;
}
.info-row .col {
	padding: 0;
}
.info-row p {
	margin: 0;
}
.col-ser, .col-work {
	padding: 115px 80px;
}
.col-ser {
	padding-left: 15px;
}
::placeholder {
	color: #d3d3d3;
	font-weight: normal;
}
.rq {
	color: #d00;
}
.form-col label {
	font-size: 16px;
}
.form-col input[type=text],
.form-col input[type=tel],
.form-col input[type=phone],
.form-col input[type=email] {
	color: #000;
	height: 48px;
	line-height: 48px;
	border: solid 1px #c4c4c4;
	border-radius: 4px;
	padding: 0 12px;
	width: 80%;
	box-shadow: 0 0 0;
}
.form-col textarea {
	min-height: 200px;
	width: 100%;
	border-radius: 4px;
	padding: 12px 12px;
	border: solid 1px #c4c4c4;
	resize: vertical;
	box-shadow: 0 0 0;
}
.form-col input[type=submit] {
	height: 60px;
	line-height: 60px;
	color: #fff;
	border-radius: 30px;
	box-shadow: 0 0 0;
	background: #028400 url('assets/images/ar2.png') no-repeat;
	background-size: 32px 32px;
	background-position: calc(100% - 20px) center;
	padding: 0 72px 0 30px;
	transition: all ease 0.3;
}
.form-col input[type=submit]:hover {
	background-color: #013f00;
}
.nav-line-bottom>li>a:before, .nav-line-grow>li>a:before, .nav-line>li>a:before {
	background: #028400;
}
ul.links.footer-nav  li a {
	text-transform: none;
	font-size: 14px;
}
ul.links.footer-nav li {
	margin: 10px 10px;
}
.back-to-top:hover {
	background: #013100;
	border-color:  #013100;
}
.btn__send-mail {
	color: #000;
	font-size: 16px;
	display: inline-block;
	padding: 0 46px 0 46px;
	position: relative;
	line-height: 46px;
}
.btn__send-mail:before {
	content: '';
	display: inline-block;
	width: 23px;
	height: 16px;
	position: absolute;
	left: 16px;
	top: 16px;
	background: url('assets/images/icon-env.png') no-repeat;
	background-size: 23px 16px;
}
.btn__send-mail:after {
	content: '';
	display: inline-block;
	width: 26px;
	height: 26px;
	position: absolute;
	right: 6px;
	top: 10px;
	background: url('assets/images/ar1.png') no-repeat;
	background-size: 26px 26px;
	-webkit-transition: all ease 0.2s;
	-moz-transition: all ease 0.2s;
	-o-transition: all ease 0.2s;
	-ms-transition: all ease 0.2s;
	transition: all ease 0.2s;
}

.head__title {
	font-size: 60px;
	font-weight: 600;
}
.breadcrumb-section {
	background-image: url(./assets/images/bc-new.jpg); 
	background-position: center center;
	background-size: cover; 
}
/* .breadcrumb-section .col {
	padding: 0;
} */
.breadcrumb-section .inner {
	min-height: 340px;
	display: flex;
	align-items: center;
	position: relative;
}
.breadcrumbs {
	position: absolute;
	bottom: 0;
	left: 0;
	display: inline-block;
	width: 100%;
	height: 40px;
	line-height: 40px;
}
.breadcrumbs a {
	color: #008400;
	font-weight: bold;
}
.breadcrumbs span {
	color: #111;
}
.breadcrumbs span.sep {
	display: inline-block;
    height: 19.5px;
    width: 40px;
	position: relative;
}
.breadcrumbs span.sep i {
	display: inline-block;
    width: 20px;
    height: 1px;
    background: #000;
	position: absolute;
	top: 15px;
	left: 10px;
}
.head__single {
	margin-top: 40px;
	margin-bottom: 20px;
}
.head__single h1{
	font-size: 42px;
	font-weight: 300;
	color: #111;
	padding-left: 40px;
	position: relative;
}
.head__single h1::before {
	content: '';
	width: 20px;
	height: 20px;
	background: #b3dab2;
	border-radius: 50px;
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
}
.head__date {
	font-size: 14px;
	color: #028400;
	font-weight: 500;
}
.head__category .post-categories {
	display: inline-block;
	list-style: none;
}
.head__category .post-categories li {
	border: 1px solid #028400;
    border-radius: 20px;
    padding: 0px 20px;
    margin-left: 20px;
}
.head__category .post-categories li a {
	color: #028400;
	font-weight: 600;
}
.nav li.lang-item {
	margin-right: 0 !important;
}
.slide-sect {
	position: relative;
	background: #fff;
}
.logo-slide {
	position: absolute;
	z-index: 99;
	width: 60% !important;
	right: 5%;
	bottom: 15%;
}
.logo-slide.logo-sp {
	display: none ;
}
.a-justify {
	text-align: justify
}
.footer-logo img {
	width: 250px;
}
.footer-logo-sect .text-box {
	margin-top: 20px;
}
.slider-wrapper {
	background: #b0b0b0;
}
.slider-wrapper .slider {
	overflow: hidden;
}
.slider-wrapper .slider .banner {
	
}
.w-840 {
	width: 840px;
}
.show-tb {
	display: none !important;
}

@media only screen and (max-width: 48em) {
/*************** ADD MOBILE ONLY CSS HERE  ***************/


}
@media only screen and (min-width: 1367px) {
	.container, .row {
		max-width: 1400px !important;
	}
	.row-full-width, .row-full {
		max-width: 100% !important;
	}
	.footer-right h3 {
		font-size: 16px !important;
	}
	
}
@media only screen and (max-width: 1400px) {
	.footer-txt h3 {
		font-size: 15px;
		line-height: 1.4em;
		font-weight: bold;
	}
	.btn__send-mail {
		padding-left: 15px;
	}
	.btn__send-mail:before {
		display: none;
	}
	.footer-right h3 {
		font-size: 15px !important; 
	}
	.container, .row {
		max-width: 1100px !important;
	}
	.row-full-width {
		max-width: 100% !important;
	}
	.gg-iframe iframe {
		height: 380px
	}
}

@media only screen and (max-width: 1366px) {
	.sect-about:after,
	.sect-news:after,
	.col-ser:after {
		font-size: 100px;
	}
	.col-ser, .col-work {
		padding: 90px 60px 60px 60px;
	}
}
@media only screen and (max-width: 1200px) {
	.sect-about:after,
	.sect-news:after,
	.col-ser:after {
		font-size: 85px;
	}
	.about-fea {
		padding: 30px 30px;
	}
	.col-ser, .col-work {
		padding: 90px 50px 50px 50px;
	}
	.container, .row {
		max-width: 980px !important;
	}
	.row-full-width {
		max-width: 100% !important;
	}
	.gg-iframe iframe {
		height: 255px
	}
	.header-nav .nav-top-link {
		font-size: 15px;
	}
	.fea-row-1 .col {
		width: 50%;
		max-width: 50%;
		flex-basis: 50%;
	}
	.fea-row-1 .col:last-child {
		display: none;
	}
	.fea-row-2 .col {
		width: 50%;
		max-width: 50%;
		flex-basis: 50%;
	}
	.fea-row-2 .col:first-child {
		display: none;
	}
}
@media only screen and (max-width: 991px) {
	.section {
		padding: 80px 0 !important;
	}
	.title-big1 h2,
	.title-big2 h2,
	.title-big3 h2 {
		font-size: 34px;
	}
	.title-big1 span,
	.title-big3 span {
		font-size: 20px;
	}
	.title-big2:after {
		top: 22px;
	}
	.sect-about:after,
	.sect-news:after,
	.col-ser:after {
		font-size: 70px;
	}
	.fea-row-1 .col {
		width: 50%;
		max-width: 50%;
		flex-basis: 50%;
	}
	.fea-row-1 .col:last-child {
		display: none;
	}
	.fea-row-2 .col {
		width: 50%;
		max-width: 50%;
		flex-basis: 50%;
	}
	.fea-row-2 .col:first-child {
		display: none;
	}
	.section.section-s {
		padding: 10px 0 !important;
	}
	.col-ser, .col-work {
		padding: 70px 30px 30px 30px;
	}
	.service-box .text-box h3 {
		font-size: 20px;
	}
	.header-nav .nav-top-link {
		font-size: 14px;
	}
	.nav-spacing-xlarge>li {
		margin: 0 8px;
	}
	.nav-top-link img {
		max-width: 26px;
	}
	.w-840 {
		width: 100%;
	}
	.show-tb {
		display: block !important;
	}
	.hide-tb {
		display: none !important;
	}
	.about-fea {
		top: 0;
	}
}
@media only screen and (max-width: 767px) {
	.section {
		padding: 60px 0 !important;
	}
	.title-big1 h2,
	.title-big2 h2,
	.title-big3 h2 {
		font-size: 32px;
	}
	.title-big1 span,
	.title-big3 span {
		font-size: 18px;
	}
	.title-big2:after {
		top: 20px;
	}
	.sect-about:after,
	.sect-news:after,
	.col-ser:after {
		display: none;
	}
	.about-fea {
		padding: 20px 20px;
	}
	.col-ser, .col-work {
		max-width: 100%;
		flex-basis: 100%;
	}
	.col-ser .row .col {
		
	}
	.service-box .text-box h3 {
		font-size: 18px;
	}
	.form-col input[type=text],
	.form-col input[type=tel],
	.form-col input[type=phone],
	.form-col input[type=email] {
		width: 100%;
	}
	.breadcrumbs {
		height: auto;
	}
	.head__single h1 {
		font-size: 18px;
	}
	.logo-slide.logo-sp {
		display: block !important;
	}
	.logo-slide.logo-pc {
		display: none !important;
	}
	.slide-sect.no-pdt {
		/*padding-top: 100px !important;*/
	}
	.flickity-slider {
		height: auto !important;
	}
	.slider .has-slide-effect {
		height: auto !important;
		min-height: 400px;
	}
	.head__title {
		font-size: 36px;
	}
	.breadcrumb-section .inner {
		min-height: 220px;
	}
	.logo-slide {
		margin-top: 0;
		right: auto;
		bottom: 60px;
		width: 85% !important;
		top: auto;
		left: 50%;
		transform: translate(-50%,-50%);
	}
}
@media (max-width: 549px) {
	body, p, input, button, select, textarea  {
		font-size: 14px;
	}
	.section {
		padding: 50px 0 !important;
	}
	.title-big1 h2,
	.title-big2 h2,
	.title-big3 h2 {
		font-size: 26px;
	}
	.title-big1 span,
	.title-big3 span {
		font-size: 18px;
	}
	.title-big2:after {
		top: 14px;
	}
	.title-big2 {
		margin-bottom: 20px;
	}
	.fea-row-1 .col, .fea-row-2 .col {
		width: 100%;
		max-width: 100%;
		flex-basis: 100%;
	}
	.fea-row-1 .col:first-child, .fea-row-2 .col:last-child {
		padding-bottom: 10px;
	}
	.fea-row-1 .banner, .fea-row-2 .banner {
		padding-top: 200px !important;
	}
	.fea-row-2 {
		flex-direction: column-reverse;
	}
	.about-fea {
		padding: 0 20px;
	}
	.info-row {
		padding: 10px 10px;
		margin-left: 0 !important;
		margin-right: 0 !important;
	}
	.slider .has-slide-effect {
		min-height: 300px;
	}
	.head__title {
		font-size: 24px;
	}
	.breadcrumb-section .inner {
		min-height: 160px;
	}
	.banner-left-col .col-inner > .banner {
		padding-top: 170px !important;
	}
	.breadcrumbs {
		line-height: 24px;
    	font-size: 16px;
	}
}
.no-pdt {
	padding-top: 0 !important;
}
.no-pdb {
	padding-bottom: 0 !important;
}