@charset "UTF-8";
/*--------------------
共通設定
----------------------*/
* {
  padding: 0;
  margin: 0; }

img, video {
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

a {
  text-decoration: none;
  color: #3c463c;
  transition: .4s; }
  a.disabled {
    pointer-events: none;
    text-decoration: none; }

ul, ol {
  list-style: none; }

/*--------------------------------------------*/
.image_wrapper {
  position: relative;
  overflow: hidden; }
  .image_wrapper::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 1; }

.js-anime__item {
  position: relative;
  overflow: hidden;
  opacity: 0;
  transform: translateY(15px);
  transition: opacity 1.5s cubic-bezier(0.2, 0.6, 0.4, 1), transform 1.5s cubic-bezier(0.2, 0.6, 0.4, 1); }

.js-anime__item.is-active {
  opacity: 1;
  transform: translateY(0); }
  .js-anime__item.is-active .image_wrapper::before {
    animation: bg-gradient 2.0s ease-out alternate forwards; }

@keyframes bg-gradient {
  0% {
    opacity: 1;
    background-image: linear-gradient(15deg, rgba(253, 253, 248, 0.8), #fdfdf8 20%); }
  100% {
    background-image: linear-gradient(15deg, rgba(253, 253, 248, 0), #fdfdf8 100%);
    opacity: 0; } }
/*--------------------------------------------*/
.lp_wrapper {
  margin: 0 auto;
  box-sizing: border-box;
  background: #fdfdf8;
  letter-spacing: 0.05em;
  color: #3c463c;
  font-size: 14px;
  text-align: left;
  font-family: "toppan-bunkyu-gothic-pr6n", serif;
  font-weight: normal;
  font-style: normal;
  font-weight: 400;
  overflow: hidden;
  /* modal */ }
  .lp_wrapper .innerBox {
    max-width: 1920px;
    margin: 0 auto;
    width: 100%; }
    .lp_wrapper .innerBox .mv {
      position: relative; }
      .lp_wrapper .innerBox .mv .kv {
        max-width: 75vw;
        display: block;
        margin: 0 auto 0 15vh; }
        @media screen and (max-width: 1800px) {
          .lp_wrapper .innerBox .mv .kv {
            width: 60vw; } }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .innerBox .mv .kv {
            max-width: 100%;
            width: 100%;
            margin: 0 auto; } }
    .lp_wrapper .innerBox .ttl {
      position: absolute;
      top: 50vh;
      right: 20vh; }
      .lp_wrapper .innerBox .ttl h1, .lp_wrapper .innerBox .ttl p {
        overflow: hidden; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .innerBox .ttl {
          top: 50%;
          transform: translateY(-50%);
          right: 5%; } }
      @media screen and (max-width: 800px) {
        .lp_wrapper .innerBox .ttl {
          top: auto;
          right: auto;
          transform: translate(0);
          bottom: 48px;
          left: 48px; } }
      @media screen and (max-width: 600px) {
        .lp_wrapper .innerBox .ttl {
          bottom: 20px;
          left: 20px; } }
      .lp_wrapper .innerBox .ttl .line-item {
        display: block;
        transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.6s ease-out;
        opacity: 0;
        transform: translateY(100%); }
      .lp_wrapper .innerBox .ttl .line-item.slide-in {
        opacity: 1;
        transform: translateY(0); }
      .lp_wrapper .innerBox .ttl h1 {
        font-family: "noto-sans", sans-serif;
        font-size: 1.3em;
        line-height: 3.5;
        letter-spacing: 1px;
        text-align: left; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .innerBox .ttl h1 {
            font-size: 0.8em; } }
        @media screen and (max-width: 600px) {
          .lp_wrapper .innerBox .ttl h1 {
            font-size: 3vw !important; } }
        .lp_wrapper .innerBox .ttl h1 .line-item {
          transition: transform 1.2s cubic-bezier(0.25, 1, 0.5, 1), opacity 1.2s ease-out; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .innerBox .ttl h1 img {
            max-width: 120px; } }
      .lp_wrapper .innerBox .ttl p {
        font-size: 0.9em;
        font-family: "noto-sans", sans-serif;
        line-height: 1.8;
        letter-spacing: 0.05em; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .innerBox .ttl p {
            font-size: .6em; } }
        @media screen and (max-width: 600px) {
          .lp_wrapper .innerBox .ttl p {
            font-size: 2.2vw !important; } }
  .lp_wrapper .js-modal-open {
    position: relative;
    display: block; }
    .lp_wrapper .js-modal-open::after, .lp_wrapper .js-modal-open::before {
      position: absolute;
      content: "";
      bottom: 20px;
      left: 20px;
      width: 30px;
      height: 30px;
      background: url("../images/SVG/plus.svg");
      background-size: cover;
      z-index: 200;
      filter: brightness(0) invert(1); }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .js-modal-open::after, .lp_wrapper .js-modal-open::before {
          width: 20px;
          height: 20px;
          bottom: 10px;
          left: 10px; } }
    .lp_wrapper .js-modal-open.right::after, .lp_wrapper .js-modal-open.right::before {
      left: auto;
      right: 20px; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .js-modal-open.right::after, .lp_wrapper .js-modal-open.right::before {
          right: 10px; } }
    .lp_wrapper .js-modal-open.top_right::before, .lp_wrapper .js-modal-open.top_right::after {
      left: auto;
      right: 20px;
      bottom: auto;
      top: 20px; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .js-modal-open.top_right::before, .lp_wrapper .js-modal-open.top_right::after {
          right: 10px;
          top: 10px; } }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .js-modal-open.sp_right::before, .lp_wrapper .js-modal-open.sp_right::after {
        right: 10px;
        left: auto; } }
  .lp_wrapper section {
    margin: 20vh auto; }
    @media screen and (max-width: 1080px) {
      .lp_wrapper section {
        margin: 10vh auto; } }
  @media screen and (max-width: 1080px) {
    .lp_wrapper .box {
      width: 85%;
      margin: 10vh 0 0 auto; } }
  .lp_wrapper .box1 {
    display: flex;
    width: fit-content;
    max-width: 80%;
    align-items: flex-start;
    justify-content: space-between;
    flex-wrap: wrap; }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .box1 {
        flex-direction: column;
        max-width: 100%; } }
    .lp_wrapper .box1 .block {
      width: 56%;
      max-width: 800px; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box1 .block {
          width: 90%; } }
      .lp_wrapper .box1 .block:nth-child(2) {
        width: 40%;
        padding-top: 320px; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .box1 .block:nth-child(2) {
            width: 70%;
            padding-top: 0;
            margin: 10vh auto; } }
    .lp_wrapper .box1 .itemBox {
      width: 100%;
      margin-top: 0; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box1 .itemBox {
          width: 80%;
          margin: 0 auto; } }
      .lp_wrapper .box1 .itemBox div {
        width: 56%;
        max-width: 800px; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .box1 .itemBox div {
            width: 100%; } }
  .lp_wrapper .box2 {
    max-width: 80%;
    display: flex;
    width: fit-content;
    align-items: flex-end;
    justify-content: space-between; }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .box2 {
        flex-direction: column;
        align-items: flex-start; } }
    .lp_wrapper .box2 .block {
      width: 60%;
      max-width: 800px; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box2 .block {
          width: 90%; } }
      .lp_wrapper .box2 .block:nth-child(2) {
        width: 30%;
        display: flex;
        flex-direction: column;
        max-width: 470px; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .box2 .block:nth-child(2) {
            max-width: none;
            width: 100%;
            display: block;
            margin-top: 10vh; }
            .lp_wrapper .box2 .block:nth-child(2) a {
              display: block; }
              .lp_wrapper .box2 .block:nth-child(2) a img {
                width: 55%;
                display: block; }
                .lp_wrapper .box2 .block:nth-child(2) a img.right {
                  margin: 0 0 0 auto; }
                .lp_wrapper .box2 .block:nth-child(2) a img.left {
                  margin: -40% auto 0 0; }
              .lp_wrapper .box2 .block:nth-child(2) a::after, .lp_wrapper .box2 .block:nth-child(2) a::before {
                right: auto;
                left: 10px; } }
    .lp_wrapper .box2 .itemBox {
      margin-bottom: 10%; }
      .lp_wrapper .box2 .itemBox.pc {
        display: block; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .box2 .itemBox.pc {
            display: none; } }
      .lp_wrapper .box2 .itemBox.sp {
        display: none; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .box2 .itemBox.sp {
            display: block;
            width: 100%; } }
  .lp_wrapper .box3 {
    max-width: 80%;
    display: flex;
    width: fit-content;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap; }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .box3 {
        max-width: 100%;
        align-items: flex-start;
        justify-content: center; } }
    .lp_wrapper .box3 .block {
      width: 30%;
      max-width: 470px; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box3 .block {
          width: 50%;
          max-width: none;
          order: 2; } }
      .lp_wrapper .box3 .block:nth-child(2) {
        width: 60%;
        max-width: 800px; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .box3 .block:nth-child(2) {
            width: 50%;
            order: 1; } }
    .lp_wrapper .box3 .itemBox {
      width: 100%;
      display: flex;
      justify-content: flex-end;
      margin-top: 5%; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box3 .itemBox {
          width: 80%;
          order: 3; } }
      .lp_wrapper .box3 .itemBox div {
        width: 60%;
        max-width: 800px; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .box3 .itemBox div {
            width: 100%; } }
  .lp_wrapper .box4 {
    display: flex;
    width: fit-content;
    align-items: flex-start;
    justify-content: space-between; }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .box4 {
        width: 80%;
        flex-direction: column; } }
    .lp_wrapper .box4 .block {
      width: 50%; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box4 .block {
          width: 100%; } }
  .lp_wrapper .box5 {
    width: 90%; }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .box5 {
        width: 100%; } }
    @media screen and (max-width: 1800px) {
      .lp_wrapper .box5 div:nth-child(1) {
        width: 65%; } }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .box5 div:nth-child(1) {
        width: 100%; } }
    .lp_wrapper .box5 div:nth-child(2) {
      width: fit-content;
      margin: -700px 0 0 auto; }
      @media screen and (max-width: 1800px) {
        .lp_wrapper .box5 div:nth-child(2) {
          width: 45%;
          margin-top: -400px; } }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box5 div:nth-child(2) {
          width: 75%;
          margin: 10vh 10% 0 auto; } }
  @media screen and (max-width: 1080px) {
    .lp_wrapper .box5_2 {
      width: 85%;
      margin: 10vh auto 0 0; } }
  .lp_wrapper .box6 {
    max-width: 80%; }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .box6 {
        max-width: 100%; } }
    .lp_wrapper .box6 .flex {
      margin: 0 auto;
      display: flex;
      width: fit-content;
      align-items: flex-start;
      justify-content: space-between; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box6 .flex {
          flex-direction: column; } }
      .lp_wrapper .box6 .flex .block {
        max-width: 470px; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .box6 .flex .block {
            width: 70%;
            margin: 0 0 0 auto; }
            .lp_wrapper .box6 .flex .block a::after, .lp_wrapper .box6 .flex .block a::before {
              left: auto;
              right: 10px; } }
        .lp_wrapper .box6 .flex .block:nth-child(2) {
          max-width: 974px;
          margin-left: 10%;
          padding-top: 10%; }
          @media screen and (max-width: 1080px) {
            .lp_wrapper .box6 .flex .block:nth-child(2) {
              width: 80%; }
              .lp_wrapper .box6 .flex .block:nth-child(2) a::after, .lp_wrapper .box6 .flex .block:nth-child(2) a::before {
                left: 10px;
                right: auto; } }
    .lp_wrapper .box6 .itemBox {
      max-width: 650px;
      margin-left: 7%; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box6 .itemBox {
          width: 80%;
          margin: 10% auto; } }
  .lp_wrapper .box7 {
    width: 80%; }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .box7 {
        width: 100%; } }
    .lp_wrapper .box7 .block1 {
      max-width: 974px;
      margin: 0 0 0 auto;
      position: relative;
      z-index: 10; }
      @media screen and (max-width: 1800px) {
        .lp_wrapper .box7 .block1 {
          width: 65%; } }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box7 .block1 {
          width: 85%; } }
    .lp_wrapper .box7 .block2 {
      position: relative;
      width: 95%; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box7 .block2 {
          width: 90%;
          margin: 10vh auto; } }
      .lp_wrapper .box7 .block2 div:nth-child(1) {
        margin-top: -10%;
        position: relative;
        z-index: 2; }
        @media screen and (max-width: 1800px) {
          .lp_wrapper .box7 .block2 div:nth-child(1) {
            width: 45%; } }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .box7 .block2 div:nth-child(1) {
            margin-top: 10vh;
            width: 60%; } }
      .lp_wrapper .box7 .block2 div:nth-child(2) {
        text-align: right;
        margin: -20% 0 0 auto;
        position: relative;
        z-index: 1; }
        @media screen and (max-width: 1800px) {
          .lp_wrapper .box7 .block2 div:nth-child(2) {
            width: 63%; } }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .box7 .block2 div:nth-child(2) {
            width: 60%;
            margin-top: -10%; } }
  .lp_wrapper .box8 {
    display: flex;
    width: 90%;
    align-items: flex-start;
    justify-content: space-between; }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .box8 {
        flex-direction: column; } }
    .lp_wrapper .box8 div.block1 {
      width: calc(100%/2 - 2%); }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box8 div.block1 {
          width: 100%;
          display: flex;
          align-items: flex-start;
          justify-content: center; } }
      .lp_wrapper .box8 div.block1 a {
        display: block;
        width: 60%; }
        @media screen and (max-width: 1080px) {
          .lp_wrapper .box8 div.block1 a {
            width: 50%; } }
        .lp_wrapper .box8 div.block1 a:nth-child(1) {
          position: relative;
          z-index: 2; }
        .lp_wrapper .box8 div.block1 a:nth-child(2) {
          margin: -10% 0 0 auto;
          position: relative;
          z-index: 1;
          text-align: right; }
          @media screen and (max-width: 1080px) {
            .lp_wrapper .box8 div.block1 a:nth-child(2) {
              margin: auto; } }
    .lp_wrapper .box8 div.block2 {
      width: calc(100%/2 - 5%); }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .box8 div.block2 {
          width: 90%;
          margin: 0 auto; } }
  .lp_wrapper .itemBox {
    margin-top: 12%;
    width: 85%; }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .itemBox {
        width: 100%; } }
    .lp_wrapper .itemBox div {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      margin-bottom: 2.0em; }
      .lp_wrapper .itemBox div p {
        font-size: 1em !important;
        line-height: 1.5; }
        @media screen and (max-width: 1800px) {
          .lp_wrapper .itemBox div p {
            font-size: 0.8em !important; } }
        @media screen and (max-width: 600px) {
          .lp_wrapper .itemBox div p {
            font-size: 2.8vw !important; } }
        .lp_wrapper .itemBox div p span {
          font-size: 85%;
          display: block; }
          .lp_wrapper .itemBox div p span small {
            margin-left: 1.0em; }
        .lp_wrapper .itemBox div p br {
          display: none; }
          @media screen and (max-width: 600px) {
            .lp_wrapper .itemBox div p br {
              display: block; } }
      .lp_wrapper .itemBox div a {
        display: block;
        font-family: "noto-sans", sans-serif;
        font-size: 1em !important; }
        @media screen and (max-width: 1800px) {
          .lp_wrapper .itemBox div a {
            font-size: 0.8em !important; } }
        @media screen and (max-width: 600px) {
          .lp_wrapper .itemBox div a {
            font-size: 2.8vw !important; } }
        .lp_wrapper .itemBox div a span {
          font-size: 100%;
          border-bottom: 1px solid #3c463c; }
        .lp_wrapper .itemBox div a:hover span {
          border: none; }
  .lp_wrapper .btn {
    max-width: 600px;
    margin: 15vh auto; }
    @media screen and (max-width: 1080px) {
      .lp_wrapper .btn {
        margin: 10vh auto;
        width: 80%; } }
    .lp_wrapper .btn a {
      display: block;
      border: 1px solid #3c463c;
      font-size: 2.0em;
      text-align: center;
      font-family: "noto-sans", sans-serif;
      padding: .5em 0; }
      .lp_wrapper .btn a:hover {
        color: #fdfdf8;
        background: #3c463c; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .btn a {
          font-size: 1.5em; } }
      @media screen and (max-width: 600px) {
        .lp_wrapper .btn a {
          font-size: 4.5vw; } }
  .lp_wrapper footer {
    position: relative;
    background: none;
    padding: 0; }
    .lp_wrapper footer div {
      position: absolute;
      top: 15%;
      left: 20%; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper footer div {
          left: 50%;
          transform: translateX(-50%);
          text-align: center; } }
      .lp_wrapper footer div h2 {
        font-family: "noto-sans", sans-serif;
        font-size: 1.2em;
        font-weight: 600;
        line-height: 3.5;
        margin-bottom: 2.0em;
        color: #3c463c;
        border: none; }
        @media screen and (max-width: 600px) {
          .lp_wrapper footer div h2 {
            font-size: 3vw !important;
            text-align: center; } }
        @media screen and (max-width: 600px) {
          .lp_wrapper footer div h2 img {
            max-width: 110px; } }
      .lp_wrapper footer div p {
        font-family: "noto-sans", sans-serif;
        line-height: 1.8;
        font-size: 0.9em;
        color: #3c463c; }
        @media screen and (max-width: 600px) {
          .lp_wrapper footer div p {
            font-size: 3.0vw;
            line-height: 2.2; } }
  .lp_wrapper .modal {
    display: none;
    width: 100%;
    height: 100vh;
    position: fixed;
    top: 0;
    z-index: 9999; }
    .lp_wrapper .modal .modal__bg {
      background: rgba(0, 0, 0, 0.5);
      height: 100vh;
      position: absolute;
      width: 100%; }
    .lp_wrapper .modal .modal__content {
      left: 50%;
      position: absolute;
      top: 50%;
      transform: translate(-50%, -50%);
      max-width: calc(400px + (32px*2));
      width: fit-content;
      max-height: 90vh;
      background: #fdfdf8;
      height: fit-content; }
      @media screen and (max-width: 1080px) {
        .lp_wrapper .modal .modal__content {
          min-width: auto;
          width: 90%; } }
      @media screen and (max-width: 600px) {
        .lp_wrapper .modal .modal__content {
          max-height: 70vh; } }
      .lp_wrapper .modal .modal__content .itemList {
        max-height: 85vh;
        overflow-y: auto;
        padding: 32px; }
        @media screen and (max-width: 600px) {
          .lp_wrapper .modal .modal__content .itemList {
            max-height: 92vh;
            padding: 24px; } }
        .lp_wrapper .modal .modal__content .itemList .swiper, .lp_wrapper .modal .modal__content .itemList .swiper2 {
          overflow: hidden; }
          .lp_wrapper .modal .modal__content .itemList .swiper .swiper-slide, .lp_wrapper .modal .modal__content .itemList .swiper2 .swiper-slide {
            text-align: center; }
            .lp_wrapper .modal .modal__content .itemList .swiper .swiper-slide .detail, .lp_wrapper .modal .modal__content .itemList .swiper2 .swiper-slide .detail {
              text-align: left; }
          .lp_wrapper .modal .modal__content .itemList .swiper .swiper-pagination-bullet, .lp_wrapper .modal .modal__content .itemList .swiper2 .swiper-pagination-bullet {
            background-color: transparent;
            /* 背景色を透明に */
            border: 1px solid #3c463c;
            border-radius: 50%;
            height: 7px;
            opacity: 1;
            width: 7px; }
          .lp_wrapper .modal .modal__content .itemList .swiper .swiper-pagination-bullet-active, .lp_wrapper .modal .modal__content .itemList .swiper2 .swiper-pagination-bullet-active {
            height: 7px;
            width: 7px;
            background: #3c463c; }
          .lp_wrapper .modal .modal__content .itemList .swiper .swiper-button-next::after, .lp_wrapper .modal .modal__content .itemList .swiper .swiper-button-prev::after, .lp_wrapper .modal .modal__content .itemList .swiper2 .swiper-button-next::after, .lp_wrapper .modal .modal__content .itemList .swiper2 .swiper-button-prev::after {
            font-size: 16px;
            color: #3c463c; }
        .lp_wrapper .modal .modal__content .itemList .detail {
          margin-top: 24px;
          background: #fdfdf8; }
          .lp_wrapper .modal .modal__content .itemList .detail dl {
            display: flex;
            align-items: center;
            justify-content: flex-start;
            flex-wrap: wrap;
            margin-bottom: 24px;
            line-height: 1.8; }
            .lp_wrapper .modal .modal__content .itemList .detail dl dt {
              width: 22%;
              font-size: .85em;
              font-weight: 600; }
              @media screen and (max-width: 600px) {
                .lp_wrapper .modal .modal__content .itemList .detail dl dt {
                  font-size: 2.8vw; } }
            .lp_wrapper .modal .modal__content .itemList .detail dl dd {
              width: 78%;
              font-size: .9em; }
              @media screen and (max-width: 600px) {
                .lp_wrapper .modal .modal__content .itemList .detail dl dd {
                  font-size: 2.8vw;
                  white-space: nowrap;
                  overflow-x: hidden;
                  text-overflow: ellipsis; } }
              .lp_wrapper .modal .modal__content .itemList .detail dl dd span {
                font-size: 70%;
                margin-left: 1.0em; }
          .lp_wrapper .modal .modal__content .itemList .detail a {
            text-align: center;
            display: block;
            width: 98%;
            margin: 0 auto;
            padding: 1.0em 0;
            line-height: 1.0;
            font-family: "noto-sans", sans-serif;
            font-size: 1.2em;
            border: 1px solid #3c463c;
            letter-spacing: .1em; }
            @media screen and (max-width: 600px) {
              .lp_wrapper .modal .modal__content .itemList .detail a {
                font-size: 3.5vw; } }
            .lp_wrapper .modal .modal__content .itemList .detail a:hover {
              background: #3c463c;
              color: #fdfdf8 !important; }
    .lp_wrapper .modal .js-modal-close {
      font-size: 1.0em;
      position: absolute;
      top: 0;
      right: 0; }
      .lp_wrapper .modal .js-modal-close.closebtn {
        font-size: 2em !important;
        color: #fdfdf8 !important;
        text-align: center;
        height: 25px;
        line-height: 1.0;
        top: -1.0em; }
