@charset "UTF-8";

/* reset -------------------------------------------------- */
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, object, iframe, pre, code, p, blockquote, form, fieldset, legend, table, th, td, caption, tbody, tfoot, thead, article, aside, figure, footer, header, hgroup, menu, nav, section, audio, video, canvas, main {
	margin: 0;
	padding: 0;
}
article, aside, figure, figcaption, footer, h1, h2, h3, h4, h5, h6, header, hgroup, menu, nav, section, main {
	display: block;
}

/* List -------------------- */
ol, ul, li {
	overflow: hidden;
	zoom: 1;
	list-style: none;
	margin: 0;
	padding: 0;
}

/* Definition -------------------- */
dl, dt, dd {
	overflow: hidden;
	zoom: 1;
}

/* base -------------------------------------------------- */
*, *:before, *:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
html {
	font-size: 62.5%;
}
html, body {
	width: 100%;
	height: 100%;
	background: #fff;
    overflow-x: hidden;
}
body {
	font-size: 1.5rem;
	line-height: 1.8;
	font-family: "游ゴシック Medium" , "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic , 'Helvetica Neue' , Helvetica , Arial , Verdana , 'ヒラギノ角ゴ Pro W3' , 'Hiragino Kaku Gothic Pro' , 'メイリオ' , Meiryo , 'ＭＳ Ｐゴシック' , 'MS PGothic' , sans-serif;
	background: #fff;
	color: #161616;
	height: auto;
	border: solid 5px #98E05F;
}
a{
	color: inherit;
	text-decoration: none;
	transition: 0.3s;
}
a:hover{
	transition: 0.3s;
}
a img{
	border: none;
}
img{
	width: 100%;
}
.clearfix{
	zoom: 1;
}
.clearfix:after{
	content: '';
	display: block;
	clear: both;
}
h2, h3, h4{
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic" ,'ヒラギノ角ゴ Pro W3' , 'Hiragino Kaku Gothic Pro' , 'メイリオ' , Meiryo , 'ＭＳ Ｐゴシック' , 'MS PGothic' , sans-serif;
}
.no-pa{
	padding: 0!important;
}
section p{
	margin-bottom: 35px;
	padding: 0 15px;
	width: 100%;
	z-index: 1;
	position: relative;
}
.txt-white{
	color: #fff!important;
}
.bg-green{
	background-color: #EEF5E7;
	padding: 50px 0 20px;
}

.align-right{
	text-align: right!important;
}
.tb-parts{
	display: none!important;
}
.pc-parts{
	display: none!important;
}
.anime_wrap{
 	position: relative;
 	overflow: hidden;
}
.slideUp{
 	opacity: 0;
 	transform: translateY(40px);
 	transition: 1.5s;
}
.slideUp.show{
	opacity: 1!important;
	transform: translateY(0);
	overflow: visible;
}
.fadeIn{
	opacity: 0;
	transition: 1.5s;
}
.fadeIn.show{
	opacity: 1!important;
	overflow: visible;
}
.curtain::before{
 	content: '';
	width: 100%;
 	height: 100%;
 	position: absolute;
	left: 0;
	top: 0;
 	background: #FFF;
 	z-index: 2;
 	transition: 1s;
}
.curtain.show::before{
 	transform: translateX(100%);
}
.curtain{
	opacity: 0;
	transition: .5s;
}
.curtain.show{
	opacity: 1;
}
svg {
  backface-visibility: hidden;
  transform: translateZ(0);
}
.wp-title {
	display: none;
}
img[src$=".svg"],
img[src$=".jpg"],
img[src$=".png"]{
    width: 100%;
}
.rampartone{
	font-family: "Rampart One", serif;
	font-weight: 400;
	font-style: normal;
}
.dotlist li{
	list-style-type: disc;
	list-style-position:inside;
	padding-left: 0.5rem;
}
.mb0{
	margin-bottom: 0!important;
}

@media print, screen and (min-width: 600px) {
body{
	font-size: 1.5rem;
	border: none;
}
section{
	width: 100%;
	margin-bottom: 60px;
}
section p{
	margin-bottom: 35px;
	padding: 0 40px;
}
.sp-parts{
	display: none;
}
.align-center{
	text-align: center!important;
}
.bg-green{
	margin-bottom: 0;
}
}

@media print, screen and (min-width: 980px) {
body{
	font-size: 1.6rem;
	line-height: 1.8;
}
/*section{
	margin-bottom: 110px;
}*/
.pc-parts{
	display: block;
}
}

@media print, screen and (min-width: 1200px) {
section p{
	margin-bottom: 35px;
	padding: 0;
}
}

@media print, screen and (min-width: 1730px) {
body{
	font-size: 1.7rem;
	line-height: 1.88;
}
section p{
	margin-bottom: 40px;
}
}

@page {
    margin: 0;
    size: 210mm 297mm; /* A4縦サイズ */
}

@media print {
body {
    zoom: 0.5;
}
}

/* header -------------------- */
header{
	width: 100%;
}
.logo{
	width: 220px;
	height: auto;
	margin: 15px 15px 0 15px;
}

@media print, screen and (min-width: 600px) {
.logo{
	width: 250px;
	height: auto;
	margin: 15px 15px 0 40px;
}
}

@media print, screen and (min-width: 1200px) {
header{
	width: calc(100% - 80px);
	margin: 0 auto;
	padding: 25px 0 5px;
	display: flex;
	justify-content: space-between;
}
.logo{
	width: 330px;
	height: auto;
	margin:0;
}
}

@media print, screen and (min-width: 1730px) {
header{
	padding: 30px 0 5px;
	width: calc(100% - 220px);
	max-width: 1800px;
	margin: 0 auto;
}
.logo{
	width: 352px;
	height: auto;
	margin:0;
}
}


/* navigation write pc first-------------------- */
#global-nav ul{
	display: flex;
	width: calc(100%-352px);
	font-size: 1.8rem;
 	font-weight: bold;
	align-items: center;
}
#global-nav ul li{
	margin-left: 60px;
}
.gnavi-txt a{
	position: relative;
	padding-bottom: 5px;
}
.gnavi-txt a:hover{
	color: #98E05F;
}
.gnavi-txt a::after{
	content: "";
	display: block;
	width: 100%;
	height: 3px;
	background: #98E05F;
	position: absolute;
	left: 0;
	bottom: 0;
	transform: scale(0,1);
	transition: all .3s ease-in-out;
}
.gnavi-txt a:hover::after{
  transform: scale(1,1);
}
.nav-contact{
	color: #fff;
	background-color: #FC9439;
	width: 210px;
	height: 60px;
	border-radius: 25px;
	border: solid 2px #FC9439;
	text-align: center;
	position: relative;
	transition: all .3s;
}
.nav-contact:hover{
	color: #FC9439;
	background-color: #fff;
}
.nav-contact a{
	position: absolute;
	top: 0;
	left: 0;
	height:100%;
	width: 100%;
	padding-top: 11px!important;
}
#nav-toggle{
	display: none;
}
.pc-none{
    display: none;
}

@media screen and (max-width: 1729px) {
#global-nav ul{
	width: calc(100%-120px);
	font-size: 1.6rem;
}
#global-nav ul li{
	margin-left: 35px;
}
.nav-contact{
	width: 200px;
	height: 60px;
}
.nav-contact a{
	padding-top: 14px!important;
}
}

@media screen and (max-width: 1399px) {
#global-nav ul{
	font-size: 1.5rem;
}
#global-nav ul li{
	margin-left: 25px;
}
.nav-contact{
	width: 150px;
	height: 60px;
}
}

@media screen and (max-width: 1199px) {
#nav-toggle {
	display: block;
	position: fixed;
	top: 15px;
	right: 40px;
	width: 50px;
	height: 50px;
	cursor: pointer;
	background-color: #FC9439;
	color: #fff;
	border-radius: 13px;
}
#nav-toggle > div {
	position: relative;
	width: 30px;
	margin: 13px auto;
}
#nav-toggle span {
	width: 100%;
	height: 2px;
	left: 0;
	display: block;
	background: #fff;
	position: absolute;
	-webkit-transition: top .5s ease, -webkit-transform .6s ease-in-out;
	transition: top .5s ease, -webkit-transform .6s ease-in-out;
	transition: transform .6s ease-in-out, top .5s ease;
	transition: transform .6s ease-in-out, top .5s ease, -webkit-transform .6s ease-in-out;
}
#nav-toggle span:nth-child(1) {
  top: 1px;
}
#nav-toggle span:nth-child(2) {
  top: 8px;
}
#nav-toggle p {
	position: absolute;
	top: 12px;
	font-size: 11px;
	font-family: "Quicksand", serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
}
.open #nav-toggle span {
	background: #fff;
}
.open #nav-toggle span:nth-child(1) {
	top: 10px;
	-webkit-transform: rotate(45deg);
			transform: rotate(45deg);
}

.open #nav-toggle span:nth-child(2) {
	top: 10px;
	-webkit-transform: rotate(-45deg);
			transform: rotate(-45deg);
}
.open #nav-toggle p {
	display: none;
}
/* z-index */
#nav-toggle {
	z-index: 1000;
}
#container {
	z-index: 900;
}
#global-nav {
	background: rgb(152,224,95);
	background: linear-gradient(50deg, rgba(152,224,95,1) 0%, rgba(67,226,142,1) 67%, rgba(50,226,151,1) 84%, rgba(13,227,172,1) 100%);
	color: #fff;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 990;
	text-align: center;
	display: -webkit-box;
	display: flex;
	visibility: hidden;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
			flex-direction: column;
	-webkit-box-pack: center;
			justify-content: center;
	-webkit-box-align: center;
			align-items: center;
	font-size: 22px;
	opacity: 0;
	-webkit-transition: opacity .6s ease, visibility .6s ease;
	transition: opacity .6s ease, visibility .6s ease;
}
#global-nav a {
	display: block;
	color: #fff;
	text-decoration: none;
	padding: 10px 0;
	-webkit-transition: color .6s ease;
	transition: color .6s ease;
}
#global-nav a:hover {
	color: #666;
}
#global-nav ul {
	list-style: none;
	display: block;
	width: 100%;
    font-size: 2.2rem;
}
#global-nav ul li {
	opacity: 0;
	float: none;
	width: 100%;
	margin-left: 0;
    margin-bottom: 10px;
	-webkit-transform: translateX(200px);
			transform: translateX(200px);
	-webkit-transition: opacity .2s ease, -webkit-transform .6s ease;
	transition: opacity .2s ease, -webkit-transform .6s ease;
	transition: transform .6s ease, opacity .2s ease;
	transition: transform .6s ease, opacity .2s ease, -webkit-transform .6s ease;
}
#global-nav ul li:nth-child(2) {
	-webkit-transition-delay: .15s;
			transition-delay: .15s;
}
#global-nav ul li:nth-child(3) {
	-webkit-transition-delay: .3s;
			transition-delay: .3s;
}
#global-nav ul li:nth-child(4) {
	-webkit-transition-delay: .45s;
			transition-delay: .45s;
}
#global-nav ul li:nth-child(5) {
	-webkit-transition-delay: .6s;
			transition-delay: .6s;
}
#global-nav ul li:nth-child(6) {
	-webkit-transition-delay: .75s;
			transition-delay: .75s;
}
#global-nav ul li:nth-child(7) {
	-webkit-transition-delay: .9s;
			transition-delay: .9s;
}
/* open */
.open {
	overflow: hidden;
}
.open #global-nav {
	visibility: visible;
	opacity: 1;
}
.open #global-nav li {
	opacity: 1;
	-webkit-transform: translateX(0);
			transform: translateX(0);
	-webkit-transition: opacity .9s ease, -webkit-transform 1s ease;
	transition: opacity .9s ease, -webkit-transform 1s ease;
	transition: transform 1s ease, opacity .9s ease;
	transition: transform 1s ease, opacity .9s ease, -webkit-transform 1s ease;
}
.pc-none{
    display: block;
}
.nav-contact{
	color: #fff;
	background-color: transparent;
	width: 210px;
	height: 60px;
	border-radius: 25px;
	border: none;
	text-align: center;
	position: relative;
	transition: all .3s;
}
}

@media screen and (max-width: 599px) {
#nav-toggle {
	right: 20px;
}
}

/* mainvis -------------------- */
.mainvis{
	width: 100%;	
	height: 515px;
	padding: 40px 0 85px;
	margin: -45px 0 0;
	background: url(../../../assets/img/bg2.svg) no-repeat;
	background-size: 1100px 655px;
	background-position: bottom -55px left -130px;
}
.mainvis-in{
	position: relative;
	width: 100%;
	height: 300px;
	background: url(../../../assets/img/mainvis-bg.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.mainvis-copy-up{
	width: 130px;
	position: absolute;
	bottom: 110px;
	left: 35px;
}
.mainvis-copy-bt{
	width: 200px;
	position: absolute;
	bottom: 33px;
	left: 30px;
	opacity: 0;
}
.mainvis-copy-bt:after{
	content: url(../../../assets/img/kirakira.svg);
	transform: scale(0.25);
	display: inline-block;
	position: absolute;
	top: -20px;
	right: -30px;
	width: 48px;
	height: 44px;
}
#kira1{
	animation: kira 1s linear infinite;
	opacity:0;
}
@keyframes kira {
from {
transform:scale(0);
opacity:0;
stroke-width:30;
}
50% {
transform:scale(1);
opacity:0.8;
stroke-width:14;
}
to {
transform:scale(0);
opacity:0;
}

}
.mainvis-recruit{
	position: absolute;
	bottom: -95px;
	left: 0;
	width: 100%;
	height: 95px;
	padding-bottom: 40px;
	overflow: visible;
	background: rgb(152,224,95);
	background: linear-gradient(50deg, rgba(152,224,95,1) 0%, rgba(67,226,142,1) 67%, rgba(50,226,151,1) 84%, rgba(13,227,172,1) 100%);
	color: #fff;
}
.mainvis-fukidasi{
	position: absolute;
	top: -15px;
	right: 200px;
	width: 102px;
	height: auto;
	opacity: 0;
}
.mainvis-recruit-txt{
	position: absolute;
	top: 12px;
	right: 55px;
}
.mainvis-recruit-txt .rampartone{
	font-size: 1.8rem;
}
.mainvis-recruit-txt p{
	line-height: 1.3;
	font-size: 1.4rem;
	font-weight: bold;
}
.mainvis-recruit-txt p span{
	line-height: 1.4;
	font-size: 1.8rem;
}
.mainvis-welcome{
	position: absolute;
	top: -95px;
	right: 10px;
	width: 85px;
	height: auto;
	opacity: 0;
}
.anime_copy_up{
	animation: fadeup 2.5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
}
.anime_copy_bt{
	animation: fadeup 2.5s cubic-bezier(0.33, 1, 0.68, 1) 1s forwards;
}
.anime_welcome{
	animation: welcome 0.6s cubic-bezier(0.12, 0, 0.39, 0) 3.8s forwards;
}
.anime_fukidasi{
	animation: fukidasi 0.3s ease-in 4.6s forwards;
}

@keyframes fadeup {
0% {
	transform: translateY(40px);
	opacity: 0;
}
80% {
	opacity: 1;
}
100% {
	opacity: 1;
	transform: translateY(0);
}
}
@keyframes welcome {
0% {
	transform: translateY(80px);
	opacity: 0;
}
50% {
	transform: translateY(0);
}
65% {
	transform: translateY(30px);
}
75% {
	transform: translateY(0);
}
82% {
	transform: translateY(10px);
}
100% {
	transform: translateY(0);
}
20%,100% {
	opacity: 1;
}
}
@keyframes fukidasi {
0% {
	transform: rotateX(-90deg);
}
100% {
	opacity: 1;
	transform: rotateX(0deg);
}
}


@media print, screen and (min-width: 375px) {
.mainvis-fukidasi{
	right: 245px;
}
.mainvis-recruit-txt{
	right: 90px;
}
}

@media print, screen and (min-width: 640px) {
.mainvis{
	/*background-size: 1300px 655px;*/
	background-size: 1500px 760px;
	background-position: bottom -60px left -130px;
    height: 615px;
	padding: 40px 0 85px;
	margin: -45px 0 0;
}
.mainvis-in{
	width: calc(100% - 80px);
	height: 500px;
	margin: 0 40px;
	border: solid 10px #98E05F;
	border-radius: 20px;
}
.mainvis-copy-up{
	width: 180px;
	position: absolute;
	bottom: 148px;
	left: 45px;
}
.mainvis-copy-bt{
	width: 270px;
	position: absolute;
	bottom: 43px;
	left: 40px;
}
.mainvis-copy-bt:after{
	transform: scale(0.35);
	top: -30px;
	right: -40px;
	width: 70px;
	height: 63px;
}
.mainvis-recruit{
	bottom: 0px;
	left:auto;
	right: 0;
	width: 270px;
	height: 95px;
	padding-bottom:0;
	border-radius: 20px 0 10px 0;
}
.mainvis-fukidasi{
	top: -120px;
	right: 90px;
	width: 110px;
	height: auto;
}
.mainvis-welcome{
	top: -120px;
	right: -10px;
	width: 100px;
	height: auto;
}
}

@media print, screen and (min-width: 1200px) {
.mainvis{
	height: 850px;
	padding: 120px 0 120px;
	margin: -120px 0 0;
	background-size: 1800px 900px;
	background-position: bottom left;
}
.mainvis-in{
	width: calc(100% - 80px);
	height: 600px;
	margin: 0 40px;
	border: solid 20px #98E05F;
    border-radius: 40px;
}
.mainvis-copy-up{
	width: 22%;
	max-width: 250px;
	bottom: 220px;
	left: 95px;
}
.mainvis-copy-bt{
	width: 30%;
	max-width: 390px;
	bottom: 80px;
	left: 90px;
}
.mainvis-copy-bt:after{
	transform: scale(0.5);
	top: -40px;
	right: -50px;
	width: 70px;
	height: 63px;
}
.mainvis-recruit{
	bottom: 0px;
	left:auto;
	right: 0;
	width: 380px;
	height: 160px;
	padding-bottom:0;
	border-radius: 30px 0 15px 0;
}
.mainvis-fukidasi{
	top: -250px;
	right: 120px;
	width: 160px;
	height: auto;
}
.mainvis-recruit-txt{
	top: 25px;
	right: 150px;
}
.mainvis-recruit-txt .rampartone{
	font-size: 2.2rem;
}
.mainvis-recruit-txt p{
	line-height: 1.5;
	font-size: 1.8rem;
}
.mainvis-recruit-txt p span{
	line-height: 1.7;
	font-size: 2.2rem;
}
.mainvis-welcome{
	top: -210px;
	right: 10px;
	width: 160px;
	height: auto;
}
}

@media print, screen and (min-width: 1730px) {
.mainvis{
	/*height: 1110px;*/
    height: 1000px;
	padding: 120px 0 120px;
	margin: -120px 0 0;
	background-size: 100% 105%;
	background-position: bottom left;
}
.mainvis-in{
	width: calc(100% - 220px);
	max-width: 1800px;
	/*height: 870px;*/
    height: 770px;
	margin: 0 auto 110px;
	border: solid 20px #98E05F;
}
.mainvis-copy-up{
	width:340px;
	max-width:340px;
	bottom: 290px;
	left: 125px;
}
.mainvis-copy-bt{
	width: 520px;
	max-width: 520px;
	bottom: 90px;
	left: 120px;
}
.mainvis-recruit{
	width: 440px;
	height: 196px;
}
.mainvis-fukidasi{
	top: -270px;
	right: 120px;
}
.mainvis-recruit-txt{
	top: 39px;
	right: 170px;
}
.mainvis-recruit-txt .rampartone{
	font-size: 2.4rem;
}
.mainvis-recruit-txt p{
	line-height: 1.8;
	font-size: 1.8rem;
}
.mainvis-recruit-txt p span{
	line-height: 1.5;
	font-size: 2.6rem;
}
.mainvis-welcome{
	top: -200px;
	right: 10px;
	width: 175px;
}
}

/* h2/h3 title -------------------- */
h2{
	font-size: 1.8rem;
	line-height: 1.6;
	padding: 0 15px;
	margin-bottom: 35px;
	width: 100%;
	font-weight: bold;
	letter-spacing: 0.1em;
	color: #359869;
}
h3{
	font-size: 1.7rem;
	line-height: 1.5;
	padding: 0 15px;
	letter-spacing: 0.1em;
	color: #359869;
	font-weight: bold;
	position: relative;
}
h3::before{
	content: "●";
	left:0;
}
.subttl-en{
	font-family: "Rampart One", serif;
	font-weight: 400;
	font-size: 2rem;
	letter-spacing: 0.01em;
}
.subttl-en span{
	font-size: 2.5rem;
	padding-right: 5px;
}
.subttl-txt{
	position: relative;
	display: inline-block;
}
.first-subttl-en{
    animation-duration: 1.5s;
    animation-delay: 1s;
	animation-fill-mode: forwards;
	animation-name: second-ttl;
	transform: translateY(40px);
	opacity: 0; 
}
.first-subttl{
	animation-duration: 1.5s;
    animation-delay: 1.3s;
	animation-fill-mode: forwards;
	animation-name: second-ttl;
	transform: translateY(40px);
	opacity: 0;
}

@media print, screen and (min-width: 600px) {
h2{
	font-size: 2rem;
	line-height: 1.6;
	padding: 0 40px;
	margin-bottom: 40px;
}
h3{
	font-size: 1.8rem;
	line-height: 1.5;
	padding: 0 40px;
	margin-bottom: 10px;
}
.subttl-en{
	font-size: 2.4rem;
}
.subttl-en span{
	font-size: 3.8rem;
	padding-right: 5px;
}
}

@media print, screen and (min-width: 1200px) {
h2{
	font-size: 2.8rem;
	line-height: 1.6;
	padding: 0;
	margin-bottom: 40px;
	letter-spacing: 0.06em;
}
h3{
	font-size: 2.2rem;
	line-height: 1.5;
	padding: 0;
	margin-bottom: 20px;
}
.subttl-en{
	font-size: 3.2rem;
}
.subttl-en span{
	font-size: 6rem;
	padding-right: 10px;
}
}

@media print, screen and (min-width: 1730px) {
h2{
	font-size: 3.2rem;
	line-height: 1.6;
	padding: 0;
	margin-bottom: 50px;
	letter-spacing: 0.06em;
}
.subttl-en{
	font-size: 3.5rem;
}
.subttl-en span{
	font-size: 6.5rem;
}
}

/* btn -------------------- */
.common-btn{
	width: 280px;
	height: 70px;
	margin: 0 auto 35px;
	color: #fff;
	font-size: 1.6rem;
	font-weight: bold;
	text-align: center;
	position: relative;
	z-index: 0;
}
.common-btn:before{
	content: "";
	width: 100%;
	height: 100%;
	border-radius: 25px;
	position: absolute;
	left: 0;
	transition: all .5s;
	z-index: -1;
	background: rgb(152,224,95);
	background: linear-gradient(50deg, rgba(152,224,95,1) 0%, rgba(67,226,142,1) 67%, rgba(50,226,151,1) 84%, rgba(13,227,172,1) 100%);
}
.common-btn a{
	position: absolute;
	top: 0;
	left: 0;
	height:100%;
	width: 100%;
	padding-top: 22px;
}

@media print, screen and (min-width: 600px) {
.common-btn:after{
	content: "";
	width: 100%;
	height: 100%;
	border-radius: 25px;
	position: absolute;
	left: 0;
	z-index: -2;
	background: rgb(183,249,156);
	background: linear-gradient(70deg, rgba(183,249,156,1) 0%, rgba(59,243,180,1) 42%, rgba(85,231,236,1) 71%, rgba(34,207,242,1) 100%);
}
.common-btn:hover:before{
	opacity:0;
}
}

@media print, screen and (min-width: 1200px) {
.common-btn{
	width: 340px;
	height: 80px;
	margin: 0 0 35px 0;
	border-radius: 25px;
	font-size: 1.8rem;
}
}


/* top page -------------------- */
.photo-block{
	width: 100%;
	height: auto;
	margin-bottom: 35px;
}
.block-wrap1{
    margin-bottom: 40px;
}
.top-reform{
    margin-bottom: 70px;
}
.top-craftsmanship .subttl-txt:after{
	content: "";
	display: inline-block;
	position: absolute;
	top: -12px;
	left:220px;
	width: 65px;
	height: 60px;
	background: url(../../../assets/img/kirakira.svg) no-repeat;
	background-size: cover;
	background-position: center;
}
.top-reform .subttl-txt:after{
	content: "";
	display: inline-block;
	position: absolute;
	top: -8px;
	left:240px;
	width: 65px;
	height: 60px;
	background: url(../../../assets/img/icon-drill.svg) no-repeat;
	background-size: cover;
	background-position: center;
	animation: swing 2s linear infinite;
}
.top-voice .subttl-txt:after{
	content: "";
	display: inline-block;
	position: absolute;
	top: -8px;
	left:240px;
	width: 72px;
	height: 75px;
	background: url(../../../assets/img/icon-helmet.svg) no-repeat;
	background-size: cover;
	background-position: center;
	animation: swing 2s linear infinite;
}
.top-recruit .subttl-txt:after{
	content: "";
	display: inline-block;
	position: absolute;
	top: -30px;
	left:260px;
	width: 40px;
	height: 80px;
	background: url(../../../assets/img/icon-hammer.svg) no-repeat;
	background-size: cover;
	background-position: center;
	animation: swing 2s linear infinite;
}
@keyframes swing {
0% , 100%{
	transform: rotate(13deg);
}
50%{
	transform: rotate(-13deg);
}
}
.reform-ex-box{
	width: 100%;
	margin-bottom: 30px;
	display: flex;
	flex-wrap: wrap;
}
.reform-ex-box li{
	width: 50%;
	aspect-ratio: 1/1;
	position: relative;
	opacity: 0;
}
.reform-ex-box li span{
	position: absolute;
	bottom: 0;
	right: 0;
	width: 100px;
	height: 40px;
	text-align: center;
	border-radius: 10px 0 0 0;
	font-weight: bold;
	line-height: 40px;
	color: #FFF;
	background: rgb(152,224,95);
	background: linear-gradient(50deg, rgba(152,224,95,1) 0%, rgba(67,226,142,1) 67%, rgba(50,226,151,1) 84%, rgba(13,227,172,1) 100%);
}
.reform-ex-box li:nth-child(1){
	background: url(../../../assets/img/reform-ex01.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.reform-ex-box li:nth-child(2){
	background: url(../../../assets/img/reform-ex02.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.reform-ex-box li:nth-child(3){
	background: url(../../../assets/img/reform-ex03.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.reform-ex-box li:nth-child(4){
	background: url(../../../assets/img/reform-ex04.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.reform-ex-box li:nth-child(5){
	background: url(../../../assets/img/reform-ex05.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.reform-ex-box li:nth-child(6){
	background: url(../../../assets/img/reform-ex06.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.reform-ex-box li:nth-child(7){
	background: url(../../../assets/img/reform-ex07.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.reform-ex-box li:nth-child(8){
	background: url(../../../assets/img/reform-ex08.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.top-recruit-box .photo-block{
	margin-bottom: 25px;
}
.top-recruit-box .common-btn{
	margin-bottom: 60px;
}
.delay100ms.show{
    animation-name: delay100ms;
    animation-delay: 0.1s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(30px);
	opacity: 0;
}
.delay300ms.show{
    animation-name: delay300ms;
    animation-delay: 0.3s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(30px);
	opacity: 0;
}
.delay500ms.show{
    animation-name: delay500ms;
    animation-delay: 0.5s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(30px);
	opacity: 0;
}
.delay700ms.show{
    animation-name: delay700ms;
    animation-delay: 0.7s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(30px);
	opacity: 0;
}
.delay900ms.show{
    animation-name: delay900ms;
    animation-delay: 0.9s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateY(30px);
	opacity: 0;
}
@keyframes delay100ms {
0% {
}
100% {
	transform: translateY(0);
	opacity: 1;
}
}
@keyframes delay300ms {
0% {
}
100% {
	transform: translateY(0);
	opacity: 1;
}
}
@keyframes delay500ms {
0% {
}
100% {
	transform: translateY(0);
	opacity: 1;
}
}
@keyframes delay700ms {
0% {
}
100% {
	transform: translateY(0);
	opacity: 1;
}
}
@keyframes delay900ms {
0% {
}
100% {
	transform: translateY(0);
	opacity: 1;
}
}


@media print, screen and (min-width: 640px) {
.photo-block{
	width: calc(100% - 80px);
	max-width: 680px;
	margin: 0 auto 40px;
}
.photo-block img{
	border: solid 10px #98E05F;
	border-radius: 20px;
}
.top-craftsmanship .subttl-txt:after{
	top: -30px;
	left: auto;
	right: -55px;
	width: 65px;
	height: 60px;
}
.top-reform{
	width: 100%;
	background: url(../../../assets/img/ttl-bg.svg) no-repeat;
	background-size: 100%;
	background-position: top 35% left 0;	
}
.top-reform .subttl-txt:after{
	top: -18px;
	left: auto;
	right: -40px;
	width: 65px;
	height: 60px;
}
.top-voice .subttl-txt:after{
	top: -22px;
	left: auto;
	width: 72px;
	height: 75px;
}
.top-recruit .subttl-txt:after{
	top: -38px;
	left: auto;
	width: 40px;
	height: 80px;
}
.reform-ex-box li{
	width: 25%;
}
.top-recruit-box{
	display: flex;
	width: 100%;
}
.top-recruit-box li{
	width: 33.33%;
}
.top-recruit-box .photo-block{
	margin-bottom: 15px;
	width: 100%;
}
.top-recruit-box .photo-block img{
	border: none;
	border-radius: 0;
}
.top-recruit-box .common-btn{
	width: 190px;
	height: 60px;
	margin-bottom: 40px;
}
.top-recruit-box .common-btn a{
	padding-top: 17px
}
}

@media print, screen and (min-width: 1200px) {
.block-wrap1{
	width: calc(100% - 80px);
	max-width: 1800px;
	margin: 0 auto;
}
.block-wrap1 li{
	width: 50%;
}
.block-wrap1 li:first-child{
	float: left;
}
.block-wrap1 .photo-block{
	float: right;
	width: calc(50% - 40px);
	max-width: none;
	margin: 30px 0 0 40px;
}
.photo-block img{
	border-radius: 30px;
}
.txt-center-box{
	width: 75%;
	max-width: 900px;
	margin: 0 auto 50px;
}
.top-craftsmanship .subttl-txt:after{
	top: -40px;
	left: auto;
	right: -90px;
	width: 102px;
	height: 94px;
}
.top-reform{
    margin-bottom: 100px;
}
.top-reform .subttl-txt:after{
	top: -35px;
	left: auto;
	right: -65px;
	width: 102px;
	height: 94px;
}
.top-voice .subttl-txt:after{
	top: -36px;
	left: auto;
	width: 106px;
	height: 111px;
}
.top-recruit .subttl-txt:after{
	top: -38px;
	left: auto;
	width: 60px;
	height: 120px;
}
.reform-ex-box{
	width: calc(100% - 80px);
	max-width: 1800px;
	margin: 0 auto 30px;
	justify-content: space-between;
}
.reform-ex-box li{
	width: calc(25% - 15px);
	aspect-ratio: 4/3;
	border-radius: 20px;
	margin-bottom: 20px;
}
.reform-ex-box li span{
	width: 150px;
	height: 50px;
	border-radius: 20px 0 20px 0;
	line-height: 50px;
}
.btn-center{
	margin: 0 auto;
}
.top-recruit-box{
	width: calc(100% - 80px);
	max-width: 1800px;
	margin: 0 auto;
	justify-content: space-between;
}
.top-recruit-box li{
	width:calc(33% - 20px);
}
.top-recruit-box .photo-block img{
	border: solid 10px #98E05F;
	border-radius: 30px;
}
.top-recruit-box .common-btn{
	width: 260px;
	height: 80px;
	margin: 0 auto 40px;
}
.top-recruit-box .common-btn a{
	padding-top: 25px
}
}

@media print, screen and (min-width: 1730px) {
.block-wrap1{
	width: calc(100% - 220px);
}
.block-wrap1 .photo-block{
	width: calc(50% - 75px);
	max-width: none;
	margin: 35px 0 0 75px;
}
.reform-ex-box{
	width: calc(100% - 220px);
}
.reform-ex-box li{
	width: calc(25% - 22.5px);
	aspect-ratio: 4/2.75;
	border-radius: 30px;
	margin-bottom: 30px;
}
.reform-ex-box li span{
	width: 190px;
	height: 60px;
	font-size: 1.9rem;
	border-radius: 30px 0 30px 0;
	line-height: 60px;
}
.top-recruit-box{
	width: calc(100% - 220px);
}
.top-recruit-box .common-btn{
	width: 340px;
}
}

/* common contact -------------------- */
.contact-box-wrap{
	padding: 30px 0 60px;
	background-color: #ffffff;
	background-image: radial-gradient(circle, #efefef 5px, transparent 5px), radial-gradient(circle, #efefef 5px, transparent 5px);
	background-position: 0 0, 15px 30px;
	background-size: 30px 60px;
}
.contact-box {
	padding: 0 25px;
}
.contact-box li{
	width: 100%;
	margin: 0 auto 15px;
	text-align: center;
	padding: 15px;
}
.contact-tel{
	background-color: #98E05F;
	border-radius: 25px;
	color: #fff;
    height: 133px;
}
.contact-tel img{
	width: 45px;
	height: auto;
}
.telnumber{
	font-family: "Quicksand", serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
	font-size: 2.6rem;
	letter-spacing: 0.07em;
	margin-bottom: 0;
	line-height: 1;
}
.business-hour{
	font-weight: bold;
	font-size: 1.4rem;
	margin-bottom: 0;
	padding: 0;
}
.contact-mail{
	background-color: #FC9439;
	border-radius: 25px;
    height: 133px;
    position:relative
}
.contact-mail a{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.icon-mail{
	margin: 18px 0 5px 0;
}
.icon-mail img{
	width: 52px;
	height: auto;
	margin: 10px 0 5px 0;
}
.ttl-mail{
	margin-bottom: 5px;
}
.ttl-mail img{
	width: 200px;
	height: auto;
	margin-bottom: 0;
}


@media print, screen and (min-width: 640px) {
.contact-box-wrap{
	padding: 60px 40px 30px;
	margin-bottom: 0;
}
.contact-box-wrap .subttl-txt:after{
	content: "";
	display: inline-block;
	position: absolute;
	top: -30px;
	right:-120px;
	width: 110px;
	height: 110px;
	background: url(../../../assets/img/icon-contact.svg) no-repeat;
	background-size: cover;
	background-position: center;
}
.contact-box{
	width: 100%;
	max-width: 800px;
	margin: 0 auto 40px;
	display: flex;
	justify-content: space-between;
}
.contact-box li{
	width: calc(50% - 20px);
	padding: 25px 15px;
}
.contact-tel,
.contact-mail{
    height: auto;
}
.icon-mail{
	margin: 22px 0 2px 0;
}
}

@media print, screen and (min-width: 1200px) {
.contact-box-wrap .subttl-txt:after{
	right:-140px;
	width: 130px;
	height: 130px;
}
.contact-box-wrap{
	padding: 80px 40px 60px;
}
.contact-box{
	max-width: 1100px;
}
.contact-box li{
	width: calc(50% - 40px);
	padding: 55px 15px;
}
.contact-tel img{
	width: 70px;
}
.telnumber{
	font-size: 3.6rem;
}
.business-hour{
	font-size: 1.9rem;
}
.icon-mail{
	margin: 50px 0 8px 0;
}
.icon-mail img{
	width: 80px;
}
.ttl-mail img{
	width: 280px;
}
}

@media print, screen and (min-width: 1730px) {
.contact-box-wrap .subttl-txt:after{
	right:-160px;
	width: 150px;
	height: 150px;
}
.contact-box{
	max-width: 1200px;
}
.contact-box li{
	width: calc(50% - 50px);
	padding: 60px 15px;
}
.icon-mail{
	margin: 60px 0 3px 0;
}
}

/* footer -------------------- */
footer{
	width: 100%;
	padding: 60px 15px 30px;
	color: #fff;
	background: url(../../../assets/img/footer-bg.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.footer-company{
	margin-bottom: 50px;
}
.footer-company img{
	width: 275px;
	height:auto;
	margin-bottom: 15px;
}
.footer-menu{
	margin-bottom: 35px;
}
.footer-menu li{
	margin-bottom: 5px;
}
.footer-btn{
	width: 270px;
	height: 100px;
	border-radius: 25px;
	margin: 0 auto 60px;
	position: relative;
	z-index:0;
}
.footer-btn:before{
	content: "";
	width: 100%;
	height:100%;
	border-radius: 25px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	transition:0.5s;
	background: rgb(152,224,95);
	background: linear-gradient(50deg, rgba(152,224,95,1) 0%, rgba(67,226,142,1) 67%, rgba(50,226,151,1) 84%, rgba(13,227,172,1) 100%);
}
.footer-btn a{
	position: absolute;
	top: 0;
	left: 0;
	height:100%;
	width: 100%;
	/*padding-top: 22px;*/
}
.footer-btn .rampartone{
	font-size: 1.6rem;
}
.footer-btn p{
	line-height: 1.1;
	font-size: 1.4rem;
	font-weight: bold;
	position: absolute;
	top: 10px;
	left: 60px;
	height:100%;
	width: 100%;
}
.footer-btn p span{
	line-height: 1.8;
	font-size: 1.8rem;
}
.copyright{
	font-family: "Quicksand", serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	font-size: 1.5rem;
	letter-spacing: 0.03em;
	line-height: 1.4;
	text-align: center;
}

@media print, screen and (min-width: 640px) {
footer{
	padding: 60px 40px 40px;
}
.footer-in{
	display: flex;
	flex-wrap: wrap;
}
.footer-company{
	width: 60%;
}
.footer-menu{
	width: 40%;
}
.footer-btn-wrap{
	width: 100%;
}
.footer-btn:after{
	content: "";
	width: 100%;
	height: 100%;
	border-radius: 25px;
	position: absolute;
	top:0;
	left: 0;
	z-index: -2;
	background: rgb(183,249,156);
	background: linear-gradient(70deg, rgba(183,249,156,1) 0%, rgba(59,243,180,1) 42%, rgba(85,231,236,1) 71%, rgba(34,207,242,1) 100%);
}
.footer-btn:hover:before{
	opacity:0;
}
}

@media print, screen and (min-width: 1200px) {
footer{
	padding: 60px 0 40px 40px;
}
.footer-company img{
	width: 320px;
	margin-bottom: 25px;
}
.footer-in{
	margin-bottom: 30px;
}
.footer-company{
	width: calc(100% - 550px);
}
.footer-menu{
	width: 250px;
}
.footer-menu ul li{
	margin-bottom: 10px;
}
.footer-btn-wrap{
	width: 300px;
}
.footer-btn{
	margin: 15px 0 0 0;
	width: 300px;
	height: 140px;
}
.footer-btn:before,
.footer-btn:after{
	border-radius: 30px 0 0 30px;
}
.footer-btn .rampartone{
	font-size: 2.0rem;
}
.footer-btn p{
	line-height: 1.2;
	font-size: 1.6rem;
	top: 20px;
	left: 50px;
}
.footer-btn p span{
	line-height: 1.8;
	font-size: 2.2rem;
}
}

@media print, screen and (min-width: 1730px) {
footer{
	padding: 100px 0 65px 110px;
}
.footer-company img{
	width: 350px;
	margin-bottom: 25px;
}
.footer-company{
	font-size: 1.7rem;
	width: calc(100% - 960px);
}
.footer-menu{
	font-size: 1.7rem;
	width: 520px;
	margin: 20px 90px 0 0;
}
.footer-menu ul{
	display: flex;
	flex-wrap: wrap;
}
.footer-menu ul li{
	width :50%;
	margin-bottom: 20px;
}
.footer-btn-wrap{
	width: 350px;
}
.footer-btn{
	margin:0;
	border-radius: 30px 0 0 30px;
	width: 350px;
	height: 170px;
}
.footer-btn .rampartone{
	font-size: 2.2rem;
}
.footer-btn p{
	line-height: 1.2;
	font-size: 1.8rem;
	font-weight: bold;
	top: 30px;
	left: 70px;
}
.footer-btn p span{
	line-height: 1.8;
	font-size: 2.4rem;
}
}

/* second-ttl -------------------- */
.second-ttl-wrap{
	width: 100%;
	/*height: 280px;*/
	padding: 70px 0;
	margin: -75px 0 -10px;
	overflow: visible;
	background: url(../../../assets/img/ttl-bg.svg) no-repeat;
	background-size: 1000px 550px;
	background-position: bottom -110px right;
}
.second-ttl{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 140px;
	background-color: rgba(255,255,255,0.7);
	animation-duration: 1.5s;
	animation-fill-mode: forwards;
	animation-name: second-ttl;
	transform: translateY(40px);
	opacity: 0;
}
.second-ttl img{
	width: auto;
	height: 45px;
}
@keyframes second-ttl {
0% {
}
100% {
	transform: translateY(0);
	opacity: 1;
}
}

@media print, screen and (min-width: 600px) {
.second-ttl-wrap{
	padding: 90px 0;
	margin-top: -90px;
	background-size: 1200px 480px;
	background-position: bottom -50px right;
}
.second-ttl{
	width: calc(100% - 40px);
	height: 180px;
	margin: 0 20px;
	background-color: rgba(255,255,255,0.7);
	border: solid 10px #98E05F;
	border-radius: 20px;
}
.second-ttl img{
	width: auto;
	height: 50px;
}
}

@media print, screen and (min-width: 1200px) {
.second-ttl-wrap{
	padding: 100px 0 100px;
	margin-top: -110px;
	background-size: 1730px auto;
	background-position: top 10% right;
	z-index: 100;
}
.second-ttl{
	width: calc(100% - 80px);
	height: 300px;
	margin: 0 40px;
	overflow: visible;
}
.second-ttl img{
	width: auto;
	height: 65px;
}
}

@media print, screen and (min-width: 1730px) {
.second-ttl-wrap{
	padding: 110px 0 190px;
	margin: -110px 0 -130px;
	background-size: 100% auto;
	background-position: top 10% right;
	z-index: 100;
}
.second-ttl{
	width: calc(100% - 220px);
	max-width: 1800px;
	height: 300px;
	margin: 0 auto 110px;
}
.second-ttl img{
	width: auto;
	height: 75px;
}
}

/* common-table -------------------- */
.common-table-wrap{
	padding: 0 5%;
	margin-bottom: 80px;
}
.common-table{
	width: 100%;
	border-bottom: #BBBBBB dashed 1px;
	margin-bottom: 15px;
	padding-bottom: 15px;
}
.common-table dt{
	font-size: 1.7rem;
	font-weight: bold;
	letter-spacing: 0.01;
	color: #359869;
	margin-bottom: 2px;
	padding-left: 2rem;
	position: relative;
}
.common-table dt::before{
	content: "●";
	position: absolute;
	left: 0;
	color: #359869;
}

@media print, screen and (min-width: 600px) {
.common-table-wrap{
	padding: 0 40px;
	margin-bottom: 80px;
}
.common-table{
	display: flex;
}
.common-table dt{
	width: 10em!important;
}
.common-table dd{
    width: calc(100% - 10em - 20px);
}
}

@media print, screen and (min-width: 1200px) {
.common-table-wrap{
	max-width: 880px;
	padding: 0 40px;
	margin: 0 auto 90px;
}
.common-table{
	margin-bottom: 18px;
	padding-bottom: 18px;
}
.common-table dt{
	width: 11em;
}
}


/* recruit -------------------- */
.recruit-illust{
	width: 100%;
	padding-bottom: 30px;
	background: url(../../../assets/img/illust-recruit.svg) no-repeat;
	background-size: 150px auto;
	background-position: bottom right -30px;
	overflow: visible;
}
.recruit-bottom-menu{
    margin-bottom: 0;
}
.recruit-bottom-menu li{
    width: 100%;
    height: 100px;
    position: relative;
}
.recruit-bottom-menu li a{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.recruit-bottom-menu li a:hover{
    opacity: 0.5;
}
.recruit-bottom-menu img{
    display: block;
    height: 40px;
    width: auto;
    margin: 35px auto 0;
}
.recruit-bottom-menu li:first-child{
    background-color: #D3F191;
}
.recruit-bottom-menu li:last-child{
    background-color: #98E05F;
}

@media print, screen and (min-width: 600px) {
.recruit-illust{
	padding-bottom: 0;
	background-size: 200px auto;
	background-position: bottom left 560px;
}
.recruit-bottom-menu{
    display: flex;
    align-items: center;
}
.recruit-bottom-menu li{
    width: 50%;
    height: 100px;
}
}

@media print, screen and (min-width: 1200px) {
.recruit-illust{
	max-width: 880px;
	padding: 0 40px;
	margin: 0 auto 90px;
	background-size: 250px auto;
	background-position: bottom left 600px;
}
.recruit-bottom-menu li{
    height: 180px;
}
.recruit-bottom-menu img{
    height: 60px;
    margin: 65px auto 0;
}
}

@media print, screen and (min-width: 1730px) {
.recruit-illust{
	margin: 0 auto 110px;
	background-size: 260px auto;
	background-position: bottom left 630px;
}
.recruit-bottom-menu li{
    height: 220px;
}
.recruit-bottom-menu img{
    height: 60px;
    margin: 85px auto 0;
}
}

/* company -------------------- */
.message-wrap ul{
	position: relative;
	overflow: visible;
}
.message-wrap li:last-child{
	overflow: visible;
}
.president-wrap{
	width: calc(100% - 30px);
	margin: 0 15px 60px;
	padding-top: 240px;
	position: relative;
}
.president-name{
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 180px;
	padding: 80px 190px 0 25px;
	background: rgb(152,224,95);
	background: linear-gradient(50deg, rgba(152,224,95,1) 0%, rgba(67,226,142,1) 67%, rgba(50,226,151,1) 84%, rgba(13,227,172,1) 100%);
	border-radius: 20px 20px 0 20px;
}
.president-name img{
	display: block;
	width: 110px;
	margin: 0 0 0 auto;
	z-index: 11;
}
.president-photo{
	position: absolute;
	bottom: -8px;
	right: -10px;
	width: 150px;
	height: auto;
}
.company-outline-wrap{
	margin-bottom: 60px;
}
.company-outline-wrap .common-table-wrap{
	margin-bottom:30px;
}
#gmap{
	position: relative;
	padding-bottom: 75%;
	height: 0;
	overflow: hidden;
	margin-bottom: 60px;
}
#gmap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
}

@media print, screen and (min-width: 350px) {
.president-photo{
	right: 20px;
}
}

@media print, screen and (min-width: 600px) {
.president-wrap{
	width: calc(100% - 80px);
	margin: 0 40px 80px;
	padding-top: 280px;
}
.president-name{
	bottom: 0;
	left: auto;
	right: 0;
	width: 550px;
	height: 230px;
	padding: 85px 250px 0 25px;
}
.president-name img{
	width: 135px;
}
.president-photo{
	bottom: -8px;
	right: 30px;
	width: 190px;
	height: auto;
}
.company-photo{
	width: calc(100% - 80px);
	max-width : 680px;
	margin: 0 auto;
}
.company-photo img{
	display: block;
	border: solid 10px #98E05F;
	border-radius: 20px;
}
#gmap{
	width: calc(100% - 80px);
	margin: 0 auto 60px;
	padding-bottom: 60%;
}
}

@media print, screen and (min-width: 1200px) {
.message-wrap{
	width: calc(100% - 80px);
	max-width: 1800px;
	margin: 0 auto 60px;
}
.message-wrap ul{
	display: flex;
}
.message-wrap li{
	align-self: flex-end;
}
.message-wrap li:first-child{
	width: calc(100% - 550px);
}
.message-wrap li:last-child{
	width: 550px;
	padding-bottom: 35px;
}
.president-wrap{
	width: 100%;
	margin: 0 40px 0 50px;
	padding-top: 0;
}
.president-name{
	bottom: 0;
	right: 40px;
	width: 500px;
	height: 350px;
	padding: 180px 330px 0 0;
	border-radius: 30px 30px 0 30px;
}
.president-name img{
	width: 130px;
}
.president-photo{
	bottom: -10px;
	right: 50px;
	width: 290px;
}
.company-outline-wrap{
	width: calc(100% - 80px);
	max-width: 1800px;
	margin: 0 auto 60px;
}
.company-outline-wrap ul{
	display: flex;
	align-items:flex-start;
	justify-content: space-between;
}
.company-outline-wrap li:first-child{
	width: 50%;
}
.company-outline-wrap li:last-child{
	width: 50%;
	padding-left: 50px;
}
.company-outline-wrap .common-table-wrap{
	padding:0;
}
.company-photo{
	width: 100%;
	max-width : initial;
}
.common-wrap{
	width: calc(100% - 80px);
	margin: 0 auto 90px;
	max-width: 1800px;
}
#gmap{
	width:100%;
	margin:0;
	padding-bottom: 40%;
}
}

@media print, screen and (min-width: 1730px) {
.message-wrap,
.company-outline-wrap,
.common-wrap{
	width: calc(100% - 220px);
}
.message-wrap li:first-child{
	width: calc(100% - 670px);
}
.message-wrap li:last-child{
	width: 650px;
	padding-bottom: 35px;
}
.president-name{
	right: 40px;
	width: 600px;
	height: 400px;
	padding: 200px 400px 0 0;
}
.president-name img{
	width: 150px;
}
.president-photo{
	bottom: -11px;
	right: 70px;
	width: 340px;
}
.company-outline-wrap li:last-child{
	padding-left: 70px;
}
}

/* interview -------------------- */
.interview-top-wrap h2,
.interview-block h2{
	margin-bottom: 20px;
}
.interview-top-ogasawara,
.interview-top-fukuchi{
	position: relative;
	width: 100%;
	height: 277px;
	margin-bottom: 20px; 
}
.top-ogasawara-name{
	position: absolute;
	top: 0;
	left: 150px;
	width: 140px;
}
.top-ogasawara-photo{
	position: absolute;
	top:0;
	left:0;
	width: 170px;
	height: auto;
}
.top-fukuchi-name{
	position: absolute;
	top: 0;
	right: 165px;
	width: 140px;
}
.top-fukuchi-photo{
	position: absolute;
	top:0;
	right:0;
	width: 202px;
	height: auto;
}
.interview-block{
	margin-bottom: 40px;
}
.photo-right,
.photo-left{
	margin-bottom: 30px;
}
.ogasawara-talk,
.fukuchi-talk{
	color: #359869;
}
.staff-massage{
	position: relative;
	overflow-y: visible;
	padding-top: 40px;
	margin-top: -40px;
}
.staff-massage dt{
	width: calc(100% - 30px);
	margin: 0 15px;
	height: 200px;
	overflow-y: visible;
	color: #FFF;
	font-family: "Quicksand", serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
	font-size: 1.8rem;
	letter-spacing: 0.07em;
	margin-bottom: 0;
	line-height: 1.2;
	border-radius: 20px 20px 0 20px;
	background: rgb(152,224,95);
	background: linear-gradient(50deg, rgba(152,224,95,1) 0%, rgba(67,226,142,1) 67%, rgba(50,226,151,1) 84%, rgba(13,227,172,1) 100%);
}
.staff-massage dt p{
	position: absolute;
	left: 40px;
	top: 150px;
	padding: 0;
	margin:0;
}
.staff-massage dt span{
	font-size: 3rem;
}
.staff-massage dt img{
	position:absolute;
	width: 80px;
	top: 0;
	right:50px;
}
.staff-massage dd{
	margin-top: 50px;
}

@media print, screen and (min-width: 600px) {
.interview-top-wrap{
	display: flex;
	flex-wrap:wrap;
	margin: 0;
}
.interview-top-txt{
	width: 100%;
}
.interview-top-ogasawara,
.interview-top-fukuchi{
	position: relative;
	width: calc(50% - 40px);
	margin: 0;
}
.interview-top-ogasawara{
	margin-left: 40px;
}
.interview-top-fukuchi{
	margin-right: 40px;
}
.top-ogasawara-name{
	top: 0;
	left: initial;
	right: 20px;
}
.top-ogasawara-photo{
	left:initial;
	right: 150px;
}
.top-fukuchi-name{
	top: 0;
	right: initial;
	left:20px;
}
.top-fukuchi-photo{
	left: 130px;
	right: initial;
}
.photo-right,
.photo-left{
	width: calc(100% - 80px);
	max-width : 680px;
	margin: 0 auto 35px;
}
.photo-right img,
.photo-left img{
	display: block;
	border: solid 10px #98E05F;
	border-radius: 20px;
}
.ogasawara-talk,
.fukuchi-talk{
	padding-left: 120px;
	position: relative;
}
.ogasawara-talk::before{
	content: "";
	display: inline-block;
	position: absolute;
	top: 0;
	left:40px;
	width: 100px;
	height: 100px;
	background: url(../../../assets/img/ogasawara-icon.png) no-repeat;
	background-size: cover;
	background-position: center;
}
.fukuchi-talk::before{
	content: "";
	display: inline-block;
	position: absolute;
	top: 0;
	left:40px;
	width: 100px;
	height: 100px;
	background: url(../../../assets/img/fukuchi-icon.png) no-repeat;
	background-size: cover;
	background-position: center;
}
.staff-massage{
	padding-top: 60px;
	margin-top: -60px;
}
.staff-massage dt{
	width: calc(100% - 80px);
	margin: 0 40px;
	font-size: 2rem;
	border-radius: 30px 30px 0 30px;
}
.staff-massage dt span{
	font-size: 3.4rem;
}
.staff-massage dt p{
	left: 80px;
	top: 145px;
}
.staff-massage dt img{
	width: 90px;
	right:90px;
}
.margin-adjust{
	margin-bottom: 60px;
}
}

@media print, screen and (min-width: 1200px) {
.interview-top-wrap{
	width: calc(100% - 80px);
	max-width: 1800px;
	margin: 0 auto 80px;
	padding-top: 80px;
	flex-wrap: nowrap;
	align-items:flex-end;
	position: relative;
}
.interview-top-wrap::before{
	content:"";
	display: block;
	width: 100%;
	max-width: 1800px;
	height: 200px;
	position: absolute;
	bottom: 0;
	left: 0;
	border-radius: 30px;
	background: rgb(152,224,95);
	background: linear-gradient(50deg, rgba(152,224,95,1) 0%, rgba(67,226,142,1) 67%, rgba(50,226,151,1) 84%, rgba(13,227,172,1) 100%);
}
.interview-top-txt{
	width: 50%;
	min-width: 680px!important;
	padding: 30px 30px 5px 30px;
	margin-bottom: 20px;
	border: solid 10px #98E05F;
	border-radius: 30px;
	background-color: #fff;
	order: 2;
	z-index: 100;
}
.interview-top-ogasawara,
.interview-top-fukuchi{
	position: relative;
	width: 25%;
	margin: 0;
	height: 450px;
	overflow: visible;
}
.interview-top-ogasawara{
	margin-left:0;
	order: 1;
}
.interview-top-fukuchi{
	margin-right: 0;
	order: 3;
}
.top-ogasawara-name{
	top: -60px;
	left: 270px;
	right: initial;
	width: 220px;
	overflow: visible;
}
.top-ogasawara-photo{
	left:0;
	right: initial;
	width: 300px;
}
.top-fukuchi-name{
	top: -60px;
	right: 270px;
	left: initial;
	width: 220px;
	overflow: visible;
}
.top-fukuchi-photo{
	left: initial;
	right: 0;
	width: 340px;
}
.interview-block{
	width: calc(100% - 80px);
	max-width: 1800px;
	margin: 0 auto 60px;
}
.interview-block h2{
	margin-bottom: 40px;
}
.ogasawara-talk,
.fukuchi-talk{
	padding-left: 180px;
}
.ogasawara-talk::before{
	top: 0;
	left:0;
	width: 150px;
	height: 150px;
}
.fukuchi-talk::before{
	top: 0;
	left:0;
	width: 150px;
	height: 150px;
}
.photo-right{
	width: 45%;
	max-width : 760px;
	margin: 0 0 35px 35px;
	float: right;
}
.photo-left{
	width: 45%;
	max-width : 760px;
	margin: 0 35px 35px 0;
	float: left;
}
.photo-right img,
.photo-left img{
	border-radius: 30px;
}
.staff-massage{
	display: flex;
	padding-top: 60px;
	padding-bottom: 60px;
	margin-top: 20px;
}
.staff-massage dt{
	width: 600px;
	height: 380px;
	margin: 0 50px 0 0;
	font-size: 2.6rem;
}
.staff-massage dt span{
	font-size: 4rem;
}
.staff-massage dt p{
	left: 50px;
	top: 200px;
}
.staff-massage dt img{
	width: 140px;
	right:initial;
	left: 250px;
}
.margin-adjust{
	margin-bottom: 60px;
}
.self-employed{
	padding: 80px 0!important;
}
.self-employed p{
	width: 800px;
	margin: 0 auto 30px;
}
}

@media print, screen and (min-width: 1730px) {
.interview-top-wrap{
	width: calc(100% - 220px);
}
.interview-top-txt{
	padding: 40px 60px 20px 60px;
	margin-bottom: 20px;
}
.interview-top-ogasawara,
.interview-top-fukuchi{
	height: 500px;
}
.interview-top-ogasawara{
	margin-left:60px;
}
.interview-top-fukuchi{
	margin-right: 40px;
}
.top-ogasawara-photo{
	left:0;
	right: initial;
	width: 316px;
}
.top-fukuchi-photo{
	width: 374px;
	bottom:0;
}
.top-ogasawara-name{
	top: -60px;
	left: 280px;
	width: 240px;
}
.top-fukuchi-name{
	top: -60px;
	right: 300px;
	width: 240px;
}
.interview-block{
	width: calc(100% - 220px);
}
.photo-right{
	margin: 0 0 50px 70px;
}
.photo-left{
	margin: 0 70px 50px 0;
}
.ogasawara-talk,
.fukuchi-talk{
	padding-left: 210px;
	min-height: 200px;
}
.ogasawara-talk::before{
	width: 170px;
	height: 170px;
}
.fukuchi-talk::before{
	width: 170px;
	height: 170px;
}
.staff-massage dt{
	width: 600px;
	height: 400px;
	margin: 0 60px 0 0;
}
.staff-massage dt span{
	font-size: 4.6rem;
}
.staff-massage dt p{
	left: 70px;
	top: 210px;
}
.staff-massage dt img{
	width: 150px;
	left: 330px;
}
}

/* recruit top-------------------- */
.recurit-top-wrap img{
	margin-bottom: 35px;
}
.company-tour img{
	display: block;
	width: calc(100% - 30px);
	margin:0 auto 30px;
}
.recruit-stop{
    width: calc(100% - 30px);
    padding: 30px;
    margin: 0 15px 50px;
    border-radius: 10px;
    background-color: #EEF5E7;
    border: solid 5px #98E05F;
    text-align: center;
    font-weight: bold;
}

@media print, screen and (min-width: 600px) {
.recurit-top-wrap img{
	display: block;
	border: solid 10px #98E05F;
	border-radius: 20px;
	width: calc(100% - 80px);
	max-width : 680px;
	margin: 0 auto 45px;
}
.company-tour img{
	width: calc(100% - 120px);
	max-width : 500px;
	margin: 0 auto 45px;
}
.recruit-stop{
    width: calc(100% - 80px);
    padding: 30px;
    margin: 0 40px 50px;
    border-radius: 10px;
    max-width: 900px;
}
}

@media print, screen and (min-width: 1200px) {
.recurit-top-wrap img{
	display: none;
}
.recurit-top-wrap{
	display: flex;
	width: calc(100% - 80px);
	max-width: 1800px;
	margin: 0 auto 100px;
}
.recurit-top-photo{
	width: 50%;
	height: auto;
	background: url(../../../assets/img/recruit-top-photo.jpg) no-repeat;
	background-size: cover;
	background-position: left bottom;
}
.recurit-top-txt{
	width: 50%;
	padding: 80px 60px 60px 60px;
	color: #fff;
	border-radius: 0 30px 0 0;
	background: rgb(152,224,95);
	background: linear-gradient(50deg, rgba(152,224,95,1) 0%, rgba(67,226,142,1) 67%, rgba(50,226,151,1) 84%, rgba(13,227,172,1) 100%);
}
.recurit-top-txt h2{
	color: #fff!important;
}
.company-tour{
	display: flex;
	width: calc(100% - 80px);
	max-width: 1800px;
	margin: 0 auto 20px;
}
.company-tour li{
	width: 50%;
}
.company-tour img{
	width: 100%;
	max-width : initial;
	margin: 0;
	padding: 20px 0 0 40px;
}
.recruit-stop{
    width: 100%;
    padding: 40px;
    margin: 0 auto 60px;
    border-radius: 10px;
    max-width: 900px;
}
}

@media print, screen and (min-width: 1730px) {
.recurit-top-wrap,
.company-tour{
	width: calc(100% - 220px);
}
.company-tour{
	margin: 20px auto 60px;
}
.company-tour img{
	padding: 20px 0 0 70px;
}
}

/* customer -------------------- */
.customer-top-wrap img{
	margin-bottom: 35px;
}
.customer-top-photo{
	display: none;
}
.before-photo{
	position: relative;
}
.before-photo::after{
	content:"";
	display: inline-block;
	width: 104px;
	height: 90px;
	position: absolute;
	top: 10px;
	right: 10px;
	background: url(../../../assets/img/icon-before.svg) no-repeat;
	background-size: cover;
	background-position: center;
}
.after-photo{
	position: relative;
	width: 60%;
	max-width: 436px;
	margin: 0 auto 30px;
}
.after-photo::after{
	content:"";
	display: inline-block;
	width: 104px;
	height: 90px;
	position: absolute;
	top: 20px;
	right: -30px;
	background: url(../../../assets/img/icon-after.svg) no-repeat;
	background-size: cover;
	background-position: center;	
}
.Hsama-talk{
	color: #359869;
}
.customer-photo-block{
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	height: auto;
	margin-bottom: 35px;
}
.customer-photo-block li{
	width: 50%;
}
.customer-photo-block li img{
	display: block;
}

@media print, screen and (min-width: 600px) {
.customer-top-wrap img{
	display: block;
	border: solid 10px #98E05F;
	border-radius: 20px;
	width: calc(100% - 80px);
	max-width : 680px;
	margin: 0 auto 45px;
}
.customer-top-txt p:last-child{
	margin-bottom: 0!important;
}
.before-photo::after{
	width: 160px;
	height: 138px;
	position: absolute;
	top: 20px;
	right: 20px;
}
.after-photo::after{
	width: 160px;
	height: 138px;
	top: 30px;
	right: -40px;
}
.Hsama-talk{
	padding-left: 120px;
	position: relative;
}
.Hsama-talk::before{
	content: "";
	display: inline-block;
	position: absolute;
	top: 0;
	left:40px;
	width: 100px;
	height: 100px;
	background: url(../../../assets/img/Hsama-icon.png) no-repeat;
	background-size: cover;
	background-position: center;
}
}

@media print, screen and (min-width: 1200px) {
.customer-top-wrap img{
	display: none;
}
.customer-top-wrap{
	display: flex;
	width: calc(100% - 80px);
	max-width: 1800px;
	margin: 0 auto 100px;
}
.customer-top-photo{
	display: block;
	width: 50%;
	height: auto;
	background: url(../../../assets/img/top-photo02.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.customer-top-txt{
	width: 50%;
	padding: 80px 60px 60px 60px;
	color: #fff;
	border-radius: 30px 0 0 0;
	background: rgb(152,224,95);
	background: linear-gradient(50deg, rgba(152,224,95,1) 0%, rgba(67,226,142,1) 67%, rgba(50,226,151,1) 84%, rgba(13,227,172,1) 100%);
}
.customer-top-txt h2{
	color: #fff!important;
}
.before-photo::after{
	width: 209px;
	height: 180px;
	top: 20px;
	right: 20px;
}
.after-photo::after{
	width: 209px;
	height: 180px;
	top: 40px;
	right: -20px;
}
.Hsama-talk{
	padding-left: 180px;
}
.Hsama-talk::before{
	top: 0;
	left:0;
	width: 150px;
	height: 150px;
}
.after-photo{
	margin: 0 0 0 60px;
}
.customer-photo-block{
	max-width: 1500px;
	justify-content: center;
	margin: 0 auto 80px;
}
}

@media print, screen and (min-width: 1730px) {
.customer-top-wrap{
	width: calc(100% - 220px);
}
}


/* welfare -------------------- */
.dummy{
    width: 100%;
    height:auto;
    aspect-ratio: 1.55/1;
    background-color: #ddd;
    display: flex;
    align-items: center;
}
.dummy p{
    font-weight: bold;
    text-align: center;
    margin-bottom: 0;
}
.center-photo{
    max-width: 500px!important;
}
.welfare-ttl{
    text-align: center;
}
.welfare-ttl img{
    width: auto;
    height: 60px;
}
.training-center-top,
.training-center-detail{
    margin-bottom: 60px;
}
.welfare-figure01{
    padding: 0 15px;
}
.photo-training,
.icon-training{
    display: none;
}
.dormitory{
    margin-bottom: 30px;
    overflow: visible;
}
.domitory-photo{
    position: relative;
    overflow: visible;
}
.domitory-person{
    display: block;
    position: absolute;
    bottom: 8px;
    right: 0;
    left: 0;
    margin: 0 auto;
    width: 27%!important;
    height: auto;
}
.training-second-wrap{
    padding: 50px 0;
}
.meister-block{
    margin-bottom: 60px;
}
.bounty{
    font-weight: bold;
    line-height: 1.3;
}
.bounty span{
    font-size: 2.6rem;
    font-family: "Quicksand", serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
}
.bounty-table{
    margin-bottom: 40px;
}
.incentive{
    margin: 0 0 40px 20px;    
}
.slide-items{
    position: relative;
}
  

@media print, screen and (min-width: 600px) {
.dummy{
	border: solid 10px #98E05F;
	border-radius: 20px;
	width: calc(100% - 80px);
	max-width : 680px;
	margin: 0 auto;
}
.welfare-ttl img{
    height: 70px;
}
.welfare-figure01{
    position: relative;
    padding: 0 40px 20px;
    width: 100%;
    max-width: 760px;
    height: auto;
    overflow: visible;
    margin: 0 auto;
}
.point-training{
    width: 80%;
    max-width: 550px;
    padding-top: 20px;
}
.photo-training{
    display: block;
    position: absolute;
    width: 230px!important;
    height: auto;
    top: -20px;
    left: 550px;
}
.icon-training{
    display: none;
}
.training-ojt-block img,
.domitory-room{
    display: block;
	border: solid 10px #98E05F;
	border-radius: 20px;
	width: calc(100% - 80px);
	max-width : 680px;
	margin: 0 auto;
}
.domitory-person{
    bottom: 10px;
    width: 170px!important;
}
.meister-block img{
    display: block;
    width: calc(100% - 80px);
    max-width: 700px;
    margin: 0 auto;
}
.bounty-table dt{
    width: 6em;
}
.bounty-table dd{
    width: calc(100% - 6em);
}
.incentive{
    margin: 0 0 40px 40px;    
}
.slide-items{
    display: block;
	border: solid 10px #98E05F;
	border-radius: 20px;
	width: calc(100% - 80px);
	max-width : 680px;
	margin: 0 auto;
}
}

@media print, screen and (min-width: 1200px) {
.dummy{
    width: 100%;
    margin:0;
}
.welfare-ttl img{
    height: 95px;
}
.training-center-top{
    display: flex;
    justify-content: space-between;
}
.training-center-top li{
    width: calc(50% - 20px);
}
.training-center-wrap{
    width: 100%;
    padding: 20px 40px 30px 40px;
}
.training-center-detail{
    display: flex;
    justify-content: space-between;
    overflow: visible;
    margin-bottom: 10px;
}
.training-center-detail li{
    width: calc(50% - 20px);
}
.welfare-figure01{
    padding: 50px 0 0 0;
    width: 100%;
    max-width: 760px;
    height: auto;
    overflow: visible;
    margin: 0;
    z-index:10;
}
.photo-training{
    width: 230px!important;
    top: -20px;
    left: 490px;
    z-index: -1;
}
.icon-training{
    display: block;
    position: absolute;
    top: -80px;
    left: 400px;
    width: 160px!important;
    height: auto;
}
.dormitory{
    width: calc(100% - 80px);
    max-width: 1800px;
    margin: 10px auto 50px;
    display: flex;
    justify-content: space-between;
}
.dormitory li{
    width: calc(50% - 20px);
}
.domitory-person{
    bottom: 10px;
    left: 260px;
}
.training-second-wrap{
    padding: 60px 0 0 0;
}
.training-ojt-block{
    max-width: 1800px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;   
}
.training-ojt-block li{
    width: calc(50% - 20px);
}
.training-ojt-block img,
.dormitory img{
	width: 100%;
	max-width: 680px;
	margin: 0;
}
.welfare-wrap{
    display: flex;
    justify-content: space-between; 
}
.welfare-wrap-li{
    width: 48%;
}
.bounty-table{
    /*margin-top: -100px;*/
    padding:0;
    margin: 0;
}
.bounty span{
    font-size: 3.2rem;
}
.incentive{
    margin: 0;    
}
.slide-items{
	margin: 0;
}
}

@media print, screen and (min-width: 1730px) {
.training-center-top li{
    width: calc(50% - 35px);
}
.training-center-wrap{
    width: calc(100% - 240px);
    max-width: 1800px;
    margin: 0 auto 60px;
    padding: 20px 0 30px;
}
.training-center-detail li{
    width: calc(50% - 35px);
}
.welfare-figure01{
    padding: 50px 0 0 0;
    max-width: initial;
    z-index:10;
}
.point-training{
    max-width: 610px;
    padding-top: 0;
}
.photo-training{
    width: 260px!important;
    top: -50px;
    left: 580px;
    z-index: 1;
}
.icon-training{
    top: -100px;
    left: 480px;
    width: 180px!important;
    height: auto;
}
.dormitory{
    width: calc(100% - 240px);
    max-width: 1800px;
    margin: 10px auto 50px;
}
.training-ojt-block li,
.dormitory li{
    width: calc(50% - 35px);
}
.meister-block{
    display: flex;
    justify-content: space-between;   
}
.meister-block li{
    width: calc(50% - 35px);
}
.meister-block img{
    max-width: 800px;
}
.bounty li{
    width: auto;
}
}

/* privacy -------------------- */
.privacy-block{
    padding: 0 15px 50px;
}
.privacy-block dt{
    color: #359869;
    font-weight: bold;
    font-size: 1.7rem;
}

@media print, screen and (min-width: 600px) {
.privacy-block{
    padding: 0 40px 50px;
}
}

@media print, screen and (min-width: 1200px) {
.privacy-block{
    max-width: 900px;
    margin: 0 auto 70px;
    padding: 0;
}
.privacy-block dt{
    font-size: 2rem;
    margin-bottom: 5px;
}
}

/* about -------------------- */
.about-image,
.about-image04{
    margin-bottom: 30px;
}
.since1978{
    display: none;
}
.sekisui-logo{
    width: 320px;
    margin: -20px auto 0;
}

@media print, screen and (min-width: 600px) {
.sekisui-logo{
    width: 439px;
}
.about01-txt,
.about03-txt,
.about-common-txt{
    max-width: 900px;
    margin: 0 auto 60px;
}
.about-image,
.about-image04{
    margin-bottom: 40px;
}
}

@media print, screen and (min-width: 1200px) {
.about-image{
    display: none;
}
.about01{
    position: relative;
    width: 100%;
    height: 600px;
    background: url(../../../assets/img/about-bg01.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.since1978{
    display: block;
    position: absolute;
    bottom: 20px;
    left: 480px;
    width: 250px;
    height: auto;
    z-index: 10;
}
.about01-txt{
    position: absolute;
    bottom: 0;
    left: 50px;
    width: 650px;
    height: auto;
    padding: 50px 50px 10px 50px;
    border-radius: 30px;
    background-color: rgba( 255, 255, 255, 0.85 );
}
/*.sekisui-logo{
    width: 330px;
    margin: 80px auto 90px;
}*/
.about03{
    position: relative;
    width: 100%;
    height: 750px;
    background: url(../../../assets/img/about-bg03.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.about03-txt{
    position: absolute;
    bottom: 0;
    left: 50px;
    width: 800px;
    height: auto;
    padding: 50px 50px 10px 50px;
    border-radius: 30px;
    background-color: rgba( 255, 255, 255, 0.75 );   
}
}

@media print, screen and (min-width: 1730px) {
.about01{
    height: 770px;
}
.since1978{
    bottom: 40px;
    left: 550px;
    width: 300px;
    height: auto;
    z-index: 10;
}
.about01-txt{
    bottom: 20px;
    left: 80px;
    width: 800px;
    padding: 70px 70px 30px 70px;
}
.about03{
    height: 800px;
}
.about03-txt{
    top: 150px;
    bottom: auto;
    left: 50px;
    width: 940px;
    padding: 60px 60px 20px 60px;
}
}

/* renovation -------------------- */
.renovation-menu{
    margin-bottom: 30px;
}
.renovation-menu li{
    list-style-type: disc;
    margin-left: 37px;
    overflow: visible; 
}
.renovation-ex{
    margin-bottom: 40px;
}
.renovation-ex li{
    padding: 40px 0;
}
.renovation-ex li:nth-child(odd){
    background-color: #EFEFEF;
}
.renovation-ex li:nth-child(even){
    background-color: #EEF5E7;
}
.term-cost{
    display: flex;
    margin: 0 15px 30px;
    font-weight: bold;
    font-size: 1.6rem;
}
.renovation-term{
    padding-left: 30px;
    margin-right: 10px;
    position: relative;
}
.renovation-term::before{
    content: "";
    width: 25px;
    height: 24px;
    background: url(../../../assets/img/icon-calendar.svg) no-repeat;
	background-size: cover;
    position: absolute;
    top: 0;
    left:0;
}
.renovation-cost{
    padding-left: 35px;
    position: relative;
}
.renovation-cost::before{
    content: "";
    width: 30px;
    height: 25px;
    background: url(../../../assets/img/icon-wallet.svg) no-repeat;
	background-size: cover;
    position: absolute;
    top: 0;
    left:0;
}
.renovation-ex-photo img{
    display: block;
}
.renovation-before{
    margin-bottom: 15px;
    position: relative;
}
.renovation-before::after{
	content:"";
	display: inline-block;
	width: 104px;
	height: 90px;
	position: absolute;
	top: 10px;
	right: 10px;
	background: url(../../../assets/img/icon-before.svg) no-repeat;
	background-size: cover;
	background-position: center;
}
.renovation-after{
    position: relative;
    margin-bottom: 15px;
}
.renovation-after::after{
	content:"";
	display: inline-block;
	width: 104px;
	height: 90px;
	position: absolute;
	top: 10px;
	right: 10px;
	background: url(../../../assets/img/icon-after.svg) no-repeat;
	background-size: cover;
	background-position: center;
}

@media print, screen and (min-width: 600px) {
.renovation-menu{
    margin: 0 40px 30px;
    display: flex;
    flex-wrap: wrap;
}
.renovation-menu li{
    width: calc(50% - 40px);
    margin-left: 22px;
}
.renovation-ex li{
    padding: 50px 0;
}
.term-cost{
    margin: 0 40px 40px;
    font-weight: bold;
    font-size: 1.6rem;
}
.renovation-term{
    padding-left: 55px;
    margin-right: 40px;
}
.renovation-term::before{
    width: 47px;
    height: 45px;
    top: -10px;
    left:0;
}
.renovation-cost{
    padding-left: 60px;
}
.renovation-cost::before{
    width: 54px;
    height: 45px;
    top: -10px;
    left:0;
}
.renovation-ex-photo img{
    border: solid 10px #98E05F;
	border-radius: 20px;
}
.renovation-before,
.renovation-after{
	width: calc(100% - 80px);
	max-width : 680px;
	margin: 0 auto 25px;
}
.renovation-before::after,
.renovation-after::after{
	width: 160px;
	height: 138px;
	top: 20px;
	right: 20px;
}
}

@media print, screen and (min-width: 1200px) {
.renovation-photo{
	background: url(../../../assets/img/renovation-photo01.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.renovation-intro-wrap{
    display: flex;
    width: 100%;
    margin-bottom: 50px;
}
.renovation-intro-txt{
    width: 55%;
    margin-right: 70px;
}
.renovation-intro-menu{
    width: calc(100% - 55% - 70px);
}
.renovation-menu{
    margin: 0;
}
.renovation-menu li{
    width: calc(50% - 40px);
    margin-left: 23px;
}
.renovation-ex-wrap h2{
    width: calc(100% - 80px);
    margin-left: 40px;
}
.renovation-ex li{
    padding: 50px 40px 50px 40px;
}
.term-cost{
    margin: 0 0 40px 0;
    font-size: 1.8rem;
}
.renovation-term{
    padding-left: 75px;
    margin-right: 60px;
}
.renovation-term::before{
    width: 63px;
    height: 60px;
    top: -15px;
}
.renovation-cost{
    padding-left: 80px;
}
.renovation-cost::before{
    width: 67px;
    height: 56px;
    top: -15px;
}
.renovation-ex-photo{
    display: flex;
    justify-content: space-between;
    max-width: 1670px;
    flex-wrap: wrap;
}
.renovation-before,
.renovation-after{
	width: calc(50% - 20px);
	max-width : 800px;
	margin: 0 0 30px 0;
}
}

@media print, screen and (min-width: 1730px) {
.renovation-ex-wrap h2{
    width: calc(100% - 220px);
    max-width: 1800px;
    margin: 0 auto 50px;
}
.renovation-ex-block{
    width: calc(100% - 220px);
    max-width: 1800px;
    margin: 60px auto 70px;
}
.renovation-ex li{
    padding: 0;
}
}

/* contact -------------------- */
.contact-page{
    padding: 0 15px 50px;
}
.contact-page-top{
    margin-bottom: 20px;
}
.contact-page-top li{
    margin-bottom: 20px;
}
.contact-page-tel dt,
.contact-page-mail dt{
    position: relative;
    padding: 15px 0 15px 50px;
    font-weight: bold;
    font-size: 1.7rem;
}
.contact-page-tel dt::before{
    content: "";
    width: 45px;
    height: 45px;
    position: absolute;
    top:5px;
    left:0;
	background: url(../../../assets/img/contact-tel.svg) no-repeat;
	background-size: cover;
	background-position: center;
}
.contact-page-mail dt::before{
    content: "";
    width: 45px;
    height: 45px;
    position: absolute;
    top:5px;
    left:0;
	background: url(../../../assets/img/contact-mail.svg) no-repeat;
	background-size: cover;
	background-position: center;
}
.contact-page-tel span{
    font-family: "Quicksand", serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: normal;
	font-size: 2.8rem;
	letter-spacing: 0.07em;
	margin-bottom: 0;
	line-height: 1.1;
}
span.wpcf7-list-item {
    display: block;
}
.required{
    padding: 4px 5px;
    background: #cc0000;
    color: #ffffff;
    border-radius: 3px;
    margin-left: 5px;
    margin-bottom: 2px;
    display: inline-block;
    font-size: 1.2rem;
    line-height: 1;
}
.wpcf7-form p{
    padding: 0!important;
    margin-bottom: 0;
}
.wpcf7-form dl{
    margin-bottom: 20px;
}
.wpcf7-form dt{
    font-weight: bold;
    margin-bottom: 0;
}
.wpcf7-text,
.wpcf7-form textarea{
    padding: 7px;
    margin-top: 5px;
    border: 1px solid #cccccc;
    border-radius: 5px;
    line-height: 1.6;
}
.wpcf7-form input[type="checkbox"]{
    transform: scale(1.35);
}
.wpcf7-list-item{
    margin: 0!important;
}
.wpcf7-form input[type="submit"] {
    background-color: #FC9439;
    color: white;
    cursor: pointer;
    transition: background-color 0.5s ease;
    border: solid 3px #FC9439;
    border-radius: 10px;
    margin: 0 auto;
    width: auto;
    padding: 10px 25px;
    display: block;
    font-weight: bold;
    font-size: 1.6rem;
    font-family: "游ゴシック Medium" , "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic , 'Helvetica Neue' , Helvetica , Arial , Verdana , 'ヒラギノ角ゴ Pro W3' , 'Hiragino Kaku Gothic Pro' , 'メイリオ' , Meiryo , 'ＭＳ Ｐゴシック' , 'MS PGothic' , sans-serif;
} 
.wpcf7-form input[type="submit"]:hover {
    background-color: #ffffff;
    color: #FC9439;
}
.notice{
    width: calc(100% - 30px);
    margin: 0 15px 30px;
    text-indent: -1em;
    padding-left: 1em;
}

@media print, screen and (min-width: 600px) {
.contact-page{
    padding: 0 40px 50px;
}
.contact-page-top{
    display: flex;
    justify-content: space-between;
}
.contact-page-top li{
    width: calc(50% - 20px);

}
.wpcf7-form dl{
    margin-bottom: 20px;
    display: flex;
}
.wpcf7-form dt{
    width: 175px;
    text-align: right;
    margin: 5px 15px 0 0;
}
.notice{
    width: calc(100% - 80px);
    margin: 0 40px 30px;
}
}

@media print, screen and (min-width: 1200px) {
.contact-page{
    max-width: 980px;
    padding: 0;
    margin: 0 auto 60px;
}
.contact-page-top{
    margin-bottom: 40px;
}
.contact-page-tel dt,
.contact-page-mail dt{
    padding: 20px 0 20px 70px;
    font-size: 2.2rem;
    margin-bottom: 15px;
}
.contact-page-tel dt::before{
    width: 60px;
    height: 60px;
    top:10px;
    left:0;
}
.contact-page-mail dt::before{
    width: 60px;
    height: 60px;
    top: 10px;
    left:0;
}
.contact-page-tel span{
	font-size: 3.2rem;
	letter-spacing: 0.07em;
	margin-bottom: 0;
	line-height: 1.4;
}
.wpcf7-form dl{
    margin: 0 auto 30px;
    max-width: 800px;
}
.wpcf7-form dt{
    margin: 8px 20px 0 0;
}
.wpcf7-form dd{
    width: calc(100% - 190px);
}
.wpcf7-text,
.wpcf7-form textarea{
    padding: 10px;
    font-size: 0.9em;
}
.wpcf7-form textarea{
    width: 100%!important;
}
.wpcf7-form input[type="checkbox"]{
    transform: scale(1.4);
}
.wpcf7-form input[type="submit"] {
    border-radius: 20px;
    padding: 20px 30px;
    font-size: 1.7rem;
}
.thanks{
    max-width: 800px;
    margin: 0 auto 90px;
}
.notice{
    width: 800px;
    margin: 0 auto 40px;
}
}

@media print, screen and (min-width: 1730px) {
.contact-page{
    max-width: 1100px;
    margin: 0 auto 80px;
}
.contact-page-tel dt,
.contact-page-mail dt{
    padding: 30px 0 30px 105px;
    font-size: 2.6rem;
    margin-bottom: 20px;
}
.contact-page-tel dt::before{
    width: 90px;
    height: 90px;
    top:5px;
}
.contact-page-mail dt::before{
    width: 90px;
    height: 90px;
    top: 5px;
}
.contact-page-tel span{
	font-size: 3.6rem;
	letter-spacing: 0.07em;
	margin-bottom: 0;
	line-height: 1.4;
}
.wpcf7-form dt{
    width: 185px;
}
}