#page-works {
  padding-top: 80px;
}
@media screen and (max-width: 768px) {
  #page-works {
    padding-top: 0.24rem;
  }
}

#works-header {
  border-bottom: 1.5px dashed #f07800;
  padding-bottom: 24px;
}
@media screen and (max-width: 768px) {
  #works-header {
    padding-bottom: 0.16rem;
  }
}

.works-ttl {
  font-size: 32px;
  line-height: 1.5;
  letter-spacing: 0.08em;
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .works-ttl {
    font-size: 0.24rem;
    margin-top: 0.4rem;
  }
}

article .works-sec {
  margin-top: 80px;
}
@media screen and (max-width: 768px) {
  article .works-sec {
    margin-top: 0.4rem;
  }
}
article .works-sec h2 {
  background: #f07800;
  color: #fff;
  border-radius: 20px;
  font-size: 20px;
  line-height: 2;
  letter-spacing: 0.08em;
  padding: 8px 40px;
  margin-bottom: 32px;
}
@media screen and (max-width: 768px) {
  article .works-sec h2 {
    font-size: 0.16rem;
    padding: 0.08rem 0.4rem;
    margin-bottom: 0.32rem;
  }
}
article .works-sec .txt {
  font-size: 20px;
  line-height: 2;
  letter-spacing: 0.08em;
  font-weight: 400;
  padding: 0 24px;
}
@media screen and (max-width: 768px) {
  article .works-sec .txt {
    font-size: 0.16rem;
    padding: 0 0.24rem;
  }
}
article .works-sec .link-area {
  margin-top: 32px;
  padding: 0 24px;
}
@media screen and (max-width: 768px) {
  article .works-sec .link-area {
    margin-top: 0.24rem;
    padding: 0 0.24rem;
  }
}
article .works-sec .link-area .link-txt {
  font-size: 16px;
  line-height: 2.1875;
  letter-spacing: 0.04em;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  article .works-sec .link-area .link-txt {
    font-size: 0.16rem;
  }
}
article .works-sec .link-area .link-a {
  font-size: 14px;
  line-height: 2.5;
  letter-spacing: 0.08em;
  color: #f07800;
  border-bottom: 1px solid #f07800;
  font-weight: 400;
}
@media screen and (max-width: 768px) {
  article .works-sec .link-area .link-a {
    font-size: 0.14rem;
  }
}
article .ba-list {
  margin-top: 40px;
  display: flex;
  align-items: center;
  gap: 64px;
}
@media screen and (max-width: 768px) {
  article .ba-list {
    margin-top: 0.4rem;
    flex-direction: column;
    gap: 0.64rem;
  }
}
article .ba-list .before {
  width: 388px;
}
@media screen and (max-width: 768px) {
  article .ba-list .before {
    width: 100%;
    position: relative;
  }
  article .ba-list .before:after {
    content: "";
    display: inline-block;
    position: absolute;
    background-image: url("../images/works/arrow-ba.svg");
    background-size: 100%;
    background-position: center;
    background-repeat: no-repeat;
    width: 0.48rem;
    height: 0.48rem;
    right: 0;
    left: 0;
    top: initial;
    bottom: -0.56rem;
    margin: 0 auto;
    transform: rotate(90deg);
  }
}
article .ba-list .before figure {
  position: relative;
}
article .ba-list .before figure:before {
  content: "";
  display: inline-block;
  width: 179.99px;
  height: 57.19px;
  position: absolute;
  top: 0;
  left: 32px;
  background-image: url("../images/works/label-before@2x.png");
  background-size: 100%;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  article .ba-list .before figure:before {
    left: 0.32rem;
    width: 1.7999rem;
    height: 0.5719rem;
  }
}
article .ba-list .before figure:after {
  content: "";
  display: inline-block;
  width: 48px;
  height: 48px;
  position: absolute;
  right: -56px;
  top: 0;
  bottom: 0;
  margin: auto 0;
  background-image: url("../images/works/arrow-ba.svg");
  background-size: 100%;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  article .ba-list .before figure:after {
    content: none;
  }
}
article .ba-list .after {
  width: 508px;
}
@media screen and (max-width: 768px) {
  article .ba-list .after {
    width: 100%;
  }
}
article .ba-list .after figure {
  position: relative;
}
article .ba-list .after figure:before {
  content: "";
  display: inline-block;
  width: 179.99px;
  height: 57.19px;
  position: absolute;
  top: 0;
  left: 32px;
  background-image: url("../images/works/label-after@2x.png");
  background-size: 100%;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  article .ba-list .after figure:before {
    left: 0.32rem;
    width: 1.7999rem;
    height: 0.5719rem;
  }
}
article .ba-list figure {
  padding: 24px;
  background: #fff;
  border-radius: 8px;
  border: 1px solid #cfc7c0;
}
@media screen and (max-width: 768px) {
  article .ba-list figure {
    padding: 0.24rem;
    border-radius: 0.08rem;
  }
}
article .ba-list figure img {
  width: 100%;
  border-radius: 4px;
}
article .ba-list .txt-area {
  padding: 24px 24px 0;
}
@media screen and (max-width: 768px) {
  article .ba-list .txt-area {
    padding: 0.24rem 0.24rem 0;
  }
}
article .ba-list .txt-area .ttl-ba {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  article .ba-list .txt-area .ttl-ba {
    font-size: 0.16rem;
  }
}
article .ba-list .txt-area .txt-ba {
  font-size: 14px;
  line-height: 2.5;
  letter-spacing: 0.08em;
  margin-top: 8px;
  font-weight: 400;
}
@media screen and (max-width: 768px) {
  article .ba-list .txt-area .txt-ba {
    font-size: 0.14rem;
    margin-top: 0.08rem;
  }
}
article .ba-list .txt-area .txt-ba .orange {
  color: #f07800;
  font-weight: 700;
}
article .recommend-list {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
@media screen and (max-width: 768px) {
  article .recommend-list {
    flex-direction: column;
    gap: 0.16rem;
  }
}
article .recommend-list li {
  width: calc((100% - 16px) / 2);
  background: #fff;
  padding: 24px;
  border-radius: 8px;
  border: 1px solid #cfc7c0;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 768px) {
  article .recommend-list li {
    width: 100%;
    padding: 0.24rem;
  }
}
article .recommend-list li figure {
  border-radius: 8px;
  overflow: hidden;
}
article .recommend-list li figure img {
  width: 100%;
  height: auto;
}
article .recommend-list li .txt-area {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: auto;
  flex-grow: 1;
}
article .recommend-list li .ttl-rec {
  font-size: 20px;
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.08em;
  border-bottom: 1.5px dashed #ccc2b8;
  margin-top: 8px;
  padding-bottom: 8px;
}
@media screen and (max-width: 768px) {
  article .recommend-list li .ttl-rec {
    font-size: 0.16rem;
    margin-top: 0.08rem;
    padding-bottom: 0.08rem;
  }
}
article .recommend-list li .txt-rec {
  margin-top: 8px;
  font-size: 14px;
  line-height: 2;
  letter-spacing: 0.08em;
  font-weight: 400;
  flex-grow: 1;
}
@media screen and (max-width: 768px) {
  article .recommend-list li .txt-rec {
    font-size: 0.14rem;
    margin-top: 0.08rem;
  }
}
article .recommend-list li .caption {
  display: block;
  font-size: 10px;
  line-height: 2.8;
  letter-spacing: 0.08em;
  text-align: right;
  margin-top: 16px;
  font-weight: 400;
}
@media screen and (max-width: 768px) {
  article .recommend-list li .caption {
    font-size: 0.1rem;
    margin-top: 0.16rem;
  }
}
article .finished-contents {
  margin-top: 40px;
  width: 100%;
  background: #fff;
  padding: 24px;
  border-radius: 8px;
  border: 1px solid #cfc7c0;
}
@media screen and (max-width: 768px) {
  article .finished-contents {
    padding: 0.16rem;
  }
}
article .finished-contents figure {
  border-radius: 8px;
  overflow: hidden;
}
article .finished-contents figure img {
  width: 100%;
  height: auto;
}
article .finished-contents .finished-column {
  padding: 0 24px;
}
@media screen and (max-width: 768px) {
  article .finished-contents .finished-column {
    padding: 0 0.16rem;
  }
}
article .finished-contents .finished-column > div {
  padding: 16px 0;
  display: flex;
}
@media screen and (max-width: 768px) {
  article .finished-contents .finished-column > div {
    padding: 0.16rem 0;
  }
}
@media screen and (max-width: 768px) {
  article .finished-contents .finished-column > div {
    display: block;
  }
}
article .finished-contents .finished-column > div:not(:last-child) {
  border-bottom: 1px dashed #ccc2b8;
}
article .finished-contents .finished-column > div > dt {
  width: 20%;
  font-size: 14px;
  line-height: 2.5;
  letter-spacing: 0.08em;
  font-weight: 700;
}
@media screen and (max-width: 768px) {
  article .finished-contents .finished-column > div > dt {
    width: 100%;
    font-size: 0.16rem;
  }
}
article .finished-contents .finished-column > div > dd {
  width: 80%;
  font-size: 16px;
  line-height: 2.1875;
  letter-spacing: 0.08em;
  font-weight: 400;
}
@media screen and (max-width: 768px) {
  article .finished-contents .finished-column > div > dd {
    width: 100%;
    font-size: 0.14rem;
  }
}
article .finished-contents .finished-column > div > dd dl div {
  display: flex;
}
@media screen and (max-width: 768px) {
  article .finished-contents .finished-column > div > dd dl div {
    display: block;
  }
}
article .finished-contents .finished-column > div > dd dl div dt {
  width: 15%;
}
@media screen and (max-width: 768px) {
  article .finished-contents .finished-column > div > dd dl div dt {
    font-weight: 700;
    width: 100%;
  }
}
article .finished-contents .finished-column > div > dd dl div dd {
  width: 85%;
}
@media screen and (max-width: 768px) {
  article .finished-contents .finished-column > div > dd dl div dd {
    width: 100%;
  }
}

#works-links {
  margin-top: 80px;
  background-image: url("../images/works/back-works@2x.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: 60px 0;
}
#works-links .links-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
}
@media screen and (max-width: 768px) {
  #works-links .links-list {
    flex-direction: column;
    gap: 0.16rem;
  }
}
#works-links .links-list li {
  width: calc((100% - 40px) / 3);
  background: #fff;
  padding: 40px 20px 32px;
  border-radius: 20px;
}
@media screen and (max-width: 768px) {
  #works-links .links-list li {
    width: 100%;
    padding: 0.24rem 0.16rem 0.24rem;
  }
}
#works-links .links-list li .sec-header .en {
  justify-content: center;
}
#works-links .links-list li .sec-header .jp {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  margin: 16px auto 20px;
}
@media screen and (max-width: 768px) {
  #works-links .links-list li .sec-header .jp {
    margin: 0.16rem auto 0.2rem;
  }
}
#works-links .links-list li p {
  text-align: center;
  color: #f07800;
  font-size: 14px;
  line-height: 2.5;
  letter-spacing: 0.08em;
  margin-top: 8px;
  font-weight: 400;
}
@media screen and (max-width: 768px) {
  #works-links .links-list li p {
    font-size: 0.14rem;
    margin-top: 0.08rem;
  }
}

#reform {
  padding-top: 80px;
  padding-bottom: 240px;
  background-image: url("../images/works/back-reform@2x.png");
  background-size: 100%;
  background-position: center bottom;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  #reform {
    padding-top: 0.4rem;
    padding-bottom: 1.2rem;
  }
}
#reform h2 {
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  border: 1px dashed #f07800;
  border-radius: 20px;
  height: 60px;
  font-size: 20px;
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.08em;
}
@media screen and (max-width: 768px) {
  #reform h2 {
    font-size: 0.16rem;
    height: 0.6rem;
  }
}
#reform #reform-slider {
  margin-top: 32px;
}
#reform #reform-slider li {
  padding: 0 12px;
}
@media screen and (max-width: 768px) {
  #reform #reform-slider li {
    padding: 0 0.04rem;
  }
}
#reform #reform-slider li .reform-items {
  background: #fff;
  padding: 8px;
  border-radius: 24px;
}
#reform #reform-slider li .reform-items .reform-box {
  border-radius: 20px;
  padding: 16px 16px 24px;
}
#reform #reform-slider li .reform-items .reform-box > p {
  font-size: 14px;
  letter-spacing: 0.08em;
  line-height: 3;
  font-weight: 400;
}
#reform #reform-slider li .reform-items figure {
  border-radius: 20px;
  overflow: hidden;
}
#reform #reform-slider li .reform-items figure img {
  width: 100%;
  height: auto;
}
#reform #reform-slider li .reform-items .ttl-reform {
  display: flex;
  align-items: center;
  gap: 8px;
  border-bottom: 1.5px dashed #f07800;
  padding-bottom: 16px;
}
#reform #reform-slider li .reform-items .ttl-reform span {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding: 0 18px;
  border-radius: 12px;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 10px;
  color: #fff;
  background: #47372b;
  height: 24px;
}
#reform #reform-slider li .reform-items .ttl-reform p {
  font-size: 14px;
  font-weight: 400;
  line-height: 1.15;
  display: flex;
  align-items: flex-end;
  gap: 4px;
}
#reform #reform-slider li .reform-items .ttl-reform p em {
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
}/*# sourceMappingURL=works.css.map */