html{
	height: 100%;
	padding:0;
	margin:0;
scroll-padding-top: 100px; 
scroll-behavior: smooth;

}
a {
	text-decoration: none;
}
/*
a:link{
    color: #595554;
}
a:visited{
    color: #595554;
}
*/
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: 16px;
  color: #595554;
	background-color: #f0f5fc;
	font-family: "Noto Sans JP", "游ゴシック", "Yu Gothic", sans-serif;
  margin:0; padding: 0;
	height: 100%;
	-webkit-text-size-adjust: 100%;
}
.cnt_wrapper{
/*
	margin-top: 80px;
	padding-bottom: 130px;
	min-height: calc(100vh - 80px);
*/
box-sizing: border-box;
	padding-top: 80px;
	min-height: 100vh;
	display: flex;
  flex-direction: column;
}
.wrapper{
/*
	width: 100%;
	margin: 0 auto;
	padding: 0;
	flex: 1;
	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;
	width: 220px;
}
.logo img{
	width: 100%;
}
.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: #595554;
  padding-bottom: 5px;
  position: relative;
}
.leftMenu > ul > li a::before {
	color: #595554;
  background: #595554;
  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: #595554;
  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;
	height: 48px;
	line-height: 48px;
}
.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;
}
nav ul.subMenu{
  position: absolute;
  top: 50px;
  opacity: 0;
  visibility: hidden;
  width: 150px;
	background:rgba(240, 245, 252,.9);
  transition: 0.5s;
}
nav ul.subMenu li{
	position: relative;
  display: block;
}
nav ul.subMenu a{
  display: block;
	box-sizing: border-box;
  width: 150px;
  padding: 10px 15px;
	color: #595554;
}
/*
nav .subMenu a:hover {
  color: #fff;
}
*/
nav .hasSub:hover ul,nav .hasSub_2:hover ul {
  opacity: 1;
  visibility: visible;
}

nav li.hasSub li a:hover {
  background: transparent;
}
nav li.hasSub_2 li a:hover {
	background-color: #DFE8F7;
}
.topicPath{
	padding: 20px 50px 0 50px;
	font-size: 0.9em;
	font-family: "見出ゴMB31";
}
.topicPath a{
	font-weight: bold;
	text-decoration: underline;
}
.topicPath a:hover{
	color: #667eea;
}

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

/* 暗幕レイヤー（初期は非表示） */
.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 #595554;
  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: #595554;
	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 #595554;
		color:#595554;
		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 #595554 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:#595554;
	background: no-repeat #DFE8F7 right 7px top 50% url("../img/icon_mail.png");
}
#drawer-top-title{
	width: 220px;
}
#drawer-top-title img{
	width: 100%;
}
/* =======================================
   トップページ
	 ======================================= */
.top{
  display: flex;
  gap: 32px;
  align-items: stretch;
  width: 100%;
  max-width: 1600px;
  margin: 0 auto;
  box-sizing: border-box;
  font-family: "見出ゴMB31";
}
.top--middle{
  font-family: "見出ゴMB31";
}
.top__catch{
	display: flex;
  flex-direction: column;
  flex: 2 1 0;
  min-width: 0;
}
.top__cta{
	margin-top: auto;
	padding-top: 80px;
}
.top__photo{
  flex: 1 1 0;
  min-width: 0;
	margin-right: calc(50% - 50vw);
	opacity: 0;
  transition: opacity 0.9s ease;
	transition-delay: 0.2s;
}
.top__photo.is-active{
  opacity: 1;
}
.top__photo img{
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 25px 0 0 25px;
	object-position: 30% center;
	filter: brightness(0.85);
}
.top__choices{
  display: flex;
  gap: 36px;
  align-items: stretch;
  margin-top: 20px;
}

.top__choiceGroup{
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1 1 0;
  min-width: 0;
}

.top__choiceBranchTitle{
  font-size: var(--fz-mid);
  font-weight: 700;
  line-height: 1.4;
	text-align: center;
}
.top__choiceList{
  display: flex;
  gap: 20px;
  flex: 1;
}
.top__choice{
  display: flex;
  flex: 1;
  border: 1px solid #d8d2cc;
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
  height: 100%;
	min-height: 230px;
	opacity: 0;
  transform: translateY(12px);
  transition: transform 0.3s ease, box-shadow 0.3s ease, filter 0.3s ease, opacity 0.4s ease;
}
.top__choice.is-active{
  opacity: 1;
  transform: translateY(0);
}
.top__choice:nth-child(1){
  transition-delay: 0s;
}

.top__choice:nth-child(2){
  transition-delay: 0.1s;
}

.top__choice:nth-child(3){
  transition-delay: 0.2s;
}
.top__choice:hover{
  transform: translateY(-6px);
  box-shadow: 0 12px 24px rgba(0,0,0,0.12);
  filter: brightness(1.02);
}

.top__choice:active{
  transform: translateY(-2px);
  box-shadow: 0 6px 12px rgba(0,0,0,0.1);
}

.top__choiceLink{
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: inherit;
  transition: all 0.3s ease;
}
.top__choiceBody{
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 20px 10px;
  box-sizing: border-box;
}
.top__choiceImage{
  height: 172px;
  overflow: hidden;
  flex-shrink: 0;
}
.top__choiceImage img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.top__choiceHeader{
  margin-bottom: 12px;
}
.top__choiceTitle{
/*
  font-size: 1.3rem;
*/
	font-size: var(--fz-sm);
  font-weight: 700;
  margin-bottom: 4px;
	text-align: left;
	border-left: 5px solid #667eea;
	padding-left: 10px;
}

.top__choiceSubTitle{
  font-size: clamp(1rem, 2.2vw, 1.2rem);
	padding-left: 10px;
}

.top__choiceFooter{
    margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  font-size: clamp(1rem, 2.2vw, 1.2rem);
	text-align: right;
 	padding-top: 0;
}
.top__choiceLinkText{
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.top__choiceIcon{
 display: inline-block;
  transition: transform 0.3s ease;
}
.top__choiceLink:hover .top__choiceImage img{
  transform: scale(1.05);
}
.top__choiceLink:hover .top__choiceIcon{
  transform: translateX(6px);
}
/* 経験者用分岐ボタン */
.top__choice--bg{
  position: relative;
  overflow: hidden;
	min-height: 140px;
  box-shadow: 0 10px 24px rgba(0,0,0,0.2);
}
.top__choice--bg .top__choiceLink{
  position: relative;
  display: flex;
  flex-direction: column;
  height: 100%;
  color: #fff;
}
.top__choiceBg{
  position: absolute;
  inset: 0;
  z-index: 0;
}

.top__choiceBg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
	display: block;
}
.top__choiceOverlay{
  position: relative;
  z-index: 1;

  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;

  padding: 20px;
  box-sizing: border-box;
}

.top__choice--bg::before{
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
}
.top__choice--bg:hover .top__choiceBg img{
  transform: scale(1.05);
  transition: transform 0.4s ease;
}

.top__choice--bg:hover{
  box-shadow: 0 14px 32px rgba(0,0,0,0.3);
}

.top__choice.top__choice--bg .top__choiceOverlay .top__choiceTitle{
/*
  font-size: 1.7rem;
*/
	font-size: var(--fz-mid);
  font-weight: 700;
  margin-bottom: 20px;
	border: 1px solid #fff;
	padding: 8px 12px;
	text-align: center;
}

.top__choice--bg .top__choiceSubTitle{
  font-size: clamp(1rem, 2.2vw, 1.2rem);
	color:#fff;
}
.top__choicePoints{
  margin: 8px 0 0;
  padding-left: 0;
  font-size: clamp(0.95rem, 2vw, 1.1rem);
  line-height: 1.6;
  color: #595554;
}
.top__choice--bg .top__choicePoints{
  color: #fff;
  padding-left: 1.2em;
}
.top__choice--bg .top__choicePoints li{
	padding-bottom: 5px;
}
.top__choiceNote{
  margin-top: 8px;
  font-weight: 600;
}
.top__mainCopy{
/*
	font-size: 2.6em;
*/
	font-size: var(--fz-xl);
	margin-bottom: 12px;
}
.top__subCopy{
	font-size: 1.2em;
  margin-bottom: 32px;
}

.top__cta{
  margin-top: auto;
}

.top__cta .ctaBtns{
  display: flex;
  justify-content: center;
  gap: 16px;
  max-width: 520px;
  margin: 0 auto;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::
	NEWS
::::::::::::::::::::::::::::::::::::::::::::::::::*/
.news{
  margin-top: -20px; /* ← 軽く重ねる */
	padding-top: 32px;
  border-top: 1px solid rgba(0,0,0,0.06);
  position: relative;
  z-index: 2;
}
.news__inner{
  max-width: 1100px;
  margin: 0 auto;
  padding: 24px 28px 30px 28px;
	font-family:"中ゴシックBBB";
  background: #fff;
  border-radius: 16px;

  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}
.news__head{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
	padding-right: 4px;
}
.news__title{
  font-size: 1.3rem;
  font-weight: 700;
  margin-bottom: 16px;
}
.news__link{
  display: inline-flex;
  align-items: center;
  gap: 6px;  font-size: 0.85rem;
  opacity: 0.7;
  color: #595554;
  text-decoration: none;
  transition: transform 0.3s ease;

}
.news__list a{
  color: #595554;
}
.news__link i{
  color: #595554;
  opacity: 0.8;
  transition: transform 0.3s ease;
}

.news__link:hover{
  transform: translateX(4px);
  opacity: 1;
}

.news__link:hover i{
  transform: translateX(4px);
	opacity: 1;
}
.news__list li{
	border-bottom: 1px dotted rgba(89, 85, 84,0.4);
  padding: 15px 20px;
}
.news__list li a{
  display: block;
}
.news__list li:has(a):hover{
  background: rgba(0,0,0,0.04);
}
.news__list li:has(a){
  cursor: pointer;
}
/* 左のテキスト */
.ctaText{
  flex: 1;
	text-align: center;
}

/* 右のアイコン */
.ctaIcon{
	position: absolute;
/*
  margin-left: 10px;
*/
	right: 8px;
  display: flex;
  align-items: center;
  justify-content: center;

  width: 48px;
  height: 48px;
  border-radius: 50%;

  background: #595554;
  color: #fff;

  flex-shrink: 0; /* 潰れ防止 */
}
.ctaList li:last-child .ctaIcon{
  background: #fff;
	border: 1px solid #595554;
  color: #595554;
}
/* 色分け */
.ctaList li:first-child a{
  background: #fff;
  color: #595554;
}

.ctaList li:last-child a{
  background: #595554;
  color: #fff;
}

/* hover */
.ctaList li:first-child a:hover{
  background: #DFE8F7;
}

.ctaList li:last-child a:hover{
  background: #DFE8F7;
  color: #595554;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::
	トップページ共通
::::::::::::::::::::::::::::::::::::::::::::::::::*/
.c-sectionHead__title{
	font-size: var(--fz-xl);
}
.c-sectionHead__text p{
  margin: 0 0 1em;
  line-height: 1.5;
}

/* 左：文字エリア */
.c-sectionTitleArea {
  flex: 1;
  min-width: 0;
}

/* 右：画像エリア */
.c-sectionImageArea {
  flex: 1;
  min-width: 0;
}

.c-sectionImageArea img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
  border-radius: 16px;

}
.c-sectionImageArea a{
  position: relative;
	display: block;
  overflow: hidden;
  border-radius: 16px;
}
.c-sectionImageArea a::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(29, 79, 145, 0.15);
  opacity: 0;
  transition: 0.3s;
}
.c-sectionImageArea a:hover::after {
  opacity: 1;
}

.c-sectionImageArea a:hover img {
  transform: scale(1.05);
}
.c-sectionHead--column{
	display: flex;
	flex-direction: column;
	gap: 32px;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::
	トップページ : 事業内容
::::::::::::::::::::::::::::::::::::::::::::::::::*/
.bizSection{
  position: relative;
  width: 100%;
	box-sizing: border-box;
  overflow: hidden;
  z-index: 1;
  font-family: "見出ゴMB31";
/*
	background: url("../img/recruit/topimage_3d.jpg?04181958") center / cover no-repeat;
*/
	background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
	transition: opacity 0.5s ease;
	color: #fff;
}
.bizSection--overlap{
  padding: 6em 0;
	margin-top: -24px;
}
.bizSection--narrow{
  padding: 2em 0;
	margin-top: var(--space-md);
	margin-bottom: var(--space-lg);
}
.biz__message{
	margin: 50px 0;
	font-size: var(--fz-sm);
	line-height: 1.9;
	padding: 0 10px;
}
.biz__message p:first-child{
  font-weight: 600;
  font-size: 1.1em;
}
/*::::::::::::::::::::::::::::::::::::::::::::::::
	トップページ : 経験者の方へ
::::::::::::::::::::::::::::::::::::::::::::::::::*/
.sekokan {
  display: flex;
  align-items: flex-start;
  gap: 40px;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::
	トップページ : 社員インタビュー
::::::::::::::::::::::::::::::::::::::::::::::::::*/
/*
.intv__choices{
  display: flex;
  gap: 36px;
  align-items: stretch;
	margin-top: var(--space-md);
}
.intv__choice{
  display: flex;
	flex : 1;
  gap: 8px;
}
*/
.intvSwiper{
  margin-top: var(--space-md);
  overflow: hidden;
}

.intvSwiper .swiper-wrapper{
  align-items: stretch;
}
.intvSwiper .swiper-slide{
  height: auto;
	box-sizing: border-box;
}
.intv__choice{
  box-sizing: border-box;
}
.intv__choiceLink{
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: inherit;
/*
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid #e3e8ef;
  box-shadow: 0 6px 18px rgba(29, 79, 145, 0.06);
*/
  transition: 
    transform 0.25s ease,
    box-shadow 0.25s ease;
}
.intv__choiceImage{
  height: 240px;
  overflow: hidden;
	width: 100%;
  border-radius: 12px;

}
.intv__choiceImage img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: 12px;
  transition: transform 0.4s ease, filter 0.4s ease;
}
.intv__choiceBody{
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 16px 16px 18px;
  box-sizing: border-box;
	gap: 6px;
}
.intv__choiceAttribute{
	font-size: 0.95em;
	color: #888;
  letter-spacing: 0.03em;
}
.intv__choiceTitle{
	font-size: var(--fz-sm);
  font-family: "見出ゴMB31";
  line-height: 1.5;
}
.intv__choiceLink:hover{
/*
  transform: translateY(-6px);
  box-shadow: 0 14px 30px rgba(29, 79, 145, 0.12);
*/
}

/* 画像ちょいズーム */
.intv__choiceLink:hover .intv__choiceImage img{
  transform: scale(1.05);
  filter: brightness(0.9);
}
.intvSwiper__pagination{
  margin-top: 20px;
  position: static !important;
  text-align: center;
}

/*::::::::::::::::::::::::::::::::::::::::::::::::
	トップページ : FAQ
::::::::::::::::::::::::::::::::::::::::::::::::::*/
/* =========================
   FAQ Section
========================= */
.faqSection {
  padding-block: 80px;
}

.faqSection__layout {
  display: flex;
  align-items: stretch;
  gap: 0;
}

/* =========================
   左帯
========================= */
.faqSection__intro {
  flex: 0 0 38%;
  background: #595554;
  border-radius: 0 20px 20px 0;
  overflow: hidden;
}
.faqSection__intro--blue {
  background: #1d4f91;
}

.faqSection__introHead {
  background: #757271;
  padding-block: 56px 20px;
}
.faqSection__introHead--blue {
  background: #4376ba;
}
.faqSection__introBody {
  padding-block: 30px 36px;
}

/* 左の文字幅調整 */
.faqSection__introInner {
  width: min(100% - 24px, 420px);
  margin-left: auto;
  padding-right: 48px;
  box-sizing: border-box;
}

.faqSection__title {
  margin: 0;
  font-family: "ゴシックMB101 B", sans-serif;
  font-size: var(--fz-xl3);
  line-height: 1.3;
  color: #fff;
  text-align: right;
}

.faqSection__introLead {
  margin: 0 0 16px;
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.7;
  color: #fff;
  font-family: "見出ゴMB31", sans-serif;
}

.faqSection__introList {
  margin: 0;
  padding: 0;
  list-style: none;
}

.faqSection__introList li {
  position: relative;
  margin-top: 10px;
  padding-left: 1.2em;
  line-height: 1.8;
  color: #fff;
  font-family: "見出ゴMB31", sans-serif;
}

.faqSection__introList li::before {
  content: "・";
  position: absolute;
  left: 0;
  top: 0;
}

.faqSection__introText {
  margin: 18px 0 0;
  line-height: 1.9;
  color: #fff;
  font-family: "見出ゴMB31", sans-serif;
}

/* =========================
   右側
========================= */
.faqSection__main {
  flex: 1;
  min-width: 0;
}

.faqSection__mainInner {
  padding-top: var(--space-lg);
  padding-left: 48px;
}

.faqSection__mainHead {
  margin-bottom: 18px;
}

.faqSection__mainTitle {
  margin: 0;
  font-size: var(--fz-mid2);
  line-height: 1.5;
  color: #595554;
  font-family: "見出ゴMB31", sans-serif;
}

/* =========================
   FAQ items
========================= */
.faqSection__items {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.faqItem {
  background: #fff;
  border: 1px solid #e3e8ef;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(29, 79, 145, 0.04);
}

.faqItem__question {
  list-style: none;
  cursor: pointer;
  padding: 22px 24px;
}

.faqItem__question::-webkit-details-marker {
  display: none;
}

.faqItem__questionInner {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  padding-right: 28px;
  font-weight: 700;
  line-height: 1.7;
  color: #595554;
	font-size: 1rem;
}

.faqItem__questionInner::after {
  content: "+";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.2rem;
  color: #757271;
}

.faqItem[open] .faqItem__questionInner::after {
  content: "−";
}

.faqItem__icon {
  flex-shrink: 0;
  color: #757271;
  font-size: 1.15rem;
}

.faqItem__answer {
  padding: 0 24px 24px;
}

.faqItem__answer p {
  margin: 0;
  line-height: 1.8;
  color: #595554;
	font-size: 0.98rem;
}

/* =========================
   下部リンク
========================= */
.faqSection__footer {
  margin-top: 32px;
  text-align: center;
}

.faqSection__footerTitle {
  margin: 0 0 18px;
  font-size: 1.05rem;
  color: #595554;
}

.faqSection__links {
  display: flex;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}

.faqSection__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-width: 240px;
  padding: 16px 22px;
  border: 1px solid #d7dce5;
  border-radius: 999px;
  background: #fff;
  color: #595554;
  text-decoration: none;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.faqSection__link:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(29, 79, 145, 0.08);
}

.faqSection__linkText {
  font-weight: 700;
}

.faqSection__linkIcon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.faqSection__linkIcon i {
  transform: rotate(45deg);
}

/* =========================
   Responsive
========================= */
@media (max-width: 1100px) {
  .faqSection__layout {
    flex-direction: column;
    gap: 32px;
  }

  .faqSection__intro {
    flex: none;
    width: 100%;
    border-radius: 16px;
  }

  .faqSection__introInner {
    width: 100%;
    max-width: none;
    margin-left: 0;
    padding-inline: 24px;
  }

  .faqSection__title {
    text-align: left;
  }

  .faqSection__mainInner {
    padding-left: 20px;
/*
    padding-top: 0;
*/
  }
}

@media (max-width: 768px) {
  .faqSection {
    padding-block: 56px;
  }

  .faqSection__introHead {
    padding-block: 32px 16px;
  }

  .faqSection__introBody {
    padding-block: 24px 28px;
  }

  .faqItem__question {
    padding: 18px 18px;
  }

  .faqItem__answer {
    padding: 0 18px 18px;
  }

  .faqSection__link {
    width: 100%;
    min-width: 0;
  }
}
.msg,.msg1{
	padding-top: 3em;
	font-weight: bold;
	font-size: 1.3em;
	color: #fff;
}
.msg1{
	padding: 24px 0;
}
.msg1 span{
	display: block;
	padding-bottom: 12px;
	font-size: 1.4em;
}
.intro{
	box-sizing: border-box;
	width: 100%;
	background-color: #DFE8F7;
/*
	border-radius: 0px 0px 50px 50px;
*/
clip-path: polygon(0 0, 100% 0, 80% 100%, 20% 100%);
	padding: 50px;
	text-align: center;
}
.introMsg{
	width : 55%;
	margin: 0 auto;
	text-align: left;
	font-size: 1.1em;
}
.ourJobOut .msg{
	padding-top: 1em;
	font-size: 1.1em;
	color: #595554;
	border: 1px solid currentColor;
	padding: 12px 15px;
}
.ourJobOut .msg a,.ourJobOut .exp a{
	color: #667eea;
}

.linkBtn{
	position: relative;
	margin-top: 2em;
	width:auto; height: 1.4em;
	text-align: right;
}
.linkBtn a{
	position: absolute;
	display: inline-block;
	bottom:0; right: 0;
	width: auto; height: 100%;
	color: #fff;
	font-weight: bold;
	font-size: 1.2em;
}
.linkBtn a:hover{
	opacity: 0.8;
	transform: translateX(-4px);
  transition: transform .2s;
}

.linkBtnL {
  margin-top: 2em;
  text-align: right; /* 右寄せ */
}

.linkBtnL a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #fff;
  font-weight: bold;
  font-size: 1em;
}
.linkBtnL a {
  font-size: clamp(1rem, 2.2vw, 1.2rem);
}
.linkBtnL a:hover {
	transform: translateX(-4px);
  opacity: 0.9;
  transition: .2s;
}
.linkBtnL--navy a{
	color: #1d4f91;
  font-size: clamp(0.95rem, 2vw, 1.1rem);
}
.linkBtnL--brown a{
	color: #595554;

}
.interviewOut{
	position: relative;
/*
	width: 980px; height: auto;
*/
	width: 1180px; height: auto;
	margin: 0 auto;
	box-sizing: border-box;
	padding: 80px 8px;
	font-family: "見出ゴMB31";
}
.headerBox{
	padding-bottom: 40px;
}
.h2Title{
	float: left;
	width: 100%;
}
.h2Title h2, .h2Title h3{
	font-family: "ゴシックMB101 B";
	font-size: var(--fz-xl3);
	font-weight: bold;
	display: block;
	line-height: 1.3em;
	padding-bottom: 5px;
}
.h2Title h2:after,.h2Title h3:after {
  content: "";
  display: block;
  height: 4px;
  background: -webkit-linear-gradient(to right, #667eea, 60%,#595554);
  background: linear-gradient(to right, #667eea, 60%, #595554);
transform: translateY(5px);
}
.h2Title h3:after {
  height: 2px;
}
.h2Title h2 span,.h2Title h3 span{
	font-size: 1.2em;
	margin-left: 5px;
  background: linear-gradient(45deg, #667eea,60%, #595554);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

span.h2{
	display: block;
	font-weight: bold;
	color: #667eea;
	padding: 6px 10px;
	font-family: "見出ゴMB31";
	font-size: 1.2em;
	line-height: 1em;
}

.jobMsg .h2Title h2 span.h2{
	color: #fff;
}

div.link{
	position: relative;
	float: right;
	width:100%; height: 1.4em;
	margin-top: 2em;
	text-align: right;
	font-family: "見出ゴMB31";
}
div.link a{
	position: absolute;
	display: inline-block;
	bottom:0; right: 0;
	width: auto; height: 100%;
	color: #595554;
	font-weight: bold;
	font-size: 1.2em;
}

div.link a:hover {
	opacity: 0.8;
	transform: translateX(-4px);
  transition: transform .2s;
}

.work{
	padding: 10px 0;
	vertical-align: middle;
}
.work span:first-child{
	display: inline-block;
	padding: 2px 7px;
	color:#fff;
	background-color: #667eea;
	border-radius: 8px;
	margin-right: 5px;
	font-family:"中ゴシックBBB";
	font-size: 0.9em;
}
.work span:last-child{
	font-size: 0.95em;
}
.staff .title{
	font-size: 1.4em;
	font-weight: bold;
	line-height: 1.4em;
}
.jobAreaOut{
  position: relative;
  width: 100%;
  padding: 6em 0;
  overflow: hidden;
  font-family: "見出ゴMB31";
  background:
    linear-gradient(
      rgba(0,0,0,0.7),
      rgba(0,0,0,0.5)
    ),
    url("../img/recruit/topimg_rc_3.webp") center / cover no-repeat;

}
.jobArea{
	width: 1180px;
	margin: 0 auto;
	z-index: 2;
}
.jobMenu{
  position: relative;
  box-sizing: border-box;
  width: 100%;
  padding: 50px 0 25px;
  z-index: 5;
  border-top: 1px dotted #fff;
}

.jobMenu ul{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
/*
  gap: 16px;
*/
  gap: 24px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.jobMenu ul li{
  list-style: none;
}

.jobMenu ul li a.jobCard,.jobCard--featured{
  display: flex;
  flex-direction: column;
/*
  gap: 10px;
*/
  gap: 24px;
  height: 100%;
   padding: 22px 24px 20px;
  box-sizing: border-box;

  border: 1px solid #d7deea;
  border-radius: 12px;
  background-color: #fff;
  color: inherit;
  text-decoration: none;

  transition: background-color .25s, border-color .25s, transform .25s, box-shadow .25s;
}

.jobMenu ul li a.jobCard:hover,.jobCard--featured:hover{
  background-color: #e4edf9;
  border-color: #c5d5f3;
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.08);
}

.jobMenu ul li p,p.jobCard__title{
  margin: 0;
  padding-left: 12px;
  border-left: 4px solid #667eea;
  font-size: var(--fz-mid2);
  line-height: 1.35;
  font-weight: bold;
}

.jobMenu .sub{
  margin: 0;
  color: #555;
  font-size: 0.96em;
  line-height: 1.6;
}

.jobMenu .tags{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0;
}

.jobMenu .tags span{
  display: inline-block;
  padding: 0.2em 0.65em;
  border-radius: 999px;
  background-color: #7c7370;
  color: #fff;
  font-family: "中ゴシックBBB";
  font-size: 0.84em;
  line-height: 1.4;
}
.jobCard .cta{
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  margin-top: 16px;
  color: #667eea;
  font-weight: bold;
  font-size: 1.1rem;
}

.jobCard .arrow{
  transition: transform .25s ease;
}

.jobCard:hover .arrow{
  transform: translateX(6px);
}

.jobMenu--single{
  display: flex;
}

.jobMenu--single .jobCard{
  width: 100%;
  max-width: 640px; /* ←ここがポイント */
  margin: 0 auto;
}
.jobMsg{
	position: relative;
  z-index: 5;
	box-sizing: border-box;
	width: 100%;
	color: #fff;
	padding: 0 50px 0 0;
}
.jobMsgBtm{
	margin-top: 30px;
}
.jobMsgLeft{
	position: relative;
  z-index: 5;
	box-sizing: border-box;
	width: 48%;
	color: #fff;
	padding: 50px 0 60px 0;

}
.floatL{
	float: left;
}
.floatR{
	float: right;
}

/*
.jobMsgLeft h3{
	padding-left: 15px;
}
*/
.jobMsg .h2Title, .envMsg .h2Title, .jobMsgLeft .h2Title{
	clear: both;
}
.jobMsg .h2Title h2:after,.jobMsgLeft .h2Title h3:after{
  background: -webkit-linear-gradient(to right, #667eea, 20%,#fff);
  background: linear-gradient(to right, #667eea, 20%, #fff);
}
.jobMsgLeft .h2Title h3:after{
  background: -webkit-linear-gradient(to right, #fff, 20%,#fff);
  background: linear-gradient(to right, #fff, 20%, #fff);
}
.jobMsgLeft .h2Title h3:after{
/*
	transform: translateX(-15px);
*/
	transform: translateY(5px);
}
.jobMsg .h2Title span,.jobMsgLeft .h2Title span{
  background: linear-gradient(45deg, #fff,20%, #fff);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;

}
.jobMsg .msg,.jobMsgLeft .msg{
	padding-top: 20px;
	font-size: 1.2em;
	line-height: 1.6em;
}

/*-- 写真上に置くctaボタン --*/
.ctaMenu{
  margin-top: 32px;
}

.ctaMenu ul{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ctaMenu__item{
  list-style: none;
}

.ctaMenu__item a{
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 170px;
  height: 100%;
  padding: 22px 24px 20px;
  box-sizing: border-box;
  border-radius: 12px;
  text-decoration: none;
  transition: background-color .25s, border-color .25s, transform .25s, box-shadow .25s;
}

/* タイトル */
.ctaMenu__item p{
  margin: 0;
  font-size: var(--fz-mid2);
  line-height: 1.35;
  font-weight: bold;
}

/* 説明文 */
.ctaMenu .sub{
  margin-top: 10px;
  line-height: 1.7;
  font-size: 0.96rem;
}

/* タグ */
.ctaMenu .tags{
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.ctaMenu .tags span{
  display: inline-block;
  padding: 0.18em 0.65em;
  border-radius: 999px;
  font-size: 0.82rem;
  line-height: 1.4;
  letter-spacing: 0.02em;
}

/* 下部CTA */
.ctaMenu__more{
  display: inline-flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  margin-top: 18px;
  font-weight: bold;
  font-size: 0.95rem;
}

.ctaMenu__more i{
  transition: transform .25s ease;
}

.ctaMenu__item a:hover .ctaMenu__more i{
  transform: translateX(6px);
}

/* 募集要項：サブCTA */
.ctaMenu__item--sub a{
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.6);
  color: #fff;
}

.ctaMenu__item--sub .sub{
  color: rgba(255,255,255,0.88);
}

.ctaMenu__item--sub .tags span{
  background: rgba(255,255,255,0.16);
  color: #ffffff;
  border: 1px solid rgba(255,255,255,0.2);
}

.ctaMenu__item--sub .ctaMenu__more{
  color: #ffffff;
}

.ctaMenu__item--sub a:hover{
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.95);
  transform: translateY(-3px);
  box-shadow: 0 10px 24px rgba(0,0,0,0.12);
}

/* 応募する：メインCTA */
.ctaMenu__item--main a{
  background: linear-gradient(135deg, #667eea, #7f9cf5);
  border: none;
  color: #fff;
  box-shadow: 0 10px 24px rgba(102,126,234,0.25);
}

.ctaMenu__item--main .sub{
  color: rgba(255,255,255,0.92);
}

.ctaMenu__item--main .tags span{
  background: rgba(255,255,255,0.16);
  color: #ffffff;
  border: 1px solid rgba(255,255,255,0.16);
}

.ctaMenu__item--main .ctaMenu__more{
  color: #ffffff;
}

.ctaMenu__item--main a:hover{
  background: linear-gradient(135deg, #4d69e8 0%, #3b59e3 100%);
  border-color: #df5661;
  transform: translateY(-3px);
  box-shadow: 0 14px 28px rgba(217,75,86,0.32);
}
/*-- ▲ 写真上に置くctaボタン ▲ --*/
/*-- ▼ 背景白に置くctaボタン ▼ --*/
.ctaMenu2 ul{
  display: grid;
  grid-template-columns: 1fr 1fr;
/*
  gap: 24px;
*/
	gap: 12px;
  padding: 0;
  margin: 60px 0 60px 0;
  list-style: none;
}

/* 共通カード */
.ctaMenu2__item a{
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  padding: 24px;
  border-radius: 12px;
  text-decoration: none;
  color: inherit;
  transition: all .25s ease;

}

/* --- 左：募集要項（サブ） --- */
.ctaMenu2__item--sub a{
  background: #fefefe;
  border: 1px solid #e2e8f0;
}

.ctaMenu2__item--sub a:hover{
  background: #e8ecf3;
  transform: translateY(-2px);
}

/* --- 右：応募（メイン） --- */
.ctaMenu2__item--main a{
  background: linear-gradient(135deg, #667eea, #7f9cf5);
  color: #fff;
  box-shadow: 0 10px 25px rgba(0,0,0,0.1);
}

.ctaMenu2__item--main a:hover{
  transform: translateY(-3px);
  box-shadow: 0 14px 30px rgba(0,0,0,0.15);
}

/* タイトル */
.ctaMenu2__item p{
  margin: 0;
  font-size: var(--fz-sm);
  font-weight: bold;
}

/* サブテキスト */
.ctaMenu2 .sub{
/*
  margin-top: 10px;
*/
  font-size: 0.95rem;
  line-height: 1.6;
  opacity: 0.85;
}

/* タグ */
.ctaMenu2 .tags{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
/*
  margin-top: 14px;
*/
}

.ctaMenu2 .tags span{
  padding: 0.2em 0.6em;
  border-radius: 999px;
  font-size: 0.8rem;
}

/* サブ側タグ */
.ctaMenu2__item--sub .tags span{
  background: #e5e7eb;
  color: #333;
}

/* メイン側タグ */
.ctaMenu2__item--main .tags span{
  background: rgba(255,255,255,0.2);
  color: #fff;
}

/* CTA部分 */
.ctaMenu2__more{
  display: inline-flex;
  align-items: center;
  gap: 6px;
/*
  margin-top: 18px;
*/
  font-weight: bold;

}

/* サブCTA */
.ctaMenu2__item--sub .ctaMenu2__more{
  color: #667eea;
}

/* メインCTA */
.ctaMenu2__item--main .ctaMenu2__more{
  color: #fff;
}

/* 矢印アニメーション */
.ctaMenu2__more i{
  transition: transform .25s;
}

.ctaMenu2__item a:hover .ctaMenu2__more i{
  transform: translateX(5px);
}
/*-- ▲ 背景白に置くctaボタン ▲ --*/

.interviewOut .ctaMenu, .faqAreaOut .ctaMenu{
	margin-top: 50px;
	border-top: 1px dotted #757271;
}
.interviewOut .ctaMenu ul li, .faqAreaOut .ctaMenu ul li{
	color: #595554;
	border: 2px solid #757271;
}
.interviewOut .ctaMenu ul li div span, .faqAreaOut .ctaMenu ul li div span{
	background-color: transparent;
}
.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: 40px;
}
.envMsg .msg{
	color: #595554;
	padding: 50px 0 0 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;
}
.fs13{
	font-size: 1.3em;
}

.fs12{
	font-size: 1.2em;
}
.fs11{
	font-size: 1.1em;
}
/* =======================================
   事業内容　施工事例カード
	 ======================================= */
/* =========================
   施工実績カード
========================= */
.constExp__list{
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
	box-sizing: border-box;
}

.constExp__card{
  width: calc((100% - 72px) / 4); /* 24px gap × 3 */
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid #e3e8ef;
  border-radius: 16px;
	box-sizing: border-box;
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(29, 79, 145, 0.06);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.constExp__card:hover{
  transform: translateY(-4px);
  box-shadow: 0 16px 32px rgba(29, 79, 145, 0.1);
}

.constExp__header{
  padding: 14px 18px;
  background: #f7f9fc;
  border-bottom: 1px solid #e3e8ef;
}

.constExp__type{
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: #1d4f91;
  font-family: "見出ゴMB31", sans-serif;
}

.constExp__body{
  display: flex;
  flex: 1;
	box-sizing: border-box;
}

.constExp__body a{
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 100%;
  color: inherit;
  text-decoration: none;
	box-sizing: border-box;
}

.constExp__photo{
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #f0f5fc;
}

.constExp__photo img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.constExp__card:hover .constExp__photo img{
  transform: scale(1.05);
}

.constExp__title{
  padding: 18px 18px 6px;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.6;
  color: #222;
  font-family: "見出ゴMB31", sans-serif;
}

.constExp__subTitle{
  padding: 0 18px 18px;
  font-size: 0.95rem;
  line-height: 1.6;
  color: #595554;
}
/* =========================
   ライトボックス
========================= */
.lightbox{
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}

.lightbox.is-open{
  display: flex;
}

.lightbox__content{
  max-width: 90%;
  max-height: 90%;
}

.lightbox__content img{
  width: 100%;
  height: auto;
  border-radius: 8px;
}

/* ちょい演出 */
.lightbox__content img{
  transform: scale(0.95);
  transition: 0.3s;
}

.lightbox.is-open .lightbox__content img{
  transform: scale(1);
}
/* =========================
   タブレット
========================= */
@media (max-width: 1100px){
  .constExp__card{
    width: calc((100% - 24px) / 2);
  }
}

/* =========================
   スマホ
========================= */
@media (max-width: 768px){
  .constExp__list{
    gap: 16px;
  }

  .constExp__card{
    width: 100%;
  }

  .constExp__header{
    padding: 12px 16px;
  }

  .constExp__title{
    padding: 16px 16px 6px;
    font-size: 1rem;
  }

  .constExp__subTitle{
    padding: 0 16px 16px;
    font-size: 0.92rem;
  }
}

/* =======================================
   インタビューﾍﾟｰｼﾞ
	 ======================================= */
.intvOut .headerBox{
	display: flex;
	height: 360px;
}
.intvOut .titleBox{
	width: 50%; 
	margin-top: 50px;
	box-sizing: border-box;
	padding: 0 50px 0 0;
}
.intvOut h2{
/*
	font-size: 2em;
*/
	font-size: var(--fz-lg);
	line-height: 1.3em;
	padding-bottom: 40px;
}
.intvOut .photoBox{
	position: relative;
	width: 50%; height:auto;
	border-radius: 8px;
	overflow: hidden;
}
.intvOut .photoBox img{
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  object-fit: cover;
}
.nextString{
	width: 60%;
	box-sizing: border-box;
	padding: 15px;
	float: right;
	margin-top: 30px;
}

.nextIntv{
	position: relative;
	display: flex;
	box-sizing: border-box;
	width: 60%;
	height: 200px;
	padding: 15px;
	float: right;
	border: 2px solid #667eea;
	background-color: #dce8f7;
	margin-bottom: 80px;
}
.nextIntv .photo{
	position: relative;
	width: 30%; height:100%;
	border-radius: 8px 0 0 8px;
	overflow: hidden;
}
.nextIntv .photo img{
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  object-fit: cover;
}
.nextIntv p{
	padding: 5px 60px 0 0;
	font-size: 1.1em;
}
.nextIntv .rightBox{
	width: 70%;
	box-sizing: border-box;
	padding: 20px;
	border-radius: 0 8px 8px 0;
	background-color: #fff;
	background: no-repeat #fff right 20px top 50% url("../img/icon_arrow.png?3121403");
}
.nextIntv a{
	display: block;
	position: absolute;
	top:0; left:0;
	width: 100%; height: 100%;
}
.nextIntv:hover{
	background-color: #c8ddf7;
	transition: background-color 0.7s;
}
.nextIntv .work{
	position: absolute;
	bottom: 15px;
}
.interview{
	box-sizing: border-box;
	background-color: #fff;
	border-radius: 8px;
	padding: 50px 80px;
/*
	font-family:"中ゴシックBBB";
*/
}
.interview > span{
	color: #667eea;
  font-size: 1.2em;
}
.interview p a{
	font-size: 1.1em;
	color: #667eea;
	text-decoration: underline;
}
.interview p a:hover{
	opacity: 0.8;
  transition: opacity .2s;

}
.interview .ctaBox{
	width: 80%;
	margin: 0 auto;
	text-align: center;
}
.questionBox,.answerBox{
	display: flex;
}
.answerBox{
	justify-content: flex-end;
}

.comIcon{
  display: inline-block;
	width: 60px; height: 60px;
	border-radius: 50%;
	background: no-repeat #fff top 0 left 0 / 60px  url("../img/icon_chara.png?320");
	overflow: hidden;
}
.empIcon{
	position: relative;
  display: inline-block;
	width: 60px; height: 60px;
	border-radius: 50%;
	overflow: hidden;
}
.empIcon img{
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  object-fit: cover;
}
/*
.question {
  position: relative;
  display: inline-block;
	width: 60%;
	box-size: border-box;
  margin-left: 20px;
	margin-bottom: 34px;
  padding: 7px 15px 15px 15px;
  border: 2px solid #667eea;
  border-radius: 8px;
  background-color: #dce8f7;
  text-align: left;
  line-height: 1.4em;
	color: #4e6bed;
  font-size: 1.15em;
	font-weight: bold;
}

.question::before {
  content: "";
  position: absolute;
	top: 30px;
  left: 0;
  border-style: solid;
  border-width: 0 20px 20px 0;
  border-color: transparent #667eea transparent transparent;
  translate: -100% -50%;
  transform: skew(0, 5deg);
  transform-origin: right;
}

.question::after {
  content: "";
  position: absolute;
	top: 30px;
  left: 0;
  border-style: solid;
  border-width: 0 15.2px 15.2px 0;
  border-color: transparent #dce8f7 transparent transparent;
  translate: -100% calc(-50% - 0.4px);
  transform: skew(0, 5deg);
  transform-origin: right;
}
.answer {
  position: relative;
  display: inline-block;
  margin-right: 20px;
	margin-bottom: 54px;
	width: 60%;
	box-size: border-box;
  padding: 7px 15px 15px 15px;
  border: 2px solid #667eea;
  border-radius: 8px;
  background-color: #fdfdfd;
  text-align: left;
  font-size: 1.1em;
  line-height: 1.4em;
  color: #595554;
}

.answer::before {
  content: "";
  position: absolute;
	top: 30px;
  right: 0;
  border-style: solid;
  border-width: 0 0 20px 20px;
  border-color: transparent transparent transparent #667eea;
  translate: 100% -50%;
  transform: skew(0, 5deg);
  transform-origin: left;
}

.answer::after {
  content: "";
  position: absolute;
	top: 30px;
  right: 0;
  border-style: solid;
  border-width: 0 0 15.2px 15.2px;
  border-color: transparent transparent transparent #fdfdfd;
  translate: 100% calc(-50% - 0.4px);
  transform: skew(0, 5deg);
  transform-origin: left;
}
*/
/* =======================================
   応募フォーム
	 ======================================= */
/*
.entryOut,.jobOut, .intvOut, .ourJobOut,.introOut,.ctaMenuOut{
*/
.entryOut,.intvOut,.introOut,.ctaMenuOut{
	position: relative;
	width: 960px;
	margin: 0 auto;
	font-size: 1.1em;
	padding-bottom: 50px;
	font-family: "見出ゴMB31";
}
 .intvOut,.ourJobOut{
	width: 1200px;
}
.introOut{
	width: 99%;
	padding-bottom: 5px;
}
.entryFormOut{
	box-sizing: border-box;
	padding: 40px;
	background-color: #fff;
	border-radius: 5px;
}
.entryMsg{
	padding-bottom: 15px;
}
.entryFormOut .item{
	font-weight: bold;
	padding-bottom: 10px;
}
.entryFormOut .item span{
	display: inline-block;
	padding: 1px 12px;
	margin-right: 10px;
	text-align: center;
	color: #fff;
	background-color: #667eea;
	border-radius: 50px;
	font-size: 0.9em;
}
.entryFormOut .input{
	margin-bottom: 40px;
}
.radio{
	display: flex;
	align-items: center;
	margin-right: 20px;
	cursor: pointer;
	gap: 4px; 
}
.upload{
	position: relative;
	border: 1px solid #667eea;
	color: #667eea;
	background-color: #eee;
	width: 40%;
}
.upload span{
	text-align: center;
	display: table-cell;
	line-height: 1em;
	padding: 10px 15px;
}
.upload span:first-child{
	width: 40px;
	height: 100%;
	background-color: #667eea;
}
.upload span:last-child{
	width: calc(100% - 40px);
	text-align: center;
}
input[type='file']{
	position: absolute;
	display: block;
	top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity:0;
	cursor: pointer;
}
.entryFormOut input[type='text']{
	box-sizing: border-box;
	width: 100%;
	padding: 10px;
	border-radius: 5px;
	border: 1px solid #ccc;
	font-size: 16px;
}
.input a{
	text-decoration: underline;
}
.inputBtnArea{
	display: flex;
}
.inputBtn{
	position: relative;
	width: 30%; height: 3em;
	margin: 0 auto;
	line-height: 3em;
}
.inputBtn a{
	position: absolute;
	display: block;
	top:0; left: 0;
	width: 100%; height: 100%;
	text-align: center;
	background-color: #1d4f91;
	border: 2px solid #1d4f91;
	color: #fff;
	border-radius: 50px;
}
#modifyBtn{
	background-color: #1d4f91;
	color: #fff;
}
#sendBtn{
	background-color: #ccc;
	border: 2px solid #ccc;
	pointer-events:none;
	cursor: default;
}
.inputBtn a:hover{
	opacity: 0.8;
  transition: opacity .2s;
}
#warning{
	width: 100%;
	padding: 15px 0;
	margin-bottom: 30px;
	border: 1px solid #667eea;
	text-align: center;
}
/* =======================================
   プライバシーポリシー
	 ======================================= */
.privacyOut .entryMsg{
	padding: 15px 0;
}
.privacyOut h3:nth-child(n+2){
	margin-top: 30px;
}
/* =======================================
   募集要項
	 ======================================= */
.ctaWrap--narrow{
  max-width: 720px;
  margin: 0 auto;
}
.jobList{
	position: relative;
	margin: 1em 0;
}
.jobList h2, .faqOut h2{
	display: block;
	font-size: var(--fz-md);
/*
	border-left: 6px solid #667eea;
*/
	border-left: 6px solid #1f5fa6;
	padding-left: 20px;
}
/* 外枠 */
.jobListBox {
  padding: 32px 28px;
  background: #ffffff;
  border: 1px solid #dbe4f0;
  border-radius: 16px;;
  box-shadow: 0 12px 36px rgba(29, 79, 145, 0.06);
	border-top: 4px solid #2f5ea3;
}

/* dl全体 */
.jobListBox dl {
  display: grid;
  grid-template-columns: 180px 1fr;
  margin: 0;
}

/* 項目共通 */
.jobListBox dt,
.jobListBox dd {
  margin: 0;
  padding: 22px 0;
  border-bottom: 1px solid #e8eef6;
  box-sizing: border-box;
}

.jobListBox dt {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding-left: 0;
  font-family: "見出ゴMB31", sans-serif;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.7;
  color: #1d4f91;
}

.jobListBox dt::before {
  content: "";
  width: 12px;
  height: 2px;
  background: #1d4f91;
  margin-top: 0.85em;
  flex-shrink: 0;
}
/* 右側本文 */
.jobListBox dd {
  padding-left: 8px;
  font-size: 1rem;
  line-height: 1.9;
  color: #595554;
}

/* 最初と最後の余白調整 */
.jobListBox dl dt:first-of-type,
.jobListBox dl dd:first-of-type {
  padding-top: 0;
}

.jobListBox dl dt:last-of-type,
.jobListBox dl dd:last-of-type {
  padding-bottom: 0;
  border-bottom: none;
}

/* リンク */
.jobListBox .linkBar {
  display: inline-block;
  margin-top: 12px;
}

/* dd内の強調用
*/
.jobListBox dd strong {
  display: inline-block;
  margin-bottom: 6px;
  font-family: "見出ゴMB31", sans-serif;
}

/* CTAメッセージ */
.ctaMsg {
  margin-top: 32px;
  padding: 24px 20px;
  background: #f7faff;
  border: 1px solid #dbe4f0;
  border-radius: 16px;
  text-align: center;
}

.ctaMsg p {
  margin-bottom: 20px;
  line-height: 1.9;
  color: #595554;
}

/* 応募ボタンまわり */
/*
.entryBtnBox {
  margin-top: 20px;
}

.entryBtn {
  width: min(100%, 640px);
  margin: 0 auto;
}
*/
/* =========================
   スマホ
========================= */
@media screen and (max-width: 767px) {
  .jobList {
    margin-bottom: 56px;
  }

  .jobList h2 {
    margin-bottom: 20px;
  }

  .jobListBox {
    padding: 24px 18px;
    border-radius: 16px;
  }

  .jobListBox dl {
    grid-template-columns: 1fr;
  }

  .jobListBox dt {
    padding: 8px 0 8px;
    border-bottom: none;
    font-size: 0.95rem;
  }

  .jobListBox dd {
    padding: 0 0 18px;
    padding-left: 0;
    border-bottom: 1px solid #e8eef6;
    font-size: 0.95rem;
    line-height: 1.8;
  }

  .jobListBox dl dt:first-of-type {
    padding-top: 0;
  }

  .jobListBox dl dd:last-of-type {
    padding-bottom: 0;
    border-bottom: none;
  }

  .ctaMsg {
    margin-top: 24px;
    padding: 20px 16px;
    border-radius: 14px;
  }
}


a.linkBar{
	display: inline-block;
	padding: 8px 20px 8px 40px;
	border-radius: 8px;
	color: #fff;
	height: 1em;
	line-height: 1em;
	margin-top: 5px;
	background: no-repeat #595554 left 8px top 50% / 20px url("../img/icon_arrow_white.png");
}
a.linkBar:hover{
	opacity: 0.8;
	transition: opacity 0.7s;
}
/*
.entryBtnBox{
  margin-bottom: 40px;
}
*/
.entryBtn{
  width: min(96%, 420px);
  margin: 0 auto;
}
/* =======================================
   仕事内容
	 ======================================= */
.ourJob__header{
	display: flex;
	align-items: stretch;
  gap: 20px;
}
.ourJob__copy{
/*
	font-size: 2rem;
*/
	font-size: var(--fz-lg);
	font-family: "見出ゴMB31";
}
.ourJob__subCopy{
	margin: 20px 0 40px 0;
}
.ourJob__note{
	padding: 8px 15px;
	text-align: left;
	border: 1px solid rgba(89, 85, 84,0.5);
	border-radius: 8px;
	line-height: 1.7rem;
	margin-bottom: 30px;
}
.ourJob__text{
	margin-top: 20px;
}
.ourJob__title{
	box-sizing: border-box;
	flex: 1 1 50%;
	padding-right: 10px;
}
.ourJob__photo{
	flex: 1 1 50%;
  border-radius: 8px;
  overflow: hidden;
  aspect-ratio: 4 / 3;
}
.ourJob__photo img{
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* =========================
   見出し・本文
========================= */
.jobSection__title {
  margin-bottom: var(--space-sm);
	display: block;
	font-size: var(--fz-md);
	font-family: "ゴシックMB101 B", sans-serif;
	border-left: 6px solid #667eea;
	padding-left: 20px;
}

.jobSection__lead {
  margin-bottom: 24px;
  font-size: 1rem;
  line-height: 1.7;
}

.jobSection__note {
  margin-top: 24px;
  font-weight: 700;
  color: #1d4f91;
}

/* =========================
   リスト
========================= */
.jobFitList {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px 24px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.jobFitList__item {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 1.1rem;
}

.jobFitList__item i {
  color: #667eea;
  flex-shrink: 0;
}

/* =========================
   スマホ対応
========================= */
@media (max-width: 768px) {
  .jobFitList {
    grid-template-columns: 1fr;
  }
}


.jobSection__subTitle{
	position: relative;
	display: inline-block;
	box-sizing: border-box;
	width: 100%;
	font-size: var(--fz-sm);
	font-weight: bold;
	border-left: 4px solid #595554;
	padding: 0 15px 5px 15px;
	margin-top: 30px;
}
.jobSection__subTitle::after {
  content: '';
  position: absolute;
  left: 6px;
  bottom: 0; /* 下にずらす */
	width: 100%;
  height: 1px;
  background-color: #595554; /* 線の色 */
}
.jobSection__text{
	font-family:"中ゴシックBBB";
	font-size: 1.1rem;
	line-height: 1.8rem;
	padding: 15px 15px 5px 15px;
}
.jobSection__text-center{
	text-align: center;
}
.jobSection__text dl{
	padding:0;
	margin:0;
}
.jobSection__text dd{
	font-size: 1.1rem;
	line-height: 1.7em;
	margin: 0 0 15px 1rem;
}
.jobSection__text dt{
	font-size: 1.2rem;
	font-family: "見出ゴMB31";
}
.jobConBtm{
	font-family:"中ゴシックBBB";
	font-size: 0.95em;
	line-height: 1.5em;
	display: flex;
}
.careerPass h3{
	display: inline-block;
	box-sizing: border-box;
	width: 100%;
	font-size: var(--fz-sm);
	font-weight: bold;
	border-left: 3px solid #595554;
	padding: 0 15px 5px 15px;
	margin-bottom: 20px;
}
.careerPass__inner{
	display: inline-block;
	box-sizing: border-box;
	padding: 15px;
	border-radius: 8px;
	width: 100%;
	background-color: #e1ebfa;
	margin: 10px 0;
	font-family:"中ゴシックBBB";
	font-size: 1em;
	line-height: 1.8rem;
}
.careerPass__year{
	margin-bottom: 20px;
}
.careerPass__work{
	font-size: 1.2rem;
	font-weight: bold;
}
careerPass__year p{
	margin-bottom: 5px;
}
.careerPass__license span{
	margin-bottom: 5px;
	font-size: 0.9em;
	padding: 2px 7px;
}
.careerPass__message{
	box-sizing: border-box;
	padding: 15px;
	border: 2px solid #667eea;
	border-radius: 8px;
	margin: 40px 0;
	line-height:1.8rem;
}
.schedule{
	width: 100%;
	box-sizing: border-box;
	border-radius: 8px;
	border: 1px solid rgba(89, 85, 84,0.5);
	padding: 40px 120px;
	background:#fff;
}
.schedule h3{
	font-size: var(--fz-mid2);
	padding: 0 0 20px 0;
}

.timeline > li {
	overflow: hidden;
	margin: 0;
	position: relative;
}
.timeline-date {
	width: 110px;
	float: left;
	margin-top: 20px;
}
.timeline-content {
	width: calc(100% - 110px);
	box-sizing: border-box;
	float: left;
	border-left: 3px #e1ebfa solid;
	padding: 15px 0 0 30px;
}
.timeline-content:before {
	content: '';
	width: 12px;
	height: 12px;
	background: #667eea;
	position: absolute;
	left: 106px;
	top: 24px;
	border-radius: 100%;
}
.timeline-content p:first-child{
	font-size: 1.3em;
}
.timeline-content p:last-child{
	font-family:"中ゴシックBBB";
	font-size: 0.95em;
	line-height: 1.5em;
}

.down_arrow {
  position: relative;
  display: block;
  width: 44.8px;
  height: 21.7px;
	margin: 0 auto;
}

.down_arrow::before,
.down_arrow::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: calc(50% - 2.5px);
  width: 5px;
  height: 31px;
  border-radius: 9999px;
  background-color: #e1ebfa;
  transform-origin: 50% calc(100% - 2.5px);
}

.down_arrow::before {
  transform: rotate(50deg);
}

.down_arrow::after {
  transform: rotate(-50deg);
}

/* =======================================
   フッター
  ======================================== */
.footer{
	box-sizing:border-box;
	position: relative;
	padding: 15px 25px;
	width: 100%; height: auto;
	background-color: #595554;
	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-around;
	flex-wrap: wrap;
	width: 90%;
	margin: 0 auto;
}

.footerMenu li{
/*
	padding: 5px 10px;
*/
	padding: 0 10px 5px;
	list-style: none;
}

.footerMenu li a{
	color: #fff;
	padding-bottom: 5px;
	position: relative;
	text-decoration: none;
}

.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;
}

.footerMenuToggle{
	display: none;
}

.footerMenu__subToggle{
	display: none;
}
.footerMenu__subList{
	font-size: 0.9rem;
	margin-top: 5px;
}
.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;
}
.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: var(--fz-sm);
}
.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);
}

.btnBox{
	position: relative;
	width: 100%;
}
.leftBtn{
	float: left;
	width: 50%;
}
.rightBtn{
	float: right;
	width: 50%;

}
.red{
	color: red;
}
.blue{
	color: #667eea;
	font-size: 1.2em;
}
.bold{
	font-weight: bold;
}
.small_08{
	font-size: 0.8em;
}
#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;
}
.note{
	text-align: center;
	padding-bottom: 10px;
}

/*
@media print
{
	.header{
		display: none;
	}
}
*/

/*トップページFVメディアクエリ */
@media (max-width: 1360px){
	.top{
    flex-direction: column;
  }

  .top__catch,
  .top__photo{
    width: 100%;
  }

  .top__photo{
    margin-right: 0;
    margin-top: 24px;
  }

  .top__photo img{
    border-radius: 25px;
    height: auto;
  }
}
@media screen and ( max-width:1300px ){
	 .intvOut,.ourJobOut{
		width: 85%;
	}
	.intvOut .titleBox{
		margin-top: 100px;
		padding: 0 30px 0 0;
	}

}
@media screen and ( max-width:1200px ){
	.globalMenu .leftMenu{
		display: none;
	}
	.footerMenu ul{
		width: 100%;
	}

	.jobMsgLeft{
		clear: both;
		width: 96%;
	}
	.jobMsgLeft:last-child{
		clear: both;
		width: 96%;
	}

	.envArea{
		width: 980px;
	}
	 .intvOut,.ourJobOut{
		width: 90%;
	}
	.jobArea{
		width: 96%;
	}
	.jobMsgLeft{
		width: 100%;
	}
	.floatL,.floatR{
		clear:both;
	}
	.ourJob__title{
		padding-right: 24px;
	}
}

@media (max-width: 1100px){
  .top__choices{
    flex-direction: column;
    gap: 24px;
  }
/*
  .top__choiceList{
    flex-direction: column;
    gap: 16px;
  }
*/
  .ctaBtns{
    flex-direction: column;
    gap: 12px;
  }
	.top__photo{
    display: none;
  }
}
@media screen and (max-width: 768px){
  .top__catch{
    order: 1;
  }
	.top__choiceList{
    flex-direction: column;
  }
/*
	.top__photo{
    margin-top: 20px;
  }

  .top__photo img{
    border-radius: 8px;
  }
*/
	.news{
    margin-top: -24px;
  }

  .news__inner{
    padding: 20px;
    border-radius: 12px;
  }
	.sekokan {
		display: block;
	}
	.c-sectionTitleArea {
		padding-bottom: var(--space-md);
	}
}


@media screen and ( max-width:1050px )
{
	.cp-drawer .btns{
		width: 300px;
	}
	.cp-drawer .drawer_menu .site_menu{
		position: relative;
		width: calc(100% - 300px);
	}
	.entryOut, .privacyOut{
		width: 90%;
	}
	.jobOut{
		width: 98%;
	}
	.jobBtn{
		width: 40%;
	}
	.intvOut .titleBox{
		margin-top: 80px;
	}
	.nextIntv .rightBox{
		padding: 12px;
		background: no-repeat #fff right 10px top 50% url("../img/icon_arrow.png?3121403");
	}
	.nextIntv{
		height: 180px;
	}
	.nextIntv p{
		padding: 0 40px 0 0;
		line-height: 1.3em;
	}
	.ourJob__header{
		flex-direction: column;
		align-items: stretch;
		gap: 24px;
		min-height: auto;
	}
	.ourJob__title{
		flex: none;
		width: 100%;
		padding-right: 0;
	}
	.ourJob__photo{
		flex: none;
    width: 100%;
    aspect-ratio: 16 / 9;
		min-height: 0;
	}

}
@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 ;		/* 左右の余白 */
	}
	.topImage img{
		top:0;
	}
	.contents_2{
		width: auto ;
		padding: 0 10px;
	}
	.contents{
		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 a{
		-webkit-tap-highlight-color: rgba(0,0,0,0);
	}
	#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%;
	}
	div.link{
		margin-top: 1.5em;
	}
	.jobArea,.envArea{
		width: 780px;
	}
	.jobMsg{
		padding: 0 0 0 20px;
	}
	.jobMsg .msg{
		padding-top: 20px;
		line-height: 1.4em;
	}
}
@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%;
	}
	.work{
		font-size: 1em;
	}
	.staff .title{
		line-height: 1.2em;
	}
	.upload{
		width: 60%;
	}
	.footerMenuToggle{
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 10px;
		width: 90%;
		margin: 20px auto 0;
		padding: 14px 16px;
		border-radius: 999px;
		border: 1px solid #fff;
		background: #595554;
		color: #fff;
		font-size: 1rem;
		font-weight: 700;
		cursor: pointer;
	}

	.footerMenuToggle__icon{
		position: relative;
		display: inline-block;
		width: 20px;
		height: 14px;
	}

	.footerMenuToggle__icon,
	.footerMenuToggle__icon::before,
	.footerMenuToggle__icon::after{
		border-top: 2px solid #fff;
	}

	.footerMenuToggle__icon::before,
	.footerMenuToggle__icon::after{
		content: "";
		position: absolute;
		left: 0;
		width: 20px;
	}

	.footerMenuToggle__icon::before{
		top: 5px;
	}

	.footerMenuToggle__icon::after{
		top: 10px;
	}

	.footerMenu{
		display: none;
		width: 90%;
		margin: 12px auto 0;
		padding: 12px 16px;
		border-top: none;
		border-radius: 16px;
		background: rgba(255,255,255,0.08);
	}

	.footerMenu.is-open{
		display: block;
	}

	.footerMenu > ul{
		display: block;
		width: 100%;
		margin: 0;
		padding: 0;
	}

	.footerMenu > ul > li{
		padding: 0;
		border-bottom: 1px solid rgba(255,255,255,0.15);
	}

	.footerMenu > ul > li:last-child{
		border-bottom: none;
	}

	.footerMenu > ul > li > a{
		display: block;
		padding: 14px 0;
	}

	.footerMenu__head{
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 12px;
		padding: 10px 0;
	}

	.footerMenu__parentLink{
		display: block;
		flex: 1;
		padding: 4px 0;
	}

	.footerMenu__subToggle{
		display: inline-flex;
		align-items: center;
		justify-content: center;
		width: 32px;
		height: 32px;
		border: 1px solid rgba(255,255,255,0.35);
		border-radius: 50%;
		background: transparent;
		color: #fff;
		font-size: 1.2rem;
		line-height: 1;
		cursor: pointer;
		flex-shrink: 0;
	}

	.footerMenu__subToggle.is-open{
		transform: rotate(45deg);
	}

	.footerMenu__subList{
		display: none;
		margin: 0 0 10px;
		padding: 0 0 0 14px;
	}

	.footerMenu__subList li{
		padding: 6px 0;
	}

	.footerMenu__subList a{
		display: inline-block;
		font-size: 0.95rem;
		color: rgba(255,255,255,0.92);
	}

	.footerMenu ul li a::before{
		display: none;
	}

}
@media screen and ( max-width:830px )
{
	.jobArea,.envArea{
		width: 90%;
	}
	.jobMsg,.envMsg, .envPicture{
		clear: both;
		width: 100%;
		padding: 0;
	}
	.jobAreaOut{
		padding: 3em 0;
	}
	.envPicture{
		margin-top: 40px;
		height: 300px;
	}
	.envMsg .msg{
		padding: 30px 0 0 0;
	}
	div.link{
		margin-top: 1em;
	}
	.linkBtn{
		margin-top: 2em;
	}
	.nextIntv,.nextString{
		width: 70%;
	}
/*
	.nextIntv .rightBox{
		padding: 15px 20px 0 20px;
		background: no-repeat #fff right 10px top 50% / 30px url("../img/icon_arrow.png?3121403");
	}
	.nextIntv p{
		padding: 0 42px 0 0;
	}
*/
}

@media screen and ( max-width:768px )
{
	.top__choice,
  .top__photo{
    opacity: 1;
    transform: none;
    transition: none;
  }
  .entryBtn{
    width: 100%;
  }

  .entryBtn a{
    min-height: 64px;
    padding: 14px 16px;
    gap: 8px;
    border-radius: 6px;
  }

	.msgArea{
		width: 73%;
	}
	.msgArea .copy{
		font-size: 2.5em;
	}
	p.msg{
		padding-top: 3.5em;
		font-size: 1.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%;
	}
	.intvOut .titleBox{
		margin-top: 50px;
	}
	.nextIntv,.nextString{
		width: 80%;
	}

	.schedule{
		padding: 40px;
	}
	.jobConBtm{
		display: block;
	}
	.jobConBtm .work{
		padding-bottom: 0;
	}
	.jobMenu ul{
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .jobMenu ul li a{
    min-height: auto;
    padding: 18px 16px;
  }

  .jobMenu ul li p{
    line-height: 1.4;
  }

  .jobMenu .sub{
    margin-top: 10px;
    line-height: 1.6;
  }

  .jobMenu .tags{
    margin-top: 12px;
    gap: 6px;
  }
/*
  .jobMenu .tags span{
    font-size: 0.82em;
  }
*/
  .jobMenu ul li a::after{
    margin-top: 14px;
/*
    font-size: 0.9em;
*/
  }
	.ourJob__subCopy{
		margin: 16px 0 24px 0;
	}
	.ourJob__photo{
		aspect-ratio: 3 / 2;
	}
	.jobSection__title {
		margin-bottom: 5px;
	}
	.top__choiceFooter{
		padding-top: 20px;
	}
}
@media screen and ( max-width:640px )
{
	.rightMenu ul li:not(.menu){
		display: none;
	}
	.rightMenu ul li:last-child{
		padding-left: 18px;
	}
	.topicPath{
		padding: 2% 0;
	}
	.msgArea .copy{
		font-size: 2.25em;
	}
	p.msg{
		padding-top: 2.5em;
		font-size: 1.1em;
	}
	 div.link{
		margin-top: 1em;
	}
	.h1Title{
		padding: 30px 0;
	}
	.upload{
		width: 100%;
	}
	.inputBtn, .jobBtn{
		width: 49%;
	}
	.jobBtn a{
		text-align: left;
		padding-left: 30px;
	}
	.jobListBox{
		padding: 18px 20px;
	}
	.intvOut .headerBox{
		display: block;
		height: auto;
	}
	.intvOut .titleBox{
		width: 100%;
		padding: 0 0 20px 0;
		margin:0;
	}
	.intvOut h2{
		padding: 0 0 20px 0;
	}
	.intvOut .photoBox{
		width: 100%;
		height: 280px;

	}
	.interview{
		padding: 40px 30px;
	}
	.interview span{
	  font-size: 1.1em;
	}
	.answer,.question{
		line-height: 1.3em;
	}
	.question{
	  font-size: 1.1em;
		margin-bottom: 24px;
	}
	.answer{
	  font-size: 1em;
		margin-bottom: 44px;
	}
	.nextIntv,.nextString{
		width: 100%;
	}
	.nextIntv p{
		padding: 0 20px 0 0;
		font-size: 1em;
	}
	.nextIntv .rightBox{
		padding: 15px;
		background: no-repeat #fff right 10px top 50% / 30px url("../img/icon_arrow.png?3121403");
	}

	.schedule{
		padding: 20px;
	}

	.panel-title {
	  padding: 10px 10px 0 24px;
	  font-size: 1.1em;
	}
	.panel-content {
	  font-size: 1em;
	  padding: 0;
	  margin: 10px 0 0 30px;
	}
	.panel-faq:checked ~ .panel-content{
	  padding: 0;
	}
	.plus {
	  font-size: 1.1em;
	}
/*
	.intv__choices{
	    gap: 16px;
	    flex-wrap: nowrap;
	    overflow-x: auto;
	    padding-inline: 16px;
	    scroll-snap-type: x mandatory;
	    -webkit-overflow-scrolling: touch;
	    scrollbar-width: none;
	  }

	  .intv__choices::-webkit-scrollbar{
	    display: none;
	  }

  .intv__choice{
    flex: 0 0 82%;
    scroll-snap-align: start;
  }
	.intvSwiper .swiper-wrapper{
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 36px;
  }
*/

/*
  .intvSwiper__pagination{
    display: none;
  }
*/
	.ctaMenu2 ul{
		display: block;
	}
	.ctaMenu2 ul li{
		margin-bottom: var(--space-md);
	}
	.ctaMenu2__item a{
		gap: 12px;
	}
	.radio,.radio label{
		display: block;
	}
	.radio label{
		margin-bottom: 12px;
	}
}

@media screen and ( max-width: 500px )
{
	.cp-drawer .btns a, .cp-drawer .drawer_menu .site_menu li a{
		font-size:1em;
	}
	.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 #595554 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;
	}
	.h1Title h1{
		font-size: 2em;
		line-height: 1.2em;
	}

	.msgArea{
		width: 96%;
	}
	.envPicture{
		height: 250px;
	}
	.entryOut, .privacyOut,.intvOut{
		width: 96%;
	}
	.entryFormOut{
		padding: 20px 15px;
	}
	.jobBtn a{
		padding-left: 15px;
	}
	.jobListBox{
		padding: 10px 10px;
	}
	.jobList dd{
		padding: 10px 8px;
	}
/*
	.interview{
		padding: 30px 20px;
	}
	.question, .answer{
		width: 70%;
	  padding: 7px 10px 12px 10px;
	}
	.comIcon{
		width: 40px; height: 40px;
		background: no-repeat #fff top 0 left 0 / 40px  url("../img/icon_chara.png?320");
	}
	.empIcon{
		width: 40px; height: 40px;
	}
	.answer::before, .question::before{
 		 top: 20px;
	}
	.answer::after, .question::after {
 		 top: 20px;
	}
*/
	.timeline-date {
		width: 70px;
	}
	.timeline-content {
		width: calc(100% - 70px);
	}
	.timeline-content:before {
		left: 66px;
	}

}
@media screen and ( max-width:380px )
{
	.jobSection {
	  padding: 0;
	}
	.jobSection--fv {
	  padding: 0;
	}
	.corpName span{
		display: block;
	}
	.corpAdd{
		font-size: 0.8em;
	}
	.envPicture{
		height: 200px;
	}
	.h1Title h1{
		font-size: 1.8em;
	}

	.jobBtn:first-child a{
		padding-left: 5px;
	}
	.intvOut .photoBox{
		height: 230px;
	}
	.timeline-date {
		width: 50px;
	}
	.timeline-content {
		width: calc(100% - 50px);
	}
	.timeline-content:before {
		left: 46px;
	}
	.top__choiceOverlay{
		padding: 20px 5px;
	}
	.jobSection__text{
		padding: 15px 0 5px 0;
	}
}
/*
@media (prefers-reduced-motion: reduce){
  .top__choice,
  .top__photo{
    transition: none;
  }
}
*/
/* -------------- others def -------------- */
.clearfix:after{
  visibility: hidden;
  display: block;
  content: " ";
  clear: both;
  height: 0;
  border: 0;
}

.clearfix{
  zoom:1;
}
