@charset "utf-8";

.mv-bg {
  position: relative;
  overflow: hidden;
}

.mv-img {
  display: grid;
  grid-template-columns: 25% 1fr;
  height: 100%;
  width: 100%;
  position: absolute;
}

.bg-img {
  position: relative;
}

.mv-img .bg-img img,
.mv-img .bg-img picture {
  height: 100%;
  width: 100%;
  object-fit: cover;
}

.bg-img::before {
  content: '';
  position: absolute;
  top: 0;
  left: -1px;
  width: 170px;
  height: 100%;
  background-color: var(--clr-primary);
  z-index: 1;
  clip-path: polygon(0% 0%, 1% 0%, 85% 100%, 0% 100%);
  opacity: 1;
}

.mv-bg .q-bg {
  position: relative;
  margin-left: 13.69vw;
  z-index: 1;
}

.mv-bg .mv-text {
  position: absolute;
  top: 45%;
  transform: translateY(-55%);
  z-index: 2;
  padding-inline: var(--space-45);
}

.mv-text h2 {
  line-height: 1.5;
}

.mv-text p {
  line-height: 2;
}

.q-bg .event-btn {
  position: absolute;
  bottom: 6.25rem;
  left: 4%;
}

.vertical-ttl {
  position: relative;
}

.vertical-ttl span {
  position: absolute;
  top: 10%;
  color: var(--clr-neutral-100);
  font-size: 5rem;
  font-weight: 700;
  white-space: nowrap;
  z-index: 1;
  writing-mode: vertical-lr;
  opacity: 0.45;
}

.sec-concerns {
  padding-block: var(--space-80) 6.5625rem;
}

.sec-concerns .sec-ttl {
  padding-bottom: var(--space-40);
}

.concerns-list li+li {
  margin-top: var(--space-50);
}

.concerns-card {
  display: grid;
  position: relative;
  grid-template-columns: repeat(2, 1fr);
  background-color: var(--clr-secondary);
}

.concerns-card::after {
  position: absolute;
  top: 0;
  right: 99%;
  bottom: 0;
  width: 50vw;
  content: "";
  z-index: -999;
  background-color: inherit;
}

.concern-problem-wrap {
  padding-block: var(--space-45);
}

.concern-problem {
  display: flex;
  margin-left: var(--space-50);
  gap: 1.4375rem;
}

.concern-problem-txt {
  padding: var(--space-60) 0 var(--space-90) var(--space-55);
  background: url("../img/event-scene-detail/img_concern_bg.png") no-repeat left top / contain;
}

.concern-problem-txt h3 {
  line-height: 1.5;
}

.concern-problem-img {
  align-items: flex-end;
}

.concern-solution {
  display: grid;
  position: relative;
  margin: 0 var(--space-40) var(--space-40) 0;
  padding: var(--space-70) var(--space-20) var(--space-20) var(--space-70);
  border-radius: 0 0 50px 50px;
  grid-template-areas:
    "title title"
    "text image"
    "text image"
    "button button";
  grid-template-columns: 1fr 1fr;
  align-items: center;
  background-color: var(--clr-neutral-100);
}

.concern-solution::before {
  position: absolute;
  top: 50%;
  left: -1.5rem;
  border-color: transparent transparent var(--clr-secondary) transparent;
  transform: rotate(90deg) translateX(-50%);
  content: "";
  border-style: solid;
  border-width: 0 53.5px 59px 53.5px;
}

.concern-solution .concern-solution-ttl {
  line-height: 1.5;
  margin: 0;
  grid-area: title;
}

.concern-solution-txt {
  grid-area: text;
}

.concern-solution-txt p {
  line-height: 2;
}

.concern-solution-img {
  grid-area: image;
}

.concern-solution-img img {
  margin: auto;
}

.concerns-card .view-more-case {
  grid-area: button;
  justify-content: flex-start;
}

.concern-solution .btn-view-more {
  padding: .625rem 1.4375rem .75rem 1.75rem;
}

.sec-feature {
  padding-block: var(--space-100) var(--space-80);
  background-color: var(--clr-secondary);
}

.feature-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-30);
}

.feature-list-item {
  display: grid;
  max-width: 21.875rem;
  padding: var(--space-30) var(--space-25);
  margin-inline: auto;
  grid-template-rows: 1fr 1fr;
  gap: var(--space-15);
  background-color: var(--clr-neutral-100);
}

.feature-list-item p {
  line-height: 2;
  font-size: var(--fs-14);
  text-align: justify;
}

.feature-wrap li+li {
  margin-top: var(--space-35);
}

.feature-icon {
  width: 35%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.icon-wrap {
  display: flex;
  align-items: center;
}

.feature-list-item .icon-wrap h4 {
  line-height: 1.4;
}

.content-info-wrapper::before {
  background: url("../img/event-scene-detail/img_free_account_left.png") no-repeat center / contain;
}

.content-info-wrapper::after {
  background: url("../img/event-scene-detail/img_free_account_right.png") no-repeat center / contain;
}

@media (min-width: 100em) {
  .sec-mv .mv-content{
    max-width: 1600px;
    padding-inline: var(--space-40);
    margin-inline:auto;
  }

  .mv-bg .q-bg {
    margin-left: unset;
    left: 50%;
    transform: translateX(-40%);
  }
}

@media (max-width: 73.75em) {
  .concerns-card {
    grid-template-columns: 1fr;
    gap: 1.4375rem;
    justify-content: center;
    align-items: center;
    padding-block: var(--space-20) var(--space-35);
  }

  .concern-problem {
    margin: auto;
    justify-content: space-between;
    max-width: 18.5rem;
  }

  .concern-solution {
    margin-bottom: 0;
    padding: var(--space-40);
    border-radius: 50px;
    margin-inline: var(--space-40);
    grid-template-areas:
      "title image"
      "text text"
      "button button";
  }

  .concern-solution::before {
    top: 0;
    left: 50%;
    transform: rotate(180deg) translateX(50%);
    border-width: 0 20px 20px 20px;
  }

  .concern-problem-txt h3 {
    font-size: 1.125rem;
  }

  .concern-solution .concern-solution-ttl {
    font-size: 1rem;
  }

  .feature-list-item {
    gap: var(--space-30);
    grid-template-rows: auto auto;
  }

  .feature-icon {
    width: 100%;
  }

  .icon-wrap {
    padding-left: 0;
    flex-direction: column;
    justify-content: center;
    gap: var(--space-15);
  }

  .feature-wrap li+li {
    margin-top: var(--space-10);
  }

  .feature-list {
    gap: var(--space-10);
  }

  .feature-icon svg {
    margin: auto;
  }

  .view-more-case {
    justify-content: center;
  }

  .concerns-card .view-more-case .btn-view-more {
    margin: auto;
  }
}

@media (max-width: 73.75em) and (min-width: 48.0625em) {
  .q-bg .btn {
    min-width: 30rem;
    height: 4rem;
    font-size: var(--fs-24);
  }

  .q-bg .btn:after {
    right: 1.25rem;
    width: 1.5rem;
    height: 1.5rem;
  }
}

@media (max-width: 48em) {

  .mv-bg .event-btn .btn::after {
    width: 1.125rem;
    height: 1.125rem;
  }

  .event-btn .btn .icon {
    width: 1.5625rem;
    height: 1.5625rem;
  }

  .mv-img {
    grid-template-columns: unset;
    height: auto;
  }

  .bg-img::before {
    display: none;
  }

  .mv-img .bg-img {
    min-height: 23rem;
  }

  .mv-img .bg-img img {
    object-position: 59%;
  }

  .mv-bg .q-bg {
    margin: 30.531vw 0 0 0;
  }

  .mv-bg .mv-text {
    top: 4.5rem;
    transform: translateY(0);
    width: 100%;
  }

  .mv-text .event-btn {
    margin-top: 3.4375rem;
  }

  .q-bg .event-btn {
    bottom: 1.875rem;
    left: 1.5625rem;
  }

  .q-bg .event-btn .btn {
    padding-inline: 1.875rem 5rem;
    font-size: 1.125rem
  }

  .q-bg .event-btn .btn:after {
    right: 1.25rem;
  }

  .vertical-ttl span {
    font-size: 14.103vw;
    writing-mode: unset;
    line-height: 0.9;
  }

  .q-bg img {
    position: relative;
    top: 1.25rem;
    width: 13.25rem;
    margin-left: var(--space-20);
  }

  .q-bg::after {
    display: block;
    width: 100%;
    height: var(--space-100);
    content: "";
    background-color: var(--clr-primary);
  }

  .sec-concerns {
    padding-block: var(--space-30) var(--space-100);
  }

  .sec-concerns .sec-wrap {
    --padding: 0;
  }

  .concern-problem-wrap {
    padding-block: 0;
  }

  .concerns-list li+li {
    margin-top: var(--space-30);
  }

  .concern-problem-txt {
    padding: var(--space-20) 0 var(--space-45) var(--space-25);
    flex-shrink: 0;
  }

  .private-show .concern-problem-img img:first-child {
    width: var(--space-120);
  }

  .concern-problem-img {
    width: var(--space-90);
  }

  .concern-solution {
    padding: var(--space-20);
    grid-template-areas:
      "title"
      "image"
      "text"
      "button";
    grid-template-columns: 1fr;
    max-width: 18.5rem;
    margin: auto;
  }

  .concern-solution .btn-view-more {
    font-size: .6875rem;
  }

  .sec-feature {
    padding-block: var(--space-50);
  }

  .feature-list {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
    gap: var(--space-10);
  }

  .feature-wrap li+li {
    margin-top: var(--space-10);
  }

  .icon-wrap {
    flex-direction: row;
    justify-content: left;
  }

  .feature-icon {
    width: unset;
  }

  .private-show .q-bg img,
  .family-sale .q-bg img,
  .recruit .q-bg img {
    width: 14.5rem;
  }

  .reception .mv-text .event-btn {
    margin-top: 3.25rem;
  }

  .family-sale .mv-text .event-btn {
    margin-top: 3.125rem;
  }

  .private-show .q-bg img,
  .family-sale .q-bg img,
  .reception .q-bg img,
  .recruit .q-bg img {
    width: 15rem;
  }

  .private-show .mv-bg .mv-text,
  .family-sale .mv-bg .mv-text,
  .reception .mv-bg .mv-text,
  .recruit .mv-bg .mv-text {
    padding-inline: var(--space-60);
  }

  .scene-type .concerns-card:first-child .concern-problem-img {
    width: var(--space-120);
    height: auto;
  }
}

@media (max-width: 35em) {
  .mv-bg .q-bg {
    margin: 7.143vw 0 0 0;
  }
}

@media (max-width: 24.4375em) {
  .mv-bg .q-bg {
    margin: 3.143vw 0 0 0;
  }
}

@media (max-width: 23.75em) {
  .q-bg .event-btn .btn {
    padding-inline: 1.25rem 3.75rem;
    font-size: 4.615vw;
  }
}

@media (max-width: 68.75em) and (min-width: 48.0625em) {
  .concern-problem-txt span {
    font-size: .75rem;
  }

  .concern-problem-txt {
    padding: 3.625rem 0 2.8125rem 1.875rem;
  }

  .concern-solution::before {
    border-width: 0 1.875rem 1.875rem 1.875rem;
  }

  .concern-solution {
    padding: 1.25rem;
    max-width: 32.1875rem;
    margin: auto;
  }

  .concern-solution-txt p {
    font-size: .75rem;
  }

    .concern-problem {
    margin-left: 0;
    justify-content: space-around;
    max-width: 32.1875rem;
    margin: auto;
    }
}