@charset "utf-8";
@media screen and (min-width: 768px) and (max-width: 1024px) {

/*-- ヘッダータイトル --*/
.sb-business-title{
	margin-top: 130px;
}
/* 共通
  ------------------------------------------------------------*/
	body {
  overflow-x: hidden;
}
	.br-pc{
	display: none;
}

  .br-mid{
	display: block;
}
  .br-sp{
	display: none;
}
/*========= ヘッダーナビ ===============*/
.header-nav{
	display: none;
}

/*========= 三本線 ===============*/
  .openbtn{
    display: block;
  }
	.openbtn{
		position:fixed;
		z-index: 888;/*ボタンを最前面に*/
		top:10px;
		right: 10px;
		cursor: pointer;
		width: 50px;
		height:50px;
	}

  /*×に変化*/
	.openbtn span{
		display: inline-block;
		transition: all .4s;
		position: absolute;
		left: 14px;
		height: 1px;
		border-radius: 2px;
		background-color: #666;/*カラー*/
		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;
		}
  /*end//三本線の高さ*/

	.openbtn.active span:nth-of-type(1) {
			top: 18px;
			left: 18px;
			transform: translateY(6px) rotate(-45deg);
			width: 30%;
			background-color: #fff;/*カラー*/
	}
	.openbtn.active span:nth-of-type(2) {
		opacity: 0;
		background-color: #fff;/*カラー*/
	}
	.openbtn.active span:nth-of-type(3){
		top: 30px;
		left: 18px;
		transform: translateY(-6px) rotate(45deg);
		width: 30%;
		background-color: #fff;/*カラー*/
	}


/*========= TOPマーク ===============*/
	.top-mark{
		display: block;
		}
	.top-mark{
		position:fixed;
		z-index: 888;/*ボタンを最前面に*/
		bottom:30px;
		right: 30px;
		width: 40px;
		height:40px;
		opacity: 0.8;
	}

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

#g-nav{
	display: block;

	/*position:fixed;にし、z-indexの数値を大きくして前面へ*/
	position:fixed;
	z-index: 100;
	/*ナビのスタート位置と形状*/
	top:0;
	right: -100%;
	width:100%;
	height: 100vh;/*ナビの高さ*/
	background:#fff;/*ナビ背景色*/
	opacity: 0.8;
	/*動き*/
	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:50%;
        left:50%;
        transform: translate(-50%,-50%);
    }

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

    #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-family: "Zen Kaku Gothic New", sans-serif;
			font-weight: 600;
			font-style: normal;
    }

    /*ホバー半透明*/
    #g-nav li a:hover{
				opacity: 0.5;
    }


/*--------------------------------------------------------
  メインビジュアル
--------------------------------------------------------*/


	/*ロゴ*/
.top-logo{
	position: absolute;
	z-index: 20;
	top: 20px;
	left: 5%;
	width: 95%;
}

.top-content{
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	font-style: normal;
	font-size: 12px;
	letter-spacing: -0.02em;
}

.top-logomark{
	width:30%;
	margin-top: 5px;
}


/* 事業内容<screws.html>
------------------------------------------------------------*/

#sb-business{
	margin-top: 180px;	
}
.sb-business-bar{
	height: 18px;
	background-color: #333;
}
.sb-business-back{
	width: 100%;
	height: 250px;
}

.sb-business-back-sp{
	display: none;
}
.sb-business-back img{
	object-fit: cover;
	height: 250px;
}

.sb-business-title-inner{
	width: 70%;
	margin: 0 auto;
	margin-top: -220px;
	margin-bottom: 160px;
}

.sb-business-title-inner2{
	width: 70%;
	margin: 0 auto;
	margin-top: -145px;
	text-align: center;
	font-size: 38px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
}

/*-- キャッチコピー --*/
.sb-business-headline-section{
	width: 90%;
	margin: 100px auto 80px;
}
.sb-business-headline{
	text-align: center;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	font-size: 28px;
	line-height: 2em;
}
.sb-business-body{
	max-width: 930px;
	margin: 40px auto;
	line-height: 2em;
	font-size: 18px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	font-style: normal;
	text-align: justify;
}

/*-- 製品（共通箇所あり） --*/
.product-spec {
   width: 90%;
  margin: 60px auto 100px;
}
.product-spec-title {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
  background-color: #777;
  color: #fff;
  font-size: 21px;
  text-align: center;
  padding: 20px 0;
  margin-bottom: 40px;
}

.product-spec-label {
	background-color: #eee;
  width: 100%;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	font-size: 20px;
  margin-bottom: 8px;
  padding: 10px 40px;
}

.product-spec-content {
  width: 100%;
  line-height: 1.8;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	font-size: 20px;
  margin-bottom: 20px;
  padding: 6px 40px;
}


/*ネジ小物部品
------------------------------------------------------------*/
.product-spec-inner-image{
  width: 90%;
  margin: 60px auto 100px;
}

/*-- イメージ（共通箇所あり）  --*/
.sb-business-img-container{
	width: 100%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 auto;
	height: 280px;
}
.sb-business-img-item{
	width: 50%;
	height: 280px;
}
.sb-business-img-item img{
	object-fit: cover;
	height: 280px;
}
/*-- 強み（共通箇所あり）  --*/
.sb-business-feature{
	width: 100%;
	background-color: #09adad;
	padding-bottom: 40px;
}
.sb-business-feature-title{
	text-align: center;
	padding-top: 80px;
	font-size: 32px;
	color: #fff;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
}
.sb-business-feature-container{
	width: 90%;;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 40px auto;
}
.sb-business-feature-item{
	width: 48%;
	padding: 60px 30px;
	background-color: #fff;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	text-align: center;
	align-items: center;
	font-size: 21px;
	box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* 控えめなシャドウ */
	 display: flex;               /* 追加 */
  flex-direction: column;      /* 追加 */
  justify-content: center;     /* 追加 */
  align-items: center;         /* 追加 */
  text-align: center;          /* 既にOK */
}
.sb-business-feature-item2{
	width: 100%;
	padding-top: 60px;
	background-color: #fff;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	text-align: center;
	align-items: center;
	font-size: 21px;
}
.sb-business-feature-item2-sp{
	display: none;
}

.sb-business-feature-item2-text{
	width: 100%;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	text-align: center;
	align-items: center;
}

/*----- よくあるご相談-------*/
/*-- ねじ販売 --*/
.sb-business-consult{
	width: 100%;
	background-image:url("../business/images/sb-business-back.jpg");
	background-size: cover;
	background-position: center center; /* ←これを追加 */
	height: auto;
	padding-bottom: 60px;
}
/*-- ツール販売用 --*/
.sb-business2-consult{
	width: 100%;
	background-image:url("../business/images/sb-business2-back.jpg");
	background-size: cover;
	background-position: center center; /* ←これを追加 */
	height: auto;
	padding-bottom: 60px;
}
/*-- 部品製作用 --*/
.sb-business3-consult{
	width: 100%;
	background-image:url("../business/images/sb-business3-back.jpg");
	background-size: cover;
	background-position: center center; /* ←これを追加 */
	height: auto;
	padding-bottom: 60px;
}

.sb-business-consult-title{
	text-align: center;
	padding-top: 100px;
	font-size: 32px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
}
.sb-business-consult-inner{
	width: 90%;
  margin: 40px auto;
  background-color: #fff;
  opacity: 0.8;
  padding-bottom: 20px;
  padding-top: 20px;
}

.sb-business-consult-question{
	width: 90%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
	margin: 10px auto 10px;
	padding-top: 40px;
}
.sb-business-consult-question-2{
	width: 90%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: space-between;
	margin: 30px auto 10px;
}
.sb-business-consult-q{
	width: 10%;
	background-color: #09adad;
	padding: 20px;
	text-align: center;
	font-size: 24px;
	font-family: "Roboto", sans-serif;
	font-weight: 700;
	font-style: normal;
	color: #fff;
}
.sb-business-consult-content{
	width: 90%;
	background-color: #cccccc;
	font-size: 18px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
	padding: 20px;
}
.sb-business-consult-answer{
	width: 90%;
	margin: 0px auto;
	padding-left: 30px;
	padding-right: 30px;
	font-size: 18px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	line-height: 2em;
}
.sb-business-consult-answer-2{
	width: 90%;
	margin: 0px auto;
	padding-left: 30px;
	padding-right: 30px;
	font-size: 18px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	line-height: 2em;
	padding-bottom: 20px;
}
.sb-business-bottom{
	margin: 100px auto 0px;
	text-align: center;
	font-size: 20px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	line-height: 2.4em;
}





/*部品制作　加工工程のフロー
------------------------------------------------------------*/
.process-container{
  position: relative;
  max-width: 1200px;
  width: 90%;
  margin: 0 auto;
  padding: 10px 45px 80px;
  background: #00a6a6; /* 背景色が必要 */
}
.process-container-inner{
margin: 0 auto;
background-color: #fff;
}
.process-container-text{
  text-align: center;
  font-size: clamp(20px, 2vw + 16px, 30px);
	color: #fff;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
  padding-top: 65px;
  margin-bottom: 35px;
}


.process-container-inner-sp{
  display: none;
}

.btn-business-4 {
  display: inline-block;
  background-color:#fff; 
  color: #00a6a6;
  text-align: center;
  width: 50%;
	margin: 0 auto;
  padding: 15px 100px;
  text-decoration: none;
  border-radius: 30px;
  font-size: 20px;
  font-weight: bold;
  transition: background-color 1s ease;
}
.btn-business-4 a {color:#006666;}
.btn-business-4 a:link {color:#006666;}
.btn-business-4 a:visited {color:#006666;}
.btn-business-4 a:active {color:#006666;}

.btn-business-4:hover {
  background-color: #fff;;
  color:  #006666;
  transition: 1.0s ease;
opacity: 0.5;
}

/*部品制作　製作事例 
------------------------------------------------------------*/
.case-studies {
  background-color: #eee;
  padding: 60px 0 150px;
	margin-top: 100px;
}

.case-studies-inner {
  width: 90%;
  margin: 60px auto 100px;
}



.case-studies-image img {
  width: 100%;
  height: auto;
  margin-bottom: 30px;
}
.case-studies-inner-image{
	width: 90%;
  margin: 0 auto;
}

.thumb-grid {
  text-align: center;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
}

.thumb-grid img {
  width: 100%;
  height: auto;
  display: block;
}

/* メーカー一覧ページ
------------------------------------------------------------*/
/* リード文 */
.maker-lead-text {
  text-align: center;
  margin-bottom: clamp(40px, 8vw, 80px);
  line-height: 1.8;
  font-size: 18px;
  color: #333;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
}

/* 行選択ボタン */
.maker-kana-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(18px, 2vw, 35px) clamp(10px, 2vw, 18px);
  margin-bottom: clamp(40px, 8vw, 80px);
  max-width: 1000px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

/* 共通：スマホは自動 */
.maker-kana-nav .kana-btn {
  flex: 1 1 48%;        /* スマホは2列くらい */
  text-align: center;
  padding: clamp(14px, 1vw, 10px) 0;
  background: #00a19a;
  color: #fff;
  border-radius: clamp(33px, 2vw, 25px);
  text-decoration: none;
  font-weight: 700;
  font-size: 16px;
  transition: background 0.3s ease;
}


/* 会社案内
------------------------------------------------------------*/
.sb-business-consult{
	width: 100%;
	background-image:url("../business/images/sb-business-back.jpg");
	background-size: cover;
	background-position: center center; /* ←これを追加 */
	height: auto;
	padding-bottom: 60px;
}

/* 会社案内
------------------------------------------------------------*/
/* 会社案内セクション共通設定 */
#sb-company {
  margin-top: 180px;
}

.sb-company-title-inner {
	margin-top: -160px;
	margin-left: 44%;
	font-size: 38px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 700;
}


.sb-company-message {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  margin-bottom: 1100px;
  flex-wrap: nowrap;
}

/* 画像：左寄せ、幅40% */
.sb-company-message-image {
  width: 50%;
  position: relative;
  z-index: 2;
}

/* テキストブロック：画像より100px下・右側に重ねる */
.sb-company-message-text-block {
  background-color: #eee;
  padding:  20% 90px 100px;
  position: absolute;
  top: 45%;
  left: 8%;
  z-index: 1;
  box-sizing: border-box;
  width: 92%;
}

/* その他既存の設定はそのままでOK */
.sb-company-message-text-inner {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
.sb-company-message-title-jp {
  font-size: 32px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  padding: 0 10px;
}

.sb-company-message-title-eg {
  font-size: 18px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: bold;
  color: #09adad;
  padding: 0 10px;
}
.company-message-line {
  border: 0.5px solid #09adad;
  margin: 10px 0;
  width: 100%;
}

.sb-company-message-text-inner p {
  margin-top: 50px;
  font-size: 16px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  line-height: 2.2em;
  padding-left: 10px;
	text-align: justify;
}

/*-- 会社概要 --*/
.sb-company-history{
	width: 100%;
	background-image:url("../company/images/sb-company-history-bg.jpg");
	background-size: cover;
	 background-position: center;  /* 画像を縦横中央に配置 */
	height: auto;
	padding-bottom: 120px;
}

.sb-company-history-text-inner{
	width: 350px;
  margin: 40px auto;
  padding-bottom: 20px;
  padding-top: 100px;
	text-align: center;
}

/* テーブル全体のラッパー */
.sb-company-history-inner-table {
  width: 85%;
  margin: 0 auto;
  padding: 0 15px;
}

/* テーブル基本設定 */
.company-profile-table {
  width: 100%;
  border-collapse: collapse;
  border-radius: 8px;
  overflow: hidden;
  font-size: 18px;
	font-weight: 500;
}

/* ヘッダーセル */
.company-profile-table th {
  width: 30%;
  text-align: left;
  padding: 30px 16px;
  border-bottom: 1px solid #ddd;
}

/* データセル */
.company-profile-table td {
  padding: 12px 16px;
  border-bottom: 1px solid #ddd;
}

}
