@charset "UTF-8";
@import url("base.css");
/*共通設定-------------------------------------------------------------------------------------------------------------------------------------*/
/*基本設定*/
/*ヘッダー*/
/*メイン*/
#m_top {
  width: 100%;
  position: relative; }
  #m_top h1 {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    font-size: 250%;
    color: #fff;
    text-shadow: 0px 0px 10px black; }

#business {
  width: 90%;
  margin: 5em auto 0; }
  #business .t_text {
    text-align: center; }
  #business ul {
    width: 100%;
    margin: 2em auto 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between; }
    #business ul li {
      position: relative;
      overflow: hidden;
      width: 25%;
      min-height: 15em; }
      #business ul li::after {
        position: absolute;
        content: "";
        display: block;
        width: 100%;
        height: 100%;
        top: 0;
        -webkit-background-size: cover;
        -moz-background-size: cover;
        -ms-background-size: cover;
        background-size: cover;
        -webkit-transition: all .3s ease-out;
        -moz-transition: all .3s ease-out;
        -ms-transition: all .3s ease-out;
        transition: all .3s ease-out;
        z-index: -1; }
      #business ul li:nth-child(1)::after {
        background: url("../img/business/photo01.png") no-repeat center center;
        background-size: 100% auto; }
      #business ul li:nth-child(2)::after {
        background: url("../img/business/photo02.png") no-repeat center center;
        background-size: 100% auto; }
      #business ul li:nth-child(3)::after {
        background: url("../img/business/photo03.png") no-repeat center center;
        background-size: 100% auto; }
      #business ul li:nth-child(4)::after {
        background: url("../img/business/photo04.png") no-repeat center center;
        background-size: 100% auto; }
      #business ul li a {
        color: #fff;
        text-decoration: none; }
      #business ul li:hover:after {
        opacity: .8;
        -moz-transform: scale(1.1);
        -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
        transform: scale(1.1); }
      #business ul li .name {
        position: absolute;
        top: 40%;
        left: 50%;
        transform: translate(-40%, -50%);
        -webkit-transform: translate(-40%, -50%);
        -ms-transform: translate(-40%, -50%); }
        #business ul li .name p {
          font-family: "Sawarabi Mincho", serif;
          font-size: 156%;
          text-align: center;
          writing-mode: vertical-rl;
          text-orientation: upright; }
        #business ul li .name div {
          margin: 0.5em 0 0; }
          #business ul li .name div i {
            margin: 0 5px 0 0;
            vertical-align: middle; }
      #business ul li dl {
        position: absolute;
        bottom: 2em;
        color: #fff;
        padding: 0 3%;
        width: 94%;
        min-height: 7em;
        text-align: right; }
        #business ul li dl dt {
          font-size: 156%;
          font-weight: bold;
          border-bottom: 5px solid #2eb6aa; }
          #business ul li dl dt span {
            display: block;
            font-weight: normal;
            font-size: 50%; }
        #business ul li dl dd {
          color: #fff;
          text-decoration: none;
          text-align: right;
          font-size: 75%;
          margin: 0.5em 0 0; }
          #business ul li dl dd i {
            vertical-align: middle;
            margin: 0 5px 0 0; }

#manufacturing {
  width: 80%;
  margin: 5em auto 0; }
  #manufacturing h2 {
    font-size: 250%;
    color: #182d7b;
    text-align: center;
    margin: 0 0 1em; }
  #manufacturing ol li {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    position: relative;
    border: 1px solid #c6c7c8;
    width: 96%;
    padding: 2em 2%; }
    #manufacturing ol li:nth-child(n+2) {
      margin: 7em 0 0; }
    #manufacturing ol li::after {
      content: '';
      /*何も入れない*/
      display: inline-block;
      width: 96px;
      /*画像の幅*/
      height: 37px;
      /*画像の高さ*/
      background-image: url(../img/business/ya.png);
      background-size: contain;
      vertical-align: middle;
      background-repeat: no-repeat;
      position: absolute;
      bottom: -5em;
      left: 50%;
      transform: translateX(-50%);
      -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%); }
    #manufacturing ol li:last-child::after {
      display: none; }
    #manufacturing ol li div {
      width: 58%; }
      #manufacturing ol li div h3 {
        background-color: #2eb6aa;
        color: #fff;
        font-size: 156%;
        margin: 0 0 0.5em;
        padding: 0.25em 2%; }
    #manufacturing ol li figure {
      width: 38%; }

#bottom {
  width: 100%;
  margin: 5em 0 0; }
  #bottom h2 {
    position: relative;
    width: 96%;
    padding: 3em 2%;
    text-align: center;
    color: #fff;
    font-size: 156%;
    background-color: #363636; }
    #bottom h2 span {
      color: #6db5a9;
      font-size: 156%;
      vertical-align: middle; }
    #bottom h2::before {
      content: "";
      position: absolute;
      top: 100%;
      left: 50%;
      margin-left: -40px;
      border: 40px solid transparent;
      border-top: 40px solid #363636; }
  #bottom dl {
    width: 96%;
    padding: 3em 2%;
    background-color: #6db5a9; }
    #bottom dl dt {
      width: 50%;
      margin: 0 auto 1em; }
    #bottom dl dd {
      text-align: center; }
      #bottom dl dd i {
        vertical-align: middle;
        font-size: 187%;
        margin: 0 5px 0 0;
        color: #6db5a9; }
      #bottom dl dd a {
        width: 400px;
        margin: 2em auto 0;
        display: block;
        background-color: #fff;
        color: #363636;
        font-weight: bold;
        text-decoration: none;
        padding: 0.5em 2%;
        border-radius: 20px;
        -webkit-transition: all 0.3s ease;
        -moz-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all  0.3s ease; }
        #bottom dl dd a:hover, #bottom dl dd a:active {
          background-color: rgba(255, 255, 255, 0.8); }

#bottom_map {
  width: 80%;
  background-color: #b2b2b2;
  padding: 4em 10%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between; }
  #bottom_map li {
    width: 48%; }
    #bottom_map li iframe {
      aspect-ratio: 16/9;
      width: 100%;
      height: auto; }
    #bottom_map li dl {
      margin: 0.5em 0 0; }
      #bottom_map li dl dt {
        color: #fff;
        font-size: 130%;
        font-weight: bold; }
      #bottom_map li dl dd i {
        color: #fff;
        font-style: normal;
        background-color: #2eb6aa;
        width: 50px;
        border-radius: 5px;
        text-align: center;
        display: inline-block;
        font-weight: bold;
        line-height: 1;
        padding: 0.2em 0;
        margin: 0 5px 0 0; }
      #bottom_map li dl dd a {
        color: #363636;
        text-decoration: none; }
        #bottom_map li dl dd a:hover, #bottom_map li dl dd a:active {
          color: #363636;
          text-decoration: underline; }

/*フッター*/
/*共通設定ここまで-------------------------------------------------------------------------------------------------------------------------------------*/
/* pc */
@media screen and (min-width: 1300px) {
  /*ヘッダー*/
  /*メイン*/
  #business ul .name p br {
    display: none; }

  /*フッター*/ }
@media only screen and (min-width: 1300px) and (max-width: 1450px) {
  /*基本設定*/
  /*ヘッダー*/
  /*メイン*/
  #business ul .name p {
    font-size: 110% !important;
    margin: 0 0 0 0.5em; }

  /*フッター*/ }
/* tablet1 */
@media only screen and (min-width: 1024px) and (max-width: 1299px) {
  /*基本設定*/
  /*ヘッダー*/
  /*メイン*/
  #business {
    width: 90%; }
    #business ul {
      width: 90%; }
      #business ul .name p {
        font-size: 120% !important;
        margin: 0 0 0 0.5em; }
      #business ul .name div {
        margin: 0.5em 0 0; }
        #business ul .name div i {
          margin: 0 5px 0 0;
          vertical-align: middle; }
      #business ul dl dt {
        font-size: 120% !important; }
      #business ul dl dd {
        font-size: 70% !important; }

  /*フッター*/ }
/* tablet2  */
@media only screen and (min-width: 768px) and (max-width: 1023px) {
  /*基本設定*/
  /*ヘッダー*/
  /*メイン*/
  #m_top {
    width: 100%;
    margin: 80px 0 0; }
    #m_top h1 {
      font-size: 200%; }

  #business {
    width: 90%; }
    #business ul {
      width: 100%; }
      #business ul li {
        min-height: 25em; }
        #business ul li .name p {
          font-size: 115% !important;
          margin: 0 0 0 0.75em; }
        #business ul li .name div {
          margin: 0.5em 0 0; }
          #business ul li .name div i {
            margin: 0 5px 0 0;
            vertical-align: middle; }
        #business ul li dl dt {
          font-size: 120% !important;
          line-height: 1.2; }
        #business ul li dl dd {
          font-size: 70% !important; }
        #business ul li:nth-child(n+3) {
          margin: 0; }
          #business ul li:nth-child(n+3) .name p {
            margin: 0; }

  #manufacturing {
    width: 90%; }
    #manufacturing h2 {
      font-size: 180%; }
    #manufacturing ol li::after {
      content: '';
      /*何も入れない*/
      display: inline-block;
      width: 70px;
      /*画像の幅*/
      height: 27px;
      /*画像の高さ*/ }

  #bottom h2 {
    font-size: 130%; }
    #bottom h2 span {
      font-size: 130%; }
    #bottom h2::before {
      margin-left: -30px;
      border: 30px solid transparent;
      border-top: 30px solid #363636; }

  #bottom_map {
    width: 90%;
    padding: 4em 5%; }

  /*フッター*/ }
/* tablet3  */
@media only screen and (max-width: 767px) {
  /*基本設定*/
  /*ヘッダー*/
  /*メイン*/
  #m_top {
    width: 100%;
    margin: 80px 0 0; }
    #m_top h1 {
      font-size: 200%; }

  #business {
    width: 90%;
    margin: 2.5em auto 0; }
    #business ul {
      width: 90%; }
      #business ul li {
        width: 50%;
        min-height: 25em; }
        #business ul li .name p {
          font-family: "Sawarabi Mincho", serif;
          font-size: 115%;
          margin: 0 0 0 0.75em; }
        #business ul li:nth-child(n+3) {
          margin: 0; }
          #business ul li:nth-child(n+3) .name p {
            margin: 0; }
        #business ul li dl dt {
          font-size: 112%; }

  #manufacturing {
    width: 90%;
    margin: 2.5em auto 0; }
    #manufacturing h2 {
      font-size: 160%; }
    #manufacturing ol li {
      flex-direction: column-reverse;
      padding: 1em 2%; }
      #manufacturing ol li:nth-child(n+2) {
        margin: 3.5em 0 0; }
      #manufacturing ol li::after {
        width: 70px;
        /*画像の幅*/
        height: 27px;
        /*画像の高さ*/
        bottom: -3em; }
      #manufacturing ol li div {
        width: 100%; }
        #manufacturing ol li div h3 {
          font-size: 130%; }
      #manufacturing ol li figure {
        width: 100%; }

  #bottom {
    width: 100%;
    margin: 2.5em 0 0; }
    #bottom h2 {
      position: relative;
      width: 96%;
      padding: 3em 2%;
      text-align: center;
      color: #fff;
      font-size: 130%;
      background-color: #363636; }
      #bottom h2 span {
        color: #6db5a9;
        font-size: 130%;
        vertical-align: middle; }
      #bottom h2::before {
        margin-left: -30px;
        border: 30px solid transparent;
        border-top: 30px solid #363636; }
    #bottom dl dt {
      width: 80%;
      margin: 0 auto 1em; }
    #bottom dl dd i {
      font-size: 130%; }
    #bottom dl dd a {
      width: 280px;
      margin: 1em auto 0;
      padding: 0.5em 0; }

  #bottom_map {
    width: 90%;
    padding: 2em 5%; }
    #bottom_map li {
      width: 100%; }
      #bottom_map li:nth-child(n+2) {
        margin: 1em 0 0; }
      #bottom_map li dl dt {
        font-size: 120%; }

  /*フッター*/ }
/* smartPhone1 */
@media only screen and (max-width: 499px) {
  /*基本設定*/
  /*ヘッダー*/
  /*メイン*/
  /*フッター*/ }
