html{
	height: 100%;
	padding:0;
	margin:0;
}
a {
	text-decoration: none;
}
a:link{
    color: #4C433F;
}
a:visited{
    color: #4C433F;
}
label{
	padding-left:5px;
}

img{ 
  border: 0; 
  margin:0; 
  padding:0; 
  vertical-align:middle;
 }

ul{
  list-style-type: none;
	margin:0; padding:0;
}
li,p{
	margin:0; padding:0;
}
input{
  vertical-align: middle;
	font-size: 16px ;
}
textarea{
	font-size: 16px ;
}
h1,h2,h3,h4,h5,h6{
  margin: 0;
	font-weight: normal;
	font-family: "見出ゴMB31";
}
iframe{
	border: none;
}
/*
**  Mac OS X, Win Vista, Win XP, Win 2000のフォントを指定
*/
body
{
  font-size: 15px;
  color: #4c433f;
	background-color: #f0f5fc;

/*
	background-color: #d2e0f9;
*/
/*
  font-family: "ヒラギノ角ゴ Pro W3" , "Hiragino Kaku Gothic Pro" , "メイリオ" , Meiryo, Osaka, "ＭＳ Ｐゴシック" , "MS P Gothic" , sans-serif;
  font-family: "メイリオ" , Meiryo, Osaka, "ＭＳ Ｐゴシック" , "MS P Gothic","Hiragino Kaku Gothic ProN W3";
*/
/*
	font-family:"中ゴシックBBB",Avenir , "Open Sans" , "Helvetica Neue" , Helvetica , Arial , Verdana , Roboto , "メイリオ" ,"游ゴシック" , "Yu Gothic" , "游ゴシック体" , "YuGothic" , "ヒラギノ角ゴ Pro W3" , "Hiragino Kaku Gothic Pro" , "Meiryo UI" ,  Meiryo , "ＭＳ Ｐゴシック" , "MS PGothic" , sans-serif;
*/
	font-family:Avenir , "Open Sans" , "Helvetica Neue" , Helvetica , Arial , Verdana , Roboto , "メイリオ" ,"游ゴシック" , "Yu Gothic" , "游ゴシック体" , "YuGothic" , "ヒラギノ角ゴ Pro W3" , "Hiragino Kaku Gothic Pro" , "Meiryo UI" ,  Meiryo , "ＭＳ Ｐゴシック" , "MS PGothic" , sans-serif;
  margin:0; padding: 0;
	height: 100%;
	-webkit-text-size-adjust: 100%;
}
.cnt_wrapper{
	margin-top: 80px;
	padding-bottom: 130px;
}
.wrapper{
	width: 100%;
	margin: 0 auto;
	padding: 0;
	overflow-x: hidden;
}
.contents{
	width: 94%;
	margin: 0 auto;
	padding:0;
}
.contents_2{
	width: 1200px;
	margin: 0 auto;
	padding:0;
}
/* =========================================
   ヘッダー
 ========================================= */
.header{
	box-sizing: border-box;
	position: fixed;
	top:0;
	width: 100%;
	height: 80px;
	border-top: 8px solid #322424;
	border-bottom: 1px solid #705f5f;
	background-color: #f0f5fc;
/*
	background-color: rgba(210,224,249,0.8);
*/
	z-index: 10;
	font-family: "見出ゴMB31";
	font-size: 0.9em;
}
.logo{
	float: left;
	padding: 15px 0 0 30px;
}
.globalMenu{
	position: absolute;
	float: right;
	right: 30px;
}
.globalMenu ul{
	display: table;
}
.globalMenu div{
	float: left;
}
.leftMenu ul li{
	position: relative;
	display: table-cell;
	height: 72px;
	padding: 0 7px;
	text-align: center;
	vertical-align: middle;
}
.leftMenu ul li a {
	color: #4c433f;
  padding-bottom: 5px;
  position: relative;
}
.leftMenu ul li a::before {
	color: #4c433f;
  background: #4c433f;
  content: '';
  width: 100%;
  height: 1px;
  position: absolute;
  left: 0;
  bottom: 0;
  transform-origin: center top;
  transform: scale(0, 1);
  transition: transform .3s;
}
.leftMenu ul li a:hover::before {
  transform-origin: left top;
  transform: scale(1, 1);
}
 
.rightMenu ul{
	display: table;
  background: #4c433f;
  vertical-align: middle;
  border-radius: 25px;
	height: 48px;
	line-height: 48px;
	margin: 12px 0 0 15px;
}
.rightMenu ul li{
	display: table-cell;
	padding: 0 7px;
	text-align: center;
	vertical-align: middle;
	color: #fff;
}
.rightMenu ul li:first-child{
	padding-left: 18px;
}
.rightMenu ul li:last-child{
	padding-right: 18px;
}
.rightMenu ul li a{
	color: #fff;
	font-weight: bold;
	transition: opacity 0.3s ease;
}
.rightMenu ul li a:hover{
	opacity: 0.5;
}
.topicPath{
	padding: 20px 50px 0 50px;
	font-size: 0.9em;
	font-family: "見出ゴMB31";
}
.topicPath a{
	font-weight: bold;
}
.topicPath a:hover{
	text-decoration: underline;
}

/* =========================================================
   ドロワーメニュー
   ========================================================= */

/* 暗幕レイヤー（初期は非表示） */
.cp-drawer .layer{
	position:fixed; 								/* 画面全体に固定配置 */
	inset:0;												/* top/right/bottom/left を 0 に（全画面） */
	background:rgba(40,40,40,.2); 		/* 半透明ダークで背面を抑制 */
	opacity:0;											/* 初期は透明（非表示） */
	pointer-events:none;						/* 初期はクリック不可 */
	transition:.2.5s; 								/* フェード速度（好みで） */
	z-index:9999; 									/* パネルのすぐ下になるよう高めに設定 */
}

/* data-open="1" で暗幕を表示＆クリック可 */
.cp-drawer[data-open="1"] .layer{
	opacity:1;						/* フェードイン */
	pointer-events:auto;	/* クリックを拾えるように（背景クリックで閉じる） */
	z-index:9999; 									/* パネルのすぐ下になるよう高めに設定 */
}

/* ドロワーパネル本体（下からスライドイン） */
.cp-drawer .panel{
	position:fixed; 												 /* 画面に固定 */
	left:0; right:0; top:0; 							/* 画面下端に横いっぱいで固定 */
	background:#fff;												 /* 白背景 */
	color:#0f172a;													 /* テキスト色 */
	max-height:min(80vh,800px); 						 /* 上限高さ（ビューポート80% or 560px） */
	overflow:auto;													 /* コンテンツが溢れたら内部スクロール */
	border-top:1px solid #e5e7eb; 					 /* 上端に薄いボーダー */
	box-shadow:0 -8px 24px rgba(2,8,23,.18); /* 上方向へ落ちる影で浮かせる */
	pointer-events:none;										/* 初期はクリック不可 */
	transform:translateY(30vh); 						 /* 初期は画面の下外へ待避 */
	opacity: 0;
	transition:.2s ease-in-out; 								/* フェード速度（好みで） */
	z-index:10000;													 /* 暗幕より前面に */
}

/* data-open="1" で画面内へスライドイン */
.cp-drawer[data-open="1"] .panel{
  transform:translateY(0);
	opacity: 1;
	pointer-events:auto;  /* クリックを拾えるように（背景クリックで閉じる） */
  z-index:10000;                           /* 暗幕より前面に */
}

/* パネル内ヘッダー（タイトル＋閉じるボタン） */
.cp-drawer .panel header{
	position: relative;
	display:flex; 														/* 横並び */
	align-items:center; 											/* 垂直中央 */
	justify-content:space-between;						/* タイトル左／ボタン右 */
	padding:14px 16px;												/* 内側余白 */
	border-bottom:1px solid #e5e7eb;					/* 下線で区切り */
	position:sticky; top:0; 									/* スクロールしても上部に固定 */
	background:#fff;													/* 固定時に背景透けを防ぐ */
	z-index:1;																/* 内容より前に */
}

/* 閉じるボタンの見た目（控えめ） */
.cp-drawer .panel .close{
  appearance:none;                          /* ブラウザデフォルト外観を無効化 */
  background:#fff;
  border:1px solid #4C433F;
  border-radius:10px;
  padding:10px;
  cursor:pointer;
}

.cp-drawer .drawer_menu{
	position: relative;
	width: 70%; height: auto;
	margin-left: 15%;
	padding: 50px 0 100px 0;
}
.cp-drawer .drawer_menu div{
	display: block;
	float: left;
}
.cp-drawer .drawer_menu .site_menu{
	position: relative;
	width: calc(100% - 360px);
}
.cp-drawer .drawer_menu ul{
	display: block;
	width: 100%;
}
.cp-drawer .drawer_menu .site_menu ul li{
	position: relative;
	display: block;
	float: left;
	width: 50%;
	height: 80px;
	line-height: 80px;
}
.cp-drawer .drawer_menu .site_menu li a{
	display: block;
	position: absolute;
	top:0; left:0;
	width: calc(100% - 40px); height: 100%;
	font-weight: bold;
	font-family: "見出ゴMB31";
	color: #4c433f;
	font-size: 1.3em;
	padding: 0 10px;
	border-bottom: 1px solid #ddd;
}
.cp-drawer .btns{
	width: 360px;
}
.cp-drawer .btns ul li{
	position: relative;
	padding: 20px 0 0 40px;
	height: 60px;
	line-height: 60px;
}
.cp-drawer .btns a{
		display:block;
		width:calc(100% - 40px);
		height:100%;
		text-decoration: none;
		text-align:center;
		border:1px solid #4C433F;
		color:#4C433F;
		font-size:1.3em;
		font-weight:bold;
		border-radius:50px;
		-webkit-border-radius:50px;
		-moz-border-radius:50px;
		transition: background 0.3s ease;
}
.cp-drawer .btns li:first-child a{
	background: no-repeat #fff right 7px top 50% url("../img/icon_faq.png");
}
.cp-drawer .btns li:nth-child(2) a{
	background: no-repeat #fff right 7px top 50% url("../img/icon_req.png");
}
.cp-drawer .btns li:last-child a{
	color:#fff;
	background: no-repeat #4C433F right 7px top 50% url("../img/icon_mail.png");
}
.cp-drawer .btns li:first-child a:hover{
	background: no-repeat #DFE8F7 right 7px top 50% url("../img/icon_faq.png");
}
.cp-drawer .btns li:nth-child(2) a:hover{
	background: no-repeat #DFE8F7 right 7px top 50% url("../img/icon_req.png");
}
.cp-drawer .btns li:last-child a:hover{
	color:#4C433F;
	background: no-repeat #DFE8F7 right 7px top 50% url("../img/icon_mail.png");
}

/* =======================================
   トップページ
	 ======================================= */
.topArea{
	position: relative;
	width: 94%;
	margin: 0 auto;
}
.catchArea{
	float: left;
	width: 420px;
	padding: 180px 80px 0 80px;
	font-family: "見出ゴMB31";
}
.photoArea{
	position: relative;
	width: calc(100% - 580px);
	float: right;
	margin: 30px 0 60px 0;
}
.catchArea p{
	font-size: 3em;
	font-weight: bold;
	margin-bottom: 100px;
}
.catchArea ul li{
	position: relative;
	display: block;
	float: left;
	height: 60px;
	line-height: 60px;
	width: calc(50% - 15px);
	margin: 0 15px 0 0;
}
.catchArea ul li a{
	position: absolute;
	top: 0; left:0;
	display:block;
	width: calc(100% - 35px);
	height:100%;
	text-decoration: none;
	text-align: left;
	padding-left: 35px;
	border:1px solid #4C433F;
	color:#4C433F;
	font-size:1.2em;
	font-weight:bold;
	border-radius:50px;
	-webkit-border-radius:50px;
	-moz-border-radius:50px;
	transition: background 0.3s ease;
 	 cursor:pointer;

}
.catchArea ul li:first-child a{
	background: no-repeat #fff right 7px top 50% url("../img/icon_req.png");
}
.catchArea ul li:last-child a{
	color:#fff;
	background: no-repeat #4C433F right 7px top 50% url("../img/icon_mail.png");
}
.catchArea ul li:first-child a:hover{
	background: no-repeat #DFE8F7 right 7px top 50% url("../img/icon_req.png");
}
.catchArea ul li:last-child a:hover{
	color:#4C433F;
	background: no-repeat #DFE8F7 right 7px top 50% url("../img/icon_mail.png");
	}
.photoArea ul{
	display: flex;
	flex-wrap: wrap;
}
.photoArea ul li{
	width: calc(50% - 7px); height: 280px;
	border-radius: 5px;
	overflow: hidden;
}
.photoArea ul li:nth-child(2n+1){
	margin: 0 7px 14px 0;
}
.photoArea ul li:nth-child(2n){
	margin: 0 0 14px 7px;
}

.photoArea ul li img{
	object-fit: cover;
	width: 100%;
	height: 100%;
}
.msgAreaOut{
	position: relative;
	width: 100%; height: auto;
	padding: 6em 0;
	overflow: hidden;
	background: no-repeat top left / cover url("../img/recruit/topimg_rc_3.webp");
  z-index: 0;
	font-family: "見出ゴMB31";
}
.msgAreaOut:before{
  content: '';
  background: inherit;
  -webkit-filter: blur(3px);
  -moz-filter: blur(3px);
  -o-filter: blur(3px);
  -ms-filter: blur(3px);
  filter: blur(3px);
  position: absolute;
  top: -3px;
  left: -3px;
  right: -3px;
  bottom: -3px;
  z-index: -1;
}
.backCover{
	position: absolute;
	top: 0; left: 0;
	width: 100%; height: 100%;
	background-color: rgba(70, 70, 70, 0.7);
  z-index: 1;
}
.msgArea{
	position: relative;
	width: 640px; height: auto;
	margin: 0 auto;
  z-index: 2;
}
.msgArea .copy{
	font-weight: bold;
	font-size: 4em;
	line-height: 1.2em;
	color: #fff;
}
.msg{
	padding-top: 3em;
	font-weight: bold;
	font-size: 1.3em;
	color: #fff;
}
.linkBtn{
	position: relative;
	margin-top: 4em;
	width: 10em; height: 1.4em;
}
.linkBtn a{
	position: absolute;
	top:0; left: 0;
	width: 100%; height: 100%;
	color: #fff;
	font-weight: bold;
	font-size: 1.2em;
}
.linkBtn a:hover {
	opacity: 0.8;
	transform: translateX(-4px);
  transition: transform .2s;
}
.interviewOut{
	position: relative;
	width: 980px; height: auto;
	margin: 0 auto;
	box-sizing: border-box;
	padding: 80px 8px;
	font-family: "見出ゴMB31";
}
.headerBox{
	padding-bottom: 40px;
}
.h2Title{
	float: left;
	width: calc(100% - 130px);
}
.h2Title h2{
	font-family: "ゴシックMB101 B";
	font-size: 2.8em;
}
.h2Title span{
	font-size: 1.2em;
}
div.link{
	position: relative;
	float: right;
	width: 130px; height: 1.4em;
	font-size: 1.1em;
	margin-top: 2em;
}
div.link a{
	position: absolute;
	top:0; left: 0;
	width: 100%; height: 100%;
	color: #4C433F;
	font-weight: bold;
	font-size: 1em;
}
div.link a:hover {
	opacity: 0.8;
	transform: translateX(-4px);
  transition: transform .2s;
}

.staffBox{
  position: relative;
/*
	display: flex;
	flex-wrap: wrap;
*/
	width: 100%; height: auto;
}
.staff{
  position: relative;
	float: left;
	width: 31%; height: auto;
	margin-right: 5%;
}
.staff .photo{
	position: relative;
	width: 100%; height: 100%;
	border-radius: 8px;
	overflow: hidden;
}
.staff .photo img{
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  object-fit: cover;
}
.staff .photo a::before {
  content: "";
  display: block;
  padding-top: 100%;
}
.staff .work{
	padding: 10px 0;
	font-size: 1.1em;
}
.staff .title{
	font-size: 1.4em;
	font-weight: bold;
	line-height: 1.4em;
}
.jobAreaOut{
	position: relative;
	width: 100%; height: auto;
	padding: 6em 0;
	overflow: hidden;
	font-family: "見出ゴMB31";
	background: no-repeat top left / cover url("../img/recruit/topimg_rc_1.webp");
  z-index: 0;
}
.jobAreaOut:before{
  content: '';
  background: inherit;
  -webkit-filter: blur(3px);
  -moz-filter: blur(3px);
  -o-filter: blur(3px);
  -ms-filter: blur(3px);
  filter: blur(3px);
  position: absolute;
  top: -3px;
  left: -3px;
  right: -3px;
  bottom: -3px;
  z-index: -1;
}
.jobArea{
	width: 1180px;
	margin: 0 auto;
}
.jobMenu{
	position: relative;
	float: left;
	box-sizing: border-box;
	width: 50%;
	padding: 18px 25px 25px 25px;
  z-index: 5;
}
.jobMenu ul, .jobMenu ul li{
	position: relative;
	display: block;
	width: 100%;
}
.jobMenu ul li{
	box-sizing: border-box;
	padding: 25px;
	height: 120px;
	margin-bottom: 25px;
	border-radius: 5px;
	background: no-repeat #f0f5fc right 20px top 50% url("../img/icon_arrow.png?3121403");
}
.jobMenu ul li p{
	font-size: 1.5em;
	font-weight: bold;
	padding-bottom: 7px;
}
/*
.jobMenu ul li div{
	display: flex;
}
*/
.jobMenu ul li div span{
	display: block;
	float: left;
	background-color: rgba(213, 229, 247, 1);
	padding: 0.1em 0.5em;
	margin-right: 7px;
	border-radius: 7px;
}
.jobMenu a{
	position: absolute;
	display: block;
	width: 100%; height: 100%;
	top:0; left:0;
}
.jobMenu a:hover{
}
.jobMenu ul li:hover{
	background-color: #e4edf9;
	transition: background-color 0.7s;

}
.jobMsg{
	position: relative;
	float: right;
  z-index: 5;
	box-sizing: border-box;
	width: 50%;
	color: #fff;
	padding: 0 0 0 50px;
}
.jobMsg .h2Title, .envMsg .h2Title{
	width: 100%;
	clear: both;
}
.jobMsg .h2Title h2{
	display: block;
	width: 100%;
	border-bottom: 1px solid #fff;

}
.jobMsg .h2Title span{
	display: block;
	width: 100%;
	text-align: right;
	padding: 3px 5px 0 0;
}
.jobMsg .msg{
	padding-top: 50px;
	font-size: 1.2em;
	line-height: 1.6em;
}
.envArea{
	position: relative;
	width: 1200px;
	margin: 0 auto;
	padding: 80px 0;
	font-family: "見出ゴMB31";
}
.envMsg{
	float: left;
	box-sizing: border-box;
	width: 45%; height: auto;
	padding-right: 80px;
}
.envMsg .msg{
	color: #4c433f;
	padding: 50px 0 40px 0;
	font-size: 1.2em;
	line-height: 1.6em;
}
.envPicture{
	position: relative;
	float: right;
	width: 50%; height: 500px;
	border-radius: 5px;
	overflow: hidden;
}
.envPicture img{
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  object-fit: cover;
}
/* =======================================
   サブページ　ヘッダー
	 ======================================= */
.h1Title{
	width: 100%;
	box-sizing: border-box;
	padding: 20px 50px;
}
.h1Title h1{
	font-size: 4em;
	font-weight: bold;
}

/* =======================================
   フッター
  ======================================== */
.footer{
	box-sizing:border-box;
	position: relative;
	padding: 15px 25px;
	width: 100%; height: auto;
	background-color: #4c433f;
	color: #fff;
	z-index: 1;
}

.f_corpbox_1{
	float: left;
	width: calc(100% - 106px);
}
.f_corpbox_2{
	float: right;
}
.corpName{
	font-size: 1.3em;
	font-weight:bold;
	margin-top: 8px;
}
.corpName span{
	font-weight: normal;
	font-size: 0.9em;
}
.corpAdd{
	margin-top: 10px;
	line-height: 1.4em;
	font-size: 0.95em;
}
.corpAdd a{
	color: #fff;
}
.footerMenu {
	width: 100%;
	border-top: 1px solid #ccc;
	margin-top: 20px;
	padding: 10px 0;
}
.footerMenu ul{
	display: flex;
	justify-content:space-between;
	flex-wrap: wrap;
	width: 90%;
	margin: 0 auto;
}
.footerMenu li{
	padding: 5px 10px;
}
.footerMenu li a{
	color: #fff;
  padding-bottom: 5px;
  position: relative;
}
.footerMenu ul li a::before {
	color: #fff;
  background: #fff;
  content: '';
  width: 100%;
  height: 1px;
  position: absolute;
  left: 0;
  bottom: 0;
  transform-origin: center top;
  transform: scale(0, 1);
  transition: transform .3s;
}
.footerMenu ul li a:hover::before {
  transform-origin: left top;
  transform: scale(1, 1);
}
.footerMenu p{
	font-size: 0.85em;
	padding: 2px 15px;
}
.isoLogo{
	width: 106px; height: auto;
	text-align: center;
}
.isoLogo img{
	width: 100%;
}
.topImage{
	position: relative;
	z-index: 5;
/*
	background: linear-gradient(0deg, rgba(112,95,95,1) 0%, rgba(255,255,255,1) 100%);
*/
	color: #fff;
}
.topImage img{
	width: 100%;
	position: relative;
	top: -100px;
}
.swiper-container {
  width: 1200px;
  height: 450px;
	overflow: hidden;
}
.subTitle{
	border-bottom: 1px solid #705f5f;
	padding: 0 0 5px 5px;
	color: #582500;
	text-align: center;
}
h3.subTitle{
	text-align: left;
	font-size: 1.2em;
}
.mt_1{
	margin-top: 50px;
}
.mt_2{
	margin-top: 50px;
}


span.bold{
	display: block;
	font-size: 1.1em;
	font-weight: bold;
	color:#705f5f;
}
.box_1{
	width: 100%;
	text-align: center;
	padding: 40px 0;
	line-height: 1.8em;
}
.box_2{
	width: 100%;
	text-align: center;
	padding: 10px 0;
}
span.phone{
	font-family: "ゴシックMB101 B";
	color: #2d6efc;
	font-size: 1.4em;
}
.btn_1{
    width:320px;
    height:60px;
    line-height:60px;
		margin: 0 auto;
}
.btn_1 a{
    display:block;
    width:100%;
    height:100%;
    text-decoration: none;
    background:#2d6efc;
    text-align:center;
    color:#FFFFFF;
    font-size:18px;
    font-weight:bold;
    border-radius:10px;
    -webkit-border-radius:10px;
    -moz-border-radius:10px;
		font-family: "見出ゴMB31";
}
.btn_1 a:hover{
    background:#5892fc;
    color:#FFFFFF;
    margin-left:0px;
    margin-top:0px;
    box-shadow:none;
}
.btn_2 a{
    display:block;
    width:100%;
    height:100%;
    text-decoration: none;
    background:#d5d4d6;
    text-align:center;
    color:#666;
    font-size:18px;
    font-weight:bold;
    border-radius:10px;
    -webkit-border-radius:10px;
    -moz-border-radius:10px;
		font-family: "見出ゴMB31";
}
.btn_2 a:hover{
    background:#e2e1e3;
    color:#666;
    margin-left:0px;
    margin-top:0px;
    box-shadow:none;
}

.subMenu{
	float: right;
}
.subMenu li{
	position: relative;
	display: block;
	float: left;
	border-left: 1px dotted #705f5f;
	border-bottom: 1px dotted #705f5f;
	padding: 5px 10px;
	color: #705446;
}
div.subMenu li:last-child{
	border-right: 1px dotted #705f5f;
}
.subMenu a{
	display: block;
	position: absolute;
	top: 0; left:0;
	width: 100%; height: 100%;
}
.subMenu a:hover{
	background-color: rgba(112,84,70,0.3);
}
.companyData{
	position: relative;
	width: 820px;
	margin: 0 auto;
	padding: 20px 0;
}
.companyData dl{
	padding: 0; margin:0;
	width: 100%;
	overflow: hidden;
	border-bottom: 1px dotted #705f5f;
}
.companyData dt{
	float: left;
	clear: both;
	padding: 10px 25px; margin:0;
	width: 35%;
	line-height: 1.8em;
	text-align: left;
	border-top: 1px dotted #705f5f;
	box-sizing: border-box;
}
.companyData dd{
	padding: 10px; 
	margin: 0 0 0 35%;
	width: 65%;
	line-height: 1.8em;
	text-align: left;
	border-top: 1px dotted #705f5f;
	box-sizing: border-box;
}
.companyData dt:first-child{
	border-top: none;
}
.companyData dt:first-child + dd{
	border-top: none;
}

.contactForm{
	border-top: 1px solid #ccc;
	padding-bottom: 30px;
}
.contactForm label{
	display: block;
	padding: 20px 16px 5px 0;
}
.contactForm input[type='text']{
	width: calc(100% - 20px);
	padding: 5px 10px;
	font-size: 1em;
}
.contactForm div{
	padding: 5px 0;
}
.contactForm span{
	color: red;
}
.contactBox p{
	margin: 30px 0 5px 0;
}
.contactBox label{
	display: inline;
	font-size: 0.95em;
}
.contactBox input[type='radio']{
	position: relative;
	top: -2px;
}
.contactBox div:last-child{
	margin-top: 5px;
}
.contactBox textarea{
	width: 98%;
	line-height: 1.4em;
	width: 98%; height: 200px;
}
.btnBox{
	position: relative;
	width: 100%;
}
.leftBtn{
	float: left;
	width: 50%;
}
.rightBtn{
	float: right;
	width: 50%;

}
.red{
	color: red;
}
.bold{
	font-weight: bold;
}

#page_top{
  width: 50px;
  height: 50px;
  position: fixed;
  right: 50px;
  bottom: 50px;
  background: #2d6efc;
  opacity: 0.6;
  border-radius: 50%;
	z-index: 100;
}
#page_top a{
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
  text-align: center;
}
#page_top a::before{
  font-family: "Font Awesome 5 Free";
  content: '\f106';
  font-weight: 900;
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: 10px;
  bottom: 10px;
  right: 0;
  left: 0;
  margin: auto;
}
.txtLeft{
	text-align: left;
}
/*
@media print
{
	.header{
		display: none;
	}
}
*/
@media screen and ( max-width:1200px ){
	.globalMenu .leftMenu{
		display: none;
	}
	.footerMenu ul{
		width: 100%;
	}

	.catchArea{
		width: 320px;
		padding: 120px 40px 180px 40px;
	}
	.photoArea{
		width: calc(100% - 400px);
	}
	.catchArea p{
		font-size: 2.6em;
	}
	.catchArea ul li{
		clear: both;
		width: 100%;
		margin-bottom: 15px;
	}
	.jobArea,.envArea{
		width: 980px;
	}
}
@media screen and ( max-width:1050px )
{
	.cp-drawer .btns{
		width: 300px;
	}
	.cp-drawer .drawer_menu .site_menu{
		position: relative;
		width: calc(100% - 300px);
	}
	.cp-drawer .btns a, .cp-drawer .drawer_menu .site_menu li a{
		font-size:1.2em;
	}
	.catchArea{
		width: 270px;
		padding: 120px 20px 180px 20px;
	}
	.photoArea{
		width: calc(100% - 310px);
	}
	.catchArea p{
		font-size: 2.2em;
	}

}
@media screen and ( max-width:1000px )
{
	input,textarea {
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -webkit-appearance: none;
		border: 1px solid #888;
		border-radius: 3px;
  }
	input[type="text"]{
		padding: 8px 10px;
	}
	input[type="radio"]{
	  -webkit-appearance: none;
	  width:15px;
	  height:15px;
	  border-radius:15px;
	  background:transparent;
	  opacity:0.5;
	}
	input[type="radio"]:checked{
	  background:#2d6efc;
	  opacity:1;
	}
	.logo{
		padding: 10px 0 0 10px;
	}
/*
	.cnt_wrapper{
		margin-top: 60px;
	}
*/
	.wrapper
	{
		width: auto ;
		padding: 0 10px ;		/* 左右の余白 */
	}
	.swiper-container {
  	width: 100%; height: 320px;
	}
	.swiper-slide {
		text-align: center;
	}
	.swiper-slide img{
		width: auto; height: 100%;
	}
	.topImage img{
		top:0;
	}
	.contents_2{
		width: auto ;
		padding: 0 10px;
	}
	.contents,.companyData{
		width: auto ;
	}
	.topImage .wrapper{
		padding: 0;
	}
	.mt_1{
		margin-top: 50px;
	}
	.mt_2{
		margin-top: 30px;
	}
	.btn_1{
    width:180px;
    height:50px;
    line-height:50px;
	}
	.btnBox .btn_1, .btnBox .btn_2{
		width: 160px;
	}
	.entry .btn_1{
		width: 240px;
	}
	.subMenu{
		padding: 12px 0;
	}
	.subMenu li{
		border-radius: 8px;
		color: #fff;
		background-color: #705f5f;
		margin: 3px 2px;
	}
	.subMenu li{
		font-size: 0.9em;
	}
	.subMenu li a{
		-webkit-tap-highlight-color: rgba(0,0,0,0);
	}
	.contents .companyData:first-of-type dt{
		width: 100%;
		float: none;
		border-top: none;
		background-color: #eee;
		text-align: center;
	}
	.contents .companyData:first-of-type dd{
		border-top: none;
		width: 90%;
		margin: 0 auto;
		text-align: center;
	}
	.contents .companyData:first-of-type dd.txtLeft{
		width: 90%;
		text-align: left;
	}
	.contents .companyData:first-of-type dl{
		border: none;
	}
	.contents .companyData dt{
		padding: 10px; 
	}
	#page_top{
	  right: 20px;
		bottom: 20px;
	}
	.msgArea .copy{
		font-size: 3em;
	}
	p.msg{
		padding-top: 3.5em;
		font-size: 1.3em;
	}
/*
	.msgArea p:last-child{
		margin-top: 3.5em;
	}
	.msgArea p:last-child a{
		font-size: 1.1em;
	}
*/
	.interviewOut{
		width: 98%;
	}
/*
	.headerBox h2, .jobMsg h2{
*/
	.h2Title h2{
		font-size: 2.3em;
		line-height: 1.2em;
	}
	.h2Title span{
		font-size: 1em;
	}
	div.link{
		margin-top: 1.5em;
	}
	.jobArea,.envArea{
		width: 780px;
	}
	.jobMsg{
		padding: 0 0 0 20px;
	}
	.jobMsg .msg{
		padding-top: 20px;
		font-size: 1.1em;
		line-height: 1.4em;
	}
	.jobMenu{
		padding-left: 0;
	}
}
@media screen and ( max-width:915px )
{
	.cp-drawer .drawer_menu{
		padding: 15px 0 50px 0;
		margin-left: 5px;
		width: calc(100% - 5px);
	}
	.cp-drawer .drawer_menu div{
		clear: both;
	}
	.cp-drawer .btns{
		width: 70%;
		padding-top: 0;
		margin-left: 15%;

	}
	.cp-drawer .btns ul li{
		padding: 20px 0 0 0;
	}
	.cp-drawer .btns a{
		width: 100%;
	}
	.cp-drawer .drawer_menu .site_menu{
		position: relative;
		width: 100%;
	}
	.catchArea{
		width: 200px;
		padding: 120px 20px 180px 20px;
	}
	.photoArea{
		width: calc(100% - 240px);
	}
	.catchArea p{
		font-size: 1.6em;
	}
	.staff .work{
		font-size: 1em;
	}
	.staff .title{
		font-size: 1.2em;
		line-height: 1.2em;
	}
}
@media screen and ( max-width:830px )
{
	.jobArea,.envArea{
		width: 90%;
	}
	.jobMsg, .jobMenu, .envMsg, .envPicture{
		clear: both;
		width: 100%;
		padding: 0;
	}
	.h2Title h2{
		font-size: 2.1em;
		line-height: 1.5em;
	}
	.jobAreaOut{
		padding: 3em 0;
	}
	.jobMenu{
		padding-top: 40px;
	}
	.envPicture{
		margin-top: 40px;
		height: 300px;
	}
	.envMsg .msg{
		padding: 30px 0 0 0;
	}
	div.link{
		margin-top: 1em;
	}
	.linkBtn{
		margin-top: 2em;
	}
}
@media screen and ( max-width:780px )
{
	.msgArea{
		width: 73%;
	}
	.msgArea .copy{
		font-size: 2.5em;
	}
	p.msg{
		padding-top: 3.5em;
		font-size: 1.2em;
	}
/*
	.msgArea p:last-child{
		margin-top: 3.5em;
	}
	.msgArea p:last-child a{
		font-size: 1.1em;
	}
*/
	.h2Title h2{
		font-size: 2em;
	}
	.staff{
		width: calc(50% - 1.5%);
	}
	.staff:nth-child(2n+1){
		margin-right: 1.5%;
	}
	.staff:nth-child(2n){
		margin: 0 0 0 1.5%;
	}
}
@media screen and ( max-width:640px )
{
	.rightMenu ul li:not(.menu){
		display: none;
	}
	.rightMenu ul li:last-child{
		padding-left: 18px;
	}
	.catchArea{
		clear: both;
		width: calc(100% - 30px);
		padding: 30px 15px 20px 15px;
	}
	.catchArea p{
		font-size: 2em;
		margin-bottom: 30px;
	}
	.catchArea ul{
		display: flex;
		justify-content: center;
	}
	.catchArea ul li{
		width: calc(50% - 15px);
	}
	.photoArea{
/*
		width: 96%;
*/
		width: 100%;
		clear: both;
/*
		margin-left: 2%;
*/
		margin-top: 0;
	}
	.photoArea ul li{
		height: 170px;
	}
	.msgArea .copy{
		font-size: 2.25em;
	}
	p.msg{
		padding-top: 2.5em;
		font-size: 1.1em;
	}
/*
	.msgArea p:last-child{
		margin-top: 4em;
		font-size: 1em;
	}
*/
	.h2Title h2{
		font-size: 1.8em;
	}
	 div.link{
		margin-top: 1em;
	}

}

@media screen and ( max-width: 500px )
{
	.cp-drawer .btns a, .cp-drawer .drawer_menu .site_menu li a{
		font-size:1em;
	}
	.staff .work{
		font-size: 0.9em;
	}
	.staff .title{
		font-size: 1.1em;
		line-height: 1.1em;
	}

}
@media screen and ( max-width:480px )
{
	.globalMenu{
		right: 10px;
	}
	.cp-drawer .panel{
		max-height:min(90vh);
	}
	.cp-drawer .drawer_menu .site_menu ul li{
		clear: both;
		height: 50px;
		line-height: 50px;
		width: 100%;
	}
	.cp-drawer .btns ul li{
		height: 40px;
		line-height: 40px;
	}
	.cp-drawer .btns li:first-child a{
		background: no-repeat #fff right 7px top 50% / 30px url("../img/icon_faq.png");
	}
	.cp-drawer .btns li:nth-child(2) a{
		background: no-repeat #fff right 7px top 50% / 30px url("../img/icon_req.png");
	}
	.cp-drawer .btns li:last-child a{
		background: no-repeat #4C433F right 7px top 50% / 30px url("../img/icon_mail.png");
	}
	.cp-drawer .btns li:first-child a:hover{
		background: no-repeat #DFE8F7 right 7px top 50% / 30px url("../img/icon_faq.png");
	}
	.cp-drawer .btns li:nth-child(2) a:hover{
		background: no-repeat #DFE8F7 right 7px top 50% / 30px url("../img/icon_req.png");
	}
	.cp-drawer .btns li:last-child a:hover{
		background: no-repeat #DFE8F7 right 7px top 50% / 30px url("../img/icon_mail.png");
	}
	.footer{
		padding: 15px 8px;
	}
	.f_corpbox_1{
		width: calc(100% - 80px);
	}
	.isoLogo{
		width: 80px; height: auto;
	}
	.corpName{
		margin-top: 0;
		font-size: 1.2em;
	}
	.corpName span{
		font-weight: normal;
		font-size: 0.8em;
	}
	.corpAdd{
		font-size: 0.9em;
	}

	.catchArea ul li{
		height: 40px;
		line-height: 40px;
	}
	.catchArea ul li a{
		font-size:0.9em;
		width: calc(100% - 25px);
		padding-left: 25px;
	}
	.catchArea ul li:first-child a{
		background: no-repeat #fff right 7px top 50% / 30px url("../img/icon_req.png");
	}
	.catchArea ul li:last-child a{
		color:#fff;
		background: no-repeat #4C433F right 7px top 50% / 30px url("../img/icon_mail.png");
	}
	.catchArea ul li:first-child a:hover{
		background: no-repeat #DFE8F7 right 7px top 50% / 30px url("../img/icon_req.png");
	}
	.catchArea ul li:last-child a:hover{
		color:#4C433F;
		background: no-repeat #DFE8F7 right 7px top 50% / 30px url("../img/icon_mail.png");
	}
	.photoArea ul li{
		width: calc(50% - 4px);
		height: 120px;
	}
	.photoArea ul li:nth-child(2n+1){
		margin: 0 4px 8px 0;
	}
	.photoArea ul li:nth-child(2n){
		margin: 0 0 8px 4px;
	}
	.msgArea{
		width: 96%;
	}
	.msgAreaOut{
		padding: 4em 0;
	}
/*
	.headerBox div.link, .linkBtn{
		font-size: 1em;
		width: 110px;
	}
	.headerBox div.link a, .linkBtn a{
		font-size: 0.9em;
	}
*/
	.jobMenu ul li{
		height: 100px;
	}
	.jobMenu ul li p{
		font-size: 1.2em;
	}
	.jobMenu ul li div span{
		font-size: 0.9em;
	}
	.jobMenu ul li{
		background: no-repeat #f0f5fc right 20px top 50% / 30px url("../img/icon_arrow.png?3121403");
	}
	.envPicture{
		height: 250px;
	}

}
@media screen and ( max-width:370px )
{
	.catchArea ul li a{
		font-size:0.85em;
		width: calc(100% - 15px);
		padding-left: 15px;
	}
	.corpName span{
		display: block;
	}
	.corpAdd{
		font-size: 0.8em;
	}
	.jobMenu ul li{
		padding: 15px;
	}
	.envPicture{
		height: 200px;
	}

}
/* -------------- others def -------------- */
.clearfix:after{
  visibility: hidden;
  display: block;
  content: " ";
  clear: both;
  height: 0;
  border: 0;
}

.clearfix{
  zoom:1;
}
