@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Outfit:wght@100..900&family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&display=swap');
/* CSS Document */
body {
  padding-top: 97px;
}
.main-wrap {
  overflow: hidden;
}
.center-logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  z-index: 10;
  width: 100%;
  max-width: 650px;
}
/* section02 */
.section02 .center-logo {
  background: none;
  box-shadow: none;
  width: 168px;
  height: 168px;
}
.section02 .center-logo img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  z-index: 1;
}
.section02 .center-logo p {
  position: relative;
  z-index: 2;
  text-align: center;
  font-weight: bold;
  margin-top: 20px;
}
.section02 {
  position: relative;
  z-index: 1;
  gap: 50px;
  min-height: 1000px;
  overflow: visible;

}
.section02 .circle-area {
  position: relative;
  width: clamp(450px, 40vw, 500px);
  height: clamp(450px, 40vw, 500px);
}
body.on .section02 .circle-area {
pointer-events: none;
}

.section02 .circle-area .bg-line {
  position: absolute;
  width: 80%;
  height: auto;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.section02 .circle {
  position: absolute;
  width: 140px;
  height: 140px;
  background: white;
  border-radius: 50%;
  box-shadow: 0 0 0 2px #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  z-index: 2;
  padding: 10px;
}
.section02 .circle img {
  width: 60px;
  height: auto;
  margin-bottom: 6px;
}
/* 各円の配置 */
.section02 .forestry {
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}
.section02 .material {
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
.section02 .building {
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
.section02 .farm {
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.section02 .text-area {
  max-width: clamp(300px, 40vw, 500px);
}
/* 背景黒、白文字 */
.cate-title {
  background: #000;
  color: #fff;
  padding: 6px 12px;
  font-weight: bold;
  display: inline-block;
}
/* 背景画像 */
.bg-wrap {
  background-image: url('https://saitozaimokuten.co.jp/system_panel/uploads/images/bgimg.png');
  background-repeat: no-repeat;
  background-position: center 450px;
  background-size: 100% cover;
}
.bg-wrap .main-wrap {
  background-image: url('https://saitozaimokuten.co.jp/system_panel/uploads/images/bgimg2.jpg');
  background-repeat: repeat-y;
  background-position: center 0px;
  background-size: 100% cover;
}
/* 背景画像 */
/* product-area */
.product-area {
  text-align: center;
  color: #fff;
  position: relative;
}
.cate5 {
  background-color: #84968A;
}
.product-title {
  position: relative;
  display: inline-block; /* 必須 */
  text-align: center;
}
.product-title::before, .product-title::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 90px;
  height: 90px;
  background-size: contain;
  background-repeat: no-repeat;
  transform: translateY(-50%);
}
/* 左の画像 */
.product-title::before {
  left: -110px;
  background-image: url('https://saitozaimokuten.co.jp/system_panel/uploads/images/smoke-l.png');
}
/* 右の画像 */
.product-title::after {
  right: -110px;
  background-image: url('https://saitozaimokuten.co.jp/system_panel/uploads/images/smoke-r.png');
}
.product-title span {
  font-size: 1.5em;
  font-weight: bold;
}
.product-desc {
  color: #fff;
  margin-bottom: 40px;
}
.product-list-wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
.product-list {
  flex-wrap: nowrap;
  gap: clamp(20px, 5vw, 60px);
}
.product-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: calc(100% / 5 - 20px); /* 初期: 5列想定 */
  max-width: 200px;
}
.product-item .imgwrap {
  width: clamp(120px, 15vw, 170px);
  height: clamp(120px, 15vw, 170px);
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid #000;
}
.product-item .imgwrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 20%;
  transform: scale(1.3);
  transform-origin: center;
}
.product-item p {
  margin-top: -10px;
  background: #000;
  color: #fff;
  padding: clamp(4px, 1vw, 8px) clamp(12px, 2vw, 20px);
  font-weight: bold;
  letter-spacing: 0.1em;
  z-index: 3;
}
.product-area .link-button {
  position: absolute;
  top: 35%;
  right: -30px;
  transform: translateY(-50%);
  z-index: 2;
}
/* product-area */
/* 見出しタイトル文字*/
.cate-heading {
  text-align: center;
  margin: 0 auto;
}
.cate-heading h2 {
  font-size: clamp(22px, 5vw, 36px);
  font-weight: bold;
}
/* 見出しタイトル文字 */
/* news一覧 */
/* 中身 */
.talentlist .webgene-blog {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-box;
  display: -webkit-flexbox;
  display: -moz-flexbox;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: flex;
  -webkit-box-lines: multiple;
  -moz-box-lines: multiple;
  -webkit-flex-wrap: wrap;
  -moz-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: flex-start;
  flex-direction: column;
}
/* 各アイテム：横並びの中身 */
.talentlist .webgene-blog .webgene-item {
  position: relative;
  padding: 30px 0;
  width: 100%;
}
.talentlist .webgene-blog .webgene-item::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-image: radial-gradient(circle, #000 0.5px, transparent 0.5px);
  background-size: 6px 1px;
  background-repeat: repeat-x;
}
.talentlist .webgene-blog .webgene-item:first-of-type {
  position: relative;
}
.talentlist .webgene-blog .webgene-item:first-of-type::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-image: radial-gradient(circle, #000 0.5px, transparent 0.5px);
  background-size: 6px 1px;
  background-repeat: repeat-x;
}
.talentlist .webgene-blog .webgene-item:hover {
  opacity: 0.5;
}
.talentlist .webgene-blog .webgene-item a {
  display: block;
}
.talentlist .webgene-item .contentbox {
  flex-wrap: nowrap;
  gap: 30px;
}
.talentlist .webgene-blog .webgene-item .imgbox {
  width: 100px;
  height: 100px;
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
  border: 1px solid #000;
}
.talentlist .webgene-blog .webgene-item .imgbox img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* テキスト部分 */
.talentlist .webgene-blog .webgene-item .box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex: 1;
  gap: 20px;
}
/* 情報ブロック（タイトル＋日付） */
.talentlist .webgene-blog .webgene-item .txtbox {
  display: flex;
  flex-direction: column;
  width: clamp(100px, 50vw, 500px); /* 最小200px 最大500pxまでに制限 */
  flex: 1;
  max-width: 100%;
}
.talentlist .txtbox .meta {
  display: flex;
  align-items: center;
  font-size: 13px;
  color: #8E8E8E;
}
/* カテゴリ・日付 */
.talentlist .txtbox .cate {
  color: #8E8E8E;
}
.talentlist .txtbox .cate::after {
  content: "|";
  color: #000;
  padding: 0 20px;
  font-size: 12px;
}
.talentlist .webgene-blog .webgene-item .date {
  font-size: 13px;
  color: #8E8E8E;
  display: flex;
  font-family: "Outfit";
}
.talentlist .webgene-item i.fa-arrow-right {
  transition: transform 0.3s ease;
}
.talentlist .webgene-item a:hover i.fa-arrow-right {
  transform: translateX(5px);
}
/* ボタン */
.box1 .linkbox {
  margin-top: 50px;
}
.link-button {
  display: inline-flex;
  align-items: center;
  gap: 16px;
  text-decoration: none;
}
.link-button i {
  width: 56px;
  height: 56px;
  background-color: #000;
  color: #fff;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background 0.3s ease, transform 0.3s ease;
  font-size: 16px;
}
.link-button:hover i {
  background-color: #333;
  transform: translateX(7px);
}
.box1:not(:first-child) {
  border-top: 1px solid #000;
}
.box1 {
  display: flex;
  align-items: flex-start;
}
.toptxtbox {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.toptxtbox > p:first-child {
  font-weight: bold;
}
.toptxtbox img {
  width: auto;
  height: 80px;
  object-fit: contain;
  margin-bottom: 30px;
}
.kana-wrapper {
  position: relative;
  display: inline-block;
  padding: 12px 0;
  text-align: center;
  width: 180px;
}
.kana-wrapper::before, .kana-wrapper::after {
  content: '';
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #444;
}
.kana-wrapper::before {
  top: 0;
}
.kana-wrapper::after {
  bottom: 0;
}
.catchcopy {
  line-height: 2;
  letter-spacing: 0.2em;
  font-weight: bold;
    margin-top: 20px;
}
.catchcopy span {
  writing-mode: horizontal-tb;
  display: inline-block;
  position: relative;
  padding-left: 0.2em;
  padding-bottom: 0.2em;
}
.catchcopy span::before, .catchcopy span::after {
  content: '';
  position: absolute;
  font-size: 1em;
  writing-mode: horizontal-tb;
  display: inline-block;
  line-height: 1;
  font-weight: normal;
  color: #000;
}
.catchcopy span::before {
  content: '"';
  top: 0;
  right: -0.3em;
}
.catchcopy span::after {
  content: '"';
  bottom: -0.6em;
  left: -0.1em;
}
  .intro-images-wrap {
      margin-top: 30px;
  }

.box1 .txtbox {
  flex: 1;
  min-width: 300px;
  max-width: 640px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.box1 .txtbox h2 {
  background: #000;
  color: #fff;
  font-weight: bold;
  display: inline-block;
  padding: 6px 12px;
  margin-bottom: 20px;
  position: relative;
}
.box1 .title-wrapper {
  position: relative;
  display: inline-block;
  letter-spacing: 0.25em;
  margin-top: 60px;
}
.box1 .title-wrapper::before {
  content: "";
  position: absolute;
  top: -60px;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  height: 50px;
  background: #000;
}
.box1 .imgbox {
  position: relative;
  width: 360px;
  height: 500px;
border-radius: 180px 180px 0 0;
  overflow: hidden;
  border: 2px solid #000;
  background: #fff;
}
.box1 .imgbox img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
/* ページタイトル */
.pagetitle1 {
  justify-content: space-between;
  flex-wrap: wrap;
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
}
.pagetitle1 .intro-images.left, .pagetitle1 .intro-images.right {
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 3vw, 30px);
}
.pagetitle1 .intro-images.left {
  flex: 1;
  max-width: 240px;
}
.pagetitle1 .intro-images.right {
  flex: 1;
  max-width: 240px;
  justify-content: flex-end;
}
.pagetitle1 .img-left-top, .pagetitle1 .img-left-bottom, .pagetitle1 .img-right {
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 5px;
}
.pagetitle1 .img-left-top {
  position: absolute;
  top: 80px;
  left: 150px;
  width: 200px;
  height: 150px;
  object-fit: cover;
}
.pagetitle1 .img-left-bottom {
  position: absolute;
  top: 350px;
  left: 20px;
  width: 210px;
  height: 280px;
  object-fit: cover;
}
.pagetitle1 .img-right {
  position: absolute;
  top: 440px;
  right: 20px;
  width: 240px;
  height: 140px;
  object-fit: cover;
}
.pagetitle1 {
  height: 750px;
}
.pagetitle1 .intro-center {
  flex: 2;
  max-width: 900px;
  text-align: center;
  position: relative;
}
.pagetitle1 .toptxtbox {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.pagetitle1 .toptxtbox > img {
  max-width: 200px;
  height: auto;
  margin-bottom: 20px;
}
.pagetitle1 .kana-wrapper {
  margin-bottom: 10px;
}
.pagetitle1 .kana {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.1em;
}
.pagetitle1 {
  position: relative;
}
.pagetitle1 .catchcopy {
  position: absolute;
  top: 80px;
  right: 100px;
}
.desc {
  line-height: 3;
  font-weight: 700;
  margin-top: clamp(0px, 5vw, 30px);
}
/* ページタイトル */
html {}
body {
  font-family: "Noto Sans JP", "Outfit", sans-serif;
  background-color: #F5F2EF;
  color: #333333;
}
body .bg_img_wrap {
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
body.on .bg_img_wrap .bg_img {
  display: none;
}
body .bg_img_wrap2 {
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}
body.on .bg_img_wrap2 > img {
  display: none;
}
a {
  display: inline-block;
  transition: ease 0.3s;
}
a:hover {
  opacity: 0.5;
}
a p, a, a i {
  color: #000000;
}
/*----------------------------------*/
.font-medium {
  font-weight: 500;
}
.font-semibold {
  font-weight: 600;
}
.font-black {
  font-weight: 900;
}
.pd_wrap {
  padding: 150px 80px 0;
}
.pd_wrap_all {
  padding: 150px 80px 150px;
}
.pd_wrap_side {
  padding-left: 80px;
  padding-right: 80px;
}
.cate_wrap > .cate {
  padding-top: 150px;
}
/* ---------- header ---------- */
.menu-wrap {
  display: none;
}
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  padding: 18px 40px;
  justify-content: space-between;
  z-index: 9999;
  border-top: 4px solid #000;
  border-bottom: 1px solid #000;
}
.header::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 1;
  background-color: #F6F2EF;
}
.header > div {
  position: relative;
  z-index: 2;
}
.header .leftbox {
  max-width: 20%;
}
.header .rightbox {
  max-width: 80%;
  gap: 30px;
}
.header .leftbox .logo {
  min-width: clamp(220px, 20vw, 250px);
}
.header .rightbox .ul {
  gap: clamp(20px, 5vw, 80px);
}
.header .rightbox .ul .li a p {
  font-size: 18px;
  font-weight: 700;
}
.header .rightbox .shop_bt a {
  background-color: #000;
  overflow: hidden;
  padding: clamp(8px, 2vw, 13px) clamp(12px, 4vw, 20px) clamp(6px, 2vw, 10px);
}
.header .rightbox .shop_bt a .flex {
  gap: 10px;
}
.header .rightbox .shop_bt a .flex img {
  width: 20px;
}
.header .menu-bt {
  display: none;
}
/* ---------- footer ---------- */
/* ANIME */
.sc-anime.topin.on {
  opacity: 0;
  transform: translateY(-50px);
}
.sc-anime.topin.on.active {
  animation-name: topin;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.bottomin.on {
  opacity: 0;
  transform: translateY(50px);
}
.sc-anime.bottomin.on.active {
  animation-name: bottomin;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.leftin.on {
  opacity: 0;
  transform: translateX(-50px);
}
.sc-anime.leftin.on.active {
  animation-name: leftin;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.rightin.on {
  opacity: 0;
  transform: translateX(50px);
}
.sc-anime.rightin.on.active {
  animation-name: rightin;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.fadein.on {
  opacity: 0;
}
.sc-anime.fadein.on.active {
  animation-name: fadein;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.blurin.on {
  opacity: 0;
  -ms-filter: blur(6px);
  filter: blur(6px);
}
.sc-anime.blurin.on.active {
  animation-name: blurin;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
.sc-anime.blurin2.on {
  opacity: 0;
  transform: translateY(50px);
  -ms-filter: blur(6px);
  filter: blur(6px);
}
.sc-anime.blurin2.on.active {
  animation-name: blurin2;
  animation-duration: 1.2s;
  animation-timing-function: ease;
  animation-fill-mode: forwards;
}
@keyframes topin {
  0% {
    opacity: 0;
    transform: translateY(-50px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
@keyframes bottomin {
  0% {
    opacity: 0;
    transform: translateY(50px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
  }
}
@keyframes leftin {
  0% {
    opacity: 0;
    transform: translateX(-50px);
  }
  100% {
    opacity: 1;
    transform: translateX(0px);
  }
}
@keyframes rightin {
  0% {
    opacity: 0;
    transform: translateX(50px);
  }
  100% {
    opacity: 1;
    transform: translateX(0px);
  }
}
@keyframes upin {
  0% {
    transform: translateY(100%);
  }
  100% {
    transform: translateY(0);
  }
}
@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeout {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes blurin {
  0% {
    opacity: 0;
    -ms-filter: blur(6px);
    filter: blur(6px);
  }
  100% {
    opacity: 1;
    -ms-filter: blur(0px);
    filter: blur(0px);
  }
}
@keyframes blurin2 {
  0% {
    opacity: 0;
    transform: translateY(50px);
    -ms-filter: blur(6px);
    filter: blur(6px);
  }
  100% {
    opacity: 1;
    transform: translateY(0px);
    -ms-filter: blur(0px);
    filter: blur(0px);
  }
}
/* color */
.txt-color-normal {
  color: #000000;
}
.txt-white {
  color: #ffffff;
}
.txt-red {
  color: red;
}
.txt-color1 {
  color: #E9CF01
}
.txt-color2 {
  color: #000
}
.txt-color3 {
  color: #021745
}
.txt-color4 {
  color: #EBF5E5
}
.bg-white {
  background-color: #ffffff;
}
.bg-black {
  background-color: black
}
.bg-color1 {
  background-color: #E9CF01
}
.bg-color2 {
  background-color: #000
}
.bg-color3 {
  background-color: #021745
}
.bg-color4 {
  background-color: #EBF5E5
}
.border-color1 {
  border-color: #FFE93C
}
.border-color2 {
  border-color: #F1F1E9
}
.border-color3 {
  border-color: #021745
}
.border-color4 {
  border-color: #EBF5E5
}
.hvr-txt-color-normal:hover {
  color: #000000;
}
.hvr-txt-white:hover {
  color: #ffffff;
}
.hvr-txt-red:hover {
  color: red;
}
.hvr-txt-color1:hover {
  color: #FFE93C
}
.hvr-txt-color2:hover {
  color: #F1F1E9
}
.hvr-txt-color3:hover {
  color: #021745
}
.hvr-txt-color4:hover {
  color: #EBF5E5
}
.hvr-bg-white:hover {
  background-color: #ffffff;
}
.hvr-bg-black:hover {
  background-color: black
}
.hvr-bg-color1:hover {
  background-color: #FFE93C
}
.hvr-bg-color2:hover {
  background-color: #F1F1E9
}
.hvr-bg-color3:hover {
  background-color: #021745
}
.hvr-bg-color4:hover {
  background-color: #EBF5E5
}
.hvr-border-color1:hover {
  border-color: #FFE93C
}
.hvr-border-color2:hover {
  border-color: #F1F1E9
}
.hvr-border-color3:hover {
  border-color: #021745
}
.hvr-border-color4:hover {
  border-color: #EBF5E5
}
/* ---------- 以下追加style ---------- */
/* ---------- pagetitle ---------- */
.pagetitle {
  position: relative;
  width: 100%;
  height: clamp(200px, 50vw, 500px);
}
.bg_img::before {
  content: "";
  position: absolute;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
  height: 90%;
  background-image: url("https://saitozaimokuten.co.jp/system_panel/uploads/images/pagetitle1.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
  border-radius: 20px;
}
.pagetitle .characterbox {
  position: absolute;
  justify-content: space-between;
  bottom: -10%;
  width: 80%;
}
.pagetitle .characterbox img {
  width: 10%;
}
.pagetitle .title_wrap {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.pagetitle .titlebox {
  flex-direction: column;
  background-color: #E17903;
  color: #fff;
  border-radius: 50%;
  width: 150px;
  height: 150px;
}
.pagetitle .titlebox img {
  width: 35px;
}
.pagetitle .titlebox h1 {
  font-weight: 700;
}
.pagetitle3 {
  position: relative;
  width: 100%;
  height: clamp(150px, 30vw, 250px);
}
.pagetitle3 h1 {
  font-size: clamp(30px, 5vw, 40px);
  font-weight: 700;
  letter-spacing: 0.25em;
}
body.on .pagetitle3 p {
  position: absolute;
  top: 45%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: clamp(80px, 18vw, 200px);
  color: rgba(0, 0, 0, 0.05);
  font-weight: 700;
  z-index: 1;
  pointer-events: none;
  white-space: nowrap;
  letter-spacing: 0.1em;
}
/* ---------- common ---------- */
.titleline {
  position: relative;
  padding-left: 20px;
  font-weight: bold;
}
.titleline::before {
  content: "";
  position: absolute;
  top: 5px;
  left: 0;
  width: 4px;
  height: 30px;
  background-color: #E17903;
  border-radius: 2px;
}
.img-frame {
  border: 6px solid #fff;
  border-radius: 20px;
  display: block;
  width: 100%;
  box-sizing: border-box;
}
.img-frame2 {
  border: 6px solid #F7F6F4;
  border-radius: 20px;
  display: block;
  width: 100%;
  box-sizing: border-box;
}
/* ---------- more ---------- */
.more_wrap {
  gap: 20px 30px;
}
.more a {
  position: relative;
  border-radius: 200px;
  border: 2px solid #000;
  overflow: hidden;
  box-sizing: border-box;
  background-color: #fff;
  transition: ease 0.4s;
}
.more a:hover {
  opacity: 1;
  background-color: #000;
}
.more a::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translateX(-100%);
  transition: ease 0.3s;
  background-color: #000;
}
.more a:hover::after {
  transform: translateX(0);
}
.more a > .flex {
  position: relative;
  z-index: 2;
  min-width: 240px;
  height: 50px;
  padding: 0 20px;
  justify-content: center;
}
.more a > .flex p {
  font-family: "Outfit", "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
  color: #333333;
  line-height: 1;
  transform: translateY(2px);
  transition: ease 0.3s;
}
.more .fa-solid {
  font-size: 18px;
  color: #000;
  margin-left: 10px;
  transition: transform 0.3s ease, color 0.3s ease;
}
.more a:hover .fa-solid {
  transform: translateX(5px);
  color: #fff;
}
.more a:hover p {
  color: #fff;
}
/* ---------- font-size ---------- */
.default_title {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 30px;
  font-weight: 700;
}
.default_title2 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 28px;
  font-weight: 700;
}
.default_title3 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 24px;
  font-weight: 700;
}
.default_title4 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-weight: 700;
}
.default_txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
}
.default_txt2 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
}
.default_txt3 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
}
.en_txt {
  font-family: "Outfit", sans-serif;
  letter-spacing: 0.3em;
  font-size: 16px;
}
.en_txt {
  font-family: "Outfit", sans-serif;
  letter-spacing: 0.3em;
  font-size: 16px;
  position: relative;
  display: inline-block;
  font-weight: 900;
}
.en_txt::before, .en_txt::after {
  display: inline-block;
  content: "";
  position: absolute;
  top: 50%;
  width: 40px;
  font-weight: bold;
  font-size: 20px;
}
.en_txt::before {
  left: 0px;
  content: "[";
  font-family: inherit;
  top: 0;
  position: relative;
  text-align: left
}
.en_txt::after {
  right: 0px;
  content: "]";
  font-family: inherit;
  top: 0;
  position: relative;
  text-align: right;
}
.font-Outfit {
  font-family: "Outfit", "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
.txt-color1 {
  color: #E9CF01
}
.txt-color3 {
  color: #E17903
}
/* ---------- footer ---------- */
.footer {
  padding-bottom: clamp(0px, 5vw, 50px);
  background-color: #212121;
  color: #fff;
}
.footer a:hover {
  opacity: 1;
}
.footer p {
  color: #fff;
}
.footer .topbox {
  position: relative;
  overflow: visible;
  text-align: center;
  background-color: #2b2b2b;
  padding-top: 100px;
  padding-bottom: 60px;
  width: 100%;
}
.footer .bottombox {
  width: 100%;
}
.footer .topbox .contact-label {
  position: relative;
  height: 0;
}
.contact-en {
  position: relative;
  display: inline-block;
  letter-spacing: 0.3em;
}
.contact-en::before, .contact-en::after {
  font-family: inherit;
  font-size: inherit;
  font-weight: bold;
  color: #000;
}
.contact-en::before {
  content: '[';
  margin-right: 0.5em;
}
.contact-en::after {
  content: ']';
  margin-left: 0.5em;
}
.footer .topbox .bubble {
  position: absolute;
  top: -190px;
  left: 50%;
  transform: translateX(-50%);
  width: 300px;
  height: 160px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #343434;
  z-index: 1;
}
.footer .topbox .bubble::after {
  content: '';
  position: absolute;
  inset: 0;
  background: url('https://saitozaimokuten.co.jp/system_panel/uploads/images/babble.svg') no-repeat center/contain;
  z-index: -1;
  pointer-events: none;
}
.footer .topbox .bubble p {
  color: #343434;
}
.footer .topbox .contact-message p {
  margin: 0;
  line-height: 2;
}
.footer .topbox .contact-buttons {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin-top: 40px;
  flex-wrap: wrap;
}
.footer .topbox .btn1 {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 15px 90px;
  background: #fff;
  color: #111;
  border: 1px solid #fff;
  text-decoration: none;
  transition: background 0.3s, color 0.3s;
}
.footer .topbox .btn1 p {
  color: #343434;
}
.footer .topbox .btn1:hover {
  background: #343434;
  color: #fff;
  border-color: #fff;
}
.footer .topbox .btn1:hover p, .footer .topbox .btn1:hover i {
  color: #fff;
}
.footer .leftbox {
  width: 30%;
}
.footer .leftbox .snsbox {
  gap: 30px;
}
.footer .leftbox .snsbox a {
  border-radius: 50%;
  width: 60px;
  height: 60px;
  background-color: #000;
}
.footer .leftbox .snsbox a i {
  color: #fff;
}
.footer .leftbox .logo {
  min-width: 300px;
}
.footer .rightbox {
  width: 70%;
  gap: 60px;
}

.footer .rightbox a:hover{
opacity: 0.5;
}

.rightbox .list1 {
  gap: clamp(20px, 5vw, 80px);
}
.rightbox .list2 {
  gap: clamp(20px, 5vw, 50px);
  justify-content: flex-end;
}
.footer .rightbox .list1 p {
  font-size: 20px;
}
.footer .rightbox .list2 p {
  font-size: 16px;
}
.copyright {
  width: 100%;
  padding: 20px;
  background-color: #212121;
  text-align: center;
  color: #fff;
}
/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px) {
  .pd_wrap {
    padding: 150px 60px 0;
  }
  .pd_wrap_all {
    padding: 150px 60px 150px;
  }
  .pd_wrap_side {
    padding-left: 60px;
    padding-right: 60px;
  }
  /* ---------- pagetitle ---------- */
  .pagetitle .characterbox {
    bottom: -5%;
  }
  .pagetitle .characterbox img {
    width: 15%;
  }
  /* ---------- common ---------- */
  .default_title {
    font-size: 26px;
  }
  .default_title2 {
    font-size: 24px;
  }
  .default_title3 {
    font-size: 20px;
  }
  .default_title4 {
    font-size: 18px;
  }
  .default_txt {
    font-size: 16px;
  }
  .default_txt2 {
    font-size: 14px;
  }
  .default_txt3 {
    font-size: 12px;
  }
  .en_txt2 {
    font-size: 14px;
  }
  /* 足したところ1280px*/
  /* -------会社概要----- */
  .recruit1 .item-wrap {}
  .recruit1 .item-wrap .item > div {
    padding-left: 0px;
  }
  .main-wrap .map {
    height: 500px;
  }
  .main-wrap .history .box_wrap .box {
    padding-left: 150px;
  }
  /* -------お問い合わせ----- */
  .form-box .box-wrap .box h3 {
    width: 250px;
  }
  .form-box .box-wrap .box .inputbox {
    width: calc(100% - 250px);
  }
  /* ---------- header ---------- */
  .header .leftbox {}
  .header .rightbox .ul {
    gap: 20px;
  }
  .header .rightbox .ul .li a p {
    font-size: 16px;
  }
  /* ---------- footer ---------- */
  .footer .leftbox .snsbox a {
    width: 50px;
    height: 50px;
  }
}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px) {
  body {
    padding-top: 111px;
  }
  .pagetitle .characterbox {
    bottom: -5%;
  }
  /* 足したところ1080px*/
  /* pagetitle1 */
  .pagetitle1 {
    flex-direction: column;
    align-items: center;
    height: auto;
  }
  .pagetitle1 .intro-images.left, .pagetitle1 .intro-images.right {
    position: static;
    flex-direction: row;
    justify-content: center;
    flex-wrap: wrap;
    max-width: 100%;
    gap: 40px;
    margin-bottom: 30px;
  }
  .pagetitle1 .intro-images.right {
    margin-bottom: 0px;
  }
  .pagetitle1 .img-left-top, .pagetitle1 .img-left-bottom, .pagetitle1 .img-right {
    position: static;
    width: 180px;
    height: 180px;
    object-fit: cover;
    border-radius: 5px;
  }
  .pagetitle1 .catchcopy {
    right: 50px;
  }
  .pagetitle1 .toptxtbox {
    position: static;
    transform: none;
  }
  .desc {
    line-height: 2.5;
    padding: 0 10px;
  }
  /* pagetitle1 */
  /* -------会社概要----- */
  .recruit1 .item-wrap {
    width: 100%;
  }
  .recruit1 .item-wrap .item h3 {
    width: 120px;
    padding-right: 20px;
  }
  .recruit1 .item-wrap .item > div {
    width: calc(100% - 120px);
    padding-left: 20px;
  }
  /* ---------- common ---------- */
  /* ---------- header ---------- */
  .header .rightbox .ul {
    display: none;
  }
  .header .rightbox {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    gap: 30px;
    max-width: 50%;
  }
  .header .menu-bt {
    display: block;
    position: relative;
    width: 70px;
    aspect-ratio: 1 / 1;
    border: 2px solid #000;
    background-color: #fff;
    border-radius: 50%;
  }
  .header .menu-bt .line {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 30px;
    height: 20px;
  }
  .header .menu-bt .line > div {
    content: "";
    position: absolute;
    width: 100%;
    height: 2px;
    background-color: #000;
    ;
    left: 0;
    transition: ease 0.3s;
  }
  .header .menu-bt .line > div:nth-of-type(1) {
    top: 0;
  }
  .header .menu-bt .line > div:nth-of-type(2) {
    top: 50%;
    transform: translateY(-50%);
  }
  .header .menu-bt .line > div:nth-of-type(3) {
    bottom: 0;
  }
  .header .menu-bt.active .line > div:nth-of-type(1) {
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
  }
  .header .menu-bt.active .line > div:nth-of-type(2) {
    top: 50%;
    transform: translateY(-50%) translateX(50%);
    opacity: 0;
  }
  .header .menu-bt.active .line > div:nth-of-type(3) {
    bottom: 50%;
    transform: translateY(50%) rotate(-45deg);
  }
  .menu-wrap {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.90);
    z-index: 998;
  }
  .menu-wrap > div {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .menu-wrap .menu-wrap-box {
    overflow: auto;
  }
  .menu-wrap > div .ul {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    gap: 40px;
    padding: 50px;
  }
  .menu-wrap > div .ul .li {
    min-width: calc(100% / 4 - 120px / 4);
    text-align: center;
  }
  .menu-wrap > div .ul .li a {
    margin: 0 auto;
  }
  .menu-wrap > div .ul .li a p {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    color: #333333;
    font-size: 18px;
    font-weight: 700;
  }
  .menu-wrap > div .ul .li a p.en {
    font-size: 14px;
    font-family: "Funnel Sans", "Zen Kaku Gothic New", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    color: #0C4134;
    opacity: 0.8;
  }
  /* ---------- footer ---------- */
  .footer {
    justify-content: center;
    width: 100%;
    text-align: center;
  }
  .footer .leftbox {
    text-align: center;
  }
  .footer .rightbox {
    display: none;
  }
  .footer .bottom_footer {
    justify-content: center;
    padding-top: 50px;
  }
  .footer .bottom_footer .copyright {
    width: 100%;
    padding-top: 20px;
  }
  .footer .leftbox .snsbox {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    flex-direction: row;
  }
}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px) {
  body {
    padding-top: 105px;
  }
  /* 足したところ 768px*/
  .box1 {
    flex-direction: column;
    align-items: center;
  }
  /* 木からできたいろいろ */
  .product-item .imgwrap {
    width: clamp(90px, 25vw, 150px);
    height: clamp(90px, 25vw, 150px);
  }
  .product-list {
    flex-wrap: wrap;
    gap: 0px;
  }
  .product-item {
    width: calc(100% / 3);
  }
  .product-area .link-button {
    top: 25%;
    right: -30px;
  }
  /* 木からできたいろいろ */
  /* pagetitle1 */
  .pagetitle1 .catchcopy {
    position: static;
    text-orientation: initial;
    text-align: center;
  }
  .intro-images-wrap {
    display: flex;
    gap: 10px;
    justify-content: center;
    flex-wrap: nowrap;
  }
  .pagetitle1 .intro-images.left, .pagetitle1 .intro-images.right {
    display: contents;
  }
  .pagetitle1 .img-left-top, .pagetitle1 .img-left-bottom, .pagetitle1 .img-right {
    width: clamp(100px, 25vw, 300px);
    height: clamp(100px, 25vw, 300px);
  }
  /* pagetitle1 */
  .talentlist .webgene-blog .webgene-item .imgbox {
    width: 60px;
    height: 60px;
    border-radius: 4px;
  }
  /* -------お問い合わせ----- */
  .form-box .box-wrap .box h3 {
    width: 100%;
    margin-bottom: 10px;
  }
  .form-box .box-wrap .box .inputbox {
    width: 100%;
    padding-left: 0;
  }
  .form-box .box-wrap .box.required-box h3 {
    padding-right: 0;
    padding-left: 0px;
  }
  .form-box .box-wrap .box.required-box h3::after {
    position: static;
    display: inline-block;
    margin-left: 20px;
    font-size: 13px;
    transform: translateY(-2px);
  }
  .form-box .box-wrap .box .inputbox {}
  .form-box .box-wrap .box .inputbox .check-wrap {
    padding-top: 10px;
    gap: 20px;
  }
  .form-box .box-wrap .box .inputbox .check-wrap1 .check-box {
    box-sizing: border-box;
  }
  .send, .check-area {
    margin-left: 0px;
  }
  .privacypolicy {
    padding: 100px 50px;
  }
  .privacypolicy .box-wrap {
    padding-left: 30px;
    padding-top: 50px;
  }
  .privacypolicy .box-wrap .box h3 {
    font-size: 18px;
  }
  .privacypolicy p {
    font-size: 14px;
  }
  .privacypolicy .close-bt {
    top: 20px;
    right: 20px;
    width: 50px;
    height: 50px;
  }
  .privacypolicy .close-bt::before, .privacypolicy .close-bt::after {
    width: 36px;
    height: 2px;
  }
  .pd_wrap {
    padding: 100px 50px 0;
  }
  .pd_wrap_all {
    padding: 100px 50px 100px;
  }
  .pd_wrap_side {
    padding-left: 50px;
    padding-right: 50px;
  }
  .cate_wrap > .cate {
    padding-top: 100px;
  }
  /* ---------- pagetitle ---------- */
  .pagetitle .titlebox {
    width: 120px;
    height: 120px;
  }
  /* ---------- common ---------- */
  .default_title {
    font-size: 22px;
  }
  .default_title2 {
    font-size: 20px;
  }
  .default_title3 {
    font-size: 18px;
  }
  .default_title4 {
    font-size: 16px;
  }
  .default_txt {
    font-size: 14px;
  }
  .default_txt2 {
    font-size: 14px;
  }
  .default_txt3 {
    font-size: 12px;
  }
  .en_txt2 {
    font-size: 14px;
  }
  /* ---------- header ---------- */
  .header {
    padding: 15px 20px;
  }
  .header .rightbox .ul {
    display: none;
  }
  .header .rightbox {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    gap: 30px;
    max-width: 80%;
  }
  .header .menu-bt {
    display: block;
    position: relative;
    width: 70px;
    aspect-ratio: 1 / 1;
    border: 2px solid #000;
    background-color: #fff;
    border-radius: 50%;
  }
  .header .menu-bt .line {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 30px;
    height: 20px;
  }
  .header .menu-bt .line > div {
    content: "";
    position: absolute;
    width: 100%;
    height: 2px;
    background-color: #000;
    left: 0;
    transition: ease 0.3s;
  }
  .header .menu-bt .line > div:nth-of-type(1) {
    top: 0;
  }
  .header .menu-bt .line > div:nth-of-type(2) {
    top: 50%;
    transform: translateY(-50%);
  }
  .header .menu-bt .line > div:nth-of-type(3) {
    bottom: 0;
  }
  .header .menu-bt.active .line > div:nth-of-type(1) {
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
  }
  .header .menu-bt.active .line > div:nth-of-type(2) {
    top: 50%;
    transform: translateY(-50%) translateX(50%);
    opacity: 0;
  }
  .header .menu-bt.active .line > div:nth-of-type(3) {
    bottom: 50%;
    transform: translateY(50%) rotate(-45deg);
  }
  .menu-wrap {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.90);
    z-index: 998;
  }
  .menu-wrap > div {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
  .menu-wrap .menu-wrap-box {
    overflow: auto;
  }
  .menu-wrap > div .ul {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    gap: 40px;
    padding: 50px;
  }
  .menu-wrap > div .ul .li {
    min-width: calc(100% / 4 - 120px / 4);
    text-align: center;
  }
  .menu-wrap > div .ul .li a {
    margin: 0 auto;
  }
  .menu-wrap > div .ul .li a p {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    color: #333333;
    font-size: 18px;
    font-weight: 700;
  }
  .menu-wrap > div .ul .li a p.en {
    font-size: 14px;
    font-family: "Funnel Sans", "Zen Kaku Gothic New", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    color: #0C4134;
    opacity: 0.8;
  }
  /* ---------- footer ---------- */
}
/* ---------- スマートフォン ---------- */
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px) {
  body {
    padding-top: 75px;
  }
  .pd_wrap {
    padding: 80px 20px 0;
  }
  .pd_wrap_all {
    padding: 80px 20px 80px;
  }
  .pd_wrap_side {
    padding-left: 20px;
    padding-right: 20px;
  }
  .cate_wrap > .cate {
    padding-top: 80px;
  }
  /* ---------- pagetitle ---------- */
  .desc {
    line-height: 2;
  }
  .pagetitle .characterbox img {
    width: 20%;
  }
  .pagetitle .titlebox {
    width: 110px;
    height: 110px;
  }
  .pagetitle .characterbox {
    bottom: -10%;
  }
  /* ---------- more ---------- */
  .more a > .flex {
    min-width: 170px;
  }
  .pagetitle3 p {
    letter-spacing: 0.01em;
  }
  /* 足したところ576px*/
  /* 木からできたいろいろ */
  .product-item .imgwrap {
    width: 150px;
    height: 150px;
  }
  .product-title::before, .product-title::after {
    width: 70px;
    height: 70px;
  }
  .product-title::after {
    right: -70px;
  }
  .product-title::before {
    left: -70px;
  }
  .product-list-wrap {
    justify-content: center;
  }
  .product-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 10px;
    margin-top: 10%;
  }
  .product-item {
    width: calc(50% - 5px);
    max-width: 150px;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .product-area .link-button {
    position: absolute;
    top: 200px;
    right: 2%;
  }
  /* 木からできたいろいろ */
  .box1 .imgbox {
    position: relative;
    width: clamp(240px, 35vw, 400px);
    height: clamp(260px, 38vw, 450px);
    border-radius: 75% 75% 0 0 / 60% 60% 0 0;
  }
  /* -------会社概要----- */
  .recruit1 .item-wrap {}
  .recruit1 .item-wrap .item {
    gap: 0;
  }
  .recruit1 .item-wrap .item h3 {
    width: 100%;
    padding: 10px 0 0;
    padding-right: 0px;
  }
  .recruit1 .item-wrap .item > div {
    width: 100%;
    padding-left: 0px;
  }
  /* -------お問い合わせ-------- */
  .form-box .box-wrap .box .inputbox input::placeholder, .form-box .box-wrap .box .inputbox textarea::placeholder {
    font-size: 12px;
  }
  /* ---------- common ---------- */
  /* ---------- header ---------- */
  .header {
    padding: 10px 10px;
  }
  .header .leftbox .logo {
    min-width: 180px;
  }
  .header .rightbox {
    gap: 10px;
  }
  .header .rightbox .shop_bt a {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-box;
    display: -webkit-flexbox;
    display: -moz-flexbox;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: flex;
    -webkit-box-lines: multiple;
    -moz-box-lines: multiple;
    -webkit-flex-wrap: wrap;
    -moz-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    flex-direction: row;
    width: 50px;
    aspect-ratio: 1 / 1;
    padding: 0;
    border-radius: 50%;
  }
  .header .rightbox .shop_bt a .flex p {
    display: none;
  }
  .header .menu-bt {
    width: 50px;
  }
  .header .menu-bt .line {
    width: 20px;
    height: 16px;
  }
  .menu-wrap > div .ul {
    gap: 20px 0;
    padding: 80px 20px;
  }
  .menu-wrap > div .ul .li {
    width: 50%;
  }
  .menu-wrap > div .ul .li a p.en {
    font-size: 10px;
  }
  .menu-wrap > div .ul .li a p.jp {
    font-size: 14px;
  }
  /* ---------- footer ---------- */
  .footer .leftbox {
    width: 70%;
  }
  .footer .bottom_footer {
    padding-top: 30px;
  }
  .footer .leftbox .snsbox a {
    width: 40px;
    height: 40px;
  }
  .footer .onlineshop_bt a {
    padding: 12px 15px;
  }
  .footer .onlineshop_bt a > div p {
    font-size: 20px;
  }
  .footer .onlineshop_bt a > div .cart_icon {
    width: 22px;
  }
  .copyright {
    padding: 15px;
  }
  .footer .topbox .btn1 {
    padding: 15px 30px
  }
  .header .leftbox {
    max-width: 50%;
  }
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px) {}