@charset "UTF-8";

body{font-family: 游ゴシック!important;}
.top-view ul{padding: 0!important;}
.container-fluid{padding: 0!important;margin: 0;}
a:hover{opacity: 0.7!important;}
img{max-width: 100%;}



/*==================================================
ヘッダー
===================================*/
#header {
    background-color: rgba(255, 255, 255, 0.7);
    position: fixed;
    z-index: +999;
    max-width: 100%;
    width: 100%;
    height: 70px;
}
#header .logo img {
    width: 70%;
    padding: 20px 0 20px 20px;
}

.header-nav ,#header .tell{
    display: none;
}


/*==================================================
ナビゲーション
===================================*/

#g-nav{
    /*position:fixed;にし、z-indexの数値を大きくして前面へ*/
    position:fixed;
    z-index: 999;
    /*ナビのスタート位置と形状*/
	top:70px;
    right: -120%;
	width:100%;
    height: 100vh;/*ナビの高さ*/
	background:#fff;
    /*動き*/
	transition: all 0.6s;
}

/*アクティブクラスがついたら位置を0に*/
#g-nav.panelactive{
    right: 0;
}

/*ナビゲーションの縦スクロール*/
#g-nav.panelactive #g-nav-list{
    /*ナビの数が増えた場合縦スクロール*/
    position: fixed;
    z-index: 999; 
    width: 100%;
    height: 100vh;/*表示する高さ*/
    overflow: auto;
    -webkit-overflow-scrolling: touch;
}

/*ナビゲーション*/
#g-nav ul {
    position: absolute;
    z-index: 999;
    /* top: 35%; */
    top: 15%;
    left: 50%;
    transform: translate(-50%,-50%);
    padding: 0;
}
#g-nav ul li{
    width: 300px;
    border-bottom: 1px solid;
}
#g-nav img {
    position: absolute;
    top: 30%;
    left: 0;
    right: 0;
    margin: 0 auto;
}

/*リストのレイアウト設定*/

#g-nav li{
	list-style: none;
    text-align: center;
}

#g-nav li a{
	color: #333;
	text-decoration: none;
	padding:10px;
	display: block;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	font-weight: bold;
}

/*========= ボタンのためのCSS ===============*/
.openbtn{
	position:fixed;
    z-index: 9999;/*ボタンを最前面に*/
	top:10px;
	right: 10px;
	cursor: pointer;
    width: 50px;
    height:50px;
}
	
/*×に変化*/	
.openbtn span{
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 3px;
    border-radius: 2px;
	background-color: #004e98;
  	width: 45%;
  }

.openbtn span:nth-of-type(1) {
	top:15px;	
}

.openbtn span:nth-of-type(2) {
	top:23px;
}

.openbtn span:nth-of-type(3) {
	top:31px;
}

.openbtn.active span:nth-of-type(1) {
    top: 18px;
    left: 18px;
    transform: translateY(6px) rotate(-45deg);
    width: 30%;
}

.openbtn.active span:nth-of-type(2) {
	opacity: 0;
}

.openbtn.active span:nth-of-type(3){
    top: 30px;
    left: 18px;
    transform: translateY(-6px) rotate(45deg);
    width: 30%;
}


/*==================================================
トップスライダーのためのcss
===================================*/
.top-view{
    padding-top: 70px;
    position: relative;
}
.catch-copy {
    position: absolute;
    top: 55%;
    left: 6%;
    z-index: 998;
    color: #fff;
    font-weight: bold;
    text-align: center;
    line-height: 1.8em;
    font-size: 20px;
    /* font-family: 游ゴシック; */
}
.top-bottom {
    background: #00A4C9;
    color: #fff;
    text-align: center;
    font-weight: bold;
    line-height: 1.8em;
    padding: 20px;
    letter-spacing: 0.2em;
    text-align: left;
}


.slider {
    margin: 0;
    position:relative;
      z-index: 1;
      /*↑z-indexの値をh1のz-indexの値よりも小さくして背景に回す*/
      height: 235px;/*スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
  }
  /*　背景画像設定　*/
  
  .slider-item01 {
      background:url(../img/top.jpg);
  }
  
  .slider-item02 {
      background:url(../img/top.jpg);
  }
  
  .slider-item03 {
      background:url(../img/top.jpg);
    }
  
  .slider-item {
      width: 100%;/*各スライダー全体の横幅を画面の高さいっぱい（100%）にする*/
      height:235px;/*各スライダー全体の縦幅を画面の高さいっぱい（100vh）にする*/
      background-repeat: no-repeat;/*背景画像をリピートしない*/
      background-position: center;/*背景画像の位置を中央に*/
      background-size: cover;/*背景画像が.slider-item全体を覆い表示*/
      filter: brightness(0.8);
  }
  
  /*矢印の設定
  
  .slick-prev, 
  .slick-next {
      position: absolute;
      z-index: 3;
      top: 42%;
      cursor: pointer;
      outline: none;
      border-top: 2px solid #fff;
      border-right: 2px solid #fff;
      height: 25px;
      width: 25px;
  }
  
  .slick-prev {
      left:2.5%;
      transform: rotate(-135deg);
  }
  
  .slick-next {
      right:2.5%;
      transform: rotate(45deg);
  }*/
  
  /*ドットナビゲーションの設定*/
  
  .slick-dots {
      position: relative;
      z-index: 3;
      text-align:center;
      margin:-50px 0 0 0;/*ドットの位置*/
  }
  
  .slick-dots li {
      display:inline-block;
      margin:0 5px;
  }
  
  .slick-dots button {
      color: transparent;
      outline: none;
      width:8px;/*ドットボタンのサイズ*/
      height:8px;/*ドットボタンのサイズ*/
      display:block;
      border-radius:50%;
      background:#fff;/*ドットボタンの色*/
  }
  
  .slick-dots .slick-active button{
      background:#333;/*ドットボタンの現在地表示の色*/
  }


  
/*==================================================
トップスライダー下のコンテンツ
===================================*/

.contents {
    position: relative;
    margin: 0 auto;
    width: 330px;
    margin-bottom: 15px;
}
.contents img {
    width: 350px;
    filter: brightness(80%);
}
.contents a{
    text-decoration: none;
    display: block;
}

.contents p {
    color: #fff;
    position: absolute;
    top: 44%;
    left: 37.5%;
    font-weight: bold;
    font-size: 20px;
    letter-spacing: 0.2em;
}

  

/*==================================================
あいさつ
===================================*/
#aisatu {
    padding: 30px 12px;
    background-color: #E7F1F7;
}
.aisatu-text1 p{
    margin: 0;
}
#aisatu h2 {
    text-align: center;
    font-weight: normal;
    margin-bottom: 20px;
    font-size: 21px;
    font-family: 游明朝!important
}
.aisatu-text1 .pre-name{
    text-align: right;
    font-size: 16px;
    margin-top: 10px;
}
.aisatu-text1 .pre-name span{
    font-size: 21px;
    padding-left: 10px;
    vertical-align: super;
}
#aisatu .aisatu-text1,#aisatu .aisatu-text2 {
    background-color: #fff;
    padding: 20px 12px;
    line-height: 2em;
    font-weight: 500;
}
#aisatu .aisatu-text2 h3{
    font-size: 20px;
    margin: 0;
    font-weight: bold;
}
#aisatu .aisatu-text2 h3::before {
    color: #00A4C9;
    font-size: 30px;
    padding-right: 8px;
}
#aisatu .aisatu-text2 .No1::before {
    content: "01";
    vertical-align: middle;
}
#aisatu .aisatu-text2 .No2::before {
    content: "02";
    vertical-align: middle;
}
#aisatu .aisatu-text2 .No3::before {
    content: "03";
    vertical-align: middle;
}

/*==================================================
事業案内
===================================*/
#works .container{
    padding: 0;
}
.logo2 img{
    width: 30px;
}
#works .works-bg {
    background-image: url(../img/work-bg.png);
    background-repeat: no-repeat;
    background-position: top;
    background-size: cover;
    color: #fff;
    padding: 30px 12px 40px 12px;
}
.works-bg h2,.works-bg h3 {
    text-align: center;
    font-weight: bold;
}
.works-bg h3 {
    font-weight: normal;
    margin-top: 40px;
    margin-bottom: 10px;
}
.appeal {
    margin-top: 25px;
    margin-bottom: 0;
    font-size: 20px;
    font-family: 游明朝!important
}
.operations {
    text-align: center;
}

.operations p {
    border: 1px solid;
    width: 300px;
    padding: 15px 0;
    margin-left: auto;
    margin-right: auto;
    font-size: 18px;
    font-weight: bold;
}
.operations ul {
    text-align: left;
    margin-left: 50px;
}
/*==================================================
スライダーのためのcss
===================================*/
#works .slider2 {/*横幅94%で左右に余白を持たせて中央寄せ*/
    width:90%;
     margin:0 auto;
     padding: 0;
 }

 
 #works .slider2 img {
     width:100%;/*スライダー内の画像を横幅100%に*/
     height:auto;
 }
 
 /*slickのJSで書かれるタグ内、スライド左右の余白調整*/
 
 #works .slider2 .slick-slide {
     margin:0 10px;
 }
 
 /*矢印の設定*/
 
 /*戻る、次へ矢印の位置*/
 #works .slick-prev, 
 #works .slick-next {
     position: absolute;/*絶対配置にする*/
     top: 50%;
     cursor: pointer;/*マウスカーソルを指マークに*/
     outline: none;/*クリックをしたら出てくる枠線を消す*/
     border-top: 5px solid #fff;/*矢印の色*/
     border-right: 5px solid #fff;/*矢印の色*/
     height: 15px;
     width: 15px;
 }
 
 #works .slick-prev {/*戻る矢印の位置と形状*/
     left: -4%;
     transform: rotate(-135deg);
 }
 
 #works .slick-next {/*次へ矢印の位置と形状*/
     right: -4%;
     transform: rotate(45deg);
 }
 #works .machine .slick-prev, #works .machine .slick-next {
    top: 55%;
}
 
 /*ドットナビゲーションの設定*/
 
 #works .slick-dots {
     text-align:center;
     margin:20px 0 0 0;
     padding: 0;
 }
 
 #works .slick-dots li {
     display:inline-block;
     margin:0 5px;
 }
 
 #works .slick-dots button {
     color: transparent;
     outline: none;
     width:8px;/*ドットボタンのサイズ*/
     height:8px;/*ドットボタンのサイズ*/
     display:block;
     border-radius:50%;
     background:#ccc;/*ドットボタンの色*/
 }
 
 #works .slick-dots .slick-active button{
     background:#333;/*ドットボタンの現在地表示の色*/
 }
 
.machine {
    background-color: #E1F0F9;
    padding: 30px 12px;
}
.machine h3{
    text-align: center;
    font-weight: 500;
}
.machine-table {
    overflow: scroll;
    margin: 20px 30px 20px;
    padding: 25px 0;
    font-weight: 500;
}
.machine-table table {
    width: 520px;
    /* table-layout: fixed; */
}
.machine-table table tr td {
    width: 45%;
    padding: 0 50px;
}

.machine-table tbody {
    border-top: 1px solid #818182;
}
.machine-table table tr {
    border-bottom: 1px solid #818182;
    line-height: 3em;
}

.works-img {
    margin-bottom: 5px;
}

/*==================================================
採用情報
===================================*/

#recruit {
    background-image: url(../img/recruit-bg.png);
    background-repeat: no-repeat;
    background-size: cover;
    color: #fff;
    padding: 40px 12px;
    background-position: center;
}
.recruit-box{
    font-family: 游ゴシック;
}
#recruit h2{
    text-align: center;
    font-weight: bold;
}
#recruit .recruit-txt {
    font-weight: bold;
}
#recruit .recruit-txt1 {
    text-align: center;
    padding-top: 20px;
    font-size: 19px;
}
.recruit-main{
    margin-top: 20px;
}
.link-btn-wrap {
    background-image: url(../img/btn-bg.png);
    width: 320px;
    margin: 0 auto;
    box-shadow: 0 0 2px #fff;
    padding: 20px;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: bottom;
    border-radius: 10px;
}
/* .link-btn{
    background-image: url(../img/btn-bg.png);
    width: 280px;
    margin: 0 auto;
    box-shadow: 0 0 2px #fff;
    margin-top: 20px;
} */
.link-btn a {
    color: #fff;
    text-decoration: none;
    text-align: center;
    display: block;
    padding: 15px 0;
    font-weight: bold;
}
.link-btn a:hover{
    color: #fff;
}

/*==================================================
会社概要
===================================*/
#gaiyou{
    padding: 30px 12px;
    font-weight: 500;
}
#gaiyou h2 {
    text-align: center;
    font-weight: normal;
    font-family: 游明朝!important
}
#gaiyou .gaiyo {
    margin: 30px 0;
}
.company-name {
    background: #00A4C9;
    text-align: center;
    padding: 10px 0;
    color: #fff;
    letter-spacing: 0.2em;
    font-weight: bold;
    font-size: 19px;
}
.pt-company{
    padding-top: 30px;
}
#gaiyou .company-info dl {
    border-top: 1px solid #E8E8E8;
}
#gaiyou .company-info dt {
    padding: 10px 20px;
}
#gaiyou .company-info dl dd{
    border-bottom: 1px solid #E8E8E8;
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 8px;
}
#gaiyou .map {
    margin: 20px 0;
    height: 200px;
}
/* アコーディオンメニュー全体のサイズ・位置 */
.ac {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
  }
  
  /* クリック領域 */
  .ac-parent {
    position: relative;  /* 追加 */
    background-color: #00A4C9;
    color: #fff;
    text-align: center;
    cursor: pointer;
    padding: 5px 0;
    letter-spacing: 0.2em;
    font-size: 19px;
}

/* ①プラスの横線 */
.ac-parent:before {
    content: url(../img/on.png);
    position: absolute;
    top: 20%;
    right: 32%;
}

/* ②プラスの縦線 */
.ac-parent:after {
    content: url(../img/off.png);
    position: absolute;
    top: 20%;
    right: 32%;
    opacity: 0;
}

/* ③オープン時にopenクラスを付与（縦線を回転させて非表示に） */
.ac-parent.open:after {
    top: 20%;
    opacity: 1;
}
.ac-parent.open::before{
    display: none;
}
.ac-parent:after,.ac-parent::before{
    display: none;
}

  /* クリックしたら表示される領域 */
  .ac-child {
    /* display: none; */
    display: block;
    /* padding: 2em 1em; */
    text-align: center;
    margin: 30px 0;
  }
  #gaiyou  .table th,#gaiyou  .table td{
    display: block;
    text-align: left;
  }
  #gaiyou  .table th{
    border-bottom-width:0px;
    padding-bottom: 0;
  }

  #gaiyou .ac th{
    padding: 10px 20px;
  }
  #gaiyou .ac td{
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 8px;
  }

  /*==================================================
フッター
===================================*/

  #footer{
    padding: 40px 12px 0;
    background-color: #EFEFEF;
    text-align: center;
  }
  .footer-logo {
    width: 70%;
    margin: 0 auto;
}
.footer-tell {
    width: 80%;
    margin: 20px auto;
    display: none;
}
.footer-tell-sp {
    /* background-image: url(../img/tell-footer-bg.png);
    width: 320px; */
    margin: 0 auto;
    /* background-size: cover;
    padding: 20px;
    background-position: center; */
    margin-bottom: 16px;
    /* color: #fff;
    font-weight: bold; */
}
.footer-tell-sp a {
    display: block;
    margin: 15px 0;
}
.copyright p {
    margin: 0;
    font-size: 11.5px;
}
.footer-tell-sp img {
    object-fit: cover;
    width: 100%;
    height: 70px;
}
/*リンクの形状*/
#page-top a{
	display: flex;
	justify-content:center;
	align-items:center;
	background:#00A4C9;
	border-radius: 5px;
	width: 50px;
	height: 50px;
	color: #fff;
	text-align: center;
	text-transform: uppercase; 
	text-decoration: none;
	font-size:0.6rem;
	transition:all 0.3s;
}

#page-top a:hover{
	background: #777;
}

/*リンクを右下に固定*/
#page-top {
	position: fixed;
	right: 0;
	bottom:0;
	z-index: 2;
    /*はじめは非表示*/
	opacity: 0;
	transform: translateY(100px);
    margin: 0;
}

/*　上に上がる動き　*/

#page-top.UpMove{
	animation: UpAnime 0.5s forwards;
}
@keyframes UpAnime{
  from {
    opacity: 0;
	transform: translateY(100px);
  }
  to {
    opacity: 1;
	transform: translateY(0);
  }
}

/*　下に下がる動き　*/

#page-top.DownMove{
	animation: DownAnime 0.5s forwards;
}
@keyframes DownAnime{
  from {
  	opacity: 1;
	transform: translateY(0);
  }
  to {
  	opacity: 1;
	transform: translateY(100px);
  }
}

@media screen and (min-width:760px) {
    #header .logo img {
        width: 35%;
        padding: 20px 0 20px 10px;
    }
    .slider,.slider-item {
        height: 480px;
    }
    .catch-copy {
        left: 10%;
        font-size: 30px;
    }
    .top-bottom{
        text-align: center;
    }
    .contents {
        width: 220px;
    }
    .contents p {
        top: 41%;
        left: 29.5%;
        font-size: 18px;
    }

    #aisatu {
        padding: 50px 20px;
    }
    #aisatu .aisatu-text1, #aisatu .aisatu-text2 {
        padding: 30px;
    }
    #aisatu h2 {
        font-size: 25px;
    }
    #aisatu .aisatu-text2 h3 {
        font-size: 23px;
    }
    #aisatu .aisatu-text2 h3::before {
        font-size: 40px;
    }
    .aisatu-text2 .No1,.aisatu-text2 .No2,.aisatu-text2 .No3{
        font-size: 25px;
    }
    #works#works .container{
        max-width: 100%!important;
    }
    #works .row{
        max-width: 720px;
        margin: 0 auto;
    }
    .appeal {
        font-size: 25px;
        text-align: center;
        margin-top: 30px!important;
    }
    .logo2 img {
        width: 3%;
    }
    #works .works-bg {
        padding-top: 50px;
    }
    .machine {
        padding-bottom: 50px;
    }
    .machine .col-sm-4 {
        padding: 0 2px;
    }
    .machine-table table {
        width: 700px;
    }
    .machine-table table tr td.pl{
        padding-left: 100px;
    }
    .operations p {
        width: auto;
    }
    .operations ul {
        margin-left: 0;
    }

    #recruit {
        padding: 50px 12px;
    }
    .no-g{
        margin: 0;
    }
    .recruit-main {
        position: relative;
    }
    .recruit-box {
        position: absolute;
        bottom: 5%;
        right: 20px;
        text-align: center;
        color: #0e175b;
        width: 45%;
    }
    #recruit .recruit-txt1 {
        font-size: 25px;
        margin: 0 auto 1rem;
    }
    .link-btn-wrap {
        background-image: url(../img/btn-bg.png);
        width: 500px;
        padding: 0 20px;
        box-shadow: none;
    }
    .link-btn-wrap {
        display: flex;
        justify-content: center;
    }
    .link-btn{
        margin: 0 15px;
    }
    .line{
        position: relative;
    }
    .line::after {
        content: url(../img/line.png);
        position: absolute;
        top: 0;
        left: 100%;
        content: "";
        width: 2px;
        background: #00a4c9;
        height: 100%;
    }
    #gaiyou {
        padding: 50px 12px;
    }
    .pt-company{
        padding-top: 50px;
    }
    #gaiyou .gaiyo dl {
        display: flex;
        flex-wrap: wrap;
        width: 100%;
      }
    #gaiyou .gaiyo dt {
        width: 30%;
        border-bottom: 1px solid #E8E8E8;
        line-height: 3em;
      }
      
    #gaiyou .gaiyo dl dd {
        width: 70%;
        height:60px ;
        padding:10px 0;
        margin: 0;
        height: 69px;
        line-height: 3em;
      }
    .company-info {
        margin-bottom: 20px;
    }
    #footer {
        padding: 50px 12px 0;
    }
    .footer-logo {
        width: 45%;
    }
    /* .footer-tell-sp{
        display: none;
    } */
    /* .footer-tell-sp {
        display: flex;
        width: 650px;
        max-width: 960px;
        justify-content: center;
        padding: 30px 10px;
    }
    .footer-tell-sp a {
        width: 45%;
        margin: 0 15px;
    } */
    /* .footer-tell {
        width: 65%;
        margin: 25px auto;
        display: block;
    } */

.footer-tell-sp a {
    display: block;
    width: 450px;
    margin: 0 auto;
}
}

@media screen and (min-width:1000px) {
    .catch-copy {
        font-size: 40px;
    }
    .contents {
        width: 300px;
    }
    .contents p {
        top: 41%;
        left: 29.5%;
        font-size: 24px;
    }

    #works .row {
        max-width: 900px;
    }
    #works .slider2 {
        width: 100%;
    }
    .works-bg h3 {
        margin-bottom: 20px;
    }
    .machine-table {
        overflow:visible;
    }
    .machine-table table {
        width: 900px;
    }
    #recruit .recruit-txt p {
        font-size: 20px;
        line-height: 1.8em;
        text-align: left;
        padding-left: 4px;
    }
    #recruit .recruit-txt .recruit-txt1 {
        font-size: 40px;
        text-align: center;
    }
    .recruit-box {
    bottom: 60px;
}
    .line::after {
        left: 479px;
    }
    #gaiyou .map {
        height: 300px;
    }
    #gaiyou .table th, #gaiyou .table td {
        display: table-cell;
        text-align: left;
    }
    .company-info {
        margin-bottom: 40px;
    }
    #gaiyou .table th {
        border-bottom-width: 1px;
        padding-bottom: 0;
    }
    #gaiyou .table th {
        /* padding-left: 60px; */
        width: 20%;
    }
    #gaiyou .table tr{
        line-height: 3em;
    }
    #gaiyou .l-h {
        line-height: 1.8;
    }
    #g-nav ul li {
        width: 615px;
        line-height: 4em;
    }
    #g-nav li a {
        font-size: 20px;
    }
    #g-nav img {
        left: 20%;
        width: 60%;
    }
    .machine-table table {
        width: 800px;
        margin: 0 auto;
    }
    .machine-table table tr td.pl {
        padding-left: 150px;
    }

}
@media screen and (min-width:1200px) {
    #header ul{
        list-style: none;
        margin: 0;
    }
    #header {
        display: flex;
        justify-content: space-between;
        height: 80px;
        position: absolute;
        top: 0;
        padding: 6px;
        align-items: center;
    }
    #header .logo img {
        width: 290px;
        padding: 0;
    }
    #header .header-nav {
        display: flex;
        align-items: center;
    }
    .header-nav ul {
        display: flex;
        padding-right: 15px;
    }
    .header-nav ul li {
        line-height: 4.5em;
    }
    .header-nav ul li a {
        display: block;
        color: #000;
        text-decoration: none;
        margin: 0 15px;
        font-size: 20px;
        font-weight: bold;
    }
    .header-nav, #header .tell {
        display: block;
    }
    .openbtn {
        display: none;
    }
    .top-view {
        padding-top: 0;
    }
    .slider, .slider-item {
        height: 700px;
    }
    .catch-copy {
        font-size: 52px;
        top: 50%;
        text-align: left;
    }
    .top-bottom {
        padding: 30px 0;
        font-size: 24px;
    }
    .contents {
        width: 390px;
    }
    .pre-img {
        width: 52%;
    }
    #aisatu {
        padding: 50px 0px;
    }
    #aisatu h2 {
        font-size: 30px;
    }
    #aisatu .aisatu-text2 h3 {
        font-size: 26px;
    }
    .pre-img {
        margin-left: auto;
        width: 74%;
    }
    .aisatu-text1 {
        position: absolute;
        width: 560px;
        top: 35px;
        left: 30px;
    }
    .reson-img {
        width: 77%;
        margin-right: auto;
    }
    .aisatu-text2 {
        position: absolute;
        width: 500px;
        top: 25px;
        right: 30px;
    }
    .aisatu-text1 {
        top: 30px;
        left: 80px;
    }
    .aisatu-text2 {
        width: 600px;
        top: 40px;
        right: 25px;
    }
    .aisatu-text2 p {
        padding-left: 60px;
    }
    .aisatu-text1 .pre-name span {
        font-size: 25px;
        padding-left: 5px;
    }
    #aisatu .aisatu-text1, #aisatu .aisatu-text2 {
        padding: 30px 20px;
        box-shadow: 0 0 8px gray;
    }
    #aisatu .aisatu-text2 h3::before {
        font-size: 45px;
    }
    #works .row {
        max-width: 1000px;
    }
    .operations p {
        width: 260px;
    }
    .operations ul {
        padding-left: 5em;
    }
    .machine-table table {
        width: 1000px;
        margin: 0 auto;
    }

    .recruit-main {
        max-width: 1140px;
        margin-left: auto;
        margin-right: auto;
    }
    .recruit-main img {
        width: 100%;
    }
    .logo2 img {
        width: 40px;
    }

    .line::after {
        left: 569px;
    }
    .company-name {
        font-size: 22px;
    }
    .ac-parent {
        font-size: 22px;
    }

    #gaiyou .company-info dl {
        display: flex;
        flex-wrap: wrap;
        width: 100%;
      }
    #gaiyou .company-info dt {
        width: 25%;
        border-bottom: 1px solid #E8E8E8;
        line-height: 3em;
      }
      
    #gaiyou .company-info dl dd {
        width: 75%;
        height:60px ;
        padding:10px 0;
        margin: 0;
        height: 69px;
        line-height: 3em;
      }
      .footer-logo {
        width: 20%;
        margin-bottom: 10px;
    }    
      .footer-tell {
        width: 40%;
    }
}

@media screen and (min-width:1300px) {
    .slider, .slider-item {
        height: 780px;
    }
    #aisatu .aisatu-text1, #aisatu .aisatu-text2 {
        padding: 30px;
    }
    .aisatu-text1 {
        top: 40px;
    }
    .aisatu-text2 {
        top: 60px;
    }
}
@media screen and (min-width:1400px) {
    .header-nav ul li a {
        margin: 0 20px;
    }
    /* .catch-copy {
        left: 23%;
    } */
    .top-bottom {
        padding: 40px 0;
        font-size: 29px;
    }
    .contet-wrap{
        max-width: 1150px;
        margin: 0 auto!important;
    }
    #aisatu {
        padding: 70px 0px;
    }
    .pre-img {
        margin-left: auto;
        width: 71%;
    }
    #aisatu .aisatu-text1, #aisatu .aisatu-text2 {
        padding: 60px 35px;
        width: 670px;
    }
    .aisatu-text1 {
        top: 60px;
        left: 120px;
    }
    .aisatu-text2 {
        right: 35px;
        top: 55px;
    }
    
    #aisatu h2 {
        font-size: 35px;
    }
    #aisatu .aisatu-text2 h3 {
        font-size: 28px;
    }
    #works .works-bg {
        padding-top: 70px;
    }
    .works-bg h2 {
        font-size: 35px;
    }
    #works .row {
        max-width: 1200px;
    }
    .operations p {
        width: 310px;
    }
    .machine-table table {
        width: 1200px;
    }
    .machine-table table tr td.pl {
        padding-left: 240px;
    }
    .machine {
        padding-bottom: 70px;
    }
    #recruit {
        padding: 95px 12px;
    }
    #recruit h2 {
        font-size: 40px;
    }
    .recruit-box {
        bottom: 80px;
    }
    .link-btn-wrap {
        width: 700px;
        padding: 10px 20px;
    }
    #gaiyou .container {
        max-width: 1200px;
    }
    #gaiyou {
        padding: 70px 12px;
    }
    .pt-company{
        padding-top: 70px;
    }
    #gaiyou h2 {
        font-size: 40px;
    }
    .line::after {
        left: 598px;
    }
    .company-info {
        margin-bottom: 10px;
    }
    #gaiyou .map {
        height: 370px;
    }
    .ac {
        margin-top: 20px!important;
    }
    #recruit .recruit-txt .recruit-txt1 {
        line-height: 1.4;
        margin-bottom: 2rem;
    }
    .recruit-box a {
        margin-top: 2rem;
    }
    .footer-tell-sp img {
    height: 90px;
    }
    .footer-tell-sp a {
        width: 600px;
    }
}
@media screen and (min-width:1600px) {
    #recruit {
        padding: 106px 12px;
    }
    .slider, .slider-item {
        height: 910px;
    }
    /* .catch-copy {
        left: 25%;
    } */
    .aisatu-text2 {
        top: 95px;
    }
    .pre-img {
        width: 60%;
    }
    .recruit-box {
        bottom: 75px;
    }
}
@media screen and (min-width:1900px) {
    p{
        font-size: 18px;
    }
    .header-nav ul li a {
        margin: 0 40px;
    }
    .slider, .slider-item {
        height: 970px;
    }
    /* .catch-copy {
        left: 31%;
    } */
    .top-bottom {
        padding: 57px 0;
    }
    .contet-wrap {
        max-width: 1200px;
    }
    .contents {
        width: 440px;
    }
    .contents img {
        width: 380px;
    }
    #aisatu .aisatu-text1 p, #aisatu .aisatu-text2 p{
        font-size: 16px;
    }
    #aisatu .aisatu-text1, #aisatu .aisatu-text2 {
        padding: 50px 70px;
        width: 740px;
    }
    #aisatu h2 {
        margin-bottom: 40px;
        font-size: 40px;
    }
    .pre-img {
        width: 50%;
    }
    .aisatu-text1 .pre-name {
        margin-top: 40px;
    }
    .aisatu-text1 .pre-name span {
        font-size: 30px;
        padding-left: 10px;
    }
    .aisatu-text1 .pre-name {
        margin-top: 10px;
    }
    .aisatu-text1 {
        top: 45px;
        left: 350px;
    }
    .aisatu-text2 {
        right: 220px;
        top: 55px;
    }
    .aisatu-text2 p {
        padding-left: 80px;
    }
    #aisatu .aisatu-text2 h3::before {
        font-size: 62px;
    }
    #works .works-bg {
        padding-top: 90px;
    }
    .appeal {
        font-size: 40px;
    }
    .works-bg h3 {
        margin-bottom: 30px;
    }
    .operations p {
        font-size: 24px;
    }
    .operations ul li {
        font-size: 18px;
    }
    .machine-table {
        font-size: 18px;
    }
    #recruit {
        padding: 195px 12px;
    }
    #recruit h2 {
        margin-top: -20px;
    }
    #recruit .logo2 {
        margin-bottom: 30px;
    }
    .recruit-main {
        max-width: 1200px;
        margin-left: auto;
        margin-right: auto;
    }
    /* .logo2 img {
        width: 1.3%;
    }
    .works-bg .logo2 img {
        width: 2%;
    }
    #gaiyou .logo2 img {
        width: 2%;
    } */
    .link-btn a {
        font-size: 18px;
    }
    .link-btn a:hover{
        color: #fff;
    }
    .company-name {
        font-size: 26px;
    }
    .company-info dt, .company-info dl {
        font-size: 18px;
    }
    #gaiyou .company-info dt {
        padding: 7px 20px;
    }
    #gaiyou .company-info dt {
        line-height: 3em;
    }
    #gaiyou .company-info dt {
        width: 25%;
    }
    #gaiyou .company-info dl dd {
        width: 75%;
        padding: 7px 0;
    }
    .ac-parent {
        font-size: 26px;
    }
    .ac-child {
        font-size: 18px;
    }
    #footer {
        padding: 80px 12px 0;
    }
    .footer-logo {
        margin-bottom: 10px;
    }
    .footer-tell {
        width: 35%;
    }
    .copyright p {
        font-size: 16px;
    }
}

/*-----------
固定ページ：お問い合わせ
----------------------------------*/

.page-id-7 .container {
    padding-top: 100px;
    padding-bottom: 50px;
}
.page-id-7 .container h2 {
    text-align: center;
    margin-bottom: 30px;
}
.page-id-7 .wpcf7-spinner{
    display: none;
}
.page-id-7 #contact-form {
    max-width: 860px;
    margin: 20px auto;
}
.page-id-7 .ml-auto{
    margin-left: auto;
}

@media screen and (min-width:1400px) {
    .page-id-7 .container {
        padding-top: 150px;
        padding-bottom: 100px;
    }
    .page-id-7 .container h2 {
        text-align: center;
        margin-bottom: 90px;
    }
}


.recruit-box a {
    border: 2px solid #fff;
    display: block;
}

.recruit-box a img {
    object-fit: cover;
    width: 100%;
    height: 70px;
}
@media screen and (min-width:1200px) {
    .recruit-box a {
    border: 2px solid #fff;
    width: fit-content;
    margin: 0 auto;
    border: none;
}
.recruit-box a img {
    object-fit: cover;
    width: 370px;
    height: 80px;
}
}