@charset "utf-8";
/*#####　基本設定　#####*/
.clearfix:before, .clearfix:after {
  content: " ";
  display: table;
}
.clearfix:after {
  clear: both;
}
.clearfix {
  *zoom: 1;
}
body {
  font-family:
    -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Yu Gothic", "Meiryo", sans-serif;
  font-size: 16px;
  color: #04461e;
  line-height: 2;
  background-color: #f8faf4;
}
p {
  clear: both;
  padding: 10px;
}
a {
  text-decoration: none;
  color: #04461e;
}
a:hover {
  opacity: 0.7;
  transition: 0.7s;
}
img {
  image-rendering: -webkit-optimize-contrast;
}
/*################## スマホ縦用　##################*/
@media screen and (min-width: 0px) and (max-width: 480px) {
  /*####### PC非表示　スマホ表示 改行　#######*/
  .pc_area {
    display: none;
  }
  .phone_area {
    display: block;
  }
  .side-phone_area {
    display: block;
  }
  .pc_side_area {
    display: none;
  }
  .side_and_phone_area {
    display: block;
  }
  .br-pc {
    display: none;
  }
  .br-sp {
    display: block;
  }
  .br-side-phone {
    display: none;
  }
  .br-side-and-phone {
    display: block;
  }
  .br-side-and-pc {
    display: none;
  }
  .sp-center {
    text-align: center;
  }
  /*########################################*/
  #container {
    margin: 0 auto;
  }
  .img100 img {
    width: 100%;
    height: auto;
  }
  .img100-2 img { /*縦横どっちも画像100％表示*/
    width: 100%;
    height: auto;
  }
  /*#####　TOPに戻るボタン　#####*/
  #t-scroll {
    right: 10px;
    bottom: 20px;
  }
  #t-scroll a {
    padding: 12px 12px;
  }
  /*#####　見出し　#####*/
  .title-e {
    font-size: 13px;
    text-align: center;
    padding-bottom: 0;
    margin-bottom: 0;
  }
  .title-j {
    font-size: 30px;
    text-align: center;
    margin-top: -10px;
  }
}
/*################## スマホ横用 #################*/
@media screen and (min-width: 481px) and (max-width: 896px) {
  body {
    -webkit-text-size-adjust: 100%;
  }
  /*####### スマホ横表示 #######*/
  .pc_area {
    display: none;
  }
  .side-phone_area {
    display: block;
  }
  .phone_area {
    display: none;
  }
  .pc_side_area {
    display: block;
  }
  .side_and_phone_area {
    display: block;
  }
  .br-pc {
    display: none;
  }
  .br-sp {
    display: none;
  }
  .br-side-phone {
    display: block;
  }
  .br-side-and-phone {
    display: block;
  }
  .br-side-and-pc {
    display: block;
  }
  .pc-center {
    text-align: center;
  }
  .side-phone_none {
    display: none;
  }
  /*########################################*/
  #containe:after {
    content: "";
    display: block;
    clear: both
  }
  #container {
    margin: 0 auto;
    overflow-y: scroll;
    -ms-overflow-style: none; /* IE, Edge 対応 */
    scrollbar-width: none; /* Firefox 対応 */
  }
  #container::-webkit-scrollbar { /* Chrome, Safari 対応 */
    display: none;
  }
  .img100-2 img { /*縦横どっちも画像100％表示*/
    width: 100%;
    height: auto;
  }
  .img100-phone-w img {
    width: 100%;
    height: auto;
  }
  .img80 img {
    width: 30%;
    height: auto;
  }
  /*#####　TOPに戻るボタン　#####*/
  #t-scroll {
    right: 10px;
    bottom: 50px;
  }
  #t-scroll a {
    padding: 12px 12px;
  }
  /*#####　見出し　#####*/
  .title-e {
    font-size: 14px;
    text-align: center;
    padding-bottom: 0;
    margin-bottom: 0;
  }
  .title-j {
    font-size: 36px;
    text-align: center;
    margin-top: -10px;
  }
}
/*################## PC用 #################*/
@media print, screen and (min-width:897px) {
  body {
    min-width: 950px;
  }
  /*####### PC表示　スマホ非表示 #######*/
  .pc_area {
    display: block;
  }
  .phone_area {
    display: none;
  }
  .side-phone_area {
    display: none;
  }
  .pc_side_area {
    display: block;
  }
  .side_and_phone_area {
    display: none;
  }
  .br-pc {
    display: block;
  }
  .br-sp {
    display: none;
  }
  .br-side-phone {
    display: none;
  }
  .br-side-and-phone {
    display: none;
  }
  .br-side-and-pc {
    display: block;
  }
  .pc-center {
    text-align: center;
  }
  /*########################################*/
  #containe:after {
    content: "";
    display: block;
    clear: both
  }
  #container {
    margin: 0 auto;
    overflow-y: scroll;
    -ms-overflow-style: none; /* IE, Edge 対応 */
    scrollbar-width: none; /* Firefox 対応 */
  }
  #container::-webkit-scrollbar { /* Chrome, Safari 対応 */
    display: none;
  }
  /*#####　TOPに戻るボタン　#####*/
  #t-scroll {
    right: 50px;
    bottom: 50px;
  }
  #t-scroll a {
    padding: 20px 20px;
  }
  /*#####　見出し　#####*/
  .title-e {
    font-size: 14px;
    text-align: center;
    padding-bottom: 0;
    margin-bottom: 0;
  }
  .title-j {
    font-size: 36px;
    text-align: center;
    margin-top: -10px;
  }
}
/*################## スマホ・PC共通 ##################*/
#container {
  margin: 0 auto;
}
/*ページリンク着地*/
.jump_point {
  display: block;
  padding-top: 100px;
  margin-top: -100px;
}
/*ページリンク着地*/
.jump_point-2 {
  display: block;
  padding-top: 200px;
  margin-top: -200px;
}
/*#####　左揃えの文字を横幅が自動的に伸縮　#####*/
.inline-block {
  text-align: center;
}
.inline-block p {
  display: inline-block;
  text-align: left;
}
.inline-block ul {
  display: inline-block;
  text-align: left;
}
.inline-block dl {
  display: inline-block;
  text-align: left;
}
/*#####　文字揃え　#####*/
.center {
  text-align: center;
}
.left {
  text-align: left;
}
.right {
  text-align: right;
}
/*#####　間隔（padding)　#####*/
.padding-10 {
  padding: 10px;
}
.padding-r-20px {
  padding-right: 20px;
}
/*########## 文字色 ##########*/
.white {
  color: #ffffff; /*白*/
}
.green {
  color: #04461e; /*ロゴ緑*/
}
/*########## 文字の大きさ ##########*/
.f14 {
  font-size: 14px;
  font-weight: normal;
}
.f16 {
  font-size: 16px;
  font-weight: normal;
}
.f18 {
  font-size: 18px;
}
.f21 {
  font-size: 21px;
}
.f24 {
  font-size: 24px;
}
.f30 {
  font-size: 30px;
}
.f36 {
  font-size: 36px;
}
.f40 {
  font-size: 40px;
}
.f50-p {
  font-size: 50%;
}
.f80-p {
  font-size: 80%;
  padding: 0 3px;
}
/*########## 塗りつぶし背景 ##########*/
.paint-g { /*採用情報*/
  padding: 10px 30px;
  background-color: #04461e;
  color: #fff;
  font-size: 21px;
  font-weight: 600;
  border-radius: 10px;
  letter-spacing: 2px;
}
/*#####　TOPに戻るボタン　#####*/
#t-scroll {
  z-index: 999999; /*最前面に*/
  position: fixed;
}
#t-scroll a {
  color: #04461e;
  text-align: center;
  text-decoration: none;
}
#t-scroll a:hover {
  opacity: 0.7;
  transition: 0.7s;
}
/*#####　もっと見るボタン　#####*/
.btn-more {
  padding: 5px 30px;
  background-color: #fff;
  border: solid 1px #04461e;
  color: #04461e;
  border-radius: 30px;
  cursor: pointer;
  display: inline-block;
  font-weight: 600;
}