@charset "UTF-8";

/* ご利用事例CSS
========================================*/

#main .case {
  /* 一覧ページ */
  /* 投稿ページ */
}

#main .case-box {
  background-color: #fff;
  overflow: hidden;
  position: relative;
}

#main .case-box>figure img {
  object-fit: cover;
  height: 100%;
  width: 100%;
}

#main .case-box .-title {
  color: #003b89;
  font-weight: 700;
  line-height: 1.5;
}

#main .case-box .-button {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  border: 1px solid #247ac0;
  color: #247ac0;
  font-weight: 700;
  position: absolute;
  text-align: center;
}

#main .case-box .-button:before {
  background-image: url(../img/common/arrow_blue.svg);
  background-size: contain;
  content: "";
  display: block;
  position: absolute;
  z-index: 10;
}

#main .case-icon {
  display: flex;
  flex-wrap: wrap;
}

#main .case-icon>li {
  border-radius: 5px;
  font-weight: 700;
  line-height: 1.4;
  padding: .2em 1em;
}

#main .case-icon>li._type {
  background-color: #fcf3da;
  color: #f1af00;
}

#main .case-icon>li._size {
  background-color: #eef9da;
  color: #8ab73c;
}

#main .case-post {
  background-color: #fff;
}

#main .case-post>header {
  border-bottom: 1px solid #003b89;
}

#main .case-post>header>h1 {
  color: #003b89;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: .05em;
}

#main .case-post .case-icon {
  margin-bottom: 0;
  padding: 0;
}

#main .case-post .case-icon>li {
  padding: .35em 1em;
}

#main .case-post-body {
  border-top: 1px solid #003b89;
}

#main .case-post-photo-main {
  background-color: #f2f2f2;
}

#main .case-post-photo-main .swiper-slide {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  transition-property: all;
}

#main .case-post-photo-main .swiper-slide img {
  max-height: 100%;
  max-width: 100%;
}

#main .case-post-photo-sub {
  position: relative;
}

#main .case-post-photo-sub .swiper-slide {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}

#main .case-post-photo-sub .swiper-slide img {
  max-height: 100%;
  max-width: 100%;
}

#main .case-post-photo-sub .swiper-button-prev {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  background-color: #247ac0;
  cursor: pointer;
  position: absolute;
  top: 0;
  left: 0;
}

#main .case-post-photo-sub .swiper-button-prev img {
  rotate: -180deg;
  filter: brightness(0) invert(1);
}

#main .case-post-photo-sub .swiper-button-next {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  background-color: #247ac0;
  cursor: pointer;
  position: absolute;
  top: 0;
  right: 0;
}

#main .case-post-photo-sub .swiper-button-next img {
  filter: brightness(0) invert(1);
}

#main .case-post-photo-sub .swiper-button-disabled {
  cursor: default;
  opacity: .5;
}

#main .title {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  background-image: linear-gradient(-45deg, rgba(255, 255, 255, .08) 0px, rgba(255, 255, 255, .08) 3px, transparent 3px, transparent 13px, rgba(255, 255, 255, .08) 13px, rgba(255, 255, 255, .08) 16px, transparent 16px, transparent 26px);
  background-size: 18px 18px;
  background-color: #247ac0;
}

#main .title>h2 {
  color: #fff;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: .05em;
}

@media print, screen and (min-width: 768px) {
  #main .case-list {
    display: flex;
    flex-wrap: wrap;
    gap: 45px;
    padding: 60px 0;
  }

  #main .case-box {
    border-radius: 20px;
    padding-bottom: 65px;
    width: 370px;
  }

  #main .case-box>figure {
    margin-bottom: 16px;
    height: 210px;
  }

  #main .case-box .-title {
    font-size: 1.1rem;
    margin-bottom: 20px;
    padding: 0 16px;
  }

  #main .case-box .-button {
    border-radius: 20px;
    font-size: .9rem;
    overflow: hidden;
    left: calc(50% - 117px);
    bottom: 25px;
    height: 40px;
    width: 234px;
    transition: .2s ease;
  }

  #main .case-box .-button:before {
    right: 16px;
    height: 10px;
    width: 6px;
    transition: .3s ease;
  }

  #main .case-box .-button:after {
    background-color: #ef7f1c;
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 0;
    z-index: 1;
    transition: .3s ease;
  }

  #main .case-box .-button>span {
    display: block;
    position: relative;
    z-index: 2;
  }

  #main .case-box .-button:hover {
    border-color: #ef7f1c;
    color: #fff;
  }

  #main .case-box .-button:hover:before {
    filter: brightness(0) invert(1);
  }

  #main .case-box .-button:hover:after {
    width: 100%;
  }

  #main .case-icon {
    gap: 8px;
    margin-bottom: 10px;
    padding: 0 16px;
  }

  #main .case-icon>li {
    font-size: .75rem;
  }

  #main .case-post {
    border-radius: 30px;
    margin-top: 30px;
    margin-bottom: 60px;
    padding: 40px 70px 60px;
  }

  #main .case-post>header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 3px;
    padding-bottom: 12px;
  }

  #main .case-post>header>h1 {
    font-size: 1.6rem;
    margin-right: 20px;
    padding-bottom: 8px;
  }

  #main .case-post .case-icon {
    gap: 10px;
  }

  #main .case-post .case-icon>li {
    font-size: .9rem;
  }

  #main .case-post-body {
    padding-top: 50px;
  }

  #main .case-post-photo-main {
    margin-bottom: 25px;
  }

  #main .case-post-photo-main .swiper-slide {
    height: 520px;
    width: 720px;
  }

  #main .case-post-photo-sub .swiper {
    width: 1000px;
  }

  #main .case-post-photo-sub .swiper-slide {
    height: 120px;
    width: 160px;
  }

  #main .case-post-photo-sub .swiper-button-prev {
    height: 120px;
    width: 22px;
  }

  #main .case-post-photo-sub .swiper-button-prev img {
    height: 14px;
    width: 8px;
  }

  #main .case-post-photo-sub .swiper-button-next {
    height: 120px;
    width: 22px;
  }

  #main .case-post-photo-sub .swiper-button-next img {
    height: 14px;
    width: 8px;
  }

  #main .case-post-text {
    margin-top: 50px;
  }

  #main .title {
    padding: 30px 0;
  }

  #main .title>h2 {
    font-size: 2rem;
    margin-left: 20px;
  }
}

@media screen and (max-width: 767px) {
  #main .case-list {
    padding: 5.3333333333vw 8vw;
  }

  #main .case-box {
    border-radius: 4vw;
    margin-bottom: 8vw;
    padding-bottom: 16vw;
  }

  #main .case-box>figure {
    margin-bottom: 3.4666666667vw;
    height: 44vw;
  }

  #main .case-box .-title {
    font-size: 4.8vw;
    margin-bottom: 4.2666666667vw;
    padding: 0 4vw;
  }

  #main .case-box .-button {
    border-radius: 5.3333333333vw;
    font-size: 4vw;
    left: calc(50% - 30.6666666667vw);
    bottom: 5.3333333333vw;
    height: 10.6666666667vw;
    width: 61.3333333333vw;
  }

  #main .case-box .-button:before {
    right: 16px;
    height: 10px;
    width: 6px;
  }

  #main .case-icon {
    gap: 1.6vw;
    margin-bottom: 2.6666666667vw;
    padding: 0 4vw;
  }

  #main .case-icon>li {
    font-size: 3.4666666667vw;
  }

  #main .case-post {
    border-radius: 5.3333333333vw;
    margin: 5.3333333333vw -2.6666666667vw 10.6666666667vw;
    padding: 6.6666666667vw 4vw 9.3333333333vw;
  }

  #main .case-post>header {
    margin-bottom: .8vw;
    padding-bottom: 4vw;
  }

  #main .case-post>header>h1 {
    font-size: 5.8666666667vw;
    padding-bottom: 2.1333333333vw;
  }

  #main .case-post .case-icon>li {
    font-size: 3.7333333333vw;
  }

  #main .case-post-body {
    padding-top: 8vw;
  }

  #main .case-post-photo-main {
    margin-bottom: 4vw;
  }

  #main .case-post-photo-main .swiper-slide {
    height: 65.3333333333vw;
    width: 86.6666666667vw;
  }

  #main .case-post-photo-sub .swiper {
    width: 75.2vw;
  }

  #main .case-post-photo-sub .swiper-slide {
    height: 17.8666666667vw;
    width: 24vw;
  }

  #main .case-post-photo-sub .swiper-button-prev {
    height: 17.8666666667vw;
    width: 4.8vw;
  }

  #main .case-post-photo-sub .swiper-button-prev img {
    height: 3.2vw;
    width: 1.8666666667vw;
  }

  #main .case-post-photo-sub .swiper-button-next {
    height: 17.8666666667vw;
    width: 4.8vw;
  }

  #main .case-post-photo-sub .swiper-button-next img {
    height: 3.2vw;
    width: 1.8666666667vw;
  }

  #main .case-post-text {
    line-height: 1.6;
    margin-top: 8vw;
  }

  #main .title {
    padding: 5.3333333333vw 5.3333333333vw;
  }

  #main .title>img {
    width: 10.1333333333vw;
  }

  #main .title>h2 {
    font-size: 6.4vw;
    margin-left: 2.6666666667vw;
    max-width: 76.5333333333vw;
  }
}
/*# sourceMappingURL=../../_sourcemap/assets/css/case.css.map */