@charset "utf-8";

/*-------------- 共通 --------------*/
#u_cover {
    width: 100%;
    min-height: 200px;
    overflow: hidden;
}
#u_cover img {
    width: 100%;
    height: 400px;
    object-fit: cover;
    object-position: center center;
}

.ta_l {
    text-align: left;
}

.to_form_btn {
    width: 50%;
    margin: 0 auto;
    color: #fff;
    padding: 10px;
    font-size: 23px;
    border-radius: 2px;
}
/*きらっと光る*/
.btnshine{
    /*キラッと光る基点とするためrelativeを指定*/
	position: relative;
    /*ボタンの形状*/	
	display:inline-block;
    background: #006834;
    color: #fff;
    padding: 10px 20px;
    text-decoration: none;
    outline: none;
    overflow: hidden;
}
/*キラッと光る*/
.btnshine::before {
	content: '';
    /*絶対配置でキラッと光るの位置を決める*/
	position: absolute;
	top: 0;
	left: -75%;
    /*キラッと光る形状*/
    width: 50%;
	height: 100%;
	background: linear-gradient(to right, rgba(0,105,52,0) 0%, rgba(255,255,255,.3) 100%);
	transform: skewX(-25deg);
}
/*hoverした際の移動のアニメーション*/
.btnshine:hover::before {
	animation: shine 0.7s;
}
@keyframes shine {
	100% {
		left: 125%;
	}
}

/* title */
.ttl2 {
    width: 100%;
    /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ffffff+0,c9c9ca+100 */
    background: rgb(255,255,255); /* Old browsers */
    background: -moz-linear-gradient(top,  rgba(255,255,255,1) 0%, rgba(201,201,202,1) 100%); /* FF3.6-15 */
    background: -webkit-linear-gradient(top,  rgba(255,255,255,1) 0%,rgba(201,201,202,1) 100%); /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to bottom,  rgba(255,255,255,1) 0%,rgba(201,201,202,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#c9c9ca',GradientType=0 ); /* IE6-9 */
    margin-bottom: 28px;
}
.ttl2::after {
    border-bottom: 1px solid #4b4848;
    box-shadow:rgba(122, 122, 122, 0.0588235) 0px 0px 3px 1px;
    -webkit-box-shadow:rgba(122, 122, 122, 0.0588235) 0px 0px 3px 1px;
    -moz-box-shadow:rgba(122, 122, 122, 0.0588235) 0px 0px 3px 1px;
}
.ttl2 h2 {
    width: 100%;
    max-width: 1110px;
    margin: 0 auto;
    font-size: 23px;
}

.ttl3_ul {
    font-size: 35px;
    border-bottom: 1px solid #ea5414;
    margin-bottom: 1rem;
}
.ttl4 {
    padding: .5em 1em;
    margin-bottom: 8px;
    position: relative;
}
.ttl4::after {
    position: absolute;
    content: '';
    top: .25em;
    left: 0;
    width: 6px;
    height: -webkit-calc(100% - 1em);
    height: calc(100% - .5em);
    background-color: #21ab38;
    border-radius: 4px;}
.ttl5 {
    padding: .5em 1em;
    font-size: 25px;
    margin-bottom: 20px;
    position: relative;
}
.ttl5::after {
    position: absolute;
    content: '';
    top: .25em;
    left: 0;
    width: 6px;
    height: -webkit-calc(100% - 1em);
    height: calc(100% - .5em);
    background-color: #21ab38;
    border-radius: 4px;
}

/*-----*/
.col_bb_or {
    border-bottom: 1px solid #ea5414;
}
.bb_gray {
    border-bottom: 1px solid #d2cbcb;
    margin-bottom: 45px;
}

/*-------------- safety policy --------------*/
#safety .inner {
    padding: 40px;
    border-bottom: 1px solid #ea5414;
}
.policy_list {
    list-style: none;
    counter-reset: li_count;
    position: relative;
    line-height: normal;
}
.policy_list .list_item {
    display: block;
    font-size: 21px;
    padding: 8px 10px 4px;
    margin-bottom: 21px;
    border-bottom: 2px solid #21ab38;
    line-height: 1;
}
.policy_list .list_item::before {
    counter-increment: li_count;
    content: counter(li_count)"";
    color: #ea5414;
    margin-right: 17px;
    font-size: 57px;
    vertical-align: sub;
}
/*.policy_list .list_item::after {
    position: absolute;
    bottom: 0;
    left: 50%;
    content: '';
    width: 657px;
    border-bottom: 2px solid #21ab38;
    transform: translate(-50%);
}*/

/*-------------- contents --------------*/
.contents_list {
    line-height: 2;
    margin-left: 1rem;
}
.contents_list li::before{
    content: "";
    width: 16px;
    height: 16px;
    display: inline-block;
    background-color: #ea5414;
    border-radius: 50%;
    position: relative;
    top: 11%;
     margin-right: 8px;
}

/*-------------- company --------------*/
.comp_inbox {
    padding: 0 3em 37px;
}
.comp_inbox dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 8px 1em;
}
.comp_inbox dl dt {
    width: 10%;
}
.comp_inbox dl dd {
    width: 90%;
}
.comp_phtbox {
    padding: 20px;
}

/*-------------- construction --------------*/
.caption {
    display: block;
    text-align: center;
    padding: 8px 0;
}
.caption_l {
    padding-bottom: 4px;
}

/*-------------- recruit --------------*/
.rec_inbox {
    padding: 0 3em 37px;
}
.rec_inbox dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding: 0 1em;
}
.rec_inbox dl dt {
    width: 25%;
}
.rec_inbox dl dd {
    width: 75%;
}
.rec_inbox dl dt span {
    padding: .3em 1em;
    background-color: #fce1b9;
}
.rec_list {
    padding-bottom: .5em;
}

.attention_box {
    margin: 0 0 2em;
    padding: 2em;
    background-color: #fff0f1;
    border-radius: 5px;
}
.box_ttl {
    font-size: 24px;
    margin-bottom: .5em;
    color: #ce000f;
}
.box_ttl span {
    font-size: 18px;
    font-weight: normal;
}
.attention_box p {
    font-size: 19px;
    line-height: 2;
}

.rec_infobox {
    width: 80%;
    margin: 0 auto 20px;
    border: 1px solid #b2b2b2;
    border-radius: 5px;
    padding: 2em;
}

/*-------------- contact --------------*/
/* mailform */
.form_txt {
    width: 100%;
    max-width: 960px;
    margin: 0 auto 32px;
}

.mailform p{
    width: 100%;
    text-align: center;
    /*margin-top: 65px;*/
    font-size: 12px;
}

input[type="text"],
textarea{
    border: solid 0.5px #808080;
    background-color: #fff;
    -webkit-border-radius: 5px;
       -moz-border-radius: 5px;
            border-radius: 5px;
    width: 700px !important;
    height: 46px;
    padding: 8px 10px;
    -webkit-box-shadow: 1px 1px 1px 1px #e6e6e6 inset;
       -moz-box-shadow: 1px 1px 1px 1px #e6e6e6 inset;
            box-shadow: 1px 1px 1px 1px #e6e6e6 inset;
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
            box-sizing: border-box;
}

.flbox_mr {
    margin-right: 30%;
}

textarea{
    height: 200px;
}

.mailform{
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
            box-sizing: border-box;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
    max-width: 960px;
    margin: 0 auto;
    font-size: 14px;
}

.mobile_br{
    display: none;
}

.mailform dt{
    width: 200px;
    height: 46px;
    background: #ec6c00;
    color: #fff;
    -webkit-border-radius: 5px;
       -moz-border-radius: 5px;
            border-radius: 5px;
    padding: 12px 12px;
    margin-right: 29px;
    margin-top: 20px;
    line-height: 1.5em;
}

.mailform dd{
    margin-top: 20px;
}

/*.mailform span{
    color: #fff;
}*/

/*input[type="button"] {
    background-color: gray;
    padding: 3px 16px;
    border-radius: 5px;
    clear: left;
    color: #fff;
}*/

.submit{
    text-align: center;
    margin: 65px auto 0;
    font-size: 16px;
    /*padding: 0 60px;*/
    width: 260px;
    height: 45px;
    background: #136421;
    -webkit-border-radius: 20px;
       -moz-border-radius: 20px;
            border-radius: 20px;
    line-height: 45px;
    color: #fff;
}

input[type="submit"]{
    border-style: none;
    padding: 0 66px;
}

.submit:hover{
    background: #21ab38;
}

.chara03box {
    width: 100%;
    height: 190px;
    max-height: 100%;
    position: relative;
}
.chara03box img {
    position: absolute;
    height: 100%;
    top: -50%;
    right: 0;
}

/*---------- thanks ----------*/
.thanks_inner {
    text-align: center;
}

.thanks_inner p{
    margin: 8vh 0 10vh;
    line-height: 2em;
}


/*-------------- privacy --------------*/
.pr_txt {
    line-height: 2;
}
.pr_list li {
    margin-bottom: .5rem;
}
.pr_list li::before {
    content: "";
    width: 16px;
    height: 16px;
    display: inline-block;
    background-color: #ea5414;
    border-radius: 50%;
    position: relative;
    top: 11%;
     margin-right: 8px;
}