@charset "utf-8";
/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  リセットcss

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

  html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; }
  article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
  body { line-height: 1; }
  ol, ul { list-style: none; }
  blockquote, q { quotes: none; }
  blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }
  table { border-collapse: collapse; border-spacing: 0; }
  input, select, button, textarea { margin: 0; padding: 0; background: none; border: none; border-radius: 0; outline: none; -webkit-appearance: none; -moz-appearance: none; appearance: none; }
  select::-ms-expand { display: none; }

/* PC対応 */
@media screen and (min-width: 769px) {
  .pc_view { display:block; }
  .sp_view { display:none; }
}

/* スマートフォン対応 */
@media screen and (max-width: 768px) {
  .pc_view { display:none; }
  .sp_view { display:block; }
}

/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  初期設定

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

  html, body { width: 100%; height: 100%; color: #444; background: #fff; }
  html { font-size: 62.5%; }
  body { font: 1.5rem/1.8 'Lato', 'Noto Sans Japanese', '游ゴシック体', YuGothic, '游ゴシック Medium', 'Yu Gothic Medium', 'ヒラギノ角ゴ ProN', 'Hiragino Kaku Gothic ProN', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif; }
  * { box-sizing: border-box; }
  a { color: #222; text-decoration: none; transition: .3s ease-out; }
  a:visited { color: #222; }
  a:hover { color: #222; opacity: .8; }
  a:active { color: #222; }
  img { display: block; width: 100%; max-width: 100%; height: auto; vertical-align: bottom; }


/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  全体設定

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

/* ========================================
  共通パーツ
======================================== */

  .wrap { width: calc(100% - 40px); max-width: 1100px; margin: 0 auto; }  /* サイト幅960px */
  section { margin: 90px 0 0; }
  ul.number { list-style: decimal; }


/* レイアウト
---------------------------------------- */
  /* flexbox */
  .unit2,
  .unit3,
  .unit4 { display: flex; flex-wrap: wrap; width: calc(100% + 40px); transform: translateX(-20px); }  /* カラム間の余白40px */
  .unit2 .col { width: 48%; }  /* 2カラム */
  .unit3 .col { width: calc(33.33% - 40px); margin: 0 20px; }  /* 3カラム */
  .unit4 .col { width: calc(25% - 40px); margin: 0 20px; }  /* 4カラム */
  /* clearfix */
  .cf:after { content: ""; display: block; clear: both; }

/* 見出し
---------------------------------------- */
  /* ページ見出し */
  .pagetitle { margin: 0 auto 40px; font-size: 3.0rem; }
  /* 大見出し */
  .headline { margin: 0 auto 30px; font-size: 4.2rem; color: #2e6da4; text-align: center; }
  .headline .ttl { font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; line-height: 1; }
  .headline p { padding: 0; font-size: 2.4rem; }
  /* 中見出し */
  .midle_title { background: url(img/ttl_h2.svg); background-repeat: repeat-x; margin: 0 auto 30px; }
  .midle_title .ttl { display: inline-block; padding: 10px 40px 10px 40px; background: #fff; font-size: 2.2rem; font-weight: bold; color: #2e6da4; }
  /* 小見出し */
  .ttl3 { margin: 0 auto 10px; font-size: 1.5rem; }

/* リード文
---------------------------------------- */
  .lead { padding: 0 0 0 20px; margin: 60px 0 90px; border-left: 20px solid #337ab7; font-size: 1.8rem; }
  .lead a { text-decoration: underline; color: #1537b5; }

/* テキスト
---------------------------------------- */
  .text { text-align: justify; }
  /* 位置 */
  .text.center { text-align: center; }
  .text.right { text-align: right; }
  /* 色（使用しない色は削除する） */
  .fc_red { color: ; }  /* 赤色 */
  .fc_blu { color: ; }  /* 青色 */
  .fc_yel { color: ; }  /* 黄色 */
  .fc_grn { color: ; }  /* 緑色 */
  .fc_brn { color: ; }  /* 茶色 */
  .fc_orn { color: ; }  /* オレンジ */
  .fc_pnk { color: ; }  /* ピンク */
  em { color: #2e6da4; font-weight: 600; }
  b { font-weight: bold; }

/* 注釈
---------------------------------------- */
  /* 文章 */
  .note { text-indent: -1em; margin: 0 0 0 1em; }
  .note:before { content: "※"; }
  /* リスト */
  .note_list .item { text-indent: -1em; margin: 0 0 0 1em; }
  .note_list .item:before { content: "※"; }

/* ボタン
---------------------------------------- */
  .btn a { display: block; width: 100%; max-width: px; height: px; margin: 0 auto; text-align: center; line-height: px; }
  .btn a:hover { opacity: 1; }
  /* ページトップ */
  .pagetop { position: fixed; bottom: 0; right: 20px; width: 140px; cursor: pointer; }
  .pagetop a { opacity: 1; }

/* マージン
---------------------------------------- */
  .mb_s { margin-bottom: 20px; }
  .mb_m { margin-bottom: 40px; }
  .mb_l { margin-bottom: 60px; }

/* 線
---------------------------------------- */
  .line_btm { margin-bottom: 20px; padding-bottom: 20px; border-bottom: solid 1px #ccc; } /* 直線 */
  .line_dot { margin-bottom: 20px; padding-bottom: 20px; border-bottom: dotted 1px #ccc; } /* 点線 */
  .line_mark { background: linear-gradient(transparent 60%, #ccc 0%); } /* マーカー */

/* メインビジュアル
---------------------------------------- */
  .visual { overflow: hidden; width: 100%; max-height: 480px; }

/* blankパーツ
---------------------------------------- */
  .blank::after { content: ''; display: inline-block; width: 15px; height: 12px; margin-left: 5px; background: url(img/blank.svg); background-size: 100%; }

/* フォーム
---------------------------------------- */
  input,
  select,
  textarea { display: block; width: 100%; height: 50px; padding: 0 10px; border: solid 1px #ccc; border-radius: 5px; font: 1.5rem/50px "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; vertical-align: middle; }
  select { background: url("/wp-content/uploads/img/recruit/select.png") no-repeat 96% center; }
  textarea { overflow: auto; height: 200px; padding: 10px; line-height: 1.8; }
  /* 必須項目 */
  .must { font-size: 1.3rem; }
  /* 送信ボタン */
  .submit {
    padding: 0; margin: 0 auto 20px; width: 32%; height: 66px; line-height: 66px; text-align: center;
    border: none; border-radius: 5px; display: block; background: #f5f5f5; font-size: 1.8rem;
    -webkit-transition: 0.3s; -moz-transition: 0.3s; -o-transition: 0.3s; -ms-transition: 0.3s; transition: 0.3s;
    }
  .submit:hover { cursor: pointer; opacity: 0.8; background: #2e6da4; color: #fff; }
  /* 送信完了・エラーボックス */
  div.wpcf7-mail-sent-ok,
  div.wpcf7-validation-errors { padding: 3%; background: #f5f5f5; border: 1px solid #ccc; border-radius: 3px; font-size: 1.3rem; text-align: center; }
  /* エラー箇所 */
  span.wpcf7-not-valid-tip { padding: 1% 0 0; color: #c80000; font-size: 1.3rem; }
  .wpcf7 .wpcf7-not-valid { background: #f5f5f5; }


/* ========================================
  ヘッダー
======================================== */
  #header { position: relative; }
  .header_logo { float: left; width: 267px; padding: 15px 0 20px; }
  .gnav { float: right; }
  .gnav ul { display: flex; justify-content: ; padding-top: 25px; }
  .gnav .item { width: 120px; text-align: center; }
  .gnav .item a { display: block; font-size: 1.6rem; color: #337ab7; }
  .gnav .item a:hover,
  .gnav .item.current a { padding-bottom: 22px; border-bottom: 4px solid #337ab7; }




/* ========================================
  フッター
======================================== */
  .footer_tel { margin: 90px auto 50px; }
  .footer_tel a { display: block; margin: 0 auto; max-width: 615px; }
  .back_top { display: block; background: #003c68; width: 100%; height: 30px; position: relative; }
  .back_top::before { content: ''; position: absolute; top: 0; right: 0; left: 0; bottom: 0; margin: auto; width: 15px; height: 10px; background: url(img/arrow.svg) no-repeat; background-size: 100%; -webkit-transform: rotate(180deg);　-moz-transform: rotate(180deg);　-ms-transform: rotate(180deg);　-o-transform: rotate(180deg);　transform: rotate(180deg); }
  .footer_inner {  }
  .footer_inner .logo { display: block; width: 218px; margin: 20px auto 15px; }
  .footer_inner .add { font-size: 1.6rem; text-align: center; color: #2e6da4; }
  .footer_inner .add a { color: #2e6da4; }
  .footer_inner .add a:hover { padding: 0 0 5px; border-bottom: 1px solid; }
  .footer_navi { display: flex; justify-content: center; margin: 20px 0; }
  .footer_navi li { padding: 0 10px; }
  .footer_navi a { color: #2e6da4; text-align: center; }
  .footer_navi a:hover { padding: 0 0 5px; border-bottom: 1px solid; }
  /* コピーライト */
  .copy { padding: 7px 0; background: #2e6da4; font-size: 1.2rem; text-align: center; color: #fff; }
  .powered_by { display: inline-block; width: 45px; height: 10px; vertical-align: baseline; }


/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  ページ個別設定

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

/* ========================================
  トップ
======================================== */
/* flexslider */
.flexslider { position: relative; border: none!important; }
.flexslider .slides > li { position: relative; }
.flexslider .slides > li .wrap { position: absolute; top: 10px; left: 0; right: 0; color: #fff; }
.flexslider .slides > li .wrap .ttl { font-size: 5.0rem; font-weight: bold; line-height: 1; margin: 50px 0 20px; }
.flexslider .slides > li .wrap p { font-size: 2.2rem; }
.flex-viewport { max-height: 750px!important; }
{ color: #919191; }
.flex-control-paging li a { width: 12px!important; height: 12px!important; background: rgba(145, 145, 145, 0.9)!important; box-shadow: none!important; border-radius: 20px!important; -webkit-border-radius: 20px!important; }
.flex-control-nav { top: 180px; left: 0; right: 0; max-width: 1100px; margin: 0 auto!important; text-align: left!important; }
.flex-direction-nav a { }
.flex-control-paging li a.flex-active { background: rgba(21, 55, 181, 0.9)!important; }

.floating_box { position: absolute; bottom: 100px; right: 0; z-index: 1; }
.floating_box .box { display: block; width: 340px; padding: 25px 0 25px 40px; background: #1b2323; color: #cecece; font-size: 2.0rem; }
.floating_box .box span { border-bottom: 1px dotted #cecece; }
.floating_box .box::after { content: ''; position: absolute; top: 0; right: 20px; bottom: 0; margin: auto; width: 10px; height: 6px; background: url(img/arrow.svg) no-repeat; background-size: 100%; }
#company { background: #c3d4e0; padding: 50px 0; }
#company .col { position: relative; min-height: 285px; }
#company .unit2 { justify-content: space-between; }
#company .col.ser { background: url(img/top_01.jpg); background-repeat: no-repeat; background-size: cover; }
#company .col.ser .ttl { width: 198px; margin: 70px auto 50px; }
#company .col.com { background: url(img/top_02.jpg); background-repeat: no-repeat; background-size: cover; }
#company .col.com .ttl { width: 85px; margin: 40px auto 40px; }
#company .col .text { font-weight: bold; color: #fff; padding: 0 30px; }
#company .col a { display: block; position: absolute; bottom: -30px; left: 0; right: 0; width: 220px; margin: 0 auto; padding: 10px 0; border: 1px solid #c3d4e0; background: #fff; font-size: 1.8rem; text-align: center; color: #1537b5; }
#company .col::before { content: ''; background: rgba(0,50,81,0.4); }
#company .col a:hover { background: #1537b5; color: #fff; }
#company .col a:hover::before { border-top: 9px solid #fff; }
#company .col a::before { display: block; content: ""; backface-visibility: hidden; position: absolute; top: 16px; left: 0px; width: 0; height: 0; border: 9px solid transparent; border-top: 9px solid #1537b5; -webkit-transform: otate(-90deg); -moz-transform: rotate(-90deg); -ms-transform: rotate(-90deg); -o-transform: rotate(-90deg); transform: rotate(-90deg); }
#news .unit2 { justify-content: space-between; }
#news .col { margin: 0 0 40px; }
#news .col .image { border: 1px solid #ddd; margin: 0 0 10px; }
#news .block { display: block; padding: 10px 20px; color: #2e6da4; border-left: 3px solid #337ab7; }
#news .block:hover { background: #337ab7; color: #fff; }
#news .date { font-size: 1.6rem; }
#news .col .ttl { font-size: 2.0rem; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
#news .more { display: block; max-width: 410px; margin: 0 auto; padding: 10px 10px; border: 1px solid #337ab7; border-radius: 30px; color: #337ab7; text-align: center; }
#news .more:hover { background: #337ab7; color: #fff; }


/* ========================================
  会社概要
======================================== */
#company_info {}
#message { margin: 0 0 90px; }
#message .image {  }
#message .text { max-width: 1000px; margin: -90px auto 0; padding: 50px 50px 30px 50px; border: 1px solid #a3a3a3; background: #fff; position: relative; z-index: 1; font-size: 2.0rem; display: }
#message .text img[src="img/sdg_icon.png"] { width: 300px; bottom: 0; }
#message .big { display: flex; flex-wrap: wrap; justify-content: space-around; right: 0px; }
#message .big .small { text-align: right; vertical-align: middle; margin-top: auto; margin-bottom: auto; }
.ceo_img { text-align: right; }
.ceo_img span { display: inline-block; vertical-align: text-bottom; padding: 0 10px 0 0; font-size: 1.8rem; font-weight: bold; }
.ceo_img .oono { display: inline-block; width: 184px; }
#company_profile table { width: 100%; }
#company_profile th,
#company_profile td { background: #f7f7f7; padding: 20px; border-bottom: 4px solid #fff; font-size: 1.8rem; }
#company_profile th { border-right: 4px solid #fff; }
#company_profile td {  }
#company_profile .blank { color: #2e6da4; }
#sdgs { width: 100%; }
#sdgs .midle_title { margin: 30px auto 30px; }
#sdgs .midle_title .ttl { padding: 10px 40px 10px 0; }
#sdgs p { font-size: 1.8rem; }
#sdgs a { color: #0000ff; text-decoration: underline; }
#sdgs .ttl img[src="img/sdg_icon.png"] { width: 50px; display: inline-block; vertical-align: middle; }
#sdgs .row { display: inline-block; vertical-align: middle; }

/* ========================================
  事業内容
======================================== */
#service_info {}
#service_info .inner { margin: 0 0 50px; }
#service_info ul { display: flex; flex-wrap: wrap; }
#service_info li { padding: 20px; margin: 0 20px 20px 0; background: #337ab7; color: #fff; font-size: 2.0rem; font-weight: bold; text-align: center; line-height: 1; }
.year_ttl { padding: 30px 0 30px 40px; background: #e5eaf2; border-top: 1px solid #2e6da4; font-size: 2.2rem; color: #2e6da4; line-height: 1; }
#works .block { border-bottom: 1px solid #e5e5e5; padding: 20px 0; }
#works .block:after { display:block; content: ''; clear: both; }
#works .block .month { float: left; width: 140px; margin: 0 auto; text-align: center; font-size: 1.8rem; }
#works .block .place { float: left; width: 110px; margin: 0 auto; padding: 10px 15px; background: #2e6da4; color: #fff; text-align: center; line-height: 1; font-size: 1.6rem;}
#works .block .achievement { float: right; width: calc(100% - 290px); margin: 0; font-size: 1.8rem; }

/* ========================================
  お問い合わせ
======================================== */
#contact {}
#form .wrap { margin: 0 auto 60px; }
#form .table { display: flex; justify-content: space-between; width: 100%; max-width: 900px; margin: 0 auto 20px; position: relative; }
#form .th,
#form .td,
#form .required { display: flex; align-items: center; }
#form .th { width: 30%; background: #f5f5f5; position: relative; justify-content: center; font-size: 1.6rem; }
#form .th::after { content: ""; display: block; clear: both; }
#form .required { background: #ce0202; color: #fff; width: 4em; justify-content: center; font-size: 1.4rem; }
#form .title { }
#form .td { max-width: 630px; width: 70%; padding-left: 2%; }
#form .caution { text-align: center; font-size: 1.2rem; }


/* ========================================
  求人情報
======================================== */
#recruit {}
.requirement { margin: 0 0 60px; padding: 0 0 60px; border-bottom: 1px solid #e5e5e5; border-bottom-width: 5px; }
.requirement dl { display: flex; justify-content: space-between; margin: 0 0 10px; }
.requirement dt,
.requirement dd { display: flex; align-items: center; padding: 15px 0; font-size: 1.6rem; }
.requirement dt { justify-content: center; width: 255px; background: #f5f5f5; font-weight: bold }
.requirement dd { width: calc(100% - 300px); }
.requirement dt.job-title { font-size: 2.2rem; color: #000; }
.recruit_btn { display: block; max-width: 500px; margin: 30px auto 0; padding: 20px 0; background: #f5f5f5; text-align: center; font-size: 1.8rem; }
.recruit_btn:hover { background: #337ab7; color: #fff; }

/* ========================================
  プライバシーポリシー
======================================== */
#privacy dl { margin: 0 0 30px; }
#privacy dt { font-weight: bold; font-size: 2.0rem; color: #337ab7; }
#privacy dd { font-size: 1.6rem; }
#privacy dd ul { padding: 1em 0 1em 2.4em; }

/* ========================================
  404 - Not Found
======================================== */
  .notfound {  }
  .notfound_ttl { margin: 0 auto 40px; font-size: 4.0rem; }
  .notfound_lead { font-size: 2.0rem; }
  .notfound_text { padding: 40px; border: solid 1px #ccc; text-align: center; }


/* ######################################################################

  ノートPCサイズ (1280px以下)

###################################################################### */

  @media screen and (max-width: 1280px) {

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    全体設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    個別設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
.flex-control-nav { left: 20px; }

}


/* ######################################################################

  タブレットサイズ (960px以下)

###################################################################### */

  @media screen and (max-width: 960px) {

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    全体設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    個別設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */


  }


/* ######################################################################

  タブレットサイズ (768px以下)

###################################################################### */

  @media screen and (max-width: 768px) {

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    全体設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
  .gnav { display: none; }
  /* ヘッダー */
  #header.wrap { width: 100%; }
  .header_logo { float: none; width: 50%; margin: 0 auto; padding: 20px 0 20px; }
  section { margin: 40px 0 0; }
  .headline { margin: 0 auto 30px; font-size: 3.0rem; }
  .headline p { font-size: 2.0rem; }
  .midle_title { margin: 0 auto 20px; }
  .midle_title .ttl { padding: 0px 30px 0px 0px; font-size: 2.0rem; }

  .unit2,
  .unit3,
  .unit4 { width: 100%; transform: translateX(0px);}
  .unit2 .col { width: 100%; }
  /* フッター */
  .footer_tel { margin: 50px auto 50px; }
  .footer_navi { display: none; }
  .footer_inner .add { margin: 0 0 30px; }

  .lead { font-size: 1.6rem; margin: 30px 0 60px; }
  .submit { width: 50%; }


  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    個別設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

/* top */
.floating_box { display: none; }
.flexslider { margin: 0!important; }
.flexslider .slides > li .wrap .ttl { margin: 20px 0 10px; font-size: 2.8rem; }
.flexslider .slides > li .wrap p { font-size: 1.4rem; }
.flex-control-nav { top: 100px; left: -25px; width: 90%!important; }
#company { background: transparent; padding: 0; }
#company .col { height: 362px; }
#company .col.ser { margin: 0 0 50px; }
#company .col.ser .ttl { margin: 50px auto 30px; }
#company .col .text { font-size: 1.8rem; }
#company .col a { width: 90%; bottom: 30px; background: transparent; color: #fff; }
#company .col a::before { border-top: 9px solid #fff; }
#news .unit2 { width: calc(100% - 40px); }
#news .col { margin: 0 0 30px; }
#news .more { font-size: 1.6rem; margin: 0 32px;}

/* ========================================
  会社概要
======================================== */
#company_info {}
#message .text { margin: 0px auto 0; padding: 20px 20px 30px 20px; font-size: 1.6rem; }
.ceo_img { margin: 30px 0 0; }
#company_profile th,
#company_profile td { display: block; padding: 10px 10px 10px 20px; }
#company_profile th { text-align: left; }
#company_profile td { background: transparent; font-size: 1.6rem;}
#sdgs a { overflow-wrap: break-word; }
#message .text img[src="img/sdg_icon.png"] { max-width: 100%; height: auto; }


/* ========================================
  事業内容
======================================== */
#service_info {}
#service_info ul { justify-content: space-between; }
#service_info li { width: 48%; margin: 0 0px 20px 0; line-height: 1.4; }
#works .block .month { float: none; display: inline-block; vertical-align: middle; padding: 0 30px 0 30px; color: #2e6da4; }
#works .block .place { float: none; display: inline-block; vertical-align: middle; font-size: 1.4rem; }
#works .block .achievement { float: none; width: 100%; padding: 10px 0 0; line-height: 1.4; font-size: 1.6rem; }
.year_ttl { padding: 20px 0 20px 30px; font-size: 2.2rem; color: #2e6da4; line-height: 1; }

/* ========================================
  お問い合わせ
======================================== */
#contact {}
#form .wrap { margin: 0 auto 30px; padding: 20px 20px 30px 20px; }
#form .table { display: block; }
#form .th,
#form .td,
#form .required { display: block; }
#form .th { width: 100%; padding: 10px 10px 10px 80px; }
#form .required { padding: 10px 10px; font-size: 1.6rem; text-align: center; position: absolute; z-index: 1; }
#form .title { }
#form .td { max-width: 100%; width: 100%; padding-left: 0; }


/* ========================================
  求人情報
======================================== */
#recruit {}
.requirement {  }
.requirement dl { display: block; }
.requirement dt,
.requirement dd { display: block; width: 100%; padding: 15px 20px; }
.recruit_btn { width: 80%; }


  /* SPメニュー
  ======================================== */
  .fixed_menu_box { position: absolute; top: 20px; left: 20px; width: 50px; }
  .fixed_menu {  }
  .fixed_menu img { width: 100%; }
  /* ドロワーメニュー */
  nav.drawer-nav .profile { color: #fff; font-size: 1.2rem; padding: 4%; }
  nav.drawer-nav ul.drawer-menu { font-size: 1.4rem; }
  nav.drawer-nav ul.drawer-menu li { border-bottom: 1px solid #EFEFEF; position: relative; }
  nav.drawer-nav ul.drawer-menu li a { width: 100%; height: 100%; color: #2e6da4; display: block; padding: 12px; font-size: 1.5rem; }
  nav.drawer-nav ul.drawer-menu li:hover { background-color: #F5F5F5; color: #2e6da4; }
  nav.drawer-nav ul.drawer-menu li:hover a, nav.drawer-nav ul.drawer-menu li:active a, nav.drawer-nav ul.drawer-menu li a:active { color: #2e6da4; }
  #fixed_contact { display: none; }
  .drawer-main a { color: #e1e1e1; font-size: 1.6rem;}
  ul.nav.drawer-nav-list { padding-bottom: 60px; }
  ul.nav.drawer-nav-list li {
    display: block; padding-left: 15px; line-height: 48px; line-height: 4.8rem;
    border-bottom: 1px solid #fff; -webkit-font-smoothing: antialiased;
  }
  ul.nav.drawer-nav-list li:first-child { border-top: none; }
  ul.nav.drawer-nav-list li:last-child { border-bottom: none; }
  ul.nav.drawer-nav-list li.contact_us { color:#fff; line-height: 2em; padding-top:10px; font-size: 14px; font-size: 1.4rem;}
  nav.drawer-nav { background: #fff; width: 60%; }
  .drawer--left .drawer-nav { left: -60%!important; }
  .drawer--left.drawer-open .drawer-nav { left: 0!important; }
  nav.drawer-nav ul.drawer-menu li.sub { text-indent: 1em; }
  nav.drawer-nav ul.drawer-menu li.sub a { font-size: 1.3rem;  }
  /* ドロワーの装飾 */
  .drawer--left .drawer-hamburger { display: none; }  /* ページ上部の開閉メニューを非表示 */

  /*ACCORDION*/
  nav.drawer-nav ul.drawer-menu li ul li { border-bottom: 1px solid #EFEFEF; padding-bottom: 0; }
  nav.drawer-nav ul.drawer-menu li ul li:last-of-type { border-bottom: none; }
  #acMenu .toggle { display:block; width:100%; height:auto; cursor:pointer; }
  #acMenu ul { width:100%; height:auto; display:none; border-top: 1px solid #EFEFEF; }
  #acMenu .maru::after {
    border-top: none;
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
  }
  nav.drawer-nav ul.drawer-menu li a.toggle { position: relative; }
  nav.drawer-nav ul.drawer-menu li a.toggle::before,
  nav.drawer-nav ul.drawer-menu li a.toggle::after { position: absolute; top: 0; bottom: 0; right: 0; margin: auto; content: ""; vertical-align: middle; }
  nav.drawer-nav ul.drawer-menu li a.toggle::before { right: 15px; width: 4px; height: 4px; border-top: 1px solid #231f20; border-right: 1px solid #231f20; -webkit-transform: rotate(135deg); transform: rotate(135deg); }
  .open a.toggle::before { -webkit-transform: rotate(90deg)!important; transform: rotate(-45deg)!important; }

  }


/* ######################################################################

  スマートフォン - 横向きサイズ (640px以下)

###################################################################### */

  @media screen and (max-width: 640px) {

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    初期設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
  body { font-size: 1.3rem; line-height: 1.6; }

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    全体設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
  /* 共通パーツ
  ======================================== */
  /* マージン PC表示の半分 -------------------- */
  .mb_s { margin-bottom: 10px; }
  .mb_m { margin-bottom: 20px; }
  .mb_l { margin-bottom: 30px; }

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    個別設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

  }


/* ######################################################################

  スマートフォン - 縦向きサイズ (480px以下)

###################################################################### */

  @media screen and (max-width: 480px) {

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    全体設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    個別設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
.flex-control-nav { top: 130px; }
#service_info li { width: 100%; }

  }