@charset "UTF-8";
/* 500 700 */
/* 500 */
/* 600 700 */
/* structure
----------------------------------------------------------------------*/
html, body {
  overflow-x: hidden; }

html {
  font-size: 62.5%;
  /* html入力枠用設定 */
  visibility: hidden;
  scroll-behavior: smooth; }

html.wf-active, html.wfno-load {
  visibility: visible; }

body {
  width: 100%;
  color: #000;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 500;
  font-style: normal;
  line-height: 1.6em;
  letter-spacing: 0.1em;
  text-align: left; }

@media screen and (max-width: 767px) {
  body {
    font-size: 14px;
    line-height: 1.6em;
    letter-spacing: 0.1em; } }
@media print {
  body {
    width: 1200px;
    transform: scale(0.8);
    -moz-transform: scale(0.8);
    -webkit-transform: scale(0.8);
    transform-origin: 0 0; } }
input::placeholder {
  color: #A0A0A0; }

textarea::placeholder {
  color: #A0A0A0; }

/* IE */
input:-ms-input-placeholder {
  color: #A0A0A0; }

textarea:-ms-input-placeholder {
  color: #A0A0A0; }

/* Edge */
input::-ms-input-placeholder {
  color: #A0A0A0; }

textarea::-ms-input-placeholder {
  color: #A0A0A0; }

/* 携帯以外の電話リンク無効 */
a[href^="tel:"] {
  color: #000; }

@media screen and (min-width: 768px) {
  a[href^="tel:"] {
    cursor: default;
    pointer-events: none; } }
/* Scrollup */
#scrollUp {
  background: url("../images/common/pagetop.gif") left top no-repeat;
  background-size: contain;
  bottom: 20px;
  right: 20px;
  width: 44px;
  height: 70px;
  font-size: 0;
  line-height: 0;
  text-indent: -9999px;
  transition: all 0.5s; }

#scrollUp.hide {
  right: -60px; }

/* Font */
.c_green {
  color: #004637; }

.c_bgreen {
  color: #ECF7EF; }

.c_blue {
  color: #0071BC; }

.c_red {
  color: #D44455; }

.fsize11 {
  font-size: 11px; }

.fsize12 {
  font-size: 12px; }

.fsize13 {
  font-size: 13px; }

.fsize14 {
  font-size: 14px; }

.fsize15 {
  font-size: 15px; }

.fsize16 {
  font-size: 16px; }

.fsize18 {
  font-size: 18px; }

.fsize20 {
  font-size: 20px; }

.fsize22 {
  font-size: 22px; }

.fsize23 {
  font-size: 23px; }

.fsize24 {
  font-size: 24px; }

.fsize25 {
  font-size: 25px; }

.fsize26 {
  font-size: 26px; }

.fsize28 {
  font-size: 28px; }

.fsize30 {
  font-size: 30px; }

.fsize33 {
  font-size: 33px; }

.fsize35 {
  font-size: 35px; }

.fsize40 {
  font-size: 40px; }

.fsize45 {
  font-size: 45px; }

.fsize50 {
  font-size: 50px; }

.fsize60 {
  font-size: 60px; }

.tx_right {
  text-align: right; }

.tx_center {
  text-align: center; }

.tx_center_pc {
  text-align: center; }

a {
  color: #000; }

b {
  font-weight: 700; }

.f_shs_500 {
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 500; }

.f_shs_700 {
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 700; }

.f_ymin_500 {
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500; }

.tl_catearea {
  width: 100%;
  padding: 15px 0 0 0; }

.tl_cate {
  position: relative;
  width: 100%;
  height: 128px;
  color: #000;
  font-size: 40px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.7em;
  text-align: center;
  padding-top: 30px; }
  .tl_cate span {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    color: #ECF7EF;
    font-size: 180px;
    font-family: din-2014, sans-serif;
    font-weight: 700;
    line-height: 128px;
    text-align: center;
    z-index: -1; }

.tl_topcate {
  color: #004637;
  font-size: 40px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.4em;
  text-align: center;
  margin: 0 0 15px 0; }

.tl_midashi {
  color: #000;
  font-size: 40px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.4em;
  margin: 0 0 30px 0; }

.tl_topabout {
  position: relative;
  width: 100%;
  height: 130px;
  color: #004637;
  font-size: 40px;
  font-family: dnp-shuei-ymincho-std, sans-serif;
  font-weight: 500;
  line-height: 1.7em;
  text-align: center;
  margin: 0 0 40px 0;
  padding-top: 95px; }
  .tl_topabout span {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    color: #ECF7EF;
    font-size: 180px;
    font-family: din-2014, sans-serif;
    font-weight: 700;
    line-height: 1.0em;
    text-align: center;
    margin: 0 0 30px 0;
    z-index: -1; }

.stl_bggra {
  width: 100%;
  height: 60px;
  color: #FFF;
  font-size: 25px;
  line-height: 60px;
  background: linear-gradient(90deg, #53B671, #0071BC);
  background: -webkit-linear-gradient(0, #53B671, #0071BC);
  margin: 0 0 30px 0;
  padding: 0 0 0 40px; }

.tl_year {
  display: inline-block;
  font-size: 30px;
  font-family: din-2014, sans-serif;
  font-weight: 700;
  line-height: 1.0em;
  background: linear-gradient(90deg, #53B671, #0071BC);
  background: -webkit-linear-gradient(0, #53B671, #0071BC);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; }

h5 {
  font-size: 25px;
  line-height: 1.4em;
  margin-bottom: 15px; }

@media screen and (max-width: 767px) {
  .fsize11 {
    font-size: 10px; }

  .fsize12 {
    font-size: 12px; }

  .fsize13 {
    font-size: 13px; }

  .fsize14 {
    font-size: 14px; }

  .fsize15 {
    font-size: 15px; }

  .fsize16 {
    font-size: 14px; }

  .fsize18 {
    font-size: 16px; }

  .fsize20 {
    font-size: 18px; }

  .fsize22 {
    font-size: 18px; }

  .fsize23 {
    font-size: 21px; }

  .fsize24 {
    font-size: 22px; }

  .fsize25 {
    font-size: 22px; }

  .fsize26 {
    font-size: 23px; }

  .fsize28 {
    font-size: 28px; }

  .fsize30 {
    font-size: 22px; }

  .fsize33 {
    font-size: 33px; }

  .fsize35 {
    font-size: 30px; }

  .fsize40 {
    font-size: 28px; }

  .fsize45 {
    font-size: 25px; }

  .fsize50 {
    font-size: 40px; }

  .fsize60 {
    font-size: 35px; }

  .tl_cate {
    width: 100%;
    height: 60px;
    font-size: 22px;
    line-height: 1.7em;
    padding-top: 18px; }
    .tl_cate span {
      width: 100%;
      height: 100%;
      font-size: 80px;
      line-height: 1.0em;
      text-align: center;
      white-space: nowrap; }

  .tl_topcate {
    font-size: 22px;
    line-height: 1.4em;
    text-align: center;
    margin: 0 0 25px 0; }

  .tl_midashi {
    font-size: 22px;
    line-height: 1.4em;
    margin: 0 0 25px 0; }

  .tl_topabout {
    width: 100%;
    height: 60px;
    font-size: 22px;
    line-height: 1.7em;
    letter-spacing: 0;
    margin: 0 0 25px 0;
    padding-top: 34px; }
    .tl_topabout span {
      width: 100%;
      height: 100%;
      font-size: 80px;
      line-height: 1.0em;
      text-align: center;
      margin: 0 0 30px 0;
      white-space: nowrap; }

  .stl_bggra {
    width: 100%;
    height: 60px;
    font-size: 25px;
    line-height: 60px;
    text-align: center;
    margin: 0 0 30px 0;
    padding: 0; } }
/* INDENT */
.indent {
  text-indent: -1.0em;
  padding-left: 1.0em; }

@media screen and (max-width: 767px) {
  .newline {
    display: block; } }
/* ボタン */
a.btn, button, input[type=submit] {
  display: block;
  width: 180px;
  height: 55px;
  color: #FFF;
  font-size: 16px;
  line-height: 55px;
  text-align: center;
  background-color: #004637;
  margin: 0 auto;
  border-radius: 5px;
  transition: all 0.3s; }

button:hover {
  opacity: 0.8; }

header a.btn_contact {
  display: block;
  width: 180px;
  height: 55px;
  color: #FFF;
  font-size: 16px;
  line-height: 55px;
  text-align: center;
  background-color: #53B671;
  border-radius: 5px; }

/* fullwidth */
.fullwidth_img, .fullwidth_half {
  width: 100%; }

/* margin */
.marea {
  width: 850px;
  margin: 0 auto; }

@media screen and (max-width: 767px) {
  .marea {
    width: 92%; } }
.mboxarea {
  width: 1000px;
  margin: 0 auto; }

.m_top20 {
  margin-top: 20px; }

.m_bottom80 {
  margin-bottom: 80px; }

@media screen and (max-width: 767px) {
  .mbox, .mbox1, .mbox2 {
    width: 90%;
    margin: 0 auto; }

  .m_top20 {
    margin-top: 15px; }

  .m_bottom80 {
    margin-bottom: 40px; } }
/* ul */
ul.pagelinklist {
  display: flex;
  display: -webkit-flex;
  width: 100%;
  background-color: #ECF7EF;
  padding: 25px;
  flex-wrap: wrap;
  justify-content: center;
  -webkit-justify-content: center; }
  ul.pagelinklist li {
    margin: 0 30px; }
    ul.pagelinklist li a {
      display: block;
      height: 20px;
      color: #000;
      font-size: 16px;
      line-height: 1.0em; }
      ul.pagelinklist li a::after {
        content: "";
        display: inline-block;
        width: 18px;
        height: 20px;
        background: url("../images/common/arrow.png") top 2px left no-repeat;
        background-size: contain;
        margin: 0 0 0 10px;
        vertical-align: bottom; }

@media screen and (max-width: 767px) {
  ul.pagelinklist {
    width: 100%;
    padding: 20px 0 0 0; }
    ul.pagelinklist li {
      margin: 0 10px 20px 10px; } }
/* ol */
ol > li {
  list-style-position: inside;
  list-style-type: decimal; }
  ol > li ul {
    margin-left: 1.5em; }

@media screen and (max-width: 767px) {
  ol > li ul {
    margin-left: 1.0em; } }
/* dl */
dl {
  display: flex;
  display: -webkit-flex;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between; }

@media screen and (max-width: 767px) {
  dl.reverse {
    flex-wrap: wrap-reverse; } }
/* table */
table.ttype1 {
  width: 100%; }
  table.ttype1 th {
    color: #FFF;
    font-size: 16px;
    line-height: 1.6em;
    vertical-align: middle;
    background-color: #004637;
    border-bottom: 2px solid #FFF;
    padding: 20px; }
  table.ttype1 td {
    color: #000;
    font-size: 16px;
    line-height: 1.6em;
    vertical-align: middle;
    background-color: #ECF7EF;
    border-bottom: 2px solid #FFF;
    padding: 20px; }

table.ttype2 {
  width: 100%; }
  table.ttype2 tr {
    border-bottom: 1px solid #004637; }
  table.ttype2 th {
    width: 110px;
    color: #000;
    vertical-align: top;
    padding: 25px 20px 20px 20px; }
  table.ttype2 td {
    width: calc(100% - 110px);
    color: #000;
    font-size: 16px;
    line-height: 1.6em;
    vertical-align: middle;
    padding: 20px; }

@media screen and (max-width: 767px) {
  table.ttype1 {
    width: 100%; }
    table.ttype1 th {
      font-size: 14px;
      line-height: 1.6em;
      border-bottom: 2px solid #FFF;
      padding: 15px 10px; }
    table.ttype1 td {
      font-size: 14px;
      line-height: 1.6em;
      border-bottom: 2px solid #FFF;
      padding: 15px 10px; }

  table.ttype2 {
    width: 100%; }
    table.ttype2 tr {
      border-bottom: 1px solid #004637; }
    table.ttype2 th {
      width: 105px;
      padding: 15px 10px 15px 10px; }
    table.ttype2 td {
      width: calc(100% - 105px);
      font-size: 14px;
      line-height: 1.6em;
      padding: 15px 10px 15px 0; } }
/* Object Fit */
.img_of {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit:cover'; }

.imgbox {
  position: relative;
  width: 100%; }

/* table */
table.availability {
  width: 570px;
  background-color: #FFF;
  border-top: 1px solid #000;
  border-left: 1px solid #000;
  margin: 0 auto; }
  table.availability th, table.availability td {
    color: black;
    font-size: 18px;
    line-height: 1.4em;
    vertical-align: middle;
    border-bottom: 1px solid #000;
    border-right: 1px solid #000;
    padding: 5px 15px; }
    table.availability th.c_red, table.availability td.c_red {
      color: red; }
  table.availability th {
    text-align: left; }
    table.availability th.w46 {
      width: 46%; }
    table.availability th.w27 {
      width: 27%; }
    table.availability th.center {
      text-align: center; }
  table.availability td {
    text-align: right; }

@media screen and (max-width: 767px) {
  /* dl table */
  dl.pointtable {
    width: 100%;
    margin: 0 auto 50px auto; }
    dl.pointtable dt {
      width: 100%;
      font-size: 16px;
      line-height: 1.7em;
      border-bottom: 2px solid #808080;
      margin-bottom: 10px;
      padding: 0 0 10px 5px; }
    dl.pointtable dd {
      width: 100%;
      font-size: 16px;
      line-height: 1.7em;
      letter-spacing: 0;
      border-bottom: 1px solid #CECECE;
      margin-bottom: 25px;
      padding: 0 0 10px 5px; }

  /* table */
  table.availability {
    width: 100%;
    background-color: #FFF;
    border-top: 1px solid #000;
    border-left: 1px solid #000;
    margin: 0 auto; }
    table.availability th, table.availability td {
      color: black;
      font-size: 16px;
      line-height: 1.4em;
      border-bottom: 1px solid #000;
      border-right: 1px solid #000;
      padding: 5px 7px; }
    table.availability th.w46 {
      width: 46%; }
    table.availability th.w27 {
      width: 27%; } }
/* 非表示 */
.disno {
  display: none; }

.sp {
  display: none; }

@media screen and (max-width: 767px) {
  .pc {
    display: none; }

  .sp {
    display: block; } }
/*--------------------------------------------------*/
#wrapper {
  width: 100%;
  margin: 0 auto;
  overflow-x: hidden; }

/* basehead
--------------------------------------------------*/
header#basehead {
  width: 100%;
  height: 97px;
  background-color: #FFF;
  padding-top: 22px; }
  header#basehead dl {
    width: 1145px;
    margin: 0 auto; }
    header#basehead dl dt {
      width: 287px; }
    header#basehead dl dd {
      width: 712px; }
  header#basehead .logoarea {
    width: 100%;
    height: 49px;
    margin-top: 5px; }
    header#basehead .logoarea a {
      display: block;
      width: 100%;
      height: 100%;
      background: url("../images/common/logo_b.png") left top no-repeat;
      background-size: contain;
      font-size: 0;
      line-height: 0;
      text-indent: -9999px; }
  header#basehead .pc_navi {
    display: flex;
    display: -webkit-flex;
    width: 100%;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between; }
    header#basehead .pc_navi > ul {
      display: flex;
      display: -webkit-flex;
      width: 504px;
      padding-top: 18px;
      flex-wrap: wrap;
      -webkit-justify-content: space-between;
      justify-content: space-between; }
      header#basehead .pc_navi > ul li {
        position: relative; }
        header#basehead .pc_navi > ul li > a {
          display: block;
          height: 16px;
          color: #000;
          line-height: 1.0em; }
  header#basehead .sp_navi {
    display: none; }
  header#basehead .catchcopy {
    display: none; }

#top #wrapper > header#basehead {
  width: 100%;
  height: 730px;
  background: url("../images/top/top_main.jpg") center center no-repeat;
  background-size: cover;
  margin: 0 auto; }
  #top #wrapper > header#basehead .logoarea a {
    background: url("../images/common/logo_w.png") left top no-repeat;
    background-size: contain; }
  #top #wrapper > header#basehead .pc_navi ul li a {
    color: #FFF; }
  #top #wrapper > header#basehead .catchcopy {
    display: block;
    width: 900px;
    height: 146px;
    background: url("../images/top/top_main_tl.png") left top no-repeat;
    background-size: contain;
    margin: 220px auto 0 auto;
    font-size: 0;
    line-height: 0;
    text-indent: -9999px; }

#top #fixhead header#basehead {
  width: 100%;
  height: 97px;
  background-color: #FFF;
  padding-top: 22px; }
  #top #fixhead header#basehead .logoarea a {
    background: url("../images/common/logo_b.png") left top no-repeat;
    background-size: contain; }
  #top #fixhead header#basehead .pc_navi > ul li.firstnav > a {
    color: #000; }
  #top #fixhead header#basehead .catchcopy {
    display: none; }

@media screen and (max-width: 767px) {
  header#basehead {
    width: 100%;
    height: 50px;
    background-color: #FFF;
    padding-top: 0; }
    header#basehead dl {
      width: 100%;
      margin: 0 auto;
      padding-left: 14px; }
      header#basehead dl dt {
        width: 272px; }
      header#basehead dl dd {
        width: 50px; }
    header#basehead .logoarea {
      width: 100%;
      height: 43px;
      margin-top: 5px; }
      header#basehead .logoarea a {
        display: block;
        width: 100%;
        height: 100%;
        background: url("../images/common/logo_b.png") left top no-repeat;
        background-size: contain;
        font-size: 0;
        line-height: 0;
        text-indent: -9999px; }
    header#basehead .pc_navi {
      display: none; }
    header#basehead .sp_navi {
      display: flex;
      width: 100%;
      height: 50px; }

  #top #wrapper > header#basehead {
    width: 100%;
    height: 550px;
    background: url("../images/top/top_main.jpg") center center no-repeat;
    background-size: cover;
    margin: 0 auto; }
    #top #wrapper > header#basehead .logoarea a {
      background: url("../images/common/logo_w.png") left top no-repeat;
      background-size: contain; }
    #top #wrapper > header#basehead .pc_navi ul li a {
      color: #FFF; }
    #top #wrapper > header#basehead .catchcopy {
      display: block;
      width: 90%;
      height: auto;
      background: url("../images/top/top_main_tl.png") left top no-repeat;
      background-size: contain;
      margin: 205px auto 0 auto;
      padding-top: 14.02%; }

  #top #fixhead header#basehead {
    width: 100%;
    height: 50px;
    background-color: #FFF;
    padding-top: 0; }
    #top #fixhead header#basehead .logoarea a {
      background: url("../images/common/logo_b.png") left top no-repeat;
      background-size: contain; }
    #top #fixhead header#basehead .pc_navi > ul li.firstnav > a {
      color: #000; }

  a.hmenu_btn, a.hmenu_close {
    display: block;
    position: relative;
    width: 50px;
    height: 50px;
    background-color: #53B671; }
    a.hmenu_btn span, a.hmenu_close span {
      display: block;
      position: absolute;
      left: 12px;
      width: 26px;
      height: 1px;
      background-color: #FFF;
      transform-origin: 0 0;
      transition: all 0.2s; }
    a.hmenu_btn span:nth-child(1), a.hmenu_close span:nth-child(1) {
      top: 16px; }
    a.hmenu_btn span:nth-child(2), a.hmenu_close span:nth-child(2) {
      top: 24px;
      opacity: 1; }
    a.hmenu_btn span:nth-child(3), a.hmenu_close span:nth-child(3) {
      top: 32px; }

  .hmenu_btn.active span:nth-child(1), a.hmenu_close span:nth-child(1) {
    top: 16px;
    left: 16px;
    -webkit-transform: rotate(40deg);
    transform: rotate(40deg); }

  .hmenu_btn.active span:nth-child(2), a.hmenu_close span:nth-child(2) {
    opacity: 0; }

  .hmenu_btn.active span:nth-child(3), a.hmenu_close span:nth-child(3) {
    top: 32px;
    left: 15px;
    -webkit-transform: rotate(-40deg);
    transform: rotate(-40deg); } }
/* fixhead
--------------------------------------------------*/
#fixhead {
  position: fixed;
  top: -97px;
  left: 0;
  width: 100%;
  height: 97px;
  opacity: 0;
  transition: all 0.65s;
  padding: 0;
  z-index: 200; }

#fixhead.scrolled {
  top: 0;
  opacity: 1; }

@media screen and (max-width: 767px) {
  #fixhead {
    position: fixed;
    top: -100px;
    left: 0;
    width: 100%;
    height: 50px;
    opacity: 0;
    transition: all 0.65s;
    padding: 0;
    z-index: 200; }

  #fixhead.scrolled {
    top: 0;
    opacity: 1; } }
/* ハンバーガーメニュー
--------------------------------------------------*/
.hmenu {
  display: none; }

@media screen and (max-width: 767px) {
  .hmenu {
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    color: #FFF;
    background: #53B671;
    z-index: -1;
    opacity: 0;
    transition: all 0.6s;
    overflow: hidden; }

  .hmenu.active {
    opacity: 1;
    z-index: 1000 !important; }

  .hmenu_in {
    position: relative;
    padding: 0;
    overflow: hidden;
    z-index: 300; }
    .hmenu_in dl {
      width: 100%;
      margin: 0 auto;
      padding-left: 14px; }
      .hmenu_in dl dt {
        width: 272px; }
      .hmenu_in dl dd {
        width: 50px; }
    .hmenu_in .logoarea {
      width: 100%;
      height: 43px;
      margin-top: 5px; }
      .hmenu_in .logoarea a {
        display: block;
        width: 100%;
        height: 100%;
        background: url("../images/common/logo_w.png") left top no-repeat;
        background-size: contain;
        font-size: 0;
        line-height: 0;
        text-indent: -9999px; }

  .hnavi {
    width: 100%;
    height: 100vh;
    margin: 0 0 40px auto; }
    .hnavi ul.hnavi_menu {
      width: 90%;
      margin: 0 auto;
      padding: 40px 0 0 0; }
      .hnavi ul.hnavi_menu > li {
        width: 100%;
        text-align: center;
        border-bottom: 1px solid #FFF;
        margin-bottom: 30px;
        padding: 0 0 10px 0; }
        .hnavi ul.hnavi_menu > li > a {
          display: block;
          color: #FFF;
          font-size: 18px;
          line-height: 1.4em;
          letter-spacing: 0; }
    .hnavi .contactarea {
      width: 180px;
      margin: 0 auto; }
      .hnavi .contactarea a.btn_contact {
        display: block;
        width: 100%;
        height: 50px;
        background-color: #004637;
        color: #FFF;
        font-size: 18px;
        line-height: 50px;
        text-align: center;
        border-radius: 5px; } }
/* footer
--------------------------------------------------*/
footer {
  width: 100%;
  background-color: #FAFAFA;
  padding: 50px 0 0 0; }
  footer .f_menuarea {
    display: flex;
    display: -webkit-flex;
    width: 880px;
    margin: 0 auto;
    padding-bottom: 50px;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between; }
    footer .f_menuarea dl {
      width: 630px;
      margin-bottom: 30px; }
      footer .f_menuarea dl dt {
        width: 287px; }
        footer .f_menuarea dl dt .logoarea {
          width: 100%;
          height: 49px;
          margin-top: 5px; }
          footer .f_menuarea dl dt .logoarea a {
            display: block;
            width: 100%;
            height: 100%;
            background: url("../images/common/logo_b.png") left top no-repeat;
            background-size: contain;
            font-size: 0;
            line-height: 0;
            text-indent: -9999px; }
      footer .f_menuarea dl dd {
        width: 310px; }
        footer .f_menuarea dl dd p.address {
          font-size: 14px;
          line-height: 1.4em;
          letter-spacing: 0;
          margin-bottom: 5px; }
        footer .f_menuarea dl dd p.tel {
          color: #004637;
          font-size: 20px;
          line-height: 1.4em;
          letter-spacing: 0; }
          footer .f_menuarea dl dd p.tel .fax {
            color: #000;
            font-size: 14px; }
    footer .f_menuarea ul.fmenu {
      display: flex;
      display: -webkit-flex;
      width: 100%;
      flex-wrap: wrap;
      -webkit-justify-content: space-between;
      justify-content: space-between; }
      footer .f_menuarea ul.fmenu li a.pagelink {
        display: block;
        color: #000;
        font-size: 16px;
        line-height: 1.4em;
        letter-spacing: 0;
        margin-bottom: 12px; }
      footer .f_menuarea ul.fmenu li a.secondarylink {
        display: block;
        color: #000;
        font-size: 14px;
        line-height: 1.4em;
        letter-spacing: 0;
        margin-bottom: 7px; }
        footer .f_menuarea ul.fmenu li a.secondarylink::before {
          content: '−';
          margin-right: 5px; }
      footer .f_menuarea ul.fmenu li a.thirdlink {
        display: block;
        color: #000;
        font-size: 14px;
        line-height: 1.4em;
        letter-spacing: 0;
        text-indent: 1.0em;
        margin-bottom: 7px; }
        footer .f_menuarea ul.fmenu li a.thirdlink::before {
          content: '▪'; }
  footer .copyrightarea {
    width: 100%;
    background-color: #FFF;
    padding: 25px 0; }
    footer .copyrightarea p.copyright {
      font-size: 11px;
      line-height: 1.4em;
      text-align: center; }

@media screen and (max-width: 767px) {
  footer {
    width: 100%;
    padding: 30px 0 0 0; }
    footer .f_menuarea {
      width: 300px;
      margin: 0 auto;
      padding-bottom: 15px; }
      footer .f_menuarea dl {
        width: 100%;
        margin-bottom: 30px; }
        footer .f_menuarea dl dt {
          width: 287px;
          margin: 0 auto 20px auto; }
        footer .f_menuarea dl dd {
          width: 100%;
          text-align: center; }
          footer .f_menuarea dl dd p.address {
            font-size: 14px;
            line-height: 1.4em;
            letter-spacing: 0;
            margin-bottom: 5px; }
          footer .f_menuarea dl dd p.tel {
            color: #004637;
            font-size: 20px;
            line-height: 1.4em;
            letter-spacing: 0; }
            footer .f_menuarea dl dd p.tel .fax {
              color: #000;
              font-size: 14px; }
      footer .f_menuarea ul.fmenu {
        width: 100%; }
        footer .f_menuarea ul.fmenu li {
          margin-bottom: 25px; }
    footer .copyrightarea {
      width: 15px 0; }
      footer .copyrightarea p.copyright {
        font-size: 9px;
        line-height: 1.4em;
        letter-spacing: 0;
        text-align: center; } }
/* トップ
--------------------------------------------------*/
.toparea1 {
  width: 100%;
  padding: 25px 0 80px 0; }
  .toparea1 p {
    width: 650px;
    margin: 0 auto 50px auto; }

.toparea2 {
  position: relative;
  width: 100%;
  height: 970px;
  background: url("../images/common/bg_pattern.gif") center center repeat;
  background-size: 249px 254px;
  overflow: hidden; }
  .toparea2::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 480px;
    border-style: solid;
    border-width: 480px 100vw 0 0;
    border-color: #ECF7EF transparent transparent transparent;
    z-index: 1; }
  .toparea2 .toparea2_in {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    padding: 45px 0 0 0;
    z-index: 2; }
  .toparea2 .dl_linkbox {
    width: 1100px;
    height: 380px;
    margin: 0 auto 80px auto; }
    .toparea2 .dl_linkbox .photoarea {
      width: 650px; }
    .toparea2 .dl_linkbox .txtarea {
      display: flex;
      width: 400px;
      gap: 40px;
      flex-wrap: wrap;
      align-content: center; }
      .toparea2 .dl_linkbox .txtarea h3.tl_topcate {
        width: 450px;
        line-height: 1.0em;
        margin-bottom: 0; }
      .toparea2 .dl_linkbox .txtarea p {
        width: 100%;
        letter-spacing: 0; }

.toparea3 {
  width: 100%;
  background: url("../images/top/csr_bg.jpg") center center no-repeat;
  background-size: cover;
  padding: 55px 0; }
  .toparea3 .top_csrbox {
    width: 1100px;
    background: rgba(255, 255, 255, 0.8);
    margin: 0 auto;
    padding: 50px 0; }
    .toparea3 .top_csrbox p {
      margin-bottom: 30px; }

.toparea4 {
  width: 100%;
  padding: 50px 0 100px 0; }
  .toparea4 h3.bg_title {
    color: #ECF7EF;
    font-size: 180px;
    font-family: din-2014, sans-serif;
    font-weight: 700;
    line-height: 1.0em;
    text-align: center;
    white-space: nowrap; }
  .toparea4 .dl_toprecruitbox {
    width: 1100px;
    margin: -80px auto 0 auto; }
    .toparea4 .dl_toprecruitbox .txtarea {
      display: flex;
      width: 440px;
      gap: 40px;
      flex-wrap: wrap;
      justify-content: inherit;
      align-content: center; }
      .toparea4 .dl_toprecruitbox .txtarea h3.tl_topcate {
        text-align: left;
        margin-bottom: 0; }
      .toparea4 .dl_toprecruitbox .txtarea .toprecruit_list {
        width: 100%; }
        .toparea4 .dl_toprecruitbox .txtarea .toprecruit_list .toprecruit_item {
          width: 100%;
          margin-bottom: 35px;
          padding: 0 58px 45px 84px;
          border-bottom: 1px solid #004637; }
          .toparea4 .dl_toprecruitbox .txtarea .toprecruit_list .toprecruit_item a {
            position: relative;
            display: block;
            width: 100%;
            height: 18px; }
            .toparea4 .dl_toprecruitbox .txtarea .toprecruit_list .toprecruit_item a::after {
              content: '';
              position: absolute;
              top: 5px;
              right: 5px;
              width: 18px;
              height: 18px;
              background: url("../images/common/arrow.png") left top no-repeat;
              background-size: contain;
              transform: rotate(-90deg);
              transition: all 0.3s ease; }
            .toparea4 .dl_toprecruitbox .txtarea .toprecruit_list .toprecruit_item a:hover::after {
              right: 0; }
    .toparea4 .dl_toprecruitbox .photoarea {
      width: 615px; }

.toparea5 {
  width: 100%;
  background-color: #004637;
  padding: 80px 0 100px 0; }
  .toparea5 h3.tl_topcate {
    color: #FFF;
    margin-bottom: 60px; }
  .toparea5 .link_newsmorearea {
    width: 850px;
    margin: 0 auto; }
    .toparea5 .link_newsmorearea a.link_newsmore {
      display: block;
      height: 16px;
      color: #FFF;
      font-size: 16px;
      line-height: 1.0em;
      text-align: right; }

ul.newsbox {
  width: 850px;
  margin: 0 auto 30px auto; }
  ul.newsbox li {
    width: 100%;
    border-bottom: 1px solid #FFF;
    margin-bottom: 40px;
    padding: 0 0 30px 0; }
    ul.newsbox li:last-child {
      margin-bottom: 0; }
    ul.newsbox li a {
      display: flex;
      display: -webkit-flex;
      width: 100%;
      flex-wrap: wrap;
      -webkit-justify-content: space-between;
      justify-content: space-between; }
      ul.newsbox li a p {
        width: 600px;
        color: #FFF;
        line-height: 1.4em;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis; }
      ul.newsbox li a p.i_cate {
        width: 90px;
        height: 25px;
        color: #FFF;
        font-size: 12px;
        line-height: 25px;
        background-color: #53B671;
        border-radius: 12px;
        letter-spacing: 0;
        text-align: center; }
      ul.newsbox li a time {
        display: block;
        width: 85px;
        color: #FFF;
        font-size: 14px;
        font-family: din-2014, sans-serif;
        font-weight: 700;
        line-height: 25px; }

@media screen and (max-width: 767px) {
  .toparea1 {
    width: 100%;
    padding: 40px 0 60px 0; }
    .toparea1 p {
      width: 92%;
      margin: 0 auto 20px auto; }

  .toparea2 {
    position: relative;
    width: 100%;
    height: auto;
    background: url("../images/common/bg_pattern.gif") center center repeat;
    background-size: 249px 254px;
    padding-bottom: 232%;
    overflow: hidden; }
    .toparea2::before {
      width: 100%;
      height: 160px;
      border-style: solid;
      border-width: 160px 100vw 0 0;
      border-color: #ECF7EF transparent transparent transparent;
      z-index: 1; }
    .toparea2 .toparea2_in {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      min-height: 815px;
      padding: 30px 0 0 0;
      z-index: 2; }
    .toparea2 .dl_linkbox {
      width: 92%;
      height: auto;
      margin: 0 auto 60px auto; }
      .toparea2 .dl_linkbox .photoarea {
        width: 100%;
        margin-bottom: 25px; }
      .toparea2 .dl_linkbox .txtarea {
        width: 100%;
        gap: 25px; }
        .toparea2 .dl_linkbox .txtarea h3.tl_topcate {
          width: 100%;
          line-height: 1.0em;
          margin-bottom: 0; }
        .toparea2 .dl_linkbox .txtarea p {
          width: 100%;
          font-size: 14px;
          line-height: 1.4em;
          letter-spacing: 0; }

  .toparea3 {
    width: 100%;
    background: url("../images/top/csr_bg.jpg") center center no-repeat;
    background-size: cover;
    padding: 30px 20px; }
    .toparea3 .top_csrbox {
      width: 100%;
      margin: 0 auto;
      padding: 25px; }
      .toparea3 .top_csrbox h3.tl_topcate {
        margin-bottom: 10px; }
      .toparea3 .top_csrbox p {
        margin-bottom: 30px; }
      .toparea3 .top_csrbox .tx_center {
        line-height: 1.8em;
        letter-spacing: 0;
        text-align: left; }

  .toparea4 {
    width: 100%;
    padding: 70px 0 60px 0; }
    .toparea4 h3.bg_title {
      width: 100%;
      font-size: 80px;
      line-height: 1.0em;
      text-align: center;
      white-space: nowrap; }
    .toparea4 .dl_toprecruitbox {
      width: 100%;
      margin: -40px auto 0 auto; }
      .toparea4 .dl_toprecruitbox .txtarea {
        display: flex;
        width: 92%;
        margin: 0 auto;
        gap: 30px;
        flex-wrap: wrap;
        justify-content: inherit;
        align-content: center; }
        .toparea4 .dl_toprecruitbox .txtarea h3.tl_topcate {
          text-align: left;
          margin-bottom: 0; }
        .toparea4 .dl_toprecruitbox .txtarea .toprecruit_list {
          width: 100%; }
          .toparea4 .dl_toprecruitbox .txtarea .toprecruit_list .toprecruit_item {
            width: 100%;
            margin-bottom: 30px;
            padding: 0 10px 35px 30px;
            border-bottom: 1px solid #004637; }
            .toparea4 .dl_toprecruitbox .txtarea .toprecruit_list .toprecruit_item a {
              position: relative;
              display: block;
              width: 100%;
              height: 18px; }
      .toparea4 .dl_toprecruitbox .photoarea {
        width: 92%;
        margin: 0 auto; }

  .toparea5 {
    width: 100%;
    padding: 30px 0; }
    .toparea5 h3.tl_topcate {
      margin-bottom: 40px; }
    .toparea5 .link_newsmorearea {
      width: 850px;
      margin: 0 auto; }
      .toparea5 .link_newsmorearea a.link_newsmore {
        display: block;
        height: 16px;
        color: #FFF;
        font-size: 16px;
        line-height: 1.0em;
        text-align: right; }

  ul.newsbox {
    width: 92%;
    margin: 0 auto; }
    ul.newsbox li {
      width: 100%;
      border-bottom: 1px solid #FFF;
      margin-bottom: 30px;
      padding: 0 0 20px 0; }
      ul.newsbox li a {
        display: flex;
        display: -webkit-flex;
        width: 100%;
        flex-wrap: wrap;
        -webkit-justify-content: flex-start;
        justify-content: flex-start; }
        ul.newsbox li a p {
          width: 100%;
          color: #FFF;
          line-height: 1.5em;
          white-space: normal;
          overflow: visible;
          text-overflow: visible; }
        ul.newsbox li a p.i_cate {
          width: 90px;
          height: 25px;
          color: #FFF;
          font-size: 12px;
          line-height: 25px;
          background-color: #53B671;
          border-radius: 12px;
          letter-spacing: 0;
          text-align: center;
          margin: 0 20px 10px 0; }
        ul.newsbox li a time {
          display: block;
          width: 85px;
          color: #FFF;
          font-size: 14px;
          font-family: din-2014, sans-serif;
          font-weight: 700;
          line-height: 25px; } }
/* 企業情報
--------------------------------------------------*/
#a1 {
  width: 100%;
  background: url("../images/common/bg_pattern.gif") center center repeat;
  background-size: 249px 254px;
  padding: 100px 0; }
  #a1 .greetingarea {
    width: 850px;
    margin: 0 auto; }
    #a1 .greetingarea .txtarea {
      width: 535px; }
      #a1 .greetingarea .txtarea p {
        line-height: 1.6em;
        letter-spacing: 0; }
    #a1 .greetingarea .photoarea {
      width: 270px; }
      #a1 .greetingarea .photoarea .imgbox {
        margin-bottom: 10px; }
      #a1 .greetingarea .photoarea .tx_name {
        font-size: 20px;
        line-height: 25px;
        letter-spacing: 0;
        text-align: center; }
        #a1 .greetingarea .photoarea .tx_name span {
          font-size: 25px;
          margin-left: 15px; }

#a2 {
  width: 1100px;
  margin: 0 auto;
  padding: 80px 0 100px 0; }
  #a2 .company_profile {
    width: 100%;
    margin: 0 auto 100px auto; }
    #a2 .company_profile .factory_indent {
      display: inline-block;
      width: 175px; }
  #a2 .company_history {
    width: 100%;
    margin: 0 auto 100px auto; }
    #a2 .company_history .year_indent {
      display: inline-block;
      width: 125px; }
  #a2 .img_profilearea {
    width: 100%;
    background: url("../images/aboutus/enkaku.jpg") center center repeat;
    background-size: contain;
    padding-top: 23.7%; }
    #a2 .img_profilearea li {
      display: none; }

#a4 {
  width: 100%;
  background: url("../images/common/bg_pattern.gif") center center repeat;
  background-size: 249px 254px;
  padding: 80px 0 100px 0; }
  #a4 .gmap {
    position: relative;
    width: 850px;
    height: 300px;
    margin: 0 auto; }
    #a4 .gmap iframe {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }

#a5 {
  width: 850px;
  margin: 0 auto;
  padding: 80px 0 100px 0; }
  #a5 .link_list {
    display: flex;
    display: -webkit-flex;
    width: 100%;
    margin: 0 auto;
    flex-wrap: wrap;
    justify-content: space-between;
    -webkit-justify-content: space-between; }
    #a5 .link_list li {
      width: 23.2%; }
      #a5 .link_list li a {
        display: block;
        width: 100%;
        height: 100px;
        font-size: 25px;
        font-family: dnp-shuei-ymincho-std, sans-serif;
        font-weight: 500;
        line-height: 94px;
        background: linear-gradient(0deg, #E1E1E1, #FFF 55%, #FFF);
        border: 3px solid #004637;
        border-radius: 10px;
        text-align: center; }

@media screen and (max-width: 767px) {
  #a1 {
    width: 100%;
    background: url("../images/common/bg_pattern.gif") center center repeat;
    background-size: 249px 254px;
    padding: 60px 0; }
    #a1 .greetingarea {
      width: 92%;
      margin: 0 auto; }
      #a1 .greetingarea .txtarea {
        width: 100%;
        margin-bottom: 30px; }
        #a1 .greetingarea .txtarea p {
          line-height: 1.6em;
          letter-spacing: 0; }
      #a1 .greetingarea .photoarea {
        width: 270px;
        margin: 0 auto; }

  #a2 {
    width: 100%;
    margin: 0 auto;
    padding: 60px 0; }
    #a2 .company_profile {
      width: 100%;
      margin: 0 auto 60px auto; }
      #a2 .company_profile th {
        width: 115px; }
      #a2 .company_profile td {
        width: calc(100% - 115px); }
      #a2 .company_profile .factory_indent {
        display: inline-block;
        width: 150px; }
    #a2 .company_history {
      width: 100%;
      margin: 0 auto 25px auto; }
      #a2 .company_history .year_indent {
        display: block;
        width: 100%; }
    #a2 .img_profilearea {
      width: 92%;
      background: url("../images/aboutus/enkaku.jpg") center center repeat;
      background-size: contain;
      padding-top: 21.8%;
      margin: 0 auto; }

  #a4 {
    width: 100%;
    padding: 30px 0 60px 0; }
    #a4 .gmap {
      position: relative;
      width: 92%;
      height: 250px;
      margin: 0 auto; }

  #a5 {
    width: 92%;
    margin: 0 auto;
    padding: 30px 0 60px 0; }
    #a5 .link_list {
      width: 100%;
      margin: 0 auto; }
      #a5 .link_list li {
        width: 48%; }
        #a5 .link_list li a {
          width: 100%;
          height: 80px;
          font-size: 20px;
          line-height: 74px;
          background: linear-gradient(0deg, #E1E1E1, #FFF 55%, #FFF);
          border: 3px solid #004637;
          border-radius: 10px;
          text-align: center;
          margin-bottom: 7%; } }
/* 設備・施設紹介
--------------------------------------------------*/
#m1 {
  width: 1100px;
  margin: 0 auto;
  padding: 100px 0 0 0; }
  #m1 .machinery_list {
    width: 100%;
    margin-bottom: 70px; }
    #m1 .machinery_list dt, #m1 .machinery_list dd {
      width: 525px;
      margin-bottom: 30px; }
      #m1 .machinery_list dt .imgbox, #m1 .machinery_list dd .imgbox {
        width: 100%;
        background-color: #ECF7EF;
        padding: 20px;
        margin-bottom: 10px; }
      #m1 .machinery_list dt p, #m1 .machinery_list dd p {
        line-height: 1.7em;
        margin-bottom: 15px;
        padding-left: 20px; }

#m2 {
  width: 100%;
  background: url("../images/common/bg_pattern.gif") center center repeat;
  background-size: 249px 254px;
  padding: 100px 0; }
  #m2 p {
    width: 800px;
    margin: 0 auto 30px auto; }

#m3 {
  width: 1100px;
  margin: 0 auto;
  padding: 100px 0 0 0; }
  #m3 .kanagatakozyo_list {
    width: 100%;
    margin: 25px 0 70px 0; }
    #m3 .kanagatakozyo_list dt, #m3 .kanagatakozyo_list dd {
      width: 525px;
      margin-bottom: 30px; }

ul.tab-group {
  display: flex;
  display: -webkit-flex;
  width: 876px;
  margin: 0 auto;
  flex-wrap: wrap;
  -webkit-justify-content: space-between;
  justify-content: space-between; }
  ul.tab-group::after {
    content: "";
    width: 204px; }
  ul.tab-group li {
    width: 204px;
    margin-bottom: 20px;
    cursor: pointer;
    transition: all 0.3s; }
  ul.tab-group li:hover {
    opacity: 0.6; }
  ul.tab-group li.is-active {
    opacity: 0.6; }

ul.panel-group {
  width: 800px;
  margin: 0 auto 50px auto; }
  ul.panel-group li {
    display: none;
    opacity: 0; }
  ul.panel-group li.is-show {
    display: block;
    animation-name: displayAnime;
    animation-duration: 2s;
    animation-fill-mode: forwards; }

@keyframes displayAnime {
  from {
    opacity: 0; }
  to {
    opacity: 1; } }
@media screen and (max-width: 767px) {
  #m1 {
    width: 92%;
    margin: 0 auto;
    padding: 60px 0 0 0; }
    #m1 h3.tl_midashi span {
      display: block; }
    #m1 .machinery_list {
      width: 100%;
      margin-bottom: 20px; }
      #m1 .machinery_list dt, #m1 .machinery_list dd {
        width: 100%;
        margin-bottom: 30px; }
        #m1 .machinery_list dt .imgbox, #m1 .machinery_list dd .imgbox {
          width: 100%;
          padding: 15px;
          margin-bottom: 10px; }
        #m1 .machinery_list dt p, #m1 .machinery_list dd p {
          line-height: 1.7em;
          margin-bottom: 0;
          padding-left: 0; }

  #m2 {
    width: 100%;
    padding: 30px 0 60px 0; }
    #m2 p {
      width: 92%;
      letter-spacing: 0;
      line-height: 1.6em;
      margin: 0 auto 20px auto; }

  #m3 {
    width: 92%;
    margin: 0 auto;
    padding: 30px 0 50px 0; }
    #m3 p.tx_center {
      width: 100%;
      letter-spacing: 0;
      line-height: 1.6em;
      text-align: left;
      margin-bottom: 20px; }
    #m3 .kanagatakozyo_list {
      width: 100%;
      margin: 10px 0 0 0; }
      #m3 .kanagatakozyo_list dt, #m3 .kanagatakozyo_list dd {
        width: 100%;
        margin-bottom: 10px; }

  ul.tab-group {
    width: 92%;
    margin: 0 auto; }
    ul.tab-group::after {
      content: "";
      width: 31%; }
    ul.tab-group li {
      width: 31%;
      margin-bottom: 3.5%; }

  ul.panel-group {
    width: 92%;
    margin: 0 auto 30px auto; } }
/* 製品情報
--------------------------------------------------*/
#p1 {
  width: 100%;
  background: url("../images/common/bg_pattern.gif") center center repeat;
  background-size: 249px 254px;
  margin: 0 auto; }
  #p1 h3.tl_midashi {
    width: 100%;
    background-color: #FFF;
    margin-bottom: 75px;
    padding: 100px 0 0 0; }
    #p1 h3.tl_midashi::after {
      content: "";
      display: block;
      width: 100%;
      background: url("../images/products/titlephoto.jpg") bottom center no-repeat;
      background-size: contain;
      margin-top: 40px;
      padding-top: 24%; }
  #p1 .product_list {
    display: flex;
    display: -webkit-flex;
    width: 1100px;
    margin: 0 auto;
    padding-bottom: 70px;
    flex-wrap: wrap;
    -webkit-justify-content: space-between;
    justify-content: space-between; }
    #p1 .product_list::after {
      content: "";
      width: 333px; }
    #p1 .product_list li {
      width: 333px;
      background-color: #FFF;
      margin-bottom: 30px;
      padding: 20px; }
      #p1 .product_list li h4 {
        font-size: 25px;
        line-height: 1.4em;
        margin-bottom: 15px; }
        #p1 .product_list li h4 span {
          display: block;
          font-size: 70px;
          font-family: din-2014, sans-serif;
          font-weight: 700;
          line-height: 1em;
          margin-bottom: 5px; }

#p2 {
  width: 1100px;
  margin: 0 auto;
  padding: 100px 0; }
  #p2 h3.tx_center {
    margin-bottom: 60px; }
  #p2 .technology_list {
    width: 100%;
    margin-bottom: 70px; }
    #p2 .technology_list dt {
      width: 430px; }
      #p2 .technology_list dt .imgbox {
        width: 100%;
        margin-bottom: 20px; }
    #p2 .technology_list dd {
      width: 620px; }
      #p2 .technology_list dd h3 {
        margin-bottom: 15px; }
      #p2 .technology_list dd p {
        letter-spacing: 0; }
  #p2 .cadbox h3 {
    margin-bottom: 15px; }
  #p2 .cadbox p {
    letter-spacing: 0; }
  #p2 .cadcam_list {
    margin-top: 20px; }
    #p2 .cadcam_list dt img, #p2 .cadcam_list dd img {
      height: 175px; }

@media screen and (max-width: 767px) {
  #p1 {
    width: 100%;
    margin: 0 auto; }
    #p1 h3.tl_midashi {
      width: 100%;
      margin-bottom: 30px;
      padding: 60px 0 0 0; }
      #p1 h3.tl_midashi::after {
        content: "";
        display: block;
        width: 100%;
        background: url("../images/products/titlephoto.jpg") bottom center no-repeat;
        background-size: contain;
        margin-top: 20px;
        padding-top: 24%; }
    #p1 .product_list {
      width: 92%;
      margin: 0 auto;
      padding-bottom: 40px; }
      #p1 .product_list::after {
        content: "";
        width: 48.5%; }
      #p1 .product_list li {
        width: 48.5%;
        margin-bottom: 3%;
        padding: 15px; }
        #p1 .product_list li h4 {
          min-height: 100px;
          font-size: 18px;
          line-height: 1.4em;
          margin-bottom: 15px; }
          #p1 .product_list li h4 span {
            font-size: 50px;
            line-height: 1em;
            margin-bottom: 5px; }

  #p2 {
    width: 92%;
    margin: 0 auto;
    padding: 30px 0 60px 0; }
    #p2 h3.tx_center {
      margin-bottom: 30px; }
    #p2 .technology_list {
      width: 100%;
      margin-bottom: 40px; }
      #p2 .technology_list dt {
        width: 100%; }
        #p2 .technology_list dt .imgbox {
          width: 100%;
          margin-bottom: 10px; }
      #p2 .technology_list dd {
        width: 100%;
        margin-bottom: 20px; }
        #p2 .technology_list dd h3 {
          margin-bottom: 15px; }
        #p2 .technology_list dd p {
          line-height: 1.6em;
          letter-spacing: 0; }
    #p2 .cadbox h3 {
      margin-bottom: 15px; }
    #p2 .cadbox p {
      line-height: 1.6em;
      letter-spacing: 0; }
    #p2 .cadcam_list {
      margin-top: 15px; }
      #p2 .cadcam_list dt img, #p2 .cadcam_list dd img {
        height: auto;
        margin-bottom: 10px; } }
/* CSR
--------------------------------------------------*/
.carea1 {
  width: 100%;
  margin: 0 auto;
  padding: 28% 0 50px 0;
  background: url("../images/csr/titlephoto.jpg") left top no-repeat;
  background-size: contain; }
  .carea1 h4.stl_bggra {
    width: 1100px;
    margin: 0 auto 30px auto; }

.link_pdf {
  width: 100%;
  height: 35px;
  font-size: 25px;
  line-height: 35px;
  margin-top: 20px; }
  .link_pdf a {
    display: inline-block;
    background: url("../images/common/icon_pdf.png") left top no-repeat;
    background-size: 30px 35px;
    padding-left: 50px; }

.carea2 {
  width: 1100px;
  margin: 0 auto;
  padding: 0 0 50px 0; }
  .carea2 p {
    letter-spacing: 0;
    margin-bottom: 25px; }

.carea3 {
  width: 1100px;
  margin: 0 auto;
  padding: 0 0 50px 0; }

dl.pdfimg {
  width: 400px;
  height: 396px;
  margin: 0 auto 25px auto;
  align-items: end; }
  dl.pdfimg dt {
    width: 280px;
    height: 396px;
    border: 1px solid #000; }
  dl.pdfimg dd {
    width: 90px;
    height: 112px; }

.carea4 {
  width: 1100px;
  margin: 0 auto;
  padding: 0 0 100px 0; }
  .carea4 .link_pdf {
    margin-bottom: 60px; }

@media screen and (max-width: 767px) {
  .carea1 {
    width: 100%;
    margin: 0 auto;
    padding: 32% 0 50px 0;
    background: url("../images/csr/titlephoto.jpg") left top no-repeat;
    background-size: contain; }
    .carea1 h4.stl_bggra {
      width: 92%;
      margin: 0 auto 30px auto; }
    .carea1 p {
      line-height: 1.6em;
      letter-spacing: 0; }
    .carea1 p.link_pdf {
      line-height: 25px; }

  .link_pdf {
    width: 100%;
    height: 25px;
    font-size: 18px;
    line-height: 25px;
    margin-top: 15px; }
    .link_pdf a {
      display: inline-block;
      background: url("../images/common/icon_pdf.png") left top no-repeat;
      background-size: 20px 25px;
      padding-left: 35px; }

  .carea2 {
    width: 92%;
    margin: 0 auto;
    padding: 0 0 50px 0; }
    .carea2 .marea {
      width: 100%; }
    .carea2 p {
      line-height: 1.6em;
      letter-spacing: 0;
      margin-bottom: 25px; }
    .carea2 li {
      letter-spacing: 0; }

  .carea3 {
    width: 92%;
    margin: 0 auto;
    padding: 0 0 50px 0; }
    .carea3 .marea {
      width: 100%; }

  dl.pdfimg {
    width: 100%;
    height: auto;
    margin: 0 auto 20px auto;
    align-items: end; }
    dl.pdfimg dt {
      width: 70%;
      height: auto;
      border: 1px solid #000; }
    dl.pdfimg dd {
      width: 25%;
      height: auto; }

  .carea4 {
    width: 92%;
    margin: 0 auto;
    padding: 0 0 60px 0; }
    .carea4 .marea {
      width: 100%; }
    .carea4 .link_pdf {
      margin-bottom: 50px; }
    .carea4 .year_indent {
      display: block;
      margin-top: 10px; }
    .carea4 .year_indent:first-child {
      margin-top: 0; } }
/* お知らせ
--------------------------------------------------*/
.n_listarea1 {
  width: 100%;
  margin: 0 auto;
  padding: 100px 0; }

.n_listarea1 ul.newsbox {
  margin: 0 auto 30px auto; }
  .n_listarea1 ul.newsbox li {
    border-bottom: 1px solid #004637; }
    .n_listarea1 ul.newsbox li a p {
      color: #000; }
    .n_listarea1 ul.newsbox li a p.i_cate {
      color: #FFF; }
    .n_listarea1 ul.newsbox li a time {
      color: #000; }

.n_detailarea1 {
  width: 850px;
  margin: 0 auto;
  padding: 100px 0; }
  .n_detailarea1 .n_detailbox {
    width: 100%; }
    .n_detailarea1 .n_detailbox .n_date {
      width: 100%;
      border-bottom: 1px solid #004637;
      margin-bottom: 30px;
      padding-bottom: 15px; }
      .n_detailarea1 .n_detailbox .n_date .n_datebox {
        display: flex;
        display: -webkit-flex;
        width: 190px;
        margin-bottom: 15px;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
        -webkit-justify-content: space-between; }
        .n_detailarea1 .n_detailbox .n_date .n_datebox p.i_cate {
          width: 90px;
          height: 25px;
          color: #FFF;
          font-size: 12px;
          line-height: 25px;
          background-color: #53B671;
          border-radius: 12px;
          letter-spacing: 0;
          text-align: center; }
        .n_detailarea1 .n_detailbox .n_date .n_datebox time {
          display: block;
          width: 75px;
          color: #000;
          font-size: 14px;
          font-family: din-2014, sans-serif;
          font-weight: 700;
          line-height: 25px; }
      .n_detailarea1 .n_detailbox .n_date h1 {
        width: 100%;
        font-size: 18px;
        line-height: 1.4em;
        letter-spacing: 0; }
    .n_detailarea1 .n_detailbox p.tx_info {
      width: 100%;
      margin-bottom: 30px; }
    .n_detailarea1 .n_detailbox .imgbox {
      width: 100%;
      margin-bottom: 30px; }
      .n_detailarea1 .n_detailbox .imgbox.p_large {
        width: auto;
        max-width: 100%; }
      .n_detailarea1 .n_detailbox .imgbox.p_medium {
        width: auto;
        max-width: 500px; }
      .n_detailarea1 .n_detailbox .imgbox.p_small {
        width: auto;
        max-width: 350px; }
    .n_detailarea1 .n_detailbox ul.linkarea, .n_detailarea1 .n_detailbox ul.downloadarea {
      width: 100%;
      margin: 0 auto 30px auto; }
      .n_detailarea1 .n_detailbox ul.linkarea li a, .n_detailarea1 .n_detailbox ul.downloadarea li a {
        display: block;
        font-size: 16px;
        line-height: 1.4em;
        text-decoration: underline; }
    .n_detailarea1 .n_detailbox a.btn {
      margin: 60px auto 0 auto; }

/* ページネーション */
ul.page-numbers {
  display: flex;
  display: -webkit-flex;
  width: 400px;
  height: 25px;
  margin: 0 auto;
  flex-wrap: wrap;
  justify-content: center; }

ul.page-numbers li {
  color: #000;
  margin-right: 5px;
  line-height: 25px; }

ul.page-numbers li.dot {
  line-height: 36px; }

ul.page-numbers li:last-child {
  margin-right: 0; }

ul.page-numbers li a {
  display: block;
  width: 25px;
  height: 25px;
  color: #000;
  font-size: 20px;
  line-height: 25px;
  text-align: center;
  transition: all 0.3s ease-out; }

ul.page-numbers li a:hover {
  text-decoration: underline; }

ul.page-numbers li .current {
  color: #004637;
  font-weight: 700;
  font-size: 20px;
  margin-right: 5px;
  margin-left: 5px;
  text-decoration: underline; }

@media screen and (max-width: 767px) {
  .n_listarea1 {
    width: 100%;
    margin: 0 auto;
    padding: 60px 0; }

  .n_listarea1 ul.newsbox {
    margin: 0 auto 30px auto; }

  .n_detailarea1 {
    width: 92%;
    margin: 0 auto;
    padding: 60px 0; }
    .n_detailarea1 .n_detailbox {
      width: 100%; }
      .n_detailarea1 .n_detailbox .n_date {
        width: 100%;
        border-bottom: 1px solid #004637;
        margin-bottom: 20px;
        padding-bottom: 15px; }
        .n_detailarea1 .n_detailbox .n_date .n_datebox {
          display: flex;
          display: -webkit-flex;
          width: 190px;
          margin-bottom: 15px;
          flex-wrap: wrap;
          align-items: center;
          justify-content: space-between;
          -webkit-justify-content: space-between; }
        .n_detailarea1 .n_detailbox .n_date h1 {
          width: 100%;
          font-size: 17px;
          line-height: 1.6em;
          letter-spacing: 0; }
      .n_detailarea1 .n_detailbox p.tx_info {
        width: 100%;
        margin-bottom: 20px; }
      .n_detailarea1 .n_detailbox .imgbox {
        width: 100%;
        margin-bottom: 20px; }
        .n_detailarea1 .n_detailbox .imgbox.p_large {
          width: auto;
          max-width: 100%; }
        .n_detailarea1 .n_detailbox .imgbox.p_medium {
          width: auto;
          max-width: 100%; }
        .n_detailarea1 .n_detailbox .imgbox.p_small {
          width: auto;
          max-width: 100%; }
      .n_detailarea1 .n_detailbox ul.linkarea, .n_detailarea1 .n_detailbox ul.downloadarea {
        width: 100%;
        margin: 0 auto 20px auto; }
        .n_detailarea1 .n_detailbox ul.linkarea li a, .n_detailarea1 .n_detailbox ul.downloadarea li a {
          display: block;
          font-size: 14px;
          line-height: 1.4em;
          text-decoration: underline; }
      .n_detailarea1 .n_detailbox a.btn {
        margin: 30px auto 0 auto; }

  /* ページネーション */
  ul.page-numbers {
    display: flex;
    display: -webkit-flex;
    width: 300px;
    height: 20px;
    margin: 0 auto;
    flex-wrap: wrap;
    justify-content: center; }

  ul.page-numbers li {
    margin-right: 5px;
    line-height: 25px; }

  ul.page-numbers li.dot {
    line-height: 20px; }

  ul.page-numbers li:last-child {
    margin-right: 0; }

  ul.page-numbers li a {
    display: block;
    width: 20px;
    height: 20px;
    font-size: 18px;
    line-height: 20px;
    text-align: center;
    transition: all 0.3s ease-out; } }
/* 採用情報
--------------------------------------------------*/
.rarea1 {
  width: 1100px;
  margin: 0 auto;
  padding: 100px 0; }
  .rarea1 .r_dl_area1 {
    width: 100%; }
    .rarea1 .r_dl_area1 dt {
      width: 440px; }
    .rarea1 .r_dl_area1 dd {
      width: 610px; }
    .rarea1 .r_dl_area1 p {
      letter-spacing: 0; }

.rarea2 {
  width: 100%;
  margin: 0 auto; }
  .rarea2 h3.tl_rmessage {
    width: 100%;
    margin-bottom: 50px; }
    .rarea2 h3.tl_rmessage .eng {
      display: block;
      width: 1100px;
      height: 80px;
      color: #0071BC;
      font-size: 100px;
      font-family: din-2014, sans-serif;
      font-weight: 700;
      line-height: 1.0em;
      text-align: right;
      margin: 0 auto; }
    .rarea2 h3.tl_rmessage .maintitle {
      display: block;
      width: 100%;
      height: 80px;
      background-color: #0071BC; }
      .rarea2 h3.tl_rmessage .maintitle .tl_margin {
        display: block;
        width: 1100px;
        color: #FFF;
        font-size: 40px;
        font-family: dnp-shuei-ymincho-std, sans-serif;
        font-weight: 500;
        line-height: 80px;
        margin: 0 auto; }
  .rarea2 .rmessage_titlearea {
    display: block;
    position: relative;
    width: 850px;
    height: 425px;
    margin: 0 auto 50px auto; }
    .rarea2 .rmessage_titlearea .rmessage_title {
      position: absolute;
      top: 160px;
      left: 0;
      width: 315px;
      height: 215px;
      background: linear-gradient(90deg, #53B671, #0071BC);
      background: -webkit-linear-gradient(0, #53B671, #0071BC);
      padding: 25px;
      z-index: 2; }
      .rarea2 .rmessage_titlearea .rmessage_title h4 {
        color: #FFF;
        font-size: 25px;
        line-height: 1.4em; }
        .rarea2 .rmessage_titlearea .rmessage_title h4 .number {
          display: block;
          font-size: 70px;
          font-family: din-2014, sans-serif;
          font-weight: 700;
          line-height: 1.0em;
          margin-bottom: 15px; }
        .rarea2 .rmessage_titlearea .rmessage_title h4 .year {
          font-size: 20px;
          line-height: 1.4em; }
    .rarea2 .rmessage_titlearea .imgarea {
      position: absolute;
      top: 0;
      right: 0;
      width: 625px;
      height: 425px;
      z-index: 1; }

.rarea3 {
  width: 100%;
  height: 468px;
  background: url("../images/recruit/recruit_bg.jpg") center center no-repeat;
  background-size: cover;
  margin: 0 auto;
  padding: 100px 0; }
  .rarea3 h3, .rarea3 p {
    color: #FFF; }
  .rarea3 h3 {
    margin-bottom: 10px; }
  .rarea3 p {
    margin-bottom: 45px; }
  .rarea3 dl {
    width: 1000px;
    margin: 0 auto; }
    .rarea3 dl dt, .rarea3 dl dd {
      width: 475px; }
      .rarea3 dl dt a, .rarea3 dl dd a {
        display: block;
        width: 100%;
        height: 130px;
        color: #FFF;
        font-size: 40px;
        font-family: dnp-shuei-ymincho-std, sans-serif;
        font-weight: 500;
        line-height: 130px;
        background-color: #0071BC;
        text-align: center; }

.rarea4 {
  width: 100%;
  margin: 0 auto;
  padding: 100px 0 0 0; }
  .rarea4 h3.tx_center {
    width: 100%;
    padding: 0 0 26% 0;
    background: url("../images/recruit/titlephoto.jpg") bottom center no-repeat;
    background-size: contain;
    margin-bottom: 60px; }
  .rarea4 .ttype1 th {
    background-color: #0071BC; }
  .rarea4 .ttype1 td {
    background-color: #FAFAFA; }
  .rarea4 .recruit_info {
    margin-bottom: 100px; }
    .rarea4 .recruit_info th {
      width: 230px; }
    .rarea4 .recruit_info td {
      width: calc(100% - 230px); }

.qa_list {
  width: 100%;
  margin-bottom: 100px; }

.qa_accordion_item {
  margin-bottom: 30px; }
  .qa_accordion_item .qa_accordion_btn {
    display: flex;
    width: 100%;
    height: auto;
    padding: 16px 30px 16px 25px;
    background-color: #ECF7EF;
    text-align: left;
    cursor: pointer;
    align-items: center;
    justify-content: space-between;
    -webkit-appearance: none;
    appearance: none; }
  .qa_accordion_item .qa_question {
    flex: 1;
    margin: 0; }
    .qa_accordion_item .qa_question p {
      margin: 0;
      color: #000;
      font-size: 20px;
      font-family: dnp-shuei-ymincho-std, sans-serif;
      font-weight: 400;
      line-height: 1.5; }
  .qa_accordion_item .qa_answer {
    height: 0;
    overflow: hidden;
    transition: all 0.3s ease;
    padding: 0 20px; }
    .qa_accordion_item .qa_answer p {
      line-height: 1.7; }
  .qa_accordion_item.is_open .qa_answer {
    height: 150px;
    padding: 20px; }
  .qa_accordion_item .accordion_icon {
    display: inline-block;
    width: 20px;
    height: 20px;
    border-right: 2px solid #000;
    border-bottom: 2px solid #000;
    transform: rotate(45deg);
    transition: transform 0.25s ease;
    flex-shrink: 0; }
  .qa_accordion_item.is_open .accordion_icon {
    transform: rotate(-135deg); }

@media screen and (max-width: 767px) {
  .rarea1 {
    width: 92%;
    margin: 0 auto;
    padding: 60px 0; }
    .rarea1 .r_dl_area1 {
      width: 100%; }
      .rarea1 .r_dl_area1 dt, .rarea1 .r_dl_area1 dd {
        width: 100%; }
      .rarea1 .r_dl_area1 dt {
        margin-bottom: 20px; }
      .rarea1 .r_dl_area1 p {
        letter-spacing: 0; }

  .rarea2 {
    width: 100%;
    margin: 0 auto; }
    .rarea2 h3.tl_rmessage {
      width: 100%;
      margin-bottom: 30px; }
      .rarea2 h3.tl_rmessage .eng {
        width: 98%;
        height: 55px;
        color: #0071BC;
        font-size: 70px;
        line-height: 1.0em;
        margin: 0 auto; }
      .rarea2 h3.tl_rmessage .maintitle {
        width: 100%;
        height: 80px; }
        .rarea2 h3.tl_rmessage .maintitle .tl_margin {
          width: 92%;
          font-size: 22px;
          line-height: 80px;
          margin: 0 auto; }
    .rarea2 .rmessage_titlearea {
      display: block;
      position: relative;
      width: 100%;
      height: 400px;
      margin: 0 auto 30px auto; }
      .rarea2 .rmessage_titlearea .rmessage_title {
        position: absolute;
        top: inherit;
        bottom: 0;
        left: 50%;
        width: 252px;
        height: 172px;
        padding: 20px;
        transform: translateX(-50%);
        z-index: 2; }
        .rarea2 .rmessage_titlearea .rmessage_title h4 {
          font-size: 20px;
          line-height: 1.4em; }
          .rarea2 .rmessage_titlearea .rmessage_title h4 .number {
            font-size: 56px;
            margin-bottom: 15px; }
          .rarea2 .rmessage_titlearea .rmessage_title h4 .year {
            font-size: 16px;
            line-height: 1.4em; }
      .rarea2 .rmessage_titlearea .imgarea {
        position: absolute;
        top: 0;
        right: 0;
        width: 100%;
        height: 245px;
        z-index: 1; }
        .rarea2 .rmessage_titlearea .imgarea img {
          position: absolute;
          top: 0;
          left: 0;
          width: 100%;
          height: 100%;
          object-fit: cover;
          font-family: 'object-fit:cover';
          object-position: top center; }

  .rarea3 {
    width: 100%;
    height: auto;
    background: url("../images/recruit/recruit_bg.jpg") center center no-repeat;
    background-size: cover;
    margin: 0 auto;
    padding: 30px 0; }
    .rarea3 h3 {
      margin-bottom: 10px; }
    .rarea3 p {
      width: 92%;
      margin: 0 auto 20px auto; }
    .rarea3 dl {
      width: 92%;
      margin: 0 auto; }
      .rarea3 dl dt, .rarea3 dl dd {
        width: 100%; }
        .rarea3 dl dt a, .rarea3 dl dd a {
          display: block;
          width: 100%;
          height: 90px;
          font-size: 22px;
          line-height: 90px; }
      .rarea3 dl dt {
        margin-bottom: 15px; }

  .rarea4 {
    width: 100%;
    margin: 0 auto;
    padding: 60px 0 0 0; }
    .rarea4 h3.tx_center {
      width: 100%;
      padding: 0 0 26% 0;
      background: url("../images/recruit/titlephoto.jpg") bottom center no-repeat;
      background-size: contain;
      margin-bottom: 30px; }
    .rarea4 .recruit_info {
      margin-bottom: 50px; }
      .rarea4 .recruit_info th {
        width: 90px; }
      .rarea4 .recruit_info td {
        width: calc(100% - 90px); }

  .qa_list {
    width: 100%;
    margin-bottom: 100px; }

  .qa_accordion_item {
    margin-bottom: 30px; }
    .qa_accordion_item .qa_accordion_btn {
      width: 100%;
      padding: 16px 30px 16px 25px; }
    .qa_accordion_item .qa_question {
      flex: 1;
      margin: 0; }
      .qa_accordion_item .qa_question p {
        margin: 0;
        font-size: 18px;
        line-height: 1.5em;
        text-indent: -1.2em;
        padding-left: 1.2em;
        padding-right: 20px; }
    .qa_accordion_item .qa_answer {
      padding: 0 2%; }
      .qa_accordion_item .qa_answer p {
        line-height: 1.6em; }
    .qa_accordion_item.is_open .qa_answer {
      height: auto;
      min-height: 100px;
      padding: 15px 2%; }
    .qa_accordion_item .accordion_icon {
      display: inline-block;
      width: 12px;
      height: 12px;
      border-right: 2px solid #000;
      border-bottom: 2px solid #000;
      transform: rotate(45deg);
      transition: transform 0.25s ease;
      flex-shrink: 0; } }
/* contact
--------------------------------------------------*/
.contactarea1 {
  width: 850px;
  margin: 0 auto;
  padding: 70px 0; }

dl.formarea {
  width: 100%;
  margin: 70px auto 20px auto; }
  dl.formarea dt {
    width: 258px;
    padding-top: 10px; }
  dl.formarea dd {
    width: 592px;
    margin-bottom: 10px; }
  dl.formarea label {
    display: block;
    font-size: 18px;
    line-height: 20px; }
    dl.formarea label span {
      display: inline-block;
      width: 45px;
      height: 20px;
      color: #FFF;
      font-size: 13px;
      line-height: 20px;
      background-color: #D44455;
      border-radius: 10px;
      margin-left: 10px;
      text-align: center; }
  dl.formarea p.formitem1 {
    width: 100%;
    margin: 0 0 30px 0; }
  dl.formarea p.formitem2 {
    width: 100%;
    margin: 0 0 30px 0; }
  dl.formarea .text1 {
    width: 100%;
    height: 50px;
    font-size: 16px;
    line-height: 1.6em;
    border: 1px solid #B3B3B3;
    background-color: #FFF;
    padding: 15px; }
  dl.formarea .text2 {
    width: 50%;
    height: 50px;
    font-size: 16px;
    line-height: 1.6em;
    border: 1px solid #B3B3B3;
    background-color: #FFF;
    padding: 15px; }
  dl.formarea .text3 {
    width: 80%;
    height: 50px;
    font-size: 16px;
    line-height: 1.6em;
    border: 1px solid #B3B3B3;
    background-color: #FFF;
    padding: 15px 10px; }
  dl.formarea .text4 {
    width: 50px;
    height: 50px;
    font-size: 16px;
    line-height: 1.6em;
    border: 1px solid #B3B3B3;
    background-color: #FFF;
    margin: 0 5px 0 10px;
    padding: 15px 10px; }
  dl.formarea .textarea1 {
    width: 100%;
    height: 200px;
    font-size: 16px;
    line-height: 1.6em;
    border: 1px solid #B3B3B3;
    background-color: #FFF;
    padding: 15px; }
  dl.formarea ul.radioarea .wpcf7-radio {
    width: 100%;
    display: flex;
    flex-direction: column;
    margin-bottom: 40px; }
    dl.formarea ul.radioarea .wpcf7-radio .wpcf7-list-item {
      margin: 0 0 10px 0;
      text-indent: -1.0em;
      padding-left: 1.0em;
      vertical-align: bottom; }

.privacybox {
  width: 800px;
  height: 300px;
  background-color: #FAFAFA;
  margin: 0 auto 50px auto;
  padding: 30px;
  overflow: scroll; }
  .privacybox p {
    line-height: 1.4em;
    margin-bottom: 20px; }
  .privacybox h3 {
    font-weight: 700;
    text-align: center;
    margin-bottom: 25px; }
  .privacybox h4 {
    font-weight: 700;
    margin-bottom: 5px; }
  .privacybox ul.privacylist, .privacybox ol {
    width: 100%;
    margin-bottom: 20px; }
    .privacybox ul.privacylist li, .privacybox ol li {
      padding-left: 1.5em;
      text-indent: -1.5em; }

p.checkbox {
  width: 350px;
  height: 50px;
  font-size: 16px;
  line-height: 50px;
  text-align: center;
  background-color: #E6E6E6;
  margin: 0 auto 50px auto; }
  p.checkbox .check1 input[type=checkbox] {
    width: 16px;
    height: 16px;
    font-size: 16px;
    line-height: 1.0em;
    border: 1px solid #000; }

@media screen and (max-width: 767px) {
  .contactarea1 {
    width: 92%;
    margin: 0 auto;
    padding: 60px 0; }

  dl.formarea {
    width: 100%;
    margin: 30px auto 20px auto; }
    dl.formarea dt {
      width: 100%;
      padding-top: 0;
      margin-bottom: 10px; }
    dl.formarea dd {
      width: 100%;
      margin-bottom: 30px; }
    dl.formarea p.formitem1 {
      width: 100%;
      margin: 0; }
    dl.formarea p.formitem2 {
      width: 100%;
      margin: 0; }
    dl.formarea ul.radioarea .wpcf7-radio {
      width: 100%;
      display: flex;
      flex-direction: column;
      margin: 10px 0;
      padding-left: 1.0em; }
      dl.formarea ul.radioarea .wpcf7-radio .wpcf7-list-item {
        margin: 0 0 10px 0;
        font-size: 16px;
        line-height: 1.6em;
        text-indent: -1.0em;
        padding-left: 1.0em;
        vertical-align: bottom; }

  .privacybox {
    width: 100%;
    height: 300px;
    background-color: #FAFAFA;
    margin: 0 auto 30px auto;
    padding: 20px;
    overflow: scroll; }
    .privacybox p {
      line-height: 1.4em;
      margin-bottom: 20px; }
    .privacybox h3 {
      font-weight: 700;
      text-align: center;
      margin-bottom: 25px; }
    .privacybox h4 {
      font-weight: 700;
      margin-bottom: 5px; }
    .privacybox ul.privacylist, .privacybox ol {
      width: 100%;
      margin-bottom: 20px; }
      .privacybox ul.privacylist li, .privacybox ol li {
        padding-left: 1.5em;
        text-indent: -1.5em; }

  p.checkbox {
    width: 100%;
    height: 50px;
    font-size: 16px;
    line-height: 50px;
    margin: 0 auto 50px auto; }
    p.checkbox .check1 {
      width: 16px;
      height: 16px;
      font-size: 16px;
      line-height: 1.0em;
      border: 1px solid #000; } }
/* スクロールトリガー
--------------------------------------------------*/
.visible, .invisible {
  opacity: 0.0;
  transition: opacity 0.5s ease; }

.visible {
  opacity: 1.0; }

.visible.translateY, .invisible.translateY {
  transform: translateY(100px);
  transition: all 1s cubic-bezier(0.165, 0.5, 0.44, 1); }

.visible.translateY {
  transform: translateY(0); }

.visible.translateToLeft, .invisible.translateToLeft {
  transform: translateX(100px);
  transition: all 1s cubic-bezier(0.165, 0.5, 0.44, 1); }

.visible.translateToLeft {
  transform: translateX(0); }

.visible.translateToRight, .invisible.translateToRight {
  transform: translateX(-100px);
  transition: all 1s cubic-bezier(0.165, 0.5, 0.44, 1); }

.visible.translateToRight {
  transform: translateX(0); }

@media screen and (max-width: 767px) {
  .photoarea_r .visible.translateToLeft, .invisible.translateToLeft {
    transform: translateX(50px); }

  .photoarea_r .visible.translateToLeft {
    transform: translateX(-50%); }

  .photoarea_r .visible.translateToRight, .invisible.translateToRight {
    transform: translateX(-50px); }

  .photoarea_r .visible.translateToRight {
    transform: translateX(-50%); }

  .photoarea_l .visible.translateToLeft, .invisible.translateToLeft {
    transform: translateX(50px); }

  .photoarea_l .visible.translateToLeft {
    transform: translateX(-50%); }

  .photoarea_l .visible.translateToRight, .invisible.translateToRight {
    transform: translateX(-50px); }

  .photoarea_l .visible.translateToRight {
    transform: translateX(-50%); } }
