@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: #333333;
  	--themecolor: #00876b;
	--hovercolor: #78ba93;
	--enLg: "Manrope", 'ヒラギノ角ゴ ProN W3','Osaka' ,'Yu Gothic','Arial', sans-serif , serif;
}

html{
	scroll-behavior: smooth;
	 font-size: 62.5%; 
}
body{
	font-family: "Noto Sans JP", "BIZ UDPGothic", "Manrope", "IBM Plex Sans JP", "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;
}
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;
}
.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_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: 100;
  	background-color: #fff;
	height:90px;
  	transition: box-shadow 0.3s ease;
	display: flex;
  	justify-content: center;
  	align-items: center;
  	min-height: 90px;
}
.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);
}

.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: 94%;
  	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: 320px;
	transition:0.3s ease;
}
.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;
}
.headerLSub{
	color:#505050;
	font-size:1.2rem;
	line-height:1;
	padding:0 0 10px 0;
	transition:0.3s ease;
}
.headerL.shrink .headerLSub {
  	font-size: 1.05rem;
  	font-weight: 600;
}
.headerR{
	width: calc(100% - 800px);
  	margin: 0 0 0 480px;
	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-between;
	 position: relative;
  	z-index: auto;
}
.header-item {
  	transition:.3s;
	position:relative;
  	z-index: auto;
}
.header-item:hover {
  	/*background-color: #fff;*/
}
.header-item a {
  	color: #111;
  	display: block;
  	padding:0;
	transition:.3s;
}
.header-item a:hover {
  	color:var(--themecolor);
	text-decoration:none;
}
.header-item.recruit-link a {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.recruit-link .material-symbols-outlined {
    font-size: 1em;
    line-height: 1;
}
.megaMenu {
	background-color:#fff;
  	height: 0;
	left:0;
  	overflow: hidden;
  	position: absolute;
  	text-align: center;
  	transition: height .3s;
  	width: 280px;
  	max-width: 280px;
	margin:auto;
	box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.3);
	-moz-box-shadow:0px 5px 10px 0px rgba(0, 0, 0, 0.3);
	-webkit-box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.3);
	border-radius:5px;
	-moz-border-radius:5px;
	-webkit-border-radius:5px;
	 z-index: 120;
}
.megaMenuNaka{
	width:90%;
	max-width:90%;
	margin:0 auto;
}
.megaMenu-list{
	position:relative;
	/*display:flex;
	justify-content:space-between;*/
}
.megaMenu-list li{
	border-bottom:1px solid #f2f2f2;
}
.megaMenu-list li:last-child{
	border-bottom:none;
}
.megaMenu-list a{
	color:#111;
  	display:block;
	width:98%;
	font-size:1.5rem;
	z-index: 1;
	position: relative;
	padding: 8px 0 8px 20px;
	transition:.3s;
	text-align:left;
}
.megaMenu-list a::before{
  	content: '';
  	width: 14px;
  	height: 14px;
  	background: var(--themecolor);
  	border-radius: 50%;
  	position: absolute;
  	top: 1px;
  	left: 0;
  	bottom: 0;
  	margin: auto;
	transition:.3s;
}
.megaMenu-list a:after {
  	content: '';
  	width: 4px;
  	height: 4px;
  	border: 0;
  	border-top: solid 2px #fff;
  	border-right: solid 2px #fff;
  	transform: rotate(45deg);
  	position: absolute;
  	top: 1px;
  	left: 3px;
  	bottom: 0;
  	margin: auto;
	transition:.3s;
}
.megaMenu-list a:hover::before{
	left: 2px;
}
.megaMenu-list a:hover::after{
	left: 5px;
}
.megaMenu-item.has-sub {
  	position: relative;
}
.megaMenu-item .sub-submenu {
  	display: none;
  	position: absolute;
  	top: 0;
  	left: 100%;
  	width: 160px;
  	background-color: #fff;
  	box-shadow: 0 0 10px rgba(0,0,0,0.15);
	-moz-box-shadow: 0 0 10px rgba(0,0,0,0.15);
	-webkti-box-shadow: 0 0 10px rgba(0,0,0,0.15);
  	border-radius: 5px;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
  	z-index: 100;
}
.megaMenu-item {
    position: relative;
}
.megaMenu-item .sub-submenuNaka {
    position: absolute;
    top: 0;
    left: 105%;
    z-index: 9999;
    background: #fff;
    display: none;
    width: 220px;
    border: 1px solid #eee;
}
.megaMenu-item:hover .sub-submenuNaka {
    display: block;
}
.sub-submenuNaka{
	width:100%;
	max-width:100%;
	margin:0 auto;
}
.megaMenu-item.has-sub:hover .sub-submenu {
  	display: block;
}
.sub-submenuNaka ul{
	width:90%;
	max-width:90%;
	margin:0 auto;
}
.sub-submenuNaka li {
  border-bottom: 1px solid #eee;
}
.sub-submenuNaka li:last-child {
  border-bottom: none;
}
.sub-submenuNaka li a {
  	display: block;
  	padding: 8px 15px 8px 20px;
  	font-size: 1.4rem;
  	color: #111;
  	text-align: left;
  	transition: 0.3s;
}
.sub-submenuNaka li a:hover {
  	color: var(--themecolor);
}
.header-item:hover .megaMenu, .megaMenu:hover {
  	height: auto;
  	overflow: visible;
  	padding: 5px 0 0 0;
}
.megaMenu .sub-submenu {
  	position: absolute;
  	top: 0;
  	left: 100%;
  	z-index: 10;
}
#dropmenu li ul {
  	list-style: none;
  	position: absolute;
  	z-index: 100;
  	top: 100%;
  	left: 0;
  	width: 100%;
  	margin: 0;
  	padding: 0;
}
#dropmenu li ul li {
  	overflow: hidden;
  	width: 100%;
  	height: 0;
  	color: #fff;
  	transition: .2s;
}
#dropmenu li ul li a {
  	padding: 13px 15px;
  	background: #7c8c0e;
  	text-align: left;
  	font-size: 12px;
  	font-weight: normal;
}
.header-item:hover .megaMenu {
  	height: auto;
  	padding: 5px 0 0 0;
}
.headerRM{
	width: calc(100% - 300px);
}
.headerContact{
	width:260px;
  	margin: 0 0 0 40px;
	display:flex;
	justify-content:space-between;
	align-items: stretch;
	border:1px solid var(--themecolor);
}
.headerTel{
	width:calc(100% - 60px);
	margin:0;
	position: relative;
  	display: inline-block;
	text-align:center;
	font-family:var(--enLg);
	font-size:1.8rem;
	color:var(--themecolor);
}
.headerMail{
	width:60px;
	height: 100%;
}
.headerMail a{
	display: flex;
  	align-items: center;
  	justify-content: center;
  	color: #fff;
  	text-align: center;
  	box-sizing: border-box;
  	width: 100%;
  	height: 34px;
  	transition: .3s;
	background:var(--themecolor);
}
.headerMail a span{
	display:inline-block;
	font-size:28px;
}
.headerMail .material-symbols-outlined {
  font-variation-settings:
  'FILL' 0,
  'wght' 400,
  'GRAD' 0,
  'opsz' 20
}
.headerMail a:hover{
	background:var(--hovercolor);
	text-decoration:none;
}
.c-menu{
	display:none;
}

@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;
}
.headerLSub {
    font-size: 1.1rem;
}
.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 50px 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:first-child a{
  	padding:0 0 20px 0;
}
.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;
}
.hspMUnderContactTxt{
	text-align:center;
	font-size:1.45rem;
	font-weight:500;
	margin:0 auto 5px auto;
}
.hspMUnderContact {
	width:100%;
	margin:0 auto 30px auto;
}
.hspMUnderContact a{
	display:block;
	width:100%;
	background:var(--themecolor);
	color:#fff;
	text-align:center;
	padding:13px 5%;
	box-sizing:border-box;
	border-radius:10px;
	-moz-border-radius:10px;
	-webkit-border-radius:10px;
	font-size:1.7rem;
	transition:.3s;
}
.hspMUnderContact a:hover{
	background:var(--hovercolor);
	border-radius:20px;
	-moz-border-radius:20px;
	-webkit-border-radius:20px;
	text-decoration:none;
}
.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;
}
}

@media screen and (max-width: 640px) {
.sp-menu-btn_03 {
     right: 1px;
     top: 4px;
}
.header__navi_03 ul {
  	padding: 65px 0 30px 0;
	width:84%;
}
.hspMUnderContact {
    margin: 0 auto 10px auto;
}
.hspMUnderMenu ul{
	padding: 20px 0 10px 0!important;
	width:100%!important;
}
.accBtn:after {
  	top: 20%;
}
}

@media screen and (max-width: 480px) {
.header {
    height: 60px;
    min-height: 60px;
}
.headerL {
    max-width: 230px;
}
.header-logo {
    width: 230px;
}
.headerLSub {
    display:none;
}
}

@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{
	width:100%;
	margin:0 auto;
	overflow:hidden;
}
#wrapperTop .main {
    width:94%;
	max-width:1400px;
	margin:0 auto;
	overflow:hidden;
	padding:90px 0;
}
#wrapperTop .contents , #wrapper .contents {
	width:100%;
	margin:0 auto;
	clear:both;
	position:relative;
	z-index:1;	
}
#wrapperTop .contentsTopSt {
	width:100%;
	margin:0 auto;
	clear:both;
	position:relative;
	z-index:1;
	background:url(./images/top/top-strength-bg.jpg) no-repeat center center;
	background-size: cover;
	overflow: hidden;
}
#wrapperTop .contentsTopSt::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 50%;
	height: 100%;
	background: rgba(255, 255, 255, 0.7);
	z-index: 2;
	pointer-events: none;
}
#wrapperTop .contentsTopYellow , #wrapper .contentsTopYellow{
	width:100%;
	margin:0 auto;
	clear:both;
	position:relative;
	z-index:1;
	background:#fff3e1;
}
#wrapperTop .mainTopSt{
	width:94%;
	max-width:1400px;
	margin:0 auto;
	overflow:hidden;
	padding:90px 0 0 0;
	z-index:10;
	position:relative;
}
#wrapperTop .mainTopPickup{
	width:100%;
	margin:0 auto;
	overflow:hidden;
	padding:50px 0 90px 0;
	position:relative;
}
#wrapperTop .contentsTopRec{
	width:100%;
	margin:0 auto;
	clear:both;
	position:relative;
	z-index:1;
	background:#fff3e1;
	padding:90px 0;
}
#wrapper .main  {
    width:94%;
	max-width:1400px;
	margin:0 auto;
	padding:90px 0;
	position:relative;
}
@media screen and (max-width: 1500px) {
#wrapperTop .main  {
    width:90%;
	max-width:90%;
	padding:70px 0;
}
#wrapperTop .mainTopSt{
	 width:90%;
	max-width:90%;
	padding:70px 0 0 0;
}
#wrapperTop .mainTopPickup{
	padding:70px 0;
}
#wrapperTop .contentsTopRec{
	padding:70px 0;
}
#wrapper .main  {
    width:90%;
	max-width:90%;
	padding:70px 0 90px 0;
}
}
@media screen and (max-width: 1340px) {
#wrapperTop .main {
	max-width:90%;
	padding:60px 0;
}
#wrapperTop .mainTopSt {
        padding: 60px 0 0 0;
}
#wrapperTop .mainTopPickup{
	padding:60px 0;
}
}
@media screen and (max-width: 1000px) {
#wrapperTop .contentsTopSt::before {
	right:0;
	margin:auto;
	width: 100%;
}
#wrapper .main  {
	padding:60px 0 80px 0;
}
}
@media screen and (max-width: 800px) {
#wrapperTop .main {
	padding:50px 0;
}
#wrapperTop .mainTopSt {
    padding: 50px 0 0 0;
}
#wrapperTop .mainTopPickup{
	padding:50px 0;
}
#wrapperTop .contentsTopRec{
	padding:60px 0;
}
}
@media screen and (max-width: 640px) {
#wrapperTop .main {
	max-width:84%;
}
#wrapperTop .mainTopSt {
    width:84%;
	max-width:84%;
}
#wrapper .main  {
    width:86%;
	max-width:86%;
	padding:30px 0 50px 0;
}
#wrapperTop .contentsTopRec{
	padding:60px 0 5px 0;
}
}


/******************
フッターコンタクト
******************/
.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;
}
.footerNaka{
	width:90%;
	max-width:1400px;
	margin:0 auto;
	padding:50px 0;
	display:flex;
}
.footerL{
	width:22%;
}
.footerR{
	width:calc(100% - 32%);
	margin:0 0 0 10%;
}

.footerLogo{
	width:100%;
	overflow:hidden;
	margin:0 0 15px 0;
}
.footerLogo img{
	max-width:100%;
	display:block;
	margin:0;
	height:auto;
}
.footerAdd{
	font-size:1.4rem;
	line-height:2.3rem;
	font-style:normal!important;
}
.footerAdd a{
	pointer-events:none;
	color:var(--basecolor);
}
.footerMenu{
	width:100%;
	margin:0 auto;
	overflow:hidden;
	position:relative;
	display:flex;
}
.fMenu{
	position:relative;
	width:22%;
	border-left:1px solid #424242;
	padding:0 2%;
}
.fMenu:last-child{
	width:48%;
}
.fMenu li{
	position:relative;
	padding:10px 0 0 0;
}
.fIcon {
  display: inline-block;
  width: 14px;
  height: 14px;
  background-color: #e3f0ee;
  border-radius: 50%;
  position: relative;
  margin-right: 8px;
  vertical-align: middle;
}

.fIcon::after {
  	content: "";
  	position: absolute;
  	top: 50%;
  	left: 50%;
  	transform: translate(-50%, -50%);
  	width: 0;
  	height: 0;
  	border-top: 3px solid transparent;
  	border-bottom: 3px solid transparent;
  	border-left: 5px solid #2d8c7f;
}
.fMenu li a{
	position:relative;
	font-size:1.4rem;
}
.fMenu li ul{
	position:relative;
	display:flex;
	flex-wrap:wrap;
	width: 94%;
  	margin: 0 0 0 6%;
}
.fMenu li ul li{
	width:24%;
	position:relative;
	padding:3px 0;
}
.fMenu li ul li a{
	width:100%;
	display:block;
	position:relative;
	padding:0 0 0 15px;
}
.fMenu li ul li a::before{
	font-family: 'Material Icons';
	content: '\e5cc';
	position: absolute;
	left: 0.1px;
	top: 3%;
	color: var(--themecolor);
	font-weight: 500;
	transition: 0.3s;
}
.fMenu li ul li:first-child{
	width:66%;
}
.fMenu li ul li:nth-child(2){
	width:24%;
}
.fMenu li ul li:nth-child(3) {
	width:18%;
}
.fMenu li ul li:nth-child(4) {
	width:43%;
}
.fMenu li ul li:nth-child(6) {
	width:45%;
}
.fSubMenu{
	position:relative;
	width: 94%;
  	margin: 0 0 0 6%;
}
.fSubMenu li{
	width:100%!important;
	position:relative;
	padding:1px 0;
}
.fSubMenu li a{
	width:100%;
	display:block;
	position:relative;
	padding:0 0 0 15px;
}
.fSubMenu li a::before{
	font-family: 'Material Icons';
	content: '\e5cc';
	position: absolute;
	left: 0.1px;
	top: 3%;
	color: var(--themecolor);
	font-weight: 500;
	transition: 0.3s;
}
.fSubMenu li ul{
	width:100%;
	display:flex;
}
.fSubMenu li ul li{
	width:30%!important;
	position:relative;
	padding:0;
}
.fSubMenu li ul li a{
	width:100%;
	display:block;
	position:relative;
	padding:0 0 0 9px;
	font-size:1.3rem;
}
.fSubMenu li ul li a::before{
	content: '';
	position: absolute;
	width:5px;
	height:5px;
	border-radius:50%;
	-moz-border-radius:50%;
	-webkit-border-radius:50%;
	left: 0.1px;
	top: 15px;
	background: var(--themecolor);
	transition: 0.3s;
}
.footerUnder{
	width:100%;
	margin:0 auto;
	border-top:1px solid #424242;
}
.footerUnderNaka{
	width:90%;
	max-width:1400px;
	margin:0 auto;
	padding:15px 0;
	display:flex;
	justify-content:space-between;
}
.footerUnderMenu{
	width:65%;
}
.footerUnderMenu ul{
	display:flex;
}
.footerUnderMenu ul li a{
	font-size:1.2rem;
	padding:0 30px 0 0;
	transition:.3s;
}
.copy{
	clear:both;
	text-align:right;
	width:35%;
	overflow:hidden;
	font-size:1.1rem;
}
.copy br{
	display:none;
}
.copySp{
	display:none;
}
#fixSideBtn{
	clear:both;
	z-index:90;
	display:block;
	position: fixed;
	bottom: 10px;
	right: 0;
}
#fixSideBtn a{
	position: relative;
	transition: all 0.3s ease;
	display:inline-block;
}
#fixSideBtn a img{
	box-shadow: -5px 0px 5px 0px rgba(0, 0, 0, 0);
	-moz-box-shadow: -5px 0px 5px 0px rgba(0, 0, 0, 0);
	-webkit-box-shadow: -5px 0px 5px 0px rgba(0, 0, 0, 0);
	transition: box-shadow 0.3s ease, opacity 0.3s ease;
	will-change: box-shadow, opacity;
}
#fixSideBtn a:hover img{
	box-shadow: -5px 0px 5px 0px rgba(0, 0, 0, 0.2);
	-moz-box-shadow: -5px 0px 5px 0px rgba(0, 0, 0, 0.2);
	-webkit-box-shadow: -5px 0px 5px 0px rgba(0, 0, 0, 0.2);
	opacity:1!important;
	-moz-opacity:1!important;
	-webkit-opacity:1!important;
}
#fixBottom{
	display:none;
}
@media screen and (max-width:1500px) {
.footerNaka{
	max-width:90%;
}
.footerUnderNaka {
   max-width:60%;
}
}
@media screen and (max-width:1350px) {
.footerUnder{
	padding:0 0 40px 0;
}
}
@media screen and (max-width:1300px) {
.footerL{
	width:25%;
}
.footerR{
	width:calc(100% - 28%);
	margin:0 0 0 3%;
}
.fMenu{
	width:24%;
}
.fMenu:last-child{
	width:44%;
}
.fMenu li ul li:first-child {
    width: 100%;
}
}
@media screen and (max-width:1200px) {
.footerNaka {
    display: block;
	padding: 50px 0;
}
.footerL {
    width:100%;
	margin:0 auto;
}
.footerR {
    display:none;
}
.footerLogo {
    width: 30%;
	margin:0 auto 20px auto;
}
.footerAdd {
    text-align:center;
}
.footerUnder{
	padding:0;
}
.footerUnderNaka {
   max-width:90%;
	display:block;
}
.footerUnderMenu {
    display:none;
}
.copy {
    text-align: center;
    width: 100%;
}
}
@media screen and (max-width:1000px) {
.footerNaka {
	padding: 30px 0;
}
.footerLogo {
    width: 40%;
	margin:0 auto 15px auto;
}
}
@media screen and (max-width:800px) {
.footerAdd a{
    pointer-events:inherit;
}
.footerUnder{
	padding:0 0 55px 0;
}
.footerUnderNaka{
    padding: 10px 0;
}
#fixSideBtn{
	display:none;
}
#fixBottom{
	display:none;
	clear:both;
	z-index:90;
	position: fixed;
	bottom: 0;
	right: 0;
	left:0;
	margin:auto;
	width:100%;
}
.fixBottomBtn{
	display:flex;
	width:100%;
}
.fixBottomOne{
	width:50%;
}
.fixBottomOne a{
	width:100%;
	background:#eae418;
	color:var(--basecolor);
	text-align:center;
	padding:13px 3%;
	box-sizing:border-box;
	font-weight:600;
	display: inline-flex;
  	align-items: center;
  	justify-content: center;
  	gap: 0.4em;
  	text-decoration: none;
	font-size:1.7rem;
	transition:.3s;
}
.fixBottomOne:nth-child(2) a{
	background:#387482;
	color:#fff;
}
.fixBottomOne a .material-symbols-outlined {
    font-size: 1.8em;
    line-height: 1;
	vertical-align: middle;
  	position: relative;
  	top: 0.07em;
}
.fixBottomOne a:hover{
	background:#e8b21a;
}
.fixBottomOne:nth-child(2) a:hover{
	background:#38467f;
}
}
@media screen and (max-width:640px) {
.footerLogo {
    width: 60%;
}
}
@media screen and (max-width:480px) {
.footerLogo {
    width: 75%;
}
}
@media screen and (max-width:400px) {
.footerLogo {
    width: 80%;
}
}
@media screen and (max-width:350px) {
.footerLogo {
    width: 85%;
}
.fixBottomOne a{
	font-size:1.6rem;
}
.fixBottomOne a .material-symbols-outlined {
    font-size: 1.7em;
}
}
@media (orientation: landscape) and (max-width: 956px){
#fixSideBtn a img {
  	width: 80px;
}
}

@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;
}
.headerLSub{
	display:none;
}
.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;
}
.headerTel {
    width: calc(100% - 40px);
    font-size: 1.5rem;
}
.headerMail {
    width: 40px;
}
.mainVisual {
    margin-top: 0!important;
	width:1000px!important;
}
.mainTxtWrapper {
    right: 13%!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;
}
.topInfoMidashi {
    max-width: 200px!important;
}
.topInfoBox {
    width: calc(100% - 280px)!important;
    margin: 0 0 0 80px!important;
}
.topMidashi {
    font-size: 2.8rem!important;
	line-height: 1.5!important;
}
.topStrengthTxt {
    font-size: 3rem!important;
}
.topStrengthTxt span {
    font-size: 4rem!important;
}
.topStrengthSubTxt br{
	display:none;
}
.topStrengthIconWrapper {
    flex-wrap: wrap!important;
	justify-content: space-around!important;
}
.strengthItem {
    width: calc(33.333% - 50px)!important;
	margin:20px 0;
}
#wrapperTop .mainTopPickup {
    max-width: 1000px!important;
    padding: 60px 0!important;
}
.topPickupInner {
    max-width: 90%!important;
}
.pu-section .topPickupInner {
    padding: 0 0 40px 0!important;
}
.topMiddleBnr {
    margin: 50px auto 10px auto!important;
}
.topRecruitWrapper {
    width: 90%!important;
    padding: 70px 0!important;
}
.topRecruit {
    max-width: 100%!important;
}
.topRecruitL {
    width: 47%!important;
    max-width: 47%!important;
}
.topRecruitR {
    top: 25%!important;
}
#wrapperTop .contentsTopRec {
    padding: 0 0 10px 0!important;
}
.commonContactL {
    max-width: 250px!important;
}
.commonContactR {
    overflow: hidden;
    width: calc(100% - 330px)!important;
    margin: 0 0 0 80px!important;
}
.contactMidashi {
    font-size: 4rem!important;
	line-height:1.4!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;
}
#fixSideBtn {
    display:none;
}
#wrapper .main {
    max-width: 1000px!important;
    padding: 50px 0!important;
	width:100%!important;
}
.bread {
    width: 100%!important;
    padding: 20px 0 0 0!important;
}
.h2Main p span,
.h2Main h2 span {
  	transform: unset!important;
}
.h2SubEn {
    font-size: 7rem!important;
	line-height: 0.3!important;
}
h2 {
    font-size: 2.2rem!important;
    margin: 0 auto 40px auto!important;
}
.companyMain {
    max-width: 70%!important;
}
.companySide {
    width: calc(100% - 75%)!important;
    margin: 0 0 0 5%!important;
    position: relative!important;
    top: 0!important;
}
.commonContact{
	width:90%!important;
	margin:0 auto;
}
}



@page{
	margin: 16mm 10mm;
}

@-moz-document url-prefix(){
@page{
	margin: auto;
}
}

@media screen and (-webkit-min-device-pixel-ratio:0){
@page{
	margin: auto;
}
}

