@charset "UTF-8";
/*--------------------
共通設定
----------------------*/
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

a {
  text-decoration: none;
  color: #4d4d4d; }
  a.disabled {
    pointer-events: none;
    text-decoration: none; }

ul, ol {
  list-style: none; }

.pc {
  display: block; }
  @media screen and (max-width: 769px) {
    .pc {
      display: none; } }

.sp {
  display: none; }
  @media screen and (max-width: 769px) {
    .sp {
      display: block; } }

body {
  overflow-x: hidden; }

.mainBox {
  margin: 0 auto !important; }

.fadein {
  opacity: 0;
  transition: 1.5s; }
  .fadein.scroll {
    opacity: 1; }

.fadeIn {
  opacity: 0; }

/*--------------------------------------------*/
.lp_wrapper {
  max-width: 600px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 0;
  letter-spacing: 1px;
  color: #4d4d4d;
  font-size: 16px;
  text-align: center;
  font-family: "source-han-sans-japanese", sans-serif;
  font-weight: 400;
  font-style: normal; }
  .lp_wrapper section {
    margin: 0 auto 25%; }
  .lp_wrapper .mv {
    position: relative;
    margin: 0 auto; }
    .lp_wrapper .mv .anime_right.is_active {
      animation: slideIn 2.0s forwards; }
    .lp_wrapper .mv .anime_left.is_active {
      animation: slideInleft 2.0s forwards; }
    .lp_wrapper .mv .box {
      position: relative; }
      .lp_wrapper .mv .box .txt {
        position: absolute;
        right: 10%;
        bottom: 20%;
        max-width: 150px; }
        @media screen and (max-width: 500px) {
          .lp_wrapper .mv .box .txt {
            max-width: 110px; } }
    .lp_wrapper .mv .flex_left {
      display: flex;
      align-items: flex-start;
      justify-content: space-between; }
      .lp_wrapper .mv .flex_left div {
        width: 20%; }
        @media screen and (max-width: 500px) {
          .lp_wrapper .mv .flex_left div {
            width: 25%; } }
        .lp_wrapper .mv .flex_left div:first-child {
          width: 80%;
          position: relative; }
          @media screen and (max-width: 500px) {
            .lp_wrapper .mv .flex_left div:first-child {
              width: 75%; } }
        .lp_wrapper .mv .flex_left div.logo {
          padding: 1.0em 1.0em 0 2.0em; }
          @media screen and (max-width: 500px) {
            .lp_wrapper .mv .flex_left div.logo {
              padding-top: 0.7em;
              padding-right: 0; } }
          .lp_wrapper .mv .flex_left div.logo img {
            max-width: 50px; }
            @media screen and (max-width: 500px) {
              .lp_wrapper .mv .flex_left div.logo img {
                width: 40px; } }
    .lp_wrapper .mv .flex_right {
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 5%; }
      .lp_wrapper .mv .flex_right div:last-child {
        width: 70%; }
      .lp_wrapper .mv .flex_right div.txt {
        width: 30%;
        padding-left: 2.0em; }
        @media screen and (max-width: 500px) {
          .lp_wrapper .mv .flex_right div.txt {
            padding-left: 1.5em; } }
        .lp_wrapper .mv .flex_right div.txt img {
          max-width: 150px;
          padding-bottom: 2.0em; }
          @media screen and (max-width: 500px) {
            .lp_wrapper .mv .flex_right div.txt img {
              max-width: 110px; } }
  .lp_wrapper h2 {
    font-family: "toppan-bunkyu-gothic-pr6n", serif;
    font-size: 1.2em;
    margin: 1.5em auto 0.5em; }
    @media screen and (max-width: 500px) {
      .lp_wrapper h2 {
        margin-top: 3.0em;
        font-size: 4.0vw; } }
    .lp_wrapper h2 span {
      font-family: "source-han-sans-japanese", sans-serif;
      display: block;
      font-weight: 400;
      font-size: 70%;
      line-height: 1.2; }
  .lp_wrapper .block {
    margin: 10% auto; }
    .lp_wrapper .block .catch {
      max-width: 300px;
      width: 70%;
      margin: 0 auto 5%; }
      @media screen and (max-width: 500px) {
        .lp_wrapper .block .catch {
          width: 45%; } }
    .lp_wrapper .block p.line {
      font-size: 1.0em;
      margin: 10% auto; }
      @media screen and (max-width: 500px) {
        .lp_wrapper .block p.line {
          font-size: 3.5vw; } }
      .lp_wrapper .block p.line span {
        position: relative; }
        .lp_wrapper .block p.line span::before {
          content: "";
          background: url("../images/SVG/line.svg") no-repeat;
          width: 100%;
          height: 15px;
          bottom: -0.5em;
          position: absolute;
          z-index: -1; }
    .lp_wrapper .block .txt {
      margin: 0 auto;
      width: 80%; }
    .lp_wrapper .block .txt_2 {
      margin: 0 auto;
      max-width: 350px;
      width: 70%; }
    .lp_wrapper .block .point {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
      background: #f1e9de;
      border-radius: 0.5em;
      width: 90%;
      margin: 0 auto 5%; }
      @media screen and (max-width: 500px) {
        .lp_wrapper .block .point {
          width: 95%; } }
      .lp_wrapper .block .point .p_img {
        padding: 1.0em;
        width: 35%; }
        @media screen and (max-width: 500px) {
          .lp_wrapper .block .point .p_img {
            padding: 0.5em; } }
        .lp_wrapper .block .point .p_img.size {
          padding: 0; }
      .lp_wrapper .block .point .p_txt {
        padding: 1.5em;
        width: 65%; }
        @media screen and (max-width: 500px) {
          .lp_wrapper .block .point .p_txt {
            padding: 1.0em 0 1.0em 1.0em; } }
        .lp_wrapper .block .point .p_txt p {
          text-align: left; }
          .lp_wrapper .block .point .p_txt p.p_1 {
            width: fit-content;
            background: #fff;
            border-radius: 50vh;
            padding: 0.5em 1.0em;
            font-size: 0.7em; }
            @media screen and (max-width: 500px) {
              .lp_wrapper .block .point .p_txt p.p_1 {
                font-size: 2.5vw;
                letter-spacing: 0; } }
          .lp_wrapper .block .point .p_txt p.p_2 {
            font-size: 0.9em;
            line-height: 2.0;
            margin: 1.0em 0.5em 1.0em 0;
            width: fit-content;
            position: relative; }
            @media screen and (max-width: 500px) {
              .lp_wrapper .block .point .p_txt p.p_2 {
                margin: 1.0em 0;
                font-size: 2.9vw;
                line-height: 1.8;
                letter-spacing: 0; } }
            .lp_wrapper .block .point .p_txt p.p_2 img {
              position: absolute;
              right: -1.5em;
              bottom: -40px; }
              @media screen and (max-width: 500px) {
                .lp_wrapper .block .point .p_txt p.p_2 img {
                  max-width: 50px;
                  bottom: -27px; }
                  .lp_wrapper .block .point .p_txt p.p_2 img.first {
                    right: 0; } }
              .lp_wrapper .block .point .p_txt p.p_2 img.is_active {
                animation: slideIntop .5s forwards;
                animation-delay: 1.0s; }
    .lp_wrapper .block.lineup {
      margin: 20% auto 10%;
      width: 80%; }
      @media screen and (max-width: 500px) {
        .lp_wrapper .block.lineup {
          width: 85%; } }
      .lp_wrapper .block.lineup .center {
        margin: 10% auto; }
      .lp_wrapper .block.lineup ul.link {
        display: flex;
        justify-content: space-between;
        align-items: center;
        flex-wrap: wrap; }
        .lp_wrapper .block.lineup ul.link li {
          width: calc(100%/2 - 3%);
          margin-bottom: 6%;
          border-radius: 1.0em;
          overflow: hidden; }
          .lp_wrapper .block.lineup ul.link li a {
            display: block; }
            .lp_wrapper .block.lineup ul.link li a img {
              transform: scale(1); }
              .lp_wrapper .block.lineup ul.link li a img:hover {
                transition: .4s;
                transform: scale(1.1); }
            .lp_wrapper .block.lineup ul.link li a p {
              font-size: 0.7em;
              line-height: 1.8;
              padding: 1.5em 0 2.5em;
              background: #ccc5be;
              position: relative;
              margin: 0; }
              @media screen and (max-width: 500px) {
                .lp_wrapper .block.lineup ul.link li a p {
                  font-size: 2.7vw; } }
              .lp_wrapper .block.lineup ul.link li a p span {
                font-family: "toppan-bunkyu-gothic-pr6n", serif;
                font-weight: 600;
                display: block;
                font-size: 120%; }
                @media screen and (max-width: 500px) {
                  .lp_wrapper .block.lineup ul.link li a p span {
                    font-size: 115%;
                    letter-spacing: 0; } }
              .lp_wrapper .block.lineup ul.link li a p::before {
                position: absolute;
                content: "▼";
                bottom: 0.5em;
                right: 1.0em;
                font-size: 16px;
                line-height: 1.0; }
                @media screen and (max-width: 500px) {
                  .lp_wrapper .block.lineup ul.link li a p::before {
                    font-size: 14px; } }
      .lp_wrapper .block.lineup .c_list {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        flex-wrap: wrap; }
        .lp_wrapper .block.lineup .c_list div {
          width: calc(100%/4 - 2%); }
          @media screen and (max-width: 500px) {
            .lp_wrapper .block.lineup .c_list div {
              width: calc(100%/4 - 1%); } }
          .lp_wrapper .block.lineup .c_list div p {
            font-size: 0.65em;
            line-height: 1.2;
            text-align: left;
            letter-spacing: 0;
            width: fit-content;
            margin: 0.5em auto; }
            @media screen and (max-width: 500px) {
              .lp_wrapper .block.lineup .c_list div p {
                font-size: 0.6em; } }
  .lp_wrapper .itemBox {
    padding-top: 60px;
    margin: 0 auto 15%;
    width: 90%; }
    .lp_wrapper .itemBox h2 {
      margin-bottom: 2.0em; }
      @media screen and (max-width: 500px) {
        .lp_wrapper .itemBox h2 {
          margin-top: 0; } }
    .lp_wrapper .itemBox .max {
      margin-bottom: 5%; }
    .lp_wrapper .itemBox .flex_img {
      display: flex;
      align-items: center;
      justify-content: space-between; }
      .lp_wrapper .itemBox .flex_img div:first-child {
        width: 50%; }
        @media screen and (max-width: 500px) {
          .lp_wrapper .itemBox .flex_img div:first-child {
            width: 56%; } }
        .lp_wrapper .itemBox .flex_img div:first-child img {
          object-fit: cover; }
      .lp_wrapper .itemBox .flex_img div:last-child {
        width: 46%; }
        @media screen and (max-width: 500px) {
          .lp_wrapper .itemBox .flex_img div:last-child {
            width: 40%; } }
        .lp_wrapper .itemBox .flex_img div:last-child img {
          width: 80%;
          margin: 0 auto;
          padding: 1.0em 1.0em 0; }
          @media screen and (max-width: 500px) {
            .lp_wrapper .itemBox .flex_img div:last-child img {
              width: 90%;
              padding: 0.5em 0 0; } }
      .lp_wrapper .itemBox .flex_img div .detail {
        margin: 2.0em auto 0;
        border: 3px dashed #f1e9de;
        position: relative;
        padding: 1.5em 0.5em 1.0em;
        width: 90%; }
        @media screen and (max-width: 500px) {
          .lp_wrapper .itemBox .flex_img div .detail {
            width: 100%;
            padding: 1.0em 0.2em 0.5em;
            border: 2px dashed #f1e9de; } }
        .lp_wrapper .itemBox .flex_img div .detail p {
          text-align: left;
          font-size: .8em;
          line-height: 1.8; }
          @media screen and (max-width: 500px) {
            .lp_wrapper .itemBox .flex_img div .detail p {
              letter-spacing: 0;
              font-size: 2.9vw; } }
          .lp_wrapper .itemBox .flex_img div .detail p.ttl {
            font-size: 0.8em;
            font-family: "toppan-bunkyu-gothic-pr6n", serif;
            color: #fff;
            background: #ccc5be;
            border-radius: 50vh;
            padding: 0.5em 1.0em;
            line-height: 1.0;
            width: fit-content;
            position: absolute;
            top: -1.0em;
            left: -0.2em; }
            @media screen and (max-width: 500px) {
              .lp_wrapper .itemBox .flex_img div .detail p.ttl {
                top: -2.0em;
                font-size: 2.8vw;
                font-weight: 400;
                letter-spacing: 1px; } }
    .lp_wrapper .itemBox .txtBox {
      font-size: 0.9em;
      margin: 5% auto;
      line-height: 1.8;
      text-align: left; }
      @media screen and (max-width: 500px) {
        .lp_wrapper .itemBox .txtBox {
          font-size: 3.0vw; } }
    .lp_wrapper .itemBox .btn {
      border: 1px solid #4d4d4d;
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 1.0em; }
      .lp_wrapper .itemBox .btn p {
        font-size: 1.2em;
        font-family: "toppan-bunkyu-gothic-pr6n", serif;
        font-weight: 600;
        text-align: left;
        line-height: 1.5; }
        @media screen and (max-width: 500px) {
          .lp_wrapper .itemBox .btn p {
            font-size: 4.0vw; } }
        .lp_wrapper .itemBox .btn p span {
          display: block;
          font-size: 70%;
          font-family: "source-han-sans-japanese", sans-serif;
          font-weight: 400; }
        .lp_wrapper .itemBox .btn p a {
          font-weight: 400;
          font-family: "source-han-sans-japanese", sans-serif;
          font-size: 70%;
          background: #ccc5be;
          border-radius: 50vh;
          padding: 0.5em 2.0em; }
          @media screen and (max-width: 500px) {
            .lp_wrapper .itemBox .btn p a {
              padding: 0.5em 2.0em 0.7em; } }
          .lp_wrapper .itemBox .btn p a:hover {
            transition: .4s;
            opacity: 0.7; }
  .lp_wrapper .foot {
    width: 90%;
    margin: 0 auto; }
    .lp_wrapper .foot .btn {
      margin-top: 10%; }
      .lp_wrapper .foot .btn a {
        display: block;
        background: #ccc5be;
        padding: 0.5em 2.0em;
        line-height: 1.5;
        border-radius: 50vh;
        width: fit-content;
        margin: 0 auto; }
        @media screen and (max-width: 500px) {
          .lp_wrapper .foot .btn a {
            font-size: 3.5vw; } }
        .lp_wrapper .foot .btn a:hover {
          opacity: .7;
          transition: .4s; }

@keyframes slideIn {
  0% {
    opacity: 0;
    transform: translate(50%, 0); }
  100% {
    opacity: 1;
    transform: translate(0, 0); } }
@keyframes slideInleft {
  0% {
    opacity: 0;
    transform: translate(-50%, 0); }
  100% {
    opacity: 1;
    transform: translate(0, 0); } }
@keyframes slideIntop {
  0% {
    opacity: 0;
    transform: translateY(50px); }
  100% {
    opacity: 1;
    transform: translate(0); } }
