:root {
  --margin: 80px;
  --color_key: #b50029;
  --color_main: #967d64;
  --color_black: #505050;
  --color_grey: #ededed;
  --font_cp: clamp(13px, 1.8vw, 18px);
  --font_rg: clamp(18px, 2.4vw, 24px);
  --font_md: clamp(14px, 2.5vw, 32px);
  --font_lg: clamp(20px, 5vw, 44px);
}

.news_container {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: clamp(70px, 100vw / 980 * 90, 100px);
  width: 90%;
  max-width: 980px;
  margin-right: auto;
  margin-left: auto;
}
.news_container::after {
  display: block;
  width: clamp(203px, 290vw / 980 * 90, 290px);
  content: "";
}
.news_box {
  width: clamp(203px, 290vw / 980 * 90, 290px);
  margin-bottom: clamp(49px, 70vw / 980 * 90, 70px);
}
.news_box img {
  width: clamp(203px, 290vw / 980 * 90, 290px);
  height: clamp(135.1px, 193vw / 980 * 90, 193px);
  -o-object-fit: cover;
     object-fit: cover;
}
.news_time {
  display: block;
  margin-top: 0.75em;
  font-size: clamp(9.1px, 13vw / 980 * 90, 13px);
}
.news_name {
  margin-top: 0.25em;
  font-size: clamp(14px, 20vw / 980 * 90, 20px);
  font-weight: 700;
  color: var(--color_black);
}
.news_blog, .case_blog {
  width: 90%;
  max-width: 800px;
  margin-top: clamp(42px, 60vw / 980 * 90, 60px);
  margin-right: auto;
  margin-bottom: clamp(105px, 150vw / 980 * 90, 150px);
  margin-left: auto;
  font-weight: normal;
  line-height: 1.75;
  color: var(--color_black);
}
.news_blog_time {
  margin-bottom: clamp(21px, 30vw / 980 * 90, 30px);
  font-size: clamp(11.2px, 16vw / 980 * 90, 16px);
  color: var(--color_main);
}
.news_blog_name, .case_blog_name {
  margin-bottom: clamp(42px, 60vw / 980 * 90, 60px);
  font-size: clamp(22.4px, 32vw / 980 * 90, 32px);
  font-weight: 700;
  color: var(--color_black);
}
.news_blog_mv {
  margin-bottom: clamp(42px, 60vw / 980 * 90, 60px);
}
.news_blog_mv img {
  width: 100%;
  max-height: 500px;
  -o-object-fit: contain;
     object-fit: contain;
}
.news_blog > img, .case_blog > img {
  max-width: 100%;
  margin-bottom: clamp(42px, 60vw / 980 * 90, 60px);
}
.news_blog h2, .case_blog h2,
.news_blog h3,
.case_blog h3 {
  margin-top: clamp(35px, 50vw / 980 * 90, 50px);
  margin-bottom: clamp(17.5px, 25vw / 980 * 90, 25px);
  padding-left: 0.5em;
  font-size: clamp(16.8px, 24vw / 980 * 90, 24px);
  font-weight: normal;
  border-left: clamp(2.8px, 4vw / 980 * 90, 4px) solid var(--color_key);
}
.news_blog p, .case_blog p {
  line-height: 2;
}
.news_blog p + p, .case_blog p + p {
  margin-top: clamp(35px, 50vw / 980 * 90, 50px);
}
.news_blog p a, .case_blog p a {
  font-size: clamp(9.8px, 14vw / 980 * 90, 14px);
  text-decoration: underline;
  color: var(--color_main);
}
.news_blog pre, .case_blog pre {
  margin: clamp(35px, 50vw / 980 * 90, 50px) 0;
  padding: 5%;
  white-space: pre-line;
  border-radius: 12px;
  background-color: #f6f6f6;
}
.news_blog ul, .case_blog ul {
  margin: clamp(42px, 60vw / 980 * 90, 60px) 0;
  padding-left: 1.5em;
}
.news_blog ul li, .case_blog ul li {
  margin: 0.5em 0;
  list-style-type: disc;
}
.news_button {
  width: clamp(168px, 240vw / 980 * 90, 240px);
  color: var(--color_main);
  border: 1px solid;
  background-color: #fff;
}
.news_button:hover {
  color: #fff;
  background-color: var(--color_main);
}
.news_button_area {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: clamp(70px, 100vw / 980 * 90, 100px);
}

.top_notice {
  margin-bottom: clamp(42px, 60vw / 980 * 90, 60px);
  padding-top: clamp(35px, 50vw / 980 * 90, 50px);
  padding-bottom: clamp(28px, 40vw / 980 * 90, 40px);
  background-color: #eae5e0;
}
.top_notice_inner {
  width: 90%;
  max-width: 980px;
  margin-right: auto;
  margin-left: auto;
}
.top_notice_title {
  font-size: clamp(14px, 20vw / 980 * 90, 20px);
  text-align: center;
}
.top_notice_time {
  display: block;
  font-size: clamp(14px, 20vw / 980 * 90, 20px);
  text-align: center;
}
.top_notice_content {
  margin-top: 1em;
  font-size: clamp(11.2px, 16vw / 980 * 90, 16px);
  font-weight: normal;
  color: var(--color_black);
}

.single-case .main {
  overflow-x: hidden;
}

.case {
  width: 90%;
  max-width: 980px;
  margin-right: auto;
  margin-left: auto;
}
.case_blog {
  position: relative;
  max-width: 980px;
  margin-bottom: 0;
}
.case_blog::before {
  position: absolute;
  z-index: -1;
  top: clamp(-42px, -60vw / 980 * 90, -60px);
  right: clamp(-224px, -320vw / 980 * 90, -320px);
  display: block;
  width: clamp(707.7px, 1011vw / 980 * 90, 1011px);
  height: clamp(682.5px, 975vw / 980 * 90, 975px);
  content: "";
  background-image: url(../image/case_bg.png);
  background-repeat: no-repeat;
  background-position: right top;
  background-size: contain;
}
.case_container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: clamp(35px, 50vw / 980 * 90, 50px);
}
.case_box {
  width: clamp(329px, 470vw / 980 * 90, 470px);
  margin-bottom: clamp(31.5px, 45vw / 980 * 90, 45px);
  padding: clamp(17.5px, 25vw / 980 * 90, 25px) clamp(17.5px, 25vw / 980 * 90, 25px) clamp(28px, 40vw / 980 * 90, 40px);
  border-radius: clamp(14px, 20vw / 980 * 90, 20px);
  background-color: #f4f2ef;
  -webkit-box-shadow: 0 0 clamp(2.8px, 4vw / 980 * 90, 4px) rgba(33, 22, 19, 0.15);
          box-shadow: 0 0 clamp(2.8px, 4vw / 980 * 90, 4px) rgba(33, 22, 19, 0.15);
}
.case_box img {
  width: clamp(294px, 420vw / 980 * 90, 420px);
  height: clamp(196px, 280vw / 980 * 90, 280px);
  margin-bottom: clamp(14px, 20vw / 980 * 90, 20px);
  border-radius: clamp(8.4px, 12vw / 980 * 90, 12px);
  -o-object-fit: cover;
     object-fit: cover;
}
.case_time {
  display: none;
}
.case_company {
  margin-bottom: clamp(14px, 20vw / 980 * 90, 20px);
  font-weight: 700;
  color: var(--color_black);
}
.case_name {
  width: 100%;
  font-size: clamp(14px, 20vw / 980 * 90, 20px);
  font-weight: 700;
  text-overflow: ellipsis;
}
.case_tag {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: clamp(28px, 40vw / 980 * 90, 40px);
  gap: clamp(14px, 20vw / 980 * 90, 20px) clamp(7px, 10vw / 980 * 90, 10px);
}
.case_blog_content .case_tag {
  padding-top: clamp(14px, 20vw / 980 * 90, 20px);
  border-top: 1px solid #ddd;
}
.case_blog_content .case_tag h3 {
  width: 100%;
  margin-top: 0;
}
.case_blog_content .case_tag a {
  display: block;
  height: 100%;
  padding: 1em 1.5em;
  font-size: clamp(8.4px, 12vw / 980 * 90, 12px);
  pointer-events: all;
  color: #fff;
  border-radius: 100px;
  background-color: var(--color_main);
}
.case_tag a {
  padding: 1em 1.5em;
  font-size: clamp(8.4px, 12vw / 980 * 90, 12px);
  color: var(--color_black);
  border-radius: 100px;
  background-color: #e5ded8;
}
.case_tagtitle {
  margin-top: clamp(35px, 50vw / 980 * 90, 50px);
  font-size: clamp(15.4px, 22vw / 980 * 90, 22px);
  font-weight: 700;
  text-align: center;
}
.case_undefined {
  width: 100%;
  padding: clamp(35px, 50vw / 980 * 90, 50px) 0 clamp(70px, 100vw / 980 * 90, 100px);
  text-align: center;
  color: var(--color_black);
}
.case_blog_name {
  font-size: clamp(22.4px, 32vw / 980 * 90, 32px);
  color: var(--color_main);
}
.case_blog_mv img {
  width: 100%;
}
.case_blog_image img {
  width: clamp(686px, 980vw / 980 * 90, 980px);
  max-width: 100%;
  height: clamp(364px, 520vw / 980 * 90, 520px);
  border-radius: clamp(21px, 30vw / 980 * 90, 30px);
  -o-object-fit: cover;
     object-fit: cover;
}
.case_blog .slick-dots {
  position: static;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: clamp(35px, 50vw / 980 * 90, 50px) 0 0;
  padding: 0;
  gap: clamp(14px, 20vw / 980 * 90, 20px);
}
.case_blog .slick-dots li {
  overflow: hidden;
  width: clamp(172.2px, 246vw / 980 * 90, 246px);
  height: clamp(123.2px, 176vw / 980 * 90, 176px);
  margin: 0;
  border-radius: clamp(7px, 10vw / 980 * 90, 10px);
  background-color: #f0f0f0;
}
.case_blog .slick-dots li img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.case_blog .slick-dots .slick-active {
  display: none;
}
.case_blog .slick-prev, .case_blog .slick-next {
  z-index: 10;
  top: clamp(182px, 260vw / 980 * 90, 260px);
  left: clamp(14px, 20vw / 980 * 90, 20px);
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
.case_blog .slick-prev::before, .case_blog .slick-next::before {
  font-size: clamp(19.6px, 28vw / 980 * 90, 28px);
  color: #c0c0c0;
}
.case_blog .slick-next {
  right: clamp(14px, 20vw / 980 * 90, 20px);
  left: auto;
}
.case_blog_data {
  width: clamp(546px, 780vw / 980 * 90, 780px);
  max-width: 100%;
  margin-top: clamp(35px, 50vw / 980 * 90, 50px);
  margin-right: auto;
  margin-left: auto;
  padding: clamp(28px, 40vw / 980 * 90, 40px) clamp(35px, 50vw / 980 * 90, 50px);
  border-radius: clamp(10.5px, 15vw / 980 * 90, 15px);
  background-color: #eae5e0;
}
.case_blog_data h2 {
  margin-top: 0;
  padding: 0;
  font-size: clamp(14px, 20vw / 980 * 90, 20px);
  font-weight: 700;
  text-align: center;
  color: var(--color_main);
  border: 0;
}
.case_blog_data dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.case_blog_data dt {
  width: 20%;
  white-space: nowrap;
}
.case_blog_data dd {
  width: 80%;
}
.case_blog_container {
  width: clamp(546px, 780vw / 980 * 90, 780px);
}
.case_blog_sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: clamp(28px, 40vw / 980 * 90, 40px);
}
.case_blog_content {
  width: 100%;
  max-width: 800px;
  margin-top: clamp(56px, 80vw / 980 * 90, 80px);
  margin-right: auto;
  margin-left: auto;
}
.case_blog_content p {
  font-weight: normal;
}
.case_blog_content p + p {
  margin-top: 1.5em;
}
.case_blog_content h2 {
  padding-left: 0;
  font-weight: 700;
  color: var(--color_main);
  border: 0;
}
.case_blog_content h3 {
  margin-bottom: 0;
  padding-left: 0;
  font-size: clamp(11.2px, 16vw / 980 * 90, 16px);
  font-weight: 700;
  color: var(--color_main);
  border: 0;
}
.case_blog_content .wp-caption {
  width: 100% !important;
  margin-top: clamp(24.5px, 35vw / 980 * 90, 35px);
}
.case_blog_content .wp-caption-text {
  margin-top: 0.5em;
  font-size: clamp(9.8px, 14vw / 980 * 90, 14px);
  text-align: center;
  color: var(--color_main);
}
.case_blog_content img {
  width: 100%;
  border-radius: clamp(10.5px, 15vw / 980 * 90, 15px);
}
.case .insta {
  margin-top: 20px;
}
.case #sb_instagram .sbi_header_link {
  display: none;
}
.case #sb_instagram #sbi_load {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 28px;
}
.case #sb_instagram #sbi_load a {
  width: 230px;
  height: 48px;
  border-radius: 24px;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0;
  font-size: 14px;
  font-weight: bold;
  -webkit-transition: 0.3s opacity;
  transition: 0.3s opacity;
}
.case #sb_instagram #sbi_load a:hover {
  opacity: 0.7;
}
.case #sb_instagram #sbi_load .sbi_load_btn {
  display: none;
}
.case #sb_instagram #sbi_load .sbi_load_btn .sbi_btn_text {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.case #sb_instagram #sbi_load .sbi_load_btn .sbi_btn_text::before {
  content: "";
  background-image: url(../image/icon-plus.svg);
  background-repeat: no-repeat;
  background-size: 100%;
  display: inline-block;
  position: relative;
  width: 20px;
  height: 20px;
  margin-right: 10px;
}
.case #sb_instagram #sbi_load .sbi_follow_btn {
  margin-left: 20px;
}
.case #sb_instagram #sbi_load .sbi_follow_btn a:hover {
  -webkit-box-shadow: none;
          box-shadow: none;
}
.case #sb_instagram #sbi_load .sbi_follow_btn a .svg-inline--fa {
  height: 20px;
  margin-right: 10px;
}
@media (max-width: 768px) {
  :root {
    --margin: 12vw;
  }
  .news_container {
    margin-top: 13.3333333333vw;
  }
  .news_box {
    width: 47%;
    margin-bottom: 9.3333333333vw;
  }
  .news_blog, .case_blog {
    font-size: 3.7333333333vw;
  }
  .news_blog h2, .case_blog h2,
  .news_blog h3,
  .case_blog h3 {
    font-size: 5.3333333333vw;
  }
  .news_blog p a, .case_blog p a {
    font-size: 3.4666666667vw;
  }
  .case_blog::before {
    top: -5vw;
    right: -5vw;
    width: 50vw;
    height: 50vw;
  }
  .case_container {
    margin-top: 13.3333333333vw;
  }
  .case_box {
    width: 100%;
  }
  .case_box img {
    display: block;
    width: 82vw;
    height: 54.66666694vw;
    margin-right: auto;
    margin-left: auto;
  }
  .case_name {
    font-size: 4vw;
  }
  .case_tag {
    margin-top: 6.6666666667vw;
  }
  .case_blog_content .case_tag a {
    font-size: 2.9333333333vw;
  }
  .case_tag a {
    font-size: 2.4vw;
  }
  .case_undefined {
    font-size: 4vw;
  }
  .case_blog_image img {
    width: 100%;
    height: 62.4vw;
    border-radius: 4vw;
  }
  .case_blog .slick-dots {
    margin-top: 4vw;
    gap: 2vw;
  }
  .case_blog .slick-dots li {
    width: 32.8vw;
    height: 23.4666666667vw;
    border-radius: 1.3333333333vw;
  }
  .case_blog .slick-prev, .case_blog .slick-next {
    top: 35vw;
  }
  .case_blog_data {
    padding: 5.3333333333vw 6.6666666667vw;
  }
  .case_blog_data dl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
  .case_blog_data dl + dl {
    margin-top: 5.3333333333vw;
  }
  .case_blog_data dt {
    width: auto;
  }
  .case_blog_data dd {
    width: auto;
  }
  .case_blog_content h3 {
    font-size: 4vw;
  }
  .case_blog_content .wp-caption-text {
    font-size: 3.2vw;
  }
  .case #sb_instagram #sbi_load {
    margin-top: 20px;
  }
  .case #sb_instagram #sbi_load a {
    width: 43.2vw;
    height: 10.6666666667vw;
  }
  .case #sb_instagram #sbi_load .sbi_follow_btn {
    margin-left: 3.7333333333vw;
  }
}