@charset "UTF-8";
/* base */
body {
  font-family: "Noto Sans JP", sans-serif;
  letter-spacing: 0;
  color: #222;
  overflow-anchor: none;
  overflow-x: hidden;
  word-break: break-all;
}

a {
  color: currentColor;
  text-decoration: none;
}
a[href^="mailto:"].--underline {
  color: Colors(link);
  -webkit-text-decoration-color: Colors(link);
          text-decoration-color: Colors(link);
  text-decoration: underline;
}
a[href^="mailto:"].--underline:hover {
  color: Colors(link-hover);
  -webkit-text-decoration-color: Colors(link-hover);
          text-decoration-color: Colors(link-hover);
  text-decoration: none;
}
a[href^="tel:"].--underline {
  color: Colors(link);
  -webkit-text-decoration-color: Colors(link);
          text-decoration-color: Colors(link);
  text-decoration: underline;
}
a[href^="tel:"].--underline:hover {
  color: Colors(link-hover);
  text-decoration: none;
}
@media screen and (min-width: 769px) {
  a[href^="tel:"] {
    text-decoration: none;
    pointer-events: none;
  }
}

@media screen and (max-width: 768px) {
  img {
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
  }
}

h1,
h2,
h3,
h4 {
  font-size: inherit;
}

button {
  padding: 0;
  color: inherit;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
  background-color: transparent;
  border: none;
}

/* 共通部分 */
.p-case .sp-only, .p-case-sample .sp-only {
  display: none;
}
@media screen and (max-width: 768px) {
  .p-case .sp-only, .p-case-sample .sp-only {
    display: block;
  }
}
.p-case .case-btn, .p-case-sample .case-btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 62px;
  border-radius: 40px;
  transition: all 0.5s ease;
}
.p-case .case-btn-text, .p-case-sample .case-btn-text {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .p-case .case-btn-text, .p-case-sample .case-btn-text {
    font-size: 18px;
  }
}
.p-case .case-btn .arrow, .p-case-sample .case-btn .arrow {
  position: absolute;
}
.p-case .case-btn-gra, .p-case-sample .case-btn-gra {
  background: linear-gradient(90deg, #f6ab00 0%, #eec870 100%);
  transition: all 0.5s ease;
}
@media (any-hover: hover) {
  .p-case .case-btn-gra:hover, .p-case-sample .case-btn-gra:hover {
    color: #fff;
    background: #0049A7;
  }
  .p-case .case-btn-gra:hover svg path, .p-case-sample .case-btn-gra:hover svg path {
    fill: #fff;
  }
}
.p-case .case-btn-gra .arrow, .p-case-sample .case-btn-gra .arrow {
  right: 24px;
}
.p-case .case-btn-bk, .p-case-sample .case-btn-bk {
  background: #000;
}
@media (any-hover: hover) {
  .p-case .case-btn-bk:hover, .p-case-sample .case-btn-bk:hover {
    color: #fff;
    background: #0049A7;
  }
  .p-case .case-btn-bk:hover svg path, .p-case-sample .case-btn-bk:hover svg path {
    fill: #fff;
  }
}
.p-case .case-btn-bk .arrow, .p-case-sample .case-btn-bk .arrow {
  left: 24px;
  rotate: 180deg;
}
.p-case .case-btn-bk .arrow svg path, .p-case-sample .case-btn-bk .arrow svg path {
  fill: #fff;
}
.p-case .case-btn-bk .case-btn-text, .p-case-sample .case-btn-bk .case-btn-text {
  color: #fff;
}
.p-case .tag-list, .p-case-sample .tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.p-case .tag-list .tag-item, .p-case-sample .tag-list .tag-item {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-weight: 500;
  line-height: 1.5;
  color: #666;
  background: #efefef;
  border-radius: 4px;
}

/* 事例一覧ページ */
.p-case .case__item {
  display: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.p-case .case__item.is-show {
  opacity: 1;
}
.p-case .filterWrap {
  max-width: 1080px;
  margin: 102px auto 62px;
}
@media screen and (max-width: 1100px) {
  .p-case .filterWrap {
    margin: 61px auto;
    padding-inline: 35px;
  }
}
.p-case .filterWrap .js-accordion-content .filter__btn-list {
  display: none;
}
.p-case .filterWrap .js-accordion-content.is-open .filter__btn-list {
  display: flex;
}
.p-case .filterWrap .filterBox + .filterBox {
  margin-top: 16px;
}
.p-case .filterBox {
  padding: 22px 30px;
  border: 2px solid #0049A7;
  border-radius: 8px;
}
@media screen and (max-width: 768px) {
  .p-case .filterBox {
    padding: 12.5px 22px;
  }
}
.p-case .filterBox button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.p-case .filterBox button .filter-title {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
  color: #0049A7;
}
@media screen and (max-width: 768px) {
  .p-case .filterBox button .filter-title {
    font-size: 18px;
  }
}
.p-case .filterBox button svg {
  transform: rotate(-180deg);
  transition: transform 0.3s ease;
}
.p-case .filterBox button.is-open svg {
  transform: rotate(0);
  transition: transform 0.3s ease;
}
.p-case .filterBox .filter__btn-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}
@media screen and (max-width: 768px) {
  .p-case .filterBox .filter__btn-list {
    gap: 16px 12px;
  }
}
.p-case .filterBox .filter__btn-item a {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.5;
  color: #666;
  background: #efefef;
  border-radius: 4px;
  transition: transform 0.3s ease;
}
@media (any-hover: hover) {
  .p-case .filterBox .filter__btn-item a:hover {
    color: #fff;
    background: #0049A7;
  }
}
@media screen and (max-width: 768px) {
  .p-case .filterBox .filter__btn-item a {
    padding: 8px 12px;
    font-size: 13px;
  }
}
.p-case .filterBox .filter__btn-item a.is-active {
  color: #fff;
  background: #0049A7;
}
.p-case .case-box {
  display: flex;
  flex-wrap: wrap;
  gap: 64px 40px;
  max-width: 1400px;
  width: 100%;
  margin: 0 auto 104px;
}
@media screen and (max-width: 1400px) {
  .p-case .case-box {
    justify-content: center;
    padding-inline: 35px;
  }
}
@media screen and (max-width: 940px) {
  .p-case .case-box {
    display: flex;
    flex-direction: column;
    gap: 56px 0;
    margin: 0 auto 73px;
  }
}
.p-case .case-box .case__item.is-show {
  display: block;
  max-width: 440px;
  width: calc((100% - 80px) / 3);
}
@media screen and (max-width: 1400px) {
  .p-case .case-box .case__item.is-show {
    width: calc((100% - 40px) / 2);
  }
}
@media screen and (max-width: 940px) {
  .p-case .case-box .case__item.is-show {
    max-width: 100%;
    width: 100%;
  }
}
.p-case .case-box .case__item.is-show .img-wrap {
  width: 100%;
  overflow: hidden;
  border-radius: 8px;
  border: 1px solid #ccc;
}
.p-case .case-box .case__item.is-show .img-wrap .thumb {
  width: 100%;
  height: auto;
  scale: 1;
  transition: scale 0.4s 0s ease;
}
@media (any-hover: hover) {
  .p-case .case-box .case__item.is-show:hover .thumb {
    scale: 1.2;
  }
}
.p-case .case-box .case__item.is-show .date {
  margin-top: 24px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  color: #999;
}
@media screen and (max-width: 768px) {
  .p-case .case-box .case__item.is-show .date {
    margin-top: 16px;
    font-size: 12px;
    font-weight: 700;
  }
}
.p-case .case-box .case__item.is-show .company-desc {
  margin-top: 4px;
  font-weight: 700;
  line-height: 1.5;
}
.p-case .case-box .case__item.is-show .company-desc .name {
  font-size: 22px;
}
@media screen and (max-width: 768px) {
  .p-case .case-box .case__item.is-show .company-desc .name {
    font-size: 16px;
  }
}
.p-case .case-box .case__item.is-show .company-desc .text {
  margin-top: 16px;
  font-size: 16px;
}
@media screen and (max-width: 768px) {
  .p-case .case-box .case__item.is-show .company-desc .text {
    margin-top: 8px;
    font-size: 12px;
  }
}
.p-case .case-box .case__item.is-show .tag-list {
  margin-top: 24px;
}
@media screen and (max-width: 768px) {
  .p-case .case-box .case__item.is-show .tag-list {
    margin-top: 16px;
  }
}
.p-case .case-box .case__item.is-show .tag-list .tag-item {
  padding: 8px 12px;
  font-size: 13px;
}
.p-case .case-bottom {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 104px;
  background: linear-gradient(270deg, #0054A7 0.13%, #408CD7 99.87%);
}
@media screen and (max-width: 768px) {
  .p-case .case-bottom {
    padding: 48px 35px 64px;
  }
}
.p-case .case-bottom .title, .p-case .case-bottom .text {
  color: #fff;
}
.p-case .case-bottom .title {
  font-size: 32px;
  font-weight: 700;
  line-height: 1.375;
}
@media screen and (max-width: 768px) {
  .p-case .case-bottom .title {
    font-size: 20px;
    line-height: 1.5;
  }
}
.p-case .case-bottom .text {
  margin-top: 24px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .p-case .case-bottom .text {
    margin-top: 16px;
    font-size: 12px;
  }
}
.p-case .case-bottom .case-btn {
  margin-top: 40px;
  width: 408px;
}
@media screen and (max-width: 768px) {
  .p-case .case-bottom .case-btn {
    margin-top: 32px;
    width: 100%;
    border-radius: 51px;
  }
}

/* 事例詳細ページ */
.p-case-sample {
  padding-top: 200px;
}
@media screen and (max-width: 768px) {
  .p-case-sample {
    padding-top: 56px;
  }
}
.p-case-sample .inner, .p-case-sample .content-wrap {
  max-width: 896px;
  margin-inline: auto;
}
@media screen and (max-width: 900px) {
  .p-case-sample .inner, .p-case-sample .content-wrap {
    padding-inline: 35px;
  }
}
.p-case-sample .text-link {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
  text-decoration: underline;
}
@media (any-hover: hover) {
  .p-case-sample .text-link:hover {
    color: #0049A7;
  }
}
.p-case-sample .link-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 24px 62px;
  border-radius: 40px;
  color: #fff;
  background: #000;
  transition: all 0.5s ease;
}
@media screen and (max-width: 768px) {
  .p-case-sample .link-btn {
    position: relative;
    width: 100%;
  }
}
@media (any-hover: hover) {
  .p-case-sample .link-btn:hover {
    color: #fff;
    background: #0049A7;
  }
  .p-case-sample .link-btn:hover svg path {
    fill: #fff;
  }
}
.p-case-sample .link-btn .link-text {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .p-case-sample .link-btn .link-text {
    font-size: 18px;
  }
}
@media screen and (max-width: 768px) {
  .p-case-sample .link-btn svg {
    position: absolute;
    right: 24px;
  }
}
.p-case-sample .case-top {
  margin-bottom: 64px;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top {
    margin-bottom: 56px;
  }
}
.p-case-sample .case-top .date {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  color: #999;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .date {
    font-size: 12px;
    font-weight: 700;
  }
}
.p-case-sample .case-top h2.title {
  font-size: 34px;
  font-weight: 700;
  line-height: 1.4;
  color: #0049A7;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top h2.title {
    font-size: 22px;
    line-height: 1.5;
  }
}
.p-case-sample .case-top .description-box {
  display: flex;
  gap: 40px;
  margin-top: 64px;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .description-box {
    flex-direction: column;
    gap: 32px;
    margin-top: 56px;
  }
}
.p-case-sample .case-top .description-box .caption {
  width: calc(50% - 20px);
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .description-box .caption {
    width: 100%;
  }
}
.p-case-sample .case-top .description-box .caption .name {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .description-box .caption .name {
    font-size: 16px;
  }
}
.p-case-sample .case-top .description-box .caption .tag-list {
  margin-top: 24px;
}
.p-case-sample .case-top .description-box .caption .tag-list .tag-item {
  padding: 12px 16px;
  font-size: 16px;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .description-box .caption .tag-list .tag-item {
    padding: 8px 12px;
    font-size: 13px;
  }
}
.p-case-sample .case-top .description-box .caption .text {
  margin-top: 40px;
  font-size: 16px;
  font-weight: 400;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .description-box .caption .text {
    margin-top: 32px;
    font-size: 12px;
  }
}
.p-case-sample .case-top .description-box .thumb {
  width: 428px;
  height: 285px;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .description-box .thumb {
    width: 100%;
    height: auto;
  }
}
.p-case-sample .case-top .evaluation-box {
  max-width: 896px;
  width: 100%;
  margin-top: 64px;
  margin-inline: auto;
  padding: 56px 64px;
  background: #F5F5F5;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .evaluation-box {
    margin-top: 56px;
    padding: 40px 43.5px;
  }
}
.p-case-sample .case-top .evaluation-box .evaluation-title {
  font-size: 26px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .evaluation-box .evaluation-title {
    font-size: 18px;
    text-align: center;
  }
}
.p-case-sample .case-top .evaluation-box .evalution-list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 28.5px 56px;
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .evaluation-box .evalution-list {
    flex-direction: column;
    gap: 16px;
    margin-top: 32px;
  }
}
.p-case-sample .case-top .evaluation-box .evalution-list .evolution-item {
  display: flex;
  justify-content: space-between;
  width: calc((100% - 56px) / 2);
  padding-bottom: 16px;
  border-bottom: 1px solid #999;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .evaluation-box .evalution-list .evolution-item {
    width: 100%;
  }
}
.p-case-sample .case-top .evaluation-box .evalution-list .evolution-item .text {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .evaluation-box .evalution-list .evolution-item .text {
    font-size: 16px;
  }
}
.p-case-sample .case-top .evaluation-box .evalution-list .evolution-item .star-box {
  display: flex;
  align-items: center;
  gap: 8px;
}
.p-case-sample .case-top .evaluation-box .evalution-list .evolution-item .star-box .number {
  font-family: "Roboto Condensed", sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.72px;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-top .evaluation-box .evalution-list .evolution-item .star-box .number {
    font-size: 18px;
    letter-spacing: 0.54px;
  }
}
.p-case-sample .case-bottom {
  margin-top: 104px;
  padding-block: 64px 80px;
  background: linear-gradient(270deg, #0054A7 0.13%, #408CD7 99.87%);
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-bottom {
    margin-top: 72px;
    padding: 48px 35px 64px;
  }
}
.p-case-sample .case-bottom .title {
  font-size: 26px;
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-bottom .title {
    font-size: 18px;
  }
}
.p-case-sample .case-bottom .case-btn {
  margin-top: 24px;
  margin-inline: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-bottom .case-btn {
    margin-top: 24px;
    width: 100%;
    border-radius: 51px;
  }
}
.p-case-sample .case-another {
  padding-block: 104px;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-another {
    padding: 72px 35px;
  }
}
.p-case-sample .case-another .case-btn {
  width: 264px;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-another .case-btn {
    width: 100%;
  }
}
.p-case-sample .content-wrap .text-box01, .p-case-sample .content-wrap .case-point, .p-case-sample .content-wrap .img-box-bg, .p-case-sample .content-wrap .horizontal-box, .p-case-sample .content-wrap .text-link, .p-case-sample .content-wrap .link-btn {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .p-case-sample .content-wrap .text-box01, .p-case-sample .content-wrap .case-point, .p-case-sample .content-wrap .img-box-bg, .p-case-sample .content-wrap .horizontal-box, .p-case-sample .content-wrap .text-link, .p-case-sample .content-wrap .link-btn {
    margin-top: 32px;
  }
}
.p-case-sample .content-wrap h3.title {
  margin-top: 64px;
  padding-bottom: 20px;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.375;
  color: #0049A7;
  border-bottom: 1px solid #0049A7;
}
@media screen and (max-width: 768px) {
  .p-case-sample .content-wrap h3.title {
    margin-top: 56px;
    font-size: 20px;
    line-height: 1.5;
  }
}
.p-case-sample .content-wrap h4.heading {
  margin-top: 56px;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .p-case-sample .content-wrap h4.heading {
    margin-top: 48px;
    font-size: 18px;
  }
}
.p-case-sample .content-wrap .text {
  font-size: 16px;
  font-weight: 400;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .p-case-sample .content-wrap .text {
    font-size: 12px;
  }
}
.p-case-sample .content-wrap .strong-text {
  font-size: 16px;
  font-weight: 700;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .p-case-sample .content-wrap .strong-text {
    font-size: 12px;
  }
}
.p-case-sample .content-wrap .caption-text {
  margin-top: 16px;
  font-size: 13px;
  font-weight: 500;
  line-height: 1.5;
}
.p-case-sample .img-box-bg img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 768px) {
  .p-case-sample .img-box-bg img {
    width: 100vw;
    margin-inline: calc(50% - 50vw);
  }
}
.p-case-sample .horizontal-box {
  display: flex;
  gap: 40px;
}
@media screen and (max-width: 768px) {
  .p-case-sample .horizontal-box {
    flex-direction: column;
    gap: 32px;
  }
}
.p-case-sample .horizontal-box .img-box img {
  width: 428px;
  height: 285px;
}
@media screen and (max-width: 768px) {
  .p-case-sample .horizontal-box .img-box img {
    width: 100%;
    height: auto;
  }
}
.p-case-sample .horizontal-box .text-box {
  width: calc(50% - 20px);
}
@media screen and (max-width: 768px) {
  .p-case-sample .horizontal-box .text-box {
    width: 100%;
  }
}
.p-case-sample .case-point {
  padding: 38px;
  border: 2px solid #0049A7;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-point {
    padding: 30px;
  }
}
.p-case-sample .case-point .sub-title {
  font-family: "Roboto Condensed", sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.6px;
  color: #0049A7;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-point .sub-title {
    font-size: 14px;
    letter-spacing: 0.42px;
  }
}
.p-case-sample .case-point h5.title {
  margin-top: 8px;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .p-case-sample .case-point h5.title {
    font-size: 16px;
  }
}
.p-case-sample .case-point p.text {
  margin-top: 24px;
}
.p-case-sample .staff-comment {
  margin-top: 64px;
  padding: 40px;
  background: #F5F5F5;
}
@media screen and (max-width: 768px) {
  .p-case-sample .staff-comment {
    width: 100vw;
    margin-inline: calc(50% - 50vw);
    margin-top: 56px;
    padding: 32px 0;
  }
}
.p-case-sample .staff-comment h4.staff-title {
  font-size: 26px;
  font-weight: 700;
  line-height: 1.5;
  color: #0049A7;
}
@media screen and (max-width: 768px) {
  .p-case-sample .staff-comment h4.staff-title {
    font-size: 18px;
    text-align: center;
  }
}
.p-case-sample .staff-comment .inner {
  display: flex;
  gap: 24px;
  margin-top: 24px;
}
@media screen and (max-width: 768px) {
  .p-case-sample .staff-comment .inner {
    flex-direction: column;
    align-items: center;
  }
}
.p-case-sample .staff-comment .inner .desc-box {
  width: calc(100% - 168px);
}
@media screen and (max-width: 768px) {
  .p-case-sample .staff-comment .inner .desc-box {
    width: 100%;
  }
}
.p-case-sample .staff-comment .inner .desc-box dl {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .p-case-sample .staff-comment .inner .desc-box dl {
    font-size: 12px;
    text-align: center;
  }
}
.p-case-sample .staff-comment .inner .desc-box .text {
  margin-top: 16px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
}
@media screen and (max-width: 768px) {
  .p-case-sample .staff-comment .inner .desc-box .text {
    font-size: 12px;
  }
}
/*# sourceMappingURL=case.css.map */