body.modal-open {
  overflow: hidden;
}

html {
  scroll-behavior: smooth;
}

#dcs-04 {
  background: #fadce2;
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .dcs-wrap {
    padding-top: 12.5rem;
    padding-bottom: 6.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .dcs-wrap {
    padding-top: 10rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .dcs-wrap:last-child {
    padding-bottom: 14.375rem;
  }
}
@media only screen and (max-width: 48em) {
  .dcs-wrap:last-child {
    padding-top: 4.375rem;
  }
}

.dcs-section {
  position: relative;
  margin-right: auto;
  margin-left: auto;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .dcs-section {
    width: 68.75rem;
  }
}
@media only screen and (max-width: 48em) {
  .dcs-section {
    padding-top: 4.375rem;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .dcs-section + .dcs-section {
    margin-top: 6.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .dcs-section + .dcs-section {
    margin-top: 4.375rem;
  }
}
@media only screen and (max-width: 48em) {
  .dcs-section.contents01 {
    padding-top: 0;
  }
}

.section-box {
  background: #fff;
  position: relative;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .section-box {
    border-radius: 0.625rem;
    box-shadow: 0px 0px 10px rgba(101, 99, 69, 0.2);
    padding: 3.75rem;
  }
}
@media only screen and (max-width: 48em) {
  .section-box {
    border-radius: 0.625rem;
    padding: 2.5rem 1rem;
    box-shadow: 0px 0px 10px rgba(101, 99, 69, 0.2);
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .section-box + .section-box {
    margin-top: 6.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .section-box + .section-box {
    margin-top: 3.125rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .section-title {
    margin-bottom: 3.4375rem;
  }
}
@media only screen and (max-width: 48em) {
  .section-title {
    margin-bottom: 1.4375rem;
  }
}

@media only screen and (max-width: 48em) {
  .section-title02 {
    font-size: 1.25rem;
  }
}

.lead {
  line-height: 2;
  letter-spacing: 0.1em;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .lead {
    font-size: 1rem;
  }
}
@media only screen and (max-width: 48em) {
  .lead {
    font-size: 1rem;
  }
}

.work-movie {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .charactor-tag {
    width: 15rem;
    top: -8.125rem;
    right: -2.8125rem;
    position: absolute;
  }
}
@media only screen and (max-width: 48em) {
  .charactor-tag {
    transform: rotate(-8deg);
    width: 15rem;
    margin-top: 1.25rem;
  }
}
.charactor-tag img {
  width: 100%;
  height: auto;
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-movie iframe {
    border-radius: 1.25rem;
    width: 31.25rem;
    height: 17.5rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-movie iframe {
    border-radius: 0.625rem;
    width: 100%;
    height: 11.5rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-movie .lead {
    margin-top: 1.875rem;
    padding: 0 7.0625rem;
    width: 100%;
  }
}
@media only screen and (max-width: 48em) {
  .work-movie .lead {
    line-height: 1.7;
    margin-top: 1.375rem;
    width: 19.9375rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-movie .lead + .lead {
    margin-top: 0.625rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-movie .lead + .lead {
    margin-top: 0.6875rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-images {
    margin-top: 1.0625rem;
    margin-bottom: 4.5625rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-images {
    margin-top: 2rem;
    margin-bottom: 3.75rem;
  }
}

.work-images__title {
  text-align: center;
  font-weight: 700;
  color: #000;
  letter-spacing: 0.1em;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-images__title {
    font-size: 1.625rem;
    margin-bottom: 1.1875rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-images__title {
    font-size: 1.375rem;
    margin-bottom: 0.8125rem;
  }
}

.work-images__list {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  position: relative;
}
.work-images__list::after {
  display: block;
  content: "";
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-images__list::after {
    width: 14.125rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-images__list::after {
    width: 10.375rem;
  }
}

.work-image {
  position: relative;
  overflow: hidden;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-image {
    width: 14.125rem;
    height: 10.625rem;
    border-radius: 0.625rem;
    margin-bottom: 1.1875rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-image {
    width: 10.375rem;
    height: 7.75rem;
    border-radius: 0.3125rem;
    margin-bottom: 0.625rem;
  }
}
.work-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .zoom-button {
    width: 2.375rem;
    position: absolute;
    bottom: 0.3125rem;
    right: 0.3125rem;
  }
}
@media only screen and (max-width: 48em) {
  .zoom-button {
    width: 2.375rem;
    position: absolute;
    bottom: 0.3125rem;
    right: 0.3125rem;
  }
}
.zoom-button img {
  width: 100%;
  height: auto;
}

.work-voice {
  background: #fffdea;
  position: relative;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-voice {
    border-radius: 0.625rem;
    padding: 5.25rem 4.375rem 3.75rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-voice {
    border-radius: 0.625rem;
    padding: 0.875rem 1.375rem 3.125rem;
    margin: 0 -0.5rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-voice + .work-voice {
    margin-top: 5.125rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-voice + .work-voice {
    margin-top: 1.875rem;
  }
}

@media only screen and (max-width: 48em) {
  .work-category {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0.9375rem;
  }
}

.work-category p {
  color: #ed7a94;
  letter-spacing: 0.1em;
  font-weight: 700;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  background: url(../../img/dcs/page04/work-fukidashi.png) no-repeat top center/100% auto;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-category p {
    font-size: 1.625rem;
    width: 16.375rem;
    height: 6.25rem;
    padding-top: 1.25rem;
    position: absolute;
    top: -2.125rem;
    left: -1.5rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-category p {
    width: 11.5rem;
    height: 4.375rem;
    font-size: 1.25rem;
    padding-top: 0.9375rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-category > img {
    width: 8.125rem;
    height: auto;
    position: absolute;
    top: 2.75rem;
    right: 4.375rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-category > img {
    width: 6.25rem;
    height: 6.5rem;
  }
}

.voice-title {
  color: #418fde;
  font-weight: 700;
  letter-spacing: 0.1em;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .voice-title {
    font-size: 1.75rem;
    margin-bottom: 2.5rem;
  }
}
@media only screen and (max-width: 48em) {
  .voice-title {
    font-size: 1.125rem;
    margin: 0 auto 1.25rem;
    width: 19rem;
    letter-spacing: 0.03em;
  }
}

.voice-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media only screen and (max-width: 48em) {
  .voice-inner {
    flex-direction: column;
  }
}
@media only screen and (max-width: 48em) {
  .voice-inner.voice02 {
    flex-direction: column-reverse;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .voice-text {
    width: 24.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .voice-text {
    margin-bottom: 1.875rem;
    width: 19rem;
  }
}
@media only screen and (max-width: 48em) {
  .voice-text .lead {
    line-height: 1.7;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .voice-text .lead + .lead {
    margin-top: 2em;
  }
}
@media only screen and (max-width: 48em) {
  .voice-text .lead + .lead {
    margin-top: 1.25rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .voice-image {
    width: 25.5625rem;
    height: auto;
  }
}
.voice-image figcaption {
  font-size: 90%;
  text-align: center;
  margin-top: 1em;
}

.work-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media only screen and (max-width: 48em) {
  .work-inner {
    flex-direction: column;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-inner img {
    width: 28.75rem;
    height: 18.75rem;
    border-radius: 0.625rem;
    margin-right: 2.3125rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-inner img {
    margin-bottom: 1.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .work-inner .lead {
    line-height: 1.7;
    width: 19.9375rem;
  }
}

@media only screen and (max-width: 48em) {
  .work-inner.work02 {
    flex-direction: column-reverse;
  }
}

@media only screen and (max-width: 48em) {
  .work-inner.project {
    flex-direction: column-reverse;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-inner.project img {
    margin-right: 0;
    margin-left: 2.1875rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .work-inner.interview {
    align-items: flex-start;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .interview-movie {
    width: 31.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .interview-movie {
    width: 100%;
  }
}
.interview-movie .work-movie {
  border-radius: 0.625rem;
  overflow: hidden;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .interview-movie .lead {
    margin-top: 0.875rem;
  }
}
@media only screen and (max-width: 48em) {
  .interview-movie .lead {
    margin: 1.25rem auto 0;
    width: 19.9375rem;
  }
}

.link {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .link {
    font-size: 1rem;
    margin-top: 0.4375rem;
  }
}
@media only screen and (max-width: 48em) {
  .link {
    font-size: 1rem;
    margin-top: 0.5rem;
  }
}
.link span {
  text-decoration: underline;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .link img {
    width: 1.625rem;
    height: auto;
    margin-right: 0.5625rem;
  }
}
@media only screen and (max-width: 48em) {
  .link img {
    width: 1.5rem;
    height: auto;
    margin-right: 0.4375rem;
    margin-bottom: 0;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .contact {
    width: 26.25rem;
    padding-top: 3.75rem;
  }
}
@media only screen and (max-width: 48em) {
  .contact {
    width: 100%;
    margin-top: 1.875rem;
  }
}
.contact p {
  font-weight: 700;
  letter-spacing: 0.1em;
  text-align: center;
  line-height: 1.8;
  position: relative;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .contact p {
    font-size: 1rem;
    margin-bottom: 1.75rem;
  }
}
@media only screen and (max-width: 48em) {
  .contact p {
    line-height: 1.5;
    font-size: 0.875rem;
    margin-bottom: 1rem;
  }
}
.contact p::before {
  display: block;
  content: "";
  background: url(../../img/dcs/page04/title-bar.png) no-repeat center center/cover;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .contact p::before {
    width: 1.0625rem;
    height: 3.5625rem;
    position: absolute;
    bottom: 0;
    left: 0.3125rem;
  }
}
@media only screen and (max-width: 48em) {
  .contact p::before {
    width: 1.0625rem;
    height: 2.875rem;
    position: absolute;
    bottom: 0;
    left: 0.3125rem;
  }
}
.contact p::after {
  display: block;
  content: "";
  background: url(../../img/dcs/page04/title-bar.png) no-repeat center center/cover;
  transform: scale(1, -1);
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .contact p::after {
    width: 1.0625rem;
    height: 3.5625rem;
    position: absolute;
    bottom: 0;
    right: 0.3125rem;
  }
}
@media only screen and (max-width: 48em) {
  .contact p::after {
    width: 1.0625rem;
    height: 2.875rem;
    position: absolute;
    bottom: 0;
    right: 0.4375rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .contact .c-button {
    width: 100%;
    height: 3.75rem;
    font-size: 1.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .contact .c-button {
    width: 100%;
    height: 3.75rem;
    font-size: 1rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .heading {
    margin-bottom: 4.125rem;
  }
}
@media only screen and (max-width: 48em) {
  .heading {
    margin-bottom: 1.25rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .heading .section-title02 {
    margin-bottom: 0.9375rem;
  }
}
@media only screen and (max-width: 48em) {
  .heading .section-title02 {
    margin-bottom: 1.25rem;
  }
}

.heading .lead {
  text-align: center;
}
@media only screen and (max-width: 48em) {
  .heading .lead {
    line-height: 1.7;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .project-inner {
    margin-top: 3.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .project-inner {
    margin-top: 1.625rem;
  }
}
.project-inner h3 {
  color: #ed7a94;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.1em;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .project-inner h3 {
    font-size: 1.5rem;
    margin-bottom: 1.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .project-inner h3 {
    font-size: 1.0625rem;
    margin-bottom: 1rem;
  }
}
.project-inner h3 span {
  position: relative;
  display: inline-block;
}
.project-inner h3 span::before {
  display: block;
  content: "";
  background: url(../../img/dcs/page04/title-bar-pk.png) no-repeat center center/cover;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .project-inner h3 span::before {
    width: 1.0625rem;
    height: 2.0625rem;
    position: absolute;
    bottom: 0;
    left: -1.6875rem;
  }
}
@media only screen and (max-width: 48em) {
  .project-inner h3 span::before {
    background: url(../../img/dcs/page04/title-bar-pk_sp.png) no-repeat center center/cover;
    width: 1.5625rem;
    height: 4.25rem;
    position: absolute;
    bottom: 0;
    left: -1.6875rem;
  }
}
.project-inner h3 span::after {
  display: block;
  content: "";
  background: url(../../img/dcs/page04/title-bar-pk.png) no-repeat center center/cover;
  transform: scale(1, -1);
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .project-inner h3 span::after {
    width: 1.0625rem;
    height: 2.0625rem;
    position: absolute;
    bottom: 0;
    right: -1.0625rem;
  }
}
@media only screen and (max-width: 48em) {
  .project-inner h3 span::after {
    background: url(../../img/dcs/page04/title-bar-pk_sp.png) no-repeat center center/cover;
    width: 1.5625rem;
    height: 4.25rem;
    position: absolute;
    bottom: 0;
    right: -1.6875rem;
  }
}
.project-inner > picture img {
  width: 100%;
  height: auto;
}

.section-box.news .heading {
  display: flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .section-box.news .heading {
    margin-bottom: 2.5rem;
  }
}

.section-box.news .section-title02 span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.section-box.news .section-title02 span img {
  display: inline-block;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .section-box.news .section-title02 span img {
    width: 1.8125rem;
    height: auto;
    margin-right: 0.5rem;
  }
}
@media only screen and (max-width: 48em) {
  .section-box.news .section-title02 span img {
    width: 1.25rem;
    height: auto;
    margin-right: 0.3125rem;
  }
}

.news-block {
  max-height: 0;
  overflow: hidden;
  transition: all 0.4s ease;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .news-block {
    padding: 0;
    background-image: url(../../img/dcs/common/section-border.png);
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
  }
}
@media only screen and (max-width: 48em) {
  .news-block {
    padding: 0;
    background-image: url(../../img/dcs/common/section-border_sp.png);
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
  }
}
.news-block.visible {
  max-height: 100%;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .news-block.visible {
    padding: 1.5625rem 0;
  }
}
@media only screen and (max-width: 48em) {
  .news-block.visible {
    padding: 1.5625rem 0;
  }
}

.news-article {
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .news-article {
    padding: 0 1.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .news-article {
    flex-direction: column;
    align-items: flex-start;
    width: 19.9375rem;
    margin: 0 auto;
  }
}
.news-article .day {
  color: #418fde;
  font-weight: 700;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .news-article .day {
    font-size: 1rem;
    width: 8.125rem;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
}
@media only screen and (max-width: 48em) {
  .news-article .day {
    font-size: 1rem;
  }
}
.news-article .day span {
  color: #000000;
  font-weight: 400;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .news-article .day span {
    margin-right: 0.625rem;
  }
}
@media only screen and (max-width: 48em) {
  .news-article .day span {
    display: none;
  }
}
.news-article .text {
  color: #000;
  letter-spacing: 0.1em;
  position: relative;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .news-article .text {
    font-size: 1rem;
  }
}
@media only screen and (max-width: 48em) {
  .news-article .text {
    font-size: 1rem;
  }
}
.news-article .text:hover {
  color: #595757;
}
.news-article .text:hover::after {
  display: block;
  content: "";
  width: 100%;
  height: 1px;
  background: #595757;
  position: absolute;
  left: 0;
  bottom: -1px;
}

.section-box.news .news-more {
  box-shadow: 0 5px 0 #9bcfeb;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .section-box.news .news-more {
    width: 26.25rem;
    height: 3.75rem;
    font-size: 1.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .section-box.news .news-more {
    width: 100%;
    height: 3.75rem;
    font-size: 1rem;
    margin-top: 1.25rem;
  }
}
.section-box.news .news-more:hover {
  transform: translateY(3px);
  box-shadow: 0 3px 0 #9bcfeb;
}
.section-box.news .news-more.active {
  background-image: url(../../../img/dcs/common/btn-arrow-up.png);
}

.item-cart {
  background-color: #fff;
  position: relative;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-cart {
    width: 55rem;
    height: 25rem;
    border-radius: 0.625rem;
    border: 3px solid #ed7a94;
    box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.16);
    margin: 6.25rem auto;
    padding-top: 2.625rem;
    padding-left: 5.75rem;
    padding-right: 6.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .item-cart {
    margin: 3.125rem 0 4.375rem;
    border-radius: 0.625rem;
    border: 3px solid #ed7a94;
    box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.16);
    padding: 2.5rem 1.5625rem;
  }
}
.item-cart h2 {
  color: #ed7a94;
  font-weight: 800;
  text-align: center;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-cart h2 {
    font-size: 2.875rem;
    margin-bottom: 1.5625rem;
  }
}
@media only screen and (max-width: 48em) {
  .item-cart h2 {
    font-size: 1.875rem;
    margin-bottom: 1.0625rem;
  }
}
.item-cart h2 span {
  position: relative;
}
.item-cart h2 span::before {
  display: block;
  content: "";
  background: url(../../img/dcs/page04/title-bar-pk.png) no-repeat center center/cover;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-cart h2 span::before {
    width: 1.375rem;
    height: 3.75rem;
    position: absolute;
    bottom: 0;
    left: -2.6875rem;
  }
}
@media only screen and (max-width: 48em) {
  .item-cart h2 span::before {
    width: 1.375rem;
    height: 2.625rem;
    position: absolute;
    bottom: 0;
    left: -2.6875rem;
  }
}
.item-cart h2 span::after {
  display: block;
  content: "";
  background: url(../../img/dcs/page04/title-bar-pk.png) no-repeat center center/cover;
  transform: scale(1, -1);
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-cart h2 span::after {
    width: 1.375rem;
    height: 3.75rem;
    position: absolute;
    bottom: 0;
    right: -2.6875rem;
  }
}
@media only screen and (max-width: 48em) {
  .item-cart h2 span::after {
    width: 1.375rem;
    height: 2.625rem;
    position: absolute;
    bottom: 0;
    right: -2.6875rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-cart::before {
    display: block;
    content: "";
    background: url(../../img/dcs/page04/kumapin.png) no-repeat center center/100% auto;
    width: 9.5rem;
    height: 19.3125rem;
    position: absolute;
    bottom: 0;
    left: -9.6875rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-cart::after {
    display: block;
    content: "";
    background: url(../../img/dcs/page04/kaikai.png) no-repeat center center/100% auto;
    width: 9.3125rem;
    height: 6rem;
    position: absolute;
    bottom: -1.625rem;
    right: -4.375rem;
  }
}

.item-cart__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media only screen and (max-width: 48em) {
  .item-cart__inner {
    flex-direction: column;
  }
}
.item-cart__inner > img {
  background: #f0f5f8;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-cart__inner > img {
    width: 14.4375rem;
    height: 14.4375rem;
    border-radius: 0.625rem;
  }
}
@media only screen and (max-width: 48em) {
  .item-cart__inner > img {
    width: 16.875rem;
    height: 16.875rem;
    border-radius: 0.625rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-detail {
    width: 26.25rem;
  }
}
@media only screen and (max-width: 48em) {
  .item-detail {
    width: 16.875rem;
    margin-top: 0.75rem;
  }
}
.item-detail .name {
  color: #000;
  letter-spacing: 0.1em;
  font-weight: 700;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-detail .name {
    font-size: 1.5rem;
  }
}
@media only screen and (max-width: 48em) {
  .item-detail .name {
    color: #595757;
    font-size: 1.5rem;
    line-height: 1.4;
  }
}
.item-detail .price {
  font-weight: 700;
  color: #000;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-detail .price {
    font-size: 2rem;
    margin-bottom: 1.1875rem;
  }
}
@media only screen and (max-width: 48em) {
  .item-detail .price {
    color: #595757;
    font-size: 2rem;
    margin-bottom: 1.25rem;
  }
}
.item-detail .price small {
  font-weight: 400;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-detail .price small {
    font-size: 1rem;
    margin-right: 0.3125rem;
  }
}
@media only screen and (max-width: 48em) {
  .item-detail .price small {
    font-size: 1rem;
    margin-right: 0.3125rem;
  }
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .item-detail .price span {
    font-size: 1rem;
    margin-left: 0.3125rem;
  }
}
@media only screen and (max-width: 48em) {
  .item-detail .price span {
    font-size: 1rem;
    margin-left: 0.3125rem;
  }
}
.item-detail .c-button {
  width: 100%;
}
@media only screen and (max-width: 48em) {
  .item-detail .c-button {
    width: 20rem;
    margin-left: -1.5625rem;
  }
}

.fslightbox-slide-btn {
  background: url(../../img/dcs/common/nav-arrow-bk.png) no-repeat center center/5rem auto !important;
  width: 5rem;
  height: 5rem;
}
@media only screen and (max-width: 48em) {
  .fslightbox-slide-btn {
    width: 3.125rem;
    height: 3.125rem;
    background-size: 3.125rem auto !important;
  }
}
.fslightbox-slide-btn svg {
  display: none;
}

.fslightbox-slide-btn-container-next .fslightbox-slide-btn {
  background: url(../../img/dcs/common/nav-arrow-bk-next.png) no-repeat center center/5rem auto !important;
  width: 5rem;
  height: 5rem;
  transform: scale(1, -1);
}
@media only screen and (max-width: 48em) {
  .fslightbox-slide-btn-container-next .fslightbox-slide-btn {
    width: 3.125rem;
    height: 3.125rem;
    background-size: 3.125rem auto !important;
  }
}

.fslightbox-slide-number-container {
  display: none !important;
}

@media only screen and (max-width: 48em) {
  .fslightbox-slide-btn-container.fslightbox-slide-btn-container-previous,
  .fslightbox-slide-btn-container.fslightbox-slide-btn-container-next {
    top: 75%;
  }
}

@media only screen and (max-width: 48em) {
  .fslightbox-toolbar {
    right: unset;
    left: 0;
  }
}

.fslightbox-toolbar-button {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  cursor: pointer !important;
  background: url(../../img/dcs/page04/close-icon.png) no-repeat center center;
  background-color: #000 !important;
  color: #fff !important;
  font-weight: 700 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .fslightbox-toolbar-button {
    width: 11.875rem !important;
    height: 11.875rem !important;
    right: 0 !important;
    background-size: 3.875rem auto;
  }
}
@media only screen and (max-width: 48em) {
  .fslightbox-toolbar-button {
    width: 4.375rem !important;
    height: 4.375rem !important;
    background-size: 2rem auto;
    right: unset !important;
    left: 0;
  }
}
.fslightbox-toolbar-button svg {
  display: none;
}

@media only screen and (max-width: 48em) {
  .fslightbox-fade-in-strong {
    width: 90%;
    border-radius: 0.3125rem;
    overflow: hidden;
    outline: 5px solid #fff;
  }
  .fslightbox-fade-in-strong img {
    width: 100% !important;
    height: auto !important;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .anchor_link {
    scroll-margin-top: 9.375rem;
  }
}
@media only screen and (max-width: 48em) {
  .anchor_link {
    scroll-margin-top: 9.375rem;
  }
}

.header-nav__item:last-child a p {
  position: relative;
  color: #ed7a94;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .header-nav__item:last-child a p::after {
    display: block;
    content: "";
    background: url(../../../img/dcs/common/nav-bar.png) no-repeat center center/cover;
    width: 90%;
    height: 0.3125rem;
    position: absolute;
    left: 0;
    bottom: -0.3125rem;
  }
}
@media only screen and (max-width: 48em) {
  .header-nav__item:last-child a p::after {
    display: block;
    content: "";
    background: url(../../../img/dcs/common/nav-bar.png) no-repeat center center/cover;
    width: 90%;
    height: 0.3125rem;
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    bottom: -0.3125rem;
  }
}

.news-images {
  width: 80%;
  max-height: 800px;
}
@media only screen and (max-width: 48em) {
  .news-images {
    width: 90%;
    padding-bottom: 5rem;
    margin-bottom: -5rem;
  }
}

.modal-contents.is-news {
  align-items: center;
  flex-direction: column;
}
@media only screen and (max-width: 48em) {
  .modal-contents.is-news {
    flex-direction: column-reverse;
  }
  .modal-contents.is-news .swiper-button-prev {
    left: 0;
    width: 3.125rem;
    height: 3.125rem;
    top: unset;
    bottom: 0;
  }
  .modal-contents.is-news .swiper-button-prev::after {
    content: "";
    background: url(../../img/dcs/common/nav-arrow-bk.png) no-repeat center center/3.125rem auto;
    width: 3.125rem;
    height: 3.125rem;
  }
  .modal-contents.is-news .swiper-button-next {
    right: 0;
    width: 3.125rem;
    height: 3.125rem;
    top: unset;
    bottom: 0;
  }
  .modal-contents.is-news .swiper-button-next::after {
    content: "";
    background: url(../../img/dcs/common/nav-arrow-bk-next.png) no-repeat center center/3.125rem auto;
    width: 3.125rem;
    height: 3.125rem;
  }
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .swiper-wrapper {
    justify-content: center;
  }
}

.swiper-slide.news-slide {
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media only screen and (min-width: calc(48em + 0.01px)) {
  .swiper-slide.news-slide {
    width: 500px !important;
    height: auto;
    border-radius: 0.625rem;
  }
  .swiper-slide.news-slide.slide-two {
    border-radius: 0px;
    width: 800px !important;
  }  
  .swiper-slide.news-slide.slide-two ul {
    display: flex;
  }
  .swiper-slide.news-slide.slide-two ul li {
    width: 50%;
    padding: 0 20px;
    box-sizing: border-box;
  }
  .swiper-slide.news-slide.slide-two ul li img {
    border-radius: 0.625rem;
  }
}
@media only screen and (max-width: 48em) {
  .swiper-slide.news-slide {
    border-radius: 0.625rem;
  }
  .swiper-slide.news-slide.slide-two {
    border-radius: 0px;
  }
  .swiper-slide.news-slide.slide-two ul li {
    width: 100%;
    padding: 0;
    box-sizing: border-box;
    display: flex;
    flex-direction: column-reverse;
    margin: 0 auto;
  }
  .swiper-slide.news-slide.slide-two ul li:first-child {
    margin-bottom: 1.25rem;
  }
  .swiper-slide.news-slide.slide-two ul li p {
    margin-bottom: 0.25rem;
  }
  .swiper-slide.news-slide.slide-two ul li br {
    display: none;
  }
  .swiper-slide.news-slide.slide-two ul {
    display: block;
  }
  .swiper-slide.news-slide.slide-two ul li img {
    border-radius: 0.625rem;
  }
}
.swiper-slide.news-slide img {
  width: 100%;
  height: auto;
}
@media only screen and (max-width: 48em) {
  .swiper-slide.news-slide img {
    border-radius: 0.625rem;
    overflow: hidden;
    border: 2px solid #fff;
  }
}

.image-title {
  color: #fff;
  font-weight: 700;
  text-align: center;
}
@media only screen and (min-width: calc(48em + 0.01px)) {
  .image-title {
    font-size: 1.875rem;
    margin-top: 1.875rem;
  }
}
@media only screen and (max-width: 48em) {
  .image-title {
    font-size: 1.125rem;
    margin-bottom: 1.25rem;
  }
}/*# sourceMappingURL=page04.css.map */

.section-title03 {
  font-size: 1.625rem;
  margin-top: 4.5rem;
  margin-bottom: 3rem;
  text-align: center;
  color: #000;
  font-weight: 700;
}

.other-work-title-cont {
  display: flex;
  justify-content: space-between;
  margin-bottom: 2.5rem;
  line-height: 2;
  letter-spacing: 0.1em;
}

.other-work-title-cont.other-work-title-cont-1 {
  flex-direction: row-reverse;
}

.other-work-title {
  width: 50%;
}

.other-work-img {
  width: 46%;
}

.other-work-img .swiper-slide img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: 0.625rem;
}

.other-work-img .item_img {
  margin-bottom: 0.7875rem;
}

.other-work-img .swiper-wrapper {
  justify-content: left;
}

.other-work-title .title {
  font-size: 1.5rem;
  margin-top: 1.05rem;
  margin-bottom: 3rem;
  font-weight: 700;
}

.other-work-title .detail {
  display: flex;
}

.other-work-title .detail dt {
  width: 5.5rem;
}
.other-work-title .detail dd:before {
  content: "：";
}
.other-work-title .detail dd {
  text-indent: -1em;
}
.other-work-title .link {
  margin-top: 1.5rem;
  font-size: 0.9rem;
}
.other-work-title .link a:hover {
  text-decoration: underline;
}

.other-work-cont h3 {
  color: #418fde;
  font-weight: 700;
  letter-spacing: 0.1em;
  font-size: 1.75rem;
  margin-bottom: 0.5rem;
}
.other-work-cont .work-voice {
  margin-top: 4rem;
  margin-bottom: 4rem;
  padding: 3.25rem 4.375rem 1.75rem;
}

.other-work-cont .work-voice .voice-title {
  margin-bottom: 1.5rem;
  font-size: 1.5rem;
}

.other-work-cont .work-voice p {
  line-height: 2;
  letter-spacing: 0.1em;
  margin-bottom: 3rem;
}

@media only screen and (max-width: 48em) {
  .section-title03 {
    font-size: 1.125rem;
    margin: 3rem auto 1.25rem;
    letter-spacing: 0.03em;
  }
  .other-work-title-cont {
    display: block;
  }
  .other-work-title {
    width: 100%;
  }
  .other-work-title .title {
    font-size: 1.125rem;
    letter-spacing: 0.03em;
    margin: 2rem auto 1.25rem;
  }
  .other-work-title .detail {
    line-height: 1.7;
    display: block;
    font-size: 80%;
  }
  .other-work-title .detail dt {
    width: 100%;
  }
  .other-work-title .detail dd {
    text-indent: 0;
    margin-bottom: 1rem;
  }
  .other-work-title .detail dd::before {
    display: none;
  }
  .other-work-title .link {
    margin-top: 0;
    font-size: 80%;
  }
  .other-work-img {
    width: 100%;
    margin-top: 2rem;
  }
  .other-work-cont h3 {
    font-size: 1.2rem;
  }
  .other-work-cont .work-voice {
    border-radius: 0.625rem;
    padding: 1.25rem 1.375rem 0.5rem;
    margin-top: 1.875rem;
    margin-bottom: 1.25rem;
  }
  .other-work-cont .work-voice .voice-title {
    margin-bottom: 1rem;
    font-size: 1.2rem;
  }
  
  .other-work-cont .work-voice p {
    line-height: 1.7;
    margin-bottom: 2rem;
  }
}