@charset "UTF-8";
/* --------------------------------------------------------------------------
共通
 ------------------------------------------------------------------------- */
/* WP管理画面の右上アバターを非表示 */
#wpadminbar #wp-admin-bar-my-account.with-avatar>.ab-empty-item img, #wpadminbar #wp-admin-bar-my-account.with-avatar>a img {
  display: none;
}
/* フォントサイズ10px */
html {
  font-size: 62.5%;
}

/* 基本のフォントサイズ */
body {
  font-size: 16px;
  font-size: 1.8rem;
  letter-spacing: 0.08em;
  color: #333;
  display: flex;
  flex-flow: column;
  min-height: 100vh;
}

.modal {
  display: none;
}

main {
  flex: 1;
}

img {
  width: 100%;
  height: auto;
}

/* インナー幅 */
.inner {
  padding: 0 85px;
}

/* コンテンツ幅 */
.content {
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
}

.page-content {
  width: 78.431373%;
  max-width: 1200px;
  margin: 0 auto;
}

/* カンパニーロゴ */
.company-logo {
  text-transform: uppercase;
}

.company-logo__main {
  font-size: 4.1rem;
}

.company-logo__sub {
  display: block;
  font-size: 1.6rem;
}

/* セクションタイトル */
.section__title {
  font-weight: 900;
}

.section__title-sub {
  font-family: azo-sans-web, sans-serif;
  font-weight: 700;
  display: block;
  text-transform: uppercase;
}

/* 一部テキストの色を変える */
.change-color-accent {
  color: #fc1223;
}

/* カード群 */
.cards {
  display: flex;
  justify-content: space-between;
}

.card {
  background-color: #fff;
  box-shadow: 0 34px 38px rgba(95, 95, 95, 0.1);
  display: flex;
  flex-direction: column;
}

.card__title {
  font-weight: 900;
  color: #222;
  text-align: center;
}

.card__title-sub {
  font-family: azo-sans-web, sans-serif;
  font-weight: 700;
  display: block;
  text-transform: uppercase;
  color: #999;
  text-align: center;
}

.card__link {
  background-color: #fc1223;
  color: #fff;
  display: block;
  width: 100%;
  font-size: 1.8rem;
  letter-spacing: 0.3em;
  text-align: center;
  margin-top: auto;
}

.card__link:hover {
  opacity: .8;
}

/* ボタン */
.btn__link {
  max-width: 400px;
  background-color: #fc1223;
  color: #fff;
  display: block;
  width: 100%;
  font-size: 1.8rem;
  letter-spacing: 0.3em;
  text-align: center;
  margin-top: auto;
  padding: 20px 10px;
}
.btn__link:hover {
  opacity: .8;
}

/* 写真とキャプションのカード群 */
.picture-cards {
  display: flex;
  flex-wrap: wrap;
  margin: 40px auto 0;
}

.picture-card {
  width: calc((100% - 60px) / 3);
  max-width: 380px;
}

.picture-card:not(:nth-child(3n)) {
  margin-right: 30px;
}

.picture-card:nth-child(n + 4) {
  margin-top: 30px;
}

.picture-card__img {
  position: relative;
  width: 100%;
}

.picture-card__img::before {
  content: "";
  display: block;
  padding-top: 73.684211%;
}

.picture-card__img img {
  position: absolute;
  top: 0;
  left: 0;
}

.picture-card__caption {
  font-size: 1.7rem;
  margin-top: 16px;
}

/* アイキャッチ */
.eyecatch {
  width: 100%;
  color: #fff;
  position: relative;
}
.eyecatch__img {
  position: relative;
  width: 100%;
}

.eyecatch__img::before {
  content: "";
  display: block;
  padding-top: 23.529412%;
}

.eyecatch__img img {
  position: absolute;
  top: 0;
  left: 0;
}

.eyecatch__box {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
}

/* ぱんクズリスト */
.breadcrumbs {
  font-size: 1.3rem;
  line-height: 1.92;
  letter-spacing: 0.15em;
  margin-top: 5px;
}
.breadcrumbs li {
  display: inline;
}

/* ページタイトル */
.page-title__copy-en {
  display: block;
  font-family: azo-sans-web, sans-serif;
  font-weight: 700;
  font-size: 3rem;
}

.page-title__copy-main {
  font-family: heisei-kaku-gothic-std, sans-serif;
  font-weight: 900;
  font-size: 6rem;
  letter-spacing: 0.12em;
}

/* ページセクションタイトル */
.page-section__title {
  font-family: heisei-kaku-gothic-std, sans-serif;
  font-weight: 900;
  font-size: 3.5rem;
  display: inline-block;
  position: relative;
}

.page-section__title::after {
  content: "";
  width: 1.43em;
  height: 3px;
  background-color: #fc1223;
  position: absolute;
  top: 50%;
  right: -2.3em;
  transform: translateY(-50%);
}

/* ページ内リンク */
.page-link {
  margin-top: 70px;
}

.page-link__box {
  display: flex;
  justify-content: center;
  padding: 40px 10px;
  background-color: #eee;
  border-radius: 10px;
}

.page-link__item:not(:last-child) {
  margin-right: 60px;
}

.page-link__item {
  display: inline-block;
  font-size: 1.8rem;
  position: relative;
  padding-left: 1.8em;
}

.page-link__item:hover {
  text-decoration: underline;
}

.page-link__item::before {
  position: absolute;
  content: "";
  width: 20px;
  height: 20px;
  background-color: #fc1223;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

.page-link__item::after {
  position: absolute;
  content: "";
  width: 10px;
  height: 10px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
  top: 50%;
  left: 0;
  margin-top: -5px;
  margin-left: 2px;
}

/* テーブル01 */
.table01 {
  width: 100%;
}

.table01 dl {
  display: flex;
  border-bottom: 1px solid #ccc;
}

.table01 dl:first-of-type {
  border-bottom: 1px solid #fc1223;
}

.table01 dl {
  border-bottom: 1px solid #ccc;
  display: flex;
}

.table01 dl:first-of-type {
  border-bottom: 1px solid #fc1223;
}

/* テーブル02 */
.table02 {
  font-size: 1.7rem;
  line-height: 1.2;
}

.table02 dl {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}

.table02 dl:not(:first-child) {
  margin-top: 1px;
}

.table02 dt {
  display: inline-block;
  background-color: #eee;
}

.table02 dd {
  display: inline-block;
  background-color: #f8f8f8;
}

/* ヘッダー */
.header {
  height: 120px;
  align-items: center;
  background-color: #222;
  z-index: 100;
}
.header__inner {
  padding: 0 calc(50vw - 50%);
  height: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
}
.header__inner--right {
  display: flex;
  margin: 0 calc(50% - 50vw);
  height: inherit;
}
.header-company-logo {
  color: #fc1223;
  font-family: azo-sans-web, sans-serif;
  font-weight: 900;
  padding-left: 30px;
  margin-right: auto;
}
.header-company-logo__sub {
  line-height: 0.1764;
  position: relative;
}
.header-company-logo__sub::after {
  content: "";
  background-color: #fff;
  width: 140%;
  max-width: 300px;
  height: 1px;
  position: absolute;
  z-index: -1;
  bottom: -15px;
  left: 0;
}
.header-company-logo__ja {
  color: #fff;
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 700;
}
.header-company-logo__ja-small {
  font-size: 1.5rem;
}
.header-company-logo__ja-regular {
  font-size: 1.7rem;
}
.header-company-logo__link {
  display: inline-block;
  height: 100%;
}
.global-nav {
  height: inherit;
  background-color: #fff;
}
.global-nav__list {
  color: #222;
  display: flex;
  height: inherit;
}
.global-nav__list-item {
  display: inline-block;
  border-right: 1px solid #ddd;
  width: 120px;
  text-align: center;
}
.global-nav__list-item:hover {
  background-color: #ddd;
}
.global-nav__link {
  width: 100%;
  height: 100%;
  font-size: 1.7rem;
  font-weight: 700;
  display: inline-block;
  padding: 35px 0;
}
.global-nav__link span {
  display: block;
}
.global-nav__link-sub {
  display: block;
  font-family: azo-sans-web, sans-serif;
  font-weight: 700;
  font-size: 1rem;
  text-transform: uppercase;
  margin-top: 5px;
}
.global-nav__tel {
  background-color: #fff;
  display: flex;
  align-items: center;
}
.global-nav__tel-link {
  display: inline-block;
  height: 100%;
  padding: 25px 10px;
  text-align: center;
}
.global-nav__tel-icon {
  width: 43px;
  height: auto;
  display: inline-block;
}
.tel-svg {
  fill: #fc1223;
}
.global-nav__tel-info {
  display: inline-block;
}
.global-nav__tel-num {
  font-family: azo-sans-web, sans-serif;
  font-weight: 700;
  font-size: 2.7rem;
  letter-spacing: 0.02em;
}
.global-nav__tel-time {
  font-weight: 700;
  font-size: 1.2rem;
  line-height: 2;
  letter-spacing: 0.1em;
}
.global-nav__contact {
  background-color: #bc000f;
  width: 120px;
}
.global-nav__contact:hover {
  opacity: .8;
}
.global-nav__contact-link {
  display: inline-block;
  width: 100%;
  height: 100%;
}
.global-nav__mail-img {
  width: 53px;
  height: 100%;
  margin: 0 auto;
  position: relative;
}
.mail-svg {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  fill: #fff;
}

/* サブメニュー */
.has-child{position: relative;}

ul.submenu {
  position: absolute;
  top: 115px;
  left: 50%;
  transform: translate(-50% , 0);
  width: 200px;
  
  margin: 0;
  text-align: center;
  z-index: 99999;
  display: block;
  box-shadow: 0px 8px 10px -6px rgba(0,0,0,0.3);
}

.submenu a{padding: 18px 0; display: block;  background-color: #fff; font-size: 1.6rem; border-bottom: 1px solid #F6E72F; font-weight: 700;}
.submenu a:hover{background-color: #ddd; }
.submenu li{visibility: hidden; height: 0; transition: .5s;  color: transparent; opacity: 0;}

ul.submenu li:first-child {
  border: 0 none; 
}
.has-child:hover .submenu li{visibility: visible; height: 60px; transition: .5s; color: #333; opacity: 1;}

.header_item ul.submenu a::after{display: none;}


/* フッター */
.footer {
  background-color: #fc1223;
  color: #fff;
  padding: 50px 0;
}
.footer .content {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}
.footer__text-box {
  display: flex;
  align-items: flex-end;
}
.footer-company-logo {
  margin-right: 60px;
  font-family: azo-sans-web, sans-serif;
  font-weight: 900;
}
.footer-company-logo__main {
  letter-spacing: 0.001em;
}
.footer-company-logo__sub {
  position: relative;
}
.footer-company-logo__sub::after {
  content: "";
  background-color: #fff;
  width: 110%;
  max-width: 260px;
  height: 1px;
  position: absolute;
  z-index: 0;
  bottom: 0;
  left: 0;
}
.footer-company-logo__ja {
  color: #fff;
  font-family: source-han-sans-japanese, sans-serif;
  font-weight: 700;
}
.footer-company-logo__ja-small {
  font-size: 1.5rem;
}
.footer-company-logo__ja-regular {
  font-size: 1.7rem;
}
.footer-info {
  font-size: 1.5rem;
  line-height: 1.666;
}
.copyright {
  font-size: 1rem;
  line-height: 2.5;
  letter-spacing: 0.15em;
}

.footer_logo{ background-color: #fff; width: 125px; height: 125px; margin: 0 0 0 20px; }
.footer_logo img{ width: 125px; height: 125px; padding: 10px; }



/**********
トップページ
***********/
/* メインビュー */
.main-view {
  width: 100%;
  height: auto;
  position: relative;
}
.main-view::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(204, 204, 204, 0.1);
  z-index: 1;
}
.main-view__img {
  position: relative;
  width: 100%;
  height: auto;
  max-height: 800px;
  overflow: hidden;
}
.main-view__img video {
  width: 100%;
  height: 100%;
  display: block;
}
.main-view__copy {
  position: absolute;
  top: 46%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  color: #fff;
  padding: 0 85px;
  z-index: 1;
}
.main-view__copy-en,
.main-view__copy-main,
.main-view__copy-sub {
  display: block;
  text-align: center;
}
.main-view__copy-en {
  font-size: 3rem;
  font-weight: 900;
  font-family: azo-sans-web, sans-serif;
}
.main-view__copy-main {
  font-size: 11rem;
  font-weight: 900;
  letter-spacing: -0.07em;
}
.main-view__copy-sub {
  font-size: 5rem;
  font-weight: 900;
  letter-spacing: 0;
}

.main-view_topic_img{
  position: absolute;
  bottom: 60px;
  right: 3%;
  z-index: 5;
}

/* 梶川の技術 */
.top-techno {
  width: 100%;
  height: auto;
  position: relative;
  padding: 110px 85px 90px 85px;
}
.top-techno::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-color: #222;
  z-index: -3;
}
.top-techno::after {
  content: '';
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: linear-gradient(to bottom, #222222, #222222 25%, rgba(34, 34, 34, 0.9) 35%, rgba(34, 34, 34, 0.7) 45%, rgba(255, 255, 255, 0));
  z-index: -2;
}
.top-techno__img {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -2;
}
.top-techno__box {
  max-width: 1300px;
  width: 100%;
  margin: 0 auto;
}
.top-techno .section__title {
  font-size: 10rem;
  color: #fff;
  letter-spacing: 0.08em;
}
.top-techno .section__title-sub {
  font-size: 4.5rem;
  letter-spacing: 0.08em;
}
.card01 {
  width: 34.6%;
  max-width: 450px;
  margin-top: 45px;
}
.card01__text-box {
  padding: 45px 50px;
}
.card01__text {
  line-height: 2.3;
  letter-spacing: -0.03em;
}
.card01__link {
  padding: 35px 10px;
}

/* 3カラムコンテンツ */
.top-site-contents {
  background-color: #f5f5f5;
  padding-top: 100px;
  padding-bottom: 105px;
}
.card02 {
  width: 30.7%;
  max-width: 400px;
}
.card02__img {
  position: relative;
}
.card02__img::before {
  content: "";
  display: block;
  padding-top: 70%;
}
.card02__img img {
  position: absolute;
  top: 0;
  left: 0;
}
.card02__text-box {
  padding: 30px 37px;
}
.card02__title {
  font-size: 3.7rem;
  letter-spacing: 0.15em;
}
.card02__title-sub {
  font-size: 1.8rem;
  margin-top: 5px;
  letter-spacing: 0.1em;
}
.card02__text {
  font-size: 1.6rem;
  line-height: 2;
  margin-top: 20px;
}
.card02__link {
  padding: 25px 10px;
}

/* 採用情報 */
.top-recruit {
  height: 520px;
  background-color: #222;
  color: #fff;
  display: flex;
  align-items: center;
}
.top-recruit__img {
  width: 50%;
  height: 100%;
  overflow: hidden;
  object-fit: cover;
}
.top-recruit__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.top-recruit__box {
  width: 50%;
  margin-right: 0;
  margin-left: auto;
  padding-left: 110px;
  padding-right: 270px;
}
.top-recruit .section__title {
  font-size: 6rem;
  letter-spacing: 0.1em;
}
.top-recruit .section__title-sub {
  font-size: 3.5rem;
  letter-spacing: 0.05em;
}
.top-recruit .top-recruit__text {
  font-size: 1.7rem;
  line-height: 2.058;
  margin-top: 20px;
}
.btn__link--top-recruit {
  margin-top: 15px;
}

/**********
梶川の技術
***********/
.advantage {
  margin-top: 140px;
  margin-bottom: 120px;
}
.advantage_item:not(:first-of-type) {
  margin-top: 100px;
}
.advantage__head {
  display: flex;
  align-items: center;
}
.advantage__list-style {
  font-family: azo-sans-web, sans-serif;
  font-weight: 700;
  line-height: 1.25;
  color: #fff;
  width: 160px;
  height: 160px;
  padding: 25px 0;
  margin-right: 40px;
  text-align: center;
  background: linear-gradient(-45deg, #000 0%, #000 50%, #fc1223 50%, #fc1223 100%);
}
.advantage__en {
  font-size: 2rem;
}
.advantage__num {
  display: block;
  font-size: 8rem;
  letter-spacing: 0.02em;
}
.advantage__title {
  font-family: heisei-kaku-gothic-std, sans-serif;
  font-weight: 900;
  font-size: 5rem;
  line-height: 1.4;
  letter-spacing: 0.03em;
  color: #000;
}
.advantage__body {
  display: flex;
  margin-top: 45px;
}
.advantage__body02 {
  display: block;
}
.advantage__text-box {
  width: 45%;
}
.advantage__text {
  font-size: 1.7rem;
  line-height: 2.35;
  letter-spacing: 0.06em;
  color: #000;
}
.advantage__text-box02 {
  width: 100%;
}
.advantage__link {
  font-weight: 700;
  font-size: 1.7rem;
  line-height: 1.47;
  letter-spacing: 0.1em;
  color: #fff;
  background-color: #fc1223;
  padding: 25px 68px;
  margin-top: 30px;
  display: inline-block;
}
.advantage__img {
  width: 56%;
  max-width: 650px;
  margin-left: 40px;
  position: relative;
}
.advantage__img::before {
  content: "";
  display: block;
  padding-top: 69.23079%;
}
.advantage__img img {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.advantage__table {
  margin-top: 40px;
  width: 100%;
  letter-spacing: 0.12em;
  border-collapse: collapse;
}
.advantage__table th,
.advantage__table td {
  padding: 15px 20px;
  font-size: 1.7rem;
  line-height: 2.35;
  border: 1px solid #ccc;
  color: #000;
}
.advantage__table .advantage__table-title {
  text-align: center;
  color: #fff;
  background-color: #000;
  font-weight: 700;
  font-size: 2.3rem;
  line-height: 1.3;
}
.advantage__table .advantage__table-subtitle {
  text-align-last: left;
  background-color: #eee;
}
.advantage__table .advantage__table-subtitle:first-child {
  width: 245px;
}
.advantage__table .advantage__table-desc {
  line-height: 1.764;
}

/**********
機械設備
***********/
/* 工場レイアウト */
.layout {
  margin-top: 55px;
}
/* 主要設備一覧 */
.equipment-own {
  margin-top: 80px;
}
.equipment-own__table {
  margin-top: 20px;
  font-size: 1.7rem;
}
.equipment-own__table dl {
  padding: 15px 0;
}
.equipment-own__table .row1 {
  width: 34%;
}
.equipment-own__table .row2 {
  width: 40%;
}
.equipment-own__table .row3 {
  width: 20%;
}
.equipment-own__table .row4 {
  width: 6%;
  text-align: center;
}

/* 主要設備写真 */
.equipment-picture {
  margin-top: 90px;
}

/* 協力工場主要設備 */
.equipment-other {
  margin-top: 80px;
  margin-bottom: 95px;
}
.equipment-other__table {
  margin-top: 25px;
  display: flex;
  justify-content: space-between;
  font-size: 1.5rem;
}
.equipment-other__table-box {
  width: 48%;
  max-width: 577px;
}
.equipment-other__table dl {
  padding-top: 20px;
  padding-bottom: 16px;
}
.equipment-other__table-box .row1 {
  width: 56.5%;
}
.equipment-other__table-box .row2 {
  width: 36.5%;
}
.equipment-other__table-box .row3 {
  width: 7%;
  text-align: center;
}

/**********
加工実績
***********/
.products-picture {
  margin: 130px 0 140px;
}

/**********
会社概要
***********/
/* 会社概要 */
.overview {
  margin-top: 55px;
}
.overview__table {
  margin-top: 40px;
}
.overview__table dt {
  width: 24%;
  padding: 20px 30px;
}
.overview__table dd {
  width: 76%;
  padding: 20px 50px;
}
.overview__img-box {
  display: flex;
  justify-content: space-between;
  margin-top: 50px;
}
.overview__img {
  width: 48.333333%;
  max-width: 580px;
  position: relative;
}
.overview__img::before {
  content: "";
  display: block;
  padding-top: 68.965517%;
}
.overview__img img {
  position: absolute;
  top: 0;
  left: 0;
}

/* 交通アクセス */
.access {
  margin-top: 95px;
  margin-bottom: 120px;
}
.access__googlemap {
  margin-top: 50px;
  position: relative;
  width: 100%;
}
.access__googlemap::before {
  content: "";
  display: block;
  padding-top: 50%;
}
.access__googlemap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/**********
採用情報
***********/
/* 新卒募集要項 */
.new-graduate {
  margin-top: 50px;
  margin-bottom: 150px;
}
.new-graduate__news {
  background-color: #fc1223;
  color: #fff;
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  padding: 15px 20px;
  margin-top: 50px;
}
.new-graduate__table {
  margin-top: 65px;
  line-height: 1.3;
}
.new-graduate__table dt {
  width: 24%;
  padding: 20px 30px;
}
.new-graduate__table dd {
  width: 76%;
  padding: 20px 50px;
}

/* キャリア募集要項 */
.mid-career {
  margin-top: 140px;
  margin-bottom: 185px;
}
.mid-career__news {
  background-color: #fc1223;
  color: #fff;
  font-size: 2.5rem;
  font-weight: 700;
  text-align: center;
  padding: 15px 20px;
  margin-top: 45px;
}
.mid-career__table {
  margin-top: 65px;
  line-height: 1.3;
}
.mid-career__table dt {
  width: 24%;
  padding: 20px 30px;
}
.mid-career__table dd {
  width: 76%;
  padding: 20px 50px;
}

/**********
お問い合わせ
***********/
/* お問い合わせフォーム */
.form {
  margin-top: 50px;
}
.form__table {
  width: 81.6%;
  max-width: 980px;
  margin: 50px auto 0;
}
/* 必須マーク */
.must{
  font-size: 1.5rem;
  letter-spacing: 0.1em;
	color: #fff;
	padding: 7px 0;
	background: #bd2e2e;
	border-radius: 17.5px;
  width: 70px;
  height: 35px;
  text-align: center;
}
/* 各種指定 */
input, button, textarea {
  border: 1px solid #ccc;
  border-radius: 5px;
  padding: 5px;
}
.your-company input {
  width: 64%;
}
.your-name-last input,
.your-name-first input,
.your-name-kana-last input,
.your-name-kana-first input,
.your-post input {
  width: 31.5%;
}
.your-prefecture input,
.your-municipalities input,
.your-block input {
  width: 100%;
}
.your-tell input,
.your-email input,
.your-email_confirm input {
  width: 42%;
}
textarea {
  width: 85%;
  height: calc( 1.3em * 12 );
  line-height: 1.3;
}
.form__table dl {
  display: flex;
  border-top: 1px solid #ccc;
  padding: 25px 30px 27px;
  width: 100%;
}
.form__table .form-head {
  width: 20%;
  min-width: 180px;
}
.form__table dt {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-right: 30px;
  font-size: 1.5rem;
  letter-spacing: 0.001em;
}
.textarea .form-head {
  align-items: flex-start;
}
.form__table dd {
  width: 100%;
}
.form__table .post {
  justify-content: flex-end;
}
.form__table .address {
  display: block;
}
.address-items {
  display: flex;
  align-items: flex-start;
}
.address-item {
  display: flex;
}
.address-items .address-item {
  margin-top: 18px;
}
.address-item dt {
  justify-content: flex-end;
}
.form-sub {
  color: #999;
  white-space: nowrap;
  padding-left: 1em;
}
/* 送信,リセットボタン */
input.wpcf7-submit,
input[type="reset" i] {
  background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(224,224,224,1) 100%);
	font-size: 2rem;
  padding: 5px 15px;
  border: none;
	border-radius: 5px;
  text-shadow: 2px 2px 2px #fff;
	color: #000;
}
.form-btn {
  text-align: center;
}
input.wpcf7-submit {
  margin-right: 10px;
  font-size: 2.5rem;
}
input[type="reset" i] {
  font-size: 2.5rem;
  cursor: pointer;
}
/* スピナーを非表示 */
.wpcf7-spinner {
  display: none;
}


/* 個人情報保護方針 */
.privacy-policy {
  margin-top: 140px;
  margin-bottom: 110px;
}
.privacy-policy__table {
  width: 81.6%;
  max-width: 980px;
  margin: 50px auto 0;
}
.privacy-policy__table dl:not(:first-of-type) {
  margin-top: 50px;
}
.privacy-policy__table dt {
  font-size: 2.3rem;
  line-height: 1.3;
  color: #999;
}
.privacy-policy__table dd {
  line-height: 1.8;
  letter-spacing: 0.008em;
  margin-top: 20px;
}

.thanks_sec{line-height: 3.5rem; padding: 60px 0 80px; max-width: 1000px; margin: 0 auto; width: 90%;}


/**********
新設備ページ
***********/
.newfacilities_wrapper h2{
  margin-bottom: 40px;
}
.new_about{
  margin: 130px 0 80px;
}
.new_about_contents{
  display: flex;
  gap: 55px;
}
.new_about_txt{
  width: 50%;
}
.new_about_txt p{
  font-size: 1.8rem;
  line-height: 3.5rem;
  margin-bottom: 30px;
}
.new_size{
  margin-bottom: 60px;
}
.new_size_img{
  max-width: 740px;
  margin: 0 auto;
}
.new_advantage{
  margin-bottom: 90px;
}
.new_advantage_list{
  display: flex;
  column-gap: 60px;
  row-gap: 50px;
  flex-wrap: wrap;
}
.new_advantage_list li{
  width: calc((100% - 60px)/2);
}
.new_advantage_topic{
  font-family: heisei-kaku-gothic-std, sans-serif;
  font-weight: 900;
  font-size: 2.5rem;
  padding: 15px;
  background-color: #eee;
}
.new_advantage_list p{line-height: 3.5rem; font-size: 1.8rem;}
.new_img{margin-bottom: 85px;}
.new_img_list{display: flex; row-gap: 30px; column-gap: 40px; flex-wrap: wrap;}
.new_img_list li{width: calc((100% - 40px)/2);}
.new_img_list li img{width: 100%; height: auto;}


/* --------------------------------------------------------------------------
PC WIDE CSS　※PC：1420px
 ------------------------------------------------------------------------- */
@media (min-width: 1420px) {
  /* フォントサイズ10px */
  html {
    font-size: 62.5%;
    height: 100%;
  }
  /* 基本のフォントサイズ */
  body {
    font-size: 16px;
    font-size: 1.8rem;
    height: 100%;
  }
  /* 非表示用 */
  .nonePCWIDE {
    display: none !important;
  }
  /**********************
  共通 
  ***********************/
  .header {
    height: 120px;
  }
  .header__inner--right {
    height: inherit;
  }
  .global-nav {
    height: inherit;
  }
  .global-nav__list-item {
    height: inherit;
  }
  .global-nav__contact {
    width: 120px;
    height: inherit;
  }

  .newfacilities_wrapper .page-content{width: initial;}

}

/* --------------------------------------------------------------------------
PC CSS　※PC：1025px～1419px　※印刷用はPC CSSを大体利用する
 -------------------------------------------------------------------------- */
@media print, (max-width: 1419px) {
  /* フォントサイズ10px */
  html {
    font-size: 62.5%;
  }
  /* 基本のフォントサイズ */
  body {
    font-size: 16px;
    font-size: 1.8rem;
  }
  /* 非表示用 */
  .nonePC {
    display: none !important;
  }
  /**********************
  共通 
  ***********************/
  .inner {
    padding: 0 30px;
  }
  .header-company-logo__main {
    font-size: 3.4rem;
  }
  .global-nav__list-item {
    width: initial;
  }
  .global-nav__link {
    padding: 35px 10px;
  }
  .global-nav__tel {
    display: block;
  }
  .global-nav__tel-icon {
    display: block;
    margin: 0 auto;
  }
  .global-nav__tel-link {
    padding: 5px 10px;
  }
  .global-nav__tel-num {
    font-size: 2.3rem;
  }
  .global-nav__contact {
    padding: 0 20px;
    width: initial;
  }
  .global-nav__contact 
  .card01 {
    width: 50%;
  }
  .page-content {
    width: 90%;
    max-width: 1300px;
  }
  /* 写真とキャプションのカード群 */
  .picture-card__caption {
  font-size: 1.5rem;
  }
  /* ページタイトル */
  .page-title__copy-en {
    font-size: 2.5rem;
  }
  .page-title__copy-main {
    font-size: 5rem;
  }
  /* アイキャッチ */
  .eyecatch__box {
    width: 100%;
    padding: 0 30px;
  }
  /* フッター */
  .footer {
    padding: 20px 0;
  }
  .footer .content {
    display: block;
  }
  .copyright {
    text-align: center;
    margin-top: 30px;
  }

.footer_logo{ margin: 0 0 0 20px; }

  /**********************
  トップページ 
  ***********************/
  /* メインビュー */
  .main-view__copy {
    padding: 0 30px;
  }
  .main-view__copy-main {
    font-size: 8rem;
  }
  .main-view__copy-sub {
    font-size: 4rem;
  }
  .main-view_topic_img{
    right: 3%;
    bottom: -30px;
  }
  .main-view_topic_img img{
    width: 80%;
    height: auto;
    margin: 0 0 0 auto;
  }

  /* 梶川の技術 */
  .top-techno {
    padding: 90px 30px;
  }
  .top-techno .section__title {
    font-size: 7rem;
  }
  .top-techno .section__title-sub {
    font-size: 3rem;
  }
  .top-techno::before {
    background: linear-gradient(to bottom, #222222, #222222 45%, rgba(34, 34, 34, 0.9) 55%, rgba(34, 34, 34, 0.8) 65%, rgba(255, 255, 255, 0));
  }
  /* 採用情報 */
  .top-recruit__box {
    padding-left: 30px;
    padding-right: 30px;
  }
  .top-recruit .section__title {
    font-size: 5rem;
  }
  .top-recruit .section__title-sub {
    font-size: 2.5rem;
  }
  /**********************
  梶川の技術 
  ***********************/
  .advantage__title {
    font-size: 4rem;
  }
  .wrap-advantage__table {
    overflow-x: scroll;
  }
  .advantage__table {
    min-width: 1400px;
  }
  /**********************
  機械設備
  ***********************/
  .equipment-own__table {
    font-size: 1.5rem;
  }
  .equipment-other__table {
    font-size: 1.3rem;
  }
  /**********************
  加工実績 
  ***********************/
  /**********************
  会社概要
  ***********************/
  /**********************
  採用情報
  ***********************/
  /**********************
  お問い合わせ 
  ***********************/

}

/* --------------------------------------------------------------------------
  TAB CSS　※タブレット：681px～1024px
 -------------------------------------------------------------------------- */
@media (max-width: 1024px) {
  /* フォントサイズ10px=62.5% */
  html {
    font-size: 50%;
  }
  /* 基本のフォントサイズ */
  body {
    font-size: 1.8rem;
  }
  /* 非表示用 */
  .noneTAB {
    display: none !important;
  }
  /**********************
  共通 
  ***********************/
  .header {
    position: fixed;
    width: 100%;
    top: 0;
    left: 0;
  }
  .header__inner {
    padding-left: 30px;
    padding-right: 60px;
  }
  .global-nav {
    display: none;
  }
  .global-nav__tel {
    display: none;
  }
  .global-nav__contact {
    display: none;
  }
  .burger-btn {
    cursor: pointer;
    display: inline-block;
    width: 35px;
    height: 35px;
    position: absolute;
    right: 30px;
    top: 50px;
  }
  .burger-btn__bar {
    width: 35px;
    height: 5px;
    background-color: #fff;
    border-radius: 5px;
    right: 30px;
    z-index: 100;
  }
  .bar01 {
    position: absolute;
    top: 0;
    right: 0;
    transition: transform .5s;
  }
  .bar02 {
    position: absolute;
    top: 10px;
    right: 0;
    transition: transform .5s;
  }
  .bar03 {
    position: absolute;
    top: 20px;
    right: 0;
    transition: transform .5s;
  }
  .bar01.js-close {
    transform: translate(0, 0.375rem) rotate(45deg);
    transition: transform .5s;
    top: 10px;
  }
  .bar02.js-close {
    opacity: 0;
    transition: opacity .5s;
  }
  .bar03.js-close {
    transform: translate(0, -0.375rem) rotate(-45deg);
    transition: transform .5s;
    top: 17px;
  }
  .modal {
    background-color: #fc1223;
    width: 100%;
    height: 100vh;
    position: fixed;
    padding-top: 140px;
    z-index: 99;
    overflow-y: scroll;
    /* IE, Edge 対応 */
    -ms-overflow-style: none;
    /* Firefox 対応 */
    scrollbar-width: none;    
  }
  /* Chrome, Safari 対応 */
  .modal::-webkit-scrollbar { 
    display:none;
  }
  .modal-nav {
    position: relative;
    text-align: center;
    align-items: center;
    vertical-align: middle;
    height: 100%;
  }
  .modal-nav__list {
    width: 100%;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    font-size: 2.5rem;
    font-weight: 300;
    letter-spacing: 2px;
    color: #fff;
    padding: 30px 0;
  }
  .modal-nav__item {
    border-bottom: .5px solid #ddd;
  }
  .modal-nav__item:not(:first-of-type) {
    margin-top: 20px;
  }
  .modal-nav__link {
    display: inline-block;
    width: 100%;
    height: 100%;
  }
  .eyecatch {
    margin-top: 120px;
  }
  .page-content {
    width: 100%;
  }
  .card01 {
    width: 80%;
    max-width: none;
  }
  .card01__text-box {
    padding: 38px 30px;
  }
  .card01__link {
    padding: 20px 10px;
  }
  .card02__text-box {
    padding: 35px 10px 20px;
  }
  .card02__text {
    margin-top: 20px;
    line-height: 2;
  }
  .card02__link {
    padding: 20px 10px;
  }
  .table02 {
    font-size: 1.5rem;
  }
  /* ページタイトル */
  .page-title__copy-en {
    font-size: 1.8rem;
  }
  /**********************
  トップページ 
  ***********************/
  /* メインビュー */
  .main-view {
    margin-top: 120px;
  }
  .main-view__copy-en {
    font-size: 2rem;
  }
  .main-view__copy-main {
    font-size: 6rem;
  }
  .main-view__copy-sub {
    font-size: 3rem;
  }
  .main-view_topic_img{
    bottom: -60px;
  }
.main-view_topic_img img{
  width: 200px;
  height: auto;
}


  /* 梶川の技術 */
  .top-techno .section__title {
    font-size: 5rem;
  }
  .top-techno .section__title-sub {
    font-size: 2.5rem;
  }
  /* 採用情報 */
  .top-recruit {
    height: 350px;
  }
  .top-recruit .section__title {
    font-size: 3rem;
  }
  .top-recruit .section__title-sub {
    font-size: 1.8rem;
  }
  .top-recruit .top-recruit__text {
    line-height: 1.6;
  }
  /**********************
  梶川の技術 
  ***********************/
  .advantage__list-style {
    width: 130px;
    height: 130px;
    padding: 20px 0;
  }
  .advantage__title {
    font-size: 3rem;
  }
  .advantage__link {
    padding: 25px 10px;
    width: 100%;
    text-align: center;
  }
  .advantage__table {
    min-width: 1024px;
  }
  .advantage__table .advantage__table-subtitle:first-child {
    width: 180px;
  }
  .advantage__table th, 
  .advantage__table td {
    padding: 5px 10px;
    font-size: 1.3rem;
  }
  /**********************
  機械設備
  ***********************/
  .equipment-other__table {
    display: block;
  }
  .equipment-other__table-box {
    width: 100%;
    margin: 0 auto;
  }
  
  /**********************
  加工実績
  ***********************/
  /**********************
  会社概要 
  ***********************/
  /**********************
  採用情報 
  ***********************/
  /**********************
  お問い合わせ 
  ***********************/
  .form__table dl {
    display: block;
    padding: 15px 10px;
  }
  .form__table dd {
    margin-top: 10px;
  }
  .address-items {
    display: block;
  }
  .address-items .address-item {
    margin-top: 8px;
  }
  .form__table {
    margin-top: 30px;
    width: 100%;
  }
  .address-item {
    display: block;
  }
  .form__table dt {
    display: block;
  }
  .must {
    padding: 3px 10px;
    margin-right: 5px;
  }
  .your-company input {
    width: 100%;
  }
  .your-name-last input,
  .your-name-first input,
  .your-name-kana-last input,
  .your-name-kana-first input,
  .your-post input {
    width: 49%;
  }
  .your-tell input,
  .your-email input,
  .your-email_confirm input {
    width: 100%;
  }
  input, textarea {
    width: 100%;
  }
  button {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
  input.wpcf7-submit {
    margin-right: 0;
    font-size: 2rem;
  }
  input[type="reset" i] {
    margin-top: 10px;
    font-size: 2rem;
  }
  .form-btn {
    max-width: 300px;
    margin: 0 auto;
  }


/**********
新設備ページ
***********/
.new_about{
  margin: 60px 0;
}
.new_about_contents{
  gap: 40px;
  flex-direction: column;
}
.new_about_txt{
  width: 100%;
}
.new_about_img{
  width: 100%;
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}
.new_about_img iframe{
 position: absolute;
 top: 0;
 width: 100%;
 height: 100%;
}

.new_advantage{
  margin-bottom: 60px;
}
.new_advantage_list{
  column-gap: 40px;
  row-gap: 40px;
}
.new_advantage_list li{
  width: calc((100% - 40px)/2);
}




}

/* --------------------------------------------------------------------------
SP CSS　※スマートフォン：0～680px
 ------------------------------------------------------------------------- */
@media (max-width: 680px) {
  /* フォントサイズ10px=62.5% */
  html {
    font-size: 60%;
  }
  /* 基本のフォントサイズ */
  body {
    font-size: 1.6rem;
    height: auto !important;
    height: 100%;
  }
  /* 非表示用 */
  .noneSP {
    display: none !important;
  }
  /**********************
  共通 
  ***********************/
  .cards {
    display: block;
  }
  .card01 {
    width: 100%;
    margin-top: 30px;
  }
  .card01__text-box {
    padding: 28px 20px;
  }
  .card01__text {
    line-height: 1.6;
  }
  .card02 {
    width: 100%;
    max-width: none;
  }
  .card02:not(:first-of-type) {
    margin-top: 50px;
  }
  .card02__title {
    font-size: 3rem;
  }
  .card02__title-sub {
    font-size: 1.5rem;
  }
  .company-logo__main {
    font-size: 2.4rem;
  }
  .company-logo__sub {
    font-size: 1.4rem;
  }
  /* ボタン */
  .btn__link {
    max-width: initial;
  }

  /* 写真とキャプションのカード群 */
  .picture-card:not(:nth-child(3n)) {
    margin-right: 0;
  }
  .picture-card:not(:nth-child(2n)) {
    margin-right: 10px;
  }
  .picture-card:nth-child(n + 4) {
    margin-top: 0;
  }
  .picture-card:nth-child(n + 3) {
    margin-top: 20px;
  }
  .picture-card {
    width: calc((100% - 10px) / 2);
  }
  .picture-cards {
    margin: 30px auto 0;
  }
  .picture-card__caption {
    margin-top: 5px;
  }
  /* ページ内リンク */
  .page-link {
    margin-top: 50px;
  }  
  .page-link__box {
    display: block;
    padding: 20px 10px;
  }
  .page-link__item {
    display: block;
    font-size: 1.6rem;
  }
  .page-link__item:not(:first-child) {
    margin-top: 15px;
  }
  .page-link__item:not(:last-child) {
    margin-right: 0;
  }
  /* ヘッダー */
  .header {
    height: 100px;
  }
  .header-company-logo {
    padding: 15px 0;
  }
  .burger-btn {
    top: 35px;
  }
  .header-company-logo__main {
    padding: 46px 0;
  }
  .header-company-logo__ja,
  .footer-company-logo__ja {
    font-size: 1.2rem;
  }
  .modal-nav__list {
    font-size: 2rem;
  }
  .breadcrumbs {
    margin-top: 0;
  }
  .eyecatch {
    margin-top: 100px;
  }
  /* ページタイトル */
  .page-title__copy-en {
    font-size: 1.5rem;
  }
  .page-title__copy-main {
    font-size: 2.6rem;
  }
  /* セクションタイトル */
  .page-section__title {
    font-size: 2.5rem;
  }
  .page-section__title::after {
    width: 1em;
    right: -1em;
  }
  /* フッター */
  .footer__text-box {
    display: block;
  }
  .footer-company-logo {
    margin-right: 0;
  }
  .footer-info {
    margin-top: 20px;
  }

.footer_logo{ background-color: #fff; width: 125px; height: 125px; margin: 20px auto 0 auto; }
.footer_logo img{ width: 125px; height: 125px; padding: 10px; }


  /**********************
  トップページ 
  ***********************/
  /* メインビュー */
  .main-view {
    margin-top: 100px;
  }
  .main-view__copy {
    padding: 0;
  }
  .main-view__copy-en {
    font-size: 1rem;
  }
  .main-view__copy-main {
    font-size: 3.5rem;
  }
  .main-view__copy-sub {
    font-size: 1.6rem;
  }
  .main-view_topic_img{
    bottom: -80px;
  }
.main-view_topic_img img{
  width: 140px;
  height: auto;
}

  /* 梶川の技術 */
  .top-techno {
    padding: 50px 30px;
  }
  .top-techno .section__title {
    font-size: 3rem;
  }
  .top-techno .section__title-sub {
    font-size: 1.5rem;
  }
  /* 3カラムコンテンツ */
  .top-site-contents {
    padding-top: 60px;
    padding-bottom: 60px;
  }
  /* 採用情報 */
  .top-recruit {
    display: block;
    height: initial;
  }
  .top-recruit__img {
    width: 100%;
  }
  .top-recruit .section__title-sub {
    font-size: 1.5rem;
  }
  .top-recruit__box {
    width: 100%;
    padding: 20px 30px 40px;
  }
  /**********************
  梶川の技術 
  ***********************/
  .advantage {
    margin-top: 70px;
  }
  .advantage_item:not(:first-of-type) {
    margin-top: 60px;
  }
  .advantage__head {
    display: block;
  }
  .advantage__list-style {
    margin-right: 20px;
    width: 110px;
    height: 110px;
    padding: 15px 0;
  }
  .advantage__en {
    font-size: 1.5rem;
  }
  .advantage__num {
    font-size: 6rem;
  }
  .advantage__title {
    font-size: 2.6rem;
    margin-top: 20px;
  }
  .advantage__body {
    flex-direction: column-reverse;
    margin-top: 20px;
  }
  .advantage__text-box {
    width: 100%;
  }
  .advantage__text {
    margin-top: 10px;
    line-height: 2;
  }
  .advantage__link {
    margin-top: 20px;
  }
  .advantage__img {
    width: 100%;
    margin: 0 auto;
  }
  /**********************
  機械設備
  ***********************/
  .layout {
    margin-top: 50px;
  }
  .wrap-equipment-own__table {
    overflow: scroll;
  }
  .equipment-own__table {
    margin-top: 20px;
    min-width: 680px;
  }
  .equipment-own__table dl {
    padding: 5px 0;
  }
  .equipment-picture {
    margin-top: 70px;
  }
  .equipment-other {
    margin-top: 70px;
    margin-bottom: 100px;
  }
  .wrap-equipment-other__table {
    overflow: scroll;
  }
  .equipment-other__table {
    margin-top: 20px;
    min-width: 620px;
  }
  .equipment-other__table-box {
    max-width: initial;
  }
  .equipment-other__table dl {
    padding: 5px 0;
  }
  /**********************
  加工実績
  ***********************/
  .products-picture {
    margin: 50px 0 100px;
  }
  .products-picture-cards .products-picture-card {
    width: 100%;
    margin: 0 auto;
  } 
  .products-picture-card:not(:first-child) {
    margin-top: 30px;
  }
  /**********************
  会社概要 
  ***********************/
  .overview {
    margin-top: 50px;
  }
  .overview__table {
    margin-top: 20px;
  }
  .table02 dl {
    display: block;
  }
  .table02 dt,
  .table02 dd {
    width: 100%;
  }
  .table02 dt {
    padding: 10px;
  }
  .table02 dd {
    padding: 10px 20px;
  }
  .access {
    margin-top: 50px;
    margin-bottom: 100px;
  }
  .access__googlemap {
    margin-top: 30px;
  }
  /**********************
  採用情報 
  ***********************/
  .new-graduate {
    margin-top: 50px;
    margin-bottom: 100px;
  }
  .new-graduate__news {
    margin-top: 30px;
    font-size: 1.6rem;
  }
  .new-graduate__table {
    margin-top: 20px;
  }
  .mid-career {
    margin-top: 50px;
    margin-bottom: 100px;
  }
  .mid-career__news {
    margin-top: 30px;
    font-size: 1.6rem;
  }
  .mid-career__table {
    margin-top: 20px;
  }
  /**********************
  お問い合わせ 
  ***********************/
  .privacy-policy {
    margin-top: 50px;
    margin-bottom: 100px;
  }
  .privacy-policy__table {
    width: 90%;
    margin-top: 20px;
  }
  .privacy-policy__table dt {
    font-size: 2rem;
  }
  .privacy-policy__table dd {
    margin-top: 10px;
  }
  .privacy-policy__table dl:not(:first-of-type) {
    margin-top: 30px;
  }

/**********
新設備ページ
***********/
.newfacilities_wrapper h2{
  margin-bottom: 20px;
}
.new_about{
  margin: 50px 0 60px;
}
.new_about_contents{
  flex-direction: column;
  gap: 20px;
}
.new_about_txt{
  width: 100%;
}
.new_about_img{
  width: 100%;
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}
.new_about_img iframe{
 position: absolute;
 top: 0;
 width: 100%;
 height: 100%;
}
.new_about_txt p{
  margin-bottom: 20px;
}
.new_advantage{
  margin-bottom: 60px;
}
.new_advantage_list{
  flex-direction: column;
  row-gap: 40px;
}
.new_advantage_list li{
  width: 100%;
}
.new_img_list{
  flex-direction: column;

}
.new_img_list li{
  width: 100%;
}



}
