@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: #676767; 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: #676767; text-decoration: none; transition: .3s ease-out; }
  a:visited { color: #676767; }
  a:hover { color: #676767; opacity: .8; }
  a:active { color: #676767; }
  img { display: block; width: 100%; max-width: 100%; height: auto; vertical-align: bottom; }


/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  全体設定

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

/* ========================================
  共通パーツ
======================================== */

  .wrap { width: 100%; max-width: 1280px; margin: 0 auto; } 
  section { margin: 0 0 100px; }
  ul.number { list-style: decimal; }

/* 色共通 #1D92BE → #1b70cc */

/* レイアウト
---------------------------------------- */
  /* flexbox */
  .unit2,
  .unit3,
  .unit4 { display: flex; flex-wrap: wrap; width: calc(100%); }
  .unit2 .col { width: 48%; }  /* 2カラム */
  .unit3 .col { width: calc(33.33%); margin: 0 20px; }  /* 3カラム */
  .unit4 .col { width: calc(25%); 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; font: 1.8rem/50px "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; vertical-align: middle; }
  input::placeholder,
  select::placeholder,
  textarea::placeholder { color: #A2A2A2; }
  select { background: url("") no-repeat 96% center; }
  textarea { overflow: auto; height: 200px; padding: 10px; line-height: 1.8; }
  /* 必須項目 */
  .must { font-size: 1.3rem; }
  /* 送信ボタン */
  .submit {
    padding: 20px 0; margin: 0 auto 20px; width: 32%; height: auto; line-height: 1; text-align: center;
    border: 3px solid #1b70cc; border-radius: 34px; display: block; background: #fff; color: #1b70cc; font-size: 2.4rem; font-weight: bold;
    -webkit-transition: 0.3s; -moz-transition: 0.3s; -o-transition: 0.3s; -ms-transition: 0.3s; transition: 0.3s; box-shadow: 1px 2.3px 4.5px rgba(66, 31, 11, 0.2);
    }
  .submit:hover { cursor: pointer; opacity: 0.8; background: #1b70cc; 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; }



  /* 共通ボタン */
a.btn_link { display: block; max-width: 500px; margin: 0 auto; padding: 15px 50px; background: #1b70cc; border: 2px solid #1b70cc; border-radius: 5px; color: #fff; text-align: center; font-size: 2.4rem; line-height: 1.4; box-shadow: 1px 2.3px 4.5px rgba(66, 31, 11, 0.2); }
a.btn_link:hover { background: #fff; color: #1b70cc; }
  @media screen and (max-width: 1400px) {
    a.btn_link { max-width: 100%; width: 72%; }
}

.arrow {  }
.arrow::before { content: ''; display: inline-block; width: 10px; height: 10px; border: 2px solid; border-color: #fff #fff transparent transparent; transform: rotate(45deg); margin-right: .5em; }
.arrow:hover::before { border-color: #1b70cc #1b70cc transparent transparent; }
.arrow.blue::before { border-color: #1b70cc #1b70cc transparent transparent; }
.arrow.blue:hover::before { border-color: #fff #fff transparent transparent; }


  /* SPメニュー
  ======================================== */
  .drawer-overlay { z-index: 9!important; }
  /* ドロワーメニュー?*/
  nav.drawer-nav { background: #fff; width: 60%; }
  nav ul.drawer-menu { font-size: 1.4rem; }
  nav ul.drawer-menu li { border-bottom: 1px solid #1b70cc; }
  nav ul.drawer-menu li a { width: 100%; height: 100%; color: #4B4B4B; display: block; padding: 20px; font-size: 1.6rem; font-weight: bold; }

  /*======================================== */
  /* ドロワーメニュー?*/
  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; }
  nav.drawer-nav { background: #fff; width: 60%; }
  .drawer--left .drawer-nav { left: -60%!important; }
  .drawer--left.drawer-open .drawer-nav { left: 0!important; }
  /* ドロワーの装飾?*/
  .drawer--left .drawer-hamburger { display: none; }  /* ページ上部の開閉メニューを非表示?*/




/* ========================================
  ヘッダー
======================================== */



/* ========================================
  フッター
======================================== */
#footer { background: ; }
.footer_navi { display: flex; justify-content: center; margin: 100px auto 40px; }
.footer_navi li { border-right: 1px solid #ccc; }
.footer_navi li:last-child { border-right: none; }
.footer_navi li a { display: block; padding: 10px 30px; font-size: 1.6rem; line-height: 1; }
.footer_town { display: block; height: 9vh; background: url(img/footer_town.svg) no-repeat; background-size: cover; background-position: center; }
.copyright { background: #1b70cc; padding: 10px 0; }
.copyright::after { content: ''; display: block; clear: both; }
.copyright .privacy_text { color: #fff; float: left; }
.copyright .copy_text { color: #fff; float: right; font-size: 1.3rem; }

/* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  ページ個別設定

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

/* ========================================
  トップ
======================================== */
header { background: #fff; }
header .wrap { position: relative; z-index: 10; }
.fixed_menu_box { position: absolute; top: 25px; right: 0px; width: 38px; }
/*
.top .fixed_menu_box { top: 30px; width: auto; }
*/
.top section { margin: 0 0 0px; }


/*
.fixed-bg { background-size: cover; background-attachment: fixed; background-position: center; min-height: 100vh;  }
.main_visual { background: url(img/index01.jpg) no-repeat; background-size: cover; background-attachment: fixed; background-position: center; min-height: 100vh; }
.main_visual::before { content: ''; background-color: rgba(0,0,0,0.5); position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 0; }
*/
.fixed-bg { background-size: cover; background-attachment: fixed; background-position: center; min-height: calc(100vh - 90px);  }
.main_visual { background: url(img/index01.jpg) no-repeat; background-size: cover; background-attachment: fixed; background-position: bottom; min-height: calc(100vh - 90px); }
.main_description { position: absolute; text-align: center; top: 50%; left: 50%; transform: translate(-50%, -50%); -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%);}
.top_logo { width: 100%; max-width: 120px; margin: 0 auto 50px; }
.main_description h2 { color: #fff; font-size: 4.8rem; font-weight: bold; line-height: 1.4; }
.scroll_box { position: absolute; bottom: 50px; left: 50%; transform: translate(-50%, 0%); -webkit-transform: translate(-50%, 0%); }
#showa { position: relative; overflow: hidden; padding: 160px 0 160px; }
#showa .wrap { position: relative; z-index: 2; }
#showa::before { content: '';
transform: translate(-50%, -50%) rotate(-45deg); background: #DCEBF7; height: 350px; width: 2000px; display: block; z-index: 0; position: absolute; top: 50%; left: 50%; }
#showa h2 { margin: 0 0 40px; font-size: 4.0rem; text-align: center; font-weight: bold; color: #1b70cc; }
#showa .lead_text { margin: 0 auto 80px; font-size: 2.4rem; text-align: center; }
#introductinon .block { background: #1b70cc; }
#introductinon .block .col { margin: 1%; position: relative; overflow: hidden; }
#introductinon .block .text { font-size: 2.2rem; margin: 0 auto 7em; width: 70%; }
#introductinon .block .left { background: #fff; color: #1b70cc; }
#introductinon .block .right { background: #1b70cc; color: #fff; }
#introductinon .col .ttl { width: 200px; margin: 70px auto 50px; }
#introductinon .block .col::before { display: block; content: ""; backface-visibility: hidden; position: absolute; top: -31px; left: -31px; width: 0; height: 0; border: 30px solid transparent; border-top: 30px solid #fff; -webkit-transform: otate(135deg); -moz-transform: rotate(135deg); -ms-transform: rotate(135deg); -o-transform: rotate(135deg); transform: rotate(135deg); }
#introductinon .block .col.left::before { border-top-color: #1b70cc; }
#introductinon .block .col::after { display: block; content: ""; backface-visibility: hidden; position: absolute; bottom: -31px; right: -31px; width: 0; height: 0; border: 30px solid transparent; border-top: 30px solid #fff; -webkit-transform: otate(-45deg); -moz-transform: rotate(-45deg); -ms-transform: rotate(-45deg); -o-transform: rotate(-45deg); transform: rotate(-45deg); }
#introductinon .block .col.left::after { border-top-color: #1b70cc; }
#introductinon .btn_link { position: absolute; bottom: 0; left: 50%; margin: 0 auto; transform: translate(-50%, -60px); color: #fff; }
#introductinon .btn_link:hover { color: #1b70cc; }
#introductinon .right .btn_link { background: #fff; color: #1b70cc; }
#introductinon .right .btn_link:hover { background: #1b70cc; color: #fff; border: 2px solid #fff; }






/* ========================================
  企業概要
======================================== */
/* 下層共通 */
/*
.header_logo { width: 100%; margin: 0 auto; padding: 10px 0; text-align: center; }
*/
.header_logo { width: 100%; margin: 0 auto; padding: 10px 0; text-align: left; }
.header_logo figure { max-width: 300px; display: inline-block; vertical-align: middle; }
.header_logo span { padding-left: 0.5em; color: #1b70cc; display: inline-block; vertical-align: middle; font-weight: 600; font-size: 2.6rem; }
.header_bg { position: relative; color: #fff; margin: 0 0 100px; }
.header_bg::before { content: ''; background-color: rgba(0,0,0,0.5); position: absolute; top: 0; right: 0; bottom: 0; left: 0; z-index: 0; }
.header_bg .inner { position: relative; padding: 60px 0; text-align: center; font-size: 4.0rem; font-weight: 600; }
.header_bg .inner h1 { }
.header_bg .inner h1::after { content: ''; display: block; border-bottom: 2px solid #fff; max-width: 580px; margin: 10px auto; }
.icon_ttl { margin: 0 0 30px; color: #1b70cc; font-size: 4.0rem; font-weight: 600; line-height: 1; }
.icon_ttl::before { content: ''; display: inline-block; height: 40px; width: 40px; vertical-align: top; margin-right: 10px; }
a.underline { text-decoration: underline; }
.about-bg { background: url(img/about_bg.jpg) no-repeat; background-size: cover; background-position: center; }
.business-bg { background: url(img/business_bg.jpg) no-repeat; background-size: cover; background-position: center; }
.recruit-bg { background: url(img/recruit_bg.jpg) no-repeat; background-size: cover; background-position: 0 -500px; }
.contact-bg { background: url(img/contact_bg.jpg) no-repeat; background-size: cover; background-position: 0 -600px; }


#greeting { margin: 0 0 100px; }
#greeting .wrap { background: url(img/greeting_bg.png); padding: 60 }
#greeting .block { padding: 50px 100px; }
#greeting .block h2 { margin: 0 0 30px; text-align: center; color: #1b70cc; font-size: 4.0rem; font-weight: 600; }
#greeting .block .leadText { margin: 0 0 50px; text-align: center; font-size: 2.4rem; }
#greeting .block .cio-image { margin-bottom: 50px; }
#greeting .block .cio-image img { width: 33%; margin-left: auto; }
#greeting .block .cio { text-align: right; font-weight: 600; font-size: 3.0rem; line-height: 1.4; color: #4B4B4B; }
#rinen {}
#rinen .block { display: flex; justify-content: space-between; }
#rinen .block .left { width: 53%; }
#rinen .block .left h2 { margin: 0 0 30px; color: #1b70cc; font-size: 4.0rem; font-weight: 600; line-height: 1; }
#rinen .block .left h2::before { background: url(img/icon_rinen.svg) no-repeat; background-position: center;  background-size: contain; width: 40px; }
#rinen .block .left .text { font-size: 2.2rem; }
#rinen .block .right { width: 45%; }

#about {}
#about .wrap { max-width: 1000px; margin: 0 auto 100px; }
#about h2 { text-align: center; }
#about h2::before { background: url(img/icon_about.svg) no-repeat; background-position: center; background-size: contain; width: 83px; }
#about .inner dl { display: flex; justify-content: space-between; font-size: 2.4rem; }
#about .inner dl dt { width: 21%; color: #0070C3; font-weight: 600; }
#about .inner dl dd { width: 74%; }
#about .inner dl dt,
#about .inner dl dd { padding: 12px 20px; border-bottom: 1px solid #0070C3; }
#about .inner dl:last-child dt,
#about .inner dl:last-child dd { border-bottom: none; }
#about #map {  }
#about #map .block { display: flex; justify-content: space-between; font-size: 2.4rem; }
#about #map .block .left { width: 50%; }
#about #map .block .right { width: 50%; }
#about #map .block .right iframe { width: 100%; height: 37.1vw; padding: 15px; background: #1b70cc; }


/* ========================================
  事業内容
======================================== */
#business .leadText { text-align: center; font-size: 2.4rem; }
#keiso h2::before { background: url(img/icon_keiso.svg) no-repeat; background-position: center; background-size: contain; width: 53px; }
/*
#keiso .wrap { background: url(img/business01.jpg) no-repeat; min-height: 456px; background-size: cover; }
#keiso .wrap:after { content: ''; display: block; clear: both; }
*/
#keiso .text { font-size: 2.0rem; }
#keiso .block { display: flex; justify-content: space-between; }
#keiso .block .left { width: 48%; }
#keiso .block .right { width: 48%; }
#case h2::before { background: url(img/icon_case.svg) no-repeat; background-position: center; background-size: contain; width: 53px; }
#case p { border-bottom: 1px solid #1b70cc; padding: 15px 0; font-size: 2.0rem; }
#case p:nth-child(2) { padding-top: 0; }


/* ========================================
  採用情報
======================================== */
#recruit_greeting {  }
#recruit_greeting .wrap { background: url(img/recruit01.jpg) no-repeat; min-height: 456px; background-size: cover; }
#recruit_greeting .wrap:after { content: ''; display: block; clear: both; }
#recruit_greeting .leadText { float: right; width: 58%; padding: 70px 0; font-size: 2.0rem; letter-spacing: -0.5px; }

#recruit {}
#recruit h2 { text-align: center; }
#recruit h2::before { background: url(img/icon_recruit_bl.svg) no-repeat; background-position: center; background-size: contain; width: 60px; }

#recruit .inner { margin: 0 0 160px; }
#recruit .inner dl { display: flex; justify-content: space-between; font-size: 2.4rem; margin: 0 0 10px; }
#recruit .inner dl dt { width: 23%; background: #1b70cc; color: #fff; font-weight: 600; display: flex; align-items: center; justify-content: center; }
#recruit .inner dl dd { width: 74%; }
#recruit .inner dl dt,
#recruit .inner dl dd { padding: 12px 20px; }

#recruit #entry {  }
#recruit #entry .wrap { display: flex; justify-content: center; position: relative; max-width: 1100px; }
#recruit #entry .wrap::after { content: ''; display: block; clear: both; }
#recruit #entry .left { width: 61%; margin: 0 39% 60px 0; position: relative; z-index: 1; }
#recruit #entry .left .box { position: relative; margin: 0 0 80px; color: #1b70cc; text-align: center; font-size: 2.6rem; }
#recruit #entry .left .box::before { content: ''; display: block; width: 144px; border-bottom: 3px solid #1b70cc; position: absolute; top: 70px; left: -40px; transform: rotate(65deg); }
#recruit #entry .left .box::after { content: ''; display: block; width: 144px; border-bottom: 3px solid #1b70cc; position: absolute; top: 70px; right: -40px; transform: rotate(-65deg); }
#recruit #entry .left .btn_link { background: #fff; color: #1b70cc; font-size: 2.8rem; border-radius: 54px; padding: 30px; }
#recruit #entry .left .btn_link:hover { background: #1b70cc; color: #fff; border: 2px solid #fff; }
#recruit #entry .right { width: 67.8%; position: absolute; top: -80px; right: -100px; }



/* ========================================
  お問い合わせ
======================================== */
#contact_lead { text-align: center; font-size: 2.4rem; }
#contact_lead .leadText { margin: 0 0 70px; }
#contact_lead .tel { font-size: 3.0rem; color: #1b70cc; font-weight: bold; line-height: 1; }
#contact_lead .tel span { font-size: 5.2rem; }
.bustime { color: #8A8A8A; }
#form { margin-bottom: 150px; }
#form h2 { text-align: center; }
#form h2::before { background: url(img/icon_mail.svg) no-repeat; background-position: center; background-size: contain; width: 60px; }
#form .inner { margin: 0 auto 60px; }
#form .inner dl { display: flex; justify-content: space-between; font-size: 2.4rem; }
#form .inner dl dt { width: 22.5%; color: #0070C3; font-weight: 600; }
#form .inner dl dd { width: 72%; }
#form .inner dl dt,
#form .inner dl dd { padding: 12px 20px; border-bottom: 1px solid #0070C3; }




#privacy .wrap { max-width: 1000px; }
#privacy h2 { margin: 0 0 30px; color: #1b70cc; font-size: 4.0rem; font-weight: 600; line-height: 1; text-align: center; }
#privacy .leadText { margin: 0 0 50px; font-size: 2.2rem; line-height: 1.6; text-align: center; }
#privacy .text { height: 500px; overflow-y: scroll; border: 2px solid #1b70cc; padding: 30px; }
#privacy dl { margin: 0 0 30px; }
#privacy dt { font-weight: bold; font-size: 2.0rem; }
#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サイズ (1300px以下)

###################################################################### */

  @media screen and (max-width: 1300px) {

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    全体設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    個別設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

  .wrap { padding: 0 20px; }
  .fixed_menu_box { right: 25px; }
.fixed-bg { min-height: calc(100vh - 70px);  }
.main_visual { min-height: calc(100vh - 70px); }
.about-bg { background-position: center; }
.business-bg { background-position: center; }
.recruit-bg { background-position: center; }
.contact-bg { background-position: center; }


}






/* ######################################################################

  タブレットサイズ (960px以下)

###################################################################### */

  @media screen and (max-width: 960px) {

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    全体設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

  .gnav { display: none; }
  /* ヘッダー */
  section { margin: 0 0 50px; }
  header .wrap { width: 100%; }
  .header_logo { padding: 10px 0 10px; }
  .header_logo figure { max-width: 200px; }
  .header_logo span { font-size: 2.2rem; }
  .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; }
  .copyright { padding: 10px 20px; }

  .lead { font-size: 1.6rem; margin: 30px 0 60px; }
  .submit { width: 50%; }
  .fixed_menu_box { top: 15px; }
  .btn_link { width: 100%; font-size: 2.0rem; }
  .header_bg .inner { font-size: 2.8rem; }
  .header_bg .inner h1::after { width: 80%; }
  .header_bg { margin: 0 0 50px; }
  .icon_ttl { font-size: 2.8rem; }
  .icon_ttl::before { width: 25px; height: 25px; }



  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    個別設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

/* top */
.main_description { width: 90%; }
.main_description h2 { font-size: 3.8rem; }
#showa { padding: 100px 0 100px; }
#showa h2 { font-size: 3.2rem; }
#introductinon .block { margin: 0 0 50px; }
#introductinon .btn_link { width: 80%; }
#introductinon .col .ttl { margin: 30px auto 30px; }



/* ========================================
  会社概要
======================================== */
#greeting { margin: 0 0 50px; }
#greeting .block { padding: 30px 30px; margin: 0 0 50px; }
#greeting .block h2 { margin: 0 0 30px; font-size: 2.8rem; }
#greeting .block .leadText { margin: 0 0 30px; font-size: 2.0rem; }
#greeting .block .cio-image img { width: 100%; }
#greeting .block .cio { font-size: 2.2rem; }
#rinen .block { display: block; }
#rinen .block .left { width: 100%; margin: 0 0 30px; }
#rinen .block .left h2 { font-size: 2.8rem; }
#rinen .block .right { width: 100%; }
#rinen .block .left h2::before { width: 25px; height: 25px; }
#rinen .block .left .text { font-size: 1.8rem; }
#about .wrap { margin: 0 auto 50px; }
#about .inner dl { display: block; font-size: 1.8rem; }
#about .inner dl dt { width: 100%; border-bottom: none; padding-bottom: 0; padding-left: 0; }
#about .inner dl dd { width: 100%; padding-top: 0; padding-left: 0; line-height: 1.6; }
#about #map .block { display: block; }
#about #map .block .left { width: 100%; }
#about #map .block .right { width: 100%; }
#about #map .block .right iframe { height: 50vh; }

/* ========================================
  事業内容
======================================== */
#business .leadText { font-size: 2.0rem; }
#keiso .text { font-size: 1.8rem; }
/*
#keiso .wrap { background: none; min-height: auto; }
#keiso .wrap::after { content: ''; display: block; background: url(img/business01_sp.jpg) no-repeat; min-height: 80vw; background-size: cover; }
*/
#case p { font-size: 1.8rem; }
#keiso .block { display: block; }
#keiso .block .left { width: 100%; margin: 0 0 30px; }
#keiso .block .right { width: 100%; }


/* ========================================
  お問い合わせ
======================================== */
#contact {}
#contact_lead .leadText { font-size: 2.2rem; }
#contact_lead .tel { display: block; font-size: 2.2rem; }
#contact_lead .tel span { display: inline-block; font-size: 4.6rem; }
#form { margin-bottom: 100px; }
#form .inner dl { display: block; font-size: 2.0rem; }
#form .inner dl dt { width: 100%; border-bottom: none; }
#form .inner dl dd { width: 100%; margin-bottom: 30px; line-height: 1.4; }
#form .inner dl dt,
#form .inner dl dd { padding: 0; }
#privacy h2 { font-size: 2.8rem; }
#privacy .leadText { font-size: 1.8rem; margin-bottom: 30px; }


/* ========================================
  求人情報
======================================== */
#recruit {}
#recruit .inner { margin: 0 0 50px; }
#recruit .inner dl { display: block; }
#recruit .inner dl dt { width: 100%; font-size: 2.0rem; padding: 10px; }
#recruit .inner dl dd { width: 100%; font-size: 1.8rem; padding: 5px 0 10px; }
#recruit .inner dl dt,
#recruit .inner dl dd { }
#recruit #entry .left { width: 90%; margin: 0; }
#recruit #entry .left .box { font-size: 2.4rem; }
#recruit #entry .right { display: none; }
#recruit_greeting .leadText { width: 100%; float: none; padding: 0 0 20px; font-size: 1.8rem; }
#recruit_greeting .wrap { background: none; min-height: auto; }
#recruit_greeting .wrap::after { content: ''; display: block; background: url(img/recruit01.jpg) no-repeat; min-height: 80vw; background-size: cover; }
#recruit #entry .left .box { margin: 0 0 40px; }
#recruit #entry .left .btn_link { padding: 20px; font-size: 2.4rem; }



  }








/* ######################################################################

  タブレットサイズ (768px以下)

###################################################################### */

  @media screen and (max-width: 768px) {





  }





/* ######################################################################

  スマートフォン - 横向きサイズ (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; }

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    個別設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

#recruit #entry .left { width: 100%; }
#recruit #entry .left .box { border: 3px double; border-radius: 6px; padding: 1em; font-size: 1.8rem; }
#recruit #entry .left .box::before { content: none; }
#recruit #entry .left .box::after { content: none; }

  }


/* ######################################################################

  スマートフォン - 縦向きサイズ (480px以下)

###################################################################### */

  @media screen and (max-width: 480px) {

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    全体設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

  /* ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
    個別設定
  ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */
.flex-control-nav { top: 130px; }
#service_info li { width: 100%; }

  }