@charset "utf-8";


body{
	overflow-y: scroll;
}

p{
	line-height: 1.5em;
}

p.lineH-0{
	line-height: 0em;
}

.myPageContents h1,
.contentsBody h1{
	margin: 0 0 20px 0;
	padding: 20px;
	border-radius: 5px;
	background: #FAF8EE;
	-webkit-box-shadow: 0 5px 6px -6px #777;
	-moz-box-shadow: 0 5px 6px -6px #777;
	box-shadow: 0 5px 6px -6px #777;
}

.myPageContents h1 small,
.contentsBody h1 small{
	padding-left: 0.5em;
	font-weight: normal;
}

.contentsBody h1 small.formTitle{
	font-size: 16px;
}

.myPageContents h2,
.contentsBody h2{
	margin: 30px 0 20px 0;
	padding: 0 0.5em;
	border-left: 10px #388ECC solid;
	color: #388ECC;
}


/* ==========================================================================
 * 共通class
 * ========================================================================== */
.container {
	max-width: none !important;
	width: 970px;
}

.containerS{
	max-width: none !important;
	width: 970px;
	margin-right: auto;
	margin-left: auto;
	padding: 0;
}

.mgBlockTop{ /*各セクションのトップにmarginを設定*/
	margin-top: 30px;
}

.mgBlockTopW{ /*各セクションのトップにmarginを設定*/
	margin-top: 60px;
}

a{text-decoration: underline;}
a:hover{color: #0569AB;}

/*白リンク*/
a.wlink{color: #fff;}
a.wlink:hover{color: #DDD;}

/*特別黄色リンク*/
a.yl{color: #F4E85D; text-decoration: none;}
a.yl:hover{color: #F8F098;}

/*装飾なしリンク*/
a.noborder{text-decoration: none;}

/*文字サイズ*/
.txt11{font-size: 0.688em;}
.txt14{font-size: 0.875em;}
.txt20{font-size: 1.429em;}
.txt21{font-size: 1.500em;}
.txt24{font-size: 1.714em;}
.txt30{font-size: 2.143em;}

/*文字カラー*/
.txtRed{color: #F96745;}
.txtRecruit{color: #37B38B;}
.txtGeneral{color: #B4527E;}
.txtCompany{color: #425588;}
.txtUI{color: #4c302c;}
.txtBlue{color: #388ECC;}
.txtGray{color:#666;}
.txtMarker{background: linear-gradient(transparent 60%, #ffff66 60%); display: inline-block;}

/*margin*/
.mg3-0{
	margin: 3px 0;
}
.mgT-5{
	margin-top: 5px;
}
.mgB-10{
	margin-bottom: 10px;
}

.mgB-15{
	margin-bottom: 15px;
}

.mgT-10{
	margin-top: 10px;
}

.mgL-10{
	margin-left: 10px;
}

.mgR-10{
	margin-right: 10px;
}


/*webフォント*/
.txtAlphameric{
	font-family: 'Josefin Sans', sans-serif;
}

.text-left {
	text-align: left;
}
.text-right {
	text-align: right;
}
.text-center {
	text-align: center;
}
.text-justify {
	text-align: justify;
}
.text-nowrap {
	white-space: nowrap;
}

.ls01{letter-spacing: 0.1em;}

.inforArea{
	border: 3px #388ECC solid;
	padding: 15px 30px;
	border-radius: 5px;
	background: #E4F4F7;
}

.inforArea h4{
	margin: 0;
}

.inforArea ul{
	padding-left: 20px;
}

.imgRight img{
	float: right;
}


fieldset {
    border: none;
    margin: 0;
    padding: 0;
}

legend{
	display: none;
}


/* ==========================================================================
 * 共通ボタンclass　<a>に適用
 * ========================================================================== */
a.btnBase,
input.btnBase,
button.btnBase{
	display: inline-block;
	box-sizing: border-box;
	text-decoration: none;
	border-radius: 5px;
	padding: 10px;
}

a.btnS, input.btnS, button.btnS{width: 140px;}
a.btnM, input.btnM, button.btnM{width: 220px; padding: 10px 30px;}
a.btnL, input.btnL, button.btnL{width: 280px;}
a.btnW, input.btnW, button.btnW{width: 100%;}

button.btnReg,	/* リニューアル時追加 */
a.btnReg,
input.btnReg{ /*recruit*/
	border: 1px #37B38B solid;
	background: #37B38B;
	color: #fff;
	font-weight: bold;
	text-align: center;
}

button.btnReg:hover,	/* リニューアル時追加 */
a.btnReg:hover,
input.btnReg:hover{background: #4BC79F;}

button.btnReg02,	/* リニューアル時追加 */
a.btnReg02,
input.btnReg02{ /*general*/
	border: 1px #B4527E solid;
	background: #B4527E;
	color: #fff;
	font-weight: bold;
	text-align: center;
}

button.btnReg02:hover,	/* リニューアル時追加 */
a.btnReg02:hover,
input.btnReg02:hover{
	background: #C86692;
}

button.btnReg03,	/* リニューアル時追加 */
a.btnReg03,
input.btnReg03{ /*company*/
	border: 1px #425588 solid;
	background: #425588;
	color: #fff;
	font-weight: bold;
	text-align: center;
}

button.btnReg03:hover,	/* リニューアル時追加 */
a.btnReg03:hover,
input.btnReg03:hover{
	background: #56699C;
}

button.btnGrey,	/* リニューアル時追加 */
a.btnGrey,
input.btnGrey{
	border: 1px #ddd solid;
	background: #EFEFEF;
	font-weight: bold;
	text-align: center;
}

a.btnEdit,
input.btnEdit,
button.btnEdit{
	border: 1px #388ECC solid;
	background: #388ECC;
	color:#fff;
}

button.btnEdit:hover,	/* リニューアル時追加 */
a.btnEdit:hover,
input.btnEdit:hover{background: #4B98D1;}

button.btnView,	/* リニューアル時追加 */
a.btnView,
input.btnView{
	border: 1px #5E4F4F solid;
	background: #5E4F4F;
	color:#fff;
}

button.btnView:hover,	/* リニューアル時追加 */
a.btnView:hover,
input.btnView:hover{
	background: #746161;
}

button.btnCopy,	/* リニューアル時追加 */
a.btnCopy,
input.btnCopy{
	border: 1px #ddd solid;
	background: #EFEFEF;
}

a.btnEntry{ /*詳細など*/
	border: 1px #ddd solid;
	background: #EFEFEF;
	margin: 0 auto 0;
}

a.btnEntry:hover{}

a.btnOff{
	border: 1px #aaa solid;
	background: #aaa;
	color: #fff;
	pointer-events: none;
}

a.othercity{
	opacity: 0.3;
	pointer-events: none;
}



/* ==========================================================================
 * ヘッダー
 * ========================================================================== */
header{
	background: #388ECC;
	color: #fff;
	min-width: 970px;
}

header #headerL{
	float: left;
	padding: 15px;
}

header #headerL span{
	display: inline-block;
	padding: 7px 0 0 10px;
	vertical-align: middle;
	letter-spacing: 0.1em;
}

header #headerR{
	float: right;
	text-align: right;
	padding: 15px;
}

header #headerR p{
	margin: 0;
}

header #headerR p:first-child{
	margin: 0 0 8px 0;
}

header #headerR span{
	padding: 0 0 0 1.75em;
	font-weight: bold;
}

header form button{
	background: none;
	border: none;
	padding: 0;
	text-decoration: underline;
}

header form button:hover{
	color: #ddd;
}

header #headerR p.person{
	font-weight: bold;
	padding: 1.0em 0.5em 0 0;
}



/* ==========================================================================
 * グローバルナビ
 * ========================================================================== */
nav{
	background: url(../img/bg_navi.png) repeat-x;
	background-color: rgba(238,238,238,1.00);
}

nav div.col-xs-2{
	text-align: center;
	margin: 16px 0 0 0;
	padding: 0;
}

nav div a{
	padding: 16px 0 12px 0;
	display: block;
	font-weight: bold;
	border-top-left-radius: 10px;
	border-top-right-radius: 10px;
}

nav div.active a{
	border-right: 1px #b2b2b2 solid;
	background: #fff;
}

nav div img{
	display: block;
	margin: 0 auto 12px auto;
}



/* ==========================================================================
 * パンくず
 * ========================================================================== */
.breadcrumb{
	widows: 100%;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	padding : 16px 0;
	margin: 0;
	list-style:none;
}

.breadcrumb>li{
	display:inline-block
}

.breadcrumb>li+li:before{
	padding:0 7px;
	content:"\003e";
}



/* ==========================================================================
 * ページトップ
 * ========================================================================== */
#pageTop{
	cursor: pointer;
	display: none;
	position: fixed;
	bottom: 20px;
	right: 20px;
	z-index: 9999;
	color: #666;
}
#pageTop span{
	opacity: 0.9;
}



/* ==========================================================================
 * フッター
 * ========================================================================== */
footer{
	margin: 100px 0 0 0;
	padding: 15px 0;
	border-top: 7px #388ECC solid;
	background: #2E3136;
	color: #fff;
}

footer div ul li{
	display: inline;
	padding: 0 0 0 15px;
}



/* ==========================================================================
 * 新着情報
 * ========================================================================== */
#topicsNews{
	margin: 0;
	border: #388ECC 2px solid;
	box-sizing: border-box;
	position: relative;
	max-height: 250px;
	overflow-y: auto;
}

#topicsNews h2{
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100px;
	margin: 0;
	padding: 7px 15px;
	color: #fff;
	font-size: 1.0em;
	font-weight: bold;
	background: #388ECC;
	border: 0;
}

#topicsNews div{
	padding: 5px 15px 15px 110px;

}

#topicsNews div p{
	margin: 0;
	padding: 7px 15px 5px 15px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	vertical-align: bottom;
}

#topicsNews div p:before{
	content: " \f061";
	font-family: FontAwesome;
	padding-right: 5px;
	color: #B4527E;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
}

#topicsNews div p span i{
	margin-right: 0.3em;
}

/* ==========================================================================
 * 市のリンク集
 * ========================================================================== */
#otherLinks{
	margin: 50px 0 0 0;
}

#otherLinks div.row{
	margin-bottom: 15px;
}


#otherLinks div.row>div{
	display: table;
}

#otherLinks div.row>div>a{
	display: table-cell;
	position: relative;
	height: 60px;
	width: 100%;
	border: 2px #ccc solid;
	font-weight: bold;
	vertical-align: middle;
	text-align: center;
	background: #F4F4F4;
}
#otherLinks div.row>div>a:after{
	position: absolute;
	content: '';
	right: -2px;
	top: -2px;
	border-width: 0 15px 15px 0;
	border-style: solid;
	border-color: #F9BA45 #fff #F9BA45;
	box-shadow: -2px 2px 2px rgba(0, 0, 0, 0.15);
}
/*
#otherLinks div.row a img{
	margin: 0 auto;
	display: block;
}
*/

#otherLinks h2{
	color: #5E4F4F;
	padding: 10px;
	margin: 0 0 20px 0;
	border: 0;
}

#otherLinks p{
	margin: 3px 22px 0 30px;
	color: #444;
}

#otherLinks div dl{
	margin-top: 30px;
}

#otherLinks div dl dt{
	font-weight: normal;
	color: #777;
	border-left: 3px #F9BA45 solid;
	padding: 0 0 5px 15px;
}

#otherLinks div dl dd{
	border-left: 3px #ccc solid;
	margin: 0 0 15px 0;
	padding: 0 0 5px 15px;
	font-weight: bold;
}



/* ==========================================================================
 * 緊急表示
 * ========================================================================== */
#specialInfo{
	background-color: rgb(0,0,0);
	opacity: 0.8;
	color: #fff;
	width: 100%;
	position: fixed;
	bottom: 0;
}
#specialInfo div{
	padding: 15px 0;
}
#specialInfo div strong{
	color: yellow;
}

/* ==========================================================================
 * エラーメッセージ表示用調整　2022/06/03 追加
 * ========================================================================== */
table.registCommon td input[type=radio],
table.registCommon td input[type=checkbox],
table.registCommon td input[type=text] {
	margin-right: 5px;
}
/* ラベル要素を縦に表示 */
table.registCommon td .lbl_block label {
	display: block !important;
}
table.registCommon td {
	overflow: hidden;
}
/* テキスト、セレクトボックス、thにあるボタンをインライン表示 */
table.registCommon td .text,
table.registCommon td .select,
table.registCommon td .number,
table.registCommon th .button {
   display: inline-block;
}
/* 要素の奇数個目のトップマージンがcommon.cssでセットされるのをクリア */
table.registCommon td div:nth-child(2n){
	margin-top: 0;
}
/*readonlyの背景色を変える*/
textarea:read-only,
input:read-only {
	background-color: #f8f8f8;
 	border: 1px solid #ccc;
}

/* バリデーションエラーのエラーメッセージ表示部分 ここから */
.error
{
	padding: 10px;
	font-weight: bold;
	color: #F96745;
}
.error:before
{
    font-family: "Font Awesome 5 Free";
    content: '\f071';
    font-weight: 800;
    padding-right: 5px;
}
.error-message,
.error-messages
{
	color: #F96745;
	clear: both;
	padding-top: 5px;
}
.error-message:before,
.error-messages li:before
{
    font-family: "Font Awesome 5 Free";
    content: '\f071';
    font-weight: 800;
    padding-right: 5px;
}

/* 複数エラーが出た場合 */
ul.error-messages
{
	margin: 0 !important;
	padding: 0 !important;
}
.error-messages li
{
    list-style: none;
}
/* バリデーションエラーのエラーメッセージ表示部分 ここまで */

/* reCAPTCHA v3 バッジ表示位置調整 ここから */
.grecaptcha-badge{
	margin-bottom: 90px;
}
/* reCAPTCHA v3 バッジ表示位置調整 ここまで */

/* 新卒求人の「労働関係法令」確認チェック部分 */
#recruit_check {
	vertical-align: top;
	margin-top: 3px;
}
#recruit_check + label {
	display: inline-block;
	padding-right: 0;
}

/* --------------------------------------------------------------
 * 企業情報　企業の特長説明用　CSS追加　2025.03.27
 -------------------------------------------------------------- */
.explanation {
    margin:5px !important;
    margin-top: 10px !important;
    font-size: 0.9em;
    padding: 10px !important;
    border-radius: 5px;
    background: #faf8ef;
}
.explanation p:not(.lineH-0) {
    margin-bottom: 0 !important;
    text-indent: 1em;
}
.explanation hr {
	border-top: 1px dotted #cdcdcd;
}
.explanation ul {
    margin: 5px !important;
    padding-top: 15px !important;
    padding-bottom: 15px !important;
    color: #596368;
    border-radius: 5px;
    background: #fefefe;
    font-size: 0.95em;
    border: 2px dotted #ddd;
}
.explanation li {
    margin-top: 4px !important;
    margin-right: 15px !important;
}
.explanation ul >  li {
    border-bottom: 1px solid #efefef;
}
.explanation ul >  li:last-child {
	border: none;
}
.explanation ol {
    margin-top: 5px !important;
    padding-left: 20px !important;
}
