@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&family=Noto+Sans:wght@400;500;700;900&display=swap");
/*--------------------
共通設定
----------------------*/
* {
  padding: 0;
  margin: 0; }

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom; }

a {
  text-decoration: none;
  color: #3c463c; }
  a.disabled {
    pointer-events: none;
    text-decoration: none; }
  a:hover {
    opacity: 0.8;
    transition: .4s; }

ul, ol {
  list-style: none; }

.pc {
  display: block; }
  @media screen and (max-width: 1050px) {
    .pc {
      display: none; } }

.sp {
  display: none; }
  @media screen and (max-width: 1050px) {
    .sp {
      display: block; } }

.en {
  font-family: "the-seasons", sans-serif !important; }

.eng {
  font-family: "Noto Sans", sans-serif !important; }

.ja {
  font-family: "toppan-bunkyu-gothic-pr6n", serif !important; }

body {
  overflow-x: hidden; }

/*--------------------------------------------*/
.lp_wrapper {
  margin: 0 auto;
  box-sizing: border-box;
  background: #fdfdf8;
  letter-spacing: 0.1em;
  color: #3c463c;
  font-size: 16px !important;
  text-align: center;
  font-family: "toppan-bunkyu-gothic-pr6n", 'Noto Sans', sans-serif;
  font-weight: normal;
  font-style: normal; }
  .lp_wrapper .hide {
    display: none; }
  .lp_wrapper .start {
    position: relative;
    height: 100vh; }
    .lp_wrapper .start img {
      max-height: 60vh;
      object-fit: cover;
      object-position: top; }
      @media screen and (max-width: 800px) {
        .lp_wrapper .start img {
          min-height: 60vh; } }
    .lp_wrapper .start h1 {
      position: absolute;
      font-size: 1em !important;
      text-align: left;
      font-weight: normal;
      width: fit-content;
      margin: 0 auto;
      color: #fff !important;
      top: 20%;
      left: 50%;
      transform: translateX(-50%); }
      @media screen and (max-width: 800px) {
        .lp_wrapper .start h1 {
          font-size: 0.8em !important;
          top: 25%; } }
      .lp_wrapper .start h1 span {
        font-size: 350% !important;
        color: #fff !important;
        display: block;
        margin-top: 10px; }
        @media screen and (max-width: 800px) {
          .lp_wrapper .start h1 span {
            font-size: 300% !important; } }
    .lp_wrapper .start .txt {
      height: 40vh;
      position: relative; }
      .lp_wrapper .start .txt div {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 100%; }
        .lp_wrapper .start .txt div p {
          margin: 0 auto 2%; }
          @media screen and (max-width: 800px) {
            .lp_wrapper .start .txt div p {
              margin-bottom: 5%; } }
  .lp_wrapper h2 {
    font-family: "toppan-bunkyu-gothic-pr6n", serif;
    font-size: 3em !important;
    letter-spacing: 0.2em !important;
    margin-top: 10% !important;
    border-bottom: none !important;
    padding: 0;
    text-align: center !important; }
    @media screen and (max-width: 800px) {
      .lp_wrapper h2 {
        font-size: 1.2em !important;
        margin-top: 10%; } }
  .lp_wrapper p {
    font-size: 1em !important;
    line-height: 1.8;
    margin: 2.0em auto; }
    @media screen and (max-width: 800px) {
      .lp_wrapper p {
        font-size: 0.9em !important; } }
  .lp_wrapper img {
    margin: 0 auto; }
  .lp_wrapper .choose_box {
    width: 100%;
    background: #fff; }
    .lp_wrapper .choose_box .q_box {
      background: #fdfdf8; }
      @media screen and (max-width: 800px) {
        .lp_wrapper .choose_box .q_box img {
          max-width: 200px;
          width: 80%; } }
      .lp_wrapper .choose_box .q_box .ttl {
        position: relative; }
        .lp_wrapper .choose_box .q_box .ttl h3 {
          background: #7A8C5B;
          font-size: 1.2em !important;
          font-weight: normal;
          padding: 2em 0 2.5em !important;
          line-height: 1.0;
          width: 100%;
          color: #fff; }
        .lp_wrapper .choose_box .q_box .ttl p {
          position: absolute;
          bottom: -30px;
          left: 50%;
          transform: translateX(-50%);
          font-size: 1.2em !important;
          background: #fff;
          border: 1px solid #7A8C5B;
          border-radius: 50%;
          line-height: 3.0;
          width: 60px;
          height: 60px;
          margin: 0; }
          @media screen and (max-width: 800px) {
            .lp_wrapper .choose_box .q_box .ttl p {
              line-height: 4.2; } }
      .lp_wrapper .choose_box .q_box h2 {
        font-size: 1.1em !important;
        font-weight: 400;
        font-weight: bold;
        margin: 7% auto 2% !important; }
        @media screen and (max-width: 800px) {
          .lp_wrapper .choose_box .q_box h2 {
            margin: 15% auto 7% !important; } }
      .lp_wrapper .choose_box .q_box ul {
        width: 100%;
        max-width: 600px;
        margin: 3% auto 0;
        display: flex;
        align-items: stretch;
        justify-content: center;
        flex-wrap: wrap; }
        @media screen and (max-width: 800px) {
          .lp_wrapper .choose_box .q_box ul {
            margin-top: 10%; } }
        .lp_wrapper .choose_box .q_box ul li {
          width: calc(100%/2 - 3%);
          border: 1px solid #3c463c;
          margin: 1.5%;
          background: #7A8C5B; }
          .lp_wrapper .choose_box .q_box ul li a {
            width: 100%;
            height: 100px;
            display: block;
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center; }
            @media screen and (max-width: 800px) {
              .lp_wrapper .choose_box .q_box ul li a {
                height: 80px; } }
            .lp_wrapper .choose_box .q_box ul li a p {
              color: #fff;
              font-size: 0.9em !important;
              margin: 0; }
              @media screen and (max-width: 800px) {
                .lp_wrapper .choose_box .q_box ul li a p {
                  font-size: 0.8em !important; } }

.kekka {
  position: relative;
  /*height: 100vh;*/
  margin: 0 auto; }
  .kekka img {
    object-fit: cover;
    object-position: bottom;
    height: 70vh; }
    @media screen and (max-width: 800px) {
      .kekka img {
        object-fit: cover;
        max-height: 60vh;
        min-height: 60vh;
        object-position: top; } }
  .kekka h1 {
    position: absolute;
    font-size: 1em !important;
    text-align: left;
    font-weight: normal;
    width: fit-content;
    margin: 0 auto;
    color: #fff !important;
    top: 2.0em;
    right: 2.0em; }
    @media screen and (max-width: 800px) {
      .kekka h1 {
        font-size: 0.8em !important; } }
    .kekka h1 span {
      font-size: 300% !important;
      color: #fff !important;
      display: block;
      margin-top: 10px; }
  .kekka p {
    margin: 0 auto; }
  .kekka .msg {
    height: 30vh;
    position: relative; }
    @media screen and (max-width: 800px) {
      .kekka .msg {
        padding: 25% 0 0;
        height: 40vh; } }
    .kekka .msg div {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      width: 100%; }
      .kekka .msg div a.resultBtn {
        font-size: 0.9em;
        color: #fff !important;
        background: #7A8C5B;
        padding: 0.7em 3.0em;
        border-radius: 50vh;
        margin: 1% auto 3%;
        max-width: 200px;
        display: block; }
        @media screen and (max-width: 800px) {
          .kekka .msg div a.resultBtn {
            margin-bottom: 7%; } }
      .kekka .msg div p.en {
        font-size: 110%; }

.result_box {
  width: 100%;
  text-align: left;
  max-width: 600px;
  margin: 0 auto; }
  .result_box .result {
    margin: 0 auto; }
    .result_box .result .type_mv {
      position: relative; }
      .result_box .result .type_mv .type_txt {
        position: absolute;
        top: 10%;
        left: 50%;
        transform: translateX(-50%);
        width: 70%; }
        .result_box .result .type_mv .type_txt h2 {
          line-height: 1.2;
          font-size: 2em !important;
          padding-left: 2.5em !important;
          position: relative;
          text-align: left !important;
          letter-spacing: 0.2em !important;
          font-weight: normal; }
          @media screen and (max-width: 800px) {
            .result_box .result .type_mv .type_txt h2 {
              font-size: 6vw !important; } }
          .result_box .result .type_mv .type_txt h2 span {
            font-size: 40% !important; }
          .result_box .result .type_mv .type_txt h2::before {
            position: absolute;
            content: "type";
            font-family: "Noto Sans", sans-serif;
            font-size: 45%;
            line-height: 2.0;
            letter-spacing: 0.1em;
            font-weight: normal;
            top: 10%;
            left: 0; }
          .result_box .result .type_mv .type_txt h2::after {
            position: absolute;
            content: "";
            height: 90%;
            width: .5px;
            background: #3c463c;
            top: 10%;
            left: 1.2em;
            transform: rotate(40deg); }
        .result_box .result .type_mv .type_txt p {
          font-size: 0.9em !important;
          text-align: left; }
          @media screen and (max-width: 800px) {
            .result_box .result .type_mv .type_txt p {
              font-size: 2.8vw !important; } }
    .result_box .result .box {
      width: 80%;
      margin: 15% auto; }
      @media screen and (max-width: 800px) {
        .result_box .result .box {
          width: 90%; } }
      .result_box .result .box p {
        font-size: 0.9em !important; }
        @media screen and (max-width: 800px) {
          .result_box .result .box p {
            font-size: 0.8em !important; } }
        .result_box .result .box p.center {
          text-align: center;
          margin-bottom: 1.0em; }
      .result_box .result .box .center {
        text-align: center;
        margin: 3.0em auto; }
      .result_box .result .box .list {
        display: flex;
        align-items: center;
        justify-content: space-evenly; }
        .result_box .result .box .list div {
          width: calc(100%/5 - 4%); }
          @media screen and (max-width: 800px) {
            .result_box .result .box .list div {
              width: calc(100%/5 - 2%); } }
      .result_box .result .box .color_chip {
        max-height: 60px; }
      .result_box .result .box .color_list {
        display: flex;
        justify-content: space-between;
        align-items: center;
        flex-wrap: wrap; }
        .result_box .result .box .color_list a {
          width: calc(100%/2 - 3%); }
          .result_box .result .box .color_list a p {
            margin: -1.0em auto 2.0em;
            font-weight: bold;
            font-size: 1.2em !important;
            letter-spacing: .2em;
            line-height: 1.0; }
            @media screen and (max-width: 800px) {
              .result_box .result .box .color_list a p {
                font-size: 1em !important; } }
            .result_box .result .box .color_list a p span {
              font-weight: normal;
              font-size: 60% !important;
              letter-spacing: .1em;
              font-family: "toppan-bunkyu-gothic-pr6n", serif; }
    .result_box .result a.result_btn {
      display: block;
      width: 100%;
      color: #fff !important;
      background: #7A8C5B;
      padding: 1.5em;
      font-size: 1em !important;
      line-height: 1.0;
      text-align: center; }

p.attention {
  font-size: 0.6em !important;
  text-align: center;
  margin: 10% auto; }

.product_sns {
  max-width: 600px;
  margin: 10% auto;
  width: 90%; }
  .product_sns p.center {
    text-align: center !important;
    margin: 1.0em auto;
    font-size: 0.8em !important;
    border-bottom: 1px solid #3c463c;
    padding-bottom: 1em !important;
    width: 100%; }
  .product_sns .product_sns_box {
    max-width: 350px;
    width: 100%;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-around; }
