@charset "UTF-8";
/*
Theme Name: レスポンシブテンプレート
Theme URI: 
Description: サインズ
Version: 1.0
Author: sains
Author URI: 
*/

/******************
画像位置ぞろえ[共通]
******************/
.nextFade .animation-bg {
	background: #fff;
  	content: "";
  	position: fixed;
  	z-index: 999;
  	top: 0;
  	left: 0;
  	width: 100%;
 	height: 100vh;
  	animation-name: PageAnime-fade;
  	animation-duration: 0.2s;
  	animation-delay: 0.4s;
  	animation-timing-function: ease-in-out;
  	animation-fill-mode: forwards;
  	pointer-events: none;
}
@keyframes PageAnime-fade {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    display: none;
  }
}

@keyframes fadein {
  from {
    opacity: 0;
	transform: translateY(10px);
  }
  to {
    opacity: 1;
	transform: translateY(0);
  }
}
img.aligncenter{
	display: block;
	margin-left: auto;
	margin-right: auto;
}

img.alignright{
	margin-left: auto;
	display:block;
}

img.alignleft{
	text-align: left;
}

/******************
オールクリア[共通]
******************/

body,div,pre,p,blockquote,
form,fieldset,input,textarea,select,option,
dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,
table,th,td,embed,object{
	margin: 0;
	padding: 0;
}

:root {
  	--basecolor: #212121;
  	--themecolor: #009e5d;
	--hovercolor: #5db448;
	--enLg: "Montserrat", 'ヒラギノ角ゴ ProN W3','Osaka' ,'Yu Gothic','Arial', sans-serif , serif;
}

html{
	scroll-behavior: smooth;
	 font-size: 62.5%; 
}
body{
	font-family:"IBM Plex Sans JP", "Noto Sans JP", "Montserrat", "Hina Mincho",'ヒラギノ角ゴシック','Hiragino Sans','メイリオ','Hiragino Kaku Gothic ProN','ヒラギノ角ゴ ProN W3','Osaka' ,'Yu Gothic','Arial', sans-serif , serif;
	font-size:1.6rem;
	color:var(--basecolor);
	font-weight:400;
	line-height:3.2rem;
	-webkit-text-size-adjust: 100%;
	word-break:break-all;
	letter-spacing: 1px;
	-webkit-text-size-adjust: 100%;
	word-break:break-all;
 	-webkit-font-smoothing: antialiased;
	-webkit-font-smoothing: subpixel-antialiased;
	scroll-behavior: smooth;
	background:#dff3eb;
}
img{
	border:none;
	vertical-align:bottom;
	max-width:100%;
	height:auto;
	-webkit-backface-visibility: hidden;
}
li{
	list-style-type:none;	
}
a{
	backface-visibility: hidden; 
	color:#1a1a1a;
	text-decoration:none;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}
a:hover{
	color:var(--themecolor);
	text-decoration:underline;
}
a img{
    -webkit-transition: 0.3s ease-in-out;
       -moz-transition: 0.3s ease-in-out;
         -o-transition: 0.3s ease-in-out;
            transition: 0.3s ease-in-out;
		outline:none;
		box-shadow: #000 0 0 0;
}
a:hover img{
	opacity:0.7;
	-moz-opacity:0.7;
	-webkit-opacity:0.7;
}
table{
	border-collapse:collapse;
	border-color: #333333;
}

th{
	font-weight:500;
}

td{
	vertical-align:top;
}
.fadeIn_up {
  opacity: 0;
  transform: translate(0, 50%);
  transition: 1s;
}
#wrapper .fadeIn_up {
  opacity: 0;
  transform: translate(0, 20%);
  transition: 0.6s;
}
#wrapper .footerFind .fadeIn_up {
  opacity: 1;
  transform: translate(0, 0);
}
#wrapper .fadeIn_up.is-show {
  transform: translate(0, 0);
  opacity: 1;
}
.fadeIn_up.is-show {
  transform: translate(0, 0);
  opacity: 1;
}
.fadeIn_only {
  opacity: 0;
  transition: opacity 2s ease;
}
.fadeIn_only.is-show {
  opacity: 1;
}
.fadeIn_up_blur {
  opacity: 0;
  transform: translateY(50%);
  filter: blur(10px);
  transition: 1s ease;
}
.fadeIn_up_blur.is-show {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.fadeIn_up_naka {
  opacity: 0;
  transform: translate(0, 10%);
  transition: 1s;
}
.fadeIn_up_naka.is-show {
  transform: translate(0, 0);
  opacity: 1;
}
.pc{
	display:block!important;
}
.sp{
	display:none!important;
}
.grecaptcha-badge{
	display:none;
}
@media screen and (max-width: 1000px) {
body{
	font-size:1.55rem;
	line-height:3rem;
}
body.no-scroll {
  overflow: hidden;
  height: 100vh;
}
}
@media screen and (max-width: 781px) {
.pc{
	display:none!important;
}

.sp{
	display:block!important;
}
.heiSmt50{
	height:50px!important;
}
}


/******************
汎用[共通]
******************/

.float_left{
	float:left;
}

.float_right{
	float:right;
}

.clear{
	clear:both;
	height:40px;
}

.cenclear{
	clear:both;
	text-align:center;
	padding-top:30px;
}

.txt_center{
	text-align:center;
}
.resizeimage{
	width:100%;
}
.button{
	width:600px;
	margin:0 auto;
}
.button a{
    display: inline-block; 
  	color: #c1282d;
  	background: #fff;
  	padding: 30px 0 27px 0;
  	text-decoration: none;
	transition: .3s;
	border:3px solid #c1282d;
	text-align:center;
	width:100%;
	font-size:125%;
}
.button a:hover {
  background: #c1282d;
  color:  #fff;
	border:3px solid #c1282d;
}
.button a span{
	padding-right:2%;
}
@media screen and (min-width: 851px)  and (max-width: 1200px) {
.button{
	width:70%;
}
}
@media screen and (max-width: 850px) {
.button{
	width:80%;
}
.button a{
  	padding: 23px 0 20px 0;
	font-size:115%;
}
.clear{
	height:30px;
}
}


/******************
ヘッダー【トップ＋コンテンツ共通】[PC+タブレット]
******************/
.header {
  	position: fixed;
  	top: 0;
  	left: 0;
  	width: 100%;
  	z-index: 200;
	height:90px;
  	transition: box-shadow 0.3s ease;
	display: flex;
  	justify-content: center;
  	align-items: center;
  	min-height: 90px;
	transition: 
      transform 0.35s ease,
      box-shadow 0.3s ease,
      background 0.3s ease;
}
.header.scrolled {
  	box-shadow: 0 2px 7px rgba(0,0,0,0.1);	
	-moz-box-shadow: 0 2px 7px rgba(0,0,0,0.1);
	-webkit-box-shadow: 0 2px 7px rgba(0,0,0,0.1);
	background:rgba(255,255,255,.95);
}
.header.hide {
  transform: translateY(-100%);
}
.headerOverlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.4);
  z-index: 60;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  pointer-events: none;
}
.headerOverlay.active {
  opacity: 1;
  visibility: visible;
}
.headerNaka{
	width: 100%;
  	margin: 0 auto;
  	display: flex;
  	align-items: center;
  	justify-content: space-between;
	position: relative;
  	z-index: auto;
	transition:0.3s ease;
}
.headerL{
	width: 100%;
  	max-width: 300px;
	transition:0.3s ease;
	margin:0 0 0 2%;
}
.header-logo {
    display: block;
  	width: 300px;
    display: block;
    margin: 0;
    transition: width 0.3s ease, height 0.3s ease;
	will-change: height,background-color;
	backface-visibility: hidden;
}
.header-logo img{
	width: 100%;
    height: auto;
    display: block;
	transition: width 0.3s ease;
}
.headerR{
	width: calc(100% - 900px);
  	margin: 0 0 0 600px;
	display: flex;
  	align-items: center;
  	justify-content: space-between;
	 position: relative;
  	z-index: auto;
	transition:0.3s ease;
}
.headerPc{
	display:block;
	position: relative;
  	z-index: auto;
}
.headerRSp{
	display:none;
}
.header-nav{
	width: 100%;
  	max-width: 100%;
	 position: relative;
  	z-index: auto;
}
.header-list {
  	display: flex;
  	justify-content: space-around;
	position: relative;
  	z-index: auto;
}
.header-item {
  	transition:.3s;
	position:relative;
  	z-index: auto;
}
.header-item a {
  	color: var(--basecolor);
  	display: block;
  	padding:0;
	transition:.3s;
	font-weight:500;
}
.header-item a:hover {
  	color:var(--themecolor);
	text-decoration:none;
}
.headerRM{
	width: 70%;
}
.headerContact{
	width:30%;
  	margin: 0 0 0 40px;
}
.header-Contactnav ul{
	display:flex;
	justify-content:space-between;
	align-items: stretch;
}
.header-Contactnav ul li{
	width:50%;
}
.header-Contactnav ul li a{
	display:flex;
  	justify-content:center;
  	align-items:center;
	width:100%;
	height:90px;
	background:#4fb723;
	color:#fff;
	text-align:center;
	font-size:1.5rem;
	font-weight:500;
	transition:.3s;
}
.header-Contactnav ul li:nth-child(2) a{
	background:var(--themecolor);
}
.header-Contactnav ul li a:hover{
	text-decoration:none;
	background:#2c7c0a;
}
.header-Contactnav ul li:nth-child(2) a:hover{
	background:#05633b;
}
@media screen and (max-width: 1760px) {
.headerR{
	width: calc(100% - 720px);
  	margin: 0 0 0 400px;
}
}
@media screen and (max-width: 1700px) {
.headerR{
	width: calc(100% - 570px);
  	margin: 0 0 0 250px;
}
}
@media screen and (max-width: 1500px) {
.headerR{
	width: calc(100% - 470px);
  	margin: 0 0 0 150px;
}
}
@media screen and (max-width: 1400px) {
.headerL {
    max-width: 300px;
}
.headerR{
	width: calc(100% - 380px);
  	margin: 0 0 0 80px;
}
}
@media screen and (max-width: 1200px) {
.headerR {
	width: 70px;
    margin: 0 ;
}
.headerRM , .headerContact{
	display:none;
}
.headerRSp{
	display:block;
	height:70px;
}
.headerRSpMenu {
    z-index: 10000;
    position: fixed;
    left: 0;
    background: #fff;
    width: 100%;
    height: 100vh;
    opacity: 0;
    transform: translateY(0);
    transition: opacity 0.3s ease, top 0.3s ease;
    pointer-events: none;
}
.headerRSpMenu.active {
    top: 0;
    opacity: 1;
    pointer-events: auto;
}
.headerRSpMenuNaka {
  	height: 100vh; 
  	overflow-y: auto;
  	position: fixed;
  	top: 0;
  	left: 0;
  	width: 100%;
  	background-color: #fff;
  	z-index: 999; 
}
.header__navi_03 ul {
  	padding: 70px 0 30px 0;
  	text-align: left;
	width:80%;
	margin:0 auto;
}
.header__navi_03 li {
  	list-style: none;
}
.header__navi_03 li a {
  	color: var(--basecolor);
	display:block;
	text-align:left;
  	text-decoration: none;
	border-bottom:1px solid #e5e5e5;
	display:block;
	padding:12px 0;
	font-weight:500;
	font-size:1.6rem;
	position:relative;
}
.header__navi_03 li:nth-child(2) a.active , .header__navi_03 li:nth-child(3) a.active{
	border-bottom:none;
}
.header__navi_03 li:last-child a::before {
  	list-style: none;
}
.header-item.recruit-link a {
    display: block;
}
.sp-menu-btn_03 {
  	background: transparent;
  	border: none;
  	position: absolute;
  	right: 7px;
  	top: 5px;
  	width: 60px;
  	height: 60px;
  	cursor: pointer;
  	z-index: 12000;
}
.sp-menu-btn_03 span {
  	display: block;
  	position: absolute;
  	width: 40px;
  	right: 7px;
  	transition: 0.3s ease-in-out;
  	font-size: 1.2rem;
	color: var(--themecolor);
}
.sp-menu-btn_03 .line {
  	height: 2px;
  	background: var(--themecolor);
}
.sp-menu-btn_03 span:nth-child(1) {
  	top: 20px;
}
.sp-menu-btn_03 span:nth-child(2) {
  	top: 28px;
}
.sp-menu-btn_03 span:nth-child(3) {
  	top: 36px;
}
.sp-menu-btn_03.active span:nth-child(1) {
  	top: 28px;
  	transform: rotate(-45deg);
}
.sp-menu-btn_03.active span:nth-child(2) {
  	transform: rotate(45deg);
}
.sp-menu-btn_03.active .menu  {
  	font-size:0;
}
.accBtn:after {
	font-family: 'Material Icons';
  	content:'\e313';
  	transition: 0.3s;
  	position: absolute;
  	right: 1%;
  	top: 26%;
  	color:var(--themecolor);
	font-size:2rem;
	transition:.3s;
}
.accBtn.active:after{
	content:'\e316';
     -ms-transform: rotate(360deg);
     -webkit-transform: rotate(360deg);
     transform: rotate(360deg);
	color:var(--themecolor);
}
.spSubMenu {
	display: none;
}
.spSubMenu ul{
	padding:0 0 0 2%!important;
	width:98%!important;
}
.spSubMenu ul li:first-child{
	padding:5px 0 0 0;
}
.spSubMenu ul li a{
	width:94%;
	font-size:1.5rem!important;
	padding: 7px 2%  7px 15px;
	border-bottom:none;
	color:var(--basecolor);
	position:relative;
}
.spSubMenu ul li:first-child a{
	padding: 7px 2%  7px 15px!important;
}
.spSubMenu ul li a::before{
	content: "";
  	display: inline-block;
  	width: 10px;
  	height: 2px;
  	background-color: var(--themecolor);
  	position: absolute;
  	top: 50%;
  	left: 0;
}
.hspMUnder{
	width:80%;
	margin:0 auto 40px auto;
}
.hspMUnderMenuUnder{
	display:flex;
	justify-content:space-between;
	width:100%;
	margin:0 auto;
}
.hspMUnderMenu{
	width:100%;
}
.hspMUnderMenu ul{
	width:100%;
	padding:0;
}
.hspMUnderMenu ul li a {
  	color:var(--basecolor);
	border-bottom:none;
	display:block;
	padding:7px 0;
	font-weight:500;
	font-size:1.4rem;
}
.hspMUnderMenu ul li a {
        padding: 0 0 7px 0!important;
}
.hspMUnderMenu ul li.hspOutLink a{
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.hspMUnderMenu ul li.hspOutLink a span{
	margin:0 0 0 5px;
	font-weight:300;
	font-size:1.8rem;
	line-height: 1;
}
.hspBosyu{
	width:100%;
	margin:30px auto 15px auto;
}
.hspBosyu a{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width:100%;
	background:var(--themecolor);
	color:#fff;
	box-sizing:border-box;
	padding:10px 3% 8px 3%;
	text-align:center;
	transition:.3s;
	font-size:1.6rem;
	border-radius:30px;
	-moz-border-radius:30px;
	-webkit-border-radius:30px;
}
.hspBosyu a:hover{
	text-decoration:none;
	background:var(--hovercolor);
}
.hspBosyu span{
	margin:0 0 0 5px;
	font-weight:300;
	font-size:1.8rem;
	line-height: 1;
}
.hspChara{
	text-align:right;
}
}

@media screen and (max-width: 640px) {
.sp-menu-btn_03 {
     right: 1px;
     top: 4px;
}
.header__navi_03 ul {
  	padding: 65px 0 20px 0;
	width:84%;
}
.hspMUnderContact {
    margin: 0 auto 10px auto;
}
.hspMUnderMenu ul{
	padding: 20px 0 10px 0!important;
	width:100%!important;
}
.accBtn:after {
  	top: 20%;
}
.hspBosyu {
   	margin: 15px auto 25px auto;
	overflow:hidden;
}
.hspChara img{
	max-width:100px;
}
}
@media screen and (max-width: 480px) {
.header {
    height: 60px;
    min-height: 60px;
}
.headerL {
    max-width: 230px;
}
.header-logo {
    width: 230px;
}
.hspChara img{
	max-width:80px;
}
}

@media screen and (max-width: 400px) {
.headerL {
    max-width: 200px;
}
.header-logo {
    width: 200px;
}
.sp-menu-btn_03 span {
    width: 36px;
	font-size: 1.15rem;
}
}

/******************
コンテンツボックス[共通]
******************/
#wrapperTop{
	position:relative;
	overflow:hidden;
}
#wrapperTop .main {
    width:94%;
	max-width:1300px;
	margin:0 auto;
	overflow:hidden;
	padding:90px 0;
}
#wrapperTop .taMUp{
	margin:170px auto 0 auto!important;
}
#wrapperTop .contents{
	width:100%;
	margin:0 auto;
	clear:both;
	position:relative;
	z-index:1;	
}
#wrapper .contents {
	width:100%;
	margin:0 auto;
	clear:both;
	position:relative;
	z-index:1;	
}
#wrapper .contents::before {
	content: "";
  	position: absolute;
	background: url("./images/common/back-logo.svg") no-repeat left top;
	right:30px;
	top:20px;
	width:500px;
	height:446px;
	transform: translateY(100%);
  	opacity: 0;
  	animation: riseUp .8s ease-out forwards;
  	animation-delay: 0.2s;
}
#wrapper .contentsVoice {
	width:100%;
	margin:0 auto;
	clear:both;
	position:relative;
	z-index:1;	
}
@keyframes riseUp {
  to {
    transform: translateY(0);
    opacity: 1;
  }
}
#wrapperTop .contentsTopGray , #wrapper .contentsTopGray{
	width:100%;
	margin:0 auto;
	clear:both;
	position:relative;
	z-index:1;
	background:#f2f3f4;
}
#wrapperTop .contentsTopBannar{
	width:100%;
	max-width:100%;
	margin:0 auto;
	position:relative;
	background: #4aa56b url("./images/top/main-bg.svg") repeat center top;
}
#wrapperTop .contentsTopBannar::after {
  	content: "";
  	position: absolute;
  	bottom: -5vw;
  	left: 50%;
  	transform: translateX(-50%);
  	width: 160vw;
  	height: 20vw;
  	border-radius: 0 0 50% 50% / 0 0 100% 100%;
  	background: inherit;
  	z-index: 0;
}
#wrapperTop .contentsTopDate{
	width: 100%;
    margin: 0 auto;
    clear: both;
    position: relative;
    z-index: 1;
    background: #f7f7f7;
}
#wrapperTop .contentsTopDate::before{
	content: "";
    position: absolute;
    top: -6vw;
    left: 50%;
    transform: translateX(-50%);
    width: 160vw;
    height: 25vw;
    border-radius: 50% 50% 0 0 / 100% 100% 0 0;
    background: #f7f7f7;
    z-index: 0;
}
#wrapperTop .contentsTopPeople{
	width:100%;
	max-width:100%;
	margin:0 auto;
	position:relative;
	background: #359f80 url("./images/top/main-bg.svg") repeat center top;
}
#wrapperTop .contentsTopInsta{
	width:100%;
	max-width:100%;
	margin:0 auto;
	position:relative;
	background: url("./images/top/top-date-bg.png") repeat left top;
	background-size:auto;
}
#wrapper .mainWrapper{
	background:#fff;
	width:100%;
	border-radius:50px 50px 0 0;
	-moz-border-radius:50px 50px 0 0;
	-webkit-border-radius:50px 50px 0 0;
}
#wrapper .main  {
    width:94%;
	max-width:1300px;
	margin:0 auto;
	padding:120px 0;
	position:relative;
	z-index:100;
}
#wrapper .peopleSingleMain{
	padding:4%;
	background:#fff;
	margin:60px auto;
	overflow:hidden;
	box-sizing:border-box;
	width:90%;
	max-width:1200px;
	border-radius:50px;
	-moz-border-radius:50px;
	-webkit-border-radius:50px;
}
@media screen and (max-width: 1500px) {
#wrapperTop .main  {
    width:90%;
	max-width:90%;
	padding:70px 0;
}
#wrapperTop .taMUp{
	margin:120px auto 0 auto!important;
}
#wrapper .contents::before {
	background-size:400px 367px;
	right:50px;
	top:30px;
	width:400px;
	height:367px;
}
#wrapper .main  {
    width:90%;
	max-width:90%;
	padding:90px 0;
}
#wrapper .peopleSingleMain{
	width:90%;
	max-width:90%;
	padding:5%;
}
}
@media screen and (max-width: 1340px) {
#wrapperTop .main {
	max-width:90%;
	padding:60px 0;
}
#wrapperTop .taMUp{
	margin:100px auto 0 auto!important;
}
}
@media screen and (max-width: 1200px) {
#wrapper .main  {
	padding:70px 0;
}
#wrapper .peopleSingleMain{
	padding:5%;
}
#wrapper .contents::before {
	background-size:320px 285px;
	right:40px;
	top:25px;
	width:320px;
	height:285px;
}
}
@media screen and (max-width: 1000px) {
#wrapperTop .contentsTopSt::before {
	right:0;
	margin:auto;
	width: 100%;
}
#wrapper .main  {
	padding:60px 0;
}
#wrapper .peopleSingleMain{
	padding:6%;
	margin:40px auto 60px auto;
}
#wrapperTop .contentsTopInsta{
	background: url("./images/top/top-date-bg.png") repeat left -20px;
	background-size:200% auto;
}
#wrapper .contents::before {
	background-size:260px 232px;
	width:260px;
	height:232px;
}
}
@media screen and (max-width: 800px) {
#wrapperTop .main {
	padding:50px 0;
}
#wrapperTop .taMUp {
     margin: 70px auto 0 auto !important;
}
}
@media screen and (max-width: 640px) {
#wrapperTop .main {
	max-width:84%;
}
#wrapperTop .taMUp {
    margin: 40px auto 0 auto !important;
}
#wrapper .main  {
    width:84%;
	max-width:84%;
	padding:50px 0 60px 0;
}
#wrapperTop .contentsTopInsta{
	background-size:260% auto;
}
#wrapper .contents::before {
	background-size:220px 196px;
	width:220px;
	height:196px;
	top:10px;
	right:0;
}
#wrapper .peopleSingleMain{
	padding:7%;
	margin:30px auto 60px auto;
	border-radius:30px;
	-moz-border-radius:30px;
	-webkit-border-radius:30px;
}
}
@media screen and (max-width: 480px) {
#wrapper .contents::before {
	background-size:220px 196px;
	width:220px;
	height:196px;
}
#wrapper .main  {
	padding:40px 0 60px 0;
}
#wrapper .peopleSingleMain{
	padding:8%;
}
}
@media screen and (max-width: 440px) {
#wrapperTop .taMUp {
    margin: 20px auto 0 auto !important;
}
#wrapperTop .contentsTopInsta{
	background: url("./images/top/top-date-bg.png") repeat left top;
	background-size:280% auto;
}
}

/******************
フッターコンタクト
******************/
.noContact{
	border-top:2px solid #ebefea;
}
.contactMidashiWrapper{
	width:100%;
	margin:0 auto;
	overflow:hidden;
	display:flex;
	justify-content:space-between;
	align-items:center;
}
.commonContactL{
	width:100%;
	max-width:300px;
}
.contactMidashi{
	font-family:var(--enLg);
	color:var(--themecolor);
	font-size:4.3rem;
	font-weight:600;
	line-height:1.4;
	letter-spacing:0.4rem;
}
.contactMidashi span{
	display:block;
	color:var(--basecolor);
	font-size:1.5rem;
	font-weight:500;
	letter-spacing:0;
}
.commonContactR{
	overflow: hidden;
	width:calc(100% - 800px);
	margin:0 250px;
}
.commonContactRUp{
	width:100%;
	margin:0 auto 30px auto;
	display:flex;
	justify-content:space-between;
}
.commonContactRTel{
	
}
.commonContactRTel a{
	pointer-events:none;
	color:var(--themecolor);
}
.commonContactRFax{
	margin-left: auto;
}
.ccTTxt{
	color:var(--themecolor);
	font-size:3.2rem;
	font-weight:600;
	font-family:var(--enLg);
}
.commonContactRUnder{
	width:100%;
	margin:0 auto;
}
.ccMail{
	width:100%;
	text-align:center;
}
.ccMail a{
	width:100%;
	box-sizing:border-box;
	background:var(--themecolor);
	color:#fff;
	padding:12px 5%;
	border-radius:10px;
	-moz-border-radius:10px;
	-webkit-border-radius:10px;
	display: inline-flex;
  	align-items: center;
	justify-content: center;
  	gap: 4px;
	font-size:1.8rem;
	transition:.3s;
}
.ccMail a:hover{
	text-decoration:none;
	background:#f2d55a;
	color:var(--basecolor);
}


@media screen and (max-width:1500px) {
.commonContactR{
	overflow: hidden;
	width:calc(100% - 700px);
	margin:0 200px;
}
}
@media screen and (max-width:1400px) {
.commonContactR{
	overflow: hidden;
	width:calc(100% - 600px);
	margin:0 150px;
}
}
@media screen and (max-width:1200px) {
.commonContactL{
	max-width:280px;
}
.commonContactR{
	overflow: hidden;
	width:calc(100% - 400px);
	margin:0 60px;
}
}
@media screen and (max-width:1000px) {
.commonContactL{
	max-width:250px;
}
.commonContactR{
	overflow: hidden;
	width:calc(100% - 310px);
	margin:0 30px;
}
}
@media screen and (max-width:900px) {
.commonContactR{
	overflow: hidden;
	width:calc(100% - 250px);
	margin:0;
}
}
@media screen and (max-width:800px) {
.commonContactL{
	max-width:30%;
}
.commonContactR{
	width:62%;
}
.contactMidashi{
     font-size: 3.6rem;
     letter-spacing: 0.1rem;
     font-weight: 700;
}
.commonContactRUp {
    display: block;
	text-align:center;
}
.commonContactRTel {
	margin:0 auto 10px auto;
	overflow:hidden;
	width:100%;
}
.commonContactRTel a {
    pointer-events: inherit;
}
.ccTTxt {
    font-size: 2.8rem;
}
.ccMail a {
    font-size: 1.7rem;
}
}
@media screen and (max-width:640px) {
.contactMidashiWrapper {
    display: block;
}
.commonContactL {
    max-width: 100%;
	margin:0 auto;
	overflow:hidden;
	text-align:center;
}
.contactMidashi{
	margin:0 auto 25px auto;
}
.commonContactR{
	width:100%;
}
.contactMidashi {
    line-height: 1.2;
}
}
@media screen and (max-width:480px) {

}
@media screen and (max-width:400px) {
.ccMail a {
    font-size: 1.6rem;
}
}

/******************
フッター(中部)[共通]
******************/
.footer{
	clear:both;
	width:100%;
	overflow:hidden;
	margin:0 auto;
	position: relative;
	background:#fff;
}
.footerNaka{
	width:90%;
	max-width:1300px;
	margin:0 auto;
	padding:50px 0 30px 0;
	display:flex;
}
.footerL{
	width:22%;
}
.footerR{
	width:calc(100% - 32%);
	margin:0 0 0 10%;
}
.footerLogo{
	width:100%;
	overflow:hidden;
	margin:0 0 30px 0;
}
.footerLogo img{
	max-width:100%;
	display:block;
	margin:0;
	height:auto;
}
.footerBosyu{
	float:right;
	width:65%;
}
.footerBosyu a{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width:100%;
	background:var(--themecolor);
	color:#fff;
	box-sizing:border-box;
	padding:6px 3% 4px 3%;
	text-align:center;
	transition:.3s;
	font-size:1.45rem;
	border-radius:30px;
	-moz-border-radius:30px;
	-webkit-border-radius:30px;
}
.footerBosyu a:hover{
	text-decoration:none;
	background:var(--hovercolor);
}
.footerBosyu span{
	margin:0 0 0 5px;
	font-weight:300;
	font-size:1.8rem;
	line-height: 1;
}
.footerMenu{
	width:100%;
	margin:0 auto;
	overflow:hidden;
	position:relative;
}
.fMenu{
	position:relative;
	width:100%;
}
.fMenu ul{
	position:relative;
	width:100%;
	display:flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	gap: 4%;
}
.fMenu li{
	position:relative;
	width:22%;
	margin:0 0 10px 0;
}
.fMenu li a{
	position:relative;
	font-size:1.4rem;
	transition:.3s;
}
.fmOutLink a{
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.fmOutLink a span{
	margin:0 0 0 5px;
	font-weight:300;
	font-size:1.8rem;
	line-height: 1;
}
.fMenu li a:hover{
	text-decoration:none;
}
.copy{
	clear:both;
	text-align:center;
	width:100%;
	overflow:hidden;
	font-size:1.1rem;
	padding:0 0 10px 0; 
}
.copy span{
	padding:0 0 0 10px;
}
#pagetop{
	display:none;
	clear:both;
	z-index:90;
	position: fixed;
	bottom: 25px;
	right: 25px;
}
@media screen and (max-width:1500px) {
.footerNaka{
	max-width:90%;
}
}
@media screen and (max-width:1200px) {
.footerNaka {
    display: block;
	padding: 30px 0;
}
.footerL {
    width:100%;
	margin:0 auto;
}
.footerR {
    display:none;
}
.footerLogo {
    width: 25%;
	margin:0 auto;
}
.footerBosyu {
    display:none;
}
.copy {
    text-align: center;
    width: 100%;
}
}
@media screen and (max-width:1000px) {
.footerLogo {
    width: 30%;
	margin:0 auto;
}
.copy{
	line-height:1.5;
}
}
@media screen and (max-width:800px) {
.footerLogo {
    width: 45%;
}
}
@media screen and (max-width:640px) {
.footerLogo {
    width: 55%;
}
#pagetop{
	bottom: 10px;
	right: 10px;
}
.copy span{
	display:block;
}
}
@media screen and (max-width:480px) {
.footerLogo {
    width: 60%;
}
}
@media screen and (max-width:400px) {
.footerLogo {
    width: 65%;
}
}
@media screen and (max-width:350px) {
.footerLogo {
    width: 70%;
}
}


/*求人ボタンbox*/
.topFindWrapper{
	max-width:1300px;
	width:100%;
	margin:0 auto;
	padding:100px 0;
	position:relative;
} 
.topFindUp , .topFindUnder{
	max-width:100%;
	width:100%;
	overflow:hidden;
	display:flex;
	justify-content:space-between;
} 
.topFindL{
	width:250px;
}
.topFind{
	width:calc(100% - 300px);
	margin:0 0 0 50px;
}
.topFindUp{
	width:100%;
	margin:0 auto 70px auto;
	overflow:hidden;
}
.topFindMidashi{
	font-weight:500;
	font-size:1.7rem;
	margin:0 auto;
}
.topFindMidashi span{
	display:block;
	font-weight:700;
	font-family:var(--enLg);
	font-size:2.7rem;
	color:#229674;
}
.tfm1{
	margin:30px 0 0 0;
}
.topFindJobcan{
	width:100%;
	margin:0 auto;
	display:flex;
	justify-content:space-between;
}
.topFindJobcan{
	width:100%;
	margin:0 auto;
	display:flex;
	justify-content: flex-start;
	flex-wrap:wrap;
	gap: 2%;
}
.topFindOne{
	width:31%;
	margin:0 0 2% 0;
}
.topFindOne a{
	display:block;
	width:100%;
	background:#229674;
	color:#fff;
	box-sizing:border-box;
	padding:17px 4% 15px 4%;
	text-align:center;
	border-radius:30px;
	-moz-border-radius:30px;
	-webkit-border-radius:30px;
	transition:.3s;
	font-weight:500;
	letter-spacing:-1px;
}
.topFindOne:nth-child(even) a{
	background:#5db448;
}
.topFindOne a:hover{
	text-decoration:none;
	background:#246350;
}
.topFindOne:nth-child(even) a:hover{
	background:#366629;
}
.topFindMynavi{
	width:100%;
	margin:0 auto;
	display:flex;
	justify-content:space-between;
	flex-wrap:wrap;
}
.topMynaviOne{
	width:48%;
}
.topMynaviOne a{
	display:block;
	width:100%;
	background:#fff;
	border:2px solid #57a2e5;
	box-sizing:border-box;
	padding:1px 4%;
	text-align:center;
	border-radius:50px;
	-moz-border-radius:50px;
	-webkit-border-radius:50px;
	transition:.3s;
	margin:0 0 1px 0;
}
.topMynaviOne a:hover{
	border:2px solid var(--themecolor);
}
.topMynaviOne a img{
	width:50%;
	margin:0 auto;
}
.topMynaviOne a:hover img{
	opacity:1!important;
	-moz-opacity:1!important;
	-webkit-opacity:1!important;
}
.topMynaviYear{
	font-weight:500;
}
.topFindMore{
	width:100%;
	margin:25px 0 0 0;
	overflow:hidden;
	position:relative;
}
.topFindMore a {
	display: inline-flex;
	align-items: center;
	text-decoration: none;
	border-bottom:1px solid #229674;
	font-size:1.45rem;
	padding:0 0 5px 0;
	font-weight:500;
}
.arrowText {
	display: flex;
	align-items: center;
	gap: 20px;
}
.topFindMore .toPage {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	background: #229674;
	border-radius: 50%;
	-moz-border-radius: 50%;
	-webkit-border-radius: 50%;
}
.topFindMore .toPage img {
	display: block;
	width: 14px;
	height: 10px;
}
.topFindMore a:hover .toPage img {
	opacity:1!important;
	-moz-opacity:1!important;
	-webkit-opacity:1!important;
}
.topUpFindChara{
	position:absolute;
	top:-35px;
	left:0;
}
@media screen and (max-width:1400px) {
.topFindWrapper{
	max-width:90%;
	width:90%;
	padding:80px 0;
} 
}
@media screen and (max-width:1300px) {
.topFindOne {
    width: 48%;
}
.topFindOne:nth-child(4n+1) a {
    background: #229674;
}
.topMynaviOne a img{
	width:60%;
}
}
@media screen and (max-width:1250px)  and (min-width:641px){
.topFindOne:nth-child(4n+1) a {
    background: #229674;
}
.topFindOne:nth-child(4n+2) a {
    background: #5db448;
}
.topFindOne:nth-child(4n+3) a {
    background: #5db448;
}
.topFindOne:nth-child(4n+4) a {
    background: #229674;
}
}
@media screen and (max-width:1000px) {
.topFindWrapper {
    padding: 70px 0;
}
.topFindUp , .topFindUnder{
	display:block;
}
.topFindL {
    width: 100%;
	margin:0 auto 30px auto;
	overflow:hidden;
}
.topFind{
	width:100%;
	margin:0 auto;
}
.topFindUp {
    margin: 0 auto 50px auto;
}
.topFindMidashi{
	font-size:1.75rem;
	margin:0 auto;
	text-align:center;
	line-height:1.4
}
.topFindMidashi span{
	font-size:3.8rem;
	color:#229674;
}
.topFindMore{
	text-align:right;
}
}
@media screen and (max-width:800px) {
.topFindWrapper {
	max-width:84%;
	width:84%;
    padding: 60px 0;
}
}
@media screen and (max-width:640px) {
.topFindWrapper {
    padding: 50px 0;
}
.topFindMidashi{
	font-size:1.65rem;
	line-height:1.3;
}
.topFindMidashi span{
	font-size:3.2rem;
}
.topUpFindChara img {
     width: 30%;
}
.topFindJobcan{
	display:block;
	gap:unset;
}
.topFindOne{
	width:100%;
	margin:0 auto 4% auto;
}
.topFindOne:last-child{
	margin:0 auto;
}
.topFindOne:nth-child(even) a{
	background:#5db448;
}
.topFindOne a {
    padding: 15px 4% 13px 4%;
}
.topFindMore {
    margin: 15px 0 0 0;
}
.topFindMynavi{
	display:block;
}
.topMynaviOne{
	width:100%;
	margin:0 auto 4% auto;
}
.topMynaviOne:last-child{
	margin:0 auto;
}
.topMynaviOne a img{
	width:50%;
}
.topMynaviYear {
    text-align:center;
}
}
@media screen and (max-width:480px) {
.topUpFindChara {
    top: -30px;
    left: unset;
    right: 0;
    text-align: right;
}
.topUpFindChara img {
     width: 25%;
}
}


@media print{
body{
	width:1000px;
	margin:0 auto;
}
#wrapperTop,#wrapper{
	padding-top:0;
	width:1000px;
	margin:0 auto;
}
.header {
    width: 1000px;
	position: relative !important;
	border-bottom: 1px solid #ccc;
}
.headerNaka {
    width: 99%;
    margin: 0 auto;
    padding: 0 0 0 1% !important;
}
.headerL {
    max-width: 200px;
}
.header-logo {
    width: 200px;
}
.headerR {
    width: calc(100% - 240px);
    margin: 0 0 0 40px;
}
.headerRM {
    width: calc(100% - 240px);
}
.headerContact {
    width: 220px;
    margin: 0 0 0 20px;
}
.mainVisual {
    margin-top: 0!important;
	width:1000px!important;
	height:70vh!important;
}
.mv1{
	width:19vw!important;
}
.mv2{
	width:17vw!important;
	left:-11%!important;
}
.mv3{
	width:17vw!important;
	right:-11%!important;
}
.mv4 {
    left: 6%!important;
    top: 35%!important;
}
.mv5 {
    right: 1%!important;
    top: 23%!important;
}
.mvChara {
    width: 5vw!important;
    right: 24%!important;
    top: 86%!important;
}
#wrapperTop .main {
    max-width: 1000px!important;
    padding: 60px 0!important;
}
.fadeIn_up {
    opacity: 1!important;
    transform: translate(0, 0)!important;
}
.fadeIn_only {
    opacity: 1!important;
    transform: translate(0, 0)!important;
}
.mv {
     opacity: 1!important;
    transform: translateY(0)!important;
}
.footerNaka {
	width: 96%!important;
    max-width: 1000px!important;
}
.footerL {
    width: 26%!important;
}
.footerR {
    width: calc(100% - 30%)!important;
    margin: 0 0 0 4%!important;
}
.fMenu li a {
    font-size: 1.25rem!important;
}
.topFindWrapper {
    max-width: 90%!important;
    width:90%!important;
}
.topFindL {
    width: 200px!important;
}
.topFind {
    width: calc(100% - 240px)!important;
    margin: 0 0 0 40px!important;
}
.topMiddleBnr {
   max-width: 90%!important;
    width:90%!important;
}
.topAboutWrapper {
    width: 95%!important;
	margin: 0 0 20px 0!important;
}
.topAboutL{
	width:50%!important;
}
.topAboutR {
	width:50%!important;
    padding: 60px 0 40px 0!important;
}
.topAboutPic img {
    height: 479px!important;
    object-fit: cover!important;
}
.topAboutMidashi {
    font-size: 5rem!important;
}
.topEnvWrapper {
    width: 95%!important;
	margin: 0 0 0 5%!important;
}
.topEnvL{
	width:50%!important;
}
.topEnvR {
	width:50%!important;
    padding: 60px 0 40px 0!important;
}
.topEnvPic img {
    height: 479px!important;
    object-fit: cover!important;
}
.topEnvMidashi {
    font-size: 5rem!important;
}
.topNumberMidashi span {
    font-size: 6rem!important;
}
#wrapperTop .taMUp {
    margin: 130px auto 0 auto !important;
}
#wrapper .main {
    width:1000px!important;
    max-width: 100%!important;
    padding: 50px 5%!important;
	box-sizing:border-box;
}
.mainNakaUp {
    margin: 0 auto!important;
	padding: 30px 0!important;
}
.p70s30{
	height:60px!important;
}
.peopleMain h2 {
    margin: 0 auto!important;
	width:100%!important;
}
.peopleMainL{
	width:40%!important;
}
.peopleMainTxtWrapper {
    width: 1000px!important;
    max-width: 100%!important;
}
.peopleTextLine {
    font-size: 2.6rem!important;
}
}



@page{
	margin: 16mm 10mm;
}

@-moz-document url-prefix(){
@page{
	margin: auto;
}
}

@media screen and (-webkit-min-device-pixel-ratio:0){
@page{
	margin: auto;
}
}

