@charset "utf-8";
/* NXエンジニアリング 事例・実績 CSS */


/* 事例TOPページ ----------------- */
#case-idx .container__inner:first-child {
  margin-bottom: 140px;
}
#case-idx .idx-card {
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 2.08vw, 40px);
}
#case-idx .idx-card-box a {
  padding: max(2.08vw, 25px) max(3.13vw, 24px) max(2.08vw, 29px);
}
#case-idx .case-label {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
  width: 100%;
  margin-bottom: 30px;
}
#case-idx .case-label img {
  width: 64px;
}
#case-idx .case-label span {
  padding: 9px 8px 9px 9px;
  margin-left: auto;
  background-color: var(--main-color);
  border-radius: 2px;
  color: var(--light-color);
  font-size: var(--txtfs-s);
  letter-spacing: var(--txtls-df);
  line-height: 1;
  font-weight: bold;
  font-family: var(--font-family-bold);
}
#case-idx .idx-card-box .case-img {
  order: 2;
  max-width: 460px;
  margin-bottom: 29px;
  overflow: hidden;
}
#case-idx .idx-card-box h2 {
  order: 3;
  margin-bottom: 14px;
  font-size: var(--txtfs-df);
  letter-spacing: var(--txtls-df);
  line-height: 1.625;
  text-align: center;
}
#case-idx .idx-card-box h2 br {
  display: none;
}
#case-idx .idx-card-box p {
  order: 4;
  margin-top: auto;
  margin-bottom: 35px;
  font-size: var(--txtfs-m);
  letter-spacing: var(--txtls-df);
  line-height: 1.857;
  text-align: center;
}
#case-idx .idx-card-box .more-lnk {
  order: 5;
  margin-top: auto;
}
#case-idx .deco-line-FL {
  margin-bottom: 0;
}
#case-idx + footer {
  margin-top: 102px;
}
@media screen and (min-width:1025px) {
  .idx-card-box .case-img img {
    -o-object-fit: contain;
    object-fit: contain;
    -o-object-position: center;
    object-position: center;
    transition: scale 0.2s ease-out;
  }
  .idx-card-box a:hover .case-img img {
    scale: 1.05;
  }
}
@media screen and (max-width: 1024px) {
  #ttl-area h1 {
    padding-bottom: 63px;
  }
  .container {
    margin-bottom: 0;
  }
}
@media screen and (max-width: 1024px) and (min-width: 751px) {
  #case-idx .idx-card-box h2 br {
    display: block;
  }
}
@media screen and (max-width:750px) {
  #case-idx .container__inner:first-child {
    margin-bottom: 80px;
  }
  #case-idx .idx-card {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  #case-idx .idx-card-box {
    width: 100%;
    min-height: 409px;
  }
  #case-idx .case-label {
    margin-bottom: 24px;
  }
  #case-idx .case-label img {
    width: 55px;
  }
  #case-idx .case-label span {
    padding: 9px 8px 8px 10px;
    font-size: 1rem;
  }
  #case-idx .idx-card-box .case-img {
    width: 100%;
    max-width: initial;
    margin-bottom: 22px;
  }
  #case-idx .idx-card-box h2 {
    margin-bottom: 14px;
    font-size: var(--txtfs-m);
    letter-spacing: var(--txtls-l);
    line-height: 1.714;
  }
  #case-idx .idx-card-box p {
    margin-bottom: 23px;
    font-size: var(--txtfs-s);
    line-height: 1.833;
  }
  #case-idx + footer {
    margin-top: 50px;
  }
}
@media screen and (max-width: 425px) {
  #case-idx .idx-card-box h2 br {
    display: block;
  }
}
/* 事例下層ページ ---------------- */
.case-sub #ttl-area {
  margin-bottom: 193px;
}
.case-sub #ttl-area .case-ttl {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  column-gap: clamp(40px, 5.21vw, 100px);
}
.case-sub #ttl-area .case-ttl h1 {
  padding-right: 0;
}
#ttl-area h1.sub-cate + p {
  margin-right: 0;
  margin-bottom: 53px;
}
.case-sub #ttl-area .case-label {
  display: inline-block;
  margin-left: 100px;
  padding: 8px 9px 8px;
  border: var(--df-txtcolor) 1px solid;
  border-radius: 2px;
  font-size: var(--txtfs-s);
  letter-spacing: var(--txtls-df);
  line-height: 1;
  font-weight: bold;
  font-family: var(--font-family-bold);
}
.case-sub #ttl-area .case-ttl-mv {
  flex: 0 0 auto;
  width: 38.54vw;
  min-width: 320px;
  margin-right: 100px;
  margin-top: 56px;
}
.case-sub .clm-2.txt-img picture {
  max-width: 480px;
}
.case-sub #YouTube {
  width: 100%;
}
.case-sub #YouTube iframe {
  width: 100%;
  height: 100%;
  aspect-ratio: 560/315;
}
.case-sub .case-btn .main-btn {
  padding: 10px 10px 10px 16px;
}
.case-sub .case-btn .main-btn::after {
  right: initial;
  left: 23px;
  transform: rotate(180deg);
}
.case-sub + footer {
  margin-top: 0;
}
@media screen and (max-width:1400px) {
  .case-sub #ttl-area .case-ttl-mv {
    width: 32.14vw;
  }
}
@media screen and (max-width:1024px) {
  .case-sub #ttl-area {
    margin-bottom: 100px;
  }
  .case-sub #ttl-area .case-ttl {
    column-gap: 40px;
  }
  .case-sub #ttl-area .case-label {
    margin-left: 40px;
  }
  .case-sub #ttl-area .case-ttl-mv {
    margin-right: 40px;
    margin-top: 80px;
  }
  .case-sub .clm-2.txt-img picture {
    max-width: 320px;
  }
}
@media screen and (max-width:750px) {
  .case-sub #ttl-area {
    margin-bottom: 56px;
  }
  .case-sub #ttl-area .case-ttl h1 {
    padding-right: 20px;
}
  .case-sub #ttl-area .case-ttl {
    flex-direction: column;
    row-gap: 50px;
  }
  #ttl-area h1.sub-cate + p {
    margin-right: 20px;
    margin-bottom: 23px;
  }
  .case-sub #ttl-area .case-label {
    margin-left: 40px;
  }
  .case-sub #ttl-area .case-ttl-mv {
    margin: 0;
    width: 100%;
    min-width: initial;
  }
  .case-sub #ttl-area .case-ttl-mv .att-txt-sml {
    margin: 0 20px;
  }
  .case-sub .clm-2.txt-img picture {
    max-width: initial;
  }
  .case-sub aside {
    width: 100vw;
    margin: 0 calc(50% - 50vw) 80px;
  }
  .case-sub aside .att-txt-sml {
    margin: 0 20px;
  }
  .case-sub #YouTube {
    margin: 0 0 -38px;
  }
  .case-sub #YouTube iframe {
    margin-top: 10px;
  }
}
@media screen and (max-width:374px) {
  .case-sub .case-btn .main-btn {
    padding: 2.67vw 2.67vw 2.67vw 4.27vw;
  }
}